1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499105001050110502105031050410505105061050710508105091051010511105121051310514105151051610517105181051910520105211052210523105241052510526105271052810529105301053110532105331053410535105361053710538105391054010541105421054310544105451054610547105481054910550105511055210553105541055510556105571055810559105601056110562105631056410565105661056710568105691057010571105721057310574105751057610577105781057910580105811058210583105841058510586105871058810589105901059110592105931059410595105961059710598105991060010601106021060310604106051060610607106081060910610106111061210613106141061510616106171061810619106201062110622106231062410625106261062710628106291063010631106321063310634106351063610637106381063910640106411064210643106441064510646106471064810649106501065110652106531065410655106561065710658106591066010661106621066310664106651066610667106681066910670106711067210673106741067510676106771067810679106801068110682106831068410685106861068710688106891069010691106921069310694106951069610697106981069910700107011070210703107041070510706107071070810709107101071110712107131071410715107161071710718107191072010721107221072310724107251072610727107281072910730107311073210733107341073510736107371073810739107401074110742107431074410745107461074710748107491075010751107521075310754107551075610757107581075910760107611076210763107641076510766107671076810769107701077110772107731077410775107761077710778107791078010781107821078310784107851078610787107881078910790107911079210793107941079510796107971079810799108001080110802108031080410805108061080710808108091081010811108121081310814108151081610817108181081910820108211082210823108241082510826108271082810829108301083110832108331083410835108361083710838108391084010841108421084310844108451084610847108481084910850108511085210853108541085510856108571085810859108601086110862108631086410865108661086710868108691087010871108721087310874108751087610877108781087910880108811088210883108841088510886108871088810889108901089110892108931089410895108961089710898108991090010901109021090310904109051090610907109081090910910109111091210913109141091510916109171091810919109201092110922109231092410925109261092710928109291093010931109321093310934109351093610937109381093910940109411094210943109441094510946109471094810949109501095110952109531095410955109561095710958109591096010961109621096310964109651096610967109681096910970109711097210973109741097510976109771097810979109801098110982109831098410985109861098710988109891099010991109921099310994109951099610997109981099911000110011100211003110041100511006110071100811009110101101111012110131101411015110161101711018110191102011021110221102311024110251102611027110281102911030110311103211033110341103511036110371103811039110401104111042110431104411045110461104711048110491105011051110521105311054110551105611057110581105911060110611106211063110641106511066110671106811069110701107111072110731107411075110761107711078110791108011081110821108311084110851108611087110881108911090110911109211093110941109511096110971109811099111001110111102111031110411105111061110711108111091111011111111121111311114111151111611117111181111911120111211112211123111241112511126111271112811129111301113111132111331113411135111361113711138111391114011141111421114311144111451114611147111481114911150111511115211153111541115511156111571115811159111601116111162111631116411165111661116711168111691117011171111721117311174111751117611177111781117911180111811118211183111841118511186111871118811189111901119111192111931119411195111961119711198111991120011201112021120311204112051120611207112081120911210112111121211213112141121511216112171121811219112201122111222112231122411225112261122711228112291123011231112321123311234112351123611237112381123911240112411124211243112441124511246112471124811249112501125111252112531125411255112561125711258112591126011261112621126311264112651126611267112681126911270112711127211273112741127511276112771127811279112801128111282112831128411285112861128711288112891129011291112921129311294112951129611297112981129911300113011130211303113041130511306113071130811309113101131111312113131131411315113161131711318113191132011321113221132311324113251132611327113281132911330113311133211333113341133511336113371133811339113401134111342113431134411345113461134711348113491135011351113521135311354113551135611357113581135911360113611136211363113641136511366113671136811369113701137111372113731137411375113761137711378113791138011381113821138311384113851138611387113881138911390113911139211393113941139511396113971139811399114001140111402114031140411405114061140711408114091141011411114121141311414114151141611417114181141911420114211142211423114241142511426114271142811429114301143111432114331143411435114361143711438114391144011441114421144311444114451144611447114481144911450114511145211453114541145511456114571145811459114601146111462114631146411465114661146711468114691147011471114721147311474114751147611477114781147911480114811148211483114841148511486114871148811489114901149111492114931149411495114961149711498114991150011501115021150311504115051150611507115081150911510115111151211513115141151511516115171151811519115201152111522115231152411525115261152711528115291153011531115321153311534115351153611537115381153911540115411154211543115441154511546115471154811549115501155111552115531155411555115561155711558115591156011561115621156311564115651156611567115681156911570115711157211573115741157511576115771157811579115801158111582115831158411585115861158711588115891159011591115921159311594115951159611597115981159911600116011160211603116041160511606116071160811609116101161111612116131161411615116161161711618116191162011621116221162311624116251162611627116281162911630116311163211633116341163511636116371163811639116401164111642116431164411645116461164711648116491165011651116521165311654116551165611657116581165911660116611166211663116641166511666116671166811669116701167111672116731167411675116761167711678116791168011681116821168311684116851168611687116881168911690116911169211693116941169511696116971169811699117001170111702117031170411705117061170711708117091171011711117121171311714117151171611717117181171911720117211172211723117241172511726117271172811729117301173111732117331173411735117361173711738117391174011741117421174311744117451174611747117481174911750117511175211753117541175511756117571175811759117601176111762117631176411765117661176711768117691177011771117721177311774117751177611777117781177911780117811178211783117841178511786117871178811789117901179111792117931179411795117961179711798117991180011801118021180311804118051180611807118081180911810118111181211813118141181511816118171181811819118201182111822118231182411825118261182711828118291183011831118321183311834118351183611837118381183911840118411184211843118441184511846118471184811849118501185111852118531185411855118561185711858118591186011861118621186311864118651186611867118681186911870118711187211873118741187511876118771187811879118801188111882118831188411885118861188711888118891189011891118921189311894118951189611897118981189911900119011190211903119041190511906119071190811909119101191111912119131191411915119161191711918119191192011921119221192311924119251192611927119281192911930119311193211933119341193511936119371193811939119401194111942119431194411945119461194711948119491195011951119521195311954119551195611957119581195911960119611196211963119641196511966119671196811969119701197111972119731197411975119761197711978119791198011981119821198311984119851198611987119881198911990119911199211993119941199511996119971199811999120001200112002120031200412005120061200712008120091201012011120121201312014120151201612017120181201912020120211202212023120241202512026120271202812029120301203112032120331203412035120361203712038120391204012041120421204312044120451204612047120481204912050120511205212053120541205512056120571205812059120601206112062120631206412065120661206712068120691207012071120721207312074120751207612077120781207912080120811208212083120841208512086120871208812089120901209112092120931209412095120961209712098120991210012101121021210312104121051210612107121081210912110121111211212113121141211512116121171211812119121201212112122121231212412125121261212712128121291213012131121321213312134121351213612137121381213912140121411214212143121441214512146121471214812149121501215112152121531215412155121561215712158121591216012161121621216312164121651216612167121681216912170121711217212173121741217512176121771217812179121801218112182121831218412185121861218712188121891219012191121921219312194121951219612197121981219912200122011220212203122041220512206122071220812209122101221112212122131221412215122161221712218122191222012221122221222312224122251222612227122281222912230122311223212233122341223512236122371223812239122401224112242122431224412245122461224712248122491225012251122521225312254122551225612257122581225912260122611226212263122641226512266122671226812269122701227112272122731227412275122761227712278122791228012281122821228312284122851228612287122881228912290122911229212293122941229512296122971229812299123001230112302123031230412305123061230712308123091231012311123121231312314123151231612317123181231912320123211232212323123241232512326123271232812329123301233112332123331233412335123361233712338123391234012341123421234312344123451234612347123481234912350123511235212353123541235512356123571235812359123601236112362123631236412365123661236712368123691237012371123721237312374123751237612377123781237912380123811238212383123841238512386123871238812389123901239112392123931239412395123961239712398123991240012401124021240312404124051240612407124081240912410124111241212413124141241512416124171241812419124201242112422124231242412425124261242712428124291243012431124321243312434124351243612437124381243912440124411244212443124441244512446124471244812449124501245112452124531245412455124561245712458124591246012461124621246312464124651246612467124681246912470124711247212473124741247512476124771247812479124801248112482124831248412485124861248712488124891249012491124921249312494124951249612497124981249912500125011250212503125041250512506125071250812509125101251112512125131251412515125161251712518125191252012521125221252312524125251252612527125281252912530125311253212533125341253512536125371253812539125401254112542125431254412545125461254712548125491255012551125521255312554125551255612557125581255912560125611256212563125641256512566125671256812569125701257112572125731257412575125761257712578125791258012581125821258312584125851258612587125881258912590125911259212593125941259512596125971259812599126001260112602126031260412605126061260712608126091261012611126121261312614126151261612617126181261912620126211262212623126241262512626126271262812629126301263112632126331263412635126361263712638126391264012641126421264312644126451264612647126481264912650126511265212653126541265512656126571265812659126601266112662126631266412665126661266712668126691267012671126721267312674126751267612677126781267912680126811268212683126841268512686126871268812689126901269112692126931269412695126961269712698126991270012701127021270312704127051270612707127081270912710127111271212713127141271512716127171271812719127201272112722127231272412725127261272712728127291273012731127321273312734127351273612737127381273912740127411274212743127441274512746127471274812749127501275112752127531275412755127561275712758127591276012761127621276312764127651276612767127681276912770127711277212773127741277512776127771277812779127801278112782127831278412785127861278712788127891279012791127921279312794127951279612797127981279912800128011280212803128041280512806128071280812809128101281112812128131281412815128161281712818128191282012821128221282312824128251282612827128281282912830128311283212833128341283512836128371283812839128401284112842128431284412845128461284712848128491285012851128521285312854128551285612857128581285912860128611286212863128641286512866128671286812869128701287112872128731287412875128761287712878128791288012881128821288312884128851288612887128881288912890128911289212893128941289512896128971289812899129001290112902129031290412905129061290712908129091291012911129121291312914129151291612917129181291912920129211292212923129241292512926129271292812929129301293112932129331293412935129361293712938129391294012941129421294312944129451294612947129481294912950129511295212953129541295512956129571295812959129601296112962129631296412965129661296712968129691297012971129721297312974129751297612977129781297912980129811298212983129841298512986129871298812989129901299112992129931299412995129961299712998129991300013001130021300313004130051300613007130081300913010130111301213013130141301513016130171301813019130201302113022130231302413025130261302713028130291303013031130321303313034130351303613037130381303913040130411304213043130441304513046130471304813049130501305113052130531305413055130561305713058130591306013061130621306313064130651306613067130681306913070130711307213073130741307513076130771307813079130801308113082130831308413085130861308713088130891309013091130921309313094130951309613097130981309913100131011310213103131041310513106131071310813109131101311113112131131311413115131161311713118131191312013121131221312313124131251312613127131281312913130131311313213133131341313513136131371313813139131401314113142131431314413145131461314713148131491315013151131521315313154131551315613157131581315913160131611316213163131641316513166131671316813169131701317113172131731317413175131761317713178131791318013181131821318313184131851318613187131881318913190131911319213193131941319513196131971319813199132001320113202132031320413205132061320713208132091321013211132121321313214132151321613217132181321913220132211322213223132241322513226132271322813229132301323113232132331323413235132361323713238132391324013241132421324313244132451324613247132481324913250132511325213253132541325513256132571325813259132601326113262132631326413265132661326713268132691327013271132721327313274132751327613277132781327913280132811328213283132841328513286132871328813289132901329113292132931329413295132961329713298132991330013301133021330313304133051330613307133081330913310133111331213313133141331513316133171331813319133201332113322133231332413325133261332713328133291333013331133321333313334133351333613337133381333913340133411334213343133441334513346133471334813349133501335113352133531335413355133561335713358133591336013361133621336313364133651336613367133681336913370133711337213373133741337513376133771337813379133801338113382133831338413385133861338713388133891339013391133921339313394133951339613397133981339913400134011340213403134041340513406134071340813409134101341113412134131341413415134161341713418134191342013421134221342313424134251342613427134281342913430134311343213433134341343513436134371343813439134401344113442134431344413445134461344713448134491345013451134521345313454134551345613457134581345913460134611346213463134641346513466134671346813469134701347113472134731347413475134761347713478134791348013481134821348313484134851348613487134881348913490134911349213493134941349513496134971349813499135001350113502135031350413505135061350713508135091351013511135121351313514135151351613517135181351913520135211352213523135241352513526135271352813529135301353113532135331353413535135361353713538135391354013541135421354313544135451354613547135481354913550135511355213553135541355513556135571355813559135601356113562135631356413565135661356713568135691357013571135721357313574135751357613577135781357913580135811358213583135841358513586135871358813589135901359113592135931359413595135961359713598135991360013601136021360313604136051360613607136081360913610136111361213613136141361513616136171361813619136201362113622136231362413625136261362713628136291363013631136321363313634136351363613637136381363913640136411364213643136441364513646136471364813649136501365113652136531365413655136561365713658136591366013661136621366313664136651366613667136681366913670136711367213673136741367513676136771367813679136801368113682136831368413685136861368713688136891369013691136921369313694136951369613697136981369913700137011370213703137041370513706137071370813709137101371113712137131371413715137161371713718137191372013721137221372313724137251372613727137281372913730137311373213733137341373513736137371373813739137401374113742137431374413745137461374713748137491375013751137521375313754137551375613757137581375913760137611376213763137641376513766137671376813769137701377113772137731377413775137761377713778137791378013781137821378313784137851378613787137881378913790137911379213793137941379513796137971379813799138001380113802138031380413805138061380713808138091381013811138121381313814138151381613817138181381913820138211382213823138241382513826138271382813829138301383113832138331383413835138361383713838138391384013841138421384313844138451384613847138481384913850138511385213853138541385513856138571385813859138601386113862138631386413865138661386713868138691387013871138721387313874138751387613877138781387913880138811388213883138841388513886138871388813889138901389113892138931389413895138961389713898138991390013901139021390313904139051390613907139081390913910139111391213913139141391513916139171391813919139201392113922139231392413925139261392713928139291393013931139321393313934139351393613937139381393913940139411394213943139441394513946139471394813949139501395113952139531395413955139561395713958139591396013961139621396313964139651396613967139681396913970139711397213973139741397513976139771397813979139801398113982139831398413985139861398713988139891399013991139921399313994139951399613997139981399914000140011400214003140041400514006140071400814009140101401114012140131401414015140161401714018140191402014021140221402314024140251402614027140281402914030140311403214033140341403514036140371403814039140401404114042140431404414045140461404714048140491405014051140521405314054140551405614057140581405914060140611406214063140641406514066140671406814069140701407114072140731407414075140761407714078140791408014081140821408314084140851408614087140881408914090140911409214093140941409514096140971409814099141001410114102141031410414105141061410714108141091411014111141121411314114141151411614117141181411914120141211412214123141241412514126141271412814129141301413114132141331413414135141361413714138141391414014141141421414314144141451414614147141481414914150141511415214153141541415514156141571415814159141601416114162141631416414165141661416714168141691417014171141721417314174141751417614177141781417914180141811418214183141841418514186141871418814189141901419114192141931419414195141961419714198141991420014201142021420314204142051420614207142081420914210142111421214213142141421514216142171421814219142201422114222142231422414225142261422714228142291423014231142321423314234142351423614237142381423914240142411424214243142441424514246142471424814249142501425114252142531425414255142561425714258142591426014261142621426314264142651426614267142681426914270142711427214273142741427514276142771427814279142801428114282142831428414285142861428714288142891429014291142921429314294142951429614297142981429914300143011430214303143041430514306143071430814309143101431114312143131431414315143161431714318143191432014321143221432314324143251432614327143281432914330143311433214333143341433514336143371433814339143401434114342143431434414345143461434714348143491435014351143521435314354143551435614357143581435914360143611436214363143641436514366143671436814369143701437114372143731437414375143761437714378143791438014381143821438314384143851438614387143881438914390143911439214393143941439514396143971439814399144001440114402144031440414405144061440714408144091441014411144121441314414144151441614417144181441914420144211442214423144241442514426144271442814429144301443114432144331443414435144361443714438144391444014441144421444314444144451444614447144481444914450144511445214453144541445514456144571445814459144601446114462144631446414465144661446714468144691447014471144721447314474144751447614477144781447914480144811448214483144841448514486144871448814489144901449114492144931449414495144961449714498144991450014501145021450314504145051450614507145081450914510145111451214513145141451514516145171451814519145201452114522145231452414525145261452714528145291453014531145321453314534145351453614537145381453914540145411454214543145441454514546145471454814549145501455114552145531455414555145561455714558145591456014561145621456314564145651456614567145681456914570145711457214573145741457514576145771457814579145801458114582145831458414585145861458714588145891459014591145921459314594145951459614597145981459914600146011460214603146041460514606146071460814609146101461114612146131461414615146161461714618146191462014621146221462314624146251462614627146281462914630146311463214633146341463514636146371463814639146401464114642146431464414645146461464714648146491465014651146521465314654146551465614657146581465914660146611466214663146641466514666146671466814669146701467114672146731467414675146761467714678146791468014681146821468314684146851468614687146881468914690146911469214693146941469514696146971469814699147001470114702147031470414705147061470714708147091471014711147121471314714147151471614717147181471914720147211472214723147241472514726147271472814729147301473114732147331473414735147361473714738147391474014741147421474314744147451474614747147481474914750147511475214753147541475514756147571475814759147601476114762147631476414765147661476714768147691477014771147721477314774147751477614777147781477914780147811478214783147841478514786147871478814789147901479114792147931479414795147961479714798147991480014801148021480314804148051480614807148081480914810148111481214813148141481514816148171481814819148201482114822148231482414825148261482714828148291483014831148321483314834148351483614837148381483914840148411484214843148441484514846148471484814849148501485114852148531485414855148561485714858148591486014861148621486314864148651486614867148681486914870148711487214873148741487514876148771487814879148801488114882148831488414885148861488714888148891489014891148921489314894148951489614897148981489914900149011490214903149041490514906149071490814909149101491114912149131491414915149161491714918149191492014921149221492314924149251492614927149281492914930149311493214933149341493514936149371493814939149401494114942149431494414945149461494714948149491495014951149521495314954149551495614957149581495914960149611496214963149641496514966149671496814969149701497114972149731497414975149761497714978149791498014981149821498314984149851498614987149881498914990149911499214993149941499514996149971499814999150001500115002150031500415005150061500715008150091501015011150121501315014150151501615017150181501915020150211502215023150241502515026150271502815029150301503115032150331503415035150361503715038150391504015041150421504315044150451504615047150481504915050150511505215053150541505515056150571505815059150601506115062150631506415065150661506715068150691507015071150721507315074150751507615077150781507915080150811508215083150841508515086150871508815089150901509115092150931509415095150961509715098150991510015101151021510315104151051510615107151081510915110151111511215113151141511515116151171511815119151201512115122151231512415125151261512715128151291513015131151321513315134151351513615137151381513915140151411514215143151441514515146151471514815149151501515115152151531515415155151561515715158151591516015161151621516315164151651516615167151681516915170151711517215173151741517515176151771517815179151801518115182151831518415185151861518715188151891519015191151921519315194151951519615197151981519915200152011520215203152041520515206152071520815209152101521115212152131521415215152161521715218152191522015221152221522315224152251522615227152281522915230152311523215233152341523515236152371523815239152401524115242152431524415245152461524715248152491525015251152521525315254152551525615257152581525915260152611526215263152641526515266152671526815269152701527115272152731527415275152761527715278152791528015281152821528315284152851528615287152881528915290152911529215293152941529515296152971529815299153001530115302153031530415305153061530715308153091531015311153121531315314153151531615317153181531915320153211532215323153241532515326153271532815329153301533115332153331533415335153361533715338153391534015341153421534315344153451534615347153481534915350153511535215353153541535515356153571535815359153601536115362153631536415365153661536715368153691537015371153721537315374153751537615377153781537915380153811538215383153841538515386153871538815389153901539115392153931539415395153961539715398153991540015401154021540315404154051540615407154081540915410154111541215413154141541515416154171541815419154201542115422154231542415425154261542715428154291543015431154321543315434154351543615437154381543915440154411544215443154441544515446154471544815449154501545115452154531545415455154561545715458154591546015461154621546315464154651546615467154681546915470154711547215473154741547515476154771547815479154801548115482154831548415485154861548715488154891549015491154921549315494154951549615497154981549915500155011550215503155041550515506155071550815509155101551115512155131551415515155161551715518155191552015521155221552315524155251552615527155281552915530155311553215533155341553515536155371553815539155401554115542155431554415545155461554715548155491555015551155521555315554155551555615557155581555915560155611556215563155641556515566155671556815569155701557115572155731557415575155761557715578155791558015581155821558315584155851558615587155881558915590155911559215593155941559515596155971559815599156001560115602156031560415605156061560715608156091561015611156121561315614156151561615617156181561915620156211562215623156241562515626156271562815629156301563115632156331563415635156361563715638156391564015641156421564315644156451564615647156481564915650156511565215653156541565515656156571565815659156601566115662156631566415665156661566715668156691567015671156721567315674156751567615677156781567915680156811568215683156841568515686156871568815689156901569115692156931569415695156961569715698156991570015701157021570315704157051570615707157081570915710157111571215713157141571515716157171571815719157201572115722157231572415725157261572715728157291573015731157321573315734157351573615737157381573915740157411574215743157441574515746157471574815749157501575115752157531575415755157561575715758157591576015761157621576315764157651576615767157681576915770157711577215773157741577515776157771577815779157801578115782157831578415785157861578715788157891579015791157921579315794157951579615797157981579915800158011580215803158041580515806158071580815809158101581115812158131581415815158161581715818158191582015821158221582315824158251582615827158281582915830158311583215833158341583515836158371583815839158401584115842158431584415845158461584715848158491585015851158521585315854158551585615857158581585915860158611586215863158641586515866158671586815869158701587115872158731587415875158761587715878158791588015881158821588315884158851588615887158881588915890158911589215893158941589515896158971589815899159001590115902159031590415905159061590715908159091591015911159121591315914159151591615917159181591915920159211592215923159241592515926159271592815929159301593115932159331593415935159361593715938159391594015941159421594315944159451594615947159481594915950159511595215953159541595515956159571595815959159601596115962159631596415965159661596715968159691597015971159721597315974159751597615977159781597915980159811598215983159841598515986159871598815989159901599115992159931599415995159961599715998159991600016001160021600316004160051600616007160081600916010160111601216013160141601516016160171601816019160201602116022160231602416025160261602716028160291603016031160321603316034160351603616037160381603916040160411604216043160441604516046160471604816049160501605116052160531605416055160561605716058160591606016061160621606316064160651606616067160681606916070160711607216073160741607516076160771607816079160801608116082160831608416085160861608716088160891609016091160921609316094160951609616097160981609916100161011610216103161041610516106161071610816109161101611116112161131611416115161161611716118161191612016121161221612316124161251612616127161281612916130161311613216133161341613516136161371613816139161401614116142161431614416145161461614716148161491615016151161521615316154161551615616157161581615916160161611616216163161641616516166161671616816169161701617116172161731617416175161761617716178161791618016181161821618316184161851618616187161881618916190161911619216193161941619516196161971619816199162001620116202162031620416205162061620716208162091621016211162121621316214162151621616217162181621916220162211622216223162241622516226162271622816229162301623116232162331623416235162361623716238162391624016241162421624316244162451624616247162481624916250162511625216253162541625516256162571625816259162601626116262162631626416265162661626716268162691627016271162721627316274162751627616277162781627916280162811628216283162841628516286162871628816289162901629116292162931629416295162961629716298162991630016301163021630316304163051630616307163081630916310163111631216313163141631516316163171631816319163201632116322163231632416325163261632716328163291633016331163321633316334163351633616337163381633916340163411634216343163441634516346163471634816349163501635116352163531635416355163561635716358163591636016361163621636316364163651636616367163681636916370163711637216373163741637516376163771637816379163801638116382163831638416385163861638716388163891639016391163921639316394163951639616397163981639916400164011640216403164041640516406164071640816409164101641116412164131641416415164161641716418164191642016421164221642316424164251642616427164281642916430164311643216433164341643516436164371643816439164401644116442164431644416445164461644716448164491645016451164521645316454164551645616457164581645916460164611646216463164641646516466164671646816469164701647116472164731647416475164761647716478164791648016481164821648316484164851648616487164881648916490164911649216493164941649516496164971649816499165001650116502165031650416505165061650716508165091651016511165121651316514165151651616517165181651916520165211652216523165241652516526165271652816529165301653116532165331653416535165361653716538165391654016541165421654316544165451654616547165481654916550165511655216553165541655516556165571655816559165601656116562165631656416565165661656716568165691657016571165721657316574165751657616577165781657916580165811658216583165841658516586165871658816589165901659116592165931659416595165961659716598165991660016601166021660316604166051660616607166081660916610166111661216613166141661516616166171661816619166201662116622166231662416625166261662716628166291663016631166321663316634166351663616637166381663916640166411664216643166441664516646166471664816649166501665116652166531665416655166561665716658166591666016661166621666316664166651666616667166681666916670166711667216673166741667516676166771667816679166801668116682166831668416685166861668716688166891669016691166921669316694166951669616697166981669916700167011670216703167041670516706167071670816709167101671116712167131671416715167161671716718167191672016721167221672316724167251672616727167281672916730167311673216733167341673516736167371673816739167401674116742167431674416745167461674716748167491675016751167521675316754167551675616757167581675916760167611676216763167641676516766167671676816769167701677116772167731677416775167761677716778167791678016781167821678316784167851678616787167881678916790167911679216793167941679516796167971679816799168001680116802168031680416805168061680716808168091681016811168121681316814168151681616817168181681916820168211682216823168241682516826168271682816829168301683116832168331683416835168361683716838168391684016841168421684316844168451684616847168481684916850168511685216853168541685516856168571685816859168601686116862168631686416865168661686716868168691687016871168721687316874168751687616877168781687916880168811688216883168841688516886168871688816889168901689116892168931689416895168961689716898168991690016901169021690316904169051690616907169081690916910169111691216913169141691516916169171691816919169201692116922169231692416925169261692716928169291693016931169321693316934169351693616937169381693916940169411694216943169441694516946169471694816949169501695116952169531695416955169561695716958169591696016961169621696316964169651696616967169681696916970169711697216973169741697516976169771697816979169801698116982169831698416985169861698716988169891699016991169921699316994169951699616997169981699917000170011700217003170041700517006170071700817009170101701117012170131701417015170161701717018170191702017021170221702317024170251702617027170281702917030170311703217033170341703517036170371703817039170401704117042170431704417045170461704717048170491705017051170521705317054170551705617057170581705917060170611706217063170641706517066170671706817069170701707117072170731707417075170761707717078170791708017081170821708317084170851708617087170881708917090170911709217093170941709517096170971709817099171001710117102171031710417105171061710717108171091711017111171121711317114171151711617117171181711917120171211712217123171241712517126171271712817129171301713117132171331713417135171361713717138171391714017141171421714317144171451714617147171481714917150171511715217153171541715517156171571715817159171601716117162171631716417165171661716717168171691717017171171721717317174171751717617177171781717917180171811718217183171841718517186171871718817189171901719117192171931719417195171961719717198171991720017201172021720317204172051720617207172081720917210172111721217213172141721517216172171721817219172201722117222172231722417225172261722717228172291723017231172321723317234172351723617237172381723917240172411724217243172441724517246172471724817249172501725117252172531725417255172561725717258172591726017261172621726317264172651726617267172681726917270172711727217273172741727517276172771727817279172801728117282172831728417285172861728717288172891729017291172921729317294172951729617297172981729917300173011730217303173041730517306173071730817309173101731117312173131731417315173161731717318173191732017321173221732317324173251732617327173281732917330173311733217333173341733517336173371733817339173401734117342173431734417345173461734717348173491735017351173521735317354173551735617357173581735917360173611736217363173641736517366173671736817369173701737117372173731737417375173761737717378173791738017381173821738317384173851738617387173881738917390173911739217393173941739517396173971739817399174001740117402174031740417405174061740717408174091741017411174121741317414174151741617417174181741917420174211742217423174241742517426174271742817429174301743117432174331743417435174361743717438174391744017441174421744317444174451744617447174481744917450174511745217453174541745517456174571745817459174601746117462174631746417465174661746717468174691747017471174721747317474174751747617477174781747917480174811748217483174841748517486174871748817489174901749117492174931749417495174961749717498174991750017501175021750317504175051750617507175081750917510175111751217513175141751517516175171751817519175201752117522175231752417525175261752717528175291753017531175321753317534175351753617537175381753917540175411754217543175441754517546175471754817549175501755117552175531755417555175561755717558175591756017561175621756317564175651756617567175681756917570175711757217573175741757517576175771757817579175801758117582175831758417585175861758717588175891759017591175921759317594175951759617597175981759917600176011760217603176041760517606176071760817609176101761117612176131761417615176161761717618176191762017621176221762317624176251762617627176281762917630176311763217633176341763517636176371763817639176401764117642176431764417645176461764717648176491765017651176521765317654176551765617657176581765917660176611766217663176641766517666176671766817669176701767117672176731767417675176761767717678176791768017681176821768317684176851768617687176881768917690176911769217693176941769517696176971769817699177001770117702177031770417705177061770717708177091771017711177121771317714177151771617717177181771917720177211772217723177241772517726177271772817729177301773117732177331773417735177361773717738177391774017741177421774317744177451774617747177481774917750177511775217753177541775517756177571775817759177601776117762177631776417765177661776717768177691777017771177721777317774177751777617777177781777917780177811778217783177841778517786177871778817789177901779117792177931779417795177961779717798177991780017801178021780317804178051780617807178081780917810178111781217813178141781517816178171781817819178201782117822178231782417825178261782717828178291783017831178321783317834178351783617837178381783917840178411784217843178441784517846178471784817849178501785117852178531785417855178561785717858178591786017861178621786317864178651786617867178681786917870178711787217873178741787517876178771787817879178801788117882178831788417885178861788717888178891789017891178921789317894178951789617897178981789917900179011790217903179041790517906179071790817909179101791117912179131791417915179161791717918179191792017921179221792317924179251792617927179281792917930179311793217933179341793517936179371793817939179401794117942179431794417945179461794717948179491795017951179521795317954179551795617957179581795917960179611796217963179641796517966179671796817969179701797117972179731797417975179761797717978179791798017981179821798317984179851798617987179881798917990179911799217993179941799517996179971799817999180001800118002180031800418005180061800718008180091801018011180121801318014180151801618017180181801918020180211802218023180241802518026180271802818029180301803118032180331803418035180361803718038180391804018041180421804318044180451804618047180481804918050180511805218053180541805518056180571805818059180601806118062180631806418065180661806718068180691807018071180721807318074180751807618077180781807918080180811808218083180841808518086180871808818089180901809118092180931809418095180961809718098180991810018101181021810318104181051810618107181081810918110181111811218113181141811518116181171811818119181201812118122181231812418125181261812718128181291813018131181321813318134181351813618137181381813918140181411814218143181441814518146181471814818149181501815118152181531815418155181561815718158181591816018161181621816318164181651816618167181681816918170181711817218173181741817518176181771817818179181801818118182181831818418185181861818718188181891819018191181921819318194181951819618197181981819918200182011820218203182041820518206182071820818209182101821118212182131821418215182161821718218182191822018221182221822318224182251822618227182281822918230182311823218233182341823518236182371823818239182401824118242182431824418245182461824718248182491825018251182521825318254182551825618257182581825918260182611826218263182641826518266182671826818269182701827118272182731827418275182761827718278182791828018281182821828318284182851828618287182881828918290182911829218293182941829518296182971829818299183001830118302183031830418305183061830718308183091831018311183121831318314183151831618317183181831918320183211832218323183241832518326183271832818329183301833118332183331833418335183361833718338183391834018341183421834318344183451834618347183481834918350183511835218353183541835518356183571835818359183601836118362183631836418365183661836718368183691837018371183721837318374183751837618377183781837918380183811838218383183841838518386183871838818389183901839118392183931839418395183961839718398183991840018401184021840318404184051840618407184081840918410184111841218413184141841518416184171841818419184201842118422184231842418425184261842718428184291843018431184321843318434184351843618437184381843918440184411844218443184441844518446184471844818449184501845118452184531845418455184561845718458184591846018461184621846318464184651846618467184681846918470184711847218473184741847518476184771847818479184801848118482184831848418485184861848718488184891849018491184921849318494184951849618497184981849918500185011850218503185041850518506185071850818509185101851118512185131851418515185161851718518185191852018521185221852318524185251852618527185281852918530185311853218533185341853518536185371853818539185401854118542185431854418545185461854718548185491855018551185521855318554185551855618557185581855918560185611856218563185641856518566185671856818569185701857118572185731857418575185761857718578185791858018581185821858318584185851858618587185881858918590185911859218593185941859518596185971859818599186001860118602186031860418605186061860718608186091861018611186121861318614186151861618617186181861918620186211862218623186241862518626186271862818629186301863118632186331863418635186361863718638186391864018641186421864318644186451864618647186481864918650186511865218653186541865518656186571865818659186601866118662186631866418665186661866718668186691867018671186721867318674186751867618677186781867918680186811868218683186841868518686186871868818689186901869118692186931869418695186961869718698186991870018701187021870318704187051870618707187081870918710187111871218713187141871518716187171871818719187201872118722187231872418725187261872718728187291873018731187321873318734187351873618737187381873918740187411874218743187441874518746187471874818749187501875118752187531875418755187561875718758187591876018761187621876318764187651876618767187681876918770187711877218773187741877518776187771877818779187801878118782187831878418785187861878718788187891879018791187921879318794187951879618797187981879918800188011880218803188041880518806188071880818809188101881118812188131881418815188161881718818188191882018821188221882318824188251882618827188281882918830188311883218833188341883518836188371883818839188401884118842188431884418845188461884718848188491885018851188521885318854188551885618857188581885918860188611886218863188641886518866188671886818869188701887118872188731887418875188761887718878188791888018881188821888318884188851888618887188881888918890188911889218893188941889518896188971889818899189001890118902189031890418905189061890718908189091891018911189121891318914189151891618917189181891918920189211892218923189241892518926189271892818929189301893118932189331893418935189361893718938189391894018941189421894318944189451894618947189481894918950189511895218953189541895518956189571895818959189601896118962189631896418965189661896718968189691897018971189721897318974189751897618977189781897918980189811898218983189841898518986189871898818989189901899118992189931899418995189961899718998189991900019001190021900319004190051900619007190081900919010190111901219013190141901519016190171901819019190201902119022190231902419025190261902719028190291903019031190321903319034190351903619037190381903919040190411904219043190441904519046190471904819049190501905119052190531905419055190561905719058190591906019061190621906319064190651906619067190681906919070190711907219073190741907519076190771907819079190801908119082190831908419085190861908719088190891909019091190921909319094190951909619097190981909919100191011910219103191041910519106191071910819109191101911119112191131911419115191161911719118191191912019121191221912319124191251912619127191281912919130191311913219133191341913519136191371913819139191401914119142191431914419145191461914719148191491915019151191521915319154191551915619157191581915919160191611916219163191641916519166191671916819169191701917119172191731917419175191761917719178191791918019181191821918319184191851918619187191881918919190191911919219193191941919519196191971919819199192001920119202192031920419205192061920719208192091921019211192121921319214192151921619217192181921919220192211922219223192241922519226192271922819229192301923119232192331923419235192361923719238192391924019241192421924319244192451924619247192481924919250192511925219253192541925519256192571925819259192601926119262192631926419265192661926719268192691927019271192721927319274192751927619277192781927919280192811928219283192841928519286192871928819289192901929119292192931929419295192961929719298192991930019301193021930319304193051930619307193081930919310193111931219313193141931519316193171931819319193201932119322193231932419325193261932719328193291933019331193321933319334193351933619337193381933919340193411934219343193441934519346193471934819349193501935119352193531935419355193561935719358193591936019361193621936319364193651936619367193681936919370193711937219373193741937519376193771937819379193801938119382193831938419385193861938719388193891939019391193921939319394193951939619397193981939919400194011940219403194041940519406194071940819409194101941119412194131941419415194161941719418194191942019421194221942319424194251942619427194281942919430194311943219433194341943519436194371943819439194401944119442194431944419445194461944719448194491945019451194521945319454194551945619457194581945919460194611946219463194641946519466194671946819469194701947119472194731947419475194761947719478194791948019481194821948319484194851948619487194881948919490194911949219493194941949519496194971949819499195001950119502195031950419505195061950719508195091951019511195121951319514195151951619517195181951919520195211952219523195241952519526195271952819529195301953119532195331953419535195361953719538195391954019541195421954319544195451954619547195481954919550195511955219553195541955519556195571955819559195601956119562195631956419565195661956719568195691957019571195721957319574195751957619577195781957919580195811958219583195841958519586195871958819589195901959119592195931959419595195961959719598195991960019601196021960319604196051960619607196081960919610196111961219613196141961519616196171961819619196201962119622196231962419625196261962719628196291963019631196321963319634196351963619637196381963919640196411964219643196441964519646196471964819649196501965119652196531965419655196561965719658196591966019661196621966319664196651966619667196681966919670196711967219673196741967519676196771967819679196801968119682196831968419685196861968719688196891969019691196921969319694196951969619697196981969919700197011970219703197041970519706197071970819709197101971119712197131971419715197161971719718197191972019721197221972319724197251972619727197281972919730197311973219733197341973519736197371973819739197401974119742197431974419745197461974719748197491975019751197521975319754197551975619757197581975919760197611976219763197641976519766197671976819769197701977119772197731977419775197761977719778197791978019781197821978319784197851978619787197881978919790197911979219793197941979519796197971979819799198001980119802198031980419805198061980719808198091981019811198121981319814198151981619817198181981919820198211982219823198241982519826198271982819829198301983119832198331983419835198361983719838198391984019841198421984319844198451984619847198481984919850198511985219853198541985519856198571985819859198601986119862198631986419865198661986719868198691987019871198721987319874198751987619877198781987919880198811988219883198841988519886198871988819889198901989119892198931989419895198961989719898198991990019901199021990319904199051990619907199081990919910199111991219913199141991519916199171991819919199201992119922199231992419925199261992719928199291993019931199321993319934199351993619937199381993919940199411994219943199441994519946199471994819949199501995119952199531995419955199561995719958199591996019961199621996319964199651996619967199681996919970199711997219973199741997519976199771997819979199801998119982199831998419985199861998719988199891999019991199921999319994199951999619997199981999920000200012000220003200042000520006200072000820009200102001120012200132001420015200162001720018200192002020021200222002320024200252002620027200282002920030200312003220033200342003520036200372003820039200402004120042200432004420045200462004720048200492005020051200522005320054200552005620057200582005920060200612006220063200642006520066200672006820069200702007120072200732007420075200762007720078200792008020081200822008320084200852008620087200882008920090200912009220093200942009520096200972009820099201002010120102201032010420105201062010720108201092011020111201122011320114201152011620117201182011920120201212012220123201242012520126201272012820129201302013120132201332013420135201362013720138201392014020141201422014320144201452014620147201482014920150201512015220153201542015520156201572015820159201602016120162201632016420165201662016720168201692017020171201722017320174201752017620177201782017920180201812018220183201842018520186201872018820189201902019120192201932019420195201962019720198201992020020201202022020320204202052020620207202082020920210202112021220213202142021520216202172021820219202202022120222202232022420225202262022720228202292023020231202322023320234202352023620237202382023920240202412024220243202442024520246202472024820249202502025120252202532025420255202562025720258202592026020261202622026320264202652026620267202682026920270202712027220273202742027520276202772027820279202802028120282202832028420285202862028720288202892029020291202922029320294202952029620297202982029920300203012030220303203042030520306203072030820309203102031120312203132031420315203162031720318203192032020321203222032320324203252032620327203282032920330203312033220333203342033520336203372033820339203402034120342203432034420345203462034720348203492035020351203522035320354203552035620357203582035920360203612036220363203642036520366203672036820369203702037120372203732037420375203762037720378203792038020381203822038320384203852038620387203882038920390203912039220393203942039520396203972039820399204002040120402204032040420405204062040720408204092041020411204122041320414204152041620417204182041920420204212042220423204242042520426204272042820429204302043120432204332043420435204362043720438204392044020441204422044320444204452044620447204482044920450204512045220453204542045520456204572045820459204602046120462204632046420465204662046720468204692047020471204722047320474204752047620477204782047920480204812048220483204842048520486204872048820489204902049120492204932049420495204962049720498204992050020501205022050320504205052050620507205082050920510205112051220513205142051520516205172051820519205202052120522205232052420525205262052720528205292053020531205322053320534205352053620537205382053920540205412054220543205442054520546205472054820549205502055120552205532055420555205562055720558205592056020561205622056320564205652056620567205682056920570205712057220573205742057520576205772057820579205802058120582205832058420585205862058720588205892059020591205922059320594205952059620597205982059920600206012060220603206042060520606206072060820609206102061120612206132061420615206162061720618206192062020621206222062320624206252062620627206282062920630206312063220633206342063520636206372063820639206402064120642206432064420645206462064720648206492065020651206522065320654206552065620657206582065920660206612066220663206642066520666206672066820669206702067120672206732067420675206762067720678206792068020681206822068320684206852068620687206882068920690206912069220693206942069520696206972069820699207002070120702207032070420705207062070720708207092071020711207122071320714207152071620717207182071920720207212072220723207242072520726207272072820729207302073120732207332073420735207362073720738207392074020741207422074320744207452074620747207482074920750207512075220753207542075520756207572075820759207602076120762207632076420765207662076720768207692077020771207722077320774207752077620777207782077920780207812078220783207842078520786207872078820789207902079120792207932079420795207962079720798207992080020801208022080320804208052080620807208082080920810208112081220813208142081520816208172081820819208202082120822208232082420825208262082720828208292083020831208322083320834208352083620837208382083920840208412084220843208442084520846208472084820849208502085120852208532085420855208562085720858208592086020861208622086320864208652086620867208682086920870208712087220873208742087520876208772087820879208802088120882208832088420885208862088720888208892089020891208922089320894208952089620897208982089920900209012090220903209042090520906209072090820909209102091120912209132091420915209162091720918209192092020921209222092320924209252092620927209282092920930209312093220933209342093520936209372093820939209402094120942209432094420945209462094720948209492095020951209522095320954209552095620957209582095920960209612096220963209642096520966209672096820969209702097120972209732097420975209762097720978209792098020981209822098320984209852098620987209882098920990209912099220993209942099520996209972099820999210002100121002210032100421005210062100721008210092101021011210122101321014210152101621017210182101921020210212102221023210242102521026210272102821029210302103121032210332103421035210362103721038210392104021041210422104321044210452104621047210482104921050210512105221053210542105521056210572105821059210602106121062210632106421065210662106721068210692107021071210722107321074210752107621077210782107921080210812108221083210842108521086210872108821089210902109121092210932109421095210962109721098210992110021101211022110321104211052110621107211082110921110211112111221113211142111521116211172111821119211202112121122211232112421125211262112721128211292113021131211322113321134211352113621137211382113921140211412114221143211442114521146211472114821149211502115121152211532115421155211562115721158211592116021161211622116321164211652116621167211682116921170211712117221173211742117521176211772117821179211802118121182211832118421185211862118721188211892119021191211922119321194211952119621197211982119921200212012120221203212042120521206212072120821209212102121121212212132121421215212162121721218212192122021221212222122321224212252122621227212282122921230212312123221233212342123521236212372123821239212402124121242212432124421245212462124721248212492125021251212522125321254212552125621257212582125921260212612126221263212642126521266212672126821269212702127121272212732127421275212762127721278212792128021281212822128321284212852128621287212882128921290212912129221293212942129521296212972129821299213002130121302213032130421305213062130721308213092131021311213122131321314213152131621317213182131921320213212132221323213242132521326213272132821329213302133121332213332133421335213362133721338213392134021341213422134321344213452134621347213482134921350213512135221353213542135521356213572135821359213602136121362213632136421365213662136721368213692137021371213722137321374213752137621377213782137921380213812138221383213842138521386213872138821389213902139121392213932139421395213962139721398213992140021401214022140321404214052140621407214082140921410214112141221413214142141521416214172141821419214202142121422214232142421425214262142721428214292143021431214322143321434214352143621437214382143921440214412144221443214442144521446214472144821449214502145121452214532145421455214562145721458214592146021461214622146321464214652146621467214682146921470214712147221473214742147521476214772147821479214802148121482214832148421485214862148721488214892149021491214922149321494214952149621497214982149921500215012150221503215042150521506215072150821509215102151121512215132151421515215162151721518215192152021521215222152321524215252152621527215282152921530215312153221533215342153521536215372153821539215402154121542215432154421545215462154721548215492155021551215522155321554215552155621557215582155921560215612156221563215642156521566215672156821569215702157121572215732157421575215762157721578215792158021581215822158321584215852158621587215882158921590215912159221593215942159521596215972159821599216002160121602216032160421605216062160721608216092161021611216122161321614216152161621617216182161921620216212162221623216242162521626216272162821629216302163121632216332163421635216362163721638216392164021641216422164321644216452164621647216482164921650216512165221653216542165521656216572165821659216602166121662216632166421665216662166721668216692167021671216722167321674216752167621677216782167921680216812168221683216842168521686216872168821689216902169121692216932169421695216962169721698216992170021701217022170321704217052170621707217082170921710217112171221713217142171521716217172171821719217202172121722217232172421725217262172721728217292173021731217322173321734217352173621737217382173921740217412174221743217442174521746217472174821749217502175121752217532175421755217562175721758217592176021761217622176321764217652176621767217682176921770217712177221773217742177521776217772177821779217802178121782217832178421785217862178721788217892179021791217922179321794217952179621797217982179921800218012180221803218042180521806218072180821809218102181121812218132181421815218162181721818218192182021821218222182321824218252182621827218282182921830218312183221833218342183521836218372183821839218402184121842218432184421845218462184721848218492185021851218522185321854218552185621857218582185921860218612186221863218642186521866218672186821869218702187121872218732187421875218762187721878218792188021881218822188321884218852188621887218882188921890218912189221893218942189521896218972189821899219002190121902219032190421905219062190721908219092191021911219122191321914219152191621917219182191921920219212192221923219242192521926219272192821929219302193121932219332193421935219362193721938219392194021941219422194321944219452194621947219482194921950219512195221953219542195521956219572195821959219602196121962219632196421965219662196721968219692197021971219722197321974219752197621977219782197921980219812198221983219842198521986219872198821989219902199121992219932199421995219962199721998219992200022001220022200322004220052200622007220082200922010220112201222013220142201522016220172201822019220202202122022220232202422025220262202722028220292203022031220322203322034220352203622037220382203922040220412204222043220442204522046220472204822049220502205122052220532205422055220562205722058220592206022061220622206322064220652206622067220682206922070220712207222073220742207522076220772207822079220802208122082220832208422085220862208722088220892209022091220922209322094220952209622097220982209922100221012210222103221042210522106221072210822109221102211122112221132211422115221162211722118221192212022121221222212322124221252212622127221282212922130221312213222133221342213522136221372213822139221402214122142221432214422145221462214722148221492215022151221522215322154221552215622157221582215922160221612216222163221642216522166221672216822169221702217122172221732217422175221762217722178221792218022181221822218322184221852218622187221882218922190221912219222193221942219522196221972219822199222002220122202222032220422205222062220722208222092221022211222122221322214222152221622217222182221922220222212222222223222242222522226222272222822229222302223122232222332223422235222362223722238222392224022241222422224322244222452224622247222482224922250222512225222253222542225522256222572225822259222602226122262222632226422265222662226722268222692227022271222722227322274222752227622277222782227922280222812228222283222842228522286222872228822289222902229122292222932229422295222962229722298222992230022301223022230322304223052230622307223082230922310223112231222313223142231522316223172231822319223202232122322223232232422325223262232722328223292233022331223322233322334223352233622337223382233922340223412234222343223442234522346223472234822349223502235122352223532235422355223562235722358223592236022361223622236322364223652236622367223682236922370223712237222373223742237522376223772237822379223802238122382223832238422385223862238722388223892239022391223922239322394223952239622397223982239922400224012240222403224042240522406224072240822409224102241122412224132241422415224162241722418224192242022421224222242322424224252242622427224282242922430224312243222433224342243522436224372243822439224402244122442224432244422445224462244722448224492245022451224522245322454224552245622457224582245922460224612246222463224642246522466224672246822469224702247122472224732247422475224762247722478224792248022481224822248322484224852248622487224882248922490224912249222493224942249522496224972249822499225002250122502225032250422505225062250722508225092251022511225122251322514225152251622517225182251922520225212252222523225242252522526225272252822529225302253122532225332253422535225362253722538225392254022541225422254322544225452254622547225482254922550225512255222553225542255522556225572255822559225602256122562225632256422565225662256722568225692257022571225722257322574225752257622577225782257922580225812258222583225842258522586225872258822589225902259122592225932259422595225962259722598225992260022601226022260322604226052260622607226082260922610226112261222613226142261522616226172261822619226202262122622226232262422625226262262722628226292263022631226322263322634226352263622637226382263922640226412264222643226442264522646226472264822649226502265122652226532265422655226562265722658226592266022661226622266322664226652266622667226682266922670226712267222673226742267522676226772267822679226802268122682226832268422685226862268722688226892269022691226922269322694226952269622697226982269922700227012270222703227042270522706227072270822709227102271122712227132271422715227162271722718227192272022721227222272322724227252272622727227282272922730227312273222733227342273522736227372273822739227402274122742227432274422745227462274722748227492275022751227522275322754227552275622757227582275922760227612276222763227642276522766227672276822769227702277122772227732277422775227762277722778227792278022781227822278322784227852278622787227882278922790227912279222793227942279522796227972279822799228002280122802228032280422805228062280722808228092281022811228122281322814228152281622817228182281922820228212282222823228242282522826228272282822829228302283122832228332283422835228362283722838228392284022841228422284322844228452284622847228482284922850228512285222853228542285522856228572285822859228602286122862228632286422865228662286722868228692287022871228722287322874228752287622877228782287922880228812288222883228842288522886228872288822889228902289122892228932289422895228962289722898228992290022901229022290322904229052290622907229082290922910229112291222913229142291522916229172291822919229202292122922229232292422925229262292722928229292293022931229322293322934229352293622937229382293922940229412294222943229442294522946229472294822949229502295122952229532295422955229562295722958229592296022961229622296322964229652296622967229682296922970229712297222973229742297522976229772297822979229802298122982229832298422985229862298722988229892299022991229922299322994229952299622997229982299923000230012300223003230042300523006230072300823009230102301123012230132301423015230162301723018230192302023021230222302323024230252302623027230282302923030230312303223033230342303523036230372303823039230402304123042230432304423045230462304723048230492305023051230522305323054230552305623057230582305923060230612306223063230642306523066230672306823069230702307123072230732307423075230762307723078230792308023081230822308323084230852308623087230882308923090230912309223093230942309523096230972309823099231002310123102231032310423105231062310723108231092311023111231122311323114231152311623117231182311923120231212312223123231242312523126231272312823129231302313123132231332313423135231362313723138231392314023141231422314323144231452314623147231482314923150231512315223153231542315523156231572315823159231602316123162231632316423165231662316723168231692317023171231722317323174231752317623177231782317923180231812318223183231842318523186231872318823189231902319123192231932319423195231962319723198231992320023201232022320323204232052320623207232082320923210232112321223213232142321523216232172321823219232202322123222232232322423225232262322723228232292323023231232322323323234232352323623237232382323923240232412324223243232442324523246232472324823249232502325123252232532325423255232562325723258232592326023261232622326323264232652326623267232682326923270232712327223273232742327523276232772327823279232802328123282232832328423285232862328723288232892329023291232922329323294232952329623297232982329923300233012330223303233042330523306233072330823309233102331123312233132331423315233162331723318233192332023321233222332323324233252332623327233282332923330233312333223333233342333523336233372333823339233402334123342233432334423345233462334723348233492335023351233522335323354233552335623357233582335923360233612336223363233642336523366233672336823369233702337123372233732337423375233762337723378233792338023381233822338323384233852338623387233882338923390233912339223393233942339523396233972339823399234002340123402234032340423405234062340723408234092341023411234122341323414234152341623417234182341923420234212342223423234242342523426234272342823429234302343123432234332343423435234362343723438234392344023441234422344323444234452344623447234482344923450234512345223453234542345523456234572345823459234602346123462234632346423465234662346723468234692347023471234722347323474234752347623477234782347923480234812348223483234842348523486234872348823489234902349123492234932349423495234962349723498234992350023501235022350323504235052350623507235082350923510235112351223513235142351523516235172351823519235202352123522235232352423525235262352723528235292353023531235322353323534235352353623537235382353923540235412354223543235442354523546235472354823549235502355123552235532355423555235562355723558235592356023561235622356323564235652356623567235682356923570235712357223573235742357523576235772357823579235802358123582235832358423585235862358723588235892359023591235922359323594235952359623597235982359923600236012360223603236042360523606236072360823609236102361123612236132361423615236162361723618236192362023621236222362323624236252362623627236282362923630236312363223633236342363523636236372363823639236402364123642236432364423645236462364723648236492365023651236522365323654236552365623657236582365923660236612366223663236642366523666236672366823669236702367123672236732367423675236762367723678236792368023681236822368323684236852368623687236882368923690236912369223693236942369523696236972369823699237002370123702237032370423705237062370723708237092371023711237122371323714237152371623717237182371923720237212372223723237242372523726237272372823729237302373123732237332373423735237362373723738237392374023741237422374323744237452374623747237482374923750237512375223753237542375523756237572375823759237602376123762237632376423765237662376723768237692377023771237722377323774237752377623777237782377923780237812378223783237842378523786237872378823789237902379123792237932379423795237962379723798237992380023801238022380323804238052380623807238082380923810238112381223813238142381523816238172381823819238202382123822238232382423825238262382723828238292383023831238322383323834238352383623837238382383923840238412384223843238442384523846238472384823849238502385123852238532385423855238562385723858238592386023861238622386323864238652386623867238682386923870238712387223873238742387523876238772387823879238802388123882238832388423885238862388723888238892389023891238922389323894238952389623897238982389923900239012390223903239042390523906239072390823909239102391123912239132391423915239162391723918239192392023921239222392323924239252392623927239282392923930239312393223933239342393523936239372393823939239402394123942239432394423945239462394723948239492395023951239522395323954239552395623957239582395923960239612396223963239642396523966239672396823969239702397123972239732397423975239762397723978239792398023981239822398323984239852398623987239882398923990239912399223993239942399523996239972399823999240002400124002240032400424005240062400724008240092401024011240122401324014240152401624017240182401924020240212402224023240242402524026240272402824029240302403124032240332403424035240362403724038240392404024041240422404324044240452404624047240482404924050240512405224053240542405524056240572405824059240602406124062240632406424065240662406724068240692407024071240722407324074240752407624077240782407924080240812408224083240842408524086240872408824089240902409124092240932409424095240962409724098240992410024101241022410324104241052410624107241082410924110241112411224113241142411524116241172411824119241202412124122241232412424125241262412724128241292413024131241322413324134241352413624137241382413924140241412414224143241442414524146241472414824149241502415124152241532415424155241562415724158241592416024161241622416324164241652416624167241682416924170241712417224173241742417524176241772417824179241802418124182241832418424185241862418724188241892419024191241922419324194241952419624197241982419924200242012420224203242042420524206242072420824209242102421124212242132421424215242162421724218242192422024221242222422324224242252422624227242282422924230242312423224233242342423524236242372423824239242402424124242242432424424245242462424724248242492425024251242522425324254242552425624257242582425924260242612426224263242642426524266242672426824269242702427124272242732427424275242762427724278242792428024281242822428324284242852428624287242882428924290242912429224293242942429524296242972429824299243002430124302243032430424305243062430724308243092431024311243122431324314243152431624317243182431924320243212432224323243242432524326243272432824329243302433124332243332433424335243362433724338243392434024341243422434324344243452434624347243482434924350243512435224353243542435524356243572435824359243602436124362243632436424365243662436724368243692437024371243722437324374243752437624377243782437924380243812438224383243842438524386243872438824389243902439124392243932439424395243962439724398243992440024401244022440324404244052440624407244082440924410244112441224413244142441524416244172441824419244202442124422244232442424425244262442724428244292443024431244322443324434244352443624437244382443924440244412444224443244442444524446244472444824449244502445124452244532445424455244562445724458244592446024461244622446324464244652446624467244682446924470244712447224473244742447524476244772447824479244802448124482244832448424485244862448724488244892449024491244922449324494244952449624497244982449924500245012450224503245042450524506245072450824509245102451124512245132451424515245162451724518245192452024521245222452324524245252452624527245282452924530245312453224533245342453524536245372453824539245402454124542245432454424545245462454724548245492455024551245522455324554245552455624557245582455924560245612456224563245642456524566245672456824569245702457124572245732457424575245762457724578245792458024581245822458324584245852458624587245882458924590245912459224593245942459524596245972459824599246002460124602246032460424605246062460724608246092461024611246122461324614246152461624617246182461924620246212462224623246242462524626246272462824629246302463124632246332463424635246362463724638246392464024641246422464324644246452464624647246482464924650246512465224653246542465524656246572465824659246602466124662246632466424665246662466724668246692467024671246722467324674246752467624677246782467924680246812468224683246842468524686246872468824689246902469124692246932469424695246962469724698246992470024701247022470324704247052470624707247082470924710247112471224713247142471524716247172471824719247202472124722247232472424725247262472724728247292473024731247322473324734247352473624737247382473924740247412474224743247442474524746247472474824749247502475124752247532475424755247562475724758247592476024761247622476324764247652476624767247682476924770247712477224773247742477524776247772477824779247802478124782247832478424785247862478724788247892479024791247922479324794247952479624797247982479924800248012480224803248042480524806248072480824809248102481124812248132481424815248162481724818248192482024821248222482324824248252482624827248282482924830248312483224833248342483524836248372483824839248402484124842248432484424845248462484724848248492485024851248522485324854248552485624857248582485924860248612486224863248642486524866248672486824869248702487124872248732487424875248762487724878248792488024881248822488324884248852488624887248882488924890248912489224893248942489524896248972489824899249002490124902249032490424905249062490724908249092491024911249122491324914249152491624917249182491924920249212492224923249242492524926249272492824929249302493124932249332493424935249362493724938249392494024941249422494324944249452494624947249482494924950249512495224953249542495524956249572495824959249602496124962249632496424965249662496724968249692497024971249722497324974249752497624977249782497924980249812498224983249842498524986249872498824989249902499124992249932499424995249962499724998249992500025001250022500325004250052500625007250082500925010250112501225013250142501525016250172501825019250202502125022250232502425025250262502725028250292503025031250322503325034250352503625037250382503925040250412504225043250442504525046250472504825049250502505125052250532505425055250562505725058250592506025061250622506325064250652506625067250682506925070250712507225073250742507525076250772507825079250802508125082250832508425085250862508725088250892509025091250922509325094250952509625097250982509925100251012510225103251042510525106251072510825109251102511125112251132511425115251162511725118251192512025121251222512325124251252512625127251282512925130251312513225133251342513525136251372513825139251402514125142251432514425145251462514725148251492515025151251522515325154251552515625157251582515925160251612516225163251642516525166251672516825169251702517125172251732517425175251762517725178251792518025181251822518325184251852518625187251882518925190251912519225193251942519525196251972519825199252002520125202252032520425205252062520725208252092521025211252122521325214252152521625217252182521925220252212522225223252242522525226252272522825229252302523125232252332523425235252362523725238252392524025241252422524325244252452524625247252482524925250252512525225253252542525525256252572525825259252602526125262252632526425265252662526725268252692527025271252722527325274252752527625277252782527925280252812528225283252842528525286252872528825289252902529125292252932529425295252962529725298252992530025301253022530325304253052530625307253082530925310253112531225313253142531525316253172531825319253202532125322253232532425325253262532725328253292533025331253322533325334253352533625337253382533925340253412534225343253442534525346253472534825349253502535125352253532535425355253562535725358253592536025361253622536325364253652536625367253682536925370253712537225373253742537525376253772537825379253802538125382253832538425385253862538725388253892539025391253922539325394253952539625397253982539925400254012540225403254042540525406254072540825409254102541125412254132541425415254162541725418254192542025421254222542325424254252542625427254282542925430254312543225433254342543525436254372543825439254402544125442254432544425445254462544725448254492545025451254522545325454254552545625457254582545925460254612546225463254642546525466254672546825469254702547125472254732547425475254762547725478254792548025481254822548325484254852548625487254882548925490254912549225493254942549525496254972549825499255002550125502255032550425505255062550725508255092551025511255122551325514255152551625517255182551925520255212552225523255242552525526255272552825529255302553125532255332553425535255362553725538255392554025541255422554325544255452554625547255482554925550255512555225553255542555525556255572555825559255602556125562255632556425565255662556725568255692557025571255722557325574255752557625577255782557925580255812558225583255842558525586255872558825589255902559125592255932559425595255962559725598255992560025601256022560325604256052560625607256082560925610256112561225613256142561525616256172561825619256202562125622256232562425625256262562725628256292563025631256322563325634256352563625637256382563925640256412564225643256442564525646256472564825649256502565125652256532565425655256562565725658256592566025661256622566325664256652566625667256682566925670256712567225673256742567525676256772567825679256802568125682256832568425685256862568725688256892569025691256922569325694256952569625697256982569925700257012570225703257042570525706257072570825709257102571125712257132571425715257162571725718257192572025721257222572325724257252572625727257282572925730257312573225733257342573525736257372573825739257402574125742257432574425745257462574725748257492575025751257522575325754257552575625757257582575925760257612576225763257642576525766257672576825769257702577125772257732577425775257762577725778257792578025781257822578325784257852578625787257882578925790257912579225793257942579525796257972579825799258002580125802258032580425805258062580725808258092581025811258122581325814258152581625817258182581925820258212582225823258242582525826258272582825829258302583125832258332583425835258362583725838258392584025841258422584325844258452584625847258482584925850258512585225853258542585525856258572585825859258602586125862258632586425865258662586725868258692587025871258722587325874258752587625877258782587925880258812588225883258842588525886258872588825889258902589125892258932589425895258962589725898258992590025901259022590325904259052590625907259082590925910259112591225913259142591525916259172591825919259202592125922259232592425925259262592725928259292593025931259322593325934259352593625937259382593925940259412594225943259442594525946259472594825949259502595125952259532595425955259562595725958259592596025961259622596325964259652596625967259682596925970259712597225973259742597525976259772597825979259802598125982259832598425985259862598725988259892599025991259922599325994259952599625997259982599926000260012600226003260042600526006260072600826009260102601126012260132601426015260162601726018260192602026021260222602326024260252602626027260282602926030260312603226033260342603526036260372603826039260402604126042260432604426045260462604726048260492605026051260522605326054260552605626057260582605926060260612606226063260642606526066260672606826069260702607126072260732607426075260762607726078260792608026081260822608326084260852608626087260882608926090260912609226093260942609526096260972609826099261002610126102261032610426105261062610726108261092611026111261122611326114261152611626117261182611926120261212612226123261242612526126261272612826129261302613126132261332613426135261362613726138261392614026141261422614326144261452614626147261482614926150261512615226153261542615526156261572615826159261602616126162261632616426165261662616726168261692617026171261722617326174261752617626177261782617926180261812618226183261842618526186261872618826189261902619126192261932619426195261962619726198261992620026201262022620326204262052620626207262082620926210262112621226213262142621526216262172621826219262202622126222262232622426225262262622726228262292623026231262322623326234262352623626237262382623926240262412624226243262442624526246262472624826249262502625126252262532625426255262562625726258262592626026261262622626326264262652626626267262682626926270262712627226273262742627526276262772627826279262802628126282262832628426285262862628726288262892629026291262922629326294262952629626297262982629926300263012630226303263042630526306263072630826309263102631126312263132631426315263162631726318263192632026321263222632326324263252632626327263282632926330263312633226333263342633526336263372633826339263402634126342263432634426345263462634726348263492635026351263522635326354263552635626357263582635926360263612636226363263642636526366263672636826369263702637126372263732637426375263762637726378263792638026381263822638326384263852638626387263882638926390263912639226393263942639526396263972639826399264002640126402264032640426405264062640726408264092641026411264122641326414264152641626417264182641926420264212642226423264242642526426264272642826429264302643126432264332643426435264362643726438264392644026441264422644326444264452644626447264482644926450264512645226453264542645526456264572645826459264602646126462264632646426465264662646726468264692647026471264722647326474264752647626477264782647926480264812648226483264842648526486264872648826489264902649126492264932649426495264962649726498264992650026501265022650326504265052650626507265082650926510265112651226513265142651526516265172651826519265202652126522265232652426525265262652726528265292653026531265322653326534265352653626537265382653926540265412654226543265442654526546265472654826549265502655126552265532655426555265562655726558265592656026561265622656326564265652656626567265682656926570265712657226573265742657526576265772657826579265802658126582265832658426585265862658726588265892659026591265922659326594265952659626597265982659926600266012660226603266042660526606266072660826609266102661126612266132661426615266162661726618266192662026621266222662326624266252662626627266282662926630266312663226633266342663526636266372663826639266402664126642266432664426645266462664726648266492665026651266522665326654266552665626657266582665926660266612666226663266642666526666266672666826669266702667126672266732667426675266762667726678266792668026681266822668326684266852668626687266882668926690266912669226693266942669526696266972669826699267002670126702267032670426705267062670726708267092671026711267122671326714267152671626717267182671926720267212672226723267242672526726267272672826729267302673126732267332673426735267362673726738267392674026741267422674326744267452674626747267482674926750267512675226753267542675526756267572675826759267602676126762267632676426765267662676726768267692677026771267722677326774267752677626777267782677926780267812678226783267842678526786267872678826789267902679126792267932679426795267962679726798267992680026801268022680326804268052680626807268082680926810268112681226813268142681526816268172681826819268202682126822268232682426825268262682726828268292683026831268322683326834268352683626837268382683926840268412684226843268442684526846268472684826849268502685126852268532685426855268562685726858268592686026861268622686326864268652686626867268682686926870268712687226873268742687526876268772687826879268802688126882268832688426885268862688726888268892689026891268922689326894268952689626897268982689926900269012690226903269042690526906269072690826909269102691126912269132691426915269162691726918269192692026921269222692326924269252692626927269282692926930269312693226933269342693526936269372693826939269402694126942269432694426945269462694726948269492695026951269522695326954269552695626957269582695926960269612696226963269642696526966269672696826969269702697126972269732697426975269762697726978269792698026981269822698326984269852698626987269882698926990269912699226993269942699526996269972699826999270002700127002270032700427005270062700727008270092701027011270122701327014270152701627017270182701927020270212702227023270242702527026270272702827029270302703127032270332703427035270362703727038270392704027041270422704327044270452704627047270482704927050270512705227053270542705527056270572705827059270602706127062270632706427065270662706727068270692707027071270722707327074270752707627077270782707927080270812708227083270842708527086270872708827089270902709127092270932709427095270962709727098270992710027101271022710327104271052710627107271082710927110271112711227113271142711527116271172711827119271202712127122271232712427125271262712727128271292713027131271322713327134271352713627137271382713927140271412714227143271442714527146271472714827149271502715127152271532715427155271562715727158271592716027161271622716327164271652716627167271682716927170271712717227173271742717527176271772717827179271802718127182271832718427185271862718727188271892719027191271922719327194271952719627197271982719927200272012720227203272042720527206272072720827209272102721127212272132721427215272162721727218272192722027221272222722327224272252722627227272282722927230272312723227233272342723527236272372723827239272402724127242272432724427245272462724727248272492725027251272522725327254272552725627257272582725927260272612726227263272642726527266272672726827269272702727127272272732727427275272762727727278272792728027281272822728327284272852728627287272882728927290272912729227293272942729527296272972729827299273002730127302273032730427305273062730727308273092731027311273122731327314273152731627317273182731927320273212732227323273242732527326273272732827329273302733127332273332733427335273362733727338273392734027341273422734327344273452734627347273482734927350273512735227353273542735527356273572735827359273602736127362273632736427365273662736727368273692737027371273722737327374273752737627377273782737927380273812738227383273842738527386273872738827389273902739127392273932739427395273962739727398273992740027401274022740327404274052740627407274082740927410274112741227413274142741527416274172741827419274202742127422274232742427425274262742727428274292743027431274322743327434274352743627437274382743927440274412744227443274442744527446274472744827449274502745127452274532745427455274562745727458274592746027461274622746327464274652746627467274682746927470274712747227473274742747527476274772747827479274802748127482274832748427485274862748727488274892749027491274922749327494274952749627497274982749927500275012750227503275042750527506275072750827509275102751127512275132751427515275162751727518275192752027521275222752327524275252752627527275282752927530275312753227533275342753527536275372753827539275402754127542275432754427545275462754727548275492755027551275522755327554275552755627557275582755927560275612756227563275642756527566275672756827569275702757127572275732757427575275762757727578275792758027581275822758327584275852758627587275882758927590275912759227593275942759527596275972759827599276002760127602276032760427605276062760727608276092761027611276122761327614276152761627617276182761927620276212762227623276242762527626276272762827629276302763127632276332763427635276362763727638276392764027641276422764327644276452764627647276482764927650276512765227653276542765527656276572765827659276602766127662276632766427665276662766727668276692767027671276722767327674276752767627677276782767927680276812768227683276842768527686276872768827689276902769127692276932769427695276962769727698276992770027701277022770327704277052770627707277082770927710277112771227713277142771527716277172771827719277202772127722277232772427725277262772727728277292773027731277322773327734277352773627737277382773927740277412774227743277442774527746277472774827749277502775127752277532775427755277562775727758277592776027761277622776327764277652776627767277682776927770277712777227773277742777527776277772777827779277802778127782277832778427785277862778727788277892779027791277922779327794277952779627797277982779927800278012780227803278042780527806278072780827809278102781127812278132781427815278162781727818278192782027821278222782327824278252782627827278282782927830278312783227833278342783527836278372783827839278402784127842278432784427845278462784727848278492785027851278522785327854278552785627857278582785927860278612786227863278642786527866278672786827869278702787127872278732787427875278762787727878278792788027881278822788327884278852788627887278882788927890278912789227893278942789527896278972789827899279002790127902279032790427905279062790727908279092791027911279122791327914279152791627917279182791927920279212792227923279242792527926279272792827929279302793127932279332793427935279362793727938279392794027941279422794327944279452794627947279482794927950279512795227953279542795527956279572795827959279602796127962279632796427965279662796727968279692797027971279722797327974279752797627977279782797927980279812798227983279842798527986279872798827989279902799127992279932799427995279962799727998279992800028001280022800328004280052800628007280082800928010280112801228013280142801528016280172801828019280202802128022280232802428025280262802728028280292803028031280322803328034280352803628037280382803928040280412804228043280442804528046280472804828049280502805128052280532805428055280562805728058280592806028061280622806328064280652806628067280682806928070280712807228073280742807528076280772807828079280802808128082280832808428085280862808728088280892809028091280922809328094280952809628097280982809928100281012810228103281042810528106281072810828109281102811128112281132811428115281162811728118281192812028121281222812328124281252812628127281282812928130281312813228133281342813528136281372813828139281402814128142281432814428145281462814728148281492815028151281522815328154281552815628157281582815928160281612816228163281642816528166281672816828169281702817128172281732817428175281762817728178281792818028181281822818328184281852818628187281882818928190281912819228193281942819528196281972819828199282002820128202282032820428205282062820728208282092821028211282122821328214282152821628217282182821928220282212822228223282242822528226282272822828229282302823128232282332823428235282362823728238282392824028241282422824328244282452824628247282482824928250282512825228253282542825528256282572825828259282602826128262282632826428265282662826728268282692827028271282722827328274282752827628277282782827928280282812828228283282842828528286282872828828289282902829128292282932829428295282962829728298282992830028301283022830328304283052830628307283082830928310283112831228313283142831528316283172831828319283202832128322283232832428325283262832728328283292833028331283322833328334283352833628337283382833928340283412834228343283442834528346283472834828349283502835128352283532835428355283562835728358283592836028361283622836328364283652836628367283682836928370283712837228373283742837528376283772837828379283802838128382283832838428385283862838728388283892839028391283922839328394283952839628397283982839928400284012840228403284042840528406284072840828409284102841128412284132841428415284162841728418284192842028421284222842328424284252842628427284282842928430284312843228433284342843528436284372843828439284402844128442284432844428445284462844728448284492845028451284522845328454284552845628457284582845928460284612846228463284642846528466284672846828469284702847128472284732847428475284762847728478284792848028481284822848328484284852848628487284882848928490284912849228493284942849528496284972849828499285002850128502285032850428505285062850728508285092851028511285122851328514285152851628517285182851928520285212852228523285242852528526285272852828529285302853128532285332853428535285362853728538285392854028541285422854328544285452854628547285482854928550285512855228553285542855528556285572855828559285602856128562285632856428565285662856728568285692857028571285722857328574285752857628577285782857928580285812858228583285842858528586285872858828589285902859128592285932859428595285962859728598285992860028601286022860328604286052860628607286082860928610286112861228613286142861528616286172861828619286202862128622286232862428625286262862728628286292863028631286322863328634286352863628637286382863928640286412864228643286442864528646286472864828649286502865128652286532865428655286562865728658286592866028661286622866328664286652866628667286682866928670286712867228673286742867528676286772867828679286802868128682286832868428685286862868728688286892869028691286922869328694286952869628697286982869928700287012870228703287042870528706287072870828709287102871128712287132871428715287162871728718287192872028721287222872328724287252872628727287282872928730287312873228733287342873528736287372873828739287402874128742287432874428745287462874728748287492875028751287522875328754287552875628757287582875928760287612876228763287642876528766287672876828769287702877128772287732877428775287762877728778287792878028781287822878328784287852878628787287882878928790287912879228793287942879528796287972879828799288002880128802288032880428805288062880728808288092881028811288122881328814288152881628817288182881928820288212882228823288242882528826288272882828829288302883128832288332883428835288362883728838288392884028841288422884328844288452884628847288482884928850288512885228853288542885528856288572885828859288602886128862288632886428865288662886728868288692887028871288722887328874288752887628877288782887928880288812888228883288842888528886288872888828889288902889128892288932889428895288962889728898288992890028901289022890328904289052890628907289082890928910289112891228913289142891528916289172891828919289202892128922289232892428925289262892728928289292893028931289322893328934289352893628937289382893928940289412894228943289442894528946289472894828949289502895128952289532895428955289562895728958289592896028961289622896328964289652896628967289682896928970289712897228973289742897528976289772897828979289802898128982289832898428985289862898728988289892899028991289922899328994289952899628997289982899929000290012900229003290042900529006290072900829009290102901129012290132901429015290162901729018290192902029021290222902329024290252902629027290282902929030290312903229033290342903529036290372903829039290402904129042290432904429045290462904729048290492905029051290522905329054290552905629057290582905929060290612906229063290642906529066290672906829069290702907129072290732907429075290762907729078290792908029081290822908329084290852908629087290882908929090290912909229093290942909529096290972909829099291002910129102291032910429105291062910729108291092911029111291122911329114291152911629117291182911929120291212912229123291242912529126291272912829129291302913129132291332913429135291362913729138291392914029141291422914329144291452914629147291482914929150291512915229153291542915529156291572915829159291602916129162291632916429165291662916729168291692917029171291722917329174291752917629177291782917929180291812918229183291842918529186291872918829189291902919129192291932919429195291962919729198291992920029201292022920329204292052920629207292082920929210292112921229213292142921529216292172921829219292202922129222292232922429225292262922729228292292923029231292322923329234292352923629237292382923929240292412924229243292442924529246292472924829249292502925129252292532925429255292562925729258292592926029261292622926329264292652926629267292682926929270292712927229273292742927529276292772927829279292802928129282292832928429285292862928729288292892929029291292922929329294292952929629297292982929929300293012930229303293042930529306293072930829309293102931129312293132931429315293162931729318293192932029321293222932329324293252932629327293282932929330293312933229333293342933529336293372933829339293402934129342293432934429345293462934729348293492935029351293522935329354293552935629357293582935929360293612936229363293642936529366293672936829369293702937129372293732937429375293762937729378293792938029381293822938329384293852938629387293882938929390293912939229393293942939529396293972939829399294002940129402294032940429405294062940729408294092941029411294122941329414294152941629417294182941929420294212942229423294242942529426294272942829429294302943129432294332943429435294362943729438294392944029441294422944329444294452944629447294482944929450294512945229453294542945529456294572945829459294602946129462294632946429465294662946729468294692947029471294722947329474294752947629477294782947929480294812948229483294842948529486294872948829489294902949129492294932949429495294962949729498294992950029501295022950329504295052950629507295082950929510295112951229513295142951529516295172951829519295202952129522295232952429525295262952729528295292953029531295322953329534295352953629537295382953929540295412954229543295442954529546295472954829549295502955129552295532955429555295562955729558295592956029561295622956329564295652956629567295682956929570295712957229573295742957529576295772957829579295802958129582295832958429585295862958729588295892959029591295922959329594295952959629597295982959929600296012960229603296042960529606296072960829609296102961129612296132961429615296162961729618296192962029621296222962329624296252962629627296282962929630296312963229633296342963529636296372963829639296402964129642296432964429645296462964729648296492965029651296522965329654296552965629657296582965929660296612966229663296642966529666296672966829669296702967129672296732967429675296762967729678296792968029681296822968329684296852968629687296882968929690296912969229693296942969529696296972969829699297002970129702297032970429705297062970729708297092971029711297122971329714297152971629717297182971929720297212972229723297242972529726297272972829729297302973129732297332973429735297362973729738297392974029741297422974329744297452974629747297482974929750297512975229753297542975529756297572975829759297602976129762297632976429765297662976729768297692977029771297722977329774297752977629777297782977929780297812978229783297842978529786297872978829789297902979129792297932979429795297962979729798297992980029801298022980329804298052980629807298082980929810298112981229813298142981529816298172981829819298202982129822298232982429825298262982729828298292983029831298322983329834298352983629837298382983929840298412984229843298442984529846298472984829849298502985129852298532985429855298562985729858298592986029861298622986329864298652986629867298682986929870298712987229873298742987529876298772987829879298802988129882298832988429885298862988729888298892989029891298922989329894298952989629897298982989929900299012990229903299042990529906299072990829909299102991129912299132991429915299162991729918299192992029921299222992329924299252992629927299282992929930299312993229933299342993529936299372993829939299402994129942299432994429945299462994729948299492995029951299522995329954299552995629957299582995929960299612996229963299642996529966299672996829969299702997129972299732997429975299762997729978299792998029981299822998329984299852998629987299882998929990299912999229993299942999529996299972999829999300003000130002300033000430005300063000730008300093001030011300123001330014300153001630017300183001930020300213002230023300243002530026300273002830029300303003130032300333003430035300363003730038300393004030041300423004330044300453004630047300483004930050300513005230053300543005530056300573005830059300603006130062300633006430065300663006730068300693007030071300723007330074300753007630077300783007930080300813008230083300843008530086300873008830089300903009130092300933009430095300963009730098300993010030101301023010330104301053010630107301083010930110301113011230113301143011530116301173011830119301203012130122301233012430125301263012730128301293013030131301323013330134301353013630137301383013930140301413014230143301443014530146301473014830149301503015130152301533015430155301563015730158301593016030161301623016330164301653016630167301683016930170301713017230173301743017530176301773017830179301803018130182301833018430185301863018730188301893019030191301923019330194301953019630197301983019930200302013020230203302043020530206302073020830209302103021130212302133021430215302163021730218302193022030221302223022330224302253022630227302283022930230302313023230233302343023530236302373023830239302403024130242302433024430245302463024730248302493025030251302523025330254302553025630257302583025930260302613026230263302643026530266302673026830269302703027130272302733027430275302763027730278302793028030281302823028330284302853028630287302883028930290302913029230293302943029530296302973029830299303003030130302303033030430305303063030730308303093031030311303123031330314303153031630317303183031930320303213032230323303243032530326303273032830329303303033130332303333033430335303363033730338303393034030341303423034330344303453034630347303483034930350303513035230353303543035530356303573035830359303603036130362303633036430365303663036730368303693037030371303723037330374303753037630377303783037930380303813038230383303843038530386303873038830389303903039130392303933039430395303963039730398303993040030401304023040330404304053040630407304083040930410304113041230413304143041530416304173041830419304203042130422304233042430425304263042730428304293043030431304323043330434304353043630437304383043930440304413044230443304443044530446304473044830449304503045130452304533045430455304563045730458304593046030461304623046330464304653046630467304683046930470304713047230473304743047530476304773047830479304803048130482304833048430485304863048730488304893049030491304923049330494304953049630497304983049930500305013050230503305043050530506305073050830509305103051130512305133051430515305163051730518305193052030521305223052330524305253052630527305283052930530305313053230533305343053530536305373053830539305403054130542305433054430545305463054730548305493055030551305523055330554305553055630557305583055930560305613056230563305643056530566305673056830569305703057130572305733057430575305763057730578305793058030581305823058330584305853058630587305883058930590305913059230593305943059530596305973059830599306003060130602306033060430605306063060730608306093061030611306123061330614306153061630617306183061930620306213062230623306243062530626306273062830629306303063130632306333063430635306363063730638306393064030641306423064330644306453064630647306483064930650306513065230653306543065530656306573065830659306603066130662306633066430665306663066730668306693067030671306723067330674306753067630677306783067930680306813068230683306843068530686306873068830689306903069130692306933069430695306963069730698306993070030701307023070330704307053070630707307083070930710307113071230713307143071530716307173071830719307203072130722307233072430725307263072730728307293073030731307323073330734307353073630737307383073930740307413074230743307443074530746307473074830749307503075130752307533075430755307563075730758307593076030761307623076330764307653076630767307683076930770307713077230773307743077530776307773077830779307803078130782307833078430785307863078730788307893079030791307923079330794307953079630797307983079930800308013080230803308043080530806308073080830809308103081130812308133081430815308163081730818308193082030821308223082330824308253082630827308283082930830308313083230833308343083530836308373083830839308403084130842308433084430845308463084730848308493085030851308523085330854308553085630857308583085930860308613086230863308643086530866308673086830869308703087130872308733087430875308763087730878308793088030881308823088330884308853088630887308883088930890308913089230893308943089530896308973089830899309003090130902309033090430905309063090730908309093091030911309123091330914309153091630917309183091930920309213092230923309243092530926309273092830929309303093130932309333093430935309363093730938309393094030941309423094330944309453094630947309483094930950309513095230953309543095530956309573095830959309603096130962309633096430965309663096730968309693097030971309723097330974309753097630977309783097930980309813098230983309843098530986309873098830989309903099130992309933099430995309963099730998309993100031001310023100331004310053100631007310083100931010310113101231013310143101531016310173101831019310203102131022310233102431025310263102731028310293103031031310323103331034310353103631037310383103931040310413104231043310443104531046310473104831049310503105131052310533105431055310563105731058310593106031061310623106331064310653106631067310683106931070310713107231073310743107531076310773107831079310803108131082310833108431085310863108731088310893109031091310923109331094310953109631097310983109931100311013110231103311043110531106311073110831109311103111131112311133111431115311163111731118311193112031121311223112331124311253112631127311283112931130311313113231133311343113531136311373113831139311403114131142311433114431145311463114731148311493115031151311523115331154311553115631157311583115931160311613116231163311643116531166311673116831169311703117131172311733117431175311763117731178311793118031181311823118331184311853118631187311883118931190311913119231193311943119531196311973119831199312003120131202312033120431205312063120731208312093121031211312123121331214312153121631217312183121931220312213122231223312243122531226312273122831229312303123131232312333123431235312363123731238312393124031241312423124331244312453124631247312483124931250312513125231253312543125531256312573125831259312603126131262312633126431265312663126731268312693127031271312723127331274312753127631277312783127931280312813128231283312843128531286312873128831289312903129131292312933129431295312963129731298312993130031301313023130331304313053130631307313083130931310313113131231313313143131531316313173131831319313203132131322313233132431325313263132731328313293133031331313323133331334313353133631337313383133931340313413134231343313443134531346313473134831349313503135131352313533135431355313563135731358313593136031361313623136331364313653136631367313683136931370313713137231373313743137531376313773137831379313803138131382313833138431385313863138731388313893139031391313923139331394313953139631397313983139931400314013140231403314043140531406314073140831409314103141131412314133141431415314163141731418314193142031421314223142331424314253142631427314283142931430314313143231433314343143531436314373143831439314403144131442314433144431445314463144731448314493145031451314523145331454314553145631457314583145931460314613146231463314643146531466314673146831469314703147131472314733147431475314763147731478314793148031481314823148331484314853148631487314883148931490314913149231493314943149531496314973149831499315003150131502315033150431505315063150731508315093151031511315123151331514315153151631517315183151931520315213152231523315243152531526315273152831529315303153131532315333153431535315363153731538315393154031541315423154331544315453154631547315483154931550315513155231553315543155531556315573155831559315603156131562315633156431565315663156731568315693157031571315723157331574315753157631577315783157931580315813158231583315843158531586315873158831589315903159131592315933159431595315963159731598315993160031601316023160331604316053160631607316083160931610316113161231613316143161531616316173161831619316203162131622316233162431625316263162731628316293163031631316323163331634316353163631637316383163931640316413164231643316443164531646316473164831649316503165131652316533165431655316563165731658316593166031661316623166331664316653166631667316683166931670316713167231673316743167531676316773167831679316803168131682316833168431685316863168731688316893169031691316923169331694316953169631697316983169931700317013170231703317043170531706317073170831709317103171131712317133171431715317163171731718317193172031721317223172331724317253172631727317283172931730317313173231733317343173531736317373173831739317403174131742317433174431745317463174731748317493175031751317523175331754317553175631757317583175931760317613176231763317643176531766317673176831769317703177131772317733177431775317763177731778317793178031781317823178331784317853178631787317883178931790317913179231793317943179531796317973179831799318003180131802318033180431805318063180731808318093181031811318123181331814318153181631817318183181931820318213182231823318243182531826318273182831829318303183131832318333183431835318363183731838318393184031841318423184331844318453184631847318483184931850318513185231853318543185531856318573185831859318603186131862318633186431865318663186731868318693187031871318723187331874318753187631877318783187931880318813188231883318843188531886318873188831889318903189131892318933189431895318963189731898318993190031901319023190331904319053190631907319083190931910319113191231913319143191531916319173191831919319203192131922319233192431925319263192731928319293193031931319323193331934319353193631937319383193931940319413194231943319443194531946319473194831949319503195131952319533195431955319563195731958319593196031961319623196331964319653196631967319683196931970319713197231973319743197531976319773197831979319803198131982319833198431985319863198731988319893199031991319923199331994319953199631997319983199932000320013200232003320043200532006320073200832009320103201132012320133201432015320163201732018320193202032021320223202332024320253202632027320283202932030320313203232033320343203532036320373203832039320403204132042320433204432045320463204732048320493205032051320523205332054320553205632057320583205932060320613206232063320643206532066320673206832069320703207132072320733207432075320763207732078320793208032081320823208332084320853208632087320883208932090320913209232093320943209532096320973209832099321003210132102321033210432105321063210732108321093211032111321123211332114321153211632117321183211932120321213212232123321243212532126321273212832129321303213132132321333213432135321363213732138321393214032141321423214332144321453214632147321483214932150321513215232153321543215532156321573215832159321603216132162321633216432165321663216732168321693217032171321723217332174321753217632177321783217932180321813218232183321843218532186321873218832189321903219132192321933219432195321963219732198321993220032201322023220332204322053220632207322083220932210322113221232213322143221532216322173221832219322203222132222322233222432225322263222732228322293223032231322323223332234322353223632237322383223932240322413224232243322443224532246322473224832249322503225132252322533225432255322563225732258322593226032261322623226332264322653226632267322683226932270322713227232273322743227532276322773227832279322803228132282322833228432285322863228732288322893229032291322923229332294322953229632297322983229932300323013230232303323043230532306323073230832309323103231132312323133231432315323163231732318323193232032321323223232332324323253232632327323283232932330323313233232333323343233532336323373233832339323403234132342323433234432345323463234732348323493235032351323523235332354323553235632357323583235932360323613236232363323643236532366323673236832369323703237132372323733237432375323763237732378323793238032381323823238332384323853238632387323883238932390323913239232393323943239532396323973239832399324003240132402324033240432405324063240732408324093241032411324123241332414324153241632417324183241932420324213242232423324243242532426324273242832429324303243132432324333243432435324363243732438324393244032441324423244332444324453244632447324483244932450324513245232453324543245532456324573245832459324603246132462324633246432465324663246732468324693247032471324723247332474324753247632477324783247932480324813248232483324843248532486324873248832489324903249132492324933249432495324963249732498324993250032501325023250332504325053250632507325083250932510325113251232513325143251532516325173251832519325203252132522325233252432525325263252732528325293253032531325323253332534325353253632537325383253932540325413254232543325443254532546325473254832549325503255132552325533255432555325563255732558325593256032561325623256332564325653256632567325683256932570325713257232573325743257532576325773257832579325803258132582325833258432585325863258732588325893259032591325923259332594325953259632597325983259932600326013260232603326043260532606326073260832609326103261132612326133261432615326163261732618326193262032621326223262332624326253262632627326283262932630326313263232633326343263532636326373263832639326403264132642326433264432645326463264732648326493265032651326523265332654326553265632657326583265932660326613266232663326643266532666326673266832669326703267132672326733267432675326763267732678326793268032681326823268332684326853268632687326883268932690326913269232693326943269532696326973269832699327003270132702327033270432705327063270732708327093271032711327123271332714327153271632717327183271932720327213272232723327243272532726327273272832729327303273132732327333273432735327363273732738327393274032741327423274332744327453274632747327483274932750327513275232753327543275532756327573275832759327603276132762327633276432765327663276732768327693277032771327723277332774327753277632777327783277932780327813278232783327843278532786327873278832789327903279132792327933279432795327963279732798327993280032801328023280332804328053280632807328083280932810328113281232813328143281532816328173281832819328203282132822328233282432825328263282732828328293283032831328323283332834328353283632837328383283932840328413284232843328443284532846328473284832849328503285132852328533285432855328563285732858328593286032861328623286332864328653286632867328683286932870328713287232873328743287532876328773287832879328803288132882328833288432885328863288732888328893289032891328923289332894328953289632897328983289932900329013290232903329043290532906329073290832909329103291132912329133291432915329163291732918329193292032921329223292332924329253292632927329283292932930329313293232933329343293532936329373293832939329403294132942329433294432945329463294732948329493295032951329523295332954329553295632957329583295932960329613296232963329643296532966329673296832969329703297132972329733297432975329763297732978329793298032981329823298332984329853298632987329883298932990329913299232993329943299532996329973299832999330003300133002330033300433005330063300733008330093301033011330123301333014330153301633017330183301933020330213302233023330243302533026330273302833029330303303133032330333303433035330363303733038330393304033041330423304333044330453304633047330483304933050330513305233053330543305533056330573305833059330603306133062330633306433065330663306733068330693307033071330723307333074330753307633077330783307933080330813308233083330843308533086330873308833089330903309133092330933309433095330963309733098330993310033101331023310333104331053310633107331083310933110331113311233113331143311533116331173311833119331203312133122331233312433125331263312733128331293313033131331323313333134331353313633137331383313933140331413314233143331443314533146331473314833149331503315133152331533315433155331563315733158331593316033161331623316333164331653316633167331683316933170331713317233173331743317533176331773317833179331803318133182331833318433185331863318733188331893319033191331923319333194331953319633197331983319933200332013320233203332043320533206332073320833209332103321133212332133321433215332163321733218332193322033221332223322333224332253322633227332283322933230332313323233233332343323533236332373323833239332403324133242332433324433245332463324733248332493325033251332523325333254332553325633257332583325933260332613326233263332643326533266332673326833269332703327133272332733327433275332763327733278332793328033281332823328333284332853328633287332883328933290332913329233293332943329533296332973329833299333003330133302333033330433305333063330733308333093331033311333123331333314333153331633317333183331933320333213332233323333243332533326333273332833329333303333133332333333333433335333363333733338333393334033341333423334333344333453334633347333483334933350333513335233353333543335533356333573335833359333603336133362333633336433365333663336733368333693337033371333723337333374333753337633377333783337933380333813338233383333843338533386333873338833389333903339133392333933339433395333963339733398333993340033401334023340333404334053340633407334083340933410334113341233413334143341533416334173341833419334203342133422334233342433425334263342733428334293343033431334323343333434334353343633437334383343933440334413344233443334443344533446334473344833449334503345133452334533345433455334563345733458334593346033461334623346333464334653346633467334683346933470334713347233473334743347533476334773347833479334803348133482334833348433485334863348733488334893349033491334923349333494334953349633497334983349933500335013350233503335043350533506335073350833509335103351133512335133351433515335163351733518335193352033521335223352333524335253352633527335283352933530335313353233533335343353533536335373353833539335403354133542335433354433545335463354733548335493355033551335523355333554335553355633557335583355933560335613356233563335643356533566335673356833569335703357133572335733357433575335763357733578335793358033581335823358333584335853358633587335883358933590335913359233593335943359533596335973359833599336003360133602336033360433605336063360733608336093361033611336123361333614336153361633617336183361933620336213362233623336243362533626336273362833629336303363133632336333363433635336363363733638336393364033641336423364333644336453364633647336483364933650336513365233653336543365533656336573365833659336603366133662336633366433665336663366733668336693367033671336723367333674336753367633677336783367933680336813368233683336843368533686336873368833689336903369133692336933369433695336963369733698336993370033701337023370333704337053370633707337083370933710337113371233713337143371533716337173371833719337203372133722337233372433725337263372733728337293373033731337323373333734337353373633737337383373933740337413374233743337443374533746337473374833749337503375133752337533375433755337563375733758337593376033761337623376333764337653376633767337683376933770337713377233773337743377533776337773377833779337803378133782337833378433785337863378733788337893379033791337923379333794337953379633797337983379933800338013380233803338043380533806338073380833809338103381133812338133381433815338163381733818338193382033821338223382333824338253382633827338283382933830338313383233833338343383533836338373383833839338403384133842338433384433845338463384733848338493385033851338523385333854338553385633857338583385933860338613386233863338643386533866338673386833869338703387133872338733387433875338763387733878338793388033881338823388333884338853388633887338883388933890338913389233893338943389533896338973389833899339003390133902339033390433905339063390733908339093391033911339123391333914339153391633917339183391933920339213392233923339243392533926339273392833929339303393133932339333393433935339363393733938339393394033941339423394333944339453394633947339483394933950339513395233953339543395533956339573395833959339603396133962339633396433965339663396733968339693397033971339723397333974339753397633977339783397933980339813398233983339843398533986339873398833989339903399133992339933399433995339963399733998339993400034001340023400334004340053400634007340083400934010340113401234013340143401534016340173401834019340203402134022340233402434025340263402734028340293403034031340323403334034340353403634037340383403934040340413404234043340443404534046340473404834049340503405134052340533405434055340563405734058340593406034061340623406334064340653406634067340683406934070340713407234073340743407534076340773407834079340803408134082340833408434085340863408734088340893409034091340923409334094340953409634097340983409934100341013410234103341043410534106341073410834109341103411134112341133411434115341163411734118341193412034121341223412334124341253412634127341283412934130341313413234133341343413534136341373413834139341403414134142341433414434145341463414734148341493415034151341523415334154341553415634157341583415934160341613416234163341643416534166341673416834169341703417134172341733417434175341763417734178341793418034181341823418334184341853418634187341883418934190341913419234193341943419534196341973419834199342003420134202342033420434205342063420734208342093421034211342123421334214342153421634217342183421934220342213422234223342243422534226342273422834229342303423134232342333423434235342363423734238342393424034241342423424334244342453424634247342483424934250342513425234253342543425534256342573425834259342603426134262342633426434265342663426734268342693427034271342723427334274342753427634277342783427934280342813428234283342843428534286342873428834289342903429134292342933429434295342963429734298342993430034301343023430334304343053430634307343083430934310343113431234313343143431534316343173431834319343203432134322343233432434325343263432734328343293433034331343323433334334343353433634337343383433934340343413434234343343443434534346343473434834349343503435134352343533435434355343563435734358343593436034361343623436334364343653436634367343683436934370343713437234373343743437534376343773437834379343803438134382343833438434385343863438734388343893439034391343923439334394343953439634397343983439934400344013440234403344043440534406344073440834409344103441134412344133441434415344163441734418344193442034421344223442334424344253442634427344283442934430344313443234433344343443534436344373443834439344403444134442344433444434445344463444734448344493445034451344523445334454344553445634457344583445934460344613446234463344643446534466344673446834469344703447134472344733447434475344763447734478344793448034481344823448334484344853448634487344883448934490344913449234493344943449534496344973449834499345003450134502345033450434505345063450734508345093451034511345123451334514345153451634517345183451934520345213452234523345243452534526345273452834529345303453134532345333453434535345363453734538345393454034541345423454334544345453454634547345483454934550345513455234553345543455534556345573455834559345603456134562345633456434565345663456734568345693457034571345723457334574345753457634577345783457934580345813458234583345843458534586345873458834589345903459134592345933459434595345963459734598345993460034601346023460334604346053460634607346083460934610346113461234613346143461534616346173461834619346203462134622346233462434625346263462734628346293463034631346323463334634346353463634637346383463934640346413464234643346443464534646346473464834649346503465134652346533465434655346563465734658346593466034661346623466334664346653466634667346683466934670346713467234673346743467534676346773467834679346803468134682346833468434685346863468734688346893469034691346923469334694346953469634697346983469934700347013470234703347043470534706347073470834709347103471134712347133471434715347163471734718347193472034721347223472334724347253472634727347283472934730347313473234733347343473534736347373473834739347403474134742347433474434745347463474734748347493475034751347523475334754347553475634757347583475934760347613476234763347643476534766347673476834769347703477134772347733477434775347763477734778347793478034781347823478334784347853478634787347883478934790347913479234793347943479534796347973479834799348003480134802348033480434805348063480734808348093481034811348123481334814348153481634817348183481934820348213482234823348243482534826348273482834829348303483134832348333483434835348363483734838348393484034841348423484334844348453484634847348483484934850348513485234853348543485534856348573485834859348603486134862348633486434865348663486734868348693487034871348723487334874348753487634877348783487934880348813488234883348843488534886348873488834889348903489134892348933489434895348963489734898348993490034901349023490334904349053490634907349083490934910349113491234913349143491534916349173491834919349203492134922349233492434925349263492734928349293493034931349323493334934349353493634937349383493934940349413494234943349443494534946349473494834949349503495134952349533495434955349563495734958349593496034961349623496334964349653496634967349683496934970349713497234973349743497534976349773497834979349803498134982349833498434985349863498734988349893499034991349923499334994349953499634997349983499935000350013500235003350043500535006350073500835009350103501135012350133501435015350163501735018350193502035021350223502335024350253502635027350283502935030350313503235033350343503535036350373503835039350403504135042350433504435045350463504735048350493505035051350523505335054350553505635057350583505935060350613506235063350643506535066350673506835069350703507135072350733507435075350763507735078350793508035081350823508335084350853508635087350883508935090350913509235093350943509535096350973509835099351003510135102351033510435105351063510735108351093511035111351123511335114351153511635117351183511935120351213512235123351243512535126351273512835129351303513135132351333513435135351363513735138351393514035141351423514335144351453514635147351483514935150351513515235153351543515535156351573515835159351603516135162351633516435165351663516735168351693517035171351723517335174351753517635177351783517935180351813518235183351843518535186351873518835189351903519135192351933519435195351963519735198351993520035201352023520335204352053520635207352083520935210352113521235213352143521535216352173521835219352203522135222352233522435225352263522735228352293523035231352323523335234352353523635237352383523935240352413524235243352443524535246352473524835249352503525135252352533525435255352563525735258352593526035261352623526335264352653526635267352683526935270352713527235273352743527535276352773527835279352803528135282352833528435285352863528735288352893529035291352923529335294352953529635297352983529935300353013530235303353043530535306353073530835309353103531135312353133531435315353163531735318353193532035321353223532335324353253532635327353283532935330353313533235333353343533535336353373533835339353403534135342353433534435345353463534735348353493535035351353523535335354353553535635357353583535935360353613536235363353643536535366353673536835369353703537135372353733537435375353763537735378353793538035381353823538335384353853538635387353883538935390353913539235393353943539535396353973539835399354003540135402354033540435405354063540735408354093541035411354123541335414354153541635417354183541935420354213542235423354243542535426354273542835429354303543135432354333543435435354363543735438354393544035441354423544335444354453544635447354483544935450354513545235453354543545535456354573545835459354603546135462354633546435465354663546735468354693547035471354723547335474354753547635477354783547935480354813548235483354843548535486354873548835489354903549135492354933549435495354963549735498354993550035501355023550335504355053550635507355083550935510355113551235513355143551535516355173551835519355203552135522355233552435525355263552735528355293553035531355323553335534355353553635537355383553935540355413554235543355443554535546355473554835549355503555135552355533555435555355563555735558355593556035561355623556335564355653556635567355683556935570355713557235573355743557535576355773557835579355803558135582355833558435585355863558735588355893559035591355923559335594355953559635597355983559935600356013560235603356043560535606356073560835609356103561135612356133561435615356163561735618356193562035621356223562335624356253562635627356283562935630356313563235633356343563535636356373563835639356403564135642356433564435645356463564735648356493565035651356523565335654356553565635657356583565935660356613566235663356643566535666356673566835669356703567135672356733567435675356763567735678356793568035681356823568335684356853568635687356883568935690356913569235693356943569535696356973569835699357003570135702357033570435705357063570735708357093571035711357123571335714357153571635717357183571935720357213572235723357243572535726357273572835729357303573135732357333573435735357363573735738357393574035741357423574335744357453574635747357483574935750357513575235753357543575535756357573575835759357603576135762357633576435765357663576735768357693577035771357723577335774357753577635777357783577935780357813578235783357843578535786357873578835789357903579135792357933579435795357963579735798357993580035801358023580335804358053580635807358083580935810358113581235813358143581535816358173581835819358203582135822358233582435825358263582735828358293583035831358323583335834358353583635837358383583935840358413584235843358443584535846358473584835849358503585135852358533585435855358563585735858358593586035861358623586335864358653586635867358683586935870358713587235873358743587535876358773587835879358803588135882358833588435885358863588735888358893589035891358923589335894358953589635897358983589935900359013590235903359043590535906359073590835909359103591135912359133591435915359163591735918359193592035921359223592335924359253592635927359283592935930359313593235933359343593535936359373593835939359403594135942359433594435945359463594735948359493595035951359523595335954359553595635957359583595935960359613596235963359643596535966359673596835969359703597135972359733597435975359763597735978359793598035981359823598335984359853598635987359883598935990359913599235993359943599535996359973599835999360003600136002360033600436005360063600736008360093601036011360123601336014360153601636017360183601936020360213602236023360243602536026360273602836029360303603136032360333603436035360363603736038360393604036041360423604336044360453604636047360483604936050360513605236053360543605536056360573605836059360603606136062360633606436065360663606736068360693607036071360723607336074360753607636077360783607936080360813608236083360843608536086360873608836089360903609136092360933609436095360963609736098360993610036101361023610336104361053610636107361083610936110361113611236113361143611536116361173611836119361203612136122361233612436125361263612736128361293613036131361323613336134361353613636137361383613936140361413614236143361443614536146361473614836149361503615136152361533615436155361563615736158361593616036161361623616336164361653616636167361683616936170361713617236173361743617536176361773617836179361803618136182361833618436185361863618736188361893619036191361923619336194361953619636197361983619936200362013620236203362043620536206 |
- /*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
- ! function(t, e) {
- "object" == typeof exports && "undefined" != typeof module ? e(exports) : "function" == typeof define && define.amd ?
- define(["exports"], e) : e(t.echarts = {})
- }(this, function(t) {
- "use strict";
- function e(t, e) {
- "createCanvas" === t && (q_ = null), j_[t] = e
- }
- function i(t) {
- if (null == t || "object" != typeof t) return t;
- var e = t,
- n = G_.call(t);
- if ("[object Array]" === n) {
- if (!O(t)) {
- e = [];
- for (var o = 0, a = t.length; o < a; o++) e[o] = i(t[o])
- }
- } else if (V_[n]) {
- if (!O(t)) {
- var r = t.constructor;
- if (t.constructor.from) e = r.from(t);
- else {
- e = new r(t.length);
- for (var o = 0, a = t.length; o < a; o++) e[o] = i(t[o])
- }
- }
- } else if (!B_[n] && !O(t) && !M(t)) {
- e = {};
- for (var s in t) t.hasOwnProperty(s) && (e[s] = i(t[s]))
- }
- return e
- }
- function n(t, e, o) {
- if (!w(e) || !w(t)) return o ? i(e) : t;
- for (var a in e)
- if (e.hasOwnProperty(a)) {
- var r = t[a],
- s = e[a];
- !w(s) || !w(r) || y(s) || y(r) || M(s) || M(r) || b(s) || b(r) || O(s) || O(r) ? !o && a in t || (t[a] = i(e[a], !
- 0)) : n(r, s, o)
- } return t
- }
- function o(t, e) {
- for (var i = t[0], o = 1, a = t.length; o < a; o++) i = n(i, t[o], e);
- return i
- }
- function a(t, e) {
- for (var i in e) e.hasOwnProperty(i) && (t[i] = e[i]);
- return t
- }
- function r(t, e, i) {
- for (var n in e) e.hasOwnProperty(n) && (i ? null != e[n] : null == t[n]) && (t[n] = e[n]);
- return t
- }
- function s() {
- return q_ || (q_ = Y_().getContext("2d")), q_
- }
- function l(t, e) {
- if (t) {
- if (t.indexOf) return t.indexOf(e);
- for (var i = 0, n = t.length; i < n; i++)
- if (t[i] === e) return i
- }
- return -1
- }
- function u(t, e) {
- function i() {}
- var n = t.prototype;
- i.prototype = e.prototype, t.prototype = new i;
- for (var o in n) t.prototype[o] = n[o];
- t.prototype.constructor = t, t.superClass = e
- }
- function h(t, e, i) {
- r(t = "prototype" in t ? t.prototype : t, e = "prototype" in e ? e.prototype : e, i)
- }
- function c(t) {
- if (t) return "string" != typeof t && "number" == typeof t.length
- }
- function d(t, e, i) {
- if (t && e)
- if (t.forEach && t.forEach === W_) t.forEach(e, i);
- else if (t.length === +t.length)
- for (var n = 0, o = t.length; n < o; n++) e.call(i, t[n], n, t);
- else
- for (var a in t) t.hasOwnProperty(a) && e.call(i, t[a], a, t)
- }
- function f(t, e, i) {
- if (t && e) {
- if (t.map && t.map === U_) return t.map(e, i);
- for (var n = [], o = 0, a = t.length; o < a; o++) n.push(e.call(i, t[o], o, t));
- return n
- }
- }
- function p(t, e, i, n) {
- if (t && e) {
- if (t.reduce && t.reduce === X_) return t.reduce(e, i, n);
- for (var o = 0, a = t.length; o < a; o++) i = e.call(n, i, t[o], o, t);
- return i
- }
- }
- function g(t, e, i) {
- if (t && e) {
- if (t.filter && t.filter === H_) return t.filter(e, i);
- for (var n = [], o = 0, a = t.length; o < a; o++) e.call(i, t[o], o, t) && n.push(t[o]);
- return n
- }
- }
- function m(t, e) {
- var i = Z_.call(arguments, 2);
- return function() {
- return t.apply(e, i.concat(Z_.call(arguments)))
- }
- }
- function v(t) {
- var e = Z_.call(arguments, 1);
- return function() {
- return t.apply(this, e.concat(Z_.call(arguments)))
- }
- }
- function y(t) {
- return "[object Array]" === G_.call(t)
- }
- function x(t) {
- return "function" == typeof t
- }
- function _(t) {
- return "[object String]" === G_.call(t)
- }
- function w(t) {
- var e = typeof t;
- return "function" === e || !!t && "object" == e
- }
- function b(t) {
- return !!B_[G_.call(t)]
- }
- function S(t) {
- return !!V_[G_.call(t)]
- }
- function M(t) {
- return "object" == typeof t && "number" == typeof t.nodeType && "object" == typeof t.ownerDocument
- }
- function I(t) {
- return t !== t
- }
- function T(t) {
- for (var e = 0, i = arguments.length; e < i; e++)
- if (null != arguments[e]) return arguments[e]
- }
- function A(t, e) {
- return null != t ? t : e
- }
- function D(t, e, i) {
- return null != t ? t : null != e ? e : i
- }
- function C() {
- return Function.call.apply(Z_, arguments)
- }
- function L(t) {
- if ("number" == typeof t) return [t, t, t, t];
- var e = t.length;
- return 2 === e ? [t[0], t[1], t[0], t[1]] : 3 === e ? [t[0], t[1], t[2], t[1]] : t
- }
- function k(t, e) {
- if (!t) throw new Error(e)
- }
- function P(t) {
- return null == t ? null : "function" == typeof t.trim ? t.trim() : t.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
- "")
- }
- function N(t) {
- t[K_] = !0
- }
- function O(t) {
- return t[K_]
- }
- function E(t) {
- function e(t, e) {
- i ? n.set(t, e) : n.set(e, t)
- }
- var i = y(t);
- this.data = {};
- var n = this;
- t instanceof E ? t.each(e) : t && d(t, e)
- }
- function R(t) {
- return new E(t)
- }
- function z(t, e) {
- for (var i = new t.constructor(t.length + e.length), n = 0; n < t.length; n++) i[n] = t[n];
- var o = t.length;
- for (n = 0; n < e.length; n++) i[n + o] = e[n];
- return i
- }
- function B() {}
- function V(t, e) {
- var i = new J_(2);
- return null == t && (t = 0), null == e && (e = 0), i[0] = t, i[1] = e, i
- }
- function G(t, e) {
- return t[0] = e[0], t[1] = e[1], t
- }
- function F(t) {
- var e = new J_(2);
- return e[0] = t[0], e[1] = t[1], e
- }
- function W(t, e, i) {
- return t[0] = e, t[1] = i, t
- }
- function H(t, e, i) {
- return t[0] = e[0] + i[0], t[1] = e[1] + i[1], t
- }
- function Z(t, e, i, n) {
- return t[0] = e[0] + i[0] * n, t[1] = e[1] + i[1] * n, t
- }
- function U(t, e, i) {
- return t[0] = e[0] - i[0], t[1] = e[1] - i[1], t
- }
- function X(t) {
- return Math.sqrt(j(t))
- }
- function j(t) {
- return t[0] * t[0] + t[1] * t[1]
- }
- function Y(t, e, i) {
- return t[0] = e[0] * i, t[1] = e[1] * i, t
- }
- function q(t, e) {
- var i = X(e);
- return 0 === i ? (t[0] = 0, t[1] = 0) : (t[0] = e[0] / i, t[1] = e[1] / i), t
- }
- function K(t, e) {
- return Math.sqrt((t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1]))
- }
- function $(t, e) {
- return (t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1])
- }
- function J(t, e, i, n) {
- return t[0] = e[0] + n * (i[0] - e[0]), t[1] = e[1] + n * (i[1] - e[1]), t
- }
- function Q(t, e, i) {
- var n = e[0],
- o = e[1];
- return t[0] = i[0] * n + i[2] * o + i[4], t[1] = i[1] * n + i[3] * o + i[5], t
- }
- function tt(t, e, i) {
- return t[0] = Math.min(e[0], i[0]), t[1] = Math.min(e[1], i[1]), t
- }
- function et(t, e, i) {
- return t[0] = Math.max(e[0], i[0]), t[1] = Math.max(e[1], i[1]), t
- }
- function it() {
- this.on("mousedown", this._dragStart, this), this.on("mousemove", this._drag, this), this.on("mouseup", this._dragEnd,
- this), this.on("globalout", this._dragEnd, this)
- }
- function nt(t, e) {
- return {
- target: t,
- topTarget: e && e.topTarget
- }
- }
- function ot(t, e) {
- var i = t._$eventProcessor;
- return null != e && i && i.normalizeQuery && (e = i.normalizeQuery(e)), e
- }
- function at(t) {
- return t.getBoundingClientRect ? t.getBoundingClientRect() : {
- left: 0,
- top: 0
- }
- }
- function rt(t, e, i, n) {
- return i = i || {}, n || !z_.canvasSupported ? st(t, e, i) : z_.browser.firefox && null != e.layerX && e.layerX !==
- e.offsetX ? (i.zrX = e.layerX, i.zrY = e.layerY) : null != e.offsetX ? (i.zrX = e.offsetX, i.zrY = e.offsetY) : st(
- t, e, i), i
- }
- function st(t, e, i) {
- var n = at(t);
- i.zrX = e.clientX - n.left, i.zrY = e.clientY - n.top
- }
- function lt(t, e, i) {
- if (null != (e = e || window.event).zrX) return e;
- var n = e.type;
- if (n && n.indexOf("touch") >= 0) {
- var o = "touchend" != n ? e.targetTouches[0] : e.changedTouches[0];
- o && rt(t, o, e, i)
- } else rt(t, e, e, i), e.zrDelta = e.wheelDelta ? e.wheelDelta / 120 : -(e.detail || 0) / 3;
- var a = e.button;
- return null == e.which && void 0 !== a && sw.test(e.type) && (e.which = 1 & a ? 1 : 2 & a ? 3 : 4 & a ? 2 : 0), e
- }
- function ut(t, e, i) {
- rw ? t.addEventListener(e, i) : t.attachEvent("on" + e, i)
- }
- function ht(t, e, i) {
- rw ? t.removeEventListener(e, i) : t.detachEvent("on" + e, i)
- }
- function ct(t) {
- return t.which > 1
- }
- function dt(t, e, i) {
- return {
- type: t,
- event: i,
- target: e.target,
- topTarget: e.topTarget,
- cancelBubble: !1,
- offsetX: i.zrX,
- offsetY: i.zrY,
- gestureEvent: i.gestureEvent,
- pinchX: i.pinchX,
- pinchY: i.pinchY,
- pinchScale: i.pinchScale,
- wheelDelta: i.zrDelta,
- zrByTouch: i.zrByTouch,
- which: i.which,
- stop: ft
- }
- }
- function ft(t) {
- lw(this.event)
- }
- function pt() {}
- function gt(t, e, i) {
- if (t[t.rectHover ? "rectContain" : "contain"](e, i)) {
- for (var n, o = t; o;) {
- if (o.clipPath && !o.clipPath.contain(e, i)) return !1;
- o.silent && (n = !0), o = o.parent
- }
- return !n || uw
- }
- return !1
- }
- function mt() {
- var t = new dw(6);
- return vt(t), t
- }
- function vt(t) {
- return t[0] = 1, t[1] = 0, t[2] = 0, t[3] = 1, t[4] = 0, t[5] = 0, t
- }
- function yt(t, e) {
- return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t[4] = e[4], t[5] = e[5], t
- }
- function xt(t, e, i) {
- var n = e[0] * i[0] + e[2] * i[1],
- o = e[1] * i[0] + e[3] * i[1],
- a = e[0] * i[2] + e[2] * i[3],
- r = e[1] * i[2] + e[3] * i[3],
- s = e[0] * i[4] + e[2] * i[5] + e[4],
- l = e[1] * i[4] + e[3] * i[5] + e[5];
- return t[0] = n, t[1] = o, t[2] = a, t[3] = r, t[4] = s, t[5] = l, t
- }
- function _t(t, e, i) {
- return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t[4] = e[4] + i[0], t[5] = e[5] + i[1], t
- }
- function wt(t, e, i) {
- var n = e[0],
- o = e[2],
- a = e[4],
- r = e[1],
- s = e[3],
- l = e[5],
- u = Math.sin(i),
- h = Math.cos(i);
- return t[0] = n * h + r * u, t[1] = -n * u + r * h, t[2] = o * h + s * u, t[3] = -o * u + h * s, t[4] = h * a + u *
- l, t[5] = h * l - u * a, t
- }
- function bt(t, e, i) {
- var n = i[0],
- o = i[1];
- return t[0] = e[0] * n, t[1] = e[1] * o, t[2] = e[2] * n, t[3] = e[3] * o, t[4] = e[4] * n, t[5] = e[5] * o, t
- }
- function St(t, e) {
- var i = e[0],
- n = e[2],
- o = e[4],
- a = e[1],
- r = e[3],
- s = e[5],
- l = i * r - a * n;
- return l ? (l = 1 / l, t[0] = r * l, t[1] = -a * l, t[2] = -n * l, t[3] = i * l, t[4] = (n * s - r * o) * l, t[5] =
- (a * o - i * s) * l, t) : null
- }
- function Mt(t) {
- var e = mt();
- return yt(e, t), e
- }
- function It(t) {
- return t > gw || t < -gw
- }
- function Tt(t) {
- this._target = t.target, this._life = t.life || 1e3, this._delay = t.delay || 0, this._initialized = !1, this.loop =
- null != t.loop && t.loop, this.gap = t.gap || 0, this.easing = t.easing || "Linear", this.onframe = t.onframe, this
- .ondestroy = t.ondestroy, this.onrestart = t.onrestart, this._pausedTime = 0, this._paused = !1
- }
- function At(t) {
- return (t = Math.round(t)) < 0 ? 0 : t > 255 ? 255 : t
- }
- function Dt(t) {
- return (t = Math.round(t)) < 0 ? 0 : t > 360 ? 360 : t
- }
- function Ct(t) {
- return t < 0 ? 0 : t > 1 ? 1 : t
- }
- function Lt(t) {
- return At(t.length && "%" === t.charAt(t.length - 1) ? parseFloat(t) / 100 * 255 : parseInt(t, 10))
- }
- function kt(t) {
- return Ct(t.length && "%" === t.charAt(t.length - 1) ? parseFloat(t) / 100 : parseFloat(t))
- }
- function Pt(t, e, i) {
- return i < 0 ? i += 1 : i > 1 && (i -= 1), 6 * i < 1 ? t + (e - t) * i * 6 : 2 * i < 1 ? e : 3 * i < 2 ? t + (e - t) *
- (2 / 3 - i) * 6 : t
- }
- function Nt(t, e, i) {
- return t + (e - t) * i
- }
- function Ot(t, e, i, n, o) {
- return t[0] = e, t[1] = i, t[2] = n, t[3] = o, t
- }
- function Et(t, e) {
- return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t
- }
- function Rt(t, e) {
- Cw && Et(Cw, e), Cw = Dw.put(t, Cw || e.slice())
- }
- function zt(t, e) {
- if (t) {
- e = e || [];
- var i = Dw.get(t);
- if (i) return Et(e, i);
- var n = (t += "").replace(/ /g, "").toLowerCase();
- if (n in Aw) return Et(e, Aw[n]), Rt(t, e), e;
- if ("#" !== n.charAt(0)) {
- var o = n.indexOf("("),
- a = n.indexOf(")");
- if (-1 !== o && a + 1 === n.length) {
- var r = n.substr(0, o),
- s = n.substr(o + 1, a - (o + 1)).split(","),
- l = 1;
- switch (r) {
- case "rgba":
- if (4 !== s.length) return void Ot(e, 0, 0, 0, 1);
- l = kt(s.pop());
- case "rgb":
- return 3 !== s.length ? void Ot(e, 0, 0, 0, 1) : (Ot(e, Lt(s[0]), Lt(s[1]), Lt(s[2]), l), Rt(t, e), e);
- case "hsla":
- return 4 !== s.length ? void Ot(e, 0, 0, 0, 1) : (s[3] = kt(s[3]), Bt(s, e), Rt(t, e), e);
- case "hsl":
- return 3 !== s.length ? void Ot(e, 0, 0, 0, 1) : (Bt(s, e), Rt(t, e), e);
- default:
- return
- }
- }
- Ot(e, 0, 0, 0, 1)
- } else {
- if (4 === n.length) return (u = parseInt(n.substr(1), 16)) >= 0 && u <= 4095 ? (Ot(e, (3840 & u) >> 4 | (3840 & u) >>
- 8, 240 & u | (240 & u) >> 4, 15 & u | (15 & u) << 4, 1), Rt(t, e), e) : void Ot(e, 0, 0, 0, 1);
- if (7 === n.length) {
- var u = parseInt(n.substr(1), 16);
- return u >= 0 && u <= 16777215 ? (Ot(e, (16711680 & u) >> 16, (65280 & u) >> 8, 255 & u, 1), Rt(t, e), e) : void Ot(
- e, 0, 0, 0, 1)
- }
- }
- }
- }
- function Bt(t, e) {
- var i = (parseFloat(t[0]) % 360 + 360) % 360 / 360,
- n = kt(t[1]),
- o = kt(t[2]),
- a = o <= .5 ? o * (n + 1) : o + n - o * n,
- r = 2 * o - a;
- return e = e || [], Ot(e, At(255 * Pt(r, a, i + 1 / 3)), At(255 * Pt(r, a, i)), At(255 * Pt(r, a, i - 1 / 3)), 1), 4 ===
- t.length && (e[3] = t[3]), e
- }
- function Vt(t) {
- if (t) {
- var e, i, n = t[0] / 255,
- o = t[1] / 255,
- a = t[2] / 255,
- r = Math.min(n, o, a),
- s = Math.max(n, o, a),
- l = s - r,
- u = (s + r) / 2;
- if (0 === l) e = 0, i = 0;
- else {
- i = u < .5 ? l / (s + r) : l / (2 - s - r);
- var h = ((s - n) / 6 + l / 2) / l,
- c = ((s - o) / 6 + l / 2) / l,
- d = ((s - a) / 6 + l / 2) / l;
- n === s ? e = d - c : o === s ? e = 1 / 3 + h - d : a === s && (e = 2 / 3 + c - h), e < 0 && (e += 1), e > 1 && (e -=
- 1)
- }
- var f = [360 * e, i, u];
- return null != t[3] && f.push(t[3]), f
- }
- }
- function Gt(t, e) {
- var i = zt(t);
- if (i) {
- for (var n = 0; n < 3; n++) i[n] = e < 0 ? i[n] * (1 - e) | 0 : (255 - i[n]) * e + i[n] | 0, i[n] > 255 ? i[n] =
- 255 : t[n] < 0 && (i[n] = 0);
- return Xt(i, 4 === i.length ? "rgba" : "rgb")
- }
- }
- function Ft(t) {
- var e = zt(t);
- if (e) return ((1 << 24) + (e[0] << 16) + (e[1] << 8) + +e[2]).toString(16).slice(1)
- }
- function Wt(t, e, i) {
- if (e && e.length && t >= 0 && t <= 1) {
- i = i || [];
- var n = t * (e.length - 1),
- o = Math.floor(n),
- a = Math.ceil(n),
- r = e[o],
- s = e[a],
- l = n - o;
- return i[0] = At(Nt(r[0], s[0], l)), i[1] = At(Nt(r[1], s[1], l)), i[2] = At(Nt(r[2], s[2], l)), i[3] = Ct(Nt(r[3],
- s[3], l)), i
- }
- }
- function Ht(t, e, i) {
- if (e && e.length && t >= 0 && t <= 1) {
- var n = t * (e.length - 1),
- o = Math.floor(n),
- a = Math.ceil(n),
- r = zt(e[o]),
- s = zt(e[a]),
- l = n - o,
- u = Xt([At(Nt(r[0], s[0], l)), At(Nt(r[1], s[1], l)), At(Nt(r[2], s[2], l)), Ct(Nt(r[3], s[3], l))], "rgba");
- return i ? {
- color: u,
- leftIndex: o,
- rightIndex: a,
- value: n
- } : u
- }
- }
- function Zt(t, e, i, n) {
- if (t = zt(t)) return t = Vt(t), null != e && (t[0] = Dt(e)), null != i && (t[1] = kt(i)), null != n && (t[2] = kt(n)),
- Xt(Bt(t), "rgba")
- }
- function Ut(t, e) {
- if ((t = zt(t)) && null != e) return t[3] = Ct(e), Xt(t, "rgba")
- }
- function Xt(t, e) {
- if (t && t.length) {
- var i = t[0] + "," + t[1] + "," + t[2];
- return "rgba" !== e && "hsva" !== e && "hsla" !== e || (i += "," + t[3]), e + "(" + i + ")"
- }
- }
- function jt(t, e) {
- return t[e]
- }
- function Yt(t, e, i) {
- t[e] = i
- }
- function qt(t, e, i) {
- return (e - t) * i + t
- }
- function Kt(t, e, i) {
- return i > .5 ? e : t
- }
- function $t(t, e, i, n, o) {
- var a = t.length;
- if (1 == o)
- for (s = 0; s < a; s++) n[s] = qt(t[s], e[s], i);
- else
- for (var r = a && t[0].length, s = 0; s < a; s++)
- for (var l = 0; l < r; l++) n[s][l] = qt(t[s][l], e[s][l], i)
- }
- function Jt(t, e, i) {
- var n = t.length,
- o = e.length;
- if (n !== o)
- if (n > o) t.length = o;
- else
- for (r = n; r < o; r++) t.push(1 === i ? e[r] : Nw.call(e[r]));
- for (var a = t[0] && t[0].length, r = 0; r < t.length; r++)
- if (1 === i) isNaN(t[r]) && (t[r] = e[r]);
- else
- for (var s = 0; s < a; s++) isNaN(t[r][s]) && (t[r][s] = e[r][s])
- }
- function Qt(t, e, i) {
- if (t === e) return !0;
- var n = t.length;
- if (n !== e.length) return !1;
- if (1 === i) {
- for (a = 0; a < n; a++)
- if (t[a] !== e[a]) return !1
- } else
- for (var o = t[0].length, a = 0; a < n; a++)
- for (var r = 0; r < o; r++)
- if (t[a][r] !== e[a][r]) return !1;
- return !0
- }
- function te(t, e, i, n, o, a, r, s, l) {
- var u = t.length;
- if (1 == l)
- for (c = 0; c < u; c++) s[c] = ee(t[c], e[c], i[c], n[c], o, a, r);
- else
- for (var h = t[0].length, c = 0; c < u; c++)
- for (var d = 0; d < h; d++) s[c][d] = ee(t[c][d], e[c][d], i[c][d], n[c][d], o, a, r)
- }
- function ee(t, e, i, n, o, a, r) {
- var s = .5 * (i - t),
- l = .5 * (n - e);
- return (2 * (e - i) + s + l) * r + (-3 * (e - i) - 2 * s - l) * a + s * o + e
- }
- function ie(t) {
- if (c(t)) {
- var e = t.length;
- if (c(t[0])) {
- for (var i = [], n = 0; n < e; n++) i.push(Nw.call(t[n]));
- return i
- }
- return Nw.call(t)
- }
- return t
- }
- function ne(t) {
- return t[0] = Math.floor(t[0]), t[1] = Math.floor(t[1]), t[2] = Math.floor(t[2]), "rgba(" + t.join(",") + ")"
- }
- function oe(t) {
- var e = t[t.length - 1].value;
- return c(e && e[0]) ? 2 : 1
- }
- function ae(t, e, i, n, o, a) {
- var r = t._getter,
- s = t._setter,
- l = "spline" === e,
- u = n.length;
- if (u) {
- var h, d = c(n[0].value),
- f = !1,
- p = !1,
- g = d ? oe(n) : 0;
- n.sort(function(t, e) {
- return t.time - e.time
- }), h = n[u - 1].time;
- for (var m = [], v = [], y = n[0].value, x = !0, _ = 0; _ < u; _++) {
- m.push(n[_].time / h);
- var w = n[_].value;
- if (d && Qt(w, y, g) || !d && w === y || (x = !1), y = w, "string" == typeof w) {
- var b = zt(w);
- b ? (w = b, f = !0) : p = !0
- }
- v.push(w)
- }
- if (a || !x) {
- for (var S = v[u - 1], _ = 0; _ < u - 1; _++) d ? Jt(v[_], S, g) : !isNaN(v[_]) || isNaN(S) || p || f || (v[_] = S);
- d && Jt(r(t._target, o), S, g);
- var M, I, T, A, D, C, L = 0,
- k = 0;
- if (f) var P = [0, 0, 0, 0];
- var N = new Tt({
- target: t._target,
- life: h,
- loop: t._loop,
- delay: t._delay,
- onframe: function(t, e) {
- var i;
- if (e < 0) i = 0;
- else if (e < k) {
- for (i = M = Math.min(L + 1, u - 1); i >= 0 && !(m[i] <= e); i--);
- i = Math.min(i, u - 2)
- } else {
- for (i = L; i < u && !(m[i] > e); i++);
- i = Math.min(i - 1, u - 2)
- }
- L = i, k = e;
- var n = m[i + 1] - m[i];
- if (0 !== n)
- if (I = (e - m[i]) / n, l)
- if (A = v[i], T = v[0 === i ? i : i - 1], D = v[i > u - 2 ? u - 1 : i + 1], C = v[i > u - 3 ? u - 1 : i + 2],
- d) te(T, A, D, C, I, I * I, I * I * I, r(t, o), g);
- else {
- if (f) a = te(T, A, D, C, I, I * I, I * I * I, P, 1), a = ne(P);
- else {
- if (p) return Kt(A, D, I);
- a = ee(T, A, D, C, I, I * I, I * I * I)
- }
- s(t, o, a)
- }
- else if (d) $t(v[i], v[i + 1], I, r(t, o), g);
- else {
- var a;
- if (f) $t(v[i], v[i + 1], I, P, 1), a = ne(P);
- else {
- if (p) return Kt(v[i], v[i + 1], I);
- a = qt(v[i], v[i + 1], I)
- }
- s(t, o, a)
- }
- },
- ondestroy: i
- });
- return e && "spline" !== e && (N.easing = e), N
- }
- }
- }
- function re(t, e, i, n, o, a, r, s) {
- _(n) ? (a = o, o = n, n = 0) : x(o) ? (a = o, o = "linear", n = 0) : x(n) ? (a = n, n = 0) : x(i) ? (a = i, i = 500) :
- i || (i = 500), t.stopAnimation(), se(t, "", t, e, i, n, s);
- var l = t.animators.slice(),
- u = l.length;
- u || a && a();
- for (var h = 0; h < l.length; h++) l[h].done(function() {
- --u || a && a()
- }).start(o, r)
- }
- function se(t, e, i, n, o, a, r) {
- var s = {},
- l = 0;
- for (var u in n) n.hasOwnProperty(u) && (null != i[u] ? w(n[u]) && !c(n[u]) ? se(t, e ? e + "." + u : u, i[u], n[u],
- o, a, r) : (r ? (s[u] = i[u], le(t, e, u, n[u])) : s[u] = n[u], l++) : null == n[u] || r || le(t, e, u, n[u]));
- l > 0 && t.animate(e, !1).when(null == o ? 500 : o, s).delay(a || 0)
- }
- function le(t, e, i, n) {
- if (e) {
- var o = {};
- o[e] = {}, o[e][i] = n, t.attr(o)
- } else t.attr(i, n)
- }
- function ue(t, e, i, n) {
- i < 0 && (t += i, i = -i), n < 0 && (e += n, n = -n), this.x = t, this.y = e, this.width = i, this.height = n
- }
- function he(t) {
- for (var e = 0; t >= Uw;) e |= 1 & t, t >>= 1;
- return t + e
- }
- function ce(t, e, i, n) {
- var o = e + 1;
- if (o === i) return 1;
- if (n(t[o++], t[e]) < 0) {
- for (; o < i && n(t[o], t[o - 1]) < 0;) o++;
- de(t, e, o)
- } else
- for (; o < i && n(t[o], t[o - 1]) >= 0;) o++;
- return o - e
- }
- function de(t, e, i) {
- for (i--; e < i;) {
- var n = t[e];
- t[e++] = t[i], t[i--] = n
- }
- }
- function fe(t, e, i, n, o) {
- for (n === e && n++; n < i; n++) {
- for (var a, r = t[n], s = e, l = n; s < l;) o(r, t[a = s + l >>> 1]) < 0 ? l = a : s = a + 1;
- var u = n - s;
- switch (u) {
- case 3:
- t[s + 3] = t[s + 2];
- case 2:
- t[s + 2] = t[s + 1];
- case 1:
- t[s + 1] = t[s];
- break;
- default:
- for (; u > 0;) t[s + u] = t[s + u - 1], u--
- }
- t[s] = r
- }
- }
- function pe(t, e, i, n, o, a) {
- var r = 0,
- s = 0,
- l = 1;
- if (a(t, e[i + o]) > 0) {
- for (s = n - o; l < s && a(t, e[i + o + l]) > 0;) r = l, (l = 1 + (l << 1)) <= 0 && (l = s);
- l > s && (l = s), r += o, l += o
- } else {
- for (s = o + 1; l < s && a(t, e[i + o - l]) <= 0;) r = l, (l = 1 + (l << 1)) <= 0 && (l = s);
- l > s && (l = s);
- var u = r;
- r = o - l, l = o - u
- }
- for (r++; r < l;) {
- var h = r + (l - r >>> 1);
- a(t, e[i + h]) > 0 ? r = h + 1 : l = h
- }
- return l
- }
- function ge(t, e, i, n, o, a) {
- var r = 0,
- s = 0,
- l = 1;
- if (a(t, e[i + o]) < 0) {
- for (s = o + 1; l < s && a(t, e[i + o - l]) < 0;) r = l, (l = 1 + (l << 1)) <= 0 && (l = s);
- l > s && (l = s);
- var u = r;
- r = o - l, l = o - u
- } else {
- for (s = n - o; l < s && a(t, e[i + o + l]) >= 0;) r = l, (l = 1 + (l << 1)) <= 0 && (l = s);
- l > s && (l = s), r += o, l += o
- }
- for (r++; r < l;) {
- var h = r + (l - r >>> 1);
- a(t, e[i + h]) < 0 ? l = h : r = h + 1
- }
- return l
- }
- function me(t, e) {
- function i(i) {
- var s = a[i],
- u = r[i],
- h = a[i + 1],
- c = r[i + 1];
- r[i] = u + c, i === l - 3 && (a[i + 1] = a[i + 2], r[i + 1] = r[i + 2]), l--;
- var d = ge(t[h], t, s, u, 0, e);
- s += d, 0 !== (u -= d) && 0 !== (c = pe(t[s + u - 1], t, h, c, c - 1, e)) && (u <= c ? n(s, u, h, c) : o(s, u, h, c))
- }
- function n(i, n, o, a) {
- var r = 0;
- for (r = 0; r < n; r++) u[r] = t[i + r];
- var l = 0,
- h = o,
- c = i;
- if (t[c++] = t[h++], 0 != --a)
- if (1 !== n) {
- for (var d, f, p, g = s;;) {
- d = 0, f = 0, p = !1;
- do {
- if (e(t[h], u[l]) < 0) {
- if (t[c++] = t[h++], f++, d = 0, 0 == --a) {
- p = !0;
- break
- }
- } else if (t[c++] = u[l++], d++, f = 0, 1 == --n) {
- p = !0;
- break
- }
- } while ((d | f) < g);
- if (p) break;
- do {
- if (0 !== (d = ge(t[h], u, l, n, 0, e))) {
- for (r = 0; r < d; r++) t[c + r] = u[l + r];
- if (c += d, l += d, (n -= d) <= 1) {
- p = !0;
- break
- }
- }
- if (t[c++] = t[h++], 0 == --a) {
- p = !0;
- break
- }
- if (0 !== (f = pe(u[l], t, h, a, 0, e))) {
- for (r = 0; r < f; r++) t[c + r] = t[h + r];
- if (c += f, h += f, 0 === (a -= f)) {
- p = !0;
- break
- }
- }
- if (t[c++] = u[l++], 1 == --n) {
- p = !0;
- break
- }
- g--
- } while (d >= Xw || f >= Xw);
- if (p) break;
- g < 0 && (g = 0), g += 2
- }
- if ((s = g) < 1 && (s = 1), 1 === n) {
- for (r = 0; r < a; r++) t[c + r] = t[h + r];
- t[c + a] = u[l]
- } else {
- if (0 === n) throw new Error;
- for (r = 0; r < n; r++) t[c + r] = u[l + r]
- }
- } else {
- for (r = 0; r < a; r++) t[c + r] = t[h + r];
- t[c + a] = u[l]
- }
- else
- for (r = 0; r < n; r++) t[c + r] = u[l + r]
- }
- function o(i, n, o, a) {
- var r = 0;
- for (r = 0; r < a; r++) u[r] = t[o + r];
- var l = i + n - 1,
- h = a - 1,
- c = o + a - 1,
- d = 0,
- f = 0;
- if (t[c--] = t[l--], 0 != --n)
- if (1 !== a) {
- for (var p = s;;) {
- var g = 0,
- m = 0,
- v = !1;
- do {
- if (e(u[h], t[l]) < 0) {
- if (t[c--] = t[l--], g++, m = 0, 0 == --n) {
- v = !0;
- break
- }
- } else if (t[c--] = u[h--], m++, g = 0, 1 == --a) {
- v = !0;
- break
- }
- } while ((g | m) < p);
- if (v) break;
- do {
- if (0 != (g = n - ge(u[h], t, i, n, n - 1, e))) {
- for (n -= g, f = (c -= g) + 1, d = (l -= g) + 1, r = g - 1; r >= 0; r--) t[f + r] = t[d + r];
- if (0 === n) {
- v = !0;
- break
- }
- }
- if (t[c--] = u[h--], 1 == --a) {
- v = !0;
- break
- }
- if (0 != (m = a - pe(t[l], u, 0, a, a - 1, e))) {
- for (a -= m, f = (c -= m) + 1, d = (h -= m) + 1, r = 0; r < m; r++) t[f + r] = u[d + r];
- if (a <= 1) {
- v = !0;
- break
- }
- }
- if (t[c--] = t[l--], 0 == --n) {
- v = !0;
- break
- }
- p--
- } while (g >= Xw || m >= Xw);
- if (v) break;
- p < 0 && (p = 0), p += 2
- }
- if ((s = p) < 1 && (s = 1), 1 === a) {
- for (f = (c -= n) + 1, d = (l -= n) + 1, r = n - 1; r >= 0; r--) t[f + r] = t[d + r];
- t[c] = u[h]
- } else {
- if (0 === a) throw new Error;
- for (d = c - (a - 1), r = 0; r < a; r++) t[d + r] = u[r]
- }
- } else {
- for (f = (c -= n) + 1, d = (l -= n) + 1, r = n - 1; r >= 0; r--) t[f + r] = t[d + r];
- t[c] = u[h]
- }
- else
- for (d = c - (a - 1), r = 0; r < a; r++) t[d + r] = u[r]
- }
- var a, r, s = Xw,
- l = 0,
- u = [];
- a = [], r = [], this.mergeRuns = function() {
- for (; l > 1;) {
- var t = l - 2;
- if (t >= 1 && r[t - 1] <= r[t] + r[t + 1] || t >= 2 && r[t - 2] <= r[t] + r[t - 1]) r[t - 1] < r[t + 1] && t--;
- else if (r[t] > r[t + 1]) break;
- i(t)
- }
- }, this.forceMergeRuns = function() {
- for (; l > 1;) {
- var t = l - 2;
- t > 0 && r[t - 1] < r[t + 1] && t--, i(t)
- }
- }, this.pushRun = function(t, e) {
- a[l] = t, r[l] = e, l += 1
- }
- }
- function ve(t, e, i, n) {
- i || (i = 0), n || (n = t.length);
- var o = n - i;
- if (!(o < 2)) {
- var a = 0;
- if (o < Uw) return a = ce(t, i, n, e), void fe(t, i, n, i + a, e);
- var r = new me(t, e),
- s = he(o);
- do {
- if ((a = ce(t, i, n, e)) < s) {
- var l = o;
- l > s && (l = s), fe(t, i, i + l, i + a, e), a = l
- }
- r.pushRun(i, a), r.mergeRuns(), o -= a, i += a
- } while (0 !== o);
- r.forceMergeRuns()
- }
- }
- function ye(t, e) {
- return t.zlevel === e.zlevel ? t.z === e.z ? t.z2 - e.z2 : t.z - e.z : t.zlevel - e.zlevel
- }
- function xe(t, e, i) {
- var n = null == e.x ? 0 : e.x,
- o = null == e.x2 ? 1 : e.x2,
- a = null == e.y ? 0 : e.y,
- r = null == e.y2 ? 0 : e.y2;
- return e.global || (n = n * i.width + i.x, o = o * i.width + i.x, a = a * i.height + i.y, r = r * i.height + i.y), n =
- isNaN(n) ? 0 : n, o = isNaN(o) ? 1 : o, a = isNaN(a) ? 0 : a, r = isNaN(r) ? 0 : r, t.createLinearGradient(n, a, o,
- r)
- }
- function _e(t, e, i) {
- var n = i.width,
- o = i.height,
- a = Math.min(n, o),
- r = null == e.x ? .5 : e.x,
- s = null == e.y ? .5 : e.y,
- l = null == e.r ? .5 : e.r;
- return e.global || (r = r * n + i.x, s = s * o + i.y, l *= a), t.createRadialGradient(r, s, 0, r, s, l)
- }
- function we() {
- return !1
- }
- function be(t, e, i) {
- var n = Y_(),
- o = e.getWidth(),
- a = e.getHeight(),
- r = n.style;
- return r && (r.position = "absolute", r.left = 0, r.top = 0, r.width = o + "px", r.height = a + "px", n.setAttribute(
- "data-zr-dom-id", t)), n.width = o * i, n.height = a * i, n
- }
- function Se(t) {
- if ("string" == typeof t) {
- var e = ob.get(t);
- return e && e.image
- }
- return t
- }
- function Me(t, e, i, n, o) {
- if (t) {
- if ("string" == typeof t) {
- if (e && e.__zrImageSrc === t || !i) return e;
- var a = ob.get(t),
- r = {
- hostEl: i,
- cb: n,
- cbPayload: o
- };
- return a ? !Te(e = a.image) && a.pending.push(r) : (!e && (e = new Image), e.onload = e.onerror = Ie, ob.put(t, e.__cachedImgObj = {
- image: e,
- pending: [r]
- }), e.src = e.__zrImageSrc = t), e
- }
- return t
- }
- return e
- }
- function Ie() {
- var t = this.__cachedImgObj;
- this.onload = this.onerror = this.__cachedImgObj = null;
- for (var e = 0; e < t.pending.length; e++) {
- var i = t.pending[e],
- n = i.cb;
- n && n(this, i.cbPayload), i.hostEl.dirty()
- }
- t.pending.length = 0
- }
- function Te(t) {
- return t && t.width && t.height
- }
- function Ae(t, e) {
- var i = t + ":" + (e = e || ub);
- if (ab[i]) return ab[i];
- for (var n = (t + "").split("\n"), o = 0, a = 0, r = n.length; a < r; a++) o = Math.max(Ve(n[a], e).width, o);
- return rb > sb && (rb = 0, ab = {}), rb++, ab[i] = o, o
- }
- function De(t, e, i, n, o, a, r) {
- return a ? Le(t, e, i, n, o, a, r) : Ce(t, e, i, n, o, r)
- }
- function Ce(t, e, i, n, o, a) {
- var r = Ge(t, e, o, a),
- s = Ae(t, e);
- o && (s += o[1] + o[3]);
- var l = r.outerHeight,
- u = new ue(ke(0, s, i), Pe(0, l, n), s, l);
- return u.lineHeight = r.lineHeight, u
- }
- function Le(t, e, i, n, o, a, r) {
- var s = Fe(t, {
- rich: a,
- truncate: r,
- font: e,
- textAlign: i,
- textPadding: o
- }),
- l = s.outerWidth,
- u = s.outerHeight;
- return new ue(ke(0, l, i), Pe(0, u, n), l, u)
- }
- function ke(t, e, i) {
- return "right" === i ? t -= e : "center" === i && (t -= e / 2), t
- }
- function Pe(t, e, i) {
- return "middle" === i ? t -= e / 2 : "bottom" === i && (t -= e), t
- }
- function Ne(t, e, i) {
- var n = e.x,
- o = e.y,
- a = e.height,
- r = e.width,
- s = a / 2,
- l = "left",
- u = "top";
- switch (t) {
- case "left":
- n -= i, o += s, l = "right", u = "middle";
- break;
- case "right":
- n += i + r, o += s, u = "middle";
- break;
- case "top":
- n += r / 2, o -= i, l = "center", u = "bottom";
- break;
- case "bottom":
- n += r / 2, o += a + i, l = "center";
- break;
- case "inside":
- n += r / 2, o += s, l = "center", u = "middle";
- break;
- case "insideLeft":
- n += i, o += s, u = "middle";
- break;
- case "insideRight":
- n += r - i, o += s, l = "right", u = "middle";
- break;
- case "insideTop":
- n += r / 2, o += i, l = "center";
- break;
- case "insideBottom":
- n += r / 2, o += a - i, l = "center", u = "bottom";
- break;
- case "insideTopLeft":
- n += i, o += i;
- break;
- case "insideTopRight":
- n += r - i, o += i, l = "right";
- break;
- case "insideBottomLeft":
- n += i, o += a - i, u = "bottom";
- break;
- case "insideBottomRight":
- n += r - i, o += a - i, l = "right", u = "bottom"
- }
- return {
- x: n,
- y: o,
- textAlign: l,
- textVerticalAlign: u
- }
- }
- function Oe(t, e, i, n, o) {
- if (!e) return "";
- var a = (t + "").split("\n");
- o = Ee(e, i, n, o);
- for (var r = 0, s = a.length; r < s; r++) a[r] = Re(a[r], o);
- return a.join("\n")
- }
- function Ee(t, e, i, n) {
- (n = a({}, n)).font = e;
- var i = A(i, "...");
- n.maxIterations = A(n.maxIterations, 2);
- var o = n.minChar = A(n.minChar, 0);
- n.cnCharWidth = Ae("国", e);
- var r = n.ascCharWidth = Ae("a", e);
- n.placeholder = A(n.placeholder, "");
- for (var s = t = Math.max(0, t - 1), l = 0; l < o && s >= r; l++) s -= r;
- var u = Ae(i);
- return u > s && (i = "", u = 0), s = t - u, n.ellipsis = i, n.ellipsisWidth = u, n.contentWidth = s, n.containerWidth =
- t, n
- }
- function Re(t, e) {
- var i = e.containerWidth,
- n = e.font,
- o = e.contentWidth;
- if (!i) return "";
- var a = Ae(t, n);
- if (a <= i) return t;
- for (var r = 0;; r++) {
- if (a <= o || r >= e.maxIterations) {
- t += e.ellipsis;
- break
- }
- var s = 0 === r ? ze(t, o, e.ascCharWidth, e.cnCharWidth) : a > 0 ? Math.floor(t.length * o / a) : 0;
- a = Ae(t = t.substr(0, s), n)
- }
- return "" === t && (t = e.placeholder), t
- }
- function ze(t, e, i, n) {
- for (var o = 0, a = 0, r = t.length; a < r && o < e; a++) {
- var s = t.charCodeAt(a);
- o += 0 <= s && s <= 127 ? i : n
- }
- return a
- }
- function Be(t) {
- return Ae("国", t)
- }
- function Ve(t, e) {
- return hb.measureText(t, e)
- }
- function Ge(t, e, i, n) {
- null != t && (t += "");
- var o = Be(e),
- a = t ? t.split("\n") : [],
- r = a.length * o,
- s = r;
- if (i && (s += i[0] + i[2]), t && n) {
- var l = n.outerHeight,
- u = n.outerWidth;
- if (null != l && s > l) t = "", a = [];
- else if (null != u)
- for (var h = Ee(u - (i ? i[1] + i[3] : 0), e, n.ellipsis, {
- minChar: n.minChar,
- placeholder: n.placeholder
- }), c = 0, d = a.length; c < d; c++) a[c] = Re(a[c], h)
- }
- return {
- lines: a,
- height: r,
- outerHeight: s,
- lineHeight: o
- }
- }
- function Fe(t, e) {
- var i = {
- lines: [],
- width: 0,
- height: 0
- };
- if (null != t && (t += ""), !t) return i;
- for (var n, o = lb.lastIndex = 0; null != (n = lb.exec(t));) {
- var a = n.index;
- a > o && We(i, t.substring(o, a)), We(i, n[2], n[1]), o = lb.lastIndex
- }
- o < t.length && We(i, t.substring(o, t.length));
- var r = i.lines,
- s = 0,
- l = 0,
- u = [],
- h = e.textPadding,
- c = e.truncate,
- d = c && c.outerWidth,
- f = c && c.outerHeight;
- h && (null != d && (d -= h[1] + h[3]), null != f && (f -= h[0] + h[2]));
- for (L = 0; L < r.length; L++) {
- for (var p = r[L], g = 0, m = 0, v = 0; v < p.tokens.length; v++) {
- var y = (k = p.tokens[v]).styleName && e.rich[k.styleName] || {},
- x = k.textPadding = y.textPadding,
- _ = k.font = y.font || e.font,
- w = k.textHeight = A(y.textHeight, Be(_));
- if (x && (w += x[0] + x[2]), k.height = w, k.lineHeight = D(y.textLineHeight, e.textLineHeight, w), k.textAlign =
- y && y.textAlign || e.textAlign, k.textVerticalAlign = y && y.textVerticalAlign || "middle", null != f && s + k.lineHeight >
- f) return {
- lines: [],
- width: 0,
- height: 0
- };
- k.textWidth = Ae(k.text, _);
- var b = y.textWidth,
- S = null == b || "auto" === b;
- if ("string" == typeof b && "%" === b.charAt(b.length - 1)) k.percentWidth = b, u.push(k), b = 0;
- else {
- if (S) {
- b = k.textWidth;
- var M = y.textBackgroundColor,
- I = M && M.image;
- I && Te(I = Se(I)) && (b = Math.max(b, I.width * w / I.height))
- }
- var T = x ? x[1] + x[3] : 0;
- b += T;
- var C = null != d ? d - m : null;
- null != C && C < b && (!S || C < T ? (k.text = "", k.textWidth = b = 0) : (k.text = Oe(k.text, C - T, _, c.ellipsis, {
- minChar: c.minChar
- }), k.textWidth = Ae(k.text, _), b = k.textWidth + T))
- }
- m += k.width = b, y && (g = Math.max(g, k.lineHeight))
- }
- p.width = m, p.lineHeight = g, s += g, l = Math.max(l, m)
- }
- i.outerWidth = i.width = A(e.textWidth, l), i.outerHeight = i.height = A(e.textHeight, s), h && (i.outerWidth += h[1] +
- h[3], i.outerHeight += h[0] + h[2]);
- for (var L = 0; L < u.length; L++) {
- var k = u[L],
- P = k.percentWidth;
- k.width = parseInt(P, 10) / 100 * l
- }
- return i
- }
- function We(t, e, i) {
- for (var n = "" === e, o = e.split("\n"), a = t.lines, r = 0; r < o.length; r++) {
- var s = o[r],
- l = {
- styleName: i,
- text: s,
- isLineHolder: !s && !n
- };
- if (r) a.push({
- tokens: [l]
- });
- else {
- var u = (a[a.length - 1] || (a[0] = {
- tokens: []
- })).tokens,
- h = u.length;
- 1 === h && u[0].isLineHolder ? u[0] = l : (s || !h || n) && u.push(l)
- }
- }
- }
- function He(t) {
- var e = (t.fontSize || t.fontFamily) && [t.fontStyle, t.fontWeight, (t.fontSize || 12) + "px", t.fontFamily ||
- "sans-serif"
- ].join(" ");
- return e && P(e) || t.textFont || t.font
- }
- function Ze(t, e) {
- var i, n, o, a, r = e.x,
- s = e.y,
- l = e.width,
- u = e.height,
- h = e.r;
- l < 0 && (r += l, l = -l), u < 0 && (s += u, u = -u), "number" == typeof h ? i = n = o = a = h : h instanceof Array ?
- 1 === h.length ? i = n = o = a = h[0] : 2 === h.length ? (i = o = h[0], n = a = h[1]) : 3 === h.length ? (i = h[0],
- n = a = h[1], o = h[2]) : (i = h[0], n = h[1], o = h[2], a = h[3]) : i = n = o = a = 0;
- var c;
- i + n > l && (i *= l / (c = i + n), n *= l / c), o + a > l && (o *= l / (c = o + a), a *= l / c), n + o > u && (n *=
- u / (c = n + o), o *= u / c), i + a > u && (i *= u / (c = i + a), a *= u / c), t.moveTo(r + i, s), t.lineTo(r + l -
- n, s), 0 !== n && t.arc(r + l - n, s + n, n, -Math.PI / 2, 0), t.lineTo(r + l, s + u - o), 0 !== o && t.arc(r + l -
- o, s + u - o, o, 0, Math.PI / 2), t.lineTo(r + a, s + u), 0 !== a && t.arc(r + a, s + u - a, a, Math.PI / 2, Math.PI),
- t.lineTo(r, s + i), 0 !== i && t.arc(r + i, s + i, i, Math.PI, 1.5 * Math.PI)
- }
- function Ue(t) {
- return Xe(t), d(t.rich, Xe), t
- }
- function Xe(t) {
- if (t) {
- t.font = He(t);
- var e = t.textAlign;
- "middle" === e && (e = "center"), t.textAlign = null == e || cb[e] ? e : "left";
- var i = t.textVerticalAlign || t.textBaseline;
- "center" === i && (i = "middle"), t.textVerticalAlign = null == i || db[i] ? i : "top", t.textPadding && (t.textPadding =
- L(t.textPadding))
- }
- }
- function je(t, e, i, n, o, a) {
- n.rich ? qe(t, e, i, n, o) : Ye(t, e, i, n, o, a)
- }
- function Ye(t, e, i, n, o, a) {
- var r = a && a.style,
- s = r && "text" === a.type,
- l = n.font || ub;
- s && l === (r.font || ub) || (e.font = l);
- var u = t.__computedFont;
- t.__styleFont !== l && (t.__styleFont = l, u = t.__computedFont = e.font);
- var h = n.textPadding,
- c = t.__textCotentBlock;
- c && !t.__dirtyText || (c = t.__textCotentBlock = Ge(i, u, h, n.truncate));
- var d = c.outerHeight,
- f = c.lines,
- p = c.lineHeight,
- g = ii(d, n, o),
- m = g.baseX,
- v = g.baseY,
- y = g.textAlign || "left",
- x = g.textVerticalAlign;
- $e(e, n, o, m, v);
- var _ = Pe(v, d, x),
- w = m,
- b = _,
- S = Qe(n);
- if (S || h) {
- var M = Ae(i, u);
- h && (M += h[1] + h[3]);
- var I = ke(m, M, y);
- S && ti(t, e, n, I, _, M, d), h && (w = si(m, y, h), b += h[0])
- }
- e.textAlign = y, e.textBaseline = "middle";
- for (R = 0; R < fb.length; R++) {
- var T = fb[R],
- A = T[0],
- D = T[1],
- C = n[A];
- s && C === r[A] || (e[D] = qw(e, D, C || T[2]))
- }
- b += p / 2;
- var L = n.textStrokeWidth,
- k = s ? r.textStrokeWidth : null,
- P = !s || L !== k,
- N = !s || P || n.textStroke !== r.textStroke,
- O = oi(n.textStroke, L),
- E = ai(n.textFill);
- if (O && (P && (e.lineWidth = L), N && (e.strokeStyle = O)), E && (s && n.textFill === r.textFill && !r.textBackgroundColor ||
- (e.fillStyle = E)), 1 === f.length) O && e.strokeText(f[0], w, b), E && e.fillText(f[0], w, b);
- else
- for (var R = 0; R < f.length; R++) O && e.strokeText(f[R], w, b), E && e.fillText(f[R], w, b), b += p
- }
- function qe(t, e, i, n, o) {
- var a = t.__textCotentBlock;
- a && !t.__dirtyText || (a = t.__textCotentBlock = Fe(i, n)), Ke(t, e, a, n, o)
- }
- function Ke(t, e, i, n, o) {
- var a = i.width,
- r = i.outerWidth,
- s = i.outerHeight,
- l = n.textPadding,
- u = ii(s, n, o),
- h = u.baseX,
- c = u.baseY,
- d = u.textAlign,
- f = u.textVerticalAlign;
- $e(e, n, o, h, c);
- var p = ke(h, r, d),
- g = Pe(c, s, f),
- m = p,
- v = g;
- l && (m += l[3], v += l[0]);
- var y = m + a;
- Qe(n) && ti(t, e, n, p, g, r, s);
- for (var x = 0; x < i.lines.length; x++) {
- for (var _, w = i.lines[x], b = w.tokens, S = b.length, M = w.lineHeight, I = w.width, T = 0, A = m, D = y, C = S -
- 1; T < S && (!(_ = b[T]).textAlign || "left" === _.textAlign);) Je(t, e, _, n, M, v, A, "left"), I -= _.width, A +=
- _.width, T++;
- for (; C >= 0 && "right" === (_ = b[C]).textAlign;) Je(t, e, _, n, M, v, D, "right"), I -= _.width, D -= _.width, C--;
- for (A += (a - (A - m) - (y - D) - I) / 2; T <= C;) Je(t, e, _ = b[T], n, M, v, A + _.width / 2, "center"), A += _.width,
- T++;
- v += M
- }
- }
- function $e(t, e, i, n, o) {
- if (i && e.textRotation) {
- var a = e.textOrigin;
- "center" === a ? (n = i.width / 2 + i.x, o = i.height / 2 + i.y) : a && (n = a[0] + i.x, o = a[1] + i.y), t.translate(
- n, o), t.rotate(-e.textRotation), t.translate(-n, -o)
- }
- }
- function Je(t, e, i, n, o, a, r, s) {
- var l = n.rich[i.styleName] || {};
- l.text = i.text;
- var u = i.textVerticalAlign,
- h = a + o / 2;
- "top" === u ? h = a + i.height / 2 : "bottom" === u && (h = a + o - i.height / 2), !i.isLineHolder && Qe(l) && ti(t,
- e, l, "right" === s ? r - i.width : "center" === s ? r - i.width / 2 : r, h - i.height / 2, i.width, i.height);
- var c = i.textPadding;
- c && (r = si(r, s, c), h -= i.height / 2 - c[2] - i.textHeight / 2), ni(e, "shadowBlur", D(l.textShadowBlur, n.textShadowBlur,
- 0)), ni(e, "shadowColor", l.textShadowColor || n.textShadowColor || "transparent"), ni(e, "shadowOffsetX", D(l.textShadowOffsetX,
- n.textShadowOffsetX, 0)), ni(e, "shadowOffsetY", D(l.textShadowOffsetY, n.textShadowOffsetY, 0)), ni(e,
- "textAlign", s), ni(e, "textBaseline", "middle"), ni(e, "font", i.font || ub);
- var d = oi(l.textStroke || n.textStroke, p),
- f = ai(l.textFill || n.textFill),
- p = A(l.textStrokeWidth, n.textStrokeWidth);
- d && (ni(e, "lineWidth", p), ni(e, "strokeStyle", d), e.strokeText(i.text, r, h)), f && (ni(e, "fillStyle", f), e.fillText(
- i.text, r, h))
- }
- function Qe(t) {
- return t.textBackgroundColor || t.textBorderWidth && t.textBorderColor
- }
- function ti(t, e, i, n, o, a, r) {
- var s = i.textBackgroundColor,
- l = i.textBorderWidth,
- u = i.textBorderColor,
- h = _(s);
- if (ni(e, "shadowBlur", i.textBoxShadowBlur || 0), ni(e, "shadowColor", i.textBoxShadowColor || "transparent"), ni(e,
- "shadowOffsetX", i.textBoxShadowOffsetX || 0), ni(e, "shadowOffsetY", i.textBoxShadowOffsetY || 0), h || l && u) {
- e.beginPath();
- var c = i.textBorderRadius;
- c ? Ze(e, {
- x: n,
- y: o,
- width: a,
- height: r,
- r: c
- }) : e.rect(n, o, a, r), e.closePath()
- }
- if (h)
- if (ni(e, "fillStyle", s), null != i.fillOpacity) {
- f = e.globalAlpha;
- e.globalAlpha = i.fillOpacity * i.opacity, e.fill(), e.globalAlpha = f
- } else e.fill();
- else if (x(s)) ni(e, "fillStyle", s(i)), e.fill();
- else if (w(s)) {
- var d = s.image;
- (d = Me(d, null, t, ei, s)) && Te(d) && e.drawImage(d, n, o, a, r)
- }
- if (l && u)
- if (ni(e, "lineWidth", l), ni(e, "strokeStyle", u), null != i.strokeOpacity) {
- var f = e.globalAlpha;
- e.globalAlpha = i.strokeOpacity * i.opacity, e.stroke(), e.globalAlpha = f
- } else e.stroke()
- }
- function ei(t, e) {
- e.image = t
- }
- function ii(t, e, i) {
- var n = e.x || 0,
- o = e.y || 0,
- a = e.textAlign,
- r = e.textVerticalAlign;
- if (i) {
- var s = e.textPosition;
- if (s instanceof Array) n = i.x + ri(s[0], i.width), o = i.y + ri(s[1], i.height);
- else {
- var l = Ne(s, i, e.textDistance);
- n = l.x, o = l.y, a = a || l.textAlign, r = r || l.textVerticalAlign
- }
- var u = e.textOffset;
- u && (n += u[0], o += u[1])
- }
- return {
- baseX: n,
- baseY: o,
- textAlign: a,
- textVerticalAlign: r
- }
- }
- function ni(t, e, i) {
- return t[e] = qw(t, e, i), t[e]
- }
- function oi(t, e) {
- return null == t || e <= 0 || "transparent" === t || "none" === t ? null : t.image || t.colorStops ? "#000" : t
- }
- function ai(t) {
- return null == t || "none" === t ? null : t.image || t.colorStops ? "#000" : t
- }
- function ri(t, e) {
- return "string" == typeof t ? t.lastIndexOf("%") >= 0 ? parseFloat(t) / 100 * e : parseFloat(t) : t
- }
- function si(t, e, i) {
- return "right" === e ? t - i[1] : "center" === e ? t + i[3] / 2 - i[1] / 2 : t + i[3]
- }
- function li(t, e) {
- return null != t && (t || e.textBackgroundColor || e.textBorderWidth && e.textBorderColor || e.textPadding)
- }
- function ui(t) {
- t = t || {}, Gw.call(this, t);
- for (var e in t) t.hasOwnProperty(e) && "style" !== e && (this[e] = t[e]);
- this.style = new $w(t.style, this), this._rect = null, this.__clipPaths = []
- }
- function hi(t) {
- ui.call(this, t)
- }
- function ci(t) {
- return parseInt(t, 10)
- }
- function di(t) {
- return !!t && (!!t.__builtin__ || "function" == typeof t.resize && "function" == typeof t.refresh)
- }
- function fi(t, e, i) {
- return mb.copy(t.getBoundingRect()), t.transform && mb.applyTransform(t.transform), vb.width = e, vb.height = i, !mb
- .intersect(vb)
- }
- function pi(t, e) {
- if (t == e) return !1;
- if (!t || !e || t.length !== e.length) return !0;
- for (var i = 0; i < t.length; i++)
- if (t[i] !== e[i]) return !0
- }
- function gi(t, e) {
- for (var i = 0; i < t.length; i++) {
- var n = t[i];
- n.setTransform(e), e.beginPath(), n.buildPath(e, n.shape), e.clip(), n.restoreTransform(e)
- }
- }
- function mi(t, e) {
- var i = document.createElement("div");
- return i.style.cssText = ["position:relative", "overflow:hidden", "width:" + t + "px", "height:" + e + "px",
- "padding:0", "margin:0", "border-width:0"
- ].join(";") + ";", i
- }
- function vi(t) {
- var e = t[1][0] - t[0][0],
- i = t[1][1] - t[0][1];
- return Math.sqrt(e * e + i * i)
- }
- function yi(t) {
- return [(t[0][0] + t[1][0]) / 2, (t[0][1] + t[1][1]) / 2]
- }
- function xi(t) {
- return "mousewheel" === t && z_.browser.firefox ? "DOMMouseScroll" : t
- }
- function _i(t, e, i) {
- var n = t._gestureMgr;
- "start" === i && n.clear();
- var o = n.recognize(e, t.handler.findHover(e.zrX, e.zrY, null).target, t.dom);
- if ("end" === i && n.clear(), o) {
- var a = o.type;
- e.gestureEvent = a, t.handler.dispatchToElement({
- target: o.target
- }, a, o.event)
- }
- }
- function wi(t) {
- t._touching = !0, clearTimeout(t._touchTimer), t._touchTimer = setTimeout(function() {
- t._touching = !1
- }, 700)
- }
- function bi(t) {
- var e = t.pointerType;
- return "pen" === e || "touch" === e
- }
- function Si(t) {
- function e(t, e) {
- return function() {
- if (!e._touching) return t.apply(e, arguments)
- }
- }
- d(Sb, function(e) {
- t._handlers[e] = m(Tb[e], t)
- }), d(Ib, function(e) {
- t._handlers[e] = m(Tb[e], t)
- }), d(bb, function(i) {
- t._handlers[i] = e(Tb[i], t)
- })
- }
- function Mi(t) {
- function e(e, i) {
- d(e, function(e) {
- ut(t, xi(e), i._handlers[e])
- }, i)
- }
- aw.call(this), this.dom = t, this._touching = !1, this._touchTimer, this._gestureMgr = new _b, this._handlers = {},
- Si(this), z_.pointerEventsSupported ? e(Ib, this) : (z_.touchEventsSupported && e(Sb, this), e(bb, this))
- }
- function Ii(t, e) {
- var i = new kb(E_(), t, e);
- return Lb[i.id] = i, i
- }
- function Ti(t, e) {
- Cb[t] = e
- }
- function Ai(t) {
- delete Lb[t]
- }
- function Di(t) {
- return t instanceof Array ? t : null == t ? [] : [t]
- }
- function Ci(t, e, i) {
- if (t) {
- t[e] = t[e] || {}, t.emphasis = t.emphasis || {}, t.emphasis[e] = t.emphasis[e] || {};
- for (var n = 0, o = i.length; n < o; n++) {
- var a = i[n];
- !t.emphasis[e].hasOwnProperty(a) && t[e].hasOwnProperty(a) && (t.emphasis[e][a] = t[e][a])
- }
- }
- }
- function Li(t) {
- return !Ob(t) || Eb(t) || t instanceof Date ? t : t.value
- }
- function ki(t) {
- return Ob(t) && !(t instanceof Array)
- }
- function Pi(t, e) {
- e = (e || []).slice();
- var i = f(t || [], function(t, e) {
- return {
- exist: t
- }
- });
- return Nb(e, function(t, n) {
- if (Ob(t)) {
- for (o = 0; o < i.length; o++)
- if (!i[o].option && null != t.id && i[o].exist.id === t.id + "") return i[o].option = t, void(e[n] = null);
- for (var o = 0; o < i.length; o++) {
- var a = i[o].exist;
- if (!(i[o].option || null != a.id && null != t.id || null == t.name || Ei(t) || Ei(a) || a.name !== t.name + ""))
- return i[o].option = t, void(e[n] = null)
- }
- }
- }), Nb(e, function(t, e) {
- if (Ob(t)) {
- for (var n = 0; n < i.length; n++) {
- var o = i[n].exist;
- if (!i[n].option && !Ei(o) && null == t.id) {
- i[n].option = t;
- break
- }
- }
- n >= i.length && i.push({
- option: t
- })
- }
- }), i
- }
- function Ni(t) {
- var e = R();
- Nb(t, function(t, i) {
- var n = t.exist;
- n && e.set(n.id, t)
- }), Nb(t, function(t, i) {
- var n = t.option;
- k(!n || null == n.id || !e.get(n.id) || e.get(n.id) === t, "id duplicates: " + (n && n.id)), n && null != n.id &&
- e.set(n.id, t), !t.keyInfo && (t.keyInfo = {})
- }), Nb(t, function(t, i) {
- var n = t.exist,
- o = t.option,
- a = t.keyInfo;
- if (Ob(o)) {
- if (a.name = null != o.name ? o.name + "" : n ? n.name : Rb + i, n) a.id = n.id;
- else if (null != o.id) a.id = o.id + "";
- else {
- var r = 0;
- do {
- a.id = "\0" + a.name + "\0" + r++
- } while (e.get(a.id))
- }
- e.set(a.id, t)
- }
- })
- }
- function Oi(t) {
- var e = t.name;
- return !(!e || !e.indexOf(Rb))
- }
- function Ei(t) {
- return Ob(t) && t.id && 0 === (t.id + "").indexOf("\0_ec_\0")
- }
- function Ri(t, e) {
- function i(t, e, i) {
- for (var n = 0, o = t.length; n < o; n++)
- for (var a = t[n].seriesId, r = Di(t[n].dataIndex), s = i && i[a], l = 0, u = r.length; l < u; l++) {
- var h = r[l];
- s && s[h] ? s[h] = null : (e[a] || (e[a] = {}))[h] = 1
- }
- }
- function n(t, e) {
- var i = [];
- for (var o in t)
- if (t.hasOwnProperty(o) && null != t[o])
- if (e) i.push(+o);
- else {
- var a = n(t[o], !0);
- a.length && i.push({
- seriesId: o,
- dataIndex: a
- })
- } return i
- }
- var o = {},
- a = {};
- return i(t || [], o), i(e || [], a, o), [n(o), n(a)]
- }
- function zi(t, e) {
- return null != e.dataIndexInside ? e.dataIndexInside : null != e.dataIndex ? y(e.dataIndex) ? f(e.dataIndex,
- function(e) {
- return t.indexOfRawIndex(e)
- }) : t.indexOfRawIndex(e.dataIndex) : null != e.name ? y(e.name) ? f(e.name, function(e) {
- return t.indexOfName(e)
- }) : t.indexOfName(e.name) : void 0
- }
- function Bi() {
- var t = "__\0ec_inner_" + Bb++ + "_" + Math.random().toFixed(5);
- return function(e) {
- return e[t] || (e[t] = {})
- }
- }
- function Vi(t, e, i) {
- if (_(e)) {
- var n = {};
- n[e + "Index"] = 0, e = n
- }
- var o = i && i.defaultMainType;
- !o || Gi(e, o + "Index") || Gi(e, o + "Id") || Gi(e, o + "Name") || (e[o + "Index"] = 0);
- var a = {};
- return Nb(e, function(n, o) {
- var n = e[o];
- if ("dataIndex" !== o && "dataIndexInside" !== o) {
- var r = o.match(/^(\w+)(Index|Id|Name)$/) || [],
- s = r[1],
- u = (r[2] || "").toLowerCase();
- if (!(!s || !u || null == n || "index" === u && "none" === n || i && i.includeMainTypes && l(i.includeMainTypes,
- s) < 0)) {
- var h = {
- mainType: s
- };
- "index" === u && "all" === n || (h[u] = n);
- var c = t.queryComponents(h);
- a[s + "Models"] = c, a[s + "Model"] = c[0]
- }
- } else a[o] = n
- }), a
- }
- function Gi(t, e) {
- return t && t.hasOwnProperty(e)
- }
- function Fi(t, e, i) {
- t.setAttribute ? t.setAttribute(e, i) : t[e] = i
- }
- function Wi(t, e) {
- return t.getAttribute ? t.getAttribute(e) : t[e]
- }
- function Hi(t) {
- return "auto" === t ? z_.domSupported ? "html" : "richText" : t || "html"
- }
- function Zi(t) {
- var e = {
- main: "",
- sub: ""
- };
- return t && (t = t.split(Vb), e.main = t[0] || "", e.sub = t[1] || ""), e
- }
- function Ui(t) {
- k(/^[a-zA-Z0-9_]+([.][a-zA-Z0-9_]+)?$/.test(t), 'componentType "' + t + '" illegal')
- }
- function Xi(t, e) {
- t.$constructor = t, t.extend = function(t) {
- var e = this,
- i = function() {
- t.$constructor ? t.$constructor.apply(this, arguments) : e.apply(this, arguments)
- };
- return a(i.prototype, t), i.extend = this.extend, i.superCall = Yi, i.superApply = qi, u(i, this), i.superClass =
- e, i
- }
- }
- function ji(t) {
- var e = ["__\0is_clz", Fb++, Math.random().toFixed(3)].join("_");
- t.prototype[e] = !0, t.isInstance = function(t) {
- return !(!t || !t[e])
- }
- }
- function Yi(t, e) {
- var i = C(arguments, 2);
- return this.superClass.prototype[e].apply(t, i)
- }
- function qi(t, e, i) {
- return this.superClass.prototype[e].apply(t, i)
- }
- function Ki(t, e) {
- function i(t) {
- var e = n[t.main];
- return e && e[Gb] || ((e = n[t.main] = {})[Gb] = !0), e
- }
- e = e || {};
- var n = {};
- if (t.registerClass = function(t, e) {
- return e && (Ui(e), (e = Zi(e)).sub ? e.sub !== Gb && (i(e)[e.sub] = t) : n[e.main] = t), t
- }, t.getClass = function(t, e, i) {
- var o = n[t];
- if (o && o[Gb] && (o = e ? o[e] : null), i && !o) throw new Error(e ? "Component " + t + "." + (e || "") +
- " not exists. Load it first." : t + ".type should be specified.");
- return o
- }, t.getClassesByMainType = function(t) {
- t = Zi(t);
- var e = [],
- i = n[t.main];
- return i && i[Gb] ? d(i, function(t, i) {
- i !== Gb && e.push(t)
- }) : e.push(i), e
- }, t.hasClass = function(t) {
- return t = Zi(t), !!n[t.main]
- }, t.getAllClassMainTypes = function() {
- var t = [];
- return d(n, function(e, i) {
- t.push(i)
- }), t
- }, t.hasSubTypes = function(t) {
- t = Zi(t);
- var e = n[t.main];
- return e && e[Gb]
- }, t.parseClassType = Zi, e.registerWhenExtend) {
- var o = t.extend;
- o && (t.extend = function(e) {
- var i = o.call(this, e);
- return t.registerClass(i, e.type)
- })
- }
- return t
- }
- function $i(t) {
- return t > -qb && t < qb
- }
- function Ji(t) {
- return t > qb || t < -qb
- }
- function Qi(t, e, i, n, o) {
- var a = 1 - o;
- return a * a * (a * t + 3 * o * e) + o * o * (o * n + 3 * a * i)
- }
- function tn(t, e, i, n, o) {
- var a = 1 - o;
- return 3 * (((e - t) * a + 2 * (i - e) * o) * a + (n - i) * o * o)
- }
- function en(t, e, i, n, o, a) {
- var r = n + 3 * (e - i) - t,
- s = 3 * (i - 2 * e + t),
- l = 3 * (e - t),
- u = t - o,
- h = s * s - 3 * r * l,
- c = s * l - 9 * r * u,
- d = l * l - 3 * s * u,
- f = 0;
- if ($i(h) && $i(c)) $i(s) ? a[0] = 0 : (M = -l / s) >= 0 && M <= 1 && (a[f++] = M);
- else {
- var p = c * c - 4 * h * d;
- if ($i(p)) {
- var g = c / h,
- m = -g / 2;
- (M = -s / r + g) >= 0 && M <= 1 && (a[f++] = M), m >= 0 && m <= 1 && (a[f++] = m)
- } else if (p > 0) {
- var v = Yb(p),
- y = h * s + 1.5 * r * (-c + v),
- x = h * s + 1.5 * r * (-c - v);
- (M = (-s - ((y = y < 0 ? -jb(-y, Jb) : jb(y, Jb)) + (x = x < 0 ? -jb(-x, Jb) : jb(x, Jb)))) / (3 * r)) >= 0 && M <=
- 1 && (a[f++] = M)
- } else {
- var _ = (2 * h * s - 3 * r * c) / (2 * Yb(h * h * h)),
- w = Math.acos(_) / 3,
- b = Yb(h),
- S = Math.cos(w),
- M = (-s - 2 * b * S) / (3 * r),
- m = (-s + b * (S + $b * Math.sin(w))) / (3 * r),
- I = (-s + b * (S - $b * Math.sin(w))) / (3 * r);
- M >= 0 && M <= 1 && (a[f++] = M), m >= 0 && m <= 1 && (a[f++] = m), I >= 0 && I <= 1 && (a[f++] = I)
- }
- }
- return f
- }
- function nn(t, e, i, n, o) {
- var a = 6 * i - 12 * e + 6 * t,
- r = 9 * e + 3 * n - 3 * t - 9 * i,
- s = 3 * e - 3 * t,
- l = 0;
- if ($i(r)) Ji(a) && (c = -s / a) >= 0 && c <= 1 && (o[l++] = c);
- else {
- var u = a * a - 4 * r * s;
- if ($i(u)) o[0] = -a / (2 * r);
- else if (u > 0) {
- var h = Yb(u),
- c = (-a + h) / (2 * r),
- d = (-a - h) / (2 * r);
- c >= 0 && c <= 1 && (o[l++] = c), d >= 0 && d <= 1 && (o[l++] = d)
- }
- }
- return l
- }
- function on(t, e, i, n, o, a) {
- var r = (e - t) * o + t,
- s = (i - e) * o + e,
- l = (n - i) * o + i,
- u = (s - r) * o + r,
- h = (l - s) * o + s,
- c = (h - u) * o + u;
- a[0] = t, a[1] = r, a[2] = u, a[3] = c, a[4] = c, a[5] = h, a[6] = l, a[7] = n
- }
- function an(t, e, i, n, o, a, r, s, l, u, h) {
- var c, d, f, p, g, m = .005,
- v = 1 / 0;
- Qb[0] = l, Qb[1] = u;
- for (var y = 0; y < 1; y += .05) tS[0] = Qi(t, i, o, r, y), tS[1] = Qi(e, n, a, s, y), (p = iw(Qb, tS)) < v && (c =
- y, v = p);
- v = 1 / 0;
- for (var x = 0; x < 32 && !(m < Kb); x++) d = c - m, f = c + m, tS[0] = Qi(t, i, o, r, d), tS[1] = Qi(e, n, a, s, d),
- p = iw(tS, Qb), d >= 0 && p < v ? (c = d, v = p) : (eS[0] = Qi(t, i, o, r, f), eS[1] = Qi(e, n, a, s, f), g = iw(eS,
- Qb), f <= 1 && g < v ? (c = f, v = g) : m *= .5);
- return h && (h[0] = Qi(t, i, o, r, c), h[1] = Qi(e, n, a, s, c)), Yb(v)
- }
- function rn(t, e, i, n) {
- var o = 1 - n;
- return o * (o * t + 2 * n * e) + n * n * i
- }
- function sn(t, e, i, n) {
- return 2 * ((1 - n) * (e - t) + n * (i - e))
- }
- function ln(t, e, i, n, o) {
- var a = t - 2 * e + i,
- r = 2 * (e - t),
- s = t - n,
- l = 0;
- if ($i(a)) Ji(r) && (c = -s / r) >= 0 && c <= 1 && (o[l++] = c);
- else {
- var u = r * r - 4 * a * s;
- if ($i(u))(c = -r / (2 * a)) >= 0 && c <= 1 && (o[l++] = c);
- else if (u > 0) {
- var h = Yb(u),
- c = (-r + h) / (2 * a),
- d = (-r - h) / (2 * a);
- c >= 0 && c <= 1 && (o[l++] = c), d >= 0 && d <= 1 && (o[l++] = d)
- }
- }
- return l
- }
- function un(t, e, i) {
- var n = t + i - 2 * e;
- return 0 === n ? .5 : (t - e) / n
- }
- function hn(t, e, i, n, o) {
- var a = (e - t) * n + t,
- r = (i - e) * n + e,
- s = (r - a) * n + a;
- o[0] = t, o[1] = a, o[2] = s, o[3] = s, o[4] = r, o[5] = i
- }
- function cn(t, e, i, n, o, a, r, s, l) {
- var u, h = .005,
- c = 1 / 0;
- Qb[0] = r, Qb[1] = s;
- for (var d = 0; d < 1; d += .05) tS[0] = rn(t, i, o, d), tS[1] = rn(e, n, a, d), (m = iw(Qb, tS)) < c && (u = d, c =
- m);
- c = 1 / 0;
- for (var f = 0; f < 32 && !(h < Kb); f++) {
- var p = u - h,
- g = u + h;
- tS[0] = rn(t, i, o, p), tS[1] = rn(e, n, a, p);
- var m = iw(tS, Qb);
- if (p >= 0 && m < c) u = p, c = m;
- else {
- eS[0] = rn(t, i, o, g), eS[1] = rn(e, n, a, g);
- var v = iw(eS, Qb);
- g <= 1 && v < c ? (u = g, c = v) : h *= .5
- }
- }
- return l && (l[0] = rn(t, i, o, u), l[1] = rn(e, n, a, u)), Yb(c)
- }
- function dn(t, e, i) {
- if (0 !== t.length) {
- var n, o = t[0],
- a = o[0],
- r = o[0],
- s = o[1],
- l = o[1];
- for (n = 1; n < t.length; n++) o = t[n], a = iS(a, o[0]), r = nS(r, o[0]), s = iS(s, o[1]), l = nS(l, o[1]);
- e[0] = a, e[1] = s, i[0] = r, i[1] = l
- }
- }
- function fn(t, e, i, n, o, a) {
- o[0] = iS(t, i), o[1] = iS(e, n), a[0] = nS(t, i), a[1] = nS(e, n)
- }
- function pn(t, e, i, n, o, a, r, s, l, u) {
- var h, c = nn,
- d = Qi,
- f = c(t, i, o, r, hS);
- for (l[0] = 1 / 0, l[1] = 1 / 0, u[0] = -1 / 0, u[1] = -1 / 0, h = 0; h < f; h++) {
- var p = d(t, i, o, r, hS[h]);
- l[0] = iS(p, l[0]), u[0] = nS(p, u[0])
- }
- for (f = c(e, n, a, s, cS), h = 0; h < f; h++) {
- var g = d(e, n, a, s, cS[h]);
- l[1] = iS(g, l[1]), u[1] = nS(g, u[1])
- }
- l[0] = iS(t, l[0]), u[0] = nS(t, u[0]), l[0] = iS(r, l[0]), u[0] = nS(r, u[0]), l[1] = iS(e, l[1]), u[1] = nS(e, u[1]),
- l[1] = iS(s, l[1]), u[1] = nS(s, u[1])
- }
- function gn(t, e, i, n, o, a, r, s) {
- var l = un,
- u = rn,
- h = nS(iS(l(t, i, o), 1), 0),
- c = nS(iS(l(e, n, a), 1), 0),
- d = u(t, i, o, h),
- f = u(e, n, a, c);
- r[0] = iS(t, o, d), r[1] = iS(e, a, f), s[0] = nS(t, o, d), s[1] = nS(e, a, f)
- }
- function mn(t, e, i, n, o, a, r, s, l) {
- var u = tt,
- h = et,
- c = Math.abs(o - a);
- if (c % rS < 1e-4 && c > 1e-4) return s[0] = t - i, s[1] = e - n, l[0] = t + i, void(l[1] = e + n);
- if (sS[0] = aS(o) * i + t, sS[1] = oS(o) * n + e, lS[0] = aS(a) * i + t, lS[1] = oS(a) * n + e, u(s, sS, lS), h(l,
- sS, lS), (o %= rS) < 0 && (o += rS), (a %= rS) < 0 && (a += rS), o > a && !r ? a += rS : o < a && r && (o += rS),
- r) {
- var d = a;
- a = o, o = d
- }
- for (var f = 0; f < a; f += Math.PI / 2) f > o && (uS[0] = aS(f) * i + t, uS[1] = oS(f) * n + e, u(s, uS, s), h(l,
- uS, l))
- }
- function vn(t, e, i, n, o, a, r) {
- if (0 === o) return !1;
- var s = o,
- l = 0,
- u = t;
- if (r > e + s && r > n + s || r < e - s && r < n - s || a > t + s && a > i + s || a < t - s && a < i - s) return !1;
- if (t === i) return Math.abs(a - t) <= s / 2;
- var h = (l = (e - n) / (t - i)) * a - r + (u = (t * n - i * e) / (t - i));
- return h * h / (l * l + 1) <= s / 2 * s / 2
- }
- function yn(t, e, i, n, o, a, r, s, l, u, h) {
- if (0 === l) return !1;
- var c = l;
- return !(h > e + c && h > n + c && h > a + c && h > s + c || h < e - c && h < n - c && h < a - c && h < s - c || u >
- t + c && u > i + c && u > o + c && u > r + c || u < t - c && u < i - c && u < o - c && u < r - c) && an(t, e, i, n,
- o, a, r, s, u, h, null) <= c / 2
- }
- function xn(t, e, i, n, o, a, r, s, l) {
- if (0 === r) return !1;
- var u = r;
- return !(l > e + u && l > n + u && l > a + u || l < e - u && l < n - u && l < a - u || s > t + u && s > i + u && s >
- o + u || s < t - u && s < i - u && s < o - u) && cn(t, e, i, n, o, a, s, l, null) <= u / 2
- }
- function _n(t) {
- return (t %= IS) < 0 && (t += IS), t
- }
- function wn(t, e, i, n, o, a, r, s, l) {
- if (0 === r) return !1;
- var u = r;
- s -= t, l -= e;
- var h = Math.sqrt(s * s + l * l);
- if (h - u > i || h + u < i) return !1;
- if (Math.abs(n - o) % TS < 1e-4) return !0;
- if (a) {
- var c = n;
- n = _n(o), o = _n(c)
- } else n = _n(n), o = _n(o);
- n > o && (o += TS);
- var d = Math.atan2(l, s);
- return d < 0 && (d += TS), d >= n && d <= o || d + TS >= n && d + TS <= o
- }
- function bn(t, e, i, n, o, a) {
- if (a > e && a > n || a < e && a < n) return 0;
- if (n === e) return 0;
- var r = n < e ? 1 : -1,
- s = (a - e) / (n - e);
- 1 !== s && 0 !== s || (r = n < e ? .5 : -.5);
- var l = s * (i - t) + t;
- return l === o ? 1 / 0 : l > o ? r : 0
- }
- function Sn(t, e) {
- return Math.abs(t - e) < CS
- }
- function Mn() {
- var t = kS[0];
- kS[0] = kS[1], kS[1] = t
- }
- function In(t, e, i, n, o, a, r, s, l, u) {
- if (u > e && u > n && u > a && u > s || u < e && u < n && u < a && u < s) return 0;
- var h = en(e, n, a, s, u, LS);
- if (0 === h) return 0;
- for (var c, d, f = 0, p = -1, g = 0; g < h; g++) {
- var m = LS[g],
- v = 0 === m || 1 === m ? .5 : 1;
- Qi(t, i, o, r, m) < l || (p < 0 && (p = nn(e, n, a, s, kS), kS[1] < kS[0] && p > 1 && Mn(), c = Qi(e, n, a, s, kS[0]),
- p > 1 && (d = Qi(e, n, a, s, kS[1]))), 2 == p ? m < kS[0] ? f += c < e ? v : -v : m < kS[1] ? f += d < c ? v : -
- v : f += s < d ? v : -v : m < kS[0] ? f += c < e ? v : -v : f += s < c ? v : -v)
- }
- return f
- }
- function Tn(t, e, i, n, o, a, r, s) {
- if (s > e && s > n && s > a || s < e && s < n && s < a) return 0;
- var l = ln(e, n, a, s, LS);
- if (0 === l) return 0;
- var u = un(e, n, a);
- if (u >= 0 && u <= 1) {
- for (var h = 0, c = rn(e, n, a, u), d = 0; d < l; d++) {
- f = 0 === LS[d] || 1 === LS[d] ? .5 : 1;
- (p = rn(t, i, o, LS[d])) < r || (LS[d] < u ? h += c < e ? f : -f : h += a < c ? f : -f)
- }
- return h
- }
- var f = 0 === LS[0] || 1 === LS[0] ? .5 : 1,
- p = rn(t, i, o, LS[0]);
- return p < r ? 0 : a < e ? f : -f
- }
- function An(t, e, i, n, o, a, r, s) {
- if ((s -= e) > i || s < -i) return 0;
- u = Math.sqrt(i * i - s * s);
- LS[0] = -u, LS[1] = u;
- var l = Math.abs(n - o);
- if (l < 1e-4) return 0;
- if (l % DS < 1e-4) {
- n = 0, o = DS;
- p = a ? 1 : -1;
- return r >= LS[0] + t && r <= LS[1] + t ? p : 0
- }
- if (a) {
- var u = n;
- n = _n(o), o = _n(u)
- } else n = _n(n), o = _n(o);
- n > o && (o += DS);
- for (var h = 0, c = 0; c < 2; c++) {
- var d = LS[c];
- if (d + t > r) {
- var f = Math.atan2(s, d),
- p = a ? 1 : -1;
- f < 0 && (f = DS + f), (f >= n && f <= o || f + DS >= n && f + DS <= o) && (f > Math.PI / 2 && f < 1.5 * Math.PI &&
- (p = -p), h += p)
- }
- }
- return h
- }
- function Dn(t, e, i, n, o) {
- for (var a = 0, r = 0, s = 0, l = 0, u = 0, h = 0; h < t.length;) {
- var c = t[h++];
- switch (c === AS.M && h > 1 && (i || (a += bn(r, s, l, u, n, o))), 1 == h && (l = r = t[h], u = s = t[h + 1]), c) {
- case AS.M:
- r = l = t[h++], s = u = t[h++];
- break;
- case AS.L:
- if (i) {
- if (vn(r, s, t[h], t[h + 1], e, n, o)) return !0
- } else a += bn(r, s, t[h], t[h + 1], n, o) || 0;
- r = t[h++], s = t[h++];
- break;
- case AS.C:
- if (i) {
- if (yn(r, s, t[h++], t[h++], t[h++], t[h++], t[h], t[h + 1], e, n, o)) return !0
- } else a += In(r, s, t[h++], t[h++], t[h++], t[h++], t[h], t[h + 1], n, o) || 0;
- r = t[h++], s = t[h++];
- break;
- case AS.Q:
- if (i) {
- if (xn(r, s, t[h++], t[h++], t[h], t[h + 1], e, n, o)) return !0
- } else a += Tn(r, s, t[h++], t[h++], t[h], t[h + 1], n, o) || 0;
- r = t[h++], s = t[h++];
- break;
- case AS.A:
- var d = t[h++],
- f = t[h++],
- p = t[h++],
- g = t[h++],
- m = t[h++],
- v = t[h++],
- y = (t[h++], 1 - t[h++]),
- x = Math.cos(m) * p + d,
- _ = Math.sin(m) * g + f;
- h > 1 ? a += bn(r, s, x, _, n, o) : (l = x, u = _);
- var w = (n - d) * g / p + d;
- if (i) {
- if (wn(d, f, g, m, m + v, y, e, w, o)) return !0
- } else a += An(d, f, g, m, m + v, y, w, o);
- r = Math.cos(m + v) * p + d, s = Math.sin(m + v) * g + f;
- break;
- case AS.R:
- l = r = t[h++], u = s = t[h++];
- var x = l + t[h++],
- _ = u + t[h++];
- if (i) {
- if (vn(l, u, x, u, e, n, o) || vn(x, u, x, _, e, n, o) || vn(x, _, l, _, e, n, o) || vn(l, _, l, u, e, n, o))
- return !0
- } else a += bn(x, u, x, _, n, o), a += bn(l, _, l, u, n, o);
- break;
- case AS.Z:
- if (i) {
- if (vn(r, s, l, u, e, n, o)) return !0
- } else a += bn(r, s, l, u, n, o);
- r = l, s = u
- }
- }
- return i || Sn(s, u) || (a += bn(r, s, l, u, n, o) || 0), 0 !== a
- }
- function Cn(t, e, i) {
- return Dn(t, 0, !1, e, i)
- }
- function Ln(t, e, i, n) {
- return Dn(t, e, !0, i, n)
- }
- function kn(t) {
- ui.call(this, t), this.path = null
- }
- function Pn(t, e, i, n, o, a, r, s, l, u, h) {
- var c = l * (HS / 180),
- d = WS(c) * (t - i) / 2 + FS(c) * (e - n) / 2,
- f = -1 * FS(c) * (t - i) / 2 + WS(c) * (e - n) / 2,
- p = d * d / (r * r) + f * f / (s * s);
- p > 1 && (r *= GS(p), s *= GS(p));
- var g = (o === a ? -1 : 1) * GS((r * r * (s * s) - r * r * (f * f) - s * s * (d * d)) / (r * r * (f * f) + s * s * (
- d * d))) || 0,
- m = g * r * f / s,
- v = g * -s * d / r,
- y = (t + i) / 2 + WS(c) * m - FS(c) * v,
- x = (e + n) / 2 + FS(c) * m + WS(c) * v,
- _ = XS([1, 0], [(d - m) / r, (f - v) / s]),
- w = [(d - m) / r, (f - v) / s],
- b = [(-1 * d - m) / r, (-1 * f - v) / s],
- S = XS(w, b);
- US(w, b) <= -1 && (S = HS), US(w, b) >= 1 && (S = 0), 0 === a && S > 0 && (S -= 2 * HS), 1 === a && S < 0 && (S += 2 *
- HS), h.addData(u, y, x, r, s, _, S, c, a)
- }
- function Nn(t) {
- if (!t) return new MS;
- for (var e, i = 0, n = 0, o = i, a = n, r = new MS, s = MS.CMD, l = t.match(jS), u = 0; u < l.length; u++) {
- for (var h, c = l[u], d = c.charAt(0), f = c.match(YS) || [], p = f.length, g = 0; g < p; g++) f[g] = parseFloat(f[
- g]);
- for (var m = 0; m < p;) {
- var v, y, x, _, w, b, S, M = i,
- I = n;
- switch (d) {
- case "l":
- i += f[m++], n += f[m++], h = s.L, r.addData(h, i, n);
- break;
- case "L":
- i = f[m++], n = f[m++], h = s.L, r.addData(h, i, n);
- break;
- case "m":
- i += f[m++], n += f[m++], h = s.M, r.addData(h, i, n), o = i, a = n, d = "l";
- break;
- case "M":
- i = f[m++], n = f[m++], h = s.M, r.addData(h, i, n), o = i, a = n, d = "L";
- break;
- case "h":
- i += f[m++], h = s.L, r.addData(h, i, n);
- break;
- case "H":
- i = f[m++], h = s.L, r.addData(h, i, n);
- break;
- case "v":
- n += f[m++], h = s.L, r.addData(h, i, n);
- break;
- case "V":
- n = f[m++], h = s.L, r.addData(h, i, n);
- break;
- case "C":
- h = s.C, r.addData(h, f[m++], f[m++], f[m++], f[m++], f[m++], f[m++]), i = f[m - 2], n = f[m - 1];
- break;
- case "c":
- h = s.C, r.addData(h, f[m++] + i, f[m++] + n, f[m++] + i, f[m++] + n, f[m++] + i, f[m++] + n), i += f[m - 2], n +=
- f[m - 1];
- break;
- case "S":
- v = i, y = n;
- var T = r.len(),
- A = r.data;
- e === s.C && (v += i - A[T - 4], y += n - A[T - 3]), h = s.C, M = f[m++], I = f[m++], i = f[m++], n = f[m++], r.addData(
- h, v, y, M, I, i, n);
- break;
- case "s":
- v = i, y = n;
- var T = r.len(),
- A = r.data;
- e === s.C && (v += i - A[T - 4], y += n - A[T - 3]), h = s.C, M = i + f[m++], I = n + f[m++], i += f[m++], n +=
- f[m++], r.addData(h, v, y, M, I, i, n);
- break;
- case "Q":
- M = f[m++], I = f[m++], i = f[m++], n = f[m++], h = s.Q, r.addData(h, M, I, i, n);
- break;
- case "q":
- M = f[m++] + i, I = f[m++] + n, i += f[m++], n += f[m++], h = s.Q, r.addData(h, M, I, i, n);
- break;
- case "T":
- v = i, y = n;
- var T = r.len(),
- A = r.data;
- e === s.Q && (v += i - A[T - 4], y += n - A[T - 3]), i = f[m++], n = f[m++], h = s.Q, r.addData(h, v, y, i, n);
- break;
- case "t":
- v = i, y = n;
- var T = r.len(),
- A = r.data;
- e === s.Q && (v += i - A[T - 4], y += n - A[T - 3]), i += f[m++], n += f[m++], h = s.Q, r.addData(h, v, y, i, n);
- break;
- case "A":
- x = f[m++], _ = f[m++], w = f[m++], b = f[m++], S = f[m++], Pn(M = i, I = n, i = f[m++], n = f[m++], b, S, x, _,
- w, h = s.A, r);
- break;
- case "a":
- x = f[m++], _ = f[m++], w = f[m++], b = f[m++], S = f[m++], Pn(M = i, I = n, i += f[m++], n += f[m++], b, S, x,
- _, w, h = s.A, r)
- }
- }
- "z" !== d && "Z" !== d || (h = s.Z, r.addData(h), i = o, n = a), e = h
- }
- return r.toStatic(), r
- }
- function On(t, e) {
- var i = Nn(t);
- return e = e || {}, e.buildPath = function(t) {
- if (t.setData) t.setData(i.data), (e = t.getContext()) && t.rebuildPath(e);
- else {
- var e = t;
- i.rebuildPath(e)
- }
- }, e.applyTransform = function(t) {
- VS(i, t), this.dirty(!0)
- }, e
- }
- function En(t, e) {
- return new kn(On(t, e))
- }
- function Rn(t, e) {
- return kn.extend(On(t, e))
- }
- function zn(t, e, i, n, o, a, r) {
- var s = .5 * (i - t),
- l = .5 * (n - e);
- return (2 * (e - i) + s + l) * r + (-3 * (e - i) - 2 * s - l) * a + s * o + e
- }
- function Bn(t, e, i) {
- var n = e.points,
- o = e.smooth;
- if (n && n.length >= 2) {
- if (o && "spline" !== o) {
- var a = iM(n, o, i, e.smoothConstraint);
- t.moveTo(n[0][0], n[0][1]);
- for (var r = n.length, s = 0; s < (i ? r : r - 1); s++) {
- var l = a[2 * s],
- u = a[2 * s + 1],
- h = n[(s + 1) % r];
- t.bezierCurveTo(l[0], l[1], u[0], u[1], h[0], h[1])
- }
- } else {
- "spline" === o && (n = eM(n, i)), t.moveTo(n[0][0], n[0][1]);
- for (var s = 1, c = n.length; s < c; s++) t.lineTo(n[s][0], n[s][1])
- }
- i && t.closePath()
- }
- }
- function Vn(t, e, i) {
- var n = t.cpx2,
- o = t.cpy2;
- return null === n || null === o ? [(i ? tn : Qi)(t.x1, t.cpx1, t.cpx2, t.x2, e), (i ? tn : Qi)(t.y1, t.cpy1, t.cpy2,
- t.y2, e)] : [(i ? sn : rn)(t.x1, t.cpx1, t.x2, e), (i ? sn : rn)(t.y1, t.cpy1, t.y2, e)]
- }
- function Gn(t) {
- ui.call(this, t), this._displayables = [], this._temporaryDisplayables = [], this._cursor = 0, this.notClear = !0
- }
- function Fn(t) {
- return kn.extend(t)
- }
- function Wn(t, e, i, n) {
- var o = En(t, e);
- return i && ("center" === n && (i = Zn(i, o.getBoundingRect())), Un(o, i)), o
- }
- function Hn(t, e, i) {
- var n = new hi({
- style: {
- image: t,
- x: e.x,
- y: e.y,
- width: e.width,
- height: e.height
- },
- onload: function(t) {
- if ("center" === i) {
- var o = {
- width: t.width,
- height: t.height
- };
- n.setStyle(Zn(e, o))
- }
- }
- });
- return n
- }
- function Zn(t, e) {
- var i, n = e.width / e.height,
- o = t.height * n;
- return i = o <= t.width ? t.height : (o = t.width) / n, {
- x: t.x + t.width / 2 - o / 2,
- y: t.y + t.height / 2 - i / 2,
- width: o,
- height: i
- }
- }
- function Un(t, e) {
- if (t.applyTransform) {
- var i = t.getBoundingRect().calculateTransform(e);
- t.applyTransform(i)
- }
- }
- function Xn(t) {
- var e = t.shape,
- i = t.style.lineWidth;
- return gM(2 * e.x1) === gM(2 * e.x2) && (e.x1 = e.x2 = Yn(e.x1, i, !0)), gM(2 * e.y1) === gM(2 * e.y2) && (e.y1 = e.y2 =
- Yn(e.y1, i, !0)), t
- }
- function jn(t) {
- var e = t.shape,
- i = t.style.lineWidth,
- n = e.x,
- o = e.y,
- a = e.width,
- r = e.height;
- return e.x = Yn(e.x, i, !0), e.y = Yn(e.y, i, !0), e.width = Math.max(Yn(n + a, i, !1) - e.x, 0 === a ? 0 : 1), e.height =
- Math.max(Yn(o + r, i, !1) - e.y, 0 === r ? 0 : 1), t
- }
- function Yn(t, e, i) {
- var n = gM(2 * t);
- return (n + gM(e)) % 2 == 0 ? n / 2 : (n + (i ? 1 : -1)) / 2
- }
- function qn(t) {
- return null != t && "none" !== t
- }
- function Kn(t) {
- if ("string" != typeof t) return t;
- var e = _M.get(t);
- return e || (e = Gt(t, -.1), wM < 1e4 && (_M.set(t, e), wM++)), e
- }
- function $n(t) {
- if (t.__hoverStlDirty) {
- t.__hoverStlDirty = !1;
- var e = t.__hoverStl;
- if (e) {
- var i = t.__normalStl = {},
- n = t.style;
- for (var o in e) null != e[o] && (i[o] = n[o]);
- i.fill = n.fill, i.stroke = n.stroke
- } else t.__normalStl = null
- }
- }
- function Jn(t) {
- var e = t.__hoverStl;
- if (e && !t.__highlighted) {
- var i = t.useHoverLayer;
- t.__highlighted = i ? "layer" : "plain";
- var n = t.__zr;
- if (n || !i) {
- var o = t,
- a = t.style;
- i && (a = (o = n.addHover(t)).style), xo(a), i || $n(o), a.extendFrom(e), Qn(a, e, "fill"), Qn(a, e, "stroke"), yo(
- a), i || (t.dirty(!1), t.z2 += 1)
- }
- }
- }
- function Qn(t, e, i) {
- !qn(e[i]) && qn(t[i]) && (t[i] = Kn(t[i]))
- }
- function to(t) {
- t.__highlighted && (eo(t), t.__highlighted = !1)
- }
- function eo(t) {
- var e = t.__highlighted;
- if ("layer" === e) t.__zr && t.__zr.removeHover(t);
- else if (e) {
- var i = t.style,
- n = t.__normalStl;
- n && (xo(i), t.setStyle(n), yo(i), t.z2 -= 1)
- }
- }
- function io(t, e) {
- t.isGroup ? t.traverse(function(t) {
- !t.isGroup && e(t)
- }) : e(t)
- }
- function no(t, e) {
- e = t.__hoverStl = !1 !== e && (e || {}), t.__hoverStlDirty = !0, t.__highlighted && (to(t), Jn(t))
- }
- function oo(t) {
- return t && t.__isEmphasisEntered
- }
- function ao(t) {
- this.__hoverSilentOnTouch && t.zrByTouch || !this.__isEmphasisEntered && io(this, Jn)
- }
- function ro(t) {
- this.__hoverSilentOnTouch && t.zrByTouch || !this.__isEmphasisEntered && io(this, to)
- }
- function so() {
- this.__isEmphasisEntered = !0, io(this, Jn)
- }
- function lo() {
- this.__isEmphasisEntered = !1, io(this, to)
- }
- function uo(t, e, i) {
- t.isGroup ? t.traverse(function(t) {
- !t.isGroup && no(t, t.hoverStyle || e)
- }) : no(t, t.hoverStyle || e), ho(t, i)
- }
- function ho(t, e) {
- var i = !1 === e;
- if (t.__hoverSilentOnTouch = null != e && e.hoverSilentOnTouch, !i || t.__hoverStyleTrigger) {
- var n = i ? "off" : "on";
- t[n]("mouseover", ao)[n]("mouseout", ro), t[n]("emphasis", so)[n]("normal", lo), t.__hoverStyleTrigger = !i
- }
- }
- function co(t, e, i, n, o, a, r) {
- var s, l = (o = o || yM).labelFetcher,
- u = o.labelDataIndex,
- h = o.labelDimIndex,
- c = i.getShallow("show"),
- d = n.getShallow("show");
- (c || d) && (l && (s = l.getFormattedLabel(u, "normal", null, h)), null == s && (s = x(o.defaultText) ? o.defaultText(
- u, o) : o.defaultText));
- var f = c ? s : null,
- p = d ? A(l ? l.getFormattedLabel(u, "emphasis", null, h) : null, s) : null;
- null == f && null == p || (fo(t, i, a, o), fo(e, n, r, o, !0)), t.text = f, e.text = p
- }
- function fo(t, e, i, n, o) {
- return po(t, e, n, o), i && a(t, i), t
- }
- function po(t, e, i, n) {
- if ((i = i || yM).isRectText) {
- var o = e.getShallow("position") || (n ? null : "inside");
- "outside" === o && (o = "top"), t.textPosition = o, t.textOffset = e.getShallow("offset");
- var a = e.getShallow("rotate");
- null != a && (a *= Math.PI / 180), t.textRotation = a, t.textDistance = A(e.getShallow("distance"), n ? null : 5)
- }
- var r, s = e.ecModel,
- l = s && s.option.textStyle,
- u = go(e);
- if (u) {
- r = {};
- for (var h in u)
- if (u.hasOwnProperty(h)) {
- var c = e.getModel(["rich", h]);
- mo(r[h] = {}, c, l, i, n)
- }
- }
- return t.rich = r, mo(t, e, l, i, n, !0), i.forceRich && !i.textStyle && (i.textStyle = {}), t
- }
- function go(t) {
- for (var e; t && t !== t.ecModel;) {
- var i = (t.option || yM).rich;
- if (i) {
- e = e || {};
- for (var n in i) i.hasOwnProperty(n) && (e[n] = 1)
- }
- t = t.parentModel
- }
- return e
- }
- function mo(t, e, i, n, o, a) {
- i = !o && i || yM, t.textFill = vo(e.getShallow("color"), n) || i.color, t.textStroke = vo(e.getShallow(
- "textBorderColor"), n) || i.textBorderColor, t.textStrokeWidth = A(e.getShallow("textBorderWidth"), i.textBorderWidth),
- t.insideRawTextPosition = t.textPosition, o || (a && (t.insideRollbackOpt = n, yo(t)), null == t.textFill && (t.textFill =
- n.autoColor)), t.fontStyle = e.getShallow("fontStyle") || i.fontStyle, t.fontWeight = e.getShallow("fontWeight") ||
- i.fontWeight, t.fontSize = e.getShallow("fontSize") || i.fontSize, t.fontFamily = e.getShallow("fontFamily") || i.fontFamily,
- t.textAlign = e.getShallow("align"), t.textVerticalAlign = e.getShallow("verticalAlign") || e.getShallow("baseline"),
- t.textLineHeight = e.getShallow("lineHeight"), t.textWidth = e.getShallow("width"), t.textHeight = e.getShallow(
- "height"), t.textTag = e.getShallow("tag"), a && n.disableBox || (t.textBackgroundColor = vo(e.getShallow(
- "backgroundColor"), n), t.textPadding = e.getShallow("padding"), t.textBorderColor = vo(e.getShallow(
- "borderColor"), n), t.textBorderWidth = e.getShallow("borderWidth"), t.textBorderRadius = e.getShallow(
- "borderRadius"), t.textBoxShadowColor = e.getShallow("shadowColor"), t.textBoxShadowBlur = e.getShallow(
- "shadowBlur"), t.textBoxShadowOffsetX = e.getShallow("shadowOffsetX"), t.textBoxShadowOffsetY = e.getShallow(
- "shadowOffsetY")), t.textShadowColor = e.getShallow("textShadowColor") || i.textShadowColor, t.textShadowBlur = e.getShallow(
- "textShadowBlur") || i.textShadowBlur, t.textShadowOffsetX = e.getShallow("textShadowOffsetX") || i.textShadowOffsetX,
- t.textShadowOffsetY = e.getShallow("textShadowOffsetY") || i.textShadowOffsetY
- }
- function vo(t, e) {
- return "auto" !== t ? t : e && e.autoColor ? e.autoColor : null
- }
- function yo(t) {
- var e = t.insideRollbackOpt;
- if (e && null == t.textFill) {
- var i, n = e.useInsideStyle,
- o = t.insideRawTextPosition,
- a = e.autoColor;
- !1 !== n && (!0 === n || e.isRectText && o && "string" == typeof o && o.indexOf("inside") >= 0) ? (i = {
- textFill: null,
- textStroke: t.textStroke,
- textStrokeWidth: t.textStrokeWidth
- }, t.textFill = "#fff", null == t.textStroke && (t.textStroke = a, null == t.textStrokeWidth && (t.textStrokeWidth =
- 2))) : null != a && (i = {
- textFill: null
- }, t.textFill = a), i && (t.insideRollback = i)
- }
- }
- function xo(t) {
- var e = t.insideRollback;
- e && (t.textFill = e.textFill, t.textStroke = e.textStroke, t.textStrokeWidth = e.textStrokeWidth, t.insideRollback =
- null)
- }
- function _o(t, e) {
- var i = e || e.getModel("textStyle");
- return P([t.fontStyle || i && i.getShallow("fontStyle") || "", t.fontWeight || i && i.getShallow("fontWeight") || "",
- (t.fontSize || i && i.getShallow("fontSize") || 12) + "px", t.fontFamily || i && i.getShallow("fontFamily") ||
- "sans-serif"
- ].join(" "))
- }
- function wo(t, e, i, n, o, a) {
- if ("function" == typeof o && (a = o, o = null), n && n.isAnimationEnabled()) {
- var r = t ? "Update" : "",
- s = n.getShallow("animationDuration" + r),
- l = n.getShallow("animationEasing" + r),
- u = n.getShallow("animationDelay" + r);
- "function" == typeof u && (u = u(o, n.getAnimationDelayParams ? n.getAnimationDelayParams(e, o) : null)),
- "function" == typeof s && (s = s(o)), s > 0 ? e.animateTo(i, s, u || 0, l, a, !!a) : (e.stopAnimation(), e.attr(i),
- a && a())
- } else e.stopAnimation(), e.attr(i), a && a()
- }
- function bo(t, e, i, n, o) {
- wo(!0, t, e, i, n, o)
- }
- function So(t, e, i, n, o) {
- wo(!1, t, e, i, n, o)
- }
- function Mo(t, e) {
- for (var i = vt([]); t && t !== e;) xt(i, t.getLocalTransform(), i), t = t.parent;
- return i
- }
- function Io(t, e, i) {
- return e && !c(e) && (e = mw.getLocalTransform(e)), i && (e = St([], e)), Q([], t, e)
- }
- function To(t, e, i) {
- var n = 0 === e[4] || 0 === e[5] || 0 === e[0] ? 1 : Math.abs(2 * e[4] / e[0]),
- o = 0 === e[4] || 0 === e[5] || 0 === e[2] ? 1 : Math.abs(2 * e[4] / e[2]),
- a = ["left" === t ? -n : "right" === t ? n : 0, "top" === t ? -o : "bottom" === t ? o : 0];
- return a = Io(a, e, i), Math.abs(a[0]) > Math.abs(a[1]) ? a[0] > 0 ? "right" : "left" : a[1] > 0 ? "bottom" : "top"
- }
- function Ao(t, e, i, n) {
- function o(t) {
- var e = {
- position: F(t.position),
- rotation: t.rotation
- };
- return t.shape && (e.shape = a({}, t.shape)), e
- }
- if (t && e) {
- var r = function(t) {
- var e = {};
- return t.traverse(function(t) {
- !t.isGroup && t.anid && (e[t.anid] = t)
- }), e
- }(t);
- e.traverse(function(t) {
- if (!t.isGroup && t.anid) {
- var e = r[t.anid];
- if (e) {
- var n = o(t);
- t.attr(o(e)), bo(t, n, i, t.dataIndex)
- }
- }
- })
- }
- }
- function Do(t, e) {
- return f(t, function(t) {
- var i = t[0];
- i = mM(i, e.x), i = vM(i, e.x + e.width);
- var n = t[1];
- return n = mM(n, e.y), n = vM(n, e.y + e.height), [i, n]
- })
- }
- function Co(t, e, i) {
- var n = (e = a({
- rectHover: !0
- }, e)).style = {
- strokeNoScale: !0
- };
- if (i = i || {
- x: -1,
- y: -1,
- width: 2,
- height: 2
- }, t) return 0 === t.indexOf("image://") ? (n.image = t.slice(8), r(n, i), new hi(e)) : Wn(t.replace("path://", ""),
- e, i, "center")
- }
- function Lo(t, e, i) {
- this.parentModel = e, this.ecModel = i, this.option = t
- }
- function ko(t, e, i) {
- for (var n = 0; n < e.length && (!e[n] || null != (t = t && "object" == typeof t ? t[e[n]] : null)); n++);
- return null == t && i && (t = i.get(e)), t
- }
- function Po(t, e) {
- var i = DM(t).getParent;
- return i ? i.call(t, e) : t.parentModel
- }
- function No(t) {
- return [t || "", CM++, Math.random().toFixed(5)].join("_")
- }
- function Oo(t) {
- return t.replace(/^\s+/, "").replace(/\s+$/, "")
- }
- function Eo(t, e, i, n) {
- var o = e[1] - e[0],
- a = i[1] - i[0];
- if (0 === o) return 0 === a ? i[0] : (i[0] + i[1]) / 2;
- if (n)
- if (o > 0) {
- if (t <= e[0]) return i[0];
- if (t >= e[1]) return i[1]
- } else {
- if (t >= e[0]) return i[0];
- if (t <= e[1]) return i[1]
- }
- else {
- if (t === e[0]) return i[0];
- if (t === e[1]) return i[1]
- }
- return (t - e[0]) / o * a + i[0]
- }
- function Ro(t, e) {
- switch (t) {
- case "center":
- case "middle":
- t = "50%";
- break;
- case "left":
- case "top":
- t = "0%";
- break;
- case "right":
- case "bottom":
- t = "100%"
- }
- return "string" == typeof t ? Oo(t).match(/%$/) ? parseFloat(t) / 100 * e : parseFloat(t) : null == t ? NaN : +t
- }
- function zo(t, e, i) {
- return null == e && (e = 10), e = Math.min(Math.max(0, e), 20), t = (+t).toFixed(e), i ? t : +t
- }
- function Bo(t) {
- return t.sort(function(t, e) {
- return t - e
- }), t
- }
- function Vo(t) {
- if (t = +t, isNaN(t)) return 0;
- for (var e = 1, i = 0; Math.round(t * e) / e !== t;) e *= 10, i++;
- return i
- }
- function Go(t) {
- var e = t.toString(),
- i = e.indexOf("e");
- if (i > 0) {
- var n = +e.slice(i + 1);
- return n < 0 ? -n : 0
- }
- var o = e.indexOf(".");
- return o < 0 ? 0 : e.length - 1 - o
- }
- function Fo(t, e) {
- var i = Math.log,
- n = Math.LN10,
- o = Math.floor(i(t[1] - t[0]) / n),
- a = Math.round(i(Math.abs(e[1] - e[0])) / n),
- r = Math.min(Math.max(-o + a, 0), 20);
- return isFinite(r) ? r : 20
- }
- function Wo(t, e, i) {
- if (!t[e]) return 0;
- var n = p(t, function(t, e) {
- return t + (isNaN(e) ? 0 : e)
- }, 0);
- if (0 === n) return 0;
- for (var o = Math.pow(10, i), a = f(t, function(t) {
- return (isNaN(t) ? 0 : t) / n * o * 100
- }), r = 100 * o, s = f(a, function(t) {
- return Math.floor(t)
- }), l = p(s, function(t, e) {
- return t + e
- }, 0), u = f(a, function(t, e) {
- return t - s[e]
- }); l < r;) {
- for (var h = Number.NEGATIVE_INFINITY, c = null, d = 0, g = u.length; d < g; ++d) u[d] > h && (h = u[d], c = d);
- ++s[c], u[c] = 0, ++l
- }
- return s[e] / o
- }
- function Ho(t) {
- var e = 2 * Math.PI;
- return (t % e + e) % e
- }
- function Zo(t) {
- return t > -LM && t < LM
- }
- function Uo(t) {
- if (t instanceof Date) return t;
- if ("string" == typeof t) {
- var e = PM.exec(t);
- if (!e) return new Date(NaN);
- if (e[8]) {
- var i = +e[4] || 0;
- return "Z" !== e[8].toUpperCase() && (i -= e[8].slice(0, 3)), new Date(Date.UTC(+e[1], +(e[2] || 1) - 1, +e[3] ||
- 1, i, +(e[5] || 0), +e[6] || 0, +e[7] || 0))
- }
- return new Date(+e[1], +(e[2] || 1) - 1, +e[3] || 1, +e[4] || 0, +(e[5] || 0), +e[6] || 0, +e[7] || 0)
- }
- return null == t ? new Date(NaN) : new Date(Math.round(t))
- }
- function Xo(t) {
- return Math.pow(10, jo(t))
- }
- function jo(t) {
- return Math.floor(Math.log(t) / Math.LN10)
- }
- function Yo(t, e) {
- var i, n = jo(t),
- o = Math.pow(10, n),
- a = t / o;
- return i = e ? a < 1.5 ? 1 : a < 2.5 ? 2 : a < 4 ? 3 : a < 7 ? 5 : 10 : a < 1 ? 1 : a < 2 ? 2 : a < 3 ? 3 : a < 5 ?
- 5 : 10, t = i * o, n >= -20 ? +t.toFixed(n < 0 ? -n : 0) : t
- }
- function qo(t) {
- function e(t, i, n) {
- return t.interval[n] < i.interval[n] || t.interval[n] === i.interval[n] && (t.close[n] - i.close[n] == (n ? -1 : 1) ||
- !n && e(t, i, 1))
- }
- t.sort(function(t, i) {
- return e(t, i, 0) ? -1 : 1
- });
- for (var i = -1 / 0, n = 1, o = 0; o < t.length;) {
- for (var a = t[o].interval, r = t[o].close, s = 0; s < 2; s++) a[s] <= i && (a[s] = i, r[s] = s ? 1 : 1 - n), i = a[
- s], n = r[s];
- a[0] === a[1] && r[0] * r[1] != 1 ? t.splice(o, 1) : o++
- }
- return t
- }
- function Ko(t) {
- return t - parseFloat(t) >= 0
- }
- function $o(t) {
- return isNaN(t) ? "-" : (t = (t + "").split("."))[0].replace(/(\d{1,3})(?=(?:\d{3})+(?!\d))/g, "$1,") + (t.length >
- 1 ? "." + t[1] : "")
- }
- function Jo(t, e) {
- return t = (t || "").toLowerCase().replace(/-(.)/g, function(t, e) {
- return e.toUpperCase()
- }), e && t && (t = t.charAt(0).toUpperCase() + t.slice(1)), t
- }
- function Qo(t) {
- return null == t ? "" : (t + "").replace(EM, function(t, e) {
- return RM[e]
- })
- }
- function ta(t, e, i) {
- y(e) || (e = [e]);
- var n = e.length;
- if (!n) return "";
- for (var o = e[0].$vars || [], a = 0; a < o.length; a++) {
- var r = zM[a];
- t = t.replace(BM(r), BM(r, 0))
- }
- for (var s = 0; s < n; s++)
- for (var l = 0; l < o.length; l++) {
- var u = e[s][o[l]];
- t = t.replace(BM(zM[l], s), i ? Qo(u) : u)
- }
- return t
- }
- function ea(t, e, i) {
- return d(e, function(e, n) {
- t = t.replace("{" + n + "}", i ? Qo(e) : e)
- }), t
- }
- function ia(t, e) {
- var i = (t = _(t) ? {
- color: t,
- extraCssText: e
- } : t || {}).color,
- n = t.type,
- e = t.extraCssText,
- o = t.renderMode || "html",
- a = t.markerId || "X";
- return i ? "html" === o ? "subItem" === n ?
- '<span style="display:inline-block;vertical-align:middle;margin-right:8px;margin-left:3px;border-radius:4px;width:4px;height:4px;background-color:' +
- Qo(i) + ";" + (e || "") + '"></span>' :
- '<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:' +
- Qo(i) + ";" + (e || "") + '"></span>' : {
- renderMode: o,
- content: "{marker" + a + "|} ",
- style: {
- color: i
- }
- } : ""
- }
- function na(t, e) {
- return t += "", "0000".substr(0, e - t.length) + t
- }
- function oa(t, e, i) {
- "week" !== t && "month" !== t && "quarter" !== t && "half-year" !== t && "year" !== t || (t = "MM-dd\nyyyy");
- var n = Uo(e),
- o = i ? "UTC" : "",
- a = n["get" + o + "FullYear"](),
- r = n["get" + o + "Month"]() + 1,
- s = n["get" + o + "Date"](),
- l = n["get" + o + "Hours"](),
- u = n["get" + o + "Minutes"](),
- h = n["get" + o + "Seconds"](),
- c = n["get" + o + "Milliseconds"]();
- return t = t.replace("MM", na(r, 2)).replace("M", r).replace("yyyy", a).replace("yy", a % 100).replace("dd", na(s, 2))
- .replace("d", s).replace("hh", na(l, 2)).replace("h", l).replace("mm", na(u, 2)).replace("m", u).replace("ss", na(h,
- 2)).replace("s", h).replace("SSS", na(c, 3))
- }
- function aa(t) {
- return t ? t.charAt(0).toUpperCase() + t.substr(1) : t
- }
- function ra(t, e, i, n, o) {
- var a = 0,
- r = 0;
- null == n && (n = 1 / 0), null == o && (o = 1 / 0);
- var s = 0;
- e.eachChild(function(l, u) {
- var h, c, d = l.position,
- f = l.getBoundingRect(),
- p = e.childAt(u + 1),
- g = p && p.getBoundingRect();
- if ("horizontal" === t) {
- var m = f.width + (g ? -g.x + f.x : 0);
- (h = a + m) > n || l.newline ? (a = 0, h = m, r += s + i, s = f.height) : s = Math.max(s, f.height)
- } else {
- var v = f.height + (g ? -g.y + f.y : 0);
- (c = r + v) > o || l.newline ? (a += s + i, r = 0, c = v, s = f.width) : s = Math.max(s, f.width)
- }
- l.newline || (d[0] = a, d[1] = r, "horizontal" === t ? a = h + i : r = c + i)
- })
- }
- function sa(t, e, i) {
- var n = e.width,
- o = e.height,
- a = Ro(t.x, n),
- r = Ro(t.y, o),
- s = Ro(t.x2, n),
- l = Ro(t.y2, o);
- return (isNaN(a) || isNaN(parseFloat(t.x))) && (a = 0), (isNaN(s) || isNaN(parseFloat(t.x2))) && (s = n), (isNaN(r) ||
- isNaN(parseFloat(t.y))) && (r = 0), (isNaN(l) || isNaN(parseFloat(t.y2))) && (l = o), i = OM(i || 0), {
- width: Math.max(s - a - i[1] - i[3], 0),
- height: Math.max(l - r - i[0] - i[2], 0)
- }
- }
- function la(t, e, i) {
- i = OM(i || 0);
- var n = e.width,
- o = e.height,
- a = Ro(t.left, n),
- r = Ro(t.top, o),
- s = Ro(t.right, n),
- l = Ro(t.bottom, o),
- u = Ro(t.width, n),
- h = Ro(t.height, o),
- c = i[2] + i[0],
- d = i[1] + i[3],
- f = t.aspect;
- switch (isNaN(u) && (u = n - s - d - a), isNaN(h) && (h = o - l - c - r), null != f && (isNaN(u) && isNaN(h) && (f >
- n / o ? u = .8 * n : h = .8 * o), isNaN(u) && (u = f * h), isNaN(h) && (h = u / f)), isNaN(a) && (a = n - s - u -
- d), isNaN(r) && (r = o - l - h - c), t.left || t.right) {
- case "center":
- a = n / 2 - u / 2 - i[3];
- break;
- case "right":
- a = n - u - d
- }
- switch (t.top || t.bottom) {
- case "middle":
- case "center":
- r = o / 2 - h / 2 - i[0];
- break;
- case "bottom":
- r = o - h - c
- }
- a = a || 0, r = r || 0, isNaN(u) && (u = n - d - a - (s || 0)), isNaN(h) && (h = o - c - r - (l || 0));
- var p = new ue(a + i[3], r + i[0], u, h);
- return p.margin = i, p
- }
- function ua(t, e, i, n, o) {
- var a = !o || !o.hv || o.hv[0],
- s = !o || !o.hv || o.hv[1],
- l = o && o.boundingMode || "all";
- if (a || s) {
- var u;
- if ("raw" === l) u = "group" === t.type ? new ue(0, 0, +e.width || 0, +e.height || 0) : t.getBoundingRect();
- else if (u = t.getBoundingRect(), t.needLocalTransform()) {
- var h = t.getLocalTransform();
- (u = u.clone()).applyTransform(h)
- }
- e = la(r({
- width: u.width,
- height: u.height
- }, e), i, n);
- var c = t.position,
- d = a ? e.x - u.x : 0,
- f = s ? e.y - u.y : 0;
- t.attr("position", "raw" === l ? [d, f] : [c[0] + d, c[1] + f])
- }
- }
- function ha(t, e) {
- return null != t[ZM[e][0]] || null != t[ZM[e][1]] && null != t[ZM[e][2]]
- }
- function ca(t, e, i) {
- function n(i, n) {
- var r = {},
- l = 0,
- u = {},
- h = 0;
- if (WM(i, function(e) {
- u[e] = t[e]
- }), WM(i, function(t) {
- o(e, t) && (r[t] = u[t] = e[t]), a(r, t) && l++, a(u, t) && h++
- }), s[n]) return a(e, i[1]) ? u[i[2]] = null : a(e, i[2]) && (u[i[1]] = null), u;
- if (2 !== h && l) {
- if (l >= 2) return r;
- for (var c = 0; c < i.length; c++) {
- var d = i[c];
- if (!o(r, d) && o(t, d)) {
- r[d] = t[d];
- break
- }
- }
- return r
- }
- return u
- }
- function o(t, e) {
- return t.hasOwnProperty(e)
- }
- function a(t, e) {
- return null != t[e] && "auto" !== t[e]
- }
- function r(t, e, i) {
- WM(t, function(t) {
- e[t] = i[t]
- })
- }!w(i) && (i = {});
- var s = i.ignoreSize;
- !y(s) && (s = [s, s]);
- var l = n(ZM[0], 0),
- u = n(ZM[1], 1);
- r(ZM[0], t, l), r(ZM[1], t, u)
- }
- function da(t) {
- return fa({}, t)
- }
- function fa(t, e) {
- return e && t && WM(HM, function(i) {
- e.hasOwnProperty(i) && (t[i] = e[i])
- }), t
- }
- function pa(t, e) {
- for (var i = t.length, n = 0; n < i; n++)
- if (t[n].length > e) return t[n];
- return t[i - 1]
- }
- function ga(t) {
- var e = t.get("coordinateSystem"),
- i = {
- coordSysName: e,
- coordSysDims: [],
- axisMap: R(),
- categoryAxisMap: R()
- },
- n = QM[e];
- if (n) return n(t, i, i.axisMap, i.categoryAxisMap), i
- }
- function ma(t) {
- return "category" === t.get("type")
- }
- function va(t) {
- this.fromDataset = t.fromDataset, this.data = t.data || (t.sourceFormat === nI ? {} : []), this.sourceFormat = t.sourceFormat ||
- oI, this.seriesLayoutBy = t.seriesLayoutBy || rI, this.dimensionsDefine = t.dimensionsDefine, this.encodeDefine = t
- .encodeDefine && R(t.encodeDefine), this.startIndex = t.startIndex || 0, this.dimensionsDetectCount = t.dimensionsDetectCount
- }
- function ya(t) {
- var e = t.option.source,
- i = oI;
- if (S(e)) i = aI;
- else if (y(e)) {
- 0 === e.length && (i = eI);
- for (var n = 0, o = e.length; n < o; n++) {
- var a = e[n];
- if (null != a) {
- if (y(a)) {
- i = eI;
- break
- }
- if (w(a)) {
- i = iI;
- break
- }
- }
- }
- } else if (w(e)) {
- for (var r in e)
- if (e.hasOwnProperty(r) && c(e[r])) {
- i = nI;
- break
- }
- } else if (null != e) throw new Error("Invalid data");
- lI(t).sourceFormat = i
- }
- function xa(t) {
- return lI(t).source
- }
- function _a(t) {
- lI(t).datasetMap = R()
- }
- function wa(t) {
- var e = t.option,
- i = e.data,
- n = S(i) ? aI : tI,
- o = !1,
- a = e.seriesLayoutBy,
- r = e.sourceHeader,
- s = e.dimensions,
- l = Aa(t);
- if (l) {
- var u = l.option;
- i = u.source, n = lI(l).sourceFormat, o = !0, a = a || u.seriesLayoutBy, null == r && (r = u.sourceHeader), s = s ||
- u.dimensions
- }
- var h = ba(i, n, a, r, s),
- c = e.encode;
- !c && l && (c = Ta(t, l, i, n, a, h)), lI(t).source = new va({
- data: i,
- fromDataset: o,
- seriesLayoutBy: a,
- sourceFormat: n,
- dimensionsDefine: h.dimensionsDefine,
- startIndex: h.startIndex,
- dimensionsDetectCount: h.dimensionsDetectCount,
- encodeDefine: c
- })
- }
- function ba(t, e, i, n, o) {
- if (!t) return {
- dimensionsDefine: Sa(o)
- };
- var a, r, s;
- if (e === eI) "auto" === n || null == n ? Ma(function(t) {
- null != t && "-" !== t && (_(t) ? null == r && (r = 1) : r = 0)
- }, i, t, 10) : r = n ? 1 : 0, o || 1 !== r || (o = [], Ma(function(t, e) {
- o[e] = null != t ? t : ""
- }, i, t)), a = o ? o.length : i === sI ? t.length : t[0] ? t[0].length : null;
- else if (e === iI) o || (o = Ia(t), s = !0);
- else if (e === nI) o || (o = [], s = !0, d(t, function(t, e) {
- o.push(e)
- }));
- else if (e === tI) {
- var l = Li(t[0]);
- a = y(l) && l.length || 1
- }
- var u;
- return s && d(o, function(t, e) {
- "name" === (w(t) ? t.name : t) && (u = e)
- }), {
- startIndex: r,
- dimensionsDefine: Sa(o),
- dimensionsDetectCount: a,
- potentialNameDimIndex: u
- }
- }
- function Sa(t) {
- if (t) {
- var e = R();
- return f(t, function(t, i) {
- if (null == (t = a({}, w(t) ? t : {
- name: t
- })).name) return t;
- t.name += "", null == t.displayName && (t.displayName = t.name);
- var n = e.get(t.name);
- return n ? t.name += "-" + n.count++ : e.set(t.name, {
- count: 1
- }), t
- })
- }
- }
- function Ma(t, e, i, n) {
- if (null == n && (n = 1 / 0), e === sI)
- for (a = 0; a < i.length && a < n; a++) t(i[a] ? i[a][0] : null, a);
- else
- for (var o = i[0] || [], a = 0; a < o.length && a < n; a++) t(o[a], a)
- }
- function Ia(t) {
- for (var e, i = 0; i < t.length && !(e = t[i++]););
- if (e) {
- var n = [];
- return d(e, function(t, e) {
- n.push(e)
- }), n
- }
- }
- function Ta(t, e, i, n, o, a) {
- var r = ga(t),
- s = {},
- l = [],
- u = [],
- h = t.subType,
- c = R(["pie", "map", "funnel"]),
- f = R(["line", "bar", "pictorialBar", "scatter", "effectScatter", "candlestick", "boxplot"]);
- if (r && null != f.get(h)) {
- var p = t.ecModel,
- g = lI(p).datasetMap,
- m = e.uid + "_" + o,
- v = g.get(m) || g.set(m, {
- categoryWayDim: 1,
- valueWayDim: 0
- });
- d(r.coordSysDims, function(t) {
- if (null == r.firstCategoryDimIndex) {
- e = v.valueWayDim++;
- s[t] = e, u.push(e)
- } else if (r.categoryAxisMap.get(t)) s[t] = 0, l.push(0);
- else {
- var e = v.categoryWayDim++;
- s[t] = e, u.push(e)
- }
- })
- } else if (null != c.get(h)) {
- for (var y, x = 0; x < 5 && null == y; x++) Ca(i, n, o, a.dimensionsDefine, a.startIndex, x) || (y = x);
- if (null != y) {
- s.value = y;
- var _ = a.potentialNameDimIndex || Math.max(y - 1, 0);
- u.push(_), l.push(_)
- }
- }
- return l.length && (s.itemName = l), u.length && (s.seriesName = u), s
- }
- function Aa(t) {
- var e = t.option;
- if (!e.data) return t.ecModel.getComponent("dataset", e.datasetIndex || 0)
- }
- function Da(t, e) {
- return Ca(t.data, t.sourceFormat, t.seriesLayoutBy, t.dimensionsDefine, t.startIndex, e)
- }
- function Ca(t, e, i, n, o, a) {
- function r(t) {
- return (null == t || !isFinite(t) || "" === t) && (!(!_(t) || "-" === t) || void 0)
- }
- var s;
- if (S(t)) return !1;
- var l;
- if (n && (l = w(l = n[a]) ? l.name : l), e === eI)
- if (i === sI) {
- for (var u = t[a], h = 0; h < (u || []).length && h < 5; h++)
- if (null != (s = r(u[o + h]))) return s
- } else
- for (h = 0; h < t.length && h < 5; h++) {
- var c = t[o + h];
- if (c && null != (s = r(c[a]))) return s
- } else if (e === iI) {
- if (!l) return;
- for (h = 0; h < t.length && h < 5; h++)
- if ((d = t[h]) && null != (s = r(d[l]))) return s
- } else if (e === nI) {
- if (!l) return;
- if (!(u = t[l]) || S(u)) return !1;
- for (h = 0; h < u.length && h < 5; h++)
- if (null != (s = r(u[h]))) return s
- } else if (e === tI)
- for (h = 0; h < t.length && h < 5; h++) {
- var d = t[h],
- f = Li(d);
- if (!y(f)) return !1;
- if (null != (s = r(f[a]))) return s
- }
- return !1
- }
- function La(t, e) {
- if (e) {
- var i = e.seiresIndex,
- n = e.seriesId,
- o = e.seriesName;
- return null != i && t.componentIndex !== i || null != n && t.id !== n || null != o && t.name !== o
- }
- }
- function ka(t, e) {
- var o = t.color && !t.colorLayer;
- d(e, function(e, a) {
- "colorLayer" === a && o || YM.hasClass(a) || ("object" == typeof e ? t[a] = t[a] ? n(t[a], e, !1) : i(e) : null ==
- t[a] && (t[a] = e))
- })
- }
- function Pa(t) {
- t = t, this.option = {}, this.option[uI] = 1, this._componentsMap = R({
- series: []
- }), this._seriesIndices, this._seriesIndicesMap, ka(t, this._theme.option), n(t, KM, !1), this.mergeOption(t)
- }
- function Na(t, e) {
- y(e) || (e = e ? [e] : []);
- var i = {};
- return d(e, function(e) {
- i[e] = (t.get(e) || []).slice()
- }), i
- }
- function Oa(t, e, i) {
- return e.type ? e.type : i ? i.subType : YM.determineSubType(t, e)
- }
- function Ea(t, e) {
- t._seriesIndicesMap = R(t._seriesIndices = f(e, function(t) {
- return t.componentIndex
- }) || [])
- }
- function Ra(t, e) {
- return e.hasOwnProperty("subType") ? g(t, function(t) {
- return t.subType === e.subType
- }) : t
- }
- function za(t) {
- d(cI, function(e) {
- this[e] = m(t[e], t)
- }, this)
- }
- function Ba() {
- this._coordinateSystems = []
- }
- function Va(t) {
- this._api = t, this._timelineOptions = [], this._mediaList = [], this._mediaDefault, this._currentMediaIndices = [],
- this._optionBackup, this._newBaseOption
- }
- function Ga(t, e, i) {
- var n, o, a = [],
- r = [],
- s = t.timeline;
- if (t.baseOption && (o = t.baseOption), (s || t.options) && (o = o || {}, a = (t.options || []).slice()), t.media) {
- o = o || {};
- var l = t.media;
- fI(l, function(t) {
- t && t.option && (t.query ? r.push(t) : n || (n = t))
- })
- }
- return o || (o = t), o.timeline || (o.timeline = s), fI([o].concat(a).concat(f(r, function(t) {
- return t.option
- })), function(t) {
- fI(e, function(e) {
- e(t, i)
- })
- }), {
- baseOption: o,
- timelineOptions: a,
- mediaDefault: n,
- mediaList: r
- }
- }
- function Fa(t, e, i) {
- var n = {
- width: e,
- height: i,
- aspectratio: e / i
- },
- o = !0;
- return d(t, function(t, e) {
- var i = e.match(vI);
- if (i && i[1] && i[2]) {
- var a = i[1],
- r = i[2].toLowerCase();
- Wa(n[r], t, a) || (o = !1)
- }
- }), o
- }
- function Wa(t, e, i) {
- return "min" === i ? t >= e : "max" === i ? t <= e : t === e
- }
- function Ha(t, e) {
- return t.join(",") === e.join(",")
- }
- function Za(t, e) {
- fI(e = e || {}, function(e, i) {
- if (null != e) {
- var n = t[i];
- if (YM.hasClass(i)) {
- e = Di(e);
- var o = Pi(n = Di(n), e);
- t[i] = gI(o, function(t) {
- return t.option && t.exist ? mI(t.exist, t.option, !0) : t.exist || t.option
- })
- } else t[i] = mI(n, e, !0)
- }
- })
- }
- function Ua(t) {
- var e = t && t.itemStyle;
- if (e)
- for (var i = 0, o = _I.length; i < o; i++) {
- var a = _I[i],
- r = e.normal,
- s = e.emphasis;
- r && r[a] && (t[a] = t[a] || {}, t[a].normal ? n(t[a].normal, r[a]) : t[a].normal = r[a], r[a] = null), s && s[a] &&
- (t[a] = t[a] || {}, t[a].emphasis ? n(t[a].emphasis, s[a]) : t[a].emphasis = s[a], s[a] = null)
- }
- }
- function Xa(t, e, i) {
- if (t && t[e] && (t[e].normal || t[e].emphasis)) {
- var n = t[e].normal,
- o = t[e].emphasis;
- n && (i ? (t[e].normal = t[e].emphasis = null, r(t[e], n)) : t[e] = n), o && (t.emphasis = t.emphasis || {}, t.emphasis[
- e] = o)
- }
- }
- function ja(t) {
- Xa(t, "itemStyle"), Xa(t, "lineStyle"), Xa(t, "areaStyle"), Xa(t, "label"), Xa(t, "labelLine"), Xa(t, "upperLabel"),
- Xa(t, "edgeLabel")
- }
- function Ya(t, e) {
- var i = xI(t) && t[e],
- n = xI(i) && i.textStyle;
- if (n)
- for (var o = 0, a = zb.length; o < a; o++) {
- var e = zb[o];
- n.hasOwnProperty(e) && (i[e] = n[e])
- }
- }
- function qa(t) {
- t && (ja(t), Ya(t, "label"), t.emphasis && Ya(t.emphasis, "label"))
- }
- function Ka(t) {
- if (xI(t)) {
- Ua(t), ja(t), Ya(t, "label"), Ya(t, "upperLabel"), Ya(t, "edgeLabel"), t.emphasis && (Ya(t.emphasis, "label"), Ya(t
- .emphasis, "upperLabel"), Ya(t.emphasis, "edgeLabel"));
- var e = t.markPoint;
- e && (Ua(e), qa(e));
- var i = t.markLine;
- i && (Ua(i), qa(i));
- var n = t.markArea;
- n && qa(n);
- var o = t.data;
- if ("graph" === t.type) {
- o = o || t.nodes;
- var a = t.links || t.edges;
- if (a && !S(a))
- for (s = 0; s < a.length; s++) qa(a[s]);
- d(t.categories, function(t) {
- ja(t)
- })
- }
- if (o && !S(o))
- for (s = 0; s < o.length; s++) qa(o[s]);
- if ((e = t.markPoint) && e.data)
- for (var r = e.data, s = 0; s < r.length; s++) qa(r[s]);
- if ((i = t.markLine) && i.data)
- for (var l = i.data, s = 0; s < l.length; s++) y(l[s]) ? (qa(l[s][0]), qa(l[s][1])) : qa(l[s]);
- "gauge" === t.type ? (Ya(t, "axisLabel"), Ya(t, "title"), Ya(t, "detail")) : "treemap" === t.type ? (Xa(t.breadcrumb,
- "itemStyle"), d(t.levels, function(t) {
- ja(t)
- })) : "tree" === t.type && ja(t.leaves)
- }
- }
- function $a(t) {
- return y(t) ? t : t ? [t] : []
- }
- function Ja(t) {
- return (y(t) ? t[0] : t) || {}
- }
- function Qa(t, e) {
- e = e.split(",");
- for (var i = t, n = 0; n < e.length && null != (i = i && i[e[n]]); n++);
- return i
- }
- function tr(t, e, i, n) {
- e = e.split(",");
- for (var o, a = t, r = 0; r < e.length - 1; r++) null == a[o = e[r]] && (a[o] = {}), a = a[o];
- (n || null == a[e[r]]) && (a[e[r]] = i)
- }
- function er(t) {
- d(bI, function(e) {
- e[0] in t && !(e[1] in t) && (t[e[1]] = t[e[0]])
- })
- }
- function ir(t) {
- d(t, function(e, i) {
- var n = [],
- o = [NaN, NaN],
- a = [e.stackResultDimension, e.stackedOverDimension],
- r = e.data,
- s = e.isStackedByIndex,
- l = r.map(a, function(a, l, u) {
- var h = r.get(e.stackedDimension, u);
- if (isNaN(h)) return o;
- var c, d;
- s ? d = r.getRawIndex(u) : c = r.get(e.stackedByDimension, u);
- for (var f = NaN, p = i - 1; p >= 0; p--) {
- var g = t[p];
- if (s || (d = g.data.rawIndexOf(g.stackedByDimension, c)), d >= 0) {
- var m = g.data.getByRawIndex(g.stackResultDimension, d);
- if (h >= 0 && m > 0 || h <= 0 && m < 0) {
- h += m, f = m;
- break
- }
- }
- }
- return n[0] = h, n[1] = f, n
- });
- r.hostModel.setData(l), e.data = l
- })
- }
- function nr(t, e) {
- va.isInstance(t) || (t = va.seriesDataToSource(t)), this._source = t;
- var i = this._data = t.data,
- n = t.sourceFormat;
- n === aI && (this._offset = 0, this._dimSize = e, this._data = i), a(this, TI[n === eI ? n + "_" + t.seriesLayoutBy :
- n])
- }
- function or() {
- return this._data.length
- }
- function ar(t) {
- return this._data[t]
- }
- function rr(t) {
- for (var e = 0; e < t.length; e++) this._data.push(t[e])
- }
- function sr(t, e, i, n) {
- return null != i ? t[i] : t
- }
- function lr(t, e, i, n) {
- return ur(t[n], this._dimensionInfos[e])
- }
- function ur(t, e) {
- var i = e && e.type;
- if ("ordinal" === i) {
- var n = e && e.ordinalMeta;
- return n ? n.parseAndCollect(t) : t
- }
- return "time" === i && "number" != typeof t && null != t && "-" !== t && (t = +Uo(t)), null == t || "" === t ? NaN :
- +t
- }
- function hr(t, e, i) {
- if (t) {
- var n = t.getRawDataItem(e);
- if (null != n) {
- var o, a, r = t.getProvider().getSource().sourceFormat,
- s = t.getDimensionInfo(i);
- return s && (o = s.name, a = s.index), AI[r](n, e, a, o)
- }
- }
- }
- function cr(t, e, i) {
- if (t) {
- var n = t.getProvider().getSource().sourceFormat;
- if (n === tI || n === iI) {
- var o = t.getRawDataItem(e);
- return n !== tI || w(o) || (o = null), o ? o[i] : void 0
- }
- }
- }
- function dr(t) {
- return new fr(t)
- }
- function fr(t) {
- t = t || {}, this._reset = t.reset, this._plan = t.plan, this._count = t.count, this._onDirty = t.onDirty, this._dirty = !
- 0, this.context
- }
- function pr(t, e, i, n, o, a) {
- PI.reset(i, n, o, a), t._callingProgress = e, t._callingProgress({
- start: i,
- end: n,
- count: n - i,
- next: PI.next
- }, t.context)
- }
- function gr(t, e) {
- t._dueIndex = t._outputDueEnd = t._dueEnd = 0, t._settedOutputEnd = null;
- var i, n;
- !e && t._reset && ((i = t._reset(t.context)) && i.progress && (n = i.forceFirstProgress, i = i.progress), y(i) && !i
- .length && (i = null)), t._progress = i, t._modBy = t._modDataCount = null;
- var o = t._downstream;
- return o && o.dirty(), n
- }
- function mr(t) {
- var e = t.name;
- Oi(t) || (t.name = vr(t) || e)
- }
- function vr(t) {
- var e = t.getRawData(),
- i = [];
- return d(e.mapDimension("seriesName", !0), function(t) {
- var n = e.getDimensionInfo(t);
- n.displayName && i.push(n.displayName)
- }), i.join(" ")
- }
- function yr(t) {
- return t.model.getRawData().count()
- }
- function xr(t) {
- var e = t.model;
- return e.setData(e.getRawData().cloneShallow()), _r
- }
- function _r(t, e) {
- t.end > e.outputData.count() && e.model.getRawData().cloneShallow(e.outputData)
- }
- function wr(t, e) {
- d(t.CHANGABLE_METHODS, function(i) {
- t.wrapMethod(i, v(br, e))
- })
- }
- function br(t) {
- var e = Sr(t);
- e && e.setOutputEnd(this.count())
- }
- function Sr(t) {
- var e = (t.ecModel || {}).scheduler,
- i = e && e.getPipeline(t.uid);
- if (i) {
- var n = i.currentTask;
- if (n) {
- var o = n.agentStubMap;
- o && (n = o.get(t.uid))
- }
- return n
- }
- }
- function Mr() {
- this.group = new Zw, this.uid = No("viewChart"), this.renderTask = dr({
- plan: Ar,
- reset: Dr
- }), this.renderTask.context = {
- view: this
- }
- }
- function Ir(t, e) {
- if (t && (t.trigger(e), "group" === t.type))
- for (var i = 0; i < t.childCount(); i++) Ir(t.childAt(i), e)
- }
- function Tr(t, e, i) {
- var n = zi(t, e);
- null != n ? d(Di(n), function(e) {
- Ir(t.getItemGraphicEl(e), i)
- }) : t.eachItemGraphicEl(function(t) {
- Ir(t, i)
- })
- }
- function Ar(t) {
- return VI(t.model)
- }
- function Dr(t) {
- var e = t.model,
- i = t.ecModel,
- n = t.api,
- o = t.payload,
- a = e.pipelineContext.progressiveRender,
- r = t.view,
- s = o && BI(o).updateMethod,
- l = a ? "incrementalPrepareRender" : s && r[s] ? s : "render";
- return "render" !== l && r[l](e, i, n, o), FI[l]
- }
- function Cr(t, e, i) {
- function n() {
- h = (new Date).getTime(), c = null, t.apply(r, s || [])
- }
- var o, a, r, s, l, u = 0,
- h = 0,
- c = null;
- e = e || 0;
- var d = function() {
- o = (new Date).getTime(), r = this, s = arguments;
- var t = l || e,
- d = l || i;
- l = null, a = o - (d ? u : h) - t, clearTimeout(c), d ? c = setTimeout(n, t) : a >= 0 ? n() : c = setTimeout(n, -a),
- u = o
- };
- return d.clear = function() {
- c && (clearTimeout(c), c = null)
- }, d.debounceNextCall = function(t) {
- l = t
- }, d
- }
- function Lr(t, e, i, n) {
- var o = t[e];
- if (o) {
- var a = o[WI] || o,
- r = o[ZI];
- if (o[HI] !== i || r !== n) {
- if (null == i || !n) return t[e] = a;
- (o = t[e] = Cr(a, i, "debounce" === n))[WI] = a, o[ZI] = n, o[HI] = i
- }
- return o
- }
- }
- function kr(t, e) {
- var i = t[e];
- i && i[WI] && (t[e] = i[WI])
- }
- function Pr(t, e, i, n) {
- this.ecInstance = t, this.api = e, this.unfinished;
- var i = this._dataProcessorHandlers = i.slice(),
- n = this._visualHandlers = n.slice();
- this._allHandlers = i.concat(n), this._stageTaskMap = R()
- }
- function Nr(t, e, i, n, o) {
- function a(t, e) {
- return t.setDirty && (!t.dirtyMap || t.dirtyMap.get(e.__pipeline.id))
- }
- o = o || {};
- var r;
- d(e, function(e, s) {
- if (!o.visualType || o.visualType === e.visualType) {
- var l = t._stageTaskMap.get(e.uid),
- u = l.seriesTaskMap,
- h = l.overallTask;
- if (h) {
- var c, d = h.agentStubMap;
- d.each(function(t) {
- a(o, t) && (t.dirty(), c = !0)
- }), c && h.dirty(), KI(h, n);
- var f = t.getPerformArgs(h, o.block);
- d.each(function(t) {
- t.perform(f)
- }), r |= h.perform(f)
- } else u && u.each(function(s, l) {
- a(o, s) && s.dirty();
- var u = t.getPerformArgs(s, o.block);
- u.skip = !e.performRawSeries && i.isSeriesFiltered(s.context.model), KI(s, n), r |= s.perform(u)
- })
- }
- }), t.unfinished |= r
- }
- function Or(t, e, i, n, o) {
- function a(i) {
- var a = i.uid,
- s = r.get(a) || r.set(a, dr({
- plan: Gr,
- reset: Fr,
- count: Hr
- }));
- s.context = {
- model: i,
- ecModel: n,
- api: o,
- useClearVisual: e.isVisual && !e.isLayout,
- plan: e.plan,
- reset: e.reset,
- scheduler: t
- }, Zr(t, i, s)
- }
- var r = i.seriesTaskMap || (i.seriesTaskMap = R()),
- s = e.seriesType,
- l = e.getTargetSeries;
- e.createOnAllSeries ? n.eachRawSeries(a) : s ? n.eachRawSeriesByType(s, a) : l && l(n, o).each(a);
- var u = t._pipelineMap;
- r.each(function(t, e) {
- u.get(e) || (t.dispose(), r.removeKey(e))
- })
- }
- function Er(t, e, i, n, o) {
- function a(e) {
- var i = e.uid,
- n = s.get(i);
- n || (n = s.set(i, dr({
- reset: zr,
- onDirty: Vr
- })), r.dirty()), n.context = {
- model: e,
- overallProgress: h,
- modifyOutputEnd: c
- }, n.agent = r, n.__block = h, Zr(t, e, n)
- }
- var r = i.overallTask = i.overallTask || dr({
- reset: Rr
- });
- r.context = {
- ecModel: n,
- api: o,
- overallReset: e.overallReset,
- scheduler: t
- };
- var s = r.agentStubMap = r.agentStubMap || R(),
- l = e.seriesType,
- u = e.getTargetSeries,
- h = !0,
- c = e.modifyOutputEnd;
- l ? n.eachRawSeriesByType(l, a) : u ? u(n, o).each(a) : (h = !1, d(n.getSeries(), a));
- var f = t._pipelineMap;
- s.each(function(t, e) {
- f.get(e) || (t.dispose(), r.dirty(), s.removeKey(e))
- })
- }
- function Rr(t) {
- t.overallReset(t.ecModel, t.api, t.payload)
- }
- function zr(t, e) {
- return t.overallProgress && Br
- }
- function Br() {
- this.agent.dirty(), this.getDownstream().dirty()
- }
- function Vr() {
- this.agent && this.agent.dirty()
- }
- function Gr(t) {
- return t.plan && t.plan(t.model, t.ecModel, t.api, t.payload)
- }
- function Fr(t) {
- t.useClearVisual && t.data.clearAllVisual();
- var e = t.resetDefines = Di(t.reset(t.model, t.ecModel, t.api, t.payload));
- return e.length > 1 ? f(e, function(t, e) {
- return Wr(e)
- }) : $I
- }
- function Wr(t) {
- return function(e, i) {
- var n = i.data,
- o = i.resetDefines[t];
- if (o && o.dataEach)
- for (var a = e.start; a < e.end; a++) o.dataEach(n, a);
- else o && o.progress && o.progress(e, n)
- }
- }
- function Hr(t) {
- return t.data.count()
- }
- function Zr(t, e, i) {
- var n = e.uid,
- o = t._pipelineMap.get(n);
- !o.head && (o.head = i), o.tail && o.tail.pipe(i), o.tail = i, i.__idxInPipeline = o.count++, i.__pipeline = o
- }
- function Ur(t) {
- JI = null;
- try {
- t(QI, tT)
- } catch (t) {}
- return JI
- }
- function Xr(t, e) {
- for (var i in e.prototype) t[i] = B
- }
- function jr(t) {
- for (_(t) && (t = (new DOMParser).parseFromString(t, "text/xml")), 9 === t.nodeType && (t = t.firstChild);
- "svg" !== t.nodeName.toLowerCase() || 1 !== t.nodeType;) t = t.nextSibling;
- return t
- }
- function Yr() {
- this._defs = {}, this._root = null, this._isDefine = !1, this._isText = !1
- }
- function qr(t, e) {
- for (var i = t.firstChild; i;) {
- if (1 === i.nodeType) {
- var n = i.getAttribute("offset");
- n = n.indexOf("%") > 0 ? parseInt(n, 10) / 100 : n ? parseFloat(n) : 0;
- var o = i.getAttribute("stop-color") || "#000000";
- e.addColorStop(n, o)
- }
- i = i.nextSibling
- }
- }
- function Kr(t, e) {
- t && t.__inheritedStyle && (e.__inheritedStyle || (e.__inheritedStyle = {}), r(e.__inheritedStyle, t.__inheritedStyle))
- }
- function $r(t) {
- for (var e = P(t).split(rT), i = [], n = 0; n < e.length; n += 2) {
- var o = parseFloat(e[n]),
- a = parseFloat(e[n + 1]);
- i.push([o, a])
- }
- return i
- }
- function Jr(t, e, i, n) {
- var o = e.__inheritedStyle || {},
- r = "text" === e.type;
- if (1 === t.nodeType && (ts(t, e), a(o, es(t)), !n))
- for (var s in uT)
- if (uT.hasOwnProperty(s)) {
- var l = t.getAttribute(s);
- null != l && (o[uT[s]] = l)
- } var u = r ? "textFill" : "fill",
- h = r ? "textStroke" : "stroke";
- e.style = e.style || new $w;
- var c = e.style;
- null != o.fill && c.set(u, Qr(o.fill, i)), null != o.stroke && c.set(h, Qr(o.stroke, i)), d(["lineWidth", "opacity",
- "fillOpacity", "strokeOpacity", "miterLimit", "fontSize"
- ], function(t) {
- var e = "lineWidth" === t && r ? "textStrokeWidth" : t;
- null != o[t] && c.set(e, parseFloat(o[t]))
- }), o.textBaseline && "auto" !== o.textBaseline || (o.textBaseline = "alphabetic"), "alphabetic" === o.textBaseline &&
- (o.textBaseline = "bottom"), "start" === o.textAlign && (o.textAlign = "left"), "end" === o.textAlign && (o.textAlign =
- "right"), d(["lineDashOffset", "lineCap", "lineJoin", "fontWeight", "fontFamily", "fontStyle", "textAlign",
- "textBaseline"
- ], function(t) {
- null != o[t] && c.set(t, o[t])
- }), o.lineDash && (e.style.lineDash = P(o.lineDash).split(rT)), c[h] && "none" !== c[h] && (e[h] = !0), e.__inheritedStyle =
- o
- }
- function Qr(t, e) {
- var i = e && t && t.match(hT);
- return i ? e[P(i[1])] : t
- }
- function ts(t, e) {
- var i = t.getAttribute("transform");
- if (i) {
- var n = null,
- o = [];
- (i = i.replace(/,/g, " ")).replace(cT, function(t, e, i) {
- o.push(e, i)
- });
- for (var a = o.length - 1; a > 0; a -= 2) {
- var r = o[a],
- s = o[a - 1];
- switch (n = n || mt(), s) {
- case "translate":
- r = P(r).split(rT), _t(n, n, [parseFloat(r[0]), parseFloat(r[1] || 0)]);
- break;
- case "scale":
- r = P(r).split(rT), bt(n, n, [parseFloat(r[0]), parseFloat(r[1] || r[0])]);
- break;
- case "rotate":
- r = P(r).split(rT), wt(n, n, parseFloat(r[0]));
- break;
- case "skew":
- r = P(r).split(rT), console.warn("Skew transform is not supported yet");
- break;
- case "matrix":
- r = P(r).split(rT);
- n[0] = parseFloat(r[0]), n[1] = parseFloat(r[1]), n[2] = parseFloat(r[2]), n[3] = parseFloat(r[3]), n[4] =
- parseFloat(r[4]), n[5] = parseFloat(r[5])
- }
- }
- }
- e.setLocalTransform(n)
- }
- function es(t) {
- var e = t.getAttribute("style"),
- i = {};
- if (!e) return i;
- var n = {};
- dT.lastIndex = 0;
- for (var o; null != (o = dT.exec(e));) n[o[1]] = o[2];
- for (var a in uT) uT.hasOwnProperty(a) && null != n[a] && (i[uT[a]] = n[a]);
- return i
- }
- function is(t, e, i) {
- var n = e / t.width,
- o = i / t.height,
- a = Math.min(n, o);
- return {
- scale: [a, a],
- position: [-(t.x + t.width / 2) * a + e / 2, -(t.y + t.height / 2) * a + i / 2]
- }
- }
- function ns(t, e) {
- return (new Yr).parse(t, e)
- }
- function os(t) {
- return function(e, i, n) {
- e = e && e.toLowerCase(), aw.prototype[t].call(this, e, i, n)
- }
- }
- function as() {
- aw.call(this)
- }
- function rs(t, e, n) {
- function o(t, e) {
- return t.__prio - e.__prio
- }
- n = n || {}, "string" == typeof e && (e = BT[e]), this.id, this.group, this._dom = t;
- var a = this._zr = Ii(t, {
- renderer: n.renderer || "canvas",
- devicePixelRatio: n.devicePixelRatio,
- width: n.width,
- height: n.height
- });
- this._throttledZrFlush = Cr(m(a.flush, a), 17), (e = i(e)) && MI(e, !0), this._theme = e, this._chartsViews = [],
- this._chartsMap = {}, this._componentsViews = [], this._componentsMap = {}, this._coordSysMgr = new Ba;
- var r = this._api = Ms(this);
- ve(zT, o), ve(OT, o), this._scheduler = new Pr(this, r, OT, zT), aw.call(this, this._ecEventProcessor = new Is),
- this._messageCenter = new as, this._initEvents(), this.resize = m(this.resize, this), this._pendingActions = [], a.animation
- .on("frame", this._onframe, this), ps(a, this), N(this)
- }
- function ss(t, e, i) {
- var n, o = this._model,
- a = this._coordSysMgr.getCoordinateSystems();
- e = Vi(o, e);
- for (var r = 0; r < a.length; r++) {
- var s = a[r];
- if (s[t] && null != (n = s[t](o, e, i))) return n
- }
- }
- function ls(t) {
- var e = t._model,
- i = t._scheduler;
- i.restorePipelines(e), i.prepareStageTasks(), gs(t, "component", e, i), gs(t, "chart", e, i), i.plan()
- }
- function us(t, e, i, n, o) {
- function a(n) {
- n && n.__alive && n[e] && n[e](n.__model, r, t._api, i)
- }
- var r = t._model;
- if (n) {
- var s = {};
- s[n + "Id"] = i[n + "Id"], s[n + "Index"] = i[n + "Index"], s[n + "Name"] = i[n + "Name"];
- var l = {
- mainType: n,
- query: s
- };
- o && (l.subType = o);
- var u = i.excludeSeriesId;
- null != u && (u = R(Di(u))), r && r.eachComponent(l, function(e) {
- u && null != u.get(e.id) || a(t["series" === n ? "_chartsMap" : "_componentsMap"][e.__viewId])
- }, t)
- } else vT(t._componentsViews.concat(t._chartsViews), a)
- }
- function hs(t, e) {
- var i = t._chartsMap,
- n = t._scheduler;
- e.eachSeries(function(t) {
- n.updateStreamModes(t, i[t.__viewId])
- })
- }
- function cs(t, e) {
- var i = t.type,
- n = t.escapeConnect,
- o = PT[i],
- s = o.actionInfo,
- l = (s.update || "update").split(":"),
- u = l.pop();
- l = null != l[0] && _T(l[0]), this[TT] = !0;
- var h = [t],
- c = !1;
- t.batch && (c = !0, h = f(t.batch, function(e) {
- return e = r(a({}, e), t), e.batch = null, e
- }));
- var d, p = [],
- g = "highlight" === i || "downplay" === i;
- vT(h, function(t) {
- d = o.action(t, this._model, this._api), (d = d || a({}, t)).type = s.event || d.type, p.push(d), g ? us(this, u,
- t, "series") : l && us(this, u, t, l.main, l.sub)
- }, this), "none" === u || g || l || (this[AT] ? (ls(this), LT.update.call(this, t), this[AT] = !1) : LT[u].call(
- this, t)), d = c ? {
- type: s.event || i,
- escapeConnect: n,
- batch: p
- } : p[0], this[TT] = !1, !e && this._messageCenter.trigger(d.type, d)
- }
- function ds(t) {
- for (var e = this._pendingActions; e.length;) {
- var i = e.shift();
- cs.call(this, i, t)
- }
- }
- function fs(t) {
- !t && this.trigger("updated")
- }
- function ps(t, e) {
- t.on("rendered", function() {
- e.trigger("rendered"), !t.animation.isFinished() || e[AT] || e._scheduler.unfinished || e._pendingActions.length ||
- e.trigger("finished")
- })
- }
- function gs(t, e, i, n) {
- function o(t) {
- var e = "_ec_" + t.id + "_" + t.type,
- o = s[e];
- if (!o) {
- var h = _T(t.type);
- (o = new(a ? EI.getClass(h.main, h.sub) : Mr.getClass(h.sub))).init(i, u), s[e] = o, r.push(o), l.add(o.group)
- }
- t.__viewId = o.__id = e, o.__alive = !0, o.__model = t, o.group.__ecComponentInfo = {
- mainType: t.mainType,
- index: t.componentIndex
- }, !a && n.prepareView(o, t, i, u)
- }
- for (var a = "component" === e, r = a ? t._componentsViews : t._chartsViews, s = a ? t._componentsMap : t._chartsMap,
- l = t._zr, u = t._api, h = 0; h < r.length; h++) r[h].__alive = !1;
- a ? i.eachComponent(function(t, e) {
- "series" !== t && o(e)
- }) : i.eachSeries(o);
- for (h = 0; h < r.length;) {
- var c = r[h];
- c.__alive ? h++ : (!a && c.renderTask.dispose(), l.remove(c.group), c.dispose(i, u), r.splice(h, 1), delete s[c.__id],
- c.__id = c.group.__ecComponentInfo = null)
- }
- }
- function ms(t) {
- t.clearColorPalette(), t.eachSeries(function(t) {
- t.clearColorPalette()
- })
- }
- function vs(t, e, i, n) {
- ys(t, e, i, n), vT(t._chartsViews, function(t) {
- t.__alive = !1
- }), xs(t, e, i, n), vT(t._chartsViews, function(t) {
- t.__alive || t.remove(e, i)
- })
- }
- function ys(t, e, i, n, o) {
- vT(o || t._componentsViews, function(t) {
- var o = t.__model;
- t.render(o, e, i, n), Ss(o, t)
- })
- }
- function xs(t, e, i, n, o) {
- var a, r = t._scheduler;
- e.eachSeries(function(e) {
- var i = t._chartsMap[e.__viewId];
- i.__alive = !0;
- var s = i.renderTask;
- r.updatePayload(s, n), o && o.get(e.uid) && s.dirty(), a |= s.perform(r.getPerformArgs(s)), i.group.silent = !!e.get(
- "silent"), Ss(e, i), bs(e, i)
- }), r.unfinished |= a, ws(t._zr, e), jI(t._zr.dom, e)
- }
- function _s(t, e) {
- vT(RT, function(i) {
- i(t, e)
- })
- }
- function ws(t, e) {
- var i = t.storage,
- n = 0;
- i.traverse(function(t) {
- t.isGroup || n++
- }), n > e.get("hoverLayerThreshold") && !z_.node && i.traverse(function(t) {
- t.isGroup || (t.useHoverLayer = !0)
- })
- }
- function bs(t, e) {
- var i = t.get("blendMode") || null;
- e.group.traverse(function(t) {
- t.isGroup || t.style.blend !== i && t.setStyle("blend", i), t.eachPendingDisplayable && t.eachPendingDisplayable(
- function(t) {
- t.setStyle("blend", i)
- })
- })
- }
- function Ss(t, e) {
- var i = t.get("z"),
- n = t.get("zlevel");
- e.group.traverse(function(t) {
- "group" !== t.type && (null != i && (t.z = i), null != n && (t.zlevel = n))
- })
- }
- function Ms(t) {
- var e = t._coordSysMgr;
- return a(new za(t), {
- getCoordinateSystems: m(e.getCoordinateSystems, e),
- getComponentByElement: function(e) {
- for (; e;) {
- var i = e.__ecComponentInfo;
- if (null != i) return t._model.getComponent(i.mainType, i.index);
- e = e.parent
- }
- }
- })
- }
- function Is() {
- this.eventInfo
- }
- function Ts(t) {
- function e(t, e) {
- for (var n = 0; n < t.length; n++) t[n][i] = e
- }
- var i = "__connectUpdateStatus";
- vT(NT, function(n, o) {
- t._messageCenter.on(o, function(n) {
- if (FT[t.group] && 0 !== t[i]) {
- if (n && n.escapeConnect) return;
- var o = t.makeActionFromEvent(n),
- a = [];
- vT(GT, function(e) {
- e !== t && e.group === t.group && a.push(e)
- }), e(a, 0), vT(a, function(t) {
- 1 !== t[i] && t.dispatchAction(o)
- }), e(a, 2)
- }
- })
- })
- }
- function As(t) {
- FT[t] = !1
- }
- function Ds(t) {
- return GT[Wi(t, ZT)]
- }
- function Cs(t, e) {
- BT[t] = e
- }
- function Ls(t) {
- ET.push(t)
- }
- function ks(t, e) {
- Rs(OT, t, e, bT)
- }
- function Ps(t, e, i) {
- "function" == typeof e && (i = e, e = "");
- var n = xT(t) ? t.type : [t, t = {
- event: e
- }][0];
- t.event = (t.event || n).toLowerCase(), e = t.event, mT(DT.test(n) && DT.test(e)), PT[n] || (PT[n] = {
- action: i,
- actionInfo: t
- }), NT[e] = n
- }
- function Ns(t, e) {
- Ba.register(t, e)
- }
- function Os(t, e) {
- Rs(zT, t, e, ST, "layout")
- }
- function Es(t, e) {
- Rs(zT, t, e, MT, "visual")
- }
- function Rs(t, e, i, n, o) {
- (yT(e) || xT(e)) && (i = e, e = n);
- var a = Pr.wrapStageHandler(i, o);
- return a.__prio = e, a.__raw = i, t.push(a), a
- }
- function zs(t, e) {
- VT[t] = e
- }
- function Bs(t) {
- return YM.extend(t)
- }
- function Vs(t) {
- return EI.extend(t)
- }
- function Gs(t) {
- return OI.extend(t)
- }
- function Fs(t) {
- return Mr.extend(t)
- }
- function Ws(t) {
- return t
- }
- function Hs(t, e, i, n, o) {
- this._old = t, this._new = e, this._oldKeyGetter = i || Ws, this._newKeyGetter = n || Ws, this.context = o
- }
- function Zs(t, e, i, n, o) {
- for (var a = 0; a < t.length; a++) {
- var r = "_ec_" + o[n](t[a], a),
- s = e[r];
- null == s ? (i.push(r), e[r] = a) : (s.length || (e[r] = s = [s]), s.push(a))
- }
- }
- function Us(t) {
- var e = {},
- i = e.encode = {},
- n = R(),
- o = [],
- a = [];
- d(t.dimensions, function(e) {
- var r = t.getDimensionInfo(e),
- s = r.coordDim;
- if (s) {
- var l = i[s];
- i.hasOwnProperty(s) || (l = i[s] = []), l[r.coordDimIndex] = e, r.isExtraCoord || (n.set(s, 1), js(r.type) && (o[
- 0] = e)), r.defaultTooltip && a.push(e)
- }
- jT.each(function(t, e) {
- var n = i[e];
- i.hasOwnProperty(e) || (n = i[e] = []);
- var o = r.otherDims[e];
- null != o && !1 !== o && (n[o] = r.name)
- })
- });
- var r = [],
- s = {};
- n.each(function(t, e) {
- var n = i[e];
- s[e] = n[0], r = r.concat(n)
- }), e.dataDimsOnCoord = r, e.encodeFirstDimNotExtra = s;
- var l = i.label;
- l && l.length && (o = l.slice());
- var u = i.tooltip;
- return u && u.length ? a = u.slice() : a.length || (a = o.slice()), i.defaultedLabel = o, i.defaultedTooltip = a, e
- }
- function Xs(t) {
- return "category" === t ? "ordinal" : "time" === t ? "time" : "float"
- }
- function js(t) {
- return !("ordinal" === t || "time" === t)
- }
- function Ys(t) {
- return t._rawCount > 65535 ? $T : JT
- }
- function qs(t) {
- var e = t.constructor;
- return e === Array ? t.slice() : new e(t)
- }
- function Ks(t, e) {
- d(QT.concat(e.__wrappedMethods || []), function(i) {
- e.hasOwnProperty(i) && (t[i] = e[i])
- }), t.__wrappedMethods = e.__wrappedMethods, d(tA, function(n) {
- t[n] = i(e[n])
- }), t._calculationInfo = a(e._calculationInfo)
- }
- function $s(t) {
- var e = t._invertedIndicesMap;
- d(e, function(i, n) {
- var o = t._dimensionInfos[n].ordinalMeta;
- if (o) {
- i = e[n] = new $T(o.categories.length);
- for (a = 0; a < i.length; a++) i[a] = NaN;
- for (var a = 0; a < t._count; a++) i[t.get(n, a)] = a
- }
- })
- }
- function Js(t, e, i) {
- var n;
- if (null != e) {
- var o = t._chunkSize,
- a = Math.floor(i / o),
- r = i % o,
- s = t.dimensions[e],
- l = t._storage[s][a];
- if (l) {
- n = l[r];
- var u = t._dimensionInfos[s].ordinalMeta;
- u && u.categories.length && (n = u.categories[n])
- }
- }
- return n
- }
- function Qs(t) {
- return t
- }
- function tl(t) {
- return t < this._count && t >= 0 ? this._indices[t] : -1
- }
- function el(t, e) {
- var i = t._idList[e];
- return null == i && (i = Js(t, t._idDimIdx, e)), null == i && (i = qT + e), i
- }
- function il(t) {
- return y(t) || (t = [t]), t
- }
- function nl(t, e) {
- var i = t.dimensions,
- n = new eA(f(i, t.getDimensionInfo, t), t.hostModel);
- Ks(n, t);
- for (var o = n._storage = {}, a = t._storage, r = 0; r < i.length; r++) {
- var s = i[r];
- a[s] && (l(e, s) >= 0 ? (o[s] = ol(a[s]), n._rawExtent[s] = al(), n._extent[s] = null) : o[s] = a[s])
- }
- return n
- }
- function ol(t) {
- for (var e = new Array(t.length), i = 0; i < t.length; i++) e[i] = qs(t[i]);
- return e
- }
- function al() {
- return [1 / 0, -1 / 0]
- }
- function rl(t, e, n) {
- function o(t, e, i) {
- null != jT.get(e) ? t.otherDims[e] = i : (t.coordDim = e, t.coordDimIndex = i, h.set(e, !0))
- }
- va.isInstance(e) || (e = va.seriesDataToSource(e)), n = n || {}, t = (t || []).slice();
- for (var s = (n.dimsDef || []).slice(), l = R(n.encodeDef), u = R(), h = R(), c = [], f = sl(e, t, s, n.dimCount), p =
- 0; p < f; p++) {
- var g = s[p] = a({}, w(s[p]) ? s[p] : {
- name: s[p]
- }),
- m = g.name,
- v = c[p] = {
- otherDims: {}
- };
- null != m && null == u.get(m) && (v.name = v.displayName = m, u.set(m, p)), null != g.type && (v.type = g.type),
- null != g.displayName && (v.displayName = g.displayName)
- }
- l.each(function(t, e) {
- if (1 === (t = Di(t).slice()).length && t[0] < 0) l.set(e, !1);
- else {
- var i = l.set(e, []);
- d(t, function(t, n) {
- _(t) && (t = u.get(t)), null != t && t < f && (i[n] = t, o(c[t], e, n))
- })
- }
- });
- var y = 0;
- d(t, function(t, e) {
- var n, t, a, s;
- if (_(t)) n = t, t = {};
- else {
- n = t.name;
- var u = t.ordinalMeta;
- t.ordinalMeta = null, (t = i(t)).ordinalMeta = u, a = t.dimsDef, s = t.otherDims, t.name = t.coordDim = t.coordDimIndex =
- t.dimsDef = t.otherDims = null
- }
- var h = l.get(n);
- if (!1 !== h) {
- if (!(h = Di(h)).length)
- for (var f = 0; f < (a && a.length || 1); f++) {
- for (; y < c.length && null != c[y].coordDim;) y++;
- y < c.length && h.push(y++)
- }
- d(h, function(e, i) {
- var l = c[e];
- if (o(r(l, t), n, i), null == l.name && a) {
- var u = a[i];
- !w(u) && (u = {
- name: u
- }), l.name = l.displayName = u.name, l.defaultTooltip = u.defaultTooltip
- }
- s && r(l.otherDims, s)
- })
- }
- });
- var x = n.generateCoord,
- b = n.generateCoordCount,
- S = null != b;
- b = x ? b || 1 : 0;
- for (var M = x || "value", I = 0; I < f; I++) null == (v = c[I] = c[I] || {}).coordDim && (v.coordDim = ll(M, h, S),
- v.coordDimIndex = 0, (!x || b <= 0) && (v.isExtraCoord = !0), b--), null == v.name && (v.name = ll(v.coordDim, u)),
- null == v.type && Da(e, I, v.name) && (v.type = "ordinal");
- return c
- }
- function sl(t, e, i, n) {
- var o = Math.max(t.dimensionsDetectCount || 1, e.length, i.length, n || 0);
- return d(e, function(t) {
- var e = t.dimsDef;
- e && (o = Math.max(o, e.length))
- }), o
- }
- function ll(t, e, i) {
- if (i || null != e.get(t)) {
- for (var n = 0; null != e.get(t + n);) n++;
- t += n
- }
- return e.set(t, !0), t
- }
- function ul(t, e, i) {
- var n, o, a, r, s = (i = i || {}).byIndex,
- l = i.stackedCoordDimension,
- u = !(!t || !t.get("stack"));
- if (d(e, function(t, i) {
- _(t) && (e[i] = t = {
- name: t
- }), u && !t.isExtraCoord && (s || n || !t.ordinalMeta || (n = t), o || "ordinal" === t.type || "time" === t.type ||
- l && l !== t.coordDim || (o = t))
- }), !o || s || n || (s = !0), o) {
- a = "__\0ecstackresult", r = "__\0ecstackedover", n && (n.createInvertedIndices = !0);
- var h = o.coordDim,
- c = o.type,
- f = 0;
- d(e, function(t) {
- t.coordDim === h && f++
- }), e.push({
- name: a,
- coordDim: h,
- coordDimIndex: f,
- type: c,
- isExtraCoord: !0,
- isCalculationCoord: !0
- }), f++, e.push({
- name: r,
- coordDim: r,
- coordDimIndex: f,
- type: c,
- isExtraCoord: !0,
- isCalculationCoord: !0
- })
- }
- return {
- stackedDimension: o && o.name,
- stackedByDimension: n && n.name,
- isStackedByIndex: s,
- stackedOverDimension: r,
- stackResultDimension: a
- }
- }
- function hl(t, e) {
- return !!e && e === t.getCalculationInfo("stackedDimension")
- }
- function cl(t, e) {
- return hl(t, e) ? t.getCalculationInfo("stackResultDimension") : e
- }
- function dl(t, e, i) {
- i = i || {}, va.isInstance(t) || (t = va.seriesDataToSource(t));
- var n, o = e.get("coordinateSystem"),
- a = Ba.get(o),
- r = ga(e);
- r && (n = f(r.coordSysDims, function(t) {
- var e = {
- name: t
- },
- i = r.axisMap.get(t);
- if (i) {
- var n = i.get("type");
- e.type = Xs(n)
- }
- return e
- })), n || (n = a && (a.getDimensionsInfo ? a.getDimensionsInfo() : a.dimensions.slice()) || ["x", "y"]);
- var s, l, u = oA(t, {
- coordDimensions: n,
- generateCoord: i.generateCoord
- });
- r && d(u, function(t, e) {
- var i = t.coordDim,
- n = r.categoryAxisMap.get(i);
- n && (null == s && (s = e), t.ordinalMeta = n.getOrdinalMeta()), null != t.otherDims.itemName && (l = !0)
- }), l || null == s || (u[s].otherDims.itemName = 0);
- var h = ul(e, u),
- c = new eA(u, e);
- c.setCalculationInfo(h);
- var p = null != s && fl(t) ? function(t, e, i, n) {
- return n === s ? i : this.defaultDimValueGetter(t, e, i, n)
- } : null;
- return c.hasItemOption = !1, c.initData(t, null, p), c
- }
- function fl(t) {
- if (t.sourceFormat === tI) {
- var e = pl(t.data || []);
- return null != e && !y(Li(e))
- }
- }
- function pl(t) {
- for (var e = 0; e < t.length && null == t[e];) e++;
- return t[e]
- }
- function gl(t) {
- this._setting = t || {}, this._extent = [1 / 0, -1 / 0], this._interval = 0, this.init && this.init.apply(this,
- arguments)
- }
- function ml(t) {
- this.categories = t.categories || [], this._needCollect = t.needCollect, this._deduplication = t.deduplication, this
- ._map
- }
- function vl(t) {
- return t._map || (t._map = R(t.categories))
- }
- function yl(t) {
- return w(t) && null != t.value ? t.value : t + ""
- }
- function xl(t, e, i, n) {
- var o = {},
- a = t[1] - t[0],
- r = o.interval = Yo(a / e, !0);
- null != i && r < i && (r = o.interval = i), null != n && r > n && (r = o.interval = n);
- var s = o.intervalPrecision = _l(r);
- return bl(o.niceTickExtent = [lA(Math.ceil(t[0] / r) * r, s), lA(Math.floor(t[1] / r) * r, s)], t), o
- }
- function _l(t) {
- return Go(t) + 2
- }
- function wl(t, e, i) {
- t[e] = Math.max(Math.min(t[e], i[1]), i[0])
- }
- function bl(t, e) {
- !isFinite(t[0]) && (t[0] = e[0]), !isFinite(t[1]) && (t[1] = e[1]), wl(t, 0, e), wl(t, 1, e), t[0] > t[1] && (t[0] =
- t[1])
- }
- function Sl(t, e, i, n) {
- var o = [];
- if (!t) return o;
- e[0] < i[0] && o.push(e[0]);
- for (var a = i[0]; a <= i[1] && (o.push(a), (a = lA(a + t, n)) !== o[o.length - 1]);)
- if (o.length > 1e4) return [];
- return e[1] > (o.length ? o[o.length - 1] : i[1]) && o.push(e[1]), o
- }
- function Ml(t) {
- return t.get("stack") || cA + t.seriesIndex
- }
- function Il(t) {
- return t.dim + t.index
- }
- function Tl(t) {
- var e = [],
- i = t.axis;
- if ("category" === i.type) {
- for (var n = i.getBandWidth(), o = 0; o < t.count; o++) e.push(r({
- bandWidth: n,
- axisKey: "axis0",
- stackId: cA + o
- }, t));
- for (var a = Cl(e), s = [], o = 0; o < t.count; o++) {
- var l = a.axis0[cA + o];
- l.offsetCenter = l.offset + l.width / 2, s.push(l)
- }
- return s
- }
- }
- function Al(t, e) {
- var i = [];
- return e.eachSeriesByType(t, function(t) {
- Pl(t) && !Nl(t) && i.push(t)
- }), i
- }
- function Dl(t) {
- var e = [];
- return d(t, function(t) {
- var i = t.getData(),
- n = t.coordinateSystem.getBaseAxis(),
- o = n.getExtent(),
- a = "category" === n.type ? n.getBandWidth() : Math.abs(o[1] - o[0]) / i.count(),
- r = Ro(t.get("barWidth"), a),
- s = Ro(t.get("barMaxWidth"), a),
- l = t.get("barGap"),
- u = t.get("barCategoryGap");
- e.push({
- bandWidth: a,
- barWidth: r,
- barMaxWidth: s,
- barGap: l,
- barCategoryGap: u,
- axisKey: Il(n),
- stackId: Ml(t)
- })
- }), Cl(e)
- }
- function Cl(t) {
- var e = {};
- d(t, function(t, i) {
- var n = t.axisKey,
- o = t.bandWidth,
- a = e[n] || {
- bandWidth: o,
- remainedWidth: o,
- autoWidthCount: 0,
- categoryGap: "20%",
- gap: "30%",
- stacks: {}
- },
- r = a.stacks;
- e[n] = a;
- var s = t.stackId;
- r[s] || a.autoWidthCount++, r[s] = r[s] || {
- width: 0,
- maxWidth: 0
- };
- var l = t.barWidth;
- l && !r[s].width && (r[s].width = l, l = Math.min(a.remainedWidth, l), a.remainedWidth -= l);
- var u = t.barMaxWidth;
- u && (r[s].maxWidth = u);
- var h = t.barGap;
- null != h && (a.gap = h);
- var c = t.barCategoryGap;
- null != c && (a.categoryGap = c)
- });
- var i = {};
- return d(e, function(t, e) {
- i[e] = {};
- var n = t.stacks,
- o = t.bandWidth,
- a = Ro(t.categoryGap, o),
- r = Ro(t.gap, 1),
- s = t.remainedWidth,
- l = t.autoWidthCount,
- u = (s - a) / (l + (l - 1) * r);
- u = Math.max(u, 0), d(n, function(t, e) {
- var i = t.maxWidth;
- i && i < u && (i = Math.min(i, s), t.width && (i = Math.min(i, t.width)), s -= i, t.width = i, l--)
- }), u = (s - a) / (l + (l - 1) * r), u = Math.max(u, 0);
- var h, c = 0;
- d(n, function(t, e) {
- t.width || (t.width = u), h = t, c += t.width * (1 + r)
- }), h && (c -= h.width * r);
- var f = -c / 2;
- d(n, function(t, n) {
- i[e][n] = i[e][n] || {
- offset: f,
- width: t.width
- }, f += t.width * (1 + r)
- })
- }), i
- }
- function Ll(t, e, i) {
- if (t && e) {
- var n = t[Il(e)];
- return null != n && null != i && (n = n[Ml(i)]), n
- }
- }
- function kl(t, e) {
- var i = Al(t, e),
- n = Dl(i),
- o = {};
- d(i, function(t) {
- var e = t.getData(),
- i = t.coordinateSystem,
- a = i.getBaseAxis(),
- r = Ml(t),
- s = n[Il(a)][r],
- l = s.offset,
- u = s.width,
- h = i.getOtherAxis(a),
- c = t.get("barMinHeight") || 0;
- o[r] = o[r] || [], e.setLayout({
- offset: l,
- size: u
- });
- for (var d = e.mapDimension(h.dim), f = e.mapDimension(a.dim), p = hl(e, d), g = h.isHorizontal(), m = Ol(a, h, p),
- v = 0, y = e.count(); v < y; v++) {
- var x = e.get(d, v),
- _ = e.get(f, v);
- if (!isNaN(x)) {
- var w = x >= 0 ? "p" : "n",
- b = m;
- p && (o[r][_] || (o[r][_] = {
- p: m,
- n: m
- }), b = o[r][_][w]);
- var S, M, I, T;
- if (g) S = b, M = (A = i.dataToPoint([x, _]))[1] + l, I = A[0] - m, T = u, Math.abs(I) < c && (I = (I < 0 ? -1 :
- 1) * c), p && (o[r][_][w] += I);
- else {
- var A = i.dataToPoint([_, x]);
- S = A[0] + l, M = b, I = u, T = A[1] - m, Math.abs(T) < c && (T = (T <= 0 ? -1 : 1) * c), p && (o[r][_][w] +=
- T)
- }
- e.setItemLayout(v, {
- x: S,
- y: M,
- width: I,
- height: T
- })
- }
- }
- }, this)
- }
- function Pl(t) {
- return t.coordinateSystem && "cartesian2d" === t.coordinateSystem.type
- }
- function Nl(t) {
- return t.pipelineContext && t.pipelineContext.large
- }
- function Ol(t, e, i) {
- var n, o, a = e.getGlobalExtent();
- a[0] > a[1] ? (n = a[1], o = a[0]) : (n = a[0], o = a[1]);
- var r = e.toGlobalCoord(e.dataToCoord(0));
- return r < n && (r = n), r > o && (r = o), r
- }
- function El(t, e) {
- return SA(t, bA(e))
- }
- function Rl(t, e) {
- var i, n, o, a = t.type,
- r = e.getMin(),
- s = e.getMax(),
- l = null != r,
- u = null != s,
- h = t.getExtent();
- "ordinal" === a ? i = e.getCategories().length : (y(n = e.get("boundaryGap")) || (n = [n || 0, n || 0]), "boolean" ==
- typeof n[0] && (n = [0, 0]), n[0] = Ro(n[0], 1), n[1] = Ro(n[1], 1), o = h[1] - h[0] || Math.abs(h[0])), null == r &&
- (r = "ordinal" === a ? i ? 0 : NaN : h[0] - n[0] * o), null == s && (s = "ordinal" === a ? i ? i - 1 : NaN : h[1] +
- n[1] * o), "dataMin" === r ? r = h[0] : "function" == typeof r && (r = r({
- min: h[0],
- max: h[1]
- })), "dataMax" === s ? s = h[1] : "function" == typeof s && (s = s({
- min: h[0],
- max: h[1]
- })), (null == r || !isFinite(r)) && (r = NaN), (null == s || !isFinite(s)) && (s = NaN), t.setBlank(I(r) || I(s) ||
- "ordinal" === a && !t.getOrdinalMeta().categories.length), e.getNeedCrossZero() && (r > 0 && s > 0 && !l && (r = 0),
- r < 0 && s < 0 && !u && (s = 0));
- var c = e.ecModel;
- if (c && "time" === a) {
- var f, p = Al("bar", c);
- if (d(p, function(t) {
- f |= t.getBaseAxis() === e.axis
- }), f) {
- var g = Dl(p),
- m = zl(r, s, e, g);
- r = m.min, s = m.max
- }
- }
- return [r, s]
- }
- function zl(t, e, i, n) {
- var o = i.axis.getExtent(),
- a = o[1] - o[0],
- r = Ll(n, i.axis);
- if (void 0 === r) return {
- min: t,
- max: e
- };
- var s = 1 / 0;
- d(r, function(t) {
- s = Math.min(t.offset, s)
- });
- var l = -1 / 0;
- d(r, function(t) {
- l = Math.max(t.offset + t.width, l)
- }), s = Math.abs(s), l = Math.abs(l);
- var u = s + l,
- h = e - t,
- c = h / (1 - (s + l) / a) - h;
- return e += c * (l / u), t -= c * (s / u), {
- min: t,
- max: e
- }
- }
- function Bl(t, e) {
- var i = Rl(t, e),
- n = null != e.getMin(),
- o = null != e.getMax(),
- a = e.get("splitNumber");
- "log" === t.type && (t.base = e.get("logBase"));
- var r = t.type;
- t.setExtent(i[0], i[1]), t.niceExtent({
- splitNumber: a,
- fixMin: n,
- fixMax: o,
- minInterval: "interval" === r || "time" === r ? e.get("minInterval") : null,
- maxInterval: "interval" === r || "time" === r ? e.get("maxInterval") : null
- });
- var s = e.get("interval");
- null != s && t.setInterval && t.setInterval(s)
- }
- function Vl(t, e) {
- if (e = e || t.get("type")) switch (e) {
- case "category":
- return new sA(t.getOrdinalMeta ? t.getOrdinalMeta() : t.getCategories(), [1 / 0, -1 / 0]);
- case "value":
- return new hA;
- default:
- return (gl.getClass(e) || hA).create(t)
- }
- }
- function Gl(t) {
- var e = t.scale.getExtent(),
- i = e[0],
- n = e[1];
- return !(i > 0 && n > 0 || i < 0 && n < 0)
- }
- function Fl(t) {
- var e = t.getLabelModel().get("formatter"),
- i = "category" === t.type ? t.scale.getExtent()[0] : null;
- return "string" == typeof e ? e = function(e) {
- return function(i) {
- return i = t.scale.getLabel(i), e.replace("{value}", null != i ? i : "")
- }
- }(e) : "function" == typeof e ? function(n, o) {
- return null != i && (o = n - i), e(Wl(t, n), o)
- } : function(e) {
- return t.scale.getLabel(e)
- }
- }
- function Wl(t, e) {
- return "category" === t.type ? t.scale.getLabel(e) : e
- }
- function Hl(t) {
- var e = t.model,
- i = t.scale;
- if (e.get("axisLabel.show") && !i.isBlank()) {
- var n, o, a = "category" === t.type,
- r = i.getExtent();
- o = a ? i.count() : (n = i.getTicks()).length;
- var s, l = t.getLabelModel(),
- u = Fl(t),
- h = 1;
- o > 40 && (h = Math.ceil(o / 40));
- for (var c = 0; c < o; c += h) {
- var d = u(n ? n[c] : r[0] + c),
- f = Zl(l.getTextRect(d), l.get("rotate") || 0);
- s ? s.union(f) : s = f
- }
- return s
- }
- }
- function Zl(t, e) {
- var i = e * Math.PI / 180,
- n = t.plain(),
- o = n.width,
- a = n.height,
- r = o * Math.cos(i) + a * Math.sin(i),
- s = o * Math.sin(i) + a * Math.cos(i);
- return new ue(n.x, n.y, r, s)
- }
- function Ul(t, e) {
- if ("image" !== this.type) {
- var i = this.style,
- n = this.shape;
- n && "line" === n.symbolType ? i.stroke = t : this.__isEmptyBrush ? (i.stroke = t, i.fill = e || "#fff") : (i.fill &&
- (i.fill = t), i.stroke && (i.stroke = t)), this.dirty(!1)
- }
- }
- function Xl(t, e, i, n, o, a, r) {
- var s = 0 === t.indexOf("empty");
- s && (t = t.substr(5, 1).toLowerCase() + t.substr(6));
- var l;
- return l = 0 === t.indexOf("image://") ? Hn(t.slice(8), new ue(e, i, n, o), r ? "center" : "cover") : 0 === t.indexOf(
- "path://") ? Wn(t.slice(7), {}, new ue(e, i, n, o), r ? "center" : "cover") : new RA({
- shape: {
- symbolType: t,
- x: e,
- y: i,
- width: n,
- height: o
- }
- }), l.__isEmptyBrush = s, l.setColor = Ul, l.setColor(a), l
- }
- function jl(t, e) {
- return Math.abs(t - e) < VA
- }
- function Yl(t, e, i) {
- var n = 0,
- o = t[0];
- if (!o) return !1;
- for (var a = 1; a < t.length; a++) {
- var r = t[a];
- n += bn(o[0], o[1], r[0], r[1], e, i), o = r
- }
- var s = t[0];
- return jl(o[0], s[0]) && jl(o[1], s[1]) || (n += bn(o[0], o[1], s[0], s[1], e, i)), 0 !== n
- }
- function ql(t, e, i) {
- if (this.name = t, this.geometries = e, i) i = [i[0], i[1]];
- else {
- var n = this.getBoundingRect();
- i = [n.x + n.width / 2, n.y + n.height / 2]
- }
- this.center = i
- }
- function Kl(t) {
- if (!t.UTF8Encoding) return t;
- var e = t.UTF8Scale;
- null == e && (e = 1024);
- for (var i = t.features, n = 0; n < i.length; n++)
- for (var o = i[n].geometry, a = o.coordinates, r = o.encodeOffsets, s = 0; s < a.length; s++) {
- var l = a[s];
- if ("Polygon" === o.type) a[s] = $l(l, r[s], e);
- else if ("MultiPolygon" === o.type)
- for (var u = 0; u < l.length; u++) {
- var h = l[u];
- l[u] = $l(h, r[s][u], e)
- }
- }
- return t.UTF8Encoding = !1, t
- }
- function $l(t, e, i) {
- for (var n = [], o = e[0], a = e[1], r = 0; r < t.length; r += 2) {
- var s = t.charCodeAt(r) - 64,
- l = t.charCodeAt(r + 1) - 64;
- s = s >> 1 ^ -(1 & s), l = l >> 1 ^ -(1 & l), o = s += o, a = l += a, n.push([s / i, l / i])
- }
- return n
- }
- function Jl(t) {
- return "category" === t.type ? tu(t) : nu(t)
- }
- function Ql(t, e) {
- return "category" === t.type ? iu(t, e) : {
- ticks: t.scale.getTicks()
- }
- }
- function tu(t) {
- var e = t.getLabelModel(),
- i = eu(t, e);
- return !e.get("show") || t.scale.isBlank() ? {
- labels: [],
- labelCategoryInterval: i.labelCategoryInterval
- } : i
- }
- function eu(t, e) {
- var i = ou(t, "labels"),
- n = du(e),
- o = au(i, n);
- if (o) return o;
- var a, r;
- return a = x(n) ? cu(t, n) : hu(t, r = "auto" === n ? su(t) : n), ru(i, n, {
- labels: a,
- labelCategoryInterval: r
- })
- }
- function iu(t, e) {
- var i = ou(t, "ticks"),
- n = du(e),
- o = au(i, n);
- if (o) return o;
- var a, r;
- if (e.get("show") && !t.scale.isBlank() || (a = []), x(n)) a = cu(t, n, !0);
- else if ("auto" === n) {
- var s = eu(t, t.getLabelModel());
- r = s.labelCategoryInterval, a = f(s.labels, function(t) {
- return t.tickValue
- })
- } else a = hu(t, r = n, !0);
- return ru(i, n, {
- ticks: a,
- tickCategoryInterval: r
- })
- }
- function nu(t) {
- var e = t.scale.getTicks(),
- i = Fl(t);
- return {
- labels: f(e, function(e, n) {
- return {
- formattedLabel: i(e, n),
- rawLabel: t.scale.getLabel(e),
- tickValue: e
- }
- })
- }
- }
- function ou(t, e) {
- return FA(t)[e] || (FA(t)[e] = [])
- }
- function au(t, e) {
- for (var i = 0; i < t.length; i++)
- if (t[i].key === e) return t[i].value
- }
- function ru(t, e, i) {
- return t.push({
- key: e,
- value: i
- }), i
- }
- function su(t) {
- var e = FA(t).autoInterval;
- return null != e ? e : FA(t).autoInterval = t.calculateCategoryInterval()
- }
- function lu(t) {
- var e = uu(t),
- i = Fl(t),
- n = (e.axisRotate - e.labelRotate) / 180 * Math.PI,
- o = t.scale,
- a = o.getExtent(),
- r = o.count();
- if (a[1] - a[0] < 1) return 0;
- var s = 1;
- r > 40 && (s = Math.max(1, Math.floor(r / 40)));
- for (var l = a[0], u = t.dataToCoord(l + 1) - t.dataToCoord(l), h = Math.abs(u * Math.cos(n)), c = Math.abs(u * Math
- .sin(n)), d = 0, f = 0; l <= a[1]; l += s) {
- var p = 0,
- g = 0,
- m = De(i(l), e.font, "center", "top");
- p = 1.3 * m.width, g = 1.3 * m.height, d = Math.max(d, p, 7), f = Math.max(f, g, 7)
- }
- var v = d / h,
- y = f / c;
- isNaN(v) && (v = 1 / 0), isNaN(y) && (y = 1 / 0);
- var x = Math.max(0, Math.floor(Math.min(v, y))),
- _ = FA(t.model),
- w = _.lastAutoInterval,
- b = _.lastTickCount;
- return null != w && null != b && Math.abs(w - x) <= 1 && Math.abs(b - r) <= 1 && w > x ? x = w : (_.lastTickCount =
- r, _.lastAutoInterval = x), x
- }
- function uu(t) {
- var e = t.getLabelModel();
- return {
- axisRotate: t.getRotate ? t.getRotate() : t.isHorizontal && !t.isHorizontal() ? 90 : 0,
- labelRotate: e.get("rotate") || 0,
- font: e.getFont()
- }
- }
- function hu(t, e, i) {
- function n(t) {
- l.push(i ? t : {
- formattedLabel: o(t),
- rawLabel: a.getLabel(t),
- tickValue: t
- })
- }
- var o = Fl(t),
- a = t.scale,
- r = a.getExtent(),
- s = t.getLabelModel(),
- l = [],
- u = Math.max((e || 0) + 1, 1),
- h = r[0],
- c = a.count();
- 0 !== h && u > 1 && c / u > 2 && (h = Math.round(Math.ceil(h / u) * u));
- var d = {
- min: s.get("showMinLabel"),
- max: s.get("showMaxLabel")
- };
- d.min && h !== r[0] && n(r[0]);
- for (var f = h; f <= r[1]; f += u) n(f);
- return d.max && f !== r[1] && n(r[1]), l
- }
- function cu(t, e, i) {
- var n = t.scale,
- o = Fl(t),
- a = [];
- return d(n.getTicks(), function(t) {
- var r = n.getLabel(t);
- e(t, r) && a.push(i ? t : {
- formattedLabel: o(t),
- rawLabel: r,
- tickValue: t
- })
- }), a
- }
- function du(t) {
- var e = t.get("interval");
- return null == e ? "auto" : e
- }
- function fu(t, e) {
- var i = (t[1] - t[0]) / e / 2;
- t[0] += i, t[1] -= i
- }
- function pu(t, e, i, n, o) {
- function a(t, e) {
- return h ? t > e : t < e
- }
- var r = e.length;
- if (t.onBand && !n && r) {
- var s, l = t.getExtent();
- if (1 === r) e[0].coord = l[0], s = e[1] = {
- coord: l[0]
- };
- else {
- var u = e[1].coord - e[0].coord;
- d(e, function(t) {
- t.coord -= u / 2;
- var e = e || 0;
- e % 2 > 0 && (t.coord -= u / (2 * (e + 1)))
- }), s = {
- coord: e[r - 1].coord + u
- }, e.push(s)
- }
- var h = l[0] > l[1];
- a(e[0].coord, l[0]) && (o ? e[0].coord = l[0] : e.shift()), o && a(l[0], e[0].coord) && e.unshift({
- coord: l[0]
- }), a(l[1], s.coord) && (o ? s.coord = l[1] : e.pop()), o && a(s.coord, l[1]) && e.push({
- coord: l[1]
- })
- }
- }
- function gu(t, e) {
- var i = t.mapDimension("defaultedLabel", !0),
- n = i.length;
- if (1 === n) return hr(t, e, i[0]);
- if (n) {
- for (var o = [], a = 0; a < i.length; a++) {
- var r = hr(t, e, i[a]);
- o.push(r)
- }
- return o.join(" ")
- }
- }
- function mu(t, e, i) {
- Zw.call(this), this.updateData(t, e, i)
- }
- function vu(t) {
- return [t[0] / 2, t[1] / 2]
- }
- function yu(t, e) {
- this.parent.drift(t, e)
- }
- function xu() {
- !oo(this) && wu.call(this)
- }
- function _u() {
- !oo(this) && bu.call(this)
- }
- function wu() {
- if (!this.incremental && !this.useHoverLayer) {
- var t = this.__symbolOriginalScale,
- e = t[1] / t[0];
- this.animateTo({
- scale: [Math.max(1.1 * t[0], t[0] + 3), Math.max(1.1 * t[1], t[1] + 3 * e)]
- }, 400, "elasticOut")
- }
- }
- function bu() {
- this.incremental || this.useHoverLayer || this.animateTo({
- scale: this.__symbolOriginalScale
- }, 400, "elasticOut")
- }
- function Su(t) {
- this.group = new Zw, this._symbolCtor = t || mu
- }
- function Mu(t, e, i, n) {
- return e && !isNaN(e[0]) && !isNaN(e[1]) && !(n.isIgnore && n.isIgnore(i)) && !(n.clipShape && !n.clipShape.contain(
- e[0], e[1])) && "none" !== t.getItemVisual(i, "symbol")
- }
- function Iu(t) {
- return null == t || w(t) || (t = {
- isIgnore: t
- }), t || {}
- }
- function Tu(t) {
- var e = t.hostModel;
- return {
- itemStyle: e.getModel("itemStyle").getItemStyle(["color"]),
- hoverItemStyle: e.getModel("emphasis.itemStyle").getItemStyle(),
- symbolRotate: e.get("symbolRotate"),
- symbolOffset: e.get("symbolOffset"),
- hoverAnimation: e.get("hoverAnimation"),
- labelModel: e.getModel("label"),
- hoverLabelModel: e.getModel("emphasis.label"),
- cursorStyle: e.get("cursor")
- }
- }
- function Au(t, e, i) {
- var n, o = t.getBaseAxis(),
- a = t.getOtherAxis(o),
- r = Du(a, i),
- s = o.dim,
- l = a.dim,
- u = e.mapDimension(l),
- h = e.mapDimension(s),
- c = "x" === l || "radius" === l ? 1 : 0,
- d = f(t.dimensions, function(t) {
- return e.mapDimension(t)
- }),
- p = e.getCalculationInfo("stackResultDimension");
- return (n |= hl(e, d[0])) && (d[0] = p), (n |= hl(e, d[1])) && (d[1] = p), {
- dataDimsForPoint: d,
- valueStart: r,
- valueAxisDim: l,
- baseAxisDim: s,
- stacked: !!n,
- valueDim: u,
- baseDim: h,
- baseDataOffset: c,
- stackedOverDimension: e.getCalculationInfo("stackedOverDimension")
- }
- }
- function Du(t, e) {
- var i = 0,
- n = t.scale.getExtent();
- return "start" === e ? i = n[0] : "end" === e ? i = n[1] : n[0] > 0 ? i = n[0] : n[1] < 0 && (i = n[1]), i
- }
- function Cu(t, e, i, n) {
- var o = NaN;
- t.stacked && (o = i.get(i.getCalculationInfo("stackedOverDimension"), n)), isNaN(o) && (o = t.valueStart);
- var a = t.baseDataOffset,
- r = [];
- return r[a] = i.get(t.baseDim, n), r[1 - a] = o, e.dataToPoint(r)
- }
- function Lu(t, e) {
- var i = [];
- return e.diff(t).add(function(t) {
- i.push({
- cmd: "+",
- idx: t
- })
- }).update(function(t, e) {
- i.push({
- cmd: "=",
- idx: e,
- idx1: t
- })
- }).remove(function(t) {
- i.push({
- cmd: "-",
- idx: t
- })
- }).execute(), i
- }
- function ku(t) {
- return isNaN(t[0]) || isNaN(t[1])
- }
- function Pu(t, e, i, n, o, a, r, s, l, u, h) {
- return "none" !== u && u ? Nu.apply(this, arguments) : Ou.apply(this, arguments)
- }
- function Nu(t, e, i, n, o, a, r, s, l, u, h) {
- for (var c = 0, d = i, f = 0; f < n; f++) {
- var p = e[d];
- if (d >= o || d < 0) break;
- if (ku(p)) {
- if (h) {
- d += a;
- continue
- }
- break
- }
- if (d === i) t[a > 0 ? "moveTo" : "lineTo"](p[0], p[1]);
- else if (l > 0) {
- var g = e[c],
- m = "y" === u ? 1 : 0,
- v = (p[m] - g[m]) * l;
- oD(rD, g), rD[m] = g[m] + v, oD(sD, p), sD[m] = p[m] - v, t.bezierCurveTo(rD[0], rD[1], sD[0], sD[1], p[0], p[1])
- } else t.lineTo(p[0], p[1]);
- c = d, d += a
- }
- return f
- }
- function Ou(t, e, i, n, o, a, r, s, l, u, h) {
- for (var c = 0, d = i, f = 0; f < n; f++) {
- var p = e[d];
- if (d >= o || d < 0) break;
- if (ku(p)) {
- if (h) {
- d += a;
- continue
- }
- break
- }
- if (d === i) t[a > 0 ? "moveTo" : "lineTo"](p[0], p[1]), oD(rD, p);
- else if (l > 0) {
- var g = d + a,
- m = e[g];
- if (h)
- for (; m && ku(e[g]);) m = e[g += a];
- var v = .5,
- y = e[c];
- if (!(m = e[g]) || ku(m)) oD(sD, p);
- else {
- ku(m) && !h && (m = p), U(aD, m, y);
- var x, _;
- if ("x" === u || "y" === u) {
- var w = "x" === u ? 0 : 1;
- x = Math.abs(p[w] - y[w]), _ = Math.abs(p[w] - m[w])
- } else x = ew(p, y), _ = ew(p, m);
- nD(sD, p, aD, -l * (1 - (v = _ / (_ + x))))
- }
- eD(rD, rD, s), iD(rD, rD, r), eD(sD, sD, s), iD(sD, sD, r), t.bezierCurveTo(rD[0], rD[1], sD[0], sD[1], p[0], p[1]),
- nD(rD, p, aD, l * v)
- } else t.lineTo(p[0], p[1]);
- c = d, d += a
- }
- return f
- }
- function Eu(t, e) {
- var i = [1 / 0, 1 / 0],
- n = [-1 / 0, -1 / 0];
- if (e)
- for (var o = 0; o < t.length; o++) {
- var a = t[o];
- a[0] < i[0] && (i[0] = a[0]), a[1] < i[1] && (i[1] = a[1]), a[0] > n[0] && (n[0] = a[0]), a[1] > n[1] && (n[1] = a[
- 1])
- }
- return {
- min: e ? i : n,
- max: e ? n : i
- }
- }
- function Ru(t, e) {
- if (t.length === e.length) {
- for (var i = 0; i < t.length; i++) {
- var n = t[i],
- o = e[i];
- if (n[0] !== o[0] || n[1] !== o[1]) return
- }
- return !0
- }
- }
- function zu(t) {
- return "number" == typeof t ? t : t ? .5 : 0
- }
- function Bu(t) {
- var e = t.getGlobalExtent();
- if (t.onBand) {
- var i = t.getBandWidth() / 2 - 1,
- n = e[1] > e[0] ? 1 : -1;
- e[0] += n * i, e[1] -= n * i
- }
- return e
- }
- function Vu(t, e, i) {
- if (!i.valueDim) return [];
- for (var n = [], o = 0, a = e.count(); o < a; o++) n.push(Cu(i, t, e, o));
- return n
- }
- function Gu(t, e, i, n) {
- var o = Bu(t.getAxis("x")),
- a = Bu(t.getAxis("y")),
- r = t.getBaseAxis().isHorizontal(),
- s = Math.min(o[0], o[1]),
- l = Math.min(a[0], a[1]),
- u = Math.max(o[0], o[1]) - s,
- h = Math.max(a[0], a[1]) - l;
- if (i) s -= .5, u += .5, l -= .5, h += .5;
- else {
- var c = n.get("lineStyle.width") || 2,
- d = n.get("clipOverflow") ? c / 2 : Math.max(u, h);
- r ? (l -= d, h += 2 * d) : (s -= d, u += 2 * d)
- }
- var f = new aM({
- shape: {
- x: s,
- y: l,
- width: u,
- height: h
- }
- });
- return e && (f.shape[r ? "width" : "height"] = 0, So(f, {
- shape: {
- width: u,
- height: h
- }
- }, n)), f
- }
- function Fu(t, e, i, n) {
- var o = t.getAngleAxis(),
- a = t.getRadiusAxis().getExtent().slice();
- a[0] > a[1] && a.reverse();
- var r = o.getExtent(),
- s = Math.PI / 180;
- i && (a[0] -= .5, a[1] += .5);
- var l = new QS({
- shape: {
- cx: zo(t.cx, 1),
- cy: zo(t.cy, 1),
- r0: zo(a[0], 1),
- r: zo(a[1], 1),
- startAngle: -r[0] * s,
- endAngle: -r[1] * s,
- clockwise: o.inverse
- }
- });
- return e && (l.shape.endAngle = -r[0] * s, So(l, {
- shape: {
- endAngle: -r[1] * s
- }
- }, n)), l
- }
- function Wu(t, e, i, n) {
- return "polar" === t.type ? Fu(t, e, i, n) : Gu(t, e, i, n)
- }
- function Hu(t, e, i) {
- for (var n = e.getBaseAxis(), o = "x" === n.dim || "radius" === n.dim ? 0 : 1, a = [], r = 0; r < t.length - 1; r++) {
- var s = t[r + 1],
- l = t[r];
- a.push(l);
- var u = [];
- switch (i) {
- case "end":
- u[o] = s[o], u[1 - o] = l[1 - o], a.push(u);
- break;
- case "middle":
- var h = (l[o] + s[o]) / 2,
- c = [];
- u[o] = c[o] = h, u[1 - o] = l[1 - o], c[1 - o] = s[1 - o], a.push(u), a.push(c);
- break;
- default:
- u[o] = l[o], u[1 - o] = s[1 - o], a.push(u)
- }
- }
- return t[r] && a.push(t[r]), a
- }
- function Zu(t, e) {
- var i = t.getVisual("visualMeta");
- if (i && i.length && t.count() && "cartesian2d" === e.type) {
- for (var n, o, a = i.length - 1; a >= 0; a--) {
- var r = i[a].dimension,
- s = t.dimensions[r],
- l = t.getDimensionInfo(s);
- if ("x" === (n = l && l.coordDim) || "y" === n) {
- o = i[a];
- break
- }
- }
- if (o) {
- var u = e.getAxis(n),
- h = f(o.stops, function(t) {
- return {
- coord: u.toGlobalCoord(u.dataToCoord(t.value)),
- color: t.color
- }
- }),
- c = h.length,
- p = o.outerColors.slice();
- c && h[0].coord > h[c - 1].coord && (h.reverse(), p.reverse());
- var g = h[0].coord - 10,
- m = h[c - 1].coord + 10,
- v = m - g;
- if (v < .001) return "transparent";
- d(h, function(t) {
- t.offset = (t.coord - g) / v
- }), h.push({
- offset: c ? h[c - 1].offset : .5,
- color: p[1] || "transparent"
- }), h.unshift({
- offset: c ? h[0].offset : .5,
- color: p[0] || "transparent"
- });
- var y = new dM(0, 0, 0, 0, h, !0);
- return y[n] = g, y[n + "2"] = m, y
- }
- }
- }
- function Uu(t, e, i) {
- var n = t.get("showAllSymbol"),
- o = "auto" === n;
- if (!n || o) {
- var a = i.getAxesByScale("ordinal")[0];
- if (a && (!o || !Xu(a, e))) {
- var r = e.mapDimension(a.dim),
- s = {};
- return d(a.getViewLabels(), function(t) {
- s[t.tickValue] = 1
- }),
- function(t) {
- return !s.hasOwnProperty(e.get(r, t))
- }
- }
- }
- }
- function Xu(t, e) {
- var i = t.getExtent(),
- n = Math.abs(i[1] - i[0]) / t.scale.count();
- isNaN(n) && (n = 0);
- for (var o = e.count(), a = Math.max(1, Math.round(o / 5)), r = 0; r < o; r += a)
- if (1.5 * mu.getSymbolSize(e, r)[t.isHorizontal() ? 1 : 0] > n) return !1;
- return !0
- }
- function ju(t) {
- return this._axes[t]
- }
- function Yu(t) {
- pD.call(this, t)
- }
- function qu(t, e) {
- return e.type || (e.data ? "category" : "value")
- }
- function Ku(t, e, i) {
- return t.getCoordSysModel() === e
- }
- function $u(t, e, i) {
- this._coordsMap = {}, this._coordsList = [], this._axesMap = {}, this._axesList = [], this._initCartesian(t, e, i),
- this.model = t
- }
- function Ju(t, e, i, n) {
- function o(t) {
- return t.dim + "_" + t.index
- }
- i.getAxesOnZeroOf = function() {
- return a ? [a] : []
- };
- var a, r = t[e],
- s = i.model,
- l = s.get("axisLine.onZero"),
- u = s.get("axisLine.onZeroAxisIndex");
- if (l) {
- if (null != u) Qu(r[u]) && (a = r[u]);
- else
- for (var h in r)
- if (r.hasOwnProperty(h) && Qu(r[h]) && !n[o(r[h])]) {
- a = r[h];
- break
- } a && (n[o(a)] = !0)
- }
- }
- function Qu(t) {
- return t && "category" !== t.type && "time" !== t.type && Gl(t)
- }
- function th(t, e) {
- var i = t.getExtent(),
- n = i[0] + i[1];
- t.toGlobalCoord = "x" === t.dim ? function(t) {
- return t + e
- } : function(t) {
- return n - t + e
- }, t.toLocalCoord = "x" === t.dim ? function(t) {
- return t - e
- } : function(t) {
- return n - t + e
- }
- }
- function eh(t, e) {
- return f(SD, function(e) {
- return t.getReferringComponents(e)[0]
- })
- }
- function ih(t) {
- return "cartesian2d" === t.get("coordinateSystem")
- }
- function nh(t) {
- var e = {
- componentType: t.mainType,
- componentIndex: t.componentIndex
- };
- return e[t.mainType + "Index"] = t.componentIndex, e
- }
- function oh(t, e, i, n) {
- var o, a, r = Ho(i - t.rotation),
- s = n[0] > n[1],
- l = "start" === e && !s || "start" !== e && s;
- return Zo(r - MD / 2) ? (a = l ? "bottom" : "top", o = "center") : Zo(r - 1.5 * MD) ? (a = l ? "top" : "bottom", o =
- "center") : (a = "middle", o = r < 1.5 * MD && r > MD / 2 ? l ? "left" : "right" : l ? "right" : "left"), {
- rotation: r,
- textAlign: o,
- textVerticalAlign: a
- }
- }
- function ah(t) {
- var e = t.get("tooltip");
- return t.get("silent") || !(t.get("triggerEvent") || e && e.show)
- }
- function rh(t, e, i) {
- var n = t.get("axisLabel.showMinLabel"),
- o = t.get("axisLabel.showMaxLabel");
- e = e || [], i = i || [];
- var a = e[0],
- r = e[1],
- s = e[e.length - 1],
- l = e[e.length - 2],
- u = i[0],
- h = i[1],
- c = i[i.length - 1],
- d = i[i.length - 2];
- !1 === n ? (sh(a), sh(u)) : lh(a, r) && (n ? (sh(r), sh(h)) : (sh(a), sh(u))), !1 === o ? (sh(s), sh(c)) : lh(l, s) &&
- (o ? (sh(l), sh(d)) : (sh(s), sh(c)))
- }
- function sh(t) {
- t && (t.ignore = !0)
- }
- function lh(t, e, i) {
- var n = t && t.getBoundingRect().clone(),
- o = e && e.getBoundingRect().clone();
- if (n && o) {
- var a = vt([]);
- return wt(a, a, -t.rotation), n.applyTransform(xt([], a, t.getLocalTransform())), o.applyTransform(xt([], a, e.getLocalTransform())),
- n.intersect(o)
- }
- }
- function uh(t) {
- return "middle" === t || "center" === t
- }
- function hh(t, e, i) {
- var n = e.axis;
- if (e.get("axisTick.show") && !n.scale.isBlank()) {
- for (var o = e.getModel("axisTick"), a = o.getModel("lineStyle"), s = o.get("length"), l = n.getTicksCoords(), u = [],
- h = [], c = t._transform, d = [], f = 0; f < l.length; f++) {
- var p = l[f].coord;
- u[0] = p, u[1] = 0, h[0] = p, h[1] = i.tickDirection * s, c && (Q(u, u, c), Q(h, h, c));
- var g = new rM(Xn({
- anid: "tick_" + l[f].tickValue,
- shape: {
- x1: u[0],
- y1: u[1],
- x2: h[0],
- y2: h[1]
- },
- style: r(a.getLineStyle(), {
- stroke: e.get("axisLine.lineStyle.color")
- }),
- z2: 2,
- silent: !0
- }));
- t.group.add(g), d.push(g)
- }
- return d
- }
- }
- function ch(t, e, i) {
- var n = e.axis;
- if (T(i.axisLabelShow, e.get("axisLabel.show")) && !n.scale.isBlank()) {
- var o = e.getModel("axisLabel"),
- a = o.get("margin"),
- r = n.getViewLabels(),
- s = (T(i.labelRotate, o.get("rotate")) || 0) * MD / 180,
- l = AD(i.rotation, s, i.labelDirection),
- u = e.getCategories(!0),
- h = [],
- c = ah(e),
- f = e.get("triggerEvent");
- return d(r, function(r, s) {
- var d = r.tickValue,
- p = r.formattedLabel,
- g = r.rawLabel,
- m = o;
- u && u[d] && u[d].textStyle && (m = new Lo(u[d].textStyle, o, e.ecModel));
- var v = m.getTextColor() || e.get("axisLine.lineStyle.color"),
- y = [n.dataToCoord(d), i.labelOffset + i.labelDirection * a],
- x = new qS({
- anid: "label_" + d,
- position: y,
- rotation: l.rotation,
- silent: c,
- z2: 10
- });
- fo(x.style, m, {
- text: p,
- textAlign: m.getShallow("align", !0) || l.textAlign,
- textVerticalAlign: m.getShallow("verticalAlign", !0) || m.getShallow("baseline", !0) || l.textVerticalAlign,
- textFill: "function" == typeof v ? v("category" === n.type ? g : "value" === n.type ? d + "" : d, s) : v
- }), f && (x.eventData = nh(e), x.eventData.targetType = "axisLabel", x.eventData.value = g), t._dumbGroup.add(x),
- x.updateTransform(), h.push(x), t.group.add(x), x.decomposeTransform()
- }), h
- }
- }
- function dh(t, e) {
- var i = {
- axesInfo: {},
- seriesInvolved: !1,
- coordSysAxesInfo: {},
- coordSysMap: {}
- };
- return fh(i, t, e), i.seriesInvolved && gh(i, t), i
- }
- function fh(t, e, i) {
- var n = e.getComponent("tooltip"),
- o = e.getComponent("axisPointer"),
- a = o.get("link", !0) || [],
- r = [];
- DD(i.getCoordinateSystems(), function(i) {
- function s(n, s, l) {
- var c = l.model.getModel("axisPointer", o),
- d = c.get("show");
- if (d && ("auto" !== d || n || wh(c))) {
- null == s && (s = c.get("triggerTooltip"));
- var f = (c = n ? ph(l, h, o, e, n, s) : c).get("snap"),
- p = bh(l.model),
- g = s || f || "category" === l.type,
- m = t.axesInfo[p] = {
- key: p,
- axis: l,
- coordSys: i,
- axisPointerModel: c,
- triggerTooltip: s,
- involveSeries: g,
- snap: f,
- useHandle: wh(c),
- seriesModels: []
- };
- u[p] = m, t.seriesInvolved |= g;
- var v = mh(a, l);
- if (null != v) {
- var y = r[v] || (r[v] = {
- axesInfo: {}
- });
- y.axesInfo[p] = m, y.mapper = a[v].mapper, m.linkGroup = y
- }
- }
- }
- if (i.axisPointerEnabled) {
- var l = bh(i.model),
- u = t.coordSysAxesInfo[l] = {};
- t.coordSysMap[l] = i;
- var h = i.model.getModel("tooltip", n);
- if (DD(i.getAxes(), CD(s, !1, null)), i.getTooltipAxes && n && h.get("show")) {
- var c = "axis" === h.get("trigger"),
- d = "cross" === h.get("axisPointer.type"),
- f = i.getTooltipAxes(h.get("axisPointer.axis"));
- (c || d) && DD(f.baseAxes, CD(s, !d || "cross", c)), d && DD(f.otherAxes, CD(s, "cross", !1))
- }
- }
- })
- }
- function ph(t, e, n, o, a, s) {
- var l = e.getModel("axisPointer"),
- u = {};
- DD(["type", "snap", "lineStyle", "shadowStyle", "label", "animation", "animationDurationUpdate",
- "animationEasingUpdate", "z"
- ], function(t) {
- u[t] = i(l.get(t))
- }), u.snap = "category" !== t.type && !!s, "cross" === l.get("type") && (u.type = "line");
- var h = u.label || (u.label = {});
- if (null == h.show && (h.show = !1), "cross" === a) {
- var c = l.get("label.show");
- if (h.show = null == c || c, !s) {
- var d = u.lineStyle = l.get("crossStyle");
- d && r(h, d.textStyle)
- }
- }
- return t.model.getModel("axisPointer", new Lo(u, n, o))
- }
- function gh(t, e) {
- e.eachSeries(function(e) {
- var i = e.coordinateSystem,
- n = e.get("tooltip.trigger", !0),
- o = e.get("tooltip.show", !0);
- i && "none" !== n && !1 !== n && "item" !== n && !1 !== o && !1 !== e.get("axisPointer.show", !0) && DD(t.coordSysAxesInfo[
- bh(i.model)], function(t) {
- var n = t.axis;
- i.getAxis(n.dim) === n && (t.seriesModels.push(e), null == t.seriesDataCount && (t.seriesDataCount = 0), t.seriesDataCount +=
- e.getData().count())
- })
- }, this)
- }
- function mh(t, e) {
- for (var i = e.model, n = e.dim, o = 0; o < t.length; o++) {
- var a = t[o] || {};
- if (vh(a[n + "AxisId"], i.id) || vh(a[n + "AxisIndex"], i.componentIndex) || vh(a[n + "AxisName"], i.name)) return o
- }
- }
- function vh(t, e) {
- return "all" === t || y(t) && l(t, e) >= 0 || t === e
- }
- function yh(t) {
- var e = xh(t);
- if (e) {
- var i = e.axisPointerModel,
- n = e.axis.scale,
- o = i.option,
- a = i.get("status"),
- r = i.get("value");
- null != r && (r = n.parse(r));
- var s = wh(i);
- null == a && (o.status = s ? "show" : "hide");
- var l = n.getExtent().slice();
- l[0] > l[1] && l.reverse(), (null == r || r > l[1]) && (r = l[1]), r < l[0] && (r = l[0]), o.value = r, s && (o.status =
- e.axis.scale.isBlank() ? "hide" : "show")
- }
- }
- function xh(t) {
- var e = (t.ecModel.getComponent("axisPointer") || {}).coordSysAxesInfo;
- return e && e.axesInfo[bh(t)]
- }
- function _h(t) {
- var e = xh(t);
- return e && e.axisPointerModel
- }
- function wh(t) {
- return !!t.get("handle.show")
- }
- function bh(t) {
- return t.type + "||" + t.id
- }
- function Sh(t, e, i, n, o, a) {
- var r = LD.getAxisPointerClass(t.axisPointerClass);
- if (r) {
- var s = _h(e);
- s ? (t._axisPointer || (t._axisPointer = new r)).render(e, s, n, a) : Mh(t, n)
- }
- }
- function Mh(t, e, i) {
- var n = t._axisPointer;
- n && n.dispose(e, i), t._axisPointer = null
- }
- function Ih(t, e, i) {
- i = i || {};
- var n = t.coordinateSystem,
- o = e.axis,
- a = {},
- r = o.getAxesOnZeroOf()[0],
- s = o.position,
- l = r ? "onZero" : s,
- u = o.dim,
- h = n.getRect(),
- c = [h.x, h.x + h.width, h.y, h.y + h.height],
- d = {
- left: 0,
- right: 1,
- top: 0,
- bottom: 1,
- onZero: 2
- },
- f = e.get("offset") || 0,
- p = "x" === u ? [c[2] - f, c[3] + f] : [c[0] - f, c[1] + f];
- if (r) {
- var g = r.toGlobalCoord(r.dataToCoord(0));
- p[d.onZero] = Math.max(Math.min(g, p[1]), p[0])
- }
- a.position = ["y" === u ? p[d[l]] : c[0], "x" === u ? p[d[l]] : c[3]], a.rotation = Math.PI / 2 * ("x" === u ? 0 : 1);
- var m = {
- top: -1,
- bottom: 1,
- left: -1,
- right: 1
- };
- a.labelDirection = a.tickDirection = a.nameDirection = m[s], a.labelOffset = r ? p[d[s]] - p[d.onZero] : 0, e.get(
- "axisTick.inside") && (a.tickDirection = -a.tickDirection), T(i.labelInside, e.get("axisLabel.inside")) && (a.labelDirection = -
- a.labelDirection);
- var v = e.get("axisLabel.rotate");
- return a.labelRotate = "top" === l ? -v : v, a.z2 = 1, a
- }
- function Th(t, e, i, n, o, a, r) {
- co(t, e, i.getModel("label"), i.getModel("emphasis.label"), {
- labelFetcher: o,
- labelDataIndex: a,
- defaultText: gu(o.getData(), a),
- isRectText: !0,
- autoColor: n
- }), Ah(t), Ah(e)
- }
- function Ah(t, e) {
- "outside" === t.textPosition && (t.textPosition = e)
- }
- function Dh(t, e, i) {
- i.style.text = null, bo(i, {
- shape: {
- width: 0
- }
- }, e, t, function() {
- i.parent && i.parent.remove(i)
- })
- }
- function Ch(t, e, i) {
- i.style.text = null, bo(i, {
- shape: {
- r: i.shape.r0
- }
- }, e, t, function() {
- i.parent && i.parent.remove(i)
- })
- }
- function Lh(t, e, i, n, o, a, s, l) {
- var u = e.getItemVisual(i, "color"),
- h = e.getItemVisual(i, "opacity"),
- c = n.getModel("itemStyle"),
- d = n.getModel("emphasis.itemStyle").getBarItemStyle();
- l || t.setShape("r", c.get("barBorderRadius") || 0), t.useStyle(r({
- fill: u,
- opacity: h
- }, c.getBarItemStyle()));
- var f = n.getShallow("cursor");
- f && t.attr("cursor", f);
- var p = s ? o.height > 0 ? "bottom" : "top" : o.width > 0 ? "left" : "right";
- l || Th(t.style, d, n, u, a, i, p), uo(t, d)
- }
- function kh(t, e) {
- var i = t.get(BD) || 0;
- return Math.min(i, Math.abs(e.width), Math.abs(e.height))
- }
- function Ph(t, e, i) {
- var n = t.getData(),
- o = [],
- a = n.getLayout("valueAxisHorizontal") ? 1 : 0;
- o[1 - a] = n.getLayout("valueAxisStart");
- var r = new FD({
- shape: {
- points: n.getLayout("largePoints")
- },
- incremental: !!i,
- __startPoint: o,
- __valueIdx: a
- });
- e.add(r), Nh(r, t, n)
- }
- function Nh(t, e, i) {
- var n = i.getVisual("borderColor") || i.getVisual("color"),
- o = e.getModel("itemStyle").getItemStyle(["color", "borderColor"]);
- t.useStyle(o), t.style.fill = null, t.style.stroke = n, t.style.lineWidth = i.getLayout("barWidth")
- }
- function Oh(t, e, i, n) {
- var o = e.getData(),
- a = this.dataIndex,
- r = o.getName(a),
- s = e.get("selectedOffset");
- n.dispatchAction({
- type: "pieToggleSelect",
- from: t,
- name: r,
- seriesId: e.id
- }), o.each(function(t) {
- Eh(o.getItemGraphicEl(t), o.getItemLayout(t), e.isSelected(o.getName(t)), s, i)
- })
- }
- function Eh(t, e, i, n, o) {
- var a = (e.startAngle + e.endAngle) / 2,
- r = Math.cos(a),
- s = Math.sin(a),
- l = i ? n : 0,
- u = [r * l, s * l];
- o ? t.animate().when(200, {
- position: u
- }).start("bounceOut") : t.attr("position", u)
- }
- function Rh(t, e) {
- function i() {
- a.ignore = a.hoverIgnore, r.ignore = r.hoverIgnore
- }
- function n() {
- a.ignore = a.normalIgnore, r.ignore = r.normalIgnore
- }
- Zw.call(this);
- var o = new QS({
- z2: 2
- }),
- a = new oM,
- r = new qS;
- this.add(o), this.add(a), this.add(r), this.updateData(t, e, !0), this.on("emphasis", i).on("normal", n).on(
- "mouseover", i).on("mouseout", n)
- }
- function zh(t, e, i, n, o, a, r) {
- function s(e, i) {
- for (var n = e; n >= 0 && (t[n].y -= i, !(n > 0 && t[n].y > t[n - 1].y + t[n - 1].height)); n--);
- }
- function l(t, e, i, n, o, a) {
- for (var r = e ? Number.MAX_VALUE : 0, s = 0, l = t.length; s < l; s++)
- if ("center" !== t[s].position) {
- var u = Math.abs(t[s].y - n),
- h = t[s].len,
- c = t[s].len2,
- d = u < o + h ? Math.sqrt((o + h + c) * (o + h + c) - u * u) : Math.abs(t[s].x - i);
- e && d >= r && (d = r - 10), !e && d <= r && (d = r + 10), t[s].x = i + d * a, r = d
- }
- }
- t.sort(function(t, e) {
- return t.y - e.y
- });
- for (var u, h = 0, c = t.length, d = [], f = [], p = 0; p < c; p++)(u = t[p].y - h) < 0 && function(e, i, n, o) {
- for (var a = e; a < i; a++)
- if (t[a].y += n, a > e && a + 1 < i && t[a + 1].y > t[a].y + t[a].height) return void s(a, n / 2);
- s(i - 1, n / 2)
- }(p, c, -u), h = t[p].y + t[p].height;
- r - h < 0 && s(c - 1, h - r);
- for (p = 0; p < c; p++) t[p].y >= i ? f.push(t[p]) : d.push(t[p]);
- l(d, !1, e, i, n, o), l(f, !0, e, i, n, o)
- }
- function Bh(t, e, i, n, o, a) {
- for (var r = [], s = [], l = 0; l < t.length; l++) t[l].x < e ? r.push(t[l]) : s.push(t[l]);
- zh(s, e, i, n, 1, o, a), zh(r, e, i, n, -1, o, a);
- for (l = 0; l < t.length; l++) {
- var u = t[l].linePoints;
- if (u) {
- var h = u[1][0] - u[2][0];
- t[l].x < e ? u[2][0] = t[l].x + 3 : u[2][0] = t[l].x - 3, u[1][1] = u[2][1] = t[l].y, u[1][0] = u[2][0] + h
- }
- }
- }
- function Vh() {
- this.group = new Zw
- }
- function Gh(t, e, i) {
- HA.call(this, t, e, i), this.type = "value", this.angle = 0, this.name = "", this.model
- }
- function Fh(t, e, i) {
- this._model = t, this.dimensions = [], this._indicatorAxes = f(t.getIndicatorModels(), function(t, e) {
- var i = "indicator_" + e,
- n = new Gh(i, new hA);
- return n.name = t.get("name"), n.model = t, t.axis = n, this.dimensions.push(i), n
- }, this), this.resize(t, i), this.cx, this.cy, this.r, this.r0, this.startAngle
- }
- function Wh(t, e) {
- return r({
- show: e
- }, t)
- }
- function Hh(t) {
- return y(t) || (t = [+t, +t]), t
- }
- function Zh() {
- mw.call(this)
- }
- function Uh(t) {
- this.name = t, this.zoomLimit, mw.call(this), this._roamTransformable = new Zh, this._rawTransformable = new Zh,
- this._center, this._zoom
- }
- function Xh(t, e, i, n) {
- var o = i.seriesModel,
- a = o ? o.coordinateSystem : null;
- return a === this ? a[t](n) : null
- }
- function jh(t) {
- for (var e, i = 0; i < t.length; i++) {
- var n = t[i].getBoundingRect();
- (e = e || n.clone()).union(n)
- }
- return e
- }
- function Yh(t, e) {
- var i, n, o = t.svgXML;
- try {
- k(null != (n = (i = o && ns(o, {
- ignoreViewBox: !0,
- ignoreRootClip: !0
- }) || {}).root))
- } catch (t) {
- throw new Error("Invalid svg format\n" + t.message)
- }
- var a = i.width,
- r = i.height,
- s = i.viewBoxRect;
- if (e || (e = null == a || null == r ? n.getBoundingRect() : new ue(0, 0, 0, 0), null != a && (e.width = a), null !=
- r && (e.height = r)), s) {
- var l = is(s, e.width, e.height),
- u = n;
- (n = new Zw).add(u), u.scale = l.scale, u.position = l.position
- }
- return n.setClipPath(new aM({
- shape: e.plain()
- })), {
- root: n,
- boundingRect: e
- }
- }
- function qh(t) {
- return function(e, i) {
- var n = [];
- return d(Kh(e), function(o) {
- var a = yC[o.type][t];
- a && n.push(a(e, o, i))
- }), n
- }
- }
- function Kh(t) {
- return pT.retrieveMap(t) || []
- }
- function $h(t, e, i, n) {
- Uh.call(this, t), this.map = e;
- var o = xC.load(e, i);
- this._nameCoordMap = o.nameCoordMap, this._regionsMap = o.nameCoordMap, this._invertLongitute = null == n || n, this
- .regions = o.regions, this._rect = o.boundingRect
- }
- function Jh(t, e, i, n) {
- var o = i.geoModel,
- a = i.seriesModel,
- r = o ? o.coordinateSystem : a ? a.coordinateSystem || (a.getReferringComponents("geo")[0] || {}).coordinateSystem :
- null;
- return r === this ? r[t](n) : null
- }
- function Qh(t, e) {
- var i = t.get("boundingCoords");
- if (null != i) {
- var n = i[0],
- o = i[1];
- isNaN(n[0]) || isNaN(n[1]) || isNaN(o[0]) || isNaN(o[1]) || this.setBoundingRect(n[0], n[1], o[0] - n[0], o[1] - n[
- 1])
- }
- var a, r = this.getBoundingRect(),
- s = t.get("layoutCenter"),
- l = t.get("layoutSize"),
- u = e.getWidth(),
- h = e.getHeight(),
- c = r.width / r.height * this.aspectScale,
- d = !1;
- s && l && (s = [Ro(s[0], u), Ro(s[1], h)], l = Ro(l, Math.min(u, h)), isNaN(s[0]) || isNaN(s[1]) || isNaN(l) || (d = !
- 0));
- if (d) {
- var f = {};
- c > 1 ? (f.width = l, f.height = l / c) : (f.height = l, f.width = l * c), f.y = s[1] - f.height / 2, f.x = s[0] -
- f.width / 2
- } else(a = t.getBoxLayoutParams()).aspect = c, f = la(a, {
- width: u,
- height: h
- });
- this.setViewRect(f.x, f.y, f.width, f.height), this.setCenter(t.get("center")), this.setZoom(t.get("zoom"))
- }
- function tc(t, e) {
- d(e.get("geoCoord"), function(e, i) {
- t.addGeoCoord(i, e)
- })
- }
- function ec(t, e, i) {
- oc(t)[e] = i
- }
- function ic(t, e, i) {
- var n = oc(t);
- n[e] === i && (n[e] = null)
- }
- function nc(t, e) {
- return !!oc(t)[e]
- }
- function oc(t) {
- return t[bC] || (t[bC] = {})
- }
- function ac(t) {
- this.pointerChecker, this._zr = t, this._opt = {};
- var e = m,
- n = e(rc, this),
- o = e(sc, this),
- a = e(lc, this),
- s = e(uc, this),
- l = e(hc, this);
- aw.call(this), this.setPointerChecker = function(t) {
- this.pointerChecker = t
- }, this.enable = function(e, u) {
- this.disable(), this._opt = r(i(u) || {}, {
- zoomOnMouseWheel: !0,
- moveOnMouseMove: !0,
- moveOnMouseWheel: !1,
- preventDefaultMouseMove: !0
- }), null == e && (e = !0), !0 !== e && "move" !== e && "pan" !== e || (t.on("mousedown", n), t.on("mousemove", o),
- t.on("mouseup", a)), !0 !== e && "scale" !== e && "zoom" !== e || (t.on("mousewheel", s), t.on("pinch", l))
- }, this.disable = function() {
- t.off("mousedown", n), t.off("mousemove", o), t.off("mouseup", a), t.off("mousewheel", s), t.off("pinch", l)
- }, this.dispose = this.disable, this.isDragging = function() {
- return this._dragging
- }, this.isPinching = function() {
- return this._pinching
- }
- }
- function rc(t) {
- if (!(ct(t) || t.target && t.target.draggable)) {
- var e = t.offsetX,
- i = t.offsetY;
- this.pointerChecker && this.pointerChecker(t, e, i) && (this._x = e, this._y = i, this._dragging = !0)
- }
- }
- function sc(t) {
- if (!ct(t) && fc("moveOnMouseMove", t, this._opt) && this._dragging && "pinch" !== t.gestureEvent && !nc(this._zr,
- "globalPan")) {
- var e = t.offsetX,
- i = t.offsetY,
- n = this._x,
- o = this._y,
- a = e - n,
- r = i - o;
- this._x = e, this._y = i, this._opt.preventDefaultMouseMove && lw(t.event), dc(this, "pan", "moveOnMouseMove", t, {
- dx: a,
- dy: r,
- oldX: n,
- oldY: o,
- newX: e,
- newY: i
- })
- }
- }
- function lc(t) {
- ct(t) || (this._dragging = !1)
- }
- function uc(t) {
- var e = fc("zoomOnMouseWheel", t, this._opt),
- i = fc("moveOnMouseWheel", t, this._opt),
- n = t.wheelDelta,
- o = Math.abs(n),
- a = t.offsetX,
- r = t.offsetY;
- if (0 !== n && (e || i)) {
- if (e) {
- var s = o > 3 ? 1.4 : o > 1 ? 1.2 : 1.1;
- cc(this, "zoom", "zoomOnMouseWheel", t, {
- scale: n > 0 ? s : 1 / s,
- originX: a,
- originY: r
- })
- }
- if (i) {
- var l = Math.abs(n);
- cc(this, "scrollMove", "moveOnMouseWheel", t, {
- scrollDelta: (n > 0 ? 1 : -1) * (l > 3 ? .4 : l > 1 ? .15 : .05),
- originX: a,
- originY: r
- })
- }
- }
- }
- function hc(t) {
- nc(this._zr, "globalPan") || cc(this, "zoom", null, t, {
- scale: t.pinchScale > 1 ? 1.1 : 1 / 1.1,
- originX: t.pinchX,
- originY: t.pinchY
- })
- }
- function cc(t, e, i, n, o) {
- t.pointerChecker && t.pointerChecker(n, o.originX, o.originY) && (lw(n.event), dc(t, e, i, n, o))
- }
- function dc(t, e, i, n, o) {
- o.isAvailableBehavior = m(fc, null, i, n), t.trigger(e, o)
- }
- function fc(t, e, i) {
- var n = i[t];
- return !t || n && (!_(n) || e.event[n + "Key"])
- }
- function pc(t, e, i) {
- var n = t.target,
- o = n.position;
- o[0] += e, o[1] += i, n.dirty()
- }
- function gc(t, e, i, n) {
- var o = t.target,
- a = t.zoomLimit,
- r = o.position,
- s = o.scale,
- l = t.zoom = t.zoom || 1;
- if (l *= e, a) {
- var u = a.min || 0,
- h = a.max || 1 / 0;
- l = Math.max(Math.min(h, l), u)
- }
- var c = l / t.zoom;
- t.zoom = l, r[0] -= (i - r[0]) * (c - 1), r[1] -= (n - r[1]) * (c - 1), s[0] *= c, s[1] *= c, o.dirty()
- }
- function mc(t, e, i) {
- var n = e.getComponentByElement(t.topTarget),
- o = n && n.coordinateSystem;
- return n && n !== i && !SC[n.mainType] && o && o.model !== i
- }
- function vc(t, e) {
- var i = t.getItemStyle(),
- n = t.get("areaColor");
- return null != n && (i.fill = n), i
- }
- function yc(t, e, i, n, o) {
- i.off("click"), i.off("mousedown"), e.get("selectedMode") && (i.on("mousedown", function() {
- t._mouseDownFlag = !0
- }), i.on("click", function(a) {
- if (t._mouseDownFlag) {
- t._mouseDownFlag = !1;
- for (var r = a.target; !r.__regions;) r = r.parent;
- if (r) {
- var s = {
- type: ("geo" === e.mainType ? "geo" : "map") + "ToggleSelect",
- batch: f(r.__regions, function(t) {
- return {
- name: t.name,
- from: o.uid
- }
- })
- };
- s[e.mainType + "Id"] = e.id, n.dispatchAction(s), xc(e, i)
- }
- }
- }))
- }
- function xc(t, e) {
- e.eachChild(function(e) {
- d(e.__regions, function(i) {
- e.trigger(t.isSelected(i.name) ? "emphasis" : "normal")
- })
- })
- }
- function _c(t, e) {
- var i = new Zw;
- this.uid = No("ec_map_draw"), this._controller = new ac(t.getZr()), this._controllerHost = {
- target: e ? i : null
- }, this.group = i, this._updateGroup = e, this._mouseDownFlag, this._mapName, this._initialized, i.add(this._regionsGroup =
- new Zw), i.add(this._backgroundGroup = new Zw)
- }
- function wc(t, e, i) {
- var n = t.getZoom(),
- o = t.getCenter(),
- a = e.zoom,
- r = t.dataToPoint(o);
- if (null != e.dx && null != e.dy) {
- r[0] -= e.dx, r[1] -= e.dy;
- o = t.pointToData(r);
- t.setCenter(o)
- }
- if (null != a) {
- if (i) {
- var s = i.min || 0,
- l = i.max || 1 / 0;
- a = Math.max(Math.min(n * a, l), s) / n
- }
- t.scale[0] *= a, t.scale[1] *= a;
- var u = t.position,
- h = (e.originX - u[0]) * (a - 1),
- c = (e.originY - u[1]) * (a - 1);
- u[0] -= h, u[1] -= c, t.updateTransform();
- o = t.pointToData(r);
- t.setCenter(o), t.setZoom(a * n)
- }
- return {
- center: t.getCenter(),
- zoom: t.getZoom()
- }
- }
- function bc(t, e) {
- var i = {};
- return d(t, function(t) {
- t.each(t.mapDimension("value"), function(e, n) {
- var o = "ec-" + t.getName(n);
- i[o] = i[o] || [], isNaN(e) || i[o].push(e)
- })
- }), t[0].map(t[0].mapDimension("value"), function(n, o) {
- for (var a = "ec-" + t[0].getName(o), r = 0, s = 1 / 0, l = -1 / 0, u = i[a].length, h = 0; h < u; h++) s = Math.min(
- s, i[a][h]), l = Math.max(l, i[a][h]), r += i[a][h];
- var c;
- return c = "min" === e ? s : "max" === e ? l : "average" === e ? r / u : r, 0 === u ? NaN : c
- })
- }
- function Sc(t) {
- var e = t.mainData,
- i = t.datas;
- i || (i = {
- main: e
- }, t.datasAttr = {
- main: "data"
- }), t.datas = t.mainData = null, Cc(e, i, t), MC(i, function(i) {
- MC(e.TRANSFERABLE_METHODS, function(e) {
- i.wrapMethod(e, v(Mc, t))
- })
- }), e.wrapMethod("cloneShallow", v(Tc, t)), MC(e.CHANGABLE_METHODS, function(i) {
- e.wrapMethod(i, v(Ic, t))
- }), k(i[e.dataType] === e)
- }
- function Mc(t, e) {
- if (Dc(this)) {
- var i = a({}, this[IC]);
- i[this.dataType] = e, Cc(e, i, t)
- } else Lc(e, this.dataType, this[TC], t);
- return e
- }
- function Ic(t, e) {
- return t.struct && t.struct.update(this), e
- }
- function Tc(t, e) {
- return MC(e[IC], function(i, n) {
- i !== e && Lc(i.cloneShallow(), n, e, t)
- }), e
- }
- function Ac(t) {
- var e = this[TC];
- return null == t || null == e ? e : e[IC][t]
- }
- function Dc(t) {
- return t[TC] === t
- }
- function Cc(t, e, i) {
- t[IC] = {}, MC(e, function(e, n) {
- Lc(e, n, t, i)
- })
- }
- function Lc(t, e, i, n) {
- i[IC][e] = t, t[TC] = i, t.dataType = e, n.struct && (t[n.structAttr] = n.struct, n.struct[n.datasAttr[e]] = t), t.getLinkedData =
- Ac
- }
- function kc(t, e, i) {
- this.root, this.data, this._nodes = [], this.hostModel = t, this.levelModels = f(e || [], function(e) {
- return new Lo(e, t, t.ecModel)
- }), this.leavesModel = new Lo(i || {}, t, t.ecModel)
- }
- function Pc(t, e) {
- var i = e.children;
- t.parentNode !== e && (i.push(t), t.parentNode = e)
- }
- function Nc(t) {
- t.hierNode = {
- defaultAncestor: null,
- ancestor: t,
- prelim: 0,
- modifier: 0,
- change: 0,
- shift: 0,
- i: 0,
- thread: null
- };
- for (var e, i, n = [t]; e = n.pop();)
- if (i = e.children, e.isExpand && i.length)
- for (var o = i.length - 1; o >= 0; o--) {
- var a = i[o];
- a.hierNode = {
- defaultAncestor: null,
- ancestor: a,
- prelim: 0,
- modifier: 0,
- change: 0,
- shift: 0,
- i: o,
- thread: null
- }, n.push(a)
- }
- }
- function Oc(t, e) {
- var i = t.isExpand ? t.children : [],
- n = t.parentNode.children,
- o = t.hierNode.i ? n[t.hierNode.i - 1] : null;
- if (i.length) {
- Vc(t);
- var a = (i[0].hierNode.prelim + i[i.length - 1].hierNode.prelim) / 2;
- o ? (t.hierNode.prelim = o.hierNode.prelim + e(t, o), t.hierNode.modifier = t.hierNode.prelim - a) : t.hierNode.prelim =
- a
- } else o && (t.hierNode.prelim = o.hierNode.prelim + e(t, o));
- t.parentNode.hierNode.defaultAncestor = Gc(t, o, t.parentNode.hierNode.defaultAncestor || n[0], e)
- }
- function Ec(t) {
- var e = t.hierNode.prelim + t.parentNode.hierNode.modifier;
- t.setLayout({
- x: e
- }, !0), t.hierNode.modifier += t.parentNode.hierNode.modifier
- }
- function Rc(t) {
- return arguments.length ? t : Uc
- }
- function zc(t, e) {
- var i = {};
- return t -= Math.PI / 2, i.x = e * Math.cos(t), i.y = e * Math.sin(t), i
- }
- function Bc(t, e) {
- return la(t.getBoxLayoutParams(), {
- width: e.getWidth(),
- height: e.getHeight()
- })
- }
- function Vc(t) {
- for (var e = t.children, i = e.length, n = 0, o = 0; --i >= 0;) {
- var a = e[i];
- a.hierNode.prelim += n, a.hierNode.modifier += n, o += a.hierNode.change, n += a.hierNode.shift + o
- }
- }
- function Gc(t, e, i, n) {
- if (e) {
- for (var o = t, a = t, r = a.parentNode.children[0], s = e, l = o.hierNode.modifier, u = a.hierNode.modifier, h = r
- .hierNode.modifier, c = s.hierNode.modifier; s = Fc(s), a = Wc(a), s && a;) {
- o = Fc(o), r = Wc(r), o.hierNode.ancestor = t;
- var d = s.hierNode.prelim + c - a.hierNode.prelim - u + n(s, a);
- d > 0 && (Zc(Hc(s, t, i), t, d), u += d, l += d), c += s.hierNode.modifier, u += a.hierNode.modifier, l += o.hierNode
- .modifier, h += r.hierNode.modifier
- }
- s && !Fc(o) && (o.hierNode.thread = s, o.hierNode.modifier += c - l), a && !Wc(r) && (r.hierNode.thread = a, r.hierNode
- .modifier += u - h, i = t)
- }
- return i
- }
- function Fc(t) {
- var e = t.children;
- return e.length && t.isExpand ? e[e.length - 1] : t.hierNode.thread
- }
- function Wc(t) {
- var e = t.children;
- return e.length && t.isExpand ? e[0] : t.hierNode.thread
- }
- function Hc(t, e, i) {
- return t.hierNode.ancestor.parentNode === e.parentNode ? t.hierNode.ancestor : i
- }
- function Zc(t, e, i) {
- var n = i / (e.hierNode.i - t.hierNode.i);
- e.hierNode.change -= n, e.hierNode.shift += i, e.hierNode.modifier += i, e.hierNode.prelim += i, t.hierNode.change +=
- n
- }
- function Uc(t, e) {
- return t.parentNode === e.parentNode ? 1 : 2
- }
- function Xc(t, e) {
- var i = t.getItemLayout(e);
- return i && !isNaN(i.x) && !isNaN(i.y) && "none" !== t.getItemVisual(e, "symbol")
- }
- function jc(t, e, i) {
- return i.itemModel = e, i.itemStyle = e.getModel("itemStyle").getItemStyle(), i.hoverItemStyle = e.getModel(
- "emphasis.itemStyle").getItemStyle(), i.lineStyle = e.getModel("lineStyle").getLineStyle(), i.labelModel = e.getModel(
- "label"), i.hoverLabelModel = e.getModel("emphasis.label"), !1 === t.isExpand && 0 !== t.children.length ? i.symbolInnerColor =
- i.itemStyle.fill : i.symbolInnerColor = "#fff", i
- }
- function Yc(t, e, i, n, o, a) {
- var s = !i,
- l = t.tree.getNodeByDataIndex(e),
- a = jc(l, l.getModel(), a),
- u = t.tree.root,
- h = l.parentNode === u ? l : l.parentNode || l,
- c = t.getItemGraphicEl(h.dataIndex),
- d = h.getLayout(),
- f = c ? {
- x: c.position[0],
- y: c.position[1],
- rawX: c.__radialOldRawX,
- rawY: c.__radialOldRawY
- } : d,
- p = l.getLayout();
- s ? (i = new mu(t, e, a)).attr("position", [f.x, f.y]) : i.updateData(t, e, a), i.__radialOldRawX = i.__radialRawX,
- i.__radialOldRawY = i.__radialRawY, i.__radialRawX = p.rawX, i.__radialRawY = p.rawY, n.add(i), t.setItemGraphicEl(
- e, i), bo(i, {
- position: [p.x, p.y]
- }, o);
- var g = i.getSymbolPath();
- if ("radial" === a.layout) {
- var m, v, y = u.children[0],
- x = y.getLayout(),
- _ = y.children.length;
- if (p.x === x.x && !0 === l.isExpand) {
- var w = {};
- w.x = (y.children[0].getLayout().x + y.children[_ - 1].getLayout().x) / 2, w.y = (y.children[0].getLayout().y + y.children[
- _ - 1].getLayout().y) / 2, (m = Math.atan2(w.y - x.y, w.x - x.x)) < 0 && (m = 2 * Math.PI + m), (v = w.x < x.x) &&
- (m -= Math.PI)
- } else(m = Math.atan2(p.y - x.y, p.x - x.x)) < 0 && (m = 2 * Math.PI + m), 0 === l.children.length || 0 !== l.children
- .length && !1 === l.isExpand ? (v = p.x < x.x) && (m -= Math.PI) : (v = p.x > x.x) || (m -= Math.PI);
- var b = v ? "left" : "right";
- g.setStyle({
- textPosition: b,
- textRotation: -m,
- textOrigin: "center",
- verticalAlign: "middle"
- })
- }
- if (l.parentNode && l.parentNode !== u) {
- var S = i.__edge;
- S || (S = i.__edge = new lM({
- shape: Kc(a, f, f),
- style: r({
- opacity: 0,
- strokeNoScale: !0
- }, a.lineStyle)
- })), bo(S, {
- shape: Kc(a, d, p),
- style: {
- opacity: 1
- }
- }, o), n.add(S)
- }
- }
- function qc(t, e, i, n, o, a) {
- for (var r, s = t.tree.getNodeByDataIndex(e), l = t.tree.root, a = jc(s, s.getModel(), a), u = s.parentNode === l ?
- s : s.parentNode || s; null == (r = u.getLayout());) u = u.parentNode === l ? u : u.parentNode || u;
- bo(i, {
- position: [r.x + 1, r.y + 1]
- }, o, function() {
- n.remove(i), t.setItemGraphicEl(e, null)
- }), i.fadeOut(null, {
- keepLabel: !0
- });
- var h = i.__edge;
- h && bo(h, {
- shape: Kc(a, r, r),
- style: {
- opacity: 0
- }
- }, o, function() {
- n.remove(h)
- })
- }
- function Kc(t, e, i) {
- var n, o, a, r, s, l, u, h, c = t.orient;
- if ("radial" === t.layout) {
- s = e.rawX, u = e.rawY, l = i.rawX, h = i.rawY;
- var d = zc(s, u),
- f = zc(s, u + (h - u) * t.curvature),
- p = zc(l, h + (u - h) * t.curvature),
- g = zc(l, h);
- return {
- x1: d.x,
- y1: d.y,
- x2: g.x,
- y2: g.y,
- cpx1: f.x,
- cpy1: f.y,
- cpx2: p.x,
- cpy2: p.y
- }
- }
- return s = e.x, u = e.y, l = i.x, h = i.y, "LR" !== c && "RL" !== c || (n = s + (l - s) * t.curvature, o = u, a = l +
- (s - l) * t.curvature, r = h), "TB" !== c && "BT" !== c || (n = s, o = u + (h - u) * t.curvature, a = l, r = h + (
- u - h) * t.curvature), {
- x1: s,
- y1: u,
- x2: l,
- y2: h,
- cpx1: n,
- cpy1: o,
- cpx2: a,
- cpy2: r
- }
- }
- function $c(t, e, i) {
- for (var n, o = [t], a = []; n = o.pop();)
- if (a.push(n), n.isExpand) {
- var r = n.children;
- if (r.length)
- for (var s = 0; s < r.length; s++) o.push(r[s])
- } for (; n = a.pop();) e(n, i)
- }
- function Jc(t, e) {
- for (var i, n = [t]; i = n.pop();)
- if (e(i), i.isExpand) {
- var o = i.children;
- if (o.length)
- for (var a = o.length - 1; a >= 0; a--) n.push(o[a])
- }
- }
- function Qc(t, e) {
- var i = Bc(t, e);
- t.layoutInfo = i;
- var n = t.get("layout"),
- o = 0,
- a = 0,
- r = null;
- "radial" === n ? (o = 2 * Math.PI, a = Math.min(i.height, i.width) / 2, r = Rc(function(t, e) {
- return (t.parentNode === e.parentNode ? 1 : 2) / t.depth
- })) : (o = i.width, a = i.height, r = Rc());
- var s = t.getData().tree.root,
- l = s.children[0];
- if (l) {
- Nc(s), $c(l, Oc, r), s.hierNode.modifier = -l.hierNode.prelim, Jc(l, Ec);
- var u = l,
- h = l,
- c = l;
- Jc(l, function(t) {
- var e = t.getLayout().x;
- e < u.getLayout().x && (u = t), e > h.getLayout().x && (h = t), t.depth > c.depth && (c = t)
- });
- var d = u === h ? 1 : r(u, h) / 2,
- f = d - u.getLayout().x,
- p = 0,
- g = 0,
- m = 0,
- v = 0;
- if ("radial" === n) p = o / (h.getLayout().x + d + f), g = a / (c.depth - 1 || 1), Jc(l, function(t) {
- m = (t.getLayout().x + f) * p, v = (t.depth - 1) * g;
- var e = zc(m, v);
- t.setLayout({
- x: e.x,
- y: e.y,
- rawX: m,
- rawY: v
- }, !0)
- });
- else {
- var y = t.getOrient();
- "RL" === y || "LR" === y ? (g = a / (h.getLayout().x + d + f), p = o / (c.depth - 1 || 1), Jc(l, function(t) {
- v = (t.getLayout().x + f) * g, m = "LR" === y ? (t.depth - 1) * p : o - (t.depth - 1) * p, t.setLayout({
- x: m,
- y: v
- }, !0)
- })) : "TB" !== y && "BT" !== y || (p = o / (h.getLayout().x + d + f), g = a / (c.depth - 1 || 1), Jc(l, function(
- t) {
- m = (t.getLayout().x + f) * p, v = "TB" === y ? (t.depth - 1) * g : a - (t.depth - 1) * g, t.setLayout({
- x: m,
- y: v
- }, !0)
- }))
- }
- }
- }
- function td(t, e, i) {
- if (t && l(e, t.type) >= 0) {
- var n = i.getData().tree.root,
- o = t.targetNode;
- if ("string" == typeof o && (o = n.getNodeById(o)), o && n.contains(o)) return {
- node: o
- };
- var a = t.targetNodeId;
- if (null != a && (o = n.getNodeById(a))) return {
- node: o
- }
- }
- }
- function ed(t) {
- for (var e = []; t;)(t = t.parentNode) && e.push(t);
- return e.reverse()
- }
- function id(t, e) {
- return l(ed(t), e) >= 0
- }
- function nd(t, e) {
- for (var i = []; t;) {
- var n = t.dataIndex;
- i.push({
- name: t.name,
- dataIndex: n,
- value: e.getRawValue(n)
- }), t = t.parentNode
- }
- return i.reverse(), i
- }
- function od(t) {
- var e = 0;
- d(t.children, function(t) {
- od(t);
- var i = t.value;
- y(i) && (i = i[0]), e += i
- });
- var i = t.value;
- y(i) && (i = i[0]), (null == i || isNaN(i)) && (i = e), i < 0 && (i = 0), y(t.value) ? t.value[0] = i : t.value = i
- }
- function ad(t, e) {
- var i = e.get("color");
- if (i) {
- var n;
- return d(t = t || [], function(t) {
- var e = new Lo(t),
- i = e.get("color");
- (e.get("itemStyle.color") || i && "none" !== i) && (n = !0)
- }), n || ((t[0] || (t[0] = {})).color = i.slice()), t
- }
- }
- function rd(t) {
- this.group = new Zw, t.add(this.group)
- }
- function sd(t, e, i, n, o, a) {
- var r = [
- [o ? t : t - DC, e],
- [t + i, e],
- [t + i, e + n],
- [o ? t : t - DC, e + n]
- ];
- return !a && r.splice(2, 0, [t + i + DC, e + n / 2]), !o && r.push([t, e + n / 2]), r
- }
- function ld(t, e, i) {
- t.eventData = {
- componentType: "series",
- componentSubType: "treemap",
- componentIndex: e.componentIndex,
- seriesIndex: e.componentIndex,
- seriesName: e.name,
- seriesType: "treemap",
- selfType: "breadcrumb",
- nodeData: {
- dataIndex: i && i.dataIndex,
- name: i && i.name
- },
- treePathInfo: i && nd(i, e)
- }
- }
- function ud() {
- var t, e = [],
- i = {};
- return {
- add: function(t, n, o, a, r) {
- return _(a) && (r = a, a = 0), !i[t.id] && (i[t.id] = 1, e.push({
- el: t,
- target: n,
- time: o,
- delay: a,
- easing: r
- }), !0)
- },
- done: function(e) {
- return t = e, this
- },
- start: function() {
- for (var n = e.length, o = 0, a = e.length; o < a; o++) {
- var r = e[o];
- r.el.animateTo(r.target, r.time, r.delay, r.easing, function() {
- --n || (e.length = 0, i = {}, t && t())
- })
- }
- return this
- }
- }
- }
- function hd(t, e, n, o, r, s, l, u, h, c) {
- function d(t, e) {
- w ? !t.invisible && s.push(t) : (e(), t.__tmWillVisible || (t.invisible = !1))
- }
- function f(e, n, o, a, r, s) {
- var u = l.getModel(),
- h = T(t.getFormattedLabel(l.dataIndex, "normal", null, null, s ? "upperLabel" : "label"), u.get("name"));
- if (!s && v.isLeafRoot) {
- var c = t.get("drillDownIcon", !0);
- h = c ? c + " " + h : h
- }
- var d = u.getModel(s ? EC : NC),
- f = u.getModel(s ? RC : OC),
- p = d.getShallow("show");
- co(e, n, d, f, {
- defaultText: p ? h : null,
- autoColor: o,
- isRectText: !0
- }), s && (e.textRect = i(s)), e.truncate = p && d.get("ellipsis") ? {
- outerWidth: a,
- outerHeight: r,
- minChar: 2
- } : null
- }
- function p(t, i, o, a) {
- var s = null != S && n[t][S],
- l = r[t];
- return s ? (n[t][S] = null, g(l, s, t)) : w || ((s = new i({
- z: cd(o, a)
- })).__tmDepth = o, s.__tmStorageName = t, m(l, s, t)), e[t][b] = s
- }
- function g(t, e, i) {
- (t[b] = {}).old = "nodeGroup" === i ? e.position.slice() : a({}, e.shape)
- }
- function m(t, e, i) {
- var n = t[b] = {},
- a = l.parentNode;
- if (a && (!o || "drillDown" === o.direction)) {
- var s = 0,
- u = 0,
- h = r.background[a.getRawIndex()];
- !o && h && h.old && (s = h.old.width, u = h.old.height), n.old = "nodeGroup" === i ? [0, u] : {
- x: s,
- y: u,
- width: 0,
- height: 0
- }
- }
- n.fadein = "nodeGroup" !== i
- }
- if (l) {
- var v = l.getLayout();
- if (v && v.isInView) {
- var y = v.width,
- x = v.height,
- _ = v.borderWidth,
- w = v.invisible,
- b = l.getRawIndex(),
- S = u && u.getRawIndex(),
- M = l.viewChildren,
- I = v.upperHeight,
- A = M && M.length,
- D = l.getModel("itemStyle"),
- C = l.getModel("emphasis.itemStyle"),
- L = p("nodeGroup", LC);
- if (L) {
- if (h.add(L), L.attr("position", [v.x || 0, v.y || 0]), L.__tmNodeWidth = y, L.__tmNodeHeight = x, v.isAboveViewRoot)
- return L;
- var k = p("background", kC, c, BC);
- if (k && function(e, i, n) {
- i.dataIndex = l.dataIndex, i.seriesIndex = t.seriesIndex, i.setShape({
- x: 0,
- y: 0,
- width: y,
- height: x
- });
- var o = l.getVisual("borderColor", !0),
- a = C.get("borderColor");
- d(i, function() {
- var t = FC(D);
- t.fill = o;
- var e = GC(C);
- if (e.fill = a, n) {
- var r = y - 2 * _;
- f(t, e, o, r, I, {
- x: _,
- y: 0,
- width: r,
- height: I
- })
- } else t.text = e.text = null;
- i.setStyle(t), uo(i, e)
- }), e.add(i)
- }(L, k, A && v.upperHeight), !A) {
- var P = p("content", kC, c, VC);
- P && function(e, i) {
- i.dataIndex = l.dataIndex, i.seriesIndex = t.seriesIndex;
- var n = Math.max(y - 2 * _, 0),
- o = Math.max(x - 2 * _, 0);
- i.culling = !0, i.setShape({
- x: _,
- y: _,
- width: n,
- height: o
- });
- var a = l.getVisual("color", !0);
- d(i, function() {
- var t = FC(D);
- t.fill = a;
- var e = GC(C);
- f(t, e, a, n, o), i.setStyle(t), uo(i, e)
- }), e.add(i)
- }(L, P)
- }
- return L
- }
- }
- }
- }
- function cd(t, e) {
- var i = t * zC + e;
- return (i - 1) / i
- }
- function dd(t) {
- var e = t.pieceList;
- t.hasSpecialVisual = !1, d(e, function(e, i) {
- e.originIndex = i, null != e.visual && (t.hasSpecialVisual = !0)
- })
- }
- function fd(t) {
- var e = t.categories,
- i = t.visual,
- n = t.categoryMap = {};
- if (ZC(e, function(t, e) {
- n[t] = e
- }), !y(i)) {
- var o = [];
- w(i) ? ZC(i, function(t, e) {
- var i = n[e];
- o[null != i ? i : XC] = t
- }) : o[XC] = i, i = bd(t, o)
- }
- for (var a = e.length - 1; a >= 0; a--) null == i[a] && (delete n[e[a]], e.pop())
- }
- function pd(t, e) {
- var i = t.visual,
- n = [];
- w(i) ? ZC(i, function(t) {
- n.push(t)
- }) : null != i && n.push(i);
- var o = {
- color: 1,
- symbol: 1
- };
- e || 1 !== n.length || o.hasOwnProperty(t.type) || (n[1] = n[0]), bd(t, n)
- }
- function gd(t) {
- return {
- applyVisual: function(e, i, n) {
- e = this.mapValueToVisual(e), n("color", t(i("color"), e))
- },
- _doMap: _d([0, 1])
- }
- }
- function md(t) {
- var e = this.option.visual;
- return e[Math.round(Eo(t, [0, 1], [0, e.length - 1], !0))] || {}
- }
- function vd(t) {
- return function(e, i, n) {
- n(t, this.mapValueToVisual(e))
- }
- }
- function yd(t) {
- var e = this.option.visual;
- return e[this.option.loop && t !== XC ? t % e.length : t]
- }
- function xd() {
- return this.option.visual[0]
- }
- function _d(t) {
- return {
- linear: function(e) {
- return Eo(e, t, this.option.visual, !0)
- },
- category: yd,
- piecewise: function(e, i) {
- var n = wd.call(this, i);
- return null == n && (n = Eo(e, t, this.option.visual, !0)), n
- },
- fixed: xd
- }
- }
- function wd(t) {
- var e = this.option,
- i = e.pieceList;
- if (e.hasSpecialVisual) {
- var n = i[jC.findPieceIndex(t, i)];
- if (n && n.visual) return n.visual[this.type]
- }
- }
- function bd(t, e) {
- return t.visual = e, "color" === t.type && (t.parsedVisual = f(e, function(t) {
- return zt(t)
- })), e
- }
- function Sd(t, e, i) {
- return t ? e <= i : e < i
- }
- function Md(t, e, i, n, o, a) {
- var r = t.getModel(),
- s = t.getLayout();
- if (s && !s.invisible && s.isInView) {
- var l, u = t.getModel($C),
- h = Id(u, e, i[t.depth], n),
- c = u.get("borderColor"),
- f = u.get("borderColorSaturation");
- null != f && (c = Ad(f, l = Td(h))), t.setVisual("borderColor", c);
- var p = t.viewChildren;
- if (p && p.length) {
- var g = Cd(t, r, s, u, h, p);
- d(p, function(t, e) {
- (t.depth >= o.length || t === o[t.depth]) && Md(t, kd(r, h, t, e, g, a), i, n, o, a)
- })
- } else l = Td(h), t.setVisual("color", l)
- }
- }
- function Id(t, e, i, n) {
- var o = a({}, e);
- return d(["color", "colorAlpha", "colorSaturation"], function(a) {
- var r = t.get(a, !0);
- null == r && i && (r = i[a]), null == r && (r = e[a]), null == r && (r = n.get(a)), null != r && (o[a] = r)
- }), o
- }
- function Td(t) {
- var e = Dd(t, "color");
- if (e) {
- var i = Dd(t, "colorAlpha"),
- n = Dd(t, "colorSaturation");
- return n && (e = Zt(e, null, null, n)), i && (e = Ut(e, i)), e
- }
- }
- function Ad(t, e) {
- return null != e ? Zt(e, null, null, t) : null
- }
- function Dd(t, e) {
- var i = t[e];
- if (null != i && "none" !== i) return i
- }
- function Cd(t, e, i, n, o, a) {
- if (a && a.length) {
- var r = Ld(e, "color") || null != o.color && "none" !== o.color && (Ld(e, "colorAlpha") || Ld(e, "colorSaturation"));
- if (r) {
- var s = e.get("visualMin"),
- l = e.get("visualMax"),
- u = i.dataExtent.slice();
- null != s && s < u[0] && (u[0] = s), null != l && l > u[1] && (u[1] = l);
- var h = e.get("colorMappingBy"),
- c = {
- type: r.name,
- dataExtent: u,
- visual: r.range
- };
- "color" !== c.type || "index" !== h && "id" !== h ? c.mappingMethod = "linear" : (c.mappingMethod = "category", c.loop = !
- 0);
- var d = new jC(c);
- return d.__drColorMappingBy = h, d
- }
- }
- }
- function Ld(t, e) {
- var i = t.get(e);
- return KC(i) && i.length ? {
- name: e,
- range: i
- } : null
- }
- function kd(t, e, i, n, o, r) {
- var s = a({}, e);
- if (o) {
- var l = o.type,
- u = "color" === l && o.__drColorMappingBy,
- h = "index" === u ? n : "id" === u ? r.mapIdToIndex(i.getId()) : i.getValue(t.get("visualDimension"));
- s[l] = o.mapValueToVisual(h)
- }
- return s
- }
- function Pd(t, e, i, n) {
- var o, a;
- if (!t.isRemoved()) {
- var r = t.getLayout();
- o = r.width, a = r.height;
- var s = (f = t.getModel()).get(nL),
- l = f.get(oL) / 2,
- u = Wd(f),
- h = Math.max(s, u),
- c = s - l,
- d = h - l,
- f = t.getModel();
- t.setLayout({
- borderWidth: s,
- upperHeight: h,
- upperLabelHeight: u
- }, !0);
- var p = (o = QC(o - 2 * c, 0)) * (a = QC(a - c - d, 0)),
- g = Nd(t, f, p, e, i, n);
- if (g.length) {
- var m = {
- x: c,
- y: d,
- width: o,
- height: a
- },
- v = tL(o, a),
- y = 1 / 0,
- x = [];
- x.area = 0;
- for (var _ = 0, w = g.length; _ < w;) {
- var b = g[_];
- x.push(b), x.area += b.getLayout().area;
- var S = zd(x, v, e.squareRatio);
- S <= y ? (_++, y = S) : (x.area -= x.pop().getLayout().area, Bd(x, v, m, l, !1), v = tL(m.width, m.height), x.length =
- x.area = 0, y = 1 / 0)
- }
- if (x.length && Bd(x, v, m, l, !0), !i) {
- var M = f.get("childrenVisibleMin");
- null != M && p < M && (i = !0)
- }
- for (var _ = 0, w = g.length; _ < w; _++) Pd(g[_], e, i, n + 1)
- }
- }
- }
- function Nd(t, e, i, n, o, a) {
- var r = t.children || [],
- s = n.sort;
- "asc" !== s && "desc" !== s && (s = null);
- var l = null != n.leafDepth && n.leafDepth <= a;
- if (o && !l) return t.viewChildren = [];
- Ed(r = g(r, function(t) {
- return !t.isRemoved()
- }), s);
- var u = Rd(e, r, s);
- if (0 === u.sum) return t.viewChildren = [];
- if (u.sum = Od(e, i, u.sum, s, r), 0 === u.sum) return t.viewChildren = [];
- for (var h = 0, c = r.length; h < c; h++) {
- var d = r[h].getValue() / u.sum * i;
- r[h].setLayout({
- area: d
- })
- }
- return l && (r.length && t.setLayout({
- isLeafRoot: !0
- }, !0), r.length = 0), t.viewChildren = r, t.setLayout({
- dataExtent: u.dataExtent
- }, !0), r
- }
- function Od(t, e, i, n, o) {
- if (!n) return i;
- for (var a = t.get("visibleMin"), r = o.length, s = r, l = r - 1; l >= 0; l--) {
- var u = o["asc" === n ? r - l - 1 : l].getValue();
- u / i * e < a && (s = l, i -= u)
- }
- return "asc" === n ? o.splice(0, r - s) : o.splice(s, r - s), i
- }
- function Ed(t, e) {
- return e && t.sort(function(t, i) {
- var n = "asc" === e ? t.getValue() - i.getValue() : i.getValue() - t.getValue();
- return 0 === n ? "asc" === e ? t.dataIndex - i.dataIndex : i.dataIndex - t.dataIndex : n
- }), t
- }
- function Rd(t, e, i) {
- for (var n = 0, o = 0, a = e.length; o < a; o++) n += e[o].getValue();
- var r = t.get("visualDimension");
- if (e && e.length)
- if ("value" === r && i) s = [e[e.length - 1].getValue(), e[0].getValue()], "asc" === i && s.reverse();
- else {
- var s = [1 / 0, -1 / 0];
- iL(e, function(t) {
- var e = t.getValue(r);
- e < s[0] && (s[0] = e), e > s[1] && (s[1] = e)
- })
- }
- else s = [NaN, NaN];
- return {
- sum: n,
- dataExtent: s
- }
- }
- function zd(t, e, i) {
- for (var n, o = 0, a = 1 / 0, r = 0, s = t.length; r < s; r++)(n = t[r].getLayout().area) && (n < a && (a = n), n >
- o && (o = n));
- var l = t.area * t.area,
- u = e * e * i;
- return l ? QC(u * o / l, l / (u * a)) : 1 / 0
- }
- function Bd(t, e, i, n, o) {
- var a = e === i.width ? 0 : 1,
- r = 1 - a,
- s = ["x", "y"],
- l = ["width", "height"],
- u = i[s[a]],
- h = e ? t.area / e : 0;
- (o || h > i[l[r]]) && (h = i[l[r]]);
- for (var c = 0, d = t.length; c < d; c++) {
- var f = t[c],
- p = {},
- g = h ? f.getLayout().area / h : 0,
- m = p[l[r]] = QC(h - 2 * n, 0),
- v = i[s[a]] + i[l[a]] - u,
- y = c === d - 1 || v < g ? v : g,
- x = p[l[a]] = QC(y - 2 * n, 0);
- p[s[r]] = i[s[r]] + tL(n, m / 2), p[s[a]] = u + tL(n, x / 2), u += y, f.setLayout(p, !0)
- }
- i[s[r]] += h, i[l[r]] -= h
- }
- function Vd(t, e, i, n, o) {
- var a = (e || {}).node,
- r = [n, o];
- if (!a || a === i) return r;
- for (var s, l = n * o, u = l * t.option.zoomToNodeRatio; s = a.parentNode;) {
- for (var h = 0, c = s.children, d = 0, f = c.length; d < f; d++) h += c[d].getValue();
- var p = a.getValue();
- if (0 === p) return r;
- u *= h / p;
- var g = s.getModel(),
- m = g.get(nL);
- (u += 4 * m * m + (3 * m + Math.max(m, Wd(g))) * Math.pow(u, .5)) > kM && (u = kM), a = s
- }
- u < l && (u = l);
- var v = Math.pow(u / l, .5);
- return [n * v, o * v]
- }
- function Gd(t, e, i) {
- if (e) return {
- x: e.x,
- y: e.y
- };
- var n = {
- x: 0,
- y: 0
- };
- if (!i) return n;
- var o = i.node,
- a = o.getLayout();
- if (!a) return n;
- for (var r = [a.width / 2, a.height / 2], s = o; s;) {
- var l = s.getLayout();
- r[0] += l.x, r[1] += l.y, s = s.parentNode
- }
- return {
- x: t.width / 2 - r[0],
- y: t.height / 2 - r[1]
- }
- }
- function Fd(t, e, i, n, o) {
- var a = t.getLayout(),
- r = i[o],
- s = r && r === t;
- if (!(r && !s || o === i.length && t !== n)) {
- t.setLayout({
- isInView: !0,
- invisible: !s && !e.intersect(a),
- isAboveViewRoot: s
- }, !0);
- var l = new ue(e.x - a.x, e.y - a.y, e.width, e.height);
- iL(t.viewChildren || [], function(t) {
- Fd(t, l, i, n, o + 1)
- })
- }
- }
- function Wd(t) {
- return t.get(aL) ? t.get(rL) : 0
- }
- function Hd(t) {
- return "_EC_" + t
- }
- function Zd(t, e) {
- this.id = null == t ? "" : t, this.inEdges = [], this.outEdges = [], this.edges = [], this.hostGraph, this.dataIndex =
- null == e ? -1 : e
- }
- function Ud(t, e, i) {
- this.node1 = t, this.node2 = e, this.dataIndex = null == i ? -1 : i
- }
- function Xd(t) {
- return isNaN(+t.cpx1) || isNaN(+t.cpy1)
- }
- function jd(t) {
- return "_" + t + "Type"
- }
- function Yd(t, e, i) {
- var n = e.getItemVisual(i, "color"),
- o = e.getItemVisual(i, t),
- a = e.getItemVisual(i, t + "Size");
- if (o && "none" !== o) {
- y(a) || (a = [a, a]);
- var r = Xl(o, -a[0] / 2, -a[1] / 2, a[0], a[1], n);
- return r.name = t, r
- }
- }
- function qd(t) {
- var e = new gL({
- name: "line"
- });
- return Kd(e.shape, t), e
- }
- function Kd(t, e) {
- var i = e[0],
- n = e[1],
- o = e[2];
- t.x1 = i[0], t.y1 = i[1], t.x2 = n[0], t.y2 = n[1], t.percent = 1, o ? (t.cpx1 = o[0], t.cpy1 = o[1]) : (t.cpx1 =
- NaN, t.cpy1 = NaN)
- }
- function $d(t, e, i) {
- Zw.call(this), this._createLine(t, e, i)
- }
- function Jd(t) {
- this._ctor = t || $d, this.group = new Zw
- }
- function Qd(t, e, i, n) {
- if ( of (e.getItemLayout(i))) {
- var o = new t._ctor(e, i, n);
- e.setItemGraphicEl(i, o), t.group.add(o)
- }
- }
- function tf(t, e, i, n, o, a) {
- var r = e.getItemGraphicEl(n); of (i.getItemLayout(o)) ? (r ? r.updateData(i, o, a) : r = new t._ctor(i, o, a), i.setItemGraphicEl(
- o, r), t.group.add(r)) : t.group.remove(r)
- }
- function ef(t) {
- var e = t.hostModel;
- return {
- lineStyle: e.getModel("lineStyle").getLineStyle(),
- hoverLineStyle: e.getModel("emphasis.lineStyle").getLineStyle(),
- labelModel: e.getModel("label"),
- hoverLabelModel: e.getModel("emphasis.label")
- }
- }
- function nf(t) {
- return isNaN(t[0]) || isNaN(t[1])
- }
- function of (t) {
- return !nf(t[0]) && !nf(t[1])
- }
- function af(t, e, i) {
- for (var n, o = t[0], a = t[1], r = t[2], s = 1 / 0, l = i * i, u = .1, h = .1; h <= .9; h += .1) xL[0] = bL(o[0], a[
- 0], r[0], h), xL[1] = bL(o[1], a[1], r[1], h), (f = ML(SL(xL, e) - l)) < s && (s = f, n = h);
- for (var c = 0; c < 32; c++) {
- var d = n + u;
- _L[0] = bL(o[0], a[0], r[0], n), _L[1] = bL(o[1], a[1], r[1], n), wL[0] = bL(o[0], a[0], r[0], d), wL[1] = bL(o[1],
- a[1], r[1], d);
- var f = SL(_L, e) - l;
- if (ML(f) < .01) break;
- var p = SL(wL, e) - l;
- u /= 2, f < 0 ? p >= 0 ? n += u : n -= u : p >= 0 ? n -= u : n += u
- }
- return n
- }
- function rf(t, e) {
- return t.getVisual("opacity") || t.getModel().get(e)
- }
- function sf(t, e, i) {
- var n = t.getGraphicEl(),
- o = rf(t, e);
- null != i && (null == o && (o = 1), o *= i), n.downplay && n.downplay(), n.traverse(function(t) {
- "group" !== t.type && t.setStyle("opacity", o)
- })
- }
- function lf(t, e) {
- var i = rf(t, e),
- n = t.getGraphicEl();
- n.highlight && n.highlight(), n.traverse(function(t) {
- "group" !== t.type && t.setStyle("opacity", i)
- })
- }
- function uf(t) {
- return t instanceof Array || (t = [t, t]), t
- }
- function hf(t) {
- var e = t.coordinateSystem;
- if (!e || "view" === e.type) {
- var i = t.getGraph();
- i.eachNode(function(t) {
- var e = t.getModel();
- t.setLayout([+e.get("x"), +e.get("y")])
- }), cf(i)
- }
- }
- function cf(t) {
- t.eachEdge(function(t) {
- var e = t.getModel().get("lineStyle.curveness") || 0,
- i = F(t.node1.getLayout()),
- n = F(t.node2.getLayout()),
- o = [i, n]; + e && o.push([(i[0] + n[0]) / 2 - (i[1] - n[1]) * e, (i[1] + n[1]) / 2 - (n[0] - i[0]) * e]), t.setLayout(
- o)
- })
- }
- function df(t) {
- var e = t.coordinateSystem;
- if (!e || "view" === e.type) {
- var i = e.getBoundingRect(),
- n = t.getData(),
- o = n.graph,
- a = 0,
- r = n.getSum("value"),
- s = 2 * Math.PI / (r || n.count()),
- l = i.width / 2 + i.x,
- u = i.height / 2 + i.y,
- h = Math.min(i.width, i.height) / 2;
- o.eachNode(function(t) {
- var e = t.getValue("value");
- a += s * (r ? e : 1) / 2, t.setLayout([h * Math.cos(a) + l, h * Math.sin(a) + u]), a += s * (r ? e : 1) / 2
- }), n.setLayout({
- cx: l,
- cy: u
- }), o.eachEdge(function(t) {
- var e, i = t.getModel().get("lineStyle.curveness") || 0,
- n = F(t.node1.getLayout()),
- o = F(t.node2.getLayout()),
- a = (n[0] + o[0]) / 2,
- r = (n[1] + o[1]) / 2; + i && (e = [l * (i *= 3) + a * (1 - i), u * i + r * (1 - i)]), t.setLayout([n, o, e])
- })
- }
- }
- function ff(t, e, i) {
- for (var n = i.rect, o = n.width, a = n.height, r = [n.x + o / 2, n.y + a / 2], s = null == i.gravity ? .1 : i.gravity,
- l = 0; l < t.length; l++) {
- var u = t[l];
- u.p || (u.p = V(o * (Math.random() - .5) + r[0], a * (Math.random() - .5) + r[1])), u.pp = F(u.p), u.edges = null
- }
- var h = .6;
- return {
- warmUp: function() {
- h = .5
- },
- setFixed: function(e) {
- t[e].fixed = !0
- },
- setUnfixed: function(e) {
- t[e].fixed = !1
- },
- step: function(i) {
- for (var n = [], o = t.length, a = 0; a < e.length; a++) {
- var l = e[a],
- u = l.n1;
- U(n, (p = l.n2).p, u.p);
- var c = X(n) - l.d,
- d = p.w / (u.w + p.w);
- isNaN(d) && (d = 0), q(n, n), !u.fixed && DL(u.p, u.p, n, d * c * h), !p.fixed && DL(p.p, p.p, n, -(1 - d) * c *
- h)
- }
- for (a = 0; a < o; a++)(v = t[a]).fixed || (U(n, r, v.p), DL(v.p, v.p, n, s * h));
- for (a = 0; a < o; a++)
- for (var u = t[a], f = a + 1; f < o; f++) {
- var p = t[f];
- U(n, p.p, u.p), 0 === (c = X(n)) && (W(n, Math.random() - .5, Math.random() - .5), c = 1);
- var g = (u.rep + p.rep) / c / c;
- !u.fixed && DL(u.pp, u.pp, n, g), !p.fixed && DL(p.pp, p.pp, n, -g)
- }
- for (var m = [], a = 0; a < o; a++) {
- var v = t[a];
- v.fixed || (U(m, v.p, v.pp), DL(v.p, v.p, m, h), G(v.pp, v.p))
- }
- h *= .992, i && i(t, e, h < .01)
- }
- }
- }
- function pf(t, e, i) {
- var n = t.getBoxLayoutParams();
- return n.aspect = i, la(n, {
- width: e.getWidth(),
- height: e.getHeight()
- })
- }
- function gf(t, e) {
- var i = t.get("center"),
- n = e.getWidth(),
- o = e.getHeight(),
- a = Math.min(n, o);
- return {
- cx: Ro(i[0], e.getWidth()),
- cy: Ro(i[1], e.getHeight()),
- r: Ro(t.get("radius"), a / 2)
- }
- }
- function mf(t, e) {
- return e && ("string" == typeof e ? t = e.replace("{value}", null != t ? t : "") : "function" == typeof e && (t = e(
- t))), t
- }
- function vf(t, e) {
- function i() {
- a.ignore = a.hoverIgnore, r.ignore = r.hoverIgnore
- }
- function n() {
- a.ignore = a.normalIgnore, r.ignore = r.normalIgnore
- }
- Zw.call(this);
- var o = new nM,
- a = new oM,
- r = new qS;
- this.add(o), this.add(a), this.add(r), this.updateData(t, e, !0), this.on("emphasis", i).on("normal", n).on(
- "mouseover", i).on("mouseout", n)
- }
- function yf(t, e) {
- return la(t.getBoxLayoutParams(), {
- width: e.getWidth(),
- height: e.getHeight()
- })
- }
- function xf(t, e) {
- for (var i = t.mapDimension("value"), n = t.mapArray(i, function(t) {
- return t
- }), o = [], a = "ascending" === e, r = 0, s = t.count(); r < s; r++) o[r] = r;
- return "function" == typeof e ? o.sort(e) : "none" !== e && o.sort(function(t, e) {
- return a ? n[t] - n[e] : n[e] - n[t]
- }), o
- }
- function _f(t) {
- t.each(function(e) {
- var i, n, o, a, r = t.getItemModel(e),
- s = r.getModel("label").get("position"),
- l = r.getModel("labelLine"),
- u = t.getItemLayout(e),
- h = u.points,
- c = "inner" === s || "inside" === s || "center" === s;
- if (c) i = "center", a = [
- [n = (h[0][0] + h[1][0] + h[2][0] + h[3][0]) / 4, o = (h[0][1] + h[1][1] + h[2][1] + h[3][1]) / 4],
- [n, o]
- ];
- else {
- var d, f, p, g = l.get("length");
- "left" === s ? (d = (h[3][0] + h[0][0]) / 2, f = (h[3][1] + h[0][1]) / 2, n = (p = d - g) - 5, i = "right") : (d =
- (h[1][0] + h[2][0]) / 2, f = (h[1][1] + h[2][1]) / 2, n = (p = d + g) + 5, i = "left");
- var m = f;
- a = [
- [d, f],
- [p, m]
- ], o = m
- }
- u.label = {
- linePoints: a,
- x: n,
- y: o,
- verticalAlign: "middle",
- textAlign: i,
- inside: c
- }
- })
- }
- function wf(t) {
- if (!t.parallel) {
- var e = !1;
- d(t.series, function(t) {
- t && "parallel" === t.type && (e = !0)
- }), e && (t.parallel = [{}])
- }
- }
- function bf(t) {
- d(Di(t.parallelAxis), function(e) {
- if (w(e)) {
- var i = e.parallelIndex || 0,
- o = Di(t.parallel)[i];
- o && o.parallelAxisDefault && n(e, o.parallelAxisDefault, !1)
- }
- })
- }
- function Sf(t, e) {
- var i = t[e] - t[1 - e];
- return {
- span: Math.abs(i),
- sign: i > 0 ? -1 : i < 0 ? 1 : e ? -1 : 1
- }
- }
- function Mf(t, e) {
- return Math.min(e[1], Math.max(e[0], t))
- }
- function If(t, e, i) {
- this._axesMap = R(), this._axesLayout = {}, this.dimensions = t.dimensions, this._rect, this._model = t, this._init(
- t, e, i)
- }
- function Tf(t, e) {
- return zL(BL(t, e[0]), e[1])
- }
- function Af(t, e) {
- var i = e.layoutLength / (e.axisCount - 1);
- return {
- position: i * t,
- axisNameAvailableWidth: i,
- axisLabelShow: !0
- }
- }
- function Df(t, e) {
- var i, n, o = e.layoutLength,
- a = e.axisExpandWidth,
- r = e.axisCount,
- s = e.axisCollapseWidth,
- l = e.winInnerIndices,
- u = s,
- h = !1;
- return t < l[0] ? (i = t * s, n = s) : t <= l[1] ? (i = e.axisExpandWindow0Pos + t * a - e.axisExpandWindow[0], u =
- a, h = !0) : (i = o - (r - 1 - t) * s, n = s), {
- position: i,
- axisNameAvailableWidth: u,
- axisLabelShow: h,
- nameTruncateMaxWidth: n
- }
- }
- function Cf(t) {
- aw.call(this), this._zr = t, this.group = new Zw, this._brushType, this._brushOption, this._panels, this._track = [],
- this._dragging, this._covers = [], this._creatingCover, this._creatingPanel, this._enableGlobalPan, this._uid =
- "brushController_" + ok++, this._handlers = {}, XL(ak, function(t, e) {
- this._handlers[e] = m(t, this)
- }, this)
- }
- function Lf(t, e) {
- var o = t._zr;
- t._enableGlobalPan || ec(o, tk, t._uid), XL(t._handlers, function(t, e) {
- o.on(e, t)
- }), t._brushType = e.brushType, t._brushOption = n(i(nk), e, !0)
- }
- function kf(t) {
- var e = t._zr;
- ic(e, tk, t._uid), XL(t._handlers, function(t, i) {
- e.off(i, t)
- }), t._brushType = t._brushOption = null
- }
- function Pf(t, e) {
- var i = rk[e.brushType].createCover(t, e);
- return i.__brushOption = e, Ef(i, e), t.group.add(i), i
- }
- function Nf(t, e) {
- var i = zf(e);
- return i.endCreating && (i.endCreating(t, e), Ef(e, e.__brushOption)), e
- }
- function Of(t, e) {
- var i = e.__brushOption;
- zf(e).updateCoverShape(t, e, i.range, i)
- }
- function Ef(t, e) {
- var i = e.z;
- null == i && (i = $L), t.traverse(function(t) {
- t.z = i, t.z2 = i
- })
- }
- function Rf(t, e) {
- zf(e).updateCommon(t, e), Of(t, e)
- }
- function zf(t) {
- return rk[t.__brushOption.brushType]
- }
- function Bf(t, e, i) {
- var n = t._panels;
- if (!n) return !0;
- var o, a = t._transform;
- return XL(n, function(t) {
- t.isTargetByCursor(e, i, a) && (o = t)
- }), o
- }
- function Vf(t, e) {
- var i = t._panels;
- if (!i) return !0;
- var n = e.__brushOption.panelId;
- return null == n || i[n]
- }
- function Gf(t) {
- var e = t._covers,
- i = e.length;
- return XL(e, function(e) {
- t.group.remove(e)
- }, t), e.length = 0, !!i
- }
- function Ff(t, e) {
- var n = jL(t._covers, function(t) {
- var e = t.__brushOption,
- n = i(e.range);
- return {
- brushType: e.brushType,
- panelId: e.panelId,
- range: n
- }
- });
- t.trigger("brush", n, {
- isEnd: !!e.isEnd,
- removeOnClick: !!e.removeOnClick
- })
- }
- function Wf(t) {
- var e = t._track;
- if (!e.length) return !1;
- var i = e[e.length - 1],
- n = e[0],
- o = i[0] - n[0],
- a = i[1] - n[1];
- return KL(o * o + a * a, .5) > JL
- }
- function Hf(t) {
- var e = t.length - 1;
- return e < 0 && (e = 0), [t[0], t[e]]
- }
- function Zf(t, e, i, n) {
- var o = new Zw;
- return o.add(new aM({
- name: "main",
- style: Yf(i),
- silent: !0,
- draggable: !0,
- cursor: "move",
- drift: UL(t, e, o, "nswe"),
- ondragend: UL(Ff, e, {
- isEnd: !0
- })
- })), XL(n, function(i) {
- o.add(new aM({
- name: i,
- style: {
- opacity: 0
- },
- draggable: !0,
- silent: !0,
- invisible: !0,
- drift: UL(t, e, o, i),
- ondragend: UL(Ff, e, {
- isEnd: !0
- })
- }))
- }), o
- }
- function Uf(t, e, i, n) {
- var o = n.brushStyle.lineWidth || 0,
- a = qL(o, QL),
- r = i[0][0],
- s = i[1][0],
- l = r - o / 2,
- u = s - o / 2,
- h = i[0][1],
- c = i[1][1],
- d = h - a + o / 2,
- f = c - a + o / 2,
- p = h - r,
- g = c - s,
- m = p + o,
- v = g + o;
- jf(t, e, "main", r, s, p, g), n.transformable && (jf(t, e, "w", l, u, a, v), jf(t, e, "e", d, u, a, v), jf(t, e, "n",
- l, u, m, a), jf(t, e, "s", l, f, m, a), jf(t, e, "nw", l, u, a, a), jf(t, e, "ne", d, u, a, a), jf(t, e, "sw", l,
- f, a, a), jf(t, e, "se", d, f, a, a))
- }
- function Xf(t, e) {
- var i = e.__brushOption,
- n = i.transformable,
- o = e.childAt(0);
- o.useStyle(Yf(i)), o.attr({
- silent: !n,
- cursor: n ? "move" : "default"
- }), XL(["w", "e", "n", "s", "se", "sw", "ne", "nw"], function(i) {
- var o = e.childOfName(i),
- a = $f(t, i);
- o && o.attr({
- silent: !n,
- invisible: !n,
- cursor: n ? ik[a] + "-resize" : null
- })
- })
- }
- function jf(t, e, i, n, o, a, r) {
- var s = e.childOfName(i);
- s && s.setShape(ip(ep(t, e, [
- [n, o],
- [n + a, o + r]
- ])))
- }
- function Yf(t) {
- return r({
- strokeNoScale: !0
- }, t.brushStyle)
- }
- function qf(t, e, i, n) {
- var o = [YL(t, i), YL(e, n)],
- a = [qL(t, i), qL(e, n)];
- return [
- [o[0], a[0]],
- [o[1], a[1]]
- ]
- }
- function Kf(t) {
- return Mo(t.group)
- }
- function $f(t, e) {
- if (e.length > 1) return ("e" === (n = [$f(t, (e = e.split(""))[0]), $f(t, e[1])])[0] || "w" === n[0]) && n.reverse(),
- n.join("");
- var i = {
- left: "w",
- right: "e",
- top: "n",
- bottom: "s"
- },
- n = To({
- w: "left",
- e: "right",
- n: "top",
- s: "bottom"
- } [e], Kf(t));
- return i[n]
- }
- function Jf(t, e, i, n, o, a, r, s) {
- var l = n.__brushOption,
- u = t(l.range),
- h = tp(i, a, r);
- XL(o.split(""), function(t) {
- var e = ek[t];
- u[e[0]][e[1]] += h[e[0]]
- }), l.range = e(qf(u[0][0], u[1][0], u[0][1], u[1][1])), Rf(i, n), Ff(i, {
- isEnd: !1
- })
- }
- function Qf(t, e, i, n, o) {
- var a = e.__brushOption.range,
- r = tp(t, i, n);
- XL(a, function(t) {
- t[0] += r[0], t[1] += r[1]
- }), Rf(t, e), Ff(t, {
- isEnd: !1
- })
- }
- function tp(t, e, i) {
- var n = t.group,
- o = n.transformCoordToLocal(e, i),
- a = n.transformCoordToLocal(0, 0);
- return [o[0] - a[0], o[1] - a[1]]
- }
- function ep(t, e, n) {
- var o = Vf(t, e);
- return o && !0 !== o ? o.clipPath(n, t._transform) : i(n)
- }
- function ip(t) {
- var e = YL(t[0][0], t[1][0]),
- i = YL(t[0][1], t[1][1]);
- return {
- x: e,
- y: i,
- width: qL(t[0][0], t[1][0]) - e,
- height: qL(t[0][1], t[1][1]) - i
- }
- }
- function np(t, e, i) {
- if (t._brushType) {
- var n = t._zr,
- o = t._covers,
- a = Bf(t, e, i);
- if (!t._dragging)
- for (var r = 0; r < o.length; r++) {
- var s = o[r].__brushOption;
- if (a && (!0 === a || s.panelId === a.panelId) && rk[s.brushType].contain(o[r], i[0], i[1])) return
- }
- a && n.setCursorStyle("crosshair")
- }
- }
- function op(t) {
- var e = t.event;
- e.preventDefault && e.preventDefault()
- }
- function ap(t, e, i) {
- return t.childOfName("main").contain(e, i)
- }
- function rp(t, e, n, o) {
- var a, r = t._creatingCover,
- s = t._creatingPanel,
- l = t._brushOption;
- if (t._track.push(n.slice()), Wf(t) || r) {
- if (s && !r) {
- "single" === l.brushMode && Gf(t);
- var u = i(l);
- u.brushType = sp(u.brushType, s), u.panelId = !0 === s ? null : s.panelId, r = t._creatingCover = Pf(t, u), t._covers
- .push(r)
- }
- if (r) {
- var h = rk[sp(t._brushType, s)];
- r.__brushOption.range = h.getCreatingRange(ep(t, r, t._track)), o && (Nf(t, r), h.updateCommon(t, r)), Of(t, r), a = {
- isEnd: o
- }
- }
- } else o && "single" === l.brushMode && l.removeOnClick && Bf(t, e, n) && Gf(t) && (a = {
- isEnd: o,
- removeOnClick: !0
- });
- return a
- }
- function sp(t, e) {
- return "auto" === t ? e.defaultBrushType : t
- }
- function lp(t) {
- if (this._dragging) {
- op(t);
- var e = rp(this, t, this.group.transformCoordToLocal(t.offsetX, t.offsetY), !0);
- this._dragging = !1, this._track = [], this._creatingCover = null, e && Ff(this, e)
- }
- }
- function up(t) {
- return {
- createCover: function(e, i) {
- return Zf(UL(Jf, function(e) {
- var i = [e, [0, 100]];
- return t && i.reverse(), i
- }, function(e) {
- return e[t]
- }), e, i, [
- ["w", "e"],
- ["n", "s"]
- ][t])
- },
- getCreatingRange: function(e) {
- var i = Hf(e);
- return [YL(i[0][t], i[1][t]), qL(i[0][t], i[1][t])]
- },
- updateCoverShape: function(e, i, n, o) {
- var a, r = Vf(e, i);
- if (!0 !== r && r.getLinearBrushOtherExtent) a = r.getLinearBrushOtherExtent(t, e._transform);
- else {
- var s = e._zr;
- a = [0, [s.getWidth(), s.getHeight()][1 - t]]
- }
- var l = [n, a];
- t && l.reverse(), Uf(e, i, l, o)
- },
- updateCommon: Xf,
- contain: ap
- }
- }
- function hp(t) {
- return t = fp(t),
- function(e, i) {
- return Do(e, t)
- }
- }
- function cp(t, e) {
- return t = fp(t),
- function(i) {
- var n = null != e ? e : i,
- o = n ? t.width : t.height,
- a = n ? t.x : t.y;
- return [a, a + (o || 0)]
- }
- }
- function dp(t, e, i) {
- return t = fp(t),
- function(n, o, a) {
- return t.contain(o[0], o[1]) && !mc(n, e, i)
- }
- }
- function fp(t) {
- return ue.create(t)
- }
- function pp(t, e, i) {
- return i && "axisAreaSelect" === i.type && e.findComponents({
- mainType: "parallelAxis",
- query: i
- })[0] === t
- }
- function gp(t) {
- var e = t.axis;
- return f(t.activeIntervals, function(t) {
- return {
- brushType: "lineX",
- panelId: "pl",
- range: [e.dataToCoord(t[0], !0), e.dataToCoord(t[1], !0)]
- }
- })
- }
- function mp(t, e) {
- return e.getComponent("parallel", t.get("parallelIndex"))
- }
- function vp(t, e) {
- var i = t._model;
- return i.get("axisExpandable") && i.get("axisExpandTriggerOn") === e
- }
- function yp(t, e) {
- if (!t.encodeDefine) {
- var i = e.ecModel.getComponent("parallel", e.get("parallelIndex"));
- if (i) {
- var n = t.encodeDefine = R();
- d(i.dimensions, function(t) {
- var e = xp(t);
- n.set(t, e)
- })
- }
- }
- }
- function xp(t) {
- return +t.replace("dim", "")
- }
- function _p(t, e, i) {
- var n = t.model,
- o = t.getRect(),
- a = new aM({
- shape: {
- x: o.x,
- y: o.y,
- width: o.width,
- height: o.height
- }
- }),
- r = "horizontal" === n.get("layout") ? "width" : "height";
- return a.setShape(r, 0), So(a, {
- shape: {
- width: o.width,
- height: o.height
- }
- }, e, i), a
- }
- function wp(t, e, i, n) {
- for (var o = [], a = 0; a < i.length; a++) {
- var r = i[a],
- s = t.get(t.mapDimension(r), e);
- Ip(s, n.getAxis(r).type) || o.push(n.dataToPoint(s, r))
- }
- return o
- }
- function bp(t, e, i, n, o) {
- var a = wp(t, i, n, o),
- r = new oM({
- shape: {
- points: a
- },
- silent: !0,
- z2: 10
- });
- return e.add(r), t.setItemGraphicEl(i, r), r
- }
- function Sp(t) {
- var e = t.get("smooth", !0);
- return !0 === e && (e = hk), {
- lineStyle: t.getModel("lineStyle").getLineStyle(),
- smooth: null != e ? e : hk
- }
- }
- function Mp(t, e, i, n) {
- var o = n.lineStyle;
- e.hasItemOption && (o = e.getItemModel(i).getModel("lineStyle").getLineStyle()), t.useStyle(o);
- var a = t.style;
- a.fill = null, a.stroke = e.getItemVisual(i, "color"), a.opacity = e.getItemVisual(i, "opacity"), n.smooth && (t.shape
- .smooth = n.smooth)
- }
- function Ip(t, e) {
- return "category" === e ? null == t : null == t || isNaN(t)
- }
- function Tp(t, e) {
- return t.getVisual("opacity") || t.getModel().get(e)
- }
- function Ap(t, e, i) {
- var n = t.getGraphicEl(),
- o = Tp(t, e);
- null != i && (null == o && (o = 1), o *= i), n.downplay && n.downplay(), n.traverse(function(t) {
- "group" !== t.type && t.setStyle("opacity", o)
- })
- }
- function Dp(t, e) {
- var i = Tp(t, e),
- n = t.getGraphicEl();
- n.highlight && n.highlight(), n.traverse(function(t) {
- "group" !== t.type && t.setStyle("opacity", i)
- })
- }
- function Cp(t, e, i) {
- var n = new aM({
- shape: {
- x: t.x - 10,
- y: t.y - 10,
- width: 0,
- height: t.height + 20
- }
- });
- return So(n, {
- shape: {
- width: t.width + 20,
- height: t.height + 20
- }
- }, e, i), n
- }
- function Lp() {
- function t(e, n) {
- if (n >= i.length) return e;
- for (var o = -1, a = e.length, r = i[n++], s = {}, l = {}; ++o < a;) {
- var u = r(e[o]),
- h = l[u];
- h ? h.push(e[o]) : l[u] = [e[o]]
- }
- return d(l, function(e, i) {
- s[i] = t(e, n)
- }), s
- }
- function e(t, o) {
- if (o >= i.length) return t;
- var a = [],
- r = n[o++];
- return d(t, function(t, i) {
- a.push({
- key: i,
- values: e(t, o)
- })
- }), r ? a.sort(function(t, e) {
- return r(t.key, e.key)
- }) : a
- }
- var i = [],
- n = [];
- return {
- key: function(t) {
- return i.push(t), this
- },
- sortKeys: function(t) {
- return n[i.length - 1] = t, this
- },
- entries: function(i) {
- return e(t(i, 0), 0)
- }
- }
- }
- function kp(t, e) {
- return la(t.getBoxLayoutParams(), {
- width: e.getWidth(),
- height: e.getHeight()
- })
- }
- function Pp(t, e, i, n, o, a, r, s) {
- Op(t, e, i, o, a, s), zp(t, e, a, o, n, r, s), Yp(t, s)
- }
- function Np(t) {
- d(t, function(t) {
- var e = Xp(t.outEdges, Up),
- i = Xp(t.inEdges, Up),
- n = Math.max(e, i);
- t.setLayout({
- value: n
- }, !0)
- })
- }
- function Op(t, e, i, n, o, a) {
- for (var r = [], s = [], l = [], u = [], h = 0, c = 0; c < e.length; c++) r[c] = 1;
- for (c = 0; c < t.length; c++) s[c] = t[c].inEdges.length, 0 === s[c] && l.push(t[c]);
- for (; l.length;) {
- for (var d = 0; d < l.length; d++) {
- var f = l[d];
- "vertical" === a ? (f.setLayout({
- y: h
- }, !0), f.setLayout({
- dy: i
- }, !0)) : (f.setLayout({
- x: h
- }, !0), f.setLayout({
- dx: i
- }, !0));
- for (var p = 0; p < f.outEdges.length; p++) {
- var g = f.outEdges[p];
- r[e.indexOf(g)] = 0;
- var m = g.node2;
- 0 == --s[t.indexOf(m)] && u.push(m)
- }
- }++h, l = u, u = []
- }
- for (c = 0; c < r.length; c++);
- Ep(t, h, a), Rp(t, "vertical" === a ? (o - i) / (h - 1) : (n - i) / (h - 1), a)
- }
- function Ep(t, e, i) {
- d(t, function(t) {
- t.outEdges.length || ("vertical" === i ? t.setLayout({
- y: e - 1
- }, !0) : t.setLayout({
- x: e - 1
- }, !0))
- })
- }
- function Rp(t, e, i) {
- d(t, function(t) {
- if ("vertical" === i) {
- var n = t.getLayout().y * e;
- t.setLayout({
- y: n
- }, !0)
- } else {
- var o = t.getLayout().x * e;
- t.setLayout({
- x: o
- }, !0)
- }
- })
- }
- function zp(t, e, i, n, o, a, r) {
- var s = Lp().key(Bp(r)).sortKeys(function(t, e) {
- return t - e
- }).entries(t).map(function(t) {
- return t.values
- });
- Vp(t, s, e, i, n, o, r), Gp(s, o, i, n, r);
- for (var l = 1; a > 0; a--) Fp(s, l *= .99, r), Gp(s, o, i, n, r), jp(s, l, r), Gp(s, o, i, n, r)
- }
- function Bp(t) {
- return "vertical" === t ? function(t) {
- return t.getLayout().y
- } : function(t) {
- return t.getLayout().x
- }
- }
- function Vp(t, e, i, n, o, a, r) {
- var s = [];
- d(e, function(t) {
- var e = t.length,
- i = 0,
- l = 0;
- d(t, function(t) {
- i += t.getLayout().value
- }), l = "vertical" === r ? (o - (e - 1) * a) / i : (n - (e - 1) * a) / i, s.push(l)
- }), s.sort(function(t, e) {
- return t - e
- });
- var l = s[0];
- d(e, function(t) {
- d(t, function(t, e) {
- var i = t.getLayout().value * l;
- "vertical" === r ? (t.setLayout({
- x: e
- }, !0), t.setLayout({
- dx: i
- }, !0)) : (t.setLayout({
- y: e
- }, !0), t.setLayout({
- dy: i
- }, !0))
- })
- }), d(i, function(t) {
- var e = +t.getValue() * l;
- t.setLayout({
- dy: e
- }, !0)
- })
- }
- function Gp(t, e, i, n, o) {
- d(t, function(t) {
- var a, r, s, l = 0,
- u = t.length;
- if ("vertical" === o) {
- var h;
- for (t.sort(function(t, e) {
- return t.getLayout().x - e.getLayout().x
- }), s = 0; s < u; s++)(r = l - (a = t[s]).getLayout().x) > 0 && (h = a.getLayout().x + r, a.setLayout({
- x: h
- }, !0)), l = a.getLayout().x + a.getLayout().dx + e;
- if ((r = l - e - n) > 0)
- for (h = a.getLayout().x - r, a.setLayout({
- x: h
- }, !0), l = h, s = u - 2; s >= 0; --s)(r = (a = t[s]).getLayout().x + a.getLayout().dx + e - l) > 0 && (h = a.getLayout()
- .x - r, a.setLayout({
- x: h
- }, !0)), l = a.getLayout().x
- } else {
- var c;
- for (t.sort(function(t, e) {
- return t.getLayout().y - e.getLayout().y
- }), s = 0; s < u; s++)(r = l - (a = t[s]).getLayout().y) > 0 && (c = a.getLayout().y + r, a.setLayout({
- y: c
- }, !0)), l = a.getLayout().y + a.getLayout().dy + e;
- if ((r = l - e - i) > 0)
- for (c = a.getLayout().y - r, a.setLayout({
- y: c
- }, !0), l = c, s = u - 2; s >= 0; --s)(r = (a = t[s]).getLayout().y + a.getLayout().dy + e - l) > 0 && (c = a.getLayout()
- .y - r, a.setLayout({
- y: c
- }, !0)), l = a.getLayout().y
- }
- })
- }
- function Fp(t, e, i) {
- d(t.slice().reverse(), function(t) {
- d(t, function(t) {
- if (t.outEdges.length) {
- var n = Xp(t.outEdges, Wp, i) / Xp(t.outEdges, Up, i);
- if ("vertical" === i) {
- var o = t.getLayout().x + (n - Zp(t, i)) * e;
- t.setLayout({
- x: o
- }, !0)
- } else {
- var a = t.getLayout().y + (n - Zp(t, i)) * e;
- t.setLayout({
- y: a
- }, !0)
- }
- }
- })
- })
- }
- function Wp(t, e) {
- return Zp(t.node2, e) * t.getValue()
- }
- function Hp(t, e) {
- return Zp(t.node1, e) * t.getValue()
- }
- function Zp(t, e) {
- return "vertical" === e ? t.getLayout().x + t.getLayout().dx / 2 : t.getLayout().y + t.getLayout().dy / 2
- }
- function Up(t) {
- return t.getValue()
- }
- function Xp(t, e, i) {
- for (var n = 0, o = t.length, a = -1; ++a < o;) {
- var r = +e.call(t, t[a], i);
- isNaN(r) || (n += r)
- }
- return n
- }
- function jp(t, e, i) {
- d(t, function(t) {
- d(t, function(t) {
- if (t.inEdges.length) {
- var n = Xp(t.inEdges, Hp, i) / Xp(t.inEdges, Up, i);
- if ("vertical" === i) {
- var o = t.getLayout().x + (n - Zp(t, i)) * e;
- t.setLayout({
- x: o
- }, !0)
- } else {
- var a = t.getLayout().y + (n - Zp(t, i)) * e;
- t.setLayout({
- y: a
- }, !0)
- }
- }
- })
- })
- }
- function Yp(t, e) {
- d(t, function(t) {
- "vertical" === e ? (t.outEdges.sort(function(t, e) {
- return t.node2.getLayout().x - e.node2.getLayout().x
- }), t.inEdges.sort(function(t, e) {
- return t.node1.getLayout().x - e.node1.getLayout().x
- })) : (t.outEdges.sort(function(t, e) {
- return t.node2.getLayout().y - e.node2.getLayout().y
- }), t.inEdges.sort(function(t, e) {
- return t.node1.getLayout().y - e.node1.getLayout().y
- }))
- }), d(t, function(t) {
- var e = 0,
- i = 0;
- d(t.outEdges, function(t) {
- t.setLayout({
- sy: e
- }, !0), e += t.getLayout().dy
- }), d(t.inEdges, function(t) {
- t.setLayout({
- ty: i
- }, !0), i += t.getLayout().dy
- })
- })
- }
- function qp(t, e, i, n, o) {
- var a = t.ends,
- r = new xk({
- shape: {
- points: o ? $p(a, n, t) : a
- }
- });
- return Kp(t, r, e, i, o), r
- }
- function Kp(t, e, i, n, o) {
- var a = i.hostModel;
- (0, bM[o ? "initProps" : "updateProps"])(e, {
- shape: {
- points: t.ends
- }
- }, a, n);
- var r = i.getItemModel(n),
- s = r.getModel(vk),
- l = i.getItemVisual(n, "color"),
- u = s.getItemStyle(["borderColor"]);
- u.stroke = l, u.strokeNoScale = !0, e.useStyle(u), e.z2 = 100, uo(e, r.getModel(yk).getItemStyle())
- }
- function $p(t, e, i) {
- return f(t, function(t) {
- return t = t.slice(), t[e] = i.initBaseline, t
- })
- }
- function Jp(t) {
- var e = [],
- i = [];
- return t.eachSeriesByType("boxplot", function(t) {
- var n = t.getBaseAxis(),
- o = l(i, n);
- o < 0 && (o = i.length, i[o] = n, e[o] = {
- axis: n,
- seriesModels: []
- }), e[o].seriesModels.push(t)
- }), e
- }
- function Qp(t) {
- var e, i, n = t.axis,
- o = t.seriesModels,
- a = o.length,
- r = t.boxWidthList = [],
- s = t.boxOffsetList = [],
- l = [];
- if ("category" === n.type) i = n.getBandWidth();
- else {
- var u = 0;
- wk(o, function(t) {
- u = Math.max(u, t.getData().count())
- }), e = n.getExtent(), Math.abs(e[1] - e[0])
- }
- wk(o, function(t) {
- var e = t.get("boxWidth");
- y(e) || (e = [e, e]), l.push([Ro(e[0], i) || 0, Ro(e[1], i) || 0])
- });
- var h = .8 * i - 2,
- c = h / a * .3,
- d = (h - c * (a - 1)) / a,
- f = d / 2 - h / 2;
- wk(o, function(t, e) {
- s.push(f), f += c + d, r.push(Math.min(Math.max(d, l[e][0]), l[e][1]))
- })
- }
- function tg(t, e, i) {
- function n(t, i, n) {
- var o = s.get(i, n),
- a = [];
- a[u] = t, a[h] = o;
- var l;
- return isNaN(t) || isNaN(o) ? l = [NaN, NaN] : (l = r.dataToPoint(a))[u] += e, l
- }
- function o(t, e, i) {
- var n = e.slice(),
- o = e.slice();
- n[u] += l, o[u] -= l, i ? t.push(n, o) : t.push(o, n)
- }
- function a(t, e) {
- var i = e.slice(),
- n = e.slice();
- i[u] -= l, n[u] += l, t.push(i, n)
- }
- var r = t.coordinateSystem,
- s = t.getData(),
- l = i / 2,
- u = "horizontal" === t.get("layout") ? 0 : 1,
- h = 1 - u,
- c = ["x", "y"],
- d = s.mapDimension(c[u]),
- f = s.mapDimension(c[h], !0);
- if (!(null == d || f.length < 5))
- for (var p = 0; p < s.count(); p++) {
- var g = s.get(d, p),
- m = n(g, f[2], p),
- v = n(g, f[0], p),
- y = n(g, f[1], p),
- x = n(g, f[3], p),
- _ = n(g, f[4], p),
- w = [];
- o(w, y, 0), o(w, x, 1), w.push(v, y, _, x), a(w, v), a(w, _), a(w, m), s.setItemLayout(p, {
- initBaseline: m[h],
- ends: w
- })
- }
- }
- function eg(t, e, i) {
- var n = t.ends;
- return new Ik({
- shape: {
- points: i ? ng(n, t) : n
- },
- z2: 100
- })
- }
- function ig(t, e, i, n) {
- var o = e.getItemModel(i),
- a = o.getModel(bk),
- r = e.getItemVisual(i, "color"),
- s = e.getItemVisual(i, "borderColor") || r,
- l = a.getItemStyle(Mk);
- t.useStyle(l), t.style.strokeNoScale = !0, t.style.fill = r, t.style.stroke = s, t.__simpleBox = n, uo(t, o.getModel(
- Sk).getItemStyle())
- }
- function ng(t, e) {
- return f(t, function(t) {
- return t = t.slice(), t[1] = e.initBaseline, t
- })
- }
- function og(t, e, i) {
- var n = t.getData(),
- o = n.getLayout("largePoints"),
- a = new Tk({
- shape: {
- points: o
- },
- __sign: 1
- });
- e.add(a);
- var r = new Tk({
- shape: {
- points: o
- },
- __sign: -1
- });
- e.add(r), ag(1, a, t, n), ag(-1, r, t, n), i && (a.incremental = !0, r.incremental = !0)
- }
- function ag(t, e, i, n) {
- var o = t > 0 ? "P" : "N",
- a = n.getVisual("borderColor" + o) || n.getVisual("color" + o),
- r = i.getModel(bk).getItemStyle(Mk);
- e.useStyle(r), e.style.fill = null, e.style.stroke = a
- }
- function rg(t, e, i, n, o) {
- return i > n ? -1 : i < n ? 1 : e > 0 ? t.get(o, e - 1) <= n ? 1 : -1 : 1
- }
- function sg(t, e) {
- var i, n = t.getBaseAxis(),
- o = "category" === n.type ? n.getBandWidth() : (i = n.getExtent(), Math.abs(i[1] - i[0]) / e.count()),
- a = Ro(A(t.get("barMaxWidth"), o), o),
- r = Ro(A(t.get("barMinWidth"), 1), o),
- s = t.get("barWidth");
- return null != s ? Ro(s, o) : Math.max(Math.min(o / 2, a), r)
- }
- function lg(t) {
- return y(t) || (t = [+t, +t]), t
- }
- function ug(t, e) {
- t.eachChild(function(t) {
- t.attr({
- z: e.z,
- zlevel: e.zlevel,
- style: {
- stroke: "stroke" === e.brushType ? e.color : null,
- fill: "fill" === e.brushType ? e.color : null
- }
- })
- })
- }
- function hg(t, e) {
- Zw.call(this);
- var i = new mu(t, e),
- n = new Zw;
- this.add(i), this.add(n), n.beforeUpdate = function() {
- this.attr(i.getScale())
- }, this.updateData(t, e)
- }
- function cg(t) {
- var e = t.data;
- e && e[0] && e[0][0] && e[0][0].coord && (t.data = f(e, function(t) {
- var e = {
- coords: [t[0].coord, t[1].coord]
- };
- return t[0].name && (e.fromName = t[0].name), t[1].name && (e.toName = t[1].name), o([e, t[0], t[1]])
- }))
- }
- function dg(t, e, i) {
- Zw.call(this), this.add(this.createLine(t, e, i)), this._updateEffectSymbol(t, e)
- }
- function fg(t, e, i) {
- Zw.call(this), this._createPolyline(t, e, i)
- }
- function pg(t, e, i) {
- dg.call(this, t, e, i), this._lastFrame = 0, this._lastFramePercent = 0
- }
- function gg() {
- this.group = new Zw
- }
- function mg(t) {
- return t instanceof Array || (t = [t, t]), t
- }
- function vg() {
- var t = Y_();
- this.canvas = t, this.blurSize = 30, this.pointSize = 20, this.maxOpacity = 1, this.minOpacity = 0, this._gradientPixels = {}
- }
- function yg(t, e, i) {
- var n = t[1] - t[0],
- o = (e = f(e, function(e) {
- return {
- interval: [(e.interval[0] - t[0]) / n, (e.interval[1] - t[0]) / n]
- }
- })).length,
- a = 0;
- return function(t) {
- for (n = a; n < o; n++)
- if ((r = e[n].interval)[0] <= t && t <= r[1]) {
- a = n;
- break
- } if (n === o)
- for (var n = a - 1; n >= 0; n--) {
- var r = e[n].interval;
- if (r[0] <= t && t <= r[1]) {
- a = n;
- break
- }
- }
- return n >= 0 && n < o && i[n]
- }
- }
- function xg(t, e) {
- var i = t[1] - t[0];
- return e = [(e[0] - t[0]) / i, (e[1] - t[0]) / i],
- function(t) {
- return t >= e[0] && t <= e[1]
- }
- }
- function _g(t) {
- var e = t.dimensions;
- return "lng" === e[0] && "lat" === e[1]
- }
- function wg(t, e, i, n) {
- var o = t.getItemLayout(e),
- a = i.get("symbolRepeat"),
- r = i.get("symbolClip"),
- s = i.get("symbolPosition") || "start",
- l = (i.get("symbolRotate") || 0) * Math.PI / 180 || 0,
- u = i.get("symbolPatternSize") || 2,
- h = i.isAnimationEnabled(),
- c = {
- dataIndex: e,
- layout: o,
- itemModel: i,
- symbolType: t.getItemVisual(e, "symbol") || "circle",
- color: t.getItemVisual(e, "color"),
- symbolClip: r,
- symbolRepeat: a,
- symbolRepeatDirection: i.get("symbolRepeatDirection"),
- symbolPatternSize: u,
- rotation: l,
- animationModel: h ? i : null,
- hoverAnimation: h && i.get("hoverAnimation"),
- z2: i.getShallow("z", !0) || 0
- };
- bg(i, a, o, n, c), Mg(t, e, o, a, r, c.boundingLength, c.pxSign, u, n, c), Ig(i, c.symbolScale, l, n, c);
- var d = c.symbolSize,
- f = i.get("symbolOffset");
- return y(f) && (f = [Ro(f[0], d[0]), Ro(f[1], d[1])]), Tg(i, d, o, a, r, f, s, c.valueLineWidth, c.boundingLength, c
- .repeatCutLength, n, c), c
- }
- function bg(t, e, i, n, o) {
- var a, r = n.valueDim,
- s = t.get("symbolBoundingData"),
- l = n.coordSys.getOtherAxis(n.coordSys.getBaseAxis()),
- u = l.toGlobalCoord(l.dataToCoord(0)),
- h = 1 - +(i[r.wh] <= 0);
- if (y(s)) {
- var c = [Sg(l, s[0]) - u, Sg(l, s[1]) - u];
- c[1] < c[0] && c.reverse(), a = c[h]
- } else a = null != s ? Sg(l, s) - u : e ? n.coordSysExtent[r.index][h] - u : i[r.wh];
- o.boundingLength = a, e && (o.repeatCutLength = i[r.wh]), o.pxSign = a > 0 ? 1 : a < 0 ? -1 : 0
- }
- function Sg(t, e) {
- return t.toGlobalCoord(t.dataToCoord(t.scale.parse(e)))
- }
- function Mg(t, e, i, n, o, a, r, s, l, u) {
- var h = l.valueDim,
- c = l.categoryDim,
- d = Math.abs(i[c.wh]),
- f = t.getItemVisual(e, "symbolSize");
- y(f) ? f = f.slice() : (null == f && (f = "100%"), f = [f, f]), f[c.index] = Ro(f[c.index], d), f[h.index] = Ro(f[h.index],
- n ? d : Math.abs(a)), u.symbolSize = f, (u.symbolScale = [f[0] / s, f[1] / s])[h.index] *= (l.isHorizontal ? -1 :
- 1) * r
- }
- function Ig(t, e, i, n, o) {
- var a = t.get(jk) || 0;
- a && (qk.attr({
- scale: e.slice(),
- rotation: i
- }), qk.updateTransform(), a /= qk.getLineScale(), a *= e[n.valueDim.index]), o.valueLineWidth = a
- }
- function Tg(t, e, i, n, o, r, s, l, u, h, c, d) {
- var f = c.categoryDim,
- p = c.valueDim,
- g = d.pxSign,
- m = Math.max(e[p.index] + l, 0),
- v = m;
- if (n) {
- var y = Math.abs(u),
- x = T(t.get("symbolMargin"), "15%") + "",
- _ = !1;
- x.lastIndexOf("!") === x.length - 1 && (_ = !0, x = x.slice(0, x.length - 1)), x = Ro(x, e[p.index]);
- var w = Math.max(m + 2 * x, 0),
- b = _ ? 0 : 2 * x,
- S = Ko(n),
- M = S ? n : Hg((y + b) / w);
- w = m + 2 * (x = (y - M * m) / 2 / (_ ? M : M - 1)), b = _ ? 0 : 2 * x, S || "fixed" === n || (M = h ? Hg((Math.abs(
- h) + b) / w) : 0), v = M * w - b, d.repeatTimes = M, d.symbolMargin = x
- }
- var I = g * (v / 2),
- A = d.pathPosition = [];
- A[f.index] = i[f.wh] / 2, A[p.index] = "start" === s ? I : "end" === s ? u - I : u / 2, r && (A[0] += r[0], A[1] +=
- r[1]);
- var D = d.bundlePosition = [];
- D[f.index] = i[f.xy], D[p.index] = i[p.xy];
- var C = d.barRectShape = a({}, i);
- C[p.wh] = g * Math.max(Math.abs(i[p.wh]), Math.abs(A[p.index] + I)), C[f.wh] = i[f.wh];
- var L = d.clipShape = {};
- L[f.xy] = -i[f.xy], L[f.wh] = c.ecSize[f.wh], L[p.xy] = 0, L[p.wh] = i[p.wh]
- }
- function Ag(t) {
- var e = t.symbolPatternSize,
- i = Xl(t.symbolType, -e / 2, -e / 2, e, e, t.color);
- return i.attr({
- culling: !0
- }), "image" !== i.type && i.setStyle({
- strokeNoScale: !0
- }), i
- }
- function Dg(t, e, i, n) {
- function o(t) {
- var e = l.slice(),
- n = i.pxSign,
- o = t;
- return ("start" === i.symbolRepeatDirection ? n > 0 : n < 0) && (o = h - 1 - t), e[u.index] = d * (o - h / 2 + .5) +
- l[u.index], {
- position: e,
- scale: i.symbolScale.slice(),
- rotation: i.rotation
- }
- }
- var a = t.__pictorialBundle,
- r = i.symbolSize,
- s = i.valueLineWidth,
- l = i.pathPosition,
- u = e.valueDim,
- h = i.repeatTimes || 0,
- c = 0,
- d = r[e.valueDim.index] + s + 2 * i.symbolMargin;
- for (Gg(t, function(t) {
- t.__pictorialAnimationIndex = c, t.__pictorialRepeatTimes = h, c < h ? Fg(t, null, o(c), i, n) : Fg(t, null, {
- scale: [0, 0]
- }, i, n, function() {
- a.remove(t)
- }), Eg(t, i), c++
- }); c < h; c++) {
- var f = Ag(i);
- f.__pictorialAnimationIndex = c, f.__pictorialRepeatTimes = h, a.add(f);
- var p = o(c);
- Fg(f, {
- position: p.position,
- scale: [0, 0]
- }, {
- scale: p.scale,
- rotation: p.rotation
- }, i, n), f.on("mouseover", function() {
- Gg(t, function(t) {
- t.trigger("emphasis")
- })
- }).on("mouseout", function() {
- Gg(t, function(t) {
- t.trigger("normal")
- })
- }), Eg(f, i)
- }
- }
- function Cg(t, e, i, n) {
- var o = t.__pictorialBundle,
- a = t.__pictorialMainPath;
- a ? Fg(a, null, {
- position: i.pathPosition.slice(),
- scale: i.symbolScale.slice(),
- rotation: i.rotation
- }, i, n) : (a = t.__pictorialMainPath = Ag(i), o.add(a), Fg(a, {
- position: i.pathPosition.slice(),
- scale: [0, 0],
- rotation: i.rotation
- }, {
- scale: i.symbolScale.slice()
- }, i, n), a.on("mouseover", function() {
- this.trigger("emphasis")
- }).on("mouseout", function() {
- this.trigger("normal")
- })), Eg(a, i)
- }
- function Lg(t, e, i) {
- var n = a({}, e.barRectShape),
- o = t.__pictorialBarRect;
- o ? Fg(o, null, {
- shape: n
- }, e, i) : (o = t.__pictorialBarRect = new aM({
- z2: 2,
- shape: n,
- silent: !0,
- style: {
- stroke: "transparent",
- fill: "transparent",
- lineWidth: 0
- }
- }), t.add(o))
- }
- function kg(t, e, i, n) {
- if (i.symbolClip) {
- var o = t.__pictorialClipPath,
- r = a({}, i.clipShape),
- s = e.valueDim,
- l = i.animationModel,
- u = i.dataIndex;
- if (o) bo(o, {
- shape: r
- }, l, u);
- else {
- r[s.wh] = 0, o = new aM({
- shape: r
- }), t.__pictorialBundle.setClipPath(o), t.__pictorialClipPath = o;
- var h = {};
- h[s.wh] = i.clipShape[s.wh], bM[n ? "updateProps" : "initProps"](o, {
- shape: h
- }, l, u)
- }
- }
- }
- function Pg(t, e) {
- var i = t.getItemModel(e);
- return i.getAnimationDelayParams = Ng, i.isAnimationEnabled = Og, i
- }
- function Ng(t) {
- return {
- index: t.__pictorialAnimationIndex,
- count: t.__pictorialRepeatTimes
- }
- }
- function Og() {
- return this.parentModel.isAnimationEnabled() && !!this.getShallow("animation")
- }
- function Eg(t, e) {
- t.off("emphasis").off("normal");
- var i = e.symbolScale.slice();
- e.hoverAnimation && t.on("emphasis", function() {
- this.animateTo({
- scale: [1.1 * i[0], 1.1 * i[1]]
- }, 400, "elasticOut")
- }).on("normal", function() {
- this.animateTo({
- scale: i.slice()
- }, 400, "elasticOut")
- })
- }
- function Rg(t, e, i, n) {
- var o = new Zw,
- a = new Zw;
- return o.add(a), o.__pictorialBundle = a, a.attr("position", i.bundlePosition.slice()), i.symbolRepeat ? Dg(o, e, i) :
- Cg(o, e, i), Lg(o, i, n), kg(o, e, i, n), o.__pictorialShapeStr = Vg(t, i), o.__pictorialSymbolMeta = i, o
- }
- function zg(t, e, i) {
- var n = i.animationModel,
- o = i.dataIndex;
- bo(t.__pictorialBundle, {
- position: i.bundlePosition.slice()
- }, n, o), i.symbolRepeat ? Dg(t, e, i, !0) : Cg(t, e, i, !0), Lg(t, i, !0), kg(t, e, i, !0)
- }
- function Bg(t, e, i, n) {
- var o = n.__pictorialBarRect;
- o && (o.style.text = null);
- var a = [];
- Gg(n, function(t) {
- a.push(t)
- }), n.__pictorialMainPath && a.push(n.__pictorialMainPath), n.__pictorialClipPath && (i = null), d(a, function(t) {
- bo(t, {
- scale: [0, 0]
- }, i, e, function() {
- n.parent && n.parent.remove(n)
- })
- }), t.setItemGraphicEl(e, null)
- }
- function Vg(t, e) {
- return [t.getItemVisual(e.dataIndex, "symbol") || "none", !!e.symbolRepeat, !!e.symbolClip].join(":")
- }
- function Gg(t, e, i) {
- d(t.__pictorialBundle.children(), function(n) {
- n !== t.__pictorialBarRect && e.call(i, n)
- })
- }
- function Fg(t, e, i, n, o, a) {
- e && t.attr(e), n.symbolClip && !o ? i && t.attr(i) : i && bM[o ? "updateProps" : "initProps"](t, i, n.animationModel,
- n.dataIndex, a)
- }
- function Wg(t, e, i) {
- var n = i.color,
- o = i.dataIndex,
- a = i.itemModel,
- s = a.getModel("itemStyle").getItemStyle(["color"]),
- l = a.getModel("emphasis.itemStyle").getItemStyle(),
- u = a.getShallow("cursor");
- Gg(t, function(t) {
- t.setColor(n), t.setStyle(r({
- fill: n,
- opacity: i.opacity
- }, s)), uo(t, l), u && (t.cursor = u), t.z2 = i.z2
- });
- var h = {},
- c = e.valueDim.posDesc[+(i.boundingLength > 0)],
- d = t.__pictorialBarRect;
- Th(d.style, h, a, n, e.seriesModel, o, c), uo(d, h)
- }
- function Hg(t) {
- var e = Math.round(t);
- return Math.abs(t - e) < 1e-4 ? e : Math.ceil(t)
- }
- function Zg(t, e, i) {
- this.dimension = "single", this.dimensions = ["single"], this._axis = null, this._rect, this._init(t, e, i), this.model =
- t
- }
- function Ug(t, e) {
- e = e || {};
- var i = t.coordinateSystem,
- n = t.axis,
- o = {},
- a = n.position,
- r = n.orient,
- s = i.getRect(),
- l = [s.x, s.x + s.width, s.y, s.y + s.height],
- u = {
- horizontal: {
- top: l[2],
- bottom: l[3]
- },
- vertical: {
- left: l[0],
- right: l[1]
- }
- };
- o.position = ["vertical" === r ? u.vertical[a] : l[0], "horizontal" === r ? u.horizontal[a] : l[3]];
- var h = {
- horizontal: 0,
- vertical: 1
- };
- o.rotation = Math.PI / 2 * h[r];
- var c = {
- top: -1,
- bottom: 1,
- right: 1,
- left: -1
- };
- o.labelDirection = o.tickDirection = o.nameDirection = c[a], t.get("axisTick.inside") && (o.tickDirection = -o.tickDirection),
- T(e.labelInside, t.get("axisLabel.inside")) && (o.labelDirection = -o.labelDirection);
- var d = e.rotate;
- return null == d && (d = t.get("axisLabel.rotate")), o.labelRotation = "top" === a ? -d : d, o.z2 = 1, o
- }
- function Xg(t, e, i, n, o) {
- var r = t.axis;
- if (!r.scale.isBlank() && r.containData(e))
- if (t.involveSeries) {
- var s = jg(e, t),
- l = s.payloadBatch,
- u = s.snapToValue;
- l[0] && null == o.seriesIndex && a(o, l[0]), !n && t.snap && r.containData(u) && null != u && (e = u), i.showPointer(
- t, e, l, o), i.showTooltip(t, s, u)
- } else i.showPointer(t, e)
- }
- function jg(t, e) {
- var i = e.axis,
- n = i.dim,
- o = t,
- a = [],
- r = Number.MAX_VALUE,
- s = -1;
- return iP(e.seriesModels, function(e, l) {
- var u, h, c = e.getData().mapDimension(n, !0);
- if (e.getAxisTooltipData) {
- var d = e.getAxisTooltipData(c, t, i);
- h = d.dataIndices, u = d.nestestValue
- } else {
- if (!(h = e.getData().indicesOfNearest(c[0], t, "category" === i.type ? .5 : null)).length) return;
- u = e.getData().get(c[0], h[0])
- }
- if (null != u && isFinite(u)) {
- var f = t - u,
- p = Math.abs(f);
- p <= r && ((p < r || f >= 0 && s < 0) && (r = p, s = f, o = u, a.length = 0), iP(h, function(t) {
- a.push({
- seriesIndex: e.seriesIndex,
- dataIndexInside: t,
- dataIndex: e.getData().getRawIndex(t)
- })
- }))
- }
- }), {
- payloadBatch: a,
- snapToValue: o
- }
- }
- function Yg(t, e, i, n) {
- t[e.key] = {
- value: i,
- payloadBatch: n
- }
- }
- function qg(t, e, i, n) {
- var o = i.payloadBatch,
- a = e.axis,
- r = a.model,
- s = e.axisPointerModel;
- if (e.triggerTooltip && o.length) {
- var l = e.coordSys.model,
- u = bh(l),
- h = t.map[u];
- h || (h = t.map[u] = {
- coordSysId: l.id,
- coordSysIndex: l.componentIndex,
- coordSysType: l.type,
- coordSysMainType: l.mainType,
- dataByAxis: []
- }, t.list.push(h)), h.dataByAxis.push({
- axisDim: a.dim,
- axisIndex: r.componentIndex,
- axisType: r.type,
- axisId: r.id,
- value: n,
- valueLabelOpt: {
- precision: s.get("label.precision"),
- formatter: s.get("label.formatter")
- },
- seriesDataIndices: o.slice()
- })
- }
- }
- function Kg(t, e, i) {
- var n = i.axesInfo = [];
- iP(e, function(e, i) {
- var o = e.axisPointerModel.option,
- a = t[i];
- a ? (!e.useHandle && (o.status = "show"), o.value = a.value, o.seriesDataIndices = (a.payloadBatch || []).slice()) :
- !e.useHandle && (o.status = "hide"), "show" === o.status && n.push({
- axisDim: e.axis.dim,
- axisIndex: e.axis.model.componentIndex,
- value: o.value
- })
- })
- }
- function $g(t, e, i, n) {
- if (!em(e) && t.list.length) {
- var o = ((t.list[0].dataByAxis[0] || {}).seriesDataIndices || [])[0] || {};
- n({
- type: "showTip",
- escapeConnect: !0,
- x: e[0],
- y: e[1],
- tooltipOption: i.tooltipOption,
- position: i.position,
- dataIndexInside: o.dataIndexInside,
- dataIndex: o.dataIndex,
- seriesIndex: o.seriesIndex,
- dataByCoordSys: t.list
- })
- } else n({
- type: "hideTip"
- })
- }
- function Jg(t, e, i) {
- var n = i.getZr(),
- o = oP(n).axisPointerLastHighlights || {},
- a = oP(n).axisPointerLastHighlights = {};
- iP(t, function(t, e) {
- var i = t.axisPointerModel.option;
- "show" === i.status && iP(i.seriesDataIndices, function(t) {
- var e = t.seriesIndex + " | " + t.dataIndex;
- a[e] = t
- })
- });
- var r = [],
- s = [];
- d(o, function(t, e) {
- !a[e] && s.push(t)
- }), d(a, function(t, e) {
- !o[e] && r.push(t)
- }), s.length && i.dispatchAction({
- type: "downplay",
- escapeConnect: !0,
- batch: s
- }), r.length && i.dispatchAction({
- type: "highlight",
- escapeConnect: !0,
- batch: r
- })
- }
- function Qg(t, e) {
- for (var i = 0; i < (t || []).length; i++) {
- var n = t[i];
- if (e.axis.dim === n.axisDim && e.axis.model.componentIndex === n.axisIndex) return n
- }
- }
- function tm(t) {
- var e = t.axis.model,
- i = {},
- n = i.axisDim = t.axis.dim;
- return i.axisIndex = i[n + "AxisIndex"] = e.componentIndex, i.axisName = i[n + "AxisName"] = e.name, i.axisId = i[n +
- "AxisId"] = e.id, i
- }
- function em(t) {
- return !t || null == t[0] || isNaN(t[0]) || null == t[1] || isNaN(t[1])
- }
- function im(t, e, i) {
- if (!z_.node) {
- var n = e.getZr();
- aP(n).records || (aP(n).records = {}), nm(n, e), (aP(n).records[t] || (aP(n).records[t] = {})).handler = i
- }
- }
- function nm(t, e) {
- function i(i, n) {
- t.on(i, function(i) {
- var o = sm(e);
- rP(aP(t).records, function(t) {
- t && n(t, i, o.dispatchAction)
- }), om(o.pendings, e)
- })
- }
- aP(t).initialized || (aP(t).initialized = !0, i("click", v(rm, "click")), i("mousemove", v(rm, "mousemove")), i(
- "globalout", am))
- }
- function om(t, e) {
- var i, n = t.showTip.length,
- o = t.hideTip.length;
- n ? i = t.showTip[n - 1] : o && (i = t.hideTip[o - 1]), i && (i.dispatchAction = null, e.dispatchAction(i))
- }
- function am(t, e, i) {
- t.handler("leave", null, i)
- }
- function rm(t, e, i, n) {
- e.handler(t, i, n)
- }
- function sm(t) {
- var e = {
- showTip: [],
- hideTip: []
- },
- i = function(n) {
- var o = e[n.type];
- o ? o.push(n) : (n.dispatchAction = i, t.dispatchAction(n))
- };
- return {
- dispatchAction: i,
- pendings: e
- }
- }
- function lm(t, e) {
- if (!z_.node) {
- var i = e.getZr();
- (aP(i).records || {})[t] && (aP(i).records[t] = null)
- }
- }
- function um() {}
- function hm(t, e, i, n) {
- cm(lP(i).lastProp, n) || (lP(i).lastProp = n, e ? bo(i, n, t) : (i.stopAnimation(), i.attr(n)))
- }
- function cm(t, e) {
- if (w(t) && w(e)) {
- var i = !0;
- return d(e, function(e, n) {
- i = i && cm(t[n], e)
- }), !!i
- }
- return t === e
- }
- function dm(t, e) {
- t[e.get("label.show") ? "show" : "hide"]()
- }
- function fm(t) {
- return {
- position: t.position.slice(),
- rotation: t.rotation || 0
- }
- }
- function pm(t, e, i) {
- var n = e.get("z"),
- o = e.get("zlevel");
- t && t.traverse(function(t) {
- "group" !== t.type && (null != n && (t.z = n), null != o && (t.zlevel = o), t.silent = i)
- })
- }
- function gm(t) {
- var e, i = t.get("type"),
- n = t.getModel(i + "Style");
- return "line" === i ? (e = n.getLineStyle()).fill = null : "shadow" === i && ((e = n.getAreaStyle()).stroke = null),
- e
- }
- function mm(t, e, i, n, o) {
- var a = ym(i.get("value"), e.axis, e.ecModel, i.get("seriesDataIndices"), {
- precision: i.get("label.precision"),
- formatter: i.get("label.formatter")
- }),
- r = i.getModel("label"),
- s = OM(r.get("padding") || 0),
- l = r.getFont(),
- u = De(a, l),
- h = o.position,
- c = u.width + s[1] + s[3],
- d = u.height + s[0] + s[2],
- f = o.align;
- "right" === f && (h[0] -= c), "center" === f && (h[0] -= c / 2);
- var p = o.verticalAlign;
- "bottom" === p && (h[1] -= d), "middle" === p && (h[1] -= d / 2), vm(h, c, d, n);
- var g = r.get("backgroundColor");
- g && "auto" !== g || (g = e.get("axisLine.lineStyle.color")), t.label = {
- shape: {
- x: 0,
- y: 0,
- width: c,
- height: d,
- r: r.get("borderRadius")
- },
- position: h.slice(),
- style: {
- text: a,
- textFont: l,
- textFill: r.getTextColor(),
- textPosition: "inside",
- fill: g,
- stroke: r.get("borderColor") || "transparent",
- lineWidth: r.get("borderWidth") || 0,
- shadowBlur: r.get("shadowBlur"),
- shadowColor: r.get("shadowColor"),
- shadowOffsetX: r.get("shadowOffsetX"),
- shadowOffsetY: r.get("shadowOffsetY")
- },
- z2: 10
- }
- }
- function vm(t, e, i, n) {
- var o = n.getWidth(),
- a = n.getHeight();
- t[0] = Math.min(t[0] + e, o) - e, t[1] = Math.min(t[1] + i, a) - i, t[0] = Math.max(t[0], 0), t[1] = Math.max(t[1],
- 0)
- }
- function ym(t, e, i, n, o) {
- t = e.scale.parse(t);
- var a = e.scale.getLabel(t, {
- precision: o.precision
- }),
- r = o.formatter;
- if (r) {
- var s = {
- value: Wl(e, t),
- seriesData: []
- };
- d(n, function(t) {
- var e = i.getSeriesByIndex(t.seriesIndex),
- n = t.dataIndexInside,
- o = e && e.getDataParams(n);
- o && s.seriesData.push(o)
- }), _(r) ? a = r.replace("{value}", a) : x(r) && (a = r(s))
- }
- return a
- }
- function xm(t, e, i) {
- var n = mt();
- return wt(n, n, i.rotation), _t(n, n, i.position), Io([t.dataToCoord(e), (i.labelOffset || 0) + (i.labelDirection ||
- 1) * (i.labelMargin || 0)], n)
- }
- function _m(t, e, i, n, o, a) {
- var r = ID.innerTextLayout(i.rotation, 0, i.labelDirection);
- i.labelMargin = o.get("label.margin"), mm(e, n, o, a, {
- position: xm(n.axis, t, i),
- align: r.textAlign,
- verticalAlign: r.textVerticalAlign
- })
- }
- function wm(t, e, i) {
- return i = i || 0, {
- x1: t[i],
- y1: t[1 - i],
- x2: e[i],
- y2: e[1 - i]
- }
- }
- function bm(t, e, i) {
- return i = i || 0, {
- x: t[i],
- y: t[1 - i],
- width: e[i],
- height: e[1 - i]
- }
- }
- function Sm(t, e, i, n, o, a) {
- return {
- cx: t,
- cy: e,
- r0: i,
- r: n,
- startAngle: o,
- endAngle: a,
- clockwise: !0
- }
- }
- function Mm(t, e) {
- var i = {};
- return i[e.dim + "AxisIndex"] = e.index, t.getCartesian(i)
- }
- function Im(t) {
- return "x" === t.dim ? 0 : 1
- }
- function Tm(t) {
- return t.isHorizontal() ? 0 : 1
- }
- function Am(t, e) {
- var i = t.getRect();
- return [i[fP[e]], i[fP[e]] + i[pP[e]]]
- }
- function Dm(t, e, i) {
- var n = new aM({
- shape: {
- x: t.x - 10,
- y: t.y - 10,
- width: 0,
- height: t.height + 20
- }
- });
- return So(n, {
- shape: {
- width: t.width + 20,
- height: t.height + 20
- }
- }, e, i), n
- }
- function Cm(t, e, i) {
- if (t.count())
- for (var n, o = e.coordinateSystem, a = e.getLayerSeries(), r = t.mapDimension("single"), s = t.mapDimension(
- "value"), l = f(a, function(e) {
- return f(e.indices, function(e) {
- var i = o.dataToPoint(t.get(r, e));
- return i[1] = t.get(s, e), i
- })
- }), u = Lm(l), h = u.y0, c = i / u.max, d = a.length, p = a[0].indices.length, g = 0; g < p; ++g) {
- n = h[g] * c, t.setItemLayout(a[0].indices[g], {
- layerIndex: 0,
- x: l[0][g][0],
- y0: n,
- y: l[0][g][1] * c
- });
- for (var m = 1; m < d; ++m) n += l[m - 1][g][1] * c, t.setItemLayout(a[m].indices[g], {
- layerIndex: m,
- x: l[m][g][0],
- y0: n,
- y: l[m][g][1] * c
- })
- }
- }
- function Lm(t) {
- for (var e = t.length, i = t[0].length, n = [], o = [], a = 0, r = {}, s = 0; s < i; ++s) {
- for (var l = 0, u = 0; l < e; ++l) u += t[l][s][1];
- u > a && (a = u), n.push(u)
- }
- for (var h = 0; h < i; ++h) o[h] = (a - n[h]) / 2;
- a = 0;
- for (var c = 0; c < i; ++c) {
- var d = n[c] + o[c];
- d > a && (a = d)
- }
- return r.y0 = o, r.max = a, r
- }
- function km(t) {
- var e = 0;
- d(t.children, function(t) {
- km(t);
- var i = t.value;
- y(i) && (i = i[0]), e += i
- });
- var i = t.value;
- y(i) && (i = i[0]), (null == i || isNaN(i)) && (i = e), i < 0 && (i = 0), y(t.value) ? t.value[0] = i : t.value = i
- }
- function Pm(t, e, i) {
- function n() {
- r.ignore = r.hoverIgnore
- }
- function o() {
- r.ignore = r.normalIgnore
- }
- Zw.call(this);
- var a = new QS({
- z2: xP
- });
- a.seriesIndex = e.seriesIndex;
- var r = new qS({
- z2: _P,
- silent: t.getModel("label").get("silent")
- });
- this.add(a), this.add(r), this.updateData(!0, t, "normal", e, i), this.on("emphasis", n).on("normal", o).on(
- "mouseover", n).on("mouseout", o)
- }
- function Nm(t, e, i) {
- var n = t.getVisual("color"),
- o = t.getVisual("visualMeta");
- o && 0 !== o.length || (n = null);
- var a = t.getModel("itemStyle").get("color");
- if (a) return a;
- if (n) return n;
- if (0 === t.depth) return i.option.color[0];
- var r = i.option.color.length;
- return a = i.option.color[Om(t) % r]
- }
- function Om(t) {
- for (var e = t; e.depth > 1;) e = e.parentNode;
- return l(t.getAncestors()[0].children, e)
- }
- function Em(t, e, i) {
- return i !== yP.NONE && (i === yP.SELF ? t === e : i === yP.ANCESTOR ? t === e || t.isAncestorOf(e) : t === e || t.isDescendantOf(
- e))
- }
- function Rm(t, e) {
- var i = t.children || [];
- t.children = zm(i, e), i.length && d(t.children, function(t) {
- Rm(t, e)
- })
- }
- function zm(t, e) {
- if ("function" == typeof e) return t.sort(e);
- var i = "asc" === e;
- return t.sort(function(t, e) {
- var n = (t.getValue() - e.getValue()) * (i ? 1 : -1);
- return 0 === n ? (t.dataIndex - e.dataIndex) * (i ? -1 : 1) : n
- })
- }
- function Bm(t, e) {
- return e = e || [0, 0], f(["x", "y"], function(i, n) {
- var o = this.getAxis(i),
- a = e[n],
- r = t[n] / 2;
- return "category" === o.type ? o.getBandWidth() : Math.abs(o.dataToCoord(a - r) - o.dataToCoord(a + r))
- }, this)
- }
- function Vm(t, e) {
- return e = e || [0, 0], f([0, 1], function(i) {
- var n = e[i],
- o = t[i] / 2,
- a = [],
- r = [];
- return a[i] = n - o, r[i] = n + o, a[1 - i] = r[1 - i] = e[1 - i], Math.abs(this.dataToPoint(a)[i] - this.dataToPoint(
- r)[i])
- }, this)
- }
- function Gm(t, e) {
- var i = this.getAxis(),
- n = e instanceof Array ? e[0] : e,
- o = (t instanceof Array ? t[0] : t) / 2;
- return "category" === i.type ? i.getBandWidth() : Math.abs(i.dataToCoord(n - o) - i.dataToCoord(n + o))
- }
- function Fm(t, e) {
- return f(["Radius", "Angle"], function(i, n) {
- var o = this["get" + i + "Axis"](),
- a = e[n],
- r = t[n] / 2,
- s = "dataTo" + i,
- l = "category" === o.type ? o.getBandWidth() : Math.abs(o[s](a - r) - o[s](a + r));
- return "Angle" === i && (l = l * Math.PI / 180), l
- }, this)
- }
- function Wm(t) {
- var e, i = t.type;
- if ("path" === i) {
- var n = t.shape,
- o = null != n.width && null != n.height ? {
- x: n.x || 0,
- y: n.y || 0,
- width: n.width,
- height: n.height
- } : null,
- a = tv(n);
- (e = Wn(a, null, o, n.layout || "center")).__customPathData = a
- } else "image" === i ? (e = new hi({})).__customImagePath = t.style.image : "text" === i ? (e = new qS({})).__customText =
- t.style.text : e = new(0, bM[i.charAt(0).toUpperCase() + i.slice(1)]);
- return e.__customGraphicType = i, e.name = t.name, e
- }
- function Hm(t, e, n, o, a, r, s) {
- var l = {},
- u = n.style || {};
- if (n.shape && (l.shape = i(n.shape)), n.position && (l.position = n.position.slice()), n.scale && (l.scale = n.scale
- .slice()), n.origin && (l.origin = n.origin.slice()), n.rotation && (l.rotation = n.rotation), "image" === t.type &&
- n.style) {
- h = l.style = {};
- d(["x", "y", "width", "height"], function(e) {
- Zm(e, h, u, t.style, r)
- })
- }
- if ("text" === t.type && n.style) {
- var h = l.style = {};
- d(["x", "y"], function(e) {
- Zm(e, h, u, t.style, r)
- }), !u.hasOwnProperty("textFill") && u.fill && (u.textFill = u.fill), !u.hasOwnProperty("textStroke") && u.stroke &&
- (u.textStroke = u.stroke)
- }
- if ("group" !== t.type && (t.useStyle(u), r)) {
- t.style.opacity = 0;
- var c = u.opacity;
- null == c && (c = 1), So(t, {
- style: {
- opacity: c
- }
- }, o, e)
- }
- r ? t.attr(l) : bo(t, l, o, e), n.hasOwnProperty("z2") && t.attr("z2", n.z2 || 0), n.hasOwnProperty("silent") && t.attr(
- "silent", n.silent), n.hasOwnProperty("invisible") && t.attr("invisible", n.invisible), n.hasOwnProperty("ignore") &&
- t.attr("ignore", n.ignore), n.hasOwnProperty("info") && t.attr("info", n.info);
- var f = n.styleEmphasis,
- p = !1 === f;
- t.__cusHasEmphStl && null == f || !t.__cusHasEmphStl && p || (no(t, f), t.__cusHasEmphStl = !p), s && ho(t, !p)
- }
- function Zm(t, e, i, n, o) {
- null == i[t] || o || (e[t] = i[t], i[t] = n[t])
- }
- function Um(t, e, i, n) {
- function o(t) {
- null == t && (t = h), v && (c = e.getItemModel(t), d = c.getModel(AP), f = c.getModel(DP), p = e.getItemVisual(t,
- "color"), v = !1)
- }
- var s = t.get("renderItem"),
- l = t.coordinateSystem,
- u = {};
- l && (u = l.prepareCustoms ? l.prepareCustoms() : LP[l.type](l));
- var h, c, d, f, p, g = r({
- getWidth: n.getWidth,
- getHeight: n.getHeight,
- getZr: n.getZr,
- getDevicePixelRatio: n.getDevicePixelRatio,
- value: function(t, i) {
- return null == i && (i = h), e.get(e.getDimension(t || 0), i)
- },
- style: function(i, n) {
- null == n && (n = h), o(n);
- var r = c.getModel(IP).getItemStyle();
- null != p && (r.fill = p);
- var s = e.getItemVisual(n, "opacity");
- return null != s && (r.opacity = s), fo(r, d, null, {
- autoColor: p,
- isRectText: !0
- }), r.text = d.getShallow("show") ? A(t.getFormattedLabel(n, "normal"), gu(e, n)) : null, i && a(r, i), r
- },
- styleEmphasis: function(i, n) {
- null == n && (n = h), o(n);
- var r = c.getModel(TP).getItemStyle();
- return fo(r, f, null, {
- isRectText: !0
- }, !0), r.text = f.getShallow("show") ? D(t.getFormattedLabel(n, "emphasis"), t.getFormattedLabel(n, "normal"),
- gu(e, n)) : null, i && a(r, i), r
- },
- visual: function(t, i) {
- return null == i && (i = h), e.getItemVisual(i, t)
- },
- barLayout: function(t) {
- if (l.getBaseAxis) return Tl(r({
- axis: l.getBaseAxis()
- }, t), n)
- },
- currentSeriesIndices: function() {
- return i.getCurrentSeriesIndices()
- },
- font: function(t) {
- return _o(t, i)
- }
- }, u.api || {}),
- m = {
- context: {},
- seriesId: t.id,
- seriesName: t.name,
- seriesIndex: t.seriesIndex,
- coordSys: u.coordSys,
- dataInsideLength: e.count(),
- encode: Xm(t.getData())
- },
- v = !0;
- return function(t, i) {
- return h = t, v = !0, s && s(r({
- dataIndexInside: t,
- dataIndex: e.getRawIndex(t),
- actionType: i ? i.type : null
- }, m), g)
- }
- }
- function Xm(t) {
- var e = {};
- return d(t.dimensions, function(i, n) {
- var o = t.getDimensionInfo(i);
- if (!o.isExtraCoord) {
- var a = o.coordDim;
- (e[a] = e[a] || [])[o.coordDimIndex] = n
- }
- }), e
- }
- function jm(t, e, i, n, o, a) {
- return (t = Ym(t, e, i, n, o, a, !0)) && a.setItemGraphicEl(e, t), t
- }
- function Ym(t, e, i, n, o, a, r) {
- var s = !i,
- l = (i = i || {}).type,
- u = i.shape,
- h = i.style;
- if (t && (s || null != l && l !== t.__customGraphicType || "path" === l && ev(u) && tv(u) !== t.__customPathData ||
- "image" === l && iv(h, "image") && h.image !== t.__customImagePath || "text" === l && iv(u, "text") && h.text !==
- t.__customText) && (o.remove(t), t = null), !s) {
- var c = !t;
- return !t && (t = Wm(i)), Hm(t, e, i, n, a, c, r), "group" === l && qm(t, e, i, n, a), o.add(t), t
- }
- }
- function qm(t, e, i, n, o) {
- var a = i.children,
- r = a ? a.length : 0,
- s = i.$mergeChildren,
- l = "byName" === s || i.diffChildrenByName,
- u = !1 === s;
- if (r || l || u)
- if (l) Km({
- oldChildren: t.children() || [],
- newChildren: a || [],
- dataIndex: e,
- animatableModel: n,
- group: t,
- data: o
- });
- else {
- u && t.removeAll();
- for (var h = 0; h < r; h++) a[h] && Ym(t.childAt(h), e, a[h], n, t, o)
- }
- }
- function Km(t) {
- new Hs(t.oldChildren, t.newChildren, $m, $m, t).add(Jm).update(Jm).remove(Qm).execute()
- }
- function $m(t, e) {
- var i = t && t.name;
- return null != i ? i : CP + e
- }
- function Jm(t, e) {
- var i = this.context,
- n = null != t ? i.newChildren[t] : null;
- Ym(null != e ? i.oldChildren[e] : null, i.dataIndex, n, i.animatableModel, i.group, i.data)
- }
- function Qm(t) {
- var e = this.context,
- i = e.oldChildren[t];
- i && e.group.remove(i)
- }
- function tv(t) {
- return t && (t.pathData || t.d)
- }
- function ev(t) {
- return t && (t.hasOwnProperty("pathData") || t.hasOwnProperty("d"))
- }
- function iv(t, e) {
- return t && t.hasOwnProperty(e)
- }
- function nv(t, e, i, n) {
- var o = i.type,
- a = new(0, bM[o.charAt(0).toUpperCase() + o.slice(1)])(i);
- e.add(a), n.set(t, a), a.__ecGraphicId = t
- }
- function ov(t, e) {
- var i = t && t.parent;
- i && ("group" === t.type && t.traverse(function(t) {
- ov(t, e)
- }), e.removeKey(t.__ecGraphicId), i.remove(t))
- }
- function av(t) {
- return t = a({}, t), d(["id", "parentId", "$action", "hv", "bounding"].concat(HM), function(e) {
- delete t[e]
- }), t
- }
- function rv(t, e) {
- var i;
- return d(e, function(e) {
- null != t[e] && "auto" !== t[e] && (i = !0)
- }), i
- }
- function sv(t, e) {
- var i = t.exist;
- if (e.id = t.keyInfo.id, !e.type && i && (e.type = i.type), null == e.parentId) {
- var n = e.parentOption;
- n ? e.parentId = n.id : i && (e.parentId = i.parentId)
- }
- e.parentOption = null
- }
- function lv(t, e, i) {
- var o = a({}, i),
- r = t[e],
- s = i.$action || "merge";
- "merge" === s ? r ? (n(r, o, !0), ca(r, o, {
- ignoreSize: !0
- }), fa(i, r)) : t[e] = o : "replace" === s ? t[e] = o : "remove" === s && r && (t[e] = null)
- }
- function uv(t, e) {
- t && (t.hv = e.hv = [rv(e, ["left", "right"]), rv(e, ["top", "bottom"])], "group" === t.type && (null == t.width &&
- (t.width = e.width = 0), null == t.height && (t.height = e.height = 0)))
- }
- function hv(t, e, i) {
- var n = t.eventData;
- t.silent || t.ignore || n || (n = t.eventData = {
- componentType: "graphic",
- componentIndex: e.componentIndex,
- name: t.name
- }), n && (n.info = t.info)
- }
- function cv(t, e, i) {
- var n, o = {},
- a = "toggleSelected" === t;
- return i.eachComponent("legend", function(i) {
- a && null != n ? i[n ? "select" : "unSelect"](e.name) : (i[t](e.name), n = i.isSelected(e.name)), d(i.getData(),
- function(t) {
- var e = t.get("name");
- if ("\n" !== e && "" !== e) {
- var n = i.isSelected(e);
- o.hasOwnProperty(e) ? o[e] = o[e] && n : o[e] = n
- }
- })
- }), {
- name: e.name,
- selected: o
- }
- }
- function dv(t, e, i) {
- var n = e.getBoxLayoutParams(),
- o = e.get("padding"),
- a = {
- width: i.getWidth(),
- height: i.getHeight()
- },
- r = la(n, a, o);
- UM(e.get("orient"), t, e.get("itemGap"), r.width, r.height), ua(t, n, a, o)
- }
- function fv(t, e) {
- var i = OM(e.get("padding")),
- n = e.getItemStyle(["color", "opacity"]);
- return n.fill = e.get("backgroundColor"), t = new aM({
- shape: {
- x: t.x - i[3],
- y: t.y - i[0],
- width: t.width + i[1] + i[3],
- height: t.height + i[0] + i[2],
- r: e.get("borderRadius")
- },
- style: n,
- silent: !0,
- z2: -1
- })
- }
- function pv(t, e) {
- e.dispatchAction({
- type: "legendToggleSelect",
- name: t
- })
- }
- function gv(t, e, i, n) {
- var o = i.getZr().storage.getDisplayList()[0];
- o && o.useHoverLayer || i.dispatchAction({
- type: "highlight",
- seriesName: t,
- name: e,
- excludeSeriesId: n
- })
- }
- function mv(t, e, i, n) {
- var o = i.getZr().storage.getDisplayList()[0];
- o && o.useHoverLayer || i.dispatchAction({
- type: "downplay",
- seriesName: t,
- name: e,
- excludeSeriesId: n
- })
- }
- function vv(t, e, i) {
- var n = [1, 1];
- n[t.getOrient().index] = 0, ca(e, i, {
- type: "box",
- ignoreSize: n
- })
- }
- function yv(t) {
- var e = "left " + t + "s cubic-bezier(0.23, 1, 0.32, 1),top " + t + "s cubic-bezier(0.23, 1, 0.32, 1)";
- return f(ZP, function(t) {
- return t + "transition:" + e
- }).join(";")
- }
- function xv(t) {
- var e = [],
- i = t.get("fontSize"),
- n = t.getTextColor();
- return n && e.push("color:" + n), e.push("font:" + t.getFont()), i && e.push("line-height:" + Math.round(3 * i / 2) +
- "px"), WP(["decoration", "align"], function(i) {
- var n = t.get(i);
- n && e.push("text-" + i + ":" + n)
- }), e.join(";")
- }
- function _v(t) {
- var e = [],
- i = t.get("transitionDuration"),
- n = t.get("backgroundColor"),
- o = t.getModel("textStyle"),
- a = t.get("padding");
- return i && e.push(yv(i)), n && (z_.canvasSupported ? e.push("background-Color:" + n) : (e.push("background-Color:#" +
- Ft(n)), e.push("filter:alpha(opacity=70)"))), WP(["width", "color", "radius"], function(i) {
- var n = "border-" + i,
- o = HP(n),
- a = t.get(o);
- null != a && e.push(n + ":" + a + ("color" === i ? "" : "px"))
- }), e.push(xv(o)), null != a && e.push("padding:" + OM(a).join("px ") + "px"), e.join(";") + ";"
- }
- function wv(t, e) {
- if (z_.wxa) return null;
- var i = document.createElement("div"),
- n = this._zr = e.getZr();
- this.el = i, this._x = e.getWidth() / 2, this._y = e.getHeight() / 2, t.appendChild(i), this._container = t, this._show = !
- 1, this._hideTimeout;
- var o = this;
- i.onmouseenter = function() {
- o._enterable && (clearTimeout(o._hideTimeout), o._show = !0), o._inContent = !0
- }, i.onmousemove = function(e) {
- if (e = e || window.event, !o._enterable) {
- var i = n.handler;
- lt(t, e, !0), i.dispatch("mousemove", e)
- }
- }, i.onmouseleave = function() {
- o._enterable && o._show && o.hideLater(o._hideDelay), o._inContent = !1
- }
- }
- function bv(t) {
- this._zr = t.getZr(), this._show = !1, this._hideTimeout
- }
- function Sv(t) {
- for (var e = t.pop(); t.length;) {
- var i = t.pop();
- i && (Lo.isInstance(i) && (i = i.get("tooltip", !0)), "string" == typeof i && (i = {
- formatter: i
- }), e = new Lo(i, e, e.ecModel))
- }
- return e
- }
- function Mv(t, e) {
- return t.dispatchAction || m(e.dispatchAction, e)
- }
- function Iv(t, e, i, n, o, a, r) {
- var s = i.getOuterSize(),
- l = s.width,
- u = s.height;
- return null != a && (t + l + a > n ? t -= l + a : t += a), null != r && (e + u + r > o ? e -= u + r : e += r), [t, e]
- }
- function Tv(t, e, i, n, o) {
- var a = i.getOuterSize(),
- r = a.width,
- s = a.height;
- return t = Math.min(t + r, n) - r, e = Math.min(e + s, o) - s, t = Math.max(t, 0), e = Math.max(e, 0), [t, e]
- }
- function Av(t, e, i) {
- var n = i[0],
- o = i[1],
- a = 0,
- r = 0,
- s = e.width,
- l = e.height;
- switch (t) {
- case "inside":
- a = e.x + s / 2 - n / 2, r = e.y + l / 2 - o / 2;
- break;
- case "top":
- a = e.x + s / 2 - n / 2, r = e.y - o - 5;
- break;
- case "bottom":
- a = e.x + s / 2 - n / 2, r = e.y + l + 5;
- break;
- case "left":
- a = e.x - n - 5, r = e.y + l / 2 - o / 2;
- break;
- case "right":
- a = e.x + s + 5, r = e.y + l / 2 - o / 2
- }
- return [a, r]
- }
- function Dv(t) {
- return "center" === t || "middle" === t
- }
- function Cv(t) {
- return t.get("stack") || "__ec_stack_" + t.seriesIndex
- }
- function Lv(t) {
- return t.dim
- }
- function kv(t, e) {
- var i = {};
- d(t, function(t, e) {
- var n = t.getData(),
- o = t.coordinateSystem.getBaseAxis(),
- a = o.getExtent(),
- r = "category" === o.type ? o.getBandWidth() : Math.abs(a[1] - a[0]) / n.count(),
- s = i[Lv(o)] || {
- bandWidth: r,
- remainedWidth: r,
- autoWidthCount: 0,
- categoryGap: "20%",
- gap: "30%",
- stacks: {}
- },
- l = s.stacks;
- i[Lv(o)] = s;
- var u = Cv(t);
- l[u] || s.autoWidthCount++, l[u] = l[u] || {
- width: 0,
- maxWidth: 0
- };
- var h = Ro(t.get("barWidth"), r),
- c = Ro(t.get("barMaxWidth"), r),
- d = t.get("barGap"),
- f = t.get("barCategoryGap");
- h && !l[u].width && (h = Math.min(s.remainedWidth, h), l[u].width = h, s.remainedWidth -= h), c && (l[u].maxWidth =
- c), null != d && (s.gap = d), null != f && (s.categoryGap = f)
- });
- var n = {};
- return d(i, function(t, e) {
- n[e] = {};
- var i = t.stacks,
- o = t.bandWidth,
- a = Ro(t.categoryGap, o),
- r = Ro(t.gap, 1),
- s = t.remainedWidth,
- l = t.autoWidthCount,
- u = (s - a) / (l + (l - 1) * r);
- u = Math.max(u, 0), d(i, function(t, e) {
- var i = t.maxWidth;
- i && i < u && (i = Math.min(i, s), t.width && (i = Math.min(i, t.width)), s -= i, t.width = i, l--)
- }), u = (s - a) / (l + (l - 1) * r), u = Math.max(u, 0);
- var h, c = 0;
- d(i, function(t, e) {
- t.width || (t.width = u), h = t, c += t.width * (1 + r)
- }), h && (c -= h.width * r);
- var f = -c / 2;
- d(i, function(t, i) {
- n[e][i] = n[e][i] || {
- offset: f,
- width: t.width
- }, f += t.width * (1 + r)
- })
- }), n
- }
- function Pv(t, e) {
- HA.call(this, "radius", t, e), this.type = "category"
- }
- function Nv(t, e) {
- e = e || [0, 360], HA.call(this, "angle", t, e), this.type = "category"
- }
- function Ov(t, e) {
- return e.type || (e.data ? "category" : "value")
- }
- function Ev(t, e, i) {
- var n = e.get("center"),
- o = i.getWidth(),
- a = i.getHeight();
- t.cx = Ro(n[0], o), t.cy = Ro(n[1], a);
- var r = t.getRadiusAxis(),
- s = Math.min(o, a) / 2,
- l = Ro(e.get("radius"), s);
- r.inverse ? r.setExtent(l, 0) : r.setExtent(0, l)
- }
- function Rv(t, e) {
- var i = this,
- n = i.getAngleAxis(),
- o = i.getRadiusAxis();
- if (n.scale.setExtent(1 / 0, -1 / 0), o.scale.setExtent(1 / 0, -1 / 0), t.eachSeries(function(t) {
- if (t.coordinateSystem === i) {
- var e = t.getData();
- d(e.mapDimension("radius", !0), function(t) {
- o.scale.unionExtentFromData(e, cl(e, t))
- }), d(e.mapDimension("angle", !0), function(t) {
- n.scale.unionExtentFromData(e, cl(e, t))
- })
- }
- }), Bl(n.scale, n.model), Bl(o.scale, o.model), "category" === n.type && !n.onBand) {
- var a = n.getExtent(),
- r = 360 / n.scale.count();
- n.inverse ? a[1] += r : a[1] -= r, n.setExtent(a[0], a[1])
- }
- }
- function zv(t, e) {
- if (t.type = e.get("type"), t.scale = Vl(e), t.onBand = e.get("boundaryGap") && "category" === t.type, t.inverse = e
- .get("inverse"), "angleAxis" === e.mainType) {
- t.inverse ^= e.get("clockwise");
- var i = e.get("startAngle");
- t.setExtent(i, i + (t.inverse ? -360 : 360))
- }
- e.axis = t, t.model = e
- }
- function Bv(t, e, i) {
- e[1] > e[0] && (e = e.slice().reverse());
- var n = t.coordToPoint([e[0], i]),
- o = t.coordToPoint([e[1], i]);
- return {
- x1: n[0],
- y1: n[1],
- x2: o[0],
- y2: o[1]
- }
- }
- function Vv(t) {
- return t.getRadiusAxis().inverse ? 0 : 1
- }
- function Gv(t) {
- var e = t[0],
- i = t[t.length - 1];
- e && i && Math.abs(Math.abs(e.coord - i.coord) - 360) < 1e-4 && t.pop()
- }
- function Fv(t, e, i) {
- return {
- position: [t.cx, t.cy],
- rotation: i / 180 * Math.PI,
- labelDirection: -1,
- tickDirection: -1,
- nameDirection: 1,
- labelRotate: e.getModel("axisLabel").get("rotate"),
- z2: 1
- }
- }
- function Wv(t, e, i, n, o) {
- var a = e.axis,
- r = a.dataToCoord(t),
- s = n.getAngleAxis().getExtent()[0];
- s = s / 180 * Math.PI;
- var l, u, h, c = n.getRadiusAxis().getExtent();
- if ("radius" === a.dim) {
- var d = mt();
- wt(d, d, s), _t(d, d, [n.cx, n.cy]), l = Io([r, -o], d);
- var f = e.getModel("axisLabel").get("rotate") || 0,
- p = ID.innerTextLayout(s, f * Math.PI / 180, -1);
- u = p.textAlign, h = p.textVerticalAlign
- } else {
- var g = c[1];
- l = n.coordToPoint([g + o, r]);
- var m = n.cx,
- v = n.cy;
- u = Math.abs(l[0] - m) / g < .3 ? "center" : l[0] > m ? "left" : "right", h = Math.abs(l[1] - v) / g < .3 ?
- "middle" : l[1] > v ? "top" : "bottom"
- }
- return {
- position: l,
- align: u,
- verticalAlign: h
- }
- }
- function Hv(t, e) {
- e.update = "updateView", Ps(e, function(e, i) {
- var n = {};
- return i.eachComponent({
- mainType: "geo",
- query: e
- }, function(i) {
- i[t](e.name), d(i.coordinateSystem.regions, function(t) {
- n[t.name] = i.isSelected(t.name) || !1
- })
- }), {
- selected: n,
- name: e.name
- }
- })
- }
- function Zv(t) {
- var e = {};
- d(t, function(t) {
- e[t] = 1
- }), t.length = 0, d(e, function(e, i) {
- t.push(i)
- })
- }
- function Uv(t) {
- if (t)
- for (var e in t)
- if (t.hasOwnProperty(e)) return !0
- }
- function Xv(t, e, n) {
- function o() {
- var t = function() {};
- return t.prototype.__hidden = t.prototype, new t
- }
- var a = {};
- return rN(e, function(e) {
- var r = a[e] = o();
- rN(t[e], function(t, o) {
- if (jC.isValidType(o)) {
- var a = {
- type: o,
- visual: t
- };
- n && n(a, e), r[o] = new jC(a), "opacity" === o && ((a = i(a)).type = "colorAlpha", r.__hidden.__alphaForOpacity =
- new jC(a))
- }
- })
- }), a
- }
- function jv(t, e, n) {
- var o;
- d(n, function(t) {
- e.hasOwnProperty(t) && Uv(e[t]) && (o = !0)
- }), o && d(n, function(n) {
- e.hasOwnProperty(n) && Uv(e[n]) ? t[n] = i(e[n]) : delete t[n]
- })
- }
- function Yv(t, e, i, n, o, a) {
- function r(t) {
- return i.getItemVisual(h, t)
- }
- function s(t, e) {
- i.setItemVisual(h, t, e)
- }
- function l(t, l) {
- h = null == a ? t : l;
- var c = i.getRawDataItem(h);
- if (!c || !1 !== c.visualMap)
- for (var d = n.call(o, t), f = e[d], p = u[d], g = 0, m = p.length; g < m; g++) {
- var v = p[g];
- f[v] && f[v].applyVisual(t, r, s)
- }
- }
- var u = {};
- d(t, function(t) {
- var i = jC.prepareVisualTypes(e[t]);
- u[t] = i
- });
- var h;
- null == a ? i.each(l) : i.each([a], l)
- }
- function qv(t, e, i, n) {
- var o = {};
- return d(t, function(t) {
- var i = jC.prepareVisualTypes(e[t]);
- o[t] = i
- }), {
- progress: function(t, a) {
- null != n && (n = a.getDimension(n));
- for (var r; null != (r = t.next());) {
- var s = a.getRawDataItem(r);
- if (s && !1 === s.visualMap) return;
- for (var l = null != n ? a.get(n, r, !0) : r, u = i(l), h = e[u], c = o[u], d = 0, f = c.length; d < f; d++) {
- var p = c[d];
- h[p] && h[p].applyVisual(l, function(t) {
- return a.getItemVisual(r, t)
- }, function(t, e) {
- a.setItemVisual(r, t, e)
- })
- }
- }
- }
- }
- }
- function Kv(t) {
- var e = ["x", "y"],
- i = ["width", "height"];
- return {
- point: function(e, i, n) {
- if (e) {
- var o = n.range;
- return $v(e[t], o)
- }
- },
- rect: function(n, o, a) {
- if (n) {
- var r = a.range,
- s = [n[e[t]], n[e[t]] + n[i[t]]];
- return s[1] < s[0] && s.reverse(), $v(s[0], r) || $v(s[1], r) || $v(r[0], s) || $v(r[1], s)
- }
- }
- }
- }
- function $v(t, e) {
- return e[0] <= t && t <= e[1]
- }
- function Jv(t, e, i, n, o) {
- for (var a = 0, r = o[o.length - 1]; a < o.length; a++) {
- var s = o[a];
- if (Qv(t, e, i, n, s[0], s[1], r[0], r[1])) return !0;
- r = s
- }
- }
- function Qv(t, e, i, n, o, a, r, s) {
- var l = ey(i - t, o - r, n - e, a - s);
- if (ty(l)) return !1;
- var u = ey(o - t, o - r, a - e, a - s) / l;
- if (u < 0 || u > 1) return !1;
- var h = ey(i - t, o - t, n - e, a - e) / l;
- return !(h < 0 || h > 1)
- }
- function ty(t) {
- return t <= 1e-6 && t >= -1e-6
- }
- function ey(t, e, i, n) {
- return t * n - e * i
- }
- function iy(t, e, i) {
- var n = this._targetInfoList = [],
- o = {},
- a = oy(e, t);
- lN(pN, function(t, e) {
- (!i || !i.include || uN(i.include, e) >= 0) && t(a, n, o)
- })
- }
- function ny(t) {
- return t[0] > t[1] && t.reverse(), t
- }
- function oy(t, e) {
- return Vi(t, e, {
- includeMainTypes: dN
- })
- }
- function ay(t, e, i, n) {
- var o = i.getAxis(["x", "y"][t]),
- a = ny(f([0, 1], function(t) {
- return e ? o.coordToData(o.toLocalCoord(n[t])) : o.toGlobalCoord(o.dataToCoord(n[t]))
- })),
- r = [];
- return r[t] = a, r[1 - t] = [NaN, NaN], {
- values: a,
- xyMinMax: r
- }
- }
- function ry(t, e, i, n) {
- return [e[0] - n[t] * i[0], e[1] - n[t] * i[1]]
- }
- function sy(t, e) {
- var i = ly(t),
- n = ly(e),
- o = [i[0] / n[0], i[1] / n[1]];
- return isNaN(o[0]) && (o[0] = 1), isNaN(o[1]) && (o[1] = 1), o
- }
- function ly(t) {
- return t ? [t[0][1] - t[0][0], t[1][1] - t[1][0]] : [NaN, NaN]
- }
- function uy(t, e, i, n, o) {
- if (o) {
- var a = t.getZr();
- a[wN] || (a[_N] || (a[_N] = hy), Lr(a, _N, i, e)(t, n))
- }
- }
- function hy(t, e) {
- if (!t.isDisposed()) {
- var i = t.getZr();
- i[wN] = !0, t.dispatchAction({
- type: "brushSelect",
- batch: e
- }), i[wN] = !1
- }
- }
- function cy(t, e, i, n) {
- for (var o = 0, a = e.length; o < a; o++) {
- var r = e[o];
- if (t[r.brushType](n, i, r.selectors, r)) return !0
- }
- }
- function dy(t) {
- var e = t.brushSelector;
- if (_(e)) {
- var i = [];
- return d(sN, function(t, n) {
- i[n] = function(i, n, o, a) {
- var r = n.getItemLayout(i);
- return t[e](r, o, a)
- }
- }), i
- }
- if (x(e)) {
- var n = {};
- return d(sN, function(t, i) {
- n[i] = e
- }), n
- }
- return e
- }
- function fy(t, e) {
- var i = t.option.seriesIndex;
- return null != i && "all" !== i && (y(i) ? l(i, e) < 0 : e !== i)
- }
- function py(t) {
- var e = t.selectors = {};
- return d(sN[t.brushType], function(i, n) {
- e[n] = function(n) {
- return i(n, e, t)
- }
- }), t
- }
- function gy(t) {
- return new ue(t[0][0], t[1][0], t[0][1] - t[0][0], t[1][1] - t[1][0])
- }
- function my(t, e) {
- return n({
- brushType: t.brushType,
- brushMode: t.brushMode,
- transformable: t.transformable,
- brushStyle: new Lo(t.brushStyle).getItemStyle(),
- removeOnClick: t.removeOnClick,
- z: t.z
- }, e, !0)
- }
- function vy(t, e, i, n) {
- (!n || n.$from !== t.id) && this._brushController.setPanels(t.brushTargetManager.makePanelOpts(i)).enableBrush(t.brushOption)
- .updateCovers(t.areas.slice())
- }
- function yy(t, e) {
- IN[t] = e
- }
- function xy(t) {
- return IN[t]
- }
- function _y(t, e, i) {
- this.model = t, this.ecModel = e, this.api = i, this._brushType, this._brushMode
- }
- function wy(t, e, i) {
- this._model = t
- }
- function by(t, e, i, n) {
- var o = i.calendarModel,
- a = i.seriesModel,
- r = o ? o.coordinateSystem : a ? a.coordinateSystem : null;
- return r === this ? r[t](n) : null
- }
- function Sy(t, e) {
- var i = t.cellSize;
- y(i) ? 1 === i.length && (i[1] = i[0]) : i = t.cellSize = [i, i];
- var n = f([0, 1], function(t) {
- return ha(e, t) && (i[t] = "auto"), null != i[t] && "auto" !== i[t]
- });
- ca(t, e, {
- type: "box",
- ignoreSize: n
- })
- }
- function My(t) {
- return l(kN, t) >= 0
- }
- function Iy(t, e, i) {
- function n(t, e) {
- return l(e.nodes, t) >= 0
- }
- function o(t, n) {
- var o = !1;
- return e(function(e) {
- d(i(t, e) || [], function(t) {
- n.records[e.name][t] && (o = !0)
- })
- }), o
- }
- function a(t, n) {
- n.nodes.push(t), e(function(e) {
- d(i(t, e) || [], function(t) {
- n.records[e.name][t] = !0
- })
- })
- }
- return function(i) {
- var r = {
- nodes: [],
- records: {}
- };
- if (e(function(t) {
- r.records[t.name] = {}
- }), !i) return r;
- a(i, r);
- var s;
- do {
- s = !1, t(function(t) {
- !n(t, r) && o(t, r) && (a(t, r), s = !0)
- })
- } while (s);
- return r
- }
- }
- function Ty(t, e, i) {
- var n = [1 / 0, -1 / 0];
- return NN(i, function(t) {
- var i = t.getData();
- i && NN(i.mapDimension(e, !0), function(t) {
- var e = i.getApproximateExtent(t);
- e[0] < n[0] && (n[0] = e[0]), e[1] > n[1] && (n[1] = e[1])
- })
- }), n[1] < n[0] && (n = [NaN, NaN]), Ay(t, n), n
- }
- function Ay(t, e) {
- var i = t.getAxisModel(),
- n = i.getMin(!0),
- o = "category" === i.get("type"),
- a = o && i.getCategories().length;
- null != n && "dataMin" !== n && "function" != typeof n ? e[0] = n : o && (e[0] = a > 0 ? 0 : NaN);
- var r = i.getMax(!0);
- return null != r && "dataMax" !== r && "function" != typeof r ? e[1] = r : o && (e[1] = a > 0 ? a - 1 : NaN), i.get(
- "scale", !0) || (e[0] > 0 && (e[0] = 0), e[1] < 0 && (e[1] = 0)), e
- }
- function Dy(t, e) {
- var i = t.getAxisModel(),
- n = t._percentWindow,
- o = t._valueWindow;
- if (n) {
- var a = Fo(o, [0, 500]);
- a = Math.min(a, 20);
- var r = e || 0 === n[0] && 100 === n[1];
- i.setRange(r ? null : +o[0].toFixed(a), r ? null : +o[1].toFixed(a))
- }
- }
- function Cy(t) {
- var e = t._minMaxSpan = {},
- i = t._dataZoomModel;
- NN(["min", "max"], function(n) {
- e[n + "Span"] = i.get(n + "Span");
- var o = i.get(n + "ValueSpan");
- if (null != o && (e[n + "ValueSpan"] = o, null != (o = t.getAxisModel().axis.scale.parse(o)))) {
- var a = t._dataExtent;
- e[n + "Span"] = Eo(a[0] + o, a, [0, 100], !0)
- }
- })
- }
- function Ly(t) {
- var e = {};
- return RN(["start", "end", "startValue", "endValue", "throttle"], function(i) {
- t.hasOwnProperty(i) && (e[i] = t[i])
- }), e
- }
- function ky(t, e) {
- var i = t._rangePropMode,
- n = t.get("rangeMode");
- RN([
- ["start", "startValue"],
- ["end", "endValue"]
- ], function(t, o) {
- var a = null != e[t[0]],
- r = null != e[t[1]];
- a && !r ? i[o] = "percent" : !a && r ? i[o] = "value" : n ? i[o] = n[o] : a && (i[o] = "percent")
- })
- }
- function Py(t) {
- return {
- x: "y",
- y: "x",
- radius: "angle",
- angle: "radius"
- } [t]
- }
- function Ny(t) {
- return "vertical" === t ? "ns-resize" : "ew-resize"
- }
- function Oy(t, e) {
- var i = zy(t),
- n = e.dataZoomId,
- o = e.coordId;
- d(i, function(t, i) {
- var a = t.dataZoomInfos;
- a[n] && l(e.allCoordIds, o) < 0 && (delete a[n], t.count--)
- }), Vy(i);
- var a = i[o];
- a || ((a = i[o] = {
- coordId: o,
- dataZoomInfos: {},
- count: 0
- }).controller = By(t, a), a.dispatchAction = v(Gy, t)), !a.dataZoomInfos[n] && a.count++, a.dataZoomInfos[n] = e;
- var r = Fy(a.dataZoomInfos);
- a.controller.enable(r.controlType, r.opt), a.controller.setPointerChecker(e.containsPoint), Lr(a, "dispatchAction",
- e.dataZoomModel.get("throttle", !0), "fixRate")
- }
- function Ey(t, e) {
- var i = zy(t);
- d(i, function(t) {
- t.controller.dispose();
- var i = t.dataZoomInfos;
- i[e] && (delete i[e], t.count--)
- }), Vy(i)
- }
- function Ry(t) {
- return t.type + "\0_" + t.id
- }
- function zy(t) {
- var e = t.getZr();
- return e[qN] || (e[qN] = {})
- }
- function By(t, e) {
- var i = new ac(t.getZr());
- return d(["pan", "zoom", "scrollMove"], function(t) {
- i.on(t, function(i) {
- var n = [];
- d(e.dataZoomInfos, function(o) {
- if (i.isAvailableBehavior(o.dataZoomModel.option)) {
- var a = (o.getRange || {})[t],
- r = a && a(e.controller, i);
- !o.dataZoomModel.get("disabled", !0) && r && n.push({
- dataZoomId: o.dataZoomId,
- start: r[0],
- end: r[1]
- })
- }
- }), n.length && e.dispatchAction(n)
- })
- }), i
- }
- function Vy(t) {
- d(t, function(e, i) {
- e.count || (e.controller.dispose(), delete t[i])
- })
- }
- function Gy(t, e) {
- t.dispatchAction({
- type: "dataZoom",
- batch: e
- })
- }
- function Fy(t) {
- var e, i = {
- type_true: 2,
- type_move: 1,
- type_false: 0,
- type_undefined: -1
- },
- n = !0;
- return d(t, function(t) {
- var o = t.dataZoomModel,
- a = !o.get("disabled", !0) && (!o.get("zoomLock", !0) || "move");
- i["type_" + a] > i["type_" + e] && (e = a), n &= o.get("preventDefaultMouseMove", !0)
- }), {
- controlType: e,
- opt: {
- zoomOnMouseWheel: !0,
- moveOnMouseMove: !0,
- moveOnMouseWheel: !0,
- preventDefaultMouseMove: !!n
- }
- }
- }
- function Wy(t) {
- return function(e, i, n, o) {
- var a = this._range,
- r = a.slice(),
- s = e.axisModels[0];
- if (s) {
- var l = t(r, s, e, i, n, o);
- return EL(l, r, [0, 100], "all"), this._range = r, a[0] !== r[0] || a[1] !== r[1] ? r : void 0
- }
- }
- }
- function Hy(t, e) {
- return t && t.hasOwnProperty && t.hasOwnProperty(e)
- }
- function Zy(t, e, i, n) {
- for (var o = e.targetVisuals[n], a = jC.prepareVisualTypes(o), r = {
- color: t.getData().getVisual("color")
- }, s = 0, l = a.length; s < l; s++) {
- var u = a[s],
- h = o["opacity" === u ? "__alphaForOpacity" : u];
- h && h.applyVisual(i, function(t) {
- return r[t]
- }, function(t, e) {
- r[t] = e
- })
- }
- return r.color
- }
- function Uy(t, e, i) {
- if (i[0] === i[1]) return i.slice();
- for (var n = (i[1] - i[0]) / 200, o = i[0], a = [], r = 0; r <= 200 && o < i[1]; r++) a.push(o), o += n;
- return a.push(i[1]), a
- }
- function Xy(t, e, i) {
- var n = t.option,
- o = n.align;
- if (null != o && "auto" !== o) return o;
- for (var a = {
- width: e.getWidth(),
- height: e.getHeight()
- }, r = "horizontal" === n.orient ? 1 : 0, s = [
- ["left", "right", "width"],
- ["top", "bottom", "height"]
- ], l = s[r], u = [0, null, 10], h = {}, c = 0; c < 3; c++) h[s[1 - r][c]] = u[c], h[l[c]] = 2 === c ? i[0] : n[l[c]];
- var d = [
- ["x", "width", 3],
- ["y", "height", 0]
- ][r],
- f = la(h, a, n.padding);
- return l[(f.margin[d[2]] || 0) + f[d[0]] + .5 * f[d[1]] < .5 * a[d[1]] ? 0 : 1]
- }
- function jy(t) {
- return d(t || [], function(e) {
- null != t.dataIndex && (t.dataIndexInside = t.dataIndex, t.dataIndex = null)
- }), t
- }
- function Yy(t, e, i, n) {
- return new nM({
- shape: {
- points: t
- },
- draggable: !!i,
- cursor: e,
- drift: i,
- onmousemove: function(t) {
- lw(t.event)
- },
- ondragend: n
- })
- }
- function qy(t, e) {
- return 0 === t ? [
- [0, 0],
- [e, 0],
- [e, -e]
- ] : [
- [0, 0],
- [e, 0],
- [e, e]
- ]
- }
- function Ky(t, e, i, n) {
- return t ? [
- [0, -yO(e, xO(i, 0))],
- [wO, 0],
- [0, yO(e, xO(n - i, 0))]
- ] : [
- [0, 0],
- [5, -5],
- [5, 5]
- ]
- }
- function $y(t, e, i) {
- var n = _O / 2,
- o = t.get("hoverLinkDataSize");
- return o && (n = mO(o, e, i, !0) / 2), n
- }
- function Jy(t) {
- var e = t.get("hoverLinkOnHandle");
- return !!(null == e ? t.get("realtime") : e)
- }
- function Qy(t) {
- return "vertical" === t ? "ns-resize" : "ew-resize"
- }
- function tx(t, e) {
- var i = t.inverse;
- ("vertical" === t.orient ? !i : i) && e.reverse()
- }
- function ex(t) {
- Ci(t, "label", ["show"])
- }
- function ix(t) {
- return !(isNaN(parseFloat(t.x)) && isNaN(parseFloat(t.y)))
- }
- function nx(t) {
- return !isNaN(parseFloat(t.x)) && !isNaN(parseFloat(t.y))
- }
- function ox(t, e, i, n, o, a) {
- var r = [],
- s = hl(e, n) ? e.getCalculationInfo("stackResultDimension") : n,
- l = hx(e, s, t),
- u = e.indicesOfNearest(s, l)[0];
- r[o] = e.get(i, u), r[a] = e.get(n, u);
- var h = Vo(e.get(n, u));
- return (h = Math.min(h, 20)) >= 0 && (r[a] = +r[a].toFixed(h)), r
- }
- function ax(t, e) {
- var n = t.getData(),
- o = t.coordinateSystem;
- if (e && !nx(e) && !y(e.coord) && o) {
- var a = o.dimensions,
- r = rx(e, n, o, t);
- if ((e = i(e)).type && LO[e.type] && r.baseAxis && r.valueAxis) {
- var s = DO(a, r.baseAxis.dim),
- l = DO(a, r.valueAxis.dim);
- e.coord = LO[e.type](n, r.baseDataDim, r.valueDataDim, s, l), e.value = e.coord[l]
- } else {
- for (var u = [null != e.xAxis ? e.xAxis : e.radiusAxis, null != e.yAxis ? e.yAxis : e.angleAxis], h = 0; h < 2; h++)
- LO[u[h]] && (u[h] = hx(n, n.mapDimension(a[h]), u[h]));
- e.coord = u
- }
- }
- return e
- }
- function rx(t, e, i, n) {
- var o = {};
- return null != t.valueIndex || null != t.valueDim ? (o.valueDataDim = null != t.valueIndex ? e.getDimension(t.valueIndex) :
- t.valueDim, o.valueAxis = i.getAxis(sx(n, o.valueDataDim)), o.baseAxis = i.getOtherAxis(o.valueAxis), o.baseDataDim =
- e.mapDimension(o.baseAxis.dim)) : (o.baseAxis = n.getBaseAxis(), o.valueAxis = i.getOtherAxis(o.baseAxis), o.baseDataDim =
- e.mapDimension(o.baseAxis.dim), o.valueDataDim = e.mapDimension(o.valueAxis.dim)), o
- }
- function sx(t, e) {
- var i = t.getData(),
- n = i.dimensions;
- e = i.getDimension(e);
- for (var o = 0; o < n.length; o++) {
- var a = i.getDimensionInfo(n[o]);
- if (a.name === e) return a.coordDim
- }
- }
- function lx(t, e) {
- return !(t && t.containData && e.coord && !ix(e)) || t.containData(e.coord)
- }
- function ux(t, e, i, n) {
- return n < 2 ? t.coord && t.coord[n] : t.value
- }
- function hx(t, e, i) {
- if ("average" === i) {
- var n = 0,
- o = 0;
- return t.each(e, function(t, e) {
- isNaN(t) || (n += t, o++)
- }), n / o
- }
- return "median" === i ? t.getMedian(e) : t.getDataExtent(e, !0)["max" === i ? 1 : 0]
- }
- function cx(t, e, i) {
- var n = e.coordinateSystem;
- t.each(function(o) {
- var a, r = t.getItemModel(o),
- s = Ro(r.get("x"), i.getWidth()),
- l = Ro(r.get("y"), i.getHeight());
- if (isNaN(s) || isNaN(l)) {
- if (e.getMarkerPosition) a = e.getMarkerPosition(t.getValues(t.dimensions, o));
- else if (n) {
- var u = t.get(n.dimensions[0], o),
- h = t.get(n.dimensions[1], o);
- a = n.dataToPoint([u, h])
- }
- } else a = [s, l];
- isNaN(s) || (a[0] = s), isNaN(l) || (a[1] = l), t.setItemLayout(o, a)
- })
- }
- function dx(t, e, i) {
- var n;
- n = t ? f(t && t.dimensions, function(t) {
- return r({
- name: t
- }, e.getData().getDimensionInfo(e.getData().mapDimension(t)) || {})
- }) : [{
- name: "value",
- type: "float"
- }];
- var o = new eA(n, i),
- a = f(i.get("data"), v(ax, e));
- return t && (a = g(a, v(lx, t))), o.initData(a, null, t ? ux : function(t) {
- return t.value
- }), o
- }
- function fx(t) {
- return !isNaN(t) && !isFinite(t)
- }
- function px(t, e, i, n) {
- var o = 1 - t,
- a = n.dimensions[t];
- return fx(e[o]) && fx(i[o]) && e[t] === i[t] && n.getAxis(a).containData(e[t])
- }
- function gx(t, e) {
- if ("cartesian2d" === t.type) {
- var i = e[0].coord,
- n = e[1].coord;
- if (i && n && (px(1, i, n, t) || px(0, i, n, t))) return !0
- }
- return lx(t, e[0]) && lx(t, e[1])
- }
- function mx(t, e, i, n, o) {
- var a, r = n.coordinateSystem,
- s = t.getItemModel(e),
- l = Ro(s.get("x"), o.getWidth()),
- u = Ro(s.get("y"), o.getHeight());
- if (isNaN(l) || isNaN(u)) {
- if (n.getMarkerPosition) a = n.getMarkerPosition(t.getValues(t.dimensions, e));
- else {
- var h = r.dimensions,
- c = t.get(h[0], e),
- d = t.get(h[1], e);
- a = r.dataToPoint([c, d])
- }
- if ("cartesian2d" === r.type) {
- var f = r.getAxis("x"),
- p = r.getAxis("y"),
- h = r.dimensions;
- fx(t.get(h[0], e)) ? a[0] = f.toGlobalCoord(f.getExtent()[i ? 0 : 1]) : fx(t.get(h[1], e)) && (a[1] = p.toGlobalCoord(
- p.getExtent()[i ? 0 : 1]))
- }
- isNaN(l) || (a[0] = l), isNaN(u) || (a[1] = u)
- } else a = [l, u];
- t.setItemLayout(e, a)
- }
- function vx(t, e, i) {
- var n;
- n = t ? f(t && t.dimensions, function(t) {
- return r({
- name: t
- }, e.getData().getDimensionInfo(e.getData().mapDimension(t)) || {})
- }) : [{
- name: "value",
- type: "float"
- }];
- var o = new eA(n, i),
- a = new eA(n, i),
- s = new eA([], i),
- l = f(i.get("data"), v(PO, e, t, i));
- t && (l = g(l, v(gx, t)));
- var u = t ? ux : function(t) {
- return t.value
- };
- return o.initData(f(l, function(t) {
- return t[0]
- }), null, u), a.initData(f(l, function(t) {
- return t[1]
- }), null, u), s.initData(f(l, function(t) {
- return t[2]
- })), s.hasItemOption = !0, {
- from: o,
- to: a,
- line: s
- }
- }
- function yx(t) {
- return !isNaN(t) && !isFinite(t)
- }
- function xx(t, e, i, n) {
- var o = 1 - t;
- return yx(e[o]) && yx(i[o])
- }
- function _x(t, e) {
- var i = e.coord[0],
- n = e.coord[1];
- return !("cartesian2d" !== t.type || !i || !n || !xx(1, i, n, t) && !xx(0, i, n, t)) || (lx(t, {
- coord: i,
- x: e.x0,
- y: e.y0
- }) || lx(t, {
- coord: n,
- x: e.x1,
- y: e.y1
- }))
- }
- function bx(t, e, i, n, o) {
- var a, r = n.coordinateSystem,
- s = t.getItemModel(e),
- l = Ro(s.get(i[0]), o.getWidth()),
- u = Ro(s.get(i[1]), o.getHeight());
- if (isNaN(l) || isNaN(u)) {
- if (n.getMarkerPosition) a = n.getMarkerPosition(t.getValues(i, e));
- else {
- var h = [f = t.get(i[0], e), p = t.get(i[1], e)];
- r.clampData && r.clampData(h, h), a = r.dataToPoint(h, !0)
- }
- if ("cartesian2d" === r.type) {
- var c = r.getAxis("x"),
- d = r.getAxis("y"),
- f = t.get(i[0], e),
- p = t.get(i[1], e);
- yx(f) ? a[0] = c.toGlobalCoord(c.getExtent()["x0" === i[0] ? 0 : 1]) : yx(p) && (a[1] = d.toGlobalCoord(d.getExtent()[
- "y0" === i[1] ? 0 : 1]))
- }
- isNaN(l) || (a[0] = l), isNaN(u) || (a[1] = u)
- } else a = [l, u];
- return a
- }
- function Sx(t, e, i) {
- var n, o, a = ["x0", "y0", "x1", "y1"];
- t ? (n = f(t && t.dimensions, function(t) {
- var i = e.getData();
- return r({
- name: t
- }, i.getDimensionInfo(i.mapDimension(t)) || {})
- }), o = new eA(f(a, function(t, e) {
- return {
- name: t,
- type: n[e % 2].type
- }
- }), i)) : o = new eA(n = [{
- name: "value",
- type: "float"
- }], i);
- var s = f(i.get("data"), v(NO, e, t, i));
- t && (s = g(s, v(_x, t)));
- var l = t ? function(t, e, i, n) {
- return t.coord[Math.floor(n / 2)][n % 2]
- } : function(t) {
- return t.value
- };
- return o.initData(s, null, l), o.hasItemOption = !0, o
- }
- function Mx(t) {
- var e = t.type,
- i = {
- number: "value",
- time: "time"
- };
- if (i[e] && (t.axisType = i[e], delete t.type), Ix(t), Tx(t, "controlPosition")) {
- var n = t.controlStyle || (t.controlStyle = {});
- Tx(n, "position") || (n.position = t.controlPosition), "none" !== n.position || Tx(n, "show") || (n.show = !1,
- delete n.position), delete t.controlPosition
- }
- d(t.data || [], function(t) {
- w(t) && !y(t) && (!Tx(t, "value") && Tx(t, "name") && (t.value = t.name), Ix(t))
- })
- }
- function Ix(t) {
- var e = t.itemStyle || (t.itemStyle = {}),
- i = e.emphasis || (e.emphasis = {}),
- n = t.label || t.label || {},
- o = n.normal || (n.normal = {}),
- a = {
- normal: 1,
- emphasis: 1
- };
- d(n, function(t, e) {
- a[e] || Tx(o, e) || (o[e] = t)
- }), i.label && !Tx(n, "emphasis") && (n.emphasis = i.label, delete i.label)
- }
- function Tx(t, e) {
- return t.hasOwnProperty(e)
- }
- function Ax(t, e) {
- return la(t.getBoxLayoutParams(), {
- width: e.getWidth(),
- height: e.getHeight()
- }, t.get("padding"))
- }
- function Dx(t, e, n, o) {
- return Wn(t.get(e).replace(/^path:\/\//, ""), i(o || {}), new ue(n[0], n[1], n[2], n[3]), "center")
- }
- function Cx(t, e, i, o, a, r) {
- var s = e.get("color");
- a ? (a.setColor(s), i.add(a), r && r.onUpdate(a)) : ((a = Xl(t.get("symbol"), -1, -1, 2, 2, s)).setStyle(
- "strokeNoScale", !0), i.add(a), r && r.onCreate(a));
- var l = e.getItemStyle(["color", "symbol", "symbolSize"]);
- a.setStyle(l), o = n({
- rectHover: !0,
- z2: 100
- }, o, !0);
- var u = t.get("symbolSize");
- (u = u instanceof Array ? u.slice() : [+u, +u])[0] /= 2, u[1] /= 2, o.scale = u;
- var h = t.get("symbolOffset");
- if (h) {
- var c = o.position = o.position || [0, 0];
- c[0] += Ro(h[0], u[0]), c[1] += Ro(h[1], u[1])
- }
- var d = t.get("symbolRotate");
- return o.rotation = (d || 0) * Math.PI / 180 || 0, a.attr(o), a.updateTransform(), a
- }
- function Lx(t, e, i, n, o) {
- if (!t.dragging) {
- var a = n.getModel("checkpointStyle"),
- r = i.dataToCoord(n.getData().get(["value"], e));
- o || !a.get("animation", !0) ? t.attr({
- position: [r, 0]
- }) : (t.stopAnimation(!0), t.animateTo({
- position: [r, 0]
- }, a.get("animationDuration", !0), a.get("animationEasing", !0)))
- }
- }
- function kx(t) {
- return 0 === t.indexOf("my")
- }
- function Px(t) {
- this.model = t
- }
- function Nx(t) {
- this.model = t
- }
- function Ox(t) {
- var e = {},
- i = [],
- n = [];
- return t.eachRawSeries(function(t) {
- var o = t.coordinateSystem;
- if (!o || "cartesian2d" !== o.type && "polar" !== o.type) i.push(t);
- else {
- var a = o.getBaseAxis();
- if ("category" === a.type) {
- var r = a.dim + "_" + a.index;
- e[r] || (e[r] = {
- categoryAxis: a,
- valueAxis: o.getOtherAxis(a),
- series: []
- }, n.push({
- axisDim: a.dim,
- axisIndex: a.index
- })), e[r].series.push(t)
- } else i.push(t)
- }
- }), {
- seriesGroupByCategoryAxis: e,
- other: i,
- meta: n
- }
- }
- function Ex(t) {
- var e = [];
- return d(t, function(t, i) {
- var n = t.categoryAxis,
- o = t.valueAxis.dim,
- a = [" "].concat(f(t.series, function(t) {
- return t.name
- })),
- r = [n.model.getCategories()];
- d(t.series, function(t) {
- r.push(t.getRawData().mapArray(o, function(t) {
- return t
- }))
- });
- for (var s = [a.join(qO)], l = 0; l < r[0].length; l++) {
- for (var u = [], h = 0; h < r.length; h++) u.push(r[h][l]);
- s.push(u.join(qO))
- }
- e.push(s.join("\n"))
- }), e.join("\n\n" + YO + "\n\n")
- }
- function Rx(t) {
- return f(t, function(t) {
- var e = t.getRawData(),
- i = [t.name],
- n = [];
- return e.each(e.dimensions, function() {
- for (var t = arguments.length, o = arguments[t - 1], a = e.getName(o), r = 0; r < t - 1; r++) n[r] = arguments[
- r];
- i.push((a ? a + qO : "") + n.join(qO))
- }), i.join("\n")
- }).join("\n\n" + YO + "\n\n")
- }
- function zx(t) {
- var e = Ox(t);
- return {
- value: g([Ex(e.seriesGroupByCategoryAxis), Rx(e.other)], function(t) {
- return t.replace(/[\n\t\s]/g, "")
- }).join("\n\n" + YO + "\n\n"),
- meta: e.meta
- }
- }
- function Bx(t) {
- return t.replace(/^\s\s*/, "").replace(/\s\s*$/, "")
- }
- function Vx(t) {
- if (t.slice(0, t.indexOf("\n")).indexOf(qO) >= 0) return !0
- }
- function Gx(t) {
- for (var e = t.split(/\n+/g), i = [], n = f(Bx(e.shift()).split(KO), function(t) {
- return {
- name: t,
- data: []
- }
- }), o = 0; o < e.length; o++) {
- var a = Bx(e[o]).split(KO);
- i.push(a.shift());
- for (var r = 0; r < a.length; r++) n[r] && (n[r].data[o] = a[r])
- }
- return {
- series: n,
- categories: i
- }
- }
- function Fx(t) {
- for (var e = t.split(/\n+/g), i = Bx(e.shift()), n = [], o = 0; o < e.length; o++) {
- var a, r = Bx(e[o]).split(KO),
- s = "",
- l = !1;
- isNaN(r[0]) ? (l = !0, s = r[0], r = r.slice(1), n[o] = {
- name: s,
- value: []
- }, a = n[o].value) : a = n[o] = [];
- for (var u = 0; u < r.length; u++) a.push(+r[u]);
- 1 === a.length && (l ? n[o].value = a[0] : n[o] = a[0])
- }
- return {
- name: i,
- data: n
- }
- }
- function Wx(t, e) {
- var i = {
- series: []
- };
- return d(t.split(new RegExp("\n*" + YO + "\n*", "g")), function(t, n) {
- if (Vx(t)) {
- var o = Gx(t),
- a = e[n],
- r = a.axisDim + "Axis";
- a && (i[r] = i[r] || [], i[r][a.axisIndex] = {
- data: o.categories
- }, i.series = i.series.concat(o.series))
- } else {
- o = Fx(t);
- i.series.push(o)
- }
- }), i
- }
- function Hx(t) {
- this._dom = null, this.model = t
- }
- function Zx(t, e) {
- return f(t, function(t, i) {
- var n = e && e[i];
- return w(n) && !y(n) ? (w(t) && !y(t) && (t = t.value), r({
- value: t
- }, n)) : t
- })
- }
- function Ux(t, e) {
- var i = qx(t);
- $O(e, function(e, n) {
- for (var o = i.length - 1; o >= 0 && !i[o][n]; o--);
- if (o < 0) {
- var a = t.queryComponents({
- mainType: "dataZoom",
- subType: "select",
- id: n
- })[0];
- if (a) {
- var r = a.getPercentRange();
- i[0][n] = {
- dataZoomId: n,
- start: r[0],
- end: r[1]
- }
- }
- }
- }), i.push(e)
- }
- function Xx(t) {
- var e = qx(t),
- i = e[e.length - 1];
- e.length > 1 && e.pop();
- var n = {};
- return $O(i, function(t, i) {
- for (var o = e.length - 1; o >= 0; o--)
- if (t = e[o][i]) {
- n[i] = t;
- break
- }
- }), n
- }
- function jx(t) {
- t[JO] = null
- }
- function Yx(t) {
- return qx(t).length
- }
- function qx(t) {
- var e = t[JO];
- return e || (e = t[JO] = [{}]), e
- }
- function Kx(t, e, i) {
- (this._brushController = new Cf(i.getZr())).on("brush", m(this._onBrush, this)).mount(), this._isZoomActive
- }
- function $x(t) {
- var e = {};
- return d(["xAxisIndex", "yAxisIndex"], function(i) {
- e[i] = t[i], null == e[i] && (e[i] = "all"), (!1 === e[i] || "none" === e[i]) && (e[i] = [])
- }), e
- }
- function Jx(t, e) {
- t.setIconStatus("back", Yx(e) > 1 ? "emphasis" : "normal")
- }
- function Qx(t, e, i, n, o) {
- var a = i._isZoomActive;
- n && "takeGlobalCursor" === n.type && (a = "dataZoomSelect" === n.key && n.dataZoomSelectActive), i._isZoomActive =
- a, t.setIconStatus("zoom", a ? "emphasis" : "normal");
- var r = new iy($x(t.option), e, {
- include: ["grid"]
- });
- i._brushController.setPanels(r.makePanelOpts(o, function(t) {
- return t.xAxisDeclared && !t.yAxisDeclared ? "lineX" : !t.xAxisDeclared && t.yAxisDeclared ? "lineY" : "rect"
- })).enableBrush(!!a && {
- brushType: "auto",
- brushStyle: {
- lineWidth: 0,
- fill: "rgba(0,0,0,0.2)"
- }
- })
- }
- function t_(t) {
- this.model = t
- }
- function e_(t) {
- return aE(t)
- }
- function i_() {
- if (!lE && uE) {
- lE = !0;
- var t = uE.styleSheets;
- t.length < 31 ? uE.createStyleSheet().addRule(".zrvml", "behavior:url(#default#VML)") : t[0].addRule(".zrvml",
- "behavior:url(#default#VML)")
- }
- }
- function n_(t) {
- return parseInt(t, 10)
- }
- function o_(t, e) {
- i_(), this.root = t, this.storage = e;
- var i = document.createElement("div"),
- n = document.createElement("div");
- i.style.cssText = "display:inline-block;overflow:hidden;position:relative;width:300px;height:150px;", n.style.cssText =
- "position:absolute;left:0;top:0;", t.appendChild(i), this._vmlRoot = n, this._vmlViewport = i, this.resize();
- var o = e.delFromStorage,
- a = e.addToStorage;
- e.delFromStorage = function(t) {
- o.call(e, t), t && t.onRemove && t.onRemove(n)
- }, e.addToStorage = function(t) {
- t.onAdd && t.onAdd(n), a.call(e, t)
- }, this._firstPaint = !0
- }
- function a_(t) {
- return function() {
- Bw('In IE8.0 VML mode painter not support method "' + t + '"')
- }
- }
- function r_(t) {
- return document.createElementNS(HE, t)
- }
- function s_(t) {
- return jE(1e4 * t) / 1e4
- }
- function l_(t) {
- return t < QE && t > -QE
- }
- function u_(t, e) {
- var i = e ? t.textFill : t.fill;
- return null != i && i !== XE
- }
- function h_(t, e) {
- var i = e ? t.textStroke : t.stroke;
- return null != i && i !== XE
- }
- function c_(t, e) {
- e && d_(t, "transform", "matrix(" + UE.call(e, ",") + ")")
- }
- function d_(t, e, i) {
- (!i || "linear" !== i.type && "radial" !== i.type) && ("string" == typeof i && i.indexOf("NaN") > -1 && console.log(
- i), t.setAttribute(e, i))
- }
- function f_(t, e, i) {
- t.setAttributeNS("http://www.w3.org/1999/xlink", e, i)
- }
- function p_(t, e, i, n) {
- if (u_(e, i)) {
- var o = i ? e.textFill : e.fill;
- o = "transparent" === o ? XE : o, "none" !== t.getAttribute("clip-path") && o === XE && (o = "rgba(0, 0, 0, 0.002)"),
- d_(t, "fill", o), d_(t, "fill-opacity", null != e.fillOpacity ? e.fillOpacity * e.opacity : e.opacity)
- } else d_(t, "fill", XE);
- if (h_(e, i)) {
- var a = i ? e.textStroke : e.stroke;
- d_(t, "stroke", a = "transparent" === a ? XE : a), d_(t, "stroke-width", (i ? e.textStrokeWidth : e.lineWidth) / (!
- i && e.strokeNoScale ? n.getLineScale() : 1)), d_(t, "paint-order", i ? "stroke" : "fill"), d_(t,
- "stroke-opacity", null != e.strokeOpacity ? e.strokeOpacity : e.opacity), e.lineDash ? (d_(t, "stroke-dasharray",
- e.lineDash.join(",")), d_(t, "stroke-dashoffset", jE(e.lineDashOffset || 0))) : d_(t, "stroke-dasharray", ""), e.lineCap &&
- d_(t, "stroke-linecap", e.lineCap), e.lineJoin && d_(t, "stroke-linejoin", e.lineJoin), e.miterLimit && d_(t,
- "stroke-miterlimit", e.miterLimit)
- } else d_(t, "stroke", XE)
- }
- function g_(t) {
- for (var e = [], i = t.data, n = t.len(), o = 0; o < n;) {
- var a = "",
- r = 0;
- switch (i[o++]) {
- case ZE.M:
- a = "M", r = 2;
- break;
- case ZE.L:
- a = "L", r = 2;
- break;
- case ZE.Q:
- a = "Q", r = 4;
- break;
- case ZE.C:
- a = "C", r = 6;
- break;
- case ZE.A:
- var s = i[o++],
- l = i[o++],
- u = i[o++],
- h = i[o++],
- c = i[o++],
- d = i[o++],
- f = i[o++],
- p = i[o++],
- g = Math.abs(d),
- m = l_(g - $E) && !l_(g),
- v = !1;
- v = g >= $E || !l_(g) && (d > -KE && d < 0 || d > KE) == !!p;
- var y = s_(s + u * qE(c)),
- x = s_(l + h * YE(c));
- m && (d = p ? $E - 1e-4 : 1e-4 - $E, v = !0, 9 === o && e.push("M", y, x));
- var _ = s_(s + u * qE(c + d)),
- w = s_(l + h * YE(c + d));
- e.push("A", s_(u), s_(h), jE(f * JE), +v, +p, _, w);
- break;
- case ZE.Z:
- a = "Z";
- break;
- case ZE.R:
- var _ = s_(i[o++]),
- w = s_(i[o++]),
- b = s_(i[o++]),
- S = s_(i[o++]);
- e.push("M", _, w, "L", _ + b, w, "L", _ + b, w + S, "L", _, w + S, "L", _, w)
- }
- a && e.push(a);
- for (var M = 0; M < r; M++) e.push(s_(i[o++]))
- }
- return e.join(" ")
- }
- function m_(t) {
- return "middle" === t ? "middle" : "bottom" === t ? "after-edge" : "hanging"
- }
- function v_() {}
- function y_(t, e, i, n) {
- for (var o = 0, a = e.length, r = 0, s = 0; o < a; o++) {
- var l = e[o];
- if (l.removed) {
- for (var u = [], h = s; h < s + l.count; h++) u.push(h);
- l.indices = u, s += l.count
- } else {
- for (var u = [], h = r; h < r + l.count; h++) u.push(h);
- l.indices = u, r += l.count, l.added || (s += l.count)
- }
- }
- return e
- }
- function x_(t) {
- return {
- newPos: t.newPos,
- components: t.components.slice(0)
- }
- }
- function __(t, e, i, n, o) {
- this._zrId = t, this._svgRoot = e, this._tagNames = "string" == typeof i ? [i] : i, this._markLabel = n, this._domName =
- o || "_dom", this.nextId = 0
- }
- function w_(t, e) {
- __.call(this, t, e, ["linearGradient", "radialGradient"], "__gradient_in_use__")
- }
- function b_(t, e) {
- __.call(this, t, e, "clipPath", "__clippath_in_use__")
- }
- function S_(t, e) {
- __.call(this, t, e, ["filter"], "__filter_in_use__", "_shadowDom")
- }
- function M_(t) {
- return t && (t.shadowBlur || t.shadowOffsetX || t.shadowOffsetY || t.textShadowBlur || t.textShadowOffsetX || t.textShadowOffsetY)
- }
- function I_(t) {
- return parseInt(t, 10)
- }
- function T_(t) {
- return t instanceof kn ? tR : t instanceof hi ? eR : t instanceof qS ? iR : tR
- }
- function A_(t, e) {
- return e && t && e.parentNode !== t
- }
- function D_(t, e, i) {
- if (A_(t, e) && i) {
- var n = i.nextSibling;
- n ? t.insertBefore(e, n) : t.appendChild(e)
- }
- }
- function C_(t, e) {
- if (A_(t, e)) {
- var i = t.firstChild;
- i ? t.insertBefore(e, i) : t.appendChild(e)
- }
- }
- function L_(t, e) {
- e && t && e.parentNode === t && t.removeChild(e)
- }
- function k_(t) {
- return t.__textSvgEl
- }
- function P_(t) {
- return t.__svgEl
- }
- function N_(t) {
- return function() {
- Bw('In SVG mode painter not support method "' + t + '"')
- }
- }
- var O_ = 2311,
- E_ = function() {
- return O_++
- },
- R_ = {},
- z_ = R_ = "object" == typeof wx && "function" == typeof wx.getSystemInfoSync ? {
- browser: {},
- os: {},
- node: !1,
- wxa: !0,
- canvasSupported: !0,
- svgSupported: !1,
- touchEventsSupported: !0,
- domSupported: !1
- } : "undefined" == typeof document && "undefined" != typeof self ? {
- browser: {},
- os: {},
- node: !1,
- worker: !0,
- canvasSupported: !0,
- domSupported: !1
- } : "undefined" == typeof navigator ? {
- browser: {},
- os: {},
- node: !0,
- worker: !1,
- canvasSupported: !0,
- svgSupported: !0,
- domSupported: !1
- } : function(t) {
- var e = {},
- i = {},
- n = t.match(/Firefox\/([\d.]+)/),
- o = t.match(/MSIE\s([\d.]+)/) || t.match(/Trident\/.+?rv:(([\d.]+))/),
- a = t.match(/Edge\/([\d.]+)/),
- r = /micromessenger/i.test(t);
- return n && (i.firefox = !0, i.version = n[1]), o && (i.ie = !0, i.version = o[1]), a && (i.edge = !0, i.version =
- a[1]), r && (i.weChat = !0), {
- browser: i,
- os: e,
- node: !1,
- canvasSupported: !!document.createElement("canvas").getContext,
- svgSupported: "undefined" != typeof SVGRect,
- touchEventsSupported: "ontouchstart" in window && !i.ie && !i.edge,
- pointerEventsSupported: "onpointerdown" in window && (i.edge || i.ie && i.version >= 11),
- domSupported: "undefined" != typeof document
- }
- }(navigator.userAgent),
- B_ = {
- "[object Function]": 1,
- "[object RegExp]": 1,
- "[object Date]": 1,
- "[object Error]": 1,
- "[object CanvasGradient]": 1,
- "[object CanvasPattern]": 1,
- "[object Image]": 1,
- "[object Canvas]": 1
- },
- V_ = {
- "[object Int8Array]": 1,
- "[object Uint8Array]": 1,
- "[object Uint8ClampedArray]": 1,
- "[object Int16Array]": 1,
- "[object Uint16Array]": 1,
- "[object Int32Array]": 1,
- "[object Uint32Array]": 1,
- "[object Float32Array]": 1,
- "[object Float64Array]": 1
- },
- G_ = Object.prototype.toString,
- F_ = Array.prototype,
- W_ = F_.forEach,
- H_ = F_.filter,
- Z_ = F_.slice,
- U_ = F_.map,
- X_ = F_.reduce,
- j_ = {},
- Y_ = function() {
- return j_.createCanvas()
- };
- j_.createCanvas = function() {
- return document.createElement("canvas")
- };
- var q_, K_ = "__ec_primitive__";
- E.prototype = {
- constructor: E,
- get: function(t) {
- return this.data.hasOwnProperty(t) ? this.data[t] : null
- },
- set: function(t, e) {
- return this.data[t] = e
- },
- each: function(t, e) {
- void 0 !== e && (t = m(t, e));
- for (var i in this.data) this.data.hasOwnProperty(i) && t(this.data[i], i)
- },
- removeKey: function(t) {
- delete this.data[t]
- }
- };
- var $_ = (Object.freeze || Object)({
- $override: e,
- clone: i,
- merge: n,
- mergeAll: o,
- extend: a,
- defaults: r,
- createCanvas: Y_,
- getContext: s,
- indexOf: l,
- inherits: u,
- mixin: h,
- isArrayLike: c,
- each: d,
- map: f,
- reduce: p,
- filter: g,
- find: function(t, e, i) {
- if (t && e)
- for (var n = 0, o = t.length; n < o; n++)
- if (e.call(i, t[n], n, t)) return t[n]
- },
- bind: m,
- curry: v,
- isArray: y,
- isFunction: x,
- isString: _,
- isObject: w,
- isBuiltInObject: b,
- isTypedArray: S,
- isDom: M,
- eqNaN: I,
- retrieve: T,
- retrieve2: A,
- retrieve3: D,
- slice: C,
- normalizeCssArray: L,
- assert: k,
- trim: P,
- setAsPrimitive: N,
- isPrimitive: O,
- createHashMap: R,
- concatArray: z,
- noop: B
- }),
- J_ = "undefined" == typeof Float32Array ? Array : Float32Array,
- Q_ = X,
- tw = j,
- ew = K,
- iw = $,
- nw = (Object.freeze || Object)({
- create: V,
- copy: G,
- clone: F,
- set: W,
- add: H,
- scaleAndAdd: Z,
- sub: U,
- len: X,
- length: Q_,
- lenSquare: j,
- lengthSquare: tw,
- mul: function(t, e, i) {
- return t[0] = e[0] * i[0], t[1] = e[1] * i[1], t
- },
- div: function(t, e, i) {
- return t[0] = e[0] / i[0], t[1] = e[1] / i[1], t
- },
- dot: function(t, e) {
- return t[0] * e[0] + t[1] * e[1]
- },
- scale: Y,
- normalize: q,
- distance: K,
- dist: ew,
- distanceSquare: $,
- distSquare: iw,
- negate: function(t, e) {
- return t[0] = -e[0], t[1] = -e[1], t
- },
- lerp: J,
- applyTransform: Q,
- min: tt,
- max: et
- });
- it.prototype = {
- constructor: it,
- _dragStart: function(t) {
- var e = t.target;
- e && e.draggable && (this._draggingTarget = e, e.dragging = !0, this._x = t.offsetX, this._y = t.offsetY, this.dispatchToElement(
- nt(e, t), "dragstart", t.event))
- },
- _drag: function(t) {
- var e = this._draggingTarget;
- if (e) {
- var i = t.offsetX,
- n = t.offsetY,
- o = i - this._x,
- a = n - this._y;
- this._x = i, this._y = n, e.drift(o, a, t), this.dispatchToElement(nt(e, t), "drag", t.event);
- var r = this.findHover(i, n, e).target,
- s = this._dropTarget;
- this._dropTarget = r, e !== r && (s && r !== s && this.dispatchToElement(nt(s, t), "dragleave", t.event), r && r !==
- s && this.dispatchToElement(nt(r, t), "dragenter", t.event))
- }
- },
- _dragEnd: function(t) {
- var e = this._draggingTarget;
- e && (e.dragging = !1), this.dispatchToElement(nt(e, t), "dragend", t.event), this._dropTarget && this.dispatchToElement(
- nt(this._dropTarget, t), "drop", t.event), this._draggingTarget = null, this._dropTarget = null
- }
- };
- var ow = Array.prototype.slice,
- aw = function(t) {
- this._$handlers = {}, this._$eventProcessor = t
- };
- aw.prototype = {
- constructor: aw,
- one: function(t, e, i, n) {
- var o = this._$handlers;
- if ("function" == typeof e && (n = i, i = e, e = null), !i || !t) return this;
- e = ot(this, e), o[t] || (o[t] = []);
- for (var a = 0; a < o[t].length; a++)
- if (o[t][a].h === i) return this;
- return o[t].push({
- h: i,
- one: !0,
- query: e,
- ctx: n || this
- }), this
- },
- on: function(t, e, i, n) {
- var o = this._$handlers;
- if ("function" == typeof e && (n = i, i = e, e = null), !i || !t) return this;
- e = ot(this, e), o[t] || (o[t] = []);
- for (var a = 0; a < o[t].length; a++)
- if (o[t][a].h === i) return this;
- return o[t].push({
- h: i,
- one: !1,
- query: e,
- ctx: n || this
- }), this
- },
- isSilent: function(t) {
- var e = this._$handlers;
- return e[t] && e[t].length
- },
- off: function(t, e) {
- var i = this._$handlers;
- if (!t) return this._$handlers = {}, this;
- if (e) {
- if (i[t]) {
- for (var n = [], o = 0, a = i[t].length; o < a; o++) i[t][o].h !== e && n.push(i[t][o]);
- i[t] = n
- }
- i[t] && 0 === i[t].length && delete i[t]
- } else delete i[t];
- return this
- },
- trigger: function(t) {
- var e = this._$handlers[t],
- i = this._$eventProcessor;
- if (e) {
- var n = arguments,
- o = n.length;
- o > 3 && (n = ow.call(n, 1));
- for (var a = e.length, r = 0; r < a;) {
- var s = e[r];
- if (i && i.filter && null != s.query && !i.filter(t, s.query)) r++;
- else {
- switch (o) {
- case 1:
- s.h.call(s.ctx);
- break;
- case 2:
- s.h.call(s.ctx, n[1]);
- break;
- case 3:
- s.h.call(s.ctx, n[1], n[2]);
- break;
- default:
- s.h.apply(s.ctx, n)
- }
- s.one ? (e.splice(r, 1), a--) : r++
- }
- }
- }
- return i && i.afterTrigger && i.afterTrigger(t), this
- },
- triggerWithContext: function(t) {
- var e = this._$handlers[t],
- i = this._$eventProcessor;
- if (e) {
- var n = arguments,
- o = n.length;
- o > 4 && (n = ow.call(n, 1, n.length - 1));
- for (var a = n[n.length - 1], r = e.length, s = 0; s < r;) {
- var l = e[s];
- if (i && i.filter && null != l.query && !i.filter(t, l.query)) s++;
- else {
- switch (o) {
- case 1:
- l.h.call(a);
- break;
- case 2:
- l.h.call(a, n[1]);
- break;
- case 3:
- l.h.call(a, n[1], n[2]);
- break;
- default:
- l.h.apply(a, n)
- }
- l.one ? (e.splice(s, 1), r--) : s++
- }
- }
- }
- return i && i.afterTrigger && i.afterTrigger(t), this
- }
- };
- var rw = "undefined" != typeof window && !!window.addEventListener,
- sw = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,
- lw = rw ? function(t) {
- t.preventDefault(), t.stopPropagation(), t.cancelBubble = !0
- } : function(t) {
- t.returnValue = !1, t.cancelBubble = !0
- },
- uw = "silent";
- pt.prototype.dispose = function() {};
- var hw = ["click", "dblclick", "mousewheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu"],
- cw = function(t, e, i, n) {
- aw.call(this), this.storage = t, this.painter = e, this.painterRoot = n, i = i || new pt, this.proxy = null, this._hovered = {},
- this._lastTouchMoment, this._lastX, this._lastY, it.call(this), this.setHandlerProxy(i)
- };
- cw.prototype = {
- constructor: cw,
- setHandlerProxy: function(t) {
- this.proxy && this.proxy.dispose(), t && (d(hw, function(e) {
- t.on && t.on(e, this[e], this)
- }, this), t.handler = this), this.proxy = t
- },
- mousemove: function(t) {
- var e = t.zrX,
- i = t.zrY,
- n = this._hovered,
- o = n.target;
- o && !o.__zr && (o = (n = this.findHover(n.x, n.y)).target);
- var a = this._hovered = this.findHover(e, i),
- r = a.target,
- s = this.proxy;
- s.setCursor && s.setCursor(r ? r.cursor : "default"), o && r !== o && this.dispatchToElement(n, "mouseout", t),
- this.dispatchToElement(a, "mousemove", t), r && r !== o && this.dispatchToElement(a, "mouseover", t)
- },
- mouseout: function(t) {
- this.dispatchToElement(this._hovered, "mouseout", t);
- var e, i = t.toElement || t.relatedTarget;
- do {
- i = i && i.parentNode
- } while (i && 9 != i.nodeType && !(e = i === this.painterRoot));
- !e && this.trigger("globalout", {
- event: t
- })
- },
- resize: function(t) {
- this._hovered = {}
- },
- dispatch: function(t, e) {
- var i = this[t];
- i && i.call(this, e)
- },
- dispose: function() {
- this.proxy.dispose(), this.storage = this.proxy = this.painter = null
- },
- setCursorStyle: function(t) {
- var e = this.proxy;
- e.setCursor && e.setCursor(t)
- },
- dispatchToElement: function(t, e, i) {
- var n = (t = t || {}).target;
- if (!n || !n.silent) {
- for (var o = "on" + e, a = dt(e, t, i); n && (n[o] && (a.cancelBubble = n[o].call(n, a)), n.trigger(e, a), n = n
- .parent, !a.cancelBubble););
- a.cancelBubble || (this.trigger(e, a), this.painter && this.painter.eachOtherLayer(function(t) {
- "function" == typeof t[o] && t[o].call(t, a), t.trigger && t.trigger(e, a)
- }))
- }
- },
- findHover: function(t, e, i) {
- for (var n = this.storage.getDisplayList(), o = {
- x: t,
- y: e
- }, a = n.length - 1; a >= 0; a--) {
- var r;
- if (n[a] !== i && !n[a].ignore && (r = gt(n[a], t, e)) && (!o.topTarget && (o.topTarget = n[a]), r !== uw)) {
- o.target = n[a];
- break
- }
- }
- return o
- }
- }, d(["click", "mousedown", "mouseup", "mousewheel", "dblclick", "contextmenu"], function(t) {
- cw.prototype[t] = function(e) {
- var i = this.findHover(e.zrX, e.zrY),
- n = i.target;
- if ("mousedown" === t) this._downEl = n, this._downPoint = [e.zrX, e.zrY], this._upEl = n;
- else if ("mouseup" === t) this._upEl = n;
- else if ("click" === t) {
- if (this._downEl !== this._upEl || !this._downPoint || ew(this._downPoint, [e.zrX, e.zrY]) > 4) return;
- this._downPoint = null
- }
- this.dispatchToElement(i, t, e)
- }
- }), h(cw, aw), h(cw, it);
- var dw = "undefined" == typeof Float32Array ? Array : Float32Array,
- fw = (Object.freeze || Object)({
- create: mt,
- identity: vt,
- copy: yt,
- mul: xt,
- translate: _t,
- rotate: wt,
- scale: bt,
- invert: St,
- clone: Mt
- }),
- pw = vt,
- gw = 5e-5,
- mw = function(t) {
- (t = t || {}).position || (this.position = [0, 0]), null == t.rotation && (this.rotation = 0), t.scale || (this.scale = [
- 1, 1
- ]), this.origin = this.origin || null
- },
- vw = mw.prototype;
- vw.transform = null, vw.needLocalTransform = function() {
- return It(this.rotation) || It(this.position[0]) || It(this.position[1]) || It(this.scale[0] - 1) || It(this.scale[
- 1] - 1)
- };
- var yw = [];
- vw.updateTransform = function() {
- var t = this.parent,
- e = t && t.transform,
- i = this.needLocalTransform(),
- n = this.transform;
- if (i || e) {
- n = n || mt(), i ? this.getLocalTransform(n) : pw(n), e && (i ? xt(n, t.transform, n) : yt(n, t.transform)), this.transform =
- n;
- var o = this.globalScaleRatio;
- if (null != o && 1 !== o) {
- this.getGlobalScale(yw);
- var a = yw[0] < 0 ? -1 : 1,
- r = yw[1] < 0 ? -1 : 1,
- s = ((yw[0] - a) * o + a) / yw[0] || 0,
- l = ((yw[1] - r) * o + r) / yw[1] || 0;
- n[0] *= s, n[1] *= s, n[2] *= l, n[3] *= l
- }
- this.invTransform = this.invTransform || mt(), St(this.invTransform, n)
- } else n && pw(n)
- }, vw.getLocalTransform = function(t) {
- return mw.getLocalTransform(this, t)
- }, vw.setTransform = function(t) {
- var e = this.transform,
- i = t.dpr || 1;
- e ? t.setTransform(i * e[0], i * e[1], i * e[2], i * e[3], i * e[4], i * e[5]) : t.setTransform(i, 0, 0, i, 0, 0)
- }, vw.restoreTransform = function(t) {
- var e = t.dpr || 1;
- t.setTransform(e, 0, 0, e, 0, 0)
- };
- var xw = [],
- _w = mt();
- vw.setLocalTransform = function(t) {
- if (t) {
- var e = t[0] * t[0] + t[1] * t[1],
- i = t[2] * t[2] + t[3] * t[3],
- n = this.position,
- o = this.scale;
- It(e - 1) && (e = Math.sqrt(e)), It(i - 1) && (i = Math.sqrt(i)), t[0] < 0 && (e = -e), t[3] < 0 && (i = -i), n[0] =
- t[4], n[1] = t[5], o[0] = e, o[1] = i, this.rotation = Math.atan2(-t[1] / i, t[0] / e)
- }
- }, vw.decomposeTransform = function() {
- if (this.transform) {
- var t = this.parent,
- e = this.transform;
- t && t.transform && (xt(xw, t.invTransform, e), e = xw);
- var i = this.origin;
- i && (i[0] || i[1]) && (_w[4] = i[0], _w[5] = i[1], xt(xw, e, _w), xw[4] -= i[0], xw[5] -= i[1], e = xw), this.setLocalTransform(
- e)
- }
- }, vw.getGlobalScale = function(t) {
- var e = this.transform;
- return t = t || [], e ? (t[0] = Math.sqrt(e[0] * e[0] + e[1] * e[1]), t[1] = Math.sqrt(e[2] * e[2] + e[3] * e[3]),
- e[0] < 0 && (t[0] = -t[0]), e[3] < 0 && (t[1] = -t[1]), t) : (t[0] = 1, t[1] = 1, t)
- }, vw.transformCoordToLocal = function(t, e) {
- var i = [t, e],
- n = this.invTransform;
- return n && Q(i, i, n), i
- }, vw.transformCoordToGlobal = function(t, e) {
- var i = [t, e],
- n = this.transform;
- return n && Q(i, i, n), i
- }, mw.getLocalTransform = function(t, e) {
- pw(e = e || []);
- var i = t.origin,
- n = t.scale || [1, 1],
- o = t.rotation || 0,
- a = t.position || [0, 0];
- return i && (e[4] -= i[0], e[5] -= i[1]), bt(e, e, n), o && wt(e, e, o), i && (e[4] += i[0], e[5] += i[1]), e[4] +=
- a[0], e[5] += a[1], e
- };
- var ww = {
- linear: function(t) {
- return t
- },
- quadraticIn: function(t) {
- return t * t
- },
- quadraticOut: function(t) {
- return t * (2 - t)
- },
- quadraticInOut: function(t) {
- return (t *= 2) < 1 ? .5 * t * t : -.5 * (--t * (t - 2) - 1)
- },
- cubicIn: function(t) {
- return t * t * t
- },
- cubicOut: function(t) {
- return --t * t * t + 1
- },
- cubicInOut: function(t) {
- return (t *= 2) < 1 ? .5 * t * t * t : .5 * ((t -= 2) * t * t + 2)
- },
- quarticIn: function(t) {
- return t * t * t * t
- },
- quarticOut: function(t) {
- return 1 - --t * t * t * t
- },
- quarticInOut: function(t) {
- return (t *= 2) < 1 ? .5 * t * t * t * t : -.5 * ((t -= 2) * t * t * t - 2)
- },
- quinticIn: function(t) {
- return t * t * t * t * t
- },
- quinticOut: function(t) {
- return --t * t * t * t * t + 1
- },
- quinticInOut: function(t) {
- return (t *= 2) < 1 ? .5 * t * t * t * t * t : .5 * ((t -= 2) * t * t * t * t + 2)
- },
- sinusoidalIn: function(t) {
- return 1 - Math.cos(t * Math.PI / 2)
- },
- sinusoidalOut: function(t) {
- return Math.sin(t * Math.PI / 2)
- },
- sinusoidalInOut: function(t) {
- return .5 * (1 - Math.cos(Math.PI * t))
- },
- exponentialIn: function(t) {
- return 0 === t ? 0 : Math.pow(1024, t - 1)
- },
- exponentialOut: function(t) {
- return 1 === t ? 1 : 1 - Math.pow(2, -10 * t)
- },
- exponentialInOut: function(t) {
- return 0 === t ? 0 : 1 === t ? 1 : (t *= 2) < 1 ? .5 * Math.pow(1024, t - 1) : .5 * (2 - Math.pow(2, -10 * (t - 1)))
- },
- circularIn: function(t) {
- return 1 - Math.sqrt(1 - t * t)
- },
- circularOut: function(t) {
- return Math.sqrt(1 - --t * t)
- },
- circularInOut: function(t) {
- return (t *= 2) < 1 ? -.5 * (Math.sqrt(1 - t * t) - 1) : .5 * (Math.sqrt(1 - (t -= 2) * t) + 1)
- },
- elasticIn: function(t) {
- var e, i = .1;
- return 0 === t ? 0 : 1 === t ? 1 : (!i || i < 1 ? (i = 1, e = .1) : e = .4 * Math.asin(1 / i) / (2 * Math.PI), -i *
- Math.pow(2, 10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / .4))
- },
- elasticOut: function(t) {
- var e, i = .1;
- return 0 === t ? 0 : 1 === t ? 1 : (!i || i < 1 ? (i = 1, e = .1) : e = .4 * Math.asin(1 / i) / (2 * Math.PI), i *
- Math.pow(2, -10 * t) * Math.sin((t - e) * (2 * Math.PI) / .4) + 1)
- },
- elasticInOut: function(t) {
- var e, i = .1;
- return 0 === t ? 0 : 1 === t ? 1 : (!i || i < 1 ? (i = 1, e = .1) : e = .4 * Math.asin(1 / i) / (2 * Math.PI), (t *=
- 2) < 1 ? i * Math.pow(2, 10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / .4) * -.5 : i * Math.pow(2, -10 *
- (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / .4) * .5 + 1)
- },
- backIn: function(t) {
- var e = 1.70158;
- return t * t * ((e + 1) * t - e)
- },
- backOut: function(t) {
- var e = 1.70158;
- return --t * t * ((e + 1) * t + e) + 1
- },
- backInOut: function(t) {
- var e = 2.5949095;
- return (t *= 2) < 1 ? t * t * ((e + 1) * t - e) * .5 : .5 * ((t -= 2) * t * ((e + 1) * t + e) + 2)
- },
- bounceIn: function(t) {
- return 1 - ww.bounceOut(1 - t)
- },
- bounceOut: function(t) {
- return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + .75 : t < 2.5 / 2.75 ?
- 7.5625 * (t -= 2.25 / 2.75) * t + .9375 : 7.5625 * (t -= 2.625 / 2.75) * t + .984375
- },
- bounceInOut: function(t) {
- return t < .5 ? .5 * ww.bounceIn(2 * t) : .5 * ww.bounceOut(2 * t - 1) + .5
- }
- };
- Tt.prototype = {
- constructor: Tt,
- step: function(t, e) {
- if (this._initialized || (this._startTime = t + this._delay, this._initialized = !0), this._paused) this._pausedTime +=
- e;
- else {
- var i = (t - this._startTime - this._pausedTime) / this._life;
- if (!(i < 0)) {
- i = Math.min(i, 1);
- var n = this.easing,
- o = "string" == typeof n ? ww[n] : n,
- a = "function" == typeof o ? o(i) : i;
- return this.fire("frame", a), 1 == i ? this.loop ? (this.restart(t), "restart") : (this._needsRemove = !0,
- "destroy") : null
- }
- }
- },
- restart: function(t) {
- var e = (t - this._startTime - this._pausedTime) % this._life;
- this._startTime = t - e + this.gap, this._pausedTime = 0, this._needsRemove = !1
- },
- fire: function(t, e) {
- this[t = "on" + t] && this[t](this._target, e)
- },
- pause: function() {
- this._paused = !0
- },
- resume: function() {
- this._paused = !1
- }
- };
- var bw = function() {
- this.head = null, this.tail = null, this._len = 0
- },
- Sw = bw.prototype;
- Sw.insert = function(t) {
- var e = new Mw(t);
- return this.insertEntry(e), e
- }, Sw.insertEntry = function(t) {
- this.head ? (this.tail.next = t, t.prev = this.tail, t.next = null, this.tail = t) : this.head = this.tail = t,
- this._len++
- }, Sw.remove = function(t) {
- var e = t.prev,
- i = t.next;
- e ? e.next = i : this.head = i, i ? i.prev = e : this.tail = e, t.next = t.prev = null, this._len--
- }, Sw.len = function() {
- return this._len
- }, Sw.clear = function() {
- this.head = this.tail = null, this._len = 0
- };
- var Mw = function(t) {
- this.value = t, this.next, this.prev
- },
- Iw = function(t) {
- this._list = new bw, this._map = {}, this._maxSize = t || 10, this._lastRemovedEntry = null
- },
- Tw = Iw.prototype;
- Tw.put = function(t, e) {
- var i = this._list,
- n = this._map,
- o = null;
- if (null == n[t]) {
- var a = i.len(),
- r = this._lastRemovedEntry;
- if (a >= this._maxSize && a > 0) {
- var s = i.head;
- i.remove(s), delete n[s.key], o = s.value, this._lastRemovedEntry = s
- }
- r ? r.value = e : r = new Mw(e), r.key = t, i.insertEntry(r), n[t] = r
- }
- return o
- }, Tw.get = function(t) {
- var e = this._map[t],
- i = this._list;
- if (null != e) return e !== i.tail && (i.remove(e), i.insertEntry(e)), e.value
- }, Tw.clear = function() {
- this._list.clear(), this._map = {}
- };
- var Aw = {
- transparent: [0, 0, 0, 0],
- aliceblue: [240, 248, 255, 1],
- antiquewhite: [250, 235, 215, 1],
- aqua: [0, 255, 255, 1],
- aquamarine: [127, 255, 212, 1],
- azure: [240, 255, 255, 1],
- beige: [245, 245, 220, 1],
- bisque: [255, 228, 196, 1],
- black: [0, 0, 0, 1],
- blanchedalmond: [255, 235, 205, 1],
- blue: [0, 0, 255, 1],
- blueviolet: [138, 43, 226, 1],
- brown: [165, 42, 42, 1],
- burlywood: [222, 184, 135, 1],
- cadetblue: [95, 158, 160, 1],
- chartreuse: [127, 255, 0, 1],
- chocolate: [210, 105, 30, 1],
- coral: [255, 127, 80, 1],
- cornflowerblue: [100, 149, 237, 1],
- cornsilk: [255, 248, 220, 1],
- crimson: [220, 20, 60, 1],
- cyan: [0, 255, 255, 1],
- darkblue: [0, 0, 139, 1],
- darkcyan: [0, 139, 139, 1],
- darkgoldenrod: [184, 134, 11, 1],
- darkgray: [169, 169, 169, 1],
- darkgreen: [0, 100, 0, 1],
- darkgrey: [169, 169, 169, 1],
- darkkhaki: [189, 183, 107, 1],
- darkmagenta: [139, 0, 139, 1],
- darkolivegreen: [85, 107, 47, 1],
- darkorange: [255, 140, 0, 1],
- darkorchid: [153, 50, 204, 1],
- darkred: [139, 0, 0, 1],
- darksalmon: [233, 150, 122, 1],
- darkseagreen: [143, 188, 143, 1],
- darkslateblue: [72, 61, 139, 1],
- darkslategray: [47, 79, 79, 1],
- darkslategrey: [47, 79, 79, 1],
- darkturquoise: [0, 206, 209, 1],
- darkviolet: [148, 0, 211, 1],
- deeppink: [255, 20, 147, 1],
- deepskyblue: [0, 191, 255, 1],
- dimgray: [105, 105, 105, 1],
- dimgrey: [105, 105, 105, 1],
- dodgerblue: [30, 144, 255, 1],
- firebrick: [178, 34, 34, 1],
- floralwhite: [255, 250, 240, 1],
- forestgreen: [34, 139, 34, 1],
- fuchsia: [255, 0, 255, 1],
- gainsboro: [220, 220, 220, 1],
- ghostwhite: [248, 248, 255, 1],
- gold: [255, 215, 0, 1],
- goldenrod: [218, 165, 32, 1],
- gray: [128, 128, 128, 1],
- green: [0, 128, 0, 1],
- greenyellow: [173, 255, 47, 1],
- grey: [128, 128, 128, 1],
- honeydew: [240, 255, 240, 1],
- hotpink: [255, 105, 180, 1],
- indianred: [205, 92, 92, 1],
- indigo: [75, 0, 130, 1],
- ivory: [255, 255, 240, 1],
- khaki: [240, 230, 140, 1],
- lavender: [230, 230, 250, 1],
- lavenderblush: [255, 240, 245, 1],
- lawngreen: [124, 252, 0, 1],
- lemonchiffon: [255, 250, 205, 1],
- lightblue: [173, 216, 230, 1],
- lightcoral: [240, 128, 128, 1],
- lightcyan: [224, 255, 255, 1],
- lightgoldenrodyellow: [250, 250, 210, 1],
- lightgray: [211, 211, 211, 1],
- lightgreen: [144, 238, 144, 1],
- lightgrey: [211, 211, 211, 1],
- lightpink: [255, 182, 193, 1],
- lightsalmon: [255, 160, 122, 1],
- lightseagreen: [32, 178, 170, 1],
- lightskyblue: [135, 206, 250, 1],
- lightslategray: [119, 136, 153, 1],
- lightslategrey: [119, 136, 153, 1],
- lightsteelblue: [176, 196, 222, 1],
- lightyellow: [255, 255, 224, 1],
- lime: [0, 255, 0, 1],
- limegreen: [50, 205, 50, 1],
- linen: [250, 240, 230, 1],
- magenta: [255, 0, 255, 1],
- maroon: [128, 0, 0, 1],
- mediumaquamarine: [102, 205, 170, 1],
- mediumblue: [0, 0, 205, 1],
- mediumorchid: [186, 85, 211, 1],
- mediumpurple: [147, 112, 219, 1],
- mediumseagreen: [60, 179, 113, 1],
- mediumslateblue: [123, 104, 238, 1],
- mediumspringgreen: [0, 250, 154, 1],
- mediumturquoise: [72, 209, 204, 1],
- mediumvioletred: [199, 21, 133, 1],
- midnightblue: [25, 25, 112, 1],
- mintcream: [245, 255, 250, 1],
- mistyrose: [255, 228, 225, 1],
- moccasin: [255, 228, 181, 1],
- navajowhite: [255, 222, 173, 1],
- navy: [0, 0, 128, 1],
- oldlace: [253, 245, 230, 1],
- olive: [128, 128, 0, 1],
- olivedrab: [107, 142, 35, 1],
- orange: [255, 165, 0, 1],
- orangered: [255, 69, 0, 1],
- orchid: [218, 112, 214, 1],
- palegoldenrod: [238, 232, 170, 1],
- palegreen: [152, 251, 152, 1],
- paleturquoise: [175, 238, 238, 1],
- palevioletred: [219, 112, 147, 1],
- papayawhip: [255, 239, 213, 1],
- peachpuff: [255, 218, 185, 1],
- peru: [205, 133, 63, 1],
- pink: [255, 192, 203, 1],
- plum: [221, 160, 221, 1],
- powderblue: [176, 224, 230, 1],
- purple: [128, 0, 128, 1],
- red: [255, 0, 0, 1],
- rosybrown: [188, 143, 143, 1],
- royalblue: [65, 105, 225, 1],
- saddlebrown: [139, 69, 19, 1],
- salmon: [250, 128, 114, 1],
- sandybrown: [244, 164, 96, 1],
- seagreen: [46, 139, 87, 1],
- seashell: [255, 245, 238, 1],
- sienna: [160, 82, 45, 1],
- silver: [192, 192, 192, 1],
- skyblue: [135, 206, 235, 1],
- slateblue: [106, 90, 205, 1],
- slategray: [112, 128, 144, 1],
- slategrey: [112, 128, 144, 1],
- snow: [255, 250, 250, 1],
- springgreen: [0, 255, 127, 1],
- steelblue: [70, 130, 180, 1],
- tan: [210, 180, 140, 1],
- teal: [0, 128, 128, 1],
- thistle: [216, 191, 216, 1],
- tomato: [255, 99, 71, 1],
- turquoise: [64, 224, 208, 1],
- violet: [238, 130, 238, 1],
- wheat: [245, 222, 179, 1],
- white: [255, 255, 255, 1],
- whitesmoke: [245, 245, 245, 1],
- yellow: [255, 255, 0, 1],
- yellowgreen: [154, 205, 50, 1]
- },
- Dw = new Iw(20),
- Cw = null,
- Lw = Wt,
- kw = Ht,
- Pw = (Object.freeze || Object)({
- parse: zt,
- lift: Gt,
- toHex: Ft,
- fastLerp: Wt,
- fastMapToColor: Lw,
- lerp: Ht,
- mapToColor: kw,
- modifyHSL: Zt,
- modifyAlpha: Ut,
- stringify: Xt
- }),
- Nw = Array.prototype.slice,
- Ow = function(t, e, i, n) {
- this._tracks = {}, this._target = t, this._loop = e || !1, this._getter = i || jt, this._setter = n || Yt, this._clipCount =
- 0, this._delay = 0, this._doneList = [], this._onframeList = [], this._clipList = []
- };
- Ow.prototype = {
- when: function(t, e) {
- var i = this._tracks;
- for (var n in e)
- if (e.hasOwnProperty(n)) {
- if (!i[n]) {
- i[n] = [];
- var o = this._getter(this._target, n);
- if (null == o) continue;
- 0 !== t && i[n].push({
- time: 0,
- value: ie(o)
- })
- }
- i[n].push({
- time: t,
- value: e[n]
- })
- } return this
- },
- during: function(t) {
- return this._onframeList.push(t), this
- },
- pause: function() {
- for (var t = 0; t < this._clipList.length; t++) this._clipList[t].pause();
- this._paused = !0
- },
- resume: function() {
- for (var t = 0; t < this._clipList.length; t++) this._clipList[t].resume();
- this._paused = !1
- },
- isPaused: function() {
- return !!this._paused
- },
- _doneCallback: function() {
- this._tracks = {}, this._clipList.length = 0;
- for (var t = this._doneList, e = t.length, i = 0; i < e; i++) t[i].call(this)
- },
- start: function(t, e) {
- var i, n = this,
- o = 0;
- for (var a in this._tracks)
- if (this._tracks.hasOwnProperty(a)) {
- var r = ae(this, t, function() {
- --o || n._doneCallback()
- }, this._tracks[a], a, e);
- r && (this._clipList.push(r), o++, this.animation && this.animation.addClip(r), i = r)
- } if (i) {
- var s = i.onframe;
- i.onframe = function(t, e) {
- s(t, e);
- for (var i = 0; i < n._onframeList.length; i++) n._onframeList[i](t, e)
- }
- }
- return o || this._doneCallback(), this
- },
- stop: function(t) {
- for (var e = this._clipList, i = this.animation, n = 0; n < e.length; n++) {
- var o = e[n];
- t && o.onframe(this._target, 1), i && i.removeClip(o)
- }
- e.length = 0
- },
- delay: function(t) {
- return this._delay = t, this
- },
- done: function(t) {
- return t && this._doneList.push(t), this
- },
- getClips: function() {
- return this._clipList
- }
- };
- var Ew = 1;
- "undefined" != typeof window && (Ew = Math.max(window.devicePixelRatio || 1, 1));
- var Rw = Ew,
- zw = function() {},
- Bw = zw,
- Vw = function() {
- this.animators = []
- };
- Vw.prototype = {
- constructor: Vw,
- animate: function(t, e) {
- var i, n = !1,
- o = this,
- a = this.__zr;
- if (t) {
- var r = t.split("."),
- s = o;
- n = "shape" === r[0];
- for (var u = 0, h = r.length; u < h; u++) s && (s = s[r[u]]);
- s && (i = s)
- } else i = o;
- if (i) {
- var c = o.animators,
- d = new Ow(i, e);
- return d.during(function(t) {
- o.dirty(n)
- }).done(function() {
- c.splice(l(c, d), 1)
- }), c.push(d), a && a.animation.addAnimator(d), d
- }
- Bw('Property "' + t + '" is not existed in element ' + o.id)
- },
- stopAnimation: function(t) {
- for (var e = this.animators, i = e.length, n = 0; n < i; n++) e[n].stop(t);
- return e.length = 0, this
- },
- animateTo: function(t, e, i, n, o, a) {
- re(this, t, e, i, n, o, a)
- },
- animateFrom: function(t, e, i, n, o, a) {
- re(this, t, e, i, n, o, a, !0)
- }
- };
- var Gw = function(t) {
- mw.call(this, t), aw.call(this, t), Vw.call(this, t), this.id = t.id || E_()
- };
- Gw.prototype = {
- type: "element",
- name: "",
- __zr: null,
- ignore: !1,
- clipPath: null,
- isGroup: !1,
- drift: function(t, e) {
- switch (this.draggable) {
- case "horizontal":
- e = 0;
- break;
- case "vertical":
- t = 0
- }
- var i = this.transform;
- i || (i = this.transform = [1, 0, 0, 1, 0, 0]), i[4] += t, i[5] += e, this.decomposeTransform(), this.dirty(!1)
- },
- beforeUpdate: function() {},
- afterUpdate: function() {},
- update: function() {
- this.updateTransform()
- },
- traverse: function(t, e) {},
- attrKV: function(t, e) {
- if ("position" === t || "scale" === t || "origin" === t) {
- if (e) {
- var i = this[t];
- i || (i = this[t] = []), i[0] = e[0], i[1] = e[1]
- }
- } else this[t] = e
- },
- hide: function() {
- this.ignore = !0, this.__zr && this.__zr.refresh()
- },
- show: function() {
- this.ignore = !1, this.__zr && this.__zr.refresh()
- },
- attr: function(t, e) {
- if ("string" == typeof t) this.attrKV(t, e);
- else if (w(t))
- for (var i in t) t.hasOwnProperty(i) && this.attrKV(i, t[i]);
- return this.dirty(!1), this
- },
- setClipPath: function(t) {
- var e = this.__zr;
- e && t.addSelfToZr(e), this.clipPath && this.clipPath !== t && this.removeClipPath(), this.clipPath = t, t.__zr =
- e, t.__clipTarget = this, this.dirty(!1)
- },
- removeClipPath: function() {
- var t = this.clipPath;
- t && (t.__zr && t.removeSelfFromZr(t.__zr), t.__zr = null, t.__clipTarget = null, this.clipPath = null, this.dirty(
- !1))
- },
- addSelfToZr: function(t) {
- this.__zr = t;
- var e = this.animators;
- if (e)
- for (var i = 0; i < e.length; i++) t.animation.addAnimator(e[i]);
- this.clipPath && this.clipPath.addSelfToZr(t)
- },
- removeSelfFromZr: function(t) {
- this.__zr = null;
- var e = this.animators;
- if (e)
- for (var i = 0; i < e.length; i++) t.animation.removeAnimator(e[i]);
- this.clipPath && this.clipPath.removeSelfFromZr(t)
- }
- }, h(Gw, Vw), h(Gw, mw), h(Gw, aw);
- var Fw = Q,
- Ww = Math.min,
- Hw = Math.max;
- ue.prototype = {
- constructor: ue,
- union: function(t) {
- var e = Ww(t.x, this.x),
- i = Ww(t.y, this.y);
- this.width = Hw(t.x + t.width, this.x + this.width) - e, this.height = Hw(t.y + t.height, this.y + this.height) -
- i, this.x = e, this.y = i
- },
- applyTransform: function() {
- var t = [],
- e = [],
- i = [],
- n = [];
- return function(o) {
- if (o) {
- t[0] = i[0] = this.x, t[1] = n[1] = this.y, e[0] = n[0] = this.x + this.width, e[1] = i[1] = this.y + this.height,
- Fw(t, t, o), Fw(e, e, o), Fw(i, i, o), Fw(n, n, o), this.x = Ww(t[0], e[0], i[0], n[0]), this.y = Ww(t[1], e[
- 1], i[1], n[1]);
- var a = Hw(t[0], e[0], i[0], n[0]),
- r = Hw(t[1], e[1], i[1], n[1]);
- this.width = a - this.x, this.height = r - this.y
- }
- }
- }(),
- calculateTransform: function(t) {
- var e = this,
- i = t.width / e.width,
- n = t.height / e.height,
- o = mt();
- return _t(o, o, [-e.x, -e.y]), bt(o, o, [i, n]), _t(o, o, [t.x, t.y]), o
- },
- intersect: function(t) {
- if (!t) return !1;
- t instanceof ue || (t = ue.create(t));
- var e = this,
- i = e.x,
- n = e.x + e.width,
- o = e.y,
- a = e.y + e.height,
- r = t.x,
- s = t.x + t.width,
- l = t.y,
- u = t.y + t.height;
- return !(n < r || s < i || a < l || u < o)
- },
- contain: function(t, e) {
- var i = this;
- return t >= i.x && t <= i.x + i.width && e >= i.y && e <= i.y + i.height
- },
- clone: function() {
- return new ue(this.x, this.y, this.width, this.height)
- },
- copy: function(t) {
- this.x = t.x, this.y = t.y, this.width = t.width, this.height = t.height
- },
- plain: function() {
- return {
- x: this.x,
- y: this.y,
- width: this.width,
- height: this.height
- }
- }
- }, ue.create = function(t) {
- return new ue(t.x, t.y, t.width, t.height)
- };
- var Zw = function(t) {
- t = t || {}, Gw.call(this, t);
- for (var e in t) t.hasOwnProperty(e) && (this[e] = t[e]);
- this._children = [], this.__storage = null, this.__dirty = !0
- };
- Zw.prototype = {
- constructor: Zw,
- isGroup: !0,
- type: "group",
- silent: !1,
- children: function() {
- return this._children.slice()
- },
- childAt: function(t) {
- return this._children[t]
- },
- childOfName: function(t) {
- for (var e = this._children, i = 0; i < e.length; i++)
- if (e[i].name === t) return e[i]
- },
- childCount: function() {
- return this._children.length
- },
- add: function(t) {
- return t && t !== this && t.parent !== this && (this._children.push(t), this._doAdd(t)), this
- },
- addBefore: function(t, e) {
- if (t && t !== this && t.parent !== this && e && e.parent === this) {
- var i = this._children,
- n = i.indexOf(e);
- n >= 0 && (i.splice(n, 0, t), this._doAdd(t))
- }
- return this
- },
- _doAdd: function(t) {
- t.parent && t.parent.remove(t), t.parent = this;
- var e = this.__storage,
- i = this.__zr;
- e && e !== t.__storage && (e.addToStorage(t), t instanceof Zw && t.addChildrenToStorage(e)), i && i.refresh()
- },
- remove: function(t) {
- var e = this.__zr,
- i = this.__storage,
- n = this._children,
- o = l(n, t);
- return o < 0 ? this : (n.splice(o, 1), t.parent = null, i && (i.delFromStorage(t), t instanceof Zw && t.delChildrenFromStorage(
- i)), e && e.refresh(), this)
- },
- removeAll: function() {
- var t, e, i = this._children,
- n = this.__storage;
- for (e = 0; e < i.length; e++) t = i[e], n && (n.delFromStorage(t), t instanceof Zw && t.delChildrenFromStorage(n)),
- t.parent = null;
- return i.length = 0, this
- },
- eachChild: function(t, e) {
- for (var i = this._children, n = 0; n < i.length; n++) {
- var o = i[n];
- t.call(e, o, n)
- }
- return this
- },
- traverse: function(t, e) {
- for (var i = 0; i < this._children.length; i++) {
- var n = this._children[i];
- t.call(e, n), "group" === n.type && n.traverse(t, e)
- }
- return this
- },
- addChildrenToStorage: function(t) {
- for (var e = 0; e < this._children.length; e++) {
- var i = this._children[e];
- t.addToStorage(i), i instanceof Zw && i.addChildrenToStorage(t)
- }
- },
- delChildrenFromStorage: function(t) {
- for (var e = 0; e < this._children.length; e++) {
- var i = this._children[e];
- t.delFromStorage(i), i instanceof Zw && i.delChildrenFromStorage(t)
- }
- },
- dirty: function() {
- return this.__dirty = !0, this.__zr && this.__zr.refresh(), this
- },
- getBoundingRect: function(t) {
- for (var e = null, i = new ue(0, 0, 0, 0), n = t || this._children, o = [], a = 0; a < n.length; a++) {
- var r = n[a];
- if (!r.ignore && !r.invisible) {
- var s = r.getBoundingRect(),
- l = r.getLocalTransform(o);
- l ? (i.copy(s), i.applyTransform(l), (e = e || i.clone()).union(i)) : (e = e || s.clone()).union(s)
- }
- }
- return e || i
- }
- }, u(Zw, Gw);
- var Uw = 32,
- Xw = 7,
- jw = function() {
- this._roots = [], this._displayList = [], this._displayListLen = 0
- };
- jw.prototype = {
- constructor: jw,
- traverse: function(t, e) {
- for (var i = 0; i < this._roots.length; i++) this._roots[i].traverse(t, e)
- },
- getDisplayList: function(t, e) {
- return e = e || !1, t && this.updateDisplayList(e), this._displayList
- },
- updateDisplayList: function(t) {
- this._displayListLen = 0;
- for (var e = this._roots, i = this._displayList, n = 0, o = e.length; n < o; n++) this._updateAndAddDisplayable(e[
- n], null, t);
- i.length = this._displayListLen, z_.canvasSupported && ve(i, ye)
- },
- _updateAndAddDisplayable: function(t, e, i) {
- if (!t.ignore || i) {
- t.beforeUpdate(), t.__dirty && t.update(), t.afterUpdate();
- var n = t.clipPath;
- if (n) {
- e = e ? e.slice() : [];
- for (var o = n, a = t; o;) o.parent = a, o.updateTransform(), e.push(o), a = o, o = o.clipPath
- }
- if (t.isGroup) {
- for (var r = t._children, s = 0; s < r.length; s++) {
- var l = r[s];
- t.__dirty && (l.__dirty = !0), this._updateAndAddDisplayable(l, e, i)
- }
- t.__dirty = !1
- } else t.__clipPaths = e, this._displayList[this._displayListLen++] = t
- }
- },
- addRoot: function(t) {
- t.__storage !== this && (t instanceof Zw && t.addChildrenToStorage(this), this.addToStorage(t), this._roots.push(
- t))
- },
- delRoot: function(t) {
- if (null == t) {
- for (i = 0; i < this._roots.length; i++) {
- var e = this._roots[i];
- e instanceof Zw && e.delChildrenFromStorage(this)
- }
- return this._roots = [], this._displayList = [], void(this._displayListLen = 0)
- }
- if (t instanceof Array)
- for (var i = 0, n = t.length; i < n; i++) this.delRoot(t[i]);
- else {
- var o = l(this._roots, t);
- o >= 0 && (this.delFromStorage(t), this._roots.splice(o, 1), t instanceof Zw && t.delChildrenFromStorage(this))
- }
- },
- addToStorage: function(t) {
- return t && (t.__storage = this, t.dirty(!1)), this
- },
- delFromStorage: function(t) {
- return t && (t.__storage = null), this
- },
- dispose: function() {
- this._renderList = this._roots = null
- },
- displayableSortFunc: ye
- };
- var Yw = {
- shadowBlur: 1,
- shadowOffsetX: 1,
- shadowOffsetY: 1,
- textShadowBlur: 1,
- textShadowOffsetX: 1,
- textShadowOffsetY: 1,
- textBoxShadowBlur: 1,
- textBoxShadowOffsetX: 1,
- textBoxShadowOffsetY: 1
- },
- qw = function(t, e, i) {
- return Yw.hasOwnProperty(e) ? i *= t.dpr : i
- },
- Kw = [
- ["shadowBlur", 0],
- ["shadowOffsetX", 0],
- ["shadowOffsetY", 0],
- ["shadowColor", "#000"],
- ["lineCap", "butt"],
- ["lineJoin", "miter"],
- ["miterLimit", 10]
- ],
- $w = function(t) {
- this.extendFrom(t, !1)
- };
- $w.prototype = {
- constructor: $w,
- fill: "#000",
- stroke: null,
- opacity: 1,
- fillOpacity: null,
- strokeOpacity: null,
- lineDash: null,
- lineDashOffset: 0,
- shadowBlur: 0,
- shadowOffsetX: 0,
- shadowOffsetY: 0,
- lineWidth: 1,
- strokeNoScale: !1,
- text: null,
- font: null,
- textFont: null,
- fontStyle: null,
- fontWeight: null,
- fontSize: null,
- fontFamily: null,
- textTag: null,
- textFill: "#000",
- textStroke: null,
- textWidth: null,
- textHeight: null,
- textStrokeWidth: 0,
- textLineHeight: null,
- textPosition: "inside",
- textRect: null,
- textOffset: null,
- textAlign: null,
- textVerticalAlign: null,
- textDistance: 5,
- textShadowColor: "transparent",
- textShadowBlur: 0,
- textShadowOffsetX: 0,
- textShadowOffsetY: 0,
- textBoxShadowColor: "transparent",
- textBoxShadowBlur: 0,
- textBoxShadowOffsetX: 0,
- textBoxShadowOffsetY: 0,
- transformText: !1,
- textRotation: 0,
- textOrigin: null,
- textBackgroundColor: null,
- textBorderColor: null,
- textBorderWidth: 0,
- textBorderRadius: 0,
- textPadding: null,
- rich: null,
- truncate: null,
- blend: null,
- bind: function(t, e, i) {
- for (var n = this, o = i && i.style, a = !o, r = 0; r < Kw.length; r++) {
- var s = Kw[r],
- l = s[0];
- (a || n[l] !== o[l]) && (t[l] = qw(t, l, n[l] || s[1]))
- }
- if ((a || n.fill !== o.fill) && (t.fillStyle = n.fill), (a || n.stroke !== o.stroke) && (t.strokeStyle = n.stroke),
- (a || n.opacity !== o.opacity) && (t.globalAlpha = null == n.opacity ? 1 : n.opacity), (a || n.blend !== o.blend) &&
- (t.globalCompositeOperation = n.blend || "source-over"), this.hasStroke()) {
- var u = n.lineWidth;
- t.lineWidth = u / (this.strokeNoScale && e && e.getLineScale ? e.getLineScale() : 1)
- }
- },
- hasFill: function() {
- var t = this.fill;
- return null != t && "none" !== t
- },
- hasStroke: function() {
- var t = this.stroke;
- return null != t && "none" !== t && this.lineWidth > 0
- },
- extendFrom: function(t, e) {
- if (t)
- for (var i in t) !t.hasOwnProperty(i) || !0 !== e && (!1 === e ? this.hasOwnProperty(i) : null == t[i]) || (this[
- i] = t[i])
- },
- set: function(t, e) {
- "string" == typeof t ? this[t] = e : this.extendFrom(t, !0)
- },
- clone: function() {
- var t = new this.constructor;
- return t.extendFrom(this, !0), t
- },
- getGradient: function(t, e, i) {
- for (var n = ("radial" === e.type ? _e : xe)(t, e, i), o = e.colorStops, a = 0; a < o.length; a++) n.addColorStop(
- o[a].offset, o[a].color);
- return n
- }
- };
- for (var Jw = $w.prototype, Qw = 0; Qw < Kw.length; Qw++) {
- var tb = Kw[Qw];
- tb[0] in Jw || (Jw[tb[0]] = tb[1])
- }
- $w.getGradient = Jw.getGradient;
- var eb = function(t, e) {
- this.image = t, this.repeat = e, this.type = "pattern"
- };
- eb.prototype.getCanvasPattern = function(t) {
- return t.createPattern(this.image, this.repeat || "repeat")
- };
- var ib = function(t, e, i) {
- var n;
- i = i || Rw, "string" == typeof t ? n = be(t, e, i) : w(t) && (t = (n = t).id), this.id = t, this.dom = n;
- var o = n.style;
- o && (n.onselectstart = we, o["-webkit-user-select"] = "none", o["user-select"] = "none", o["-webkit-touch-callout"] =
- "none", o["-webkit-tap-highlight-color"] = "rgba(0,0,0,0)", o.padding = 0, o.margin = 0, o["border-width"] = 0),
- this.domBack = null, this.ctxBack = null, this.painter = e, this.config = null, this.clearColor = 0, this.motionBlur = !
- 1, this.lastFrameAlpha = .7, this.dpr = i
- };
- ib.prototype = {
- constructor: ib,
- __dirty: !0,
- __used: !1,
- __drawIndex: 0,
- __startIndex: 0,
- __endIndex: 0,
- incremental: !1,
- getElementCount: function() {
- return this.__endIndex - this.__startIndex
- },
- initContext: function() {
- this.ctx = this.dom.getContext("2d"), this.ctx.dpr = this.dpr
- },
- createBackBuffer: function() {
- var t = this.dpr;
- this.domBack = be("back-" + this.id, this.painter, t), this.ctxBack = this.domBack.getContext("2d"), 1 != t &&
- this.ctxBack.scale(t, t)
- },
- resize: function(t, e) {
- var i = this.dpr,
- n = this.dom,
- o = n.style,
- a = this.domBack;
- o && (o.width = t + "px", o.height = e + "px"), n.width = t * i, n.height = e * i, a && (a.width = t * i, a.height =
- e * i, 1 != i && this.ctxBack.scale(i, i))
- },
- clear: function(t, e) {
- var i = this.dom,
- n = this.ctx,
- o = i.width,
- a = i.height,
- e = e || this.clearColor,
- r = this.motionBlur && !t,
- s = this.lastFrameAlpha,
- l = this.dpr;
- if (r && (this.domBack || this.createBackBuffer(), this.ctxBack.globalCompositeOperation = "copy", this.ctxBack.drawImage(
- i, 0, 0, o / l, a / l)), n.clearRect(0, 0, o, a), e && "transparent" !== e) {
- var u;
- e.colorStops ? (u = e.__canvasGradient || $w.getGradient(n, e, {
- x: 0,
- y: 0,
- width: o,
- height: a
- }), e.__canvasGradient = u) : e.image && (u = eb.prototype.getCanvasPattern.call(e, n)), n.save(), n.fillStyle =
- u || e, n.fillRect(0, 0, o, a), n.restore()
- }
- if (r) {
- var h = this.domBack;
- n.save(), n.globalAlpha = s, n.drawImage(h, 0, 0, o, a), n.restore()
- }
- }
- };
- var nb = "undefined" != typeof window && (window.requestAnimationFrame && window.requestAnimationFrame.bind(window) ||
- window.msRequestAnimationFrame && window.msRequestAnimationFrame.bind(window) || window.mozRequestAnimationFrame ||
- window.webkitRequestAnimationFrame) || function(t) {
- setTimeout(t, 16)
- },
- ob = new Iw(50),
- ab = {},
- rb = 0,
- sb = 5e3,
- lb = /\{([a-zA-Z0-9_]+)\|([^}]*)\}/g,
- ub = "12px sans-serif",
- hb = {};
- hb.measureText = function(t, e) {
- var i = s();
- return i.font = e || ub, i.measureText(t)
- };
- var cb = {
- left: 1,
- right: 1,
- center: 1
- },
- db = {
- top: 1,
- bottom: 1,
- middle: 1
- },
- fb = [
- ["textShadowBlur", "shadowBlur", 0],
- ["textShadowOffsetX", "shadowOffsetX", 0],
- ["textShadowOffsetY", "shadowOffsetY", 0],
- ["textShadowColor", "shadowColor", "transparent"]
- ],
- pb = new ue,
- gb = function() {};
- gb.prototype = {
- constructor: gb,
- drawRectText: function(t, e) {
- var i = this.style;
- e = i.textRect || e, this.__dirty && Ue(i);
- var n = i.text;
- if (null != n && (n += ""), li(n, i)) {
- t.save();
- var o = this.transform;
- i.transformText ? this.setTransform(t) : o && (pb.copy(e), pb.applyTransform(o), e = pb), je(this, t, n, i, e),
- t.restore()
- }
- }
- }, ui.prototype = {
- constructor: ui,
- type: "displayable",
- __dirty: !0,
- invisible: !1,
- z: 0,
- z2: 0,
- zlevel: 0,
- draggable: !1,
- dragging: !1,
- silent: !1,
- culling: !1,
- cursor: "pointer",
- rectHover: !1,
- progressive: !1,
- incremental: !1,
- globalScaleRatio: 1,
- beforeBrush: function(t) {},
- afterBrush: function(t) {},
- brush: function(t, e) {},
- getBoundingRect: function() {},
- contain: function(t, e) {
- return this.rectContain(t, e)
- },
- traverse: function(t, e) {
- t.call(e, this)
- },
- rectContain: function(t, e) {
- var i = this.transformCoordToLocal(t, e);
- return this.getBoundingRect().contain(i[0], i[1])
- },
- dirty: function() {
- this.__dirty = this.__dirtyText = !0, this._rect = null, this.__zr && this.__zr.refresh()
- },
- animateStyle: function(t) {
- return this.animate("style", t)
- },
- attrKV: function(t, e) {
- "style" !== t ? Gw.prototype.attrKV.call(this, t, e) : this.style.set(e)
- },
- setStyle: function(t, e) {
- return this.style.set(t, e), this.dirty(!1), this
- },
- useStyle: function(t) {
- return this.style = new $w(t, this), this.dirty(!1), this
- }
- }, u(ui, Gw), h(ui, gb), hi.prototype = {
- constructor: hi,
- type: "image",
- brush: function(t, e) {
- var i = this.style,
- n = i.image;
- i.bind(t, this, e);
- var o = this._image = Me(n, this._image, this, this.onload);
- if (o && Te(o)) {
- var a = i.x || 0,
- r = i.y || 0,
- s = i.width,
- l = i.height,
- u = o.width / o.height;
- if (null == s && null != l ? s = l * u : null == l && null != s ? l = s / u : null == s && null == l && (s = o.width,
- l = o.height), this.setTransform(t), i.sWidth && i.sHeight) {
- var h = i.sx || 0,
- c = i.sy || 0;
- t.drawImage(o, h, c, i.sWidth, i.sHeight, a, r, s, l)
- } else if (i.sx && i.sy) {
- var d = s - (h = i.sx),
- f = l - (c = i.sy);
- t.drawImage(o, h, c, d, f, a, r, s, l)
- } else t.drawImage(o, a, r, s, l);
- null != i.text && (this.restoreTransform(t), this.drawRectText(t, this.getBoundingRect()))
- }
- },
- getBoundingRect: function() {
- var t = this.style;
- return this._rect || (this._rect = new ue(t.x || 0, t.y || 0, t.width || 0, t.height || 0)), this._rect
- }
- }, u(hi, ui);
- var mb = new ue(0, 0, 0, 0),
- vb = new ue(0, 0, 0, 0),
- yb = function(t, e, i) {
- this.type = "canvas";
- var n = !t.nodeName || "CANVAS" === t.nodeName.toUpperCase();
- this._opts = i = a({}, i || {}), this.dpr = i.devicePixelRatio || Rw, this._singleCanvas = n, this.root = t;
- var o = t.style;
- o && (o["-webkit-tap-highlight-color"] = "transparent", o["-webkit-user-select"] = o["user-select"] = o[
- "-webkit-touch-callout"] = "none", t.innerHTML = ""), this.storage = e;
- var r = this._zlevelList = [],
- s = this._layers = {};
- if (this._layerConfig = {}, this._needsManuallyCompositing = !1, n) {
- var l = t.width,
- u = t.height;
- null != i.width && (l = i.width), null != i.height && (u = i.height), this.dpr = i.devicePixelRatio || 1, t.width =
- l * this.dpr, t.height = u * this.dpr, this._width = l, this._height = u;
- var h = new ib(t, this, this.dpr);
- h.__builtin__ = !0, h.initContext(), s[314159] = h, h.zlevel = 314159, r.push(314159), this._domRoot = t
- } else {
- this._width = this._getSize(0), this._height = this._getSize(1);
- var c = this._domRoot = mi(this._width, this._height);
- t.appendChild(c)
- }
- this._hoverlayer = null, this._hoverElements = []
- };
- yb.prototype = {
- constructor: yb,
- getType: function() {
- return "canvas"
- },
- isSingleCanvas: function() {
- return this._singleCanvas
- },
- getViewportRoot: function() {
- return this._domRoot
- },
- getViewportRootOffset: function() {
- var t = this.getViewportRoot();
- if (t) return {
- offsetLeft: t.offsetLeft || 0,
- offsetTop: t.offsetTop || 0
- }
- },
- refresh: function(t) {
- var e = this.storage.getDisplayList(!0),
- i = this._zlevelList;
- this._redrawId = Math.random(), this._paintList(e, t, this._redrawId);
- for (var n = 0; n < i.length; n++) {
- var o = i[n],
- a = this._layers[o];
- if (!a.__builtin__ && a.refresh) {
- var r = 0 === n ? this._backgroundColor : null;
- a.refresh(r)
- }
- }
- return this.refreshHover(), this
- },
- addHover: function(t, e) {
- if (!t.__hoverMir) {
- var i = new t.constructor({
- style: t.style,
- shape: t.shape,
- z: t.z,
- z2: t.z2,
- silent: t.silent
- });
- return i.__from = t, t.__hoverMir = i, e && i.setStyle(e), this._hoverElements.push(i), i
- }
- },
- removeHover: function(t) {
- var e = t.__hoverMir,
- i = this._hoverElements,
- n = l(i, e);
- n >= 0 && i.splice(n, 1), t.__hoverMir = null
- },
- clearHover: function(t) {
- for (var e = this._hoverElements, i = 0; i < e.length; i++) {
- var n = e[i].__from;
- n && (n.__hoverMir = null)
- }
- e.length = 0
- },
- refreshHover: function() {
- var t = this._hoverElements,
- e = t.length,
- i = this._hoverlayer;
- if (i && i.clear(), e) {
- ve(t, this.storage.displayableSortFunc), i || (i = this._hoverlayer = this.getLayer(1e5));
- var n = {};
- i.ctx.save();
- for (var o = 0; o < e;) {
- var a = t[o],
- r = a.__from;
- r && r.__zr ? (o++, r.invisible || (a.transform = r.transform, a.invTransform = r.invTransform, a.__clipPaths =
- r.__clipPaths, this._doPaintEl(a, i, !0, n))) : (t.splice(o, 1), r.__hoverMir = null, e--)
- }
- i.ctx.restore()
- }
- },
- getHoverLayer: function() {
- return this.getLayer(1e5)
- },
- _paintList: function(t, e, i) {
- if (this._redrawId === i) {
- e = e || !1, this._updateLayerStatus(t);
- var n = this._doPaintList(t, e);
- if (this._needsManuallyCompositing && this._compositeManually(), !n) {
- var o = this;
- nb(function() {
- o._paintList(t, e, i)
- })
- }
- }
- },
- _compositeManually: function() {
- var t = this.getLayer(314159).ctx,
- e = this._domRoot.width,
- i = this._domRoot.height;
- t.clearRect(0, 0, e, i), this.eachBuiltinLayer(function(n) {
- n.virtual && t.drawImage(n.dom, 0, 0, e, i)
- })
- },
- _doPaintList: function(t, e) {
- for (var i = [], n = 0; n < this._zlevelList.length; n++) {
- var o = this._zlevelList[n];
- (s = this._layers[o]).__builtin__ && s !== this._hoverlayer && (s.__dirty || e) && i.push(s)
- }
- for (var a = !0, r = 0; r < i.length; r++) {
- var s = i[r],
- l = s.ctx,
- u = {};
- l.save();
- var h = e ? s.__startIndex : s.__drawIndex,
- c = !e && s.incremental && Date.now,
- f = c && Date.now(),
- p = s.zlevel === this._zlevelList[0] ? this._backgroundColor : null;
- if (s.__startIndex === s.__endIndex) s.clear(!1, p);
- else if (h === s.__startIndex) {
- var g = t[h];
- g.incremental && g.notClear && !e || s.clear(!1, p)
- } - 1 === h && (console.error("For some unknown reason. drawIndex is -1"), h = s.__startIndex);
- for (var m = h; m < s.__endIndex; m++) {
- var v = t[m];
- if (this._doPaintEl(v, s, e, u), v.__dirty = v.__dirtyText = !1, c && Date.now() - f > 15) break
- }
- s.__drawIndex = m, s.__drawIndex < s.__endIndex && (a = !1), u.prevElClipPaths && l.restore(), l.restore()
- }
- return z_.wxa && d(this._layers, function(t) {
- t && t.ctx && t.ctx.draw && t.ctx.draw()
- }), a
- },
- _doPaintEl: function(t, e, i, n) {
- var o = e.ctx,
- a = t.transform;
- if ((e.__dirty || i) && !t.invisible && 0 !== t.style.opacity && (!a || a[0] || a[3]) && (!t.culling || !fi(t,
- this._width, this._height))) {
- var r = t.__clipPaths;
- n.prevElClipPaths && !pi(r, n.prevElClipPaths) || (n.prevElClipPaths && (e.ctx.restore(), n.prevElClipPaths =
- null, n.prevEl = null), r && (o.save(), gi(r, o), n.prevElClipPaths = r)), t.beforeBrush && t.beforeBrush(o),
- t.brush(o, n.prevEl || null), n.prevEl = t, t.afterBrush && t.afterBrush(o)
- }
- },
- getLayer: function(t, e) {
- this._singleCanvas && !this._needsManuallyCompositing && (t = 314159);
- var i = this._layers[t];
- return i || ((i = new ib("zr_" + t, this, this.dpr)).zlevel = t, i.__builtin__ = !0, this._layerConfig[t] && n(i,
- this._layerConfig[t], !0), e && (i.virtual = e), this.insertLayer(t, i), i.initContext()), i
- },
- insertLayer: function(t, e) {
- var i = this._layers,
- n = this._zlevelList,
- o = n.length,
- a = null,
- r = -1,
- s = this._domRoot;
- if (i[t]) Bw("ZLevel " + t + " has been used already");
- else if (di(e)) {
- if (o > 0 && t > n[0]) {
- for (r = 0; r < o - 1 && !(n[r] < t && n[r + 1] > t); r++);
- a = i[n[r]]
- }
- if (n.splice(r + 1, 0, t), i[t] = e, !e.virtual)
- if (a) {
- var l = a.dom;
- l.nextSibling ? s.insertBefore(e.dom, l.nextSibling) : s.appendChild(e.dom)
- } else s.firstChild ? s.insertBefore(e.dom, s.firstChild) : s.appendChild(e.dom)
- } else Bw("Layer of zlevel " + t + " is not valid")
- },
- eachLayer: function(t, e) {
- var i, n, o = this._zlevelList;
- for (n = 0; n < o.length; n++) i = o[n], t.call(e, this._layers[i], i)
- },
- eachBuiltinLayer: function(t, e) {
- var i, n, o, a = this._zlevelList;
- for (o = 0; o < a.length; o++) n = a[o], (i = this._layers[n]).__builtin__ && t.call(e, i, n)
- },
- eachOtherLayer: function(t, e) {
- var i, n, o, a = this._zlevelList;
- for (o = 0; o < a.length; o++) n = a[o], (i = this._layers[n]).__builtin__ || t.call(e, i, n)
- },
- getLayers: function() {
- return this._layers
- },
- _updateLayerStatus: function(t) {
- function e(t) {
- i && (i.__endIndex !== t && (i.__dirty = !0), i.__endIndex = t)
- }
- if (this.eachBuiltinLayer(function(t, e) {
- t.__dirty = t.__used = !1
- }), this._singleCanvas)
- for (o = 1; o < t.length; o++)
- if ((r = t[o]).zlevel !== t[o - 1].zlevel || r.incremental) {
- this._needsManuallyCompositing = !0;
- break
- } for (var i = null, n = 0, o = 0; o < t.length; o++) {
- var a, r = t[o],
- s = r.zlevel;
- r.incremental ? ((a = this.getLayer(s + .001, this._needsManuallyCompositing)).incremental = !0, n = 1) : a =
- this.getLayer(s + (n > 0 ? .01 : 0), this._needsManuallyCompositing), a.__builtin__ || Bw("ZLevel " + s +
- " has been used by unkown layer " + a.id), a !== i && (a.__used = !0, a.__startIndex !== o && (a.__dirty = !0),
- a.__startIndex = o, a.incremental ? a.__drawIndex = -1 : a.__drawIndex = o, e(o), i = a), r.__dirty && (a.__dirty = !
- 0, a.incremental && a.__drawIndex < 0 && (a.__drawIndex = o))
- }
- e(o), this.eachBuiltinLayer(function(t, e) {
- !t.__used && t.getElementCount() > 0 && (t.__dirty = !0, t.__startIndex = t.__endIndex = t.__drawIndex = 0), t
- .__dirty && t.__drawIndex < 0 && (t.__drawIndex = t.__startIndex)
- })
- },
- clear: function() {
- return this.eachBuiltinLayer(this._clearLayer), this
- },
- _clearLayer: function(t) {
- t.clear()
- },
- setBackgroundColor: function(t) {
- this._backgroundColor = t
- },
- configLayer: function(t, e) {
- if (e) {
- var i = this._layerConfig;
- i[t] ? n(i[t], e, !0) : i[t] = e;
- for (var o = 0; o < this._zlevelList.length; o++) {
- var a = this._zlevelList[o];
- a !== t && a !== t + .01 || n(this._layers[a], i[t], !0)
- }
- }
- },
- delLayer: function(t) {
- var e = this._layers,
- i = this._zlevelList,
- n = e[t];
- n && (n.dom.parentNode.removeChild(n.dom), delete e[t], i.splice(l(i, t), 1))
- },
- resize: function(t, e) {
- if (this._domRoot.style) {
- var i = this._domRoot;
- i.style.display = "none";
- var n = this._opts;
- if (null != t && (n.width = t), null != e && (n.height = e), t = this._getSize(0), e = this._getSize(1), i.style
- .display = "", this._width != t || e != this._height) {
- i.style.width = t + "px", i.style.height = e + "px";
- for (var o in this._layers) this._layers.hasOwnProperty(o) && this._layers[o].resize(t, e);
- d(this._progressiveLayers, function(i) {
- i.resize(t, e)
- }), this.refresh(!0)
- }
- this._width = t, this._height = e
- } else {
- if (null == t || null == e) return;
- this._width = t, this._height = e, this.getLayer(314159).resize(t, e)
- }
- return this
- },
- clearLayer: function(t) {
- var e = this._layers[t];
- e && e.clear()
- },
- dispose: function() {
- this.root.innerHTML = "", this.root = this.storage = this._domRoot = this._layers = null
- },
- getRenderedCanvas: function(t) {
- if (t = t || {}, this._singleCanvas && !this._compositeManually) return this._layers[314159].dom;
- var e = new ib("image", this, t.pixelRatio || this.dpr);
- if (e.initContext(), e.clear(!1, t.backgroundColor || this._backgroundColor), t.pixelRatio <= this.dpr) {
- this.refresh();
- var i = e.dom.width,
- n = e.dom.height,
- o = e.ctx;
- this.eachLayer(function(t) {
- t.__builtin__ ? o.drawImage(t.dom, 0, 0, i, n) : t.renderToCanvas && (e.ctx.save(), t.renderToCanvas(e.ctx),
- e.ctx.restore())
- })
- } else
- for (var a = {}, r = this.storage.getDisplayList(!0), s = 0; s < r.length; s++) {
- var l = r[s];
- this._doPaintEl(l, e, !0, a)
- }
- return e.dom
- },
- getWidth: function() {
- return this._width
- },
- getHeight: function() {
- return this._height
- },
- _getSize: function(t) {
- var e = this._opts,
- i = ["width", "height"][t],
- n = ["clientWidth", "clientHeight"][t],
- o = ["paddingLeft", "paddingTop"][t],
- a = ["paddingRight", "paddingBottom"][t];
- if (null != e[i] && "auto" !== e[i]) return parseFloat(e[i]);
- var r = this.root,
- s = document.defaultView.getComputedStyle(r);
- return (r[n] || ci(s[i]) || ci(r.style[i])) - (ci(s[o]) || 0) - (ci(s[a]) || 0) | 0
- },
- pathToImage: function(t, e) {
- e = e || this.dpr;
- var i = document.createElement("canvas"),
- n = i.getContext("2d"),
- o = t.getBoundingRect(),
- a = t.style,
- r = a.shadowBlur * e,
- s = a.shadowOffsetX * e,
- l = a.shadowOffsetY * e,
- u = a.hasStroke() ? a.lineWidth : 0,
- h = Math.max(u / 2, -s + r),
- c = Math.max(u / 2, s + r),
- d = Math.max(u / 2, -l + r),
- f = Math.max(u / 2, l + r),
- p = o.width + h + c,
- g = o.height + d + f;
- i.width = p * e, i.height = g * e, n.scale(e, e), n.clearRect(0, 0, p, g), n.dpr = e;
- var m = {
- position: t.position,
- rotation: t.rotation,
- scale: t.scale
- };
- t.position = [h - o.x, d - o.y], t.rotation = 0, t.scale = [1, 1], t.updateTransform(), t && t.brush(n);
- var v = new hi({
- style: {
- x: 0,
- y: 0,
- image: i
- }
- });
- return null != m.position && (v.position = t.position = m.position), null != m.rotation && (v.rotation = t.rotation =
- m.rotation), null != m.scale && (v.scale = t.scale = m.scale), v
- }
- };
- var xb = function(t) {
- t = t || {}, this.stage = t.stage || {}, this.onframe = t.onframe || function() {}, this._clips = [], this._running = !
- 1, this._time, this._pausedTime, this._pauseStart, this._paused = !1, aw.call(this)
- };
- xb.prototype = {
- constructor: xb,
- addClip: function(t) {
- this._clips.push(t)
- },
- addAnimator: function(t) {
- t.animation = this;
- for (var e = t.getClips(), i = 0; i < e.length; i++) this.addClip(e[i])
- },
- removeClip: function(t) {
- var e = l(this._clips, t);
- e >= 0 && this._clips.splice(e, 1)
- },
- removeAnimator: function(t) {
- for (var e = t.getClips(), i = 0; i < e.length; i++) this.removeClip(e[i]);
- t.animation = null
- },
- _update: function() {
- for (var t = (new Date).getTime() - this._pausedTime, e = t - this._time, i = this._clips, n = i.length, o = [],
- a = [], r = 0; r < n; r++) {
- var s = i[r],
- l = s.step(t, e);
- l && (o.push(l), a.push(s))
- }
- for (r = 0; r < n;) i[r]._needsRemove ? (i[r] = i[n - 1], i.pop(), n--) : r++;
- n = o.length;
- for (r = 0; r < n; r++) a[r].fire(o[r]);
- this._time = t, this.onframe(e), this.trigger("frame", e), this.stage.update && this.stage.update()
- },
- _startLoop: function() {
- function t() {
- e._running && (nb(t), !e._paused && e._update())
- }
- var e = this;
- this._running = !0, nb(t)
- },
- start: function() {
- this._time = (new Date).getTime(), this._pausedTime = 0, this._startLoop()
- },
- stop: function() {
- this._running = !1
- },
- pause: function() {
- this._paused || (this._pauseStart = (new Date).getTime(), this._paused = !0)
- },
- resume: function() {
- this._paused && (this._pausedTime += (new Date).getTime() - this._pauseStart, this._paused = !1)
- },
- clear: function() {
- this._clips = []
- },
- isFinished: function() {
- return !this._clips.length
- },
- animate: function(t, e) {
- var i = new Ow(t, (e = e || {}).loop, e.getter, e.setter);
- return this.addAnimator(i), i
- }
- }, h(xb, aw);
- var _b = function() {
- this._track = []
- };
- _b.prototype = {
- constructor: _b,
- recognize: function(t, e, i) {
- return this._doTrack(t, e, i), this._recognize(t)
- },
- clear: function() {
- return this._track.length = 0, this
- },
- _doTrack: function(t, e, i) {
- var n = t.touches;
- if (n) {
- for (var o = {
- points: [],
- touches: [],
- target: e,
- event: t
- }, a = 0, r = n.length; a < r; a++) {
- var s = n[a],
- l = rt(i, s, {});
- o.points.push([l.zrX, l.zrY]), o.touches.push(s)
- }
- this._track.push(o)
- }
- },
- _recognize: function(t) {
- for (var e in wb)
- if (wb.hasOwnProperty(e)) {
- var i = wb[e](this._track, t);
- if (i) return i
- }
- }
- };
- var wb = {
- pinch: function(t, e) {
- var i = t.length;
- if (i) {
- var n = (t[i - 1] || {}).points,
- o = (t[i - 2] || {}).points || n;
- if (o && o.length > 1 && n && n.length > 1) {
- var a = vi(n) / vi(o);
- !isFinite(a) && (a = 1), e.pinchScale = a;
- var r = yi(n);
- return e.pinchX = r[0], e.pinchY = r[1], {
- type: "pinch",
- target: t[0].target,
- event: e
- }
- }
- }
- }
- },
- bb = ["click", "dblclick", "mousewheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu"],
- Sb = ["touchstart", "touchend", "touchmove"],
- Mb = {
- pointerdown: 1,
- pointerup: 1,
- pointermove: 1,
- pointerout: 1
- },
- Ib = f(bb, function(t) {
- var e = t.replace("mouse", "pointer");
- return Mb[e] ? e : t
- }),
- Tb = {
- mousemove: function(t) {
- t = lt(this.dom, t), this.trigger("mousemove", t)
- },
- mouseout: function(t) {
- var e = (t = lt(this.dom, t)).toElement || t.relatedTarget;
- if (e != this.dom)
- for (; e && 9 != e.nodeType;) {
- if (e === this.dom) return;
- e = e.parentNode
- }
- this.trigger("mouseout", t)
- },
- touchstart: function(t) {
- (t = lt(this.dom, t)).zrByTouch = !0, this._lastTouchMoment = new Date, _i(this, t, "start"), Tb.mousemove.call(
- this, t), Tb.mousedown.call(this, t), wi(this)
- },
- touchmove: function(t) {
- (t = lt(this.dom, t)).zrByTouch = !0, _i(this, t, "change"), Tb.mousemove.call(this, t), wi(this)
- },
- touchend: function(t) {
- (t = lt(this.dom, t)).zrByTouch = !0, _i(this, t, "end"), Tb.mouseup.call(this, t), +new Date - this._lastTouchMoment <
- 300 && Tb.click.call(this, t), wi(this)
- },
- pointerdown: function(t) {
- Tb.mousedown.call(this, t)
- },
- pointermove: function(t) {
- bi(t) || Tb.mousemove.call(this, t)
- },
- pointerup: function(t) {
- Tb.mouseup.call(this, t)
- },
- pointerout: function(t) {
- bi(t) || Tb.mouseout.call(this, t)
- }
- };
- d(["click", "mousedown", "mouseup", "mousewheel", "dblclick", "contextmenu"], function(t) {
- Tb[t] = function(e) {
- e = lt(this.dom, e), this.trigger(t, e)
- }
- });
- var Ab = Mi.prototype;
- Ab.dispose = function() {
- for (var t = bb.concat(Sb), e = 0; e < t.length; e++) {
- var i = t[e];
- ht(this.dom, xi(i), this._handlers[i])
- }
- }, Ab.setCursor = function(t) {
- this.dom.style && (this.dom.style.cursor = t || "default")
- }, h(Mi, aw);
- var Db = !z_.canvasSupported,
- Cb = {
- canvas: yb
- },
- Lb = {},
- kb = function(t, e, i) {
- i = i || {}, this.dom = e, this.id = t;
- var n = this,
- o = new jw,
- a = i.renderer;
- if (Db) {
- if (!Cb.vml) throw new Error("You need to require 'zrender/vml/vml' to support IE8");
- a = "vml"
- } else a && Cb[a] || (a = "canvas");
- var r = new Cb[a](e, o, i, t);
- this.storage = o, this.painter = r;
- var s = z_.node || z_.worker ? null : new Mi(r.getViewportRoot());
- this.handler = new cw(o, r, s, r.root), this.animation = new xb({
- stage: {
- update: m(this.flush, this)
- }
- }), this.animation.start(), this._needsRefresh;
- var l = o.delFromStorage,
- u = o.addToStorage;
- o.delFromStorage = function(t) {
- l.call(o, t), t && t.removeSelfFromZr(n)
- }, o.addToStorage = function(t) {
- u.call(o, t), t.addSelfToZr(n)
- }
- };
- kb.prototype = {
- constructor: kb,
- getId: function() {
- return this.id
- },
- add: function(t) {
- this.storage.addRoot(t), this._needsRefresh = !0
- },
- remove: function(t) {
- this.storage.delRoot(t), this._needsRefresh = !0
- },
- configLayer: function(t, e) {
- this.painter.configLayer && this.painter.configLayer(t, e), this._needsRefresh = !0
- },
- setBackgroundColor: function(t) {
- this.painter.setBackgroundColor && this.painter.setBackgroundColor(t), this._needsRefresh = !0
- },
- refreshImmediately: function() {
- this._needsRefresh = !1, this.painter.refresh(), this._needsRefresh = !1
- },
- refresh: function() {
- this._needsRefresh = !0
- },
- flush: function() {
- var t;
- this._needsRefresh && (t = !0, this.refreshImmediately()), this._needsRefreshHover && (t = !0, this.refreshHoverImmediately()),
- t && this.trigger("rendered")
- },
- addHover: function(t, e) {
- if (this.painter.addHover) {
- var i = this.painter.addHover(t, e);
- return this.refreshHover(), i
- }
- },
- removeHover: function(t) {
- this.painter.removeHover && (this.painter.removeHover(t), this.refreshHover())
- },
- clearHover: function() {
- this.painter.clearHover && (this.painter.clearHover(), this.refreshHover())
- },
- refreshHover: function() {
- this._needsRefreshHover = !0
- },
- refreshHoverImmediately: function() {
- this._needsRefreshHover = !1, this.painter.refreshHover && this.painter.refreshHover()
- },
- resize: function(t) {
- t = t || {}, this.painter.resize(t.width, t.height), this.handler.resize()
- },
- clearAnimation: function() {
- this.animation.clear()
- },
- getWidth: function() {
- return this.painter.getWidth()
- },
- getHeight: function() {
- return this.painter.getHeight()
- },
- pathToImage: function(t, e) {
- return this.painter.pathToImage(t, e)
- },
- setCursorStyle: function(t) {
- this.handler.setCursorStyle(t)
- },
- findHover: function(t, e) {
- return this.handler.findHover(t, e)
- },
- on: function(t, e, i) {
- this.handler.on(t, e, i)
- },
- off: function(t, e) {
- this.handler.off(t, e)
- },
- trigger: function(t, e) {
- this.handler.trigger(t, e)
- },
- clear: function() {
- this.storage.delRoot(), this.painter.clear()
- },
- dispose: function() {
- this.animation.stop(), this.clear(), this.storage.dispose(), this.painter.dispose(), this.handler.dispose(), this
- .animation = this.storage = this.painter = this.handler = null, Ai(this.id)
- }
- };
- var Pb = (Object.freeze || Object)({
- version: "4.0.5",
- init: Ii,
- dispose: function(t) {
- if (t) t.dispose();
- else {
- for (var e in Lb) Lb.hasOwnProperty(e) && Lb[e].dispose();
- Lb = {}
- }
- return this
- },
- getInstance: function(t) {
- return Lb[t]
- },
- registerPainter: Ti
- }),
- Nb = d,
- Ob = w,
- Eb = y,
- Rb = "series\0",
- zb = ["fontStyle", "fontWeight", "fontSize", "fontFamily", "rich", "tag", "color", "textBorderColor",
- "textBorderWidth", "width", "height", "lineHeight", "align", "verticalAlign", "baseline", "shadowColor",
- "shadowBlur", "shadowOffsetX", "shadowOffsetY", "textShadowColor", "textShadowBlur", "textShadowOffsetX",
- "textShadowOffsetY", "backgroundColor", "borderColor", "borderWidth", "borderRadius", "padding"
- ],
- Bb = 0,
- Vb = ".",
- Gb = "___EC__COMPONENT__CONTAINER___",
- Fb = 0,
- Wb = function(t) {
- for (var e = 0; e < t.length; e++) t[e][1] || (t[e][1] = t[e][0]);
- return function(e, i, n) {
- for (var o = {}, a = 0; a < t.length; a++) {
- var r = t[a][1];
- if (!(i && l(i, r) >= 0 || n && l(n, r) < 0)) {
- var s = e.getShallow(r);
- null != s && (o[t[a][0]] = s)
- }
- }
- return o
- }
- },
- Hb = Wb([
- ["lineWidth", "width"],
- ["stroke", "color"],
- ["opacity"],
- ["shadowBlur"],
- ["shadowOffsetX"],
- ["shadowOffsetY"],
- ["shadowColor"]
- ]),
- Zb = {
- getLineStyle: function(t) {
- var e = Hb(this, t),
- i = this.getLineDash(e.lineWidth);
- return i && (e.lineDash = i), e
- },
- getLineDash: function(t) {
- null == t && (t = 1);
- var e = this.get("type"),
- i = Math.max(t, 2),
- n = 4 * t;
- return "solid" === e || null == e ? null : "dashed" === e ? [n, n] : [i, i]
- }
- },
- Ub = Wb([
- ["fill", "color"],
- ["shadowBlur"],
- ["shadowOffsetX"],
- ["shadowOffsetY"],
- ["opacity"],
- ["shadowColor"]
- ]),
- Xb = {
- getAreaStyle: function(t, e) {
- return Ub(this, t, e)
- }
- },
- jb = Math.pow,
- Yb = Math.sqrt,
- qb = 1e-8,
- Kb = 1e-4,
- $b = Yb(3),
- Jb = 1 / 3,
- Qb = V(),
- tS = V(),
- eS = V(),
- iS = Math.min,
- nS = Math.max,
- oS = Math.sin,
- aS = Math.cos,
- rS = 2 * Math.PI,
- sS = V(),
- lS = V(),
- uS = V(),
- hS = [],
- cS = [],
- dS = {
- M: 1,
- L: 2,
- C: 3,
- Q: 4,
- A: 5,
- Z: 6,
- R: 7
- },
- fS = [],
- pS = [],
- gS = [],
- mS = [],
- vS = Math.min,
- yS = Math.max,
- xS = Math.cos,
- _S = Math.sin,
- wS = Math.sqrt,
- bS = Math.abs,
- SS = "undefined" != typeof Float32Array,
- MS = function(t) {
- this._saveData = !t, this._saveData && (this.data = []), this._ctx = null
- };
- MS.prototype = {
- constructor: MS,
- _xi: 0,
- _yi: 0,
- _x0: 0,
- _y0: 0,
- _ux: 0,
- _uy: 0,
- _len: 0,
- _lineDash: null,
- _dashOffset: 0,
- _dashIdx: 0,
- _dashSum: 0,
- setScale: function(t, e) {
- this._ux = bS(1 / Rw / t) || 0, this._uy = bS(1 / Rw / e) || 0
- },
- getContext: function() {
- return this._ctx
- },
- beginPath: function(t) {
- return this._ctx = t, t && t.beginPath(), t && (this.dpr = t.dpr), this._saveData && (this._len = 0), this._lineDash &&
- (this._lineDash = null, this._dashOffset = 0), this
- },
- moveTo: function(t, e) {
- return this.addData(dS.M, t, e), this._ctx && this._ctx.moveTo(t, e), this._x0 = t, this._y0 = e, this._xi = t,
- this._yi = e, this
- },
- lineTo: function(t, e) {
- var i = bS(t - this._xi) > this._ux || bS(e - this._yi) > this._uy || this._len < 5;
- return this.addData(dS.L, t, e), this._ctx && i && (this._needsDash() ? this._dashedLineTo(t, e) : this._ctx.lineTo(
- t, e)), i && (this._xi = t, this._yi = e), this
- },
- bezierCurveTo: function(t, e, i, n, o, a) {
- return this.addData(dS.C, t, e, i, n, o, a), this._ctx && (this._needsDash() ? this._dashedBezierTo(t, e, i, n, o,
- a) : this._ctx.bezierCurveTo(t, e, i, n, o, a)), this._xi = o, this._yi = a, this
- },
- quadraticCurveTo: function(t, e, i, n) {
- return this.addData(dS.Q, t, e, i, n), this._ctx && (this._needsDash() ? this._dashedQuadraticTo(t, e, i, n) :
- this._ctx.quadraticCurveTo(t, e, i, n)), this._xi = i, this._yi = n, this
- },
- arc: function(t, e, i, n, o, a) {
- return this.addData(dS.A, t, e, i, i, n, o - n, 0, a ? 0 : 1), this._ctx && this._ctx.arc(t, e, i, n, o, a), this
- ._xi = xS(o) * i + t, this._yi = _S(o) * i + e, this
- },
- arcTo: function(t, e, i, n, o) {
- return this._ctx && this._ctx.arcTo(t, e, i, n, o), this
- },
- rect: function(t, e, i, n) {
- return this._ctx && this._ctx.rect(t, e, i, n), this.addData(dS.R, t, e, i, n), this
- },
- closePath: function() {
- this.addData(dS.Z);
- var t = this._ctx,
- e = this._x0,
- i = this._y0;
- return t && (this._needsDash() && this._dashedLineTo(e, i), t.closePath()), this._xi = e, this._yi = i, this
- },
- fill: function(t) {
- t && t.fill(), this.toStatic()
- },
- stroke: function(t) {
- t && t.stroke(), this.toStatic()
- },
- setLineDash: function(t) {
- if (t instanceof Array) {
- this._lineDash = t, this._dashIdx = 0;
- for (var e = 0, i = 0; i < t.length; i++) e += t[i];
- this._dashSum = e
- }
- return this
- },
- setLineDashOffset: function(t) {
- return this._dashOffset = t, this
- },
- len: function() {
- return this._len
- },
- setData: function(t) {
- var e = t.length;
- this.data && this.data.length == e || !SS || (this.data = new Float32Array(e));
- for (var i = 0; i < e; i++) this.data[i] = t[i];
- this._len = e
- },
- appendPath: function(t) {
- t instanceof Array || (t = [t]);
- for (var e = t.length, i = 0, n = this._len, o = 0; o < e; o++) i += t[o].len();
- SS && this.data instanceof Float32Array && (this.data = new Float32Array(n + i));
- for (o = 0; o < e; o++)
- for (var a = t[o].data, r = 0; r < a.length; r++) this.data[n++] = a[r];
- this._len = n
- },
- addData: function(t) {
- if (this._saveData) {
- var e = this.data;
- this._len + arguments.length > e.length && (this._expandData(), e = this.data);
- for (var i = 0; i < arguments.length; i++) e[this._len++] = arguments[i];
- this._prevCmd = t
- }
- },
- _expandData: function() {
- if (!(this.data instanceof Array)) {
- for (var t = [], e = 0; e < this._len; e++) t[e] = this.data[e];
- this.data = t
- }
- },
- _needsDash: function() {
- return this._lineDash
- },
- _dashedLineTo: function(t, e) {
- var i, n, o = this._dashSum,
- a = this._dashOffset,
- r = this._lineDash,
- s = this._ctx,
- l = this._xi,
- u = this._yi,
- h = t - l,
- c = e - u,
- d = wS(h * h + c * c),
- f = l,
- p = u,
- g = r.length;
- for (h /= d, c /= d, a < 0 && (a = o + a), f -= (a %= o) * h, p -= a * c; h > 0 && f <= t || h < 0 && f >= t || 0 ==
- h && (c > 0 && p <= e || c < 0 && p >= e);) f += h * (i = r[n = this._dashIdx]), p += c * i, this._dashIdx = (n +
- 1) % g, h > 0 && f < l || h < 0 && f > l || c > 0 && p < u || c < 0 && p > u || s[n % 2 ? "moveTo" : "lineTo"](
- h >= 0 ? vS(f, t) : yS(f, t), c >= 0 ? vS(p, e) : yS(p, e));
- h = f - t, c = p - e, this._dashOffset = -wS(h * h + c * c)
- },
- _dashedBezierTo: function(t, e, i, n, o, a) {
- var r, s, l, u, h, c = this._dashSum,
- d = this._dashOffset,
- f = this._lineDash,
- p = this._ctx,
- g = this._xi,
- m = this._yi,
- v = Qi,
- y = 0,
- x = this._dashIdx,
- _ = f.length,
- w = 0;
- for (d < 0 && (d = c + d), d %= c, r = 0; r < 1; r += .1) s = v(g, t, i, o, r + .1) - v(g, t, i, o, r), l = v(m,
- e, n, a, r + .1) - v(m, e, n, a, r), y += wS(s * s + l * l);
- for (; x < _ && !((w += f[x]) > d); x++);
- for (r = (w - d) / y; r <= 1;) u = v(g, t, i, o, r), h = v(m, e, n, a, r), x % 2 ? p.moveTo(u, h) : p.lineTo(u, h),
- r += f[x] / y, x = (x + 1) % _;
- x % 2 != 0 && p.lineTo(o, a), s = o - u, l = a - h, this._dashOffset = -wS(s * s + l * l)
- },
- _dashedQuadraticTo: function(t, e, i, n) {
- var o = i,
- a = n;
- i = (i + 2 * t) / 3, n = (n + 2 * e) / 3, t = (this._xi + 2 * t) / 3, e = (this._yi + 2 * e) / 3, this._dashedBezierTo(
- t, e, i, n, o, a)
- },
- toStatic: function() {
- var t = this.data;
- t instanceof Array && (t.length = this._len, SS && (this.data = new Float32Array(t)))
- },
- getBoundingRect: function() {
- fS[0] = fS[1] = gS[0] = gS[1] = Number.MAX_VALUE, pS[0] = pS[1] = mS[0] = mS[1] = -Number.MAX_VALUE;
- for (var t = this.data, e = 0, i = 0, n = 0, o = 0, a = 0; a < t.length;) {
- var r = t[a++];
- switch (1 == a && (n = e = t[a], o = i = t[a + 1]), r) {
- case dS.M:
- e = n = t[a++], i = o = t[a++], gS[0] = n, gS[1] = o, mS[0] = n, mS[1] = o;
- break;
- case dS.L:
- fn(e, i, t[a], t[a + 1], gS, mS), e = t[a++], i = t[a++];
- break;
- case dS.C:
- pn(e, i, t[a++], t[a++], t[a++], t[a++], t[a], t[a + 1], gS, mS), e = t[a++], i = t[a++];
- break;
- case dS.Q:
- gn(e, i, t[a++], t[a++], t[a], t[a + 1], gS, mS), e = t[a++], i = t[a++];
- break;
- case dS.A:
- var s = t[a++],
- l = t[a++],
- u = t[a++],
- h = t[a++],
- c = t[a++],
- d = t[a++] + c,
- f = (t[a++], 1 - t[a++]);
- 1 == a && (n = xS(c) * u + s, o = _S(c) * h + l), mn(s, l, u, h, c, d, f, gS, mS), e = xS(d) * u + s, i = _S(d) *
- h + l;
- break;
- case dS.R:
- fn(n = e = t[a++], o = i = t[a++], n + t[a++], o + t[a++], gS, mS);
- break;
- case dS.Z:
- e = n, i = o
- }
- tt(fS, fS, gS), et(pS, pS, mS)
- }
- return 0 === a && (fS[0] = fS[1] = pS[0] = pS[1] = 0), new ue(fS[0], fS[1], pS[0] - fS[0], pS[1] - fS[1])
- },
- rebuildPath: function(t) {
- for (var e, i, n, o, a, r, s = this.data, l = this._ux, u = this._uy, h = this._len, c = 0; c < h;) {
- var d = s[c++];
- switch (1 == c && (e = n = s[c], i = o = s[c + 1]), d) {
- case dS.M:
- e = n = s[c++], i = o = s[c++], t.moveTo(n, o);
- break;
- case dS.L:
- a = s[c++], r = s[c++], (bS(a - n) > l || bS(r - o) > u || c === h - 1) && (t.lineTo(a, r), n = a, o = r);
- break;
- case dS.C:
- t.bezierCurveTo(s[c++], s[c++], s[c++], s[c++], s[c++], s[c++]), n = s[c - 2], o = s[c - 1];
- break;
- case dS.Q:
- t.quadraticCurveTo(s[c++], s[c++], s[c++], s[c++]), n = s[c - 2], o = s[c - 1];
- break;
- case dS.A:
- var f = s[c++],
- p = s[c++],
- g = s[c++],
- m = s[c++],
- v = s[c++],
- y = s[c++],
- x = s[c++],
- _ = s[c++],
- w = g > m ? g : m,
- b = g > m ? 1 : g / m,
- S = g > m ? m / g : 1,
- M = v + y;
- Math.abs(g - m) > .001 ? (t.translate(f, p), t.rotate(x), t.scale(b, S), t.arc(0, 0, w, v, M, 1 - _), t.scale(
- 1 / b, 1 / S), t.rotate(-x), t.translate(-f, -p)) : t.arc(f, p, w, v, M, 1 - _), 1 == c && (e = xS(v) * g +
- f, i = _S(v) * m + p), n = xS(M) * g + f, o = _S(M) * m + p;
- break;
- case dS.R:
- e = n = s[c], i = o = s[c + 1], t.rect(s[c++], s[c++], s[c++], s[c++]);
- break;
- case dS.Z:
- t.closePath(), n = e, o = i
- }
- }
- }
- }, MS.CMD = dS;
- var IS = 2 * Math.PI,
- TS = 2 * Math.PI,
- AS = MS.CMD,
- DS = 2 * Math.PI,
- CS = 1e-4,
- LS = [-1, -1, -1],
- kS = [-1, -1],
- PS = eb.prototype.getCanvasPattern,
- NS = Math.abs,
- OS = new MS(!0);
- kn.prototype = {
- constructor: kn,
- type: "path",
- __dirtyPath: !0,
- strokeContainThreshold: 5,
- brush: function(t, e) {
- var i = this.style,
- n = this.path || OS,
- o = i.hasStroke(),
- a = i.hasFill(),
- r = i.fill,
- s = i.stroke,
- l = a && !!r.colorStops,
- u = o && !!s.colorStops,
- h = a && !!r.image,
- c = o && !!s.image;
- if (i.bind(t, this, e), this.setTransform(t), this.__dirty) {
- var d;
- l && (d = d || this.getBoundingRect(), this._fillGradient = i.getGradient(t, r, d)), u && (d = d || this.getBoundingRect(),
- this._strokeGradient = i.getGradient(t, s, d))
- }
- l ? t.fillStyle = this._fillGradient : h && (t.fillStyle = PS.call(r, t)), u ? t.strokeStyle = this._strokeGradient :
- c && (t.strokeStyle = PS.call(s, t));
- var f = i.lineDash,
- p = i.lineDashOffset,
- g = !!t.setLineDash,
- m = this.getGlobalScale();
- if (n.setScale(m[0], m[1]), this.__dirtyPath || f && !g && o ? (n.beginPath(t), f && !g && (n.setLineDash(f), n.setLineDashOffset(
- p)), this.buildPath(n, this.shape, !1), this.path && (this.__dirtyPath = !1)) : (t.beginPath(), this.path.rebuildPath(
- t)), a)
- if (null != i.fillOpacity) {
- v = t.globalAlpha;
- t.globalAlpha = i.fillOpacity * i.opacity, n.fill(t), t.globalAlpha = v
- } else n.fill(t);
- if (f && g && (t.setLineDash(f), t.lineDashOffset = p), o)
- if (null != i.strokeOpacity) {
- var v = t.globalAlpha;
- t.globalAlpha = i.strokeOpacity * i.opacity, n.stroke(t), t.globalAlpha = v
- } else n.stroke(t);
- f && g && t.setLineDash([]), null != i.text && (this.restoreTransform(t), this.drawRectText(t, this.getBoundingRect()))
- },
- buildPath: function(t, e, i) {},
- createPathProxy: function() {
- this.path = new MS
- },
- getBoundingRect: function() {
- var t = this._rect,
- e = this.style,
- i = !t;
- if (i) {
- var n = this.path;
- n || (n = this.path = new MS), this.__dirtyPath && (n.beginPath(), this.buildPath(n, this.shape, !1)), t = n.getBoundingRect()
- }
- if (this._rect = t, e.hasStroke()) {
- var o = this._rectWithStroke || (this._rectWithStroke = t.clone());
- if (this.__dirty || i) {
- o.copy(t);
- var a = e.lineWidth,
- r = e.strokeNoScale ? this.getLineScale() : 1;
- e.hasFill() || (a = Math.max(a, this.strokeContainThreshold || 4)), r > 1e-10 && (o.width += a / r, o.height +=
- a / r, o.x -= a / r / 2, o.y -= a / r / 2)
- }
- return o
- }
- return t
- },
- contain: function(t, e) {
- var i = this.transformCoordToLocal(t, e),
- n = this.getBoundingRect(),
- o = this.style;
- if (t = i[0], e = i[1], n.contain(t, e)) {
- var a = this.path.data;
- if (o.hasStroke()) {
- var r = o.lineWidth,
- s = o.strokeNoScale ? this.getLineScale() : 1;
- if (s > 1e-10 && (o.hasFill() || (r = Math.max(r, this.strokeContainThreshold)), Ln(a, r / s, t, e))) return !0
- }
- if (o.hasFill()) return Cn(a, t, e)
- }
- return !1
- },
- dirty: function(t) {
- null == t && (t = !0), t && (this.__dirtyPath = t, this._rect = null), this.__dirty = this.__dirtyText = !0, this
- .__zr && this.__zr.refresh(), this.__clipTarget && this.__clipTarget.dirty()
- },
- animateShape: function(t) {
- return this.animate("shape", t)
- },
- attrKV: function(t, e) {
- "shape" === t ? (this.setShape(e), this.__dirtyPath = !0, this._rect = null) : ui.prototype.attrKV.call(this, t,
- e)
- },
- setShape: function(t, e) {
- var i = this.shape;
- if (i) {
- if (w(t))
- for (var n in t) t.hasOwnProperty(n) && (i[n] = t[n]);
- else i[t] = e;
- this.dirty(!0)
- }
- return this
- },
- getLineScale: function() {
- var t = this.transform;
- return t && NS(t[0] - 1) > 1e-10 && NS(t[3] - 1) > 1e-10 ? Math.sqrt(NS(t[0] * t[3] - t[2] * t[1])) : 1
- }
- }, kn.extend = function(t) {
- var e = function(e) {
- kn.call(this, e), t.style && this.style.extendFrom(t.style, !1);
- var i = t.shape;
- if (i) {
- this.shape = this.shape || {};
- var n = this.shape;
- for (var o in i) !n.hasOwnProperty(o) && i.hasOwnProperty(o) && (n[o] = i[o])
- }
- t.init && t.init.call(this, e)
- };
- u(e, kn);
- for (var i in t) "style" !== i && "shape" !== i && (e.prototype[i] = t[i]);
- return e
- }, u(kn, ui);
- var ES = MS.CMD,
- RS = [
- [],
- [],
- []
- ],
- zS = Math.sqrt,
- BS = Math.atan2,
- VS = function(t, e) {
- var i, n, o, a, r, s, l = t.data,
- u = ES.M,
- h = ES.C,
- c = ES.L,
- d = ES.R,
- f = ES.A,
- p = ES.Q;
- for (o = 0, a = 0; o < l.length;) {
- switch (i = l[o++], a = o, n = 0, i) {
- case u:
- case c:
- n = 1;
- break;
- case h:
- n = 3;
- break;
- case p:
- n = 2;
- break;
- case f:
- var g = e[4],
- m = e[5],
- v = zS(e[0] * e[0] + e[1] * e[1]),
- y = zS(e[2] * e[2] + e[3] * e[3]),
- x = BS(-e[1] / y, e[0] / v);
- l[o] *= v, l[o++] += g, l[o] *= y, l[o++] += m, l[o++] *= v, l[o++] *= y, l[o++] += x, l[o++] += x, a = o += 2;
- break;
- case d:
- s[0] = l[o++], s[1] = l[o++], Q(s, s, e), l[a++] = s[0], l[a++] = s[1], s[0] += l[o++], s[1] += l[o++], Q(s, s,
- e), l[a++] = s[0], l[a++] = s[1]
- }
- for (r = 0; r < n; r++)(s = RS[r])[0] = l[o++], s[1] = l[o++], Q(s, s, e), l[a++] = s[0], l[a++] = s[1]
- }
- },
- GS = Math.sqrt,
- FS = Math.sin,
- WS = Math.cos,
- HS = Math.PI,
- ZS = function(t) {
- return Math.sqrt(t[0] * t[0] + t[1] * t[1])
- },
- US = function(t, e) {
- return (t[0] * e[0] + t[1] * e[1]) / (ZS(t) * ZS(e))
- },
- XS = function(t, e) {
- return (t[0] * e[1] < t[1] * e[0] ? -1 : 1) * Math.acos(US(t, e))
- },
- jS = /([mlvhzcqtsa])([^mlvhzcqtsa]*)/gi,
- YS = /-?([0-9]*\.)?[0-9]+([eE]-?[0-9]+)?/g,
- qS = function(t) {
- ui.call(this, t)
- };
- qS.prototype = {
- constructor: qS,
- type: "text",
- brush: function(t, e) {
- var i = this.style;
- this.__dirty && Ue(i), i.fill = i.stroke = i.shadowBlur = i.shadowColor = i.shadowOffsetX = i.shadowOffsetY =
- null;
- var n = i.text;
- null != n && (n += ""), li(n, i) && (this.setTransform(t), je(this, t, n, i, null, e), this.restoreTransform(t))
- },
- getBoundingRect: function() {
- var t = this.style;
- if (this.__dirty && Ue(t), !this._rect) {
- var e = t.text;
- null != e ? e += "" : e = "";
- var i = De(t.text + "", t.font, t.textAlign, t.textVerticalAlign, t.textPadding, t.rich);
- if (i.x += t.x || 0, i.y += t.y || 0, oi(t.textStroke, t.textStrokeWidth)) {
- var n = t.textStrokeWidth;
- i.x -= n / 2, i.y -= n / 2, i.width += n, i.height += n
- }
- this._rect = i
- }
- return this._rect
- }
- }, u(qS, ui);
- var KS = kn.extend({
- type: "circle",
- shape: {
- cx: 0,
- cy: 0,
- r: 0
- },
- buildPath: function(t, e, i) {
- i && t.moveTo(e.cx + e.r, e.cy), t.arc(e.cx, e.cy, e.r, 0, 2 * Math.PI, !0)
- }
- }),
- $S = [
- ["shadowBlur", 0],
- ["shadowColor", "#000"],
- ["shadowOffsetX", 0],
- ["shadowOffsetY", 0]
- ],
- JS = function(t) {
- return z_.browser.ie && z_.browser.version >= 11 ? function() {
- var e, i = this.__clipPaths,
- n = this.style;
- if (i)
- for (var o = 0; o < i.length; o++) {
- var a = i[o],
- r = a && a.shape,
- s = a && a.type;
- if (r && ("sector" === s && r.startAngle === r.endAngle || "rect" === s && (!r.width || !r.height))) {
- for (l = 0; l < $S.length; l++) $S[l][2] = n[$S[l][0]], n[$S[l][0]] = $S[l][1];
- e = !0;
- break
- }
- }
- if (t.apply(this, arguments), e)
- for (var l = 0; l < $S.length; l++) n[$S[l][0]] = $S[l][2]
- } : t
- },
- QS = kn.extend({
- type: "sector",
- shape: {
- cx: 0,
- cy: 0,
- r0: 0,
- r: 0,
- startAngle: 0,
- endAngle: 2 * Math.PI,
- clockwise: !0
- },
- brush: JS(kn.prototype.brush),
- buildPath: function(t, e) {
- var i = e.cx,
- n = e.cy,
- o = Math.max(e.r0 || 0, 0),
- a = Math.max(e.r, 0),
- r = e.startAngle,
- s = e.endAngle,
- l = e.clockwise,
- u = Math.cos(r),
- h = Math.sin(r);
- t.moveTo(u * o + i, h * o + n), t.lineTo(u * a + i, h * a + n), t.arc(i, n, a, r, s, !l), t.lineTo(Math.cos(s) *
- o + i, Math.sin(s) * o + n), 0 !== o && t.arc(i, n, o, s, r, l), t.closePath()
- }
- }),
- tM = kn.extend({
- type: "ring",
- shape: {
- cx: 0,
- cy: 0,
- r: 0,
- r0: 0
- },
- buildPath: function(t, e) {
- var i = e.cx,
- n = e.cy,
- o = 2 * Math.PI;
- t.moveTo(i + e.r, n), t.arc(i, n, e.r, 0, o, !1), t.moveTo(i + e.r0, n), t.arc(i, n, e.r0, 0, o, !0)
- }
- }),
- eM = function(t, e) {
- for (var i = t.length, n = [], o = 0, a = 1; a < i; a++) o += K(t[a - 1], t[a]);
- var r = o / 2;
- r = r < i ? i : r;
- for (a = 0; a < r; a++) {
- var s, l, u, h = a / (r - 1) * (e ? i : i - 1),
- c = Math.floor(h),
- d = h - c,
- f = t[c % i];
- e ? (s = t[(c - 1 + i) % i], l = t[(c + 1) % i], u = t[(c + 2) % i]) : (s = t[0 === c ? c : c - 1], l = t[c > i -
- 2 ? i - 1 : c + 1], u = t[c > i - 3 ? i - 1 : c + 2]);
- var p = d * d,
- g = d * p;
- n.push([zn(s[0], f[0], l[0], u[0], d, p, g), zn(s[1], f[1], l[1], u[1], d, p, g)])
- }
- return n
- },
- iM = function(t, e, i, n) {
- var o, a, r, s, l = [],
- u = [],
- h = [],
- c = [];
- if (n) {
- r = [1 / 0, 1 / 0], s = [-1 / 0, -1 / 0];
- for (var d = 0, f = t.length; d < f; d++) tt(r, r, t[d]), et(s, s, t[d]);
- tt(r, r, n[0]), et(s, s, n[1])
- }
- for (var d = 0, f = t.length; d < f; d++) {
- var p = t[d];
- if (i) o = t[d ? d - 1 : f - 1], a = t[(d + 1) % f];
- else {
- if (0 === d || d === f - 1) {
- l.push(F(t[d]));
- continue
- }
- o = t[d - 1], a = t[d + 1]
- }
- U(u, a, o), Y(u, u, e);
- var g = K(p, o),
- m = K(p, a),
- v = g + m;
- 0 !== v && (g /= v, m /= v), Y(h, u, -g), Y(c, u, m);
- var y = H([], p, h),
- x = H([], p, c);
- n && (et(y, y, r), tt(y, y, s), et(x, x, r), tt(x, x, s)), l.push(y), l.push(x)
- }
- return i && l.push(l.shift()), l
- },
- nM = kn.extend({
- type: "polygon",
- shape: {
- points: null,
- smooth: !1,
- smoothConstraint: null
- },
- buildPath: function(t, e) {
- Bn(t, e, !0)
- }
- }),
- oM = kn.extend({
- type: "polyline",
- shape: {
- points: null,
- smooth: !1,
- smoothConstraint: null
- },
- style: {
- stroke: "#000",
- fill: null
- },
- buildPath: function(t, e) {
- Bn(t, e, !1)
- }
- }),
- aM = kn.extend({
- type: "rect",
- shape: {
- r: 0,
- x: 0,
- y: 0,
- width: 0,
- height: 0
- },
- buildPath: function(t, e) {
- var i = e.x,
- n = e.y,
- o = e.width,
- a = e.height;
- e.r ? Ze(t, e) : t.rect(i, n, o, a), t.closePath()
- }
- }),
- rM = kn.extend({
- type: "line",
- shape: {
- x1: 0,
- y1: 0,
- x2: 0,
- y2: 0,
- percent: 1
- },
- style: {
- stroke: "#000",
- fill: null
- },
- buildPath: function(t, e) {
- var i = e.x1,
- n = e.y1,
- o = e.x2,
- a = e.y2,
- r = e.percent;
- 0 !== r && (t.moveTo(i, n), r < 1 && (o = i * (1 - r) + o * r, a = n * (1 - r) + a * r), t.lineTo(o, a))
- },
- pointAt: function(t) {
- var e = this.shape;
- return [e.x1 * (1 - t) + e.x2 * t, e.y1 * (1 - t) + e.y2 * t]
- }
- }),
- sM = [],
- lM = kn.extend({
- type: "bezier-curve",
- shape: {
- x1: 0,
- y1: 0,
- x2: 0,
- y2: 0,
- cpx1: 0,
- cpy1: 0,
- percent: 1
- },
- style: {
- stroke: "#000",
- fill: null
- },
- buildPath: function(t, e) {
- var i = e.x1,
- n = e.y1,
- o = e.x2,
- a = e.y2,
- r = e.cpx1,
- s = e.cpy1,
- l = e.cpx2,
- u = e.cpy2,
- h = e.percent;
- 0 !== h && (t.moveTo(i, n), null == l || null == u ? (h < 1 && (hn(i, r, o, h, sM), r = sM[1], o = sM[2], hn(n,
- s, a, h, sM), s = sM[1], a = sM[2]), t.quadraticCurveTo(r, s, o, a)) : (h < 1 && (on(i, r, l, o, h, sM), r =
- sM[1], l = sM[2], o = sM[3], on(n, s, u, a, h, sM), s = sM[1], u = sM[2], a = sM[3]), t.bezierCurveTo(r, s,
- l, u, o, a)))
- },
- pointAt: function(t) {
- return Vn(this.shape, t, !1)
- },
- tangentAt: function(t) {
- var e = Vn(this.shape, t, !0);
- return q(e, e)
- }
- }),
- uM = kn.extend({
- type: "arc",
- shape: {
- cx: 0,
- cy: 0,
- r: 0,
- startAngle: 0,
- endAngle: 2 * Math.PI,
- clockwise: !0
- },
- style: {
- stroke: "#000",
- fill: null
- },
- buildPath: function(t, e) {
- var i = e.cx,
- n = e.cy,
- o = Math.max(e.r, 0),
- a = e.startAngle,
- r = e.endAngle,
- s = e.clockwise,
- l = Math.cos(a),
- u = Math.sin(a);
- t.moveTo(l * o + i, u * o + n), t.arc(i, n, o, a, r, !s)
- }
- }),
- hM = kn.extend({
- type: "compound",
- shape: {
- paths: null
- },
- _updatePathDirty: function() {
- for (var t = this.__dirtyPath, e = this.shape.paths, i = 0; i < e.length; i++) t = t || e[i].__dirtyPath;
- this.__dirtyPath = t, this.__dirty = this.__dirty || t
- },
- beforeBrush: function() {
- this._updatePathDirty();
- for (var t = this.shape.paths || [], e = this.getGlobalScale(), i = 0; i < t.length; i++) t[i].path || t[i].createPathProxy(),
- t[i].path.setScale(e[0], e[1])
- },
- buildPath: function(t, e) {
- for (var i = e.paths || [], n = 0; n < i.length; n++) i[n].buildPath(t, i[n].shape, !0)
- },
- afterBrush: function() {
- for (var t = this.shape.paths || [], e = 0; e < t.length; e++) t[e].__dirtyPath = !1
- },
- getBoundingRect: function() {
- return this._updatePathDirty(), kn.prototype.getBoundingRect.call(this)
- }
- }),
- cM = function(t) {
- this.colorStops = t || []
- };
- cM.prototype = {
- constructor: cM,
- addColorStop: function(t, e) {
- this.colorStops.push({
- offset: t,
- color: e
- })
- }
- };
- var dM = function(t, e, i, n, o, a) {
- this.x = null == t ? 0 : t, this.y = null == e ? 0 : e, this.x2 = null == i ? 1 : i, this.y2 = null == n ? 0 : n,
- this.type = "linear", this.global = a || !1, cM.call(this, o)
- };
- dM.prototype = {
- constructor: dM
- }, u(dM, cM);
- var fM = function(t, e, i, n, o) {
- this.x = null == t ? .5 : t, this.y = null == e ? .5 : e, this.r = null == i ? .5 : i, this.type = "radial", this.global =
- o || !1, cM.call(this, n)
- };
- fM.prototype = {
- constructor: fM
- }, u(fM, cM), Gn.prototype.incremental = !0, Gn.prototype.clearDisplaybles = function() {
- this._displayables = [], this._temporaryDisplayables = [], this._cursor = 0, this.dirty(), this.notClear = !1
- }, Gn.prototype.addDisplayable = function(t, e) {
- e ? this._temporaryDisplayables.push(t) : this._displayables.push(t), this.dirty()
- }, Gn.prototype.addDisplayables = function(t, e) {
- e = e || !1;
- for (var i = 0; i < t.length; i++) this.addDisplayable(t[i], e)
- }, Gn.prototype.eachPendingDisplayable = function(t) {
- for (e = this._cursor; e < this._displayables.length; e++) t && t(this._displayables[e]);
- for (var e = 0; e < this._temporaryDisplayables.length; e++) t && t(this._temporaryDisplayables[e])
- }, Gn.prototype.update = function() {
- this.updateTransform();
- for (t = this._cursor; t < this._displayables.length; t++)(e = this._displayables[t]).parent = this, e.update(), e.parent =
- null;
- for (var t = 0; t < this._temporaryDisplayables.length; t++) {
- var e = this._temporaryDisplayables[t];
- e.parent = this, e.update(), e.parent = null
- }
- }, Gn.prototype.brush = function(t, e) {
- for (i = this._cursor; i < this._displayables.length; i++)(n = this._displayables[i]).beforeBrush && n.beforeBrush(
- t), n.brush(t, i === this._cursor ? null : this._displayables[i - 1]), n.afterBrush && n.afterBrush(t);
- this._cursor = i;
- for (var i = 0; i < this._temporaryDisplayables.length; i++) {
- var n = this._temporaryDisplayables[i];
- n.beforeBrush && n.beforeBrush(t), n.brush(t, 0 === i ? null : this._temporaryDisplayables[i - 1]), n.afterBrush &&
- n.afterBrush(t)
- }
- this._temporaryDisplayables = [], this.notClear = !0
- };
- var pM = [];
- Gn.prototype.getBoundingRect = function() {
- if (!this._rect) {
- for (var t = new ue(1 / 0, 1 / 0, -1 / 0, -1 / 0), e = 0; e < this._displayables.length; e++) {
- var i = this._displayables[e],
- n = i.getBoundingRect().clone();
- i.needLocalTransform() && n.applyTransform(i.getLocalTransform(pM)), t.union(n)
- }
- this._rect = t
- }
- return this._rect
- }, Gn.prototype.contain = function(t, e) {
- var i = this.transformCoordToLocal(t, e);
- if (this.getBoundingRect().contain(i[0], i[1]))
- for (var n = 0; n < this._displayables.length; n++)
- if (this._displayables[n].contain(t, e)) return !0;
- return !1
- }, u(Gn, ui);
- var gM = Math.round,
- mM = Math.max,
- vM = Math.min,
- yM = {},
- xM = function(t, e) {
- for (var i = [], n = t.length, o = 0; o < n; o++) {
- var a = t[o];
- a.path || a.createPathProxy(), a.__dirtyPath && a.buildPath(a.path, a.shape, !0), i.push(a.path)
- }
- var r = new kn(e);
- return r.createPathProxy(), r.buildPath = function(t) {
- t.appendPath(i);
- var e = t.getContext();
- e && t.rebuildPath(e)
- }, r
- },
- _M = R(),
- wM = 0,
- bM = (Object.freeze || Object)({
- extendShape: Fn,
- extendPath: function(t, e) {
- return Rn(t, e)
- },
- makePath: Wn,
- makeImage: Hn,
- mergePath: xM,
- resizePath: Un,
- subPixelOptimizeLine: Xn,
- subPixelOptimizeRect: jn,
- subPixelOptimize: Yn,
- setElementHoverStyle: no,
- isInEmphasis: oo,
- setHoverStyle: uo,
- setAsHoverStyleTrigger: ho,
- setLabelStyle: co,
- setTextStyle: fo,
- setText: function(t, e, i) {
- var n, o = {
- isRectText: !0
- };
- !1 === i ? n = !0 : o.autoColor = i, po(t, e, o, n)
- },
- getFont: _o,
- updateProps: bo,
- initProps: So,
- getTransform: Mo,
- applyTransform: Io,
- transformDirection: To,
- groupTransition: Ao,
- clipPointsByRect: Do,
- clipRectByRect: function(t, e) {
- var i = mM(t.x, e.x),
- n = vM(t.x + t.width, e.x + e.width),
- o = mM(t.y, e.y),
- a = vM(t.y + t.height, e.y + e.height);
- if (n >= i && a >= o) return {
- x: i,
- y: o,
- width: n - i,
- height: a - o
- }
- },
- createIcon: Co,
- Group: Zw,
- Image: hi,
- Text: qS,
- Circle: KS,
- Sector: QS,
- Ring: tM,
- Polygon: nM,
- Polyline: oM,
- Rect: aM,
- Line: rM,
- BezierCurve: lM,
- Arc: uM,
- IncrementalDisplayable: Gn,
- CompoundPath: hM,
- LinearGradient: dM,
- RadialGradient: fM,
- BoundingRect: ue
- }),
- SM = ["textStyle", "color"],
- MM = {
- getTextColor: function(t) {
- var e = this.ecModel;
- return this.getShallow("color") || (!t && e ? e.get(SM) : null)
- },
- getFont: function() {
- return _o({
- fontStyle: this.getShallow("fontStyle"),
- fontWeight: this.getShallow("fontWeight"),
- fontSize: this.getShallow("fontSize"),
- fontFamily: this.getShallow("fontFamily")
- }, this.ecModel)
- },
- getTextRect: function(t) {
- return De(t, this.getFont(), this.getShallow("align"), this.getShallow("verticalAlign") || this.getShallow(
- "baseline"), this.getShallow("padding"), this.getShallow("rich"), this.getShallow("truncateText"))
- }
- },
- IM = Wb([
- ["fill", "color"],
- ["stroke", "borderColor"],
- ["lineWidth", "borderWidth"],
- ["opacity"],
- ["shadowBlur"],
- ["shadowOffsetX"],
- ["shadowOffsetY"],
- ["shadowColor"],
- ["textPosition"],
- ["textAlign"]
- ]),
- TM = {
- getItemStyle: function(t, e) {
- var i = IM(this, t, e),
- n = this.getBorderLineDash();
- return n && (i.lineDash = n), i
- },
- getBorderLineDash: function() {
- var t = this.get("borderType");
- return "solid" === t || null == t ? null : "dashed" === t ? [5, 5] : [1, 1]
- }
- },
- AM = h,
- DM = Bi();
- Lo.prototype = {
- constructor: Lo,
- init: null,
- mergeOption: function(t) {
- n(this.option, t, !0)
- },
- get: function(t, e) {
- return null == t ? this.option : ko(this.option, this.parsePath(t), !e && Po(this, t))
- },
- getShallow: function(t, e) {
- var i = this.option,
- n = null == i ? i : i[t],
- o = !e && Po(this, t);
- return null == n && o && (n = o.getShallow(t)), n
- },
- getModel: function(t, e) {
- var i, n = null == t ? this.option : ko(this.option, t = this.parsePath(t));
- return e = e || (i = Po(this, t)) && i.getModel(t), new Lo(n, e, this.ecModel)
- },
- isEmpty: function() {
- return null == this.option
- },
- restoreData: function() {},
- clone: function() {
- return new(0, this.constructor)(i(this.option))
- },
- setReadOnly: function(t) {},
- parsePath: function(t) {
- return "string" == typeof t && (t = t.split(".")), t
- },
- customizeGetParent: function(t) {
- DM(this).getParent = t
- },
- isAnimationEnabled: function() {
- if (!z_.node) {
- if (null != this.option.animation) return !!this.option.animation;
- if (this.parentModel) return this.parentModel.isAnimationEnabled()
- }
- }
- }, Xi(Lo), ji(Lo), AM(Lo, Zb), AM(Lo, Xb), AM(Lo, MM), AM(Lo, TM);
- var CM = 0,
- LM = 1e-4,
- kM = 9007199254740991,
- PM =
- /^(?:(\d{4})(?:[-\/](\d{1,2})(?:[-\/](\d{1,2})(?:[T ](\d{1,2})(?::(\d\d)(?::(\d\d)(?:[.,](\d+))?)?)?(Z|[\+\-]\d\d:?\d\d)?)?)?)?)?$/,
- NM = (Object.freeze || Object)({
- linearMap: Eo,
- parsePercent: Ro,
- round: zo,
- asc: Bo,
- getPrecision: Vo,
- getPrecisionSafe: Go,
- getPixelPrecision: Fo,
- getPercentWithPrecision: Wo,
- MAX_SAFE_INTEGER: kM,
- remRadian: Ho,
- isRadianAroundZero: Zo,
- parseDate: Uo,
- quantity: Xo,
- nice: Yo,
- quantile: function(t, e) {
- var i = (t.length - 1) * e + 1,
- n = Math.floor(i),
- o = +t[n - 1],
- a = i - n;
- return a ? o + a * (t[n] - o) : o
- },
- reformIntervals: qo,
- isNumeric: Ko
- }),
- OM = L,
- EM = /([&<>"'])/g,
- RM = {
- "&": "&",
- "<": "<",
- ">": ">",
- '"': """,
- "'": "'"
- },
- zM = ["a", "b", "c", "d", "e", "f", "g"],
- BM = function(t, e) {
- return "{" + t + (null == e ? "" : e) + "}"
- },
- VM = Oe,
- GM = De,
- FM = (Object.freeze || Object)({
- addCommas: $o,
- toCamelCase: Jo,
- normalizeCssArray: OM,
- encodeHTML: Qo,
- formatTpl: ta,
- formatTplSimple: ea,
- getTooltipMarker: ia,
- formatTime: oa,
- capitalFirst: aa,
- truncateText: VM,
- getTextRect: GM
- }),
- WM = d,
- HM = ["left", "right", "top", "bottom", "width", "height"],
- ZM = [
- ["width", "left", "right"],
- ["height", "top", "bottom"]
- ],
- UM = ra,
- XM = (v(ra, "vertical"), v(ra, "horizontal"), {
- getBoxLayoutParams: function() {
- return {
- left: this.get("left"),
- top: this.get("top"),
- right: this.get("right"),
- bottom: this.get("bottom"),
- width: this.get("width"),
- height: this.get("height")
- }
- }
- }),
- jM = Bi(),
- YM = Lo.extend({
- type: "component",
- id: "",
- name: "",
- mainType: "",
- subType: "",
- componentIndex: 0,
- defaultOption: null,
- ecModel: null,
- dependentModels: [],
- uid: null,
- layoutMode: null,
- $constructor: function(t, e, i, n) {
- Lo.call(this, t, e, i, n), this.uid = No("ec_cpt_model")
- },
- init: function(t, e, i, n) {
- this.mergeDefaultAndTheme(t, i)
- },
- mergeDefaultAndTheme: function(t, e) {
- var i = this.layoutMode,
- o = i ? da(t) : {};
- n(t, e.getTheme().get(this.mainType)), n(t, this.getDefaultOption()), i && ca(t, o, i)
- },
- mergeOption: function(t, e) {
- n(this.option, t, !0);
- var i = this.layoutMode;
- i && ca(this.option, t, i)
- },
- optionUpdated: function(t, e) {},
- getDefaultOption: function() {
- var t = jM(this);
- if (!t.defaultOption) {
- for (var e = [], i = this.constructor; i;) {
- var o = i.prototype.defaultOption;
- o && e.push(o), i = i.superClass
- }
- for (var a = {}, r = e.length - 1; r >= 0; r--) a = n(a, e[r], !0);
- t.defaultOption = a
- }
- return t.defaultOption
- },
- getReferringComponents: function(t) {
- return this.ecModel.queryComponents({
- mainType: t,
- index: this.get(t + "Index", !0),
- id: this.get(t + "Id", !0)
- })
- }
- });
- Ki(YM, {
- registerWhenExtend: !0
- }),
- function(t) {
- var e = {};
- t.registerSubTypeDefaulter = function(t, i) {
- t = Zi(t), e[t.main] = i
- }, t.determineSubType = function(i, n) {
- var o = n.type;
- if (!o) {
- var a = Zi(i).main;
- t.hasSubTypes(i) && e[a] && (o = e[a](n))
- }
- return o
- }
- }(YM),
- function(t, e) {
- function i(t) {
- var i = {},
- a = [];
- return d(t, function(r) {
- var s = n(i, r),
- u = o(s.originalDeps = e(r), t);
- s.entryCount = u.length, 0 === s.entryCount && a.push(r), d(u, function(t) {
- l(s.predecessor, t) < 0 && s.predecessor.push(t);
- var e = n(i, t);
- l(e.successor, t) < 0 && e.successor.push(r)
- })
- }), {
- graph: i,
- noEntryList: a
- }
- }
- function n(t, e) {
- return t[e] || (t[e] = {
- predecessor: [],
- successor: []
- }), t[e]
- }
- function o(t, e) {
- var i = [];
- return d(t, function(t) {
- l(e, t) >= 0 && i.push(t)
- }), i
- }
- t.topologicalTravel = function(t, e, n, o) {
- function a(t) {
- s[t].entryCount--, 0 === s[t].entryCount && l.push(t)
- }
- if (t.length) {
- var r = i(e),
- s = r.graph,
- l = r.noEntryList,
- u = {};
- for (d(t, function(t) {
- u[t] = !0
- }); l.length;) {
- var h = l.pop(),
- c = s[h],
- f = !!u[h];
- f && (n.call(o, h, c.originalDeps.slice()), delete u[h]), d(c.successor, f ? function(t) {
- u[t] = !0, a(t)
- } : a)
- }
- d(u, function() {
- throw new Error("Circle dependency may exists")
- })
- }
- }
- }(YM, function(t) {
- var e = [];
- return d(YM.getClassesByMainType(t), function(t) {
- e = e.concat(t.prototype.dependencies || [])
- }), e = f(e, function(t) {
- return Zi(t).main
- }), "dataset" !== t && l(e, "dataset") <= 0 && e.unshift("dataset"), e
- }), h(YM, XM);
- var qM = "";
- "undefined" != typeof navigator && (qM = navigator.platform || "");
- var KM = {
- color: ["#c23531", "#2f4554", "#61a0a8", "#d48265", "#91c7ae", "#749f83", "#ca8622", "#bda29a", "#6e7074",
- "#546570", "#c4ccd3"
- ],
- gradientColor: ["#f6efa6", "#d88273", "#bf444c"],
- textStyle: {
- fontFamily: qM.match(/^Win/) ? "Microsoft YaHei" : "sans-serif",
- fontSize: 12,
- fontStyle: "normal",
- fontWeight: "normal"
- },
- blendMode: null,
- animation: "auto",
- animationDuration: 1e3,
- animationDurationUpdate: 300,
- animationEasing: "exponentialOut",
- animationEasingUpdate: "cubicOut",
- animationThreshold: 2e3,
- progressiveThreshold: 3e3,
- progressive: 400,
- hoverLayerThreshold: 3e3,
- useUTC: !1
- },
- $M = Bi(),
- JM = {
- clearColorPalette: function() {
- $M(this).colorIdx = 0, $M(this).colorNameMap = {}
- },
- getColorFromPalette: function(t, e, i) {
- var n = $M(e = e || this),
- o = n.colorIdx || 0,
- a = n.colorNameMap = n.colorNameMap || {};
- if (a.hasOwnProperty(t)) return a[t];
- var r = Di(this.get("color", !0)),
- s = this.get("colorLayer", !0),
- l = null != i && s ? pa(s, i) : r;
- if ((l = l || r) && l.length) {
- var u = l[o];
- return t && (a[t] = u), n.colorIdx = (o + 1) % l.length, u
- }
- }
- },
- QM = {
- cartesian2d: function(t, e, i, n) {
- var o = t.getReferringComponents("xAxis")[0],
- a = t.getReferringComponents("yAxis")[0];
- e.coordSysDims = ["x", "y"], i.set("x", o), i.set("y", a), ma(o) && (n.set("x", o), e.firstCategoryDimIndex = 0),
- ma(a) && (n.set("y", a), e.firstCategoryDimIndex = 1)
- },
- singleAxis: function(t, e, i, n) {
- var o = t.getReferringComponents("singleAxis")[0];
- e.coordSysDims = ["single"], i.set("single", o), ma(o) && (n.set("single", o), e.firstCategoryDimIndex = 0)
- },
- polar: function(t, e, i, n) {
- var o = t.getReferringComponents("polar")[0],
- a = o.findAxisModel("radiusAxis"),
- r = o.findAxisModel("angleAxis");
- e.coordSysDims = ["radius", "angle"], i.set("radius", a), i.set("angle", r), ma(a) && (n.set("radius", a), e.firstCategoryDimIndex =
- 0), ma(r) && (n.set("angle", r), e.firstCategoryDimIndex = 1)
- },
- geo: function(t, e, i, n) {
- e.coordSysDims = ["lng", "lat"]
- },
- parallel: function(t, e, i, n) {
- var o = t.ecModel,
- a = o.getComponent("parallel", t.get("parallelIndex")),
- r = e.coordSysDims = a.dimensions.slice();
- d(a.parallelAxisIndex, function(t, a) {
- var s = o.getComponent("parallelAxis", t),
- l = r[a];
- i.set(l, s), ma(s) && null == e.firstCategoryDimIndex && (n.set(l, s), e.firstCategoryDimIndex = a)
- })
- }
- },
- tI = "original",
- eI = "arrayRows",
- iI = "objectRows",
- nI = "keyedColumns",
- oI = "unknown",
- aI = "typedArray",
- rI = "column",
- sI = "row";
- va.seriesDataToSource = function(t) {
- return new va({
- data: t,
- sourceFormat: S(t) ? aI : tI,
- fromDataset: !1
- })
- }, ji(va);
- var lI = Bi(),
- uI = "\0_ec_inner",
- hI = Lo.extend({
- init: function(t, e, i, n) {
- i = i || {}, this.option = null, this._theme = new Lo(i), this._optionManager = n
- },
- setOption: function(t, e) {
- k(!(uI in t), "please use chart.getOption()"), this._optionManager.setOption(t, e), this.resetOption(null)
- },
- resetOption: function(t) {
- var e = !1,
- i = this._optionManager;
- if (!t || "recreate" === t) {
- var n = i.mountOption("recreate" === t);
- this.option && "recreate" !== t ? (this.restoreData(), this.mergeOption(n)) : Pa.call(this, n), e = !0
- }
- if ("timeline" !== t && "media" !== t || this.restoreData(), !t || "recreate" === t || "timeline" === t) {
- var o = i.getTimelineOption(this);
- o && (this.mergeOption(o), e = !0)
- }
- if (!t || "recreate" === t || "media" === t) {
- var a = i.getMediaOption(this, this._api);
- a.length && d(a, function(t) {
- this.mergeOption(t, e = !0)
- }, this)
- }
- return e
- },
- mergeOption: function(t) {
- var e = this.option,
- o = this._componentsMap,
- r = [];
- _a(this), d(t, function(t, o) {
- null != t && (YM.hasClass(o) ? o && r.push(o) : e[o] = null == e[o] ? i(t) : n(e[o], t, !0))
- }), YM.topologicalTravel(r, YM.getAllClassMainTypes(), function(i, n) {
- var r = Di(t[i]),
- s = Pi(o.get(i), r);
- Ni(s), d(s, function(t, e) {
- var n = t.option;
- w(n) && (t.keyInfo.mainType = i, t.keyInfo.subType = Oa(i, n, t.exist))
- });
- var l = Na(o, n);
- e[i] = [], o.set(i, []), d(s, function(t, n) {
- var r = t.exist,
- s = t.option;
- if (k(w(s) || r, "Empty component definition"), s) {
- var u = YM.getClass(i, t.keyInfo.subType, !0);
- if (r && r instanceof u) r.name = t.keyInfo.name, r.mergeOption(s, this), r.optionUpdated(s, !1);
- else {
- var h = a({
- dependentModels: l,
- componentIndex: n
- }, t.keyInfo);
- a(r = new u(s, this, this, h), h), r.init(s, this, this, h), r.optionUpdated(null, !0)
- }
- } else r.mergeOption({}, this), r.optionUpdated({}, !1);
- o.get(i)[n] = r, e[i][n] = r.option
- }, this), "series" === i && Ea(this, o.get("series"))
- }, this), this._seriesIndicesMap = R(this._seriesIndices = this._seriesIndices || [])
- },
- getOption: function() {
- var t = i(this.option);
- return d(t, function(e, i) {
- if (YM.hasClass(i)) {
- for (var n = (e = Di(e)).length - 1; n >= 0; n--) Ei(e[n]) && e.splice(n, 1);
- t[i] = e
- }
- }), delete t[uI], t
- },
- getTheme: function() {
- return this._theme
- },
- getComponent: function(t, e) {
- var i = this._componentsMap.get(t);
- if (i) return i[e || 0]
- },
- queryComponents: function(t) {
- var e = t.mainType;
- if (!e) return [];
- var i = t.index,
- n = t.id,
- o = t.name,
- a = this._componentsMap.get(e);
- if (!a || !a.length) return [];
- var r;
- if (null != i) y(i) || (i = [i]), r = g(f(i, function(t) {
- return a[t]
- }), function(t) {
- return !!t
- });
- else if (null != n) {
- var s = y(n);
- r = g(a, function(t) {
- return s && l(n, t.id) >= 0 || !s && t.id === n
- })
- } else if (null != o) {
- var u = y(o);
- r = g(a, function(t) {
- return u && l(o, t.name) >= 0 || !u && t.name === o
- })
- } else r = a.slice();
- return Ra(r, t)
- },
- findComponents: function(t) {
- var e = t.query,
- i = t.mainType,
- n = function(t) {
- var e = i + "Index",
- n = i + "Id",
- o = i + "Name";
- return !t || null == t[e] && null == t[n] && null == t[o] ? null : {
- mainType: i,
- index: t[e],
- id: t[n],
- name: t[o]
- }
- }(e);
- return function(e) {
- return t.filter ? g(e, t.filter) : e
- }(Ra(n ? this.queryComponents(n) : this._componentsMap.get(i), t))
- },
- eachComponent: function(t, e, i) {
- var n = this._componentsMap;
- "function" == typeof t ? (i = e, e = t, n.each(function(t, n) {
- d(t, function(t, o) {
- e.call(i, n, t, o)
- })
- })) : _(t) ? d(n.get(t), e, i) : w(t) && d(this.findComponents(t), e, i)
- },
- getSeriesByName: function(t) {
- return g(this._componentsMap.get("series"), function(e) {
- return e.name === t
- })
- },
- getSeriesByIndex: function(t) {
- return this._componentsMap.get("series")[t]
- },
- getSeriesByType: function(t) {
- return g(this._componentsMap.get("series"), function(e) {
- return e.subType === t
- })
- },
- getSeries: function() {
- return this._componentsMap.get("series").slice()
- },
- getSeriesCount: function() {
- return this._componentsMap.get("series").length
- },
- eachSeries: function(t, e) {
- d(this._seriesIndices, function(i) {
- var n = this._componentsMap.get("series")[i];
- t.call(e, n, i)
- }, this)
- },
- eachRawSeries: function(t, e) {
- d(this._componentsMap.get("series"), t, e)
- },
- eachSeriesByType: function(t, e, i) {
- d(this._seriesIndices, function(n) {
- var o = this._componentsMap.get("series")[n];
- o.subType === t && e.call(i, o, n)
- }, this)
- },
- eachRawSeriesByType: function(t, e, i) {
- return d(this.getSeriesByType(t), e, i)
- },
- isSeriesFiltered: function(t) {
- return null == this._seriesIndicesMap.get(t.componentIndex)
- },
- getCurrentSeriesIndices: function() {
- return (this._seriesIndices || []).slice()
- },
- filterSeries: function(t, e) {
- Ea(this, g(this._componentsMap.get("series"), t, e))
- },
- restoreData: function(t) {
- var e = this._componentsMap;
- Ea(this, e.get("series"));
- var i = [];
- e.each(function(t, e) {
- i.push(e)
- }), YM.topologicalTravel(i, YM.getAllClassMainTypes(), function(i, n) {
- d(e.get(i), function(e) {
- ("series" !== i || !La(e, t)) && e.restoreData()
- })
- })
- }
- });
- h(hI, JM);
- var cI = ["getDom", "getZr", "getWidth", "getHeight", "getDevicePixelRatio", "dispatchAction", "isDisposed", "on",
- "off", "getDataURL", "getConnectedDataURL", "getModel", "getOption", "getViewOfComponentModel",
- "getViewOfSeriesModel"
- ],
- dI = {};
- Ba.prototype = {
- constructor: Ba,
- create: function(t, e) {
- var i = [];
- d(dI, function(n, o) {
- var a = n.create(t, e);
- i = i.concat(a || [])
- }), this._coordinateSystems = i
- },
- update: function(t, e) {
- d(this._coordinateSystems, function(i) {
- i.update && i.update(t, e)
- })
- },
- getCoordinateSystems: function() {
- return this._coordinateSystems.slice()
- }
- }, Ba.register = function(t, e) {
- dI[t] = e
- }, Ba.get = function(t) {
- return dI[t]
- };
- var fI = d,
- pI = i,
- gI = f,
- mI = n,
- vI = /^(min|max)?(.+)$/;
- Va.prototype = {
- constructor: Va,
- setOption: function(t, e) {
- t && d(Di(t.series), function(t) {
- t && t.data && S(t.data) && N(t.data)
- }), t = pI(t, !0);
- var i = this._optionBackup,
- n = Ga.call(this, t, e, !i);
- this._newBaseOption = n.baseOption, i ? (Za(i.baseOption, n.baseOption), n.timelineOptions.length && (i.timelineOptions =
- n.timelineOptions), n.mediaList.length && (i.mediaList = n.mediaList), n.mediaDefault && (i.mediaDefault = n.mediaDefault)) :
- this._optionBackup = n
- },
- mountOption: function(t) {
- var e = this._optionBackup;
- return this._timelineOptions = gI(e.timelineOptions, pI), this._mediaList = gI(e.mediaList, pI), this._mediaDefault =
- pI(e.mediaDefault), this._currentMediaIndices = [], pI(t ? e.baseOption : this._newBaseOption)
- },
- getTimelineOption: function(t) {
- var e, i = this._timelineOptions;
- if (i.length) {
- var n = t.getComponent("timeline");
- n && (e = pI(i[n.getCurrentIndex()], !0))
- }
- return e
- },
- getMediaOption: function(t) {
- var e = this._api.getWidth(),
- i = this._api.getHeight(),
- n = this._mediaList,
- o = this._mediaDefault,
- a = [],
- r = [];
- if (!n.length && !o) return r;
- for (var s = 0, l = n.length; s < l; s++) Fa(n[s].query, e, i) && a.push(s);
- return !a.length && o && (a = [-1]), a.length && !Ha(a, this._currentMediaIndices) && (r = gI(a, function(t) {
- return pI(-1 === t ? o.option : n[t].option)
- })), this._currentMediaIndices = a, r
- }
- };
- var yI = d,
- xI = w,
- _I = ["areaStyle", "lineStyle", "nodeStyle", "linkStyle", "chordStyle", "label", "labelLine"],
- wI = function(t, e) {
- yI($a(t.series), function(t) {
- xI(t) && Ka(t)
- });
- var i = ["xAxis", "yAxis", "radiusAxis", "angleAxis", "singleAxis", "parallelAxis", "radar"];
- e && i.push("valueAxis", "categoryAxis", "logAxis", "timeAxis"), yI(i, function(e) {
- yI($a(t[e]), function(t) {
- t && (Ya(t, "axisLabel"), Ya(t.axisPointer, "label"))
- })
- }), yI($a(t.parallel), function(t) {
- var e = t && t.parallelAxisDefault;
- Ya(e, "axisLabel"), Ya(e && e.axisPointer, "label")
- }), yI($a(t.calendar), function(t) {
- Xa(t, "itemStyle"), Ya(t, "dayLabel"), Ya(t, "monthLabel"), Ya(t, "yearLabel")
- }), yI($a(t.radar), function(t) {
- Ya(t, "name")
- }), yI($a(t.geo), function(t) {
- xI(t) && (qa(t), yI($a(t.regions), function(t) {
- qa(t)
- }))
- }), yI($a(t.timeline), function(t) {
- qa(t), Xa(t, "label"), Xa(t, "itemStyle"), Xa(t, "controlStyle", !0);
- var e = t.data;
- y(e) && d(e, function(t) {
- w(t) && (Xa(t, "label"), Xa(t, "itemStyle"))
- })
- }), yI($a(t.toolbox), function(t) {
- Xa(t, "iconStyle"), yI(t.feature, function(t) {
- Xa(t, "iconStyle")
- })
- }), Ya(Ja(t.axisPointer), "label"), Ya(Ja(t.tooltip).axisPointer, "label")
- },
- bI = [
- ["x", "left"],
- ["y", "top"],
- ["x2", "right"],
- ["y2", "bottom"]
- ],
- SI = ["grid", "geo", "parallel", "legend", "toolbox", "title", "visualMap", "dataZoom", "timeline"],
- MI = function(t, e) {
- wI(t, e), t.series = Di(t.series), d(t.series, function(t) {
- if (w(t)) {
- var e = t.type;
- if ("pie" !== e && "gauge" !== e || null != t.clockWise && (t.clockwise = t.clockWise), "gauge" === e) {
- var i = Qa(t, "pointer.color");
- null != i && tr(t, "itemStyle.normal.color", i)
- }
- er(t)
- }
- }), t.dataRange && (t.visualMap = t.dataRange), d(SI, function(e) {
- var i = t[e];
- i && (y(i) || (i = [i]), d(i, function(t) {
- er(t)
- }))
- })
- },
- II = nr.prototype;
- II.pure = !1, II.persistent = !0, II.getSource = function() {
- return this._source
- };
- var TI = {
- arrayRows_column: {
- pure: !0,
- count: function() {
- return Math.max(0, this._data.length - this._source.startIndex)
- },
- getItem: function(t) {
- return this._data[t + this._source.startIndex]
- },
- appendData: rr
- },
- arrayRows_row: {
- pure: !0,
- count: function() {
- var t = this._data[0];
- return t ? Math.max(0, t.length - this._source.startIndex) : 0
- },
- getItem: function(t) {
- t += this._source.startIndex;
- for (var e = [], i = this._data, n = 0; n < i.length; n++) {
- var o = i[n];
- e.push(o ? o[t] : null)
- }
- return e
- },
- appendData: function() {
- throw new Error('Do not support appendData when set seriesLayoutBy: "row".')
- }
- },
- objectRows: {
- pure: !0,
- count: or,
- getItem: ar,
- appendData: rr
- },
- keyedColumns: {
- pure: !0,
- count: function() {
- var t = this._source.dimensionsDefine[0].name,
- e = this._data[t];
- return e ? e.length : 0
- },
- getItem: function(t) {
- for (var e = [], i = this._source.dimensionsDefine, n = 0; n < i.length; n++) {
- var o = this._data[i[n].name];
- e.push(o ? o[t] : null)
- }
- return e
- },
- appendData: function(t) {
- var e = this._data;
- d(t, function(t, i) {
- for (var n = e[i] || (e[i] = []), o = 0; o < (t || []).length; o++) n.push(t[o])
- })
- }
- },
- original: {
- count: or,
- getItem: ar,
- appendData: rr
- },
- typedArray: {
- persistent: !1,
- pure: !0,
- count: function() {
- return this._data ? this._data.length / this._dimSize : 0
- },
- getItem: function(t, e) {
- t -= this._offset, e = e || [];
- for (var i = this._dimSize * t, n = 0; n < this._dimSize; n++) e[n] = this._data[i + n];
- return e
- },
- appendData: function(t) {
- this._data = t
- },
- clean: function() {
- this._offset += this.count(), this._data = null
- }
- }
- },
- AI = {
- arrayRows: sr,
- objectRows: function(t, e, i, n) {
- return null != i ? t[n] : t
- },
- keyedColumns: sr,
- original: function(t, e, i, n) {
- var o = Li(t);
- return null != i && o instanceof Array ? o[i] : o
- },
- typedArray: sr
- },
- DI = {
- arrayRows: lr,
- objectRows: function(t, e, i, n) {
- return ur(t[e], this._dimensionInfos[e])
- },
- keyedColumns: lr,
- original: function(t, e, i, n) {
- var o = t && (null == t.value ? t : t.value);
- return !this._rawData.pure && ki(t) && (this.hasItemOption = !0), ur(o instanceof Array ? o[n] : o, this._dimensionInfos[
- e])
- },
- typedArray: function(t, e, i, n) {
- return t[n]
- }
- },
- CI = /\{@(.+?)\}/g,
- LI = {
- getDataParams: function(t, e) {
- var i = this.getData(e),
- n = this.getRawValue(t, e),
- o = i.getRawIndex(t),
- a = i.getName(t),
- r = i.getRawDataItem(t),
- s = i.getItemVisual(t, "color"),
- l = this.ecModel.getComponent("tooltip"),
- u = Hi(l && l.get("renderMode")),
- h = this.mainType,
- c = "series" === h;
- return {
- componentType: h,
- componentSubType: this.subType,
- componentIndex: this.componentIndex,
- seriesType: c ? this.subType : null,
- seriesIndex: this.seriesIndex,
- seriesId: c ? this.id : null,
- seriesName: c ? this.name : null,
- name: a,
- dataIndex: o,
- data: r,
- dataType: e,
- value: n,
- color: s,
- marker: ia({
- color: s,
- renderMode: u
- }),
- $vars: ["seriesName", "name", "value"]
- }
- },
- getFormattedLabel: function(t, e, i, n, o) {
- e = e || "normal";
- var a = this.getData(i),
- r = a.getItemModel(t),
- s = this.getDataParams(t, i);
- null != n && s.value instanceof Array && (s.value = s.value[n]);
- var l = r.get("normal" === e ? [o || "label", "formatter"] : [e, o || "label", "formatter"]);
- return "function" == typeof l ? (s.status = e, l(s)) : "string" == typeof l ? ta(l, s).replace(CI, function(e, i) {
- var n = i.length;
- return "[" === i.charAt(0) && "]" === i.charAt(n - 1) && (i = +i.slice(1, n - 1)), hr(a, t, i)
- }) : void 0
- },
- getRawValue: function(t, e) {
- return hr(this.getData(e), t)
- },
- formatTooltip: function() {}
- },
- kI = fr.prototype;
- kI.perform = function(t) {
- function e(t) {
- return !(t >= 1) && (t = 1), t
- }
- var i = this._upstream,
- n = t && t.skip;
- if (this._dirty && i) {
- var o = this.context;
- o.data = o.outputData = i.context.outputData
- }
- this.__pipeline && (this.__pipeline.currentTask = this);
- var a;
- this._plan && !n && (a = this._plan(this.context));
- var r = e(this._modBy),
- s = this._modDataCount || 0,
- l = e(t && t.modBy),
- u = t && t.modDataCount || 0;
- r === l && s === u || (a = "reset");
- var h;
- (this._dirty || "reset" === a) && (this._dirty = !1, h = gr(this, n)), this._modBy = l, this._modDataCount = u;
- var c = t && t.step;
- if (this._dueEnd = i ? i._outputDueEnd : this._count ? this._count(this.context) : 1 / 0, this._progress) {
- var d = this._dueIndex,
- f = Math.min(null != c ? this._dueIndex + c : 1 / 0, this._dueEnd);
- if (!n && (h || d < f)) {
- var p = this._progress;
- if (y(p))
- for (var g = 0; g < p.length; g++) pr(this, p[g], d, f, l, u);
- else pr(this, p, d, f, l, u)
- }
- this._dueIndex = f;
- var m = null != this._settedOutputEnd ? this._settedOutputEnd : f;
- this._outputDueEnd = m
- } else this._dueIndex = this._outputDueEnd = null != this._settedOutputEnd ? this._settedOutputEnd : this._dueEnd;
- return this.unfinished()
- };
- var PI = function() {
- function t() {
- return n < i ? n++ : null
- }
- function e() {
- var t = n % r * o + Math.ceil(n / r),
- e = n >= i ? null : t < a ? t : n;
- return n++, e
- }
- var i, n, o, a, r, s = {
- reset: function(l, u, h, c) {
- n = l, i = u, o = h, a = c, r = Math.ceil(a / o), s.next = o > 1 && a > 0 ? e : t
- }
- };
- return s
- }();
- kI.dirty = function() {
- this._dirty = !0, this._onDirty && this._onDirty(this.context)
- }, kI.unfinished = function() {
- return this._progress && this._dueIndex < this._dueEnd
- }, kI.pipe = function(t) {
- (this._downstream !== t || this._dirty) && (this._downstream = t, t._upstream = this, t.dirty())
- }, kI.dispose = function() {
- this._disposed || (this._upstream && (this._upstream._downstream = null), this._downstream && (this._downstream._upstream =
- null), this._dirty = !1, this._disposed = !0)
- }, kI.getUpstream = function() {
- return this._upstream
- }, kI.getDownstream = function() {
- return this._downstream
- }, kI.setOutputEnd = function(t) {
- this._outputDueEnd = this._settedOutputEnd = t
- };
- var NI = Bi(),
- OI = YM.extend({
- type: "series.__base__",
- seriesIndex: 0,
- coordinateSystem: null,
- defaultOption: null,
- legendDataProvider: null,
- visualColorAccessPath: "itemStyle.color",
- layoutMode: null,
- init: function(t, e, i, n) {
- this.seriesIndex = this.componentIndex, this.dataTask = dr({
- count: yr,
- reset: xr
- }), this.dataTask.context = {
- model: this
- }, this.mergeDefaultAndTheme(t, i), wa(this);
- var o = this.getInitialData(t, i);
- wr(o, this), this.dataTask.context.data = o, NI(this).dataBeforeProcessed = o, mr(this)
- },
- mergeDefaultAndTheme: function(t, e) {
- var i = this.layoutMode,
- o = i ? da(t) : {},
- a = this.subType;
- YM.hasClass(a) && (a += "Series"), n(t, e.getTheme().get(this.subType)), n(t, this.getDefaultOption()), Ci(t,
- "label", ["show"]), this.fillDataTextStyle(t.data), i && ca(t, o, i)
- },
- mergeOption: function(t, e) {
- t = n(this.option, t, !0), this.fillDataTextStyle(t.data);
- var i = this.layoutMode;
- i && ca(this.option, t, i), wa(this);
- var o = this.getInitialData(t, e);
- wr(o, this), this.dataTask.dirty(), this.dataTask.context.data = o, NI(this).dataBeforeProcessed = o, mr(this)
- },
- fillDataTextStyle: function(t) {
- if (t && !S(t))
- for (var e = ["show"], i = 0; i < t.length; i++) t[i] && t[i].label && Ci(t[i], "label", e)
- },
- getInitialData: function() {},
- appendData: function(t) {
- this.getRawData().appendData(t.data)
- },
- getData: function(t) {
- var e = Sr(this);
- if (e) {
- var i = e.context.data;
- return null == t ? i : i.getLinkedData(t)
- }
- return NI(this).data
- },
- setData: function(t) {
- var e = Sr(this);
- if (e) {
- var i = e.context;
- i.data !== t && e.modifyOutputEnd && e.setOutputEnd(t.count()), i.outputData = t, e !== this.dataTask && (i.data =
- t)
- }
- NI(this).data = t
- },
- getSource: function() {
- return xa(this)
- },
- getRawData: function() {
- return NI(this).dataBeforeProcessed
- },
- getBaseAxis: function() {
- var t = this.coordinateSystem;
- return t && t.getBaseAxis && t.getBaseAxis()
- },
- formatTooltip: function(t, e, i, n) {
- function o(t) {
- return {
- renderMode: n,
- content: Qo($o(t)),
- style: l
- }
- }
- var a = this,
- r = "html" === (n = n || "html") ? "<br/>" : "\n",
- s = "richText" === n,
- l = {},
- u = 0,
- h = this.getData(),
- c = h.mapDimension("defaultedTooltip", !0),
- f = c.length,
- g = this.getRawValue(t),
- m = y(g),
- v = h.getItemVisual(t, "color");
- w(v) && v.colorStops && (v = (v.colorStops[0] || {}).color), v = v || "transparent";
- var x = (f > 1 || m && !f ? function(i) {
- function o(t, i) {
- var o = h.getDimensionInfo(i);
- if (o && !1 !== o.otherDims.tooltip) {
- var c = o.type,
- d = "sub" + a.seriesIndex + "at" + u,
- p = ia({
- color: v,
- type: "subItem",
- renderMode: n,
- markerId: d
- }),
- g = "string" == typeof p ? p : p.content,
- m = (r ? g + Qo(o.displayName || "-") + ": " : "") + Qo("ordinal" === c ? t + "" : "time" === c ? e ? "" :
- oa("yyyy/MM/dd hh:mm:ss", t) : $o(t));
- m && f.push(m), s && (l[d] = v, ++u)
- }
- }
- var r = p(i, function(t, e, i) {
- var n = h.getDimensionInfo(i);
- return t |= n && !1 !== n.tooltip && null != n.displayName
- }, 0),
- f = [];
- c.length ? d(c, function(e) {
- o(hr(h, t, e), e)
- }) : d(i, o);
- var g = r ? s ? "\n" : "<br/>" : "",
- m = g + f.join(g || ", ");
- return {
- renderMode: n,
- content: m,
- style: l
- }
- }(g) : o(f ? hr(h, t, c[0]) : m ? g[0] : g)).content,
- _ = a.seriesIndex + "at" + u,
- b = ia({
- color: v,
- type: "item",
- renderMode: n,
- markerId: _
- });
- l[_] = v, ++u;
- var S = h.getName(t),
- M = this.name;
- Oi(this) || (M = ""), M = M ? Qo(M) + (e ? ": " : r) : "";
- var I = "string" == typeof b ? b : b.content;
- return {
- html: e ? I + M + x : M + I + (S ? Qo(S) + ": " + x : x),
- markers: l
- }
- },
- isAnimationEnabled: function() {
- if (z_.node) return !1;
- var t = this.getShallow("animation");
- return t && this.getData().count() > this.getShallow("animationThreshold") && (t = !1), t
- },
- restoreData: function() {
- this.dataTask.dirty()
- },
- getColorFromPalette: function(t, e, i) {
- var n = this.ecModel,
- o = JM.getColorFromPalette.call(this, t, e, i);
- return o || (o = n.getColorFromPalette(t, e, i)), o
- },
- coordDimToDataDim: function(t) {
- return this.getRawData().mapDimension(t, !0)
- },
- getProgressive: function() {
- return this.get("progressive")
- },
- getProgressiveThreshold: function() {
- return this.get("progressiveThreshold")
- },
- getAxisTooltipData: null,
- getTooltipPosition: null,
- pipeTask: null,
- preventIncremental: null,
- pipelineContext: null
- });
- h(OI, LI), h(OI, JM);
- var EI = function() {
- this.group = new Zw, this.uid = No("viewComponent")
- };
- EI.prototype = {
- constructor: EI,
- init: function(t, e) {},
- render: function(t, e, i, n) {},
- dispose: function() {},
- filterForExposedEvent: null
- };
- var RI = EI.prototype;
- RI.updateView = RI.updateLayout = RI.updateVisual = function(t, e, i, n) {}, Xi(EI), Ki(EI, {
- registerWhenExtend: !0
- });
- var zI = function() {
- var t = Bi();
- return function(e) {
- var i = t(e),
- n = e.pipelineContext,
- o = i.large,
- a = i.progressiveRender,
- r = i.large = n.large,
- s = i.progressiveRender = n.progressiveRender;
- return !!(o ^ r || a ^ s) && "reset"
- }
- },
- BI = Bi(),
- VI = zI();
- Mr.prototype = {
- type: "chart",
- init: function(t, e) {},
- render: function(t, e, i, n) {},
- highlight: function(t, e, i, n) {
- Tr(t.getData(), n, "emphasis")
- },
- downplay: function(t, e, i, n) {
- Tr(t.getData(), n, "normal")
- },
- remove: function(t, e) {
- this.group.removeAll()
- },
- dispose: function() {},
- incrementalPrepareRender: null,
- incrementalRender: null,
- updateTransform: null,
- filterForExposedEvent: null
- };
- var GI = Mr.prototype;
- GI.updateView = GI.updateLayout = GI.updateVisual = function(t, e, i, n) {
- this.render(t, e, i, n)
- }, Xi(Mr), Ki(Mr, {
- registerWhenExtend: !0
- }), Mr.markUpdateMethod = function(t, e) {
- BI(t).updateMethod = e
- };
- var FI = {
- incrementalPrepareRender: {
- progress: function(t, e) {
- e.view.incrementalRender(t, e.model, e.ecModel, e.api, e.payload)
- }
- },
- render: {
- forceFirstProgress: !0,
- progress: function(t, e) {
- e.view.render(e.model, e.ecModel, e.api, e.payload)
- }
- }
- },
- WI = "\0__throttleOriginMethod",
- HI = "\0__throttleRate",
- ZI = "\0__throttleType",
- UI = {
- createOnAllSeries: !0,
- performRawSeries: !0,
- reset: function(t, e) {
- var i = t.getData(),
- n = (t.visualColorAccessPath || "itemStyle.color").split("."),
- o = t.get(n) || t.getColorFromPalette(t.name, null, e.getSeriesCount());
- if (i.setVisual("color", o), !e.isSeriesFiltered(t)) {
- "function" != typeof o || o instanceof cM || i.each(function(e) {
- i.setItemVisual(e, "color", o(t.getDataParams(e)))
- });
- return {
- dataEach: i.hasItemOption ? function(t, e) {
- var i = t.getItemModel(e).get(n, !0);
- null != i && t.setItemVisual(e, "color", i)
- } : null
- }
- }
- }
- },
- XI = {
- toolbox: {
- brush: {
- title: {
- rect: "矩形选择",
- polygon: "圈选",
- lineX: "横向选择",
- lineY: "纵向选择",
- keep: "保持选择",
- clear: "清除选择"
- }
- },
- dataView: {
- title: "数据视图",
- lang: ["数据视图", "关闭", "刷新"]
- },
- dataZoom: {
- title: {
- zoom: "区域缩放",
- back: "区域缩放还原"
- }
- },
- magicType: {
- title: {
- line: "切换为折线图",
- bar: "切换为柱状图",
- stack: "切换为堆叠",
- tiled: "切换为平铺"
- }
- },
- restore: {
- title: "还原"
- },
- saveAsImage: {
- title: "保存为图片",
- lang: ["右键另存为图片"]
- }
- },
- series: {
- typeNames: {
- pie: "饼图",
- bar: "柱状图",
- line: "折线图",
- scatter: "散点图",
- effectScatter: "涟漪散点图",
- radar: "雷达图",
- tree: "树图",
- treemap: "矩形树图",
- boxplot: "箱型图",
- candlestick: "K线图",
- k: "K线图",
- heatmap: "热力图",
- map: "地图",
- parallel: "平行坐标图",
- lines: "线图",
- graph: "关系图",
- sankey: "桑基图",
- funnel: "漏斗图",
- gauge: "仪表盘图",
- pictorialBar: "象形柱图",
- themeRiver: "主题河流图",
- sunburst: "旭日图"
- }
- },
- aria: {
- general: {
- withTitle: "这是一个关于“{title}”的图表。",
- withoutTitle: "这是一个图表,"
- },
- series: {
- single: {
- prefix: "",
- withName: "图表类型是{seriesType},表示{seriesName}。",
- withoutName: "图表类型是{seriesType}。"
- },
- multiple: {
- prefix: "它由{seriesCount}个图表系列组成。",
- withName: "第{seriesId}个系列是一个表示{seriesName}的{seriesType},",
- withoutName: "第{seriesId}个系列是一个{seriesType},",
- separator: {
- middle: ";",
- end: "。"
- }
- }
- },
- data: {
- allData: "其数据是——",
- partialData: "其中,前{displayCnt}项是——",
- withName: "{name}的数据是{value}",
- withoutName: "{value}",
- separator: {
- middle: ",",
- end: ""
- }
- }
- }
- },
- jI = function(t, e) {
- function i(t, e) {
- if ("string" != typeof t) return t;
- var i = t;
- return d(e, function(t, e) {
- i = i.replace(new RegExp("\\{\\s*" + e + "\\s*\\}", "g"), t)
- }), i
- }
- function n(t) {
- var e = a.get(t);
- if (null == e) {
- for (var i = t.split("."), n = XI.aria, o = 0; o < i.length; ++o) n = n[i[o]];
- return n
- }
- return e
- }
- function o(t) {
- return XI.series.typeNames[t] || "自定义图"
- }
- var a = e.getModel("aria");
- if (a.get("show"))
- if (a.get("description")) t.setAttribute("aria-label", a.get("description"));
- else {
- var r = 0;
- e.eachSeries(function(t, e) {
- ++r
- }, this);
- var s, l = a.get("data.maxCount") || 10,
- u = a.get("series.maxCount") || 10,
- h = Math.min(r, u);
- if (!(r < 1)) {
- var c = function() {
- var t = e.getModel("title").option;
- return t && t.length && (t = t[0]), t && t.text
- }();
- s = c ? i(n("general.withTitle"), {
- title: c
- }) : n("general.withoutTitle");
- var f = [];
- s += i(n(r > 1 ? "series.multiple.prefix" : "series.single.prefix"), {
- seriesCount: r
- }), e.eachSeries(function(t, e) {
- if (e < h) {
- var a, s = t.get("name"),
- u = "series." + (r > 1 ? "multiple" : "single") + ".";
- a = i(a = n(s ? u + "withName" : u + "withoutName"), {
- seriesId: t.seriesIndex,
- seriesName: t.get("name"),
- seriesType: o(t.subType)
- });
- var c = t.getData();
- window.data = c, c.count() > l ? a += i(n("data.partialData"), {
- displayCnt: l
- }) : a += n("data.allData");
- for (var d = [], p = 0; p < c.count(); p++)
- if (p < l) {
- var g = c.getName(p),
- m = hr(c, p);
- d.push(i(n(g ? "data.withName" : "data.withoutName"), {
- name: g,
- value: m
- }))
- } a += d.join(n("data.separator.middle")) + n("data.separator.end"), f.push(a)
- }
- }), s += f.join(n("series.multiple.separator.middle")) + n("series.multiple.separator.end"), t.setAttribute(
- "aria-label", s)
- }
- }
- },
- YI = Math.PI,
- qI = Pr.prototype;
- qI.restoreData = function(t, e) {
- t.restoreData(e), this._stageTaskMap.each(function(t) {
- var e = t.overallTask;
- e && e.dirty()
- })
- }, qI.getPerformArgs = function(t, e) {
- if (t.__pipeline) {
- var i = this._pipelineMap.get(t.__pipeline.id),
- n = i.context,
- o = !e && i.progressiveEnabled && (!n || n.progressiveRender) && t.__idxInPipeline > i.blockIndex ? i.step : null,
- a = n && n.modDataCount;
- return {
- step: o,
- modBy: null != a ? Math.ceil(a / o) : null,
- modDataCount: a
- }
- }
- }, qI.getPipeline = function(t) {
- return this._pipelineMap.get(t)
- }, qI.updateStreamModes = function(t, e) {
- var i = this._pipelineMap.get(t.uid),
- n = t.getData().count(),
- o = i.progressiveEnabled && e.incrementalPrepareRender && n >= i.threshold,
- a = t.get("large") && n >= t.get("largeThreshold"),
- r = "mod" === t.get("progressiveChunkMode") ? n : null;
- t.pipelineContext = i.context = {
- progressiveRender: o,
- modDataCount: r,
- large: a
- }
- }, qI.restorePipelines = function(t) {
- var e = this,
- i = e._pipelineMap = R();
- t.eachSeries(function(t) {
- var n = t.getProgressive(),
- o = t.uid;
- i.set(o, {
- id: o,
- head: null,
- tail: null,
- threshold: t.getProgressiveThreshold(),
- progressiveEnabled: n && !(t.preventIncremental && t.preventIncremental()),
- blockIndex: -1,
- step: Math.round(n || 700),
- count: 0
- }), Zr(e, t, t.dataTask)
- })
- }, qI.prepareStageTasks = function() {
- var t = this._stageTaskMap,
- e = this.ecInstance.getModel(),
- i = this.api;
- d(this._allHandlers, function(n) {
- var o = t.get(n.uid) || t.set(n.uid, []);
- n.reset && Or(this, n, o, e, i), n.overallReset && Er(this, n, o, e, i)
- }, this)
- }, qI.prepareView = function(t, e, i, n) {
- var o = t.renderTask,
- a = o.context;
- a.model = e, a.ecModel = i, a.api = n, o.__block = !t.incrementalPrepareRender, Zr(this, e, o)
- }, qI.performDataProcessorTasks = function(t, e) {
- Nr(this, this._dataProcessorHandlers, t, e, {
- block: !0
- })
- }, qI.performVisualTasks = function(t, e, i) {
- Nr(this, this._visualHandlers, t, e, i)
- }, qI.performSeriesTasks = function(t) {
- var e;
- t.eachSeries(function(t) {
- e |= t.dataTask.perform()
- }), this.unfinished |= e
- }, qI.plan = function() {
- this._pipelineMap.each(function(t) {
- var e = t.tail;
- do {
- if (e.__block) {
- t.blockIndex = e.__idxInPipeline;
- break
- }
- e = e.getUpstream()
- } while (e)
- })
- };
- var KI = qI.updatePayload = function(t, e) {
- "remain" !== e && (t.context.payload = e)
- },
- $I = Wr(0);
- Pr.wrapStageHandler = function(t, e) {
- return x(t) && (t = {
- overallReset: t,
- seriesType: Ur(t)
- }), t.uid = No("stageHandler"), e && (t.visualType = e), t
- };
- var JI, QI = {},
- tT = {};
- Xr(QI, hI), Xr(tT, za), QI.eachSeriesByType = QI.eachRawSeriesByType = function(t) {
- JI = t
- }, QI.eachComponent = function(t) {
- "series" === t.mainType && t.subType && (JI = t.subType)
- };
- var eT = ["#37A2DA", "#32C5E9", "#67E0E3", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#E062AE", "#E690D1",
- "#e7bcf3", "#9d96f5", "#8378EA", "#96BFFF"
- ],
- iT = {
- color: eT,
- colorLayer: [
- ["#37A2DA", "#ffd85c", "#fd7b5f"],
- ["#37A2DA", "#67E0E3", "#FFDB5C", "#ff9f7f", "#E062AE", "#9d96f5"],
- ["#37A2DA", "#32C5E9", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#e7bcf3", "#8378EA", "#96BFFF"], eT
- ]
- },
- nT = ["#dd6b66", "#759aa0", "#e69d87", "#8dc1a9", "#ea7e53", "#eedd78", "#73a373", "#73b9bc", "#7289ab", "#91ca8c",
- "#f49f42"
- ],
- oT = {
- color: nT,
- backgroundColor: "#333",
- tooltip: {
- axisPointer: {
- lineStyle: {
- color: "#eee"
- },
- crossStyle: {
- color: "#eee"
- }
- }
- },
- legend: {
- textStyle: {
- color: "#eee"
- }
- },
- textStyle: {
- color: "#eee"
- },
- title: {
- textStyle: {
- color: "#eee"
- }
- },
- toolbox: {
- iconStyle: {
- normal: {
- borderColor: "#eee"
- }
- }
- },
- dataZoom: {
- textStyle: {
- color: "#eee"
- }
- },
- visualMap: {
- textStyle: {
- color: "#eee"
- }
- },
- timeline: {
- lineStyle: {
- color: "#eee"
- },
- itemStyle: {
- normal: {
- color: nT[1]
- }
- },
- label: {
- normal: {
- textStyle: {
- color: "#eee"
- }
- }
- },
- controlStyle: {
- normal: {
- color: "#eee",
- borderColor: "#eee"
- }
- }
- },
- timeAxis: {
- axisLine: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisTick: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisLabel: {
- textStyle: {
- color: "#eee"
- }
- },
- splitLine: {
- lineStyle: {
- type: "dashed",
- color: "#aaa"
- }
- },
- splitArea: {
- areaStyle: {
- color: "#eee"
- }
- }
- },
- logAxis: {
- axisLine: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisTick: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisLabel: {
- textStyle: {
- color: "#eee"
- }
- },
- splitLine: {
- lineStyle: {
- type: "dashed",
- color: "#aaa"
- }
- },
- splitArea: {
- areaStyle: {
- color: "#eee"
- }
- }
- },
- valueAxis: {
- axisLine: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisTick: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisLabel: {
- textStyle: {
- color: "#eee"
- }
- },
- splitLine: {
- lineStyle: {
- type: "dashed",
- color: "#aaa"
- }
- },
- splitArea: {
- areaStyle: {
- color: "#eee"
- }
- }
- },
- categoryAxis: {
- axisLine: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisTick: {
- lineStyle: {
- color: "#eee"
- }
- },
- axisLabel: {
- textStyle: {
- color: "#eee"
- }
- },
- splitLine: {
- lineStyle: {
- type: "dashed",
- color: "#aaa"
- }
- },
- splitArea: {
- areaStyle: {
- color: "#eee"
- }
- }
- },
- line: {
- symbol: "circle"
- },
- graph: {
- color: nT
- },
- gauge: {
- title: {
- textStyle: {
- color: "#eee"
- }
- }
- },
- candlestick: {
- itemStyle: {
- normal: {
- color: "#FD1050",
- color0: "#0CF49B",
- borderColor: "#FD1050",
- borderColor0: "#0CF49B"
- }
- }
- }
- };
- oT.categoryAxis.splitLine.show = !1, YM.extend({
- type: "dataset",
- defaultOption: {
- seriesLayoutBy: rI,
- sourceHeader: null,
- dimensions: null,
- source: null
- },
- optionUpdated: function() {
- ya(this)
- }
- }), EI.extend({
- type: "dataset"
- });
- var aT = kn.extend({
- type: "ellipse",
- shape: {
- cx: 0,
- cy: 0,
- rx: 0,
- ry: 0
- },
- buildPath: function(t, e) {
- var i = .5522848,
- n = e.cx,
- o = e.cy,
- a = e.rx,
- r = e.ry,
- s = a * i,
- l = r * i;
- t.moveTo(n - a, o), t.bezierCurveTo(n - a, o - l, n - s, o - r, n, o - r), t.bezierCurveTo(n + s, o - r, n + a,
- o - l, n + a, o), t.bezierCurveTo(n + a, o + l, n + s, o + r, n, o + r), t.bezierCurveTo(n - s, o + r, n - a,
- o + l, n - a, o), t.closePath()
- }
- }),
- rT = /[\s,]+/;
- Yr.prototype.parse = function(t, e) {
- e = e || {};
- var i = jr(t);
- if (!i) throw new Error("Illegal svg");
- var n = new Zw;
- this._root = n;
- var o = i.getAttribute("viewBox") || "",
- a = parseFloat(i.getAttribute("width") || e.width),
- r = parseFloat(i.getAttribute("height") || e.height);
- isNaN(a) && (a = null), isNaN(r) && (r = null), Jr(i, n, null, !0);
- for (var s = i.firstChild; s;) this._parseNode(s, n), s = s.nextSibling;
- var l, u;
- if (o) {
- var h = P(o).split(rT);
- h.length >= 4 && (l = {
- x: parseFloat(h[0] || 0),
- y: parseFloat(h[1] || 0),
- width: parseFloat(h[2]),
- height: parseFloat(h[3])
- })
- }
- if (l && null != a && null != r && (u = is(l, a, r), !e.ignoreViewBox)) {
- var c = n;
- (n = new Zw).add(c), c.scale = u.scale.slice(), c.position = u.position.slice()
- }
- return e.ignoreRootClip || null == a || null == r || n.setClipPath(new aM({
- shape: {
- x: 0,
- y: 0,
- width: a,
- height: r
- }
- })), {
- root: n,
- width: a,
- height: r,
- viewBoxRect: l,
- viewBoxTransform: u
- }
- }, Yr.prototype._parseNode = function(t, e) {
- var i = t.nodeName.toLowerCase();
- "defs" === i ? this._isDefine = !0 : "text" === i && (this._isText = !0);
- var n;
- if (this._isDefine) {
- if (r = lT[i]) {
- var o = r.call(this, t),
- a = t.getAttribute("id");
- a && (this._defs[a] = o)
- }
- } else {
- var r = sT[i];
- r && (n = r.call(this, t, e), e.add(n))
- }
- for (var s = t.firstChild; s;) 1 === s.nodeType && this._parseNode(s, n), 3 === s.nodeType && this._isText && this._parseText(
- s, n), s = s.nextSibling;
- "defs" === i ? this._isDefine = !1 : "text" === i && (this._isText = !1)
- }, Yr.prototype._parseText = function(t, e) {
- if (1 === t.nodeType) {
- var i = t.getAttribute("dx") || 0,
- n = t.getAttribute("dy") || 0;
- this._textX += parseFloat(i), this._textY += parseFloat(n)
- }
- var o = new qS({
- style: {
- text: t.textContent,
- transformText: !0
- },
- position: [this._textX || 0, this._textY || 0]
- });
- Kr(e, o), Jr(t, o, this._defs);
- var a = o.style.fontSize;
- a && a < 9 && (o.style.fontSize = 9, o.scale = o.scale || [1, 1], o.scale[0] *= a / 9, o.scale[1] *= a / 9);
- var r = o.getBoundingRect();
- return this._textX += r.width, e.add(o), o
- };
- var sT = {
- g: function(t, e) {
- var i = new Zw;
- return Kr(e, i), Jr(t, i, this._defs), i
- },
- rect: function(t, e) {
- var i = new aM;
- return Kr(e, i), Jr(t, i, this._defs), i.setShape({
- x: parseFloat(t.getAttribute("x") || 0),
- y: parseFloat(t.getAttribute("y") || 0),
- width: parseFloat(t.getAttribute("width") || 0),
- height: parseFloat(t.getAttribute("height") || 0)
- }), i
- },
- circle: function(t, e) {
- var i = new KS;
- return Kr(e, i), Jr(t, i, this._defs), i.setShape({
- cx: parseFloat(t.getAttribute("cx") || 0),
- cy: parseFloat(t.getAttribute("cy") || 0),
- r: parseFloat(t.getAttribute("r") || 0)
- }), i
- },
- line: function(t, e) {
- var i = new rM;
- return Kr(e, i), Jr(t, i, this._defs), i.setShape({
- x1: parseFloat(t.getAttribute("x1") || 0),
- y1: parseFloat(t.getAttribute("y1") || 0),
- x2: parseFloat(t.getAttribute("x2") || 0),
- y2: parseFloat(t.getAttribute("y2") || 0)
- }), i
- },
- ellipse: function(t, e) {
- var i = new aT;
- return Kr(e, i), Jr(t, i, this._defs), i.setShape({
- cx: parseFloat(t.getAttribute("cx") || 0),
- cy: parseFloat(t.getAttribute("cy") || 0),
- rx: parseFloat(t.getAttribute("rx") || 0),
- ry: parseFloat(t.getAttribute("ry") || 0)
- }), i
- },
- polygon: function(t, e) {
- var i = t.getAttribute("points");
- i && (i = $r(i));
- var n = new nM({
- shape: {
- points: i || []
- }
- });
- return Kr(e, n), Jr(t, n, this._defs), n
- },
- polyline: function(t, e) {
- var i = new kn;
- Kr(e, i), Jr(t, i, this._defs);
- var n = t.getAttribute("points");
- return n && (n = $r(n)), new oM({
- shape: {
- points: n || []
- }
- })
- },
- image: function(t, e) {
- var i = new hi;
- return Kr(e, i), Jr(t, i, this._defs), i.setStyle({
- image: t.getAttribute("xlink:href"),
- x: t.getAttribute("x"),
- y: t.getAttribute("y"),
- width: t.getAttribute("width"),
- height: t.getAttribute("height")
- }), i
- },
- text: function(t, e) {
- var i = t.getAttribute("x") || 0,
- n = t.getAttribute("y") || 0,
- o = t.getAttribute("dx") || 0,
- a = t.getAttribute("dy") || 0;
- this._textX = parseFloat(i) + parseFloat(o), this._textY = parseFloat(n) + parseFloat(a);
- var r = new Zw;
- return Kr(e, r), Jr(t, r, this._defs), r
- },
- tspan: function(t, e) {
- var i = t.getAttribute("x"),
- n = t.getAttribute("y");
- null != i && (this._textX = parseFloat(i)), null != n && (this._textY = parseFloat(n));
- var o = t.getAttribute("dx") || 0,
- a = t.getAttribute("dy") || 0,
- r = new Zw;
- return Kr(e, r), Jr(t, r, this._defs), this._textX += o, this._textY += a, r
- },
- path: function(t, e) {
- var i = En(t.getAttribute("d") || "");
- return Kr(e, i), Jr(t, i, this._defs), i
- }
- },
- lT = {
- lineargradient: function(t) {
- var e = parseInt(t.getAttribute("x1") || 0, 10),
- i = parseInt(t.getAttribute("y1") || 0, 10),
- n = parseInt(t.getAttribute("x2") || 10, 10),
- o = parseInt(t.getAttribute("y2") || 0, 10),
- a = new dM(e, i, n, o);
- return qr(t, a), a
- },
- radialgradient: function(t) {}
- },
- uT = {
- fill: "fill",
- stroke: "stroke",
- "stroke-width": "lineWidth",
- opacity: "opacity",
- "fill-opacity": "fillOpacity",
- "stroke-opacity": "strokeOpacity",
- "stroke-dasharray": "lineDash",
- "stroke-dashoffset": "lineDashOffset",
- "stroke-linecap": "lineCap",
- "stroke-linejoin": "lineJoin",
- "stroke-miterlimit": "miterLimit",
- "font-family": "fontFamily",
- "font-size": "fontSize",
- "font-style": "fontStyle",
- "font-weight": "fontWeight",
- "text-align": "textAlign",
- "alignment-baseline": "textBaseline"
- },
- hT = /url\(\s*#(.*?)\)/,
- cT = /(translate|scale|rotate|skewX|skewY|matrix)\(([\-\s0-9\.e,]*)\)/g,
- dT = /([^\s:;]+)\s*:\s*([^:;]+)/g,
- fT = R(),
- pT = {
- registerMap: function(t, e, i) {
- var n;
- return y(e) ? n = e : e.svg ? n = [{
- type: "svg",
- source: e.svg,
- specialAreas: e.specialAreas
- }] : (e.geoJson && !e.features && (i = e.specialAreas, e = e.geoJson), n = [{
- type: "geoJSON",
- source: e,
- specialAreas: i
- }]), d(n, function(t) {
- var e = t.type;
- "geoJson" === e && (e = t.type = "geoJSON"), (0, gT[e])(t)
- }), fT.set(t, n)
- },
- retrieveMap: function(t) {
- return fT.get(t)
- }
- },
- gT = {
- geoJSON: function(t) {
- var e = t.source;
- t.geoJSON = _(e) ? "undefined" != typeof JSON && JSON.parse ? JSON.parse(e) : new Function("return (" + e + ");")
- () : e
- },
- svg: function(t) {
- t.svgXML = jr(t.source)
- }
- },
- mT = k,
- vT = d,
- yT = x,
- xT = w,
- _T = YM.parseClassType,
- wT = {
- zrender: "4.0.5"
- },
- bT = 1e3,
- ST = 1e3,
- MT = 3e3,
- IT = {
- PROCESSOR: {
- FILTER: bT,
- STATISTIC: 5e3
- },
- VISUAL: {
- LAYOUT: ST,
- GLOBAL: 2e3,
- CHART: MT,
- COMPONENT: 4e3,
- BRUSH: 5e3
- }
- },
- TT = "__flagInMainProcess",
- AT = "__optionUpdated",
- DT = /^[a-zA-Z0-9_]+$/;
- as.prototype.on = os("on"), as.prototype.off = os("off"), as.prototype.one = os("one"), h(as, aw);
- var CT = rs.prototype;
- CT._onframe = function() {
- if (!this._disposed) {
- var t = this._scheduler;
- if (this[AT]) {
- var e = this[AT].silent;
- this[TT] = !0, ls(this), LT.update.call(this), this[TT] = !1, this[AT] = !1, ds.call(this, e), fs.call(this, e)
- } else if (t.unfinished) {
- var i = 1,
- n = this._model;
- this._api;
- t.unfinished = !1;
- do {
- var o = +new Date;
- t.performSeriesTasks(n), t.performDataProcessorTasks(n), hs(this, n), t.performVisualTasks(n), xs(this, this._model,
- 0, "remain"), i -= +new Date - o
- } while (i > 0 && t.unfinished);
- t.unfinished || this._zr.flush()
- }
- }
- }, CT.getDom = function() {
- return this._dom
- }, CT.getZr = function() {
- return this._zr
- }, CT.setOption = function(t, e, i) {
- var n;
- if (xT(e) && (i = e.lazyUpdate, n = e.silent, e = e.notMerge), this[TT] = !0, !this._model || e) {
- var o = new Va(this._api),
- a = this._theme,
- r = this._model = new hI(null, null, a, o);
- r.scheduler = this._scheduler, r.init(null, null, a, o)
- }
- this._model.setOption(t, ET), i ? (this[AT] = {
- silent: n
- }, this[TT] = !1) : (ls(this), LT.update.call(this), this._zr.flush(), this[AT] = !1, this[TT] = !1, ds.call(this,
- n), fs.call(this, n))
- }, CT.setTheme = function() {
- console.error("ECharts#setTheme() is DEPRECATED in ECharts 3.0")
- }, CT.getModel = function() {
- return this._model
- }, CT.getOption = function() {
- return this._model && this._model.getOption()
- }, CT.getWidth = function() {
- return this._zr.getWidth()
- }, CT.getHeight = function() {
- return this._zr.getHeight()
- }, CT.getDevicePixelRatio = function() {
- return this._zr.painter.dpr || window.devicePixelRatio || 1
- }, CT.getRenderedCanvas = function(t) {
- if (z_.canvasSupported) return (t = t || {}).pixelRatio = t.pixelRatio || 1, t.backgroundColor = t.backgroundColor ||
- this._model.get("backgroundColor"), this._zr.painter.getRenderedCanvas(t)
- }, CT.getSvgDataUrl = function() {
- if (z_.svgSupported) {
- var t = this._zr;
- return d(t.storage.getDisplayList(), function(t) {
- t.stopAnimation(!0)
- }), t.painter.pathToDataUrl()
- }
- }, CT.getDataURL = function(t) {
- var e = (t = t || {}).excludeComponents,
- i = this._model,
- n = [],
- o = this;
- vT(e, function(t) {
- i.eachComponent({
- mainType: t
- }, function(t) {
- var e = o._componentsMap[t.__viewId];
- e.group.ignore || (n.push(e), e.group.ignore = !0)
- })
- });
- var a = "svg" === this._zr.painter.getType() ? this.getSvgDataUrl() : this.getRenderedCanvas(t).toDataURL("image/" +
- (t && t.type || "png"));
- return vT(n, function(t) {
- t.group.ignore = !1
- }), a
- }, CT.getConnectedDataURL = function(t) {
- if (z_.canvasSupported) {
- var e = this.group,
- n = Math.min,
- o = Math.max;
- if (FT[e]) {
- var a = 1 / 0,
- r = 1 / 0,
- s = -1 / 0,
- l = -1 / 0,
- u = [],
- h = t && t.pixelRatio || 1;
- d(GT, function(h, c) {
- if (h.group === e) {
- var d = h.getRenderedCanvas(i(t)),
- f = h.getDom().getBoundingClientRect();
- a = n(f.left, a), r = n(f.top, r), s = o(f.right, s), l = o(f.bottom, l), u.push({
- dom: d,
- left: f.left,
- top: f.top
- })
- }
- });
- var c = (s *= h) - (a *= h),
- f = (l *= h) - (r *= h),
- p = Y_();
- p.width = c, p.height = f;
- var g = Ii(p);
- return vT(u, function(t) {
- var e = new hi({
- style: {
- x: t.left * h - a,
- y: t.top * h - r,
- image: t.dom
- }
- });
- g.add(e)
- }), g.refreshImmediately(), p.toDataURL("image/" + (t && t.type || "png"))
- }
- return this.getDataURL(t)
- }
- }, CT.convertToPixel = v(ss, "convertToPixel"), CT.convertFromPixel = v(ss, "convertFromPixel"), CT.containPixel =
- function(t, e) {
- var i;
- return t = Vi(this._model, t), d(t, function(t, n) {
- n.indexOf("Models") >= 0 && d(t, function(t) {
- var o = t.coordinateSystem;
- if (o && o.containPoint) i |= !!o.containPoint(e);
- else if ("seriesModels" === n) {
- var a = this._chartsMap[t.__viewId];
- a && a.containPoint && (i |= a.containPoint(e, t))
- }
- }, this)
- }, this), !!i
- }, CT.getVisual = function(t, e) {
- var i = (t = Vi(this._model, t, {
- defaultMainType: "series"
- })).seriesModel.getData(),
- n = t.hasOwnProperty("dataIndexInside") ? t.dataIndexInside : t.hasOwnProperty("dataIndex") ? i.indexOfRawIndex(t.dataIndex) :
- null;
- return null != n ? i.getItemVisual(n, e) : i.getVisual(e)
- }, CT.getViewOfComponentModel = function(t) {
- return this._componentsMap[t.__viewId]
- }, CT.getViewOfSeriesModel = function(t) {
- return this._chartsMap[t.__viewId]
- };
- var LT = {
- prepareAndUpdate: function(t) {
- ls(this), LT.update.call(this, t)
- },
- update: function(t) {
- var e = this._model,
- i = this._api,
- n = this._zr,
- o = this._coordSysMgr,
- a = this._scheduler;
- if (e) {
- a.restoreData(e, t), a.performSeriesTasks(e), o.create(e, i), a.performDataProcessorTasks(e, t), hs(this, e), o.update(
- e, i), ms(e), a.performVisualTasks(e, t), vs(this, e, i, t);
- var r = e.get("backgroundColor") || "transparent";
- if (z_.canvasSupported) n.setBackgroundColor(r);
- else {
- var s = zt(r);
- r = Xt(s, "rgb"), 0 === s[3] && (r = "transparent")
- }
- _s(e, i)
- }
- },
- updateTransform: function(t) {
- var e = this._model,
- i = this,
- n = this._api;
- if (e) {
- var o = [];
- e.eachComponent(function(a, r) {
- var s = i.getViewOfComponentModel(r);
- if (s && s.__alive)
- if (s.updateTransform) {
- var l = s.updateTransform(r, e, n, t);
- l && l.update && o.push(s)
- } else o.push(s)
- });
- var a = R();
- e.eachSeries(function(o) {
- var r = i._chartsMap[o.__viewId];
- if (r.updateTransform) {
- var s = r.updateTransform(o, e, n, t);
- s && s.update && a.set(o.uid, 1)
- } else a.set(o.uid, 1)
- }), ms(e), this._scheduler.performVisualTasks(e, t, {
- setDirty: !0,
- dirtyMap: a
- }), xs(i, e, 0, t, a), _s(e, this._api)
- }
- },
- updateView: function(t) {
- var e = this._model;
- e && (Mr.markUpdateMethod(t, "updateView"), ms(e), this._scheduler.performVisualTasks(e, t, {
- setDirty: !0
- }), vs(this, this._model, this._api, t), _s(e, this._api))
- },
- updateVisual: function(t) {
- LT.update.call(this, t)
- },
- updateLayout: function(t) {
- LT.update.call(this, t)
- }
- };
- CT.resize = function(t) {
- this._zr.resize(t);
- var e = this._model;
- if (this._loadingFX && this._loadingFX.resize(), e) {
- var i = e.resetOption("media"),
- n = t && t.silent;
- this[TT] = !0, i && ls(this), LT.update.call(this), this[TT] = !1, ds.call(this, n), fs.call(this, n)
- }
- }, CT.showLoading = function(t, e) {
- if (xT(t) && (e = t, t = ""), t = t || "default", this.hideLoading(), VT[t]) {
- var i = VT[t](this._api, e),
- n = this._zr;
- this._loadingFX = i, n.add(i)
- }
- }, CT.hideLoading = function() {
- this._loadingFX && this._zr.remove(this._loadingFX), this._loadingFX = null
- }, CT.makeActionFromEvent = function(t) {
- var e = a({}, t);
- return e.type = NT[t.type], e
- }, CT.dispatchAction = function(t, e) {
- xT(e) || (e = {
- silent: !!e
- }), PT[t.type] && this._model && (this[TT] ? this._pendingActions.push(t) : (cs.call(this, t, e.silent), e.flush ?
- this._zr.flush(!0) : !1 !== e.flush && z_.browser.weChat && this._throttledZrFlush(), ds.call(this, e.silent),
- fs.call(this, e.silent)))
- }, CT.appendData = function(t) {
- var e = t.seriesIndex;
- this.getModel().getSeriesByIndex(e).appendData(t), this._scheduler.unfinished = !0
- }, CT.on = os("on"), CT.off = os("off"), CT.one = os("one");
- var kT = ["click", "dblclick", "mouseover", "mouseout", "mousemove", "mousedown", "mouseup", "globalout",
- "contextmenu"
- ];
- CT._initEvents = function() {
- vT(kT, function(t) {
- this._zr.on(t, function(e) {
- var i, n = this.getModel(),
- o = e.target;
- if ("globalout" === t) i = {};
- else if (o && null != o.dataIndex) {
- var r = o.dataModel || n.getSeriesByIndex(o.seriesIndex);
- i = r && r.getDataParams(o.dataIndex, o.dataType, o) || {}
- } else o && o.eventData && (i = a({}, o.eventData));
- if (i) {
- var s = i.componentType,
- l = i.componentIndex;
- "markLine" !== s && "markPoint" !== s && "markArea" !== s || (s = "series", l = i.seriesIndex);
- var u = s && null != l && n.getComponent(s, l),
- h = u && this["series" === u.mainType ? "_chartsMap" : "_componentsMap"][u.__viewId];
- i.event = e, i.type = t, this._ecEventProcessor.eventInfo = {
- targetEl: o,
- packedEvent: i,
- model: u,
- view: h
- }, this.trigger(t, i)
- }
- }, this)
- }, this), vT(NT, function(t, e) {
- this._messageCenter.on(e, function(t) {
- this.trigger(e, t)
- }, this)
- }, this)
- }, CT.isDisposed = function() {
- return this._disposed
- }, CT.clear = function() {
- this.setOption({
- series: []
- }, !0)
- }, CT.dispose = function() {
- if (!this._disposed) {
- this._disposed = !0, Fi(this.getDom(), ZT, "");
- var t = this._api,
- e = this._model;
- vT(this._componentsViews, function(i) {
- i.dispose(e, t)
- }), vT(this._chartsViews, function(i) {
- i.dispose(e, t)
- }), this._zr.dispose(), delete GT[this.id]
- }
- }, h(rs, aw), Is.prototype = {
- constructor: Is,
- normalizeQuery: function(t) {
- var e = {},
- i = {},
- n = {};
- if (_(t)) {
- var o = _T(t);
- e.mainType = o.main || null, e.subType = o.sub || null
- } else {
- var a = ["Index", "Name", "Id"],
- r = {
- name: 1,
- dataIndex: 1,
- dataType: 1
- };
- d(t, function(t, o) {
- for (var s = !1, l = 0; l < a.length; l++) {
- var u = a[l],
- h = o.lastIndexOf(u);
- if (h > 0 && h === o.length - u.length) {
- var c = o.slice(0, h);
- "data" !== c && (e.mainType = c, e[u.toLowerCase()] = t, s = !0)
- }
- }
- r.hasOwnProperty(o) && (i[o] = t, s = !0), s || (n[o] = t)
- })
- }
- return {
- cptQuery: e,
- dataQuery: i,
- otherQuery: n
- }
- },
- filter: function(t, e, i) {
- function n(t, e, i, n) {
- return null == t[i] || e[n || i] === t[i]
- }
- var o = this.eventInfo;
- if (!o) return !0;
- var a = o.targetEl,
- r = o.packedEvent,
- s = o.model,
- l = o.view;
- if (!s || !l) return !0;
- var u = e.cptQuery,
- h = e.dataQuery;
- return n(u, s, "mainType") && n(u, s, "subType") && n(u, s, "index", "componentIndex") && n(u, s, "name") && n(u,
- s, "id") && n(h, r, "name") && n(h, r, "dataIndex") && n(h, r, "dataType") && (!l.filterForExposedEvent || l.filterForExposedEvent(
- t, e.otherQuery, a, r))
- },
- afterTrigger: function() {
- this.eventInfo = null
- }
- };
- var PT = {},
- NT = {},
- OT = [],
- ET = [],
- RT = [],
- zT = [],
- BT = {},
- VT = {},
- GT = {},
- FT = {},
- WT = new Date - 0,
- HT = new Date - 0,
- ZT = "_echarts_instance_",
- UT = As;
- Es(2e3, UI), Ls(MI), ks(5e3, function(t) {
- var e = R();
- t.eachSeries(function(t) {
- var i = t.get("stack");
- if (i) {
- var n = e.get(i) || e.set(i, []),
- o = t.getData(),
- a = {
- stackResultDimension: o.getCalculationInfo("stackResultDimension"),
- stackedOverDimension: o.getCalculationInfo("stackedOverDimension"),
- stackedDimension: o.getCalculationInfo("stackedDimension"),
- stackedByDimension: o.getCalculationInfo("stackedByDimension"),
- isStackedByIndex: o.getCalculationInfo("isStackedByIndex"),
- data: o,
- seriesModel: t
- };
- if (!a.stackedDimension || !a.isStackedByIndex && !a.stackedByDimension) return;
- n.length && o.setCalculationInfo("stackedOnSeries", n[n.length - 1].seriesModel), n.push(a)
- }
- }), e.each(ir)
- }), zs("default", function(t, e) {
- r(e = e || {}, {
- text: "loading",
- color: "#c23531",
- textColor: "#000",
- maskColor: "rgba(255, 255, 255, 0.8)",
- zlevel: 0
- });
- var i = new aM({
- style: {
- fill: e.maskColor
- },
- zlevel: e.zlevel,
- z: 1e4
- }),
- n = new uM({
- shape: {
- startAngle: -YI / 2,
- endAngle: -YI / 2 + .1,
- r: 10
- },
- style: {
- stroke: e.color,
- lineCap: "round",
- lineWidth: 5
- },
- zlevel: e.zlevel,
- z: 10001
- }),
- o = new aM({
- style: {
- fill: "none",
- text: e.text,
- textPosition: "right",
- textDistance: 10,
- textFill: e.textColor
- },
- zlevel: e.zlevel,
- z: 10001
- });
- n.animateShape(!0).when(1e3, {
- endAngle: 3 * YI / 2
- }).start("circularInOut"), n.animateShape(!0).when(1e3, {
- startAngle: 3 * YI / 2
- }).delay(300).start("circularInOut");
- var a = new Zw;
- return a.add(n), a.add(o), a.add(i), a.resize = function() {
- var e = t.getWidth() / 2,
- a = t.getHeight() / 2;
- n.setShape({
- cx: e,
- cy: a
- });
- var r = n.shape.r;
- o.setShape({
- x: e - r,
- y: a - r,
- width: 2 * r,
- height: 2 * r
- }), i.setShape({
- x: 0,
- y: 0,
- width: t.getWidth(),
- height: t.getHeight()
- })
- }, a.resize(), a
- }), Ps({
- type: "highlight",
- event: "highlight",
- update: "highlight"
- }, B), Ps({
- type: "downplay",
- event: "downplay",
- update: "downplay"
- }, B), Cs("light", iT), Cs("dark", oT);
- var XT = {};
- Hs.prototype = {
- constructor: Hs,
- add: function(t) {
- return this._add = t, this
- },
- update: function(t) {
- return this._update = t, this
- },
- remove: function(t) {
- return this._remove = t, this
- },
- execute: function() {
- var t = this._old,
- e = this._new,
- i = {},
- n = [],
- o = [];
- for (Zs(t, {}, n, "_oldKeyGetter", this), Zs(e, i, o, "_newKeyGetter", this), a = 0; a < t.length; a++) null != (
- s = i[r = n[a]]) ? ((u = s.length) ? (1 === u && (i[r] = null), s = s.unshift()) : i[r] = null, this._update &&
- this._update(s, a)) : this._remove && this._remove(a);
- for (var a = 0; a < o.length; a++) {
- var r = o[a];
- if (i.hasOwnProperty(r)) {
- var s = i[r];
- if (null == s) continue;
- if (s.length)
- for (var l = 0, u = s.length; l < u; l++) this._add && this._add(s[l]);
- else this._add && this._add(s)
- }
- }
- }
- };
- var jT = R(["tooltip", "label", "itemName", "itemId", "seriesName"]),
- YT = w,
- qT = "e\0\0",
- KT = {
- float: "undefined" == typeof Float64Array ? Array : Float64Array,
- int: "undefined" == typeof Int32Array ? Array : Int32Array,
- ordinal: Array,
- number: Array,
- time: Array
- },
- $T = "undefined" == typeof Uint32Array ? Array : Uint32Array,
- JT = "undefined" == typeof Uint16Array ? Array : Uint16Array,
- QT = ["hasItemOption", "_nameList", "_idList", "_invertedIndicesMap", "_rawData", "_chunkSize", "_chunkCount",
- "_dimValueGetter", "_count", "_rawCount", "_nameDimIdx", "_idDimIdx"
- ],
- tA = ["_extent", "_approximateExtent", "_rawExtent"],
- eA = function(t, e) {
- t = t || ["x", "y"];
- for (var i = {}, n = [], o = {}, a = 0; a < t.length; a++) {
- var r = t[a];
- _(r) && (r = {
- name: r
- });
- var s = r.name;
- r.type = r.type || "float", r.coordDim || (r.coordDim = s, r.coordDimIndex = 0), r.otherDims = r.otherDims || {},
- n.push(s), i[s] = r, r.index = a, r.createInvertedIndices && (o[s] = [])
- }
- this.dimensions = n, this._dimensionInfos = i, this.hostModel = e, this.dataType, this._indices = null, this._count =
- 0, this._rawCount = 0, this._storage = {}, this._nameList = [], this._idList = [], this._optionModels = [], this._visual = {},
- this._layout = {}, this._itemVisuals = [], this.hasItemVisual = {}, this._itemLayouts = [], this._graphicEls = [],
- this._chunkSize = 1e5, this._chunkCount = 0, this._rawData, this._rawExtent = {}, this._extent = {}, this._approximateExtent = {},
- this._dimensionsSummary = Us(this), this._invertedIndicesMap = o, this._calculationInfo = {}
- },
- iA = eA.prototype;
- iA.type = "list", iA.hasItemOption = !0, iA.getDimension = function(t) {
- return isNaN(t) || (t = this.dimensions[t] || t), t
- }, iA.getDimensionInfo = function(t) {
- return this._dimensionInfos[this.getDimension(t)]
- }, iA.getDimensionsOnCoord = function() {
- return this._dimensionsSummary.dataDimsOnCoord.slice()
- }, iA.mapDimension = function(t, e) {
- var i = this._dimensionsSummary;
- if (null == e) return i.encodeFirstDimNotExtra[t];
- var n = i.encode[t];
- return !0 === e ? (n || []).slice() : n && n[e]
- }, iA.initData = function(t, e, i) {
- (va.isInstance(t) || c(t)) && (t = new nr(t, this.dimensions.length)), this._rawData = t, this._storage = {}, this._indices =
- null, this._nameList = e || [], this._idList = [], this._nameRepeatCount = {}, i || (this.hasItemOption = !1),
- this.defaultDimValueGetter = DI[this._rawData.getSource().sourceFormat], this._dimValueGetter = i = i || this.defaultDimValueGetter,
- this._rawExtent = {}, this._initDataFromProvider(0, t.count()), t.pure && (this.hasItemOption = !1)
- }, iA.getProvider = function() {
- return this._rawData
- }, iA.appendData = function(t) {
- var e = this._rawData,
- i = this.count();
- e.appendData(t);
- var n = e.count();
- e.persistent || (n += i), this._initDataFromProvider(i, n)
- }, iA._initDataFromProvider = function(t, e) {
- if (!(t >= e)) {
- for (var i, n = this._chunkSize, o = this._rawData, a = this._storage, r = this.dimensions, s = r.length, l = this
- ._dimensionInfos, u = this._nameList, h = this._idList, c = this._rawExtent, d = this._nameRepeatCount = {}, f =
- this._chunkCount, p = f - 1, g = 0; g < s; g++) {
- c[T = r[g]] || (c[T] = [1 / 0, -1 / 0]);
- var m = l[T];
- 0 === m.otherDims.itemName && (i = this._nameDimIdx = g), 0 === m.otherDims.itemId && (this._idDimIdx = g);
- var v = KT[m.type];
- a[T] || (a[T] = []);
- var y = a[T][p];
- if (y && y.length < n) {
- for (var x = new v(Math.min(e - p * n, n)), _ = 0; _ < y.length; _++) x[_] = y[_];
- a[T][p] = x
- }
- for (I = f * n; I < e; I += n) a[T].push(new v(Math.min(e - I, n)));
- this._chunkCount = a[T].length
- }
- for (var w = new Array(s), b = t; b < e; b++) {
- w = o.getItem(b, w);
- for (var S = Math.floor(b / n), M = b % n, I = 0; I < s; I++) {
- var T = r[I],
- A = a[T][S],
- D = this._dimValueGetter(w, T, b, I);
- A[M] = D;
- var C = c[T];
- D < C[0] && (C[0] = D), D > C[1] && (C[1] = D)
- }
- if (!o.pure) {
- var L = u[b];
- if (w && null == L)
- if (null != w.name) u[b] = L = w.name;
- else if (null != i) {
- var k = r[i],
- P = a[k][S];
- if (P) {
- L = P[M];
- var N = l[k].ordinalMeta;
- N && N.categories.length && (L = N.categories[L])
- }
- }
- var O = null == w ? null : w.id;
- null == O && null != L && (d[L] = d[L] || 0, O = L, d[L] > 0 && (O += "__ec__" + d[L]), d[L]++), null != O && (h[
- b] = O)
- }
- }!o.persistent && o.clean && o.clean(), this._rawCount = this._count = e, this._extent = {}, $s(this)
- }
- }, iA.count = function() {
- return this._count
- }, iA.getIndices = function() {
- var t = this._indices;
- if (t) {
- var e = t.constructor,
- i = this._count;
- if (e === Array) {
- n = new e(i);
- for (o = 0; o < i; o++) n[o] = t[o]
- } else n = new e(t.buffer, 0, i)
- } else
- for (var n = new(e = Ys(this))(this.count()), o = 0; o < n.length; o++) n[o] = o;
- return n
- }, iA.get = function(t, e) {
- if (!(e >= 0 && e < this._count)) return NaN;
- var i = this._storage;
- if (!i[t]) return NaN;
- e = this.getRawIndex(e);
- var n = Math.floor(e / this._chunkSize),
- o = e % this._chunkSize;
- return i[t][n][o]
- }, iA.getByRawIndex = function(t, e) {
- if (!(e >= 0 && e < this._rawCount)) return NaN;
- var i = this._storage[t];
- if (!i) return NaN;
- var n = Math.floor(e / this._chunkSize),
- o = e % this._chunkSize;
- return i[n][o]
- }, iA._getFast = function(t, e) {
- var i = Math.floor(e / this._chunkSize),
- n = e % this._chunkSize;
- return this._storage[t][i][n]
- }, iA.getValues = function(t, e) {
- var i = [];
- y(t) || (e = t, t = this.dimensions);
- for (var n = 0, o = t.length; n < o; n++) i.push(this.get(t[n], e));
- return i
- }, iA.hasValue = function(t) {
- for (var e = this._dimensionsSummary.dataDimsOnCoord, i = this._dimensionInfos, n = 0, o = e.length; n < o; n++)
- if ("ordinal" !== i[e[n]].type && isNaN(this.get(e[n], t))) return !1;
- return !0
- }, iA.getDataExtent = function(t) {
- t = this.getDimension(t);
- var e = [1 / 0, -1 / 0];
- if (!this._storage[t]) return e;
- var i, n = this.count();
- if (!this._indices) return this._rawExtent[t].slice();
- if (i = this._extent[t]) return i.slice();
- for (var o = (i = e)[0], a = i[1], r = 0; r < n; r++) {
- var s = this._getFast(t, this.getRawIndex(r));
- s < o && (o = s), s > a && (a = s)
- }
- return i = [o, a], this._extent[t] = i, i
- }, iA.getApproximateExtent = function(t) {
- return t = this.getDimension(t), this._approximateExtent[t] || this.getDataExtent(t)
- }, iA.setApproximateExtent = function(t, e) {
- e = this.getDimension(e), this._approximateExtent[e] = t.slice()
- }, iA.getCalculationInfo = function(t) {
- return this._calculationInfo[t]
- }, iA.setCalculationInfo = function(t, e) {
- YT(t) ? a(this._calculationInfo, t) : this._calculationInfo[t] = e
- }, iA.getSum = function(t) {
- var e = 0;
- if (this._storage[t])
- for (var i = 0, n = this.count(); i < n; i++) {
- var o = this.get(t, i);
- isNaN(o) || (e += o)
- }
- return e
- }, iA.getMedian = function(t) {
- var e = [];
- this.each(t, function(t, i) {
- isNaN(t) || e.push(t)
- });
- var i = [].concat(e).sort(function(t, e) {
- return t - e
- }),
- n = this.count();
- return 0 === n ? 0 : n % 2 == 1 ? i[(n - 1) / 2] : (i[n / 2] + i[n / 2 - 1]) / 2
- }, iA.rawIndexOf = function(t, e) {
- var i = (t && this._invertedIndicesMap[t])[e];
- return null == i || isNaN(i) ? -1 : i
- }, iA.indexOfName = function(t) {
- for (var e = 0, i = this.count(); e < i; e++)
- if (this.getName(e) === t) return e;
- return -1
- }, iA.indexOfRawIndex = function(t) {
- if (!this._indices) return t;
- if (t >= this._rawCount || t < 0) return -1;
- var e = this._indices,
- i = e[t];
- if (null != i && i < this._count && i === t) return t;
- for (var n = 0, o = this._count - 1; n <= o;) {
- var a = (n + o) / 2 | 0;
- if (e[a] < t) n = a + 1;
- else {
- if (!(e[a] > t)) return a;
- o = a - 1
- }
- }
- return -1
- }, iA.indicesOfNearest = function(t, e, i) {
- var n = [];
- if (!this._storage[t]) return n;
- null == i && (i = 1 / 0);
- for (var o = Number.MAX_VALUE, a = -1, r = 0, s = this.count(); r < s; r++) {
- var l = e - this.get(t, r),
- u = Math.abs(l);
- l <= i && u <= o && ((u < o || l >= 0 && a < 0) && (o = u, a = l, n.length = 0), n.push(r))
- }
- return n
- }, iA.getRawIndex = Qs, iA.getRawDataItem = function(t) {
- if (this._rawData.persistent) return this._rawData.getItem(this.getRawIndex(t));
- for (var e = [], i = 0; i < this.dimensions.length; i++) {
- var n = this.dimensions[i];
- e.push(this.get(n, t))
- }
- return e
- }, iA.getName = function(t) {
- var e = this.getRawIndex(t);
- return this._nameList[e] || Js(this, this._nameDimIdx, e) || ""
- }, iA.getId = function(t) {
- return el(this, this.getRawIndex(t))
- }, iA.each = function(t, e, i, n) {
- if (this._count) {
- "function" == typeof t && (n = i, i = e, e = t, t = []), i = i || n || this;
- for (var o = (t = f(il(t), this.getDimension, this)).length, a = 0; a < this.count(); a++) switch (o) {
- case 0:
- e.call(i, a);
- break;
- case 1:
- e.call(i, this.get(t[0], a), a);
- break;
- case 2:
- e.call(i, this.get(t[0], a), this.get(t[1], a), a);
- break;
- default:
- for (var r = 0, s = []; r < o; r++) s[r] = this.get(t[r], a);
- s[r] = a, e.apply(i, s)
- }
- }
- }, iA.filterSelf = function(t, e, i, n) {
- if (this._count) {
- "function" == typeof t && (n = i, i = e, e = t, t = []), i = i || n || this, t = f(il(t), this.getDimension, this);
- for (var o = this.count(), a = new(Ys(this))(o), r = [], s = t.length, l = 0, u = t[0], h = 0; h < o; h++) {
- var c, d = this.getRawIndex(h);
- if (0 === s) c = e.call(i, h);
- else if (1 === s) {
- var p = this._getFast(u, d);
- c = e.call(i, p, h)
- } else {
- for (var g = 0; g < s; g++) r[g] = this._getFast(u, d);
- r[g] = h, c = e.apply(i, r)
- }
- c && (a[l++] = d)
- }
- return l < o && (this._indices = a), this._count = l, this._extent = {}, this.getRawIndex = this._indices ? tl :
- Qs, this
- }
- }, iA.selectRange = function(t) {
- if (this._count) {
- var e = [];
- for (var i in t) t.hasOwnProperty(i) && e.push(i);
- var n = e.length;
- if (n) {
- var o = this.count(),
- a = new(Ys(this))(o),
- r = 0,
- s = e[0],
- l = t[s][0],
- u = t[s][1],
- h = !1;
- if (!this._indices) {
- var c = 0;
- if (1 === n) {
- for (var d = this._storage[e[0]], f = 0; f < this._chunkCount; f++)
- for (var p = d[f], g = Math.min(this._count - f * this._chunkSize, this._chunkSize), m = 0; m < g; m++)((w = p[
- m]) >= l && w <= u || isNaN(w)) && (a[r++] = c), c++;
- h = !0
- } else if (2 === n) {
- for (var d = this._storage[s], v = this._storage[e[1]], y = t[e[1]][0], x = t[e[1]][1], f = 0; f < this._chunkCount; f++)
- for (var p = d[f], _ = v[f], g = Math.min(this._count - f * this._chunkSize, this._chunkSize), m = 0; m < g; m++) {
- var w = p[m],
- b = _[m];
- (w >= l && w <= u || isNaN(w)) && (b >= y && b <= x || isNaN(b)) && (a[r++] = c), c++
- }
- h = !0
- }
- }
- if (!h)
- if (1 === n)
- for (m = 0; m < o; m++) {
- M = this.getRawIndex(m);
- ((w = this._getFast(s, M)) >= l && w <= u || isNaN(w)) && (a[r++] = M)
- } else
- for (m = 0; m < o; m++) {
- for (var S = !0, M = this.getRawIndex(m), f = 0; f < n; f++) {
- var I = e[f];
- ((w = this._getFast(i, M)) < t[I][0] || w > t[I][1]) && (S = !1)
- }
- S && (a[r++] = this.getRawIndex(m))
- }
- return r < o && (this._indices = a), this._count = r, this._extent = {}, this.getRawIndex = this._indices ? tl :
- Qs, this
- }
- }
- }, iA.mapArray = function(t, e, i, n) {
- "function" == typeof t && (n = i, i = e, e = t, t = []), i = i || n || this;
- var o = [];
- return this.each(t, function() {
- o.push(e && e.apply(this, arguments))
- }, i), o
- }, iA.map = function(t, e, i, n) {
- i = i || n || this;
- var o = nl(this, t = f(il(t), this.getDimension, this));
- o._indices = this._indices, o.getRawIndex = o._indices ? tl : Qs;
- for (var a = o._storage, r = [], s = this._chunkSize, l = t.length, u = this.count(), h = [], c = o._rawExtent, d =
- 0; d < u; d++) {
- for (var p = 0; p < l; p++) h[p] = this.get(t[p], d);
- h[l] = d;
- var g = e && e.apply(i, h);
- if (null != g) {
- "object" != typeof g && (r[0] = g, g = r);
- for (var m = this.getRawIndex(d), v = Math.floor(m / s), y = m % s, x = 0; x < g.length; x++) {
- var _ = t[x],
- w = g[x],
- b = c[_],
- S = a[_];
- S && (S[v][y] = w), w < b[0] && (b[0] = w), w > b[1] && (b[1] = w)
- }
- }
- }
- return o
- }, iA.downSample = function(t, e, i, n) {
- for (var o = nl(this, [t]), a = o._storage, r = [], s = Math.floor(1 / e), l = a[t], u = this.count(), h = this._chunkSize,
- c = o._rawExtent[t], d = new(Ys(this))(u), f = 0, p = 0; p < u; p += s) {
- s > u - p && (s = u - p, r.length = s);
- for (var g = 0; g < s; g++) {
- var m = this.getRawIndex(p + g),
- v = Math.floor(m / h),
- y = m % h;
- r[g] = l[v][y]
- }
- var x = i(r),
- _ = this.getRawIndex(Math.min(p + n(r, x) || 0, u - 1)),
- w = _ % h;
- l[Math.floor(_ / h)][w] = x, x < c[0] && (c[0] = x), x > c[1] && (c[1] = x), d[f++] = _
- }
- return o._count = f, o._indices = d, o.getRawIndex = tl, o
- }, iA.getItemModel = function(t) {
- var e = this.hostModel;
- return new Lo(this.getRawDataItem(t), e, e && e.ecModel)
- }, iA.diff = function(t) {
- var e = this;
- return new Hs(t ? t.getIndices() : [], this.getIndices(), function(e) {
- return el(t, e)
- }, function(t) {
- return el(e, t)
- })
- }, iA.getVisual = function(t) {
- var e = this._visual;
- return e && e[t]
- }, iA.setVisual = function(t, e) {
- if (YT(t))
- for (var i in t) t.hasOwnProperty(i) && this.setVisual(i, t[i]);
- else this._visual = this._visual || {}, this._visual[t] = e
- }, iA.setLayout = function(t, e) {
- if (YT(t))
- for (var i in t) t.hasOwnProperty(i) && this.setLayout(i, t[i]);
- else this._layout[t] = e
- }, iA.getLayout = function(t) {
- return this._layout[t]
- }, iA.getItemLayout = function(t) {
- return this._itemLayouts[t]
- }, iA.setItemLayout = function(t, e, i) {
- this._itemLayouts[t] = i ? a(this._itemLayouts[t] || {}, e) : e
- }, iA.clearItemLayouts = function() {
- this._itemLayouts.length = 0
- }, iA.getItemVisual = function(t, e, i) {
- var n = this._itemVisuals[t],
- o = n && n[e];
- return null != o || i ? o : this.getVisual(e)
- }, iA.setItemVisual = function(t, e, i) {
- var n = this._itemVisuals[t] || {},
- o = this.hasItemVisual;
- if (this._itemVisuals[t] = n, YT(e))
- for (var a in e) e.hasOwnProperty(a) && (n[a] = e[a], o[a] = !0);
- else n[e] = i, o[e] = !0
- }, iA.clearAllVisual = function() {
- this._visual = {}, this._itemVisuals = [], this.hasItemVisual = {}
- };
- var nA = function(t) {
- t.seriesIndex = this.seriesIndex, t.dataIndex = this.dataIndex, t.dataType = this.dataType
- };
- iA.setItemGraphicEl = function(t, e) {
- var i = this.hostModel;
- e && (e.dataIndex = t, e.dataType = this.dataType, e.seriesIndex = i && i.seriesIndex, "group" === e.type && e.traverse(
- nA, e)), this._graphicEls[t] = e
- }, iA.getItemGraphicEl = function(t) {
- return this._graphicEls[t]
- }, iA.eachItemGraphicEl = function(t, e) {
- d(this._graphicEls, function(i, n) {
- i && t && t.call(e, i, n)
- })
- }, iA.cloneShallow = function(t) {
- if (!t) {
- var e = f(this.dimensions, this.getDimensionInfo, this);
- t = new eA(e, this.hostModel)
- }
- if (t._storage = this._storage, Ks(t, this), this._indices) {
- var i = this._indices.constructor;
- t._indices = new i(this._indices)
- } else t._indices = null;
- return t.getRawIndex = t._indices ? tl : Qs, t
- }, iA.wrapMethod = function(t, e) {
- var i = this[t];
- "function" == typeof i && (this.__wrappedMethods = this.__wrappedMethods || [], this.__wrappedMethods.push(t), this[
- t] = function() {
- var t = i.apply(this, arguments);
- return e.apply(this, [t].concat(C(arguments)))
- })
- }, iA.TRANSFERABLE_METHODS = ["cloneShallow", "downSample", "map"], iA.CHANGABLE_METHODS = ["filterSelf",
- "selectRange"
- ];
- var oA = function(t, e) {
- return e = e || {}, rl(e.coordDimensions || [], t, {
- dimsDef: e.dimensionsDefine || t.dimensionsDefine,
- encodeDef: e.encodeDefine || t.encodeDefine,
- dimCount: e.dimensionsCount,
- generateCoord: e.generateCoord,
- generateCoordCount: e.generateCoordCount
- })
- };
- gl.prototype.parse = function(t) {
- return t
- }, gl.prototype.getSetting = function(t) {
- return this._setting[t]
- }, gl.prototype.contain = function(t) {
- var e = this._extent;
- return t >= e[0] && t <= e[1]
- }, gl.prototype.normalize = function(t) {
- var e = this._extent;
- return e[1] === e[0] ? .5 : (t - e[0]) / (e[1] - e[0])
- }, gl.prototype.scale = function(t) {
- var e = this._extent;
- return t * (e[1] - e[0]) + e[0]
- }, gl.prototype.unionExtent = function(t) {
- var e = this._extent;
- t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1])
- }, gl.prototype.unionExtentFromData = function(t, e) {
- this.unionExtent(t.getApproximateExtent(e))
- }, gl.prototype.getExtent = function() {
- return this._extent.slice()
- }, gl.prototype.setExtent = function(t, e) {
- var i = this._extent;
- isNaN(t) || (i[0] = t), isNaN(e) || (i[1] = e)
- }, gl.prototype.isBlank = function() {
- return this._isBlank
- }, gl.prototype.setBlank = function(t) {
- this._isBlank = t
- }, gl.prototype.getLabel = null, Xi(gl), Ki(gl, {
- registerWhenExtend: !0
- }), ml.createByAxisModel = function(t) {
- var e = t.option,
- i = e.data,
- n = i && f(i, yl);
- return new ml({
- categories: n,
- needCollect: !n,
- deduplication: !1 !== e.dedplication
- })
- };
- var aA = ml.prototype;
- aA.getOrdinal = function(t) {
- return vl(this).get(t)
- }, aA.parseAndCollect = function(t) {
- var e, i = this._needCollect;
- if ("string" != typeof t && !i) return t;
- if (i && !this._deduplication) return e = this.categories.length, this.categories[e] = t, e;
- var n = vl(this);
- return null == (e = n.get(t)) && (i ? (e = this.categories.length, this.categories[e] = t, n.set(t, e)) : e = NaN),
- e
- };
- var rA = gl.prototype,
- sA = gl.extend({
- type: "ordinal",
- init: function(t, e) {
- t && !y(t) || (t = new ml({
- categories: t
- })), this._ordinalMeta = t, this._extent = e || [0, t.categories.length - 1]
- },
- parse: function(t) {
- return "string" == typeof t ? this._ordinalMeta.getOrdinal(t) : Math.round(t)
- },
- contain: function(t) {
- return t = this.parse(t), rA.contain.call(this, t) && null != this._ordinalMeta.categories[t]
- },
- normalize: function(t) {
- return rA.normalize.call(this, this.parse(t))
- },
- scale: function(t) {
- return Math.round(rA.scale.call(this, t))
- },
- getTicks: function() {
- for (var t = [], e = this._extent, i = e[0]; i <= e[1];) t.push(i), i++;
- return t
- },
- getLabel: function(t) {
- if (!this.isBlank()) return this._ordinalMeta.categories[t]
- },
- count: function() {
- return this._extent[1] - this._extent[0] + 1
- },
- unionExtentFromData: function(t, e) {
- this.unionExtent(t.getApproximateExtent(e))
- },
- getOrdinalMeta: function() {
- return this._ordinalMeta
- },
- niceTicks: B,
- niceExtent: B
- });
- sA.create = function() {
- return new sA
- };
- var lA = zo,
- uA = zo,
- hA = gl.extend({
- type: "interval",
- _interval: 0,
- _intervalPrecision: 2,
- setExtent: function(t, e) {
- var i = this._extent;
- isNaN(t) || (i[0] = parseFloat(t)), isNaN(e) || (i[1] = parseFloat(e))
- },
- unionExtent: function(t) {
- var e = this._extent;
- t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1]), hA.prototype.setExtent.call(this, e[0], e[1])
- },
- getInterval: function() {
- return this._interval
- },
- setInterval: function(t) {
- this._interval = t, this._niceExtent = this._extent.slice(), this._intervalPrecision = _l(t)
- },
- getTicks: function() {
- return Sl(this._interval, this._extent, this._niceExtent, this._intervalPrecision)
- },
- getLabel: function(t, e) {
- if (null == t) return "";
- var i = e && e.precision;
- return null == i ? i = Go(t) || 0 : "auto" === i && (i = this._intervalPrecision), t = uA(t, i, !0), $o(t)
- },
- niceTicks: function(t, e, i) {
- t = t || 5;
- var n = this._extent,
- o = n[1] - n[0];
- if (isFinite(o)) {
- o < 0 && (o = -o, n.reverse());
- var a = xl(n, t, e, i);
- this._intervalPrecision = a.intervalPrecision, this._interval = a.interval, this._niceExtent = a.niceTickExtent
- }
- },
- niceExtent: function(t) {
- var e = this._extent;
- if (e[0] === e[1])
- if (0 !== e[0]) {
- var i = e[0];
- t.fixMax ? e[0] -= i / 2 : (e[1] += i / 2, e[0] -= i / 2)
- } else e[1] = 1;
- var n = e[1] - e[0];
- isFinite(n) || (e[0] = 0, e[1] = 1), this.niceTicks(t.splitNumber, t.minInterval, t.maxInterval);
- var o = this._interval;
- t.fixMin || (e[0] = uA(Math.floor(e[0] / o) * o)), t.fixMax || (e[1] = uA(Math.ceil(e[1] / o) * o))
- }
- });
- hA.create = function() {
- return new hA
- };
- var cA = "__ec_stack_",
- dA = "undefined" != typeof Float32Array ? Float32Array : Array,
- fA = {
- seriesType: "bar",
- plan: zI(),
- reset: function(t) {
- if (Pl(t) && Nl(t)) {
- var e = t.getData(),
- i = t.coordinateSystem,
- n = i.getBaseAxis(),
- o = i.getOtherAxis(n),
- a = e.mapDimension(o.dim),
- r = e.mapDimension(n.dim),
- s = o.isHorizontal(),
- l = s ? 0 : 1,
- u = Ll(Dl([t]), n, t).width;
- return u > .5 || (u = .5), {
- progress: function(t, e) {
- for (var n, h = new dA(2 * t.count), c = [], d = [], f = 0; null != (n = t.next());) d[l] = e.get(a, n), d[1 -
- l] = e.get(r, n), c = i.dataToPoint(d, null, c), h[f++] = c[0], h[f++] = c[1];
- e.setLayout({
- largePoints: h,
- barWidth: u,
- valueAxisStart: Ol(0, o),
- valueAxisHorizontal: s
- })
- }
- }
- }
- }
- },
- pA = hA.prototype,
- gA = Math.ceil,
- mA = Math.floor,
- vA = function(t, e, i, n) {
- for (; i < n;) {
- var o = i + n >>> 1;
- t[o][1] < e ? i = o + 1 : n = o
- }
- return i
- },
- yA = hA.extend({
- type: "time",
- getLabel: function(t) {
- var e = this._stepLvl,
- i = new Date(t);
- return oa(e[0], i, this.getSetting("useUTC"))
- },
- niceExtent: function(t) {
- var e = this._extent;
- if (e[0] === e[1] && (e[0] -= 864e5, e[1] += 864e5), e[1] === -1 / 0 && e[0] === 1 / 0) {
- var i = new Date;
- e[1] = +new Date(i.getFullYear(), i.getMonth(), i.getDate()), e[0] = e[1] - 864e5
- }
- this.niceTicks(t.splitNumber, t.minInterval, t.maxInterval);
- var n = this._interval;
- t.fixMin || (e[0] = zo(mA(e[0] / n) * n)), t.fixMax || (e[1] = zo(gA(e[1] / n) * n))
- },
- niceTicks: function(t, e, i) {
- t = t || 10;
- var n = this._extent,
- o = n[1] - n[0],
- a = o / t;
- null != e && a < e && (a = e), null != i && a > i && (a = i);
- var r = xA.length,
- s = vA(xA, a, 0, r),
- l = xA[Math.min(s, r - 1)],
- u = l[1];
- "year" === l[0] && (u *= Yo(o / u / t, !0));
- var h = this.getSetting("useUTC") ? 0 : 60 * new Date(+n[0] || +n[1]).getTimezoneOffset() * 1e3,
- c = [Math.round(gA((n[0] - h) / u) * u + h), Math.round(mA((n[1] - h) / u) * u + h)];
- bl(c, n), this._stepLvl = l, this._interval = u, this._niceExtent = c
- },
- parse: function(t) {
- return +Uo(t)
- }
- });
- d(["contain", "normalize"], function(t) {
- yA.prototype[t] = function(e) {
- return pA[t].call(this, this.parse(e))
- }
- });
- var xA = [
- ["hh:mm:ss", 1e3],
- ["hh:mm:ss", 5e3],
- ["hh:mm:ss", 1e4],
- ["hh:mm:ss", 15e3],
- ["hh:mm:ss", 3e4],
- ["hh:mm\nMM-dd", 6e4],
- ["hh:mm\nMM-dd", 3e5],
- ["hh:mm\nMM-dd", 6e5],
- ["hh:mm\nMM-dd", 9e5],
- ["hh:mm\nMM-dd", 18e5],
- ["hh:mm\nMM-dd", 36e5],
- ["hh:mm\nMM-dd", 72e5],
- ["hh:mm\nMM-dd", 216e5],
- ["hh:mm\nMM-dd", 432e5],
- ["MM-dd\nyyyy", 864e5],
- ["MM-dd\nyyyy", 1728e5],
- ["MM-dd\nyyyy", 2592e5],
- ["MM-dd\nyyyy", 3456e5],
- ["MM-dd\nyyyy", 432e6],
- ["MM-dd\nyyyy", 5184e5],
- ["week", 6048e5],
- ["MM-dd\nyyyy", 864e6],
- ["week", 12096e5],
- ["week", 18144e5],
- ["month", 26784e5],
- ["week", 36288e5],
- ["month", 53568e5],
- ["week", 6048e6],
- ["quarter", 8208e6],
- ["month", 107136e5],
- ["month", 13392e6],
- ["half-year", 16416e6],
- ["month", 214272e5],
- ["month", 26784e6],
- ["year", 32832e6]
- ];
- yA.create = function(t) {
- return new yA({
- useUTC: t.ecModel.get("useUTC")
- })
- };
- var _A = gl.prototype,
- wA = hA.prototype,
- bA = Go,
- SA = zo,
- MA = Math.floor,
- IA = Math.ceil,
- TA = Math.pow,
- AA = Math.log,
- DA = gl.extend({
- type: "log",
- base: 10,
- $constructor: function() {
- gl.apply(this, arguments), this._originalScale = new hA
- },
- getTicks: function() {
- var t = this._originalScale,
- e = this._extent,
- i = t.getExtent();
- return f(wA.getTicks.call(this), function(n) {
- var o = zo(TA(this.base, n));
- return o = n === e[0] && t.__fixMin ? El(o, i[0]) : o, o = n === e[1] && t.__fixMax ? El(o, i[1]) : o
- }, this)
- },
- getLabel: wA.getLabel,
- scale: function(t) {
- return t = _A.scale.call(this, t), TA(this.base, t)
- },
- setExtent: function(t, e) {
- var i = this.base;
- t = AA(t) / AA(i), e = AA(e) / AA(i), wA.setExtent.call(this, t, e)
- },
- getExtent: function() {
- var t = this.base,
- e = _A.getExtent.call(this);
- e[0] = TA(t, e[0]), e[1] = TA(t, e[1]);
- var i = this._originalScale,
- n = i.getExtent();
- return i.__fixMin && (e[0] = El(e[0], n[0])), i.__fixMax && (e[1] = El(e[1], n[1])), e
- },
- unionExtent: function(t) {
- this._originalScale.unionExtent(t);
- var e = this.base;
- t[0] = AA(t[0]) / AA(e), t[1] = AA(t[1]) / AA(e), _A.unionExtent.call(this, t)
- },
- unionExtentFromData: function(t, e) {
- this.unionExtent(t.getApproximateExtent(e))
- },
- niceTicks: function(t) {
- t = t || 10;
- var e = this._extent,
- i = e[1] - e[0];
- if (!(i === 1 / 0 || i <= 0)) {
- var n = Xo(i);
- for (t / i * n <= .5 && (n *= 10); !isNaN(n) && Math.abs(n) < 1 && Math.abs(n) > 0;) n *= 10;
- var o = [zo(IA(e[0] / n) * n), zo(MA(e[1] / n) * n)];
- this._interval = n, this._niceExtent = o
- }
- },
- niceExtent: function(t) {
- wA.niceExtent.call(this, t);
- var e = this._originalScale;
- e.__fixMin = t.fixMin, e.__fixMax = t.fixMax
- }
- });
- d(["contain", "normalize"], function(t) {
- DA.prototype[t] = function(e) {
- return e = AA(e) / AA(this.base), _A[t].call(this, e)
- }
- }), DA.create = function() {
- return new DA
- };
- var CA = {
- getMin: function(t) {
- var e = this.option,
- i = t || null == e.rangeStart ? e.min : e.rangeStart;
- return this.axis && null != i && "dataMin" !== i && "function" != typeof i && !I(i) && (i = this.axis.scale.parse(
- i)), i
- },
- getMax: function(t) {
- var e = this.option,
- i = t || null == e.rangeEnd ? e.max : e.rangeEnd;
- return this.axis && null != i && "dataMax" !== i && "function" != typeof i && !I(i) && (i = this.axis.scale.parse(
- i)), i
- },
- getNeedCrossZero: function() {
- var t = this.option;
- return null == t.rangeStart && null == t.rangeEnd && !t.scale
- },
- getCoordSysModel: B,
- setRange: function(t, e) {
- this.option.rangeStart = t, this.option.rangeEnd = e
- },
- resetRange: function() {
- this.option.rangeStart = this.option.rangeEnd = null
- }
- },
- LA = Fn({
- type: "triangle",
- shape: {
- cx: 0,
- cy: 0,
- width: 0,
- height: 0
- },
- buildPath: function(t, e) {
- var i = e.cx,
- n = e.cy,
- o = e.width / 2,
- a = e.height / 2;
- t.moveTo(i, n - a), t.lineTo(i + o, n + a), t.lineTo(i - o, n + a), t.closePath()
- }
- }),
- kA = Fn({
- type: "diamond",
- shape: {
- cx: 0,
- cy: 0,
- width: 0,
- height: 0
- },
- buildPath: function(t, e) {
- var i = e.cx,
- n = e.cy,
- o = e.width / 2,
- a = e.height / 2;
- t.moveTo(i, n - a), t.lineTo(i + o, n), t.lineTo(i, n + a), t.lineTo(i - o, n), t.closePath()
- }
- }),
- PA = Fn({
- type: "pin",
- shape: {
- x: 0,
- y: 0,
- width: 0,
- height: 0
- },
- buildPath: function(t, e) {
- var i = e.x,
- n = e.y,
- o = e.width / 5 * 3,
- a = Math.max(o, e.height),
- r = o / 2,
- s = r * r / (a - r),
- l = n - a + r + s,
- u = Math.asin(s / r),
- h = Math.cos(u) * r,
- c = Math.sin(u),
- d = Math.cos(u),
- f = .6 * r,
- p = .7 * r;
- t.moveTo(i - h, l + s), t.arc(i, l, r, Math.PI - u, 2 * Math.PI + u), t.bezierCurveTo(i + h - c * f, l + s + d *
- f, i, n - p, i, n), t.bezierCurveTo(i, n - p, i - h + c * f, l + s + d * f, i - h, l + s), t.closePath()
- }
- }),
- NA = Fn({
- type: "arrow",
- shape: {
- x: 0,
- y: 0,
- width: 0,
- height: 0
- },
- buildPath: function(t, e) {
- var i = e.height,
- n = e.width,
- o = e.x,
- a = e.y,
- r = n / 3 * 2;
- t.moveTo(o, a), t.lineTo(o + r, a + i), t.lineTo(o, a + i / 4 * 3), t.lineTo(o - r, a + i), t.lineTo(o, a), t.closePath()
- }
- }),
- OA = {
- line: function(t, e, i, n, o) {
- o.x1 = t, o.y1 = e + n / 2, o.x2 = t + i, o.y2 = e + n / 2
- },
- rect: function(t, e, i, n, o) {
- o.x = t, o.y = e, o.width = i, o.height = n
- },
- roundRect: function(t, e, i, n, o) {
- o.x = t, o.y = e, o.width = i, o.height = n, o.r = Math.min(i, n) / 4
- },
- square: function(t, e, i, n, o) {
- var a = Math.min(i, n);
- o.x = t, o.y = e, o.width = a, o.height = a
- },
- circle: function(t, e, i, n, o) {
- o.cx = t + i / 2, o.cy = e + n / 2, o.r = Math.min(i, n) / 2
- },
- diamond: function(t, e, i, n, o) {
- o.cx = t + i / 2, o.cy = e + n / 2, o.width = i, o.height = n
- },
- pin: function(t, e, i, n, o) {
- o.x = t + i / 2, o.y = e + n / 2, o.width = i, o.height = n
- },
- arrow: function(t, e, i, n, o) {
- o.x = t + i / 2, o.y = e + n / 2, o.width = i, o.height = n
- },
- triangle: function(t, e, i, n, o) {
- o.cx = t + i / 2, o.cy = e + n / 2, o.width = i, o.height = n
- }
- },
- EA = {};
- d({
- line: rM,
- rect: aM,
- roundRect: aM,
- square: aM,
- circle: KS,
- diamond: kA,
- pin: PA,
- arrow: NA,
- triangle: LA
- }, function(t, e) {
- EA[e] = new t
- });
- var RA = Fn({
- type: "symbol",
- shape: {
- symbolType: "",
- x: 0,
- y: 0,
- width: 0,
- height: 0
- },
- beforeBrush: function() {
- var t = this.style;
- "pin" === this.shape.symbolType && "inside" === t.textPosition && (t.textPosition = ["50%", "40%"], t.textAlign =
- "center", t.textVerticalAlign = "middle")
- },
- buildPath: function(t, e, i) {
- var n = e.symbolType,
- o = EA[n];
- "none" !== e.symbolType && (o || (o = EA[n = "rect"]), OA[n](e.x, e.y, e.width, e.height, o.shape), o.buildPath(
- t, o.shape, i))
- }
- }),
- zA = {
- isDimensionStacked: hl,
- enableDataStack: ul,
- getStackedDimension: cl
- },
- BA = (Object.freeze || Object)({
- createList: function(t) {
- return dl(t.getSource(), t)
- },
- getLayoutRect: la,
- dataStack: zA,
- createScale: function(t, e) {
- var i = e;
- Lo.isInstance(e) || h(i = new Lo(e), CA);
- var n = Vl(i);
- return n.setExtent(t[0], t[1]), Bl(n, i), n
- },
- mixinAxisModelCommonMethods: function(t) {
- h(t, CA)
- },
- completeDimensions: rl,
- createDimensions: oA,
- createSymbol: Xl
- }),
- VA = 1e-8;
- ql.prototype = {
- constructor: ql,
- properties: null,
- getBoundingRect: function() {
- var t = this._rect;
- if (t) return t;
- for (var e = Number.MAX_VALUE, i = [e, e], n = [-e, -e], o = [], a = [], r = this.geometries, s = 0; s < r.length; s++)
- "polygon" === r[s].type && (dn(r[s].exterior, o, a), tt(i, i, o), et(n, n, a));
- return 0 === s && (i[0] = i[1] = n[0] = n[1] = 0), this._rect = new ue(i[0], i[1], n[0] - i[0], n[1] - i[1])
- },
- contain: function(t) {
- var e = this.getBoundingRect(),
- i = this.geometries;
- if (!e.contain(t[0], t[1])) return !1;
- t: for (var n = 0, o = i.length; n < o; n++)
- if ("polygon" === i[n].type) {
- var a = i[n].exterior,
- r = i[n].interiors;
- if (Yl(a, t[0], t[1])) {
- for (var s = 0; s < (r ? r.length : 0); s++)
- if (Yl(r[s])) continue t;
- return !0
- }
- }
- return !1
- },
- transformTo: function(t, e, i, n) {
- var o = this.getBoundingRect(),
- a = o.width / o.height;
- i ? n || (n = i / a) : i = a * n;
- for (var r = new ue(t, e, i, n), s = o.calculateTransform(r), l = this.geometries, u = 0; u < l.length; u++)
- if ("polygon" === l[u].type) {
- for (var h = l[u].exterior, c = l[u].interiors, d = 0; d < h.length; d++) Q(h[d], h[d], s);
- for (var f = 0; f < (c ? c.length : 0); f++)
- for (d = 0; d < c[f].length; d++) Q(c[f][d], c[f][d], s)
- }(o = this._rect). copy(r), this.center = [o.x + o.width / 2, o.y + o.height / 2]
- },
- cloneShallow: function(t) {
- null == t && (t = this.name);
- var e = new ql(t, this.geometries, this.center);
- return e._rect = this._rect, e.transformTo = null, e
- }
- };
- var GA = function(t) {
- return Kl(t), f(g(t.features, function(t) {
- return t.geometry && t.properties && t.geometry.coordinates.length > 0
- }), function(t) {
- var e = t.properties,
- i = t.geometry,
- n = i.coordinates,
- o = [];
- "Polygon" === i.type && o.push({
- type: "polygon",
- exterior: n[0],
- interiors: n.slice(1)
- }), "MultiPolygon" === i.type && d(n, function(t) {
- t[0] && o.push({
- type: "polygon",
- exterior: t[0],
- interiors: t.slice(1)
- })
- });
- var a = new ql(e.name, o, e.cp);
- return a.properties = e, a
- })
- },
- FA = Bi(),
- WA = [0, 1],
- HA = function(t, e, i) {
- this.dim = t, this.scale = e, this._extent = i || [0, 0], this.inverse = !1, this.onBand = !1
- };
- HA.prototype = {
- constructor: HA,
- contain: function(t) {
- var e = this._extent,
- i = Math.min(e[0], e[1]),
- n = Math.max(e[0], e[1]);
- return t >= i && t <= n
- },
- containData: function(t) {
- return this.contain(this.dataToCoord(t))
- },
- getExtent: function() {
- return this._extent.slice()
- },
- getPixelPrecision: function(t) {
- return Fo(t || this.scale.getExtent(), this._extent)
- },
- setExtent: function(t, e) {
- var i = this._extent;
- i[0] = t, i[1] = e
- },
- dataToCoord: function(t, e) {
- var i = this._extent,
- n = this.scale;
- return t = n.normalize(t), this.onBand && "ordinal" === n.type && fu(i = i.slice(), n.count()), Eo(t, WA, i, e)
- },
- coordToData: function(t, e) {
- var i = this._extent,
- n = this.scale;
- this.onBand && "ordinal" === n.type && fu(i = i.slice(), n.count());
- var o = Eo(t, i, WA, e);
- return this.scale.scale(o)
- },
- pointToData: function(t, e) {},
- getTicksCoords: function(t) {
- var e = (t = t || {}).tickModel || this.getTickModel(),
- i = Ql(this, e),
- n = f(i.ticks, function(t) {
- return {
- coord: this.dataToCoord(t),
- tickValue: t
- }
- }, this),
- o = e.get("alignWithLabel");
- return pu(this, n, i.tickCategoryInterval, o, t.clamp), n
- },
- getViewLabels: function() {
- return Jl(this).labels
- },
- getLabelModel: function() {
- return this.model.getModel("axisLabel")
- },
- getTickModel: function() {
- return this.model.getModel("axisTick")
- },
- getBandWidth: function() {
- var t = this._extent,
- e = this.scale.getExtent(),
- i = e[1] - e[0] + (this.onBand ? 1 : 0);
- 0 === i && (i = 1);
- var n = Math.abs(t[1] - t[0]);
- return Math.abs(n) / i
- },
- isHorizontal: null,
- getRotate: null,
- calculateCategoryInterval: function() {
- return lu(this)
- }
- };
- var ZA = GA,
- UA = {};
- d(["map", "each", "filter", "indexOf", "inherits", "reduce", "filter", "bind", "curry", "isArray", "isString",
- "isObject", "isFunction", "extend", "defaults", "clone", "merge"
- ], function(t) {
- UA[t] = $_[t]
- });
- var XA = {};
- d(["extendShape", "extendPath", "makePath", "makeImage", "mergePath", "resizePath", "createIcon", "setHoverStyle",
- "setLabelStyle", "setTextStyle", "setText", "getFont", "updateProps", "initProps", "getTransform",
- "clipPointsByRect", "clipRectByRect", "Group", "Image", "Text", "Circle", "Sector", "Ring", "Polygon", "Polyline",
- "Rect", "Line", "BezierCurve", "Arc", "IncrementalDisplayable", "CompoundPath", "LinearGradient", "RadialGradient",
- "BoundingRect"
- ], function(t) {
- XA[t] = bM[t]
- }), OI.extend({
- type: "series.line",
- dependencies: ["grid", "polar"],
- getInitialData: function(t, e) {
- return dl(this.getSource(), this)
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "cartesian2d",
- legendHoverLink: !0,
- hoverAnimation: !0,
- clipOverflow: !0,
- label: {
- position: "top"
- },
- lineStyle: {
- width: 2,
- type: "solid"
- },
- step: !1,
- smooth: !1,
- smoothMonotone: null,
- symbol: "emptyCircle",
- symbolSize: 4,
- symbolRotate: null,
- showSymbol: !0,
- showAllSymbol: "auto",
- connectNulls: !1,
- sampling: "none",
- animationEasing: "linear",
- progressive: 0,
- hoverLayerThreshold: 1 / 0
- }
- });
- var jA = mu.prototype,
- YA = mu.getSymbolSize = function(t, e) {
- var i = t.getItemVisual(e, "symbolSize");
- return i instanceof Array ? i.slice() : [+i, +i]
- };
- jA._createSymbol = function(t, e, i, n, o) {
- this.removeAll();
- var a = Xl(t, -1, -1, 2, 2, e.getItemVisual(i, "color"), o);
- a.attr({
- z2: 100,
- culling: !0,
- scale: vu(n)
- }), a.drift = yu, this._symbolType = t, this.add(a)
- }, jA.stopSymbolAnimation = function(t) {
- this.childAt(0).stopAnimation(t)
- }, jA.getSymbolPath = function() {
- return this.childAt(0)
- }, jA.getScale = function() {
- return this.childAt(0).scale
- }, jA.highlight = function() {
- this.childAt(0).trigger("emphasis")
- }, jA.downplay = function() {
- this.childAt(0).trigger("normal")
- }, jA.setZ = function(t, e) {
- var i = this.childAt(0);
- i.zlevel = t, i.z = e
- }, jA.setDraggable = function(t) {
- var e = this.childAt(0);
- e.draggable = t, e.cursor = t ? "move" : "pointer"
- }, jA.updateData = function(t, e, i) {
- this.silent = !1;
- var n = t.getItemVisual(e, "symbol") || "circle",
- o = t.hostModel,
- a = YA(t, e),
- r = n !== this._symbolType;
- if (r) {
- var s = t.getItemVisual(e, "symbolKeepAspect");
- this._createSymbol(n, t, e, a, s)
- } else(l = this.childAt(0)).silent = !1, bo(l, {
- scale: vu(a)
- }, o, e);
- if (this._updateCommon(t, e, a, i), r) {
- var l = this.childAt(0),
- u = i && i.fadeIn,
- h = {
- scale: l.scale.slice()
- };
- u && (h.style = {
- opacity: l.style.opacity
- }), l.scale = [0, 0], u && (l.style.opacity = 0), So(l, h, o, e)
- }
- this._seriesModel = o
- };
- var qA = ["itemStyle"],
- KA = ["emphasis", "itemStyle"],
- $A = ["label"],
- JA = ["emphasis", "label"];
- jA._updateCommon = function(t, e, i, n) {
- var o = this.childAt(0),
- r = t.hostModel,
- s = t.getItemVisual(e, "color");
- "image" !== o.type && o.useStyle({
- strokeNoScale: !0
- });
- var l = n && n.itemStyle,
- u = n && n.hoverItemStyle,
- h = n && n.symbolRotate,
- c = n && n.symbolOffset,
- d = n && n.labelModel,
- f = n && n.hoverLabelModel,
- p = n && n.hoverAnimation,
- g = n && n.cursorStyle;
- if (!n || t.hasItemOption) {
- var m = n && n.itemModel ? n.itemModel : t.getItemModel(e);
- l = m.getModel(qA).getItemStyle(["color"]), u = m.getModel(KA).getItemStyle(), h = m.getShallow("symbolRotate"), c =
- m.getShallow("symbolOffset"), d = m.getModel($A), f = m.getModel(JA), p = m.getShallow("hoverAnimation"), g = m.getShallow(
- "cursor")
- } else u = a({}, u);
- var v = o.style;
- o.attr("rotation", (h || 0) * Math.PI / 180 || 0), c && o.attr("position", [Ro(c[0], i[0]), Ro(c[1], i[1])]), g &&
- o.attr("cursor", g), o.setColor(s, n && n.symbolInnerColor), o.setStyle(l);
- var y = t.getItemVisual(e, "opacity");
- null != y && (v.opacity = y);
- var x = t.getItemVisual(e, "liftZ"),
- _ = o.__z2Origin;
- null != x ? null == _ && (o.__z2Origin = o.z2, o.z2 += x) : null != _ && (o.z2 = _, o.__z2Origin = null);
- var w = n && n.useNameLabel;
- co(v, u, d, f, {
- labelFetcher: r,
- labelDataIndex: e,
- defaultText: function(e, i) {
- return w ? t.getName(e) : gu(t, e)
- },
- isRectText: !0,
- autoColor: s
- }), o.off("mouseover").off("mouseout").off("emphasis").off("normal"), o.hoverStyle = u, uo(o), o.__symbolOriginalScale =
- vu(i), p && r.isAnimationEnabled() && o.on("mouseover", xu).on("mouseout", _u).on("emphasis", wu).on("normal", bu)
- }, jA.fadeOut = function(t, e) {
- var i = this.childAt(0);
- this.silent = i.silent = !0, !(e && e.keepLabel) && (i.style.text = null), bo(i, {
- style: {
- opacity: 0
- },
- scale: [0, 0]
- }, this._seriesModel, this.dataIndex, t)
- }, u(mu, Zw);
- var QA = Su.prototype;
- QA.updateData = function(t, e) {
- e = Iu(e);
- var i = this.group,
- n = t.hostModel,
- o = this._data,
- a = this._symbolCtor,
- r = Tu(t);
- o || i.removeAll(), t.diff(o).add(function(n) {
- var o = t.getItemLayout(n);
- if (Mu(t, o, n, e)) {
- var s = new a(t, n, r);
- s.attr("position", o), t.setItemGraphicEl(n, s), i.add(s)
- }
- }).update(function(s, l) {
- var u = o.getItemGraphicEl(l),
- h = t.getItemLayout(s);
- Mu(t, h, s, e) ? (u ? (u.updateData(t, s, r), bo(u, {
- position: h
- }, n)) : (u = new a(t, s)).attr("position", h), i.add(u), t.setItemGraphicEl(s, u)) : i.remove(u)
- }).remove(function(t) {
- var e = o.getItemGraphicEl(t);
- e && e.fadeOut(function() {
- i.remove(e)
- })
- }).execute(), this._data = t
- }, QA.isPersistent = function() {
- return !0
- }, QA.updateLayout = function() {
- var t = this._data;
- t && t.eachItemGraphicEl(function(e, i) {
- var n = t.getItemLayout(i);
- e.attr("position", n)
- })
- }, QA.incrementalPrepareUpdate = function(t) {
- this._seriesScope = Tu(t), this._data = null, this.group.removeAll()
- }, QA.incrementalUpdate = function(t, e, i) {
- i = Iu(i);
- for (var n = t.start; n < t.end; n++) {
- var o = e.getItemLayout(n);
- if (Mu(e, o, n, i)) {
- var a = new this._symbolCtor(e, n, this._seriesScope);
- a.traverse(function(t) {
- t.isGroup || (t.incremental = t.useHoverLayer = !0)
- }), a.attr("position", o), this.group.add(a), e.setItemGraphicEl(n, a)
- }
- }
- }, QA.remove = function(t) {
- var e = this.group,
- i = this._data;
- i && t ? i.eachItemGraphicEl(function(t) {
- t.fadeOut(function() {
- e.remove(t)
- })
- }) : e.removeAll()
- };
- var tD = function(t, e, i, n, o, a, r, s) {
- for (var l = Lu(t, e), u = [], h = [], c = [], d = [], f = [], p = [], g = [], m = Au(o, e, r), v = Au(a, t, s), y =
- 0; y < l.length; y++) {
- var x = l[y],
- _ = !0;
- switch (x.cmd) {
- case "=":
- var w = t.getItemLayout(x.idx),
- b = e.getItemLayout(x.idx1);
- (isNaN(w[0]) || isNaN(w[1])) && (w = b.slice()), u.push(w), h.push(b), c.push(i[x.idx]), d.push(n[x.idx1]), g.push(
- e.getRawIndex(x.idx1));
- break;
- case "+":
- S = x.idx;
- u.push(o.dataToPoint([e.get(m.dataDimsForPoint[0], S), e.get(m.dataDimsForPoint[1], S)])), h.push(e.getItemLayout(
- S).slice()), c.push(Cu(m, o, e, S)), d.push(n[S]), g.push(e.getRawIndex(S));
- break;
- case "-":
- var S = x.idx,
- M = t.getRawIndex(S);
- M !== S ? (u.push(t.getItemLayout(S)), h.push(a.dataToPoint([t.get(v.dataDimsForPoint[0], S), t.get(v.dataDimsForPoint[
- 1], S)])), c.push(i[S]), d.push(Cu(v, a, t, S)), g.push(M)) : _ = !1
- }
- _ && (f.push(x), p.push(p.length))
- }
- p.sort(function(t, e) {
- return g[t] - g[e]
- });
- for (var I = [], T = [], A = [], D = [], C = [], y = 0; y < p.length; y++) {
- S = p[y];
- I[y] = u[S], T[y] = h[S], A[y] = c[S], D[y] = d[S], C[y] = f[S]
- }
- return {
- current: I,
- next: T,
- stackedOnCurrent: A,
- stackedOnNext: D,
- status: C
- }
- },
- eD = tt,
- iD = et,
- nD = Z,
- oD = G,
- aD = [],
- rD = [],
- sD = [],
- lD = kn.extend({
- type: "ec-polyline",
- shape: {
- points: [],
- smooth: 0,
- smoothConstraint: !0,
- smoothMonotone: null,
- connectNulls: !1
- },
- style: {
- fill: null,
- stroke: "#000"
- },
- brush: JS(kn.prototype.brush),
- buildPath: function(t, e) {
- var i = e.points,
- n = 0,
- o = i.length,
- a = Eu(i, e.smoothConstraint);
- if (e.connectNulls) {
- for (; o > 0 && ku(i[o - 1]); o--);
- for (; n < o && ku(i[n]); n++);
- }
- for (; n < o;) n += Pu(t, i, n, o, o, 1, a.min, a.max, e.smooth, e.smoothMonotone, e.connectNulls) + 1
- }
- }),
- uD = kn.extend({
- type: "ec-polygon",
- shape: {
- points: [],
- stackedOnPoints: [],
- smooth: 0,
- stackedOnSmooth: 0,
- smoothConstraint: !0,
- smoothMonotone: null,
- connectNulls: !1
- },
- brush: JS(kn.prototype.brush),
- buildPath: function(t, e) {
- var i = e.points,
- n = e.stackedOnPoints,
- o = 0,
- a = i.length,
- r = e.smoothMonotone,
- s = Eu(i, e.smoothConstraint),
- l = Eu(n, e.smoothConstraint);
- if (e.connectNulls) {
- for (; a > 0 && ku(i[a - 1]); a--);
- for (; o < a && ku(i[o]); o++);
- }
- for (; o < a;) {
- var u = Pu(t, i, o, a, a, 1, s.min, s.max, e.smooth, r, e.connectNulls);
- Pu(t, n, o + u - 1, u, a, -1, l.min, l.max, e.stackedOnSmooth, r, e.connectNulls), o += u + 1, t.closePath()
- }
- }
- });
- Mr.extend({
- type: "line",
- init: function() {
- var t = new Zw,
- e = new Su;
- this.group.add(e.group), this._symbolDraw = e, this._lineGroup = t
- },
- render: function(t, e, i) {
- var n = t.coordinateSystem,
- o = this.group,
- a = t.getData(),
- s = t.getModel("lineStyle"),
- l = t.getModel("areaStyle"),
- u = a.mapArray(a.getItemLayout),
- h = "polar" === n.type,
- c = this._coordSys,
- d = this._symbolDraw,
- f = this._polyline,
- p = this._polygon,
- g = this._lineGroup,
- m = t.get("animation"),
- v = !l.isEmpty(),
- y = l.get("origin"),
- x = Vu(n, a, Au(n, a, y)),
- _ = t.get("showSymbol"),
- w = _ && !h && Uu(t, a, n),
- b = this._data;
- b && b.eachItemGraphicEl(function(t, e) {
- t.__temp && (o.remove(t), b.setItemGraphicEl(e, null))
- }), _ || d.remove(), o.add(g);
- var S = !h && t.get("step");
- f && c.type === n.type && S === this._step ? (v && !p ? p = this._newPolygon(u, x, n, m) : p && !v && (g.remove(
- p), p = this._polygon = null), g.setClipPath(Wu(n, !1, !1, t)), _ && d.updateData(a, {
- isIgnore: w,
- clipShape: Wu(n, !1, !0, t)
- }), a.eachItemGraphicEl(function(t) {
- t.stopAnimation(!0)
- }), Ru(this._stackedOnPoints, x) && Ru(this._points, u) || (m ? this._updateAnimation(a, x, n, i, S, y) : (S &&
- (u = Hu(u, n, S), x = Hu(x, n, S)), f.setShape({
- points: u
- }), p && p.setShape({
- points: u,
- stackedOnPoints: x
- })))) : (_ && d.updateData(a, {
- isIgnore: w,
- clipShape: Wu(n, !1, !0, t)
- }), S && (u = Hu(u, n, S), x = Hu(x, n, S)), f = this._newPolyline(u, n, m), v && (p = this._newPolygon(u, x,
- n, m)), g.setClipPath(Wu(n, !0, !1, t)));
- var M = Zu(a, n) || a.getVisual("color");
- f.useStyle(r(s.getLineStyle(), {
- fill: "none",
- stroke: M,
- lineJoin: "bevel"
- }));
- var I = t.get("smooth");
- if (I = zu(t.get("smooth")), f.setShape({
- smooth: I,
- smoothMonotone: t.get("smoothMonotone"),
- connectNulls: t.get("connectNulls")
- }), p) {
- var T = a.getCalculationInfo("stackedOnSeries"),
- A = 0;
- p.useStyle(r(l.getAreaStyle(), {
- fill: M,
- opacity: .7,
- lineJoin: "bevel"
- })), T && (A = zu(T.get("smooth"))), p.setShape({
- smooth: I,
- stackedOnSmooth: A,
- smoothMonotone: t.get("smoothMonotone"),
- connectNulls: t.get("connectNulls")
- })
- }
- this._data = a, this._coordSys = n, this._stackedOnPoints = x, this._points = u, this._step = S, this._valueOrigin =
- y
- },
- dispose: function() {},
- highlight: function(t, e, i, n) {
- var o = t.getData(),
- a = zi(o, n);
- if (!(a instanceof Array) && null != a && a >= 0) {
- var r = o.getItemGraphicEl(a);
- if (!r) {
- var s = o.getItemLayout(a);
- if (!s) return;
- (r = new mu(o, a)).position = s, r.setZ(t.get("zlevel"), t.get("z")), r.ignore = isNaN(s[0]) || isNaN(s[1]), r
- .__temp = !0, o.setItemGraphicEl(a, r), r.stopSymbolAnimation(!0), this.group.add(r)
- }
- r.highlight()
- } else Mr.prototype.highlight.call(this, t, e, i, n)
- },
- downplay: function(t, e, i, n) {
- var o = t.getData(),
- a = zi(o, n);
- if (null != a && a >= 0) {
- var r = o.getItemGraphicEl(a);
- r && (r.__temp ? (o.setItemGraphicEl(a, null), this.group.remove(r)) : r.downplay())
- } else Mr.prototype.downplay.call(this, t, e, i, n)
- },
- _newPolyline: function(t) {
- var e = this._polyline;
- return e && this._lineGroup.remove(e), e = new lD({
- shape: {
- points: t
- },
- silent: !0,
- z2: 10
- }), this._lineGroup.add(e), this._polyline = e, e
- },
- _newPolygon: function(t, e) {
- var i = this._polygon;
- return i && this._lineGroup.remove(i), i = new uD({
- shape: {
- points: t,
- stackedOnPoints: e
- },
- silent: !0
- }), this._lineGroup.add(i), this._polygon = i, i
- },
- _updateAnimation: function(t, e, i, n, o, a) {
- var r = this._polyline,
- s = this._polygon,
- l = t.hostModel,
- u = tD(this._data, t, this._stackedOnPoints, e, this._coordSys, i, this._valueOrigin, a),
- h = u.current,
- c = u.stackedOnCurrent,
- d = u.next,
- f = u.stackedOnNext;
- o && (h = Hu(u.current, i, o), c = Hu(u.stackedOnCurrent, i, o), d = Hu(u.next, i, o), f = Hu(u.stackedOnNext, i,
- o)), r.shape.__points = u.current, r.shape.points = h, bo(r, {
- shape: {
- points: d
- }
- }, l), s && (s.setShape({
- points: h,
- stackedOnPoints: c
- }), bo(s, {
- shape: {
- points: d,
- stackedOnPoints: f
- }
- }, l));
- for (var p = [], g = u.status, m = 0; m < g.length; m++)
- if ("=" === g[m].cmd) {
- var v = t.getItemGraphicEl(g[m].idx1);
- v && p.push({
- el: v,
- ptIdx: m
- })
- } r.animators && r.animators.length && r.animators[0].during(function() {
- for (var t = 0; t < p.length; t++) p[t].el.attr("position", r.shape.__points[p[t].ptIdx])
- })
- },
- remove: function(t) {
- var e = this.group,
- i = this._data;
- this._lineGroup.removeAll(), this._symbolDraw.remove(!0), i && i.eachItemGraphicEl(function(t, n) {
- t.__temp && (e.remove(t), i.setItemGraphicEl(n, null))
- }), this._polyline = this._polygon = this._coordSys = this._points = this._stackedOnPoints = this._data = null
- }
- });
- var hD = function(t, e, i) {
- return {
- seriesType: t,
- performRawSeries: !0,
- reset: function(t, n, o) {
- var a = t.getData(),
- r = t.get("symbol") || e,
- s = t.get("symbolSize"),
- l = t.get("symbolKeepAspect");
- if (a.setVisual({
- legendSymbol: i || r,
- symbol: r,
- symbolSize: s,
- symbolKeepAspect: l
- }), !n.isSeriesFiltered(t)) {
- var u = "function" == typeof s;
- return {
- dataEach: a.hasItemOption || u ? function(e, i) {
- if ("function" == typeof s) {
- var n = t.getRawValue(i),
- o = t.getDataParams(i);
- e.setItemVisual(i, "symbolSize", s(n, o))
- }
- if (e.hasItemOption) {
- var a = e.getItemModel(i),
- r = a.getShallow("symbol", !0),
- l = a.getShallow("symbolSize", !0),
- u = a.getShallow("symbolKeepAspect", !0);
- null != r && e.setItemVisual(i, "symbol", r), null != l && e.setItemVisual(i, "symbolSize", l), null != u &&
- e.setItemVisual(i, "symbolKeepAspect", u)
- }
- } : null
- }
- }
- }
- }
- },
- cD = function(t) {
- return {
- seriesType: t,
- plan: zI(),
- reset: function(t) {
- var e = t.getData(),
- i = t.coordinateSystem,
- n = t.pipelineContext.large;
- if (i) {
- var o = f(i.dimensions, function(t) {
- return e.mapDimension(t)
- }).slice(0, 2),
- a = o.length,
- r = e.getCalculationInfo("stackResultDimension");
- return hl(e, o[0]) && (o[0] = r), hl(e, o[1]) && (o[1] = r), a && {
- progress: function(t, e) {
- for (var r = t.end - t.start, s = n && new Float32Array(r * a), l = t.start, u = 0, h = [], c = []; l < t.end; l++) {
- var d;
- if (1 === a) f = e.get(o[0], l), d = !isNaN(f) && i.dataToPoint(f, null, c);
- else {
- var f = h[0] = e.get(o[0], l),
- p = h[1] = e.get(o[1], l);
- d = !isNaN(f) && !isNaN(p) && i.dataToPoint(h, null, c)
- }
- n ? (s[u++] = d ? d[0] : NaN, s[u++] = d ? d[1] : NaN) : e.setItemLayout(l, d && d.slice() || [NaN, NaN])
- }
- n && e.setLayout("symbolPoints", s)
- }
- }
- }
- }
- }
- },
- dD = {
- average: function(t) {
- for (var e = 0, i = 0, n = 0; n < t.length; n++) isNaN(t[n]) || (e += t[n], i++);
- return 0 === i ? NaN : e / i
- },
- sum: function(t) {
- for (var e = 0, i = 0; i < t.length; i++) e += t[i] || 0;
- return e
- },
- max: function(t) {
- for (var e = -1 / 0, i = 0; i < t.length; i++) t[i] > e && (e = t[i]);
- return isFinite(e) ? e : NaN
- },
- min: function(t) {
- for (var e = 1 / 0, i = 0; i < t.length; i++) t[i] < e && (e = t[i]);
- return isFinite(e) ? e : NaN
- },
- nearest: function(t) {
- return t[0]
- }
- },
- fD = function(t, e) {
- return Math.round(t.length / 2)
- },
- pD = function(t) {
- this._axes = {}, this._dimList = [], this.name = t || ""
- };
- pD.prototype = {
- constructor: pD,
- type: "cartesian",
- getAxis: function(t) {
- return this._axes[t]
- },
- getAxes: function() {
- return f(this._dimList, ju, this)
- },
- getAxesByScale: function(t) {
- return t = t.toLowerCase(), g(this.getAxes(), function(e) {
- return e.scale.type === t
- })
- },
- addAxis: function(t) {
- var e = t.dim;
- this._axes[e] = t, this._dimList.push(e)
- },
- dataToCoord: function(t) {
- return this._dataCoordConvert(t, "dataToCoord")
- },
- coordToData: function(t) {
- return this._dataCoordConvert(t, "coordToData")
- },
- _dataCoordConvert: function(t, e) {
- for (var i = this._dimList, n = t instanceof Array ? [] : {}, o = 0; o < i.length; o++) {
- var a = i[o],
- r = this._axes[a];
- n[a] = r[e](t[a])
- }
- return n
- }
- }, Yu.prototype = {
- constructor: Yu,
- type: "cartesian2d",
- dimensions: ["x", "y"],
- getBaseAxis: function() {
- return this.getAxesByScale("ordinal")[0] || this.getAxesByScale("time")[0] || this.getAxis("x")
- },
- containPoint: function(t) {
- var e = this.getAxis("x"),
- i = this.getAxis("y");
- return e.contain(e.toLocalCoord(t[0])) && i.contain(i.toLocalCoord(t[1]))
- },
- containData: function(t) {
- return this.getAxis("x").containData(t[0]) && this.getAxis("y").containData(t[1])
- },
- dataToPoint: function(t, e, i) {
- var n = this.getAxis("x"),
- o = this.getAxis("y");
- return i = i || [], i[0] = n.toGlobalCoord(n.dataToCoord(t[0])), i[1] = o.toGlobalCoord(o.dataToCoord(t[1])), i
- },
- clampData: function(t, e) {
- var i = this.getAxis("x").scale,
- n = this.getAxis("y").scale,
- o = i.getExtent(),
- a = n.getExtent(),
- r = i.parse(t[0]),
- s = n.parse(t[1]);
- return e = e || [], e[0] = Math.min(Math.max(Math.min(o[0], o[1]), r), Math.max(o[0], o[1])), e[1] = Math.min(
- Math.max(Math.min(a[0], a[1]), s), Math.max(a[0], a[1])), e
- },
- pointToData: function(t, e) {
- var i = this.getAxis("x"),
- n = this.getAxis("y");
- return e = e || [], e[0] = i.coordToData(i.toLocalCoord(t[0])), e[1] = n.coordToData(n.toLocalCoord(t[1])), e
- },
- getOtherAxis: function(t) {
- return this.getAxis("x" === t.dim ? "y" : "x")
- }
- }, u(Yu, pD);
- var gD = function(t, e, i, n, o) {
- HA.call(this, t, e, i), this.type = n || "value", this.position = o || "bottom"
- };
- gD.prototype = {
- constructor: gD,
- index: 0,
- getAxesOnZeroOf: null,
- model: null,
- isHorizontal: function() {
- var t = this.position;
- return "top" === t || "bottom" === t
- },
- getGlobalExtent: function(t) {
- var e = this.getExtent();
- return e[0] = this.toGlobalCoord(e[0]), e[1] = this.toGlobalCoord(e[1]), t && e[0] > e[1] && e.reverse(), e
- },
- getOtherAxis: function() {
- this.grid.getOtherAxis()
- },
- pointToData: function(t, e) {
- return this.coordToData(this.toLocalCoord(t["x" === this.dim ? 0 : 1]), e)
- },
- toLocalCoord: null,
- toGlobalCoord: null
- }, u(gD, HA);
- var mD = {
- show: !0,
- zlevel: 0,
- z: 0,
- inverse: !1,
- name: "",
- nameLocation: "end",
- nameRotate: null,
- nameTruncate: {
- maxWidth: null,
- ellipsis: "...",
- placeholder: "."
- },
- nameTextStyle: {},
- nameGap: 15,
- silent: !1,
- triggerEvent: !1,
- tooltip: {
- show: !1
- },
- axisPointer: {},
- axisLine: {
- show: !0,
- onZero: !0,
- onZeroAxisIndex: null,
- lineStyle: {
- color: "#333",
- width: 1,
- type: "solid"
- },
- symbol: ["none", "none"],
- symbolSize: [10, 15]
- },
- axisTick: {
- show: !0,
- inside: !1,
- length: 5,
- lineStyle: {
- width: 1
- }
- },
- axisLabel: {
- show: !0,
- inside: !1,
- rotate: 0,
- showMinLabel: null,
- showMaxLabel: null,
- margin: 8,
- fontSize: 12
- },
- splitLine: {
- show: !0,
- lineStyle: {
- color: ["#ccc"],
- width: 1,
- type: "solid"
- }
- },
- splitArea: {
- show: !1,
- areaStyle: {
- color: ["rgba(250,250,250,0.3)", "rgba(200,200,200,0.3)"]
- }
- }
- },
- vD = {};
- vD.categoryAxis = n({
- boundaryGap: !0,
- deduplication: null,
- splitLine: {
- show: !1
- },
- axisTick: {
- alignWithLabel: !1,
- interval: "auto"
- },
- axisLabel: {
- interval: "auto"
- }
- }, mD), vD.valueAxis = n({
- boundaryGap: [0, 0],
- splitNumber: 5
- }, mD), vD.timeAxis = r({
- scale: !0,
- min: "dataMin",
- max: "dataMax"
- }, vD.valueAxis), vD.logAxis = r({
- scale: !0,
- logBase: 10
- }, vD.valueAxis);
- var yD = ["value", "category", "time", "log"],
- xD = function(t, e, i, a) {
- d(yD, function(r) {
- e.extend({
- type: t + "Axis." + r,
- mergeDefaultAndTheme: function(e, o) {
- var a = this.layoutMode,
- s = a ? da(e) : {};
- n(e, o.getTheme().get(r + "Axis")), n(e, this.getDefaultOption()), e.type = i(t, e), a && ca(e, s, a)
- },
- optionUpdated: function() {
- "category" === this.option.type && (this.__ordinalMeta = ml.createByAxisModel(this))
- },
- getCategories: function(t) {
- var e = this.option;
- if ("category" === e.type) return t ? e.data : this.__ordinalMeta.categories
- },
- getOrdinalMeta: function() {
- return this.__ordinalMeta
- },
- defaultOption: o([{}, vD[r + "Axis"], a], !0)
- })
- }), YM.registerSubTypeDefaulter(t + "Axis", v(i, t))
- },
- _D = YM.extend({
- type: "cartesian2dAxis",
- axis: null,
- init: function() {
- _D.superApply(this, "init", arguments), this.resetRange()
- },
- mergeOption: function() {
- _D.superApply(this, "mergeOption", arguments), this.resetRange()
- },
- restoreData: function() {
- _D.superApply(this, "restoreData", arguments), this.resetRange()
- },
- getCoordSysModel: function() {
- return this.ecModel.queryComponents({
- mainType: "grid",
- index: this.option.gridIndex,
- id: this.option.gridId
- })[0]
- }
- });
- n(_D.prototype, CA);
- var wD = {
- offset: 0
- };
- xD("x", _D, qu, wD), xD("y", _D, qu, wD), YM.extend({
- type: "grid",
- dependencies: ["xAxis", "yAxis"],
- layoutMode: "box",
- coordinateSystem: null,
- defaultOption: {
- show: !1,
- zlevel: 0,
- z: 0,
- left: "10%",
- top: 60,
- right: "10%",
- bottom: 60,
- containLabel: !1,
- backgroundColor: "rgba(0,0,0,0)",
- borderWidth: 1,
- borderColor: "#ccc"
- }
- });
- var bD = $u.prototype;
- bD.type = "grid", bD.axisPointerEnabled = !0, bD.getRect = function() {
- return this._rect
- }, bD.update = function(t, e) {
- var i = this._axesMap;
- this._updateScale(t, this.model), d(i.x, function(t) {
- Bl(t.scale, t.model)
- }), d(i.y, function(t) {
- Bl(t.scale, t.model)
- });
- var n = {};
- d(i.x, function(t) {
- Ju(i, "y", t, n)
- }), d(i.y, function(t) {
- Ju(i, "x", t, n)
- }), this.resize(this.model, e)
- }, bD.resize = function(t, e, i) {
- function n() {
- d(a, function(t) {
- var e = t.isHorizontal(),
- i = e ? [0, o.width] : [0, o.height],
- n = t.inverse ? 1 : 0;
- t.setExtent(i[n], i[1 - n]), th(t, e ? o.x : o.y)
- })
- }
- var o = la(t.getBoxLayoutParams(), {
- width: e.getWidth(),
- height: e.getHeight()
- });
- this._rect = o;
- var a = this._axesList;
- n(), !i && t.get("containLabel") && (d(a, function(t) {
- if (!t.model.get("axisLabel.inside")) {
- var e = Hl(t);
- if (e) {
- var i = t.isHorizontal() ? "height" : "width",
- n = t.model.get("axisLabel.margin");
- o[i] -= e[i] + n, "top" === t.position ? o.y += e.height + n : "left" === t.position && (o.x += e.width + n)
- }
- }
- }), n())
- }, bD.getAxis = function(t, e) {
- var i = this._axesMap[t];
- if (null != i) {
- if (null == e)
- for (var n in i)
- if (i.hasOwnProperty(n)) return i[n];
- return i[e]
- }
- }, bD.getAxes = function() {
- return this._axesList.slice()
- }, bD.getCartesian = function(t, e) {
- if (null != t && null != e) {
- var i = "x" + t + "y" + e;
- return this._coordsMap[i]
- }
- w(t) && (e = t.yAxisIndex, t = t.xAxisIndex);
- for (var n = 0, o = this._coordsList; n < o.length; n++)
- if (o[n].getAxis("x").index === t || o[n].getAxis("y").index === e) return o[n]
- }, bD.getCartesians = function() {
- return this._coordsList.slice()
- }, bD.convertToPixel = function(t, e, i) {
- var n = this._findConvertTarget(t, e);
- return n.cartesian ? n.cartesian.dataToPoint(i) : n.axis ? n.axis.toGlobalCoord(n.axis.dataToCoord(i)) : null
- }, bD.convertFromPixel = function(t, e, i) {
- var n = this._findConvertTarget(t, e);
- return n.cartesian ? n.cartesian.pointToData(i) : n.axis ? n.axis.coordToData(n.axis.toLocalCoord(i)) : null
- }, bD._findConvertTarget = function(t, e) {
- var i, n, o = e.seriesModel,
- a = e.xAxisModel || o && o.getReferringComponents("xAxis")[0],
- r = e.yAxisModel || o && o.getReferringComponents("yAxis")[0],
- s = e.gridModel,
- u = this._coordsList;
- return o ? l(u, i = o.coordinateSystem) < 0 && (i = null) : a && r ? i = this.getCartesian(a.componentIndex, r.componentIndex) :
- a ? n = this.getAxis("x", a.componentIndex) : r ? n = this.getAxis("y", r.componentIndex) : s && s.coordinateSystem ===
- this && (i = this._coordsList[0]), {
- cartesian: i,
- axis: n
- }
- }, bD.containPoint = function(t) {
- var e = this._coordsList[0];
- if (e) return e.containPoint(t)
- }, bD._initCartesian = function(t, e, i) {
- function n(i) {
- return function(n, s) {
- if (Ku(n, t, e)) {
- var l = n.get("position");
- "x" === i ? "top" !== l && "bottom" !== l && o[l = "bottom"] && (l = "top" === l ? "bottom" : "top") : "left" !==
- l && "right" !== l && o[l = "left"] && (l = "left" === l ? "right" : "left"), o[l] = !0;
- var u = new gD(i, Vl(n), [0, 0], n.get("type"), l),
- h = "category" === u.type;
- u.onBand = h && n.get("boundaryGap"), u.inverse = n.get("inverse"), n.axis = u, u.model = n, u.grid = this, u.index =
- s, this._axesList.push(u), a[i][s] = u, r[i]++
- }
- }
- }
- var o = {
- left: !1,
- right: !1,
- top: !1,
- bottom: !1
- },
- a = {
- x: {},
- y: {}
- },
- r = {
- x: 0,
- y: 0
- };
- if (e.eachComponent("xAxis", n("x"), this), e.eachComponent("yAxis", n("y"), this), !r.x || !r.y) return this._axesMap = {},
- void(this._axesList = []);
- this._axesMap = a, d(a.x, function(e, i) {
- d(a.y, function(n, o) {
- var a = "x" + i + "y" + o,
- r = new Yu(a);
- r.grid = this, r.model = t, this._coordsMap[a] = r, this._coordsList.push(r), r.addAxis(e), r.addAxis(n)
- }, this)
- }, this)
- }, bD._updateScale = function(t, e) {
- function i(t, e, i) {
- d(t.mapDimension(e.dim, !0), function(i) {
- e.scale.unionExtentFromData(t, cl(t, i))
- })
- }
- d(this._axesList, function(t) {
- t.scale.setExtent(1 / 0, -1 / 0)
- }), t.eachSeries(function(n) {
- if (ih(n)) {
- var o = eh(n),
- a = o[0],
- r = o[1];
- if (!Ku(a, e, t) || !Ku(r, e, t)) return;
- var s = this.getCartesian(a.componentIndex, r.componentIndex),
- l = n.getData(),
- u = s.getAxis("x"),
- h = s.getAxis("y");
- "list" === l.type && (i(l, u), i(l, h))
- }
- }, this)
- }, bD.getTooltipAxes = function(t) {
- var e = [],
- i = [];
- return d(this.getCartesians(), function(n) {
- var o = null != t && "auto" !== t ? n.getAxis(t) : n.getBaseAxis(),
- a = n.getOtherAxis(o);
- l(e, o) < 0 && e.push(o), l(i, a) < 0 && i.push(a)
- }), {
- baseAxes: e,
- otherAxes: i
- }
- };
- var SD = ["xAxis", "yAxis"];
- $u.create = function(t, e) {
- var i = [];
- return t.eachComponent("grid", function(n, o) {
- var a = new $u(n, t, e);
- a.name = "grid_" + o, a.resize(n, e, !0), n.coordinateSystem = a, i.push(a)
- }), t.eachSeries(function(t) {
- if (ih(t)) {
- var e = eh(t),
- i = e[0],
- n = e[1],
- o = i.getCoordSysModel().coordinateSystem;
- t.coordinateSystem = o.getCartesian(i.componentIndex, n.componentIndex)
- }
- }), i
- }, $u.dimensions = $u.prototype.dimensions = Yu.prototype.dimensions, Ba.register("cartesian2d", $u);
- var MD = Math.PI,
- ID = function(t, e) {
- this.opt = e, this.axisModel = t, r(e, {
- labelOffset: 0,
- nameDirection: 1,
- tickDirection: 1,
- labelDirection: 1,
- silent: !0
- }), this.group = new Zw;
- var i = new Zw({
- position: e.position.slice(),
- rotation: e.rotation
- });
- i.updateTransform(), this._transform = i.transform, this._dumbGroup = i
- };
- ID.prototype = {
- constructor: ID,
- hasBuilder: function(t) {
- return !!TD[t]
- },
- add: function(t) {
- TD[t].call(this)
- },
- getGroup: function() {
- return this.group
- }
- };
- var TD = {
- axisLine: function() {
- var t = this.opt,
- e = this.axisModel;
- if (e.get("axisLine.show")) {
- var i = this.axisModel.axis.getExtent(),
- n = this._transform,
- o = [i[0], 0],
- r = [i[1], 0];
- n && (Q(o, o, n), Q(r, r, n));
- var s = a({
- lineCap: "round"
- }, e.getModel("axisLine.lineStyle").getLineStyle());
- this.group.add(new rM(Xn({
- anid: "line",
- shape: {
- x1: o[0],
- y1: o[1],
- x2: r[0],
- y2: r[1]
- },
- style: s,
- strokeContainThreshold: t.strokeContainThreshold || 5,
- silent: !0,
- z2: 1
- })));
- var l = e.get("axisLine.symbol"),
- u = e.get("axisLine.symbolSize"),
- h = e.get("axisLine.symbolOffset") || 0;
- if ("number" == typeof h && (h = [h, h]), null != l) {
- "string" == typeof l && (l = [l, l]), "string" != typeof u && "number" != typeof u || (u = [u, u]);
- var c = u[0],
- f = u[1];
- d([{
- rotate: t.rotation + Math.PI / 2,
- offset: h[0],
- r: 0
- }, {
- rotate: t.rotation - Math.PI / 2,
- offset: h[1],
- r: Math.sqrt((o[0] - r[0]) * (o[0] - r[0]) + (o[1] - r[1]) * (o[1] - r[1]))
- }], function(e, i) {
- if ("none" !== l[i] && null != l[i]) {
- var n = Xl(l[i], -c / 2, -f / 2, c, f, s.stroke, !0),
- a = e.r + e.offset,
- r = [o[0] + a * Math.cos(t.rotation), o[1] - a * Math.sin(t.rotation)];
- n.attr({
- rotation: e.rotate,
- position: r,
- silent: !0
- }), this.group.add(n)
- }
- }, this)
- }
- }
- },
- axisTickLabel: function() {
- var t = this.axisModel,
- e = this.opt,
- i = hh(this, t, e);
- rh(t, ch(this, t, e), i)
- },
- axisName: function() {
- var t = this.opt,
- e = this.axisModel,
- i = T(t.axisName, e.get("name"));
- if (i) {
- var n, o = e.get("nameLocation"),
- r = t.nameDirection,
- s = e.getModel("nameTextStyle"),
- l = e.get("nameGap") || 0,
- u = this.axisModel.axis.getExtent(),
- h = u[0] > u[1] ? -1 : 1,
- c = ["start" === o ? u[0] - h * l : "end" === o ? u[1] + h * l : (u[0] + u[1]) / 2, uh(o) ? t.labelOffset + r *
- l : 0
- ],
- d = e.get("nameRotate");
- null != d && (d = d * MD / 180);
- var f;
- uh(o) ? n = AD(t.rotation, null != d ? d : t.rotation, r) : (n = oh(t, o, d || 0, u), null != (f = t.axisNameAvailableWidth) &&
- (f = Math.abs(f / Math.sin(n.rotation)), !isFinite(f) && (f = null)));
- var p = s.getFont(),
- g = e.get("nameTruncate", !0) || {},
- m = g.ellipsis,
- v = T(t.nameTruncateMaxWidth, g.maxWidth, f),
- y = null != m && null != v ? VM(i, v, p, m, {
- minChar: 2,
- placeholder: g.placeholder
- }) : i,
- x = e.get("tooltip", !0),
- _ = e.mainType,
- w = {
- componentType: _,
- name: i,
- $vars: ["name"]
- };
- w[_ + "Index"] = e.componentIndex;
- var b = new qS({
- anid: "name",
- __fullText: i,
- __truncatedText: y,
- position: c,
- rotation: n.rotation,
- silent: ah(e),
- z2: 1,
- tooltip: x && x.show ? a({
- content: i,
- formatter: function() {
- return i
- },
- formatterParams: w
- }, x) : null
- });
- fo(b.style, s, {
- text: y,
- textFont: p,
- textFill: s.getTextColor() || e.get("axisLine.lineStyle.color"),
- textAlign: n.textAlign,
- textVerticalAlign: n.textVerticalAlign
- }), e.get("triggerEvent") && (b.eventData = nh(e), b.eventData.targetType = "axisName", b.eventData.name = i),
- this._dumbGroup.add(b), b.updateTransform(), this.group.add(b), b.decomposeTransform()
- }
- }
- },
- AD = ID.innerTextLayout = function(t, e, i) {
- var n, o, a = Ho(e - t);
- return Zo(a) ? (o = i > 0 ? "top" : "bottom", n = "center") : Zo(a - MD) ? (o = i > 0 ? "bottom" : "top", n =
- "center") : (o = "middle", n = a > 0 && a < MD ? i > 0 ? "right" : "left" : i > 0 ? "left" : "right"), {
- rotation: a,
- textAlign: n,
- textVerticalAlign: o
- }
- },
- DD = d,
- CD = v,
- LD = Vs({
- type: "axis",
- _axisPointer: null,
- axisPointerClass: null,
- render: function(t, e, i, n) {
- this.axisPointerClass && yh(t), LD.superApply(this, "render", arguments), Sh(this, t, 0, i, 0, !0)
- },
- updateAxisPointer: function(t, e, i, n, o) {
- Sh(this, t, 0, i, 0, !1)
- },
- remove: function(t, e) {
- var i = this._axisPointer;
- i && i.remove(e), LD.superApply(this, "remove", arguments)
- },
- dispose: function(t, e) {
- Mh(this, e), LD.superApply(this, "dispose", arguments)
- }
- }),
- kD = [];
- LD.registerAxisPointerClass = function(t, e) {
- kD[t] = e
- }, LD.getAxisPointerClass = function(t) {
- return t && kD[t]
- };
- var PD = ["axisLine", "axisTickLabel", "axisName"],
- ND = ["splitArea", "splitLine"],
- OD = LD.extend({
- type: "cartesianAxis",
- axisPointerClass: "CartesianAxisPointer",
- render: function(t, e, i, n) {
- this.group.removeAll();
- var o = this._axisGroup;
- if (this._axisGroup = new Zw, this.group.add(this._axisGroup), t.get("show")) {
- var a = t.getCoordSysModel(),
- r = Ih(a, t),
- s = new ID(t, r);
- d(PD, s.add, s), this._axisGroup.add(s.getGroup()), d(ND, function(e) {
- t.get(e + ".show") && this["_" + e](t, a)
- }, this), Ao(o, this._axisGroup, t), OD.superCall(this, "render", t, e, i, n)
- }
- },
- remove: function() {
- this._splitAreaColors = null
- },
- _splitLine: function(t, e) {
- var i = t.axis;
- if (!i.scale.isBlank()) {
- var n = t.getModel("splitLine"),
- o = n.getModel("lineStyle"),
- a = o.get("color");
- a = y(a) ? a : [a];
- for (var s = e.coordinateSystem.getRect(), l = i.isHorizontal(), u = 0, h = i.getTicksCoords({
- tickModel: n
- }), c = [], d = [], f = o.getLineStyle(), p = 0; p < h.length; p++) {
- var g = i.toGlobalCoord(h[p].coord);
- l ? (c[0] = g, c[1] = s.y, d[0] = g, d[1] = s.y + s.height) : (c[0] = s.x, c[1] = g, d[0] = s.x + s.width, d[1] =
- g);
- var m = u++ % a.length,
- v = h[p].tickValue;
- this._axisGroup.add(new rM(Xn({
- anid: null != v ? "line_" + h[p].tickValue : null,
- shape: {
- x1: c[0],
- y1: c[1],
- x2: d[0],
- y2: d[1]
- },
- style: r({
- stroke: a[m]
- }, f),
- silent: !0
- })))
- }
- }
- },
- _splitArea: function(t, e) {
- var i = t.axis;
- if (!i.scale.isBlank()) {
- var n = t.getModel("splitArea"),
- o = n.getModel("areaStyle"),
- a = o.get("color"),
- s = e.coordinateSystem.getRect(),
- l = i.getTicksCoords({
- tickModel: n,
- clamp: !0
- });
- if (l.length) {
- var u = a.length,
- h = this._splitAreaColors,
- c = R(),
- d = 0;
- if (h)
- for (m = 0; m < l.length; m++) {
- var f = h.get(l[m].tickValue);
- if (null != f) {
- d = (f + (u - 1) * m) % u;
- break
- }
- }
- var p = i.toGlobalCoord(l[0].coord),
- g = o.getAreaStyle();
- a = y(a) ? a : [a];
- for (var m = 1; m < l.length; m++) {
- var v, x, _, w, b = i.toGlobalCoord(l[m].coord);
- i.isHorizontal() ? (v = p, x = s.y, _ = b - v, w = s.height, p = v + _) : (v = s.x, x = p, _ = s.width, p = x +
- (w = b - x));
- var S = l[m - 1].tickValue;
- null != S && c.set(S, d), this._axisGroup.add(new aM({
- anid: null != S ? "area_" + S : null,
- shape: {
- x: v,
- y: x,
- width: _,
- height: w
- },
- style: r({
- fill: a[d]
- }, g),
- silent: !0
- })), d = (d + 1) % u
- }
- this._splitAreaColors = c
- }
- }
- }
- });
- OD.extend({
- type: "xAxis"
- }), OD.extend({
- type: "yAxis"
- }), Vs({
- type: "grid",
- render: function(t, e) {
- this.group.removeAll(), t.get("show") && this.group.add(new aM({
- shape: t.coordinateSystem.getRect(),
- style: r({
- fill: t.get("backgroundColor")
- }, t.getItemStyle()),
- silent: !0,
- z2: -1
- }))
- }
- }), Ls(function(t) {
- t.xAxis && t.yAxis && !t.grid && (t.grid = {})
- }), Es(hD("line", "circle", "line")), Os(cD("line")), ks(IT.PROCESSOR.STATISTIC, function(t) {
- return {
- seriesType: t,
- modifyOutputEnd: !0,
- reset: function(t, e, i) {
- var n = t.getData(),
- o = t.get("sampling"),
- a = t.coordinateSystem;
- if ("cartesian2d" === a.type && o) {
- var r = a.getBaseAxis(),
- s = a.getOtherAxis(r),
- l = r.getExtent(),
- u = l[1] - l[0],
- h = Math.round(n.count() / u);
- if (h > 1) {
- var c;
- "string" == typeof o ? c = dD[o] : "function" == typeof o && (c = o), c && t.setData(n.downSample(n.mapDimension(
- s.dim), 1 / h, c, fD))
- }
- }
- }
- }
- }("line"));
- var ED = OI.extend({
- type: "series.__base_bar__",
- getInitialData: function(t, e) {
- return dl(this.getSource(), this)
- },
- getMarkerPosition: function(t) {
- var e = this.coordinateSystem;
- if (e) {
- var i = e.dataToPoint(e.clampData(t)),
- n = this.getData(),
- o = n.getLayout("offset"),
- a = n.getLayout("size");
- return i[e.getBaseAxis().isHorizontal() ? 0 : 1] += o + a / 2, i
- }
- return [NaN, NaN]
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "cartesian2d",
- legendHoverLink: !0,
- barMinHeight: 0,
- barMinAngle: 0,
- large: !1,
- largeThreshold: 400,
- progressive: 3e3,
- progressiveChunkMode: "mod",
- itemStyle: {},
- emphasis: {}
- }
- });
- ED.extend({
- type: "series.bar",
- dependencies: ["grid", "polar"],
- brushSelector: "rect",
- getProgressive: function() {
- return !!this.get("large") && this.get("progressive")
- },
- getProgressiveThreshold: function() {
- var t = this.get("progressiveThreshold"),
- e = this.get("largeThreshold");
- return e > t && (t = e), t
- }
- });
- var RD = Wb([
- ["fill", "color"],
- ["stroke", "borderColor"],
- ["lineWidth", "borderWidth"],
- ["stroke", "barBorderColor"],
- ["lineWidth", "barBorderWidth"],
- ["opacity"],
- ["shadowBlur"],
- ["shadowOffsetX"],
- ["shadowOffsetY"],
- ["shadowColor"]
- ]),
- zD = {
- getBarItemStyle: function(t) {
- var e = RD(this, t);
- if (this.getBorderLineDash) {
- var i = this.getBorderLineDash();
- i && (e.lineDash = i)
- }
- return e
- }
- },
- BD = ["itemStyle", "barBorderWidth"];
- a(Lo.prototype, zD), Fs({
- type: "bar",
- render: function(t, e, i) {
- this._updateDrawMode(t);
- var n = t.get("coordinateSystem");
- return "cartesian2d" !== n && "polar" !== n || (this._isLargeDraw ? this._renderLarge(t, e, i) : this._renderNormal(
- t, e, i)), this.group
- },
- incrementalPrepareRender: function(t, e, i) {
- this._clear(), this._updateDrawMode(t)
- },
- incrementalRender: function(t, e, i, n) {
- this._incrementalRenderLarge(t, e)
- },
- _updateDrawMode: function(t) {
- var e = t.pipelineContext.large;
- (null == this._isLargeDraw || e ^ this._isLargeDraw) && (this._isLargeDraw = e, this._clear())
- },
- _renderNormal: function(t, e, i) {
- var n, o = this.group,
- a = t.getData(),
- r = this._data,
- s = t.coordinateSystem,
- l = s.getBaseAxis();
- "cartesian2d" === s.type ? n = l.isHorizontal() : "polar" === s.type && (n = "angle" === l.dim);
- var u = t.isAnimationEnabled() ? t : null;
- a.diff(r).add(function(e) {
- if (a.hasValue(e)) {
- var i = a.getItemModel(e),
- r = GD[s.type](a, e, i),
- l = VD[s.type](a, e, i, r, n, u);
- a.setItemGraphicEl(e, l), o.add(l), Lh(l, a, e, i, r, t, n, "polar" === s.type)
- }
- }).update(function(e, i) {
- var l = r.getItemGraphicEl(i);
- if (a.hasValue(e)) {
- var h = a.getItemModel(e),
- c = GD[s.type](a, e, h);
- l ? bo(l, {
- shape: c
- }, u, e) : l = VD[s.type](a, e, h, c, n, u, !0), a.setItemGraphicEl(e, l), o.add(l), Lh(l, a, e, h, c, t, n,
- "polar" === s.type)
- } else o.remove(l)
- }).remove(function(t) {
- var e = r.getItemGraphicEl(t);
- "cartesian2d" === s.type ? e && Dh(t, u, e) : e && Ch(t, u, e)
- }).execute(), this._data = a
- },
- _renderLarge: function(t, e, i) {
- this._clear(), Ph(t, this.group)
- },
- _incrementalRenderLarge: function(t, e) {
- Ph(e, this.group, !0)
- },
- dispose: B,
- remove: function(t) {
- this._clear(t)
- },
- _clear: function(t) {
- var e = this.group,
- i = this._data;
- t && t.get("animation") && i && !this._isLargeDraw ? i.eachItemGraphicEl(function(e) {
- "sector" === e.type ? Ch(e.dataIndex, t, e) : Dh(e.dataIndex, t, e)
- }) : e.removeAll(), this._data = null
- }
- });
- var VD = {
- cartesian2d: function(t, e, i, n, o, r, s) {
- var l = new aM({
- shape: a({}, n)
- });
- if (r) {
- var u = l.shape,
- h = o ? "height" : "width",
- c = {};
- u[h] = 0, c[h] = n[h], bM[s ? "updateProps" : "initProps"](l, {
- shape: c
- }, r, e)
- }
- return l
- },
- polar: function(t, e, i, n, o, a, s) {
- var l = n.startAngle < n.endAngle,
- u = new QS({
- shape: r({
- clockwise: l
- }, n)
- });
- if (a) {
- var h = u.shape,
- c = o ? "r" : "endAngle",
- d = {};
- h[c] = o ? 0 : n.startAngle, d[c] = n[c], bM[s ? "updateProps" : "initProps"](u, {
- shape: d
- }, a, e)
- }
- return u
- }
- },
- GD = {
- cartesian2d: function(t, e, i) {
- var n = t.getItemLayout(e),
- o = kh(i, n),
- a = n.width > 0 ? 1 : -1,
- r = n.height > 0 ? 1 : -1;
- return {
- x: n.x + a * o / 2,
- y: n.y + r * o / 2,
- width: n.width - a * o,
- height: n.height - r * o
- }
- },
- polar: function(t, e, i) {
- var n = t.getItemLayout(e);
- return {
- cx: n.cx,
- cy: n.cy,
- r0: n.r0,
- r: n.r,
- startAngle: n.startAngle,
- endAngle: n.endAngle
- }
- }
- },
- FD = kn.extend({
- type: "largeBar",
- shape: {
- points: []
- },
- buildPath: function(t, e) {
- for (var i = e.points, n = this.__startPoint, o = this.__valueIdx, a = 0; a < i.length; a += 2) n[this.__valueIdx] =
- i[a + o], t.moveTo(n[0], n[1]), t.lineTo(i[a], i[a + 1])
- }
- });
- Os(v(kl, "bar")), Os(fA), Es({
- seriesType: "bar",
- reset: function(t) {
- t.getData().setVisual("legendSymbol", "roundRect")
- }
- });
- var WD = function(t, e, i) {
- e = y(e) && {
- coordDimensions: e
- } || a({}, e);
- var n = t.getSource(),
- o = oA(n, e),
- r = new eA(o, t);
- return r.initData(n, i), r
- },
- HD = {
- updateSelectedMap: function(t) {
- this._targetList = y(t) ? t.slice() : [], this._selectTargetMap = p(t || [], function(t, e) {
- return t.set(e.name, e), t
- }, R())
- },
- select: function(t, e) {
- var i = null != e ? this._targetList[e] : this._selectTargetMap.get(t);
- "single" === this.get("selectedMode") && this._selectTargetMap.each(function(t) {
- t.selected = !1
- }), i && (i.selected = !0)
- },
- unSelect: function(t, e) {
- var i = null != e ? this._targetList[e] : this._selectTargetMap.get(t);
- i && (i.selected = !1)
- },
- toggleSelected: function(t, e) {
- var i = null != e ? this._targetList[e] : this._selectTargetMap.get(t);
- if (null != i) return this[i.selected ? "unSelect" : "select"](t, e), i.selected
- },
- isSelected: function(t, e) {
- var i = null != e ? this._targetList[e] : this._selectTargetMap.get(t);
- return i && i.selected
- }
- },
- ZD = Gs({
- type: "series.pie",
- init: function(t) {
- ZD.superApply(this, "init", arguments), this.legendDataProvider = function() {
- return this.getRawData()
- }, this.updateSelectedMap(this._createSelectableList()), this._defaultLabelLine(t)
- },
- mergeOption: function(t) {
- ZD.superCall(this, "mergeOption", t), this.updateSelectedMap(this._createSelectableList())
- },
- getInitialData: function(t, e) {
- return WD(this, ["value"])
- },
- _createSelectableList: function() {
- for (var t = this.getRawData(), e = t.mapDimension("value"), i = [], n = 0, o = t.count(); n < o; n++) i.push({
- name: t.getName(n),
- value: t.get(e, n),
- selected: cr(t, n, "selected")
- });
- return i
- },
- getDataParams: function(t) {
- var e = this.getData(),
- i = ZD.superCall(this, "getDataParams", t),
- n = [];
- return e.each(e.mapDimension("value"), function(t) {
- n.push(t)
- }), i.percent = Wo(n, t, e.hostModel.get("percentPrecision")), i.$vars.push("percent"), i
- },
- _defaultLabelLine: function(t) {
- Ci(t, "labelLine", ["show"]);
- var e = t.labelLine,
- i = t.emphasis.labelLine;
- e.show = e.show && t.label.show, i.show = i.show && t.emphasis.label.show
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- legendHoverLink: !0,
- hoverAnimation: !0,
- center: ["50%", "50%"],
- radius: [0, "75%"],
- clockwise: !0,
- startAngle: 90,
- minAngle: 0,
- selectedOffset: 10,
- hoverOffset: 10,
- avoidLabelOverlap: !0,
- percentPrecision: 2,
- stillShowZeroSum: !0,
- label: {
- rotate: !1,
- show: !0,
- position: "outer"
- },
- labelLine: {
- show: !0,
- length: 15,
- length2: 15,
- smooth: !1,
- lineStyle: {
- width: 1,
- type: "solid"
- }
- },
- itemStyle: {
- borderWidth: 1
- },
- animationType: "expansion",
- animationEasing: "cubicOut"
- }
- });
- h(ZD, HD);
- var UD = Rh.prototype;
- UD.updateData = function(t, e, i) {
- function n() {
- s.stopAnimation(!0), s.animateTo({
- shape: {
- r: h.r + l.get("hoverOffset")
- }
- }, 300, "elasticOut")
- }
- function o() {
- s.stopAnimation(!0), s.animateTo({
- shape: {
- r: h.r
- }
- }, 300, "elasticOut")
- }
- var s = this.childAt(0),
- l = t.hostModel,
- u = t.getItemModel(e),
- h = t.getItemLayout(e),
- c = a({}, h);
- c.label = null, i ? (s.setShape(c), "scale" === l.getShallow("animationType") ? (s.shape.r = h.r0, So(s, {
- shape: {
- r: h.r
- }
- }, l, e)) : (s.shape.endAngle = h.startAngle, bo(s, {
- shape: {
- endAngle: h.endAngle
- }
- }, l, e))) : bo(s, {
- shape: c
- }, l, e);
- var d = t.getItemVisual(e, "color");
- s.useStyle(r({
- lineJoin: "bevel",
- fill: d
- }, u.getModel("itemStyle").getItemStyle())), s.hoverStyle = u.getModel("emphasis.itemStyle").getItemStyle();
- var f = u.getShallow("cursor");
- f && s.attr("cursor", f), Eh(this, t.getItemLayout(e), l.isSelected(null, e), l.get("selectedOffset"), l.get(
- "animation")), s.off("mouseover").off("mouseout").off("emphasis").off("normal"), u.get("hoverAnimation") && l.isAnimationEnabled() &&
- s.on("mouseover", n).on("mouseout", o).on("emphasis", n).on("normal", o), this._updateLabel(t, e), uo(this)
- }, UD._updateLabel = function(t, e) {
- var i = this.childAt(1),
- n = this.childAt(2),
- o = t.hostModel,
- a = t.getItemModel(e),
- r = t.getItemLayout(e).label,
- s = t.getItemVisual(e, "color");
- bo(i, {
- shape: {
- points: r.linePoints || [
- [r.x, r.y],
- [r.x, r.y],
- [r.x, r.y]
- ]
- }
- }, o, e), bo(n, {
- style: {
- x: r.x,
- y: r.y
- }
- }, o, e), n.attr({
- rotation: r.rotation,
- origin: [r.x, r.y],
- z2: 10
- });
- var l = a.getModel("label"),
- u = a.getModel("emphasis.label"),
- h = a.getModel("labelLine"),
- c = a.getModel("emphasis.labelLine"),
- s = t.getItemVisual(e, "color");
- co(n.style, n.hoverStyle = {}, l, u, {
- labelFetcher: t.hostModel,
- labelDataIndex: e,
- defaultText: t.getName(e),
- autoColor: s,
- useInsideStyle: !!r.inside
- }, {
- textAlign: r.textAlign,
- textVerticalAlign: r.verticalAlign,
- opacity: t.getItemVisual(e, "opacity")
- }), n.ignore = n.normalIgnore = !l.get("show"), n.hoverIgnore = !u.get("show"), i.ignore = i.normalIgnore = !h.get(
- "show"), i.hoverIgnore = !c.get("show"), i.setStyle({
- stroke: s,
- opacity: t.getItemVisual(e, "opacity")
- }), i.setStyle(h.getModel("lineStyle").getLineStyle()), i.hoverStyle = c.getModel("lineStyle").getLineStyle();
- var d = h.get("smooth");
- d && !0 === d && (d = .4), i.setShape({
- smooth: d
- })
- }, u(Rh, Zw);
- Mr.extend({
- type: "pie",
- init: function() {
- var t = new Zw;
- this._sectorGroup = t
- },
- render: function(t, e, i, n) {
- if (!n || n.from !== this.uid) {
- var o = t.getData(),
- a = this._data,
- r = this.group,
- s = e.get("animation"),
- l = !a,
- u = t.get("animationType"),
- h = v(Oh, this.uid, t, s, i),
- c = t.get("selectedMode");
- if (o.diff(a).add(function(t) {
- var e = new Rh(o, t);
- l && "scale" !== u && e.eachChild(function(t) {
- t.stopAnimation(!0)
- }), c && e.on("click", h), o.setItemGraphicEl(t, e), r.add(e)
- }).update(function(t, e) {
- var i = a.getItemGraphicEl(e);
- i.updateData(o, t), i.off("click"), c && i.on("click", h), r.add(i), o.setItemGraphicEl(t, i)
- }).remove(function(t) {
- var e = a.getItemGraphicEl(t);
- r.remove(e)
- }).execute(), s && l && o.count() > 0 && "scale" !== u) {
- var d = o.getItemLayout(0),
- f = Math.max(i.getWidth(), i.getHeight()) / 2,
- p = m(r.removeClipPath, r);
- r.setClipPath(this._createClipPath(d.cx, d.cy, f, d.startAngle, d.clockwise, p, t))
- } else r.removeClipPath();
- this._data = o
- }
- },
- dispose: function() {},
- _createClipPath: function(t, e, i, n, o, a, r) {
- var s = new QS({
- shape: {
- cx: t,
- cy: e,
- r0: 0,
- r: i,
- startAngle: n,
- endAngle: n,
- clockwise: o
- }
- });
- return So(s, {
- shape: {
- endAngle: n + (o ? 1 : -1) * Math.PI * 2
- }
- }, r, a), s
- },
- containPoint: function(t, e) {
- var i = e.getData().getItemLayout(0);
- if (i) {
- var n = t[0] - i.cx,
- o = t[1] - i.cy,
- a = Math.sqrt(n * n + o * o);
- return a <= i.r && a >= i.r0
- }
- }
- });
- var XD = function(t, e) {
- d(e, function(e) {
- e.update = "updateView", Ps(e, function(i, n) {
- var o = {};
- return n.eachComponent({
- mainType: "series",
- subType: t,
- query: i
- }, function(t) {
- t[e.method] && t[e.method](i.name, i.dataIndex);
- var n = t.getData();
- n.each(function(e) {
- var i = n.getName(e);
- o[i] = t.isSelected(i) || !1
- })
- }), {
- name: i.name,
- selected: o
- }
- })
- })
- },
- jD = function(t) {
- return {
- getTargetSeries: function(e) {
- var i = {},
- n = R();
- return e.eachSeriesByType(t, function(t) {
- t.__paletteScope = i, n.set(t.uid, t)
- }), n
- },
- reset: function(t, e) {
- var i = t.getRawData(),
- n = {},
- o = t.getData();
- o.each(function(t) {
- var e = o.getRawIndex(t);
- n[e] = t
- }), i.each(function(e) {
- var a = n[e],
- r = null != a && o.getItemVisual(a, "color", !0);
- if (r) i.setItemVisual(e, "color", r);
- else {
- var s = i.getItemModel(e).get("itemStyle.color") || t.getColorFromPalette(i.getName(e) || e + "", t.__paletteScope,
- i.count());
- i.setItemVisual(e, "color", s), null != a && o.setItemVisual(a, "color", s)
- }
- })
- }
- }
- },
- YD = function(t, e, i, n) {
- var o, a, r = t.getData(),
- s = [],
- l = !1;
- r.each(function(i) {
- var n, u, h, c, d = r.getItemLayout(i),
- f = r.getItemModel(i),
- p = f.getModel("label"),
- g = p.get("position") || f.get("emphasis.label.position"),
- m = f.getModel("labelLine"),
- v = m.get("length"),
- y = m.get("length2"),
- x = (d.startAngle + d.endAngle) / 2,
- _ = Math.cos(x),
- w = Math.sin(x);
- o = d.cx, a = d.cy;
- var b = "inside" === g || "inner" === g;
- if ("center" === g) n = d.cx, u = d.cy, c = "center";
- else {
- var S = (b ? (d.r + d.r0) / 2 * _ : d.r * _) + o,
- M = (b ? (d.r + d.r0) / 2 * w : d.r * w) + a;
- if (n = S + 3 * _, u = M + 3 * w, !b) {
- var I = S + _ * (v + e - d.r),
- T = M + w * (v + e - d.r),
- A = I + (_ < 0 ? -1 : 1) * y,
- D = T;
- n = A + (_ < 0 ? -5 : 5), u = D, h = [
- [S, M],
- [I, T],
- [A, D]
- ]
- }
- c = b ? "center" : _ > 0 ? "left" : "right"
- }
- var C = p.getFont(),
- L = p.get("rotate") ? _ < 0 ? -x + Math.PI : -x : 0,
- k = De(t.getFormattedLabel(i, "normal") || r.getName(i), C, c, "top");
- l = !!L, d.label = {
- x: n,
- y: u,
- position: g,
- height: k.height,
- len: v,
- len2: y,
- linePoints: h,
- textAlign: c,
- verticalAlign: "middle",
- rotation: L,
- inside: b
- }, b || s.push(d.label)
- }), !l && t.get("avoidLabelOverlap") && Bh(s, o, a, e, i, n)
- },
- qD = 2 * Math.PI,
- KD = Math.PI / 180,
- $D = function(t) {
- return {
- seriesType: t,
- reset: function(t, e) {
- var i = e.findComponents({
- mainType: "legend"
- });
- if (i && i.length) {
- var n = t.getData();
- n.filterSelf(function(t) {
- for (var e = n.getName(t), o = 0; o < i.length; o++)
- if (!i[o].isSelected(e)) return !1;
- return !0
- })
- }
- }
- }
- };
- XD("pie", [{
- type: "pieToggleSelect",
- event: "pieselectchanged",
- method: "toggleSelected"
- }, {
- type: "pieSelect",
- event: "pieselected",
- method: "select"
- }, {
- type: "pieUnSelect",
- event: "pieunselected",
- method: "unSelect"
- }]), Es(jD("pie")), Os(v(function(t, e, i, n) {
- e.eachSeriesByType(t, function(t) {
- var e = t.getData(),
- n = e.mapDimension("value"),
- o = t.get("center"),
- a = t.get("radius");
- y(a) || (a = [0, a]), y(o) || (o = [o, o]);
- var r = i.getWidth(),
- s = i.getHeight(),
- l = Math.min(r, s),
- u = Ro(o[0], r),
- h = Ro(o[1], s),
- c = Ro(a[0], l / 2),
- d = Ro(a[1], l / 2),
- f = -t.get("startAngle") * KD,
- p = t.get("minAngle") * KD,
- g = 0;
- e.each(n, function(t) {
- !isNaN(t) && g++
- });
- var m = e.getSum(n),
- v = Math.PI / (m || g) * 2,
- x = t.get("clockwise"),
- _ = t.get("roseType"),
- w = t.get("stillShowZeroSum"),
- b = e.getDataExtent(n);
- b[0] = 0;
- var S = qD,
- M = 0,
- I = f,
- T = x ? 1 : -1;
- if (e.each(n, function(t, i) {
- var n;
- if (isNaN(t)) e.setItemLayout(i, {
- angle: NaN,
- startAngle: NaN,
- endAngle: NaN,
- clockwise: x,
- cx: u,
- cy: h,
- r0: c,
- r: _ ? NaN : d
- });
- else {
- (n = "area" !== _ ? 0 === m && w ? v : t * v : qD / g) < p ? (n = p, S -= p) : M += t;
- var o = I + T * n;
- e.setItemLayout(i, {
- angle: n,
- startAngle: I,
- endAngle: o,
- clockwise: x,
- cx: u,
- cy: h,
- r0: c,
- r: _ ? Eo(t, b, [c, d]) : d
- }), I = o
- }
- }), S < qD && g)
- if (S <= .001) {
- var A = qD / g;
- e.each(n, function(t, i) {
- if (!isNaN(t)) {
- var n = e.getItemLayout(i);
- n.angle = A, n.startAngle = f + T * i * A, n.endAngle = f + T * (i + 1) * A
- }
- })
- } else v = S / M, I = f, e.each(n, function(t, i) {
- if (!isNaN(t)) {
- var n = e.getItemLayout(i),
- o = n.angle === p ? p : t * v;
- n.startAngle = I, n.endAngle = I + T * o, I += T * o
- }
- });
- YD(t, d, r, s)
- })
- }, "pie")), ks($D("pie")), OI.extend({
- type: "series.scatter",
- dependencies: ["grid", "polar", "geo", "singleAxis", "calendar"],
- getInitialData: function(t, e) {
- return dl(this.getSource(), this)
- },
- brushSelector: "point",
- getProgressive: function() {
- var t = this.option.progressive;
- return null == t ? this.option.large ? 5e3 : this.get("progressive") : t
- },
- getProgressiveThreshold: function() {
- var t = this.option.progressiveThreshold;
- return null == t ? this.option.large ? 1e4 : this.get("progressiveThreshold") : t
- },
- defaultOption: {
- coordinateSystem: "cartesian2d",
- zlevel: 0,
- z: 2,
- legendHoverLink: !0,
- hoverAnimation: !0,
- symbolSize: 10,
- large: !1,
- largeThreshold: 2e3,
- itemStyle: {
- opacity: .8
- }
- }
- });
- var JD = Fn({
- shape: {
- points: null
- },
- symbolProxy: null,
- buildPath: function(t, e) {
- var i = e.points,
- n = e.size,
- o = this.symbolProxy,
- a = o.shape;
- if (!((t.getContext ? t.getContext() : t) && n[0] < 4))
- for (var r = 0; r < i.length;) {
- var s = i[r++],
- l = i[r++];
- isNaN(s) || isNaN(l) || (a.x = s - n[0] / 2, a.y = l - n[1] / 2, a.width = n[0], a.height = n[1], o.buildPath(
- t, a, !0))
- }
- },
- afterBrush: function(t) {
- var e = this.shape,
- i = e.points,
- n = e.size;
- if (n[0] < 4) {
- this.setTransform(t);
- for (var o = 0; o < i.length;) {
- var a = i[o++],
- r = i[o++];
- isNaN(a) || isNaN(r) || t.fillRect(a - n[0] / 2, r - n[1] / 2, n[0], n[1])
- }
- this.restoreTransform(t)
- }
- },
- findDataIndex: function(t, e) {
- for (var i = this.shape, n = i.points, o = i.size, a = Math.max(o[0], 4), r = Math.max(o[1], 4), s = n.length /
- 2 - 1; s >= 0; s--) {
- var l = 2 * s,
- u = n[l] - a / 2,
- h = n[l + 1] - r / 2;
- if (t >= u && e >= h && t <= u + a && e <= h + r) return s
- }
- return -1
- }
- }),
- QD = Vh.prototype;
- QD.isPersistent = function() {
- return !this._incremental
- }, QD.updateData = function(t) {
- this.group.removeAll();
- var e = new JD({
- rectHover: !0,
- cursor: "default"
- });
- e.setShape({
- points: t.getLayout("symbolPoints")
- }), this._setCommon(e, t), this.group.add(e), this._incremental = null
- }, QD.updateLayout = function(t) {
- if (!this._incremental) {
- var e = t.getLayout("symbolPoints");
- this.group.eachChild(function(t) {
- if (null != t.startIndex) {
- var i = 2 * (t.endIndex - t.startIndex),
- n = 4 * t.startIndex * 2;
- e = new Float32Array(e.buffer, n, i)
- }
- t.setShape("points", e)
- })
- }
- }, QD.incrementalPrepareUpdate = function(t) {
- this.group.removeAll(), this._clearIncremental(), t.count() > 2e6 ? (this._incremental || (this._incremental = new Gn({
- silent: !0
- })), this.group.add(this._incremental)) : this._incremental = null
- }, QD.incrementalUpdate = function(t, e) {
- var i;
- this._incremental ? (i = new JD, this._incremental.addDisplayable(i, !0)) : ((i = new JD({
- rectHover: !0,
- cursor: "default",
- startIndex: t.start,
- endIndex: t.end
- })).incremental = !0, this.group.add(i)), i.setShape({
- points: e.getLayout("symbolPoints")
- }), this._setCommon(i, e, !!this._incremental)
- }, QD._setCommon = function(t, e, i) {
- var n = e.hostModel,
- o = e.getVisual("symbolSize");
- t.setShape("size", o instanceof Array ? o : [o, o]), t.symbolProxy = Xl(e.getVisual("symbol"), 0, 0, 0, 0), t.setColor =
- t.symbolProxy.setColor;
- var a = t.shape.size[0] < 4;
- t.useStyle(n.getModel("itemStyle").getItemStyle(a ? ["color", "shadowBlur", "shadowColor"] : ["color"]));
- var r = e.getVisual("color");
- r && t.setColor(r), i || (t.seriesIndex = n.seriesIndex, t.on("mousemove", function(e) {
- t.dataIndex = null;
- var i = t.findDataIndex(e.offsetX, e.offsetY);
- i >= 0 && (t.dataIndex = i + (t.startIndex || 0))
- }))
- }, QD.remove = function() {
- this._clearIncremental(), this._incremental = null, this.group.removeAll()
- }, QD._clearIncremental = function() {
- var t = this._incremental;
- t && t.clearDisplaybles()
- }, Fs({
- type: "scatter",
- render: function(t, e, i) {
- var n = t.getData();
- this._updateSymbolDraw(n, t).updateData(n), this._finished = !0
- },
- incrementalPrepareRender: function(t, e, i) {
- var n = t.getData();
- this._updateSymbolDraw(n, t).incrementalPrepareUpdate(n), this._finished = !1
- },
- incrementalRender: function(t, e, i) {
- this._symbolDraw.incrementalUpdate(t, e.getData()), this._finished = t.end === e.getData().count()
- },
- updateTransform: function(t, e, i) {
- var n = t.getData();
- if (this.group.dirty(), !this._finished || n.count() > 1e4 || !this._symbolDraw.isPersistent()) return {
- update: !0
- };
- var o = cD().reset(t);
- o.progress && o.progress({
- start: 0,
- end: n.count()
- }, n), this._symbolDraw.updateLayout(n)
- },
- _updateSymbolDraw: function(t, e) {
- var i = this._symbolDraw,
- n = e.pipelineContext.large;
- return i && n === this._isLargeDraw || (i && i.remove(), i = this._symbolDraw = n ? new Vh : new Su, this._isLargeDraw =
- n, this.group.removeAll()), this.group.add(i.group), i
- },
- remove: function(t, e) {
- this._symbolDraw && this._symbolDraw.remove(!0), this._symbolDraw = null
- },
- dispose: function() {}
- }), Es(hD("scatter", "circle")), Os(cD("scatter")), u(Gh, HA), Fh.prototype.getIndicatorAxes = function() {
- return this._indicatorAxes
- }, Fh.prototype.dataToPoint = function(t, e) {
- var i = this._indicatorAxes[e];
- return this.coordToPoint(i.dataToCoord(t), e)
- }, Fh.prototype.coordToPoint = function(t, e) {
- var i = this._indicatorAxes[e].angle;
- return [this.cx + t * Math.cos(i), this.cy - t * Math.sin(i)]
- }, Fh.prototype.pointToData = function(t) {
- var e = t[0] - this.cx,
- i = t[1] - this.cy,
- n = Math.sqrt(e * e + i * i);
- e /= n, i /= n;
- for (var o, a = Math.atan2(-i, e), r = 1 / 0, s = -1, l = 0; l < this._indicatorAxes.length; l++) {
- var u = this._indicatorAxes[l],
- h = Math.abs(a - u.angle);
- h < r && (o = u, s = l, r = h)
- }
- return [s, +(o && o.coodToData(n))]
- }, Fh.prototype.resize = function(t, e) {
- var i = t.get("center"),
- n = e.getWidth(),
- o = e.getHeight(),
- a = Math.min(n, o) / 2;
- this.cx = Ro(i[0], n), this.cy = Ro(i[1], o), this.startAngle = t.get("startAngle") * Math.PI / 180;
- var r = t.get("radius");
- "string" != typeof r && "number" != typeof r || (r = [0, r]), this.r0 = Ro(r[0], a), this.r = Ro(r[1], a), d(this._indicatorAxes,
- function(t, e) {
- t.setExtent(this.r0, this.r);
- var i = this.startAngle + e * Math.PI * 2 / this._indicatorAxes.length;
- i = Math.atan2(Math.sin(i), Math.cos(i)), t.angle = i
- }, this)
- }, Fh.prototype.update = function(t, e) {
- function i(t) {
- var e = Math.pow(10, Math.floor(Math.log(t) / Math.LN10)),
- i = t / e;
- return 2 === i ? i = 5 : i *= 2, i * e
- }
- var n = this._indicatorAxes,
- o = this._model;
- d(n, function(t) {
- t.scale.setExtent(1 / 0, -1 / 0)
- }), t.eachSeriesByType("radar", function(e, i) {
- if ("radar" === e.get("coordinateSystem") && t.getComponent("radar", e.get("radarIndex")) === o) {
- var a = e.getData();
- d(n, function(t) {
- t.scale.unionExtentFromData(a, a.mapDimension(t.dim))
- })
- }
- }, this);
- var a = o.get("splitNumber");
- d(n, function(t, e) {
- var n = Rl(t.scale, t.model);
- Bl(t.scale, t.model);
- var o = t.model,
- r = t.scale,
- s = o.getMin(),
- l = o.getMax(),
- u = r.getInterval();
- if (null != s && null != l) r.setExtent(+s, +l), r.setInterval((l - s) / a);
- else if (null != s) {
- var h;
- do {
- h = s + u * a, r.setExtent(+s, h), r.setInterval(u), u = i(u)
- } while (h < n[1] && isFinite(h) && isFinite(n[1]))
- } else if (null != l) {
- var c;
- do {
- c = l - u * a, r.setExtent(c, +l), r.setInterval(u), u = i(u)
- } while (c > n[0] && isFinite(c) && isFinite(n[0]))
- } else {
- r.getTicks().length - 1 > a && (u = i(u));
- var d = Math.round((n[0] + n[1]) / 2 / u) * u,
- f = Math.round(a / 2);
- r.setExtent(zo(d - f * u), zo(d + (a - f) * u)), r.setInterval(u)
- }
- })
- }, Fh.dimensions = [], Fh.create = function(t, e) {
- var i = [];
- return t.eachComponent("radar", function(n) {
- var o = new Fh(n, t, e);
- i.push(o), n.coordinateSystem = o
- }), t.eachSeriesByType("radar", function(t) {
- "radar" === t.get("coordinateSystem") && (t.coordinateSystem = i[t.get("radarIndex") || 0])
- }), i
- }, Ba.register("radar", Fh);
- var tC = vD.valueAxis,
- eC = (Bs({
- type: "radar",
- optionUpdated: function() {
- var t = this.get("boundaryGap"),
- e = this.get("splitNumber"),
- o = this.get("scale"),
- s = this.get("axisLine"),
- l = this.get("axisTick"),
- u = this.get("axisLabel"),
- h = this.get("name"),
- c = this.get("name.show"),
- d = this.get("name.formatter"),
- p = this.get("nameGap"),
- g = this.get("triggerEvent"),
- m = f(this.get("indicator") || [], function(f) {
- null != f.max && f.max > 0 && !f.min ? f.min = 0 : null != f.min && f.min < 0 && !f.max && (f.max = 0);
- var m = h;
- if (null != f.color && (m = r({
- color: f.color
- }, h)), f = n(i(f), {
- boundaryGap: t,
- splitNumber: e,
- scale: o,
- axisLine: s,
- axisTick: l,
- axisLabel: u,
- name: f.text,
- nameLocation: "end",
- nameGap: p,
- nameTextStyle: m,
- triggerEvent: g
- }, !1), c || (f.name = ""), "string" == typeof d) {
- var v = f.name;
- f.name = d.replace("{value}", null != v ? v : "")
- } else "function" == typeof d && (f.name = d(f.name, f));
- var y = a(new Lo(f, null, this.ecModel), CA);
- return y.mainType = "radar", y.componentIndex = this.componentIndex, y
- }, this);
- this.getIndicatorModels = function() {
- return m
- }
- },
- defaultOption: {
- zlevel: 0,
- z: 0,
- center: ["50%", "50%"],
- radius: "75%",
- startAngle: 90,
- name: {
- show: !0
- },
- boundaryGap: [0, 0],
- splitNumber: 5,
- nameGap: 15,
- scale: !1,
- shape: "polygon",
- axisLine: n({
- lineStyle: {
- color: "#bbb"
- }
- }, tC.axisLine),
- axisLabel: Wh(tC.axisLabel, !1),
- axisTick: Wh(tC.axisTick, !1),
- splitLine: Wh(tC.splitLine, !0),
- splitArea: Wh(tC.splitArea, !0),
- indicator: []
- }
- }), ["axisLine", "axisTickLabel", "axisName"]);
- Vs({
- type: "radar",
- render: function(t, e, i) {
- this.group.removeAll(), this._buildAxes(t), this._buildSplitLineAndArea(t)
- },
- _buildAxes: function(t) {
- var e = t.coordinateSystem;
- d(f(e.getIndicatorAxes(), function(t) {
- return new ID(t.model, {
- position: [e.cx, e.cy],
- rotation: t.angle,
- labelDirection: -1,
- tickDirection: -1,
- nameDirection: 1
- })
- }), function(t) {
- d(eC, t.add, t), this.group.add(t.getGroup())
- }, this)
- },
- _buildSplitLineAndArea: function(t) {
- function e(t, e, i) {
- var n = i % e.length;
- return t[n] = t[n] || [], n
- }
- var i = t.coordinateSystem,
- n = i.getIndicatorAxes();
- if (n.length) {
- var o = t.get("shape"),
- a = t.getModel("splitLine"),
- s = t.getModel("splitArea"),
- l = a.getModel("lineStyle"),
- u = s.getModel("areaStyle"),
- h = a.get("show"),
- c = s.get("show"),
- p = l.get("color"),
- g = u.get("color");
- p = y(p) ? p : [p], g = y(g) ? g : [g];
- var m = [],
- v = [];
- if ("circle" === o)
- for (var x = n[0].getTicksCoords(), _ = i.cx, w = i.cy, b = 0; b < x.length; b++) h && m[D = e(m, p, b)].push(
- new KS({
- shape: {
- cx: _,
- cy: w,
- r: x[b].coord
- }
- })), c && b < x.length - 1 && v[D = e(v, g, b)].push(new tM({
- shape: {
- cx: _,
- cy: w,
- r0: x[b].coord,
- r: x[b + 1].coord
- }
- }));
- else
- for (var S, M = f(n, function(t, e) {
- var n = t.getTicksCoords();
- return S = null == S ? n.length - 1 : Math.min(n.length - 1, S), f(n, function(t) {
- return i.coordToPoint(t.coord, e)
- })
- }), I = [], b = 0; b <= S; b++) {
- for (var T = [], A = 0; A < n.length; A++) T.push(M[A][b]);
- if (T[0] && T.push(T[0].slice()), h && m[D = e(m, p, b)].push(new oM({
- shape: {
- points: T
- }
- })), c && I) {
- var D = e(v, g, b - 1);
- v[D].push(new nM({
- shape: {
- points: T.concat(I)
- }
- }))
- }
- I = T.slice().reverse()
- }
- var C = l.getLineStyle(),
- L = u.getAreaStyle();
- d(v, function(t, e) {
- this.group.add(xM(t, {
- style: r({
- stroke: "none",
- fill: g[e % g.length]
- }, L),
- silent: !0
- }))
- }, this), d(m, function(t, e) {
- this.group.add(xM(t, {
- style: r({
- fill: "none",
- stroke: p[e % p.length]
- }, C),
- silent: !0
- }))
- }, this)
- }
- }
- });
- var iC = OI.extend({
- type: "series.radar",
- dependencies: ["radar"],
- init: function(t) {
- iC.superApply(this, "init", arguments), this.legendDataProvider = function() {
- return this.getRawData()
- }
- },
- getInitialData: function(t, e) {
- return WD(this, {
- generateCoord: "indicator_",
- generateCoordCount: 1 / 0
- })
- },
- formatTooltip: function(t) {
- var e = this.getData(),
- i = this.coordinateSystem.getIndicatorAxes(),
- n = this.getData().getName(t);
- return Qo("" === n ? this.name : n) + "<br/>" + f(i, function(i, n) {
- var o = e.get(e.mapDimension(i.dim), t);
- return Qo(i.name + " : " + o)
- }).join("<br />")
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "radar",
- legendHoverLink: !0,
- radarIndex: 0,
- lineStyle: {
- width: 2,
- type: "solid"
- },
- label: {
- position: "top"
- },
- symbol: "emptyCircle",
- symbolSize: 4
- }
- });
- Fs({
- type: "radar",
- render: function(t, e, n) {
- function o(t, e) {
- var i = t.getItemVisual(e, "symbol") || "circle",
- n = t.getItemVisual(e, "color");
- if ("none" !== i) {
- var o = Hh(t.getItemVisual(e, "symbolSize")),
- a = Xl(i, -1, -1, 2, 2, n);
- return a.attr({
- style: {
- strokeNoScale: !0
- },
- z2: 100,
- scale: [o[0] / 2, o[1] / 2]
- }), a
- }
- }
- function a(e, i, n, a, r, s) {
- n.removeAll();
- for (var l = 0; l < i.length - 1; l++) {
- var u = o(a, r);
- u && (u.__dimIdx = l, e[l] ? (u.attr("position", e[l]), bM[s ? "initProps" : "updateProps"](u, {
- position: i[l]
- }, t, r)) : u.attr("position", i[l]), n.add(u))
- }
- }
- function s(t) {
- return f(t, function(t) {
- return [l.cx, l.cy]
- })
- }
- var l = t.coordinateSystem,
- u = this.group,
- h = t.getData(),
- c = this._data;
- h.diff(c).add(function(e) {
- var i = h.getItemLayout(e);
- if (i) {
- var n = new nM,
- o = new oM,
- r = {
- shape: {
- points: i
- }
- };
- n.shape.points = s(i), o.shape.points = s(i), So(n, r, t, e), So(o, r, t, e);
- var l = new Zw,
- u = new Zw;
- l.add(o), l.add(n), l.add(u), a(o.shape.points, i, u, h, e, !0), h.setItemGraphicEl(e, l)
- }
- }).update(function(e, i) {
- var n = c.getItemGraphicEl(i),
- o = n.childAt(0),
- r = n.childAt(1),
- s = n.childAt(2),
- l = {
- shape: {
- points: h.getItemLayout(e)
- }
- };
- l.shape.points && (a(o.shape.points, l.shape.points, s, h, e, !1), bo(o, l, t), bo(r, l, t), h.setItemGraphicEl(
- e, n))
- }).remove(function(t) {
- u.remove(c.getItemGraphicEl(t))
- }).execute(), h.eachItemGraphicEl(function(t, e) {
- function n() {
- l.attr("ignore", m)
- }
- function o() {
- l.attr("ignore", g)
- }
- var a = h.getItemModel(e),
- s = t.childAt(0),
- l = t.childAt(1),
- c = t.childAt(2),
- d = h.getItemVisual(e, "color");
- u.add(t), s.useStyle(r(a.getModel("lineStyle").getLineStyle(), {
- fill: "none",
- stroke: d
- })), s.hoverStyle = a.getModel("emphasis.lineStyle").getLineStyle();
- var f = a.getModel("areaStyle"),
- p = a.getModel("emphasis.areaStyle"),
- g = f.isEmpty() && f.parentModel.isEmpty(),
- m = p.isEmpty() && p.parentModel.isEmpty();
- m = m && g, l.ignore = g, l.useStyle(r(f.getAreaStyle(), {
- fill: d,
- opacity: .7
- })), l.hoverStyle = p.getAreaStyle();
- var v = a.getModel("itemStyle").getItemStyle(["color"]),
- y = a.getModel("emphasis.itemStyle").getItemStyle(),
- x = a.getModel("label"),
- _ = a.getModel("emphasis.label");
- c.eachChild(function(t) {
- t.setStyle(v), t.hoverStyle = i(y), co(t.style, t.hoverStyle, x, _, {
- labelFetcher: h.hostModel,
- labelDataIndex: e,
- labelDimIndex: t.__dimIdx,
- defaultText: h.get(h.dimensions[t.__dimIdx], e),
- autoColor: d,
- isRectText: !0
- })
- }), t.off("mouseover").off("mouseout").off("normal").off("emphasis"), t.on("emphasis", n).on("mouseover", n)
- .on("normal", o).on("mouseout", o), uo(t)
- }), this._data = h
- },
- remove: function() {
- this.group.removeAll(), this._data = null
- },
- dispose: function() {}
- });
- Es(jD("radar")), Es(hD("radar", "circle")), Os(function(t) {
- t.eachSeriesByType("radar", function(t) {
- var e = t.getData(),
- i = [],
- n = t.coordinateSystem;
- if (n) {
- for (var o = n.getIndicatorAxes(), a = 0; a < o.length; a++) e.each(e.mapDimension(o[a].dim), function(t, e) {
- i[e] = i[e] || [], i[e][a] = n.dataToPoint(t, a)
- });
- e.each(function(t) {
- i[t][0] && i[t].push(i[t][0].slice()), e.setItemLayout(t, i[t])
- })
- }
- })
- }), ks($D("radar")), Ls(function(t) {
- var e = t.polar;
- if (e) {
- y(e) || (e = [e]);
- var i = [];
- d(e, function(e, n) {
- e.indicator ? (e.type && !e.shape && (e.shape = e.type), t.radar = t.radar || [], y(t.radar) || (t.radar = [t.radar]),
- t.radar.push(e)) : i.push(e)
- }), t.polar = i
- }
- d(t.series, function(t) {
- t && "radar" === t.type && t.polarIndex && (t.radarIndex = t.polarIndex)
- })
- });
- var nC = Q;
- h(Zh, mw), Uh.prototype = {
- constructor: Uh,
- type: "view",
- dimensions: ["x", "y"],
- setBoundingRect: function(t, e, i, n) {
- return this._rect = new ue(t, e, i, n), this._rect
- },
- getBoundingRect: function() {
- return this._rect
- },
- setViewRect: function(t, e, i, n) {
- this.transformTo(t, e, i, n), this._viewRect = new ue(t, e, i, n)
- },
- transformTo: function(t, e, i, n) {
- var o = this.getBoundingRect(),
- a = this._rawTransformable;
- a.transform = o.calculateTransform(new ue(t, e, i, n)), a.decomposeTransform(), this._updateTransform()
- },
- setCenter: function(t) {
- t && (this._center = t, this._updateCenterAndZoom())
- },
- setZoom: function(t) {
- t = t || 1;
- var e = this.zoomLimit;
- e && (null != e.max && (t = Math.min(e.max, t)), null != e.min && (t = Math.max(e.min, t))), this._zoom = t, this
- ._updateCenterAndZoom()
- },
- getDefaultCenter: function() {
- var t = this.getBoundingRect();
- return [t.x + t.width / 2, t.y + t.height / 2]
- },
- getCenter: function() {
- return this._center || this.getDefaultCenter()
- },
- getZoom: function() {
- return this._zoom || 1
- },
- getRoamTransform: function() {
- return this._roamTransformable.getLocalTransform()
- },
- _updateCenterAndZoom: function() {
- var t = this._rawTransformable.getLocalTransform(),
- e = this._roamTransformable,
- i = this.getDefaultCenter(),
- n = this.getCenter(),
- o = this.getZoom();
- n = Q([], n, t), i = Q([], i, t), e.origin = n, e.position = [i[0] - n[0], i[1] - n[1]], e.scale = [o, o], this._updateTransform()
- },
- _updateTransform: function() {
- var t = this._roamTransformable,
- e = this._rawTransformable;
- e.parent = t, t.updateTransform(), e.updateTransform(), yt(this.transform || (this.transform = []), e.transform ||
- mt()), this._rawTransform = e.getLocalTransform(), this.invTransform = this.invTransform || [], St(this.invTransform,
- this.transform), this.decomposeTransform()
- },
- getViewRect: function() {
- return this._viewRect
- },
- getViewRectAfterRoam: function() {
- var t = this.getBoundingRect().clone();
- return t.applyTransform(this.transform), t
- },
- dataToPoint: function(t, e, i) {
- var n = e ? this._rawTransform : this.transform;
- return i = i || [], n ? nC(i, t, n) : G(i, t)
- },
- pointToData: function(t) {
- var e = this.invTransform;
- return e ? nC([], t, e) : [t[0], t[1]]
- },
- convertToPixel: v(Xh, "dataToPoint"),
- convertFromPixel: v(Xh, "pointToData"),
- containPoint: function(t) {
- return this.getViewRectAfterRoam().contain(t[0], t[1])
- }
- }, h(Uh, mw);
- for (var oC = [126, 25], aC = [
- [
- [0, 3.5],
- [7, 11.2],
- [15, 11.9],
- [30, 7],
- [42, .7],
- [52, .7],
- [56, 7.7],
- [59, .7],
- [64, .7],
- [64, 0],
- [5, 0],
- [0, 3.5]
- ],
- [
- [13, 16.1],
- [19, 14.7],
- [16, 21.7],
- [11, 23.1],
- [13, 16.1]
- ],
- [
- [12, 32.2],
- [14, 38.5],
- [15, 38.5],
- [13, 32.2],
- [12, 32.2]
- ],
- [
- [16, 47.6],
- [12, 53.2],
- [13, 53.2],
- [18, 47.6],
- [16, 47.6]
- ],
- [
- [6, 64.4],
- [8, 70],
- [9, 70],
- [8, 64.4],
- [6, 64.4]
- ],
- [
- [23, 82.6],
- [29, 79.8],
- [30, 79.8],
- [25, 82.6],
- [23, 82.6]
- ],
- [
- [37, 70.7],
- [43, 62.3],
- [44, 62.3],
- [39, 70.7],
- [37, 70.7]
- ],
- [
- [48, 51.1],
- [51, 45.5],
- [53, 45.5],
- [50, 51.1],
- [48, 51.1]
- ],
- [
- [51, 35],
- [51, 28.7],
- [53, 28.7],
- [53, 35],
- [51, 35]
- ],
- [
- [52, 22.4],
- [55, 17.5],
- [56, 17.5],
- [53, 22.4],
- [52, 22.4]
- ],
- [
- [58, 12.6],
- [62, 7],
- [63, 7],
- [60, 12.6],
- [58, 12.6]
- ],
- [
- [0, 3.5],
- [0, 93.1],
- [64, 93.1],
- [64, 0],
- [63, 0],
- [63, 92.4],
- [1, 92.4],
- [1, 3.5],
- [0, 3.5]
- ]
- ], rC = 0; rC < aC.length; rC++)
- for (var sC = 0; sC < aC[rC].length; sC++) aC[rC][sC][0] /= 10.5, aC[rC][sC][1] /= -14, aC[rC][sC][0] += oC[0], aC[
- rC][sC][1] += oC[1];
- var lC = function(t, e) {
- "china" === t && e.push(new ql("南海诸岛", f(aC, function(t) {
- return {
- type: "polygon",
- exterior: t
- }
- }), oC))
- },
- uC = {
- "南海诸岛": [32, 80],
- "广东": [0, -10],
- "香港": [10, 5],
- "澳门": [-10, 10],
- "天津": [5, 5]
- },
- hC = function(t, e) {
- if ("china" === t) {
- var i = uC[e.name];
- if (i) {
- var n = e.center;
- n[0] += i[0] / 10.5, n[1] += -i[1] / 14
- }
- }
- },
- cC = {
- Russia: [100, 60],
- "United States": [-99, 38],
- "United States of America": [-99, 38]
- },
- dC = function(t, e) {
- if ("world" === t) {
- var i = cC[e.name];
- if (i) {
- var n = e.center;
- n[0] = i[0], n[1] = i[1]
- }
- }
- },
- fC = [
- [
- [123.45165252685547, 25.73527164402261],
- [123.49731445312499, 25.73527164402261],
- [123.49731445312499, 25.750734064600884],
- [123.45165252685547, 25.750734064600884],
- [123.45165252685547, 25.73527164402261]
- ]
- ],
- pC = function(t, e) {
- "china" === t && "台湾" === e.name && e.geometries.push({
- type: "polygon",
- exterior: fC[0]
- })
- },
- gC = Bi(),
- mC = {
- load: function(t, e) {
- var i = gC(e).parsed;
- if (i) return i;
- var n, o = e.specialAreas || {},
- a = e.geoJSON;
- try {
- n = a ? GA(a) : []
- } catch (t) {
- throw new Error("Invalid geoJson format\n" + t.message)
- }
- return d(n, function(e) {
- var i = e.name;
- hC(t, e), dC(t, e), pC(t, e);
- var n = o[i];
- n && e.transformTo(n.left, n.top, n.width, n.height)
- }), lC(t, n), gC(e).parsed = {
- regions: n,
- boundingRect: jh(n)
- }
- }
- },
- vC = Bi(),
- yC = {
- geoJSON: mC,
- svg: {
- load: function(t, e) {
- var i = vC(e).originRoot;
- if (i) return {
- root: i,
- boundingRect: vC(e).boundingRect
- };
- var n = Yh(e);
- return vC(e).originRoot = n.root, vC(e).boundingRect = n.boundingRect, n
- },
- makeGraphic: function(t, e, i) {
- var n = vC(e),
- o = n.rootMap || (n.rootMap = R()),
- a = o.get(i);
- if (a) return a;
- var r = n.originRoot,
- s = n.boundingRect;
- return n.originRootHostKey ? a = Yh(e, s).root : (n.originRootHostKey = i, a = r), o.set(i, a)
- },
- removeGraphic: function(t, e, i) {
- var n = vC(e),
- o = n.rootMap;
- o && o.removeKey(i), i === n.originRootHostKey && (n.originRootHostKey = null)
- }
- }
- },
- xC = {
- load: function(t, e) {
- var i, n = [],
- o = R(),
- a = R();
- return d(Kh(t), function(r) {
- var s = yC[r.type].load(t, r);
- d(s.regions, function(t) {
- var i = t.name;
- e && e.hasOwnProperty(i) && (t = t.cloneShallow(i = e[i])), n.push(t), o.set(i, t), a.set(i, t.center)
- });
- var l = s.boundingRect;
- l && (i ? i.union(l) : i = l.clone())
- }), {
- regions: n,
- regionsMap: o,
- nameCoordMap: a,
- boundingRect: i || new ue(0, 0, 0, 0)
- }
- },
- makeGraphic: qh("makeGraphic"),
- removeGraphic: qh("removeGraphic")
- };
- $h.prototype = {
- constructor: $h,
- type: "geo",
- dimensions: ["lng", "lat"],
- containCoord: function(t) {
- for (var e = this.regions, i = 0; i < e.length; i++)
- if (e[i].contain(t)) return !0;
- return !1
- },
- transformTo: function(t, e, i, n) {
- var o = this.getBoundingRect(),
- a = this._invertLongitute;
- o = o.clone(), a && (o.y = -o.y - o.height);
- var r = this._rawTransformable;
- if (r.transform = o.calculateTransform(new ue(t, e, i, n)), r.decomposeTransform(), a) {
- var s = r.scale;
- s[1] = -s[1]
- }
- r.updateTransform(), this._updateTransform()
- },
- getRegion: function(t) {
- return this._regionsMap.get(t)
- },
- getRegionByCoord: function(t) {
- for (var e = this.regions, i = 0; i < e.length; i++)
- if (e[i].contain(t)) return e[i]
- },
- addGeoCoord: function(t, e) {
- this._nameCoordMap.set(t, e)
- },
- getGeoCoord: function(t) {
- return this._nameCoordMap.get(t)
- },
- getBoundingRect: function() {
- return this._rect
- },
- dataToPoint: function(t, e, i) {
- if ("string" == typeof t && (t = this.getGeoCoord(t)), t) return Uh.prototype.dataToPoint.call(this, t, e, i)
- },
- convertToPixel: v(Jh, "dataToPoint"),
- convertFromPixel: v(Jh, "pointToData")
- }, h($h, Uh);
- var _C = {
- dimensions: $h.prototype.dimensions,
- create: function(t, e) {
- var i = [];
- t.eachComponent("geo", function(t, n) {
- var o = t.get("map"),
- a = t.get("aspectScale"),
- r = !0,
- s = pT.retrieveMap(o);
- s && s[0] && "svg" === s[0].type ? (null == a && (a = 1), r = !1) : null == a && (a = .75);
- var l = new $h(o + n, o, t.get("nameMap"), r);
- l.aspectScale = a, l.zoomLimit = t.get("scaleLimit"), i.push(l), tc(l, t), t.coordinateSystem = l, l.model = t,
- l.resize = Qh, l.resize(t, e)
- }), t.eachSeries(function(t) {
- if ("geo" === t.get("coordinateSystem")) {
- var e = t.get("geoIndex") || 0;
- t.coordinateSystem = i[e]
- }
- });
- var n = {};
- return t.eachSeriesByType("map", function(t) {
- if (!t.getHostGeoModel()) {
- var e = t.getMapType();
- n[e] = n[e] || [], n[e].push(t)
- }
- }), d(n, function(t, n) {
- var a = new $h(n, n, o(f(t, function(t) {
- return t.get("nameMap")
- })));
- a.zoomLimit = T.apply(null, f(t, function(t) {
- return t.get("scaleLimit")
- })), i.push(a), a.resize = Qh, a.aspectScale = t[0].get("aspectScale"), a.resize(t[0], e), d(t, function(t) {
- t.coordinateSystem = a, tc(a, t)
- })
- }), i
- },
- getFilledRegions: function(t, e, i) {
- for (var n = (t || []).slice(), o = R(), a = 0; a < n.length; a++) o.set(n[a].name, n[a]);
- return d(xC.load(e, i).regions, function(t) {
- var e = t.name;
- !o.get(e) && n.push({
- name: e
- })
- }), n
- }
- };
- Ns("geo", _C);
- var wC = OI.extend({
- type: "series.map",
- dependencies: ["geo"],
- layoutMode: "box",
- needsDrawMap: !1,
- seriesGroup: [],
- init: function(t) {
- wC.superApply(this, "init", arguments), this.updateSelectedMap(this._createSelectableList())
- },
- getInitialData: function(t) {
- return WD(this, ["value"])
- },
- mergeOption: function(t) {
- wC.superApply(this, "mergeOption", arguments), this.updateSelectedMap(this._createSelectableList())
- },
- _createSelectableList: function() {
- for (var t = this.getRawData(), e = t.mapDimension("value"), i = [], n = 0, o = t.count(); n < o; n++) i.push({
- name: t.getName(n),
- value: t.get(e, n),
- selected: cr(t, n, "selected")
- });
- return i = _C.getFilledRegions(i, this.getMapType(), this.option.nameMap)
- },
- getHostGeoModel: function() {
- var t = this.option.geoIndex;
- return null != t ? this.dependentModels.geo[t] : null
- },
- getMapType: function() {
- return (this.getHostGeoModel() || this).option.map
- },
- _fillOption: function(t, e) {},
- getRawValue: function(t) {
- var e = this.getData();
- return e.get(e.mapDimension("value"), t)
- },
- getRegionModel: function(t) {
- var e = this.getData();
- return e.getItemModel(e.indexOfName(t))
- },
- formatTooltip: function(t) {
- for (var e = this.getData(), i = $o(this.getRawValue(t)), n = e.getName(t), o = this.seriesGroup, a = [], r = 0; r <
- o.length; r++) {
- var s = o[r].originalData.indexOfName(n),
- l = e.mapDimension("value");
- isNaN(o[r].originalData.get(l, s)) || a.push(Qo(o[r].name))
- }
- return a.join(", ") + "<br />" + Qo(n + " : " + i)
- },
- getTooltipPosition: function(t) {
- if (null != t) {
- var e = this.getData().getName(t),
- i = this.coordinateSystem,
- n = i.getRegion(e);
- return n && i.dataToPoint(n.center)
- }
- },
- setZoom: function(t) {
- this.option.zoom = t
- },
- setCenter: function(t) {
- this.option.center = t
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "geo",
- map: "",
- left: "center",
- top: "center",
- aspectScale: .75,
- showLegendSymbol: !0,
- dataRangeHoverLink: !0,
- boundingCoords: null,
- center: null,
- zoom: 1,
- scaleLimit: null,
- label: {
- show: !1,
- color: "#000"
- },
- itemStyle: {
- borderWidth: .5,
- borderColor: "#444",
- areaColor: "#eee"
- },
- emphasis: {
- label: {
- show: !0,
- color: "rgb(100,0,0)"
- },
- itemStyle: {
- areaColor: "rgba(255,215,0,0.8)"
- }
- }
- }
- });
- h(wC, HD);
- var bC = "\0_ec_interaction_mutex";
- Ps({
- type: "takeGlobalCursor",
- event: "globalCursorTaken",
- update: "update"
- }, function() {}), h(ac, aw);
- var SC = {
- axisPointer: 1,
- tooltip: 1,
- brush: 1
- };
- _c.prototype = {
- constructor: _c,
- draw: function(t, e, i, n, o) {
- var a = "geo" === t.mainType,
- r = t.getData && t.getData();
- a && e.eachComponent({
- mainType: "series",
- subType: "map"
- }, function(e) {
- r || e.getHostGeoModel() !== t || (r = e.getData())
- });
- var s = t.coordinateSystem;
- this._updateBackground(s);
- var l = this._regionsGroup,
- u = this.group,
- h = s.scale,
- c = {
- position: s.position,
- scale: h
- };
- !l.childAt(0) || o ? u.attr(c) : bo(u, c, t), l.removeAll();
- var f = ["itemStyle"],
- p = ["emphasis", "itemStyle"],
- g = ["label"],
- m = ["emphasis", "label"],
- v = R();
- d(s.regions, function(e) {
- var i = v.get(e.name) || v.set(e.name, new Zw),
- n = new hM({
- shape: {
- paths: []
- }
- });
- i.add(n);
- var o, s = (C = t.getRegionModel(e.name) || t).getModel(f),
- u = C.getModel(p),
- c = vc(s),
- y = vc(u),
- x = C.getModel(g),
- _ = C.getModel(m);
- if (r) {
- o = r.indexOfName(e.name);
- var w = r.getItemVisual(o, "color", !0);
- w && (c.fill = w)
- }
- d(e.geometries, function(t) {
- if ("polygon" === t.type) {
- n.shape.paths.push(new nM({
- shape: {
- points: t.exterior
- }
- }));
- for (var e = 0; e < (t.interiors ? t.interiors.length : 0); e++) n.shape.paths.push(new nM({
- shape: {
- points: t.interiors[e]
- }
- }))
- }
- }), n.setStyle(c), n.style.strokeNoScale = !0, n.culling = !0;
- var b = x.get("show"),
- S = _.get("show"),
- M = r && isNaN(r.get(r.mapDimension("value"), o)),
- I = r && r.getItemLayout(o);
- if (a || M && (b || S) || I && I.showLabel) {
- var T, A = a ? e.name : o;
- (!r || o >= 0) && (T = t);
- var D = new qS({
- position: e.center.slice(),
- scale: [1 / h[0], 1 / h[1]],
- z2: 10,
- silent: !0
- });
- co(D.style, D.hoverStyle = {}, x, _, {
- labelFetcher: T,
- labelDataIndex: A,
- defaultText: e.name,
- useInsideStyle: !1
- }, {
- textAlign: "center",
- textVerticalAlign: "middle"
- }), i.add(D)
- }
- if (r) r.setItemGraphicEl(o, i);
- else {
- var C = t.getRegionModel(e.name);
- n.eventData = {
- componentType: "geo",
- componentIndex: t.componentIndex,
- geoIndex: t.componentIndex,
- name: e.name,
- region: C && C.option || {}
- }
- }(i.__regions || (i.__regions = [])).push(e), uo(i, y, {
- hoverSilentOnTouch: !!t.get("selectedMode")
- }), l.add(i)
- }), this._updateController(t, e, i), yc(this, t, l, i, n), xc(t, l)
- },
- remove: function() {
- this._regionsGroup.removeAll(), this._backgroundGroup.removeAll(), this._controller.dispose(), this._mapName &&
- xC.removeGraphic(this._mapName, this.uid), this._mapName = null, this._controllerHost = {}
- },
- _updateBackground: function(t) {
- var e = t.map;
- this._mapName !== e && d(xC.makeGraphic(e, this.uid), function(t) {
- this._backgroundGroup.add(t)
- }, this), this._mapName = e
- },
- _updateController: function(t, e, i) {
- function n() {
- var e = {
- type: "geoRoam",
- componentType: l
- };
- return e[l + "Id"] = t.id, e
- }
- var o = t.coordinateSystem,
- r = this._controller,
- s = this._controllerHost;
- s.zoomLimit = t.get("scaleLimit"), s.zoom = o.getZoom(), r.enable(t.get("roam") || !1);
- var l = t.mainType;
- r.off("pan").on("pan", function(t) {
- this._mouseDownFlag = !1, pc(s, t.dx, t.dy), i.dispatchAction(a(n(), {
- dx: t.dx,
- dy: t.dy
- }))
- }, this), r.off("zoom").on("zoom", function(t) {
- if (this._mouseDownFlag = !1, gc(s, t.scale, t.originX, t.originY), i.dispatchAction(a(n(), {
- zoom: t.scale,
- originX: t.originX,
- originY: t.originY
- })), this._updateGroup) {
- var e = this.group.scale;
- this._regionsGroup.traverse(function(t) {
- "text" === t.type && t.attr("scale", [1 / e[0], 1 / e[1]])
- })
- }
- }, this), r.setPointerChecker(function(e, n, a) {
- return o.getViewRectAfterRoam().contain(n, a) && !mc(e, i, t)
- })
- }
- }, Fs({
- type: "map",
- render: function(t, e, i, n) {
- if (!n || "mapToggleSelect" !== n.type || n.from !== this.uid) {
- var o = this.group;
- if (o.removeAll(), !t.getHostGeoModel()) {
- if (n && "geoRoam" === n.type && "series" === n.componentType && n.seriesId === t.id)(a = this._mapDraw) && o.add(
- a.group);
- else if (t.needsDrawMap) {
- var a = this._mapDraw || new _c(i, !0);
- o.add(a.group), a.draw(t, e, i, this, n), this._mapDraw = a
- } else this._mapDraw && this._mapDraw.remove(), this._mapDraw = null;
- t.get("showLegendSymbol") && e.getComponent("legend") && this._renderSymbols(t, e, i)
- }
- }
- },
- remove: function() {
- this._mapDraw && this._mapDraw.remove(), this._mapDraw = null, this.group.removeAll()
- },
- dispose: function() {
- this._mapDraw && this._mapDraw.remove(), this._mapDraw = null
- },
- _renderSymbols: function(t, e, i) {
- var n = t.originalData,
- o = this.group;
- n.each(n.mapDimension("value"), function(e, i) {
- if (!isNaN(e)) {
- var a = n.getItemLayout(i);
- if (a && a.point) {
- var r = a.point,
- s = a.offset,
- l = new KS({
- style: {
- fill: t.getData().getVisual("color")
- },
- shape: {
- cx: r[0] + 9 * s,
- cy: r[1],
- r: 3
- },
- silent: !0,
- z2: s ? 8 : 10
- });
- if (!s) {
- var u = t.mainSeries.getData(),
- h = n.getName(i),
- c = u.indexOfName(h),
- d = n.getItemModel(i),
- f = d.getModel("label"),
- p = d.getModel("emphasis.label"),
- g = u.getItemGraphicEl(c),
- m = A(t.getFormattedLabel(i, "normal"), h),
- v = A(t.getFormattedLabel(i, "emphasis"), m),
- y = function() {
- var t = fo({}, p, {
- text: p.get("show") ? v : null
- }, {
- isRectText: !0,
- useInsideStyle: !1
- }, !0);
- l.style.extendFrom(t), l.__mapOriginalZ2 = l.z2, l.z2 += 1
- },
- x = function() {
- fo(l.style, f, {
- text: f.get("show") ? m : null,
- textPosition: f.getShallow("position") || "bottom"
- }, {
- isRectText: !0,
- useInsideStyle: !1
- }), null != l.__mapOriginalZ2 && (l.z2 = l.__mapOriginalZ2, l.__mapOriginalZ2 = null)
- };
- g.on("mouseover", y).on("mouseout", x).on("emphasis", y).on("normal", x), x()
- }
- o.add(l)
- }
- }
- })
- }
- }), Ps({
- type: "geoRoam",
- event: "geoRoam",
- update: "updateTransform"
- }, function(t, e) {
- var i = t.componentType || "series";
- e.eachComponent({
- mainType: i,
- query: t
- }, function(e) {
- var n = e.coordinateSystem;
- if ("geo" === n.type) {
- var o = wc(n, t, e.get("scaleLimit"));
- e.setCenter && e.setCenter(o.center), e.setZoom && e.setZoom(o.zoom), "series" === i && d(e.seriesGroup,
- function(t) {
- t.setCenter(o.center), t.setZoom(o.zoom)
- })
- }
- })
- });
- Os(function(t) {
- var e = {};
- t.eachSeriesByType("map", function(i) {
- var n = i.getMapType();
- if (!i.getHostGeoModel() && !e[n]) {
- var o = {};
- d(i.seriesGroup, function(e) {
- var i = e.coordinateSystem,
- n = e.originalData;
- e.get("showLegendSymbol") && t.getComponent("legend") && n.each(n.mapDimension("value"), function(t, e) {
- var a = n.getName(e),
- r = i.getRegion(a);
- if (r && !isNaN(t)) {
- var s = o[a] || 0,
- l = i.dataToPoint(r.center);
- o[a] = s + 1, n.setItemLayout(e, {
- point: l,
- offset: s
- })
- }
- })
- });
- var a = i.getData();
- a.each(function(t) {
- var e = a.getName(t),
- i = a.getItemLayout(t) || {};
- i.showLabel = !o[e], a.setItemLayout(t, i)
- }), e[n] = !0
- }
- })
- }), Es(function(t) {
- t.eachSeriesByType("map", function(t) {
- var e = t.get("color"),
- i = t.getModel("itemStyle"),
- n = i.get("areaColor"),
- o = i.get("color") || e[t.seriesIndex % e.length];
- t.getData().setVisual({
- areaColor: n,
- color: o
- })
- })
- }), ks(IT.PROCESSOR.STATISTIC, function(t) {
- var e = {};
- t.eachSeriesByType("map", function(t) {
- var i = t.getHostGeoModel(),
- n = i ? "o" + i.id : "i" + t.getMapType();
- (e[n] = e[n] || []).push(t)
- }), d(e, function(t, e) {
- for (var i = bc(f(t, function(t) {
- return t.getData()
- }), t[0].get("mapValueCalculation")), n = 0; n < t.length; n++) t[n].originalData = t[n].getData();
- for (n = 0; n < t.length; n++) t[n].seriesGroup = t, t[n].needsDrawMap = 0 === n && !t[n].getHostGeoModel(), t[
- n].setData(i.cloneShallow()), t[n].mainSeries = t[0]
- })
- }), Ls(function(t) {
- var e = [];
- d(t.series, function(t) {
- t && "map" === t.type && (e.push(t), t.map = t.map || t.mapType, r(t, t.mapLocation))
- })
- }), XD("map", [{
- type: "mapToggleSelect",
- event: "mapselectchanged",
- method: "toggleSelected"
- }, {
- type: "mapSelect",
- event: "mapselected",
- method: "select"
- }, {
- type: "mapUnSelect",
- event: "mapunselected",
- method: "unSelect"
- }]);
- var MC = d,
- IC = "\0__link_datas",
- TC = "\0__link_mainData",
- AC = function(t, e) {
- this.name = t || "", this.depth = 0, this.height = 0, this.parentNode = null, this.dataIndex = -1, this.children = [],
- this.viewChildren = [], this.hostTree = e
- };
- AC.prototype = {
- constructor: AC,
- isRemoved: function() {
- return this.dataIndex < 0
- },
- eachNode: function(t, e, i) {
- "function" == typeof t && (i = e, e = t, t = null), _(t = t || {}) && (t = {
- order: t
- });
- var n, o = t.order || "preorder",
- a = this[t.attr || "children"];
- "preorder" === o && (n = e.call(i, this));
- for (var r = 0; !n && r < a.length; r++) a[r].eachNode(t, e, i);
- "postorder" === o && e.call(i, this)
- },
- updateDepthAndHeight: function(t) {
- var e = 0;
- this.depth = t;
- for (var i = 0; i < this.children.length; i++) {
- var n = this.children[i];
- n.updateDepthAndHeight(t + 1), n.height > e && (e = n.height)
- }
- this.height = e + 1
- },
- getNodeById: function(t) {
- if (this.getId() === t) return this;
- for (var e = 0, i = this.children, n = i.length; e < n; e++) {
- var o = i[e].getNodeById(t);
- if (o) return o
- }
- },
- contains: function(t) {
- if (t === this) return !0;
- for (var e = 0, i = this.children, n = i.length; e < n; e++) {
- var o = i[e].contains(t);
- if (o) return o
- }
- },
- getAncestors: function(t) {
- for (var e = [], i = t ? this : this.parentNode; i;) e.push(i), i = i.parentNode;
- return e.reverse(), e
- },
- getValue: function(t) {
- var e = this.hostTree.data;
- return e.get(e.getDimension(t || "value"), this.dataIndex)
- },
- setLayout: function(t, e) {
- this.dataIndex >= 0 && this.hostTree.data.setItemLayout(this.dataIndex, t, e)
- },
- getLayout: function() {
- return this.hostTree.data.getItemLayout(this.dataIndex)
- },
- getModel: function(t) {
- if (!(this.dataIndex < 0)) {
- var e, i = this.hostTree,
- n = i.data.getItemModel(this.dataIndex),
- o = this.getLevelModel();
- return o || 0 !== this.children.length && (0 === this.children.length || !1 !== this.isExpand) || (e = this.getLeavesModel()),
- n.getModel(t, (o || e || i.hostModel).getModel(t))
- }
- },
- getLevelModel: function() {
- return (this.hostTree.levelModels || [])[this.depth]
- },
- getLeavesModel: function() {
- return this.hostTree.leavesModel
- },
- setVisual: function(t, e) {
- this.dataIndex >= 0 && this.hostTree.data.setItemVisual(this.dataIndex, t, e)
- },
- getVisual: function(t, e) {
- return this.hostTree.data.getItemVisual(this.dataIndex, t, e)
- },
- getRawIndex: function() {
- return this.hostTree.data.getRawIndex(this.dataIndex)
- },
- getId: function() {
- return this.hostTree.data.getId(this.dataIndex)
- },
- isAncestorOf: function(t) {
- for (var e = t.parentNode; e;) {
- if (e === this) return !0;
- e = e.parentNode
- }
- return !1
- },
- isDescendantOf: function(t) {
- return t !== this && t.isAncestorOf(this)
- }
- }, kc.prototype = {
- constructor: kc,
- type: "tree",
- eachNode: function(t, e, i) {
- this.root.eachNode(t, e, i)
- },
- getNodeByDataIndex: function(t) {
- var e = this.data.getRawIndex(t);
- return this._nodes[e]
- },
- getNodeByName: function(t) {
- return this.root.getNodeByName(t)
- },
- update: function() {
- for (var t = this.data, e = this._nodes, i = 0, n = e.length; i < n; i++) e[i].dataIndex = -1;
- for (var i = 0, n = t.count(); i < n; i++) e[t.getRawIndex(i)].dataIndex = i
- },
- clearLayouts: function() {
- this.data.clearItemLayouts()
- }
- }, kc.createTree = function(t, e, i) {
- function n(t, e) {
- var i = t.value;
- r = Math.max(r, y(i) ? i.length : 1), a.push(t);
- var s = new AC(t.name, o);
- e ? Pc(s, e) : o.root = s, o._nodes.push(s);
- var l = t.children;
- if (l)
- for (var u = 0; u < l.length; u++) n(l[u], s)
- }
- var o = new kc(e, i.levels, i.leaves),
- a = [],
- r = 1;
- n(t), o.root.updateDepthAndHeight(0);
- var s = oA(a, {
- coordDimensions: ["value"],
- dimensionsCount: r
- }),
- l = new eA(s, e);
- return l.initData(a), Sc({
- mainData: l,
- struct: o,
- structAttr: "tree"
- }), o.update(), o
- }, OI.extend({
- type: "series.tree",
- layoutInfo: null,
- layoutMode: "box",
- getInitialData: function(t) {
- var e = {
- name: t.name,
- children: t.data
- },
- i = t.leaves || {},
- n = {};
- n.leaves = i;
- var o = kc.createTree(e, this, n),
- a = 0;
- o.eachNode("preorder", function(t) {
- t.depth > a && (a = t.depth)
- });
- var r = t.expandAndCollapse && t.initialTreeDepth >= 0 ? t.initialTreeDepth : a;
- return o.root.eachNode("preorder", function(t) {
- var e = t.hostTree.data.getRawDataItem(t.dataIndex);
- t.isExpand = e && null != e.collapsed ? !e.collapsed : t.depth <= r
- }), o.data
- },
- getOrient: function() {
- var t = this.get("orient");
- return "horizontal" === t ? t = "LR" : "vertical" === t && (t = "TB"), t
- },
- setZoom: function(t) {
- this.option.zoom = t
- },
- setCenter: function(t) {
- this.option.center = t
- },
- formatTooltip: function(t) {
- for (var e = this.getData().tree, i = e.root.children[0], n = e.getNodeByDataIndex(t), o = n.getValue(), a = n.name; n &&
- n !== i;) a = n.parentNode.name + "." + a, n = n.parentNode;
- return Qo(a + (isNaN(o) || null == o ? "" : " : " + o))
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "view",
- left: "12%",
- top: "12%",
- right: "12%",
- bottom: "12%",
- layout: "orthogonal",
- roam: !1,
- nodeScaleRatio: .4,
- center: null,
- zoom: 1,
- orient: "LR",
- symbol: "emptyCircle",
- symbolSize: 7,
- expandAndCollapse: !0,
- initialTreeDepth: 2,
- lineStyle: {
- color: "#ccc",
- width: 1.5,
- curveness: .5
- },
- itemStyle: {
- color: "lightsteelblue",
- borderColor: "#c23531",
- borderWidth: 1.5
- },
- label: {
- show: !0,
- color: "#555"
- },
- leaves: {
- label: {
- show: !0
- }
- },
- animationEasing: "linear",
- animationDuration: 700,
- animationDurationUpdate: 1e3
- }
- }), Fs({
- type: "tree",
- init: function(t, e) {
- this._oldTree, this._mainGroup = new Zw, this._controller = new ac(e.getZr()), this._controllerHost = {
- target: this.group
- }, this.group.add(this._mainGroup)
- },
- render: function(t, e, i, n) {
- var o = t.getData(),
- a = t.layoutInfo,
- r = this._mainGroup,
- s = t.get("layout");
- "radial" === s ? r.attr("position", [a.x + a.width / 2, a.y + a.height / 2]) : r.attr("position", [a.x, a.y]),
- this._updateViewCoordSys(t), this._updateController(t, e, i);
- var l = this._data,
- u = {
- expandAndCollapse: t.get("expandAndCollapse"),
- layout: s,
- orient: t.getOrient(),
- curvature: t.get("lineStyle.curveness"),
- symbolRotate: t.get("symbolRotate"),
- symbolOffset: t.get("symbolOffset"),
- hoverAnimation: t.get("hoverAnimation"),
- useNameLabel: !0,
- fadeIn: !0
- };
- o.diff(l).add(function(e) {
- Xc(o, e) && Yc(o, e, null, r, t, u)
- }).update(function(e, i) {
- var n = l.getItemGraphicEl(i);
- Xc(o, e) ? Yc(o, e, n, r, t, u) : n && qc(l, i, n, r, t, u)
- }).remove(function(e) {
- var i = l.getItemGraphicEl(e);
- i && qc(l, e, i, r, t, u)
- }).execute(), this._nodeScaleRatio = t.get("nodeScaleRatio"), this._updateNodeAndLinkScale(t), !0 === u.expandAndCollapse &&
- o.eachItemGraphicEl(function(e, n) {
- e.off("click").on("click", function() {
- i.dispatchAction({
- type: "treeExpandAndCollapse",
- seriesId: t.id,
- dataIndex: n
- })
- })
- }), this._data = o
- },
- _updateViewCoordSys: function(t) {
- var e = t.getData(),
- i = [];
- e.each(function(t) {
- var n = e.getItemLayout(t);
- !n || isNaN(n.x) || isNaN(n.y) || i.push([+n.x, +n.y])
- });
- var n = [],
- o = [];
- dn(i, n, o), o[0] - n[0] == 0 && (o[0] += 1, n[0] -= 1), o[1] - n[1] == 0 && (o[1] += 1, n[1] -= 1);
- var a = t.coordinateSystem = new Uh;
- a.zoomLimit = t.get("scaleLimit"), a.setBoundingRect(n[0], n[1], o[0] - n[0], o[1] - n[1]), a.setCenter(t.get(
- "center")), a.setZoom(t.get("zoom")), this.group.attr({
- position: a.position,
- scale: a.scale
- }), this._viewCoordSys = a
- },
- _updateController: function(t, e, i) {
- var n = this._controller,
- o = this._controllerHost,
- a = this.group;
- n.setPointerChecker(function(e, n, o) {
- var r = a.getBoundingRect();
- return r.applyTransform(a.transform), r.contain(n, o) && !mc(e, i, t)
- }), n.enable(t.get("roam")), o.zoomLimit = t.get("scaleLimit"), o.zoom = t.coordinateSystem.getZoom(), n.off(
- "pan").off("zoom").on("pan", function(e) {
- pc(o, e.dx, e.dy), i.dispatchAction({
- seriesId: t.id,
- type: "treeRoam",
- dx: e.dx,
- dy: e.dy
- })
- }, this).on("zoom", function(e) {
- gc(o, e.scale, e.originX, e.originY), i.dispatchAction({
- seriesId: t.id,
- type: "treeRoam",
- zoom: e.scale,
- originX: e.originX,
- originY: e.originY
- }), this._updateNodeAndLinkScale(t)
- }, this)
- },
- _updateNodeAndLinkScale: function(t) {
- var e = t.getData(),
- i = this._getNodeGlobalScale(t),
- n = [i, i];
- e.eachItemGraphicEl(function(t, e) {
- t.attr("scale", n)
- })
- },
- _getNodeGlobalScale: function(t) {
- var e = t.coordinateSystem;
- if ("view" !== e.type) return 1;
- var i = this._nodeScaleRatio,
- n = e.scale,
- o = n && n[0] || 1;
- return ((e.getZoom() - 1) * i + 1) / o
- },
- dispose: function() {
- this._controller && this._controller.dispose(), this._controllerHost = {}
- },
- remove: function() {
- this._mainGroup.removeAll(), this._data = null
- }
- }), Ps({
- type: "treeExpandAndCollapse",
- event: "treeExpandAndCollapse",
- update: "update"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- subType: "tree",
- query: t
- }, function(e) {
- var i = t.dataIndex,
- n = e.getData().tree.getNodeByDataIndex(i);
- n.isExpand = !n.isExpand
- })
- }), Ps({
- type: "treeRoam",
- event: "treeRoam",
- update: "none"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- subType: "tree",
- query: t
- }, function(e) {
- var i = wc(e.coordinateSystem, t);
- e.setCenter && e.setCenter(i.center), e.setZoom && e.setZoom(i.zoom)
- })
- });
- Es(hD("tree", "circle")), Os(function(t, e) {
- t.eachSeriesByType("tree", function(t) {
- Qc(t, e)
- })
- }), OI.extend({
- type: "series.treemap",
- layoutMode: "box",
- dependencies: ["grid", "polar"],
- _viewRoot: null,
- defaultOption: {
- progressive: 0,
- hoverLayerThreshold: 1 / 0,
- left: "center",
- top: "middle",
- right: null,
- bottom: null,
- width: "80%",
- height: "80%",
- sort: !0,
- clipWindow: "origin",
- squareRatio: .5 * (1 + Math.sqrt(5)),
- leafDepth: null,
- drillDownIcon: "▶",
- zoomToNodeRatio: .1024,
- roam: !0,
- nodeClick: "zoomToNode",
- animation: !0,
- animationDurationUpdate: 900,
- animationEasing: "quinticInOut",
- breadcrumb: {
- show: !0,
- height: 22,
- left: "center",
- top: "bottom",
- emptyItemWidth: 25,
- itemStyle: {
- color: "rgba(0,0,0,0.7)",
- borderColor: "rgba(255,255,255,0.7)",
- borderWidth: 1,
- shadowColor: "rgba(150,150,150,1)",
- shadowBlur: 3,
- shadowOffsetX: 0,
- shadowOffsetY: 0,
- textStyle: {
- color: "#fff"
- }
- },
- emphasis: {
- textStyle: {}
- }
- },
- label: {
- show: !0,
- distance: 0,
- padding: 5,
- position: "inside",
- color: "#fff",
- ellipsis: !0
- },
- upperLabel: {
- show: !1,
- position: [0, "50%"],
- height: 20,
- color: "#fff",
- ellipsis: !0,
- verticalAlign: "middle"
- },
- itemStyle: {
- color: null,
- colorAlpha: null,
- colorSaturation: null,
- borderWidth: 0,
- gapWidth: 0,
- borderColor: "#fff",
- borderColorSaturation: null
- },
- emphasis: {
- upperLabel: {
- show: !0,
- position: [0, "50%"],
- color: "#fff",
- ellipsis: !0,
- verticalAlign: "middle"
- }
- },
- visualDimension: 0,
- visualMin: null,
- visualMax: null,
- color: [],
- colorAlpha: null,
- colorSaturation: null,
- colorMappingBy: "index",
- visibleMin: 10,
- childrenVisibleMin: null,
- levels: []
- },
- getInitialData: function(t, e) {
- var i = {
- name: t.name,
- children: t.data
- };
- od(i);
- var n = t.levels || [];
- n = t.levels = ad(n, e);
- var o = {};
- return o.levels = n, kc.createTree(i, this, o).data
- },
- optionUpdated: function() {
- this.resetViewRoot()
- },
- formatTooltip: function(t) {
- var e = this.getData(),
- i = this.getRawValue(t),
- n = $o(y(i) ? i[0] : i);
- return Qo(e.getName(t) + ": " + n)
- },
- getDataParams: function(t) {
- var e = OI.prototype.getDataParams.apply(this, arguments),
- i = this.getData().tree.getNodeByDataIndex(t);
- return e.treePathInfo = nd(i, this), e
- },
- setLayoutInfo: function(t) {
- this.layoutInfo = this.layoutInfo || {}, a(this.layoutInfo, t)
- },
- mapIdToIndex: function(t) {
- var e = this._idIndexMap;
- e || (e = this._idIndexMap = R(), this._idIndexMapCount = 0);
- var i = e.get(t);
- return null == i && e.set(t, i = this._idIndexMapCount++), i
- },
- getViewRoot: function() {
- return this._viewRoot
- },
- resetViewRoot: function(t) {
- t ? this._viewRoot = t : t = this._viewRoot;
- var e = this.getRawData().tree.root;
- t && (t === e || e.contains(t)) || (this._viewRoot = e)
- }
- });
- var DC = 5;
- rd.prototype = {
- constructor: rd,
- render: function(t, e, i, n) {
- var o = t.getModel("breadcrumb"),
- a = this.group;
- if (a.removeAll(), o.get("show") && i) {
- var r = o.getModel("itemStyle"),
- s = r.getModel("textStyle"),
- l = {
- pos: {
- left: o.get("left"),
- right: o.get("right"),
- top: o.get("top"),
- bottom: o.get("bottom")
- },
- box: {
- width: e.getWidth(),
- height: e.getHeight()
- },
- emptyItemWidth: o.get("emptyItemWidth"),
- totalWidth: 0,
- renderList: []
- };
- this._prepare(i, l, s), this._renderContent(t, l, r, s, n), ua(a, l.pos, l.box)
- }
- },
- _prepare: function(t, e, i) {
- for (var n = t; n; n = n.parentNode) {
- var o = n.getModel().get("name"),
- a = i.getTextRect(o),
- r = Math.max(a.width + 16, e.emptyItemWidth);
- e.totalWidth += r + 8, e.renderList.push({
- node: n,
- text: o,
- width: r
- })
- }
- },
- _renderContent: function(t, e, i, n, o) {
- for (var a = 0, s = e.emptyItemWidth, l = t.get("breadcrumb.height"), u = sa(e.pos, e.box), h = e.totalWidth, c =
- e.renderList, d = c.length - 1; d >= 0; d--) {
- var f = c[d],
- p = f.node,
- g = f.width,
- m = f.text;
- h > u.width && (h -= g - s, g = s, m = null);
- var y = new nM({
- shape: {
- points: sd(a, 0, g, l, d === c.length - 1, 0 === d)
- },
- style: r(i.getItemStyle(), {
- lineJoin: "bevel",
- text: m,
- textFill: n.getTextColor(),
- textFont: n.getFont()
- }),
- z: 10,
- onclick: v(o, p)
- });
- this.group.add(y), ld(y, t, p), a += g + 8
- }
- },
- remove: function() {
- this.group.removeAll()
- }
- };
- var CC = m,
- LC = Zw,
- kC = aM,
- PC = d,
- NC = ["label"],
- OC = ["emphasis", "label"],
- EC = ["upperLabel"],
- RC = ["emphasis", "upperLabel"],
- zC = 10,
- BC = 1,
- VC = 2,
- GC = Wb([
- ["fill", "color"],
- ["stroke", "strokeColor"],
- ["lineWidth", "strokeWidth"],
- ["shadowBlur"],
- ["shadowOffsetX"],
- ["shadowOffsetY"],
- ["shadowColor"]
- ]),
- FC = function(t) {
- var e = GC(t);
- return e.stroke = e.fill = e.lineWidth = null, e
- };
- Fs({
- type: "treemap",
- init: function(t, e) {
- this._containerGroup, this._storage = {
- nodeGroup: [],
- background: [],
- content: []
- }, this._oldTree, this._breadcrumb, this._controller, this._state = "ready"
- },
- render: function(t, e, i, n) {
- if (!(l(e.findComponents({
- mainType: "series",
- subType: "treemap",
- query: n
- }), t) < 0)) {
- this.seriesModel = t, this.api = i, this.ecModel = e;
- var o = td(n, ["treemapZoomToNode", "treemapRootToNode"], t),
- a = n && n.type,
- r = t.layoutInfo,
- s = !this._oldTree,
- u = this._storage,
- h = "treemapRootToNode" === a && o && u ? {
- rootNodeGroup: u.nodeGroup[o.node.getRawIndex()],
- direction: n.direction
- } : null,
- c = this._giveContainerGroup(r),
- d = this._doRender(c, t, h);
- s || a && "treemapZoomToNode" !== a && "treemapRootToNode" !== a ? d.renderFinally() : this._doAnimation(c, d,
- t, h), this._resetController(i), this._renderBreadcrumb(t, i, o)
- }
- },
- _giveContainerGroup: function(t) {
- var e = this._containerGroup;
- return e || (e = this._containerGroup = new LC, this._initEvents(e), this.group.add(e)), e.attr("position", [t.x,
- t.y
- ]), e
- },
- _doRender: function(t, e, i) {
- function n(t, e, i, o, a) {
- function r(t) {
- return t.getId()
- }
- function s(r, s) {
- var l = null != r ? t[r] : null,
- u = null != s ? e[s] : null,
- c = h(l, u, i, a);
- c && n(l && l.viewChildren || [], u && u.viewChildren || [], c, o, a + 1)
- }
- o ? (e = t, PC(t, function(t, e) {
- !t.isRemoved() && s(e, e)
- })) : new Hs(e, t, r, r).add(s).update(s).remove(v(s, null)).execute()
- }
- var o = e.getData().tree,
- a = this._oldTree,
- r = {
- nodeGroup: [],
- background: [],
- content: []
- },
- s = {
- nodeGroup: [],
- background: [],
- content: []
- },
- l = this._storage,
- u = [],
- h = v(hd, e, s, l, i, r, u);
- n(o.root ? [o.root] : [], a && a.root ? [a.root] : [], t, o === a || !a, 0);
- var c = function(t) {
- var e = {
- nodeGroup: [],
- background: [],
- content: []
- };
- return t && PC(t, function(t, i) {
- var n = e[i];
- PC(t, function(t) {
- t && (n.push(t), t.__tmWillDelete = 1)
- })
- }), e
- }(l);
- return this._oldTree = o, this._storage = s, {
- lastsForAnimation: r,
- willDeleteEls: c,
- renderFinally: function() {
- PC(c, function(t) {
- PC(t, function(t) {
- t.parent && t.parent.remove(t)
- })
- }), PC(u, function(t) {
- t.invisible = !0, t.dirty()
- })
- }
- }
- },
- _doAnimation: function(t, e, i, n) {
- if (i.get("animation")) {
- var o = i.get("animationDurationUpdate"),
- r = i.get("animationEasing"),
- s = ud();
- PC(e.willDeleteEls, function(t, e) {
- PC(t, function(t, i) {
- if (!t.invisible) {
- var a, l = t.parent;
- if (n && "drillDown" === n.direction) a = l === n.rootNodeGroup ? {
- shape: {
- x: 0,
- y: 0,
- width: l.__tmNodeWidth,
- height: l.__tmNodeHeight
- },
- style: {
- opacity: 0
- }
- } : {
- style: {
- opacity: 0
- }
- };
- else {
- var u = 0,
- h = 0;
- l.__tmWillDelete || (u = l.__tmNodeWidth / 2, h = l.__tmNodeHeight / 2), a = "nodeGroup" === e ? {
- position: [u, h],
- style: {
- opacity: 0
- }
- } : {
- shape: {
- x: u,
- y: h,
- width: 0,
- height: 0
- },
- style: {
- opacity: 0
- }
- }
- }
- a && s.add(t, a, o, r)
- }
- })
- }), PC(this._storage, function(t, i) {
- PC(t, function(t, n) {
- var l = e.lastsForAnimation[i][n],
- u = {};
- l && ("nodeGroup" === i ? l.old && (u.position = t.position.slice(), t.attr("position", l.old)) : (l.old &&
- (u.shape = a({}, t.shape), t.setShape(l.old)), l.fadein ? (t.setStyle("opacity", 0), u.style = {
- opacity: 1
- }) : 1 !== t.style.opacity && (u.style = {
- opacity: 1
- })), s.add(t, u, o, r))
- })
- }, this), this._state = "animating", s.done(CC(function() {
- this._state = "ready", e.renderFinally()
- }, this)).start()
- }
- },
- _resetController: function(t) {
- var e = this._controller;
- e || ((e = this._controller = new ac(t.getZr())).enable(this.seriesModel.get("roam")), e.on("pan", CC(this._onPan,
- this)), e.on("zoom", CC(this._onZoom, this)));
- var i = new ue(0, 0, t.getWidth(), t.getHeight());
- e.setPointerChecker(function(t, e, n) {
- return i.contain(e, n)
- })
- },
- _clearController: function() {
- var t = this._controller;
- t && (t.dispose(), t = null)
- },
- _onPan: function(t) {
- if ("animating" !== this._state && (Math.abs(t.dx) > 3 || Math.abs(t.dy) > 3)) {
- var e = this.seriesModel.getData().tree.root;
- if (!e) return;
- var i = e.getLayout();
- if (!i) return;
- this.api.dispatchAction({
- type: "treemapMove",
- from: this.uid,
- seriesId: this.seriesModel.id,
- rootRect: {
- x: i.x + t.dx,
- y: i.y + t.dy,
- width: i.width,
- height: i.height
- }
- })
- }
- },
- _onZoom: function(t) {
- var e = t.originX,
- i = t.originY;
- if ("animating" !== this._state) {
- var n = this.seriesModel.getData().tree.root;
- if (!n) return;
- var o = n.getLayout();
- if (!o) return;
- var a = new ue(o.x, o.y, o.width, o.height),
- r = this.seriesModel.layoutInfo;
- e -= r.x, i -= r.y;
- var s = mt();
- _t(s, s, [-e, -i]), bt(s, s, [t.scale, t.scale]), _t(s, s, [e, i]), a.applyTransform(s), this.api.dispatchAction({
- type: "treemapRender",
- from: this.uid,
- seriesId: this.seriesModel.id,
- rootRect: {
- x: a.x,
- y: a.y,
- width: a.width,
- height: a.height
- }
- })
- }
- },
- _initEvents: function(t) {
- t.on("click", function(t) {
- if ("ready" === this._state) {
- var e = this.seriesModel.get("nodeClick", !0);
- if (e) {
- var i = this.findTarget(t.offsetX, t.offsetY);
- if (i) {
- var n = i.node;
- if (n.getLayout().isLeafRoot) this._rootToNode(i);
- else if ("zoomToNode" === e) this._zoomToNode(i);
- else if ("link" === e) {
- var o = n.hostTree.data.getItemModel(n.dataIndex),
- a = o.get("link", !0),
- r = o.get("target", !0) || "blank";
- a && window.open(a, r)
- }
- }
- }
- }
- }, this)
- },
- _renderBreadcrumb: function(t, e, i) {
- i || (i = null != t.get("leafDepth", !0) ? {
- node: t.getViewRoot()
- } : this.findTarget(e.getWidth() / 2, e.getHeight() / 2)) || (i = {
- node: t.getData().tree.root
- }), (this._breadcrumb || (this._breadcrumb = new rd(this.group))).render(t, e, i.node, CC(function(e) {
- "animating" !== this._state && (id(t.getViewRoot(), e) ? this._rootToNode({
- node: e
- }) : this._zoomToNode({
- node: e
- }))
- }, this))
- },
- remove: function() {
- this._clearController(), this._containerGroup && this._containerGroup.removeAll(), this._storage = {
- nodeGroup: [],
- background: [],
- content: []
- }, this._state = "ready", this._breadcrumb && this._breadcrumb.remove()
- },
- dispose: function() {
- this._clearController()
- },
- _zoomToNode: function(t) {
- this.api.dispatchAction({
- type: "treemapZoomToNode",
- from: this.uid,
- seriesId: this.seriesModel.id,
- targetNode: t.node
- })
- },
- _rootToNode: function(t) {
- this.api.dispatchAction({
- type: "treemapRootToNode",
- from: this.uid,
- seriesId: this.seriesModel.id,
- targetNode: t.node
- })
- },
- findTarget: function(t, e) {
- var i;
- return this.seriesModel.getViewRoot().eachNode({
- attr: "viewChildren",
- order: "preorder"
- }, function(n) {
- var o = this._storage.background[n.getRawIndex()];
- if (o) {
- var a = o.transformCoordToLocal(t, e),
- r = o.shape;
- if (!(r.x <= a[0] && a[0] <= r.x + r.width && r.y <= a[1] && a[1] <= r.y + r.height)) return !1;
- i = {
- node: n,
- offsetX: a[0],
- offsetY: a[1]
- }
- }
- }, this), i
- }
- });
- for (var WC = ["treemapZoomToNode", "treemapRender", "treemapMove"], HC = 0; HC < WC.length; HC++) Ps({
- type: WC[HC],
- update: "updateView"
- }, function() {});
- Ps({
- type: "treemapRootToNode",
- update: "updateView"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- subType: "treemap",
- query: t
- }, function(e, i) {
- var n = td(t, ["treemapZoomToNode", "treemapRootToNode"], e);
- if (n) {
- var o = e.getViewRoot();
- o && (t.direction = id(o, n.node) ? "rollUp" : "drillDown"), e.resetViewRoot(n.node)
- }
- })
- });
- var ZC = d,
- UC = w,
- XC = -1,
- jC = function(t) {
- var e = t.mappingMethod,
- n = t.type,
- o = this.option = i(t);
- this.type = n, this.mappingMethod = e, this._normalizeData = qC[e];
- var a = YC[n];
- this.applyVisual = a.applyVisual, this.getColorMapper = a.getColorMapper, this._doMap = a._doMap[e], "piecewise" ===
- e ? (pd(o), dd(o)) : "category" === e ? o.categories ? fd(o) : pd(o, !0) : (k("linear" !== e || o.dataExtent), pd(
- o))
- };
- jC.prototype = {
- constructor: jC,
- mapValueToVisual: function(t) {
- var e = this._normalizeData(t);
- return this._doMap(e, t)
- },
- getNormalizer: function() {
- return m(this._normalizeData, this)
- }
- };
- var YC = jC.visualHandlers = {
- color: {
- applyVisual: vd("color"),
- getColorMapper: function() {
- var t = this.option;
- return m("category" === t.mappingMethod ? function(t, e) {
- return !e && (t = this._normalizeData(t)), yd.call(this, t)
- } : function(e, i, n) {
- var o = !!n;
- return !i && (e = this._normalizeData(e)), n = Wt(e, t.parsedVisual, n), o ? n : Xt(n, "rgba")
- }, this)
- },
- _doMap: {
- linear: function(t) {
- return Xt(Wt(t, this.option.parsedVisual), "rgba")
- },
- category: yd,
- piecewise: function(t, e) {
- var i = wd.call(this, e);
- return null == i && (i = Xt(Wt(t, this.option.parsedVisual), "rgba")), i
- },
- fixed: xd
- }
- },
- colorHue: gd(function(t, e) {
- return Zt(t, e)
- }),
- colorSaturation: gd(function(t, e) {
- return Zt(t, null, e)
- }),
- colorLightness: gd(function(t, e) {
- return Zt(t, null, null, e)
- }),
- colorAlpha: gd(function(t, e) {
- return Ut(t, e)
- }),
- opacity: {
- applyVisual: vd("opacity"),
- _doMap: _d([0, 1])
- },
- liftZ: {
- applyVisual: vd("liftZ"),
- _doMap: {
- linear: xd,
- category: xd,
- piecewise: xd,
- fixed: xd
- }
- },
- symbol: {
- applyVisual: function(t, e, i) {
- var n = this.mapValueToVisual(t);
- if (_(n)) i("symbol", n);
- else if (UC(n))
- for (var o in n) n.hasOwnProperty(o) && i(o, n[o])
- },
- _doMap: {
- linear: md,
- category: yd,
- piecewise: function(t, e) {
- var i = wd.call(this, e);
- return null == i && (i = md.call(this, t)), i
- },
- fixed: xd
- }
- },
- symbolSize: {
- applyVisual: vd("symbolSize"),
- _doMap: _d([0, 1])
- }
- },
- qC = {
- linear: function(t) {
- return Eo(t, this.option.dataExtent, [0, 1], !0)
- },
- piecewise: function(t) {
- var e = this.option.pieceList,
- i = jC.findPieceIndex(t, e, !0);
- if (null != i) return Eo(i, [0, e.length - 1], [0, 1], !0)
- },
- category: function(t) {
- var e = this.option.categories ? this.option.categoryMap[t] : t;
- return null == e ? XC : e
- },
- fixed: B
- };
- jC.listVisualTypes = function() {
- var t = [];
- return d(YC, function(e, i) {
- t.push(i)
- }), t
- }, jC.addVisualHandler = function(t, e) {
- YC[t] = e
- }, jC.isValidType = function(t) {
- return YC.hasOwnProperty(t)
- }, jC.eachVisual = function(t, e, i) {
- w(t) ? d(t, e, i) : e.call(i, t)
- }, jC.mapVisual = function(t, e, i) {
- var n, o = y(t) ? [] : w(t) ? {} : (n = !0, null);
- return jC.eachVisual(t, function(t, a) {
- var r = e.call(i, t, a);
- n ? o = r : o[a] = r
- }), o
- }, jC.retrieveVisuals = function(t) {
- var e, i = {};
- return t && ZC(YC, function(n, o) {
- t.hasOwnProperty(o) && (i[o] = t[o], e = !0)
- }), e ? i : null
- }, jC.prepareVisualTypes = function(t) {
- if (UC(t)) {
- var e = [];
- ZC(t, function(t, i) {
- e.push(i)
- }), t = e
- } else {
- if (!y(t)) return [];
- t = t.slice()
- }
- return t.sort(function(t, e) {
- return "color" === e && "color" !== t && 0 === t.indexOf("color") ? 1 : -1
- }), t
- }, jC.dependsOn = function(t, e) {
- return "color" === e ? !(!t || 0 !== t.indexOf(e)) : t === e
- }, jC.findPieceIndex = function(t, e, i) {
- function n(e, i) {
- var n = Math.abs(e - t);
- n < a && (a = n, o = i)
- }
- for (var o, a = 1 / 0, r = 0, s = e.length; r < s; r++) {
- var l = e[r].value;
- if (null != l) {
- if (l === t || "string" == typeof l && l === t + "") return r;
- i && n(l, r)
- }
- }
- for (var r = 0, s = e.length; r < s; r++) {
- var u = e[r],
- h = u.interval,
- c = u.close;
- if (h) {
- if (h[0] === -1 / 0) {
- if (Sd(c[1], t, h[1])) return r
- } else if (h[1] === 1 / 0) {
- if (Sd(c[0], h[0], t)) return r
- } else if (Sd(c[0], h[0], t) && Sd(c[1], t, h[1])) return r;
- i && n(h[0], r), i && n(h[1], r)
- }
- }
- if (i) return t === 1 / 0 ? e.length - 1 : t === -1 / 0 ? 0 : o
- };
- var KC = y,
- $C = "itemStyle",
- JC = {
- seriesType: "treemap",
- reset: function(t, e, i, n) {
- var o = t.getData().tree,
- a = o.root,
- r = t.getModel($C);
- a.isRemoved() || Md(a, {}, f(o.levelModels, function(t) {
- return t ? t.get($C) : null
- }), r, t.getViewRoot().getAncestors(), t)
- }
- },
- QC = Math.max,
- tL = Math.min,
- eL = T,
- iL = d,
- nL = ["itemStyle", "borderWidth"],
- oL = ["itemStyle", "gapWidth"],
- aL = ["upperLabel", "show"],
- rL = ["upperLabel", "height"],
- sL = {
- seriesType: "treemap",
- reset: function(t, e, i, n) {
- var o = i.getWidth(),
- r = i.getHeight(),
- s = t.option,
- l = la(t.getBoxLayoutParams(), {
- width: i.getWidth(),
- height: i.getHeight()
- }),
- u = s.size || [],
- h = Ro(eL(l.width, u[0]), o),
- c = Ro(eL(l.height, u[1]), r),
- d = n && n.type,
- f = td(n, ["treemapZoomToNode", "treemapRootToNode"], t),
- p = "treemapRender" === d || "treemapMove" === d ? n.rootRect : null,
- g = t.getViewRoot(),
- m = ed(g);
- if ("treemapMove" !== d) {
- var v = "treemapZoomToNode" === d ? Vd(t, f, g, h, c) : p ? [p.width, p.height] : [h, c],
- y = s.sort;
- y && "asc" !== y && "desc" !== y && (y = "desc");
- var x = {
- squareRatio: s.squareRatio,
- sort: y,
- leafDepth: s.leafDepth
- };
- g.hostTree.clearLayouts();
- _ = {
- x: 0,
- y: 0,
- width: v[0],
- height: v[1],
- area: v[0] * v[1]
- };
- g.setLayout(_), Pd(g, x, !1, 0);
- var _ = g.getLayout();
- iL(m, function(t, e) {
- var i = (m[e + 1] || g).getValue();
- t.setLayout(a({
- dataExtent: [i, i],
- borderWidth: 0,
- upperHeight: 0
- }, _))
- })
- }
- var w = t.getData().tree.root;
- w.setLayout(Gd(l, p, f), !0), t.setLayoutInfo(l), Fd(w, new ue(-l.x, -l.y, o, r), m, g, 0)
- }
- };
- Es(JC), Os(sL);
- var lL = function(t) {
- this._directed = t || !1, this.nodes = [], this.edges = [], this._nodesMap = {}, this._edgesMap = {}, this.data,
- this.edgeData
- },
- uL = lL.prototype;
- uL.type = "graph", uL.isDirected = function() {
- return this._directed
- }, uL.addNode = function(t, e) {
- t = t || "" + e;
- var i = this._nodesMap;
- if (!i[Hd(t)]) {
- var n = new Zd(t, e);
- return n.hostGraph = this, this.nodes.push(n), i[Hd(t)] = n, n
- }
- }, uL.getNodeByIndex = function(t) {
- var e = this.data.getRawIndex(t);
- return this.nodes[e]
- }, uL.getNodeById = function(t) {
- return this._nodesMap[Hd(t)]
- }, uL.addEdge = function(t, e, i) {
- var n = this._nodesMap,
- o = this._edgesMap;
- if ("number" == typeof t && (t = this.nodes[t]), "number" == typeof e && (e = this.nodes[e]), Zd.isInstance(t) || (
- t = n[Hd(t)]), Zd.isInstance(e) || (e = n[Hd(e)]), t && e) {
- var a = t.id + "-" + e.id;
- if (!o[a]) {
- var r = new Ud(t, e, i);
- return r.hostGraph = this, this._directed && (t.outEdges.push(r), e.inEdges.push(r)), t.edges.push(r), t !== e &&
- e.edges.push(r), this.edges.push(r), o[a] = r, r
- }
- }
- }, uL.getEdgeByIndex = function(t) {
- var e = this.edgeData.getRawIndex(t);
- return this.edges[e]
- }, uL.getEdge = function(t, e) {
- Zd.isInstance(t) && (t = t.id), Zd.isInstance(e) && (e = e.id);
- var i = this._edgesMap;
- return this._directed ? i[t + "-" + e] : i[t + "-" + e] || i[e + "-" + t]
- }, uL.eachNode = function(t, e) {
- for (var i = this.nodes, n = i.length, o = 0; o < n; o++) i[o].dataIndex >= 0 && t.call(e, i[o], o)
- }, uL.eachEdge = function(t, e) {
- for (var i = this.edges, n = i.length, o = 0; o < n; o++) i[o].dataIndex >= 0 && i[o].node1.dataIndex >= 0 && i[o].node2
- .dataIndex >= 0 && t.call(e, i[o], o)
- }, uL.breadthFirstTraverse = function(t, e, i, n) {
- if (Zd.isInstance(e) || (e = this._nodesMap[Hd(e)]), e) {
- for (var o = "out" === i ? "outEdges" : "in" === i ? "inEdges" : "edges", a = 0; a < this.nodes.length; a++) this.nodes[
- a].__visited = !1;
- if (!t.call(n, e, null))
- for (var r = [e]; r.length;)
- for (var s = r.shift(), l = s[o], a = 0; a < l.length; a++) {
- var u = l[a],
- h = u.node1 === s ? u.node2 : u.node1;
- if (!h.__visited) {
- if (t.call(n, h, s)) return;
- r.push(h), h.__visited = !0
- }
- }
- }
- }, uL.update = function() {
- for (var t = this.data, e = this.edgeData, i = this.nodes, n = this.edges, o = 0, a = i.length; o < a; o++) i[o].dataIndex = -
- 1;
- for (var o = 0, a = t.count(); o < a; o++) i[t.getRawIndex(o)].dataIndex = o;
- e.filterSelf(function(t) {
- var i = n[e.getRawIndex(t)];
- return i.node1.dataIndex >= 0 && i.node2.dataIndex >= 0
- });
- for (var o = 0, a = n.length; o < a; o++) n[o].dataIndex = -1;
- for (var o = 0, a = e.count(); o < a; o++) n[e.getRawIndex(o)].dataIndex = o
- }, uL.clone = function() {
- for (var t = new lL(this._directed), e = this.nodes, i = this.edges, n = 0; n < e.length; n++) t.addNode(e[n].id, e[
- n].dataIndex);
- for (n = 0; n < i.length; n++) {
- var o = i[n];
- t.addEdge(o.node1.id, o.node2.id, o.dataIndex)
- }
- return t
- }, Zd.prototype = {
- constructor: Zd,
- degree: function() {
- return this.edges.length
- },
- inDegree: function() {
- return this.inEdges.length
- },
- outDegree: function() {
- return this.outEdges.length
- },
- getModel: function(t) {
- if (!(this.dataIndex < 0)) return this.hostGraph.data.getItemModel(this.dataIndex).getModel(t)
- }
- }, Ud.prototype.getModel = function(t) {
- if (!(this.dataIndex < 0)) return this.hostGraph.edgeData.getItemModel(this.dataIndex).getModel(t)
- };
- var hL = function(t, e) {
- return {
- getValue: function(i) {
- var n = this[t][e];
- return n.get(n.getDimension(i || "value"), this.dataIndex)
- },
- setVisual: function(i, n) {
- this.dataIndex >= 0 && this[t][e].setItemVisual(this.dataIndex, i, n)
- },
- getVisual: function(i, n) {
- return this[t][e].getItemVisual(this.dataIndex, i, n)
- },
- setLayout: function(i, n) {
- this.dataIndex >= 0 && this[t][e].setItemLayout(this.dataIndex, i, n)
- },
- getLayout: function() {
- return this[t][e].getItemLayout(this.dataIndex)
- },
- getGraphicEl: function() {
- return this[t][e].getItemGraphicEl(this.dataIndex)
- },
- getRawIndex: function() {
- return this[t][e].getRawIndex(this.dataIndex)
- }
- }
- };
- h(Zd, hL("hostGraph", "data")), h(Ud, hL("hostGraph", "edgeData")), lL.Node = Zd, lL.Edge = Ud, ji(Zd), ji(Ud);
- var cL = function(t, e, i, n, o) {
- for (var a = new lL(n), r = 0; r < t.length; r++) a.addNode(T(t[r].id, t[r].name, r), r);
- for (var s = [], u = [], h = 0, r = 0; r < e.length; r++) {
- var c = e[r],
- d = c.source,
- f = c.target;
- a.addEdge(d, f, h) && (u.push(c), s.push(T(c.id, d + " > " + f)), h++)
- }
- var p, g = i.get("coordinateSystem");
- if ("cartesian2d" === g || "polar" === g) p = dl(t, i);
- else {
- var m = Ba.get(g),
- v = m && "view" !== m.type ? m.dimensions || [] : [];
- l(v, "value") < 0 && v.concat(["value"]);
- var y = oA(t, {
- coordDimensions: v
- });
- (p = new eA(y, i)).initData(t)
- }
- var x = new eA(["value"], i);
- return x.initData(u, s), o && o(p, x), Sc({
- mainData: p,
- struct: a,
- structAttr: "graph",
- datas: {
- node: p,
- edge: x
- },
- datasAttr: {
- node: "data",
- edge: "edgeData"
- }
- }), a.update(), a
- },
- dL = Gs({
- type: "series.graph",
- init: function(t) {
- dL.superApply(this, "init", arguments), this.legendDataProvider = function() {
- return this._categoriesData
- }, this.fillDataTextStyle(t.edges || t.links), this._updateCategoriesData()
- },
- mergeOption: function(t) {
- dL.superApply(this, "mergeOption", arguments), this.fillDataTextStyle(t.edges || t.links), this._updateCategoriesData()
- },
- mergeDefaultAndTheme: function(t) {
- dL.superApply(this, "mergeDefaultAndTheme", arguments), Ci(t, ["edgeLabel"], ["show"])
- },
- getInitialData: function(t, e) {
- var i = t.edges || t.links || [],
- n = t.data || t.nodes || [],
- o = this;
- if (n && i) return cL(n, i, this, !0, function(t, i) {
- function n(t) {
- return (t = this.parsePath(t)) && "label" === t[0] ? r : t && "emphasis" === t[0] && "label" === t[1] ? l :
- this.parentModel
- }
- t.wrapMethod("getItemModel", function(t) {
- var e = o._categoriesModels[t.getShallow("category")];
- return e && (e.parentModel = t.parentModel, t.parentModel = e), t
- });
- var a = o.getModel("edgeLabel"),
- r = new Lo({
- label: a.option
- }, a.parentModel, e),
- s = o.getModel("emphasis.edgeLabel"),
- l = new Lo({
- emphasis: {
- label: s.option
- }
- }, s.parentModel, e);
- i.wrapMethod("getItemModel", function(t) {
- return t.customizeGetParent(n), t
- })
- }).data
- },
- getGraph: function() {
- return this.getData().graph
- },
- getEdgeData: function() {
- return this.getGraph().edgeData
- },
- getCategoriesData: function() {
- return this._categoriesData
- },
- formatTooltip: function(t, e, i) {
- if ("edge" === i) {
- var n = this.getData(),
- o = this.getDataParams(t, i),
- a = n.graph.getEdgeByIndex(t),
- r = n.getName(a.node1.dataIndex),
- s = n.getName(a.node2.dataIndex),
- l = [];
- return null != r && l.push(r), null != s && l.push(s), l = Qo(l.join(" > ")), o.value && (l += " : " + Qo(o.value)),
- l
- }
- return dL.superApply(this, "formatTooltip", arguments)
- },
- _updateCategoriesData: function() {
- var t = f(this.option.categories || [], function(t) {
- return null != t.value ? t : a({
- value: 0
- }, t)
- }),
- e = new eA(["value"], this);
- e.initData(t), this._categoriesData = e, this._categoriesModels = e.mapArray(function(t) {
- return e.getItemModel(t, !0)
- })
- },
- setZoom: function(t) {
- this.option.zoom = t
- },
- setCenter: function(t) {
- this.option.center = t
- },
- isAnimationEnabled: function() {
- return dL.superCall(this, "isAnimationEnabled") && !("force" === this.get("layout") && this.get(
- "force.layoutAnimation"))
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "view",
- legendHoverLink: !0,
- hoverAnimation: !0,
- layout: null,
- focusNodeAdjacency: !1,
- circular: {
- rotateLabel: !1
- },
- force: {
- initLayout: null,
- repulsion: [0, 50],
- gravity: .1,
- edgeLength: 30,
- layoutAnimation: !0
- },
- left: "center",
- top: "center",
- symbol: "circle",
- symbolSize: 10,
- edgeSymbol: ["none", "none"],
- edgeSymbolSize: 10,
- edgeLabel: {
- position: "middle"
- },
- draggable: !1,
- roam: !1,
- center: null,
- zoom: 1,
- nodeScaleRatio: .6,
- label: {
- show: !1,
- formatter: "{b}"
- },
- itemStyle: {},
- lineStyle: {
- color: "#aaa",
- width: 1,
- curveness: 0,
- opacity: .5
- },
- emphasis: {
- label: {
- show: !0
- }
- }
- }
- }),
- fL = rM.prototype,
- pL = lM.prototype,
- gL = Fn({
- type: "ec-line",
- style: {
- stroke: "#000",
- fill: null
- },
- shape: {
- x1: 0,
- y1: 0,
- x2: 0,
- y2: 0,
- percent: 1,
- cpx1: null,
- cpy1: null
- },
- buildPath: function(t, e) {
- (Xd(e) ? fL : pL).buildPath(t, e)
- },
- pointAt: function(t) {
- return Xd(this.shape) ? fL.pointAt.call(this, t) : pL.pointAt.call(this, t)
- },
- tangentAt: function(t) {
- var e = this.shape,
- i = Xd(e) ? [e.x2 - e.x1, e.y2 - e.y1] : pL.tangentAt.call(this, t);
- return q(i, i)
- }
- }),
- mL = ["fromSymbol", "toSymbol"],
- vL = $d.prototype;
- vL.beforeUpdate = function() {
- var t = this,
- e = t.childOfName("fromSymbol"),
- i = t.childOfName("toSymbol"),
- n = t.childOfName("label");
- if (e || i || !n.ignore) {
- for (var o = 1, a = this.parent; a;) a.scale && (o /= a.scale[0]), a = a.parent;
- var r = t.childOfName("line");
- if (this.__dirty || r.__dirty) {
- var s = r.shape.percent,
- l = r.pointAt(0),
- u = r.pointAt(s),
- h = U([], u, l);
- if (q(h, h), e && (e.attr("position", l), c = r.tangentAt(0), e.attr("rotation", Math.PI / 2 - Math.atan2(c[1], c[
- 0])), e.attr("scale", [o * s, o * s])), i) {
- i.attr("position", u);
- var c = r.tangentAt(1);
- i.attr("rotation", -Math.PI / 2 - Math.atan2(c[1], c[0])), i.attr("scale", [o * s, o * s])
- }
- if (!n.ignore) {
- n.attr("position", u);
- var d, f, p, g = 5 * o;
- if ("end" === n.__position) d = [h[0] * g + u[0], h[1] * g + u[1]], f = h[0] > .8 ? "left" : h[0] < -.8 ?
- "right" : "center", p = h[1] > .8 ? "top" : h[1] < -.8 ? "bottom" : "middle";
- else if ("middle" === n.__position) {
- var m = s / 2,
- v = [(c = r.tangentAt(m))[1], -c[0]],
- y = r.pointAt(m);
- v[1] > 0 && (v[0] = -v[0], v[1] = -v[1]), d = [y[0] + v[0] * g, y[1] + v[1] * g], f = "center", p = "bottom";
- var x = -Math.atan2(c[1], c[0]);
- u[0] < l[0] && (x = Math.PI + x), n.attr("rotation", x)
- } else d = [-h[0] * g + l[0], -h[1] * g + l[1]], f = h[0] > .8 ? "right" : h[0] < -.8 ? "left" : "center", p = h[
- 1] > .8 ? "bottom" : h[1] < -.8 ? "top" : "middle";
- n.attr({
- style: {
- textVerticalAlign: n.__verticalAlign || p,
- textAlign: n.__textAlign || f
- },
- position: d,
- scale: [o, o]
- })
- }
- }
- }
- }, vL._createLine = function(t, e, i) {
- var n = t.hostModel,
- o = qd(t.getItemLayout(e));
- o.shape.percent = 0, So(o, {
- shape: {
- percent: 1
- }
- }, n, e), this.add(o);
- var a = new qS({
- name: "label"
- });
- this.add(a), d(mL, function(i) {
- var n = Yd(i, t, e);
- this.add(n), this[jd(i)] = t.getItemVisual(e, i)
- }, this), this._updateCommonStl(t, e, i)
- }, vL.updateData = function(t, e, i) {
- var n = t.hostModel,
- o = this.childOfName("line"),
- a = t.getItemLayout(e),
- r = {
- shape: {}
- };
- Kd(r.shape, a), bo(o, r, n, e), d(mL, function(i) {
- var n = t.getItemVisual(e, i),
- o = jd(i);
- if (this[o] !== n) {
- this.remove(this.childOfName(i));
- var a = Yd(i, t, e);
- this.add(a)
- }
- this[o] = n
- }, this), this._updateCommonStl(t, e, i)
- }, vL._updateCommonStl = function(t, e, i) {
- var n = t.hostModel,
- o = this.childOfName("line"),
- a = i && i.lineStyle,
- s = i && i.hoverLineStyle,
- l = i && i.labelModel,
- u = i && i.hoverLabelModel;
- if (!i || t.hasItemOption) {
- var h = t.getItemModel(e);
- a = h.getModel("lineStyle").getLineStyle(), s = h.getModel("emphasis.lineStyle").getLineStyle(), l = h.getModel(
- "label"), u = h.getModel("emphasis.label")
- }
- var c = t.getItemVisual(e, "color"),
- f = D(t.getItemVisual(e, "opacity"), a.opacity, 1);
- o.useStyle(r({
- strokeNoScale: !0,
- fill: "none",
- stroke: c,
- opacity: f
- }, a)), o.hoverStyle = s, d(mL, function(t) {
- var e = this.childOfName(t);
- e && (e.setColor(c), e.setStyle({
- opacity: f
- }))
- }, this);
- var p, g, m = l.getShallow("show"),
- v = u.getShallow("show"),
- y = this.childOfName("label");
- if ((m || v) && (p = c || "#000", null == (g = n.getFormattedLabel(e, "normal", t.dataType)))) {
- var x = n.getRawValue(e);
- g = null == x ? t.getName(e) : isFinite(x) ? zo(x) : x
- }
- var _ = m ? g : null,
- w = v ? A(n.getFormattedLabel(e, "emphasis", t.dataType), g) : null,
- b = y.style;
- null == _ && null == w || (fo(y.style, l, {
- text: _
- }, {
- autoColor: p
- }), y.__textAlign = b.textAlign, y.__verticalAlign = b.textVerticalAlign, y.__position = l.get("position") ||
- "middle"), y.hoverStyle = null != w ? {
- text: w,
- textFill: u.getTextColor(!0),
- fontStyle: u.getShallow("fontStyle"),
- fontWeight: u.getShallow("fontWeight"),
- fontSize: u.getShallow("fontSize"),
- fontFamily: u.getShallow("fontFamily")
- } : {
- text: null
- }, y.ignore = !m && !v, uo(this)
- }, vL.highlight = function() {
- this.trigger("emphasis")
- }, vL.downplay = function() {
- this.trigger("normal")
- }, vL.updateLayout = function(t, e) {
- this.setLinePoints(t.getItemLayout(e))
- }, vL.setLinePoints = function(t) {
- var e = this.childOfName("line");
- Kd(e.shape, t), e.dirty()
- }, u($d, Zw);
- var yL = Jd.prototype;
- yL.isPersistent = function() {
- return !0
- }, yL.updateData = function(t) {
- var e = this,
- i = e.group,
- n = e._lineData;
- e._lineData = t, n || i.removeAll();
- var o = ef(t);
- t.diff(n).add(function(i) {
- Qd(e, t, i, o)
- }).update(function(i, a) {
- tf(e, n, t, a, i, o)
- }).remove(function(t) {
- i.remove(n.getItemGraphicEl(t))
- }).execute()
- }, yL.updateLayout = function() {
- var t = this._lineData;
- t && t.eachItemGraphicEl(function(e, i) {
- e.updateLayout(t, i)
- }, this)
- }, yL.incrementalPrepareUpdate = function(t) {
- this._seriesScope = ef(t), this._lineData = null, this.group.removeAll()
- }, yL.incrementalUpdate = function(t, e) {
- for (var i = t.start; i < t.end; i++)
- if ( of (e.getItemLayout(i))) {
- var n = new this._ctor(e, i, this._seriesScope);
- n.traverse(function(t) {
- t.isGroup || (t.incremental = t.useHoverLayer = !0)
- }), this.group.add(n), e.setItemGraphicEl(i, n)
- }
- }, yL.remove = function() {
- this._clearIncremental(), this._incremental = null, this.group.removeAll()
- }, yL._clearIncremental = function() {
- var t = this._incremental;
- t && t.clearDisplaybles()
- };
- var xL = [],
- _L = [],
- wL = [],
- bL = rn,
- SL = iw,
- ML = Math.abs,
- IL = function(t, e) {
- function i(t) {
- var e = t.getVisual("symbolSize");
- return e instanceof Array && (e = (e[0] + e[1]) / 2), e
- }
- var n = [],
- o = hn,
- a = [
- [],
- [],
- []
- ],
- r = [
- [],
- []
- ],
- s = [];
- e /= 2, t.eachEdge(function(t, l) {
- var u = t.getLayout(),
- h = t.getVisual("fromSymbol"),
- c = t.getVisual("toSymbol");
- u.__original || (u.__original = [F(u[0]), F(u[1])], u[2] && u.__original.push(F(u[2])));
- var d = u.__original;
- if (null != u[2]) {
- if (G(a[0], d[0]), G(a[1], d[2]), G(a[2], d[1]), h && "none" !== h) {
- var f = i(t.node1),
- p = af(a, d[0], f * e);
- o(a[0][0], a[1][0], a[2][0], p, n), a[0][0] = n[3], a[1][0] = n[4], o(a[0][1], a[1][1], a[2][1], p, n), a[0][1] =
- n[3], a[1][1] = n[4]
- }
- if (c && "none" !== c) {
- var f = i(t.node2),
- p = af(a, d[1], f * e);
- o(a[0][0], a[1][0], a[2][0], p, n), a[1][0] = n[1], a[2][0] = n[2], o(a[0][1], a[1][1], a[2][1], p, n), a[1][1] =
- n[1], a[2][1] = n[2]
- }
- G(u[0], a[0]), G(u[1], a[2]), G(u[2], a[1])
- } else {
- if (G(r[0], d[0]), G(r[1], d[1]), U(s, r[1], r[0]), q(s, s), h && "none" !== h) {
- f = i(t.node1);
- Z(r[0], r[0], s, f * e)
- }
- if (c && "none" !== c) {
- f = i(t.node2);
- Z(r[1], r[1], s, -f * e)
- }
- G(u[0], r[0]), G(u[1], r[1])
- }
- })
- },
- TL = ["itemStyle", "opacity"],
- AL = ["lineStyle", "opacity"];
- Fs({
- type: "graph",
- init: function(t, e) {
- var i = new Su,
- n = new Jd,
- o = this.group;
- this._controller = new ac(e.getZr()), this._controllerHost = {
- target: o
- }, o.add(i.group), o.add(n.group), this._symbolDraw = i, this._lineDraw = n, this._firstRender = !0
- },
- render: function(t, e, i) {
- var n = t.coordinateSystem;
- this._model = t, this._nodeScaleRatio = t.get("nodeScaleRatio");
- var o = this._symbolDraw,
- a = this._lineDraw,
- r = this.group;
- if ("view" === n.type) {
- var s = {
- position: n.position,
- scale: n.scale
- };
- this._firstRender ? r.attr(s) : bo(r, s, t)
- }
- IL(t.getGraph(), this._getNodeGlobalScale(t));
- var l = t.getData();
- o.updateData(l);
- var u = t.getEdgeData();
- a.updateData(u), this._updateNodeAndLinkScale(), this._updateController(t, e, i), clearTimeout(this._layoutTimeout);
- var h = t.forceLayout,
- c = t.get("force.layoutAnimation");
- h && this._startForceLayoutIteration(h, c), l.eachItemGraphicEl(function(e, n) {
- var o = l.getItemModel(n);
- e.off("drag").off("dragend");
- var a = o.get("draggable");
- a && e.on("drag", function() {
- h && (h.warmUp(), !this._layouting && this._startForceLayoutIteration(h, c), h.setFixed(n), l.setItemLayout(
- n, e.position))
- }, this).on("dragend", function() {
- h && h.setUnfixed(n)
- }, this), e.setDraggable(a && h), e.off("mouseover", e.__focusNodeAdjacency), e.off("mouseout", e.__unfocusNodeAdjacency),
- o.get("focusNodeAdjacency") && (e.on("mouseover", e.__focusNodeAdjacency = function() {
- i.dispatchAction({
- type: "focusNodeAdjacency",
- seriesId: t.id,
- dataIndex: e.dataIndex
- })
- }), e.on("mouseout", e.__unfocusNodeAdjacency = function() {
- i.dispatchAction({
- type: "unfocusNodeAdjacency",
- seriesId: t.id
- })
- }))
- }, this), l.graph.eachEdge(function(e) {
- var n = e.getGraphicEl();
- n.off("mouseover", n.__focusNodeAdjacency), n.off("mouseout", n.__unfocusNodeAdjacency), e.getModel().get(
- "focusNodeAdjacency") && (n.on("mouseover", n.__focusNodeAdjacency = function() {
- i.dispatchAction({
- type: "focusNodeAdjacency",
- seriesId: t.id,
- edgeDataIndex: e.dataIndex
- })
- }), n.on("mouseout", n.__unfocusNodeAdjacency = function() {
- i.dispatchAction({
- type: "unfocusNodeAdjacency",
- seriesId: t.id
- })
- }))
- });
- var d = "circular" === t.get("layout") && t.get("circular.rotateLabel"),
- f = l.getLayout("cx"),
- p = l.getLayout("cy");
- l.eachItemGraphicEl(function(t, e) {
- var i = t.getSymbolPath();
- if (d) {
- var n = l.getItemLayout(e),
- o = Math.atan2(n[1] - p, n[0] - f);
- o < 0 && (o = 2 * Math.PI + o);
- var a = n[0] < f;
- a && (o -= Math.PI);
- var r = a ? "left" : "right";
- i.setStyle({
- textRotation: -o,
- textPosition: r,
- textOrigin: "center"
- }), i.hoverStyle && (i.hoverStyle.textPosition = r)
- } else i.setStyle({
- textRotation: 0
- })
- }), this._firstRender = !1
- },
- dispose: function() {
- this._controller && this._controller.dispose(), this._controllerHost = {}
- },
- focusNodeAdjacency: function(t, e, i, n) {
- var o = this._model.getData().graph,
- a = n.dataIndex,
- r = n.edgeDataIndex,
- s = o.getNodeByIndex(a),
- l = o.getEdgeByIndex(r);
- (s || l) && (o.eachNode(function(t) {
- sf(t, TL, .1)
- }), o.eachEdge(function(t) {
- sf(t, AL, .1)
- }), s && (lf(s, TL), d(s.edges, function(t) {
- t.dataIndex < 0 || (lf(t, AL), lf(t.node1, TL), lf(t.node2, TL))
- })), l && (lf(l, AL), lf(l.node1, TL), lf(l.node2, TL)))
- },
- unfocusNodeAdjacency: function(t, e, i, n) {
- var o = this._model.getData().graph;
- o.eachNode(function(t) {
- sf(t, TL)
- }), o.eachEdge(function(t) {
- sf(t, AL)
- })
- },
- _startForceLayoutIteration: function(t, e) {
- var i = this;
- ! function n() {
- t.step(function(t) {
- i.updateLayout(i._model), (i._layouting = !t) && (e ? i._layoutTimeout = setTimeout(n, 16) : n())
- })
- }()
- },
- _updateController: function(t, e, i) {
- var n = this._controller,
- o = this._controllerHost,
- a = this.group;
- n.setPointerChecker(function(e, n, o) {
- var r = a.getBoundingRect();
- return r.applyTransform(a.transform), r.contain(n, o) && !mc(e, i, t)
- }), "view" === t.coordinateSystem.type ? (n.enable(t.get("roam")), o.zoomLimit = t.get("scaleLimit"), o.zoom =
- t.coordinateSystem.getZoom(), n.off("pan").off("zoom").on("pan", function(e) {
- pc(o, e.dx, e.dy), i.dispatchAction({
- seriesId: t.id,
- type: "graphRoam",
- dx: e.dx,
- dy: e.dy
- })
- }).on("zoom", function(e) {
- gc(o, e.scale, e.originX, e.originY), i.dispatchAction({
- seriesId: t.id,
- type: "graphRoam",
- zoom: e.scale,
- originX: e.originX,
- originY: e.originY
- }), this._updateNodeAndLinkScale(), IL(t.getGraph(), this._getNodeGlobalScale(t)), this._lineDraw.updateLayout()
- }, this)) : n.disable()
- },
- _updateNodeAndLinkScale: function() {
- var t = this._model,
- e = t.getData(),
- i = this._getNodeGlobalScale(t),
- n = [i, i];
- e.eachItemGraphicEl(function(t, e) {
- t.attr("scale", n)
- })
- },
- _getNodeGlobalScale: function(t) {
- var e = t.coordinateSystem;
- if ("view" !== e.type) return 1;
- var i = this._nodeScaleRatio,
- n = e.scale,
- o = n && n[0] || 1;
- return ((e.getZoom() - 1) * i + 1) / o
- },
- updateLayout: function(t) {
- IL(t.getGraph(), this._getNodeGlobalScale(t)), this._symbolDraw.updateLayout(), this._lineDraw.updateLayout()
- },
- remove: function(t, e) {
- this._symbolDraw && this._symbolDraw.remove(), this._lineDraw && this._lineDraw.remove()
- }
- }), Ps({
- type: "focusNodeAdjacency",
- event: "focusNodeAdjacency",
- update: "series:focusNodeAdjacency"
- }, function() {}), Ps({
- type: "unfocusNodeAdjacency",
- event: "unfocusNodeAdjacency",
- update: "series:unfocusNodeAdjacency"
- }, function() {}), Ps({
- type: "graphRoam",
- event: "graphRoam",
- update: "none"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- query: t
- }, function(e) {
- var i = wc(e.coordinateSystem, t);
- e.setCenter && e.setCenter(i.center), e.setZoom && e.setZoom(i.zoom)
- })
- });
- var DL = Z;
- ks(function(t) {
- var e = t.findComponents({
- mainType: "legend"
- });
- e && e.length && t.eachSeriesByType("graph", function(t) {
- var i = t.getCategoriesData(),
- n = t.getGraph().data,
- o = i.mapArray(i.getName);
- n.filterSelf(function(t) {
- var i = n.getItemModel(t).getShallow("category");
- if (null != i) {
- "number" == typeof i && (i = o[i]);
- for (var a = 0; a < e.length; a++)
- if (!e[a].isSelected(i)) return !1
- }
- return !0
- })
- }, this)
- }), Es(hD("graph", "circle", null)), Es(function(t) {
- var e = {};
- t.eachSeriesByType("graph", function(t) {
- var i = t.getCategoriesData(),
- n = t.getData(),
- o = {};
- i.each(function(n) {
- var a = i.getName(n);
- o["ec-" + a] = n;
- var r = i.getItemModel(n).get("itemStyle.color") || t.getColorFromPalette(a, e);
- i.setItemVisual(n, "color", r)
- }), i.count() && n.each(function(t) {
- var e = n.getItemModel(t).getShallow("category");
- null != e && ("string" == typeof e && (e = o["ec-" + e]), n.getItemVisual(t, "color", !0) || n.setItemVisual(
- t, "color", i.getItemVisual(e, "color")))
- })
- })
- }), Es(function(t) {
- t.eachSeriesByType("graph", function(t) {
- var e = t.getGraph(),
- i = t.getEdgeData(),
- n = uf(t.get("edgeSymbol")),
- o = uf(t.get("edgeSymbolSize")),
- a = "lineStyle.color".split("."),
- r = "lineStyle.opacity".split(".");
- i.setVisual("fromSymbol", n && n[0]), i.setVisual("toSymbol", n && n[1]), i.setVisual("fromSymbolSize", o && o[
- 0]), i.setVisual("toSymbolSize", o && o[1]), i.setVisual("color", t.get(a)), i.setVisual("opacity", t.get(r)),
- i.each(function(t) {
- var n = i.getItemModel(t),
- o = e.getEdgeByIndex(t),
- s = uf(n.getShallow("symbol", !0)),
- l = uf(n.getShallow("symbolSize", !0)),
- u = n.get(a),
- h = n.get(r);
- switch (u) {
- case "source":
- u = o.node1.getVisual("color");
- break;
- case "target":
- u = o.node2.getVisual("color")
- }
- s[0] && o.setVisual("fromSymbol", s[0]), s[1] && o.setVisual("toSymbol", s[1]), l[0] && o.setVisual(
- "fromSymbolSize", l[0]), l[1] && o.setVisual("toSymbolSize", l[1]), o.setVisual("color", u), o.setVisual(
- "opacity", h)
- })
- })
- }), Os(function(t, e) {
- t.eachSeriesByType("graph", function(t) {
- var e = t.get("layout"),
- i = t.coordinateSystem;
- if (i && "view" !== i.type) {
- var n = t.getData(),
- o = [];
- d(i.dimensions, function(t) {
- o = o.concat(n.mapDimension(t, !0))
- });
- for (var a = 0; a < n.count(); a++) {
- for (var r = [], s = !1, l = 0; l < o.length; l++) {
- var u = n.get(o[l], a);
- isNaN(u) || (s = !0), r.push(u)
- }
- s ? n.setItemLayout(a, i.dataToPoint(r)) : n.setItemLayout(a, [NaN, NaN])
- }
- cf(n.graph)
- } else e && "none" !== e || hf(t)
- })
- }), Os(function(t) {
- t.eachSeriesByType("graph", function(t) {
- "circular" === t.get("layout") && df(t)
- })
- }), Os(function(t) {
- t.eachSeriesByType("graph", function(t) {
- var e = t.coordinateSystem;
- if (!e || "view" === e.type)
- if ("force" === t.get("layout")) {
- var i = t.preservedPoints || {},
- n = t.getGraph(),
- o = n.data,
- a = n.edgeData,
- r = t.getModel("force"),
- s = r.get("initLayout");
- t.preservedPoints ? o.each(function(t) {
- var e = o.getId(t);
- o.setItemLayout(t, i[e] || [NaN, NaN])
- }) : s && "none" !== s ? "circular" === s && df(t) : hf(t);
- var l = o.getDataExtent("value"),
- u = a.getDataExtent("value"),
- h = r.get("repulsion"),
- c = r.get("edgeLength");
- y(h) || (h = [h, h]), y(c) || (c = [c, c]), c = [c[1], c[0]];
- var d = o.mapArray("value", function(t, e) {
- var i = o.getItemLayout(e),
- n = Eo(t, l, h);
- return isNaN(n) && (n = (h[0] + h[1]) / 2), {
- w: n,
- rep: n,
- fixed: o.getItemModel(e).get("fixed"),
- p: !i || isNaN(i[0]) || isNaN(i[1]) ? null : i
- }
- }),
- f = a.mapArray("value", function(t, e) {
- var i = n.getEdgeByIndex(e),
- o = Eo(t, u, c);
- return isNaN(o) && (o = (c[0] + c[1]) / 2), {
- n1: d[i.node1.dataIndex],
- n2: d[i.node2.dataIndex],
- d: o,
- curveness: i.getModel().get("lineStyle.curveness") || 0
- }
- }),
- p = (e = t.coordinateSystem).getBoundingRect(),
- g = ff(d, f, {
- rect: p,
- gravity: r.get("gravity")
- }),
- m = g.step;
- g.step = function(t) {
- for (var e = 0, a = d.length; e < a; e++) d[e].fixed && G(d[e].p, n.getNodeByIndex(e).getLayout());
- m(function(e, a, r) {
- for (var s = 0, l = e.length; s < l; s++) e[s].fixed || n.getNodeByIndex(s).setLayout(e[s].p), i[o.getId(
- s)] = e[s].p;
- for (var s = 0, l = a.length; s < l; s++) {
- var u = a[s],
- h = n.getEdgeByIndex(s),
- c = u.n1.p,
- d = u.n2.p,
- f = h.getLayout();
- (f = f ? f.slice() : [])[0] = f[0] || [], f[1] = f[1] || [], G(f[0], c), G(f[1], d), +u.curveness && (f[
- 2] = [(c[0] + d[0]) / 2 - (c[1] - d[1]) * u.curveness, (c[1] + d[1]) / 2 - (d[0] - c[0]) * u.curveness]),
- h.setLayout(f)
- }
- t && t(r)
- })
- }, t.forceLayout = g, t.preservedPoints = i, g.step()
- } else t.forceLayout = null
- })
- }), Ns("graphView", {
- create: function(t, e) {
- var i = [];
- return t.eachSeriesByType("graph", function(t) {
- var n = t.get("coordinateSystem");
- if (!n || "view" === n) {
- var o = t.getData(),
- a = [],
- r = [];
- dn(o.mapArray(function(t) {
- var e = o.getItemModel(t);
- return [+e.get("x"), +e.get("y")]
- }), a, r), r[0] - a[0] == 0 && (r[0] += 1, a[0] -= 1), r[1] - a[1] == 0 && (r[1] += 1, a[1] -= 1);
- var s = (r[0] - a[0]) / (r[1] - a[1]),
- l = pf(t, e, s);
- isNaN(s) && (a = [l.x, l.y], r = [l.x + l.width, l.y + l.height]);
- var u = r[0] - a[0],
- h = r[1] - a[1],
- c = l.width,
- d = l.height,
- f = t.coordinateSystem = new Uh;
- f.zoomLimit = t.get("scaleLimit"), f.setBoundingRect(a[0], a[1], u, h), f.setViewRect(l.x, l.y, c, d), f.setCenter(
- t.get("center")), f.setZoom(t.get("zoom")), i.push(f)
- }
- }), i
- }
- });
- OI.extend({
- type: "series.gauge",
- getInitialData: function(t, e) {
- var i = t.data || [];
- return y(i) || (i = [i]), t.data = i, WD(this, ["value"])
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- center: ["50%", "50%"],
- legendHoverLink: !0,
- radius: "75%",
- startAngle: 225,
- endAngle: -45,
- clockwise: !0,
- min: 0,
- max: 100,
- splitNumber: 10,
- axisLine: {
- show: !0,
- lineStyle: {
- color: [
- [.2, "#91c7ae"],
- [.8, "#63869e"],
- [1, "#c23531"]
- ],
- width: 30
- }
- },
- splitLine: {
- show: !0,
- length: 30,
- lineStyle: {
- color: "#eee",
- width: 2,
- type: "solid"
- }
- },
- axisTick: {
- show: !0,
- splitNumber: 5,
- length: 8,
- lineStyle: {
- color: "#eee",
- width: 1,
- type: "solid"
- }
- },
- axisLabel: {
- show: !0,
- distance: 5,
- color: "auto"
- },
- pointer: {
- show: !0,
- length: "80%",
- width: 8
- },
- itemStyle: {
- color: "auto"
- },
- title: {
- show: !0,
- offsetCenter: [0, "-40%"],
- color: "#333",
- fontSize: 15
- },
- detail: {
- show: !0,
- backgroundColor: "rgba(0,0,0,0)",
- borderWidth: 0,
- borderColor: "#ccc",
- width: 100,
- height: null,
- padding: [5, 10],
- offsetCenter: [0, "40%"],
- color: "auto",
- fontSize: 30
- }
- }
- });
- var CL = kn.extend({
- type: "echartsGaugePointer",
- shape: {
- angle: 0,
- width: 10,
- r: 10,
- x: 0,
- y: 0
- },
- buildPath: function(t, e) {
- var i = Math.cos,
- n = Math.sin,
- o = e.r,
- a = e.width,
- r = e.angle,
- s = e.x - i(r) * a * (a >= o / 3 ? 1 : 2),
- l = e.y - n(r) * a * (a >= o / 3 ? 1 : 2);
- r = e.angle - Math.PI / 2, t.moveTo(s, l), t.lineTo(e.x + i(r) * a, e.y + n(r) * a), t.lineTo(e.x + i(e.angle) *
- o, e.y + n(e.angle) * o), t.lineTo(e.x - i(r) * a, e.y - n(r) * a), t.lineTo(s, l)
- }
- }),
- LL = 2 * Math.PI,
- kL = (Mr.extend({
- type: "gauge",
- render: function(t, e, i) {
- this.group.removeAll();
- var n = t.get("axisLine.lineStyle.color"),
- o = gf(t, i);
- this._renderMain(t, e, i, n, o)
- },
- dispose: function() {},
- _renderMain: function(t, e, i, n, o) {
- for (var a = this.group, r = t.getModel("axisLine").getModel("lineStyle"), s = t.get("clockwise"), l = -t.get(
- "startAngle") / 180 * Math.PI, u = -t.get("endAngle") / 180 * Math.PI, h = (u - l) % LL, c = l, d = r.get(
- "width"), f = 0; f < n.length; f++) {
- var p = Math.min(Math.max(n[f][0], 0), 1),
- g = new QS({
- shape: {
- startAngle: c,
- endAngle: u = l + h * p,
- cx: o.cx,
- cy: o.cy,
- clockwise: s,
- r0: o.r - d,
- r: o.r
- },
- silent: !0
- });
- g.setStyle({
- fill: n[f][1]
- }), g.setStyle(r.getLineStyle(["color", "borderWidth", "borderColor"])), a.add(g), c = u
- }
- var m = function(t) {
- if (t <= 0) return n[0][1];
- for (var e = 0; e < n.length; e++)
- if (n[e][0] >= t && (0 === e ? 0 : n[e - 1][0]) < t) return n[e][1];
- return n[e - 1][1]
- };
- if (!s) {
- var v = l;
- l = u, u = v
- }
- this._renderTicks(t, e, i, m, o, l, u, s), this._renderPointer(t, e, i, m, o, l, u, s), this._renderTitle(t, e,
- i, m, o), this._renderDetail(t, e, i, m, o)
- },
- _renderTicks: function(t, e, i, n, o, a, r, s) {
- for (var l = this.group, u = o.cx, h = o.cy, c = o.r, d = +t.get("min"), f = +t.get("max"), p = t.getModel(
- "splitLine"), g = t.getModel("axisTick"), m = t.getModel("axisLabel"), v = t.get("splitNumber"), y = g.get(
- "splitNumber"), x = Ro(p.get("length"), c), _ = Ro(g.get("length"), c), w = a, b = (r - a) / v, S = b / y, M =
- p.getModel("lineStyle").getLineStyle(), I = g.getModel("lineStyle").getLineStyle(), T = 0; T <= v; T++) {
- var A = Math.cos(w),
- D = Math.sin(w);
- if (p.get("show")) {
- var C = new rM({
- shape: {
- x1: A * c + u,
- y1: D * c + h,
- x2: A * (c - x) + u,
- y2: D * (c - x) + h
- },
- style: M,
- silent: !0
- });
- "auto" === M.stroke && C.setStyle({
- stroke: n(T / v)
- }), l.add(C)
- }
- if (m.get("show")) {
- var L = mf(zo(T / v * (f - d) + d), m.get("formatter")),
- k = m.get("distance"),
- P = n(T / v);
- l.add(new qS({
- style: fo({}, m, {
- text: L,
- x: A * (c - x - k) + u,
- y: D * (c - x - k) + h,
- textVerticalAlign: D < -.4 ? "top" : D > .4 ? "bottom" : "middle",
- textAlign: A < -.4 ? "left" : A > .4 ? "right" : "center"
- }, {
- autoColor: P
- }),
- silent: !0
- }))
- }
- if (g.get("show") && T !== v) {
- for (var N = 0; N <= y; N++) {
- var A = Math.cos(w),
- D = Math.sin(w),
- O = new rM({
- shape: {
- x1: A * c + u,
- y1: D * c + h,
- x2: A * (c - _) + u,
- y2: D * (c - _) + h
- },
- silent: !0,
- style: I
- });
- "auto" === I.stroke && O.setStyle({
- stroke: n((T + N / y) / v)
- }), l.add(O), w += S
- }
- w -= S
- } else w += b
- }
- },
- _renderPointer: function(t, e, i, n, o, a, r, s) {
- var l = this.group,
- u = this._data;
- if (t.get("pointer.show")) {
- var h = [+t.get("min"), +t.get("max")],
- c = [a, r],
- d = t.getData(),
- f = d.mapDimension("value");
- d.diff(u).add(function(e) {
- var i = new CL({
- shape: {
- angle: a
- }
- });
- So(i, {
- shape: {
- angle: Eo(d.get(f, e), h, c, !0)
- }
- }, t), l.add(i), d.setItemGraphicEl(e, i)
- }).update(function(e, i) {
- var n = u.getItemGraphicEl(i);
- bo(n, {
- shape: {
- angle: Eo(d.get(f, e), h, c, !0)
- }
- }, t), l.add(n), d.setItemGraphicEl(e, n)
- }).remove(function(t) {
- var e = u.getItemGraphicEl(t);
- l.remove(e)
- }).execute(), d.eachItemGraphicEl(function(t, e) {
- var i = d.getItemModel(e),
- a = i.getModel("pointer");
- t.setShape({
- x: o.cx,
- y: o.cy,
- width: Ro(a.get("width"), o.r),
- r: Ro(a.get("length"), o.r)
- }), t.useStyle(i.getModel("itemStyle").getItemStyle()), "auto" === t.style.fill && t.setStyle("fill", n(Eo(
- d.get(f, e), h, [0, 1], !0))), uo(t, i.getModel("emphasis.itemStyle").getItemStyle())
- }), this._data = d
- } else u && u.eachItemGraphicEl(function(t) {
- l.remove(t)
- })
- },
- _renderTitle: function(t, e, i, n, o) {
- var a = t.getData(),
- r = a.mapDimension("value"),
- s = t.getModel("title");
- if (s.get("show")) {
- var l = s.get("offsetCenter"),
- u = o.cx + Ro(l[0], o.r),
- h = o.cy + Ro(l[1], o.r),
- c = +t.get("min"),
- d = +t.get("max"),
- f = n(Eo(t.getData().get(r, 0), [c, d], [0, 1], !0));
- this.group.add(new qS({
- silent: !0,
- style: fo({}, s, {
- x: u,
- y: h,
- text: a.getName(0),
- textAlign: "center",
- textVerticalAlign: "middle"
- }, {
- autoColor: f,
- forceRich: !0
- })
- }))
- }
- },
- _renderDetail: function(t, e, i, n, o) {
- var a = t.getModel("detail"),
- r = +t.get("min"),
- s = +t.get("max");
- if (a.get("show")) {
- var l = a.get("offsetCenter"),
- u = o.cx + Ro(l[0], o.r),
- h = o.cy + Ro(l[1], o.r),
- c = Ro(a.get("width"), o.r),
- d = Ro(a.get("height"), o.r),
- f = t.getData(),
- p = f.get(f.mapDimension("value"), 0),
- g = n(Eo(p, [r, s], [0, 1], !0));
- this.group.add(new qS({
- silent: !0,
- style: fo({}, a, {
- x: u,
- y: h,
- text: mf(p, a.get("formatter")),
- textWidth: isNaN(c) ? null : c,
- textHeight: isNaN(d) ? null : d,
- textAlign: "center",
- textVerticalAlign: "middle"
- }, {
- autoColor: g,
- forceRich: !0
- })
- }))
- }
- }
- }), Gs({
- type: "series.funnel",
- init: function(t) {
- kL.superApply(this, "init", arguments), this.legendDataProvider = function() {
- return this.getRawData()
- }, this._defaultLabelLine(t)
- },
- getInitialData: function(t, e) {
- return WD(this, ["value"])
- },
- _defaultLabelLine: function(t) {
- Ci(t, "labelLine", ["show"]);
- var e = t.labelLine,
- i = t.emphasis.labelLine;
- e.show = e.show && t.label.show, i.show = i.show && t.emphasis.label.show
- },
- getDataParams: function(t) {
- var e = this.getData(),
- i = kL.superCall(this, "getDataParams", t),
- n = e.mapDimension("value"),
- o = e.getSum(n);
- return i.percent = o ? +(e.get(n, t) / o * 100).toFixed(2) : 0, i.$vars.push("percent"), i
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- legendHoverLink: !0,
- left: 80,
- top: 60,
- right: 80,
- bottom: 60,
- minSize: "0%",
- maxSize: "100%",
- sort: "descending",
- gap: 0,
- funnelAlign: "center",
- label: {
- show: !0,
- position: "outer"
- },
- labelLine: {
- show: !0,
- length: 20,
- lineStyle: {
- width: 1,
- type: "solid"
- }
- },
- itemStyle: {
- borderColor: "#fff",
- borderWidth: 1
- },
- emphasis: {
- label: {
- show: !0
- }
- }
- }
- })),
- PL = vf.prototype,
- NL = ["itemStyle", "opacity"];
- PL.updateData = function(t, e, i) {
- var n = this.childAt(0),
- o = t.hostModel,
- a = t.getItemModel(e),
- s = t.getItemLayout(e),
- l = t.getItemModel(e).get(NL);
- l = null == l ? 1 : l, n.useStyle({}), i ? (n.setShape({
- points: s.points
- }), n.setStyle({
- opacity: 0
- }), So(n, {
- style: {
- opacity: l
- }
- }, o, e)) : bo(n, {
- style: {
- opacity: l
- },
- shape: {
- points: s.points
- }
- }, o, e);
- var u = a.getModel("itemStyle"),
- h = t.getItemVisual(e, "color");
- n.setStyle(r({
- lineJoin: "round",
- fill: h
- }, u.getItemStyle(["opacity"]))), n.hoverStyle = u.getModel("emphasis").getItemStyle(), this._updateLabel(t, e),
- uo(this)
- }, PL._updateLabel = function(t, e) {
- var i = this.childAt(1),
- n = this.childAt(2),
- o = t.hostModel,
- a = t.getItemModel(e),
- r = t.getItemLayout(e).label,
- s = t.getItemVisual(e, "color");
- bo(i, {
- shape: {
- points: r.linePoints || r.linePoints
- }
- }, o, e), bo(n, {
- style: {
- x: r.x,
- y: r.y
- }
- }, o, e), n.attr({
- rotation: r.rotation,
- origin: [r.x, r.y],
- z2: 10
- });
- var l = a.getModel("label"),
- u = a.getModel("emphasis.label"),
- h = a.getModel("labelLine"),
- c = a.getModel("emphasis.labelLine"),
- s = t.getItemVisual(e, "color");
- co(n.style, n.hoverStyle = {}, l, u, {
- labelFetcher: t.hostModel,
- labelDataIndex: e,
- defaultText: t.getName(e),
- autoColor: s,
- useInsideStyle: !!r.inside
- }, {
- textAlign: r.textAlign,
- textVerticalAlign: r.verticalAlign
- }), n.ignore = n.normalIgnore = !l.get("show"), n.hoverIgnore = !u.get("show"), i.ignore = i.normalIgnore = !h.get(
- "show"), i.hoverIgnore = !c.get("show"), i.setStyle({
- stroke: s
- }), i.setStyle(h.getModel("lineStyle").getLineStyle()), i.hoverStyle = c.getModel("lineStyle").getLineStyle()
- }, u(vf, Zw);
- Mr.extend({
- type: "funnel",
- render: function(t, e, i) {
- var n = t.getData(),
- o = this._data,
- a = this.group;
- n.diff(o).add(function(t) {
- var e = new vf(n, t);
- n.setItemGraphicEl(t, e), a.add(e)
- }).update(function(t, e) {
- var i = o.getItemGraphicEl(e);
- i.updateData(n, t), a.add(i), n.setItemGraphicEl(t, i)
- }).remove(function(t) {
- var e = o.getItemGraphicEl(t);
- a.remove(e)
- }).execute(), this._data = n
- },
- remove: function() {
- this.group.removeAll(), this._data = null
- },
- dispose: function() {}
- });
- Es(jD("funnel")), Os(function(t, e, i) {
- t.eachSeriesByType("funnel", function(t) {
- var i = t.getData(),
- n = i.mapDimension("value"),
- o = t.get("sort"),
- a = yf(t, e),
- r = xf(i, o),
- s = [Ro(t.get("minSize"), a.width), Ro(t.get("maxSize"), a.width)],
- l = i.getDataExtent(n),
- u = t.get("min"),
- h = t.get("max");
- null == u && (u = Math.min(l[0], 0)), null == h && (h = l[1]);
- var c = t.get("funnelAlign"),
- d = t.get("gap"),
- f = (a.height - d * (i.count() - 1)) / i.count(),
- p = a.y,
- g = function(t, e) {
- var o, r = Eo(i.get(n, t) || 0, [u, h], s, !0);
- switch (c) {
- case "left":
- o = a.x;
- break;
- case "center":
- o = a.x + (a.width - r) / 2;
- break;
- case "right":
- o = a.x + a.width - r
- }
- return [
- [o, e],
- [o + r, e]
- ]
- };
- "ascending" === o && (f = -f, d = -d, p += a.height, r = r.reverse());
- for (var m = 0; m < r.length; m++) {
- var v = r[m],
- y = r[m + 1],
- x = i.getItemModel(v).get("itemStyle.height");
- null == x ? x = f : (x = Ro(x, a.height), "ascending" === o && (x = -x));
- var _ = g(v, p),
- w = g(y, p + x);
- p += x + d, i.setItemLayout(v, {
- points: _.concat(w.slice().reverse())
- })
- }
- _f(i)
- })
- }), ks($D("funnel"));
- var OL = function(t, e, i, n, o) {
- HA.call(this, t, e, i), this.type = n || "value", this.axisIndex = o
- };
- OL.prototype = {
- constructor: OL,
- model: null,
- isHorizontal: function() {
- return "horizontal" !== this.coordinateSystem.getModel().get("layout")
- }
- }, u(OL, HA);
- var EL = function(t, e, i, n, o, a) {
- e[0] = Mf(e[0], i), e[1] = Mf(e[1], i), t = t || 0;
- var r = i[1] - i[0];
- null != o && (o = Mf(o, [0, r])), null != a && (a = Math.max(a, null != o ? o : 0)), "all" === n && (o = a = Math.abs(
- e[1] - e[0]), n = 0);
- var s = Sf(e, n);
- e[n] += t;
- var l = o || 0,
- u = i.slice();
- s.sign < 0 ? u[0] += l : u[1] -= l, e[n] = Mf(e[n], u);
- h = Sf(e, n);
- null != o && (h.sign !== s.sign || h.span < o) && (e[1 - n] = e[n] + s.sign * o);
- var h = Sf(e, n);
- return null != a && h.span > a && (e[1 - n] = e[n] + h.sign * a), e
- },
- RL = d,
- zL = Math.min,
- BL = Math.max,
- VL = Math.floor,
- GL = Math.ceil,
- FL = zo,
- WL = Math.PI;
- If.prototype = {
- type: "parallel",
- constructor: If,
- _init: function(t, e, i) {
- var n = t.dimensions,
- o = t.parallelAxisIndex;
- RL(n, function(t, i) {
- var n = o[i],
- a = e.getComponent("parallelAxis", n),
- r = this._axesMap.set(t, new OL(t, Vl(a), [0, 0], a.get("type"), n)),
- s = "category" === r.type;
- r.onBand = s && a.get("boundaryGap"), r.inverse = a.get("inverse"), a.axis = r, r.model = a, r.coordinateSystem =
- a.coordinateSystem = this
- }, this)
- },
- update: function(t, e) {
- this._updateAxesFromSeries(this._model, t)
- },
- containPoint: function(t) {
- var e = this._makeLayoutInfo(),
- i = e.axisBase,
- n = e.layoutBase,
- o = e.pixelDimIndex,
- a = t[1 - o],
- r = t[o];
- return a >= i && a <= i + e.axisLength && r >= n && r <= n + e.layoutLength
- },
- getModel: function() {
- return this._model
- },
- _updateAxesFromSeries: function(t, e) {
- e.eachSeries(function(i) {
- if (t.contains(i, e)) {
- var n = i.getData();
- RL(this.dimensions, function(t) {
- var e = this._axesMap.get(t);
- e.scale.unionExtentFromData(n, n.mapDimension(t)), Bl(e.scale, e.model)
- }, this)
- }
- }, this)
- },
- resize: function(t, e) {
- this._rect = la(t.getBoxLayoutParams(), {
- width: e.getWidth(),
- height: e.getHeight()
- }), this._layoutAxes()
- },
- getRect: function() {
- return this._rect
- },
- _makeLayoutInfo: function() {
- var t, e = this._model,
- i = this._rect,
- n = ["x", "y"],
- o = ["width", "height"],
- a = e.get("layout"),
- r = "horizontal" === a ? 0 : 1,
- s = i[o[r]],
- l = [0, s],
- u = this.dimensions.length,
- h = Tf(e.get("axisExpandWidth"), l),
- c = Tf(e.get("axisExpandCount") || 0, [0, u]),
- d = e.get("axisExpandable") && u > 3 && u > c && c > 1 && h > 0 && s > 0,
- f = e.get("axisExpandWindow");
- f ? (t = Tf(f[1] - f[0], l), f[1] = f[0] + t) : (t = Tf(h * (c - 1), l), (f = [h * (e.get("axisExpandCenter") ||
- VL(u / 2)) - t / 2])[1] = f[0] + t);
- var p = (s - t) / (u - c);
- p < 3 && (p = 0);
- var g = [VL(FL(f[0] / h, 1)) + 1, GL(FL(f[1] / h, 1)) - 1],
- m = p / h * f[0];
- return {
- layout: a,
- pixelDimIndex: r,
- layoutBase: i[n[r]],
- layoutLength: s,
- axisBase: i[n[1 - r]],
- axisLength: i[o[1 - r]],
- axisExpandable: d,
- axisExpandWidth: h,
- axisCollapseWidth: p,
- axisExpandWindow: f,
- axisCount: u,
- winInnerIndices: g,
- axisExpandWindow0Pos: m
- }
- },
- _layoutAxes: function() {
- var t = this._rect,
- e = this._axesMap,
- i = this.dimensions,
- n = this._makeLayoutInfo(),
- o = n.layout;
- e.each(function(t) {
- var e = [0, n.axisLength],
- i = t.inverse ? 1 : 0;
- t.setExtent(e[i], e[1 - i])
- }), RL(i, function(e, i) {
- var a = (n.axisExpandable ? Df : Af)(i, n),
- r = {
- horizontal: {
- x: a.position,
- y: n.axisLength
- },
- vertical: {
- x: 0,
- y: a.position
- }
- },
- s = {
- horizontal: WL / 2,
- vertical: 0
- },
- l = [r[o].x + t.x, r[o].y + t.y],
- u = s[o],
- h = mt();
- wt(h, h, u), _t(h, h, l), this._axesLayout[e] = {
- position: l,
- rotation: u,
- transform: h,
- axisNameAvailableWidth: a.axisNameAvailableWidth,
- axisLabelShow: a.axisLabelShow,
- nameTruncateMaxWidth: a.nameTruncateMaxWidth,
- tickDirection: 1,
- labelDirection: 1
- }
- }, this)
- },
- getAxis: function(t) {
- return this._axesMap.get(t)
- },
- dataToPoint: function(t, e) {
- return this.axisCoordToPoint(this._axesMap.get(e).dataToCoord(t), e)
- },
- eachActiveState: function(t, e, i, n) {
- null == i && (i = 0), null == n && (n = t.count());
- var o = this._axesMap,
- a = this.dimensions,
- r = [],
- s = [];
- d(a, function(e) {
- r.push(t.mapDimension(e)), s.push(o.get(e).model)
- });
- for (var l = this.hasAxisBrushed(), u = i; u < n; u++) {
- var h;
- if (l) {
- h = "active";
- for (var c = t.getValues(r, u), f = 0, p = a.length; f < p; f++)
- if ("inactive" === s[f].getActiveState(c[f])) {
- h = "inactive";
- break
- }
- } else h = "normal";
- e(h, u)
- }
- },
- hasAxisBrushed: function() {
- for (var t = this.dimensions, e = this._axesMap, i = !1, n = 0, o = t.length; n < o; n++) "normal" !== e.get(t[n])
- .model.getActiveState() && (i = !0);
- return i
- },
- axisCoordToPoint: function(t, e) {
- return Io([t, 0], this._axesLayout[e].transform)
- },
- getAxisLayout: function(t) {
- return i(this._axesLayout[t])
- },
- getSlidedAxisExpandWindow: function(t) {
- var e = this._makeLayoutInfo(),
- i = e.pixelDimIndex,
- n = e.axisExpandWindow.slice(),
- o = n[1] - n[0],
- a = [0, e.axisExpandWidth * (e.axisCount - 1)];
- if (!this.containPoint(t)) return {
- behavior: "none",
- axisExpandWindow: n
- };
- var r, s = t[i] - e.layoutBase - e.axisExpandWindow0Pos,
- l = "slide",
- u = e.axisCollapseWidth,
- h = this._model.get("axisExpandSlideTriggerArea"),
- c = null != h[0];
- if (u) c && u && s < o * h[0] ? (l = "jump", r = s - o * h[2]) : c && u && s > o * (1 - h[0]) ? (l = "jump", r =
- s - o * (1 - h[2])) : (r = s - o * h[1]) >= 0 && (r = s - o * (1 - h[1])) <= 0 && (r = 0), (r *= e.axisExpandWidth /
- u) ? EL(r, n, a, "all") : l = "none";
- else {
- o = n[1] - n[0];
- (n = [BL(0, a[1] * s / o - o / 2)])[1] = zL(a[1], n[0] + o), n[0] = n[1] - o
- }
- return {
- axisExpandWindow: n,
- behavior: l
- }
- }
- }, Ba.register("parallel", {
- create: function(t, e) {
- var i = [];
- return t.eachComponent("parallel", function(n, o) {
- var a = new If(n, t, e);
- a.name = "parallel_" + o, a.resize(n, e), n.coordinateSystem = a, a.model = n, i.push(a)
- }), t.eachSeries(function(e) {
- if ("parallel" === e.get("coordinateSystem")) {
- var i = t.queryComponents({
- mainType: "parallel",
- index: e.get("parallelIndex"),
- id: e.get("parallelId")
- })[0];
- e.coordinateSystem = i.coordinateSystem
- }
- }), i
- }
- });
- var HL = YM.extend({
- type: "baseParallelAxis",
- axis: null,
- activeIntervals: [],
- getAreaSelectStyle: function() {
- return Wb([
- ["fill", "color"],
- ["lineWidth", "borderWidth"],
- ["stroke", "borderColor"],
- ["width", "width"],
- ["opacity", "opacity"]
- ])(this.getModel("areaSelectStyle"))
- },
- setActiveIntervals: function(t) {
- var e = this.activeIntervals = i(t);
- if (e)
- for (var n = e.length - 1; n >= 0; n--) Bo(e[n])
- },
- getActiveState: function(t) {
- var e = this.activeIntervals;
- if (!e.length) return "normal";
- if (null == t || isNaN(t)) return "inactive";
- if (1 === e.length) {
- var i = e[0];
- if (i[0] <= t && t <= i[1]) return "active"
- } else
- for (var n = 0, o = e.length; n < o; n++)
- if (e[n][0] <= t && t <= e[n][1]) return "active";
- return "inactive"
- }
- }),
- ZL = {
- type: "value",
- dim: null,
- areaSelectStyle: {
- width: 20,
- borderWidth: 1,
- borderColor: "rgba(160,197,232)",
- color: "rgba(160,197,232)",
- opacity: .3
- },
- realtime: !0,
- z: 10
- };
- n(HL.prototype, CA), xD("parallel", HL, function(t, e) {
- return e.type || (e.data ? "category" : "value")
- }, ZL), YM.extend({
- type: "parallel",
- dependencies: ["parallelAxis"],
- coordinateSystem: null,
- dimensions: null,
- parallelAxisIndex: null,
- layoutMode: "box",
- defaultOption: {
- zlevel: 0,
- z: 0,
- left: 80,
- top: 60,
- right: 80,
- bottom: 60,
- layout: "horizontal",
- axisExpandable: !1,
- axisExpandCenter: null,
- axisExpandCount: 0,
- axisExpandWidth: 50,
- axisExpandRate: 17,
- axisExpandDebounce: 50,
- axisExpandSlideTriggerArea: [-.15, .05, .4],
- axisExpandTriggerOn: "click",
- parallelAxisDefault: null
- },
- init: function() {
- YM.prototype.init.apply(this, arguments), this.mergeOption({})
- },
- mergeOption: function(t) {
- var e = this.option;
- t && n(e, t, !0), this._initDimensions()
- },
- contains: function(t, e) {
- var i = t.get("parallelIndex");
- return null != i && e.getComponent("parallel", i) === this
- },
- setAxisExpand: function(t) {
- d(["axisExpandable", "axisExpandCenter", "axisExpandCount", "axisExpandWidth", "axisExpandWindow"], function(e) {
- t.hasOwnProperty(e) && (this.option[e] = t[e])
- }, this)
- },
- _initDimensions: function() {
- var t = this.dimensions = [],
- e = this.parallelAxisIndex = [];
- d(g(this.dependentModels.parallelAxis, function(t) {
- return (t.get("parallelIndex") || 0) === this.componentIndex
- }, this), function(i) {
- t.push("dim" + i.get("dim")), e.push(i.componentIndex)
- })
- }
- }), Ps({
- type: "axisAreaSelect",
- event: "axisAreaSelected"
- }, function(t, e) {
- e.eachComponent({
- mainType: "parallelAxis",
- query: t
- }, function(e) {
- e.axis.model.setActiveIntervals(t.intervals)
- })
- }), Ps("parallelAxisExpand", function(t, e) {
- e.eachComponent({
- mainType: "parallel",
- query: t
- }, function(e) {
- e.setAxisExpand(t)
- })
- });
- var UL = v,
- XL = d,
- jL = f,
- YL = Math.min,
- qL = Math.max,
- KL = Math.pow,
- $L = 1e4,
- JL = 6,
- QL = 6,
- tk = "globalPan",
- ek = {
- w: [0, 0],
- e: [0, 1],
- n: [1, 0],
- s: [1, 1]
- },
- ik = {
- w: "ew",
- e: "ew",
- n: "ns",
- s: "ns",
- ne: "nesw",
- sw: "nesw",
- nw: "nwse",
- se: "nwse"
- },
- nk = {
- brushStyle: {
- lineWidth: 2,
- stroke: "rgba(0,0,0,0.3)",
- fill: "rgba(0,0,0,0.1)"
- },
- transformable: !0,
- brushMode: "single",
- removeOnClick: !1
- },
- ok = 0;
- Cf.prototype = {
- constructor: Cf,
- enableBrush: function(t) {
- return this._brushType && kf(this), t.brushType && Lf(this, t), this
- },
- setPanels: function(t) {
- if (t && t.length) {
- var e = this._panels = {};
- d(t, function(t) {
- e[t.panelId] = i(t)
- })
- } else this._panels = null;
- return this
- },
- mount: function(t) {
- t = t || {}, this._enableGlobalPan = t.enableGlobalPan;
- var e = this.group;
- return this._zr.add(e), e.attr({
- position: t.position || [0, 0],
- rotation: t.rotation || 0,
- scale: t.scale || [1, 1]
- }), this._transform = e.getLocalTransform(), this
- },
- eachCover: function(t, e) {
- XL(this._covers, t, e)
- },
- updateCovers: function(t) {
- function e(t, e) {
- return (null != t.id ? t.id : a + e) + "-" + t.brushType
- }
- function o(e, i) {
- var n = t[e];
- if (null != i && r[i] === u) s[e] = r[i];
- else {
- var o = s[e] = null != i ? (r[i].__brushOption = n, r[i]) : Nf(l, Pf(l, n));
- Rf(l, o)
- }
- }
- t = f(t, function(t) {
- return n(i(nk), t, !0)
- });
- var a = "\0-brush-index-",
- r = this._covers,
- s = this._covers = [],
- l = this,
- u = this._creatingCover;
- return new Hs(r, t, function(t, i) {
- return e(t.__brushOption, i)
- }, e).add(o).update(o).remove(function(t) {
- r[t] !== u && l.group.remove(r[t])
- }).execute(), this
- },
- unmount: function() {
- return this.enableBrush(!1), Gf(this), this._zr.remove(this.group), this
- },
- dispose: function() {
- this.unmount(), this.off()
- }
- }, h(Cf, aw);
- var ak = {
- mousedown: function(t) {
- if (this._dragging) lp.call(this, t);
- else if (!t.target || !t.target.draggable) {
- op(t);
- var e = this.group.transformCoordToLocal(t.offsetX, t.offsetY);
- this._creatingCover = null, (this._creatingPanel = Bf(this, t, e)) && (this._dragging = !0, this._track = [e.slice()])
- }
- },
- mousemove: function(t) {
- var e = this.group.transformCoordToLocal(t.offsetX, t.offsetY);
- if (np(this, t, e), this._dragging) {
- op(t);
- var i = rp(this, t, e, !1);
- i && Ff(this, i)
- }
- },
- mouseup: lp
- },
- rk = {
- lineX: up(0),
- lineY: up(1),
- rect: {
- createCover: function(t, e) {
- return Zf(UL(Jf, function(t) {
- return t
- }, function(t) {
- return t
- }), t, e, ["w", "e", "n", "s", "se", "sw", "ne", "nw"])
- },
- getCreatingRange: function(t) {
- var e = Hf(t);
- return qf(e[1][0], e[1][1], e[0][0], e[0][1])
- },
- updateCoverShape: function(t, e, i, n) {
- Uf(t, e, i, n)
- },
- updateCommon: Xf,
- contain: ap
- },
- polygon: {
- createCover: function(t, e) {
- var i = new Zw;
- return i.add(new oM({
- name: "main",
- style: Yf(e),
- silent: !0
- })), i
- },
- getCreatingRange: function(t) {
- return t
- },
- endCreating: function(t, e) {
- e.remove(e.childAt(0)), e.add(new nM({
- name: "main",
- draggable: !0,
- drift: UL(Qf, t, e),
- ondragend: UL(Ff, t, {
- isEnd: !0
- })
- }))
- },
- updateCoverShape: function(t, e, i, n) {
- e.childAt(0).setShape({
- points: ep(t, e, i)
- })
- },
- updateCommon: Xf,
- contain: ap
- }
- },
- sk = ["axisLine", "axisTickLabel", "axisName"],
- lk = Vs({
- type: "parallelAxis",
- init: function(t, e) {
- lk.superApply(this, "init", arguments), (this._brushController = new Cf(e.getZr())).on("brush", m(this._onBrush,
- this))
- },
- render: function(t, e, i, n) {
- if (!pp(t, e, n)) {
- this.axisModel = t, this.api = i, this.group.removeAll();
- var o = this._axisGroup;
- if (this._axisGroup = new Zw, this.group.add(this._axisGroup), t.get("show")) {
- var r = mp(t, e),
- s = r.coordinateSystem,
- l = t.getAreaSelectStyle(),
- u = l.width,
- h = t.axis.dim,
- c = a({
- strokeContainThreshold: u
- }, s.getAxisLayout(h)),
- f = new ID(t, c);
- d(sk, f.add, f), this._axisGroup.add(f.getGroup()), this._refreshBrushController(c, l, t, r, u, i);
- var p = n && !1 === n.animation ? null : t;
- Ao(o, this._axisGroup, p)
- }
- }
- },
- _refreshBrushController: function(t, e, i, n, o, a) {
- var r = i.axis.getExtent(),
- s = r[1] - r[0],
- l = Math.min(30, .1 * Math.abs(s)),
- u = ue.create({
- x: r[0],
- y: -o / 2,
- width: s,
- height: o
- });
- u.x -= l, u.width += 2 * l, this._brushController.mount({
- enableGlobalPan: !0,
- rotation: t.rotation,
- position: t.position
- }).setPanels([{
- panelId: "pl",
- clipPath: hp(u),
- isTargetByCursor: dp(u, a, n),
- getLinearBrushOtherExtent: cp(u, 0)
- }]).enableBrush({
- brushType: "lineX",
- brushStyle: e,
- removeOnClick: !0
- }).updateCovers(gp(i))
- },
- _onBrush: function(t, e) {
- var i = this.axisModel,
- n = i.axis,
- o = f(t, function(t) {
- return [n.coordToData(t.range[0], !0), n.coordToData(t.range[1], !0)]
- });
- (!i.option.realtime === e.isEnd || e.removeOnClick) && this.api.dispatchAction({
- type: "axisAreaSelect",
- parallelAxisId: i.id,
- intervals: o
- })
- },
- dispose: function() {
- this._brushController.dispose()
- }
- });
- Vs({
- type: "parallel",
- render: function(t, e, i) {
- this._model = t, this._api = i, this._handlers || (this._handlers = {}, d(uk, function(t, e) {
- i.getZr().on(e, this._handlers[e] = m(t, this))
- }, this)), Lr(this, "_throttledDispatchExpand", t.get("axisExpandRate"), "fixRate")
- },
- dispose: function(t, e) {
- d(this._handlers, function(t, i) {
- e.getZr().off(i, t)
- }), this._handlers = null
- },
- _throttledDispatchExpand: function(t) {
- this._dispatchExpand(t)
- },
- _dispatchExpand: function(t) {
- t && this._api.dispatchAction(a({
- type: "parallelAxisExpand"
- }, t))
- }
- });
- var uk = {
- mousedown: function(t) {
- vp(this, "click") && (this._mouseDownPoint = [t.offsetX, t.offsetY])
- },
- mouseup: function(t) {
- var e = this._mouseDownPoint;
- if (vp(this, "click") && e) {
- var i = [t.offsetX, t.offsetY];
- if (Math.pow(e[0] - i[0], 2) + Math.pow(e[1] - i[1], 2) > 5) return;
- var n = this._model.coordinateSystem.getSlidedAxisExpandWindow([t.offsetX, t.offsetY]);
- "none" !== n.behavior && this._dispatchExpand({
- axisExpandWindow: n.axisExpandWindow
- })
- }
- this._mouseDownPoint = null
- },
- mousemove: function(t) {
- if (!this._mouseDownPoint && vp(this, "mousemove")) {
- var e = this._model,
- i = e.coordinateSystem.getSlidedAxisExpandWindow([t.offsetX, t.offsetY]),
- n = i.behavior;
- "jump" === n && this._throttledDispatchExpand.debounceNextCall(e.get("axisExpandDebounce")), this._throttledDispatchExpand(
- "none" === n ? null : {
- axisExpandWindow: i.axisExpandWindow,
- animation: "jump" === n && null
- })
- }
- }
- };
- Ls(function(t) {
- wf(t), bf(t)
- }), OI.extend({
- type: "series.parallel",
- dependencies: ["parallel"],
- visualColorAccessPath: "lineStyle.color",
- getInitialData: function(t, e) {
- var i = this.getSource();
- return yp(i, this), dl(i, this)
- },
- getRawIndicesByActiveState: function(t) {
- var e = this.coordinateSystem,
- i = this.getData(),
- n = [];
- return e.eachActiveState(i, function(e, o) {
- t === e && n.push(i.getRawIndex(o))
- }), n
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "parallel",
- parallelIndex: 0,
- label: {
- show: !1
- },
- inactiveOpacity: .05,
- activeOpacity: 1,
- lineStyle: {
- width: 1,
- opacity: .45,
- type: "solid"
- },
- emphasis: {
- label: {
- show: !1
- }
- },
- progressive: 500,
- smooth: !1,
- animationEasing: "linear"
- }
- });
- var hk = .3,
- ck = (Mr.extend({
- type: "parallel",
- init: function() {
- this._dataGroup = new Zw, this.group.add(this._dataGroup), this._data, this._initialized
- },
- render: function(t, e, i, n) {
- var o = this._dataGroup,
- a = t.getData(),
- r = this._data,
- s = t.coordinateSystem,
- l = s.dimensions,
- u = Sp(t);
- if (a.diff(r).add(function(t) {
- Mp(bp(a, o, t, l, s), a, t, u)
- }).update(function(e, i) {
- var o = r.getItemGraphicEl(i),
- h = wp(a, e, l, s);
- a.setItemGraphicEl(e, o), bo(o, {
- shape: {
- points: h
- }
- }, n && !1 === n.animation ? null : t, e), Mp(o, a, e, u)
- }).remove(function(t) {
- var e = r.getItemGraphicEl(t);
- o.remove(e)
- }).execute(), !this._initialized) {
- this._initialized = !0;
- var h = _p(s, t, function() {
- setTimeout(function() {
- o.removeClipPath()
- })
- });
- o.setClipPath(h)
- }
- this._data = a
- },
- incrementalPrepareRender: function(t, e, i) {
- this._initialized = !0, this._data = null, this._dataGroup.removeAll()
- },
- incrementalRender: function(t, e, i) {
- for (var n = e.getData(), o = e.coordinateSystem, a = o.dimensions, r = Sp(e), s = t.start; s < t.end; s++) {
- var l = bp(n, this._dataGroup, s, a, o);
- l.incremental = !0, Mp(l, n, s, r)
- }
- },
- dispose: function() {},
- remove: function() {
- this._dataGroup && this._dataGroup.removeAll(), this._data = null
- }
- }), ["lineStyle", "normal", "opacity"]);
- Es({
- seriesType: "parallel",
- reset: function(t, e, i) {
- var n = t.getModel("itemStyle"),
- o = t.getModel("lineStyle"),
- a = e.get("color"),
- r = o.get("color") || n.get("color") || a[t.seriesIndex % a.length],
- s = t.get("inactiveOpacity"),
- l = t.get("activeOpacity"),
- u = t.getModel("lineStyle").getLineStyle(),
- h = t.coordinateSystem,
- c = t.getData(),
- d = {
- normal: u.opacity,
- active: l,
- inactive: s
- };
- return c.setVisual("color", r), {
- progress: function(t, e) {
- h.eachActiveState(e, function(t, i) {
- var n = d[t];
- if ("normal" === t && e.hasItemOption) {
- var o = e.getItemModel(i).get(ck, !0);
- null != o && (n = o)
- }
- e.setItemVisual(i, "opacity", n)
- }, t.start, t.end)
- }
- }
- }
- });
- var dk = OI.extend({
- type: "series.sankey",
- layoutInfo: null,
- getInitialData: function(t) {
- var e = t.edges || t.links,
- i = t.data || t.nodes;
- if (i && e) return cL(i, e, this, !0).data
- },
- setNodePosition: function(t, e) {
- var i = this.option.data[t];
- i.localX = e[0], i.localY = e[1]
- },
- getGraph: function() {
- return this.getData().graph
- },
- getEdgeData: function() {
- return this.getGraph().edgeData
- },
- formatTooltip: function(t, e, i) {
- if ("edge" === i) {
- var n = this.getDataParams(t, i),
- o = n.data,
- a = o.source + " -- " + o.target;
- return n.value && (a += " : " + n.value), Qo(a)
- }
- return dk.superCall(this, "formatTooltip", t, e)
- },
- optionUpdated: function() {
- var t = this.option;
- !0 === t.focusNodeAdjacency && (t.focusNodeAdjacency = "allEdges")
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "view",
- layout: null,
- left: "5%",
- top: "5%",
- right: "20%",
- bottom: "5%",
- orient: "horizontal",
- nodeWidth: 20,
- nodeGap: 8,
- draggable: !0,
- focusNodeAdjacency: !1,
- layoutIterations: 32,
- label: {
- show: !0,
- position: "right",
- color: "#000",
- fontSize: 12
- },
- itemStyle: {
- borderWidth: 1,
- borderColor: "#333"
- },
- lineStyle: {
- color: "#314656",
- opacity: .2,
- curveness: .5
- },
- emphasis: {
- label: {
- show: !0
- },
- lineStyle: {
- opacity: .6
- }
- },
- animationEasing: "linear",
- animationDuration: 1e3
- }
- }),
- fk = ["itemStyle", "opacity"],
- pk = ["lineStyle", "opacity"],
- gk = Fn({
- shape: {
- x1: 0,
- y1: 0,
- x2: 0,
- y2: 0,
- cpx1: 0,
- cpy1: 0,
- cpx2: 0,
- cpy2: 0,
- extent: 0,
- orient: ""
- },
- buildPath: function(t, e) {
- var i = e.extent;
- "vertical" === e.orient ? (t.moveTo(e.x1, e.y1), t.bezierCurveTo(e.cpx1, e.cpy1, e.cpx2, e.cpy2, e.x2, e.y2), t.lineTo(
- e.x2 + i, e.y2), t.bezierCurveTo(e.cpx2 + i, e.cpy2, e.cpx1 + i, e.cpy1, e.x1 + i, e.y1)) : (t.moveTo(e.x1, e.y1),
- t.bezierCurveTo(e.cpx1, e.cpy1, e.cpx2, e.cpy2, e.x2, e.y2), t.lineTo(e.x2, e.y2 + i), t.bezierCurveTo(e.cpx2,
- e.cpy2 + i, e.cpx1, e.cpy1 + i, e.x1, e.y1 + i)), t.closePath()
- }
- });
- Fs({
- type: "sankey",
- _model: null,
- _focusAdjacencyDisabled: !1,
- render: function(t, e, i) {
- var n = this,
- o = t.getGraph(),
- a = this.group,
- r = t.layoutInfo,
- s = r.width,
- l = r.height,
- u = t.getData(),
- h = t.getData("edge"),
- c = t.get("orient");
- this._model = t, a.removeAll(), a.attr("position", [r.x, r.y]), o.eachEdge(function(e) {
- var i = new gk;
- i.dataIndex = e.dataIndex, i.seriesIndex = t.seriesIndex, i.dataType = "edge";
- var n, o, r, u, d, f, p, g, m = e.getModel("lineStyle"),
- v = m.get("curveness"),
- y = e.node1.getLayout(),
- x = e.node1.getModel(),
- _ = x.get("localX"),
- w = x.get("localY"),
- b = e.node2.getLayout(),
- S = e.node2.getModel(),
- M = S.get("localX"),
- I = S.get("localY"),
- T = e.getLayout();
- switch (i.shape.extent = Math.max(1, T.dy), i.shape.orient = c, "vertical" === c ? (n = (null != _ ? _ * s :
- y.x) + T.sy, o = (null != w ? w * l : y.y) + y.dy, r = (null != M ? M * s : b.x) + T.ty, d = n, f = o * (1 -
- v) + (u = null != I ? I * l : b.y) * v, p = r, g = o * v + u * (1 - v)) : (n = (null != _ ? _ * s : y.x) +
- y.dx, o = (null != w ? w * l : y.y) + T.sy, d = n * (1 - v) + (r = null != M ? M * s : b.x) * v, f = o, p =
- n * v + r * (1 - v), g = u = (null != I ? I * l : b.y) + T.ty), i.setShape({
- x1: n,
- y1: o,
- x2: r,
- y2: u,
- cpx1: d,
- cpy1: f,
- cpx2: p,
- cpy2: g
- }), i.setStyle(m.getItemStyle()), i.style.fill) {
- case "source":
- i.style.fill = e.node1.getVisual("color");
- break;
- case "target":
- i.style.fill = e.node2.getVisual("color")
- }
- uo(i, e.getModel("emphasis.lineStyle").getItemStyle()), a.add(i), h.setItemGraphicEl(e.dataIndex, i)
- }), o.eachNode(function(e) {
- var i = e.getLayout(),
- n = e.getModel(),
- o = n.get("localX"),
- r = n.get("localY"),
- h = n.getModel("label"),
- c = n.getModel("emphasis.label"),
- d = new aM({
- shape: {
- x: null != o ? o * s : i.x,
- y: null != r ? r * l : i.y,
- width: i.dx,
- height: i.dy
- },
- style: n.getModel("itemStyle").getItemStyle()
- }),
- f = e.getModel("emphasis.itemStyle").getItemStyle();
- co(d.style, f, h, c, {
- labelFetcher: t,
- labelDataIndex: e.dataIndex,
- defaultText: e.id,
- isRectText: !0
- }), d.setStyle("fill", e.getVisual("color")), uo(d, f), a.add(d), u.setItemGraphicEl(e.dataIndex, d), d.dataType =
- "node"
- }), u.eachItemGraphicEl(function(e, o) {
- var a = u.getItemModel(o);
- a.get("draggable") && (e.drift = function(e, a) {
- n._focusAdjacencyDisabled = !0, this.shape.x += e, this.shape.y += a, this.dirty(), i.dispatchAction({
- type: "dragNode",
- seriesId: t.id,
- dataIndex: u.getRawIndex(o),
- localX: this.shape.x / s,
- localY: this.shape.y / l
- })
- }, e.ondragend = function() {
- n._focusAdjacencyDisabled = !1
- }, e.draggable = !0, e.cursor = "move"), a.get("focusNodeAdjacency") && (e.off("mouseover").on("mouseover",
- function() {
- n._focusAdjacencyDisabled || i.dispatchAction({
- type: "focusNodeAdjacency",
- seriesId: t.id,
- dataIndex: e.dataIndex
- })
- }), e.off("mouseout").on("mouseout", function() {
- n._focusAdjacencyDisabled || i.dispatchAction({
- type: "unfocusNodeAdjacency",
- seriesId: t.id
- })
- }))
- }), h.eachItemGraphicEl(function(e, o) {
- h.getItemModel(o).get("focusNodeAdjacency") && (e.off("mouseover").on("mouseover", function() {
- n._focusAdjacencyDisabled || i.dispatchAction({
- type: "focusNodeAdjacency",
- seriesId: t.id,
- edgeDataIndex: e.dataIndex
- })
- }), e.off("mouseout").on("mouseout", function() {
- n._focusAdjacencyDisabled || i.dispatchAction({
- type: "unfocusNodeAdjacency",
- seriesId: t.id
- })
- }))
- }), !this._data && t.get("animation") && a.setClipPath(Cp(a.getBoundingRect(), t, function() {
- a.removeClipPath()
- })), this._data = t.getData()
- },
- dispose: function() {},
- focusNodeAdjacency: function(t, e, i, n) {
- var o = this._model.getData(),
- a = o.graph,
- r = n.dataIndex,
- s = o.getItemModel(r),
- l = n.edgeDataIndex;
- if (null != r || null != l) {
- var u = a.getNodeByIndex(r),
- h = a.getEdgeByIndex(l);
- if (a.eachNode(function(t) {
- Ap(t, fk, .1)
- }), a.eachEdge(function(t) {
- Ap(t, pk, .1)
- }), u) {
- Dp(u, fk);
- var c = s.get("focusNodeAdjacency");
- "outEdges" === c ? d(u.outEdges, function(t) {
- t.dataIndex < 0 || (Dp(t, pk), Dp(t.node2, fk))
- }) : "inEdges" === c ? d(u.inEdges, function(t) {
- t.dataIndex < 0 || (Dp(t, pk), Dp(t.node1, fk))
- }) : "allEdges" === c && d(u.edges, function(t) {
- t.dataIndex < 0 || (Dp(t, pk), Dp(t.node1, fk), Dp(t.node2, fk))
- })
- }
- h && (Dp(h, pk), Dp(h.node1, fk), Dp(h.node2, fk))
- }
- },
- unfocusNodeAdjacency: function(t, e, i, n) {
- var o = this._model.getGraph();
- o.eachNode(function(t) {
- Ap(t, fk)
- }), o.eachEdge(function(t) {
- Ap(t, pk)
- })
- }
- }), Ps({
- type: "dragNode",
- event: "dragNode",
- update: "update"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- subType: "sankey",
- query: t
- }, function(e) {
- e.setNodePosition(t.dataIndex, [t.localX, t.localY])
- })
- });
- Os(function(t, e, i) {
- t.eachSeriesByType("sankey", function(t) {
- var i = t.get("nodeWidth"),
- n = t.get("nodeGap"),
- o = kp(t, e);
- t.layoutInfo = o;
- var a = o.width,
- r = o.height,
- s = t.getGraph(),
- l = s.nodes,
- u = s.edges;
- Np(l), Pp(l, u, i, n, a, r, 0 !== g(l, function(t) {
- return 0 === t.getLayout().value
- }).length ? 0 : t.get("layoutIterations"), t.get("orient"))
- })
- }), Es(function(t, e) {
- t.eachSeriesByType("sankey", function(t) {
- var e = t.getGraph().nodes;
- if (e.length) {
- var i = 1 / 0,
- n = -1 / 0;
- d(e, function(t) {
- var e = t.getLayout().value;
- e < i && (i = e), e > n && (n = e)
- }), d(e, function(e) {
- var o = new jC({
- type: "color",
- mappingMethod: "linear",
- dataExtent: [i, n],
- visual: t.get("color")
- }).mapValueToVisual(e.getLayout().value);
- e.setVisual("color", o);
- var a = e.getModel().get("itemStyle.color");
- null != a && e.setVisual("color", a)
- })
- }
- })
- });
- var mk = {
- _baseAxisDim: null,
- getInitialData: function(t, e) {
- var i, n, o = e.getComponent("xAxis", this.get("xAxisIndex")),
- a = e.getComponent("yAxis", this.get("yAxisIndex")),
- r = o.get("type"),
- s = a.get("type");
- "category" === r ? (t.layout = "horizontal", i = o.getOrdinalMeta(), n = !0) : "category" === s ? (t.layout =
- "vertical", i = a.getOrdinalMeta(), n = !0) : t.layout = t.layout || "horizontal";
- var l = ["x", "y"],
- u = "horizontal" === t.layout ? 0 : 1,
- h = this._baseAxisDim = l[u],
- c = l[1 - u],
- f = [o, a],
- p = f[u].get("type"),
- g = f[1 - u].get("type"),
- m = t.data;
- if (m && n) {
- var v = [];
- d(m, function(t, e) {
- var i;
- t.value && y(t.value) ? (i = t.value.slice(), t.value.unshift(e)) : y(t) ? (i = t.slice(), t.unshift(e)) : i =
- t, v.push(i)
- }), t.data = v
- }
- var x = this.defaultValueDimensions;
- return WD(this, {
- coordDimensions: [{
- name: h,
- type: Xs(p),
- ordinalMeta: i,
- otherDims: {
- tooltip: !1,
- itemName: 0
- },
- dimsDef: ["base"]
- }, {
- name: c,
- type: Xs(g),
- dimsDef: x.slice()
- }],
- dimensionsCount: x.length + 1
- })
- },
- getBaseAxis: function() {
- var t = this._baseAxisDim;
- return this.ecModel.getComponent(t + "Axis", this.get(t + "AxisIndex")).axis
- }
- };
- h(OI.extend({
- type: "series.boxplot",
- dependencies: ["xAxis", "yAxis", "grid"],
- defaultValueDimensions: [{
- name: "min",
- defaultTooltip: !0
- }, {
- name: "Q1",
- defaultTooltip: !0
- }, {
- name: "median",
- defaultTooltip: !0
- }, {
- name: "Q3",
- defaultTooltip: !0
- }, {
- name: "max",
- defaultTooltip: !0
- }],
- dimensions: null,
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "cartesian2d",
- legendHoverLink: !0,
- hoverAnimation: !0,
- layout: null,
- boxWidth: [7, 50],
- itemStyle: {
- color: "#fff",
- borderWidth: 1
- },
- emphasis: {
- itemStyle: {
- borderWidth: 2,
- shadowBlur: 5,
- shadowOffsetX: 2,
- shadowOffsetY: 2,
- shadowColor: "rgba(0,0,0,0.4)"
- }
- },
- animationEasing: "elasticOut",
- animationDuration: 800
- }
- }), mk, !0);
- var vk = ["itemStyle"],
- yk = ["emphasis", "itemStyle"],
- xk = (Mr.extend({
- type: "boxplot",
- render: function(t, e, i) {
- var n = t.getData(),
- o = this.group,
- a = this._data;
- this._data || o.removeAll();
- var r = "horizontal" === t.get("layout") ? 1 : 0;
- n.diff(a).add(function(t) {
- if (n.hasValue(t)) {
- var e = qp(n.getItemLayout(t), n, t, r, !0);
- n.setItemGraphicEl(t, e), o.add(e)
- }
- }).update(function(t, e) {
- var i = a.getItemGraphicEl(e);
- if (n.hasValue(t)) {
- var s = n.getItemLayout(t);
- i ? Kp(s, i, n, t) : i = qp(s, n, t, r), o.add(i), n.setItemGraphicEl(t, i)
- } else o.remove(i)
- }).remove(function(t) {
- var e = a.getItemGraphicEl(t);
- e && o.remove(e)
- }).execute(), this._data = n
- },
- remove: function(t) {
- var e = this.group,
- i = this._data;
- this._data = null, i && i.eachItemGraphicEl(function(t) {
- t && e.remove(t)
- })
- },
- dispose: B
- }), kn.extend({
- type: "boxplotBoxPath",
- shape: {},
- buildPath: function(t, e) {
- var i = e.points,
- n = 0;
- for (t.moveTo(i[n][0], i[n][1]), n++; n < 4; n++) t.lineTo(i[n][0], i[n][1]);
- for (t.closePath(); n < i.length; n++) t.moveTo(i[n][0], i[n][1]), n++, t.lineTo(i[n][0], i[n][1])
- }
- })),
- _k = ["itemStyle", "borderColor"],
- wk = d;
- Es(function(t, e) {
- var i = t.get("color");
- t.eachRawSeriesByType("boxplot", function(e) {
- var n = i[e.seriesIndex % i.length],
- o = e.getData();
- o.setVisual({
- legendSymbol: "roundRect",
- color: e.get(_k) || n
- }), t.isSeriesFiltered(e) || o.each(function(t) {
- var e = o.getItemModel(t);
- o.setItemVisual(t, {
- color: e.get(_k, !0)
- })
- })
- })
- }), Os(function(t) {
- var e = Jp(t);
- wk(e, function(t) {
- var e = t.seriesModels;
- e.length && (Qp(t), wk(e, function(e, i) {
- tg(e, t.boxOffsetList[i], t.boxWidthList[i])
- }))
- })
- }), h(OI.extend({
- type: "series.candlestick",
- dependencies: ["xAxis", "yAxis", "grid"],
- defaultValueDimensions: [{
- name: "open",
- defaultTooltip: !0
- }, {
- name: "close",
- defaultTooltip: !0
- }, {
- name: "lowest",
- defaultTooltip: !0
- }, {
- name: "highest",
- defaultTooltip: !0
- }],
- dimensions: null,
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "cartesian2d",
- legendHoverLink: !0,
- hoverAnimation: !0,
- layout: null,
- itemStyle: {
- color: "#c23531",
- color0: "#314656",
- borderWidth: 1,
- borderColor: "#c23531",
- borderColor0: "#314656"
- },
- emphasis: {
- itemStyle: {
- borderWidth: 2
- }
- },
- barMaxWidth: null,
- barMinWidth: null,
- barWidth: null,
- large: !0,
- largeThreshold: 600,
- progressive: 3e3,
- progressiveThreshold: 1e4,
- progressiveChunkMode: "mod",
- animationUpdate: !1,
- animationEasing: "linear",
- animationDuration: 300
- },
- getShadowDim: function() {
- return "open"
- },
- brushSelector: function(t, e, i) {
- var n = e.getItemLayout(t);
- return n && i.rect(n.brushRect)
- }
- }), mk, !0);
- var bk = ["itemStyle"],
- Sk = ["emphasis", "itemStyle"],
- Mk = ["color", "color0", "borderColor", "borderColor0"],
- Ik = (Mr.extend({
- type: "candlestick",
- render: function(t, e, i) {
- this._updateDrawMode(t), this._isLargeDraw ? this._renderLarge(t) : this._renderNormal(t)
- },
- incrementalPrepareRender: function(t, e, i) {
- this._clear(), this._updateDrawMode(t)
- },
- incrementalRender: function(t, e, i, n) {
- this._isLargeDraw ? this._incrementalRenderLarge(t, e) : this._incrementalRenderNormal(t, e)
- },
- _updateDrawMode: function(t) {
- var e = t.pipelineContext.large;
- (null == this._isLargeDraw || e ^ this._isLargeDraw) && (this._isLargeDraw = e, this._clear())
- },
- _renderNormal: function(t) {
- var e = t.getData(),
- i = this._data,
- n = this.group,
- o = e.getLayout("isSimpleBox");
- this._data || n.removeAll(), e.diff(i).add(function(i) {
- if (e.hasValue(i)) {
- var a, r = e.getItemLayout(i);
- So(a = eg(r, 0, !0), {
- shape: {
- points: r.ends
- }
- }, t, i), ig(a, e, i, o), n.add(a), e.setItemGraphicEl(i, a)
- }
- }).update(function(a, r) {
- var s = i.getItemGraphicEl(r);
- if (e.hasValue(a)) {
- var l = e.getItemLayout(a);
- s ? bo(s, {
- shape: {
- points: l.ends
- }
- }, t, a) : s = eg(l), ig(s, e, a, o), n.add(s), e.setItemGraphicEl(a, s)
- } else n.remove(s)
- }).remove(function(t) {
- var e = i.getItemGraphicEl(t);
- e && n.remove(e)
- }).execute(), this._data = e
- },
- _renderLarge: function(t) {
- this._clear(), og(t, this.group)
- },
- _incrementalRenderNormal: function(t, e) {
- for (var i, n = e.getData(), o = n.getLayout("isSimpleBox"); null != (i = t.next());) {
- var a;
- ig(a = eg(n.getItemLayout(i)), n, i, o), a.incremental = !0, this.group.add(a)
- }
- },
- _incrementalRenderLarge: function(t, e) {
- og(e, this.group, !0)
- },
- remove: function(t) {
- this._clear()
- },
- _clear: function() {
- this.group.removeAll(), this._data = null
- },
- dispose: B
- }), kn.extend({
- type: "normalCandlestickBox",
- shape: {},
- buildPath: function(t, e) {
- var i = e.points;
- this.__simpleBox ? (t.moveTo(i[4][0], i[4][1]), t.lineTo(i[6][0], i[6][1])) : (t.moveTo(i[0][0], i[0][1]), t.lineTo(
- i[1][0], i[1][1]), t.lineTo(i[2][0], i[2][1]), t.lineTo(i[3][0], i[3][1]), t.closePath(), t.moveTo(i[4][0],
- i[4][1]), t.lineTo(i[5][0], i[5][1]), t.moveTo(i[6][0], i[6][1]), t.lineTo(i[7][0], i[7][1]))
- }
- })),
- Tk = kn.extend({
- type: "largeCandlestickBox",
- shape: {},
- buildPath: function(t, e) {
- for (var i = e.points, n = 0; n < i.length;)
- if (this.__sign === i[n++]) {
- var o = i[n++];
- t.moveTo(o, i[n++]), t.lineTo(o, i[n++])
- } else n += 3
- }
- }),
- Ak = ["itemStyle", "borderColor"],
- Dk = ["itemStyle", "borderColor0"],
- Ck = ["itemStyle", "color"],
- Lk = ["itemStyle", "color0"],
- kk = {
- seriesType: "candlestick",
- plan: zI(),
- performRawSeries: !0,
- reset: function(t, e) {
- function i(t, e) {
- return e.get(t > 0 ? Ck : Lk)
- }
- function n(t, e) {
- return e.get(t > 0 ? Ak : Dk)
- }
- var o = t.getData(),
- a = t.pipelineContext.large;
- if (o.setVisual({
- legendSymbol: "roundRect",
- colorP: i(1, t),
- colorN: i(-1, t),
- borderColorP: n(1, t),
- borderColorN: n(-1, t)
- }), !e.isSeriesFiltered(t)) return !a && {
- progress: function(t, e) {
- for (var o; null != (o = t.next());) {
- var a = e.getItemModel(o),
- r = e.getItemLayout(o).sign;
- e.setItemVisual(o, {
- color: i(r, a),
- borderColor: n(r, a)
- })
- }
- }
- }
- }
- },
- Pk = "undefined" != typeof Float32Array ? Float32Array : Array,
- Nk = {
- seriesType: "candlestick",
- plan: zI(),
- reset: function(t) {
- var e = t.coordinateSystem,
- i = t.getData(),
- n = sg(t, i),
- o = 0,
- a = 1,
- r = ["x", "y"],
- s = i.mapDimension(r[o]),
- l = i.mapDimension(r[a], !0),
- u = l[0],
- h = l[1],
- c = l[2],
- d = l[3];
- if (i.setLayout({
- candleWidth: n,
- isSimpleBox: n <= 1.3
- }), !(null == s || l.length < 4)) return {
- progress: t.pipelineContext.large ? function(t, i) {
- for (var n, r, l = new Pk(5 * t.count), f = 0, p = [], g = []; null != (r = t.next());) {
- var m = i.get(s, r),
- v = i.get(u, r),
- y = i.get(h, r),
- x = i.get(c, r),
- _ = i.get(d, r);
- isNaN(m) || isNaN(x) || isNaN(_) ? (l[f++] = NaN, f += 4) : (l[f++] = rg(i, r, v, y, h), p[o] = m, p[a] = x,
- n = e.dataToPoint(p, null, g), l[f++] = n ? n[0] : NaN, l[f++] = n ? n[1] : NaN, p[a] = _, n = e.dataToPoint(
- p, null, g), l[f++] = n ? n[1] : NaN)
- }
- i.setLayout("largePoints", l)
- } : function(t, i) {
- function r(t, i) {
- var n = [];
- return n[o] = i, n[a] = t, isNaN(i) || isNaN(t) ? [NaN, NaN] : e.dataToPoint(n)
- }
- function l(t, e, i) {
- var a = e.slice(),
- r = e.slice();
- a[o] = Yn(a[o] + n / 2, 1, !1), r[o] = Yn(r[o] - n / 2, 1, !0), i ? t.push(a, r) : t.push(r, a)
- }
- function f(t) {
- return t[o] = Yn(t[o], 1), t
- }
- for (var p; null != (p = t.next());) {
- var g = i.get(s, p),
- m = i.get(u, p),
- v = i.get(h, p),
- y = i.get(c, p),
- x = i.get(d, p),
- _ = Math.min(m, v),
- w = Math.max(m, v),
- b = r(_, g),
- S = r(w, g),
- M = r(y, g),
- I = r(x, g),
- T = [];
- l(T, S, 0), l(T, b, 1), T.push(f(I), f(S), f(M), f(b)), i.setItemLayout(p, {
- sign: rg(i, p, m, v, h),
- initBaseline: m > v ? S[a] : b[a],
- ends: T,
- brushRect: function(t, e, i) {
- var s = r(t, i),
- l = r(e, i);
- return s[o] -= n / 2, l[o] -= n / 2, {
- x: s[0],
- y: s[1],
- width: a ? n : l[0] - s[0],
- height: a ? l[1] - s[1] : n
- }
- }(y, x, g)
- })
- }
- }
- }
- }
- };
- Ls(function(t) {
- t && y(t.series) && d(t.series, function(t) {
- w(t) && "k" === t.type && (t.type = "candlestick")
- })
- }), Es(kk), Os(Nk), OI.extend({
- type: "series.effectScatter",
- dependencies: ["grid", "polar"],
- getInitialData: function(t, e) {
- return dl(this.getSource(), this)
- },
- brushSelector: "point",
- defaultOption: {
- coordinateSystem: "cartesian2d",
- zlevel: 0,
- z: 2,
- legendHoverLink: !0,
- effectType: "ripple",
- progressive: 0,
- showEffectOn: "render",
- rippleEffect: {
- period: 4,
- scale: 2.5,
- brushType: "fill"
- },
- symbolSize: 10
- }
- });
- var Ok = hg.prototype;
- Ok.stopEffectAnimation = function() {
- this.childAt(1).removeAll()
- }, Ok.startEffectAnimation = function(t) {
- for (var e = t.symbolType, i = t.color, n = this.childAt(1), o = 0; o < 3; o++) {
- var a = Xl(e, -1, -1, 2, 2, i);
- a.attr({
- style: {
- strokeNoScale: !0
- },
- z2: 99,
- silent: !0,
- scale: [.5, .5]
- });
- var r = -o / 3 * t.period + t.effectOffset;
- a.animate("", !0).when(t.period, {
- scale: [t.rippleScale / 2, t.rippleScale / 2]
- }).delay(r).start(), a.animateStyle(!0).when(t.period, {
- opacity: 0
- }).delay(r).start(), n.add(a)
- }
- ug(n, t)
- }, Ok.updateEffectAnimation = function(t) {
- for (var e = this._effectCfg, i = this.childAt(1), n = ["symbolType", "period", "rippleScale"], o = 0; o < n.length; o++) {
- var a = n[o];
- if (e[a] !== t[a]) return this.stopEffectAnimation(), void this.startEffectAnimation(t)
- }
- ug(i, t)
- }, Ok.highlight = function() {
- this.trigger("emphasis")
- }, Ok.downplay = function() {
- this.trigger("normal")
- }, Ok.updateData = function(t, e) {
- var i = t.hostModel;
- this.childAt(0).updateData(t, e);
- var n = this.childAt(1),
- o = t.getItemModel(e),
- a = t.getItemVisual(e, "symbol"),
- r = lg(t.getItemVisual(e, "symbolSize")),
- s = t.getItemVisual(e, "color");
- n.attr("scale", r), n.traverse(function(t) {
- t.attr({
- fill: s
- })
- });
- var l = o.getShallow("symbolOffset");
- if (l) {
- var u = n.position;
- u[0] = Ro(l[0], r[0]), u[1] = Ro(l[1], r[1])
- }
- n.rotation = (o.getShallow("symbolRotate") || 0) * Math.PI / 180 || 0;
- var h = {};
- if (h.showEffectOn = i.get("showEffectOn"), h.rippleScale = o.get("rippleEffect.scale"), h.brushType = o.get(
- "rippleEffect.brushType"), h.period = 1e3 * o.get("rippleEffect.period"), h.effectOffset = e / t.count(), h.z = o
- .getShallow("z") || 0, h.zlevel = o.getShallow("zlevel") || 0, h.symbolType = a, h.color = s, this.off("mouseover")
- .off("mouseout").off("emphasis").off("normal"), "render" === h.showEffectOn) this._effectCfg ? this.updateEffectAnimation(
- h) : this.startEffectAnimation(h), this._effectCfg = h;
- else {
- this._effectCfg = null, this.stopEffectAnimation();
- var c = this.childAt(0),
- d = function() {
- c.highlight(), "render" !== h.showEffectOn && this.startEffectAnimation(h)
- },
- f = function() {
- c.downplay(), "render" !== h.showEffectOn && this.stopEffectAnimation()
- };
- this.on("mouseover", d, this).on("mouseout", f, this).on("emphasis", d, this).on("normal", f, this)
- }
- this._effectCfg = h
- }, Ok.fadeOut = function(t) {
- this.off("mouseover").off("mouseout").off("emphasis").off("normal"), t && t()
- }, u(hg, Zw), Fs({
- type: "effectScatter",
- init: function() {
- this._symbolDraw = new Su(hg)
- },
- render: function(t, e, i) {
- var n = t.getData(),
- o = this._symbolDraw;
- o.updateData(n), this.group.add(o.group)
- },
- updateTransform: function(t, e, i) {
- var n = t.getData();
- this.group.dirty();
- var o = cD().reset(t);
- o.progress && o.progress({
- start: 0,
- end: n.count()
- }, n), this._symbolDraw.updateLayout(n)
- },
- _updateGroupTransform: function(t) {
- var e = t.coordinateSystem;
- e && e.getRoamTransform && (this.group.transform = Mt(e.getRoamTransform()), this.group.decomposeTransform())
- },
- remove: function(t, e) {
- this._symbolDraw && this._symbolDraw.remove(e)
- },
- dispose: function() {}
- }), Es(hD("effectScatter", "circle")), Os(cD("effectScatter"));
- var Ek = "undefined" == typeof Uint32Array ? Array : Uint32Array,
- Rk = "undefined" == typeof Float64Array ? Array : Float64Array,
- zk = OI.extend({
- type: "series.lines",
- dependencies: ["grid", "polar"],
- visualColorAccessPath: "lineStyle.color",
- init: function(t) {
- t.data = t.data || [], cg(t);
- var e = this._processFlatCoordsArray(t.data);
- this._flatCoords = e.flatCoords, this._flatCoordsOffset = e.flatCoordsOffset, e.flatCoords && (t.data = new Float32Array(
- e.count)), zk.superApply(this, "init", arguments)
- },
- mergeOption: function(t) {
- if (t.data = t.data || [], cg(t), t.data) {
- var e = this._processFlatCoordsArray(t.data);
- this._flatCoords = e.flatCoords, this._flatCoordsOffset = e.flatCoordsOffset, e.flatCoords && (t.data = new Float32Array(
- e.count))
- }
- zk.superApply(this, "mergeOption", arguments)
- },
- appendData: function(t) {
- var e = this._processFlatCoordsArray(t.data);
- e.flatCoords && (this._flatCoords ? (this._flatCoords = z(this._flatCoords, e.flatCoords), this._flatCoordsOffset =
- z(this._flatCoordsOffset, e.flatCoordsOffset)) : (this._flatCoords = e.flatCoords, this._flatCoordsOffset = e
- .flatCoordsOffset), t.data = new Float32Array(e.count)), this.getRawData().appendData(t.data)
- },
- _getCoordsFromItemModel: function(t) {
- var e = this.getData().getItemModel(t);
- return e.option instanceof Array ? e.option : e.getShallow("coords")
- },
- getLineCoordsCount: function(t) {
- return this._flatCoordsOffset ? this._flatCoordsOffset[2 * t + 1] : this._getCoordsFromItemModel(t).length
- },
- getLineCoords: function(t, e) {
- if (this._flatCoordsOffset) {
- for (var i = this._flatCoordsOffset[2 * t], n = this._flatCoordsOffset[2 * t + 1], o = 0; o < n; o++) e[o] = e[
- o] || [], e[o][0] = this._flatCoords[i + 2 * o], e[o][1] = this._flatCoords[i + 2 * o + 1];
- return n
- }
- for (var a = this._getCoordsFromItemModel(t), o = 0; o < a.length; o++) e[o] = e[o] || [], e[o][0] = a[o][0], e[
- o][1] = a[o][1];
- return a.length
- },
- _processFlatCoordsArray: function(t) {
- var e = 0;
- if (this._flatCoords && (e = this._flatCoords.length), "number" == typeof t[0]) {
- for (var i = t.length, n = new Ek(i), o = new Rk(i), a = 0, r = 0, s = 0, l = 0; l < i;) {
- s++;
- var u = t[l++];
- n[r++] = a + e, n[r++] = u;
- for (var h = 0; h < u; h++) {
- var c = t[l++],
- d = t[l++];
- o[a++] = c, o[a++] = d
- }
- }
- return {
- flatCoordsOffset: new Uint32Array(n.buffer, 0, r),
- flatCoords: o,
- count: s
- }
- }
- return {
- flatCoordsOffset: null,
- flatCoords: null,
- count: t.length
- }
- },
- getInitialData: function(t, e) {
- var i = new eA(["value"], this);
- return i.hasItemOption = !1, i.initData(t.data, [], function(t, e, n, o) {
- if (t instanceof Array) return NaN;
- i.hasItemOption = !0;
- var a = t.value;
- return null != a ? a instanceof Array ? a[o] : a : void 0
- }), i
- },
- formatTooltip: function(t) {
- var e = this.getData().getItemModel(t),
- i = e.get("name");
- if (i) return i;
- var n = e.get("fromName"),
- o = e.get("toName"),
- a = [];
- return null != n && a.push(n), null != o && a.push(o), Qo(a.join(" > "))
- },
- preventIncremental: function() {
- return !!this.get("effect.show")
- },
- getProgressive: function() {
- var t = this.option.progressive;
- return null == t ? this.option.large ? 1e4 : this.get("progressive") : t
- },
- getProgressiveThreshold: function() {
- var t = this.option.progressiveThreshold;
- return null == t ? this.option.large ? 2e4 : this.get("progressiveThreshold") : t
- },
- defaultOption: {
- coordinateSystem: "geo",
- zlevel: 0,
- z: 2,
- legendHoverLink: !0,
- hoverAnimation: !0,
- xAxisIndex: 0,
- yAxisIndex: 0,
- symbol: ["none", "none"],
- symbolSize: [10, 10],
- geoIndex: 0,
- effect: {
- show: !1,
- period: 4,
- constantSpeed: 0,
- symbol: "circle",
- symbolSize: 3,
- loop: !0,
- trailLength: .2
- },
- large: !1,
- largeThreshold: 2e3,
- polyline: !1,
- label: {
- show: !1,
- position: "end"
- },
- lineStyle: {
- opacity: .5
- }
- }
- }),
- Bk = dg.prototype;
- Bk.createLine = function(t, e, i) {
- return new $d(t, e, i)
- }, Bk._updateEffectSymbol = function(t, e) {
- var i = t.getItemModel(e).getModel("effect"),
- n = i.get("symbolSize"),
- o = i.get("symbol");
- y(n) || (n = [n, n]);
- var a = i.get("color") || t.getItemVisual(e, "color"),
- r = this.childAt(1);
- this._symbolType !== o && (this.remove(r), (r = Xl(o, -.5, -.5, 1, 1, a)).z2 = 100, r.culling = !0, this.add(r)), r &&
- (r.setStyle("shadowColor", a), r.setStyle(i.getItemStyle(["color"])), r.attr("scale", n), r.setColor(a), r.attr(
- "scale", n), this._symbolType = o, this._updateEffectAnimation(t, i, e))
- }, Bk._updateEffectAnimation = function(t, e, i) {
- var n = this.childAt(1);
- if (n) {
- var o = this,
- a = t.getItemLayout(i),
- r = 1e3 * e.get("period"),
- s = e.get("loop"),
- l = e.get("constantSpeed"),
- u = T(e.get("delay"), function(e) {
- return e / t.count() * r / 3
- }),
- h = "function" == typeof u;
- if (n.ignore = !0, this.updateAnimationPoints(n, a), l > 0 && (r = this.getLineLength(n) / l * 1e3), r !== this._period ||
- s !== this._loop) {
- n.stopAnimation();
- var c = u;
- h && (c = u(i)), n.__t > 0 && (c = -r * n.__t), n.__t = 0;
- var d = n.animate("", s).when(r, {
- __t: 1
- }).delay(c).during(function() {
- o.updateSymbolPosition(n)
- });
- s || d.done(function() {
- o.remove(n)
- }), d.start()
- }
- this._period = r, this._loop = s
- }
- }, Bk.getLineLength = function(t) {
- return ew(t.__p1, t.__cp1) + ew(t.__cp1, t.__p2)
- }, Bk.updateAnimationPoints = function(t, e) {
- t.__p1 = e[0], t.__p2 = e[1], t.__cp1 = e[2] || [(e[0][0] + e[1][0]) / 2, (e[0][1] + e[1][1]) / 2]
- }, Bk.updateData = function(t, e, i) {
- this.childAt(0).updateData(t, e, i), this._updateEffectSymbol(t, e)
- }, Bk.updateSymbolPosition = function(t) {
- var e = t.__p1,
- i = t.__p2,
- n = t.__cp1,
- o = t.__t,
- a = t.position,
- r = rn,
- s = sn;
- a[0] = r(e[0], n[0], i[0], o), a[1] = r(e[1], n[1], i[1], o);
- var l = s(e[0], n[0], i[0], o),
- u = s(e[1], n[1], i[1], o);
- t.rotation = -Math.atan2(u, l) - Math.PI / 2, t.ignore = !1
- }, Bk.updateLayout = function(t, e) {
- this.childAt(0).updateLayout(t, e);
- var i = t.getItemModel(e).getModel("effect");
- this._updateEffectAnimation(t, i, e)
- }, u(dg, Zw);
- var Vk = fg.prototype;
- Vk._createPolyline = function(t, e, i) {
- var n = t.getItemLayout(e),
- o = new oM({
- shape: {
- points: n
- }
- });
- this.add(o), this._updateCommonStl(t, e, i)
- }, Vk.updateData = function(t, e, i) {
- var n = t.hostModel;
- bo(this.childAt(0), {
- shape: {
- points: t.getItemLayout(e)
- }
- }, n, e), this._updateCommonStl(t, e, i)
- }, Vk._updateCommonStl = function(t, e, i) {
- var n = this.childAt(0),
- o = t.getItemModel(e),
- a = t.getItemVisual(e, "color"),
- s = i && i.lineStyle,
- l = i && i.hoverLineStyle;
- i && !t.hasItemOption || (s = o.getModel("lineStyle").getLineStyle(), l = o.getModel("emphasis.lineStyle").getLineStyle()),
- n.useStyle(r({
- strokeNoScale: !0,
- fill: "none",
- stroke: a
- }, s)), n.hoverStyle = l, uo(this)
- }, Vk.updateLayout = function(t, e) {
- this.childAt(0).setShape("points", t.getItemLayout(e))
- }, u(fg, Zw);
- var Gk = pg.prototype;
- Gk.createLine = function(t, e, i) {
- return new fg(t, e, i)
- }, Gk.updateAnimationPoints = function(t, e) {
- this._points = e;
- for (var i = [0], n = 0, o = 1; o < e.length; o++) {
- var a = e[o - 1],
- r = e[o];
- n += ew(a, r), i.push(n)
- }
- if (0 !== n) {
- for (o = 0; o < i.length; o++) i[o] /= n;
- this._offsets = i, this._length = n
- }
- }, Gk.getLineLength = function(t) {
- return this._length
- }, Gk.updateSymbolPosition = function(t) {
- var e = t.__t,
- i = this._points,
- n = this._offsets,
- o = i.length;
- if (n) {
- var a = this._lastFrame;
- if (e < this._lastFramePercent) {
- for (r = Math.min(a + 1, o - 1); r >= 0 && !(n[r] <= e); r--);
- r = Math.min(r, o - 2)
- } else {
- for (var r = a; r < o && !(n[r] > e); r++);
- r = Math.min(r - 1, o - 2)
- }
- J(t.position, i[r], i[r + 1], (e - n[r]) / (n[r + 1] - n[r]));
- var s = i[r + 1][0] - i[r][0],
- l = i[r + 1][1] - i[r][1];
- t.rotation = -Math.atan2(l, s) - Math.PI / 2, this._lastFrame = r, this._lastFramePercent = e, t.ignore = !1
- }
- }, u(pg, dg);
- var Fk = Fn({
- shape: {
- polyline: !1,
- curveness: 0,
- segs: []
- },
- buildPath: function(t, e) {
- var i = e.segs,
- n = e.curveness;
- if (e.polyline)
- for (r = 0; r < i.length;) {
- var o = i[r++];
- if (o > 0) {
- t.moveTo(i[r++], i[r++]);
- for (var a = 1; a < o; a++) t.lineTo(i[r++], i[r++])
- }
- } else
- for (var r = 0; r < i.length;) {
- var s = i[r++],
- l = i[r++],
- u = i[r++],
- h = i[r++];
- if (t.moveTo(s, l), n > 0) {
- var c = (s + u) / 2 - (l - h) * n,
- d = (l + h) / 2 - (u - s) * n;
- t.quadraticCurveTo(c, d, u, h)
- } else t.lineTo(u, h)
- }
- },
- findDataIndex: function(t, e) {
- var i = this.shape,
- n = i.segs,
- o = i.curveness;
- if (i.polyline)
- for (var a = 0, r = 0; r < n.length;) {
- var s = n[r++];
- if (s > 0)
- for (var l = n[r++], u = n[r++], h = 1; h < s; h++)
- if (vn(l, u, c = n[r++], d = n[r++])) return a;
- a++
- } else
- for (var a = 0, r = 0; r < n.length;) {
- var l = n[r++],
- u = n[r++],
- c = n[r++],
- d = n[r++];
- if (o > 0) {
- if (xn(l, u, (l + c) / 2 - (u - d) * o, (u + d) / 2 - (c - l) * o, c, d)) return a
- } else if (vn(l, u, c, d)) return a;
- a++
- }
- return -1
- }
- }),
- Wk = gg.prototype;
- Wk.isPersistent = function() {
- return !this._incremental
- }, Wk.updateData = function(t) {
- this.group.removeAll();
- var e = new Fk({
- rectHover: !0,
- cursor: "default"
- });
- e.setShape({
- segs: t.getLayout("linesPoints")
- }), this._setCommon(e, t), this.group.add(e), this._incremental = null
- }, Wk.incrementalPrepareUpdate = function(t) {
- this.group.removeAll(), this._clearIncremental(), t.count() > 5e5 ? (this._incremental || (this._incremental = new Gn({
- silent: !0
- })), this.group.add(this._incremental)) : this._incremental = null
- }, Wk.incrementalUpdate = function(t, e) {
- var i = new Fk;
- i.setShape({
- segs: e.getLayout("linesPoints")
- }), this._setCommon(i, e, !!this._incremental), this._incremental ? this._incremental.addDisplayable(i, !0) : (i.rectHover = !
- 0, i.cursor = "default", i.__startIndex = t.start, this.group.add(i))
- }, Wk.remove = function() {
- this._clearIncremental(), this._incremental = null, this.group.removeAll()
- }, Wk._setCommon = function(t, e, i) {
- var n = e.hostModel;
- t.setShape({
- polyline: n.get("polyline"),
- curveness: n.get("lineStyle.curveness")
- }), t.useStyle(n.getModel("lineStyle").getLineStyle()), t.style.strokeNoScale = !0;
- var o = e.getVisual("color");
- o && t.setStyle("stroke", o), t.setStyle("fill"), i || (t.seriesIndex = n.seriesIndex, t.on("mousemove", function(e) {
- t.dataIndex = null;
- var i = t.findDataIndex(e.offsetX, e.offsetY);
- i > 0 && (t.dataIndex = i + t.__startIndex)
- }))
- }, Wk._clearIncremental = function() {
- var t = this._incremental;
- t && t.clearDisplaybles()
- };
- var Hk = {
- seriesType: "lines",
- plan: zI(),
- reset: function(t) {
- var e = t.coordinateSystem,
- i = t.get("polyline"),
- n = t.pipelineContext.large;
- return {
- progress: function(o, a) {
- var r = [];
- if (n) {
- var s, l = o.end - o.start;
- if (i) {
- for (var u = 0, h = o.start; h < o.end; h++) u += t.getLineCoordsCount(h);
- s = new Float32Array(l + 2 * u)
- } else s = new Float32Array(4 * l);
- for (var c = 0, d = [], h = o.start; h < o.end; h++) {
- g = t.getLineCoords(h, r), i && (s[c++] = g);
- for (var f = 0; f < g; f++) d = e.dataToPoint(r[f], !1, d), s[c++] = d[0], s[c++] = d[1]
- }
- a.setLayout("linesPoints", s)
- } else
- for (h = o.start; h < o.end; h++) {
- var p = a.getItemModel(h),
- g = t.getLineCoords(h, r),
- m = [];
- if (i)
- for (var v = 0; v < g; v++) m.push(e.dataToPoint(r[v]));
- else {
- m[0] = e.dataToPoint(r[0]), m[1] = e.dataToPoint(r[1]);
- var y = p.get("lineStyle.curveness"); + y && (m[2] = [(m[0][0] + m[1][0]) / 2 - (m[0][1] - m[1][1]) * y, (m[
- 0][1] + m[1][1]) / 2 - (m[1][0] - m[0][0]) * y])
- }
- a.setItemLayout(h, m)
- }
- }
- }
- }
- };
- Fs({
- type: "lines",
- init: function() {},
- render: function(t, e, i) {
- var n = t.getData(),
- o = this._updateLineDraw(n, t),
- a = t.get("zlevel"),
- r = t.get("effect.trailLength"),
- s = i.getZr(),
- l = "svg" === s.painter.getType();
- l || s.painter.getLayer(a).clear(!0), null == this._lastZlevel || l || s.configLayer(this._lastZlevel, {
- motionBlur: !1
- }), this._showEffect(t) && r && (l || s.configLayer(a, {
- motionBlur: !0,
- lastFrameAlpha: Math.max(Math.min(r / 10 + .9, 1), 0)
- })), o.updateData(n), this._lastZlevel = a, this._finished = !0
- },
- incrementalPrepareRender: function(t, e, i) {
- var n = t.getData();
- this._updateLineDraw(n, t).incrementalPrepareUpdate(n), this._clearLayer(i), this._finished = !1
- },
- incrementalRender: function(t, e, i) {
- this._lineDraw.incrementalUpdate(t, e.getData()), this._finished = t.end === e.getData().count()
- },
- updateTransform: function(t, e, i) {
- var n = t.getData(),
- o = t.pipelineContext;
- if (!this._finished || o.large || o.progressiveRender) return {
- update: !0
- };
- var a = Hk.reset(t);
- a.progress && a.progress({
- start: 0,
- end: n.count()
- }, n), this._lineDraw.updateLayout(), this._clearLayer(i)
- },
- _updateLineDraw: function(t, e) {
- var i = this._lineDraw,
- n = this._showEffect(e),
- o = !!e.get("polyline"),
- a = e.pipelineContext.large;
- return i && n === this._hasEffet && o === this._isPolyline && a === this._isLargeDraw || (i && i.remove(), i =
- this._lineDraw = a ? new gg : new Jd(o ? n ? pg : fg : n ? dg : $d), this._hasEffet = n, this._isPolyline = o,
- this._isLargeDraw = a, this.group.removeAll()), this.group.add(i.group), i
- },
- _showEffect: function(t) {
- return !!t.get("effect.show")
- },
- _clearLayer: function(t) {
- var e = t.getZr();
- "svg" === e.painter.getType() || null == this._lastZlevel || e.painter.getLayer(this._lastZlevel).clear(!0)
- },
- remove: function(t, e) {
- this._lineDraw && this._lineDraw.remove(), this._lineDraw = null, this._clearLayer(e)
- },
- dispose: function() {}
- });
- var Zk = "lineStyle.opacity".split("."),
- Uk = {
- seriesType: "lines",
- reset: function(t, e, i) {
- var n = mg(t.get("symbol")),
- o = mg(t.get("symbolSize")),
- a = t.getData();
- return a.setVisual("fromSymbol", n && n[0]), a.setVisual("toSymbol", n && n[1]), a.setVisual("fromSymbolSize", o &&
- o[0]), a.setVisual("toSymbolSize", o && o[1]), a.setVisual("opacity", t.get(Zk)), {
- dataEach: a.hasItemOption ? function(t, e) {
- var i = t.getItemModel(e),
- n = mg(i.getShallow("symbol", !0)),
- o = mg(i.getShallow("symbolSize", !0)),
- a = i.get(Zk);
- n[0] && t.setItemVisual(e, "fromSymbol", n[0]), n[1] && t.setItemVisual(e, "toSymbol", n[1]), o[0] && t.setItemVisual(
- e, "fromSymbolSize", o[0]), o[1] && t.setItemVisual(e, "toSymbolSize", o[1]), t.setItemVisual(e, "opacity",
- a)
- } : null
- }
- }
- };
- Os(Hk), Es(Uk), OI.extend({
- type: "series.heatmap",
- getInitialData: function(t, e) {
- return dl(this.getSource(), this, {
- generateCoord: "value"
- })
- },
- preventIncremental: function() {
- var t = Ba.get(this.get("coordinateSystem"));
- if (t && t.dimensions) return "lng" === t.dimensions[0] && "lat" === t.dimensions[1]
- },
- defaultOption: {
- coordinateSystem: "cartesian2d",
- zlevel: 0,
- z: 2,
- geoIndex: 0,
- blurSize: 30,
- pointSize: 20,
- maxOpacity: 1,
- minOpacity: 0
- }
- });
- vg.prototype = {
- update: function(t, e, i, n, o, a) {
- var r = this._getBrush(),
- s = this._getGradient(t, o, "inRange"),
- l = this._getGradient(t, o, "outOfRange"),
- u = this.pointSize + this.blurSize,
- h = this.canvas,
- c = h.getContext("2d"),
- d = t.length;
- h.width = e, h.height = i;
- for (var f = 0; f < d; ++f) {
- var p = t[f],
- g = p[0],
- m = p[1],
- v = n(p[2]);
- c.globalAlpha = v, c.drawImage(r, g - u, m - u)
- }
- if (!h.width || !h.height) return h;
- for (var y = c.getImageData(0, 0, h.width, h.height), x = y.data, _ = 0, w = x.length, b = this.minOpacity, S =
- this.maxOpacity - b; _ < w;) {
- var v = x[_ + 3] / 256,
- M = 4 * Math.floor(255 * v);
- if (v > 0) {
- var I = a(v) ? s : l;
- v > 0 && (v = v * S + b), x[_++] = I[M], x[_++] = I[M + 1], x[_++] = I[M + 2], x[_++] = I[M + 3] * v * 256
- } else _ += 4
- }
- return c.putImageData(y, 0, 0), h
- },
- _getBrush: function() {
- var t = this._brushCanvas || (this._brushCanvas = Y_()),
- e = this.pointSize + this.blurSize,
- i = 2 * e;
- t.width = i, t.height = i;
- var n = t.getContext("2d");
- return n.clearRect(0, 0, i, i), n.shadowOffsetX = i, n.shadowBlur = this.blurSize, n.shadowColor = "#000", n.beginPath(),
- n.arc(-e, e, this.pointSize, 0, 2 * Math.PI, !0), n.closePath(), n.fill(), t
- },
- _getGradient: function(t, e, i) {
- for (var n = this._gradientPixels, o = n[i] || (n[i] = new Uint8ClampedArray(1024)), a = [0, 0, 0, 0], r = 0, s =
- 0; s < 256; s++) e[i](s / 255, !0, a), o[r++] = a[0], o[r++] = a[1], o[r++] = a[2], o[r++] = a[3];
- return o
- }
- }, Fs({
- type: "heatmap",
- render: function(t, e, i) {
- var n;
- e.eachComponent("visualMap", function(e) {
- e.eachTargetSeries(function(i) {
- i === t && (n = e)
- })
- }), this.group.removeAll(), this._incrementalDisplayable = null;
- var o = t.coordinateSystem;
- "cartesian2d" === o.type || "calendar" === o.type ? this._renderOnCartesianAndCalendar(t, i, 0, t.getData().count()) :
- _g(o) && this._renderOnGeo(o, t, n, i)
- },
- incrementalPrepareRender: function(t, e, i) {
- this.group.removeAll()
- },
- incrementalRender: function(t, e, i, n) {
- e.coordinateSystem && this._renderOnCartesianAndCalendar(e, n, t.start, t.end, !0)
- },
- _renderOnCartesianAndCalendar: function(t, e, i, n, o) {
- var r, s, l = t.coordinateSystem;
- if ("cartesian2d" === l.type) {
- var u = l.getAxis("x"),
- h = l.getAxis("y");
- r = u.getBandWidth(), s = h.getBandWidth()
- }
- for (var c = this.group, d = t.getData(), f = t.getModel("itemStyle").getItemStyle(["color"]), p = t.getModel(
- "emphasis.itemStyle").getItemStyle(), g = t.getModel("label"), m = t.getModel("emphasis.label"), v = l.type,
- y = "cartesian2d" === v ? [d.mapDimension("x"), d.mapDimension("y"), d.mapDimension("value")] : [d.mapDimension(
- "time"), d.mapDimension("value")], x = i; x < n; x++) {
- var _;
- if ("cartesian2d" === v) {
- if (isNaN(d.get(y[2], x))) continue;
- var w = l.dataToPoint([d.get(y[0], x), d.get(y[1], x)]);
- _ = new aM({
- shape: {
- x: w[0] - r / 2,
- y: w[1] - s / 2,
- width: r,
- height: s
- },
- style: {
- fill: d.getItemVisual(x, "color"),
- opacity: d.getItemVisual(x, "opacity")
- }
- })
- } else {
- if (isNaN(d.get(y[1], x))) continue;
- _ = new aM({
- z2: 1,
- shape: l.dataToRect([d.get(y[0], x)]).contentShape,
- style: {
- fill: d.getItemVisual(x, "color"),
- opacity: d.getItemVisual(x, "opacity")
- }
- })
- }
- var b = d.getItemModel(x);
- d.hasItemOption && (f = b.getModel("itemStyle").getItemStyle(["color"]), p = b.getModel("emphasis.itemStyle").getItemStyle(),
- g = b.getModel("label"), m = b.getModel("emphasis.label"));
- var S = t.getRawValue(x),
- M = "-";
- S && null != S[2] && (M = S[2]), co(f, p, g, m, {
- labelFetcher: t,
- labelDataIndex: x,
- defaultText: M,
- isRectText: !0
- }), _.setStyle(f), uo(_, d.hasItemOption ? p : a({}, p)), _.incremental = o, o && (_.useHoverLayer = !0), c.add(
- _), d.setItemGraphicEl(x, _)
- }
- },
- _renderOnGeo: function(t, e, i, n) {
- var o = i.targetVisuals.inRange,
- a = i.targetVisuals.outOfRange,
- r = e.getData(),
- s = this._hmLayer || this._hmLayer || new vg;
- s.blurSize = e.get("blurSize"), s.pointSize = e.get("pointSize"), s.minOpacity = e.get("minOpacity"), s.maxOpacity =
- e.get("maxOpacity");
- var l = t.getViewRect().clone(),
- u = t.getRoamTransform();
- l.applyTransform(u);
- var h = Math.max(l.x, 0),
- c = Math.max(l.y, 0),
- d = Math.min(l.width + l.x, n.getWidth()),
- f = Math.min(l.height + l.y, n.getHeight()),
- p = d - h,
- g = f - c,
- m = [r.mapDimension("lng"), r.mapDimension("lat"), r.mapDimension("value")],
- v = r.mapArray(m, function(e, i, n) {
- var o = t.dataToPoint([e, i]);
- return o[0] -= h, o[1] -= c, o.push(n), o
- }),
- y = i.getExtent(),
- x = "visualMap.continuous" === i.type ? xg(y, i.option.range) : yg(y, i.getPieceList(), i.option.selected);
- s.update(v, p, g, o.color.getNormalizer(), {
- inRange: o.color.getColorMapper(),
- outOfRange: a.color.getColorMapper()
- }, x);
- var _ = new hi({
- style: {
- width: p,
- height: g,
- x: h,
- y: c,
- image: s.canvas
- },
- silent: !0
- });
- this.group.add(_)
- },
- dispose: function() {}
- });
- var Xk = ED.extend({
- type: "series.pictorialBar",
- dependencies: ["grid"],
- defaultOption: {
- symbol: "circle",
- symbolSize: null,
- symbolRotate: null,
- symbolPosition: null,
- symbolOffset: null,
- symbolMargin: null,
- symbolRepeat: !1,
- symbolRepeatDirection: "end",
- symbolClip: !1,
- symbolBoundingData: null,
- symbolPatternSize: 400,
- barGap: "-100%",
- progressive: 0,
- hoverAnimation: !1
- },
- getInitialData: function(t) {
- return t.stack = null, Xk.superApply(this, "getInitialData", arguments)
- }
- }),
- jk = ["itemStyle", "borderWidth"],
- Yk = [{
- xy: "x",
- wh: "width",
- index: 0,
- posDesc: ["left", "right"]
- }, {
- xy: "y",
- wh: "height",
- index: 1,
- posDesc: ["top", "bottom"]
- }],
- qk = new KS;
- Fs({
- type: "pictorialBar",
- render: function(t, e, i) {
- var n = this.group,
- o = t.getData(),
- a = this._data,
- r = t.coordinateSystem,
- s = !!r.getBaseAxis().isHorizontal(),
- l = r.grid.getRect(),
- u = {
- ecSize: {
- width: i.getWidth(),
- height: i.getHeight()
- },
- seriesModel: t,
- coordSys: r,
- coordSysExtent: [
- [l.x, l.x + l.width],
- [l.y, l.y + l.height]
- ],
- isHorizontal: s,
- valueDim: Yk[+s],
- categoryDim: Yk[1 - s]
- };
- return o.diff(a).add(function(t) {
- if (o.hasValue(t)) {
- var e = Pg(o, t),
- i = wg(o, t, e, u),
- a = Rg(o, u, i);
- o.setItemGraphicEl(t, a), n.add(a), Wg(a, u, i)
- }
- }).update(function(t, e) {
- var i = a.getItemGraphicEl(e);
- if (o.hasValue(t)) {
- var r = Pg(o, t),
- s = wg(o, t, r, u),
- l = Vg(o, s);
- i && l !== i.__pictorialShapeStr && (n.remove(i), o.setItemGraphicEl(t, null), i = null), i ? zg(i, u, s) :
- i = Rg(o, u, s, !0), o.setItemGraphicEl(t, i), i.__pictorialSymbolMeta = s, n.add(i), Wg(i, u, s)
- } else n.remove(i)
- }).remove(function(t) {
- var e = a.getItemGraphicEl(t);
- e && Bg(a, t, e.__pictorialSymbolMeta.animationModel, e)
- }).execute(), this._data = o, this.group
- },
- dispose: B,
- remove: function(t, e) {
- var i = this.group,
- n = this._data;
- t.get("animation") ? n && n.eachItemGraphicEl(function(e) {
- Bg(n, e.dataIndex, t, e)
- }) : i.removeAll()
- }
- });
- Os(v(kl, "pictorialBar")), Es(hD("pictorialBar", "roundRect"));
- var Kk = function(t, e, i, n, o) {
- HA.call(this, t, e, i), this.type = n || "value", this.position = o || "bottom", this.orient = null
- };
- Kk.prototype = {
- constructor: Kk,
- model: null,
- isHorizontal: function() {
- var t = this.position;
- return "top" === t || "bottom" === t
- },
- pointToData: function(t, e) {
- return this.coordinateSystem.pointToData(t, e)[0]
- },
- toGlobalCoord: null,
- toLocalCoord: null
- }, u(Kk, HA), Zg.prototype = {
- type: "singleAxis",
- axisPointerEnabled: !0,
- constructor: Zg,
- _init: function(t, e, i) {
- var n = this.dimension,
- o = new Kk(n, Vl(t), [0, 0], t.get("type"), t.get("position")),
- a = "category" === o.type;
- o.onBand = a && t.get("boundaryGap"), o.inverse = t.get("inverse"), o.orient = t.get("orient"), t.axis = o, o.model =
- t, o.coordinateSystem = this, this._axis = o
- },
- update: function(t, e) {
- t.eachSeries(function(t) {
- if (t.coordinateSystem === this) {
- var e = t.getData();
- d(e.mapDimension(this.dimension, !0), function(t) {
- this._axis.scale.unionExtentFromData(e, t)
- }, this), Bl(this._axis.scale, this._axis.model)
- }
- }, this)
- },
- resize: function(t, e) {
- this._rect = la({
- left: t.get("left"),
- top: t.get("top"),
- right: t.get("right"),
- bottom: t.get("bottom"),
- width: t.get("width"),
- height: t.get("height")
- }, {
- width: e.getWidth(),
- height: e.getHeight()
- }), this._adjustAxis()
- },
- getRect: function() {
- return this._rect
- },
- _adjustAxis: function() {
- var t = this._rect,
- e = this._axis,
- i = e.isHorizontal(),
- n = i ? [0, t.width] : [0, t.height],
- o = e.reverse ? 1 : 0;
- e.setExtent(n[o], n[1 - o]), this._updateAxisTransform(e, i ? t.x : t.y)
- },
- _updateAxisTransform: function(t, e) {
- var i = t.getExtent(),
- n = i[0] + i[1],
- o = t.isHorizontal();
- t.toGlobalCoord = o ? function(t) {
- return t + e
- } : function(t) {
- return n - t + e
- }, t.toLocalCoord = o ? function(t) {
- return t - e
- } : function(t) {
- return n - t + e
- }
- },
- getAxis: function() {
- return this._axis
- },
- getBaseAxis: function() {
- return this._axis
- },
- getAxes: function() {
- return [this._axis]
- },
- getTooltipAxes: function() {
- return {
- baseAxes: [this.getAxis()]
- }
- },
- containPoint: function(t) {
- var e = this.getRect(),
- i = this.getAxis();
- return "horizontal" === i.orient ? i.contain(i.toLocalCoord(t[0])) && t[1] >= e.y && t[1] <= e.y + e.height : i.contain(
- i.toLocalCoord(t[1])) && t[0] >= e.y && t[0] <= e.y + e.height
- },
- pointToData: function(t) {
- var e = this.getAxis();
- return [e.coordToData(e.toLocalCoord(t["horizontal" === e.orient ? 0 : 1]))]
- },
- dataToPoint: function(t) {
- var e = this.getAxis(),
- i = this.getRect(),
- n = [],
- o = "horizontal" === e.orient ? 0 : 1;
- return t instanceof Array && (t = t[0]), n[o] = e.toGlobalCoord(e.dataToCoord(+t)), n[1 - o] = 0 === o ? i.y + i.height /
- 2 : i.x + i.width / 2, n
- }
- }, Ba.register("single", {
- create: function(t, e) {
- var i = [];
- return t.eachComponent("singleAxis", function(n, o) {
- var a = new Zg(n, t, e);
- a.name = "single_" + o, a.resize(n, e), n.coordinateSystem = a, i.push(a)
- }), t.eachSeries(function(e) {
- if ("singleAxis" === e.get("coordinateSystem")) {
- var i = t.queryComponents({
- mainType: "singleAxis",
- index: e.get("singleAxisIndex"),
- id: e.get("singleAxisId")
- })[0];
- e.coordinateSystem = i && i.coordinateSystem
- }
- }), i
- },
- dimensions: Zg.prototype.dimensions
- });
- var $k = ["axisLine", "axisTickLabel", "axisName"],
- Jk = LD.extend({
- type: "singleAxis",
- axisPointerClass: "SingleAxisPointer",
- render: function(t, e, i, n) {
- var o = this.group;
- o.removeAll();
- var a = Ug(t),
- r = new ID(t, a);
- d($k, r.add, r), o.add(r.getGroup()), t.get("splitLine.show") && this._splitLine(t), Jk.superCall(this, "render",
- t, e, i, n)
- },
- _splitLine: function(t) {
- var e = t.axis;
- if (!e.scale.isBlank()) {
- var i = t.getModel("splitLine"),
- n = i.getModel("lineStyle"),
- o = n.get("width"),
- a = n.get("color");
- a = a instanceof Array ? a : [a];
- for (var r = t.coordinateSystem.getRect(), s = e.isHorizontal(), l = [], u = 0, h = e.getTicksCoords({
- tickModel: i
- }), c = [], d = [], f = 0; f < h.length; ++f) {
- var p = e.toGlobalCoord(h[f].coord);
- s ? (c[0] = p, c[1] = r.y, d[0] = p, d[1] = r.y + r.height) : (c[0] = r.x, c[1] = p, d[0] = r.x + r.width, d[1] =
- p);
- var g = u++ % a.length;
- l[g] = l[g] || [], l[g].push(new rM(Xn({
- shape: {
- x1: c[0],
- y1: c[1],
- x2: d[0],
- y2: d[1]
- },
- style: {
- lineWidth: o
- },
- silent: !0
- })))
- }
- for (f = 0; f < l.length; ++f) this.group.add(xM(l[f], {
- style: {
- stroke: a[f % a.length],
- lineDash: n.getLineDash(o),
- lineWidth: o
- },
- silent: !0
- }))
- }
- }
- }),
- Qk = YM.extend({
- type: "singleAxis",
- layoutMode: "box",
- axis: null,
- coordinateSystem: null,
- getCoordSysModel: function() {
- return this
- }
- }),
- tP = {
- left: "5%",
- top: "5%",
- right: "5%",
- bottom: "5%",
- type: "value",
- position: "bottom",
- orient: "horizontal",
- axisLine: {
- show: !0,
- lineStyle: {
- width: 2,
- type: "solid"
- }
- },
- tooltip: {
- show: !0
- },
- axisTick: {
- show: !0,
- length: 6,
- lineStyle: {
- width: 2
- }
- },
- axisLabel: {
- show: !0,
- interval: "auto"
- },
- splitLine: {
- show: !0,
- lineStyle: {
- type: "dashed",
- opacity: .2
- }
- }
- };
- n(Qk.prototype, CA), xD("single", Qk, function(t, e) {
- return e.type || (e.data ? "category" : "value")
- }, tP);
- var eP = function(t, e) {
- var i, n = [],
- o = t.seriesIndex;
- if (null == o || !(i = e.getSeriesByIndex(o))) return {
- point: []
- };
- var a = i.getData(),
- r = zi(a, t);
- if (null == r || r < 0 || y(r)) return {
- point: []
- };
- var s = a.getItemGraphicEl(r),
- l = i.coordinateSystem;
- if (i.getTooltipPosition) n = i.getTooltipPosition(r) || [];
- else if (l && l.dataToPoint) n = l.dataToPoint(a.getValues(f(l.dimensions, function(t) {
- return a.mapDimension(t)
- }), r, !0)) || [];
- else if (s) {
- var u = s.getBoundingRect().clone();
- u.applyTransform(s.transform), n = [u.x + u.width / 2, u.y + u.height / 2]
- }
- return {
- point: n,
- el: s
- }
- },
- iP = d,
- nP = v,
- oP = Bi(),
- aP = (Bs({
- type: "axisPointer",
- coordSysAxesInfo: null,
- defaultOption: {
- show: "auto",
- triggerOn: null,
- zlevel: 0,
- z: 50,
- type: "line",
- snap: !1,
- triggerTooltip: !0,
- value: null,
- status: null,
- link: [],
- animation: null,
- animationDurationUpdate: 200,
- lineStyle: {
- color: "#aaa",
- width: 1,
- type: "solid"
- },
- shadowStyle: {
- color: "rgba(150,150,150,0.3)"
- },
- label: {
- show: !0,
- formatter: null,
- precision: "auto",
- margin: 3,
- color: "#fff",
- padding: [5, 7, 5, 7],
- backgroundColor: "auto",
- borderColor: null,
- borderWidth: 0,
- shadowBlur: 3,
- shadowColor: "#aaa"
- },
- handle: {
- show: !1,
- icon: "M10.7,11.9v-1.3H9.3v1.3c-4.9,0.3-8.8,4.4-8.8,9.4c0,5,3.9,9.1,8.8,9.4h1.3c4.9-0.3,8.8-4.4,8.8-9.4C19.5,16.3,15.6,12.2,10.7,11.9z M13.3,24.4H6.7v-1.2h6.6z M13.3,22H6.7v-1.2h6.6z M13.3,19.6H6.7v-1.2h6.6z",
- size: 45,
- margin: 50,
- color: "#333",
- shadowBlur: 3,
- shadowColor: "#aaa",
- shadowOffsetX: 0,
- shadowOffsetY: 2,
- throttle: 40
- }
- }
- }), Bi()),
- rP = d,
- sP = Vs({
- type: "axisPointer",
- render: function(t, e, i) {
- var n = e.getComponent("tooltip"),
- o = t.get("triggerOn") || n && n.get("triggerOn") || "mousemove|click";
- im("axisPointer", i, function(t, e, i) {
- "none" !== o && ("leave" === t || o.indexOf(t) >= 0) && i({
- type: "updateAxisPointer",
- currTrigger: t,
- x: e && e.offsetX,
- y: e && e.offsetY
- })
- })
- },
- remove: function(t, e) {
- lm(e.getZr(), "axisPointer"), sP.superApply(this._model, "remove", arguments)
- },
- dispose: function(t, e) {
- lm("axisPointer", e), sP.superApply(this._model, "dispose", arguments)
- }
- }),
- lP = Bi(),
- uP = i,
- hP = m;
- (um.prototype = {
- _group: null,
- _lastGraphicKey: null,
- _handle: null,
- _dragging: !1,
- _lastValue: null,
- _lastStatus: null,
- _payloadInfo: null,
- animationThreshold: 15,
- render: function(t, e, i, n) {
- var o = e.get("value"),
- a = e.get("status");
- if (this._axisModel = t, this._axisPointerModel = e, this._api = i, n || this._lastValue !== o || this._lastStatus !==
- a) {
- this._lastValue = o, this._lastStatus = a;
- var r = this._group,
- s = this._handle;
- if (!a || "hide" === a) return r && r.hide(), void(s && s.hide());
- r && r.show(), s && s.show();
- var l = {};
- this.makeElOption(l, o, t, e, i);
- var u = l.graphicKey;
- u !== this._lastGraphicKey && this.clear(i), this._lastGraphicKey = u;
- var h = this._moveAnimation = this.determineAnimation(t, e);
- if (r) {
- var c = v(hm, e, h);
- this.updatePointerEl(r, l, c, e), this.updateLabelEl(r, l, c, e)
- } else r = this._group = new Zw, this.createPointerEl(r, l, t, e), this.createLabelEl(r, l, t, e), i.getZr().add(
- r);
- pm(r, e, !0), this._renderHandle(o)
- }
- },
- remove: function(t) {
- this.clear(t)
- },
- dispose: function(t) {
- this.clear(t)
- },
- determineAnimation: function(t, e) {
- var i = e.get("animation"),
- n = t.axis,
- o = "category" === n.type,
- a = e.get("snap");
- if (!a && !o) return !1;
- if ("auto" === i || null == i) {
- var r = this.animationThreshold;
- if (o && n.getBandWidth() > r) return !0;
- if (a) {
- var s = xh(t).seriesDataCount,
- l = n.getExtent();
- return Math.abs(l[0] - l[1]) / s > r
- }
- return !1
- }
- return !0 === i
- },
- makeElOption: function(t, e, i, n, o) {},
- createPointerEl: function(t, e, i, n) {
- var o = e.pointer;
- if (o) {
- var a = lP(t).pointerEl = new bM[o.type](uP(e.pointer));
- t.add(a)
- }
- },
- createLabelEl: function(t, e, i, n) {
- if (e.label) {
- var o = lP(t).labelEl = new aM(uP(e.label));
- t.add(o), dm(o, n)
- }
- },
- updatePointerEl: function(t, e, i) {
- var n = lP(t).pointerEl;
- n && (n.setStyle(e.pointer.style), i(n, {
- shape: e.pointer.shape
- }))
- },
- updateLabelEl: function(t, e, i, n) {
- var o = lP(t).labelEl;
- o && (o.setStyle(e.label.style), i(o, {
- shape: e.label.shape,
- position: e.label.position
- }), dm(o, n))
- },
- _renderHandle: function(t) {
- if (!this._dragging && this.updateHandleTransform) {
- var e = this._axisPointerModel,
- i = this._api.getZr(),
- n = this._handle,
- o = e.getModel("handle"),
- a = e.get("status");
- if (!o.get("show") || !a || "hide" === a) return n && i.remove(n), void(this._handle = null);
- var r;
- this._handle || (r = !0, n = this._handle = Co(o.get("icon"), {
- cursor: "move",
- draggable: !0,
- onmousemove: function(t) {
- lw(t.event)
- },
- onmousedown: hP(this._onHandleDragMove, this, 0, 0),
- drift: hP(this._onHandleDragMove, this),
- ondragend: hP(this._onHandleDragEnd, this)
- }), i.add(n)), pm(n, e, !1);
- var s = ["color", "borderColor", "borderWidth", "opacity", "shadowColor", "shadowBlur", "shadowOffsetX",
- "shadowOffsetY"
- ];
- n.setStyle(o.getItemStyle(null, s));
- var l = o.get("size");
- y(l) || (l = [l, l]), n.attr("scale", [l[0] / 2, l[1] / 2]), Lr(this, "_doDispatchAxisPointer", o.get("throttle") ||
- 0, "fixRate"), this._moveHandleToValue(t, r)
- }
- },
- _moveHandleToValue: function(t, e) {
- hm(this._axisPointerModel, !e && this._moveAnimation, this._handle, fm(this.getHandleTransform(t, this._axisModel,
- this._axisPointerModel)))
- },
- _onHandleDragMove: function(t, e) {
- var i = this._handle;
- if (i) {
- this._dragging = !0;
- var n = this.updateHandleTransform(fm(i), [t, e], this._axisModel, this._axisPointerModel);
- this._payloadInfo = n, i.stopAnimation(), i.attr(fm(n)), lP(i).lastProp = null, this._doDispatchAxisPointer()
- }
- },
- _doDispatchAxisPointer: function() {
- if (this._handle) {
- var t = this._payloadInfo,
- e = this._axisModel;
- this._api.dispatchAction({
- type: "updateAxisPointer",
- x: t.cursorPoint[0],
- y: t.cursorPoint[1],
- tooltipOption: t.tooltipOption,
- axesInfo: [{
- axisDim: e.axis.dim,
- axisIndex: e.componentIndex
- }]
- })
- }
- },
- _onHandleDragEnd: function(t) {
- if (this._dragging = !1, this._handle) {
- var e = this._axisPointerModel.get("value");
- this._moveHandleToValue(e), this._api.dispatchAction({
- type: "hideTip"
- })
- }
- },
- getHandleTransform: null,
- updateHandleTransform: null,
- clear: function(t) {
- this._lastValue = null, this._lastStatus = null;
- var e = t.getZr(),
- i = this._group,
- n = this._handle;
- e && i && (this._lastGraphicKey = null, i && e.remove(i), n && e.remove(n), this._group = null, this._handle =
- null, this._payloadInfo = null)
- },
- doClear: function() {},
- buildLabel: function(t, e, i) {
- return i = i || 0, {
- x: t[i],
- y: t[1 - i],
- width: e[i],
- height: e[1 - i]
- }
- }
- }).constructor = um, Xi(um);
- var cP = um.extend({
- makeElOption: function(t, e, i, n, o) {
- var a = i.axis,
- r = a.grid,
- s = n.get("type"),
- l = Mm(r, a).getOtherAxis(a).getGlobalExtent(),
- u = a.toGlobalCoord(a.dataToCoord(e, !0));
- if (s && "none" !== s) {
- var h = gm(n),
- c = dP[s](a, u, l, h);
- c.style = h, t.graphicKey = c.type, t.pointer = c
- }
- _m(e, t, Ih(r.model, i), i, n, o)
- },
- getHandleTransform: function(t, e, i) {
- var n = Ih(e.axis.grid.model, e, {
- labelInside: !1
- });
- return n.labelMargin = i.get("handle.margin"), {
- position: xm(e.axis, t, n),
- rotation: n.rotation + (n.labelDirection < 0 ? Math.PI : 0)
- }
- },
- updateHandleTransform: function(t, e, i, n) {
- var o = i.axis,
- a = o.grid,
- r = o.getGlobalExtent(!0),
- s = Mm(a, o).getOtherAxis(o).getGlobalExtent(),
- l = "x" === o.dim ? 0 : 1,
- u = t.position;
- u[l] += e[l], u[l] = Math.min(r[1], u[l]), u[l] = Math.max(r[0], u[l]);
- var h = (s[1] + s[0]) / 2,
- c = [h, h];
- c[l] = u[l];
- var d = [{
- verticalAlign: "middle"
- }, {
- align: "center"
- }];
- return {
- position: u,
- rotation: t.rotation,
- cursorPoint: c,
- tooltipOption: d[l]
- }
- }
- }),
- dP = {
- line: function(t, e, i, n) {
- var o = wm([e, i[0]], [e, i[1]], Im(t));
- return Xn({
- shape: o,
- style: n
- }), {
- type: "Line",
- shape: o
- }
- },
- shadow: function(t, e, i, n) {
- var o = Math.max(1, t.getBandWidth()),
- a = i[1] - i[0];
- return {
- type: "Rect",
- shape: bm([e - o / 2, i[0]], [o, a], Im(t))
- }
- }
- };
- LD.registerAxisPointerClass("CartesianAxisPointer", cP), Ls(function(t) {
- if (t) {
- (!t.axisPointer || 0 === t.axisPointer.length) && (t.axisPointer = {});
- var e = t.axisPointer.link;
- e && !y(e) && (t.axisPointer.link = [e])
- }
- }), ks(IT.PROCESSOR.STATISTIC, function(t, e) {
- t.getComponent("axisPointer").coordSysAxesInfo = dh(t, e)
- }), Ps({
- type: "updateAxisPointer",
- event: "updateAxisPointer",
- update: ":updateAxisPointer"
- }, function(t, e, i) {
- var n = t.currTrigger,
- o = [t.x, t.y],
- a = t,
- r = t.dispatchAction || m(i.dispatchAction, i),
- s = e.getComponent("axisPointer").coordSysAxesInfo;
- if (s) {
- em(o) && (o = eP({
- seriesIndex: a.seriesIndex,
- dataIndex: a.dataIndex
- }, e).point);
- var l = em(o),
- u = a.axesInfo,
- h = s.axesInfo,
- c = "leave" === n || em(o),
- d = {},
- f = {},
- p = {
- list: [],
- map: {}
- },
- g = {
- showPointer: nP(Yg, f),
- showTooltip: nP(qg, p)
- };
- iP(s.coordSysMap, function(t, e) {
- var i = l || t.containPoint(o);
- iP(s.coordSysAxesInfo[e], function(t, e) {
- var n = t.axis,
- a = Qg(u, t);
- if (!c && i && (!u || a)) {
- var r = a && a.value;
- null != r || l || (r = n.pointToData(o)), null != r && Xg(t, r, g, !1, d)
- }
- })
- });
- var v = {};
- return iP(h, function(t, e) {
- var i = t.linkGroup;
- i && !f[e] && iP(i.axesInfo, function(e, n) {
- var o = f[n];
- if (e !== t && o) {
- var a = o.value;
- i.mapper && (a = t.axis.scale.parse(i.mapper(a, tm(e), tm(t)))), v[t.key] = a
- }
- })
- }), iP(v, function(t, e) {
- Xg(h[e], t, g, !0, d)
- }), Kg(f, h, d), $g(p, o, t, r), Jg(h, 0, i), d
- }
- });
- var fP = ["x", "y"],
- pP = ["width", "height"],
- gP = um.extend({
- makeElOption: function(t, e, i, n, o) {
- var a = i.axis,
- r = a.coordinateSystem,
- s = Am(r, 1 - Tm(a)),
- l = r.dataToPoint(e)[0],
- u = n.get("type");
- if (u && "none" !== u) {
- var h = gm(n),
- c = mP[u](a, l, s, h);
- c.style = h, t.graphicKey = c.type, t.pointer = c
- }
- _m(e, t, Ug(i), i, n, o)
- },
- getHandleTransform: function(t, e, i) {
- var n = Ug(e, {
- labelInside: !1
- });
- return n.labelMargin = i.get("handle.margin"), {
- position: xm(e.axis, t, n),
- rotation: n.rotation + (n.labelDirection < 0 ? Math.PI : 0)
- }
- },
- updateHandleTransform: function(t, e, i, n) {
- var o = i.axis,
- a = o.coordinateSystem,
- r = Tm(o),
- s = Am(a, r),
- l = t.position;
- l[r] += e[r], l[r] = Math.min(s[1], l[r]), l[r] = Math.max(s[0], l[r]);
- var u = Am(a, 1 - r),
- h = (u[1] + u[0]) / 2,
- c = [h, h];
- return c[r] = l[r], {
- position: l,
- rotation: t.rotation,
- cursorPoint: c,
- tooltipOption: {
- verticalAlign: "middle"
- }
- }
- }
- }),
- mP = {
- line: function(t, e, i, n) {
- var o = wm([e, i[0]], [e, i[1]], Tm(t));
- return Xn({
- shape: o,
- style: n
- }), {
- type: "Line",
- shape: o
- }
- },
- shadow: function(t, e, i, n) {
- var o = t.getBandWidth(),
- a = i[1] - i[0];
- return {
- type: "Rect",
- shape: bm([e - o / 2, i[0]], [o, a], Tm(t))
- }
- }
- };
- LD.registerAxisPointerClass("SingleAxisPointer", gP), Vs({
- type: "single"
- });
- var vP = OI.extend({
- type: "series.themeRiver",
- dependencies: ["singleAxis"],
- nameMap: null,
- init: function(t) {
- vP.superApply(this, "init", arguments), this.legendDataProvider = function() {
- return this.getRawData()
- }
- },
- fixData: function(t) {
- for (var e = t.length, i = f(Lp().key(function(t) {
- return t[2]
- }).entries(t), function(t) {
- return {
- name: t.key,
- dataList: t.values
- }
- }), n = i.length, o = -1, a = -1, r = 0; r < n; ++r) {
- var s = i[r].dataList.length;
- s > o && (o = s, a = r)
- }
- for (var l = 0; l < n; ++l)
- if (l !== a)
- for (var u = i[l].name, h = 0; h < o; ++h) {
- for (var c = i[a].dataList[h][0], d = i[l].dataList.length, p = -1, g = 0; g < d; ++g)
- if (i[l].dataList[g][0] === c) {
- p = g;
- break
- } - 1 === p && (t[e] = [], t[e][0] = c, t[e][1] = 0, t[e][2] = u, e++)
- }
- return t
- },
- getInitialData: function(t, e) {
- for (var i = e.queryComponents({
- mainType: "singleAxis",
- index: this.get("singleAxisIndex"),
- id: this.get("singleAxisId")
- })[0].get("type"), n = g(t.data, function(t) {
- return void 0 !== t[2]
- }), o = this.fixData(n || []), a = [], r = this.nameMap = R(), s = 0, l = 0; l < o.length; ++l) a.push(o[l][2]),
- r.get(o[l][2]) || (r.set(o[l][2], s), s++);
- var u = oA(o, {
- coordDimensions: ["single"],
- dimensionsDefine: [{
- name: "time",
- type: Xs(i)
- }, {
- name: "value",
- type: "float"
- }, {
- name: "name",
- type: "ordinal"
- }],
- encodeDefine: {
- single: 0,
- value: 1,
- itemName: 2
- }
- }),
- h = new eA(u, this);
- return h.initData(o), h
- },
- getLayerSeries: function() {
- for (var t = this.getData(), e = t.count(), i = [], n = 0; n < e; ++n) i[n] = n;
- for (var o = f(Lp().key(function(e) {
- return t.get("name", e)
- }).entries(i), function(t) {
- return {
- name: t.key,
- indices: t.values
- }
- }), a = t.mapDimension("single"), r = 0; r < o.length; ++r) o[r].indices.sort(function(e, i) {
- return t.get(a, e) - t.get(a, i)
- });
- return o
- },
- getAxisTooltipData: function(t, e, i) {
- y(t) || (t = t ? [t] : []);
- for (var n, o = this.getData(), a = this.getLayerSeries(), r = [], s = a.length, l = 0; l < s; ++l) {
- for (var u = Number.MAX_VALUE, h = -1, c = a[l].indices.length, d = 0; d < c; ++d) {
- var f = o.get(t[0], a[l].indices[d]),
- p = Math.abs(f - e);
- p <= u && (n = f, u = p, h = a[l].indices[d])
- }
- r.push(h)
- }
- return {
- dataIndices: r,
- nestestValue: n
- }
- },
- formatTooltip: function(t) {
- var e = this.getData(),
- i = e.getName(t),
- n = e.get(e.mapDimension("value"), t);
- return (isNaN(n) || null == n) && (n = "-"), Qo(i + " : " + n)
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- coordinateSystem: "singleAxis",
- boundaryGap: ["10%", "10%"],
- singleAxisIndex: 0,
- animationEasing: "linear",
- label: {
- margin: 4,
- show: !0,
- position: "left",
- color: "#000",
- fontSize: 11
- },
- emphasis: {
- label: {
- show: !0
- }
- }
- }
- });
- Fs({
- type: "themeRiver",
- init: function() {
- this._layers = []
- },
- render: function(t, e, i) {
- function n(t) {
- return t.name
- }
- function o(e, i, n) {
- var o = this._layers;
- if ("remove" !== e) {
- for (var u, h = [], c = [], f = l[i].indices, p = 0; p < f.length; p++) {
- var g = r.getItemLayout(f[p]),
- m = g.x,
- v = g.y0,
- y = g.y;
- h.push([m, v]), c.push([m, v + y]), u = r.getItemVisual(f[p], "color")
- }
- var x, _, w = r.getItemLayout(f[0]),
- b = r.getItemModel(f[p - 1]),
- S = b.getModel("label"),
- M = S.get("margin");
- if ("add" === e) {
- I = d[i] = new Zw;
- x = new uD({
- shape: {
- points: h,
- stackedOnPoints: c,
- smooth: .4,
- stackedOnSmooth: .4,
- smoothConstraint: !1
- },
- z2: 0
- }), _ = new qS({
- style: {
- x: w.x - M,
- y: w.y0 + w.y / 2
- }
- }), I.add(x), I.add(_), s.add(I), x.setClipPath(Dm(x.getBoundingRect(), t, function() {
- x.removeClipPath()
- }))
- } else {
- var I = o[n];
- x = I.childAt(0), _ = I.childAt(1), s.add(I), d[i] = I, bo(x, {
- shape: {
- points: h,
- stackedOnPoints: c
- }
- }, t), bo(_, {
- style: {
- x: w.x - M,
- y: w.y0 + w.y / 2
- }
- }, t)
- }
- var T = b.getModel("emphasis.itemStyle"),
- A = b.getModel("itemStyle");
- fo(_.style, S, {
- text: S.get("show") ? t.getFormattedLabel(f[p - 1], "normal") || r.getName(f[p - 1]) : null,
- textVerticalAlign: "middle"
- }), x.setStyle(a({
- fill: u
- }, A.getItemStyle(["color"]))), uo(x, T.getItemStyle())
- } else s.remove(o[i])
- }
- var r = t.getData(),
- s = this.group,
- l = t.getLayerSeries(),
- u = r.getLayout("layoutInfo"),
- h = u.rect,
- c = u.boundaryGap;
- s.attr("position", [0, h.y + c[0]]);
- var d = {};
- new Hs(this._layersSeries || [], l, n, n).add(m(o, this, "add")).update(m(o, this, "update")).remove(m(o, this,
- "remove")).execute(), this._layersSeries = l, this._layers = d
- },
- dispose: function() {}
- });
- Os(function(t, e) {
- t.eachSeriesByType("themeRiver", function(t) {
- var e = t.getData(),
- i = t.coordinateSystem,
- n = {},
- o = i.getRect();
- n.rect = o;
- var a = t.get("boundaryGap"),
- r = i.getAxis();
- n.boundaryGap = a, "horizontal" === r.orient ? (a[0] = Ro(a[0], o.height), a[1] = Ro(a[1], o.height), Cm(e, t,
- o.height - a[0] - a[1])) : (a[0] = Ro(a[0], o.width), a[1] = Ro(a[1], o.width), Cm(e, t, o.width - a[0] - a[1])),
- e.setLayout("layoutInfo", n)
- })
- }), Es(function(t) {
- t.eachSeriesByType("themeRiver", function(t) {
- var e = t.getData(),
- i = t.getRawData(),
- n = t.get("color"),
- o = R();
- e.each(function(t) {
- o.set(e.getRawIndex(t), t)
- }), i.each(function(a) {
- var r = i.getName(a),
- s = n[(t.nameMap.get(r) - 1) % n.length];
- i.setItemVisual(a, "color", s);
- var l = o.get(a);
- null != l && e.setItemVisual(l, "color", s)
- })
- })
- }), ks($D("themeRiver")), OI.extend({
- type: "series.sunburst",
- _viewRoot: null,
- getInitialData: function(t, e) {
- var i = {
- name: t.name,
- children: t.data
- };
- km(i);
- var n = t.levels || [],
- o = {};
- return o.levels = n, kc.createTree(i, this, o).data
- },
- optionUpdated: function() {
- this.resetViewRoot()
- },
- getDataParams: function(t) {
- var e = OI.prototype.getDataParams.apply(this, arguments),
- i = this.getData().tree.getNodeByDataIndex(t);
- return e.treePathInfo = nd(i, this), e
- },
- defaultOption: {
- zlevel: 0,
- z: 2,
- center: ["50%", "50%"],
- radius: [0, "75%"],
- clockwise: !0,
- startAngle: 90,
- minAngle: 0,
- percentPrecision: 2,
- stillShowZeroSum: !0,
- highlightPolicy: "descendant",
- nodeClick: "rootToNode",
- renderLabelForZeroData: !1,
- label: {
- rotate: "radial",
- show: !0,
- opacity: 1,
- align: "center",
- position: "inside",
- distance: 5,
- silent: !0,
- emphasis: {}
- },
- itemStyle: {
- borderWidth: 1,
- borderColor: "white",
- borderType: "solid",
- shadowBlur: 0,
- shadowColor: "rgba(0, 0, 0, 0.2)",
- shadowOffsetX: 0,
- shadowOffsetY: 0,
- opacity: 1,
- emphasis: {},
- highlight: {
- opacity: 1
- },
- downplay: {
- opacity: .9
- }
- },
- animationType: "expansion",
- animationDuration: 1e3,
- animationDurationUpdate: 500,
- animationEasing: "cubicOut",
- data: [],
- levels: [],
- sort: "desc"
- },
- getViewRoot: function() {
- return this._viewRoot
- },
- resetViewRoot: function(t) {
- t ? this._viewRoot = t : t = this._viewRoot;
- var e = this.getRawData().tree.root;
- t && (t === e || e.contains(t)) || (this._viewRoot = e)
- }
- });
- var yP = {
- NONE: "none",
- DESCENDANT: "descendant",
- ANCESTOR: "ancestor",
- SELF: "self"
- },
- xP = 2,
- _P = 4,
- wP = Pm.prototype;
- wP.updateData = function(t, e, i, o, s) {
- this.node = e, e.piece = this, o = o || this._seriesModel, s = s || this._ecModel;
- var l = this.childAt(0);
- l.dataIndex = e.dataIndex;
- var u = e.getModel(),
- h = e.getLayout();
- h || console.log(e.getLayout());
- var c = a({}, h);
- c.label = null;
- var d, f = Nm(e, 0, s),
- p = u.getModel("itemStyle").getItemStyle();
- d = r({
- lineJoin: "bevel",
- fill: (d = "normal" === i ? p : n(u.getModel(i + ".itemStyle").getItemStyle(), p)).fill || f
- }, d), t ? (l.setShape(c), l.shape.r = h.r0, bo(l, {
- shape: {
- r: h.r
- }
- }, o, e.dataIndex), l.useStyle(d)) : "object" == typeof d.fill && d.fill.type || "object" == typeof l.style.fill &&
- l.style.fill.type ? (bo(l, {
- shape: c
- }, o), l.useStyle(d)) : bo(l, {
- shape: c,
- style: d
- }, o), this._updateLabel(o, f, i);
- var g = u.getShallow("cursor");
- if (g && l.attr("cursor", g), t) {
- var m = o.getShallow("highlightPolicy");
- this._initEvents(l, e, o, m)
- }
- this._seriesModel = o || this._seriesModel, this._ecModel = s || this._ecModel
- }, wP.onEmphasis = function(t) {
- var e = this;
- this.node.hostTree.root.eachNode(function(i) {
- i.piece && (e.node === i ? i.piece.updateData(!1, i, "emphasis") : Em(i, e.node, t) ? i.piece.childAt(0).trigger(
- "highlight") : t !== yP.NONE && i.piece.childAt(0).trigger("downplay"))
- })
- }, wP.onNormal = function() {
- this.node.hostTree.root.eachNode(function(t) {
- t.piece && t.piece.updateData(!1, t, "normal")
- })
- }, wP.onHighlight = function() {
- this.updateData(!1, this.node, "highlight")
- }, wP.onDownplay = function() {
- this.updateData(!1, this.node, "downplay")
- }, wP._updateLabel = function(t, e, i) {
- function n(t) {
- var e = r.get(t);
- return null == e ? a.get(t) : e
- }
- var o = this.node.getModel(),
- a = o.getModel("label"),
- r = "normal" === i || "emphasis" === i ? a : o.getModel(i + ".label"),
- s = o.getModel("emphasis.label"),
- l = T(t.getFormattedLabel(this.node.dataIndex, "normal", null, null, "label"), this.node.name);
- !1 === n("show") && (l = "");
- var u = this.node.getLayout(),
- h = r.get("minAngle");
- null == h && (h = a.get("minAngle")), h = h / 180 * Math.PI;
- var c = u.endAngle - u.startAngle;
- null != h && Math.abs(c) < h && (l = "");
- var d = this.childAt(1);
- co(d.style, d.hoverStyle || {}, a, s, {
- defaultText: r.getShallow("show") ? l : null,
- autoColor: e,
- useInsideStyle: !0
- });
- var f, p = (u.startAngle + u.endAngle) / 2,
- g = Math.cos(p),
- m = Math.sin(p),
- v = n("position"),
- y = n("distance") || 0,
- x = n("align");
- "outside" === v ? (f = u.r + y, x = p > Math.PI / 2 ? "right" : "left") : x && "center" !== x ? "left" === x ? (f =
- u.r0 + y, p > Math.PI / 2 && (x = "right")) : "right" === x && (f = u.r - y, p > Math.PI / 2 && (x = "left")) : (
- f = (u.r + u.r0) / 2, x = "center"), d.attr("style", {
- text: l,
- textAlign: x,
- textVerticalAlign: n("verticalAlign") || "middle",
- opacity: n("opacity")
- });
- var _ = f * g + u.cx,
- w = f * m + u.cy;
- d.attr("position", [_, w]);
- var b = n("rotate"),
- S = 0;
- "radial" === b ? (S = -p) < -Math.PI / 2 && (S += Math.PI) : "tangential" === b ? (S = Math.PI / 2 - p) > Math.PI /
- 2 ? S -= Math.PI : S < -Math.PI / 2 && (S += Math.PI) : "number" == typeof b && (S = b * Math.PI / 180), d.attr(
- "rotation", S)
- }, wP._initEvents = function(t, e, i, n) {
- t.off("mouseover").off("mouseout").off("emphasis").off("normal");
- var o = this,
- a = function() {
- o.onEmphasis(n)
- },
- r = function() {
- o.onNormal()
- };
- i.isAnimationEnabled() && t.on("mouseover", a).on("mouseout", r).on("emphasis", a).on("normal", r).on("downplay",
- function() {
- o.onDownplay()
- }).on("highlight", function() {
- o.onHighlight()
- })
- }, u(Pm, Zw);
- Mr.extend({
- type: "sunburst",
- init: function() {},
- render: function(t, e, i, n) {
- function o(i, n) {
- if (c || !i || i.getValue() || (i = null), i !== l && n !== l)
- if (n && n.piece) i ? (n.piece.updateData(!1, i, "normal", t, e), s.setItemGraphicEl(i.dataIndex, n.piece)) :
- a(n);
- else if (i) {
- var o = new Pm(i, t, e);
- h.add(o), s.setItemGraphicEl(i.dataIndex, o)
- }
- }
- function a(t) {
- t && t.piece && (h.remove(t.piece), t.piece = null)
- }
- var r = this;
- this.seriesModel = t, this.api = i, this.ecModel = e;
- var s = t.getData(),
- l = s.tree.root,
- u = t.getViewRoot(),
- h = this.group,
- c = t.get("renderLabelForZeroData"),
- d = [];
- u.eachNode(function(t) {
- d.push(t)
- });
- var f = this._oldChildren || [];
- if (function(t, e) {
- function i(t) {
- return t.getId()
- }
- function n(i, n) {
- o(null == i ? null : t[i], null == n ? null : e[n])
- }
- 0 === t.length && 0 === e.length || new Hs(e, t, i, i).add(n).update(n).remove(v(n, null)).execute()
- }(d, f), function(i, n) {
- if (n.depth > 0) {
- r.virtualPiece ? r.virtualPiece.updateData(!1, i, "normal", t, e) : (r.virtualPiece = new Pm(i, t, e), h.add(
- r.virtualPiece)), n.piece._onclickEvent && n.piece.off("click", n.piece._onclickEvent);
- var o = function(t) {
- r._rootToNode(n.parentNode)
- };
- n.piece._onclickEvent = o, r.virtualPiece.on("click", o)
- } else r.virtualPiece && (h.remove(r.virtualPiece), r.virtualPiece = null)
- }(l, u), n && n.highlight && n.highlight.piece) {
- var p = t.getShallow("highlightPolicy");
- n.highlight.piece.onEmphasis(p)
- } else if (n && n.unhighlight) {
- var g = this.virtualPiece;
- !g && l.children.length && (g = l.children[0].piece), g && g.onNormal()
- }
- this._initEvents(), this._oldChildren = d
- },
- dispose: function() {},
- _initEvents: function() {
- var t = this,
- e = function(e) {
- var i = !1;
- t.seriesModel.getViewRoot().eachNode(function(n) {
- if (!i && n.piece && n.piece.childAt(0) === e.target) {
- var o = n.getModel().get("nodeClick");
- if ("rootToNode" === o) t._rootToNode(n);
- else if ("link" === o) {
- var a = n.getModel(),
- r = a.get("link");
- if (r) {
- var s = a.get("target", !0) || "_blank";
- window.open(r, s)
- }
- }
- i = !0
- }
- })
- };
- this.group._onclickEvent && this.group.off("click", this.group._onclickEvent), this.group.on("click", e), this.group
- ._onclickEvent = e
- },
- _rootToNode: function(t) {
- t !== this.seriesModel.getViewRoot() && this.api.dispatchAction({
- type: "sunburstRootToNode",
- from: this.uid,
- seriesId: this.seriesModel.id,
- targetNode: t
- })
- },
- containPoint: function(t, e) {
- var i = e.getData().getItemLayout(0);
- if (i) {
- var n = t[0] - i.cx,
- o = t[1] - i.cy,
- a = Math.sqrt(n * n + o * o);
- return a <= i.r && a >= i.r0
- }
- }
- });
- var bP = "sunburstRootToNode";
- Ps({
- type: bP,
- update: "updateView"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- subType: "sunburst",
- query: t
- }, function(e, i) {
- var n = td(t, [bP], e);
- if (n) {
- var o = e.getViewRoot();
- o && (t.direction = id(o, n.node) ? "rollUp" : "drillDown"), e.resetViewRoot(n.node)
- }
- })
- });
- var SP = "sunburstHighlight";
- Ps({
- type: SP,
- update: "updateView"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- subType: "sunburst",
- query: t
- }, function(e, i) {
- var n = td(t, [SP], e);
- n && (t.highlight = n.node)
- })
- });
- Ps({
- type: "sunburstUnhighlight",
- update: "updateView"
- }, function(t, e) {
- e.eachComponent({
- mainType: "series",
- subType: "sunburst",
- query: t
- }, function(e, i) {
- t.unhighlight = !0
- })
- });
- var MP = Math.PI / 180;
- Es(v(jD, "sunburst")), Os(v(function(t, e, i, n) {
- e.eachSeriesByType(t, function(t) {
- var e = t.get("center"),
- n = t.get("radius");
- y(n) || (n = [0, n]), y(e) || (e = [e, e]);
- var o = i.getWidth(),
- a = i.getHeight(),
- r = Math.min(o, a),
- s = Ro(e[0], o),
- l = Ro(e[1], a),
- u = Ro(n[0], r / 2),
- h = Ro(n[1], r / 2),
- c = -t.get("startAngle") * MP,
- f = t.get("minAngle") * MP,
- p = t.getData().tree.root,
- g = t.getViewRoot(),
- m = g.depth,
- v = t.get("sort");
- null != v && Rm(g, v);
- var x = 0;
- d(g.children, function(t) {
- !isNaN(t.getValue()) && x++
- });
- var _ = g.getValue(),
- w = Math.PI / (_ || x) * 2,
- b = g.depth > 0,
- S = g.height - (b ? -1 : 1),
- M = (h - u) / (S || 1),
- I = t.get("clockwise"),
- T = t.get("stillShowZeroSum"),
- A = I ? 1 : -1,
- D = function(t, e) {
- if (t) {
- var i = e;
- if (t !== p) {
- var n = t.getValue(),
- o = 0 === _ && T ? w : n * w;
- o < f && (o = f), i = e + A * o;
- var a = t.depth - m - (b ? -1 : 1),
- h = u + M * a,
- c = u + M * (a + 1),
- g = t.getModel();
- null != g.get("r0") && (h = Ro(g.get("r0"), r / 2)), null != g.get("r") && (c = Ro(g.get("r"), r / 2)), t.setLayout({
- angle: o,
- startAngle: e,
- endAngle: i,
- clockwise: I,
- cx: s,
- cy: l,
- r0: h,
- r: c
- })
- }
- if (t.children && t.children.length) {
- var v = 0;
- d(t.children, function(t) {
- v += D(t, e + v)
- })
- }
- return i - e
- }
- };
- if (b) {
- var C = u,
- L = u + M,
- k = 2 * Math.PI;
- p.setLayout({
- angle: k,
- startAngle: c,
- endAngle: c + k,
- clockwise: I,
- cx: s,
- cy: l,
- r0: C,
- r: L
- })
- }
- D(g, c)
- })
- }, "sunburst")), ks(v($D, "sunburst"));
- var IP = ["itemStyle"],
- TP = ["emphasis", "itemStyle"],
- AP = ["label"],
- DP = ["emphasis", "label"],
- CP = "e\0\0",
- LP = {
- cartesian2d: function(t) {
- var e = t.grid.getRect();
- return {
- coordSys: {
- type: "cartesian2d",
- x: e.x,
- y: e.y,
- width: e.width,
- height: e.height
- },
- api: {
- coord: function(e) {
- return t.dataToPoint(e)
- },
- size: m(Bm, t)
- }
- }
- },
- geo: function(t) {
- var e = t.getBoundingRect();
- return {
- coordSys: {
- type: "geo",
- x: e.x,
- y: e.y,
- width: e.width,
- height: e.height,
- zoom: t.getZoom()
- },
- api: {
- coord: function(e) {
- return t.dataToPoint(e)
- },
- size: m(Vm, t)
- }
- }
- },
- singleAxis: function(t) {
- var e = t.getRect();
- return {
- coordSys: {
- type: "singleAxis",
- x: e.x,
- y: e.y,
- width: e.width,
- height: e.height
- },
- api: {
- coord: function(e) {
- return t.dataToPoint(e)
- },
- size: m(Gm, t)
- }
- }
- },
- polar: function(t) {
- var e = t.getRadiusAxis(),
- i = t.getAngleAxis(),
- n = e.getExtent();
- return n[0] > n[1] && n.reverse(), {
- coordSys: {
- type: "polar",
- cx: t.cx,
- cy: t.cy,
- r: n[1],
- r0: n[0]
- },
- api: {
- coord: m(function(n) {
- var o = e.dataToRadius(n[0]),
- a = i.dataToAngle(n[1]),
- r = t.coordToPoint([o, a]);
- return r.push(o, a * Math.PI / 180), r
- }),
- size: m(Fm, t)
- }
- }
- },
- calendar: function(t) {
- var e = t.getRect(),
- i = t.getRangeInfo();
- return {
- coordSys: {
- type: "calendar",
- x: e.x,
- y: e.y,
- width: e.width,
- height: e.height,
- cellWidth: t.getCellWidth(),
- cellHeight: t.getCellHeight(),
- rangeInfo: {
- start: i.start,
- end: i.end,
- weeks: i.weeks,
- dayCount: i.allDay
- }
- },
- api: {
- coord: function(e, i) {
- return t.dataToPoint(e, i)
- }
- }
- }
- }
- };
- OI.extend({
- type: "series.custom",
- dependencies: ["grid", "polar", "geo", "singleAxis", "calendar"],
- defaultOption: {
- coordinateSystem: "cartesian2d",
- zlevel: 0,
- z: 2,
- legendHoverLink: !0,
- useTransform: !0
- },
- getInitialData: function(t, e) {
- return dl(this.getSource(), this)
- },
- getDataParams: function(t, e, i) {
- var n = OI.prototype.getDataParams.apply(this, arguments);
- return i && (n.info = i.info), n
- }
- }), Mr.extend({
- type: "custom",
- _data: null,
- render: function(t, e, i, n) {
- var o = this._data,
- a = t.getData(),
- r = this.group,
- s = Um(t, a, e, i);
- a.diff(o).add(function(e) {
- jm(null, e, s(e, n), t, r, a)
- }).update(function(e, i) {
- jm(o.getItemGraphicEl(i), e, s(e, n), t, r, a)
- }).remove(function(t) {
- var e = o.getItemGraphicEl(t);
- e && r.remove(e)
- }).execute(), this._data = a
- },
- incrementalPrepareRender: function(t, e, i) {
- this.group.removeAll(), this._data = null
- },
- incrementalRender: function(t, e, i, n, o) {
- for (var a = e.getData(), r = Um(e, a, i, n), s = t.start; s < t.end; s++) jm(null, s, r(s, o), e, this.group, a)
- .traverse(function(t) {
- t.isGroup || (t.incremental = !0, t.useHoverLayer = !0)
- })
- },
- dispose: B,
- filterForExposedEvent: function(t, e, i, n) {
- var o = e.element;
- if (null == o || i.name === o) return !0;
- for (;
- (i = i.parent) && i !== this.group;)
- if (i.name === o) return !0;
- return !1
- }
- }), Ls(function(t) {
- var e = t.graphic;
- y(e) ? e[0] && e[0].elements ? t.graphic = [t.graphic[0]] : t.graphic = [{
- elements: e
- }] : e && !e.elements && (t.graphic = [{
- elements: [e]
- }])
- });
- var kP = Bs({
- type: "graphic",
- defaultOption: {
- elements: [],
- parentId: null
- },
- _elOptionsToUpdate: null,
- mergeOption: function(t) {
- var e = this.option.elements;
- this.option.elements = null, kP.superApply(this, "mergeOption", arguments), this.option.elements = e
- },
- optionUpdated: function(t, e) {
- var i = this.option,
- n = (e ? i : t).elements,
- o = i.elements = e ? [] : i.elements,
- a = [];
- this._flatten(n, a);
- var r = Pi(o, a);
- Ni(r);
- var s = this._elOptionsToUpdate = [];
- d(r, function(t, e) {
- var i = t.option;
- i && (s.push(i), sv(t, i), lv(o, e, i), uv(o[e], i))
- }, this);
- for (var l = o.length - 1; l >= 0; l--) null == o[l] ? o.splice(l, 1) : delete o[l].$action
- },
- _flatten: function(t, e, i) {
- d(t, function(t) {
- if (t) {
- i && (t.parentOption = i), e.push(t);
- var n = t.children;
- "group" === t.type && n && this._flatten(n, e, t), delete t.children
- }
- }, this)
- },
- useElOptionsToUpdate: function() {
- var t = this._elOptionsToUpdate;
- return this._elOptionsToUpdate = null, t
- }
- });
- Vs({
- type: "graphic",
- init: function(t, e) {
- this._elMap = R(), this._lastGraphicModel
- },
- render: function(t, e, i) {
- t !== this._lastGraphicModel && this._clear(), this._lastGraphicModel = t, this._updateElements(t), this._relocate(
- t, i)
- },
- _updateElements: function(t) {
- var e = t.useElOptionsToUpdate();
- if (e) {
- var i = this._elMap,
- n = this.group;
- d(e, function(e) {
- var o = e.$action,
- a = e.id,
- r = i.get(a),
- s = e.parentId,
- l = null != s ? i.get(s) : n,
- u = e.style;
- "text" === e.type && u && (e.hv && e.hv[1] && (u.textVerticalAlign = u.textBaseline = null), !u.hasOwnProperty(
- "textFill") && u.fill && (u.textFill = u.fill), !u.hasOwnProperty("textStroke") && u.stroke && (u.textStroke =
- u.stroke));
- var h = av(e);
- o && "merge" !== o ? "replace" === o ? (ov(r, i), nv(a, l, h, i)) : "remove" === o && ov(r, i) : r ? r.attr(
- h) : nv(a, l, h, i);
- var c = i.get(a);
- c && (c.__ecGraphicWidth = e.width, c.__ecGraphicHeight = e.height, hv(c, t))
- })
- }
- },
- _relocate: function(t, e) {
- for (var i = t.option.elements, n = this.group, o = this._elMap, a = i.length - 1; a >= 0; a--) {
- var r = i[a],
- s = o.get(r.id);
- if (s) {
- var l = s.parent;
- ua(s, r, l === n ? {
- width: e.getWidth(),
- height: e.getHeight()
- } : {
- width: l.__ecGraphicWidth || 0,
- height: l.__ecGraphicHeight || 0
- }, null, {
- hv: r.hv,
- boundingMode: r.bounding
- })
- }
- }
- },
- _clear: function() {
- var t = this._elMap;
- t.each(function(e) {
- ov(e, t)
- }), this._elMap = R()
- },
- dispose: function() {
- this._clear()
- }
- });
- var PP = Bs({
- type: "legend.plain",
- dependencies: ["series"],
- layoutMode: {
- type: "box",
- ignoreSize: !0
- },
- init: function(t, e, i) {
- this.mergeDefaultAndTheme(t, i), t.selected = t.selected || {}
- },
- mergeOption: function(t) {
- PP.superCall(this, "mergeOption", t)
- },
- optionUpdated: function() {
- this._updateData(this.ecModel);
- var t = this._data;
- if (t[0] && "single" === this.get("selectedMode")) {
- for (var e = !1, i = 0; i < t.length; i++) {
- var n = t[i].get("name");
- if (this.isSelected(n)) {
- this.select(n), e = !0;
- break
- }
- }!e && this.select(t[0].get("name"))
- }
- },
- _updateData: function(t) {
- var e = [],
- i = [];
- t.eachRawSeries(function(n) {
- var o = n.name;
- i.push(o);
- var a;
- if (n.legendDataProvider) {
- var r = n.legendDataProvider(),
- s = r.mapArray(r.getName);
- t.isSeriesFiltered(n) || (i = i.concat(s)), s.length ? e = e.concat(s) : a = !0
- } else a = !0;
- a && Oi(n) && e.push(n.name)
- }), this._availableNames = i;
- var n = f(this.get("data") || e, function(t) {
- return "string" != typeof t && "number" != typeof t || (t = {
- name: t
- }), new Lo(t, this, this.ecModel)
- }, this);
- this._data = n
- },
- getData: function() {
- return this._data
- },
- select: function(t) {
- var e = this.option.selected;
- "single" === this.get("selectedMode") && d(this._data, function(t) {
- e[t.get("name")] = !1
- }), e[t] = !0
- },
- unSelect: function(t) {
- "single" !== this.get("selectedMode") && (this.option.selected[t] = !1)
- },
- toggleSelected: function(t) {
- var e = this.option.selected;
- e.hasOwnProperty(t) || (e[t] = !0), this[e[t] ? "unSelect" : "select"](t)
- },
- isSelected: function(t) {
- var e = this.option.selected;
- return !(e.hasOwnProperty(t) && !e[t]) && l(this._availableNames, t) >= 0
- },
- defaultOption: {
- zlevel: 0,
- z: 4,
- show: !0,
- orient: "horizontal",
- left: "center",
- top: 0,
- align: "auto",
- backgroundColor: "rgba(0,0,0,0)",
- borderColor: "#ccc",
- borderRadius: 0,
- borderWidth: 0,
- padding: 5,
- itemGap: 10,
- itemWidth: 25,
- itemHeight: 14,
- inactiveColor: "#ccc",
- textStyle: {
- color: "#333"
- },
- selectedMode: !0,
- tooltip: {
- show: !1
- }
- }
- });
- Ps("legendToggleSelect", "legendselectchanged", v(cv, "toggleSelected")), Ps("legendSelect", "legendselected", v(cv,
- "select")), Ps("legendUnSelect", "legendunselected", v(cv, "unSelect"));
- var NP = v,
- OP = d,
- EP = Zw,
- RP = Vs({
- type: "legend.plain",
- newlineDisabled: !1,
- init: function() {
- this.group.add(this._contentGroup = new EP), this._backgroundEl
- },
- getContentGroup: function() {
- return this._contentGroup
- },
- render: function(t, e, i) {
- if (this.resetInner(), t.get("show", !0)) {
- var n = t.get("align");
- n && "auto" !== n || (n = "right" === t.get("left") && "vertical" === t.get("orient") ? "right" : "left"), this
- .renderInner(n, t, e, i);
- var o = t.getBoxLayoutParams(),
- a = {
- width: i.getWidth(),
- height: i.getHeight()
- },
- s = t.get("padding"),
- l = la(o, a, s),
- u = this.layoutInner(t, n, l),
- h = la(r({
- width: u.width,
- height: u.height
- }, o), a, s);
- this.group.attr("position", [h.x - u.x, h.y - u.y]), this.group.add(this._backgroundEl = fv(u, t))
- }
- },
- resetInner: function() {
- this.getContentGroup().removeAll(), this._backgroundEl && this.group.remove(this._backgroundEl)
- },
- renderInner: function(t, e, i, n) {
- var o = this.getContentGroup(),
- a = R(),
- r = e.get("selectedMode"),
- s = [];
- i.eachRawSeries(function(t) {
- !t.get("legendHoverLink") && s.push(t.id)
- }), OP(e.getData(), function(l, u) {
- var h = l.get("name");
- if (this.newlineDisabled || "" !== h && "\n" !== h) {
- var c = i.getSeriesByName(h)[0];
- if (!a.get(h))
- if (c) {
- var d = c.getData(),
- f = d.getVisual("color");
- "function" == typeof f && (f = f(c.getDataParams(0)));
- var p = d.getVisual("legendSymbol") || "roundRect",
- g = d.getVisual("symbol");
- this._createItem(h, u, l, e, p, g, t, f, r).on("click", NP(pv, h, n)).on("mouseover", NP(gv, c.name, null,
- n, s)).on("mouseout", NP(mv, c.name, null, n, s)), a.set(h, !0)
- } else i.eachRawSeries(function(i) {
- if (!a.get(h) && i.legendDataProvider) {
- var o = i.legendDataProvider(),
- c = o.indexOfName(h);
- if (c < 0) return;
- var d = o.getItemVisual(c, "color");
- this._createItem(h, u, l, e, "roundRect", null, t, d, r).on("click", NP(pv, h, n)).on("mouseover", NP(
- gv, null, h, n, s)).on("mouseout", NP(mv, null, h, n, s)), a.set(h, !0)
- }
- }, this)
- } else o.add(new EP({
- newline: !0
- }))
- }, this)
- },
- _createItem: function(t, e, i, n, o, r, s, l, u) {
- var h = n.get("itemWidth"),
- c = n.get("itemHeight"),
- d = n.get("inactiveColor"),
- f = n.get("symbolKeepAspect"),
- p = n.isSelected(t),
- g = new EP,
- m = i.getModel("textStyle"),
- v = i.get("icon"),
- y = i.getModel("tooltip"),
- x = y.parentModel;
- if (o = v || o, g.add(Xl(o, 0, 0, h, c, p ? l : d, null == f || f)), !v && r && (r !== o || "none" === r)) {
- var _ = .8 * c;
- "none" === r && (r = "circle"), g.add(Xl(r, (h - _) / 2, (c - _) / 2, _, _, p ? l : d, null == f || f))
- }
- var w = "left" === s ? h + 5 : -5,
- b = s,
- S = n.get("formatter"),
- M = t;
- "string" == typeof S && S ? M = S.replace("{name}", null != t ? t : "") : "function" == typeof S && (M = S(t)),
- g.add(new qS({
- style: fo({}, m, {
- text: M,
- x: w,
- y: c / 2,
- textFill: p ? m.getTextColor() : d,
- textAlign: b,
- textVerticalAlign: "middle"
- })
- }));
- var I = new aM({
- shape: g.getBoundingRect(),
- invisible: !0,
- tooltip: y.get("show") ? a({
- content: t,
- formatter: x.get("formatter", !0) || function() {
- return t
- },
- formatterParams: {
- componentType: "legend",
- legendIndex: n.componentIndex,
- name: t,
- $vars: ["name"]
- }
- }, y.option) : null
- });
- return g.add(I), g.eachChild(function(t) {
- t.silent = !0
- }), I.silent = !u, this.getContentGroup().add(g), uo(g), g.__legendDataIndex = e, g
- },
- layoutInner: function(t, e, i) {
- var n = this.getContentGroup();
- UM(t.get("orient"), n, t.get("itemGap"), i.width, i.height);
- var o = n.getBoundingRect();
- return n.attr("position", [-o.x, -o.y]), this.group.getBoundingRect()
- }
- });
- ks(function(t) {
- var e = t.findComponents({
- mainType: "legend"
- });
- e && e.length && t.filterSeries(function(t) {
- for (var i = 0; i < e.length; i++)
- if (!e[i].isSelected(t.name)) return !1;
- return !0
- })
- }), YM.registerSubTypeDefaulter("legend", function() {
- return "plain"
- });
- var zP = PP.extend({
- type: "legend.scroll",
- setScrollDataIndex: function(t) {
- this.option.scrollDataIndex = t
- },
- defaultOption: {
- scrollDataIndex: 0,
- pageButtonItemGap: 5,
- pageButtonGap: null,
- pageButtonPosition: "end",
- pageFormatter: "{current}/{total}",
- pageIcons: {
- horizontal: ["M0,0L12,-10L12,10z", "M0,0L-12,-10L-12,10z"],
- vertical: ["M0,0L20,0L10,-20z", "M0,0L20,0L10,20z"]
- },
- pageIconColor: "#2f4554",
- pageIconInactiveColor: "#aaa",
- pageIconSize: 15,
- pageTextStyle: {
- color: "#333"
- },
- animationDurationUpdate: 800
- },
- init: function(t, e, i, n) {
- var o = da(t);
- zP.superCall(this, "init", t, e, i, n), vv(this, t, o)
- },
- mergeOption: function(t, e) {
- zP.superCall(this, "mergeOption", t, e), vv(this, this.option, t)
- },
- getOrient: function() {
- return "vertical" === this.get("orient") ? {
- index: 1,
- name: "vertical"
- } : {
- index: 0,
- name: "horizontal"
- }
- }
- }),
- BP = Zw,
- VP = ["width", "height"],
- GP = ["x", "y"],
- FP = RP.extend({
- type: "legend.scroll",
- newlineDisabled: !0,
- init: function() {
- FP.superCall(this, "init"), this._currentIndex = 0, this.group.add(this._containerGroup = new BP), this._containerGroup
- .add(this.getContentGroup()), this.group.add(this._controllerGroup = new BP), this._showController
- },
- resetInner: function() {
- FP.superCall(this, "resetInner"), this._controllerGroup.removeAll(), this._containerGroup.removeClipPath(), this
- ._containerGroup.__rectSize = null
- },
- renderInner: function(t, e, i, n) {
- function o(t, i) {
- var o = t + "DataIndex",
- l = Co(e.get("pageIcons", !0)[e.getOrient().name][i], {
- onclick: m(a._pageGo, a, o, e, n)
- }, {
- x: -s[0] / 2,
- y: -s[1] / 2,
- width: s[0],
- height: s[1]
- });
- l.name = t, r.add(l)
- }
- var a = this;
- FP.superCall(this, "renderInner", t, e, i, n);
- var r = this._controllerGroup,
- s = e.get("pageIconSize", !0);
- y(s) || (s = [s, s]), o("pagePrev", 0);
- var l = e.getModel("pageTextStyle");
- r.add(new qS({
- name: "pageText",
- style: {
- textFill: l.getTextColor(),
- font: l.getFont(),
- textVerticalAlign: "middle",
- textAlign: "center"
- },
- silent: !0
- })), o("pageNext", 1)
- },
- layoutInner: function(t, e, i) {
- var n = this.getContentGroup(),
- o = this._containerGroup,
- a = this._controllerGroup,
- r = t.getOrient().index,
- s = VP[r],
- l = VP[1 - r],
- u = GP[1 - r];
- UM(t.get("orient"), n, t.get("itemGap"), r ? i.width : null, r ? null : i.height), UM("horizontal", a, t.get(
- "pageButtonItemGap", !0));
- var h = n.getBoundingRect(),
- c = a.getBoundingRect(),
- d = this._showController = h[s] > i[s],
- f = [-h.x, -h.y];
- f[r] = n.position[r];
- var p = [0, 0],
- g = [-c.x, -c.y],
- m = A(t.get("pageButtonGap", !0), t.get("itemGap", !0));
- d && ("end" === t.get("pageButtonPosition", !0) ? g[r] += i[s] - c[s] : p[r] += c[s] + m), g[1 - r] += h[l] / 2 -
- c[l] / 2, n.attr("position", f), o.attr("position", p), a.attr("position", g);
- var v = this.group.getBoundingRect();
- if ((v = {
- x: 0,
- y: 0
- })[s] = d ? i[s] : h[s], v[l] = Math.max(h[l], c[l]), v[u] = Math.min(0, c[u] + g[1 - r]), o.__rectSize = i[s],
- d) {
- var y = {
- x: 0,
- y: 0
- };
- y[s] = Math.max(i[s] - c[s] - m, 0), y[l] = v[l], o.setClipPath(new aM({
- shape: y
- })), o.__rectSize = y[s]
- } else a.eachChild(function(t) {
- t.attr({
- invisible: !0,
- silent: !0
- })
- });
- var x = this._getPageInfo(t);
- return null != x.pageIndex && bo(n, {
- position: x.contentPosition
- }, !!d && t), this._updatePageInfoView(t, x), v
- },
- _pageGo: function(t, e, i) {
- var n = this._getPageInfo(e)[t];
- null != n && i.dispatchAction({
- type: "legendScroll",
- scrollDataIndex: n,
- legendId: e.id
- })
- },
- _updatePageInfoView: function(t, e) {
- var i = this._controllerGroup;
- d(["pagePrev", "pageNext"], function(n) {
- var o = null != e[n + "DataIndex"],
- a = i.childOfName(n);
- a && (a.setStyle("fill", o ? t.get("pageIconColor", !0) : t.get("pageIconInactiveColor", !0)), a.cursor = o ?
- "pointer" : "default")
- });
- var n = i.childOfName("pageText"),
- o = t.get("pageFormatter"),
- a = e.pageIndex,
- r = null != a ? a + 1 : 0,
- s = e.pageCount;
- n && o && n.setStyle("text", _(o) ? o.replace("{current}", r).replace("{total}", s) : o({
- current: r,
- total: s
- }))
- },
- _getPageInfo: function(t) {
- function e(t) {
- var e = t.getBoundingRect().clone();
- return e[f] += t.position[h], e
- }
- var i, n, o, a, r = t.get("scrollDataIndex", !0),
- s = this.getContentGroup(),
- l = s.getBoundingRect(),
- u = this._containerGroup.__rectSize,
- h = t.getOrient().index,
- c = VP[h],
- d = VP[1 - h],
- f = GP[h],
- p = s.position.slice();
- this._showController ? s.eachChild(function(t) {
- t.__legendDataIndex === r && (a = t)
- }) : a = s.childAt(0);
- var g = u ? Math.ceil(l[c] / u) : 0;
- if (a) {
- var m = a.getBoundingRect(),
- v = a.position[h] + m[f];
- p[h] = -v - l[f], i = Math.floor(g * (v + m[f] + u / 2) / l[c]), i = l[c] && g ? Math.max(0, Math.min(g - 1, i)) :
- -1;
- var y = {
- x: 0,
- y: 0
- };
- y[c] = u, y[d] = l[d], y[f] = -p[h] - l[f];
- var x, _ = s.children();
- if (s.eachChild(function(t, i) {
- var n = e(t);
- n.intersect(y) && (null == x && (x = i), o = t.__legendDataIndex), i === _.length - 1 && n[f] + n[c] <= y[f] +
- y[c] && (o = null)
- }), null != x) {
- var w = e(_[x]);
- if (y[f] = w[f] + w[c] - y[c], x <= 0 && w[f] >= y[f]) n = null;
- else {
- for (; x > 0 && e(_[x - 1]).intersect(y);) x--;
- n = _[x].__legendDataIndex
- }
- }
- }
- return {
- contentPosition: p,
- pageIndex: i,
- pageCount: g,
- pagePrevDataIndex: n,
- pageNextDataIndex: o
- }
- }
- });
- Ps("legendScroll", "legendscroll", function(t, e) {
- var i = t.scrollDataIndex;
- null != i && e.eachComponent({
- mainType: "legend",
- subType: "scroll",
- query: t
- }, function(t) {
- t.setScrollDataIndex(i)
- })
- }), Bs({
- type: "tooltip",
- dependencies: ["axisPointer"],
- defaultOption: {
- zlevel: 0,
- z: 60,
- show: !0,
- showContent: !0,
- trigger: "item",
- triggerOn: "mousemove|click",
- alwaysShowContent: !1,
- displayMode: "single",
- renderMode: "auto",
- confine: !1,
- showDelay: 0,
- hideDelay: 100,
- transitionDuration: .4,
- enterable: !1,
- backgroundColor: "rgba(50,50,50,0.7)",
- borderColor: "#333",
- borderRadius: 4,
- borderWidth: 0,
- padding: 5,
- extraCssText: "",
- axisPointer: {
- type: "line",
- axis: "auto",
- animation: "auto",
- animationDurationUpdate: 200,
- animationEasingUpdate: "exponentialOut",
- crossStyle: {
- color: "#999",
- width: 1,
- type: "dashed",
- textStyle: {}
- }
- },
- textStyle: {
- color: "#fff",
- fontSize: 14
- }
- }
- });
- var WP = d,
- HP = Jo,
- ZP = ["", "-webkit-", "-moz-", "-o-"];
- wv.prototype = {
- constructor: wv,
- _enterable: !0,
- update: function() {
- var t = this._container,
- e = t.currentStyle || document.defaultView.getComputedStyle(t),
- i = t.style;
- "absolute" !== i.position && "absolute" !== e.position && (i.position = "relative")
- },
- show: function(t) {
- clearTimeout(this._hideTimeout);
- var e = this.el;
- e.style.cssText = "position:absolute;display:block;border-style:solid;white-space:nowrap;z-index:9999999;" + _v(t) +
- ";left:" + this._x + "px;top:" + this._y + "px;" + (t.get("extraCssText") || ""), e.style.display = e.innerHTML ?
- "block" : "none", e.style.pointerEvents = this._enterable ? "auto" : "none", this._show = !0
- },
- setContent: function(t) {
- this.el.innerHTML = null == t ? "" : t
- },
- setEnterable: function(t) {
- this._enterable = t
- },
- getSize: function() {
- var t = this.el;
- return [t.clientWidth, t.clientHeight]
- },
- moveTo: function(t, e) {
- var i, n = this._zr;
- n && n.painter && (i = n.painter.getViewportRootOffset()) && (t += i.offsetLeft, e += i.offsetTop);
- var o = this.el.style;
- o.left = t + "px", o.top = e + "px", this._x = t, this._y = e
- },
- hide: function() {
- this.el.style.display = "none", this._show = !1
- },
- hideLater: function(t) {
- !this._show || this._inContent && this._enterable || (t ? (this._hideDelay = t, this._show = !1, this._hideTimeout =
- setTimeout(m(this.hide, this), t)) : this.hide())
- },
- isShow: function() {
- return this._show
- },
- getOuterSize: function() {
- var t = this.el.clientWidth,
- e = this.el.clientHeight;
- if (document.defaultView && document.defaultView.getComputedStyle) {
- var i = document.defaultView.getComputedStyle(this.el);
- i && (t += parseInt(i.paddingLeft, 10) + parseInt(i.paddingRight, 10) + parseInt(i.borderLeftWidth, 10) +
- parseInt(i.borderRightWidth, 10), e += parseInt(i.paddingTop, 10) + parseInt(i.paddingBottom, 10) + parseInt(i
- .borderTopWidth, 10) + parseInt(i.borderBottomWidth, 10))
- }
- return {
- width: t,
- height: e
- }
- }
- }, bv.prototype = {
- constructor: bv,
- _enterable: !0,
- update: function() {},
- show: function(t) {
- this._hideTimeout && clearTimeout(this._hideTimeout), this.el.attr("show", !0), this._show = !0
- },
- setContent: function(t, e, i) {
- this.el && this._zr.remove(this.el);
- for (var n = {}, o = t, a = o.indexOf("{marker"); a >= 0;) {
- var r = o.indexOf("|}"),
- s = o.substr(a + "{marker".length, r - a - "{marker".length);
- s.indexOf("sub") > -1 ? n["marker" + s] = {
- textWidth: 4,
- textHeight: 4,
- textBorderRadius: 2,
- textBackgroundColor: e[s],
- textOffset: [3, 0]
- } : n["marker" + s] = {
- textWidth: 10,
- textHeight: 10,
- textBorderRadius: 5,
- textBackgroundColor: e[s]
- }, a = (o = o.substr(r + 1)).indexOf("{marker")
- }
- this.el = new qS({
- style: {
- rich: n,
- text: t,
- textLineHeight: 20,
- textBackgroundColor: i.get("backgroundColor"),
- textBorderRadius: i.get("borderRadius"),
- textFill: i.get("textStyle.color"),
- textPadding: i.get("padding")
- },
- z: i.get("z")
- }), this._zr.add(this.el);
- var l = this;
- this.el.on("mouseover", function() {
- l._enterable && (clearTimeout(l._hideTimeout), l._show = !0), l._inContent = !0
- }), this.el.on("mouseout", function() {
- l._enterable && l._show && l.hideLater(l._hideDelay), l._inContent = !1
- })
- },
- setEnterable: function(t) {
- this._enterable = t
- },
- getSize: function() {
- var t = this.el.getBoundingRect();
- return [t.width, t.height]
- },
- moveTo: function(t, e) {
- this.el && this.el.attr("position", [t, e])
- },
- hide: function() {
- this.el.hide(), this._show = !1
- },
- hideLater: function(t) {
- !this._show || this._inContent && this._enterable || (t ? (this._hideDelay = t, this._show = !1, this._hideTimeout =
- setTimeout(m(this.hide, this), t)) : this.hide())
- },
- isShow: function() {
- return this._show
- },
- getOuterSize: function() {
- return this.getSize()
- }
- };
- var UP = m,
- XP = d,
- jP = Ro,
- YP = new aM({
- shape: {
- x: -1,
- y: -1,
- width: 2,
- height: 2
- }
- });
- Vs({
- type: "tooltip",
- init: function(t, e) {
- if (!z_.node) {
- var i = t.getComponent("tooltip").get("renderMode");
- this._renderMode = Hi(i);
- var n;
- "html" === this._renderMode ? (n = new wv(e.getDom(), e), this._newLine = "<br/>") : (n = new bv(e), this._newLine =
- "\n"), this._tooltipContent = n
- }
- },
- render: function(t, e, i) {
- if (!z_.node) {
- this.group.removeAll(), this._tooltipModel = t, this._ecModel = e, this._api = i, this._lastDataByCoordSys =
- null, this._alwaysShowContent = t.get("alwaysShowContent");
- var n = this._tooltipContent;
- n.update(), n.setEnterable(t.get("enterable")), this._initGlobalListener(), this._keepShow()
- }
- },
- _initGlobalListener: function() {
- var t = this._tooltipModel.get("triggerOn");
- im("itemTooltip", this._api, UP(function(e, i, n) {
- "none" !== t && (t.indexOf(e) >= 0 ? this._tryShow(i, n) : "leave" === e && this._hide(n))
- }, this))
- },
- _keepShow: function() {
- var t = this._tooltipModel,
- e = this._ecModel,
- i = this._api;
- if (null != this._lastX && null != this._lastY && "none" !== t.get("triggerOn")) {
- var n = this;
- clearTimeout(this._refreshUpdateTimeout), this._refreshUpdateTimeout = setTimeout(function() {
- n.manuallyShowTip(t, e, i, {
- x: n._lastX,
- y: n._lastY
- })
- })
- }
- },
- manuallyShowTip: function(t, e, i, n) {
- if (n.from !== this.uid && !z_.node) {
- var o = Mv(n, i);
- this._ticket = "";
- var a = n.dataByCoordSys;
- if (n.tooltip && null != n.x && null != n.y) {
- var r = YP;
- r.position = [n.x, n.y], r.update(), r.tooltip = n.tooltip, this._tryShow({
- offsetX: n.x,
- offsetY: n.y,
- target: r
- }, o)
- } else if (a) this._tryShow({
- offsetX: n.x,
- offsetY: n.y,
- position: n.position,
- event: {},
- dataByCoordSys: n.dataByCoordSys,
- tooltipOption: n.tooltipOption
- }, o);
- else if (null != n.seriesIndex) {
- if (this._manuallyAxisShowTip(t, e, i, n)) return;
- var s = eP(n, e),
- l = s.point[0],
- u = s.point[1];
- null != l && null != u && this._tryShow({
- offsetX: l,
- offsetY: u,
- position: n.position,
- target: s.el,
- event: {}
- }, o)
- } else null != n.x && null != n.y && (i.dispatchAction({
- type: "updateAxisPointer",
- x: n.x,
- y: n.y
- }), this._tryShow({
- offsetX: n.x,
- offsetY: n.y,
- position: n.position,
- target: i.getZr().findHover(n.x, n.y).target,
- event: {}
- }, o))
- }
- },
- manuallyHideTip: function(t, e, i, n) {
- var o = this._tooltipContent;
- !this._alwaysShowContent && this._tooltipModel && o.hideLater(this._tooltipModel.get("hideDelay")), this._lastX =
- this._lastY = null, n.from !== this.uid && this._hide(Mv(n, i))
- },
- _manuallyAxisShowTip: function(t, e, i, n) {
- var o = n.seriesIndex,
- a = n.dataIndex,
- r = e.getComponent("axisPointer").coordSysAxesInfo;
- if (null != o && null != a && null != r) {
- var s = e.getSeriesByIndex(o);
- if (s && "axis" === (t = Sv([s.getData().getItemModel(a), s, (s.coordinateSystem || {}).model, t])).get(
- "trigger")) return i.dispatchAction({
- type: "updateAxisPointer",
- seriesIndex: o,
- dataIndex: a,
- position: n.position
- }), !0
- }
- },
- _tryShow: function(t, e) {
- var i = t.target;
- if (this._tooltipModel) {
- this._lastX = t.offsetX, this._lastY = t.offsetY;
- var n = t.dataByCoordSys;
- n && n.length ? this._showAxisTooltip(n, t) : i && null != i.dataIndex ? (this._lastDataByCoordSys = null, this
- ._showSeriesItemTooltip(t, i, e)) : i && i.tooltip ? (this._lastDataByCoordSys = null, this._showComponentItemTooltip(
- t, i, e)) : (this._lastDataByCoordSys = null, this._hide(e))
- }
- },
- _showOrMove: function(t, e) {
- var i = t.get("showDelay");
- e = m(e, this), clearTimeout(this._showTimout), i > 0 ? this._showTimout = setTimeout(e, i) : e()
- },
- _showAxisTooltip: function(t, e) {
- var i = this._ecModel,
- o = this._tooltipModel,
- a = [e.offsetX, e.offsetY],
- r = [],
- s = [],
- l = Sv([e.tooltipOption, o]),
- u = this._renderMode,
- h = this._newLine,
- c = {};
- XP(t, function(t) {
- XP(t.dataByAxis, function(t) {
- var e = i.getComponent(t.axisDim + "Axis", t.axisIndex),
- o = t.value,
- a = [];
- if (e && null != o) {
- var l = ym(o, e.axis, i, t.seriesDataIndices, t.valueLabelOpt);
- d(t.seriesDataIndices, function(r) {
- var h = i.getSeriesByIndex(r.seriesIndex),
- d = r.dataIndexInside,
- f = h && h.getDataParams(d);
- if (f.axisDim = t.axisDim, f.axisIndex = t.axisIndex, f.axisType = t.axisType, f.axisId = t.axisId, f.axisValue =
- Wl(e.axis, o), f.axisValueLabel = l, f) {
- s.push(f);
- var p, g = h.formatTooltip(d, !0, null, u);
- if (w(g)) {
- p = g.html;
- var m = g.markers;
- n(c, m)
- } else p = g;
- a.push(p)
- }
- });
- var f = l;
- "html" !== u ? r.push(a.join(h)) : r.push((f ? Qo(f) + h : "") + a.join(h))
- }
- })
- }, this), r.reverse(), r = r.join(this._newLine + this._newLine);
- var f = e.position;
- this._showOrMove(l, function() {
- this._updateContentNotChangedOnAxis(t) ? this._updatePosition(l, f, a[0], a[1], this._tooltipContent, s) :
- this._showTooltipContent(l, r, s, Math.random(), a[0], a[1], f, void 0, c)
- })
- },
- _showSeriesItemTooltip: function(t, e, i) {
- var n = this._ecModel,
- o = e.seriesIndex,
- a = n.getSeriesByIndex(o),
- r = e.dataModel || a,
- s = e.dataIndex,
- l = e.dataType,
- u = r.getData(),
- h = Sv([u.getItemModel(s), r, a && (a.coordinateSystem || {}).model, this._tooltipModel]),
- c = h.get("trigger");
- if (null == c || "item" === c) {
- var d, f, p = r.getDataParams(s, l),
- g = r.formatTooltip(s, !1, l, this._renderMode);
- w(g) ? (d = g.html, f = g.markers) : (d = g, f = null);
- var m = "item_" + r.name + "_" + s;
- this._showOrMove(h, function() {
- this._showTooltipContent(h, d, p, m, t.offsetX, t.offsetY, t.position, t.target, f)
- }), i({
- type: "showTip",
- dataIndexInside: s,
- dataIndex: u.getRawIndex(s),
- seriesIndex: o,
- from: this.uid
- })
- }
- },
- _showComponentItemTooltip: function(t, e, i) {
- var n = e.tooltip;
- if ("string" == typeof n) {
- var o = n;
- n = {
- content: o,
- formatter: o
- }
- }
- var a = new Lo(n, this._tooltipModel, this._ecModel),
- r = a.get("content"),
- s = Math.random();
- this._showOrMove(a, function() {
- this._showTooltipContent(a, r, a.get("formatterParams") || {}, s, t.offsetX, t.offsetY, t.position, e)
- }), i({
- type: "showTip",
- from: this.uid
- })
- },
- _showTooltipContent: function(t, e, i, n, o, a, r, s, l) {
- if (this._ticket = "", t.get("showContent") && t.get("show")) {
- var u = this._tooltipContent,
- h = t.get("formatter");
- r = r || t.get("position");
- var c = e;
- if (h && "string" == typeof h) c = ta(h, i, !0);
- else if ("function" == typeof h) {
- var d = UP(function(e, n) {
- e === this._ticket && (u.setContent(n, l, t), this._updatePosition(t, r, o, a, u, i, s))
- }, this);
- this._ticket = n, c = h(i, n, d)
- }
- u.setContent(c, l, t), u.show(t), this._updatePosition(t, r, o, a, u, i, s)
- }
- },
- _updatePosition: function(t, e, i, n, o, a, r) {
- var s = this._api.getWidth(),
- l = this._api.getHeight();
- e = e || t.get("position");
- var u = o.getSize(),
- h = t.get("align"),
- c = t.get("verticalAlign"),
- d = r && r.getBoundingRect().clone();
- if (r && d.applyTransform(r.transform), "function" == typeof e && (e = e([i, n], a, o.el, d, {
- viewSize: [s, l],
- contentSize: u.slice()
- })), y(e)) i = jP(e[0], s), n = jP(e[1], l);
- else if (w(e)) {
- e.width = u[0], e.height = u[1];
- var f = la(e, {
- width: s,
- height: l
- });
- i = f.x, n = f.y, h = null, c = null
- } else "string" == typeof e && r ? (i = (p = Av(e, d, u))[0], n = p[1]) : (i = (p = Iv(i, n, o, s, l, h ? null :
- 20, c ? null : 20))[0], n = p[1]);
- if (h && (i -= Dv(h) ? u[0] / 2 : "right" === h ? u[0] : 0), c && (n -= Dv(c) ? u[1] / 2 : "bottom" === c ? u[1] :
- 0), t.get("confine")) {
- var p = Tv(i, n, o, s, l);
- i = p[0], n = p[1]
- }
- o.moveTo(i, n)
- },
- _updateContentNotChangedOnAxis: function(t) {
- var e = this._lastDataByCoordSys,
- i = !!e && e.length === t.length;
- return i && XP(e, function(e, n) {
- var o = e.dataByAxis || {},
- a = (t[n] || {}).dataByAxis || [];
- (i &= o.length === a.length) && XP(o, function(t, e) {
- var n = a[e] || {},
- o = t.seriesDataIndices || [],
- r = n.seriesDataIndices || [];
- (i &= t.value === n.value && t.axisType === n.axisType && t.axisId === n.axisId && o.length === r.length) &&
- XP(o, function(t, e) {
- var n = r[e];
- i &= t.seriesIndex === n.seriesIndex && t.dataIndex === n.dataIndex
- })
- })
- }), this._lastDataByCoordSys = t, !!i
- },
- _hide: function(t) {
- this._lastDataByCoordSys = null, t({
- type: "hideTip",
- from: this.uid
- })
- },
- dispose: function(t, e) {
- z_.node || (this._tooltipContent.hide(), lm("itemTooltip", e))
- }
- }), Ps({
- type: "showTip",
- event: "showTip",
- update: "tooltip:manuallyShowTip"
- }, function() {}), Ps({
- type: "hideTip",
- event: "hideTip",
- update: "tooltip:manuallyHideTip"
- }, function() {}), Pv.prototype = {
- constructor: Pv,
- pointToData: function(t, e) {
- return this.polar.pointToData(t, e)["radius" === this.dim ? 0 : 1]
- },
- dataToRadius: HA.prototype.dataToCoord,
- radiusToData: HA.prototype.coordToData
- }, u(Pv, HA);
- var qP = Bi();
- Nv.prototype = {
- constructor: Nv,
- pointToData: function(t, e) {
- return this.polar.pointToData(t, e)["radius" === this.dim ? 0 : 1]
- },
- dataToAngle: HA.prototype.dataToCoord,
- angleToData: HA.prototype.coordToData,
- calculateCategoryInterval: function() {
- var t = this,
- e = t.getLabelModel(),
- i = t.scale,
- n = i.getExtent(),
- o = i.count();
- if (n[1] - n[0] < 1) return 0;
- var a = n[0],
- r = t.dataToCoord(a + 1) - t.dataToCoord(a),
- s = Math.abs(r),
- l = De(a, e.getFont(), "center", "top"),
- u = Math.max(l.height, 7) / s;
- isNaN(u) && (u = 1 / 0);
- var h = Math.max(0, Math.floor(u)),
- c = qP(t.model),
- d = c.lastAutoInterval,
- f = c.lastTickCount;
- return null != d && null != f && Math.abs(d - h) <= 1 && Math.abs(f - o) <= 1 && d > h ? h = d : (c.lastTickCount =
- o, c.lastAutoInterval = h), h
- }
- }, u(Nv, HA);
- var KP = function(t) {
- this.name = t || "", this.cx = 0, this.cy = 0, this._radiusAxis = new Pv, this._angleAxis = new Nv, this._radiusAxis
- .polar = this._angleAxis.polar = this
- };
- KP.prototype = {
- type: "polar",
- axisPointerEnabled: !0,
- constructor: KP,
- dimensions: ["radius", "angle"],
- model: null,
- containPoint: function(t) {
- var e = this.pointToCoord(t);
- return this._radiusAxis.contain(e[0]) && this._angleAxis.contain(e[1])
- },
- containData: function(t) {
- return this._radiusAxis.containData(t[0]) && this._angleAxis.containData(t[1])
- },
- getAxis: function(t) {
- return this["_" + t + "Axis"]
- },
- getAxes: function() {
- return [this._radiusAxis, this._angleAxis]
- },
- getAxesByScale: function(t) {
- var e = [],
- i = this._angleAxis,
- n = this._radiusAxis;
- return i.scale.type === t && e.push(i), n.scale.type === t && e.push(n), e
- },
- getAngleAxis: function() {
- return this._angleAxis
- },
- getRadiusAxis: function() {
- return this._radiusAxis
- },
- getOtherAxis: function(t) {
- var e = this._angleAxis;
- return t === e ? this._radiusAxis : e
- },
- getBaseAxis: function() {
- return this.getAxesByScale("ordinal")[0] || this.getAxesByScale("time")[0] || this.getAngleAxis()
- },
- getTooltipAxes: function(t) {
- var e = null != t && "auto" !== t ? this.getAxis(t) : this.getBaseAxis();
- return {
- baseAxes: [e],
- otherAxes: [this.getOtherAxis(e)]
- }
- },
- dataToPoint: function(t, e) {
- return this.coordToPoint([this._radiusAxis.dataToRadius(t[0], e), this._angleAxis.dataToAngle(t[1], e)])
- },
- pointToData: function(t, e) {
- var i = this.pointToCoord(t);
- return [this._radiusAxis.radiusToData(i[0], e), this._angleAxis.angleToData(i[1], e)]
- },
- pointToCoord: function(t) {
- var e = t[0] - this.cx,
- i = t[1] - this.cy,
- n = this.getAngleAxis(),
- o = n.getExtent(),
- a = Math.min(o[0], o[1]),
- r = Math.max(o[0], o[1]);
- n.inverse ? a = r - 360 : r = a + 360;
- var s = Math.sqrt(e * e + i * i);
- e /= s, i /= s;
- for (var l = Math.atan2(-i, e) / Math.PI * 180, u = l < a ? 1 : -1; l < a || l > r;) l += 360 * u;
- return [s, l]
- },
- coordToPoint: function(t) {
- var e = t[0],
- i = t[1] / 180 * Math.PI;
- return [Math.cos(i) * e + this.cx, -Math.sin(i) * e + this.cy]
- }
- };
- var $P = YM.extend({
- type: "polarAxis",
- axis: null,
- getCoordSysModel: function() {
- return this.ecModel.queryComponents({
- mainType: "polar",
- index: this.option.polarIndex,
- id: this.option.polarId
- })[0]
- }
- });
- n($P.prototype, CA);
- var JP = {
- angle: {
- startAngle: 90,
- clockwise: !0,
- splitNumber: 12,
- axisLabel: {
- rotate: !1
- }
- },
- radius: {
- splitNumber: 5
- }
- };
- xD("angle", $P, Ov, JP.angle), xD("radius", $P, Ov, JP.radius), Bs({
- type: "polar",
- dependencies: ["polarAxis", "angleAxis"],
- coordinateSystem: null,
- findAxisModel: function(t) {
- var e;
- return this.ecModel.eachComponent(t, function(t) {
- t.getCoordSysModel() === this && (e = t)
- }, this), e
- },
- defaultOption: {
- zlevel: 0,
- z: 0,
- center: ["50%", "50%"],
- radius: "80%"
- }
- });
- var QP = {
- dimensions: KP.prototype.dimensions,
- create: function(t, e) {
- var i = [];
- return t.eachComponent("polar", function(t, n) {
- var o = new KP(n);
- o.update = Rv;
- var a = o.getRadiusAxis(),
- r = o.getAngleAxis(),
- s = t.findAxisModel("radiusAxis"),
- l = t.findAxisModel("angleAxis");
- zv(a, s), zv(r, l), Ev(o, t, e), i.push(o), t.coordinateSystem = o, o.model = t
- }), t.eachSeries(function(e) {
- if ("polar" === e.get("coordinateSystem")) {
- var i = t.queryComponents({
- mainType: "polar",
- index: e.get("polarIndex"),
- id: e.get("polarId")
- })[0];
- e.coordinateSystem = i.coordinateSystem
- }
- }), i
- }
- };
- Ba.register("polar", QP);
- var tN = ["axisLine", "axisLabel", "axisTick", "splitLine", "splitArea"];
- LD.extend({
- type: "angleAxis",
- axisPointerClass: "PolarAxisPointer",
- render: function(t, e) {
- if (this.group.removeAll(), t.get("show")) {
- var n = t.axis,
- o = n.polar,
- a = o.getRadiusAxis().getExtent(),
- r = n.getTicksCoords(),
- s = f(n.getViewLabels(), function(t) {
- return (t = i(t)).coord = n.dataToCoord(t.tickValue), t
- });
- Gv(s), Gv(r), d(tN, function(e) {
- !t.get(e + ".show") || n.scale.isBlank() && "axisLine" !== e || this["_" + e](t, o, r, a, s)
- }, this)
- }
- },
- _axisLine: function(t, e, i, n) {
- var o = t.getModel("axisLine.lineStyle"),
- a = new KS({
- shape: {
- cx: e.cx,
- cy: e.cy,
- r: n[Vv(e)]
- },
- style: o.getLineStyle(),
- z2: 1,
- silent: !0
- });
- a.style.fill = null, this.group.add(a)
- },
- _axisTick: function(t, e, i, n) {
- var o = t.getModel("axisTick"),
- a = (o.get("inside") ? -1 : 1) * o.get("length"),
- s = n[Vv(e)],
- l = f(i, function(t) {
- return new rM({
- shape: Bv(e, [s, s + a], t.coord)
- })
- });
- this.group.add(xM(l, {
- style: r(o.getModel("lineStyle").getLineStyle(), {
- stroke: t.get("axisLine.lineStyle.color")
- })
- }))
- },
- _axisLabel: function(t, e, i, n, o) {
- var a = t.getCategories(!0),
- r = t.getModel("axisLabel"),
- s = r.get("margin");
- d(o, function(i, o) {
- var l = r,
- u = i.tickValue,
- h = n[Vv(e)],
- c = e.coordToPoint([h + s, i.coord]),
- d = e.cx,
- f = e.cy,
- p = Math.abs(c[0] - d) / h < .3 ? "center" : c[0] > d ? "left" : "right",
- g = Math.abs(c[1] - f) / h < .3 ? "middle" : c[1] > f ? "top" : "bottom";
- a && a[u] && a[u].textStyle && (l = new Lo(a[u].textStyle, r, r.ecModel));
- var m = new qS({
- silent: !0
- });
- this.group.add(m), fo(m.style, l, {
- x: c[0],
- y: c[1],
- textFill: l.getTextColor() || t.get("axisLine.lineStyle.color"),
- text: i.formattedLabel,
- textAlign: p,
- textVerticalAlign: g
- })
- }, this)
- },
- _splitLine: function(t, e, i, n) {
- var o = t.getModel("splitLine").getModel("lineStyle"),
- a = o.get("color"),
- s = 0;
- a = a instanceof Array ? a : [a];
- for (var l = [], u = 0; u < i.length; u++) {
- var h = s++ % a.length;
- l[h] = l[h] || [], l[h].push(new rM({
- shape: Bv(e, n, i[u].coord)
- }))
- }
- for (u = 0; u < l.length; u++) this.group.add(xM(l[u], {
- style: r({
- stroke: a[u % a.length]
- }, o.getLineStyle()),
- silent: !0,
- z: t.get("z")
- }))
- },
- _splitArea: function(t, e, i, n) {
- if (i.length) {
- var o = t.getModel("splitArea").getModel("areaStyle"),
- a = o.get("color"),
- s = 0;
- a = a instanceof Array ? a : [a];
- for (var l = [], u = Math.PI / 180, h = -i[0].coord * u, c = Math.min(n[0], n[1]), d = Math.max(n[0], n[1]), f =
- t.get("clockwise"), p = 1; p < i.length; p++) {
- var g = s++ % a.length;
- l[g] = l[g] || [], l[g].push(new QS({
- shape: {
- cx: e.cx,
- cy: e.cy,
- r0: c,
- r: d,
- startAngle: h,
- endAngle: -i[p].coord * u,
- clockwise: f
- },
- silent: !0
- })), h = -i[p].coord * u
- }
- for (p = 0; p < l.length; p++) this.group.add(xM(l[p], {
- style: r({
- fill: a[p % a.length]
- }, o.getAreaStyle()),
- silent: !0
- }))
- }
- }
- });
- var eN = ["axisLine", "axisTickLabel", "axisName"],
- iN = ["splitLine", "splitArea"];
- LD.extend({
- type: "radiusAxis",
- axisPointerClass: "PolarAxisPointer",
- render: function(t, e) {
- if (this.group.removeAll(), t.get("show")) {
- var i = t.axis,
- n = i.polar,
- o = n.getAngleAxis(),
- a = i.getTicksCoords(),
- r = o.getExtent()[0],
- s = i.getExtent(),
- l = Fv(n, t, r),
- u = new ID(t, l);
- d(eN, u.add, u), this.group.add(u.getGroup()), d(iN, function(e) {
- t.get(e + ".show") && !i.scale.isBlank() && this["_" + e](t, n, r, s, a)
- }, this)
- }
- },
- _splitLine: function(t, e, i, n, o) {
- var a = t.getModel("splitLine").getModel("lineStyle"),
- s = a.get("color"),
- l = 0;
- s = s instanceof Array ? s : [s];
- for (var u = [], h = 0; h < o.length; h++) {
- var c = l++ % s.length;
- u[c] = u[c] || [], u[c].push(new KS({
- shape: {
- cx: e.cx,
- cy: e.cy,
- r: o[h].coord
- },
- silent: !0
- }))
- }
- for (h = 0; h < u.length; h++) this.group.add(xM(u[h], {
- style: r({
- stroke: s[h % s.length],
- fill: null
- }, a.getLineStyle()),
- silent: !0
- }))
- },
- _splitArea: function(t, e, i, n, o) {
- if (o.length) {
- var a = t.getModel("splitArea").getModel("areaStyle"),
- s = a.get("color"),
- l = 0;
- s = s instanceof Array ? s : [s];
- for (var u = [], h = o[0].coord, c = 1; c < o.length; c++) {
- var d = l++ % s.length;
- u[d] = u[d] || [], u[d].push(new QS({
- shape: {
- cx: e.cx,
- cy: e.cy,
- r0: h,
- r: o[c].coord,
- startAngle: 0,
- endAngle: 2 * Math.PI
- },
- silent: !0
- })), h = o[c].coord
- }
- for (c = 0; c < u.length; c++) this.group.add(xM(u[c], {
- style: r({
- fill: s[c % s.length]
- }, a.getAreaStyle()),
- silent: !0
- }))
- }
- }
- });
- var nN = um.extend({
- makeElOption: function(t, e, i, n, o) {
- var a = i.axis;
- "angle" === a.dim && (this.animationThreshold = Math.PI / 18);
- var r, s = a.polar,
- l = s.getOtherAxis(a).getExtent();
- r = a["dataTo" + aa(a.dim)](e);
- var u = n.get("type");
- if (u && "none" !== u) {
- var h = gm(n),
- c = oN[u](a, s, r, l, h);
- c.style = h, t.graphicKey = c.type, t.pointer = c
- }
- mm(t, i, n, o, Wv(e, i, 0, s, n.get("label.margin")))
- }
- }),
- oN = {
- line: function(t, e, i, n, o) {
- return "angle" === t.dim ? {
- type: "Line",
- shape: wm(e.coordToPoint([n[0], i]), e.coordToPoint([n[1], i]))
- } : {
- type: "Circle",
- shape: {
- cx: e.cx,
- cy: e.cy,
- r: i
- }
- }
- },
- shadow: function(t, e, i, n, o) {
- var a = Math.max(1, t.getBandWidth()),
- r = Math.PI / 180;
- return "angle" === t.dim ? {
- type: "Sector",
- shape: Sm(e.cx, e.cy, n[0], n[1], (-i - a / 2) * r, (a / 2 - i) * r)
- } : {
- type: "Sector",
- shape: Sm(e.cx, e.cy, i - a / 2, i + a / 2, 0, 2 * Math.PI)
- }
- }
- };
- LD.registerAxisPointerClass("PolarAxisPointer", nN), Os(v(function(t, e, i) {
- var n = {},
- o = kv(g(e.getSeriesByType(t), function(t) {
- return !e.isSeriesFiltered(t) && t.coordinateSystem && "polar" === t.coordinateSystem.type
- }));
- e.eachSeriesByType(t, function(t) {
- if ("polar" === t.coordinateSystem.type) {
- var e = t.getData(),
- i = t.coordinateSystem,
- a = i.getBaseAxis(),
- r = Cv(t),
- s = o[Lv(a)][r],
- l = s.offset,
- u = s.width,
- h = i.getOtherAxis(a),
- c = t.coordinateSystem.cx,
- d = t.coordinateSystem.cy,
- f = t.get("barMinHeight") || 0,
- p = t.get("barMinAngle") || 0;
- n[r] = n[r] || [];
- for (var g = e.mapDimension(h.dim), m = e.mapDimension(a.dim), v = hl(e, g), y = h.getExtent()[0], x = 0, _ =
- e.count(); x < _; x++) {
- var w = e.get(g, x),
- b = e.get(m, x);
- if (!isNaN(w)) {
- var S = w >= 0 ? "p" : "n",
- M = y;
- v && (n[r][b] || (n[r][b] = {
- p: y,
- n: y
- }), M = n[r][b][S]);
- var I, T, A, D;
- if ("radius" === h.dim) {
- var C = h.dataToRadius(w) - y,
- L = a.dataToAngle(b);
- Math.abs(C) < f && (C = (C < 0 ? -1 : 1) * f), I = M, T = M + C, D = (A = L - l) - u, v && (n[r][b][S] = T)
- } else {
- var k = h.dataToAngle(w, !0) - y,
- P = a.dataToRadius(b);
- Math.abs(k) < p && (k = (k < 0 ? -1 : 1) * p), T = (I = P + l) + u, A = M, D = M + k, v && (n[r][b][S] = D)
- }
- e.setItemLayout(x, {
- cx: c,
- cy: d,
- r0: I,
- r: T,
- startAngle: -A * Math.PI / 180,
- endAngle: -D * Math.PI / 180
- })
- }
- }
- }
- }, this)
- }, "bar")), Vs({
- type: "polar"
- }), h(YM.extend({
- type: "geo",
- coordinateSystem: null,
- layoutMode: "box",
- init: function(t) {
- YM.prototype.init.apply(this, arguments), Ci(t, "label", ["show"])
- },
- optionUpdated: function() {
- var t = this.option,
- e = this;
- t.regions = _C.getFilledRegions(t.regions, t.map, t.nameMap), this._optionModelMap = p(t.regions || [],
- function(t, i) {
- return i.name && t.set(i.name, new Lo(i, e)), t
- }, R()), this.updateSelectedMap(t.regions)
- },
- defaultOption: {
- zlevel: 0,
- z: 0,
- show: !0,
- left: "center",
- top: "center",
- aspectScale: null,
- silent: !1,
- map: "",
- boundingCoords: null,
- center: null,
- zoom: 1,
- scaleLimit: null,
- label: {
- show: !1,
- color: "#000"
- },
- itemStyle: {
- borderWidth: .5,
- borderColor: "#444",
- color: "#eee"
- },
- emphasis: {
- label: {
- show: !0,
- color: "rgb(100,0,0)"
- },
- itemStyle: {
- color: "rgba(255,215,0,0.8)"
- }
- },
- regions: []
- },
- getRegionModel: function(t) {
- return this._optionModelMap.get(t) || new Lo(null, this, this.ecModel)
- },
- getFormattedLabel: function(t, e) {
- var i = this.getRegionModel(t).get("label." + e + ".formatter"),
- n = {
- name: t
- };
- return "function" == typeof i ? (n.status = e, i(n)) : "string" == typeof i ? i.replace("{a}", null != t ? t :
- "") : void 0
- },
- setZoom: function(t) {
- this.option.zoom = t
- },
- setCenter: function(t) {
- this.option.center = t
- }
- }), HD), Vs({
- type: "geo",
- init: function(t, e) {
- var i = new _c(e, !0);
- this._mapDraw = i, this.group.add(i.group)
- },
- render: function(t, e, i, n) {
- if (!n || "geoToggleSelect" !== n.type || n.from !== this.uid) {
- var o = this._mapDraw;
- t.get("show") ? o.draw(t, e, i, this, n) : this._mapDraw.group.removeAll(), this.group.silent = t.get("silent")
- }
- },
- dispose: function() {
- this._mapDraw && this._mapDraw.remove()
- }
- }), Hv("toggleSelected", {
- type: "geoToggleSelect",
- event: "geoselectchanged"
- }), Hv("select", {
- type: "geoSelect",
- event: "geoselected"
- }), Hv("unSelect", {
- type: "geoUnSelect",
- event: "geounselected"
- });
- var aN = ["rect", "polygon", "keep", "clear"],
- rN = d,
- sN = {
- lineX: Kv(0),
- lineY: Kv(1),
- rect: {
- point: function(t, e, i) {
- return t && i.boundingRect.contain(t[0], t[1])
- },
- rect: function(t, e, i) {
- return t && i.boundingRect.intersect(t)
- }
- },
- polygon: {
- point: function(t, e, i) {
- return t && i.boundingRect.contain(t[0], t[1]) && Yl(i.range, t[0], t[1])
- },
- rect: function(t, e, i) {
- var n = i.range;
- if (!t || n.length <= 1) return !1;
- var o = t.x,
- a = t.y,
- r = t.width,
- s = t.height,
- l = n[0];
- return !!(Yl(n, o, a) || Yl(n, o + r, a) || Yl(n, o, a + s) || Yl(n, o + r, a + s) || ue.create(t).contain(l[0],
- l[1]) || Jv(o, a, o + r, a, n) || Jv(o, a, o, a + s, n) || Jv(o + r, a, o + r, a + s, n) || Jv(o, a + s, o +
- r, a + s, n)) || void 0
- }
- }
- },
- lN = d,
- uN = l,
- hN = v,
- cN = ["dataToPoint", "pointToData"],
- dN = ["grid", "xAxis", "yAxis", "geo", "graph", "polar", "radiusAxis", "angleAxis", "bmap"],
- fN = iy.prototype;
- fN.setOutputRanges = function(t, e) {
- this.matchOutputRanges(t, e, function(t, e, i) {
- if ((t.coordRanges || (t.coordRanges = [])).push(e), !t.coordRange) {
- t.coordRange = e;
- var n = vN[t.brushType](0, i, e);
- t.__rangeOffset = {
- offset: yN[t.brushType](n.values, t.range, [1, 1]),
- xyMinMax: n.xyMinMax
- }
- }
- })
- }, fN.matchOutputRanges = function(t, e, i) {
- lN(t, function(t) {
- var n = this.findTargetInfo(t, e);
- n && !0 !== n && d(n.coordSyses, function(n) {
- var o = vN[t.brushType](1, n, t.range);
- i(t, o.values, n, e)
- })
- }, this)
- }, fN.setInputRanges = function(t, e) {
- lN(t, function(t) {
- var i = this.findTargetInfo(t, e);
- if (t.range = t.range || [], i && !0 !== i) {
- t.panelId = i.panelId;
- var n = vN[t.brushType](0, i.coordSys, t.coordRange),
- o = t.__rangeOffset;
- t.range = o ? yN[t.brushType](n.values, o.offset, sy(n.xyMinMax, o.xyMinMax)) : n.values
- }
- }, this)
- }, fN.makePanelOpts = function(t, e) {
- return f(this._targetInfoList, function(i) {
- var n = i.getPanelRect();
- return {
- panelId: i.panelId,
- defaultBrushType: e && e(i),
- clipPath: hp(n),
- isTargetByCursor: dp(n, t, i.coordSysModel),
- getLinearBrushOtherExtent: cp(n)
- }
- })
- }, fN.controlSeries = function(t, e, i) {
- var n = this.findTargetInfo(t, i);
- return !0 === n || n && uN(n.coordSyses, e.coordinateSystem) >= 0
- }, fN.findTargetInfo = function(t, e) {
- for (var i = this._targetInfoList, n = oy(e, t), o = 0; o < i.length; o++) {
- var a = i[o],
- r = t.panelId;
- if (r) {
- if (a.panelId === r) return a
- } else
- for (o = 0; o < gN.length; o++)
- if (gN[o](n, a)) return a
- }
- return !0
- };
- var pN = {
- grid: function(t, e) {
- var i = t.xAxisModels,
- n = t.yAxisModels,
- o = t.gridModels,
- a = R(),
- r = {},
- s = {};
- (i || n || o) && (lN(i, function(t) {
- var e = t.axis.grid.model;
- a.set(e.id, e), r[e.id] = !0
- }), lN(n, function(t) {
- var e = t.axis.grid.model;
- a.set(e.id, e), s[e.id] = !0
- }), lN(o, function(t) {
- a.set(t.id, t), r[t.id] = !0, s[t.id] = !0
- }), a.each(function(t) {
- var o = t.coordinateSystem,
- a = [];
- lN(o.getCartesians(), function(t, e) {
- (uN(i, t.getAxis("x").model) >= 0 || uN(n, t.getAxis("y").model) >= 0) && a.push(t)
- }), e.push({
- panelId: "grid--" + t.id,
- gridModel: t,
- coordSysModel: t,
- coordSys: a[0],
- coordSyses: a,
- getPanelRect: mN.grid,
- xAxisDeclared: r[t.id],
- yAxisDeclared: s[t.id]
- })
- }))
- },
- geo: function(t, e) {
- lN(t.geoModels, function(t) {
- var i = t.coordinateSystem;
- e.push({
- panelId: "geo--" + t.id,
- geoModel: t,
- coordSysModel: t,
- coordSys: i,
- coordSyses: [i],
- getPanelRect: mN.geo
- })
- })
- }
- },
- gN = [function(t, e) {
- var i = t.xAxisModel,
- n = t.yAxisModel,
- o = t.gridModel;
- return !o && i && (o = i.axis.grid.model), !o && n && (o = n.axis.grid.model), o && o === e.gridModel
- }, function(t, e) {
- var i = t.geoModel;
- return i && i === e.geoModel
- }],
- mN = {
- grid: function() {
- return this.coordSys.grid.getRect().clone()
- },
- geo: function() {
- var t = this.coordSys,
- e = t.getBoundingRect().clone();
- return e.applyTransform(Mo(t)), e
- }
- },
- vN = {
- lineX: hN(ay, 0),
- lineY: hN(ay, 1),
- rect: function(t, e, i) {
- var n = e[cN[t]]([i[0][0], i[1][0]]),
- o = e[cN[t]]([i[0][1], i[1][1]]),
- a = [ny([n[0], o[0]]), ny([n[1], o[1]])];
- return {
- values: a,
- xyMinMax: a
- }
- },
- polygon: function(t, e, i) {
- var n = [
- [1 / 0, -1 / 0],
- [1 / 0, -1 / 0]
- ];
- return {
- values: f(i, function(i) {
- var o = e[cN[t]](i);
- return n[0][0] = Math.min(n[0][0], o[0]), n[1][0] = Math.min(n[1][0], o[1]), n[0][1] = Math.max(n[0][1], o[0]),
- n[1][1] = Math.max(n[1][1], o[1]), o
- }),
- xyMinMax: n
- }
- }
- },
- yN = {
- lineX: hN(ry, 0),
- lineY: hN(ry, 1),
- rect: function(t, e, i) {
- return [
- [t[0][0] - i[0] * e[0][0], t[0][1] - i[0] * e[0][1]],
- [t[1][0] - i[1] * e[1][0], t[1][1] - i[1] * e[1][1]]
- ]
- },
- polygon: function(t, e, i) {
- return f(t, function(t, n) {
- return [t[0] - i[0] * e[n][0], t[1] - i[1] * e[n][1]]
- })
- }
- },
- xN = ["inBrush", "outOfBrush"],
- _N = "__ecBrushSelect",
- wN = "__ecInBrushSelectEvent",
- bN = IT.VISUAL.BRUSH;
- Os(bN, function(t, e, i) {
- t.eachComponent({
- mainType: "brush"
- }, function(e) {
- i && "takeGlobalCursor" === i.type && e.setBrushOption("brush" === i.key ? i.brushOption : {
- brushType: !1
- }), (e.brushTargetManager = new iy(e.option, t)).setInputRanges(e.areas, t)
- })
- }), Es(bN, function(t, e, n) {
- var o, a, s = [];
- t.eachComponent({
- mainType: "brush"
- }, function(e, n) {
- function l(t) {
- return "all" === m || v[t]
- }
- function u(t) {
- return !!t.length
- }
- function h(t, e) {
- var i = t.coordinateSystem;
- w |= i.hasAxisBrushed(), l(e) && i.eachActiveState(t.getData(), function(t, e) {
- "active" === t && (x[e] = 1)
- })
- }
- function c(i, n, o) {
- var a = dy(i);
- if (a && !fy(e, n) && (d(b, function(n) {
- a[n.brushType] && e.brushTargetManager.controlSeries(n, i, t) && o.push(n), w |= u(o)
- }), l(n) && u(o))) {
- var r = i.getData();
- r.each(function(t) {
- cy(a, o, r, t) && (x[t] = 1)
- })
- }
- }
- var p = {
- brushId: e.id,
- brushIndex: n,
- brushName: e.name,
- areas: i(e.areas),
- selected: []
- };
- s.push(p);
- var g = e.option,
- m = g.brushLink,
- v = [],
- x = [],
- _ = [],
- w = 0;
- n || (o = g.throttleType, a = g.throttleDelay);
- var b = f(e.areas, function(t) {
- return py(r({
- boundingRect: SN[t.brushType](t)
- }, t))
- }),
- S = Xv(e.option, xN, function(t) {
- t.mappingMethod = "fixed"
- });
- y(m) && d(m, function(t) {
- v[t] = 1
- }), t.eachSeries(function(t, e) {
- var i = _[e] = [];
- "parallel" === t.subType ? h(t, e) : c(t, e, i)
- }), t.eachSeries(function(t, e) {
- var i = {
- seriesId: t.id,
- seriesIndex: e,
- seriesName: t.name,
- dataIndex: []
- };
- p.selected.push(i);
- var n = dy(t),
- o = _[e],
- a = t.getData(),
- r = l(e) ? function(t) {
- return x[t] ? (i.dataIndex.push(a.getRawIndex(t)), "inBrush") : "outOfBrush"
- } : function(t) {
- return cy(n, o, a, t) ? (i.dataIndex.push(a.getRawIndex(t)), "inBrush") : "outOfBrush"
- };
- (l(e) ? w : u(o)) && Yv(xN, S, a, r)
- })
- }), uy(e, o, a, s, n)
- });
- var SN = {
- lineX: B,
- lineY: B,
- rect: function(t) {
- return gy(t.range)
- },
- polygon: function(t) {
- for (var e, i = t.range, n = 0, o = i.length; n < o; n++) {
- e = e || [
- [1 / 0, -1 / 0],
- [1 / 0, -1 / 0]
- ];
- var a = i[n];
- a[0] < e[0][0] && (e[0][0] = a[0]), a[0] > e[0][1] && (e[0][1] = a[0]), a[1] < e[1][0] && (e[1][0] = a[1]), a[1] >
- e[1][1] && (e[1][1] = a[1])
- }
- return e && gy(e)
- }
- },
- MN = ["#ddd"];
- Bs({
- type: "brush",
- dependencies: ["geo", "grid", "xAxis", "yAxis", "parallel", "series"],
- defaultOption: {
- toolbox: null,
- brushLink: null,
- seriesIndex: "all",
- geoIndex: null,
- xAxisIndex: null,
- yAxisIndex: null,
- brushType: "rect",
- brushMode: "single",
- transformable: !0,
- brushStyle: {
- borderWidth: 1,
- color: "rgba(120,140,180,0.3)",
- borderColor: "rgba(120,140,180,0.8)"
- },
- throttleType: "fixRate",
- throttleDelay: 0,
- removeOnClick: !0,
- z: 1e4
- },
- areas: [],
- brushType: null,
- brushOption: {},
- coordInfoList: [],
- optionUpdated: function(t, e) {
- var i = this.option;
- !e && jv(i, t, ["inBrush", "outOfBrush"]);
- var n = i.inBrush = i.inBrush || {};
- i.outOfBrush = i.outOfBrush || {
- color: MN
- }, n.hasOwnProperty("liftZ") || (n.liftZ = 5)
- },
- setAreas: function(t) {
- t && (this.areas = f(t, function(t) {
- return my(this.option, t)
- }, this))
- },
- setBrushOption: function(t) {
- this.brushOption = my(this.option, t), this.brushType = this.brushOption.brushType
- }
- });
- Vs({
- type: "brush",
- init: function(t, e) {
- this.ecModel = t, this.api = e, this.model, (this._brushController = new Cf(e.getZr())).on("brush", m(this._onBrush,
- this)).mount()
- },
- render: function(t) {
- return this.model = t, vy.apply(this, arguments)
- },
- updateTransform: vy,
- updateView: vy,
- dispose: function() {
- this._brushController.dispose()
- },
- _onBrush: function(t, e) {
- var n = this.model.id;
- this.model.brushTargetManager.setOutputRanges(t, this.ecModel), (!e.isEnd || e.removeOnClick) && this.api.dispatchAction({
- type: "brush",
- brushId: n,
- areas: i(t),
- $from: n
- })
- }
- }), Ps({
- type: "brush",
- event: "brush"
- }, function(t, e) {
- e.eachComponent({
- mainType: "brush",
- query: t
- }, function(e) {
- e.setAreas(t.areas)
- })
- }), Ps({
- type: "brushSelect",
- event: "brushSelected",
- update: "none"
- }, function() {});
- var IN = {},
- TN = XI.toolbox.brush;
- _y.defaultOption = {
- show: !0,
- type: ["rect", "polygon", "lineX", "lineY", "keep", "clear"],
- icon: {
- rect: "M7.3,34.7 M0.4,10V-0.2h9.8 M89.6,10V-0.2h-9.8 M0.4,60v10.2h9.8 M89.6,60v10.2h-9.8 M12.3,22.4V10.5h13.1 M33.6,10.5h7.8 M49.1,10.5h7.8 M77.5,22.4V10.5h-13 M12.3,31.1v8.2 M77.7,31.1v8.2 M12.3,47.6v11.9h13.1 M33.6,59.5h7.6 M49.1,59.5 h7.7 M77.5,47.6v11.9h-13",
- polygon: "M55.2,34.9c1.7,0,3.1,1.4,3.1,3.1s-1.4,3.1-3.1,3.1 s-3.1-1.4-3.1-3.1S53.5,34.9,55.2,34.9z M50.4,51c1.7,0,3.1,1.4,3.1,3.1c0,1.7-1.4,3.1-3.1,3.1c-1.7,0-3.1-1.4-3.1-3.1 C47.3,52.4,48.7,51,50.4,51z M55.6,37.1l1.5-7.8 M60.1,13.5l1.6-8.7l-7.8,4 M59,19l-1,5.3 M24,16.1l6.4,4.9l6.4-3.3 M48.5,11.6 l-5.9,3.1 M19.1,12.8L9.7,5.1l1.1,7.7 M13.4,29.8l1,7.3l6.6,1.6 M11.6,18.4l1,6.1 M32.8,41.9 M26.6,40.4 M27.3,40.2l6.1,1.6 M49.9,52.1l-5.6-7.6l-4.9-1.2",
- lineX: "M15.2,30 M19.7,15.6V1.9H29 M34.8,1.9H40.4 M55.3,15.6V1.9H45.9 M19.7,44.4V58.1H29 M34.8,58.1H40.4 M55.3,44.4 V58.1H45.9 M12.5,20.3l-9.4,9.6l9.6,9.8 M3.1,29.9h16.5 M62.5,20.3l9.4,9.6L62.3,39.7 M71.9,29.9H55.4",
- lineY: "M38.8,7.7 M52.7,12h13.2v9 M65.9,26.6V32 M52.7,46.3h13.2v-9 M24.9,12H11.8v9 M11.8,26.6V32 M24.9,46.3H11.8v-9 M48.2,5.1l-9.3-9l-9.4,9.2 M38.9-3.9V12 M48.2,53.3l-9.3,9l-9.4-9.2 M38.9,62.3V46.4",
- keep: "M4,10.5V1h10.3 M20.7,1h6.1 M33,1h6.1 M55.4,10.5V1H45.2 M4,17.3v6.6 M55.6,17.3v6.6 M4,30.5V40h10.3 M20.7,40 h6.1 M33,40h6.1 M55.4,30.5V40H45.2 M21,18.9h62.9v48.6H21V18.9z",
- clear: "M22,14.7l30.9,31 M52.9,14.7L22,45.7 M4.7,16.8V4.2h13.1 M26,4.2h7.8 M41.6,4.2h7.8 M70.3,16.8V4.2H57.2 M4.7,25.9v8.6 M70.3,25.9v8.6 M4.7,43.2v12.6h13.1 M26,55.8h7.8 M41.6,55.8h7.8 M70.3,43.2v12.6H57.2"
- },
- title: i(TN.title)
- };
- var AN = _y.prototype;
- AN.render = AN.updateView = function(t, e, i) {
- var n, o, a;
- e.eachComponent({
- mainType: "brush"
- }, function(t) {
- n = t.brushType, o = t.brushOption.brushMode || "single", a |= t.areas.length
- }), this._brushType = n, this._brushMode = o, d(t.get("type", !0), function(e) {
- t.setIconStatus(e, ("keep" === e ? "multiple" === o : "clear" === e ? a : e === n) ? "emphasis" : "normal")
- })
- }, AN.getIcons = function() {
- var t = this.model,
- e = t.get("icon", !0),
- i = {};
- return d(t.get("type", !0), function(t) {
- e[t] && (i[t] = e[t])
- }), i
- }, AN.onclick = function(t, e, i) {
- var n = this._brushType,
- o = this._brushMode;
- "clear" === i ? (e.dispatchAction({
- type: "axisAreaSelect",
- intervals: []
- }), e.dispatchAction({
- type: "brush",
- command: "clear",
- areas: []
- })) : e.dispatchAction({
- type: "takeGlobalCursor",
- key: "brush",
- brushOption: {
- brushType: "keep" === i ? n : n !== i && i,
- brushMode: "keep" === i ? "multiple" === o ? "single" : "multiple" : o
- }
- })
- }, yy("brush", _y), Ls(function(t, e) {
- var i = t && t.brush;
- if (y(i) || (i = i ? [i] : []), i.length) {
- var n = [];
- d(i, function(t) {
- var e = t.hasOwnProperty("toolbox") ? t.toolbox : [];
- e instanceof Array && (n = n.concat(e))
- });
- var o = t && t.toolbox;
- y(o) && (o = o[0]), o || (o = {
- feature: {}
- }, t.toolbox = [o]);
- var a = o.feature || (o.feature = {}),
- r = a.brush || (a.brush = {}),
- s = r.type || (r.type = []);
- s.push.apply(s, n), Zv(s), e && !s.length && s.push.apply(s, aN)
- }
- });
- wy.prototype = {
- constructor: wy,
- type: "calendar",
- dimensions: ["time", "value"],
- getDimensionsInfo: function() {
- return [{
- name: "time",
- type: "time"
- }, "value"]
- },
- getRangeInfo: function() {
- return this._rangeInfo
- },
- getModel: function() {
- return this._model
- },
- getRect: function() {
- return this._rect
- },
- getCellWidth: function() {
- return this._sw
- },
- getCellHeight: function() {
- return this._sh
- },
- getOrient: function() {
- return this._orient
- },
- getFirstDayOfWeek: function() {
- return this._firstDayOfWeek
- },
- getDateInfo: function(t) {
- var e = (t = Uo(t)).getFullYear(),
- i = t.getMonth() + 1;
- i = i < 10 ? "0" + i : i;
- var n = t.getDate();
- n = n < 10 ? "0" + n : n;
- var o = t.getDay();
- return o = Math.abs((o + 7 - this.getFirstDayOfWeek()) % 7), {
- y: e,
- m: i,
- d: n,
- day: o,
- time: t.getTime(),
- formatedDate: e + "-" + i + "-" + n,
- date: t
- }
- },
- getNextNDay: function(t, e) {
- return 0 === (e = e || 0) ? this.getDateInfo(t) : ((t = new Date(this.getDateInfo(t).time)).setDate(t.getDate() +
- e), this.getDateInfo(t))
- },
- update: function(t, e) {
- function i(t, e) {
- return null != t[e] && "auto" !== t[e]
- }
- this._firstDayOfWeek = +this._model.getModel("dayLabel").get("firstDay"), this._orient = this._model.get("orient"),
- this._lineWidth = this._model.getModel("itemStyle").getItemStyle().lineWidth || 0, this._rangeInfo = this._getRangeInfo(
- this._initRangeOption());
- var n = this._rangeInfo.weeks || 1,
- o = ["width", "height"],
- a = this._model.get("cellSize").slice(),
- r = this._model.getBoxLayoutParams(),
- s = "horizontal" === this._orient ? [n, 7] : [7, n];
- d([0, 1], function(t) {
- i(a, t) && (r[o[t]] = a[t] * s[t])
- });
- var l = {
- width: e.getWidth(),
- height: e.getHeight()
- },
- u = this._rect = la(r, l);
- d([0, 1], function(t) {
- i(a, t) || (a[t] = u[o[t]] / s[t])
- }), this._sw = a[0], this._sh = a[1]
- },
- dataToPoint: function(t, e) {
- y(t) && (t = t[0]), null == e && (e = !0);
- var i = this.getDateInfo(t),
- n = this._rangeInfo,
- o = i.formatedDate;
- if (e && !(i.time >= n.start.time && i.time < n.end.time + 864e5)) return [NaN, NaN];
- var a = i.day,
- r = this._getRangeInfo([n.start.time, o]).nthWeek;
- return "vertical" === this._orient ? [this._rect.x + a * this._sw + this._sw / 2, this._rect.y + r * this._sh +
- this._sh / 2
- ] : [this._rect.x + r * this._sw + this._sw / 2, this._rect.y + a * this._sh + this._sh / 2]
- },
- pointToData: function(t) {
- var e = this.pointToDate(t);
- return e && e.time
- },
- dataToRect: function(t, e) {
- var i = this.dataToPoint(t, e);
- return {
- contentShape: {
- x: i[0] - (this._sw - this._lineWidth) / 2,
- y: i[1] - (this._sh - this._lineWidth) / 2,
- width: this._sw - this._lineWidth,
- height: this._sh - this._lineWidth
- },
- center: i,
- tl: [i[0] - this._sw / 2, i[1] - this._sh / 2],
- tr: [i[0] + this._sw / 2, i[1] - this._sh / 2],
- br: [i[0] + this._sw / 2, i[1] + this._sh / 2],
- bl: [i[0] - this._sw / 2, i[1] + this._sh / 2]
- }
- },
- pointToDate: function(t) {
- var e = Math.floor((t[0] - this._rect.x) / this._sw) + 1,
- i = Math.floor((t[1] - this._rect.y) / this._sh) + 1,
- n = this._rangeInfo.range;
- return "vertical" === this._orient ? this._getDateByWeeksAndDay(i, e - 1, n) : this._getDateByWeeksAndDay(e, i -
- 1, n)
- },
- convertToPixel: v(by, "dataToPoint"),
- convertFromPixel: v(by, "pointToData"),
- _initRangeOption: function() {
- var t = this._model.get("range"),
- e = t;
- if (y(e) && 1 === e.length && (e = e[0]), /^\d{4}$/.test(e) && (t = [e + "-01-01", e + "-12-31"]),
- /^\d{4}[\/|-]\d{1,2}$/.test(e)) {
- var i = this.getDateInfo(e),
- n = i.date;
- n.setMonth(n.getMonth() + 1);
- var o = this.getNextNDay(n, -1);
- t = [i.formatedDate, o.formatedDate]
- }
- /^\d{4}[\/|-]\d{1,2}[\/|-]\d{1,2}$/.test(e) && (t = [e, e]);
- var a = this._getRangeInfo(t);
- return a.start.time > a.end.time && t.reverse(), t
- },
- _getRangeInfo: function(t) {
- var e;
- (t = [this.getDateInfo(t[0]), this.getDateInfo(t[1])])[0].time > t[1].time && (e = !0, t.reverse());
- var i = Math.floor(t[1].time / 864e5) - Math.floor(t[0].time / 864e5) + 1,
- n = new Date(t[0].time),
- o = n.getDate(),
- a = t[1].date.getDate();
- if (n.setDate(o + i - 1), n.getDate() !== a)
- for (var r = n.getTime() - t[1].time > 0 ? 1 : -1; n.getDate() !== a && (n.getTime() - t[1].time) * r > 0;) i -=
- r, n.setDate(o + i - 1);
- var s = Math.floor((i + t[0].day + 6) / 7),
- l = e ? 1 - s : s - 1;
- return e && t.reverse(), {
- range: [t[0].formatedDate, t[1].formatedDate],
- start: t[0],
- end: t[1],
- allDay: i,
- weeks: s,
- nthWeek: l,
- fweek: t[0].day,
- lweek: t[1].day
- }
- },
- _getDateByWeeksAndDay: function(t, e, i) {
- var n = this._getRangeInfo(i);
- if (t > n.weeks || 0 === t && e < n.fweek || t === n.weeks && e > n.lweek) return !1;
- var o = 7 * (t - 1) - n.fweek + e,
- a = new Date(n.start.time);
- return a.setDate(n.start.d + o), this.getDateInfo(a)
- }
- }, wy.dimensions = wy.prototype.dimensions, wy.getDimensionsInfo = wy.prototype.getDimensionsInfo, wy.create =
- function(t, e) {
- var i = [];
- return t.eachComponent("calendar", function(n) {
- var o = new wy(n, t, e);
- i.push(o), n.coordinateSystem = o
- }), t.eachSeries(function(t) {
- "calendar" === t.get("coordinateSystem") && (t.coordinateSystem = i[t.get("calendarIndex") || 0])
- }), i
- }, Ba.register("calendar", wy);
- var DN = YM.extend({
- type: "calendar",
- coordinateSystem: null,
- defaultOption: {
- zlevel: 0,
- z: 2,
- left: 80,
- top: 60,
- cellSize: 20,
- orient: "horizontal",
- splitLine: {
- show: !0,
- lineStyle: {
- color: "#000",
- width: 1,
- type: "solid"
- }
- },
- itemStyle: {
- color: "#fff",
- borderWidth: 1,
- borderColor: "#ccc"
- },
- dayLabel: {
- show: !0,
- firstDay: 0,
- position: "start",
- margin: "50%",
- nameMap: "en",
- color: "#000"
- },
- monthLabel: {
- show: !0,
- position: "start",
- margin: 5,
- align: "center",
- nameMap: "en",
- formatter: null,
- color: "#000"
- },
- yearLabel: {
- show: !0,
- position: null,
- margin: 30,
- formatter: null,
- color: "#ccc",
- fontFamily: "sans-serif",
- fontWeight: "bolder",
- fontSize: 20
- }
- },
- init: function(t, e, i, n) {
- var o = da(t);
- DN.superApply(this, "init", arguments), Sy(t, o)
- },
- mergeOption: function(t, e) {
- DN.superApply(this, "mergeOption", arguments), Sy(this.option, t)
- }
- }),
- CN = {
- EN: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
- CN: ["一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月"]
- },
- LN = {
- EN: ["S", "M", "T", "W", "T", "F", "S"],
- CN: ["日", "一", "二", "三", "四", "五", "六"]
- };
- Vs({
- type: "calendar",
- _tlpoints: null,
- _blpoints: null,
- _firstDayOfMonth: null,
- _firstDayPoints: null,
- render: function(t, e, i) {
- var n = this.group;
- n.removeAll();
- var o = t.coordinateSystem,
- a = o.getRangeInfo(),
- r = o.getOrient();
- this._renderDayRect(t, a, n), this._renderLines(t, a, r, n), this._renderYearText(t, a, r, n), this._renderMonthText(
- t, r, n), this._renderWeekText(t, a, r, n)
- },
- _renderDayRect: function(t, e, i) {
- for (var n = t.coordinateSystem, o = t.getModel("itemStyle").getItemStyle(), a = n.getCellWidth(), r = n.getCellHeight(),
- s = e.start.time; s <= e.end.time; s = n.getNextNDay(s, 1).time) {
- var l = n.dataToRect([s], !1).tl,
- u = new aM({
- shape: {
- x: l[0],
- y: l[1],
- width: a,
- height: r
- },
- cursor: "default",
- style: o
- });
- i.add(u)
- }
- },
- _renderLines: function(t, e, i, n) {
- function o(e) {
- a._firstDayOfMonth.push(r.getDateInfo(e)), a._firstDayPoints.push(r.dataToRect([e], !1).tl);
- var o = a._getLinePointsOfOneWeek(t, e, i);
- a._tlpoints.push(o[0]), a._blpoints.push(o[o.length - 1]), l && a._drawSplitline(o, s, n)
- }
- var a = this,
- r = t.coordinateSystem,
- s = t.getModel("splitLine.lineStyle").getLineStyle(),
- l = t.get("splitLine.show"),
- u = s.lineWidth;
- this._tlpoints = [], this._blpoints = [], this._firstDayOfMonth = [], this._firstDayPoints = [];
- for (var h = e.start, c = 0; h.time <= e.end.time; c++) {
- o(h.formatedDate), 0 === c && (h = r.getDateInfo(e.start.y + "-" + e.start.m));
- var d = h.date;
- d.setMonth(d.getMonth() + 1), h = r.getDateInfo(d)
- }
- o(r.getNextNDay(e.end.time, 1).formatedDate), l && this._drawSplitline(a._getEdgesPoints(a._tlpoints, u, i), s,
- n), l && this._drawSplitline(a._getEdgesPoints(a._blpoints, u, i), s, n)
- },
- _getEdgesPoints: function(t, e, i) {
- var n = [t[0].slice(), t[t.length - 1].slice()],
- o = "horizontal" === i ? 0 : 1;
- return n[0][o] = n[0][o] - e / 2, n[1][o] = n[1][o] + e / 2, n
- },
- _drawSplitline: function(t, e, i) {
- var n = new oM({
- z2: 20,
- shape: {
- points: t
- },
- style: e
- });
- i.add(n)
- },
- _getLinePointsOfOneWeek: function(t, e, i) {
- var n = t.coordinateSystem;
- e = n.getDateInfo(e);
- for (var o = [], a = 0; a < 7; a++) {
- var r = n.getNextNDay(e.time, a),
- s = n.dataToRect([r.time], !1);
- o[2 * r.day] = s.tl, o[2 * r.day + 1] = s["horizontal" === i ? "bl" : "tr"]
- }
- return o
- },
- _formatterLabel: function(t, e) {
- return "string" == typeof t && t ? ea(t, e) : "function" == typeof t ? t(e) : e.nameMap
- },
- _yearTextPositionControl: function(t, e, i, n, o) {
- e = e.slice();
- var a = ["center", "bottom"];
- "bottom" === n ? (e[1] += o, a = ["center", "top"]) : "left" === n ? e[0] -= o : "right" === n ? (e[0] += o, a = [
- "center", "top"
- ]) : e[1] -= o;
- var r = 0;
- return "left" !== n && "right" !== n || (r = Math.PI / 2), {
- rotation: r,
- position: e,
- style: {
- textAlign: a[0],
- textVerticalAlign: a[1]
- }
- }
- },
- _renderYearText: function(t, e, i, n) {
- var o = t.getModel("yearLabel");
- if (o.get("show")) {
- var a = o.get("margin"),
- r = o.get("position");
- r || (r = "horizontal" !== i ? "top" : "left");
- var s = [this._tlpoints[this._tlpoints.length - 1], this._blpoints[0]],
- l = (s[0][0] + s[1][0]) / 2,
- u = (s[0][1] + s[1][1]) / 2,
- h = "horizontal" === i ? 0 : 1,
- c = {
- top: [l, s[h][1]],
- bottom: [l, s[1 - h][1]],
- left: [s[1 - h][0], u],
- right: [s[h][0], u]
- },
- d = e.start.y; + e.end.y > +e.start.y && (d = d + "-" + e.end.y);
- var f = o.get("formatter"),
- p = {
- start: e.start.y,
- end: e.end.y,
- nameMap: d
- },
- g = this._formatterLabel(f, p),
- m = new qS({
- z2: 30
- });
- fo(m.style, o, {
- text: g
- }), m.attr(this._yearTextPositionControl(m, c[r], i, r, a)), n.add(m)
- }
- },
- _monthTextPositionControl: function(t, e, i, n, o) {
- var a = "left",
- r = "top",
- s = t[0],
- l = t[1];
- return "horizontal" === i ? (l += o, e && (a = "center"), "start" === n && (r = "bottom")) : (s += o, e && (r =
- "middle"), "start" === n && (a = "right")), {
- x: s,
- y: l,
- textAlign: a,
- textVerticalAlign: r
- }
- },
- _renderMonthText: function(t, e, i) {
- var n = t.getModel("monthLabel");
- if (n.get("show")) {
- var o = n.get("nameMap"),
- r = n.get("margin"),
- s = n.get("position"),
- l = n.get("align"),
- u = [this._tlpoints, this._blpoints];
- _(o) && (o = CN[o.toUpperCase()] || []);
- var h = "start" === s ? 0 : 1,
- c = "horizontal" === e ? 0 : 1;
- r = "start" === s ? -r : r;
- for (var d = "center" === l, f = 0; f < u[h].length - 1; f++) {
- var p = u[h][f].slice(),
- g = this._firstDayOfMonth[f];
- if (d) {
- var m = this._firstDayPoints[f];
- p[c] = (m[c] + u[0][f + 1][c]) / 2
- }
- var v = n.get("formatter"),
- y = o[+g.m - 1],
- x = {
- yyyy: g.y,
- yy: (g.y + "").slice(2),
- MM: g.m,
- M: +g.m,
- nameMap: y
- },
- w = this._formatterLabel(v, x),
- b = new qS({
- z2: 30
- });
- a(fo(b.style, n, {
- text: w
- }), this._monthTextPositionControl(p, d, e, s, r)), i.add(b)
- }
- }
- },
- _weekTextPositionControl: function(t, e, i, n, o) {
- var a = "center",
- r = "middle",
- s = t[0],
- l = t[1],
- u = "start" === i;
- return "horizontal" === e ? (s = s + n + (u ? 1 : -1) * o[0] / 2, a = u ? "right" : "left") : (l = l + n + (u ?
- 1 : -1) * o[1] / 2, r = u ? "bottom" : "top"), {
- x: s,
- y: l,
- textAlign: a,
- textVerticalAlign: r
- }
- },
- _renderWeekText: function(t, e, i, n) {
- var o = t.getModel("dayLabel");
- if (o.get("show")) {
- var r = t.coordinateSystem,
- s = o.get("position"),
- l = o.get("nameMap"),
- u = o.get("margin"),
- h = r.getFirstDayOfWeek();
- _(l) && (l = LN[l.toUpperCase()] || []);
- var c = r.getNextNDay(e.end.time, 7 - e.lweek).time,
- d = [r.getCellWidth(), r.getCellHeight()];
- u = Ro(u, d["horizontal" === i ? 0 : 1]), "start" === s && (c = r.getNextNDay(e.start.time, -(7 + e.fweek)).time,
- u = -u);
- for (var f = 0; f < 7; f++) {
- var p = r.getNextNDay(c, f),
- g = r.dataToRect([p.time], !1).center,
- m = f;
- m = Math.abs((f + h) % 7);
- var v = new qS({
- z2: 30
- });
- a(fo(v.style, o, {
- text: l[m]
- }), this._weekTextPositionControl(g, i, s, u, d)), n.add(v)
- }
- }
- }
- }), Bs({
- type: "title",
- layoutMode: {
- type: "box",
- ignoreSize: !0
- },
- defaultOption: {
- zlevel: 0,
- z: 6,
- show: !0,
- text: "",
- target: "blank",
- subtext: "",
- subtarget: "blank",
- left: 0,
- top: 0,
- backgroundColor: "rgba(0,0,0,0)",
- borderColor: "#ccc",
- borderWidth: 0,
- padding: 5,
- itemGap: 10,
- textStyle: {
- fontSize: 18,
- fontWeight: "bolder",
- color: "#333"
- },
- subtextStyle: {
- color: "#aaa"
- }
- }
- }), Vs({
- type: "title",
- render: function(t, e, i) {
- if (this.group.removeAll(), t.get("show")) {
- var n = this.group,
- o = t.getModel("textStyle"),
- a = t.getModel("subtextStyle"),
- r = t.get("textAlign"),
- s = t.get("textBaseline"),
- l = new qS({
- style: fo({}, o, {
- text: t.get("text"),
- textFill: o.getTextColor()
- }, {
- disableBox: !0
- }),
- z2: 10
- }),
- u = l.getBoundingRect(),
- h = t.get("subtext"),
- c = new qS({
- style: fo({}, a, {
- text: h,
- textFill: a.getTextColor(),
- y: u.height + t.get("itemGap"),
- textVerticalAlign: "top"
- }, {
- disableBox: !0
- }),
- z2: 10
- }),
- d = t.get("link"),
- f = t.get("sublink"),
- p = t.get("triggerEvent", !0);
- l.silent = !d && !p, c.silent = !f && !p, d && l.on("click", function() {
- window.open(d, "_" + t.get("target"))
- }), f && c.on("click", function() {
- window.open(f, "_" + t.get("subtarget"))
- }), l.eventData = c.eventData = p ? {
- componentType: "title",
- componentIndex: t.componentIndex
- } : null, n.add(l), h && n.add(c);
- var g = n.getBoundingRect(),
- m = t.getBoxLayoutParams();
- m.width = g.width, m.height = g.height;
- var v = la(m, {
- width: i.getWidth(),
- height: i.getHeight()
- }, t.get("padding"));
- r || ("middle" === (r = t.get("left") || t.get("right")) && (r = "center"), "right" === r ? v.x += v.width :
- "center" === r && (v.x += v.width / 2)), s || ("center" === (s = t.get("top") || t.get("bottom")) && (s =
- "middle"), "bottom" === s ? v.y += v.height : "middle" === s && (v.y += v.height / 2), s = s || "top"), n.attr(
- "position", [v.x, v.y]);
- var y = {
- textAlign: r,
- textVerticalAlign: s
- };
- l.setStyle(y), c.setStyle(y), g = n.getBoundingRect();
- var x = v.margin,
- _ = t.getItemStyle(["color", "opacity"]);
- _.fill = t.get("backgroundColor");
- var w = new aM({
- shape: {
- x: g.x - x[3],
- y: g.y - x[0],
- width: g.width + x[1] + x[3],
- height: g.height + x[0] + x[2],
- r: t.get("borderRadius")
- },
- style: _,
- silent: !0
- });
- jn(w), n.add(w)
- }
- }
- }), YM.registerSubTypeDefaulter("dataZoom", function() {
- return "slider"
- });
- var kN = ["cartesian2d", "polar", "singleAxis"],
- PN = function(t, e) {
- var i = f(t = t.slice(), aa),
- n = f(e = (e || []).slice(), aa);
- return function(o, a) {
- d(t, function(t, r) {
- for (var s = {
- name: t,
- capital: i[r]
- }, l = 0; l < e.length; l++) s[e[l]] = t + n[l];
- o.call(a, s)
- })
- }
- }(["x", "y", "z", "radius", "angle", "single"], ["axisIndex", "axis", "index", "id"]),
- NN = d,
- ON = Bo,
- EN = function(t, e, i, n) {
- this._dimName = t, this._axisIndex = e, this._valueWindow, this._percentWindow, this._dataExtent, this._minMaxSpan,
- this.ecModel = n, this._dataZoomModel = i
- };
- EN.prototype = {
- constructor: EN,
- hostedBy: function(t) {
- return this._dataZoomModel === t
- },
- getDataValueWindow: function() {
- return this._valueWindow.slice()
- },
- getDataPercentWindow: function() {
- return this._percentWindow.slice()
- },
- getTargetSeriesModels: function() {
- var t = [],
- e = this.ecModel;
- return e.eachSeries(function(i) {
- if (My(i.get("coordinateSystem"))) {
- var n = this._dimName,
- o = e.queryComponents({
- mainType: n + "Axis",
- index: i.get(n + "AxisIndex"),
- id: i.get(n + "AxisId")
- })[0];
- this._axisIndex === (o && o.componentIndex) && t.push(i)
- }
- }, this), t
- },
- getAxisModel: function() {
- return this.ecModel.getComponent(this._dimName + "Axis", this._axisIndex)
- },
- getOtherAxisModel: function() {
- var t, e, i = this._dimName,
- n = this.ecModel,
- o = this.getAxisModel();
- "x" === i || "y" === i ? (e = "gridIndex", t = "x" === i ? "y" : "x") : (e = "polarIndex", t = "angle" === i ?
- "radius" : "angle");
- var a;
- return n.eachComponent(t + "Axis", function(t) {
- (t.get(e) || 0) === (o.get(e) || 0) && (a = t)
- }), a
- },
- getMinMaxSpan: function() {
- return i(this._minMaxSpan)
- },
- calculateDataWindow: function(t) {
- var e = this._dataExtent,
- i = this.getAxisModel().axis.scale,
- n = this._dataZoomModel.getRangePropMode(),
- o = [0, 100],
- a = [t.start, t.end],
- r = [];
- return NN(["startValue", "endValue"], function(e) {
- r.push(null != t[e] ? i.parse(t[e]) : null)
- }), NN([0, 1], function(t) {
- var s = r[t],
- l = a[t];
- "percent" === n[t] ? (null == l && (l = o[t]), s = i.parse(Eo(l, o, e, !0))) : l = Eo(s, e, o, !0), r[t] = s,
- a[t] = l
- }), {
- valueWindow: ON(r),
- percentWindow: ON(a)
- }
- },
- reset: function(t) {
- if (t === this._dataZoomModel) {
- var e = this.getTargetSeriesModels();
- this._dataExtent = Ty(this, this._dimName, e);
- var i = this.calculateDataWindow(t.option);
- this._valueWindow = i.valueWindow, this._percentWindow = i.percentWindow, Cy(this), Dy(this)
- }
- },
- restore: function(t) {
- t === this._dataZoomModel && (this._valueWindow = this._percentWindow = null, Dy(this, !0))
- },
- filterData: function(t, e) {
- function i(t) {
- return t >= r[0] && t <= r[1]
- }
- if (t === this._dataZoomModel) {
- var n = this._dimName,
- o = this.getTargetSeriesModels(),
- a = t.get("filterMode"),
- r = this._valueWindow;
- "none" !== a && NN(o, function(t) {
- var e = t.getData(),
- o = e.mapDimension(n, !0);
- o.length && ("weakFilter" === a ? e.filterSelf(function(t) {
- for (var i, n, a, s = 0; s < o.length; s++) {
- var l = e.get(o[s], t),
- u = !isNaN(l),
- h = l < r[0],
- c = l > r[1];
- if (u && !h && !c) return !0;
- u && (a = !0), h && (i = !0), c && (n = !0)
- }
- return a && i && n
- }) : NN(o, function(n) {
- if ("empty" === a) t.setData(e.map(n, function(t) {
- return i(t) ? t : NaN
- }));
- else {
- var o = {};
- o[n] = r, e.selectRange(o)
- }
- }), NN(o, function(t) {
- e.setApproximateExtent(r, t)
- }))
- })
- }
- }
- };
- var RN = d,
- zN = PN,
- BN = Bs({
- type: "dataZoom",
- dependencies: ["xAxis", "yAxis", "zAxis", "radiusAxis", "angleAxis", "singleAxis", "series"],
- defaultOption: {
- zlevel: 0,
- z: 4,
- orient: null,
- xAxisIndex: null,
- yAxisIndex: null,
- filterMode: "filter",
- throttle: null,
- start: 0,
- end: 100,
- startValue: null,
- endValue: null,
- minSpan: null,
- maxSpan: null,
- minValueSpan: null,
- maxValueSpan: null,
- rangeMode: null
- },
- init: function(t, e, i) {
- this._dataIntervalByAxis = {}, this._dataInfo = {}, this._axisProxies = {}, this.textStyleModel, this._autoThrottle = !
- 0, this._rangePropMode = ["percent", "percent"];
- var n = Ly(t);
- this.mergeDefaultAndTheme(t, i), this.doInit(n)
- },
- mergeOption: function(t) {
- var e = Ly(t);
- n(this.option, t, !0), this.doInit(e)
- },
- doInit: function(t) {
- var e = this.option;
- z_.canvasSupported || (e.realtime = !1), this._setDefaultThrottle(t), ky(this, t), RN([
- ["start", "startValue"],
- ["end", "endValue"]
- ], function(t, i) {
- "value" === this._rangePropMode[i] && (e[t[0]] = null)
- }, this), this.textStyleModel = this.getModel("textStyle"), this._resetTarget(), this._giveAxisProxies()
- },
- _giveAxisProxies: function() {
- var t = this._axisProxies;
- this.eachTargetAxis(function(e, i, n, o) {
- var a = this.dependentModels[e.axis][i],
- r = a.__dzAxisProxy || (a.__dzAxisProxy = new EN(e.name, i, this, o));
- t[e.name + "_" + i] = r
- }, this)
- },
- _resetTarget: function() {
- var t = this.option,
- e = this._judgeAutoMode();
- zN(function(e) {
- var i = e.axisIndex;
- t[i] = Di(t[i])
- }, this), "axisIndex" === e ? this._autoSetAxisIndex() : "orient" === e && this._autoSetOrient()
- },
- _judgeAutoMode: function() {
- var t = this.option,
- e = !1;
- zN(function(i) {
- null != t[i.axisIndex] && (e = !0)
- }, this);
- var i = t.orient;
- return null == i && e ? "orient" : e ? void 0 : (null == i && (t.orient = "horizontal"), "axisIndex")
- },
- _autoSetAxisIndex: function() {
- var t = !0,
- e = this.get("orient", !0),
- i = this.option,
- n = this.dependentModels;
- if (t) {
- var o = "vertical" === e ? "y" : "x";
- n[o + "Axis"].length ? (i[o + "AxisIndex"] = [0], t = !1) : RN(n.singleAxis, function(n) {
- t && n.get("orient", !0) === e && (i.singleAxisIndex = [n.componentIndex], t = !1)
- })
- }
- t && zN(function(e) {
- if (t) {
- var n = [],
- o = this.dependentModels[e.axis];
- if (o.length && !n.length)
- for (var a = 0, r = o.length; a < r; a++) "category" === o[a].get("type") && n.push(a);
- i[e.axisIndex] = n, n.length && (t = !1)
- }
- }, this), t && this.ecModel.eachSeries(function(t) {
- this._isSeriesHasAllAxesTypeOf(t, "value") && zN(function(e) {
- var n = i[e.axisIndex],
- o = t.get(e.axisIndex),
- a = t.get(e.axisId);
- l(n, o = t.ecModel.queryComponents({
- mainType: e.axis,
- index: o,
- id: a
- })[0].componentIndex) < 0 && n.push(o)
- })
- }, this)
- },
- _autoSetOrient: function() {
- var t;
- this.eachTargetAxis(function(e) {
- !t && (t = e.name)
- }, this), this.option.orient = "y" === t ? "vertical" : "horizontal"
- },
- _isSeriesHasAllAxesTypeOf: function(t, e) {
- var i = !0;
- return zN(function(n) {
- var o = t.get(n.axisIndex),
- a = this.dependentModels[n.axis][o];
- a && a.get("type") === e || (i = !1)
- }, this), i
- },
- _setDefaultThrottle: function(t) {
- if (t.hasOwnProperty("throttle") && (this._autoThrottle = !1), this._autoThrottle) {
- var e = this.ecModel.option;
- this.option.throttle = e.animation && e.animationDurationUpdate > 0 ? 100 : 20
- }
- },
- getFirstTargetAxisModel: function() {
- var t;
- return zN(function(e) {
- if (null == t) {
- var i = this.get(e.axisIndex);
- i.length && (t = this.dependentModels[e.axis][i[0]])
- }
- }, this), t
- },
- eachTargetAxis: function(t, e) {
- var i = this.ecModel;
- zN(function(n) {
- RN(this.get(n.axisIndex), function(o) {
- t.call(e, n, o, this, i)
- }, this)
- }, this)
- },
- getAxisProxy: function(t, e) {
- return this._axisProxies[t + "_" + e]
- },
- getAxisModel: function(t, e) {
- var i = this.getAxisProxy(t, e);
- return i && i.getAxisModel()
- },
- setRawRange: function(t, e) {
- var i = this.option;
- RN([
- ["start", "startValue"],
- ["end", "endValue"]
- ], function(e) {
- null == t[e[0]] && null == t[e[1]] || (i[e[0]] = t[e[0]], i[e[1]] = t[e[1]])
- }, this), !e && ky(this, t)
- },
- getPercentRange: function() {
- var t = this.findRepresentativeAxisProxy();
- if (t) return t.getDataPercentWindow()
- },
- getValueRange: function(t, e) {
- if (null != t || null != e) return this.getAxisProxy(t, e).getDataValueWindow();
- var i = this.findRepresentativeAxisProxy();
- return i ? i.getDataValueWindow() : void 0
- },
- findRepresentativeAxisProxy: function(t) {
- if (t) return t.__dzAxisProxy;
- var e = this._axisProxies;
- for (var i in e)
- if (e.hasOwnProperty(i) && e[i].hostedBy(this)) return e[i];
- for (var i in e)
- if (e.hasOwnProperty(i) && !e[i].hostedBy(this)) return e[i]
- },
- getRangePropMode: function() {
- return this._rangePropMode.slice()
- }
- }),
- VN = EI.extend({
- type: "dataZoom",
- render: function(t, e, i, n) {
- this.dataZoomModel = t, this.ecModel = e, this.api = i
- },
- getTargetCoordInfo: function() {
- function t(t, e, i, n) {
- for (var o, a = 0; a < i.length; a++)
- if (i[a].model === t) {
- o = i[a];
- break
- } o || i.push(o = {
- model: t,
- axisModels: [],
- coordIndex: n
- }), o.axisModels.push(e)
- }
- var e = this.dataZoomModel,
- i = this.ecModel,
- n = {};
- return e.eachTargetAxis(function(e, o) {
- var a = i.getComponent(e.axis, o);
- if (a) {
- var r = a.getCoordSysModel();
- r && t(r, a, n[r.mainType] || (n[r.mainType] = []), r.componentIndex)
- }
- }, this), n
- }
- }),
- GN = (BN.extend({
- type: "dataZoom.slider",
- layoutMode: "box",
- defaultOption: {
- show: !0,
- right: "ph",
- top: "ph",
- width: "ph",
- height: "ph",
- left: null,
- bottom: null,
- backgroundColor: "rgba(47,69,84,0)",
- dataBackground: {
- lineStyle: {
- color: "#2f4554",
- width: .5,
- opacity: .3
- },
- areaStyle: {
- color: "rgba(47,69,84,0.3)",
- opacity: .3
- }
- },
- borderColor: "#ddd",
- fillerColor: "rgba(167,183,204,0.4)",
- handleIcon: "M8.2,13.6V3.9H6.3v9.7H3.1v14.9h3.3v9.7h1.8v-9.7h3.3V13.6H8.2z M9.7,24.4H4.8v-1.4h4.9V24.4z M9.7,19.1H4.8v-1.4h4.9V19.1z",
- handleSize: "100%",
- handleStyle: {
- color: "#a7b7cc"
- },
- labelPrecision: null,
- labelFormatter: null,
- showDetail: !0,
- showDataShadow: "auto",
- realtime: !0,
- zoomLock: !1,
- textStyle: {
- color: "#333"
- }
- }
- }), aM),
- FN = Eo,
- WN = Bo,
- HN = m,
- ZN = d,
- UN = "horizontal",
- XN = 5,
- jN = ["line", "bar", "candlestick", "scatter"],
- YN = VN.extend({
- type: "dataZoom.slider",
- init: function(t, e) {
- this._displayables = {}, this._orient, this._range, this._handleEnds, this._size, this._handleWidth, this._handleHeight,
- this._location, this._dragging, this._dataShadowInfo, this.api = e
- },
- render: function(t, e, i, n) {
- YN.superApply(this, "render", arguments), Lr(this, "_dispatchZoomAction", this.dataZoomModel.get("throttle"),
- "fixRate"), this._orient = t.get("orient"), !1 !== this.dataZoomModel.get("show") ? (n && "dataZoom" === n.type &&
- n.from === this.uid || this._buildView(), this._updateView()) : this.group.removeAll()
- },
- remove: function() {
- YN.superApply(this, "remove", arguments), kr(this, "_dispatchZoomAction")
- },
- dispose: function() {
- YN.superApply(this, "dispose", arguments), kr(this, "_dispatchZoomAction")
- },
- _buildView: function() {
- var t = this.group;
- t.removeAll(), this._resetLocation(), this._resetInterval();
- var e = this._displayables.barGroup = new Zw;
- this._renderBackground(), this._renderHandle(), this._renderDataShadow(), t.add(e), this._positionGroup()
- },
- _resetLocation: function() {
- var t = this.dataZoomModel,
- e = this.api,
- i = this._findCoordRect(),
- n = {
- width: e.getWidth(),
- height: e.getHeight()
- },
- o = this._orient === UN ? {
- right: n.width - i.x - i.width,
- top: n.height - 30 - 7,
- width: i.width,
- height: 30
- } : {
- right: 7,
- top: i.y,
- width: 30,
- height: i.height
- },
- a = da(t.option);
- d(["right", "top", "width", "height"], function(t) {
- "ph" === a[t] && (a[t] = o[t])
- });
- var r = la(a, n, t.padding);
- this._location = {
- x: r.x,
- y: r.y
- }, this._size = [r.width, r.height], "vertical" === this._orient && this._size.reverse()
- },
- _positionGroup: function() {
- var t = this.group,
- e = this._location,
- i = this._orient,
- n = this.dataZoomModel.getFirstTargetAxisModel(),
- o = n && n.get("inverse"),
- a = this._displayables.barGroup,
- r = (this._dataShadowInfo || {}).otherAxisInverse;
- a.attr(i !== UN || o ? i === UN && o ? {
- scale: r ? [-1, 1] : [-1, -1]
- } : "vertical" !== i || o ? {
- scale: r ? [-1, -1] : [-1, 1],
- rotation: Math.PI / 2
- } : {
- scale: r ? [1, -1] : [1, 1],
- rotation: Math.PI / 2
- } : {
- scale: r ? [1, 1] : [1, -1]
- });
- var s = t.getBoundingRect([a]);
- t.attr("position", [e.x - s.x, e.y - s.y])
- },
- _getViewExtent: function() {
- return [0, this._size[0]]
- },
- _renderBackground: function() {
- var t = this.dataZoomModel,
- e = this._size,
- i = this._displayables.barGroup;
- i.add(new GN({
- silent: !0,
- shape: {
- x: 0,
- y: 0,
- width: e[0],
- height: e[1]
- },
- style: {
- fill: t.get("backgroundColor")
- },
- z2: -40
- })), i.add(new GN({
- shape: {
- x: 0,
- y: 0,
- width: e[0],
- height: e[1]
- },
- style: {
- fill: "transparent"
- },
- z2: 0,
- onclick: m(this._onClickPanelClick, this)
- }))
- },
- _renderDataShadow: function() {
- var t = this._dataShadowInfo = this._prepareDataShadowInfo();
- if (t) {
- var e = this._size,
- i = t.series,
- n = i.getRawData(),
- o = i.getShadowDim ? i.getShadowDim() : t.otherDim;
- if (null != o) {
- var a = n.getDataExtent(o),
- s = .3 * (a[1] - a[0]);
- a = [a[0] - s, a[1] + s];
- var l, u = [0, e[1]],
- h = [0, e[0]],
- c = [
- [e[0], 0],
- [0, 0]
- ],
- d = [],
- f = h[1] / (n.count() - 1),
- p = 0,
- g = Math.round(n.count() / e[0]);
- n.each([o], function(t, e) {
- if (g > 0 && e % g) p += f;
- else {
- var i = null == t || isNaN(t) || "" === t,
- n = i ? 0 : FN(t, a, u, !0);
- i && !l && e ? (c.push([c[c.length - 1][0], 0]), d.push([d[d.length - 1][0], 0])) : !i && l && (c.push([p,
- 0
- ]), d.push([p, 0])), c.push([p, n]), d.push([p, n]), p += f, l = i
- }
- });
- var m = this.dataZoomModel;
- this._displayables.barGroup.add(new nM({
- shape: {
- points: c
- },
- style: r({
- fill: m.get("dataBackgroundColor")
- }, m.getModel("dataBackground.areaStyle").getAreaStyle()),
- silent: !0,
- z2: -20
- })), this._displayables.barGroup.add(new oM({
- shape: {
- points: d
- },
- style: m.getModel("dataBackground.lineStyle").getLineStyle(),
- silent: !0,
- z2: -19
- }))
- }
- }
- },
- _prepareDataShadowInfo: function() {
- var t = this.dataZoomModel,
- e = t.get("showDataShadow");
- if (!1 !== e) {
- var i, n = this.ecModel;
- return t.eachTargetAxis(function(o, a) {
- d(t.getAxisProxy(o.name, a).getTargetSeriesModels(), function(t) {
- if (!(i || !0 !== e && l(jN, t.get("type")) < 0)) {
- var r, s = n.getComponent(o.axis, a).axis,
- u = Py(o.name),
- h = t.coordinateSystem;
- null != u && h.getOtherAxis && (r = h.getOtherAxis(s).inverse), u = t.getData().mapDimension(u), i = {
- thisAxis: s,
- series: t,
- thisDim: o.name,
- otherDim: u,
- otherAxisInverse: r
- }
- }
- }, this)
- }, this), i
- }
- },
- _renderHandle: function() {
- var t = this._displayables,
- e = t.handles = [],
- i = t.handleLabels = [],
- n = this._displayables.barGroup,
- o = this._size,
- a = this.dataZoomModel;
- n.add(t.filler = new GN({
- draggable: !0,
- cursor: Ny(this._orient),
- drift: HN(this._onDragMove, this, "all"),
- onmousemove: function(t) {
- lw(t.event)
- },
- ondragstart: HN(this._showDataInfo, this, !0),
- ondragend: HN(this._onDragEnd, this),
- onmouseover: HN(this._showDataInfo, this, !0),
- onmouseout: HN(this._showDataInfo, this, !1),
- style: {
- fill: a.get("fillerColor"),
- textPosition: "inside"
- }
- })), n.add(new GN(jn({
- silent: !0,
- shape: {
- x: 0,
- y: 0,
- width: o[0],
- height: o[1]
- },
- style: {
- stroke: a.get("dataBackgroundColor") || a.get("borderColor"),
- lineWidth: 1,
- fill: "rgba(0,0,0,0)"
- }
- }))), ZN([0, 1], function(t) {
- var o = Co(a.get("handleIcon"), {
- cursor: Ny(this._orient),
- draggable: !0,
- drift: HN(this._onDragMove, this, t),
- onmousemove: function(t) {
- lw(t.event)
- },
- ondragend: HN(this._onDragEnd, this),
- onmouseover: HN(this._showDataInfo, this, !0),
- onmouseout: HN(this._showDataInfo, this, !1)
- }, {
- x: -1,
- y: 0,
- width: 2,
- height: 2
- }),
- r = o.getBoundingRect();
- this._handleHeight = Ro(a.get("handleSize"), this._size[1]), this._handleWidth = r.width / r.height * this._handleHeight,
- o.setStyle(a.getModel("handleStyle").getItemStyle());
- var s = a.get("handleColor");
- null != s && (o.style.fill = s), n.add(e[t] = o);
- var l = a.textStyleModel;
- this.group.add(i[t] = new qS({
- silent: !0,
- invisible: !0,
- style: {
- x: 0,
- y: 0,
- text: "",
- textVerticalAlign: "middle",
- textAlign: "center",
- textFill: l.getTextColor(),
- textFont: l.getFont()
- },
- z2: 10
- }))
- }, this)
- },
- _resetInterval: function() {
- var t = this._range = this.dataZoomModel.getPercentRange(),
- e = this._getViewExtent();
- this._handleEnds = [FN(t[0], [0, 100], e, !0), FN(t[1], [0, 100], e, !0)]
- },
- _updateInterval: function(t, e) {
- var i = this.dataZoomModel,
- n = this._handleEnds,
- o = this._getViewExtent(),
- a = i.findRepresentativeAxisProxy().getMinMaxSpan(),
- r = [0, 100];
- EL(e, n, o, i.get("zoomLock") ? "all" : t, null != a.minSpan ? FN(a.minSpan, r, o, !0) : null, null != a.maxSpan ?
- FN(a.maxSpan, r, o, !0) : null);
- var s = this._range,
- l = this._range = WN([FN(n[0], o, r, !0), FN(n[1], o, r, !0)]);
- return !s || s[0] !== l[0] || s[1] !== l[1]
- },
- _updateView: function(t) {
- var e = this._displayables,
- i = this._handleEnds,
- n = WN(i.slice()),
- o = this._size;
- ZN([0, 1], function(t) {
- var n = e.handles[t],
- a = this._handleHeight;
- n.attr({
- scale: [a / 2, a / 2],
- position: [i[t], o[1] / 2 - a / 2]
- })
- }, this), e.filler.setShape({
- x: n[0],
- y: 0,
- width: n[1] - n[0],
- height: o[1]
- }), this._updateDataInfo(t)
- },
- _updateDataInfo: function(t) {
- function e(t) {
- var e = Mo(n.handles[t].parent, this.group),
- i = To(0 === t ? "right" : "left", e),
- s = this._handleWidth / 2 + XN,
- l = Io([c[t] + (0 === t ? -s : s), this._size[1] / 2], e);
- o[t].setStyle({
- x: l[0],
- y: l[1],
- textVerticalAlign: a === UN ? "middle" : i,
- textAlign: a === UN ? i : "center",
- text: r[t]
- })
- }
- var i = this.dataZoomModel,
- n = this._displayables,
- o = n.handleLabels,
- a = this._orient,
- r = ["", ""];
- if (i.get("showDetail")) {
- var s = i.findRepresentativeAxisProxy();
- if (s) {
- var l = s.getAxisModel().axis,
- u = this._range,
- h = t ? s.calculateDataWindow({
- start: u[0],
- end: u[1]
- }).valueWindow : s.getDataValueWindow();
- r = [this._formatLabel(h[0], l), this._formatLabel(h[1], l)]
- }
- }
- var c = WN(this._handleEnds.slice());
- e.call(this, 0), e.call(this, 1)
- },
- _formatLabel: function(t, e) {
- var i = this.dataZoomModel,
- n = i.get("labelFormatter"),
- o = i.get("labelPrecision");
- null != o && "auto" !== o || (o = e.getPixelPrecision());
- var a = null == t || isNaN(t) ? "" : "category" === e.type || "time" === e.type ? e.scale.getLabel(Math.round(t)) :
- t.toFixed(Math.min(o, 20));
- return x(n) ? n(t, a) : _(n) ? n.replace("{value}", a) : a
- },
- _showDataInfo: function(t) {
- t = this._dragging || t;
- var e = this._displayables.handleLabels;
- e[0].attr("invisible", !t), e[1].attr("invisible", !t)
- },
- _onDragMove: function(t, e, i) {
- this._dragging = !0;
- var n = Io([e, i], this._displayables.barGroup.getLocalTransform(), !0),
- o = this._updateInterval(t, n[0]),
- a = this.dataZoomModel.get("realtime");
- this._updateView(!a), o && a && this._dispatchZoomAction()
- },
- _onDragEnd: function() {
- this._dragging = !1, this._showDataInfo(!1), !this.dataZoomModel.get("realtime") && this._dispatchZoomAction()
- },
- _onClickPanelClick: function(t) {
- var e = this._size,
- i = this._displayables.barGroup.transformCoordToLocal(t.offsetX, t.offsetY);
- if (!(i[0] < 0 || i[0] > e[0] || i[1] < 0 || i[1] > e[1])) {
- var n = this._handleEnds,
- o = (n[0] + n[1]) / 2,
- a = this._updateInterval("all", i[0] - o);
- this._updateView(), a && this._dispatchZoomAction()
- }
- },
- _dispatchZoomAction: function() {
- var t = this._range;
- this.api.dispatchAction({
- type: "dataZoom",
- from: this.uid,
- dataZoomId: this.dataZoomModel.id,
- start: t[0],
- end: t[1]
- })
- },
- _findCoordRect: function() {
- var t;
- if (ZN(this.getTargetCoordInfo(), function(e) {
- if (!t && e.length) {
- var i = e[0].model.coordinateSystem;
- t = i.getRect && i.getRect()
- }
- }), !t) {
- var e = this.api.getWidth(),
- i = this.api.getHeight();
- t = {
- x: .2 * e,
- y: .2 * i,
- width: .6 * e,
- height: .6 * i
- }
- }
- return t
- }
- });
- BN.extend({
- type: "dataZoom.inside",
- defaultOption: {
- disabled: !1,
- zoomLock: !1,
- zoomOnMouseWheel: !0,
- moveOnMouseMove: !0,
- moveOnMouseWheel: !1,
- preventDefaultMouseMove: !0
- }
- });
- var qN = "\0_ec_dataZoom_roams",
- KN = m,
- $N = VN.extend({
- type: "dataZoom.inside",
- init: function(t, e) {
- this._range
- },
- render: function(t, e, i, n) {
- $N.superApply(this, "render", arguments), this._range = t.getPercentRange(), d(this.getTargetCoordInfo(),
- function(e, n) {
- var o = f(e, function(t) {
- return Ry(t.model)
- });
- d(e, function(e) {
- var a = e.model,
- r = {};
- d(["pan", "zoom", "scrollMove"], function(t) {
- r[t] = KN(JN[t], this, e, n)
- }, this), Oy(i, {
- coordId: Ry(a),
- allCoordIds: o,
- containsPoint: function(t, e, i) {
- return a.coordinateSystem.containPoint([e, i])
- },
- dataZoomId: t.id,
- dataZoomModel: t,
- getRange: r
- })
- }, this)
- }, this)
- },
- dispose: function() {
- Ey(this.api, this.dataZoomModel.id), $N.superApply(this, "dispose", arguments), this._range = null
- }
- }),
- JN = {
- zoom: function(t, e, i, n) {
- var o = this._range,
- a = o.slice(),
- r = t.axisModels[0];
- if (r) {
- var s = QN[e](null, [n.originX, n.originY], r, i, t),
- l = (s.signal > 0 ? s.pixelStart + s.pixelLength - s.pixel : s.pixel - s.pixelStart) / s.pixelLength * (a[1] -
- a[0]) + a[0],
- u = Math.max(1 / n.scale, 0);
- a[0] = (a[0] - l) * u + l, a[1] = (a[1] - l) * u + l;
- var h = this.dataZoomModel.findRepresentativeAxisProxy().getMinMaxSpan();
- return EL(0, a, [0, 100], 0, h.minSpan, h.maxSpan), this._range = a, o[0] !== a[0] || o[1] !== a[1] ? a : void 0
- }
- },
- pan: Wy(function(t, e, i, n, o, a) {
- var r = QN[n]([a.oldX, a.oldY], [a.newX, a.newY], e, o, i);
- return r.signal * (t[1] - t[0]) * r.pixel / r.pixelLength
- }),
- scrollMove: Wy(function(t, e, i, n, o, a) {
- return QN[n]([0, 0], [a.scrollDelta, a.scrollDelta], e, o, i).signal * (t[1] - t[0]) * a.scrollDelta
- })
- },
- QN = {
- grid: function(t, e, i, n, o) {
- var a = i.axis,
- r = {},
- s = o.model.coordinateSystem.getRect();
- return t = t || [0, 0], "x" === a.dim ? (r.pixel = e[0] - t[0], r.pixelLength = s.width, r.pixelStart = s.x, r.signal =
- a.inverse ? 1 : -1) : (r.pixel = e[1] - t[1], r.pixelLength = s.height, r.pixelStart = s.y, r.signal = a.inverse ?
- -1 : 1), r
- },
- polar: function(t, e, i, n, o) {
- var a = i.axis,
- r = {},
- s = o.model.coordinateSystem,
- l = s.getRadiusAxis().getExtent(),
- u = s.getAngleAxis().getExtent();
- return t = t ? s.pointToCoord(t) : [0, 0], e = s.pointToCoord(e), "radiusAxis" === i.mainType ? (r.pixel = e[0] -
- t[0], r.pixelLength = l[1] - l[0], r.pixelStart = l[0], r.signal = a.inverse ? 1 : -1) : (r.pixel = e[1] - t[1],
- r.pixelLength = u[1] - u[0], r.pixelStart = u[0], r.signal = a.inverse ? -1 : 1), r
- },
- singleAxis: function(t, e, i, n, o) {
- var a = i.axis,
- r = o.model.coordinateSystem.getRect(),
- s = {};
- return t = t || [0, 0], "horizontal" === a.orient ? (s.pixel = e[0] - t[0], s.pixelLength = r.width, s.pixelStart =
- r.x, s.signal = a.inverse ? 1 : -1) : (s.pixel = e[1] - t[1], s.pixelLength = r.height, s.pixelStart = r.y, s.signal =
- a.inverse ? -1 : 1), s
- }
- };
- ks({
- getTargetSeries: function(t) {
- var e = R();
- return t.eachComponent("dataZoom", function(t) {
- t.eachTargetAxis(function(t, i, n) {
- d(n.getAxisProxy(t.name, i).getTargetSeriesModels(), function(t) {
- e.set(t.uid, t)
- })
- })
- }), e
- },
- modifyOutputEnd: !0,
- overallReset: function(t, e) {
- t.eachComponent("dataZoom", function(t) {
- t.eachTargetAxis(function(t, i, n) {
- n.getAxisProxy(t.name, i).reset(n, e)
- }), t.eachTargetAxis(function(t, i, n) {
- n.getAxisProxy(t.name, i).filterData(n, e)
- })
- }), t.eachComponent("dataZoom", function(t) {
- var e = t.findRepresentativeAxisProxy(),
- i = e.getDataPercentWindow(),
- n = e.getDataValueWindow();
- t.setRawRange({
- start: i[0],
- end: i[1],
- startValue: n[0],
- endValue: n[1]
- }, !0)
- })
- }
- }), Ps("dataZoom", function(t, e) {
- var i = Iy(m(e.eachComponent, e, "dataZoom"), PN, function(t, e) {
- return t.get(e.axisIndex)
- }),
- n = [];
- e.eachComponent({
- mainType: "dataZoom",
- query: t
- }, function(t, e) {
- n.push.apply(n, i(t).nodes)
- }), d(n, function(e, i) {
- e.setRawRange({
- start: t.start,
- end: t.end,
- startValue: t.startValue,
- endValue: t.endValue
- })
- })
- });
- var tO = d,
- eO = function(t) {
- var e = t && t.visualMap;
- y(e) || (e = e ? [e] : []), tO(e, function(t) {
- if (t) {
- Hy(t, "splitList") && !Hy(t, "pieces") && (t.pieces = t.splitList, delete t.splitList);
- var e = t.pieces;
- e && y(e) && tO(e, function(t) {
- w(t) && (Hy(t, "start") && !Hy(t, "min") && (t.min = t.start), Hy(t, "end") && !Hy(t, "max") && (t.max = t.end))
- })
- }
- })
- };
- YM.registerSubTypeDefaulter("visualMap", function(t) {
- return t.categories || (t.pieces ? t.pieces.length > 0 : t.splitNumber > 0) && !t.calculable ? "piecewise" :
- "continuous"
- });
- var iO = IT.VISUAL.COMPONENT;
- Es(iO, {
- createOnAllSeries: !0,
- reset: function(t, e) {
- var i = [];
- return e.eachComponent("visualMap", function(e) {
- var n = t.pipelineContext;
- !e.isTargetSeries(t) || n && n.large || i.push(qv(e.stateList, e.targetVisuals, m(e.getValueState, e), e.getDataDimension(
- t.getData())))
- }), i
- }
- }), Es(iO, {
- createOnAllSeries: !0,
- reset: function(t, e) {
- var i = t.getData(),
- n = [];
- e.eachComponent("visualMap", function(e) {
- if (e.isTargetSeries(t)) {
- var o = e.getVisualMeta(m(Zy, null, t, e)) || {
- stops: [],
- outerColors: []
- },
- a = e.getDataDimension(i),
- r = i.getDimensionInfo(a);
- null != r && (o.dimension = r.index, n.push(o))
- }
- }), t.getData().setVisual("visualMeta", n)
- }
- });
- var nO = {
- get: function(t, e, n) {
- var o = i((oO[t] || {})[e]);
- return n && y(o) ? o[o.length - 1] : o
- }
- },
- oO = {
- color: {
- active: ["#006edd", "#e0ffff"],
- inactive: ["rgba(0,0,0,0)"]
- },
- colorHue: {
- active: [0, 360],
- inactive: [0, 0]
- },
- colorSaturation: {
- active: [.3, 1],
- inactive: [0, 0]
- },
- colorLightness: {
- active: [.9, .5],
- inactive: [0, 0]
- },
- colorAlpha: {
- active: [.3, 1],
- inactive: [0, 0]
- },
- opacity: {
- active: [.3, 1],
- inactive: [0, 0]
- },
- symbol: {
- active: ["circle", "roundRect", "diamond"],
- inactive: ["none"]
- },
- symbolSize: {
- active: [10, 50],
- inactive: [0, 0]
- }
- },
- aO = jC.mapVisual,
- rO = jC.eachVisual,
- sO = y,
- lO = d,
- uO = Bo,
- hO = Eo,
- cO = B,
- dO = Bs({
- type: "visualMap",
- dependencies: ["series"],
- stateList: ["inRange", "outOfRange"],
- replacableOptionKeys: ["inRange", "outOfRange", "target", "controller", "color"],
- dataBound: [-1 / 0, 1 / 0],
- layoutMode: {
- type: "box",
- ignoreSize: !0
- },
- defaultOption: {
- show: !0,
- zlevel: 0,
- z: 4,
- seriesIndex: "all",
- min: 0,
- max: 200,
- dimension: null,
- inRange: null,
- outOfRange: null,
- left: 0,
- right: null,
- top: null,
- bottom: 0,
- itemWidth: null,
- itemHeight: null,
- inverse: !1,
- orient: "vertical",
- backgroundColor: "rgba(0,0,0,0)",
- borderColor: "#ccc",
- contentColor: "#5793f3",
- inactiveColor: "#aaa",
- borderWidth: 0,
- padding: 5,
- textGap: 10,
- precision: 0,
- color: null,
- formatter: null,
- text: null,
- textStyle: {
- color: "#333"
- }
- },
- init: function(t, e, i) {
- this._dataExtent, this.targetVisuals = {}, this.controllerVisuals = {}, this.textStyleModel, this.itemSize, this
- .mergeDefaultAndTheme(t, i)
- },
- optionUpdated: function(t, e) {
- var i = this.option;
- z_.canvasSupported || (i.realtime = !1), !e && jv(i, t, this.replacableOptionKeys), this.textStyleModel = this.getModel(
- "textStyle"), this.resetItemSize(), this.completeVisualOption()
- },
- resetVisual: function(t) {
- var e = this.stateList;
- t = m(t, this), this.controllerVisuals = Xv(this.option.controller, e, t), this.targetVisuals = Xv(this.option.target,
- e, t)
- },
- getTargetSeriesIndices: function() {
- var t = this.option.seriesIndex,
- e = [];
- return null == t || "all" === t ? this.ecModel.eachSeries(function(t, i) {
- e.push(i)
- }) : e = Di(t), e
- },
- eachTargetSeries: function(t, e) {
- d(this.getTargetSeriesIndices(), function(i) {
- t.call(e, this.ecModel.getSeriesByIndex(i))
- }, this)
- },
- isTargetSeries: function(t) {
- var e = !1;
- return this.eachTargetSeries(function(i) {
- i === t && (e = !0)
- }), e
- },
- formatValueText: function(t, e, i) {
- function n(t) {
- return t === l[0] ? "min" : t === l[1] ? "max" : (+t).toFixed(Math.min(s, 20))
- }
- var o, a, r = this.option,
- s = r.precision,
- l = this.dataBound,
- u = r.formatter;
- return i = i || ["<", ">"], y(t) && (t = t.slice(), o = !0), a = e ? t : o ? [n(t[0]), n(t[1])] : n(t), _(u) ? u
- .replace("{value}", o ? a[0] : a).replace("{value2}", o ? a[1] : a) : x(u) ? o ? u(t[0], t[1]) : u(t) : o ? t[0] ===
- l[0] ? i[0] + " " + a[1] : t[1] === l[1] ? i[1] + " " + a[0] : a[0] + " - " + a[1] : a
- },
- resetExtent: function() {
- var t = this.option,
- e = uO([t.min, t.max]);
- this._dataExtent = e
- },
- getDataDimension: function(t) {
- var e = this.option.dimension,
- i = t.dimensions;
- if (null != e || i.length) {
- if (null != e) return t.getDimension(e);
- for (var n = t.dimensions, o = n.length - 1; o >= 0; o--) {
- var a = n[o];
- if (!t.getDimensionInfo(a).isCalculationCoord) return a
- }
- }
- },
- getExtent: function() {
- return this._dataExtent.slice()
- },
- completeVisualOption: function() {
- function t(t) {
- sO(o.color) && !t.inRange && (t.inRange = {
- color: o.color.slice().reverse()
- }), t.inRange = t.inRange || {
- color: e.get("gradientColor")
- }, lO(this.stateList, function(e) {
- var i = t[e];
- if (_(i)) {
- var n = nO.get(i, "active", l);
- n ? (t[e] = {}, t[e][i] = n) : delete t[e]
- }
- }, this)
- }
- var e = this.ecModel,
- o = this.option,
- a = {
- inRange: o.inRange,
- outOfRange: o.outOfRange
- },
- r = o.target || (o.target = {}),
- s = o.controller || (o.controller = {});
- n(r, a), n(s, a);
- var l = this.isCategory();
- t.call(this, r), t.call(this, s),
- function(t, e, i) {
- var n = t[e],
- o = t[i];
- n && !o && (o = t[i] = {}, lO(n, function(t, e) {
- if (jC.isValidType(e)) {
- var i = nO.get(e, "inactive", l);
- null != i && (o[e] = i, "color" !== e || o.hasOwnProperty("opacity") || o.hasOwnProperty("colorAlpha") ||
- (o.opacity = [0, 0]))
- }
- }))
- }.call(this, r, "inRange", "outOfRange"),
- function(t) {
- var e = (t.inRange || {}).symbol || (t.outOfRange || {}).symbol,
- n = (t.inRange || {}).symbolSize || (t.outOfRange || {}).symbolSize,
- o = this.get("inactiveColor");
- lO(this.stateList, function(a) {
- var r = this.itemSize,
- s = t[a];
- s || (s = t[a] = {
- color: l ? o : [o]
- }), null == s.symbol && (s.symbol = e && i(e) || (l ? "roundRect" : ["roundRect"])), null == s.symbolSize &&
- (s.symbolSize = n && i(n) || (l ? r[0] : [r[0], r[0]])), s.symbol = aO(s.symbol, function(t) {
- return "none" === t || "square" === t ? "roundRect" : t
- });
- var u = s.symbolSize;
- if (null != u) {
- var h = -1 / 0;
- rO(u, function(t) {
- t > h && (h = t)
- }), s.symbolSize = aO(u, function(t) {
- return hO(t, [0, h], [0, r[0]], !0)
- })
- }
- }, this)
- }.call(this, s)
- },
- resetItemSize: function() {
- this.itemSize = [parseFloat(this.get("itemWidth")), parseFloat(this.get("itemHeight"))]
- },
- isCategory: function() {
- return !!this.option.categories
- },
- setSelected: cO,
- getValueState: cO,
- getVisualMeta: cO
- }),
- fO = [20, 140],
- pO = dO.extend({
- type: "visualMap.continuous",
- defaultOption: {
- align: "auto",
- calculable: !1,
- range: null,
- realtime: !0,
- itemHeight: null,
- itemWidth: null,
- hoverLink: !0,
- hoverLinkDataSize: null,
- hoverLinkOnHandle: null
- },
- optionUpdated: function(t, e) {
- pO.superApply(this, "optionUpdated", arguments), this.resetExtent(), this.resetVisual(function(t) {
- t.mappingMethod = "linear", t.dataExtent = this.getExtent()
- }), this._resetRange()
- },
- resetItemSize: function() {
- pO.superApply(this, "resetItemSize", arguments);
- var t = this.itemSize;
- "horizontal" === this._orient && t.reverse(), (null == t[0] || isNaN(t[0])) && (t[0] = fO[0]), (null == t[1] ||
- isNaN(t[1])) && (t[1] = fO[1])
- },
- _resetRange: function() {
- var t = this.getExtent(),
- e = this.option.range;
- !e || e.auto ? (t.auto = 1, this.option.range = t) : y(e) && (e[0] > e[1] && e.reverse(), e[0] = Math.max(e[0],
- t[0]), e[1] = Math.min(e[1], t[1]))
- },
- completeVisualOption: function() {
- dO.prototype.completeVisualOption.apply(this, arguments), d(this.stateList, function(t) {
- var e = this.option.controller[t].symbolSize;
- e && e[0] !== e[1] && (e[0] = 0)
- }, this)
- },
- setSelected: function(t) {
- this.option.range = t.slice(), this._resetRange()
- },
- getSelected: function() {
- var t = this.getExtent(),
- e = Bo((this.get("range") || []).slice());
- return e[0] > t[1] && (e[0] = t[1]), e[1] > t[1] && (e[1] = t[1]), e[0] < t[0] && (e[0] = t[0]), e[1] < t[0] &&
- (e[1] = t[0]), e
- },
- getValueState: function(t) {
- var e = this.option.range,
- i = this.getExtent();
- return (e[0] <= i[0] || e[0] <= t) && (e[1] >= i[1] || t <= e[1]) ? "inRange" : "outOfRange"
- },
- findTargetDataIndices: function(t) {
- var e = [];
- return this.eachTargetSeries(function(i) {
- var n = [],
- o = i.getData();
- o.each(this.getDataDimension(o), function(e, i) {
- t[0] <= e && e <= t[1] && n.push(i)
- }, this), e.push({
- seriesId: i.id,
- dataIndex: n
- })
- }, this), e
- },
- getVisualMeta: function(t) {
- function e(e, i) {
- o.push({
- value: e,
- color: t(e, i)
- })
- }
- for (var i = Uy(0, 0, this.getExtent()), n = Uy(0, 0, this.option.range.slice()), o = [], a = 0, r = 0, s = n.length,
- l = i.length; r < l && (!n.length || i[r] <= n[0]); r++) i[r] < n[a] && e(i[r], "outOfRange");
- for (u = 1; a < s; a++, u = 0) u && o.length && e(n[a], "outOfRange"), e(n[a], "inRange");
- for (var u = 1; r < l; r++)(!n.length || n[n.length - 1] < i[r]) && (u && (o.length && e(o[o.length - 1].value,
- "outOfRange"), u = 0), e(i[r], "outOfRange"));
- var h = o.length;
- return {
- stops: o,
- outerColors: [h ? o[0].color : "transparent", h ? o[h - 1].color : "transparent"]
- }
- }
- }),
- gO = Vs({
- type: "visualMap",
- autoPositionValues: {
- left: 1,
- right: 1,
- top: 1,
- bottom: 1
- },
- init: function(t, e) {
- this.ecModel = t, this.api = e, this.visualMapModel
- },
- render: function(t, e, i, n) {
- this.visualMapModel = t, !1 !== t.get("show") ? this.doRender.apply(this, arguments) : this.group.removeAll()
- },
- renderBackground: function(t) {
- var e = this.visualMapModel,
- i = OM(e.get("padding") || 0),
- n = t.getBoundingRect();
- t.add(new aM({
- z2: -1,
- silent: !0,
- shape: {
- x: n.x - i[3],
- y: n.y - i[0],
- width: n.width + i[3] + i[1],
- height: n.height + i[0] + i[2]
- },
- style: {
- fill: e.get("backgroundColor"),
- stroke: e.get("borderColor"),
- lineWidth: e.get("borderWidth")
- }
- }))
- },
- getControllerVisual: function(t, e, i) {
- function n(t) {
- return s[t]
- }
- function o(t, e) {
- s[t] = e
- }
- var a = (i = i || {}).forceState,
- r = this.visualMapModel,
- s = {};
- if ("symbol" === e && (s.symbol = r.get("itemSymbol")), "color" === e) {
- var l = r.get("contentColor");
- s.color = l
- }
- var u = r.controllerVisuals[a || r.getValueState(t)];
- return d(jC.prepareVisualTypes(u), function(a) {
- var r = u[a];
- i.convertOpacityToAlpha && "opacity" === a && (a = "colorAlpha", r = u.__alphaForOpacity), jC.dependsOn(a, e) &&
- r && r.applyVisual(t, n, o)
- }), s[e]
- },
- positionGroup: function(t) {
- var e = this.visualMapModel,
- i = this.api;
- ua(t, e.getBoxLayoutParams(), {
- width: i.getWidth(),
- height: i.getHeight()
- })
- },
- doRender: B
- }),
- mO = Eo,
- vO = d,
- yO = Math.min,
- xO = Math.max,
- _O = 12,
- wO = 6,
- bO = gO.extend({
- type: "visualMap.continuous",
- init: function() {
- bO.superApply(this, "init", arguments), this._shapes = {}, this._dataInterval = [], this._handleEnds = [], this._orient,
- this._useHandle, this._hoverLinkDataIndices = [], this._dragging, this._hovering
- },
- doRender: function(t, e, i, n) {
- n && "selectDataRange" === n.type && n.from === this.uid || this._buildView()
- },
- _buildView: function() {
- this.group.removeAll();
- var t = this.visualMapModel,
- e = this.group;
- this._orient = t.get("orient"), this._useHandle = t.get("calculable"), this._resetInterval(), this._renderBar(e);
- var i = t.get("text");
- this._renderEndsText(e, i, 0), this._renderEndsText(e, i, 1), this._updateView(!0), this.renderBackground(e),
- this._updateView(), this._enableHoverLinkToSeries(), this._enableHoverLinkFromSeries(), this.positionGroup(e)
- },
- _renderEndsText: function(t, e, i) {
- if (e) {
- var n = e[1 - i];
- n = null != n ? n + "" : "";
- var o = this.visualMapModel,
- a = o.get("textGap"),
- r = o.itemSize,
- s = this._shapes.barGroup,
- l = this._applyTransform([r[0] / 2, 0 === i ? -a : r[1] + a], s),
- u = this._applyTransform(0 === i ? "bottom" : "top", s),
- h = this._orient,
- c = this.visualMapModel.textStyleModel;
- this.group.add(new qS({
- style: {
- x: l[0],
- y: l[1],
- textVerticalAlign: "horizontal" === h ? "middle" : u,
- textAlign: "horizontal" === h ? u : "center",
- text: n,
- textFont: c.getFont(),
- textFill: c.getTextColor()
- }
- }))
- }
- },
- _renderBar: function(t) {
- var e = this.visualMapModel,
- i = this._shapes,
- n = e.itemSize,
- o = this._orient,
- a = this._useHandle,
- r = Xy(e, this.api, n),
- s = i.barGroup = this._createBarGroup(r);
- s.add(i.outOfRange = Yy()), s.add(i.inRange = Yy(null, a ? Qy(this._orient) : null, m(this._dragHandle, this,
- "all", !1), m(this._dragHandle, this, "all", !0)));
- var l = e.textStyleModel.getTextRect("国"),
- u = xO(l.width, l.height);
- a && (i.handleThumbs = [], i.handleLabels = [], i.handleLabelPoints = [], this._createHandle(s, 0, n, u, o, r),
- this._createHandle(s, 1, n, u, o, r)), this._createIndicator(s, n, u, o), t.add(s)
- },
- _createHandle: function(t, e, i, n, o) {
- var a = m(this._dragHandle, this, e, !1),
- r = m(this._dragHandle, this, e, !0),
- s = Yy(qy(e, n), Qy(this._orient), a, r);
- s.position[0] = i[0], t.add(s);
- var l = this.visualMapModel.textStyleModel,
- u = new qS({
- draggable: !0,
- drift: a,
- onmousemove: function(t) {
- lw(t.event)
- },
- ondragend: r,
- style: {
- x: 0,
- y: 0,
- text: "",
- textFont: l.getFont(),
- textFill: l.getTextColor()
- }
- });
- this.group.add(u);
- var h = ["horizontal" === o ? n / 2 : 1.5 * n, "horizontal" === o ? 0 === e ? -1.5 * n : 1.5 * n : 0 === e ? -n /
- 2 : n / 2
- ],
- c = this._shapes;
- c.handleThumbs[e] = s, c.handleLabelPoints[e] = h, c.handleLabels[e] = u
- },
- _createIndicator: function(t, e, i, n) {
- var o = Yy([
- [0, 0]
- ], "move");
- o.position[0] = e[0], o.attr({
- invisible: !0,
- silent: !0
- }), t.add(o);
- var a = this.visualMapModel.textStyleModel,
- r = new qS({
- silent: !0,
- invisible: !0,
- style: {
- x: 0,
- y: 0,
- text: "",
- textFont: a.getFont(),
- textFill: a.getTextColor()
- }
- });
- this.group.add(r);
- var s = ["horizontal" === n ? i / 2 : wO + 3, 0],
- l = this._shapes;
- l.indicator = o, l.indicatorLabel = r, l.indicatorLabelPoint = s
- },
- _dragHandle: function(t, e, i, n) {
- if (this._useHandle) {
- if (this._dragging = !e, !e) {
- var o = this._applyTransform([i, n], this._shapes.barGroup, !0);
- this._updateInterval(t, o[1]), this._updateView()
- }
- e === !this.visualMapModel.get("realtime") && this.api.dispatchAction({
- type: "selectDataRange",
- from: this.uid,
- visualMapId: this.visualMapModel.id,
- selected: this._dataInterval.slice()
- }), e ? !this._hovering && this._clearHoverLinkToSeries() : Jy(this.visualMapModel) && this._doHoverLinkToSeries(
- this._handleEnds[t], !1)
- }
- },
- _resetInterval: function() {
- var t = this.visualMapModel,
- e = this._dataInterval = t.getSelected(),
- i = t.getExtent(),
- n = [0, t.itemSize[1]];
- this._handleEnds = [mO(e[0], i, n, !0), mO(e[1], i, n, !0)]
- },
- _updateInterval: function(t, e) {
- e = e || 0;
- var i = this.visualMapModel,
- n = this._handleEnds,
- o = [0, i.itemSize[1]];
- EL(e, n, o, t, 0);
- var a = i.getExtent();
- this._dataInterval = [mO(n[0], o, a, !0), mO(n[1], o, a, !0)]
- },
- _updateView: function(t) {
- var e = this.visualMapModel,
- i = e.getExtent(),
- n = this._shapes,
- o = [0, e.itemSize[1]],
- a = t ? o : this._handleEnds,
- r = this._createBarVisual(this._dataInterval, i, a, "inRange"),
- s = this._createBarVisual(i, i, o, "outOfRange");
- n.inRange.setStyle({
- fill: r.barColor,
- opacity: r.opacity
- }).setShape("points", r.barPoints), n.outOfRange.setStyle({
- fill: s.barColor,
- opacity: s.opacity
- }).setShape("points", s.barPoints), this._updateHandle(a, r)
- },
- _createBarVisual: function(t, e, i, n) {
- var o = {
- forceState: n,
- convertOpacityToAlpha: !0
- },
- a = this._makeColorGradient(t, o),
- r = [this.getControllerVisual(t[0], "symbolSize", o), this.getControllerVisual(t[1], "symbolSize", o)],
- s = this._createBarPoints(i, r);
- return {
- barColor: new dM(0, 0, 0, 1, a),
- barPoints: s,
- handlesColor: [a[0].color, a[a.length - 1].color]
- }
- },
- _makeColorGradient: function(t, e) {
- var i = [],
- n = (t[1] - t[0]) / 100;
- i.push({
- color: this.getControllerVisual(t[0], "color", e),
- offset: 0
- });
- for (var o = 1; o < 100; o++) {
- var a = t[0] + n * o;
- if (a > t[1]) break;
- i.push({
- color: this.getControllerVisual(a, "color", e),
- offset: o / 100
- })
- }
- return i.push({
- color: this.getControllerVisual(t[1], "color", e),
- offset: 1
- }), i
- },
- _createBarPoints: function(t, e) {
- var i = this.visualMapModel.itemSize;
- return [
- [i[0] - e[0], t[0]],
- [i[0], t[0]],
- [i[0], t[1]],
- [i[0] - e[1], t[1]]
- ]
- },
- _createBarGroup: function(t) {
- var e = this._orient,
- i = this.visualMapModel.get("inverse");
- return new Zw("horizontal" !== e || i ? "horizontal" === e && i ? {
- scale: "bottom" === t ? [-1, 1] : [1, 1],
- rotation: -Math.PI / 2
- } : "vertical" !== e || i ? {
- scale: "left" === t ? [1, 1] : [-1, 1]
- } : {
- scale: "left" === t ? [1, -1] : [-1, -1]
- } : {
- scale: "bottom" === t ? [1, 1] : [-1, 1],
- rotation: Math.PI / 2
- })
- },
- _updateHandle: function(t, e) {
- if (this._useHandle) {
- var i = this._shapes,
- n = this.visualMapModel,
- o = i.handleThumbs,
- a = i.handleLabels;
- vO([0, 1], function(r) {
- var s = o[r];
- s.setStyle("fill", e.handlesColor[r]), s.position[1] = t[r];
- var l = Io(i.handleLabelPoints[r], Mo(s, this.group));
- a[r].setStyle({
- x: l[0],
- y: l[1],
- text: n.formatValueText(this._dataInterval[r]),
- textVerticalAlign: "middle",
- textAlign: this._applyTransform("horizontal" === this._orient ? 0 === r ? "bottom" : "top" : "left", i.barGroup)
- })
- }, this)
- }
- },
- _showIndicator: function(t, e, i, n) {
- var o = this.visualMapModel,
- a = o.getExtent(),
- r = o.itemSize,
- s = [0, r[1]],
- l = mO(t, a, s, !0),
- u = this._shapes,
- h = u.indicator;
- if (h) {
- h.position[1] = l, h.attr("invisible", !1), h.setShape("points", Ky(!!i, n, l, r[1]));
- var c = {
- convertOpacityToAlpha: !0
- },
- d = this.getControllerVisual(t, "color", c);
- h.setStyle("fill", d);
- var f = Io(u.indicatorLabelPoint, Mo(h, this.group)),
- p = u.indicatorLabel;
- p.attr("invisible", !1);
- var g = this._applyTransform("left", u.barGroup),
- m = this._orient;
- p.setStyle({
- text: (i || "") + o.formatValueText(e),
- textVerticalAlign: "horizontal" === m ? g : "middle",
- textAlign: "horizontal" === m ? "center" : g,
- x: f[0],
- y: f[1]
- })
- }
- },
- _enableHoverLinkToSeries: function() {
- var t = this;
- this._shapes.barGroup.on("mousemove", function(e) {
- if (t._hovering = !0, !t._dragging) {
- var i = t.visualMapModel.itemSize,
- n = t._applyTransform([e.offsetX, e.offsetY], t._shapes.barGroup, !0, !0);
- n[1] = yO(xO(0, n[1]), i[1]), t._doHoverLinkToSeries(n[1], 0 <= n[0] && n[0] <= i[0])
- }
- }).on("mouseout", function() {
- t._hovering = !1, !t._dragging && t._clearHoverLinkToSeries()
- })
- },
- _enableHoverLinkFromSeries: function() {
- var t = this.api.getZr();
- this.visualMapModel.option.hoverLink ? (t.on("mouseover", this._hoverLinkFromSeriesMouseOver, this), t.on(
- "mouseout", this._hideIndicator, this)) : this._clearHoverLinkFromSeries()
- },
- _doHoverLinkToSeries: function(t, e) {
- var i = this.visualMapModel,
- n = i.itemSize;
- if (i.option.hoverLink) {
- var o = [0, n[1]],
- a = i.getExtent();
- t = yO(xO(o[0], t), o[1]);
- var r = $y(i, a, o),
- s = [t - r, t + r],
- l = mO(t, o, a, !0),
- u = [mO(s[0], o, a, !0), mO(s[1], o, a, !0)];
- s[0] < o[0] && (u[0] = -1 / 0), s[1] > o[1] && (u[1] = 1 / 0), e && (u[0] === -1 / 0 ? this._showIndicator(l, u[
- 1], "< ", r) : u[1] === 1 / 0 ? this._showIndicator(l, u[0], "> ", r) : this._showIndicator(l, l, "≈ ", r));
- var h = this._hoverLinkDataIndices,
- c = [];
- (e || Jy(i)) && (c = this._hoverLinkDataIndices = i.findTargetDataIndices(u));
- var d = Ri(h, c);
- this._dispatchHighDown("downplay", jy(d[0])), this._dispatchHighDown("highlight", jy(d[1]))
- }
- },
- _hoverLinkFromSeriesMouseOver: function(t) {
- var e = t.target,
- i = this.visualMapModel;
- if (e && null != e.dataIndex) {
- var n = this.ecModel.getSeriesByIndex(e.seriesIndex);
- if (i.isTargetSeries(n)) {
- var o = n.getData(e.dataType),
- a = o.get(i.getDataDimension(o), e.dataIndex, !0);
- isNaN(a) || this._showIndicator(a, a)
- }
- }
- },
- _hideIndicator: function() {
- var t = this._shapes;
- t.indicator && t.indicator.attr("invisible", !0), t.indicatorLabel && t.indicatorLabel.attr("invisible", !0)
- },
- _clearHoverLinkToSeries: function() {
- this._hideIndicator();
- var t = this._hoverLinkDataIndices;
- this._dispatchHighDown("downplay", jy(t)), t.length = 0
- },
- _clearHoverLinkFromSeries: function() {
- this._hideIndicator();
- var t = this.api.getZr();
- t.off("mouseover", this._hoverLinkFromSeriesMouseOver), t.off("mouseout", this._hideIndicator)
- },
- _applyTransform: function(t, e, i, n) {
- var o = Mo(e, n ? null : this.group);
- return bM[y(t) ? "applyTransform" : "transformDirection"](t, o, i)
- },
- _dispatchHighDown: function(t, e) {
- e && e.length && this.api.dispatchAction({
- type: t,
- batch: e
- })
- },
- dispose: function() {
- this._clearHoverLinkFromSeries(), this._clearHoverLinkToSeries()
- },
- remove: function() {
- this._clearHoverLinkFromSeries(), this._clearHoverLinkToSeries()
- }
- });
- Ps({
- type: "selectDataRange",
- event: "dataRangeSelected",
- update: "update"
- }, function(t, e) {
- e.eachComponent({
- mainType: "visualMap",
- query: t
- }, function(e) {
- e.setSelected(t.selected)
- })
- }), Ls(eO);
- var SO = dO.extend({
- type: "visualMap.piecewise",
- defaultOption: {
- selected: null,
- minOpen: !1,
- maxOpen: !1,
- align: "auto",
- itemWidth: 20,
- itemHeight: 14,
- itemSymbol: "roundRect",
- pieceList: null,
- categories: null,
- splitNumber: 5,
- selectedMode: "multiple",
- itemGap: 10,
- hoverLink: !0,
- showLabel: null
- },
- optionUpdated: function(t, e) {
- SO.superApply(this, "optionUpdated", arguments), this._pieceList = [], this.resetExtent();
- var n = this._mode = this._determineMode();
- MO[this._mode].call(this), this._resetSelected(t, e);
- var o = this.option.categories;
- this.resetVisual(function(t, e) {
- "categories" === n ? (t.mappingMethod = "category", t.categories = i(o)) : (t.dataExtent = this.getExtent(),
- t.mappingMethod = "piecewise", t.pieceList = f(this._pieceList, function(t) {
- var t = i(t);
- return "inRange" !== e && (t.visual = null), t
- }))
- })
- },
- completeVisualOption: function() {
- function t(t, e, i) {
- return t && t[e] && (w(t[e]) ? t[e].hasOwnProperty(i) : t[e] === i)
- }
- var e = this.option,
- i = {},
- n = jC.listVisualTypes(),
- o = this.isCategory();
- d(e.pieces, function(t) {
- d(n, function(e) {
- t.hasOwnProperty(e) && (i[e] = 1)
- })
- }), d(i, function(i, n) {
- var a = 0;
- d(this.stateList, function(i) {
- a |= t(e, i, n) || t(e.target, i, n)
- }, this), !a && d(this.stateList, function(t) {
- (e[t] || (e[t] = {}))[n] = nO.get(n, "inRange" === t ? "active" : "inactive", o)
- })
- }, this), dO.prototype.completeVisualOption.apply(this, arguments)
- },
- _resetSelected: function(t, e) {
- var i = this.option,
- n = this._pieceList,
- o = (e ? i : t).selected || {};
- if (i.selected = o, d(n, function(t, e) {
- var i = this.getSelectedMapKey(t);
- o.hasOwnProperty(i) || (o[i] = !0)
- }, this), "single" === i.selectedMode) {
- var a = !1;
- d(n, function(t, e) {
- var i = this.getSelectedMapKey(t);
- o[i] && (a ? o[i] = !1 : a = !0)
- }, this)
- }
- },
- getSelectedMapKey: function(t) {
- return "categories" === this._mode ? t.value + "" : t.index + ""
- },
- getPieceList: function() {
- return this._pieceList
- },
- _determineMode: function() {
- var t = this.option;
- return t.pieces && t.pieces.length > 0 ? "pieces" : this.option.categories ? "categories" : "splitNumber"
- },
- setSelected: function(t) {
- this.option.selected = i(t)
- },
- getValueState: function(t) {
- var e = jC.findPieceIndex(t, this._pieceList);
- return null != e && this.option.selected[this.getSelectedMapKey(this._pieceList[e])] ? "inRange" : "outOfRange"
- },
- findTargetDataIndices: function(t) {
- var e = [];
- return this.eachTargetSeries(function(i) {
- var n = [],
- o = i.getData();
- o.each(this.getDataDimension(o), function(e, i) {
- jC.findPieceIndex(e, this._pieceList) === t && n.push(i)
- }, this), e.push({
- seriesId: i.id,
- dataIndex: n
- })
- }, this), e
- },
- getRepresentValue: function(t) {
- var e;
- if (this.isCategory()) e = t.value;
- else if (null != t.value) e = t.value;
- else {
- var i = t.interval || [];
- e = i[0] === -1 / 0 && i[1] === 1 / 0 ? 0 : (i[0] + i[1]) / 2
- }
- return e
- },
- getVisualMeta: function(t) {
- function e(e, a) {
- var r = o.getRepresentValue({
- interval: e
- });
- a || (a = o.getValueState(r));
- var s = t(r, a);
- e[0] === -1 / 0 ? n[0] = s : e[1] === 1 / 0 ? n[1] = s : i.push({
- value: e[0],
- color: s
- }, {
- value: e[1],
- color: s
- })
- }
- if (!this.isCategory()) {
- var i = [],
- n = [],
- o = this,
- a = this._pieceList.slice();
- if (a.length) {
- var r = a[0].interval[0];
- r !== -1 / 0 && a.unshift({
- interval: [-1 / 0, r]
- }), (r = a[a.length - 1].interval[1]) !== 1 / 0 && a.push({
- interval: [r, 1 / 0]
- })
- } else a.push({
- interval: [-1 / 0, 1 / 0]
- });
- var s = -1 / 0;
- return d(a, function(t) {
- var i = t.interval;
- i && (i[0] > s && e([s, i[0]], "outOfRange"), e(i.slice()), s = i[1])
- }, this), {
- stops: i,
- outerColors: n
- }
- }
- }
- }),
- MO = {
- splitNumber: function() {
- var t = this.option,
- e = this._pieceList,
- i = Math.min(t.precision, 20),
- n = this.getExtent(),
- o = t.splitNumber;
- o = Math.max(parseInt(o, 10), 1), t.splitNumber = o;
- for (var a = (n[1] - n[0]) / o; + a.toFixed(i) !== a && i < 5;) i++;
- t.precision = i, a = +a.toFixed(i);
- var r = 0;
- t.minOpen && e.push({
- index: r++,
- interval: [-1 / 0, n[0]],
- close: [0, 0]
- });
- for (var s = n[0], l = r + o; r < l; s += a) {
- var u = r === o - 1 ? n[1] : s + a;
- e.push({
- index: r++,
- interval: [s, u],
- close: [1, 1]
- })
- }
- t.maxOpen && e.push({
- index: r++,
- interval: [n[1], 1 / 0],
- close: [0, 0]
- }), qo(e), d(e, function(t) {
- t.text = this.formatValueText(t.interval)
- }, this)
- },
- categories: function() {
- var t = this.option;
- d(t.categories, function(t) {
- this._pieceList.push({
- text: this.formatValueText(t, !0),
- value: t
- })
- }, this), tx(t, this._pieceList)
- },
- pieces: function() {
- var t = this.option,
- e = this._pieceList;
- d(t.pieces, function(t, i) {
- w(t) || (t = {
- value: t
- });
- var n = {
- text: "",
- index: i
- };
- if (null != t.label && (n.text = t.label), t.hasOwnProperty("value")) {
- var o = n.value = t.value;
- n.interval = [o, o], n.close = [1, 1]
- } else {
- for (var a = n.interval = [], r = n.close = [0, 0], s = [1, 0, 1], l = [-1 / 0, 1 / 0], u = [], h = 0; h < 2; h++) {
- for (var c = [
- ["gte", "gt", "min"],
- ["lte", "lt", "max"]
- ][h], d = 0; d < 3 && null == a[h]; d++) a[h] = t[c[d]], r[h] = s[d], u[h] = 2 === d;
- null == a[h] && (a[h] = l[h])
- }
- u[0] && a[1] === 1 / 0 && (r[0] = 0), u[1] && a[0] === -1 / 0 && (r[1] = 0), a[0] === a[1] && r[0] && r[1] &&
- (n.value = a[0])
- }
- n.visual = jC.retrieveVisuals(t), e.push(n)
- }, this), tx(t, e), qo(e), d(e, function(t) {
- var e = t.close,
- i = [
- ["<", "≤"][e[1]],
- [">", "≥"][e[0]]
- ];
- t.text = t.text || this.formatValueText(null != t.value ? t.value : t.interval, !1, i)
- }, this)
- }
- };
- gO.extend({
- type: "visualMap.piecewise",
- doRender: function() {
- var t = this.group;
- t.removeAll();
- var e = this.visualMapModel,
- i = e.get("textGap"),
- n = e.textStyleModel,
- o = n.getFont(),
- a = n.getTextColor(),
- r = this._getItemAlign(),
- s = e.itemSize,
- l = this._getViewData(),
- u = l.endsText,
- h = T(e.get("showLabel", !0), !u);
- u && this._renderEndsText(t, u[0], s, h, r), d(l.viewPieceList, function(n) {
- var l = n.piece,
- u = new Zw;
- u.onclick = m(this._onItemClick, this, l), this._enableHoverLink(u, n.indexInModelPieceList);
- var c = e.getRepresentValue(l);
- if (this._createItemSymbol(u, c, [0, 0, s[0], s[1]]), h) {
- var d = this.visualMapModel.getValueState(c);
- u.add(new qS({
- style: {
- x: "right" === r ? -i : s[0] + i,
- y: s[1] / 2,
- text: l.text,
- textVerticalAlign: "middle",
- textAlign: r,
- textFont: o,
- textFill: a,
- opacity: "outOfRange" === d ? .5 : 1
- }
- }))
- }
- t.add(u)
- }, this), u && this._renderEndsText(t, u[1], s, h, r), UM(e.get("orient"), t, e.get("itemGap")), this.renderBackground(
- t), this.positionGroup(t)
- },
- _enableHoverLink: function(t, e) {
- function i(t) {
- var i = this.visualMapModel;
- i.option.hoverLink && this.api.dispatchAction({
- type: t,
- batch: jy(i.findTargetDataIndices(e))
- })
- }
- t.on("mouseover", m(i, this, "highlight")).on("mouseout", m(i, this, "downplay"))
- },
- _getItemAlign: function() {
- var t = this.visualMapModel,
- e = t.option;
- if ("vertical" === e.orient) return Xy(t, this.api, t.itemSize);
- var i = e.align;
- return i && "auto" !== i || (i = "left"), i
- },
- _renderEndsText: function(t, e, i, n, o) {
- if (e) {
- var a = new Zw,
- r = this.visualMapModel.textStyleModel;
- a.add(new qS({
- style: {
- x: n ? "right" === o ? i[0] : 0 : i[0] / 2,
- y: i[1] / 2,
- textVerticalAlign: "middle",
- textAlign: n ? o : "center",
- text: e,
- textFont: r.getFont(),
- textFill: r.getTextColor()
- }
- })), t.add(a)
- }
- },
- _getViewData: function() {
- var t = this.visualMapModel,
- e = f(t.getPieceList(), function(t, e) {
- return {
- piece: t,
- indexInModelPieceList: e
- }
- }),
- i = t.get("text"),
- n = t.get("orient"),
- o = t.get("inverse");
- return ("horizontal" === n ? o : !o) ? e.reverse() : i && (i = i.slice().reverse()), {
- viewPieceList: e,
- endsText: i
- }
- },
- _createItemSymbol: function(t, e, i) {
- t.add(Xl(this.getControllerVisual(e, "symbol"), i[0], i[1], i[2], i[3], this.getControllerVisual(e, "color")))
- },
- _onItemClick: function(t) {
- var e = this.visualMapModel,
- n = e.option,
- o = i(n.selected),
- a = e.getSelectedMapKey(t);
- "single" === n.selectedMode ? (o[a] = !0, d(o, function(t, e) {
- o[e] = e === a
- })) : o[a] = !o[a], this.api.dispatchAction({
- type: "selectDataRange",
- from: this.uid,
- visualMapId: this.visualMapModel.id,
- selected: o
- })
- }
- });
- Ls(eO);
- var IO = $o,
- TO = Qo,
- AO = Bs({
- type: "marker",
- dependencies: ["series", "grid", "polar", "geo"],
- init: function(t, e, i, n) {
- this.mergeDefaultAndTheme(t, i), this.mergeOption(t, i, n.createdBySelf, !0)
- },
- isAnimationEnabled: function() {
- if (z_.node) return !1;
- var t = this.__hostSeries;
- return this.getShallow("animation") && t && t.isAnimationEnabled()
- },
- mergeOption: function(t, e, i, n) {
- var o = this.constructor,
- r = this.mainType + "Model";
- i || e.eachSeries(function(t) {
- var i = t.get(this.mainType, !0),
- s = t[r];
- i && i.data ? (s ? s.mergeOption(i, e, !0) : (n && ex(i), d(i.data, function(t) {
- t instanceof Array ? (ex(t[0]), ex(t[1])) : ex(t)
- }), a(s = new o(i, this, e), {
- mainType: this.mainType,
- seriesIndex: t.seriesIndex,
- name: t.name,
- createdBySelf: !0
- }), s.__hostSeries = t), t[r] = s) : t[r] = null
- }, this)
- },
- formatTooltip: function(t) {
- var e = this.getData(),
- i = this.getRawValue(t),
- n = y(i) ? f(i, IO).join(", ") : IO(i),
- o = e.getName(t),
- a = TO(this.name);
- return (null != i || o) && (a += "<br />"), o && (a += TO(o), null != i && (a += " : ")), null != i && (a += TO(
- n)), a
- },
- getData: function() {
- return this._data
- },
- setData: function(t) {
- this._data = t
- }
- });
- h(AO, LI), AO.extend({
- type: "markPoint",
- defaultOption: {
- zlevel: 0,
- z: 5,
- symbol: "pin",
- symbolSize: 50,
- tooltip: {
- trigger: "item"
- },
- label: {
- show: !0,
- position: "inside"
- },
- itemStyle: {
- borderWidth: 2
- },
- emphasis: {
- label: {
- show: !0
- }
- }
- }
- });
- var DO = l,
- CO = v,
- LO = {
- min: CO(ox, "min"),
- max: CO(ox, "max"),
- average: CO(ox, "average")
- },
- kO = Vs({
- type: "marker",
- init: function() {
- this.markerGroupMap = R()
- },
- render: function(t, e, i) {
- var n = this.markerGroupMap;
- n.each(function(t) {
- t.__keep = !1
- });
- var o = this.type + "Model";
- e.eachSeries(function(t) {
- var n = t[o];
- n && this.renderSeries(t, n, e, i)
- }, this), n.each(function(t) {
- !t.__keep && this.group.remove(t.group)
- }, this)
- },
- renderSeries: function() {}
- });
- kO.extend({
- type: "markPoint",
- updateTransform: function(t, e, i) {
- e.eachSeries(function(t) {
- var e = t.markPointModel;
- e && (cx(e.getData(), t, i), this.markerGroupMap.get(t.id).updateLayout(e))
- }, this)
- },
- renderSeries: function(t, e, i, n) {
- var o = t.coordinateSystem,
- a = t.id,
- r = t.getData(),
- s = this.markerGroupMap,
- l = s.get(a) || s.set(a, new Su),
- u = dx(o, t, e);
- e.setData(u), cx(e.getData(), t, n), u.each(function(t) {
- var i = u.getItemModel(t),
- n = i.getShallow("symbolSize");
- "function" == typeof n && (n = n(e.getRawValue(t), e.getDataParams(t))), u.setItemVisual(t, {
- symbolSize: n,
- color: i.get("itemStyle.color") || r.getVisual("color"),
- symbol: i.getShallow("symbol")
- })
- }), l.updateData(u), this.group.add(l.group), u.eachItemGraphicEl(function(t) {
- t.traverse(function(t) {
- t.dataModel = e
- })
- }), l.__keep = !0, l.group.silent = e.get("silent") || t.get("silent")
- }
- }), Ls(function(t) {
- t.markPoint = t.markPoint || {}
- }), AO.extend({
- type: "markLine",
- defaultOption: {
- zlevel: 0,
- z: 5,
- symbol: ["circle", "arrow"],
- symbolSize: [8, 16],
- precision: 2,
- tooltip: {
- trigger: "item"
- },
- label: {
- show: !0,
- position: "end"
- },
- lineStyle: {
- type: "dashed"
- },
- emphasis: {
- label: {
- show: !0
- },
- lineStyle: {
- width: 3
- }
- },
- animationEasing: "linear"
- }
- });
- var PO = function(t, e, o, r) {
- var s = t.getData(),
- l = r.type;
- if (!y(r) && ("min" === l || "max" === l || "average" === l || "median" === l || null != r.xAxis || null != r.yAxis)) {
- var u, h;
- if (null != r.yAxis || null != r.xAxis) u = null != r.yAxis ? "y" : "x", e.getAxis(u), h = T(r.yAxis, r.xAxis);
- else {
- var c = rx(r, s, e, t);
- u = c.valueDataDim, c.valueAxis, h = hx(s, u, l)
- }
- var d = "x" === u ? 0 : 1,
- f = 1 - d,
- p = i(r),
- g = {};
- p.type = null, p.coord = [], g.coord = [], p.coord[f] = -1 / 0, g.coord[f] = 1 / 0;
- var m = o.get("precision");
- m >= 0 && "number" == typeof h && (h = +h.toFixed(Math.min(m, 20))), p.coord[d] = g.coord[d] = h, r = [p, g, {
- type: l,
- valueIndex: r.valueIndex,
- value: h
- }]
- }
- return r = [ax(t, r[0]), ax(t, r[1]), a({}, r[2])], r[2].type = r[2].type || "", n(r[2], r[0]), n(r[2], r[1]), r
- };
- kO.extend({
- type: "markLine",
- updateTransform: function(t, e, i) {
- e.eachSeries(function(t) {
- var e = t.markLineModel;
- if (e) {
- var n = e.getData(),
- o = e.__from,
- a = e.__to;
- o.each(function(e) {
- mx(o, e, !0, t, i), mx(a, e, !1, t, i)
- }), n.each(function(t) {
- n.setItemLayout(t, [o.getItemLayout(t), a.getItemLayout(t)])
- }), this.markerGroupMap.get(t.id).updateLayout()
- }
- }, this)
- },
- renderSeries: function(t, e, i, n) {
- function o(e, i, o) {
- var a = e.getItemModel(i);
- mx(e, i, o, t, n), e.setItemVisual(i, {
- symbolSize: a.get("symbolSize") || g[o ? 0 : 1],
- symbol: a.get("symbol", !0) || p[o ? 0 : 1],
- color: a.get("itemStyle.color") || s.getVisual("color")
- })
- }
- var a = t.coordinateSystem,
- r = t.id,
- s = t.getData(),
- l = this.markerGroupMap,
- u = l.get(r) || l.set(r, new Jd);
- this.group.add(u.group);
- var h = vx(a, t, e),
- c = h.from,
- d = h.to,
- f = h.line;
- e.__from = c, e.__to = d, e.setData(f);
- var p = e.get("symbol"),
- g = e.get("symbolSize");
- y(p) || (p = [p, p]), "number" == typeof g && (g = [g, g]), h.from.each(function(t) {
- o(c, t, !0), o(d, t, !1)
- }), f.each(function(t) {
- var e = f.getItemModel(t).get("lineStyle.color");
- f.setItemVisual(t, {
- color: e || c.getItemVisual(t, "color")
- }), f.setItemLayout(t, [c.getItemLayout(t), d.getItemLayout(t)]), f.setItemVisual(t, {
- fromSymbolSize: c.getItemVisual(t, "symbolSize"),
- fromSymbol: c.getItemVisual(t, "symbol"),
- toSymbolSize: d.getItemVisual(t, "symbolSize"),
- toSymbol: d.getItemVisual(t, "symbol")
- })
- }), u.updateData(f), h.line.eachItemGraphicEl(function(t, i) {
- t.traverse(function(t) {
- t.dataModel = e
- })
- }), u.__keep = !0, u.group.silent = e.get("silent") || t.get("silent")
- }
- }), Ls(function(t) {
- t.markLine = t.markLine || {}
- }), AO.extend({
- type: "markArea",
- defaultOption: {
- zlevel: 0,
- z: 1,
- tooltip: {
- trigger: "item"
- },
- animation: !1,
- label: {
- show: !0,
- position: "top"
- },
- itemStyle: {
- borderWidth: 0
- },
- emphasis: {
- label: {
- show: !0,
- position: "top"
- }
- }
- }
- });
- var NO = function(t, e, i, n) {
- var a = ax(t, n[0]),
- r = ax(t, n[1]),
- s = T,
- l = a.coord,
- u = r.coord;
- l[0] = s(l[0], -1 / 0), l[1] = s(l[1], -1 / 0), u[0] = s(u[0], 1 / 0), u[1] = s(u[1], 1 / 0);
- var h = o([{}, a, r]);
- return h.coord = [a.coord, r.coord], h.x0 = a.x, h.y0 = a.y, h.x1 = r.x, h.y1 = r.y, h
- },
- OO = [
- ["x0", "y0"],
- ["x1", "y0"],
- ["x1", "y1"],
- ["x0", "y1"]
- ];
- kO.extend({
- type: "markArea",
- updateTransform: function(t, e, i) {
- e.eachSeries(function(t) {
- var e = t.markAreaModel;
- if (e) {
- var n = e.getData();
- n.each(function(e) {
- var o = f(OO, function(o) {
- return bx(n, e, o, t, i)
- });
- n.setItemLayout(e, o), n.getItemGraphicEl(e).setShape("points", o)
- })
- }
- }, this)
- },
- renderSeries: function(t, e, i, n) {
- var o = t.coordinateSystem,
- a = t.id,
- s = t.getData(),
- l = this.markerGroupMap,
- u = l.get(a) || l.set(a, {
- group: new Zw
- });
- this.group.add(u.group), u.__keep = !0;
- var h = Sx(o, t, e);
- e.setData(h), h.each(function(e) {
- h.setItemLayout(e, f(OO, function(i) {
- return bx(h, e, i, t, n)
- })), h.setItemVisual(e, {
- color: s.getVisual("color")
- })
- }), h.diff(u.__data).add(function(t) {
- var e = new nM({
- shape: {
- points: h.getItemLayout(t)
- }
- });
- h.setItemGraphicEl(t, e), u.group.add(e)
- }).update(function(t, i) {
- var n = u.__data.getItemGraphicEl(i);
- bo(n, {
- shape: {
- points: h.getItemLayout(t)
- }
- }, e, t), u.group.add(n), h.setItemGraphicEl(t, n)
- }).remove(function(t) {
- var e = u.__data.getItemGraphicEl(t);
- u.group.remove(e)
- }).execute(), h.eachItemGraphicEl(function(t, i) {
- var n = h.getItemModel(i),
- o = n.getModel("label"),
- a = n.getModel("emphasis.label"),
- s = h.getItemVisual(i, "color");
- t.useStyle(r(n.getModel("itemStyle").getItemStyle(), {
- fill: Ut(s, .4),
- stroke: s
- })), t.hoverStyle = n.getModel("emphasis.itemStyle").getItemStyle(), co(t.style, t.hoverStyle, o, a, {
- labelFetcher: e,
- labelDataIndex: i,
- defaultText: h.getName(i) || "",
- isRectText: !0,
- autoColor: s
- }), uo(t, {}), t.dataModel = e
- }), u.__data = h, u.group.silent = e.get("silent") || t.get("silent")
- }
- }), Ls(function(t) {
- t.markArea = t.markArea || {}
- });
- YM.registerSubTypeDefaulter("timeline", function() {
- return "slider"
- }), Ps({
- type: "timelineChange",
- event: "timelineChanged",
- update: "prepareAndUpdate"
- }, function(t, e) {
- var i = e.getComponent("timeline");
- return i && null != t.currentIndex && (i.setCurrentIndex(t.currentIndex), !i.get("loop", !0) && i.isIndexMax() &&
- i.setPlayState(!1)), e.resetOption("timeline"), r({
- currentIndex: i.option.currentIndex
- }, t)
- }), Ps({
- type: "timelinePlayChange",
- event: "timelinePlayChanged",
- update: "update"
- }, function(t, e) {
- var i = e.getComponent("timeline");
- i && null != t.playState && i.setPlayState(t.playState)
- });
- var EO = YM.extend({
- type: "timeline",
- layoutMode: "box",
- defaultOption: {
- zlevel: 0,
- z: 4,
- show: !0,
- axisType: "time",
- realtime: !0,
- left: "20%",
- top: null,
- right: "20%",
- bottom: 0,
- width: null,
- height: 40,
- padding: 5,
- controlPosition: "left",
- autoPlay: !1,
- rewind: !1,
- loop: !0,
- playInterval: 2e3,
- currentIndex: 0,
- itemStyle: {},
- label: {
- color: "#000"
- },
- data: []
- },
- init: function(t, e, i) {
- this._data, this._names, this.mergeDefaultAndTheme(t, i), this._initData()
- },
- mergeOption: function(t) {
- EO.superApply(this, "mergeOption", arguments), this._initData()
- },
- setCurrentIndex: function(t) {
- null == t && (t = this.option.currentIndex);
- var e = this._data.count();
- this.option.loop ? t = (t % e + e) % e : (t >= e && (t = e - 1), t < 0 && (t = 0)), this.option.currentIndex = t
- },
- getCurrentIndex: function() {
- return this.option.currentIndex
- },
- isIndexMax: function() {
- return this.getCurrentIndex() >= this._data.count() - 1
- },
- setPlayState: function(t) {
- this.option.autoPlay = !!t
- },
- getPlayState: function() {
- return !!this.option.autoPlay
- },
- _initData: function() {
- var t = this.option,
- e = t.data || [],
- n = t.axisType,
- o = this._names = [];
- if ("category" === n) {
- var a = [];
- d(e, function(t, e) {
- var n, r = Li(t);
- w(t) ? (n = i(t)).value = e : n = e, a.push(n), _(r) || null != r && !isNaN(r) || (r = ""), o.push(r + "")
- }), e = a
- }
- var r = {
- category: "ordinal",
- time: "time"
- } [n] || "number";
- (this._data = new eA([{
- name: "value",
- type: r
- }], this)).initData(e, o)
- },
- getData: function() {
- return this._data
- },
- getCategories: function() {
- if ("category" === this.get("axisType")) return this._names.slice()
- }
- });
- h(EO.extend({
- type: "timeline.slider",
- defaultOption: {
- backgroundColor: "rgba(0,0,0,0)",
- borderColor: "#ccc",
- borderWidth: 0,
- orient: "horizontal",
- inverse: !1,
- tooltip: {
- trigger: "item"
- },
- symbol: "emptyCircle",
- symbolSize: 10,
- lineStyle: {
- show: !0,
- width: 2,
- color: "#304654"
- },
- label: {
- position: "auto",
- show: !0,
- interval: "auto",
- rotate: 0,
- color: "#304654"
- },
- itemStyle: {
- color: "#304654",
- borderWidth: 1
- },
- checkpointStyle: {
- symbol: "circle",
- symbolSize: 13,
- color: "#c23531",
- borderWidth: 5,
- borderColor: "rgba(194,53,49, 0.5)",
- animation: !0,
- animationDuration: 300,
- animationEasing: "quinticInOut"
- },
- controlStyle: {
- show: !0,
- showPlayBtn: !0,
- showPrevBtn: !0,
- showNextBtn: !0,
- itemSize: 22,
- itemGap: 12,
- position: "left",
- playIcon: "path://M31.6,53C17.5,53,6,41.5,6,27.4S17.5,1.8,31.6,1.8C45.7,1.8,57.2,13.3,57.2,27.4S45.7,53,31.6,53z M31.6,3.3 C18.4,3.3,7.5,14.1,7.5,27.4c0,13.3,10.8,24.1,24.1,24.1C44.9,51.5,55.7,40.7,55.7,27.4C55.7,14.1,44.9,3.3,31.6,3.3z M24.9,21.3 c0-2.2,1.6-3.1,3.5-2l10.5,6.1c1.899,1.1,1.899,2.9,0,4l-10.5,6.1c-1.9,1.1-3.5,0.2-3.5-2V21.3z",
- stopIcon: "path://M30.9,53.2C16.8,53.2,5.3,41.7,5.3,27.6S16.8,2,30.9,2C45,2,56.4,13.5,56.4,27.6S45,53.2,30.9,53.2z M30.9,3.5C17.6,3.5,6.8,14.4,6.8,27.6c0,13.3,10.8,24.1,24.101,24.1C44.2,51.7,55,40.9,55,27.6C54.9,14.4,44.1,3.5,30.9,3.5z M36.9,35.8c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H36c0.5,0,0.9,0.4,0.9,1V35.8z M27.8,35.8 c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H27c0.5,0,0.9,0.4,0.9,1L27.8,35.8L27.8,35.8z",
- nextIcon: "path://M18.6,50.8l22.5-22.5c0.2-0.2,0.3-0.4,0.3-0.7c0-0.3-0.1-0.5-0.3-0.7L18.7,4.4c-0.1-0.1-0.2-0.3-0.2-0.5 c0-0.4,0.3-0.8,0.8-0.8c0.2,0,0.5,0.1,0.6,0.3l23.5,23.5l0,0c0.2,0.2,0.3,0.4,0.3,0.7c0,0.3-0.1,0.5-0.3,0.7l-0.1,0.1L19.7,52 c-0.1,0.1-0.3,0.2-0.5,0.2c-0.4,0-0.8-0.3-0.8-0.8C18.4,51.2,18.5,51,18.6,50.8z",
- prevIcon: "path://M43,52.8L20.4,30.3c-0.2-0.2-0.3-0.4-0.3-0.7c0-0.3,0.1-0.5,0.3-0.7L42.9,6.4c0.1-0.1,0.2-0.3,0.2-0.5 c0-0.4-0.3-0.8-0.8-0.8c-0.2,0-0.5,0.1-0.6,0.3L18.3,28.8l0,0c-0.2,0.2-0.3,0.4-0.3,0.7c0,0.3,0.1,0.5,0.3,0.7l0.1,0.1L41.9,54 c0.1,0.1,0.3,0.2,0.5,0.2c0.4,0,0.8-0.3,0.8-0.8C43.2,53.2,43.1,53,43,52.8z",
- color: "#304654",
- borderColor: "#304654",
- borderWidth: 1
- },
- emphasis: {
- label: {
- show: !0,
- color: "#c23531"
- },
- itemStyle: {
- color: "#c23531"
- },
- controlStyle: {
- color: "#c23531",
- borderColor: "#c23531",
- borderWidth: 2
- }
- },
- data: []
- }
- }), LI);
- var RO = EI.extend({
- type: "timeline"
- }),
- zO = function(t, e, i, n) {
- HA.call(this, t, e, i), this.type = n || "value", this.model = null
- };
- zO.prototype = {
- constructor: zO,
- getLabelModel: function() {
- return this.model.getModel("label")
- },
- isHorizontal: function() {
- return "horizontal" === this.model.get("orient")
- }
- }, u(zO, HA);
- var BO = m,
- VO = d,
- GO = Math.PI;
- RO.extend({
- type: "timeline.slider",
- init: function(t, e) {
- this.api = e, this._axis, this._viewRect, this._timer, this._currentPointer, this._mainGroup, this._labelGroup
- },
- render: function(t, e, i, n) {
- if (this.model = t, this.api = i, this.ecModel = e, this.group.removeAll(), t.get("show", !0)) {
- var o = this._layout(t, i),
- a = this._createGroup("mainGroup"),
- r = this._createGroup("labelGroup"),
- s = this._axis = this._createAxis(o, t);
- t.formatTooltip = function(t) {
- return Qo(s.scale.getLabel(t))
- }, VO(["AxisLine", "AxisTick", "Control", "CurrentPointer"], function(e) {
- this["_render" + e](o, a, s, t)
- }, this), this._renderAxisLabel(o, r, s, t), this._position(o, t)
- }
- this._doPlayStop()
- },
- remove: function() {
- this._clearTimer(), this.group.removeAll()
- },
- dispose: function() {
- this._clearTimer()
- },
- _layout: function(t, e) {
- var i = t.get("label.position"),
- n = t.get("orient"),
- o = Ax(t, e);
- null == i || "auto" === i ? i = "horizontal" === n ? o.y + o.height / 2 < e.getHeight() / 2 ? "-" : "+" : o.x +
- o.width / 2 < e.getWidth() / 2 ? "+" : "-" : isNaN(i) && (i = {
- horizontal: {
- top: "-",
- bottom: "+"
- },
- vertical: {
- left: "-",
- right: "+"
- }
- } [n][i]);
- var a = {
- horizontal: "center",
- vertical: i >= 0 || "+" === i ? "left" : "right"
- },
- r = {
- horizontal: i >= 0 || "+" === i ? "top" : "bottom",
- vertical: "middle"
- },
- s = {
- horizontal: 0,
- vertical: GO / 2
- },
- l = "vertical" === n ? o.height : o.width,
- u = t.getModel("controlStyle"),
- h = u.get("show", !0),
- c = h ? u.get("itemSize") : 0,
- d = h ? u.get("itemGap") : 0,
- f = c + d,
- p = t.get("label.rotate") || 0;
- p = p * GO / 180;
- var g, m, v, y, x = u.get("position", !0),
- _ = h && u.get("showPlayBtn", !0),
- w = h && u.get("showPrevBtn", !0),
- b = h && u.get("showNextBtn", !0),
- S = 0,
- M = l;
- return "left" === x || "bottom" === x ? (_ && (g = [0, 0], S += f), w && (m = [S, 0], S += f), b && (v = [M - c,
- 0
- ], M -= f)) : (_ && (g = [M - c, 0], M -= f), w && (m = [0, 0], S += f), b && (v = [M - c, 0], M -= f)), y = [S,
- M
- ], t.get("inverse") && y.reverse(), {
- viewRect: o,
- mainLength: l,
- orient: n,
- rotation: s[n],
- labelRotation: p,
- labelPosOpt: i,
- labelAlign: t.get("label.align") || a[n],
- labelBaseline: t.get("label.verticalAlign") || t.get("label.baseline") || r[n],
- playPosition: g,
- prevBtnPosition: m,
- nextBtnPosition: v,
- axisExtent: y,
- controlSize: c,
- controlGap: d
- }
- },
- _position: function(t, e) {
- function i(t) {
- var e = t.position;
- t.origin = [c[0][0] - e[0], c[1][0] - e[1]]
- }
- function n(t) {
- return [
- [t.x, t.x + t.width],
- [t.y, t.y + t.height]
- ]
- }
- function o(t, e, i, n, o) {
- t[n] += i[n][o] - e[n][o]
- }
- var a = this._mainGroup,
- r = this._labelGroup,
- s = t.viewRect;
- if ("vertical" === t.orient) {
- var l = mt(),
- u = s.x,
- h = s.y + s.height;
- _t(l, l, [-u, -h]), wt(l, l, -GO / 2), _t(l, l, [u, h]), (s = s.clone()).applyTransform(l)
- }
- var c = n(s),
- d = n(a.getBoundingRect()),
- f = n(r.getBoundingRect()),
- p = a.position,
- g = r.position;
- g[0] = p[0] = c[0][0];
- var m = t.labelPosOpt;
- if (isNaN(m)) o(p, d, c, 1, v = "+" === m ? 0 : 1), o(g, f, c, 1, 1 - v);
- else {
- var v = m >= 0 ? 0 : 1;
- o(p, d, c, 1, v), g[1] = p[1] + m
- }
- a.attr("position", p), r.attr("position", g), a.rotation = r.rotation = t.rotation, i(a), i(r)
- },
- _createAxis: function(t, e) {
- var i = e.getData(),
- n = e.get("axisType"),
- o = Vl(e, n);
- o.getTicks = function() {
- return i.mapArray(["value"], function(t) {
- return t
- })
- };
- var a = i.getDataExtent("value");
- o.setExtent(a[0], a[1]), o.niceTicks();
- var r = new zO("value", o, t.axisExtent, n);
- return r.model = e, r
- },
- _createGroup: function(t) {
- var e = this["_" + t] = new Zw;
- return this.group.add(e), e
- },
- _renderAxisLine: function(t, e, i, n) {
- var o = i.getExtent();
- n.get("lineStyle.show") && e.add(new rM({
- shape: {
- x1: o[0],
- y1: 0,
- x2: o[1],
- y2: 0
- },
- style: a({
- lineCap: "round"
- }, n.getModel("lineStyle").getLineStyle()),
- silent: !0,
- z2: 1
- }))
- },
- _renderAxisTick: function(t, e, i, n) {
- var o = n.getData(),
- a = i.scale.getTicks();
- VO(a, function(t) {
- var a = i.dataToCoord(t),
- r = o.getItemModel(t),
- s = r.getModel("itemStyle"),
- l = r.getModel("emphasis.itemStyle"),
- u = {
- position: [a, 0],
- onclick: BO(this._changeTimeline, this, t)
- },
- h = Cx(r, s, e, u);
- uo(h, l.getItemStyle()), r.get("tooltip") ? (h.dataIndex = t, h.dataModel = n) : h.dataIndex = h.dataModel =
- null
- }, this)
- },
- _renderAxisLabel: function(t, e, i, n) {
- if (i.getLabelModel().get("show")) {
- var o = n.getData(),
- a = i.getViewLabels();
- VO(a, function(n) {
- var a = n.tickValue,
- r = o.getItemModel(a),
- s = r.getModel("label"),
- l = r.getModel("emphasis.label"),
- u = i.dataToCoord(n.tickValue),
- h = new qS({
- position: [u, 0],
- rotation: t.labelRotation - t.rotation,
- onclick: BO(this._changeTimeline, this, a),
- silent: !1
- });
- fo(h.style, s, {
- text: n.formattedLabel,
- textAlign: t.labelAlign,
- textVerticalAlign: t.labelBaseline
- }), e.add(h), uo(h, fo({}, l))
- }, this)
- }
- },
- _renderControl: function(t, e, i, n) {
- function o(t, i, o, h) {
- if (t) {
- var c = Dx(n, i, u, {
- position: t,
- origin: [a / 2, 0],
- rotation: h ? -r : 0,
- rectHover: !0,
- style: s,
- onclick: o
- });
- e.add(c), uo(c, l)
- }
- }
- var a = t.controlSize,
- r = t.rotation,
- s = n.getModel("controlStyle").getItemStyle(),
- l = n.getModel("emphasis.controlStyle").getItemStyle(),
- u = [0, -a / 2, a, a],
- h = n.getPlayState(),
- c = n.get("inverse", !0);
- o(t.nextBtnPosition, "controlStyle.nextIcon", BO(this._changeTimeline, this, c ? "-" : "+")), o(t.prevBtnPosition,
- "controlStyle.prevIcon", BO(this._changeTimeline, this, c ? "+" : "-")), o(t.playPosition, "controlStyle." + (
- h ? "stopIcon" : "playIcon"), BO(this._handlePlayClick, this, !h), !0)
- },
- _renderCurrentPointer: function(t, e, i, n) {
- var o = n.getData(),
- a = n.getCurrentIndex(),
- r = o.getItemModel(a).getModel("checkpointStyle"),
- s = this,
- l = {
- onCreate: function(t) {
- t.draggable = !0, t.drift = BO(s._handlePointerDrag, s), t.ondragend = BO(s._handlePointerDragend, s), Lx(t,
- a, i, n, !0)
- },
- onUpdate: function(t) {
- Lx(t, a, i, n)
- }
- };
- this._currentPointer = Cx(r, r, this._mainGroup, {}, this._currentPointer, l)
- },
- _handlePlayClick: function(t) {
- this._clearTimer(), this.api.dispatchAction({
- type: "timelinePlayChange",
- playState: t,
- from: this.uid
- })
- },
- _handlePointerDrag: function(t, e, i) {
- this._clearTimer(), this._pointerChangeTimeline([i.offsetX, i.offsetY])
- },
- _handlePointerDragend: function(t) {
- this._pointerChangeTimeline([t.offsetX, t.offsetY], !0)
- },
- _pointerChangeTimeline: function(t, e) {
- var i = this._toAxisCoord(t)[0],
- n = Bo(this._axis.getExtent().slice());
- i > n[1] && (i = n[1]), i < n[0] && (i = n[0]), this._currentPointer.position[0] = i, this._currentPointer.dirty();
- var o = this._findNearestTick(i),
- a = this.model;
- (e || o !== a.getCurrentIndex() && a.get("realtime")) && this._changeTimeline(o)
- },
- _doPlayStop: function() {
- this._clearTimer(), this.model.getPlayState() && (this._timer = setTimeout(BO(function() {
- var t = this.model;
- this._changeTimeline(t.getCurrentIndex() + (t.get("rewind", !0) ? -1 : 1))
- }, this), this.model.get("playInterval")))
- },
- _toAxisCoord: function(t) {
- return Io(t, this._mainGroup.getLocalTransform(), !0)
- },
- _findNearestTick: function(t) {
- var e, i = this.model.getData(),
- n = 1 / 0,
- o = this._axis;
- return i.each(["value"], function(i, a) {
- var r = o.dataToCoord(i),
- s = Math.abs(r - t);
- s < n && (n = s, e = a)
- }), e
- },
- _clearTimer: function() {
- this._timer && (clearTimeout(this._timer), this._timer = null)
- },
- _changeTimeline: function(t) {
- var e = this.model.getCurrentIndex();
- "+" === t ? t = e + 1 : "-" === t && (t = e - 1), this.api.dispatchAction({
- type: "timelineChange",
- currentIndex: t,
- from: this.uid
- })
- }
- }), Ls(function(t) {
- var e = t && t.timeline;
- y(e) || (e = e ? [e] : []), d(e, function(t) {
- t && Mx(t)
- })
- });
- var FO = Bs({
- type: "toolbox",
- layoutMode: {
- type: "box",
- ignoreSize: !0
- },
- optionUpdated: function() {
- FO.superApply(this, "optionUpdated", arguments), d(this.option.feature, function(t, e) {
- var i = xy(e);
- i && n(t, i.defaultOption)
- })
- },
- defaultOption: {
- show: !0,
- z: 6,
- zlevel: 0,
- orient: "horizontal",
- left: "right",
- top: "top",
- backgroundColor: "transparent",
- borderColor: "#ccc",
- borderRadius: 0,
- borderWidth: 0,
- padding: 5,
- itemSize: 15,
- itemGap: 8,
- showTitle: !0,
- iconStyle: {
- borderColor: "#666",
- color: "none"
- },
- emphasis: {
- iconStyle: {
- borderColor: "#3E98C5"
- }
- }
- }
- });
- Vs({
- type: "toolbox",
- render: function(t, e, i, n) {
- function o(o, r) {
- var s, c = h[o],
- d = h[r],
- f = new Lo(l[c], t, t.ecModel);
- if (c && !d) {
- if (kx(c)) s = {
- model: f,
- onclick: f.option.onclick,
- featureName: c
- };
- else {
- var p = xy(c);
- if (!p) return;
- s = new p(f, e, i)
- }
- u[c] = s
- } else {
- if (!(s = u[d])) return;
- s.model = f, s.ecModel = e, s.api = i
- }
- c || !d ? f.get("show") && !s.unusable ? (a(f, s, c), f.setIconStatus = function(t, e) {
- var i = this.option,
- n = this.iconPaths;
- i.iconStatus = i.iconStatus || {}, i.iconStatus[t] = e, n[t] && n[t].trigger(e)
- }, s.render && s.render(f, e, i, n)) : s.remove && s.remove(e, i) : s.dispose && s.dispose(e, i)
- }
- function a(n, o, a) {
- var l = n.getModel("iconStyle"),
- u = n.getModel("emphasis.iconStyle"),
- h = o.getIcons ? o.getIcons() : n.get("icon"),
- c = n.get("title") || {};
- if ("string" == typeof h) {
- var f = h,
- p = c;
- c = {}, (h = {})[a] = f, c[a] = p
- }
- var g = n.iconPaths = {};
- d(h, function(a, h) {
- var d = Co(a, {}, {
- x: -s / 2,
- y: -s / 2,
- width: s,
- height: s
- });
- d.setStyle(l.getItemStyle()), d.hoverStyle = u.getItemStyle(), uo(d), t.get("showTitle") && (d.__title = c[h],
- d.on("mouseover", function() {
- var t = u.getItemStyle();
- d.setStyle({
- text: c[h],
- textPosition: t.textPosition || "bottom",
- textFill: t.fill || t.stroke || "#000",
- textAlign: t.textAlign || "center"
- })
- }).on("mouseout", function() {
- d.setStyle({
- textFill: null
- })
- })), d.trigger(n.get("iconStatus." + h) || "normal"), r.add(d), d.on("click", m(o.onclick, o, e, i, h)), g[
- h] = d
- })
- }
- var r = this.group;
- if (r.removeAll(), t.get("show")) {
- var s = +t.get("itemSize"),
- l = t.get("feature") || {},
- u = this._features || (this._features = {}),
- h = [];
- d(l, function(t, e) {
- h.push(e)
- }), new Hs(this._featureNames || [], h).add(o).update(o).remove(v(o, null)).execute(), this._featureNames = h,
- dv(r, t, i), r.add(fv(r.getBoundingRect(), t)), r.eachChild(function(t) {
- var e = t.__title,
- n = t.hoverStyle;
- if (n && e) {
- var o = De(e, He(n)),
- a = t.position[0] + r.position[0],
- l = !1;
- t.position[1] + r.position[1] + s + o.height > i.getHeight() && (n.textPosition = "top", l = !0);
- var u = l ? -5 - o.height : s + 8;
- a + o.width / 2 > i.getWidth() ? (n.textPosition = ["100%", u], n.textAlign = "right") : a - o.width / 2 <
- 0 && (n.textPosition = [0, u], n.textAlign = "left")
- }
- })
- }
- },
- updateView: function(t, e, i, n) {
- d(this._features, function(t) {
- t.updateView && t.updateView(t.model, e, i, n)
- })
- },
- remove: function(t, e) {
- d(this._features, function(i) {
- i.remove && i.remove(t, e)
- }), this.group.removeAll()
- },
- dispose: function(t, e) {
- d(this._features, function(i) {
- i.dispose && i.dispose(t, e)
- })
- }
- });
- var WO = XI.toolbox.saveAsImage;
- Px.defaultOption = {
- show: !0,
- icon: "M4.7,22.9L29.3,45.5L54.7,23.4M4.6,43.6L4.6,58L53.8,58L53.8,43.6M29.2,45.1L29.2,0",
- title: WO.title,
- type: "png",
- name: "",
- excludeComponents: ["toolbox"],
- pixelRatio: 1,
- lang: WO.lang.slice()
- }, Px.prototype.unusable = !z_.canvasSupported, Px.prototype.onclick = function(t, e) {
- var i = this.model,
- n = i.get("name") || t.get("title.0.text") || "echarts",
- o = document.createElement("a"),
- a = i.get("type", !0) || "png";
- o.download = n + "." + a, o.target = "_blank";
- var r = e.getConnectedDataURL({
- type: a,
- backgroundColor: i.get("backgroundColor", !0) || t.get("backgroundColor") || "#fff",
- excludeComponents: i.get("excludeComponents"),
- pixelRatio: i.get("pixelRatio")
- });
- if (o.href = r, "function" != typeof MouseEvent || z_.browser.ie || z_.browser.edge)
- if (window.navigator.msSaveOrOpenBlob) {
- for (var s = atob(r.split(",")[1]), l = s.length, u = new Uint8Array(l); l--;) u[l] = s.charCodeAt(l);
- var h = new Blob([u]);
- window.navigator.msSaveOrOpenBlob(h, n + "." + a)
- } else {
- var c = i.get("lang"),
- d = '<body style="margin:0;"><img src="' + r + '" style="max-width:100%;" title="' + (c && c[0] || "") +
- '" /></body>';
- window.open().document.write(d)
- }
- else {
- var f = new MouseEvent("click", {
- view: window,
- bubbles: !0,
- cancelable: !1
- });
- o.dispatchEvent(f)
- }
- }, yy("saveAsImage", Px);
- var HO = XI.toolbox.magicType;
- Nx.defaultOption = {
- show: !0,
- type: [],
- icon: {
- line: "M4.1,28.9h7.1l9.3-22l7.4,38l9.7-19.7l3,12.8h14.9M4.1,58h51.4",
- bar: "M6.7,22.9h10V48h-10V22.9zM24.9,13h10v35h-10V13zM43.2,2h10v46h-10V2zM3.1,58h53.7",
- stack: "M8.2,38.4l-8.4,4.1l30.6,15.3L60,42.5l-8.1-4.1l-21.5,11L8.2,38.4z M51.9,30l-8.1,4.2l-13.4,6.9l-13.9-6.9L8.2,30l-8.4,4.2l8.4,4.2l22.2,11l21.5-11l8.1-4.2L51.9,30z M51.9,21.7l-8.1,4.2L35.7,30l-5.3,2.8L24.9,30l-8.4-4.1l-8.3-4.2l-8.4,4.2L8.2,30l8.3,4.2l13.9,6.9l13.4-6.9l8.1-4.2l8.1-4.1L51.9,21.7zM30.4,2.2L-0.2,17.5l8.4,4.1l8.3,4.2l8.4,4.2l5.5,2.7l5.3-2.7l8.1-4.2l8.1-4.2l8.1-4.1L30.4,2.2z",
- tiled: "M2.3,2.2h22.8V25H2.3V2.2z M35,2.2h22.8V25H35V2.2zM2.3,35h22.8v22.8H2.3V35z M35,35h22.8v22.8H35V35z"
- },
- title: i(HO.title),
- option: {},
- seriesIndex: {}
- };
- var ZO = Nx.prototype;
- ZO.getIcons = function() {
- var t = this.model,
- e = t.get("icon"),
- i = {};
- return d(t.get("type"), function(t) {
- e[t] && (i[t] = e[t])
- }), i
- };
- var UO = {
- line: function(t, e, i, o) {
- if ("bar" === t) return n({
- id: e,
- type: "line",
- data: i.get("data"),
- stack: i.get("stack"),
- markPoint: i.get("markPoint"),
- markLine: i.get("markLine")
- }, o.get("option.line") || {}, !0)
- },
- bar: function(t, e, i, o) {
- if ("line" === t) return n({
- id: e,
- type: "bar",
- data: i.get("data"),
- stack: i.get("stack"),
- markPoint: i.get("markPoint"),
- markLine: i.get("markLine")
- }, o.get("option.bar") || {}, !0)
- },
- stack: function(t, e, i, o) {
- if ("line" === t || "bar" === t) return n({
- id: e,
- stack: "__ec_magicType_stack__"
- }, o.get("option.stack") || {}, !0)
- },
- tiled: function(t, e, i, o) {
- if ("line" === t || "bar" === t) return n({
- id: e,
- stack: ""
- }, o.get("option.tiled") || {}, !0)
- }
- },
- XO = [
- ["line", "bar"],
- ["stack", "tiled"]
- ];
- ZO.onclick = function(t, e, i) {
- var n = this.model,
- o = n.get("seriesIndex." + i);
- if (UO[i]) {
- var a = {
- series: []
- };
- d(XO, function(t) {
- l(t, i) >= 0 && d(t, function(t) {
- n.setIconStatus(t, "normal")
- })
- }), n.setIconStatus(i, "emphasis"), t.eachComponent({
- mainType: "series",
- query: null == o ? null : {
- seriesIndex: o
- }
- }, function(e) {
- var o = e.subType,
- s = e.id,
- l = UO[i](o, s, e, n);
- l && (r(l, e.option), a.series.push(l));
- var u = e.coordinateSystem;
- if (u && "cartesian2d" === u.type && ("line" === i || "bar" === i)) {
- var h = u.getAxesByScale("ordinal")[0];
- if (h) {
- var c = h.dim + "Axis",
- d = t.queryComponents({
- mainType: c,
- index: e.get(name + "Index"),
- id: e.get(name + "Id")
- })[0].componentIndex;
- a[c] = a[c] || [];
- for (var f = 0; f <= d; f++) a[c][d] = a[c][d] || {};
- a[c][d].boundaryGap = "bar" === i
- }
- }
- }), e.dispatchAction({
- type: "changeMagicType",
- currentType: i,
- newOption: a
- })
- }
- }, Ps({
- type: "changeMagicType",
- event: "magicTypeChanged",
- update: "prepareAndUpdate"
- }, function(t, e) {
- e.mergeOption(t.newOption)
- }), yy("magicType", Nx);
- var jO = XI.toolbox.dataView,
- YO = new Array(60).join("-"),
- qO = "\t",
- KO = new RegExp("[" + qO + "]+", "g");
- Hx.defaultOption = {
- show: !0,
- readOnly: !1,
- optionToContent: null,
- contentToOption: null,
- icon: "M17.5,17.3H33 M17.5,17.3H33 M45.4,29.5h-28 M11.5,2v56H51V14.8L38.4,2H11.5z M38.4,2.2v12.7H51 M45.4,41.7h-28",
- title: i(jO.title),
- lang: i(jO.lang),
- backgroundColor: "#fff",
- textColor: "#000",
- textareaColor: "#fff",
- textareaBorderColor: "#333",
- buttonColor: "#c23531",
- buttonTextColor: "#fff"
- }, Hx.prototype.onclick = function(t, e) {
- function i() {
- n.removeChild(a), x._dom = null
- }
- var n = e.getDom(),
- o = this.model;
- this._dom && n.removeChild(this._dom);
- var a = document.createElement("div");
- a.style.cssText = "position:absolute;left:5px;top:5px;bottom:5px;right:5px;", a.style.backgroundColor = o.get(
- "backgroundColor") || "#fff";
- var r = document.createElement("h4"),
- s = o.get("lang") || [];
- r.innerHTML = s[0] || o.get("title"), r.style.cssText = "margin: 10px 20px;", r.style.color = o.get("textColor");
- var l = document.createElement("div"),
- u = document.createElement("textarea");
- l.style.cssText = "display:block;width:100%;overflow:auto;";
- var h = o.get("optionToContent"),
- c = o.get("contentToOption"),
- d = zx(t);
- if ("function" == typeof h) {
- var f = h(e.getOption());
- "string" == typeof f ? l.innerHTML = f : M(f) && l.appendChild(f)
- } else l.appendChild(u), u.readOnly = o.get("readOnly"), u.style.cssText =
- "width:100%;height:100%;font-family:monospace;font-size:14px;line-height:1.6rem;", u.style.color = o.get(
- "textColor"), u.style.borderColor = o.get("textareaBorderColor"), u.style.backgroundColor = o.get("textareaColor"),
- u.value = d.value;
- var p = d.meta,
- g = document.createElement("div");
- g.style.cssText = "position:absolute;bottom:0;left:0;right:0;";
- var m = "float:right;margin-right:20px;border:none;cursor:pointer;padding:2px 5px;font-size:12px;border-radius:3px",
- v = document.createElement("div"),
- y = document.createElement("div");
- m += ";background-color:" + o.get("buttonColor"), m += ";color:" + o.get("buttonTextColor");
- var x = this;
- ut(v, "click", i), ut(y, "click", function() {
- var t;
- try {
- t = "function" == typeof c ? c(l, e.getOption()) : Wx(u.value, p)
- } catch (t) {
- throw i(), new Error("Data view format error " + t)
- }
- t && e.dispatchAction({
- type: "changeDataView",
- newOption: t
- }), i()
- }), v.innerHTML = s[1], y.innerHTML = s[2], y.style.cssText = m, v.style.cssText = m, !o.get("readOnly") && g.appendChild(
- y), g.appendChild(v), ut(u, "keydown", function(t) {
- if (9 === (t.keyCode || t.which)) {
- var e = this.value,
- i = this.selectionStart,
- n = this.selectionEnd;
- this.value = e.substring(0, i) + qO + e.substring(n), this.selectionStart = this.selectionEnd = i + 1, lw(t)
- }
- }), a.appendChild(r), a.appendChild(l), a.appendChild(g), l.style.height = n.clientHeight - 80 + "px", n.appendChild(
- a), this._dom = a
- }, Hx.prototype.remove = function(t, e) {
- this._dom && e.getDom().removeChild(this._dom)
- }, Hx.prototype.dispose = function(t, e) {
- this.remove(t, e)
- }, yy("dataView", Hx), Ps({
- type: "changeDataView",
- event: "dataViewChanged",
- update: "prepareAndUpdate"
- }, function(t, e) {
- var i = [];
- d(t.newOption.series, function(t) {
- var n = e.getSeriesByName(t.name)[0];
- if (n) {
- var o = n.get("data");
- i.push({
- name: t.name,
- data: Zx(t.data, o)
- })
- } else i.push(a({
- type: "scatter"
- }, t))
- }), e.mergeOption(r({
- series: i
- }, t.newOption))
- });
- var $O = d,
- JO = "\0_ec_hist_store";
- BN.extend({
- type: "dataZoom.select"
- }), VN.extend({
- type: "dataZoom.select"
- });
- var QO = XI.toolbox.dataZoom,
- tE = d,
- eE = "\0_ec_\0toolbox-dataZoom_";
- Kx.defaultOption = {
- show: !0,
- icon: {
- zoom: "M0,13.5h26.9 M13.5,26.9V0 M32.1,13.5H58V58H13.5 V32.1",
- back: "M22,1.4L9.9,13.5l12.3,12.3 M10.3,13.5H54.9v44.6 H10.3v-26"
- },
- title: i(QO.title)
- };
- var iE = Kx.prototype;
- iE.render = function(t, e, i, n) {
- this.model = t, this.ecModel = e, this.api = i, Qx(t, e, this, n, i), Jx(t, e)
- }, iE.onclick = function(t, e, i) {
- nE[i].call(this)
- }, iE.remove = function(t, e) {
- this._brushController.unmount()
- }, iE.dispose = function(t, e) {
- this._brushController.dispose()
- };
- var nE = {
- zoom: function() {
- var t = !this._isZoomActive;
- this.api.dispatchAction({
- type: "takeGlobalCursor",
- key: "dataZoomSelect",
- dataZoomSelectActive: t
- })
- },
- back: function() {
- this._dispatchZoomAction(Xx(this.ecModel))
- }
- };
- iE._onBrush = function(t, e) {
- function i(t, e, i) {
- var r = e.getAxis(t),
- s = r.model,
- l = n(t, s, a),
- u = l.findRepresentativeAxisProxy(s).getMinMaxSpan();
- null == u.minValueSpan && null == u.maxValueSpan || (i = EL(0, i.slice(), r.scale.getExtent(), 0, u.minValueSpan,
- u.maxValueSpan)), l && (o[l.id] = {
- dataZoomId: l.id,
- startValue: i[0],
- endValue: i[1]
- })
- }
- function n(t, e, i) {
- var n;
- return i.eachComponent({
- mainType: "dataZoom",
- subType: "select"
- }, function(i) {
- i.getAxisModel(t, e.componentIndex) && (n = i)
- }), n
- }
- if (e.isEnd && t.length) {
- var o = {},
- a = this.ecModel;
- this._brushController.updateCovers([]), new iy($x(this.model.option), a, {
- include: ["grid"]
- }).matchOutputRanges(t, a, function(t, e, n) {
- if ("cartesian2d" === n.type) {
- var o = t.brushType;
- "rect" === o ? (i("x", n, e[0]), i("y", n, e[1])) : i({
- lineX: "x",
- lineY: "y"
- } [o], n, e)
- }
- }), Ux(a, o), this._dispatchZoomAction(o)
- }
- }, iE._dispatchZoomAction = function(t) {
- var e = [];
- tE(t, function(t, n) {
- e.push(i(t))
- }), e.length && this.api.dispatchAction({
- type: "dataZoom",
- from: this.uid,
- batch: e
- })
- }, yy("dataZoom", Kx), Ls(function(t) {
- function e(t, e) {
- if (e) {
- var o = t + "Index",
- a = e[o];
- null == a || "all" === a || y(a) || (a = !1 === a || "none" === a ? [] : [a]), i(t, function(e, i) {
- if (null == a || "all" === a || -1 !== l(a, i)) {
- var r = {
- type: "select",
- $fromToolbox: !0,
- id: eE + t + i
- };
- r[o] = i, n.push(r)
- }
- })
- }
- }
- function i(e, i) {
- var n = t[e];
- y(n) || (n = n ? [n] : []), tE(n, i)
- }
- if (t) {
- var n = t.dataZoom || (t.dataZoom = []);
- y(n) || (t.dataZoom = n = [n]);
- var o = t.toolbox;
- if (o && (y(o) && (o = o[0]), o && o.feature)) {
- var a = o.feature.dataZoom;
- e("xAxis", a), e("yAxis", a)
- }
- }
- });
- var oE = XI.toolbox.restore;
- t_.defaultOption = {
- show: !0,
- icon: "M3.8,33.4 M47,18.9h9.8V8.7 M56.3,20.1 C52.1,9,40.5,0.6,26.8,2.1C12.6,3.7,1.6,16.2,2.1,30.6 M13,41.1H3.1v10.2 M3.7,39.9c4.2,11.1,15.8,19.5,29.5,18 c14.2-1.6,25.2-14.1,24.7-28.5",
- title: oE.title
- }, t_.prototype.onclick = function(t, e, i) {
- jx(t), e.dispatchAction({
- type: "restore",
- from: this.uid
- })
- }, yy("restore", t_), Ps({
- type: "restore",
- event: "restore",
- update: "prepareAndUpdate"
- }, function(t, e) {
- e.resetOption("recreate")
- });
- var aE, rE = "urn:schemas-microsoft-com:vml",
- sE = "undefined" == typeof window ? null : window,
- lE = !1,
- uE = sE && sE.document;
- if (uE && !z_.canvasSupported) try {
- !uE.namespaces.zrvml && uE.namespaces.add("zrvml", rE), aE = function(t) {
- return uE.createElement("<zrvml:" + t + ' class="zrvml">')
- }
- } catch (t) {
- aE = function(t) {
- return uE.createElement("<" + t + ' xmlns="' + rE + '" class="zrvml">')
- }
- }
- var hE = MS.CMD,
- cE = Math.round,
- dE = Math.sqrt,
- fE = Math.abs,
- pE = Math.cos,
- gE = Math.sin,
- mE = Math.max;
- if (!z_.canvasSupported) {
- var vE = 21600,
- yE = vE / 2,
- xE = function(t) {
- t.style.cssText = "position:absolute;left:0;top:0;width:1px;height:1px;", t.coordsize = vE + "," + vE, t.coordorigin =
- "0,0"
- },
- _E = function(t) {
- return String(t).replace(/&/g, "&").replace(/"/g, """)
- },
- wE = function(t, e, i) {
- return "rgb(" + [t, e, i].join(",") + ")"
- },
- bE = function(t, e) {
- e && t && e.parentNode !== t && t.appendChild(e)
- },
- SE = function(t, e) {
- e && t && e.parentNode === t && t.removeChild(e)
- },
- ME = function(t, e, i) {
- return 1e5 * (parseFloat(t) || 0) + 1e3 * (parseFloat(e) || 0) + i
- },
- IE = function(t, e) {
- return "string" == typeof t ? t.lastIndexOf("%") >= 0 ? parseFloat(t) / 100 * e : parseFloat(t) : t
- },
- TE = function(t, e, i) {
- var n = zt(e);
- i = +i, isNaN(i) && (i = 1), n && (t.color = wE(n[0], n[1], n[2]), t.opacity = i * n[3])
- },
- AE = function(t) {
- var e = zt(t);
- return [wE(e[0], e[1], e[2]), e[3]]
- },
- DE = function(t, e, i) {
- var n = e.fill;
- if (null != n)
- if (n instanceof cM) {
- var o, a = 0,
- r = [0, 0],
- s = 0,
- l = 1,
- u = i.getBoundingRect(),
- h = u.width,
- c = u.height;
- if ("linear" === n.type) {
- o = "gradient";
- var d = i.transform,
- f = [n.x * h, n.y * c],
- p = [n.x2 * h, n.y2 * c];
- d && (Q(f, f, d), Q(p, p, d));
- var g = p[0] - f[0],
- m = p[1] - f[1];
- (a = 180 * Math.atan2(g, m) / Math.PI) < 0 && (a += 360), a < 1e-6 && (a = 0)
- } else {
- o = "gradientradial";
- var f = [n.x * h, n.y * c],
- d = i.transform,
- v = i.scale,
- y = h,
- x = c;
- r = [(f[0] - u.x) / y, (f[1] - u.y) / x], d && Q(f, f, d), y /= v[0] * vE, x /= v[1] * vE;
- var _ = mE(y, x);
- s = 0 / _, l = 2 * n.r / _ - s
- }
- var w = n.colorStops.slice();
- w.sort(function(t, e) {
- return t.offset - e.offset
- });
- for (var b = w.length, S = [], M = [], I = 0; I < b; I++) {
- var T = w[I],
- A = AE(T.color);
- M.push(T.offset * l + s + " " + A[0]), 0 !== I && I !== b - 1 || S.push(A)
- }
- if (b >= 2) {
- var D = S[0][0],
- C = S[1][0],
- L = S[0][1] * e.opacity,
- k = S[1][1] * e.opacity;
- t.type = o, t.method = "none", t.focus = "100%", t.angle = a, t.color = D, t.color2 = C, t.colors = M.join(","),
- t.opacity = k, t.opacity2 = L
- }
- "radial" === o && (t.focusposition = r.join(","))
- } else TE(t, n, e.opacity)
- },
- CE = function(t, e) {
- null != e.lineDash && (t.dashstyle = e.lineDash.join(" ")), null == e.stroke || e.stroke instanceof cM || TE(t, e.stroke,
- e.opacity)
- },
- LE = function(t, e, i, n) {
- var o = "fill" == e,
- a = t.getElementsByTagName(e)[0];
- null != i[e] && "none" !== i[e] && (o || !o && i.lineWidth) ? (t[o ? "filled" : "stroked"] = "true", i[e] instanceof cM &&
- SE(t, a), a || (a = e_(e)), o ? DE(a, i, n) : CE(a, i), bE(t, a)) : (t[o ? "filled" : "stroked"] = "false", SE(t,
- a))
- },
- kE = [
- [],
- [],
- []
- ],
- PE = function(t, e) {
- var i, n, o, a, r, s, l = hE.M,
- u = hE.C,
- h = hE.L,
- c = hE.A,
- d = hE.Q,
- f = [],
- p = t.data,
- g = t.len();
- for (a = 0; a < g;) {
- switch (o = p[a++], n = "", i = 0, o) {
- case l:
- n = " m ", i = 1, r = p[a++], s = p[a++], kE[0][0] = r, kE[0][1] = s;
- break;
- case h:
- n = " l ", i = 1, r = p[a++], s = p[a++], kE[0][0] = r, kE[0][1] = s;
- break;
- case d:
- case u:
- n = " c ", i = 3;
- var m, v, y = p[a++],
- x = p[a++],
- _ = p[a++],
- w = p[a++];
- o === d ? (m = _, v = w, _ = (_ + 2 * y) / 3, w = (w + 2 * x) / 3, y = (r + 2 * y) / 3, x = (s + 2 * x) / 3) :
- (m = p[a++], v = p[a++]), kE[0][0] = y, kE[0][1] = x, kE[1][0] = _, kE[1][1] = w, kE[2][0] = m, kE[2][1] = v,
- r = m, s = v;
- break;
- case c:
- var b = 0,
- S = 0,
- M = 1,
- I = 1,
- T = 0;
- e && (b = e[4], S = e[5], M = dE(e[0] * e[0] + e[1] * e[1]), I = dE(e[2] * e[2] + e[3] * e[3]), T = Math.atan2(
- -e[1] / I, e[0] / M));
- var A = p[a++],
- D = p[a++],
- C = p[a++],
- L = p[a++],
- k = p[a++] + T,
- P = p[a++] + k + T;
- a++;
- var N = p[a++],
- O = A + pE(k) * C,
- E = D + gE(k) * L,
- y = A + pE(P) * C,
- x = D + gE(P) * L,
- R = N ? " wa " : " at ";
- Math.abs(O - y) < 1e-4 && (Math.abs(P - k) > .01 ? N && (O += .0125) : Math.abs(E - D) < 1e-4 ? N && O < A || !
- N && O > A ? x -= .0125 : x += .0125 : N && E < D || !N && E > D ? y += .0125 : y -= .0125), f.push(R, cE(((A -
- C) * M + b) * vE - yE), ",", cE(((D - L) * I + S) * vE - yE), ",", cE(((A + C) * M + b) * vE - yE), ",", cE(
- ((D + L) * I + S) * vE - yE), ",", cE((O * M + b) * vE - yE), ",", cE((E * I + S) * vE - yE), ",", cE((y * M +
- b) * vE - yE), ",", cE((x * I + S) * vE - yE)), r = y, s = x;
- break;
- case hE.R:
- var z = kE[0],
- B = kE[1];
- z[0] = p[a++], z[1] = p[a++], B[0] = z[0] + p[a++], B[1] = z[1] + p[a++], e && (Q(z, z, e), Q(B, B, e)), z[0] =
- cE(z[0] * vE - yE), B[0] = cE(B[0] * vE - yE), z[1] = cE(z[1] * vE - yE), B[1] = cE(B[1] * vE - yE), f.push(
- " m ", z[0], ",", z[1], " l ", B[0], ",", z[1], " l ", B[0], ",", B[1], " l ", z[0], ",", B[1]);
- break;
- case hE.Z:
- f.push(" x ")
- }
- if (i > 0) {
- f.push(n);
- for (var V = 0; V < i; V++) {
- var G = kE[V];
- e && Q(G, G, e), f.push(cE(G[0] * vE - yE), ",", cE(G[1] * vE - yE), V < i - 1 ? "," : "")
- }
- }
- }
- return f.join("")
- };
- kn.prototype.brushVML = function(t) {
- var e = this.style,
- i = this._vmlEl;
- i || (i = e_("shape"), xE(i), this._vmlEl = i), LE(i, "fill", e, this), LE(i, "stroke", e, this);
- var n = this.transform,
- o = null != n,
- a = i.getElementsByTagName("stroke")[0];
- if (a) {
- var r = e.lineWidth;
- if (o && !e.strokeNoScale) {
- var s = n[0] * n[3] - n[1] * n[2];
- r *= dE(fE(s))
- }
- a.weight = r + "px"
- }
- var l = this.path || (this.path = new MS);
- this.__dirtyPath && (l.beginPath(), this.buildPath(l, this.shape), l.toStatic(), this.__dirtyPath = !1), i.path =
- PE(l, this.transform), i.style.zIndex = ME(this.zlevel, this.z, this.z2), bE(t, i), null != e.text ? this.drawRectText(
- t, this.getBoundingRect()) : this.removeRectText(t)
- }, kn.prototype.onRemove = function(t) {
- SE(t, this._vmlEl), this.removeRectText(t)
- }, kn.prototype.onAdd = function(t) {
- bE(t, this._vmlEl), this.appendRectText(t)
- };
- var NE = function(t) {
- return "object" == typeof t && t.tagName && "IMG" === t.tagName.toUpperCase()
- };
- hi.prototype.brushVML = function(t) {
- var e, i, n = this.style,
- o = n.image;
- if (NE(o)) {
- var a = o.src;
- if (a === this._imageSrc) e = this._imageWidth, i = this._imageHeight;
- else {
- var r = o.runtimeStyle,
- s = r.width,
- l = r.height;
- r.width = "auto", r.height = "auto", e = o.width, i = o.height, r.width = s, r.height = l, this._imageSrc = a,
- this._imageWidth = e, this._imageHeight = i
- }
- o = a
- } else o === this._imageSrc && (e = this._imageWidth, i = this._imageHeight);
- if (o) {
- var u = n.x || 0,
- h = n.y || 0,
- c = n.width,
- d = n.height,
- f = n.sWidth,
- p = n.sHeight,
- g = n.sx || 0,
- m = n.sy || 0,
- v = f && p,
- y = this._vmlEl;
- y || (y = uE.createElement("div"), xE(y), this._vmlEl = y);
- var x, _ = y.style,
- w = !1,
- b = 1,
- S = 1;
- if (this.transform && (x = this.transform, b = dE(x[0] * x[0] + x[1] * x[1]), S = dE(x[2] * x[2] + x[3] * x[3]),
- w = x[1] || x[2]), w) {
- var M = [u, h],
- I = [u + c, h],
- T = [u, h + d],
- A = [u + c, h + d];
- Q(M, M, x), Q(I, I, x), Q(T, T, x), Q(A, A, x);
- var D = mE(M[0], I[0], T[0], A[0]),
- C = mE(M[1], I[1], T[1], A[1]),
- L = [];
- L.push("M11=", x[0] / b, ",", "M12=", x[2] / S, ",", "M21=", x[1] / b, ",", "M22=", x[3] / S, ",", "Dx=", cE(u *
- b + x[4]), ",", "Dy=", cE(h * S + x[5])), _.padding = "0 " + cE(D) + "px " + cE(C) + "px 0", _.filter =
- "progid:DXImageTransform.Microsoft.Matrix(" + L.join("") + ", SizingMethod=clip)"
- } else x && (u = u * b + x[4], h = h * S + x[5]), _.filter = "", _.left = cE(u) + "px", _.top = cE(h) + "px";
- var k = this._imageEl,
- P = this._cropEl;
- k || (k = uE.createElement("div"), this._imageEl = k);
- var N = k.style;
- if (v) {
- if (e && i) N.width = cE(b * e * c / f) + "px", N.height = cE(S * i * d / p) + "px";
- else {
- var O = new Image,
- E = this;
- O.onload = function() {
- O.onload = null, e = O.width, i = O.height, N.width = cE(b * e * c / f) + "px", N.height = cE(S * i * d / p) +
- "px", E._imageWidth = e, E._imageHeight = i, E._imageSrc = o
- }, O.src = o
- }
- P || ((P = uE.createElement("div")).style.overflow = "hidden", this._cropEl = P);
- var R = P.style;
- R.width = cE((c + g * c / f) * b), R.height = cE((d + m * d / p) * S), R.filter =
- "progid:DXImageTransform.Microsoft.Matrix(Dx=" + -g * c / f * b + ",Dy=" + -m * d / p * S + ")", P.parentNode ||
- y.appendChild(P), k.parentNode != P && P.appendChild(k)
- } else N.width = cE(b * c) + "px", N.height = cE(S * d) + "px", y.appendChild(k), P && P.parentNode && (y.removeChild(
- P), this._cropEl = null);
- var z = "",
- B = n.opacity;
- B < 1 && (z += ".Alpha(opacity=" + cE(100 * B) + ") "), z +=
- "progid:DXImageTransform.Microsoft.AlphaImageLoader(src=" + o + ", SizingMethod=scale)", N.filter = z, y.style.zIndex =
- ME(this.zlevel, this.z, this.z2), bE(t, y), null != n.text && this.drawRectText(t, this.getBoundingRect())
- }
- }, hi.prototype.onRemove = function(t) {
- SE(t, this._vmlEl), this._vmlEl = null, this._cropEl = null, this._imageEl = null, this.removeRectText(t)
- }, hi.prototype.onAdd = function(t) {
- bE(t, this._vmlEl), this.appendRectText(t)
- };
- var OE, EE = {},
- RE = 0,
- zE = document.createElement("div"),
- BE = function(t) {
- var e = EE[t];
- if (!e) {
- RE > 100 && (RE = 0, EE = {});
- var i, n = zE.style;
- try {
- n.font = t, i = n.fontFamily.split(",")[0]
- } catch (t) {}
- e = {
- style: n.fontStyle || "normal",
- variant: n.fontVariant || "normal",
- weight: n.fontWeight || "normal",
- size: 0 | parseFloat(n.fontSize || 12),
- family: i || "Microsoft YaHei"
- }, EE[t] = e, RE++
- }
- return e
- };
- ! function(t, e) {
- hb[t] = e
- }("measureText", function(t, e) {
- var i = uE;
- OE || ((OE = i.createElement("div")).style.cssText =
- "position:absolute;top:-20000px;left:0;padding:0;margin:0;border:none;white-space:pre;", uE.body.appendChild(OE)
- );
- try {
- OE.style.font = e
- } catch (t) {}
- return OE.innerHTML = "", OE.appendChild(i.createTextNode(t)), {
- width: OE.offsetWidth
- }
- });
- for (var VE = new ue, GE = [gb, ui, hi, kn, qS], FE = 0; FE < GE.length; FE++) {
- var WE = GE[FE].prototype;
- WE.drawRectText = function(t, e, i, n) {
- var o = this.style;
- this.__dirty && Ue(o);
- var a = o.text;
- if (null != a && (a += ""), a) {
- if (o.rich) {
- var r = Fe(a, o);
- a = [];
- for (var s = 0; s < r.lines.length; s++) {
- for (var l = r.lines[s].tokens, u = [], h = 0; h < l.length; h++) u.push(l[h].text);
- a.push(u.join(""))
- }
- a = a.join("\n")
- }
- var c, d, f = o.textAlign,
- p = o.textVerticalAlign,
- g = BE(o.font),
- m = g.style + " " + g.variant + " " + g.weight + " " + g.size + 'px "' + g.family + '"';
- i = i || De(a, m, f, p);
- var v = this.transform;
- if (v && !n && (VE.copy(e), VE.applyTransform(v), e = VE), n) c = e.x, d = e.y;
- else {
- var y = o.textPosition,
- x = o.textDistance;
- if (y instanceof Array) c = e.x + IE(y[0], e.width), d = e.y + IE(y[1], e.height), f = f || "left";
- else {
- var _ = Ne(y, e, x);
- c = _.x, d = _.y, f = f || _.textAlign, p = p || _.textVerticalAlign
- }
- }
- c = ke(c, i.width, f), d = Pe(d, i.height, p), d += i.height / 2;
- var w, b, S, M = e_,
- I = this._textVmlEl;
- I ? b = (w = (S = I.firstChild).nextSibling).nextSibling : (I = M("line"), w = M("path"), b = M("textpath"), S =
- M("skew"), b.style["v-text-align"] = "left", xE(I), w.textpathok = !0, b.on = !0, I.from = "0 0", I.to =
- "1000 0.05", bE(I, S), bE(I, w), bE(I, b), this._textVmlEl = I);
- var T = [c, d],
- A = I.style;
- v && n ? (Q(T, T, v), S.on = !0, S.matrix = v[0].toFixed(3) + "," + v[2].toFixed(3) + "," + v[1].toFixed(3) +
- "," + v[3].toFixed(3) + ",0,0", S.offset = (cE(T[0]) || 0) + "," + (cE(T[1]) || 0), S.origin = "0 0", A.left =
- "0px", A.top = "0px") : (S.on = !1, A.left = cE(c) + "px", A.top = cE(d) + "px"), b.string = _E(a);
- try {
- b.style.font = m
- } catch (t) {}
- LE(I, "fill", {
- fill: o.textFill,
- opacity: o.opacity
- }, this), LE(I, "stroke", {
- stroke: o.textStroke,
- opacity: o.opacity,
- lineDash: o.lineDash
- }, this), I.style.zIndex = ME(this.zlevel, this.z, this.z2), bE(t, I)
- }
- }, WE.removeRectText = function(t) {
- SE(t, this._textVmlEl), this._textVmlEl = null
- }, WE.appendRectText = function(t) {
- bE(t, this._textVmlEl)
- }
- }
- qS.prototype.brushVML = function(t) {
- var e = this.style;
- null != e.text ? this.drawRectText(t, {
- x: e.x || 0,
- y: e.y || 0,
- width: 0,
- height: 0
- }, this.getBoundingRect(), !0) : this.removeRectText(t)
- }, qS.prototype.onRemove = function(t) {
- this.removeRectText(t)
- }, qS.prototype.onAdd = function(t) {
- this.appendRectText(t)
- }
- }
- o_.prototype = {
- constructor: o_,
- getType: function() {
- return "vml"
- },
- getViewportRoot: function() {
- return this._vmlViewport
- },
- getViewportRootOffset: function() {
- var t = this.getViewportRoot();
- if (t) return {
- offsetLeft: t.offsetLeft || 0,
- offsetTop: t.offsetTop || 0
- }
- },
- refresh: function() {
- var t = this.storage.getDisplayList(!0, !0);
- this._paintList(t)
- },
- _paintList: function(t) {
- for (var e = this._vmlRoot, i = 0; i < t.length; i++) {
- var n = t[i];
- n.invisible || n.ignore ? (n.__alreadyNotVisible || n.onRemove(e), n.__alreadyNotVisible = !0) : (n.__alreadyNotVisible &&
- n.onAdd(e), n.__alreadyNotVisible = !1, n.__dirty && (n.beforeBrush && n.beforeBrush(), (n.brushVML || n.brush)
- .call(n, e), n.afterBrush && n.afterBrush())), n.__dirty = !1
- }
- this._firstPaint && (this._vmlViewport.appendChild(e), this._firstPaint = !1)
- },
- resize: function(t, e) {
- var t = null == t ? this._getWidth() : t,
- e = null == e ? this._getHeight() : e;
- if (this._width != t || this._height != e) {
- this._width = t, this._height = e;
- var i = this._vmlViewport.style;
- i.width = t + "px", i.height = e + "px"
- }
- },
- dispose: function() {
- this.root.innerHTML = "", this._vmlRoot = this._vmlViewport = this.storage = null
- },
- getWidth: function() {
- return this._width
- },
- getHeight: function() {
- return this._height
- },
- clear: function() {
- this._vmlViewport && this.root.removeChild(this._vmlViewport)
- },
- _getWidth: function() {
- var t = this.root,
- e = t.currentStyle;
- return (t.clientWidth || n_(e.width)) - n_(e.paddingLeft) - n_(e.paddingRight) | 0
- },
- _getHeight: function() {
- var t = this.root,
- e = t.currentStyle;
- return (t.clientHeight || n_(e.height)) - n_(e.paddingTop) - n_(e.paddingBottom) | 0
- }
- }, d(["getLayer", "insertLayer", "eachLayer", "eachBuiltinLayer", "eachOtherLayer", "getLayers", "modLayer",
- "delLayer", "clearLayer", "toDataURL", "pathToImage"
- ], function(t) {
- o_.prototype[t] = a_(t)
- }), Ti("vml", o_);
- var HE = "http://www.w3.org/2000/svg",
- ZE = MS.CMD,
- UE = Array.prototype.join,
- XE = "none",
- jE = Math.round,
- YE = Math.sin,
- qE = Math.cos,
- KE = Math.PI,
- $E = 2 * Math.PI,
- JE = 180 / KE,
- QE = 1e-4,
- tR = {};
- tR.brush = function(t) {
- var e = t.style,
- i = t.__svgEl;
- i || (i = r_("path"), t.__svgEl = i), t.path || t.createPathProxy();
- var n = t.path;
- if (t.__dirtyPath) {
- n.beginPath(), t.buildPath(n, t.shape), t.__dirtyPath = !1;
- var o = g_(n);
- o.indexOf("NaN") < 0 && d_(i, "d", o)
- }
- p_(i, e, !1, t), c_(i, t.transform), null != e.text && oR(t, t.getBoundingRect())
- };
- var eR = {};
- eR.brush = function(t) {
- var e = t.style,
- i = e.image;
- if (i instanceof HTMLImageElement && (i = i.src), i) {
- var n = e.x || 0,
- o = e.y || 0,
- a = e.width,
- r = e.height,
- s = t.__svgEl;
- s || (s = r_("image"), t.__svgEl = s), i !== t.__imageSrc && (f_(s, "href", i), t.__imageSrc = i), d_(s, "width",
- a), d_(s, "height", r), d_(s, "x", n), d_(s, "y", o), c_(s, t.transform), null != e.text && oR(t, t.getBoundingRect())
- }
- };
- var iR = {},
- nR = new ue,
- oR = function(t, e, i) {
- var n = t.style;
- t.__dirty && Ue(n);
- var o = n.text;
- if (null != o) {
- o += "";
- var a = t.__textSvgEl;
- a || (a = r_("text"), t.__textSvgEl = a);
- var r, s, l = n.textPosition,
- u = n.textDistance,
- h = n.textAlign || "left";
- "number" == typeof n.fontSize && (n.fontSize += "px");
- var c = n.font || [n.fontStyle || "", n.fontWeight || "", n.fontSize || "", n.fontFamily || ""].join(" ") || ub,
- d = m_(n.textVerticalAlign),
- f = (i = De(o, c, h, d)).lineHeight;
- if (l instanceof Array) r = e.x + l[0], s = e.y + l[1];
- else {
- var p = Ne(l, e, u);
- r = p.x, s = p.y, d = m_(p.textVerticalAlign), h = p.textAlign
- }
- d_(a, "alignment-baseline", d), c && (a.style.font = c);
- var g = n.textPadding;
- if (d_(a, "x", r), d_(a, "y", s), p_(a, n, !0, t), t instanceof qS || t.style.transformText) c_(a, t.transform);
- else {
- if (t.transform) nR.copy(e), nR.applyTransform(t.transform), e = nR;
- else {
- var m = t.transformCoordToGlobal(e.x, e.y);
- e.x = m[0], e.y = m[1], t.transform = vt(mt())
- }
- var v = n.textOrigin;
- "center" === v ? (r = i.width / 2 + r, s = i.height / 2 + s) : v && (r = v[0] + r, s = v[1] + s);
- var y = -n.textRotation || 0,
- x = mt();
- wt(x, x, y), _t(x, x, m = [t.transform[4], t.transform[5]]), c_(a, x)
- }
- var _ = o.split("\n"),
- w = _.length,
- b = h;
- "left" === b ? (b = "start", g && (r += g[3])) : "right" === b ? (b = "end", g && (r -= g[1])) : "center" === b &&
- (b = "middle", g && (r += (g[3] - g[1]) / 2));
- var S = 0;
- if ("after-edge" === d ? (S = -i.height + f, g && (S -= g[2])) : "middle" === d ? (S = (-i.height + f) / 2, g && (
- s += (g[0] - g[2]) / 2)) : g && (S += g[0]), t.__text !== o || t.__textFont !== c) {
- var M = t.__tspanList || [];
- t.__tspanList = M;
- for (T = 0; T < w; T++)(A = M[T]) ? A.innerHTML = "" : (A = M[T] = r_("tspan"), a.appendChild(A), d_(A,
- "alignment-baseline", d), d_(A, "text-anchor", b)), d_(A, "x", r), d_(A, "y", s + T * f + S), A.appendChild(
- document.createTextNode(_[T]));
- for (; T < M.length; T++) a.removeChild(M[T]);
- M.length = w, t.__text = o, t.__textFont = c
- } else if (t.__tspanList.length)
- for (var I = t.__tspanList.length, T = 0; T < I; ++T) {
- var A = t.__tspanList[T];
- A && (d_(A, "x", r), d_(A, "y", s + T * f + S))
- }
- }
- };
- iR.drawRectText = oR, iR.brush = function(t) {
- var e = t.style;
- null != e.text && (e.textPosition = [0, 0], oR(t, {
- x: e.x || 0,
- y: e.y || 0,
- width: 0,
- height: 0
- }, t.getBoundingRect()))
- }, v_.prototype = {
- diff: function(t, e, i) {
- i || (i = function(t, e) {
- return t === e
- }), this.equals = i;
- var n = this;
- t = t.slice();
- var o = (e = e.slice()).length,
- a = t.length,
- r = 1,
- s = o + a,
- l = [{
- newPos: -1,
- components: []
- }],
- u = this.extractCommon(l[0], e, t, 0);
- if (l[0].newPos + 1 >= o && u + 1 >= a) {
- for (var h = [], c = 0; c < e.length; c++) h.push(c);
- return [{
- indices: h,
- count: e.length
- }]
- }
- for (; r <= s;) {
- var d = function() {
- for (var i = -1 * r; i <= r; i += 2) {
- var s, u = l[i - 1],
- h = l[i + 1],
- c = (h ? h.newPos : 0) - i;
- u && (l[i - 1] = void 0);
- var d = u && u.newPos + 1 < o,
- f = h && 0 <= c && c < a;
- if (d || f) {
- if (!d || f && u.newPos < h.newPos ? (s = x_(h), n.pushComponent(s.components, void 0, !0)) : ((s = u).newPos++,
- n.pushComponent(s.components, !0, void 0)), c = n.extractCommon(s, e, t, i), s.newPos + 1 >= o && c + 1 >=
- a) return y_(0, s.components);
- l[i] = s
- } else l[i] = void 0
- }
- r++
- }();
- if (d) return d
- }
- },
- pushComponent: function(t, e, i) {
- var n = t[t.length - 1];
- n && n.added === e && n.removed === i ? t[t.length - 1] = {
- count: n.count + 1,
- added: e,
- removed: i
- } : t.push({
- count: 1,
- added: e,
- removed: i
- })
- },
- extractCommon: function(t, e, i, n) {
- for (var o = e.length, a = i.length, r = t.newPos, s = r - n, l = 0; r + 1 < o && s + 1 < a && this.equals(e[r +
- 1], i[s + 1]);) r++, s++, l++;
- return l && t.components.push({
- count: l
- }), t.newPos = r, s
- },
- tokenize: function(t) {
- return t.slice()
- },
- join: function(t) {
- return t.slice()
- }
- };
- var aR = new v_,
- rR = function(t, e, i) {
- return aR.diff(t, e, i)
- };
- __.prototype.createElement = r_, __.prototype.getDefs = function(t) {
- var e = this._svgRoot,
- i = this._svgRoot.getElementsByTagName("defs");
- return 0 === i.length ? t ? ((i = e.insertBefore(this.createElement("defs"), e.firstChild)).contains || (i.contains =
- function(t) {
- var e = i.children;
- if (!e) return !1;
- for (var n = e.length - 1; n >= 0; --n)
- if (e[n] === t) return !0;
- return !1
- }), i) : null : i[0]
- }, __.prototype.update = function(t, e) {
- if (t) {
- var i = this.getDefs(!1);
- if (t[this._domName] && i.contains(t[this._domName])) "function" == typeof e && e(t);
- else {
- var n = this.add(t);
- n && (t[this._domName] = n)
- }
- }
- }, __.prototype.addDom = function(t) {
- this.getDefs(!0).appendChild(t)
- }, __.prototype.removeDom = function(t) {
- var e = this.getDefs(!1);
- e && t[this._domName] && (e.removeChild(t[this._domName]), t[this._domName] = null)
- }, __.prototype.getDoms = function() {
- var t = this.getDefs(!1);
- if (!t) return [];
- var e = [];
- return d(this._tagNames, function(i) {
- var n = t.getElementsByTagName(i);
- e = e.concat([].slice.call(n))
- }), e
- }, __.prototype.markAllUnused = function() {
- var t = this;
- d(this.getDoms(), function(e) {
- e[t._markLabel] = "0"
- })
- }, __.prototype.markUsed = function(t) {
- t && (t[this._markLabel] = "1")
- }, __.prototype.removeUnused = function() {
- var t = this.getDefs(!1);
- if (t) {
- var e = this;
- d(this.getDoms(), function(i) {
- "1" !== i[e._markLabel] && t.removeChild(i)
- })
- }
- }, __.prototype.getSvgProxy = function(t) {
- return t instanceof kn ? tR : t instanceof hi ? eR : t instanceof qS ? iR : tR
- }, __.prototype.getTextSvgElement = function(t) {
- return t.__textSvgEl
- }, __.prototype.getSvgElement = function(t) {
- return t.__svgEl
- }, u(w_, __), w_.prototype.addWithoutUpdate = function(t, e) {
- if (e && e.style) {
- var i = this;
- d(["fill", "stroke"], function(n) {
- if (e.style[n] && ("linear" === e.style[n].type || "radial" === e.style[n].type)) {
- var o, a = e.style[n],
- r = i.getDefs(!0);
- a._dom ? (o = a._dom, r.contains(a._dom) || i.addDom(o)) : o = i.add(a), i.markUsed(e);
- var s = o.getAttribute("id");
- t.setAttribute(n, "url(#" + s + ")")
- }
- })
- }
- }, w_.prototype.add = function(t) {
- var e;
- if ("linear" === t.type) e = this.createElement("linearGradient");
- else {
- if ("radial" !== t.type) return Bw("Illegal gradient type."), null;
- e = this.createElement("radialGradient")
- }
- return t.id = t.id || this.nextId++, e.setAttribute("id", "zr" + this._zrId + "-gradient-" + t.id), this.updateDom(
- t, e), this.addDom(e), e
- }, w_.prototype.update = function(t) {
- var e = this;
- __.prototype.update.call(this, t, function() {
- var i = t.type,
- n = t._dom.tagName;
- "linear" === i && "linearGradient" === n || "radial" === i && "radialGradient" === n ? e.updateDom(t, t._dom) :
- (e.removeDom(t), e.add(t))
- })
- }, w_.prototype.updateDom = function(t, e) {
- if ("linear" === t.type) e.setAttribute("x1", t.x), e.setAttribute("y1", t.y), e.setAttribute("x2", t.x2), e.setAttribute(
- "y2", t.y2);
- else {
- if ("radial" !== t.type) return void Bw("Illegal gradient type.");
- e.setAttribute("cx", t.x), e.setAttribute("cy", t.y), e.setAttribute("r", t.r)
- }
- t.global ? e.setAttribute("gradientUnits", "userSpaceOnUse") : e.setAttribute("gradientUnits", "objectBoundingBox"),
- e.innerHTML = "";
- for (var i = t.colorStops, n = 0, o = i.length; n < o; ++n) {
- var a = this.createElement("stop");
- a.setAttribute("offset", 100 * i[n].offset + "%"), a.setAttribute("stop-color", i[n].color), e.appendChild(a)
- }
- t._dom = e
- }, w_.prototype.markUsed = function(t) {
- if (t.style) {
- var e = t.style.fill;
- e && e._dom && __.prototype.markUsed.call(this, e._dom), (e = t.style.stroke) && e._dom && __.prototype.markUsed.call(
- this, e._dom)
- }
- }, u(b_, __), b_.prototype.update = function(t) {
- var e = this.getSvgElement(t);
- e && this.updateDom(e, t.__clipPaths, !1);
- var i = this.getTextSvgElement(t);
- i && this.updateDom(i, t.__clipPaths, !0), this.markUsed(t)
- }, b_.prototype.updateDom = function(t, e, i) {
- if (e && e.length > 0) {
- var n, o, a = this.getDefs(!0),
- r = e[0],
- s = i ? "_textDom" : "_dom";
- r[s] ? (o = r[s].getAttribute("id"), n = r[s], a.contains(n) || a.appendChild(n)) : (o = "zr" + this._zrId +
- "-clip-" + this.nextId, ++this.nextId, (n = this.createElement("clipPath")).setAttribute("id", o), a.appendChild(
- n), r[s] = n);
- var l = this.getSvgProxy(r);
- if (r.transform && r.parent.invTransform && !i) {
- var u = Array.prototype.slice.call(r.transform);
- xt(r.transform, r.parent.invTransform, r.transform), l.brush(r), r.transform = u
- } else l.brush(r);
- var h = this.getSvgElement(r);
- n.innerHTML = "", n.appendChild(h.cloneNode()), t.setAttribute("clip-path", "url(#" + o + ")"), e.length > 1 &&
- this.updateDom(n, e.slice(1), i)
- } else t && t.setAttribute("clip-path", "none")
- }, b_.prototype.markUsed = function(t) {
- var e = this;
- t.__clipPaths && t.__clipPaths.length > 0 && d(t.__clipPaths, function(t) {
- t._dom && __.prototype.markUsed.call(e, t._dom), t._textDom && __.prototype.markUsed.call(e, t._textDom)
- })
- }, u(S_, __), S_.prototype.addWithoutUpdate = function(t, e) {
- if (e && M_(e.style)) {
- var i, n = e.style;
- n._shadowDom ? (i = n._shadowDom, this.getDefs(!0).contains(n._shadowDom) || this.addDom(i)) : i = this.add(e),
- this.markUsed(e);
- var o = i.getAttribute("id");
- t.style.filter = "url(#" + o + ")"
- }
- }, S_.prototype.add = function(t) {
- var e = this.createElement("filter"),
- i = t.style;
- return i._shadowDomId = i._shadowDomId || this.nextId++, e.setAttribute("id", "zr" + this._zrId + "-shadow-" + i._shadowDomId),
- this.updateDom(t, e), this.addDom(e), e
- }, S_.prototype.update = function(t, e) {
- var i = e.style;
- if (M_(i)) {
- var n = this;
- __.prototype.update.call(this, e, function(t) {
- n.updateDom(e, t._shadowDom)
- })
- } else this.remove(t, i)
- }, S_.prototype.remove = function(t, e) {
- null != e._shadowDomId && (this.removeDom(e), t.style.filter = "")
- }, S_.prototype.updateDom = function(t, e) {
- var i = e.getElementsByTagName("feDropShadow");
- i = 0 === i.length ? this.createElement("feDropShadow") : i[0];
- var n, o, a, r, s = t.style,
- l = t.scale ? t.scale[0] || 1 : 1,
- u = t.scale ? t.scale[1] || 1 : 1;
- if (s.shadowBlur || s.shadowOffsetX || s.shadowOffsetY) n = s.shadowOffsetX || 0, o = s.shadowOffsetY || 0, a = s.shadowBlur,
- r = s.shadowColor;
- else {
- if (!s.textShadowBlur) return void this.removeDom(e, s);
- n = s.textShadowOffsetX || 0, o = s.textShadowOffsetY || 0, a = s.textShadowBlur, r = s.textShadowColor
- }
- i.setAttribute("dx", n / l), i.setAttribute("dy", o / u), i.setAttribute("flood-color", r);
- var h = a / 2 / l + " " + a / 2 / u;
- i.setAttribute("stdDeviation", h), e.setAttribute("x", "-100%"), e.setAttribute("y", "-100%"), e.setAttribute(
- "width", Math.ceil(a / 2 * 200) + "%"), e.setAttribute("height", Math.ceil(a / 2 * 200) + "%"), e.appendChild(i),
- s._shadowDom = e
- }, S_.prototype.markUsed = function(t) {
- var e = t.style;
- e && e._shadowDom && __.prototype.markUsed.call(this, e._shadowDom)
- };
- var sR = function(t, e, i, n) {
- this.root = t, this.storage = e, this._opts = i = a({}, i || {});
- var o = r_("svg");
- o.setAttribute("xmlns", "http://www.w3.org/2000/svg"), o.setAttribute("version", "1.1"), o.setAttribute(
- "baseProfile", "full"), o.style.cssText = "user-select:none;position:absolute;left:0;top:0;", this.gradientManager =
- new w_(n, o), this.clipPathManager = new b_(n, o), this.shadowManager = new S_(n, o);
- var r = document.createElement("div");
- r.style.cssText = "overflow:hidden;position:relative", this._svgRoot = o, this._viewport = r, t.appendChild(r), r.appendChild(
- o), this.resize(i.width, i.height), this._visibleList = []
- };
- sR.prototype = {
- constructor: sR,
- getType: function() {
- return "svg"
- },
- getViewportRoot: function() {
- return this._viewport
- },
- getViewportRootOffset: function() {
- var t = this.getViewportRoot();
- if (t) return {
- offsetLeft: t.offsetLeft || 0,
- offsetTop: t.offsetTop || 0
- }
- },
- refresh: function() {
- var t = this.storage.getDisplayList(!0);
- this._paintList(t)
- },
- setBackgroundColor: function(t) {
- this._viewport.style.background = t
- },
- _paintList: function(t) {
- this.gradientManager.markAllUnused(), this.clipPathManager.markAllUnused(), this.shadowManager.markAllUnused();
- var e, i = this._svgRoot,
- n = this._visibleList,
- o = t.length,
- a = [];
- for (e = 0; e < o; e++) {
- var r = T_(f = t[e]),
- s = P_(f) || k_(f);
- f.invisible || (f.__dirty && (r && r.brush(f), this.clipPathManager.update(f), f.style && (this.gradientManager.update(
- f.style.fill), this.gradientManager.update(f.style.stroke), this.shadowManager.update(s, f)), f.__dirty = !1),
- a.push(f))
- }
- var l, u = rR(n, a);
- for (e = 0; e < u.length; e++)
- if ((c = u[e]).removed)
- for (d = 0; d < c.count; d++) {
- var s = P_(f = n[c.indices[d]]),
- h = k_(f);
- L_(i, s), L_(i, h)
- }
- for (e = 0; e < u.length; e++) {
- var c = u[e];
- if (c.added)
- for (d = 0; d < c.count; d++) {
- var s = P_(f = a[c.indices[d]]),
- h = k_(f);
- l ? D_(i, s, l) : C_(i, s), s ? D_(i, h, s) : l ? D_(i, h, l) : C_(i, h), D_(i, h, s), l = h || s || l, this.gradientManager
- .addWithoutUpdate(s, f), this.shadowManager.addWithoutUpdate(l, f), this.clipPathManager.markUsed(f)
- } else if (!c.removed)
- for (var d = 0; d < c.count; d++) {
- var f = a[c.indices[d]];
- l = s = k_(f) || P_(f) || l, this.gradientManager.markUsed(f), this.gradientManager.addWithoutUpdate(s, f),
- this.shadowManager.markUsed(f), this.shadowManager.addWithoutUpdate(s, f), this.clipPathManager.markUsed(f)
- }
- }
- this.gradientManager.removeUnused(), this.clipPathManager.removeUnused(), this.shadowManager.removeUnused(), this
- ._visibleList = a
- },
- _getDefs: function(t) {
- var e = this._svgRoot,
- i = this._svgRoot.getElementsByTagName("defs");
- return 0 === i.length ? t ? ((i = e.insertBefore(r_("defs"), e.firstChild)).contains || (i.contains = function(t) {
- var e = i.children;
- if (!e) return !1;
- for (var n = e.length - 1; n >= 0; --n)
- if (e[n] === t) return !0;
- return !1
- }), i) : null : i[0]
- },
- resize: function(t, e) {
- var i = this._viewport;
- i.style.display = "none";
- var n = this._opts;
- if (null != t && (n.width = t), null != e && (n.height = e), t = this._getSize(0), e = this._getSize(1), i.style.display =
- "", this._width !== t || this._height !== e) {
- this._width = t, this._height = e;
- var o = i.style;
- o.width = t + "px", o.height = e + "px";
- var a = this._svgRoot;
- a.setAttribute("width", t), a.setAttribute("height", e)
- }
- },
- getWidth: function() {
- return this._width
- },
- getHeight: function() {
- return this._height
- },
- _getSize: function(t) {
- var e = this._opts,
- i = ["width", "height"][t],
- n = ["clientWidth", "clientHeight"][t],
- o = ["paddingLeft", "paddingTop"][t],
- a = ["paddingRight", "paddingBottom"][t];
- if (null != e[i] && "auto" !== e[i]) return parseFloat(e[i]);
- var r = this.root,
- s = document.defaultView.getComputedStyle(r);
- return (r[n] || I_(s[i]) || I_(r.style[i])) - (I_(s[o]) || 0) - (I_(s[a]) || 0) | 0
- },
- dispose: function() {
- this.root.innerHTML = "", this._svgRoot = this._viewport = this.storage = null
- },
- clear: function() {
- this._viewport && this.root.removeChild(this._viewport)
- },
- pathToDataUrl: function() {
- return this.refresh(), "data:image/svg+xml;charset=UTF-8," + this._svgRoot.outerHTML
- }
- }, d(["getLayer", "insertLayer", "eachLayer", "eachBuiltinLayer", "eachOtherLayer", "getLayers", "modLayer",
- "delLayer", "clearLayer", "toDataURL", "pathToImage"
- ], function(t) {
- sR.prototype[t] = N_(t)
- }), Ti("svg", sR), t.version = "4.2.0", t.dependencies = wT, t.PRIORITY = IT, t.init = function(t, e, i) {
- var n = Ds(t);
- if (n) return n;
- var o = new rs(t, e, i);
- return o.id = "ec_" + WT++, GT[o.id] = o, Fi(t, ZT, o.id), Ts(o), o
- }, t.connect = function(t) {
- if (y(t)) {
- var e = t;
- t = null, vT(e, function(e) {
- null != e.group && (t = e.group)
- }), t = t || "g_" + HT++, vT(e, function(e) {
- e.group = t
- })
- }
- return FT[t] = !0, t
- }, t.disConnect = As, t.disconnect = UT, t.dispose = function(t) {
- "string" == typeof t ? t = GT[t] : t instanceof rs || (t = Ds(t)), t instanceof rs && !t.isDisposed() && t.dispose()
- }, t.getInstanceByDom = Ds, t.getInstanceById = function(t) {
- return GT[t]
- }, t.registerTheme = Cs, t.registerPreprocessor = Ls, t.registerProcessor = ks, t.registerPostUpdate = function(t) {
- RT.push(t)
- }, t.registerAction = Ps, t.registerCoordinateSystem = Ns, t.getCoordinateSystemDimensions = function(t) {
- var e = Ba.get(t);
- if (e) return e.getDimensionsInfo ? e.getDimensionsInfo() : e.dimensions.slice()
- }, t.registerLayout = Os, t.registerVisual = Es, t.registerLoading = zs, t.extendComponentModel = Bs, t.extendComponentView =
- Vs, t.extendSeriesModel = Gs, t.extendChartView = Fs, t.setCanvasCreator = function(t) {
- e("createCanvas", t)
- }, t.registerMap = function(t, e, i) {
- pT.registerMap(t, e, i)
- }, t.getMap = function(t) {
- var e = pT.retrieveMap(t);
- return e && e[0] && {
- geoJson: e[0].geoJSON,
- specialAreas: e[0].specialAreas
- }
- }, t.dataTool = XT, t.zrender = Pb, t.number = NM, t.format = FM, t.throttle = Cr, t.helper = BA, t.matrix = fw, t.vector =
- nw, t.color = Pw, t.parseGeoJSON = GA, t.parseGeoJson = ZA, t.util = UA, t.graphic = XA, t.List = eA, t.Model = Lo,
- t.Axis = HA, t.env = z_
- });
|