wangEditor.js 715 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516125171251812519125201252112522125231252412525125261252712528125291253012531125321253312534125351253612537125381253912540125411254212543125441254512546125471254812549125501255112552125531255412555125561255712558125591256012561125621256312564125651256612567125681256912570125711257212573125741257512576125771257812579125801258112582125831258412585125861258712588125891259012591125921259312594125951259612597125981259912600126011260212603126041260512606126071260812609126101261112612126131261412615126161261712618126191262012621126221262312624126251262612627126281262912630126311263212633126341263512636126371263812639126401264112642126431264412645126461264712648126491265012651126521265312654126551265612657126581265912660126611266212663126641266512666126671266812669126701267112672126731267412675126761267712678126791268012681126821268312684126851268612687126881268912690126911269212693126941269512696126971269812699127001270112702127031270412705127061270712708127091271012711127121271312714127151271612717127181271912720127211272212723127241272512726127271272812729127301273112732127331273412735127361273712738127391274012741127421274312744127451274612747127481274912750127511275212753127541275512756127571275812759127601276112762127631276412765127661276712768127691277012771127721277312774127751277612777127781277912780127811278212783127841278512786127871278812789127901279112792127931279412795127961279712798127991280012801128021280312804128051280612807128081280912810128111281212813128141281512816128171281812819128201282112822128231282412825128261282712828128291283012831128321283312834128351283612837128381283912840128411284212843128441284512846128471284812849128501285112852128531285412855128561285712858128591286012861128621286312864128651286612867128681286912870128711287212873128741287512876128771287812879128801288112882128831288412885128861288712888128891289012891128921289312894128951289612897128981289912900129011290212903129041290512906129071290812909129101291112912129131291412915129161291712918129191292012921129221292312924129251292612927129281292912930129311293212933129341293512936129371293812939129401294112942129431294412945129461294712948129491295012951129521295312954129551295612957129581295912960129611296212963129641296512966129671296812969129701297112972129731297412975129761297712978129791298012981129821298312984129851298612987129881298912990129911299212993129941299512996129971299812999130001300113002130031300413005130061300713008130091301013011130121301313014130151301613017130181301913020130211302213023130241302513026130271302813029130301303113032130331303413035130361303713038130391304013041130421304313044130451304613047130481304913050130511305213053130541305513056130571305813059130601306113062130631306413065130661306713068130691307013071130721307313074130751307613077130781307913080130811308213083130841308513086130871308813089130901309113092130931309413095130961309713098130991310013101131021310313104131051310613107131081310913110131111311213113131141311513116131171311813119131201312113122131231312413125131261312713128131291313013131131321313313134131351313613137131381313913140131411314213143131441314513146131471314813149131501315113152131531315413155131561315713158131591316013161131621316313164131651316613167131681316913170131711317213173131741317513176131771317813179131801318113182131831318413185131861318713188131891319013191131921319313194131951319613197131981319913200132011320213203132041320513206132071320813209132101321113212132131321413215132161321713218132191322013221132221322313224132251322613227132281322913230132311323213233132341323513236132371323813239132401324113242132431324413245132461324713248132491325013251132521325313254132551325613257132581325913260132611326213263132641326513266132671326813269132701327113272132731327413275132761327713278132791328013281132821328313284132851328613287132881328913290132911329213293132941329513296132971329813299133001330113302133031330413305133061330713308133091331013311133121331313314133151331613317133181331913320133211332213323133241332513326133271332813329133301333113332133331333413335133361333713338133391334013341133421334313344133451334613347133481334913350133511335213353133541335513356133571335813359133601336113362133631336413365133661336713368133691337013371133721337313374133751337613377133781337913380133811338213383133841338513386133871338813389133901339113392133931339413395133961339713398133991340013401134021340313404134051340613407134081340913410134111341213413134141341513416134171341813419134201342113422134231342413425134261342713428134291343013431134321343313434134351343613437134381343913440134411344213443134441344513446134471344813449134501345113452134531345413455134561345713458134591346013461134621346313464134651346613467134681346913470134711347213473134741347513476134771347813479134801348113482134831348413485134861348713488134891349013491134921349313494134951349613497134981349913500135011350213503135041350513506135071350813509135101351113512135131351413515135161351713518135191352013521135221352313524135251352613527135281352913530135311353213533135341353513536135371353813539135401354113542135431354413545135461354713548135491355013551135521355313554135551355613557135581355913560135611356213563135641356513566135671356813569135701357113572135731357413575135761357713578135791358013581135821358313584135851358613587135881358913590135911359213593135941359513596135971359813599136001360113602136031360413605136061360713608136091361013611136121361313614136151361613617136181361913620136211362213623136241362513626136271362813629136301363113632136331363413635136361363713638136391364013641136421364313644136451364613647136481364913650136511365213653136541365513656136571365813659136601366113662136631366413665136661366713668136691367013671136721367313674136751367613677136781367913680136811368213683136841368513686136871368813689136901369113692136931369413695136961369713698136991370013701137021370313704137051370613707137081370913710137111371213713137141371513716137171371813719137201372113722137231372413725137261372713728137291373013731137321373313734137351373613737137381373913740137411374213743137441374513746137471374813749137501375113752137531375413755137561375713758137591376013761137621376313764137651376613767137681376913770137711377213773137741377513776137771377813779137801378113782137831378413785137861378713788137891379013791137921379313794137951379613797137981379913800138011380213803138041380513806138071380813809138101381113812138131381413815138161381713818138191382013821138221382313824138251382613827138281382913830138311383213833138341383513836138371383813839138401384113842138431384413845138461384713848138491385013851138521385313854138551385613857138581385913860138611386213863138641386513866138671386813869138701387113872138731387413875138761387713878138791388013881138821388313884138851388613887138881388913890138911389213893138941389513896138971389813899139001390113902139031390413905139061390713908139091391013911139121391313914139151391613917139181391913920139211392213923139241392513926139271392813929139301393113932139331393413935139361393713938139391394013941139421394313944139451394613947139481394913950139511395213953139541395513956139571395813959139601396113962139631396413965139661396713968139691397013971139721397313974139751397613977139781397913980139811398213983139841398513986139871398813989139901399113992139931399413995139961399713998139991400014001140021400314004140051400614007140081400914010140111401214013140141401514016140171401814019140201402114022140231402414025140261402714028140291403014031140321403314034140351403614037140381403914040140411404214043140441404514046140471404814049140501405114052140531405414055140561405714058140591406014061140621406314064140651406614067140681406914070140711407214073140741407514076140771407814079140801408114082140831408414085140861408714088140891409014091140921409314094140951409614097140981409914100141011410214103141041410514106141071410814109141101411114112141131411414115141161411714118141191412014121141221412314124141251412614127141281412914130141311413214133141341413514136141371413814139141401414114142141431414414145141461414714148141491415014151141521415314154141551415614157141581415914160141611416214163141641416514166141671416814169141701417114172141731417414175141761417714178141791418014181141821418314184141851418614187141881418914190141911419214193141941419514196141971419814199142001420114202142031420414205142061420714208142091421014211142121421314214142151421614217142181421914220142211422214223142241422514226142271422814229142301423114232142331423414235142361423714238142391424014241142421424314244142451424614247142481424914250142511425214253142541425514256142571425814259142601426114262142631426414265142661426714268142691427014271142721427314274142751427614277142781427914280142811428214283142841428514286142871428814289142901429114292142931429414295142961429714298142991430014301143021430314304143051430614307143081430914310143111431214313143141431514316143171431814319143201432114322143231432414325143261432714328143291433014331143321433314334143351433614337143381433914340143411434214343143441434514346143471434814349143501435114352143531435414355143561435714358143591436014361143621436314364143651436614367143681436914370143711437214373143741437514376143771437814379143801438114382143831438414385143861438714388143891439014391143921439314394143951439614397143981439914400144011440214403144041440514406144071440814409144101441114412144131441414415144161441714418144191442014421144221442314424144251442614427144281442914430144311443214433144341443514436144371443814439144401444114442144431444414445144461444714448144491445014451144521445314454144551445614457144581445914460144611446214463144641446514466144671446814469144701447114472144731447414475144761447714478144791448014481144821448314484144851448614487144881448914490144911449214493144941449514496144971449814499145001450114502145031450414505145061450714508145091451014511145121451314514145151451614517145181451914520145211452214523145241452514526145271452814529145301453114532145331453414535145361453714538145391454014541145421454314544145451454614547145481454914550145511455214553145541455514556145571455814559145601456114562145631456414565145661456714568145691457014571145721457314574145751457614577145781457914580145811458214583145841458514586145871458814589145901459114592145931459414595145961459714598145991460014601146021460314604146051460614607146081460914610146111461214613146141461514616146171461814619146201462114622146231462414625146261462714628146291463014631146321463314634146351463614637146381463914640146411464214643146441464514646146471464814649146501465114652146531465414655146561465714658146591466014661146621466314664146651466614667146681466914670146711467214673146741467514676146771467814679146801468114682146831468414685146861468714688146891469014691146921469314694146951469614697146981469914700147011470214703147041470514706147071470814709147101471114712147131471414715147161471714718147191472014721147221472314724147251472614727147281472914730147311473214733147341473514736147371473814739147401474114742147431474414745147461474714748147491475014751147521475314754147551475614757147581475914760147611476214763147641476514766147671476814769147701477114772147731477414775147761477714778147791478014781147821478314784147851478614787147881478914790147911479214793147941479514796147971479814799148001480114802148031480414805148061480714808148091481014811148121481314814148151481614817148181481914820148211482214823148241482514826148271482814829148301483114832148331483414835148361483714838148391484014841148421484314844148451484614847148481484914850148511485214853148541485514856148571485814859148601486114862148631486414865148661486714868148691487014871148721487314874148751487614877148781487914880148811488214883148841488514886148871488814889148901489114892148931489414895148961489714898148991490014901149021490314904149051490614907149081490914910149111491214913149141491514916149171491814919149201492114922149231492414925149261492714928149291493014931149321493314934149351493614937149381493914940149411494214943149441494514946149471494814949149501495114952149531495414955149561495714958149591496014961149621496314964149651496614967149681496914970149711497214973149741497514976149771497814979149801498114982149831498414985149861498714988149891499014991149921499314994149951499614997149981499915000150011500215003150041500515006150071500815009150101501115012150131501415015150161501715018150191502015021150221502315024150251502615027150281502915030150311503215033150341503515036150371503815039150401504115042150431504415045150461504715048150491505015051150521505315054150551505615057150581505915060150611506215063150641506515066150671506815069150701507115072150731507415075150761507715078150791508015081150821508315084150851508615087150881508915090150911509215093150941509515096150971509815099151001510115102151031510415105151061510715108151091511015111151121511315114151151511615117151181511915120151211512215123151241512515126151271512815129151301513115132151331513415135151361513715138151391514015141151421514315144151451514615147151481514915150151511515215153151541515515156151571515815159151601516115162151631516415165151661516715168151691517015171151721517315174151751517615177151781517915180151811518215183151841518515186151871518815189151901519115192151931519415195151961519715198151991520015201152021520315204152051520615207152081520915210152111521215213152141521515216152171521815219152201522115222152231522415225152261522715228152291523015231152321523315234152351523615237152381523915240152411524215243152441524515246152471524815249152501525115252152531525415255152561525715258152591526015261152621526315264152651526615267152681526915270152711527215273152741527515276152771527815279152801528115282152831528415285152861528715288152891529015291152921529315294152951529615297152981529915300153011530215303153041530515306153071530815309153101531115312153131531415315153161531715318153191532015321153221532315324153251532615327153281532915330153311533215333153341533515336153371533815339153401534115342153431534415345153461534715348153491535015351153521535315354153551535615357153581535915360153611536215363153641536515366153671536815369153701537115372153731537415375153761537715378153791538015381153821538315384153851538615387153881538915390153911539215393153941539515396153971539815399154001540115402154031540415405154061540715408154091541015411154121541315414154151541615417154181541915420154211542215423154241542515426154271542815429154301543115432154331543415435154361543715438154391544015441154421544315444154451544615447154481544915450154511545215453154541545515456154571545815459154601546115462154631546415465154661546715468154691547015471154721547315474154751547615477154781547915480154811548215483154841548515486154871548815489154901549115492154931549415495154961549715498154991550015501155021550315504155051550615507155081550915510155111551215513155141551515516155171551815519155201552115522155231552415525155261552715528155291553015531155321553315534155351553615537155381553915540155411554215543155441554515546155471554815549155501555115552155531555415555155561555715558155591556015561155621556315564155651556615567155681556915570155711557215573155741557515576155771557815579155801558115582155831558415585155861558715588155891559015591155921559315594155951559615597155981559915600156011560215603156041560515606156071560815609156101561115612156131561415615156161561715618156191562015621156221562315624156251562615627156281562915630156311563215633156341563515636156371563815639156401564115642156431564415645156461564715648156491565015651156521565315654156551565615657156581565915660156611566215663156641566515666156671566815669156701567115672156731567415675156761567715678156791568015681156821568315684156851568615687156881568915690156911569215693156941569515696156971569815699157001570115702157031570415705157061570715708157091571015711157121571315714157151571615717157181571915720157211572215723157241572515726157271572815729157301573115732157331573415735157361573715738157391574015741157421574315744157451574615747157481574915750157511575215753157541575515756157571575815759157601576115762157631576415765157661576715768157691577015771157721577315774157751577615777157781577915780157811578215783157841578515786157871578815789157901579115792157931579415795157961579715798157991580015801158021580315804158051580615807158081580915810158111581215813158141581515816158171581815819158201582115822158231582415825158261582715828158291583015831158321583315834158351583615837158381583915840158411584215843158441584515846158471584815849158501585115852158531585415855158561585715858158591586015861158621586315864158651586615867158681586915870158711587215873158741587515876158771587815879158801588115882158831588415885158861588715888158891589015891158921589315894158951589615897158981589915900159011590215903159041590515906159071590815909159101591115912159131591415915159161591715918159191592015921159221592315924159251592615927159281592915930159311593215933159341593515936159371593815939159401594115942159431594415945159461594715948159491595015951159521595315954159551595615957159581595915960159611596215963159641596515966159671596815969159701597115972159731597415975159761597715978159791598015981159821598315984159851598615987159881598915990159911599215993159941599515996159971599815999160001600116002160031600416005160061600716008160091601016011160121601316014160151601616017160181601916020160211602216023160241602516026160271602816029160301603116032160331603416035160361603716038160391604016041160421604316044160451604616047160481604916050160511605216053160541605516056160571605816059160601606116062160631606416065160661606716068160691607016071160721607316074160751607616077160781607916080160811608216083160841608516086160871608816089160901609116092160931609416095160961609716098160991610016101161021610316104161051610616107161081610916110161111611216113161141611516116161171611816119161201612116122161231612416125161261612716128161291613016131161321613316134161351613616137161381613916140161411614216143161441614516146161471614816149161501615116152161531615416155161561615716158161591616016161161621616316164161651616616167161681616916170161711617216173161741617516176161771617816179161801618116182161831618416185161861618716188161891619016191161921619316194161951619616197161981619916200162011620216203162041620516206162071620816209162101621116212162131621416215162161621716218162191622016221162221622316224162251622616227162281622916230162311623216233162341623516236162371623816239162401624116242162431624416245162461624716248162491625016251162521625316254162551625616257162581625916260162611626216263162641626516266162671626816269162701627116272162731627416275162761627716278162791628016281162821628316284162851628616287162881628916290162911629216293162941629516296162971629816299163001630116302163031630416305163061630716308163091631016311163121631316314163151631616317163181631916320163211632216323163241632516326163271632816329163301633116332163331633416335163361633716338163391634016341163421634316344163451634616347163481634916350163511635216353163541635516356163571635816359163601636116362163631636416365163661636716368163691637016371163721637316374163751637616377163781637916380163811638216383163841638516386163871638816389163901639116392163931639416395163961639716398163991640016401164021640316404164051640616407164081640916410164111641216413164141641516416164171641816419164201642116422164231642416425164261642716428164291643016431164321643316434164351643616437164381643916440164411644216443164441644516446164471644816449164501645116452164531645416455164561645716458164591646016461164621646316464164651646616467164681646916470164711647216473164741647516476164771647816479164801648116482164831648416485164861648716488164891649016491164921649316494164951649616497164981649916500165011650216503165041650516506165071650816509165101651116512165131651416515165161651716518165191652016521165221652316524165251652616527165281652916530165311653216533165341653516536165371653816539165401654116542165431654416545165461654716548165491655016551165521655316554165551655616557165581655916560165611656216563165641656516566165671656816569165701657116572165731657416575165761657716578165791658016581165821658316584165851658616587165881658916590165911659216593165941659516596165971659816599166001660116602166031660416605166061660716608166091661016611166121661316614166151661616617166181661916620166211662216623166241662516626166271662816629166301663116632166331663416635166361663716638166391664016641166421664316644166451664616647166481664916650166511665216653166541665516656166571665816659166601666116662166631666416665166661666716668166691667016671166721667316674166751667616677166781667916680166811668216683166841668516686166871668816689166901669116692166931669416695166961669716698166991670016701167021670316704167051670616707167081670916710167111671216713167141671516716167171671816719167201672116722167231672416725167261672716728167291673016731167321673316734167351673616737167381673916740167411674216743167441674516746167471674816749167501675116752167531675416755167561675716758167591676016761167621676316764167651676616767167681676916770167711677216773167741677516776167771677816779167801678116782167831678416785167861678716788167891679016791167921679316794167951679616797167981679916800168011680216803168041680516806168071680816809168101681116812168131681416815168161681716818168191682016821168221682316824168251682616827168281682916830168311683216833168341683516836168371683816839168401684116842168431684416845168461684716848168491685016851168521685316854168551685616857168581685916860168611686216863168641686516866168671686816869168701687116872168731687416875168761687716878168791688016881168821688316884168851688616887168881688916890168911689216893168941689516896168971689816899169001690116902169031690416905169061690716908169091691016911169121691316914169151691616917169181691916920169211692216923169241692516926169271692816929169301693116932169331693416935169361693716938169391694016941169421694316944169451694616947169481694916950169511695216953169541695516956169571695816959169601696116962169631696416965169661696716968169691697016971169721697316974169751697616977169781697916980169811698216983169841698516986169871698816989169901699116992169931699416995169961699716998169991700017001170021700317004170051700617007170081700917010170111701217013170141701517016170171701817019170201702117022170231702417025170261702717028170291703017031170321703317034170351703617037170381703917040170411704217043170441704517046170471704817049170501705117052170531705417055170561705717058170591706017061170621706317064170651706617067170681706917070170711707217073170741707517076170771707817079170801708117082170831708417085170861708717088170891709017091170921709317094170951709617097170981709917100171011710217103171041710517106171071710817109171101711117112171131711417115171161711717118171191712017121171221712317124171251712617127171281712917130171311713217133171341713517136171371713817139171401714117142171431714417145171461714717148171491715017151171521715317154171551715617157171581715917160171611716217163171641716517166171671716817169171701717117172171731717417175171761717717178171791718017181171821718317184171851718617187171881718917190171911719217193171941719517196171971719817199172001720117202172031720417205172061720717208172091721017211172121721317214172151721617217172181721917220172211722217223172241722517226172271722817229172301723117232172331723417235172361723717238172391724017241172421724317244172451724617247172481724917250172511725217253172541725517256172571725817259172601726117262172631726417265172661726717268172691727017271172721727317274172751727617277172781727917280172811728217283172841728517286172871728817289172901729117292172931729417295172961729717298172991730017301173021730317304173051730617307173081730917310173111731217313173141731517316173171731817319173201732117322173231732417325173261732717328173291733017331173321733317334173351733617337173381733917340173411734217343173441734517346173471734817349173501735117352173531735417355173561735717358173591736017361173621736317364173651736617367173681736917370173711737217373173741737517376173771737817379173801738117382173831738417385173861738717388173891739017391173921739317394173951739617397173981739917400174011740217403174041740517406174071740817409174101741117412174131741417415174161741717418174191742017421174221742317424174251742617427174281742917430174311743217433174341743517436174371743817439174401744117442174431744417445174461744717448174491745017451174521745317454174551745617457174581745917460174611746217463174641746517466174671746817469174701747117472174731747417475174761747717478174791748017481174821748317484174851748617487174881748917490174911749217493174941749517496174971749817499175001750117502175031750417505175061750717508175091751017511175121751317514175151751617517175181751917520175211752217523175241752517526175271752817529175301753117532175331753417535175361753717538175391754017541175421754317544175451754617547175481754917550175511755217553175541755517556175571755817559175601756117562175631756417565175661756717568175691757017571175721757317574175751757617577175781757917580175811758217583175841758517586175871758817589175901759117592175931759417595175961759717598175991760017601176021760317604176051760617607176081760917610176111761217613176141761517616176171761817619176201762117622176231762417625176261762717628176291763017631176321763317634176351763617637176381763917640176411764217643176441764517646176471764817649176501765117652176531765417655176561765717658176591766017661176621766317664176651766617667176681766917670176711767217673176741767517676176771767817679176801768117682176831768417685176861768717688176891769017691176921769317694176951769617697176981769917700177011770217703177041770517706177071770817709177101771117712177131771417715177161771717718177191772017721177221772317724177251772617727177281772917730177311773217733177341773517736177371773817739177401774117742177431774417745177461774717748177491775017751177521775317754177551775617757177581775917760177611776217763177641776517766177671776817769177701777117772177731777417775177761777717778177791778017781177821778317784177851778617787177881778917790177911779217793177941779517796177971779817799178001780117802178031780417805178061780717808178091781017811178121781317814178151781617817178181781917820178211782217823178241782517826178271782817829178301783117832178331783417835178361783717838178391784017841178421784317844178451784617847178481784917850178511785217853178541785517856178571785817859178601786117862178631786417865178661786717868178691787017871178721787317874178751787617877178781787917880178811788217883178841788517886178871788817889178901789117892178931789417895178961789717898178991790017901179021790317904179051790617907179081790917910179111791217913179141791517916179171791817919179201792117922179231792417925179261792717928179291793017931179321793317934179351793617937179381793917940179411794217943179441794517946179471794817949179501795117952179531795417955179561795717958179591796017961179621796317964179651796617967179681796917970179711797217973179741797517976179771797817979179801798117982179831798417985179861798717988179891799017991179921799317994179951799617997179981799918000180011800218003180041800518006180071800818009180101801118012180131801418015180161801718018180191802018021180221802318024180251802618027180281802918030180311803218033180341803518036180371803818039180401804118042180431804418045180461804718048180491805018051180521805318054180551805618057180581805918060180611806218063180641806518066180671806818069180701807118072180731807418075180761807718078180791808018081180821808318084180851808618087180881808918090180911809218093180941809518096180971809818099181001810118102181031810418105181061810718108181091811018111181121811318114181151811618117181181811918120181211812218123181241812518126181271812818129181301813118132181331813418135181361813718138181391814018141181421814318144181451814618147181481814918150181511815218153181541815518156181571815818159181601816118162181631816418165181661816718168181691817018171181721817318174181751817618177181781817918180181811818218183181841818518186181871818818189181901819118192181931819418195181961819718198181991820018201182021820318204182051820618207182081820918210182111821218213182141821518216182171821818219182201822118222182231822418225182261822718228182291823018231182321823318234182351823618237182381823918240182411824218243182441824518246182471824818249182501825118252182531825418255182561825718258182591826018261182621826318264182651826618267182681826918270182711827218273182741827518276182771827818279182801828118282182831828418285182861828718288182891829018291182921829318294182951829618297182981829918300183011830218303183041830518306183071830818309183101831118312183131831418315183161831718318183191832018321183221832318324183251832618327183281832918330183311833218333183341833518336183371833818339183401834118342183431834418345183461834718348183491835018351183521835318354183551835618357183581835918360183611836218363183641836518366183671836818369183701837118372183731837418375183761837718378183791838018381183821838318384183851838618387183881838918390183911839218393183941839518396183971839818399184001840118402184031840418405184061840718408184091841018411184121841318414184151841618417184181841918420184211842218423184241842518426184271842818429184301843118432184331843418435184361843718438184391844018441184421844318444184451844618447184481844918450184511845218453184541845518456184571845818459184601846118462184631846418465184661846718468184691847018471184721847318474184751847618477184781847918480184811848218483184841848518486184871848818489184901849118492184931849418495184961849718498184991850018501185021850318504185051850618507185081850918510185111851218513185141851518516185171851818519185201852118522185231852418525185261852718528185291853018531185321853318534185351853618537185381853918540185411854218543185441854518546185471854818549185501855118552185531855418555185561855718558185591856018561185621856318564185651856618567185681856918570185711857218573185741857518576185771857818579185801858118582185831858418585185861858718588185891859018591185921859318594185951859618597185981859918600186011860218603186041860518606186071860818609186101861118612186131861418615186161861718618186191862018621186221862318624186251862618627186281862918630186311863218633186341863518636186371863818639186401864118642186431864418645186461864718648186491865018651186521865318654186551865618657186581865918660186611866218663186641866518666186671866818669186701867118672186731867418675186761867718678186791868018681186821868318684186851868618687186881868918690186911869218693186941869518696186971869818699187001870118702187031870418705187061870718708187091871018711187121871318714187151871618717187181871918720187211872218723187241872518726187271872818729187301873118732187331873418735187361873718738187391874018741187421874318744187451874618747187481874918750187511875218753187541875518756187571875818759187601876118762187631876418765187661876718768187691877018771187721877318774187751877618777187781877918780187811878218783187841878518786187871878818789187901879118792187931879418795187961879718798187991880018801188021880318804188051880618807188081880918810188111881218813188141881518816188171881818819188201882118822188231882418825188261882718828188291883018831188321883318834188351883618837188381883918840188411884218843188441884518846188471884818849188501885118852188531885418855188561885718858188591886018861188621886318864188651886618867188681886918870188711887218873188741887518876188771887818879188801888118882188831888418885188861888718888188891889018891188921889318894188951889618897188981889918900189011890218903189041890518906189071890818909189101891118912189131891418915189161891718918189191892018921189221892318924189251892618927189281892918930189311893218933189341893518936189371893818939189401894118942189431894418945189461894718948189491895018951189521895318954189551895618957189581895918960189611896218963189641896518966189671896818969189701897118972189731897418975189761897718978189791898018981189821898318984189851898618987189881898918990189911899218993189941899518996189971899818999190001900119002190031900419005190061900719008190091901019011190121901319014190151901619017190181901919020190211902219023190241902519026190271902819029190301903119032190331903419035190361903719038190391904019041190421904319044190451904619047190481904919050190511905219053190541905519056190571905819059190601906119062190631906419065190661906719068190691907019071190721907319074190751907619077190781907919080190811908219083190841908519086190871908819089190901909119092190931909419095190961909719098190991910019101191021910319104191051910619107191081910919110191111911219113191141911519116191171911819119191201912119122191231912419125191261912719128191291913019131191321913319134191351913619137191381913919140191411914219143191441914519146191471914819149191501915119152191531915419155191561915719158191591916019161191621916319164191651916619167191681916919170191711917219173191741917519176191771917819179191801918119182191831918419185191861918719188191891919019191191921919319194191951919619197191981919919200192011920219203192041920519206192071920819209192101921119212192131921419215192161921719218192191922019221192221922319224192251922619227192281922919230192311923219233192341923519236192371923819239192401924119242192431924419245192461924719248192491925019251192521925319254192551925619257192581925919260192611926219263192641926519266192671926819269192701927119272192731927419275192761927719278192791928019281192821928319284192851928619287192881928919290192911929219293192941929519296192971929819299193001930119302193031930419305193061930719308193091931019311193121931319314193151931619317193181931919320193211932219323193241932519326193271932819329193301933119332193331933419335193361933719338193391934019341193421934319344193451934619347193481934919350193511935219353193541935519356193571935819359193601936119362193631936419365193661936719368193691937019371193721937319374193751937619377193781937919380193811938219383193841938519386193871938819389193901939119392193931939419395193961939719398193991940019401194021940319404194051940619407194081940919410194111941219413194141941519416194171941819419194201942119422194231942419425194261942719428194291943019431194321943319434194351943619437194381943919440194411944219443194441944519446194471944819449194501945119452194531945419455194561945719458194591946019461194621946319464194651946619467194681946919470194711947219473194741947519476194771947819479194801948119482194831948419485194861948719488194891949019491194921949319494194951949619497194981949919500195011950219503195041950519506195071950819509195101951119512195131951419515195161951719518195191952019521195221952319524195251952619527195281952919530195311953219533195341953519536195371953819539195401954119542195431954419545195461954719548195491955019551195521955319554195551955619557195581955919560195611956219563195641956519566195671956819569195701957119572195731957419575195761957719578195791958019581195821958319584195851958619587195881958919590195911959219593195941959519596195971959819599196001960119602196031960419605196061960719608196091961019611196121961319614196151961619617196181961919620196211962219623196241962519626196271962819629196301963119632196331963419635196361963719638196391964019641196421964319644196451964619647196481964919650196511965219653196541965519656196571965819659196601966119662196631966419665196661966719668196691967019671196721967319674196751967619677196781967919680196811968219683196841968519686196871968819689196901969119692196931969419695196961969719698196991970019701197021970319704197051970619707197081970919710197111971219713197141971519716197171971819719197201972119722197231972419725197261972719728197291973019731197321973319734197351973619737197381973919740197411974219743197441974519746197471974819749197501975119752197531975419755197561975719758197591976019761197621976319764197651976619767197681976919770197711977219773197741977519776197771977819779197801978119782197831978419785197861978719788197891979019791197921979319794197951979619797197981979919800198011980219803198041980519806198071980819809198101981119812198131981419815198161981719818198191982019821198221982319824198251982619827198281982919830198311983219833198341983519836198371983819839198401984119842198431984419845198461984719848198491985019851198521985319854198551985619857198581985919860198611986219863198641986519866198671986819869198701987119872198731987419875198761987719878198791988019881198821988319884198851988619887198881988919890198911989219893198941989519896198971989819899199001990119902199031990419905199061990719908199091991019911199121991319914199151991619917199181991919920199211992219923199241992519926199271992819929199301993119932199331993419935199361993719938199391994019941199421994319944199451994619947199481994919950199511995219953199541995519956199571995819959199601996119962199631996419965199661996719968199691997019971199721997319974199751997619977199781997919980199811998219983199841998519986199871998819989199901999119992199931999419995199961999719998199992000020001200022000320004200052000620007200082000920010200112001220013200142001520016200172001820019200202002120022200232002420025200262002720028200292003020031200322003320034200352003620037200382003920040200412004220043200442004520046200472004820049200502005120052200532005420055200562005720058200592006020061200622006320064200652006620067200682006920070200712007220073200742007520076200772007820079200802008120082200832008420085200862008720088200892009020091200922009320094200952009620097200982009920100201012010220103201042010520106201072010820109201102011120112201132011420115201162011720118201192012020121201222012320124201252012620127201282012920130201312013220133201342013520136201372013820139201402014120142201432014420145201462014720148201492015020151201522015320154201552015620157201582015920160201612016220163201642016520166201672016820169201702017120172201732017420175201762017720178201792018020181201822018320184201852018620187201882018920190201912019220193201942019520196201972019820199202002020120202202032020420205202062020720208202092021020211202122021320214202152021620217202182021920220202212022220223202242022520226202272022820229202302023120232202332023420235202362023720238202392024020241202422024320244202452024620247202482024920250202512025220253202542025520256202572025820259202602026120262202632026420265202662026720268202692027020271202722027320274202752027620277202782027920280202812028220283202842028520286202872028820289202902029120292202932029420295202962029720298202992030020301203022030320304203052030620307203082030920310203112031220313203142031520316203172031820319203202032120322203232032420325203262032720328203292033020331203322033320334203352033620337203382033920340203412034220343203442034520346203472034820349203502035120352203532035420355203562035720358203592036020361203622036320364203652036620367203682036920370203712037220373203742037520376203772037820379203802038120382203832038420385203862038720388203892039020391203922039320394203952039620397203982039920400204012040220403204042040520406204072040820409204102041120412204132041420415204162041720418204192042020421204222042320424204252042620427204282042920430204312043220433204342043520436204372043820439204402044120442204432044420445204462044720448204492045020451204522045320454204552045620457204582045920460204612046220463204642046520466204672046820469204702047120472204732047420475204762047720478204792048020481204822048320484204852048620487204882048920490204912049220493204942049520496204972049820499205002050120502205032050420505205062050720508205092051020511205122051320514205152051620517205182051920520205212052220523205242052520526205272052820529205302053120532205332053420535205362053720538205392054020541205422054320544205452054620547205482054920550205512055220553205542055520556205572055820559205602056120562205632056420565205662056720568205692057020571205722057320574205752057620577205782057920580205812058220583205842058520586205872058820589205902059120592205932059420595205962059720598205992060020601206022060320604206052060620607206082060920610206112061220613206142061520616206172061820619206202062120622206232062420625206262062720628206292063020631206322063320634206352063620637206382063920640206412064220643206442064520646206472064820649206502065120652206532065420655206562065720658206592066020661206622066320664206652066620667206682066920670206712067220673206742067520676206772067820679206802068120682206832068420685206862068720688206892069020691206922069320694206952069620697206982069920700207012070220703207042070520706207072070820709207102071120712207132071420715207162071720718207192072020721207222072320724207252072620727207282072920730207312073220733207342073520736207372073820739207402074120742207432074420745207462074720748207492075020751207522075320754207552075620757207582075920760207612076220763207642076520766207672076820769207702077120772207732077420775207762077720778207792078020781207822078320784207852078620787207882078920790207912079220793207942079520796207972079820799208002080120802208032080420805208062080720808208092081020811208122081320814208152081620817208182081920820208212082220823208242082520826208272082820829208302083120832208332083420835208362083720838208392084020841208422084320844208452084620847208482084920850208512085220853208542085520856208572085820859208602086120862208632086420865208662086720868208692087020871208722087320874208752087620877208782087920880208812088220883208842088520886208872088820889208902089120892208932089420895208962089720898208992090020901209022090320904209052090620907209082090920910209112091220913209142091520916209172091820919209202092120922209232092420925209262092720928209292093020931209322093320934209352093620937209382093920940209412094220943209442094520946209472094820949209502095120952209532095420955209562095720958209592096020961209622096320964209652096620967209682096920970209712097220973209742097520976209772097820979209802098120982209832098420985209862098720988209892099020991209922099320994209952099620997209982099921000210012100221003210042100521006210072100821009210102101121012210132101421015210162101721018210192102021021210222102321024210252102621027210282102921030210312103221033210342103521036210372103821039210402104121042210432104421045210462104721048210492105021051210522105321054210552105621057210582105921060210612106221063210642106521066210672106821069210702107121072210732107421075210762107721078210792108021081210822108321084210852108621087210882108921090210912109221093210942109521096210972109821099211002110121102211032110421105211062110721108211092111021111211122111321114211152111621117211182111921120211212112221123211242112521126211272112821129211302113121132211332113421135211362113721138211392114021141211422114321144211452114621147211482114921150211512115221153211542115521156211572115821159211602116121162211632116421165211662116721168211692117021171211722117321174211752117621177211782117921180211812118221183211842118521186211872118821189211902119121192211932119421195211962119721198211992120021201212022120321204212052120621207212082120921210212112121221213212142121521216212172121821219212202122121222212232122421225212262122721228212292123021231212322123321234212352123621237212382123921240212412124221243212442124521246212472124821249212502125121252212532125421255212562125721258212592126021261212622126321264212652126621267212682126921270212712127221273212742127521276212772127821279212802128121282212832128421285212862128721288212892129021291212922129321294212952129621297212982129921300213012130221303213042130521306213072130821309213102131121312213132131421315213162131721318213192132021321213222132321324213252132621327213282132921330213312133221333213342133521336213372133821339213402134121342213432134421345213462134721348213492135021351213522135321354213552135621357213582135921360213612136221363213642136521366213672136821369213702137121372213732137421375213762137721378213792138021381213822138321384213852138621387213882138921390213912139221393213942139521396213972139821399214002140121402214032140421405214062140721408214092141021411214122141321414214152141621417214182141921420214212142221423214242142521426214272142821429214302143121432214332143421435214362143721438214392144021441214422144321444214452144621447214482144921450214512145221453214542145521456214572145821459214602146121462214632146421465214662146721468214692147021471214722147321474214752147621477214782147921480214812148221483214842148521486214872148821489214902149121492214932149421495214962149721498214992150021501215022150321504215052150621507215082150921510215112151221513215142151521516215172151821519215202152121522215232152421525215262152721528215292153021531215322153321534215352153621537215382153921540215412154221543215442154521546215472154821549215502155121552215532155421555215562155721558215592156021561215622156321564215652156621567215682156921570215712157221573215742157521576215772157821579215802158121582215832158421585215862158721588215892159021591215922159321594215952159621597215982159921600216012160221603216042160521606216072160821609216102161121612216132161421615216162161721618216192162021621216222162321624216252162621627216282162921630216312163221633216342163521636216372163821639216402164121642216432164421645216462164721648216492165021651216522165321654216552165621657216582165921660216612166221663216642166521666216672166821669216702167121672216732167421675216762167721678216792168021681216822168321684216852168621687216882168921690216912169221693216942169521696216972169821699217002170121702217032170421705217062170721708217092171021711217122171321714217152171621717217182171921720217212172221723217242172521726217272172821729217302173121732217332173421735217362173721738217392174021741217422174321744217452174621747217482174921750217512175221753217542175521756217572175821759217602176121762217632176421765217662176721768217692177021771217722177321774217752177621777217782177921780217812178221783217842178521786217872178821789217902179121792217932179421795217962179721798217992180021801218022180321804218052180621807218082180921810218112181221813218142181521816218172181821819218202182121822218232182421825218262182721828218292183021831218322183321834218352183621837218382183921840218412184221843218442184521846218472184821849218502185121852218532185421855218562185721858218592186021861218622186321864218652186621867218682186921870218712187221873218742187521876218772187821879218802188121882218832188421885218862188721888218892189021891218922189321894218952189621897218982189921900219012190221903219042190521906219072190821909219102191121912219132191421915219162191721918219192192021921219222192321924219252192621927219282192921930219312193221933219342193521936219372193821939219402194121942219432194421945219462194721948219492195021951219522195321954219552195621957219582195921960219612196221963219642196521966219672196821969219702197121972219732197421975219762197721978219792198021981219822198321984219852198621987219882198921990219912199221993219942199521996219972199821999220002200122002220032200422005220062200722008220092201022011220122201322014220152201622017220182201922020220212202222023220242202522026220272202822029220302203122032220332203422035220362203722038220392204022041220422204322044220452204622047220482204922050220512205222053220542205522056220572205822059220602206122062220632206422065220662206722068220692207022071220722207322074220752207622077220782207922080220812208222083220842208522086220872208822089220902209122092220932209422095220962209722098220992210022101221022210322104221052210622107221082210922110221112211222113221142211522116221172211822119221202212122122221232212422125221262212722128221292213022131221322213322134221352213622137221382213922140221412214222143221442214522146221472214822149221502215122152221532215422155221562215722158221592216022161221622216322164221652216622167221682216922170221712217222173221742217522176221772217822179221802218122182221832218422185221862218722188221892219022191221922219322194221952219622197221982219922200222012220222203222042220522206222072220822209222102221122212222132221422215222162221722218222192222022221222222222322224222252222622227222282222922230222312223222233222342223522236222372223822239222402224122242222432224422245222462224722248222492225022251222522225322254222552225622257222582225922260222612226222263222642226522266222672226822269222702227122272222732227422275222762227722278222792228022281222822228322284222852228622287222882228922290222912229222293222942229522296222972229822299223002230122302223032230422305223062230722308223092231022311223122231322314223152231622317223182231922320223212232222323223242232522326223272232822329223302233122332223332233422335223362233722338223392234022341223422234322344223452234622347223482234922350223512235222353223542235522356223572235822359223602236122362223632236422365223662236722368223692237022371223722237322374223752237622377223782237922380223812238222383223842238522386223872238822389223902239122392223932239422395223962239722398223992240022401224022240322404224052240622407224082240922410224112241222413224142241522416224172241822419224202242122422224232242422425224262242722428224292243022431224322243322434224352243622437224382243922440224412244222443224442244522446224472244822449224502245122452224532245422455224562245722458224592246022461224622246322464224652246622467224682246922470224712247222473224742247522476224772247822479224802248122482224832248422485224862248722488224892249022491224922249322494224952249622497224982249922500225012250222503225042250522506225072250822509225102251122512225132251422515225162251722518225192252022521225222252322524225252252622527225282252922530225312253222533225342253522536225372253822539225402254122542225432254422545225462254722548225492255022551225522255322554225552255622557225582255922560225612256222563225642256522566225672256822569225702257122572225732257422575225762257722578225792258022581225822258322584225852258622587225882258922590225912259222593225942259522596225972259822599226002260122602226032260422605226062260722608226092261022611226122261322614226152261622617226182261922620226212262222623226242262522626226272262822629226302263122632226332263422635226362263722638226392264022641226422264322644226452264622647226482264922650226512265222653226542265522656226572265822659226602266122662226632266422665226662266722668226692267022671226722267322674226752267622677226782267922680226812268222683226842268522686226872268822689226902269122692226932269422695226962269722698226992270022701227022270322704227052270622707227082270922710227112271222713227142271522716227172271822719227202272122722227232272422725227262272722728227292273022731227322273322734227352273622737227382273922740227412274222743227442274522746227472274822749227502275122752227532275422755227562275722758227592276022761227622276322764227652276622767227682276922770227712277222773227742277522776227772277822779227802278122782227832278422785227862278722788227892279022791227922279322794227952279622797227982279922800228012280222803228042280522806228072280822809228102281122812228132281422815228162281722818228192282022821228222282322824228252282622827228282282922830228312283222833228342283522836228372283822839228402284122842228432284422845228462284722848228492285022851228522285322854228552285622857228582285922860228612286222863228642286522866228672286822869228702287122872228732287422875228762287722878228792288022881228822288322884228852288622887228882288922890228912289222893228942289522896228972289822899229002290122902229032290422905229062290722908229092291022911229122291322914229152291622917229182291922920229212292222923229242292522926229272292822929229302293122932229332293422935229362293722938229392294022941229422294322944229452294622947229482294922950229512295222953229542295522956229572295822959229602296122962229632296422965229662296722968229692297022971229722297322974229752297622977229782297922980229812298222983229842298522986229872298822989229902299122992229932299422995229962299722998229992300023001230022300323004230052300623007230082300923010230112301223013230142301523016230172301823019230202302123022230232302423025230262302723028230292303023031230322303323034230352303623037230382303923040230412304223043230442304523046230472304823049230502305123052230532305423055230562305723058230592306023061230622306323064230652306623067230682306923070230712307223073230742307523076230772307823079230802308123082230832308423085230862308723088230892309023091230922309323094230952309623097230982309923100231012310223103231042310523106231072310823109231102311123112231132311423115231162311723118231192312023121231222312323124231252312623127231282312923130231312313223133231342313523136231372313823139231402314123142231432314423145231462314723148231492315023151231522315323154231552315623157231582315923160231612316223163231642316523166231672316823169231702317123172231732317423175231762317723178231792318023181231822318323184231852318623187231882318923190231912319223193231942319523196231972319823199232002320123202232032320423205232062320723208232092321023211232122321323214232152321623217232182321923220232212322223223232242322523226232272322823229232302323123232232332323423235232362323723238232392324023241232422324323244232452324623247232482324923250232512325223253232542325523256232572325823259232602326123262232632326423265232662326723268232692327023271232722327323274232752327623277232782327923280232812328223283232842328523286232872328823289232902329123292232932329423295232962329723298232992330023301233022330323304233052330623307233082330923310233112331223313233142331523316233172331823319233202332123322233232332423325233262332723328233292333023331233322333323334233352333623337233382333923340233412334223343233442334523346233472334823349233502335123352233532335423355233562335723358233592336023361233622336323364233652336623367233682336923370233712337223373233742337523376233772337823379233802338123382233832338423385233862338723388233892339023391233922339323394233952339623397233982339923400234012340223403234042340523406234072340823409234102341123412234132341423415234162341723418234192342023421234222342323424234252342623427234282342923430234312343223433234342343523436234372343823439234402344123442234432344423445234462344723448234492345023451234522345323454234552345623457234582345923460234612346223463234642346523466234672346823469234702347123472234732347423475234762347723478234792348023481234822348323484234852348623487234882348923490234912349223493234942349523496234972349823499235002350123502235032350423505235062350723508235092351023511235122351323514235152351623517235182351923520235212352223523235242352523526235272352823529235302353123532235332353423535235362353723538235392354023541235422354323544235452354623547235482354923550235512355223553235542355523556235572355823559235602356123562235632356423565235662356723568235692357023571235722357323574235752357623577235782357923580235812358223583235842358523586235872358823589235902359123592235932359423595235962359723598235992360023601236022360323604236052360623607236082360923610236112361223613236142361523616236172361823619236202362123622236232362423625236262362723628236292363023631236322363323634236352363623637236382363923640236412364223643236442364523646236472364823649236502365123652236532365423655236562365723658236592366023661236622366323664236652366623667236682366923670236712367223673236742367523676236772367823679236802368123682236832368423685236862368723688236892369023691236922369323694236952369623697236982369923700237012370223703237042370523706237072370823709237102371123712237132371423715237162371723718237192372023721237222372323724237252372623727237282372923730237312373223733237342373523736237372373823739237402374123742237432374423745237462374723748237492375023751237522375323754237552375623757237582375923760237612376223763237642376523766237672376823769237702377123772237732377423775237762377723778237792378023781237822378323784237852378623787237882378923790237912379223793237942379523796237972379823799238002380123802238032380423805238062380723808238092381023811238122381323814238152381623817238182381923820238212382223823238242382523826238272382823829238302383123832238332383423835238362383723838238392384023841238422384323844238452384623847238482384923850238512385223853238542385523856238572385823859238602386123862238632386423865238662386723868238692387023871238722387323874238752387623877238782387923880238812388223883238842388523886238872388823889238902389123892238932389423895238962389723898238992390023901239022390323904239052390623907239082390923910239112391223913239142391523916239172391823919239202392123922239232392423925239262392723928239292393023931239322393323934239352393623937239382393923940239412394223943239442394523946239472394823949239502395123952239532395423955239562395723958239592396023961239622396323964239652396623967239682396923970239712397223973239742397523976239772397823979239802398123982239832398423985239862398723988239892399023991239922399323994239952399623997239982399924000240012400224003240042400524006240072400824009240102401124012240132401424015240162401724018240192402024021240222402324024240252402624027240282402924030240312403224033240342403524036240372403824039240402404124042240432404424045240462404724048240492405024051240522405324054240552405624057240582405924060240612406224063240642406524066240672406824069240702407124072240732407424075240762407724078240792408024081240822408324084240852408624087240882408924090240912409224093240942409524096240972409824099241002410124102241032410424105241062410724108241092411024111241122411324114241152411624117241182411924120241212412224123241242412524126241272412824129241302413124132241332413424135241362413724138241392414024141241422414324144241452414624147241482414924150241512415224153241542415524156241572415824159241602416124162241632416424165241662416724168241692417024171241722417324174241752417624177241782417924180241812418224183241842418524186241872418824189241902419124192241932419424195241962419724198241992420024201242022420324204242052420624207242082420924210242112421224213242142421524216242172421824219242202422124222242232422424225242262422724228242292423024231242322423324234242352423624237242382423924240242412424224243242442424524246242472424824249242502425124252242532425424255242562425724258242592426024261242622426324264242652426624267242682426924270242712427224273242742427524276242772427824279242802428124282242832428424285242862428724288242892429024291242922429324294242952429624297242982429924300243012430224303243042430524306243072430824309243102431124312243132431424315243162431724318243192432024321243222432324324243252432624327243282432924330243312433224333243342433524336243372433824339243402434124342243432434424345243462434724348243492435024351243522435324354243552435624357243582435924360243612436224363243642436524366243672436824369243702437124372243732437424375243762437724378243792438024381243822438324384243852438624387243882438924390243912439224393243942439524396243972439824399244002440124402244032440424405244062440724408244092441024411244122441324414244152441624417244182441924420244212442224423244242442524426244272442824429244302443124432244332443424435244362443724438244392444024441244422444324444244452444624447244482444924450244512445224453244542445524456244572445824459244602446124462244632446424465244662446724468244692447024471244722447324474244752447624477244782447924480244812448224483244842448524486244872448824489244902449124492244932449424495244962449724498244992450024501245022450324504245052450624507245082450924510245112451224513245142451524516245172451824519245202452124522245232452424525245262452724528245292453024531245322453324534245352453624537245382453924540245412454224543245442454524546245472454824549245502455124552245532455424555245562455724558245592456024561245622456324564245652456624567245682456924570245712457224573245742457524576245772457824579245802458124582245832458424585245862458724588245892459024591245922459324594245952459624597245982459924600246012460224603246042460524606246072460824609246102461124612246132461424615246162461724618246192462024621246222462324624246252462624627246282462924630246312463224633246342463524636246372463824639246402464124642246432464424645246462464724648246492465024651246522465324654246552465624657246582465924660246612466224663246642466524666246672466824669246702467124672246732467424675246762467724678246792468024681246822468324684246852468624687246882468924690246912469224693246942469524696246972469824699247002470124702247032470424705247062470724708247092471024711247122471324714247152471624717247182471924720247212472224723247242472524726247272472824729247302473124732247332473424735247362473724738247392474024741247422474324744247452474624747247482474924750247512475224753247542475524756247572475824759247602476124762247632476424765247662476724768247692477024771247722477324774247752477624777247782477924780247812478224783247842478524786247872478824789247902479124792247932479424795247962479724798247992480024801248022480324804248052480624807248082480924810248112481224813248142481524816248172481824819248202482124822248232482424825248262482724828248292483024831248322483324834248352483624837248382483924840248412484224843248442484524846248472484824849248502485124852248532485424855248562485724858248592486024861248622486324864248652486624867248682486924870248712487224873248742487524876248772487824879248802488124882248832488424885248862488724888248892489024891248922489324894248952489624897248982489924900249012490224903249042490524906249072490824909249102491124912249132491424915249162491724918249192492024921249222492324924249252492624927249282492924930249312493224933249342493524936249372493824939249402494124942249432494424945249462494724948249492495024951249522495324954249552495624957249582495924960249612496224963249642496524966249672496824969249702497124972249732497424975249762497724978249792498024981249822498324984249852498624987249882498924990249912499224993249942499524996249972499824999250002500125002250032500425005250062500725008250092501025011250122501325014250152501625017250182501925020250212502225023250242502525026250272502825029250302503125032250332503425035250362503725038250392504025041250422504325044250452504625047250482504925050250512505225053250542505525056250572505825059250602506125062250632506425065250662506725068250692507025071250722507325074250752507625077250782507925080250812508225083250842508525086250872508825089250902509125092250932509425095250962509725098
  1. (function webpackUniversalModuleDefinition(root, factory) {
  2. if(typeof exports === 'object' && typeof module === 'object')
  3. module.exports = factory();
  4. else if(typeof define === 'function' && define.amd)
  5. define([], factory);
  6. else if(typeof exports === 'object')
  7. exports["wangEditor"] = factory();
  8. else
  9. root["wangEditor"] = factory();
  10. })(window, function() {
  11. return /******/ (function(modules) { // webpackBootstrap
  12. /******/ // The module cache
  13. /******/ var installedModules = {};
  14. /******/
  15. /******/ // The require function
  16. /******/ function __webpack_require__(moduleId) {
  17. /******/
  18. /******/ // Check if module is in cache
  19. /******/ if(installedModules[moduleId]) {
  20. /******/ return installedModules[moduleId].exports;
  21. /******/ }
  22. /******/ // Create a new module (and put it into the cache)
  23. /******/ var module = installedModules[moduleId] = {
  24. /******/ i: moduleId,
  25. /******/ l: false,
  26. /******/ exports: {}
  27. /******/ };
  28. /******/
  29. /******/ // Execute the module function
  30. /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
  31. /******/
  32. /******/ // Flag the module as loaded
  33. /******/ module.l = true;
  34. /******/
  35. /******/ // Return the exports of the module
  36. /******/ return module.exports;
  37. /******/ }
  38. /******/
  39. /******/
  40. /******/ // expose the modules object (__webpack_modules__)
  41. /******/ __webpack_require__.m = modules;
  42. /******/
  43. /******/ // expose the module cache
  44. /******/ __webpack_require__.c = installedModules;
  45. /******/
  46. /******/ // define getter function for harmony exports
  47. /******/ __webpack_require__.d = function(exports, name, getter) {
  48. /******/ if(!__webpack_require__.o(exports, name)) {
  49. /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
  50. /******/ }
  51. /******/ };
  52. /******/
  53. /******/ // define __esModule on exports
  54. /******/ __webpack_require__.r = function(exports) {
  55. /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
  56. /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  57. /******/ }
  58. /******/ Object.defineProperty(exports, '__esModule', { value: true });
  59. /******/ };
  60. /******/
  61. /******/ // create a fake namespace object
  62. /******/ // mode & 1: value is a module id, require it
  63. /******/ // mode & 2: merge all properties of value into the ns
  64. /******/ // mode & 4: return value when already ns object
  65. /******/ // mode & 8|1: behave like require
  66. /******/ __webpack_require__.t = function(value, mode) {
  67. /******/ if(mode & 1) value = __webpack_require__(value);
  68. /******/ if(mode & 8) return value;
  69. /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
  70. /******/ var ns = Object.create(null);
  71. /******/ __webpack_require__.r(ns);
  72. /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
  73. /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
  74. /******/ return ns;
  75. /******/ };
  76. /******/
  77. /******/ // getDefaultExport function for compatibility with non-harmony modules
  78. /******/ __webpack_require__.n = function(module) {
  79. /******/ var getter = module && module.__esModule ?
  80. /******/ function getDefault() { return module['default']; } :
  81. /******/ function getModuleExports() { return module; };
  82. /******/ __webpack_require__.d(getter, 'a', getter);
  83. /******/ return getter;
  84. /******/ };
  85. /******/
  86. /******/ // Object.prototype.hasOwnProperty.call
  87. /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
  88. /******/
  89. /******/ // __webpack_public_path__
  90. /******/ __webpack_require__.p = "";
  91. /******/
  92. /******/
  93. /******/ // Load entry module and return exports
  94. /******/ return __webpack_require__(__webpack_require__.s = 146);
  95. /******/ })
  96. /************************************************************************/
  97. /******/ ([
  98. /* 0 */
  99. /***/ (function(module, exports) {
  100. function _interopRequireDefault(obj) {
  101. return obj && obj.__esModule ? obj : {
  102. "default": obj
  103. };
  104. }
  105. module.exports = _interopRequireDefault;
  106. module.exports["default"] = module.exports, module.exports.__esModule = true;
  107. /***/ }),
  108. /* 1 */
  109. /***/ (function(module, exports, __webpack_require__) {
  110. module.exports = __webpack_require__(147);
  111. /***/ }),
  112. /* 2 */
  113. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  114. "use strict";
  115. __webpack_require__.r(__webpack_exports__);
  116. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__extends", function() { return __extends; });
  117. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__assign", function() { return __assign; });
  118. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__rest", function() { return __rest; });
  119. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__decorate", function() { return __decorate; });
  120. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__param", function() { return __param; });
  121. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__metadata", function() { return __metadata; });
  122. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__awaiter", function() { return __awaiter; });
  123. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__generator", function() { return __generator; });
  124. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__createBinding", function() { return __createBinding; });
  125. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__exportStar", function() { return __exportStar; });
  126. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__values", function() { return __values; });
  127. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__read", function() { return __read; });
  128. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__spread", function() { return __spread; });
  129. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__spreadArrays", function() { return __spreadArrays; });
  130. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__spreadArray", function() { return __spreadArray; });
  131. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__await", function() { return __await; });
  132. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncGenerator", function() { return __asyncGenerator; });
  133. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncDelegator", function() { return __asyncDelegator; });
  134. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncValues", function() { return __asyncValues; });
  135. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__makeTemplateObject", function() { return __makeTemplateObject; });
  136. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__importStar", function() { return __importStar; });
  137. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__importDefault", function() { return __importDefault; });
  138. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__classPrivateFieldGet", function() { return __classPrivateFieldGet; });
  139. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__classPrivateFieldSet", function() { return __classPrivateFieldSet; });
  140. /*! *****************************************************************************
  141. Copyright (c) Microsoft Corporation.
  142. Permission to use, copy, modify, and/or distribute this software for any
  143. purpose with or without fee is hereby granted.
  144. THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
  145. REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  146. AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
  147. INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  148. LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
  149. OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  150. PERFORMANCE OF THIS SOFTWARE.
  151. ***************************************************************************** */
  152. /* global Reflect, Promise */
  153. var extendStatics = function(d, b) {
  154. extendStatics = Object.setPrototypeOf ||
  155. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  156. function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
  157. return extendStatics(d, b);
  158. };
  159. function __extends(d, b) {
  160. if (typeof b !== "function" && b !== null)
  161. throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
  162. extendStatics(d, b);
  163. function __() { this.constructor = d; }
  164. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  165. }
  166. var __assign = function() {
  167. __assign = Object.assign || function __assign(t) {
  168. for (var s, i = 1, n = arguments.length; i < n; i++) {
  169. s = arguments[i];
  170. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
  171. }
  172. return t;
  173. }
  174. return __assign.apply(this, arguments);
  175. }
  176. function __rest(s, e) {
  177. var t = {};
  178. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
  179. t[p] = s[p];
  180. if (s != null && typeof Object.getOwnPropertySymbols === "function")
  181. for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  182. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
  183. t[p[i]] = s[p[i]];
  184. }
  185. return t;
  186. }
  187. function __decorate(decorators, target, key, desc) {
  188. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  189. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  190. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  191. return c > 3 && r && Object.defineProperty(target, key, r), r;
  192. }
  193. function __param(paramIndex, decorator) {
  194. return function (target, key) { decorator(target, key, paramIndex); }
  195. }
  196. function __metadata(metadataKey, metadataValue) {
  197. if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
  198. }
  199. function __awaiter(thisArg, _arguments, P, generator) {
  200. function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
  201. return new (P || (P = Promise))(function (resolve, reject) {
  202. function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
  203. function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
  204. function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
  205. step((generator = generator.apply(thisArg, _arguments || [])).next());
  206. });
  207. }
  208. function __generator(thisArg, body) {
  209. var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
  210. return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
  211. function verb(n) { return function (v) { return step([n, v]); }; }
  212. function step(op) {
  213. if (f) throw new TypeError("Generator is already executing.");
  214. while (_) try {
  215. if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
  216. if (y = 0, t) op = [op[0] & 2, t.value];
  217. switch (op[0]) {
  218. case 0: case 1: t = op; break;
  219. case 4: _.label++; return { value: op[1], done: false };
  220. case 5: _.label++; y = op[1]; op = [0]; continue;
  221. case 7: op = _.ops.pop(); _.trys.pop(); continue;
  222. default:
  223. if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
  224. if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
  225. if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
  226. if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
  227. if (t[2]) _.ops.pop();
  228. _.trys.pop(); continue;
  229. }
  230. op = body.call(thisArg, _);
  231. } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
  232. if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
  233. }
  234. }
  235. var __createBinding = Object.create ? (function(o, m, k, k2) {
  236. if (k2 === undefined) k2 = k;
  237. Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
  238. }) : (function(o, m, k, k2) {
  239. if (k2 === undefined) k2 = k;
  240. o[k2] = m[k];
  241. });
  242. function __exportStar(m, o) {
  243. for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);
  244. }
  245. function __values(o) {
  246. var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
  247. if (m) return m.call(o);
  248. if (o && typeof o.length === "number") return {
  249. next: function () {
  250. if (o && i >= o.length) o = void 0;
  251. return { value: o && o[i++], done: !o };
  252. }
  253. };
  254. throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
  255. }
  256. function __read(o, n) {
  257. var m = typeof Symbol === "function" && o[Symbol.iterator];
  258. if (!m) return o;
  259. var i = m.call(o), r, ar = [], e;
  260. try {
  261. while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
  262. }
  263. catch (error) { e = { error: error }; }
  264. finally {
  265. try {
  266. if (r && !r.done && (m = i["return"])) m.call(i);
  267. }
  268. finally { if (e) throw e.error; }
  269. }
  270. return ar;
  271. }
  272. /** @deprecated */
  273. function __spread() {
  274. for (var ar = [], i = 0; i < arguments.length; i++)
  275. ar = ar.concat(__read(arguments[i]));
  276. return ar;
  277. }
  278. /** @deprecated */
  279. function __spreadArrays() {
  280. for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
  281. for (var r = Array(s), k = 0, i = 0; i < il; i++)
  282. for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
  283. r[k] = a[j];
  284. return r;
  285. }
  286. function __spreadArray(to, from, pack) {
  287. if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
  288. if (ar || !(i in from)) {
  289. if (!ar) ar = Array.prototype.slice.call(from, 0, i);
  290. ar[i] = from[i];
  291. }
  292. }
  293. return to.concat(ar || Array.prototype.slice.call(from));
  294. }
  295. function __await(v) {
  296. return this instanceof __await ? (this.v = v, this) : new __await(v);
  297. }
  298. function __asyncGenerator(thisArg, _arguments, generator) {
  299. if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
  300. var g = generator.apply(thisArg, _arguments || []), i, q = [];
  301. return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
  302. function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
  303. function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
  304. function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
  305. function fulfill(value) { resume("next", value); }
  306. function reject(value) { resume("throw", value); }
  307. function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
  308. }
  309. function __asyncDelegator(o) {
  310. var i, p;
  311. return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
  312. function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; }
  313. }
  314. function __asyncValues(o) {
  315. if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
  316. var m = o[Symbol.asyncIterator], i;
  317. return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
  318. function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
  319. function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
  320. }
  321. function __makeTemplateObject(cooked, raw) {
  322. if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
  323. return cooked;
  324. };
  325. var __setModuleDefault = Object.create ? (function(o, v) {
  326. Object.defineProperty(o, "default", { enumerable: true, value: v });
  327. }) : function(o, v) {
  328. o["default"] = v;
  329. };
  330. function __importStar(mod) {
  331. if (mod && mod.__esModule) return mod;
  332. var result = {};
  333. if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
  334. __setModuleDefault(result, mod);
  335. return result;
  336. }
  337. function __importDefault(mod) {
  338. return (mod && mod.__esModule) ? mod : { default: mod };
  339. }
  340. function __classPrivateFieldGet(receiver, state, kind, f) {
  341. if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
  342. if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
  343. return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
  344. }
  345. function __classPrivateFieldSet(receiver, state, value, kind, f) {
  346. if (kind === "m") throw new TypeError("Private method is not writable");
  347. if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
  348. if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
  349. return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
  350. }
  351. /***/ }),
  352. /* 3 */
  353. /***/ (function(module, exports, __webpack_require__) {
  354. "use strict";
  355. /**
  356. * @description 封装 DOM 操作
  357. * @wangfupeng
  358. */
  359. var _interopRequireDefault = __webpack_require__(0);
  360. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  361. var _isArray = _interopRequireDefault(__webpack_require__(96));
  362. var _forEach = _interopRequireDefault(__webpack_require__(4));
  363. var _map = _interopRequireDefault(__webpack_require__(27));
  364. var _trim = _interopRequireDefault(__webpack_require__(16));
  365. var _map2 = _interopRequireDefault(__webpack_require__(125));
  366. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  367. var _splice = _interopRequireDefault(__webpack_require__(99));
  368. var _filter = _interopRequireDefault(__webpack_require__(76));
  369. var _includes = _interopRequireDefault(__webpack_require__(46));
  370. var _bind = _interopRequireDefault(__webpack_require__(61));
  371. (0, _defineProperty["default"])(exports, "__esModule", {
  372. value: true
  373. });
  374. exports.DomElement = void 0;
  375. var tslib_1 = __webpack_require__(2);
  376. var util_1 = __webpack_require__(6);
  377. var AGENT_EVENTS = [];
  378. /**
  379. * 根据 html 字符串创建 elem
  380. * @param {String} html html
  381. */
  382. function _createElemByHTML(html) {
  383. var div = document.createElement('div');
  384. div.innerHTML = html;
  385. var elems = div.children;
  386. return util_1.toArray(elems);
  387. }
  388. /**
  389. * 判断是否是 DOM List
  390. * @param selector DOM 元素或列表
  391. */
  392. function _isDOMList(selector) {
  393. if (!selector) {
  394. return false;
  395. }
  396. if (selector instanceof HTMLCollection || selector instanceof NodeList) {
  397. return true;
  398. }
  399. return false;
  400. }
  401. /**
  402. * 封装 querySelectorAll
  403. * @param selector css 选择器
  404. */
  405. function _querySelectorAll(selector) {
  406. var elems = document.querySelectorAll(selector);
  407. return util_1.toArray(elems);
  408. }
  409. /**
  410. * 封装 _styleArrTrim
  411. * @param styleArr css
  412. */
  413. function _styleArrTrim(style) {
  414. var styleArr = [];
  415. var resultArr = [];
  416. if (!(0, _isArray["default"])(style)) {
  417. // 有 style,将 style 按照 `;` 拆分为数组
  418. styleArr = style.split(';');
  419. } else {
  420. styleArr = style;
  421. }
  422. (0, _forEach["default"])(styleArr).call(styleArr, function (item) {
  423. var _context;
  424. // 对每项样式,按照 : 拆分为 key 和 value
  425. var arr = (0, _map["default"])(_context = item.split(':')).call(_context, function (i) {
  426. return (0, _trim["default"])(i).call(i);
  427. });
  428. if (arr.length === 2) {
  429. resultArr.push(arr[0] + ':' + arr[1]);
  430. }
  431. });
  432. return resultArr;
  433. } // 构造函数
  434. var DomElement = function () {
  435. /**
  436. * 构造函数
  437. * @param selector 任一类型的选择器
  438. */
  439. function DomElement(selector) {
  440. // 初始化属性
  441. this.elems = [];
  442. this.length = this.elems.length;
  443. this.dataSource = new _map2["default"]();
  444. if (!selector) {
  445. return;
  446. } // 原本就是 DomElement 实例,则直接返回
  447. if (selector instanceof DomElement) {
  448. return selector;
  449. }
  450. var selectorResult = []; // 存储查询结果
  451. var nodeType = selector instanceof Node ? selector.nodeType : -1;
  452. this.selector = selector;
  453. if (nodeType === 1 || nodeType === 9) {
  454. selectorResult = [selector];
  455. } else if (_isDOMList(selector)) {
  456. // DOM List
  457. selectorResult = util_1.toArray(selector);
  458. } else if (selector instanceof Array) {
  459. // Element 数组(其他数据类型,暂时忽略)
  460. selectorResult = selector;
  461. } else if (typeof selector === 'string') {
  462. var _context2;
  463. // 字符串
  464. var tmpSelector = (0, _trim["default"])(_context2 = selector.replace('/\n/mg', '')).call(_context2);
  465. if ((0, _indexOf["default"])(tmpSelector).call(tmpSelector, '<') === 0) {
  466. // 如 <div>
  467. selectorResult = _createElemByHTML(tmpSelector);
  468. } else {
  469. // 如 #id .class
  470. selectorResult = _querySelectorAll(tmpSelector);
  471. }
  472. }
  473. var length = selectorResult.length;
  474. if (!length) {
  475. // 空数组
  476. return this;
  477. } // 加入 DOM 节点
  478. var i = 0;
  479. for (; i < length; i++) {
  480. this.elems.push(selectorResult[i]);
  481. }
  482. this.length = length;
  483. }
  484. (0, _defineProperty["default"])(DomElement.prototype, "id", {
  485. /**
  486. * 获取元素 id
  487. */
  488. get: function get() {
  489. return this.elems[0].id;
  490. },
  491. enumerable: false,
  492. configurable: true
  493. });
  494. /**
  495. * 遍历所有元素,执行回调函数
  496. * @param fn 回调函数
  497. */
  498. DomElement.prototype.forEach = function (fn) {
  499. for (var i = 0; i < this.length; i++) {
  500. var elem = this.elems[i];
  501. var result = fn.call(elem, elem, i);
  502. if (result === false) {
  503. break;
  504. }
  505. }
  506. return this;
  507. };
  508. /**
  509. * 克隆元素
  510. * @param deep 是否深度克隆
  511. */
  512. DomElement.prototype.clone = function (deep) {
  513. var _context3;
  514. if (deep === void 0) {
  515. deep = false;
  516. }
  517. var cloneList = [];
  518. (0, _forEach["default"])(_context3 = this.elems).call(_context3, function (elem) {
  519. cloneList.push(elem.cloneNode(!!deep));
  520. });
  521. return $(cloneList);
  522. };
  523. /**
  524. * 获取第几个元素
  525. * @param index index
  526. */
  527. DomElement.prototype.get = function (index) {
  528. if (index === void 0) {
  529. index = 0;
  530. }
  531. var length = this.length;
  532. if (index >= length) {
  533. index = index % length;
  534. }
  535. return $(this.elems[index]);
  536. };
  537. /**
  538. * 获取第一个元素
  539. */
  540. DomElement.prototype.first = function () {
  541. return this.get(0);
  542. };
  543. /**
  544. * 获取最后一个元素
  545. */
  546. DomElement.prototype.last = function () {
  547. var length = this.length;
  548. return this.get(length - 1);
  549. };
  550. DomElement.prototype.on = function (type, selector, fn) {
  551. var _context4;
  552. if (!type) return this; // 没有 selector ,只有 type 和 fn
  553. if (typeof selector === 'function') {
  554. fn = selector;
  555. selector = '';
  556. }
  557. return (0, _forEach["default"])(_context4 = this).call(_context4, function (elem) {
  558. // 没有事件代理
  559. if (!selector) {
  560. // 无代理
  561. elem.addEventListener(type, fn);
  562. return;
  563. } // 有事件代理
  564. var agentFn = function agentFn(e) {
  565. var target = e.target;
  566. if (target.matches(selector)) {
  567. ;
  568. fn.call(target, e);
  569. }
  570. };
  571. elem.addEventListener(type, agentFn); // 缓存代理事件
  572. AGENT_EVENTS.push({
  573. elem: elem,
  574. selector: selector,
  575. fn: fn,
  576. agentFn: agentFn
  577. });
  578. });
  579. };
  580. DomElement.prototype.off = function (type, selector, fn) {
  581. var _context5;
  582. if (!type) return this; // 没有 selector ,只有 type 和 fn
  583. if (typeof selector === 'function') {
  584. fn = selector;
  585. selector = '';
  586. }
  587. return (0, _forEach["default"])(_context5 = this).call(_context5, function (elem) {
  588. // 解绑事件代理
  589. if (selector) {
  590. var idx = -1;
  591. for (var i = 0; i < AGENT_EVENTS.length; i++) {
  592. var item = AGENT_EVENTS[i];
  593. if (item.selector === selector && item.fn === fn && item.elem === elem) {
  594. idx = i;
  595. break;
  596. }
  597. }
  598. if (idx !== -1) {
  599. var agentFn = (0, _splice["default"])(AGENT_EVENTS).call(AGENT_EVENTS, idx, 1)[0].agentFn;
  600. elem.removeEventListener(type, agentFn);
  601. }
  602. } else {
  603. // @ts-ignore
  604. elem.removeEventListener(type, fn);
  605. }
  606. });
  607. };
  608. DomElement.prototype.attr = function (key, val) {
  609. var _context6;
  610. if (val == null) {
  611. // 获取数据
  612. return this.elems[0].getAttribute(key) || '';
  613. } // 否则,设置属性
  614. return (0, _forEach["default"])(_context6 = this).call(_context6, function (elem) {
  615. elem.setAttribute(key, val);
  616. });
  617. };
  618. /**
  619. * 删除 属性
  620. * @param key key
  621. */
  622. DomElement.prototype.removeAttr = function (key) {
  623. var _context7;
  624. (0, _forEach["default"])(_context7 = this).call(_context7, function (elem) {
  625. elem.removeAttribute(key);
  626. });
  627. };
  628. /**
  629. * 添加 css class
  630. * @param className css class
  631. */
  632. DomElement.prototype.addClass = function (className) {
  633. var _context8;
  634. if (!className) {
  635. return this;
  636. }
  637. return (0, _forEach["default"])(_context8 = this).call(_context8, function (elem) {
  638. if (elem.className) {
  639. // 当前有 class
  640. var arr = elem.className.split(/\s/);
  641. arr = (0, _filter["default"])(arr).call(arr, function (item) {
  642. return !!(0, _trim["default"])(item).call(item);
  643. }); // 添加 class
  644. if ((0, _indexOf["default"])(arr).call(arr, className) < 0) {
  645. arr.push(className);
  646. } // 修改 elem.class
  647. elem.className = arr.join(' ');
  648. } else {
  649. // 当前没有 class
  650. elem.className = className;
  651. }
  652. });
  653. };
  654. /**
  655. * 添加 css class
  656. * @param className css class
  657. */
  658. DomElement.prototype.removeClass = function (className) {
  659. var _context9;
  660. if (!className) {
  661. return this;
  662. }
  663. return (0, _forEach["default"])(_context9 = this).call(_context9, function (elem) {
  664. if (!elem.className) {
  665. // 当前无 class
  666. return;
  667. }
  668. var arr = elem.className.split(/\s/);
  669. arr = (0, _filter["default"])(arr).call(arr, function (item) {
  670. item = (0, _trim["default"])(item).call(item); // 删除 class
  671. if (!item || item === className) {
  672. return false;
  673. }
  674. return true;
  675. }); // 修改 elem.class
  676. elem.className = arr.join(' ');
  677. });
  678. };
  679. /**
  680. * 是否有传入的 css class
  681. * @param className css class
  682. */
  683. DomElement.prototype.hasClass = function (className) {
  684. if (!className) {
  685. return false;
  686. }
  687. var elem = this.elems[0];
  688. if (!elem.className) {
  689. // 当前无 class
  690. return false;
  691. }
  692. var arr = elem.className.split(/\s/);
  693. return (0, _includes["default"])(arr).call(arr, className); // 是否包含
  694. };
  695. /**
  696. * 修改 css
  697. * @param key css key
  698. * @param val css value
  699. */
  700. // css(key: string): string
  701. DomElement.prototype.css = function (key, val) {
  702. var _context10;
  703. var currentStyle;
  704. if (val == '') {
  705. currentStyle = '';
  706. } else {
  707. currentStyle = key + ":" + val + ";";
  708. }
  709. return (0, _forEach["default"])(_context10 = this).call(_context10, function (elem) {
  710. var _context11;
  711. var style = (0, _trim["default"])(_context11 = elem.getAttribute('style') || '').call(_context11);
  712. if (style) {
  713. // 有 style,将 style 按照 `;` 拆分为数组
  714. var resultArr = _styleArrTrim(style); // 替换现有的 style
  715. resultArr = (0, _map["default"])(resultArr).call(resultArr, function (item) {
  716. if ((0, _indexOf["default"])(item).call(item, key) === 0) {
  717. return currentStyle;
  718. } else {
  719. return item;
  720. }
  721. }); // 新增 style
  722. if (currentStyle != '' && (0, _indexOf["default"])(resultArr).call(resultArr, currentStyle) < 0) {
  723. resultArr.push(currentStyle);
  724. } // 去掉 空白
  725. if (currentStyle == '') {
  726. resultArr = _styleArrTrim(resultArr);
  727. } // 重新设置 style
  728. elem.setAttribute('style', resultArr.join('; '));
  729. } else {
  730. // 当前没有 style
  731. elem.setAttribute('style', currentStyle);
  732. }
  733. });
  734. };
  735. /**
  736. * 封装 getBoundingClientRect
  737. */
  738. DomElement.prototype.getBoundingClientRect = function () {
  739. var elem = this.elems[0];
  740. return elem.getBoundingClientRect();
  741. };
  742. /**
  743. * 显示
  744. */
  745. DomElement.prototype.show = function () {
  746. return this.css('display', 'block');
  747. };
  748. /**
  749. * 隐藏
  750. */
  751. DomElement.prototype.hide = function () {
  752. return this.css('display', 'none');
  753. };
  754. /**
  755. * 获取子节点(只有 DOM 元素)
  756. */
  757. DomElement.prototype.children = function () {
  758. var elem = this.elems[0];
  759. if (!elem) {
  760. return null;
  761. }
  762. return $(elem.children);
  763. };
  764. /**
  765. * 获取子节点(包括文本节点)
  766. */
  767. DomElement.prototype.childNodes = function () {
  768. var elem = this.elems[0];
  769. if (!elem) {
  770. return null;
  771. }
  772. return $(elem.childNodes);
  773. };
  774. /**
  775. * 将子元素全部替换
  776. * @param $children 新的child节点
  777. */
  778. DomElement.prototype.replaceChildAll = function ($children) {
  779. var parent = this.getNode();
  780. var elem = this.elems[0];
  781. while (elem.hasChildNodes()) {
  782. parent.firstChild && elem.removeChild(parent.firstChild);
  783. }
  784. this.append($children);
  785. };
  786. /**
  787. * 增加子节点
  788. * @param $children 子节点
  789. */
  790. DomElement.prototype.append = function ($children) {
  791. var _context12;
  792. return (0, _forEach["default"])(_context12 = this).call(_context12, function (elem) {
  793. (0, _forEach["default"])($children).call($children, function (child) {
  794. elem.appendChild(child);
  795. });
  796. });
  797. };
  798. /**
  799. * 移除当前节点
  800. */
  801. DomElement.prototype.remove = function () {
  802. var _context13;
  803. return (0, _forEach["default"])(_context13 = this).call(_context13, function (elem) {
  804. if (elem.remove) {
  805. elem.remove();
  806. } else {
  807. var parent_1 = elem.parentElement;
  808. parent_1 && parent_1.removeChild(elem);
  809. }
  810. });
  811. };
  812. /**
  813. * 当前元素,是否包含某个子元素
  814. * @param $child 子元素
  815. */
  816. DomElement.prototype.isContain = function ($child) {
  817. var elem = this.elems[0];
  818. var child = $child.elems[0];
  819. return elem.contains(child);
  820. };
  821. /**
  822. * 获取当前元素 nodeName
  823. */
  824. DomElement.prototype.getNodeName = function () {
  825. var elem = this.elems[0];
  826. return elem.nodeName;
  827. };
  828. /**
  829. * 根据元素位置获取元素节点(默认获取0位置的节点)
  830. * @param n 元素节点位置
  831. */
  832. DomElement.prototype.getNode = function (n) {
  833. if (n === void 0) {
  834. n = 0;
  835. }
  836. var elem;
  837. elem = this.elems[n];
  838. return elem;
  839. };
  840. /**
  841. * 查询
  842. * @param selector css 选择器
  843. */
  844. DomElement.prototype.find = function (selector) {
  845. var elem = this.elems[0];
  846. return $(elem.querySelectorAll(selector));
  847. };
  848. DomElement.prototype.text = function (val) {
  849. if (!val) {
  850. // 获取 text
  851. var elem = this.elems[0];
  852. return elem.innerHTML.replace(/<[^>]+>/g, function () {
  853. return '';
  854. });
  855. } else {
  856. var _context14;
  857. // 设置 text
  858. return (0, _forEach["default"])(_context14 = this).call(_context14, function (elem) {
  859. elem.innerHTML = val;
  860. });
  861. }
  862. };
  863. DomElement.prototype.html = function (val) {
  864. var elem = this.elems[0];
  865. if (!val) {
  866. // 获取 html
  867. return elem.innerHTML;
  868. } else {
  869. // 设置 html
  870. elem.innerHTML = val;
  871. return this;
  872. }
  873. };
  874. /**
  875. * 获取元素 value
  876. */
  877. DomElement.prototype.val = function () {
  878. var _context15;
  879. var elem = this.elems[0];
  880. return (0, _trim["default"])(_context15 = elem.value).call(_context15); // 暂用 any
  881. };
  882. /**
  883. * focus 到当前元素
  884. */
  885. DomElement.prototype.focus = function () {
  886. var _context16;
  887. return (0, _forEach["default"])(_context16 = this).call(_context16, function (elem) {
  888. elem.focus();
  889. });
  890. };
  891. /**
  892. * 当前元素前一个兄弟节点
  893. */
  894. DomElement.prototype.prev = function () {
  895. var elem = this.elems[0];
  896. return $(elem.previousElementSibling);
  897. };
  898. /**
  899. * 当前元素后一个兄弟节点
  900. * 不包括文本节点、注释节点)
  901. */
  902. DomElement.prototype.next = function () {
  903. var elem = this.elems[0];
  904. return $(elem.nextElementSibling);
  905. };
  906. /**
  907. * 获取当前节点的下一个兄弟节点
  908. * 包括文本节点、注释节点即回车、换行、空格、文本等等)
  909. */
  910. DomElement.prototype.getNextSibling = function () {
  911. var elem = this.elems[0];
  912. return $(elem.nextSibling);
  913. };
  914. /**
  915. * 获取父元素
  916. */
  917. DomElement.prototype.parent = function () {
  918. var elem = this.elems[0];
  919. return $(elem.parentElement);
  920. };
  921. /**
  922. * 查找父元素,直到满足 selector 条件
  923. * @param selector css 选择器
  924. * @param curElem 从哪个元素开始查找,默认为当前元素
  925. */
  926. DomElement.prototype.parentUntil = function (selector, curElem) {
  927. var elem = curElem || this.elems[0];
  928. if (elem.nodeName === 'BODY') {
  929. return null;
  930. }
  931. var parent = elem.parentElement;
  932. if (parent === null) {
  933. return null;
  934. }
  935. if (parent.matches(selector)) {
  936. // 找到,并返回
  937. return $(parent);
  938. } // 继续查找,递归
  939. return this.parentUntil(selector, parent);
  940. };
  941. /**
  942. * 查找父元素,直到满足 selector 条件,或者 到达 编辑区域容器以及菜单栏容器
  943. * @param selector css 选择器
  944. * @param curElem 从哪个元素开始查找,默认为当前元素
  945. */
  946. DomElement.prototype.parentUntilEditor = function (selector, editor, curElem) {
  947. var elem = curElem || this.elems[0];
  948. if ($(elem).equal(editor.$textContainerElem) || $(elem).equal(editor.$toolbarElem)) {
  949. return null;
  950. }
  951. var parent = elem.parentElement;
  952. if (parent === null) {
  953. return null;
  954. }
  955. if (parent.matches(selector)) {
  956. // 找到,并返回
  957. return $(parent);
  958. } // 继续查找,递归
  959. return this.parentUntilEditor(selector, editor, parent);
  960. };
  961. /**
  962. * 判读是否相等
  963. * @param $elem 元素
  964. */
  965. DomElement.prototype.equal = function ($elem) {
  966. if ($elem instanceof DomElement) {
  967. return this.elems[0] === $elem.elems[0];
  968. } else if ($elem instanceof HTMLElement) {
  969. return this.elems[0] === $elem;
  970. } else {
  971. return false;
  972. }
  973. };
  974. /**
  975. * 将该元素插入到某个元素前面
  976. * @param selector css 选择器
  977. */
  978. DomElement.prototype.insertBefore = function (selector) {
  979. var _context17;
  980. var $referenceNode = $(selector);
  981. var referenceNode = $referenceNode.elems[0];
  982. if (!referenceNode) {
  983. return this;
  984. }
  985. return (0, _forEach["default"])(_context17 = this).call(_context17, function (elem) {
  986. var parent = referenceNode.parentNode;
  987. parent === null || parent === void 0 ? void 0 : parent.insertBefore(elem, referenceNode);
  988. });
  989. };
  990. /**
  991. * 将该元素插入到selector元素后面
  992. * @param selector css 选择器
  993. */
  994. DomElement.prototype.insertAfter = function (selector) {
  995. var _context18;
  996. var $referenceNode = $(selector);
  997. var referenceNode = $referenceNode.elems[0];
  998. var anchorNode = referenceNode && referenceNode.nextSibling;
  999. if (!referenceNode) {
  1000. return this;
  1001. }
  1002. return (0, _forEach["default"])(_context18 = this).call(_context18, function (elem) {
  1003. var parent = referenceNode.parentNode;
  1004. if (anchorNode) {
  1005. parent.insertBefore(elem, anchorNode);
  1006. } else {
  1007. parent.appendChild(elem);
  1008. }
  1009. });
  1010. };
  1011. /**
  1012. * 设置/获取 数据
  1013. * @param key key
  1014. * @param value value
  1015. */
  1016. DomElement.prototype.data = function (key, value) {
  1017. if (value != null) {
  1018. // 设置数据
  1019. this.dataSource.set(key, value);
  1020. } else {
  1021. // 获取数据
  1022. return this.dataSource.get(key);
  1023. }
  1024. };
  1025. /**
  1026. * 获取当前节点的顶级(段落)
  1027. * @param editor 富文本实例
  1028. */
  1029. DomElement.prototype.getNodeTop = function (editor) {
  1030. // 异常抛出,空的 DomElement 直接返回
  1031. if (this.length < 1) {
  1032. return this;
  1033. } // 获取父级元素,并判断是否是 编辑区域
  1034. // 如果是则返回当前节点
  1035. var $parent = this.parent(); // fix:添加当前元素与编辑区元素的比较,防止传入的当前元素就是编辑区元素而造成的获取顶级元素为空的情况
  1036. if (editor.$textElem.equal(this) || editor.$textElem.equal($parent)) {
  1037. return this;
  1038. } // 到了此处,即代表当前节点不是顶级段落
  1039. // 将当前节点存放于父节点的 prior 字段下
  1040. // 主要用于 回溯 子节点
  1041. // 例如:ul ol 等标签
  1042. // 实际操作的节点是 li 但是一个 ul ol 的子节点可能有多个
  1043. // 所以需要对其进行 回溯 找到对应的子节点
  1044. $parent.prior = this;
  1045. return $parent.getNodeTop(editor);
  1046. };
  1047. /**
  1048. * 获取当前 节点 基与上一个拥有相对或者解决定位的父容器的位置
  1049. * @param editor 富文本实例
  1050. */
  1051. DomElement.prototype.getOffsetData = function () {
  1052. var $node = this.elems[0];
  1053. return {
  1054. top: $node.offsetTop,
  1055. left: $node.offsetLeft,
  1056. width: $node.offsetWidth,
  1057. height: $node.offsetHeight,
  1058. parent: $node.offsetParent
  1059. };
  1060. };
  1061. /**
  1062. * 从上至下进行滚动
  1063. * @param top 滚动的值
  1064. */
  1065. DomElement.prototype.scrollTop = function (top) {
  1066. var $node = this.elems[0];
  1067. $node.scrollTo({
  1068. top: top
  1069. });
  1070. };
  1071. return DomElement;
  1072. }();
  1073. exports.DomElement = DomElement; // new 一个对象
  1074. function $() {
  1075. var arg = [];
  1076. for (var _i = 0; _i < arguments.length; _i++) {
  1077. arg[_i] = arguments[_i];
  1078. }
  1079. return new ((0, _bind["default"])(DomElement).apply(DomElement, tslib_1.__spreadArray([void 0], arg)))();
  1080. }
  1081. exports["default"] = $;
  1082. /***/ }),
  1083. /* 4 */
  1084. /***/ (function(module, exports, __webpack_require__) {
  1085. module.exports = __webpack_require__(190);
  1086. /***/ }),
  1087. /* 5 */
  1088. /***/ (function(module, exports, __webpack_require__) {
  1089. "use strict";
  1090. var global = __webpack_require__(8);
  1091. var getOwnPropertyDescriptor = __webpack_require__(77).f;
  1092. var isForced = __webpack_require__(109);
  1093. var path = __webpack_require__(11);
  1094. var bind = __webpack_require__(40);
  1095. var createNonEnumerableProperty = __webpack_require__(19);
  1096. var has = __webpack_require__(17);
  1097. var wrapConstructor = function (NativeConstructor) {
  1098. var Wrapper = function (a, b, c) {
  1099. if (this instanceof NativeConstructor) {
  1100. switch (arguments.length) {
  1101. case 0: return new NativeConstructor();
  1102. case 1: return new NativeConstructor(a);
  1103. case 2: return new NativeConstructor(a, b);
  1104. } return new NativeConstructor(a, b, c);
  1105. } return NativeConstructor.apply(this, arguments);
  1106. };
  1107. Wrapper.prototype = NativeConstructor.prototype;
  1108. return Wrapper;
  1109. };
  1110. /*
  1111. options.target - name of the target object
  1112. options.global - target is the global object
  1113. options.stat - export as static methods of target
  1114. options.proto - export as prototype methods of target
  1115. options.real - real prototype method for the `pure` version
  1116. options.forced - export even if the native feature is available
  1117. options.bind - bind methods to the target, required for the `pure` version
  1118. options.wrap - wrap constructors to preventing global pollution, required for the `pure` version
  1119. options.unsafe - use the simple assignment of property instead of delete + defineProperty
  1120. options.sham - add a flag to not completely full polyfills
  1121. options.enumerable - export as enumerable property
  1122. options.noTargetGet - prevent calling a getter on target
  1123. */
  1124. module.exports = function (options, source) {
  1125. var TARGET = options.target;
  1126. var GLOBAL = options.global;
  1127. var STATIC = options.stat;
  1128. var PROTO = options.proto;
  1129. var nativeSource = GLOBAL ? global : STATIC ? global[TARGET] : (global[TARGET] || {}).prototype;
  1130. var target = GLOBAL ? path : path[TARGET] || (path[TARGET] = {});
  1131. var targetPrototype = target.prototype;
  1132. var FORCED, USE_NATIVE, VIRTUAL_PROTOTYPE;
  1133. var key, sourceProperty, targetProperty, nativeProperty, resultProperty, descriptor;
  1134. for (key in source) {
  1135. FORCED = isForced(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);
  1136. // contains in native
  1137. USE_NATIVE = !FORCED && nativeSource && has(nativeSource, key);
  1138. targetProperty = target[key];
  1139. if (USE_NATIVE) if (options.noTargetGet) {
  1140. descriptor = getOwnPropertyDescriptor(nativeSource, key);
  1141. nativeProperty = descriptor && descriptor.value;
  1142. } else nativeProperty = nativeSource[key];
  1143. // export native or implementation
  1144. sourceProperty = (USE_NATIVE && nativeProperty) ? nativeProperty : source[key];
  1145. if (USE_NATIVE && typeof targetProperty === typeof sourceProperty) continue;
  1146. // bind timers to global for call from export context
  1147. if (options.bind && USE_NATIVE) resultProperty = bind(sourceProperty, global);
  1148. // wrap global constructors for prevent changs in this version
  1149. else if (options.wrap && USE_NATIVE) resultProperty = wrapConstructor(sourceProperty);
  1150. // make static versions for prototype methods
  1151. else if (PROTO && typeof sourceProperty == 'function') resultProperty = bind(Function.call, sourceProperty);
  1152. // default case
  1153. else resultProperty = sourceProperty;
  1154. // add a flag to not completely full polyfills
  1155. if (options.sham || (sourceProperty && sourceProperty.sham) || (targetProperty && targetProperty.sham)) {
  1156. createNonEnumerableProperty(resultProperty, 'sham', true);
  1157. }
  1158. target[key] = resultProperty;
  1159. if (PROTO) {
  1160. VIRTUAL_PROTOTYPE = TARGET + 'Prototype';
  1161. if (!has(path, VIRTUAL_PROTOTYPE)) {
  1162. createNonEnumerableProperty(path, VIRTUAL_PROTOTYPE, {});
  1163. }
  1164. // export virtual prototype methods
  1165. path[VIRTUAL_PROTOTYPE][key] = sourceProperty;
  1166. // export real prototype methods
  1167. if (options.real && targetPrototype && !targetPrototype[key]) {
  1168. createNonEnumerableProperty(targetPrototype, key, sourceProperty);
  1169. }
  1170. }
  1171. }
  1172. };
  1173. /***/ }),
  1174. /* 6 */
  1175. /***/ (function(module, exports, __webpack_require__) {
  1176. "use strict";
  1177. /**
  1178. * @description 工具函数集合
  1179. * @author wangfupeng
  1180. */
  1181. var _interopRequireDefault = __webpack_require__(0);
  1182. var _typeof2 = _interopRequireDefault(__webpack_require__(100));
  1183. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  1184. var _parseInt2 = _interopRequireDefault(__webpack_require__(271));
  1185. var _slice = _interopRequireDefault(__webpack_require__(47));
  1186. var _setTimeout2 = _interopRequireDefault(__webpack_require__(48));
  1187. var _isArray = _interopRequireDefault(__webpack_require__(96));
  1188. var _map = _interopRequireDefault(__webpack_require__(27));
  1189. (0, _defineProperty["default"])(exports, "__esModule", {
  1190. value: true
  1191. });
  1192. exports.hexToRgb = exports.getRandomCode = exports.toArray = exports.deepClone = exports.isFunction = exports.debounce = exports.throttle = exports.arrForEach = exports.forEach = exports.replaceSpecialSymbol = exports.replaceHtmlSymbol = exports.getRandom = exports.UA = void 0;
  1193. var tslib_1 = __webpack_require__(2);
  1194. var NavUA = function () {
  1195. function NavUA() {
  1196. this._ua = navigator.userAgent;
  1197. var math = this._ua.match(/(Edge?)\/(\d+)/);
  1198. this.isOldEdge = math && math[1] == 'Edge' && (0, _parseInt2["default"])(math[2]) < 19 ? true : false;
  1199. this.isFirefox = /Firefox\/\d+/.test(this._ua) && !/Seamonkey\/\d+/.test(this._ua) ? true : false;
  1200. } // 是否为 IE
  1201. NavUA.prototype.isIE = function () {
  1202. return 'ActiveXObject' in window;
  1203. }; // 是否为 webkit
  1204. NavUA.prototype.isWebkit = function () {
  1205. return /webkit/i.test(this._ua);
  1206. };
  1207. return NavUA;
  1208. }(); // 和 UA 相关的属性
  1209. exports.UA = new NavUA();
  1210. /**
  1211. * 获取随机字符
  1212. * @param prefix 前缀
  1213. */
  1214. function getRandom(prefix) {
  1215. var _context;
  1216. if (prefix === void 0) {
  1217. prefix = '';
  1218. }
  1219. return prefix + (0, _slice["default"])(_context = Math.random().toString()).call(_context, 2);
  1220. }
  1221. exports.getRandom = getRandom;
  1222. /**
  1223. * 替换 html 特殊字符
  1224. * @param html html 字符串
  1225. */
  1226. function replaceHtmlSymbol(html) {
  1227. return html.replace(/</gm, '&lt;').replace(/>/gm, '&gt;').replace(/"/gm, '&quot;').replace(/(\r\n|\r|\n)/g, '<br/>');
  1228. }
  1229. exports.replaceHtmlSymbol = replaceHtmlSymbol;
  1230. function replaceSpecialSymbol(value) {
  1231. return value.replace(/&lt;/gm, '<').replace(/&gt;/gm, '>').replace(/&quot;/gm, '"');
  1232. }
  1233. exports.replaceSpecialSymbol = replaceSpecialSymbol;
  1234. function forEach(obj, fn) {
  1235. for (var key in obj) {
  1236. if (Object.prototype.hasOwnProperty.call(obj, key)) {
  1237. var result = fn(key, obj[key]);
  1238. if (result === false) {
  1239. // 提前终止循环
  1240. break;
  1241. }
  1242. }
  1243. }
  1244. }
  1245. exports.forEach = forEach;
  1246. /**
  1247. * 遍历类数组
  1248. * @param fakeArr 类数组
  1249. * @param fn 回调函数
  1250. */
  1251. function arrForEach(fakeArr, fn) {
  1252. var i, item, result;
  1253. var length = fakeArr.length || 0;
  1254. for (i = 0; i < length; i++) {
  1255. item = fakeArr[i];
  1256. result = fn.call(fakeArr, item, i);
  1257. if (result === false) {
  1258. break;
  1259. }
  1260. }
  1261. }
  1262. exports.arrForEach = arrForEach;
  1263. /**
  1264. * 节流
  1265. * @param fn 函数
  1266. * @param interval 间隔时间,毫秒
  1267. */
  1268. function throttle(fn, interval) {
  1269. if (interval === void 0) {
  1270. interval = 200;
  1271. }
  1272. var flag = false;
  1273. return function () {
  1274. var _this = this;
  1275. var args = [];
  1276. for (var _i = 0; _i < arguments.length; _i++) {
  1277. args[_i] = arguments[_i];
  1278. }
  1279. if (!flag) {
  1280. flag = true;
  1281. (0, _setTimeout2["default"])(function () {
  1282. flag = false;
  1283. fn.call.apply(fn, tslib_1.__spreadArray([_this], args)); // this 报语法错误,先用 null
  1284. }, interval);
  1285. }
  1286. };
  1287. }
  1288. exports.throttle = throttle;
  1289. /**
  1290. * 防抖
  1291. * @param fn 函数
  1292. * @param delay 间隔时间,毫秒
  1293. */
  1294. function debounce(fn, delay) {
  1295. if (delay === void 0) {
  1296. delay = 200;
  1297. }
  1298. var lastFn = 0;
  1299. return function () {
  1300. var _this = this;
  1301. var args = [];
  1302. for (var _i = 0; _i < arguments.length; _i++) {
  1303. args[_i] = arguments[_i];
  1304. }
  1305. if (lastFn) {
  1306. window.clearTimeout(lastFn);
  1307. }
  1308. lastFn = (0, _setTimeout2["default"])(function () {
  1309. lastFn = 0;
  1310. fn.call.apply(fn, tslib_1.__spreadArray([_this], args)); // this 报语法错误,先用 null
  1311. }, delay);
  1312. };
  1313. }
  1314. exports.debounce = debounce;
  1315. /**
  1316. * isFunction 是否是函数
  1317. * @param fn 函数
  1318. */
  1319. function isFunction(fn) {
  1320. return typeof fn === 'function';
  1321. }
  1322. exports.isFunction = isFunction;
  1323. /**
  1324. * 引用与非引用值 深拷贝方法
  1325. * @param data
  1326. */
  1327. function deepClone(data) {
  1328. if ((0, _typeof2["default"])(data) !== 'object' || typeof data == 'function' || data === null) {
  1329. return data;
  1330. }
  1331. var item;
  1332. if ((0, _isArray["default"])(data)) {
  1333. item = [];
  1334. }
  1335. if (!(0, _isArray["default"])(data)) {
  1336. item = {};
  1337. }
  1338. for (var i in data) {
  1339. if (Object.prototype.hasOwnProperty.call(data, i)) {
  1340. item[i] = deepClone(data[i]);
  1341. }
  1342. }
  1343. return item;
  1344. }
  1345. exports.deepClone = deepClone;
  1346. /**
  1347. * 将可遍历的对象转换为数组
  1348. * @param data 可遍历的对象
  1349. */
  1350. function toArray(data) {
  1351. return (0, _slice["default"])(Array.prototype).call(data);
  1352. }
  1353. exports.toArray = toArray;
  1354. /**
  1355. * 唯一id生成
  1356. * @param length 随机数长度
  1357. */
  1358. function getRandomCode() {
  1359. var _context2;
  1360. return (0, _slice["default"])(_context2 = Math.random().toString(36)).call(_context2, -5);
  1361. }
  1362. exports.getRandomCode = getRandomCode;
  1363. /**
  1364. * hex color 转换成 rgb
  1365. * @param hex string
  1366. */
  1367. function hexToRgb(hex) {
  1368. var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
  1369. if (result == null) return null;
  1370. var colors = (0, _map["default"])(result).call(result, function (i) {
  1371. return (0, _parseInt2["default"])(i, 16);
  1372. });
  1373. var r = colors[1];
  1374. var g = colors[2];
  1375. var b = colors[3];
  1376. return "rgb(" + r + ", " + g + ", " + b + ")";
  1377. }
  1378. exports.hexToRgb = hexToRgb;
  1379. /***/ }),
  1380. /* 7 */
  1381. /***/ (function(module, exports, __webpack_require__) {
  1382. "use strict";
  1383. /**
  1384. * @description 常量
  1385. * @author wangfupeng
  1386. */
  1387. var _interopRequireDefault = __webpack_require__(0);
  1388. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  1389. (0, _defineProperty["default"])(exports, "__esModule", {
  1390. value: true
  1391. });
  1392. exports.EMPTY_P_REGEX = exports.EMPTY_P_LAST_REGEX = exports.EMPTY_P = exports.urlRegex = exports.EMPTY_FN = void 0;
  1393. function EMPTY_FN() {}
  1394. exports.EMPTY_FN = EMPTY_FN; //用于校验是否为url格式字符串
  1395. exports.urlRegex = /^(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-.,@?^=%&amp;:/~+#]*[\w\-@?^=%&amp;/~+#])?/; // 编辑器为了方便继续输入/换行等原因 主动生成的空标签
  1396. exports.EMPTY_P = '<p data-we-empty-p=""><br></p>'; // 用于校验dom中最后 由编辑器主动生成的空标签结构
  1397. exports.EMPTY_P_LAST_REGEX = /<p data-we-empty-p=""><br\/?><\/p>$/gim; // 用于校验dom中所有 由编辑器主动生成的空标签结构
  1398. exports.EMPTY_P_REGEX = /<p data-we-empty-p="">/gim;
  1399. /***/ }),
  1400. /* 8 */
  1401. /***/ (function(module, exports, __webpack_require__) {
  1402. /* WEBPACK VAR INJECTION */(function(global) {var check = function (it) {
  1403. return it && it.Math == Math && it;
  1404. };
  1405. // https://github.com/zloirock/core-js/issues/86#issuecomment-115759028
  1406. module.exports =
  1407. // eslint-disable-next-line es/no-global-this -- safe
  1408. check(typeof globalThis == 'object' && globalThis) ||
  1409. check(typeof window == 'object' && window) ||
  1410. // eslint-disable-next-line no-restricted-globals -- safe
  1411. check(typeof self == 'object' && self) ||
  1412. check(typeof global == 'object' && global) ||
  1413. // eslint-disable-next-line no-new-func -- fallback
  1414. (function () { return this; })() || Function('return this')();
  1415. /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(150)))
  1416. /***/ }),
  1417. /* 9 */
  1418. /***/ (function(module, exports, __webpack_require__) {
  1419. var global = __webpack_require__(8);
  1420. var shared = __webpack_require__(80);
  1421. var has = __webpack_require__(17);
  1422. var uid = __webpack_require__(67);
  1423. var NATIVE_SYMBOL = __webpack_require__(79);
  1424. var USE_SYMBOL_AS_UID = __webpack_require__(107);
  1425. var WellKnownSymbolsStore = shared('wks');
  1426. var Symbol = global.Symbol;
  1427. var createWellKnownSymbol = USE_SYMBOL_AS_UID ? Symbol : Symbol && Symbol.withoutSetter || uid;
  1428. module.exports = function (name) {
  1429. if (!has(WellKnownSymbolsStore, name) || !(NATIVE_SYMBOL || typeof WellKnownSymbolsStore[name] == 'string')) {
  1430. if (NATIVE_SYMBOL && has(Symbol, name)) {
  1431. WellKnownSymbolsStore[name] = Symbol[name];
  1432. } else {
  1433. WellKnownSymbolsStore[name] = createWellKnownSymbol('Symbol.' + name);
  1434. }
  1435. } return WellKnownSymbolsStore[name];
  1436. };
  1437. /***/ }),
  1438. /* 10 */
  1439. /***/ (function(module, exports, __webpack_require__) {
  1440. var path = __webpack_require__(11);
  1441. var has = __webpack_require__(17);
  1442. var wrappedWellKnownSymbolModule = __webpack_require__(101);
  1443. var defineProperty = __webpack_require__(18).f;
  1444. module.exports = function (NAME) {
  1445. var Symbol = path.Symbol || (path.Symbol = {});
  1446. if (!has(Symbol, NAME)) defineProperty(Symbol, NAME, {
  1447. value: wrappedWellKnownSymbolModule.f(NAME)
  1448. });
  1449. };
  1450. /***/ }),
  1451. /* 11 */
  1452. /***/ (function(module, exports) {
  1453. module.exports = {};
  1454. /***/ }),
  1455. /* 12 */
  1456. /***/ (function(module, exports) {
  1457. module.exports = function (exec) {
  1458. try {
  1459. return !!exec();
  1460. } catch (error) {
  1461. return true;
  1462. }
  1463. };
  1464. /***/ }),
  1465. /* 13 */
  1466. /***/ (function(module, exports) {
  1467. module.exports = function (it) {
  1468. return typeof it === 'object' ? it !== null : typeof it === 'function';
  1469. };
  1470. /***/ }),
  1471. /* 14 */
  1472. /***/ (function(module, exports, __webpack_require__) {
  1473. var path = __webpack_require__(11);
  1474. module.exports = function (CONSTRUCTOR) {
  1475. return path[CONSTRUCTOR + 'Prototype'];
  1476. };
  1477. /***/ }),
  1478. /* 15 */
  1479. /***/ (function(module, exports, __webpack_require__) {
  1480. var fails = __webpack_require__(12);
  1481. // Detect IE8's incomplete defineProperty implementation
  1482. module.exports = !fails(function () {
  1483. // eslint-disable-next-line es/no-object-defineproperty -- required for testing
  1484. return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] != 7;
  1485. });
  1486. /***/ }),
  1487. /* 16 */
  1488. /***/ (function(module, exports, __webpack_require__) {
  1489. module.exports = __webpack_require__(203);
  1490. /***/ }),
  1491. /* 17 */
  1492. /***/ (function(module, exports, __webpack_require__) {
  1493. var toObject = __webpack_require__(26);
  1494. var hasOwnProperty = {}.hasOwnProperty;
  1495. module.exports = Object.hasOwn || function hasOwn(it, key) {
  1496. return hasOwnProperty.call(toObject(it), key);
  1497. };
  1498. /***/ }),
  1499. /* 18 */
  1500. /***/ (function(module, exports, __webpack_require__) {
  1501. var DESCRIPTORS = __webpack_require__(15);
  1502. var IE8_DOM_DEFINE = __webpack_require__(108);
  1503. var anObject = __webpack_require__(20);
  1504. var toPropertyKey = __webpack_require__(64);
  1505. // eslint-disable-next-line es/no-object-defineproperty -- safe
  1506. var $defineProperty = Object.defineProperty;
  1507. // `Object.defineProperty` method
  1508. // https://tc39.es/ecma262/#sec-object.defineproperty
  1509. exports.f = DESCRIPTORS ? $defineProperty : function defineProperty(O, P, Attributes) {
  1510. anObject(O);
  1511. P = toPropertyKey(P);
  1512. anObject(Attributes);
  1513. if (IE8_DOM_DEFINE) try {
  1514. return $defineProperty(O, P, Attributes);
  1515. } catch (error) { /* empty */ }
  1516. if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported');
  1517. if ('value' in Attributes) O[P] = Attributes.value;
  1518. return O;
  1519. };
  1520. /***/ }),
  1521. /* 19 */
  1522. /***/ (function(module, exports, __webpack_require__) {
  1523. var DESCRIPTORS = __webpack_require__(15);
  1524. var definePropertyModule = __webpack_require__(18);
  1525. var createPropertyDescriptor = __webpack_require__(38);
  1526. module.exports = DESCRIPTORS ? function (object, key, value) {
  1527. return definePropertyModule.f(object, key, createPropertyDescriptor(1, value));
  1528. } : function (object, key, value) {
  1529. object[key] = value;
  1530. return object;
  1531. };
  1532. /***/ }),
  1533. /* 20 */
  1534. /***/ (function(module, exports, __webpack_require__) {
  1535. var isObject = __webpack_require__(13);
  1536. module.exports = function (it) {
  1537. if (!isObject(it)) {
  1538. throw TypeError(String(it) + ' is not an object');
  1539. } return it;
  1540. };
  1541. /***/ }),
  1542. /* 21 */
  1543. /***/ (function(module, exports, __webpack_require__) {
  1544. "use strict";
  1545. var isOldIE = function isOldIE() {
  1546. var memo;
  1547. return function memorize() {
  1548. if (typeof memo === 'undefined') {
  1549. // Test for IE <= 9 as proposed by Browserhacks
  1550. // @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805
  1551. // Tests for existence of standard globals is to allow style-loader
  1552. // to operate correctly into non-standard environments
  1553. // @see https://github.com/webpack-contrib/style-loader/issues/177
  1554. memo = Boolean(window && document && document.all && !window.atob);
  1555. }
  1556. return memo;
  1557. };
  1558. }();
  1559. var getTarget = function getTarget() {
  1560. var memo = {};
  1561. return function memorize(target) {
  1562. if (typeof memo[target] === 'undefined') {
  1563. var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself
  1564. if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {
  1565. try {
  1566. // This will throw an exception if access to iframe is blocked
  1567. // due to cross-origin restrictions
  1568. styleTarget = styleTarget.contentDocument.head;
  1569. } catch (e) {
  1570. // istanbul ignore next
  1571. styleTarget = null;
  1572. }
  1573. }
  1574. memo[target] = styleTarget;
  1575. }
  1576. return memo[target];
  1577. };
  1578. }();
  1579. var stylesInDom = [];
  1580. function getIndexByIdentifier(identifier) {
  1581. var result = -1;
  1582. for (var i = 0; i < stylesInDom.length; i++) {
  1583. if (stylesInDom[i].identifier === identifier) {
  1584. result = i;
  1585. break;
  1586. }
  1587. }
  1588. return result;
  1589. }
  1590. function modulesToDom(list, options) {
  1591. var idCountMap = {};
  1592. var identifiers = [];
  1593. for (var i = 0; i < list.length; i++) {
  1594. var item = list[i];
  1595. var id = options.base ? item[0] + options.base : item[0];
  1596. var count = idCountMap[id] || 0;
  1597. var identifier = "".concat(id, " ").concat(count);
  1598. idCountMap[id] = count + 1;
  1599. var index = getIndexByIdentifier(identifier);
  1600. var obj = {
  1601. css: item[1],
  1602. media: item[2],
  1603. sourceMap: item[3]
  1604. };
  1605. if (index !== -1) {
  1606. stylesInDom[index].references++;
  1607. stylesInDom[index].updater(obj);
  1608. } else {
  1609. stylesInDom.push({
  1610. identifier: identifier,
  1611. updater: addStyle(obj, options),
  1612. references: 1
  1613. });
  1614. }
  1615. identifiers.push(identifier);
  1616. }
  1617. return identifiers;
  1618. }
  1619. function insertStyleElement(options) {
  1620. var style = document.createElement('style');
  1621. var attributes = options.attributes || {};
  1622. if (typeof attributes.nonce === 'undefined') {
  1623. var nonce = true ? __webpack_require__.nc : undefined;
  1624. if (nonce) {
  1625. attributes.nonce = nonce;
  1626. }
  1627. }
  1628. Object.keys(attributes).forEach(function (key) {
  1629. style.setAttribute(key, attributes[key]);
  1630. });
  1631. if (typeof options.insert === 'function') {
  1632. options.insert(style);
  1633. } else {
  1634. var target = getTarget(options.insert || 'head');
  1635. if (!target) {
  1636. throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");
  1637. }
  1638. target.appendChild(style);
  1639. }
  1640. return style;
  1641. }
  1642. function removeStyleElement(style) {
  1643. // istanbul ignore if
  1644. if (style.parentNode === null) {
  1645. return false;
  1646. }
  1647. style.parentNode.removeChild(style);
  1648. }
  1649. /* istanbul ignore next */
  1650. var replaceText = function replaceText() {
  1651. var textStore = [];
  1652. return function replace(index, replacement) {
  1653. textStore[index] = replacement;
  1654. return textStore.filter(Boolean).join('\n');
  1655. };
  1656. }();
  1657. function applyToSingletonTag(style, index, remove, obj) {
  1658. var css = remove ? '' : obj.media ? "@media ".concat(obj.media, " {").concat(obj.css, "}") : obj.css; // For old IE
  1659. /* istanbul ignore if */
  1660. if (style.styleSheet) {
  1661. style.styleSheet.cssText = replaceText(index, css);
  1662. } else {
  1663. var cssNode = document.createTextNode(css);
  1664. var childNodes = style.childNodes;
  1665. if (childNodes[index]) {
  1666. style.removeChild(childNodes[index]);
  1667. }
  1668. if (childNodes.length) {
  1669. style.insertBefore(cssNode, childNodes[index]);
  1670. } else {
  1671. style.appendChild(cssNode);
  1672. }
  1673. }
  1674. }
  1675. function applyToTag(style, options, obj) {
  1676. var css = obj.css;
  1677. var media = obj.media;
  1678. var sourceMap = obj.sourceMap;
  1679. if (media) {
  1680. style.setAttribute('media', media);
  1681. } else {
  1682. style.removeAttribute('media');
  1683. }
  1684. if (sourceMap && typeof btoa !== 'undefined') {
  1685. css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */");
  1686. } // For old IE
  1687. /* istanbul ignore if */
  1688. if (style.styleSheet) {
  1689. style.styleSheet.cssText = css;
  1690. } else {
  1691. while (style.firstChild) {
  1692. style.removeChild(style.firstChild);
  1693. }
  1694. style.appendChild(document.createTextNode(css));
  1695. }
  1696. }
  1697. var singleton = null;
  1698. var singletonCounter = 0;
  1699. function addStyle(obj, options) {
  1700. var style;
  1701. var update;
  1702. var remove;
  1703. if (options.singleton) {
  1704. var styleIndex = singletonCounter++;
  1705. style = singleton || (singleton = insertStyleElement(options));
  1706. update = applyToSingletonTag.bind(null, style, styleIndex, false);
  1707. remove = applyToSingletonTag.bind(null, style, styleIndex, true);
  1708. } else {
  1709. style = insertStyleElement(options);
  1710. update = applyToTag.bind(null, style, options);
  1711. remove = function remove() {
  1712. removeStyleElement(style);
  1713. };
  1714. }
  1715. update(obj);
  1716. return function updateStyle(newObj) {
  1717. if (newObj) {
  1718. if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) {
  1719. return;
  1720. }
  1721. update(obj = newObj);
  1722. } else {
  1723. remove();
  1724. }
  1725. };
  1726. }
  1727. module.exports = function (list, options) {
  1728. options = options || {}; // Force single-tag solution on IE6-9, which has a hard limit on the # of <style>
  1729. // tags it will allow on a page
  1730. if (!options.singleton && typeof options.singleton !== 'boolean') {
  1731. options.singleton = isOldIE();
  1732. }
  1733. list = list || [];
  1734. var lastIdentifiers = modulesToDom(list, options);
  1735. return function update(newList) {
  1736. newList = newList || [];
  1737. if (Object.prototype.toString.call(newList) !== '[object Array]') {
  1738. return;
  1739. }
  1740. for (var i = 0; i < lastIdentifiers.length; i++) {
  1741. var identifier = lastIdentifiers[i];
  1742. var index = getIndexByIdentifier(identifier);
  1743. stylesInDom[index].references--;
  1744. }
  1745. var newLastIdentifiers = modulesToDom(newList, options);
  1746. for (var _i = 0; _i < lastIdentifiers.length; _i++) {
  1747. var _identifier = lastIdentifiers[_i];
  1748. var _index = getIndexByIdentifier(_identifier);
  1749. if (stylesInDom[_index].references === 0) {
  1750. stylesInDom[_index].updater();
  1751. stylesInDom.splice(_index, 1);
  1752. }
  1753. }
  1754. lastIdentifiers = newLastIdentifiers;
  1755. };
  1756. };
  1757. /***/ }),
  1758. /* 22 */
  1759. /***/ (function(module, exports, __webpack_require__) {
  1760. "use strict";
  1761. /*
  1762. MIT License http://www.opensource.org/licenses/mit-license.php
  1763. Author Tobias Koppers @sokra
  1764. */
  1765. // css base code, injected by the css-loader
  1766. // eslint-disable-next-line func-names
  1767. module.exports = function (useSourceMap) {
  1768. var list = []; // return the list of modules as css string
  1769. list.toString = function toString() {
  1770. return this.map(function (item) {
  1771. var content = cssWithMappingToString(item, useSourceMap);
  1772. if (item[2]) {
  1773. return "@media ".concat(item[2], " {").concat(content, "}");
  1774. }
  1775. return content;
  1776. }).join('');
  1777. }; // import a list of modules into the list
  1778. // eslint-disable-next-line func-names
  1779. list.i = function (modules, mediaQuery, dedupe) {
  1780. if (typeof modules === 'string') {
  1781. // eslint-disable-next-line no-param-reassign
  1782. modules = [[null, modules, '']];
  1783. }
  1784. var alreadyImportedModules = {};
  1785. if (dedupe) {
  1786. for (var i = 0; i < this.length; i++) {
  1787. // eslint-disable-next-line prefer-destructuring
  1788. var id = this[i][0];
  1789. if (id != null) {
  1790. alreadyImportedModules[id] = true;
  1791. }
  1792. }
  1793. }
  1794. for (var _i = 0; _i < modules.length; _i++) {
  1795. var item = [].concat(modules[_i]);
  1796. if (dedupe && alreadyImportedModules[item[0]]) {
  1797. // eslint-disable-next-line no-continue
  1798. continue;
  1799. }
  1800. if (mediaQuery) {
  1801. if (!item[2]) {
  1802. item[2] = mediaQuery;
  1803. } else {
  1804. item[2] = "".concat(mediaQuery, " and ").concat(item[2]);
  1805. }
  1806. }
  1807. list.push(item);
  1808. }
  1809. };
  1810. return list;
  1811. };
  1812. function cssWithMappingToString(item, useSourceMap) {
  1813. var content = item[1] || ''; // eslint-disable-next-line prefer-destructuring
  1814. var cssMapping = item[3];
  1815. if (!cssMapping) {
  1816. return content;
  1817. }
  1818. if (useSourceMap && typeof btoa === 'function') {
  1819. var sourceMapping = toComment(cssMapping);
  1820. var sourceURLs = cssMapping.sources.map(function (source) {
  1821. return "/*# sourceURL=".concat(cssMapping.sourceRoot || '').concat(source, " */");
  1822. });
  1823. return [content].concat(sourceURLs).concat([sourceMapping]).join('\n');
  1824. }
  1825. return [content].join('\n');
  1826. } // Adapted from convert-source-map (MIT)
  1827. function toComment(sourceMap) {
  1828. // eslint-disable-next-line no-undef
  1829. var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));
  1830. var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64);
  1831. return "/*# ".concat(data, " */");
  1832. }
  1833. /***/ }),
  1834. /* 23 */
  1835. /***/ (function(module, exports, __webpack_require__) {
  1836. "use strict";
  1837. /**
  1838. * @description 按钮菜单 Class
  1839. * @author wangfupeng
  1840. */
  1841. var _interopRequireDefault = __webpack_require__(0);
  1842. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  1843. (0, _defineProperty["default"])(exports, "__esModule", {
  1844. value: true
  1845. });
  1846. var tslib_1 = __webpack_require__(2);
  1847. var Menu_1 = tslib_1.__importDefault(__webpack_require__(103));
  1848. var BtnMenu = function (_super) {
  1849. tslib_1.__extends(BtnMenu, _super);
  1850. function BtnMenu($elem, editor) {
  1851. return _super.call(this, $elem, editor) || this;
  1852. }
  1853. return BtnMenu;
  1854. }(Menu_1["default"]);
  1855. exports["default"] = BtnMenu;
  1856. /***/ }),
  1857. /* 24 */
  1858. /***/ (function(module, exports, __webpack_require__) {
  1859. "use strict";
  1860. /**
  1861. * @description 下拉菜单 Class
  1862. * @author wangfupeng
  1863. */
  1864. var _interopRequireDefault = __webpack_require__(0);
  1865. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  1866. var _forEach = _interopRequireDefault(__webpack_require__(4));
  1867. var _setTimeout2 = _interopRequireDefault(__webpack_require__(48));
  1868. (0, _defineProperty["default"])(exports, "__esModule", {
  1869. value: true
  1870. });
  1871. var tslib_1 = __webpack_require__(2);
  1872. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  1873. var Menu_1 = tslib_1.__importDefault(__webpack_require__(103));
  1874. var DropList_1 = tslib_1.__importDefault(__webpack_require__(138));
  1875. var DropListMenu = function (_super) {
  1876. tslib_1.__extends(DropListMenu, _super);
  1877. function DropListMenu($elem, editor, conf) {
  1878. var _this = _super.call(this, $elem, editor) || this; // 国际化
  1879. conf.title = editor.i18next.t("menus.dropListMenu." + conf.title); // 非中文模式下 带 icon 的下拉列表居左
  1880. var className = editor.config.lang === 'zh-CN' ? '' : 'w-e-drop-list-tl';
  1881. if (className !== '' && conf.type === 'list') {
  1882. var _context;
  1883. (0, _forEach["default"])(_context = conf.list).call(_context, function (item) {
  1884. var $elem = item.$elem;
  1885. var $children = dom_core_1["default"]($elem.children());
  1886. if ($children.length > 0) {
  1887. var nodeName = $children === null || $children === void 0 ? void 0 : $children.getNodeName();
  1888. if (nodeName && nodeName === 'I') {
  1889. $elem.addClass(className);
  1890. }
  1891. }
  1892. });
  1893. } // 初始化 dropList
  1894. var dropList = new DropList_1["default"](_this, conf);
  1895. _this.dropList = dropList; // 绑定事件
  1896. $elem.on('click', function () {
  1897. var _context2;
  1898. if (editor.selection.getRange() == null) {
  1899. return;
  1900. }
  1901. $elem.css('z-index', editor.zIndex.get('menu')); // 触发 droplist 悬浮事件
  1902. (0, _forEach["default"])(_context2 = editor.txt.eventHooks.dropListMenuHoverEvents).call(_context2, function (fn) {
  1903. return fn();
  1904. }); // 显示
  1905. dropList.show();
  1906. }).on('mouseleave', function () {
  1907. $elem.css('z-index', 'auto'); // 隐藏
  1908. dropList.hideTimeoutId = (0, _setTimeout2["default"])(function () {
  1909. dropList.hide();
  1910. });
  1911. });
  1912. return _this;
  1913. }
  1914. return DropListMenu;
  1915. }(Menu_1["default"]);
  1916. exports["default"] = DropListMenu;
  1917. /***/ }),
  1918. /* 25 */
  1919. /***/ (function(module, exports, __webpack_require__) {
  1920. var path = __webpack_require__(11);
  1921. var global = __webpack_require__(8);
  1922. var aFunction = function (variable) {
  1923. return typeof variable == 'function' ? variable : undefined;
  1924. };
  1925. module.exports = function (namespace, method) {
  1926. return arguments.length < 2 ? aFunction(path[namespace]) || aFunction(global[namespace])
  1927. : path[namespace] && path[namespace][method] || global[namespace] && global[namespace][method];
  1928. };
  1929. /***/ }),
  1930. /* 26 */
  1931. /***/ (function(module, exports, __webpack_require__) {
  1932. var requireObjectCoercible = __webpack_require__(51);
  1933. // `ToObject` abstract operation
  1934. // https://tc39.es/ecma262/#sec-toobject
  1935. module.exports = function (argument) {
  1936. return Object(requireObjectCoercible(argument));
  1937. };
  1938. /***/ }),
  1939. /* 27 */
  1940. /***/ (function(module, exports, __webpack_require__) {
  1941. module.exports = __webpack_require__(199);
  1942. /***/ }),
  1943. /* 28 */
  1944. /***/ (function(module, exports, __webpack_require__) {
  1945. module.exports = __webpack_require__(212);
  1946. /***/ }),
  1947. /* 29 */
  1948. /***/ (function(module, exports, __webpack_require__) {
  1949. // toObject with fallback for non-array-like ES3 strings
  1950. var IndexedObject = __webpack_require__(78);
  1951. var requireObjectCoercible = __webpack_require__(51);
  1952. module.exports = function (it) {
  1953. return IndexedObject(requireObjectCoercible(it));
  1954. };
  1955. /***/ }),
  1956. /* 30 */
  1957. /***/ (function(module, exports, __webpack_require__) {
  1958. var isSymbol = __webpack_require__(65);
  1959. module.exports = function (argument) {
  1960. if (isSymbol(argument)) throw TypeError('Cannot convert a Symbol value to a string');
  1961. return String(argument);
  1962. };
  1963. /***/ }),
  1964. /* 31 */
  1965. /***/ (function(module, exports, __webpack_require__) {
  1966. var bind = __webpack_require__(40);
  1967. var IndexedObject = __webpack_require__(78);
  1968. var toObject = __webpack_require__(26);
  1969. var toLength = __webpack_require__(35);
  1970. var arraySpeciesCreate = __webpack_require__(95);
  1971. var push = [].push;
  1972. // `Array.prototype.{ forEach, map, filter, some, every, find, findIndex, filterReject }` methods implementation
  1973. var createMethod = function (TYPE) {
  1974. var IS_MAP = TYPE == 1;
  1975. var IS_FILTER = TYPE == 2;
  1976. var IS_SOME = TYPE == 3;
  1977. var IS_EVERY = TYPE == 4;
  1978. var IS_FIND_INDEX = TYPE == 6;
  1979. var IS_FILTER_REJECT = TYPE == 7;
  1980. var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;
  1981. return function ($this, callbackfn, that, specificCreate) {
  1982. var O = toObject($this);
  1983. var self = IndexedObject(O);
  1984. var boundFunction = bind(callbackfn, that, 3);
  1985. var length = toLength(self.length);
  1986. var index = 0;
  1987. var create = specificCreate || arraySpeciesCreate;
  1988. var target = IS_MAP ? create($this, length) : IS_FILTER || IS_FILTER_REJECT ? create($this, 0) : undefined;
  1989. var value, result;
  1990. for (;length > index; index++) if (NO_HOLES || index in self) {
  1991. value = self[index];
  1992. result = boundFunction(value, index, O);
  1993. if (TYPE) {
  1994. if (IS_MAP) target[index] = result; // map
  1995. else if (result) switch (TYPE) {
  1996. case 3: return true; // some
  1997. case 5: return value; // find
  1998. case 6: return index; // findIndex
  1999. case 2: push.call(target, value); // filter
  2000. } else switch (TYPE) {
  2001. case 4: return false; // every
  2002. case 7: push.call(target, value); // filterReject
  2003. }
  2004. }
  2005. }
  2006. return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target;
  2007. };
  2008. };
  2009. module.exports = {
  2010. // `Array.prototype.forEach` method
  2011. // https://tc39.es/ecma262/#sec-array.prototype.foreach
  2012. forEach: createMethod(0),
  2013. // `Array.prototype.map` method
  2014. // https://tc39.es/ecma262/#sec-array.prototype.map
  2015. map: createMethod(1),
  2016. // `Array.prototype.filter` method
  2017. // https://tc39.es/ecma262/#sec-array.prototype.filter
  2018. filter: createMethod(2),
  2019. // `Array.prototype.some` method
  2020. // https://tc39.es/ecma262/#sec-array.prototype.some
  2021. some: createMethod(3),
  2022. // `Array.prototype.every` method
  2023. // https://tc39.es/ecma262/#sec-array.prototype.every
  2024. every: createMethod(4),
  2025. // `Array.prototype.find` method
  2026. // https://tc39.es/ecma262/#sec-array.prototype.find
  2027. find: createMethod(5),
  2028. // `Array.prototype.findIndex` method
  2029. // https://tc39.es/ecma262/#sec-array.prototype.findIndex
  2030. findIndex: createMethod(6),
  2031. // `Array.prototype.filterReject` method
  2032. // https://github.com/tc39/proposal-array-filtering
  2033. filterReject: createMethod(7)
  2034. };
  2035. /***/ }),
  2036. /* 32 */
  2037. /***/ (function(module, exports, __webpack_require__) {
  2038. module.exports = __webpack_require__(298);
  2039. /***/ }),
  2040. /* 33 */
  2041. /***/ (function(module, exports, __webpack_require__) {
  2042. "use strict";
  2043. /**
  2044. * @description panel class
  2045. * @author wangfupeng
  2046. */
  2047. var _interopRequireDefault = __webpack_require__(0);
  2048. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  2049. var _forEach = _interopRequireDefault(__webpack_require__(4));
  2050. var _find = _interopRequireDefault(__webpack_require__(32));
  2051. var _set = _interopRequireDefault(__webpack_require__(136));
  2052. (0, _defineProperty["default"])(exports, "__esModule", {
  2053. value: true
  2054. });
  2055. var tslib_1 = __webpack_require__(2);
  2056. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  2057. var const_1 = __webpack_require__(7);
  2058. var Panel = function () {
  2059. function Panel(menu, conf) {
  2060. this.menu = menu;
  2061. this.conf = conf;
  2062. this.$container = dom_core_1["default"]('<div class="w-e-panel-container"></div>'); // 隐藏 panel
  2063. var editor = menu.editor;
  2064. editor.txt.eventHooks.clickEvents.push(Panel.hideCurAllPanels);
  2065. editor.txt.eventHooks.toolbarClickEvents.push(Panel.hideCurAllPanels);
  2066. editor.txt.eventHooks.dropListMenuHoverEvents.push(Panel.hideCurAllPanels);
  2067. }
  2068. /**
  2069. * 创建并展示 panel
  2070. */
  2071. Panel.prototype.create = function () {
  2072. var _this = this;
  2073. var menu = this.menu;
  2074. if (Panel.createdMenus.has(menu)) {
  2075. // 创建过了
  2076. return;
  2077. }
  2078. var conf = this.conf; // panel 的容器
  2079. var $container = this.$container;
  2080. var width = conf.width || 300; // 默认 300px
  2081. var rect = menu.editor.$toolbarElem.getBoundingClientRect();
  2082. var menuRect = menu.$elem.getBoundingClientRect();
  2083. var top = rect.height + rect.top - menuRect.top;
  2084. var left = (rect.width - width) / 2 + rect.left - menuRect.left;
  2085. var offset = 300; // icon与panel菜单距离偏移量暂定 300
  2086. if (Math.abs(left) > offset) {
  2087. // panel菜单离工具栏icon过远时,让panel菜单出现在icon正下方,处理边界逻辑
  2088. if (menuRect.left < document.documentElement.clientWidth / 2) {
  2089. // icon在左侧
  2090. left = -menuRect.width / 2;
  2091. } else {
  2092. // icon在右侧
  2093. left = -width + menuRect.width / 2;
  2094. }
  2095. }
  2096. $container.css('width', width + 'px').css('margin-top', top + "px").css('margin-left', left + "px").css('z-index', menu.editor.zIndex.get('panel')); // 添加关闭按钮
  2097. var $closeBtn = dom_core_1["default"]('<i class="w-e-icon-close w-e-panel-close"></i>');
  2098. $container.append($closeBtn);
  2099. $closeBtn.on('click', function () {
  2100. _this.remove();
  2101. }); // 准备 tabs 容器
  2102. var $tabTitleContainer = dom_core_1["default"]('<ul class="w-e-panel-tab-title"></ul>');
  2103. var $tabContentContainer = dom_core_1["default"]('<div class="w-e-panel-tab-content"></div>');
  2104. $container.append($tabTitleContainer).append($tabContentContainer); // 设置高度
  2105. var height = conf.height; // height: 0 即不用设置
  2106. if (height) {
  2107. $tabContentContainer.css('height', height + 'px').css('overflow-y', 'auto');
  2108. } // tabs
  2109. var tabs = conf.tabs || [];
  2110. var tabTitleArr = [];
  2111. var tabContentArr = [];
  2112. (0, _forEach["default"])(tabs).call(tabs, function (tab, tabIndex) {
  2113. if (!tab) {
  2114. return;
  2115. }
  2116. var title = tab.title || '';
  2117. var tpl = tab.tpl || ''; // 添加到 DOM
  2118. var $title = dom_core_1["default"]("<li class=\"w-e-item\">" + title + "</li>");
  2119. $tabTitleContainer.append($title);
  2120. var $content = dom_core_1["default"](tpl);
  2121. $tabContentContainer.append($content); // 记录到内存
  2122. tabTitleArr.push($title);
  2123. tabContentArr.push($content); // 设置 active 项
  2124. if (tabIndex === 0) {
  2125. $title.data('active', true);
  2126. $title.addClass('w-e-active');
  2127. } else {
  2128. $content.hide();
  2129. } // 绑定 tab 的事件
  2130. $title.on('click', function () {
  2131. if ($title.data('active')) {
  2132. return;
  2133. } // 隐藏所有的 tab
  2134. (0, _forEach["default"])(tabTitleArr).call(tabTitleArr, function ($title) {
  2135. $title.data('active', false);
  2136. $title.removeClass('w-e-active');
  2137. });
  2138. (0, _forEach["default"])(tabContentArr).call(tabContentArr, function ($content) {
  2139. $content.hide();
  2140. }); // 显示当前的 tab
  2141. $title.data('active', true);
  2142. $title.addClass('w-e-active');
  2143. $content.show();
  2144. });
  2145. }); // 绑定关闭事件
  2146. $container.on('click', function (e) {
  2147. // 点击时阻止冒泡
  2148. e.stopPropagation();
  2149. }); // 添加到 DOM
  2150. menu.$elem.append($container); // 绑定 conf events 的事件,只有添加到 DOM 之后才能绑定成功
  2151. (0, _forEach["default"])(tabs).call(tabs, function (tab, index) {
  2152. if (!tab) {
  2153. return;
  2154. }
  2155. var events = tab.events || [];
  2156. (0, _forEach["default"])(events).call(events, function (event) {
  2157. var _a;
  2158. var selector = event.selector;
  2159. var type = event.type;
  2160. var fn = event.fn || const_1.EMPTY_FN;
  2161. var $content = tabContentArr[index];
  2162. var bindEnter = (_a = event.bindEnter) !== null && _a !== void 0 ? _a : false;
  2163. var doneFn = function doneFn(e) {
  2164. return tslib_1.__awaiter(_this, void 0, void 0, function () {
  2165. var needToHide;
  2166. return tslib_1.__generator(this, function (_a) {
  2167. switch (_a.label) {
  2168. case 0:
  2169. e.stopPropagation();
  2170. return [4
  2171. /*yield*/
  2172. , fn(e) // 执行完事件之后,是否要关闭 panel
  2173. ];
  2174. case 1:
  2175. needToHide = _a.sent(); // 执行完事件之后,是否要关闭 panel
  2176. if (needToHide) {
  2177. this.remove();
  2178. }
  2179. return [2
  2180. /*return*/
  2181. ];
  2182. }
  2183. });
  2184. });
  2185. }; // 给按钮绑定相应的事件
  2186. (0, _find["default"])($content).call($content, selector).on(type, doneFn); // 绑定enter键入事件
  2187. if (bindEnter && type === 'click') {
  2188. $content.on('keyup', function (e) {
  2189. if (e.keyCode == 13) {
  2190. doneFn(e);
  2191. }
  2192. });
  2193. }
  2194. });
  2195. }); // focus 第一个 elem
  2196. var $inputs = (0, _find["default"])($container).call($container, 'input[type=text],textarea');
  2197. if ($inputs.length) {
  2198. $inputs.get(0).focus();
  2199. } // 隐藏其他 panel
  2200. Panel.hideCurAllPanels(); // 记录该 menu 已经创建了 panel
  2201. menu.setPanel(this);
  2202. Panel.createdMenus.add(menu);
  2203. };
  2204. /**
  2205. * 移除 penal
  2206. */
  2207. Panel.prototype.remove = function () {
  2208. var menu = this.menu;
  2209. var $container = this.$container;
  2210. if ($container) {
  2211. $container.remove();
  2212. } // 将该 menu 记录中移除
  2213. Panel.createdMenus["delete"](menu);
  2214. };
  2215. /**
  2216. * 隐藏当前所有的 panel
  2217. */
  2218. Panel.hideCurAllPanels = function () {
  2219. var _context;
  2220. if (Panel.createdMenus.size === 0) {
  2221. return;
  2222. }
  2223. (0, _forEach["default"])(_context = Panel.createdMenus).call(_context, function (menu) {
  2224. var panel = menu.panel;
  2225. panel && panel.remove();
  2226. });
  2227. }; // 记录已经创建过的 panelMenu
  2228. Panel.createdMenus = new _set["default"]();
  2229. return Panel;
  2230. }();
  2231. exports["default"] = Panel;
  2232. /***/ }),
  2233. /* 34 */
  2234. /***/ (function(module, exports) {
  2235. module.exports = function (it) {
  2236. if (typeof it != 'function') {
  2237. throw TypeError(String(it) + ' is not a function');
  2238. } return it;
  2239. };
  2240. /***/ }),
  2241. /* 35 */
  2242. /***/ (function(module, exports, __webpack_require__) {
  2243. var toInteger = __webpack_require__(70);
  2244. var min = Math.min;
  2245. // `ToLength` abstract operation
  2246. // https://tc39.es/ecma262/#sec-tolength
  2247. module.exports = function (argument) {
  2248. return argument > 0 ? min(toInteger(argument), 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991
  2249. };
  2250. /***/ }),
  2251. /* 36 */
  2252. /***/ (function(module, exports, __webpack_require__) {
  2253. "use strict";
  2254. /**
  2255. * @description Modal 菜单 Class
  2256. * @author wangfupeng
  2257. */
  2258. var _interopRequireDefault = __webpack_require__(0);
  2259. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  2260. (0, _defineProperty["default"])(exports, "__esModule", {
  2261. value: true
  2262. });
  2263. var tslib_1 = __webpack_require__(2);
  2264. var Menu_1 = tslib_1.__importDefault(__webpack_require__(103));
  2265. var PanelMenu = function (_super) {
  2266. tslib_1.__extends(PanelMenu, _super);
  2267. function PanelMenu($elem, editor) {
  2268. return _super.call(this, $elem, editor) || this;
  2269. }
  2270. /**
  2271. * 给 menu 设置 panel
  2272. * @param panel panel 实例
  2273. */
  2274. PanelMenu.prototype.setPanel = function (panel) {
  2275. this.panel = panel;
  2276. };
  2277. return PanelMenu;
  2278. }(Menu_1["default"]);
  2279. exports["default"] = PanelMenu;
  2280. /***/ }),
  2281. /* 37 */
  2282. /***/ (function(module, exports, __webpack_require__) {
  2283. "use strict";
  2284. /**
  2285. * @description Tooltip class
  2286. * @author wangfupeng
  2287. */
  2288. var _interopRequireDefault = __webpack_require__(0);
  2289. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  2290. var _forEach = _interopRequireDefault(__webpack_require__(4));
  2291. var _bind = _interopRequireDefault(__webpack_require__(61));
  2292. (0, _defineProperty["default"])(exports, "__esModule", {
  2293. value: true
  2294. });
  2295. var tslib_1 = __webpack_require__(2);
  2296. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  2297. var Tooltip = function () {
  2298. function Tooltip(editor, $elem, conf) {
  2299. this.editor = editor;
  2300. this.$targetElem = $elem;
  2301. this.conf = conf;
  2302. this._show = false;
  2303. this._isInsertTextContainer = false; // 定义 container
  2304. var $container = dom_core_1["default"]('<div></div>');
  2305. $container.addClass('w-e-tooltip');
  2306. this.$container = $container;
  2307. }
  2308. /**
  2309. * 获取 tooltip 定位
  2310. */
  2311. Tooltip.prototype.getPositionData = function () {
  2312. var $container = this.$container;
  2313. var top = 0;
  2314. var left = 0; // tooltip 的高度
  2315. var tooltipHeight = 20; // 网页的 scrollTop
  2316. var pageScrollTop = document.documentElement.scrollTop; // 目标元素的 rect
  2317. var targetElemRect = this.$targetElem.getBoundingClientRect(); // 编辑区域的 rect
  2318. var textElemRect = this.editor.$textElem.getBoundingClientRect(); // 获取基于 textContainerElem 的 位置信息
  2319. var targetOffset = this.$targetElem.getOffsetData();
  2320. var targetParentElem = dom_core_1["default"](targetOffset.parent); // 获取 编辑区域的滚动条信息
  2321. var scrollTop = this.editor.$textElem.elems[0].scrollTop; // 是否插入 textContainer 中
  2322. this._isInsertTextContainer = targetParentElem.equal(this.editor.$textContainerElem);
  2323. if (this._isInsertTextContainer) {
  2324. // 父容器的高度
  2325. var targetParentElemHeight = targetParentElem.getBoundingClientRect().height; // 相对于父容器的位置信息
  2326. var offsetTop = targetOffset.top,
  2327. offsetLeft = targetOffset.left,
  2328. offsetHeight = targetOffset.height; // 元素基于父容器的 绝对top信息
  2329. var absoluteTop = offsetTop - scrollTop;
  2330. if (absoluteTop > tooltipHeight + 5) {
  2331. // 说明模板元素的顶部空间足够
  2332. top = absoluteTop - tooltipHeight - 15;
  2333. $container.addClass('w-e-tooltip-up');
  2334. } else if (absoluteTop + offsetHeight + tooltipHeight < targetParentElemHeight) {
  2335. // 说明模板元素的底部空间足够
  2336. top = absoluteTop + offsetHeight + 10;
  2337. $container.addClass('w-e-tooltip-down');
  2338. } else {
  2339. // 其他情况,tooltip 放在目标元素左上角
  2340. top = (absoluteTop > 0 ? absoluteTop : 0) + tooltipHeight + 10;
  2341. $container.addClass('w-e-tooltip-down');
  2342. } // 计算 left
  2343. if (offsetLeft < 0) {
  2344. left = 0;
  2345. } else {
  2346. left = offsetLeft;
  2347. }
  2348. } else {
  2349. if (targetElemRect.top < tooltipHeight) {
  2350. // 说明目标元素的顶部,因滑动隐藏在浏览器上方。tooltip 要放在目标元素下面
  2351. top = targetElemRect.bottom + pageScrollTop + 5; // 5px 间距
  2352. $container.addClass('w-e-tooltip-down');
  2353. } else if (targetElemRect.top - textElemRect.top < tooltipHeight) {
  2354. // 说明目标元素的顶部,因滑动隐藏在编辑区域上方。tooltip 要放在目标元素下面
  2355. top = targetElemRect.bottom + pageScrollTop + 5; // 5px 间距
  2356. $container.addClass('w-e-tooltip-down');
  2357. } else {
  2358. // 其他情况,tooltip 放在目标元素上方
  2359. top = targetElemRect.top + pageScrollTop - tooltipHeight - 15; // 减去 toolbar 的高度,还有 15px 间距
  2360. $container.addClass('w-e-tooltip-up');
  2361. } // 计算 left
  2362. if (targetElemRect.left < 0) {
  2363. left = 0;
  2364. } else {
  2365. left = targetElemRect.left;
  2366. }
  2367. } // 返回结果
  2368. return {
  2369. top: top,
  2370. left: left
  2371. };
  2372. };
  2373. /**
  2374. * 添加 tooltip 菜单
  2375. */
  2376. Tooltip.prototype.appendMenus = function () {
  2377. var _this = this;
  2378. var conf = this.conf;
  2379. var editor = this.editor;
  2380. var $targetElem = this.$targetElem;
  2381. var $container = this.$container;
  2382. (0, _forEach["default"])(conf).call(conf, function (item, index) {
  2383. // 添加元素
  2384. var $elem = item.$elem;
  2385. var $wrapper = dom_core_1["default"]('<div></div>');
  2386. $wrapper.addClass('w-e-tooltip-item-wrapper ');
  2387. $wrapper.append($elem);
  2388. $container.append($wrapper); // 绑定点击事件
  2389. $elem.on('click', function (e) {
  2390. e.preventDefault();
  2391. var res = item.onClick(editor, $targetElem);
  2392. if (res) _this.remove();
  2393. });
  2394. });
  2395. };
  2396. /**
  2397. * 创建 tooltip
  2398. */
  2399. Tooltip.prototype.create = function () {
  2400. var _context, _context2;
  2401. var editor = this.editor;
  2402. var $container = this.$container; // 生成 container 的内容
  2403. this.appendMenus(); // 设置定位
  2404. var _a = this.getPositionData(),
  2405. top = _a.top,
  2406. left = _a.left;
  2407. $container.css('top', top + "px");
  2408. $container.css('left', left + "px"); // 设置 z-index
  2409. $container.css('z-index', editor.zIndex.get('tooltip')); // 添加到 DOM
  2410. if (this._isInsertTextContainer) {
  2411. this.editor.$textContainerElem.append($container);
  2412. } else {
  2413. dom_core_1["default"]('body').append($container);
  2414. }
  2415. this._show = true;
  2416. editor.beforeDestroy((0, _bind["default"])(_context = this.remove).call(_context, this));
  2417. editor.txt.eventHooks.onBlurEvents.push((0, _bind["default"])(_context2 = this.remove).call(_context2, this));
  2418. };
  2419. /**
  2420. * 移除该 tooltip
  2421. */
  2422. Tooltip.prototype.remove = function () {
  2423. this.$container.remove();
  2424. this._show = false;
  2425. };
  2426. (0, _defineProperty["default"])(Tooltip.prototype, "isShow", {
  2427. /**
  2428. * 是否显示
  2429. */
  2430. get: function get() {
  2431. return this._show;
  2432. },
  2433. enumerable: false,
  2434. configurable: true
  2435. });
  2436. return Tooltip;
  2437. }();
  2438. exports["default"] = Tooltip;
  2439. /***/ }),
  2440. /* 38 */
  2441. /***/ (function(module, exports) {
  2442. module.exports = function (bitmap, value) {
  2443. return {
  2444. enumerable: !(bitmap & 1),
  2445. configurable: !(bitmap & 2),
  2446. writable: !(bitmap & 4),
  2447. value: value
  2448. };
  2449. };
  2450. /***/ }),
  2451. /* 39 */
  2452. /***/ (function(module, exports) {
  2453. module.exports = true;
  2454. /***/ }),
  2455. /* 40 */
  2456. /***/ (function(module, exports, __webpack_require__) {
  2457. var aFunction = __webpack_require__(34);
  2458. // optional / simple context binding
  2459. module.exports = function (fn, that, length) {
  2460. aFunction(fn);
  2461. if (that === undefined) return fn;
  2462. switch (length) {
  2463. case 0: return function () {
  2464. return fn.call(that);
  2465. };
  2466. case 1: return function (a) {
  2467. return fn.call(that, a);
  2468. };
  2469. case 2: return function (a, b) {
  2470. return fn.call(that, a, b);
  2471. };
  2472. case 3: return function (a, b, c) {
  2473. return fn.call(that, a, b, c);
  2474. };
  2475. }
  2476. return function (/* ...args */) {
  2477. return fn.apply(that, arguments);
  2478. };
  2479. };
  2480. /***/ }),
  2481. /* 41 */
  2482. /***/ (function(module, exports, __webpack_require__) {
  2483. var anObject = __webpack_require__(20);
  2484. var isArrayIteratorMethod = __webpack_require__(112);
  2485. var toLength = __webpack_require__(35);
  2486. var bind = __webpack_require__(40);
  2487. var getIteratorMethod = __webpack_require__(113);
  2488. var iteratorClose = __webpack_require__(114);
  2489. var Result = function (stopped, result) {
  2490. this.stopped = stopped;
  2491. this.result = result;
  2492. };
  2493. module.exports = function (iterable, unboundFunction, options) {
  2494. var that = options && options.that;
  2495. var AS_ENTRIES = !!(options && options.AS_ENTRIES);
  2496. var IS_ITERATOR = !!(options && options.IS_ITERATOR);
  2497. var INTERRUPTED = !!(options && options.INTERRUPTED);
  2498. var fn = bind(unboundFunction, that, 1 + AS_ENTRIES + INTERRUPTED);
  2499. var iterator, iterFn, index, length, result, next, step;
  2500. var stop = function (condition) {
  2501. if (iterator) iteratorClose(iterator);
  2502. return new Result(true, condition);
  2503. };
  2504. var callFn = function (value) {
  2505. if (AS_ENTRIES) {
  2506. anObject(value);
  2507. return INTERRUPTED ? fn(value[0], value[1], stop) : fn(value[0], value[1]);
  2508. } return INTERRUPTED ? fn(value, stop) : fn(value);
  2509. };
  2510. if (IS_ITERATOR) {
  2511. iterator = iterable;
  2512. } else {
  2513. iterFn = getIteratorMethod(iterable);
  2514. if (typeof iterFn != 'function') throw TypeError('Target is not iterable');
  2515. // optimisation for array iterators
  2516. if (isArrayIteratorMethod(iterFn)) {
  2517. for (index = 0, length = toLength(iterable.length); length > index; index++) {
  2518. result = callFn(iterable[index]);
  2519. if (result && result instanceof Result) return result;
  2520. } return new Result(false);
  2521. }
  2522. iterator = iterFn.call(iterable);
  2523. }
  2524. next = iterator.next;
  2525. while (!(step = next.call(iterator)).done) {
  2526. try {
  2527. result = callFn(step.value);
  2528. } catch (error) {
  2529. iteratorClose(iterator);
  2530. throw error;
  2531. }
  2532. if (typeof result == 'object' && result && result instanceof Result) return result;
  2533. } return new Result(false);
  2534. };
  2535. /***/ }),
  2536. /* 42 */
  2537. /***/ (function(module, exports) {
  2538. module.exports = {};
  2539. /***/ }),
  2540. /* 43 */
  2541. /***/ (function(module, exports, __webpack_require__) {
  2542. var NATIVE_WEAK_MAP = __webpack_require__(176);
  2543. var global = __webpack_require__(8);
  2544. var isObject = __webpack_require__(13);
  2545. var createNonEnumerableProperty = __webpack_require__(19);
  2546. var objectHas = __webpack_require__(17);
  2547. var shared = __webpack_require__(81);
  2548. var sharedKey = __webpack_require__(68);
  2549. var hiddenKeys = __webpack_require__(54);
  2550. var OBJECT_ALREADY_INITIALIZED = 'Object already initialized';
  2551. var WeakMap = global.WeakMap;
  2552. var set, get, has;
  2553. var enforce = function (it) {
  2554. return has(it) ? get(it) : set(it, {});
  2555. };
  2556. var getterFor = function (TYPE) {
  2557. return function (it) {
  2558. var state;
  2559. if (!isObject(it) || (state = get(it)).type !== TYPE) {
  2560. throw TypeError('Incompatible receiver, ' + TYPE + ' required');
  2561. } return state;
  2562. };
  2563. };
  2564. if (NATIVE_WEAK_MAP || shared.state) {
  2565. var store = shared.state || (shared.state = new WeakMap());
  2566. var wmget = store.get;
  2567. var wmhas = store.has;
  2568. var wmset = store.set;
  2569. set = function (it, metadata) {
  2570. if (wmhas.call(store, it)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);
  2571. metadata.facade = it;
  2572. wmset.call(store, it, metadata);
  2573. return metadata;
  2574. };
  2575. get = function (it) {
  2576. return wmget.call(store, it) || {};
  2577. };
  2578. has = function (it) {
  2579. return wmhas.call(store, it);
  2580. };
  2581. } else {
  2582. var STATE = sharedKey('state');
  2583. hiddenKeys[STATE] = true;
  2584. set = function (it, metadata) {
  2585. if (objectHas(it, STATE)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);
  2586. metadata.facade = it;
  2587. createNonEnumerableProperty(it, STATE, metadata);
  2588. return metadata;
  2589. };
  2590. get = function (it) {
  2591. return objectHas(it, STATE) ? it[STATE] : {};
  2592. };
  2593. has = function (it) {
  2594. return objectHas(it, STATE);
  2595. };
  2596. }
  2597. module.exports = {
  2598. set: set,
  2599. get: get,
  2600. has: has,
  2601. enforce: enforce,
  2602. getterFor: getterFor
  2603. };
  2604. /***/ }),
  2605. /* 44 */
  2606. /***/ (function(module, exports, __webpack_require__) {
  2607. var TO_STRING_TAG_SUPPORT = __webpack_require__(88);
  2608. var defineProperty = __webpack_require__(18).f;
  2609. var createNonEnumerableProperty = __webpack_require__(19);
  2610. var has = __webpack_require__(17);
  2611. var toString = __webpack_require__(178);
  2612. var wellKnownSymbol = __webpack_require__(9);
  2613. var TO_STRING_TAG = wellKnownSymbol('toStringTag');
  2614. module.exports = function (it, TAG, STATIC, SET_METHOD) {
  2615. if (it) {
  2616. var target = STATIC ? it : it.prototype;
  2617. if (!has(target, TO_STRING_TAG)) {
  2618. defineProperty(target, TO_STRING_TAG, { configurable: true, value: TAG });
  2619. }
  2620. if (SET_METHOD && !TO_STRING_TAG_SUPPORT) {
  2621. createNonEnumerableProperty(target, 'toString', toString);
  2622. }
  2623. }
  2624. };
  2625. /***/ }),
  2626. /* 45 */
  2627. /***/ (function(module, exports, __webpack_require__) {
  2628. __webpack_require__(55);
  2629. var DOMIterables = __webpack_require__(189);
  2630. var global = __webpack_require__(8);
  2631. var classof = __webpack_require__(71);
  2632. var createNonEnumerableProperty = __webpack_require__(19);
  2633. var Iterators = __webpack_require__(42);
  2634. var wellKnownSymbol = __webpack_require__(9);
  2635. var TO_STRING_TAG = wellKnownSymbol('toStringTag');
  2636. for (var COLLECTION_NAME in DOMIterables) {
  2637. var Collection = global[COLLECTION_NAME];
  2638. var CollectionPrototype = Collection && Collection.prototype;
  2639. if (CollectionPrototype && classof(CollectionPrototype) !== TO_STRING_TAG) {
  2640. createNonEnumerableProperty(CollectionPrototype, TO_STRING_TAG, COLLECTION_NAME);
  2641. }
  2642. Iterators[COLLECTION_NAME] = Iterators.Array;
  2643. }
  2644. /***/ }),
  2645. /* 46 */
  2646. /***/ (function(module, exports, __webpack_require__) {
  2647. module.exports = __webpack_require__(224);
  2648. /***/ }),
  2649. /* 47 */
  2650. /***/ (function(module, exports, __webpack_require__) {
  2651. module.exports = __webpack_require__(276);
  2652. /***/ }),
  2653. /* 48 */
  2654. /***/ (function(module, exports, __webpack_require__) {
  2655. module.exports = __webpack_require__(280);
  2656. /***/ }),
  2657. /* 49 */
  2658. /***/ (function(module, exports, __webpack_require__) {
  2659. "use strict";
  2660. var _interopRequireDefault = __webpack_require__(0);
  2661. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  2662. var _forEach = _interopRequireDefault(__webpack_require__(4));
  2663. (0, _defineProperty["default"])(exports, "__esModule", {
  2664. value: true
  2665. });
  2666. exports.createElementFragment = exports.createDocumentFragment = exports.createElement = exports.insertBefore = exports.getEndPoint = exports.getStartPoint = exports.updateRange = exports.filterSelectionNodes = void 0;
  2667. var tslib_1 = __webpack_require__(2);
  2668. var _1 = __webpack_require__(142);
  2669. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  2670. /**
  2671. * 过滤 选择的 node 节点
  2672. * @returns { DomElement[] } DomElement[]
  2673. */
  2674. function filterSelectionNodes($nodes) {
  2675. var $listHtml = [];
  2676. (0, _forEach["default"])($nodes).call($nodes, function ($node) {
  2677. var targerName = $node.getNodeName();
  2678. if (targerName !== _1.ListType.OrderedList && targerName !== _1.ListType.UnorderedList) {
  2679. // 非序列
  2680. $listHtml.push($node);
  2681. } else {
  2682. // 序列
  2683. if ($node.prior) {
  2684. $listHtml.push($node.prior);
  2685. } else {
  2686. var $children = $node.children();
  2687. $children === null || $children === void 0 ? void 0 : (0, _forEach["default"])($children).call($children, function ($li) {
  2688. $listHtml.push(dom_core_1["default"]($li));
  2689. });
  2690. }
  2691. }
  2692. });
  2693. return $listHtml;
  2694. }
  2695. exports.filterSelectionNodes = filterSelectionNodes;
  2696. /**
  2697. * 更新选区
  2698. * @param $node
  2699. */
  2700. function updateRange(editor, $node, collapsed) {
  2701. var selection = editor.selection;
  2702. var range = document.createRange(); // ===============================
  2703. // length 大于 1
  2704. // 代表着转换是一个文档节点多段落
  2705. // ===============================
  2706. if ($node.length > 1) {
  2707. range.setStart($node.elems[0], 0);
  2708. range.setEnd($node.elems[$node.length - 1], $node.elems[$node.length - 1].childNodes.length);
  2709. } // ===============================
  2710. // 序列节点 或 单段落
  2711. // ===============================
  2712. else {
  2713. range.selectNodeContents($node.elems[0]);
  2714. } // ===============================
  2715. // collapsed 为 true 代表是光标
  2716. // ===============================
  2717. collapsed && range.collapse(false);
  2718. selection.saveRange(range);
  2719. selection.restoreSelection();
  2720. }
  2721. exports.updateRange = updateRange;
  2722. /**
  2723. * 获取起点元素
  2724. * @param $startElem 开始序列节点
  2725. */
  2726. function getStartPoint($startElem) {
  2727. var _a;
  2728. return $startElem.prior ? $startElem.prior // 有 prior 代表不是全选序列
  2729. : dom_core_1["default"]((_a = $startElem.children()) === null || _a === void 0 ? void 0 : _a.elems[0]); // 没有则代表全选序列
  2730. }
  2731. exports.getStartPoint = getStartPoint;
  2732. /**
  2733. * 获取结束元素
  2734. * @param $endElem 结束序列节点
  2735. */
  2736. function getEndPoint($endElem) {
  2737. var _a;
  2738. return $endElem.prior ? $endElem.prior // 有 prior 代表不是全选序列
  2739. : dom_core_1["default"]((_a = $endElem.children()) === null || _a === void 0 ? void 0 : _a.last().elems[0]); // 没有则代表全选序列
  2740. }
  2741. exports.getEndPoint = getEndPoint;
  2742. /**
  2743. * 在您指定节点的已有子节点之前插入新的子节点。
  2744. * @param { DomElement } $node 指定节点
  2745. * @param { ContainerFragment } newNode 插入的新子节点
  2746. * @param { Node | null } existingNode 指定子节点
  2747. */
  2748. function insertBefore($node, newNode, existingNode) {
  2749. if (existingNode === void 0) {
  2750. existingNode = null;
  2751. }
  2752. $node.parent().elems[0].insertBefore(newNode, existingNode);
  2753. }
  2754. exports.insertBefore = insertBefore;
  2755. /**
  2756. * 创建指定的 element 对象
  2757. */
  2758. function createElement(target) {
  2759. return document.createElement(target);
  2760. }
  2761. exports.createElement = createElement;
  2762. /**
  2763. * 创建文档片段
  2764. */
  2765. function createDocumentFragment() {
  2766. return document.createDocumentFragment();
  2767. }
  2768. exports.createDocumentFragment = createDocumentFragment;
  2769. /**
  2770. * 生成 li 标签的元素,并返回 $fragment 文档片段
  2771. * @param { DomElement[] } $nodes 需要转换成 li 的 dom 元素数组
  2772. * @param { ContainerFragment } $fragment 用于存储生成后 li 元素的文档片段
  2773. */
  2774. function createElementFragment($nodes, $fragment, tag) {
  2775. if (tag === void 0) {
  2776. tag = 'li';
  2777. }
  2778. (0, _forEach["default"])($nodes).call($nodes, function ($node) {
  2779. var $list = createElement(tag);
  2780. $list.innerHTML = $node.html();
  2781. $fragment.appendChild($list);
  2782. $node.remove();
  2783. });
  2784. return $fragment;
  2785. }
  2786. exports.createElementFragment = createElementFragment;
  2787. /***/ }),
  2788. /* 50 */
  2789. /***/ (function(module, exports) {
  2790. var toString = {}.toString;
  2791. module.exports = function (it) {
  2792. return toString.call(it).slice(8, -1);
  2793. };
  2794. /***/ }),
  2795. /* 51 */
  2796. /***/ (function(module, exports) {
  2797. // `RequireObjectCoercible` abstract operation
  2798. // https://tc39.es/ecma262/#sec-requireobjectcoercible
  2799. module.exports = function (it) {
  2800. if (it == undefined) throw TypeError("Can't call method on " + it);
  2801. return it;
  2802. };
  2803. /***/ }),
  2804. /* 52 */
  2805. /***/ (function(module, exports, __webpack_require__) {
  2806. var getBuiltIn = __webpack_require__(25);
  2807. module.exports = getBuiltIn('navigator', 'userAgent') || '';
  2808. /***/ }),
  2809. /* 53 */
  2810. /***/ (function(module, exports, __webpack_require__) {
  2811. var internalObjectKeys = __webpack_require__(110);
  2812. var enumBugKeys = __webpack_require__(87);
  2813. // `Object.keys` method
  2814. // https://tc39.es/ecma262/#sec-object.keys
  2815. // eslint-disable-next-line es/no-object-keys -- safe
  2816. module.exports = Object.keys || function keys(O) {
  2817. return internalObjectKeys(O, enumBugKeys);
  2818. };
  2819. /***/ }),
  2820. /* 54 */
  2821. /***/ (function(module, exports) {
  2822. module.exports = {};
  2823. /***/ }),
  2824. /* 55 */
  2825. /***/ (function(module, exports, __webpack_require__) {
  2826. "use strict";
  2827. var toIndexedObject = __webpack_require__(29);
  2828. var addToUnscopables = __webpack_require__(89);
  2829. var Iterators = __webpack_require__(42);
  2830. var InternalStateModule = __webpack_require__(43);
  2831. var defineIterator = __webpack_require__(90);
  2832. var ARRAY_ITERATOR = 'Array Iterator';
  2833. var setInternalState = InternalStateModule.set;
  2834. var getInternalState = InternalStateModule.getterFor(ARRAY_ITERATOR);
  2835. // `Array.prototype.entries` method
  2836. // https://tc39.es/ecma262/#sec-array.prototype.entries
  2837. // `Array.prototype.keys` method
  2838. // https://tc39.es/ecma262/#sec-array.prototype.keys
  2839. // `Array.prototype.values` method
  2840. // https://tc39.es/ecma262/#sec-array.prototype.values
  2841. // `Array.prototype[@@iterator]` method
  2842. // https://tc39.es/ecma262/#sec-array.prototype-@@iterator
  2843. // `CreateArrayIterator` internal method
  2844. // https://tc39.es/ecma262/#sec-createarrayiterator
  2845. module.exports = defineIterator(Array, 'Array', function (iterated, kind) {
  2846. setInternalState(this, {
  2847. type: ARRAY_ITERATOR,
  2848. target: toIndexedObject(iterated), // target
  2849. index: 0, // next index
  2850. kind: kind // kind
  2851. });
  2852. // `%ArrayIteratorPrototype%.next` method
  2853. // https://tc39.es/ecma262/#sec-%arrayiteratorprototype%.next
  2854. }, function () {
  2855. var state = getInternalState(this);
  2856. var target = state.target;
  2857. var kind = state.kind;
  2858. var index = state.index++;
  2859. if (!target || index >= target.length) {
  2860. state.target = undefined;
  2861. return { value: undefined, done: true };
  2862. }
  2863. if (kind == 'keys') return { value: index, done: false };
  2864. if (kind == 'values') return { value: target[index], done: false };
  2865. return { value: [index, target[index]], done: false };
  2866. }, 'values');
  2867. // argumentsList[@@iterator] is %ArrayProto_values%
  2868. // https://tc39.es/ecma262/#sec-createunmappedargumentsobject
  2869. // https://tc39.es/ecma262/#sec-createmappedargumentsobject
  2870. Iterators.Arguments = Iterators.Array;
  2871. // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables
  2872. addToUnscopables('keys');
  2873. addToUnscopables('values');
  2874. addToUnscopables('entries');
  2875. /***/ }),
  2876. /* 56 */
  2877. /***/ (function(module, exports, __webpack_require__) {
  2878. var createNonEnumerableProperty = __webpack_require__(19);
  2879. module.exports = function (target, key, value, options) {
  2880. if (options && options.enumerable) target[key] = value;
  2881. else createNonEnumerableProperty(target, key, value);
  2882. };
  2883. /***/ }),
  2884. /* 57 */
  2885. /***/ (function(module, exports) {
  2886. // empty
  2887. /***/ }),
  2888. /* 58 */
  2889. /***/ (function(module, exports, __webpack_require__) {
  2890. "use strict";
  2891. var charAt = __webpack_require__(188).charAt;
  2892. var toString = __webpack_require__(30);
  2893. var InternalStateModule = __webpack_require__(43);
  2894. var defineIterator = __webpack_require__(90);
  2895. var STRING_ITERATOR = 'String Iterator';
  2896. var setInternalState = InternalStateModule.set;
  2897. var getInternalState = InternalStateModule.getterFor(STRING_ITERATOR);
  2898. // `String.prototype[@@iterator]` method
  2899. // https://tc39.es/ecma262/#sec-string.prototype-@@iterator
  2900. defineIterator(String, 'String', function (iterated) {
  2901. setInternalState(this, {
  2902. type: STRING_ITERATOR,
  2903. string: toString(iterated),
  2904. index: 0
  2905. });
  2906. // `%StringIteratorPrototype%.next` method
  2907. // https://tc39.es/ecma262/#sec-%stringiteratorprototype%.next
  2908. }, function next() {
  2909. var state = getInternalState(this);
  2910. var string = state.string;
  2911. var index = state.index;
  2912. var point;
  2913. if (index >= string.length) return { value: undefined, done: true };
  2914. point = charAt(string, index);
  2915. state.index += point.length;
  2916. return { value: point, done: false };
  2917. });
  2918. /***/ }),
  2919. /* 59 */
  2920. /***/ (function(module, exports, __webpack_require__) {
  2921. var classof = __webpack_require__(50);
  2922. // `IsArray` abstract operation
  2923. // https://tc39.es/ecma262/#sec-isarray
  2924. // eslint-disable-next-line es/no-array-isarray -- safe
  2925. module.exports = Array.isArray || function isArray(arg) {
  2926. return classof(arg) == 'Array';
  2927. };
  2928. /***/ }),
  2929. /* 60 */
  2930. /***/ (function(module, exports, __webpack_require__) {
  2931. var fails = __webpack_require__(12);
  2932. var wellKnownSymbol = __webpack_require__(9);
  2933. var V8_VERSION = __webpack_require__(66);
  2934. var SPECIES = wellKnownSymbol('species');
  2935. module.exports = function (METHOD_NAME) {
  2936. // We can't use this feature detection in V8 since it causes
  2937. // deoptimization and serious performance degradation
  2938. // https://github.com/zloirock/core-js/issues/677
  2939. return V8_VERSION >= 51 || !fails(function () {
  2940. var array = [];
  2941. var constructor = array.constructor = {};
  2942. constructor[SPECIES] = function () {
  2943. return { foo: 1 };
  2944. };
  2945. return array[METHOD_NAME](Boolean).foo !== 1;
  2946. });
  2947. };
  2948. /***/ }),
  2949. /* 61 */
  2950. /***/ (function(module, exports, __webpack_require__) {
  2951. module.exports = __webpack_require__(233);
  2952. /***/ }),
  2953. /* 62 */
  2954. /***/ (function(module, exports, __webpack_require__) {
  2955. "use strict";
  2956. var _interopRequireDefault = __webpack_require__(0);
  2957. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  2958. (0, _defineProperty["default"])(exports, "__esModule", {
  2959. value: true
  2960. });
  2961. exports.ListHandle = void 0;
  2962. var tslib_1 = __webpack_require__(2);
  2963. var SelectionRangeElem_1 = tslib_1.__importDefault(__webpack_require__(388));
  2964. var ListHandle = function () {
  2965. function ListHandle(options) {
  2966. this.options = options;
  2967. this.selectionRangeElem = new SelectionRangeElem_1["default"]();
  2968. }
  2969. return ListHandle;
  2970. }();
  2971. exports.ListHandle = ListHandle;
  2972. /***/ }),
  2973. /* 63 */
  2974. /***/ (function(module, exports, __webpack_require__) {
  2975. "use strict";
  2976. var $propertyIsEnumerable = {}.propertyIsEnumerable;
  2977. // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe
  2978. var getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
  2979. // Nashorn ~ JDK8 bug
  2980. var NASHORN_BUG = getOwnPropertyDescriptor && !$propertyIsEnumerable.call({ 1: 2 }, 1);
  2981. // `Object.prototype.propertyIsEnumerable` method implementation
  2982. // https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable
  2983. exports.f = NASHORN_BUG ? function propertyIsEnumerable(V) {
  2984. var descriptor = getOwnPropertyDescriptor(this, V);
  2985. return !!descriptor && descriptor.enumerable;
  2986. } : $propertyIsEnumerable;
  2987. /***/ }),
  2988. /* 64 */
  2989. /***/ (function(module, exports, __webpack_require__) {
  2990. var toPrimitive = __webpack_require__(151);
  2991. var isSymbol = __webpack_require__(65);
  2992. // `ToPropertyKey` abstract operation
  2993. // https://tc39.es/ecma262/#sec-topropertykey
  2994. module.exports = function (argument) {
  2995. var key = toPrimitive(argument, 'string');
  2996. return isSymbol(key) ? key : String(key);
  2997. };
  2998. /***/ }),
  2999. /* 65 */
  3000. /***/ (function(module, exports, __webpack_require__) {
  3001. var getBuiltIn = __webpack_require__(25);
  3002. var USE_SYMBOL_AS_UID = __webpack_require__(107);
  3003. module.exports = USE_SYMBOL_AS_UID ? function (it) {
  3004. return typeof it == 'symbol';
  3005. } : function (it) {
  3006. var $Symbol = getBuiltIn('Symbol');
  3007. return typeof $Symbol == 'function' && Object(it) instanceof $Symbol;
  3008. };
  3009. /***/ }),
  3010. /* 66 */
  3011. /***/ (function(module, exports, __webpack_require__) {
  3012. var global = __webpack_require__(8);
  3013. var userAgent = __webpack_require__(52);
  3014. var process = global.process;
  3015. var Deno = global.Deno;
  3016. var versions = process && process.versions || Deno && Deno.version;
  3017. var v8 = versions && versions.v8;
  3018. var match, version;
  3019. if (v8) {
  3020. match = v8.split('.');
  3021. version = match[0] < 4 ? 1 : match[0] + match[1];
  3022. } else if (userAgent) {
  3023. match = userAgent.match(/Edge\/(\d+)/);
  3024. if (!match || match[1] >= 74) {
  3025. match = userAgent.match(/Chrome\/(\d+)/);
  3026. if (match) version = match[1];
  3027. }
  3028. }
  3029. module.exports = version && +version;
  3030. /***/ }),
  3031. /* 67 */
  3032. /***/ (function(module, exports) {
  3033. var id = 0;
  3034. var postfix = Math.random();
  3035. module.exports = function (key) {
  3036. return 'Symbol(' + String(key === undefined ? '' : key) + ')_' + (++id + postfix).toString(36);
  3037. };
  3038. /***/ }),
  3039. /* 68 */
  3040. /***/ (function(module, exports, __webpack_require__) {
  3041. var shared = __webpack_require__(80);
  3042. var uid = __webpack_require__(67);
  3043. var keys = shared('keys');
  3044. module.exports = function (key) {
  3045. return keys[key] || (keys[key] = uid(key));
  3046. };
  3047. /***/ }),
  3048. /* 69 */
  3049. /***/ (function(module, exports, __webpack_require__) {
  3050. /* global ActiveXObject -- old IE, WSH */
  3051. var anObject = __webpack_require__(20);
  3052. var defineProperties = __webpack_require__(175);
  3053. var enumBugKeys = __webpack_require__(87);
  3054. var hiddenKeys = __webpack_require__(54);
  3055. var html = __webpack_require__(111);
  3056. var documentCreateElement = __webpack_require__(82);
  3057. var sharedKey = __webpack_require__(68);
  3058. var GT = '>';
  3059. var LT = '<';
  3060. var PROTOTYPE = 'prototype';
  3061. var SCRIPT = 'script';
  3062. var IE_PROTO = sharedKey('IE_PROTO');
  3063. var EmptyConstructor = function () { /* empty */ };
  3064. var scriptTag = function (content) {
  3065. return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;
  3066. };
  3067. // Create object with fake `null` prototype: use ActiveX Object with cleared prototype
  3068. var NullProtoObjectViaActiveX = function (activeXDocument) {
  3069. activeXDocument.write(scriptTag(''));
  3070. activeXDocument.close();
  3071. var temp = activeXDocument.parentWindow.Object;
  3072. activeXDocument = null; // avoid memory leak
  3073. return temp;
  3074. };
  3075. // Create object with fake `null` prototype: use iframe Object with cleared prototype
  3076. var NullProtoObjectViaIFrame = function () {
  3077. // Thrash, waste and sodomy: IE GC bug
  3078. var iframe = documentCreateElement('iframe');
  3079. var JS = 'java' + SCRIPT + ':';
  3080. var iframeDocument;
  3081. iframe.style.display = 'none';
  3082. html.appendChild(iframe);
  3083. // https://github.com/zloirock/core-js/issues/475
  3084. iframe.src = String(JS);
  3085. iframeDocument = iframe.contentWindow.document;
  3086. iframeDocument.open();
  3087. iframeDocument.write(scriptTag('document.F=Object'));
  3088. iframeDocument.close();
  3089. return iframeDocument.F;
  3090. };
  3091. // Check for document.domain and active x support
  3092. // No need to use active x approach when document.domain is not set
  3093. // see https://github.com/es-shims/es5-shim/issues/150
  3094. // variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346
  3095. // avoid IE GC bug
  3096. var activeXDocument;
  3097. var NullProtoObject = function () {
  3098. try {
  3099. activeXDocument = new ActiveXObject('htmlfile');
  3100. } catch (error) { /* ignore */ }
  3101. NullProtoObject = typeof document != 'undefined'
  3102. ? document.domain && activeXDocument
  3103. ? NullProtoObjectViaActiveX(activeXDocument) // old IE
  3104. : NullProtoObjectViaIFrame()
  3105. : NullProtoObjectViaActiveX(activeXDocument); // WSH
  3106. var length = enumBugKeys.length;
  3107. while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];
  3108. return NullProtoObject();
  3109. };
  3110. hiddenKeys[IE_PROTO] = true;
  3111. // `Object.create` method
  3112. // https://tc39.es/ecma262/#sec-object.create
  3113. module.exports = Object.create || function create(O, Properties) {
  3114. var result;
  3115. if (O !== null) {
  3116. EmptyConstructor[PROTOTYPE] = anObject(O);
  3117. result = new EmptyConstructor();
  3118. EmptyConstructor[PROTOTYPE] = null;
  3119. // add "__proto__" for Object.getPrototypeOf polyfill
  3120. result[IE_PROTO] = O;
  3121. } else result = NullProtoObject();
  3122. return Properties === undefined ? result : defineProperties(result, Properties);
  3123. };
  3124. /***/ }),
  3125. /* 70 */
  3126. /***/ (function(module, exports) {
  3127. var ceil = Math.ceil;
  3128. var floor = Math.floor;
  3129. // `ToInteger` abstract operation
  3130. // https://tc39.es/ecma262/#sec-tointeger
  3131. module.exports = function (argument) {
  3132. return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor : ceil)(argument);
  3133. };
  3134. /***/ }),
  3135. /* 71 */
  3136. /***/ (function(module, exports, __webpack_require__) {
  3137. var TO_STRING_TAG_SUPPORT = __webpack_require__(88);
  3138. var classofRaw = __webpack_require__(50);
  3139. var wellKnownSymbol = __webpack_require__(9);
  3140. var TO_STRING_TAG = wellKnownSymbol('toStringTag');
  3141. // ES3 wrong here
  3142. var CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) == 'Arguments';
  3143. // fallback for IE11 Script Access Denied error
  3144. var tryGet = function (it, key) {
  3145. try {
  3146. return it[key];
  3147. } catch (error) { /* empty */ }
  3148. };
  3149. // getting tag from ES6+ `Object.prototype.toString`
  3150. module.exports = TO_STRING_TAG_SUPPORT ? classofRaw : function (it) {
  3151. var O, tag, result;
  3152. return it === undefined ? 'Undefined' : it === null ? 'Null'
  3153. // @@toStringTag case
  3154. : typeof (tag = tryGet(O = Object(it), TO_STRING_TAG)) == 'string' ? tag
  3155. // builtinTag case
  3156. : CORRECT_ARGUMENTS ? classofRaw(O)
  3157. // ES3 arguments fallback
  3158. : (result = classofRaw(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : result;
  3159. };
  3160. /***/ }),
  3161. /* 72 */
  3162. /***/ (function(module, exports, __webpack_require__) {
  3163. "use strict";
  3164. var aFunction = __webpack_require__(34);
  3165. var PromiseCapability = function (C) {
  3166. var resolve, reject;
  3167. this.promise = new C(function ($$resolve, $$reject) {
  3168. if (resolve !== undefined || reject !== undefined) throw TypeError('Bad Promise constructor');
  3169. resolve = $$resolve;
  3170. reject = $$reject;
  3171. });
  3172. this.resolve = aFunction(resolve);
  3173. this.reject = aFunction(reject);
  3174. };
  3175. // `NewPromiseCapability` abstract operation
  3176. // https://tc39.es/ecma262/#sec-newpromisecapability
  3177. module.exports.f = function (C) {
  3178. return new PromiseCapability(C);
  3179. };
  3180. /***/ }),
  3181. /* 73 */
  3182. /***/ (function(module, exports, __webpack_require__) {
  3183. "use strict";
  3184. var fails = __webpack_require__(12);
  3185. module.exports = function (METHOD_NAME, argument) {
  3186. var method = [][METHOD_NAME];
  3187. return !!method && fails(function () {
  3188. // eslint-disable-next-line no-useless-call,no-throw-literal -- required for testing
  3189. method.call(null, argument || function () { throw 1; }, 1);
  3190. });
  3191. };
  3192. /***/ }),
  3193. /* 74 */
  3194. /***/ (function(module, exports) {
  3195. // a string of all valid unicode whitespaces
  3196. module.exports = '\u0009\u000A\u000B\u000C\u000D\u0020\u00A0\u1680\u2000\u2001\u2002' +
  3197. '\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200A\u202F\u205F\u3000\u2028\u2029\uFEFF';
  3198. /***/ }),
  3199. /* 75 */
  3200. /***/ (function(module, exports, __webpack_require__) {
  3201. "use strict";
  3202. var toPropertyKey = __webpack_require__(64);
  3203. var definePropertyModule = __webpack_require__(18);
  3204. var createPropertyDescriptor = __webpack_require__(38);
  3205. module.exports = function (object, key, value) {
  3206. var propertyKey = toPropertyKey(key);
  3207. if (propertyKey in object) definePropertyModule.f(object, propertyKey, createPropertyDescriptor(0, value));
  3208. else object[propertyKey] = value;
  3209. };
  3210. /***/ }),
  3211. /* 76 */
  3212. /***/ (function(module, exports, __webpack_require__) {
  3213. module.exports = __webpack_require__(220);
  3214. /***/ }),
  3215. /* 77 */
  3216. /***/ (function(module, exports, __webpack_require__) {
  3217. var DESCRIPTORS = __webpack_require__(15);
  3218. var propertyIsEnumerableModule = __webpack_require__(63);
  3219. var createPropertyDescriptor = __webpack_require__(38);
  3220. var toIndexedObject = __webpack_require__(29);
  3221. var toPropertyKey = __webpack_require__(64);
  3222. var has = __webpack_require__(17);
  3223. var IE8_DOM_DEFINE = __webpack_require__(108);
  3224. // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe
  3225. var $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
  3226. // `Object.getOwnPropertyDescriptor` method
  3227. // https://tc39.es/ecma262/#sec-object.getownpropertydescriptor
  3228. exports.f = DESCRIPTORS ? $getOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {
  3229. O = toIndexedObject(O);
  3230. P = toPropertyKey(P);
  3231. if (IE8_DOM_DEFINE) try {
  3232. return $getOwnPropertyDescriptor(O, P);
  3233. } catch (error) { /* empty */ }
  3234. if (has(O, P)) return createPropertyDescriptor(!propertyIsEnumerableModule.f.call(O, P), O[P]);
  3235. };
  3236. /***/ }),
  3237. /* 78 */
  3238. /***/ (function(module, exports, __webpack_require__) {
  3239. var fails = __webpack_require__(12);
  3240. var classof = __webpack_require__(50);
  3241. var split = ''.split;
  3242. // fallback for non-array-like ES3 and non-enumerable old V8 strings
  3243. module.exports = fails(function () {
  3244. // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346
  3245. // eslint-disable-next-line no-prototype-builtins -- safe
  3246. return !Object('z').propertyIsEnumerable(0);
  3247. }) ? function (it) {
  3248. return classof(it) == 'String' ? split.call(it, '') : Object(it);
  3249. } : Object;
  3250. /***/ }),
  3251. /* 79 */
  3252. /***/ (function(module, exports, __webpack_require__) {
  3253. /* eslint-disable es/no-symbol -- required for testing */
  3254. var V8_VERSION = __webpack_require__(66);
  3255. var fails = __webpack_require__(12);
  3256. // eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing
  3257. module.exports = !!Object.getOwnPropertySymbols && !fails(function () {
  3258. var symbol = Symbol();
  3259. // Chrome 38 Symbol has incorrect toString conversion
  3260. // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances
  3261. return !String(symbol) || !(Object(symbol) instanceof Symbol) ||
  3262. // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances
  3263. !Symbol.sham && V8_VERSION && V8_VERSION < 41;
  3264. });
  3265. /***/ }),
  3266. /* 80 */
  3267. /***/ (function(module, exports, __webpack_require__) {
  3268. var IS_PURE = __webpack_require__(39);
  3269. var store = __webpack_require__(81);
  3270. (module.exports = function (key, value) {
  3271. return store[key] || (store[key] = value !== undefined ? value : {});
  3272. })('versions', []).push({
  3273. version: '3.16.2',
  3274. mode: IS_PURE ? 'pure' : 'global',
  3275. copyright: '© 2021 Denis Pushkarev (zloirock.ru)'
  3276. });
  3277. /***/ }),
  3278. /* 81 */
  3279. /***/ (function(module, exports, __webpack_require__) {
  3280. var global = __webpack_require__(8);
  3281. var setGlobal = __webpack_require__(153);
  3282. var SHARED = '__core-js_shared__';
  3283. var store = global[SHARED] || setGlobal(SHARED, {});
  3284. module.exports = store;
  3285. /***/ }),
  3286. /* 82 */
  3287. /***/ (function(module, exports, __webpack_require__) {
  3288. var global = __webpack_require__(8);
  3289. var isObject = __webpack_require__(13);
  3290. var document = global.document;
  3291. // typeof document.createElement is 'object' in old IE
  3292. var EXISTS = isObject(document) && isObject(document.createElement);
  3293. module.exports = function (it) {
  3294. return EXISTS ? document.createElement(it) : {};
  3295. };
  3296. /***/ }),
  3297. /* 83 */
  3298. /***/ (function(module, exports, __webpack_require__) {
  3299. var has = __webpack_require__(17);
  3300. var toObject = __webpack_require__(26);
  3301. var sharedKey = __webpack_require__(68);
  3302. var CORRECT_PROTOTYPE_GETTER = __webpack_require__(173);
  3303. var IE_PROTO = sharedKey('IE_PROTO');
  3304. var ObjectPrototype = Object.prototype;
  3305. // `Object.getPrototypeOf` method
  3306. // https://tc39.es/ecma262/#sec-object.getprototypeof
  3307. // eslint-disable-next-line es/no-object-getprototypeof -- safe
  3308. module.exports = CORRECT_PROTOTYPE_GETTER ? Object.getPrototypeOf : function (O) {
  3309. O = toObject(O);
  3310. if (has(O, IE_PROTO)) return O[IE_PROTO];
  3311. if (typeof O.constructor == 'function' && O instanceof O.constructor) {
  3312. return O.constructor.prototype;
  3313. } return O instanceof Object ? ObjectPrototype : null;
  3314. };
  3315. /***/ }),
  3316. /* 84 */
  3317. /***/ (function(module, exports, __webpack_require__) {
  3318. /* eslint-disable no-proto -- safe */
  3319. var anObject = __webpack_require__(20);
  3320. var aPossiblePrototype = __webpack_require__(174);
  3321. // `Object.setPrototypeOf` method
  3322. // https://tc39.es/ecma262/#sec-object.setprototypeof
  3323. // Works with __proto__ only. Old v8 can't work with null proto objects.
  3324. // eslint-disable-next-line es/no-object-setprototypeof -- safe
  3325. module.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () {
  3326. var CORRECT_SETTER = false;
  3327. var test = {};
  3328. var setter;
  3329. try {
  3330. // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe
  3331. setter = Object.getOwnPropertyDescriptor(Object.prototype, '__proto__').set;
  3332. setter.call(test, []);
  3333. CORRECT_SETTER = test instanceof Array;
  3334. } catch (error) { /* empty */ }
  3335. return function setPrototypeOf(O, proto) {
  3336. anObject(O);
  3337. aPossiblePrototype(proto);
  3338. if (CORRECT_SETTER) setter.call(O, proto);
  3339. else O.__proto__ = proto;
  3340. return O;
  3341. };
  3342. }() : undefined);
  3343. /***/ }),
  3344. /* 85 */
  3345. /***/ (function(module, exports, __webpack_require__) {
  3346. var toIndexedObject = __webpack_require__(29);
  3347. var toLength = __webpack_require__(35);
  3348. var toAbsoluteIndex = __webpack_require__(86);
  3349. // `Array.prototype.{ indexOf, includes }` methods implementation
  3350. var createMethod = function (IS_INCLUDES) {
  3351. return function ($this, el, fromIndex) {
  3352. var O = toIndexedObject($this);
  3353. var length = toLength(O.length);
  3354. var index = toAbsoluteIndex(fromIndex, length);
  3355. var value;
  3356. // Array#includes uses SameValueZero equality algorithm
  3357. // eslint-disable-next-line no-self-compare -- NaN check
  3358. if (IS_INCLUDES && el != el) while (length > index) {
  3359. value = O[index++];
  3360. // eslint-disable-next-line no-self-compare -- NaN check
  3361. if (value != value) return true;
  3362. // Array#indexOf ignores holes, Array#includes - not
  3363. } else for (;length > index; index++) {
  3364. if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;
  3365. } return !IS_INCLUDES && -1;
  3366. };
  3367. };
  3368. module.exports = {
  3369. // `Array.prototype.includes` method
  3370. // https://tc39.es/ecma262/#sec-array.prototype.includes
  3371. includes: createMethod(true),
  3372. // `Array.prototype.indexOf` method
  3373. // https://tc39.es/ecma262/#sec-array.prototype.indexof
  3374. indexOf: createMethod(false)
  3375. };
  3376. /***/ }),
  3377. /* 86 */
  3378. /***/ (function(module, exports, __webpack_require__) {
  3379. var toInteger = __webpack_require__(70);
  3380. var max = Math.max;
  3381. var min = Math.min;
  3382. // Helper for a popular repeating case of the spec:
  3383. // Let integer be ? ToInteger(index).
  3384. // If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).
  3385. module.exports = function (index, length) {
  3386. var integer = toInteger(index);
  3387. return integer < 0 ? max(integer + length, 0) : min(integer, length);
  3388. };
  3389. /***/ }),
  3390. /* 87 */
  3391. /***/ (function(module, exports) {
  3392. // IE8- don't enum bug keys
  3393. module.exports = [
  3394. 'constructor',
  3395. 'hasOwnProperty',
  3396. 'isPrototypeOf',
  3397. 'propertyIsEnumerable',
  3398. 'toLocaleString',
  3399. 'toString',
  3400. 'valueOf'
  3401. ];
  3402. /***/ }),
  3403. /* 88 */
  3404. /***/ (function(module, exports, __webpack_require__) {
  3405. var wellKnownSymbol = __webpack_require__(9);
  3406. var TO_STRING_TAG = wellKnownSymbol('toStringTag');
  3407. var test = {};
  3408. test[TO_STRING_TAG] = 'z';
  3409. module.exports = String(test) === '[object z]';
  3410. /***/ }),
  3411. /* 89 */
  3412. /***/ (function(module, exports) {
  3413. module.exports = function () { /* empty */ };
  3414. /***/ }),
  3415. /* 90 */
  3416. /***/ (function(module, exports, __webpack_require__) {
  3417. "use strict";
  3418. var $ = __webpack_require__(5);
  3419. var createIteratorConstructor = __webpack_require__(177);
  3420. var getPrototypeOf = __webpack_require__(83);
  3421. var setPrototypeOf = __webpack_require__(84);
  3422. var setToStringTag = __webpack_require__(44);
  3423. var createNonEnumerableProperty = __webpack_require__(19);
  3424. var redefine = __webpack_require__(56);
  3425. var wellKnownSymbol = __webpack_require__(9);
  3426. var IS_PURE = __webpack_require__(39);
  3427. var Iterators = __webpack_require__(42);
  3428. var IteratorsCore = __webpack_require__(116);
  3429. var IteratorPrototype = IteratorsCore.IteratorPrototype;
  3430. var BUGGY_SAFARI_ITERATORS = IteratorsCore.BUGGY_SAFARI_ITERATORS;
  3431. var ITERATOR = wellKnownSymbol('iterator');
  3432. var KEYS = 'keys';
  3433. var VALUES = 'values';
  3434. var ENTRIES = 'entries';
  3435. var returnThis = function () { return this; };
  3436. module.exports = function (Iterable, NAME, IteratorConstructor, next, DEFAULT, IS_SET, FORCED) {
  3437. createIteratorConstructor(IteratorConstructor, NAME, next);
  3438. var getIterationMethod = function (KIND) {
  3439. if (KIND === DEFAULT && defaultIterator) return defaultIterator;
  3440. if (!BUGGY_SAFARI_ITERATORS && KIND in IterablePrototype) return IterablePrototype[KIND];
  3441. switch (KIND) {
  3442. case KEYS: return function keys() { return new IteratorConstructor(this, KIND); };
  3443. case VALUES: return function values() { return new IteratorConstructor(this, KIND); };
  3444. case ENTRIES: return function entries() { return new IteratorConstructor(this, KIND); };
  3445. } return function () { return new IteratorConstructor(this); };
  3446. };
  3447. var TO_STRING_TAG = NAME + ' Iterator';
  3448. var INCORRECT_VALUES_NAME = false;
  3449. var IterablePrototype = Iterable.prototype;
  3450. var nativeIterator = IterablePrototype[ITERATOR]
  3451. || IterablePrototype['@@iterator']
  3452. || DEFAULT && IterablePrototype[DEFAULT];
  3453. var defaultIterator = !BUGGY_SAFARI_ITERATORS && nativeIterator || getIterationMethod(DEFAULT);
  3454. var anyNativeIterator = NAME == 'Array' ? IterablePrototype.entries || nativeIterator : nativeIterator;
  3455. var CurrentIteratorPrototype, methods, KEY;
  3456. // fix native
  3457. if (anyNativeIterator) {
  3458. CurrentIteratorPrototype = getPrototypeOf(anyNativeIterator.call(new Iterable()));
  3459. if (IteratorPrototype !== Object.prototype && CurrentIteratorPrototype.next) {
  3460. if (!IS_PURE && getPrototypeOf(CurrentIteratorPrototype) !== IteratorPrototype) {
  3461. if (setPrototypeOf) {
  3462. setPrototypeOf(CurrentIteratorPrototype, IteratorPrototype);
  3463. } else if (typeof CurrentIteratorPrototype[ITERATOR] != 'function') {
  3464. createNonEnumerableProperty(CurrentIteratorPrototype, ITERATOR, returnThis);
  3465. }
  3466. }
  3467. // Set @@toStringTag to native iterators
  3468. setToStringTag(CurrentIteratorPrototype, TO_STRING_TAG, true, true);
  3469. if (IS_PURE) Iterators[TO_STRING_TAG] = returnThis;
  3470. }
  3471. }
  3472. // fix Array.prototype.{ values, @@iterator }.name in V8 / FF
  3473. if (DEFAULT == VALUES && nativeIterator && nativeIterator.name !== VALUES) {
  3474. INCORRECT_VALUES_NAME = true;
  3475. defaultIterator = function values() { return nativeIterator.call(this); };
  3476. }
  3477. // define iterator
  3478. if ((!IS_PURE || FORCED) && IterablePrototype[ITERATOR] !== defaultIterator) {
  3479. createNonEnumerableProperty(IterablePrototype, ITERATOR, defaultIterator);
  3480. }
  3481. Iterators[NAME] = defaultIterator;
  3482. // export additional methods
  3483. if (DEFAULT) {
  3484. methods = {
  3485. values: getIterationMethod(VALUES),
  3486. keys: IS_SET ? defaultIterator : getIterationMethod(KEYS),
  3487. entries: getIterationMethod(ENTRIES)
  3488. };
  3489. if (FORCED) for (KEY in methods) {
  3490. if (BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME || !(KEY in IterablePrototype)) {
  3491. redefine(IterablePrototype, KEY, methods[KEY]);
  3492. }
  3493. } else $({ target: NAME, proto: true, forced: BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME }, methods);
  3494. }
  3495. return methods;
  3496. };
  3497. /***/ }),
  3498. /* 91 */
  3499. /***/ (function(module, exports) {
  3500. module.exports = function (it, Constructor, name) {
  3501. if (!(it instanceof Constructor)) {
  3502. throw TypeError('Incorrect ' + (name ? name + ' ' : '') + 'invocation');
  3503. } return it;
  3504. };
  3505. /***/ }),
  3506. /* 92 */
  3507. /***/ (function(module, exports, __webpack_require__) {
  3508. var classof = __webpack_require__(50);
  3509. var global = __webpack_require__(8);
  3510. module.exports = classof(global.process) == 'process';
  3511. /***/ }),
  3512. /* 93 */
  3513. /***/ (function(module, exports) {
  3514. module.exports = function (exec) {
  3515. try {
  3516. return { error: false, value: exec() };
  3517. } catch (error) {
  3518. return { error: true, value: error };
  3519. }
  3520. };
  3521. /***/ }),
  3522. /* 94 */
  3523. /***/ (function(module, exports, __webpack_require__) {
  3524. "use strict";
  3525. /**
  3526. * @description 编辑器 class
  3527. * @author wangfupeng
  3528. */
  3529. var _interopRequireDefault = __webpack_require__(0);
  3530. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  3531. var _forEach = _interopRequireDefault(__webpack_require__(4));
  3532. (0, _defineProperty["default"])(exports, "__esModule", {
  3533. value: true
  3534. });
  3535. var tslib_1 = __webpack_require__(2);
  3536. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  3537. var util_1 = __webpack_require__(6);
  3538. var config_1 = tslib_1.__importDefault(__webpack_require__(282));
  3539. var selection_1 = tslib_1.__importDefault(__webpack_require__(295));
  3540. var command_1 = tslib_1.__importDefault(__webpack_require__(296));
  3541. var index_1 = tslib_1.__importDefault(__webpack_require__(297));
  3542. var index_2 = tslib_1.__importDefault(__webpack_require__(316));
  3543. var init_dom_1 = tslib_1.__importStar(__webpack_require__(432));
  3544. var init_selection_1 = tslib_1.__importDefault(__webpack_require__(433));
  3545. var bind_event_1 = tslib_1.__importDefault(__webpack_require__(434));
  3546. var i18next_init_1 = tslib_1.__importDefault(__webpack_require__(435));
  3547. var set_full_screen_1 = tslib_1.__importStar(__webpack_require__(436));
  3548. var scroll_to_head_1 = tslib_1.__importDefault(__webpack_require__(439));
  3549. var z_index_1 = tslib_1.__importDefault(__webpack_require__(440));
  3550. var index_3 = tslib_1.__importDefault(__webpack_require__(441));
  3551. var index_4 = tslib_1.__importDefault(__webpack_require__(443));
  3552. var disable_1 = tslib_1.__importDefault(__webpack_require__(453));
  3553. var selection_change_1 = tslib_1.__importDefault(__webpack_require__(456));
  3554. var plugins_1 = tslib_1.__importStar(__webpack_require__(457));
  3555. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  3556. var DropList_1 = tslib_1.__importDefault(__webpack_require__(138));
  3557. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  3558. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  3559. var PanelMenu_1 = tslib_1.__importDefault(__webpack_require__(36));
  3560. var Tooltip_1 = tslib_1.__importDefault(__webpack_require__(37));
  3561. var EDITOR_ID = 1;
  3562. var Editor = function () {
  3563. /**
  3564. * 构造函数
  3565. * @param toolbarSelector 工具栏 DOM selector
  3566. * @param textSelector 文本区域 DOM selector
  3567. */
  3568. function Editor(toolbarSelector, textSelector) {
  3569. this.pluginsFunctionList = {}; // 实例销毁前需要执行的钩子集合
  3570. this.beforeDestroyHooks = []; // id,用以区分单个页面不同的编辑器对象
  3571. this.id = "wangEditor-" + EDITOR_ID++;
  3572. this.toolbarSelector = toolbarSelector;
  3573. this.textSelector = textSelector;
  3574. init_dom_1.selectorValidator(this); // 属性的默认值,后面可能会再修改
  3575. // 默认配置 - 当一个页面有多个编辑器的时候,因为 JS 的特性(引用类型)会导致多个编辑器的 config 引用是同一个,所以需要 深度克隆 断掉引用
  3576. this.config = util_1.deepClone(config_1["default"]);
  3577. this.$toolbarElem = dom_core_1["default"]('<div></div>');
  3578. this.$textContainerElem = dom_core_1["default"]('<div></div>');
  3579. this.$textElem = dom_core_1["default"]('<div></div>');
  3580. this.toolbarElemId = '';
  3581. this.textElemId = '';
  3582. this.isFocus = false;
  3583. this.isComposing = false;
  3584. this.isCompatibleMode = false;
  3585. this.selection = new selection_1["default"](this);
  3586. this.cmd = new command_1["default"](this);
  3587. this.txt = new index_1["default"](this);
  3588. this.menus = new index_2["default"](this);
  3589. this.zIndex = new z_index_1["default"]();
  3590. this.change = new index_3["default"](this);
  3591. this.history = new index_4["default"](this);
  3592. this.onSelectionChange = new selection_change_1["default"](this);
  3593. var _a = disable_1["default"](this),
  3594. disable = _a.disable,
  3595. enable = _a.enable;
  3596. this.disable = disable;
  3597. this.enable = enable;
  3598. this.isEnable = true;
  3599. }
  3600. /**
  3601. * 初始化选区
  3602. * @param newLine 新建一行
  3603. */
  3604. Editor.prototype.initSelection = function (newLine) {
  3605. init_selection_1["default"](this, newLine);
  3606. };
  3607. /**
  3608. * 创建编辑器实例
  3609. */
  3610. Editor.prototype.create = function () {
  3611. // 初始化 ZIndex
  3612. this.zIndex.init(this); // 确定当前的历史记录模式
  3613. this.isCompatibleMode = this.config.compatibleMode(); // 标准模式下,重置延迟时间
  3614. if (!this.isCompatibleMode) {
  3615. this.config.onchangeTimeout = 30;
  3616. } // 国际化 因为要在创建菜单前使用 所以要最先 初始化
  3617. i18next_init_1["default"](this); // 初始化 DOM
  3618. init_dom_1["default"](this); // 初始化 text
  3619. this.txt.init(); // 初始化菜单
  3620. this.menus.init(); // 初始化全屏功能
  3621. set_full_screen_1["default"](this); // 初始化选区,将光标定位到内容尾部
  3622. this.initSelection(true); // 绑定事件
  3623. bind_event_1["default"](this); // 绑定监听的目标节点
  3624. this.change.observe();
  3625. this.history.observe(); // 初始化插件
  3626. plugins_1["default"](this);
  3627. };
  3628. /**
  3629. * 提供给用户添加销毁前的钩子函数
  3630. * @param fn 钩子函数
  3631. */
  3632. Editor.prototype.beforeDestroy = function (fn) {
  3633. this.beforeDestroyHooks.push(fn);
  3634. return this;
  3635. };
  3636. /**
  3637. * 销毁当前编辑器实例
  3638. */
  3639. Editor.prototype.destroy = function () {
  3640. var _context;
  3641. var _this = this; // 调用钩子函数
  3642. (0, _forEach["default"])(_context = this.beforeDestroyHooks).call(_context, function (fn) {
  3643. return fn.call(_this);
  3644. }); // 销毁 DOM 节点
  3645. this.$toolbarElem.remove();
  3646. this.$textContainerElem.remove();
  3647. };
  3648. /**
  3649. * 将编辑器设置为全屏
  3650. */
  3651. Editor.prototype.fullScreen = function () {
  3652. set_full_screen_1.setFullScreen(this);
  3653. };
  3654. /**
  3655. * 将编辑器退出全屏
  3656. */
  3657. Editor.prototype.unFullScreen = function () {
  3658. set_full_screen_1.setUnFullScreen(this);
  3659. };
  3660. /**
  3661. * 滚动到指定标题锚点
  3662. * @param id 标题锚点id
  3663. */
  3664. Editor.prototype.scrollToHead = function (id) {
  3665. scroll_to_head_1["default"](this, id);
  3666. };
  3667. /**
  3668. * 自定义添加菜单
  3669. * @param key 菜单 key
  3670. * @param Menu 菜单构造函数
  3671. */
  3672. Editor.registerMenu = function (key, Menu) {
  3673. if (!Menu || typeof Menu !== 'function') return;
  3674. Editor.globalCustomMenuConstructorList[key] = Menu;
  3675. };
  3676. /**
  3677. * 自定义添加插件
  3678. * @param { string } name 插件的名称
  3679. * @param { RegisterOptions } options 插件的选项
  3680. */
  3681. Editor.prototype.registerPlugin = function (name, options) {
  3682. plugins_1.registerPlugin(name, options, this.pluginsFunctionList);
  3683. };
  3684. /**
  3685. * 自定义添加插件
  3686. * @param { string } name 插件的名称
  3687. * @param { RegisterOptions } options 插件的选项
  3688. */
  3689. Editor.registerPlugin = function (name, options) {
  3690. plugins_1.registerPlugin(name, options, Editor.globalPluginsFunctionList);
  3691. }; // 暴露 $
  3692. Editor.$ = dom_core_1["default"];
  3693. Editor.BtnMenu = BtnMenu_1["default"];
  3694. Editor.DropList = DropList_1["default"];
  3695. Editor.DropListMenu = DropListMenu_1["default"];
  3696. Editor.Panel = Panel_1["default"];
  3697. Editor.PanelMenu = PanelMenu_1["default"];
  3698. Editor.Tooltip = Tooltip_1["default"];
  3699. Editor.globalCustomMenuConstructorList = {};
  3700. Editor.globalPluginsFunctionList = {};
  3701. return Editor;
  3702. }();
  3703. exports["default"] = Editor;
  3704. /***/ }),
  3705. /* 95 */
  3706. /***/ (function(module, exports, __webpack_require__) {
  3707. var arraySpeciesConstructor = __webpack_require__(195);
  3708. // `ArraySpeciesCreate` abstract operation
  3709. // https://tc39.es/ecma262/#sec-arrayspeciescreate
  3710. module.exports = function (originalArray, length) {
  3711. return new (arraySpeciesConstructor(originalArray))(length === 0 ? 0 : length);
  3712. };
  3713. /***/ }),
  3714. /* 96 */
  3715. /***/ (function(module, exports, __webpack_require__) {
  3716. module.exports = __webpack_require__(196);
  3717. /***/ }),
  3718. /* 97 */
  3719. /***/ (function(module, exports, __webpack_require__) {
  3720. var requireObjectCoercible = __webpack_require__(51);
  3721. var toString = __webpack_require__(30);
  3722. var whitespaces = __webpack_require__(74);
  3723. var whitespace = '[' + whitespaces + ']';
  3724. var ltrim = RegExp('^' + whitespace + whitespace + '*');
  3725. var rtrim = RegExp(whitespace + whitespace + '*$');
  3726. // `String.prototype.{ trim, trimStart, trimEnd, trimLeft, trimRight }` methods implementation
  3727. var createMethod = function (TYPE) {
  3728. return function ($this) {
  3729. var string = toString(requireObjectCoercible($this));
  3730. if (TYPE & 1) string = string.replace(ltrim, '');
  3731. if (TYPE & 2) string = string.replace(rtrim, '');
  3732. return string;
  3733. };
  3734. };
  3735. module.exports = {
  3736. // `String.prototype.{ trimLeft, trimStart }` methods
  3737. // https://tc39.es/ecma262/#sec-string.prototype.trimstart
  3738. start: createMethod(1),
  3739. // `String.prototype.{ trimRight, trimEnd }` methods
  3740. // https://tc39.es/ecma262/#sec-string.prototype.trimend
  3741. end: createMethod(2),
  3742. // `String.prototype.trim` method
  3743. // https://tc39.es/ecma262/#sec-string.prototype.trim
  3744. trim: createMethod(3)
  3745. };
  3746. /***/ }),
  3747. /* 98 */
  3748. /***/ (function(module, exports, __webpack_require__) {
  3749. var internalObjectKeys = __webpack_require__(110);
  3750. var enumBugKeys = __webpack_require__(87);
  3751. var hiddenKeys = enumBugKeys.concat('length', 'prototype');
  3752. // `Object.getOwnPropertyNames` method
  3753. // https://tc39.es/ecma262/#sec-object.getownpropertynames
  3754. // eslint-disable-next-line es/no-object-getownpropertynames -- safe
  3755. exports.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {
  3756. return internalObjectKeys(O, hiddenKeys);
  3757. };
  3758. /***/ }),
  3759. /* 99 */
  3760. /***/ (function(module, exports, __webpack_require__) {
  3761. module.exports = __webpack_require__(216);
  3762. /***/ }),
  3763. /* 100 */
  3764. /***/ (function(module, exports, __webpack_require__) {
  3765. var _Symbol = __webpack_require__(238);
  3766. var _Symbol$iterator = __webpack_require__(267);
  3767. function _typeof(obj) {
  3768. "@babel/helpers - typeof";
  3769. if (typeof _Symbol === "function" && typeof _Symbol$iterator === "symbol") {
  3770. module.exports = _typeof = function _typeof(obj) {
  3771. return typeof obj;
  3772. };
  3773. module.exports["default"] = module.exports, module.exports.__esModule = true;
  3774. } else {
  3775. module.exports = _typeof = function _typeof(obj) {
  3776. return obj && typeof _Symbol === "function" && obj.constructor === _Symbol && obj !== _Symbol.prototype ? "symbol" : typeof obj;
  3777. };
  3778. module.exports["default"] = module.exports, module.exports.__esModule = true;
  3779. }
  3780. return _typeof(obj);
  3781. }
  3782. module.exports = _typeof;
  3783. module.exports["default"] = module.exports, module.exports.__esModule = true;
  3784. /***/ }),
  3785. /* 101 */
  3786. /***/ (function(module, exports, __webpack_require__) {
  3787. var wellKnownSymbol = __webpack_require__(9);
  3788. exports.f = wellKnownSymbol;
  3789. /***/ }),
  3790. /* 102 */
  3791. /***/ (function(module, exports, __webpack_require__) {
  3792. module.exports = __webpack_require__(321);
  3793. /***/ }),
  3794. /* 103 */
  3795. /***/ (function(module, exports, __webpack_require__) {
  3796. "use strict";
  3797. /**
  3798. * @description Menu class 父类
  3799. * @author wangfupeng
  3800. */
  3801. var _interopRequireDefault = __webpack_require__(0);
  3802. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  3803. var _forEach = _interopRequireDefault(__webpack_require__(4));
  3804. (0, _defineProperty["default"])(exports, "__esModule", {
  3805. value: true
  3806. });
  3807. var tslib_1 = __webpack_require__(2);
  3808. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  3809. var Menu = function () {
  3810. function Menu($elem, editor) {
  3811. var _this = this;
  3812. this.$elem = $elem;
  3813. this.editor = editor;
  3814. this._active = false; // 绑定菜单点击事件
  3815. $elem.on('click', function (e) {
  3816. var _context;
  3817. Panel_1["default"].hideCurAllPanels(); // 隐藏当前的所有 Panel
  3818. // 触发菜单点击的钩子
  3819. (0, _forEach["default"])(_context = editor.txt.eventHooks.menuClickEvents).call(_context, function (fn) {
  3820. return fn();
  3821. });
  3822. e.stopPropagation();
  3823. if (editor.selection.getRange() == null) {
  3824. return;
  3825. }
  3826. _this.clickHandler(e);
  3827. });
  3828. }
  3829. /**
  3830. * 菜单点击事件,子类可重写
  3831. * @param e event
  3832. */
  3833. Menu.prototype.clickHandler = function (e) {};
  3834. /**
  3835. * 激活菜单,高亮显示
  3836. */
  3837. Menu.prototype.active = function () {
  3838. this._active = true;
  3839. this.$elem.addClass('w-e-active');
  3840. };
  3841. /**
  3842. * 取消激活,不再高亮显示
  3843. */
  3844. Menu.prototype.unActive = function () {
  3845. this._active = false;
  3846. this.$elem.removeClass('w-e-active');
  3847. };
  3848. (0, _defineProperty["default"])(Menu.prototype, "isActive", {
  3849. /**
  3850. * 是否处于激活状态
  3851. */
  3852. get: function get() {
  3853. return this._active;
  3854. },
  3855. enumerable: false,
  3856. configurable: true
  3857. });
  3858. return Menu;
  3859. }();
  3860. exports["default"] = Menu;
  3861. /***/ }),
  3862. /* 104 */
  3863. /***/ (function(module, exports, __webpack_require__) {
  3864. "use strict";
  3865. /**
  3866. * @description 上传图片
  3867. * @author wangfupeng
  3868. */
  3869. var _interopRequireDefault = __webpack_require__(0);
  3870. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  3871. var _bind = _interopRequireDefault(__webpack_require__(61));
  3872. var _forEach = _interopRequireDefault(__webpack_require__(4));
  3873. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  3874. (0, _defineProperty["default"])(exports, "__esModule", {
  3875. value: true
  3876. });
  3877. var tslib_1 = __webpack_require__(2);
  3878. var util_1 = __webpack_require__(6);
  3879. var upload_core_1 = tslib_1.__importDefault(__webpack_require__(140));
  3880. var progress_1 = tslib_1.__importDefault(__webpack_require__(141));
  3881. var UploadImg = function () {
  3882. function UploadImg(editor) {
  3883. this.editor = editor;
  3884. }
  3885. /**
  3886. * 往编辑区域插入图片
  3887. * @param src 图片地址
  3888. */
  3889. UploadImg.prototype.insertImg = function (src, alt, href) {
  3890. var editor = this.editor;
  3891. var config = editor.config;
  3892. var i18nPrefix = 'validate.';
  3893. var t = function t(text, prefix) {
  3894. if (prefix === void 0) {
  3895. prefix = i18nPrefix;
  3896. }
  3897. return editor.i18next.t(prefix + text);
  3898. }; // 设置图片alt
  3899. var altText = alt ? "alt=\"" + alt + "\" " : '';
  3900. var hrefText = href ? "data-href=\"" + encodeURIComponent(href) + "\" " : ''; // 先插入图片,无论是否能成功
  3901. editor.cmd["do"]('insertHTML', "<img src=\"" + src + "\" " + altText + hrefText + "style=\"max-width:100%;\" contenteditable=\"false\"/>"); // 执行回调函数
  3902. config.linkImgCallback(src, alt, href); // 加载图片
  3903. var img = document.createElement('img');
  3904. img.onload = function () {
  3905. img = null;
  3906. };
  3907. img.onerror = function () {
  3908. config.customAlert(t('插入图片错误'), 'error', "wangEditor: " + t('插入图片错误') + "\uFF0C" + t('图片链接') + " \"" + src + "\"\uFF0C" + t('下载链接失败'));
  3909. img = null;
  3910. };
  3911. img.onabort = function () {
  3912. return img = null;
  3913. };
  3914. img.src = src;
  3915. };
  3916. /**
  3917. * 上传图片
  3918. * @param files 文件列表
  3919. */
  3920. UploadImg.prototype.uploadImg = function (files) {
  3921. var _this_1 = this;
  3922. if (!files.length) {
  3923. return;
  3924. }
  3925. var editor = this.editor;
  3926. var config = editor.config; // ------------------------------ i18next ------------------------------
  3927. var i18nPrefix = 'validate.';
  3928. var t = function t(text) {
  3929. return editor.i18next.t(i18nPrefix + text);
  3930. }; // ------------------------------ 获取配置信息 ------------------------------
  3931. // 服务端地址
  3932. var uploadImgServer = config.uploadImgServer; // base64 格式
  3933. var uploadImgShowBase64 = config.uploadImgShowBase64; // 图片最大体积
  3934. var maxSize = config.uploadImgMaxSize;
  3935. var maxSizeM = maxSize / 1024 / 1024; // 一次最多上传图片数量
  3936. var maxLength = config.uploadImgMaxLength; // 自定义 fileName
  3937. var uploadFileName = config.uploadFileName; // 自定义参数
  3938. var uploadImgParams = config.uploadImgParams; // 参数拼接到 url 中
  3939. var uploadImgParamsWithUrl = config.uploadImgParamsWithUrl; // 自定义 header
  3940. var uploadImgHeaders = config.uploadImgHeaders; // 钩子函数
  3941. var hooks = config.uploadImgHooks; // 上传图片超时时间
  3942. var timeout = config.uploadImgTimeout; // 跨域带 cookie
  3943. var withCredentials = config.withCredentials; // 自定义上传图片
  3944. var customUploadImg = config.customUploadImg;
  3945. if (!customUploadImg) {
  3946. // 没有 customUploadImg 的情况下,需要如下两个配置才能继续进行图片上传
  3947. if (!uploadImgServer && !uploadImgShowBase64) {
  3948. return;
  3949. }
  3950. } // ------------------------------ 验证文件信息 ------------------------------
  3951. var resultFiles = [];
  3952. var errInfos = [];
  3953. util_1.arrForEach(files, function (file) {
  3954. // chrome 低版本 粘贴一张图时files为 [null, File]
  3955. if (!file) return;
  3956. var name = file.name || file.type.replace('/', '.'); // 兼容低版本chrome 没有name
  3957. var size = file.size; // chrome 低版本 name === undefined
  3958. if (!name || !size) {
  3959. return;
  3960. } // 将uploadImgAccept数组转换为正则对象
  3961. var imgType = editor.config.uploadImgAccept.join('|');
  3962. var imgTypeRuleStr = ".(" + imgType + ")$";
  3963. var uploadImgAcceptRule = new RegExp(imgTypeRuleStr, 'i');
  3964. if (uploadImgAcceptRule.test(name) === false) {
  3965. // 后缀名不合法,不是图片
  3966. errInfos.push("\u3010" + name + "\u3011" + t('不是图片'));
  3967. return;
  3968. }
  3969. if (maxSize < size) {
  3970. // 上传图片过大
  3971. errInfos.push("\u3010" + name + "\u3011" + t('大于') + " " + maxSizeM + "M");
  3972. return;
  3973. } // 验证通过的加入结果列表
  3974. resultFiles.push(file);
  3975. }); // 抛出验证信息
  3976. if (errInfos.length) {
  3977. config.customAlert(t('图片验证未通过') + ": \n" + errInfos.join('\n'), 'warning');
  3978. return;
  3979. } // 如果过滤后文件列表为空直接返回
  3980. if (resultFiles.length === 0) {
  3981. config.customAlert(t('传入的文件不合法'), 'warning');
  3982. return;
  3983. }
  3984. if (resultFiles.length > maxLength) {
  3985. config.customAlert(t('一次最多上传') + maxLength + t('张图片'), 'warning');
  3986. return;
  3987. } // ------------------------------ 自定义上传 ------------------------------
  3988. if (customUploadImg && typeof customUploadImg === 'function') {
  3989. var _context;
  3990. customUploadImg(resultFiles, (0, _bind["default"])(_context = this.insertImg).call(_context, this)); // 阻止以下代码执行,重要!!!
  3991. return;
  3992. } // ------------------------------ 上传图片 ------------------------------
  3993. // 添加图片数据
  3994. var formData = new FormData();
  3995. (0, _forEach["default"])(resultFiles).call(resultFiles, function (file, index) {
  3996. var name = uploadFileName || file.name;
  3997. if (resultFiles.length > 1) {
  3998. // 多个文件时,filename 不能重复
  3999. name = name + (index + 1);
  4000. }
  4001. formData.append(name, file);
  4002. });
  4003. if (uploadImgServer) {
  4004. // 添加自定义参数
  4005. var uploadImgServerArr = uploadImgServer.split('#');
  4006. uploadImgServer = uploadImgServerArr[0];
  4007. var uploadImgServerHash = uploadImgServerArr[1] || '';
  4008. (0, _forEach["default"])(util_1).call(util_1, uploadImgParams, function (key, val) {
  4009. // 因使用者反应,自定义参数不能默认 encode ,由 v3.1.1 版本开始注释掉
  4010. // val = encodeURIComponent(val)
  4011. // 第一,将参数拼接到 url 中
  4012. if (uploadImgParamsWithUrl) {
  4013. if ((0, _indexOf["default"])(uploadImgServer).call(uploadImgServer, '?') > 0) {
  4014. uploadImgServer += '&';
  4015. } else {
  4016. uploadImgServer += '?';
  4017. }
  4018. uploadImgServer = uploadImgServer + key + '=' + val;
  4019. } // 第二,将参数添加到 formData 中
  4020. formData.append(key, val);
  4021. });
  4022. if (uploadImgServerHash) {
  4023. uploadImgServer += '#' + uploadImgServerHash;
  4024. } // 开始上传
  4025. var xhr = upload_core_1["default"](uploadImgServer, {
  4026. timeout: timeout,
  4027. formData: formData,
  4028. headers: uploadImgHeaders,
  4029. withCredentials: !!withCredentials,
  4030. beforeSend: function beforeSend(xhr) {
  4031. if (hooks.before) return hooks.before(xhr, editor, resultFiles);
  4032. },
  4033. onTimeout: function onTimeout(xhr) {
  4034. config.customAlert(t('上传图片超时'), 'error');
  4035. if (hooks.timeout) hooks.timeout(xhr, editor);
  4036. },
  4037. onProgress: function onProgress(percent, e) {
  4038. var progressBar = new progress_1["default"](editor);
  4039. if (e.lengthComputable) {
  4040. percent = e.loaded / e.total;
  4041. progressBar.show(percent);
  4042. }
  4043. },
  4044. onError: function onError(xhr) {
  4045. config.customAlert(t('上传图片错误'), 'error', t('上传图片错误') + "\uFF0C" + t('服务器返回状态') + ": " + xhr.status);
  4046. if (hooks.error) hooks.error(xhr, editor);
  4047. },
  4048. onFail: function onFail(xhr, resultStr) {
  4049. config.customAlert(t('上传图片失败'), 'error', t('上传图片返回结果错误') + ("\uFF0C" + t('返回结果') + ": ") + resultStr);
  4050. if (hooks.fail) hooks.fail(xhr, editor, resultStr);
  4051. },
  4052. onSuccess: function onSuccess(xhr, result) {
  4053. if (hooks.customInsert) {
  4054. var _context2;
  4055. // 自定义插入图片
  4056. hooks.customInsert((0, _bind["default"])(_context2 = _this_1.insertImg).call(_context2, _this_1), result, editor);
  4057. return;
  4058. }
  4059. if (result.errno != '0') {
  4060. // 返回格式不对,应该为 { errno: 0, data: [...] }
  4061. config.customAlert(t('上传图片失败'), 'error', t('上传图片返回结果错误') + "\uFF0C" + t('返回结果') + " errno=" + result.errno);
  4062. if (hooks.fail) hooks.fail(xhr, editor, result);
  4063. return;
  4064. } // 成功,插入图片
  4065. var data = result.data;
  4066. (0, _forEach["default"])(data).call(data, function (link) {
  4067. if (typeof link === 'string') {
  4068. _this_1.insertImg(link);
  4069. } else {
  4070. _this_1.insertImg(link.url, link.alt, link.href);
  4071. }
  4072. }); // 钩子函数
  4073. if (hooks.success) hooks.success(xhr, editor, result);
  4074. }
  4075. });
  4076. if (typeof xhr === 'string') {
  4077. // 上传被阻止
  4078. config.customAlert(xhr, 'error');
  4079. } // 阻止以下代码执行,重要!!!
  4080. return;
  4081. } // ------------------------------ 显示 base64 格式 ------------------------------
  4082. if (uploadImgShowBase64) {
  4083. util_1.arrForEach(files, function (file) {
  4084. var _this = _this_1;
  4085. var reader = new FileReader();
  4086. reader.readAsDataURL(file);
  4087. reader.onload = function () {
  4088. if (!this.result) return;
  4089. var imgLink = this.result.toString();
  4090. _this.insertImg(imgLink, imgLink);
  4091. };
  4092. });
  4093. }
  4094. };
  4095. return UploadImg;
  4096. }();
  4097. exports["default"] = UploadImg;
  4098. /***/ }),
  4099. /* 105 */
  4100. /***/ (function(module, exports, __webpack_require__) {
  4101. "use strict";
  4102. var _interopRequireDefault = __webpack_require__(0);
  4103. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  4104. var _every = _interopRequireDefault(__webpack_require__(426));
  4105. var _forEach = _interopRequireDefault(__webpack_require__(4));
  4106. var _slice = _interopRequireDefault(__webpack_require__(47));
  4107. (0, _defineProperty["default"])(exports, "__esModule", {
  4108. value: true
  4109. });
  4110. exports.dealTextNode = exports.isAllTodo = exports.isTodo = exports.getCursorNextNode = void 0;
  4111. /**
  4112. * 判断传入的单行顶级选区选取是不是todo
  4113. * @param editor 编辑器对象
  4114. */
  4115. function isTodo($topSelectElem) {
  4116. if ($topSelectElem.length) {
  4117. return $topSelectElem.attr('class') === 'w-e-todo';
  4118. }
  4119. return false;
  4120. }
  4121. exports.isTodo = isTodo;
  4122. /**
  4123. * 判断选中的内容是不是都是todo
  4124. * @param editor 编辑器对象
  4125. */
  4126. function isAllTodo(editor) {
  4127. var $topSelectElems = editor.selection.getSelectionRangeTopNodes(); // 排除为[]的情况
  4128. if ($topSelectElems.length === 0) return;
  4129. return (0, _every["default"])($topSelectElems).call($topSelectElems, function ($topSelectElem) {
  4130. return isTodo($topSelectElem);
  4131. });
  4132. }
  4133. exports.isAllTodo = isAllTodo;
  4134. /**
  4135. * 根据所在的文本节点和光标在文本节点的位置获取截断的后节点内容
  4136. * @param node 顶级节点
  4137. * @param textNode 光标所在的文本节点
  4138. * @param pos 光标在文本节点的位置
  4139. */
  4140. function getCursorNextNode(node, textNode, pos) {
  4141. var _context;
  4142. if (!node.hasChildNodes()) return;
  4143. var newNode = node.cloneNode(); // 判断光标是否在末尾
  4144. var end = false;
  4145. if (textNode.nodeValue === '') {
  4146. end = true;
  4147. }
  4148. var delArr = [];
  4149. (0, _forEach["default"])(_context = node.childNodes).call(_context, function (v) {
  4150. //光标后的内容
  4151. if (!isContains(v, textNode) && end) {
  4152. newNode.appendChild(v.cloneNode(true));
  4153. if (v.nodeName !== 'BR') {
  4154. delArr.push(v);
  4155. }
  4156. } // 光标所在的区域
  4157. if (isContains(v, textNode)) {
  4158. if (v.nodeType === 1) {
  4159. var childNode = getCursorNextNode(v, textNode, pos);
  4160. if (childNode && childNode.textContent !== '') newNode === null || newNode === void 0 ? void 0 : newNode.appendChild(childNode);
  4161. }
  4162. if (v.nodeType === 3) {
  4163. if (textNode.isEqualNode(v)) {
  4164. var textContent = dealTextNode(v, pos);
  4165. newNode.textContent = textContent;
  4166. }
  4167. }
  4168. end = true;
  4169. }
  4170. }); // 删除选中后原来的节点
  4171. (0, _forEach["default"])(delArr).call(delArr, function (v) {
  4172. var node = v;
  4173. node.remove();
  4174. });
  4175. return newNode;
  4176. }
  4177. exports.getCursorNextNode = getCursorNextNode;
  4178. /**
  4179. * 判断otherNode是否包含在node中
  4180. * @param node 父节点
  4181. * @param otherNode 需要判断是不是被包含的节点
  4182. */
  4183. function isContains(node, otherNode) {
  4184. // 兼容ie11中textNode不支持contains方法
  4185. if (node.nodeType === 3) {
  4186. return node.nodeValue === otherNode.nodeValue;
  4187. }
  4188. return node.contains(otherNode);
  4189. }
  4190. /**
  4191. * 获取新的文本节点
  4192. * @param node 要处理的文本节点
  4193. * @param pos 光标在文本节点所在的位置
  4194. * @param start 设置为true时保留开始位置到光标的内容,设置为false时删去开始的内容
  4195. */
  4196. function dealTextNode(node, pos, start) {
  4197. if (start === void 0) {
  4198. start = true;
  4199. }
  4200. var content = node.nodeValue;
  4201. var oldContent = content === null || content === void 0 ? void 0 : (0, _slice["default"])(content).call(content, 0, pos);
  4202. content = content === null || content === void 0 ? void 0 : (0, _slice["default"])(content).call(content, pos); // start为false时替换content和oldContent
  4203. if (!start) {
  4204. var temp = content;
  4205. content = oldContent;
  4206. oldContent = temp;
  4207. }
  4208. node.nodeValue = oldContent;
  4209. return content;
  4210. }
  4211. exports.dealTextNode = dealTextNode;
  4212. /***/ }),
  4213. /* 106 */
  4214. /***/ (function(module, exports, __webpack_require__) {
  4215. "use strict";
  4216. /**
  4217. * @description 双栈实现撤销恢复
  4218. * @author fangzhicong
  4219. */
  4220. var _interopRequireDefault = __webpack_require__(0);
  4221. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  4222. (0, _defineProperty["default"])(exports, "__esModule", {
  4223. value: true
  4224. });
  4225. var stack_1 = __webpack_require__(446);
  4226. var Cache = function () {
  4227. function Cache(maxSize) {
  4228. this.maxSize = maxSize;
  4229. /**
  4230. * 上一步操作是否为 撤销/恢复
  4231. */
  4232. this.isRe = false;
  4233. this.data = new stack_1.CeilStack(maxSize);
  4234. this.revokeData = new stack_1.CeilStack(maxSize);
  4235. }
  4236. (0, _defineProperty["default"])(Cache.prototype, "size", {
  4237. /**
  4238. * 返回当前栈中的数据长度。格式为:[正常的数据的条数,被撤销的数据的条数]
  4239. */
  4240. get: function get() {
  4241. return [this.data.size, this.revokeData.size];
  4242. },
  4243. enumerable: false,
  4244. configurable: true
  4245. });
  4246. /**
  4247. * 重设数据缓存器的缓存长度(第一次有效)
  4248. */
  4249. Cache.prototype.resetMaxSize = function (maxSize) {
  4250. this.data.resetMax(maxSize);
  4251. this.revokeData.resetMax(maxSize);
  4252. };
  4253. /**
  4254. * 保存数据
  4255. */
  4256. Cache.prototype.save = function (data) {
  4257. if (this.isRe) {
  4258. this.revokeData.clear();
  4259. this.isRe = false;
  4260. }
  4261. this.data.instack(data);
  4262. return this;
  4263. };
  4264. /**
  4265. * 撤销
  4266. * @param fn 撤销时,如果有数据,执行的回调函数
  4267. */
  4268. Cache.prototype.revoke = function (fn) {
  4269. !this.isRe && (this.isRe = true);
  4270. var data = this.data.outstack();
  4271. if (data) {
  4272. this.revokeData.instack(data);
  4273. fn(data);
  4274. return true;
  4275. }
  4276. return false;
  4277. };
  4278. /**
  4279. * 恢复
  4280. * @param fn 恢复时,如果有数据,执行的回调函数
  4281. */
  4282. Cache.prototype.restore = function (fn) {
  4283. !this.isRe && (this.isRe = true);
  4284. var data = this.revokeData.outstack();
  4285. if (data) {
  4286. this.data.instack(data);
  4287. fn(data);
  4288. return true;
  4289. }
  4290. return false;
  4291. };
  4292. return Cache;
  4293. }();
  4294. exports["default"] = Cache;
  4295. /***/ }),
  4296. /* 107 */
  4297. /***/ (function(module, exports, __webpack_require__) {
  4298. /* eslint-disable es/no-symbol -- required for testing */
  4299. var NATIVE_SYMBOL = __webpack_require__(79);
  4300. module.exports = NATIVE_SYMBOL
  4301. && !Symbol.sham
  4302. && typeof Symbol.iterator == 'symbol';
  4303. /***/ }),
  4304. /* 108 */
  4305. /***/ (function(module, exports, __webpack_require__) {
  4306. var DESCRIPTORS = __webpack_require__(15);
  4307. var fails = __webpack_require__(12);
  4308. var createElement = __webpack_require__(82);
  4309. // Thank's IE8 for his funny defineProperty
  4310. module.exports = !DESCRIPTORS && !fails(function () {
  4311. // eslint-disable-next-line es/no-object-defineproperty -- requied for testing
  4312. return Object.defineProperty(createElement('div'), 'a', {
  4313. get: function () { return 7; }
  4314. }).a != 7;
  4315. });
  4316. /***/ }),
  4317. /* 109 */
  4318. /***/ (function(module, exports, __webpack_require__) {
  4319. var fails = __webpack_require__(12);
  4320. var replacement = /#|\.prototype\./;
  4321. var isForced = function (feature, detection) {
  4322. var value = data[normalize(feature)];
  4323. return value == POLYFILL ? true
  4324. : value == NATIVE ? false
  4325. : typeof detection == 'function' ? fails(detection)
  4326. : !!detection;
  4327. };
  4328. var normalize = isForced.normalize = function (string) {
  4329. return String(string).replace(replacement, '.').toLowerCase();
  4330. };
  4331. var data = isForced.data = {};
  4332. var NATIVE = isForced.NATIVE = 'N';
  4333. var POLYFILL = isForced.POLYFILL = 'P';
  4334. module.exports = isForced;
  4335. /***/ }),
  4336. /* 110 */
  4337. /***/ (function(module, exports, __webpack_require__) {
  4338. var has = __webpack_require__(17);
  4339. var toIndexedObject = __webpack_require__(29);
  4340. var indexOf = __webpack_require__(85).indexOf;
  4341. var hiddenKeys = __webpack_require__(54);
  4342. module.exports = function (object, names) {
  4343. var O = toIndexedObject(object);
  4344. var i = 0;
  4345. var result = [];
  4346. var key;
  4347. for (key in O) !has(hiddenKeys, key) && has(O, key) && result.push(key);
  4348. // Don't enum bug & hidden keys
  4349. while (names.length > i) if (has(O, key = names[i++])) {
  4350. ~indexOf(result, key) || result.push(key);
  4351. }
  4352. return result;
  4353. };
  4354. /***/ }),
  4355. /* 111 */
  4356. /***/ (function(module, exports, __webpack_require__) {
  4357. var getBuiltIn = __webpack_require__(25);
  4358. module.exports = getBuiltIn('document', 'documentElement');
  4359. /***/ }),
  4360. /* 112 */
  4361. /***/ (function(module, exports, __webpack_require__) {
  4362. var wellKnownSymbol = __webpack_require__(9);
  4363. var Iterators = __webpack_require__(42);
  4364. var ITERATOR = wellKnownSymbol('iterator');
  4365. var ArrayPrototype = Array.prototype;
  4366. // check on default Array iterator
  4367. module.exports = function (it) {
  4368. return it !== undefined && (Iterators.Array === it || ArrayPrototype[ITERATOR] === it);
  4369. };
  4370. /***/ }),
  4371. /* 113 */
  4372. /***/ (function(module, exports, __webpack_require__) {
  4373. var classof = __webpack_require__(71);
  4374. var Iterators = __webpack_require__(42);
  4375. var wellKnownSymbol = __webpack_require__(9);
  4376. var ITERATOR = wellKnownSymbol('iterator');
  4377. module.exports = function (it) {
  4378. if (it != undefined) return it[ITERATOR]
  4379. || it['@@iterator']
  4380. || Iterators[classof(it)];
  4381. };
  4382. /***/ }),
  4383. /* 114 */
  4384. /***/ (function(module, exports, __webpack_require__) {
  4385. var anObject = __webpack_require__(20);
  4386. module.exports = function (iterator) {
  4387. var returnMethod = iterator['return'];
  4388. if (returnMethod !== undefined) {
  4389. return anObject(returnMethod.call(iterator)).value;
  4390. }
  4391. };
  4392. /***/ }),
  4393. /* 115 */
  4394. /***/ (function(module, exports, __webpack_require__) {
  4395. var store = __webpack_require__(81);
  4396. var functionToString = Function.toString;
  4397. // this helper broken in `[email protected]`, so we can't use `shared` helper
  4398. if (typeof store.inspectSource != 'function') {
  4399. store.inspectSource = function (it) {
  4400. return functionToString.call(it);
  4401. };
  4402. }
  4403. module.exports = store.inspectSource;
  4404. /***/ }),
  4405. /* 116 */
  4406. /***/ (function(module, exports, __webpack_require__) {
  4407. "use strict";
  4408. var fails = __webpack_require__(12);
  4409. var getPrototypeOf = __webpack_require__(83);
  4410. var createNonEnumerableProperty = __webpack_require__(19);
  4411. var has = __webpack_require__(17);
  4412. var wellKnownSymbol = __webpack_require__(9);
  4413. var IS_PURE = __webpack_require__(39);
  4414. var ITERATOR = wellKnownSymbol('iterator');
  4415. var BUGGY_SAFARI_ITERATORS = false;
  4416. var returnThis = function () { return this; };
  4417. // `%IteratorPrototype%` object
  4418. // https://tc39.es/ecma262/#sec-%iteratorprototype%-object
  4419. var IteratorPrototype, PrototypeOfArrayIteratorPrototype, arrayIterator;
  4420. /* eslint-disable es/no-array-prototype-keys -- safe */
  4421. if ([].keys) {
  4422. arrayIterator = [].keys();
  4423. // Safari 8 has buggy iterators w/o `next`
  4424. if (!('next' in arrayIterator)) BUGGY_SAFARI_ITERATORS = true;
  4425. else {
  4426. PrototypeOfArrayIteratorPrototype = getPrototypeOf(getPrototypeOf(arrayIterator));
  4427. if (PrototypeOfArrayIteratorPrototype !== Object.prototype) IteratorPrototype = PrototypeOfArrayIteratorPrototype;
  4428. }
  4429. }
  4430. var NEW_ITERATOR_PROTOTYPE = IteratorPrototype == undefined || fails(function () {
  4431. var test = {};
  4432. // FF44- legacy iterators case
  4433. return IteratorPrototype[ITERATOR].call(test) !== test;
  4434. });
  4435. if (NEW_ITERATOR_PROTOTYPE) IteratorPrototype = {};
  4436. // `%IteratorPrototype%[@@iterator]()` method
  4437. // https://tc39.es/ecma262/#sec-%iteratorprototype%-@@iterator
  4438. if ((!IS_PURE || NEW_ITERATOR_PROTOTYPE) && !has(IteratorPrototype, ITERATOR)) {
  4439. createNonEnumerableProperty(IteratorPrototype, ITERATOR, returnThis);
  4440. }
  4441. module.exports = {
  4442. IteratorPrototype: IteratorPrototype,
  4443. BUGGY_SAFARI_ITERATORS: BUGGY_SAFARI_ITERATORS
  4444. };
  4445. /***/ }),
  4446. /* 117 */
  4447. /***/ (function(module, exports, __webpack_require__) {
  4448. var global = __webpack_require__(8);
  4449. module.exports = global.Promise;
  4450. /***/ }),
  4451. /* 118 */
  4452. /***/ (function(module, exports, __webpack_require__) {
  4453. var redefine = __webpack_require__(56);
  4454. module.exports = function (target, src, options) {
  4455. for (var key in src) {
  4456. if (options && options.unsafe && target[key]) target[key] = src[key];
  4457. else redefine(target, key, src[key], options);
  4458. } return target;
  4459. };
  4460. /***/ }),
  4461. /* 119 */
  4462. /***/ (function(module, exports, __webpack_require__) {
  4463. "use strict";
  4464. var getBuiltIn = __webpack_require__(25);
  4465. var definePropertyModule = __webpack_require__(18);
  4466. var wellKnownSymbol = __webpack_require__(9);
  4467. var DESCRIPTORS = __webpack_require__(15);
  4468. var SPECIES = wellKnownSymbol('species');
  4469. module.exports = function (CONSTRUCTOR_NAME) {
  4470. var Constructor = getBuiltIn(CONSTRUCTOR_NAME);
  4471. var defineProperty = definePropertyModule.f;
  4472. if (DESCRIPTORS && Constructor && !Constructor[SPECIES]) {
  4473. defineProperty(Constructor, SPECIES, {
  4474. configurable: true,
  4475. get: function () { return this; }
  4476. });
  4477. }
  4478. };
  4479. /***/ }),
  4480. /* 120 */
  4481. /***/ (function(module, exports, __webpack_require__) {
  4482. var wellKnownSymbol = __webpack_require__(9);
  4483. var ITERATOR = wellKnownSymbol('iterator');
  4484. var SAFE_CLOSING = false;
  4485. try {
  4486. var called = 0;
  4487. var iteratorWithReturn = {
  4488. next: function () {
  4489. return { done: !!called++ };
  4490. },
  4491. 'return': function () {
  4492. SAFE_CLOSING = true;
  4493. }
  4494. };
  4495. iteratorWithReturn[ITERATOR] = function () {
  4496. return this;
  4497. };
  4498. // eslint-disable-next-line es/no-array-from, no-throw-literal -- required for testing
  4499. Array.from(iteratorWithReturn, function () { throw 2; });
  4500. } catch (error) { /* empty */ }
  4501. module.exports = function (exec, SKIP_CLOSING) {
  4502. if (!SKIP_CLOSING && !SAFE_CLOSING) return false;
  4503. var ITERATION_SUPPORT = false;
  4504. try {
  4505. var object = {};
  4506. object[ITERATOR] = function () {
  4507. return {
  4508. next: function () {
  4509. return { done: ITERATION_SUPPORT = true };
  4510. }
  4511. };
  4512. };
  4513. exec(object);
  4514. } catch (error) { /* empty */ }
  4515. return ITERATION_SUPPORT;
  4516. };
  4517. /***/ }),
  4518. /* 121 */
  4519. /***/ (function(module, exports, __webpack_require__) {
  4520. var anObject = __webpack_require__(20);
  4521. var aFunction = __webpack_require__(34);
  4522. var wellKnownSymbol = __webpack_require__(9);
  4523. var SPECIES = wellKnownSymbol('species');
  4524. // `SpeciesConstructor` abstract operation
  4525. // https://tc39.es/ecma262/#sec-speciesconstructor
  4526. module.exports = function (O, defaultConstructor) {
  4527. var C = anObject(O).constructor;
  4528. var S;
  4529. return C === undefined || (S = anObject(C)[SPECIES]) == undefined ? defaultConstructor : aFunction(S);
  4530. };
  4531. /***/ }),
  4532. /* 122 */
  4533. /***/ (function(module, exports, __webpack_require__) {
  4534. var global = __webpack_require__(8);
  4535. var fails = __webpack_require__(12);
  4536. var bind = __webpack_require__(40);
  4537. var html = __webpack_require__(111);
  4538. var createElement = __webpack_require__(82);
  4539. var IS_IOS = __webpack_require__(123);
  4540. var IS_NODE = __webpack_require__(92);
  4541. var set = global.setImmediate;
  4542. var clear = global.clearImmediate;
  4543. var process = global.process;
  4544. var MessageChannel = global.MessageChannel;
  4545. var Dispatch = global.Dispatch;
  4546. var counter = 0;
  4547. var queue = {};
  4548. var ONREADYSTATECHANGE = 'onreadystatechange';
  4549. var location, defer, channel, port;
  4550. try {
  4551. // Deno throws a ReferenceError on `location` access without `--location` flag
  4552. location = global.location;
  4553. } catch (error) { /* empty */ }
  4554. var run = function (id) {
  4555. // eslint-disable-next-line no-prototype-builtins -- safe
  4556. if (queue.hasOwnProperty(id)) {
  4557. var fn = queue[id];
  4558. delete queue[id];
  4559. fn();
  4560. }
  4561. };
  4562. var runner = function (id) {
  4563. return function () {
  4564. run(id);
  4565. };
  4566. };
  4567. var listener = function (event) {
  4568. run(event.data);
  4569. };
  4570. var post = function (id) {
  4571. // old engines have not location.origin
  4572. global.postMessage(String(id), location.protocol + '//' + location.host);
  4573. };
  4574. // Node.js 0.9+ & IE10+ has setImmediate, otherwise:
  4575. if (!set || !clear) {
  4576. set = function setImmediate(fn) {
  4577. var args = [];
  4578. var argumentsLength = arguments.length;
  4579. var i = 1;
  4580. while (argumentsLength > i) args.push(arguments[i++]);
  4581. queue[++counter] = function () {
  4582. // eslint-disable-next-line no-new-func -- spec requirement
  4583. (typeof fn == 'function' ? fn : Function(fn)).apply(undefined, args);
  4584. };
  4585. defer(counter);
  4586. return counter;
  4587. };
  4588. clear = function clearImmediate(id) {
  4589. delete queue[id];
  4590. };
  4591. // Node.js 0.8-
  4592. if (IS_NODE) {
  4593. defer = function (id) {
  4594. process.nextTick(runner(id));
  4595. };
  4596. // Sphere (JS game engine) Dispatch API
  4597. } else if (Dispatch && Dispatch.now) {
  4598. defer = function (id) {
  4599. Dispatch.now(runner(id));
  4600. };
  4601. // Browsers with MessageChannel, includes WebWorkers
  4602. // except iOS - https://github.com/zloirock/core-js/issues/624
  4603. } else if (MessageChannel && !IS_IOS) {
  4604. channel = new MessageChannel();
  4605. port = channel.port2;
  4606. channel.port1.onmessage = listener;
  4607. defer = bind(port.postMessage, port, 1);
  4608. // Browsers with postMessage, skip WebWorkers
  4609. // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'
  4610. } else if (
  4611. global.addEventListener &&
  4612. typeof postMessage == 'function' &&
  4613. !global.importScripts &&
  4614. location && location.protocol !== 'file:' &&
  4615. !fails(post)
  4616. ) {
  4617. defer = post;
  4618. global.addEventListener('message', listener, false);
  4619. // IE8-
  4620. } else if (ONREADYSTATECHANGE in createElement('script')) {
  4621. defer = function (id) {
  4622. html.appendChild(createElement('script'))[ONREADYSTATECHANGE] = function () {
  4623. html.removeChild(this);
  4624. run(id);
  4625. };
  4626. };
  4627. // Rest old browsers
  4628. } else {
  4629. defer = function (id) {
  4630. setTimeout(runner(id), 0);
  4631. };
  4632. }
  4633. }
  4634. module.exports = {
  4635. set: set,
  4636. clear: clear
  4637. };
  4638. /***/ }),
  4639. /* 123 */
  4640. /***/ (function(module, exports, __webpack_require__) {
  4641. var userAgent = __webpack_require__(52);
  4642. module.exports = /(?:ipad|iphone|ipod).*applewebkit/i.test(userAgent);
  4643. /***/ }),
  4644. /* 124 */
  4645. /***/ (function(module, exports, __webpack_require__) {
  4646. var anObject = __webpack_require__(20);
  4647. var isObject = __webpack_require__(13);
  4648. var newPromiseCapability = __webpack_require__(72);
  4649. module.exports = function (C, x) {
  4650. anObject(C);
  4651. if (isObject(x) && x.constructor === C) return x;
  4652. var promiseCapability = newPromiseCapability.f(C);
  4653. var resolve = promiseCapability.resolve;
  4654. resolve(x);
  4655. return promiseCapability.promise;
  4656. };
  4657. /***/ }),
  4658. /* 125 */
  4659. /***/ (function(module, exports, __webpack_require__) {
  4660. module.exports = __webpack_require__(208);
  4661. /***/ }),
  4662. /* 126 */
  4663. /***/ (function(module, exports, __webpack_require__) {
  4664. "use strict";
  4665. var $ = __webpack_require__(5);
  4666. var global = __webpack_require__(8);
  4667. var InternalMetadataModule = __webpack_require__(127);
  4668. var fails = __webpack_require__(12);
  4669. var createNonEnumerableProperty = __webpack_require__(19);
  4670. var iterate = __webpack_require__(41);
  4671. var anInstance = __webpack_require__(91);
  4672. var isObject = __webpack_require__(13);
  4673. var setToStringTag = __webpack_require__(44);
  4674. var defineProperty = __webpack_require__(18).f;
  4675. var forEach = __webpack_require__(31).forEach;
  4676. var DESCRIPTORS = __webpack_require__(15);
  4677. var InternalStateModule = __webpack_require__(43);
  4678. var setInternalState = InternalStateModule.set;
  4679. var internalStateGetterFor = InternalStateModule.getterFor;
  4680. module.exports = function (CONSTRUCTOR_NAME, wrapper, common) {
  4681. var IS_MAP = CONSTRUCTOR_NAME.indexOf('Map') !== -1;
  4682. var IS_WEAK = CONSTRUCTOR_NAME.indexOf('Weak') !== -1;
  4683. var ADDER = IS_MAP ? 'set' : 'add';
  4684. var NativeConstructor = global[CONSTRUCTOR_NAME];
  4685. var NativePrototype = NativeConstructor && NativeConstructor.prototype;
  4686. var exported = {};
  4687. var Constructor;
  4688. if (!DESCRIPTORS || typeof NativeConstructor != 'function'
  4689. || !(IS_WEAK || NativePrototype.forEach && !fails(function () { new NativeConstructor().entries().next(); }))
  4690. ) {
  4691. // create collection constructor
  4692. Constructor = common.getConstructor(wrapper, CONSTRUCTOR_NAME, IS_MAP, ADDER);
  4693. InternalMetadataModule.enable();
  4694. } else {
  4695. Constructor = wrapper(function (target, iterable) {
  4696. setInternalState(anInstance(target, Constructor, CONSTRUCTOR_NAME), {
  4697. type: CONSTRUCTOR_NAME,
  4698. collection: new NativeConstructor()
  4699. });
  4700. if (iterable != undefined) iterate(iterable, target[ADDER], { that: target, AS_ENTRIES: IS_MAP });
  4701. });
  4702. var getInternalState = internalStateGetterFor(CONSTRUCTOR_NAME);
  4703. forEach(['add', 'clear', 'delete', 'forEach', 'get', 'has', 'set', 'keys', 'values', 'entries'], function (KEY) {
  4704. var IS_ADDER = KEY == 'add' || KEY == 'set';
  4705. if (KEY in NativePrototype && !(IS_WEAK && KEY == 'clear')) {
  4706. createNonEnumerableProperty(Constructor.prototype, KEY, function (a, b) {
  4707. var collection = getInternalState(this).collection;
  4708. if (!IS_ADDER && IS_WEAK && !isObject(a)) return KEY == 'get' ? undefined : false;
  4709. var result = collection[KEY](a === 0 ? 0 : a, b);
  4710. return IS_ADDER ? this : result;
  4711. });
  4712. }
  4713. });
  4714. IS_WEAK || defineProperty(Constructor.prototype, 'size', {
  4715. configurable: true,
  4716. get: function () {
  4717. return getInternalState(this).collection.size;
  4718. }
  4719. });
  4720. }
  4721. setToStringTag(Constructor, CONSTRUCTOR_NAME, false, true);
  4722. exported[CONSTRUCTOR_NAME] = Constructor;
  4723. $({ global: true, forced: true }, exported);
  4724. if (!IS_WEAK) common.setStrong(Constructor, CONSTRUCTOR_NAME, IS_MAP);
  4725. return Constructor;
  4726. };
  4727. /***/ }),
  4728. /* 127 */
  4729. /***/ (function(module, exports, __webpack_require__) {
  4730. var $ = __webpack_require__(5);
  4731. var hiddenKeys = __webpack_require__(54);
  4732. var isObject = __webpack_require__(13);
  4733. var has = __webpack_require__(17);
  4734. var defineProperty = __webpack_require__(18).f;
  4735. var getOwnPropertyNamesModule = __webpack_require__(98);
  4736. var getOwnPropertyNamesExternalModule = __webpack_require__(128);
  4737. var uid = __webpack_require__(67);
  4738. var FREEZING = __webpack_require__(211);
  4739. var REQUIRED = false;
  4740. var METADATA = uid('meta');
  4741. var id = 0;
  4742. // eslint-disable-next-line es/no-object-isextensible -- safe
  4743. var isExtensible = Object.isExtensible || function () {
  4744. return true;
  4745. };
  4746. var setMetadata = function (it) {
  4747. defineProperty(it, METADATA, { value: {
  4748. objectID: 'O' + id++, // object ID
  4749. weakData: {} // weak collections IDs
  4750. } });
  4751. };
  4752. var fastKey = function (it, create) {
  4753. // return a primitive with prefix
  4754. if (!isObject(it)) return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;
  4755. if (!has(it, METADATA)) {
  4756. // can't set metadata to uncaught frozen object
  4757. if (!isExtensible(it)) return 'F';
  4758. // not necessary to add metadata
  4759. if (!create) return 'E';
  4760. // add missing metadata
  4761. setMetadata(it);
  4762. // return object ID
  4763. } return it[METADATA].objectID;
  4764. };
  4765. var getWeakData = function (it, create) {
  4766. if (!has(it, METADATA)) {
  4767. // can't set metadata to uncaught frozen object
  4768. if (!isExtensible(it)) return true;
  4769. // not necessary to add metadata
  4770. if (!create) return false;
  4771. // add missing metadata
  4772. setMetadata(it);
  4773. // return the store of weak collections IDs
  4774. } return it[METADATA].weakData;
  4775. };
  4776. // add metadata on freeze-family methods calling
  4777. var onFreeze = function (it) {
  4778. if (FREEZING && REQUIRED && isExtensible(it) && !has(it, METADATA)) setMetadata(it);
  4779. return it;
  4780. };
  4781. var enable = function () {
  4782. meta.enable = function () { /* empty */ };
  4783. REQUIRED = true;
  4784. var getOwnPropertyNames = getOwnPropertyNamesModule.f;
  4785. var splice = [].splice;
  4786. var test = {};
  4787. test[METADATA] = 1;
  4788. // prevent exposing of metadata key
  4789. if (getOwnPropertyNames(test).length) {
  4790. getOwnPropertyNamesModule.f = function (it) {
  4791. var result = getOwnPropertyNames(it);
  4792. for (var i = 0, length = result.length; i < length; i++) {
  4793. if (result[i] === METADATA) {
  4794. splice.call(result, i, 1);
  4795. break;
  4796. }
  4797. } return result;
  4798. };
  4799. $({ target: 'Object', stat: true, forced: true }, {
  4800. getOwnPropertyNames: getOwnPropertyNamesExternalModule.f
  4801. });
  4802. }
  4803. };
  4804. var meta = module.exports = {
  4805. enable: enable,
  4806. fastKey: fastKey,
  4807. getWeakData: getWeakData,
  4808. onFreeze: onFreeze
  4809. };
  4810. hiddenKeys[METADATA] = true;
  4811. /***/ }),
  4812. /* 128 */
  4813. /***/ (function(module, exports, __webpack_require__) {
  4814. /* eslint-disable es/no-object-getownpropertynames -- safe */
  4815. var toIndexedObject = __webpack_require__(29);
  4816. var $getOwnPropertyNames = __webpack_require__(98).f;
  4817. var toString = {}.toString;
  4818. var windowNames = typeof window == 'object' && window && Object.getOwnPropertyNames
  4819. ? Object.getOwnPropertyNames(window) : [];
  4820. var getWindowNames = function (it) {
  4821. try {
  4822. return $getOwnPropertyNames(it);
  4823. } catch (error) {
  4824. return windowNames.slice();
  4825. }
  4826. };
  4827. // fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window
  4828. module.exports.f = function getOwnPropertyNames(it) {
  4829. return windowNames && toString.call(it) == '[object Window]'
  4830. ? getWindowNames(it)
  4831. : $getOwnPropertyNames(toIndexedObject(it));
  4832. };
  4833. /***/ }),
  4834. /* 129 */
  4835. /***/ (function(module, exports, __webpack_require__) {
  4836. "use strict";
  4837. var defineProperty = __webpack_require__(18).f;
  4838. var create = __webpack_require__(69);
  4839. var redefineAll = __webpack_require__(118);
  4840. var bind = __webpack_require__(40);
  4841. var anInstance = __webpack_require__(91);
  4842. var iterate = __webpack_require__(41);
  4843. var defineIterator = __webpack_require__(90);
  4844. var setSpecies = __webpack_require__(119);
  4845. var DESCRIPTORS = __webpack_require__(15);
  4846. var fastKey = __webpack_require__(127).fastKey;
  4847. var InternalStateModule = __webpack_require__(43);
  4848. var setInternalState = InternalStateModule.set;
  4849. var internalStateGetterFor = InternalStateModule.getterFor;
  4850. module.exports = {
  4851. getConstructor: function (wrapper, CONSTRUCTOR_NAME, IS_MAP, ADDER) {
  4852. var C = wrapper(function (that, iterable) {
  4853. anInstance(that, C, CONSTRUCTOR_NAME);
  4854. setInternalState(that, {
  4855. type: CONSTRUCTOR_NAME,
  4856. index: create(null),
  4857. first: undefined,
  4858. last: undefined,
  4859. size: 0
  4860. });
  4861. if (!DESCRIPTORS) that.size = 0;
  4862. if (iterable != undefined) iterate(iterable, that[ADDER], { that: that, AS_ENTRIES: IS_MAP });
  4863. });
  4864. var getInternalState = internalStateGetterFor(CONSTRUCTOR_NAME);
  4865. var define = function (that, key, value) {
  4866. var state = getInternalState(that);
  4867. var entry = getEntry(that, key);
  4868. var previous, index;
  4869. // change existing entry
  4870. if (entry) {
  4871. entry.value = value;
  4872. // create new entry
  4873. } else {
  4874. state.last = entry = {
  4875. index: index = fastKey(key, true),
  4876. key: key,
  4877. value: value,
  4878. previous: previous = state.last,
  4879. next: undefined,
  4880. removed: false
  4881. };
  4882. if (!state.first) state.first = entry;
  4883. if (previous) previous.next = entry;
  4884. if (DESCRIPTORS) state.size++;
  4885. else that.size++;
  4886. // add to index
  4887. if (index !== 'F') state.index[index] = entry;
  4888. } return that;
  4889. };
  4890. var getEntry = function (that, key) {
  4891. var state = getInternalState(that);
  4892. // fast case
  4893. var index = fastKey(key);
  4894. var entry;
  4895. if (index !== 'F') return state.index[index];
  4896. // frozen object case
  4897. for (entry = state.first; entry; entry = entry.next) {
  4898. if (entry.key == key) return entry;
  4899. }
  4900. };
  4901. redefineAll(C.prototype, {
  4902. // `{ Map, Set }.prototype.clear()` methods
  4903. // https://tc39.es/ecma262/#sec-map.prototype.clear
  4904. // https://tc39.es/ecma262/#sec-set.prototype.clear
  4905. clear: function clear() {
  4906. var that = this;
  4907. var state = getInternalState(that);
  4908. var data = state.index;
  4909. var entry = state.first;
  4910. while (entry) {
  4911. entry.removed = true;
  4912. if (entry.previous) entry.previous = entry.previous.next = undefined;
  4913. delete data[entry.index];
  4914. entry = entry.next;
  4915. }
  4916. state.first = state.last = undefined;
  4917. if (DESCRIPTORS) state.size = 0;
  4918. else that.size = 0;
  4919. },
  4920. // `{ Map, Set }.prototype.delete(key)` methods
  4921. // https://tc39.es/ecma262/#sec-map.prototype.delete
  4922. // https://tc39.es/ecma262/#sec-set.prototype.delete
  4923. 'delete': function (key) {
  4924. var that = this;
  4925. var state = getInternalState(that);
  4926. var entry = getEntry(that, key);
  4927. if (entry) {
  4928. var next = entry.next;
  4929. var prev = entry.previous;
  4930. delete state.index[entry.index];
  4931. entry.removed = true;
  4932. if (prev) prev.next = next;
  4933. if (next) next.previous = prev;
  4934. if (state.first == entry) state.first = next;
  4935. if (state.last == entry) state.last = prev;
  4936. if (DESCRIPTORS) state.size--;
  4937. else that.size--;
  4938. } return !!entry;
  4939. },
  4940. // `{ Map, Set }.prototype.forEach(callbackfn, thisArg = undefined)` methods
  4941. // https://tc39.es/ecma262/#sec-map.prototype.foreach
  4942. // https://tc39.es/ecma262/#sec-set.prototype.foreach
  4943. forEach: function forEach(callbackfn /* , that = undefined */) {
  4944. var state = getInternalState(this);
  4945. var boundFunction = bind(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3);
  4946. var entry;
  4947. while (entry = entry ? entry.next : state.first) {
  4948. boundFunction(entry.value, entry.key, this);
  4949. // revert to the last existing entry
  4950. while (entry && entry.removed) entry = entry.previous;
  4951. }
  4952. },
  4953. // `{ Map, Set}.prototype.has(key)` methods
  4954. // https://tc39.es/ecma262/#sec-map.prototype.has
  4955. // https://tc39.es/ecma262/#sec-set.prototype.has
  4956. has: function has(key) {
  4957. return !!getEntry(this, key);
  4958. }
  4959. });
  4960. redefineAll(C.prototype, IS_MAP ? {
  4961. // `Map.prototype.get(key)` method
  4962. // https://tc39.es/ecma262/#sec-map.prototype.get
  4963. get: function get(key) {
  4964. var entry = getEntry(this, key);
  4965. return entry && entry.value;
  4966. },
  4967. // `Map.prototype.set(key, value)` method
  4968. // https://tc39.es/ecma262/#sec-map.prototype.set
  4969. set: function set(key, value) {
  4970. return define(this, key === 0 ? 0 : key, value);
  4971. }
  4972. } : {
  4973. // `Set.prototype.add(value)` method
  4974. // https://tc39.es/ecma262/#sec-set.prototype.add
  4975. add: function add(value) {
  4976. return define(this, value = value === 0 ? 0 : value, value);
  4977. }
  4978. });
  4979. if (DESCRIPTORS) defineProperty(C.prototype, 'size', {
  4980. get: function () {
  4981. return getInternalState(this).size;
  4982. }
  4983. });
  4984. return C;
  4985. },
  4986. setStrong: function (C, CONSTRUCTOR_NAME, IS_MAP) {
  4987. var ITERATOR_NAME = CONSTRUCTOR_NAME + ' Iterator';
  4988. var getInternalCollectionState = internalStateGetterFor(CONSTRUCTOR_NAME);
  4989. var getInternalIteratorState = internalStateGetterFor(ITERATOR_NAME);
  4990. // `{ Map, Set }.prototype.{ keys, values, entries, @@iterator }()` methods
  4991. // https://tc39.es/ecma262/#sec-map.prototype.entries
  4992. // https://tc39.es/ecma262/#sec-map.prototype.keys
  4993. // https://tc39.es/ecma262/#sec-map.prototype.values
  4994. // https://tc39.es/ecma262/#sec-map.prototype-@@iterator
  4995. // https://tc39.es/ecma262/#sec-set.prototype.entries
  4996. // https://tc39.es/ecma262/#sec-set.prototype.keys
  4997. // https://tc39.es/ecma262/#sec-set.prototype.values
  4998. // https://tc39.es/ecma262/#sec-set.prototype-@@iterator
  4999. defineIterator(C, CONSTRUCTOR_NAME, function (iterated, kind) {
  5000. setInternalState(this, {
  5001. type: ITERATOR_NAME,
  5002. target: iterated,
  5003. state: getInternalCollectionState(iterated),
  5004. kind: kind,
  5005. last: undefined
  5006. });
  5007. }, function () {
  5008. var state = getInternalIteratorState(this);
  5009. var kind = state.kind;
  5010. var entry = state.last;
  5011. // revert to the last existing entry
  5012. while (entry && entry.removed) entry = entry.previous;
  5013. // get next entry
  5014. if (!state.target || !(state.last = entry = entry ? entry.next : state.state.first)) {
  5015. // or finish the iteration
  5016. state.target = undefined;
  5017. return { value: undefined, done: true };
  5018. }
  5019. // return step by kind
  5020. if (kind == 'keys') return { value: entry.key, done: false };
  5021. if (kind == 'values') return { value: entry.value, done: false };
  5022. return { value: [entry.key, entry.value], done: false };
  5023. }, IS_MAP ? 'entries' : 'values', !IS_MAP, true);
  5024. // `{ Map, Set }.prototype[@@species]` accessors
  5025. // https://tc39.es/ecma262/#sec-get-map-@@species
  5026. // https://tc39.es/ecma262/#sec-get-set-@@species
  5027. setSpecies(CONSTRUCTOR_NAME);
  5028. }
  5029. };
  5030. /***/ }),
  5031. /* 130 */
  5032. /***/ (function(module, exports) {
  5033. // eslint-disable-next-line es/no-object-getownpropertysymbols -- safe
  5034. exports.f = Object.getOwnPropertySymbols;
  5035. /***/ }),
  5036. /* 131 */
  5037. /***/ (function(module, exports, __webpack_require__) {
  5038. var defineWellKnownSymbol = __webpack_require__(10);
  5039. // `Symbol.iterator` well-known symbol
  5040. // https://tc39.es/ecma262/#sec-symbol.iterator
  5041. defineWellKnownSymbol('iterator');
  5042. /***/ }),
  5043. /* 132 */
  5044. /***/ (function(module, exports, __webpack_require__) {
  5045. module.exports = __webpack_require__(283);
  5046. /***/ }),
  5047. /* 133 */
  5048. /***/ (function(module, exports, __webpack_require__) {
  5049. "use strict";
  5050. /**
  5051. * @description 样式配置
  5052. * @author wangfupeng
  5053. */
  5054. var _interopRequireDefault = __webpack_require__(0);
  5055. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5056. (0, _defineProperty["default"])(exports, "__esModule", {
  5057. value: true
  5058. });
  5059. exports["default"] = {
  5060. zIndex: 10000
  5061. };
  5062. /***/ }),
  5063. /* 134 */
  5064. /***/ (function(module, exports, __webpack_require__) {
  5065. "use strict";
  5066. /**
  5067. * @description 默认常量配置
  5068. * @author xiaokyo
  5069. */
  5070. var _interopRequireDefault = __webpack_require__(0);
  5071. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5072. (0, _defineProperty["default"])(exports, "__esModule", {
  5073. value: true
  5074. });
  5075. exports["default"] = {
  5076. focus: true,
  5077. height: 300,
  5078. placeholder: '请输入正文',
  5079. zIndexFullScreen: 10002,
  5080. showFullScreen: true
  5081. };
  5082. /***/ }),
  5083. /* 135 */
  5084. /***/ (function(module, exports, __webpack_require__) {
  5085. "use strict";
  5086. /**
  5087. * @description 处理粘贴逻辑
  5088. * @author wangfupeng
  5089. */
  5090. var _interopRequireDefault = __webpack_require__(0);
  5091. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5092. var _forEach = _interopRequireDefault(__webpack_require__(4));
  5093. (0, _defineProperty["default"])(exports, "__esModule", {
  5094. value: true
  5095. });
  5096. exports.getPasteImgs = exports.getPasteHtml = exports.getPasteText = void 0;
  5097. var tslib_1 = __webpack_require__(2);
  5098. var util_1 = __webpack_require__(6);
  5099. var parse_html_1 = tslib_1.__importDefault(__webpack_require__(307));
  5100. /**
  5101. * 获取粘贴的纯文本
  5102. * @param e Event 参数
  5103. */
  5104. function getPasteText(e) {
  5105. // const clipboardData = e.clipboardData || (e.originalEvent && e.originalEvent.clipboardData)
  5106. var clipboardData = e.clipboardData; // 暂不考虑 originalEvent 的情况
  5107. var pasteText = '';
  5108. if (clipboardData == null) {
  5109. pasteText = window.clipboardData && window.clipboardData.getData('text');
  5110. } else {
  5111. pasteText = clipboardData.getData('text/plain');
  5112. }
  5113. return util_1.replaceHtmlSymbol(pasteText);
  5114. }
  5115. exports.getPasteText = getPasteText;
  5116. /**
  5117. * 获取粘贴的 html 字符串
  5118. * @param e Event 参数
  5119. * @param filterStyle 是否过滤 style 样式
  5120. * @param ignoreImg 是否忽略 img 标签
  5121. */
  5122. function getPasteHtml(e, filterStyle, ignoreImg) {
  5123. if (filterStyle === void 0) {
  5124. filterStyle = true;
  5125. }
  5126. if (ignoreImg === void 0) {
  5127. ignoreImg = false;
  5128. }
  5129. var clipboardData = e.clipboardData; // 暂不考虑 originalEvent 的情况
  5130. var pasteHtml = '';
  5131. if (clipboardData) {
  5132. pasteHtml = clipboardData.getData('text/html');
  5133. } // 无法通过 'text/html' 格式获取 html,则尝试获取 text
  5134. if (!pasteHtml) {
  5135. var text = getPasteText(e);
  5136. if (!text) {
  5137. return ''; // 没有找到任何文字,则返回
  5138. }
  5139. pasteHtml = "<p>" + text + "</p>";
  5140. } // 转译<1,后面跟数字的转译成 &lt;1
  5141. pasteHtml = pasteHtml.replace(/<(\d)/gm, function (_, num) {
  5142. return '&lt;' + num;
  5143. }); // pdf复制只会有一个meta标签,parseHtml中的过滤meta标签会导致后面内容丢失
  5144. pasteHtml = pasteHtml.replace(/<(\/?meta.*?)>/gim, ''); // 剔除多余的标签、属性
  5145. pasteHtml = parse_html_1["default"](pasteHtml, filterStyle, ignoreImg);
  5146. return pasteHtml;
  5147. }
  5148. exports.getPasteHtml = getPasteHtml;
  5149. /**
  5150. * 获取粘贴的图片文件
  5151. * @param e Event 参数
  5152. */
  5153. function getPasteImgs(e) {
  5154. var _a;
  5155. var result = [];
  5156. var txt = getPasteText(e);
  5157. if (txt) {
  5158. // 有文字,就忽略图片
  5159. return result;
  5160. }
  5161. var items = (_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.items;
  5162. if (!items) return result;
  5163. (0, _forEach["default"])(util_1).call(util_1, items, function (key, value) {
  5164. var type = value.type;
  5165. if (/image/i.test(type)) {
  5166. result.push(value.getAsFile());
  5167. }
  5168. });
  5169. return result;
  5170. }
  5171. exports.getPasteImgs = getPasteImgs;
  5172. /***/ }),
  5173. /* 136 */
  5174. /***/ (function(module, exports, __webpack_require__) {
  5175. module.exports = __webpack_require__(309);
  5176. /***/ }),
  5177. /* 137 */
  5178. /***/ (function(module, exports, __webpack_require__) {
  5179. module.exports = __webpack_require__(325);
  5180. /***/ }),
  5181. /* 138 */
  5182. /***/ (function(module, exports, __webpack_require__) {
  5183. "use strict";
  5184. /**
  5185. * @description 下拉列表 class
  5186. */
  5187. var _interopRequireDefault = __webpack_require__(0);
  5188. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5189. var _forEach = _interopRequireDefault(__webpack_require__(4));
  5190. var _setTimeout2 = _interopRequireDefault(__webpack_require__(48));
  5191. (0, _defineProperty["default"])(exports, "__esModule", {
  5192. value: true
  5193. });
  5194. var tslib_1 = __webpack_require__(2);
  5195. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  5196. var const_1 = __webpack_require__(7);
  5197. var DropList = function () {
  5198. function DropList(menu, conf) {
  5199. var _this = this;
  5200. this.hideTimeoutId = 0;
  5201. this.menu = menu;
  5202. this.conf = conf; // 容器
  5203. var $container = dom_core_1["default"]('<div class="w-e-droplist"></div>'); // 标题
  5204. var $title = dom_core_1["default"]("<p>" + conf.title + "</p>");
  5205. $title.addClass('w-e-dp-title');
  5206. $container.append($title); // 列表和类型
  5207. var list = conf.list || [];
  5208. var type = conf.type || 'list'; // item 的点击事件
  5209. var clickHandler = conf.clickHandler || const_1.EMPTY_FN; // 加入 DOM 并绑定事件
  5210. var $list = dom_core_1["default"]('<ul class="' + (type === 'list' ? 'w-e-list' : 'w-e-block') + '"></ul>');
  5211. (0, _forEach["default"])(list).call(list, function (item) {
  5212. var $elem = item.$elem;
  5213. var value = item.value;
  5214. var $li = dom_core_1["default"]('<li class="w-e-item"></li>');
  5215. if ($elem) {
  5216. $li.append($elem);
  5217. $list.append($li);
  5218. $li.on('click', function (e) {
  5219. clickHandler(value); // 阻止冒泡
  5220. e.stopPropagation(); // item 点击之后,隐藏 list
  5221. _this.hideTimeoutId = (0, _setTimeout2["default"])(function () {
  5222. _this.hide();
  5223. });
  5224. });
  5225. }
  5226. });
  5227. $container.append($list); // 绑定隐藏事件
  5228. $container.on('mouseleave', function () {
  5229. _this.hideTimeoutId = (0, _setTimeout2["default"])(function () {
  5230. _this.hide();
  5231. });
  5232. }); // 记录属性
  5233. this.$container = $container;
  5234. this.rendered = false;
  5235. this._show = false;
  5236. }
  5237. /**
  5238. * 显示 DropList
  5239. */
  5240. DropList.prototype.show = function () {
  5241. if (this.hideTimeoutId) {
  5242. // 清除之前的定时隐藏
  5243. clearTimeout(this.hideTimeoutId);
  5244. }
  5245. var menu = this.menu;
  5246. var $menuELem = menu.$elem;
  5247. var $container = this.$container;
  5248. if (this._show) {
  5249. return;
  5250. }
  5251. if (this.rendered) {
  5252. // 显示
  5253. $container.show();
  5254. } else {
  5255. // 加入 DOM 之前先定位位置
  5256. var menuHeight = $menuELem.getBoundingClientRect().height || 0;
  5257. var width = this.conf.width || 100; // 默认为 100
  5258. $container.css('margin-top', menuHeight + 'px').css('width', width + 'px'); // 加入到 DOM
  5259. $menuELem.append($container);
  5260. this.rendered = true;
  5261. } // 修改属性
  5262. this._show = true;
  5263. };
  5264. /**
  5265. * 隐藏 DropList
  5266. */
  5267. DropList.prototype.hide = function () {
  5268. var $container = this.$container;
  5269. if (!this._show) {
  5270. return;
  5271. } // 隐藏并需改属性
  5272. $container.hide();
  5273. this._show = false;
  5274. };
  5275. (0, _defineProperty["default"])(DropList.prototype, "isShow", {
  5276. get: function get() {
  5277. return this._show;
  5278. },
  5279. enumerable: false,
  5280. configurable: true
  5281. });
  5282. return DropList;
  5283. }();
  5284. exports["default"] = DropList;
  5285. /***/ }),
  5286. /* 139 */
  5287. /***/ (function(module, exports, __webpack_require__) {
  5288. "use strict";
  5289. /**
  5290. * @description 检查选区是否在链接中,即菜单是否应该 active
  5291. * @author wangfupeng
  5292. */
  5293. var _interopRequireDefault = __webpack_require__(0);
  5294. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5295. (0, _defineProperty["default"])(exports, "__esModule", {
  5296. value: true
  5297. });
  5298. function isActive(editor) {
  5299. var $selectionELem = editor.selection.getSelectionContainerElem();
  5300. if (!($selectionELem === null || $selectionELem === void 0 ? void 0 : $selectionELem.length)) {
  5301. return false;
  5302. }
  5303. if ($selectionELem.getNodeName() === 'A') {
  5304. return true;
  5305. } else {
  5306. return false;
  5307. }
  5308. }
  5309. exports["default"] = isActive;
  5310. /***/ }),
  5311. /* 140 */
  5312. /***/ (function(module, exports, __webpack_require__) {
  5313. "use strict";
  5314. /**
  5315. * @description 上传的核心方法
  5316. * @author wangfupeng
  5317. */
  5318. var _interopRequireDefault = __webpack_require__(0);
  5319. var _typeof2 = _interopRequireDefault(__webpack_require__(100));
  5320. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5321. var _forEach = _interopRequireDefault(__webpack_require__(4));
  5322. (0, _defineProperty["default"])(exports, "__esModule", {
  5323. value: true
  5324. });
  5325. var util_1 = __webpack_require__(6);
  5326. /**
  5327. * 发送 post 请求(用于文件上传)
  5328. * @param url url
  5329. * @param option 配置项
  5330. */
  5331. function post(url, option) {
  5332. var xhr = new XMLHttpRequest();
  5333. xhr.open('POST', url); // 超时,默认 10s
  5334. xhr.timeout = option.timeout || 10 * 1000;
  5335. xhr.ontimeout = function () {
  5336. console.error('wangEditor - 请求超时');
  5337. option.onTimeout && option.onTimeout(xhr);
  5338. }; // 进度
  5339. if (xhr.upload) {
  5340. xhr.upload.onprogress = function (e) {
  5341. var percent = e.loaded / e.total;
  5342. option.onProgress && option.onProgress(percent, e);
  5343. };
  5344. } // 自定义 header
  5345. if (option.headers) {
  5346. (0, _forEach["default"])(util_1).call(util_1, option.headers, function (key, val) {
  5347. xhr.setRequestHeader(key, val);
  5348. });
  5349. } // 跨域传 cookie
  5350. xhr.withCredentials = !!option.withCredentials; // 上传之前的钩子函数,在 xhr.send() 之前执行
  5351. if (option.beforeSend) {
  5352. var beforeResult = option.beforeSend(xhr);
  5353. if (beforeResult && (0, _typeof2["default"])(beforeResult) === 'object') {
  5354. if (beforeResult.prevent) {
  5355. // 如果返回的结果是 {prevent: true, msg: 'xxxx'} 则表示用户放弃上传
  5356. return beforeResult.msg;
  5357. }
  5358. }
  5359. } // 服务端返回之后
  5360. xhr.onreadystatechange = function () {
  5361. if (xhr.readyState !== 4) return;
  5362. var status = xhr.status;
  5363. if (status < 200) return; // 请求发送过程中,尚未返回
  5364. if (status >= 300 && status < 400) return; // 重定向
  5365. if (status >= 400) {
  5366. // 40x 50x 报错
  5367. console.error('wangEditor - XHR 报错,状态码 ' + status);
  5368. if (option.onError) option.onError(xhr); // 有,则执行 onError 函数即可
  5369. return;
  5370. } // status = 200 ,得到结果
  5371. var resultStr = xhr.responseText;
  5372. var result;
  5373. if ((0, _typeof2["default"])(resultStr) !== 'object') {
  5374. try {
  5375. result = JSON.parse(resultStr);
  5376. } catch (ex) {
  5377. console.error('wangEditor - 返回结果不是 JSON 格式', resultStr);
  5378. if (option.onFail) option.onFail(xhr, resultStr);
  5379. return;
  5380. }
  5381. } else {
  5382. result = resultStr;
  5383. }
  5384. option.onSuccess(xhr, result);
  5385. }; // 发送请求
  5386. xhr.send(option.formData || null);
  5387. return xhr;
  5388. }
  5389. exports["default"] = post;
  5390. /***/ }),
  5391. /* 141 */
  5392. /***/ (function(module, exports, __webpack_require__) {
  5393. "use strict";
  5394. /**
  5395. * @description 上传进度条
  5396. * @author wangfupeng
  5397. */
  5398. var _interopRequireDefault = __webpack_require__(0);
  5399. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5400. var _now = _interopRequireDefault(__webpack_require__(357));
  5401. var _setTimeout2 = _interopRequireDefault(__webpack_require__(48));
  5402. (0, _defineProperty["default"])(exports, "__esModule", {
  5403. value: true
  5404. });
  5405. var tslib_1 = __webpack_require__(2);
  5406. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  5407. var Progress = function () {
  5408. function Progress(editor) {
  5409. this.editor = editor;
  5410. this.$textContainer = editor.$textContainerElem;
  5411. this.$bar = dom_core_1["default"]('<div class="w-e-progress"></div>');
  5412. this.isShow = false;
  5413. this.time = 0;
  5414. this.timeoutId = 0;
  5415. }
  5416. /**
  5417. * 显示进度条
  5418. * @param progress 进度百分比
  5419. */
  5420. Progress.prototype.show = function (progress) {
  5421. var _this = this; // 不要重新显示
  5422. if (this.isShow) {
  5423. return;
  5424. }
  5425. this.isShow = true; // 渲染 $bar
  5426. var $bar = this.$bar;
  5427. var $textContainer = this.$textContainer;
  5428. $textContainer.append($bar); // 改变进度条(防抖,100ms 渲染一次)
  5429. if ((0, _now["default"])() - this.time > 100) {
  5430. if (progress <= 1) {
  5431. $bar.css('width', progress * 100 + '%');
  5432. this.time = (0, _now["default"])();
  5433. }
  5434. } // 500ms 之后隐藏
  5435. var timeoutId = this.timeoutId;
  5436. if (timeoutId) {
  5437. clearTimeout(timeoutId);
  5438. }
  5439. this.timeoutId = (0, _setTimeout2["default"])(function () {
  5440. _this.hide();
  5441. }, 500);
  5442. };
  5443. /**
  5444. * 隐藏
  5445. */
  5446. Progress.prototype.hide = function () {
  5447. var $bar = this.$bar;
  5448. $bar.remove();
  5449. this.isShow = false;
  5450. this.time = 0;
  5451. this.timeoutId = 0;
  5452. };
  5453. return Progress;
  5454. }();
  5455. exports["default"] = Progress;
  5456. /***/ }),
  5457. /* 142 */
  5458. /***/ (function(module, exports, __webpack_require__) {
  5459. "use strict";
  5460. /**
  5461. * @description 无序列表/有序列表
  5462. * @author tonghan
  5463. */
  5464. var _interopRequireDefault = __webpack_require__(0);
  5465. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5466. (0, _defineProperty["default"])(exports, "__esModule", {
  5467. value: true
  5468. });
  5469. exports.ListType = void 0;
  5470. var tslib_1 = __webpack_require__(2);
  5471. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  5472. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  5473. var utils_1 = __webpack_require__(49);
  5474. var ListHandle_1 = tslib_1.__importStar(__webpack_require__(386));
  5475. /**
  5476. * 列表的种类
  5477. */
  5478. var ListType;
  5479. (function (ListType) {
  5480. ListType["OrderedList"] = "OL";
  5481. ListType["UnorderedList"] = "UL";
  5482. })(ListType = exports.ListType || (exports.ListType = {}));
  5483. var List = function (_super) {
  5484. tslib_1.__extends(List, _super);
  5485. function List(editor) {
  5486. var _this = this;
  5487. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5E8F\u5217\">\n <i class=\"w-e-icon-list2\"></i>\n </div>");
  5488. var dropListConf = {
  5489. width: 130,
  5490. title: '序列',
  5491. type: 'list',
  5492. list: [{
  5493. $elem: dom_core_1["default"]("\n <p>\n <i class=\"w-e-icon-list2 w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.list.无序列表') + "\n <p>"),
  5494. value: ListType.UnorderedList
  5495. }, {
  5496. $elem: dom_core_1["default"]("<p>\n <i class=\"w-e-icon-list-numbered w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.list.有序列表') + "\n <p>"),
  5497. value: ListType.OrderedList
  5498. }],
  5499. clickHandler: function clickHandler(value) {
  5500. // 注意 this 是指向当前的 List 对象
  5501. _this.command(value);
  5502. }
  5503. };
  5504. _this = _super.call(this, $elem, editor, dropListConf) || this;
  5505. return _this;
  5506. }
  5507. List.prototype.command = function (type) {
  5508. var editor = this.editor;
  5509. var $selectionElem = editor.selection.getSelectionContainerElem(); // 选区范围的 DOM 元素不存在,不执行命令
  5510. if ($selectionElem === undefined) return; // 获取选区范围内的顶级 DOM 元素
  5511. this.handleSelectionRangeNodes(type); // 是否激活
  5512. this.tryChangeActive();
  5513. };
  5514. List.prototype.validator = function ($startElem, $endElem, $textElem) {
  5515. if (!$startElem.length || !$endElem.length || $textElem.equal($startElem) || $textElem.equal($endElem)) {
  5516. return false;
  5517. }
  5518. return true;
  5519. };
  5520. List.prototype.handleSelectionRangeNodes = function (listType) {
  5521. var editor = this.editor;
  5522. var selection = editor.selection; // 获取 序列标签
  5523. var listTarget = listType.toLowerCase(); // 获取相对应的 元属节点
  5524. var $selectionElem = selection.getSelectionContainerElem();
  5525. var $startElem = selection.getSelectionStartElem().getNodeTop(editor);
  5526. var $endElem = selection.getSelectionEndElem().getNodeTop(editor); // 验证是否执行 处理逻辑
  5527. if (!this.validator($startElem, $endElem, editor.$textElem)) {
  5528. return;
  5529. } // 获取选区
  5530. var _range = selection.getRange();
  5531. var _collapsed = _range === null || _range === void 0 ? void 0 : _range.collapsed; // 防止光标的时候判断异常
  5532. if (!editor.$textElem.equal($selectionElem)) {
  5533. $selectionElem = $selectionElem.getNodeTop(editor);
  5534. }
  5535. var options = {
  5536. editor: editor,
  5537. listType: listType,
  5538. listTarget: listTarget,
  5539. $selectionElem: $selectionElem,
  5540. $startElem: $startElem,
  5541. $endElem: $endElem
  5542. };
  5543. var classType; // =====================================
  5544. // 当 selectionElem 属于序列元素的时候
  5545. // 代表着当前选区一定是在一个序列元素内的
  5546. // =====================================
  5547. if (this.isOrderElem($selectionElem)) {
  5548. classType = ListHandle_1.ClassType.Wrap;
  5549. } // =====================================
  5550. // 当 startElem 和 endElem 属于序列元素的时候
  5551. // 代表着当前选区一定是在再两个序列的中间(包括两个序列)
  5552. // =====================================
  5553. else if (this.isOrderElem($startElem) && this.isOrderElem($endElem)) {
  5554. classType = ListHandle_1.ClassType.Join;
  5555. } // =====================================
  5556. // 选区开始元素为 序列 的时候
  5557. // =====================================
  5558. else if (this.isOrderElem($startElem)) {
  5559. classType = ListHandle_1.ClassType.StartJoin;
  5560. } // =====================================
  5561. // 选区结束元素为 序列 的时候
  5562. // =====================================
  5563. else if (this.isOrderElem($endElem)) {
  5564. classType = ListHandle_1.ClassType.EndJoin;
  5565. } // =====================================
  5566. // 当选区不是序列内且开头和结尾不是序列的时候
  5567. // 直接获取所有顶级段落然后过滤
  5568. // 代表着 设置序列 的操作
  5569. // =====================================
  5570. else {
  5571. classType = ListHandle_1.ClassType.Other;
  5572. }
  5573. var listHandleCmd = new ListHandle_1["default"](ListHandle_1.createListHandle(classType, options, _range)); // 更新选区
  5574. utils_1.updateRange(editor, listHandleCmd.getSelectionRangeElem(), !!_collapsed);
  5575. };
  5576. /**
  5577. * 是否是序列元素节点 UL and OL
  5578. * @param $node
  5579. */
  5580. List.prototype.isOrderElem = function ($node) {
  5581. var nodeName = $node.getNodeName();
  5582. if (nodeName === ListType.OrderedList || nodeName === ListType.UnorderedList) {
  5583. return true;
  5584. }
  5585. return false;
  5586. };
  5587. List.prototype.tryChangeActive = function () {};
  5588. return List;
  5589. }(DropListMenu_1["default"]);
  5590. exports["default"] = List;
  5591. /***/ }),
  5592. /* 143 */
  5593. /***/ (function(module, exports, __webpack_require__) {
  5594. module.exports = __webpack_require__(410);
  5595. /***/ }),
  5596. /* 144 */
  5597. /***/ (function(module, exports, __webpack_require__) {
  5598. "use strict";
  5599. /**
  5600. * @description 检查选区是否在代码中,即菜单是否应该 active
  5601. * @author lkw
  5602. */
  5603. var _interopRequireDefault = __webpack_require__(0);
  5604. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5605. (0, _defineProperty["default"])(exports, "__esModule", {
  5606. value: true
  5607. });
  5608. function isActive(editor) {
  5609. var $selectionELem = editor.selection.getSelectionContainerElem();
  5610. if (!($selectionELem === null || $selectionELem === void 0 ? void 0 : $selectionELem.length)) {
  5611. return false;
  5612. }
  5613. if ($selectionELem.getNodeName() == 'CODE' || $selectionELem.getNodeName() == 'PRE' || $selectionELem.parent().getNodeName() == 'CODE' || $selectionELem.parent().getNodeName() == 'PRE' || /hljs/.test($selectionELem.parent().attr('class'))) {
  5614. return true;
  5615. } else {
  5616. return false;
  5617. }
  5618. }
  5619. exports["default"] = isActive;
  5620. /***/ }),
  5621. /* 145 */
  5622. /***/ (function(module, exports, __webpack_require__) {
  5623. "use strict";
  5624. var _interopRequireDefault = __webpack_require__(0);
  5625. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5626. var _find = _interopRequireDefault(__webpack_require__(32));
  5627. (0, _defineProperty["default"])(exports, "__esModule", {
  5628. value: true
  5629. });
  5630. exports.todo = void 0;
  5631. var tslib_1 = __webpack_require__(2);
  5632. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  5633. var todo = function () {
  5634. function todo($orginElem) {
  5635. var _a;
  5636. this.template = "<ul class=\"w-e-todo\"><li><span contenteditable=\"false\"><input type=\"checkbox\"></span></li></ul>";
  5637. this.checked = false;
  5638. this.$todo = dom_core_1["default"](this.template);
  5639. this.$child = (_a = $orginElem === null || $orginElem === void 0 ? void 0 : $orginElem.childNodes()) === null || _a === void 0 ? void 0 : _a.clone(true);
  5640. }
  5641. todo.prototype.init = function () {
  5642. var $child = this.$child;
  5643. var $inputContainer = this.getInputContainer();
  5644. if ($child) {
  5645. $child.insertAfter($inputContainer);
  5646. }
  5647. };
  5648. todo.prototype.getInput = function () {
  5649. var $todo = this.$todo;
  5650. var $input = (0, _find["default"])($todo).call($todo, 'input');
  5651. return $input;
  5652. };
  5653. todo.prototype.getInputContainer = function () {
  5654. var $inputContainer = this.getInput().parent();
  5655. return $inputContainer;
  5656. };
  5657. todo.prototype.getTodo = function () {
  5658. return this.$todo;
  5659. };
  5660. return todo;
  5661. }();
  5662. exports.todo = todo;
  5663. function createTodo($orginElem) {
  5664. var t = new todo($orginElem);
  5665. t.init();
  5666. return t;
  5667. }
  5668. exports["default"] = createTodo;
  5669. /***/ }),
  5670. /* 146 */
  5671. /***/ (function(module, exports, __webpack_require__) {
  5672. "use strict";
  5673. /**
  5674. * @description 入口文件
  5675. * @author wangfupeng
  5676. */
  5677. var _interopRequireDefault = __webpack_require__(0);
  5678. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  5679. (0, _defineProperty["default"])(exports, "__esModule", {
  5680. value: true
  5681. });
  5682. var tslib_1 = __webpack_require__(2);
  5683. __webpack_require__(154);
  5684. __webpack_require__(156);
  5685. __webpack_require__(160);
  5686. __webpack_require__(162);
  5687. __webpack_require__(164);
  5688. __webpack_require__(166);
  5689. __webpack_require__(168);
  5690. var index_1 = tslib_1.__importDefault(__webpack_require__(94));
  5691. tslib_1.__exportStar(__webpack_require__(458), exports); // 检验是否浏览器环境
  5692. try {
  5693. document;
  5694. } catch (ex) {
  5695. throw new Error('请在浏览器环境下运行');
  5696. }
  5697. exports["default"] = index_1["default"];
  5698. /***/ }),
  5699. /* 147 */
  5700. /***/ (function(module, exports, __webpack_require__) {
  5701. var parent = __webpack_require__(148);
  5702. module.exports = parent;
  5703. /***/ }),
  5704. /* 148 */
  5705. /***/ (function(module, exports, __webpack_require__) {
  5706. __webpack_require__(149);
  5707. var path = __webpack_require__(11);
  5708. var Object = path.Object;
  5709. var defineProperty = module.exports = function defineProperty(it, key, desc) {
  5710. return Object.defineProperty(it, key, desc);
  5711. };
  5712. if (Object.defineProperty.sham) defineProperty.sham = true;
  5713. /***/ }),
  5714. /* 149 */
  5715. /***/ (function(module, exports, __webpack_require__) {
  5716. var $ = __webpack_require__(5);
  5717. var DESCRIPTORS = __webpack_require__(15);
  5718. var objectDefinePropertyModile = __webpack_require__(18);
  5719. // `Object.defineProperty` method
  5720. // https://tc39.es/ecma262/#sec-object.defineproperty
  5721. $({ target: 'Object', stat: true, forced: !DESCRIPTORS, sham: !DESCRIPTORS }, {
  5722. defineProperty: objectDefinePropertyModile.f
  5723. });
  5724. /***/ }),
  5725. /* 150 */
  5726. /***/ (function(module, exports) {
  5727. var g;
  5728. // This works in non-strict mode
  5729. g = (function() {
  5730. return this;
  5731. })();
  5732. try {
  5733. // This works if eval is allowed (see CSP)
  5734. g = g || new Function("return this")();
  5735. } catch (e) {
  5736. // This works if the window reference is available
  5737. if (typeof window === "object") g = window;
  5738. }
  5739. // g can still be undefined, but nothing to do about it...
  5740. // We return undefined, instead of nothing here, so it's
  5741. // easier to handle this case. if(!global) { ...}
  5742. module.exports = g;
  5743. /***/ }),
  5744. /* 151 */
  5745. /***/ (function(module, exports, __webpack_require__) {
  5746. var isObject = __webpack_require__(13);
  5747. var isSymbol = __webpack_require__(65);
  5748. var ordinaryToPrimitive = __webpack_require__(152);
  5749. var wellKnownSymbol = __webpack_require__(9);
  5750. var TO_PRIMITIVE = wellKnownSymbol('toPrimitive');
  5751. // `ToPrimitive` abstract operation
  5752. // https://tc39.es/ecma262/#sec-toprimitive
  5753. module.exports = function (input, pref) {
  5754. if (!isObject(input) || isSymbol(input)) return input;
  5755. var exoticToPrim = input[TO_PRIMITIVE];
  5756. var result;
  5757. if (exoticToPrim !== undefined) {
  5758. if (pref === undefined) pref = 'default';
  5759. result = exoticToPrim.call(input, pref);
  5760. if (!isObject(result) || isSymbol(result)) return result;
  5761. throw TypeError("Can't convert object to primitive value");
  5762. }
  5763. if (pref === undefined) pref = 'number';
  5764. return ordinaryToPrimitive(input, pref);
  5765. };
  5766. /***/ }),
  5767. /* 152 */
  5768. /***/ (function(module, exports, __webpack_require__) {
  5769. var isObject = __webpack_require__(13);
  5770. // `OrdinaryToPrimitive` abstract operation
  5771. // https://tc39.es/ecma262/#sec-ordinarytoprimitive
  5772. module.exports = function (input, pref) {
  5773. var fn, val;
  5774. if (pref === 'string' && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
  5775. if (typeof (fn = input.valueOf) == 'function' && !isObject(val = fn.call(input))) return val;
  5776. if (pref !== 'string' && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
  5777. throw TypeError("Can't convert object to primitive value");
  5778. };
  5779. /***/ }),
  5780. /* 153 */
  5781. /***/ (function(module, exports, __webpack_require__) {
  5782. var global = __webpack_require__(8);
  5783. module.exports = function (key, value) {
  5784. try {
  5785. // eslint-disable-next-line es/no-object-defineproperty -- safe
  5786. Object.defineProperty(global, key, { value: value, configurable: true, writable: true });
  5787. } catch (error) {
  5788. global[key] = value;
  5789. } return value;
  5790. };
  5791. /***/ }),
  5792. /* 154 */
  5793. /***/ (function(module, exports, __webpack_require__) {
  5794. var api = __webpack_require__(21);
  5795. var content = __webpack_require__(155);
  5796. content = content.__esModule ? content.default : content;
  5797. if (typeof content === 'string') {
  5798. content = [[module.i, content, '']];
  5799. }
  5800. var options = {};
  5801. options.insert = "head";
  5802. options.singleton = false;
  5803. var update = api(content, options);
  5804. module.exports = content.locals || {};
  5805. /***/ }),
  5806. /* 155 */
  5807. /***/ (function(module, exports, __webpack_require__) {
  5808. // Imports
  5809. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  5810. exports = ___CSS_LOADER_API_IMPORT___(false);
  5811. // Module
  5812. exports.push([module.i, ".w-e-toolbar,\n.w-e-text-container,\n.w-e-menu-panel {\n padding: 0;\n margin: 0;\n box-sizing: border-box;\n background-color: #fff;\n /*表情菜单样式*/\n /*分割线样式*/\n}\n.w-e-toolbar h1,\n.w-e-text-container h1,\n.w-e-menu-panel h1 {\n font-size: 32px !important;\n}\n.w-e-toolbar h2,\n.w-e-text-container h2,\n.w-e-menu-panel h2 {\n font-size: 24px !important;\n}\n.w-e-toolbar h3,\n.w-e-text-container h3,\n.w-e-menu-panel h3 {\n font-size: 18.72px !important;\n}\n.w-e-toolbar h4,\n.w-e-text-container h4,\n.w-e-menu-panel h4 {\n font-size: 16px !important;\n}\n.w-e-toolbar h5,\n.w-e-text-container h5,\n.w-e-menu-panel h5 {\n font-size: 13.28px !important;\n}\n.w-e-toolbar p,\n.w-e-text-container p,\n.w-e-menu-panel p {\n font-size: 16px !important;\n}\n.w-e-toolbar .eleImg,\n.w-e-text-container .eleImg,\n.w-e-menu-panel .eleImg {\n cursor: pointer;\n display: inline-block;\n font-size: 18px;\n padding: 0 3px;\n}\n.w-e-toolbar *,\n.w-e-text-container *,\n.w-e-menu-panel * {\n padding: 0;\n margin: 0;\n box-sizing: border-box;\n}\n.w-e-toolbar hr,\n.w-e-text-container hr,\n.w-e-menu-panel hr {\n cursor: pointer;\n display: block;\n height: 0px;\n border: 0;\n border-top: 3px solid #ccc;\n margin: 20px 0;\n}\n.w-e-clear-fix:after {\n content: \"\";\n display: table;\n clear: both;\n}\n.w-e-drop-list-item {\n position: relative;\n top: 1px;\n padding-right: 7px;\n color: #333 !important;\n}\n.w-e-drop-list-tl {\n padding-left: 10px;\n text-align: left;\n}\n", ""]);
  5813. // Exports
  5814. module.exports = exports;
  5815. /***/ }),
  5816. /* 156 */
  5817. /***/ (function(module, exports, __webpack_require__) {
  5818. var api = __webpack_require__(21);
  5819. var content = __webpack_require__(157);
  5820. content = content.__esModule ? content.default : content;
  5821. if (typeof content === 'string') {
  5822. content = [[module.i, content, '']];
  5823. }
  5824. var options = {};
  5825. options.insert = "head";
  5826. options.singleton = false;
  5827. var update = api(content, options);
  5828. module.exports = content.locals || {};
  5829. /***/ }),
  5830. /* 157 */
  5831. /***/ (function(module, exports, __webpack_require__) {
  5832. // Imports
  5833. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  5834. var ___CSS_LOADER_GET_URL_IMPORT___ = __webpack_require__(158);
  5835. var ___CSS_LOADER_URL_IMPORT_0___ = __webpack_require__(159);
  5836. exports = ___CSS_LOADER_API_IMPORT___(false);
  5837. var ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);
  5838. // Module
  5839. exports.push([module.i, "@font-face {\n font-family: 'w-e-icon';\n src: url(" + ___CSS_LOADER_URL_REPLACEMENT_0___ + ") format('truetype');\n font-weight: normal;\n font-style: normal;\n}\n[class^=\"w-e-icon-\"],\n[class*=\" w-e-icon-\"] {\n /* use !important to prevent issues with browser extensions that change fonts */\n font-family: 'w-e-icon' !important;\n speak: none;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n line-height: 1;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n.w-e-icon-close:before {\n content: \"\\f00d\";\n}\n.w-e-icon-upload2:before {\n content: \"\\e9c6\";\n}\n.w-e-icon-trash-o:before {\n content: \"\\f014\";\n}\n.w-e-icon-header:before {\n content: \"\\f1dc\";\n}\n.w-e-icon-pencil2:before {\n content: \"\\e906\";\n}\n.w-e-icon-paint-brush:before {\n content: \"\\f1fc\";\n}\n.w-e-icon-image:before {\n content: \"\\e90d\";\n}\n.w-e-icon-play:before {\n content: \"\\e912\";\n}\n.w-e-icon-location:before {\n content: \"\\e947\";\n}\n.w-e-icon-undo:before {\n content: \"\\e965\";\n}\n.w-e-icon-redo:before {\n content: \"\\e966\";\n}\n.w-e-icon-quotes-left:before {\n content: \"\\e977\";\n}\n.w-e-icon-list-numbered:before {\n content: \"\\e9b9\";\n}\n.w-e-icon-list2:before {\n content: \"\\e9bb\";\n}\n.w-e-icon-link:before {\n content: \"\\e9cb\";\n}\n.w-e-icon-happy:before {\n content: \"\\e9df\";\n}\n.w-e-icon-bold:before {\n content: \"\\ea62\";\n}\n.w-e-icon-underline:before {\n content: \"\\ea63\";\n}\n.w-e-icon-italic:before {\n content: \"\\ea64\";\n}\n.w-e-icon-strikethrough:before {\n content: \"\\ea65\";\n}\n.w-e-icon-table2:before {\n content: \"\\ea71\";\n}\n.w-e-icon-paragraph-left:before {\n content: \"\\ea77\";\n}\n.w-e-icon-paragraph-center:before {\n content: \"\\ea78\";\n}\n.w-e-icon-paragraph-right:before {\n content: \"\\ea79\";\n}\n.w-e-icon-paragraph-justify:before {\n content: \"\\ea7a\";\n}\n.w-e-icon-terminal:before {\n content: \"\\f120\";\n}\n.w-e-icon-page-break:before {\n content: \"\\ea68\";\n}\n.w-e-icon-cancel-circle:before {\n content: \"\\ea0d\";\n}\n.w-e-icon-font:before {\n content: \"\\ea5c\";\n}\n.w-e-icon-text-heigh:before {\n content: \"\\ea5f\";\n}\n.w-e-icon-paint-format:before {\n content: \"\\e90c\";\n}\n.w-e-icon-indent-increase:before {\n content: \"\\ea7b\";\n}\n.w-e-icon-indent-decrease:before {\n content: \"\\ea7c\";\n}\n.w-e-icon-row-height:before {\n content: \"\\e9be\";\n}\n.w-e-icon-fullscreen_exit:before {\n content: \"\\e900\";\n}\n.w-e-icon-fullscreen:before {\n content: \"\\e901\";\n}\n.w-e-icon-split-line:before {\n content: \"\\ea0b\";\n}\n.w-e-icon-checkbox-checked:before {\n content: \"\\ea52\";\n}\n", ""]);
  5840. // Exports
  5841. module.exports = exports;
  5842. /***/ }),
  5843. /* 158 */
  5844. /***/ (function(module, exports, __webpack_require__) {
  5845. "use strict";
  5846. module.exports = function (url, options) {
  5847. if (!options) {
  5848. // eslint-disable-next-line no-param-reassign
  5849. options = {};
  5850. } // eslint-disable-next-line no-underscore-dangle, no-param-reassign
  5851. url = url && url.__esModule ? url.default : url;
  5852. if (typeof url !== 'string') {
  5853. return url;
  5854. } // If url is already wrapped in quotes, remove them
  5855. if (/^['"].*['"]$/.test(url)) {
  5856. // eslint-disable-next-line no-param-reassign
  5857. url = url.slice(1, -1);
  5858. }
  5859. if (options.hash) {
  5860. // eslint-disable-next-line no-param-reassign
  5861. url += options.hash;
  5862. } // Should url be wrapped?
  5863. // See https://drafts.csswg.org/css-values-3/#urls
  5864. if (/["'() \t\n]/.test(url) || options.needQuotes) {
  5865. return "\"".concat(url.replace(/"/g, '\\"').replace(/\n/g, '\\n'), "\"");
  5866. }
  5867. return url;
  5868. };
  5869. /***/ }),
  5870. /* 159 */
  5871. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  5872. "use strict";
  5873. __webpack_require__.r(__webpack_exports__);
  5874. /* harmony default export */ __webpack_exports__["default"] = ("data:font/woff;base64,d09GRgABAAAAABskAAsAAAAAGtgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABPUy8yAAABCAAAAGAAAABgDxIPFWNtYXAAAAFoAAABHAAAARz2mfAgZ2FzcAAAAoQAAAAIAAAACAAAABBnbHlmAAACjAAAFXwAABV8IH7+mGhlYWQAABgIAAAANgAAADYb6gumaGhlYQAAGEAAAAAkAAAAJAkjBWlobXR4AAAYZAAAAKQAAACkmYcEbmxvY2EAABkIAAAAVAAAAFReAmKYbWF4cAAAGVwAAAAgAAAAIAA0ALZuYW1lAAAZfAAAAYYAAAGGmUoJ+3Bvc3QAABsEAAAAIAAAACAAAwAAAAMD7wGQAAUAAAKZAswAAACPApkCzAAAAesAMwEJAAAAAAAAAAAAAAAAAAAAARAAAAAAAAAAAAAAAAAAAAAAQAAA8fwDwP/AAEADwABAAAAAAQAAAAAAAAAAAAAAIAAAAAAAAwAAAAMAAAAcAAEAAwAAABwAAwABAAAAHAAEAQAAAAA8ACAABAAcAAEAIOkB6QbpDekS6UfpZul36bnpu+m+6cbpy+nf6gvqDepS6lzqX+pl6nHqfPAN8BTxIPHc8fz//f//AAAAAAAg6QDpBukM6RLpR+ll6Xfpuem76b7pxunL6d/qC+oN6lLqXOpf6mLqcep38A3wFPEg8dzx/P/9//8AAf/jFwQXABb7FvcWwxamFpYWVRZUFlIWSxZHFjQWCRYIFcQVuxW5FbcVrBWnEBcQEQ8GDksOLAADAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAB//8ADwABAAAAAAAAAAAAAgAANzkBAAAAAAEAAAAAAAAAAAACAAA3OQEAAAAAAQAAAAAAAAAAAAIAADc5AQAAAAAEAEEAAQO/A38ABQALABEAFwAAATMVIREzAxEhFSMVATUzESE1ETUhESM1Av/A/sJ+fgE+wP4Cfv7CAT5+Ar9+AT78ggE+fsACvsD+wn7+An7+wsAAAAAABABBAAEDvwN/AAUACwARABcAAAEhESM1IxM1MxEhNQERIRUjFREVMxUhEQKBAT5+wMB+/sL9wAE+wMD+wgN//sLA/X7A/sJ+AcIBPn7A/v7AfgE+AAAAAAIAAP/ABAADwAAEABMAAAE3AScBAy4BJxM3ASMBAyUBNQEHAYCAAcBA/kCfFzsyY4ABgMD+gMACgAGA/oBOAUBAAcBA/kD+nTI7FwERTgGA/oD9gMABgMD+gIAAAgAA/8AEAAOAACkALQAAAREjNTQmIyEiBh0BFBYzITI2PQEzESEVIyIGFREUFjsBMjY1ETQmKwE1ASE1IQQAwCYa/UAaJiYaAsAaJoD9wCANExMNgA0TEw0gAUD9QALAAYABgEAaJiYawBomJhpA/wCAEw3+wA0TEw0BQA0TQAGAQAAABAAAAAAEAAOAABAAIQAtADQAAAE4ATEROAExITgBMRE4ATEhNSEiBhURFBYzITI2NRE0JiMHFAYjIiY1NDYzMhYTITUTATM3A8D8gAOA/IAaJiYaA4AaJiYagDgoKDg4KCg4QP0A4AEAQOADQP0AAwBAJhr9ABomJhoDABom4Cg4OCgoODj9uIABgP7AwAAAAgAAAEAEAANAADgAPAAAASYnLgEnJiMiBw4BBwYHBgcOAQcGFRQXHgEXFhcWFx4BFxYzMjc+ATc2NzY3PgE3NjU0Jy4BJyYnARENAQPVNjg5djw9Pz89PHY5ODYLBwgLAwMDAwsIBws2ODl2PD0/Pz08djk4NgsHCAsDAwMDCwgHC/2rAUD+wAMgCAYGCAICAgIIBgYIKSoqWS0uLy8uLVkqKikIBgYIAgICAggGBggpKipZLS4vLy4tWSoqKf3gAYDAwAAAAAACAMD/wANAA8AAGwAnAAABIgcOAQcGFRQXHgEXFjEwNz4BNzY1NCcuAScmAyImNTQ2MzIWFRQGAgBCOzpXGRkyMngyMjIyeDIyGRlXOjtCUHBwUFBwcAPAGRlXOjtCeH19zEFBQUHMfX14Qjs6VxkZ/gBwUFBwcFBQcAAAAQAAAAAEAAOAACsAAAEiBw4BBwYHJxEhJz4BMzIXHgEXFhUUBw4BBwYHFzY3PgE3NjU0Jy4BJyYjAgA1MjJcKSkjlgGAkDWLUFBFRmkeHgkJIhgYHlUoICAtDAwoKIteXWoDgAoLJxscI5b+gJA0PB4eaUZFUCsoKUkgIRpgIysrYjY2OWpdXosoKAABAAAAAAQAA4AAKgAAExQXHgEXFhc3JicuAScmNTQ3PgE3NjMyFhcHIREHJicuAScmIyIHDgEHBgAMDC0gIChVHhgYIgkJHh5pRkVQUIs1kAGAliMpKVwyMjVqXV6LKCgBgDk2NmIrKyNgGiEgSSkoK1BFRmkeHjw0kAGAliMcGycLCigoi15dAAAAAAIAAABABAEDAAAmAE0AABMyFx4BFxYVFAcOAQcGIyInLgEnJjUnNDc+ATc2MxUiBgcOAQc+ASEyFx4BFxYVFAcOAQcGIyInLgEnJjUnNDc+ATc2MxUiBgcOAQc+AeEuKSk9ERISET0pKS4uKSk9ERIBIyN6UlFdQHUtCRAHCBICSS4pKT0REhIRPSkpLi4pKT0REgEjI3pSUV1AdS0JEAcIEgIAEhE9KSkuLikpPRESEhE9KSkuIF1RUnojI4AwLggTCgIBEhE9KSkuLikpPRESEhE9KSkuIF1RUnojI4AwLggTCgIBAAAGAED/wAQAA8AAAwAHAAsAEQAdACkAACUhFSERIRUhESEVIScRIzUjNRMVMxUjNTc1IzUzFRURIzUzNSM1MzUjNQGAAoD9gAKA/YACgP2AwEBAQIDAgIDAwICAgICAgAIAgAIAgMD/AMBA/fIyQJI8MkCS7v7AQEBAQEAABgAA/8AEAAPAAAMABwALABcAIwAvAAABIRUhESEVIREhFSEBNDYzMhYVFAYjIiYRNDYzMhYVFAYjIiYRNDYzMhYVFAYjIiYBgAKA/YACgP2AAoD9gP6ASzU1S0s1NUtLNTVLSzU1S0s1NUtLNTVLA4CA/wCA/wCAA0A1S0s1NUtL/rU1S0s1NUtL/rU1S0s1NUtLAAUAAABABWADAAADAAcACwAOABEAABMhFSEVIRUhFSEVIQEXNzUnBwADgPyAA4D8gAOA/IAD4MDAwMADAMBAwEDAAUDAwEDAwAAAAAADAAAAAAQAA6AAAwANABQAADchFSElFSE1EyEVITUhJQkBIxEjEQAEAPwABAD8AIABAAEAAQD9YAEgASDggEBAwEBAAQCAgMABIP7g/wABAAAAAAACAB7/zAPiA7QAMwBkAAABIiYnJicmNDc2PwE+ATMyFhcWFxYUBwYPAQYiJyY0PwE2NCcuASMiBg8BBhQXFhQHDgEjAyImJyYnJjQ3Nj8BNjIXFhQPAQYUFx4BMzI2PwE2NCcmNDc2MhcWFxYUBwYPAQ4BIwG4ChMIIxISEhIjwCNZMTFZIyMSEhISI1gPLA8PD1gpKRQzHBwzFMApKQ8PCBMKuDFZIyMSEhISI1gPLA8PD1gpKRQzHBwzFMApKQ8PDysQIxISEhIjwCNZMQFECAckLS1eLS0kwCIlJSIkLS1eLS0kVxAQDysPWCl0KRQVFRTAKXQpDysQBwj+iCUiJC0tXi0tJFcQEA8rD1gpdCkUFRUUwCl0KQ8rEA8PJC0tXi0tJMAiJQAAAAAFAAD/wAQAA8AAGwA3AFMAXwBrAAAFMjc+ATc2NTQnLgEnJiMiBw4BBwYVFBceARcWEzIXHgEXFhUUBw4BBwYjIicuAScmNTQ3PgE3NhMyNz4BNzY3BgcOAQcGIyInLgEnJicWFx4BFxYnNDYzMhYVFAYjIiYlNDYzMhYVFAYjIiYCAGpdXosoKCgoi15dampdXosoKCgoi15dalZMTHEgISEgcUxMVlZMTHEgISEgcUxMVisrKlEmJiMFHBtWODc/Pzc4VhscBSMmJlEqK9UlGxslJRsbJQGAJRsbJSUbGyVAKCiLXl1qal1eiygoKCiLXl1qal1eiygoA6AhIHFMTFZWTExxICEhIHFMTFZWTExxICH+CQYGFRAQFEM6OlYYGRkYVjo6QxQQEBUGBvcoODgoKDg4KCg4OCgoODgAAAEAAAFABAACQAAPAAATFRQWMyEyNj0BNCYjISIGABMNA8ANExMN/EANEwIgwA0TEw3ADRMTAAAAAwAA/8AEAAPAABsANwBDAAABIgcOAQcGFRQXHgEXFjMyNz4BNzY1NCcuAScmAyInLgEnJjU0Nz4BNzYzMhceARcWFRQHDgEHBhMHJwcXBxc3FzcnNwIAal1eiygoKCiLXl1qal1eiygoKCiLXl1qVkxMcSAhISBxTExWVkxMcSAhISBxTExKoKBgoKBgoKBgoKADwCgoi15dampdXosoKCgoi15dampdXosoKPxgISBxTExWVkxMcSAhISBxTExWVkxMcSAhAqCgoGCgoGCgoGCgoAACAAD/wAQAA8AADwAVAAABISIGFREUFjMhMjY1ETQmASc3FwEXA4D9ADVLSzUDADVLS/4L7VqTATNaA8BLNf0ANUtLNQMANUv85e5akgEyWgAAAAABAGX/wAObA8AAKQAAASImIyIHDgEHBhUUFjMuATU0NjcwBwYCBwYHFSETMzcjNx4BMzI2Nw4BAyBEaEZxU1RtGhtJSAYNZUoQEEs8PFkBPWzGLNc0LVUmLlAYHT0DsBAeHWE+P0FNOwsmN5lvA31+/sWPkCMZAgCA9gkPN2sJBwAAAAACAAAAAAQAA4AACQAXAAAlMwcnMxEjNxcjJREnIxEzFSE1MxEjBxEDgICgoICAoKCA/wBAwID+gIDAQMDAwAIAwMDA/wCA/UBAQALAgAEAAAMAwAAAA0ADgAAWAB8AKAAAAT4BNTQnLgEnJiMhESEyNz4BNzY1NCYBMzIWFRQGKwETIxEzMhYVFAYCxBwgFBRGLi81/sABgDUvLkYUFET+hGUqPDwpZp+fnyw+PgHbIlQvNS8uRhQU/IAUFEYuLzVGdAFGSzU1S/6AAQBLNTVLAAAAAAIAwAAAA0ADgAAfACMAAAEzERQHDgEHBiMiJy4BJyY1ETMRFBYXHgEzMjY3PgE1ASEVIQLAgBkZVzo7QkI7OlcZGYAbGBxJKChJHBgb/gACgP2AA4D+YDw0NU4WFxcWTjU0PAGg/mAeOBcYGxsYFzge/qCAAAAAAAEAgAAAA4ADgAALAAABFSMBMxUhNTMBIzUDgID+wID+QIABQIADgED9AEBAAwBAAAEAAAAABAADgAA9AAABFSMeARUUBgcOASMiJicuATUzFBYzMjY1NCYjITUhLgEnLgE1NDY3PgEzMhYXHgEVIzQmIyIGFRQWMzIWFwQA6xUWNTAscT4+cSwwNYByTk5yck7+AAEsAgQBMDU1MCxxPj5xLDA1gHJOTnJyTjtuKwHAQB1BIjViJCEkJCEkYjU0TEw0NExAAQMBJGI1NWIkISQkISRiNTRMTDQ0TCEfAAAACgAAAAAEAAOAAAMABwALAA8AEwAXABsAHwAjACcAABMRIREBNSEVHQEhNQEVITUjFSE1ESEVISUhFSERNSEVASEVISE1IRUABAD9gAEA/wABAP8AQP8AAQD/AAKAAQD/AAEA/IABAP8AAoABAAOA/IADgP3AwMBAwMACAMDAwMD/AMDAwAEAwMD+wMDAwAAABQAAAAAEAAOAAAMABwALAA8AEwAAEyEVIRUhFSERIRUhESEVIREhFSEABAD8AAKA/YACgP2ABAD8AAQA/AADgIBAgP8AgAFAgP8AgAAAAAAFAAAAAAQAA4AAAwAHAAsADwATAAATIRUhFyEVIREhFSEDIRUhESEVIQAEAPwAwAKA/YACgP2AwAQA/AAEAPwAA4CAQID/AIABQID/AIAAAAUAAAAABAADgAADAAcACwAPABMAABMhFSEFIRUhESEVIQEhFSERIRUhAAQA/AABgAKA/YACgP2A/oAEAPwABAD8AAOAgECA/wCAAUCA/wCAAAAAAAUAAAAABAADgAADAAcACwAPABMAABMhFSEVIRUhFSEVIRUhFSEVIRUhAAQA/AAEAPwABAD8AAQA/AAEAPwAA4CAQIBAgECAQIAAAAAGAAAAAAQAA4AAAwAHAAsADwATABYAABMhFSEFIRUhFSEVIRUhFSEFIRUhGQEFAAQA/AABgAKA/YACgP2AAoD9gP6ABAD8AAEAA4CAQIBAgECAQIABAAGAwAAAAAYAAAAABAADgAADAAcACwAPABMAFgAAEyEVIQUhFSEVIRUhFSEVIQUhFSEBESUABAD8AAGAAoD9gAKA/YACgP2A/oAEAPwAAQD/AAOAgECAQIBAgECAAoD+gMAAAQA/AD8C5gLmACwAACUUDwEGIyIvAQcGIyIvASY1ND8BJyY1ND8BNjMyHwE3NjMyHwEWFRQPARcWFQLmEE4QFxcQqKgQFxYQThAQqKgQEE4QFhcQqKgQFxcQThAQqKgQwxYQThAQqKgQEE4QFhcQqKgQFxcQThAQqKgQEE4QFxcQqKgQFwAAAAYAAAAAAyUDbgAUACgAPABNAFUAggAAAREUBwYrASInJjURNDc2OwEyFxYVMxEUBwYrASInJjURNDc2OwEyFxYXERQHBisBIicmNRE0NzY7ATIXFhMRIREUFxYXFjMhMjc2NzY1ASEnJicjBgcFFRQHBisBERQHBiMhIicmNREjIicmPQE0NzY7ATc2NzY7ATIXFh8BMzIXFhUBJQYFCCQIBQYGBQgkCAUGkgUFCCUIBQUFBQglCAUFkgUFCCUIBQUFBQglCAUFSf4ABAQFBAIB2wIEBAQE/oABABsEBrUGBAH3BgUINxobJv4lJhsbNwgFBQUFCLEoCBcWF7cXFhYJKLAIBQYCEv63CAUFBQUIAUkIBQYGBQj+twgFBQUFCAFJCAUGBgUI/rcIBQUFBQgBSQgFBgYF/lsCHf3jDQsKBQUFBQoLDQJmQwUCAgVVJAgGBf3jMCIjISIvAiAFBggkCAUFYBUPDw8PFWAFBQgAAgAHAEkDtwKvABoALgAACQEGIyIvASY1ND8BJyY1ND8BNjMyFwEWFRQHARUUBwYjISInJj0BNDc2MyEyFxYBTv72BgcIBR0GBuHhBgYdBQgHBgEKBgYCaQUFCP3bCAUFBQUIAiUIBQUBhf72BgYcBggHBuDhBgcHBh0FBf71BQgHBv77JQgFBQUFCCUIBQUFBQAAAAEAIwAAA90DbgCzAAAlIicmIyIHBiMiJyY1NDc2NzY3Njc2PQE0JyYjISIHBh0BFBcWFxYzFhcWFRQHBiMiJyYjIgcGIyInJjU0NzY3Njc2NzY9ARE0NTQ1NCc0JyYnJicmJyYnJiMiJyY1NDc2MzIXFjMyNzYzMhcWFRQHBiMGBwYHBh0BFBcWMyEyNzY9ATQnJicmJyY1NDc2MzIXFjMyNzYzMhcWFRQHBgciBwYHBhURFBcWFxYXMhcWFRQHBiMDwRkzMhoZMjMZDQgHCQoNDBEQChIBBxX+fhYHARUJEhMODgwLBwcOGzU1GhgxMRgNBwcJCQsMEA8JEgECAQIDBAQFCBIRDQ0KCwcHDho1NRoYMDEYDgcHCQoMDRAQCBQBBw8BkA4HARQKFxcPDgcHDhkzMhkZMTEZDgcHCgoNDRARCBQUCRERDg0KCwcHDgACAgICDAsPEQkJAQEDAwUMROAMBQMDBQzUUQ0GAQIBCAgSDwwNAgICAgwMDhEICQECAwMFDUUhAdACDQ0ICA4OCgoLCwcHAwYBAQgIEg8MDQICAgINDA8RCAgBAgEGDFC2DAcBAQcMtlAMBgEBBgcWDwwNAgICAg0MDxEICAEBAgYNT/3mRAwGAgIBCQgRDwwNAAACAAD/twP/A7cAEwA5AAABMhcWFRQHAgcGIyInJjU0NwE2MwEWFxYfARYHBiMiJyYnJicmNRYXFhcWFxYzMjc2NzY3Njc2NzY3A5soHh4avkw3RUg0NDUBbSEp/fgXJicvAQJMTHtHNjYhIRARBBMUEBASEQkXCA8SExUVHR0eHikDtxsaKCQz/plGNDU0SUkwAUsf/bErHx8NKHpNTBobLi86OkQDDw4LCwoKFiUbGhERCgsEBAIAAQAAAAAAAIWwaoFfDzz1AAsEAAAAAADbteOZAAAAANu145kAAP+3BWADwAAAAAgAAgAAAAAAAAABAAADwP/AAAAFgAAA//8FYAABAAAAAAAAAAAAAAAAAAAAKQQAAAAAAAAAAAAAAAIAAAAEAABBBAAAQQQAAAAEAAAABAAAAAQAAAAEAADABAAAAAQAAAAEAAAABAAAQAQAAAAFgAAABAAAAAQAAB4EAAAABAAAAAQAAAAEAAAABAAAZQQAAAAEAADABAAAwAQAAIAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAMlAD8DJQAAA74ABwQAACMD/wAAAAAAAAAKABQAHgBKAHYApADmAS4BkgHQAhYCXALQAw4DWAN+A6gEPgTeBPoFZAWOBdAF+AY6BnYGjgbmBy4HVgd+B6gHzgf8CCoIbgkmCXAKYgq+AAEAAAApALQACgAAAAAAAgAAAAAAAAAAAAAAAAAAAAAAAAAOAK4AAQAAAAAAAQAHAAAAAQAAAAAAAgAHAGAAAQAAAAAAAwAHADYAAQAAAAAABAAHAHUAAQAAAAAABQALABUAAQAAAAAABgAHAEsAAQAAAAAACgAaAIoAAwABBAkAAQAOAAcAAwABBAkAAgAOAGcAAwABBAkAAwAOAD0AAwABBAkABAAOAHwAAwABBAkABQAWACAAAwABBAkABgAOAFIAAwABBAkACgA0AKRpY29tb29uAGkAYwBvAG0AbwBvAG5WZXJzaW9uIDEuMABWAGUAcgBzAGkAbwBuACAAMQAuADBpY29tb29uAGkAYwBvAG0AbwBvAG5pY29tb29uAGkAYwBvAG0AbwBvAG5SZWd1bGFyAFIAZQBnAHUAbABhAHJpY29tb29uAGkAYwBvAG0AbwBvAG5Gb250IGdlbmVyYXRlZCBieSBJY29Nb29uLgBGAG8AbgB0ACAAZwBlAG4AZQByAGEAdABlAGQAIABiAHkAIABJAGMAbwBNAG8AbwBuAC4AAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA");
  5875. /***/ }),
  5876. /* 160 */
  5877. /***/ (function(module, exports, __webpack_require__) {
  5878. var api = __webpack_require__(21);
  5879. var content = __webpack_require__(161);
  5880. content = content.__esModule ? content.default : content;
  5881. if (typeof content === 'string') {
  5882. content = [[module.i, content, '']];
  5883. }
  5884. var options = {};
  5885. options.insert = "head";
  5886. options.singleton = false;
  5887. var update = api(content, options);
  5888. module.exports = content.locals || {};
  5889. /***/ }),
  5890. /* 161 */
  5891. /***/ (function(module, exports, __webpack_require__) {
  5892. // Imports
  5893. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  5894. exports = ___CSS_LOADER_API_IMPORT___(false);
  5895. // Module
  5896. exports.push([module.i, ".w-e-toolbar {\n display: flex;\n padding: 0 6px;\n flex-wrap: wrap;\n position: relative;\n /* 单个菜单 */\n}\n.w-e-toolbar .w-e-menu {\n position: relative;\n display: flex;\n width: 40px;\n height: 40px;\n align-items: center;\n justify-content: center;\n text-align: center;\n cursor: pointer;\n}\n.w-e-toolbar .w-e-menu i {\n color: #999;\n}\n.w-e-toolbar .w-e-menu:hover {\n background-color: #F6F6F6;\n}\n.w-e-toolbar .w-e-menu:hover i {\n color: #333;\n}\n.w-e-toolbar .w-e-active i {\n color: #1e88e5;\n}\n.w-e-toolbar .w-e-active:hover i {\n color: #1e88e5;\n}\n.w-e-menu-tooltip {\n position: absolute;\n display: flex;\n color: #f1f1f1;\n background-color: rgba(0, 0, 0, 0.75);\n box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.15);\n border-radius: 4px;\n padding: 4px 5px 6px;\n justify-content: center;\n align-items: center;\n}\n.w-e-menu-tooltip-up::after {\n content: \"\";\n position: absolute;\n top: 100%;\n left: 50%;\n margin-left: -5px;\n border: 5px solid rgba(0, 0, 0, 0);\n border-top-color: rgba(0, 0, 0, 0.73);\n}\n.w-e-menu-tooltip-down::after {\n content: \"\";\n position: absolute;\n bottom: 100%;\n left: 50%;\n margin-left: -5px;\n border: 5px solid rgba(0, 0, 0, 0);\n border-bottom-color: rgba(0, 0, 0, 0.73);\n}\n.w-e-menu-tooltip-item-wrapper {\n font-size: 14px;\n margin: 0 5px;\n}\n", ""]);
  5897. // Exports
  5898. module.exports = exports;
  5899. /***/ }),
  5900. /* 162 */
  5901. /***/ (function(module, exports, __webpack_require__) {
  5902. var api = __webpack_require__(21);
  5903. var content = __webpack_require__(163);
  5904. content = content.__esModule ? content.default : content;
  5905. if (typeof content === 'string') {
  5906. content = [[module.i, content, '']];
  5907. }
  5908. var options = {};
  5909. options.insert = "head";
  5910. options.singleton = false;
  5911. var update = api(content, options);
  5912. module.exports = content.locals || {};
  5913. /***/ }),
  5914. /* 163 */
  5915. /***/ (function(module, exports, __webpack_require__) {
  5916. // Imports
  5917. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  5918. exports = ___CSS_LOADER_API_IMPORT___(false);
  5919. // Module
  5920. exports.push([module.i, ".w-e-text-container {\n position: relative;\n height: 100%;\n}\n.w-e-text-container .w-e-progress {\n position: absolute;\n background-color: #1e88e5;\n top: 0;\n left: 0;\n height: 1px;\n}\n.w-e-text-container .placeholder {\n color: #D4D4D4;\n position: absolute;\n font-size: 11pt;\n line-height: 22px;\n left: 10px;\n top: 10px;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n z-index: -1;\n}\n.w-e-text {\n padding: 0 10px;\n overflow-y: auto;\n}\n.w-e-text p,\n.w-e-text h1,\n.w-e-text h2,\n.w-e-text h3,\n.w-e-text h4,\n.w-e-text h5,\n.w-e-text table,\n.w-e-text pre {\n margin: 10px 0;\n line-height: 1.5;\n}\n.w-e-text ul,\n.w-e-text ol {\n margin: 10px 0 10px 20px;\n}\n.w-e-text blockquote {\n display: block;\n border-left: 8px solid #d0e5f2;\n padding: 5px 10px;\n margin: 10px 0;\n line-height: 1.4;\n font-size: 100%;\n background-color: #f1f1f1;\n}\n.w-e-text code {\n display: inline-block;\n background-color: #f1f1f1;\n border-radius: 3px;\n padding: 3px 5px;\n margin: 0 3px;\n}\n.w-e-text pre code {\n display: block;\n}\n.w-e-text table {\n border-top: 1px solid #ccc;\n border-left: 1px solid #ccc;\n}\n.w-e-text table td,\n.w-e-text table th {\n border-bottom: 1px solid #ccc;\n border-right: 1px solid #ccc;\n padding: 3px 5px;\n min-height: 30px;\n}\n.w-e-text table th {\n border-bottom: 2px solid #ccc;\n text-align: center;\n background-color: #f1f1f1;\n}\n.w-e-text:focus {\n outline: none;\n}\n.w-e-text img {\n cursor: pointer;\n}\n.w-e-text img:hover {\n box-shadow: 0 0 5px #333;\n}\n.w-e-text .w-e-todo {\n margin: 0 0 0 20px;\n}\n.w-e-text .w-e-todo li {\n list-style: none;\n font-size: 1em;\n}\n.w-e-text .w-e-todo li span:nth-child(1) {\n position: relative;\n left: -18px;\n}\n.w-e-text .w-e-todo li span:nth-child(1) input {\n position: absolute;\n margin-right: 3px;\n}\n.w-e-text .w-e-todo li span:nth-child(1) input[type=checkbox] {\n top: 50%;\n margin-top: -6px;\n}\n.w-e-tooltip {\n position: absolute;\n display: flex;\n color: #f1f1f1;\n background-color: rgba(0, 0, 0, 0.75);\n box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.15);\n border-radius: 4px;\n padding: 4px 5px 6px;\n justify-content: center;\n align-items: center;\n}\n.w-e-tooltip-up::after {\n content: \"\";\n position: absolute;\n top: 100%;\n left: 50%;\n margin-left: -5px;\n border: 5px solid rgba(0, 0, 0, 0);\n border-top-color: rgba(0, 0, 0, 0.73);\n}\n.w-e-tooltip-down::after {\n content: \"\";\n position: absolute;\n bottom: 100%;\n left: 50%;\n margin-left: -5px;\n border: 5px solid rgba(0, 0, 0, 0);\n border-bottom-color: rgba(0, 0, 0, 0.73);\n}\n.w-e-tooltip-item-wrapper {\n cursor: pointer;\n font-size: 14px;\n margin: 0 5px;\n}\n.w-e-tooltip-item-wrapper:hover {\n color: #ccc;\n text-decoration: underline;\n}\n", ""]);
  5921. // Exports
  5922. module.exports = exports;
  5923. /***/ }),
  5924. /* 164 */
  5925. /***/ (function(module, exports, __webpack_require__) {
  5926. var api = __webpack_require__(21);
  5927. var content = __webpack_require__(165);
  5928. content = content.__esModule ? content.default : content;
  5929. if (typeof content === 'string') {
  5930. content = [[module.i, content, '']];
  5931. }
  5932. var options = {};
  5933. options.insert = "head";
  5934. options.singleton = false;
  5935. var update = api(content, options);
  5936. module.exports = content.locals || {};
  5937. /***/ }),
  5938. /* 165 */
  5939. /***/ (function(module, exports, __webpack_require__) {
  5940. // Imports
  5941. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  5942. exports = ___CSS_LOADER_API_IMPORT___(false);
  5943. // Module
  5944. exports.push([module.i, ".w-e-menu .w-e-panel-container {\n position: absolute;\n top: 0;\n left: 50%;\n border: 1px solid #ccc;\n border-top: 0;\n box-shadow: 1px 1px 2px #ccc;\n color: #333;\n background-color: #fff;\n text-align: left;\n /* 为 emotion panel 定制的样式 */\n /* 上传图片、上传视频的 panel 定制样式 */\n}\n.w-e-menu .w-e-panel-container .w-e-panel-close {\n position: absolute;\n right: 0;\n top: 0;\n padding: 5px;\n margin: 2px 5px 0 0;\n cursor: pointer;\n color: #999;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-close:hover {\n color: #333;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-title {\n list-style: none;\n display: flex;\n font-size: 14px;\n margin: 2px 10px 0 10px;\n border-bottom: 1px solid #f1f1f1;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-title .w-e-item {\n padding: 3px 5px;\n color: #999;\n cursor: pointer;\n margin: 0 3px;\n position: relative;\n top: 1px;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-title .w-e-active {\n color: #333;\n border-bottom: 1px solid #333;\n cursor: default;\n font-weight: 700;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content {\n padding: 10px 15px 10px 15px;\n font-size: 16px;\n /* 输入框的样式 */\n /* 按钮的样式 */\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content input:focus,\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content textarea:focus,\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content button:focus {\n outline: none;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content textarea {\n width: 100%;\n border: 1px solid #ccc;\n padding: 5px;\n margin-top: 10px;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content textarea:focus {\n border-color: #1e88e5;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content input[type=text] {\n border: none;\n border-bottom: 1px solid #ccc;\n font-size: 14px;\n height: 20px;\n color: #333;\n text-align: left;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content input[type=text].small {\n width: 30px;\n text-align: center;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content input[type=text].block {\n display: block;\n width: 100%;\n margin: 10px 0;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content input[type=text]:focus {\n border-bottom: 2px solid #1e88e5;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content .w-e-button-container button {\n font-size: 14px;\n color: #1e88e5;\n border: none;\n padding: 5px 10px;\n background-color: #fff;\n cursor: pointer;\n border-radius: 3px;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content .w-e-button-container button.left {\n float: left;\n margin-right: 10px;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content .w-e-button-container button.right {\n float: right;\n margin-left: 10px;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content .w-e-button-container button.gray {\n color: #999;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content .w-e-button-container button.red {\n color: #c24f4a;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content .w-e-button-container button:hover {\n background-color: #f1f1f1;\n}\n.w-e-menu .w-e-panel-container .w-e-panel-tab-content .w-e-button-container:after {\n content: \"\";\n display: table;\n clear: both;\n}\n.w-e-menu .w-e-panel-container .w-e-emoticon-container .w-e-item {\n cursor: pointer;\n font-size: 18px;\n padding: 0 3px;\n display: inline-block;\n}\n.w-e-menu .w-e-panel-container .w-e-up-img-container,\n.w-e-menu .w-e-panel-container .w-e-up-video-container {\n text-align: center;\n}\n.w-e-menu .w-e-panel-container .w-e-up-img-container .w-e-up-btn,\n.w-e-menu .w-e-panel-container .w-e-up-video-container .w-e-up-btn {\n display: inline-block;\n color: #999;\n cursor: pointer;\n font-size: 60px;\n line-height: 1;\n}\n.w-e-menu .w-e-panel-container .w-e-up-img-container .w-e-up-btn:hover,\n.w-e-menu .w-e-panel-container .w-e-up-video-container .w-e-up-btn:hover {\n color: #333;\n}\n", ""]);
  5945. // Exports
  5946. module.exports = exports;
  5947. /***/ }),
  5948. /* 166 */
  5949. /***/ (function(module, exports, __webpack_require__) {
  5950. var api = __webpack_require__(21);
  5951. var content = __webpack_require__(167);
  5952. content = content.__esModule ? content.default : content;
  5953. if (typeof content === 'string') {
  5954. content = [[module.i, content, '']];
  5955. }
  5956. var options = {};
  5957. options.insert = "head";
  5958. options.singleton = false;
  5959. var update = api(content, options);
  5960. module.exports = content.locals || {};
  5961. /***/ }),
  5962. /* 167 */
  5963. /***/ (function(module, exports, __webpack_require__) {
  5964. // Imports
  5965. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  5966. exports = ___CSS_LOADER_API_IMPORT___(false);
  5967. // Module
  5968. exports.push([module.i, ".w-e-toolbar .w-e-droplist {\n position: absolute;\n left: 0;\n top: 0;\n background-color: #fff;\n border: 1px solid #f1f1f1;\n border-right-color: #ccc;\n border-bottom-color: #ccc;\n}\n.w-e-toolbar .w-e-droplist .w-e-dp-title {\n text-align: center;\n color: #999;\n line-height: 2;\n border-bottom: 1px solid #f1f1f1;\n font-size: 13px;\n}\n.w-e-toolbar .w-e-droplist ul.w-e-list {\n list-style: none;\n line-height: 1;\n}\n.w-e-toolbar .w-e-droplist ul.w-e-list li.w-e-item {\n color: #333;\n padding: 5px 0;\n}\n.w-e-toolbar .w-e-droplist ul.w-e-list li.w-e-item:hover {\n background-color: #f1f1f1;\n}\n.w-e-toolbar .w-e-droplist ul.w-e-block {\n list-style: none;\n text-align: left;\n padding: 5px;\n}\n.w-e-toolbar .w-e-droplist ul.w-e-block li.w-e-item {\n display: inline-block;\n padding: 3px 5px;\n}\n.w-e-toolbar .w-e-droplist ul.w-e-block li.w-e-item:hover {\n background-color: #f1f1f1;\n}\n", ""]);
  5969. // Exports
  5970. module.exports = exports;
  5971. /***/ }),
  5972. /* 168 */
  5973. /***/ (function(module, exports, __webpack_require__) {
  5974. "use strict";
  5975. /**
  5976. * @description polyfill 【注意,js 语法的兼容,都通过 babel transform runtime 支持】
  5977. * @author wangfupeng
  5978. */
  5979. var _interopRequireDefault = __webpack_require__(0);
  5980. var _promise = _interopRequireDefault(__webpack_require__(169));
  5981. if (!Element.prototype.matches) {
  5982. Element.prototype.matches = function (s) {
  5983. var matches = this.ownerDocument.querySelectorAll(s);
  5984. var i = matches.length;
  5985. for (i; i >= 0; i--) {
  5986. if (matches.item(i) === this) break;
  5987. }
  5988. return i > -1;
  5989. };
  5990. } // 有的第三方库需要原生 Promise ,而 IE11 又没有原生 Promise ,就报错
  5991. if (!_promise["default"]) {
  5992. window.Promise = _promise["default"];
  5993. }
  5994. /***/ }),
  5995. /* 169 */
  5996. /***/ (function(module, exports, __webpack_require__) {
  5997. module.exports = __webpack_require__(170);
  5998. /***/ }),
  5999. /* 170 */
  6000. /***/ (function(module, exports, __webpack_require__) {
  6001. var parent = __webpack_require__(171);
  6002. __webpack_require__(45);
  6003. module.exports = parent;
  6004. /***/ }),
  6005. /* 171 */
  6006. /***/ (function(module, exports, __webpack_require__) {
  6007. __webpack_require__(172);
  6008. __webpack_require__(55);
  6009. __webpack_require__(57);
  6010. __webpack_require__(179);
  6011. __webpack_require__(185);
  6012. __webpack_require__(186);
  6013. __webpack_require__(187);
  6014. __webpack_require__(58);
  6015. var path = __webpack_require__(11);
  6016. module.exports = path.Promise;
  6017. /***/ }),
  6018. /* 172 */
  6019. /***/ (function(module, exports, __webpack_require__) {
  6020. "use strict";
  6021. var $ = __webpack_require__(5);
  6022. var getPrototypeOf = __webpack_require__(83);
  6023. var setPrototypeOf = __webpack_require__(84);
  6024. var create = __webpack_require__(69);
  6025. var createNonEnumerableProperty = __webpack_require__(19);
  6026. var createPropertyDescriptor = __webpack_require__(38);
  6027. var iterate = __webpack_require__(41);
  6028. var toString = __webpack_require__(30);
  6029. var $AggregateError = function AggregateError(errors, message) {
  6030. var that = this;
  6031. if (!(that instanceof $AggregateError)) return new $AggregateError(errors, message);
  6032. if (setPrototypeOf) {
  6033. // eslint-disable-next-line unicorn/error-message -- expected
  6034. that = setPrototypeOf(new Error(undefined), getPrototypeOf(that));
  6035. }
  6036. if (message !== undefined) createNonEnumerableProperty(that, 'message', toString(message));
  6037. var errorsArray = [];
  6038. iterate(errors, errorsArray.push, { that: errorsArray });
  6039. createNonEnumerableProperty(that, 'errors', errorsArray);
  6040. return that;
  6041. };
  6042. $AggregateError.prototype = create(Error.prototype, {
  6043. constructor: createPropertyDescriptor(5, $AggregateError),
  6044. message: createPropertyDescriptor(5, ''),
  6045. name: createPropertyDescriptor(5, 'AggregateError')
  6046. });
  6047. // `AggregateError` constructor
  6048. // https://tc39.es/ecma262/#sec-aggregate-error-constructor
  6049. $({ global: true }, {
  6050. AggregateError: $AggregateError
  6051. });
  6052. /***/ }),
  6053. /* 173 */
  6054. /***/ (function(module, exports, __webpack_require__) {
  6055. var fails = __webpack_require__(12);
  6056. module.exports = !fails(function () {
  6057. function F() { /* empty */ }
  6058. F.prototype.constructor = null;
  6059. // eslint-disable-next-line es/no-object-getprototypeof -- required for testing
  6060. return Object.getPrototypeOf(new F()) !== F.prototype;
  6061. });
  6062. /***/ }),
  6063. /* 174 */
  6064. /***/ (function(module, exports, __webpack_require__) {
  6065. var isObject = __webpack_require__(13);
  6066. module.exports = function (it) {
  6067. if (!isObject(it) && it !== null) {
  6068. throw TypeError("Can't set " + String(it) + ' as a prototype');
  6069. } return it;
  6070. };
  6071. /***/ }),
  6072. /* 175 */
  6073. /***/ (function(module, exports, __webpack_require__) {
  6074. var DESCRIPTORS = __webpack_require__(15);
  6075. var definePropertyModule = __webpack_require__(18);
  6076. var anObject = __webpack_require__(20);
  6077. var objectKeys = __webpack_require__(53);
  6078. // `Object.defineProperties` method
  6079. // https://tc39.es/ecma262/#sec-object.defineproperties
  6080. // eslint-disable-next-line es/no-object-defineproperties -- safe
  6081. module.exports = DESCRIPTORS ? Object.defineProperties : function defineProperties(O, Properties) {
  6082. anObject(O);
  6083. var keys = objectKeys(Properties);
  6084. var length = keys.length;
  6085. var index = 0;
  6086. var key;
  6087. while (length > index) definePropertyModule.f(O, key = keys[index++], Properties[key]);
  6088. return O;
  6089. };
  6090. /***/ }),
  6091. /* 176 */
  6092. /***/ (function(module, exports, __webpack_require__) {
  6093. var global = __webpack_require__(8);
  6094. var inspectSource = __webpack_require__(115);
  6095. var WeakMap = global.WeakMap;
  6096. module.exports = typeof WeakMap === 'function' && /native code/.test(inspectSource(WeakMap));
  6097. /***/ }),
  6098. /* 177 */
  6099. /***/ (function(module, exports, __webpack_require__) {
  6100. "use strict";
  6101. var IteratorPrototype = __webpack_require__(116).IteratorPrototype;
  6102. var create = __webpack_require__(69);
  6103. var createPropertyDescriptor = __webpack_require__(38);
  6104. var setToStringTag = __webpack_require__(44);
  6105. var Iterators = __webpack_require__(42);
  6106. var returnThis = function () { return this; };
  6107. module.exports = function (IteratorConstructor, NAME, next) {
  6108. var TO_STRING_TAG = NAME + ' Iterator';
  6109. IteratorConstructor.prototype = create(IteratorPrototype, { next: createPropertyDescriptor(1, next) });
  6110. setToStringTag(IteratorConstructor, TO_STRING_TAG, false, true);
  6111. Iterators[TO_STRING_TAG] = returnThis;
  6112. return IteratorConstructor;
  6113. };
  6114. /***/ }),
  6115. /* 178 */
  6116. /***/ (function(module, exports, __webpack_require__) {
  6117. "use strict";
  6118. var TO_STRING_TAG_SUPPORT = __webpack_require__(88);
  6119. var classof = __webpack_require__(71);
  6120. // `Object.prototype.toString` method implementation
  6121. // https://tc39.es/ecma262/#sec-object.prototype.tostring
  6122. module.exports = TO_STRING_TAG_SUPPORT ? {}.toString : function toString() {
  6123. return '[object ' + classof(this) + ']';
  6124. };
  6125. /***/ }),
  6126. /* 179 */
  6127. /***/ (function(module, exports, __webpack_require__) {
  6128. "use strict";
  6129. var $ = __webpack_require__(5);
  6130. var IS_PURE = __webpack_require__(39);
  6131. var global = __webpack_require__(8);
  6132. var getBuiltIn = __webpack_require__(25);
  6133. var NativePromise = __webpack_require__(117);
  6134. var redefine = __webpack_require__(56);
  6135. var redefineAll = __webpack_require__(118);
  6136. var setPrototypeOf = __webpack_require__(84);
  6137. var setToStringTag = __webpack_require__(44);
  6138. var setSpecies = __webpack_require__(119);
  6139. var isObject = __webpack_require__(13);
  6140. var aFunction = __webpack_require__(34);
  6141. var anInstance = __webpack_require__(91);
  6142. var inspectSource = __webpack_require__(115);
  6143. var iterate = __webpack_require__(41);
  6144. var checkCorrectnessOfIteration = __webpack_require__(120);
  6145. var speciesConstructor = __webpack_require__(121);
  6146. var task = __webpack_require__(122).set;
  6147. var microtask = __webpack_require__(180);
  6148. var promiseResolve = __webpack_require__(124);
  6149. var hostReportErrors = __webpack_require__(183);
  6150. var newPromiseCapabilityModule = __webpack_require__(72);
  6151. var perform = __webpack_require__(93);
  6152. var InternalStateModule = __webpack_require__(43);
  6153. var isForced = __webpack_require__(109);
  6154. var wellKnownSymbol = __webpack_require__(9);
  6155. var IS_BROWSER = __webpack_require__(184);
  6156. var IS_NODE = __webpack_require__(92);
  6157. var V8_VERSION = __webpack_require__(66);
  6158. var SPECIES = wellKnownSymbol('species');
  6159. var PROMISE = 'Promise';
  6160. var getInternalState = InternalStateModule.get;
  6161. var setInternalState = InternalStateModule.set;
  6162. var getInternalPromiseState = InternalStateModule.getterFor(PROMISE);
  6163. var NativePromisePrototype = NativePromise && NativePromise.prototype;
  6164. var PromiseConstructor = NativePromise;
  6165. var PromiseConstructorPrototype = NativePromisePrototype;
  6166. var TypeError = global.TypeError;
  6167. var document = global.document;
  6168. var process = global.process;
  6169. var newPromiseCapability = newPromiseCapabilityModule.f;
  6170. var newGenericPromiseCapability = newPromiseCapability;
  6171. var DISPATCH_EVENT = !!(document && document.createEvent && global.dispatchEvent);
  6172. var NATIVE_REJECTION_EVENT = typeof PromiseRejectionEvent == 'function';
  6173. var UNHANDLED_REJECTION = 'unhandledrejection';
  6174. var REJECTION_HANDLED = 'rejectionhandled';
  6175. var PENDING = 0;
  6176. var FULFILLED = 1;
  6177. var REJECTED = 2;
  6178. var HANDLED = 1;
  6179. var UNHANDLED = 2;
  6180. var SUBCLASSING = false;
  6181. var Internal, OwnPromiseCapability, PromiseWrapper, nativeThen;
  6182. var FORCED = isForced(PROMISE, function () {
  6183. var PROMISE_CONSTRUCTOR_SOURCE = inspectSource(PromiseConstructor);
  6184. var GLOBAL_CORE_JS_PROMISE = PROMISE_CONSTRUCTOR_SOURCE !== String(PromiseConstructor);
  6185. // V8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables
  6186. // https://bugs.chromium.org/p/chromium/issues/detail?id=830565
  6187. // We can't detect it synchronously, so just check versions
  6188. if (!GLOBAL_CORE_JS_PROMISE && V8_VERSION === 66) return true;
  6189. // We need Promise#finally in the pure version for preventing prototype pollution
  6190. if (IS_PURE && !PromiseConstructorPrototype['finally']) return true;
  6191. // We can't use @@species feature detection in V8 since it causes
  6192. // deoptimization and performance degradation
  6193. // https://github.com/zloirock/core-js/issues/679
  6194. if (V8_VERSION >= 51 && /native code/.test(PROMISE_CONSTRUCTOR_SOURCE)) return false;
  6195. // Detect correctness of subclassing with @@species support
  6196. var promise = new PromiseConstructor(function (resolve) { resolve(1); });
  6197. var FakePromise = function (exec) {
  6198. exec(function () { /* empty */ }, function () { /* empty */ });
  6199. };
  6200. var constructor = promise.constructor = {};
  6201. constructor[SPECIES] = FakePromise;
  6202. SUBCLASSING = promise.then(function () { /* empty */ }) instanceof FakePromise;
  6203. if (!SUBCLASSING) return true;
  6204. // Unhandled rejections tracking support, NodeJS Promise without it fails @@species test
  6205. return !GLOBAL_CORE_JS_PROMISE && IS_BROWSER && !NATIVE_REJECTION_EVENT;
  6206. });
  6207. var INCORRECT_ITERATION = FORCED || !checkCorrectnessOfIteration(function (iterable) {
  6208. PromiseConstructor.all(iterable)['catch'](function () { /* empty */ });
  6209. });
  6210. // helpers
  6211. var isThenable = function (it) {
  6212. var then;
  6213. return isObject(it) && typeof (then = it.then) == 'function' ? then : false;
  6214. };
  6215. var notify = function (state, isReject) {
  6216. if (state.notified) return;
  6217. state.notified = true;
  6218. var chain = state.reactions;
  6219. microtask(function () {
  6220. var value = state.value;
  6221. var ok = state.state == FULFILLED;
  6222. var index = 0;
  6223. // variable length - can't use forEach
  6224. while (chain.length > index) {
  6225. var reaction = chain[index++];
  6226. var handler = ok ? reaction.ok : reaction.fail;
  6227. var resolve = reaction.resolve;
  6228. var reject = reaction.reject;
  6229. var domain = reaction.domain;
  6230. var result, then, exited;
  6231. try {
  6232. if (handler) {
  6233. if (!ok) {
  6234. if (state.rejection === UNHANDLED) onHandleUnhandled(state);
  6235. state.rejection = HANDLED;
  6236. }
  6237. if (handler === true) result = value;
  6238. else {
  6239. if (domain) domain.enter();
  6240. result = handler(value); // can throw
  6241. if (domain) {
  6242. domain.exit();
  6243. exited = true;
  6244. }
  6245. }
  6246. if (result === reaction.promise) {
  6247. reject(TypeError('Promise-chain cycle'));
  6248. } else if (then = isThenable(result)) {
  6249. then.call(result, resolve, reject);
  6250. } else resolve(result);
  6251. } else reject(value);
  6252. } catch (error) {
  6253. if (domain && !exited) domain.exit();
  6254. reject(error);
  6255. }
  6256. }
  6257. state.reactions = [];
  6258. state.notified = false;
  6259. if (isReject && !state.rejection) onUnhandled(state);
  6260. });
  6261. };
  6262. var dispatchEvent = function (name, promise, reason) {
  6263. var event, handler;
  6264. if (DISPATCH_EVENT) {
  6265. event = document.createEvent('Event');
  6266. event.promise = promise;
  6267. event.reason = reason;
  6268. event.initEvent(name, false, true);
  6269. global.dispatchEvent(event);
  6270. } else event = { promise: promise, reason: reason };
  6271. if (!NATIVE_REJECTION_EVENT && (handler = global['on' + name])) handler(event);
  6272. else if (name === UNHANDLED_REJECTION) hostReportErrors('Unhandled promise rejection', reason);
  6273. };
  6274. var onUnhandled = function (state) {
  6275. task.call(global, function () {
  6276. var promise = state.facade;
  6277. var value = state.value;
  6278. var IS_UNHANDLED = isUnhandled(state);
  6279. var result;
  6280. if (IS_UNHANDLED) {
  6281. result = perform(function () {
  6282. if (IS_NODE) {
  6283. process.emit('unhandledRejection', value, promise);
  6284. } else dispatchEvent(UNHANDLED_REJECTION, promise, value);
  6285. });
  6286. // Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should
  6287. state.rejection = IS_NODE || isUnhandled(state) ? UNHANDLED : HANDLED;
  6288. if (result.error) throw result.value;
  6289. }
  6290. });
  6291. };
  6292. var isUnhandled = function (state) {
  6293. return state.rejection !== HANDLED && !state.parent;
  6294. };
  6295. var onHandleUnhandled = function (state) {
  6296. task.call(global, function () {
  6297. var promise = state.facade;
  6298. if (IS_NODE) {
  6299. process.emit('rejectionHandled', promise);
  6300. } else dispatchEvent(REJECTION_HANDLED, promise, state.value);
  6301. });
  6302. };
  6303. var bind = function (fn, state, unwrap) {
  6304. return function (value) {
  6305. fn(state, value, unwrap);
  6306. };
  6307. };
  6308. var internalReject = function (state, value, unwrap) {
  6309. if (state.done) return;
  6310. state.done = true;
  6311. if (unwrap) state = unwrap;
  6312. state.value = value;
  6313. state.state = REJECTED;
  6314. notify(state, true);
  6315. };
  6316. var internalResolve = function (state, value, unwrap) {
  6317. if (state.done) return;
  6318. state.done = true;
  6319. if (unwrap) state = unwrap;
  6320. try {
  6321. if (state.facade === value) throw TypeError("Promise can't be resolved itself");
  6322. var then = isThenable(value);
  6323. if (then) {
  6324. microtask(function () {
  6325. var wrapper = { done: false };
  6326. try {
  6327. then.call(value,
  6328. bind(internalResolve, wrapper, state),
  6329. bind(internalReject, wrapper, state)
  6330. );
  6331. } catch (error) {
  6332. internalReject(wrapper, error, state);
  6333. }
  6334. });
  6335. } else {
  6336. state.value = value;
  6337. state.state = FULFILLED;
  6338. notify(state, false);
  6339. }
  6340. } catch (error) {
  6341. internalReject({ done: false }, error, state);
  6342. }
  6343. };
  6344. // constructor polyfill
  6345. if (FORCED) {
  6346. // 25.4.3.1 Promise(executor)
  6347. PromiseConstructor = function Promise(executor) {
  6348. anInstance(this, PromiseConstructor, PROMISE);
  6349. aFunction(executor);
  6350. Internal.call(this);
  6351. var state = getInternalState(this);
  6352. try {
  6353. executor(bind(internalResolve, state), bind(internalReject, state));
  6354. } catch (error) {
  6355. internalReject(state, error);
  6356. }
  6357. };
  6358. PromiseConstructorPrototype = PromiseConstructor.prototype;
  6359. // eslint-disable-next-line no-unused-vars -- required for `.length`
  6360. Internal = function Promise(executor) {
  6361. setInternalState(this, {
  6362. type: PROMISE,
  6363. done: false,
  6364. notified: false,
  6365. parent: false,
  6366. reactions: [],
  6367. rejection: false,
  6368. state: PENDING,
  6369. value: undefined
  6370. });
  6371. };
  6372. Internal.prototype = redefineAll(PromiseConstructorPrototype, {
  6373. // `Promise.prototype.then` method
  6374. // https://tc39.es/ecma262/#sec-promise.prototype.then
  6375. then: function then(onFulfilled, onRejected) {
  6376. var state = getInternalPromiseState(this);
  6377. var reaction = newPromiseCapability(speciesConstructor(this, PromiseConstructor));
  6378. reaction.ok = typeof onFulfilled == 'function' ? onFulfilled : true;
  6379. reaction.fail = typeof onRejected == 'function' && onRejected;
  6380. reaction.domain = IS_NODE ? process.domain : undefined;
  6381. state.parent = true;
  6382. state.reactions.push(reaction);
  6383. if (state.state != PENDING) notify(state, false);
  6384. return reaction.promise;
  6385. },
  6386. // `Promise.prototype.catch` method
  6387. // https://tc39.es/ecma262/#sec-promise.prototype.catch
  6388. 'catch': function (onRejected) {
  6389. return this.then(undefined, onRejected);
  6390. }
  6391. });
  6392. OwnPromiseCapability = function () {
  6393. var promise = new Internal();
  6394. var state = getInternalState(promise);
  6395. this.promise = promise;
  6396. this.resolve = bind(internalResolve, state);
  6397. this.reject = bind(internalReject, state);
  6398. };
  6399. newPromiseCapabilityModule.f = newPromiseCapability = function (C) {
  6400. return C === PromiseConstructor || C === PromiseWrapper
  6401. ? new OwnPromiseCapability(C)
  6402. : newGenericPromiseCapability(C);
  6403. };
  6404. if (!IS_PURE && typeof NativePromise == 'function' && NativePromisePrototype !== Object.prototype) {
  6405. nativeThen = NativePromisePrototype.then;
  6406. if (!SUBCLASSING) {
  6407. // make `Promise#then` return a polyfilled `Promise` for native promise-based APIs
  6408. redefine(NativePromisePrototype, 'then', function then(onFulfilled, onRejected) {
  6409. var that = this;
  6410. return new PromiseConstructor(function (resolve, reject) {
  6411. nativeThen.call(that, resolve, reject);
  6412. }).then(onFulfilled, onRejected);
  6413. // https://github.com/zloirock/core-js/issues/640
  6414. }, { unsafe: true });
  6415. // makes sure that native promise-based APIs `Promise#catch` properly works with patched `Promise#then`
  6416. redefine(NativePromisePrototype, 'catch', PromiseConstructorPrototype['catch'], { unsafe: true });
  6417. }
  6418. // make `.constructor === Promise` work for native promise-based APIs
  6419. try {
  6420. delete NativePromisePrototype.constructor;
  6421. } catch (error) { /* empty */ }
  6422. // make `instanceof Promise` work for native promise-based APIs
  6423. if (setPrototypeOf) {
  6424. setPrototypeOf(NativePromisePrototype, PromiseConstructorPrototype);
  6425. }
  6426. }
  6427. }
  6428. $({ global: true, wrap: true, forced: FORCED }, {
  6429. Promise: PromiseConstructor
  6430. });
  6431. setToStringTag(PromiseConstructor, PROMISE, false, true);
  6432. setSpecies(PROMISE);
  6433. PromiseWrapper = getBuiltIn(PROMISE);
  6434. // statics
  6435. $({ target: PROMISE, stat: true, forced: FORCED }, {
  6436. // `Promise.reject` method
  6437. // https://tc39.es/ecma262/#sec-promise.reject
  6438. reject: function reject(r) {
  6439. var capability = newPromiseCapability(this);
  6440. capability.reject.call(undefined, r);
  6441. return capability.promise;
  6442. }
  6443. });
  6444. $({ target: PROMISE, stat: true, forced: IS_PURE || FORCED }, {
  6445. // `Promise.resolve` method
  6446. // https://tc39.es/ecma262/#sec-promise.resolve
  6447. resolve: function resolve(x) {
  6448. return promiseResolve(IS_PURE && this === PromiseWrapper ? PromiseConstructor : this, x);
  6449. }
  6450. });
  6451. $({ target: PROMISE, stat: true, forced: INCORRECT_ITERATION }, {
  6452. // `Promise.all` method
  6453. // https://tc39.es/ecma262/#sec-promise.all
  6454. all: function all(iterable) {
  6455. var C = this;
  6456. var capability = newPromiseCapability(C);
  6457. var resolve = capability.resolve;
  6458. var reject = capability.reject;
  6459. var result = perform(function () {
  6460. var $promiseResolve = aFunction(C.resolve);
  6461. var values = [];
  6462. var counter = 0;
  6463. var remaining = 1;
  6464. iterate(iterable, function (promise) {
  6465. var index = counter++;
  6466. var alreadyCalled = false;
  6467. values.push(undefined);
  6468. remaining++;
  6469. $promiseResolve.call(C, promise).then(function (value) {
  6470. if (alreadyCalled) return;
  6471. alreadyCalled = true;
  6472. values[index] = value;
  6473. --remaining || resolve(values);
  6474. }, reject);
  6475. });
  6476. --remaining || resolve(values);
  6477. });
  6478. if (result.error) reject(result.value);
  6479. return capability.promise;
  6480. },
  6481. // `Promise.race` method
  6482. // https://tc39.es/ecma262/#sec-promise.race
  6483. race: function race(iterable) {
  6484. var C = this;
  6485. var capability = newPromiseCapability(C);
  6486. var reject = capability.reject;
  6487. var result = perform(function () {
  6488. var $promiseResolve = aFunction(C.resolve);
  6489. iterate(iterable, function (promise) {
  6490. $promiseResolve.call(C, promise).then(capability.resolve, reject);
  6491. });
  6492. });
  6493. if (result.error) reject(result.value);
  6494. return capability.promise;
  6495. }
  6496. });
  6497. /***/ }),
  6498. /* 180 */
  6499. /***/ (function(module, exports, __webpack_require__) {
  6500. var global = __webpack_require__(8);
  6501. var getOwnPropertyDescriptor = __webpack_require__(77).f;
  6502. var macrotask = __webpack_require__(122).set;
  6503. var IS_IOS = __webpack_require__(123);
  6504. var IS_IOS_PEBBLE = __webpack_require__(181);
  6505. var IS_WEBOS_WEBKIT = __webpack_require__(182);
  6506. var IS_NODE = __webpack_require__(92);
  6507. var MutationObserver = global.MutationObserver || global.WebKitMutationObserver;
  6508. var document = global.document;
  6509. var process = global.process;
  6510. var Promise = global.Promise;
  6511. // Node.js 11 shows ExperimentalWarning on getting `queueMicrotask`
  6512. var queueMicrotaskDescriptor = getOwnPropertyDescriptor(global, 'queueMicrotask');
  6513. var queueMicrotask = queueMicrotaskDescriptor && queueMicrotaskDescriptor.value;
  6514. var flush, head, last, notify, toggle, node, promise, then;
  6515. // modern engines have queueMicrotask method
  6516. if (!queueMicrotask) {
  6517. flush = function () {
  6518. var parent, fn;
  6519. if (IS_NODE && (parent = process.domain)) parent.exit();
  6520. while (head) {
  6521. fn = head.fn;
  6522. head = head.next;
  6523. try {
  6524. fn();
  6525. } catch (error) {
  6526. if (head) notify();
  6527. else last = undefined;
  6528. throw error;
  6529. }
  6530. } last = undefined;
  6531. if (parent) parent.enter();
  6532. };
  6533. // browsers with MutationObserver, except iOS - https://github.com/zloirock/core-js/issues/339
  6534. // also except WebOS Webkit https://github.com/zloirock/core-js/issues/898
  6535. if (!IS_IOS && !IS_NODE && !IS_WEBOS_WEBKIT && MutationObserver && document) {
  6536. toggle = true;
  6537. node = document.createTextNode('');
  6538. new MutationObserver(flush).observe(node, { characterData: true });
  6539. notify = function () {
  6540. node.data = toggle = !toggle;
  6541. };
  6542. // environments with maybe non-completely correct, but existent Promise
  6543. } else if (!IS_IOS_PEBBLE && Promise && Promise.resolve) {
  6544. // Promise.resolve without an argument throws an error in LG WebOS 2
  6545. promise = Promise.resolve(undefined);
  6546. // workaround of WebKit ~ iOS Safari 10.1 bug
  6547. promise.constructor = Promise;
  6548. then = promise.then;
  6549. notify = function () {
  6550. then.call(promise, flush);
  6551. };
  6552. // Node.js without promises
  6553. } else if (IS_NODE) {
  6554. notify = function () {
  6555. process.nextTick(flush);
  6556. };
  6557. // for other environments - macrotask based on:
  6558. // - setImmediate
  6559. // - MessageChannel
  6560. // - window.postMessag
  6561. // - onreadystatechange
  6562. // - setTimeout
  6563. } else {
  6564. notify = function () {
  6565. // strange IE + webpack dev server bug - use .call(global)
  6566. macrotask.call(global, flush);
  6567. };
  6568. }
  6569. }
  6570. module.exports = queueMicrotask || function (fn) {
  6571. var task = { fn: fn, next: undefined };
  6572. if (last) last.next = task;
  6573. if (!head) {
  6574. head = task;
  6575. notify();
  6576. } last = task;
  6577. };
  6578. /***/ }),
  6579. /* 181 */
  6580. /***/ (function(module, exports, __webpack_require__) {
  6581. var userAgent = __webpack_require__(52);
  6582. var global = __webpack_require__(8);
  6583. module.exports = /ipad|iphone|ipod/i.test(userAgent) && global.Pebble !== undefined;
  6584. /***/ }),
  6585. /* 182 */
  6586. /***/ (function(module, exports, __webpack_require__) {
  6587. var userAgent = __webpack_require__(52);
  6588. module.exports = /web0s(?!.*chrome)/i.test(userAgent);
  6589. /***/ }),
  6590. /* 183 */
  6591. /***/ (function(module, exports, __webpack_require__) {
  6592. var global = __webpack_require__(8);
  6593. module.exports = function (a, b) {
  6594. var console = global.console;
  6595. if (console && console.error) {
  6596. arguments.length === 1 ? console.error(a) : console.error(a, b);
  6597. }
  6598. };
  6599. /***/ }),
  6600. /* 184 */
  6601. /***/ (function(module, exports) {
  6602. module.exports = typeof window == 'object';
  6603. /***/ }),
  6604. /* 185 */
  6605. /***/ (function(module, exports, __webpack_require__) {
  6606. "use strict";
  6607. var $ = __webpack_require__(5);
  6608. var aFunction = __webpack_require__(34);
  6609. var newPromiseCapabilityModule = __webpack_require__(72);
  6610. var perform = __webpack_require__(93);
  6611. var iterate = __webpack_require__(41);
  6612. // `Promise.allSettled` method
  6613. // https://tc39.es/ecma262/#sec-promise.allsettled
  6614. $({ target: 'Promise', stat: true }, {
  6615. allSettled: function allSettled(iterable) {
  6616. var C = this;
  6617. var capability = newPromiseCapabilityModule.f(C);
  6618. var resolve = capability.resolve;
  6619. var reject = capability.reject;
  6620. var result = perform(function () {
  6621. var promiseResolve = aFunction(C.resolve);
  6622. var values = [];
  6623. var counter = 0;
  6624. var remaining = 1;
  6625. iterate(iterable, function (promise) {
  6626. var index = counter++;
  6627. var alreadyCalled = false;
  6628. values.push(undefined);
  6629. remaining++;
  6630. promiseResolve.call(C, promise).then(function (value) {
  6631. if (alreadyCalled) return;
  6632. alreadyCalled = true;
  6633. values[index] = { status: 'fulfilled', value: value };
  6634. --remaining || resolve(values);
  6635. }, function (error) {
  6636. if (alreadyCalled) return;
  6637. alreadyCalled = true;
  6638. values[index] = { status: 'rejected', reason: error };
  6639. --remaining || resolve(values);
  6640. });
  6641. });
  6642. --remaining || resolve(values);
  6643. });
  6644. if (result.error) reject(result.value);
  6645. return capability.promise;
  6646. }
  6647. });
  6648. /***/ }),
  6649. /* 186 */
  6650. /***/ (function(module, exports, __webpack_require__) {
  6651. "use strict";
  6652. var $ = __webpack_require__(5);
  6653. var aFunction = __webpack_require__(34);
  6654. var getBuiltIn = __webpack_require__(25);
  6655. var newPromiseCapabilityModule = __webpack_require__(72);
  6656. var perform = __webpack_require__(93);
  6657. var iterate = __webpack_require__(41);
  6658. var PROMISE_ANY_ERROR = 'No one promise resolved';
  6659. // `Promise.any` method
  6660. // https://tc39.es/ecma262/#sec-promise.any
  6661. $({ target: 'Promise', stat: true }, {
  6662. any: function any(iterable) {
  6663. var C = this;
  6664. var capability = newPromiseCapabilityModule.f(C);
  6665. var resolve = capability.resolve;
  6666. var reject = capability.reject;
  6667. var result = perform(function () {
  6668. var promiseResolve = aFunction(C.resolve);
  6669. var errors = [];
  6670. var counter = 0;
  6671. var remaining = 1;
  6672. var alreadyResolved = false;
  6673. iterate(iterable, function (promise) {
  6674. var index = counter++;
  6675. var alreadyRejected = false;
  6676. errors.push(undefined);
  6677. remaining++;
  6678. promiseResolve.call(C, promise).then(function (value) {
  6679. if (alreadyRejected || alreadyResolved) return;
  6680. alreadyResolved = true;
  6681. resolve(value);
  6682. }, function (error) {
  6683. if (alreadyRejected || alreadyResolved) return;
  6684. alreadyRejected = true;
  6685. errors[index] = error;
  6686. --remaining || reject(new (getBuiltIn('AggregateError'))(errors, PROMISE_ANY_ERROR));
  6687. });
  6688. });
  6689. --remaining || reject(new (getBuiltIn('AggregateError'))(errors, PROMISE_ANY_ERROR));
  6690. });
  6691. if (result.error) reject(result.value);
  6692. return capability.promise;
  6693. }
  6694. });
  6695. /***/ }),
  6696. /* 187 */
  6697. /***/ (function(module, exports, __webpack_require__) {
  6698. "use strict";
  6699. var $ = __webpack_require__(5);
  6700. var IS_PURE = __webpack_require__(39);
  6701. var NativePromise = __webpack_require__(117);
  6702. var fails = __webpack_require__(12);
  6703. var getBuiltIn = __webpack_require__(25);
  6704. var speciesConstructor = __webpack_require__(121);
  6705. var promiseResolve = __webpack_require__(124);
  6706. var redefine = __webpack_require__(56);
  6707. // Safari bug https://bugs.webkit.org/show_bug.cgi?id=200829
  6708. var NON_GENERIC = !!NativePromise && fails(function () {
  6709. NativePromise.prototype['finally'].call({ then: function () { /* empty */ } }, function () { /* empty */ });
  6710. });
  6711. // `Promise.prototype.finally` method
  6712. // https://tc39.es/ecma262/#sec-promise.prototype.finally
  6713. $({ target: 'Promise', proto: true, real: true, forced: NON_GENERIC }, {
  6714. 'finally': function (onFinally) {
  6715. var C = speciesConstructor(this, getBuiltIn('Promise'));
  6716. var isFunction = typeof onFinally == 'function';
  6717. return this.then(
  6718. isFunction ? function (x) {
  6719. return promiseResolve(C, onFinally()).then(function () { return x; });
  6720. } : onFinally,
  6721. isFunction ? function (e) {
  6722. return promiseResolve(C, onFinally()).then(function () { throw e; });
  6723. } : onFinally
  6724. );
  6725. }
  6726. });
  6727. // makes sure that native promise-based APIs `Promise#finally` properly works with patched `Promise#then`
  6728. if (!IS_PURE && typeof NativePromise == 'function') {
  6729. var method = getBuiltIn('Promise').prototype['finally'];
  6730. if (NativePromise.prototype['finally'] !== method) {
  6731. redefine(NativePromise.prototype, 'finally', method, { unsafe: true });
  6732. }
  6733. }
  6734. /***/ }),
  6735. /* 188 */
  6736. /***/ (function(module, exports, __webpack_require__) {
  6737. var toInteger = __webpack_require__(70);
  6738. var toString = __webpack_require__(30);
  6739. var requireObjectCoercible = __webpack_require__(51);
  6740. // `String.prototype.codePointAt` methods implementation
  6741. var createMethod = function (CONVERT_TO_STRING) {
  6742. return function ($this, pos) {
  6743. var S = toString(requireObjectCoercible($this));
  6744. var position = toInteger(pos);
  6745. var size = S.length;
  6746. var first, second;
  6747. if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;
  6748. first = S.charCodeAt(position);
  6749. return first < 0xD800 || first > 0xDBFF || position + 1 === size
  6750. || (second = S.charCodeAt(position + 1)) < 0xDC00 || second > 0xDFFF
  6751. ? CONVERT_TO_STRING ? S.charAt(position) : first
  6752. : CONVERT_TO_STRING ? S.slice(position, position + 2) : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;
  6753. };
  6754. };
  6755. module.exports = {
  6756. // `String.prototype.codePointAt` method
  6757. // https://tc39.es/ecma262/#sec-string.prototype.codepointat
  6758. codeAt: createMethod(false),
  6759. // `String.prototype.at` method
  6760. // https://github.com/mathiasbynens/String.prototype.at
  6761. charAt: createMethod(true)
  6762. };
  6763. /***/ }),
  6764. /* 189 */
  6765. /***/ (function(module, exports) {
  6766. // iterable DOM collections
  6767. // flag - `iterable` interface - 'entries', 'keys', 'values', 'forEach' methods
  6768. module.exports = {
  6769. CSSRuleList: 0,
  6770. CSSStyleDeclaration: 0,
  6771. CSSValueList: 0,
  6772. ClientRectList: 0,
  6773. DOMRectList: 0,
  6774. DOMStringList: 0,
  6775. DOMTokenList: 1,
  6776. DataTransferItemList: 0,
  6777. FileList: 0,
  6778. HTMLAllCollection: 0,
  6779. HTMLCollection: 0,
  6780. HTMLFormElement: 0,
  6781. HTMLSelectElement: 0,
  6782. MediaList: 0,
  6783. MimeTypeArray: 0,
  6784. NamedNodeMap: 0,
  6785. NodeList: 1,
  6786. PaintRequestList: 0,
  6787. Plugin: 0,
  6788. PluginArray: 0,
  6789. SVGLengthList: 0,
  6790. SVGNumberList: 0,
  6791. SVGPathSegList: 0,
  6792. SVGPointList: 0,
  6793. SVGStringList: 0,
  6794. SVGTransformList: 0,
  6795. SourceBufferList: 0,
  6796. StyleSheetList: 0,
  6797. TextTrackCueList: 0,
  6798. TextTrackList: 0,
  6799. TouchList: 0
  6800. };
  6801. /***/ }),
  6802. /* 190 */
  6803. /***/ (function(module, exports, __webpack_require__) {
  6804. __webpack_require__(45);
  6805. var forEach = __webpack_require__(191);
  6806. var classof = __webpack_require__(71);
  6807. var ArrayPrototype = Array.prototype;
  6808. var DOMIterables = {
  6809. DOMTokenList: true,
  6810. NodeList: true
  6811. };
  6812. module.exports = function (it) {
  6813. var own = it.forEach;
  6814. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.forEach)
  6815. // eslint-disable-next-line no-prototype-builtins -- safe
  6816. || DOMIterables.hasOwnProperty(classof(it)) ? forEach : own;
  6817. };
  6818. /***/ }),
  6819. /* 191 */
  6820. /***/ (function(module, exports, __webpack_require__) {
  6821. var parent = __webpack_require__(192);
  6822. module.exports = parent;
  6823. /***/ }),
  6824. /* 192 */
  6825. /***/ (function(module, exports, __webpack_require__) {
  6826. __webpack_require__(193);
  6827. var entryVirtual = __webpack_require__(14);
  6828. module.exports = entryVirtual('Array').forEach;
  6829. /***/ }),
  6830. /* 193 */
  6831. /***/ (function(module, exports, __webpack_require__) {
  6832. "use strict";
  6833. var $ = __webpack_require__(5);
  6834. var forEach = __webpack_require__(194);
  6835. // `Array.prototype.forEach` method
  6836. // https://tc39.es/ecma262/#sec-array.prototype.foreach
  6837. // eslint-disable-next-line es/no-array-prototype-foreach -- safe
  6838. $({ target: 'Array', proto: true, forced: [].forEach != forEach }, {
  6839. forEach: forEach
  6840. });
  6841. /***/ }),
  6842. /* 194 */
  6843. /***/ (function(module, exports, __webpack_require__) {
  6844. "use strict";
  6845. var $forEach = __webpack_require__(31).forEach;
  6846. var arrayMethodIsStrict = __webpack_require__(73);
  6847. var STRICT_METHOD = arrayMethodIsStrict('forEach');
  6848. // `Array.prototype.forEach` method implementation
  6849. // https://tc39.es/ecma262/#sec-array.prototype.foreach
  6850. module.exports = !STRICT_METHOD ? function forEach(callbackfn /* , thisArg */) {
  6851. return $forEach(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
  6852. // eslint-disable-next-line es/no-array-prototype-foreach -- safe
  6853. } : [].forEach;
  6854. /***/ }),
  6855. /* 195 */
  6856. /***/ (function(module, exports, __webpack_require__) {
  6857. var isObject = __webpack_require__(13);
  6858. var isArray = __webpack_require__(59);
  6859. var wellKnownSymbol = __webpack_require__(9);
  6860. var SPECIES = wellKnownSymbol('species');
  6861. // a part of `ArraySpeciesCreate` abstract operation
  6862. // https://tc39.es/ecma262/#sec-arrayspeciescreate
  6863. module.exports = function (originalArray) {
  6864. var C;
  6865. if (isArray(originalArray)) {
  6866. C = originalArray.constructor;
  6867. // cross-realm fallback
  6868. if (typeof C == 'function' && (C === Array || isArray(C.prototype))) C = undefined;
  6869. else if (isObject(C)) {
  6870. C = C[SPECIES];
  6871. if (C === null) C = undefined;
  6872. }
  6873. } return C === undefined ? Array : C;
  6874. };
  6875. /***/ }),
  6876. /* 196 */
  6877. /***/ (function(module, exports, __webpack_require__) {
  6878. var parent = __webpack_require__(197);
  6879. module.exports = parent;
  6880. /***/ }),
  6881. /* 197 */
  6882. /***/ (function(module, exports, __webpack_require__) {
  6883. __webpack_require__(198);
  6884. var path = __webpack_require__(11);
  6885. module.exports = path.Array.isArray;
  6886. /***/ }),
  6887. /* 198 */
  6888. /***/ (function(module, exports, __webpack_require__) {
  6889. var $ = __webpack_require__(5);
  6890. var isArray = __webpack_require__(59);
  6891. // `Array.isArray` method
  6892. // https://tc39.es/ecma262/#sec-array.isarray
  6893. $({ target: 'Array', stat: true }, {
  6894. isArray: isArray
  6895. });
  6896. /***/ }),
  6897. /* 199 */
  6898. /***/ (function(module, exports, __webpack_require__) {
  6899. var parent = __webpack_require__(200);
  6900. module.exports = parent;
  6901. /***/ }),
  6902. /* 200 */
  6903. /***/ (function(module, exports, __webpack_require__) {
  6904. var map = __webpack_require__(201);
  6905. var ArrayPrototype = Array.prototype;
  6906. module.exports = function (it) {
  6907. var own = it.map;
  6908. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.map) ? map : own;
  6909. };
  6910. /***/ }),
  6911. /* 201 */
  6912. /***/ (function(module, exports, __webpack_require__) {
  6913. __webpack_require__(202);
  6914. var entryVirtual = __webpack_require__(14);
  6915. module.exports = entryVirtual('Array').map;
  6916. /***/ }),
  6917. /* 202 */
  6918. /***/ (function(module, exports, __webpack_require__) {
  6919. "use strict";
  6920. var $ = __webpack_require__(5);
  6921. var $map = __webpack_require__(31).map;
  6922. var arrayMethodHasSpeciesSupport = __webpack_require__(60);
  6923. var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('map');
  6924. // `Array.prototype.map` method
  6925. // https://tc39.es/ecma262/#sec-array.prototype.map
  6926. // with adding support of @@species
  6927. $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT }, {
  6928. map: function map(callbackfn /* , thisArg */) {
  6929. return $map(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
  6930. }
  6931. });
  6932. /***/ }),
  6933. /* 203 */
  6934. /***/ (function(module, exports, __webpack_require__) {
  6935. var parent = __webpack_require__(204);
  6936. module.exports = parent;
  6937. /***/ }),
  6938. /* 204 */
  6939. /***/ (function(module, exports, __webpack_require__) {
  6940. var trim = __webpack_require__(205);
  6941. var StringPrototype = String.prototype;
  6942. module.exports = function (it) {
  6943. var own = it.trim;
  6944. return typeof it === 'string' || it === StringPrototype
  6945. || (it instanceof String && own === StringPrototype.trim) ? trim : own;
  6946. };
  6947. /***/ }),
  6948. /* 205 */
  6949. /***/ (function(module, exports, __webpack_require__) {
  6950. __webpack_require__(206);
  6951. var entryVirtual = __webpack_require__(14);
  6952. module.exports = entryVirtual('String').trim;
  6953. /***/ }),
  6954. /* 206 */
  6955. /***/ (function(module, exports, __webpack_require__) {
  6956. "use strict";
  6957. var $ = __webpack_require__(5);
  6958. var $trim = __webpack_require__(97).trim;
  6959. var forcedStringTrimMethod = __webpack_require__(207);
  6960. // `String.prototype.trim` method
  6961. // https://tc39.es/ecma262/#sec-string.prototype.trim
  6962. $({ target: 'String', proto: true, forced: forcedStringTrimMethod('trim') }, {
  6963. trim: function trim() {
  6964. return $trim(this);
  6965. }
  6966. });
  6967. /***/ }),
  6968. /* 207 */
  6969. /***/ (function(module, exports, __webpack_require__) {
  6970. var fails = __webpack_require__(12);
  6971. var whitespaces = __webpack_require__(74);
  6972. var non = '\u200B\u0085\u180E';
  6973. // check that a method works with the correct list
  6974. // of whitespaces and has a correct name
  6975. module.exports = function (METHOD_NAME) {
  6976. return fails(function () {
  6977. return !!whitespaces[METHOD_NAME]() || non[METHOD_NAME]() != non || whitespaces[METHOD_NAME].name !== METHOD_NAME;
  6978. });
  6979. };
  6980. /***/ }),
  6981. /* 208 */
  6982. /***/ (function(module, exports, __webpack_require__) {
  6983. var parent = __webpack_require__(209);
  6984. __webpack_require__(45);
  6985. module.exports = parent;
  6986. /***/ }),
  6987. /* 209 */
  6988. /***/ (function(module, exports, __webpack_require__) {
  6989. __webpack_require__(55);
  6990. __webpack_require__(210);
  6991. __webpack_require__(57);
  6992. __webpack_require__(58);
  6993. var path = __webpack_require__(11);
  6994. module.exports = path.Map;
  6995. /***/ }),
  6996. /* 210 */
  6997. /***/ (function(module, exports, __webpack_require__) {
  6998. "use strict";
  6999. var collection = __webpack_require__(126);
  7000. var collectionStrong = __webpack_require__(129);
  7001. // `Map` constructor
  7002. // https://tc39.es/ecma262/#sec-map-objects
  7003. module.exports = collection('Map', function (init) {
  7004. return function Map() { return init(this, arguments.length ? arguments[0] : undefined); };
  7005. }, collectionStrong);
  7006. /***/ }),
  7007. /* 211 */
  7008. /***/ (function(module, exports, __webpack_require__) {
  7009. var fails = __webpack_require__(12);
  7010. module.exports = !fails(function () {
  7011. // eslint-disable-next-line es/no-object-isextensible, es/no-object-preventextensions -- required for testing
  7012. return Object.isExtensible(Object.preventExtensions({}));
  7013. });
  7014. /***/ }),
  7015. /* 212 */
  7016. /***/ (function(module, exports, __webpack_require__) {
  7017. var parent = __webpack_require__(213);
  7018. module.exports = parent;
  7019. /***/ }),
  7020. /* 213 */
  7021. /***/ (function(module, exports, __webpack_require__) {
  7022. var indexOf = __webpack_require__(214);
  7023. var ArrayPrototype = Array.prototype;
  7024. module.exports = function (it) {
  7025. var own = it.indexOf;
  7026. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.indexOf) ? indexOf : own;
  7027. };
  7028. /***/ }),
  7029. /* 214 */
  7030. /***/ (function(module, exports, __webpack_require__) {
  7031. __webpack_require__(215);
  7032. var entryVirtual = __webpack_require__(14);
  7033. module.exports = entryVirtual('Array').indexOf;
  7034. /***/ }),
  7035. /* 215 */
  7036. /***/ (function(module, exports, __webpack_require__) {
  7037. "use strict";
  7038. /* eslint-disable es/no-array-prototype-indexof -- required for testing */
  7039. var $ = __webpack_require__(5);
  7040. var $indexOf = __webpack_require__(85).indexOf;
  7041. var arrayMethodIsStrict = __webpack_require__(73);
  7042. var nativeIndexOf = [].indexOf;
  7043. var NEGATIVE_ZERO = !!nativeIndexOf && 1 / [1].indexOf(1, -0) < 0;
  7044. var STRICT_METHOD = arrayMethodIsStrict('indexOf');
  7045. // `Array.prototype.indexOf` method
  7046. // https://tc39.es/ecma262/#sec-array.prototype.indexof
  7047. $({ target: 'Array', proto: true, forced: NEGATIVE_ZERO || !STRICT_METHOD }, {
  7048. indexOf: function indexOf(searchElement /* , fromIndex = 0 */) {
  7049. return NEGATIVE_ZERO
  7050. // convert -0 to +0
  7051. ? nativeIndexOf.apply(this, arguments) || 0
  7052. : $indexOf(this, searchElement, arguments.length > 1 ? arguments[1] : undefined);
  7053. }
  7054. });
  7055. /***/ }),
  7056. /* 216 */
  7057. /***/ (function(module, exports, __webpack_require__) {
  7058. var parent = __webpack_require__(217);
  7059. module.exports = parent;
  7060. /***/ }),
  7061. /* 217 */
  7062. /***/ (function(module, exports, __webpack_require__) {
  7063. var splice = __webpack_require__(218);
  7064. var ArrayPrototype = Array.prototype;
  7065. module.exports = function (it) {
  7066. var own = it.splice;
  7067. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.splice) ? splice : own;
  7068. };
  7069. /***/ }),
  7070. /* 218 */
  7071. /***/ (function(module, exports, __webpack_require__) {
  7072. __webpack_require__(219);
  7073. var entryVirtual = __webpack_require__(14);
  7074. module.exports = entryVirtual('Array').splice;
  7075. /***/ }),
  7076. /* 219 */
  7077. /***/ (function(module, exports, __webpack_require__) {
  7078. "use strict";
  7079. var $ = __webpack_require__(5);
  7080. var toAbsoluteIndex = __webpack_require__(86);
  7081. var toInteger = __webpack_require__(70);
  7082. var toLength = __webpack_require__(35);
  7083. var toObject = __webpack_require__(26);
  7084. var arraySpeciesCreate = __webpack_require__(95);
  7085. var createProperty = __webpack_require__(75);
  7086. var arrayMethodHasSpeciesSupport = __webpack_require__(60);
  7087. var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('splice');
  7088. var max = Math.max;
  7089. var min = Math.min;
  7090. var MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF;
  7091. var MAXIMUM_ALLOWED_LENGTH_EXCEEDED = 'Maximum allowed length exceeded';
  7092. // `Array.prototype.splice` method
  7093. // https://tc39.es/ecma262/#sec-array.prototype.splice
  7094. // with adding support of @@species
  7095. $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT }, {
  7096. splice: function splice(start, deleteCount /* , ...items */) {
  7097. var O = toObject(this);
  7098. var len = toLength(O.length);
  7099. var actualStart = toAbsoluteIndex(start, len);
  7100. var argumentsLength = arguments.length;
  7101. var insertCount, actualDeleteCount, A, k, from, to;
  7102. if (argumentsLength === 0) {
  7103. insertCount = actualDeleteCount = 0;
  7104. } else if (argumentsLength === 1) {
  7105. insertCount = 0;
  7106. actualDeleteCount = len - actualStart;
  7107. } else {
  7108. insertCount = argumentsLength - 2;
  7109. actualDeleteCount = min(max(toInteger(deleteCount), 0), len - actualStart);
  7110. }
  7111. if (len + insertCount - actualDeleteCount > MAX_SAFE_INTEGER) {
  7112. throw TypeError(MAXIMUM_ALLOWED_LENGTH_EXCEEDED);
  7113. }
  7114. A = arraySpeciesCreate(O, actualDeleteCount);
  7115. for (k = 0; k < actualDeleteCount; k++) {
  7116. from = actualStart + k;
  7117. if (from in O) createProperty(A, k, O[from]);
  7118. }
  7119. A.length = actualDeleteCount;
  7120. if (insertCount < actualDeleteCount) {
  7121. for (k = actualStart; k < len - actualDeleteCount; k++) {
  7122. from = k + actualDeleteCount;
  7123. to = k + insertCount;
  7124. if (from in O) O[to] = O[from];
  7125. else delete O[to];
  7126. }
  7127. for (k = len; k > len - actualDeleteCount + insertCount; k--) delete O[k - 1];
  7128. } else if (insertCount > actualDeleteCount) {
  7129. for (k = len - actualDeleteCount; k > actualStart; k--) {
  7130. from = k + actualDeleteCount - 1;
  7131. to = k + insertCount - 1;
  7132. if (from in O) O[to] = O[from];
  7133. else delete O[to];
  7134. }
  7135. }
  7136. for (k = 0; k < insertCount; k++) {
  7137. O[k + actualStart] = arguments[k + 2];
  7138. }
  7139. O.length = len - actualDeleteCount + insertCount;
  7140. return A;
  7141. }
  7142. });
  7143. /***/ }),
  7144. /* 220 */
  7145. /***/ (function(module, exports, __webpack_require__) {
  7146. var parent = __webpack_require__(221);
  7147. module.exports = parent;
  7148. /***/ }),
  7149. /* 221 */
  7150. /***/ (function(module, exports, __webpack_require__) {
  7151. var filter = __webpack_require__(222);
  7152. var ArrayPrototype = Array.prototype;
  7153. module.exports = function (it) {
  7154. var own = it.filter;
  7155. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.filter) ? filter : own;
  7156. };
  7157. /***/ }),
  7158. /* 222 */
  7159. /***/ (function(module, exports, __webpack_require__) {
  7160. __webpack_require__(223);
  7161. var entryVirtual = __webpack_require__(14);
  7162. module.exports = entryVirtual('Array').filter;
  7163. /***/ }),
  7164. /* 223 */
  7165. /***/ (function(module, exports, __webpack_require__) {
  7166. "use strict";
  7167. var $ = __webpack_require__(5);
  7168. var $filter = __webpack_require__(31).filter;
  7169. var arrayMethodHasSpeciesSupport = __webpack_require__(60);
  7170. var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('filter');
  7171. // `Array.prototype.filter` method
  7172. // https://tc39.es/ecma262/#sec-array.prototype.filter
  7173. // with adding support of @@species
  7174. $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT }, {
  7175. filter: function filter(callbackfn /* , thisArg */) {
  7176. return $filter(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
  7177. }
  7178. });
  7179. /***/ }),
  7180. /* 224 */
  7181. /***/ (function(module, exports, __webpack_require__) {
  7182. var parent = __webpack_require__(225);
  7183. module.exports = parent;
  7184. /***/ }),
  7185. /* 225 */
  7186. /***/ (function(module, exports, __webpack_require__) {
  7187. var arrayIncludes = __webpack_require__(226);
  7188. var stringIncludes = __webpack_require__(228);
  7189. var ArrayPrototype = Array.prototype;
  7190. var StringPrototype = String.prototype;
  7191. module.exports = function (it) {
  7192. var own = it.includes;
  7193. if (it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.includes)) return arrayIncludes;
  7194. if (typeof it === 'string' || it === StringPrototype || (it instanceof String && own === StringPrototype.includes)) {
  7195. return stringIncludes;
  7196. } return own;
  7197. };
  7198. /***/ }),
  7199. /* 226 */
  7200. /***/ (function(module, exports, __webpack_require__) {
  7201. __webpack_require__(227);
  7202. var entryVirtual = __webpack_require__(14);
  7203. module.exports = entryVirtual('Array').includes;
  7204. /***/ }),
  7205. /* 227 */
  7206. /***/ (function(module, exports, __webpack_require__) {
  7207. "use strict";
  7208. var $ = __webpack_require__(5);
  7209. var $includes = __webpack_require__(85).includes;
  7210. var addToUnscopables = __webpack_require__(89);
  7211. // `Array.prototype.includes` method
  7212. // https://tc39.es/ecma262/#sec-array.prototype.includes
  7213. $({ target: 'Array', proto: true }, {
  7214. includes: function includes(el /* , fromIndex = 0 */) {
  7215. return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined);
  7216. }
  7217. });
  7218. // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables
  7219. addToUnscopables('includes');
  7220. /***/ }),
  7221. /* 228 */
  7222. /***/ (function(module, exports, __webpack_require__) {
  7223. __webpack_require__(229);
  7224. var entryVirtual = __webpack_require__(14);
  7225. module.exports = entryVirtual('String').includes;
  7226. /***/ }),
  7227. /* 229 */
  7228. /***/ (function(module, exports, __webpack_require__) {
  7229. "use strict";
  7230. var $ = __webpack_require__(5);
  7231. var notARegExp = __webpack_require__(230);
  7232. var requireObjectCoercible = __webpack_require__(51);
  7233. var toString = __webpack_require__(30);
  7234. var correctIsRegExpLogic = __webpack_require__(232);
  7235. // `String.prototype.includes` method
  7236. // https://tc39.es/ecma262/#sec-string.prototype.includes
  7237. $({ target: 'String', proto: true, forced: !correctIsRegExpLogic('includes') }, {
  7238. includes: function includes(searchString /* , position = 0 */) {
  7239. return !!~toString(requireObjectCoercible(this))
  7240. .indexOf(toString(notARegExp(searchString)), arguments.length > 1 ? arguments[1] : undefined);
  7241. }
  7242. });
  7243. /***/ }),
  7244. /* 230 */
  7245. /***/ (function(module, exports, __webpack_require__) {
  7246. var isRegExp = __webpack_require__(231);
  7247. module.exports = function (it) {
  7248. if (isRegExp(it)) {
  7249. throw TypeError("The method doesn't accept regular expressions");
  7250. } return it;
  7251. };
  7252. /***/ }),
  7253. /* 231 */
  7254. /***/ (function(module, exports, __webpack_require__) {
  7255. var isObject = __webpack_require__(13);
  7256. var classof = __webpack_require__(50);
  7257. var wellKnownSymbol = __webpack_require__(9);
  7258. var MATCH = wellKnownSymbol('match');
  7259. // `IsRegExp` abstract operation
  7260. // https://tc39.es/ecma262/#sec-isregexp
  7261. module.exports = function (it) {
  7262. var isRegExp;
  7263. return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : classof(it) == 'RegExp');
  7264. };
  7265. /***/ }),
  7266. /* 232 */
  7267. /***/ (function(module, exports, __webpack_require__) {
  7268. var wellKnownSymbol = __webpack_require__(9);
  7269. var MATCH = wellKnownSymbol('match');
  7270. module.exports = function (METHOD_NAME) {
  7271. var regexp = /./;
  7272. try {
  7273. '/./'[METHOD_NAME](regexp);
  7274. } catch (error1) {
  7275. try {
  7276. regexp[MATCH] = false;
  7277. return '/./'[METHOD_NAME](regexp);
  7278. } catch (error2) { /* empty */ }
  7279. } return false;
  7280. };
  7281. /***/ }),
  7282. /* 233 */
  7283. /***/ (function(module, exports, __webpack_require__) {
  7284. var parent = __webpack_require__(234);
  7285. module.exports = parent;
  7286. /***/ }),
  7287. /* 234 */
  7288. /***/ (function(module, exports, __webpack_require__) {
  7289. var bind = __webpack_require__(235);
  7290. var FunctionPrototype = Function.prototype;
  7291. module.exports = function (it) {
  7292. var own = it.bind;
  7293. return it === FunctionPrototype || (it instanceof Function && own === FunctionPrototype.bind) ? bind : own;
  7294. };
  7295. /***/ }),
  7296. /* 235 */
  7297. /***/ (function(module, exports, __webpack_require__) {
  7298. __webpack_require__(236);
  7299. var entryVirtual = __webpack_require__(14);
  7300. module.exports = entryVirtual('Function').bind;
  7301. /***/ }),
  7302. /* 236 */
  7303. /***/ (function(module, exports, __webpack_require__) {
  7304. var $ = __webpack_require__(5);
  7305. var bind = __webpack_require__(237);
  7306. // `Function.prototype.bind` method
  7307. // https://tc39.es/ecma262/#sec-function.prototype.bind
  7308. $({ target: 'Function', proto: true }, {
  7309. bind: bind
  7310. });
  7311. /***/ }),
  7312. /* 237 */
  7313. /***/ (function(module, exports, __webpack_require__) {
  7314. "use strict";
  7315. var aFunction = __webpack_require__(34);
  7316. var isObject = __webpack_require__(13);
  7317. var slice = [].slice;
  7318. var factories = {};
  7319. var construct = function (C, argsLength, args) {
  7320. if (!(argsLength in factories)) {
  7321. for (var list = [], i = 0; i < argsLength; i++) list[i] = 'a[' + i + ']';
  7322. // eslint-disable-next-line no-new-func -- we have no proper alternatives, IE8- only
  7323. factories[argsLength] = Function('C,a', 'return new C(' + list.join(',') + ')');
  7324. } return factories[argsLength](C, args);
  7325. };
  7326. // `Function.prototype.bind` method implementation
  7327. // https://tc39.es/ecma262/#sec-function.prototype.bind
  7328. module.exports = Function.bind || function bind(that /* , ...args */) {
  7329. var fn = aFunction(this);
  7330. var partArgs = slice.call(arguments, 1);
  7331. var boundFunction = function bound(/* args... */) {
  7332. var args = partArgs.concat(slice.call(arguments));
  7333. return this instanceof boundFunction ? construct(fn, args.length, args) : fn.apply(that, args);
  7334. };
  7335. if (isObject(fn.prototype)) boundFunction.prototype = fn.prototype;
  7336. return boundFunction;
  7337. };
  7338. /***/ }),
  7339. /* 238 */
  7340. /***/ (function(module, exports, __webpack_require__) {
  7341. module.exports = __webpack_require__(239);
  7342. /***/ }),
  7343. /* 239 */
  7344. /***/ (function(module, exports, __webpack_require__) {
  7345. var parent = __webpack_require__(240);
  7346. __webpack_require__(260);
  7347. __webpack_require__(261);
  7348. __webpack_require__(262);
  7349. __webpack_require__(263);
  7350. __webpack_require__(264);
  7351. // TODO: Remove from `core-js@4`
  7352. __webpack_require__(265);
  7353. // TODO: Remove from `core-js@4`
  7354. __webpack_require__(266);
  7355. module.exports = parent;
  7356. /***/ }),
  7357. /* 240 */
  7358. /***/ (function(module, exports, __webpack_require__) {
  7359. var parent = __webpack_require__(241);
  7360. __webpack_require__(45);
  7361. module.exports = parent;
  7362. /***/ }),
  7363. /* 241 */
  7364. /***/ (function(module, exports, __webpack_require__) {
  7365. __webpack_require__(242);
  7366. __webpack_require__(57);
  7367. __webpack_require__(243);
  7368. __webpack_require__(244);
  7369. __webpack_require__(245);
  7370. __webpack_require__(246);
  7371. __webpack_require__(247);
  7372. __webpack_require__(131);
  7373. __webpack_require__(248);
  7374. __webpack_require__(249);
  7375. __webpack_require__(250);
  7376. __webpack_require__(251);
  7377. __webpack_require__(252);
  7378. __webpack_require__(253);
  7379. __webpack_require__(254);
  7380. __webpack_require__(255);
  7381. __webpack_require__(256);
  7382. __webpack_require__(257);
  7383. __webpack_require__(258);
  7384. __webpack_require__(259);
  7385. var path = __webpack_require__(11);
  7386. module.exports = path.Symbol;
  7387. /***/ }),
  7388. /* 242 */
  7389. /***/ (function(module, exports, __webpack_require__) {
  7390. "use strict";
  7391. var $ = __webpack_require__(5);
  7392. var fails = __webpack_require__(12);
  7393. var isArray = __webpack_require__(59);
  7394. var isObject = __webpack_require__(13);
  7395. var toObject = __webpack_require__(26);
  7396. var toLength = __webpack_require__(35);
  7397. var createProperty = __webpack_require__(75);
  7398. var arraySpeciesCreate = __webpack_require__(95);
  7399. var arrayMethodHasSpeciesSupport = __webpack_require__(60);
  7400. var wellKnownSymbol = __webpack_require__(9);
  7401. var V8_VERSION = __webpack_require__(66);
  7402. var IS_CONCAT_SPREADABLE = wellKnownSymbol('isConcatSpreadable');
  7403. var MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF;
  7404. var MAXIMUM_ALLOWED_INDEX_EXCEEDED = 'Maximum allowed index exceeded';
  7405. // We can't use this feature detection in V8 since it causes
  7406. // deoptimization and serious performance degradation
  7407. // https://github.com/zloirock/core-js/issues/679
  7408. var IS_CONCAT_SPREADABLE_SUPPORT = V8_VERSION >= 51 || !fails(function () {
  7409. var array = [];
  7410. array[IS_CONCAT_SPREADABLE] = false;
  7411. return array.concat()[0] !== array;
  7412. });
  7413. var SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('concat');
  7414. var isConcatSpreadable = function (O) {
  7415. if (!isObject(O)) return false;
  7416. var spreadable = O[IS_CONCAT_SPREADABLE];
  7417. return spreadable !== undefined ? !!spreadable : isArray(O);
  7418. };
  7419. var FORCED = !IS_CONCAT_SPREADABLE_SUPPORT || !SPECIES_SUPPORT;
  7420. // `Array.prototype.concat` method
  7421. // https://tc39.es/ecma262/#sec-array.prototype.concat
  7422. // with adding support of @@isConcatSpreadable and @@species
  7423. $({ target: 'Array', proto: true, forced: FORCED }, {
  7424. // eslint-disable-next-line no-unused-vars -- required for `.length`
  7425. concat: function concat(arg) {
  7426. var O = toObject(this);
  7427. var A = arraySpeciesCreate(O, 0);
  7428. var n = 0;
  7429. var i, k, length, len, E;
  7430. for (i = -1, length = arguments.length; i < length; i++) {
  7431. E = i === -1 ? O : arguments[i];
  7432. if (isConcatSpreadable(E)) {
  7433. len = toLength(E.length);
  7434. if (n + len > MAX_SAFE_INTEGER) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
  7435. for (k = 0; k < len; k++, n++) if (k in E) createProperty(A, n, E[k]);
  7436. } else {
  7437. if (n >= MAX_SAFE_INTEGER) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
  7438. createProperty(A, n++, E);
  7439. }
  7440. }
  7441. A.length = n;
  7442. return A;
  7443. }
  7444. });
  7445. /***/ }),
  7446. /* 243 */
  7447. /***/ (function(module, exports, __webpack_require__) {
  7448. "use strict";
  7449. var $ = __webpack_require__(5);
  7450. var global = __webpack_require__(8);
  7451. var getBuiltIn = __webpack_require__(25);
  7452. var IS_PURE = __webpack_require__(39);
  7453. var DESCRIPTORS = __webpack_require__(15);
  7454. var NATIVE_SYMBOL = __webpack_require__(79);
  7455. var fails = __webpack_require__(12);
  7456. var has = __webpack_require__(17);
  7457. var isArray = __webpack_require__(59);
  7458. var isObject = __webpack_require__(13);
  7459. var isSymbol = __webpack_require__(65);
  7460. var anObject = __webpack_require__(20);
  7461. var toObject = __webpack_require__(26);
  7462. var toIndexedObject = __webpack_require__(29);
  7463. var toPropertyKey = __webpack_require__(64);
  7464. var $toString = __webpack_require__(30);
  7465. var createPropertyDescriptor = __webpack_require__(38);
  7466. var nativeObjectCreate = __webpack_require__(69);
  7467. var objectKeys = __webpack_require__(53);
  7468. var getOwnPropertyNamesModule = __webpack_require__(98);
  7469. var getOwnPropertyNamesExternal = __webpack_require__(128);
  7470. var getOwnPropertySymbolsModule = __webpack_require__(130);
  7471. var getOwnPropertyDescriptorModule = __webpack_require__(77);
  7472. var definePropertyModule = __webpack_require__(18);
  7473. var propertyIsEnumerableModule = __webpack_require__(63);
  7474. var createNonEnumerableProperty = __webpack_require__(19);
  7475. var redefine = __webpack_require__(56);
  7476. var shared = __webpack_require__(80);
  7477. var sharedKey = __webpack_require__(68);
  7478. var hiddenKeys = __webpack_require__(54);
  7479. var uid = __webpack_require__(67);
  7480. var wellKnownSymbol = __webpack_require__(9);
  7481. var wrappedWellKnownSymbolModule = __webpack_require__(101);
  7482. var defineWellKnownSymbol = __webpack_require__(10);
  7483. var setToStringTag = __webpack_require__(44);
  7484. var InternalStateModule = __webpack_require__(43);
  7485. var $forEach = __webpack_require__(31).forEach;
  7486. var HIDDEN = sharedKey('hidden');
  7487. var SYMBOL = 'Symbol';
  7488. var PROTOTYPE = 'prototype';
  7489. var TO_PRIMITIVE = wellKnownSymbol('toPrimitive');
  7490. var setInternalState = InternalStateModule.set;
  7491. var getInternalState = InternalStateModule.getterFor(SYMBOL);
  7492. var ObjectPrototype = Object[PROTOTYPE];
  7493. var $Symbol = global.Symbol;
  7494. var $stringify = getBuiltIn('JSON', 'stringify');
  7495. var nativeGetOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;
  7496. var nativeDefineProperty = definePropertyModule.f;
  7497. var nativeGetOwnPropertyNames = getOwnPropertyNamesExternal.f;
  7498. var nativePropertyIsEnumerable = propertyIsEnumerableModule.f;
  7499. var AllSymbols = shared('symbols');
  7500. var ObjectPrototypeSymbols = shared('op-symbols');
  7501. var StringToSymbolRegistry = shared('string-to-symbol-registry');
  7502. var SymbolToStringRegistry = shared('symbol-to-string-registry');
  7503. var WellKnownSymbolsStore = shared('wks');
  7504. var QObject = global.QObject;
  7505. // Don't use setters in Qt Script, https://github.com/zloirock/core-js/issues/173
  7506. var USE_SETTER = !QObject || !QObject[PROTOTYPE] || !QObject[PROTOTYPE].findChild;
  7507. // fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687
  7508. var setSymbolDescriptor = DESCRIPTORS && fails(function () {
  7509. return nativeObjectCreate(nativeDefineProperty({}, 'a', {
  7510. get: function () { return nativeDefineProperty(this, 'a', { value: 7 }).a; }
  7511. })).a != 7;
  7512. }) ? function (O, P, Attributes) {
  7513. var ObjectPrototypeDescriptor = nativeGetOwnPropertyDescriptor(ObjectPrototype, P);
  7514. if (ObjectPrototypeDescriptor) delete ObjectPrototype[P];
  7515. nativeDefineProperty(O, P, Attributes);
  7516. if (ObjectPrototypeDescriptor && O !== ObjectPrototype) {
  7517. nativeDefineProperty(ObjectPrototype, P, ObjectPrototypeDescriptor);
  7518. }
  7519. } : nativeDefineProperty;
  7520. var wrap = function (tag, description) {
  7521. var symbol = AllSymbols[tag] = nativeObjectCreate($Symbol[PROTOTYPE]);
  7522. setInternalState(symbol, {
  7523. type: SYMBOL,
  7524. tag: tag,
  7525. description: description
  7526. });
  7527. if (!DESCRIPTORS) symbol.description = description;
  7528. return symbol;
  7529. };
  7530. var $defineProperty = function defineProperty(O, P, Attributes) {
  7531. if (O === ObjectPrototype) $defineProperty(ObjectPrototypeSymbols, P, Attributes);
  7532. anObject(O);
  7533. var key = toPropertyKey(P);
  7534. anObject(Attributes);
  7535. if (has(AllSymbols, key)) {
  7536. if (!Attributes.enumerable) {
  7537. if (!has(O, HIDDEN)) nativeDefineProperty(O, HIDDEN, createPropertyDescriptor(1, {}));
  7538. O[HIDDEN][key] = true;
  7539. } else {
  7540. if (has(O, HIDDEN) && O[HIDDEN][key]) O[HIDDEN][key] = false;
  7541. Attributes = nativeObjectCreate(Attributes, { enumerable: createPropertyDescriptor(0, false) });
  7542. } return setSymbolDescriptor(O, key, Attributes);
  7543. } return nativeDefineProperty(O, key, Attributes);
  7544. };
  7545. var $defineProperties = function defineProperties(O, Properties) {
  7546. anObject(O);
  7547. var properties = toIndexedObject(Properties);
  7548. var keys = objectKeys(properties).concat($getOwnPropertySymbols(properties));
  7549. $forEach(keys, function (key) {
  7550. if (!DESCRIPTORS || $propertyIsEnumerable.call(properties, key)) $defineProperty(O, key, properties[key]);
  7551. });
  7552. return O;
  7553. };
  7554. var $create = function create(O, Properties) {
  7555. return Properties === undefined ? nativeObjectCreate(O) : $defineProperties(nativeObjectCreate(O), Properties);
  7556. };
  7557. var $propertyIsEnumerable = function propertyIsEnumerable(V) {
  7558. var P = toPropertyKey(V);
  7559. var enumerable = nativePropertyIsEnumerable.call(this, P);
  7560. if (this === ObjectPrototype && has(AllSymbols, P) && !has(ObjectPrototypeSymbols, P)) return false;
  7561. return enumerable || !has(this, P) || !has(AllSymbols, P) || has(this, HIDDEN) && this[HIDDEN][P] ? enumerable : true;
  7562. };
  7563. var $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(O, P) {
  7564. var it = toIndexedObject(O);
  7565. var key = toPropertyKey(P);
  7566. if (it === ObjectPrototype && has(AllSymbols, key) && !has(ObjectPrototypeSymbols, key)) return;
  7567. var descriptor = nativeGetOwnPropertyDescriptor(it, key);
  7568. if (descriptor && has(AllSymbols, key) && !(has(it, HIDDEN) && it[HIDDEN][key])) {
  7569. descriptor.enumerable = true;
  7570. }
  7571. return descriptor;
  7572. };
  7573. var $getOwnPropertyNames = function getOwnPropertyNames(O) {
  7574. var names = nativeGetOwnPropertyNames(toIndexedObject(O));
  7575. var result = [];
  7576. $forEach(names, function (key) {
  7577. if (!has(AllSymbols, key) && !has(hiddenKeys, key)) result.push(key);
  7578. });
  7579. return result;
  7580. };
  7581. var $getOwnPropertySymbols = function getOwnPropertySymbols(O) {
  7582. var IS_OBJECT_PROTOTYPE = O === ObjectPrototype;
  7583. var names = nativeGetOwnPropertyNames(IS_OBJECT_PROTOTYPE ? ObjectPrototypeSymbols : toIndexedObject(O));
  7584. var result = [];
  7585. $forEach(names, function (key) {
  7586. if (has(AllSymbols, key) && (!IS_OBJECT_PROTOTYPE || has(ObjectPrototype, key))) {
  7587. result.push(AllSymbols[key]);
  7588. }
  7589. });
  7590. return result;
  7591. };
  7592. // `Symbol` constructor
  7593. // https://tc39.es/ecma262/#sec-symbol-constructor
  7594. if (!NATIVE_SYMBOL) {
  7595. $Symbol = function Symbol() {
  7596. if (this instanceof $Symbol) throw TypeError('Symbol is not a constructor');
  7597. var description = !arguments.length || arguments[0] === undefined ? undefined : $toString(arguments[0]);
  7598. var tag = uid(description);
  7599. var setter = function (value) {
  7600. if (this === ObjectPrototype) setter.call(ObjectPrototypeSymbols, value);
  7601. if (has(this, HIDDEN) && has(this[HIDDEN], tag)) this[HIDDEN][tag] = false;
  7602. setSymbolDescriptor(this, tag, createPropertyDescriptor(1, value));
  7603. };
  7604. if (DESCRIPTORS && USE_SETTER) setSymbolDescriptor(ObjectPrototype, tag, { configurable: true, set: setter });
  7605. return wrap(tag, description);
  7606. };
  7607. redefine($Symbol[PROTOTYPE], 'toString', function toString() {
  7608. return getInternalState(this).tag;
  7609. });
  7610. redefine($Symbol, 'withoutSetter', function (description) {
  7611. return wrap(uid(description), description);
  7612. });
  7613. propertyIsEnumerableModule.f = $propertyIsEnumerable;
  7614. definePropertyModule.f = $defineProperty;
  7615. getOwnPropertyDescriptorModule.f = $getOwnPropertyDescriptor;
  7616. getOwnPropertyNamesModule.f = getOwnPropertyNamesExternal.f = $getOwnPropertyNames;
  7617. getOwnPropertySymbolsModule.f = $getOwnPropertySymbols;
  7618. wrappedWellKnownSymbolModule.f = function (name) {
  7619. return wrap(wellKnownSymbol(name), name);
  7620. };
  7621. if (DESCRIPTORS) {
  7622. // https://github.com/tc39/proposal-Symbol-description
  7623. nativeDefineProperty($Symbol[PROTOTYPE], 'description', {
  7624. configurable: true,
  7625. get: function description() {
  7626. return getInternalState(this).description;
  7627. }
  7628. });
  7629. if (!IS_PURE) {
  7630. redefine(ObjectPrototype, 'propertyIsEnumerable', $propertyIsEnumerable, { unsafe: true });
  7631. }
  7632. }
  7633. }
  7634. $({ global: true, wrap: true, forced: !NATIVE_SYMBOL, sham: !NATIVE_SYMBOL }, {
  7635. Symbol: $Symbol
  7636. });
  7637. $forEach(objectKeys(WellKnownSymbolsStore), function (name) {
  7638. defineWellKnownSymbol(name);
  7639. });
  7640. $({ target: SYMBOL, stat: true, forced: !NATIVE_SYMBOL }, {
  7641. // `Symbol.for` method
  7642. // https://tc39.es/ecma262/#sec-symbol.for
  7643. 'for': function (key) {
  7644. var string = $toString(key);
  7645. if (has(StringToSymbolRegistry, string)) return StringToSymbolRegistry[string];
  7646. var symbol = $Symbol(string);
  7647. StringToSymbolRegistry[string] = symbol;
  7648. SymbolToStringRegistry[symbol] = string;
  7649. return symbol;
  7650. },
  7651. // `Symbol.keyFor` method
  7652. // https://tc39.es/ecma262/#sec-symbol.keyfor
  7653. keyFor: function keyFor(sym) {
  7654. if (!isSymbol(sym)) throw TypeError(sym + ' is not a symbol');
  7655. if (has(SymbolToStringRegistry, sym)) return SymbolToStringRegistry[sym];
  7656. },
  7657. useSetter: function () { USE_SETTER = true; },
  7658. useSimple: function () { USE_SETTER = false; }
  7659. });
  7660. $({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL, sham: !DESCRIPTORS }, {
  7661. // `Object.create` method
  7662. // https://tc39.es/ecma262/#sec-object.create
  7663. create: $create,
  7664. // `Object.defineProperty` method
  7665. // https://tc39.es/ecma262/#sec-object.defineproperty
  7666. defineProperty: $defineProperty,
  7667. // `Object.defineProperties` method
  7668. // https://tc39.es/ecma262/#sec-object.defineproperties
  7669. defineProperties: $defineProperties,
  7670. // `Object.getOwnPropertyDescriptor` method
  7671. // https://tc39.es/ecma262/#sec-object.getownpropertydescriptors
  7672. getOwnPropertyDescriptor: $getOwnPropertyDescriptor
  7673. });
  7674. $({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL }, {
  7675. // `Object.getOwnPropertyNames` method
  7676. // https://tc39.es/ecma262/#sec-object.getownpropertynames
  7677. getOwnPropertyNames: $getOwnPropertyNames,
  7678. // `Object.getOwnPropertySymbols` method
  7679. // https://tc39.es/ecma262/#sec-object.getownpropertysymbols
  7680. getOwnPropertySymbols: $getOwnPropertySymbols
  7681. });
  7682. // Chrome 38 and 39 `Object.getOwnPropertySymbols` fails on primitives
  7683. // https://bugs.chromium.org/p/v8/issues/detail?id=3443
  7684. $({ target: 'Object', stat: true, forced: fails(function () { getOwnPropertySymbolsModule.f(1); }) }, {
  7685. getOwnPropertySymbols: function getOwnPropertySymbols(it) {
  7686. return getOwnPropertySymbolsModule.f(toObject(it));
  7687. }
  7688. });
  7689. // `JSON.stringify` method behavior with symbols
  7690. // https://tc39.es/ecma262/#sec-json.stringify
  7691. if ($stringify) {
  7692. var FORCED_JSON_STRINGIFY = !NATIVE_SYMBOL || fails(function () {
  7693. var symbol = $Symbol();
  7694. // MS Edge converts symbol values to JSON as {}
  7695. return $stringify([symbol]) != '[null]'
  7696. // WebKit converts symbol values to JSON as null
  7697. || $stringify({ a: symbol }) != '{}'
  7698. // V8 throws on boxed symbols
  7699. || $stringify(Object(symbol)) != '{}';
  7700. });
  7701. $({ target: 'JSON', stat: true, forced: FORCED_JSON_STRINGIFY }, {
  7702. // eslint-disable-next-line no-unused-vars -- required for `.length`
  7703. stringify: function stringify(it, replacer, space) {
  7704. var args = [it];
  7705. var index = 1;
  7706. var $replacer;
  7707. while (arguments.length > index) args.push(arguments[index++]);
  7708. $replacer = replacer;
  7709. if (!isObject(replacer) && it === undefined || isSymbol(it)) return; // IE8 returns string on undefined
  7710. if (!isArray(replacer)) replacer = function (key, value) {
  7711. if (typeof $replacer == 'function') value = $replacer.call(this, key, value);
  7712. if (!isSymbol(value)) return value;
  7713. };
  7714. args[1] = replacer;
  7715. return $stringify.apply(null, args);
  7716. }
  7717. });
  7718. }
  7719. // `Symbol.prototype[@@toPrimitive]` method
  7720. // https://tc39.es/ecma262/#sec-symbol.prototype-@@toprimitive
  7721. if (!$Symbol[PROTOTYPE][TO_PRIMITIVE]) {
  7722. createNonEnumerableProperty($Symbol[PROTOTYPE], TO_PRIMITIVE, $Symbol[PROTOTYPE].valueOf);
  7723. }
  7724. // `Symbol.prototype[@@toStringTag]` property
  7725. // https://tc39.es/ecma262/#sec-symbol.prototype-@@tostringtag
  7726. setToStringTag($Symbol, SYMBOL);
  7727. hiddenKeys[HIDDEN] = true;
  7728. /***/ }),
  7729. /* 244 */
  7730. /***/ (function(module, exports, __webpack_require__) {
  7731. var defineWellKnownSymbol = __webpack_require__(10);
  7732. // `Symbol.asyncIterator` well-known symbol
  7733. // https://tc39.es/ecma262/#sec-symbol.asynciterator
  7734. defineWellKnownSymbol('asyncIterator');
  7735. /***/ }),
  7736. /* 245 */
  7737. /***/ (function(module, exports) {
  7738. // empty
  7739. /***/ }),
  7740. /* 246 */
  7741. /***/ (function(module, exports, __webpack_require__) {
  7742. var defineWellKnownSymbol = __webpack_require__(10);
  7743. // `Symbol.hasInstance` well-known symbol
  7744. // https://tc39.es/ecma262/#sec-symbol.hasinstance
  7745. defineWellKnownSymbol('hasInstance');
  7746. /***/ }),
  7747. /* 247 */
  7748. /***/ (function(module, exports, __webpack_require__) {
  7749. var defineWellKnownSymbol = __webpack_require__(10);
  7750. // `Symbol.isConcatSpreadable` well-known symbol
  7751. // https://tc39.es/ecma262/#sec-symbol.isconcatspreadable
  7752. defineWellKnownSymbol('isConcatSpreadable');
  7753. /***/ }),
  7754. /* 248 */
  7755. /***/ (function(module, exports, __webpack_require__) {
  7756. var defineWellKnownSymbol = __webpack_require__(10);
  7757. // `Symbol.match` well-known symbol
  7758. // https://tc39.es/ecma262/#sec-symbol.match
  7759. defineWellKnownSymbol('match');
  7760. /***/ }),
  7761. /* 249 */
  7762. /***/ (function(module, exports, __webpack_require__) {
  7763. var defineWellKnownSymbol = __webpack_require__(10);
  7764. // `Symbol.matchAll` well-known symbol
  7765. // https://tc39.es/ecma262/#sec-symbol.matchall
  7766. defineWellKnownSymbol('matchAll');
  7767. /***/ }),
  7768. /* 250 */
  7769. /***/ (function(module, exports, __webpack_require__) {
  7770. var defineWellKnownSymbol = __webpack_require__(10);
  7771. // `Symbol.replace` well-known symbol
  7772. // https://tc39.es/ecma262/#sec-symbol.replace
  7773. defineWellKnownSymbol('replace');
  7774. /***/ }),
  7775. /* 251 */
  7776. /***/ (function(module, exports, __webpack_require__) {
  7777. var defineWellKnownSymbol = __webpack_require__(10);
  7778. // `Symbol.search` well-known symbol
  7779. // https://tc39.es/ecma262/#sec-symbol.search
  7780. defineWellKnownSymbol('search');
  7781. /***/ }),
  7782. /* 252 */
  7783. /***/ (function(module, exports, __webpack_require__) {
  7784. var defineWellKnownSymbol = __webpack_require__(10);
  7785. // `Symbol.species` well-known symbol
  7786. // https://tc39.es/ecma262/#sec-symbol.species
  7787. defineWellKnownSymbol('species');
  7788. /***/ }),
  7789. /* 253 */
  7790. /***/ (function(module, exports, __webpack_require__) {
  7791. var defineWellKnownSymbol = __webpack_require__(10);
  7792. // `Symbol.split` well-known symbol
  7793. // https://tc39.es/ecma262/#sec-symbol.split
  7794. defineWellKnownSymbol('split');
  7795. /***/ }),
  7796. /* 254 */
  7797. /***/ (function(module, exports, __webpack_require__) {
  7798. var defineWellKnownSymbol = __webpack_require__(10);
  7799. // `Symbol.toPrimitive` well-known symbol
  7800. // https://tc39.es/ecma262/#sec-symbol.toprimitive
  7801. defineWellKnownSymbol('toPrimitive');
  7802. /***/ }),
  7803. /* 255 */
  7804. /***/ (function(module, exports, __webpack_require__) {
  7805. var defineWellKnownSymbol = __webpack_require__(10);
  7806. // `Symbol.toStringTag` well-known symbol
  7807. // https://tc39.es/ecma262/#sec-symbol.tostringtag
  7808. defineWellKnownSymbol('toStringTag');
  7809. /***/ }),
  7810. /* 256 */
  7811. /***/ (function(module, exports, __webpack_require__) {
  7812. var defineWellKnownSymbol = __webpack_require__(10);
  7813. // `Symbol.unscopables` well-known symbol
  7814. // https://tc39.es/ecma262/#sec-symbol.unscopables
  7815. defineWellKnownSymbol('unscopables');
  7816. /***/ }),
  7817. /* 257 */
  7818. /***/ (function(module, exports, __webpack_require__) {
  7819. var global = __webpack_require__(8);
  7820. var setToStringTag = __webpack_require__(44);
  7821. // JSON[@@toStringTag] property
  7822. // https://tc39.es/ecma262/#sec-json-@@tostringtag
  7823. setToStringTag(global.JSON, 'JSON', true);
  7824. /***/ }),
  7825. /* 258 */
  7826. /***/ (function(module, exports) {
  7827. // empty
  7828. /***/ }),
  7829. /* 259 */
  7830. /***/ (function(module, exports) {
  7831. // empty
  7832. /***/ }),
  7833. /* 260 */
  7834. /***/ (function(module, exports, __webpack_require__) {
  7835. var defineWellKnownSymbol = __webpack_require__(10);
  7836. // `Symbol.asyncDispose` well-known symbol
  7837. // https://github.com/tc39/proposal-using-statement
  7838. defineWellKnownSymbol('asyncDispose');
  7839. /***/ }),
  7840. /* 261 */
  7841. /***/ (function(module, exports, __webpack_require__) {
  7842. var defineWellKnownSymbol = __webpack_require__(10);
  7843. // `Symbol.dispose` well-known symbol
  7844. // https://github.com/tc39/proposal-using-statement
  7845. defineWellKnownSymbol('dispose');
  7846. /***/ }),
  7847. /* 262 */
  7848. /***/ (function(module, exports, __webpack_require__) {
  7849. var defineWellKnownSymbol = __webpack_require__(10);
  7850. // `Symbol.matcher` well-known symbol
  7851. // https://github.com/tc39/proposal-pattern-matching
  7852. defineWellKnownSymbol('matcher');
  7853. /***/ }),
  7854. /* 263 */
  7855. /***/ (function(module, exports, __webpack_require__) {
  7856. var defineWellKnownSymbol = __webpack_require__(10);
  7857. // `Symbol.metadata` well-known symbol
  7858. // https://github.com/tc39/proposal-decorators
  7859. defineWellKnownSymbol('metadata');
  7860. /***/ }),
  7861. /* 264 */
  7862. /***/ (function(module, exports, __webpack_require__) {
  7863. var defineWellKnownSymbol = __webpack_require__(10);
  7864. // `Symbol.observable` well-known symbol
  7865. // https://github.com/tc39/proposal-observable
  7866. defineWellKnownSymbol('observable');
  7867. /***/ }),
  7868. /* 265 */
  7869. /***/ (function(module, exports, __webpack_require__) {
  7870. // TODO: remove from `core-js@4`
  7871. var defineWellKnownSymbol = __webpack_require__(10);
  7872. // `Symbol.patternMatch` well-known symbol
  7873. // https://github.com/tc39/proposal-pattern-matching
  7874. defineWellKnownSymbol('patternMatch');
  7875. /***/ }),
  7876. /* 266 */
  7877. /***/ (function(module, exports, __webpack_require__) {
  7878. // TODO: remove from `core-js@4`
  7879. var defineWellKnownSymbol = __webpack_require__(10);
  7880. defineWellKnownSymbol('replaceAll');
  7881. /***/ }),
  7882. /* 267 */
  7883. /***/ (function(module, exports, __webpack_require__) {
  7884. module.exports = __webpack_require__(268);
  7885. /***/ }),
  7886. /* 268 */
  7887. /***/ (function(module, exports, __webpack_require__) {
  7888. var parent = __webpack_require__(269);
  7889. module.exports = parent;
  7890. /***/ }),
  7891. /* 269 */
  7892. /***/ (function(module, exports, __webpack_require__) {
  7893. var parent = __webpack_require__(270);
  7894. __webpack_require__(45);
  7895. module.exports = parent;
  7896. /***/ }),
  7897. /* 270 */
  7898. /***/ (function(module, exports, __webpack_require__) {
  7899. __webpack_require__(55);
  7900. __webpack_require__(57);
  7901. __webpack_require__(58);
  7902. __webpack_require__(131);
  7903. var WrappedWellKnownSymbolModule = __webpack_require__(101);
  7904. module.exports = WrappedWellKnownSymbolModule.f('iterator');
  7905. /***/ }),
  7906. /* 271 */
  7907. /***/ (function(module, exports, __webpack_require__) {
  7908. module.exports = __webpack_require__(272);
  7909. /***/ }),
  7910. /* 272 */
  7911. /***/ (function(module, exports, __webpack_require__) {
  7912. var parent = __webpack_require__(273);
  7913. module.exports = parent;
  7914. /***/ }),
  7915. /* 273 */
  7916. /***/ (function(module, exports, __webpack_require__) {
  7917. __webpack_require__(274);
  7918. var path = __webpack_require__(11);
  7919. module.exports = path.parseInt;
  7920. /***/ }),
  7921. /* 274 */
  7922. /***/ (function(module, exports, __webpack_require__) {
  7923. var $ = __webpack_require__(5);
  7924. var parseIntImplementation = __webpack_require__(275);
  7925. // `parseInt` method
  7926. // https://tc39.es/ecma262/#sec-parseint-string-radix
  7927. $({ global: true, forced: parseInt != parseIntImplementation }, {
  7928. parseInt: parseIntImplementation
  7929. });
  7930. /***/ }),
  7931. /* 275 */
  7932. /***/ (function(module, exports, __webpack_require__) {
  7933. var global = __webpack_require__(8);
  7934. var toString = __webpack_require__(30);
  7935. var trim = __webpack_require__(97).trim;
  7936. var whitespaces = __webpack_require__(74);
  7937. var $parseInt = global.parseInt;
  7938. var hex = /^[+-]?0[Xx]/;
  7939. var FORCED = $parseInt(whitespaces + '08') !== 8 || $parseInt(whitespaces + '0x16') !== 22;
  7940. // `parseInt` method
  7941. // https://tc39.es/ecma262/#sec-parseint-string-radix
  7942. module.exports = FORCED ? function parseInt(string, radix) {
  7943. var S = trim(toString(string));
  7944. return $parseInt(S, (radix >>> 0) || (hex.test(S) ? 16 : 10));
  7945. } : $parseInt;
  7946. /***/ }),
  7947. /* 276 */
  7948. /***/ (function(module, exports, __webpack_require__) {
  7949. var parent = __webpack_require__(277);
  7950. module.exports = parent;
  7951. /***/ }),
  7952. /* 277 */
  7953. /***/ (function(module, exports, __webpack_require__) {
  7954. var slice = __webpack_require__(278);
  7955. var ArrayPrototype = Array.prototype;
  7956. module.exports = function (it) {
  7957. var own = it.slice;
  7958. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.slice) ? slice : own;
  7959. };
  7960. /***/ }),
  7961. /* 278 */
  7962. /***/ (function(module, exports, __webpack_require__) {
  7963. __webpack_require__(279);
  7964. var entryVirtual = __webpack_require__(14);
  7965. module.exports = entryVirtual('Array').slice;
  7966. /***/ }),
  7967. /* 279 */
  7968. /***/ (function(module, exports, __webpack_require__) {
  7969. "use strict";
  7970. var $ = __webpack_require__(5);
  7971. var isObject = __webpack_require__(13);
  7972. var isArray = __webpack_require__(59);
  7973. var toAbsoluteIndex = __webpack_require__(86);
  7974. var toLength = __webpack_require__(35);
  7975. var toIndexedObject = __webpack_require__(29);
  7976. var createProperty = __webpack_require__(75);
  7977. var wellKnownSymbol = __webpack_require__(9);
  7978. var arrayMethodHasSpeciesSupport = __webpack_require__(60);
  7979. var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('slice');
  7980. var SPECIES = wellKnownSymbol('species');
  7981. var nativeSlice = [].slice;
  7982. var max = Math.max;
  7983. // `Array.prototype.slice` method
  7984. // https://tc39.es/ecma262/#sec-array.prototype.slice
  7985. // fallback for not array-like ES3 strings and DOM objects
  7986. $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT }, {
  7987. slice: function slice(start, end) {
  7988. var O = toIndexedObject(this);
  7989. var length = toLength(O.length);
  7990. var k = toAbsoluteIndex(start, length);
  7991. var fin = toAbsoluteIndex(end === undefined ? length : end, length);
  7992. // inline `ArraySpeciesCreate` for usage native `Array#slice` where it's possible
  7993. var Constructor, result, n;
  7994. if (isArray(O)) {
  7995. Constructor = O.constructor;
  7996. // cross-realm fallback
  7997. if (typeof Constructor == 'function' && (Constructor === Array || isArray(Constructor.prototype))) {
  7998. Constructor = undefined;
  7999. } else if (isObject(Constructor)) {
  8000. Constructor = Constructor[SPECIES];
  8001. if (Constructor === null) Constructor = undefined;
  8002. }
  8003. if (Constructor === Array || Constructor === undefined) {
  8004. return nativeSlice.call(O, k, fin);
  8005. }
  8006. }
  8007. result = new (Constructor === undefined ? Array : Constructor)(max(fin - k, 0));
  8008. for (n = 0; k < fin; k++, n++) if (k in O) createProperty(result, n, O[k]);
  8009. result.length = n;
  8010. return result;
  8011. }
  8012. });
  8013. /***/ }),
  8014. /* 280 */
  8015. /***/ (function(module, exports, __webpack_require__) {
  8016. __webpack_require__(281);
  8017. var path = __webpack_require__(11);
  8018. module.exports = path.setTimeout;
  8019. /***/ }),
  8020. /* 281 */
  8021. /***/ (function(module, exports, __webpack_require__) {
  8022. var $ = __webpack_require__(5);
  8023. var global = __webpack_require__(8);
  8024. var userAgent = __webpack_require__(52);
  8025. var slice = [].slice;
  8026. var MSIE = /MSIE .\./.test(userAgent); // <- dirty ie9- check
  8027. var wrap = function (scheduler) {
  8028. return function (handler, timeout /* , ...arguments */) {
  8029. var boundArgs = arguments.length > 2;
  8030. var args = boundArgs ? slice.call(arguments, 2) : undefined;
  8031. return scheduler(boundArgs ? function () {
  8032. // eslint-disable-next-line no-new-func -- spec requirement
  8033. (typeof handler == 'function' ? handler : Function(handler)).apply(this, args);
  8034. } : handler, timeout);
  8035. };
  8036. };
  8037. // ie9- setTimeout & setInterval additional parameters fix
  8038. // https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#timers
  8039. $({ global: true, bind: true, forced: MSIE }, {
  8040. // `setTimeout` method
  8041. // https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#dom-settimeout
  8042. setTimeout: wrap(global.setTimeout),
  8043. // `setInterval` method
  8044. // https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#dom-setinterval
  8045. setInterval: wrap(global.setInterval)
  8046. });
  8047. /***/ }),
  8048. /* 282 */
  8049. /***/ (function(module, exports, __webpack_require__) {
  8050. "use strict";
  8051. /**
  8052. * @description 编辑器配置
  8053. * @author wangfupeng
  8054. */
  8055. var _interopRequireDefault = __webpack_require__(0);
  8056. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8057. var _assign = _interopRequireDefault(__webpack_require__(132));
  8058. (0, _defineProperty["default"])(exports, "__esModule", {
  8059. value: true
  8060. });
  8061. var tslib_1 = __webpack_require__(2);
  8062. var menus_1 = tslib_1.__importDefault(__webpack_require__(287));
  8063. var events_1 = tslib_1.__importDefault(__webpack_require__(288));
  8064. var style_1 = tslib_1.__importDefault(__webpack_require__(133));
  8065. var paste_1 = tslib_1.__importDefault(__webpack_require__(289));
  8066. var cmd_1 = tslib_1.__importDefault(__webpack_require__(290));
  8067. var image_1 = tslib_1.__importDefault(__webpack_require__(291));
  8068. var text_1 = tslib_1.__importDefault(__webpack_require__(134));
  8069. var lang_1 = tslib_1.__importDefault(__webpack_require__(292));
  8070. var history_1 = tslib_1.__importDefault(__webpack_require__(293));
  8071. var video_1 = tslib_1.__importDefault(__webpack_require__(294)); // 合并所有的配置信息
  8072. var defaultConfig = (0, _assign["default"])({}, menus_1["default"], events_1["default"], style_1["default"], cmd_1["default"], paste_1["default"], image_1["default"], text_1["default"], lang_1["default"], history_1["default"], video_1["default"], //链接校验的配置函数
  8073. {
  8074. linkCheck: function linkCheck(text, link) {
  8075. return true;
  8076. }
  8077. });
  8078. exports["default"] = defaultConfig;
  8079. /***/ }),
  8080. /* 283 */
  8081. /***/ (function(module, exports, __webpack_require__) {
  8082. var parent = __webpack_require__(284);
  8083. module.exports = parent;
  8084. /***/ }),
  8085. /* 284 */
  8086. /***/ (function(module, exports, __webpack_require__) {
  8087. __webpack_require__(285);
  8088. var path = __webpack_require__(11);
  8089. module.exports = path.Object.assign;
  8090. /***/ }),
  8091. /* 285 */
  8092. /***/ (function(module, exports, __webpack_require__) {
  8093. var $ = __webpack_require__(5);
  8094. var assign = __webpack_require__(286);
  8095. // `Object.assign` method
  8096. // https://tc39.es/ecma262/#sec-object.assign
  8097. // eslint-disable-next-line es/no-object-assign -- required for testing
  8098. $({ target: 'Object', stat: true, forced: Object.assign !== assign }, {
  8099. assign: assign
  8100. });
  8101. /***/ }),
  8102. /* 286 */
  8103. /***/ (function(module, exports, __webpack_require__) {
  8104. "use strict";
  8105. var DESCRIPTORS = __webpack_require__(15);
  8106. var fails = __webpack_require__(12);
  8107. var objectKeys = __webpack_require__(53);
  8108. var getOwnPropertySymbolsModule = __webpack_require__(130);
  8109. var propertyIsEnumerableModule = __webpack_require__(63);
  8110. var toObject = __webpack_require__(26);
  8111. var IndexedObject = __webpack_require__(78);
  8112. // eslint-disable-next-line es/no-object-assign -- safe
  8113. var $assign = Object.assign;
  8114. // eslint-disable-next-line es/no-object-defineproperty -- required for testing
  8115. var defineProperty = Object.defineProperty;
  8116. // `Object.assign` method
  8117. // https://tc39.es/ecma262/#sec-object.assign
  8118. module.exports = !$assign || fails(function () {
  8119. // should have correct order of operations (Edge bug)
  8120. if (DESCRIPTORS && $assign({ b: 1 }, $assign(defineProperty({}, 'a', {
  8121. enumerable: true,
  8122. get: function () {
  8123. defineProperty(this, 'b', {
  8124. value: 3,
  8125. enumerable: false
  8126. });
  8127. }
  8128. }), { b: 2 })).b !== 1) return true;
  8129. // should work with symbols and should have deterministic property order (V8 bug)
  8130. var A = {};
  8131. var B = {};
  8132. // eslint-disable-next-line es/no-symbol -- safe
  8133. var symbol = Symbol();
  8134. var alphabet = 'abcdefghijklmnopqrst';
  8135. A[symbol] = 7;
  8136. alphabet.split('').forEach(function (chr) { B[chr] = chr; });
  8137. return $assign({}, A)[symbol] != 7 || objectKeys($assign({}, B)).join('') != alphabet;
  8138. }) ? function assign(target, source) { // eslint-disable-line no-unused-vars -- required for `.length`
  8139. var T = toObject(target);
  8140. var argumentsLength = arguments.length;
  8141. var index = 1;
  8142. var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;
  8143. var propertyIsEnumerable = propertyIsEnumerableModule.f;
  8144. while (argumentsLength > index) {
  8145. var S = IndexedObject(arguments[index++]);
  8146. var keys = getOwnPropertySymbols ? objectKeys(S).concat(getOwnPropertySymbols(S)) : objectKeys(S);
  8147. var length = keys.length;
  8148. var j = 0;
  8149. var key;
  8150. while (length > j) {
  8151. key = keys[j++];
  8152. if (!DESCRIPTORS || propertyIsEnumerable.call(S, key)) T[key] = S[key];
  8153. }
  8154. } return T;
  8155. } : $assign;
  8156. /***/ }),
  8157. /* 287 */
  8158. /***/ (function(module, exports, __webpack_require__) {
  8159. "use strict";
  8160. /**
  8161. * @description 菜单配置
  8162. * @author wangfupeng
  8163. */
  8164. var _interopRequireDefault = __webpack_require__(0);
  8165. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8166. (0, _defineProperty["default"])(exports, "__esModule", {
  8167. value: true
  8168. });
  8169. /*表情菜单数据结构类型END*/
  8170. exports["default"] = {
  8171. menus: ['head', 'bold', 'fontSize', // 'customFontSize',
  8172. 'fontName', 'italic', 'underline', 'strikeThrough', 'indent', 'lineHeight', 'foreColor', 'backColor', 'link', 'list', 'todo', 'justify', 'quote', 'emoticon', 'image', 'video', 'table', 'code', 'splitLine', 'undo', 'redo'],
  8173. fontNames: ['黑体', '仿宋', '楷体', '标楷体', '华文仿宋', '华文楷体', '宋体', '微软雅黑', 'Arial', 'Tahoma', 'Verdana', 'Times New Roman', 'Courier New'],
  8174. // fontNames: [{ name: '宋体', value: '宋体' }],
  8175. fontSizes: {
  8176. 'x-small': {
  8177. name: '10px',
  8178. value: '1'
  8179. },
  8180. small: {
  8181. name: '13px',
  8182. value: '2'
  8183. },
  8184. normal: {
  8185. name: '16px',
  8186. value: '3'
  8187. },
  8188. large: {
  8189. name: '18px',
  8190. value: '4'
  8191. },
  8192. 'x-large': {
  8193. name: '24px',
  8194. value: '5'
  8195. },
  8196. 'xx-large': {
  8197. name: '32px',
  8198. value: '6'
  8199. },
  8200. 'xxx-large': {
  8201. name: '48px',
  8202. value: '7'
  8203. }
  8204. },
  8205. // customFontSize: [ // 该菜单暂时不用 - 王福朋 20200924
  8206. // { value: '9px', text: '9' },
  8207. // { value: '10px', text: '10' },
  8208. // { value: '12px', text: '12' },
  8209. // { value: '14px', text: '14' },
  8210. // { value: '16px', text: '16' },
  8211. // { value: '20px', text: '20' },
  8212. // { value: '42px', text: '42' },
  8213. // { value: '72px', text: '72' },
  8214. // ],
  8215. colors: ['#000000', '#ffffff', '#eeece0', '#1c487f', '#4d80bf', '#c24f4a', '#8baa4a', '#7b5ba1', '#46acc8', '#f9963b'],
  8216. //插入代码语言配置
  8217. languageType: ['Bash', 'C', 'C#', 'C++', 'CSS', 'Java', 'JavaScript', 'JSON', 'TypeScript', 'Plain text', 'Html', 'XML', 'SQL', 'Go', 'Kotlin', 'Lua', 'Markdown', 'PHP', 'Python', 'Shell Session', 'Ruby'],
  8218. languageTab: '    ',
  8219. /**
  8220. * 表情配置菜单
  8221. * 如果为emoji表情直接作为元素插入
  8222. * emoticon:Array<EmotionsType>
  8223. */
  8224. emotions: [{
  8225. // tab 的标题
  8226. title: '表情',
  8227. // type -> 'emoji' / 'image'
  8228. type: 'emoji',
  8229. // content -> 数组
  8230. content: '😀 😃 😄 😁 😆 😅 😂 🤣 😊 😇 🙂 🙃 😉 😌 😍 😘 😗 😙 😚 😋 😛 😝 😜 🤓 😎 😏 😒 😞 😔 😟 😕 🙁 😣 😖 😫 😩 😢 😭 😤 😠 😡 😳 😱 😨 🤗 🤔 😶 😑 😬 🙄 😯 😴 😷 🤑 😈 🤡 💩 👻 💀 👀 👣'.split(/\s/)
  8231. }, {
  8232. // tab 的标题
  8233. title: '手势',
  8234. // type -> 'emoji' / 'image'
  8235. type: 'emoji',
  8236. // content -> 数组
  8237. content: '👐 🙌 👏 🤝 👍 👎 👊 ✊ 🤛 🤜 🤞 ✌️ 🤘 👌 👈 👉 👆 👇 ☝️ ✋ 🤚 🖐 🖖 👋 🤙 💪 🖕 ✍️ 🙏'.split(/\s/)
  8238. }],
  8239. lineHeights: ['1', '1.15', '1.6', '2', '2.5', '3'],
  8240. undoLimit: 20,
  8241. indentation: '2em',
  8242. showMenuTooltips: true,
  8243. // 菜单栏tooltip为上标还是下标
  8244. menuTooltipPosition: 'up'
  8245. };
  8246. /***/ }),
  8247. /* 288 */
  8248. /***/ (function(module, exports, __webpack_require__) {
  8249. "use strict";
  8250. /**
  8251. * @description 事件配置
  8252. * @author wangfupeng
  8253. */
  8254. var _interopRequireDefault = __webpack_require__(0);
  8255. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8256. (0, _defineProperty["default"])(exports, "__esModule", {
  8257. value: true
  8258. });
  8259. var const_1 = __webpack_require__(7);
  8260. /**
  8261. * 提示信息
  8262. * @param alertInfo alert info
  8263. * @param alertType 错误提示类型
  8264. * @param debugInfo debug info
  8265. */
  8266. function customAlert(alertInfo, alertType, debugInfo) {
  8267. window.alert(alertInfo);
  8268. if (debugInfo) {
  8269. console.error('wangEditor: ' + debugInfo);
  8270. }
  8271. }
  8272. exports["default"] = {
  8273. onchangeTimeout: 200,
  8274. onchange: null,
  8275. onfocus: const_1.EMPTY_FN,
  8276. onblur: const_1.EMPTY_FN,
  8277. onCatalogChange: null,
  8278. customAlert: customAlert
  8279. };
  8280. /***/ }),
  8281. /* 289 */
  8282. /***/ (function(module, exports, __webpack_require__) {
  8283. "use strict";
  8284. /**
  8285. * @description 粘贴,配置文件
  8286. * @author wangfupeng
  8287. */
  8288. var _interopRequireDefault = __webpack_require__(0);
  8289. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8290. (0, _defineProperty["default"])(exports, "__esModule", {
  8291. value: true
  8292. });
  8293. exports["default"] = {
  8294. // 粘贴过滤样式,默认开启
  8295. pasteFilterStyle: true,
  8296. // 粘贴内容时,忽略图片。默认关闭
  8297. pasteIgnoreImg: false,
  8298. // 对粘贴的文字进行自定义处理,返回处理后的结果。编辑器会将处理后的结果粘贴到编辑区域中。
  8299. // IE 暂时不支持
  8300. pasteTextHandle: function pasteTextHandle(content) {
  8301. // content 即粘贴过来的内容(html 或 纯文本),可进行自定义处理然后返回
  8302. return content;
  8303. }
  8304. };
  8305. /***/ }),
  8306. /* 290 */
  8307. /***/ (function(module, exports, __webpack_require__) {
  8308. "use strict";
  8309. /**
  8310. * @description 命令配置项
  8311. * @author wangfupeng
  8312. */
  8313. var _interopRequireDefault = __webpack_require__(0);
  8314. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8315. (0, _defineProperty["default"])(exports, "__esModule", {
  8316. value: true
  8317. });
  8318. exports["default"] = {
  8319. styleWithCSS: false // 默认 false
  8320. };
  8321. /***/ }),
  8322. /* 291 */
  8323. /***/ (function(module, exports, __webpack_require__) {
  8324. "use strict";
  8325. /**
  8326. * @description 图片相关的配置
  8327. * @author wangfupeng
  8328. */
  8329. var _interopRequireDefault = __webpack_require__(0);
  8330. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8331. (0, _defineProperty["default"])(exports, "__esModule", {
  8332. value: true
  8333. });
  8334. var const_1 = __webpack_require__(7);
  8335. exports["default"] = {
  8336. // 网络图片校验的配置函数
  8337. linkImgCheck: function linkImgCheck(src, alt, href) {
  8338. return true;
  8339. },
  8340. // 显示“插入网络图片”
  8341. showLinkImg: true,
  8342. // 显示“插入图片alt”
  8343. showLinkImgAlt: true,
  8344. // 显示“插入图片href”
  8345. showLinkImgHref: true,
  8346. // 插入图片成功之后的回调函数
  8347. linkImgCallback: const_1.EMPTY_FN,
  8348. // accept
  8349. uploadImgAccept: ['jpg', 'jpeg', 'png', 'gif', 'bmp'],
  8350. // 服务端地址
  8351. uploadImgServer: '',
  8352. // 使用 base64 存储图片
  8353. uploadImgShowBase64: false,
  8354. // 上传图片的最大体积,默认 5M
  8355. uploadImgMaxSize: 5 * 1024 * 1024,
  8356. // 一次最多上传多少个图片
  8357. uploadImgMaxLength: 100,
  8358. // 自定义上传图片的名称
  8359. uploadFileName: '',
  8360. // 上传图片自定义参数
  8361. uploadImgParams: {},
  8362. // 自定义参数拼接到 url 中
  8363. uploadImgParamsWithUrl: false,
  8364. // 上传图片自定义 header
  8365. uploadImgHeaders: {},
  8366. // 钩子函数
  8367. uploadImgHooks: {},
  8368. // 上传图片超时时间 ms
  8369. uploadImgTimeout: 10 * 1000,
  8370. // 跨域带 cookie
  8371. withCredentials: false,
  8372. // 自定义上传
  8373. customUploadImg: null,
  8374. // 从媒体库上传
  8375. uploadImgFromMedia: null
  8376. };
  8377. /***/ }),
  8378. /* 292 */
  8379. /***/ (function(module, exports, __webpack_require__) {
  8380. "use strict";
  8381. var _interopRequireDefault = __webpack_require__(0);
  8382. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8383. (0, _defineProperty["default"])(exports, "__esModule", {
  8384. value: true
  8385. });
  8386. exports["default"] = {
  8387. lang: 'zh-CN',
  8388. languages: {
  8389. 'zh-CN': {
  8390. wangEditor: {
  8391. 重置: '重置',
  8392. 插入: '插入',
  8393. 默认: '默认',
  8394. 创建: '创建',
  8395. 修改: '修改',
  8396. 如: '如',
  8397. 请输入正文: '请输入正文',
  8398. menus: {
  8399. title: {
  8400. 标题: '标题',
  8401. 加粗: '加粗',
  8402. 字号: '字号',
  8403. 字体: '字体',
  8404. 斜体: '斜体',
  8405. 下划线: '下划线',
  8406. 删除线: '删除线',
  8407. 缩进: '缩进',
  8408. 行高: '行高',
  8409. 文字颜色: '文字颜色',
  8410. 背景色: '背景色',
  8411. 链接: '链接',
  8412. 序列: '序列',
  8413. 对齐: '对齐',
  8414. 引用: '引用',
  8415. 表情: '表情',
  8416. 图片: '图片',
  8417. 视频: '视频',
  8418. 表格: '表格',
  8419. 代码: '代码',
  8420. 分割线: '分割线',
  8421. 恢复: '恢复',
  8422. 撤销: '撤销',
  8423. 全屏: '全屏',
  8424. 取消全屏: '取消全屏',
  8425. 待办事项: '待办事项'
  8426. },
  8427. dropListMenu: {
  8428. 设置标题: '设置标题',
  8429. 背景颜色: '背景颜色',
  8430. 文字颜色: '文字颜色',
  8431. 设置字号: '设置字号',
  8432. 设置字体: '设置字体',
  8433. 设置缩进: '设置缩进',
  8434. 对齐方式: '对齐方式',
  8435. 设置行高: '设置行高',
  8436. 序列: '序列',
  8437. head: {
  8438. 正文: '正文'
  8439. },
  8440. indent: {
  8441. 增加缩进: '增加缩进',
  8442. 减少缩进: '减少缩进'
  8443. },
  8444. justify: {
  8445. 靠左: '靠左',
  8446. 居中: '居中',
  8447. 靠右: '靠右',
  8448. 两端: '两端'
  8449. },
  8450. list: {
  8451. 无序列表: '无序列表',
  8452. 有序列表: '有序列表'
  8453. }
  8454. },
  8455. panelMenus: {
  8456. emoticon: {
  8457. 默认: '默认',
  8458. 新浪: '新浪',
  8459. emoji: 'emoji',
  8460. 手势: '手势'
  8461. },
  8462. image: {
  8463. 上传图片: '上传图片',
  8464. 网络图片: '网络图片',
  8465. 图片地址: '图片地址',
  8466. 图片文字说明: '图片文字说明',
  8467. 跳转链接: '跳转链接'
  8468. },
  8469. link: {
  8470. 链接: '链接',
  8471. 链接文字: '链接文字',
  8472. 取消链接: '取消链接',
  8473. 查看链接: '查看链接'
  8474. },
  8475. video: {
  8476. 插入视频: '插入视频',
  8477. 上传视频: '上传视频'
  8478. },
  8479. table: {
  8480. 行: '行',
  8481. 列: '列',
  8482. 的: '的',
  8483. 表格: '表格',
  8484. 添加行: '添加行',
  8485. 删除行: '删除行',
  8486. 添加列: '添加列',
  8487. 删除列: '删除列',
  8488. 设置表头: '设置表头',
  8489. 取消表头: '取消表头',
  8490. 插入表格: '插入表格',
  8491. 删除表格: '删除表格'
  8492. },
  8493. code: {
  8494. 删除代码: '删除代码',
  8495. 修改代码: '修改代码',
  8496. 插入代码: '插入代码'
  8497. }
  8498. }
  8499. },
  8500. validate: {
  8501. 张图片: '张图片',
  8502. 大于: '大于',
  8503. 图片链接: '图片链接',
  8504. 不是图片: '不是图片',
  8505. 返回结果: '返回结果',
  8506. 上传图片超时: '上传图片超时',
  8507. 上传图片错误: '上传图片错误',
  8508. 上传图片失败: '上传图片失败',
  8509. 插入图片错误: '插入图片错误',
  8510. 一次最多上传: '一次最多上传',
  8511. 下载链接失败: '下载链接失败',
  8512. 图片验证未通过: '图片验证未通过',
  8513. 服务器返回状态: '服务器返回状态',
  8514. 上传图片返回结果错误: '上传图片返回结果错误',
  8515. 请替换为支持的图片类型: '请替换为支持的图片类型',
  8516. 您插入的网络图片无法识别: '您插入的网络图片无法识别',
  8517. 您刚才插入的图片链接未通过编辑器校验: '您刚才插入的图片链接未通过编辑器校验',
  8518. 插入视频错误: '插入视频错误',
  8519. 视频链接: '视频链接',
  8520. 不是视频: '不是视频',
  8521. 视频验证未通过: '视频验证未通过',
  8522. 个视频: '个视频',
  8523. 上传视频超时: '上传视频超时',
  8524. 上传视频错误: '上传视频错误',
  8525. 上传视频失败: '上传视频失败',
  8526. 上传视频返回结果错误: '上传视频返回结果错误'
  8527. }
  8528. }
  8529. },
  8530. en: {
  8531. wangEditor: {
  8532. 重置: 'reset',
  8533. 插入: 'insert',
  8534. 默认: 'default',
  8535. 创建: 'create',
  8536. 修改: 'edit',
  8537. 如: 'like',
  8538. 请输入正文: 'please enter the text',
  8539. menus: {
  8540. title: {
  8541. 标题: 'head',
  8542. 加粗: 'bold',
  8543. 字号: 'font size',
  8544. 字体: 'font family',
  8545. 斜体: 'italic',
  8546. 下划线: 'underline',
  8547. 删除线: 'strikethrough',
  8548. 缩进: 'indent',
  8549. 行高: 'line heihgt',
  8550. 文字颜色: 'font color',
  8551. 背景色: 'background',
  8552. 链接: 'link',
  8553. 序列: 'numbered list',
  8554. 对齐: 'align',
  8555. 引用: 'quote',
  8556. 表情: 'emoticons',
  8557. 图片: 'image',
  8558. 视频: 'media',
  8559. 表格: 'table',
  8560. 代码: 'code',
  8561. 分割线: 'split line',
  8562. 恢复: 'undo',
  8563. 撤销: 'redo',
  8564. 全屏: 'fullscreen',
  8565. 取消全屏: 'cancel fullscreen',
  8566. 待办事项: 'todo'
  8567. },
  8568. dropListMenu: {
  8569. 设置标题: 'title',
  8570. 背景颜色: 'background',
  8571. 文字颜色: 'font color',
  8572. 设置字号: 'font size',
  8573. 设置字体: 'font family',
  8574. 设置缩进: 'indent',
  8575. 对齐方式: 'align',
  8576. 设置行高: 'line heihgt',
  8577. 序列: 'list',
  8578. head: {
  8579. 正文: 'text'
  8580. },
  8581. indent: {
  8582. 增加缩进: 'indent',
  8583. 减少缩进: 'outdent'
  8584. },
  8585. justify: {
  8586. 靠左: 'left',
  8587. 居中: 'center',
  8588. 靠右: 'right',
  8589. 两端: 'justify'
  8590. },
  8591. list: {
  8592. 无序列表: 'unordered',
  8593. 有序列表: 'ordered'
  8594. }
  8595. },
  8596. panelMenus: {
  8597. emoticon: {
  8598. 表情: 'emoji',
  8599. 手势: 'gesture'
  8600. },
  8601. image: {
  8602. 上传图片: 'upload image',
  8603. 网络图片: 'network image',
  8604. 图片地址: 'image link',
  8605. 图片文字说明: 'image alt',
  8606. 跳转链接: 'hyperlink'
  8607. },
  8608. link: {
  8609. 链接: 'link',
  8610. 链接文字: 'link text',
  8611. 取消链接: 'unlink',
  8612. 查看链接: 'view links'
  8613. },
  8614. video: {
  8615. 插入视频: 'insert video',
  8616. 上传视频: 'upload local video'
  8617. },
  8618. table: {
  8619. 行: 'rows',
  8620. 列: 'columns',
  8621. 的: ' ',
  8622. 表格: 'table',
  8623. 添加行: 'insert row',
  8624. 删除行: 'delete row',
  8625. 添加列: 'insert column',
  8626. 删除列: 'delete column',
  8627. 设置表头: 'set header',
  8628. 取消表头: 'cancel header',
  8629. 插入表格: 'insert table',
  8630. 删除表格: 'delete table'
  8631. },
  8632. code: {
  8633. 删除代码: 'delete code',
  8634. 修改代码: 'edit code',
  8635. 插入代码: 'insert code'
  8636. }
  8637. }
  8638. },
  8639. validate: {
  8640. 张图片: 'images',
  8641. 大于: 'greater than',
  8642. 图片链接: 'image link',
  8643. 不是图片: 'is not image',
  8644. 返回结果: 'return results',
  8645. 上传图片超时: 'upload image timeout',
  8646. 上传图片错误: 'upload image error',
  8647. 上传图片失败: 'upload image failed',
  8648. 插入图片错误: 'insert image error',
  8649. 一次最多上传: 'once most at upload',
  8650. 下载链接失败: 'download link failed',
  8651. 图片验证未通过: 'image validate failed',
  8652. 服务器返回状态: 'server return status',
  8653. 上传图片返回结果错误: 'upload image return results error',
  8654. 请替换为支持的图片类型: 'please replace with a supported image type',
  8655. 您插入的网络图片无法识别: 'the network picture you inserted is not recognized',
  8656. 您刚才插入的图片链接未通过编辑器校验: 'the image link you just inserted did not pass the editor verification',
  8657. 插入视频错误: 'insert video error',
  8658. 视频链接: 'video link',
  8659. 不是视频: 'is not video',
  8660. 视频验证未通过: 'video validate failed',
  8661. 个视频: 'videos',
  8662. 上传视频超时: 'upload video timeout',
  8663. 上传视频错误: 'upload video error',
  8664. 上传视频失败: 'upload video failed',
  8665. 上传视频返回结果错误: 'upload video return results error'
  8666. }
  8667. }
  8668. }
  8669. }
  8670. };
  8671. /***/ }),
  8672. /* 293 */
  8673. /***/ (function(module, exports, __webpack_require__) {
  8674. "use strict";
  8675. /**
  8676. * @description 历史记录 - 数据缓存的模式
  8677. * @author fangzhicong
  8678. */
  8679. var _interopRequireDefault = __webpack_require__(0);
  8680. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8681. (0, _defineProperty["default"])(exports, "__esModule", {
  8682. value: true
  8683. });
  8684. var util_1 = __webpack_require__(6);
  8685. /**
  8686. * 是否为兼容模式。返回 true 表示当前使用兼容(内容备份)模式,否则使用标准(差异备份)模式
  8687. */
  8688. function compatibleMode() {
  8689. if (util_1.UA.isIE() || util_1.UA.isOldEdge) {
  8690. return true;
  8691. }
  8692. return false;
  8693. }
  8694. exports["default"] = {
  8695. compatibleMode: compatibleMode,
  8696. historyMaxSize: 30
  8697. };
  8698. /***/ }),
  8699. /* 294 */
  8700. /***/ (function(module, exports, __webpack_require__) {
  8701. "use strict";
  8702. /**
  8703. * @description 视频相关的配置
  8704. * @author hutianhao
  8705. */
  8706. var _interopRequireDefault = __webpack_require__(0);
  8707. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8708. (0, _defineProperty["default"])(exports, "__esModule", {
  8709. value: true
  8710. });
  8711. var const_1 = __webpack_require__(7);
  8712. exports["default"] = {
  8713. // 插入网络视频前的回调函数
  8714. onlineVideoCheck: function onlineVideoCheck(video) {
  8715. return true;
  8716. },
  8717. // 插入网络视频成功之后的回调函数
  8718. onlineVideoCallback: const_1.EMPTY_FN,
  8719. // 显示“插入视频”
  8720. showLinkVideo: true,
  8721. // accept
  8722. uploadVideoAccept: ['mp4'],
  8723. // 服务端地址
  8724. uploadVideoServer: '',
  8725. // 上传视频的最大体积,默认 1024M
  8726. uploadVideoMaxSize: 1 * 1024 * 1024 * 1024,
  8727. // 一次最多上传多少个视频
  8728. // uploadVideoMaxLength: 2,
  8729. // 自定义上传视频的名称
  8730. uploadVideoName: '',
  8731. // 上传视频自定义参数
  8732. uploadVideoParams: {},
  8733. // 自定义参数拼接到 url 中
  8734. uploadVideoParamsWithUrl: false,
  8735. // 上传视频自定义 header
  8736. uploadVideoHeaders: {},
  8737. // 钩子函数
  8738. uploadVideoHooks: {},
  8739. // 上传视频超时时间 ms 默认2个小时
  8740. uploadVideoTimeout: 1000 * 60 * 60 * 2,
  8741. // 跨域带 cookie
  8742. withVideoCredentials: false,
  8743. // 自定义上传
  8744. customUploadVideo: null,
  8745. // 自定义插入视频
  8746. customInsertVideo: null
  8747. };
  8748. /***/ }),
  8749. /* 295 */
  8750. /***/ (function(module, exports, __webpack_require__) {
  8751. "use strict";
  8752. var _interopRequireDefault = __webpack_require__(0);
  8753. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  8754. var _trim = _interopRequireDefault(__webpack_require__(16));
  8755. (0, _defineProperty["default"])(exports, "__esModule", {
  8756. value: true
  8757. });
  8758. var tslib_1 = __webpack_require__(2);
  8759. /**
  8760. * @description selection range API
  8761. * @author wangfupeng
  8762. */
  8763. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  8764. var util_1 = __webpack_require__(6);
  8765. var const_1 = __webpack_require__(7);
  8766. var SelectionAndRange = function () {
  8767. function SelectionAndRange(editor) {
  8768. this._currentRange = null;
  8769. this.editor = editor;
  8770. }
  8771. /**
  8772. * 获取当前 range
  8773. */
  8774. SelectionAndRange.prototype.getRange = function () {
  8775. return this._currentRange;
  8776. };
  8777. /**
  8778. * 保存选区范围
  8779. * @param _range 选区范围
  8780. */
  8781. SelectionAndRange.prototype.saveRange = function (_range) {
  8782. if (_range) {
  8783. // 保存已有选区
  8784. this._currentRange = _range;
  8785. return;
  8786. } // 获取当前的选区
  8787. var selection = window.getSelection();
  8788. if (selection.rangeCount === 0) {
  8789. return;
  8790. }
  8791. var range = selection.getRangeAt(0); // 获取选区范围的 DOM 元素
  8792. var $containerElem = this.getSelectionContainerElem(range);
  8793. if (!($containerElem === null || $containerElem === void 0 ? void 0 : $containerElem.length)) {
  8794. // 当 选区范围内没有 DOM元素 则抛出
  8795. return;
  8796. }
  8797. if ($containerElem.attr('contenteditable') === 'false' || $containerElem.parentUntil('[contenteditable=false]')) {
  8798. // 这里大体意义上就是个保险
  8799. // 确保 编辑区域 的 contenteditable属性 的值为 true
  8800. return;
  8801. }
  8802. var editor = this.editor;
  8803. var $textElem = editor.$textElem;
  8804. if ($textElem.isContain($containerElem)) {
  8805. if ($textElem.elems[0] === $containerElem.elems[0]) {
  8806. var _context;
  8807. if ((0, _trim["default"])(_context = $textElem.html()).call(_context) === const_1.EMPTY_P) {
  8808. var $children = $textElem.children();
  8809. var $last = $children === null || $children === void 0 ? void 0 : $children.last();
  8810. editor.selection.createRangeByElem($last, true, true);
  8811. editor.selection.restoreSelection();
  8812. }
  8813. } // 是编辑内容之内的
  8814. this._currentRange = range;
  8815. }
  8816. };
  8817. /**
  8818. * 折叠选区范围
  8819. * @param toStart true 开始位置,false 结束位置
  8820. */
  8821. SelectionAndRange.prototype.collapseRange = function (toStart) {
  8822. if (toStart === void 0) {
  8823. toStart = false;
  8824. }
  8825. var range = this._currentRange;
  8826. if (range) {
  8827. range.collapse(toStart);
  8828. }
  8829. };
  8830. /**
  8831. * 获取选区范围内的文字
  8832. */
  8833. SelectionAndRange.prototype.getSelectionText = function () {
  8834. var range = this._currentRange;
  8835. if (range) {
  8836. return range.toString();
  8837. } else {
  8838. return '';
  8839. }
  8840. };
  8841. /**
  8842. * 获取选区范围的 DOM 元素
  8843. * @param range 选区范围
  8844. */
  8845. SelectionAndRange.prototype.getSelectionContainerElem = function (range) {
  8846. var r;
  8847. r = range || this._currentRange;
  8848. var elem;
  8849. if (r) {
  8850. elem = r.commonAncestorContainer;
  8851. return dom_core_1["default"](elem.nodeType === 1 ? elem : elem.parentNode);
  8852. }
  8853. };
  8854. /**
  8855. * 选区范围开始的 DOM 元素
  8856. * @param range 选区范围
  8857. */
  8858. SelectionAndRange.prototype.getSelectionStartElem = function (range) {
  8859. var r;
  8860. r = range || this._currentRange;
  8861. var elem;
  8862. if (r) {
  8863. elem = r.startContainer;
  8864. return dom_core_1["default"](elem.nodeType === 1 ? elem : elem.parentNode);
  8865. }
  8866. };
  8867. /**
  8868. * 选区范围结束的 DOM 元素
  8869. * @param range 选区范围
  8870. */
  8871. SelectionAndRange.prototype.getSelectionEndElem = function (range) {
  8872. var r;
  8873. r = range || this._currentRange;
  8874. var elem;
  8875. if (r) {
  8876. elem = r.endContainer;
  8877. return dom_core_1["default"](elem.nodeType === 1 ? elem : elem.parentNode);
  8878. }
  8879. };
  8880. /**
  8881. * 选区是否为空(没有选择文字)
  8882. */
  8883. SelectionAndRange.prototype.isSelectionEmpty = function () {
  8884. var range = this._currentRange;
  8885. if (range && range.startContainer) {
  8886. if (range.startContainer === range.endContainer) {
  8887. if (range.startOffset === range.endOffset) {
  8888. return true;
  8889. }
  8890. }
  8891. }
  8892. return false;
  8893. };
  8894. /**
  8895. * 恢复选区范围
  8896. */
  8897. SelectionAndRange.prototype.restoreSelection = function () {
  8898. var selection = window.getSelection();
  8899. var r = this._currentRange;
  8900. if (selection && r) {
  8901. selection.removeAllRanges();
  8902. selection.addRange(r);
  8903. }
  8904. };
  8905. /**
  8906. * 创建一个空白(即 &#8203 字符)选区
  8907. */
  8908. SelectionAndRange.prototype.createEmptyRange = function () {
  8909. var editor = this.editor;
  8910. var range = this.getRange();
  8911. var $elem;
  8912. if (!range) {
  8913. // 当前无 range
  8914. return;
  8915. }
  8916. if (!this.isSelectionEmpty()) {
  8917. // 当前选区必须没有内容才可以,有内容就直接 return
  8918. return;
  8919. }
  8920. try {
  8921. // 目前只支持 webkit 内核
  8922. if (util_1.UA.isWebkit()) {
  8923. // 插入 &#8203
  8924. editor.cmd["do"]('insertHTML', '&#8203;'); // 修改 offset 位置
  8925. range.setEnd(range.endContainer, range.endOffset + 1); // 存储
  8926. this.saveRange(range);
  8927. } else {
  8928. $elem = dom_core_1["default"]('<strong>&#8203;</strong>');
  8929. editor.cmd["do"]('insertElem', $elem);
  8930. this.createRangeByElem($elem, true);
  8931. }
  8932. } catch (ex) {// 部分情况下会报错,兼容一下
  8933. }
  8934. };
  8935. /**
  8936. * 重新设置选区
  8937. * @param startDom 选区开始的元素
  8938. * @param endDom 选区结束的元素
  8939. */
  8940. SelectionAndRange.prototype.createRangeByElems = function (startDom, endDom) {
  8941. var selection = window.getSelection ? window.getSelection() : document.getSelection(); //清除所有的选区
  8942. selection === null || selection === void 0 ? void 0 : selection.removeAllRanges();
  8943. var range = document.createRange();
  8944. range.setStart(startDom, 0); // 设置多行标签之后,第二个参数会被h标签内的b、font标签等影响range范围的选取
  8945. range.setEnd(endDom, endDom.childNodes.length || 1); // 保存设置好的选区
  8946. this.saveRange(range); //恢复选区
  8947. this.restoreSelection();
  8948. };
  8949. /**
  8950. * 根据 DOM 元素设置选区
  8951. * @param $elem DOM 元素
  8952. * @param toStart true 开始位置,false 结束位置
  8953. * @param isContent 是否选中 $elem 的内容
  8954. */
  8955. SelectionAndRange.prototype.createRangeByElem = function ($elem, toStart, isContent) {
  8956. if (!$elem.length) {
  8957. return;
  8958. }
  8959. var elem = $elem.elems[0];
  8960. var range = document.createRange();
  8961. if (isContent) {
  8962. range.selectNodeContents(elem);
  8963. } else {
  8964. // 如果用户没有传入 isContent 参数,那就默认为 false
  8965. range.selectNode(elem);
  8966. }
  8967. if (toStart != null) {
  8968. // 传入了 toStart 参数,折叠选区。如果没传入 toStart 参数,则忽略这一步
  8969. range.collapse(toStart);
  8970. if (!toStart) {
  8971. this.saveRange(range);
  8972. this.editor.selection.moveCursor(elem);
  8973. }
  8974. } // 存储 range
  8975. this.saveRange(range);
  8976. };
  8977. /**
  8978. * 获取 当前 选取范围的 顶级(段落) 元素
  8979. * @param $editor
  8980. */
  8981. SelectionAndRange.prototype.getSelectionRangeTopNodes = function () {
  8982. var _a, _b; // 清空,防止叠加元素
  8983. var $nodeList;
  8984. var $startElem = (_a = this.getSelectionStartElem()) === null || _a === void 0 ? void 0 : _a.getNodeTop(this.editor);
  8985. var $endElem = (_b = this.getSelectionEndElem()) === null || _b === void 0 ? void 0 : _b.getNodeTop(this.editor);
  8986. $nodeList = this.recordSelectionNodes(dom_core_1["default"]($startElem), dom_core_1["default"]($endElem));
  8987. return $nodeList;
  8988. };
  8989. /**
  8990. * 移动光标位置,默认情况下在尾部
  8991. * 有一个特殊情况是firefox下的文本节点会自动补充一个br元素,会导致自动换行
  8992. * 所以默认情况下在firefox下的文本节点会自动移动到br前面
  8993. * @param {Node} node 元素节点
  8994. * @param {number} position 光标的位置
  8995. */
  8996. SelectionAndRange.prototype.moveCursor = function (node, position) {
  8997. var _a;
  8998. var range = this.getRange(); //对文本节点特殊处理
  8999. var len = node.nodeType === 3 ? (_a = node.nodeValue) === null || _a === void 0 ? void 0 : _a.length : node.childNodes.length;
  9000. if ((util_1.UA.isFirefox || util_1.UA.isIE()) && len !== 0) {
  9001. // firefox下在节点为文本节点和节点最后一个元素为文本节点的情况下
  9002. if (node.nodeType === 3 || node.childNodes[len - 1].nodeName === 'BR') {
  9003. len = len - 1;
  9004. }
  9005. }
  9006. var pos = position !== null && position !== void 0 ? position : len;
  9007. if (!range) {
  9008. return;
  9009. }
  9010. if (node) {
  9011. range.setStart(node, pos);
  9012. range.setEnd(node, pos);
  9013. this.restoreSelection();
  9014. }
  9015. };
  9016. /**
  9017. * 获取光标在当前选区的位置
  9018. */
  9019. SelectionAndRange.prototype.getCursorPos = function () {
  9020. var selection = window.getSelection();
  9021. return selection === null || selection === void 0 ? void 0 : selection.anchorOffset;
  9022. };
  9023. /**
  9024. * 清除当前选区的Range,notice:不影响已保存的Range
  9025. */
  9026. SelectionAndRange.prototype.clearWindowSelectionRange = function () {
  9027. var selection = window.getSelection();
  9028. if (selection) {
  9029. selection.removeAllRanges();
  9030. }
  9031. };
  9032. /**
  9033. * 记录节点 - 从选区开始节点开始 一直到匹配到选区结束节点为止
  9034. * @param $node 节点
  9035. */
  9036. SelectionAndRange.prototype.recordSelectionNodes = function ($node, $endElem) {
  9037. var $list = [];
  9038. var isEnd = true;
  9039. /**
  9040. @author:lw
  9041. @description 解决ctrl+a全选报错的bug $elem.getNodeName()可能会触发$elem[0]未定义
  9042. **/
  9043. try {
  9044. var $NODE = $node;
  9045. var $textElem = this.editor.$textElem; // $NODE元素为空时不需要进行循环
  9046. while (isEnd) {
  9047. var $elem = $NODE === null || $NODE === void 0 ? void 0 : $NODE.getNodeTop(this.editor);
  9048. if ($elem.getNodeName() === 'BODY') isEnd = false; // 兜底
  9049. if ($elem.length > 0) {
  9050. $list.push(dom_core_1["default"]($NODE)); // 两个边界情况:
  9051. // 1. 当前元素就是我们要找的末尾元素
  9052. // 2. 当前元素已经是编辑区顶级元素(否则会找到编辑区的兄弟节点,比如placeholder元素)
  9053. if (($endElem === null || $endElem === void 0 ? void 0 : $endElem.equal($elem)) || $textElem.equal($elem)) {
  9054. isEnd = false;
  9055. } else {
  9056. $NODE = $elem.getNextSibling();
  9057. }
  9058. }
  9059. }
  9060. } catch (e) {
  9061. isEnd = false;
  9062. }
  9063. return $list;
  9064. };
  9065. /**
  9066. * 将当前 range 设置到 node 元素并初始化位置
  9067. * 解决编辑器内容为空时,菜单不生效的问题
  9068. * @param node 元素节点
  9069. */
  9070. SelectionAndRange.prototype.setRangeToElem = function (node) {
  9071. var range = this.getRange();
  9072. range === null || range === void 0 ? void 0 : range.setStart(node, 0);
  9073. range === null || range === void 0 ? void 0 : range.setEnd(node, 0);
  9074. };
  9075. return SelectionAndRange;
  9076. }();
  9077. exports["default"] = SelectionAndRange;
  9078. /***/ }),
  9079. /* 296 */
  9080. /***/ (function(module, exports, __webpack_require__) {
  9081. "use strict";
  9082. /**
  9083. * @description 封装 document.execCommand
  9084. * @author wangfupeng
  9085. */
  9086. var _interopRequireDefault = __webpack_require__(0);
  9087. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  9088. (0, _defineProperty["default"])(exports, "__esModule", {
  9089. value: true
  9090. });
  9091. var tslib_1 = __webpack_require__(2);
  9092. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  9093. var Command = function () {
  9094. function Command(editor) {
  9095. this.editor = editor;
  9096. }
  9097. /**
  9098. * 执行富文本操作的命令
  9099. * @param name name
  9100. * @param value value
  9101. */
  9102. Command.prototype["do"] = function (name, value) {
  9103. var editor = this.editor;
  9104. if (editor.config.styleWithCSS) {
  9105. document.execCommand('styleWithCSS', false, 'true');
  9106. }
  9107. var selection = editor.selection; // 如果无选区,忽略
  9108. if (!selection.getRange()) {
  9109. return;
  9110. } // 恢复选取
  9111. selection.restoreSelection(); // 执行
  9112. switch (name) {
  9113. case 'insertHTML':
  9114. this.insertHTML(value);
  9115. break;
  9116. case 'insertElem':
  9117. this.insertElem(value);
  9118. break;
  9119. default:
  9120. // 默认 command
  9121. this.execCommand(name, value);
  9122. break;
  9123. } // 修改菜单状态
  9124. editor.menus.changeActive(); // 最后,恢复选取保证光标在原来的位置闪烁
  9125. selection.saveRange();
  9126. selection.restoreSelection();
  9127. };
  9128. /**
  9129. * 插入 html
  9130. * @param html html 字符串
  9131. */
  9132. Command.prototype.insertHTML = function (html) {
  9133. var editor = this.editor;
  9134. var range = editor.selection.getRange();
  9135. if (range == null) return;
  9136. if (this.queryCommandSupported('insertHTML')) {
  9137. // W3C
  9138. this.execCommand('insertHTML', html);
  9139. } else if (range.insertNode) {
  9140. // IE
  9141. range.deleteContents();
  9142. if (dom_core_1["default"](html).elems.length > 0) {
  9143. range.insertNode(dom_core_1["default"](html).elems[0]);
  9144. } else {
  9145. var newNode = document.createElement('p');
  9146. newNode.appendChild(document.createTextNode(html));
  9147. range.insertNode(newNode);
  9148. }
  9149. editor.selection.collapseRange();
  9150. } // else if (range.pasteHTML) {
  9151. // // IE <= 10
  9152. // range.pasteHTML(html)
  9153. // }
  9154. };
  9155. /**
  9156. * 插入 DOM 元素
  9157. * @param $elem DOM 元素
  9158. */
  9159. Command.prototype.insertElem = function ($elem) {
  9160. var editor = this.editor;
  9161. var range = editor.selection.getRange();
  9162. if (range == null) return;
  9163. if (range.insertNode) {
  9164. range.deleteContents();
  9165. range.insertNode($elem.elems[0]);
  9166. }
  9167. };
  9168. /**
  9169. * 执行 document.execCommand
  9170. * @param name name
  9171. * @param value value
  9172. */
  9173. Command.prototype.execCommand = function (name, value) {
  9174. document.execCommand(name, false, value);
  9175. };
  9176. /**
  9177. * 执行 document.queryCommandValue
  9178. * @param name name
  9179. */
  9180. Command.prototype.queryCommandValue = function (name) {
  9181. return document.queryCommandValue(name);
  9182. };
  9183. /**
  9184. * 执行 document.queryCommandState
  9185. * @param name name
  9186. */
  9187. Command.prototype.queryCommandState = function (name) {
  9188. return document.queryCommandState(name);
  9189. };
  9190. /**
  9191. * 执行 document.queryCommandSupported
  9192. * @param name name
  9193. */
  9194. Command.prototype.queryCommandSupported = function (name) {
  9195. return document.queryCommandSupported(name);
  9196. };
  9197. return Command;
  9198. }();
  9199. exports["default"] = Command;
  9200. /***/ }),
  9201. /* 297 */
  9202. /***/ (function(module, exports, __webpack_require__) {
  9203. "use strict";
  9204. /**
  9205. * @description 编辑区域,入口文件
  9206. * @author wangfupeng
  9207. */
  9208. var _interopRequireDefault = __webpack_require__(0);
  9209. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  9210. var _find = _interopRequireDefault(__webpack_require__(32));
  9211. var _forEach = _interopRequireDefault(__webpack_require__(4));
  9212. var _trim = _interopRequireDefault(__webpack_require__(16));
  9213. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  9214. var _setTimeout2 = _interopRequireDefault(__webpack_require__(48));
  9215. (0, _defineProperty["default"])(exports, "__esModule", {
  9216. value: true
  9217. });
  9218. var tslib_1 = __webpack_require__(2);
  9219. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  9220. var index_1 = tslib_1.__importDefault(__webpack_require__(302));
  9221. var util_1 = __webpack_require__(6);
  9222. var getChildrenJSON_1 = tslib_1.__importDefault(__webpack_require__(314));
  9223. var getHtmlByNodeList_1 = tslib_1.__importDefault(__webpack_require__(315));
  9224. var const_1 = __webpack_require__(7);
  9225. var Text = function () {
  9226. function Text(editor) {
  9227. this.editor = editor;
  9228. this.eventHooks = {
  9229. onBlurEvents: [],
  9230. changeEvents: [],
  9231. dropEvents: [],
  9232. clickEvents: [],
  9233. keydownEvents: [],
  9234. keyupEvents: [],
  9235. tabUpEvents: [],
  9236. tabDownEvents: [],
  9237. enterUpEvents: [],
  9238. enterDownEvents: [],
  9239. deleteUpEvents: [],
  9240. deleteDownEvents: [],
  9241. pasteEvents: [],
  9242. linkClickEvents: [],
  9243. codeClickEvents: [],
  9244. textScrollEvents: [],
  9245. toolbarClickEvents: [],
  9246. imgClickEvents: [],
  9247. imgDragBarMouseDownEvents: [],
  9248. tableClickEvents: [],
  9249. menuClickEvents: [],
  9250. dropListMenuHoverEvents: [],
  9251. splitLineEvents: [],
  9252. videoClickEvents: []
  9253. };
  9254. }
  9255. /**
  9256. * 初始化
  9257. */
  9258. Text.prototype.init = function () {
  9259. // 实时保存选取范围
  9260. this._saveRange(); // 绑定事件
  9261. this._bindEventHooks(); // 初始化 text 事件钩子函数
  9262. index_1["default"](this);
  9263. };
  9264. /**
  9265. * 切换placeholder
  9266. */
  9267. Text.prototype.togglePlaceholder = function () {
  9268. var _context;
  9269. var html = this.html();
  9270. var $placeholder = (0, _find["default"])(_context = this.editor.$textContainerElem).call(_context, '.placeholder');
  9271. $placeholder.hide();
  9272. if (this.editor.isComposing) return;
  9273. if (!html || html === ' ') $placeholder.show();
  9274. };
  9275. /**
  9276. * 清空内容
  9277. */
  9278. Text.prototype.clear = function () {
  9279. this.html(const_1.EMPTY_P);
  9280. };
  9281. /**
  9282. * 设置/获取 html
  9283. * @param val html 字符串
  9284. */
  9285. Text.prototype.html = function (val) {
  9286. var editor = this.editor;
  9287. var $textElem = editor.$textElem; // 没有 val ,则是获取 html
  9288. if (val == null) {
  9289. var html_1 = $textElem.html(); // 未选中任何内容的时候点击“加粗”或者“斜体”等按钮,就得需要一个空的占位符 &#8203 ,这里替换掉
  9290. html_1 = html_1.replace(/\u200b/gm, ''); // 去掉空行
  9291. html_1 = html_1.replace(/<p><\/p>/gim, ''); // 去掉最后的 空标签
  9292. html_1 = html_1.replace(const_1.EMPTY_P_LAST_REGEX, ''); // 为了避免用户在最后生成的EMPTY_P标签中编辑数据, 最后产生多余标签, 去除所有p标签上的data-we-empty-p属性
  9293. html_1 = html_1.replace(const_1.EMPTY_P_REGEX, '<p>');
  9294. /**
  9295. * 这里的代码为了处理火狐多余的空行标签,但是强制删除空行标签会带来其他问题
  9296. * html()方法返回的的值,EMPTY_P中pr会被删除,只留下<p>,点不进去,从而产生垃圾数据
  9297. * 目前在末位有多个空行的情况下执行撤销重做操作,会产生一种不记录末尾空行的错觉
  9298. * 暂时注释, 等待进一步的兼容处理
  9299. */
  9300. // html = html.replace(/><br>(?!<)/gi, '>') // 过滤 <p><br>内容</p> 中的br
  9301. // html = html.replace(/(?!>)<br></gi, '<') // 过滤 <p>内容<br></p> 中的br
  9302. /**
  9303. * pre标签格式化
  9304. * html()方法理论上应当输出纯净的代码文本,但是对于是否解析html标签还没有良好的判断
  9305. * 如果去除hljs的标签,在解析状态下回显,会造成显示错误并且无法再通过hljs方法渲染
  9306. * 暂且其弃用
  9307. */
  9308. // html = formatCodeHtml(editor, html)
  9309. // 将没有自闭和的标签过滤为自闭和
  9310. var selfCloseHtmls = html_1.match(/<(img|br|hr|input)[^>]*>/gi);
  9311. if (selfCloseHtmls !== null) {
  9312. (0, _forEach["default"])(selfCloseHtmls).call(selfCloseHtmls, function (item) {
  9313. if (!item.match(/\/>/)) {
  9314. html_1 = html_1.replace(item, item.substring(0, item.length - 1) + '/>');
  9315. }
  9316. });
  9317. }
  9318. return html_1;
  9319. } // 有 val ,则是设置 html
  9320. val = (0, _trim["default"])(val).call(val);
  9321. if (val === '') {
  9322. val = const_1.EMPTY_P;
  9323. }
  9324. if ((0, _indexOf["default"])(val).call(val, '<') !== 0) {
  9325. // 内容用 p 标签包裹
  9326. val = "<p>" + val + "</p>";
  9327. }
  9328. $textElem.html(val); // 初始化选区,将光标定位到内容尾部
  9329. editor.initSelection();
  9330. };
  9331. /**
  9332. * 将json设置成html至编辑器
  9333. * @param nodeList json格式
  9334. */
  9335. Text.prototype.setJSON = function (nodeList) {
  9336. var html = getHtmlByNodeList_1["default"](nodeList).children();
  9337. var editor = this.editor;
  9338. var $textElem = editor.$textElem; // 没有获取到元素的情况
  9339. if (!html) return; // 替换文本节点下全部子节点
  9340. $textElem.replaceChildAll(html);
  9341. };
  9342. /**
  9343. * 获取 json 格式的数据
  9344. */
  9345. Text.prototype.getJSON = function () {
  9346. var editor = this.editor;
  9347. var $textElem = editor.$textElem;
  9348. return getChildrenJSON_1["default"]($textElem);
  9349. };
  9350. Text.prototype.text = function (val) {
  9351. var editor = this.editor;
  9352. var $textElem = editor.$textElem; // 没有 val ,是获取 text
  9353. if (val == null) {
  9354. var text = $textElem.text(); // 未选中任何内容的时候点击“加粗”或者“斜体”等按钮,就得需要一个空的占位符 &#8203 ,这里替换掉
  9355. text = text.replace(/\u200b/gm, '');
  9356. return text;
  9357. } // 有 val ,则是设置 text
  9358. $textElem.text("<p>" + val + "</p>"); // 初始化选区,将光标定位到内容尾部
  9359. editor.initSelection();
  9360. };
  9361. /**
  9362. * 追加 html 内容
  9363. * @param html html 字符串
  9364. */
  9365. Text.prototype.append = function (html) {
  9366. var editor = this.editor;
  9367. if ((0, _indexOf["default"])(html).call(html, '<') !== 0) {
  9368. // 普通字符串,用 <p> 包裹
  9369. html = "<p>" + html + "</p>";
  9370. }
  9371. this.html(this.html() + html); // 初始化选区,将光标定位到内容尾部
  9372. editor.initSelection();
  9373. };
  9374. /**
  9375. * 每一步操作,都实时保存选区范围
  9376. */
  9377. Text.prototype._saveRange = function () {
  9378. var editor = this.editor;
  9379. var $textElem = editor.$textElem;
  9380. var $document = dom_core_1["default"](document); // 保存当前的选区
  9381. function saveRange() {
  9382. // 随时保存选区
  9383. editor.selection.saveRange(); // 更新按钮 active 状态
  9384. editor.menus.changeActive();
  9385. } // 按键后保存
  9386. $textElem.on('keyup', saveRange); // 点击后保存,为了避免被多次执行而导致造成浪费,这里对 click 使用一次性绑定
  9387. function onceClickSaveRange() {
  9388. saveRange();
  9389. $textElem.off('click', onceClickSaveRange);
  9390. }
  9391. $textElem.on('click', onceClickSaveRange);
  9392. function handleMouseUp() {
  9393. // 在编辑器区域之外完成抬起,保存此时编辑区内的新选区,取消此时鼠标抬起事件
  9394. saveRange();
  9395. $document.off('mouseup', handleMouseUp);
  9396. }
  9397. function listenMouseLeave() {
  9398. // 当鼠标移动到外面,要监听鼠标抬起操作
  9399. $document.on('mouseup', handleMouseUp); // 首次移出时即接触leave监听,防止用户不断移入移出多次注册handleMouseUp
  9400. $textElem.off('mouseleave', listenMouseLeave);
  9401. }
  9402. $textElem.on('mousedown', function () {
  9403. // mousedown 状态下,要坚听鼠标滑动到编辑区域外面
  9404. $textElem.on('mouseleave', listenMouseLeave);
  9405. });
  9406. $textElem.on('mouseup', function (e) {
  9407. // 记得移除$textElem的mouseleave事件, 避免内存泄露
  9408. $textElem.off('mouseleave', listenMouseLeave); // fix:避免当选中一段文字之后,再次点击文字中间位置无法更新selection问题。issue#3096
  9409. (0, _setTimeout2["default"])(function () {
  9410. var selection = editor.selection;
  9411. var range = selection.getRange();
  9412. if (range === null) return;
  9413. saveRange();
  9414. }, 0);
  9415. });
  9416. };
  9417. /**
  9418. * 绑定事件,事件会触发钩子函数
  9419. */
  9420. Text.prototype._bindEventHooks = function () {
  9421. var editor = this.editor;
  9422. var $textElem = editor.$textElem;
  9423. var eventHooks = this.eventHooks; // click hooks
  9424. $textElem.on('click', function (e) {
  9425. var clickEvents = eventHooks.clickEvents;
  9426. (0, _forEach["default"])(clickEvents).call(clickEvents, function (fn) {
  9427. return fn(e);
  9428. });
  9429. }); // enter 键 up 时的 hooks
  9430. $textElem.on('keyup', function (e) {
  9431. if (e.keyCode !== 13) return;
  9432. var enterUpEvents = eventHooks.enterUpEvents;
  9433. (0, _forEach["default"])(enterUpEvents).call(enterUpEvents, function (fn) {
  9434. return fn(e);
  9435. });
  9436. }); // 键盘 up 时的 hooks
  9437. $textElem.on('keyup', function (e) {
  9438. var keyupEvents = eventHooks.keyupEvents;
  9439. (0, _forEach["default"])(keyupEvents).call(keyupEvents, function (fn) {
  9440. return fn(e);
  9441. });
  9442. }); // 键盘 down 时的 hooks
  9443. $textElem.on('keydown', function (e) {
  9444. var keydownEvents = eventHooks.keydownEvents;
  9445. (0, _forEach["default"])(keydownEvents).call(keydownEvents, function (fn) {
  9446. return fn(e);
  9447. });
  9448. }); // delete 键 up 时 hooks
  9449. $textElem.on('keyup', function (e) {
  9450. if (e.keyCode !== 8 && e.keyCode !== 46) return;
  9451. var deleteUpEvents = eventHooks.deleteUpEvents;
  9452. (0, _forEach["default"])(deleteUpEvents).call(deleteUpEvents, function (fn) {
  9453. return fn(e);
  9454. });
  9455. }); // delete 键 down 时 hooks
  9456. $textElem.on('keydown', function (e) {
  9457. if (e.keyCode !== 8 && e.keyCode !== 46) return;
  9458. var deleteDownEvents = eventHooks.deleteDownEvents;
  9459. (0, _forEach["default"])(deleteDownEvents).call(deleteDownEvents, function (fn) {
  9460. return fn(e);
  9461. });
  9462. }); // 粘贴
  9463. $textElem.on('paste', function (e) {
  9464. if (util_1.UA.isIE()) return; // IE 不支持
  9465. // 阻止默认行为,使用 execCommand 的粘贴命令
  9466. e.preventDefault();
  9467. var pasteEvents = eventHooks.pasteEvents;
  9468. (0, _forEach["default"])(pasteEvents).call(pasteEvents, function (fn) {
  9469. return fn(e);
  9470. });
  9471. }); // 撤销/恢复 快捷键
  9472. $textElem.on('keydown', function (e) {
  9473. if ( // 编辑器处于聚焦状态下(多编辑器实例) || 当前处于兼容模式(兼容模式撤销/恢复后不聚焦,所以直接过,但会造成多编辑器同时撤销/恢复)
  9474. (editor.isFocus || editor.isCompatibleMode) && (e.ctrlKey || e.metaKey) && e.keyCode === 90) {
  9475. // 取消默认行为
  9476. e.preventDefault(); // 执行事件
  9477. if (e.shiftKey) {
  9478. // 恢复
  9479. editor.history.restore();
  9480. } else {
  9481. // 撤销
  9482. editor.history.revoke();
  9483. }
  9484. }
  9485. }); // tab up
  9486. $textElem.on('keyup', function (e) {
  9487. if (e.keyCode !== 9) return;
  9488. e.preventDefault();
  9489. var tabUpEvents = eventHooks.tabUpEvents;
  9490. (0, _forEach["default"])(tabUpEvents).call(tabUpEvents, function (fn) {
  9491. return fn(e);
  9492. });
  9493. }); // tab down
  9494. $textElem.on('keydown', function (e) {
  9495. if (e.keyCode !== 9) return;
  9496. e.preventDefault();
  9497. var tabDownEvents = eventHooks.tabDownEvents;
  9498. (0, _forEach["default"])(tabDownEvents).call(tabDownEvents, function (fn) {
  9499. return fn(e);
  9500. });
  9501. }); // 文本编辑区域 滚动时触发
  9502. $textElem.on('scroll', // 使用节流
  9503. util_1.throttle(function (e) {
  9504. var textScrollEvents = eventHooks.textScrollEvents;
  9505. (0, _forEach["default"])(textScrollEvents).call(textScrollEvents, function (fn) {
  9506. return fn(e);
  9507. });
  9508. }, 100)); // 拖拽相关的事件
  9509. function preventDefault(e) {
  9510. // 禁用 document 拖拽事件
  9511. e.preventDefault();
  9512. }
  9513. dom_core_1["default"](document).on('dragleave', preventDefault).on('drop', preventDefault).on('dragenter', preventDefault).on('dragover', preventDefault); // 全局事件在编辑器实例销毁的时候进行解绑
  9514. editor.beforeDestroy(function () {
  9515. dom_core_1["default"](document).off('dragleave', preventDefault).off('drop', preventDefault).off('dragenter', preventDefault).off('dragover', preventDefault);
  9516. });
  9517. $textElem.on('drop', function (e) {
  9518. e.preventDefault();
  9519. var events = eventHooks.dropEvents;
  9520. (0, _forEach["default"])(events).call(events, function (fn) {
  9521. return fn(e);
  9522. });
  9523. }); // link click
  9524. $textElem.on('click', function (e) {
  9525. // 存储链接元素
  9526. var $link = null;
  9527. var target = e.target;
  9528. var $target = dom_core_1["default"](target);
  9529. if ($target.getNodeName() === 'A') {
  9530. // 当前点击的就是一个链接
  9531. $link = $target;
  9532. } else {
  9533. // 否则,向父节点中寻找链接
  9534. var $parent = $target.parentUntil('a');
  9535. if ($parent != null) {
  9536. // 找到了
  9537. $link = $parent;
  9538. }
  9539. }
  9540. if (!$link) return; // 没有点击链接,则返回
  9541. var linkClickEvents = eventHooks.linkClickEvents;
  9542. (0, _forEach["default"])(linkClickEvents).call(linkClickEvents, function (fn) {
  9543. return fn($link);
  9544. });
  9545. }); // img click
  9546. $textElem.on('click', function (e) {
  9547. // 存储图片元素
  9548. var $img = null;
  9549. var target = e.target;
  9550. var $target = dom_core_1["default"](target); //处理图片点击 去除掉emoji图片的情况
  9551. if ($target.getNodeName() === 'IMG' && !$target.elems[0].getAttribute('data-emoji')) {
  9552. // 当前点击的就是img
  9553. e.stopPropagation();
  9554. $img = $target;
  9555. }
  9556. if (!$img) return; // 没有点击图片,则返回
  9557. var imgClickEvents = eventHooks.imgClickEvents;
  9558. (0, _forEach["default"])(imgClickEvents).call(imgClickEvents, function (fn) {
  9559. return fn($img);
  9560. });
  9561. }); // code click
  9562. $textElem.on('click', function (e) {
  9563. // 存储代码元素
  9564. var $code = null;
  9565. var target = e.target;
  9566. var $target = dom_core_1["default"](target);
  9567. if ($target.getNodeName() === 'PRE') {
  9568. // 当前点击的就是一个链接
  9569. $code = $target;
  9570. } else {
  9571. // 否则,向父节点中寻找链接
  9572. var $parent = $target.parentUntil('pre');
  9573. if ($parent !== null) {
  9574. // 找到了
  9575. $code = $parent;
  9576. }
  9577. }
  9578. if (!$code) return;
  9579. var codeClickEvents = eventHooks.codeClickEvents;
  9580. (0, _forEach["default"])(codeClickEvents).call(codeClickEvents, function (fn) {
  9581. return fn($code);
  9582. });
  9583. }); // splitLine click
  9584. $textElem.on('click', function (e) {
  9585. // 存储分割线元素
  9586. var $splitLine = null;
  9587. var target = e.target;
  9588. var $target = dom_core_1["default"](target); // 判断当前点击元素
  9589. if ($target.getNodeName() === 'HR') {
  9590. $splitLine = $target;
  9591. } else {
  9592. $target == null;
  9593. }
  9594. if (!$splitLine) return; // 没有点击分割线,则返回
  9595. // 设置、恢复选区
  9596. editor.selection.createRangeByElem($splitLine);
  9597. editor.selection.restoreSelection();
  9598. var splitLineClickEvents = eventHooks.splitLineEvents;
  9599. (0, _forEach["default"])(splitLineClickEvents).call(splitLineClickEvents, function (fn) {
  9600. return fn($splitLine);
  9601. });
  9602. }); // 菜单栏被点击
  9603. editor.$toolbarElem.on('click', function (e) {
  9604. var toolbarClickEvents = eventHooks.toolbarClickEvents;
  9605. (0, _forEach["default"])(toolbarClickEvents).call(toolbarClickEvents, function (fn) {
  9606. return fn(e);
  9607. });
  9608. }); //mousedown事件
  9609. editor.$textContainerElem.on('mousedown', function (e) {
  9610. var target = e.target;
  9611. var $target = dom_core_1["default"](target);
  9612. if ($target.hasClass('w-e-img-drag-rb')) {
  9613. // 点击的元素,是图片拖拽调整大小的 bar
  9614. var imgDragBarMouseDownEvents = eventHooks.imgDragBarMouseDownEvents;
  9615. (0, _forEach["default"])(imgDragBarMouseDownEvents).call(imgDragBarMouseDownEvents, function (fn) {
  9616. return fn();
  9617. });
  9618. }
  9619. }); //table click
  9620. $textElem.on('click', function (e) {
  9621. // 存储元素
  9622. var $dom = null;
  9623. var target = e.target; //获取最祖父元素
  9624. $dom = dom_core_1["default"](target).parentUntilEditor('TABLE', editor, target); // 没有table范围内,则返回
  9625. if (!$dom) return;
  9626. var tableClickEvents = eventHooks.tableClickEvents;
  9627. (0, _forEach["default"])(tableClickEvents).call(tableClickEvents, function (fn) {
  9628. return fn($dom, e);
  9629. });
  9630. }); // enter 键 down
  9631. $textElem.on('keydown', function (e) {
  9632. if (e.keyCode !== 13) return;
  9633. var enterDownEvents = eventHooks.enterDownEvents;
  9634. (0, _forEach["default"])(enterDownEvents).call(enterDownEvents, function (fn) {
  9635. return fn(e);
  9636. });
  9637. }); // 视频 click
  9638. $textElem.on('click', function (e) {
  9639. // 存储视频
  9640. var $video = null;
  9641. var target = e.target;
  9642. var $target = dom_core_1["default"](target); //处理视频点击 简单的video 标签
  9643. if ($target.getNodeName() === 'VIDEO') {
  9644. // 当前点击的就是视频
  9645. e.stopPropagation();
  9646. $video = $target;
  9647. }
  9648. if (!$video) return; // 没有点击视频,则返回
  9649. var videoClickEvents = eventHooks.videoClickEvents;
  9650. (0, _forEach["default"])(videoClickEvents).call(videoClickEvents, function (fn) {
  9651. return fn($video);
  9652. });
  9653. });
  9654. };
  9655. return Text;
  9656. }();
  9657. exports["default"] = Text;
  9658. /***/ }),
  9659. /* 298 */
  9660. /***/ (function(module, exports, __webpack_require__) {
  9661. var parent = __webpack_require__(299);
  9662. module.exports = parent;
  9663. /***/ }),
  9664. /* 299 */
  9665. /***/ (function(module, exports, __webpack_require__) {
  9666. var find = __webpack_require__(300);
  9667. var ArrayPrototype = Array.prototype;
  9668. module.exports = function (it) {
  9669. var own = it.find;
  9670. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.find) ? find : own;
  9671. };
  9672. /***/ }),
  9673. /* 300 */
  9674. /***/ (function(module, exports, __webpack_require__) {
  9675. __webpack_require__(301);
  9676. var entryVirtual = __webpack_require__(14);
  9677. module.exports = entryVirtual('Array').find;
  9678. /***/ }),
  9679. /* 301 */
  9680. /***/ (function(module, exports, __webpack_require__) {
  9681. "use strict";
  9682. var $ = __webpack_require__(5);
  9683. var $find = __webpack_require__(31).find;
  9684. var addToUnscopables = __webpack_require__(89);
  9685. var FIND = 'find';
  9686. var SKIPS_HOLES = true;
  9687. // Shouldn't skip holes
  9688. if (FIND in []) Array(1)[FIND](function () { SKIPS_HOLES = false; });
  9689. // `Array.prototype.find` method
  9690. // https://tc39.es/ecma262/#sec-array.prototype.find
  9691. $({ target: 'Array', proto: true, forced: SKIPS_HOLES }, {
  9692. find: function find(callbackfn /* , that = undefined */) {
  9693. return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
  9694. }
  9695. });
  9696. // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables
  9697. addToUnscopables(FIND);
  9698. /***/ }),
  9699. /* 302 */
  9700. /***/ (function(module, exports, __webpack_require__) {
  9701. "use strict";
  9702. /**
  9703. * @description Text 事件钩子函数。Text 公共的,不是某个菜单独有的
  9704. * @wangfupeng
  9705. */
  9706. var _interopRequireDefault = __webpack_require__(0);
  9707. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  9708. (0, _defineProperty["default"])(exports, "__esModule", {
  9709. value: true
  9710. });
  9711. var tslib_1 = __webpack_require__(2);
  9712. var enter_to_create_p_1 = tslib_1.__importDefault(__webpack_require__(303));
  9713. var del_to_keep_p_1 = tslib_1.__importStar(__webpack_require__(304));
  9714. var tab_to_space_1 = tslib_1.__importDefault(__webpack_require__(305));
  9715. var paste_text_html_1 = tslib_1.__importDefault(__webpack_require__(306));
  9716. var img_click_active_1 = tslib_1.__importDefault(__webpack_require__(313));
  9717. /**
  9718. * 初始化 text 事件钩子函数
  9719. * @param text text 实例
  9720. */
  9721. function initTextHooks(text) {
  9722. var editor = text.editor;
  9723. var eventHooks = text.eventHooks; // 回车时,保证生成的是 <p> 标签
  9724. enter_to_create_p_1["default"](editor, eventHooks.enterUpEvents, eventHooks.enterDownEvents); // 删除时,保留 EMPTY_P
  9725. del_to_keep_p_1["default"](editor, eventHooks.deleteUpEvents, eventHooks.deleteDownEvents); // 剪切时, 保留p
  9726. del_to_keep_p_1.cutToKeepP(editor, eventHooks.keyupEvents); // tab 转换为空格
  9727. tab_to_space_1["default"](editor, eventHooks.tabDownEvents); // 粘贴 text html
  9728. paste_text_html_1["default"](editor, eventHooks.pasteEvents); // img click active
  9729. img_click_active_1["default"](editor, eventHooks.imgClickEvents);
  9730. }
  9731. exports["default"] = initTextHooks;
  9732. /***/ }),
  9733. /* 303 */
  9734. /***/ (function(module, exports, __webpack_require__) {
  9735. "use strict";
  9736. /**
  9737. * @description 回车时,保证生成的是 <p> 标签
  9738. * @author wangfupeng
  9739. */
  9740. var _interopRequireDefault = __webpack_require__(0);
  9741. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  9742. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  9743. (0, _defineProperty["default"])(exports, "__esModule", {
  9744. value: true
  9745. });
  9746. var tslib_1 = __webpack_require__(2);
  9747. var const_1 = __webpack_require__(7);
  9748. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  9749. /**
  9750. * 回车时,保证生成的是 <p> 标签
  9751. * @param editor 编辑器实例
  9752. * @param enterUpEvents enter 键 up 时的 hooks
  9753. * @param enterDownEvents enter 键 down 时的 hooks
  9754. */
  9755. function enterToCreateP(editor, enterUpEvents, enterDownEvents) {
  9756. function insertEmptyP($selectionElem) {
  9757. var _context;
  9758. var $p = dom_core_1["default"](const_1.EMPTY_P);
  9759. $p.insertBefore($selectionElem);
  9760. if ((0, _indexOf["default"])(_context = $selectionElem.html()).call(_context, '<img') >= 0) {
  9761. // 有图片的回车键弹起时
  9762. $p.remove();
  9763. return;
  9764. }
  9765. editor.selection.createRangeByElem($p, true, true);
  9766. editor.selection.restoreSelection();
  9767. $selectionElem.remove();
  9768. } // enter up 时
  9769. function fn() {
  9770. var $textElem = editor.$textElem;
  9771. var $selectionElem = editor.selection.getSelectionContainerElem();
  9772. var $parentElem = $selectionElem.parent();
  9773. if ($parentElem.html() === '<code><br></code>') {
  9774. // 回车之前光标所在一个 <p><code>.....</code></p> ,忽然回车生成一个空的 <p><code><br></code></p>
  9775. // 而且继续回车跳不出去,因此只能特殊处理
  9776. insertEmptyP($parentElem);
  9777. return;
  9778. }
  9779. if ($selectionElem.getNodeName() === 'FONT' && $selectionElem.text() === '' && $selectionElem.attr('face') === 'monospace') {
  9780. // 行内code回车时会产生一个<font face="monospace"><br></font>,导致样式问题
  9781. insertEmptyP($parentElem);
  9782. return;
  9783. }
  9784. if (!$parentElem.equal($textElem)) {
  9785. // 不是顶级标签
  9786. return;
  9787. }
  9788. var nodeName = $selectionElem.getNodeName();
  9789. if (nodeName === 'P' && $selectionElem.attr('data-we-empty-p') === null) {
  9790. // 当前的标签是 P 且不为 editor 生成的空白占位 p 标签,不用做处理
  9791. return;
  9792. }
  9793. if ($selectionElem.text()) {
  9794. // 有内容,不做处理
  9795. return;
  9796. } // 插入 <p> ,并将选取定位到 <p>,删除当前标签
  9797. insertEmptyP($selectionElem);
  9798. }
  9799. enterUpEvents.push(fn); // enter down 时
  9800. function createPWhenEnterText(e) {
  9801. var _a; // selection中的range缓存还有问题,更新不及时,此处手动更新range,处理enter的bug
  9802. editor.selection.saveRange((_a = getSelection()) === null || _a === void 0 ? void 0 : _a.getRangeAt(0));
  9803. var $selectElem = editor.selection.getSelectionContainerElem();
  9804. if ($selectElem.id === editor.textElemId) {
  9805. // 回车时,默认创建了 text 标签(没有 p 标签包裹),父元素直接就是 $textElem
  9806. // 例如,光标放在 table 最后侧,回车时,默认就是这个情况
  9807. e.preventDefault();
  9808. editor.cmd["do"]('insertHTML', '<p><br></p>');
  9809. }
  9810. }
  9811. enterDownEvents.push(createPWhenEnterText);
  9812. }
  9813. exports["default"] = enterToCreateP;
  9814. /***/ }),
  9815. /* 304 */
  9816. /***/ (function(module, exports, __webpack_require__) {
  9817. "use strict";
  9818. /**
  9819. * @description 删除时保留 EMPTY_P
  9820. * @author wangfupeng
  9821. */
  9822. var _interopRequireDefault = __webpack_require__(0);
  9823. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  9824. var _trim = _interopRequireDefault(__webpack_require__(16));
  9825. var _includes = _interopRequireDefault(__webpack_require__(46));
  9826. (0, _defineProperty["default"])(exports, "__esModule", {
  9827. value: true
  9828. });
  9829. exports.cutToKeepP = void 0;
  9830. var tslib_1 = __webpack_require__(2);
  9831. var const_1 = __webpack_require__(7);
  9832. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  9833. /**
  9834. * 删除时保留 EMPTY_P
  9835. * @param editor 编辑器实例
  9836. * @param deleteUpEvents delete 键 up 时的 hooks
  9837. * @param deleteDownEvents delete 建 down 时的 hooks
  9838. */
  9839. function deleteToKeepP(editor, deleteUpEvents, deleteDownEvents) {
  9840. function upFn() {
  9841. var $textElem = editor.$textElem;
  9842. var html = editor.$textElem.html();
  9843. var text = editor.$textElem.text();
  9844. var txtHtml = (0, _trim["default"])(html).call(html);
  9845. /**
  9846. @description
  9847. 如果编辑区清空的状态下,单单插入一张图片,删除图片后,会存在空的情况:'<p data-we-empty-p=""></p>'
  9848. 需要包含这种边界情况
  9849. **/
  9850. var emptyTags = ['<p><br></p>', '<br>', '<p data-we-empty-p=""></p>', const_1.EMPTY_P]; // 编辑器中的字符是""或空白,说明内容为空
  9851. if (/^\s*$/.test(text) && (!txtHtml || (0, _includes["default"])(emptyTags).call(emptyTags, txtHtml))) {
  9852. // 内容空了
  9853. $textElem.html(const_1.EMPTY_P);
  9854. editor.selection.createRangeByElem($textElem, false, true);
  9855. editor.selection.restoreSelection(); // 设置折叠后的光标位置,在firebox等浏览器下
  9856. // 光标设置在end位置会自动换行
  9857. editor.selection.moveCursor($textElem.getNode(), 0);
  9858. }
  9859. }
  9860. deleteUpEvents.push(upFn);
  9861. function downFn(e) {
  9862. var _context;
  9863. var $textElem = editor.$textElem;
  9864. var txtHtml = (0, _trim["default"])(_context = $textElem.html().toLowerCase()).call(_context);
  9865. if (txtHtml === const_1.EMPTY_P) {
  9866. // 最后剩下一个空行,就不再删除了
  9867. e.preventDefault();
  9868. return;
  9869. }
  9870. }
  9871. deleteDownEvents.push(downFn);
  9872. }
  9873. /**
  9874. * 剪切时保留 EMPTY_P
  9875. * @param editor 编辑器实例
  9876. * @param cutEvents keydown hooks
  9877. */
  9878. function cutToKeepP(editor, cutEvents) {
  9879. function upFn(e) {
  9880. var _context2;
  9881. if (e.keyCode !== 88) {
  9882. return;
  9883. }
  9884. var $textElem = editor.$textElem;
  9885. var txtHtml = (0, _trim["default"])(_context2 = $textElem.html().toLowerCase()).call(_context2); // firefox 时用 txtHtml === '<br>' 判断,其他用 !txtHtml 判断
  9886. if (!txtHtml || txtHtml === '<br>') {
  9887. // 内容空了
  9888. var $p = dom_core_1["default"](const_1.EMPTY_P);
  9889. $textElem.html(' '); // 一定要先清空,否则在 firefox 下有问题
  9890. $textElem.append($p);
  9891. editor.selection.createRangeByElem($p, false, true);
  9892. editor.selection.restoreSelection(); // 设置折叠后的光标位置,在firebox等浏览器下
  9893. // 光标设置在end位置会自动换行
  9894. editor.selection.moveCursor($p.getNode(), 0);
  9895. }
  9896. }
  9897. cutEvents.push(upFn);
  9898. }
  9899. exports.cutToKeepP = cutToKeepP;
  9900. exports["default"] = deleteToKeepP;
  9901. /***/ }),
  9902. /* 305 */
  9903. /***/ (function(module, exports, __webpack_require__) {
  9904. "use strict";
  9905. /**
  9906. * @description 编辑区域 tab 的特殊处理
  9907. * @author wangfupeng
  9908. */
  9909. var _interopRequireDefault = __webpack_require__(0);
  9910. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  9911. (0, _defineProperty["default"])(exports, "__esModule", {
  9912. value: true
  9913. });
  9914. /**
  9915. * 编辑区域 tab 的特殊处理,转换为空格
  9916. * @param editor 编辑器实例
  9917. * @param tabDownEvents tab down 事件钩子
  9918. */
  9919. function tabHandler(editor, tabDownEvents) {
  9920. // 定义函数
  9921. function fn() {
  9922. if (!editor.cmd.queryCommandSupported('insertHTML')) {
  9923. // 必须原生支持 insertHTML 命令
  9924. return;
  9925. }
  9926. var $selectionElem = editor.selection.getSelectionContainerElem();
  9927. if (!$selectionElem) {
  9928. return;
  9929. }
  9930. var $parentElem = $selectionElem.parent();
  9931. var selectionNodeName = $selectionElem.getNodeName();
  9932. var parentNodeName = $parentElem.getNodeName();
  9933. if (selectionNodeName == 'CODE' || parentNodeName === 'CODE' || parentNodeName === 'PRE' || /hljs/.test(parentNodeName)) {
  9934. // <pre><code> 里面
  9935. editor.cmd["do"]('insertHTML', editor.config.languageTab);
  9936. } else {
  9937. // 普通文字
  9938. editor.cmd["do"]('insertHTML', '&nbsp;&nbsp;&nbsp;&nbsp;');
  9939. }
  9940. } // 保留函数
  9941. tabDownEvents.push(fn);
  9942. }
  9943. exports["default"] = tabHandler;
  9944. /***/ }),
  9945. /* 306 */
  9946. /***/ (function(module, exports, __webpack_require__) {
  9947. "use strict";
  9948. /**
  9949. * @description 粘贴 text html
  9950. * @author wangfupeng
  9951. */
  9952. var _interopRequireDefault = __webpack_require__(0);
  9953. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  9954. var _trim = _interopRequireDefault(__webpack_require__(16));
  9955. (0, _defineProperty["default"])(exports, "__esModule", {
  9956. value: true
  9957. });
  9958. var paste_event_1 = __webpack_require__(135);
  9959. var util_1 = __webpack_require__(6);
  9960. var const_1 = __webpack_require__(7);
  9961. /**
  9962. * 格式化html
  9963. * @param val 粘贴的html
  9964. * @author Gavin
  9965. * @description
  9966. 格式化html,需要特别注意
  9967. 功能:
  9968. 1. 将htmlText中的div,都替换成p标签
  9969. 2. 将处理后的htmlText模拟先插入到真实dom中,处理P截断问题。
  9970. 注意点:
  9971. 由于P不能嵌套p,会导致标签截断,从而将<p><p>xx</p></p>这样一个结构插入到页面时,会出现很多问题,包括光标位置问题,页面凭空多很多元素的问题。
  9972. */
  9973. function formatHtml(htmlText) {
  9974. var _context;
  9975. var paste = (0, _trim["default"])(_context = htmlText.replace(/<div>/gim, '<p>') // div 全部替换为 p 标签
  9976. .replace(/<\/div>/gim, '</p>')).call(_context); // 去除''
  9977. // 模拟插入到真实dom中
  9978. var tempContainer = document.createElement('div');
  9979. tempContainer.innerHTML = paste;
  9980. return tempContainer.innerHTML.replace(/<p><\/p>/gim, ''); // 将被截断的p,都替换掉
  9981. }
  9982. /**
  9983. * 格式化html
  9984. * @param val 粘贴的html
  9985. * @author liuwei
  9986. */
  9987. function formatCode(val) {
  9988. var pasteText = val.replace(/<br>|<br\/>/gm, '\n').replace(/<[^>]+>/gm, '');
  9989. return pasteText;
  9990. }
  9991. /**
  9992. * 判断html是否使用P标签包裹
  9993. * @param html 粘贴的html
  9994. * @author luochao
  9995. */
  9996. function isParagraphHtml(html) {
  9997. var _a;
  9998. if (html === '') return false;
  9999. var container = document.createElement('div');
  10000. container.innerHTML = html;
  10001. return ((_a = container.firstChild) === null || _a === void 0 ? void 0 : _a.nodeName) === 'P';
  10002. }
  10003. /**
  10004. * 判断当前选区是否是空段落
  10005. * @param topElem 选区顶层元素
  10006. * @author luochao
  10007. */
  10008. function isEmptyParagraph(topElem) {
  10009. if (!(topElem === null || topElem === void 0 ? void 0 : topElem.length)) return false;
  10010. var dom = topElem.elems[0];
  10011. return dom.nodeName === 'P' && dom.innerHTML === '<br>';
  10012. }
  10013. /**
  10014. * 粘贴文本和 html
  10015. * @param editor 编辑器对象
  10016. * @param pasteEvents 粘贴事件列表
  10017. */
  10018. function pasteTextHtml(editor, pasteEvents) {
  10019. function fn(e) {
  10020. // 获取配置
  10021. var config = editor.config;
  10022. var pasteFilterStyle = config.pasteFilterStyle;
  10023. var pasteIgnoreImg = config.pasteIgnoreImg;
  10024. var pasteTextHandle = config.pasteTextHandle; // 获取粘贴的文字
  10025. var pasteHtml = paste_event_1.getPasteHtml(e, pasteFilterStyle, pasteIgnoreImg);
  10026. var pasteText = paste_event_1.getPasteText(e);
  10027. pasteText = pasteText.replace(/\n/gm, '<br>'); // 当前选区所在的 DOM 节点
  10028. var $selectionElem = editor.selection.getSelectionContainerElem();
  10029. if (!$selectionElem) {
  10030. return;
  10031. }
  10032. var nodeName = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getNodeName();
  10033. var $topElem = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getNodeTop(editor); // 当前节点顶级可能没有
  10034. var topNodeName = '';
  10035. if ($topElem.elems[0]) {
  10036. topNodeName = $topElem === null || $topElem === void 0 ? void 0 : $topElem.getNodeName();
  10037. } // code 中只能粘贴纯文本
  10038. if (nodeName === 'CODE' || topNodeName === 'PRE') {
  10039. if (pasteTextHandle && util_1.isFunction(pasteTextHandle)) {
  10040. // 用户自定义过滤处理粘贴内容
  10041. pasteText = '' + (pasteTextHandle(pasteText) || '');
  10042. }
  10043. editor.cmd["do"]('insertHTML', formatCode(pasteText));
  10044. return;
  10045. } // 如果用户开启闭粘贴样式注释则将复制进来为url的直接转为链接 否则不转换
  10046. // 在群中有用户提到关闭样式粘贴复制的文字进来后链接直接转为文字了,不符合预期,这里优化下
  10047. if (const_1.urlRegex.test(pasteText) && pasteFilterStyle) {
  10048. //当复制的内容为链接时,也应该判断用户是否定义了处理粘贴的事件
  10049. if (pasteTextHandle && util_1.isFunction(pasteTextHandle)) {
  10050. // 用户自定义过滤处理粘贴内容
  10051. pasteText = '' + (pasteTextHandle(pasteText) || ''); // html
  10052. }
  10053. var insertUrl = const_1.urlRegex.exec(pasteText)[0];
  10054. var otherText = pasteText.replace(const_1.urlRegex, '');
  10055. return editor.cmd["do"]('insertHTML', "<a href=\"" + insertUrl + "\" target=\"_blank\">" + insertUrl + "</a>" + otherText); // html
  10056. } // table 中(td、th),待开发。。。
  10057. if (!pasteHtml) {
  10058. return;
  10059. }
  10060. try {
  10061. // firefox 中,获取的 pasteHtml 可能是没有 <ul> 包裹的 <li>
  10062. // 因此执行 insertHTML 会报错
  10063. if (pasteTextHandle && util_1.isFunction(pasteTextHandle)) {
  10064. // 用户自定义过滤处理粘贴内容
  10065. pasteHtml = '' + (pasteTextHandle(pasteHtml) || ''); // html
  10066. } // 粘贴的html的是否是css的style样式
  10067. var isCssStyle = /[\.\#\@]?\w+[ ]+\{[^}]*\}/.test(pasteHtml); // eslint-disable-line
  10068. // 经过处理后还是包含暴露的css样式则直接插入它的text
  10069. if (isCssStyle && pasteFilterStyle) {
  10070. editor.cmd["do"]('insertHTML', "" + formatHtml(pasteText)); // text
  10071. } else {
  10072. var html = formatHtml(pasteHtml); // 如果是段落,为了兼容 firefox 和 chrome差异,自定义插入
  10073. if (isParagraphHtml(html)) {
  10074. var $textEl = editor.$textElem;
  10075. editor.cmd["do"]('insertHTML', html); // 全选的情况下覆盖原有内容
  10076. if ($textEl.equal($selectionElem)) {
  10077. // 更新选区
  10078. editor.selection.createEmptyRange();
  10079. return;
  10080. } // 如果选区是空段落,移除空段落
  10081. if (isEmptyParagraph($topElem)) {
  10082. $topElem.remove();
  10083. }
  10084. } else {
  10085. // 如果用户从百度等网站点击复制得到的图片是一串img标签且待src的http地址
  10086. // 见 https://github.com/wangeditor-team/wangEditor/issues/3119
  10087. // 如果是走用户定义的图片上传逻辑
  10088. var isHasOnlyImgEleReg = /^<img [^>]*src=['"]([^'"]+)[^>]*>$/g;
  10089. if (!isHasOnlyImgEleReg.test(html)) {
  10090. editor.cmd["do"]('insertHTML', html);
  10091. }
  10092. }
  10093. }
  10094. } catch (ex) {
  10095. // 此时使用 pasteText 来兼容一下
  10096. if (pasteTextHandle && util_1.isFunction(pasteTextHandle)) {
  10097. // 用户自定义过滤处理粘贴内容
  10098. pasteText = '' + (pasteTextHandle(pasteText) || '');
  10099. }
  10100. editor.cmd["do"]('insertHTML', "" + formatHtml(pasteText)); // text
  10101. }
  10102. }
  10103. pasteEvents.push(fn);
  10104. }
  10105. exports["default"] = pasteTextHtml;
  10106. /***/ }),
  10107. /* 307 */
  10108. /***/ (function(module, exports, __webpack_require__) {
  10109. "use strict";
  10110. /**
  10111. * @description 将粘贴的 html 字符串,转换为正确、简洁的 html 代码。剔除不必要的标签和属性。
  10112. * @author wangfupeng
  10113. */
  10114. var _interopRequireDefault = __webpack_require__(0);
  10115. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10116. var _trim = _interopRequireDefault(__webpack_require__(16));
  10117. var _forEach = _interopRequireDefault(__webpack_require__(4));
  10118. var _includes = _interopRequireDefault(__webpack_require__(46));
  10119. (0, _defineProperty["default"])(exports, "__esModule", {
  10120. value: true
  10121. });
  10122. var tslib_1 = __webpack_require__(2);
  10123. var tags_1 = __webpack_require__(308);
  10124. var simplehtmlparser_js_1 = tslib_1.__importDefault(__webpack_require__(312));
  10125. /**
  10126. * 过滤掉空 span
  10127. * @param html html
  10128. */
  10129. function filterEmptySpan(html) {
  10130. var regForReplace = /<span>.*?<\/span>/gi;
  10131. var regForMatch = /<span>(.*?)<\/span>/;
  10132. return html.replace(regForReplace, function (s) {
  10133. // s 是单个 span ,如 <span>文字</span>
  10134. var result = s.match(regForMatch);
  10135. if (result == null) return '';
  10136. return result[1];
  10137. });
  10138. }
  10139. /**
  10140. * 是否忽略标签
  10141. * @param tag tag
  10142. * @param ignoreImg 是否忽略 img 标签
  10143. */
  10144. function isIgnoreTag(tag, ignoreImg) {
  10145. var _context;
  10146. tag = (0, _trim["default"])(_context = tag.toLowerCase()).call(_context); // 忽略的标签
  10147. if (tags_1.IGNORE_TAGS.has(tag)) {
  10148. return true;
  10149. } // 是否忽略图片
  10150. if (ignoreImg) {
  10151. if (tag === 'img') {
  10152. return true;
  10153. }
  10154. }
  10155. return false;
  10156. }
  10157. /**
  10158. * 为 tag 生成 html 字符串,开始部分
  10159. * @param tag tag
  10160. * @param attrs 属性
  10161. */
  10162. function genStartHtml(tag, attrs) {
  10163. var result = ''; // tag < 符号
  10164. result = "<" + tag; // 拼接属性
  10165. var attrStrArr = [];
  10166. (0, _forEach["default"])(attrs).call(attrs, function (attr) {
  10167. attrStrArr.push(attr.name + "=\"" + attr.value + "\"");
  10168. });
  10169. if (attrStrArr.length > 0) {
  10170. result = result + ' ' + attrStrArr.join(' ');
  10171. } // tag > 符号
  10172. var isEmpty = tags_1.EMPTY_TAGS.has(tag); // 没有子节点或文本的标签,如 img
  10173. result = result + (isEmpty ? '/' : '') + '>';
  10174. return result;
  10175. }
  10176. /**
  10177. * 为 tag 生成 html 字符串,结尾部分
  10178. * @param tag tag
  10179. */
  10180. function genEndHtml(tag) {
  10181. return "</" + tag + ">";
  10182. }
  10183. /**
  10184. * 处理粘贴的 html
  10185. * @param html html 字符串
  10186. * @param filterStyle 是否过滤 style 样式
  10187. * @param ignoreImg 是否忽略 img 标签
  10188. */
  10189. function parseHtml(html, filterStyle, ignoreImg) {
  10190. if (filterStyle === void 0) {
  10191. filterStyle = true;
  10192. }
  10193. if (ignoreImg === void 0) {
  10194. ignoreImg = false;
  10195. }
  10196. var resultArr = []; // 存储结果,数组形式,最后再 join
  10197. // 当前正在处理的标签,以及记录和清除的方法
  10198. var CUR_TAG = '';
  10199. function markTagStart(tag) {
  10200. tag = (0, _trim["default"])(tag).call(tag);
  10201. if (!tag) return;
  10202. if (tags_1.EMPTY_TAGS.has(tag)) return; // 内容为空的标签,如 img ,不用记录
  10203. CUR_TAG = tag;
  10204. }
  10205. function markTagEnd() {
  10206. CUR_TAG = '';
  10207. } // 能通过 'text/html' 格式获取 html
  10208. var htmlParser = new simplehtmlparser_js_1["default"]();
  10209. htmlParser.parse(html, {
  10210. startElement: function startElement(tag, attrs) {
  10211. // 首先,标记开始
  10212. markTagStart(tag); // 忽略的标签
  10213. if (isIgnoreTag(tag, ignoreImg)) {
  10214. return;
  10215. } // 找出该标签必须的属性(其他的属性忽略)
  10216. var necessaryAttrKeys = tags_1.NECESSARY_ATTRS.get(tag) || [];
  10217. var attrsForTag = [];
  10218. (0, _forEach["default"])(attrs).call(attrs, function (attr) {
  10219. // 属性名
  10220. var name = attr.name; // style 单独处理
  10221. if (name === 'style') {
  10222. // 保留 style 样式
  10223. if (!filterStyle) {
  10224. attrsForTag.push(attr);
  10225. }
  10226. return;
  10227. } // 除了 style 之外的其他属性
  10228. if ((0, _includes["default"])(necessaryAttrKeys).call(necessaryAttrKeys, name) === false) {
  10229. // 不是必须的属性,忽略
  10230. return;
  10231. }
  10232. attrsForTag.push(attr);
  10233. }); // 拼接为 HTML 标签
  10234. var html = genStartHtml(tag, attrsForTag);
  10235. resultArr.push(html);
  10236. },
  10237. characters: function characters(str) {
  10238. if (!str) {
  10239. return;
  10240. } // 忽略的标签
  10241. if (isIgnoreTag(CUR_TAG, ignoreImg)) return;
  10242. resultArr.push(str);
  10243. },
  10244. endElement: function endElement(tag) {
  10245. // 忽略的标签
  10246. if (isIgnoreTag(tag, ignoreImg)) {
  10247. return;
  10248. } // 拼接为 HTML 标签
  10249. var html = genEndHtml(tag);
  10250. resultArr.push(html); // 最后,标记结束
  10251. markTagEnd();
  10252. },
  10253. comment: function comment(str) {
  10254. /* 注释,不做处理 */
  10255. markTagStart(str);
  10256. }
  10257. });
  10258. var result = resultArr.join(''); // 转换为字符串
  10259. // 过滤掉空 span 标签
  10260. result = filterEmptySpan(result);
  10261. return result;
  10262. }
  10263. exports["default"] = parseHtml;
  10264. /***/ }),
  10265. /* 308 */
  10266. /***/ (function(module, exports, __webpack_require__) {
  10267. "use strict";
  10268. /**
  10269. * @description 粘贴相关的 tags
  10270. * @author wangfupeng
  10271. */
  10272. var _interopRequireDefault = __webpack_require__(0);
  10273. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10274. var _set = _interopRequireDefault(__webpack_require__(136));
  10275. var _map = _interopRequireDefault(__webpack_require__(125));
  10276. (0, _defineProperty["default"])(exports, "__esModule", {
  10277. value: true
  10278. });
  10279. exports.TOP_LEVEL_TAGS = exports.EMPTY_TAGS = exports.NECESSARY_ATTRS = exports.IGNORE_TAGS = void 0; // 忽略的标签
  10280. exports.IGNORE_TAGS = new _set["default"](['doctype', '!doctype', 'html', 'head', 'meta', 'body', 'script', 'style', 'link', 'frame', 'iframe', 'title', 'svg', 'center', 'o:p' // 复制 word 内容包含 o:p 标签
  10281. ]); // 指定标签必要的属性
  10282. exports.NECESSARY_ATTRS = new _map["default"]([['img', ['src', 'alt']], ['a', ['href', 'target']], ['td', ['colspan', 'rowspan']], ['th', ['colspan', 'rowspan']]]); // 没有子节点或文本的标签
  10283. exports.EMPTY_TAGS = new _set["default"](['area', 'base', 'basefont', 'br', 'col', 'hr', 'img', 'input', 'isindex', 'embed']); // 编辑区域顶级节点
  10284. exports.TOP_LEVEL_TAGS = new _set["default"](['h1', 'h2', 'h3', 'h4', 'h5', 'p', 'ul', 'ol', 'table', 'blockquote', 'pre', 'hr', 'form']);
  10285. /***/ }),
  10286. /* 309 */
  10287. /***/ (function(module, exports, __webpack_require__) {
  10288. var parent = __webpack_require__(310);
  10289. __webpack_require__(45);
  10290. module.exports = parent;
  10291. /***/ }),
  10292. /* 310 */
  10293. /***/ (function(module, exports, __webpack_require__) {
  10294. __webpack_require__(55);
  10295. __webpack_require__(57);
  10296. __webpack_require__(311);
  10297. __webpack_require__(58);
  10298. var path = __webpack_require__(11);
  10299. module.exports = path.Set;
  10300. /***/ }),
  10301. /* 311 */
  10302. /***/ (function(module, exports, __webpack_require__) {
  10303. "use strict";
  10304. var collection = __webpack_require__(126);
  10305. var collectionStrong = __webpack_require__(129);
  10306. // `Set` constructor
  10307. // https://tc39.es/ecma262/#sec-set-objects
  10308. module.exports = collection('Set', function (init) {
  10309. return function Set() { return init(this, arguments.length ? arguments[0] : undefined); };
  10310. }, collectionStrong);
  10311. /***/ }),
  10312. /* 312 */
  10313. /***/ (function(module, exports) {
  10314. // Copyright 2004 Erik Arvidsson. All Rights Reserved.
  10315. //
  10316. // This code is triple licensed using Apache Software License 2.0,
  10317. // Mozilla Public License or GNU Public License
  10318. //
  10319. ///////////////////////////////////////////////////////////////////////////////
  10320. //
  10321. // Licensed under the Apache License, Version 2.0 (the "License"); you may not
  10322. // use this file except in compliance with the License. You may obtain a copy
  10323. // of the License at http://www.apache.org/licenses/LICENSE-2.0
  10324. //
  10325. ///////////////////////////////////////////////////////////////////////////////
  10326. //
  10327. // The contents of this file are subject to the Mozilla Public License
  10328. // Version 1.1 (the "License"); you may not use this file except in
  10329. // compliance with the License. You may obtain a copy of the License at
  10330. // http://www.mozilla.org/MPL/
  10331. //
  10332. // Software distributed under the License is distributed on an "AS IS"
  10333. // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
  10334. // License for the specific language governing rights and limitations
  10335. // under the License.
  10336. //
  10337. // The Original Code is Simple HTML Parser.
  10338. //
  10339. // The Initial Developer of the Original Code is Erik Arvidsson.
  10340. // Portions created by Erik Arvidssson are Copyright (C) 2004. All Rights
  10341. // Reserved.
  10342. //
  10343. ///////////////////////////////////////////////////////////////////////////////
  10344. //
  10345. // This program is free software; you can redistribute it and/or
  10346. // modify it under the terms of the GNU General Public License
  10347. // as published by the Free Software Foundation; either version 2
  10348. // of the License, or (at your option) any later version.
  10349. //
  10350. // This program is distributed in the hope that it will be useful,
  10351. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  10352. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10353. // GNU General Public License for more details.
  10354. //
  10355. // You should have received a copy of the GNU General Public License
  10356. // along with this program; if not, write to the Free Software
  10357. // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  10358. //
  10359. ///////////////////////////////////////////////////////////////////////////////
  10360. /*
  10361. var handler ={
  10362. startElement: function (sTagName, oAttrs) {},
  10363. endElement: function (sTagName) {},
  10364. characters: function (s) {},
  10365. comment: function (s) {}
  10366. };
  10367. */
  10368. function SimpleHtmlParser() {}
  10369. SimpleHtmlParser.prototype = {
  10370. handler: null,
  10371. // regexps
  10372. startTagRe: /^<([^>\s\/]+)((\s+[^=>\s]+(\s*=\s*((\"[^"]*\")|(\'[^']*\')|[^>\s]+))?)*)\s*\/?\s*>/m,
  10373. endTagRe: /^<\/([^>\s]+)[^>]*>/m,
  10374. attrRe: /([^=\s]+)(\s*=\s*((\"([^"]*)\")|(\'([^']*)\')|[^>\s]+))?/gm,
  10375. parse: function (s, oHandler) {
  10376. if (oHandler) this.contentHandler = oHandler
  10377. var i = 0
  10378. var res, lc, lm, rc, index
  10379. var treatAsChars = false
  10380. var oThis = this
  10381. while (s.length > 0) {
  10382. // Comment
  10383. if (s.substring(0, 4) == '<!--') {
  10384. index = s.indexOf('-->')
  10385. if (index != -1) {
  10386. this.contentHandler.comment(s.substring(4, index))
  10387. s = s.substring(index + 3)
  10388. treatAsChars = false
  10389. } else {
  10390. treatAsChars = true
  10391. }
  10392. }
  10393. // end tag
  10394. else if (s.substring(0, 2) == '</') {
  10395. if (this.endTagRe.test(s)) {
  10396. lc = RegExp.leftContext
  10397. lm = RegExp.lastMatch
  10398. rc = RegExp.rightContext
  10399. lm.replace(this.endTagRe, function () {
  10400. return oThis.parseEndTag.apply(oThis, arguments)
  10401. })
  10402. s = rc
  10403. treatAsChars = false
  10404. } else {
  10405. treatAsChars = true
  10406. }
  10407. }
  10408. // start tag
  10409. else if (s.charAt(0) == '<') {
  10410. if (this.startTagRe.test(s)) {
  10411. lc = RegExp.leftContext
  10412. lm = RegExp.lastMatch
  10413. rc = RegExp.rightContext
  10414. lm.replace(this.startTagRe, function () {
  10415. return oThis.parseStartTag.apply(oThis, arguments)
  10416. })
  10417. s = rc
  10418. treatAsChars = false
  10419. } else {
  10420. treatAsChars = true
  10421. }
  10422. }
  10423. if (treatAsChars) {
  10424. index = s.indexOf('<')
  10425. if (index == -1) {
  10426. this.contentHandler.characters(s)
  10427. s = ''
  10428. } else {
  10429. this.contentHandler.characters(s.substring(0, index))
  10430. s = s.substring(index)
  10431. }
  10432. }
  10433. treatAsChars = true
  10434. }
  10435. },
  10436. parseStartTag: function (sTag, sTagName, sRest) {
  10437. var attrs = this.parseAttributes(sTagName, sRest)
  10438. this.contentHandler.startElement(sTagName, attrs)
  10439. },
  10440. parseEndTag: function (sTag, sTagName) {
  10441. this.contentHandler.endElement(sTagName)
  10442. },
  10443. parseAttributes: function (sTagName, s) {
  10444. var oThis = this
  10445. var attrs = []
  10446. s.replace(this.attrRe, function (a0, a1, a2, a3, a4, a5, a6, a7) {
  10447. attrs.push(oThis.parseAttribute(sTagName, a0, a1, a2, a3, a4, a5, a6, a7))
  10448. })
  10449. return attrs
  10450. },
  10451. parseAttribute: function (sTagName, sAttribute, sName) {
  10452. var value = ''
  10453. if (arguments[7]) value = arguments[8]
  10454. else if (arguments[5]) value = arguments[6]
  10455. else if (arguments[3]) value = arguments[4]
  10456. var empty = !value && !arguments[3]
  10457. return { name: sName, value: empty ? null : value }
  10458. },
  10459. }
  10460. // export default SimpleHtmlParser
  10461. module.exports = SimpleHtmlParser
  10462. /***/ }),
  10463. /* 313 */
  10464. /***/ (function(module, exports, __webpack_require__) {
  10465. "use strict";
  10466. /**
  10467. * @description 图片点击后选区更新到img的位置
  10468. * @author tonghan
  10469. */
  10470. var _interopRequireDefault = __webpack_require__(0);
  10471. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10472. (0, _defineProperty["default"])(exports, "__esModule", {
  10473. value: true
  10474. });
  10475. /**
  10476. * 图片点击后选区更新到img的位置
  10477. * @param editor 编辑器实例
  10478. * @param imgClickEvents delete 键 up 时的 hooks
  10479. */
  10480. function imgClickActive(editor, imgClickEvents) {
  10481. function clickFn($img) {
  10482. editor.selection.createRangeByElem($img);
  10483. editor.selection.restoreSelection();
  10484. }
  10485. imgClickEvents.push(clickFn);
  10486. }
  10487. exports["default"] = imgClickActive;
  10488. /***/ }),
  10489. /* 314 */
  10490. /***/ (function(module, exports, __webpack_require__) {
  10491. "use strict";
  10492. /**
  10493. * @description 获取子元素的 JSON 格式数据
  10494. * @author wangfupeng
  10495. */
  10496. var _interopRequireDefault = __webpack_require__(0);
  10497. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10498. var _forEach = _interopRequireDefault(__webpack_require__(4));
  10499. (0, _defineProperty["default"])(exports, "__esModule", {
  10500. value: true
  10501. });
  10502. var tslib_1 = __webpack_require__(2);
  10503. var util_1 = __webpack_require__(6);
  10504. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  10505. /**
  10506. * 获取子元素的 JSON 格式数据
  10507. * @param $elem DOM 节点
  10508. */
  10509. function getChildrenJSON($elem) {
  10510. var result = []; // 存储结果
  10511. var $children = $elem.childNodes() || []; // 注意 childNodes() 可以获取文本节点
  10512. (0, _forEach["default"])($children).call($children, function (curElem) {
  10513. var elemResult;
  10514. var nodeType = curElem.nodeType; // 文本节点
  10515. if (nodeType === 3) {
  10516. elemResult = curElem.textContent || '';
  10517. elemResult = util_1.replaceHtmlSymbol(elemResult);
  10518. } // 普通 DOM 节点
  10519. if (nodeType === 1) {
  10520. elemResult = {};
  10521. elemResult = elemResult; // tag
  10522. elemResult.tag = curElem.nodeName.toLowerCase(); // attr
  10523. var attrData = [];
  10524. var attrList = curElem.attributes;
  10525. var attrListLength = attrList.length || 0;
  10526. for (var i = 0; i < attrListLength; i++) {
  10527. var attr = attrList[i];
  10528. attrData.push({
  10529. name: attr.name,
  10530. value: attr.value
  10531. });
  10532. }
  10533. elemResult.attrs = attrData; // children(递归)
  10534. elemResult.children = getChildrenJSON(dom_core_1["default"](curElem));
  10535. }
  10536. if (elemResult) {
  10537. result.push(elemResult);
  10538. }
  10539. });
  10540. return result;
  10541. }
  10542. exports["default"] = getChildrenJSON;
  10543. /***/ }),
  10544. /* 315 */
  10545. /***/ (function(module, exports, __webpack_require__) {
  10546. "use strict";
  10547. /**
  10548. * @description 从nodeList json格式中遍历生成dom元素
  10549. * @author zhengwenjian
  10550. */
  10551. var _interopRequireDefault = __webpack_require__(0);
  10552. var _typeof2 = _interopRequireDefault(__webpack_require__(100));
  10553. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10554. var _forEach = _interopRequireDefault(__webpack_require__(4));
  10555. (0, _defineProperty["default"])(exports, "__esModule", {
  10556. value: true
  10557. });
  10558. var tslib_1 = __webpack_require__(2);
  10559. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  10560. function getHtmlByNodeList(nodeList, parent) {
  10561. if (parent === void 0) {
  10562. parent = document.createElement('div');
  10563. } // 设置一个父节点存储所有子节点
  10564. var root = parent; // 遍历节点JSON
  10565. (0, _forEach["default"])(nodeList).call(nodeList, function (item) {
  10566. var elem; // 当为文本节点时
  10567. if (typeof item === 'string') {
  10568. elem = document.createTextNode(item);
  10569. } // 当为普通节点时
  10570. if ((0, _typeof2["default"])(item) === 'object') {
  10571. var _context;
  10572. elem = document.createElement(item.tag);
  10573. (0, _forEach["default"])(_context = item.attrs).call(_context, function (attr) {
  10574. dom_core_1["default"](elem).attr(attr.name, attr.value);
  10575. }); // 有子节点时递归将子节点加入当前节点
  10576. if (item.children && item.children.length > 0) {
  10577. getHtmlByNodeList(item.children, elem.getRootNode());
  10578. }
  10579. }
  10580. elem && root.appendChild(elem);
  10581. });
  10582. return dom_core_1["default"](root);
  10583. }
  10584. exports["default"] = getHtmlByNodeList;
  10585. /***/ }),
  10586. /* 316 */
  10587. /***/ (function(module, exports, __webpack_require__) {
  10588. "use strict";
  10589. /**
  10590. * @description Menus 菜单栏 入口文件
  10591. * @author wangfupeng
  10592. */
  10593. var _interopRequireDefault = __webpack_require__(0);
  10594. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10595. var _isArray = _interopRequireDefault(__webpack_require__(96));
  10596. var _filter = _interopRequireDefault(__webpack_require__(76));
  10597. var _includes = _interopRequireDefault(__webpack_require__(46));
  10598. var _keys = _interopRequireDefault(__webpack_require__(317));
  10599. var _forEach = _interopRequireDefault(__webpack_require__(4));
  10600. var _entries = _interopRequireDefault(__webpack_require__(102));
  10601. var _some = _interopRequireDefault(__webpack_require__(137));
  10602. var _setTimeout2 = _interopRequireDefault(__webpack_require__(48));
  10603. var _bind = _interopRequireDefault(__webpack_require__(61));
  10604. (0, _defineProperty["default"])(exports, "__esModule", {
  10605. value: true
  10606. });
  10607. var tslib_1 = __webpack_require__(2);
  10608. var index_1 = tslib_1.__importDefault(__webpack_require__(94));
  10609. var menu_list_1 = tslib_1.__importDefault(__webpack_require__(329));
  10610. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3)); // import { MenuActive } from './menu-constructors/Menu'
  10611. var Menus = function () {
  10612. function Menus(editor) {
  10613. this.editor = editor;
  10614. this.menuList = [];
  10615. this.constructorList = menu_list_1["default"]; // 所有菜单构造函数的列表
  10616. }
  10617. /**
  10618. * 自定义添加菜单
  10619. * @param key 菜单 key ,和 editor.config.menus 对应
  10620. * @param Menu 菜单构造函数
  10621. */
  10622. Menus.prototype.extend = function (key, Menu) {
  10623. if (!Menu || typeof Menu !== 'function') return;
  10624. this.constructorList[key] = Menu;
  10625. }; // 初始化菜单
  10626. Menus.prototype.init = function () {
  10627. var _context, _context2;
  10628. var _this = this; // 从用户配置的 menus 入手,看需要初始化哪些菜单
  10629. var config = this.editor.config; // 排除exclude包含的菜单
  10630. var excludeMenus = config.excludeMenus;
  10631. if ((0, _isArray["default"])(excludeMenus) === false) excludeMenus = [];
  10632. config.menus = (0, _filter["default"])(_context = config.menus).call(_context, function (key) {
  10633. return (0, _includes["default"])(excludeMenus).call(excludeMenus, key) === false;
  10634. }); // 排除自扩展中exclude包含的菜单
  10635. var CustomMenuKeysList = (0, _keys["default"])(index_1["default"].globalCustomMenuConstructorList);
  10636. CustomMenuKeysList = (0, _filter["default"])(CustomMenuKeysList).call(CustomMenuKeysList, function (key) {
  10637. return (0, _includes["default"])(excludeMenus).call(excludeMenus, key);
  10638. });
  10639. (0, _forEach["default"])(CustomMenuKeysList).call(CustomMenuKeysList, function (key) {
  10640. delete index_1["default"].globalCustomMenuConstructorList[key];
  10641. });
  10642. (0, _forEach["default"])(_context2 = config.menus).call(_context2, function (menuKey) {
  10643. var MenuConstructor = _this.constructorList[menuKey]; // 暂用 any ,后面再替换
  10644. _this._initMenuList(menuKey, MenuConstructor);
  10645. }); // 全局注册
  10646. for (var _i = 0, _a = (0, _entries["default"])(index_1["default"].globalCustomMenuConstructorList); _i < _a.length; _i++) {
  10647. var _b = _a[_i],
  10648. menuKey = _b[0],
  10649. menuFun = _b[1];
  10650. var MenuConstructor = menuFun; // 暂用 any ,后面再替换
  10651. this._initMenuList(menuKey, MenuConstructor);
  10652. } // 渲染 DOM
  10653. this._addToToolbar();
  10654. if (config.showMenuTooltips) {
  10655. // 添加菜单栏tooltips
  10656. this._bindMenuTooltips();
  10657. }
  10658. };
  10659. /**
  10660. * 创建 menu 实例,并放到 menuList 中
  10661. * @param menuKey 菜单 key ,和 editor.config.menus 对应
  10662. * @param MenuConstructor 菜单构造函数
  10663. */
  10664. Menus.prototype._initMenuList = function (menuKey, MenuConstructor) {
  10665. var _context3;
  10666. if (MenuConstructor == null || typeof MenuConstructor !== 'function') {
  10667. // 必须是 class
  10668. return;
  10669. }
  10670. if ((0, _some["default"])(_context3 = this.menuList).call(_context3, function (menu) {
  10671. return menu.key === menuKey;
  10672. })) {
  10673. console.warn('菜单名称重复:' + menuKey);
  10674. } else {
  10675. var m = new MenuConstructor(this.editor);
  10676. m.key = menuKey;
  10677. this.menuList.push(m);
  10678. }
  10679. }; // 绑定菜单栏tooltips
  10680. Menus.prototype._bindMenuTooltips = function () {
  10681. var editor = this.editor;
  10682. var $toolbarElem = editor.$toolbarElem;
  10683. var config = editor.config; // 若isTooltipShowTop为true则伪元素为下三角,反之为上三角
  10684. var menuTooltipPosition = config.menuTooltipPosition;
  10685. var $tooltipEl = dom_core_1["default"]("<div class=\"w-e-menu-tooltip w-e-menu-tooltip-" + menuTooltipPosition + "\">\n <div class=\"w-e-menu-tooltip-item-wrapper\">\n <div></div>\n </div>\n </div>");
  10686. $tooltipEl.css('visibility', 'hidden');
  10687. $toolbarElem.append($tooltipEl); // 设置 z-index
  10688. $tooltipEl.css('z-index', editor.zIndex.get('tooltip'));
  10689. var showTimeoutId = 0; // 定时器,延时200ms显示tooltips
  10690. // 清空计时器
  10691. function clearShowTimeoutId() {
  10692. if (showTimeoutId) {
  10693. clearTimeout(showTimeoutId);
  10694. }
  10695. } // 隐藏tooltip
  10696. function hide() {
  10697. clearShowTimeoutId();
  10698. $tooltipEl.css('visibility', 'hidden');
  10699. } // 事件监听
  10700. $toolbarElem.on('mouseover', function (e) {
  10701. var target = e.target;
  10702. var $target = dom_core_1["default"](target);
  10703. var title;
  10704. var $menuEl;
  10705. if ($target.isContain($toolbarElem)) {
  10706. hide();
  10707. return;
  10708. }
  10709. if ($target.parentUntil('.w-e-droplist') != null) {
  10710. // 处于droplist中时隐藏
  10711. hide();
  10712. } else {
  10713. if ($target.attr('data-title')) {
  10714. title = $target.attr('data-title');
  10715. $menuEl = $target;
  10716. } else {
  10717. var $parent = $target.parentUntil('.w-e-menu');
  10718. if ($parent != null) {
  10719. title = $parent.attr('data-title');
  10720. $menuEl = $parent;
  10721. }
  10722. }
  10723. }
  10724. if (title && $menuEl) {
  10725. clearShowTimeoutId();
  10726. var targetOffset = $menuEl.getOffsetData();
  10727. $tooltipEl.text(editor.i18next.t('menus.title.' + title));
  10728. var tooltipOffset = $tooltipEl.getOffsetData();
  10729. var left = targetOffset.left + targetOffset.width / 2 - tooltipOffset.width / 2;
  10730. $tooltipEl.css('left', left + "px"); // 2. 高度设置
  10731. if (menuTooltipPosition === 'up') {
  10732. $tooltipEl.css('top', targetOffset.top - tooltipOffset.height - 8 + "px");
  10733. } else if (menuTooltipPosition === 'down') {
  10734. $tooltipEl.css('top', targetOffset.top + targetOffset.height + 8 + "px");
  10735. }
  10736. showTimeoutId = (0, _setTimeout2["default"])(function () {
  10737. $tooltipEl.css('visibility', 'visible');
  10738. }, 200);
  10739. } else {
  10740. hide();
  10741. }
  10742. }).on('mouseleave', function () {
  10743. hide();
  10744. });
  10745. }; // 添加到菜单栏
  10746. Menus.prototype._addToToolbar = function () {
  10747. var _context4;
  10748. var editor = this.editor;
  10749. var $toolbarElem = editor.$toolbarElem; // 遍历添加到 DOM
  10750. (0, _forEach["default"])(_context4 = this.menuList).call(_context4, function (menu) {
  10751. var $elem = menu.$elem;
  10752. if ($elem) {
  10753. $toolbarElem.append($elem);
  10754. }
  10755. });
  10756. };
  10757. /**
  10758. * 获取菜单对象
  10759. * @param 菜单名称 小写
  10760. * @return Menus 菜单对象
  10761. */
  10762. Menus.prototype.menuFind = function (key) {
  10763. var menuList = this.menuList;
  10764. for (var i = 0, l = menuList.length; i < l; i++) {
  10765. if (menuList[i].key === key) return menuList[i];
  10766. }
  10767. return menuList[0];
  10768. };
  10769. /**
  10770. * @description 修改菜单激活状态
  10771. */
  10772. Menus.prototype.changeActive = function () {
  10773. var _context5;
  10774. (0, _forEach["default"])(_context5 = this.menuList).call(_context5, function (menu) {
  10775. var _context6;
  10776. (0, _setTimeout2["default"])((0, _bind["default"])(_context6 = menu.tryChangeActive).call(_context6, menu), 100); // 暂用 any ,后面再替换
  10777. });
  10778. };
  10779. return Menus;
  10780. }();
  10781. exports["default"] = Menus;
  10782. /***/ }),
  10783. /* 317 */
  10784. /***/ (function(module, exports, __webpack_require__) {
  10785. module.exports = __webpack_require__(318);
  10786. /***/ }),
  10787. /* 318 */
  10788. /***/ (function(module, exports, __webpack_require__) {
  10789. var parent = __webpack_require__(319);
  10790. module.exports = parent;
  10791. /***/ }),
  10792. /* 319 */
  10793. /***/ (function(module, exports, __webpack_require__) {
  10794. __webpack_require__(320);
  10795. var path = __webpack_require__(11);
  10796. module.exports = path.Object.keys;
  10797. /***/ }),
  10798. /* 320 */
  10799. /***/ (function(module, exports, __webpack_require__) {
  10800. var $ = __webpack_require__(5);
  10801. var toObject = __webpack_require__(26);
  10802. var nativeKeys = __webpack_require__(53);
  10803. var fails = __webpack_require__(12);
  10804. var FAILS_ON_PRIMITIVES = fails(function () { nativeKeys(1); });
  10805. // `Object.keys` method
  10806. // https://tc39.es/ecma262/#sec-object.keys
  10807. $({ target: 'Object', stat: true, forced: FAILS_ON_PRIMITIVES }, {
  10808. keys: function keys(it) {
  10809. return nativeKeys(toObject(it));
  10810. }
  10811. });
  10812. /***/ }),
  10813. /* 321 */
  10814. /***/ (function(module, exports, __webpack_require__) {
  10815. var parent = __webpack_require__(322);
  10816. module.exports = parent;
  10817. /***/ }),
  10818. /* 322 */
  10819. /***/ (function(module, exports, __webpack_require__) {
  10820. __webpack_require__(323);
  10821. var path = __webpack_require__(11);
  10822. module.exports = path.Object.entries;
  10823. /***/ }),
  10824. /* 323 */
  10825. /***/ (function(module, exports, __webpack_require__) {
  10826. var $ = __webpack_require__(5);
  10827. var $entries = __webpack_require__(324).entries;
  10828. // `Object.entries` method
  10829. // https://tc39.es/ecma262/#sec-object.entries
  10830. $({ target: 'Object', stat: true }, {
  10831. entries: function entries(O) {
  10832. return $entries(O);
  10833. }
  10834. });
  10835. /***/ }),
  10836. /* 324 */
  10837. /***/ (function(module, exports, __webpack_require__) {
  10838. var DESCRIPTORS = __webpack_require__(15);
  10839. var objectKeys = __webpack_require__(53);
  10840. var toIndexedObject = __webpack_require__(29);
  10841. var propertyIsEnumerable = __webpack_require__(63).f;
  10842. // `Object.{ entries, values }` methods implementation
  10843. var createMethod = function (TO_ENTRIES) {
  10844. return function (it) {
  10845. var O = toIndexedObject(it);
  10846. var keys = objectKeys(O);
  10847. var length = keys.length;
  10848. var i = 0;
  10849. var result = [];
  10850. var key;
  10851. while (length > i) {
  10852. key = keys[i++];
  10853. if (!DESCRIPTORS || propertyIsEnumerable.call(O, key)) {
  10854. result.push(TO_ENTRIES ? [key, O[key]] : O[key]);
  10855. }
  10856. }
  10857. return result;
  10858. };
  10859. };
  10860. module.exports = {
  10861. // `Object.entries` method
  10862. // https://tc39.es/ecma262/#sec-object.entries
  10863. entries: createMethod(true),
  10864. // `Object.values` method
  10865. // https://tc39.es/ecma262/#sec-object.values
  10866. values: createMethod(false)
  10867. };
  10868. /***/ }),
  10869. /* 325 */
  10870. /***/ (function(module, exports, __webpack_require__) {
  10871. var parent = __webpack_require__(326);
  10872. module.exports = parent;
  10873. /***/ }),
  10874. /* 326 */
  10875. /***/ (function(module, exports, __webpack_require__) {
  10876. var some = __webpack_require__(327);
  10877. var ArrayPrototype = Array.prototype;
  10878. module.exports = function (it) {
  10879. var own = it.some;
  10880. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.some) ? some : own;
  10881. };
  10882. /***/ }),
  10883. /* 327 */
  10884. /***/ (function(module, exports, __webpack_require__) {
  10885. __webpack_require__(328);
  10886. var entryVirtual = __webpack_require__(14);
  10887. module.exports = entryVirtual('Array').some;
  10888. /***/ }),
  10889. /* 328 */
  10890. /***/ (function(module, exports, __webpack_require__) {
  10891. "use strict";
  10892. var $ = __webpack_require__(5);
  10893. var $some = __webpack_require__(31).some;
  10894. var arrayMethodIsStrict = __webpack_require__(73);
  10895. var STRICT_METHOD = arrayMethodIsStrict('some');
  10896. // `Array.prototype.some` method
  10897. // https://tc39.es/ecma262/#sec-array.prototype.some
  10898. $({ target: 'Array', proto: true, forced: !STRICT_METHOD }, {
  10899. some: function some(callbackfn /* , thisArg */) {
  10900. return $some(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
  10901. }
  10902. });
  10903. /***/ }),
  10904. /* 329 */
  10905. /***/ (function(module, exports, __webpack_require__) {
  10906. "use strict";
  10907. /**
  10908. * @description 所有菜单的构造函数
  10909. * @author wangfupeng
  10910. */
  10911. var _interopRequireDefault = __webpack_require__(0);
  10912. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10913. (0, _defineProperty["default"])(exports, "__esModule", {
  10914. value: true
  10915. });
  10916. var tslib_1 = __webpack_require__(2);
  10917. var index_1 = tslib_1.__importDefault(__webpack_require__(330));
  10918. var index_2 = tslib_1.__importDefault(__webpack_require__(331));
  10919. var index_3 = tslib_1.__importDefault(__webpack_require__(336));
  10920. var index_4 = tslib_1.__importDefault(__webpack_require__(341));
  10921. var index_5 = tslib_1.__importDefault(__webpack_require__(342));
  10922. var index_6 = tslib_1.__importDefault(__webpack_require__(343));
  10923. var index_7 = tslib_1.__importDefault(__webpack_require__(344));
  10924. var font_size_1 = tslib_1.__importDefault(__webpack_require__(346));
  10925. var index_8 = tslib_1.__importDefault(__webpack_require__(348));
  10926. var index_9 = tslib_1.__importDefault(__webpack_require__(349));
  10927. var index_10 = tslib_1.__importDefault(__webpack_require__(352));
  10928. var index_11 = tslib_1.__importDefault(__webpack_require__(353));
  10929. var index_12 = tslib_1.__importDefault(__webpack_require__(354));
  10930. var index_13 = tslib_1.__importDefault(__webpack_require__(365));
  10931. var index_14 = tslib_1.__importDefault(__webpack_require__(380));
  10932. var index_15 = tslib_1.__importDefault(__webpack_require__(384));
  10933. var index_16 = tslib_1.__importDefault(__webpack_require__(142));
  10934. var index_17 = tslib_1.__importDefault(__webpack_require__(393));
  10935. var index_18 = tslib_1.__importDefault(__webpack_require__(395));
  10936. var index_19 = tslib_1.__importDefault(__webpack_require__(396));
  10937. var index_20 = tslib_1.__importDefault(__webpack_require__(397));
  10938. var code_1 = tslib_1.__importDefault(__webpack_require__(417));
  10939. var index_21 = tslib_1.__importDefault(__webpack_require__(422));
  10940. var todo_1 = tslib_1.__importDefault(__webpack_require__(425));
  10941. exports["default"] = {
  10942. bold: index_1["default"],
  10943. head: index_2["default"],
  10944. italic: index_4["default"],
  10945. link: index_3["default"],
  10946. underline: index_5["default"],
  10947. strikeThrough: index_6["default"],
  10948. fontName: index_7["default"],
  10949. fontSize: font_size_1["default"],
  10950. justify: index_8["default"],
  10951. quote: index_9["default"],
  10952. backColor: index_10["default"],
  10953. foreColor: index_11["default"],
  10954. video: index_12["default"],
  10955. image: index_13["default"],
  10956. indent: index_14["default"],
  10957. emoticon: index_15["default"],
  10958. list: index_16["default"],
  10959. lineHeight: index_17["default"],
  10960. undo: index_18["default"],
  10961. redo: index_19["default"],
  10962. table: index_20["default"],
  10963. code: code_1["default"],
  10964. splitLine: index_21["default"],
  10965. todo: todo_1["default"]
  10966. };
  10967. /***/ }),
  10968. /* 330 */
  10969. /***/ (function(module, exports, __webpack_require__) {
  10970. "use strict";
  10971. /**
  10972. * @description 加粗
  10973. * @author wangfupeng
  10974. */
  10975. var _interopRequireDefault = __webpack_require__(0);
  10976. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  10977. (0, _defineProperty["default"])(exports, "__esModule", {
  10978. value: true
  10979. });
  10980. var tslib_1 = __webpack_require__(2);
  10981. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  10982. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  10983. var Bold = function (_super) {
  10984. tslib_1.__extends(Bold, _super);
  10985. function Bold(editor) {
  10986. var _this = this;
  10987. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u52A0\u7C97\">\n <i class=\"w-e-icon-bold\"></i>\n </div>");
  10988. _this = _super.call(this, $elem, editor) || this;
  10989. return _this;
  10990. }
  10991. /**
  10992. * 点击事件
  10993. */
  10994. Bold.prototype.clickHandler = function () {
  10995. var editor = this.editor;
  10996. var isSelectEmpty = editor.selection.isSelectionEmpty();
  10997. if (isSelectEmpty) {
  10998. // 选区范围是空的,插入并选中一个“空白”
  10999. editor.selection.createEmptyRange();
  11000. } // 执行 bold 命令
  11001. editor.cmd["do"]('bold');
  11002. if (isSelectEmpty) {
  11003. // 需要将选区范围折叠起来
  11004. editor.selection.collapseRange();
  11005. editor.selection.restoreSelection();
  11006. }
  11007. };
  11008. /**
  11009. * 尝试修改菜单激活状态
  11010. */
  11011. Bold.prototype.tryChangeActive = function () {
  11012. var editor = this.editor;
  11013. if (editor.cmd.queryCommandState('bold')) {
  11014. this.active();
  11015. } else {
  11016. this.unActive();
  11017. }
  11018. };
  11019. return Bold;
  11020. }(BtnMenu_1["default"]);
  11021. exports["default"] = Bold;
  11022. /***/ }),
  11023. /* 331 */
  11024. /***/ (function(module, exports, __webpack_require__) {
  11025. "use strict";
  11026. /**
  11027. * @description 标题
  11028. * @author wangfupeng
  11029. */
  11030. var _interopRequireDefault = __webpack_require__(0);
  11031. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11032. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  11033. var _find = _interopRequireDefault(__webpack_require__(32));
  11034. var _forEach = _interopRequireDefault(__webpack_require__(4));
  11035. var _stringify = _interopRequireDefault(__webpack_require__(332));
  11036. var _includes = _interopRequireDefault(__webpack_require__(46));
  11037. (0, _defineProperty["default"])(exports, "__esModule", {
  11038. value: true
  11039. });
  11040. var tslib_1 = __webpack_require__(2);
  11041. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  11042. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11043. var util_1 = __webpack_require__(6);
  11044. var const_1 = __webpack_require__(7);
  11045. var Head = function (_super) {
  11046. tslib_1.__extends(Head, _super);
  11047. function Head(editor) {
  11048. var _this = this;
  11049. var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="标题"><i class="w-e-icon-header"></i></div>');
  11050. var dropListConf = {
  11051. width: 100,
  11052. title: '设置标题',
  11053. type: 'list',
  11054. list: [{
  11055. $elem: dom_core_1["default"]('<h1>H1</h1>'),
  11056. value: '<h1>'
  11057. }, {
  11058. $elem: dom_core_1["default"]('<h2>H2</h2>'),
  11059. value: '<h2>'
  11060. }, {
  11061. $elem: dom_core_1["default"]('<h3>H3</h3>'),
  11062. value: '<h3>'
  11063. }, {
  11064. $elem: dom_core_1["default"]('<h4>H4</h4>'),
  11065. value: '<h4>'
  11066. }, {
  11067. $elem: dom_core_1["default"]('<h5>H5</h5>'),
  11068. value: '<h5>'
  11069. }, {
  11070. $elem: dom_core_1["default"]("<p>" + editor.i18next.t('menus.dropListMenu.head.正文') + "</p>"),
  11071. value: '<p>'
  11072. }],
  11073. clickHandler: function clickHandler(value) {
  11074. // 注意 this 是指向当前的 Head 对象
  11075. _this.command(value);
  11076. }
  11077. };
  11078. _this = _super.call(this, $elem, editor, dropListConf) || this;
  11079. var onCatalogChange = editor.config.onCatalogChange; // 未配置目录change监听回调时不运行下面操作
  11080. if (onCatalogChange) {
  11081. _this.oldCatalogs = [];
  11082. _this.addListenerCatalog(); // 监听文本框编辑时的大纲信息
  11083. _this.getCatalogs(); // 初始有值的情况获取一遍大纲信息
  11084. }
  11085. return _this;
  11086. }
  11087. /**
  11088. * 执行命令
  11089. * @param value value
  11090. */
  11091. Head.prototype.command = function (value) {
  11092. var editor = this.editor;
  11093. var $selectionElem = editor.selection.getSelectionContainerElem();
  11094. if ($selectionElem && editor.$textElem.equal($selectionElem)) {
  11095. // 不能选中多行来设置标题,否则会出现问题
  11096. // 例如选中的是 <p>xxx</p><p>yyy</p> 来设置标题,设置之后会成为 <h1>xxx<br>yyy</h1> 不符合预期
  11097. this.setMultilineHead(value);
  11098. } else {
  11099. var _context;
  11100. // 选中内容包含序列,code,表格,分割线时不处理
  11101. if ((0, _indexOf["default"])(_context = ['OL', 'UL', 'LI', 'TABLE', 'TH', 'TR', 'CODE', 'HR']).call(_context, dom_core_1["default"]($selectionElem).getNodeName()) > -1) {
  11102. return;
  11103. }
  11104. editor.cmd["do"]('formatBlock', value);
  11105. } // 标题设置成功且不是<p>正文标签就配置大纲id
  11106. value !== '<p>' && this.addUidForSelectionElem();
  11107. };
  11108. /**
  11109. * 为标题设置大纲
  11110. */
  11111. Head.prototype.addUidForSelectionElem = function () {
  11112. var editor = this.editor;
  11113. var tag = editor.selection.getSelectionContainerElem();
  11114. var id = util_1.getRandomCode(); // 默认五位数id
  11115. dom_core_1["default"](tag).attr('id', id);
  11116. };
  11117. /**
  11118. * 监听change事件来返回大纲信息
  11119. */
  11120. Head.prototype.addListenerCatalog = function () {
  11121. var _this = this;
  11122. var editor = this.editor;
  11123. editor.txt.eventHooks.changeEvents.push(function () {
  11124. _this.getCatalogs();
  11125. });
  11126. };
  11127. /**
  11128. * 获取大纲数组
  11129. */
  11130. Head.prototype.getCatalogs = function () {
  11131. var editor = this.editor;
  11132. var $textElem = this.editor.$textElem;
  11133. var onCatalogChange = editor.config.onCatalogChange;
  11134. var elems = (0, _find["default"])($textElem).call($textElem, 'h1,h2,h3,h4,h5');
  11135. var catalogs = [];
  11136. (0, _forEach["default"])(elems).call(elems, function (elem, index) {
  11137. var $elem = dom_core_1["default"](elem);
  11138. var id = $elem.attr('id');
  11139. var tag = $elem.getNodeName();
  11140. var text = $elem.text();
  11141. if (!id) {
  11142. id = util_1.getRandomCode();
  11143. $elem.attr('id', id);
  11144. } // 标题为空的情况不生成目录
  11145. if (!text) return;
  11146. catalogs.push({
  11147. tag: tag,
  11148. id: id,
  11149. text: text
  11150. });
  11151. }); // 旧目录和新目录对比是否相等,不相等则运行回调并保存新目录到旧目录变量,以方便下一次对比
  11152. if ((0, _stringify["default"])(this.oldCatalogs) !== (0, _stringify["default"])(catalogs)) {
  11153. this.oldCatalogs = catalogs;
  11154. onCatalogChange && onCatalogChange(catalogs);
  11155. }
  11156. };
  11157. /**
  11158. * 设置选中的多行标题
  11159. * @param value 需要执行的命令值
  11160. */
  11161. Head.prototype.setMultilineHead = function (value) {
  11162. var _this = this;
  11163. var _a, _b;
  11164. var editor = this.editor;
  11165. var $selection = editor.selection; // 初始选区的父节点
  11166. var containerElem = (_a = $selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0]; // 白名单:用户选区里如果有该元素则不进行转换
  11167. var _WHITE_LIST = ['IMG', 'VIDEO', 'TABLE', 'TH', 'TR', 'UL', 'OL', 'PRE', 'HR', 'BLOCKQUOTE']; // 获取选中的首、尾元素
  11168. var startElem = dom_core_1["default"]($selection.getSelectionStartElem());
  11169. var endElem = dom_core_1["default"]($selection.getSelectionEndElem()); // 判断用户选中元素是否为最后一个空元素,如果是将endElem指向上一个元素
  11170. if (endElem.elems[0].outerHTML === dom_core_1["default"](const_1.EMPTY_P).elems[0].outerHTML && !endElem.elems[0].nextSibling) {
  11171. endElem = endElem.prev();
  11172. } // 存放选中的所有元素
  11173. var cacheDomList = [];
  11174. cacheDomList.push(startElem.getNodeTop(editor)); // 选中首尾元素在父级下的坐标
  11175. var indexList = []; // 选区共同祖先元素的所有子节点
  11176. var childList = (_b = $selection.getRange()) === null || _b === void 0 ? void 0 : _b.commonAncestorContainer.childNodes; // 找到选区的首尾元素的下标,方便最后恢复选区
  11177. childList === null || childList === void 0 ? void 0 : (0, _forEach["default"])(childList).call(childList, function (item, index) {
  11178. if (item === cacheDomList[0].getNode()) {
  11179. indexList.push(index);
  11180. }
  11181. if (item === endElem.getNodeTop(editor).getNode()) {
  11182. indexList.push(index);
  11183. }
  11184. }); // 找到首尾元素中间所包含的所有dom
  11185. var i = 0; // 数组中的当前元素不等于选区最后一个节点时循环寻找中间节点
  11186. while (cacheDomList[i].getNode() !== endElem.getNodeTop(editor).getNode()) {
  11187. // 严谨性判断,是否元素为空
  11188. if (!cacheDomList[i].elems[0]) return;
  11189. var d = dom_core_1["default"](cacheDomList[i].next().getNode());
  11190. cacheDomList.push(d);
  11191. i++;
  11192. } // 将选区内的所有子节点进行遍历生成对应的标签
  11193. cacheDomList === null || cacheDomList === void 0 ? void 0 : (0, _forEach["default"])(cacheDomList).call(cacheDomList, function (_node, index) {
  11194. // 判断元素是否含有白名单内的标签元素
  11195. if (!_this.hasTag(_node, _WHITE_LIST)) {
  11196. var $h = dom_core_1["default"](value);
  11197. var $parentNode = _node.parent().getNode(); // 设置标签内容
  11198. $h.html("" + _node.html()); // 插入生成的新标签
  11199. $parentNode.insertBefore($h.getNode(), _node.getNode()); // 移除原有的标签
  11200. _node.remove();
  11201. }
  11202. }); // 重新设置选区起始位置,保留拖蓝区域
  11203. $selection.createRangeByElems(containerElem.children[indexList[0]], containerElem.children[indexList[1]]);
  11204. };
  11205. /**
  11206. * 是否含有某元素
  11207. * @param elem 需要检查的元素
  11208. * @param whiteList 白名单
  11209. */
  11210. Head.prototype.hasTag = function (elem, whiteList) {
  11211. var _this = this;
  11212. var _a;
  11213. if (!elem) return false;
  11214. if ((0, _includes["default"])(whiteList).call(whiteList, elem === null || elem === void 0 ? void 0 : elem.getNodeName())) return true;
  11215. var _flag = false;
  11216. (_a = elem.children()) === null || _a === void 0 ? void 0 : (0, _forEach["default"])(_a).call(_a, function (child) {
  11217. _flag = _this.hasTag(dom_core_1["default"](child), whiteList);
  11218. });
  11219. return _flag;
  11220. };
  11221. /**
  11222. * 尝试改变菜单激活(高亮)状态
  11223. */
  11224. Head.prototype.tryChangeActive = function () {
  11225. var editor = this.editor;
  11226. var reg = /^h/i;
  11227. var cmdValue = editor.cmd.queryCommandValue('formatBlock');
  11228. if (reg.test(cmdValue)) {
  11229. this.active();
  11230. } else {
  11231. this.unActive();
  11232. }
  11233. };
  11234. return Head;
  11235. }(DropListMenu_1["default"]);
  11236. exports["default"] = Head;
  11237. /***/ }),
  11238. /* 332 */
  11239. /***/ (function(module, exports, __webpack_require__) {
  11240. module.exports = __webpack_require__(333);
  11241. /***/ }),
  11242. /* 333 */
  11243. /***/ (function(module, exports, __webpack_require__) {
  11244. var parent = __webpack_require__(334);
  11245. module.exports = parent;
  11246. /***/ }),
  11247. /* 334 */
  11248. /***/ (function(module, exports, __webpack_require__) {
  11249. __webpack_require__(335);
  11250. var core = __webpack_require__(11);
  11251. // eslint-disable-next-line es/no-json -- safe
  11252. if (!core.JSON) core.JSON = { stringify: JSON.stringify };
  11253. // eslint-disable-next-line no-unused-vars -- required for `.length`
  11254. module.exports = function stringify(it, replacer, space) {
  11255. return core.JSON.stringify.apply(null, arguments);
  11256. };
  11257. /***/ }),
  11258. /* 335 */
  11259. /***/ (function(module, exports, __webpack_require__) {
  11260. var $ = __webpack_require__(5);
  11261. var getBuiltIn = __webpack_require__(25);
  11262. var fails = __webpack_require__(12);
  11263. var $stringify = getBuiltIn('JSON', 'stringify');
  11264. var re = /[\uD800-\uDFFF]/g;
  11265. var low = /^[\uD800-\uDBFF]$/;
  11266. var hi = /^[\uDC00-\uDFFF]$/;
  11267. var fix = function (match, offset, string) {
  11268. var prev = string.charAt(offset - 1);
  11269. var next = string.charAt(offset + 1);
  11270. if ((low.test(match) && !hi.test(next)) || (hi.test(match) && !low.test(prev))) {
  11271. return '\\u' + match.charCodeAt(0).toString(16);
  11272. } return match;
  11273. };
  11274. var FORCED = fails(function () {
  11275. return $stringify('\uDF06\uD834') !== '"\\udf06\\ud834"'
  11276. || $stringify('\uDEAD') !== '"\\udead"';
  11277. });
  11278. if ($stringify) {
  11279. // `JSON.stringify` method
  11280. // https://tc39.es/ecma262/#sec-json.stringify
  11281. // https://github.com/tc39/proposal-well-formed-stringify
  11282. $({ target: 'JSON', stat: true, forced: FORCED }, {
  11283. // eslint-disable-next-line no-unused-vars -- required for `.length`
  11284. stringify: function stringify(it, replacer, space) {
  11285. var result = $stringify.apply(null, arguments);
  11286. return typeof result == 'string' ? result.replace(re, fix) : result;
  11287. }
  11288. });
  11289. }
  11290. /***/ }),
  11291. /* 336 */
  11292. /***/ (function(module, exports, __webpack_require__) {
  11293. "use strict";
  11294. /**
  11295. * @description 链接 菜单
  11296. * @author wangfupeng
  11297. */
  11298. var _interopRequireDefault = __webpack_require__(0);
  11299. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11300. var _trim = _interopRequireDefault(__webpack_require__(16));
  11301. (0, _defineProperty["default"])(exports, "__esModule", {
  11302. value: true
  11303. });
  11304. var tslib_1 = __webpack_require__(2);
  11305. var PanelMenu_1 = tslib_1.__importDefault(__webpack_require__(36));
  11306. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11307. var create_panel_conf_1 = tslib_1.__importDefault(__webpack_require__(337));
  11308. var is_active_1 = tslib_1.__importDefault(__webpack_require__(139));
  11309. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  11310. var index_1 = tslib_1.__importDefault(__webpack_require__(339));
  11311. var const_1 = __webpack_require__(7);
  11312. var Link = function (_super) {
  11313. tslib_1.__extends(Link, _super);
  11314. function Link(editor) {
  11315. var _this = this;
  11316. var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="链接"><i class="w-e-icon-link"></i></div>');
  11317. _this = _super.call(this, $elem, editor) || this; // 绑定事件,如点击链接时,可以查看链接
  11318. index_1["default"](editor);
  11319. return _this;
  11320. }
  11321. /**
  11322. * 菜单点击事件
  11323. */
  11324. Link.prototype.clickHandler = function () {
  11325. var editor = this.editor;
  11326. var $linkElem;
  11327. /**
  11328. @author:Gavin
  11329. @description
  11330. 解决当全选删除编辑区内容时,点击链接没反应的问题(因为选区有问题)
  11331. **/
  11332. var $selectionElem = editor.selection.getSelectionContainerElem();
  11333. var $textElem = editor.$textElem;
  11334. var html = $textElem.html();
  11335. var $txtHtml = (0, _trim["default"])(html).call(html);
  11336. if ($txtHtml === const_1.EMPTY_P) {
  11337. var $emptyChild = $textElem.children(); // 调整选区
  11338. editor.selection.createRangeByElem($emptyChild, true, true); // 重新获取选区
  11339. $selectionElem = editor.selection.getSelectionContainerElem();
  11340. } // 判断是否是多行 多行则退出 否则会出现问题
  11341. if ($selectionElem && editor.$textElem.equal($selectionElem)) {
  11342. return;
  11343. }
  11344. if (this.isActive) {
  11345. // 菜单被激活,说明选区在链接里
  11346. $linkElem = editor.selection.getSelectionContainerElem();
  11347. if (!$linkElem) {
  11348. return;
  11349. } // 弹出 panel
  11350. this.createPanel($linkElem.text(), $linkElem.attr('href'));
  11351. } else {
  11352. // 菜单未被激活,说明选区不在链接里
  11353. if (editor.selection.isSelectionEmpty()) {
  11354. // 选区是空的,未选中内容
  11355. this.createPanel('', '');
  11356. } else {
  11357. // 选中内容了
  11358. this.createPanel(editor.selection.getSelectionText(), '');
  11359. }
  11360. }
  11361. };
  11362. /**
  11363. * 创建 panel
  11364. * @param text 文本
  11365. * @param link 链接
  11366. */
  11367. Link.prototype.createPanel = function (text, link) {
  11368. var conf = create_panel_conf_1["default"](this.editor, text, link);
  11369. var panel = new Panel_1["default"](this, conf);
  11370. panel.create();
  11371. };
  11372. /**
  11373. * 尝试修改菜单 active 状态
  11374. */
  11375. Link.prototype.tryChangeActive = function () {
  11376. var editor = this.editor;
  11377. if (is_active_1["default"](editor)) {
  11378. this.active();
  11379. } else {
  11380. this.unActive();
  11381. }
  11382. };
  11383. return Link;
  11384. }(PanelMenu_1["default"]);
  11385. exports["default"] = Link;
  11386. /***/ }),
  11387. /* 337 */
  11388. /***/ (function(module, exports, __webpack_require__) {
  11389. "use strict";
  11390. /**
  11391. * @description link 菜单 panel tab 配置
  11392. * @author wangfupeng
  11393. */
  11394. var _interopRequireDefault = __webpack_require__(0);
  11395. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11396. var _trim = _interopRequireDefault(__webpack_require__(16));
  11397. (0, _defineProperty["default"])(exports, "__esModule", {
  11398. value: true
  11399. });
  11400. var tslib_1 = __webpack_require__(2);
  11401. var util_1 = __webpack_require__(6);
  11402. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11403. var is_active_1 = tslib_1.__importDefault(__webpack_require__(139));
  11404. var util_2 = __webpack_require__(338);
  11405. function default_1(editor, text, link) {
  11406. // panel 中需要用到的id
  11407. var inputLinkId = util_1.getRandom('input-link');
  11408. var inputTextId = util_1.getRandom('input-text');
  11409. var btnOkId = util_1.getRandom('btn-ok');
  11410. var btnDelId = util_1.getRandom('btn-del'); // 是否显示“取消链接”
  11411. var delBtnDisplay = is_active_1["default"](editor) ? 'inline-block' : 'none';
  11412. var $selectedLink;
  11413. /**
  11414. * 选中整个链接元素
  11415. */
  11416. function selectLinkElem() {
  11417. if (!is_active_1["default"](editor)) return;
  11418. var $linkElem = editor.selection.getSelectionContainerElem();
  11419. if (!$linkElem) return;
  11420. editor.selection.createRangeByElem($linkElem);
  11421. editor.selection.restoreSelection();
  11422. $selectedLink = $linkElem; // 赋值给函数内全局变量
  11423. }
  11424. /**
  11425. * 插入链接
  11426. * @param text 文字
  11427. * @param link 链接
  11428. */
  11429. function insertLink(text, link) {
  11430. // fix: 修复列表下无法设置超链接的问题(替换选中文字中的标签)
  11431. var subStr = new RegExp(/(<\/*ul>)|(<\/*li>)|(<\/*ol>)/g);
  11432. text = text.replace(subStr, '');
  11433. if (is_active_1["default"](editor)) {
  11434. // 选区处于链接中,则选中整个菜单,再执行 insertHTML
  11435. selectLinkElem();
  11436. editor.cmd["do"]('insertHTML', "<a href=\"" + link + "\" target=\"_blank\">" + text + "</a>");
  11437. } else {
  11438. // 选区未处于链接中,直接插入即可
  11439. editor.cmd["do"]('insertHTML', "<a href=\"" + link + "\" target=\"_blank\">" + text + "</a>");
  11440. }
  11441. }
  11442. /**
  11443. * 取消链接
  11444. */
  11445. function delLink() {
  11446. if (!is_active_1["default"](editor)) {
  11447. return;
  11448. } // 选中整个链接
  11449. selectLinkElem(); // 用文本替换链接
  11450. var selectionText = $selectedLink.text();
  11451. editor.cmd["do"]('insertHTML', '<span>' + selectionText + '</span>');
  11452. }
  11453. /**
  11454. * 校验链接是否合法
  11455. * @param link 链接
  11456. */
  11457. function checkLink(text, link) {
  11458. //查看开发者自定义配置的返回值
  11459. var check = editor.config.linkCheck(text, link);
  11460. if (check === undefined) {//用户未能通过开发者的校验,且开发者不希望编辑器提示用户
  11461. } else if (check === true) {
  11462. //用户通过了开发者的校验
  11463. return true;
  11464. } else {
  11465. //用户未能通过开发者的校验,开发者希望我们提示这一字符串
  11466. editor.config.customAlert(check, 'warning');
  11467. }
  11468. return false;
  11469. }
  11470. var conf = {
  11471. width: 300,
  11472. height: 0,
  11473. // panel 中可包含多个 tab
  11474. tabs: [{
  11475. // tab 的标题
  11476. title: editor.i18next.t('menus.panelMenus.link.链接'),
  11477. // 模板
  11478. tpl: "<div>\n <input\n id=\"" + inputTextId + "\"\n type=\"text\"\n class=\"block\"\n value=\"" + text + "\"\n placeholder=\"" + editor.i18next.t('menus.panelMenus.link.链接文字') + "\"/>\n </td>\n <input\n id=\"" + inputLinkId + "\"\n type=\"text\"\n class=\"block\"\n value=\"" + link + "\"\n placeholder=\"" + editor.i18next.t('如') + " https://...\"/>\n </td>\n <div class=\"w-e-button-container\">\n <button type=\"button\" id=\"" + btnOkId + "\" class=\"right\">\n " + editor.i18next.t('插入') + "\n </button>\n <button type=\"button\" id=\"" + btnDelId + "\" class=\"gray right\" style=\"display:" + delBtnDisplay + "\">\n " + editor.i18next.t('menus.panelMenus.link.取消链接') + "\n </button>\n </div>\n </div>",
  11479. // 事件绑定
  11480. events: [// 插入链接
  11481. {
  11482. selector: '#' + btnOkId,
  11483. type: 'click',
  11484. fn: function fn() {
  11485. var _context, _context2;
  11486. var _a, _b; // 获取选取
  11487. editor.selection.restoreSelection();
  11488. var topNode = editor.selection.getSelectionRangeTopNodes()[0].getNode();
  11489. var selection = window.getSelection(); // 执行插入链接
  11490. var $link = dom_core_1["default"]('#' + inputLinkId);
  11491. var $text = dom_core_1["default"]('#' + inputTextId);
  11492. var link = (0, _trim["default"])(_context = $link.val()).call(_context);
  11493. var text = (0, _trim["default"])(_context2 = $text.val()).call(_context2);
  11494. var html = '';
  11495. if (selection && !(selection === null || selection === void 0 ? void 0 : selection.isCollapsed)) html = (_a = util_2.insertHtml(selection, topNode)) === null || _a === void 0 ? void 0 : (0, _trim["default"])(_a).call(_a); // 去除html的tag标签
  11496. var htmlText = html === null || html === void 0 ? void 0 : html.replace(/<.*?>/g, '');
  11497. var htmlTextLen = (_b = htmlText === null || htmlText === void 0 ? void 0 : htmlText.length) !== null && _b !== void 0 ? _b : 0; // 当input中的text的长度大于等于选区的文字时
  11498. // 需要判断两者相同的长度的text内容是否相同
  11499. // 相同则只需把多余的部分添加上去即可,否则使用input中的内容
  11500. if (htmlTextLen <= text.length) {
  11501. var startText = text.substring(0, htmlTextLen);
  11502. var endText = text.substring(htmlTextLen);
  11503. if (htmlText === startText) {
  11504. text = html + endText;
  11505. }
  11506. } // 链接为空,则不插入
  11507. if (!link) return; // 文本为空,则用链接代替
  11508. if (!text) text = link; // 校验链接是否满足用户的规则,若不满足则不插入
  11509. if (!checkLink(text, link)) return;
  11510. insertLink(text, link); // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
  11511. return true;
  11512. },
  11513. bindEnter: true
  11514. }, // 取消链接
  11515. {
  11516. selector: '#' + btnDelId,
  11517. type: 'click',
  11518. fn: function fn() {
  11519. // 执行取消链接
  11520. delLink(); // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
  11521. return true;
  11522. }
  11523. }]
  11524. } // tab end
  11525. ] // tabs end
  11526. };
  11527. return conf;
  11528. }
  11529. exports["default"] = default_1;
  11530. /***/ }),
  11531. /* 338 */
  11532. /***/ (function(module, exports, __webpack_require__) {
  11533. "use strict";
  11534. var _interopRequireDefault = __webpack_require__(0);
  11535. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11536. var _forEach = _interopRequireDefault(__webpack_require__(4));
  11537. (0, _defineProperty["default"])(exports, "__esModule", {
  11538. value: true
  11539. });
  11540. exports.insertHtml = exports.createPartHtml = exports.makeHtmlString = exports.getTopNode = void 0;
  11541. /**
  11542. * 获取除了包裹在整行区域的顶级Node
  11543. * @param node 最外层node下的某个childNode
  11544. * @param topText 最外层node中文本内容
  11545. */
  11546. function getTopNode(node, topText) {
  11547. var pointerNode = node;
  11548. var topNode = node;
  11549. do {
  11550. if (pointerNode.textContent === topText) break;
  11551. topNode = pointerNode;
  11552. if (pointerNode.parentNode) {
  11553. pointerNode = pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.parentNode;
  11554. }
  11555. } while ((pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.nodeName) !== 'P');
  11556. return topNode;
  11557. }
  11558. exports.getTopNode = getTopNode;
  11559. /**
  11560. * 生成html的string形式
  11561. * @param tagName 标签名
  11562. * @param content 需要包裹的内容
  11563. */
  11564. function makeHtmlString(node, content) {
  11565. var tagName = node.nodeName;
  11566. var attr = '';
  11567. if (node.nodeType === 3 || /^(h|H)[1-6]$/.test(tagName)) {
  11568. return content;
  11569. }
  11570. if (node.nodeType === 1) {
  11571. var style = node.getAttribute('style');
  11572. var face = node.getAttribute('face');
  11573. var color = node.getAttribute('color');
  11574. if (style) attr = attr + (" style=\"" + style + "\"");
  11575. if (face) attr = attr + (" face=\"" + face + "\"");
  11576. if (color) attr = attr + (" color=\"" + color + "\"");
  11577. }
  11578. tagName = tagName.toLowerCase();
  11579. return "<" + tagName + attr + ">" + content + "</" + tagName + ">";
  11580. }
  11581. exports.makeHtmlString = makeHtmlString;
  11582. /**
  11583. * 生成开始或者结束位置的html字符片段
  11584. * @param topText 选区所在的行的文本内容
  11585. * @param node 选区给出的node节点
  11586. * @param startPos node文本内容选取的开始位置
  11587. * @param endPos node文本内容选取的结束位置
  11588. */
  11589. function createPartHtml(topText, node, startPos, endPost) {
  11590. var _a;
  11591. var selectionContent = (_a = node.textContent) === null || _a === void 0 ? void 0 : _a.substring(startPos, endPost);
  11592. var pointerNode = node;
  11593. var content = '';
  11594. do {
  11595. content = makeHtmlString(pointerNode, selectionContent !== null && selectionContent !== void 0 ? selectionContent : '');
  11596. selectionContent = content;
  11597. pointerNode = pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.parentElement;
  11598. } while (pointerNode && pointerNode.textContent !== topText);
  11599. return content;
  11600. }
  11601. exports.createPartHtml = createPartHtml;
  11602. /**
  11603. * 生成需要插入的html内容的字符串形式
  11604. * @param selection 选区对象
  11605. * @param topNode 选区所在行的顶级node节点
  11606. */
  11607. function insertHtml(selection, topNode) {
  11608. var _a, _b, _c, _d, _e;
  11609. var anchorNode = selection.anchorNode,
  11610. focusNode = selection.focusNode,
  11611. anchorPos = selection.anchorOffset,
  11612. focusPos = selection.focusOffset;
  11613. var topText = (_a = topNode.textContent) !== null && _a !== void 0 ? _a : '';
  11614. var TagArr = getContainerTag(topNode);
  11615. var content = '';
  11616. var startContent = '';
  11617. var middleContent = '';
  11618. var endContent = '';
  11619. var startNode = anchorNode;
  11620. var endNode = focusNode; // 用来保存 anchorNode的非p最外层节点
  11621. var pointerNode = anchorNode; // 节点是同一个的处理
  11622. if (anchorNode === null || anchorNode === void 0 ? void 0 : anchorNode.isEqualNode(focusNode !== null && focusNode !== void 0 ? focusNode : null)) {
  11623. var innerContent = createPartHtml(topText, anchorNode, anchorPos, focusPos);
  11624. innerContent = addContainer(TagArr, innerContent);
  11625. return innerContent;
  11626. } // 选中开始位置节点的处理
  11627. if (anchorNode) startContent = createPartHtml(topText, anchorNode, anchorPos !== null && anchorPos !== void 0 ? anchorPos : 0); // 结束位置节点的处理
  11628. if (focusNode) endContent = createPartHtml(topText, focusNode, 0, focusPos); // 将指针节点位置放置到开始的节点
  11629. if (anchorNode) {
  11630. // 获取start的非p顶级node
  11631. startNode = getTopNode(anchorNode, topText);
  11632. }
  11633. if (focusNode) {
  11634. // 获取end的非p顶级node
  11635. endNode = getTopNode(focusNode, topText);
  11636. } // 处于开始和结束节点位置之间的节点的处理
  11637. pointerNode = (_b = startNode === null || startNode === void 0 ? void 0 : startNode.nextSibling) !== null && _b !== void 0 ? _b : anchorNode;
  11638. while (!(pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.isEqualNode(endNode !== null && endNode !== void 0 ? endNode : null))) {
  11639. var pointerNodeName = pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.nodeName;
  11640. if (pointerNodeName === '#text') {
  11641. middleContent = middleContent + (pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.textContent);
  11642. } else {
  11643. var htmlString = (_d = (_c = pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.firstChild) === null || _c === void 0 ? void 0 : _c.parentElement) === null || _d === void 0 ? void 0 : _d.innerHTML;
  11644. if (pointerNode) middleContent = middleContent + makeHtmlString(pointerNode, htmlString !== null && htmlString !== void 0 ? htmlString : '');
  11645. } // 解决文字和图片同一行时会触发无限循环, 到不了endNode === pointerNode条件
  11646. var nextPointNode = (_e = pointerNode === null || pointerNode === void 0 ? void 0 : pointerNode.nextSibling) !== null && _e !== void 0 ? _e : pointerNode;
  11647. if (nextPointNode === pointerNode) break;
  11648. pointerNode = nextPointNode;
  11649. }
  11650. content = "" + startContent + middleContent + endContent; // 增加最外层包裹标签
  11651. content = addContainer(TagArr, content);
  11652. return content;
  11653. }
  11654. exports.insertHtml = insertHtml;
  11655. /**
  11656. * 获取包裹在最外层的非p Node tagName 数组
  11657. * @param node 选区所在行的node节点
  11658. */
  11659. function getContainerTag(node) {
  11660. var _a;
  11661. var topText = (_a = node.textContent) !== null && _a !== void 0 ? _a : '';
  11662. var tagArr = [];
  11663. while ((node === null || node === void 0 ? void 0 : node.textContent) === topText) {
  11664. if (node.nodeName !== 'P') {
  11665. tagArr.push(node);
  11666. }
  11667. node = node.childNodes[0];
  11668. }
  11669. return tagArr;
  11670. }
  11671. /**
  11672. * 为内容增加包裹标签
  11673. * @param tagArr 最外层包裹的tag数组,索引越小tag越在外面
  11674. * @param content tag要包裹的内容
  11675. */
  11676. function addContainer(tagArr, content) {
  11677. (0, _forEach["default"])(tagArr).call(tagArr, function (v) {
  11678. content = makeHtmlString(v, content);
  11679. });
  11680. return content;
  11681. }
  11682. /***/ }),
  11683. /* 339 */
  11684. /***/ (function(module, exports, __webpack_require__) {
  11685. "use strict";
  11686. /**
  11687. * @description 绑定链接元素的事件,入口
  11688. * @author wangfupeng
  11689. */
  11690. var _interopRequireDefault = __webpack_require__(0);
  11691. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11692. (0, _defineProperty["default"])(exports, "__esModule", {
  11693. value: true
  11694. });
  11695. var tslib_1 = __webpack_require__(2);
  11696. var tooltip_event_1 = tslib_1.__importDefault(__webpack_require__(340));
  11697. /**
  11698. * 绑定事件
  11699. * @param editor 编辑器实例
  11700. */
  11701. function bindEvent(editor) {
  11702. // tooltip 事件
  11703. tooltip_event_1["default"](editor);
  11704. }
  11705. exports["default"] = bindEvent;
  11706. /***/ }),
  11707. /* 340 */
  11708. /***/ (function(module, exports, __webpack_require__) {
  11709. "use strict";
  11710. /**
  11711. * @description tooltip 事件
  11712. * @author wangfupeng
  11713. */
  11714. var _interopRequireDefault = __webpack_require__(0);
  11715. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11716. (0, _defineProperty["default"])(exports, "__esModule", {
  11717. value: true
  11718. });
  11719. var tslib_1 = __webpack_require__(2);
  11720. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11721. var Tooltip_1 = tslib_1.__importDefault(__webpack_require__(37));
  11722. /**
  11723. * 生成 Tooltip 的显示隐藏函数
  11724. */
  11725. function createShowHideFn(editor) {
  11726. var tooltip;
  11727. /**
  11728. * 显示 tooltip
  11729. * @param $link 链接元素
  11730. */
  11731. function showLinkTooltip($link) {
  11732. var conf = [{
  11733. $elem: dom_core_1["default"]("<span>" + editor.i18next.t('menus.panelMenus.link.查看链接') + "</span>"),
  11734. onClick: function onClick(editor, $link) {
  11735. var link = $link.attr('href');
  11736. window.open(link, '_target'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  11737. return true;
  11738. }
  11739. }, {
  11740. $elem: dom_core_1["default"]("<span>" + editor.i18next.t('menus.panelMenus.link.取消链接') + "</span>"),
  11741. onClick: function onClick(editor, $link) {
  11742. var _a, _b; // 选中链接元素
  11743. editor.selection.createRangeByElem($link);
  11744. editor.selection.restoreSelection();
  11745. var $childNodes = $link.childNodes(); // 如果链接是图片
  11746. if (($childNodes === null || $childNodes === void 0 ? void 0 : $childNodes.getNodeName()) === 'IMG') {
  11747. // 获取选中的图片
  11748. var $selectIMG = (_b = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.children()) === null || _b === void 0 ? void 0 : _b.elems[0].children[0]; // 插入图片
  11749. editor.cmd["do"]('insertHTML', "<img \n src=" + ($selectIMG === null || $selectIMG === void 0 ? void 0 : $selectIMG.getAttribute('src')) + " \n style=" + ($selectIMG === null || $selectIMG === void 0 ? void 0 : $selectIMG.getAttribute('style')) + ">");
  11750. } else {
  11751. // 用文字,替换链接
  11752. var selectionText = $link.text();
  11753. editor.cmd["do"]('insertHTML', '<span>' + selectionText + '</span>');
  11754. } // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  11755. return true;
  11756. }
  11757. }]; // 创建 tooltip
  11758. tooltip = new Tooltip_1["default"](editor, $link, conf);
  11759. tooltip.create();
  11760. }
  11761. /**
  11762. * 隐藏 tooltip
  11763. */
  11764. function hideLinkTooltip() {
  11765. // 移除 tooltip
  11766. if (tooltip) {
  11767. tooltip.remove();
  11768. tooltip = null;
  11769. }
  11770. }
  11771. return {
  11772. showLinkTooltip: showLinkTooltip,
  11773. hideLinkTooltip: hideLinkTooltip
  11774. };
  11775. }
  11776. /**
  11777. * 绑定 tooltip 事件
  11778. * @param editor 编辑器实例
  11779. */
  11780. function bindTooltipEvent(editor) {
  11781. var _a = createShowHideFn(editor),
  11782. showLinkTooltip = _a.showLinkTooltip,
  11783. hideLinkTooltip = _a.hideLinkTooltip; // 点击链接元素是,显示 tooltip
  11784. editor.txt.eventHooks.linkClickEvents.push(showLinkTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
  11785. editor.txt.eventHooks.clickEvents.push(hideLinkTooltip);
  11786. editor.txt.eventHooks.keyupEvents.push(hideLinkTooltip);
  11787. editor.txt.eventHooks.toolbarClickEvents.push(hideLinkTooltip);
  11788. editor.txt.eventHooks.menuClickEvents.push(hideLinkTooltip);
  11789. editor.txt.eventHooks.textScrollEvents.push(hideLinkTooltip);
  11790. }
  11791. exports["default"] = bindTooltipEvent;
  11792. /***/ }),
  11793. /* 341 */
  11794. /***/ (function(module, exports, __webpack_require__) {
  11795. "use strict";
  11796. /**
  11797. * @description 斜体
  11798. * @author liuwei
  11799. */
  11800. var _interopRequireDefault = __webpack_require__(0);
  11801. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11802. (0, _defineProperty["default"])(exports, "__esModule", {
  11803. value: true
  11804. });
  11805. var tslib_1 = __webpack_require__(2);
  11806. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  11807. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11808. var Italic = function (_super) {
  11809. tslib_1.__extends(Italic, _super);
  11810. function Italic(editor) {
  11811. var _this = this;
  11812. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u659C\u4F53\">\n <i class=\"w-e-icon-italic\"></i>\n </div>");
  11813. _this = _super.call(this, $elem, editor) || this;
  11814. return _this;
  11815. }
  11816. /**
  11817. * 点击事件
  11818. */
  11819. Italic.prototype.clickHandler = function () {
  11820. var editor = this.editor;
  11821. var isSelectEmpty = editor.selection.isSelectionEmpty();
  11822. if (isSelectEmpty) {
  11823. // 选区范围是空的,插入并选中一个“空白”
  11824. editor.selection.createEmptyRange();
  11825. } // 执行 italic 命令
  11826. editor.cmd["do"]('italic');
  11827. if (isSelectEmpty) {
  11828. // 需要将选区范围折叠起来
  11829. editor.selection.collapseRange();
  11830. editor.selection.restoreSelection();
  11831. }
  11832. };
  11833. /**
  11834. * 尝试修改菜单激活状态
  11835. */
  11836. Italic.prototype.tryChangeActive = function () {
  11837. var editor = this.editor;
  11838. if (editor.cmd.queryCommandState('italic')) {
  11839. this.active();
  11840. } else {
  11841. this.unActive();
  11842. }
  11843. };
  11844. return Italic;
  11845. }(BtnMenu_1["default"]);
  11846. exports["default"] = Italic;
  11847. /***/ }),
  11848. /* 342 */
  11849. /***/ (function(module, exports, __webpack_require__) {
  11850. "use strict";
  11851. /**
  11852. * @description 下划线 underline
  11853. * @author dyl
  11854. *
  11855. */
  11856. var _interopRequireDefault = __webpack_require__(0);
  11857. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11858. (0, _defineProperty["default"])(exports, "__esModule", {
  11859. value: true
  11860. });
  11861. var tslib_1 = __webpack_require__(2);
  11862. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  11863. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11864. var Underline = function (_super) {
  11865. tslib_1.__extends(Underline, _super);
  11866. function Underline(editor) {
  11867. var _this = this;
  11868. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u4E0B\u5212\u7EBF\">\n <i class=\"w-e-icon-underline\"></i>\n </div>");
  11869. _this = _super.call(this, $elem, editor) || this;
  11870. return _this;
  11871. }
  11872. /**
  11873. * 点击事件
  11874. */
  11875. Underline.prototype.clickHandler = function () {
  11876. var editor = this.editor;
  11877. var isSelectEmpty = editor.selection.isSelectionEmpty();
  11878. if (isSelectEmpty) {
  11879. // 选区范围是空的,插入并选中一个“空白”
  11880. editor.selection.createEmptyRange();
  11881. } // 执行 Underline 命令
  11882. editor.cmd["do"]('underline');
  11883. if (isSelectEmpty) {
  11884. // 需要将选区范围折叠起来
  11885. editor.selection.collapseRange();
  11886. editor.selection.restoreSelection();
  11887. }
  11888. };
  11889. /**
  11890. * 尝试修改菜单激活状态
  11891. */
  11892. Underline.prototype.tryChangeActive = function () {
  11893. var editor = this.editor;
  11894. if (editor.cmd.queryCommandState('underline')) {
  11895. this.active();
  11896. } else {
  11897. this.unActive();
  11898. }
  11899. };
  11900. return Underline;
  11901. }(BtnMenu_1["default"]);
  11902. exports["default"] = Underline;
  11903. /***/ }),
  11904. /* 343 */
  11905. /***/ (function(module, exports, __webpack_require__) {
  11906. "use strict";
  11907. /**
  11908. * @description 删除线
  11909. * @author lkw
  11910. */
  11911. var _interopRequireDefault = __webpack_require__(0);
  11912. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11913. (0, _defineProperty["default"])(exports, "__esModule", {
  11914. value: true
  11915. });
  11916. var tslib_1 = __webpack_require__(2);
  11917. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  11918. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11919. var StrikeThrough = function (_super) {
  11920. tslib_1.__extends(StrikeThrough, _super);
  11921. function StrikeThrough(editor) {
  11922. var _this = this;
  11923. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5220\u9664\u7EBF\">\n <i class=\"w-e-icon-strikethrough\"></i>\n </div>");
  11924. _this = _super.call(this, $elem, editor) || this;
  11925. return _this;
  11926. }
  11927. /**
  11928. * 点击事件
  11929. */
  11930. StrikeThrough.prototype.clickHandler = function () {
  11931. var editor = this.editor;
  11932. var isSelectEmpty = editor.selection.isSelectionEmpty();
  11933. if (isSelectEmpty) {
  11934. // 选区范围是空的,插入并选中一个“空白”
  11935. editor.selection.createEmptyRange();
  11936. } // 执行 strikeThrough 命令
  11937. editor.cmd["do"]('strikeThrough');
  11938. if (isSelectEmpty) {
  11939. // 需要将选区范围折叠起来
  11940. editor.selection.collapseRange();
  11941. editor.selection.restoreSelection();
  11942. }
  11943. };
  11944. /**
  11945. * 尝试修改菜单激活状态
  11946. */
  11947. StrikeThrough.prototype.tryChangeActive = function () {
  11948. var editor = this.editor;
  11949. if (editor.cmd.queryCommandState('strikeThrough')) {
  11950. this.active();
  11951. } else {
  11952. this.unActive();
  11953. }
  11954. };
  11955. return StrikeThrough;
  11956. }(BtnMenu_1["default"]);
  11957. exports["default"] = StrikeThrough;
  11958. /***/ }),
  11959. /* 344 */
  11960. /***/ (function(module, exports, __webpack_require__) {
  11961. "use strict";
  11962. /**
  11963. * @description 字体样式 FontStyle
  11964. * @author dyl
  11965. *
  11966. */
  11967. var _interopRequireDefault = __webpack_require__(0);
  11968. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  11969. (0, _defineProperty["default"])(exports, "__esModule", {
  11970. value: true
  11971. });
  11972. var tslib_1 = __webpack_require__(2);
  11973. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  11974. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  11975. var FontStyleList_1 = tslib_1.__importDefault(__webpack_require__(345));
  11976. var FontStyle = function (_super) {
  11977. tslib_1.__extends(FontStyle, _super);
  11978. function FontStyle(editor) {
  11979. var _this = this;
  11980. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5B57\u4F53\">\n <i class=\"w-e-icon-font\"></i>\n </div>");
  11981. var fontStyleList = new FontStyleList_1["default"](editor.config.fontNames);
  11982. var fontListConf = {
  11983. width: 100,
  11984. title: '设置字体',
  11985. type: 'list',
  11986. list: fontStyleList.getItemList(),
  11987. clickHandler: function clickHandler(value) {
  11988. // this 是指向当前的 FontStyle 对象
  11989. _this.command(value);
  11990. }
  11991. };
  11992. _this = _super.call(this, $elem, editor, fontListConf) || this;
  11993. return _this;
  11994. }
  11995. /**
  11996. * 执行命令
  11997. * @param value value
  11998. */
  11999. FontStyle.prototype.command = function (value) {
  12000. var _a;
  12001. var editor = this.editor;
  12002. var isEmptySelection = editor.selection.isSelectionEmpty();
  12003. var $selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
  12004. if ($selectionElem == null) return;
  12005. var isFont = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.nodeName.toLowerCase()) !== 'p';
  12006. var isSameValue = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getAttribute('face')) === value;
  12007. if (isEmptySelection) {
  12008. if (isFont && !isSameValue) {
  12009. var $elems = editor.selection.getSelectionRangeTopNodes();
  12010. editor.selection.createRangeByElem($elems[0]);
  12011. editor.selection.moveCursor($elems[0].elems[0]);
  12012. }
  12013. editor.selection.setRangeToElem($selectionElem); // 插入空白选区
  12014. editor.selection.createEmptyRange();
  12015. }
  12016. editor.cmd["do"]('fontName', value);
  12017. if (isEmptySelection) {
  12018. // 需要将选区范围折叠起来
  12019. editor.selection.collapseRange();
  12020. editor.selection.restoreSelection();
  12021. }
  12022. };
  12023. /**
  12024. * 尝试修改菜单激活状态
  12025. * ?字体是否需要有激活状态这个操作?
  12026. */
  12027. FontStyle.prototype.tryChangeActive = function () {// const editor = this.editor
  12028. // const cmdValue = editor.cmd.queryCommandValue('fontName')
  12029. // if (menusConfig.fontNames.indexOf(cmdValue) >= 0) {
  12030. // this.active()
  12031. // } else {
  12032. // this.unActive()
  12033. // }
  12034. };
  12035. return FontStyle;
  12036. }(DropListMenu_1["default"]);
  12037. exports["default"] = FontStyle;
  12038. /***/ }),
  12039. /* 345 */
  12040. /***/ (function(module, exports, __webpack_require__) {
  12041. "use strict";
  12042. var _interopRequireDefault = __webpack_require__(0);
  12043. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12044. var _forEach = _interopRequireDefault(__webpack_require__(4));
  12045. (0, _defineProperty["default"])(exports, "__esModule", {
  12046. value: true
  12047. });
  12048. var tslib_1 = __webpack_require__(2);
  12049. /**
  12050. * @description 字体 class
  12051. * @author dyl
  12052. */
  12053. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12054. /**
  12055. * 封装的一个字体菜单列表数据的组装对象,
  12056. * 原因是因为在constructor函数中,直接执行此流程,会让代码量看起来较多,
  12057. * 如果要在constructor调用外部函数,个人目前发现会有错误提示,
  12058. * 因此,想着顺便研究实践下ts,遍创建了这样一个类
  12059. */
  12060. var FontStyleList = function () {
  12061. function FontStyleList(list) {
  12062. var _this = this;
  12063. this.itemList = [];
  12064. (0, _forEach["default"])(list).call(list, function (fontValue) {
  12065. // fontValue 2种情况一种是string类型的直接value等同于font-family
  12066. // Object类型value为font-family name为ui视图呈现
  12067. var fontFamily = typeof fontValue === 'string' ? fontValue : fontValue.value;
  12068. var fontName = typeof fontValue === 'string' ? fontValue : fontValue.name;
  12069. _this.itemList.push({
  12070. $elem: dom_core_1["default"]("<p style=\"font-family:'" + fontFamily + "'\">" + fontName + "</p>"),
  12071. value: fontName
  12072. });
  12073. });
  12074. }
  12075. FontStyleList.prototype.getItemList = function () {
  12076. return this.itemList;
  12077. };
  12078. return FontStyleList;
  12079. }();
  12080. exports["default"] = FontStyleList;
  12081. /***/ }),
  12082. /* 346 */
  12083. /***/ (function(module, exports, __webpack_require__) {
  12084. "use strict";
  12085. /**
  12086. * @description 字号 FontSize
  12087. * @author lkw
  12088. *
  12089. */
  12090. var _interopRequireDefault = __webpack_require__(0);
  12091. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12092. (0, _defineProperty["default"])(exports, "__esModule", {
  12093. value: true
  12094. });
  12095. var tslib_1 = __webpack_require__(2);
  12096. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  12097. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12098. var FontSizeList_1 = tslib_1.__importDefault(__webpack_require__(347));
  12099. var FontSize = function (_super) {
  12100. tslib_1.__extends(FontSize, _super);
  12101. function FontSize(editor) {
  12102. var _this = this;
  12103. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5B57\u53F7\">\n <i class=\"w-e-icon-text-heigh\"></i>\n </div>");
  12104. var fontStyleList = new FontSizeList_1["default"](editor.config.fontSizes);
  12105. var fontListConf = {
  12106. width: 160,
  12107. title: '设置字号',
  12108. type: 'list',
  12109. list: fontStyleList.getItemList(),
  12110. clickHandler: function clickHandler(value) {
  12111. // this 是指向当前的 FontSize 对象
  12112. _this.command(value);
  12113. }
  12114. };
  12115. _this = _super.call(this, $elem, editor, fontListConf) || this;
  12116. return _this;
  12117. }
  12118. /**
  12119. * 执行命令
  12120. * @param value value
  12121. */
  12122. FontSize.prototype.command = function (value) {
  12123. var _a;
  12124. var editor = this.editor;
  12125. var isEmptySelection = editor.selection.isSelectionEmpty();
  12126. var selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
  12127. if (selectionElem == null) return;
  12128. editor.cmd["do"]('fontSize', value);
  12129. if (isEmptySelection) {
  12130. // 需要将选区范围折叠起来
  12131. editor.selection.collapseRange();
  12132. editor.selection.restoreSelection();
  12133. }
  12134. };
  12135. /**
  12136. * 尝试修改菜单激活状态
  12137. * ?字号是否需要有激活状态这个操作?
  12138. */
  12139. FontSize.prototype.tryChangeActive = function () {};
  12140. return FontSize;
  12141. }(DropListMenu_1["default"]);
  12142. exports["default"] = FontSize;
  12143. /***/ }),
  12144. /* 347 */
  12145. /***/ (function(module, exports, __webpack_require__) {
  12146. "use strict";
  12147. var _interopRequireDefault = __webpack_require__(0);
  12148. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12149. (0, _defineProperty["default"])(exports, "__esModule", {
  12150. value: true
  12151. });
  12152. var tslib_1 = __webpack_require__(2);
  12153. /**
  12154. * @description 字号 class
  12155. * @author lkw
  12156. */
  12157. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12158. /**
  12159. * FontSizeList 字号配置列表
  12160. */
  12161. var FontSizeList = function () {
  12162. function FontSizeList(list) {
  12163. this.itemList = [];
  12164. for (var key in list) {
  12165. var item = list[key];
  12166. this.itemList.push({
  12167. $elem: dom_core_1["default"]("<p style=\"font-size:" + key + "\">" + item.name + "</p>"),
  12168. value: item.value
  12169. });
  12170. }
  12171. }
  12172. FontSizeList.prototype.getItemList = function () {
  12173. return this.itemList;
  12174. };
  12175. return FontSizeList;
  12176. }();
  12177. exports["default"] = FontSizeList;
  12178. /***/ }),
  12179. /* 348 */
  12180. /***/ (function(module, exports, __webpack_require__) {
  12181. "use strict";
  12182. /**
  12183. * @description 对齐方式
  12184. * @author liuwei
  12185. */
  12186. var _interopRequireDefault = __webpack_require__(0);
  12187. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12188. var _forEach = _interopRequireDefault(__webpack_require__(4));
  12189. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  12190. (0, _defineProperty["default"])(exports, "__esModule", {
  12191. value: true
  12192. });
  12193. var tslib_1 = __webpack_require__(2);
  12194. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  12195. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12196. var SPECIAL_NODE_LIST = ['LI'];
  12197. var SPECIAL_TOP_NODE_LIST = ['UL', 'BLOCKQUOTE'];
  12198. var Justify = function (_super) {
  12199. tslib_1.__extends(Justify, _super);
  12200. function Justify(editor) {
  12201. var _this = this;
  12202. var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="对齐"><i class="w-e-icon-paragraph-left"></i></div>');
  12203. var dropListConf = {
  12204. width: 100,
  12205. title: '对齐方式',
  12206. type: 'list',
  12207. list: [{
  12208. $elem: dom_core_1["default"]("<p>\n <i class=\"w-e-icon-paragraph-left w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.justify.靠左') + "\n </p>"),
  12209. value: 'left'
  12210. }, {
  12211. $elem: dom_core_1["default"]("<p>\n <i class=\"w-e-icon-paragraph-center w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.justify.居中') + "\n </p>"),
  12212. value: 'center'
  12213. }, {
  12214. $elem: dom_core_1["default"]("<p>\n <i class=\"w-e-icon-paragraph-right w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.justify.靠右') + "\n </p>"),
  12215. value: 'right'
  12216. }, {
  12217. $elem: dom_core_1["default"]("<p>\n <i class=\"w-e-icon-paragraph-justify w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.justify.两端') + "\n </p>"),
  12218. value: 'justify'
  12219. }],
  12220. clickHandler: function clickHandler(value) {
  12221. // 执行对应的value操作
  12222. _this.command(value);
  12223. }
  12224. };
  12225. _this = _super.call(this, $elem, editor, dropListConf) || this;
  12226. return _this;
  12227. }
  12228. /**
  12229. * 执行命令
  12230. * @param value value
  12231. */
  12232. Justify.prototype.command = function (value) {
  12233. var editor = this.editor;
  12234. var selection = editor.selection;
  12235. var $selectionElem = selection.getSelectionContainerElem(); // 保存选区
  12236. selection.saveRange(); // 获取顶级元素
  12237. var $elems = editor.selection.getSelectionRangeTopNodes();
  12238. if ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.length) {
  12239. // list 在chrome下默认多包裹一个 p,导致不能通过顶层元素判断,所以单独加个判断
  12240. if (this.isSpecialNode($selectionElem, $elems[0]) || this.isSpecialTopNode($elems[0])) {
  12241. var el = this.getSpecialNodeUntilTop($selectionElem, $elems[0]);
  12242. if (el == null) return;
  12243. dom_core_1["default"](el).css('text-align', value);
  12244. } else {
  12245. (0, _forEach["default"])($elems).call($elems, function (el) {
  12246. el.css('text-align', value);
  12247. });
  12248. }
  12249. } //恢复选区
  12250. selection.restoreSelection();
  12251. };
  12252. /**
  12253. * 获取选区中的特殊元素,如果不存在,则直接返回顶层元素子元素
  12254. * @param el DomElement
  12255. * @param topEl DomElement
  12256. */
  12257. Justify.prototype.getSpecialNodeUntilTop = function (el, topEl) {
  12258. var parentNode = el.elems[0];
  12259. var topNode = topEl.elems[0]; // 可能出现嵌套的情况,所以一级一级向上找,是否是特殊元素
  12260. while (parentNode != null) {
  12261. if ((0, _indexOf["default"])(SPECIAL_NODE_LIST).call(SPECIAL_NODE_LIST, parentNode === null || parentNode === void 0 ? void 0 : parentNode.nodeName) !== -1) {
  12262. return parentNode;
  12263. } // 如果再到 top 元素之前还没找到特殊元素,直接返回元素
  12264. if (parentNode.parentNode === topNode) {
  12265. return parentNode;
  12266. }
  12267. parentNode = parentNode.parentNode;
  12268. }
  12269. return parentNode;
  12270. };
  12271. /**
  12272. * 当选区元素或者顶层元素是某些特殊元素时,只需要修改子元素的对齐样式的元素
  12273. * @param el DomElement
  12274. * @param topEl DomElement
  12275. */
  12276. Justify.prototype.isSpecialNode = function (el, topEl) {
  12277. // 如果以后有类似的元素要这样处理,直接修改这个数组即可
  12278. var parentNode = this.getSpecialNodeUntilTop(el, topEl);
  12279. if (parentNode == null) return false;
  12280. return (0, _indexOf["default"])(SPECIAL_NODE_LIST).call(SPECIAL_NODE_LIST, parentNode.nodeName) !== -1;
  12281. };
  12282. /**
  12283. * 当选区 top 元素为某些特殊元素时,只需要修改子元素的对齐样式的元素
  12284. * @param el DomElement
  12285. */
  12286. Justify.prototype.isSpecialTopNode = function (topEl) {
  12287. var _a;
  12288. if (topEl == null) return false;
  12289. return (0, _indexOf["default"])(SPECIAL_TOP_NODE_LIST).call(SPECIAL_TOP_NODE_LIST, (_a = topEl.elems[0]) === null || _a === void 0 ? void 0 : _a.nodeName) !== -1;
  12290. };
  12291. /**
  12292. * 尝试改变菜单激活(高亮)状态
  12293. * 默认左对齐,若选择其他对其方式对active进行高亮否则unActive
  12294. * ?考虑优化的话 是否可以对具体选中的进行高亮
  12295. */
  12296. Justify.prototype.tryChangeActive = function () {};
  12297. return Justify;
  12298. }(DropListMenu_1["default"]);
  12299. exports["default"] = Justify;
  12300. /***/ }),
  12301. /* 349 */
  12302. /***/ (function(module, exports, __webpack_require__) {
  12303. "use strict";
  12304. /**
  12305. * @description 引用
  12306. * @author tonghan
  12307. */
  12308. var _interopRequireDefault = __webpack_require__(0);
  12309. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12310. var _forEach = _interopRequireDefault(__webpack_require__(4));
  12311. (0, _defineProperty["default"])(exports, "__esModule", {
  12312. value: true
  12313. });
  12314. var tslib_1 = __webpack_require__(2);
  12315. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12316. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  12317. var bind_event_1 = tslib_1.__importDefault(__webpack_require__(350));
  12318. var create_quote_node_1 = tslib_1.__importDefault(__webpack_require__(351));
  12319. var const_1 = __webpack_require__(7);
  12320. var Quote = function (_super) {
  12321. tslib_1.__extends(Quote, _super);
  12322. function Quote(editor) {
  12323. var _this = this;
  12324. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5F15\u7528\">\n <i class=\"w-e-icon-quotes-left\"></i>\n </div>");
  12325. _this = _super.call(this, $elem, editor) || this;
  12326. bind_event_1["default"](editor);
  12327. return _this;
  12328. }
  12329. /**
  12330. * 点击事件
  12331. */
  12332. Quote.prototype.clickHandler = function () {
  12333. var _a, _b;
  12334. var editor = this.editor;
  12335. var isSelectEmpty = editor.selection.isSelectionEmpty();
  12336. var topNodeElem = editor.selection.getSelectionRangeTopNodes();
  12337. var $topNodeElem = topNodeElem[topNodeElem.length - 1];
  12338. var nodeName = this.getTopNodeName(); // IE 中不支持 formatBlock <BLOCKQUOTE> ,要用其他方式兼容
  12339. // 兼容firefox无法取消blockquote的问题
  12340. if (nodeName === 'BLOCKQUOTE') {
  12341. // 撤销 quote
  12342. var $targetELem = dom_core_1["default"]($topNodeElem.childNodes());
  12343. var len = $targetELem.length;
  12344. var $middle_1 = $topNodeElem;
  12345. (0, _forEach["default"])($targetELem).call($targetELem, function (elem) {
  12346. var $elem = dom_core_1["default"](elem);
  12347. $elem.insertAfter($middle_1);
  12348. $middle_1 = $elem;
  12349. });
  12350. $topNodeElem.remove();
  12351. editor.selection.moveCursor($targetELem.elems[len - 1]); // 即时更新btn状态
  12352. this.tryChangeActive();
  12353. } else {
  12354. // 将 P 转换为 quote
  12355. /**
  12356. @author:gavin
  12357. @description
  12358. 1. 解决ctrl+a全选删除后,选区错位的问题。
  12359. 2. 或者内容清空,按删除键后,选区错位。
  12360. 导致topNodeElem选择的是编辑器顶层元素,在进行dom操作时,quote插入的位置有问题。
  12361. **/
  12362. var $quote = create_quote_node_1["default"](topNodeElem); //如果选择的元素时顶层元素,就将选区移动到正确的位置
  12363. if (editor.$textElem.equal($topNodeElem)) {
  12364. var containerElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
  12365. editor.selection.createRangeByElems(containerElem.children[0], containerElem.children[0]);
  12366. topNodeElem = editor.selection.getSelectionRangeTopNodes();
  12367. $quote = create_quote_node_1["default"](topNodeElem);
  12368. $topNodeElem.append($quote);
  12369. } else {
  12370. $quote.insertAfter($topNodeElem);
  12371. }
  12372. this.delSelectNode(topNodeElem);
  12373. var moveNode = (_b = $quote.childNodes()) === null || _b === void 0 ? void 0 : _b.last().getNode();
  12374. if (moveNode == null) return; // 兼容firefox(firefox下空行情况下选区会在br后,造成自动换行的问题)
  12375. moveNode.textContent ? editor.selection.moveCursor(moveNode) : editor.selection.moveCursor(moveNode, 0); // 即时更新btn状态
  12376. this.tryChangeActive(); // 防止最后一行无法跳出
  12377. dom_core_1["default"](const_1.EMPTY_P).insertAfter($quote);
  12378. return;
  12379. }
  12380. if (isSelectEmpty) {
  12381. // 需要将选区范围折叠起来
  12382. editor.selection.collapseRange();
  12383. editor.selection.restoreSelection();
  12384. }
  12385. };
  12386. /**
  12387. * 尝试修改菜单激活状态
  12388. */
  12389. Quote.prototype.tryChangeActive = function () {
  12390. var _a;
  12391. var editor = this.editor;
  12392. var cmdValue = (_a = editor.selection.getSelectionRangeTopNodes()[0]) === null || _a === void 0 ? void 0 : _a.getNodeName();
  12393. if (cmdValue === 'BLOCKQUOTE') {
  12394. this.active();
  12395. } else {
  12396. this.unActive();
  12397. }
  12398. };
  12399. /**
  12400. * 获取包裹在最外层的节点(防止内部嵌入多个样式)
  12401. * @param selectionElem 选中的节点
  12402. * @returns {string} 最终要处理的节点名称
  12403. */
  12404. Quote.prototype.getTopNodeName = function () {
  12405. var editor = this.editor;
  12406. var $topNodeElem = editor.selection.getSelectionRangeTopNodes()[0];
  12407. var nodeName = $topNodeElem === null || $topNodeElem === void 0 ? void 0 : $topNodeElem.getNodeName();
  12408. return nodeName;
  12409. };
  12410. /**
  12411. * 删除选中的元素
  12412. * @param selectElem 选中的元素节点数组
  12413. */
  12414. Quote.prototype.delSelectNode = function (selectElem) {
  12415. (0, _forEach["default"])(selectElem).call(selectElem, function (node) {
  12416. node.remove();
  12417. });
  12418. };
  12419. return Quote;
  12420. }(BtnMenu_1["default"]);
  12421. exports["default"] = Quote;
  12422. /***/ }),
  12423. /* 350 */
  12424. /***/ (function(module, exports, __webpack_require__) {
  12425. "use strict";
  12426. var _interopRequireDefault = __webpack_require__(0);
  12427. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12428. (0, _defineProperty["default"])(exports, "__esModule", {
  12429. value: true
  12430. });
  12431. var tslib_1 = __webpack_require__(2);
  12432. var const_1 = __webpack_require__(7);
  12433. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12434. function bindEvent(editor) {
  12435. function quoteEnter(e) {
  12436. var _a;
  12437. var $selectElem = editor.selection.getSelectionContainerElem();
  12438. var $topSelectElem = editor.selection.getSelectionRangeTopNodes()[0]; // 对quote的enter进行特殊处理
  12439. //最后一行为空标签时再按会出跳出blockquote
  12440. if (($topSelectElem === null || $topSelectElem === void 0 ? void 0 : $topSelectElem.getNodeName()) === 'BLOCKQUOTE') {
  12441. // firefox下点击引用按钮会选中外容器<blockquote></blockquote>
  12442. if ($selectElem.getNodeName() === 'BLOCKQUOTE') {
  12443. var selectNode = (_a = $selectElem.childNodes()) === null || _a === void 0 ? void 0 : _a.getNode();
  12444. editor.selection.moveCursor(selectNode);
  12445. }
  12446. if ($selectElem.text() === '') {
  12447. e.preventDefault();
  12448. $selectElem.remove();
  12449. var $newLine = dom_core_1["default"](const_1.EMPTY_P);
  12450. $newLine.insertAfter($topSelectElem); // 将光标移动br前面
  12451. editor.selection.moveCursor($newLine.getNode(), 0);
  12452. } // 当blockQuote中没有内容回车后移除blockquote
  12453. if ($topSelectElem.text() === '') {
  12454. $topSelectElem.remove();
  12455. }
  12456. }
  12457. }
  12458. editor.txt.eventHooks.enterDownEvents.push(quoteEnter);
  12459. }
  12460. exports["default"] = bindEvent;
  12461. /***/ }),
  12462. /* 351 */
  12463. /***/ (function(module, exports, __webpack_require__) {
  12464. "use strict";
  12465. var _interopRequireDefault = __webpack_require__(0);
  12466. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12467. var _forEach = _interopRequireDefault(__webpack_require__(4));
  12468. (0, _defineProperty["default"])(exports, "__esModule", {
  12469. value: true
  12470. });
  12471. var tslib_1 = __webpack_require__(2);
  12472. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12473. /**
  12474. * 创建一个blockquote元素节点
  12475. * @param editor 编辑器实例
  12476. */
  12477. function createQuote($childElem) {
  12478. var $targetElem = dom_core_1["default"]("<blockquote></blockquote>");
  12479. (0, _forEach["default"])($childElem).call($childElem, function (node) {
  12480. $targetElem.append(node.clone(true));
  12481. });
  12482. return $targetElem;
  12483. }
  12484. exports["default"] = createQuote;
  12485. /***/ }),
  12486. /* 352 */
  12487. /***/ (function(module, exports, __webpack_require__) {
  12488. "use strict";
  12489. /**
  12490. * @description 背景颜色 BackColor
  12491. * @author lkw
  12492. *
  12493. */
  12494. var _interopRequireDefault = __webpack_require__(0);
  12495. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12496. var _map = _interopRequireDefault(__webpack_require__(27));
  12497. (0, _defineProperty["default"])(exports, "__esModule", {
  12498. value: true
  12499. });
  12500. var tslib_1 = __webpack_require__(2);
  12501. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  12502. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12503. var util_1 = __webpack_require__(6);
  12504. var BackColor = function (_super) {
  12505. tslib_1.__extends(BackColor, _super);
  12506. function BackColor(editor) {
  12507. var _context;
  12508. var _this = this;
  12509. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u80CC\u666F\u8272\">\n <i class=\"w-e-icon-paint-brush\"></i>\n </div>");
  12510. var colorListConf = {
  12511. width: 120,
  12512. title: '背景颜色',
  12513. // droplist 内容以 block 形式展示
  12514. type: 'inline-block',
  12515. list: (0, _map["default"])(_context = editor.config.colors).call(_context, function (color) {
  12516. return {
  12517. $elem: dom_core_1["default"]("<i style=\"color:" + color + ";\" class=\"w-e-icon-paint-brush\"></i>"),
  12518. value: color
  12519. };
  12520. }),
  12521. clickHandler: function clickHandler(value) {
  12522. // this 是指向当前的 BackColor 对象
  12523. _this.command(value);
  12524. }
  12525. };
  12526. _this = _super.call(this, $elem, editor, colorListConf) || this;
  12527. return _this;
  12528. }
  12529. /**
  12530. * 执行命令
  12531. * @param value value
  12532. */
  12533. BackColor.prototype.command = function (value) {
  12534. var _a;
  12535. var editor = this.editor;
  12536. var isEmptySelection = editor.selection.isSelectionEmpty();
  12537. var $selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
  12538. if ($selectionElem == null) return;
  12539. var isSpan = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.nodeName.toLowerCase()) !== 'p';
  12540. var bgColor = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.style.backgroundColor;
  12541. var isSameColor = util_1.hexToRgb(value) === bgColor;
  12542. if (isEmptySelection) {
  12543. if (isSpan && !isSameColor) {
  12544. var $elems = editor.selection.getSelectionRangeTopNodes();
  12545. editor.selection.createRangeByElem($elems[0]);
  12546. editor.selection.moveCursor($elems[0].elems[0]);
  12547. } // 插入空白选区
  12548. editor.selection.createEmptyRange();
  12549. }
  12550. editor.cmd["do"]('backColor', value);
  12551. if (isEmptySelection) {
  12552. // 需要将选区范围折叠起来
  12553. editor.selection.collapseRange();
  12554. editor.selection.restoreSelection();
  12555. }
  12556. };
  12557. /**
  12558. * 尝试修改菜单激活状态
  12559. */
  12560. BackColor.prototype.tryChangeActive = function () {};
  12561. return BackColor;
  12562. }(DropListMenu_1["default"]);
  12563. exports["default"] = BackColor;
  12564. /***/ }),
  12565. /* 353 */
  12566. /***/ (function(module, exports, __webpack_require__) {
  12567. "use strict";
  12568. /**
  12569. * @description 文字颜色 FontColor
  12570. * @author lkw
  12571. *
  12572. */
  12573. var _interopRequireDefault = __webpack_require__(0);
  12574. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12575. var _map = _interopRequireDefault(__webpack_require__(27));
  12576. (0, _defineProperty["default"])(exports, "__esModule", {
  12577. value: true
  12578. });
  12579. var tslib_1 = __webpack_require__(2);
  12580. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  12581. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12582. var FontColor = function (_super) {
  12583. tslib_1.__extends(FontColor, _super);
  12584. function FontColor(editor) {
  12585. var _context;
  12586. var _this = this;
  12587. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u6587\u5B57\u989C\u8272\">\n <i class=\"w-e-icon-pencil2\"></i>\n </div>");
  12588. var colorListConf = {
  12589. width: 120,
  12590. title: '文字颜色',
  12591. // droplist 内容以 block 形式展示
  12592. type: 'inline-block',
  12593. list: (0, _map["default"])(_context = editor.config.colors).call(_context, function (color) {
  12594. return {
  12595. $elem: dom_core_1["default"]("<i style=\"color:" + color + ";\" class=\"w-e-icon-pencil2\"></i>"),
  12596. value: color
  12597. };
  12598. }),
  12599. clickHandler: function clickHandler(value) {
  12600. // this 是指向当前的 BackColor 对象
  12601. _this.command(value);
  12602. }
  12603. };
  12604. _this = _super.call(this, $elem, editor, colorListConf) || this;
  12605. return _this;
  12606. }
  12607. /**
  12608. * 执行命令
  12609. * @param value value
  12610. */
  12611. FontColor.prototype.command = function (value) {
  12612. var _a;
  12613. var editor = this.editor;
  12614. var isEmptySelection = editor.selection.isSelectionEmpty();
  12615. var $selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
  12616. if ($selectionElem == null) return; // 获取选区范围的文字
  12617. var $selectionText = editor.selection.getSelectionText(); // 如果设置的是 a 标签就特殊处理一下,避免回车换行设置颜色无效的情况
  12618. // 只处理选中a标签内全部文字的情况,因为选中部分文字不存在换行颜色失效的情况
  12619. if ($selectionElem.nodeName === 'A' && $selectionElem.textContent === $selectionText) {
  12620. // 创建一个相当于占位的元素
  12621. var _payloadElem = dom_core_1["default"]('<span>&#8203;</span>').getNode(); // 添加到a标签之后
  12622. $selectionElem.appendChild(_payloadElem);
  12623. }
  12624. editor.cmd["do"]('foreColor', value);
  12625. if (isEmptySelection) {
  12626. // 需要将选区范围折叠起来
  12627. editor.selection.collapseRange();
  12628. editor.selection.restoreSelection();
  12629. }
  12630. };
  12631. /**
  12632. * 尝试修改菜单激活状态
  12633. */
  12634. FontColor.prototype.tryChangeActive = function () {};
  12635. return FontColor;
  12636. }(DropListMenu_1["default"]);
  12637. exports["default"] = FontColor;
  12638. /***/ }),
  12639. /* 354 */
  12640. /***/ (function(module, exports, __webpack_require__) {
  12641. "use strict";
  12642. /**
  12643. * @description 视频 菜单
  12644. * @author tonghan
  12645. */
  12646. var _interopRequireDefault = __webpack_require__(0);
  12647. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12648. (0, _defineProperty["default"])(exports, "__esModule", {
  12649. value: true
  12650. });
  12651. var tslib_1 = __webpack_require__(2);
  12652. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12653. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  12654. var PanelMenu_1 = tslib_1.__importDefault(__webpack_require__(36));
  12655. var create_panel_conf_1 = tslib_1.__importDefault(__webpack_require__(355));
  12656. var index_1 = tslib_1.__importDefault(__webpack_require__(361));
  12657. var Video = function (_super) {
  12658. tslib_1.__extends(Video, _super);
  12659. function Video(editor) {
  12660. var _this = this;
  12661. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u89C6\u9891\">\n <i class=\"w-e-icon-play\"></i>\n </div>");
  12662. _this = _super.call(this, $elem, editor) || this; // 绑定事件 tootip
  12663. index_1["default"](editor);
  12664. return _this;
  12665. }
  12666. /**
  12667. * 菜单点击事件
  12668. */
  12669. Video.prototype.clickHandler = function () {
  12670. // 弹出 panel
  12671. this.createPanel('');
  12672. };
  12673. /**
  12674. * 创建 panel
  12675. * @param link 链接
  12676. */
  12677. Video.prototype.createPanel = function (iframe) {
  12678. var conf = create_panel_conf_1["default"](this.editor, iframe);
  12679. var panel = new Panel_1["default"](this, conf);
  12680. panel.create();
  12681. };
  12682. /**
  12683. * 尝试修改菜单 active 状态
  12684. */
  12685. Video.prototype.tryChangeActive = function () {};
  12686. return Video;
  12687. }(PanelMenu_1["default"]);
  12688. exports["default"] = Video;
  12689. /***/ }),
  12690. /* 355 */
  12691. /***/ (function(module, exports, __webpack_require__) {
  12692. "use strict";
  12693. /**
  12694. * @description video 菜单 panel tab 配置
  12695. * @author tonghan
  12696. */
  12697. var _interopRequireDefault = __webpack_require__(0);
  12698. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12699. var _trim = _interopRequireDefault(__webpack_require__(16));
  12700. (0, _defineProperty["default"])(exports, "__esModule", {
  12701. value: true
  12702. });
  12703. var tslib_1 = __webpack_require__(2);
  12704. var util_1 = __webpack_require__(6);
  12705. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  12706. var upload_video_1 = tslib_1.__importDefault(__webpack_require__(356));
  12707. var const_1 = __webpack_require__(7);
  12708. function default_1(editor, video) {
  12709. var config = editor.config;
  12710. var uploadVideo = new upload_video_1["default"](editor); // panel 中需要用到的id
  12711. var inputIFrameId = util_1.getRandom('input-iframe');
  12712. var btnOkId = util_1.getRandom('btn-ok');
  12713. var inputUploadId = util_1.getRandom('input-upload');
  12714. var btnStartId = util_1.getRandom('btn-local-ok');
  12715. /**
  12716. * 插入链接
  12717. * @param iframe html标签
  12718. */
  12719. function insertVideo(video) {
  12720. editor.cmd["do"]('insertHTML', video + const_1.EMPTY_P); // video添加后的回调
  12721. editor.config.onlineVideoCallback(video);
  12722. }
  12723. /**
  12724. * 校验在线视频链接
  12725. * @param video 在线视频链接
  12726. */
  12727. function checkOnlineVideo(video) {
  12728. // 查看开发者自定义配置的返回值
  12729. var check = editor.config.onlineVideoCheck(video);
  12730. if (check === true) {
  12731. return true;
  12732. }
  12733. if (typeof check === 'string') {
  12734. //用户未能通过开发者的校验,开发者希望我们提示这一字符串
  12735. editor.config.customAlert(check, 'error');
  12736. }
  12737. return false;
  12738. } // tabs配置
  12739. // const fileMultipleAttr = config.uploadVideoMaxLength === 1 ? '' : 'multiple="multiple"'
  12740. var tabsConf = [{
  12741. // tab 的标题
  12742. title: editor.i18next.t('menus.panelMenus.video.上传视频'),
  12743. tpl: "<div class=\"w-e-up-video-container\">\n <div id=\"" + btnStartId + "\" class=\"w-e-up-btn\">\n <i class=\"w-e-icon-upload2\"></i>\n </div>\n <div style=\"display:none;\">\n <input id=\"" + inputUploadId + "\" type=\"file\" accept=\"video/*\"/>\n </div>\n </div>",
  12744. events: [// 触发选择视频
  12745. {
  12746. selector: '#' + btnStartId,
  12747. type: 'click',
  12748. fn: function fn() {
  12749. var $file = dom_core_1["default"]('#' + inputUploadId);
  12750. var fileElem = $file.elems[0];
  12751. if (fileElem) {
  12752. fileElem.click();
  12753. } else {
  12754. // 返回 true 可关闭 panel
  12755. return true;
  12756. }
  12757. }
  12758. }, // 选择视频完毕
  12759. {
  12760. selector: '#' + inputUploadId,
  12761. type: 'change',
  12762. fn: function fn() {
  12763. var $file = dom_core_1["default"]('#' + inputUploadId);
  12764. var fileElem = $file.elems[0];
  12765. if (!fileElem) {
  12766. // 返回 true 可关闭 panel
  12767. return true;
  12768. } // 获取选中的 file 对象列表
  12769. var fileList = fileElem.files;
  12770. if (fileList.length) {
  12771. uploadVideo.uploadVideo(fileList);
  12772. } // 返回 true 可关闭 panel
  12773. return true;
  12774. }
  12775. }]
  12776. }, {
  12777. // tab 的标题
  12778. title: editor.i18next.t('menus.panelMenus.video.插入视频'),
  12779. // 模板
  12780. tpl: "<div>\n <input \n id=\"" + inputIFrameId + "\" \n type=\"text\" \n class=\"block\" \n placeholder=\"" + editor.i18next.t('如') + "\uFF1A<iframe src=... ></iframe>\"/>\n </td>\n <div class=\"w-e-button-container\">\n <button type=\"button\" id=\"" + btnOkId + "\" class=\"right\">\n " + editor.i18next.t('插入') + "\n </button>\n </div>\n </div>",
  12781. // 事件绑定
  12782. events: [// 插入视频
  12783. {
  12784. selector: '#' + btnOkId,
  12785. type: 'click',
  12786. fn: function fn() {
  12787. var _context;
  12788. // 执行插入视频
  12789. var $video = dom_core_1["default"]('#' + inputIFrameId);
  12790. var video = (0, _trim["default"])(_context = $video.val()).call(_context); // 视频为空,则不插入
  12791. if (!video) return; // 对当前用户插入的内容进行判断,插入为空,或者返回false,都停止插入
  12792. if (!checkOnlineVideo(video)) return;
  12793. insertVideo(video); // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
  12794. return true;
  12795. },
  12796. bindEnter: true
  12797. }]
  12798. } // tab end
  12799. ];
  12800. var conf = {
  12801. width: 300,
  12802. height: 0,
  12803. // panel 中可包含多个 tab
  12804. tabs: [] // tabs end
  12805. }; // 显示“上传视频”
  12806. if (window.FileReader && (config.uploadVideoServer || config.customUploadVideo)) {
  12807. conf.tabs.push(tabsConf[0]);
  12808. } // 显示“插入视频”
  12809. if (config.showLinkVideo) {
  12810. conf.tabs.push(tabsConf[1]);
  12811. }
  12812. return conf;
  12813. }
  12814. exports["default"] = default_1;
  12815. /***/ }),
  12816. /* 356 */
  12817. /***/ (function(module, exports, __webpack_require__) {
  12818. "use strict";
  12819. /**
  12820. * @description 上传视频
  12821. * @author lichunlin
  12822. */
  12823. var _interopRequireDefault = __webpack_require__(0);
  12824. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  12825. var _some = _interopRequireDefault(__webpack_require__(137));
  12826. var _bind = _interopRequireDefault(__webpack_require__(61));
  12827. var _forEach = _interopRequireDefault(__webpack_require__(4));
  12828. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  12829. (0, _defineProperty["default"])(exports, "__esModule", {
  12830. value: true
  12831. });
  12832. var tslib_1 = __webpack_require__(2);
  12833. var util_1 = __webpack_require__(6);
  12834. var upload_core_1 = tslib_1.__importDefault(__webpack_require__(140));
  12835. var progress_1 = tslib_1.__importDefault(__webpack_require__(141));
  12836. var const_1 = __webpack_require__(7);
  12837. var util_2 = __webpack_require__(6);
  12838. var UploadVideo = function () {
  12839. function UploadVideo(editor) {
  12840. this.editor = editor;
  12841. }
  12842. /**
  12843. * 上传视频
  12844. * @param files 文件列表
  12845. */
  12846. UploadVideo.prototype.uploadVideo = function (files) {
  12847. var _this = this;
  12848. if (!files.length) {
  12849. return;
  12850. }
  12851. var editor = this.editor;
  12852. var config = editor.config; // ------------------------------ i18next ------------------------------
  12853. var i18nPrefix = 'validate.';
  12854. var t = function t(text) {
  12855. return editor.i18next.t(i18nPrefix + text);
  12856. }; // ------------------------------ 获取配置信息 ------------------------------
  12857. // 服务端地址
  12858. var uploadVideoServer = config.uploadVideoServer; // 上传视频的最大体积,默认 1024M
  12859. var maxSize = config.uploadVideoMaxSize;
  12860. var uploadVideoMaxSize = maxSize / 1024; // 一次最多上传多少个视频
  12861. // const uploadVideoMaxLength = config.uploadVideoMaxLength
  12862. // 自定义上传视频的名称
  12863. var uploadVideoName = config.uploadVideoName; // 上传视频自定义参数
  12864. var uploadVideoParams = config.uploadVideoParams; // 自定义参数拼接到 url 中
  12865. var uploadVideoParamsWithUrl = config.uploadVideoParamsWithUrl; // 上传视频自定义 header
  12866. var uploadVideoHeaders = config.uploadVideoHeaders; // 钩子函数
  12867. var uploadVideoHooks = config.uploadVideoHooks; // 上传视频超时时间 ms 默认2个小时
  12868. var uploadVideoTimeout = config.uploadVideoTimeout; // 跨域带 cookie
  12869. var withVideoCredentials = config.withVideoCredentials; // 自定义上传
  12870. var customUploadVideo = config.customUploadVideo; // 格式校验
  12871. var uploadVideoAccept = config.uploadVideoAccept; // ------------------------------ 验证文件信息 ------------------------------
  12872. var resultFiles = [];
  12873. var errInfos = [];
  12874. util_1.arrForEach(files, function (file) {
  12875. var name = file.name;
  12876. var size = file.size / 1024 / 1024; // chrome 低版本 name === undefined
  12877. if (!name || !size) {
  12878. return;
  12879. }
  12880. if (!(uploadVideoAccept instanceof Array)) {
  12881. // 格式不是数组
  12882. errInfos.push("\u3010" + uploadVideoAccept + "\u3011" + t('uploadVideoAccept 不是Array'));
  12883. return;
  12884. }
  12885. if (!(0, _some["default"])(uploadVideoAccept).call(uploadVideoAccept, function (item) {
  12886. return item === name.split('.')[name.split('.').length - 1];
  12887. })) {
  12888. // 后缀名不合法,不是视频
  12889. errInfos.push("\u3010" + name + "\u3011" + t('不是视频'));
  12890. return;
  12891. }
  12892. if (uploadVideoMaxSize < size) {
  12893. // 上传视频过大
  12894. errInfos.push("\u3010" + name + "\u3011" + t('大于') + " " + uploadVideoMaxSize + "M");
  12895. return;
  12896. } //验证通过的加入结果列表
  12897. resultFiles.push(file);
  12898. }); // 抛出验证信息
  12899. if (errInfos.length) {
  12900. config.customAlert(t('视频验证未通过') + ": \n" + errInfos.join('\n'), 'warning');
  12901. return;
  12902. } // 如果过滤后文件列表为空直接返回
  12903. if (resultFiles.length === 0) {
  12904. config.customAlert(t('传入的文件不合法'), 'warning');
  12905. return;
  12906. } // ------------------------------ 自定义上传 ------------------------------
  12907. if (customUploadVideo && typeof customUploadVideo === 'function') {
  12908. var _context;
  12909. customUploadVideo(resultFiles, (0, _bind["default"])(_context = this.insertVideo).call(_context, this));
  12910. return;
  12911. } // 添加视频数据
  12912. var formData = new FormData();
  12913. (0, _forEach["default"])(resultFiles).call(resultFiles, function (file, index) {
  12914. var name = uploadVideoName || file.name;
  12915. if (resultFiles.length > 1) {
  12916. // 多个文件时,filename 不能重复
  12917. name = name + (index + 1);
  12918. }
  12919. formData.append(name, file);
  12920. }); // ------------------------------ 上传视频 ------------------------------
  12921. //添加自定义参数 基于有服务端地址的情况下
  12922. if (uploadVideoServer) {
  12923. // 添加自定义参数
  12924. var uploadVideoServerArr = uploadVideoServer.split('#');
  12925. uploadVideoServer = uploadVideoServerArr[0];
  12926. var uploadVideoServerHash = uploadVideoServerArr[1] || '';
  12927. (0, _forEach["default"])(util_1).call(util_1, uploadVideoParams, function (key, val) {
  12928. // 因使用者反应,自定义参数不能默认 encode ,由 v3.1.1 版本开始注释掉
  12929. // val = encodeURIComponent(val)
  12930. // 第一,将参数拼接到 url 中
  12931. if (uploadVideoParamsWithUrl) {
  12932. if ((0, _indexOf["default"])(uploadVideoServer).call(uploadVideoServer, '?') > 0) {
  12933. uploadVideoServer += '&';
  12934. } else {
  12935. uploadVideoServer += '?';
  12936. }
  12937. uploadVideoServer = uploadVideoServer + key + '=' + val;
  12938. } // 第二,将参数添加到 formData 中
  12939. formData.append(key, val);
  12940. });
  12941. if (uploadVideoServerHash) {
  12942. uploadVideoServer += '#' + uploadVideoServerHash;
  12943. } // 开始上传
  12944. var xhr = upload_core_1["default"](uploadVideoServer, {
  12945. timeout: uploadVideoTimeout,
  12946. formData: formData,
  12947. headers: uploadVideoHeaders,
  12948. withCredentials: !!withVideoCredentials,
  12949. beforeSend: function beforeSend(xhr) {
  12950. if (uploadVideoHooks.before) return uploadVideoHooks.before(xhr, editor, resultFiles);
  12951. },
  12952. onTimeout: function onTimeout(xhr) {
  12953. config.customAlert(t('上传视频超时'), 'error');
  12954. if (uploadVideoHooks.timeout) uploadVideoHooks.timeout(xhr, editor);
  12955. },
  12956. onProgress: function onProgress(percent, e) {
  12957. var progressBar = new progress_1["default"](editor);
  12958. if (e.lengthComputable) {
  12959. percent = e.loaded / e.total;
  12960. progressBar.show(percent);
  12961. }
  12962. },
  12963. onError: function onError(xhr) {
  12964. config.customAlert(t('上传视频错误'), 'error', t('上传视频错误') + "\uFF0C" + t('服务器返回状态') + ": " + xhr.status);
  12965. if (uploadVideoHooks.error) uploadVideoHooks.error(xhr, editor);
  12966. },
  12967. onFail: function onFail(xhr, resultStr) {
  12968. config.customAlert(t('上传视频失败'), 'error', t('上传视频返回结果错误') + ("\uFF0C" + t('返回结果') + ": ") + resultStr);
  12969. if (uploadVideoHooks.fail) uploadVideoHooks.fail(xhr, editor, resultStr);
  12970. },
  12971. onSuccess: function onSuccess(xhr, result) {
  12972. if (uploadVideoHooks.customInsert) {
  12973. var _context2;
  12974. // 自定义插入视频
  12975. uploadVideoHooks.customInsert((0, _bind["default"])(_context2 = _this.insertVideo).call(_context2, _this), result, editor);
  12976. return;
  12977. }
  12978. if (result.errno != '0') {
  12979. // 返回格式不对,应该为 { errno: 0, data: [...] }
  12980. config.customAlert(t('上传视频失败'), 'error', t('上传视频返回结果错误') + "\uFF0C" + t('返回结果') + " errno=" + result.errno);
  12981. if (uploadVideoHooks.fail) uploadVideoHooks.fail(xhr, editor, result);
  12982. return;
  12983. } // 成功,插入视频
  12984. var data = result.data;
  12985. _this.insertVideo(data.url); // 钩子函数
  12986. if (uploadVideoHooks.success) uploadVideoHooks.success(xhr, editor, result);
  12987. }
  12988. });
  12989. if (typeof xhr === 'string') {
  12990. // 上传被阻止
  12991. config.customAlert(xhr, 'error');
  12992. }
  12993. }
  12994. };
  12995. /**
  12996. * 往编辑器区域插入视频
  12997. * @param url 视频访问地址
  12998. */
  12999. UploadVideo.prototype.insertVideo = function (url) {
  13000. var editor = this.editor;
  13001. var config = editor.config;
  13002. var i18nPrefix = 'validate.';
  13003. var t = function t(text, prefix) {
  13004. if (prefix === void 0) {
  13005. prefix = i18nPrefix;
  13006. }
  13007. return editor.i18next.t(prefix + text);
  13008. }; // 判断用户是否自定义插入视频
  13009. if (!config.customInsertVideo) {
  13010. if (util_2.UA.isFirefox) {
  13011. editor.cmd["do"]('insertHTML', "<p data-we-video-p=\"true\"><video src=\"" + url + "\" controls=\"controls\" style=\"max-width:100%\"></video></p><p>&#8203</p>");
  13012. } else {
  13013. editor.cmd["do"]('insertHTML', "<video src=\"" + url + "\" controls=\"controls\" style=\"max-width:100%\"></video>" + const_1.EMPTY_P);
  13014. }
  13015. } else {
  13016. config.customInsertVideo(url);
  13017. return;
  13018. } // 加载视频
  13019. var video = document.createElement('video');
  13020. video.onload = function () {
  13021. video = null;
  13022. };
  13023. video.onerror = function () {
  13024. config.customAlert(t('插入视频错误'), 'error', "wangEditor: " + t('插入视频错误') + "\uFF0C" + t('视频链接') + " \"" + url + "\"\uFF0C" + t('下载链接失败'));
  13025. video = null;
  13026. };
  13027. video.onabort = function () {
  13028. return video = null;
  13029. };
  13030. video.src = url;
  13031. };
  13032. return UploadVideo;
  13033. }();
  13034. exports["default"] = UploadVideo;
  13035. /***/ }),
  13036. /* 357 */
  13037. /***/ (function(module, exports, __webpack_require__) {
  13038. module.exports = __webpack_require__(358);
  13039. /***/ }),
  13040. /* 358 */
  13041. /***/ (function(module, exports, __webpack_require__) {
  13042. var parent = __webpack_require__(359);
  13043. module.exports = parent;
  13044. /***/ }),
  13045. /* 359 */
  13046. /***/ (function(module, exports, __webpack_require__) {
  13047. __webpack_require__(360);
  13048. var path = __webpack_require__(11);
  13049. module.exports = path.Date.now;
  13050. /***/ }),
  13051. /* 360 */
  13052. /***/ (function(module, exports, __webpack_require__) {
  13053. var $ = __webpack_require__(5);
  13054. // `Date.now` method
  13055. // https://tc39.es/ecma262/#sec-date.now
  13056. $({ target: 'Date', stat: true }, {
  13057. now: function now() {
  13058. return new Date().getTime();
  13059. }
  13060. });
  13061. /***/ }),
  13062. /* 361 */
  13063. /***/ (function(module, exports, __webpack_require__) {
  13064. "use strict";
  13065. /**
  13066. * @description 绑定视频的事件
  13067. * @author lichunlin
  13068. */
  13069. var _interopRequireDefault = __webpack_require__(0);
  13070. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13071. (0, _defineProperty["default"])(exports, "__esModule", {
  13072. value: true
  13073. });
  13074. var tslib_1 = __webpack_require__(2);
  13075. var tooltip_event_1 = tslib_1.__importDefault(__webpack_require__(362));
  13076. var keyboard_1 = tslib_1.__importDefault(__webpack_require__(364));
  13077. /**
  13078. * 绑定事件
  13079. * @param editor 编辑器实例
  13080. */
  13081. function bindEvent(editor) {
  13082. //Tooltip
  13083. tooltip_event_1["default"](editor);
  13084. keyboard_1["default"](editor);
  13085. }
  13086. exports["default"] = bindEvent;
  13087. /***/ }),
  13088. /* 362 */
  13089. /***/ (function(module, exports, __webpack_require__) {
  13090. "use strict";
  13091. /**
  13092. * @description tooltip 事件
  13093. * @author lichunlin
  13094. */
  13095. var _interopRequireDefault = __webpack_require__(0);
  13096. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13097. (0, _defineProperty["default"])(exports, "__esModule", {
  13098. value: true
  13099. });
  13100. exports.createShowHideFn = void 0;
  13101. var tslib_1 = __webpack_require__(2);
  13102. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  13103. var Tooltip_1 = tslib_1.__importDefault(__webpack_require__(37));
  13104. var video_alignment_1 = tslib_1.__importDefault(__webpack_require__(363));
  13105. /**
  13106. * 生成 Tooltip 的显示隐藏函数
  13107. */
  13108. function createShowHideFn(editor) {
  13109. var tooltip;
  13110. var t = function t(text, prefix) {
  13111. if (prefix === void 0) {
  13112. prefix = '';
  13113. }
  13114. return editor.i18next.t(prefix + text);
  13115. };
  13116. /**
  13117. * 显示 tooltip
  13118. * @param $node 链接元素
  13119. */
  13120. function showVideoTooltip($node) {
  13121. var conf = [{
  13122. $elem: dom_core_1["default"]("<span class='w-e-icon-trash-o'></span>"),
  13123. onClick: function onClick(editor, $node) {
  13124. // 选中video元素 删除
  13125. $node.remove(); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13126. return true;
  13127. }
  13128. }, {
  13129. $elem: dom_core_1["default"]('<span>100%</span>'),
  13130. onClick: function onClick(editor, $node) {
  13131. $node.attr('width', '100%');
  13132. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13133. return true;
  13134. }
  13135. }, {
  13136. $elem: dom_core_1["default"]('<span>50%</span>'),
  13137. onClick: function onClick(editor, $node) {
  13138. $node.attr('width', '50%');
  13139. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13140. return true;
  13141. }
  13142. }, {
  13143. $elem: dom_core_1["default"]('<span>30%</span>'),
  13144. onClick: function onClick(editor, $node) {
  13145. $node.attr('width', '30%');
  13146. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13147. return true;
  13148. }
  13149. }, {
  13150. $elem: dom_core_1["default"]("<span>" + t('重置') + "</span>"),
  13151. onClick: function onClick(editor, $node) {
  13152. $node.removeAttr('width');
  13153. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13154. return true;
  13155. }
  13156. }, {
  13157. $elem: dom_core_1["default"]("<span>" + t('menus.justify.靠左') + "</span>"),
  13158. onClick: function onClick(editor, $node) {
  13159. // 获取顶级元素
  13160. video_alignment_1["default"]($node, 'left'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13161. return true;
  13162. }
  13163. }, {
  13164. $elem: dom_core_1["default"]("<span>" + t('menus.justify.居中') + "</span>"),
  13165. onClick: function onClick(editor, $node) {
  13166. // 获取顶级元素
  13167. video_alignment_1["default"]($node, 'center'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13168. return true;
  13169. }
  13170. }, {
  13171. $elem: dom_core_1["default"]("<span>" + t('menus.justify.靠右') + "</span>"),
  13172. onClick: function onClick(editor, $node) {
  13173. // 获取顶级元素
  13174. video_alignment_1["default"]($node, 'right'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13175. return true;
  13176. }
  13177. }];
  13178. tooltip = new Tooltip_1["default"](editor, $node, conf);
  13179. tooltip.create();
  13180. }
  13181. /**
  13182. * 隐藏 tooltip
  13183. */
  13184. function hideVideoTooltip() {
  13185. // 移除 tooltip
  13186. if (tooltip) {
  13187. tooltip.remove();
  13188. tooltip = null;
  13189. }
  13190. }
  13191. return {
  13192. showVideoTooltip: showVideoTooltip,
  13193. hideVideoTooltip: hideVideoTooltip
  13194. };
  13195. }
  13196. exports.createShowHideFn = createShowHideFn;
  13197. /**
  13198. * 绑定 tooltip 事件
  13199. * @param editor 编辑器实例
  13200. */
  13201. function bindTooltipEvent(editor) {
  13202. var _a = createShowHideFn(editor),
  13203. showVideoTooltip = _a.showVideoTooltip,
  13204. hideVideoTooltip = _a.hideVideoTooltip; // 点击视频元素是,显示 tooltip
  13205. editor.txt.eventHooks.videoClickEvents.push(showVideoTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
  13206. editor.txt.eventHooks.clickEvents.push(hideVideoTooltip);
  13207. editor.txt.eventHooks.keyupEvents.push(hideVideoTooltip);
  13208. editor.txt.eventHooks.toolbarClickEvents.push(hideVideoTooltip);
  13209. editor.txt.eventHooks.menuClickEvents.push(hideVideoTooltip);
  13210. editor.txt.eventHooks.textScrollEvents.push(hideVideoTooltip); // change 时隐藏
  13211. editor.txt.eventHooks.changeEvents.push(hideVideoTooltip);
  13212. }
  13213. exports["default"] = bindTooltipEvent;
  13214. /***/ }),
  13215. /* 363 */
  13216. /***/ (function(module, exports, __webpack_require__) {
  13217. "use strict";
  13218. /**
  13219. * @description 视频布局 事件
  13220. * @author lichunlin
  13221. */
  13222. var _interopRequireDefault = __webpack_require__(0);
  13223. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13224. var _includes = _interopRequireDefault(__webpack_require__(46));
  13225. (0, _defineProperty["default"])(exports, "__esModule", {
  13226. value: true
  13227. });
  13228. var tslib_1 = __webpack_require__(2);
  13229. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3)); // 设置布局方式
  13230. function setAlignment($node, value) {
  13231. // 设置顶级元素匹配
  13232. var NODENAME = ['P']; // 获取匹配得顶级元素
  13233. var topNode = getSelectedTopNode($node, NODENAME); // 判断是否存在
  13234. if (topNode) {
  13235. dom_core_1["default"](topNode).css('text-align', value);
  13236. }
  13237. }
  13238. exports["default"] = setAlignment;
  13239. /**
  13240. * 获取选中的元素的顶级元素
  13241. * @params el 选中的元素
  13242. * @params tag 匹配顶级的元素 如 P LI ....
  13243. */
  13244. function getSelectedTopNode(el, tag) {
  13245. var _a;
  13246. var parentNode = el.elems[0]; // 可能出现嵌套的情况,所以一级一级向上找,找到指定得顶级元素
  13247. while (parentNode != null) {
  13248. if ((0, _includes["default"])(tag).call(tag, parentNode === null || parentNode === void 0 ? void 0 : parentNode.nodeName)) {
  13249. return parentNode;
  13250. } // 兜底 body
  13251. if (((_a = parentNode === null || parentNode === void 0 ? void 0 : parentNode.parentNode) === null || _a === void 0 ? void 0 : _a.nodeName) === 'BODY') {
  13252. return null;
  13253. }
  13254. parentNode = parentNode.parentNode;
  13255. }
  13256. return parentNode;
  13257. }
  13258. /***/ }),
  13259. /* 364 */
  13260. /***/ (function(module, exports, __webpack_require__) {
  13261. "use strict";
  13262. var _interopRequireDefault = __webpack_require__(0);
  13263. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13264. (0, _defineProperty["default"])(exports, "__esModule", {
  13265. value: true
  13266. });
  13267. var util_1 = __webpack_require__(6);
  13268. function bindEventKeyboardEvent(editor) {
  13269. if (!util_1.UA.isFirefox) return;
  13270. var txt = editor.txt,
  13271. selection = editor.selection;
  13272. var keydownEvents = txt.eventHooks.keydownEvents;
  13273. keydownEvents.push(function (e) {
  13274. // 实时保存选区
  13275. // editor.selection.saveRange()
  13276. var $selectionContainerElem = selection.getSelectionContainerElem();
  13277. if ($selectionContainerElem) {
  13278. var $topElem = $selectionContainerElem.getNodeTop(editor);
  13279. var $preElem = $topElem.length ? $topElem.prev().length ? $topElem.prev() : null : null;
  13280. if ($preElem && $preElem.attr('data-we-video-p')) {
  13281. // 光标处于选区开头
  13282. if (selection.getCursorPos() === 0) {
  13283. // 如果上一个dom是包含video, 按下删除连video一块删除
  13284. if (e.keyCode === 8) {
  13285. $preElem.remove();
  13286. }
  13287. }
  13288. }
  13289. }
  13290. });
  13291. }
  13292. exports["default"] = bindEventKeyboardEvent;
  13293. /***/ }),
  13294. /* 365 */
  13295. /***/ (function(module, exports, __webpack_require__) {
  13296. "use strict";
  13297. /**
  13298. * @description 插入、上传图片
  13299. * @author wangfupeng
  13300. */
  13301. var _interopRequireDefault = __webpack_require__(0);
  13302. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13303. var _map = _interopRequireDefault(__webpack_require__(27));
  13304. (0, _defineProperty["default"])(exports, "__esModule", {
  13305. value: true
  13306. });
  13307. var tslib_1 = __webpack_require__(2);
  13308. var const_1 = __webpack_require__(7);
  13309. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  13310. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  13311. var PanelMenu_1 = tslib_1.__importDefault(__webpack_require__(36));
  13312. var index_1 = tslib_1.__importDefault(__webpack_require__(366));
  13313. var create_panel_conf_1 = tslib_1.__importDefault(__webpack_require__(379));
  13314. var Image = function (_super) {
  13315. tslib_1.__extends(Image, _super);
  13316. function Image(editor) {
  13317. var _this = this;
  13318. var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="图片"><i class="w-e-icon-image"></i></div>');
  13319. var imgPanelConfig = create_panel_conf_1["default"](editor);
  13320. if (imgPanelConfig.onlyUploadConf) {
  13321. var _context;
  13322. $elem = imgPanelConfig.onlyUploadConf.$elem;
  13323. (0, _map["default"])(_context = imgPanelConfig.onlyUploadConf.events).call(_context, function (event) {
  13324. var type = event.type;
  13325. var fn = event.fn || const_1.EMPTY_FN;
  13326. $elem.on(type, function (e) {
  13327. e.stopPropagation();
  13328. fn(e);
  13329. });
  13330. });
  13331. }
  13332. _this = _super.call(this, $elem, editor) || this;
  13333. _this.imgPanelConfig = imgPanelConfig; // 绑定事件,如粘贴图片
  13334. index_1["default"](editor);
  13335. return _this;
  13336. }
  13337. /**
  13338. * 菜单点击事件
  13339. */
  13340. Image.prototype.clickHandler = function () {
  13341. if (!this.imgPanelConfig.onlyUploadConf) {
  13342. this.createPanel();
  13343. }
  13344. };
  13345. /**
  13346. * 创建 panel
  13347. */
  13348. Image.prototype.createPanel = function () {
  13349. var conf = this.imgPanelConfig;
  13350. var panel = new Panel_1["default"](this, conf);
  13351. this.setPanel(panel);
  13352. panel.create();
  13353. };
  13354. /**
  13355. * 尝试修改菜单 active 状态
  13356. */
  13357. Image.prototype.tryChangeActive = function () {};
  13358. return Image;
  13359. }(PanelMenu_1["default"]);
  13360. exports["default"] = Image;
  13361. /***/ }),
  13362. /* 366 */
  13363. /***/ (function(module, exports, __webpack_require__) {
  13364. "use strict";
  13365. /**
  13366. * @description 绑定图片的事件
  13367. * @author wangfupeng
  13368. */
  13369. var _interopRequireDefault = __webpack_require__(0);
  13370. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13371. (0, _defineProperty["default"])(exports, "__esModule", {
  13372. value: true
  13373. });
  13374. var tslib_1 = __webpack_require__(2);
  13375. var paste_img_1 = tslib_1.__importDefault(__webpack_require__(367));
  13376. var drop_img_1 = tslib_1.__importDefault(__webpack_require__(368));
  13377. var drag_size_1 = tslib_1.__importDefault(__webpack_require__(369));
  13378. var tooltip_event_1 = tslib_1.__importDefault(__webpack_require__(377));
  13379. var keyboard_event_1 = tslib_1.__importDefault(__webpack_require__(378));
  13380. /**
  13381. * 绑定事件
  13382. * @param editor 编辑器实例
  13383. */
  13384. function bindEvent(editor) {
  13385. // 粘贴图片
  13386. paste_img_1["default"](editor); // 拖拽图片
  13387. drop_img_1["default"](editor); // 可再扩展其他事件...如图片 tooltip 等
  13388. // 拖拽图片尺寸
  13389. drag_size_1["default"](editor); //Tooltip
  13390. tooltip_event_1["default"](editor);
  13391. keyboard_event_1["default"](editor);
  13392. }
  13393. exports["default"] = bindEvent;
  13394. /***/ }),
  13395. /* 367 */
  13396. /***/ (function(module, exports, __webpack_require__) {
  13397. "use strict";
  13398. /**
  13399. * @description 粘贴图片
  13400. * @author wangfupeng
  13401. */
  13402. var _interopRequireDefault = __webpack_require__(0);
  13403. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13404. (0, _defineProperty["default"])(exports, "__esModule", {
  13405. value: true
  13406. });
  13407. var tslib_1 = __webpack_require__(2);
  13408. var paste_event_1 = __webpack_require__(135);
  13409. var upload_img_1 = tslib_1.__importDefault(__webpack_require__(104));
  13410. /**
  13411. * 剪切板是否有 text 或者 html ?
  13412. * @param editor 编辑器对象
  13413. * @param e 粘贴事件参数
  13414. */
  13415. function _haveTextOrHtml(editor, e) {
  13416. var config = editor.config;
  13417. var pasteFilterStyle = config.pasteFilterStyle;
  13418. var pasteIgnoreImg = config.pasteIgnoreImg;
  13419. var pasteHtml = paste_event_1.getPasteHtml(e, pasteFilterStyle, pasteIgnoreImg);
  13420. if (pasteHtml) return true;
  13421. var pasteText = paste_event_1.getPasteText(e);
  13422. if (pasteText) return true;
  13423. return false; // text html 都没有,则返回 false
  13424. }
  13425. /**
  13426. * 剪切板是否有 Files
  13427. * @param editor 编辑器对象
  13428. * @param e 粘贴事件参数
  13429. */
  13430. function _haveFiles(editor, e) {
  13431. var _a;
  13432. var types = ((_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.types) || [];
  13433. for (var i = 0; i < types.length; i++) {
  13434. var type = types[i];
  13435. if (type === 'Files') {
  13436. return true;
  13437. }
  13438. }
  13439. return false;
  13440. }
  13441. /**
  13442. * 粘贴图片事件方法
  13443. * @param e 事件参数
  13444. */
  13445. function pasteImgHandler(e, editor) {
  13446. // 粘贴过来的没有 file 时,判断 text 或者 html
  13447. if (!_haveFiles(editor, e)) {
  13448. if (_haveTextOrHtml(editor, e)) {
  13449. // 粘贴过来的有 text 或者 html ,则不执行粘贴图片逻辑
  13450. return;
  13451. }
  13452. } // 获取粘贴的图片列表
  13453. var pastedFiles = paste_event_1.getPasteImgs(e);
  13454. if (!pastedFiles.length) {
  13455. return;
  13456. } // code 中忽略(暂不管它)
  13457. // 执行上传
  13458. var uploadImg = new upload_img_1["default"](editor);
  13459. uploadImg.uploadImg(pastedFiles);
  13460. }
  13461. /**
  13462. * 粘贴图片
  13463. * @param editor 编辑器对象
  13464. * @param pasteEvents 粘贴事件列表
  13465. */
  13466. function bindPasteImg(editor) {
  13467. /**
  13468. * 绑定 paste 事件
  13469. * 这里使用了unshift,以前是push
  13470. * 在以前的流程中,pasteImgHandler触发之前,会调用到window.getSelection().removeAllRanges()
  13471. * 会导致性能变差。在编辑器中粘贴,粘贴耗时多了100+ms,根本原因未知
  13472. * 最小复现demo,在div内粘贴图片就可以看到getData耗时异常得长
  13473. * <html>
  13474. * <div id="a" contenteditable="true"></div>
  13475. * <script>
  13476. * const div = document.getElementById('a')
  13477. * div.addEventListener('paste', (e) => {
  13478. * window.getSelection().removeAllRanges()
  13479. * e.clipboardData.getData('text/html')
  13480. * })
  13481. * </script>
  13482. * </html>
  13483. * 因此改成unshift,先触发pasteImgHandler就不会有性能问题
  13484. */
  13485. editor.txt.eventHooks.pasteEvents.unshift(function (e) {
  13486. pasteImgHandler(e, editor);
  13487. });
  13488. }
  13489. exports["default"] = bindPasteImg;
  13490. /***/ }),
  13491. /* 368 */
  13492. /***/ (function(module, exports, __webpack_require__) {
  13493. "use strict";
  13494. /**
  13495. * @description 拖拽上传图片
  13496. * @author wangfupeng
  13497. */
  13498. var _interopRequireDefault = __webpack_require__(0);
  13499. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13500. (0, _defineProperty["default"])(exports, "__esModule", {
  13501. value: true
  13502. });
  13503. var tslib_1 = __webpack_require__(2);
  13504. var upload_img_1 = tslib_1.__importDefault(__webpack_require__(104));
  13505. function bindDropImg(editor) {
  13506. /**
  13507. * 拖拽图片的事件
  13508. * @param e 事件参数
  13509. */
  13510. function dropImgHandler(e) {
  13511. var files = e.dataTransfer && e.dataTransfer.files;
  13512. if (!files || !files.length) {
  13513. return;
  13514. } // 上传图片
  13515. var uploadImg = new upload_img_1["default"](editor);
  13516. uploadImg.uploadImg(files);
  13517. } // 绑定 drop 事件
  13518. editor.txt.eventHooks.dropEvents.push(dropImgHandler);
  13519. }
  13520. exports["default"] = bindDropImg;
  13521. /***/ }),
  13522. /* 369 */
  13523. /***/ (function(module, exports, __webpack_require__) {
  13524. "use strict";
  13525. /**
  13526. * @description 图片拖拽事件绑定
  13527. * @author xiaokyo
  13528. */
  13529. var _interopRequireDefault = __webpack_require__(0);
  13530. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13531. var _find = _interopRequireDefault(__webpack_require__(32));
  13532. var _parseFloat2 = _interopRequireDefault(__webpack_require__(370));
  13533. (0, _defineProperty["default"])(exports, "__esModule", {
  13534. value: true
  13535. });
  13536. exports.createShowHideFn = void 0;
  13537. var tslib_1 = __webpack_require__(2);
  13538. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  13539. __webpack_require__(375);
  13540. var util_1 = __webpack_require__(6);
  13541. /**
  13542. * 设置拖拽框的rect
  13543. * @param $drag drag Dom
  13544. * @param width 要设置的宽度
  13545. * @param height 要设置的高度
  13546. * @param left 要设置的左边
  13547. * @param top 要设置的顶部距离
  13548. */
  13549. function setDragStyle($drag, width, height, left, top) {
  13550. $drag.attr('style', "width:" + width + "px; height:" + height + "px; left:" + left + "px; top:" + top + "px;");
  13551. }
  13552. /**
  13553. * 生成一个图片指定大小的拖拽框
  13554. * @param editor 编辑器实例
  13555. * @param $textContainerElem 编辑框对象
  13556. */
  13557. function createDragBox(editor, $textContainerElem) {
  13558. var $drag = dom_core_1["default"]("<div class=\"w-e-img-drag-mask\">\n <div class=\"w-e-img-drag-show-size\"></div>\n <div class=\"w-e-img-drag-rb\"></div>\n </div>");
  13559. $drag.hide();
  13560. $textContainerElem.append($drag);
  13561. return $drag;
  13562. }
  13563. /**
  13564. * 显示拖拽框并设置宽度
  13565. * @param $textContainerElem 编辑框实例
  13566. * @param $drag 拖拽框对象
  13567. */
  13568. function showDargBox($textContainerElem, $drag, $img) {
  13569. var boxRect = $textContainerElem.getBoundingClientRect();
  13570. var rect = $img.getBoundingClientRect();
  13571. var rectW = rect.width.toFixed(2);
  13572. var rectH = rect.height.toFixed(2);
  13573. (0, _find["default"])($drag).call($drag, '.w-e-img-drag-show-size').text(rectW + "px * " + rectH + "px");
  13574. setDragStyle($drag, (0, _parseFloat2["default"])(rectW), (0, _parseFloat2["default"])(rectH), rect.left - boxRect.left, rect.top - boxRect.top);
  13575. $drag.show();
  13576. }
  13577. /**
  13578. * 生成图片拖拽框的 显示/隐藏 函数
  13579. */
  13580. function createShowHideFn(editor) {
  13581. var $textContainerElem = editor.$textContainerElem;
  13582. var $imgTarget; // 生成拖拽框
  13583. var $drag = createDragBox(editor, $textContainerElem);
  13584. /**
  13585. * 设置拖拽事件
  13586. * @param $drag 拖拽框的domElement
  13587. * @param $textContainerElem 编辑器实例
  13588. */
  13589. function bindDragEvents($drag, $container) {
  13590. $drag.on('click', function (e) {
  13591. e.stopPropagation();
  13592. });
  13593. $drag.on('mousedown', '.w-e-img-drag-rb', function (e) {
  13594. // e.stopPropagation()
  13595. e.preventDefault();
  13596. if (!$imgTarget) return;
  13597. var firstX = e.clientX;
  13598. var firstY = e.clientY;
  13599. var boxRect = $container.getBoundingClientRect();
  13600. var imgRect = $imgTarget.getBoundingClientRect();
  13601. var width = imgRect.width;
  13602. var height = imgRect.height;
  13603. var left = imgRect.left - boxRect.left;
  13604. var top = imgRect.top - boxRect.top;
  13605. var ratio = width / height;
  13606. var setW = width;
  13607. var setH = height;
  13608. var $document = dom_core_1["default"](document);
  13609. function offEvents() {
  13610. $document.off('mousemove', mouseMoveHandler);
  13611. $document.off('mouseup', mouseUpHandler);
  13612. }
  13613. function mouseMoveHandler(ev) {
  13614. ev.stopPropagation();
  13615. ev.preventDefault();
  13616. setW = width + (ev.clientX - firstX);
  13617. setH = height + (ev.clientY - firstY); // 等比计算
  13618. if (setW / setH != ratio) {
  13619. setH = setW / ratio;
  13620. }
  13621. setW = (0, _parseFloat2["default"])(setW.toFixed(2));
  13622. setH = (0, _parseFloat2["default"])(setH.toFixed(2));
  13623. (0, _find["default"])($drag).call($drag, '.w-e-img-drag-show-size').text(setW.toFixed(2).replace('.00', '') + "px * " + setH.toFixed(2).replace('.00', '') + "px");
  13624. setDragStyle($drag, setW, setH, left, top);
  13625. }
  13626. $document.on('mousemove', mouseMoveHandler);
  13627. function mouseUpHandler() {
  13628. $imgTarget.attr('width', setW + '');
  13629. $imgTarget.attr('height', setH + '');
  13630. var newImgRect = $imgTarget.getBoundingClientRect();
  13631. setDragStyle($drag, setW, setH, newImgRect.left - boxRect.left, newImgRect.top - boxRect.top); // 解绑事件
  13632. offEvents();
  13633. }
  13634. $document.on('mouseup', mouseUpHandler); // 解绑事件
  13635. $document.on('mouseleave', offEvents);
  13636. });
  13637. } // 显示拖拽框
  13638. function showDrag($target) {
  13639. if (util_1.UA.isIE()) return false;
  13640. if ($target) {
  13641. $imgTarget = $target;
  13642. showDargBox($textContainerElem, $drag, $imgTarget);
  13643. }
  13644. } // 隐藏拖拽框
  13645. function hideDrag() {
  13646. (0, _find["default"])($textContainerElem).call($textContainerElem, '.w-e-img-drag-mask').hide();
  13647. } // 事件绑定
  13648. bindDragEvents($drag, $textContainerElem); // 后期改成 blur 触发
  13649. dom_core_1["default"](document).on('click', hideDrag);
  13650. editor.beforeDestroy(function () {
  13651. dom_core_1["default"](document).off('click', hideDrag);
  13652. });
  13653. return {
  13654. showDrag: showDrag,
  13655. hideDrag: hideDrag
  13656. };
  13657. }
  13658. exports.createShowHideFn = createShowHideFn;
  13659. /**
  13660. * 点击事件委托
  13661. * @param editor 编辑器实例
  13662. */
  13663. function bindDragImgSize(editor) {
  13664. var _a = createShowHideFn(editor),
  13665. showDrag = _a.showDrag,
  13666. hideDrag = _a.hideDrag; // 显示拖拽框
  13667. editor.txt.eventHooks.imgClickEvents.push(showDrag); // 隐藏拖拽框
  13668. editor.txt.eventHooks.textScrollEvents.push(hideDrag);
  13669. editor.txt.eventHooks.keyupEvents.push(hideDrag);
  13670. editor.txt.eventHooks.toolbarClickEvents.push(hideDrag);
  13671. editor.txt.eventHooks.menuClickEvents.push(hideDrag);
  13672. editor.txt.eventHooks.changeEvents.push(hideDrag);
  13673. }
  13674. exports["default"] = bindDragImgSize;
  13675. /***/ }),
  13676. /* 370 */
  13677. /***/ (function(module, exports, __webpack_require__) {
  13678. module.exports = __webpack_require__(371);
  13679. /***/ }),
  13680. /* 371 */
  13681. /***/ (function(module, exports, __webpack_require__) {
  13682. var parent = __webpack_require__(372);
  13683. module.exports = parent;
  13684. /***/ }),
  13685. /* 372 */
  13686. /***/ (function(module, exports, __webpack_require__) {
  13687. __webpack_require__(373);
  13688. var path = __webpack_require__(11);
  13689. module.exports = path.parseFloat;
  13690. /***/ }),
  13691. /* 373 */
  13692. /***/ (function(module, exports, __webpack_require__) {
  13693. var $ = __webpack_require__(5);
  13694. var parseFloatImplementation = __webpack_require__(374);
  13695. // `parseFloat` method
  13696. // https://tc39.es/ecma262/#sec-parsefloat-string
  13697. $({ global: true, forced: parseFloat != parseFloatImplementation }, {
  13698. parseFloat: parseFloatImplementation
  13699. });
  13700. /***/ }),
  13701. /* 374 */
  13702. /***/ (function(module, exports, __webpack_require__) {
  13703. var global = __webpack_require__(8);
  13704. var toString = __webpack_require__(30);
  13705. var trim = __webpack_require__(97).trim;
  13706. var whitespaces = __webpack_require__(74);
  13707. var $parseFloat = global.parseFloat;
  13708. var FORCED = 1 / $parseFloat(whitespaces + '-0') !== -Infinity;
  13709. // `parseFloat` method
  13710. // https://tc39.es/ecma262/#sec-parsefloat-string
  13711. module.exports = FORCED ? function parseFloat(string) {
  13712. var trimmedString = trim(toString(string));
  13713. var result = $parseFloat(trimmedString);
  13714. return result === 0 && trimmedString.charAt(0) == '-' ? -0 : result;
  13715. } : $parseFloat;
  13716. /***/ }),
  13717. /* 375 */
  13718. /***/ (function(module, exports, __webpack_require__) {
  13719. var api = __webpack_require__(21);
  13720. var content = __webpack_require__(376);
  13721. content = content.__esModule ? content.default : content;
  13722. if (typeof content === 'string') {
  13723. content = [[module.i, content, '']];
  13724. }
  13725. var options = {};
  13726. options.insert = "head";
  13727. options.singleton = false;
  13728. var update = api(content, options);
  13729. module.exports = content.locals || {};
  13730. /***/ }),
  13731. /* 376 */
  13732. /***/ (function(module, exports, __webpack_require__) {
  13733. // Imports
  13734. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  13735. exports = ___CSS_LOADER_API_IMPORT___(false);
  13736. // Module
  13737. exports.push([module.i, ".w-e-text-container {\n overflow: hidden;\n}\n.w-e-img-drag-mask {\n position: absolute;\n z-index: 1;\n border: 1px dashed #ccc;\n box-sizing: border-box;\n}\n.w-e-img-drag-mask .w-e-img-drag-rb {\n position: absolute;\n right: -5px;\n bottom: -5px;\n width: 16px;\n height: 16px;\n border-radius: 50%;\n background: #ccc;\n cursor: se-resize;\n}\n.w-e-img-drag-mask .w-e-img-drag-show-size {\n min-width: 110px;\n height: 22px;\n line-height: 22px;\n font-size: 14px;\n color: #999;\n position: absolute;\n left: 0;\n top: 0;\n background-color: #999;\n color: #fff;\n border-radius: 2px;\n padding: 0 5px;\n}\n", ""]);
  13738. // Exports
  13739. module.exports = exports;
  13740. /***/ }),
  13741. /* 377 */
  13742. /***/ (function(module, exports, __webpack_require__) {
  13743. "use strict";
  13744. /**
  13745. * @description tooltip 事件
  13746. * @author lichunlin
  13747. */
  13748. var _interopRequireDefault = __webpack_require__(0);
  13749. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13750. (0, _defineProperty["default"])(exports, "__esModule", {
  13751. value: true
  13752. });
  13753. exports.createShowHideFn = void 0;
  13754. var tslib_1 = __webpack_require__(2);
  13755. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  13756. var Tooltip_1 = tslib_1.__importDefault(__webpack_require__(37));
  13757. /**
  13758. * 生成 Tooltip 的显示隐藏函数
  13759. */
  13760. function createShowHideFn(editor) {
  13761. var tooltip;
  13762. var t = function t(text, prefix) {
  13763. if (prefix === void 0) {
  13764. prefix = '';
  13765. }
  13766. return editor.i18next.t(prefix + text);
  13767. };
  13768. /**
  13769. * 显示 tooltip
  13770. * @param $node 链接元素
  13771. */
  13772. function showImgTooltip($node) {
  13773. var conf = [{
  13774. $elem: dom_core_1["default"]("<span class='w-e-icon-trash-o'></span>"),
  13775. onClick: function onClick(editor, $node) {
  13776. // 选中img元素
  13777. editor.selection.createRangeByElem($node);
  13778. editor.selection.restoreSelection();
  13779. editor.cmd["do"]('delete'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13780. return true;
  13781. }
  13782. }, {
  13783. $elem: dom_core_1["default"]('<span>30%</span>'),
  13784. onClick: function onClick(editor, $node) {
  13785. $node.attr('width', '30%');
  13786. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13787. return true;
  13788. }
  13789. }, {
  13790. $elem: dom_core_1["default"]('<span>50%</span>'),
  13791. onClick: function onClick(editor, $node) {
  13792. $node.attr('width', '50%');
  13793. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13794. return true;
  13795. }
  13796. }, {
  13797. $elem: dom_core_1["default"]('<span>100%</span>'),
  13798. onClick: function onClick(editor, $node) {
  13799. $node.attr('width', '100%');
  13800. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13801. return true;
  13802. }
  13803. }];
  13804. conf.push({
  13805. $elem: dom_core_1["default"]("<span>" + t('重置') + "</span>"),
  13806. onClick: function onClick(editor, $node) {
  13807. $node.removeAttr('width');
  13808. $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13809. return true;
  13810. }
  13811. });
  13812. if ($node.attr('data-href')) {
  13813. conf.push({
  13814. $elem: dom_core_1["default"]("<span>" + t('查看链接') + "</span>"),
  13815. onClick: function onClick(editor, $node) {
  13816. var link = $node.attr('data-href');
  13817. if (link) {
  13818. link = decodeURIComponent(link);
  13819. window.open(link, '_target');
  13820. } // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  13821. return true;
  13822. }
  13823. });
  13824. }
  13825. tooltip = new Tooltip_1["default"](editor, $node, conf);
  13826. tooltip.create();
  13827. }
  13828. /**
  13829. * 隐藏 tooltip
  13830. */
  13831. function hideImgTooltip() {
  13832. // 移除 tooltip
  13833. if (tooltip) {
  13834. tooltip.remove();
  13835. tooltip = null;
  13836. }
  13837. }
  13838. return {
  13839. showImgTooltip: showImgTooltip,
  13840. hideImgTooltip: hideImgTooltip
  13841. };
  13842. }
  13843. exports.createShowHideFn = createShowHideFn;
  13844. /**
  13845. * 绑定 tooltip 事件
  13846. * @param editor 编辑器实例
  13847. */
  13848. function bindTooltipEvent(editor) {
  13849. var _a = createShowHideFn(editor),
  13850. showImgTooltip = _a.showImgTooltip,
  13851. hideImgTooltip = _a.hideImgTooltip; // 点击图片元素是,显示 tooltip
  13852. editor.txt.eventHooks.imgClickEvents.push(showImgTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
  13853. editor.txt.eventHooks.clickEvents.push(hideImgTooltip);
  13854. editor.txt.eventHooks.keyupEvents.push(hideImgTooltip);
  13855. editor.txt.eventHooks.toolbarClickEvents.push(hideImgTooltip);
  13856. editor.txt.eventHooks.menuClickEvents.push(hideImgTooltip);
  13857. editor.txt.eventHooks.textScrollEvents.push(hideImgTooltip);
  13858. editor.txt.eventHooks.imgDragBarMouseDownEvents.push(hideImgTooltip); // change 时隐藏
  13859. editor.txt.eventHooks.changeEvents.push(hideImgTooltip);
  13860. }
  13861. exports["default"] = bindTooltipEvent;
  13862. /***/ }),
  13863. /* 378 */
  13864. /***/ (function(module, exports, __webpack_require__) {
  13865. "use strict";
  13866. var _interopRequireDefault = __webpack_require__(0);
  13867. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13868. (0, _defineProperty["default"])(exports, "__esModule", {
  13869. value: true
  13870. });
  13871. function bindEventKeyboardEvent(editor) {
  13872. var txt = editor.txt,
  13873. selection = editor.selection;
  13874. var keydownEvents = txt.eventHooks.keydownEvents;
  13875. keydownEvents.push(function (e) {
  13876. // 删除图片时,有时会因为浏览器bug删不掉。因此这里手动判断光标前面是不是图片,是就删掉
  13877. var $selectionContainerElem = selection.getSelectionContainerElem();
  13878. var range = selection.getRange();
  13879. if (!range || !$selectionContainerElem || e.keyCode !== 8 || !selection.isSelectionEmpty()) {
  13880. return;
  13881. }
  13882. var startContainer = range.startContainer,
  13883. startOffset = range.startOffset; // 同一段落内上一个节点
  13884. var prevNode = null;
  13885. if (startOffset === 0) {
  13886. // 此时上一个节点需要通过previousSibling去找
  13887. while (startContainer !== $selectionContainerElem.elems[0] && $selectionContainerElem.elems[0].contains(startContainer) && startContainer.parentNode && !prevNode) {
  13888. if (startContainer.previousSibling) {
  13889. prevNode = startContainer.previousSibling;
  13890. break;
  13891. }
  13892. startContainer = startContainer.parentNode;
  13893. }
  13894. } else if (startContainer.nodeType !== 3) {
  13895. // 非文本节点才需要被处理,比如p
  13896. prevNode = startContainer.childNodes[startOffset - 1];
  13897. }
  13898. if (!prevNode) {
  13899. return;
  13900. }
  13901. var lastChildNodeInPrevNode = prevNode; // 找到最右侧叶子节点
  13902. while (lastChildNodeInPrevNode.childNodes.length) {
  13903. lastChildNodeInPrevNode = lastChildNodeInPrevNode.childNodes[lastChildNodeInPrevNode.childNodes.length - 1];
  13904. }
  13905. if (lastChildNodeInPrevNode instanceof HTMLElement && lastChildNodeInPrevNode.tagName === 'IMG') {
  13906. lastChildNodeInPrevNode.remove();
  13907. e.preventDefault();
  13908. }
  13909. });
  13910. }
  13911. exports["default"] = bindEventKeyboardEvent;
  13912. /***/ }),
  13913. /* 379 */
  13914. /***/ (function(module, exports, __webpack_require__) {
  13915. "use strict";
  13916. /**
  13917. * @description image 菜单 panel tab 配置
  13918. * @author wangfupeng
  13919. */
  13920. var _interopRequireDefault = __webpack_require__(0);
  13921. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  13922. var _map = _interopRequireDefault(__webpack_require__(27));
  13923. var _trim = _interopRequireDefault(__webpack_require__(16));
  13924. (0, _defineProperty["default"])(exports, "__esModule", {
  13925. value: true
  13926. });
  13927. var tslib_1 = __webpack_require__(2);
  13928. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  13929. var util_1 = __webpack_require__(6);
  13930. var upload_img_1 = tslib_1.__importDefault(__webpack_require__(104));
  13931. function default_1(editor) {
  13932. var _context;
  13933. var config = editor.config;
  13934. var uploadImg = new upload_img_1["default"](editor); // panel 中需要用到的id
  13935. var upTriggerId = util_1.getRandom('up-trigger-id');
  13936. var upFileId = util_1.getRandom('up-file-id');
  13937. var linkUrlId = util_1.getRandom('input-link-url');
  13938. var linkUrlAltId = util_1.getRandom('input-link-url-alt');
  13939. var linkUrlHrefId = util_1.getRandom('input-link-url-href');
  13940. var linkBtnId = util_1.getRandom('btn-link');
  13941. var i18nPrefix = 'menus.panelMenus.image.';
  13942. var t = function t(text, prefix) {
  13943. if (prefix === void 0) {
  13944. prefix = i18nPrefix;
  13945. }
  13946. return editor.i18next.t(prefix + text);
  13947. };
  13948. /**
  13949. * 校验网络图片链接是否合法
  13950. * @param linkImg 网络图片链接
  13951. */
  13952. function checkLinkImg(src, linkUrlAltText, linkUrlHrefText) {
  13953. //查看开发者自定义配置的返回值
  13954. var check = config.linkImgCheck(src);
  13955. if (check === true) {
  13956. return true;
  13957. } else if (typeof check === 'string') {
  13958. //用户未能通过开发者的校验,开发者希望我们提示这一字符串
  13959. config.customAlert(check, 'error');
  13960. }
  13961. return false;
  13962. } // tabs 配置 -----------------------------------------
  13963. var fileMultipleAttr = config.uploadImgMaxLength === 1 ? '' : 'multiple="multiple"';
  13964. var accepts = (0, _map["default"])(_context = config.uploadImgAccept).call(_context, function (item) {
  13965. return "image/" + item;
  13966. }).join(',');
  13967. /**
  13968. * 设置模板的类名和icon图标
  13969. * w-e-menu是作为button菜单的模板
  13970. * w-e-up-img-container是做为panel菜单的窗口内容的模板
  13971. * @param containerClass 模板最外层的类名
  13972. * @param iconClass 模板中icon的类名
  13973. * @param titleName 模板中标题的名称 需要则设置不需要则设为空字符
  13974. */
  13975. var getUploadImgTpl = function getUploadImgTpl(containerClass, iconClass, titleName) {
  13976. return "<div class=\"" + containerClass + "\" data-title=\"" + titleName + "\">\n <div id=\"" + upTriggerId + "\" class=\"w-e-up-btn\">\n <i class=\"" + iconClass + "\"></i>\n </div>\n <div style=\"display:none;\">\n <input id=\"" + upFileId + "\" type=\"file\" " + fileMultipleAttr + " accept=\"" + accepts + "\"/>\n </div>\n </div>";
  13977. };
  13978. var uploadEvents = [// 触发选择图片
  13979. {
  13980. selector: '#' + upTriggerId,
  13981. type: 'click',
  13982. fn: function fn() {
  13983. var uploadImgFromMedia = config.uploadImgFromMedia;
  13984. if (uploadImgFromMedia && typeof uploadImgFromMedia === 'function') {
  13985. uploadImgFromMedia();
  13986. return true;
  13987. }
  13988. var $file = dom_core_1["default"]('#' + upFileId);
  13989. var fileElem = $file.elems[0];
  13990. if (fileElem) {
  13991. fileElem.click();
  13992. } else {
  13993. // 返回 true 可关闭 panel
  13994. return true;
  13995. }
  13996. }
  13997. }, // 选择图片完毕
  13998. {
  13999. selector: '#' + upFileId,
  14000. type: 'change',
  14001. fn: function fn() {
  14002. var $file = dom_core_1["default"]('#' + upFileId);
  14003. var fileElem = $file.elems[0];
  14004. if (!fileElem) {
  14005. // 返回 true 可关闭 panel
  14006. return true;
  14007. } // 获取选中的 file 对象列表
  14008. var fileList = fileElem.files;
  14009. if (fileList === null || fileList === void 0 ? void 0 : fileList.length) {
  14010. uploadImg.uploadImg(fileList);
  14011. } // 判断用于打开文件的input,有没有值,如果有就清空,以防上传同一张图片时,不会触发change事件
  14012. // input的功能只是单单为了打开文件而已,获取到需要的文件参数,当文件数据获取到后,可以清空。
  14013. if (fileElem) {
  14014. fileElem.value = '';
  14015. } // 返回 true 可关闭 panel
  14016. return true;
  14017. }
  14018. }];
  14019. var linkImgInputs = ["<input\n id=\"" + linkUrlId + "\"\n type=\"text\"\n class=\"block\"\n placeholder=\"" + t('图片地址') + "\"/>"];
  14020. if (config.showLinkImgAlt) {
  14021. linkImgInputs.push("\n <input\n id=\"" + linkUrlAltId + "\"\n type=\"text\"\n class=\"block\"\n placeholder=\"" + t('图片文字说明') + "\"/>");
  14022. }
  14023. if (config.showLinkImgHref) {
  14024. linkImgInputs.push("\n <input\n id=\"" + linkUrlHrefId + "\"\n type=\"text\"\n class=\"block\"\n placeholder=\"" + t('跳转链接') + "\"/>");
  14025. }
  14026. var tabsConf = [// first tab
  14027. {
  14028. // 标题
  14029. title: t('上传图片'),
  14030. // 模板
  14031. tpl: getUploadImgTpl('w-e-up-img-container', 'w-e-icon-upload2', ''),
  14032. // 事件绑定
  14033. events: uploadEvents
  14034. }, // second tab
  14035. {
  14036. title: t('网络图片'),
  14037. tpl: "<div>\n " + linkImgInputs.join('') + "\n <div class=\"w-e-button-container\">\n <button type=\"button\" id=\"" + linkBtnId + "\" class=\"right\">" + t('插入', '') + "</button>\n </div>\n </div>",
  14038. events: [{
  14039. selector: '#' + linkBtnId,
  14040. type: 'click',
  14041. fn: function fn() {
  14042. var _context2;
  14043. var $linkUrl = dom_core_1["default"]('#' + linkUrlId);
  14044. var url = (0, _trim["default"])(_context2 = $linkUrl.val()).call(_context2); //如果url为空则直接返回
  14045. if (!url) return;
  14046. var linkUrlAltText;
  14047. if (config.showLinkImgAlt) {
  14048. var _context3;
  14049. linkUrlAltText = (0, _trim["default"])(_context3 = dom_core_1["default"]('#' + linkUrlAltId).val()).call(_context3);
  14050. }
  14051. var linkUrlHrefText;
  14052. if (config.showLinkImgHref) {
  14053. var _context4;
  14054. linkUrlHrefText = (0, _trim["default"])(_context4 = dom_core_1["default"]('#' + linkUrlHrefId).val()).call(_context4);
  14055. } //如果不能通过校验也直接返回
  14056. if (!checkLinkImg(url, linkUrlAltText, linkUrlHrefText)) return; //插入图片url
  14057. uploadImg.insertImg(url, linkUrlAltText, linkUrlHrefText); // 返回 true 表示函数执行结束之后关闭 panel
  14058. return true;
  14059. },
  14060. bindEnter: true
  14061. }]
  14062. } // second tab end
  14063. ]; // tabs end
  14064. // 最终的配置 -----------------------------------------
  14065. var conf = {
  14066. width: 300,
  14067. height: 0,
  14068. tabs: [],
  14069. onlyUploadConf: {
  14070. $elem: dom_core_1["default"](getUploadImgTpl('w-e-menu', 'w-e-icon-image', '图片')),
  14071. events: uploadEvents
  14072. }
  14073. }; // 显示“上传图片”
  14074. if (window.FileReader && (config.uploadImgShowBase64 || config.uploadImgServer || config.customUploadImg || config.uploadImgFromMedia)) {
  14075. conf.tabs.push(tabsConf[0]);
  14076. } // 显示“插入网络图片”
  14077. if (config.showLinkImg) {
  14078. conf.tabs.push(tabsConf[1]);
  14079. conf.onlyUploadConf = undefined;
  14080. }
  14081. return conf;
  14082. }
  14083. exports["default"] = default_1;
  14084. /***/ }),
  14085. /* 380 */
  14086. /***/ (function(module, exports, __webpack_require__) {
  14087. "use strict";
  14088. /**
  14089. * @description 增加缩进/减少缩进
  14090. * @author tonghan
  14091. */
  14092. var _interopRequireDefault = __webpack_require__(0);
  14093. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14094. var _forEach = _interopRequireDefault(__webpack_require__(4));
  14095. (0, _defineProperty["default"])(exports, "__esModule", {
  14096. value: true
  14097. });
  14098. var tslib_1 = __webpack_require__(2);
  14099. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14100. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  14101. var operate_element_1 = tslib_1.__importDefault(__webpack_require__(381));
  14102. var Indent = function (_super) {
  14103. tslib_1.__extends(Indent, _super);
  14104. function Indent(editor) {
  14105. var _this = this;
  14106. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u7F29\u8FDB\">\n <i class=\"w-e-icon-indent-increase\"></i>\n </div>");
  14107. var dropListConf = {
  14108. width: 130,
  14109. title: '设置缩进',
  14110. type: 'list',
  14111. list: [{
  14112. $elem: dom_core_1["default"]("<p>\n <i class=\"w-e-icon-indent-increase w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.indent.增加缩进') + "\n <p>"),
  14113. value: 'increase'
  14114. }, {
  14115. $elem: dom_core_1["default"]("<p>\n <i class=\"w-e-icon-indent-decrease w-e-drop-list-item\"></i>\n " + editor.i18next.t('menus.dropListMenu.indent.减少缩进') + "\n <p>"),
  14116. value: 'decrease'
  14117. }],
  14118. clickHandler: function clickHandler(value) {
  14119. // 注意 this 是指向当前的 Indent 对象
  14120. _this.command(value);
  14121. }
  14122. };
  14123. _this = _super.call(this, $elem, editor, dropListConf) || this;
  14124. return _this;
  14125. }
  14126. /**
  14127. * 执行命令
  14128. * @param value value
  14129. */
  14130. Indent.prototype.command = function (value) {
  14131. var editor = this.editor;
  14132. var $selectionElem = editor.selection.getSelectionContainerElem(); // 判断 当前选区为 textElem 时
  14133. if ($selectionElem && editor.$textElem.equal($selectionElem)) {
  14134. // 当 当前选区 等于 textElem 时
  14135. // 代表 当前选区 可能是一个选择了一个完整的段落或者多个段落
  14136. var $elems = editor.selection.getSelectionRangeTopNodes();
  14137. if ($elems.length > 0) {
  14138. (0, _forEach["default"])($elems).call($elems, function (item) {
  14139. operate_element_1["default"](dom_core_1["default"](item), value, editor);
  14140. });
  14141. }
  14142. } else {
  14143. // 当 当前选区 不等于 textElem 时
  14144. // 代表 当前选区要么是一个段落,要么是段落中的一部分
  14145. if ($selectionElem && $selectionElem.length > 0) {
  14146. (0, _forEach["default"])($selectionElem).call($selectionElem, function (item) {
  14147. operate_element_1["default"](dom_core_1["default"](item), value, editor);
  14148. });
  14149. }
  14150. } // 恢复选区
  14151. editor.selection.restoreSelection();
  14152. this.tryChangeActive();
  14153. };
  14154. /**
  14155. * 尝试改变菜单激活(高亮)状态
  14156. */
  14157. Indent.prototype.tryChangeActive = function () {
  14158. var editor = this.editor;
  14159. var $selectionElem = editor.selection.getSelectionStartElem();
  14160. var $selectionStartElem = dom_core_1["default"]($selectionElem).getNodeTop(editor);
  14161. if ($selectionStartElem.length <= 0) return;
  14162. if ($selectionStartElem.elems[0].style['paddingLeft'] != '') {
  14163. this.active();
  14164. } else {
  14165. this.unActive();
  14166. }
  14167. };
  14168. return Indent;
  14169. }(DropListMenu_1["default"]);
  14170. exports["default"] = Indent;
  14171. /***/ }),
  14172. /* 381 */
  14173. /***/ (function(module, exports, __webpack_require__) {
  14174. "use strict";
  14175. /**
  14176. * @description 对节点 操作 进行封装
  14177. * 获取当前节点的段落
  14178. * 根据type判断是增加还是减少缩进
  14179. * @author tonghan
  14180. */
  14181. var _interopRequireDefault = __webpack_require__(0);
  14182. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14183. var _slice = _interopRequireDefault(__webpack_require__(47));
  14184. var _trim = _interopRequireDefault(__webpack_require__(16));
  14185. (0, _defineProperty["default"])(exports, "__esModule", {
  14186. value: true
  14187. });
  14188. var tslib_1 = __webpack_require__(2);
  14189. var increase_indent_style_1 = tslib_1.__importDefault(__webpack_require__(382));
  14190. var decrease_indent_style_1 = tslib_1.__importDefault(__webpack_require__(383));
  14191. var lengthRegex = /^(\d+)(\w+)$/;
  14192. var percentRegex = /^(\d+)%$/;
  14193. function parseIndentation(editor) {
  14194. var indentation = editor.config.indentation;
  14195. if (typeof indentation === 'string') {
  14196. if (lengthRegex.test(indentation)) {
  14197. var _context;
  14198. var _a = (0, _slice["default"])(_context = (0, _trim["default"])(indentation).call(indentation).match(lengthRegex)).call(_context, 1, 3),
  14199. value = _a[0],
  14200. unit = _a[1];
  14201. return {
  14202. value: Number(value),
  14203. unit: unit
  14204. };
  14205. } else if (percentRegex.test(indentation)) {
  14206. return {
  14207. value: Number((0, _trim["default"])(indentation).call(indentation).match(percentRegex)[1]),
  14208. unit: '%'
  14209. };
  14210. }
  14211. } else if (indentation.value !== void 0 && indentation.unit) {
  14212. return indentation;
  14213. }
  14214. return {
  14215. value: 2,
  14216. unit: 'em'
  14217. };
  14218. }
  14219. function operateElement($node, type, editor) {
  14220. var $elem = $node.getNodeTop(editor);
  14221. var reg = /^(P|H[0-9]*)$/;
  14222. if (reg.test($elem.getNodeName())) {
  14223. if (type === 'increase') increase_indent_style_1["default"]($elem, parseIndentation(editor));else if (type === 'decrease') decrease_indent_style_1["default"]($elem, parseIndentation(editor));
  14224. }
  14225. }
  14226. exports["default"] = operateElement;
  14227. /***/ }),
  14228. /* 382 */
  14229. /***/ (function(module, exports, __webpack_require__) {
  14230. "use strict";
  14231. /**
  14232. * @description 增加缩进
  14233. * @author tonghan
  14234. */
  14235. var _interopRequireDefault = __webpack_require__(0);
  14236. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14237. var _slice = _interopRequireDefault(__webpack_require__(47));
  14238. (0, _defineProperty["default"])(exports, "__esModule", {
  14239. value: true
  14240. });
  14241. function increaseIndentStyle($node, options) {
  14242. var $elem = $node.elems[0];
  14243. if ($elem.style['paddingLeft'] === '') {
  14244. $node.css('padding-left', options.value + options.unit);
  14245. } else {
  14246. var oldPL = $elem.style['paddingLeft'];
  14247. var oldVal = (0, _slice["default"])(oldPL).call(oldPL, 0, oldPL.length - options.unit.length);
  14248. var newVal = Number(oldVal) + options.value;
  14249. $node.css('padding-left', "" + newVal + options.unit);
  14250. }
  14251. }
  14252. exports["default"] = increaseIndentStyle;
  14253. /***/ }),
  14254. /* 383 */
  14255. /***/ (function(module, exports, __webpack_require__) {
  14256. "use strict";
  14257. /**
  14258. * @description 减少缩进
  14259. * @author tonghan
  14260. */
  14261. var _interopRequireDefault = __webpack_require__(0);
  14262. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14263. var _slice = _interopRequireDefault(__webpack_require__(47));
  14264. (0, _defineProperty["default"])(exports, "__esModule", {
  14265. value: true
  14266. });
  14267. function decreaseIndentStyle($node, options) {
  14268. var $elem = $node.elems[0];
  14269. if ($elem.style['paddingLeft'] !== '') {
  14270. var oldPL = $elem.style['paddingLeft'];
  14271. var oldVal = (0, _slice["default"])(oldPL).call(oldPL, 0, oldPL.length - options.unit.length);
  14272. var newVal = Number(oldVal) - options.value;
  14273. if (newVal > 0) {
  14274. $node.css('padding-left', "" + newVal + options.unit);
  14275. } else {
  14276. $node.css('padding-left', '');
  14277. }
  14278. }
  14279. }
  14280. exports["default"] = decreaseIndentStyle;
  14281. /***/ }),
  14282. /* 384 */
  14283. /***/ (function(module, exports, __webpack_require__) {
  14284. "use strict";
  14285. var _interopRequireDefault = __webpack_require__(0);
  14286. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14287. (0, _defineProperty["default"])(exports, "__esModule", {
  14288. value: true
  14289. });
  14290. var tslib_1 = __webpack_require__(2);
  14291. /**
  14292. * @description 插入表情
  14293. * @author liuwe
  14294. */
  14295. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14296. var PanelMenu_1 = tslib_1.__importDefault(__webpack_require__(36));
  14297. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  14298. var create_panel_conf_1 = tslib_1.__importDefault(__webpack_require__(385));
  14299. var Emoticon = function (_super) {
  14300. tslib_1.__extends(Emoticon, _super);
  14301. function Emoticon(editor) {
  14302. var _this = this;
  14303. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u8868\u60C5\">\n <i class=\"w-e-icon-happy\"></i>\n </div>");
  14304. _this = _super.call(this, $elem, editor) || this;
  14305. return _this;
  14306. }
  14307. /**
  14308. * 创建 panel
  14309. */
  14310. Emoticon.prototype.createPanel = function () {
  14311. var conf = create_panel_conf_1["default"](this.editor);
  14312. var panel = new Panel_1["default"](this, conf);
  14313. panel.create();
  14314. };
  14315. /**
  14316. * 菜单表情点击事件
  14317. */
  14318. Emoticon.prototype.clickHandler = function () {
  14319. this.createPanel();
  14320. };
  14321. Emoticon.prototype.tryChangeActive = function () {};
  14322. return Emoticon;
  14323. }(PanelMenu_1["default"]);
  14324. exports["default"] = Emoticon;
  14325. /***/ }),
  14326. /* 385 */
  14327. /***/ (function(module, exports, __webpack_require__) {
  14328. "use strict";
  14329. /**
  14330. * @description 表情菜单 panel配置
  14331. * @author liuwei
  14332. */
  14333. var _interopRequireDefault = __webpack_require__(0);
  14334. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14335. var _map = _interopRequireDefault(__webpack_require__(27));
  14336. var _filter = _interopRequireDefault(__webpack_require__(76));
  14337. var _trim = _interopRequireDefault(__webpack_require__(16));
  14338. (0, _defineProperty["default"])(exports, "__esModule", {
  14339. value: true
  14340. });
  14341. var tslib_1 = __webpack_require__(2);
  14342. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14343. function default_1(editor) {
  14344. // 声明emotions数据结构
  14345. var emotions = editor.config.emotions;
  14346. /* tabs配置项 ==================================================================*/
  14347. // 生成表情结构 TODO jele type类型待优化
  14348. function GenerateExpressionStructure(ele) {
  14349. // 返回为一个数组对象
  14350. var res = []; // 如果type是image类型则生成一个img标签
  14351. if (ele.type == 'image') {
  14352. var _context;
  14353. res = (0, _map["default"])(_context = ele.content).call(_context, function (con) {
  14354. if (typeof con == 'string') return '';
  14355. return "<span title=\"" + con.alt + "\">\n <img class=\"eleImg\" data-emoji=\"" + con.alt + "\" style src=\"" + con.src + "\" alt=\"[" + con.alt + "]\">\n </span>";
  14356. });
  14357. res = (0, _filter["default"])(res).call(res, function (s) {
  14358. return s !== '';
  14359. });
  14360. } //否则直接当内容处理
  14361. else {
  14362. var _context2;
  14363. res = (0, _map["default"])(_context2 = ele.content).call(_context2, function (con) {
  14364. return "<span class=\"eleImg\" title=\"" + con + "\">" + con + "</span>";
  14365. });
  14366. }
  14367. return res.join('').replace(/&nbsp;/g, '');
  14368. }
  14369. var tabsConf = (0, _map["default"])(emotions).call(emotions, function (ele) {
  14370. return {
  14371. title: editor.i18next.t("menus.panelMenus.emoticon." + ele.title),
  14372. // 判断type类型如果是image则以img的形式插入否则以内容
  14373. tpl: "<div>" + GenerateExpressionStructure(ele) + "</div>",
  14374. events: [{
  14375. selector: '.eleImg',
  14376. type: 'click',
  14377. fn: function fn(e) {
  14378. // e为事件对象
  14379. var $target = dom_core_1["default"](e.target);
  14380. var nodeName = $target.getNodeName();
  14381. var insertHtml;
  14382. if (nodeName === 'IMG') {
  14383. var _context3;
  14384. // 插入图片
  14385. insertHtml = (0, _trim["default"])(_context3 = $target.parent().html()).call(_context3);
  14386. } else {
  14387. // 插入 emoji
  14388. insertHtml = '<span>' + $target.html() + '</span>';
  14389. }
  14390. editor.cmd["do"]('insertHTML', insertHtml); // 示函数执行结束之后关闭 panel
  14391. return true;
  14392. }
  14393. }]
  14394. };
  14395. });
  14396. /* tabs配置项 =================================================================end*/
  14397. // 最终的配置 -----------------------------------------
  14398. var conf = {
  14399. width: 300,
  14400. height: 230,
  14401. tabs: tabsConf
  14402. };
  14403. return conf;
  14404. }
  14405. exports["default"] = default_1;
  14406. /***/ }),
  14407. /* 386 */
  14408. /***/ (function(module, exports, __webpack_require__) {
  14409. "use strict";
  14410. var _interopRequireDefault = __webpack_require__(0);
  14411. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14412. (0, _defineProperty["default"])(exports, "__esModule", {
  14413. value: true
  14414. });
  14415. exports.createListHandle = exports.ClassType = void 0;
  14416. var tslib_1 = __webpack_require__(2);
  14417. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14418. var WrapListHandle_1 = tslib_1.__importDefault(__webpack_require__(387));
  14419. var JoinListHandle_1 = tslib_1.__importDefault(__webpack_require__(389));
  14420. var StartJoinListHandle_1 = tslib_1.__importDefault(__webpack_require__(390));
  14421. var EndJoinListHandle_1 = tslib_1.__importDefault(__webpack_require__(391));
  14422. var OtherListHandle_1 = tslib_1.__importDefault(__webpack_require__(392));
  14423. var ClassType;
  14424. (function (ClassType) {
  14425. ClassType["Wrap"] = "WrapListHandle";
  14426. ClassType["Join"] = "JoinListHandle";
  14427. ClassType["StartJoin"] = "StartJoinListHandle";
  14428. ClassType["EndJoin"] = "EndJoinListHandle";
  14429. ClassType["Other"] = "OtherListHandle";
  14430. })(ClassType = exports.ClassType || (exports.ClassType = {}));
  14431. var handle = {
  14432. WrapListHandle: WrapListHandle_1["default"],
  14433. JoinListHandle: JoinListHandle_1["default"],
  14434. StartJoinListHandle: StartJoinListHandle_1["default"],
  14435. EndJoinListHandle: EndJoinListHandle_1["default"],
  14436. OtherListHandle: OtherListHandle_1["default"]
  14437. };
  14438. function createListHandle(classType, options, range) {
  14439. if (classType === ClassType.Other && range === undefined) {
  14440. throw new Error('other 类需要传入 range');
  14441. }
  14442. return classType !== ClassType.Other ? new handle[classType](options) : new handle[classType](options, range);
  14443. }
  14444. exports.createListHandle = createListHandle;
  14445. /**
  14446. * 统一执行的接口
  14447. */
  14448. var ListHandleCommand = function () {
  14449. function ListHandleCommand(handle) {
  14450. this.handle = handle;
  14451. this.handle.exec();
  14452. }
  14453. ListHandleCommand.prototype.getSelectionRangeElem = function () {
  14454. return dom_core_1["default"](this.handle.selectionRangeElem.get());
  14455. };
  14456. return ListHandleCommand;
  14457. }();
  14458. exports["default"] = ListHandleCommand;
  14459. /***/ }),
  14460. /* 387 */
  14461. /***/ (function(module, exports, __webpack_require__) {
  14462. "use strict";
  14463. var _interopRequireDefault = __webpack_require__(0);
  14464. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14465. var _forEach = _interopRequireDefault(__webpack_require__(4));
  14466. (0, _defineProperty["default"])(exports, "__esModule", {
  14467. value: true
  14468. });
  14469. var tslib_1 = __webpack_require__(2);
  14470. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14471. var ListHandle_1 = __webpack_require__(62);
  14472. var utils_1 = __webpack_require__(49);
  14473. /**
  14474. * 选区在序列内的处理
  14475. */
  14476. var WrapListHandle = function (_super) {
  14477. tslib_1.__extends(WrapListHandle, _super);
  14478. function WrapListHandle(options) {
  14479. return _super.call(this, options) || this;
  14480. }
  14481. WrapListHandle.prototype.exec = function () {
  14482. var _a = this.options,
  14483. listType = _a.listType,
  14484. listTarget = _a.listTarget,
  14485. $selectionElem = _a.$selectionElem,
  14486. $startElem = _a.$startElem,
  14487. $endElem = _a.$endElem;
  14488. var $containerFragment; // 容器 - HTML 文档片段
  14489. var $nodes = []; // 获取选中的段落
  14490. // 获取 selectionElem 的标签名
  14491. var containerNodeName = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getNodeName(); // 获取开始以及结束的 li 元素
  14492. var $start = $startElem.prior;
  14493. var $end = $endElem.prior; // =====================================
  14494. // 当 开始节点 和 结束节点 没有 prior
  14495. // 并且 开始节点 没有前一个兄弟节点
  14496. // 并且 结束节点 没有后一个兄弟节点
  14497. // 即代表 全选序列
  14498. // =====================================
  14499. if (!$startElem.prior && !$endElem.prior || !($start === null || $start === void 0 ? void 0 : $start.prev().length) && !($end === null || $end === void 0 ? void 0 : $end.next().length)) {
  14500. var _context;
  14501. // 获取当前序列下的所有 li 标签
  14502. ;
  14503. (0, _forEach["default"])(_context = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.children()).call(_context, function ($node) {
  14504. $nodes.push(dom_core_1["default"]($node));
  14505. }); // =====================================
  14506. // 当 selectionElem 的标签名和按钮类型 一致 的时候
  14507. // 代表着当前的操作是 取消 序列
  14508. // =====================================
  14509. if (containerNodeName === listType) {
  14510. // 生成对应的段落(p)并添加到文档片段中,然后删除掉无用的 li
  14511. $containerFragment = utils_1.createElementFragment($nodes, utils_1.createDocumentFragment(), // 创建 文档片段
  14512. 'p');
  14513. } // =====================================
  14514. // 当 selectionElem 的标签名和按钮类型 不一致 的时候
  14515. // 代表着当前的操作是 转换 序列
  14516. // =====================================
  14517. else {
  14518. // 创建 序列节点
  14519. $containerFragment = utils_1.createElement(listTarget); // 因为是转换,所以 li 元素可以直接使用
  14520. (0, _forEach["default"])($nodes).call($nodes, function ($node) {
  14521. $containerFragment.appendChild($node.elems[0]);
  14522. });
  14523. } // 把 文档片段 或 序列节点 插入到 selectionElem 的前面
  14524. this.selectionRangeElem.set($containerFragment); // 插入到 $selectionElem 之前
  14525. utils_1.insertBefore($selectionElem, $containerFragment, $selectionElem.elems[0]); // 删除无用的 selectionElem 因为它被掏空了
  14526. $selectionElem.remove();
  14527. } // =====================================
  14528. // 当不是全选序列的时候就代表是非全选序列(废话)
  14529. // 非全选序列的情况
  14530. // =====================================
  14531. else {
  14532. // 获取选中的内容
  14533. var $startDom = $start;
  14534. while ($startDom.length) {
  14535. $nodes.push($startDom);
  14536. ($end === null || $end === void 0 ? void 0 : $end.equal($startDom)) ? $startDom = dom_core_1["default"](undefined) : $startDom = $startDom.next(); // 继续
  14537. } // 获取开始节点的上一个兄弟节点
  14538. var $prveDom = $start.prev(); // 获取结束节点的下一个兄弟节点
  14539. var $nextDom = $end.next(); // =====================================
  14540. // 当 selectionElem 的标签名和按钮类型一致的时候
  14541. // 代表着当前的操作是 取消 序列
  14542. // =====================================
  14543. if (containerNodeName === listType) {
  14544. // 生成对应的段落(p)并添加到文档片段中,然后删除掉无用的 li
  14545. $containerFragment = utils_1.createElementFragment($nodes, utils_1.createDocumentFragment(), // 创建 文档片段
  14546. 'p');
  14547. } // =====================================
  14548. // 当 selectionElem 的标签名和按钮类型不一致的时候
  14549. // 代表着当前的操作是 转换 序列
  14550. // =====================================
  14551. else {
  14552. // 创建 文档片段
  14553. $containerFragment = utils_1.createElement(listTarget); // 因为是转换,所以 li 元素可以直接使用
  14554. (0, _forEach["default"])($nodes).call($nodes, function ($node) {
  14555. $containerFragment.append($node.elems[0]);
  14556. });
  14557. } // =====================================
  14558. // 当 prveDom 和 nextDom 都存在的时候
  14559. // 代表着当前选区是在序列的中间
  14560. // 所以要先把 下半部分 未选择的 li 元素独立出来生成一个 序列
  14561. // =====================================
  14562. if ($prveDom.length && $nextDom.length) {
  14563. // 获取尾部的元素
  14564. var $tailDomArr = [];
  14565. while ($nextDom.length) {
  14566. $tailDomArr.push($nextDom);
  14567. $nextDom = $nextDom.next();
  14568. } // 创建 尾部序列节点
  14569. var $tailDocFragment_1 = utils_1.createElement(containerNodeName); // 把尾部元素节点添加到尾部序列节点中
  14570. (0, _forEach["default"])($tailDomArr).call($tailDomArr, function ($node) {
  14571. $tailDocFragment_1.append($node.elems[0]);
  14572. }); // 把尾部序列节点插入到 selectionElem 的后面
  14573. dom_core_1["default"]($tailDocFragment_1).insertAfter($selectionElem); // =====================================
  14574. // 获取选区容器元素的父元素,一般就是编辑区域
  14575. // 然后判断 selectionElem 是否还有下一个兄弟节点
  14576. // 如果有,就把文档片段添加到 selectionElem 下一个兄弟节点前
  14577. // 如果没有,就把文档片段添加到 编辑区域 末尾
  14578. // =====================================
  14579. this.selectionRangeElem.set($containerFragment);
  14580. var $selectionNextDom = $selectionElem.next();
  14581. $selectionNextDom.length ? utils_1.insertBefore($selectionElem, $containerFragment, $selectionNextDom.elems[0]) : $selectionElem.parent().elems[0].append($containerFragment);
  14582. } // =====================================
  14583. // 不管是 取消 还是 转换 都需要重新插入节点
  14584. //
  14585. // prveDom.length 等于 0 即代表选区是 selectionElem 序列的上半部分
  14586. // 上半部分的 li 元素
  14587. // =====================================
  14588. else if (!$prveDom.length) {
  14589. // 文档片段插入到 selectionElem 之前
  14590. this.selectionRangeElem.set($containerFragment);
  14591. utils_1.insertBefore($selectionElem, $containerFragment, $selectionElem.elems[0]);
  14592. } // =====================================
  14593. // 不管是 取消 还是 转换 都需要重新插入节点
  14594. //
  14595. // nextDom.length 等于 0 即代表选区是 selectionElem 序列的下半部分
  14596. // 下半部分的 li 元素 if (!$nextDom.length)
  14597. // =====================================
  14598. else {
  14599. // 文档片段插入到 selectionElem 之后
  14600. this.selectionRangeElem.set($containerFragment);
  14601. var $selectionNextDom = $selectionElem.next();
  14602. $selectionNextDom.length ? utils_1.insertBefore($selectionElem, $containerFragment, $selectionNextDom.elems[0]) : $selectionElem.parent().elems[0].append($containerFragment);
  14603. }
  14604. }
  14605. };
  14606. return WrapListHandle;
  14607. }(ListHandle_1.ListHandle);
  14608. exports["default"] = WrapListHandle;
  14609. /***/ }),
  14610. /* 388 */
  14611. /***/ (function(module, exports, __webpack_require__) {
  14612. "use strict";
  14613. var _interopRequireDefault = __webpack_require__(0);
  14614. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14615. var _forEach = _interopRequireDefault(__webpack_require__(4));
  14616. (0, _defineProperty["default"])(exports, "__esModule", {
  14617. value: true
  14618. });
  14619. /**
  14620. * @description 选区的 Element
  14621. * @author tonghan
  14622. */
  14623. var SelectionRangeElem = function () {
  14624. function SelectionRangeElem() {
  14625. this._element = null;
  14626. }
  14627. /**
  14628. * 设置 SelectionRangeElem 的值
  14629. * @param { SetSelectionRangeType } data
  14630. */
  14631. SelectionRangeElem.prototype.set = function (data) {
  14632. //
  14633. if (data instanceof DocumentFragment) {
  14634. var _context;
  14635. var childNode_1 = [];
  14636. (0, _forEach["default"])(_context = data.childNodes).call(_context, function ($node) {
  14637. childNode_1.push($node);
  14638. });
  14639. data = childNode_1;
  14640. }
  14641. this._element = data;
  14642. };
  14643. /**
  14644. * 获取 SelectionRangeElem 的值
  14645. * @returns { SelectionRangeType } Elem
  14646. */
  14647. SelectionRangeElem.prototype.get = function () {
  14648. return this._element;
  14649. };
  14650. /**
  14651. * 清除 SelectionRangeElem 的值
  14652. */
  14653. SelectionRangeElem.prototype.clear = function () {
  14654. this._element = null;
  14655. };
  14656. return SelectionRangeElem;
  14657. }();
  14658. exports["default"] = SelectionRangeElem;
  14659. /***/ }),
  14660. /* 389 */
  14661. /***/ (function(module, exports, __webpack_require__) {
  14662. "use strict";
  14663. var _interopRequireDefault = __webpack_require__(0);
  14664. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14665. var _forEach = _interopRequireDefault(__webpack_require__(4));
  14666. (0, _defineProperty["default"])(exports, "__esModule", {
  14667. value: true
  14668. });
  14669. var tslib_1 = __webpack_require__(2);
  14670. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14671. var ListHandle_1 = __webpack_require__(62);
  14672. var utils_1 = __webpack_require__(49);
  14673. var JoinListHandle = function (_super) {
  14674. tslib_1.__extends(JoinListHandle, _super);
  14675. function JoinListHandle(options) {
  14676. return _super.call(this, options) || this;
  14677. }
  14678. JoinListHandle.prototype.exec = function () {
  14679. var _a, _b, _c, _d, _e, _f, _g;
  14680. var _h = this.options,
  14681. editor = _h.editor,
  14682. listType = _h.listType,
  14683. listTarget = _h.listTarget,
  14684. $startElem = _h.$startElem,
  14685. $endElem = _h.$endElem; // 容器 - HTML 文档片段
  14686. var $containerFragment; // 获取选中的段落
  14687. var $nodes = editor.selection.getSelectionRangeTopNodes(); // 获取开始段落和结束段落 标签名
  14688. var startNodeName = $startElem === null || $startElem === void 0 ? void 0 : $startElem.getNodeName();
  14689. var endNodeName = $endElem === null || $endElem === void 0 ? void 0 : $endElem.getNodeName(); // =====================================
  14690. // 开头结尾都是序列的情况下
  14691. // 开头序列 和 结尾序列的标签名一致的时候
  14692. // =====================================
  14693. if (startNodeName === endNodeName) {
  14694. // =====================================
  14695. // 开头序列 和 结尾序列 中间还有其他的段落的时候
  14696. // =====================================
  14697. if ($nodes.length > 2) {
  14698. // 弹出 开头 和 结尾
  14699. $nodes.shift();
  14700. $nodes.pop(); // 把中间部分的节点元素转换成 li 元素并添加到文档片段后删除
  14701. $containerFragment = utils_1.createElementFragment(utils_1.filterSelectionNodes($nodes), // 过滤 $nodes 获取到符合要求的选中元素节点
  14702. utils_1.createDocumentFragment() // 创建 文档片段
  14703. ); // =====================================
  14704. // 由于开头序列 和 结尾序列的标签名一样,所以只判断了开头序列的
  14705. // 当开头序列的标签名和按钮类型 一致 的时候
  14706. // 代表着当前是一个 设置序列 的操作
  14707. // =====================================
  14708. if (startNodeName === listType) {
  14709. // 把结束序列的 li 元素添加到 文档片段中
  14710. (_a = $endElem.children()) === null || _a === void 0 ? void 0 : (0, _forEach["default"])(_a).call(_a, function ($list) {
  14711. $containerFragment.append($list);
  14712. }); // 下序列全选被掏空了,就卸磨杀驴吧
  14713. $endElem.remove(); // 在开始序列中添加 文档片段
  14714. this.selectionRangeElem.set($containerFragment);
  14715. $startElem.elems[0].append($containerFragment);
  14716. } // =====================================
  14717. // 由于开头序列 和 结尾序列的标签名一样,所以只判断了开头序列的
  14718. // 当开头序列的标签名和按钮类型 不一致 的时候
  14719. // 代表着当前是一个 转换序列 的操作
  14720. // =====================================
  14721. else {
  14722. // 创建 开始序列和结束序列的文档片段
  14723. var $startFragment = document.createDocumentFragment();
  14724. var $endFragment_1 = document.createDocumentFragment(); // 获取起点元素
  14725. var $startDom = utils_1.getStartPoint($startElem); // 获取上半序列中的选中内容,并添加到文档片段中
  14726. while ($startDom.length) {
  14727. var _element = $startDom.elems[0];
  14728. $startDom = $startDom.next();
  14729. $startFragment.append(_element);
  14730. } // 获取结束元素
  14731. var $endDom = utils_1.getEndPoint($endElem); // 获取下半序列中选中的内容
  14732. var domArr = [];
  14733. while ($endDom.length) {
  14734. domArr.unshift($endDom.elems[0]);
  14735. $endDom = $endDom.prev();
  14736. } // 添加到文档片段中
  14737. (0, _forEach["default"])(domArr).call(domArr, function ($node) {
  14738. $endFragment_1.append($node);
  14739. }); // 合并文档片段
  14740. var $orderFragment = utils_1.createElement(listTarget);
  14741. $orderFragment.append($startFragment);
  14742. $orderFragment.append($containerFragment);
  14743. $orderFragment.append($endFragment_1);
  14744. $containerFragment = $orderFragment; // 插入
  14745. this.selectionRangeElem.set($containerFragment);
  14746. dom_core_1["default"]($orderFragment).insertAfter($startElem); // 序列全选被掏空了后,就卸磨杀驴吧
  14747. !((_b = $startElem.children()) === null || _b === void 0 ? void 0 : _b.length) && $startElem.remove();
  14748. !((_c = $endElem.children()) === null || _c === void 0 ? void 0 : _c.length) && $endElem.remove();
  14749. }
  14750. } // =====================================
  14751. // 开头序列 和 结尾序列 中间没有其他的段落
  14752. // =====================================
  14753. else {
  14754. $nodes.length = 0; // 获取起点元素
  14755. var $startDom = utils_1.getStartPoint($startElem); // 获取上半序列中的选中内容
  14756. while ($startDom.length) {
  14757. $nodes.push($startDom);
  14758. $startDom = $startDom.next();
  14759. } // 获取结束元素
  14760. var $endDom = utils_1.getEndPoint($endElem); // 获取下半序列中选中的内容
  14761. var domArr = []; // 获取下半序列中的选中内容
  14762. while ($endDom.length) {
  14763. domArr.unshift($endDom);
  14764. $endDom = $endDom.prev();
  14765. } // 融合内容
  14766. $nodes.push.apply($nodes, domArr); // =====================================
  14767. // 由于开头序列 和 结尾序列的标签名一样,所以只判断了开头序列的
  14768. // 当开头序列的标签名和按钮类型 一致 的时候
  14769. // 代表着当前是一个 取消序列 的操作
  14770. // =====================================
  14771. if (startNodeName === listType) {
  14772. // 创建 文档片段
  14773. // 把 li 转换为 p 标签
  14774. $containerFragment = utils_1.createElementFragment($nodes, utils_1.createDocumentFragment(), 'p'); // 插入到 endElem 前
  14775. this.selectionRangeElem.set($containerFragment);
  14776. utils_1.insertBefore($startElem, $containerFragment, $endElem.elems[0]);
  14777. } // =====================================
  14778. // 由于开头序列 和 结尾序列的标签名一样,所以只判断了开头序列的
  14779. // 当开头序列的标签名和按钮类型 不一致 的时候
  14780. // 代表着当前是一个 设置序列 的操作
  14781. // =====================================
  14782. else {
  14783. // 创建 序列元素
  14784. $containerFragment = utils_1.createElement(listTarget); // li 元素添加到 序列元素 中
  14785. (0, _forEach["default"])($nodes).call($nodes, function ($list) {
  14786. $containerFragment.append($list.elems[0]);
  14787. }); // 插入到 startElem 之后
  14788. this.selectionRangeElem.set($containerFragment);
  14789. dom_core_1["default"]($containerFragment).insertAfter($startElem);
  14790. } // 序列全选被掏空了后,就卸磨杀驴吧
  14791. !((_d = $startElem.children()) === null || _d === void 0 ? void 0 : _d.length) && $endElem.remove();
  14792. !((_e = $endElem.children()) === null || _e === void 0 ? void 0 : _e.length) && $endElem.remove();
  14793. }
  14794. } // =====================================
  14795. // 由于开头序列 和 结尾序列的标签名不一样
  14796. // =====================================
  14797. else {
  14798. // 下序列元素数组
  14799. var lowerListElems = []; // 获取结束元素
  14800. var $endDom = utils_1.getEndPoint($endElem); // 获取下半序列中选中的内容
  14801. while ($endDom.length) {
  14802. lowerListElems.unshift($endDom);
  14803. $endDom = $endDom.prev();
  14804. } // 上序列元素数组
  14805. var upperListElems = []; // 获取起点元素
  14806. var $startDom = utils_1.getStartPoint($startElem); // 获取上半序列中的选中内容,并添加到文档片段中
  14807. while ($startDom.length) {
  14808. upperListElems.push($startDom);
  14809. $startDom = $startDom.next();
  14810. } // 创建 文档片段
  14811. $containerFragment = utils_1.createDocumentFragment(); // 弹出开头和结尾的序列
  14812. $nodes.shift();
  14813. $nodes.pop(); // 把头部序列的内容添加到文档片段当中
  14814. (0, _forEach["default"])(upperListElems).call(upperListElems, function ($list) {
  14815. return $containerFragment.append($list.elems[0]);
  14816. }); // 生成 li 标签,并且添加到 文档片段中,删除无用节点
  14817. $containerFragment = utils_1.createElementFragment(utils_1.filterSelectionNodes($nodes), // 序列中间的数据 - 进行数据过滤
  14818. $containerFragment); // 把尾部序列的内容添加到文档片段当中
  14819. (0, _forEach["default"])(lowerListElems).call(lowerListElems, function ($list) {
  14820. return $containerFragment.append($list.elems[0]);
  14821. }); // 记录
  14822. this.selectionRangeElem.set($containerFragment); // =====================================
  14823. // 开头序列 和 设置序列类型相同
  14824. // =====================================
  14825. if (startNodeName === listType) {
  14826. // 插入到 开始序列的尾部(作为子元素)
  14827. $startElem.elems[0].append($containerFragment); // 序列全选被掏空了后,就卸磨杀驴吧
  14828. !((_f = $endElem.children()) === null || _f === void 0 ? void 0 : _f.length) && $endElem.remove();
  14829. } // =====================================
  14830. // 结尾序列 和 设置序列类型相同
  14831. // =====================================
  14832. else {
  14833. // 插入到结束序列的顶部(作为子元素)
  14834. if ((_g = $endElem.children()) === null || _g === void 0 ? void 0 : _g.length) {
  14835. var $endElemChild = $endElem.children();
  14836. utils_1.insertBefore($endElemChild, $containerFragment, $endElemChild.elems[0]);
  14837. } else {
  14838. $endElem.elems[0].append($containerFragment);
  14839. }
  14840. }
  14841. }
  14842. };
  14843. return JoinListHandle;
  14844. }(ListHandle_1.ListHandle);
  14845. exports["default"] = JoinListHandle;
  14846. /***/ }),
  14847. /* 390 */
  14848. /***/ (function(module, exports, __webpack_require__) {
  14849. "use strict";
  14850. var _interopRequireDefault = __webpack_require__(0);
  14851. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14852. var _forEach = _interopRequireDefault(__webpack_require__(4));
  14853. (0, _defineProperty["default"])(exports, "__esModule", {
  14854. value: true
  14855. });
  14856. var tslib_1 = __webpack_require__(2);
  14857. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14858. var ListHandle_1 = __webpack_require__(62);
  14859. var utils_1 = __webpack_require__(49);
  14860. var StartJoinListHandle = function (_super) {
  14861. tslib_1.__extends(StartJoinListHandle, _super);
  14862. function StartJoinListHandle(options) {
  14863. return _super.call(this, options) || this;
  14864. }
  14865. StartJoinListHandle.prototype.exec = function () {
  14866. var _a;
  14867. var _b = this.options,
  14868. editor = _b.editor,
  14869. listType = _b.listType,
  14870. listTarget = _b.listTarget,
  14871. $startElem = _b.$startElem; // 容器 - HTML 文档片段
  14872. var $containerFragment; // 获取选中的段落
  14873. var $nodes = editor.selection.getSelectionRangeTopNodes(); // 获取开始段落标签名
  14874. var startNodeName = $startElem === null || $startElem === void 0 ? void 0 : $startElem.getNodeName(); // 弹出 开头序列
  14875. $nodes.shift(); // 上序列元素数组
  14876. var upperListElems = []; // 获取起点元素
  14877. var $startDom = utils_1.getStartPoint($startElem); // 获取上半序列中的选中内容,并添加到文档片段中
  14878. while ($startDom.length) {
  14879. upperListElems.push($startDom);
  14880. $startDom = $startDom.next();
  14881. } // =====================================
  14882. // 当前序列类型和开头序列的类型 一致
  14883. // 代表当前是一个 融合(把其他段落加入到开头序列中) 的操作
  14884. // =====================================
  14885. if (startNodeName === listType) {
  14886. $containerFragment = utils_1.createDocumentFragment();
  14887. (0, _forEach["default"])(upperListElems).call(upperListElems, function ($list) {
  14888. return $containerFragment.append($list.elems[0]);
  14889. }); // 生成 li 元属,并删除
  14890. $containerFragment = utils_1.createElementFragment(utils_1.filterSelectionNodes($nodes), // 过滤元素节点数据
  14891. $containerFragment); // 插入到开始序列末尾
  14892. this.selectionRangeElem.set($containerFragment); // this.selectionRangeElem.set($startElem.elems[0])
  14893. $startElem.elems[0].append($containerFragment);
  14894. } // =====================================
  14895. // 当前序列类型和开头序列的类型 不一致
  14896. // 代表当前是一个 设置序列 的操作
  14897. // =====================================
  14898. else {
  14899. // 创建 序列节点
  14900. $containerFragment = utils_1.createElement(listTarget);
  14901. (0, _forEach["default"])(upperListElems).call(upperListElems, function ($list) {
  14902. return $containerFragment.append($list.elems[0]);
  14903. }); // 生成 li 元素,并添加到 序列节点 当中,删除无用节点
  14904. $containerFragment = utils_1.createElementFragment(utils_1.filterSelectionNodes($nodes), // 过滤普通节点
  14905. $containerFragment); // 插入到开始元素
  14906. this.selectionRangeElem.set($containerFragment);
  14907. dom_core_1["default"]($containerFragment).insertAfter($startElem); // 序列全选被掏空了后,就卸磨杀驴吧
  14908. !((_a = $startElem.children()) === null || _a === void 0 ? void 0 : _a.length) && $startElem.remove();
  14909. }
  14910. };
  14911. return StartJoinListHandle;
  14912. }(ListHandle_1.ListHandle);
  14913. exports["default"] = StartJoinListHandle;
  14914. /***/ }),
  14915. /* 391 */
  14916. /***/ (function(module, exports, __webpack_require__) {
  14917. "use strict";
  14918. var _interopRequireDefault = __webpack_require__(0);
  14919. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14920. var _forEach = _interopRequireDefault(__webpack_require__(4));
  14921. (0, _defineProperty["default"])(exports, "__esModule", {
  14922. value: true
  14923. });
  14924. var tslib_1 = __webpack_require__(2);
  14925. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  14926. var ListHandle_1 = __webpack_require__(62);
  14927. var utils_1 = __webpack_require__(49);
  14928. var EndJoinListHandle = function (_super) {
  14929. tslib_1.__extends(EndJoinListHandle, _super);
  14930. function EndJoinListHandle(options) {
  14931. return _super.call(this, options) || this;
  14932. }
  14933. EndJoinListHandle.prototype.exec = function () {
  14934. var _a, _b;
  14935. var _c = this.options,
  14936. editor = _c.editor,
  14937. listType = _c.listType,
  14938. listTarget = _c.listTarget,
  14939. $endElem = _c.$endElem; // 容器 - HTML 文档片段
  14940. var $containerFragment; // 获取选中的段落
  14941. var $nodes = editor.selection.getSelectionRangeTopNodes(); // 获取结束段落标签名
  14942. var endNodeName = $endElem === null || $endElem === void 0 ? void 0 : $endElem.getNodeName(); // 弹出 结束序列
  14943. $nodes.pop(); // 下序列元素数组
  14944. var lowerListElems = []; // 获取结束元素
  14945. var $endDom = utils_1.getEndPoint($endElem); // 获取下半序列中选中的内容
  14946. while ($endDom.length) {
  14947. lowerListElems.unshift($endDom);
  14948. $endDom = $endDom.prev();
  14949. } // =====================================
  14950. // 当前序列类型和结束序列的类型 一致
  14951. // 代表当前是一个 融合(把其他段落加入到结束序列中) 的操作
  14952. // =====================================
  14953. if (endNodeName === listType) {
  14954. // 生成 li 元属,并删除原来的 dom 元素
  14955. $containerFragment = utils_1.createElementFragment(utils_1.filterSelectionNodes($nodes), // 过滤元素节点数据
  14956. utils_1.createDocumentFragment() // 创建 文档片段
  14957. );
  14958. (0, _forEach["default"])(lowerListElems).call(lowerListElems, function ($list) {
  14959. return $containerFragment.append($list.elems[0]);
  14960. }); // 插入到结束序列之前
  14961. this.selectionRangeElem.set($containerFragment);
  14962. if ((_a = $endElem.children()) === null || _a === void 0 ? void 0 : _a.length) {
  14963. var $endElemChild = $endElem.children();
  14964. utils_1.insertBefore($endElemChild, $containerFragment, $endElemChild.elems[0]);
  14965. } else {
  14966. $endElem.elems[0].append($containerFragment);
  14967. }
  14968. } // =====================================
  14969. // 当前序列类型和结束序列的类型 不一致
  14970. // 代表当前是一个 设置序列 的操作
  14971. // =====================================
  14972. else {
  14973. // 过滤元素节点数据
  14974. var $selectionNodes = utils_1.filterSelectionNodes($nodes); // 把下序列的内容添加到过滤元素中
  14975. $selectionNodes.push.apply($selectionNodes, lowerListElems); // 生成 li 元素并且添加到序列节点后删除原节点
  14976. $containerFragment = utils_1.createElementFragment($selectionNodes, utils_1.createElement(listTarget) // 创建 序列节点
  14977. ); // 插入到结束序列之前
  14978. this.selectionRangeElem.set($containerFragment);
  14979. dom_core_1["default"]($containerFragment).insertBefore($endElem); // 序列全选被掏空了后,就卸磨杀驴吧
  14980. !((_b = $endElem.children()) === null || _b === void 0 ? void 0 : _b.length) && $endElem.remove();
  14981. }
  14982. };
  14983. return EndJoinListHandle;
  14984. }(ListHandle_1.ListHandle);
  14985. exports["default"] = EndJoinListHandle;
  14986. /***/ }),
  14987. /* 392 */
  14988. /***/ (function(module, exports, __webpack_require__) {
  14989. "use strict";
  14990. var _interopRequireDefault = __webpack_require__(0);
  14991. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  14992. (0, _defineProperty["default"])(exports, "__esModule", {
  14993. value: true
  14994. });
  14995. var tslib_1 = __webpack_require__(2);
  14996. var ListHandle_1 = __webpack_require__(62);
  14997. var utils_1 = __webpack_require__(49);
  14998. var OtherListHandle = function (_super) {
  14999. tslib_1.__extends(OtherListHandle, _super);
  15000. function OtherListHandle(options, range) {
  15001. var _this = _super.call(this, options) || this;
  15002. _this.range = range;
  15003. return _this;
  15004. }
  15005. OtherListHandle.prototype.exec = function () {
  15006. var _a = this.options,
  15007. editor = _a.editor,
  15008. listTarget = _a.listTarget; // 获取选中的段落
  15009. var $nodes = editor.selection.getSelectionRangeTopNodes(); // 生成 li 元素并且添加到序列节点后删除原节点
  15010. var $containerFragment = utils_1.createElementFragment(utils_1.filterSelectionNodes($nodes), // 过滤选取的元素
  15011. utils_1.createElement(listTarget) // 创建 序列节点
  15012. ); // 插入节点到选区
  15013. this.selectionRangeElem.set($containerFragment);
  15014. this.range.insertNode($containerFragment);
  15015. };
  15016. return OtherListHandle;
  15017. }(ListHandle_1.ListHandle);
  15018. exports["default"] = OtherListHandle;
  15019. /***/ }),
  15020. /* 393 */
  15021. /***/ (function(module, exports, __webpack_require__) {
  15022. "use strict";
  15023. /**
  15024. * @description 段落行高 LineHeight
  15025. * @author lichunlin
  15026. *
  15027. */
  15028. var _interopRequireDefault = __webpack_require__(0);
  15029. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15030. var _forEach = _interopRequireDefault(__webpack_require__(4));
  15031. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  15032. (0, _defineProperty["default"])(exports, "__esModule", {
  15033. value: true
  15034. });
  15035. var tslib_1 = __webpack_require__(2);
  15036. var DropListMenu_1 = tslib_1.__importDefault(__webpack_require__(24));
  15037. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15038. var lineHeightList_1 = tslib_1.__importDefault(__webpack_require__(394));
  15039. var util_1 = __webpack_require__(6);
  15040. var LineHeight = function (_super) {
  15041. tslib_1.__extends(LineHeight, _super);
  15042. function LineHeight(editor) {
  15043. var _this = this;
  15044. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u884C\u9AD8\">\n <i class=\"w-e-icon-row-height\"></i>\n </div>");
  15045. var lineHeightMenu = new lineHeightList_1["default"](editor, editor.config.lineHeights);
  15046. var DropListMenu = {
  15047. width: 100,
  15048. title: '设置行高',
  15049. type: 'list',
  15050. list: lineHeightMenu.getItemList(),
  15051. clickHandler: function clickHandler(value) {
  15052. //保存焦点
  15053. editor.selection.saveRange();
  15054. _this.command(value);
  15055. }
  15056. };
  15057. _this = _super.call(this, $elem, editor, DropListMenu) || this;
  15058. return _this;
  15059. }
  15060. /**
  15061. * 执行命令
  15062. * @param value value
  15063. */
  15064. LineHeight.prototype.command = function (value) {
  15065. var _this = this;
  15066. var _a;
  15067. var selection = window.getSelection ? window.getSelection() : document.getSelection(); //允许设置dom
  15068. var allowArray = ['P'];
  15069. var editor = this.editor;
  15070. var st = ''; //恢复焦点
  15071. editor.selection.restoreSelection();
  15072. var $selectionElem = dom_core_1["default"](editor.selection.getSelectionContainerElem());
  15073. if (!($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.length)) return;
  15074. var $selectionAll = dom_core_1["default"](editor.selection.getSelectionContainerElem()); // let dom:HTMLElement= $selectionElem.elems[0]
  15075. var dom = dom_core_1["default"](editor.selection.getSelectionStartElem()).elems[0]; //获取元素的style
  15076. var style = '';
  15077. var styleList = []; //点击默认的时候删除line-height属性 并重新设置 style
  15078. var styleStr = ''; //选中多行操作
  15079. if ($selectionElem && editor.$textElem.equal($selectionElem)) {
  15080. var isIE_1 = util_1.UA.isIE(); //获取range 开头结束的dom在 祖父元素的下标
  15081. var indexStore_1 = [];
  15082. var arrayDom_a = [];
  15083. var arrayDom_b = []; //获取range 开头结束的dom
  15084. var StartElem_1 = dom_core_1["default"](editor.selection.getSelectionStartElem());
  15085. var EndElem_1 = dom_core_1["default"](editor.selection.getSelectionEndElem());
  15086. var childList = (_a = editor.selection.getRange()) === null || _a === void 0 ? void 0 : _a.commonAncestorContainer.childNodes;
  15087. arrayDom_a.push(this.getDom(StartElem_1.elems[0]));
  15088. childList === null || childList === void 0 ? void 0 : (0, _forEach["default"])(childList).call(childList, function (item, index) {
  15089. if (item === _this.getDom(StartElem_1.elems[0])) {
  15090. indexStore_1.push(index);
  15091. }
  15092. if (item === _this.getDom(EndElem_1.elems[0])) {
  15093. indexStore_1.push(index);
  15094. }
  15095. }); //遍历 获取头尾之间的dom元素
  15096. var i = 0;
  15097. var d = void 0;
  15098. arrayDom_b.push(this.getDom(StartElem_1.elems[0]));
  15099. while (arrayDom_a[i] !== this.getDom(EndElem_1.elems[0])) {
  15100. d = dom_core_1["default"](arrayDom_a[i].nextElementSibling).elems[0];
  15101. if ((0, _indexOf["default"])(allowArray).call(allowArray, dom_core_1["default"](d).getNodeName()) !== -1) {
  15102. arrayDom_b.push(d);
  15103. arrayDom_a.push(d);
  15104. } else {
  15105. arrayDom_a.push(d);
  15106. }
  15107. i++;
  15108. } //设置段落选取 全选
  15109. if (dom_core_1["default"](arrayDom_a[0]).getNodeName() !== 'P') {
  15110. i = 0; //遍历集合得到第一个p标签的下标
  15111. for (var k = 0; k < arrayDom_a.length; k++) {
  15112. if (dom_core_1["default"](arrayDom_a[k]).getNodeName() === 'P') {
  15113. i = k;
  15114. break;
  15115. }
  15116. } //i===0 说明选区中没有p段落
  15117. if (i === 0) {
  15118. return;
  15119. }
  15120. var _i = 0;
  15121. while (_i !== i) {
  15122. arrayDom_a.shift();
  15123. _i++;
  15124. }
  15125. } //设置替换的选区
  15126. this.setRange(arrayDom_a[0], arrayDom_a[arrayDom_a.length - 1]); //生成innerHtml html字符串
  15127. (0, _forEach["default"])(arrayDom_a).call(arrayDom_a, function (item) {
  15128. style = item.getAttribute('style');
  15129. styleList = style ? style.split(';') : [];
  15130. styleStr = _this.styleProcessing(styleList);
  15131. if (dom_core_1["default"](item).getNodeName() === 'P') {
  15132. //判断是否 点击默认
  15133. if (value) {
  15134. styleStr += value ? "line-height:" + value + ";" : '';
  15135. }
  15136. }
  15137. if (!isIE_1) {
  15138. st += "<" + dom_core_1["default"](item).getNodeName().toLowerCase() + " style=\"" + styleStr + "\">" + item.innerHTML + "</" + dom_core_1["default"](item).getNodeName().toLowerCase() + ">";
  15139. } else {
  15140. dom_core_1["default"](item).css('line-height', value);
  15141. }
  15142. });
  15143. if (st) {
  15144. this.action(st, editor);
  15145. } //恢复已选择的选区
  15146. dom = $selectionAll.elems[0];
  15147. this.setRange(dom.children[indexStore_1[0]], dom.children[indexStore_1[1]]);
  15148. return;
  15149. } //遍历dom 获取祖父元素 直到contenteditable属性的div标签
  15150. dom = this.getDom(dom); //校验允许lineheight设置标签
  15151. if ((0, _indexOf["default"])(allowArray).call(allowArray, dom_core_1["default"](dom).getNodeName()) === -1) {
  15152. return;
  15153. }
  15154. style = dom.getAttribute('style');
  15155. styleList = style ? style.split(';') : []; //全选 dom下所有的内容
  15156. selection === null || selection === void 0 ? void 0 : selection.selectAllChildren(dom); //保存range
  15157. editor.selection.saveRange(); //判断是否存在value 默认 移除line-height
  15158. if (!value) {
  15159. if (style) {
  15160. styleStr = this.styleProcessing(styleList); //避免没有其它属性 只留下 ‘style’ 减少代码
  15161. if (styleStr === '') {
  15162. st = "<" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">" + dom.innerHTML + "</" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">";
  15163. } else {
  15164. st = "<" + dom_core_1["default"](dom).getNodeName().toLowerCase() + " style=\"" + styleStr + "\">" + dom.innerHTML + "</" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">";
  15165. }
  15166. this.action(st, editor);
  15167. }
  15168. return;
  15169. }
  15170. if (style) {
  15171. //存在style 检索其它style属性
  15172. styleStr = this.styleProcessing(styleList) + ("line-height:" + value + ";");
  15173. } else {
  15174. styleStr = "line-height:" + value + ";";
  15175. }
  15176. st = "<" + dom_core_1["default"](dom).getNodeName().toLowerCase() + " style=\"" + styleStr + "\">" + dom.innerHTML + "</" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">"; //防止BLOCKQUOTE叠加 or IE下导致P嵌套出现误删
  15177. if (dom_core_1["default"](dom).getNodeName() === 'BLOCKQUOTE' || util_1.UA.isIE()) {
  15178. dom_core_1["default"](dom).css('line-height', value);
  15179. } else {
  15180. this.action(st, editor);
  15181. }
  15182. };
  15183. /**
  15184. * 遍历dom 获取祖父元素 直到contenteditable属性的div标签
  15185. *
  15186. */
  15187. LineHeight.prototype.getDom = function (dom) {
  15188. var DOM = dom_core_1["default"](dom).elems[0];
  15189. if (!DOM.parentNode) {
  15190. return DOM;
  15191. }
  15192. function getParentNode($node, editor) {
  15193. var $parent = dom_core_1["default"]($node.parentNode);
  15194. if (editor.$textElem.equal($parent)) {
  15195. return $node;
  15196. } else {
  15197. return getParentNode($parent.elems[0], editor);
  15198. }
  15199. }
  15200. DOM = getParentNode(DOM, this.editor);
  15201. return DOM;
  15202. };
  15203. /**
  15204. * 执行 document.execCommand
  15205. *
  15206. */
  15207. LineHeight.prototype.action = function (html_str, editor) {
  15208. editor.cmd["do"]('insertHTML', html_str);
  15209. };
  15210. /**
  15211. * style 处理
  15212. */
  15213. LineHeight.prototype.styleProcessing = function (styleList) {
  15214. var styleStr = '';
  15215. (0, _forEach["default"])(styleList).call(styleList, function (item) {
  15216. item !== '' && (0, _indexOf["default"])(item).call(item, 'line-height') === -1 ? styleStr = styleStr + item + ';' : '';
  15217. });
  15218. return styleStr;
  15219. };
  15220. /**
  15221. * 段落全选 比如:避免11变成111
  15222. */
  15223. LineHeight.prototype.setRange = function (startDom, endDom) {
  15224. var editor = this.editor;
  15225. var selection = window.getSelection ? window.getSelection() : document.getSelection(); //清除所有的选区
  15226. selection === null || selection === void 0 ? void 0 : selection.removeAllRanges();
  15227. var range = document.createRange();
  15228. var star = startDom;
  15229. var end = endDom;
  15230. range.setStart(star, 0);
  15231. range.setEnd(end, 1);
  15232. selection === null || selection === void 0 ? void 0 : selection.addRange(range); //保存设置好的选区
  15233. editor.selection.saveRange(); //清除所有的选区
  15234. selection === null || selection === void 0 ? void 0 : selection.removeAllRanges(); //恢复选区
  15235. editor.selection.restoreSelection();
  15236. };
  15237. /**
  15238. * 尝试修改菜单激活状态
  15239. */
  15240. LineHeight.prototype.tryChangeActive = function () {
  15241. var editor = this.editor;
  15242. var $selectionElem = editor.selection.getSelectionContainerElem();
  15243. if ($selectionElem && editor.$textElem.equal($selectionElem)) {
  15244. //避免选中多行设置
  15245. return;
  15246. }
  15247. var dom = dom_core_1["default"](editor.selection.getSelectionStartElem()); // 有些情况下 dom 可能为空,比如编辑器初始化
  15248. if (dom.length === 0) return;
  15249. dom = this.getDom(dom.elems[0]);
  15250. var style = dom.getAttribute('style') ? dom.getAttribute('style') : ''; //判断当前标签是否具有line-height属性
  15251. if (style && (0, _indexOf["default"])(style).call(style, 'line-height') !== -1) {
  15252. this.active();
  15253. } else {
  15254. this.unActive();
  15255. }
  15256. };
  15257. return LineHeight;
  15258. }(DropListMenu_1["default"]);
  15259. exports["default"] = LineHeight;
  15260. /***/ }),
  15261. /* 394 */
  15262. /***/ (function(module, exports, __webpack_require__) {
  15263. "use strict";
  15264. var _interopRequireDefault = __webpack_require__(0);
  15265. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15266. var _forEach = _interopRequireDefault(__webpack_require__(4));
  15267. (0, _defineProperty["default"])(exports, "__esModule", {
  15268. value: true
  15269. });
  15270. var tslib_1 = __webpack_require__(2);
  15271. /**
  15272. * @description 行高 菜单
  15273. * @author lichunlin
  15274. */
  15275. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15276. var lineHeightList = function () {
  15277. function lineHeightList(editor, list) {
  15278. var _this = this;
  15279. this.itemList = [{
  15280. $elem: dom_core_1["default"]("<span>" + editor.i18next.t('默认') + "</span>"),
  15281. value: ''
  15282. }];
  15283. (0, _forEach["default"])(list).call(list, function (item) {
  15284. _this.itemList.push({
  15285. $elem: dom_core_1["default"]("<span>" + item + "</span>"),
  15286. value: item
  15287. });
  15288. });
  15289. }
  15290. lineHeightList.prototype.getItemList = function () {
  15291. return this.itemList;
  15292. };
  15293. return lineHeightList;
  15294. }();
  15295. exports["default"] = lineHeightList;
  15296. /***/ }),
  15297. /* 395 */
  15298. /***/ (function(module, exports, __webpack_require__) {
  15299. "use strict";
  15300. /**
  15301. * @description 撤销
  15302. * @author tonghan
  15303. */
  15304. var _interopRequireDefault = __webpack_require__(0);
  15305. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15306. (0, _defineProperty["default"])(exports, "__esModule", {
  15307. value: true
  15308. });
  15309. var tslib_1 = __webpack_require__(2);
  15310. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15311. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  15312. var Undo = function (_super) {
  15313. tslib_1.__extends(Undo, _super);
  15314. function Undo(editor) {
  15315. var _this = this;
  15316. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u64A4\u9500\">\n <i class=\"w-e-icon-undo\"></i>\n </div>");
  15317. _this = _super.call(this, $elem, editor) || this;
  15318. return _this;
  15319. }
  15320. /**
  15321. * 点击事件
  15322. */
  15323. Undo.prototype.clickHandler = function () {
  15324. var editor = this.editor;
  15325. editor.history.revoke(); // 重新创建 range,是处理当初始化编辑器,API插入内容后撤销,range 不在编辑器内部的问题
  15326. var children = editor.$textElem.children();
  15327. if (!(children === null || children === void 0 ? void 0 : children.length)) return;
  15328. var $last = children.last();
  15329. editor.selection.createRangeByElem($last, false, true);
  15330. editor.selection.restoreSelection();
  15331. };
  15332. /**
  15333. * 尝试修改菜单激活状态
  15334. */
  15335. Undo.prototype.tryChangeActive = function () {
  15336. // 标准模式下才进行操作
  15337. if (!this.editor.isCompatibleMode) {
  15338. if (this.editor.history.size[0]) {
  15339. this.active();
  15340. } else {
  15341. this.unActive();
  15342. }
  15343. }
  15344. };
  15345. return Undo;
  15346. }(BtnMenu_1["default"]);
  15347. exports["default"] = Undo;
  15348. /***/ }),
  15349. /* 396 */
  15350. /***/ (function(module, exports, __webpack_require__) {
  15351. "use strict";
  15352. /**
  15353. * @description 重做
  15354. * @author tonghan
  15355. */
  15356. var _interopRequireDefault = __webpack_require__(0);
  15357. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15358. (0, _defineProperty["default"])(exports, "__esModule", {
  15359. value: true
  15360. });
  15361. var tslib_1 = __webpack_require__(2);
  15362. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15363. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  15364. var Redo = function (_super) {
  15365. tslib_1.__extends(Redo, _super);
  15366. function Redo(editor) {
  15367. var _this = this;
  15368. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u6062\u590D\">\n <i class=\"w-e-icon-redo\"></i>\n </div>");
  15369. _this = _super.call(this, $elem, editor) || this;
  15370. return _this;
  15371. }
  15372. /**
  15373. * 点击事件
  15374. */
  15375. Redo.prototype.clickHandler = function () {
  15376. var editor = this.editor;
  15377. editor.history.restore(); // 重新创建 range,是处理当初始化编辑器,API插入内容后撤销,range 不在编辑器内部的问题
  15378. var children = editor.$textElem.children();
  15379. if (!(children === null || children === void 0 ? void 0 : children.length)) return;
  15380. var $last = children.last();
  15381. editor.selection.createRangeByElem($last, false, true);
  15382. editor.selection.restoreSelection();
  15383. };
  15384. /**
  15385. * 尝试修改菜单激活状态
  15386. */
  15387. Redo.prototype.tryChangeActive = function () {
  15388. // 标准模式下才进行操作
  15389. if (!this.editor.isCompatibleMode) {
  15390. if (this.editor.history.size[1]) {
  15391. this.active();
  15392. } else {
  15393. this.unActive();
  15394. }
  15395. }
  15396. };
  15397. return Redo;
  15398. }(BtnMenu_1["default"]);
  15399. exports["default"] = Redo;
  15400. /***/ }),
  15401. /* 397 */
  15402. /***/ (function(module, exports, __webpack_require__) {
  15403. "use strict";
  15404. /**
  15405. * @description 创建table
  15406. * @author lichunlin
  15407. */
  15408. var _interopRequireDefault = __webpack_require__(0);
  15409. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15410. (0, _defineProperty["default"])(exports, "__esModule", {
  15411. value: true
  15412. });
  15413. var tslib_1 = __webpack_require__(2);
  15414. var PanelMenu_1 = tslib_1.__importDefault(__webpack_require__(36));
  15415. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15416. var create_panel_conf_1 = tslib_1.__importDefault(__webpack_require__(398));
  15417. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  15418. var index_1 = tslib_1.__importDefault(__webpack_require__(407));
  15419. var Table = function (_super) {
  15420. tslib_1.__extends(Table, _super);
  15421. function Table(editor) {
  15422. var _this = this;
  15423. var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="表格"><i class="w-e-icon-table2"></i></div>');
  15424. _this = _super.call(this, $elem, editor) || this; // 绑定事件
  15425. index_1["default"](editor);
  15426. return _this;
  15427. }
  15428. /**
  15429. * 菜单点击事件
  15430. */
  15431. Table.prototype.clickHandler = function () {
  15432. this.createPanel();
  15433. };
  15434. /**
  15435. * 创建 panel
  15436. */
  15437. Table.prototype.createPanel = function () {
  15438. var conf = create_panel_conf_1["default"](this.editor);
  15439. var panel = new Panel_1["default"](this, conf);
  15440. panel.create();
  15441. };
  15442. /**
  15443. * 尝试修改菜单 active 状态
  15444. */
  15445. Table.prototype.tryChangeActive = function () {};
  15446. return Table;
  15447. }(PanelMenu_1["default"]);
  15448. exports["default"] = Table;
  15449. /***/ }),
  15450. /* 398 */
  15451. /***/ (function(module, exports, __webpack_require__) {
  15452. "use strict";
  15453. /**
  15454. * @description table 菜单 panel tab 配置
  15455. * @author lichunlin
  15456. */
  15457. var _interopRequireDefault = __webpack_require__(0);
  15458. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15459. var _isInteger = _interopRequireDefault(__webpack_require__(399));
  15460. (0, _defineProperty["default"])(exports, "__esModule", {
  15461. value: true
  15462. });
  15463. var tslib_1 = __webpack_require__(2);
  15464. var util_1 = __webpack_require__(6);
  15465. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15466. __webpack_require__(404);
  15467. var create_table_1 = tslib_1.__importDefault(__webpack_require__(406));
  15468. /**
  15469. * 判断一个数值是否为正整数
  15470. * @param { number } n 被验证的值
  15471. */
  15472. function isPositiveInteger(n) {
  15473. //是否为正整数
  15474. return n > 0 && (0, _isInteger["default"])(n);
  15475. }
  15476. function default_1(editor) {
  15477. var createTable = new create_table_1["default"](editor); // panel 中需要用到的id
  15478. var colId = util_1.getRandom('w-col-id');
  15479. var rowId = util_1.getRandom('w-row-id');
  15480. var insertBtnId = util_1.getRandom('btn-link');
  15481. var i18nPrefix = 'menus.panelMenus.table.';
  15482. var t = function t(text) {
  15483. return editor.i18next.t(text);
  15484. }; // tabs 配置 -----------------------------------------
  15485. var tabsConf = [{
  15486. title: t(i18nPrefix + "\u63D2\u5165\u8868\u683C"),
  15487. tpl: "<div>\n <div class=\"w-e-table\">\n <span>" + t('创建') + "</span>\n <input id=\"" + rowId + "\" type=\"text\" class=\"w-e-table-input\" value=\"5\"/></td>\n <span>" + t(i18nPrefix + "\u884C") + "</span>\n <input id=\"" + colId + "\" type=\"text\" class=\"w-e-table-input\" value=\"5\"/></td>\n <span>" + (t(i18nPrefix + "\u5217") + t(i18nPrefix + "\u7684") + t(i18nPrefix + "\u8868\u683C")) + "</span>\n </div>\n <div class=\"w-e-button-container\">\n <button type=\"button\" id=\"" + insertBtnId + "\" class=\"right\">" + t('插入') + "</button>\n </div>\n </div>",
  15488. events: [{
  15489. selector: '#' + insertBtnId,
  15490. type: 'click',
  15491. fn: function fn() {
  15492. var colValue = Number(dom_core_1["default"]('#' + colId).val());
  15493. var rowValue = Number(dom_core_1["default"]('#' + rowId).val()); //校验是否传值
  15494. if (isPositiveInteger(rowValue) && isPositiveInteger(colValue)) {
  15495. createTable.createAction(rowValue, colValue);
  15496. return true;
  15497. } else {
  15498. editor.config.customAlert('表格行列请输入正整数', 'warning');
  15499. return false;
  15500. } // 返回 true 表示函数执行结束之后关闭 panel
  15501. },
  15502. bindEnter: true
  15503. }]
  15504. }]; // tabs end
  15505. // 最终的配置 -----------------------------------------
  15506. var conf = {
  15507. width: 330,
  15508. height: 0,
  15509. tabs: []
  15510. };
  15511. conf.tabs.push(tabsConf[0]);
  15512. return conf;
  15513. }
  15514. exports["default"] = default_1;
  15515. /***/ }),
  15516. /* 399 */
  15517. /***/ (function(module, exports, __webpack_require__) {
  15518. module.exports = __webpack_require__(400);
  15519. /***/ }),
  15520. /* 400 */
  15521. /***/ (function(module, exports, __webpack_require__) {
  15522. var parent = __webpack_require__(401);
  15523. module.exports = parent;
  15524. /***/ }),
  15525. /* 401 */
  15526. /***/ (function(module, exports, __webpack_require__) {
  15527. __webpack_require__(402);
  15528. var path = __webpack_require__(11);
  15529. module.exports = path.Number.isInteger;
  15530. /***/ }),
  15531. /* 402 */
  15532. /***/ (function(module, exports, __webpack_require__) {
  15533. var $ = __webpack_require__(5);
  15534. var isInteger = __webpack_require__(403);
  15535. // `Number.isInteger` method
  15536. // https://tc39.es/ecma262/#sec-number.isinteger
  15537. $({ target: 'Number', stat: true }, {
  15538. isInteger: isInteger
  15539. });
  15540. /***/ }),
  15541. /* 403 */
  15542. /***/ (function(module, exports, __webpack_require__) {
  15543. var isObject = __webpack_require__(13);
  15544. var floor = Math.floor;
  15545. // `Number.isInteger` method implementation
  15546. // https://tc39.es/ecma262/#sec-number.isinteger
  15547. module.exports = function isInteger(it) {
  15548. return !isObject(it) && isFinite(it) && floor(it) === it;
  15549. };
  15550. /***/ }),
  15551. /* 404 */
  15552. /***/ (function(module, exports, __webpack_require__) {
  15553. var api = __webpack_require__(21);
  15554. var content = __webpack_require__(405);
  15555. content = content.__esModule ? content.default : content;
  15556. if (typeof content === 'string') {
  15557. content = [[module.i, content, '']];
  15558. }
  15559. var options = {};
  15560. options.insert = "head";
  15561. options.singleton = false;
  15562. var update = api(content, options);
  15563. module.exports = content.locals || {};
  15564. /***/ }),
  15565. /* 405 */
  15566. /***/ (function(module, exports, __webpack_require__) {
  15567. // Imports
  15568. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  15569. exports = ___CSS_LOADER_API_IMPORT___(false);
  15570. // Module
  15571. exports.push([module.i, ".w-e-table {\n display: flex;\n}\n.w-e-table .w-e-table-input {\n width: 40px;\n text-align: center!important;\n margin: 0 5px;\n}\n", ""]);
  15572. // Exports
  15573. module.exports = exports;
  15574. /***/ }),
  15575. /* 406 */
  15576. /***/ (function(module, exports, __webpack_require__) {
  15577. "use strict";
  15578. /**
  15579. * @description 创建tabel
  15580. * @author lichunlin
  15581. */
  15582. var _interopRequireDefault = __webpack_require__(0);
  15583. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15584. (0, _defineProperty["default"])(exports, "__esModule", {
  15585. value: true
  15586. });
  15587. var tslib_1 = __webpack_require__(2);
  15588. var const_1 = __webpack_require__(7);
  15589. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15590. var CreateTable = function () {
  15591. function CreateTable(editor) {
  15592. this.editor = editor;
  15593. }
  15594. /**
  15595. * 执行创建
  15596. * @param rowValue 行数
  15597. * @param colValue 列数
  15598. */
  15599. CreateTable.prototype.createAction = function (rowValue, colValue) {
  15600. var editor = this.editor; //不允许在有序列表中添加table
  15601. var $selectionElem = dom_core_1["default"](editor.selection.getSelectionContainerElem());
  15602. var $ul = dom_core_1["default"]($selectionElem.elems[0]).parentUntilEditor('UL', editor);
  15603. var $ol = dom_core_1["default"]($selectionElem.elems[0]).parentUntilEditor('OL', editor);
  15604. if ($ul || $ol) {
  15605. return;
  15606. }
  15607. var tableDom = this.createTableHtml(rowValue, colValue);
  15608. editor.cmd["do"]('insertHTML', tableDom);
  15609. };
  15610. /**
  15611. * 创建table、行、列
  15612. * @param rowValue 行数
  15613. * @param colValue 列数
  15614. */
  15615. CreateTable.prototype.createTableHtml = function (rowValue, colValue) {
  15616. var rowStr = '';
  15617. var colStr = '';
  15618. for (var i = 0; i < rowValue; i++) {
  15619. colStr = '';
  15620. for (var j = 0; j < colValue; j++) {
  15621. if (i === 0) {
  15622. colStr = colStr + '<th></th>';
  15623. } else {
  15624. colStr = colStr + '<td></td>';
  15625. }
  15626. }
  15627. rowStr = rowStr + '<tr>' + colStr + '</tr>';
  15628. }
  15629. var tableDom = "<table border=\"0\" width=\"100%\" cellpadding=\"0\" cellspacing=\"0\"><tbody>" + rowStr + ("</tbody></table>" + const_1.EMPTY_P);
  15630. return tableDom;
  15631. };
  15632. return CreateTable;
  15633. }();
  15634. exports["default"] = CreateTable;
  15635. /***/ }),
  15636. /* 407 */
  15637. /***/ (function(module, exports, __webpack_require__) {
  15638. "use strict";
  15639. /**
  15640. * @description 绑定点击事件
  15641. * @author lichunlin
  15642. */
  15643. var _interopRequireDefault = __webpack_require__(0);
  15644. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15645. (0, _defineProperty["default"])(exports, "__esModule", {
  15646. value: true
  15647. });
  15648. var tslib_1 = __webpack_require__(2);
  15649. var tooltip_event_1 = tslib_1.__importDefault(__webpack_require__(408));
  15650. var table_event_1 = __webpack_require__(416);
  15651. /**
  15652. * 绑定事件
  15653. * @param editor 编辑器实例
  15654. */
  15655. function bindEvent(editor) {
  15656. //Tooltip
  15657. tooltip_event_1["default"](editor);
  15658. table_event_1.bindEventKeyboardEvent(editor);
  15659. table_event_1.bindClickEvent(editor);
  15660. }
  15661. exports["default"] = bindEvent;
  15662. /***/ }),
  15663. /* 408 */
  15664. /***/ (function(module, exports, __webpack_require__) {
  15665. "use strict";
  15666. /**
  15667. * @description tooltip 事件
  15668. * @author lichunlin
  15669. */
  15670. var _interopRequireDefault = __webpack_require__(0);
  15671. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15672. (0, _defineProperty["default"])(exports, "__esModule", {
  15673. value: true
  15674. });
  15675. var tslib_1 = __webpack_require__(2);
  15676. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15677. var Tooltip_1 = tslib_1.__importDefault(__webpack_require__(37)); //操作事件
  15678. var operating_event_1 = tslib_1.__importDefault(__webpack_require__(409));
  15679. var getNode_1 = tslib_1.__importDefault(__webpack_require__(415));
  15680. var const_1 = __webpack_require__(7);
  15681. /**
  15682. * 生成 Tooltip 的显示隐藏函数
  15683. */
  15684. function createShowHideFn(editor) {
  15685. var tooltip;
  15686. /**
  15687. * 显示 tooltip
  15688. * @param table元素
  15689. */
  15690. function showTableTooltip($node) {
  15691. var getnode = new getNode_1["default"](editor);
  15692. var i18nPrefix = 'menus.panelMenus.table.';
  15693. var t = function t(text, prefix) {
  15694. if (prefix === void 0) {
  15695. prefix = i18nPrefix;
  15696. }
  15697. return editor.i18next.t(prefix + text);
  15698. };
  15699. var conf = [{
  15700. // $elem: $("<span class='w-e-icon-trash-o'></span>"),
  15701. $elem: dom_core_1["default"]("<span>" + t('删除表格') + "</span>"),
  15702. onClick: function onClick(editor, $node) {
  15703. // 选中img元素
  15704. editor.selection.createRangeByElem($node);
  15705. editor.selection.restoreSelection();
  15706. editor.cmd["do"]('insertHTML', const_1.EMPTY_P); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  15707. return true;
  15708. }
  15709. }, {
  15710. $elem: dom_core_1["default"]("<span>" + t('添加行') + "</span>"),
  15711. onClick: function onClick(editor, $node) {
  15712. // 禁止多选操作
  15713. var isMore = isMoreRowAction(editor);
  15714. if (isMore) {
  15715. return true;
  15716. } //当前元素
  15717. var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
  15718. var $currentRow = getnode.getRowNode(selectDom.elems[0]);
  15719. if (!$currentRow) {
  15720. return true;
  15721. } //获取当前行的index
  15722. var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow)); //生成要替换的html
  15723. var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
  15724. var newdom = getnode.getTableHtml(operating_event_1["default"].ProcessingRow(dom_core_1["default"](htmlStr), index).elems[0]);
  15725. newdom = _isEmptyP($node, newdom); // 选中table
  15726. editor.selection.createRangeByElem($node);
  15727. editor.selection.restoreSelection();
  15728. editor.cmd["do"]('insertHTML', newdom);
  15729. return true;
  15730. }
  15731. }, {
  15732. $elem: dom_core_1["default"]("<span>" + t('删除行') + "</span>"),
  15733. onClick: function onClick(editor, $node) {
  15734. // 禁止多选操作
  15735. var isMore = isMoreRowAction(editor);
  15736. if (isMore) {
  15737. return true;
  15738. } //当前元素
  15739. var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
  15740. var $currentRow = getnode.getRowNode(selectDom.elems[0]);
  15741. if (!$currentRow) {
  15742. return true;
  15743. } //获取当前行的index
  15744. var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow)); //生成要替换的html
  15745. var htmlStr = getnode.getTableHtml($node.elems[0]); //获取新生成的table 判断是否是最后一行被删除 是 删除整个table
  15746. var trLength = operating_event_1["default"].DeleteRow(dom_core_1["default"](htmlStr), index).elems[0].children[0].children.length; //生成新的table
  15747. var newdom = ''; // 选中table
  15748. editor.selection.createRangeByElem($node);
  15749. editor.selection.restoreSelection();
  15750. if (trLength === 0) {
  15751. newdom = const_1.EMPTY_P;
  15752. } else {
  15753. newdom = getnode.getTableHtml(operating_event_1["default"].DeleteRow(dom_core_1["default"](htmlStr), index).elems[0]);
  15754. }
  15755. newdom = _isEmptyP($node, newdom);
  15756. editor.cmd["do"]('insertHTML', newdom);
  15757. return true;
  15758. }
  15759. }, {
  15760. $elem: dom_core_1["default"]("<span>" + t('添加列') + "</span>"),
  15761. onClick: function onClick(editor, $node) {
  15762. // 禁止多选操作
  15763. var isMore = isMoreRowAction(editor);
  15764. if (isMore) {
  15765. return true;
  15766. } //当前元素
  15767. var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前列的index
  15768. var index = getnode.getCurrentColIndex(selectDom.elems[0]); //生成要替换的html
  15769. var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
  15770. var newdom = getnode.getTableHtml(operating_event_1["default"].ProcessingCol(dom_core_1["default"](htmlStr), index).elems[0]);
  15771. newdom = _isEmptyP($node, newdom); // 选中table
  15772. editor.selection.createRangeByElem($node);
  15773. editor.selection.restoreSelection();
  15774. editor.cmd["do"]('insertHTML', newdom);
  15775. return true;
  15776. }
  15777. }, {
  15778. $elem: dom_core_1["default"]("<span>" + t('删除列') + "</span>"),
  15779. onClick: function onClick(editor, $node) {
  15780. // 禁止多选操作
  15781. var isMore = isMoreRowAction(editor);
  15782. if (isMore) {
  15783. return true;
  15784. } //当前元素
  15785. var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前列的index
  15786. var index = getnode.getCurrentColIndex(selectDom.elems[0]); //生成要替换的html
  15787. var htmlStr = getnode.getTableHtml($node.elems[0]); //获取新生成的table 判断是否是最后一列被删除 是 删除整个table
  15788. var newDom = operating_event_1["default"].DeleteCol(dom_core_1["default"](htmlStr), index); // 获取子节点的数量
  15789. var tdLength = newDom.elems[0].children[0].children[0].children.length; //生成新的table
  15790. var newdom = ''; // 选中table
  15791. editor.selection.createRangeByElem($node);
  15792. editor.selection.restoreSelection(); // 如果没有列了 则替换成空行
  15793. if (tdLength === 0) {
  15794. newdom = const_1.EMPTY_P;
  15795. } else {
  15796. newdom = getnode.getTableHtml(newDom.elems[0]);
  15797. }
  15798. newdom = _isEmptyP($node, newdom);
  15799. editor.cmd["do"]('insertHTML', newdom);
  15800. return true;
  15801. }
  15802. }, {
  15803. $elem: dom_core_1["default"]("<span>" + t('设置表头') + "</span>"),
  15804. onClick: function onClick(editor, $node) {
  15805. // 禁止多选操作
  15806. var isMore = isMoreRowAction(editor);
  15807. if (isMore) {
  15808. return true;
  15809. } //当前元素
  15810. var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
  15811. var $currentRow = getnode.getRowNode(selectDom.elems[0]);
  15812. if (!$currentRow) {
  15813. return true;
  15814. } //获取当前行的index
  15815. var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow));
  15816. if (index !== 0) {
  15817. //控制在table的第一行
  15818. index = 0;
  15819. } //生成要替换的html
  15820. var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
  15821. var newdom = getnode.getTableHtml(operating_event_1["default"].setTheHeader(dom_core_1["default"](htmlStr), index, 'th').elems[0]);
  15822. newdom = _isEmptyP($node, newdom); // 选中table
  15823. editor.selection.createRangeByElem($node);
  15824. editor.selection.restoreSelection();
  15825. editor.cmd["do"]('insertHTML', newdom);
  15826. return true;
  15827. }
  15828. }, {
  15829. $elem: dom_core_1["default"]("<span>" + t('取消表头') + "</span>"),
  15830. onClick: function onClick(editor, $node) {
  15831. //当前元素
  15832. var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
  15833. var $currentRow = getnode.getRowNode(selectDom.elems[0]);
  15834. if (!$currentRow) {
  15835. return true;
  15836. } //获取当前行的index
  15837. var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow));
  15838. if (index !== 0) {
  15839. //控制在table的第一行
  15840. index = 0;
  15841. } //生成要替换的html
  15842. var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
  15843. var newdom = getnode.getTableHtml(operating_event_1["default"].setTheHeader(dom_core_1["default"](htmlStr), index, 'td').elems[0]);
  15844. newdom = _isEmptyP($node, newdom); // 选中table
  15845. editor.selection.createRangeByElem($node);
  15846. editor.selection.restoreSelection();
  15847. editor.cmd["do"]('insertHTML', newdom);
  15848. return true;
  15849. }
  15850. }];
  15851. tooltip = new Tooltip_1["default"](editor, $node, conf);
  15852. tooltip.create();
  15853. }
  15854. /**
  15855. * 隐藏 tooltip
  15856. */
  15857. function hideTableTooltip() {
  15858. // 移除 tooltip
  15859. if (tooltip) {
  15860. tooltip.remove();
  15861. tooltip = null;
  15862. }
  15863. }
  15864. return {
  15865. showTableTooltip: showTableTooltip,
  15866. hideTableTooltip: hideTableTooltip
  15867. };
  15868. }
  15869. /**
  15870. * 判断是否是多行
  15871. */
  15872. function isMoreRowAction(editor) {
  15873. var $startElem = editor.selection.getSelectionStartElem();
  15874. var $endElem = editor.selection.getSelectionEndElem();
  15875. if (($startElem === null || $startElem === void 0 ? void 0 : $startElem.elems[0]) !== ($endElem === null || $endElem === void 0 ? void 0 : $endElem.elems[0])) {
  15876. return true;
  15877. } else {
  15878. return false;
  15879. }
  15880. }
  15881. /**
  15882. * 绑定 tooltip 事件
  15883. * @param editor 编辑器实例
  15884. */
  15885. function bindTooltipEvent(editor) {
  15886. var _a = createShowHideFn(editor),
  15887. showTableTooltip = _a.showTableTooltip,
  15888. hideTableTooltip = _a.hideTableTooltip; // 点击table元素是,显示 tooltip
  15889. editor.txt.eventHooks.tableClickEvents.push(showTableTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
  15890. editor.txt.eventHooks.clickEvents.push(hideTableTooltip);
  15891. editor.txt.eventHooks.keyupEvents.push(hideTableTooltip);
  15892. editor.txt.eventHooks.toolbarClickEvents.push(hideTableTooltip);
  15893. editor.txt.eventHooks.menuClickEvents.push(hideTableTooltip);
  15894. editor.txt.eventHooks.textScrollEvents.push(hideTableTooltip);
  15895. }
  15896. exports["default"] = bindTooltipEvent;
  15897. /**
  15898. * 判断表格的下一个节点是否是空行
  15899. */
  15900. function _isEmptyP($node, newdom) {
  15901. // 当表格的下一个兄弟节点是空行时,在 newdom 后添加 EMPTY_P
  15902. var nextNode = $node.elems[0].nextSibling;
  15903. if (!nextNode || nextNode.innerHTML === '<br>') {
  15904. newdom += "" + const_1.EMPTY_P;
  15905. }
  15906. return newdom;
  15907. }
  15908. /***/ }),
  15909. /* 409 */
  15910. /***/ (function(module, exports, __webpack_require__) {
  15911. "use strict";
  15912. var _interopRequireDefault = __webpack_require__(0);
  15913. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  15914. var _slice = _interopRequireDefault(__webpack_require__(47));
  15915. var _splice = _interopRequireDefault(__webpack_require__(99));
  15916. var _forEach = _interopRequireDefault(__webpack_require__(4));
  15917. var _from = _interopRequireDefault(__webpack_require__(143));
  15918. (0, _defineProperty["default"])(exports, "__esModule", {
  15919. value: true
  15920. });
  15921. var tslib_1 = __webpack_require__(2);
  15922. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  15923. /**
  15924. * 处理新添加行
  15925. * @param $node 整个table
  15926. * @param _index 行的inde
  15927. */
  15928. function ProcessingRow($node, _index) {
  15929. //执行获取tbody节点
  15930. var $dom = generateDomAction($node); //取出所有的行
  15931. var domArray = (0, _slice["default"])(Array.prototype).apply($dom.children); //列的数量
  15932. var childrenLength = domArray[0].children.length; //创建新tr
  15933. var tr = document.createElement('tr');
  15934. for (var i = 0; i < childrenLength; i++) {
  15935. var td = document.createElement('td');
  15936. tr.appendChild(td);
  15937. } //插入集合中
  15938. (0, _splice["default"])(domArray).call(domArray, _index + 1, 0, tr); //移除、新增节点事件
  15939. removeAndInsertAction($dom, domArray);
  15940. return dom_core_1["default"]($dom.parentNode);
  15941. }
  15942. /**
  15943. * 处理新添加列
  15944. * @param $node 整个table
  15945. * @param _index 列的inde
  15946. */
  15947. function ProcessingCol($node, _index) {
  15948. //执行获取tbody节点
  15949. var $dom = generateDomAction($node); //取出所有的行
  15950. var domArray = (0, _slice["default"])(Array.prototype).apply($dom.children);
  15951. var _loop_1 = function _loop_1(i) {
  15952. var _context;
  15953. var cArray = []; //取出所有的列
  15954. (0, _forEach["default"])(_context = (0, _from["default"])(domArray[i].children)).call(_context, function (item) {
  15955. cArray.push(item);
  15956. }); //移除行的旧的子节点
  15957. while (domArray[i].children.length !== 0) {
  15958. domArray[i].removeChild(domArray[i].children[0]);
  15959. } //列分th td
  15960. var td = dom_core_1["default"](cArray[0]).getNodeName() !== 'TH' ? document.createElement('td') : document.createElement('th'); // let td = document.createElement('td')
  15961. (0, _splice["default"])(cArray).call(cArray, _index + 1, 0, td); //插入新的子节点
  15962. for (var j = 0; j < cArray.length; j++) {
  15963. domArray[i].appendChild(cArray[j]);
  15964. }
  15965. }; //创建td
  15966. for (var i = 0; i < domArray.length; i++) {
  15967. _loop_1(i);
  15968. } //移除、新增节点事件
  15969. removeAndInsertAction($dom, domArray);
  15970. return dom_core_1["default"]($dom.parentNode);
  15971. }
  15972. /**
  15973. * 处理删除行
  15974. * @param $node 整个table
  15975. * @param _index 行的inde
  15976. */
  15977. function DeleteRow($node, _index) {
  15978. //执行获取tbody节点
  15979. var $dom = generateDomAction($node); //取出所有的行
  15980. var domArray = (0, _slice["default"])(Array.prototype).apply($dom.children); //删除行
  15981. (0, _splice["default"])(domArray).call(domArray, _index, 1); //移除、新增节点事件
  15982. removeAndInsertAction($dom, domArray);
  15983. return dom_core_1["default"]($dom.parentNode);
  15984. }
  15985. /**
  15986. * 处理删除列
  15987. * @param $node
  15988. * @param _index
  15989. */
  15990. function DeleteCol($node, _index) {
  15991. //执行获取tbody节点
  15992. var $dom = generateDomAction($node); //取出所有的行
  15993. var domArray = (0, _slice["default"])(Array.prototype).apply($dom.children);
  15994. var _loop_2 = function _loop_2(i) {
  15995. var _context2;
  15996. var cArray = []; //取出所有的列
  15997. (0, _forEach["default"])(_context2 = (0, _from["default"])(domArray[i].children)).call(_context2, function (item) {
  15998. cArray.push(item);
  15999. }); //移除行的旧的子节点
  16000. while (domArray[i].children.length !== 0) {
  16001. domArray[i].removeChild(domArray[i].children[0]);
  16002. }
  16003. (0, _splice["default"])(cArray).call(cArray, _index, 1); //插入新的子节点
  16004. for (var j = 0; j < cArray.length; j++) {
  16005. domArray[i].appendChild(cArray[j]);
  16006. }
  16007. }; //创建td
  16008. for (var i = 0; i < domArray.length; i++) {
  16009. _loop_2(i);
  16010. } //移除、新增节点事件
  16011. removeAndInsertAction($dom, domArray);
  16012. return dom_core_1["default"]($dom.parentNode);
  16013. }
  16014. /**
  16015. * 处理设置/取消表头
  16016. * @param $node
  16017. * @param _index
  16018. * @type 替换的标签 th还是td
  16019. */
  16020. function setTheHeader($node, _index, type) {
  16021. // 执行获取tbody节点
  16022. var $dom = generateDomAction($node); // 取出所有的行
  16023. var domArray = (0, _slice["default"])(Array.prototype).apply($dom.children); // 列的数量
  16024. var cols = domArray[_index].children; // 创建新tr
  16025. var tr = document.createElement('tr');
  16026. var _loop_3 = function _loop_3(i) {
  16027. var _context3;
  16028. // 根据type(td 或者 th)生成对应的el
  16029. var el = document.createElement(type);
  16030. var col = cols[i];
  16031. /**
  16032. * 没有使用children是因为谷歌纯文本内容children数组就为空,而火狐纯文本内容是“xxx<br>”使用children只能获取br
  16033. * 当然使用childNodes也涵盖支持我们表头使用表情,代码块等,不管是设置还是取消都会保留第一行
  16034. */
  16035. (0, _forEach["default"])(_context3 = (0, _from["default"])(col.childNodes)).call(_context3, function (item) {
  16036. el.appendChild(item);
  16037. });
  16038. tr.appendChild(el);
  16039. };
  16040. for (var i = 0; i < cols.length; i++) {
  16041. _loop_3(i);
  16042. } //插入集合中
  16043. (0, _splice["default"])(domArray).call(domArray, _index, 1, tr); //移除、新增节点事件
  16044. removeAndInsertAction($dom, domArray);
  16045. return dom_core_1["default"]($dom.parentNode);
  16046. }
  16047. /**
  16048. * 封装移除、新增节点事件
  16049. * @param $dom tbody节点
  16050. * @param domArray 所有的行
  16051. */
  16052. function removeAndInsertAction($dom, domArray) {
  16053. //移除所有的旧的子节点
  16054. while ($dom.children.length !== 0) {
  16055. $dom.removeChild($dom.children[0]);
  16056. } //插入新的子节点
  16057. for (var i = 0; i < domArray.length; i++) {
  16058. $dom.appendChild(domArray[i]);
  16059. }
  16060. }
  16061. /**
  16062. * 封装判断是否tbody节点
  16063. * 粘贴的table 第一个节点是<colgroup> 最后的节点<tbody>
  16064. * @param dom
  16065. */
  16066. function generateDomAction($node) {
  16067. var $dom = $node.elems[0].children[0];
  16068. if ($dom.nodeName === 'COLGROUP') {
  16069. $dom = $node.elems[0].children[$node.elems[0].children.length - 1];
  16070. }
  16071. return $dom;
  16072. }
  16073. exports["default"] = {
  16074. ProcessingRow: ProcessingRow,
  16075. ProcessingCol: ProcessingCol,
  16076. DeleteRow: DeleteRow,
  16077. DeleteCol: DeleteCol,
  16078. setTheHeader: setTheHeader
  16079. };
  16080. /***/ }),
  16081. /* 410 */
  16082. /***/ (function(module, exports, __webpack_require__) {
  16083. var parent = __webpack_require__(411);
  16084. module.exports = parent;
  16085. /***/ }),
  16086. /* 411 */
  16087. /***/ (function(module, exports, __webpack_require__) {
  16088. __webpack_require__(58);
  16089. __webpack_require__(412);
  16090. var path = __webpack_require__(11);
  16091. module.exports = path.Array.from;
  16092. /***/ }),
  16093. /* 412 */
  16094. /***/ (function(module, exports, __webpack_require__) {
  16095. var $ = __webpack_require__(5);
  16096. var from = __webpack_require__(413);
  16097. var checkCorrectnessOfIteration = __webpack_require__(120);
  16098. var INCORRECT_ITERATION = !checkCorrectnessOfIteration(function (iterable) {
  16099. // eslint-disable-next-line es/no-array-from -- required for testing
  16100. Array.from(iterable);
  16101. });
  16102. // `Array.from` method
  16103. // https://tc39.es/ecma262/#sec-array.from
  16104. $({ target: 'Array', stat: true, forced: INCORRECT_ITERATION }, {
  16105. from: from
  16106. });
  16107. /***/ }),
  16108. /* 413 */
  16109. /***/ (function(module, exports, __webpack_require__) {
  16110. "use strict";
  16111. var bind = __webpack_require__(40);
  16112. var toObject = __webpack_require__(26);
  16113. var callWithSafeIterationClosing = __webpack_require__(414);
  16114. var isArrayIteratorMethod = __webpack_require__(112);
  16115. var toLength = __webpack_require__(35);
  16116. var createProperty = __webpack_require__(75);
  16117. var getIteratorMethod = __webpack_require__(113);
  16118. // `Array.from` method implementation
  16119. // https://tc39.es/ecma262/#sec-array.from
  16120. module.exports = function from(arrayLike /* , mapfn = undefined, thisArg = undefined */) {
  16121. var O = toObject(arrayLike);
  16122. var C = typeof this == 'function' ? this : Array;
  16123. var argumentsLength = arguments.length;
  16124. var mapfn = argumentsLength > 1 ? arguments[1] : undefined;
  16125. var mapping = mapfn !== undefined;
  16126. var iteratorMethod = getIteratorMethod(O);
  16127. var index = 0;
  16128. var length, result, step, iterator, next, value;
  16129. if (mapping) mapfn = bind(mapfn, argumentsLength > 2 ? arguments[2] : undefined, 2);
  16130. // if the target is not iterable or it's an array with the default iterator - use a simple case
  16131. if (iteratorMethod != undefined && !(C == Array && isArrayIteratorMethod(iteratorMethod))) {
  16132. iterator = iteratorMethod.call(O);
  16133. next = iterator.next;
  16134. result = new C();
  16135. for (;!(step = next.call(iterator)).done; index++) {
  16136. value = mapping ? callWithSafeIterationClosing(iterator, mapfn, [step.value, index], true) : step.value;
  16137. createProperty(result, index, value);
  16138. }
  16139. } else {
  16140. length = toLength(O.length);
  16141. result = new C(length);
  16142. for (;length > index; index++) {
  16143. value = mapping ? mapfn(O[index], index) : O[index];
  16144. createProperty(result, index, value);
  16145. }
  16146. }
  16147. result.length = index;
  16148. return result;
  16149. };
  16150. /***/ }),
  16151. /* 414 */
  16152. /***/ (function(module, exports, __webpack_require__) {
  16153. var anObject = __webpack_require__(20);
  16154. var iteratorClose = __webpack_require__(114);
  16155. // call something on iterator step with safe closing on error
  16156. module.exports = function (iterator, fn, value, ENTRIES) {
  16157. try {
  16158. return ENTRIES ? fn(anObject(value)[0], value[1]) : fn(value);
  16159. } catch (error) {
  16160. iteratorClose(iterator);
  16161. throw error;
  16162. }
  16163. };
  16164. /***/ }),
  16165. /* 415 */
  16166. /***/ (function(module, exports, __webpack_require__) {
  16167. "use strict";
  16168. /**
  16169. * @description 获取dom节点
  16170. * @author lichunlin
  16171. */
  16172. var _interopRequireDefault = __webpack_require__(0);
  16173. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16174. var _forEach = _interopRequireDefault(__webpack_require__(4));
  16175. var _from = _interopRequireDefault(__webpack_require__(143));
  16176. (0, _defineProperty["default"])(exports, "__esModule", {
  16177. value: true
  16178. });
  16179. var tslib_1 = __webpack_require__(2);
  16180. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16181. var getNode = function () {
  16182. function getNode(editor) {
  16183. this.editor = editor;
  16184. }
  16185. /**
  16186. * 获取焦点所在行
  16187. * @param $node 当前table
  16188. */
  16189. getNode.prototype.getRowNode = function ($node) {
  16190. var _a;
  16191. var DOM = dom_core_1["default"]($node).elems[0];
  16192. if (!DOM.parentNode) {
  16193. return DOM;
  16194. }
  16195. DOM = (_a = dom_core_1["default"](DOM).parentUntil('TR', DOM)) === null || _a === void 0 ? void 0 : _a.elems[0];
  16196. return DOM;
  16197. };
  16198. /**
  16199. * 获取当前行的下标
  16200. * @param $node 当前table
  16201. * @param $dmo 当前行节点
  16202. */
  16203. getNode.prototype.getCurrentRowIndex = function ($node, $dom) {
  16204. var _context;
  16205. var _index = 0;
  16206. var $nodeChild = $node.children[0]; //粘贴的table 最后一个节点才是tbody
  16207. if ($nodeChild.nodeName === 'COLGROUP') {
  16208. $nodeChild = $node.children[$node.children.length - 1];
  16209. }
  16210. (0, _forEach["default"])(_context = (0, _from["default"])($nodeChild.children)).call(_context, function (item, index) {
  16211. item === $dom ? _index = index : '';
  16212. });
  16213. return _index;
  16214. };
  16215. /**
  16216. * 获取当前列的下标
  16217. * @param $node 当前点击元素
  16218. */
  16219. getNode.prototype.getCurrentColIndex = function ($node) {
  16220. var _context2;
  16221. var _a; //当前行
  16222. var _index = 0; //获取当前列 td或th
  16223. var rowDom = dom_core_1["default"]($node).getNodeName() === 'TD' || dom_core_1["default"]($node).getNodeName() === 'TH' ? $node : (_a = dom_core_1["default"]($node).parentUntil('TD', $node)) === null || _a === void 0 ? void 0 : _a.elems[0];
  16224. var colDom = dom_core_1["default"](rowDom).parent();
  16225. (0, _forEach["default"])(_context2 = (0, _from["default"])(colDom.elems[0].children)).call(_context2, function (item, index) {
  16226. item === rowDom ? _index = index : '';
  16227. });
  16228. return _index;
  16229. };
  16230. /**
  16231. * 返回元素html字符串
  16232. * @param $node
  16233. */
  16234. getNode.prototype.getTableHtml = function ($node) {
  16235. var htmlStr = "<table border=\"0\" width=\"100%\" cellpadding=\"0\" cellspacing=\"0\">" + dom_core_1["default"]($node).html() + "</table>";
  16236. return htmlStr;
  16237. };
  16238. return getNode;
  16239. }();
  16240. exports["default"] = getNode;
  16241. /***/ }),
  16242. /* 416 */
  16243. /***/ (function(module, exports, __webpack_require__) {
  16244. "use strict";
  16245. var _interopRequireDefault = __webpack_require__(0);
  16246. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16247. (0, _defineProperty["default"])(exports, "__esModule", {
  16248. value: true
  16249. });
  16250. exports.bindEventKeyboardEvent = exports.bindClickEvent = void 0;
  16251. var tslib_1 = __webpack_require__(2);
  16252. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16253. /**
  16254. * @description 是否是空行
  16255. * @param topElem
  16256. */
  16257. function isEmptyLine(topElem) {
  16258. if (!topElem.length) {
  16259. return false;
  16260. }
  16261. var dom = topElem.elems[0];
  16262. return dom.nodeName === 'P' && dom.innerHTML === '<br>';
  16263. }
  16264. function bindClickEvent(editor) {
  16265. function handleTripleClick($dom, e) {
  16266. // 处理三击事件,此时选区可能离开table,修正回来
  16267. if (e.detail >= 3) {
  16268. var selection = window.getSelection();
  16269. if (selection) {
  16270. var focusNode = selection.focusNode,
  16271. anchorNode = selection.anchorNode;
  16272. var $anchorNode = dom_core_1["default"](anchorNode === null || anchorNode === void 0 ? void 0 : anchorNode.parentElement); // 当focusNode离开了table
  16273. if (!$dom.isContain(dom_core_1["default"](focusNode))) {
  16274. var $td = $anchorNode.elems[0].tagName === 'TD' ? $anchorNode : $anchorNode.parentUntilEditor('td', editor);
  16275. if ($td) {
  16276. var range = editor.selection.getRange();
  16277. range === null || range === void 0 ? void 0 : range.setEnd($td.elems[0], $td.elems[0].childNodes.length);
  16278. editor.selection.restoreSelection();
  16279. }
  16280. }
  16281. }
  16282. }
  16283. }
  16284. editor.txt.eventHooks.tableClickEvents.push(handleTripleClick);
  16285. }
  16286. exports.bindClickEvent = bindClickEvent;
  16287. function bindEventKeyboardEvent(editor) {
  16288. var txt = editor.txt,
  16289. selection = editor.selection;
  16290. var keydownEvents = txt.eventHooks.keydownEvents;
  16291. keydownEvents.push(function (e) {
  16292. // 实时保存选区
  16293. editor.selection.saveRange();
  16294. var $selectionContainerElem = selection.getSelectionContainerElem();
  16295. if ($selectionContainerElem) {
  16296. var $topElem = $selectionContainerElem.getNodeTop(editor);
  16297. var $preElem = $topElem.length ? $topElem.prev().length ? $topElem.prev() : null : null; // 删除时,选区前面是table,且选区没有选中文本,阻止默认行为
  16298. if ($preElem && $preElem.getNodeName() === 'TABLE' && selection.isSelectionEmpty() && selection.getCursorPos() === 0 && e.keyCode === 8) {
  16299. var $nextElem = $topElem.next();
  16300. var hasNext = !!$nextElem.length;
  16301. /**
  16302. * 如果当前是空行,并且当前行下面还有内容,删除当前行
  16303. * 浏览器默认行为不会删除掉当前行的<br>标签
  16304. * 因此阻止默认行为,特殊处理
  16305. */
  16306. if (hasNext && isEmptyLine($topElem)) {
  16307. $topElem.remove();
  16308. editor.selection.setRangeToElem($nextElem.elems[0]);
  16309. }
  16310. e.preventDefault();
  16311. }
  16312. }
  16313. });
  16314. }
  16315. exports.bindEventKeyboardEvent = bindEventKeyboardEvent;
  16316. /***/ }),
  16317. /* 417 */
  16318. /***/ (function(module, exports, __webpack_require__) {
  16319. "use strict";
  16320. /**
  16321. * @description 代码 菜单
  16322. * @author lkw
  16323. */
  16324. var _interopRequireDefault = __webpack_require__(0);
  16325. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16326. var _map = _interopRequireDefault(__webpack_require__(27));
  16327. (0, _defineProperty["default"])(exports, "__esModule", {
  16328. value: true
  16329. });
  16330. exports.formatCodeHtml = void 0;
  16331. var tslib_1 = __webpack_require__(2);
  16332. var PanelMenu_1 = tslib_1.__importDefault(__webpack_require__(36));
  16333. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16334. var util_1 = __webpack_require__(6);
  16335. var create_panel_conf_1 = tslib_1.__importDefault(__webpack_require__(418));
  16336. var is_active_1 = tslib_1.__importDefault(__webpack_require__(144));
  16337. var Panel_1 = tslib_1.__importDefault(__webpack_require__(33));
  16338. var index_1 = tslib_1.__importDefault(__webpack_require__(419));
  16339. function formatCodeHtml(editor, html) {
  16340. if (!html) return html;
  16341. html = deleteHighlightCode(html);
  16342. html = formatEnterCode(html);
  16343. html = util_1.replaceSpecialSymbol(html);
  16344. return html; // 格式化换换所产生的code标签
  16345. function formatEnterCode(html) {
  16346. var preArr = html.match(/<pre[\s|\S]+?\/pre>/g);
  16347. if (preArr === null) return html;
  16348. (0, _map["default"])(preArr).call(preArr, function (item) {
  16349. //将连续的code标签换为\n换行
  16350. html = html.replace(item, item.replace(/<\/code><code>/g, '\n').replace(/<br>/g, ''));
  16351. });
  16352. return html;
  16353. } // highlight格式化方法
  16354. function deleteHighlightCode(html) {
  16355. var _context;
  16356. // 获取所有hljs文本
  16357. var m = html.match(/<span\sclass="hljs[\s|\S]+?\/span>/gm); // 没有代码渲染文本则退出
  16358. // @ts-ignore
  16359. if (!m || !m.length) return html; // 获取替换文本
  16360. var r = (0, _map["default"])(_context = util_1.deepClone(m)).call(_context, function (i) {
  16361. i = i.replace(/<span\sclass="hljs[^>]+>/, '');
  16362. return i.replace(/<\/span>/, '');
  16363. }); // @ts-ignore
  16364. for (var i = 0; i < m.length; i++) {
  16365. html = html.replace(m[i], r[i]);
  16366. }
  16367. return deleteHighlightCode(html);
  16368. }
  16369. }
  16370. exports.formatCodeHtml = formatCodeHtml;
  16371. var Code = function (_super) {
  16372. tslib_1.__extends(Code, _super);
  16373. function Code(editor) {
  16374. var _this = this;
  16375. var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="代码"><i class="w-e-icon-terminal"></i></div>');
  16376. _this = _super.call(this, $elem, editor) || this; // 绑定事件,如点击链接时,可以查看链接
  16377. index_1["default"](editor);
  16378. return _this;
  16379. }
  16380. /**
  16381. * 插入行内代码
  16382. * @param text
  16383. * @return null
  16384. */
  16385. Code.prototype.insertLineCode = function (text) {
  16386. var editor = this.editor; // 行内代码处理
  16387. var $code = dom_core_1["default"]("<code>" + text + "</code>");
  16388. editor.cmd["do"]('insertElem', $code);
  16389. editor.selection.createRangeByElem($code, false);
  16390. editor.selection.restoreSelection();
  16391. };
  16392. /**
  16393. * 菜单点击事件
  16394. */
  16395. Code.prototype.clickHandler = function () {
  16396. var editor = this.editor;
  16397. var selectionText = editor.selection.getSelectionText();
  16398. if (this.isActive) {
  16399. return;
  16400. } else {
  16401. // 菜单未被激活,说明选区不在链接里
  16402. if (editor.selection.isSelectionEmpty()) {
  16403. // 选区是空的,未选中内容
  16404. this.createPanel('', '');
  16405. } else {
  16406. // 行内代码处理 选中了非代码内容
  16407. this.insertLineCode(selectionText);
  16408. }
  16409. }
  16410. };
  16411. /**
  16412. * 创建 panel
  16413. * @param text 代码文本
  16414. * @param languageType 代码类型
  16415. */
  16416. Code.prototype.createPanel = function (text, languageType) {
  16417. var conf = create_panel_conf_1["default"](this.editor, text, languageType);
  16418. var panel = new Panel_1["default"](this, conf);
  16419. panel.create();
  16420. };
  16421. /**
  16422. * 尝试修改菜单 active 状态
  16423. */
  16424. Code.prototype.tryChangeActive = function () {
  16425. var editor = this.editor;
  16426. if (is_active_1["default"](editor)) {
  16427. this.active();
  16428. } else {
  16429. this.unActive();
  16430. }
  16431. };
  16432. return Code;
  16433. }(PanelMenu_1["default"]);
  16434. exports["default"] = Code;
  16435. /***/ }),
  16436. /* 418 */
  16437. /***/ (function(module, exports, __webpack_require__) {
  16438. "use strict";
  16439. /**
  16440. * @description code 菜单 panel tab 配置
  16441. * @author lkw
  16442. */
  16443. var _interopRequireDefault = __webpack_require__(0);
  16444. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16445. var _map = _interopRequireDefault(__webpack_require__(27));
  16446. (0, _defineProperty["default"])(exports, "__esModule", {
  16447. value: true
  16448. });
  16449. var tslib_1 = __webpack_require__(2);
  16450. var util_1 = __webpack_require__(6);
  16451. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16452. var is_active_1 = tslib_1.__importDefault(__webpack_require__(144));
  16453. var const_1 = __webpack_require__(7);
  16454. function default_1(editor, text, languageType) {
  16455. var _context;
  16456. // panel 中需要用到的id
  16457. var inputIFrameId = util_1.getRandom('input-iframe');
  16458. var languageId = util_1.getRandom('select');
  16459. var btnOkId = util_1.getRandom('btn-ok');
  16460. /**
  16461. * 插入代码块
  16462. * @param text 文字
  16463. */
  16464. function insertCode(text) {
  16465. var _a; // 选区处于链接中,则选中整个菜单,再执行 insertHTML
  16466. var active = is_active_1["default"](editor);
  16467. if (active) {
  16468. selectCodeElem();
  16469. }
  16470. var content = (_a = editor.selection.getSelectionStartElem()) === null || _a === void 0 ? void 0 : _a.elems[0].innerHTML;
  16471. if (content) {
  16472. editor.cmd["do"]('insertHTML', const_1.EMPTY_P);
  16473. }
  16474. editor.cmd["do"]('insertHTML', text);
  16475. var $code = editor.selection.getSelectionStartElem();
  16476. var $codeElem = $code === null || $code === void 0 ? void 0 : $code.getNodeTop(editor); // 通过dom操作添加换行标签
  16477. if (($codeElem === null || $codeElem === void 0 ? void 0 : $codeElem.getNextSibling().elems.length) === 0) {
  16478. // @ts-ignore
  16479. dom_core_1["default"](const_1.EMPTY_P).insertAfter($codeElem);
  16480. }
  16481. }
  16482. /**
  16483. * 选中整个链接元素
  16484. */
  16485. function selectCodeElem() {
  16486. if (!is_active_1["default"](editor)) return; // eslint-disable-next-line @typescript-eslint/no-unused-vars
  16487. var $selectedCode;
  16488. var $code = editor.selection.getSelectionStartElem();
  16489. var $codeElem = $code === null || $code === void 0 ? void 0 : $code.getNodeTop(editor);
  16490. if (!$codeElem) return;
  16491. editor.selection.createRangeByElem($codeElem);
  16492. editor.selection.restoreSelection();
  16493. $selectedCode = $codeElem; // 赋值给函数内全局变量
  16494. }
  16495. var t = function t(text) {
  16496. return editor.i18next.t(text);
  16497. }; // @ts-ignore
  16498. var conf = {
  16499. width: 500,
  16500. height: 0,
  16501. // panel 中可包含多个 tab
  16502. tabs: [{
  16503. // tab 的标题
  16504. title: t('menus.panelMenus.code.插入代码'),
  16505. // 模板
  16506. tpl: "<div>\n <select name=\"\" id=\"" + languageId + "\">\n " + (0, _map["default"])(_context = editor.config.languageType).call(_context, function (language) {
  16507. return '<option ' + (languageType == language ? 'selected' : '') + ' value ="' + language + '">' + language + '</option>';
  16508. }) + "\n </select>\n <textarea id=\"" + inputIFrameId + "\" type=\"text\" class=\"wang-code-textarea\" placeholder=\"\" style=\"height: 160px\">" + text.replace(/&quot;/g, '"') + "</textarea>\n <div class=\"w-e-button-container\">\n <button type=\"button\" id=\"" + btnOkId + "\" class=\"right\">" + (is_active_1["default"](editor) ? t('修改') : t('插入')) + "</button>\n </div>\n </div>",
  16509. // 事件绑定
  16510. events: [// 插入链接
  16511. {
  16512. selector: '#' + btnOkId,
  16513. type: 'click',
  16514. fn: function fn() {
  16515. var formatCode, codeDom;
  16516. var $code = document.getElementById(inputIFrameId);
  16517. var $select = dom_core_1["default"]('#' + languageId);
  16518. var languageType = $select.val(); // @ts-ignore
  16519. var code = $code.value; // 高亮渲染
  16520. if (editor.highlight) {
  16521. formatCode = editor.highlight.highlightAuto(code).value;
  16522. } else {
  16523. formatCode = "<xmp>" + code + "</xmp>";
  16524. } // 代码为空,则不插入
  16525. if (!code) return; //增加标签
  16526. if (is_active_1["default"](editor)) {
  16527. return false;
  16528. } else {
  16529. //增加pre标签
  16530. codeDom = "<pre><code class=\"" + languageType + "\">" + formatCode + "</code></pre>"; // @ts-ignore
  16531. insertCode(codeDom);
  16532. } // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
  16533. return true;
  16534. }
  16535. }]
  16536. } // tab end
  16537. ] // tabs end
  16538. };
  16539. return conf;
  16540. }
  16541. exports["default"] = default_1;
  16542. /***/ }),
  16543. /* 419 */
  16544. /***/ (function(module, exports, __webpack_require__) {
  16545. "use strict";
  16546. /**
  16547. * @description 绑定链接元素的事件,入口
  16548. * @author lkw
  16549. */
  16550. var _interopRequireDefault = __webpack_require__(0);
  16551. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16552. (0, _defineProperty["default"])(exports, "__esModule", {
  16553. value: true
  16554. });
  16555. var tslib_1 = __webpack_require__(2);
  16556. var tooltip_event_1 = tslib_1.__importDefault(__webpack_require__(420));
  16557. var jump_code_block_down_1 = tslib_1.__importDefault(__webpack_require__(421));
  16558. /**
  16559. * 绑定事件
  16560. * @param editor 编辑器实例
  16561. */
  16562. function bindEvent(editor) {
  16563. // tooltip 事件
  16564. tooltip_event_1["default"](editor); // 代码块为最后内容的跳出处理
  16565. jump_code_block_down_1["default"](editor);
  16566. }
  16567. exports["default"] = bindEvent;
  16568. /***/ }),
  16569. /* 420 */
  16570. /***/ (function(module, exports, __webpack_require__) {
  16571. "use strict";
  16572. /**
  16573. * @description tooltip 事件
  16574. * @author lkw
  16575. */
  16576. var _interopRequireDefault = __webpack_require__(0);
  16577. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16578. (0, _defineProperty["default"])(exports, "__esModule", {
  16579. value: true
  16580. });
  16581. exports.createShowHideFn = void 0;
  16582. var tslib_1 = __webpack_require__(2);
  16583. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16584. var Tooltip_1 = tslib_1.__importDefault(__webpack_require__(37));
  16585. /**
  16586. * 生成 Tooltip 的显示隐藏函数
  16587. */
  16588. function createShowHideFn(editor) {
  16589. var tooltip;
  16590. /**
  16591. * 显示 tooltip
  16592. * @param $code 链接元素
  16593. */
  16594. function showCodeTooltip($code) {
  16595. var i18nPrefix = 'menus.panelMenus.code.';
  16596. var t = function t(text, prefix) {
  16597. if (prefix === void 0) {
  16598. prefix = i18nPrefix;
  16599. }
  16600. return editor.i18next.t(prefix + text);
  16601. };
  16602. var conf = [{
  16603. $elem: dom_core_1["default"]("<span>" + t('删除代码') + "</span>"),
  16604. onClick: function onClick(editor, $code) {
  16605. //dom操作删除
  16606. $code.remove(); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  16607. return true;
  16608. }
  16609. }]; // 创建 tooltip
  16610. tooltip = new Tooltip_1["default"](editor, $code, conf);
  16611. tooltip.create();
  16612. }
  16613. /**
  16614. * 隐藏 tooltip
  16615. */
  16616. function hideCodeTooltip() {
  16617. // 移除 tooltip
  16618. if (tooltip) {
  16619. tooltip.remove();
  16620. tooltip = null;
  16621. }
  16622. }
  16623. return {
  16624. showCodeTooltip: showCodeTooltip,
  16625. hideCodeTooltip: hideCodeTooltip
  16626. };
  16627. }
  16628. exports.createShowHideFn = createShowHideFn;
  16629. /**
  16630. * preEnterListener是为了统一浏览器 在pre标签内的enter行为而进行的监听
  16631. * 目前并没有使用, 但是在未来处理与Firefox和ie的兼容性时需要用到 暂且放置
  16632. * pre标签内的回车监听
  16633. * @param e
  16634. * @param editor
  16635. */
  16636. /* istanbul ignore next */
  16637. // eslint-disable-next-line @typescript-eslint/no-unused-vars
  16638. function preEnterListener(e, editor) {
  16639. // 获取当前标签元素
  16640. var $selectionElem = editor.selection.getSelectionContainerElem(); // 获取当前节点最顶级标签元素
  16641. var $topElem = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getNodeTop(editor); // 获取顶级节点节点名
  16642. var topNodeName = $topElem === null || $topElem === void 0 ? void 0 : $topElem.getNodeName(); // 非pre标签退出
  16643. if (topNodeName !== 'PRE') return; // 取消默认行为
  16644. e.preventDefault(); // 执行换行
  16645. editor.cmd["do"]('insertHTML', '\n\r');
  16646. }
  16647. /**
  16648. * 绑定 tooltip 事件
  16649. * @param editor 编辑器实例
  16650. */
  16651. function bindTooltipEvent(editor) {
  16652. var _a = createShowHideFn(editor),
  16653. showCodeTooltip = _a.showCodeTooltip,
  16654. hideCodeTooltip = _a.hideCodeTooltip; // 点击代码元素时,显示 tooltip
  16655. editor.txt.eventHooks.codeClickEvents.push(showCodeTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
  16656. editor.txt.eventHooks.clickEvents.push(hideCodeTooltip);
  16657. editor.txt.eventHooks.toolbarClickEvents.push(hideCodeTooltip);
  16658. editor.txt.eventHooks.menuClickEvents.push(hideCodeTooltip);
  16659. editor.txt.eventHooks.textScrollEvents.push(hideCodeTooltip);
  16660. }
  16661. exports["default"] = bindTooltipEvent;
  16662. /***/ }),
  16663. /* 421 */
  16664. /***/ (function(module, exports, __webpack_require__) {
  16665. "use strict";
  16666. var _interopRequireDefault = __webpack_require__(0);
  16667. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16668. (0, _defineProperty["default"])(exports, "__esModule", {
  16669. value: true
  16670. });
  16671. var tslib_1 = __webpack_require__(2);
  16672. /**
  16673. * @description 代码块为最后一块内容时往下跳出代码块
  16674. * @author zhengwenjian
  16675. */
  16676. var const_1 = __webpack_require__(7);
  16677. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16678. /**
  16679. * 在代码块最后一行 按方向下键跳出代码块的处理
  16680. * @param editor 编辑器实例
  16681. */
  16682. function bindEventJumpCodeBlock(editor) {
  16683. var $textElem = editor.$textElem,
  16684. selection = editor.selection,
  16685. txt = editor.txt;
  16686. var keydownEvents = txt.eventHooks.keydownEvents;
  16687. keydownEvents.push(function (e) {
  16688. var _a; // 40 是键盘中的下方向键
  16689. if (e.keyCode !== 40) return;
  16690. var node = selection.getSelectionContainerElem();
  16691. var $lastNode = (_a = $textElem.children()) === null || _a === void 0 ? void 0 : _a.last();
  16692. if ((node === null || node === void 0 ? void 0 : node.elems[0].tagName) === 'XMP' && ($lastNode === null || $lastNode === void 0 ? void 0 : $lastNode.elems[0].tagName) === 'PRE') {
  16693. // 就是最后一块是代码块的情况插入空p标签并光标移至p
  16694. var $emptyP = dom_core_1["default"](const_1.EMPTY_P);
  16695. $textElem.append($emptyP);
  16696. }
  16697. }); // fix: 修复代码块作为最后一个元素时,用户无法再进行输入的问题
  16698. keydownEvents.push(function (e) {
  16699. // 实时保存选区
  16700. editor.selection.saveRange();
  16701. var $selectionContainerElem = selection.getSelectionContainerElem();
  16702. if ($selectionContainerElem) {
  16703. var $topElem = $selectionContainerElem.getNodeTop(editor); // 获取选区所在节点的上一元素
  16704. var $preElem = $topElem === null || $topElem === void 0 ? void 0 : $topElem.prev(); // 判断该元素后面是否还存在元素
  16705. // 如果存在则允许删除
  16706. var $nextElem = $topElem === null || $topElem === void 0 ? void 0 : $topElem.getNextSibling();
  16707. if ($preElem.length && ($preElem === null || $preElem === void 0 ? void 0 : $preElem.getNodeName()) === 'PRE' && $nextElem.length === 0) {
  16708. // 光标处于选区开头
  16709. if (selection.getCursorPos() === 0) {
  16710. // 按下delete键时末尾追加空行
  16711. if (e.keyCode === 8) {
  16712. var $emptyP = dom_core_1["default"](const_1.EMPTY_P);
  16713. $textElem.append($emptyP);
  16714. }
  16715. }
  16716. }
  16717. }
  16718. });
  16719. }
  16720. exports["default"] = bindEventJumpCodeBlock;
  16721. /***/ }),
  16722. /* 422 */
  16723. /***/ (function(module, exports, __webpack_require__) {
  16724. "use strict";
  16725. var _interopRequireDefault = __webpack_require__(0);
  16726. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16727. (0, _defineProperty["default"])(exports, "__esModule", {
  16728. value: true
  16729. });
  16730. var tslib_1 = __webpack_require__(2);
  16731. /**
  16732. * @description 分割线
  16733. * @author wangqiaoling
  16734. */
  16735. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  16736. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16737. var index_1 = tslib_1.__importDefault(__webpack_require__(423));
  16738. var util_1 = __webpack_require__(6);
  16739. var const_1 = __webpack_require__(7);
  16740. var splitLine = function (_super) {
  16741. tslib_1.__extends(splitLine, _super);
  16742. function splitLine(editor) {
  16743. var _this = this;
  16744. var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="分割线"><i class="w-e-icon-split-line"></i></div>');
  16745. _this = _super.call(this, $elem, editor) || this; // 绑定事件
  16746. index_1["default"](editor);
  16747. return _this;
  16748. }
  16749. /**
  16750. * 菜单点击事件
  16751. */
  16752. splitLine.prototype.clickHandler = function () {
  16753. var editor = this.editor;
  16754. var range = editor.selection.getRange();
  16755. var $selectionElem = editor.selection.getSelectionContainerElem();
  16756. if (!($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.length)) return;
  16757. var $DomElement = dom_core_1["default"]($selectionElem.elems[0]);
  16758. var $tableDOM = $DomElement.parentUntil('TABLE', $selectionElem.elems[0]);
  16759. var $imgDOM = $DomElement.children(); // 禁止在代码块中添加分割线
  16760. if ($DomElement.getNodeName() === 'CODE') return; // 禁止在表格中添加分割线
  16761. if ($tableDOM && dom_core_1["default"]($tableDOM.elems[0]).getNodeName() === 'TABLE') return; // 禁止在图片处添加分割线
  16762. if ($imgDOM && $imgDOM.length !== 0 && dom_core_1["default"]($imgDOM.elems[0]).getNodeName() === 'IMG' && !(range === null || range === void 0 ? void 0 : range.collapsed) // 处理光标在 img 后面的情况
  16763. ) {
  16764. return;
  16765. }
  16766. this.createSplitLine();
  16767. };
  16768. /**
  16769. * 创建 splitLine
  16770. */
  16771. splitLine.prototype.createSplitLine = function () {
  16772. // 防止插入分割线时没有占位元素的尴尬
  16773. var splitLineDOM = "<hr/>" + const_1.EMPTY_P; // 火狐浏览器不需要br标签占位
  16774. if (util_1.UA.isFirefox) {
  16775. splitLineDOM = '<hr/><p></p>';
  16776. }
  16777. this.editor.cmd["do"]('insertHTML', splitLineDOM);
  16778. };
  16779. /**
  16780. * 尝试修改菜单激活状态
  16781. */
  16782. splitLine.prototype.tryChangeActive = function () {};
  16783. return splitLine;
  16784. }(BtnMenu_1["default"]);
  16785. exports["default"] = splitLine;
  16786. /***/ }),
  16787. /* 423 */
  16788. /***/ (function(module, exports, __webpack_require__) {
  16789. "use strict";
  16790. var _interopRequireDefault = __webpack_require__(0);
  16791. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16792. (0, _defineProperty["default"])(exports, "__esModule", {
  16793. value: true
  16794. });
  16795. var tslib_1 = __webpack_require__(2);
  16796. var tooltip_event_1 = tslib_1.__importDefault(__webpack_require__(424));
  16797. /**
  16798. * 绑定事件
  16799. * @param editor 编辑器实例
  16800. */
  16801. function bindEvent(editor) {
  16802. // 分割线的 tooltip 事件
  16803. tooltip_event_1["default"](editor);
  16804. }
  16805. exports["default"] = bindEvent;
  16806. /***/ }),
  16807. /* 424 */
  16808. /***/ (function(module, exports, __webpack_require__) {
  16809. "use strict";
  16810. var _interopRequireDefault = __webpack_require__(0);
  16811. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16812. (0, _defineProperty["default"])(exports, "__esModule", {
  16813. value: true
  16814. });
  16815. var tslib_1 = __webpack_require__(2);
  16816. /**
  16817. * @description tooltip 事件
  16818. * @author wangqiaoling
  16819. */
  16820. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16821. var Tooltip_1 = tslib_1.__importDefault(__webpack_require__(37));
  16822. /**
  16823. * 生成 Tooltip 的显示隐藏函数
  16824. */
  16825. function createShowHideFn(editor) {
  16826. var tooltip;
  16827. /**
  16828. * 显示分割线的 tooltip
  16829. * @param $splitLine 分割线元素
  16830. */
  16831. function showSplitLineTooltip($splitLine) {
  16832. // 定义 splitLine tooltip 配置
  16833. var conf = [{
  16834. $elem: dom_core_1["default"]("<span>" + editor.i18next.t('menus.panelMenus.删除') + "</span>"),
  16835. onClick: function onClick(editor, $splitLine) {
  16836. // 选中 分割线 元素
  16837. editor.selection.createRangeByElem($splitLine);
  16838. editor.selection.restoreSelection();
  16839. editor.cmd["do"]('delete'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
  16840. return true;
  16841. }
  16842. }]; // 实例化 tooltip
  16843. tooltip = new Tooltip_1["default"](editor, $splitLine, conf); // 创建 tooltip
  16844. tooltip.create();
  16845. }
  16846. /**
  16847. * 隐藏分割线的 tooltip
  16848. */
  16849. function hideSplitLineTooltip() {
  16850. if (tooltip) {
  16851. tooltip.remove();
  16852. tooltip = null;
  16853. }
  16854. }
  16855. return {
  16856. showSplitLineTooltip: showSplitLineTooltip,
  16857. hideSplitLineTooltip: hideSplitLineTooltip
  16858. };
  16859. }
  16860. function bindTooltipEvent(editor) {
  16861. var _a = createShowHideFn(editor),
  16862. showSplitLineTooltip = _a.showSplitLineTooltip,
  16863. hideSplitLineTooltip = _a.hideSplitLineTooltip; // 点击分割线时,显示 tooltip
  16864. editor.txt.eventHooks.splitLineEvents.push(showSplitLineTooltip); // 点击其他地方(工具栏、滚动、keyup)时,隐藏 tooltip
  16865. editor.txt.eventHooks.clickEvents.push(hideSplitLineTooltip);
  16866. editor.txt.eventHooks.keyupEvents.push(hideSplitLineTooltip);
  16867. editor.txt.eventHooks.toolbarClickEvents.push(hideSplitLineTooltip);
  16868. editor.txt.eventHooks.menuClickEvents.push(hideSplitLineTooltip);
  16869. editor.txt.eventHooks.textScrollEvents.push(hideSplitLineTooltip);
  16870. }
  16871. exports["default"] = bindTooltipEvent;
  16872. /***/ }),
  16873. /* 425 */
  16874. /***/ (function(module, exports, __webpack_require__) {
  16875. "use strict";
  16876. var _interopRequireDefault = __webpack_require__(0);
  16877. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  16878. var _forEach = _interopRequireDefault(__webpack_require__(4));
  16879. (0, _defineProperty["default"])(exports, "__esModule", {
  16880. value: true
  16881. });
  16882. var tslib_1 = __webpack_require__(2);
  16883. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  16884. var BtnMenu_1 = tslib_1.__importDefault(__webpack_require__(23));
  16885. var util_1 = __webpack_require__(105);
  16886. var bind_event_1 = tslib_1.__importDefault(__webpack_require__(431));
  16887. var todo_1 = tslib_1.__importDefault(__webpack_require__(145));
  16888. var Todo = function (_super) {
  16889. tslib_1.__extends(Todo, _super);
  16890. function Todo(editor) {
  16891. var _this = this;
  16892. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5F85\u529E\u4E8B\u9879\">\n <i class=\"w-e-icon-checkbox-checked\"></i>\n </div>");
  16893. _this = _super.call(this, $elem, editor) || this;
  16894. bind_event_1["default"](editor);
  16895. return _this;
  16896. }
  16897. /**
  16898. * 点击事件
  16899. */
  16900. Todo.prototype.clickHandler = function () {
  16901. var editor = this.editor;
  16902. if (!util_1.isAllTodo(editor)) {
  16903. // 设置todolist
  16904. this.setTodo();
  16905. } else {
  16906. // 取消设置todolist
  16907. this.cancelTodo();
  16908. this.tryChangeActive();
  16909. }
  16910. };
  16911. Todo.prototype.tryChangeActive = function () {
  16912. if (util_1.isAllTodo(this.editor)) {
  16913. this.active();
  16914. } else {
  16915. this.unActive();
  16916. }
  16917. };
  16918. /**
  16919. * 设置todo
  16920. */
  16921. Todo.prototype.setTodo = function () {
  16922. var editor = this.editor;
  16923. var topNodeElem = editor.selection.getSelectionRangeTopNodes();
  16924. (0, _forEach["default"])(topNodeElem).call(topNodeElem, function ($node) {
  16925. var _a;
  16926. var nodeName = $node === null || $node === void 0 ? void 0 : $node.getNodeName();
  16927. if (nodeName === 'P') {
  16928. var todo = todo_1["default"]($node);
  16929. var todoNode = todo.getTodo();
  16930. var child = (_a = todoNode.children()) === null || _a === void 0 ? void 0 : _a.getNode();
  16931. todoNode.insertAfter($node);
  16932. editor.selection.moveCursor(child);
  16933. $node.remove();
  16934. }
  16935. });
  16936. this.tryChangeActive();
  16937. };
  16938. /**
  16939. * 取消设置todo
  16940. */
  16941. Todo.prototype.cancelTodo = function () {
  16942. var editor = this.editor;
  16943. var $topNodeElems = editor.selection.getSelectionRangeTopNodes();
  16944. (0, _forEach["default"])($topNodeElems).call($topNodeElems, function ($topNodeElem) {
  16945. var _a, _b, _c;
  16946. var content = (_b = (_a = $topNodeElem.childNodes()) === null || _a === void 0 ? void 0 : _a.childNodes()) === null || _b === void 0 ? void 0 : _b.clone(true);
  16947. var $p = dom_core_1["default"]("<p></p>");
  16948. $p.append(content);
  16949. $p.insertAfter($topNodeElem); // 移除input
  16950. (_c = $p.childNodes()) === null || _c === void 0 ? void 0 : _c.get(0).remove();
  16951. editor.selection.moveCursor($p.getNode());
  16952. $topNodeElem.remove();
  16953. });
  16954. };
  16955. return Todo;
  16956. }(BtnMenu_1["default"]);
  16957. exports["default"] = Todo;
  16958. /***/ }),
  16959. /* 426 */
  16960. /***/ (function(module, exports, __webpack_require__) {
  16961. module.exports = __webpack_require__(427);
  16962. /***/ }),
  16963. /* 427 */
  16964. /***/ (function(module, exports, __webpack_require__) {
  16965. var parent = __webpack_require__(428);
  16966. module.exports = parent;
  16967. /***/ }),
  16968. /* 428 */
  16969. /***/ (function(module, exports, __webpack_require__) {
  16970. var every = __webpack_require__(429);
  16971. var ArrayPrototype = Array.prototype;
  16972. module.exports = function (it) {
  16973. var own = it.every;
  16974. return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.every) ? every : own;
  16975. };
  16976. /***/ }),
  16977. /* 429 */
  16978. /***/ (function(module, exports, __webpack_require__) {
  16979. __webpack_require__(430);
  16980. var entryVirtual = __webpack_require__(14);
  16981. module.exports = entryVirtual('Array').every;
  16982. /***/ }),
  16983. /* 430 */
  16984. /***/ (function(module, exports, __webpack_require__) {
  16985. "use strict";
  16986. var $ = __webpack_require__(5);
  16987. var $every = __webpack_require__(31).every;
  16988. var arrayMethodIsStrict = __webpack_require__(73);
  16989. var STRICT_METHOD = arrayMethodIsStrict('every');
  16990. // `Array.prototype.every` method
  16991. // https://tc39.es/ecma262/#sec-array.prototype.every
  16992. $({ target: 'Array', proto: true, forced: !STRICT_METHOD }, {
  16993. every: function every(callbackfn /* , thisArg */) {
  16994. return $every(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
  16995. }
  16996. });
  16997. /***/ }),
  16998. /* 431 */
  16999. /***/ (function(module, exports, __webpack_require__) {
  17000. "use strict";
  17001. var _interopRequireDefault = __webpack_require__(0);
  17002. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17003. var _forEach = _interopRequireDefault(__webpack_require__(4));
  17004. (0, _defineProperty["default"])(exports, "__esModule", {
  17005. value: true
  17006. });
  17007. var tslib_1 = __webpack_require__(2);
  17008. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  17009. var util_1 = __webpack_require__(105);
  17010. var todo_1 = tslib_1.__importDefault(__webpack_require__(145));
  17011. var util_2 = __webpack_require__(105);
  17012. var const_1 = __webpack_require__(7);
  17013. /**
  17014. * todolist 内部逻辑
  17015. * @param editor
  17016. */
  17017. function bindEvent(editor) {
  17018. /**
  17019. * todo的自定义回车事件
  17020. * @param e 事件属性
  17021. */
  17022. function todoEnter(e) {
  17023. var _a, _b; // 判断是否为todo节点
  17024. if (util_1.isAllTodo(editor)) {
  17025. e.preventDefault();
  17026. var selection = editor.selection;
  17027. var $topSelectElem = selection.getSelectionRangeTopNodes()[0];
  17028. var $li = (_a = $topSelectElem.childNodes()) === null || _a === void 0 ? void 0 : _a.get(0);
  17029. var selectionNode = (_b = window.getSelection()) === null || _b === void 0 ? void 0 : _b.anchorNode;
  17030. var range = selection.getRange();
  17031. if (!(range === null || range === void 0 ? void 0 : range.collapsed)) {
  17032. var rangeChildNodes = range === null || range === void 0 ? void 0 : range.commonAncestorContainer.childNodes;
  17033. var startContainer_1 = range === null || range === void 0 ? void 0 : range.startContainer;
  17034. var endContainer_1 = range === null || range === void 0 ? void 0 : range.endContainer;
  17035. var startPos = range === null || range === void 0 ? void 0 : range.startOffset;
  17036. var endPos = range === null || range === void 0 ? void 0 : range.endOffset;
  17037. var startElemIndex_1 = 0;
  17038. var endElemIndex_1 = 0;
  17039. var delList_1 = []; // 找出startContainer和endContainer在rangeChildNodes中的位置
  17040. rangeChildNodes === null || rangeChildNodes === void 0 ? void 0 : (0, _forEach["default"])(rangeChildNodes).call(rangeChildNodes, function (v, i) {
  17041. if (v.contains(startContainer_1)) startElemIndex_1 = i;
  17042. if (v.contains(endContainer_1)) endElemIndex_1 = i;
  17043. }); // 删除两个容器间的内容
  17044. if (endElemIndex_1 - startElemIndex_1 > 1) {
  17045. rangeChildNodes === null || rangeChildNodes === void 0 ? void 0 : (0, _forEach["default"])(rangeChildNodes).call(rangeChildNodes, function (v, i) {
  17046. if (i <= startElemIndex_1) return;
  17047. if (i >= endElemIndex_1) return;
  17048. delList_1.push(v);
  17049. });
  17050. (0, _forEach["default"])(delList_1).call(delList_1, function (v) {
  17051. v.remove();
  17052. });
  17053. } // 删除两个容器里拖蓝的内容
  17054. util_2.dealTextNode(startContainer_1, startPos);
  17055. util_2.dealTextNode(endContainer_1, endPos, false);
  17056. editor.selection.moveCursor(endContainer_1, 0);
  17057. } // 回车时内容为空时,删去此行
  17058. if ($topSelectElem.text() === '') {
  17059. var $p = dom_core_1["default"](const_1.EMPTY_P);
  17060. $p.insertAfter($topSelectElem);
  17061. selection.moveCursor($p.getNode());
  17062. $topSelectElem.remove();
  17063. return;
  17064. }
  17065. var pos = selection.getCursorPos();
  17066. var CursorNextNode = util_1.getCursorNextNode($li === null || $li === void 0 ? void 0 : $li.getNode(), selectionNode, pos);
  17067. var todo = todo_1["default"](dom_core_1["default"](CursorNextNode));
  17068. var $inputcontainer = todo.getInputContainer();
  17069. var todoLiElem = $inputcontainer.parent().getNode();
  17070. var $newTodo = todo.getTodo();
  17071. var contentSection = $inputcontainer.getNode().nextSibling; // 处理光标在最前面时回车input不显示的问题
  17072. if (($li === null || $li === void 0 ? void 0 : $li.text()) === '') {
  17073. $li === null || $li === void 0 ? void 0 : $li.append(dom_core_1["default"]("<br>"));
  17074. }
  17075. $newTodo.insertAfter($topSelectElem); // 处理在google中光标在最后面的,input不显示的问题(必须插入之后移动光标)
  17076. if (!contentSection || (contentSection === null || contentSection === void 0 ? void 0 : contentSection.textContent) === '') {
  17077. // 防止多个br出现的情况
  17078. if ((contentSection === null || contentSection === void 0 ? void 0 : contentSection.nodeName) !== 'BR') {
  17079. var $br = dom_core_1["default"]("<br>");
  17080. $br.insertAfter($inputcontainer);
  17081. }
  17082. selection.moveCursor(todoLiElem, 1);
  17083. } else {
  17084. selection.moveCursor(todoLiElem);
  17085. }
  17086. }
  17087. }
  17088. /**
  17089. * 自定义删除事件,用来处理光标在最前面删除input产生的问题
  17090. */
  17091. function delDown(e) {
  17092. var _a, _b;
  17093. if (util_1.isAllTodo(editor)) {
  17094. var selection = editor.selection;
  17095. var $topSelectElem = selection.getSelectionRangeTopNodes()[0];
  17096. var $li = (_a = $topSelectElem.childNodes()) === null || _a === void 0 ? void 0 : _a.getNode();
  17097. var $p = dom_core_1["default"]("<p></p>");
  17098. var p_1 = $p.getNode();
  17099. var selectionNode = (_b = window.getSelection()) === null || _b === void 0 ? void 0 : _b.anchorNode;
  17100. var pos = selection.getCursorPos();
  17101. var prevNode = selectionNode.previousSibling; // 处理内容为空的情况
  17102. if ($topSelectElem.text() === '') {
  17103. e.preventDefault();
  17104. var $newP = dom_core_1["default"](const_1.EMPTY_P);
  17105. $newP.insertAfter($topSelectElem);
  17106. $topSelectElem.remove();
  17107. selection.moveCursor($newP.getNode(), 0);
  17108. return;
  17109. } // 处理有内容时,光标在最前面的情况
  17110. if ((prevNode === null || prevNode === void 0 ? void 0 : prevNode.nodeName) === 'SPAN' && prevNode.childNodes[0].nodeName === 'INPUT' && pos === 0) {
  17111. var _context;
  17112. e.preventDefault();
  17113. $li === null || $li === void 0 ? void 0 : (0, _forEach["default"])(_context = $li.childNodes).call(_context, function (v, index) {
  17114. if (index === 0) return;
  17115. p_1.appendChild(v.cloneNode(true));
  17116. });
  17117. $p.insertAfter($topSelectElem);
  17118. $topSelectElem.remove();
  17119. }
  17120. }
  17121. }
  17122. /**
  17123. * 自定义删除键up事件
  17124. */
  17125. function deleteUp() {
  17126. var selection = editor.selection;
  17127. var $topSelectElem = selection.getSelectionRangeTopNodes()[0];
  17128. if ($topSelectElem && util_2.isTodo($topSelectElem)) {
  17129. if ($topSelectElem.text() === '') {
  17130. dom_core_1["default"](const_1.EMPTY_P).insertAfter($topSelectElem);
  17131. $topSelectElem.remove();
  17132. }
  17133. }
  17134. }
  17135. /**
  17136. * input 的点击事件( input 默认不会产生 attribute 的改变 )
  17137. * @param e 事件属性
  17138. */
  17139. function inputClick(e) {
  17140. if (e && e.target instanceof HTMLInputElement) {
  17141. if (e.target.type === 'checkbox') {
  17142. if (e.target.checked) {
  17143. e.target.setAttribute('checked', 'true');
  17144. } else {
  17145. e.target.removeAttribute('checked');
  17146. }
  17147. }
  17148. }
  17149. }
  17150. editor.txt.eventHooks.enterDownEvents.push(todoEnter);
  17151. editor.txt.eventHooks.deleteUpEvents.push(deleteUp);
  17152. editor.txt.eventHooks.deleteDownEvents.push(delDown);
  17153. editor.txt.eventHooks.clickEvents.push(inputClick);
  17154. }
  17155. exports["default"] = bindEvent;
  17156. /***/ }),
  17157. /* 432 */
  17158. /***/ (function(module, exports, __webpack_require__) {
  17159. "use strict";
  17160. /**
  17161. * @description 初始化编辑器 DOM 结构
  17162. * @author wangfupeng
  17163. */
  17164. var _interopRequireDefault = __webpack_require__(0);
  17165. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17166. (0, _defineProperty["default"])(exports, "__esModule", {
  17167. value: true
  17168. });
  17169. exports.selectorValidator = void 0;
  17170. var tslib_1 = __webpack_require__(2);
  17171. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  17172. var util_1 = __webpack_require__(6);
  17173. var const_1 = __webpack_require__(7);
  17174. var text_1 = tslib_1.__importDefault(__webpack_require__(134));
  17175. var styleSettings = {
  17176. border: '1px solid #c9d8db',
  17177. toolbarBgColor: '#FFF',
  17178. toolbarBottomBorder: '1px solid #EEE'
  17179. };
  17180. function default_1(editor) {
  17181. var toolbarSelector = editor.toolbarSelector;
  17182. var $toolbarSelector = dom_core_1["default"](toolbarSelector);
  17183. var textSelector = editor.textSelector;
  17184. var config = editor.config;
  17185. var height = config.height;
  17186. var i18next = editor.i18next;
  17187. var $toolbarElem = dom_core_1["default"]('<div></div>');
  17188. var $textContainerElem = dom_core_1["default"]('<div></div>');
  17189. var $textElem;
  17190. var $children;
  17191. var $subChildren = null;
  17192. if (textSelector == null) {
  17193. // 将编辑器区域原有的内容,暂存起来
  17194. $children = $toolbarSelector.children(); // 添加到 DOM 结构中
  17195. $toolbarSelector.append($toolbarElem).append($textContainerElem); // 自行创建的,需要配置默认的样式
  17196. $toolbarElem.css('background-color', styleSettings.toolbarBgColor).css('border', styleSettings.border).css('border-bottom', styleSettings.toolbarBottomBorder);
  17197. $textContainerElem.css('border', styleSettings.border).css('border-top', 'none').css('height', height + "px");
  17198. } else {
  17199. // toolbarSelector 和 textSelector 都有
  17200. $toolbarSelector.append($toolbarElem); // 菜单分离后,文本区域内容暂存
  17201. $subChildren = dom_core_1["default"](textSelector).children();
  17202. dom_core_1["default"](textSelector).append($textContainerElem); // 将编辑器区域原有的内容,暂存起来
  17203. $children = $textContainerElem.children();
  17204. } // 编辑区域
  17205. $textElem = dom_core_1["default"]('<div></div>');
  17206. $textElem.attr('contenteditable', 'true').css('width', '100%').css('height', '100%'); // 添加 placeholder
  17207. var $placeholder;
  17208. var placeholder = editor.config.placeholder;
  17209. if (placeholder !== text_1["default"].placeholder) {
  17210. $placeholder = dom_core_1["default"]("<div>" + placeholder + "</div>");
  17211. } else {
  17212. $placeholder = dom_core_1["default"]("<div>" + i18next.t(placeholder) + "</div>");
  17213. }
  17214. $placeholder.addClass('placeholder'); // 初始化编辑区域内容
  17215. if ($children && $children.length) {
  17216. $textElem.append($children); // 编辑器有默认值的时候隐藏placeholder
  17217. $placeholder.hide();
  17218. } else {
  17219. $textElem.append(dom_core_1["default"](const_1.EMPTY_P)); // 新增一行,方便继续编辑
  17220. } // 菜单分离后,文本区域有标签的带入编辑器内
  17221. if ($subChildren && $subChildren.length) {
  17222. $textElem.append($subChildren); // 编辑器有默认值的时候隐藏placeholder
  17223. $placeholder.hide();
  17224. } // 编辑区域加入DOM
  17225. $textContainerElem.append($textElem); // 添加placeholder
  17226. $textContainerElem.append($placeholder); // 设置通用的 class
  17227. $toolbarElem.addClass('w-e-toolbar').css('z-index', editor.zIndex.get('toolbar'));
  17228. $textContainerElem.addClass('w-e-text-container');
  17229. $textContainerElem.css('z-index', editor.zIndex.get());
  17230. $textElem.addClass('w-e-text'); // 添加 ID
  17231. var toolbarElemId = util_1.getRandom('toolbar-elem');
  17232. $toolbarElem.attr('id', toolbarElemId);
  17233. var textElemId = util_1.getRandom('text-elem');
  17234. $textElem.attr('id', textElemId); // 判断编辑区与容器高度是否一致
  17235. var textContainerCliheight = $textContainerElem.getBoundingClientRect().height;
  17236. var textElemClientHeight = $textElem.getBoundingClientRect().height;
  17237. if (textContainerCliheight !== textElemClientHeight) {
  17238. $textElem.css('min-height', textContainerCliheight + 'px');
  17239. } // 记录属性
  17240. editor.$toolbarElem = $toolbarElem;
  17241. editor.$textContainerElem = $textContainerElem;
  17242. editor.$textElem = $textElem;
  17243. editor.toolbarElemId = toolbarElemId;
  17244. editor.textElemId = textElemId;
  17245. }
  17246. exports["default"] = default_1;
  17247. /**
  17248. * 工具栏/文本区域 DOM selector 有效性验证
  17249. * @param editor 编辑器实例
  17250. */
  17251. function selectorValidator(editor) {
  17252. var name = 'data-we-id';
  17253. var regexp = /^wangEditor-\d+$/;
  17254. var textSelector = editor.textSelector,
  17255. toolbarSelector = editor.toolbarSelector;
  17256. var $el = {
  17257. bar: dom_core_1["default"]('<div></div>'),
  17258. text: dom_core_1["default"]('<div></div>')
  17259. };
  17260. if (toolbarSelector == null) {
  17261. throw new Error('错误:初始化编辑器时候未传入任何参数,请查阅文档');
  17262. } else {
  17263. $el.bar = dom_core_1["default"](toolbarSelector);
  17264. if (!$el.bar.elems.length) {
  17265. throw new Error("\u65E0\u6548\u7684\u8282\u70B9\u9009\u62E9\u5668\uFF1A" + toolbarSelector);
  17266. }
  17267. if (regexp.test($el.bar.attr(name))) {
  17268. throw new Error('初始化节点已存在编辑器实例,无法重复创建编辑器');
  17269. }
  17270. }
  17271. if (textSelector) {
  17272. $el.text = dom_core_1["default"](textSelector);
  17273. if (!$el.text.elems.length) {
  17274. throw new Error("\u65E0\u6548\u7684\u8282\u70B9\u9009\u62E9\u5668\uFF1A" + textSelector);
  17275. }
  17276. if (regexp.test($el.text.attr(name))) {
  17277. throw new Error('初始化节点已存在编辑器实例,无法重复创建编辑器');
  17278. }
  17279. } // 给节点做上标记
  17280. $el.bar.attr(name, editor.id);
  17281. $el.text.attr(name, editor.id); // 在编辑器销毁前取消标记
  17282. editor.beforeDestroy(function () {
  17283. $el.bar.removeAttr(name);
  17284. $el.text.removeAttr(name);
  17285. });
  17286. }
  17287. exports.selectorValidator = selectorValidator;
  17288. /***/ }),
  17289. /* 433 */
  17290. /***/ (function(module, exports, __webpack_require__) {
  17291. "use strict";
  17292. /**
  17293. * @description 初始化编辑器选区,将光标定位到文档末尾
  17294. * @author wangfupeng
  17295. */
  17296. var _interopRequireDefault = __webpack_require__(0);
  17297. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17298. (0, _defineProperty["default"])(exports, "__esModule", {
  17299. value: true
  17300. });
  17301. var tslib_1 = __webpack_require__(2);
  17302. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  17303. var const_1 = __webpack_require__(7);
  17304. /**
  17305. * 初始化编辑器选区,将光标定位到文档末尾
  17306. * @param editor 编辑器实例
  17307. * @param newLine 是否新增一行
  17308. */
  17309. function initSelection(editor, newLine) {
  17310. var $textElem = editor.$textElem;
  17311. var $children = $textElem.children();
  17312. if (!$children || !$children.length) {
  17313. // 如果编辑器区域无内容,添加一个空行,重新设置选区
  17314. $textElem.append(dom_core_1["default"](const_1.EMPTY_P));
  17315. initSelection(editor);
  17316. return;
  17317. }
  17318. var $last = $children.last();
  17319. if (newLine) {
  17320. // 新增一个空行
  17321. var html = $last.html().toLowerCase();
  17322. var nodeName = $last.getNodeName();
  17323. if (html !== '<br>' && html !== '<br/>' || nodeName !== 'P') {
  17324. // 最后一个元素不是 空标签,添加一个空行,重新设置选区
  17325. $textElem.append(dom_core_1["default"](const_1.EMPTY_P));
  17326. initSelection(editor);
  17327. return;
  17328. }
  17329. }
  17330. editor.selection.createRangeByElem($last, false, true);
  17331. if (editor.config.focus) {
  17332. editor.selection.restoreSelection();
  17333. } else {
  17334. // 防止focus=false受其他因素影响
  17335. editor.selection.clearWindowSelectionRange();
  17336. }
  17337. }
  17338. exports["default"] = initSelection;
  17339. /***/ }),
  17340. /* 434 */
  17341. /***/ (function(module, exports, __webpack_require__) {
  17342. "use strict";
  17343. /**
  17344. * @description 绑定编辑器事件 change blur focus
  17345. * @author wangfupeng
  17346. */
  17347. var _interopRequireDefault = __webpack_require__(0);
  17348. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17349. var _forEach = _interopRequireDefault(__webpack_require__(4));
  17350. (0, _defineProperty["default"])(exports, "__esModule", {
  17351. value: true
  17352. });
  17353. var tslib_1 = __webpack_require__(2);
  17354. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  17355. function bindEvent(editor) {
  17356. // 绑定 change 事件
  17357. _bindChange(editor); // 绑定 focus blur 事件
  17358. _bindFocusAndBlur(editor); // 绑定 input 输入
  17359. _bindInput(editor);
  17360. }
  17361. /**
  17362. * 绑定 change 事件
  17363. * @param editor 编辑器实例
  17364. */
  17365. function _bindChange(editor) {
  17366. editor.txt.eventHooks.changeEvents.push(function () {
  17367. var onchange = editor.config.onchange;
  17368. if (onchange) {
  17369. var html = editor.txt.html() || ''; // onchange触发时,是focus状态,详见https://github.com/wangeditor-team/wangEditor/issues/3034
  17370. editor.isFocus = true;
  17371. onchange(html);
  17372. }
  17373. editor.txt.togglePlaceholder();
  17374. });
  17375. }
  17376. /**
  17377. * 绑定 focus blur 事件
  17378. * @param editor 编辑器实例
  17379. */
  17380. function _bindFocusAndBlur(editor) {
  17381. // 当前编辑器是否是焦点状态
  17382. editor.isFocus = false;
  17383. function listener(e) {
  17384. var target = e.target;
  17385. var $target = dom_core_1["default"](target);
  17386. var $textElem = editor.$textElem;
  17387. var $toolbarElem = editor.$toolbarElem; //判断当前点击元素是否在编辑器内
  17388. var isChild = $textElem.isContain($target); //判断当前点击元素是否为工具栏
  17389. var isToolbar = $toolbarElem.isContain($target);
  17390. var isMenu = $toolbarElem.elems[0] == e.target ? true : false;
  17391. if (!isChild) {
  17392. // 若为选择工具栏中的功能,则不视为成 blur 操作
  17393. if (isToolbar && !isMenu || !editor.isFocus) {
  17394. return;
  17395. }
  17396. _blurHandler(editor);
  17397. editor.isFocus = false;
  17398. } else {
  17399. if (!editor.isFocus) {
  17400. _focusHandler(editor);
  17401. }
  17402. editor.isFocus = true;
  17403. }
  17404. } // fix: 增加判断条件,防止当用户设置isFocus=false时,初始化完成后点击其他元素依旧会触发blur事件的问题
  17405. if (document.activeElement === editor.$textElem.elems[0] && editor.config.focus) {
  17406. _focusHandler(editor);
  17407. editor.isFocus = true;
  17408. } // 绑定监听事件
  17409. dom_core_1["default"](document).on('click', listener); // 全局事件在编辑器实例销毁的时候进行解绑
  17410. editor.beforeDestroy(function () {
  17411. dom_core_1["default"](document).off('click', listener);
  17412. });
  17413. }
  17414. /**
  17415. * 绑定 input 事件
  17416. * @param editor 编辑器实例
  17417. */
  17418. function _bindInput(editor) {
  17419. // 绑定中文输入
  17420. editor.$textElem.on('compositionstart', function () {
  17421. editor.isComposing = true;
  17422. editor.txt.togglePlaceholder();
  17423. }).on('compositionend', function () {
  17424. editor.isComposing = false;
  17425. editor.txt.togglePlaceholder();
  17426. });
  17427. }
  17428. /**
  17429. * blur 事件
  17430. * @param editor 编辑器实例
  17431. */
  17432. function _blurHandler(editor) {
  17433. var _context;
  17434. var config = editor.config;
  17435. var onblur = config.onblur;
  17436. var currentHtml = editor.txt.html() || '';
  17437. (0, _forEach["default"])(_context = editor.txt.eventHooks.onBlurEvents).call(_context, function (fn) {
  17438. return fn();
  17439. });
  17440. onblur(currentHtml);
  17441. }
  17442. /**
  17443. * focus 事件
  17444. * @param editor 编辑器实例
  17445. */
  17446. function _focusHandler(editor) {
  17447. var config = editor.config;
  17448. var onfocus = config.onfocus;
  17449. var currentHtml = editor.txt.html() || '';
  17450. onfocus(currentHtml);
  17451. }
  17452. exports["default"] = bindEvent;
  17453. /***/ }),
  17454. /* 435 */
  17455. /***/ (function(module, exports, __webpack_require__) {
  17456. "use strict";
  17457. /**
  17458. * @description 国际化 初始化
  17459. * @author tonghan
  17460. * i18next 是使用 JavaScript 编写的国际化框架
  17461. * i18next 提供了标准的i18n功能,例如(复数,上下文,插值,格式)等
  17462. * i18next 文档地址: https://www.i18next.com/overview/getting-started
  17463. */
  17464. var _interopRequireDefault = __webpack_require__(0);
  17465. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17466. (0, _defineProperty["default"])(exports, "__esModule", {
  17467. value: true
  17468. });
  17469. function i18nextInit(editor) {
  17470. var _a = editor.config,
  17471. lang = _a.lang,
  17472. languages = _a.languages;
  17473. if (editor.i18next != null) {
  17474. try {
  17475. editor.i18next.init({
  17476. ns: 'wangEditor',
  17477. lng: lang,
  17478. defaultNS: 'wangEditor',
  17479. resources: languages
  17480. });
  17481. } catch (error) {
  17482. throw new Error('i18next:' + error);
  17483. }
  17484. return;
  17485. } // 没有引入 i18next 的替代品
  17486. editor.i18next = {
  17487. t: function t(str) {
  17488. var strArr = str.split('.');
  17489. return strArr[strArr.length - 1];
  17490. }
  17491. };
  17492. }
  17493. exports["default"] = i18nextInit;
  17494. /***/ }),
  17495. /* 436 */
  17496. /***/ (function(module, exports, __webpack_require__) {
  17497. "use strict";
  17498. /**
  17499. * @description 全屏功能
  17500. * @author xiaokyo
  17501. */
  17502. var _interopRequireDefault = __webpack_require__(0);
  17503. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17504. var _find = _interopRequireDefault(__webpack_require__(32));
  17505. (0, _defineProperty["default"])(exports, "__esModule", {
  17506. value: true
  17507. });
  17508. exports.setUnFullScreen = exports.setFullScreen = void 0;
  17509. var tslib_1 = __webpack_require__(2);
  17510. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  17511. __webpack_require__(437);
  17512. var iconFullScreenText = 'w-e-icon-fullscreen'; // 全屏icon class
  17513. var iconExitFullScreenText = 'w-e-icon-fullscreen_exit'; // 退出全屏icon class
  17514. var classfullScreenEditor = 'w-e-full-screen-editor'; // 全屏添加至编辑器的class
  17515. /**
  17516. * 设置全屏
  17517. * @param editor 编辑器实例
  17518. */
  17519. var setFullScreen = function setFullScreen(editor) {
  17520. var $editorParent = dom_core_1["default"](editor.toolbarSelector);
  17521. var $textContainerElem = editor.$textContainerElem;
  17522. var $toolbarElem = editor.$toolbarElem;
  17523. var $iconElem = (0, _find["default"])($toolbarElem).call($toolbarElem, "i." + iconFullScreenText);
  17524. var config = editor.config;
  17525. $iconElem.removeClass(iconFullScreenText);
  17526. $iconElem.addClass(iconExitFullScreenText);
  17527. $editorParent.addClass(classfullScreenEditor);
  17528. $editorParent.css('z-index', config.zIndexFullScreen);
  17529. var bar = $toolbarElem.getBoundingClientRect();
  17530. $textContainerElem.css('height', "calc(100% - " + bar.height + "px)");
  17531. };
  17532. exports.setFullScreen = setFullScreen;
  17533. /**
  17534. * 取消全屏
  17535. * @param editor 编辑器实例
  17536. */
  17537. var setUnFullScreen = function setUnFullScreen(editor) {
  17538. var $editorParent = dom_core_1["default"](editor.toolbarSelector);
  17539. var $textContainerElem = editor.$textContainerElem;
  17540. var $toolbarElem = editor.$toolbarElem;
  17541. var $iconElem = (0, _find["default"])($toolbarElem).call($toolbarElem, "i." + iconExitFullScreenText);
  17542. var config = editor.config;
  17543. $iconElem.removeClass(iconExitFullScreenText);
  17544. $iconElem.addClass(iconFullScreenText);
  17545. $editorParent.removeClass(classfullScreenEditor);
  17546. $editorParent.css('z-index', 'auto');
  17547. $textContainerElem.css('height', config.height + 'px');
  17548. };
  17549. exports.setUnFullScreen = setUnFullScreen;
  17550. /**
  17551. * 初始化全屏功能
  17552. * @param editor 编辑器实例
  17553. */
  17554. var initFullScreen = function initFullScreen(editor) {
  17555. // 当textSelector有值的时候,也就是编辑器是工具栏和编辑区域分离的情况, 则不生成全屏功能按钮
  17556. if (editor.textSelector) return;
  17557. if (!editor.config.showFullScreen) return;
  17558. var $toolbarElem = editor.$toolbarElem;
  17559. var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5168\u5C4F\">\n <i class=\"" + iconFullScreenText + "\"></i>\n </div>");
  17560. $elem.on('click', function (e) {
  17561. var _context;
  17562. var $elemIcon = (0, _find["default"])(_context = dom_core_1["default"](e.currentTarget)).call(_context, 'i');
  17563. if ($elemIcon.hasClass(iconFullScreenText)) {
  17564. $elem.attr('data-title', '取消全屏');
  17565. exports.setFullScreen(editor);
  17566. } else {
  17567. $elem.attr('data-title', '全屏');
  17568. exports.setUnFullScreen(editor);
  17569. }
  17570. });
  17571. $toolbarElem.append($elem);
  17572. };
  17573. exports["default"] = initFullScreen;
  17574. /***/ }),
  17575. /* 437 */
  17576. /***/ (function(module, exports, __webpack_require__) {
  17577. var api = __webpack_require__(21);
  17578. var content = __webpack_require__(438);
  17579. content = content.__esModule ? content.default : content;
  17580. if (typeof content === 'string') {
  17581. content = [[module.i, content, '']];
  17582. }
  17583. var options = {};
  17584. options.insert = "head";
  17585. options.singleton = false;
  17586. var update = api(content, options);
  17587. module.exports = content.locals || {};
  17588. /***/ }),
  17589. /* 438 */
  17590. /***/ (function(module, exports, __webpack_require__) {
  17591. // Imports
  17592. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  17593. exports = ___CSS_LOADER_API_IMPORT___(false);
  17594. // Module
  17595. exports.push([module.i, ".w-e-full-screen-editor {\n position: fixed;\n width: 100%!important;\n height: 100%!important;\n left: 0;\n top: 0;\n}\n", ""]);
  17596. // Exports
  17597. module.exports = exports;
  17598. /***/ }),
  17599. /* 439 */
  17600. /***/ (function(module, exports, __webpack_require__) {
  17601. "use strict";
  17602. /**
  17603. * @description 滚动到指定锚点
  17604. * @author zhengwenjian
  17605. */
  17606. var _interopRequireDefault = __webpack_require__(0);
  17607. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17608. var _find = _interopRequireDefault(__webpack_require__(32));
  17609. (0, _defineProperty["default"])(exports, "__esModule", {
  17610. value: true
  17611. });
  17612. /**
  17613. * 编辑器滚动到指定锚点
  17614. * @param editor 编辑器实例
  17615. * @param id 标题锚点id
  17616. */
  17617. var scrollToHead = function scrollToHead(editor, id) {
  17618. var _context;
  17619. var $textElem = editor.isEnable ? editor.$textElem : (0, _find["default"])(_context = editor.$textContainerElem).call(_context, '.w-e-content-mantle');
  17620. var $targetHead = (0, _find["default"])($textElem).call($textElem, "[id='" + id + "']");
  17621. var targetTop = $targetHead.getOffsetData().top;
  17622. $textElem.scrollTop(targetTop);
  17623. };
  17624. exports["default"] = scrollToHead;
  17625. /***/ }),
  17626. /* 440 */
  17627. /***/ (function(module, exports, __webpack_require__) {
  17628. "use strict";
  17629. var _interopRequireDefault = __webpack_require__(0);
  17630. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17631. (0, _defineProperty["default"])(exports, "__esModule", {
  17632. value: true
  17633. });
  17634. var tslib_1 = __webpack_require__(2);
  17635. var style_1 = tslib_1.__importDefault(__webpack_require__(133));
  17636. var tier = {
  17637. menu: 2,
  17638. panel: 2,
  17639. toolbar: 1,
  17640. tooltip: 1,
  17641. textContainer: 1 // 编辑区域
  17642. };
  17643. var ZIndex = function () {
  17644. function ZIndex() {
  17645. // 层级参数
  17646. this.tier = tier; // 默认值
  17647. this.baseZIndex = style_1["default"].zIndex;
  17648. } // 获取 tierName 对应的 z-index 的值。如果 tierName 未定义则返回默认的 z-index 值
  17649. ZIndex.prototype.get = function (tierName) {
  17650. if (tierName && this.tier[tierName]) {
  17651. return this.baseZIndex + this.tier[tierName];
  17652. }
  17653. return this.baseZIndex;
  17654. }; // 初始化
  17655. ZIndex.prototype.init = function (editor) {
  17656. if (this.baseZIndex == style_1["default"].zIndex) {
  17657. this.baseZIndex = editor.config.zIndex;
  17658. }
  17659. };
  17660. return ZIndex;
  17661. }();
  17662. exports["default"] = ZIndex;
  17663. /***/ }),
  17664. /* 441 */
  17665. /***/ (function(module, exports, __webpack_require__) {
  17666. "use strict";
  17667. /**
  17668. * @description 编辑器 change 事件
  17669. * @author fangzhicong
  17670. */
  17671. var _interopRequireDefault = __webpack_require__(0);
  17672. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17673. var _filter = _interopRequireDefault(__webpack_require__(76));
  17674. var _forEach = _interopRequireDefault(__webpack_require__(4));
  17675. (0, _defineProperty["default"])(exports, "__esModule", {
  17676. value: true
  17677. });
  17678. var tslib_1 = __webpack_require__(2);
  17679. var mutation_1 = tslib_1.__importDefault(__webpack_require__(442));
  17680. var util_1 = __webpack_require__(6);
  17681. var const_1 = __webpack_require__(7);
  17682. /**
  17683. * 剔除编辑区容器的 attribute 变化中的非 contenteditable 变化
  17684. * @param mutations MutationRecord[]
  17685. * @param tar 编辑区容器的 DOM 节点
  17686. */
  17687. function mutationsFilter(mutations, tar) {
  17688. // 剔除编辑区容器的 attribute 变化中的非 contenteditable 变化
  17689. return (0, _filter["default"])(mutations).call(mutations, function (_a) {
  17690. var type = _a.type,
  17691. target = _a.target,
  17692. attributeName = _a.attributeName;
  17693. return type != 'attributes' || type == 'attributes' && (attributeName == 'contenteditable' || target != tar);
  17694. });
  17695. }
  17696. /**
  17697. * Change 实现
  17698. */
  17699. var Change = function (_super) {
  17700. tslib_1.__extends(Change, _super);
  17701. function Change(editor) {
  17702. var _this = _super.call(this, function (mutations, observer) {
  17703. var _a; // 数据过滤
  17704. mutations = mutationsFilter(mutations, observer.target); // 存储数据
  17705. (_a = _this.data).push.apply(_a, mutations); // 标准模式下
  17706. if (!editor.isCompatibleMode) {
  17707. // 在非中文输入状态下时才保存数据
  17708. if (!editor.isComposing) {
  17709. return _this.asyncSave();
  17710. }
  17711. } // 兼容模式下
  17712. else {
  17713. _this.asyncSave();
  17714. }
  17715. }) || this;
  17716. _this.editor = editor;
  17717. /**
  17718. * 变化的数据集合
  17719. */
  17720. _this.data = [];
  17721. /**
  17722. * 异步保存数据
  17723. */
  17724. _this.asyncSave = const_1.EMPTY_FN;
  17725. return _this;
  17726. }
  17727. /**
  17728. * 保存变化的数据并发布 change event
  17729. */
  17730. Change.prototype.save = function () {
  17731. // 有数据
  17732. if (this.data.length) {
  17733. // 保存变化数据
  17734. this.editor.history.save(this.data); // 清除缓存
  17735. this.data.length = 0;
  17736. this.emit();
  17737. }
  17738. };
  17739. /**
  17740. * 发布 change event
  17741. */
  17742. Change.prototype.emit = function () {
  17743. var _context;
  17744. // 执行 onchange 回调
  17745. (0, _forEach["default"])(_context = this.editor.txt.eventHooks.changeEvents).call(_context, function (fn) {
  17746. return fn();
  17747. });
  17748. }; // 重写 observe
  17749. Change.prototype.observe = function () {
  17750. var _this = this;
  17751. _super.prototype.observe.call(this, this.editor.$textElem.elems[0]);
  17752. var timeout = this.editor.config.onchangeTimeout;
  17753. this.asyncSave = util_1.debounce(function () {
  17754. _this.save();
  17755. }, timeout);
  17756. if (!this.editor.isCompatibleMode) {
  17757. this.editor.$textElem.on('compositionend', function () {
  17758. _this.asyncSave();
  17759. });
  17760. }
  17761. };
  17762. return Change;
  17763. }(mutation_1["default"]);
  17764. exports["default"] = Change;
  17765. /***/ }),
  17766. /* 442 */
  17767. /***/ (function(module, exports, __webpack_require__) {
  17768. "use strict";
  17769. /**
  17770. * @description 封装 MutationObserver
  17771. * @author fangzhicong
  17772. */
  17773. var _interopRequireDefault = __webpack_require__(0);
  17774. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17775. (0, _defineProperty["default"])(exports, "__esModule", {
  17776. value: true
  17777. });
  17778. /**
  17779. * 封装 MutationObserver,抽离成公共类
  17780. */
  17781. var Mutation = function () {
  17782. /**
  17783. * 构造器
  17784. * @param fn 发生变化时执行的回调函数
  17785. * @param options 自定义配置项
  17786. */
  17787. function Mutation(fn, options) {
  17788. var _this = this;
  17789. /**
  17790. * 默认的 MutationObserverInit 配置
  17791. */
  17792. this.options = {
  17793. subtree: true,
  17794. childList: true,
  17795. attributes: true,
  17796. attributeOldValue: true,
  17797. characterData: true,
  17798. characterDataOldValue: true
  17799. };
  17800. this.callback = function (mutations) {
  17801. fn(mutations, _this);
  17802. };
  17803. this.observer = new MutationObserver(this.callback);
  17804. options && (this.options = options);
  17805. }
  17806. (0, _defineProperty["default"])(Mutation.prototype, "target", {
  17807. get: function get() {
  17808. return this.node;
  17809. },
  17810. enumerable: false,
  17811. configurable: true
  17812. });
  17813. /**
  17814. * 绑定监听节点(初次绑定有效)
  17815. * @param node 需要被监听的节点
  17816. */
  17817. Mutation.prototype.observe = function (node) {
  17818. if (!(this.node instanceof Node)) {
  17819. this.node = node;
  17820. this.connect();
  17821. }
  17822. };
  17823. /**
  17824. * 连接监听器(开始观察)
  17825. */
  17826. Mutation.prototype.connect = function () {
  17827. if (this.node) {
  17828. this.observer.observe(this.node, this.options);
  17829. return this;
  17830. }
  17831. throw new Error('还未初始化绑定,请您先绑定有效的 Node 节点');
  17832. };
  17833. /**
  17834. * 断开监听器(停止观察)
  17835. */
  17836. Mutation.prototype.disconnect = function () {
  17837. var list = this.observer.takeRecords();
  17838. list.length && this.callback(list);
  17839. this.observer.disconnect();
  17840. };
  17841. return Mutation;
  17842. }();
  17843. exports["default"] = Mutation;
  17844. /***/ }),
  17845. /* 443 */
  17846. /***/ (function(module, exports, __webpack_require__) {
  17847. "use strict";
  17848. /**
  17849. * @description 历史记录
  17850. * @author fangzhicong
  17851. */
  17852. var _interopRequireDefault = __webpack_require__(0);
  17853. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17854. (0, _defineProperty["default"])(exports, "__esModule", {
  17855. value: true
  17856. });
  17857. var tslib_1 = __webpack_require__(2);
  17858. var content_1 = tslib_1.__importDefault(__webpack_require__(444));
  17859. var scroll_1 = tslib_1.__importDefault(__webpack_require__(451));
  17860. var range_1 = tslib_1.__importDefault(__webpack_require__(452));
  17861. /**
  17862. * 历史记录(撤销、恢复)
  17863. */
  17864. var History = function () {
  17865. function History(editor) {
  17866. this.editor = editor;
  17867. this.content = new content_1["default"](editor);
  17868. this.scroll = new scroll_1["default"](editor);
  17869. this.range = new range_1["default"](editor);
  17870. }
  17871. (0, _defineProperty["default"])(History.prototype, "size", {
  17872. /**
  17873. * 获取缓存中的数据长度。格式为:[正常的数据的条数,被撤销的数据的条数]
  17874. */
  17875. get: function get() {
  17876. return this.scroll.size;
  17877. },
  17878. enumerable: false,
  17879. configurable: true
  17880. });
  17881. /**
  17882. * 初始化绑定。在 editor.create() 结尾时调用
  17883. */
  17884. History.prototype.observe = function () {
  17885. this.content.observe();
  17886. this.scroll.observe(); // 标准模式下才进行初始化绑定
  17887. !this.editor.isCompatibleMode && this.range.observe();
  17888. };
  17889. /**
  17890. * 保存数据
  17891. */
  17892. History.prototype.save = function (mutations) {
  17893. if (mutations.length) {
  17894. this.content.save(mutations);
  17895. this.scroll.save(); // 标准模式下才进行缓存
  17896. !this.editor.isCompatibleMode && this.range.save();
  17897. }
  17898. };
  17899. /**
  17900. * 撤销
  17901. */
  17902. History.prototype.revoke = function () {
  17903. this.editor.change.disconnect();
  17904. var res = this.content.revoke();
  17905. if (res) {
  17906. this.scroll.revoke(); // 标准模式下才执行
  17907. if (!this.editor.isCompatibleMode) {
  17908. this.range.revoke();
  17909. this.editor.$textElem.focus();
  17910. }
  17911. }
  17912. this.editor.change.connect(); // 如果用户在 onchange 中修改了内容(DOM),那么缓存中的节点数据可能不连贯了,不连贯的数据必将导致恢复失败,所以必须将用户的 onchange 处于监控状态中
  17913. res && this.editor.change.emit();
  17914. };
  17915. /**
  17916. * 恢复
  17917. */
  17918. History.prototype.restore = function () {
  17919. this.editor.change.disconnect();
  17920. var res = this.content.restore();
  17921. if (res) {
  17922. this.scroll.restore(); // 标准模式下才执行
  17923. if (!this.editor.isCompatibleMode) {
  17924. this.range.restore();
  17925. this.editor.$textElem.focus();
  17926. }
  17927. }
  17928. this.editor.change.connect(); // 与 revoke 同理
  17929. res && this.editor.change.emit();
  17930. };
  17931. return History;
  17932. }();
  17933. exports["default"] = History;
  17934. /***/ }),
  17935. /* 444 */
  17936. /***/ (function(module, exports, __webpack_require__) {
  17937. "use strict";
  17938. /**
  17939. * @description 整合差异备份和内容备份,进行统一管理
  17940. * @author fangzhicong
  17941. */
  17942. var _interopRequireDefault = __webpack_require__(0);
  17943. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  17944. (0, _defineProperty["default"])(exports, "__esModule", {
  17945. value: true
  17946. });
  17947. var tslib_1 = __webpack_require__(2);
  17948. var node_1 = tslib_1.__importDefault(__webpack_require__(445));
  17949. var html_1 = tslib_1.__importDefault(__webpack_require__(449));
  17950. var ContentCache = function () {
  17951. function ContentCache(editor) {
  17952. this.editor = editor;
  17953. }
  17954. /**
  17955. * 初始化绑定
  17956. */
  17957. ContentCache.prototype.observe = function () {
  17958. if (this.editor.isCompatibleMode) {
  17959. // 兼容模式(内容备份)
  17960. this.cache = new html_1["default"](this.editor);
  17961. } else {
  17962. // 标准模式(差异备份/节点备份)
  17963. this.cache = new node_1["default"](this.editor);
  17964. }
  17965. this.cache.observe();
  17966. };
  17967. /**
  17968. * 保存
  17969. */
  17970. ContentCache.prototype.save = function (mutations) {
  17971. if (this.editor.isCompatibleMode) {
  17972. ;
  17973. this.cache.save();
  17974. } else {
  17975. ;
  17976. this.cache.compile(mutations);
  17977. }
  17978. };
  17979. /**
  17980. * 撤销
  17981. */
  17982. ContentCache.prototype.revoke = function () {
  17983. var _a;
  17984. return (_a = this.cache) === null || _a === void 0 ? void 0 : _a.revoke();
  17985. };
  17986. /**
  17987. * 恢复
  17988. */
  17989. ContentCache.prototype.restore = function () {
  17990. var _a;
  17991. return (_a = this.cache) === null || _a === void 0 ? void 0 : _a.restore();
  17992. };
  17993. return ContentCache;
  17994. }();
  17995. exports["default"] = ContentCache;
  17996. /***/ }),
  17997. /* 445 */
  17998. /***/ (function(module, exports, __webpack_require__) {
  17999. "use strict";
  18000. /**
  18001. * @description 差异备份
  18002. * @author fangzhicong
  18003. */
  18004. var _interopRequireDefault = __webpack_require__(0);
  18005. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18006. (0, _defineProperty["default"])(exports, "__esModule", {
  18007. value: true
  18008. });
  18009. var tslib_1 = __webpack_require__(2);
  18010. var cache_1 = tslib_1.__importDefault(__webpack_require__(106));
  18011. var compile_1 = tslib_1.__importDefault(__webpack_require__(447));
  18012. var decompilation_1 = __webpack_require__(448);
  18013. var NodeCache = function (_super) {
  18014. tslib_1.__extends(NodeCache, _super);
  18015. function NodeCache(editor) {
  18016. var _this = _super.call(this, editor.config.historyMaxSize) || this;
  18017. _this.editor = editor;
  18018. return _this;
  18019. }
  18020. NodeCache.prototype.observe = function () {
  18021. this.resetMaxSize(this.editor.config.historyMaxSize);
  18022. };
  18023. /**
  18024. * 编译并保存数据
  18025. */
  18026. NodeCache.prototype.compile = function (data) {
  18027. this.save(compile_1["default"](data));
  18028. return this;
  18029. };
  18030. /**
  18031. * 撤销
  18032. */
  18033. NodeCache.prototype.revoke = function () {
  18034. return _super.prototype.revoke.call(this, function (data) {
  18035. decompilation_1.revoke(data);
  18036. });
  18037. };
  18038. /**
  18039. * 恢复
  18040. */
  18041. NodeCache.prototype.restore = function () {
  18042. return _super.prototype.restore.call(this, function (data) {
  18043. decompilation_1.restore(data);
  18044. });
  18045. };
  18046. return NodeCache;
  18047. }(cache_1["default"]);
  18048. exports["default"] = NodeCache;
  18049. /***/ }),
  18050. /* 446 */
  18051. /***/ (function(module, exports, __webpack_require__) {
  18052. "use strict";
  18053. /**
  18054. * @description 数据结构 - 栈
  18055. * @author fangzhicong
  18056. */
  18057. var _interopRequireDefault = __webpack_require__(0);
  18058. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18059. (0, _defineProperty["default"])(exports, "__esModule", {
  18060. value: true
  18061. });
  18062. exports.CeilStack = void 0;
  18063. /**
  18064. * 栈(限制最大数据条数,栈满后可以继续入栈,而先入栈的数据将失效)
  18065. */
  18066. // 取名灵感来自 Math.ceil,向上取有效值
  18067. var CeilStack = function () {
  18068. function CeilStack(max) {
  18069. if (max === void 0) {
  18070. max = 0;
  18071. }
  18072. /**
  18073. * 数据缓存
  18074. */
  18075. this.data = [];
  18076. /**
  18077. * 栈的最大长度。为零则长度不限
  18078. */
  18079. this.max = 0;
  18080. /**
  18081. * 标识是否重设过 max 值
  18082. */
  18083. this.reset = false;
  18084. max = Math.abs(max);
  18085. max && (this.max = max);
  18086. }
  18087. /**
  18088. * 允许用户重设一次 max 值
  18089. */
  18090. CeilStack.prototype.resetMax = function (maxSize) {
  18091. maxSize = Math.abs(maxSize);
  18092. if (!this.reset && !isNaN(maxSize)) {
  18093. this.max = maxSize;
  18094. this.reset = true;
  18095. }
  18096. };
  18097. (0, _defineProperty["default"])(CeilStack.prototype, "size", {
  18098. /**
  18099. * 当前栈中的数据条数
  18100. */
  18101. get: function get() {
  18102. return this.data.length;
  18103. },
  18104. enumerable: false,
  18105. configurable: true
  18106. });
  18107. /**
  18108. * 入栈
  18109. * @param data 入栈的数据
  18110. */
  18111. CeilStack.prototype.instack = function (data) {
  18112. this.data.unshift(data);
  18113. if (this.max && this.size > this.max) {
  18114. this.data.length = this.max;
  18115. }
  18116. return this;
  18117. };
  18118. /**
  18119. * 出栈
  18120. */
  18121. CeilStack.prototype.outstack = function () {
  18122. return this.data.shift();
  18123. };
  18124. /**
  18125. * 清空栈
  18126. */
  18127. CeilStack.prototype.clear = function () {
  18128. this.data.length = 0;
  18129. return this;
  18130. };
  18131. return CeilStack;
  18132. }();
  18133. exports.CeilStack = CeilStack;
  18134. /***/ }),
  18135. /* 447 */
  18136. /***/ (function(module, exports, __webpack_require__) {
  18137. "use strict";
  18138. /**
  18139. * @description 数据整理
  18140. * @author fangzhicong
  18141. */
  18142. var _interopRequireDefault = __webpack_require__(0);
  18143. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18144. var _forEach = _interopRequireDefault(__webpack_require__(4));
  18145. var _indexOf = _interopRequireDefault(__webpack_require__(28));
  18146. (0, _defineProperty["default"])(exports, "__esModule", {
  18147. value: true
  18148. });
  18149. exports.compliePosition = exports.complieNodes = exports.compileValue = exports.compileType = void 0;
  18150. var util_1 = __webpack_require__(6);
  18151. /**
  18152. * 数据类型
  18153. */
  18154. function compileType(data) {
  18155. switch (data) {
  18156. case 'childList':
  18157. return 'node';
  18158. case 'attributes':
  18159. return 'attr';
  18160. default:
  18161. return 'text';
  18162. }
  18163. }
  18164. exports.compileType = compileType;
  18165. /**
  18166. * 获取当前的文本内容
  18167. */
  18168. function compileValue(data) {
  18169. switch (data.type) {
  18170. case 'attributes':
  18171. return data.target.getAttribute(data.attributeName) || '';
  18172. case 'characterData':
  18173. return data.target.textContent;
  18174. default:
  18175. return '';
  18176. }
  18177. }
  18178. exports.compileValue = compileValue;
  18179. /**
  18180. * addedNodes/removedNodes
  18181. */
  18182. function complieNodes(data) {
  18183. var temp = {};
  18184. if (data.addedNodes.length) {
  18185. temp.add = util_1.toArray(data.addedNodes);
  18186. }
  18187. if (data.removedNodes.length) {
  18188. temp.remove = util_1.toArray(data.removedNodes);
  18189. }
  18190. return temp;
  18191. }
  18192. exports.complieNodes = complieNodes;
  18193. /**
  18194. * addedNodes/removedNodes 的相对位置
  18195. */
  18196. function compliePosition(data) {
  18197. var temp;
  18198. if (data.previousSibling) {
  18199. temp = {
  18200. type: 'before',
  18201. target: data.previousSibling
  18202. };
  18203. } else if (data.nextSibling) {
  18204. temp = {
  18205. type: 'after',
  18206. target: data.nextSibling
  18207. };
  18208. } else {
  18209. temp = {
  18210. type: 'parent',
  18211. target: data.target
  18212. };
  18213. }
  18214. return temp;
  18215. }
  18216. exports.compliePosition = compliePosition;
  18217. /**
  18218. * 补全 Firefox 数据的特殊标签
  18219. */
  18220. var tag = ['UL', 'OL', 'H1', 'H2', 'H3', 'H4', 'H5', 'H6'];
  18221. /**
  18222. * 将 MutationRecord 转换成自定义格式的数据
  18223. */
  18224. function compile(data) {
  18225. var temp = []; // 以下两个变量是兼容 Firefox 时使用到的
  18226. // 前一次操作为删除元素节点
  18227. var removeNode = false; // 连续的节点删除记录
  18228. var removeCache = [];
  18229. (0, _forEach["default"])(data).call(data, function (record, index) {
  18230. var item = {
  18231. type: compileType(record.type),
  18232. target: record.target,
  18233. attr: record.attributeName || '',
  18234. value: compileValue(record) || '',
  18235. oldValue: record.oldValue || '',
  18236. nodes: complieNodes(record),
  18237. position: compliePosition(record)
  18238. };
  18239. temp.push(item); // 兼容 Firefox,补全数据(这几十行代码写得吐血,跟 IE 有得一拼)
  18240. if (!util_1.UA.isFirefox) {
  18241. return;
  18242. } // 正常的数据:缩进、行高、超链接、对齐方式、引用、插入表情、插入图片、分割线、表格、插入代码
  18243. // 普通的数据补全:标题(纯文本内容)、加粗、斜体、删除线、下划线、颜色、背景色、字体、字号、列表(纯文本内容)
  18244. // 特殊的数据补全:标题(包含 HTMLElement)、列表(包含 HTMLElement 或 ul -> ol 或 ol -> ul 或 Enter)
  18245. if (removeNode && record.addedNodes.length && record.addedNodes[0].nodeType == 1) {
  18246. // 需要被全数据的目标节点
  18247. var replenishNode = record.addedNodes[0];
  18248. var replenishData = {
  18249. type: 'node',
  18250. target: replenishNode,
  18251. attr: '',
  18252. value: '',
  18253. oldValue: '',
  18254. nodes: {
  18255. add: [removeNode]
  18256. },
  18257. position: {
  18258. type: 'parent',
  18259. target: replenishNode
  18260. }
  18261. }; // 特殊的标签:['UL', 'OL', 'H1', 'H2', 'H3', 'H4', 'H5', 'H6']
  18262. if ((0, _indexOf["default"])(tag).call(tag, replenishNode.nodeName) != -1) {
  18263. replenishData.nodes.add = util_1.toArray(replenishNode.childNodes);
  18264. temp.push(replenishData);
  18265. } // 上一个删除元素是文本节点
  18266. else if (removeNode.nodeType == 3) {
  18267. if (contains(replenishNode, removeCache)) {
  18268. replenishData.nodes.add = util_1.toArray(replenishNode.childNodes);
  18269. }
  18270. temp.push(replenishData);
  18271. } // 上一个删除元素是 Element && 由近到远的删除元素至少有一个是需要补全数据节点的子节点
  18272. else if ((0, _indexOf["default"])(tag).call(tag, record.target.nodeName) == -1 && contains(replenishNode, removeCache)) {
  18273. replenishData.nodes.add = util_1.toArray(replenishNode.childNodes);
  18274. temp.push(replenishData);
  18275. }
  18276. } // 记录本次的节点信息
  18277. if (item.type == 'node' && record.removedNodes.length == 1) {
  18278. removeNode = record.removedNodes[0];
  18279. removeCache.push(removeNode);
  18280. } else {
  18281. removeNode = false;
  18282. removeCache.length = 0;
  18283. }
  18284. });
  18285. return temp;
  18286. }
  18287. exports["default"] = compile; // 删除元素的历史记录中包含有多少个目标节点的子元素
  18288. function contains(tar, childs) {
  18289. var count = 0;
  18290. for (var i = childs.length - 1; i > 0; i--) {
  18291. if (tar.contains(childs[i])) {
  18292. count++;
  18293. } else {
  18294. break;
  18295. }
  18296. }
  18297. return count;
  18298. }
  18299. /***/ }),
  18300. /* 448 */
  18301. /***/ (function(module, exports, __webpack_require__) {
  18302. "use strict";
  18303. var _interopRequireDefault = __webpack_require__(0);
  18304. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18305. var _forEach = _interopRequireDefault(__webpack_require__(4));
  18306. var _entries = _interopRequireDefault(__webpack_require__(102));
  18307. (0, _defineProperty["default"])(exports, "__esModule", {
  18308. value: true
  18309. });
  18310. exports.restore = exports.revoke = void 0;
  18311. /**
  18312. * 将节点添加到 DOM 树中
  18313. * @param data 数据项
  18314. * @param list 节点集合(addedNodes 或 removedNodes)
  18315. */
  18316. function insertNode(data, list) {
  18317. var reference = data.position.target;
  18318. switch (data.position.type) {
  18319. // reference 在这些节点的前面
  18320. case 'before':
  18321. if (reference.nextSibling) {
  18322. reference = reference.nextSibling;
  18323. (0, _forEach["default"])(list).call(list, function (item) {
  18324. data.target.insertBefore(item, reference);
  18325. });
  18326. } else {
  18327. (0, _forEach["default"])(list).call(list, function (item) {
  18328. data.target.appendChild(item);
  18329. });
  18330. }
  18331. break;
  18332. // reference 在这些节点的后面
  18333. case 'after':
  18334. (0, _forEach["default"])(list).call(list, function (item) {
  18335. data.target.insertBefore(item, reference);
  18336. });
  18337. break;
  18338. // parent
  18339. // reference 是这些节点的父节点
  18340. default:
  18341. (0, _forEach["default"])(list).call(list, function (item) {
  18342. reference.appendChild(item);
  18343. });
  18344. break;
  18345. }
  18346. }
  18347. /* ------------------------------------------------------------------ 撤销逻辑 ------------------------------------------------------------------ */
  18348. function revokeNode(data) {
  18349. for (var _i = 0, _a = (0, _entries["default"])(data.nodes); _i < _a.length; _i++) {
  18350. var _b = _a[_i],
  18351. relative = _b[0],
  18352. list = _b[1];
  18353. switch (relative) {
  18354. // 反向操作,将这些节点从 DOM 中移除
  18355. case 'add':
  18356. (0, _forEach["default"])(list).call(list, function (item) {
  18357. data.target.removeChild(item);
  18358. });
  18359. break;
  18360. // remove(反向操作,将这些节点添加到 DOM 中)
  18361. default:
  18362. {
  18363. insertNode(data, list);
  18364. break;
  18365. }
  18366. }
  18367. }
  18368. }
  18369. /**
  18370. * 撤销 attribute
  18371. */
  18372. function revokeAttr(data) {
  18373. var target = data.target;
  18374. if (data.oldValue == null) {
  18375. target.removeAttribute(data.attr);
  18376. } else {
  18377. target.setAttribute(data.attr, data.oldValue);
  18378. }
  18379. }
  18380. /**
  18381. * 撤销文本内容
  18382. */
  18383. function revokeText(data) {
  18384. data.target.textContent = data.oldValue;
  18385. }
  18386. var revokeFns = {
  18387. node: revokeNode,
  18388. text: revokeText,
  18389. attr: revokeAttr
  18390. }; // 撤销 - 对外暴露的接口
  18391. function revoke(data) {
  18392. for (var i = data.length - 1; i > -1; i--) {
  18393. var item = data[i];
  18394. revokeFns[item.type](item);
  18395. }
  18396. }
  18397. exports.revoke = revoke;
  18398. /* ------------------------------------------------------------------ 恢复逻辑 ------------------------------------------------------------------ */
  18399. function restoreNode(data) {
  18400. for (var _i = 0, _a = (0, _entries["default"])(data.nodes); _i < _a.length; _i++) {
  18401. var _b = _a[_i],
  18402. relative = _b[0],
  18403. list = _b[1];
  18404. switch (relative) {
  18405. case 'add':
  18406. {
  18407. insertNode(data, list);
  18408. break;
  18409. }
  18410. // remove
  18411. default:
  18412. {
  18413. (0, _forEach["default"])(list).call(list, function (item) {
  18414. ;
  18415. item.parentNode.removeChild(item);
  18416. });
  18417. break;
  18418. }
  18419. }
  18420. }
  18421. }
  18422. function restoreText(data) {
  18423. data.target.textContent = data.value;
  18424. }
  18425. function restoreAttr(data) {
  18426. ;
  18427. data.target.setAttribute(data.attr, data.value);
  18428. }
  18429. var restoreFns = {
  18430. node: restoreNode,
  18431. text: restoreText,
  18432. attr: restoreAttr
  18433. }; // 恢复 - 对外暴露的接口
  18434. function restore(data) {
  18435. for (var _i = 0, data_1 = data; _i < data_1.length; _i++) {
  18436. var item = data_1[_i];
  18437. restoreFns[item.type](item);
  18438. }
  18439. }
  18440. exports.restore = restore;
  18441. /***/ }),
  18442. /* 449 */
  18443. /***/ (function(module, exports, __webpack_require__) {
  18444. "use strict";
  18445. var _interopRequireDefault = __webpack_require__(0);
  18446. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18447. (0, _defineProperty["default"])(exports, "__esModule", {
  18448. value: true
  18449. });
  18450. var chain_1 = __webpack_require__(450);
  18451. var HtmlCache = function () {
  18452. function HtmlCache(editor) {
  18453. this.editor = editor;
  18454. this.data = new chain_1.TailChain();
  18455. }
  18456. /**
  18457. * 初始化绑定
  18458. */
  18459. HtmlCache.prototype.observe = function () {
  18460. this.data.resetMax(this.editor.config.historyMaxSize); // 保存初始化值
  18461. this.data.insertLast(this.editor.$textElem.html());
  18462. };
  18463. /**
  18464. * 保存
  18465. */
  18466. HtmlCache.prototype.save = function () {
  18467. this.data.insertLast(this.editor.$textElem.html());
  18468. return this;
  18469. };
  18470. /**
  18471. * 撤销
  18472. */
  18473. HtmlCache.prototype.revoke = function () {
  18474. var data = this.data.prev();
  18475. if (data) {
  18476. this.editor.$textElem.html(data);
  18477. return true;
  18478. }
  18479. return false;
  18480. };
  18481. /**
  18482. * 恢复
  18483. */
  18484. HtmlCache.prototype.restore = function () {
  18485. var data = this.data.next();
  18486. if (data) {
  18487. this.editor.$textElem.html(data);
  18488. return true;
  18489. }
  18490. return false;
  18491. };
  18492. return HtmlCache;
  18493. }();
  18494. exports["default"] = HtmlCache;
  18495. /***/ }),
  18496. /* 450 */
  18497. /***/ (function(module, exports, __webpack_require__) {
  18498. "use strict";
  18499. /**
  18500. * @description 数据结构 - 链表
  18501. * @author fangzhicong
  18502. */
  18503. var _interopRequireDefault = __webpack_require__(0);
  18504. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18505. var _splice = _interopRequireDefault(__webpack_require__(99));
  18506. (0, _defineProperty["default"])(exports, "__esModule", {
  18507. value: true
  18508. });
  18509. exports.TailChain = void 0;
  18510. /**
  18511. * 特殊链表(数据尾插入、插入前自动清理指针后边的数据、插入后指针永远定位于最后一位元素、可限制链表长度、指针双向移动)
  18512. */
  18513. var TailChain = function () {
  18514. function TailChain() {
  18515. /**
  18516. * 链表数据
  18517. */
  18518. this.data = [];
  18519. /**
  18520. * 链表最大长度,零表示长度不限
  18521. */
  18522. this.max = 0;
  18523. /**
  18524. * 指针
  18525. */
  18526. this.point = 0; // 当前指针是否人为操作过
  18527. this.isRe = false;
  18528. }
  18529. /**
  18530. * 允许用户重设一次 max 值
  18531. */
  18532. TailChain.prototype.resetMax = function (maxSize) {
  18533. maxSize = Math.abs(maxSize);
  18534. maxSize && (this.max = maxSize);
  18535. };
  18536. (0, _defineProperty["default"])(TailChain.prototype, "size", {
  18537. /**
  18538. * 当前链表的长度
  18539. */
  18540. get: function get() {
  18541. return this.data.length;
  18542. },
  18543. enumerable: false,
  18544. configurable: true
  18545. });
  18546. /**
  18547. * 尾插入
  18548. * @param data 插入的数据
  18549. */
  18550. TailChain.prototype.insertLast = function (data) {
  18551. // 人为操作过指针,清除指针后面的元素
  18552. if (this.isRe) {
  18553. var _context;
  18554. (0, _splice["default"])(_context = this.data).call(_context, this.point + 1);
  18555. this.isRe = false;
  18556. }
  18557. this.data.push(data); // 超出链表最大长度
  18558. while (this.max && this.size > this.max) {
  18559. this.data.shift();
  18560. } // 从新定位指针到最后一个元素
  18561. this.point = this.size - 1;
  18562. return this;
  18563. };
  18564. /**
  18565. * 获取当前指针元素
  18566. */
  18567. TailChain.prototype.current = function () {
  18568. return this.data[this.point];
  18569. };
  18570. /**
  18571. * 获取上一指针元素
  18572. */
  18573. TailChain.prototype.prev = function () {
  18574. !this.isRe && (this.isRe = true);
  18575. this.point--;
  18576. if (this.point < 0) {
  18577. this.point = 0;
  18578. return undefined;
  18579. }
  18580. return this.current();
  18581. };
  18582. /**
  18583. * 下一指针元素
  18584. */
  18585. TailChain.prototype.next = function () {
  18586. !this.isRe && (this.isRe = true);
  18587. this.point++;
  18588. if (this.point >= this.size) {
  18589. this.point = this.size - 1;
  18590. return undefined;
  18591. }
  18592. return this.current();
  18593. };
  18594. return TailChain;
  18595. }();
  18596. exports.TailChain = TailChain;
  18597. /***/ }),
  18598. /* 451 */
  18599. /***/ (function(module, exports, __webpack_require__) {
  18600. "use strict";
  18601. /**
  18602. * @description 记录 scrollTop
  18603. * @author fangzhicong
  18604. */
  18605. var _interopRequireDefault = __webpack_require__(0);
  18606. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18607. (0, _defineProperty["default"])(exports, "__esModule", {
  18608. value: true
  18609. });
  18610. var tslib_1 = __webpack_require__(2);
  18611. var cache_1 = tslib_1.__importDefault(__webpack_require__(106));
  18612. var ScrollCache = function (_super) {
  18613. tslib_1.__extends(ScrollCache, _super);
  18614. function ScrollCache(editor) {
  18615. var _this = _super.call(this, editor.config.historyMaxSize) || this;
  18616. _this.editor = editor;
  18617. /**
  18618. * 上一次的 scrollTop
  18619. */
  18620. _this.last = 0;
  18621. _this.target = editor.$textElem.elems[0];
  18622. return _this;
  18623. }
  18624. /**
  18625. * 给编辑区容器绑定 scroll 事件
  18626. */
  18627. ScrollCache.prototype.observe = function () {
  18628. var _this = this;
  18629. this.target = this.editor.$textElem.elems[0];
  18630. this.editor.$textElem.on('scroll', function () {
  18631. _this.last = _this.target.scrollTop;
  18632. });
  18633. this.resetMaxSize(this.editor.config.historyMaxSize);
  18634. };
  18635. /**
  18636. * 保存 scrollTop 值
  18637. */
  18638. ScrollCache.prototype.save = function () {
  18639. _super.prototype.save.call(this, [this.last, this.target.scrollTop]);
  18640. return this;
  18641. };
  18642. /**
  18643. * 撤销
  18644. */
  18645. ScrollCache.prototype.revoke = function () {
  18646. var _this = this;
  18647. return _super.prototype.revoke.call(this, function (data) {
  18648. _this.target.scrollTop = data[0];
  18649. });
  18650. };
  18651. /**
  18652. * 恢复
  18653. */
  18654. ScrollCache.prototype.restore = function () {
  18655. var _this = this;
  18656. return _super.prototype.restore.call(this, function (data) {
  18657. _this.target.scrollTop = data[1];
  18658. });
  18659. };
  18660. return ScrollCache;
  18661. }(cache_1["default"]);
  18662. exports["default"] = ScrollCache;
  18663. /***/ }),
  18664. /* 452 */
  18665. /***/ (function(module, exports, __webpack_require__) {
  18666. "use strict";
  18667. /**
  18668. * @description 记录 range 变化
  18669. * @author fangzhicong
  18670. */
  18671. var _interopRequireDefault = __webpack_require__(0);
  18672. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18673. (0, _defineProperty["default"])(exports, "__esModule", {
  18674. value: true
  18675. });
  18676. var tslib_1 = __webpack_require__(2);
  18677. var cache_1 = tslib_1.__importDefault(__webpack_require__(106));
  18678. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  18679. var util_1 = __webpack_require__(6);
  18680. /**
  18681. * 把 Range 对象转换成缓存对象
  18682. * @param range Range 对象
  18683. */
  18684. function rangeToObject(range) {
  18685. return {
  18686. start: [range.startContainer, range.startOffset],
  18687. end: [range.endContainer, range.endOffset],
  18688. root: range.commonAncestorContainer,
  18689. collapsed: range.collapsed
  18690. };
  18691. }
  18692. /**
  18693. * 编辑区 range 缓存管理器
  18694. */
  18695. var RangeCache = function (_super) {
  18696. tslib_1.__extends(RangeCache, _super);
  18697. function RangeCache(editor) {
  18698. var _this = _super.call(this, editor.config.historyMaxSize) || this;
  18699. _this.editor = editor;
  18700. _this.lastRange = rangeToObject(document.createRange());
  18701. _this.root = editor.$textElem.elems[0];
  18702. _this.updateLastRange = util_1.debounce(function () {
  18703. _this.lastRange = rangeToObject(_this.rangeHandle);
  18704. }, editor.config.onchangeTimeout);
  18705. return _this;
  18706. }
  18707. (0, _defineProperty["default"])(RangeCache.prototype, "rangeHandle", {
  18708. /**
  18709. * 获取 Range 对象
  18710. */
  18711. get: function get() {
  18712. var selection = document.getSelection();
  18713. return selection && selection.rangeCount ? selection.getRangeAt(0) : document.createRange();
  18714. },
  18715. enumerable: false,
  18716. configurable: true
  18717. });
  18718. /**
  18719. * 初始化绑定
  18720. */
  18721. RangeCache.prototype.observe = function () {
  18722. var self = this; // 同步节点数据
  18723. this.root = this.editor.$textElem.elems[0];
  18724. this.resetMaxSize(this.editor.config.historyMaxSize); // selection change 回调函数
  18725. function selectionchange() {
  18726. var handle = self.rangeHandle;
  18727. if (self.root === handle.commonAncestorContainer || self.root.contains(handle.commonAncestorContainer)) {
  18728. // 非中文输入状态下才进行记录
  18729. if (!self.editor.isComposing) {
  18730. self.updateLastRange();
  18731. }
  18732. }
  18733. } // backspace 和 delete 手动更新 Range 缓存
  18734. function deletecallback(e) {
  18735. if (e.key == 'Backspace' || e.key == 'Delete') {
  18736. // self.lastRange = rangeToObject(self.rangeHandle)
  18737. self.updateLastRange();
  18738. }
  18739. } // 绑定事件(必须绑定在 document 上,不能绑定在 window 上)
  18740. dom_core_1["default"](document).on('selectionchange', selectionchange); // 解除事件绑定
  18741. this.editor.beforeDestroy(function () {
  18742. dom_core_1["default"](document).off('selectionchange', selectionchange);
  18743. }); // 删除文本时手动更新 range
  18744. self.editor.$textElem.on('keydown', deletecallback);
  18745. };
  18746. /**
  18747. * 保存 Range
  18748. */
  18749. RangeCache.prototype.save = function () {
  18750. var current = rangeToObject(this.rangeHandle);
  18751. _super.prototype.save.call(this, [this.lastRange, current]);
  18752. this.lastRange = current;
  18753. return this;
  18754. };
  18755. /**
  18756. * 设置 Range,在 撤销/恢复 中调用
  18757. * @param range 缓存的 Range 数据
  18758. */
  18759. RangeCache.prototype.set = function (range) {
  18760. try {
  18761. if (range) {
  18762. var handle = this.rangeHandle;
  18763. handle.setStart.apply(handle, range.start);
  18764. handle.setEnd.apply(handle, range.end);
  18765. this.editor.menus.changeActive();
  18766. return true;
  18767. }
  18768. } catch (err) {
  18769. return false;
  18770. }
  18771. return false;
  18772. };
  18773. /**
  18774. * 撤销
  18775. */
  18776. RangeCache.prototype.revoke = function () {
  18777. var _this = this;
  18778. return _super.prototype.revoke.call(this, function (data) {
  18779. _this.set(data[0]);
  18780. });
  18781. };
  18782. /**
  18783. * 恢复
  18784. */
  18785. RangeCache.prototype.restore = function () {
  18786. var _this = this;
  18787. return _super.prototype.restore.call(this, function (data) {
  18788. _this.set(data[1]);
  18789. });
  18790. };
  18791. return RangeCache;
  18792. }(cache_1["default"]);
  18793. exports["default"] = RangeCache;
  18794. /***/ }),
  18795. /* 453 */
  18796. /***/ (function(module, exports, __webpack_require__) {
  18797. "use strict";
  18798. var _interopRequireDefault = __webpack_require__(0);
  18799. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18800. var _find = _interopRequireDefault(__webpack_require__(32));
  18801. (0, _defineProperty["default"])(exports, "__esModule", {
  18802. value: true
  18803. });
  18804. var tslib_1 = __webpack_require__(2);
  18805. var dom_core_1 = tslib_1.__importDefault(__webpack_require__(3));
  18806. __webpack_require__(454);
  18807. function disableInit(editor) {
  18808. var isCurtain = false; // 避免重复生成幕布
  18809. var $contentDom;
  18810. var $menuDom; // 禁用期间,通过 js 修改内容后,刷新内容
  18811. editor.txt.eventHooks.changeEvents.push(function () {
  18812. if (isCurtain) {
  18813. (0, _find["default"])($contentDom).call($contentDom, '.w-e-content-preview').html(editor.$textElem.html());
  18814. }
  18815. }); // 创建幕布
  18816. function disable() {
  18817. if (isCurtain) return; // 隐藏编辑区域
  18818. editor.$textElem.hide(); // 生成div 渲染编辑内容
  18819. var textContainerZindexValue = editor.zIndex.get('textContainer');
  18820. var content = editor.txt.html();
  18821. $contentDom = dom_core_1["default"]("<div class=\"w-e-content-mantle\" style=\"z-index:" + textContainerZindexValue + "\">\n <div class=\"w-e-content-preview w-e-text\">" + content + "</div>\n </div>");
  18822. editor.$textContainerElem.append($contentDom); // 生成div 菜单膜布
  18823. var menuZindexValue = editor.zIndex.get('menu');
  18824. $menuDom = dom_core_1["default"]("<div class=\"w-e-menue-mantle\" style=\"z-index:" + menuZindexValue + "\"></div>");
  18825. editor.$toolbarElem.append($menuDom);
  18826. isCurtain = true;
  18827. editor.isEnable = false;
  18828. } // 销毁幕布并显示可编辑区域
  18829. function enable() {
  18830. if (!isCurtain) return;
  18831. $contentDom.remove();
  18832. $menuDom.remove();
  18833. editor.$textElem.show();
  18834. isCurtain = false;
  18835. editor.isEnable = true;
  18836. }
  18837. return {
  18838. disable: disable,
  18839. enable: enable
  18840. };
  18841. }
  18842. exports["default"] = disableInit;
  18843. /***/ }),
  18844. /* 454 */
  18845. /***/ (function(module, exports, __webpack_require__) {
  18846. var api = __webpack_require__(21);
  18847. var content = __webpack_require__(455);
  18848. content = content.__esModule ? content.default : content;
  18849. if (typeof content === 'string') {
  18850. content = [[module.i, content, '']];
  18851. }
  18852. var options = {};
  18853. options.insert = "head";
  18854. options.singleton = false;
  18855. var update = api(content, options);
  18856. module.exports = content.locals || {};
  18857. /***/ }),
  18858. /* 455 */
  18859. /***/ (function(module, exports, __webpack_require__) {
  18860. // Imports
  18861. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(22);
  18862. exports = ___CSS_LOADER_API_IMPORT___(false);
  18863. // Module
  18864. exports.push([module.i, ".w-e-content-mantle {\n width: 100%;\n height: 100%;\n overflow-y: auto;\n}\n.w-e-content-mantle .w-e-content-preview {\n width: 100%;\n min-height: 100%;\n padding: 0 10px;\n line-height: 1.5;\n}\n.w-e-content-mantle .w-e-content-preview img {\n cursor: default;\n}\n.w-e-content-mantle .w-e-content-preview img:hover {\n box-shadow: none;\n}\n.w-e-menue-mantle {\n position: absolute;\n height: 100%;\n width: 100%;\n top: 0;\n left: 0;\n}\n", ""]);
  18865. // Exports
  18866. module.exports = exports;
  18867. /***/ }),
  18868. /* 456 */
  18869. /***/ (function(module, exports, __webpack_require__) {
  18870. "use strict";
  18871. var _interopRequireDefault = __webpack_require__(0);
  18872. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18873. (0, _defineProperty["default"])(exports, "__esModule", {
  18874. value: true
  18875. });
  18876. var SelectionChange = function () {
  18877. function SelectionChange(editor) {
  18878. var _this = this;
  18879. this.editor = editor; // 绑定的事件
  18880. var init = function init() {
  18881. var activeElement = document.activeElement;
  18882. if (activeElement === editor.$textElem.elems[0]) {
  18883. _this.emit();
  18884. }
  18885. }; // 选取变化事件监听
  18886. window.document.addEventListener('selectionchange', init); // 摧毁时移除监听
  18887. this.editor.beforeDestroy(function () {
  18888. window.document.removeEventListener('selectionchange', init);
  18889. });
  18890. }
  18891. SelectionChange.prototype.emit = function () {
  18892. var _a; // 执行rangeChange函数
  18893. var onSelectionChange = this.editor.config.onSelectionChange;
  18894. if (onSelectionChange) {
  18895. var selection = this.editor.selection;
  18896. selection.saveRange();
  18897. if (!selection.isSelectionEmpty()) onSelectionChange({
  18898. // 当前文本
  18899. text: selection.getSelectionText(),
  18900. // 当前的html
  18901. html: (_a = selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0].innerHTML,
  18902. // select对象
  18903. selection: selection
  18904. });
  18905. }
  18906. };
  18907. return SelectionChange;
  18908. }();
  18909. exports["default"] = SelectionChange;
  18910. /***/ }),
  18911. /* 457 */
  18912. /***/ (function(module, exports, __webpack_require__) {
  18913. "use strict";
  18914. var _interopRequireDefault = __webpack_require__(0);
  18915. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18916. var _assign = _interopRequireDefault(__webpack_require__(132));
  18917. var _entries = _interopRequireDefault(__webpack_require__(102));
  18918. var _forEach = _interopRequireDefault(__webpack_require__(4));
  18919. (0, _defineProperty["default"])(exports, "__esModule", {
  18920. value: true
  18921. });
  18922. exports.registerPlugin = void 0;
  18923. var tslib_1 = __webpack_require__(2);
  18924. var editor_1 = tslib_1.__importDefault(__webpack_require__(94));
  18925. var util_1 = __webpack_require__(6);
  18926. /**
  18927. * 插件注册
  18928. * @param { string } name 插件名
  18929. * @param { RegisterOptions } options 插件配置
  18930. * @param { pluginsListType } memory 存储介质
  18931. */
  18932. function registerPlugin(name, options, memory) {
  18933. if (!name) {
  18934. throw new TypeError('name is not define');
  18935. }
  18936. if (!options) {
  18937. throw new TypeError('options is not define');
  18938. }
  18939. if (!options.intention) {
  18940. throw new TypeError('options.intention is not define');
  18941. }
  18942. if (options.intention && typeof options.intention !== 'function') {
  18943. throw new TypeError('options.intention is not function');
  18944. }
  18945. if (memory[name]) {
  18946. console.warn("plugin " + name + " \u5DF2\u5B58\u5728\uFF0C\u5DF2\u8986\u76D6\u3002");
  18947. }
  18948. memory[name] = options;
  18949. }
  18950. exports.registerPlugin = registerPlugin;
  18951. /**
  18952. * 插件初始化
  18953. * @param { Editor } editor 编辑器实例
  18954. */
  18955. function initPlugins(editor) {
  18956. var plugins = (0, _assign["default"])({}, util_1.deepClone(editor_1["default"].globalPluginsFunctionList), util_1.deepClone(editor.pluginsFunctionList));
  18957. var values = (0, _entries["default"])(plugins);
  18958. (0, _forEach["default"])(values).call(values, function (_a) {
  18959. var name = _a[0],
  18960. options = _a[1];
  18961. console.info("plugin " + name + " initializing");
  18962. var intention = options.intention,
  18963. config = options.config;
  18964. intention(editor, config);
  18965. console.info("plugin " + name + " initialization complete");
  18966. });
  18967. }
  18968. exports["default"] = initPlugins;
  18969. /***/ }),
  18970. /* 458 */
  18971. /***/ (function(module, exports, __webpack_require__) {
  18972. "use strict";
  18973. var _interopRequireDefault = __webpack_require__(0);
  18974. var _defineProperty = _interopRequireDefault(__webpack_require__(1));
  18975. (0, _defineProperty["default"])(exports, "__esModule", {
  18976. value: true
  18977. });
  18978. /***/ })
  18979. /******/ ])["default"];
  18980. });
  18981. //# sourceMappingURL=wangEditor.js.map