| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206142071420814209142101421114212142131421414215142161421714218142191422014221142221422314224142251422614227142281422914230142311423214233142341423514236142371423814239142401424114242142431424414245142461424714248142491425014251142521425314254142551425614257142581425914260142611426214263142641426514266142671426814269142701427114272142731427414275142761427714278142791428014281142821428314284142851428614287142881428914290142911429214293142941429514296142971429814299143001430114302143031430414305143061430714308143091431014311143121431314314143151431614317143181431914320143211432214323143241432514326143271432814329143301433114332143331433414335143361433714338143391434014341143421434314344143451434614347143481434914350143511435214353143541435514356143571435814359143601436114362143631436414365143661436714368143691437014371143721437314374143751437614377143781437914380143811438214383143841438514386143871438814389143901439114392143931439414395143961439714398143991440014401144021440314404144051440614407144081440914410144111441214413144141441514416144171441814419144201442114422144231442414425144261442714428144291443014431144321443314434144351443614437144381443914440144411444214443144441444514446144471444814449144501445114452144531445414455144561445714458144591446014461144621446314464144651446614467144681446914470144711447214473144741447514476144771447814479144801448114482144831448414485144861448714488144891449014491144921449314494144951449614497144981449914500145011450214503145041450514506145071450814509145101451114512145131451414515145161451714518145191452014521145221452314524145251452614527145281452914530145311453214533145341453514536145371453814539145401454114542145431454414545145461454714548145491455014551145521455314554145551455614557145581455914560145611456214563145641456514566145671456814569145701457114572145731457414575145761457714578145791458014581145821458314584145851458614587145881458914590145911459214593145941459514596145971459814599146001460114602146031460414605146061460714608146091461014611146121461314614146151461614617146181461914620146211462214623146241462514626146271462814629146301463114632146331463414635146361463714638146391464014641146421464314644146451464614647146481464914650146511465214653146541465514656146571465814659146601466114662146631466414665146661466714668146691467014671146721467314674146751467614677146781467914680146811468214683146841468514686146871468814689146901469114692146931469414695146961469714698146991470014701147021470314704147051470614707147081470914710147111471214713147141471514716147171471814719147201472114722147231472414725147261472714728147291473014731147321473314734147351473614737147381473914740147411474214743147441474514746147471474814749147501475114752147531475414755147561475714758147591476014761147621476314764147651476614767147681476914770147711477214773147741477514776147771477814779147801478114782147831478414785147861478714788147891479014791147921479314794147951479614797147981479914800148011480214803148041480514806148071480814809148101481114812148131481414815148161481714818148191482014821148221482314824148251482614827148281482914830148311483214833148341483514836148371483814839148401484114842148431484414845148461484714848148491485014851148521485314854148551485614857148581485914860148611486214863148641486514866148671486814869148701487114872148731487414875148761487714878148791488014881148821488314884148851488614887148881488914890148911489214893148941489514896148971489814899149001490114902149031490414905149061490714908149091491014911149121491314914149151491614917149181491914920149211492214923149241492514926149271492814929149301493114932149331493414935149361493714938149391494014941149421494314944149451494614947149481494914950149511495214953149541495514956149571495814959149601496114962149631496414965149661496714968149691497014971149721497314974149751497614977149781497914980149811498214983149841498514986149871498814989149901499114992149931499414995149961499714998149991500015001150021500315004150051500615007150081500915010150111501215013150141501515016150171501815019150201502115022150231502415025150261502715028150291503015031150321503315034150351503615037150381503915040150411504215043150441504515046150471504815049150501505115052150531505415055150561505715058150591506015061150621506315064150651506615067150681506915070150711507215073150741507515076150771507815079150801508115082150831508415085150861508715088150891509015091150921509315094150951509615097150981509915100151011510215103151041510515106151071510815109151101511115112151131511415115151161511715118151191512015121151221512315124151251512615127151281512915130151311513215133151341513515136151371513815139151401514115142151431514415145151461514715148151491515015151151521515315154151551515615157151581515915160151611516215163151641516515166151671516815169151701517115172151731517415175151761517715178151791518015181151821518315184151851518615187151881518915190151911519215193151941519515196151971519815199152001520115202152031520415205152061520715208152091521015211152121521315214152151521615217152181521915220152211522215223152241522515226152271522815229152301523115232152331523415235152361523715238152391524015241152421524315244152451524615247152481524915250152511525215253152541525515256152571525815259152601526115262152631526415265152661526715268152691527015271152721527315274152751527615277152781527915280152811528215283152841528515286152871528815289152901529115292152931529415295152961529715298152991530015301153021530315304153051530615307153081530915310153111531215313153141531515316153171531815319153201532115322153231532415325153261532715328153291533015331153321533315334153351533615337153381533915340153411534215343153441534515346153471534815349153501535115352153531535415355153561535715358153591536015361153621536315364153651536615367153681536915370153711537215373153741537515376153771537815379153801538115382153831538415385153861538715388153891539015391153921539315394153951539615397153981539915400154011540215403154041540515406154071540815409154101541115412154131541415415154161541715418154191542015421154221542315424154251542615427154281542915430154311543215433154341543515436154371543815439154401544115442154431544415445154461544715448154491545015451154521545315454154551545615457154581545915460154611546215463154641546515466154671546815469154701547115472154731547415475154761547715478154791548015481154821548315484154851548615487154881548915490154911549215493154941549515496154971549815499155001550115502155031550415505155061550715508155091551015511155121551315514155151551615517155181551915520155211552215523155241552515526155271552815529155301553115532155331553415535155361553715538155391554015541155421554315544155451554615547155481554915550155511555215553155541555515556155571555815559155601556115562155631556415565155661556715568155691557015571155721557315574155751557615577155781557915580155811558215583155841558515586155871558815589155901559115592155931559415595155961559715598155991560015601156021560315604156051560615607156081560915610156111561215613156141561515616156171561815619156201562115622156231562415625156261562715628156291563015631156321563315634156351563615637156381563915640156411564215643156441564515646156471564815649156501565115652156531565415655156561565715658156591566015661156621566315664156651566615667156681566915670156711567215673156741567515676156771567815679156801568115682156831568415685156861568715688156891569015691156921569315694156951569615697156981569915700157011570215703157041570515706157071570815709157101571115712157131571415715157161571715718157191572015721157221572315724157251572615727157281572915730157311573215733157341573515736157371573815739157401574115742157431574415745157461574715748157491575015751157521575315754157551575615757157581575915760157611576215763157641576515766157671576815769157701577115772157731577415775157761577715778157791578015781157821578315784157851578615787157881578915790157911579215793157941579515796157971579815799158001580115802158031580415805158061580715808158091581015811158121581315814158151581615817158181581915820158211582215823158241582515826158271582815829158301583115832158331583415835158361583715838158391584015841158421584315844158451584615847158481584915850158511585215853158541585515856158571585815859158601586115862158631586415865158661586715868158691587015871158721587315874158751587615877158781587915880158811588215883158841588515886158871588815889158901589115892158931589415895158961589715898158991590015901159021590315904159051590615907159081590915910159111591215913159141591515916159171591815919159201592115922159231592415925159261592715928159291593015931159321593315934159351593615937159381593915940159411594215943159441594515946159471594815949159501595115952159531595415955159561595715958159591596015961159621596315964159651596615967159681596915970159711597215973159741597515976159771597815979159801598115982159831598415985159861598715988159891599015991159921599315994159951599615997159981599916000160011600216003160041600516006160071600816009160101601116012160131601416015160161601716018160191602016021160221602316024160251602616027160281602916030160311603216033160341603516036160371603816039160401604116042160431604416045160461604716048160491605016051160521605316054160551605616057160581605916060160611606216063160641606516066160671606816069160701607116072160731607416075160761607716078160791608016081160821608316084160851608616087160881608916090160911609216093160941609516096160971609816099161001610116102161031610416105161061610716108161091611016111161121611316114161151611616117161181611916120161211612216123161241612516126161271612816129161301613116132161331613416135161361613716138161391614016141161421614316144161451614616147161481614916150161511615216153161541615516156161571615816159161601616116162161631616416165161661616716168161691617016171161721617316174161751617616177161781617916180161811618216183161841618516186161871618816189161901619116192161931619416195161961619716198161991620016201162021620316204162051620616207162081620916210162111621216213162141621516216162171621816219162201622116222162231622416225162261622716228162291623016231162321623316234162351623616237162381623916240162411624216243162441624516246162471624816249162501625116252162531625416255162561625716258162591626016261162621626316264162651626616267162681626916270162711627216273162741627516276162771627816279162801628116282162831628416285162861628716288162891629016291162921629316294162951629616297162981629916300163011630216303163041630516306163071630816309163101631116312163131631416315163161631716318163191632016321163221632316324163251632616327163281632916330163311633216333163341633516336163371633816339163401634116342163431634416345163461634716348163491635016351163521635316354163551635616357163581635916360163611636216363163641636516366163671636816369163701637116372163731637416375163761637716378163791638016381163821638316384163851638616387163881638916390163911639216393163941639516396163971639816399164001640116402164031640416405164061640716408164091641016411164121641316414164151641616417164181641916420164211642216423164241642516426164271642816429164301643116432164331643416435164361643716438164391644016441164421644316444164451644616447164481644916450164511645216453164541645516456164571645816459164601646116462164631646416465164661646716468164691647016471164721647316474164751647616477164781647916480164811648216483164841648516486164871648816489164901649116492164931649416495164961649716498164991650016501165021650316504165051650616507165081650916510165111651216513165141651516516165171651816519165201652116522165231652416525165261652716528165291653016531165321653316534165351653616537165381653916540165411654216543165441654516546165471654816549165501655116552165531655416555165561655716558165591656016561165621656316564165651656616567165681656916570165711657216573165741657516576165771657816579165801658116582165831658416585165861658716588165891659016591165921659316594165951659616597165981659916600166011660216603166041660516606166071660816609166101661116612166131661416615166161661716618166191662016621166221662316624166251662616627166281662916630166311663216633166341663516636166371663816639166401664116642166431664416645166461664716648166491665016651166521665316654166551665616657166581665916660166611666216663166641666516666166671666816669166701667116672166731667416675166761667716678166791668016681166821668316684166851668616687166881668916690166911669216693166941669516696166971669816699167001670116702167031670416705167061670716708167091671016711167121671316714167151671616717167181671916720167211672216723167241672516726167271672816729167301673116732167331673416735167361673716738167391674016741167421674316744167451674616747167481674916750167511675216753167541675516756167571675816759167601676116762167631676416765167661676716768167691677016771167721677316774167751677616777167781677916780167811678216783167841678516786167871678816789167901679116792167931679416795167961679716798167991680016801168021680316804168051680616807168081680916810168111681216813168141681516816168171681816819168201682116822168231682416825168261682716828168291683016831168321683316834168351683616837168381683916840168411684216843168441684516846168471684816849168501685116852168531685416855168561685716858168591686016861168621686316864168651686616867168681686916870168711687216873168741687516876168771687816879168801688116882168831688416885168861688716888168891689016891168921689316894168951689616897168981689916900169011690216903169041690516906169071690816909169101691116912169131691416915169161691716918169191692016921169221692316924169251692616927169281692916930169311693216933169341693516936169371693816939169401694116942169431694416945169461694716948169491695016951169521695316954169551695616957169581695916960169611696216963169641696516966169671696816969169701697116972169731697416975169761697716978169791698016981169821698316984169851698616987169881698916990169911699216993169941699516996169971699816999170001700117002170031700417005170061700717008170091701017011170121701317014170151701617017170181701917020170211702217023170241702517026170271702817029170301703117032170331703417035170361703717038170391704017041170421704317044170451704617047170481704917050170511705217053170541705517056170571705817059170601706117062170631706417065170661706717068170691707017071170721707317074170751707617077170781707917080170811708217083170841708517086170871708817089170901709117092170931709417095170961709717098170991710017101171021710317104171051710617107171081710917110171111711217113171141711517116171171711817119171201712117122171231712417125171261712717128171291713017131171321713317134171351713617137171381713917140171411714217143171441714517146171471714817149171501715117152171531715417155171561715717158171591716017161171621716317164171651716617167171681716917170171711717217173171741717517176171771717817179171801718117182171831718417185171861718717188171891719017191171921719317194171951719617197171981719917200172011720217203172041720517206172071720817209172101721117212172131721417215172161721717218172191722017221172221722317224172251722617227172281722917230172311723217233172341723517236172371723817239172401724117242172431724417245172461724717248172491725017251172521725317254172551725617257172581725917260172611726217263172641726517266172671726817269172701727117272172731727417275172761727717278172791728017281172821728317284172851728617287172881728917290172911729217293172941729517296172971729817299173001730117302173031730417305173061730717308173091731017311173121731317314173151731617317173181731917320173211732217323173241732517326173271732817329173301733117332173331733417335173361733717338173391734017341173421734317344173451734617347173481734917350173511735217353173541735517356173571735817359173601736117362173631736417365173661736717368173691737017371173721737317374173751737617377173781737917380173811738217383173841738517386173871738817389173901739117392173931739417395173961739717398173991740017401174021740317404174051740617407174081740917410174111741217413174141741517416174171741817419174201742117422174231742417425174261742717428174291743017431174321743317434174351743617437174381743917440174411744217443174441744517446174471744817449174501745117452174531745417455174561745717458174591746017461174621746317464174651746617467174681746917470174711747217473174741747517476174771747817479174801748117482174831748417485174861748717488174891749017491174921749317494174951749617497174981749917500175011750217503175041750517506175071750817509175101751117512175131751417515175161751717518175191752017521175221752317524175251752617527175281752917530175311753217533175341753517536175371753817539175401754117542175431754417545175461754717548175491755017551175521755317554175551755617557175581755917560175611756217563175641756517566175671756817569175701757117572175731757417575175761757717578175791758017581175821758317584175851758617587175881758917590175911759217593175941759517596175971759817599176001760117602176031760417605176061760717608176091761017611176121761317614176151761617617176181761917620176211762217623176241762517626176271762817629176301763117632176331763417635176361763717638176391764017641176421764317644176451764617647176481764917650176511765217653176541765517656176571765817659176601766117662176631766417665176661766717668176691767017671176721767317674176751767617677176781767917680176811768217683176841768517686176871768817689176901769117692176931769417695176961769717698176991770017701177021770317704177051770617707177081770917710177111771217713177141771517716177171771817719177201772117722177231772417725177261772717728177291773017731177321773317734177351773617737177381773917740177411774217743177441774517746177471774817749177501775117752177531775417755177561775717758177591776017761177621776317764177651776617767177681776917770177711777217773177741777517776177771777817779177801778117782177831778417785177861778717788177891779017791177921779317794177951779617797177981779917800178011780217803178041780517806178071780817809178101781117812178131781417815178161781717818178191782017821178221782317824178251782617827178281782917830178311783217833178341783517836178371783817839178401784117842178431784417845178461784717848178491785017851178521785317854178551785617857178581785917860178611786217863178641786517866178671786817869178701787117872178731787417875178761787717878178791788017881178821788317884178851788617887178881788917890178911789217893178941789517896178971789817899179001790117902179031790417905179061790717908179091791017911179121791317914179151791617917179181791917920179211792217923179241792517926179271792817929179301793117932179331793417935179361793717938179391794017941179421794317944179451794617947179481794917950179511795217953179541795517956179571795817959179601796117962179631796417965179661796717968179691797017971179721797317974179751797617977179781797917980179811798217983179841798517986179871798817989179901799117992179931799417995179961799717998179991800018001180021800318004180051800618007180081800918010180111801218013180141801518016180171801818019180201802118022180231802418025180261802718028180291803018031180321803318034180351803618037180381803918040180411804218043180441804518046180471804818049180501805118052180531805418055180561805718058180591806018061180621806318064180651806618067180681806918070180711807218073180741807518076180771807818079180801808118082180831808418085180861808718088180891809018091180921809318094180951809618097180981809918100181011810218103181041810518106181071810818109181101811118112181131811418115181161811718118181191812018121181221812318124181251812618127181281812918130181311813218133181341813518136181371813818139181401814118142181431814418145181461814718148181491815018151181521815318154181551815618157181581815918160181611816218163181641816518166181671816818169181701817118172181731817418175181761817718178181791818018181181821818318184181851818618187181881818918190181911819218193181941819518196181971819818199182001820118202182031820418205182061820718208182091821018211182121821318214182151821618217182181821918220182211822218223182241822518226182271822818229182301823118232182331823418235182361823718238182391824018241182421824318244182451824618247182481824918250182511825218253182541825518256182571825818259182601826118262182631826418265182661826718268182691827018271182721827318274182751827618277182781827918280182811828218283182841828518286182871828818289182901829118292182931829418295182961829718298182991830018301183021830318304183051830618307183081830918310183111831218313183141831518316183171831818319183201832118322183231832418325183261832718328183291833018331183321833318334183351833618337183381833918340183411834218343183441834518346183471834818349183501835118352183531835418355183561835718358183591836018361183621836318364183651836618367183681836918370183711837218373183741837518376183771837818379183801838118382183831838418385183861838718388183891839018391183921839318394183951839618397183981839918400184011840218403184041840518406184071840818409184101841118412184131841418415184161841718418184191842018421184221842318424184251842618427184281842918430184311843218433184341843518436184371843818439184401844118442184431844418445184461844718448184491845018451184521845318454184551845618457184581845918460184611846218463184641846518466184671846818469184701847118472184731847418475184761847718478184791848018481184821848318484184851848618487184881848918490184911849218493184941849518496184971849818499185001850118502185031850418505185061850718508185091851018511185121851318514185151851618517185181851918520185211852218523185241852518526185271852818529185301853118532185331853418535185361853718538185391854018541185421854318544185451854618547185481854918550185511855218553185541855518556185571855818559185601856118562185631856418565185661856718568185691857018571185721857318574185751857618577185781857918580185811858218583185841858518586185871858818589185901859118592185931859418595185961859718598185991860018601186021860318604186051860618607186081860918610186111861218613186141861518616186171861818619186201862118622186231862418625186261862718628186291863018631186321863318634186351863618637186381863918640186411864218643186441864518646186471864818649186501865118652186531865418655186561865718658186591866018661186621866318664186651866618667186681866918670186711867218673186741867518676186771867818679186801868118682186831868418685186861868718688186891869018691186921869318694186951869618697186981869918700187011870218703187041870518706187071870818709187101871118712187131871418715187161871718718187191872018721187221872318724187251872618727187281872918730187311873218733187341873518736187371873818739187401874118742187431874418745187461874718748187491875018751187521875318754187551875618757187581875918760187611876218763187641876518766187671876818769187701877118772187731877418775187761877718778187791878018781187821878318784187851878618787187881878918790187911879218793187941879518796187971879818799188001880118802188031880418805188061880718808188091881018811188121881318814188151881618817188181881918820188211882218823188241882518826188271882818829188301883118832188331883418835188361883718838188391884018841188421884318844188451884618847188481884918850188511885218853188541885518856188571885818859188601886118862188631886418865188661886718868188691887018871188721887318874188751887618877188781887918880188811888218883188841888518886188871888818889188901889118892188931889418895188961889718898188991890018901189021890318904189051890618907189081890918910189111891218913189141891518916189171891818919189201892118922189231892418925189261892718928189291893018931189321893318934189351893618937189381893918940189411894218943189441894518946189471894818949189501895118952189531895418955189561895718958189591896018961189621896318964189651896618967189681896918970189711897218973189741897518976189771897818979189801898118982189831898418985189861898718988189891899018991189921899318994189951899618997189981899919000190011900219003190041900519006190071900819009190101901119012190131901419015190161901719018190191902019021190221902319024190251902619027190281902919030190311903219033190341903519036190371903819039190401904119042190431904419045190461904719048190491905019051190521905319054190551905619057190581905919060190611906219063190641906519066190671906819069190701907119072190731907419075190761907719078190791908019081190821908319084190851908619087190881908919090190911909219093190941909519096190971909819099191001910119102191031910419105191061910719108191091911019111191121911319114191151911619117191181911919120191211912219123191241912519126191271912819129191301913119132191331913419135191361913719138191391914019141191421914319144191451914619147191481914919150191511915219153191541915519156191571915819159191601916119162191631916419165191661916719168191691917019171191721917319174191751917619177191781917919180191811918219183191841918519186191871918819189191901919119192191931919419195191961919719198191991920019201192021920319204192051920619207192081920919210192111921219213192141921519216192171921819219192201922119222192231922419225192261922719228192291923019231192321923319234192351923619237192381923919240192411924219243192441924519246192471924819249192501925119252192531925419255192561925719258192591926019261192621926319264192651926619267192681926919270192711927219273192741927519276192771927819279192801928119282192831928419285192861928719288192891929019291192921929319294192951929619297192981929919300193011930219303193041930519306193071930819309193101931119312193131931419315193161931719318193191932019321193221932319324193251932619327193281932919330193311933219333193341933519336193371933819339193401934119342193431934419345193461934719348193491935019351193521935319354193551935619357193581935919360193611936219363193641936519366193671936819369193701937119372193731937419375193761937719378193791938019381193821938319384193851938619387193881938919390193911939219393193941939519396193971939819399194001940119402194031940419405194061940719408194091941019411194121941319414194151941619417194181941919420194211942219423194241942519426194271942819429194301943119432194331943419435194361943719438194391944019441194421944319444194451944619447194481944919450194511945219453194541945519456194571945819459194601946119462194631946419465194661946719468194691947019471194721947319474194751947619477194781947919480194811948219483194841948519486194871948819489194901949119492194931949419495194961949719498194991950019501195021950319504195051950619507195081950919510195111951219513195141951519516195171951819519195201952119522195231952419525195261952719528195291953019531195321953319534195351953619537195381953919540195411954219543195441954519546195471954819549195501955119552195531955419555195561955719558195591956019561195621956319564195651956619567195681956919570195711957219573195741957519576195771957819579195801958119582195831958419585195861958719588195891959019591195921959319594195951959619597195981959919600196011960219603196041960519606196071960819609196101961119612196131961419615196161961719618196191962019621196221962319624196251962619627196281962919630196311963219633196341963519636196371963819639196401964119642196431964419645196461964719648196491965019651196521965319654196551965619657196581965919660196611966219663196641966519666196671966819669196701967119672196731967419675196761967719678196791968019681196821968319684196851968619687196881968919690196911969219693196941969519696196971969819699197001970119702197031970419705197061970719708197091971019711197121971319714197151971619717197181971919720197211972219723197241972519726197271972819729197301973119732197331973419735197361973719738197391974019741197421974319744197451974619747197481974919750197511975219753197541975519756197571975819759197601976119762197631976419765197661976719768197691977019771197721977319774197751977619777197781977919780197811978219783197841978519786197871978819789197901979119792197931979419795197961979719798197991980019801198021980319804198051980619807198081980919810198111981219813198141981519816198171981819819198201982119822198231982419825198261982719828198291983019831198321983319834198351983619837198381983919840198411984219843198441984519846198471984819849198501985119852198531985419855198561985719858198591986019861198621986319864198651986619867198681986919870198711987219873198741987519876198771987819879198801988119882198831988419885198861988719888198891989019891198921989319894198951989619897198981989919900199011990219903199041990519906199071990819909199101991119912199131991419915199161991719918199191992019921199221992319924199251992619927199281992919930199311993219933199341993519936199371993819939199401994119942199431994419945199461994719948199491995019951199521995319954199551995619957199581995919960199611996219963199641996519966199671996819969199701997119972199731997419975199761997719978199791998019981199821998319984199851998619987199881998919990199911999219993199941999519996199971999819999200002000120002200032000420005200062000720008200092001020011200122001320014200152001620017200182001920020200212002220023200242002520026200272002820029200302003120032200332003420035200362003720038200392004020041200422004320044200452004620047200482004920050200512005220053200542005520056200572005820059200602006120062200632006420065200662006720068200692007020071200722007320074200752007620077200782007920080200812008220083200842008520086200872008820089200902009120092200932009420095200962009720098200992010020101201022010320104201052010620107201082010920110201112011220113201142011520116201172011820119201202012120122201232012420125201262012720128201292013020131201322013320134201352013620137201382013920140201412014220143201442014520146201472014820149201502015120152201532015420155201562015720158201592016020161201622016320164201652016620167201682016920170201712017220173201742017520176201772017820179201802018120182201832018420185201862018720188201892019020191201922019320194201952019620197201982019920200202012020220203202042020520206202072020820209202102021120212202132021420215202162021720218202192022020221202222022320224202252022620227202282022920230202312023220233202342023520236202372023820239202402024120242202432024420245202462024720248202492025020251202522025320254202552025620257202582025920260202612026220263202642026520266202672026820269202702027120272202732027420275202762027720278202792028020281202822028320284202852028620287202882028920290202912029220293202942029520296202972029820299203002030120302203032030420305203062030720308203092031020311203122031320314203152031620317203182031920320203212032220323203242032520326203272032820329203302033120332203332033420335203362033720338203392034020341203422034320344203452034620347203482034920350203512035220353203542035520356203572035820359203602036120362203632036420365203662036720368203692037020371203722037320374203752037620377203782037920380203812038220383203842038520386203872038820389203902039120392203932039420395203962039720398203992040020401204022040320404204052040620407204082040920410204112041220413204142041520416204172041820419204202042120422204232042420425204262042720428204292043020431204322043320434204352043620437204382043920440204412044220443204442044520446204472044820449204502045120452204532045420455204562045720458204592046020461204622046320464204652046620467204682046920470204712047220473204742047520476204772047820479204802048120482204832048420485204862048720488204892049020491204922049320494204952049620497204982049920500205012050220503205042050520506205072050820509205102051120512205132051420515205162051720518205192052020521205222052320524205252052620527205282052920530205312053220533205342053520536205372053820539205402054120542205432054420545205462054720548205492055020551205522055320554205552055620557205582055920560205612056220563205642056520566205672056820569205702057120572205732057420575205762057720578205792058020581205822058320584205852058620587205882058920590205912059220593205942059520596205972059820599206002060120602206032060420605206062060720608206092061020611206122061320614206152061620617206182061920620206212062220623206242062520626206272062820629206302063120632206332063420635206362063720638206392064020641206422064320644206452064620647206482064920650206512065220653206542065520656206572065820659206602066120662206632066420665206662066720668206692067020671206722067320674206752067620677206782067920680206812068220683206842068520686206872068820689206902069120692206932069420695206962069720698206992070020701207022070320704207052070620707207082070920710207112071220713207142071520716207172071820719207202072120722207232072420725207262072720728207292073020731207322073320734207352073620737207382073920740207412074220743207442074520746207472074820749207502075120752207532075420755207562075720758207592076020761207622076320764207652076620767207682076920770207712077220773207742077520776207772077820779207802078120782207832078420785207862078720788207892079020791207922079320794207952079620797207982079920800208012080220803208042080520806208072080820809208102081120812208132081420815208162081720818208192082020821208222082320824208252082620827208282082920830208312083220833208342083520836208372083820839208402084120842208432084420845208462084720848208492085020851208522085320854208552085620857208582085920860208612086220863208642086520866208672086820869208702087120872208732087420875208762087720878208792088020881208822088320884208852088620887208882088920890208912089220893208942089520896208972089820899209002090120902209032090420905209062090720908209092091020911209122091320914209152091620917209182091920920209212092220923209242092520926209272092820929209302093120932209332093420935209362093720938209392094020941209422094320944209452094620947209482094920950209512095220953209542095520956209572095820959209602096120962209632096420965209662096720968209692097020971209722097320974209752097620977209782097920980209812098220983209842098520986209872098820989209902099120992209932099420995209962099720998209992100021001210022100321004210052100621007210082100921010210112101221013210142101521016210172101821019210202102121022210232102421025210262102721028210292103021031210322103321034210352103621037210382103921040210412104221043210442104521046210472104821049210502105121052210532105421055210562105721058210592106021061210622106321064210652106621067210682106921070210712107221073210742107521076210772107821079210802108121082210832108421085210862108721088210892109021091210922109321094210952109621097210982109921100211012110221103211042110521106211072110821109211102111121112211132111421115211162111721118211192112021121211222112321124211252112621127211282112921130211312113221133211342113521136211372113821139211402114121142211432114421145211462114721148211492115021151211522115321154211552115621157211582115921160211612116221163211642116521166211672116821169211702117121172211732117421175211762117721178211792118021181211822118321184211852118621187211882118921190211912119221193211942119521196211972119821199212002120121202212032120421205212062120721208212092121021211212122121321214212152121621217212182121921220212212122221223212242122521226212272122821229212302123121232212332123421235212362123721238212392124021241212422124321244212452124621247212482124921250212512125221253212542125521256212572125821259212602126121262212632126421265212662126721268212692127021271212722127321274212752127621277212782127921280212812128221283212842128521286212872128821289212902129121292212932129421295212962129721298212992130021301213022130321304213052130621307213082130921310213112131221313213142131521316213172131821319213202132121322213232132421325213262132721328213292133021331213322133321334213352133621337213382133921340213412134221343213442134521346213472134821349213502135121352213532135421355213562135721358213592136021361213622136321364213652136621367213682136921370213712137221373213742137521376213772137821379213802138121382213832138421385213862138721388213892139021391213922139321394213952139621397213982139921400214012140221403214042140521406214072140821409214102141121412214132141421415214162141721418214192142021421214222142321424214252142621427214282142921430214312143221433214342143521436214372143821439214402144121442214432144421445214462144721448214492145021451214522145321454214552145621457214582145921460214612146221463214642146521466214672146821469214702147121472214732147421475214762147721478214792148021481214822148321484214852148621487214882148921490214912149221493214942149521496214972149821499215002150121502215032150421505215062150721508215092151021511215122151321514215152151621517215182151921520215212152221523215242152521526215272152821529215302153121532215332153421535215362153721538215392154021541215422154321544215452154621547215482154921550215512155221553215542155521556215572155821559215602156121562215632156421565215662156721568215692157021571215722157321574215752157621577215782157921580215812158221583215842158521586215872158821589215902159121592215932159421595215962159721598215992160021601216022160321604216052160621607216082160921610216112161221613216142161521616216172161821619216202162121622216232162421625216262162721628216292163021631216322163321634216352163621637216382163921640216412164221643216442164521646216472164821649216502165121652216532165421655216562165721658216592166021661216622166321664216652166621667216682166921670216712167221673216742167521676216772167821679216802168121682216832168421685216862168721688216892169021691216922169321694216952169621697216982169921700217012170221703217042170521706217072170821709217102171121712217132171421715217162171721718217192172021721217222172321724217252172621727217282172921730217312173221733217342173521736217372173821739217402174121742217432174421745217462174721748217492175021751217522175321754217552175621757217582175921760217612176221763217642176521766217672176821769217702177121772217732177421775217762177721778217792178021781217822178321784217852178621787217882178921790217912179221793217942179521796217972179821799218002180121802218032180421805218062180721808218092181021811218122181321814218152181621817218182181921820218212182221823218242182521826218272182821829218302183121832218332183421835218362183721838218392184021841218422184321844218452184621847218482184921850218512185221853218542185521856218572185821859218602186121862218632186421865218662186721868218692187021871218722187321874218752187621877218782187921880218812188221883218842188521886218872188821889218902189121892218932189421895218962189721898218992190021901219022190321904219052190621907219082190921910219112191221913219142191521916219172191821919219202192121922219232192421925219262192721928219292193021931219322193321934219352193621937219382193921940219412194221943219442194521946219472194821949219502195121952219532195421955219562195721958219592196021961219622196321964219652196621967219682196921970219712197221973219742197521976219772197821979219802198121982219832198421985219862198721988219892199021991219922199321994219952199621997219982199922000220012200222003220042200522006220072200822009220102201122012220132201422015220162201722018220192202022021220222202322024220252202622027220282202922030220312203222033220342203522036220372203822039220402204122042220432204422045220462204722048220492205022051220522205322054220552205622057220582205922060220612206222063220642206522066220672206822069220702207122072220732207422075220762207722078220792208022081220822208322084220852208622087220882208922090220912209222093220942209522096220972209822099221002210122102221032210422105221062210722108221092211022111221122211322114221152211622117221182211922120221212212222123221242212522126221272212822129221302213122132221332213422135221362213722138221392214022141221422214322144221452214622147221482214922150221512215222153221542215522156221572215822159221602216122162221632216422165221662216722168221692217022171221722217322174221752217622177221782217922180221812218222183221842218522186221872218822189221902219122192221932219422195221962219722198221992220022201222022220322204222052220622207222082220922210222112221222213222142221522216222172221822219222202222122222222232222422225222262222722228222292223022231222322223322234222352223622237222382223922240222412224222243222442224522246222472224822249222502225122252222532225422255222562225722258222592226022261222622226322264222652226622267222682226922270222712227222273222742227522276222772227822279222802228122282222832228422285222862228722288222892229022291222922229322294222952229622297222982229922300223012230222303223042230522306223072230822309223102231122312223132231422315223162231722318223192232022321223222232322324223252232622327223282232922330223312233222333223342233522336223372233822339223402234122342223432234422345223462234722348223492235022351223522235322354223552235622357223582235922360223612236222363223642236522366223672236822369223702237122372223732237422375223762237722378223792238022381223822238322384223852238622387223882238922390223912239222393223942239522396223972239822399224002240122402224032240422405224062240722408224092241022411224122241322414224152241622417224182241922420224212242222423224242242522426224272242822429224302243122432224332243422435224362243722438224392244022441224422244322444224452244622447224482244922450224512245222453224542245522456224572245822459224602246122462224632246422465224662246722468224692247022471224722247322474224752247622477224782247922480224812248222483224842248522486224872248822489224902249122492224932249422495224962249722498224992250022501225022250322504225052250622507225082250922510225112251222513225142251522516225172251822519225202252122522225232252422525225262252722528225292253022531225322253322534225352253622537225382253922540225412254222543225442254522546225472254822549225502255122552225532255422555225562255722558225592256022561 |
- (function webpackUniversalModuleDefinition(root, factory) {
- if(typeof exports === 'object' && typeof module === 'object')
- module.exports = factory();
- else if(typeof define === 'function' && define.amd)
- define([], factory);
- else if(typeof exports === 'object')
- exports["wangEditor"] = factory();
- else
- root["wangEditor"] = factory();
- })(window, function() {
- return /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 129);
- /******/ })
- /************************************************************************/
- /******/ ([
- /* 0 */
- /***/ (function(module, exports) {
- function _interopRequireDefault(obj) {
- return obj && obj.__esModule ? obj : {
- "default": obj
- };
- }
- module.exports = _interopRequireDefault;
- /***/ }),
- /* 1 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(130);
- /***/ }),
- /* 2 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 封装 DOM 操作
- * @wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _bind = _interopRequireDefault(__webpack_require__(88));
- var _includes = _interopRequireDefault(__webpack_require__(89));
- var _filter = _interopRequireDefault(__webpack_require__(65));
- var _splice = _interopRequireDefault(__webpack_require__(90));
- var _indexOf = _interopRequireDefault(__webpack_require__(54));
- var _map = _interopRequireDefault(__webpack_require__(114));
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _map2 = _interopRequireDefault(__webpack_require__(29));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _isArray = _interopRequireDefault(__webpack_require__(93));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __spreadArrays = void 0 && (void 0).__spreadArrays || function () {
- for (var s = 0, i = 0, il = arguments.length; i < il; i++) {
- s += arguments[i].length;
- }
- for (var r = Array(s), k = 0, i = 0; i < il; i++) {
- for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) {
- r[k] = a[j];
- }
- }
- return r;
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.DomElement = void 0;
- var util_1 = __webpack_require__(7);
- var AGENT_EVENTS = [];
- /**
- * 根据 html 字符串创建 elem
- * @param {String} html html
- */
- function _createElemByHTML(html) {
- var div = document.createElement('div');
- div.innerHTML = html;
- var elems = div.children;
- return util_1.toArray(elems);
- }
- /**
- * 判断是否是 DOM List
- * @param selector DOM 元素或列表
- */
- function _isDOMList(selector) {
- if (!selector) {
- return false;
- }
- if (selector instanceof HTMLCollection || selector instanceof NodeList) {
- return true;
- }
- return false;
- }
- /**
- * 封装 querySelectorAll
- * @param selector css 选择器
- */
- function _querySelectorAll(selector) {
- var elems = document.querySelectorAll(selector);
- return util_1.toArray(elems);
- }
- /**
- * 封装 _styleArrTrim
- * @param styleArr css
- */
- function _styleArrTrim(style) {
- var styleArr = [];
- var resultArr = [];
- if (!(0, _isArray["default"])(style)) {
- // 有 style,将 style 按照 `;` 拆分为数组
- styleArr = style.split(';');
- } else {
- styleArr = style;
- }
- (0, _forEach["default"])(styleArr).call(styleArr, function (item) {
- var _context;
- // 对每项样式,按照 : 拆分为 key 和 value
- var arr = (0, _map2["default"])(_context = item.split(':')).call(_context, function (i) {
- return (0, _trim["default"])(i).call(i);
- });
- if (arr.length === 2) {
- resultArr.push(arr[0] + ':' + arr[1]);
- }
- });
- return resultArr;
- } // 构造函数
- var DomElement =
- /** @class */
- function () {
- /**
- * 构造函数
- * @param selector 任一类型的选择器
- */
- function DomElement(selector) {
- // 初始化属性
- this.elems = [];
- this.length = this.elems.length;
- this.dataSource = new _map["default"]();
- if (!selector) {
- return;
- } // 原本就是 DomElement 实例,则直接返回
- if (selector instanceof DomElement) {
- return selector;
- }
- var selectorResult = []; // 存储查询结果
- var nodeType = selector instanceof Node ? selector.nodeType : -1;
- this.selector = selector;
- if (nodeType === 1 || nodeType === 9) {
- selectorResult = [selector];
- } else if (_isDOMList(selector)) {
- // DOM List
- selectorResult = util_1.toArray(selector);
- } else if (selector instanceof Array) {
- // Element 数组(其他数据类型,暂时忽略)
- selectorResult = selector;
- } else if (typeof selector === 'string') {
- var _context2;
- // 字符串
- var tmpSelector = (0, _trim["default"])(_context2 = selector.replace('/\n/mg', '')).call(_context2);
- if ((0, _indexOf["default"])(tmpSelector).call(tmpSelector, '<') === 0) {
- // 如 <div>
- selectorResult = _createElemByHTML(tmpSelector);
- } else {
- // 如 #id .class
- selectorResult = _querySelectorAll(tmpSelector);
- }
- }
- var length = selectorResult.length;
- if (!length) {
- // 空数组
- return this;
- } // 加入 DOM 节点
- var i = 0;
- for (; i < length; i++) {
- this.elems.push(selectorResult[i]);
- }
- this.length = length;
- }
- (0, _defineProperty["default"])(DomElement.prototype, "id", {
- /**
- * 获取元素 id
- */
- get: function get() {
- return this.elems[0].id;
- },
- enumerable: false,
- configurable: true
- });
- /**
- * 遍历所有元素,执行回调函数
- * @param fn 回调函数
- */
- DomElement.prototype.forEach = function (fn) {
- for (var i = 0; i < this.length; i++) {
- var elem = this.elems[i];
- var result = fn.call(elem, elem, i);
- if (result === false) {
- break;
- }
- }
- return this;
- };
- /**
- * 克隆元素
- * @param deep 是否深度克隆
- */
- DomElement.prototype.clone = function (deep) {
- var _context3;
- if (deep === void 0) {
- deep = false;
- }
- var cloneList = [];
- (0, _forEach["default"])(_context3 = this.elems).call(_context3, function (elem) {
- cloneList.push(elem.cloneNode(!!deep));
- });
- return $(cloneList);
- };
- /**
- * 获取第几个元素
- * @param index index
- */
- DomElement.prototype.get = function (index) {
- if (index === void 0) {
- index = 0;
- }
- var length = this.length;
- if (index >= length) {
- index = index % length;
- }
- return $(this.elems[index]);
- };
-
- /**
- * 获取第一个元素
- */
- DomElement.prototype.first = function () {
- return this.get(0);
- };
- /**
- * 获取最后一个元素
- */
- DomElement.prototype.last = function () {
- var length = this.length;
- return this.get(length - 1);
- };
- DomElement.prototype.on = function (type, selector, fn) {
- var _context4;
- if (!type) return this; // 没有 selector ,只有 type 和 fn
- if (typeof selector === 'function') {
- fn = selector;
- selector = '';
- }
- return (0, _forEach["default"])(_context4 = this).call(_context4, function (elem) {
- // 没有事件代理
- if (!selector) {
- // 无代理
- elem.addEventListener(type, fn);
- return;
- } // 有事件代理
- var agentFn = function agentFn(e) {
- var target = e.target;
- if (target.matches(selector)) {
- ;
- fn.call(target, e);
- }
- };
- elem.addEventListener(type, agentFn); // 缓存代理事件
- AGENT_EVENTS.push({
- elem: elem,
- selector: selector,
- fn: fn,
- agentFn: agentFn
- });
- });
- };
- DomElement.prototype.off = function (type, selector, fn) {
- var _context5;
- if (!type) return this; // 没有 selector ,只有 type 和 fn
- if (typeof selector === 'function') {
- fn = selector;
- selector = '';
- }
- return (0, _forEach["default"])(_context5 = this).call(_context5, function (elem) {
- // 解绑事件代理
- if (selector) {
- var idx = -1;
- for (var i = 0; i < AGENT_EVENTS.length; i++) {
- var item = AGENT_EVENTS[i];
- if (item.selector === selector && item.fn === fn && item.elem === elem) {
- idx = i;
- break;
- }
- }
- if (idx !== -1) {
- var agentFn = (0, _splice["default"])(AGENT_EVENTS).call(AGENT_EVENTS, idx, 1)[0].agentFn;
- elem.removeEventListener(type, agentFn);
- }
- } else {
- // @ts-ignore
- elem.removeEventListener(type, fn);
- }
- });
- };
- DomElement.prototype.attr = function (key, val) {
- var _context6;
- if (val == null) {
- // 获取数据
- return this.elems[0].getAttribute(key) || '';
- } // 否则,设置属性
- return (0, _forEach["default"])(_context6 = this).call(_context6, function (elem) {
- elem.setAttribute(key, val);
- });
- };
- /**
- * 删除 属性
- * @param key key
- */
- DomElement.prototype.removeAttr = function (key) {
- var _context7;
- (0, _forEach["default"])(_context7 = this).call(_context7, function (elem) {
- elem.removeAttribute(key);
- });
- };
- /**
- * 添加 css class
- * @param className css class
- */
- DomElement.prototype.addClass = function (className) {
- var _context8;
- if (!className) {
- return this;
- }
- return (0, _forEach["default"])(_context8 = this).call(_context8, function (elem) {
- if (elem.className) {
- // 当前有 class
- var arr = elem.className.split(/\s/);
- arr = (0, _filter["default"])(arr).call(arr, function (item) {
- return !!(0, _trim["default"])(item).call(item);
- }); // 添加 class
- if ((0, _indexOf["default"])(arr).call(arr, className) < 0) {
- arr.push(className);
- } // 修改 elem.class
- elem.className = arr.join(' ');
- } else {
- // 当前没有 class
- elem.className = className;
- }
- });
- };
- /**
- * 添加 css class
- * @param className css class
- */
- DomElement.prototype.removeClass = function (className) {
- var _context9;
- if (!className) {
- return this;
- }
- return (0, _forEach["default"])(_context9 = this).call(_context9, function (elem) {
- if (!elem.className) {
- // 当前无 class
- return;
- }
- var arr = elem.className.split(/\s/);
- arr = (0, _filter["default"])(arr).call(arr, function (item) {
- item = (0, _trim["default"])(item).call(item); // 删除 class
- if (!item || item === className) {
- return false;
- }
- return true;
- }); // 修改 elem.class
- elem.className = arr.join(' ');
- });
- };
- /**
- * 是否有传入的 css class
- * @param className css class
- */
- DomElement.prototype.hasClass = function (className) {
- if (!className) {
- return false;
- }
- var elem = this.elems[0];
- if (!elem.className) {
- // 当前无 class
- return false;
- }
- var arr = elem.className.split(/\s/);
- return (0, _includes["default"])(arr).call(arr, className); // 是否包含
- };
- /**
- * 修改 css
- * @param key css key
- * @param val css value
- */
- // css(key: string): string
- DomElement.prototype.css = function (key, val) {
- var _context10;
- var currentStyle;
- if (val == '') {
- currentStyle = '';
- } else {
- currentStyle = key + ":" + val + ";";
- }
- return (0, _forEach["default"])(_context10 = this).call(_context10, function (elem) {
- var _context11;
- var style = (0, _trim["default"])(_context11 = elem.getAttribute('style') || '').call(_context11);
- if (style) {
- // 有 style,将 style 按照 `;` 拆分为数组
- var resultArr = _styleArrTrim(style); // 替换现有的 style
- resultArr = (0, _map2["default"])(resultArr).call(resultArr, function (item) {
- if ((0, _indexOf["default"])(item).call(item, key) === 0) {
- return currentStyle;
- } else {
- return item;
- }
- }); // 新增 style
- if (currentStyle != '' && (0, _indexOf["default"])(resultArr).call(resultArr, currentStyle) < 0) {
- resultArr.push(currentStyle);
- } // 去掉 空白
- if (currentStyle == '') {
- resultArr = _styleArrTrim(resultArr);
- } // 重新设置 style
- elem.setAttribute('style', resultArr.join('; '));
- } else {
- // 当前没有 style
- elem.setAttribute('style', currentStyle);
- }
- });
- };
- /**
- * 封装 getBoundingClientRect
- */
- DomElement.prototype.getBoundingClientRect = function () {
- var elem = this.elems[0];
- return elem.getBoundingClientRect();
- };
- /**
- * 显示
- */
- DomElement.prototype.show = function () {
- return this.css('display', 'block');
- };
- /**
- * 隐藏
- */
- DomElement.prototype.hide = function () {
- return this.css('display', 'none');
- };
- /**
- * 获取子节点(只有 DOM 元素)
- */
- DomElement.prototype.children = function () {
- var elem = this.elems[0];
- if (!elem) {
- return null;
- }
- return $(elem.children);
- };
- /**
- * 获取子节点(包括文本节点)
- */
- DomElement.prototype.childNodes = function () {
- var elem = this.elems[0];
- if (!elem) {
- return null;
- }
- return $(elem.childNodes);
- };
- /**
- * 将子元素全部替换
- * @param $children 新的child节点
- */
- DomElement.prototype.replaceChildAll = function ($children) {
- var parent = this.getNode();
- var elem = this.elems[0];
- while (elem.hasChildNodes()) {
- parent.firstChild && elem.removeChild(parent.firstChild);
- }
- this.append($children);
- };
- /**
- * 增加子节点
- * @param $children 子节点
- */
- DomElement.prototype.append = function ($children) {
- var _context12;
- return (0, _forEach["default"])(_context12 = this).call(_context12, function (elem) {
- (0, _forEach["default"])($children).call($children, function (child) {
- elem.appendChild(child);
- });
- });
- };
- /**
- * 移除当前节点
- */
- DomElement.prototype.remove = function () {
- var _context13;
- return (0, _forEach["default"])(_context13 = this).call(_context13, function (elem) {
- if (elem.remove) {
- elem.remove();
- } else {
- var parent_1 = elem.parentElement;
- parent_1 && parent_1.removeChild(elem);
- }
- });
- };
- /**
- * 当前元素,是否包含某个子元素
- * @param $child 子元素
- */
- DomElement.prototype.isContain = function ($child) {
- var elem = this.elems[0];
- var child = $child.elems[0];
- return elem.contains(child);
- };
- /**
- * 获取当前元素的尺寸和位置信息
- */
- DomElement.prototype.getSizeData = function () {
- var elem = this.elems[0]; // 可得到 bottom height left right top width 的数据
- return elem.getBoundingClientRect();
- };
- /**
- * 获取当前元素 nodeName
- */
- DomElement.prototype.getNodeName = function () {
- var elem = this.elems[0];
- return elem.nodeName;
- };
- /**
- * 根据元素位置获取元素节点(默认获取0位置的节点)
- * @param n 元素节点位置
- */
- DomElement.prototype.getNode = function (n) {
- if (n === void 0) {
- n = 0;
- }
- var elem;
- elem = this.elems[n];
- return elem;
- };
- /**
- * 获取当前元素可视高度
- */
- DomElement.prototype.getClientHeight = function () {
- var elem = this.elems[0];
- return elem.clientHeight;
- };
- /**
- * 获取当前元素可视宽度
- */
- // getClientWidth(): number {
- // const elem = this.elems[0]
- // return elem.clientWidth
- // }
- /**
- * 查询
- * @param selector css 选择器
- */
- DomElement.prototype.find = function (selector) {
- var elem = this.elems[0];
- return $(elem.querySelectorAll(selector));
- };
- DomElement.prototype.text = function (val) {
- if (!val) {
- // 获取 text
- var elem = this.elems[0];
- return elem.innerHTML.replace(/<[^>]+>/g, function () {
- return '';
- });
- } else {
- var _context14;
- // 设置 text
- return (0, _forEach["default"])(_context14 = this).call(_context14, function (elem) {
- elem.innerHTML = val;
- });
- }
- };
- DomElement.prototype.html = function (val) {
- var elem = this.elems[0];
- if (!val) {
- // 获取 html
- return elem.innerHTML;
- } else {
- // 设置 html
- elem.innerHTML = val;
- return this;
- }
- };
- /**
- * 获取元素 value
- */
- DomElement.prototype.val = function () {
- var _context15;
- var elem = this.elems[0];
- return (0, _trim["default"])(_context15 = elem.value).call(_context15); // 暂用 any
- };
- /**
- * focus 到当前元素
- */
- DomElement.prototype.focus = function () {
- var _context16;
- return (0, _forEach["default"])(_context16 = this).call(_context16, function (elem) {
- elem.focus();
- });
- };
- /**
- * 当前元素前一个兄弟节点
- */
- DomElement.prototype.prev = function () {
- var elem = this.elems[0];
- return $(elem.previousElementSibling);
- };
- /**
- * 当前元素后一个兄弟节点
- */
- DomElement.prototype.next = function () {
- var elem = this.elems[0];
- return $(elem.nextElementSibling);
- };
- /**
- * 获取父元素
- */
- DomElement.prototype.parent = function () {
- var elem = this.elems[0];
- return $(elem.parentElement);
- };
- /**
- * 查找父元素,直到满足 selector 条件
- * @param selector css 选择器
- * @param curElem 从哪个元素开始查找,默认为当前元素
- */
- DomElement.prototype.parentUntil = function (selector, curElem) {
- var elem = curElem || this.elems[0];
- if (elem.nodeName === 'BODY') {
- return null;
- }
- var parent = elem.parentElement;
- if (parent === null) {
- return null;
- }
- if (parent.matches(selector)) {
- // 找到,并返回
- return $(parent);
- } // 继续查找,递归
- return this.parentUntil(selector, parent);
- };
- /**
- * 查找父元素,直到满足 selector 条件,或者 到达 编辑区域容器以及菜单栏容器
- * @param selector css 选择器
- * @param curElem 从哪个元素开始查找,默认为当前元素
- */
- DomElement.prototype.parentUntilEditor = function (selector, editor, curElem) {
- var elem = curElem || this.elems[0];
- if ($(elem).equal(editor.$textContainerElem) || $(elem).equal(editor.$toolbarElem)) {
- return null;
- }
- var parent = elem.parentElement;
- if (parent === null) {
- return null;
- }
- if (parent.matches(selector)) {
- // 找到,并返回
- return $(parent);
- } // 继续查找,递归
- return this.parentUntilEditor(selector, editor, parent);
- };
- /**
- * 判读是否相等
- * @param $elem 元素
- */
- DomElement.prototype.equal = function ($elem) {
- if ($elem instanceof DomElement) {
- return this.elems[0] === $elem.elems[0];
- } else if ($elem instanceof HTMLElement) {
- return this.elems[0] === $elem;
- } else {
- return false;
- }
- };
- /**
- * 将该元素插入到某个元素前面
- * @param selector css 选择器
- */
- DomElement.prototype.insertBefore = function (selector) {
- var _context17;
- var $referenceNode = $(selector);
- var referenceNode = $referenceNode.elems[0];
- if (!referenceNode) {
- return this;
- }
- return (0, _forEach["default"])(_context17 = this).call(_context17, function (elem) {
- var parent = referenceNode.parentNode;
- parent.insertBefore(elem, referenceNode);
- });
- };
- /**
- * 将该元素插入到selector元素后面
- * @param selector css 选择器
- */
- DomElement.prototype.insertAfter = function (selector) {
- var _context18;
- var $referenceNode = $(selector);
- var referenceNode = $referenceNode.elems[0];
- var anchorNode = referenceNode && referenceNode.nextSibling;
- if (!referenceNode) {
- return this;
- }
- return (0, _forEach["default"])(_context18 = this).call(_context18, function (elem) {
- var parent = referenceNode.parentNode;
- if (anchorNode) {
- parent.insertBefore(elem, anchorNode);
- } else {
- parent.appendChild(elem);
- }
- });
- };
- /**
- * 设置/获取 数据
- * @param key key
- * @param value value
- */
- DomElement.prototype.data = function (key, value) {
- if (value != null) {
- // 设置数据
- this.dataSource.set(key, value);
- } else {
- // 获取数据
- return this.dataSource.get(key);
- }
- };
- /**
- * 获取当前节点的顶级(段落)
- * @param editor 富文本实例
- */
- DomElement.prototype.getNodeTop = function (editor) {
- if (this.length < 1) {
- return this;
- }
- var $parent = this.parent();
- if (editor.$textElem.equal($parent)) {
- return this;
- }
- return $parent.getNodeTop(editor);
- };
- /**
- * 获取当前 节点 基与上一个拥有相对或者解决定位的父容器的位置
- * @param editor 富文本实例
- */
- DomElement.prototype.getOffsetData = function () {
- var $node = this.elems[0];
- return {
- top: $node.offsetTop,
- left: $node.offsetLeft,
- width: $node.offsetWidth,
- height: $node.offsetHeight,
- parent: $node.offsetParent
- };
- };
- /**
- * 从上至下进行滚动
- * @param top 滚动的值
- */
- DomElement.prototype.scrollTop = function (top) {
- var $node = this.elems[0];
- $node.scrollTo({
- top: top
- });
- };
- return DomElement;
- }();
- exports.DomElement = DomElement; // new 一个对象
- function $() {
- var arg = [];
- for (var _i = 0; _i < arguments.length; _i++) {
- arg[_i] = arguments[_i];
- }
- return new ((0, _bind["default"])(DomElement).apply(DomElement, __spreadArrays([void 0], arg)))();
- }
- exports["default"] = $;
- /***/ }),
- /* 3 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(134);
- /***/ }),
- /* 4 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var global = __webpack_require__(8);
- var getOwnPropertyDescriptor = __webpack_require__(67).f;
- var isForced = __webpack_require__(101);
- var path = __webpack_require__(10);
- var bind = __webpack_require__(47);
- var createNonEnumerableProperty = __webpack_require__(17);
- var has = __webpack_require__(15);
- var wrapConstructor = function (NativeConstructor) {
- var Wrapper = function (a, b, c) {
- if (this instanceof NativeConstructor) {
- switch (arguments.length) {
- case 0: return new NativeConstructor();
- case 1: return new NativeConstructor(a);
- case 2: return new NativeConstructor(a, b);
- } return new NativeConstructor(a, b, c);
- } return NativeConstructor.apply(this, arguments);
- };
- Wrapper.prototype = NativeConstructor.prototype;
- return Wrapper;
- };
- /*
- options.target - name of the target object
- options.global - target is the global object
- options.stat - export as static methods of target
- options.proto - export as prototype methods of target
- options.real - real prototype method for the `pure` version
- options.forced - export even if the native feature is available
- options.bind - bind methods to the target, required for the `pure` version
- options.wrap - wrap constructors to preventing global pollution, required for the `pure` version
- options.unsafe - use the simple assignment of property instead of delete + defineProperty
- options.sham - add a flag to not completely full polyfills
- options.enumerable - export as enumerable property
- options.noTargetGet - prevent calling a getter on target
- */
- module.exports = function (options, source) {
- var TARGET = options.target;
- var GLOBAL = options.global;
- var STATIC = options.stat;
- var PROTO = options.proto;
- var nativeSource = GLOBAL ? global : STATIC ? global[TARGET] : (global[TARGET] || {}).prototype;
- var target = GLOBAL ? path : path[TARGET] || (path[TARGET] = {});
- var targetPrototype = target.prototype;
- var FORCED, USE_NATIVE, VIRTUAL_PROTOTYPE;
- var key, sourceProperty, targetProperty, nativeProperty, resultProperty, descriptor;
- for (key in source) {
- FORCED = isForced(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);
- // contains in native
- USE_NATIVE = !FORCED && nativeSource && has(nativeSource, key);
- targetProperty = target[key];
- if (USE_NATIVE) if (options.noTargetGet) {
- descriptor = getOwnPropertyDescriptor(nativeSource, key);
- nativeProperty = descriptor && descriptor.value;
- } else nativeProperty = nativeSource[key];
- // export native or implementation
- sourceProperty = (USE_NATIVE && nativeProperty) ? nativeProperty : source[key];
- if (USE_NATIVE && typeof targetProperty === typeof sourceProperty) continue;
- // bind timers to global for call from export context
- if (options.bind && USE_NATIVE) resultProperty = bind(sourceProperty, global);
- // wrap global constructors for prevent changs in this version
- else if (options.wrap && USE_NATIVE) resultProperty = wrapConstructor(sourceProperty);
- // make static versions for prototype methods
- else if (PROTO && typeof sourceProperty == 'function') resultProperty = bind(Function.call, sourceProperty);
- // default case
- else resultProperty = sourceProperty;
- // add a flag to not completely full polyfills
- if (options.sham || (sourceProperty && sourceProperty.sham) || (targetProperty && targetProperty.sham)) {
- createNonEnumerableProperty(resultProperty, 'sham', true);
- }
- target[key] = resultProperty;
- if (PROTO) {
- VIRTUAL_PROTOTYPE = TARGET + 'Prototype';
- if (!has(path, VIRTUAL_PROTOTYPE)) {
- createNonEnumerableProperty(path, VIRTUAL_PROTOTYPE, {});
- }
- // export virtual prototype methods
- path[VIRTUAL_PROTOTYPE][key] = sourceProperty;
- // export real prototype methods
- if (options.real && targetPrototype && !targetPrototype[key]) {
- createNonEnumerableProperty(targetPrototype, key, sourceProperty);
- }
- }
- }
- };
- /***/ }),
- /* 5 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(177);
- /***/ }),
- /* 6 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(305);
- /***/ }),
- /* 7 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 工具函数集合
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _map = _interopRequireDefault(__webpack_require__(29));
- var _isArray = _interopRequireDefault(__webpack_require__(93));
- var _typeof2 = _interopRequireDefault(__webpack_require__(94));
- var _setTimeout2 = _interopRequireDefault(__webpack_require__(121));
- var _slice = _interopRequireDefault(__webpack_require__(43));
- var _parseInt2 = _interopRequireDefault(__webpack_require__(260));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __spreadArrays = void 0 && (void 0).__spreadArrays || function () {
- for (var s = 0, i = 0, il = arguments.length; i < il; i++) {
- s += arguments[i].length;
- }
- for (var r = Array(s), k = 0, i = 0; i < il; i++) {
- for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) {
- r[k] = a[j];
- }
- }
- return r;
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- 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;
- var NavUA =
- /** @class */
- function () {
- function NavUA() {
- this._ua = navigator.userAgent;
- var math = this._ua.match(/(Edge?)\/(\d+)/);
- this.isOldEdge = math && math[1] == 'Edge' && (0, _parseInt2["default"])(math[2]) < 19 ? true : false;
- this.isFirefox = /Firefox\/\d+/.test(this._ua) && !/Seamonkey\/\d+/.test(this._ua) ? true : false;
- } // 是否为 IE
- NavUA.prototype.isIE = function () {
- return 'ActiveXObject' in window;
- }; // 是否为 webkit
- NavUA.prototype.isWebkit = function () {
- return /webkit/i.test(this._ua);
- };
- return NavUA;
- }(); // 和 UA 相关的属性
- exports.UA = new NavUA();
- /**
- * 获取随机字符
- * @param prefix 前缀
- */
- function getRandom(prefix) {
- var _context;
- if (prefix === void 0) {
- prefix = '';
- }
- return prefix + (0, _slice["default"])(_context = Math.random().toString()).call(_context, 2);
- }
- exports.getRandom = getRandom;
- /**
- * 替换 html 特殊字符
- * @param html html 字符串
- */
- function replaceHtmlSymbol(html) {
- return html.replace(/</gm, '<').replace(/>/gm, '>').replace(/"/gm, '"').replace(/(\r\n|\r|\n)/g, '<br/>');
- }
- exports.replaceHtmlSymbol = replaceHtmlSymbol;
- function replaceSpecialSymbol(value) {
- return value.replace(/</gm, '<').replace(/>/gm, '>').replace(/"/gm, '"');
- }
- exports.replaceSpecialSymbol = replaceSpecialSymbol;
- function forEach(obj, fn) {
- for (var key in obj) {
- if (Object.prototype.hasOwnProperty.call(obj, key)) {
- var result = fn(key, obj[key]);
- if (result === false) {
- // 提前终止循环
- break;
- }
- }
- }
- }
- exports.forEach = forEach;
- /**
- * 遍历类数组
- * @param fakeArr 类数组
- * @param fn 回调函数
- */
- function arrForEach(fakeArr, fn) {
- var i, item, result;
- var length = fakeArr.length || 0;
- for (i = 0; i < length; i++) {
- item = fakeArr[i];
- result = fn.call(fakeArr, item, i);
- if (result === false) {
- break;
- }
- }
- }
- exports.arrForEach = arrForEach;
- /**
- * 节流
- * @param fn 函数
- * @param interval 间隔时间,毫秒
- */
- function throttle(fn, interval) {
- if (interval === void 0) {
- interval = 200;
- }
- var flag = false;
- return function () {
- var _this = this;
- var args = [];
- for (var _i = 0; _i < arguments.length; _i++) {
- args[_i] = arguments[_i];
- }
- if (!flag) {
- flag = true;
- (0, _setTimeout2["default"])(function () {
- flag = false;
- fn.call.apply(fn, __spreadArrays([_this], args)); // this 报语法错误,先用 null
- }, interval);
- }
- };
- }
- exports.throttle = throttle;
- /**
- * 防抖
- * @param fn 函数
- * @param delay 间隔时间,毫秒
- */
- function debounce(fn, delay) {
- if (delay === void 0) {
- delay = 200;
- }
- var lastFn = 0;
- return function () {
- var _this = this;
- var args = [];
- for (var _i = 0; _i < arguments.length; _i++) {
- args[_i] = arguments[_i];
- }
- if (lastFn) {
- window.clearTimeout(lastFn);
- }
- lastFn = window.setTimeout(function () {
- lastFn = 0;
- fn.call.apply(fn, __spreadArrays([_this], args)); // this 报语法错误,先用 null
- }, delay);
- };
- }
- exports.debounce = debounce;
- /**
- * isFunction 是否是函数
- * @param fn 函数
- */
- function isFunction(fn) {
- return typeof fn === 'function';
- }
- exports.isFunction = isFunction;
- /**
- * 引用与非引用值 深拷贝方法
- * @param data
- */
- function deepClone(data) {
- if ((0, _typeof2["default"])(data) !== 'object' || typeof data == 'function' || data === null) {
- return data;
- }
- var item;
- if ((0, _isArray["default"])(data)) {
- item = [];
- }
- if (!(0, _isArray["default"])(data)) {
- item = {};
- }
- for (var i in data) {
- if (Object.prototype.hasOwnProperty.call(data, i)) {
- item[i] = deepClone(data[i]);
- }
- }
- return item;
- }
- exports.deepClone = deepClone;
- /**
- * 将可遍历的对象转换为数组
- * @param data 可遍历的对象
- */
- function toArray(data) {
- return (0, _slice["default"])(Array.prototype).call(data);
- }
- exports.toArray = toArray;
- /**
- * 唯一id生成
- * @param length 随机数长度
- */
- function getRandomCode() {
- var _context2;
- return (0, _slice["default"])(_context2 = Math.random().toString(36)).call(_context2, -5);
- }
- exports.getRandomCode = getRandomCode;
- /**
- * hex color 转换成 rgb
- * @param hex string
- */
- function hexToRgb(hex) {
- var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
- if (result == null) return null;
- var colors = (0, _map["default"])(result).call(result, function (i) {
- return (0, _parseInt2["default"])(i, 16);
- });
- var r = colors[1];
- var g = colors[2];
- var b = colors[3];
- return "rgb(" + r + ", " + g + ", " + b + ")";
- }
- exports.hexToRgb = hexToRgb;
- /***/ }),
- /* 8 */
- /***/ (function(module, exports, __webpack_require__) {
- /* WEBPACK VAR INJECTION */(function(global) {var check = function (it) {
- return it && it.Math == Math && it;
- };
- // https://github.com/zloirock/core-js/issues/86#issuecomment-115759028
- module.exports =
- // eslint-disable-next-line no-undef
- check(typeof globalThis == 'object' && globalThis) ||
- check(typeof window == 'object' && window) ||
- check(typeof self == 'object' && self) ||
- check(typeof global == 'object' && global) ||
- // eslint-disable-next-line no-new-func
- (function () { return this; })() || Function('return this')();
- /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(133)))
- /***/ }),
- /* 9 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var shared = __webpack_require__(73);
- var has = __webpack_require__(15);
- var uid = __webpack_require__(60);
- var NATIVE_SYMBOL = __webpack_require__(77);
- var USE_SYMBOL_AS_UID = __webpack_require__(104);
- var WellKnownSymbolsStore = shared('wks');
- var Symbol = global.Symbol;
- var createWellKnownSymbol = USE_SYMBOL_AS_UID ? Symbol : Symbol && Symbol.withoutSetter || uid;
- module.exports = function (name) {
- if (!has(WellKnownSymbolsStore, name)) {
- if (NATIVE_SYMBOL && has(Symbol, name)) WellKnownSymbolsStore[name] = Symbol[name];
- else WellKnownSymbolsStore[name] = createWellKnownSymbol('Symbol.' + name);
- } return WellKnownSymbolsStore[name];
- };
- /***/ }),
- /* 10 */
- /***/ (function(module, exports) {
- module.exports = {};
- /***/ }),
- /* 11 */
- /***/ (function(module, exports, __webpack_require__) {
- var path = __webpack_require__(10);
- var has = __webpack_require__(15);
- var wrappedWellKnownSymbolModule = __webpack_require__(95);
- var defineProperty = __webpack_require__(18).f;
- module.exports = function (NAME) {
- var Symbol = path.Symbol || (path.Symbol = {});
- if (!has(Symbol, NAME)) defineProperty(Symbol, NAME, {
- value: wrappedWellKnownSymbolModule.f(NAME)
- });
- };
- /***/ }),
- /* 12 */
- /***/ (function(module, exports) {
- module.exports = function (exec) {
- try {
- return !!exec();
- } catch (error) {
- return true;
- }
- };
- /***/ }),
- /* 13 */
- /***/ (function(module, exports) {
- module.exports = function (it) {
- return typeof it === 'object' ? it !== null : typeof it === 'function';
- };
- /***/ }),
- /* 14 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- // Thank's IE8 for his funny defineProperty
- module.exports = !fails(function () {
- return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] != 7;
- });
- /***/ }),
- /* 15 */
- /***/ (function(module, exports) {
- var hasOwnProperty = {}.hasOwnProperty;
- module.exports = function (it, key) {
- return hasOwnProperty.call(it, key);
- };
- /***/ }),
- /* 16 */
- /***/ (function(module, exports, __webpack_require__) {
- var path = __webpack_require__(10);
- module.exports = function (CONSTRUCTOR) {
- return path[CONSTRUCTOR + 'Prototype'];
- };
- /***/ }),
- /* 17 */
- /***/ (function(module, exports, __webpack_require__) {
- var DESCRIPTORS = __webpack_require__(14);
- var definePropertyModule = __webpack_require__(18);
- var createPropertyDescriptor = __webpack_require__(35);
- module.exports = DESCRIPTORS ? function (object, key, value) {
- return definePropertyModule.f(object, key, createPropertyDescriptor(1, value));
- } : function (object, key, value) {
- object[key] = value;
- return object;
- };
- /***/ }),
- /* 18 */
- /***/ (function(module, exports, __webpack_require__) {
- var DESCRIPTORS = __webpack_require__(14);
- var IE8_DOM_DEFINE = __webpack_require__(100);
- var anObject = __webpack_require__(24);
- var toPrimitive = __webpack_require__(56);
- var nativeDefineProperty = Object.defineProperty;
- // `Object.defineProperty` method
- // https://tc39.github.io/ecma262/#sec-object.defineproperty
- exports.f = DESCRIPTORS ? nativeDefineProperty : function defineProperty(O, P, Attributes) {
- anObject(O);
- P = toPrimitive(P, true);
- anObject(Attributes);
- if (IE8_DOM_DEFINE) try {
- return nativeDefineProperty(O, P, Attributes);
- } catch (error) { /* empty */ }
- if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported');
- if ('value' in Attributes) O[P] = Attributes.value;
- return O;
- };
- /***/ }),
- /* 19 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(212);
- /***/ }),
- /* 20 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var isOldIE = function isOldIE() {
- var memo;
- return function memorize() {
- if (typeof memo === 'undefined') {
- // Test for IE <= 9 as proposed by Browserhacks
- // @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805
- // Tests for existence of standard globals is to allow style-loader
- // to operate correctly into non-standard environments
- // @see https://github.com/webpack-contrib/style-loader/issues/177
- memo = Boolean(window && document && document.all && !window.atob);
- }
- return memo;
- };
- }();
- var getTarget = function getTarget() {
- var memo = {};
- return function memorize(target) {
- if (typeof memo[target] === 'undefined') {
- var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself
- if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {
- try {
- // This will throw an exception if access to iframe is blocked
- // due to cross-origin restrictions
- styleTarget = styleTarget.contentDocument.head;
- } catch (e) {
- // istanbul ignore next
- styleTarget = null;
- }
- }
- memo[target] = styleTarget;
- }
- return memo[target];
- };
- }();
- var stylesInDom = [];
- function getIndexByIdentifier(identifier) {
- var result = -1;
- for (var i = 0; i < stylesInDom.length; i++) {
- if (stylesInDom[i].identifier === identifier) {
- result = i;
- break;
- }
- }
- return result;
- }
- function modulesToDom(list, options) {
- var idCountMap = {};
- var identifiers = [];
- for (var i = 0; i < list.length; i++) {
- var item = list[i];
- var id = options.base ? item[0] + options.base : item[0];
- var count = idCountMap[id] || 0;
- var identifier = "".concat(id, " ").concat(count);
- idCountMap[id] = count + 1;
- var index = getIndexByIdentifier(identifier);
- var obj = {
- css: item[1],
- media: item[2],
- sourceMap: item[3]
- };
- if (index !== -1) {
- stylesInDom[index].references++;
- stylesInDom[index].updater(obj);
- } else {
- stylesInDom.push({
- identifier: identifier,
- updater: addStyle(obj, options),
- references: 1
- });
- }
- identifiers.push(identifier);
- }
- return identifiers;
- }
- function insertStyleElement(options) {
- var style = document.createElement('style');
- var attributes = options.attributes || {};
- if (typeof attributes.nonce === 'undefined') {
- var nonce = true ? __webpack_require__.nc : undefined;
- if (nonce) {
- attributes.nonce = nonce;
- }
- }
- Object.keys(attributes).forEach(function (key) {
- style.setAttribute(key, attributes[key]);
- });
- if (typeof options.insert === 'function') {
- options.insert(style);
- } else {
- var target = getTarget(options.insert || 'head');
- if (!target) {
- throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");
- }
- target.appendChild(style);
- }
- return style;
- }
- function removeStyleElement(style) {
- // istanbul ignore if
- if (style.parentNode === null) {
- return false;
- }
- style.parentNode.removeChild(style);
- }
- /* istanbul ignore next */
- var replaceText = function replaceText() {
- var textStore = [];
- return function replace(index, replacement) {
- textStore[index] = replacement;
- return textStore.filter(Boolean).join('\n');
- };
- }();
- function applyToSingletonTag(style, index, remove, obj) {
- var css = remove ? '' : obj.media ? "@media ".concat(obj.media, " {").concat(obj.css, "}") : obj.css; // For old IE
- /* istanbul ignore if */
- if (style.styleSheet) {
- style.styleSheet.cssText = replaceText(index, css);
- } else {
- var cssNode = document.createTextNode(css);
- var childNodes = style.childNodes;
- if (childNodes[index]) {
- style.removeChild(childNodes[index]);
- }
- if (childNodes.length) {
- style.insertBefore(cssNode, childNodes[index]);
- } else {
- style.appendChild(cssNode);
- }
- }
- }
- function applyToTag(style, options, obj) {
- var css = obj.css;
- var media = obj.media;
- var sourceMap = obj.sourceMap;
- if (media) {
- style.setAttribute('media', media);
- } else {
- style.removeAttribute('media');
- }
- if (sourceMap && typeof btoa !== 'undefined') {
- css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */");
- } // For old IE
- /* istanbul ignore if */
- if (style.styleSheet) {
- style.styleSheet.cssText = css;
- } else {
- while (style.firstChild) {
- style.removeChild(style.firstChild);
- }
- style.appendChild(document.createTextNode(css));
- }
- }
- var singleton = null;
- var singletonCounter = 0;
- function addStyle(obj, options) {
- var style;
- var update;
- var remove;
- if (options.singleton) {
- var styleIndex = singletonCounter++;
- style = singleton || (singleton = insertStyleElement(options));
- update = applyToSingletonTag.bind(null, style, styleIndex, false);
- remove = applyToSingletonTag.bind(null, style, styleIndex, true);
- } else {
- style = insertStyleElement(options);
- update = applyToTag.bind(null, style, options);
- remove = function remove() {
- removeStyleElement(style);
- };
- }
- update(obj);
- return function updateStyle(newObj) {
- if (newObj) {
- if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) {
- return;
- }
- update(obj = newObj);
- } else {
- remove();
- }
- };
- }
- module.exports = function (list, options) {
- options = options || {}; // Force single-tag solution on IE6-9, which has a hard limit on the # of <style>
- // tags it will allow on a page
- if (!options.singleton && typeof options.singleton !== 'boolean') {
- options.singleton = isOldIE();
- }
- list = list || [];
- var lastIdentifiers = modulesToDom(list, options);
- return function update(newList) {
- newList = newList || [];
- if (Object.prototype.toString.call(newList) !== '[object Array]') {
- return;
- }
- for (var i = 0; i < lastIdentifiers.length; i++) {
- var identifier = lastIdentifiers[i];
- var index = getIndexByIdentifier(identifier);
- stylesInDom[index].references--;
- }
- var newLastIdentifiers = modulesToDom(newList, options);
- for (var _i = 0; _i < lastIdentifiers.length; _i++) {
- var _identifier = lastIdentifiers[_i];
- var _index = getIndexByIdentifier(_identifier);
- if (stylesInDom[_index].references === 0) {
- stylesInDom[_index].updater();
- stylesInDom.splice(_index, 1);
- }
- }
- lastIdentifiers = newLastIdentifiers;
- };
- };
- /***/ }),
- /* 21 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /*
- MIT License http://www.opensource.org/licenses/mit-license.php
- Author Tobias Koppers @sokra
- */
- // css base code, injected by the css-loader
- // eslint-disable-next-line func-names
- module.exports = function (useSourceMap) {
- var list = []; // return the list of modules as css string
- list.toString = function toString() {
- return this.map(function (item) {
- var content = cssWithMappingToString(item, useSourceMap);
- if (item[2]) {
- return "@media ".concat(item[2], " {").concat(content, "}");
- }
- return content;
- }).join('');
- }; // import a list of modules into the list
- // eslint-disable-next-line func-names
- list.i = function (modules, mediaQuery, dedupe) {
- if (typeof modules === 'string') {
- // eslint-disable-next-line no-param-reassign
- modules = [[null, modules, '']];
- }
- var alreadyImportedModules = {};
- if (dedupe) {
- for (var i = 0; i < this.length; i++) {
- // eslint-disable-next-line prefer-destructuring
- var id = this[i][0];
- if (id != null) {
- alreadyImportedModules[id] = true;
- }
- }
- }
- for (var _i = 0; _i < modules.length; _i++) {
- var item = [].concat(modules[_i]);
- if (dedupe && alreadyImportedModules[item[0]]) {
- // eslint-disable-next-line no-continue
- continue;
- }
- if (mediaQuery) {
- if (!item[2]) {
- item[2] = mediaQuery;
- } else {
- item[2] = "".concat(mediaQuery, " and ").concat(item[2]);
- }
- }
- list.push(item);
- }
- };
- return list;
- };
- function cssWithMappingToString(item, useSourceMap) {
- var content = item[1] || ''; // eslint-disable-next-line prefer-destructuring
- var cssMapping = item[3];
- if (!cssMapping) {
- return content;
- }
- if (useSourceMap && typeof btoa === 'function') {
- var sourceMapping = toComment(cssMapping);
- var sourceURLs = cssMapping.sources.map(function (source) {
- return "/*# sourceURL=".concat(cssMapping.sourceRoot || '').concat(source, " */");
- });
- return [content].concat(sourceURLs).concat([sourceMapping]).join('\n');
- }
- return [content].join('\n');
- } // Adapted from convert-source-map (MIT)
- function toComment(sourceMap) {
- // eslint-disable-next-line no-undef
- var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));
- var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64);
- return "/*# ".concat(data, " */");
- }
- /***/ }),
- /* 22 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 按钮菜单 Class
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var Menu_1 = __importDefault(__webpack_require__(96));
- var BtnMenu =
- /** @class */
- function (_super) {
- __extends(BtnMenu, _super);
- function BtnMenu($elem, editor) {
- return _super.call(this, $elem, editor) || this;
- }
- return BtnMenu;
- }(Menu_1["default"]);
- exports["default"] = BtnMenu;
- /***/ }),
- /* 23 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 下拉菜单 Class
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Menu_1 = __importDefault(__webpack_require__(96));
- var DropList_1 = __importDefault(__webpack_require__(125));
- var DropListMenu =
- /** @class */
- function (_super) {
- __extends(DropListMenu, _super);
- function DropListMenu($elem, editor, conf) {
- var _this = _super.call(this, $elem, editor) || this; // 国际化
- conf.title = editor.i18next.t("menus.dropListMenu." + conf.title); // 非中文模式下 带 icon 的下拉列表居左
- var className = editor.config.lang === 'zh-CN' ? '' : 'w-e-drop-list-tl';
- if (className !== '' && conf.type === 'list') {
- var _context;
- (0, _forEach["default"])(_context = conf.list).call(_context, function (item) {
- var $elem = item.$elem;
- var $children = dom_core_1["default"]($elem.children());
- if ($children.length > 0) {
- var nodeName = $children === null || $children === void 0 ? void 0 : $children.getNodeName();
- if (nodeName && nodeName === 'I') {
- $elem.addClass(className);
- }
- }
- });
- } // 初始化 dropList
- var dropList = new DropList_1["default"](_this, conf);
- _this.dropList = dropList; // 绑定事件
- $elem.on('mouseenter', function () {
- var _context2;
- if (editor.selection.getRange() == null) {
- return;
- }
- $elem.css('z-index', editor.zIndex.get('menu')); // 触发 droplist 悬浮事件
- (0, _forEach["default"])(_context2 = editor.txt.eventHooks.dropListMenuHoverEvents).call(_context2, function (fn) {
- return fn();
- }); // 显示
- dropList.showTimeoutId = window.setTimeout(function () {
- dropList.show();
- }, 200);
- }).on('mouseleave', function () {
- $elem.css('z-index', 'auto'); // 隐藏
- dropList.hideTimeoutId = window.setTimeout(function () {
- dropList.hide();
- });
- });
- return _this;
- }
- return DropListMenu;
- }(Menu_1["default"]);
- exports["default"] = DropListMenu;
- /***/ }),
- /* 24 */
- /***/ (function(module, exports, __webpack_require__) {
- var isObject = __webpack_require__(13);
- module.exports = function (it) {
- if (!isObject(it)) {
- throw TypeError(String(it) + ' is not an object');
- } return it;
- };
- /***/ }),
- /* 25 */
- /***/ (function(module, exports, __webpack_require__) {
- var DESCRIPTORS = __webpack_require__(14);
- var fails = __webpack_require__(12);
- var has = __webpack_require__(15);
- var defineProperty = Object.defineProperty;
- var cache = {};
- var thrower = function (it) { throw it; };
- module.exports = function (METHOD_NAME, options) {
- if (has(cache, METHOD_NAME)) return cache[METHOD_NAME];
- if (!options) options = {};
- var method = [][METHOD_NAME];
- var ACCESSORS = has(options, 'ACCESSORS') ? options.ACCESSORS : false;
- var argument0 = has(options, 0) ? options[0] : thrower;
- var argument1 = has(options, 1) ? options[1] : undefined;
- return cache[METHOD_NAME] = !!method && !fails(function () {
- if (ACCESSORS && !DESCRIPTORS) return true;
- var O = { length: -1 };
- if (ACCESSORS) defineProperty(O, 1, { enumerable: true, get: thrower });
- else O[1] = 1;
- method.call(O, argument0, argument1);
- });
- };
- /***/ }),
- /* 26 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 常量
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.videoRegex = exports.urlRegex = exports.imgRegex = exports.EMPTY_FN = void 0;
- function EMPTY_FN() {}
- exports.EMPTY_FN = EMPTY_FN; //用于校验图片链接是否符合规范
- exports.imgRegex = /\.(gif|jpg|jpeg|png)$/i; //用于校验是否为url格式字符串
- exports.urlRegex = /^(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-.,@?^=%&:/~+#]*[\w\-@?^=%&/~+#])?/; //用于校验在线视频是否符合规范
- exports.videoRegex = /((<iframe|video|embed|object)\s+[\s\S]*<\/(iframe|video|embed|object))>|<(iframe|video|embed|object)\s+[\s\S]*\/?>/;
- /***/ }),
- /* 27 */
- /***/ (function(module, exports, __webpack_require__) {
- // toObject with fallback for non-array-like ES3 strings
- var IndexedObject = __webpack_require__(68);
- var requireObjectCoercible = __webpack_require__(46);
- module.exports = function (it) {
- return IndexedObject(requireObjectCoercible(it));
- };
- /***/ }),
- /* 28 */
- /***/ (function(module, exports, __webpack_require__) {
- var path = __webpack_require__(10);
- var global = __webpack_require__(8);
- var aFunction = function (variable) {
- return typeof variable == 'function' ? variable : undefined;
- };
- module.exports = function (namespace, method) {
- return arguments.length < 2 ? aFunction(path[namespace]) || aFunction(global[namespace])
- : path[namespace] && path[namespace][method] || global[namespace] && global[namespace][method];
- };
- /***/ }),
- /* 29 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(217);
- /***/ }),
- /* 30 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(284);
- /***/ }),
- /* 31 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description panel class
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _set = _interopRequireDefault(__webpack_require__(124));
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var const_1 = __webpack_require__(26);
- var Panel =
- /** @class */
- function () {
- function Panel(menu, conf) {
- this.menu = menu;
- this.conf = conf;
- this.$container = dom_core_1["default"]('<div class="w-e-panel-container"></div>'); // 隐藏 panel
- var editor = menu.editor;
- editor.txt.eventHooks.clickEvents.push(Panel.hideCurAllPanels);
- editor.txt.eventHooks.toolbarClickEvents.push(Panel.hideCurAllPanels);
- editor.txt.eventHooks.dropListMenuHoverEvents.push(Panel.hideCurAllPanels);
- }
- /**
- * 创建并展示 panel
- */
- Panel.prototype.create = function () {
- var _this = this;
- var menu = this.menu;
- if (Panel.createdMenus.has(menu)) {
- // 创建过了
- return;
- }
- var conf = this.conf; // panel 的容器
- var $container = this.$container;
- var width = conf.width || 300; // 默认 300px
- var rect = menu.editor.$toolbarElem.getBoundingClientRect();
- var menuRect = menu.$elem.getBoundingClientRect();
- var top = rect.height + rect.top - menuRect.top;
- var left = (rect.width - width) / 2 + rect.left - menuRect.left;
- $container.css('width', width + 'px').css('margin-top', top + "px").css('margin-left', left + "px").css('z-index', menu.editor.zIndex.get('panel')); // 添加关闭按钮
- var $closeBtn = dom_core_1["default"]('<i class="w-e-icon-close w-e-panel-close"></i>');
- $container.append($closeBtn);
- $closeBtn.on('click', function () {
- _this.remove();
- }); // 准备 tabs 容器
- var $tabTitleContainer = dom_core_1["default"]('<ul class="w-e-panel-tab-title"></ul>');
- var $tabContentContainer = dom_core_1["default"]('<div class="w-e-panel-tab-content"></div>');
- $container.append($tabTitleContainer).append($tabContentContainer); // 设置高度
- var height = conf.height; // height: 0 即不用设置
- if (height) {
- $tabContentContainer.css('height', height + 'px').css('overflow-y', 'auto');
- } // tabs
- var tabs = conf.tabs || [];
- var tabTitleArr = [];
- var tabContentArr = [];
- (0, _forEach["default"])(tabs).call(tabs, function (tab, tabIndex) {
- if (!tab) {
- return;
- }
- var title = tab.title || '';
- var tpl = tab.tpl || ''; // 添加到 DOM
- var $title = dom_core_1["default"]("<li class=\"w-e-item\">" + title + "</li>");
- $tabTitleContainer.append($title);
- var $content = dom_core_1["default"](tpl);
- $tabContentContainer.append($content); // 记录到内存
- tabTitleArr.push($title);
- tabContentArr.push($content); // 设置 active 项
- if (tabIndex === 0) {
- $title.data('active', true);
- $title.addClass('w-e-active');
- } else {
- $content.hide();
- } // 绑定 tab 的事件
- $title.on('click', function () {
- if ($title.data('active')) {
- return;
- } // 隐藏所有的 tab
- (0, _forEach["default"])(tabTitleArr).call(tabTitleArr, function ($title) {
- $title.data('active', false);
- $title.removeClass('w-e-active');
- });
- (0, _forEach["default"])(tabContentArr).call(tabContentArr, function ($content) {
- $content.hide();
- }); // 显示当前的 tab
- $title.data('active', true);
- $title.addClass('w-e-active');
- $content.show();
- });
- }); // 绑定关闭事件
- $container.on('click', function (e) {
- // 点击时阻止冒泡
- e.stopPropagation();
- }); // 添加到 DOM
- menu.$elem.append($container); // 绑定 conf events 的事件,只有添加到 DOM 之后才能绑定成功
- (0, _forEach["default"])(tabs).call(tabs, function (tab, index) {
- if (!tab) {
- return;
- }
- var events = tab.events || [];
- (0, _forEach["default"])(events).call(events, function (event) {
- var selector = event.selector;
- var type = event.type;
- var fn = event.fn || const_1.EMPTY_FN;
- var $content = tabContentArr[index];
- (0, _find["default"])($content).call($content, selector).on(type, function (e) {
- e.stopPropagation();
- var needToHide = fn(e); // 执行完事件之后,是否要关闭 panel
- if (needToHide) {
- _this.remove();
- }
- });
- });
- }); // focus 第一个 elem
- var $inputs = (0, _find["default"])($container).call($container, 'input[type=text],textarea');
- if ($inputs.length) {
- $inputs.get(0).focus();
- } // 隐藏其他 panel
- Panel.hideCurAllPanels(); // 记录该 menu 已经创建了 panel
- menu.setPanel(this);
- Panel.createdMenus.add(menu);
- };
- /**
- * 移除 penal
- */
- Panel.prototype.remove = function () {
- var menu = this.menu;
- var $container = this.$container;
- if ($container) {
- $container.remove();
- } // 将该 menu 记录中移除
- Panel.createdMenus["delete"](menu);
- };
- /**
- * 隐藏当前所有的 panel
- */
- Panel.hideCurAllPanels = function () {
- var _context;
- if (Panel.createdMenus.size === 0) {
- return;
- }
- (0, _forEach["default"])(_context = Panel.createdMenus).call(_context, function (menu) {
- var panel = menu.panel;
- panel && panel.remove();
- });
- }; // 记录已经创建过的 panelMenu
- Panel.createdMenus = new _set["default"]();
- return Panel;
- }();
- exports["default"] = Panel;
- /***/ }),
- /* 32 */
- /***/ (function(module, exports) {
- module.exports = function (it) {
- if (typeof it != 'function') {
- throw TypeError(String(it) + ' is not a function');
- } return it;
- };
- /***/ }),
- /* 33 */
- /***/ (function(module, exports, __webpack_require__) {
- var bind = __webpack_require__(47);
- var IndexedObject = __webpack_require__(68);
- var toObject = __webpack_require__(38);
- var toLength = __webpack_require__(36);
- var arraySpeciesCreate = __webpack_require__(86);
- var push = [].push;
- // `Array.prototype.{ forEach, map, filter, some, every, find, findIndex, filterOut }` methods implementation
- var createMethod = function (TYPE) {
- var IS_MAP = TYPE == 1;
- var IS_FILTER = TYPE == 2;
- var IS_SOME = TYPE == 3;
- var IS_EVERY = TYPE == 4;
- var IS_FIND_INDEX = TYPE == 6;
- var IS_FILTER_OUT = TYPE == 7;
- var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;
- return function ($this, callbackfn, that, specificCreate) {
- var O = toObject($this);
- var self = IndexedObject(O);
- var boundFunction = bind(callbackfn, that, 3);
- var length = toLength(self.length);
- var index = 0;
- var create = specificCreate || arraySpeciesCreate;
- var target = IS_MAP ? create($this, length) : IS_FILTER || IS_FILTER_OUT ? create($this, 0) : undefined;
- var value, result;
- for (;length > index; index++) if (NO_HOLES || index in self) {
- value = self[index];
- result = boundFunction(value, index, O);
- if (TYPE) {
- if (IS_MAP) target[index] = result; // map
- else if (result) switch (TYPE) {
- case 3: return true; // some
- case 5: return value; // find
- case 6: return index; // findIndex
- case 2: push.call(target, value); // filter
- } else switch (TYPE) {
- case 4: return false; // every
- case 7: push.call(target, value); // filterOut
- }
- }
- }
- return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target;
- };
- };
- module.exports = {
- // `Array.prototype.forEach` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.foreach
- forEach: createMethod(0),
- // `Array.prototype.map` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.map
- map: createMethod(1),
- // `Array.prototype.filter` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.filter
- filter: createMethod(2),
- // `Array.prototype.some` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.some
- some: createMethod(3),
- // `Array.prototype.every` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.every
- every: createMethod(4),
- // `Array.prototype.find` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.find
- find: createMethod(5),
- // `Array.prototype.findIndex` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.findIndex
- findIndex: createMethod(6),
- // `Array.prototype.filterOut` method
- // https://github.com/tc39/proposal-array-filtering
- filterOut: createMethod(7)
- };
- /***/ }),
- /* 34 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description Modal 菜单 Class
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var Menu_1 = __importDefault(__webpack_require__(96));
- var PanelMenu =
- /** @class */
- function (_super) {
- __extends(PanelMenu, _super);
- function PanelMenu($elem, editor) {
- return _super.call(this, $elem, editor) || this;
- }
- /**
- * 给 menu 设置 panel
- * @param panel panel 实例
- */
- PanelMenu.prototype.setPanel = function (panel) {
- this.panel = panel;
- };
- return PanelMenu;
- }(Menu_1["default"]);
- exports["default"] = PanelMenu;
- /***/ }),
- /* 35 */
- /***/ (function(module, exports) {
- module.exports = function (bitmap, value) {
- return {
- enumerable: !(bitmap & 1),
- configurable: !(bitmap & 2),
- writable: !(bitmap & 4),
- value: value
- };
- };
- /***/ }),
- /* 36 */
- /***/ (function(module, exports, __webpack_require__) {
- var toInteger = __webpack_require__(58);
- var min = Math.min;
- // `ToLength` abstract operation
- // https://tc39.github.io/ecma262/#sec-tolength
- module.exports = function (argument) {
- return argument > 0 ? min(toInteger(argument), 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991
- };
- /***/ }),
- /* 37 */
- /***/ (function(module, exports) {
- module.exports = true;
- /***/ }),
- /* 38 */
- /***/ (function(module, exports, __webpack_require__) {
- var requireObjectCoercible = __webpack_require__(46);
- // `ToObject` abstract operation
- // https://tc39.github.io/ecma262/#sec-toobject
- module.exports = function (argument) {
- return Object(requireObjectCoercible(argument));
- };
- /***/ }),
- /* 39 */
- /***/ (function(module, exports, __webpack_require__) {
- var anObject = __webpack_require__(24);
- var isArrayIteratorMethod = __webpack_require__(160);
- var toLength = __webpack_require__(36);
- var bind = __webpack_require__(47);
- var getIteratorMethod = __webpack_require__(161);
- var iteratorClose = __webpack_require__(162);
- var Result = function (stopped, result) {
- this.stopped = stopped;
- this.result = result;
- };
- module.exports = function (iterable, unboundFunction, options) {
- var that = options && options.that;
- var AS_ENTRIES = !!(options && options.AS_ENTRIES);
- var IS_ITERATOR = !!(options && options.IS_ITERATOR);
- var INTERRUPTED = !!(options && options.INTERRUPTED);
- var fn = bind(unboundFunction, that, 1 + AS_ENTRIES + INTERRUPTED);
- var iterator, iterFn, index, length, result, next, step;
- var stop = function (condition) {
- if (iterator) iteratorClose(iterator);
- return new Result(true, condition);
- };
- var callFn = function (value) {
- if (AS_ENTRIES) {
- anObject(value);
- return INTERRUPTED ? fn(value[0], value[1], stop) : fn(value[0], value[1]);
- } return INTERRUPTED ? fn(value, stop) : fn(value);
- };
- if (IS_ITERATOR) {
- iterator = iterable;
- } else {
- iterFn = getIteratorMethod(iterable);
- if (typeof iterFn != 'function') throw TypeError('Target is not iterable');
- // optimisation for array iterators
- if (isArrayIteratorMethod(iterFn)) {
- for (index = 0, length = toLength(iterable.length); length > index; index++) {
- result = callFn(iterable[index]);
- if (result && result instanceof Result) return result;
- } return new Result(false);
- }
- iterator = iterFn.call(iterable);
- }
- next = iterator.next;
- while (!(step = next.call(iterator)).done) {
- try {
- result = callFn(step.value);
- } catch (error) {
- iteratorClose(iterator);
- throw error;
- }
- if (typeof result == 'object' && result && result instanceof Result) return result;
- } return new Result(false);
- };
- /***/ }),
- /* 40 */
- /***/ (function(module, exports) {
- module.exports = {};
- /***/ }),
- /* 41 */
- /***/ (function(module, exports, __webpack_require__) {
- var TO_STRING_TAG_SUPPORT = __webpack_require__(78);
- var defineProperty = __webpack_require__(18).f;
- var createNonEnumerableProperty = __webpack_require__(17);
- var has = __webpack_require__(15);
- var toString = __webpack_require__(164);
- var wellKnownSymbol = __webpack_require__(9);
- var TO_STRING_TAG = wellKnownSymbol('toStringTag');
- module.exports = function (it, TAG, STATIC, SET_METHOD) {
- if (it) {
- var target = STATIC ? it : it.prototype;
- if (!has(target, TO_STRING_TAG)) {
- defineProperty(target, TO_STRING_TAG, { configurable: true, value: TAG });
- }
- if (SET_METHOD && !TO_STRING_TAG_SUPPORT) {
- createNonEnumerableProperty(target, 'toString', toString);
- }
- }
- };
- /***/ }),
- /* 42 */
- /***/ (function(module, exports, __webpack_require__) {
- var NATIVE_WEAK_MAP = __webpack_require__(168);
- var global = __webpack_require__(8);
- var isObject = __webpack_require__(13);
- var createNonEnumerableProperty = __webpack_require__(17);
- var objectHas = __webpack_require__(15);
- var shared = __webpack_require__(74);
- var sharedKey = __webpack_require__(59);
- var hiddenKeys = __webpack_require__(49);
- var WeakMap = global.WeakMap;
- var set, get, has;
- var enforce = function (it) {
- return has(it) ? get(it) : set(it, {});
- };
- var getterFor = function (TYPE) {
- return function (it) {
- var state;
- if (!isObject(it) || (state = get(it)).type !== TYPE) {
- throw TypeError('Incompatible receiver, ' + TYPE + ' required');
- } return state;
- };
- };
- if (NATIVE_WEAK_MAP) {
- var store = shared.state || (shared.state = new WeakMap());
- var wmget = store.get;
- var wmhas = store.has;
- var wmset = store.set;
- set = function (it, metadata) {
- metadata.facade = it;
- wmset.call(store, it, metadata);
- return metadata;
- };
- get = function (it) {
- return wmget.call(store, it) || {};
- };
- has = function (it) {
- return wmhas.call(store, it);
- };
- } else {
- var STATE = sharedKey('state');
- hiddenKeys[STATE] = true;
- set = function (it, metadata) {
- metadata.facade = it;
- createNonEnumerableProperty(it, STATE, metadata);
- return metadata;
- };
- get = function (it) {
- return objectHas(it, STATE) ? it[STATE] : {};
- };
- has = function (it) {
- return objectHas(it, STATE);
- };
- }
- module.exports = {
- set: set,
- get: get,
- has: has,
- enforce: enforce,
- getterFor: getterFor
- };
- /***/ }),
- /* 43 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(256);
- /***/ }),
- /* 44 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description Tooltip class
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Tooltip =
- /** @class */
- function () {
- function Tooltip(editor, $elem, conf) {
- this.editor = editor;
- this.$targetElem = $elem;
- this.conf = conf;
- this._show = false;
- this._isInsertTextContainer = false; // 定义 container
- var $container = dom_core_1["default"]('<div></div>');
- $container.addClass('w-e-tooltip');
- this.$container = $container;
- }
- /**
- * 获取 tooltip 定位
- */
- Tooltip.prototype.getPositionData = function () {
- var $container = this.$container;
- var top = 0;
- var left = 0; // tooltip 的高度
- var tooltipHeight = 20; // 网页的 scrollTop
- var pageScrollTop = document.documentElement.scrollTop; // 目标元素的 rect
- var targetElemRect = this.$targetElem.getBoundingClientRect(); // 编辑区域的 rect
- var textElemRect = this.editor.$textElem.getBoundingClientRect(); // 获取基于 textContainerElem 的 位置信息
- var targetOffset = this.$targetElem.getOffsetData();
- var targetParentElem = dom_core_1["default"](targetOffset.parent); // 获取 编辑区域的滚动条信息
- var scrollTop = this.editor.$textElem.elems[0].scrollTop; // 是否插入 textContainer 中
- this._isInsertTextContainer = targetParentElem.equal(this.editor.$textContainerElem);
- if (this._isInsertTextContainer) {
- // 父容器的高度
- var targetParentElemHeight = targetParentElem.getClientHeight(); // 相对于父容器的位置信息
- var offsetTop = targetOffset.top,
- offsetLeft = targetOffset.left,
- offsetHeight = targetOffset.height; // 元素基于父容器的 绝对top信息
- var absoluteTop = offsetTop - scrollTop;
- if (absoluteTop > tooltipHeight + 5) {
- // 说明模板元素的顶部空间足够
- top = absoluteTop - tooltipHeight - 15;
- $container.addClass('w-e-tooltip-up');
- } else if (absoluteTop + offsetHeight + tooltipHeight < targetParentElemHeight) {
- // 说明模板元素的底部空间足够
- top = absoluteTop + offsetHeight + 10;
- $container.addClass('w-e-tooltip-down');
- } else {
- // 其他情况,tooltip 放在目标元素左上角
- top = (absoluteTop > 0 ? absoluteTop : 0) + tooltipHeight + 10;
- $container.addClass('w-e-tooltip-down');
- } // 计算 left
- if (offsetLeft < 0) {
- left = 0;
- } else {
- left = offsetLeft;
- }
- } else {
- if (targetElemRect.top < tooltipHeight) {
- // 说明目标元素的顶部,因滑动隐藏在浏览器上方。tooltip 要放在目标元素下面
- top = targetElemRect.bottom + pageScrollTop + 5; // 5px 间距
- $container.addClass('w-e-tooltip-down');
- } else if (targetElemRect.top - textElemRect.top < tooltipHeight) {
- // 说明目标元素的顶部,因滑动隐藏在编辑区域上方。tooltip 要放在目标元素下面
- top = targetElemRect.bottom + pageScrollTop + 5; // 5px 间距
- $container.addClass('w-e-tooltip-down');
- } else {
- // 其他情况,tooltip 放在目标元素上方
- top = targetElemRect.top + pageScrollTop - tooltipHeight - 15; // 减去 toolbar 的高度,还有 15px 间距
- $container.addClass('w-e-tooltip-up');
- } // 计算 left
- if (targetElemRect.left < 0) {
- left = 0;
- } else {
- left = targetElemRect.left;
- }
- } // 返回结果
- return {
- top: top,
- left: left
- };
- };
- /**
- * 添加 tooltip 菜单
- */
- Tooltip.prototype.appendMenus = function () {
- var _this = this;
- var conf = this.conf;
- var editor = this.editor;
- var $targetElem = this.$targetElem;
- var $container = this.$container;
- (0, _forEach["default"])(conf).call(conf, function (item, index) {
- // 添加元素
- var $elem = item.$elem;
- var $wrapper = dom_core_1["default"]('<div></div>');
- $wrapper.addClass('w-e-tooltip-item-wrapper ');
- $wrapper.append($elem);
- $container.append($wrapper); // 绑定点击事件
- $elem.on('click', function (e) {
- e.preventDefault();
- var res = item.onClick(editor, $targetElem);
- if (res) _this.remove();
- });
- });
- };
- /**
- * 创建 tooltip
- */
- Tooltip.prototype.create = function () {
- var editor = this.editor;
- var $container = this.$container; // 生成 container 的内容
- this.appendMenus(); // 设置定位
- var _a = this.getPositionData(),
- top = _a.top,
- left = _a.left;
- $container.css('top', top + "px");
- $container.css('left', left + "px"); // 设置 z-index
- $container.css('z-index', editor.zIndex.get('tooltip')); // 添加到 DOM
- if (this._isInsertTextContainer) {
- this.editor.$textContainerElem.append($container);
- } else {
- dom_core_1["default"]('body').append($container);
- }
- this._show = true;
- };
- /**
- * 移除该 tooltip
- */
- Tooltip.prototype.remove = function () {
- this.$container.remove();
- this._show = false;
- };
- (0, _defineProperty["default"])(Tooltip.prototype, "isShow", {
- /**
- * 是否显示
- */
- get: function get() {
- return this._show;
- },
- enumerable: false,
- configurable: true
- });
- return Tooltip;
- }();
- exports["default"] = Tooltip;
- /***/ }),
- /* 45 */
- /***/ (function(module, exports) {
- var toString = {}.toString;
- module.exports = function (it) {
- return toString.call(it).slice(8, -1);
- };
- /***/ }),
- /* 46 */
- /***/ (function(module, exports) {
- // `RequireObjectCoercible` abstract operation
- // https://tc39.github.io/ecma262/#sec-requireobjectcoercible
- module.exports = function (it) {
- if (it == undefined) throw TypeError("Can't call method on " + it);
- return it;
- };
- /***/ }),
- /* 47 */
- /***/ (function(module, exports, __webpack_require__) {
- var aFunction = __webpack_require__(32);
- // optional / simple context binding
- module.exports = function (fn, that, length) {
- aFunction(fn);
- if (that === undefined) return fn;
- switch (length) {
- case 0: return function () {
- return fn.call(that);
- };
- case 1: return function (a) {
- return fn.call(that, a);
- };
- case 2: return function (a, b) {
- return fn.call(that, a, b);
- };
- case 3: return function (a, b, c) {
- return fn.call(that, a, b, c);
- };
- }
- return function (/* ...args */) {
- return fn.apply(that, arguments);
- };
- };
- /***/ }),
- /* 48 */
- /***/ (function(module, exports, __webpack_require__) {
- var anObject = __webpack_require__(24);
- var defineProperties = __webpack_require__(137);
- var enumBugKeys = __webpack_require__(72);
- var hiddenKeys = __webpack_require__(49);
- var html = __webpack_require__(103);
- var documentCreateElement = __webpack_require__(69);
- var sharedKey = __webpack_require__(59);
- var GT = '>';
- var LT = '<';
- var PROTOTYPE = 'prototype';
- var SCRIPT = 'script';
- var IE_PROTO = sharedKey('IE_PROTO');
- var EmptyConstructor = function () { /* empty */ };
- var scriptTag = function (content) {
- return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;
- };
- // Create object with fake `null` prototype: use ActiveX Object with cleared prototype
- var NullProtoObjectViaActiveX = function (activeXDocument) {
- activeXDocument.write(scriptTag(''));
- activeXDocument.close();
- var temp = activeXDocument.parentWindow.Object;
- activeXDocument = null; // avoid memory leak
- return temp;
- };
- // Create object with fake `null` prototype: use iframe Object with cleared prototype
- var NullProtoObjectViaIFrame = function () {
- // Thrash, waste and sodomy: IE GC bug
- var iframe = documentCreateElement('iframe');
- var JS = 'java' + SCRIPT + ':';
- var iframeDocument;
- iframe.style.display = 'none';
- html.appendChild(iframe);
- // https://github.com/zloirock/core-js/issues/475
- iframe.src = String(JS);
- iframeDocument = iframe.contentWindow.document;
- iframeDocument.open();
- iframeDocument.write(scriptTag('document.F=Object'));
- iframeDocument.close();
- return iframeDocument.F;
- };
- // Check for document.domain and active x support
- // No need to use active x approach when document.domain is not set
- // see https://github.com/es-shims/es5-shim/issues/150
- // variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346
- // avoid IE GC bug
- var activeXDocument;
- var NullProtoObject = function () {
- try {
- /* global ActiveXObject */
- activeXDocument = document.domain && new ActiveXObject('htmlfile');
- } catch (error) { /* ignore */ }
- NullProtoObject = activeXDocument ? NullProtoObjectViaActiveX(activeXDocument) : NullProtoObjectViaIFrame();
- var length = enumBugKeys.length;
- while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];
- return NullProtoObject();
- };
- hiddenKeys[IE_PROTO] = true;
- // `Object.create` method
- // https://tc39.github.io/ecma262/#sec-object.create
- module.exports = Object.create || function create(O, Properties) {
- var result;
- if (O !== null) {
- EmptyConstructor[PROTOTYPE] = anObject(O);
- result = new EmptyConstructor();
- EmptyConstructor[PROTOTYPE] = null;
- // add "__proto__" for Object.getPrototypeOf polyfill
- result[IE_PROTO] = O;
- } else result = NullProtoObject();
- return Properties === undefined ? result : defineProperties(result, Properties);
- };
- /***/ }),
- /* 49 */
- /***/ (function(module, exports) {
- module.exports = {};
- /***/ }),
- /* 50 */
- /***/ (function(module, exports, __webpack_require__) {
- var createNonEnumerableProperty = __webpack_require__(17);
- module.exports = function (target, key, value, options) {
- if (options && options.enumerable) target[key] = value;
- else createNonEnumerableProperty(target, key, value);
- };
- /***/ }),
- /* 51 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(174);
- var DOMIterables = __webpack_require__(175);
- var global = __webpack_require__(8);
- var classof = __webpack_require__(61);
- var createNonEnumerableProperty = __webpack_require__(17);
- var Iterators = __webpack_require__(40);
- var wellKnownSymbol = __webpack_require__(9);
- var TO_STRING_TAG = wellKnownSymbol('toStringTag');
- for (var COLLECTION_NAME in DOMIterables) {
- var Collection = global[COLLECTION_NAME];
- var CollectionPrototype = Collection && Collection.prototype;
- if (CollectionPrototype && classof(CollectionPrototype) !== TO_STRING_TAG) {
- createNonEnumerableProperty(CollectionPrototype, TO_STRING_TAG, COLLECTION_NAME);
- }
- Iterators[COLLECTION_NAME] = Iterators.Array;
- }
- /***/ }),
- /* 52 */
- /***/ (function(module, exports, __webpack_require__) {
- var classof = __webpack_require__(45);
- // `IsArray` abstract operation
- // https://tc39.github.io/ecma262/#sec-isarray
- module.exports = Array.isArray || function isArray(arg) {
- return classof(arg) == 'Array';
- };
- /***/ }),
- /* 53 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- var wellKnownSymbol = __webpack_require__(9);
- var V8_VERSION = __webpack_require__(83);
- var SPECIES = wellKnownSymbol('species');
- module.exports = function (METHOD_NAME) {
- // We can't use this feature detection in V8 since it causes
- // deoptimization and serious performance degradation
- // https://github.com/zloirock/core-js/issues/677
- return V8_VERSION >= 51 || !fails(function () {
- var array = [];
- var constructor = array.constructor = {};
- constructor[SPECIES] = function () {
- return { foo: 1 };
- };
- return array[METHOD_NAME](Boolean).foo !== 1;
- });
- };
- /***/ }),
- /* 54 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(204);
- /***/ }),
- /* 55 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var nativePropertyIsEnumerable = {}.propertyIsEnumerable;
- var getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
- // Nashorn ~ JDK8 bug
- var NASHORN_BUG = getOwnPropertyDescriptor && !nativePropertyIsEnumerable.call({ 1: 2 }, 1);
- // `Object.prototype.propertyIsEnumerable` method implementation
- // https://tc39.github.io/ecma262/#sec-object.prototype.propertyisenumerable
- exports.f = NASHORN_BUG ? function propertyIsEnumerable(V) {
- var descriptor = getOwnPropertyDescriptor(this, V);
- return !!descriptor && descriptor.enumerable;
- } : nativePropertyIsEnumerable;
- /***/ }),
- /* 56 */
- /***/ (function(module, exports, __webpack_require__) {
- var isObject = __webpack_require__(13);
- // `ToPrimitive` abstract operation
- // https://tc39.github.io/ecma262/#sec-toprimitive
- // instead of the ES6 spec version, we didn't implement @@toPrimitive case
- // and the second argument - flag - preferred type is a string
- module.exports = function (input, PREFERRED_STRING) {
- if (!isObject(input)) return input;
- var fn, val;
- if (PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
- if (typeof (fn = input.valueOf) == 'function' && !isObject(val = fn.call(input))) return val;
- if (!PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
- throw TypeError("Can't convert object to primitive value");
- };
- /***/ }),
- /* 57 */
- /***/ (function(module, exports, __webpack_require__) {
- var internalObjectKeys = __webpack_require__(102);
- var enumBugKeys = __webpack_require__(72);
- // `Object.keys` method
- // https://tc39.github.io/ecma262/#sec-object.keys
- module.exports = Object.keys || function keys(O) {
- return internalObjectKeys(O, enumBugKeys);
- };
- /***/ }),
- /* 58 */
- /***/ (function(module, exports) {
- var ceil = Math.ceil;
- var floor = Math.floor;
- // `ToInteger` abstract operation
- // https://tc39.github.io/ecma262/#sec-tointeger
- module.exports = function (argument) {
- return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor : ceil)(argument);
- };
- /***/ }),
- /* 59 */
- /***/ (function(module, exports, __webpack_require__) {
- var shared = __webpack_require__(73);
- var uid = __webpack_require__(60);
- var keys = shared('keys');
- module.exports = function (key) {
- return keys[key] || (keys[key] = uid(key));
- };
- /***/ }),
- /* 60 */
- /***/ (function(module, exports) {
- var id = 0;
- var postfix = Math.random();
- module.exports = function (key) {
- return 'Symbol(' + String(key === undefined ? '' : key) + ')_' + (++id + postfix).toString(36);
- };
- /***/ }),
- /* 61 */
- /***/ (function(module, exports, __webpack_require__) {
- var TO_STRING_TAG_SUPPORT = __webpack_require__(78);
- var classofRaw = __webpack_require__(45);
- var wellKnownSymbol = __webpack_require__(9);
- var TO_STRING_TAG = wellKnownSymbol('toStringTag');
- // ES3 wrong here
- var CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) == 'Arguments';
- // fallback for IE11 Script Access Denied error
- var tryGet = function (it, key) {
- try {
- return it[key];
- } catch (error) { /* empty */ }
- };
- // getting tag from ES6+ `Object.prototype.toString`
- module.exports = TO_STRING_TAG_SUPPORT ? classofRaw : function (it) {
- var O, tag, result;
- return it === undefined ? 'Undefined' : it === null ? 'Null'
- // @@toStringTag case
- : typeof (tag = tryGet(O = Object(it), TO_STRING_TAG)) == 'string' ? tag
- // builtinTag case
- : CORRECT_ARGUMENTS ? classofRaw(O)
- // ES3 arguments fallback
- : (result = classofRaw(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : result;
- };
- /***/ }),
- /* 62 */
- /***/ (function(module, exports) {
- // empty
- /***/ }),
- /* 63 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var aFunction = __webpack_require__(32);
- var PromiseCapability = function (C) {
- var resolve, reject;
- this.promise = new C(function ($$resolve, $$reject) {
- if (resolve !== undefined || reject !== undefined) throw TypeError('Bad Promise constructor');
- resolve = $$resolve;
- reject = $$reject;
- });
- this.resolve = aFunction(resolve);
- this.reject = aFunction(reject);
- };
- // 25.4.1.5 NewPromiseCapability(C)
- module.exports.f = function (C) {
- return new PromiseCapability(C);
- };
- /***/ }),
- /* 64 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var charAt = __webpack_require__(172).charAt;
- var InternalStateModule = __webpack_require__(42);
- var defineIterator = __webpack_require__(84);
- var STRING_ITERATOR = 'String Iterator';
- var setInternalState = InternalStateModule.set;
- var getInternalState = InternalStateModule.getterFor(STRING_ITERATOR);
- // `String.prototype[@@iterator]` method
- // https://tc39.github.io/ecma262/#sec-string.prototype-@@iterator
- defineIterator(String, 'String', function (iterated) {
- setInternalState(this, {
- type: STRING_ITERATOR,
- string: String(iterated),
- index: 0
- });
- // `%StringIteratorPrototype%.next` method
- // https://tc39.github.io/ecma262/#sec-%stringiteratorprototype%.next
- }, function next() {
- var state = getInternalState(this);
- var string = state.string;
- var index = state.index;
- var point;
- if (index >= string.length) return { value: undefined, done: true };
- point = charAt(string, index);
- state.index += point.length;
- return { value: point, done: false };
- });
- /***/ }),
- /* 65 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(196);
- /***/ }),
- /* 66 */
- /***/ (function(module, exports) {
- // a string of all valid unicode whitespaces
- // eslint-disable-next-line max-len
- module.exports = '\u0009\u000A\u000B\u000C\u000D\u0020\u00A0\u1680\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200A\u202F\u205F\u3000\u2028\u2029\uFEFF';
- /***/ }),
- /* 67 */
- /***/ (function(module, exports, __webpack_require__) {
- var DESCRIPTORS = __webpack_require__(14);
- var propertyIsEnumerableModule = __webpack_require__(55);
- var createPropertyDescriptor = __webpack_require__(35);
- var toIndexedObject = __webpack_require__(27);
- var toPrimitive = __webpack_require__(56);
- var has = __webpack_require__(15);
- var IE8_DOM_DEFINE = __webpack_require__(100);
- var nativeGetOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
- // `Object.getOwnPropertyDescriptor` method
- // https://tc39.github.io/ecma262/#sec-object.getownpropertydescriptor
- exports.f = DESCRIPTORS ? nativeGetOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {
- O = toIndexedObject(O);
- P = toPrimitive(P, true);
- if (IE8_DOM_DEFINE) try {
- return nativeGetOwnPropertyDescriptor(O, P);
- } catch (error) { /* empty */ }
- if (has(O, P)) return createPropertyDescriptor(!propertyIsEnumerableModule.f.call(O, P), O[P]);
- };
- /***/ }),
- /* 68 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- var classof = __webpack_require__(45);
- var split = ''.split;
- // fallback for non-array-like ES3 and non-enumerable old V8 strings
- module.exports = fails(function () {
- // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346
- // eslint-disable-next-line no-prototype-builtins
- return !Object('z').propertyIsEnumerable(0);
- }) ? function (it) {
- return classof(it) == 'String' ? split.call(it, '') : Object(it);
- } : Object;
- /***/ }),
- /* 69 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var isObject = __webpack_require__(13);
- var document = global.document;
- // typeof document.createElement is 'object' in old IE
- var EXISTS = isObject(document) && isObject(document.createElement);
- module.exports = function (it) {
- return EXISTS ? document.createElement(it) : {};
- };
- /***/ }),
- /* 70 */
- /***/ (function(module, exports, __webpack_require__) {
- var toIndexedObject = __webpack_require__(27);
- var toLength = __webpack_require__(36);
- var toAbsoluteIndex = __webpack_require__(71);
- // `Array.prototype.{ indexOf, includes }` methods implementation
- var createMethod = function (IS_INCLUDES) {
- return function ($this, el, fromIndex) {
- var O = toIndexedObject($this);
- var length = toLength(O.length);
- var index = toAbsoluteIndex(fromIndex, length);
- var value;
- // Array#includes uses SameValueZero equality algorithm
- // eslint-disable-next-line no-self-compare
- if (IS_INCLUDES && el != el) while (length > index) {
- value = O[index++];
- // eslint-disable-next-line no-self-compare
- if (value != value) return true;
- // Array#indexOf ignores holes, Array#includes - not
- } else for (;length > index; index++) {
- if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;
- } return !IS_INCLUDES && -1;
- };
- };
- module.exports = {
- // `Array.prototype.includes` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.includes
- includes: createMethod(true),
- // `Array.prototype.indexOf` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.indexof
- indexOf: createMethod(false)
- };
- /***/ }),
- /* 71 */
- /***/ (function(module, exports, __webpack_require__) {
- var toInteger = __webpack_require__(58);
- var max = Math.max;
- var min = Math.min;
- // Helper for a popular repeating case of the spec:
- // Let integer be ? ToInteger(index).
- // If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).
- module.exports = function (index, length) {
- var integer = toInteger(index);
- return integer < 0 ? max(integer + length, 0) : min(integer, length);
- };
- /***/ }),
- /* 72 */
- /***/ (function(module, exports) {
- // IE8- don't enum bug keys
- module.exports = [
- 'constructor',
- 'hasOwnProperty',
- 'isPrototypeOf',
- 'propertyIsEnumerable',
- 'toLocaleString',
- 'toString',
- 'valueOf'
- ];
- /***/ }),
- /* 73 */
- /***/ (function(module, exports, __webpack_require__) {
- var IS_PURE = __webpack_require__(37);
- var store = __webpack_require__(74);
- (module.exports = function (key, value) {
- return store[key] || (store[key] = value !== undefined ? value : {});
- })('versions', []).push({
- version: '3.8.1',
- mode: IS_PURE ? 'pure' : 'global',
- copyright: '© 2020 Denis Pushkarev (zloirock.ru)'
- });
- /***/ }),
- /* 74 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var setGlobal = __webpack_require__(138);
- var SHARED = '__core-js_shared__';
- var store = global[SHARED] || setGlobal(SHARED, {});
- module.exports = store;
- /***/ }),
- /* 75 */
- /***/ (function(module, exports, __webpack_require__) {
- var has = __webpack_require__(15);
- var toObject = __webpack_require__(38);
- var sharedKey = __webpack_require__(59);
- var CORRECT_PROTOTYPE_GETTER = __webpack_require__(158);
- var IE_PROTO = sharedKey('IE_PROTO');
- var ObjectPrototype = Object.prototype;
- // `Object.getPrototypeOf` method
- // https://tc39.github.io/ecma262/#sec-object.getprototypeof
- module.exports = CORRECT_PROTOTYPE_GETTER ? Object.getPrototypeOf : function (O) {
- O = toObject(O);
- if (has(O, IE_PROTO)) return O[IE_PROTO];
- if (typeof O.constructor == 'function' && O instanceof O.constructor) {
- return O.constructor.prototype;
- } return O instanceof Object ? ObjectPrototype : null;
- };
- /***/ }),
- /* 76 */
- /***/ (function(module, exports, __webpack_require__) {
- var anObject = __webpack_require__(24);
- var aPossiblePrototype = __webpack_require__(159);
- // `Object.setPrototypeOf` method
- // https://tc39.github.io/ecma262/#sec-object.setprototypeof
- // Works with __proto__ only. Old v8 can't work with null proto objects.
- /* eslint-disable no-proto */
- module.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () {
- var CORRECT_SETTER = false;
- var test = {};
- var setter;
- try {
- setter = Object.getOwnPropertyDescriptor(Object.prototype, '__proto__').set;
- setter.call(test, []);
- CORRECT_SETTER = test instanceof Array;
- } catch (error) { /* empty */ }
- return function setPrototypeOf(O, proto) {
- anObject(O);
- aPossiblePrototype(proto);
- if (CORRECT_SETTER) setter.call(O, proto);
- else O.__proto__ = proto;
- return O;
- };
- }() : undefined);
- /***/ }),
- /* 77 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- module.exports = !!Object.getOwnPropertySymbols && !fails(function () {
- // Chrome 38 Symbol has incorrect toString conversion
- // eslint-disable-next-line no-undef
- return !String(Symbol());
- });
- /***/ }),
- /* 78 */
- /***/ (function(module, exports, __webpack_require__) {
- var wellKnownSymbol = __webpack_require__(9);
- var TO_STRING_TAG = wellKnownSymbol('toStringTag');
- var test = {};
- test[TO_STRING_TAG] = 'z';
- module.exports = String(test) === '[object z]';
- /***/ }),
- /* 79 */
- /***/ (function(module, exports) {
- module.exports = function (it, Constructor, name) {
- if (!(it instanceof Constructor)) {
- throw TypeError('Incorrect ' + (name ? name + ' ' : '') + 'invocation');
- } return it;
- };
- /***/ }),
- /* 80 */
- /***/ (function(module, exports, __webpack_require__) {
- var getBuiltIn = __webpack_require__(28);
- module.exports = getBuiltIn('navigator', 'userAgent') || '';
- /***/ }),
- /* 81 */
- /***/ (function(module, exports, __webpack_require__) {
- var classof = __webpack_require__(45);
- var global = __webpack_require__(8);
- module.exports = classof(global.process) == 'process';
- /***/ }),
- /* 82 */
- /***/ (function(module, exports) {
- module.exports = function (exec) {
- try {
- return { error: false, value: exec() };
- } catch (error) {
- return { error: true, value: error };
- }
- };
- /***/ }),
- /* 83 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var userAgent = __webpack_require__(80);
- var process = global.process;
- var versions = process && process.versions;
- var v8 = versions && versions.v8;
- var match, version;
- if (v8) {
- match = v8.split('.');
- version = match[0] + match[1];
- } else if (userAgent) {
- match = userAgent.match(/Edge\/(\d+)/);
- if (!match || match[1] >= 74) {
- match = userAgent.match(/Chrome\/(\d+)/);
- if (match) version = match[1];
- }
- }
- module.exports = version && +version;
- /***/ }),
- /* 84 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var createIteratorConstructor = __webpack_require__(173);
- var getPrototypeOf = __webpack_require__(75);
- var setPrototypeOf = __webpack_require__(76);
- var setToStringTag = __webpack_require__(41);
- var createNonEnumerableProperty = __webpack_require__(17);
- var redefine = __webpack_require__(50);
- var wellKnownSymbol = __webpack_require__(9);
- var IS_PURE = __webpack_require__(37);
- var Iterators = __webpack_require__(40);
- var IteratorsCore = __webpack_require__(113);
- var IteratorPrototype = IteratorsCore.IteratorPrototype;
- var BUGGY_SAFARI_ITERATORS = IteratorsCore.BUGGY_SAFARI_ITERATORS;
- var ITERATOR = wellKnownSymbol('iterator');
- var KEYS = 'keys';
- var VALUES = 'values';
- var ENTRIES = 'entries';
- var returnThis = function () { return this; };
- module.exports = function (Iterable, NAME, IteratorConstructor, next, DEFAULT, IS_SET, FORCED) {
- createIteratorConstructor(IteratorConstructor, NAME, next);
- var getIterationMethod = function (KIND) {
- if (KIND === DEFAULT && defaultIterator) return defaultIterator;
- if (!BUGGY_SAFARI_ITERATORS && KIND in IterablePrototype) return IterablePrototype[KIND];
- switch (KIND) {
- case KEYS: return function keys() { return new IteratorConstructor(this, KIND); };
- case VALUES: return function values() { return new IteratorConstructor(this, KIND); };
- case ENTRIES: return function entries() { return new IteratorConstructor(this, KIND); };
- } return function () { return new IteratorConstructor(this); };
- };
- var TO_STRING_TAG = NAME + ' Iterator';
- var INCORRECT_VALUES_NAME = false;
- var IterablePrototype = Iterable.prototype;
- var nativeIterator = IterablePrototype[ITERATOR]
- || IterablePrototype['@@iterator']
- || DEFAULT && IterablePrototype[DEFAULT];
- var defaultIterator = !BUGGY_SAFARI_ITERATORS && nativeIterator || getIterationMethod(DEFAULT);
- var anyNativeIterator = NAME == 'Array' ? IterablePrototype.entries || nativeIterator : nativeIterator;
- var CurrentIteratorPrototype, methods, KEY;
- // fix native
- if (anyNativeIterator) {
- CurrentIteratorPrototype = getPrototypeOf(anyNativeIterator.call(new Iterable()));
- if (IteratorPrototype !== Object.prototype && CurrentIteratorPrototype.next) {
- if (!IS_PURE && getPrototypeOf(CurrentIteratorPrototype) !== IteratorPrototype) {
- if (setPrototypeOf) {
- setPrototypeOf(CurrentIteratorPrototype, IteratorPrototype);
- } else if (typeof CurrentIteratorPrototype[ITERATOR] != 'function') {
- createNonEnumerableProperty(CurrentIteratorPrototype, ITERATOR, returnThis);
- }
- }
- // Set @@toStringTag to native iterators
- setToStringTag(CurrentIteratorPrototype, TO_STRING_TAG, true, true);
- if (IS_PURE) Iterators[TO_STRING_TAG] = returnThis;
- }
- }
- // fix Array#{values, @@iterator}.name in V8 / FF
- if (DEFAULT == VALUES && nativeIterator && nativeIterator.name !== VALUES) {
- INCORRECT_VALUES_NAME = true;
- defaultIterator = function values() { return nativeIterator.call(this); };
- }
- // define iterator
- if ((!IS_PURE || FORCED) && IterablePrototype[ITERATOR] !== defaultIterator) {
- createNonEnumerableProperty(IterablePrototype, ITERATOR, defaultIterator);
- }
- Iterators[NAME] = defaultIterator;
- // export additional methods
- if (DEFAULT) {
- methods = {
- values: getIterationMethod(VALUES),
- keys: IS_SET ? defaultIterator : getIterationMethod(KEYS),
- entries: getIterationMethod(ENTRIES)
- };
- if (FORCED) for (KEY in methods) {
- if (BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME || !(KEY in IterablePrototype)) {
- redefine(IterablePrototype, KEY, methods[KEY]);
- }
- } else $({ target: NAME, proto: true, forced: BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME }, methods);
- }
- return methods;
- };
- /***/ }),
- /* 85 */
- /***/ (function(module, exports) {
- module.exports = function () { /* empty */ };
- /***/ }),
- /* 86 */
- /***/ (function(module, exports, __webpack_require__) {
- var isObject = __webpack_require__(13);
- var isArray = __webpack_require__(52);
- var wellKnownSymbol = __webpack_require__(9);
- var SPECIES = wellKnownSymbol('species');
- // `ArraySpeciesCreate` abstract operation
- // https://tc39.github.io/ecma262/#sec-arrayspeciescreate
- module.exports = function (originalArray, length) {
- var C;
- if (isArray(originalArray)) {
- C = originalArray.constructor;
- // cross-realm fallback
- if (typeof C == 'function' && (C === Array || isArray(C.prototype))) C = undefined;
- else if (isObject(C)) {
- C = C[SPECIES];
- if (C === null) C = undefined;
- }
- } return new (C === undefined ? Array : C)(length === 0 ? 0 : length);
- };
- /***/ }),
- /* 87 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var fails = __webpack_require__(12);
- module.exports = function (METHOD_NAME, argument) {
- var method = [][METHOD_NAME];
- return !!method && fails(function () {
- // eslint-disable-next-line no-useless-call,no-throw-literal
- method.call(null, argument || function () { throw 1; }, 1);
- });
- };
- /***/ }),
- /* 88 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(182);
- /***/ }),
- /* 89 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(187);
- /***/ }),
- /* 90 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(200);
- /***/ }),
- /* 91 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var toPrimitive = __webpack_require__(56);
- var definePropertyModule = __webpack_require__(18);
- var createPropertyDescriptor = __webpack_require__(35);
- module.exports = function (object, key, value) {
- var propertyKey = toPrimitive(key);
- if (propertyKey in object) definePropertyModule.f(object, propertyKey, createPropertyDescriptor(0, value));
- else object[propertyKey] = value;
- };
- /***/ }),
- /* 92 */
- /***/ (function(module, exports, __webpack_require__) {
- var requireObjectCoercible = __webpack_require__(46);
- var whitespaces = __webpack_require__(66);
- var whitespace = '[' + whitespaces + ']';
- var ltrim = RegExp('^' + whitespace + whitespace + '*');
- var rtrim = RegExp(whitespace + whitespace + '*$');
- // `String.prototype.{ trim, trimStart, trimEnd, trimLeft, trimRight }` methods implementation
- var createMethod = function (TYPE) {
- return function ($this) {
- var string = String(requireObjectCoercible($this));
- if (TYPE & 1) string = string.replace(ltrim, '');
- if (TYPE & 2) string = string.replace(rtrim, '');
- return string;
- };
- };
- module.exports = {
- // `String.prototype.{ trimLeft, trimStart }` methods
- // https://tc39.github.io/ecma262/#sec-string.prototype.trimstart
- start: createMethod(1),
- // `String.prototype.{ trimRight, trimEnd }` methods
- // https://tc39.github.io/ecma262/#sec-string.prototype.trimend
- end: createMethod(2),
- // `String.prototype.trim` method
- // https://tc39.github.io/ecma262/#sec-string.prototype.trim
- trim: createMethod(3)
- };
- /***/ }),
- /* 93 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(221);
- /***/ }),
- /* 94 */
- /***/ (function(module, exports, __webpack_require__) {
- var _Symbol$iterator = __webpack_require__(224);
- var _Symbol = __webpack_require__(227);
- function _typeof(obj) {
- "@babel/helpers - typeof";
- if (typeof _Symbol === "function" && typeof _Symbol$iterator === "symbol") {
- module.exports = _typeof = function _typeof(obj) {
- return typeof obj;
- };
- } else {
- module.exports = _typeof = function _typeof(obj) {
- return obj && typeof _Symbol === "function" && obj.constructor === _Symbol && obj !== _Symbol.prototype ? "symbol" : typeof obj;
- };
- }
- return _typeof(obj);
- }
- module.exports = _typeof;
- /***/ }),
- /* 95 */
- /***/ (function(module, exports, __webpack_require__) {
- var wellKnownSymbol = __webpack_require__(9);
- exports.f = wellKnownSymbol;
- /***/ }),
- /* 96 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description Menu class 父类
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var Panel_1 = __importDefault(__webpack_require__(31));
- var Menu =
- /** @class */
- function () {
- function Menu($elem, editor) {
- var _this = this;
- this.$elem = $elem;
- this.editor = editor;
- this._active = false; // 绑定菜单点击事件
- $elem.on('click', function (e) {
- var _context;
- Panel_1["default"].hideCurAllPanels(); // 隐藏当前的所有 Panel
- // 触发菜单点击的钩子
- (0, _forEach["default"])(_context = editor.txt.eventHooks.menuClickEvents).call(_context, function (fn) {
- return fn();
- });
- e.stopPropagation();
- if (editor.selection.getRange() == null) {
- return;
- }
- _this.clickHandler(e);
- });
- }
- /**
- * 菜单点击事件,子类可重写
- * @param e event
- */
- Menu.prototype.clickHandler = function (e) {};
- /**
- * 激活菜单,高亮显示
- */
- Menu.prototype.active = function () {
- this._active = true;
- this.$elem.addClass('w-e-active');
- };
- /**
- * 取消激活,不再高亮显示
- */
- Menu.prototype.unActive = function () {
- this._active = false;
- this.$elem.removeClass('w-e-active');
- };
- (0, _defineProperty["default"])(Menu.prototype, "isActive", {
- /**
- * 是否处于激活状态
- */
- get: function get() {
- return this._active;
- },
- enumerable: false,
- configurable: true
- });
- return Menu;
- }();
- exports["default"] = Menu;
- /***/ }),
- /* 97 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 上传图片
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _indexOf = _interopRequireDefault(__webpack_require__(54));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _bind = _interopRequireDefault(__webpack_require__(88));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- var upload_core_1 = __importDefault(__webpack_require__(334));
- var progress_1 = __importDefault(__webpack_require__(335));
- var UploadImg =
- /** @class */
- function () {
- function UploadImg(editor) {
- this.editor = editor;
- }
- /**
- * 往编辑区域插入图片
- * @param src 图片地址
- */
- UploadImg.prototype.insertImg = function (src) {
- var editor = this.editor;
- var config = editor.config;
- var i18nPrefix = 'validate.';
- var t = function t(text, prefix) {
- if (prefix === void 0) {
- prefix = i18nPrefix;
- }
- return editor.i18next.t(prefix + text);
- }; // 先插入图片,无论是否能成功
- editor.cmd["do"]('insertHTML', "<img src=\"" + src + "\" style=\"max-width:100%;\"/>"); // 执行回调函数
- config.linkImgCallback(src); // 加载图片
- var img = document.createElement('img');
- img.onload = function () {
- img = null;
- };
- img.onerror = function () {
- config.customAlert(t('插入图片错误'), 'error', "wangEditor: " + t('插入图片错误') + "\uFF0C" + t('图片链接') + " \"" + src + "\"\uFF0C" + t('下载链接失败'));
- img = null;
- };
- img.onabort = function () {
- return img = null;
- };
- img.src = src;
- };
- /**
- * 上传图片
- * @param files 文件列表
- */
- UploadImg.prototype.uploadImg = function (files) {
- var _this_1 = this;
- if (!files.length) {
- return;
- }
- var editor = this.editor;
- var config = editor.config; // ------------------------------ i18next ------------------------------
- var i18nPrefix = 'validate.';
- var t = function t(text) {
- return editor.i18next.t(i18nPrefix + text);
- }; // ------------------------------ 获取配置信息 ------------------------------
- // 服务端地址
- var uploadImgServer = config.uploadImgServer; // base64 格式
- var uploadImgShowBase64 = config.uploadImgShowBase64; // 图片最大体积
- var maxSize = config.uploadImgMaxSize;
- var maxSizeM = maxSize / 1024 / 1024; // 一次最多上传图片数量
- var maxLength = config.uploadImgMaxLength; // 自定义 fileName
- var uploadFileName = config.uploadFileName; // 自定义参数
- var uploadImgParams = config.uploadImgParams; // 参数拼接到 url 中
- var uploadImgParamsWithUrl = config.uploadImgParamsWithUrl; // 自定义 header
- var uploadImgHeaders = config.uploadImgHeaders; // 钩子函数
- var hooks = config.uploadImgHooks; // 上传图片超时时间
- var timeout = config.uploadImgTimeout; // 跨域带 cookie
- var withCredentials = config.withCredentials; // 自定义上传图片
- var customUploadImg = config.customUploadImg;
- if (!customUploadImg) {
- // 没有 customUploadImg 的情况下,需要如下两个配置才能继续进行图片上传
- if (!uploadImgServer && !uploadImgShowBase64) {
- return;
- }
- } // ------------------------------ 验证文件信息 ------------------------------
- var resultFiles = [];
- var errInfos = [];
- util_1.arrForEach(files, function (file) {
- var name = file.name;
- var size = file.size; // chrome 低版本 name === undefined
- if (!name || !size) {
- return;
- }
- if (/\.(jpg|jpeg|png|bmp|gif|webp)$/i.test(name) === false) {
- // 后缀名不合法,不是图片
- errInfos.push("\u3010" + name + "\u3011" + t('不是图片'));
- return;
- }
- if (maxSize < size) {
- // 上传图片过大
- errInfos.push("\u3010" + name + "\u3011" + t('大于') + " " + maxSizeM + "M");
- return;
- } // 验证通过的加入结果列表
- resultFiles.push(file);
- }); // 抛出验证信息
- if (errInfos.length) {
- config.customAlert(t('图片验证未通过') + ": \n" + errInfos.join('\n'), 'warning');
- return;
- } // 如果过滤后文件列表为空直接返回
- if (resultFiles.length === 0) {
- config.customAlert(t('传入的文件不合法'), 'warning');
- return;
- }
- if (resultFiles.length > maxLength) {
- config.customAlert(t('一次最多上传') + maxLength + t('张图片'), 'warning');
- return;
- } // ------------------------------ 自定义上传 ------------------------------
- if (customUploadImg && typeof customUploadImg === 'function') {
- var _context;
- customUploadImg(resultFiles, (0, _bind["default"])(_context = this.insertImg).call(_context, this)); // 阻止以下代码执行,重要!!!
- return;
- } // ------------------------------ 上传图片 ------------------------------
- // 添加图片数据
- var formData = new FormData();
- (0, _forEach["default"])(resultFiles).call(resultFiles, function (file, index) {
- var name = uploadFileName || file.name;
- if (resultFiles.length > 1) {
- // 多个文件时,filename 不能重复
- name = name + (index + 1);
- }
- formData.append(name, file);
- });
- if (uploadImgServer) {
- // 添加自定义参数
- var uploadImgServerArr = uploadImgServer.split('#');
- uploadImgServer = uploadImgServerArr[0];
- var uploadImgServerHash = uploadImgServerArr[1] || '';
- (0, _forEach["default"])(util_1).call(util_1, uploadImgParams, function (key, val) {
- // 因使用者反应,自定义参数不能默认 encode ,由 v3.1.1 版本开始注释掉
- // val = encodeURIComponent(val)
- // 第一,将参数拼接到 url 中
- if (uploadImgParamsWithUrl) {
- if ((0, _indexOf["default"])(uploadImgServer).call(uploadImgServer, '?') > 0) {
- uploadImgServer += '&';
- } else {
- uploadImgServer += '?';
- }
- uploadImgServer = uploadImgServer + key + '=' + val;
- } // 第二,将参数添加到 formData 中
- formData.append(key, val);
- });
- if (uploadImgServerHash) {
- uploadImgServer += '#' + uploadImgServerHash;
- } // 开始上传
- var xhr = upload_core_1["default"](uploadImgServer, {
- timeout: timeout,
- formData: formData,
- headers: uploadImgHeaders,
- withCredentials: !!withCredentials,
- beforeSend: function beforeSend(xhr) {
- if (hooks.before) return hooks.before(xhr, editor, resultFiles);
- },
- onTimeout: function onTimeout(xhr) {
- config.customAlert(t('上传图片超时'), 'error');
- if (hooks.timeout) hooks.timeout(xhr, editor);
- },
- onProgress: function onProgress(percent, e) {
- var progressBar = new progress_1["default"](editor);
- if (e.lengthComputable) {
- percent = e.loaded / e.total;
- progressBar.show(percent);
- }
- },
- onError: function onError(xhr) {
- config.customAlert(t('上传图片错误'), 'error', t('上传图片错误') + "\uFF0C" + t('服务器返回状态') + ": " + xhr.status);
- if (hooks.error) hooks.error(xhr, editor);
- },
- onFail: function onFail(xhr, resultStr) {
- config.customAlert(t('上传图片失败'), 'error', t('上传图片返回结果错误') + ("\uFF0C" + t('返回结果') + ": ") + resultStr);
- if (hooks.fail) hooks.fail(xhr, editor, resultStr);
- },
- onSuccess: function onSuccess(xhr, result) {
- if (hooks.customInsert) {
- var _context2;
- // 自定义插入图片
- hooks.customInsert((0, _bind["default"])(_context2 = _this_1.insertImg).call(_context2, _this_1), result, editor);
- return;
- }
- if (result.errno != '0') {
- // 返回格式不对,应该为 { errno: 0, data: [...] }
- config.customAlert(t('上传图片失败'), 'error', t('上传图片返回结果错误') + "\uFF0C" + t('返回结果') + " errno=" + result.errno);
- if (hooks.fail) hooks.fail(xhr, editor, result);
- return;
- } // 成功,插入图片
- var data = result.data;
- (0, _forEach["default"])(data).call(data, function (link) {
- _this_1.insertImg(link);
- }); // 钩子函数
- if (hooks.success) hooks.success(xhr, editor, result);
- }
- });
- if (typeof xhr === 'string') {
- // 上传被阻止
- config.customAlert(xhr, 'error');
- } // 阻止以下代码执行,重要!!!
- return;
- } // ------------------------------ 显示 base64 格式 ------------------------------
- if (uploadImgShowBase64) {
- util_1.arrForEach(files, function (file) {
- var _this = _this_1;
- var reader = new FileReader();
- reader.readAsDataURL(file);
- reader.onload = function () {
- if (!this.result) return;
- _this.insertImg(this.result.toString());
- };
- });
- }
- };
- return UploadImg;
- }();
- exports["default"] = UploadImg;
- /***/ }),
- /* 98 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _slice = _interopRequireDefault(__webpack_require__(43));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _every = _interopRequireDefault(__webpack_require__(380));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.dealTextNode = exports.isAllTodo = exports.isTodo = exports.getCursorNextNode = void 0;
- /**
- * 判断传入的单行顶级选区选取是不是todo
- * @param editor 编辑器对象
- */
- function isTodo($topSelectElem) {
- return $topSelectElem.attr('class') === 'w-e-todo';
- }
- exports.isTodo = isTodo;
- /**
- * 判断选中的内容是不是都是todo
- * @param editor 编辑器对象
- */
- function isAllTodo(editor) {
- var $topSelectElems = editor.selection.getSelectionRangeTopNodes(editor); // 排除为[]的情况
- if ($topSelectElems.length === 0) return;
- return (0, _every["default"])($topSelectElems).call($topSelectElems, function ($topSelectElem) {
- return isTodo($topSelectElem);
- });
- }
- exports.isAllTodo = isAllTodo;
- /**
- * 根据所在的文本节点和光标在文本节点的位置获取截断的后节点内容
- * @param node 顶级节点
- * @param textNode 光标所在的文本节点
- * @param pos 光标在文本节点的位置
- */
- function getCursorNextNode(node, textNode, pos) {
- var _context;
- if (!node.hasChildNodes()) return;
- var newNode = node.cloneNode(); // 判断光标是否在末尾
- var end = false;
- if (textNode.nodeValue === '') {
- end = true;
- }
- var delArr = [];
- (0, _forEach["default"])(_context = node.childNodes).call(_context, function (v) {
- //光标后的内容
- if (!isContains(v, textNode) && end) {
- newNode.appendChild(v.cloneNode(true));
- if (v.nodeName !== 'BR') {
- delArr.push(v);
- }
- } // 光标所在的区域
- if (isContains(v, textNode)) {
- if (v.nodeType === 1) {
- var childNode = getCursorNextNode(v, textNode, pos);
- if (childNode && childNode.textContent !== '') newNode === null || newNode === void 0 ? void 0 : newNode.appendChild(childNode);
- }
- if (v.nodeType === 3) {
- if (textNode.isEqualNode(v)) {
- var textContent = dealTextNode(v, pos);
- newNode.textContent = textContent;
- }
- }
- end = true;
- }
- }); // 删除选中后原来的节点
- (0, _forEach["default"])(delArr).call(delArr, function (v) {
- var node = v;
- node.remove();
- });
- return newNode;
- }
- exports.getCursorNextNode = getCursorNextNode;
- /**
- * 判断otherNode是否包含在node中
- * @param node 父节点
- * @param otherNode 需要判断是不是被包含的节点
- */
- function isContains(node, otherNode) {
- // 兼容ie11中textNode不支持contains方法
- if (node.nodeType === 3) {
- return node.nodeValue === otherNode.nodeValue;
- }
- return node.contains(otherNode);
- }
- /**
- * 获取新的文本节点
- * @param node 要处理的文本节点
- * @param pos 光标在文本节点所在的位置
- * @param start 设置为true时保留开始位置到光标的内容,设置为false时删去开始的内容
- */
- function dealTextNode(node, pos, start) {
- if (start === void 0) {
- start = true;
- }
- var content = node.nodeValue;
- var oldContent = content === null || content === void 0 ? void 0 : (0, _slice["default"])(content).call(content, 0, pos);
- content = content === null || content === void 0 ? void 0 : (0, _slice["default"])(content).call(content, pos); // start为false时替换content和oldContent
- if (!start) {
- var temp = content;
- content = oldContent;
- oldContent = temp;
- }
- node.nodeValue = oldContent;
- return content;
- }
- exports.dealTextNode = dealTextNode;
- /***/ }),
- /* 99 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 双栈实现撤销恢复
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var stack_1 = __webpack_require__(400);
- var Cache =
- /** @class */
- function () {
- function Cache(maxSize) {
- this.maxSize = maxSize;
- /**
- * 上一步操作是否为 撤销/恢复
- */
- this.isRe = false;
- this.data = new stack_1.CeilStack(maxSize);
- this.revokeData = new stack_1.CeilStack(maxSize);
- }
- (0, _defineProperty["default"])(Cache.prototype, "size", {
- /**
- * 返回当前栈中的数据长度。格式为:[正常的数据的条数,被撤销的数据的条数]
- */
- get: function get() {
- return [this.data.size, this.revokeData.size];
- },
- enumerable: false,
- configurable: true
- });
- /**
- * 重设数据缓存器的缓存长度(第一次有效)
- */
- Cache.prototype.resetMaxSize = function (maxSize) {
- this.data.resetMax(maxSize);
- this.revokeData.resetMax(maxSize);
- };
- /**
- * 保存数据
- */
- Cache.prototype.save = function (data) {
- if (this.isRe) {
- this.revokeData.clear();
- this.isRe = false;
- }
- this.data.instack(data);
- return this;
- };
- /**
- * 撤销
- * @param fn 撤销时,如果有数据,执行的回调函数
- */
- Cache.prototype.revoke = function (fn) {
- !this.isRe && (this.isRe = true);
- var data = this.data.outstack();
- if (data) {
- this.revokeData.instack(data);
- fn(data);
- return true;
- }
- return false;
- };
- /**
- * 恢复
- * @param fn 恢复时,如果有数据,执行的回调函数
- */
- Cache.prototype.restore = function (fn) {
- !this.isRe && (this.isRe = true);
- var data = this.revokeData.outstack();
- if (data) {
- this.data.instack(data);
- fn(data);
- return true;
- }
- return false;
- };
- return Cache;
- }();
- exports["default"] = Cache;
- /***/ }),
- /* 100 */
- /***/ (function(module, exports, __webpack_require__) {
- var DESCRIPTORS = __webpack_require__(14);
- var fails = __webpack_require__(12);
- var createElement = __webpack_require__(69);
- // Thank's IE8 for his funny defineProperty
- module.exports = !DESCRIPTORS && !fails(function () {
- return Object.defineProperty(createElement('div'), 'a', {
- get: function () { return 7; }
- }).a != 7;
- });
- /***/ }),
- /* 101 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- var replacement = /#|\.prototype\./;
- var isForced = function (feature, detection) {
- var value = data[normalize(feature)];
- return value == POLYFILL ? true
- : value == NATIVE ? false
- : typeof detection == 'function' ? fails(detection)
- : !!detection;
- };
- var normalize = isForced.normalize = function (string) {
- return String(string).replace(replacement, '.').toLowerCase();
- };
- var data = isForced.data = {};
- var NATIVE = isForced.NATIVE = 'N';
- var POLYFILL = isForced.POLYFILL = 'P';
- module.exports = isForced;
- /***/ }),
- /* 102 */
- /***/ (function(module, exports, __webpack_require__) {
- var has = __webpack_require__(15);
- var toIndexedObject = __webpack_require__(27);
- var indexOf = __webpack_require__(70).indexOf;
- var hiddenKeys = __webpack_require__(49);
- module.exports = function (object, names) {
- var O = toIndexedObject(object);
- var i = 0;
- var result = [];
- var key;
- for (key in O) !has(hiddenKeys, key) && has(O, key) && result.push(key);
- // Don't enum bug & hidden keys
- while (names.length > i) if (has(O, key = names[i++])) {
- ~indexOf(result, key) || result.push(key);
- }
- return result;
- };
- /***/ }),
- /* 103 */
- /***/ (function(module, exports, __webpack_require__) {
- var getBuiltIn = __webpack_require__(28);
- module.exports = getBuiltIn('document', 'documentElement');
- /***/ }),
- /* 104 */
- /***/ (function(module, exports, __webpack_require__) {
- var NATIVE_SYMBOL = __webpack_require__(77);
- module.exports = NATIVE_SYMBOL
- // eslint-disable-next-line no-undef
- && !Symbol.sham
- // eslint-disable-next-line no-undef
- && typeof Symbol.iterator == 'symbol';
- /***/ }),
- /* 105 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- module.exports = global.Promise;
- /***/ }),
- /* 106 */
- /***/ (function(module, exports, __webpack_require__) {
- var redefine = __webpack_require__(50);
- module.exports = function (target, src, options) {
- for (var key in src) {
- if (options && options.unsafe && target[key]) target[key] = src[key];
- else redefine(target, key, src[key], options);
- } return target;
- };
- /***/ }),
- /* 107 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var getBuiltIn = __webpack_require__(28);
- var definePropertyModule = __webpack_require__(18);
- var wellKnownSymbol = __webpack_require__(9);
- var DESCRIPTORS = __webpack_require__(14);
- var SPECIES = wellKnownSymbol('species');
- module.exports = function (CONSTRUCTOR_NAME) {
- var Constructor = getBuiltIn(CONSTRUCTOR_NAME);
- var defineProperty = definePropertyModule.f;
- if (DESCRIPTORS && Constructor && !Constructor[SPECIES]) {
- defineProperty(Constructor, SPECIES, {
- configurable: true,
- get: function () { return this; }
- });
- }
- };
- /***/ }),
- /* 108 */
- /***/ (function(module, exports, __webpack_require__) {
- var store = __webpack_require__(74);
- var functionToString = Function.toString;
- // this helper broken in `3.4.1-3.4.4`, so we can't use `shared` helper
- if (typeof store.inspectSource != 'function') {
- store.inspectSource = function (it) {
- return functionToString.call(it);
- };
- }
- module.exports = store.inspectSource;
- /***/ }),
- /* 109 */
- /***/ (function(module, exports, __webpack_require__) {
- var anObject = __webpack_require__(24);
- var aFunction = __webpack_require__(32);
- var wellKnownSymbol = __webpack_require__(9);
- var SPECIES = wellKnownSymbol('species');
- // `SpeciesConstructor` abstract operation
- // https://tc39.github.io/ecma262/#sec-speciesconstructor
- module.exports = function (O, defaultConstructor) {
- var C = anObject(O).constructor;
- var S;
- return C === undefined || (S = anObject(C)[SPECIES]) == undefined ? defaultConstructor : aFunction(S);
- };
- /***/ }),
- /* 110 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var fails = __webpack_require__(12);
- var bind = __webpack_require__(47);
- var html = __webpack_require__(103);
- var createElement = __webpack_require__(69);
- var IS_IOS = __webpack_require__(111);
- var IS_NODE = __webpack_require__(81);
- var location = global.location;
- var set = global.setImmediate;
- var clear = global.clearImmediate;
- var process = global.process;
- var MessageChannel = global.MessageChannel;
- var Dispatch = global.Dispatch;
- var counter = 0;
- var queue = {};
- var ONREADYSTATECHANGE = 'onreadystatechange';
- var defer, channel, port;
- var run = function (id) {
- // eslint-disable-next-line no-prototype-builtins
- if (queue.hasOwnProperty(id)) {
- var fn = queue[id];
- delete queue[id];
- fn();
- }
- };
- var runner = function (id) {
- return function () {
- run(id);
- };
- };
- var listener = function (event) {
- run(event.data);
- };
- var post = function (id) {
- // old engines have not location.origin
- global.postMessage(id + '', location.protocol + '//' + location.host);
- };
- // Node.js 0.9+ & IE10+ has setImmediate, otherwise:
- if (!set || !clear) {
- set = function setImmediate(fn) {
- var args = [];
- var i = 1;
- while (arguments.length > i) args.push(arguments[i++]);
- queue[++counter] = function () {
- // eslint-disable-next-line no-new-func
- (typeof fn == 'function' ? fn : Function(fn)).apply(undefined, args);
- };
- defer(counter);
- return counter;
- };
- clear = function clearImmediate(id) {
- delete queue[id];
- };
- // Node.js 0.8-
- if (IS_NODE) {
- defer = function (id) {
- process.nextTick(runner(id));
- };
- // Sphere (JS game engine) Dispatch API
- } else if (Dispatch && Dispatch.now) {
- defer = function (id) {
- Dispatch.now(runner(id));
- };
- // Browsers with MessageChannel, includes WebWorkers
- // except iOS - https://github.com/zloirock/core-js/issues/624
- } else if (MessageChannel && !IS_IOS) {
- channel = new MessageChannel();
- port = channel.port2;
- channel.port1.onmessage = listener;
- defer = bind(port.postMessage, port, 1);
- // Browsers with postMessage, skip WebWorkers
- // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'
- } else if (
- global.addEventListener &&
- typeof postMessage == 'function' &&
- !global.importScripts &&
- location && location.protocol !== 'file:' &&
- !fails(post)
- ) {
- defer = post;
- global.addEventListener('message', listener, false);
- // IE8-
- } else if (ONREADYSTATECHANGE in createElement('script')) {
- defer = function (id) {
- html.appendChild(createElement('script'))[ONREADYSTATECHANGE] = function () {
- html.removeChild(this);
- run(id);
- };
- };
- // Rest old browsers
- } else {
- defer = function (id) {
- setTimeout(runner(id), 0);
- };
- }
- }
- module.exports = {
- set: set,
- clear: clear
- };
- /***/ }),
- /* 111 */
- /***/ (function(module, exports, __webpack_require__) {
- var userAgent = __webpack_require__(80);
- module.exports = /(iphone|ipod|ipad).*applewebkit/i.test(userAgent);
- /***/ }),
- /* 112 */
- /***/ (function(module, exports, __webpack_require__) {
- var anObject = __webpack_require__(24);
- var isObject = __webpack_require__(13);
- var newPromiseCapability = __webpack_require__(63);
- module.exports = function (C, x) {
- anObject(C);
- if (isObject(x) && x.constructor === C) return x;
- var promiseCapability = newPromiseCapability.f(C);
- var resolve = promiseCapability.resolve;
- resolve(x);
- return promiseCapability.promise;
- };
- /***/ }),
- /* 113 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var getPrototypeOf = __webpack_require__(75);
- var createNonEnumerableProperty = __webpack_require__(17);
- var has = __webpack_require__(15);
- var wellKnownSymbol = __webpack_require__(9);
- var IS_PURE = __webpack_require__(37);
- var ITERATOR = wellKnownSymbol('iterator');
- var BUGGY_SAFARI_ITERATORS = false;
- var returnThis = function () { return this; };
- // `%IteratorPrototype%` object
- // https://tc39.github.io/ecma262/#sec-%iteratorprototype%-object
- var IteratorPrototype, PrototypeOfArrayIteratorPrototype, arrayIterator;
- if ([].keys) {
- arrayIterator = [].keys();
- // Safari 8 has buggy iterators w/o `next`
- if (!('next' in arrayIterator)) BUGGY_SAFARI_ITERATORS = true;
- else {
- PrototypeOfArrayIteratorPrototype = getPrototypeOf(getPrototypeOf(arrayIterator));
- if (PrototypeOfArrayIteratorPrototype !== Object.prototype) IteratorPrototype = PrototypeOfArrayIteratorPrototype;
- }
- }
- if (IteratorPrototype == undefined) IteratorPrototype = {};
- // 25.1.2.1.1 %IteratorPrototype%[@@iterator]()
- if (!IS_PURE && !has(IteratorPrototype, ITERATOR)) {
- createNonEnumerableProperty(IteratorPrototype, ITERATOR, returnThis);
- }
- module.exports = {
- IteratorPrototype: IteratorPrototype,
- BUGGY_SAFARI_ITERATORS: BUGGY_SAFARI_ITERATORS
- };
- /***/ }),
- /* 114 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(208);
- /***/ }),
- /* 115 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var global = __webpack_require__(8);
- var InternalMetadataModule = __webpack_require__(116);
- var fails = __webpack_require__(12);
- var createNonEnumerableProperty = __webpack_require__(17);
- var iterate = __webpack_require__(39);
- var anInstance = __webpack_require__(79);
- var isObject = __webpack_require__(13);
- var setToStringTag = __webpack_require__(41);
- var defineProperty = __webpack_require__(18).f;
- var forEach = __webpack_require__(33).forEach;
- var DESCRIPTORS = __webpack_require__(14);
- var InternalStateModule = __webpack_require__(42);
- var setInternalState = InternalStateModule.set;
- var internalStateGetterFor = InternalStateModule.getterFor;
- module.exports = function (CONSTRUCTOR_NAME, wrapper, common) {
- var IS_MAP = CONSTRUCTOR_NAME.indexOf('Map') !== -1;
- var IS_WEAK = CONSTRUCTOR_NAME.indexOf('Weak') !== -1;
- var ADDER = IS_MAP ? 'set' : 'add';
- var NativeConstructor = global[CONSTRUCTOR_NAME];
- var NativePrototype = NativeConstructor && NativeConstructor.prototype;
- var exported = {};
- var Constructor;
- if (!DESCRIPTORS || typeof NativeConstructor != 'function'
- || !(IS_WEAK || NativePrototype.forEach && !fails(function () { new NativeConstructor().entries().next(); }))
- ) {
- // create collection constructor
- Constructor = common.getConstructor(wrapper, CONSTRUCTOR_NAME, IS_MAP, ADDER);
- InternalMetadataModule.REQUIRED = true;
- } else {
- Constructor = wrapper(function (target, iterable) {
- setInternalState(anInstance(target, Constructor, CONSTRUCTOR_NAME), {
- type: CONSTRUCTOR_NAME,
- collection: new NativeConstructor()
- });
- if (iterable != undefined) iterate(iterable, target[ADDER], { that: target, AS_ENTRIES: IS_MAP });
- });
- var getInternalState = internalStateGetterFor(CONSTRUCTOR_NAME);
- forEach(['add', 'clear', 'delete', 'forEach', 'get', 'has', 'set', 'keys', 'values', 'entries'], function (KEY) {
- var IS_ADDER = KEY == 'add' || KEY == 'set';
- if (KEY in NativePrototype && !(IS_WEAK && KEY == 'clear')) {
- createNonEnumerableProperty(Constructor.prototype, KEY, function (a, b) {
- var collection = getInternalState(this).collection;
- if (!IS_ADDER && IS_WEAK && !isObject(a)) return KEY == 'get' ? undefined : false;
- var result = collection[KEY](a === 0 ? 0 : a, b);
- return IS_ADDER ? this : result;
- });
- }
- });
- IS_WEAK || defineProperty(Constructor.prototype, 'size', {
- configurable: true,
- get: function () {
- return getInternalState(this).collection.size;
- }
- });
- }
- setToStringTag(Constructor, CONSTRUCTOR_NAME, false, true);
- exported[CONSTRUCTOR_NAME] = Constructor;
- $({ global: true, forced: true }, exported);
- if (!IS_WEAK) common.setStrong(Constructor, CONSTRUCTOR_NAME, IS_MAP);
- return Constructor;
- };
- /***/ }),
- /* 116 */
- /***/ (function(module, exports, __webpack_require__) {
- var hiddenKeys = __webpack_require__(49);
- var isObject = __webpack_require__(13);
- var has = __webpack_require__(15);
- var defineProperty = __webpack_require__(18).f;
- var uid = __webpack_require__(60);
- var FREEZING = __webpack_require__(211);
- var METADATA = uid('meta');
- var id = 0;
- var isExtensible = Object.isExtensible || function () {
- return true;
- };
- var setMetadata = function (it) {
- defineProperty(it, METADATA, { value: {
- objectID: 'O' + ++id, // object ID
- weakData: {} // weak collections IDs
- } });
- };
- var fastKey = function (it, create) {
- // return a primitive with prefix
- if (!isObject(it)) return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;
- if (!has(it, METADATA)) {
- // can't set metadata to uncaught frozen object
- if (!isExtensible(it)) return 'F';
- // not necessary to add metadata
- if (!create) return 'E';
- // add missing metadata
- setMetadata(it);
- // return object ID
- } return it[METADATA].objectID;
- };
- var getWeakData = function (it, create) {
- if (!has(it, METADATA)) {
- // can't set metadata to uncaught frozen object
- if (!isExtensible(it)) return true;
- // not necessary to add metadata
- if (!create) return false;
- // add missing metadata
- setMetadata(it);
- // return the store of weak collections IDs
- } return it[METADATA].weakData;
- };
- // add metadata on freeze-family methods calling
- var onFreeze = function (it) {
- if (FREEZING && meta.REQUIRED && isExtensible(it) && !has(it, METADATA)) setMetadata(it);
- return it;
- };
- var meta = module.exports = {
- REQUIRED: false,
- fastKey: fastKey,
- getWeakData: getWeakData,
- onFreeze: onFreeze
- };
- hiddenKeys[METADATA] = true;
- /***/ }),
- /* 117 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var defineProperty = __webpack_require__(18).f;
- var create = __webpack_require__(48);
- var redefineAll = __webpack_require__(106);
- var bind = __webpack_require__(47);
- var anInstance = __webpack_require__(79);
- var iterate = __webpack_require__(39);
- var defineIterator = __webpack_require__(84);
- var setSpecies = __webpack_require__(107);
- var DESCRIPTORS = __webpack_require__(14);
- var fastKey = __webpack_require__(116).fastKey;
- var InternalStateModule = __webpack_require__(42);
- var setInternalState = InternalStateModule.set;
- var internalStateGetterFor = InternalStateModule.getterFor;
- module.exports = {
- getConstructor: function (wrapper, CONSTRUCTOR_NAME, IS_MAP, ADDER) {
- var C = wrapper(function (that, iterable) {
- anInstance(that, C, CONSTRUCTOR_NAME);
- setInternalState(that, {
- type: CONSTRUCTOR_NAME,
- index: create(null),
- first: undefined,
- last: undefined,
- size: 0
- });
- if (!DESCRIPTORS) that.size = 0;
- if (iterable != undefined) iterate(iterable, that[ADDER], { that: that, AS_ENTRIES: IS_MAP });
- });
- var getInternalState = internalStateGetterFor(CONSTRUCTOR_NAME);
- var define = function (that, key, value) {
- var state = getInternalState(that);
- var entry = getEntry(that, key);
- var previous, index;
- // change existing entry
- if (entry) {
- entry.value = value;
- // create new entry
- } else {
- state.last = entry = {
- index: index = fastKey(key, true),
- key: key,
- value: value,
- previous: previous = state.last,
- next: undefined,
- removed: false
- };
- if (!state.first) state.first = entry;
- if (previous) previous.next = entry;
- if (DESCRIPTORS) state.size++;
- else that.size++;
- // add to index
- if (index !== 'F') state.index[index] = entry;
- } return that;
- };
- var getEntry = function (that, key) {
- var state = getInternalState(that);
- // fast case
- var index = fastKey(key);
- var entry;
- if (index !== 'F') return state.index[index];
- // frozen object case
- for (entry = state.first; entry; entry = entry.next) {
- if (entry.key == key) return entry;
- }
- };
- redefineAll(C.prototype, {
- // 23.1.3.1 Map.prototype.clear()
- // 23.2.3.2 Set.prototype.clear()
- clear: function clear() {
- var that = this;
- var state = getInternalState(that);
- var data = state.index;
- var entry = state.first;
- while (entry) {
- entry.removed = true;
- if (entry.previous) entry.previous = entry.previous.next = undefined;
- delete data[entry.index];
- entry = entry.next;
- }
- state.first = state.last = undefined;
- if (DESCRIPTORS) state.size = 0;
- else that.size = 0;
- },
- // 23.1.3.3 Map.prototype.delete(key)
- // 23.2.3.4 Set.prototype.delete(value)
- 'delete': function (key) {
- var that = this;
- var state = getInternalState(that);
- var entry = getEntry(that, key);
- if (entry) {
- var next = entry.next;
- var prev = entry.previous;
- delete state.index[entry.index];
- entry.removed = true;
- if (prev) prev.next = next;
- if (next) next.previous = prev;
- if (state.first == entry) state.first = next;
- if (state.last == entry) state.last = prev;
- if (DESCRIPTORS) state.size--;
- else that.size--;
- } return !!entry;
- },
- // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)
- // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)
- forEach: function forEach(callbackfn /* , that = undefined */) {
- var state = getInternalState(this);
- var boundFunction = bind(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3);
- var entry;
- while (entry = entry ? entry.next : state.first) {
- boundFunction(entry.value, entry.key, this);
- // revert to the last existing entry
- while (entry && entry.removed) entry = entry.previous;
- }
- },
- // 23.1.3.7 Map.prototype.has(key)
- // 23.2.3.7 Set.prototype.has(value)
- has: function has(key) {
- return !!getEntry(this, key);
- }
- });
- redefineAll(C.prototype, IS_MAP ? {
- // 23.1.3.6 Map.prototype.get(key)
- get: function get(key) {
- var entry = getEntry(this, key);
- return entry && entry.value;
- },
- // 23.1.3.9 Map.prototype.set(key, value)
- set: function set(key, value) {
- return define(this, key === 0 ? 0 : key, value);
- }
- } : {
- // 23.2.3.1 Set.prototype.add(value)
- add: function add(value) {
- return define(this, value = value === 0 ? 0 : value, value);
- }
- });
- if (DESCRIPTORS) defineProperty(C.prototype, 'size', {
- get: function () {
- return getInternalState(this).size;
- }
- });
- return C;
- },
- setStrong: function (C, CONSTRUCTOR_NAME, IS_MAP) {
- var ITERATOR_NAME = CONSTRUCTOR_NAME + ' Iterator';
- var getInternalCollectionState = internalStateGetterFor(CONSTRUCTOR_NAME);
- var getInternalIteratorState = internalStateGetterFor(ITERATOR_NAME);
- // add .keys, .values, .entries, [@@iterator]
- // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11
- defineIterator(C, CONSTRUCTOR_NAME, function (iterated, kind) {
- setInternalState(this, {
- type: ITERATOR_NAME,
- target: iterated,
- state: getInternalCollectionState(iterated),
- kind: kind,
- last: undefined
- });
- }, function () {
- var state = getInternalIteratorState(this);
- var kind = state.kind;
- var entry = state.last;
- // revert to the last existing entry
- while (entry && entry.removed) entry = entry.previous;
- // get next entry
- if (!state.target || !(state.last = entry = entry ? entry.next : state.state.first)) {
- // or finish the iteration
- state.target = undefined;
- return { value: undefined, done: true };
- }
- // return step by kind
- if (kind == 'keys') return { value: entry.key, done: false };
- if (kind == 'values') return { value: entry.value, done: false };
- return { value: [entry.key, entry.value], done: false };
- }, IS_MAP ? 'entries' : 'values', !IS_MAP, true);
- // add [@@species], 23.1.2.2, 23.2.2.2
- setSpecies(CONSTRUCTOR_NAME);
- }
- };
- /***/ }),
- /* 118 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.iterator` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.iterator
- defineWellKnownSymbol('iterator');
- /***/ }),
- /* 119 */
- /***/ (function(module, exports, __webpack_require__) {
- var internalObjectKeys = __webpack_require__(102);
- var enumBugKeys = __webpack_require__(72);
- var hiddenKeys = enumBugKeys.concat('length', 'prototype');
- // `Object.getOwnPropertyNames` method
- // https://tc39.github.io/ecma262/#sec-object.getownpropertynames
- exports.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {
- return internalObjectKeys(O, hiddenKeys);
- };
- /***/ }),
- /* 120 */
- /***/ (function(module, exports) {
- exports.f = Object.getOwnPropertySymbols;
- /***/ }),
- /* 121 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(254);
- /***/ }),
- /* 122 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 样式配置
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports["default"] = {
- zIndex: 10000
- };
- /***/ }),
- /* 123 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 处理粘贴逻辑
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.getPasteImgs = exports.getPasteHtml = exports.getPasteText = void 0;
- var util_1 = __webpack_require__(7);
- var parse_html_1 = __importDefault(__webpack_require__(293));
- /**
- * 获取粘贴的纯文本
- * @param e Event 参数
- */
- function getPasteText(e) {
- // const clipboardData = e.clipboardData || (e.originalEvent && e.originalEvent.clipboardData)
- var clipboardData = e.clipboardData; // 暂不考虑 originalEvent 的情况
- var pasteText = '';
- if (clipboardData == null) {
- pasteText = window.clipboardData && window.clipboardData.getData('text');
- } else {
- pasteText = clipboardData.getData('text/plain');
- }
- return util_1.replaceHtmlSymbol(pasteText);
- }
- exports.getPasteText = getPasteText;
- /**
- * 获取粘贴的 html 字符串
- * @param e Event 参数
- * @param filterStyle 是否过滤 style 样式
- * @param ignoreImg 是否忽略 img 标签
- */
- function getPasteHtml(e, filterStyle, ignoreImg) {
- if (filterStyle === void 0) {
- filterStyle = true;
- }
- if (ignoreImg === void 0) {
- ignoreImg = false;
- }
- var clipboardData = e.clipboardData; // 暂不考虑 originalEvent 的情况
- var pasteHtml = '';
- if (clipboardData) {
- pasteHtml = clipboardData.getData('text/html');
- } // 无法通过 'text/html' 格式获取 html,则尝试获取 text
- if (!pasteHtml) {
- var text = getPasteText(e);
- if (!text) {
- return ''; // 没有找到任何文字,则返回
- }
- pasteHtml = "<p>" + text + "</p>";
- } // 剔除多余的标签、属性
- pasteHtml = parse_html_1["default"](pasteHtml, filterStyle, ignoreImg);
- return pasteHtml;
- }
- exports.getPasteHtml = getPasteHtml;
- /**
- * 获取粘贴的图片文件
- * @param e Event 参数
- */
- function getPasteImgs(e) {
- var _a;
- var result = [];
- var txt = getPasteText(e);
- if (txt) {
- // 有文字,就忽略图片
- return result;
- }
- var items = (_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.items;
- if (!items) return result;
- (0, _forEach["default"])(util_1).call(util_1, items, function (key, value) {
- var type = value.type;
- if (/image/i.test(type)) {
- result.push(value.getAsFile());
- }
- });
- return result;
- }
- exports.getPasteImgs = getPasteImgs;
- /***/ }),
- /* 124 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(295);
- /***/ }),
- /* 125 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 下拉列表 class
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var const_1 = __webpack_require__(26);
- var DropList =
- /** @class */
- function () {
- function DropList(menu, conf) {
- var _this = this;
- this.hideTimeoutId = 0;
- this.showTimeoutId = 0;
- this.menu = menu;
- this.conf = conf; // 容器
- var $container = dom_core_1["default"]('<div class="w-e-droplist"></div>'); // 标题
- var $title = dom_core_1["default"]("<p>" + conf.title + "</p>");
- $title.addClass('w-e-dp-title');
- $container.append($title); // 列表和类型
- var list = conf.list || [];
- var type = conf.type || 'list'; // item 的点击事件
- var clickHandler = conf.clickHandler || const_1.EMPTY_FN; // 加入 DOM 并绑定事件
- var $list = dom_core_1["default"]('<ul class="' + (type === 'list' ? 'w-e-list' : 'w-e-block') + '"></ul>');
- (0, _forEach["default"])(list).call(list, function (item) {
- var $elem = item.$elem;
- var value = item.value;
- var $li = dom_core_1["default"]('<li class="w-e-item"></li>');
- if ($elem) {
- $li.append($elem);
- $list.append($li);
- $li.on('click', function () {
- clickHandler(value); // item 点击之后,隐藏 list
- _this.hideTimeoutId = window.setTimeout(function () {
- _this.hide();
- });
- });
- }
- });
- $container.append($list); // 绑定隐藏事件
- $container.on('mouseleave', function () {
- _this.hideTimeoutId = window.setTimeout(function () {
- _this.hide();
- });
- }); // 记录属性
- this.$container = $container;
- this.rendered = false;
- this._show = false;
- }
- /**
- * 显示 DropList
- */
- DropList.prototype.show = function () {
- if (this.hideTimeoutId) {
- // 清除之前的定时隐藏
- clearTimeout(this.hideTimeoutId);
- }
- var menu = this.menu;
- var $menuELem = menu.$elem;
- var $container = this.$container;
- if (this._show) {
- return;
- }
- if (this.rendered) {
- // 显示
- $container.show();
- } else {
- // 加入 DOM 之前先定位位置
- var menuHeight = $menuELem.getSizeData().height || 0;
- var width = this.conf.width || 100; // 默认为 100
- $container.css('margin-top', menuHeight + 'px').css('width', width + 'px'); // 加入到 DOM
- $menuELem.append($container);
- this.rendered = true;
- } // 修改属性
- this._show = true;
- };
- /**
- * 隐藏 DropList
- */
- DropList.prototype.hide = function () {
- if (this.showTimeoutId) {
- // 清除之前的定时显示
- clearTimeout(this.showTimeoutId);
- }
- var $container = this.$container;
- if (!this._show) {
- return;
- } // 隐藏并需改属性
- $container.hide();
- this._show = false;
- };
- (0, _defineProperty["default"])(DropList.prototype, "isShow", {
- get: function get() {
- return this._show;
- },
- enumerable: false,
- configurable: true
- });
- return DropList;
- }();
- exports["default"] = DropList;
- /***/ }),
- /* 126 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 检查选区是否在链接中,即菜单是否应该 active
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- function isActive(editor) {
- var $selectionELem = editor.selection.getSelectionContainerElem();
- if (!$selectionELem) {
- return false;
- }
- if ($selectionELem.getNodeName() === 'A') {
- return true;
- } else {
- return false;
- }
- }
- exports["default"] = isActive;
- /***/ }),
- /* 127 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 检查选区是否在代码中,即菜单是否应该 active
- * @author lkw
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- function isActive(editor) {
- var $selectionELem = editor.selection.getSelectionContainerElem();
- if (!$selectionELem) {
- return false;
- }
- if ($selectionELem.getNodeName() == 'CODE' || $selectionELem.getNodeName() == 'PRE' || $selectionELem.parent().getNodeName() == 'CODE' || $selectionELem.parent().getNodeName() == 'PRE' || /hljs/.test($selectionELem.parent().attr('class'))) {
- return true;
- } else {
- return false;
- }
- }
- exports["default"] = isActive;
- /***/ }),
- /* 128 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.todo = void 0;
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var todo =
- /** @class */
- function () {
- function todo($orginElem) {
- var _a;
- this.template = "<ul class=\"w-e-todo\"><li><span contenteditable=\"false\"><input type=\"checkbox\"></span></li></ul>";
- this.checked = false;
- this.$todo = dom_core_1["default"](this.template);
- this.$child = (_a = $orginElem === null || $orginElem === void 0 ? void 0 : $orginElem.childNodes()) === null || _a === void 0 ? void 0 : _a.clone(true);
- }
- todo.prototype.init = function () {
- var _this = this;
- var $input = this.getInput();
- var $child = this.$child;
- var $inputContainer = this.getInputContainer();
- if ($child) {
- $child.insertAfter($inputContainer);
- }
- $input.on('click', function () {
- if (_this.checked) {
- $input === null || $input === void 0 ? void 0 : $input.removeAttr('checked');
- } else {
- $input === null || $input === void 0 ? void 0 : $input.attr('checked', '');
- }
- _this.checked = !_this.checked;
- });
- };
- todo.prototype.getInput = function () {
- var $todo = this.$todo;
- var $input = (0, _find["default"])($todo).call($todo, 'input');
- return $input;
- };
- todo.prototype.getInputContainer = function () {
- var $inputContainer = this.getInput().parent();
- return $inputContainer;
- };
- todo.prototype.getTodo = function () {
- return this.$todo;
- };
- return todo;
- }();
- exports.todo = todo;
- function createTodo($orginElem) {
- var t = new todo($orginElem);
- t.init();
- return t;
- }
- exports["default"] = createTodo;
- /***/ }),
- /* 129 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 入口文件
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var __createBinding = void 0 && (void 0).__createBinding || (_create["default"] ? function (o, m, k, k2) {
- if (k2 === undefined) k2 = k;
- (0, _defineProperty["default"])(o, k2, {
- enumerable: true,
- get: function get() {
- return m[k];
- }
- });
- } : function (o, m, k, k2) {
- if (k2 === undefined) k2 = k;
- o[k2] = m[k];
- });
- var __exportStar = void 0 && (void 0).__exportStar || function (m, exports) {
- for (var p in m) {
- if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
- }
- };
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- __webpack_require__(139);
- __webpack_require__(141);
- __webpack_require__(145);
- __webpack_require__(147);
- __webpack_require__(149);
- __webpack_require__(151);
- __webpack_require__(153);
- var index_1 = __importDefault(__webpack_require__(176));
- __exportStar(__webpack_require__(415), exports); // 检验是否浏览器环境
- try {
- document;
- } catch (ex) {
- throw new Error('请在浏览器环境下运行');
- }
- exports["default"] = index_1["default"];
- /***/ }),
- /* 130 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(131);
- module.exports = parent;
- /***/ }),
- /* 131 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(132);
- var path = __webpack_require__(10);
- var Object = path.Object;
- var defineProperty = module.exports = function defineProperty(it, key, desc) {
- return Object.defineProperty(it, key, desc);
- };
- if (Object.defineProperty.sham) defineProperty.sham = true;
- /***/ }),
- /* 132 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var DESCRIPTORS = __webpack_require__(14);
- var objectDefinePropertyModile = __webpack_require__(18);
- // `Object.defineProperty` method
- // https://tc39.github.io/ecma262/#sec-object.defineproperty
- $({ target: 'Object', stat: true, forced: !DESCRIPTORS, sham: !DESCRIPTORS }, {
- defineProperty: objectDefinePropertyModile.f
- });
- /***/ }),
- /* 133 */
- /***/ (function(module, exports) {
- var g;
- // This works in non-strict mode
- g = (function() {
- return this;
- })();
- try {
- // This works if eval is allowed (see CSP)
- g = g || new Function("return this")();
- } catch (e) {
- // This works if the window reference is available
- if (typeof window === "object") g = window;
- }
- // g can still be undefined, but nothing to do about it...
- // We return undefined, instead of nothing here, so it's
- // easier to handle this case. if(!global) { ...}
- module.exports = g;
- /***/ }),
- /* 134 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(135);
- module.exports = parent;
- /***/ }),
- /* 135 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(136);
- var path = __webpack_require__(10);
- var Object = path.Object;
- module.exports = function create(P, D) {
- return Object.create(P, D);
- };
- /***/ }),
- /* 136 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var DESCRIPTORS = __webpack_require__(14);
- var create = __webpack_require__(48);
- // `Object.create` method
- // https://tc39.github.io/ecma262/#sec-object.create
- $({ target: 'Object', stat: true, sham: !DESCRIPTORS }, {
- create: create
- });
- /***/ }),
- /* 137 */
- /***/ (function(module, exports, __webpack_require__) {
- var DESCRIPTORS = __webpack_require__(14);
- var definePropertyModule = __webpack_require__(18);
- var anObject = __webpack_require__(24);
- var objectKeys = __webpack_require__(57);
- // `Object.defineProperties` method
- // https://tc39.github.io/ecma262/#sec-object.defineproperties
- module.exports = DESCRIPTORS ? Object.defineProperties : function defineProperties(O, Properties) {
- anObject(O);
- var keys = objectKeys(Properties);
- var length = keys.length;
- var index = 0;
- var key;
- while (length > index) definePropertyModule.f(O, key = keys[index++], Properties[key]);
- return O;
- };
- /***/ }),
- /* 138 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var createNonEnumerableProperty = __webpack_require__(17);
- module.exports = function (key, value) {
- try {
- createNonEnumerableProperty(global, key, value);
- } catch (error) {
- global[key] = value;
- } return value;
- };
- /***/ }),
- /* 139 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(140);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 140 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- 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: 2em !important;\n}\n.w-e-toolbar h2,\n.w-e-text-container h2,\n.w-e-menu-panel h2 {\n font-size: 1.5em !important;\n}\n.w-e-toolbar h3,\n.w-e-text-container h3,\n.w-e-menu-panel h3 {\n font-size: 1.17em !important;\n}\n.w-e-toolbar h4,\n.w-e-text-container h4,\n.w-e-menu-panel h4 {\n font-size: 1em !important;\n}\n.w-e-toolbar h5,\n.w-e-text-container h5,\n.w-e-menu-panel h5 {\n font-size: 0.83em !important;\n}\n.w-e-toolbar p,\n.w-e-text-container p,\n.w-e-menu-panel p {\n font-size: 1em !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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 141 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(142);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 142 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- var ___CSS_LOADER_GET_URL_IMPORT___ = __webpack_require__(143);
- var ___CSS_LOADER_URL_IMPORT_0___ = __webpack_require__(144);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- var ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);
- // Module
- 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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 143 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- module.exports = function (url, options) {
- if (!options) {
- // eslint-disable-next-line no-param-reassign
- options = {};
- } // eslint-disable-next-line no-underscore-dangle, no-param-reassign
- url = url && url.__esModule ? url.default : url;
- if (typeof url !== 'string') {
- return url;
- } // If url is already wrapped in quotes, remove them
- if (/^['"].*['"]$/.test(url)) {
- // eslint-disable-next-line no-param-reassign
- url = url.slice(1, -1);
- }
- if (options.hash) {
- // eslint-disable-next-line no-param-reassign
- url += options.hash;
- } // Should url be wrapped?
- // See https://drafts.csswg.org/css-values-3/#urls
- if (/["'() \t\n]/.test(url) || options.needQuotes) {
- return "\"".concat(url.replace(/"/g, '\\"').replace(/\n/g, '\\n'), "\"");
- }
- return url;
- };
- /***/ }),
- /* 144 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* 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");
- /***/ }),
- /* 145 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(146);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 146 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- 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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 147 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(148);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 148 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- exports.push([module.i, ".w-e-text-container {\n position: relative;\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 top: 0.3em;\n margin-right: 3px;\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.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-item-wrapper {\n font-size: 14px;\n margin: 0 5px;\n}\n", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 149 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(150);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 150 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- 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 text-align: center;\n}\n.w-e-menu .w-e-panel-container .w-e-up-img-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 color: #333;\n}\n", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 151 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(152);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 152 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- 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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 153 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description polyfill 【注意,js 语法的兼容,都通过 babel transform runtime 支持】
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _promise = _interopRequireDefault(__webpack_require__(154));
- if (!Element.prototype.matches) {
- Element.prototype.matches = function (s) {
- var matches = this.ownerDocument.querySelectorAll(s);
- var i = matches.length;
- for (i; i >= 0; i--) {
- if (matches.item(i) === this) break;
- }
- return i > -1;
- };
- } // 有的第三方库需要原生 Promise ,而 IE11 又没有原生 Promise ,就报错
- if (!window.Promise) {
- window.Promise = _promise["default"];
- }
- /***/ }),
- /* 154 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(155);
- /***/ }),
- /* 155 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(156);
- module.exports = parent;
- /***/ }),
- /* 156 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(157);
- __webpack_require__(62);
- __webpack_require__(163);
- __webpack_require__(169);
- __webpack_require__(170);
- __webpack_require__(171);
- __webpack_require__(64);
- __webpack_require__(51);
- var path = __webpack_require__(10);
- module.exports = path.Promise;
- /***/ }),
- /* 157 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var getPrototypeOf = __webpack_require__(75);
- var setPrototypeOf = __webpack_require__(76);
- var create = __webpack_require__(48);
- var createNonEnumerableProperty = __webpack_require__(17);
- var createPropertyDescriptor = __webpack_require__(35);
- var iterate = __webpack_require__(39);
- var $AggregateError = function AggregateError(errors, message) {
- var that = this;
- if (!(that instanceof $AggregateError)) return new $AggregateError(errors, message);
- if (setPrototypeOf) {
- that = setPrototypeOf(new Error(undefined), getPrototypeOf(that));
- }
- if (message !== undefined) createNonEnumerableProperty(that, 'message', String(message));
- var errorsArray = [];
- iterate(errors, errorsArray.push, { that: errorsArray });
- createNonEnumerableProperty(that, 'errors', errorsArray);
- return that;
- };
- $AggregateError.prototype = create(Error.prototype, {
- constructor: createPropertyDescriptor(5, $AggregateError),
- message: createPropertyDescriptor(5, ''),
- name: createPropertyDescriptor(5, 'AggregateError')
- });
- $({ global: true }, {
- AggregateError: $AggregateError
- });
- /***/ }),
- /* 158 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- module.exports = !fails(function () {
- function F() { /* empty */ }
- F.prototype.constructor = null;
- return Object.getPrototypeOf(new F()) !== F.prototype;
- });
- /***/ }),
- /* 159 */
- /***/ (function(module, exports, __webpack_require__) {
- var isObject = __webpack_require__(13);
- module.exports = function (it) {
- if (!isObject(it) && it !== null) {
- throw TypeError("Can't set " + String(it) + ' as a prototype');
- } return it;
- };
- /***/ }),
- /* 160 */
- /***/ (function(module, exports, __webpack_require__) {
- var wellKnownSymbol = __webpack_require__(9);
- var Iterators = __webpack_require__(40);
- var ITERATOR = wellKnownSymbol('iterator');
- var ArrayPrototype = Array.prototype;
- // check on default Array iterator
- module.exports = function (it) {
- return it !== undefined && (Iterators.Array === it || ArrayPrototype[ITERATOR] === it);
- };
- /***/ }),
- /* 161 */
- /***/ (function(module, exports, __webpack_require__) {
- var classof = __webpack_require__(61);
- var Iterators = __webpack_require__(40);
- var wellKnownSymbol = __webpack_require__(9);
- var ITERATOR = wellKnownSymbol('iterator');
- module.exports = function (it) {
- if (it != undefined) return it[ITERATOR]
- || it['@@iterator']
- || Iterators[classof(it)];
- };
- /***/ }),
- /* 162 */
- /***/ (function(module, exports, __webpack_require__) {
- var anObject = __webpack_require__(24);
- module.exports = function (iterator) {
- var returnMethod = iterator['return'];
- if (returnMethod !== undefined) {
- return anObject(returnMethod.call(iterator)).value;
- }
- };
- /***/ }),
- /* 163 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var IS_PURE = __webpack_require__(37);
- var global = __webpack_require__(8);
- var getBuiltIn = __webpack_require__(28);
- var NativePromise = __webpack_require__(105);
- var redefine = __webpack_require__(50);
- var redefineAll = __webpack_require__(106);
- var setToStringTag = __webpack_require__(41);
- var setSpecies = __webpack_require__(107);
- var isObject = __webpack_require__(13);
- var aFunction = __webpack_require__(32);
- var anInstance = __webpack_require__(79);
- var inspectSource = __webpack_require__(108);
- var iterate = __webpack_require__(39);
- var checkCorrectnessOfIteration = __webpack_require__(165);
- var speciesConstructor = __webpack_require__(109);
- var task = __webpack_require__(110).set;
- var microtask = __webpack_require__(166);
- var promiseResolve = __webpack_require__(112);
- var hostReportErrors = __webpack_require__(167);
- var newPromiseCapabilityModule = __webpack_require__(63);
- var perform = __webpack_require__(82);
- var InternalStateModule = __webpack_require__(42);
- var isForced = __webpack_require__(101);
- var wellKnownSymbol = __webpack_require__(9);
- var IS_NODE = __webpack_require__(81);
- var V8_VERSION = __webpack_require__(83);
- var SPECIES = wellKnownSymbol('species');
- var PROMISE = 'Promise';
- var getInternalState = InternalStateModule.get;
- var setInternalState = InternalStateModule.set;
- var getInternalPromiseState = InternalStateModule.getterFor(PROMISE);
- var PromiseConstructor = NativePromise;
- var TypeError = global.TypeError;
- var document = global.document;
- var process = global.process;
- var $fetch = getBuiltIn('fetch');
- var newPromiseCapability = newPromiseCapabilityModule.f;
- var newGenericPromiseCapability = newPromiseCapability;
- var DISPATCH_EVENT = !!(document && document.createEvent && global.dispatchEvent);
- var NATIVE_REJECTION_EVENT = typeof PromiseRejectionEvent == 'function';
- var UNHANDLED_REJECTION = 'unhandledrejection';
- var REJECTION_HANDLED = 'rejectionhandled';
- var PENDING = 0;
- var FULFILLED = 1;
- var REJECTED = 2;
- var HANDLED = 1;
- var UNHANDLED = 2;
- var Internal, OwnPromiseCapability, PromiseWrapper, nativeThen;
- var FORCED = isForced(PROMISE, function () {
- var GLOBAL_CORE_JS_PROMISE = inspectSource(PromiseConstructor) !== String(PromiseConstructor);
- if (!GLOBAL_CORE_JS_PROMISE) {
- // V8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables
- // https://bugs.chromium.org/p/chromium/issues/detail?id=830565
- // We can't detect it synchronously, so just check versions
- if (V8_VERSION === 66) return true;
- // Unhandled rejections tracking support, NodeJS Promise without it fails @@species test
- if (!IS_NODE && !NATIVE_REJECTION_EVENT) return true;
- }
- // We need Promise#finally in the pure version for preventing prototype pollution
- if (IS_PURE && !PromiseConstructor.prototype['finally']) return true;
- // We can't use @@species feature detection in V8 since it causes
- // deoptimization and performance degradation
- // https://github.com/zloirock/core-js/issues/679
- if (V8_VERSION >= 51 && /native code/.test(PromiseConstructor)) return false;
- // Detect correctness of subclassing with @@species support
- var promise = PromiseConstructor.resolve(1);
- var FakePromise = function (exec) {
- exec(function () { /* empty */ }, function () { /* empty */ });
- };
- var constructor = promise.constructor = {};
- constructor[SPECIES] = FakePromise;
- return !(promise.then(function () { /* empty */ }) instanceof FakePromise);
- });
- var INCORRECT_ITERATION = FORCED || !checkCorrectnessOfIteration(function (iterable) {
- PromiseConstructor.all(iterable)['catch'](function () { /* empty */ });
- });
- // helpers
- var isThenable = function (it) {
- var then;
- return isObject(it) && typeof (then = it.then) == 'function' ? then : false;
- };
- var notify = function (state, isReject) {
- if (state.notified) return;
- state.notified = true;
- var chain = state.reactions;
- microtask(function () {
- var value = state.value;
- var ok = state.state == FULFILLED;
- var index = 0;
- // variable length - can't use forEach
- while (chain.length > index) {
- var reaction = chain[index++];
- var handler = ok ? reaction.ok : reaction.fail;
- var resolve = reaction.resolve;
- var reject = reaction.reject;
- var domain = reaction.domain;
- var result, then, exited;
- try {
- if (handler) {
- if (!ok) {
- if (state.rejection === UNHANDLED) onHandleUnhandled(state);
- state.rejection = HANDLED;
- }
- if (handler === true) result = value;
- else {
- if (domain) domain.enter();
- result = handler(value); // can throw
- if (domain) {
- domain.exit();
- exited = true;
- }
- }
- if (result === reaction.promise) {
- reject(TypeError('Promise-chain cycle'));
- } else if (then = isThenable(result)) {
- then.call(result, resolve, reject);
- } else resolve(result);
- } else reject(value);
- } catch (error) {
- if (domain && !exited) domain.exit();
- reject(error);
- }
- }
- state.reactions = [];
- state.notified = false;
- if (isReject && !state.rejection) onUnhandled(state);
- });
- };
- var dispatchEvent = function (name, promise, reason) {
- var event, handler;
- if (DISPATCH_EVENT) {
- event = document.createEvent('Event');
- event.promise = promise;
- event.reason = reason;
- event.initEvent(name, false, true);
- global.dispatchEvent(event);
- } else event = { promise: promise, reason: reason };
- if (!NATIVE_REJECTION_EVENT && (handler = global['on' + name])) handler(event);
- else if (name === UNHANDLED_REJECTION) hostReportErrors('Unhandled promise rejection', reason);
- };
- var onUnhandled = function (state) {
- task.call(global, function () {
- var promise = state.facade;
- var value = state.value;
- var IS_UNHANDLED = isUnhandled(state);
- var result;
- if (IS_UNHANDLED) {
- result = perform(function () {
- if (IS_NODE) {
- process.emit('unhandledRejection', value, promise);
- } else dispatchEvent(UNHANDLED_REJECTION, promise, value);
- });
- // Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should
- state.rejection = IS_NODE || isUnhandled(state) ? UNHANDLED : HANDLED;
- if (result.error) throw result.value;
- }
- });
- };
- var isUnhandled = function (state) {
- return state.rejection !== HANDLED && !state.parent;
- };
- var onHandleUnhandled = function (state) {
- task.call(global, function () {
- var promise = state.facade;
- if (IS_NODE) {
- process.emit('rejectionHandled', promise);
- } else dispatchEvent(REJECTION_HANDLED, promise, state.value);
- });
- };
- var bind = function (fn, state, unwrap) {
- return function (value) {
- fn(state, value, unwrap);
- };
- };
- var internalReject = function (state, value, unwrap) {
- if (state.done) return;
- state.done = true;
- if (unwrap) state = unwrap;
- state.value = value;
- state.state = REJECTED;
- notify(state, true);
- };
- var internalResolve = function (state, value, unwrap) {
- if (state.done) return;
- state.done = true;
- if (unwrap) state = unwrap;
- try {
- if (state.facade === value) throw TypeError("Promise can't be resolved itself");
- var then = isThenable(value);
- if (then) {
- microtask(function () {
- var wrapper = { done: false };
- try {
- then.call(value,
- bind(internalResolve, wrapper, state),
- bind(internalReject, wrapper, state)
- );
- } catch (error) {
- internalReject(wrapper, error, state);
- }
- });
- } else {
- state.value = value;
- state.state = FULFILLED;
- notify(state, false);
- }
- } catch (error) {
- internalReject({ done: false }, error, state);
- }
- };
- // constructor polyfill
- if (FORCED) {
- // 25.4.3.1 Promise(executor)
- PromiseConstructor = function Promise(executor) {
- anInstance(this, PromiseConstructor, PROMISE);
- aFunction(executor);
- Internal.call(this);
- var state = getInternalState(this);
- try {
- executor(bind(internalResolve, state), bind(internalReject, state));
- } catch (error) {
- internalReject(state, error);
- }
- };
- // eslint-disable-next-line no-unused-vars
- Internal = function Promise(executor) {
- setInternalState(this, {
- type: PROMISE,
- done: false,
- notified: false,
- parent: false,
- reactions: [],
- rejection: false,
- state: PENDING,
- value: undefined
- });
- };
- Internal.prototype = redefineAll(PromiseConstructor.prototype, {
- // `Promise.prototype.then` method
- // https://tc39.github.io/ecma262/#sec-promise.prototype.then
- then: function then(onFulfilled, onRejected) {
- var state = getInternalPromiseState(this);
- var reaction = newPromiseCapability(speciesConstructor(this, PromiseConstructor));
- reaction.ok = typeof onFulfilled == 'function' ? onFulfilled : true;
- reaction.fail = typeof onRejected == 'function' && onRejected;
- reaction.domain = IS_NODE ? process.domain : undefined;
- state.parent = true;
- state.reactions.push(reaction);
- if (state.state != PENDING) notify(state, false);
- return reaction.promise;
- },
- // `Promise.prototype.catch` method
- // https://tc39.github.io/ecma262/#sec-promise.prototype.catch
- 'catch': function (onRejected) {
- return this.then(undefined, onRejected);
- }
- });
- OwnPromiseCapability = function () {
- var promise = new Internal();
- var state = getInternalState(promise);
- this.promise = promise;
- this.resolve = bind(internalResolve, state);
- this.reject = bind(internalReject, state);
- };
- newPromiseCapabilityModule.f = newPromiseCapability = function (C) {
- return C === PromiseConstructor || C === PromiseWrapper
- ? new OwnPromiseCapability(C)
- : newGenericPromiseCapability(C);
- };
- if (!IS_PURE && typeof NativePromise == 'function') {
- nativeThen = NativePromise.prototype.then;
- // wrap native Promise#then for native async functions
- redefine(NativePromise.prototype, 'then', function then(onFulfilled, onRejected) {
- var that = this;
- return new PromiseConstructor(function (resolve, reject) {
- nativeThen.call(that, resolve, reject);
- }).then(onFulfilled, onRejected);
- // https://github.com/zloirock/core-js/issues/640
- }, { unsafe: true });
- // wrap fetch result
- if (typeof $fetch == 'function') $({ global: true, enumerable: true, forced: true }, {
- // eslint-disable-next-line no-unused-vars
- fetch: function fetch(input /* , init */) {
- return promiseResolve(PromiseConstructor, $fetch.apply(global, arguments));
- }
- });
- }
- }
- $({ global: true, wrap: true, forced: FORCED }, {
- Promise: PromiseConstructor
- });
- setToStringTag(PromiseConstructor, PROMISE, false, true);
- setSpecies(PROMISE);
- PromiseWrapper = getBuiltIn(PROMISE);
- // statics
- $({ target: PROMISE, stat: true, forced: FORCED }, {
- // `Promise.reject` method
- // https://tc39.github.io/ecma262/#sec-promise.reject
- reject: function reject(r) {
- var capability = newPromiseCapability(this);
- capability.reject.call(undefined, r);
- return capability.promise;
- }
- });
- $({ target: PROMISE, stat: true, forced: IS_PURE || FORCED }, {
- // `Promise.resolve` method
- // https://tc39.github.io/ecma262/#sec-promise.resolve
- resolve: function resolve(x) {
- return promiseResolve(IS_PURE && this === PromiseWrapper ? PromiseConstructor : this, x);
- }
- });
- $({ target: PROMISE, stat: true, forced: INCORRECT_ITERATION }, {
- // `Promise.all` method
- // https://tc39.github.io/ecma262/#sec-promise.all
- all: function all(iterable) {
- var C = this;
- var capability = newPromiseCapability(C);
- var resolve = capability.resolve;
- var reject = capability.reject;
- var result = perform(function () {
- var $promiseResolve = aFunction(C.resolve);
- var values = [];
- var counter = 0;
- var remaining = 1;
- iterate(iterable, function (promise) {
- var index = counter++;
- var alreadyCalled = false;
- values.push(undefined);
- remaining++;
- $promiseResolve.call(C, promise).then(function (value) {
- if (alreadyCalled) return;
- alreadyCalled = true;
- values[index] = value;
- --remaining || resolve(values);
- }, reject);
- });
- --remaining || resolve(values);
- });
- if (result.error) reject(result.value);
- return capability.promise;
- },
- // `Promise.race` method
- // https://tc39.github.io/ecma262/#sec-promise.race
- race: function race(iterable) {
- var C = this;
- var capability = newPromiseCapability(C);
- var reject = capability.reject;
- var result = perform(function () {
- var $promiseResolve = aFunction(C.resolve);
- iterate(iterable, function (promise) {
- $promiseResolve.call(C, promise).then(capability.resolve, reject);
- });
- });
- if (result.error) reject(result.value);
- return capability.promise;
- }
- });
- /***/ }),
- /* 164 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var TO_STRING_TAG_SUPPORT = __webpack_require__(78);
- var classof = __webpack_require__(61);
- // `Object.prototype.toString` method implementation
- // https://tc39.github.io/ecma262/#sec-object.prototype.tostring
- module.exports = TO_STRING_TAG_SUPPORT ? {}.toString : function toString() {
- return '[object ' + classof(this) + ']';
- };
- /***/ }),
- /* 165 */
- /***/ (function(module, exports, __webpack_require__) {
- var wellKnownSymbol = __webpack_require__(9);
- var ITERATOR = wellKnownSymbol('iterator');
- var SAFE_CLOSING = false;
- try {
- var called = 0;
- var iteratorWithReturn = {
- next: function () {
- return { done: !!called++ };
- },
- 'return': function () {
- SAFE_CLOSING = true;
- }
- };
- iteratorWithReturn[ITERATOR] = function () {
- return this;
- };
- // eslint-disable-next-line no-throw-literal
- Array.from(iteratorWithReturn, function () { throw 2; });
- } catch (error) { /* empty */ }
- module.exports = function (exec, SKIP_CLOSING) {
- if (!SKIP_CLOSING && !SAFE_CLOSING) return false;
- var ITERATION_SUPPORT = false;
- try {
- var object = {};
- object[ITERATOR] = function () {
- return {
- next: function () {
- return { done: ITERATION_SUPPORT = true };
- }
- };
- };
- exec(object);
- } catch (error) { /* empty */ }
- return ITERATION_SUPPORT;
- };
- /***/ }),
- /* 166 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var getOwnPropertyDescriptor = __webpack_require__(67).f;
- var macrotask = __webpack_require__(110).set;
- var IS_IOS = __webpack_require__(111);
- var IS_NODE = __webpack_require__(81);
- var MutationObserver = global.MutationObserver || global.WebKitMutationObserver;
- var document = global.document;
- var process = global.process;
- var Promise = global.Promise;
- // Node.js 11 shows ExperimentalWarning on getting `queueMicrotask`
- var queueMicrotaskDescriptor = getOwnPropertyDescriptor(global, 'queueMicrotask');
- var queueMicrotask = queueMicrotaskDescriptor && queueMicrotaskDescriptor.value;
- var flush, head, last, notify, toggle, node, promise, then;
- // modern engines have queueMicrotask method
- if (!queueMicrotask) {
- flush = function () {
- var parent, fn;
- if (IS_NODE && (parent = process.domain)) parent.exit();
- while (head) {
- fn = head.fn;
- head = head.next;
- try {
- fn();
- } catch (error) {
- if (head) notify();
- else last = undefined;
- throw error;
- }
- } last = undefined;
- if (parent) parent.enter();
- };
- // browsers with MutationObserver, except iOS - https://github.com/zloirock/core-js/issues/339
- if (!IS_IOS && !IS_NODE && MutationObserver && document) {
- toggle = true;
- node = document.createTextNode('');
- new MutationObserver(flush).observe(node, { characterData: true });
- notify = function () {
- node.data = toggle = !toggle;
- };
- // environments with maybe non-completely correct, but existent Promise
- } else if (Promise && Promise.resolve) {
- // Promise.resolve without an argument throws an error in LG WebOS 2
- promise = Promise.resolve(undefined);
- then = promise.then;
- notify = function () {
- then.call(promise, flush);
- };
- // Node.js without promises
- } else if (IS_NODE) {
- notify = function () {
- process.nextTick(flush);
- };
- // for other environments - macrotask based on:
- // - setImmediate
- // - MessageChannel
- // - window.postMessag
- // - onreadystatechange
- // - setTimeout
- } else {
- notify = function () {
- // strange IE + webpack dev server bug - use .call(global)
- macrotask.call(global, flush);
- };
- }
- }
- module.exports = queueMicrotask || function (fn) {
- var task = { fn: fn, next: undefined };
- if (last) last.next = task;
- if (!head) {
- head = task;
- notify();
- } last = task;
- };
- /***/ }),
- /* 167 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- module.exports = function (a, b) {
- var console = global.console;
- if (console && console.error) {
- arguments.length === 1 ? console.error(a) : console.error(a, b);
- }
- };
- /***/ }),
- /* 168 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var inspectSource = __webpack_require__(108);
- var WeakMap = global.WeakMap;
- module.exports = typeof WeakMap === 'function' && /native code/.test(inspectSource(WeakMap));
- /***/ }),
- /* 169 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var aFunction = __webpack_require__(32);
- var newPromiseCapabilityModule = __webpack_require__(63);
- var perform = __webpack_require__(82);
- var iterate = __webpack_require__(39);
- // `Promise.allSettled` method
- // https://github.com/tc39/proposal-promise-allSettled
- $({ target: 'Promise', stat: true }, {
- allSettled: function allSettled(iterable) {
- var C = this;
- var capability = newPromiseCapabilityModule.f(C);
- var resolve = capability.resolve;
- var reject = capability.reject;
- var result = perform(function () {
- var promiseResolve = aFunction(C.resolve);
- var values = [];
- var counter = 0;
- var remaining = 1;
- iterate(iterable, function (promise) {
- var index = counter++;
- var alreadyCalled = false;
- values.push(undefined);
- remaining++;
- promiseResolve.call(C, promise).then(function (value) {
- if (alreadyCalled) return;
- alreadyCalled = true;
- values[index] = { status: 'fulfilled', value: value };
- --remaining || resolve(values);
- }, function (error) {
- if (alreadyCalled) return;
- alreadyCalled = true;
- values[index] = { status: 'rejected', reason: error };
- --remaining || resolve(values);
- });
- });
- --remaining || resolve(values);
- });
- if (result.error) reject(result.value);
- return capability.promise;
- }
- });
- /***/ }),
- /* 170 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var aFunction = __webpack_require__(32);
- var getBuiltIn = __webpack_require__(28);
- var newPromiseCapabilityModule = __webpack_require__(63);
- var perform = __webpack_require__(82);
- var iterate = __webpack_require__(39);
- var PROMISE_ANY_ERROR = 'No one promise resolved';
- // `Promise.any` method
- // https://github.com/tc39/proposal-promise-any
- $({ target: 'Promise', stat: true }, {
- any: function any(iterable) {
- var C = this;
- var capability = newPromiseCapabilityModule.f(C);
- var resolve = capability.resolve;
- var reject = capability.reject;
- var result = perform(function () {
- var promiseResolve = aFunction(C.resolve);
- var errors = [];
- var counter = 0;
- var remaining = 1;
- var alreadyResolved = false;
- iterate(iterable, function (promise) {
- var index = counter++;
- var alreadyRejected = false;
- errors.push(undefined);
- remaining++;
- promiseResolve.call(C, promise).then(function (value) {
- if (alreadyRejected || alreadyResolved) return;
- alreadyResolved = true;
- resolve(value);
- }, function (error) {
- if (alreadyRejected || alreadyResolved) return;
- alreadyRejected = true;
- errors[index] = error;
- --remaining || reject(new (getBuiltIn('AggregateError'))(errors, PROMISE_ANY_ERROR));
- });
- });
- --remaining || reject(new (getBuiltIn('AggregateError'))(errors, PROMISE_ANY_ERROR));
- });
- if (result.error) reject(result.value);
- return capability.promise;
- }
- });
- /***/ }),
- /* 171 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var IS_PURE = __webpack_require__(37);
- var NativePromise = __webpack_require__(105);
- var fails = __webpack_require__(12);
- var getBuiltIn = __webpack_require__(28);
- var speciesConstructor = __webpack_require__(109);
- var promiseResolve = __webpack_require__(112);
- var redefine = __webpack_require__(50);
- // Safari bug https://bugs.webkit.org/show_bug.cgi?id=200829
- var NON_GENERIC = !!NativePromise && fails(function () {
- NativePromise.prototype['finally'].call({ then: function () { /* empty */ } }, function () { /* empty */ });
- });
- // `Promise.prototype.finally` method
- // https://tc39.github.io/ecma262/#sec-promise.prototype.finally
- $({ target: 'Promise', proto: true, real: true, forced: NON_GENERIC }, {
- 'finally': function (onFinally) {
- var C = speciesConstructor(this, getBuiltIn('Promise'));
- var isFunction = typeof onFinally == 'function';
- return this.then(
- isFunction ? function (x) {
- return promiseResolve(C, onFinally()).then(function () { return x; });
- } : onFinally,
- isFunction ? function (e) {
- return promiseResolve(C, onFinally()).then(function () { throw e; });
- } : onFinally
- );
- }
- });
- // patch native Promise.prototype for native async functions
- if (!IS_PURE && typeof NativePromise == 'function' && !NativePromise.prototype['finally']) {
- redefine(NativePromise.prototype, 'finally', getBuiltIn('Promise').prototype['finally']);
- }
- /***/ }),
- /* 172 */
- /***/ (function(module, exports, __webpack_require__) {
- var toInteger = __webpack_require__(58);
- var requireObjectCoercible = __webpack_require__(46);
- // `String.prototype.{ codePointAt, at }` methods implementation
- var createMethod = function (CONVERT_TO_STRING) {
- return function ($this, pos) {
- var S = String(requireObjectCoercible($this));
- var position = toInteger(pos);
- var size = S.length;
- var first, second;
- if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;
- first = S.charCodeAt(position);
- return first < 0xD800 || first > 0xDBFF || position + 1 === size
- || (second = S.charCodeAt(position + 1)) < 0xDC00 || second > 0xDFFF
- ? CONVERT_TO_STRING ? S.charAt(position) : first
- : CONVERT_TO_STRING ? S.slice(position, position + 2) : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;
- };
- };
- module.exports = {
- // `String.prototype.codePointAt` method
- // https://tc39.github.io/ecma262/#sec-string.prototype.codepointat
- codeAt: createMethod(false),
- // `String.prototype.at` method
- // https://github.com/mathiasbynens/String.prototype.at
- charAt: createMethod(true)
- };
- /***/ }),
- /* 173 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var IteratorPrototype = __webpack_require__(113).IteratorPrototype;
- var create = __webpack_require__(48);
- var createPropertyDescriptor = __webpack_require__(35);
- var setToStringTag = __webpack_require__(41);
- var Iterators = __webpack_require__(40);
- var returnThis = function () { return this; };
- module.exports = function (IteratorConstructor, NAME, next) {
- var TO_STRING_TAG = NAME + ' Iterator';
- IteratorConstructor.prototype = create(IteratorPrototype, { next: createPropertyDescriptor(1, next) });
- setToStringTag(IteratorConstructor, TO_STRING_TAG, false, true);
- Iterators[TO_STRING_TAG] = returnThis;
- return IteratorConstructor;
- };
- /***/ }),
- /* 174 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var toIndexedObject = __webpack_require__(27);
- var addToUnscopables = __webpack_require__(85);
- var Iterators = __webpack_require__(40);
- var InternalStateModule = __webpack_require__(42);
- var defineIterator = __webpack_require__(84);
- var ARRAY_ITERATOR = 'Array Iterator';
- var setInternalState = InternalStateModule.set;
- var getInternalState = InternalStateModule.getterFor(ARRAY_ITERATOR);
- // `Array.prototype.entries` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.entries
- // `Array.prototype.keys` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.keys
- // `Array.prototype.values` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.values
- // `Array.prototype[@@iterator]` method
- // https://tc39.github.io/ecma262/#sec-array.prototype-@@iterator
- // `CreateArrayIterator` internal method
- // https://tc39.github.io/ecma262/#sec-createarrayiterator
- module.exports = defineIterator(Array, 'Array', function (iterated, kind) {
- setInternalState(this, {
- type: ARRAY_ITERATOR,
- target: toIndexedObject(iterated), // target
- index: 0, // next index
- kind: kind // kind
- });
- // `%ArrayIteratorPrototype%.next` method
- // https://tc39.github.io/ecma262/#sec-%arrayiteratorprototype%.next
- }, function () {
- var state = getInternalState(this);
- var target = state.target;
- var kind = state.kind;
- var index = state.index++;
- if (!target || index >= target.length) {
- state.target = undefined;
- return { value: undefined, done: true };
- }
- if (kind == 'keys') return { value: index, done: false };
- if (kind == 'values') return { value: target[index], done: false };
- return { value: [index, target[index]], done: false };
- }, 'values');
- // argumentsList[@@iterator] is %ArrayProto_values%
- // https://tc39.github.io/ecma262/#sec-createunmappedargumentsobject
- // https://tc39.github.io/ecma262/#sec-createmappedargumentsobject
- Iterators.Arguments = Iterators.Array;
- // https://tc39.github.io/ecma262/#sec-array.prototype-@@unscopables
- addToUnscopables('keys');
- addToUnscopables('values');
- addToUnscopables('entries');
- /***/ }),
- /* 175 */
- /***/ (function(module, exports) {
- // iterable DOM collections
- // flag - `iterable` interface - 'entries', 'keys', 'values', 'forEach' methods
- module.exports = {
- CSSRuleList: 0,
- CSSStyleDeclaration: 0,
- CSSValueList: 0,
- ClientRectList: 0,
- DOMRectList: 0,
- DOMStringList: 0,
- DOMTokenList: 1,
- DataTransferItemList: 0,
- FileList: 0,
- HTMLAllCollection: 0,
- HTMLCollection: 0,
- HTMLFormElement: 0,
- HTMLSelectElement: 0,
- MediaList: 0,
- MimeTypeArray: 0,
- NamedNodeMap: 0,
- NodeList: 1,
- PaintRequestList: 0,
- Plugin: 0,
- PluginArray: 0,
- SVGLengthList: 0,
- SVGNumberList: 0,
- SVGPathSegList: 0,
- SVGPointList: 0,
- SVGStringList: 0,
- SVGTransformList: 0,
- SourceBufferList: 0,
- StyleSheetList: 0,
- TextTrackCueList: 0,
- TextTrackList: 0,
- TouchList: 0
- };
- /***/ }),
- /* 176 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 编辑器 class
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var __createBinding = void 0 && (void 0).__createBinding || (_create["default"] ? function (o, m, k, k2) {
- if (k2 === undefined) k2 = k;
- (0, _defineProperty["default"])(o, k2, {
- enumerable: true,
- get: function get() {
- return m[k];
- }
- });
- } : function (o, m, k, k2) {
- if (k2 === undefined) k2 = k;
- o[k2] = m[k];
- });
- var __setModuleDefault = void 0 && (void 0).__setModuleDefault || (_create["default"] ? function (o, v) {
- (0, _defineProperty["default"])(o, "default", {
- enumerable: true,
- value: v
- });
- } : function (o, v) {
- o["default"] = v;
- });
- var __importStar = void 0 && (void 0).__importStar || function (mod) {
- if (mod && mod.__esModule) return mod;
- var result = {};
- if (mod != null) for (var k in mod) {
- if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
- }
- __setModuleDefault(result, mod);
- return result;
- };
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(7);
- var config_1 = __importDefault(__webpack_require__(265));
- var selection_1 = __importDefault(__webpack_require__(280));
- var command_1 = __importDefault(__webpack_require__(282));
- var index_1 = __importDefault(__webpack_require__(283));
- var index_2 = __importDefault(__webpack_require__(302));
- var init_dom_1 = __importDefault(__webpack_require__(386));
- var init_selection_1 = __importDefault(__webpack_require__(387));
- var bind_event_1 = __importDefault(__webpack_require__(388));
- var i18next_init_1 = __importDefault(__webpack_require__(389));
- var set_full_screen_1 = __importStar(__webpack_require__(390));
- var scroll_to_head_1 = __importDefault(__webpack_require__(393));
- var z_index_1 = __importDefault(__webpack_require__(394));
- var index_3 = __importDefault(__webpack_require__(395));
- var index_4 = __importDefault(__webpack_require__(397));
- var disable_1 = __importDefault(__webpack_require__(412)); // 创建菜单的 class
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var DropList_1 = __importDefault(__webpack_require__(125));
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var Panel_1 = __importDefault(__webpack_require__(31));
- var PanelMenu_1 = __importDefault(__webpack_require__(34));
- var Tooltip_1 = __importDefault(__webpack_require__(44));
- var EDITOR_ID = 1;
- var Editor =
- /** @class */
- function () {
- /**
- * 构造函数
- * @param toolbarSelector 工具栏 DOM selector
- * @param textSelector 文本区域 DOM selector
- */
- function Editor(toolbarSelector, textSelector) {
- // 实例销毁前需要执行的钩子集合
- this.beforeDestroyHooks = []; // id,用以区分单个页面不同的编辑器对象
- this.id = "wangEditor-" + EDITOR_ID++;
- this.toolbarSelector = toolbarSelector;
- this.textSelector = textSelector;
- if (toolbarSelector == null) {
- throw new Error('错误:初始化编辑器时候未传入任何参数,请查阅文档');
- } // 属性的默认值,后面可能会再修改
- // 默认配置 - 当一个页面有多个编辑器的时候,因为 JS 的特性(引用类型)会导致多个编辑器的 config 引用是同一个,所以需要 深度克隆 断掉引用
- this.config = util_1.deepClone(config_1["default"]);
- this.$toolbarElem = dom_core_1["default"]('<div></div>');
- this.$textContainerElem = dom_core_1["default"]('<div></div>');
- this.$textElem = dom_core_1["default"]('<div></div>');
- this.toolbarElemId = '';
- this.textElemId = '';
- this.isFocus = false;
- this.isComposing = false;
- this.isCompatibleMode = false;
- this.selection = new selection_1["default"](this);
- this.cmd = new command_1["default"](this);
- this.txt = new index_1["default"](this);
- this.menus = new index_2["default"](this);
- this.zIndex = new z_index_1["default"]();
- this.change = new index_3["default"](this);
- this.history = new index_4["default"](this);
- var _a = disable_1["default"](this),
- disable = _a.disable,
- enable = _a.enable;
- this.disable = disable;
- this.enable = enable;
- }
- /**
- * 初始化选区
- * @param newLine 新建一行
- */
- Editor.prototype.initSelection = function (newLine) {
- init_selection_1["default"](this, newLine);
- };
- /**
- * 创建编辑器实例
- */
- Editor.prototype.create = function () {
- // 初始化 ZIndex
- this.zIndex.init(this); // 确定当前的历史记录模式
- this.isCompatibleMode = this.config.compatibleMode(); // 标准模式下,重置延迟时间
- if (!this.isCompatibleMode) {
- this.config.onchangeTimeout = 30;
- } // 国际化 因为要在创建菜单前使用 所以要最先 初始化
- i18next_init_1["default"](this); // 初始化 DOM
- init_dom_1["default"](this); // 初始化 text
- this.txt.init(); // 初始化菜单
- this.menus.init(); // 初始化全屏功能
- set_full_screen_1["default"](this); // 初始化选区,将光标定位到内容尾部
- this.initSelection(true); // 绑定事件
- bind_event_1["default"](this); // 绑定监听的目标节点
- this.change.observe();
- this.history.observe();
- };
- /**
- * 提供给用户添加销毁前的钩子函数
- * @param fn 钩子函数
- */
- Editor.prototype.beforeDestroy = function (fn) {
- this.beforeDestroyHooks.push(fn);
- return this;
- };
- /**
- * 销毁当前编辑器实例
- */
- Editor.prototype.destroy = function () {
- var _context;
- var _this = this; // 调用钩子函数
- (0, _forEach["default"])(_context = this.beforeDestroyHooks).call(_context, function (fn) {
- return fn.call(_this);
- }); // 销毁 DOM 节点
- this.$toolbarElem.remove();
- this.$textContainerElem.remove();
- };
- /**
- * 将编辑器设置为全屏
- */
- Editor.prototype.fullScreen = function () {
- set_full_screen_1.setFullScreen(this);
- };
- /**
- * 将编辑器退出全屏
- */
- Editor.prototype.unFullScreen = function () {
- set_full_screen_1.setUnFullScreen(this);
- };
- /**
- * 滚动到指定标题锚点
- * @param id 标题锚点id
- */
- Editor.prototype.scrollToHead = function (id) {
- scroll_to_head_1["default"](this, id);
- }; // 暴露 $
- Editor.$ = dom_core_1["default"];
- Editor.BtnMenu = BtnMenu_1["default"];
- Editor.DropList = DropList_1["default"];
- Editor.DropListMenu = DropListMenu_1["default"];
- Editor.Panel = Panel_1["default"];
- Editor.PanelMenu = PanelMenu_1["default"];
- Editor.Tooltip = Tooltip_1["default"];
- return Editor;
- }();
- exports["default"] = Editor;
- /***/ }),
- /* 177 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(51);
- var forEach = __webpack_require__(178);
- var classof = __webpack_require__(61);
- var ArrayPrototype = Array.prototype;
- var DOMIterables = {
- DOMTokenList: true,
- NodeList: true
- };
- module.exports = function (it) {
- var own = it.forEach;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.forEach)
- // eslint-disable-next-line no-prototype-builtins
- || DOMIterables.hasOwnProperty(classof(it)) ? forEach : own;
- };
- /***/ }),
- /* 178 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(179);
- module.exports = parent;
- /***/ }),
- /* 179 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(180);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').forEach;
- /***/ }),
- /* 180 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var forEach = __webpack_require__(181);
- // `Array.prototype.forEach` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.foreach
- $({ target: 'Array', proto: true, forced: [].forEach != forEach }, {
- forEach: forEach
- });
- /***/ }),
- /* 181 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $forEach = __webpack_require__(33).forEach;
- var arrayMethodIsStrict = __webpack_require__(87);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var STRICT_METHOD = arrayMethodIsStrict('forEach');
- var USES_TO_LENGTH = arrayMethodUsesToLength('forEach');
- // `Array.prototype.forEach` method implementation
- // https://tc39.github.io/ecma262/#sec-array.prototype.foreach
- module.exports = (!STRICT_METHOD || !USES_TO_LENGTH) ? function forEach(callbackfn /* , thisArg */) {
- return $forEach(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
- } : [].forEach;
- /***/ }),
- /* 182 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(183);
- module.exports = parent;
- /***/ }),
- /* 183 */
- /***/ (function(module, exports, __webpack_require__) {
- var bind = __webpack_require__(184);
- var FunctionPrototype = Function.prototype;
- module.exports = function (it) {
- var own = it.bind;
- return it === FunctionPrototype || (it instanceof Function && own === FunctionPrototype.bind) ? bind : own;
- };
- /***/ }),
- /* 184 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(185);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Function').bind;
- /***/ }),
- /* 185 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var bind = __webpack_require__(186);
- // `Function.prototype.bind` method
- // https://tc39.github.io/ecma262/#sec-function.prototype.bind
- $({ target: 'Function', proto: true }, {
- bind: bind
- });
- /***/ }),
- /* 186 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var aFunction = __webpack_require__(32);
- var isObject = __webpack_require__(13);
- var slice = [].slice;
- var factories = {};
- var construct = function (C, argsLength, args) {
- if (!(argsLength in factories)) {
- for (var list = [], i = 0; i < argsLength; i++) list[i] = 'a[' + i + ']';
- // eslint-disable-next-line no-new-func
- factories[argsLength] = Function('C,a', 'return new C(' + list.join(',') + ')');
- } return factories[argsLength](C, args);
- };
- // `Function.prototype.bind` method implementation
- // https://tc39.github.io/ecma262/#sec-function.prototype.bind
- module.exports = Function.bind || function bind(that /* , ...args */) {
- var fn = aFunction(this);
- var partArgs = slice.call(arguments, 1);
- var boundFunction = function bound(/* args... */) {
- var args = partArgs.concat(slice.call(arguments));
- return this instanceof boundFunction ? construct(fn, args.length, args) : fn.apply(that, args);
- };
- if (isObject(fn.prototype)) boundFunction.prototype = fn.prototype;
- return boundFunction;
- };
- /***/ }),
- /* 187 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(188);
- module.exports = parent;
- /***/ }),
- /* 188 */
- /***/ (function(module, exports, __webpack_require__) {
- var arrayIncludes = __webpack_require__(189);
- var stringIncludes = __webpack_require__(191);
- var ArrayPrototype = Array.prototype;
- var StringPrototype = String.prototype;
- module.exports = function (it) {
- var own = it.includes;
- if (it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.includes)) return arrayIncludes;
- if (typeof it === 'string' || it === StringPrototype || (it instanceof String && own === StringPrototype.includes)) {
- return stringIncludes;
- } return own;
- };
- /***/ }),
- /* 189 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(190);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').includes;
- /***/ }),
- /* 190 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var $includes = __webpack_require__(70).includes;
- var addToUnscopables = __webpack_require__(85);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var USES_TO_LENGTH = arrayMethodUsesToLength('indexOf', { ACCESSORS: true, 1: 0 });
- // `Array.prototype.includes` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.includes
- $({ target: 'Array', proto: true, forced: !USES_TO_LENGTH }, {
- includes: function includes(el /* , fromIndex = 0 */) {
- return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined);
- }
- });
- // https://tc39.github.io/ecma262/#sec-array.prototype-@@unscopables
- addToUnscopables('includes');
- /***/ }),
- /* 191 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(192);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('String').includes;
- /***/ }),
- /* 192 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var notARegExp = __webpack_require__(193);
- var requireObjectCoercible = __webpack_require__(46);
- var correctIsRegExpLogic = __webpack_require__(195);
- // `String.prototype.includes` method
- // https://tc39.github.io/ecma262/#sec-string.prototype.includes
- $({ target: 'String', proto: true, forced: !correctIsRegExpLogic('includes') }, {
- includes: function includes(searchString /* , position = 0 */) {
- return !!~String(requireObjectCoercible(this))
- .indexOf(notARegExp(searchString), arguments.length > 1 ? arguments[1] : undefined);
- }
- });
- /***/ }),
- /* 193 */
- /***/ (function(module, exports, __webpack_require__) {
- var isRegExp = __webpack_require__(194);
- module.exports = function (it) {
- if (isRegExp(it)) {
- throw TypeError("The method doesn't accept regular expressions");
- } return it;
- };
- /***/ }),
- /* 194 */
- /***/ (function(module, exports, __webpack_require__) {
- var isObject = __webpack_require__(13);
- var classof = __webpack_require__(45);
- var wellKnownSymbol = __webpack_require__(9);
- var MATCH = wellKnownSymbol('match');
- // `IsRegExp` abstract operation
- // https://tc39.github.io/ecma262/#sec-isregexp
- module.exports = function (it) {
- var isRegExp;
- return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : classof(it) == 'RegExp');
- };
- /***/ }),
- /* 195 */
- /***/ (function(module, exports, __webpack_require__) {
- var wellKnownSymbol = __webpack_require__(9);
- var MATCH = wellKnownSymbol('match');
- module.exports = function (METHOD_NAME) {
- var regexp = /./;
- try {
- '/./'[METHOD_NAME](regexp);
- } catch (error1) {
- try {
- regexp[MATCH] = false;
- return '/./'[METHOD_NAME](regexp);
- } catch (error2) { /* empty */ }
- } return false;
- };
- /***/ }),
- /* 196 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(197);
- module.exports = parent;
- /***/ }),
- /* 197 */
- /***/ (function(module, exports, __webpack_require__) {
- var filter = __webpack_require__(198);
- var ArrayPrototype = Array.prototype;
- module.exports = function (it) {
- var own = it.filter;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.filter) ? filter : own;
- };
- /***/ }),
- /* 198 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(199);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').filter;
- /***/ }),
- /* 199 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var $filter = __webpack_require__(33).filter;
- var arrayMethodHasSpeciesSupport = __webpack_require__(53);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('filter');
- // Edge 14- issue
- var USES_TO_LENGTH = arrayMethodUsesToLength('filter');
- // `Array.prototype.filter` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.filter
- // with adding support of @@species
- $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT || !USES_TO_LENGTH }, {
- filter: function filter(callbackfn /* , thisArg */) {
- return $filter(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
- }
- });
- /***/ }),
- /* 200 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(201);
- module.exports = parent;
- /***/ }),
- /* 201 */
- /***/ (function(module, exports, __webpack_require__) {
- var splice = __webpack_require__(202);
- var ArrayPrototype = Array.prototype;
- module.exports = function (it) {
- var own = it.splice;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.splice) ? splice : own;
- };
- /***/ }),
- /* 202 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(203);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').splice;
- /***/ }),
- /* 203 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var toAbsoluteIndex = __webpack_require__(71);
- var toInteger = __webpack_require__(58);
- var toLength = __webpack_require__(36);
- var toObject = __webpack_require__(38);
- var arraySpeciesCreate = __webpack_require__(86);
- var createProperty = __webpack_require__(91);
- var arrayMethodHasSpeciesSupport = __webpack_require__(53);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('splice');
- var USES_TO_LENGTH = arrayMethodUsesToLength('splice', { ACCESSORS: true, 0: 0, 1: 2 });
- var max = Math.max;
- var min = Math.min;
- var MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF;
- var MAXIMUM_ALLOWED_LENGTH_EXCEEDED = 'Maximum allowed length exceeded';
- // `Array.prototype.splice` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.splice
- // with adding support of @@species
- $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT || !USES_TO_LENGTH }, {
- splice: function splice(start, deleteCount /* , ...items */) {
- var O = toObject(this);
- var len = toLength(O.length);
- var actualStart = toAbsoluteIndex(start, len);
- var argumentsLength = arguments.length;
- var insertCount, actualDeleteCount, A, k, from, to;
- if (argumentsLength === 0) {
- insertCount = actualDeleteCount = 0;
- } else if (argumentsLength === 1) {
- insertCount = 0;
- actualDeleteCount = len - actualStart;
- } else {
- insertCount = argumentsLength - 2;
- actualDeleteCount = min(max(toInteger(deleteCount), 0), len - actualStart);
- }
- if (len + insertCount - actualDeleteCount > MAX_SAFE_INTEGER) {
- throw TypeError(MAXIMUM_ALLOWED_LENGTH_EXCEEDED);
- }
- A = arraySpeciesCreate(O, actualDeleteCount);
- for (k = 0; k < actualDeleteCount; k++) {
- from = actualStart + k;
- if (from in O) createProperty(A, k, O[from]);
- }
- A.length = actualDeleteCount;
- if (insertCount < actualDeleteCount) {
- for (k = actualStart; k < len - actualDeleteCount; k++) {
- from = k + actualDeleteCount;
- to = k + insertCount;
- if (from in O) O[to] = O[from];
- else delete O[to];
- }
- for (k = len; k > len - actualDeleteCount + insertCount; k--) delete O[k - 1];
- } else if (insertCount > actualDeleteCount) {
- for (k = len - actualDeleteCount; k > actualStart; k--) {
- from = k + actualDeleteCount - 1;
- to = k + insertCount - 1;
- if (from in O) O[to] = O[from];
- else delete O[to];
- }
- }
- for (k = 0; k < insertCount; k++) {
- O[k + actualStart] = arguments[k + 2];
- }
- O.length = len - actualDeleteCount + insertCount;
- return A;
- }
- });
- /***/ }),
- /* 204 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(205);
- module.exports = parent;
- /***/ }),
- /* 205 */
- /***/ (function(module, exports, __webpack_require__) {
- var indexOf = __webpack_require__(206);
- var ArrayPrototype = Array.prototype;
- module.exports = function (it) {
- var own = it.indexOf;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.indexOf) ? indexOf : own;
- };
- /***/ }),
- /* 206 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(207);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').indexOf;
- /***/ }),
- /* 207 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var $indexOf = __webpack_require__(70).indexOf;
- var arrayMethodIsStrict = __webpack_require__(87);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var nativeIndexOf = [].indexOf;
- var NEGATIVE_ZERO = !!nativeIndexOf && 1 / [1].indexOf(1, -0) < 0;
- var STRICT_METHOD = arrayMethodIsStrict('indexOf');
- var USES_TO_LENGTH = arrayMethodUsesToLength('indexOf', { ACCESSORS: true, 1: 0 });
- // `Array.prototype.indexOf` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.indexof
- $({ target: 'Array', proto: true, forced: NEGATIVE_ZERO || !STRICT_METHOD || !USES_TO_LENGTH }, {
- indexOf: function indexOf(searchElement /* , fromIndex = 0 */) {
- return NEGATIVE_ZERO
- // convert -0 to +0
- ? nativeIndexOf.apply(this, arguments) || 0
- : $indexOf(this, searchElement, arguments.length > 1 ? arguments[1] : undefined);
- }
- });
- /***/ }),
- /* 208 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(209);
- module.exports = parent;
- /***/ }),
- /* 209 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(210);
- __webpack_require__(62);
- __webpack_require__(64);
- __webpack_require__(51);
- var path = __webpack_require__(10);
- module.exports = path.Map;
- /***/ }),
- /* 210 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var collection = __webpack_require__(115);
- var collectionStrong = __webpack_require__(117);
- // `Map` constructor
- // https://tc39.github.io/ecma262/#sec-map-objects
- module.exports = collection('Map', function (init) {
- return function Map() { return init(this, arguments.length ? arguments[0] : undefined); };
- }, collectionStrong);
- /***/ }),
- /* 211 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- module.exports = !fails(function () {
- return Object.isExtensible(Object.preventExtensions({}));
- });
- /***/ }),
- /* 212 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(213);
- module.exports = parent;
- /***/ }),
- /* 213 */
- /***/ (function(module, exports, __webpack_require__) {
- var trim = __webpack_require__(214);
- var StringPrototype = String.prototype;
- module.exports = function (it) {
- var own = it.trim;
- return typeof it === 'string' || it === StringPrototype
- || (it instanceof String && own === StringPrototype.trim) ? trim : own;
- };
- /***/ }),
- /* 214 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(215);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('String').trim;
- /***/ }),
- /* 215 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var $trim = __webpack_require__(92).trim;
- var forcedStringTrimMethod = __webpack_require__(216);
- // `String.prototype.trim` method
- // https://tc39.github.io/ecma262/#sec-string.prototype.trim
- $({ target: 'String', proto: true, forced: forcedStringTrimMethod('trim') }, {
- trim: function trim() {
- return $trim(this);
- }
- });
- /***/ }),
- /* 216 */
- /***/ (function(module, exports, __webpack_require__) {
- var fails = __webpack_require__(12);
- var whitespaces = __webpack_require__(66);
- var non = '\u200B\u0085\u180E';
- // check that a method works with the correct list
- // of whitespaces and has a correct name
- module.exports = function (METHOD_NAME) {
- return fails(function () {
- return !!whitespaces[METHOD_NAME]() || non[METHOD_NAME]() != non || whitespaces[METHOD_NAME].name !== METHOD_NAME;
- });
- };
- /***/ }),
- /* 217 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(218);
- module.exports = parent;
- /***/ }),
- /* 218 */
- /***/ (function(module, exports, __webpack_require__) {
- var map = __webpack_require__(219);
- var ArrayPrototype = Array.prototype;
- module.exports = function (it) {
- var own = it.map;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.map) ? map : own;
- };
- /***/ }),
- /* 219 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(220);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').map;
- /***/ }),
- /* 220 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var $map = __webpack_require__(33).map;
- var arrayMethodHasSpeciesSupport = __webpack_require__(53);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('map');
- // FF49- issue
- var USES_TO_LENGTH = arrayMethodUsesToLength('map');
- // `Array.prototype.map` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.map
- // with adding support of @@species
- $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT || !USES_TO_LENGTH }, {
- map: function map(callbackfn /* , thisArg */) {
- return $map(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
- }
- });
- /***/ }),
- /* 221 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(222);
- module.exports = parent;
- /***/ }),
- /* 222 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(223);
- var path = __webpack_require__(10);
- module.exports = path.Array.isArray;
- /***/ }),
- /* 223 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var isArray = __webpack_require__(52);
- // `Array.isArray` method
- // https://tc39.github.io/ecma262/#sec-array.isarray
- $({ target: 'Array', stat: true }, {
- isArray: isArray
- });
- /***/ }),
- /* 224 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(225);
- /***/ }),
- /* 225 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(226);
- module.exports = parent;
- /***/ }),
- /* 226 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(118);
- __webpack_require__(64);
- __webpack_require__(51);
- var WrappedWellKnownSymbolModule = __webpack_require__(95);
- module.exports = WrappedWellKnownSymbolModule.f('iterator');
- /***/ }),
- /* 227 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(228);
- /***/ }),
- /* 228 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(229);
- __webpack_require__(249);
- __webpack_require__(250);
- __webpack_require__(251);
- __webpack_require__(252);
- // TODO: Remove from `core-js@4`
- __webpack_require__(253);
- module.exports = parent;
- /***/ }),
- /* 229 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(230);
- __webpack_require__(62);
- __webpack_require__(231);
- __webpack_require__(233);
- __webpack_require__(234);
- __webpack_require__(235);
- __webpack_require__(236);
- __webpack_require__(118);
- __webpack_require__(237);
- __webpack_require__(238);
- __webpack_require__(239);
- __webpack_require__(240);
- __webpack_require__(241);
- __webpack_require__(242);
- __webpack_require__(243);
- __webpack_require__(244);
- __webpack_require__(245);
- __webpack_require__(246);
- __webpack_require__(247);
- __webpack_require__(248);
- var path = __webpack_require__(10);
- module.exports = path.Symbol;
- /***/ }),
- /* 230 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var fails = __webpack_require__(12);
- var isArray = __webpack_require__(52);
- var isObject = __webpack_require__(13);
- var toObject = __webpack_require__(38);
- var toLength = __webpack_require__(36);
- var createProperty = __webpack_require__(91);
- var arraySpeciesCreate = __webpack_require__(86);
- var arrayMethodHasSpeciesSupport = __webpack_require__(53);
- var wellKnownSymbol = __webpack_require__(9);
- var V8_VERSION = __webpack_require__(83);
- var IS_CONCAT_SPREADABLE = wellKnownSymbol('isConcatSpreadable');
- var MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF;
- var MAXIMUM_ALLOWED_INDEX_EXCEEDED = 'Maximum allowed index exceeded';
- // We can't use this feature detection in V8 since it causes
- // deoptimization and serious performance degradation
- // https://github.com/zloirock/core-js/issues/679
- var IS_CONCAT_SPREADABLE_SUPPORT = V8_VERSION >= 51 || !fails(function () {
- var array = [];
- array[IS_CONCAT_SPREADABLE] = false;
- return array.concat()[0] !== array;
- });
- var SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('concat');
- var isConcatSpreadable = function (O) {
- if (!isObject(O)) return false;
- var spreadable = O[IS_CONCAT_SPREADABLE];
- return spreadable !== undefined ? !!spreadable : isArray(O);
- };
- var FORCED = !IS_CONCAT_SPREADABLE_SUPPORT || !SPECIES_SUPPORT;
- // `Array.prototype.concat` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.concat
- // with adding support of @@isConcatSpreadable and @@species
- $({ target: 'Array', proto: true, forced: FORCED }, {
- concat: function concat(arg) { // eslint-disable-line no-unused-vars
- var O = toObject(this);
- var A = arraySpeciesCreate(O, 0);
- var n = 0;
- var i, k, length, len, E;
- for (i = -1, length = arguments.length; i < length; i++) {
- E = i === -1 ? O : arguments[i];
- if (isConcatSpreadable(E)) {
- len = toLength(E.length);
- if (n + len > MAX_SAFE_INTEGER) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
- for (k = 0; k < len; k++, n++) if (k in E) createProperty(A, n, E[k]);
- } else {
- if (n >= MAX_SAFE_INTEGER) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
- createProperty(A, n++, E);
- }
- }
- A.length = n;
- return A;
- }
- });
- /***/ }),
- /* 231 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var global = __webpack_require__(8);
- var getBuiltIn = __webpack_require__(28);
- var IS_PURE = __webpack_require__(37);
- var DESCRIPTORS = __webpack_require__(14);
- var NATIVE_SYMBOL = __webpack_require__(77);
- var USE_SYMBOL_AS_UID = __webpack_require__(104);
- var fails = __webpack_require__(12);
- var has = __webpack_require__(15);
- var isArray = __webpack_require__(52);
- var isObject = __webpack_require__(13);
- var anObject = __webpack_require__(24);
- var toObject = __webpack_require__(38);
- var toIndexedObject = __webpack_require__(27);
- var toPrimitive = __webpack_require__(56);
- var createPropertyDescriptor = __webpack_require__(35);
- var nativeObjectCreate = __webpack_require__(48);
- var objectKeys = __webpack_require__(57);
- var getOwnPropertyNamesModule = __webpack_require__(119);
- var getOwnPropertyNamesExternal = __webpack_require__(232);
- var getOwnPropertySymbolsModule = __webpack_require__(120);
- var getOwnPropertyDescriptorModule = __webpack_require__(67);
- var definePropertyModule = __webpack_require__(18);
- var propertyIsEnumerableModule = __webpack_require__(55);
- var createNonEnumerableProperty = __webpack_require__(17);
- var redefine = __webpack_require__(50);
- var shared = __webpack_require__(73);
- var sharedKey = __webpack_require__(59);
- var hiddenKeys = __webpack_require__(49);
- var uid = __webpack_require__(60);
- var wellKnownSymbol = __webpack_require__(9);
- var wrappedWellKnownSymbolModule = __webpack_require__(95);
- var defineWellKnownSymbol = __webpack_require__(11);
- var setToStringTag = __webpack_require__(41);
- var InternalStateModule = __webpack_require__(42);
- var $forEach = __webpack_require__(33).forEach;
- var HIDDEN = sharedKey('hidden');
- var SYMBOL = 'Symbol';
- var PROTOTYPE = 'prototype';
- var TO_PRIMITIVE = wellKnownSymbol('toPrimitive');
- var setInternalState = InternalStateModule.set;
- var getInternalState = InternalStateModule.getterFor(SYMBOL);
- var ObjectPrototype = Object[PROTOTYPE];
- var $Symbol = global.Symbol;
- var $stringify = getBuiltIn('JSON', 'stringify');
- var nativeGetOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;
- var nativeDefineProperty = definePropertyModule.f;
- var nativeGetOwnPropertyNames = getOwnPropertyNamesExternal.f;
- var nativePropertyIsEnumerable = propertyIsEnumerableModule.f;
- var AllSymbols = shared('symbols');
- var ObjectPrototypeSymbols = shared('op-symbols');
- var StringToSymbolRegistry = shared('string-to-symbol-registry');
- var SymbolToStringRegistry = shared('symbol-to-string-registry');
- var WellKnownSymbolsStore = shared('wks');
- var QObject = global.QObject;
- // Don't use setters in Qt Script, https://github.com/zloirock/core-js/issues/173
- var USE_SETTER = !QObject || !QObject[PROTOTYPE] || !QObject[PROTOTYPE].findChild;
- // fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687
- var setSymbolDescriptor = DESCRIPTORS && fails(function () {
- return nativeObjectCreate(nativeDefineProperty({}, 'a', {
- get: function () { return nativeDefineProperty(this, 'a', { value: 7 }).a; }
- })).a != 7;
- }) ? function (O, P, Attributes) {
- var ObjectPrototypeDescriptor = nativeGetOwnPropertyDescriptor(ObjectPrototype, P);
- if (ObjectPrototypeDescriptor) delete ObjectPrototype[P];
- nativeDefineProperty(O, P, Attributes);
- if (ObjectPrototypeDescriptor && O !== ObjectPrototype) {
- nativeDefineProperty(ObjectPrototype, P, ObjectPrototypeDescriptor);
- }
- } : nativeDefineProperty;
- var wrap = function (tag, description) {
- var symbol = AllSymbols[tag] = nativeObjectCreate($Symbol[PROTOTYPE]);
- setInternalState(symbol, {
- type: SYMBOL,
- tag: tag,
- description: description
- });
- if (!DESCRIPTORS) symbol.description = description;
- return symbol;
- };
- var isSymbol = USE_SYMBOL_AS_UID ? function (it) {
- return typeof it == 'symbol';
- } : function (it) {
- return Object(it) instanceof $Symbol;
- };
- var $defineProperty = function defineProperty(O, P, Attributes) {
- if (O === ObjectPrototype) $defineProperty(ObjectPrototypeSymbols, P, Attributes);
- anObject(O);
- var key = toPrimitive(P, true);
- anObject(Attributes);
- if (has(AllSymbols, key)) {
- if (!Attributes.enumerable) {
- if (!has(O, HIDDEN)) nativeDefineProperty(O, HIDDEN, createPropertyDescriptor(1, {}));
- O[HIDDEN][key] = true;
- } else {
- if (has(O, HIDDEN) && O[HIDDEN][key]) O[HIDDEN][key] = false;
- Attributes = nativeObjectCreate(Attributes, { enumerable: createPropertyDescriptor(0, false) });
- } return setSymbolDescriptor(O, key, Attributes);
- } return nativeDefineProperty(O, key, Attributes);
- };
- var $defineProperties = function defineProperties(O, Properties) {
- anObject(O);
- var properties = toIndexedObject(Properties);
- var keys = objectKeys(properties).concat($getOwnPropertySymbols(properties));
- $forEach(keys, function (key) {
- if (!DESCRIPTORS || $propertyIsEnumerable.call(properties, key)) $defineProperty(O, key, properties[key]);
- });
- return O;
- };
- var $create = function create(O, Properties) {
- return Properties === undefined ? nativeObjectCreate(O) : $defineProperties(nativeObjectCreate(O), Properties);
- };
- var $propertyIsEnumerable = function propertyIsEnumerable(V) {
- var P = toPrimitive(V, true);
- var enumerable = nativePropertyIsEnumerable.call(this, P);
- if (this === ObjectPrototype && has(AllSymbols, P) && !has(ObjectPrototypeSymbols, P)) return false;
- return enumerable || !has(this, P) || !has(AllSymbols, P) || has(this, HIDDEN) && this[HIDDEN][P] ? enumerable : true;
- };
- var $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(O, P) {
- var it = toIndexedObject(O);
- var key = toPrimitive(P, true);
- if (it === ObjectPrototype && has(AllSymbols, key) && !has(ObjectPrototypeSymbols, key)) return;
- var descriptor = nativeGetOwnPropertyDescriptor(it, key);
- if (descriptor && has(AllSymbols, key) && !(has(it, HIDDEN) && it[HIDDEN][key])) {
- descriptor.enumerable = true;
- }
- return descriptor;
- };
- var $getOwnPropertyNames = function getOwnPropertyNames(O) {
- var names = nativeGetOwnPropertyNames(toIndexedObject(O));
- var result = [];
- $forEach(names, function (key) {
- if (!has(AllSymbols, key) && !has(hiddenKeys, key)) result.push(key);
- });
- return result;
- };
- var $getOwnPropertySymbols = function getOwnPropertySymbols(O) {
- var IS_OBJECT_PROTOTYPE = O === ObjectPrototype;
- var names = nativeGetOwnPropertyNames(IS_OBJECT_PROTOTYPE ? ObjectPrototypeSymbols : toIndexedObject(O));
- var result = [];
- $forEach(names, function (key) {
- if (has(AllSymbols, key) && (!IS_OBJECT_PROTOTYPE || has(ObjectPrototype, key))) {
- result.push(AllSymbols[key]);
- }
- });
- return result;
- };
- // `Symbol` constructor
- // https://tc39.github.io/ecma262/#sec-symbol-constructor
- if (!NATIVE_SYMBOL) {
- $Symbol = function Symbol() {
- if (this instanceof $Symbol) throw TypeError('Symbol is not a constructor');
- var description = !arguments.length || arguments[0] === undefined ? undefined : String(arguments[0]);
- var tag = uid(description);
- var setter = function (value) {
- if (this === ObjectPrototype) setter.call(ObjectPrototypeSymbols, value);
- if (has(this, HIDDEN) && has(this[HIDDEN], tag)) this[HIDDEN][tag] = false;
- setSymbolDescriptor(this, tag, createPropertyDescriptor(1, value));
- };
- if (DESCRIPTORS && USE_SETTER) setSymbolDescriptor(ObjectPrototype, tag, { configurable: true, set: setter });
- return wrap(tag, description);
- };
- redefine($Symbol[PROTOTYPE], 'toString', function toString() {
- return getInternalState(this).tag;
- });
- redefine($Symbol, 'withoutSetter', function (description) {
- return wrap(uid(description), description);
- });
- propertyIsEnumerableModule.f = $propertyIsEnumerable;
- definePropertyModule.f = $defineProperty;
- getOwnPropertyDescriptorModule.f = $getOwnPropertyDescriptor;
- getOwnPropertyNamesModule.f = getOwnPropertyNamesExternal.f = $getOwnPropertyNames;
- getOwnPropertySymbolsModule.f = $getOwnPropertySymbols;
- wrappedWellKnownSymbolModule.f = function (name) {
- return wrap(wellKnownSymbol(name), name);
- };
- if (DESCRIPTORS) {
- // https://github.com/tc39/proposal-Symbol-description
- nativeDefineProperty($Symbol[PROTOTYPE], 'description', {
- configurable: true,
- get: function description() {
- return getInternalState(this).description;
- }
- });
- if (!IS_PURE) {
- redefine(ObjectPrototype, 'propertyIsEnumerable', $propertyIsEnumerable, { unsafe: true });
- }
- }
- }
- $({ global: true, wrap: true, forced: !NATIVE_SYMBOL, sham: !NATIVE_SYMBOL }, {
- Symbol: $Symbol
- });
- $forEach(objectKeys(WellKnownSymbolsStore), function (name) {
- defineWellKnownSymbol(name);
- });
- $({ target: SYMBOL, stat: true, forced: !NATIVE_SYMBOL }, {
- // `Symbol.for` method
- // https://tc39.github.io/ecma262/#sec-symbol.for
- 'for': function (key) {
- var string = String(key);
- if (has(StringToSymbolRegistry, string)) return StringToSymbolRegistry[string];
- var symbol = $Symbol(string);
- StringToSymbolRegistry[string] = symbol;
- SymbolToStringRegistry[symbol] = string;
- return symbol;
- },
- // `Symbol.keyFor` method
- // https://tc39.github.io/ecma262/#sec-symbol.keyfor
- keyFor: function keyFor(sym) {
- if (!isSymbol(sym)) throw TypeError(sym + ' is not a symbol');
- if (has(SymbolToStringRegistry, sym)) return SymbolToStringRegistry[sym];
- },
- useSetter: function () { USE_SETTER = true; },
- useSimple: function () { USE_SETTER = false; }
- });
- $({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL, sham: !DESCRIPTORS }, {
- // `Object.create` method
- // https://tc39.github.io/ecma262/#sec-object.create
- create: $create,
- // `Object.defineProperty` method
- // https://tc39.github.io/ecma262/#sec-object.defineproperty
- defineProperty: $defineProperty,
- // `Object.defineProperties` method
- // https://tc39.github.io/ecma262/#sec-object.defineproperties
- defineProperties: $defineProperties,
- // `Object.getOwnPropertyDescriptor` method
- // https://tc39.github.io/ecma262/#sec-object.getownpropertydescriptors
- getOwnPropertyDescriptor: $getOwnPropertyDescriptor
- });
- $({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL }, {
- // `Object.getOwnPropertyNames` method
- // https://tc39.github.io/ecma262/#sec-object.getownpropertynames
- getOwnPropertyNames: $getOwnPropertyNames,
- // `Object.getOwnPropertySymbols` method
- // https://tc39.github.io/ecma262/#sec-object.getownpropertysymbols
- getOwnPropertySymbols: $getOwnPropertySymbols
- });
- // Chrome 38 and 39 `Object.getOwnPropertySymbols` fails on primitives
- // https://bugs.chromium.org/p/v8/issues/detail?id=3443
- $({ target: 'Object', stat: true, forced: fails(function () { getOwnPropertySymbolsModule.f(1); }) }, {
- getOwnPropertySymbols: function getOwnPropertySymbols(it) {
- return getOwnPropertySymbolsModule.f(toObject(it));
- }
- });
- // `JSON.stringify` method behavior with symbols
- // https://tc39.github.io/ecma262/#sec-json.stringify
- if ($stringify) {
- var FORCED_JSON_STRINGIFY = !NATIVE_SYMBOL || fails(function () {
- var symbol = $Symbol();
- // MS Edge converts symbol values to JSON as {}
- return $stringify([symbol]) != '[null]'
- // WebKit converts symbol values to JSON as null
- || $stringify({ a: symbol }) != '{}'
- // V8 throws on boxed symbols
- || $stringify(Object(symbol)) != '{}';
- });
- $({ target: 'JSON', stat: true, forced: FORCED_JSON_STRINGIFY }, {
- // eslint-disable-next-line no-unused-vars
- stringify: function stringify(it, replacer, space) {
- var args = [it];
- var index = 1;
- var $replacer;
- while (arguments.length > index) args.push(arguments[index++]);
- $replacer = replacer;
- if (!isObject(replacer) && it === undefined || isSymbol(it)) return; // IE8 returns string on undefined
- if (!isArray(replacer)) replacer = function (key, value) {
- if (typeof $replacer == 'function') value = $replacer.call(this, key, value);
- if (!isSymbol(value)) return value;
- };
- args[1] = replacer;
- return $stringify.apply(null, args);
- }
- });
- }
- // `Symbol.prototype[@@toPrimitive]` method
- // https://tc39.github.io/ecma262/#sec-symbol.prototype-@@toprimitive
- if (!$Symbol[PROTOTYPE][TO_PRIMITIVE]) {
- createNonEnumerableProperty($Symbol[PROTOTYPE], TO_PRIMITIVE, $Symbol[PROTOTYPE].valueOf);
- }
- // `Symbol.prototype[@@toStringTag]` property
- // https://tc39.github.io/ecma262/#sec-symbol.prototype-@@tostringtag
- setToStringTag($Symbol, SYMBOL);
- hiddenKeys[HIDDEN] = true;
- /***/ }),
- /* 232 */
- /***/ (function(module, exports, __webpack_require__) {
- var toIndexedObject = __webpack_require__(27);
- var nativeGetOwnPropertyNames = __webpack_require__(119).f;
- var toString = {}.toString;
- var windowNames = typeof window == 'object' && window && Object.getOwnPropertyNames
- ? Object.getOwnPropertyNames(window) : [];
- var getWindowNames = function (it) {
- try {
- return nativeGetOwnPropertyNames(it);
- } catch (error) {
- return windowNames.slice();
- }
- };
- // fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window
- module.exports.f = function getOwnPropertyNames(it) {
- return windowNames && toString.call(it) == '[object Window]'
- ? getWindowNames(it)
- : nativeGetOwnPropertyNames(toIndexedObject(it));
- };
- /***/ }),
- /* 233 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.asyncIterator` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.asynciterator
- defineWellKnownSymbol('asyncIterator');
- /***/ }),
- /* 234 */
- /***/ (function(module, exports) {
- // empty
- /***/ }),
- /* 235 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.hasInstance` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.hasinstance
- defineWellKnownSymbol('hasInstance');
- /***/ }),
- /* 236 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.isConcatSpreadable` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.isconcatspreadable
- defineWellKnownSymbol('isConcatSpreadable');
- /***/ }),
- /* 237 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.match` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.match
- defineWellKnownSymbol('match');
- /***/ }),
- /* 238 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.matchAll` well-known symbol
- defineWellKnownSymbol('matchAll');
- /***/ }),
- /* 239 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.replace` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.replace
- defineWellKnownSymbol('replace');
- /***/ }),
- /* 240 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.search` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.search
- defineWellKnownSymbol('search');
- /***/ }),
- /* 241 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.species` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.species
- defineWellKnownSymbol('species');
- /***/ }),
- /* 242 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.split` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.split
- defineWellKnownSymbol('split');
- /***/ }),
- /* 243 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.toPrimitive` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.toprimitive
- defineWellKnownSymbol('toPrimitive');
- /***/ }),
- /* 244 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.toStringTag` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.tostringtag
- defineWellKnownSymbol('toStringTag');
- /***/ }),
- /* 245 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.unscopables` well-known symbol
- // https://tc39.github.io/ecma262/#sec-symbol.unscopables
- defineWellKnownSymbol('unscopables');
- /***/ }),
- /* 246 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var setToStringTag = __webpack_require__(41);
- // JSON[@@toStringTag] property
- // https://tc39.github.io/ecma262/#sec-json-@@tostringtag
- setToStringTag(global.JSON, 'JSON', true);
- /***/ }),
- /* 247 */
- /***/ (function(module, exports) {
- // empty
- /***/ }),
- /* 248 */
- /***/ (function(module, exports) {
- // empty
- /***/ }),
- /* 249 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.asyncDispose` well-known symbol
- // https://github.com/tc39/proposal-using-statement
- defineWellKnownSymbol('asyncDispose');
- /***/ }),
- /* 250 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.dispose` well-known symbol
- // https://github.com/tc39/proposal-using-statement
- defineWellKnownSymbol('dispose');
- /***/ }),
- /* 251 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.observable` well-known symbol
- // https://github.com/tc39/proposal-observable
- defineWellKnownSymbol('observable');
- /***/ }),
- /* 252 */
- /***/ (function(module, exports, __webpack_require__) {
- var defineWellKnownSymbol = __webpack_require__(11);
- // `Symbol.patternMatch` well-known symbol
- // https://github.com/tc39/proposal-pattern-matching
- defineWellKnownSymbol('patternMatch');
- /***/ }),
- /* 253 */
- /***/ (function(module, exports, __webpack_require__) {
- // TODO: remove from `core-js@4`
- var defineWellKnownSymbol = __webpack_require__(11);
- defineWellKnownSymbol('replaceAll');
- /***/ }),
- /* 254 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(255);
- var path = __webpack_require__(10);
- module.exports = path.setTimeout;
- /***/ }),
- /* 255 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var global = __webpack_require__(8);
- var userAgent = __webpack_require__(80);
- var slice = [].slice;
- var MSIE = /MSIE .\./.test(userAgent); // <- dirty ie9- check
- var wrap = function (scheduler) {
- return function (handler, timeout /* , ...arguments */) {
- var boundArgs = arguments.length > 2;
- var args = boundArgs ? slice.call(arguments, 2) : undefined;
- return scheduler(boundArgs ? function () {
- // eslint-disable-next-line no-new-func
- (typeof handler == 'function' ? handler : Function(handler)).apply(this, args);
- } : handler, timeout);
- };
- };
- // ie9- setTimeout & setInterval additional parameters fix
- // https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#timers
- $({ global: true, bind: true, forced: MSIE }, {
- // `setTimeout` method
- // https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#dom-settimeout
- setTimeout: wrap(global.setTimeout),
- // `setInterval` method
- // https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#dom-setinterval
- setInterval: wrap(global.setInterval)
- });
- /***/ }),
- /* 256 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(257);
- module.exports = parent;
- /***/ }),
- /* 257 */
- /***/ (function(module, exports, __webpack_require__) {
- var slice = __webpack_require__(258);
- var ArrayPrototype = Array.prototype;
- module.exports = function (it) {
- var own = it.slice;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.slice) ? slice : own;
- };
- /***/ }),
- /* 258 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(259);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').slice;
- /***/ }),
- /* 259 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var isObject = __webpack_require__(13);
- var isArray = __webpack_require__(52);
- var toAbsoluteIndex = __webpack_require__(71);
- var toLength = __webpack_require__(36);
- var toIndexedObject = __webpack_require__(27);
- var createProperty = __webpack_require__(91);
- var wellKnownSymbol = __webpack_require__(9);
- var arrayMethodHasSpeciesSupport = __webpack_require__(53);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('slice');
- var USES_TO_LENGTH = arrayMethodUsesToLength('slice', { ACCESSORS: true, 0: 0, 1: 2 });
- var SPECIES = wellKnownSymbol('species');
- var nativeSlice = [].slice;
- var max = Math.max;
- // `Array.prototype.slice` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.slice
- // fallback for not array-like ES3 strings and DOM objects
- $({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT || !USES_TO_LENGTH }, {
- slice: function slice(start, end) {
- var O = toIndexedObject(this);
- var length = toLength(O.length);
- var k = toAbsoluteIndex(start, length);
- var fin = toAbsoluteIndex(end === undefined ? length : end, length);
- // inline `ArraySpeciesCreate` for usage native `Array#slice` where it's possible
- var Constructor, result, n;
- if (isArray(O)) {
- Constructor = O.constructor;
- // cross-realm fallback
- if (typeof Constructor == 'function' && (Constructor === Array || isArray(Constructor.prototype))) {
- Constructor = undefined;
- } else if (isObject(Constructor)) {
- Constructor = Constructor[SPECIES];
- if (Constructor === null) Constructor = undefined;
- }
- if (Constructor === Array || Constructor === undefined) {
- return nativeSlice.call(O, k, fin);
- }
- }
- result = new (Constructor === undefined ? Array : Constructor)(max(fin - k, 0));
- for (n = 0; k < fin; k++, n++) if (k in O) createProperty(result, n, O[k]);
- result.length = n;
- return result;
- }
- });
- /***/ }),
- /* 260 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(261);
- /***/ }),
- /* 261 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(262);
- module.exports = parent;
- /***/ }),
- /* 262 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(263);
- var path = __webpack_require__(10);
- module.exports = path.parseInt;
- /***/ }),
- /* 263 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var parseIntImplementation = __webpack_require__(264);
- // `parseInt` method
- // https://tc39.github.io/ecma262/#sec-parseint-string-radix
- $({ global: true, forced: parseInt != parseIntImplementation }, {
- parseInt: parseIntImplementation
- });
- /***/ }),
- /* 264 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var trim = __webpack_require__(92).trim;
- var whitespaces = __webpack_require__(66);
- var $parseInt = global.parseInt;
- var hex = /^[+-]?0[Xx]/;
- var FORCED = $parseInt(whitespaces + '08') !== 8 || $parseInt(whitespaces + '0x16') !== 22;
- // `parseInt` method
- // https://tc39.github.io/ecma262/#sec-parseint-string-radix
- module.exports = FORCED ? function parseInt(string, radix) {
- var S = trim(String(string));
- return $parseInt(S, (radix >>> 0) || (hex.test(S) ? 16 : 10));
- } : $parseInt;
- /***/ }),
- /* 265 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 编辑器配置
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _assign = _interopRequireDefault(__webpack_require__(266));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var menus_1 = __importDefault(__webpack_require__(271));
- var events_1 = __importDefault(__webpack_require__(272));
- var style_1 = __importDefault(__webpack_require__(122));
- var paste_1 = __importDefault(__webpack_require__(273));
- var cmd_1 = __importDefault(__webpack_require__(274));
- var image_1 = __importDefault(__webpack_require__(275));
- var text_1 = __importDefault(__webpack_require__(276));
- var lang_1 = __importDefault(__webpack_require__(277));
- var history_1 = __importDefault(__webpack_require__(278));
- var video_1 = __importDefault(__webpack_require__(279)); // 合并所有的配置信息
- 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"], //链接校验的配置函数
- {
- linkCheck: function linkCheck(text, link) {
- return true;
- }
- }, //网络图片校验的配置函数
- {
- linkImgCheck: function linkImgCheck(src) {
- return true;
- }
- });
- exports["default"] = defaultConfig;
- /***/ }),
- /* 266 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(267);
- /***/ }),
- /* 267 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(268);
- module.exports = parent;
- /***/ }),
- /* 268 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(269);
- var path = __webpack_require__(10);
- module.exports = path.Object.assign;
- /***/ }),
- /* 269 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var assign = __webpack_require__(270);
- // `Object.assign` method
- // https://tc39.github.io/ecma262/#sec-object.assign
- $({ target: 'Object', stat: true, forced: Object.assign !== assign }, {
- assign: assign
- });
- /***/ }),
- /* 270 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var DESCRIPTORS = __webpack_require__(14);
- var fails = __webpack_require__(12);
- var objectKeys = __webpack_require__(57);
- var getOwnPropertySymbolsModule = __webpack_require__(120);
- var propertyIsEnumerableModule = __webpack_require__(55);
- var toObject = __webpack_require__(38);
- var IndexedObject = __webpack_require__(68);
- var nativeAssign = Object.assign;
- var defineProperty = Object.defineProperty;
- // `Object.assign` method
- // https://tc39.github.io/ecma262/#sec-object.assign
- module.exports = !nativeAssign || fails(function () {
- // should have correct order of operations (Edge bug)
- if (DESCRIPTORS && nativeAssign({ b: 1 }, nativeAssign(defineProperty({}, 'a', {
- enumerable: true,
- get: function () {
- defineProperty(this, 'b', {
- value: 3,
- enumerable: false
- });
- }
- }), { b: 2 })).b !== 1) return true;
- // should work with symbols and should have deterministic property order (V8 bug)
- var A = {};
- var B = {};
- // eslint-disable-next-line no-undef
- var symbol = Symbol();
- var alphabet = 'abcdefghijklmnopqrst';
- A[symbol] = 7;
- alphabet.split('').forEach(function (chr) { B[chr] = chr; });
- return nativeAssign({}, A)[symbol] != 7 || objectKeys(nativeAssign({}, B)).join('') != alphabet;
- }) ? function assign(target, source) { // eslint-disable-line no-unused-vars
- var T = toObject(target);
- var argumentsLength = arguments.length;
- var index = 1;
- var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;
- var propertyIsEnumerable = propertyIsEnumerableModule.f;
- while (argumentsLength > index) {
- var S = IndexedObject(arguments[index++]);
- var keys = getOwnPropertySymbols ? objectKeys(S).concat(getOwnPropertySymbols(S)) : objectKeys(S);
- var length = keys.length;
- var j = 0;
- var key;
- while (length > j) {
- key = keys[j++];
- if (!DESCRIPTORS || propertyIsEnumerable.call(S, key)) T[key] = S[key];
- }
- } return T;
- } : nativeAssign;
- /***/ }),
- /* 271 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 菜单配置
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var SINA_PATH1 = 'http://img.t.sinajs.cn/t4/appstyle/expression/ext/normal';
- var SINA_PATH2 = 'http://img.t.sinajs.cn/t35/style/images/common/face/ext/normal';
- /*表情菜单数据结构类型END*/
- exports["default"] = {
- menus: ['head', 'bold', 'fontSize', // 'customFontSize',
- 'fontName', 'italic', 'underline', 'strikeThrough', 'indent', 'lineHeight', 'foreColor', 'backColor', 'link', 'list', 'todo', 'justify', 'quote', 'emoticon', 'image', 'video', 'table', 'code', 'splitLine', 'undo', 'redo'],
- fontNames: ['黑体', '仿宋', '楷体', '标楷体', '华文仿宋', '华文楷体', '宋体', '微软雅黑', 'Arial', 'Tahoma', 'Verdana', 'Times New Roman', 'Courier New'],
- fontSizes: {
- 'x-small': {
- name: '10px',
- value: '1'
- },
- small: {
- name: '13px',
- value: '2'
- },
- normal: {
- name: '16px',
- value: '3'
- },
- large: {
- name: '18px',
- value: '4'
- },
- 'x-large': {
- name: '24px',
- value: '5'
- },
- 'xx-large': {
- name: '32px',
- value: '6'
- },
- 'xxx-large': {
- name: '48px',
- value: '7'
- }
- },
- // customFontSize: [ // 该菜单暂时不用 - 王福朋 20200924
- // { value: '9px', text: '9' },
- // { value: '10px', text: '10' },
- // { value: '12px', text: '12' },
- // { value: '14px', text: '14' },
- // { value: '16px', text: '16' },
- // { value: '20px', text: '20' },
- // { value: '42px', text: '42' },
- // { value: '72px', text: '72' },
- // ],
- colors: ['#000000', '#eeece0', '#1c487f', '#4d80bf', '#c24f4a', '#8baa4a', '#7b5ba1', '#46acc8', '#f9963b', '#ffffff'],
- //插入代码语言配置
- languageType: ['Bash', 'C', 'C#', 'C++', 'CSS', 'Java', 'JavaScript', 'JSON', 'TypeScript', 'Plain text', 'Html', 'XML', 'SQL', 'Go', 'Kotlin', 'Lua', 'Markdown', 'PHP', 'Python', 'Shell Session', 'Ruby'],
- languageTab: ' ',
- /**
- * 表情配置菜单
- * 如果为emoji表情直接作为元素插入
- * emoticon:Array<EmotionsType>
- */
- emotions: [{
- // tab 的标题
- title: '默认',
- // type -> 'emoji' / 'image'
- type: 'image',
- // content -> 数组
- content: [{
- alt: '[坏笑]',
- src: SINA_PATH1 + "/50/pcmoren_huaixiao_org.png"
- }, {
- alt: '[舔屏]',
- src: SINA_PATH1 + "/40/pcmoren_tian_org.png"
- }, {
- alt: '[污]',
- src: SINA_PATH1 + "/3c/pcmoren_wu_org.png"
- }]
- }, {
- // tab 的标题
- title: '新浪',
- // type -> 'emoji' / 'image'
- type: 'image',
- // content -> 数组
- content: [{
- src: SINA_PATH2 + "/7a/shenshou_thumb.gif",
- alt: '[草泥马]'
- }, {
- src: SINA_PATH2 + "/60/horse2_thumb.gif",
- alt: '[神马]'
- }, {
- src: SINA_PATH2 + "/bc/fuyun_thumb.gif",
- alt: '[浮云]'
- }]
- }, {
- // tab 的标题
- title: 'emoji',
- // type -> 'emoji' / 'image'
- type: 'emoji',
- // content -> 数组
- content: '😀 😃 😄 😁 😆 😅 😂 😊 😇 🙂 🙃 😉 😓 😪 😴 🙄 🤔 😬 🤐'.split(/\s/)
- }, {
- // tab 的标题
- title: '手势',
- // type -> 'emoji' / 'image'
- type: 'emoji',
- // content -> 数组
- content: ['🙌', '👏', '👋', '👍', '👎', '👊', '✊', '️👌', '✋', '👐', '💪', '🙏', '️👆', '👇', '👈', '👉', '🖕', '🖐', '🤘']
- }],
- lineHeights: ['1', '1.15', '1.6', '2', '2.5', '3'],
- undoLimit: 20,
- indentation: '2em'
- };
- /***/ }),
- /* 272 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 事件配置
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var const_1 = __webpack_require__(26);
- /**
- * 提示信息
- * @param alertInfo alert info
- * @param alertType 错误提示类型
- * @param debugInfo debug info
- */
- function customAlert(alertInfo, alertType, debugInfo) {
- window.alert(alertInfo);
- if (debugInfo) {
- console.error('wangEditor: ' + debugInfo);
- }
- }
- exports["default"] = {
- onchangeTimeout: 200,
- onchange: const_1.EMPTY_FN,
- onfocus: const_1.EMPTY_FN,
- onblur: const_1.EMPTY_FN,
- onCatalogChange: null,
- customAlert: customAlert
- };
- /***/ }),
- /* 273 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 粘贴,配置文件
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports["default"] = {
- // 粘贴过滤样式,默认开启
- pasteFilterStyle: true,
- // 粘贴内容时,忽略图片。默认关闭
- pasteIgnoreImg: false,
- // 对粘贴的文字进行自定义处理,返回处理后的结果。编辑器会将处理后的结果粘贴到编辑区域中。
- // IE 暂时不支持
- pasteTextHandle: function pasteTextHandle(content) {
- // content 即粘贴过来的内容(html 或 纯文本),可进行自定义处理然后返回
- return content;
- }
- };
- /***/ }),
- /* 274 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 命令配置项
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports["default"] = {
- styleWithCSS: false
- };
- /***/ }),
- /* 275 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 图片相关的配置
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var const_1 = __webpack_require__(26);
- exports["default"] = {
- // 显示“插入网络图片”
- showLinkImg: true,
- // 插入图片成功之后的回调函数
- linkImgCallback: const_1.EMPTY_FN,
- // accept
- uploadImgAccept: ['jpg', 'jpeg', 'png', 'gif', 'bmp'],
- // 服务端地址
- uploadImgServer: '',
- // 使用 base64 存储图片
- uploadImgShowBase64: false,
- // 上传图片的最大体积,默认 5M
- uploadImgMaxSize: 5 * 1024 * 1024,
- // 一次最多上传多少个图片
- uploadImgMaxLength: 100,
- // 自定义上传图片的名称
- uploadFileName: '',
- // 上传图片自定义参数
- uploadImgParams: {},
- // 自定义参数拼接到 url 中
- uploadImgParamsWithUrl: false,
- // 上传图片自定义 header
- uploadImgHeaders: {},
- // 钩子函数
- uploadImgHooks: {},
- // 上传图片超时时间 ms
- uploadImgTimeout: 10 * 1000,
- // 跨域带 cookie
- withCredentials: false,
- // 自定义上传
- customUploadImg: null
- };
- /***/ }),
- /* 276 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 默认常量配置
- * @author xiaokyo
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports["default"] = {
- focus: true,
- height: 300,
- placeholder: '请输入正文',
- zIndexFullScreen: 10002,
- showFullScreen: true
- };
- /***/ }),
- /* 277 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports["default"] = {
- lang: 'zh-CN',
- languages: {
- 'zh-CN': {
- wangEditor: {
- 重置: '重置',
- 插入: '插入',
- 默认: '默认',
- 创建: '创建',
- 修改: '修改',
- 如: '如',
- 请输入正文: '请输入正文',
- menus: {
- title: {
- 标题: '标题',
- 加粗: '加粗',
- 字号: '字号',
- 字体: '字体',
- 斜体: '斜体',
- 下划线: '下划线',
- 删除线: '删除线',
- 缩进: '缩进',
- 行高: '行高',
- 文字颜色: '文字颜色',
- 背景色: '背景色',
- 链接: '链接',
- 序列: '序列',
- 对齐: '对齐',
- 引用: '引用',
- 表情: '表情',
- 图片: '图片',
- 视频: '视频',
- 表格: '表格',
- 代码: '代码',
- 分割线: '分割线',
- 恢复: '恢复',
- 撤销: '撤销',
- 全屏: '全屏',
- 代办事项: '代办事项'
- },
- dropListMenu: {
- 设置标题: '设置标题',
- 背景颜色: '背景颜色',
- 文字颜色: '文字颜色',
- 设置字号: '设置字号',
- 设置字体: '设置字体',
- 设置缩进: '设置缩进',
- 对齐方式: '对齐方式',
- 设置行高: '设置行高',
- 序列: '序列',
- head: {
- 正文: '正文'
- },
- indent: {
- 增加缩进: '增加缩进',
- 减少缩进: '减少缩进'
- },
- justify: {
- 靠左: '靠左',
- 居中: '居中',
- 靠右: '靠右',
- 两端: '两端'
- },
- list: {
- 无序列表: '无序列表',
- 有序列表: '有序列表'
- }
- },
- panelMenus: {
- emoticon: {
- 默认: '默认',
- 新浪: '新浪',
- emoji: 'emoji',
- 手势: '手势'
- },
- image: {
- 图片链接: '图片链接',
- 上传图片: '上传图片',
- 网络图片: '网络图片'
- },
- link: {
- 链接: '链接',
- 链接文字: '链接文字',
- 取消链接: '取消链接',
- 查看链接: '查看链接'
- },
- video: {
- 插入视频: '插入视频'
- },
- table: {
- 行: '行',
- 列: '列',
- 的: '的',
- 表格: '表格',
- 添加行: '添加行',
- 删除行: '删除行',
- 添加列: '添加列',
- 删除列: '删除列',
- 设置表头: '设置表头',
- 取消表头: '取消表头',
- 插入表格: '插入表格',
- 删除表格: '删除表格'
- },
- code: {
- 删除代码: '删除代码',
- 修改代码: '修改代码',
- 插入代码: '插入代码'
- }
- }
- },
- validate: {
- 张图片: '张图片',
- 大于: '大于',
- 图片链接: '图片链接',
- 不是图片: '不是图片',
- 返回结果: '返回结果',
- 上传图片超时: '上传图片超时',
- 上传图片错误: '上传图片错误',
- 上传图片失败: '上传图片失败',
- 插入图片错误: '插入图片错误',
- 一次最多上传: '一次最多上传',
- 下载链接失败: '下载链接失败',
- 图片验证未通过: '图片验证未通过',
- 服务器返回状态: '服务器返回状态',
- 上传图片返回结果错误: '上传图片返回结果错误',
- 请替换为支持的图片类型: '请替换为支持的图片类型',
- 您插入的网络图片无法识别: '您插入的网络图片无法识别',
- 您刚才插入的图片链接未通过编辑器校验: '您刚才插入的图片链接未通过编辑器校验'
- }
- }
- },
- en: {
- wangEditor: {
- 重置: 'reset',
- 插入: 'insert',
- 默认: 'default',
- 创建: 'create',
- 修改: 'edit',
- 如: 'like',
- 请输入正文: 'please enter the text',
- menus: {
- title: {
- 标题: 'head',
- 加粗: 'bold',
- 字号: 'font size',
- 字体: 'font family',
- 斜体: 'italic',
- 下划线: 'underline',
- 删除线: 'strikethrough',
- 缩进: 'indent',
- 行高: 'line heihgt',
- 文字颜色: 'font color',
- 背景色: 'background',
- 链接: 'link',
- 序列: 'numbered list',
- 对齐: 'align',
- 引用: 'quote',
- 表情: 'emoticons',
- 图片: 'image',
- 视频: 'media',
- 表格: 'table',
- 代码: 'code',
- 分割线: 'split line',
- 恢复: 'undo',
- 撤销: 'redo',
- 全屏: 'fullscreen',
- 代办事项: 'todo'
- },
- dropListMenu: {
- 设置标题: 'title',
- 背景颜色: 'background',
- 文字颜色: 'font color',
- 设置字号: 'font size',
- 设置字体: 'font family',
- 设置缩进: 'indent',
- 对齐方式: 'align',
- 设置行高: 'line heihgt',
- 序列: 'list',
- head: {
- 正文: 'text'
- },
- indent: {
- 增加缩进: 'indent',
- 减少缩进: 'outdent'
- },
- justify: {
- 靠左: 'left',
- 居中: 'center',
- 靠右: 'right',
- 两端: 'justify'
- },
- list: {
- 无序列表: 'unordered',
- 有序列表: 'ordered'
- }
- },
- panelMenus: {
- emoticon: {
- 默认: 'default',
- 新浪: 'sina',
- emoji: 'emoji',
- 手势: 'gesture'
- },
- image: {
- 图片链接: 'image link',
- 上传图片: 'upload image',
- 网络图片: 'network image'
- },
- link: {
- 链接: 'link',
- 链接文字: 'link text',
- 取消链接: 'unlink',
- 查看链接: 'view links'
- },
- video: {
- 插入视频: 'insert video'
- },
- table: {
- 行: 'rows',
- 列: 'columns',
- 的: ' ',
- 表格: 'table',
- 添加行: 'insert row',
- 删除行: 'delete row',
- 添加列: 'insert column',
- 删除列: 'delete column',
- 设置表头: 'set header',
- 取消表头: 'cancel header',
- 插入表格: 'insert table',
- 删除表格: 'delete table'
- },
- code: {
- 删除代码: 'delete code',
- 修改代码: 'edit code',
- 插入代码: 'insert code'
- }
- }
- },
- validate: {
- 张图片: 'images',
- 大于: 'greater than',
- 图片链接: 'image link',
- 不是图片: 'is not image',
- 返回结果: 'return results',
- 上传图片超时: 'upload image timeout',
- 上传图片错误: 'upload image error',
- 上传图片失败: 'upload image failed',
- 插入图片错误: 'insert image error',
- 一次最多上传: 'once most at upload',
- 下载链接失败: 'download link failed',
- 图片验证未通过: 'image validate failed',
- 服务器返回状态: 'server return status',
- 上传图片返回结果错误: 'upload image return results error',
- 请替换为支持的图片类型: 'please replace with a supported image type',
- 您插入的网络图片无法识别: 'the network picture you inserted is not recognized',
- 您刚才插入的图片链接未通过编辑器校验: 'the image link you just inserted did not pass the editor verification'
- }
- }
- }
- }
- };
- /***/ }),
- /* 278 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 历史记录 - 数据缓存的模式
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- /**
- * 是否为兼容模式。返回 true 表示当前使用兼容(内容备份)模式,否则使用标准(差异备份)模式
- */
- function compatibleMode() {
- if (util_1.UA.isIE() || util_1.UA.isOldEdge) {
- return true;
- }
- return false;
- }
- exports["default"] = {
- compatibleMode: compatibleMode,
- historyMaxSize: 30
- };
- /***/ }),
- /* 279 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 视频相关的配置
- * @author hutianhao
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var const_1 = __webpack_require__(26);
- exports["default"] = {
- // 插入网络视频前的回调函数
- onlineVideoCheck: function onlineVideoCheck(video) {
- return true;
- },
- // 插入网络视频成功之后的回调函数
- onlineVideoCallback: const_1.EMPTY_FN
- };
- /***/ }),
- /* 280 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * @description selection range API
- * @author wangfupeng
- */
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(7);
- var index_1 = __importDefault(__webpack_require__(281));
- var SelectionAndRange =
- /** @class */
- function () {
- function SelectionAndRange(editor) {
- this._currentRange = null;
- this.editor = editor;
- }
- /**
- * 获取当前 range
- */
- SelectionAndRange.prototype.getRange = function () {
- return this._currentRange;
- };
- /**
- * 保存选区范围
- * @param _range 选区范围
- */
- SelectionAndRange.prototype.saveRange = function (_range) {
- if (_range) {
- // 保存已有选区
- this._currentRange = _range;
- return;
- } // 获取当前的选区
- var selection = window.getSelection();
- if (selection.rangeCount === 0) {
- return;
- }
- var range = selection.getRangeAt(0); // 获取选区范围的 DOM 元素
- var $containerElem = this.getSelectionContainerElem(range);
- if (!$containerElem) {
- // 当 选区范围内没有 DOM元素 则抛出
- return;
- }
- if ($containerElem.attr('contenteditable') === 'false' || $containerElem.parentUntil('[contenteditable=false]')) {
- // 这里大体意义上就是个保险
- // 确保 编辑区域 的 contenteditable属性 的值为 true
- return;
- }
- var editor = this.editor;
- var $textElem = editor.$textElem;
- if ($textElem.isContain($containerElem)) {
- if ($textElem.elems[0] === $containerElem.elems[0]) {
- var _context;
- if ((0, _trim["default"])(_context = $textElem.html()).call(_context) === '<p><br></p>') {
- var $children = $textElem.children();
- var $last = $children === null || $children === void 0 ? void 0 : $children.last();
- editor.selection.createRangeByElem($last, true, true);
- editor.selection.restoreSelection();
- }
- } // 是编辑内容之内的
- this._currentRange = range;
- }
- };
- /**
- * 折叠选区范围
- * @param toStart true 开始位置,false 结束位置
- */
- SelectionAndRange.prototype.collapseRange = function (toStart) {
- if (toStart === void 0) {
- toStart = false;
- }
- var range = this._currentRange;
- if (range) {
- range.collapse(toStart);
- }
- };
- /**
- * 获取选区范围内的文字
- */
- SelectionAndRange.prototype.getSelectionText = function () {
- var range = this._currentRange;
- if (range) {
- return range.toString();
- } else {
- return '';
- }
- };
- /**
- * 获取选区范围的 DOM 元素
- * @param range 选区范围
- */
- SelectionAndRange.prototype.getSelectionContainerElem = function (range) {
- var r;
- r = range || this._currentRange;
- var elem;
- if (r) {
- elem = r.commonAncestorContainer;
- return dom_core_1["default"](elem.nodeType === 1 ? elem : elem.parentNode);
- }
- };
- /**
- * 选区范围开始的 DOM 元素
- * @param range 选区范围
- */
- SelectionAndRange.prototype.getSelectionStartElem = function (range) {
- var r;
- r = range || this._currentRange;
- var elem;
- if (r) {
- elem = r.startContainer;
- return dom_core_1["default"](elem.nodeType === 1 ? elem : elem.parentNode);
- }
- };
- /**
- * 选区范围结束的 DOM 元素
- * @param range 选区范围
- */
- SelectionAndRange.prototype.getSelectionEndElem = function (range) {
- var r;
- r = range || this._currentRange;
- var elem;
- if (r) {
- elem = r.endContainer;
- return dom_core_1["default"](elem.nodeType === 1 ? elem : elem.parentNode);
- }
- };
- /**
- * 选区是否为空(没有选择文字)
- */
- SelectionAndRange.prototype.isSelectionEmpty = function () {
- var range = this._currentRange;
- if (range && range.startContainer) {
- if (range.startContainer === range.endContainer) {
- if (range.startOffset === range.endOffset) {
- return true;
- }
- }
- }
- return false;
- };
- /**
- * 恢复选区范围
- */
- SelectionAndRange.prototype.restoreSelection = function () {
- var selection = window.getSelection();
- var r = this._currentRange;
- if (selection && r) {
- selection.removeAllRanges();
- selection.addRange(r);
- }
- };
- /**
- * 创建一个空白(即 ​ 字符)选区
- */
- SelectionAndRange.prototype.createEmptyRange = function () {
- var editor = this.editor;
- var range = this.getRange();
- var $elem;
- if (!range) {
- // 当前无 range
- return;
- }
- if (!this.isSelectionEmpty()) {
- // 当前选区必须没有内容才可以,有内容就直接 return
- return;
- }
- try {
- // 目前只支持 webkit 内核
- if (util_1.UA.isWebkit()) {
- // 插入 ​
- editor.cmd["do"]('insertHTML', '​'); // 修改 offset 位置
- range.setEnd(range.endContainer, range.endOffset + 1); // 存储
- this.saveRange(range);
- } else {
- $elem = dom_core_1["default"]('<strong>​</strong>');
- editor.cmd["do"]('insertElem', $elem);
- this.createRangeByElem($elem, true);
- }
- } catch (ex) {// 部分情况下会报错,兼容一下
- }
- };
- /**
- * 根据 DOM 元素设置选区
- * @param $elem DOM 元素
- * @param toStart true 开始位置,false 结束位置
- * @param isContent 是否选中 $elem 的内容
- */
- SelectionAndRange.prototype.createRangeByElem = function ($elem, toStart, isContent) {
- if (!$elem.length) {
- return;
- }
- var elem = $elem.elems[0];
- var range = document.createRange();
- if (isContent) {
- range.selectNodeContents(elem);
- } else {
- // 如果用户没有传入 isContent 参数,那就默认为 false
- range.selectNode(elem);
- }
- if (toStart != null) {
- // 传入了 toStart 参数,折叠选区。如果没传入 toStart 参数,则忽略这一步
- range.collapse(toStart);
- } // 存储 range
- this.saveRange(range);
- };
- /**
- * 获取 当前 选取范围的 顶级(段落) 元素
- * @param $editor
- */
- SelectionAndRange.prototype.getSelectionRangeTopNodes = function (editor) {
- var item = new index_1["default"](editor);
- item.init();
- return item.getSelectionNodes();
- };
- /**
- * 移动光标位置,默认情况下在尾部
- * 有一个特殊情况是firefox下的文本节点会自动补充一个br元素,会导致自动换行
- * 所以默认情况下在firefox下的文本节点会自动移动到br前面
- * @param {Node} node 元素节点
- * @param {number} position 光标的位置
- */
- SelectionAndRange.prototype.moveCursor = function (node, position) {
- var _a;
- var range = this.getRange(); //对文本节点特殊处理
- var len = node.nodeType === 3 ? (_a = node.nodeValue) === null || _a === void 0 ? void 0 : _a.length : node.childNodes.length;
- if ((util_1.UA.isFirefox || util_1.UA.isIE()) && len !== 0) {
- // firefox下在节点为文本节点和节点最后一个元素为文本节点的情况下
- if (node.nodeType === 3 || node.childNodes[len - 1].nodeName === 'BR') {
- len = len - 1;
- }
- }
- var pos = position !== null && position !== void 0 ? position : len;
- if (!range) {
- return;
- }
- if (node) {
- range.setStart(node, pos);
- range.setEnd(node, pos);
- this.restoreSelection();
- }
- };
- /**
- * 获取光标在当前选区的位置
- */
- SelectionAndRange.prototype.getCursorPos = function () {
- var selection = window.getSelection();
- return selection === null || selection === void 0 ? void 0 : selection.anchorOffset;
- };
- return SelectionAndRange;
- }();
- exports["default"] = SelectionAndRange;
- /***/ }),
- /* 281 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 选取范围所有顶级(段落)节点
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2)); // 构造函数
- var SelectionRangeTopNodes =
- /** @class */
- function () {
- /**
- * 构造函数
- * @param editor
- */
- function SelectionRangeTopNodes(editor) {
- // 初始化属性
- this.editor = editor;
- this.$nodeList = [];
- this.$startElem = dom_core_1["default"](editor.selection.getSelectionStartElem()).getNodeTop(this.editor);
- this.$endElem = dom_core_1["default"](editor.selection.getSelectionEndElem()).getNodeTop(this.editor);
- }
- /**
- * 初始化
- */
- SelectionRangeTopNodes.prototype.init = function () {
- this.recordSelectionNodes(dom_core_1["default"](this.$startElem));
- };
- /**
- * 添加 节点 到nodeList
- * @param $node 节点
- */
- SelectionRangeTopNodes.prototype.addNodeList = function ($node) {
- this.$nodeList.push(dom_core_1["default"]($node));
- };
- /**
- * 是否是 选区结束 节点
- * @param $node 节点
- */
- SelectionRangeTopNodes.prototype.isEndElem = function ($node) {
- var _a;
- return (_a = this.$endElem) === null || _a === void 0 ? void 0 : _a.equal($node);
- };
- /**
- * 获取当前节点的下一个兄弟节点
- * @param $node 节点
- */
- SelectionRangeTopNodes.prototype.getNextSibling = function ($node) {
- return dom_core_1["default"]($node.elems[0].nextSibling);
- };
- /**
- * 记录节点 - 从选区开始节点开始 一直到匹配到选区结束节点为止
- * @param $node 节点
- */
- SelectionRangeTopNodes.prototype.recordSelectionNodes = function ($node) {
- var $elem = $node.getNodeTop(this.editor);
- if ($elem.length > 0) {
- this.addNodeList($elem);
- if (!this.isEndElem($elem)) {
- this.recordSelectionNodes(this.getNextSibling($elem));
- }
- }
- };
- /**
- * 获取 选中节点列表
- */
- SelectionRangeTopNodes.prototype.getSelectionNodes = function () {
- return this.$nodeList;
- };
- return SelectionRangeTopNodes;
- }();
- /**
- * 导出
- */
- exports["default"] = SelectionRangeTopNodes;
- /***/ }),
- /* 282 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 封装 document.execCommand
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Command =
- /** @class */
- function () {
- function Command(editor) {
- this.editor = editor;
- }
- /**
- * 执行富文本操作的命令
- * @param name name
- * @param value value
- */
- Command.prototype["do"] = function (name, value) {
- var editor = this.editor;
- if (editor.config.styleWithCSS) {
- document.execCommand('styleWithCSS', false, 'true');
- }
- var selection = editor.selection; // 如果无选区,忽略
- if (!selection.getRange()) {
- return;
- } // 恢复选取
- selection.restoreSelection(); // 执行
- switch (name) {
- case 'insertHTML':
- this.insertHTML(value);
- break;
- case 'insertElem':
- this.insertElem(value);
- break;
- default:
- // 默认 command
- this.execCommand(name, value);
- break;
- } // 修改菜单状态
- editor.menus.changeActive(); // 最后,恢复选取保证光标在原来的位置闪烁
- selection.saveRange();
- selection.restoreSelection();
- };
- /**
- * 插入 html
- * @param html html 字符串
- */
- Command.prototype.insertHTML = function (html) {
- var editor = this.editor;
- var range = editor.selection.getRange();
- if (range == null) return;
- if (this.queryCommandSupported('insertHTML')) {
- // W3C
- this.execCommand('insertHTML', html);
- } else if (range.insertNode) {
- // IE
- range.deleteContents();
- range.insertNode(dom_core_1["default"](html).elems[0]);
- editor.selection.collapseRange();
- } // else if (range.pasteHTML) {
- // // IE <= 10
- // range.pasteHTML(html)
- // }
- };
- /**
- * 插入 DOM 元素
- * @param $elem DOM 元素
- */
- Command.prototype.insertElem = function ($elem) {
- var editor = this.editor;
- var range = editor.selection.getRange();
- if (range == null) return;
- if (range.insertNode) {
- range.deleteContents();
- range.insertNode($elem.elems[0]);
- }
- };
- /**
- * 执行 document.execCommand
- * @param name name
- * @param value value
- */
- Command.prototype.execCommand = function (name, value) {
- document.execCommand(name, false, value);
- };
- /**
- * 执行 document.queryCommandValue
- * @param name name
- */
- Command.prototype.queryCommandValue = function (name) {
- return document.queryCommandValue(name);
- };
- /**
- * 执行 document.queryCommandState
- * @param name name
- */
- Command.prototype.queryCommandState = function (name) {
- return document.queryCommandState(name);
- };
- /**
- * 执行 document.queryCommandSupported
- * @param name name
- */
- Command.prototype.queryCommandSupported = function (name) {
- return document.queryCommandSupported(name);
- };
- return Command;
- }();
- exports["default"] = Command;
- /***/ }),
- /* 283 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 编辑区域,入口文件
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _indexOf = _interopRequireDefault(__webpack_require__(54));
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var index_1 = __importDefault(__webpack_require__(288));
- var util_1 = __webpack_require__(7);
- var getChildrenJSON_1 = __importDefault(__webpack_require__(300));
- var getHtmlByNodeList_1 = __importDefault(__webpack_require__(301));
- var Text =
- /** @class */
- function () {
- function Text(editor) {
- this.editor = editor;
- this.eventHooks = {
- changeEvents: [],
- dropEvents: [],
- clickEvents: [],
- keyupEvents: [],
- tabUpEvents: [],
- tabDownEvents: [],
- enterUpEvents: [],
- enterDownEvents: [],
- deleteUpEvents: [],
- deleteDownEvents: [],
- pasteEvents: [],
- linkClickEvents: [],
- codeClickEvents: [],
- textScrollEvents: [],
- toolbarClickEvents: [],
- imgClickEvents: [],
- imgDragBarMouseDownEvents: [],
- tableClickEvents: [],
- menuClickEvents: [],
- dropListMenuHoverEvents: [],
- splitLineEvents: []
- };
- }
- /**
- * 初始化
- */
- Text.prototype.init = function () {
- // 实时保存选取范围
- this._saveRange(); // 绑定事件
- this._bindEventHooks(); // 初始化 text 事件钩子函数
- index_1["default"](this);
- };
- /**
- * 切换placeholder
- */
- Text.prototype.togglePlaceholder = function () {
- var _context;
- var html = this.html();
- var $placeholder = (0, _find["default"])(_context = this.editor.$textContainerElem).call(_context, '.placeholder');
- $placeholder.hide();
- if (!html || html === ' ') $placeholder.show();
- };
- /**
- * 清空内容
- */
- Text.prototype.clear = function () {
- this.html('<p><br></p>');
- };
- /**
- * 设置/获取 html
- * @param val html 字符串
- */
- Text.prototype.html = function (val) {
- var editor = this.editor;
- var $textElem = editor.$textElem; // 没有 val ,则是获取 html
- if (val == null) {
- var html = $textElem.html(); // 未选中任何内容的时候点击“加粗”或者“斜体”等按钮,就得需要一个空的占位符 ​ ,这里替换掉
- html = html.replace(/\u200b/gm, '');
- html = html.replace(/<p><\/p>/gim, ''); // 去掉空行
- html = html.replace(/<p><br\/?><\/p>$/gim, ''); // 去掉最后的 <p><br><p>
- /**
- * 这里的代码为了处理火狐多余的空行标签,但是强制删除空行标签会带来其他问题
- * html()方法返回的的值,"<p><br></p>"中pr会被删除,只留下<p>,点不进去,从而产生垃圾数据
- * 目前在末位有多个空行的情况下执行撤销重做操作,会产生一种不记录末尾空行的错觉
- * 暂时注释, 等待进一步的兼容处理
- */
- // html = html.replace(/><br>(?!<)/gi, '>') // 过滤 <p><br>内容</p> 中的br
- // html = html.replace(/(?!>)<br></gi, '<') // 过滤 <p>内容<br></p> 中的br
- /**
- * pre标签格式化
- * html()方法理论上应当输出纯净的代码文本,但是对于是否解析html标签还没有良好的判断
- * 如果去除hljs的标签,在解析状态下回显,会造成显示错误并且无法再通过hljs方法渲染
- * 暂且其弃用
- */
- // html = formatCodeHtml(editor, html)
- return html;
- } // 有 val ,则是设置 html
- val = (0, _trim["default"])(val).call(val);
- if (val === '') {
- val = "<p><br></p>";
- }
- if ((0, _indexOf["default"])(val).call(val, '<') !== 0) {
- // 内容用 p 标签包裹
- val = "<p>" + val + "</p>";
- }
- $textElem.html(val); // 初始化选区,将光标定位到内容尾部
- editor.initSelection();
- };
- /**
- * 将json设置成html至编辑器
- * @param nodeList json格式
- */
- Text.prototype.setJSON = function (nodeList) {
- var html = getHtmlByNodeList_1["default"](nodeList).children();
- var editor = this.editor;
- var $textElem = editor.$textElem; // 没有获取到元素的情况
- if (!html) return; // 替换文本节点下全部子节点
- $textElem.replaceChildAll(html);
- };
- /**
- * 获取 json 格式的数据
- */
- Text.prototype.getJSON = function () {
- var editor = this.editor;
- var $textElem = editor.$textElem;
- return getChildrenJSON_1["default"]($textElem);
- };
- Text.prototype.text = function (val) {
- var editor = this.editor;
- var $textElem = editor.$textElem; // 没有 val ,是获取 text
- if (val == null) {
- var text = $textElem.text(); // 未选中任何内容的时候点击“加粗”或者“斜体”等按钮,就得需要一个空的占位符 ​ ,这里替换掉
- text = text.replace(/\u200b/gm, '');
- return text;
- } // 有 val ,则是设置 text
- $textElem.text("<p>" + val + "</p>"); // 初始化选区,将光标定位到内容尾部
- editor.initSelection();
- };
- /**
- * 追加 html 内容
- * @param html html 字符串
- */
- Text.prototype.append = function (html) {
- var editor = this.editor;
- var $textElem = editor.$textElem;
- if ((0, _indexOf["default"])(html).call(html, '<') !== 0) {
- // 普通字符串,用 <p> 包裹
- html = "<p>" + html + "</p>";
- }
- $textElem.append(dom_core_1["default"](html)); // 初始化选区,将光标定位到内容尾部
- editor.initSelection();
- };
- /**
- * 每一步操作,都实时保存选区范围
- */
- Text.prototype._saveRange = function () {
- var editor = this.editor;
- var $textElem = editor.$textElem; // 保存当前的选区
- function saveRange() {
- // 随时保存选区
- editor.selection.saveRange(); // 更新按钮 active 状态
- editor.menus.changeActive();
- } // 按键后保存
- $textElem.on('keyup', saveRange); // 点击后保存,为了避免被多次执行而导致造成浪费,这里对 click 使用一次性绑定
- function onceClickSaveRange() {
- saveRange();
- $textElem.off('click', onceClickSaveRange);
- }
- $textElem.on('click', onceClickSaveRange);
- $textElem.on('mousedown', function () {
- // mousedown 状态下,鼠标滑动到编辑区域外面,也需要保存选区
- $textElem.on('mouseleave', saveRange);
- });
- $textElem.on('mouseup', function () {
- var selection = editor.selection;
- var range = selection.getRange();
- if (range == null) return;
- var startOffset = range.startOffset,
- endOffset = range.endOffset;
- var endContainer = range === null || range === void 0 ? void 0 : range.endContainer; // 修复当selection结束时,点击编辑器内部,保存选区异常的情况
- if (startOffset !== endOffset && endContainer != null) {
- range === null || range === void 0 ? void 0 : range.setStart(endContainer, endOffset);
- }
- saveRange(); // 在编辑器区域之内完成点击,取消鼠标滑动到编辑区外面的事件
- $textElem.off('mouseleave', saveRange);
- });
- };
- /**
- * 绑定事件,事件会触发钩子函数
- */
- Text.prototype._bindEventHooks = function () {
- var editor = this.editor;
- var $textElem = editor.$textElem;
- var eventHooks = this.eventHooks; // click hooks
- $textElem.on('click', function (e) {
- var clickEvents = eventHooks.clickEvents;
- (0, _forEach["default"])(clickEvents).call(clickEvents, function (fn) {
- return fn(e);
- });
- }); // enter 键 up 时的 hooks
- $textElem.on('keyup', function (e) {
- if (e.keyCode !== 13) return;
- var enterUpEvents = eventHooks.enterUpEvents;
- (0, _forEach["default"])(enterUpEvents).call(enterUpEvents, function (fn) {
- return fn(e);
- });
- }); // 键盘 up 时的 hooks
- $textElem.on('keyup', function (e) {
- var keyupEvents = eventHooks.keyupEvents;
- (0, _forEach["default"])(keyupEvents).call(keyupEvents, function (fn) {
- return fn(e);
- });
- }); // delete 键 up 时 hooks
- $textElem.on('keyup', function (e) {
- if (e.keyCode !== 8) return;
- var deleteUpEvents = eventHooks.deleteUpEvents;
- (0, _forEach["default"])(deleteUpEvents).call(deleteUpEvents, function (fn) {
- return fn(e);
- });
- }); // delete 键 down 时 hooks
- $textElem.on('keydown', function (e) {
- if (e.keyCode !== 8) return;
- var deleteDownEvents = eventHooks.deleteDownEvents;
- (0, _forEach["default"])(deleteDownEvents).call(deleteDownEvents, function (fn) {
- return fn(e);
- });
- }); // 粘贴
- $textElem.on('paste', function (e) {
- if (util_1.UA.isIE()) return; // IE 不支持
- // 阻止默认行为,使用 execCommand 的粘贴命令
- e.preventDefault();
- var pasteEvents = eventHooks.pasteEvents;
- (0, _forEach["default"])(pasteEvents).call(pasteEvents, function (fn) {
- return fn(e);
- });
- }); // 撤销/恢复 快捷键
- $textElem.on('keydown', function (e) {
- if ( // 编辑器处于聚焦状态下(多编辑器实例) || 当前处于兼容模式(兼容模式撤销/恢复后不聚焦,所以直接过,但会造成多编辑器同时撤销/恢复)
- (editor.isFocus || editor.isCompatibleMode) && (e.ctrlKey || e.metaKey) && e.keyCode === 90) {
- // 取消默认行为
- e.preventDefault(); // 执行事件
- if (e.shiftKey) {
- // 恢复
- editor.history.restore();
- } else {
- // 撤销
- editor.history.revoke();
- }
- }
- }); // tab up
- $textElem.on('keyup', function (e) {
- if (e.keyCode !== 9) return;
- e.preventDefault();
- var tabUpEvents = eventHooks.tabUpEvents;
- (0, _forEach["default"])(tabUpEvents).call(tabUpEvents, function (fn) {
- return fn(e);
- });
- }); // tab down
- $textElem.on('keydown', function (e) {
- if (e.keyCode !== 9) return;
- e.preventDefault();
- var tabDownEvents = eventHooks.tabDownEvents;
- (0, _forEach["default"])(tabDownEvents).call(tabDownEvents, function (fn) {
- return fn(e);
- });
- }); // 文本编辑区域 滚动时触发
- $textElem.on('scroll', // 使用节流
- util_1.throttle(function (e) {
- var textScrollEvents = eventHooks.textScrollEvents;
- (0, _forEach["default"])(textScrollEvents).call(textScrollEvents, function (fn) {
- return fn(e);
- });
- }, 100)); // 拖拽相关的事件
- function preventDefault(e) {
- // 禁用 document 拖拽事件
- e.preventDefault();
- }
- dom_core_1["default"](document).on('dragleave', preventDefault).on('drop', preventDefault).on('dragenter', preventDefault).on('dragover', preventDefault); // 全局事件在编辑器实例销毁的时候进行解绑
- editor.beforeDestroy(function () {
- dom_core_1["default"](document).off('dragleave', preventDefault).off('drop', preventDefault).off('dragenter', preventDefault).off('dragover', preventDefault);
- });
- $textElem.on('drop', function (e) {
- e.preventDefault();
- var events = eventHooks.dropEvents;
- (0, _forEach["default"])(events).call(events, function (fn) {
- return fn(e);
- });
- }); // link click
- $textElem.on('click', function (e) {
- // 存储链接元素
- var $link = null;
- var target = e.target;
- var $target = dom_core_1["default"](target);
- if ($target.getNodeName() === 'A') {
- // 当前点击的就是一个链接
- $link = $target;
- } else {
- // 否则,向父节点中寻找链接
- var $parent = $target.parentUntil('a');
- if ($parent != null) {
- // 找到了
- $link = $parent;
- }
- }
- if (!$link) return; // 没有点击链接,则返回
- var linkClickEvents = eventHooks.linkClickEvents;
- (0, _forEach["default"])(linkClickEvents).call(linkClickEvents, function (fn) {
- return fn($link);
- });
- }); // img click
- $textElem.on('click', function (e) {
- // 存储图片元素
- var $img = null;
- var target = e.target;
- var $target = dom_core_1["default"](target); //处理图片点击 判断是否是表情 根据 不存在class或者className!==eleImg、没有alt属性
- if ($target.getNodeName() === 'IMG' && (!$target.elems[0].getAttribute('class') || $target.elems[0].getAttribute('class') !== 'eleImg') && !$target.elems[0].getAttribute('alt')) {
- // 当前点击的就是img
- e.stopPropagation();
- $img = $target;
- }
- if (!$img) return; // 没有点击图片,则返回
- var imgClickEvents = eventHooks.imgClickEvents;
- (0, _forEach["default"])(imgClickEvents).call(imgClickEvents, function (fn) {
- return fn($img);
- });
- }); // code click
- $textElem.on('click', function (e) {
- // 存储代码元素
- var $code = null;
- var target = e.target;
- var $target = dom_core_1["default"](target);
- if ($target.getNodeName() === 'PRE') {
- // 当前点击的就是一个链接
- $code = $target;
- } else {
- // 否则,向父节点中寻找链接
- var $parent = $target.parentUntil('pre');
- if ($parent !== null) {
- // 找到了
- $code = $parent;
- }
- }
- if (!$code) return;
- var codeClickEvents = eventHooks.codeClickEvents;
- (0, _forEach["default"])(codeClickEvents).call(codeClickEvents, function (fn) {
- return fn($code);
- });
- }); // splitLine click
- $textElem.on('click', function (e) {
- // 存储分割线元素
- var $splitLine = null;
- var target = e.target;
- var $target = dom_core_1["default"](target); // 判断当前点击元素
- if ($target.getNodeName() === 'HR') {
- $splitLine = $target;
- } else {
- $target == null;
- }
- if (!$splitLine) return; // 没有点击分割线,则返回
- // 设置、恢复选区
- editor.selection.createRangeByElem($splitLine);
- editor.selection.restoreSelection();
- var splitLineClickEvents = eventHooks.splitLineEvents;
- (0, _forEach["default"])(splitLineClickEvents).call(splitLineClickEvents, function (fn) {
- return fn($splitLine);
- });
- }); // 菜单栏被点击
- editor.$toolbarElem.on('click', function (e) {
- var toolbarClickEvents = eventHooks.toolbarClickEvents;
- (0, _forEach["default"])(toolbarClickEvents).call(toolbarClickEvents, function (fn) {
- return fn(e);
- });
- }); //mousedown事件
- editor.$textContainerElem.on('mousedown', function (e) {
- var target = e.target;
- var $target = dom_core_1["default"](target);
- if ($target.hasClass('w-e-img-drag-rb')) {
- // 点击的元素,是图片拖拽调整大小的 bar
- var imgDragBarMouseDownEvents = eventHooks.imgDragBarMouseDownEvents;
- (0, _forEach["default"])(imgDragBarMouseDownEvents).call(imgDragBarMouseDownEvents, function (fn) {
- return fn();
- });
- }
- }); //table click
- $textElem.on('click', function (e) {
- // 存储元素
- var $dom = null;
- var target = e.target; //获取最祖父元素
- $dom = dom_core_1["default"](target).parentUntilEditor('TABLE', editor, target); // 没有table范围内,则返回
- if (!$dom) return;
- var tableClickEvents = eventHooks.tableClickEvents;
- (0, _forEach["default"])(tableClickEvents).call(tableClickEvents, function (fn) {
- return fn($dom);
- });
- }); // enter 键 down
- $textElem.on('keydown', function (e) {
- if (e.keyCode !== 13) return;
- var enterDownEvents = eventHooks.enterDownEvents;
- (0, _forEach["default"])(enterDownEvents).call(enterDownEvents, function (fn) {
- return fn(e);
- });
- });
- };
- return Text;
- }();
- exports["default"] = Text;
- /***/ }),
- /* 284 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(285);
- module.exports = parent;
- /***/ }),
- /* 285 */
- /***/ (function(module, exports, __webpack_require__) {
- var find = __webpack_require__(286);
- var ArrayPrototype = Array.prototype;
- module.exports = function (it) {
- var own = it.find;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.find) ? find : own;
- };
- /***/ }),
- /* 286 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(287);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').find;
- /***/ }),
- /* 287 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var $find = __webpack_require__(33).find;
- var addToUnscopables = __webpack_require__(85);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var FIND = 'find';
- var SKIPS_HOLES = true;
- var USES_TO_LENGTH = arrayMethodUsesToLength(FIND);
- // Shouldn't skip holes
- if (FIND in []) Array(1)[FIND](function () { SKIPS_HOLES = false; });
- // `Array.prototype.find` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.find
- $({ target: 'Array', proto: true, forced: SKIPS_HOLES || !USES_TO_LENGTH }, {
- find: function find(callbackfn /* , that = undefined */) {
- return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
- }
- });
- // https://tc39.github.io/ecma262/#sec-array.prototype-@@unscopables
- addToUnscopables(FIND);
- /***/ }),
- /* 288 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description Text 事件钩子函数。Text 公共的,不是某个菜单独有的
- * @wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var enter_to_create_p_1 = __importDefault(__webpack_require__(289));
- var del_to_keep_p_1 = __importDefault(__webpack_require__(290));
- var tab_to_space_1 = __importDefault(__webpack_require__(291));
- var paste_text_html_1 = __importDefault(__webpack_require__(292));
- var img_click_active_1 = __importDefault(__webpack_require__(299));
- /**
- * 初始化 text 事件钩子函数
- * @param text text 实例
- */
- function initTextHooks(text) {
- var editor = text.editor;
- var eventHooks = text.eventHooks; // 回车时,保证生成的是 <p> 标签
- enter_to_create_p_1["default"](editor, eventHooks.enterUpEvents, eventHooks.enterDownEvents); // 删除时,保留 <p><br></p>
- del_to_keep_p_1["default"](editor, eventHooks.deleteUpEvents, eventHooks.deleteDownEvents); // tab 转换为空格
- tab_to_space_1["default"](editor, eventHooks.tabDownEvents); // 粘贴 text html
- paste_text_html_1["default"](editor, eventHooks.pasteEvents); // img click active
- img_click_active_1["default"](editor, eventHooks.imgClickEvents);
- }
- exports["default"] = initTextHooks;
- /***/ }),
- /* 289 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 回车时,保证生成的是 <p> 标签
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * 回车时,保证生成的是 <p> 标签
- * @param editor 编辑器实例
- * @param enterUpEvents enter 键 up 时的 hooks
- * @param enterDownEvents enter 键 down 时的 hooks
- */
- function enterToCreateP(editor, enterUpEvents, enterDownEvents) {
- function insertEmptyP($selectionElem) {
- var $p = dom_core_1["default"]('<p><br></p>');
- $p.insertBefore($selectionElem);
- editor.selection.createRangeByElem($p, true, true);
- editor.selection.restoreSelection();
- $selectionElem.remove();
- } // enter up 时
- function fn() {
- var $textElem = editor.$textElem;
- var $selectionElem = editor.selection.getSelectionContainerElem();
- var $parentElem = $selectionElem.parent();
- if ($parentElem.html() === '<code><br></code>') {
- // 回车之前光标所在一个 <p><code>.....</code></p> ,忽然回车生成一个空的 <p><code><br></code></p>
- // 而且继续回车跳不出去,因此只能特殊处理
- insertEmptyP($selectionElem);
- return;
- }
- if (!$parentElem.equal($textElem)) {
- // 不是顶级标签
- return;
- }
- var nodeName = $selectionElem.getNodeName();
- if (nodeName === 'P') {
- // 当前的标签是 P ,不用做处理
- return;
- }
- if ($selectionElem.text()) {
- // 有内容,不做处理
- return;
- } // 插入 <p> ,并将选取定位到 <p>,删除当前标签
- insertEmptyP($selectionElem);
- }
- enterUpEvents.push(fn); // enter down 时
- function createPWhenEnterText(e) {
- var _a; // selection中的range缓存还有问题,更新不及时,此处手动更新range,处理enter的bug
- editor.selection.saveRange((_a = getSelection()) === null || _a === void 0 ? void 0 : _a.getRangeAt(0));
- var $selectElem = editor.selection.getSelectionContainerElem();
- if ($selectElem.id === editor.textElemId) {
- // 回车时,默认创建了 text 标签(没有 p 标签包裹),父元素直接就是 $textElem
- // 例如,光标放在 table 最后侧,回车时,默认就是这个情况
- e.preventDefault();
- editor.cmd["do"]('insertHTML', '<p><br></p>');
- }
- }
- enterDownEvents.push(createPWhenEnterText);
- }
- exports["default"] = enterToCreateP;
- /***/ }),
- /* 290 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 删除时保留 <p><br></p>
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * 删除时保留 <p><br></p>
- * @param editor 编辑器实例
- * @param deleteUpEvents delete 键 up 时的 hooks
- * @param deleteDownEvents delete 建 down 时的 hooks
- */
- function deleteToKeepP(editor, deleteUpEvents, deleteDownEvents) {
- function upFn() {
- var _context;
- var $textElem = editor.$textElem;
- var txtHtml = (0, _trim["default"])(_context = $textElem.html().toLowerCase()).call(_context); // firefox 时用 txtHtml === '<br>' 判断,其他用 !txtHtml 判断
- if (!txtHtml || txtHtml === '<br>') {
- // 内容空了
- var $p = dom_core_1["default"]('<p><br/></p>');
- $textElem.html(' '); // 一定要先清空,否则在 firefox 下有问题
- $textElem.append($p);
- editor.selection.createRangeByElem($p, false, true);
- editor.selection.restoreSelection(); // 设置折叠后的光标位置,在firebox等浏览器下
- // 光标设置在end位置会自动换行
- editor.selection.moveCursor($p.getNode(), 0);
- }
- }
- deleteUpEvents.push(upFn);
- function downFn(e) {
- var _context2;
- var $textElem = editor.$textElem;
- var txtHtml = (0, _trim["default"])(_context2 = $textElem.html().toLowerCase()).call(_context2);
- if (txtHtml === '<p><br></p>') {
- // 最后剩下一个空行,就不再删除了
- e.preventDefault();
- return;
- }
- }
- deleteDownEvents.push(downFn);
- }
- exports["default"] = deleteToKeepP;
- /***/ }),
- /* 291 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 编辑区域 tab 的特殊处理
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * 编辑区域 tab 的特殊处理,转换为空格
- * @param editor 编辑器实例
- * @param tabDownEvents tab down 事件钩子
- */
- function tabHandler(editor, tabDownEvents) {
- // 定义函数
- function fn() {
- if (!editor.cmd.queryCommandSupported('insertHTML')) {
- // 必须原生支持 insertHTML 命令
- return;
- }
- var $selectionElem = editor.selection.getSelectionContainerElem();
- if (!$selectionElem) {
- return;
- }
- var $parentElem = $selectionElem.parent();
- var selectionNodeName = $selectionElem.getNodeName();
- var parentNodeName = $parentElem.getNodeName();
- if (selectionNodeName == 'CODE' || parentNodeName === 'CODE' || parentNodeName === 'PRE' || /hljs/.test(parentNodeName)) {
- // <pre><code> 里面
- editor.cmd["do"]('insertHTML', editor.config.languageTab);
- } else {
- // 普通文字
- editor.cmd["do"]('insertHTML', ' ');
- }
- } // 保留函数
- tabDownEvents.push(fn);
- }
- exports["default"] = tabHandler;
- /***/ }),
- /* 292 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 粘贴 text html
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var paste_event_1 = __webpack_require__(123);
- var util_1 = __webpack_require__(7);
- var const_1 = __webpack_require__(26);
- /**
- * 格式化html
- * @param val 粘贴的html
- * @author liuwei
- */
- function formatHtml(val) {
- var pasteText = val; // div 全部替换为 p 标签
- pasteText = pasteText.replace(/<div>/gim, '<p>').replace(/<\/div>/gim, '</p>'); // 不允许空行,放在最后
- pasteText = pasteText.replace(/<p><\/p>/gim, '<p><br></p>'); // 去除''
- return (0, _trim["default"])(pasteText).call(pasteText);
- }
- /**
- * 格式化html
- * @param val 粘贴的html
- * @author liuwei
- */
- function formatCode(val) {
- var pasteText = val.replace(/<br>|<br\/>/gm, '\n').replace(/<[^>]+>/gm, '');
- return pasteText;
- }
- /**
- * 粘贴文本和 html
- * @param editor 编辑器对象
- * @param pasteEvents 粘贴事件列表
- */
- function pasteTextHtml(editor, pasteEvents) {
- function fn(e) {
- // 获取配置
- var config = editor.config;
- var pasteFilterStyle = config.pasteFilterStyle;
- var pasteIgnoreImg = config.pasteIgnoreImg;
- var pasteTextHandle = config.pasteTextHandle; // 获取粘贴的文字
- var pasteHtml = paste_event_1.getPasteHtml(e, pasteFilterStyle, pasteIgnoreImg);
- var pasteText = paste_event_1.getPasteText(e);
- pasteText = pasteText.replace(/\n/gm, '<br>'); // 当前选区所在的 DOM 节点
- var $selectionElem = editor.selection.getSelectionContainerElem();
- if (!$selectionElem) {
- return;
- }
- var nodeName = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getNodeName();
- var $topElem = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getNodeTop(editor); // 当前节点顶级可能没有
- var topNodeName = '';
- if ($topElem.elems[0]) {
- topNodeName = $topElem === null || $topElem === void 0 ? void 0 : $topElem.getNodeName();
- } // code 中只能粘贴纯文本
- if (nodeName === 'CODE' || topNodeName === 'PRE') {
- if (pasteTextHandle && util_1.isFunction(pasteTextHandle)) {
- // 用户自定义过滤处理粘贴内容
- pasteText = '' + (pasteTextHandle(pasteText) || '');
- }
- editor.cmd["do"]('insertHTML', formatCode(pasteText));
- return;
- } // 如果复制进来的是url链接则插入时将它转为链接
- if (const_1.urlRegex.test(pasteText)) {
- return editor.cmd["do"]('insertHTML', "<a href=\"" + pasteText + "\" target=\"_blank\">" + pasteText + "</a>");
- } // table 中(td、th),待开发。。。
- if (!pasteHtml) {
- return;
- }
- try {
- // firefox 中,获取的 pasteHtml 可能是没有 <ul> 包裹的 <li>
- // 因此执行 insertHTML 会报错
- if (pasteTextHandle && util_1.isFunction(pasteTextHandle)) {
- // 用户自定义过滤处理粘贴内容
- pasteHtml = '' + (pasteTextHandle(pasteHtml) || ''); // html
- }
- editor.cmd["do"]('insertHTML', "" + formatHtml(pasteHtml));
- } catch (ex) {
- // 此时使用 pasteText 来兼容一下
- if (pasteTextHandle && util_1.isFunction(pasteTextHandle)) {
- // 用户自定义过滤处理粘贴内容
- pasteText = '' + (pasteTextHandle(pasteText) || '');
- }
- editor.cmd["do"]('insertHTML', "" + formatHtml(pasteText)); // text
- }
- }
- pasteEvents.push(fn);
- }
- exports["default"] = pasteTextHtml;
- /***/ }),
- /* 293 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 将粘贴的 html 字符串,转换为正确、简洁的 html 代码。剔除不必要的标签和属性。
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _includes = _interopRequireDefault(__webpack_require__(89));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var tags_1 = __webpack_require__(294);
- var simplehtmlparser_js_1 = __importDefault(__webpack_require__(298));
- /**
- * 过滤掉空 span
- * @param html html
- */
- function filterEmptySpan(html) {
- var regForReplace = /<span>.*?<\/span>/gi;
- var regForMatch = /<span>(.*?)<\/span>/;
- return html.replace(regForReplace, function (s) {
- // s 是单个 span ,如 <span>文字</span>
- var result = s.match(regForMatch);
- if (result == null) return '';
- return result[1];
- });
- }
- /**
- * 是否忽略标签
- * @param tag tag
- * @param ignoreImg 是否忽略 img 标签
- */
- function isIgnoreTag(tag, ignoreImg) {
- var _context;
- tag = (0, _trim["default"])(_context = tag.toLowerCase()).call(_context); // 忽略的标签
- if (tags_1.IGNORE_TAGS.has(tag)) {
- return true;
- } // 是否忽略图片
- if (ignoreImg) {
- if (tag === 'img') {
- return true;
- }
- }
- return false;
- }
- /**
- * 为 tag 生成 html 字符串,开始部分
- * @param tag tag
- * @param attrs 属性
- */
- function genStartHtml(tag, attrs) {
- var result = ''; // tag < 符号
- result = "<" + tag; // 拼接属性
- var attrStrArr = [];
- (0, _forEach["default"])(attrs).call(attrs, function (attr) {
- attrStrArr.push(attr.name + "=\"" + attr.value + "\"");
- });
- if (attrStrArr.length > 0) {
- result = result + ' ' + attrStrArr.join(' ');
- } // tag > 符号
- var isEmpty = tags_1.EMPTY_TAGS.has(tag); // 没有子节点或文本的标签,如 img
- result = result + (isEmpty ? '/' : '') + '>';
- return result;
- }
- /**
- * 为 tag 生成 html 字符串,结尾部分
- * @param tag tag
- */
- function genEndHtml(tag) {
- return "</" + tag + ">";
- }
- /**
- * 处理粘贴的 html
- * @param html html 字符串
- * @param filterStyle 是否过滤 style 样式
- * @param ignoreImg 是否忽略 img 标签
- */
- function parseHtml(html, filterStyle, ignoreImg) {
- if (filterStyle === void 0) {
- filterStyle = true;
- }
- if (ignoreImg === void 0) {
- ignoreImg = false;
- }
- var resultArr = []; // 存储结果,数组形式,最后再 join
- // 当前正在处理的标签,以及记录和清除的方法
- var CUR_TAG = '';
- function markTagStart(tag) {
- tag = (0, _trim["default"])(tag).call(tag);
- if (!tag) return;
- if (tags_1.EMPTY_TAGS.has(tag)) return; // 内容为空的标签,如 img ,不用记录
- CUR_TAG = tag;
- }
- function markTagEnd() {
- CUR_TAG = '';
- } // 能通过 'text/html' 格式获取 html
- var htmlParser = new simplehtmlparser_js_1["default"]();
- htmlParser.parse(html, {
- startElement: function startElement(tag, attrs) {
- // 首先,标记开始
- markTagStart(tag); // 忽略的标签
- if (isIgnoreTag(tag, ignoreImg)) {
- return;
- } // 找出该标签必须的属性(其他的属性忽略)
- var necessaryAttrKeys = tags_1.NECESSARY_ATTRS.get(tag) || [];
- var attrsForTag = [];
- (0, _forEach["default"])(attrs).call(attrs, function (attr) {
- // 属性名
- var name = attr.name; // style 单独处理
- if (name === 'style') {
- // 保留 style 样式
- if (!filterStyle) {
- attrsForTag.push(attr);
- }
- return;
- } // 除了 style 之外的其他属性
- if ((0, _includes["default"])(necessaryAttrKeys).call(necessaryAttrKeys, name) === false) {
- // 不是必须的属性,忽略
- return;
- }
- attrsForTag.push(attr);
- }); // 拼接为 HTML 标签
- var html = genStartHtml(tag, attrsForTag);
- resultArr.push(html);
- },
- characters: function characters(str) {
- if (!str) {
- return;
- } // 忽略的标签
- // 如果复制拿到的内容是 `<body><html>这种形式无法成功粘贴</html></body>`
- if (isIgnoreTag(CUR_TAG, ignoreImg) && /^</.test(str)) {
- return;
- }
- resultArr.push(str);
- },
- endElement: function endElement(tag) {
- // 忽略的标签
- if (isIgnoreTag(tag, ignoreImg)) {
- return;
- } // 拼接为 HTML 标签
- var html = genEndHtml(tag);
- resultArr.push(html); // 最后,标记结束
- markTagEnd();
- },
- comment: function comment(str) {
- /* 注释,不做处理 */
- }
- });
- var result = resultArr.join(''); // 转换为字符串
- // 过滤掉空 span 标签
- result = filterEmptySpan(result);
- return result;
- }
- exports["default"] = parseHtml;
- /***/ }),
- /* 294 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 粘贴相关的 tags
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _map = _interopRequireDefault(__webpack_require__(114));
- var _set = _interopRequireDefault(__webpack_require__(124));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.TOP_LEVEL_TAGS = exports.EMPTY_TAGS = exports.NECESSARY_ATTRS = exports.IGNORE_TAGS = void 0; // 忽略的标签
- exports.IGNORE_TAGS = new _set["default"](['doctype', '!doctype', 'html', 'head', 'meta', 'body', 'script', 'style', 'link', 'frame', 'iframe', 'title', 'svg', 'center']); // 指定标签必要的属性
- exports.NECESSARY_ATTRS = new _map["default"]([['img', ['src', 'alt']], ['a', ['href', 'target']], ['td', ['colspan', 'rowspan']], ['th', ['colspan', 'rowspan']]]); // 没有子节点或文本的标签
- exports.EMPTY_TAGS = new _set["default"](['area', 'base', 'basefont', 'br', 'col', 'hr', 'img', 'input', 'isindex', 'embed']); // 编辑区域顶级节点
- exports.TOP_LEVEL_TAGS = new _set["default"](['h1', 'h2', 'h3', 'h4', 'h5', 'p', 'ul', 'ol', 'table', 'blockquote', 'pre', 'hr', 'form']);
- /***/ }),
- /* 295 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(296);
- module.exports = parent;
- /***/ }),
- /* 296 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(297);
- __webpack_require__(62);
- __webpack_require__(64);
- __webpack_require__(51);
- var path = __webpack_require__(10);
- module.exports = path.Set;
- /***/ }),
- /* 297 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var collection = __webpack_require__(115);
- var collectionStrong = __webpack_require__(117);
- // `Set` constructor
- // https://tc39.github.io/ecma262/#sec-set-objects
- module.exports = collection('Set', function (init) {
- return function Set() { return init(this, arguments.length ? arguments[0] : undefined); };
- }, collectionStrong);
- /***/ }),
- /* 298 */
- /***/ (function(module, exports) {
- // Copyright 2004 Erik Arvidsson. All Rights Reserved.
- //
- // This code is triple licensed using Apache Software License 2.0,
- // Mozilla Public License or GNU Public License
- //
- ///////////////////////////////////////////////////////////////////////////////
- //
- // Licensed under the Apache License, Version 2.0 (the "License"); you may not
- // use this file except in compliance with the License. You may obtain a copy
- // of the License at http://www.apache.org/licenses/LICENSE-2.0
- //
- ///////////////////////////////////////////////////////////////////////////////
- //
- // The contents of this file are subject to the Mozilla Public License
- // Version 1.1 (the "License"); you may not use this file except in
- // compliance with the License. You may obtain a copy of the License at
- // http://www.mozilla.org/MPL/
- //
- // Software distributed under the License is distributed on an "AS IS"
- // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
- // License for the specific language governing rights and limitations
- // under the License.
- //
- // The Original Code is Simple HTML Parser.
- //
- // The Initial Developer of the Original Code is Erik Arvidsson.
- // Portions created by Erik Arvidssson are Copyright (C) 2004. All Rights
- // Reserved.
- //
- ///////////////////////////////////////////////////////////////////////////////
- //
- // This program is free software; you can redistribute it and/or
- // modify it under the terms of the GNU General Public License
- // as published by the Free Software Foundation; either version 2
- // of the License, or (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- // GNU General Public License for more details.
- //
- // You should have received a copy of the GNU General Public License
- // along with this program; if not, write to the Free Software
- // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- //
- ///////////////////////////////////////////////////////////////////////////////
- /*
- var handler ={
- startElement: function (sTagName, oAttrs) {},
- endElement: function (sTagName) {},
- characters: function (s) {},
- comment: function (s) {}
- };
- */
- function SimpleHtmlParser() {}
- SimpleHtmlParser.prototype = {
- handler: null,
- // regexps
- startTagRe: /^<([^>\s\/]+)((\s+[^=>\s]+(\s*=\s*((\"[^"]*\")|(\'[^']*\')|[^>\s]+))?)*)\s*\/?\s*>/m,
- endTagRe: /^<\/([^>\s]+)[^>]*>/m,
- attrRe: /([^=\s]+)(\s*=\s*((\"([^"]*)\")|(\'([^']*)\')|[^>\s]+))?/gm,
- parse: function (s, oHandler) {
- if (oHandler) this.contentHandler = oHandler
- var i = 0
- var res, lc, lm, rc, index
- var treatAsChars = false
- var oThis = this
- while (s.length > 0) {
- // Comment
- if (s.substring(0, 4) == '<!--') {
- index = s.indexOf('-->')
- if (index != -1) {
- this.contentHandler.comment(s.substring(4, index))
- s = s.substring(index + 3)
- treatAsChars = false
- } else {
- treatAsChars = true
- }
- }
- // end tag
- else if (s.substring(0, 2) == '</') {
- if (this.endTagRe.test(s)) {
- lc = RegExp.leftContext
- lm = RegExp.lastMatch
- rc = RegExp.rightContext
- lm.replace(this.endTagRe, function () {
- return oThis.parseEndTag.apply(oThis, arguments)
- })
- s = rc
- treatAsChars = false
- } else {
- treatAsChars = true
- }
- }
- // start tag
- else if (s.charAt(0) == '<') {
- if (this.startTagRe.test(s)) {
- lc = RegExp.leftContext
- lm = RegExp.lastMatch
- rc = RegExp.rightContext
- lm.replace(this.startTagRe, function () {
- return oThis.parseStartTag.apply(oThis, arguments)
- })
- s = rc
- treatAsChars = false
- } else {
- treatAsChars = true
- }
- }
- if (treatAsChars) {
- index = s.indexOf('<')
- if (index == -1) {
- this.contentHandler.characters(s)
- s = ''
- } else {
- this.contentHandler.characters(s.substring(0, index))
- s = s.substring(index)
- }
- }
- treatAsChars = true
- }
- },
- parseStartTag: function (sTag, sTagName, sRest) {
- var attrs = this.parseAttributes(sTagName, sRest)
- this.contentHandler.startElement(sTagName, attrs)
- },
- parseEndTag: function (sTag, sTagName) {
- this.contentHandler.endElement(sTagName)
- },
- parseAttributes: function (sTagName, s) {
- var oThis = this
- var attrs = []
- s.replace(this.attrRe, function (a0, a1, a2, a3, a4, a5, a6) {
- attrs.push(oThis.parseAttribute(sTagName, a0, a1, a2, a3, a4, a5, a6))
- })
- return attrs
- },
- parseAttribute: function (sTagName, sAttribute, sName) {
- var value = ''
- if (arguments[7]) value = arguments[8]
- else if (arguments[5]) value = arguments[6]
- else if (arguments[3]) value = arguments[4]
- var empty = !value && !arguments[3]
- return { name: sName, value: empty ? null : value }
- },
- }
- // export default SimpleHtmlParser
- module.exports = SimpleHtmlParser
- /***/ }),
- /* 299 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 图片点击后选区更新到img的位置
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * 图片点击后选区更新到img的位置
- * @param editor 编辑器实例
- * @param imgClickEvents delete 键 up 时的 hooks
- */
- function imgClickActive(editor, imgClickEvents) {
- function clickFn($img) {
- editor.selection.createRangeByElem($img);
- editor.selection.restoreSelection();
- }
- imgClickEvents.push(clickFn);
- }
- exports["default"] = imgClickActive;
- /***/ }),
- /* 300 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 获取子元素的 JSON 格式数据
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * 获取子元素的 JSON 格式数据
- * @param $elem DOM 节点
- */
- function getChildrenJSON($elem) {
- var result = []; // 存储结果
- var $children = $elem.childNodes() || []; // 注意 childNodes() 可以获取文本节点
- (0, _forEach["default"])($children).call($children, function (curElem) {
- var elemResult;
- var nodeType = curElem.nodeType; // 文本节点
- if (nodeType === 3) {
- elemResult = curElem.textContent || '';
- elemResult = util_1.replaceHtmlSymbol(elemResult);
- } // 普通 DOM 节点
- if (nodeType === 1) {
- elemResult = {};
- elemResult = elemResult; // tag
- elemResult.tag = curElem.nodeName.toLowerCase(); // attr
- var attrData = [];
- var attrList = curElem.attributes;
- var attrListLength = attrList.length || 0;
- for (var i = 0; i < attrListLength; i++) {
- var attr = attrList[i];
- attrData.push({
- name: attr.name,
- value: attr.value
- });
- }
- elemResult.attrs = attrData; // children(递归)
- elemResult.children = getChildrenJSON(dom_core_1["default"](curElem));
- }
- if (elemResult) {
- result.push(elemResult);
- }
- });
- return result;
- }
- exports["default"] = getChildrenJSON;
- /***/ }),
- /* 301 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 从nodeList json格式中遍历生成dom元素
- * @author zhengwenjian
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _typeof2 = _interopRequireDefault(__webpack_require__(94));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- function getHtmlByNodeList(nodeList, parent) {
- if (parent === void 0) {
- parent = document.createElement('div');
- } // 设置一个父节点存储所有子节点
- var root = parent; // 遍历节点JSON
- (0, _forEach["default"])(nodeList).call(nodeList, function (item) {
- var elem; // 当为文本节点时
- if (typeof item === 'string') {
- elem = document.createTextNode(item);
- } // 当为普通节点时
- if ((0, _typeof2["default"])(item) === 'object') {
- var _context;
- elem = document.createElement(item.tag);
- (0, _forEach["default"])(_context = item.attrs).call(_context, function (attr) {
- dom_core_1["default"](elem).attr(attr.name, attr.value);
- }); // 有子节点时递归将子节点加入当前节点
- if (item.children && item.children.length > 0) {
- getHtmlByNodeList(item.children, elem.getRootNode());
- }
- }
- elem && root.appendChild(elem);
- });
- return dom_core_1["default"](root);
- }
- exports["default"] = getHtmlByNodeList;
- /***/ }),
- /* 302 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description Menus 菜单栏 入口文件
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _bind = _interopRequireDefault(__webpack_require__(88));
- var _setTimeout2 = _interopRequireDefault(__webpack_require__(121));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _includes = _interopRequireDefault(__webpack_require__(89));
- var _filter = _interopRequireDefault(__webpack_require__(65));
- var _isArray = _interopRequireDefault(__webpack_require__(93));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var menu_list_1 = __importDefault(__webpack_require__(303));
- var dom_core_1 = __importDefault(__webpack_require__(2)); // import { MenuActive } from './menu-constructors/Menu'
- var Menus =
- /** @class */
- function () {
- function Menus(editor) {
- this.editor = editor;
- this.menuList = [];
- this.constructorList = menu_list_1["default"]; // 所有菜单构造函数的列表
- }
- /**
- * 自定义添加菜单
- * @param key 菜单 key ,和 editor.config.menus 对应
- * @param Menu 菜单构造函数
- */
- Menus.prototype.extend = function (key, Menu) {
- if (!Menu || typeof Menu !== 'function') return;
- this.constructorList[key] = Menu;
- }; // 初始化菜单
- Menus.prototype.init = function () {
- var _context, _context2;
- var _this = this; // 从用户配置的 menus 入手,看需要初始化哪些菜单
- var config = this.editor.config; // 排除exclude包含的菜单
- var excludeMenus = config.excludeMenus;
- if ((0, _isArray["default"])(excludeMenus) === false) excludeMenus = [];
- config.menus = (0, _filter["default"])(_context = config.menus).call(_context, function (key) {
- return (0, _includes["default"])(excludeMenus).call(excludeMenus, key) === false;
- });
- (0, _forEach["default"])(_context2 = config.menus).call(_context2, function (menuKey) {
- var MenuConstructor = _this.constructorList[menuKey]; // 暂用 any ,后面再替换
- if (MenuConstructor == null || typeof MenuConstructor !== 'function') {
- // 必须是 class
- return;
- } // 创建 menu 实例,并放到 menuList 中
- var m = new MenuConstructor(_this.editor);
- m.key = menuKey;
- _this.menuList.push(m);
- }); // 渲染 DOM
- this._addToToolbar(); // 添加菜单栏tooltips
- this._bindMenuTooltips();
- }; // 绑定菜单栏tooltips
- Menus.prototype._bindMenuTooltips = function () {
- var editor = this.editor;
- var $toolbarElem = editor.$toolbarElem;
- var $tooltipEl = dom_core_1["default"]("<div class=\"w-e-menu-tooltip w-e-menu-tooltip-up\">\n <div class=\"w-e-menu-tooltip-item-wrapper\">\n <div></div>\n </div>\n </div>");
- $tooltipEl.css('visibility', 'hidden');
- $toolbarElem.append($tooltipEl); // 设置 z-index
- $tooltipEl.css('z-index', editor.zIndex.get('tooltip'));
- var showTimeoutId = 0; // 定时器,延时200ms显示tooltips
- // 清空计时器
- function clearShowTimeoutId() {
- if (showTimeoutId) {
- clearTimeout(showTimeoutId);
- }
- } // 隐藏tooltip
- function hide() {
- clearShowTimeoutId();
- $tooltipEl.css('visibility', 'hidden');
- } // 事件监听
- $toolbarElem.on('mouseover', function (e) {
- var target = e.target;
- var $target = dom_core_1["default"](target);
- var title;
- var $menuEl;
- if ($target.isContain($toolbarElem)) {
- hide();
- return;
- }
- if ($target.parentUntil('.w-e-droplist') != null) {
- // 处于droplist中时隐藏
- hide();
- } else {
- if ($target.attr('data-title')) {
- title = $target.attr('data-title');
- $menuEl = $target;
- } else {
- var $parent = $target.parentUntil('.w-e-menu');
- if ($parent != null) {
- title = $parent.attr('data-title');
- $menuEl = $parent;
- }
- }
- }
- if (title && $menuEl) {
- clearShowTimeoutId();
- var targetOffset = $menuEl.getOffsetData();
- $tooltipEl.text(editor.i18next.t('menus.title.' + title));
- var tooltipOffset = $tooltipEl.getOffsetData();
- var left = targetOffset.left + targetOffset.width / 2 - tooltipOffset.width / 2;
- $tooltipEl.css('left', left + "px");
- $tooltipEl.css('top', targetOffset.height * -1 + "px");
- showTimeoutId = window.setTimeout(function () {
- $tooltipEl.css('visibility', 'visible');
- }, 200);
- } else {
- hide();
- }
- }).on('mouseleave', function () {
- hide();
- });
- }; // 添加到菜单栏
- Menus.prototype._addToToolbar = function () {
- var _context3;
- var editor = this.editor;
- var $toolbarElem = editor.$toolbarElem; // 遍历添加到 DOM
- (0, _forEach["default"])(_context3 = this.menuList).call(_context3, function (menu) {
- var $elem = menu.$elem;
- if ($elem) {
- $toolbarElem.append($elem);
- }
- });
- };
- /**
- * 获取菜单对象
- * @param 菜单名称 小写
- * @return Menus 菜单对象
- */
- Menus.prototype.menuFind = function (key) {
- var menuList = this.menuList;
- for (var i = 0, l = menuList.length; i < l; i++) {
- if (menuList[i].key === key) return menuList[i];
- }
- return menuList[0];
- };
- /**
- * @description 修改菜单激活状态
- */
- Menus.prototype.changeActive = function () {
- var _context4;
- (0, _forEach["default"])(_context4 = this.menuList).call(_context4, function (menu) {
- var _context5;
- (0, _setTimeout2["default"])((0, _bind["default"])(_context5 = menu.tryChangeActive).call(_context5, menu), 100); // 暂用 any ,后面再替换
- });
- };
- return Menus;
- }();
- exports["default"] = Menus;
- /***/ }),
- /* 303 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 所有菜单的构造函数
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var index_1 = __importDefault(__webpack_require__(304));
- var index_2 = __importDefault(__webpack_require__(308));
- var index_3 = __importDefault(__webpack_require__(313));
- var index_4 = __importDefault(__webpack_require__(317));
- var index_5 = __importDefault(__webpack_require__(318));
- var index_6 = __importDefault(__webpack_require__(319));
- var index_7 = __importDefault(__webpack_require__(320));
- var font_size_1 = __importDefault(__webpack_require__(322));
- var index_8 = __importDefault(__webpack_require__(324));
- var index_9 = __importDefault(__webpack_require__(325));
- var index_10 = __importDefault(__webpack_require__(328));
- var index_11 = __importDefault(__webpack_require__(329));
- var index_12 = __importDefault(__webpack_require__(330));
- var index_13 = __importDefault(__webpack_require__(332));
- var index_14 = __importDefault(__webpack_require__(352));
- var index_15 = __importDefault(__webpack_require__(356));
- var index_16 = __importDefault(__webpack_require__(358));
- var index_17 = __importDefault(__webpack_require__(359));
- var index_18 = __importDefault(__webpack_require__(361));
- var index_19 = __importDefault(__webpack_require__(362));
- var index_20 = __importDefault(__webpack_require__(363));
- var code_1 = __importDefault(__webpack_require__(372));
- var index_21 = __importDefault(__webpack_require__(376));
- var todo_1 = __importDefault(__webpack_require__(379));
- exports["default"] = {
- bold: index_1["default"],
- head: index_2["default"],
- italic: index_4["default"],
- link: index_3["default"],
- underline: index_5["default"],
- strikeThrough: index_6["default"],
- fontName: index_7["default"],
- fontSize: font_size_1["default"],
- justify: index_8["default"],
- quote: index_9["default"],
- backColor: index_10["default"],
- foreColor: index_11["default"],
- video: index_12["default"],
- image: index_13["default"],
- indent: index_14["default"],
- emoticon: index_15["default"],
- list: index_16["default"],
- lineHeight: index_17["default"],
- undo: index_18["default"],
- redo: index_19["default"],
- table: index_20["default"],
- code: code_1["default"],
- splitLine: index_21["default"],
- todo: todo_1["default"]
- };
- /***/ }),
- /* 304 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 加粗
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Bold =
- /** @class */
- function (_super) {
- __extends(Bold, _super);
- function Bold(editor) {
- var _this = this;
- 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>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 点击事件
- */
- Bold.prototype.clickHandler = function () {
- var editor = this.editor;
- var isSelectEmpty = editor.selection.isSelectionEmpty();
- if (isSelectEmpty) {
- // 选区范围是空的,插入并选中一个“空白”
- editor.selection.createEmptyRange();
- } // 执行 bold 命令
- editor.cmd["do"]('bold');
- if (isSelectEmpty) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- */
- Bold.prototype.tryChangeActive = function () {
- var editor = this.editor;
- if (editor.cmd.queryCommandState('bold')) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return Bold;
- }(BtnMenu_1["default"]);
- exports["default"] = Bold;
- /***/ }),
- /* 305 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(306);
- module.exports = parent;
- /***/ }),
- /* 306 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(307);
- var path = __webpack_require__(10);
- module.exports = path.Object.setPrototypeOf;
- /***/ }),
- /* 307 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var setPrototypeOf = __webpack_require__(76);
- // `Object.setPrototypeOf` method
- // https://tc39.github.io/ecma262/#sec-object.setprototypeof
- $({ target: 'Object', stat: true }, {
- setPrototypeOf: setPrototypeOf
- });
- /***/ }),
- /* 308 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 标题
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _stringify = _interopRequireDefault(__webpack_require__(309));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(7);
- var Head =
- /** @class */
- function (_super) {
- __extends(Head, _super);
- function Head(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="标题"><i class="w-e-icon-header"></i></div>');
- var dropListConf = {
- width: 100,
- title: '设置标题',
- type: 'list',
- list: [{
- $elem: dom_core_1["default"]('<h1>H1</h1>'),
- value: '<h1>'
- }, {
- $elem: dom_core_1["default"]('<h2>H2</h2>'),
- value: '<h2>'
- }, {
- $elem: dom_core_1["default"]('<h3>H3</h3>'),
- value: '<h3>'
- }, {
- $elem: dom_core_1["default"]('<h4>H4</h4>'),
- value: '<h4>'
- }, {
- $elem: dom_core_1["default"]('<h5>H5</h5>'),
- value: '<h5>'
- }, {
- $elem: dom_core_1["default"]("<p>" + editor.i18next.t('menus.dropListMenu.head.正文') + "</p>"),
- value: '<p>'
- }],
- clickHandler: function clickHandler(value) {
- // 注意 this 是指向当前的 Head 对象
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, dropListConf) || this;
- var onCatalogChange = editor.config.onCatalogChange; // 未配置目录change监听回调时不运行下面操作
- if (onCatalogChange) {
- _this.oldCatalogs = [];
- _this.addListenerCatalog(); // 监听文本框编辑时的大纲信息
- _this.getCatalogs(); // 初始有值的情况获取一遍大纲信息
- }
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- Head.prototype.command = function (value) {
- var editor = this.editor;
- var $selectionElem = editor.selection.getSelectionContainerElem();
- if ($selectionElem && editor.$textElem.equal($selectionElem)) {
- // 不能选中多行来设置标题,否则会出现问题
- // 例如选中的是 <p>xxx</p><p>yyy</p> 来设置标题,设置之后会成为 <h1>xxx<br>yyy</h1> 不符合预期
- return;
- }
- editor.cmd["do"]('formatBlock', value); // 标题设置成功且不是<p>正文标签就配置大纲id
- value !== '<p>' && this.addUidForSelectionElem();
- };
- /**
- * 为标题设置大纲
- */
- Head.prototype.addUidForSelectionElem = function () {
- var editor = this.editor;
- var tag = editor.selection.getSelectionContainerElem();
- var id = util_1.getRandomCode(); // 默认五位数id
- dom_core_1["default"](tag).attr('id', id);
- };
- /**
- * 监听change事件来返回大纲信息
- */
- Head.prototype.addListenerCatalog = function () {
- var _this = this;
- var editor = this.editor;
- editor.txt.eventHooks.changeEvents.push(function () {
- _this.getCatalogs();
- });
- };
- /**
- * 获取大纲数组
- */
- Head.prototype.getCatalogs = function () {
- var editor = this.editor;
- var $textElem = this.editor.$textElem;
- var onCatalogChange = editor.config.onCatalogChange;
- var elems = (0, _find["default"])($textElem).call($textElem, 'h1,h2,h3,h4,h5');
- var catalogs = [];
- (0, _forEach["default"])(elems).call(elems, function (elem, index) {
- var $elem = dom_core_1["default"](elem);
- var id = $elem.attr('id');
- var tag = $elem.getNodeName();
- var text = $elem.text();
- if (!id) {
- id = util_1.getRandomCode();
- $elem.attr('id', id);
- } // 标题为空的情况不生成目录
- if (!text) return;
- catalogs.push({
- tag: tag,
- id: id,
- text: text
- });
- }); // 旧目录和新目录对比是否相等,不相等则运行回调并保存新目录到旧目录变量,以方便下一次对比
- if ((0, _stringify["default"])(this.oldCatalogs) !== (0, _stringify["default"])(catalogs)) {
- this.oldCatalogs = catalogs;
- onCatalogChange && onCatalogChange(catalogs);
- }
- };
- /**
- * 尝试改变菜单激活(高亮)状态
- */
- Head.prototype.tryChangeActive = function () {
- var editor = this.editor;
- var reg = /^h/i;
- var cmdValue = editor.cmd.queryCommandValue('formatBlock');
- if (reg.test(cmdValue)) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return Head;
- }(DropListMenu_1["default"]);
- exports["default"] = Head;
- /***/ }),
- /* 309 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(310);
- /***/ }),
- /* 310 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(311);
- module.exports = parent;
- /***/ }),
- /* 311 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(312);
- var core = __webpack_require__(10);
- if (!core.JSON) core.JSON = { stringify: JSON.stringify };
- // eslint-disable-next-line no-unused-vars
- module.exports = function stringify(it, replacer, space) {
- return core.JSON.stringify.apply(null, arguments);
- };
- /***/ }),
- /* 312 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var getBuiltIn = __webpack_require__(28);
- var fails = __webpack_require__(12);
- var $stringify = getBuiltIn('JSON', 'stringify');
- var re = /[\uD800-\uDFFF]/g;
- var low = /^[\uD800-\uDBFF]$/;
- var hi = /^[\uDC00-\uDFFF]$/;
- var fix = function (match, offset, string) {
- var prev = string.charAt(offset - 1);
- var next = string.charAt(offset + 1);
- if ((low.test(match) && !hi.test(next)) || (hi.test(match) && !low.test(prev))) {
- return '\\u' + match.charCodeAt(0).toString(16);
- } return match;
- };
- var FORCED = fails(function () {
- return $stringify('\uDF06\uD834') !== '"\\udf06\\ud834"'
- || $stringify('\uDEAD') !== '"\\udead"';
- });
- if ($stringify) {
- // https://github.com/tc39/proposal-well-formed-stringify
- $({ target: 'JSON', stat: true, forced: FORCED }, {
- // eslint-disable-next-line no-unused-vars
- stringify: function stringify(it, replacer, space) {
- var result = $stringify.apply(null, arguments);
- return typeof result == 'string' ? result.replace(re, fix) : result;
- }
- });
- }
- /***/ }),
- /* 313 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 链接 菜单
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var PanelMenu_1 = __importDefault(__webpack_require__(34));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var create_panel_conf_1 = __importDefault(__webpack_require__(314));
- var is_active_1 = __importDefault(__webpack_require__(126));
- var Panel_1 = __importDefault(__webpack_require__(31));
- var index_1 = __importDefault(__webpack_require__(315));
- var Link =
- /** @class */
- function (_super) {
- __extends(Link, _super);
- function Link(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="链接"><i class="w-e-icon-link"></i></div>');
- _this = _super.call(this, $elem, editor) || this; // 绑定事件,如点击链接时,可以查看链接
- index_1["default"](editor);
- return _this;
- }
- /**
- * 菜单点击事件
- */
- Link.prototype.clickHandler = function () {
- var editor = this.editor;
- var $linkElem;
- if (this.isActive) {
- // 菜单被激活,说明选区在链接里
- $linkElem = editor.selection.getSelectionContainerElem();
- if (!$linkElem) {
- return;
- } // 弹出 panel
- this.createPanel($linkElem.text(), $linkElem.attr('href'));
- } else {
- // 菜单未被激活,说明选区不在链接里
- if (editor.selection.isSelectionEmpty()) {
- // 选区是空的,未选中内容
- this.createPanel('', '');
- } else {
- // 选中内容了
- this.createPanel(editor.selection.getSelectionText(), '');
- }
- }
- };
- /**
- * 创建 panel
- * @param text 文本
- * @param link 链接
- */
- Link.prototype.createPanel = function (text, link) {
- var conf = create_panel_conf_1["default"](this.editor, text, link);
- var panel = new Panel_1["default"](this, conf);
- panel.create();
- };
- /**
- * 尝试修改菜单 active 状态
- */
- Link.prototype.tryChangeActive = function () {
- var editor = this.editor;
- if (is_active_1["default"](editor)) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return Link;
- }(PanelMenu_1["default"]);
- exports["default"] = Link;
- /***/ }),
- /* 314 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description link 菜单 panel tab 配置
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var is_active_1 = __importDefault(__webpack_require__(126));
- function default_1(editor, text, link) {
- // panel 中需要用到的id
- var inputLinkId = util_1.getRandom('input-link');
- var inputTextId = util_1.getRandom('input-text');
- var btnOkId = util_1.getRandom('btn-ok');
- var btnDelId = util_1.getRandom('btn-del'); // 是否显示“取消链接”
- var delBtnDisplay = is_active_1["default"](editor) ? 'inline-block' : 'none';
- var $selectedLink;
- /**
- * 选中整个链接元素
- */
- function selectLinkElem() {
- if (!is_active_1["default"](editor)) return;
- var $linkElem = editor.selection.getSelectionContainerElem();
- if (!$linkElem) return;
- editor.selection.createRangeByElem($linkElem);
- editor.selection.restoreSelection();
- $selectedLink = $linkElem; // 赋值给函数内全局变量
- }
- /**
- * 插入链接
- * @param text 文字
- * @param link 链接
- */
- function insertLink(text, link) {
- if (is_active_1["default"](editor)) {
- // 选区处于链接中,则选中整个菜单,再执行 insertHTML
- selectLinkElem();
- editor.cmd["do"]('insertHTML', "<a href=\"" + link + "\" target=\"_blank\">" + text + "</a>");
- } else {
- // 选区未处于链接中,直接插入即可
- editor.cmd["do"]('insertHTML', "<a href=\"" + link + "\" target=\"_blank\">" + text + "</a>");
- }
- }
- /**
- * 取消链接
- */
- function delLink() {
- if (!is_active_1["default"](editor)) {
- return;
- } // 选中整个链接
- selectLinkElem(); // 用文本替换链接
- var selectionText = $selectedLink.text();
- editor.cmd["do"]('insertHTML', '<span>' + selectionText + '</span>');
- }
- /**
- * 校验链接是否合法
- * @param link 链接
- */
- function checkLink(text, link) {
- //查看开发者自定义配置的返回值
- var check = editor.config.linkCheck(text, link);
- if (check === undefined) {//用户未能通过开发者的校验,且开发者不希望编辑器提示用户
- } else if (check === true) {
- //用户通过了开发者的校验
- return true;
- } else {
- //用户未能通过开发者的校验,开发者希望我们提示这一字符串
- editor.config.customAlert(check, 'warning');
- }
- return false;
- }
- var conf = {
- width: 300,
- height: 0,
- // panel 中可包含多个 tab
- tabs: [{
- // tab 的标题
- title: editor.i18next.t('menus.panelMenus.link.链接'),
- // 模板
- 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>",
- // 事件绑定
- events: [// 插入链接
- {
- selector: '#' + btnOkId,
- type: 'click',
- fn: function fn() {
- var _context, _context2;
- // 执行插入链接
- var $link = dom_core_1["default"]('#' + inputLinkId);
- var $text = dom_core_1["default"]('#' + inputTextId);
- var link = (0, _trim["default"])(_context = $link.val()).call(_context);
- var text = (0, _trim["default"])(_context2 = $text.val()).call(_context2); // 链接为空,则不插入
- if (!link) return; // 文本为空,则用链接代替
- if (!text) text = link; // 校验链接是否满足用户的规则,若不满足则不插入
- if (!checkLink(text, link)) return;
- insertLink(text, link); // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
- return true;
- }
- }, // 取消链接
- {
- selector: '#' + btnDelId,
- type: 'click',
- fn: function fn() {
- // 执行取消链接
- delLink(); // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
- return true;
- }
- }]
- }]
- };
- return conf;
- }
- exports["default"] = default_1;
- /***/ }),
- /* 315 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 绑定链接元素的事件,入口
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var tooltip_event_1 = __importDefault(__webpack_require__(316));
- /**
- * 绑定事件
- * @param editor 编辑器实例
- */
- function bindEvent(editor) {
- // tooltip 事件
- tooltip_event_1["default"](editor);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 316 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description tooltip 事件
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Tooltip_1 = __importDefault(__webpack_require__(44));
- /**
- * 生成 Tooltip 的显示隐藏函数
- */
- function createShowHideFn(editor) {
- var tooltip;
- /**
- * 显示 tooltip
- * @param $link 链接元素
- */
- function showLinkTooltip($link) {
- var conf = [{
- $elem: dom_core_1["default"]("<span>" + editor.i18next.t('menus.panelMenus.link.查看链接') + "</span>"),
- onClick: function onClick(editor, $link) {
- var link = $link.attr('href');
- window.open(link, '_target'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + editor.i18next.t('menus.panelMenus.link.取消链接') + "</span>"),
- onClick: function onClick(editor, $link) {
- // 选中链接元素
- editor.selection.createRangeByElem($link);
- editor.selection.restoreSelection(); // 用文字,替换链接
- var selectionText = $link.text();
- editor.cmd["do"]('insertHTML', '<span>' + selectionText + '</span>'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }]; // 创建 tooltip
- tooltip = new Tooltip_1["default"](editor, $link, conf);
- tooltip.create();
- }
- /**
- * 隐藏 tooltip
- */
- function hideLinkTooltip() {
- // 移除 tooltip
- if (tooltip) {
- tooltip.remove();
- tooltip = null;
- }
- }
- return {
- showLinkTooltip: showLinkTooltip,
- hideLinkTooltip: hideLinkTooltip
- };
- }
- /**
- * 绑定 tooltip 事件
- * @param editor 编辑器实例
- */
- function bindTooltipEvent(editor) {
- var _a = createShowHideFn(editor),
- showLinkTooltip = _a.showLinkTooltip,
- hideLinkTooltip = _a.hideLinkTooltip; // 点击链接元素是,显示 tooltip
- editor.txt.eventHooks.linkClickEvents.push(showLinkTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
- editor.txt.eventHooks.clickEvents.push(hideLinkTooltip);
- editor.txt.eventHooks.keyupEvents.push(hideLinkTooltip);
- editor.txt.eventHooks.toolbarClickEvents.push(hideLinkTooltip);
- editor.txt.eventHooks.menuClickEvents.push(hideLinkTooltip);
- editor.txt.eventHooks.textScrollEvents.push(hideLinkTooltip);
- }
- exports["default"] = bindTooltipEvent;
- /***/ }),
- /* 317 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 斜体
- * @author liuwei
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Italic =
- /** @class */
- function (_super) {
- __extends(Italic, _super);
- function Italic(editor) {
- var _this = this;
- 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>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 点击事件
- */
- Italic.prototype.clickHandler = function () {
- var editor = this.editor;
- var isSelectEmpty = editor.selection.isSelectionEmpty();
- if (isSelectEmpty) {
- // 选区范围是空的,插入并选中一个“空白”
- editor.selection.createEmptyRange();
- } // 执行 italic 命令
- editor.cmd["do"]('italic');
- if (isSelectEmpty) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- */
- Italic.prototype.tryChangeActive = function () {
- var editor = this.editor;
- if (editor.cmd.queryCommandState('italic')) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return Italic;
- }(BtnMenu_1["default"]);
- exports["default"] = Italic;
- /***/ }),
- /* 318 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 下划线 underline
- * @author dyl
- *
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Underline =
- /** @class */
- function (_super) {
- __extends(Underline, _super);
- function Underline(editor) {
- var _this = this;
- 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>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 点击事件
- */
- Underline.prototype.clickHandler = function () {
- var editor = this.editor;
- var isSelectEmpty = editor.selection.isSelectionEmpty();
- if (isSelectEmpty) {
- // 选区范围是空的,插入并选中一个“空白”
- editor.selection.createEmptyRange();
- } // 执行 Underline 命令
- editor.cmd["do"]('underline');
- if (isSelectEmpty) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- */
- Underline.prototype.tryChangeActive = function () {
- var editor = this.editor;
- if (editor.cmd.queryCommandState('underline')) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return Underline;
- }(BtnMenu_1["default"]);
- exports["default"] = Underline;
- /***/ }),
- /* 319 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 删除线
- * @author lkw
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var StrikeThrough =
- /** @class */
- function (_super) {
- __extends(StrikeThrough, _super);
- function StrikeThrough(editor) {
- var _this = this;
- 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>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 点击事件
- */
- StrikeThrough.prototype.clickHandler = function () {
- var editor = this.editor;
- var isSelectEmpty = editor.selection.isSelectionEmpty();
- if (isSelectEmpty) {
- // 选区范围是空的,插入并选中一个“空白”
- editor.selection.createEmptyRange();
- } // 执行 strikeThrough 命令
- editor.cmd["do"]('strikeThrough');
- if (isSelectEmpty) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- */
- StrikeThrough.prototype.tryChangeActive = function () {
- var editor = this.editor;
- if (editor.cmd.queryCommandState('strikeThrough')) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return StrikeThrough;
- }(BtnMenu_1["default"]);
- exports["default"] = StrikeThrough;
- /***/ }),
- /* 320 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 字体样式 FontStyle
- * @author dyl
- *
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var FontStyleList_1 = __importDefault(__webpack_require__(321));
- var FontStyle =
- /** @class */
- function (_super) {
- __extends(FontStyle, _super);
- function FontStyle(editor) {
- var _this = this;
- 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>");
- var fontStyleList = new FontStyleList_1["default"](editor.config.fontNames);
- var fontListConf = {
- width: 100,
- title: '设置字体',
- type: 'list',
- list: fontStyleList.getItemList(),
- clickHandler: function clickHandler(value) {
- // this 是指向当前的 FontStyle 对象
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, fontListConf) || this;
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- FontStyle.prototype.command = function (value) {
- var _a;
- var editor = this.editor;
- var isEmptySelection = editor.selection.isSelectionEmpty();
- var $selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
- var isFont = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.nodeName.toLowerCase()) !== 'p';
- var isSameValue = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getAttribute('face')) === value;
- if (isEmptySelection) {
- if (isFont && !isSameValue) {
- var $elems = editor.selection.getSelectionRangeTopNodes(editor);
- editor.selection.createRangeByElem($elems[0]);
- editor.selection.moveCursor($elems[0].elems[0]);
- } // 插入空白选区
- editor.selection.createEmptyRange();
- }
- editor.cmd["do"]('fontName', value);
- if (isEmptySelection) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- * ?字体是否需要有激活状态这个操作?
- */
- FontStyle.prototype.tryChangeActive = function () {// const editor = this.editor
- // const cmdValue = editor.cmd.queryCommandValue('fontName')
- // if (menusConfig.fontNames.indexOf(cmdValue) >= 0) {
- // this.active()
- // } else {
- // this.unActive()
- // }
- };
- return FontStyle;
- }(DropListMenu_1["default"]);
- exports["default"] = FontStyle;
- /***/ }),
- /* 321 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * @description 字体 class
- * @author dyl
- */
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * 封装的一个字体菜单列表数据的组装对象,
- * 原因是因为在constructor函数中,直接执行此流程,会让代码量看起来较多,
- * 如果要在constructor调用外部函数,个人目前发现会有错误提示,
- * 因此,想着顺便研究实践下ts,遍创建了这样一个类
- */
- var FontStyleList =
- /** @class */
- function () {
- function FontStyleList(list) {
- var _this = this;
- this.itemList = [];
- (0, _forEach["default"])(list).call(list, function (fontValue) {
- _this.itemList.push({
- $elem: dom_core_1["default"]("<p style=\"font-family:'" + fontValue + "'\">" + fontValue + "</p>"),
- value: fontValue
- });
- });
- }
- FontStyleList.prototype.getItemList = function () {
- return this.itemList;
- };
- return FontStyleList;
- }();
- exports["default"] = FontStyleList;
- /***/ }),
- /* 322 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 字号 FontSize
- * @author lkw
- *
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var FontSizeList_1 = __importDefault(__webpack_require__(323));
- var FontSize =
- /** @class */
- function (_super) {
- __extends(FontSize, _super);
- function FontSize(editor) {
- var _this = this;
- 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>");
- var fontStyleList = new FontSizeList_1["default"](editor.config.fontSizes);
- var fontListConf = {
- width: 160,
- title: '设置字号',
- type: 'list',
- list: fontStyleList.getItemList(),
- clickHandler: function clickHandler(value) {
- // this 是指向当前的 FontSize 对象
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, fontListConf) || this;
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- FontSize.prototype.command = function (value) {
- var _a;
- var editor = this.editor;
- var isEmptySelection = editor.selection.isSelectionEmpty();
- var $selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
- var isFont = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.nodeName.toLowerCase()) !== 'p';
- var isSameSize = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getAttribute('size')) === value;
- if (isEmptySelection) {
- if (isFont && !isSameSize) {
- var $elems = editor.selection.getSelectionRangeTopNodes(editor);
- editor.selection.createRangeByElem($elems[0]);
- editor.selection.moveCursor($elems[0].elems[0]);
- } // 插入空白选区
- editor.selection.createEmptyRange();
- }
- editor.cmd["do"]('fontSize', value);
- if (isEmptySelection) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- * ?字号是否需要有激活状态这个操作?
- */
- FontSize.prototype.tryChangeActive = function () {};
- return FontSize;
- }(DropListMenu_1["default"]);
- exports["default"] = FontSize;
- /***/ }),
- /* 323 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * @description 字号 class
- * @author lkw
- */
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * FontSizeList 字号配置列表
- */
- var FontSizeList =
- /** @class */
- function () {
- function FontSizeList(list) {
- this.itemList = [];
- for (var key in list) {
- var item = list[key];
- this.itemList.push({
- $elem: dom_core_1["default"]("<p style=\"font-size:" + key + "\">" + item.name + "</p>"),
- value: item.value
- });
- }
- }
- FontSizeList.prototype.getItemList = function () {
- return this.itemList;
- };
- return FontSizeList;
- }();
- exports["default"] = FontSizeList;
- /***/ }),
- /* 324 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 对齐方式
- * @author liuwei
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Justify =
- /** @class */
- function (_super) {
- __extends(Justify, _super);
- function Justify(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="对齐"><i class="w-e-icon-paragraph-left"></i></div>');
- var dropListConf = {
- width: 100,
- title: '对齐方式',
- type: 'list',
- list: [{
- $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>"),
- value: 'justifyLeft'
- }, {
- $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>"),
- value: 'justifyCenter'
- }, {
- $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>"),
- value: 'justifyRight'
- }, {
- $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>"),
- value: 'justifyFull'
- }],
- clickHandler: function clickHandler(value) {
- // 执行对应的value操作
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, dropListConf) || this;
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- Justify.prototype.command = function (value) {
- var editor = this.editor;
- var selection = editor.selection;
- var $selectionElem = selection.getSelectionContainerElem(); // 保存选区
- selection.saveRange(); // 数据项
- var justifyClass = {
- justifyLeft: 'left',
- justifyCenter: 'center',
- justifyRight: 'right',
- justifyFull: 'justify'
- }; // 获取顶级元素
- var $elems = editor.selection.getSelectionRangeTopNodes(editor);
- if ($selectionElem) {
- // 获取在css中对应style的值
- var justifyValue_1 = justifyClass[value];
- (0, _forEach["default"])($elems).call($elems, function (el) {
- el.css('text-align', justifyValue_1);
- });
- } //恢复选区
- selection.restoreSelection();
- };
- /**
- * 尝试改变菜单激活(高亮)状态
- * 默认左对齐,若选择其他对其方式对active进行高亮否则unActive
- * ?考虑优化的话 是否可以对具体选中的进行高亮
- */
- Justify.prototype.tryChangeActive = function () {// const editor = this.editor
- // let isjustify = ['justifyCenter', 'justifyRight'].some(e => editor.cmd.queryCommandState(e))
- // if (isjustify) {
- // this.active()
- // } else {
- // this.unActive()
- // }
- };
- return Justify;
- }(DropListMenu_1["default"]);
- exports["default"] = Justify;
- /***/ }),
- /* 325 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 引用
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var bind_event_1 = __importDefault(__webpack_require__(326));
- var create_quote_node_1 = __importDefault(__webpack_require__(327));
- var Quote =
- /** @class */
- function (_super) {
- __extends(Quote, _super);
- function Quote(editor) {
- var _this = this;
- 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>");
- _this = _super.call(this, $elem, editor) || this;
- bind_event_1["default"](editor);
- return _this;
- }
- /**
- * 点击事件
- */
- Quote.prototype.clickHandler = function () {
- var _a;
- var editor = this.editor;
- var isSelectEmpty = editor.selection.isSelectionEmpty();
- var topNodeElem = editor.selection.getSelectionRangeTopNodes(editor);
- var $topNodeElem = topNodeElem[topNodeElem.length - 1];
- var nodeName = this.getTopNodeName(); // IE 中不支持 formatBlock <BLOCKQUOTE> ,要用其他方式兼容
- // 兼容firefox无法取消blockquote的问题
- if (nodeName === 'BLOCKQUOTE') {
- // 撤销 quote
- var $targetELem = dom_core_1["default"]($topNodeElem.childNodes());
- var len = $targetELem.length;
- var $middle_1 = $topNodeElem;
- (0, _forEach["default"])($targetELem).call($targetELem, function (elem) {
- var $elem = dom_core_1["default"](elem);
- $elem.insertAfter($middle_1);
- $middle_1 = $elem;
- });
- $topNodeElem.remove();
- editor.selection.moveCursor($targetELem.elems[len - 1]); // 即时更新btn状态
- this.tryChangeActive();
- } else {
- // 将 P 转换为 quote
- var $quote = create_quote_node_1["default"](topNodeElem);
- $quote.insertAfter($topNodeElem);
- this.delSelectNode(topNodeElem);
- var moveNode = (_a = $quote.childNodes()) === null || _a === void 0 ? void 0 : _a.last().getNode(); // 兼容firefox(firefox下空行情况下选区会在br后,造成自动换行的问题)
- moveNode.textContent ? editor.selection.moveCursor(moveNode) : editor.selection.moveCursor(moveNode, 0); // 即时更新btn状态
- this.tryChangeActive(); // 防止最后一行无法跳出
- dom_core_1["default"]("<p><br></p>").insertAfter($quote);
- return;
- }
- if (isSelectEmpty) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- */
- Quote.prototype.tryChangeActive = function () {
- var _a;
- var editor = this.editor;
- var cmdValue = (_a = editor.selection.getSelectionRangeTopNodes(editor)[0]) === null || _a === void 0 ? void 0 : _a.getNodeName();
- if (cmdValue === 'BLOCKQUOTE') {
- this.active();
- } else {
- this.unActive();
- }
- };
- /**
- * 获取包裹在最外层的节点(防止内部嵌入多个样式)
- * @param selectionElem 选中的节点
- * @returns {string} 最终要处理的节点名称
- */
- Quote.prototype.getTopNodeName = function () {
- var editor = this.editor;
- var $topNodeElem = editor.selection.getSelectionRangeTopNodes(editor)[0];
- var nodeName = $topNodeElem === null || $topNodeElem === void 0 ? void 0 : $topNodeElem.getNodeName();
- return nodeName;
- };
- /**
- * 删除选中的元素
- * @param selectElem 选中的元素节点数组
- */
- Quote.prototype.delSelectNode = function (selectElem) {
- (0, _forEach["default"])(selectElem).call(selectElem, function (node) {
- node.remove();
- });
- };
- return Quote;
- }(BtnMenu_1["default"]);
- exports["default"] = Quote;
- /***/ }),
- /* 326 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- function bindEvent(editor) {
- function quoteEnter(e) {
- var _a;
- var $selectElem = editor.selection.getSelectionContainerElem();
- var $topSelectElem = editor.selection.getSelectionRangeTopNodes(editor)[0]; // 对quote的enter进行特殊处理
- //最后一行为<p><br></p>时再按会出跳出blockquote
- if (($topSelectElem === null || $topSelectElem === void 0 ? void 0 : $topSelectElem.getNodeName()) === 'BLOCKQUOTE') {
- // firefox下点击引用按钮会选中外容器<blockquote></blockquote>
- if ($selectElem.getNodeName() === 'BLOCKQUOTE') {
- var selectNode = (_a = $selectElem.childNodes()) === null || _a === void 0 ? void 0 : _a.getNode();
- editor.selection.moveCursor(selectNode);
- }
- if ($selectElem.text() === '') {
- e.preventDefault();
- $selectElem.remove();
- var $newLine = dom_core_1["default"]('<p><br></p>');
- $newLine.insertAfter($topSelectElem); // 将光标移动br前面
- editor.selection.moveCursor($newLine.getNode(), 0);
- } // 当blockQuote中没有内容回车后移除blockquote
- if ($topSelectElem.text() === '') {
- $topSelectElem.remove();
- }
- }
- }
- editor.txt.eventHooks.enterDownEvents.push(quoteEnter);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 327 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * 创建一个blockquote元素节点
- * @param editor 编辑器实例
- */
- function createQuote($childElem) {
- var $targetElem = dom_core_1["default"]("<blockquote></blockquote>");
- (0, _forEach["default"])($childElem).call($childElem, function (node) {
- $targetElem.append(node.clone(true));
- });
- return $targetElem;
- }
- exports["default"] = createQuote;
- /***/ }),
- /* 328 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 背景颜色 BackColor
- * @author lkw
- *
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _map = _interopRequireDefault(__webpack_require__(29));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(7);
- var BackColor =
- /** @class */
- function (_super) {
- __extends(BackColor, _super);
- function BackColor(editor) {
- var _context;
- var _this = this;
- 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>");
- var colorListConf = {
- width: 120,
- title: '背景颜色',
- // droplist 内容以 block 形式展示
- type: 'inline-block',
- list: (0, _map["default"])(_context = editor.config.colors).call(_context, function (color) {
- return {
- $elem: dom_core_1["default"]("<i style=\"color:" + color + ";\" class=\"w-e-icon-paint-brush\"></i>"),
- value: color
- };
- }),
- clickHandler: function clickHandler(value) {
- // this 是指向当前的 BackColor 对象
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, colorListConf) || this;
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- BackColor.prototype.command = function (value) {
- var _a;
- var editor = this.editor;
- var isEmptySelection = editor.selection.isSelectionEmpty();
- var $selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
- var isSpan = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.nodeName.toLowerCase()) !== 'p';
- var bgColor = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.style.backgroundColor;
- var isSameColor = util_1.hexToRgb(value) === bgColor;
- if (isEmptySelection) {
- if (isSpan && !isSameColor) {
- var $elems = editor.selection.getSelectionRangeTopNodes(editor);
- editor.selection.createRangeByElem($elems[0]);
- editor.selection.moveCursor($elems[0].elems[0]);
- } // 插入空白选区
- editor.selection.createEmptyRange();
- }
- editor.cmd["do"]('backColor', value);
- if (isEmptySelection) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- */
- BackColor.prototype.tryChangeActive = function () {};
- return BackColor;
- }(DropListMenu_1["default"]);
- exports["default"] = BackColor;
- /***/ }),
- /* 329 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 文字颜色 FontColor
- * @author lkw
- *
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _map = _interopRequireDefault(__webpack_require__(29));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var FontColor =
- /** @class */
- function (_super) {
- __extends(FontColor, _super);
- function FontColor(editor) {
- var _context;
- var _this = this;
- 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>");
- var colorListConf = {
- width: 120,
- title: '文字颜色',
- // droplist 内容以 block 形式展示
- type: 'inline-block',
- list: (0, _map["default"])(_context = editor.config.colors).call(_context, function (color) {
- return {
- $elem: dom_core_1["default"]("<i style=\"color:" + color + ";\" class=\"w-e-icon-pencil2\"></i>"),
- value: color
- };
- }),
- clickHandler: function clickHandler(value) {
- // this 是指向当前的 BackColor 对象
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, colorListConf) || this;
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- FontColor.prototype.command = function (value) {
- var _a;
- var editor = this.editor;
- var isEmptySelection = editor.selection.isSelectionEmpty();
- var $selectionElem = (_a = editor.selection.getSelectionContainerElem()) === null || _a === void 0 ? void 0 : _a.elems[0];
- var isFont = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.nodeName.toLowerCase()) !== 'p';
- var isSameColor = ($selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getAttribute('color')) === value;
- if (isEmptySelection) {
- if (isFont && !isSameColor) {
- var $elems = editor.selection.getSelectionRangeTopNodes(editor);
- editor.selection.createRangeByElem($elems[0]);
- editor.selection.moveCursor($elems[0].elems[0]);
- } // 插入空白选区
- editor.selection.createEmptyRange();
- }
- editor.cmd["do"]('foreColor', value);
- if (isEmptySelection) {
- // 需要将选区范围折叠起来
- editor.selection.collapseRange();
- editor.selection.restoreSelection();
- }
- };
- /**
- * 尝试修改菜单激活状态
- */
- FontColor.prototype.tryChangeActive = function () {};
- return FontColor;
- }(DropListMenu_1["default"]);
- exports["default"] = FontColor;
- /***/ }),
- /* 330 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 视频 菜单
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Panel_1 = __importDefault(__webpack_require__(31));
- var PanelMenu_1 = __importDefault(__webpack_require__(34));
- var create_panel_conf_1 = __importDefault(__webpack_require__(331));
- var Video =
- /** @class */
- function (_super) {
- __extends(Video, _super);
- function Video(editor) {
- var _this = this;
- 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>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 菜单点击事件
- */
- Video.prototype.clickHandler = function () {
- // 弹出 panel
- this.createPanel('');
- };
- /**
- * 创建 panel
- * @param link 链接
- */
- Video.prototype.createPanel = function (iframe) {
- var conf = create_panel_conf_1["default"](this.editor, iframe);
- var panel = new Panel_1["default"](this, conf);
- panel.create();
- };
- /**
- * 尝试修改菜单 active 状态
- */
- Video.prototype.tryChangeActive = function () {};
- return Video;
- }(PanelMenu_1["default"]);
- exports["default"] = Video;
- /***/ }),
- /* 331 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description video 菜单 panel tab 配置
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var const_1 = __webpack_require__(26);
- function default_1(editor, video) {
- // panel 中需要用到的id
- var inputIFrameId = util_1.getRandom('input-iframe');
- var btnOkId = util_1.getRandom('btn-ok');
- var i18nPrefix = 'menus.panelMenus.video.';
- var t = function t(text, prefix) {
- if (prefix === void 0) {
- prefix = i18nPrefix;
- }
- return editor.i18next.t(prefix + text);
- };
- /**
- * 插入链接
- * @param iframe html标签
- */
- function insertVideo(video) {
- editor.cmd["do"]('insertHTML', video + '<p><br></p>'); // video添加后的回调
- editor.config.onlineVideoCallback(video);
- }
- /**
- * 校验在线视频链接
- * @param video 在线视频链接
- */
- function checkOnlineVideo(video) {
- // 编辑器进行正常校验,video 合规则使指针为true,不合规为false
- var flag = true;
- if (!const_1.videoRegex.test(video)) {
- flag = false;
- } // 查看开发者自定义配置的返回值
- var check = editor.config.onlineVideoCheck(video);
- if (check === undefined) {
- if (flag === false) console.log(t('您刚才插入的视频链接未通过编辑器校验', 'validate.'));
- } else if (check === true) {
- // 用户通过了开发者的校验
- if (flag === false) {
- editor.config.customAlert(t('您插入的网络视频无法识别', 'validate.') + "\uFF0C" + t('请替换为正确的网络视频格式', 'validate.') + "\uFF1A\u5982<iframe src=...></iframe>", 'warning');
- } else {
- return true;
- }
- } else {
- //用户未能通过开发者的校验,开发者希望我们提示这一字符串
- editor.config.customAlert(check, 'error');
- }
- return false;
- }
- var conf = {
- width: 300,
- height: 0,
- // panel 中可包含多个 tab
- tabs: [{
- // tab 的标题
- title: editor.i18next.t('menus.panelMenus.video.插入视频'),
- // 模板
- 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>",
- // 事件绑定
- events: [// 插入视频
- {
- selector: '#' + btnOkId,
- type: 'click',
- fn: function fn() {
- var _context;
- // 执行插入视频
- var $video = dom_core_1["default"]('#' + inputIFrameId);
- var video = (0, _trim["default"])(_context = $video.val()).call(_context); // 视频为空,则不插入
- if (!video) return; // 对当前用户插入的内容进行判断,插入为空,或者返回false,都停止插入
- if (!checkOnlineVideo(video)) return;
- insertVideo(video); // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
- return true;
- }
- }]
- }]
- };
- return conf;
- }
- exports["default"] = default_1;
- /***/ }),
- /* 332 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 插入、上传图片
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var PanelMenu_1 = __importDefault(__webpack_require__(34));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var create_panel_conf_1 = __importDefault(__webpack_require__(333));
- var Panel_1 = __importDefault(__webpack_require__(31));
- var index_1 = __importDefault(__webpack_require__(340));
- var Image =
- /** @class */
- function (_super) {
- __extends(Image, _super);
- function Image(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="图片"><i class="w-e-icon-image"></i></div>');
- _this = _super.call(this, $elem, editor) || this; // 绑定事件,如粘贴图片
- index_1["default"](editor);
- return _this;
- }
- /**
- * 菜单点击事件
- */
- Image.prototype.clickHandler = function () {
- this.createPanel();
- };
- /**
- * 创建 panel
- */
- Image.prototype.createPanel = function () {
- var conf = create_panel_conf_1["default"](this.editor);
- var panel = new Panel_1["default"](this, conf);
- panel.create();
- };
- /**
- * 尝试修改菜单 active 状态
- */
- Image.prototype.tryChangeActive = function () {};
- return Image;
- }(PanelMenu_1["default"]);
- exports["default"] = Image;
- /***/ }),
- /* 333 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description image 菜单 panel tab 配置
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _map = _interopRequireDefault(__webpack_require__(29));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var upload_img_1 = __importDefault(__webpack_require__(97));
- var const_1 = __webpack_require__(26);
- function default_1(editor) {
- var _context;
- var config = editor.config;
- var uploadImg = new upload_img_1["default"](editor); // panel 中需要用到的id
- var upTriggerId = util_1.getRandom('up-trigger-id');
- var upFileId = util_1.getRandom('up-file-id');
- var linkUrlId = util_1.getRandom('input-link-url');
- var linkBtnId = util_1.getRandom('btn-link');
- var i18nPrefix = 'menus.panelMenus.image.';
- var t = function t(text, prefix) {
- if (prefix === void 0) {
- prefix = i18nPrefix;
- }
- return editor.i18next.t(prefix + text);
- };
- /**
- * 校验网络图片链接是否合法
- * @param linkImg 网络图片链接
- */
- function checkLinkImg(src) {
- //编辑器进行正常校验,图片合规则使指针为true,不合规为false
- var flag = true;
- if (!const_1.imgRegex.test(src)) {
- flag = false;
- } //查看开发者自定义配置的返回值
- var check = config.linkImgCheck(src);
- if (check === undefined) {
- //用户未能通过开发者的校验,且开发者不希望编辑器提示用户
- if (flag === false) console.log(t('您刚才插入的图片链接未通过编辑器校验', 'validate.'));
- } else if (check === true) {
- //用户通过了开发者的校验
- if (flag === false) {
- config.customAlert(t('您插入的网络图片无法识别', 'validate.') + "\uFF0C" + t('请替换为支持的图片类型', 'validate.') + "\uFF1Ajpg | png | gif ...", 'warning');
- } else return true;
- } else {
- //用户未能通过开发者的校验,开发者希望我们提示这一字符串
- config.customAlert(check, 'error');
- }
- return false;
- } // tabs 配置 -----------------------------------------
- var fileMultipleAttr = config.uploadImgMaxLength === 1 ? '' : 'multiple="multiple"';
- var accepts = (0, _map["default"])(_context = config.uploadImgAccept).call(_context, function (item) {
- return "image/" + item;
- }).join(',');
- var tabsConf = [// first tab
- {
- // 标题
- title: t('上传图片'),
- // 模板
- tpl: "<div class=\"w-e-up-img-container\">\n <div id=\"" + upTriggerId + "\" class=\"w-e-up-btn\">\n <i class=\"w-e-icon-upload2\"></i>\n </div>\n <div style=\"display:none;\">\n <input id=\"" + upFileId + "\" type=\"file\" " + fileMultipleAttr + " accept=\"" + accepts + "\"/>\n </div>\n </div>",
- // 事件绑定
- events: [// 触发选择图片
- {
- selector: '#' + upTriggerId,
- type: 'click',
- fn: function fn() {
- var $file = dom_core_1["default"]('#' + upFileId);
- var fileElem = $file.elems[0];
- if (fileElem) {
- fileElem.click();
- } else {
- // 返回 true 可关闭 panel
- return true;
- }
- }
- }, // 选择图片完毕
- {
- selector: '#' + upFileId,
- type: 'change',
- fn: function fn() {
- var $file = dom_core_1["default"]('#' + upFileId);
- var fileElem = $file.elems[0];
- if (!fileElem) {
- // 返回 true 可关闭 panel
- return true;
- } // 获取选中的 file 对象列表
- var fileList = fileElem.files;
- if (fileList.length) {
- uploadImg.uploadImg(fileList);
- } // 返回 true 可关闭 panel
- return true;
- }
- }]
- }, // second tab
- {
- title: t('网络图片'),
- tpl: "<div>\n <input\n id=\"" + linkUrlId + "\"\n type=\"text\"\n class=\"block\"\n placeholder=\"" + t('图片链接') + "\"/>\n </td>\n <div class=\"w-e-button-container\">\n <button type=\"button\" id=\"" + linkBtnId + "\" class=\"right\">" + t('插入', '') + "</button>\n </div>\n </div>",
- events: [{
- selector: '#' + linkBtnId,
- type: 'click',
- fn: function fn() {
- var _context2;
- var $linkUrl = dom_core_1["default"]('#' + linkUrlId);
- var url = (0, _trim["default"])(_context2 = $linkUrl.val()).call(_context2); //如果url为空则直接返回
- if (!url) return; //如果不能通过校验也直接返回
- if (!checkLinkImg(url)) return; //插入图片url
- uploadImg.insertImg(url); // 返回 true 表示函数执行结束之后关闭 panel
- return true;
- }
- }]
- }]; // tabs end
- // 最终的配置 -----------------------------------------
- var conf = {
- width: 300,
- height: 0,
- tabs: []
- }; // 显示“上传图片”
- if (window.FileReader && (config.uploadImgShowBase64 || config.uploadImgServer || config.customUploadImg)) {
- conf.tabs.push(tabsConf[0]);
- } // 显示“插入网络图片”
- if (config.showLinkImg) {
- conf.tabs.push(tabsConf[1]);
- }
- return conf;
- }
- exports["default"] = default_1;
- /***/ }),
- /* 334 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 上传的核心方法
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _typeof2 = _interopRequireDefault(__webpack_require__(94));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- /**
- * 发送 post 请求(用于文件上传)
- * @param url url
- * @param option 配置项
- */
- function post(url, option) {
- var xhr = new XMLHttpRequest();
- xhr.open('POST', url); // 超时,默认 10s
- xhr.timeout = option.timeout || 10 * 1000;
- xhr.ontimeout = function () {
- console.error('wangEditor - 请求超时');
- option.onTimeout && option.onTimeout(xhr);
- }; // 进度
- if (xhr.upload) {
- xhr.upload.onprogress = function (e) {
- var percent = e.loaded / e.total;
- option.onProgress && option.onProgress(percent, e);
- };
- } // 自定义 header
- if (option.headers) {
- (0, _forEach["default"])(util_1).call(util_1, option.headers, function (key, val) {
- xhr.setRequestHeader(key, val);
- });
- } // 跨域传 cookie
- xhr.withCredentials = !!option.withCredentials; // 上传之前的钩子函数,在 xhr.send() 之前执行
- if (option.beforeSend) {
- var beforeResult = option.beforeSend(xhr);
- if (beforeResult && (0, _typeof2["default"])(beforeResult) === 'object') {
- if (beforeResult.prevent) {
- // 如果返回的结果是 {prevent: true, msg: 'xxxx'} 则表示用户放弃上传
- return beforeResult.msg;
- }
- }
- } // 服务端返回之后
- xhr.onreadystatechange = function () {
- if (xhr.readyState !== 4) return;
- var status = xhr.status;
- if (status < 200) return; // 请求发送过程中,尚未返回
- if (status >= 300 && status < 400) return; // 重定向
- if (status >= 400) {
- // 40x 50x 报错
- console.error('wangEditor - XHR 报错,状态码 ' + status);
- if (option.onError) option.onError(xhr); // 有,则执行 onError 函数即可
- return;
- } // status = 200 ,得到结果
- var resultStr = xhr.responseText;
- var result;
- if ((0, _typeof2["default"])(resultStr) !== 'object') {
- try {
- result = JSON.parse(resultStr);
- } catch (ex) {
- console.error('wangEditor - 返回结果不是 JSON 格式', resultStr);
- if (option.onFail) option.onFail(xhr, resultStr);
- return;
- }
- } else {
- result = resultStr;
- }
- option.onSuccess(xhr, result);
- }; // 发送请求
- xhr.send(option.formData || null);
- return xhr;
- }
- exports["default"] = post;
- /***/ }),
- /* 335 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 上传进度条
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _now = _interopRequireDefault(__webpack_require__(336));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Progress =
- /** @class */
- function () {
- function Progress(editor) {
- this.editor = editor;
- this.$textContainer = editor.$textContainerElem;
- this.$bar = dom_core_1["default"]('<div class="w-e-progress"></div>');
- this.isShow = false;
- this.time = 0;
- this.timeoutId = 0;
- }
- /**
- * 显示进度条
- * @param progress 进度百分比
- */
- Progress.prototype.show = function (progress) {
- var _this = this; // 不要重新显示
- if (this.isShow) {
- return;
- }
- this.isShow = true; // 渲染 $bar
- var $bar = this.$bar;
- var $textContainer = this.$textContainer;
- $textContainer.append($bar); // 改变进度条(防抖,100ms 渲染一次)
- if ((0, _now["default"])() - this.time > 100) {
- if (progress <= 1) {
- $bar.css('width', progress * 100 + '%');
- this.time = (0, _now["default"])();
- }
- } // 500ms 之后隐藏
- var timeoutId = this.timeoutId;
- if (timeoutId) {
- clearTimeout(timeoutId);
- }
- this.timeoutId = window.setTimeout(function () {
- _this.hide();
- }, 500);
- };
- /**
- * 隐藏
- */
- Progress.prototype.hide = function () {
- var $bar = this.$bar;
- $bar.remove();
- this.isShow = false;
- this.time = 0;
- this.timeoutId = 0;
- };
- return Progress;
- }();
- exports["default"] = Progress;
- /***/ }),
- /* 336 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(337);
- /***/ }),
- /* 337 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(338);
- module.exports = parent;
- /***/ }),
- /* 338 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(339);
- var path = __webpack_require__(10);
- module.exports = path.Date.now;
- /***/ }),
- /* 339 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- // `Date.now` method
- // https://tc39.github.io/ecma262/#sec-date.now
- $({ target: 'Date', stat: true }, {
- now: function now() {
- return new Date().getTime();
- }
- });
- /***/ }),
- /* 340 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 绑定图片的事件
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var paste_img_1 = __importDefault(__webpack_require__(341));
- var drop_img_1 = __importDefault(__webpack_require__(342));
- var drag_size_1 = __importDefault(__webpack_require__(343));
- var tooltip_event_1 = __importDefault(__webpack_require__(351));
- /**
- * 绑定事件
- * @param editor 编辑器实例
- */
- function bindEvent(editor) {
- // 粘贴图片
- paste_img_1["default"](editor); // 拖拽图片
- drop_img_1["default"](editor); // 可再扩展其他事件...如图片 tooltip 等
- // 拖拽图片尺寸
- drag_size_1["default"](editor); //Tooltip
- tooltip_event_1["default"](editor);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 341 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 粘贴图片
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var paste_event_1 = __webpack_require__(123);
- var upload_img_1 = __importDefault(__webpack_require__(97));
- /**
- * 剪切板是否有 text 或者 html ?
- * @param editor 编辑器对象
- * @param e 粘贴事件参数
- */
- function _haveTextOrHtml(editor, e) {
- var config = editor.config;
- var pasteFilterStyle = config.pasteFilterStyle;
- var pasteIgnoreImg = config.pasteIgnoreImg;
- var pasteHtml = paste_event_1.getPasteHtml(e, pasteFilterStyle, pasteIgnoreImg);
- if (pasteHtml) return true;
- var pasteText = paste_event_1.getPasteText(e);
- if (pasteText) return true;
- return false; // text html 都没有,则返回 false
- }
- /**
- * 粘贴图片事件方法
- * @param e 事件参数
- */
- function pasteImgHandler(e, editor) {
- if (_haveTextOrHtml(editor, e)) {
- // 粘贴过来的有 text 或者 html ,则不执行粘贴图片逻辑
- return;
- } // 获取粘贴的图片列表
- var pastedFiles = paste_event_1.getPasteImgs(e);
- if (!pastedFiles.length) {
- return;
- } // code 中忽略(暂不管它)
- // 执行上传
- var uploadImg = new upload_img_1["default"](editor);
- uploadImg.uploadImg(pastedFiles);
- }
- /**
- * 粘贴图片
- * @param editor 编辑器对象
- * @param pasteEvents 粘贴事件列表
- */
- function bindPasteImg(editor) {
- // 绑定 paste 事件
- editor.txt.eventHooks.pasteEvents.push(function (e) {
- pasteImgHandler(e, editor);
- });
- }
- exports["default"] = bindPasteImg;
- /***/ }),
- /* 342 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 拖拽上传图片
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var upload_img_1 = __importDefault(__webpack_require__(97));
- function bindDropImg(editor) {
- /**
- * 拖拽图片的事件
- * @param e 事件参数
- */
- function dropImgHandler(e) {
- var files = e.dataTransfer && e.dataTransfer.files;
- if (!files || !files.length) {
- return;
- } // 上传图片
- var uploadImg = new upload_img_1["default"](editor);
- uploadImg.uploadImg(files);
- } // 绑定 drop 事件
- editor.txt.eventHooks.dropEvents.push(dropImgHandler);
- }
- exports["default"] = bindDropImg;
- /***/ }),
- /* 343 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 图片拖拽事件绑定
- * @author xiaokyo
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _parseFloat2 = _interopRequireDefault(__webpack_require__(344));
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.createShowHideFn = void 0;
- var dom_core_1 = __importDefault(__webpack_require__(2));
- __webpack_require__(349);
- var util_1 = __webpack_require__(7);
- /**
- * 设置拖拽框的rect
- * @param $drag drag Dom
- * @param width 要设置的宽度
- * @param height 要设置的高度
- * @param left 要设置的左边
- * @param top 要设置的顶部距离
- */
- function setDragStyle($drag, width, height, left, top) {
- $drag.attr('style', "width:" + width + "px; height:" + height + "px; left:" + left + "px; top:" + top + "px;");
- }
- /**
- * 生成一个图片指定大小的拖拽框
- * @param editor 编辑器实例
- * @param $textContainerElem 编辑框对象
- */
- function createDragBox(editor, $textContainerElem) {
- 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>");
- $drag.hide();
- $textContainerElem.append($drag);
- return $drag;
- }
- /**
- * 显示拖拽框并设置宽度
- * @param $textContainerElem 编辑框实例
- * @param $drag 拖拽框对象
- */
- function showDargBox($textContainerElem, $drag, $img) {
- var boxRect = $textContainerElem.getBoundingClientRect();
- var rect = $img.getBoundingClientRect();
- var rectW = rect.width.toFixed(2);
- var rectH = rect.height.toFixed(2);
- (0, _find["default"])($drag).call($drag, '.w-e-img-drag-show-size').text(rectW + "px * " + rectH + "px");
- setDragStyle($drag, (0, _parseFloat2["default"])(rectW), (0, _parseFloat2["default"])(rectH), rect.left - boxRect.left, rect.top - boxRect.top);
- $drag.show();
- }
- /**
- * 生成图片拖拽框的 显示/隐藏 函数
- */
- function createShowHideFn(editor) {
- var $textContainerElem = editor.$textContainerElem;
- var $imgTarget; // 生成拖拽框
- var $drag = createDragBox(editor, $textContainerElem);
- /**
- * 设置拖拽事件
- * @param $drag 拖拽框的domElement
- * @param $textContainerElem 编辑器实例
- */
- function bindDragEvents($drag, $container) {
- $drag.on('click', function (e) {
- e.stopPropagation();
- });
- $drag.on('mousedown', '.w-e-img-drag-rb', function (e) {
- // e.stopPropagation()
- e.preventDefault();
- if (!$imgTarget) return;
- var firstX = e.clientX;
- var firstY = e.clientY;
- var boxRect = $container.getBoundingClientRect();
- var imgRect = $imgTarget.getBoundingClientRect();
- var width = imgRect.width;
- var height = imgRect.height;
- var left = imgRect.left - boxRect.left;
- var top = imgRect.top - boxRect.top;
- var ratio = width / height;
- var setW = width;
- var setH = height;
- var $document = dom_core_1["default"](document);
- function offEvents() {
- $document.off('mousemove', mouseMoveHandler);
- $document.off('mouseup', mouseUpHandler);
- }
- function mouseMoveHandler(ev) {
- ev.stopPropagation();
- ev.preventDefault();
- setW = width + (ev.clientX - firstX);
- setH = height + (ev.clientY - firstY); // 等比计算
- if (setW / setH != ratio) {
- setH = setW / ratio;
- }
- setW = (0, _parseFloat2["default"])(setW.toFixed(2));
- setH = (0, _parseFloat2["default"])(setH.toFixed(2));
- (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");
- setDragStyle($drag, setW, setH, left, top);
- }
- $document.on('mousemove', mouseMoveHandler);
- function mouseUpHandler() {
- $imgTarget.attr('width', setW + '');
- $imgTarget.attr('height', setH + '');
- var newImgRect = $imgTarget.getBoundingClientRect();
- setDragStyle($drag, setW, setH, newImgRect.left - boxRect.left, newImgRect.top - boxRect.top); // 解绑事件
- offEvents();
- }
- $document.on('mouseup', mouseUpHandler); // 解绑事件
- $document.on('mouseleave', offEvents);
- });
- } // 显示拖拽框
- function showDrag($target) {
- if (util_1.UA.isIE()) return false;
- if ($target) {
- $imgTarget = $target;
- showDargBox($textContainerElem, $drag, $imgTarget);
- }
- } // 隐藏拖拽框
- function hideDrag() {
- (0, _find["default"])($textContainerElem).call($textContainerElem, '.w-e-img-drag-mask').hide();
- } // 事件绑定
- bindDragEvents($drag, $textContainerElem); // 后期改成 blur 触发
- dom_core_1["default"](document).on('click', hideDrag);
- editor.beforeDestroy(function () {
- dom_core_1["default"](document).off('click', hideDrag);
- });
- return {
- showDrag: showDrag,
- hideDrag: hideDrag
- };
- }
- exports.createShowHideFn = createShowHideFn;
- /**
- * 点击事件委托
- * @param editor 编辑器实例
- */
- function bindDragImgSize(editor) {
- var _a = createShowHideFn(editor),
- showDrag = _a.showDrag,
- hideDrag = _a.hideDrag; // 显示拖拽框
- editor.txt.eventHooks.imgClickEvents.push(showDrag); // 隐藏拖拽框
- editor.txt.eventHooks.textScrollEvents.push(hideDrag);
- editor.txt.eventHooks.keyupEvents.push(hideDrag);
- editor.txt.eventHooks.toolbarClickEvents.push(hideDrag);
- editor.txt.eventHooks.menuClickEvents.push(hideDrag);
- editor.txt.eventHooks.changeEvents.push(hideDrag);
- }
- exports["default"] = bindDragImgSize;
- /***/ }),
- /* 344 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(345);
- /***/ }),
- /* 345 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(346);
- module.exports = parent;
- /***/ }),
- /* 346 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(347);
- var path = __webpack_require__(10);
- module.exports = path.parseFloat;
- /***/ }),
- /* 347 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var parseFloatImplementation = __webpack_require__(348);
- // `parseFloat` method
- // https://tc39.github.io/ecma262/#sec-parsefloat-string
- $({ global: true, forced: parseFloat != parseFloatImplementation }, {
- parseFloat: parseFloatImplementation
- });
- /***/ }),
- /* 348 */
- /***/ (function(module, exports, __webpack_require__) {
- var global = __webpack_require__(8);
- var trim = __webpack_require__(92).trim;
- var whitespaces = __webpack_require__(66);
- var $parseFloat = global.parseFloat;
- var FORCED = 1 / $parseFloat(whitespaces + '-0') !== -Infinity;
- // `parseFloat` method
- // https://tc39.github.io/ecma262/#sec-parsefloat-string
- module.exports = FORCED ? function parseFloat(string) {
- var trimmedString = trim(String(string));
- var result = $parseFloat(trimmedString);
- return result === 0 && trimmedString.charAt(0) == '-' ? -0 : result;
- } : $parseFloat;
- /***/ }),
- /* 349 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(350);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 350 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- 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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 351 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description tooltip 事件
- * @author lichunlin
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.createShowHideFn = void 0;
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Tooltip_1 = __importDefault(__webpack_require__(44));
- /**
- * 生成 Tooltip 的显示隐藏函数
- */
- function createShowHideFn(editor) {
- var tooltip;
- var t = function t(text, prefix) {
- if (prefix === void 0) {
- prefix = '';
- }
- return editor.i18next.t(prefix + text);
- };
- /**
- * 显示 tooltip
- * @param $node 链接元素
- */
- function showImgTooltip($node) {
- var conf = [{
- $elem: dom_core_1["default"]("<span class='w-e-icon-trash-o'></span>"),
- onClick: function onClick(editor, $node) {
- // 选中img元素
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- editor.cmd["do"]('delete'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }, {
- $elem: dom_core_1["default"]('<span>30%</span>'),
- onClick: function onClick(editor, $node) {
- $node.attr('width', '30%');
- $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }, {
- $elem: dom_core_1["default"]('<span>50%</span>'),
- onClick: function onClick(editor, $node) {
- $node.attr('width', '50%');
- $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }, {
- $elem: dom_core_1["default"]('<span>100%</span>'),
- onClick: function onClick(editor, $node) {
- $node.attr('width', '100%');
- $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + t('重置') + "</span>"),
- onClick: function onClick(editor, $node) {
- $node.removeAttr('width');
- $node.removeAttr('height'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }];
- tooltip = new Tooltip_1["default"](editor, $node, conf);
- tooltip.create();
- }
- /**
- * 隐藏 tooltip
- */
- function hideImgTooltip() {
- // 移除 tooltip
- if (tooltip) {
- tooltip.remove();
- tooltip = null;
- }
- }
- return {
- showImgTooltip: showImgTooltip,
- hideImgTooltip: hideImgTooltip
- };
- }
- exports.createShowHideFn = createShowHideFn;
- /**
- * 绑定 tooltip 事件
- * @param editor 编辑器实例
- */
- function bindTooltipEvent(editor) {
- var _a = createShowHideFn(editor),
- showImgTooltip = _a.showImgTooltip,
- hideImgTooltip = _a.hideImgTooltip; // 点击图片元素是,显示 tooltip
- editor.txt.eventHooks.imgClickEvents.push(showImgTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
- editor.txt.eventHooks.clickEvents.push(hideImgTooltip);
- editor.txt.eventHooks.keyupEvents.push(hideImgTooltip);
- editor.txt.eventHooks.toolbarClickEvents.push(hideImgTooltip);
- editor.txt.eventHooks.menuClickEvents.push(hideImgTooltip);
- editor.txt.eventHooks.textScrollEvents.push(hideImgTooltip);
- editor.txt.eventHooks.imgDragBarMouseDownEvents.push(hideImgTooltip); // change 时隐藏
- editor.txt.eventHooks.changeEvents.push(hideImgTooltip);
- }
- exports["default"] = bindTooltipEvent;
- /***/ }),
- /* 352 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 增加缩进/减少缩进
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var operate_element_1 = __importDefault(__webpack_require__(353));
- var Indent =
- /** @class */
- function (_super) {
- __extends(Indent, _super);
- function Indent(editor) {
- var _this = this;
- 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>");
- var dropListConf = {
- width: 130,
- title: '设置缩进',
- type: 'list',
- list: [{
- $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>"),
- value: 'increase'
- }, {
- $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>"),
- value: 'decrease'
- }],
- clickHandler: function clickHandler(value) {
- // 注意 this 是指向当前的 Indent 对象
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, dropListConf) || this;
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- Indent.prototype.command = function (value) {
- var editor = this.editor;
- var $selectionElem = editor.selection.getSelectionContainerElem(); // 判断 当前选区为 textElem 时
- if ($selectionElem && editor.$textElem.equal($selectionElem)) {
- // 当 当前选区 等于 textElem 时
- // 代表 当前选区 可能是一个选择了一个完整的段落或者多个段落
- var $elems = editor.selection.getSelectionRangeTopNodes(editor);
- if ($elems.length > 0) {
- (0, _forEach["default"])($elems).call($elems, function (item) {
- operate_element_1["default"](dom_core_1["default"](item), value, editor);
- });
- }
- } else {
- // 当 当前选区 不等于 textElem 时
- // 代表 当前选区要么是一个段落,要么是段落中的一部分
- if ($selectionElem && $selectionElem.length > 0) {
- (0, _forEach["default"])($selectionElem).call($selectionElem, function (item) {
- operate_element_1["default"](dom_core_1["default"](item), value, editor);
- });
- }
- } // 恢复选区
- editor.selection.restoreSelection();
- this.tryChangeActive();
- };
- /**
- * 尝试改变菜单激活(高亮)状态
- */
- Indent.prototype.tryChangeActive = function () {
- var editor = this.editor;
- var $selectionElem = editor.selection.getSelectionStartElem();
- var $selectionStartElem = dom_core_1["default"]($selectionElem).getNodeTop(editor);
- if ($selectionStartElem.length <= 0) return;
- if ($selectionStartElem.elems[0].style['paddingLeft'] != '') {
- this.active();
- } else {
- this.unActive();
- }
- };
- return Indent;
- }(DropListMenu_1["default"]);
- exports["default"] = Indent;
- /***/ }),
- /* 353 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 对节点 操作 进行封装
- * 获取当前节点的段落
- * 根据type判断是增加还是减少缩进
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _slice = _interopRequireDefault(__webpack_require__(43));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var increase_indent_style_1 = __importDefault(__webpack_require__(354));
- var decrease_indent_style_1 = __importDefault(__webpack_require__(355));
- var lengthRegex = /^(\d+)(\w+)$/;
- var percentRegex = /^(\d+)%$/;
- function parseIndentation(editor) {
- var indentation = editor.config.indentation;
- if (typeof indentation === 'string') {
- if (lengthRegex.test(indentation)) {
- var _context;
- var _a = (0, _slice["default"])(_context = (0, _trim["default"])(indentation).call(indentation).match(lengthRegex)).call(_context, 1, 3),
- value = _a[0],
- unit = _a[1];
- return {
- value: Number(value),
- unit: unit
- };
- } else if (percentRegex.test(indentation)) {
- return {
- value: Number((0, _trim["default"])(indentation).call(indentation).match(percentRegex)[1]),
- unit: '%'
- };
- }
- } else if (indentation.value !== void 0 && indentation.unit) {
- return indentation;
- }
- return {
- value: 2,
- unit: 'em'
- };
- }
- function operateElement($node, type, editor) {
- var $elem = $node.getNodeTop(editor);
- var reg = /^P$/i;
- if (reg.test($elem.getNodeName())) {
- if (type === 'increase') increase_indent_style_1["default"]($elem, parseIndentation(editor));else if (type === 'decrease') decrease_indent_style_1["default"]($elem, parseIndentation(editor));
- }
- }
- exports["default"] = operateElement;
- /***/ }),
- /* 354 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 增加缩进
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _slice = _interopRequireDefault(__webpack_require__(43));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- function increaseIndentStyle($node, options) {
- var $elem = $node.elems[0];
- if ($elem.style['paddingLeft'] === '') {
- $node.css('padding-left', options.value + options.unit);
- } else {
- var oldPL = $elem.style['paddingLeft'];
- var oldVal = (0, _slice["default"])(oldPL).call(oldPL, 0, oldPL.length - options.unit.length);
- var newVal = Number(oldVal) + options.value;
- $node.css('padding-left', "" + newVal + options.unit);
- }
- }
- exports["default"] = increaseIndentStyle;
- /***/ }),
- /* 355 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 减少缩进
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _slice = _interopRequireDefault(__webpack_require__(43));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- function decreaseIndentStyle($node, options) {
- var $elem = $node.elems[0];
- if ($elem.style['paddingLeft'] !== '') {
- var oldPL = $elem.style['paddingLeft'];
- var oldVal = (0, _slice["default"])(oldPL).call(oldPL, 0, oldPL.length - options.unit.length);
- var newVal = Number(oldVal) - options.value;
- if (newVal > 0) {
- $node.css('padding-left', "" + newVal + options.unit);
- } else {
- $node.css('padding-left', '');
- }
- }
- }
- exports["default"] = decreaseIndentStyle;
- /***/ }),
- /* 356 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * @description 插入表情
- * @author liuwe
- */
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var PanelMenu_1 = __importDefault(__webpack_require__(34));
- var Panel_1 = __importDefault(__webpack_require__(31));
- var create_panel_conf_1 = __importDefault(__webpack_require__(357));
- var Emoticon =
- /** @class */
- function (_super) {
- __extends(Emoticon, _super);
- function Emoticon(editor) {
- var _this = this;
- 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>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 创建 panel
- */
- Emoticon.prototype.createPanel = function () {
- var conf = create_panel_conf_1["default"](this.editor);
- var panel = new Panel_1["default"](this, conf);
- panel.create();
- };
- /**
- * 菜单表情点击事件
- */
- Emoticon.prototype.clickHandler = function () {
- this.createPanel();
- };
- Emoticon.prototype.tryChangeActive = function () {};
- return Emoticon;
- }(PanelMenu_1["default"]);
- exports["default"] = Emoticon;
- /***/ }),
- /* 357 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 表情菜单 panel配置
- * @author liuwei
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _trim = _interopRequireDefault(__webpack_require__(19));
- var _filter = _interopRequireDefault(__webpack_require__(65));
- var _map = _interopRequireDefault(__webpack_require__(29));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- function default_1(editor) {
- // 声明emotions数据结构
- var emotions = editor.config.emotions;
- /* tabs配置项 ==================================================================*/
- // 生成表情结构 TODO jele type类型待优化
- function GenerateExpressionStructure(ele) {
- // 返回为一个数组对象
- var res = []; // 如果type是image类型则生成一个img标签
- if (ele.type == 'image') {
- var _context;
- res = (0, _map["default"])(_context = ele.content).call(_context, function (con) {
- if (typeof con == 'string') return '';
- return "<span title=\"" + con.alt + "\">\n <img class=\"eleImg\" style src=\"" + con.src + "\" alt=\"[" + con.alt + "]\">\n </span>";
- });
- res = (0, _filter["default"])(res).call(res, function (s) {
- return s !== '';
- });
- } //否则直接当内容处理
- else {
- var _context2;
- res = (0, _map["default"])(_context2 = ele.content).call(_context2, function (con) {
- return "<span class=\"eleImg\" title=\"" + con + "\">" + con + "</span>";
- });
- }
- return res.join('').replace(/ /g, '');
- }
- var tabsConf = (0, _map["default"])(emotions).call(emotions, function (ele) {
- return {
- title: editor.i18next.t("menus.panelMenus.emoticon." + ele.title),
- // 判断type类型如果是image则以img的形式插入否则以内容
- tpl: "<div>" + GenerateExpressionStructure(ele) + "</div>",
- events: [{
- selector: '.eleImg',
- type: 'click',
- fn: function fn(e) {
- // e为事件对象
- var $target = dom_core_1["default"](e.target);
- var nodeName = $target.getNodeName();
- var insertHtml;
- if (nodeName === 'IMG') {
- var _context3;
- // 插入图片
- insertHtml = (0, _trim["default"])(_context3 = $target.parent().html()).call(_context3);
- } else {
- // 插入 emoji
- insertHtml = '<span>' + $target.html() + '</span>';
- }
- editor.cmd["do"]('insertHTML', insertHtml); // 示函数执行结束之后关闭 panel
- return true;
- }
- }]
- };
- });
- /* tabs配置项 =================================================================end*/
- // 最终的配置 -----------------------------------------
- var conf = {
- width: 300,
- height: 230,
- tabs: tabsConf
- };
- return conf;
- }
- exports["default"] = default_1;
- /***/ }),
- /* 358 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 无序列表/有序列表
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var List =
- /** @class */
- function (_super) {
- __extends(List, _super);
- function List(editor) {
- var _this = this;
- 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>");
- var dropListConf = {
- width: 130,
- title: '序列',
- type: 'list',
- list: [{
- $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>"),
- value: 'insertUnorderedList'
- }, {
- $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>"),
- value: 'insertOrderedList'
- }],
- clickHandler: function clickHandler(value) {
- // 注意 this 是指向当前的 List 对象
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, dropListConf) || this;
- return _this;
- }
- List.prototype.command = function (value) {
- var editor = this.editor;
- var $textElem = editor.$textElem;
- editor.selection.restoreSelection(); // 判断是否已经执行了命令
- if (editor.cmd.queryCommandState(value)) {
- return;
- } //禁止在table中添加列表
- var $selectionElem = dom_core_1["default"](editor.selection.getSelectionContainerElem());
- var $dom = dom_core_1["default"]($selectionElem.elems[0]).parentUntil('TABLE', $selectionElem.elems[0]);
- if ($dom && dom_core_1["default"]($dom.elems[0]).getNodeName() === 'TABLE') {
- return;
- }
- editor.cmd["do"](value); // 验证列表是否被包裹在 <p> 之内
- if ($selectionElem.getNodeName() === 'LI') {
- $selectionElem = $selectionElem.parent();
- }
- if (/^ol|ul$/i.test($selectionElem.getNodeName()) === false) {
- return;
- }
- if ($selectionElem.equal($textElem)) {
- // 证明是顶级标签,没有被 <p> 包裹
- return;
- }
- var $parent = $selectionElem.parent();
- if ($parent.equal($textElem)) {
- // $parent 是顶级标签,不能删除
- return;
- }
- $selectionElem.insertAfter($parent);
- $parent.remove(); // 恢复选区
- editor.selection.restoreSelection();
- this.tryChangeActive();
- };
- List.prototype.tryChangeActive = function () {};
- return List;
- }(DropListMenu_1["default"]);
- exports["default"] = List;
- /***/ }),
- /* 359 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 段落行高 LineHeight
- * @author lichunlin
- *
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _indexOf = _interopRequireDefault(__webpack_require__(54));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var DropListMenu_1 = __importDefault(__webpack_require__(23));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var lineHeightList_1 = __importDefault(__webpack_require__(360));
- var util_1 = __webpack_require__(7);
- var LineHeight =
- /** @class */
- function (_super) {
- __extends(LineHeight, _super);
- function LineHeight(editor) {
- var _this = this;
- 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>");
- var lineHeightMenu = new lineHeightList_1["default"](editor, editor.config.lineHeights);
- var DropListMenu = {
- width: 100,
- title: '设置行高',
- type: 'list',
- list: lineHeightMenu.getItemList(),
- clickHandler: function clickHandler(value) {
- //保存焦点
- editor.selection.saveRange();
- _this.command(value);
- }
- };
- _this = _super.call(this, $elem, editor, DropListMenu) || this;
- return _this;
- }
- /**
- * 执行命令
- * @param value value
- */
- LineHeight.prototype.command = function (value) {
- var _this = this;
- var _a;
- var selection = window.getSelection ? window.getSelection() : document.getSelection(); //允许设置dom
- var allowArray = ['P'];
- var editor = this.editor;
- var st = ''; //恢复焦点
- editor.selection.restoreSelection();
- var $selectionElem = dom_core_1["default"](editor.selection.getSelectionContainerElem());
- var $selectionAll = dom_core_1["default"](editor.selection.getSelectionContainerElem()); // let dom:HTMLElement= $selectionElem.elems[0]
- var dom = dom_core_1["default"](editor.selection.getSelectionStartElem()).elems[0]; //获取元素的style
- var style = '';
- var styleList = []; //点击默认的时候删除line-height属性 并重新设置 style
- var styleStr = ''; //选中多行操作
- if ($selectionElem && editor.$textElem.equal($selectionElem)) {
- var isIE = util_1.UA.isIE();
- if (isIE) {
- // ie下禁止多行操作 避免多行造成除第一行外的段落内容都被删除
- return;
- } //获取range 开头结束的dom在 祖父元素的下标
- var indexStore_1 = [];
- var arrayDom_a = [];
- var arrayDom_b = []; //获取range 开头结束的dom
- var StartElem_1 = dom_core_1["default"](editor.selection.getSelectionStartElem());
- var EndElem_1 = dom_core_1["default"](editor.selection.getSelectionEndElem());
- var childList = (_a = editor.selection.getRange()) === null || _a === void 0 ? void 0 : _a.commonAncestorContainer.childNodes;
- arrayDom_a.push(this.getDom(StartElem_1.elems[0]));
- childList === null || childList === void 0 ? void 0 : (0, _forEach["default"])(childList).call(childList, function (item, index) {
- if (item === _this.getDom(StartElem_1.elems[0])) {
- indexStore_1.push(index);
- }
- if (item === _this.getDom(EndElem_1.elems[0])) {
- indexStore_1.push(index);
- }
- }); //遍历 获取头尾之间的dom元素
- var i = 0;
- var d = void 0;
- arrayDom_b.push(this.getDom(StartElem_1.elems[0]));
- while (arrayDom_a[i] !== this.getDom(EndElem_1.elems[0])) {
- d = dom_core_1["default"](arrayDom_a[i].nextElementSibling).elems[0];
- if ((0, _indexOf["default"])(allowArray).call(allowArray, dom_core_1["default"](d).getNodeName()) !== -1) {
- arrayDom_b.push(d);
- arrayDom_a.push(d);
- } else {
- arrayDom_a.push(d);
- }
- i++;
- } //设置段落选取 全选
- if (dom_core_1["default"](arrayDom_a[0]).getNodeName() !== 'P') {
- i = 0; //遍历集合得到第一个p标签的下标
- for (var k = 0; k < arrayDom_a.length; k++) {
- if (dom_core_1["default"](arrayDom_a[k]).getNodeName() === 'P') {
- i = k;
- break;
- }
- } //i===0 说明选区中没有p段落
- if (i === 0) {
- return;
- }
- var _i = 0;
- while (_i !== i) {
- arrayDom_a.shift();
- _i++;
- }
- } //设置替换的选区
- this.setRange(arrayDom_a[0], arrayDom_a[arrayDom_a.length - 1]); //生成innerHtml html字符串
- (0, _forEach["default"])(arrayDom_a).call(arrayDom_a, function (item) {
- style = item.getAttribute('style');
- styleList = style ? style.split(';') : [];
- styleStr = '';
- if (dom_core_1["default"](item).getNodeName() === 'P') {
- //判断是否 点击默认
- value ? styleStr = _this.styleProcessing(styleList) + ("line-height:" + value + ";") : styleStr = _this.styleProcessing(styleList);
- st = st + ("<" + dom_core_1["default"](item).getNodeName().toLowerCase() + " style=\"" + styleStr + "\">" + item.innerHTML + "</" + dom_core_1["default"](item).getNodeName().toLowerCase() + ">");
- } else {
- styleStr = _this.styleProcessing(styleList);
- st = st + ("<" + dom_core_1["default"](item).getNodeName().toLowerCase() + " style=\"" + styleStr + "\">" + item.innerHTML + "</" + dom_core_1["default"](item).getNodeName().toLowerCase() + ">");
- }
- });
- this.action(st, editor); //恢复已选择的选区
- dom = $selectionAll.elems[0];
- this.setRange(dom.children[indexStore_1[0]], dom.children[indexStore_1[1]]);
- return;
- } //遍历dom 获取祖父元素 直到contenteditable属性的div标签
- dom = this.getDom(dom); //校验允许lineheight设置标签
- if ((0, _indexOf["default"])(allowArray).call(allowArray, dom_core_1["default"](dom).getNodeName()) === -1) {
- return;
- }
- style = dom.getAttribute('style');
- styleList = style ? style.split(';') : []; //全选 dom下所有的内容
- selection === null || selection === void 0 ? void 0 : selection.selectAllChildren(dom); //保存range
- editor.selection.saveRange(); //判断是否存在value 默认 移除line-height
- if (!value) {
- if (style) {
- styleStr = this.styleProcessing(styleList); //避免没有其它属性 只留下 ‘style’ 减少代码
- if (styleStr === '') {
- st = "<" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">" + dom.innerHTML + "</" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">";
- } else {
- st = "<" + dom_core_1["default"](dom).getNodeName().toLowerCase() + " style=\"" + styleStr + "\">" + dom.innerHTML + "</" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">";
- }
- this.action(st, editor);
- }
- return;
- }
- if (style) {
- //存在style 检索其它style属性
- styleStr = this.styleProcessing(styleList) + ("line-height:" + value + ";");
- } else {
- styleStr = "line-height:" + value + ";";
- }
- st = "<" + dom_core_1["default"](dom).getNodeName().toLowerCase() + " style=\"" + styleStr + "\">" + dom.innerHTML + "</" + dom_core_1["default"](dom).getNodeName().toLowerCase() + ">"; //防止BLOCKQUOTE叠加
- if (dom_core_1["default"](dom).getNodeName() === 'BLOCKQUOTE') {
- dom_core_1["default"](dom).css('line-height', value);
- } else {
- this.action(st, editor);
- }
- };
- /**
- * 遍历dom 获取祖父元素 直到contenteditable属性的div标签
- *
- */
- LineHeight.prototype.getDom = function (dom) {
- var DOM = dom_core_1["default"](dom).elems[0];
- if (!DOM.parentNode) {
- return DOM;
- }
- function getParentNode($node, editor) {
- var $parent = dom_core_1["default"]($node.parentNode);
- if (editor.$textElem.equal($parent)) {
- return $node;
- } else {
- return getParentNode($parent.elems[0], editor);
- }
- }
- DOM = getParentNode(DOM, this.editor);
- return DOM;
- };
- /**
- * 执行 document.execCommand
- *
- */
- LineHeight.prototype.action = function (html_str, editor) {
- editor.cmd["do"]('insertHTML', html_str);
- };
- /**
- * style 处理
- */
- LineHeight.prototype.styleProcessing = function (styleList) {
- var styleStr = '';
- (0, _forEach["default"])(styleList).call(styleList, function (item) {
- item !== '' && (0, _indexOf["default"])(item).call(item, 'line-height') === -1 ? styleStr = styleStr + item + ';' : '';
- });
- return styleStr;
- };
- /**
- * 段落全选 比如:避免11变成111
- */
- LineHeight.prototype.setRange = function (startDom, endDom) {
- var editor = this.editor;
- var selection = window.getSelection ? window.getSelection() : document.getSelection(); //清除所有的选区
- selection === null || selection === void 0 ? void 0 : selection.removeAllRanges();
- var range = document.createRange();
- var star = startDom;
- var end = endDom;
- range.setStart(star, 0);
- range.setEnd(end, 1);
- selection === null || selection === void 0 ? void 0 : selection.addRange(range); //保存设置好的选区
- editor.selection.saveRange(); //清除所有的选区
- selection === null || selection === void 0 ? void 0 : selection.removeAllRanges(); //恢复选区
- editor.selection.restoreSelection();
- };
- /**
- * 尝试修改菜单激活状态
- */
- LineHeight.prototype.tryChangeActive = function () {
- var editor = this.editor;
- var $selectionElem = editor.selection.getSelectionContainerElem();
- if ($selectionElem && editor.$textElem.equal($selectionElem)) {
- //避免选中多行设置
- return;
- }
- var dom = dom_core_1["default"](editor.selection.getSelectionStartElem());
- dom = this.getDom(dom.elems[0]);
- var style = dom.getAttribute('style') ? dom.getAttribute('style') : ''; //判断当前标签是否具有line-height属性
- if (style && (0, _indexOf["default"])(style).call(style, 'line-height') !== -1) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return LineHeight;
- }(DropListMenu_1["default"]);
- exports["default"] = LineHeight;
- /***/ }),
- /* 360 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * @description 行高 菜单
- * @author lichunlin
- */
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var lineHeightList =
- /** @class */
- function () {
- function lineHeightList(editor, list) {
- var _this = this;
- this.itemList = [{
- $elem: dom_core_1["default"]("<span>" + editor.i18next.t('默认') + "</span>"),
- value: ''
- }];
- (0, _forEach["default"])(list).call(list, function (item) {
- _this.itemList.push({
- $elem: dom_core_1["default"]("<span>" + item + "</span>"),
- value: item
- });
- });
- }
- lineHeightList.prototype.getItemList = function () {
- return this.itemList;
- };
- return lineHeightList;
- }();
- exports["default"] = lineHeightList;
- /***/ }),
- /* 361 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 撤销
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var Undo =
- /** @class */
- function (_super) {
- __extends(Undo, _super);
- function Undo(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u6062\u590D\">\n <i class=\"w-e-icon-undo\"></i>\n </div>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 点击事件
- */
- Undo.prototype.clickHandler = function () {
- this.editor.history.revoke();
- };
- /**
- * 尝试修改菜单激活状态
- */
- Undo.prototype.tryChangeActive = function () {
- // 标准模式下才进行操作
- if (!this.editor.isCompatibleMode) {
- if (this.editor.history.size[0]) {
- this.active();
- } else {
- this.unActive();
- }
- }
- };
- return Undo;
- }(BtnMenu_1["default"]);
- exports["default"] = Undo;
- /***/ }),
- /* 362 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 重做
- * @author tonghan
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var Redo =
- /** @class */
- function (_super) {
- __extends(Redo, _super);
- function Redo(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u64A4\u9500\">\n <i class=\"w-e-icon-redo\"></i>\n </div>");
- _this = _super.call(this, $elem, editor) || this;
- return _this;
- }
- /**
- * 点击事件
- */
- Redo.prototype.clickHandler = function () {
- this.editor.history.restore();
- };
- /**
- * 尝试修改菜单激活状态
- */
- Redo.prototype.tryChangeActive = function () {
- // 标准模式下才进行操作
- if (!this.editor.isCompatibleMode) {
- if (this.editor.history.size[1]) {
- this.active();
- } else {
- this.unActive();
- }
- }
- };
- return Redo;
- }(BtnMenu_1["default"]);
- exports["default"] = Redo;
- /***/ }),
- /* 363 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 创建table
- * @author lichunlin
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var PanelMenu_1 = __importDefault(__webpack_require__(34));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var create_panel_conf_1 = __importDefault(__webpack_require__(364));
- var Panel_1 = __importDefault(__webpack_require__(31));
- var index_1 = __importDefault(__webpack_require__(368));
- var Table =
- /** @class */
- function (_super) {
- __extends(Table, _super);
- function Table(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="表格"><i class="w-e-icon-table2"></i></div>');
- _this = _super.call(this, $elem, editor) || this; // 绑定事件
- index_1["default"](editor);
- return _this;
- }
- /**
- * 菜单点击事件
- */
- Table.prototype.clickHandler = function () {
- this.createPanel();
- };
- /**
- * 创建 panel
- */
- Table.prototype.createPanel = function () {
- var conf = create_panel_conf_1["default"](this.editor);
- var panel = new Panel_1["default"](this, conf);
- panel.create();
- };
- /**
- * 尝试修改菜单 active 状态
- */
- Table.prototype.tryChangeActive = function () {};
- return Table;
- }(PanelMenu_1["default"]);
- exports["default"] = Table;
- /***/ }),
- /* 364 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description table 菜单 panel tab 配置
- * @author lichunlin
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- var dom_core_1 = __importDefault(__webpack_require__(2));
- __webpack_require__(365);
- var create_table_1 = __importDefault(__webpack_require__(367));
- function default_1(editor) {
- var createTable = new create_table_1["default"](editor); // panel 中需要用到的id
- var colId = util_1.getRandom('w-col-id');
- var rowId = util_1.getRandom('w-row-id');
- var insertBtnId = util_1.getRandom('btn-link');
- var i18nPrefix = 'menus.panelMenus.table.';
- var t = function t(text) {
- return editor.i18next.t(text);
- }; // tabs 配置 -----------------------------------------
- var tabsConf = [{
- title: t(i18nPrefix + "\u63D2\u5165\u8868\u683C"),
- 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>",
- events: [{
- selector: '#' + insertBtnId,
- type: 'click',
- fn: function fn() {
- var colValue = Number(dom_core_1["default"]('#' + colId).val());
- var rowValue = Number(dom_core_1["default"]('#' + rowId).val()); //校验是否传值
- if (colValue && rowValue) {
- createTable.createAction(rowValue, colValue);
- } // 返回 true 表示函数执行结束之后关闭 panel
- return true;
- }
- }]
- }]; // tabs end
- // 最终的配置 -----------------------------------------
- var conf = {
- width: 330,
- height: 0,
- tabs: []
- };
- conf.tabs.push(tabsConf[0]);
- return conf;
- }
- exports["default"] = default_1;
- /***/ }),
- /* 365 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(366);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 366 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- 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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 367 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 创建tabel
- * @author lichunlin
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var CreateTable =
- /** @class */
- function () {
- function CreateTable(editor) {
- this.editor = editor;
- }
- /**
- * 执行创建
- * @param rowValue 行数
- * @param colValue 列数
- */
- CreateTable.prototype.createAction = function (rowValue, colValue) {
- var editor = this.editor; //不允许在有序列表中添加table
- var $selectionElem = dom_core_1["default"](editor.selection.getSelectionContainerElem());
- var $ul = dom_core_1["default"]($selectionElem.elems[0]).parentUntil('UL', $selectionElem.elems[0]);
- var $ol = dom_core_1["default"]($selectionElem.elems[0]).parentUntil('OL', $selectionElem.elems[0]);
- if ($ul || $ol) {
- return;
- }
- var tableDom = this.createTableHtml(rowValue, colValue);
- editor.cmd["do"]('insertHTML', tableDom);
- };
- /**
- * 创建table、行、列
- * @param rowValue 行数
- * @param colValue 列数
- */
- CreateTable.prototype.createTableHtml = function (rowValue, colValue) {
- var rowStr = '';
- var colStr = '';
- for (var i = 0; i < rowValue; i++) {
- colStr = '';
- for (var j = 0; j < colValue; j++) {
- if (i === 0) {
- colStr = colStr + '<th></th>';
- } else {
- colStr = colStr + '<td></td>';
- }
- }
- rowStr = rowStr + '<tr>' + colStr + '</tr>';
- }
- var tableDom = "<table border=\"0\" width=\"100%\" cellpadding=\"0\" cellspacing=\"0\"><tbody>" + rowStr + '</tbody></table><p><br></p>';
- return tableDom;
- };
- return CreateTable;
- }();
- exports["default"] = CreateTable;
- /***/ }),
- /* 368 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 绑定点击事件
- * @author lichunlin
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var tooltip_event_1 = __importDefault(__webpack_require__(369));
- /**
- * 绑定事件
- * @param editor 编辑器实例
- */
- function bindEvent(editor) {
- //Tooltip
- tooltip_event_1["default"](editor);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 369 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description tooltip 事件
- * @author lichunlin
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Tooltip_1 = __importDefault(__webpack_require__(44)); //操作事件
- var operating_event_1 = __importDefault(__webpack_require__(370));
- var getNode_1 = __importDefault(__webpack_require__(371));
- /**
- * 生成 Tooltip 的显示隐藏函数
- */
- function createShowHideFn(editor) {
- var tooltip;
- /**
- * 显示 tooltip
- * @param table元素
- */
- function showTableTooltip($node) {
- var getnode = new getNode_1["default"](editor);
- var i18nPrefix = 'menus.panelMenus.table.';
- var t = function t(text, prefix) {
- if (prefix === void 0) {
- prefix = i18nPrefix;
- }
- return editor.i18next.t(prefix + text);
- };
- var conf = [{
- // $elem: $("<span class='w-e-icon-trash-o'></span>"),
- $elem: dom_core_1["default"]("<span>" + t('删除表格') + "</span>"),
- onClick: function onClick(editor, $node) {
- // 选中img元素
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- editor.cmd["do"]('insertHTML', '<p><br></p>'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + t('添加行') + "</span>"),
- onClick: function onClick(editor, $node) {
- // 禁止多选操作
- var isMore = isMoreRowAction(editor);
- if (isMore) {
- return true;
- } //当前元素
- var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
- var $currentRow = getnode.getRowNode(selectDom.elems[0]);
- if (!$currentRow) {
- return true;
- } //获取当前行的index
- var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow)); //生成要替换的html
- var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
- var newdom = getnode.getTableHtml(operating_event_1["default"].ProcessingRow(dom_core_1["default"](htmlStr), index).elems[0]); // 选中table
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- editor.cmd["do"]('insertHTML', newdom);
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + t('删除行') + "</span>"),
- onClick: function onClick(editor, $node) {
- // 禁止多选操作
- var isMore = isMoreRowAction(editor);
- if (isMore) {
- return true;
- } //当前元素
- var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
- var $currentRow = getnode.getRowNode(selectDom.elems[0]);
- if (!$currentRow) {
- return true;
- } //获取当前行的index
- var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow)); //生成要替换的html
- var htmlStr = getnode.getTableHtml($node.elems[0]); //获取新生成的table 判断是否是最后一行被删除 是 删除整个table
- var trLength = operating_event_1["default"].DeleteRow(dom_core_1["default"](htmlStr), index).elems[0].childNodes[0].childNodes.length; //生成新的table
- var newdom = ''; // 选中table
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- if (trLength === 0) {
- newdom = '<p><br></p>';
- } else {
- newdom = getnode.getTableHtml(operating_event_1["default"].DeleteRow(dom_core_1["default"](htmlStr), index).elems[0]);
- }
- editor.cmd["do"]('insertHTML', newdom);
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + t('添加列') + "</span>"),
- onClick: function onClick(editor, $node) {
- // 禁止多选操作
- var isMore = isMoreRowAction(editor);
- if (isMore) {
- return true;
- } //当前元素
- var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前列的index
- var index = getnode.getCurrentColIndex(selectDom.elems[0]); //生成要替换的html
- var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
- var newdom = getnode.getTableHtml(operating_event_1["default"].ProcessingCol(dom_core_1["default"](htmlStr), index).elems[0]); // 选中table
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- editor.cmd["do"]('insertHTML', newdom);
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + t('删除列') + "</span>"),
- onClick: function onClick(editor, $node) {
- // 禁止多选操作
- var isMore = isMoreRowAction(editor);
- if (isMore) {
- return true;
- } //当前元素
- var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前列的index
- var index = getnode.getCurrentColIndex(selectDom.elems[0]); //生成要替换的html
- var htmlStr = getnode.getTableHtml($node.elems[0]); //获取新生成的table 判断是否是最后一列被删除 是 删除整个table
- var tdLength = operating_event_1["default"].DeleteCol(dom_core_1["default"](htmlStr), index).elems[0].childNodes[0].childNodes[0].childNodes.length; //生成新的table
- var newdom = ''; // 选中table
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- if (tdLength === 1) {
- newdom = '<p><br></p>';
- } else {
- newdom = getnode.getTableHtml(operating_event_1["default"].DeleteCol(dom_core_1["default"](htmlStr), index).elems[0]);
- }
- editor.cmd["do"]('insertHTML', newdom);
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + t('设置表头') + "</span>"),
- onClick: function onClick(editor, $node) {
- // 禁止多选操作
- var isMore = isMoreRowAction(editor);
- if (isMore) {
- return true;
- } //当前元素
- var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
- var $currentRow = getnode.getRowNode(selectDom.elems[0]);
- if (!$currentRow) {
- return true;
- } //获取当前行的index
- var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow));
- if (index !== 0) {
- //控制在table的第一行
- index = 0;
- } //生成要替换的html
- var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
- var newdom = getnode.getTableHtml(operating_event_1["default"].setTheHeader(dom_core_1["default"](htmlStr), index, 'th').elems[0]); // 选中table
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- editor.cmd["do"]('insertHTML', newdom);
- return true;
- }
- }, {
- $elem: dom_core_1["default"]("<span>" + t('取消表头') + "</span>"),
- onClick: function onClick(editor, $node) {
- //当前元素
- var selectDom = dom_core_1["default"](editor.selection.getSelectionStartElem()); //当前行
- var $currentRow = getnode.getRowNode(selectDom.elems[0]);
- if (!$currentRow) {
- return true;
- } //获取当前行的index
- var index = Number(getnode.getCurrentRowIndex($node.elems[0], $currentRow));
- if (index !== 0) {
- //控制在table的第一行
- index = 0;
- } //生成要替换的html
- var htmlStr = getnode.getTableHtml($node.elems[0]); //生成新的table
- var newdom = getnode.getTableHtml(operating_event_1["default"].setTheHeader(dom_core_1["default"](htmlStr), index, 'td').elems[0]); // 选中table
- editor.selection.createRangeByElem($node);
- editor.selection.restoreSelection();
- editor.cmd["do"]('insertHTML', newdom);
- return true;
- }
- }];
- tooltip = new Tooltip_1["default"](editor, $node, conf);
- tooltip.create();
- }
- /**
- * 隐藏 tooltip
- */
- function hideTableTooltip() {
- // 移除 tooltip
- if (tooltip) {
- tooltip.remove();
- tooltip = null;
- }
- }
- return {
- showTableTooltip: showTableTooltip,
- hideTableTooltip: hideTableTooltip
- };
- }
- /**
- * 判断是否是多行
- */
- function isMoreRowAction(editor) {
- var $startElem = editor.selection.getSelectionStartElem();
- var $endElem = editor.selection.getSelectionEndElem();
- if (($startElem === null || $startElem === void 0 ? void 0 : $startElem.elems[0]) !== ($endElem === null || $endElem === void 0 ? void 0 : $endElem.elems[0])) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * 绑定 tooltip 事件
- * @param editor 编辑器实例
- */
- function bindTooltipEvent(editor) {
- var _a = createShowHideFn(editor),
- showTableTooltip = _a.showTableTooltip,
- hideTableTooltip = _a.hideTableTooltip; // 点击table元素是,显示 tooltip
- editor.txt.eventHooks.tableClickEvents.push(showTableTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
- editor.txt.eventHooks.clickEvents.push(hideTableTooltip);
- editor.txt.eventHooks.keyupEvents.push(hideTableTooltip);
- editor.txt.eventHooks.toolbarClickEvents.push(hideTableTooltip);
- editor.txt.eventHooks.menuClickEvents.push(hideTableTooltip);
- editor.txt.eventHooks.textScrollEvents.push(hideTableTooltip);
- }
- exports["default"] = bindTooltipEvent;
- /***/ }),
- /* 370 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _splice = _interopRequireDefault(__webpack_require__(90));
- var _slice = _interopRequireDefault(__webpack_require__(43));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * 处理新添加行
- * @param $node 整个table
- * @param _index 行的inde
- */
- function ProcessingRow($node, _index) {
- //执行获取tbody节点
- var $dom = generateDomAction($node); //取出所有的行
- var domArray = (0, _slice["default"])(Array.prototype).apply($dom.childNodes); //列的数量
- var childNodesLenght = domArray[0].childNodes.length; //创建新tr
- var tr = document.createElement('tr');
- for (var i = 0; i < childNodesLenght; i++) {
- var td = document.createElement('td');
- tr.appendChild(td);
- } //插入集合中
- (0, _splice["default"])(domArray).call(domArray, _index + 1, 0, tr); //移除、新增节点事件
- removeAndInsertAction($dom, domArray);
- return dom_core_1["default"]($dom.parentNode);
- }
- /**
- * 处理新添加列
- * @param $node 整个table
- * @param _index 列的inde
- */
- function ProcessingCol($node, _index) {
- //执行获取tbody节点
- var $dom = generateDomAction($node); //取出所有的行
- var domArray = (0, _slice["default"])(Array.prototype).apply($dom.childNodes);
- var _loop_1 = function _loop_1(i) {
- var _context;
- var cArray = []; //取出所有的列
- (0, _forEach["default"])(_context = domArray[i].childNodes).call(_context, function (item) {
- cArray.push(item);
- }); //移除行的旧的子节点
- while (domArray[i].childNodes.length !== 0) {
- domArray[i].removeChild(domArray[i].childNodes[0]);
- } //列分th td
- var td = dom_core_1["default"](cArray[0]).getNodeName() !== 'TH' ? document.createElement('td') : document.createElement('th'); // let td = document.createElement('td')
- (0, _splice["default"])(cArray).call(cArray, _index + 1, 0, td); //插入新的子节点
- for (var j = 0; j < cArray.length; j++) {
- domArray[i].appendChild(cArray[j]);
- }
- }; //创建td
- for (var i = 0; i < domArray.length; i++) {
- _loop_1(i);
- } //移除、新增节点事件
- removeAndInsertAction($dom, domArray);
- return dom_core_1["default"]($dom.parentNode);
- }
- /**
- * 处理删除行
- * @param $node 整个table
- * @param _index 行的inde
- */
- function DeleteRow($node, _index) {
- //执行获取tbody节点
- var $dom = generateDomAction($node); //取出所有的行
- var domArray = (0, _slice["default"])(Array.prototype).apply($dom.childNodes); //删除行
- (0, _splice["default"])(domArray).call(domArray, _index, 1); //移除、新增节点事件
- removeAndInsertAction($dom, domArray);
- return dom_core_1["default"]($dom.parentNode);
- }
- /**
- * 处理删除列
- * @param $node
- * @param _index
- */
- function DeleteCol($node, _index) {
- //执行获取tbody节点
- var $dom = generateDomAction($node); //取出所有的行
- var domArray = (0, _slice["default"])(Array.prototype).apply($dom.childNodes);
- var _loop_2 = function _loop_2(i) {
- var _context2;
- var cArray = []; //取出所有的列
- (0, _forEach["default"])(_context2 = domArray[i].childNodes).call(_context2, function (item) {
- cArray.push(item);
- }); //移除行的旧的子节点
- while (domArray[i].childNodes.length !== 0) {
- domArray[i].removeChild(domArray[i].childNodes[0]);
- }
- (0, _splice["default"])(cArray).call(cArray, _index, 1); //插入新的子节点
- for (var j = 0; j < cArray.length; j++) {
- domArray[i].appendChild(cArray[j]);
- }
- }; //创建td
- for (var i = 0; i < domArray.length; i++) {
- _loop_2(i);
- } //移除、新增节点事件
- removeAndInsertAction($dom, domArray);
- return dom_core_1["default"]($dom.parentNode);
- }
- /**
- * 处理设置/取消表头
- * @param $node
- * @param _index
- * @type 替换的列 th 还是td
- */
- function setTheHeader($node, _index, type) {
- //执行获取tbody节点
- var $dom = generateDomAction($node); //取出所有的行
- var domArray = (0, _slice["default"])(Array.prototype).apply($dom.childNodes); //列的数量
- var childNodesLenght = domArray[_index].childNodes; //创建新tr
- var tr = document.createElement('tr');
- var _loop_3 = function _loop_3(i) {
- var _context3;
- //替换td为th
- var th = document.createElement(type);
- (0, _forEach["default"])(_context3 = childNodesLenght[i].childNodes).call(_context3, function (item) {
- th.appendChild(item);
- });
- tr.appendChild(th);
- };
- for (var i = 0; i < childNodesLenght.length; i++) {
- _loop_3(i);
- } //插入集合中
- (0, _splice["default"])(domArray).call(domArray, _index, 1, tr); //移除、新增节点事件
- removeAndInsertAction($dom, domArray);
- return dom_core_1["default"]($dom.parentNode);
- }
- /**
- * 封装移除、新增节点事件
- * @param $dom tbody节点
- * @param domArray 所有的行
- */
- function removeAndInsertAction($dom, domArray) {
- //移除所有的旧的子节点
- while ($dom.childNodes.length !== 0) {
- $dom.removeChild($dom.childNodes[0]);
- } //插入新的子节点
- for (var i = 0; i < domArray.length; i++) {
- $dom.appendChild(domArray[i]);
- }
- }
- /**
- * 封装判断是否tbody节点
- * 粘贴的table 第一个节点是<colgroup> 最后的节点<tbody>
- * @param dom
- */
- function generateDomAction($node) {
- var $dom = $node.elems[0].childNodes[0];
- if ($dom.nodeName === 'COLGROUP') {
- $dom = $node.elems[0].childNodes[$node.elems[0].childNodes.length - 1];
- }
- return $dom;
- }
- exports["default"] = {
- ProcessingRow: ProcessingRow,
- ProcessingCol: ProcessingCol,
- DeleteRow: DeleteRow,
- DeleteCol: DeleteCol,
- setTheHeader: setTheHeader
- };
- /***/ }),
- /* 371 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 获取dom节点
- * @author lichunlin
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var getNode =
- /** @class */
- function () {
- function getNode(editor) {
- this.editor = editor;
- }
- /**
- * 获取焦点所在行
- * @param $node 当前table
- */
- getNode.prototype.getRowNode = function ($node) {
- var _a;
- var DOM = dom_core_1["default"]($node).elems[0];
- if (!DOM.parentNode) {
- return DOM;
- }
- DOM = (_a = dom_core_1["default"](DOM).parentUntil('TR', DOM)) === null || _a === void 0 ? void 0 : _a.elems[0];
- return DOM;
- };
- /**
- * 获取当前行的下标
- * @param $node 当前table
- * @param $dmo 当前行节点
- */
- getNode.prototype.getCurrentRowIndex = function ($node, $dom) {
- var _context;
- var _index = 0;
- var $nodeChild = $node.childNodes[0]; //粘贴的table 最后一个节点才是tbody
- if ($nodeChild.nodeName === 'COLGROUP') {
- $nodeChild = $node.childNodes[$node.childNodes.length - 1];
- }
- (0, _forEach["default"])(_context = $nodeChild.childNodes).call(_context, function (item, index) {
- item === $dom ? _index = index : '';
- });
- return _index;
- };
- /**
- * 获取当前列的下标
- * @param $node 当前点击元素
- */
- getNode.prototype.getCurrentColIndex = function ($node) {
- var _context2;
- var _a; //当前行
- var _index = 0; //获取当前列 td或th
- 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];
- var colDom = dom_core_1["default"](rowDom).parent();
- (0, _forEach["default"])(_context2 = colDom.elems[0].childNodes).call(_context2, function (item, index) {
- item === rowDom ? _index = index : '';
- });
- return _index;
- };
- /**
- * 返回元素html字符串
- * @param $node
- */
- getNode.prototype.getTableHtml = function ($node) {
- var htmlStr = "<table border=\"0\" width=\"100%\" cellpadding=\"0\" cellspacing=\"0\">" + dom_core_1["default"]($node).html() + "</table>";
- return htmlStr;
- };
- return getNode;
- }();
- exports["default"] = getNode;
- /***/ }),
- /* 372 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 代码 菜单
- * @author lkw
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _map = _interopRequireDefault(__webpack_require__(29));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.formatCodeHtml = void 0;
- var PanelMenu_1 = __importDefault(__webpack_require__(34));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(7);
- var create_panel_conf_1 = __importDefault(__webpack_require__(373));
- var is_active_1 = __importDefault(__webpack_require__(127));
- var Panel_1 = __importDefault(__webpack_require__(31));
- var index_1 = __importDefault(__webpack_require__(374));
- function formatCodeHtml(editor, html) {
- if (!html) return html;
- html = deleteHighlightCode(html);
- html = formatEnterCode(html);
- html = util_1.replaceSpecialSymbol(html);
- return html; // 格式化换换所产生的code标签
- function formatEnterCode(html) {
- var preArr = html.match(/<pre[\s|\S]+?\/pre>/g);
- if (preArr === null) return html;
- (0, _map["default"])(preArr).call(preArr, function (item) {
- //将连续的code标签换为\n换行
- html = html.replace(item, item.replace(/<\/code><code>/g, '\n').replace(/<br>/g, ''));
- });
- return html;
- } // highlight格式化方法
- function deleteHighlightCode(html) {
- var _context;
- // 获取所有hljs文本
- var m = html.match(/<span\sclass="hljs[\s|\S]+?\/span>/gm); // 没有代码渲染文本则退出
- // @ts-ignore
- if (!m || !m.length) return html; // 获取替换文本
- var r = (0, _map["default"])(_context = util_1.deepClone(m)).call(_context, function (i) {
- i = i.replace(/<span\sclass="hljs[^>]+>/, '');
- return i.replace(/<\/span>/, '');
- }); // @ts-ignore
- for (var i = 0; i < m.length; i++) {
- html = html.replace(m[i], r[i]);
- }
- return deleteHighlightCode(html);
- }
- }
- exports.formatCodeHtml = formatCodeHtml;
- var Code =
- /** @class */
- function (_super) {
- __extends(Code, _super);
- function Code(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="代码"><i class="w-e-icon-terminal"></i></div>');
- _this = _super.call(this, $elem, editor) || this; // 绑定事件,如点击链接时,可以查看链接
- index_1["default"](editor);
- return _this;
- }
- /**
- * 插入行内代码
- * @param text
- * @return null
- */
- Code.prototype.insertLineCode = function (text) {
- var editor = this.editor; // 行内代码处理
- var $code = dom_core_1["default"]("<code>" + text + "</code>");
- editor.cmd["do"]('insertElem', $code);
- editor.selection.createRangeByElem($code, false);
- editor.selection.restoreSelection();
- };
- /**
- * 菜单点击事件
- */
- Code.prototype.clickHandler = function () {
- var editor = this.editor;
- var selectionText = editor.selection.getSelectionText();
- if (this.isActive) {
- return;
- } else {
- // 菜单未被激活,说明选区不在链接里
- if (editor.selection.isSelectionEmpty()) {
- // 选区是空的,未选中内容
- this.createPanel('', '');
- } else {
- // 行内代码处理 选中了非代码内容
- this.insertLineCode(selectionText);
- }
- }
- };
- /**
- * 创建 panel
- * @param text 代码文本
- * @param languageType 代码类型
- */
- Code.prototype.createPanel = function (text, languageType) {
- var conf = create_panel_conf_1["default"](this.editor, text, languageType);
- var panel = new Panel_1["default"](this, conf);
- panel.create();
- };
- /**
- * 尝试修改菜单 active 状态
- */
- Code.prototype.tryChangeActive = function () {
- var editor = this.editor;
- if (is_active_1["default"](editor)) {
- this.active();
- } else {
- this.unActive();
- }
- };
- return Code;
- }(PanelMenu_1["default"]);
- exports["default"] = Code;
- /***/ }),
- /* 373 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description code 菜单 panel tab 配置
- * @author lkw
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _map = _interopRequireDefault(__webpack_require__(29));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var util_1 = __webpack_require__(7);
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var is_active_1 = __importDefault(__webpack_require__(127));
- function default_1(editor, text, languageType) {
- var _context;
- // panel 中需要用到的id
- var inputIFrameId = util_1.getRandom('input-iframe');
- var languageId = util_1.getRandom('select');
- var btnOkId = util_1.getRandom('btn-ok');
- /**
- * 插入链接
- * @param text 文字
- * @param code 链接
- */
- function insertCode(text) {
- // 选区处于链接中,则选中整个菜单,再执行 insertHTML
- var active = is_active_1["default"](editor);
- if (active) {
- selectCodeElem();
- }
- editor.cmd["do"]('insertHTML', text);
- var $code = editor.selection.getSelectionStartElem();
- var $codeElem = $code === null || $code === void 0 ? void 0 : $code.getNodeTop(editor); // 通过dom操作添加换行标签
- // @ts-ignore
- dom_core_1["default"]('<p><br></p>').insertAfter($codeElem);
- }
- /**
- * 选中整个链接元素
- */
- function selectCodeElem() {
- if (!is_active_1["default"](editor)) return; // eslint-disable-next-line @typescript-eslint/no-unused-vars
- var $selectedCode;
- var $code = editor.selection.getSelectionStartElem();
- var $codeElem = $code === null || $code === void 0 ? void 0 : $code.getNodeTop(editor);
- if (!$codeElem) return;
- editor.selection.createRangeByElem($codeElem);
- editor.selection.restoreSelection();
- $selectedCode = $codeElem; // 赋值给函数内全局变量
- }
- var t = function t(text) {
- return editor.i18next.t(text);
- }; // @ts-ignore
- var conf = {
- width: 500,
- height: 0,
- // panel 中可包含多个 tab
- tabs: [{
- // tab 的标题
- title: t('menus.panelMenus.code.插入代码'),
- // 模板
- tpl: "<div>\n <select name=\"\" id=\"" + languageId + "\">\n " + (0, _map["default"])(_context = editor.config.languageType).call(_context, function (language) {
- return '<option ' + (languageType == language ? 'selected' : '') + ' value ="' + language + '">' + language + '</option>';
- }) + "\n </select>\n <textarea id=\"" + inputIFrameId + "\" type=\"text\" class=\"wang-code-textarea\" placeholder=\"\" style=\"height: 160px\">" + text.replace(/"/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>",
- // 事件绑定
- events: [// 插入链接
- {
- selector: '#' + btnOkId,
- type: 'click',
- fn: function fn() {
- var formatCode, codeDom;
- var $code = document.getElementById(inputIFrameId);
- var $select = dom_core_1["default"]('#' + languageId);
- var languageType = $select.val(); // @ts-ignore
- var code = $code.value; // 高亮渲染
- if (editor.highlight) {
- formatCode = editor.highlight.highlightAuto(code).value;
- } else {
- formatCode = "<xmp>" + code + "</xmp>";
- } // 代码为空,则不插入
- if (!code) return; //增加标签
- if (is_active_1["default"](editor)) {
- return false;
- } else {
- //增加pre标签
- codeDom = "<pre type=\"" + languageType + "\"><code>" + formatCode + "</code></pre>"; // @ts-ignore
- insertCode(codeDom);
- } // 返回 true,表示该事件执行完之后,panel 要关闭。否则 panel 不会关闭
- return true;
- }
- }]
- }]
- };
- return conf;
- }
- exports["default"] = default_1;
- /***/ }),
- /* 374 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 绑定链接元素的事件,入口
- * @author lkw
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var tooltip_event_1 = __importDefault(__webpack_require__(375));
- /**
- * 绑定事件
- * @param editor 编辑器实例
- */
- function bindEvent(editor) {
- // tooltip 事件
- tooltip_event_1["default"](editor);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 375 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description tooltip 事件
- * @author lkw
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.createShowHideFn = void 0;
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Tooltip_1 = __importDefault(__webpack_require__(44));
- /**
- * 生成 Tooltip 的显示隐藏函数
- */
- function createShowHideFn(editor) {
- var tooltip;
- /**
- * 显示 tooltip
- * @param $code 链接元素
- */
- function showCodeTooltip($code) {
- var i18nPrefix = 'menus.panelMenus.code.';
- var t = function t(text, prefix) {
- if (prefix === void 0) {
- prefix = i18nPrefix;
- }
- return editor.i18next.t(prefix + text);
- };
- var conf = [{
- $elem: dom_core_1["default"]("<span>" + t('删除代码') + "</span>"),
- onClick: function onClick(editor, $code) {
- //dom操作删除
- $code.remove(); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }]; // 创建 tooltip
- tooltip = new Tooltip_1["default"](editor, $code, conf);
- tooltip.create();
- }
- /**
- * 隐藏 tooltip
- */
- function hideCodeTooltip() {
- // 移除 tooltip
- if (tooltip) {
- tooltip.remove();
- tooltip = null;
- }
- }
- return {
- showCodeTooltip: showCodeTooltip,
- hideCodeTooltip: hideCodeTooltip
- };
- }
- exports.createShowHideFn = createShowHideFn;
- /**
- * preEnterListener是为了统一浏览器 在pre标签内的enter行为而进行的监听
- * 目前并没有使用, 但是在未来处理与Firefox和ie的兼容性时需要用到 暂且放置
- * pre标签内的回车监听
- * @param e
- * @param editor
- */
- /* istanbul ignore next */
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
- function preEnterListener(e, editor) {
- // 获取当前标签元素
- var $selectionElem = editor.selection.getSelectionContainerElem(); // 获取当前节点最顶级标签元素
- var $topElem = $selectionElem === null || $selectionElem === void 0 ? void 0 : $selectionElem.getNodeTop(editor); // 获取顶级节点节点名
- var topNodeName = $topElem === null || $topElem === void 0 ? void 0 : $topElem.getNodeName(); // 非pre标签退出
- if (topNodeName !== 'PRE') return; // 取消默认行为
- e.preventDefault(); // 执行换行
- editor.cmd["do"]('insertHTML', '\n\r');
- }
- /**
- * 绑定 tooltip 事件
- * @param editor 编辑器实例
- */
- function bindTooltipEvent(editor) {
- var _a = createShowHideFn(editor),
- showCodeTooltip = _a.showCodeTooltip,
- hideCodeTooltip = _a.hideCodeTooltip; // 点击代码元素时,显示 tooltip
- editor.txt.eventHooks.codeClickEvents.push(showCodeTooltip); // 点击其他地方,或者滚动时,隐藏 tooltip
- editor.txt.eventHooks.clickEvents.push(hideCodeTooltip);
- editor.txt.eventHooks.toolbarClickEvents.push(hideCodeTooltip);
- editor.txt.eventHooks.menuClickEvents.push(hideCodeTooltip);
- editor.txt.eventHooks.textScrollEvents.push(hideCodeTooltip);
- }
- exports["default"] = bindTooltipEvent;
- /***/ }),
- /* 376 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * @description 分割线
- * @author wangqiaoling
- */
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var index_1 = __importDefault(__webpack_require__(377));
- var splitLine =
- /** @class */
- function (_super) {
- __extends(splitLine, _super);
- function splitLine(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]('<div class="w-e-menu" data-title="分割线"><i class="w-e-icon-split-line"></i></div>');
- _this = _super.call(this, $elem, editor) || this; // 绑定事件
- index_1["default"](editor);
- return _this;
- }
- /**
- * 菜单点击事件
- */
- splitLine.prototype.clickHandler = function () {
- var editor = this.editor;
- var range = editor.selection.getRange();
- var $selectionElem = editor.selection.getSelectionContainerElem();
- if (!$selectionElem) return;
- var $DomElement = dom_core_1["default"]($selectionElem.elems[0]);
- var $tableDOM = $DomElement.parentUntil('TABLE', $selectionElem.elems[0]);
- var $imgDOM = $DomElement.children(); // 禁止在代码块中添加分割线
- if ($DomElement.getNodeName() === 'CODE') return; // 禁止在表格中添加分割线
- if ($tableDOM && dom_core_1["default"]($tableDOM.elems[0]).getNodeName() === 'TABLE') return; // 禁止在图片处添加分割线
- if ($imgDOM && $imgDOM.length !== 0 && dom_core_1["default"]($imgDOM.elems[0]).getNodeName() === 'IMG' && !(range === null || range === void 0 ? void 0 : range.collapsed) // 处理光标在 img 后面的情况
- ) {
- return;
- }
- this.createSplitLine();
- };
- /**
- * 创建 splitLine
- */
- splitLine.prototype.createSplitLine = function () {
- var splitLineDOM = '<hr/>';
- this.editor.cmd["do"]('insertHTML', splitLineDOM);
- };
- /**
- * 尝试修改菜单激活状态
- */
- splitLine.prototype.tryChangeActive = function () {};
- return splitLine;
- }(BtnMenu_1["default"]);
- exports["default"] = splitLine;
- /***/ }),
- /* 377 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var tooltip_event_1 = __importDefault(__webpack_require__(378));
- /**
- * 绑定事件
- * @param editor 编辑器实例
- */
- function bindEvent(editor) {
- // 分割线的 tooltip 事件
- tooltip_event_1["default"](editor);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 378 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * @description tooltip 事件
- * @author wangqiaoling
- */
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var Tooltip_1 = __importDefault(__webpack_require__(44));
- /**
- * 生成 Tooltip 的显示隐藏函数
- */
- function createShowHideFn(editor) {
- var tooltip;
- /**
- * 显示分割线的 tooltip
- * @param $splitLine 分割线元素
- */
- function showSplitLineTooltip($splitLine) {
- // 定义 splitLine tooltip 配置
- var conf = [{
- $elem: dom_core_1["default"]("<span>" + editor.i18next.t('menus.panelMenus.删除') + "</span>"),
- onClick: function onClick(editor, $splitLine) {
- // 选中 分割线 元素
- editor.selection.createRangeByElem($splitLine);
- editor.selection.restoreSelection();
- editor.cmd["do"]('delete'); // 返回 true,表示执行完之后,隐藏 tooltip。否则不隐藏。
- return true;
- }
- }]; // 实例化 tooltip
- tooltip = new Tooltip_1["default"](editor, $splitLine, conf); // 创建 tooltip
- tooltip.create();
- }
- /**
- * 隐藏分割线的 tooltip
- */
- function hideSplitLineTooltip() {
- if (tooltip) {
- tooltip.remove();
- tooltip = null;
- }
- }
- return {
- showSplitLineTooltip: showSplitLineTooltip,
- hideSplitLineTooltip: hideSplitLineTooltip
- };
- }
- function bindTooltipEvent(editor) {
- var _a = createShowHideFn(editor),
- showSplitLineTooltip = _a.showSplitLineTooltip,
- hideSplitLineTooltip = _a.hideSplitLineTooltip; // 点击分割线时,显示 tooltip
- editor.txt.eventHooks.splitLineEvents.push(showSplitLineTooltip); // 点击其他地方(工具栏、滚动、keyup)时,隐藏 tooltip
- editor.txt.eventHooks.clickEvents.push(hideSplitLineTooltip);
- editor.txt.eventHooks.keyupEvents.push(hideSplitLineTooltip);
- editor.txt.eventHooks.toolbarClickEvents.push(hideSplitLineTooltip);
- editor.txt.eventHooks.menuClickEvents.push(hideSplitLineTooltip);
- editor.txt.eventHooks.textScrollEvents.push(hideSplitLineTooltip);
- }
- exports["default"] = bindTooltipEvent;
- /***/ }),
- /* 379 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var BtnMenu_1 = __importDefault(__webpack_require__(22));
- var util_1 = __webpack_require__(98);
- var bind_event_1 = __importDefault(__webpack_require__(385));
- var todo_1 = __importDefault(__webpack_require__(128));
- var Todo =
- /** @class */
- function (_super) {
- __extends(Todo, _super);
- function Todo(editor) {
- var _this = this;
- var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u4EE3\u529E\u4E8B\u9879\">\n <i class=\"w-e-icon-checkbox-checked\"></i>\n </div>");
- _this = _super.call(this, $elem, editor) || this;
- bind_event_1["default"](editor);
- return _this;
- }
- /**
- * 点击事件
- */
- Todo.prototype.clickHandler = function () {
- var editor = this.editor;
- if (!util_1.isAllTodo(editor)) {
- // 设置todolist
- this.setTodo();
- } else {
- // 取消设置todolist
- this.cancelTodo();
- this.tryChangeActive();
- }
- };
- Todo.prototype.tryChangeActive = function () {
- if (util_1.isAllTodo(this.editor)) {
- this.active();
- } else {
- this.unActive();
- }
- };
- /**
- * 设置todo
- */
- Todo.prototype.setTodo = function () {
- var editor = this.editor;
- var topNodeElem = editor.selection.getSelectionRangeTopNodes(editor);
- (0, _forEach["default"])(topNodeElem).call(topNodeElem, function ($node) {
- var _a;
- var nodeName = $node === null || $node === void 0 ? void 0 : $node.getNodeName();
- if (nodeName === 'P') {
- var todo = todo_1["default"]($node);
- var todoNode = todo.getTodo();
- var child = (_a = todoNode.children()) === null || _a === void 0 ? void 0 : _a.getNode();
- todoNode.insertAfter($node);
- editor.selection.moveCursor(child);
- $node.remove();
- }
- });
- this.tryChangeActive();
- };
- /**
- * 取消设置todo
- */
- Todo.prototype.cancelTodo = function () {
- var editor = this.editor;
- var $topNodeElems = editor.selection.getSelectionRangeTopNodes(editor);
- (0, _forEach["default"])($topNodeElems).call($topNodeElems, function ($topNodeElem) {
- var _a, _b, _c;
- var content = (_b = (_a = $topNodeElem.childNodes()) === null || _a === void 0 ? void 0 : _a.childNodes()) === null || _b === void 0 ? void 0 : _b.clone(true);
- var $p = dom_core_1["default"]("<p></p>");
- $p.append(content);
- $p.insertAfter($topNodeElem); // 移除input
- (_c = $p.childNodes()) === null || _c === void 0 ? void 0 : _c.get(0).remove();
- editor.selection.moveCursor($p.getNode());
- $topNodeElem.remove();
- });
- };
- return Todo;
- }(BtnMenu_1["default"]);
- exports["default"] = Todo;
- /***/ }),
- /* 380 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(381);
- /***/ }),
- /* 381 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(382);
- module.exports = parent;
- /***/ }),
- /* 382 */
- /***/ (function(module, exports, __webpack_require__) {
- var every = __webpack_require__(383);
- var ArrayPrototype = Array.prototype;
- module.exports = function (it) {
- var own = it.every;
- return it === ArrayPrototype || (it instanceof Array && own === ArrayPrototype.every) ? every : own;
- };
- /***/ }),
- /* 383 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(384);
- var entryVirtual = __webpack_require__(16);
- module.exports = entryVirtual('Array').every;
- /***/ }),
- /* 384 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var $ = __webpack_require__(4);
- var $every = __webpack_require__(33).every;
- var arrayMethodIsStrict = __webpack_require__(87);
- var arrayMethodUsesToLength = __webpack_require__(25);
- var STRICT_METHOD = arrayMethodIsStrict('every');
- var USES_TO_LENGTH = arrayMethodUsesToLength('every');
- // `Array.prototype.every` method
- // https://tc39.github.io/ecma262/#sec-array.prototype.every
- $({ target: 'Array', proto: true, forced: !STRICT_METHOD || !USES_TO_LENGTH }, {
- every: function every(callbackfn /* , thisArg */) {
- return $every(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
- }
- });
- /***/ }),
- /* 385 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(98);
- var todo_1 = __importDefault(__webpack_require__(128));
- var util_2 = __webpack_require__(98);
- /**
- * todolist 内部逻辑
- * @param editor
- */
- function bindEvent(editor) {
- /**
- * todo的自定义回车事件
- * @param e 事件属性
- */
- function todoEnter(e) {
- var _a, _b; // 判断是否为todo节点
- if (util_1.isAllTodo(editor)) {
- e.preventDefault();
- var selection = editor.selection;
- var $topSelectElem = selection.getSelectionRangeTopNodes(editor)[0];
- var $li = (_a = $topSelectElem.childNodes()) === null || _a === void 0 ? void 0 : _a.get(0);
- var selectionNode = (_b = window.getSelection()) === null || _b === void 0 ? void 0 : _b.anchorNode;
- var range = selection.getRange();
- if (!(range === null || range === void 0 ? void 0 : range.collapsed)) {
- var rangeChildNodes = range === null || range === void 0 ? void 0 : range.commonAncestorContainer.childNodes;
- var startContainer_1 = range === null || range === void 0 ? void 0 : range.startContainer;
- var endContainer_1 = range === null || range === void 0 ? void 0 : range.endContainer;
- var startPos = range === null || range === void 0 ? void 0 : range.startOffset;
- var endPos = range === null || range === void 0 ? void 0 : range.endOffset;
- var startElemIndex_1 = 0;
- var endElemIndex_1 = 0;
- var delList_1 = []; // 找出startContainer和endContainer在rangeChildNodes中的位置
- rangeChildNodes === null || rangeChildNodes === void 0 ? void 0 : (0, _forEach["default"])(rangeChildNodes).call(rangeChildNodes, function (v, i) {
- if (v.contains(startContainer_1)) startElemIndex_1 = i;
- if (v.contains(endContainer_1)) endElemIndex_1 = i;
- }); // 删除两个容器间的内容
- if (endElemIndex_1 - startElemIndex_1 > 1) {
- rangeChildNodes === null || rangeChildNodes === void 0 ? void 0 : (0, _forEach["default"])(rangeChildNodes).call(rangeChildNodes, function (v, i) {
- if (i <= startElemIndex_1) return;
- if (i >= endElemIndex_1) return;
- delList_1.push(v);
- });
- (0, _forEach["default"])(delList_1).call(delList_1, function (v) {
- v.remove();
- });
- } // 删除两个容器里拖蓝的内容
- util_2.dealTextNode(startContainer_1, startPos);
- util_2.dealTextNode(endContainer_1, endPos, false);
- editor.selection.moveCursor(endContainer_1, 0);
- } // 回车时内容为空时,删去此行
- if ($topSelectElem.text() === '') {
- var $p = dom_core_1["default"]("<p><br></p>");
- $p.insertAfter($topSelectElem);
- selection.moveCursor($p.getNode());
- $topSelectElem.remove();
- return;
- }
- var pos = selection.getCursorPos();
- var CursorNextNode = util_1.getCursorNextNode($li === null || $li === void 0 ? void 0 : $li.getNode(), selectionNode, pos);
- var todo = todo_1["default"](dom_core_1["default"](CursorNextNode));
- var $inputcontainer = todo.getInputContainer();
- var todoLiElem = $inputcontainer.parent().getNode();
- var $newTodo = todo.getTodo();
- var contentSection = $inputcontainer.getNode().nextSibling; // 处理光标在最前面时回车input不显示的问题
- if (($li === null || $li === void 0 ? void 0 : $li.text()) === '') {
- $li === null || $li === void 0 ? void 0 : $li.append(dom_core_1["default"]("<br>"));
- }
- $newTodo.insertAfter($topSelectElem); // 处理在google中光标在最后面的,input不显示的问题(必须插入之后移动光标)
- if (!contentSection || (contentSection === null || contentSection === void 0 ? void 0 : contentSection.textContent) === '') {
- // 防止多个br出现的情况
- if ((contentSection === null || contentSection === void 0 ? void 0 : contentSection.nodeName) !== 'BR') {
- var $br = dom_core_1["default"]("<br>");
- $br.insertAfter($inputcontainer);
- }
- selection.moveCursor(todoLiElem, 1);
- } else {
- selection.moveCursor(todoLiElem);
- }
- }
- }
- /**
- * 自定义删除事件,用来处理光标在最前面删除input产生的问题
- */
- function delDown(e) {
- var _a, _b;
- if (util_1.isAllTodo(editor)) {
- var selection = editor.selection;
- var $topSelectElem = selection.getSelectionRangeTopNodes(editor)[0];
- var $li = (_a = $topSelectElem.childNodes()) === null || _a === void 0 ? void 0 : _a.getNode();
- var $p = dom_core_1["default"]("<p></p>");
- var p_1 = $p.getNode();
- var selectionNode = (_b = window.getSelection()) === null || _b === void 0 ? void 0 : _b.anchorNode;
- var pos = selection.getCursorPos();
- var prevNode = selectionNode.previousSibling; // 处理内容为空的情况
- if ($topSelectElem.text() === '') {
- e.preventDefault();
- var $newP = dom_core_1["default"]("<p><br></p>");
- $newP.insertAfter($topSelectElem);
- $topSelectElem.remove();
- selection.moveCursor($newP.getNode(), 0);
- return;
- } // 处理有内容时,光标在最前面的情况
- if ((prevNode === null || prevNode === void 0 ? void 0 : prevNode.nodeName) === 'SPAN' && prevNode.childNodes[0].nodeName === 'INPUT' && pos === 0) {
- var _context;
- e.preventDefault();
- $li === null || $li === void 0 ? void 0 : (0, _forEach["default"])(_context = $li.childNodes).call(_context, function (v, index) {
- if (index === 0) return;
- p_1.appendChild(v.cloneNode(true));
- });
- $p.insertAfter($topSelectElem);
- $topSelectElem.remove();
- }
- }
- }
- /**
- * 自定义删除键up事件
- */
- function deleteUp() {
- var selection = editor.selection;
- var $topSelectElem = selection.getSelectionRangeTopNodes(editor)[0];
- if (util_2.isTodo($topSelectElem)) {
- if ($topSelectElem.text() === '') {
- dom_core_1["default"]("<p><br></p>").insertAfter($topSelectElem);
- $topSelectElem.remove();
- }
- }
- }
- editor.txt.eventHooks.enterDownEvents.push(todoEnter);
- editor.txt.eventHooks.deleteUpEvents.push(deleteUp);
- editor.txt.eventHooks.deleteDownEvents.push(delDown);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 386 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 初始化编辑器 DOM 结构
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(7);
- var styleSettings = {
- border: '1px solid #c9d8db',
- toolbarBgColor: '#FFF',
- toolbarBottomBorder: '1px solid #EEE'
- };
- function default_1(editor) {
- var toolbarSelector = editor.toolbarSelector;
- var $toolbarSelector = dom_core_1["default"](toolbarSelector);
- var textSelector = editor.textSelector;
- var config = editor.config;
- var height = config.height;
- var i18next = editor.i18next;
- var $toolbarElem;
- var $textContainerElem;
- var $textElem;
- var $children;
- var toolbarElemId;
- if (textSelector == null) {
- // 只有 toolbarSelector ,即是容器的选择器或元素,toolbar 和 text 的元素自行创建
- $toolbarElem = dom_core_1["default"]('<div></div>');
- $textContainerElem = dom_core_1["default"]('<div></div>'); // 将编辑器区域原有的内容,暂存起来
- $children = $toolbarSelector.children(); // 添加到 DOM 结构中
- $toolbarSelector.append($toolbarElem).append($textContainerElem); // 自行创建的,需要配置默认的样式
- $toolbarElem.css('background-color', styleSettings.toolbarBgColor).css('border', styleSettings.border).css('border-bottom', styleSettings.toolbarBottomBorder);
- $textContainerElem.css('border', styleSettings.border).css('border-top', 'none').css('height', height + "px"); // 当只有 toolbarSelector 时,toolbarElemId 自行创建
- toolbarElemId = util_1.getRandom('toolbar-elem');
- } else {
- // toolbarSelector 和 textSelector 都有
- $toolbarElem = $toolbarSelector;
- $textContainerElem = dom_core_1["default"](textSelector); // 将编辑器区域原有的内容,暂存起来
- $children = $textContainerElem.children(); // 都有时,toolbarElemId 使用用户自定义的
- toolbarElemId = $toolbarSelector.attr('id') || util_1.getRandom('toolbar-elem');
- } // 编辑区域
- $textElem = dom_core_1["default"]('<div></div>');
- $textElem.attr('contenteditable', 'true').css('width', '100%').css('height', '100%'); // 添加 placeholder
- var $placeholder = dom_core_1["default"]("<div>" + i18next.t(editor.config.placeholder) + "</div>");
- $placeholder.addClass('placeholder'); // 初始化编辑区域内容
- if ($children && $children.length) {
- $textElem.append($children); // 编辑器有默认值的时候隐藏placeholder
- $placeholder.hide();
- } else {
- $textElem.append(dom_core_1["default"]('<p><br></p>')); // 新增一行,方便继续编辑
- } // 编辑区域加入DOM
- $textContainerElem.append($textElem); // 添加placeholder
- $textContainerElem.append($placeholder); // 设置通用的 class
- $toolbarElem.addClass('w-e-toolbar').css('z-index', editor.zIndex.get('toolbar'));
- $textContainerElem.addClass('w-e-text-container');
- $textContainerElem.css('z-index', editor.zIndex.get());
- $textElem.addClass('w-e-text'); // 添加 ID
- $toolbarElem.attr('id', toolbarElemId);
- var textElemId = util_1.getRandom('text-elem');
- $textElem.attr('id', textElemId);
- $textElem.elems.forEach(function (v) { v.form = v.closest('form'); });
- // 判断编辑区与容器高度是否一致
- var textContainerCliheight = $textContainerElem.getClientHeight();
- var textElemClientHeight = $textElem.getClientHeight();
-
- if (textContainerCliheight !== textElemClientHeight) {
- $textElem.css('min-height', textContainerCliheight + 'px');
- } // 记录属性
- editor.$toolbarElem = $toolbarElem;
- editor.$textContainerElem = $textContainerElem;
- editor.$textElem = $textElem;
- editor.toolbarElemId = toolbarElemId;
- editor.textElemId = textElemId;
- }
- exports["default"] = default_1;
- /***/ }),
- /* 387 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 初始化编辑器选区,将光标定位到文档末尾
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- /**
- * 初始化编辑器选区,将光标定位到文档末尾
- * @param editor 编辑器实例
- * @param newLine 是否新增一行
- */
- function initSelection(editor, newLine) {
- var $textElem = editor.$textElem;
- var $children = $textElem.children();
- if (!$children || !$children.length) {
- // 如果编辑器区域无内容,添加一个空行,重新设置选区
- $textElem.append(dom_core_1["default"]('<p><br></p>'));
- initSelection(editor);
- return;
- }
- var $last = $children.last();
- if (newLine) {
- // 新增一个空行
- var html = $last.html().toLowerCase();
- var nodeName = $last.getNodeName();
- if (html !== '<br>' && html !== '<br/>' || nodeName !== 'P') {
- // 最后一个元素不是 <p><br></p>,添加一个空行,重新设置选区
- $textElem.append(dom_core_1["default"]('<p><br></p>'));
- initSelection(editor);
- return;
- }
- }
- editor.selection.createRangeByElem($last, true, true);
- if (editor.config.focus) {
- editor.selection.restoreSelection();
- }
- }
- exports["default"] = initSelection;
- /***/ }),
- /* 388 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 绑定编辑器事件 change blur focus
- * @author wangfupeng
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- function bindEvent(editor) {
- // 绑定 change 事件
- _bindChange(editor); // 绑定 focus blur 事件
- _bindFocusAndBlur(editor); // 绑定 input 输入
- _bindInput(editor);
- }
- /**
- * 绑定 change 事件
- * @param editor 编辑器实例
- */
- function _bindChange(editor) {
- var onchange = editor.config.onchange;
- editor.txt.eventHooks.changeEvents.push(function () {
- var html = editor.txt.html() || '';
- onchange(html);
- editor.txt.togglePlaceholder();
- });
- }
- /**
- * 绑定 focus blur 事件
- * @param editor 编辑器实例
- */
- function _bindFocusAndBlur(editor) {
- // 当前编辑器是否是焦点状态
- editor.isFocus = false;
- function listener(e) {
- var target = e.target;
- var $target = dom_core_1["default"](target);
- var $textElem = editor.$textElem;
- var $toolbarElem = editor.$toolbarElem; //判断当前点击元素是否在编辑器内
- var isChild = $textElem.isContain($target); //判断当前点击元素是否为工具栏
- var isToolbar = $toolbarElem.isContain($target);
- var isMenu = $toolbarElem.elems[0] == e.target ? true : false;
- if (!isChild) {
- // 若为选择工具栏中的功能,则不视为成 blur 操作
- if (isToolbar && !isMenu) {
- return;
- }
- if (editor.isFocus) {
- _blurHandler(editor);
- }
- editor.isFocus = false;
- } else {
- if (!editor.isFocus) {
- _focusHandler(editor);
- }
- editor.isFocus = true;
- }
- }
- if (document.activeElement === editor.$textElem.elems[0]) {
- _focusHandler(editor);
- editor.isFocus = true;
- }
- dom_core_1["default"](document).on('click', listener); // 全局事件在编辑器实例销毁的时候进行解绑
- editor.beforeDestroy(function () {
- dom_core_1["default"](document).off('click', listener);
- });
- }
- /**
- * 绑定 input 事件
- * @param editor 编辑器实例
- */
- function _bindInput(editor) {
- // 绑定中文输入
- editor.$textElem.on('compositionstart', function () {
- editor.isComposing = true;
- }).on('compositionend', function () {
- editor.isComposing = false;
- });
- }
- /**
- * blur 事件
- * @param editor 编辑器实例
- */
- function _blurHandler(editor) {
- var config = editor.config;
- var onblur = config.onblur;
- var currentHtml = editor.txt.html() || '';
- onblur(currentHtml);
- }
- /**
- * focus 事件
- * @param editor 编辑器实例
- */
- function _focusHandler(editor) {
- var config = editor.config;
- var onfocus = config.onfocus;
- var currentHtml = editor.txt.html() || '';
- onfocus(currentHtml);
- }
- exports["default"] = bindEvent;
- /***/ }),
- /* 389 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 国际化 初始化
- * @author tonghan
- * i18next 是使用 JavaScript 编写的国际化框架
- * i18next 提供了标准的i18n功能,例如(复数,上下文,插值,格式)等
- * i18next 文档地址: https://www.i18next.com/overview/getting-started
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- function i18nextInit(editor) {
- var _a = editor.config,
- lang = _a.lang,
- languages = _a.languages;
- if (editor.i18next != null) {
- try {
- editor.i18next.init({
- ns: 'wangEditor',
- lng: lang,
- defaultNS: 'wangEditor',
- resources: languages
- });
- } catch (error) {
- throw new Error('i18next:' + error);
- }
- return;
- } // 没有引入 i18next 的替代品
- editor.i18next = {
- t: function t(str) {
- var strArr = str.split('.');
- return strArr[strArr.length - 1];
- }
- };
- }
- exports["default"] = i18nextInit;
- /***/ }),
- /* 390 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 全屏功能
- * @author xiaokyo
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.setUnFullScreen = exports.setFullScreen = void 0;
- var dom_core_1 = __importDefault(__webpack_require__(2));
- __webpack_require__(391);
- var iconFullScreenText = 'w-e-icon-fullscreen'; // 全屏icon class
- var iconExitFullScreenText = 'w-e-icon-fullscreen_exit'; // 退出全屏icon class
- var classfullScreenEditor = 'w-e-full-screen-editor'; // 全屏添加至编辑器的class
- /**
- * 设置全屏
- * @param editor 编辑器实例
- */
- var setFullScreen = function setFullScreen(editor) {
- var $editorParent = dom_core_1["default"](editor.toolbarSelector);
- var $textContainerElem = editor.$textContainerElem;
- var $toolbarElem = editor.$toolbarElem;
- var $iconElem = (0, _find["default"])($toolbarElem).call($toolbarElem, "i." + iconFullScreenText);
- var config = editor.config;
- $iconElem.removeClass(iconFullScreenText);
- $iconElem.addClass(iconExitFullScreenText);
- $editorParent.addClass(classfullScreenEditor);
- $editorParent.css('z-index', config.zIndexFullScreen);
- var bar = $toolbarElem.getBoundingClientRect();
- var h = window.innerHeight - bar.height;
- $textContainerElem.css('height', h + "px");
- };
- exports.setFullScreen = setFullScreen;
- /**
- * 取消全屏
- * @param editor 编辑器实例
- */
- var setUnFullScreen = function setUnFullScreen(editor) {
- var $editorParent = dom_core_1["default"](editor.toolbarSelector);
- var $textContainerElem = editor.$textContainerElem;
- var $toolbarElem = editor.$toolbarElem;
- var $iconElem = (0, _find["default"])($toolbarElem).call($toolbarElem, "i." + iconExitFullScreenText);
- var config = editor.config;
- $iconElem.removeClass(iconExitFullScreenText);
- $iconElem.addClass(iconFullScreenText);
- $editorParent.removeClass(classfullScreenEditor);
- $editorParent.css('z-index', 'auto');
- $textContainerElem.css('height', config.height + 'px');
- };
- exports.setUnFullScreen = setUnFullScreen;
- /**
- * 初始化全屏功能
- * @param editor 编辑器实例
- */
- var initFullScreen = function initFullScreen(editor) {
- // 当textSelector有值的时候,也就是编辑器是工具栏和编辑区域分离的情况, 则不生成全屏功能按钮
- if (editor.textSelector) return;
- if (!editor.config.showFullScreen) return;
- var $toolbarElem = editor.$toolbarElem;
- var $elem = dom_core_1["default"]("<div class=\"w-e-menu\" data-title=\"\u5168\u5C4F\">\n <i class=\"" + iconFullScreenText + "\"></i>\n </div>");
- $elem.on('click', function (e) {
- var _context;
- var $elemIcon = (0, _find["default"])(_context = dom_core_1["default"](e.currentTarget)).call(_context, 'i');
- if ($elemIcon.hasClass(iconFullScreenText)) {
- exports.setFullScreen(editor);
- } else {
- exports.setUnFullScreen(editor);
- }
- });
- $toolbarElem.append($elem);
- };
- exports["default"] = initFullScreen;
- /***/ }),
- /* 391 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(392);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 392 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- 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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 393 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 滚动到指定锚点
- * @author zhengwenjian
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * 编辑器滚动到指定锚点
- * @param editor 编辑器实例
- * @param id 标题锚点id
- */
- var scrollToHead = function scrollToHead(editor, id) {
- var $textElem = editor.$textElem;
- var $targetHead = (0, _find["default"])($textElem).call($textElem, "[id='" + id + "']");
- var targetTop = $targetHead.getOffsetData().top;
- $textElem.scrollTop(targetTop);
- };
- exports["default"] = scrollToHead;
- /***/ }),
- /* 394 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var style_1 = __importDefault(__webpack_require__(122));
- var tier = {
- menu: 2,
- panel: 2,
- toolbar: 1,
- tooltip: 1,
- textContainer: 1
- };
- var ZIndex =
- /** @class */
- function () {
- function ZIndex() {
- // 层级参数
- this.tier = tier; // 默认值
- this.baseZIndex = style_1["default"].zIndex;
- } // 获取 tierName 对应的 z-index 的值。如果 tierName 未定义则返回默认的 z-index 值
- ZIndex.prototype.get = function (tierName) {
- if (tierName && this.tier[tierName]) {
- return this.baseZIndex + this.tier[tierName];
- }
- return this.baseZIndex;
- }; // 初始化
- ZIndex.prototype.init = function (editor) {
- if (this.baseZIndex == style_1["default"].zIndex) {
- this.baseZIndex = editor.config.zIndex;
- }
- };
- return ZIndex;
- }();
- exports["default"] = ZIndex;
- /***/ }),
- /* 395 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 编辑器 change 事件
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _filter = _interopRequireDefault(__webpack_require__(65));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var mutation_1 = __importDefault(__webpack_require__(396));
- var util_1 = __webpack_require__(7);
- var const_1 = __webpack_require__(26);
- /**
- * 剔除编辑区容器的 attribute 变化中的非 contenteditable 变化
- * @param mutations MutationRecord[]
- * @param tar 编辑区容器的 DOM 节点
- */
- function mutationsFilter(mutations, tar) {
- // 剔除编辑区容器的 attribute 变化中的非 contenteditable 变化
- return (0, _filter["default"])(mutations).call(mutations, function (_a) {
- var type = _a.type,
- target = _a.target,
- attributeName = _a.attributeName;
- return type != 'attributes' || type == 'attributes' && (attributeName == 'contenteditable' || target != tar);
- });
- }
- /**
- * Change 实现
- */
- var Change =
- /** @class */
- function (_super) {
- __extends(Change, _super);
- function Change(editor) {
- var _this = _super.call(this, function (mutations, observer) {
- var _a; // 数据过滤
- mutations = mutationsFilter(mutations, observer.target); // 存储数据
- (_a = _this.data).push.apply(_a, mutations); // 标准模式下
- if (!editor.isCompatibleMode) {
- // 在非中文输入状态下时才保存数据
- if (!editor.isComposing) {
- return _this.asyncSave();
- }
- } // 兼容模式下
- else {
- _this.asyncSave();
- }
- }) || this;
- _this.editor = editor;
- /**
- * 变化的数据集合
- */
- _this.data = [];
- /**
- * 异步保存数据
- */
- _this.asyncSave = const_1.EMPTY_FN;
- return _this;
- }
- /**
- * 保存变化的数据并发布 change event
- */
- Change.prototype.save = function () {
- // 有数据
- if (this.data.length) {
- // 保存变化数据
- this.editor.history.save(this.data); // 清除缓存
- this.data.length = 0;
- this.emit();
- }
- };
- /**
- * 发布 change event
- */
- Change.prototype.emit = function () {
- var _context;
- // 执行 onchange 回调
- (0, _forEach["default"])(_context = this.editor.txt.eventHooks.changeEvents).call(_context, function (fn) {
- return fn();
- });
- }; // 重写 observe
- Change.prototype.observe = function () {
- var _this = this;
- _super.prototype.observe.call(this, this.editor.$textElem.elems[0]);
- var timeout = this.editor.config.onchangeTimeout;
- this.asyncSave = util_1.debounce(function () {
- _this.save();
- }, timeout);
- if (!this.editor.isCompatibleMode) {
- this.editor.$textElem.on('compositionend', function () {
- _this.asyncSave();
- });
- }
- };
- return Change;
- }(mutation_1["default"]);
- exports["default"] = Change;
- /***/ }),
- /* 396 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 封装 MutationObserver
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /**
- * 封装 MutationObserver,抽离成公共类
- */
- var Mutation =
- /** @class */
- function () {
- /**
- * 构造器
- * @param fn 发生变化时执行的回调函数
- * @param options 自定义配置项
- */
- function Mutation(fn, options) {
- var _this = this;
- /**
- * 默认的 MutationObserverInit 配置
- */
- this.options = {
- subtree: true,
- childList: true,
- attributes: true,
- attributeOldValue: true,
- characterData: true,
- characterDataOldValue: true
- };
- this.callback = function (mutations) {
- fn(mutations, _this);
- };
- this.observer = new MutationObserver(this.callback);
- options && (this.options = options);
- }
- (0, _defineProperty["default"])(Mutation.prototype, "target", {
- get: function get() {
- return this.node;
- },
- enumerable: false,
- configurable: true
- });
- /**
- * 绑定监听节点(初次绑定有效)
- * @param node 需要被监听的节点
- */
- Mutation.prototype.observe = function (node) {
- if (!(this.node instanceof Node)) {
- this.node = node;
- this.connect();
- }
- };
- /**
- * 连接监听器(开始观察)
- */
- Mutation.prototype.connect = function () {
- if (this.node) {
- this.observer.observe(this.node, this.options);
- return this;
- }
- throw new Error('还未初始化绑定,请您先绑定有效的 Node 节点');
- };
- /**
- * 断开监听器(停止观察)
- */
- Mutation.prototype.disconnect = function () {
- var list = this.observer.takeRecords();
- list.length && this.callback(list);
- this.observer.disconnect();
- };
- return Mutation;
- }();
- exports["default"] = Mutation;
- /***/ }),
- /* 397 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 历史记录
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var content_1 = __importDefault(__webpack_require__(398));
- var scroll_1 = __importDefault(__webpack_require__(410));
- var range_1 = __importDefault(__webpack_require__(411));
- /**
- * 历史记录(撤销、恢复)
- */
- var History =
- /** @class */
- function () {
- function History(editor) {
- this.editor = editor;
- this.content = new content_1["default"](editor);
- this.scroll = new scroll_1["default"](editor);
- this.range = new range_1["default"](editor);
- }
- (0, _defineProperty["default"])(History.prototype, "size", {
- /**
- * 获取缓存中的数据长度。格式为:[正常的数据的条数,被撤销的数据的条数]
- */
- get: function get() {
- return this.scroll.size;
- },
- enumerable: false,
- configurable: true
- });
- /**
- * 初始化绑定。在 editor.create() 结尾时调用
- */
- History.prototype.observe = function () {
- this.content.observe();
- this.scroll.observe(); // 标准模式下才进行初始化绑定
- !this.editor.isCompatibleMode && this.range.observe();
- };
- /**
- * 保存数据
- */
- History.prototype.save = function (mutations) {
- if (mutations.length) {
- this.content.save(mutations);
- this.scroll.save(); // 标准模式下才进行缓存
- !this.editor.isCompatibleMode && this.range.save();
- }
- };
- /**
- * 撤销
- */
- History.prototype.revoke = function () {
- this.editor.change.disconnect();
- var res = this.content.revoke();
- if (res) {
- this.scroll.revoke(); // 标准模式下才执行
- if (!this.editor.isCompatibleMode) {
- this.range.revoke();
- this.editor.$textElem.focus();
- }
- }
- this.editor.change.connect(); // 如果用户在 onchange 中修改了内容(DOM),那么缓存中的节点数据可能不连贯了,不连贯的数据必将导致恢复失败,所以必须将用户的 onchange 处于监控状态中
- res && this.editor.change.emit();
- };
- /**
- * 恢复
- */
- History.prototype.restore = function () {
- this.editor.change.disconnect();
- var res = this.content.restore();
- if (res) {
- this.scroll.restore(); // 标准模式下才执行
- if (!this.editor.isCompatibleMode) {
- this.range.restore();
- this.editor.$textElem.focus();
- }
- }
- this.editor.change.connect(); // 与 revoke 同理
- res && this.editor.change.emit();
- };
- return History;
- }();
- exports["default"] = History;
- /***/ }),
- /* 398 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 整合差异备份和内容备份,进行统一管理
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var node_1 = __importDefault(__webpack_require__(399));
- var html_1 = __importDefault(__webpack_require__(408));
- var ContentCache =
- /** @class */
- function () {
- function ContentCache(editor) {
- this.editor = editor;
- }
- /**
- * 初始化绑定
- */
- ContentCache.prototype.observe = function () {
- if (this.editor.isCompatibleMode) {
- // 兼容模式(内容备份)
- this.cache = new html_1["default"](this.editor);
- } else {
- // 标准模式(差异备份/节点备份)
- this.cache = new node_1["default"](this.editor);
- }
- this.cache.observe();
- };
- /**
- * 保存
- */
- ContentCache.prototype.save = function (mutations) {
- if (this.editor.isCompatibleMode) {
- ;
- this.cache.save();
- } else {
- ;
- this.cache.compile(mutations);
- }
- };
- /**
- * 撤销
- */
- ContentCache.prototype.revoke = function () {
- var _a;
- return (_a = this.cache) === null || _a === void 0 ? void 0 : _a.revoke();
- };
- /**
- * 恢复
- */
- ContentCache.prototype.restore = function () {
- var _a;
- return (_a = this.cache) === null || _a === void 0 ? void 0 : _a.restore();
- };
- return ContentCache;
- }();
- exports["default"] = ContentCache;
- /***/ }),
- /* 399 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 差异备份
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var cache_1 = __importDefault(__webpack_require__(99));
- var compile_1 = __importDefault(__webpack_require__(401));
- var decompilation_1 = __webpack_require__(402);
- var NodeCache =
- /** @class */
- function (_super) {
- __extends(NodeCache, _super);
- function NodeCache(editor) {
- var _this = _super.call(this, editor.config.historyMaxSize) || this;
- _this.editor = editor;
- return _this;
- }
- NodeCache.prototype.observe = function () {
- this.resetMaxSize(this.editor.config.historyMaxSize);
- };
- /**
- * 编译并保存数据
- */
- NodeCache.prototype.compile = function (data) {
- this.save(compile_1["default"](data));
- return this;
- };
- /**
- * 撤销
- */
- NodeCache.prototype.revoke = function () {
- return _super.prototype.revoke.call(this, function (data) {
- decompilation_1.revoke(data);
- });
- };
- /**
- * 恢复
- */
- NodeCache.prototype.restore = function () {
- return _super.prototype.restore.call(this, function (data) {
- decompilation_1.restore(data);
- });
- };
- return NodeCache;
- }(cache_1["default"]);
- exports["default"] = NodeCache;
- /***/ }),
- /* 400 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 数据结构 - 栈
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.CeilStack = void 0;
- /**
- * 栈(限制最大数据条数,栈满后可以继续入栈,而先入栈的数据将失效)
- */
- // 取名灵感来自 Math.ceil,向上取有效值
- var CeilStack =
- /** @class */
- function () {
- function CeilStack(max) {
- if (max === void 0) {
- max = 0;
- }
- /**
- * 数据缓存
- */
- this.data = [];
- /**
- * 栈的最大长度。为零则长度不限
- */
- this.max = 0;
- /**
- * 标识是否重设过 max 值
- */
- this.reset = false;
- max = Math.abs(max);
- max && (this.max = max);
- }
- /**
- * 允许用户重设一次 max 值
- */
- CeilStack.prototype.resetMax = function (maxSize) {
- maxSize = Math.abs(maxSize);
- if (!this.reset && !isNaN(maxSize)) {
- this.max = maxSize;
- this.reset = true;
- }
- };
- (0, _defineProperty["default"])(CeilStack.prototype, "size", {
- /**
- * 当前栈中的数据条数
- */
- get: function get() {
- return this.data.length;
- },
- enumerable: false,
- configurable: true
- });
- /**
- * 入栈
- * @param data 入栈的数据
- */
- CeilStack.prototype.instack = function (data) {
- this.data.unshift(data);
- if (this.max && this.size > this.max) {
- this.data.length = this.max;
- }
- return this;
- };
- /**
- * 出栈
- */
- CeilStack.prototype.outstack = function () {
- return this.data.shift();
- };
- /**
- * 清空栈
- */
- CeilStack.prototype.clear = function () {
- this.data.length = 0;
- return this;
- };
- return CeilStack;
- }();
- exports.CeilStack = CeilStack;
- /***/ }),
- /* 401 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 数据整理
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _indexOf = _interopRequireDefault(__webpack_require__(54));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.compliePosition = exports.complieNodes = exports.compileValue = exports.compileType = void 0;
- var util_1 = __webpack_require__(7);
- /**
- * 数据类型
- */
- function compileType(data) {
- switch (data) {
- case 'childList':
- return 'node';
- case 'attributes':
- return 'attr';
- default:
- return 'text';
- }
- }
- exports.compileType = compileType;
- /**
- * 获取当前的文本内容
- */
- function compileValue(data) {
- switch (data.type) {
- case 'attributes':
- return data.target.getAttribute(data.attributeName) || '';
- case 'characterData':
- return data.target.textContent;
- default:
- return '';
- }
- }
- exports.compileValue = compileValue;
- /**
- * addedNodes/removedNodes
- */
- function complieNodes(data) {
- var temp = {};
- if (data.addedNodes.length) {
- temp.add = util_1.toArray(data.addedNodes);
- }
- if (data.removedNodes.length) {
- temp.remove = util_1.toArray(data.removedNodes);
- }
- return temp;
- }
- exports.complieNodes = complieNodes;
- /**
- * addedNodes/removedNodes 的相对位置
- */
- function compliePosition(data) {
- var temp;
- if (data.previousSibling) {
- temp = {
- type: 'before',
- target: data.previousSibling
- };
- } else if (data.nextSibling) {
- temp = {
- type: 'after',
- target: data.nextSibling
- };
- } else {
- temp = {
- type: 'parent',
- target: data.target
- };
- }
- return temp;
- }
- exports.compliePosition = compliePosition;
- /**
- * 补全 Firefox 数据的特殊标签
- */
- var tag = ['UL', 'OL', 'H1', 'H2', 'H3', 'H4', 'H5', 'H6'];
- /**
- * 将 MutationRecord 转换成自定义格式的数据
- */
- function compile(data) {
- var temp = []; // 以下两个变量是兼容 Firefox 时使用到的
- // 前一次操作为删除元素节点
- var removeNode = false; // 连续的节点删除记录
- var removeCache = [];
- (0, _forEach["default"])(data).call(data, function (record, index) {
- var item = {
- type: compileType(record.type),
- target: record.target,
- attr: record.attributeName || '',
- value: compileValue(record) || '',
- oldValue: record.oldValue || '',
- nodes: complieNodes(record),
- position: compliePosition(record)
- };
- temp.push(item); // 兼容 Firefox,补全数据(这几十行代码写得吐血,跟 IE 有得一拼)
- if (!util_1.UA.isFirefox) {
- return;
- } // 正常的数据:缩进、行高、超链接、对齐方式、引用、插入表情、插入图片、分割线、表格、插入代码
- // 普通的数据补全:标题(纯文本内容)、加粗、斜体、删除线、下划线、颜色、背景色、字体、字号、列表(纯文本内容)
- // 特殊的数据补全:标题(包含 HTMLElement)、列表(包含 HTMLElement 或 ul -> ol 或 ol -> ul 或 Enter)
- if (removeNode && record.addedNodes.length && record.addedNodes[0].nodeType == 1) {
- // 需要被全数据的目标节点
- var replenishNode = record.addedNodes[0];
- var replenishData = {
- type: 'node',
- target: replenishNode,
- attr: '',
- value: '',
- oldValue: '',
- nodes: {
- add: [removeNode]
- },
- position: {
- type: 'parent',
- target: replenishNode
- }
- }; // 特殊的标签:['UL', 'OL', 'H1', 'H2', 'H3', 'H4', 'H5', 'H6']
- if ((0, _indexOf["default"])(tag).call(tag, replenishNode.nodeName) != -1) {
- replenishData.nodes.add = util_1.toArray(replenishNode.childNodes);
- temp.push(replenishData);
- } // 上一个删除元素是文本节点
- else if (removeNode.nodeType == 3) {
- if (contains(replenishNode, removeCache)) {
- replenishData.nodes.add = util_1.toArray(replenishNode.childNodes);
- }
- temp.push(replenishData);
- } // 上一个删除元素是 Element && 由近到远的删除元素至少有一个是需要补全数据节点的子节点
- else if ((0, _indexOf["default"])(tag).call(tag, record.target.nodeName) == -1 && contains(replenishNode, removeCache)) {
- replenishData.nodes.add = util_1.toArray(replenishNode.childNodes);
- temp.push(replenishData);
- }
- } // 记录本次的节点信息
- if (item.type == 'node' && record.removedNodes.length == 1) {
- removeNode = record.removedNodes[0];
- removeCache.push(removeNode);
- } else {
- removeNode = false;
- removeCache.length = 0;
- }
- });
- return temp;
- }
- exports["default"] = compile; // 删除元素的历史记录中包含有多少个目标节点的子元素
- function contains(tar, childs) {
- var count = 0;
- for (var i = childs.length - 1; i > 0; i--) {
- if (tar.contains(childs[i])) {
- count++;
- } else {
- break;
- }
- }
- return count;
- }
- /***/ }),
- /* 402 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _entries = _interopRequireDefault(__webpack_require__(403));
- var _forEach = _interopRequireDefault(__webpack_require__(5));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.restore = exports.revoke = void 0;
- /**
- * 将节点添加到 DOM 树中
- * @param data 数据项
- * @param list 节点集合(addedNodes 或 removedNodes)
- */
- function insertNode(data, list) {
- var reference = data.position.target;
- switch (data.position.type) {
- // reference 在这些节点的前面
- case 'before':
- if (reference.nextSibling) {
- reference = reference.nextSibling;
- (0, _forEach["default"])(list).call(list, function (item) {
- data.target.insertBefore(item, reference);
- });
- } else {
- (0, _forEach["default"])(list).call(list, function (item) {
- data.target.appendChild(item);
- });
- }
- break;
- // reference 在这些节点的后面
- case 'after':
- (0, _forEach["default"])(list).call(list, function (item) {
- data.target.insertBefore(item, reference);
- });
- break;
- // parent
- // reference 是这些节点的父节点
- default:
- (0, _forEach["default"])(list).call(list, function (item) {
- reference.appendChild(item);
- });
- break;
- }
- }
- /* ------------------------------------------------------------------ 撤销逻辑 ------------------------------------------------------------------ */
- function revokeNode(data) {
- for (var _i = 0, _a = (0, _entries["default"])(data.nodes); _i < _a.length; _i++) {
- var _b = _a[_i],
- relative = _b[0],
- list = _b[1];
- switch (relative) {
- // 反向操作,将这些节点从 DOM 中移除
- case 'add':
- (0, _forEach["default"])(list).call(list, function (item) {
- data.target.removeChild(item);
- });
- break;
- // remove(反向操作,将这些节点添加到 DOM 中)
- default:
- {
- insertNode(data, list);
- break;
- }
- }
- }
- }
- /**
- * 撤销 attribute
- */
- function revokeAttr(data) {
- var target = data.target;
- if (data.oldValue == null) {
- target.removeAttribute(data.attr);
- } else {
- target.setAttribute(data.attr, data.oldValue);
- }
- }
- /**
- * 撤销文本内容
- */
- function revokeText(data) {
- data.target.textContent = data.oldValue;
- }
- var revokeFns = {
- node: revokeNode,
- text: revokeText,
- attr: revokeAttr
- }; // 撤销 - 对外暴露的接口
- function revoke(data) {
- for (var i = data.length - 1; i > -1; i--) {
- var item = data[i];
- revokeFns[item.type](item);
- }
- }
- exports.revoke = revoke;
- /* ------------------------------------------------------------------ 恢复逻辑 ------------------------------------------------------------------ */
- function restoreNode(data) {
- for (var _i = 0, _a = (0, _entries["default"])(data.nodes); _i < _a.length; _i++) {
- var _b = _a[_i],
- relative = _b[0],
- list = _b[1];
- switch (relative) {
- case 'add':
- {
- insertNode(data, list);
- break;
- }
- // remove
- default:
- {
- (0, _forEach["default"])(list).call(list, function (item) {
- ;
- item.parentNode.removeChild(item);
- });
- break;
- }
- }
- }
- }
- function restoreText(data) {
- data.target.textContent = data.value;
- }
- function restoreAttr(data) {
- ;
- data.target.setAttribute(data.attr, data.value);
- }
- var restoreFns = {
- node: restoreNode,
- text: restoreText,
- attr: restoreAttr
- }; // 恢复 - 对外暴露的接口
- function restore(data) {
- for (var _i = 0, data_1 = data; _i < data_1.length; _i++) {
- var item = data_1[_i];
- restoreFns[item.type](item);
- }
- }
- exports.restore = restore;
- /***/ }),
- /* 403 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(404);
- /***/ }),
- /* 404 */
- /***/ (function(module, exports, __webpack_require__) {
- var parent = __webpack_require__(405);
- module.exports = parent;
- /***/ }),
- /* 405 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(406);
- var path = __webpack_require__(10);
- module.exports = path.Object.entries;
- /***/ }),
- /* 406 */
- /***/ (function(module, exports, __webpack_require__) {
- var $ = __webpack_require__(4);
- var $entries = __webpack_require__(407).entries;
- // `Object.entries` method
- // https://tc39.github.io/ecma262/#sec-object.entries
- $({ target: 'Object', stat: true }, {
- entries: function entries(O) {
- return $entries(O);
- }
- });
- /***/ }),
- /* 407 */
- /***/ (function(module, exports, __webpack_require__) {
- var DESCRIPTORS = __webpack_require__(14);
- var objectKeys = __webpack_require__(57);
- var toIndexedObject = __webpack_require__(27);
- var propertyIsEnumerable = __webpack_require__(55).f;
- // `Object.{ entries, values }` methods implementation
- var createMethod = function (TO_ENTRIES) {
- return function (it) {
- var O = toIndexedObject(it);
- var keys = objectKeys(O);
- var length = keys.length;
- var i = 0;
- var result = [];
- var key;
- while (length > i) {
- key = keys[i++];
- if (!DESCRIPTORS || propertyIsEnumerable.call(O, key)) {
- result.push(TO_ENTRIES ? [key, O[key]] : O[key]);
- }
- }
- return result;
- };
- };
- module.exports = {
- // `Object.entries` method
- // https://tc39.github.io/ecma262/#sec-object.entries
- entries: createMethod(true),
- // `Object.values` method
- // https://tc39.github.io/ecma262/#sec-object.values
- values: createMethod(false)
- };
- /***/ }),
- /* 408 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var chain_1 = __webpack_require__(409);
- var HtmlCache =
- /** @class */
- function () {
- function HtmlCache(editor) {
- this.editor = editor;
- this.data = new chain_1.TailChain();
- }
- /**
- * 初始化绑定
- */
- HtmlCache.prototype.observe = function () {
- this.data.resetMax(this.editor.config.historyMaxSize); // 保存初始化值
- this.data.insertLast(this.editor.$textElem.html());
- };
- /**
- * 保存
- */
- HtmlCache.prototype.save = function () {
- this.data.insertLast(this.editor.$textElem.html());
- return this;
- };
- /**
- * 撤销
- */
- HtmlCache.prototype.revoke = function () {
- var data = this.data.prev();
- if (data) {
- this.editor.$textElem.html(data);
- return true;
- }
- return false;
- };
- /**
- * 恢复
- */
- HtmlCache.prototype.restore = function () {
- var data = this.data.next();
- if (data) {
- this.editor.$textElem.html(data);
- return true;
- }
- return false;
- };
- return HtmlCache;
- }();
- exports["default"] = HtmlCache;
- /***/ }),
- /* 409 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 数据结构 - 链表
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _splice = _interopRequireDefault(__webpack_require__(90));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- exports.TailChain = void 0;
- /**
- * 特殊链表(数据尾插入、插入前自动清理指针后边的数据、插入后指针永远定位于最后一位元素、可限制链表长度、指针双向移动)
- */
- var TailChain =
- /** @class */
- function () {
- function TailChain() {
- /**
- * 链表数据
- */
- this.data = [];
- /**
- * 链表最大长度,零表示长度不限
- */
- this.max = 0;
- /**
- * 指针
- */
- this.point = 0; // 当前指针是否人为操作过
- this.isRe = false;
- }
- /**
- * 允许用户重设一次 max 值
- */
- TailChain.prototype.resetMax = function (maxSize) {
- maxSize = Math.abs(maxSize);
- maxSize && (this.max = maxSize);
- };
- (0, _defineProperty["default"])(TailChain.prototype, "size", {
- /**
- * 当前链表的长度
- */
- get: function get() {
- return this.data.length;
- },
- enumerable: false,
- configurable: true
- });
- /**
- * 尾插入
- * @param data 插入的数据
- */
- TailChain.prototype.insertLast = function (data) {
- // 人为操作过指针,清除指针后面的元素
- if (this.isRe) {
- var _context;
- (0, _splice["default"])(_context = this.data).call(_context, this.point + 1);
- this.isRe = false;
- }
- this.data.push(data); // 超出链表最大长度
- while (this.max && this.size > this.max) {
- this.data.shift();
- } // 从新定位指针到最后一个元素
- this.point = this.size - 1;
- return this;
- };
- /**
- * 获取当前指针元素
- */
- TailChain.prototype.current = function () {
- return this.data[this.point];
- };
- /**
- * 获取上一指针元素
- */
- TailChain.prototype.prev = function () {
- !this.isRe && (this.isRe = true);
- this.point--;
- if (this.point < 0) {
- this.point = 0;
- return undefined;
- }
- return this.current();
- };
- /**
- * 下一指针元素
- */
- TailChain.prototype.next = function () {
- !this.isRe && (this.isRe = true);
- this.point++;
- if (this.point >= this.size) {
- this.point = this.size - 1;
- return undefined;
- }
- return this.current();
- };
- return TailChain;
- }();
- exports.TailChain = TailChain;
- /***/ }),
- /* 410 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 记录 scrollTop
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var cache_1 = __importDefault(__webpack_require__(99));
- var ScrollCache =
- /** @class */
- function (_super) {
- __extends(ScrollCache, _super);
- function ScrollCache(editor) {
- var _this = _super.call(this, editor.config.historyMaxSize) || this;
- _this.editor = editor;
- /**
- * 上一次的 scrollTop
- */
- _this.last = 0;
- _this.target = editor.$textElem.elems[0];
- return _this;
- }
- /**
- * 给编辑区容器绑定 scroll 事件
- */
- ScrollCache.prototype.observe = function () {
- var _this = this;
- this.target = this.editor.$textElem.elems[0];
- this.editor.$textElem.on('scroll', function () {
- _this.last = _this.target.scrollTop;
- });
- this.resetMaxSize(this.editor.config.historyMaxSize);
- };
- /**
- * 保存 scrollTop 值
- */
- ScrollCache.prototype.save = function () {
- _super.prototype.save.call(this, [this.last, this.target.scrollTop]);
- return this;
- };
- /**
- * 撤销
- */
- ScrollCache.prototype.revoke = function () {
- var _this = this;
- return _super.prototype.revoke.call(this, function (data) {
- _this.target.scrollTop = data[0];
- });
- };
- /**
- * 恢复
- */
- ScrollCache.prototype.restore = function () {
- var _this = this;
- return _super.prototype.restore.call(this, function (data) {
- _this.target.scrollTop = data[1];
- });
- };
- return ScrollCache;
- }(cache_1["default"]);
- exports["default"] = ScrollCache;
- /***/ }),
- /* 411 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /**
- * @description 记录 range 变化
- * @author fangzhicong
- */
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var _create = _interopRequireDefault(__webpack_require__(3));
- var _setPrototypeOf = _interopRequireDefault(__webpack_require__(6));
- var __extends = void 0 && (void 0).__extends || function () {
- var _extendStatics = function extendStatics(d, b) {
- _extendStatics = _setPrototypeOf["default"] || {
- __proto__: []
- } instanceof Array && function (d, b) {
- d.__proto__ = b;
- } || function (d, b) {
- for (var p in b) {
- if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];
- }
- };
- return _extendStatics(d, b);
- };
- return function (d, b) {
- _extendStatics(d, b);
- function __() {
- this.constructor = d;
- }
- d.prototype = b === null ? (0, _create["default"])(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var cache_1 = __importDefault(__webpack_require__(99));
- var dom_core_1 = __importDefault(__webpack_require__(2));
- var util_1 = __webpack_require__(7);
- /**
- * 把 Range 对象转换成缓存对象
- * @param range Range 对象
- */
- function rangeToObject(range) {
- return {
- start: [range.startContainer, range.startOffset],
- end: [range.endContainer, range.endOffset],
- root: range.commonAncestorContainer,
- collapsed: range.collapsed
- };
- }
- /**
- * 编辑区 range 缓存管理器
- */
- var RangeCache =
- /** @class */
- function (_super) {
- __extends(RangeCache, _super);
- function RangeCache(editor) {
- var _this = _super.call(this, editor.config.historyMaxSize) || this;
- _this.editor = editor;
- _this.lastRange = rangeToObject(document.createRange());
- _this.root = editor.$textElem.elems[0];
- _this.updateLastRange = util_1.debounce(function () {
- _this.lastRange = rangeToObject(_this.rangeHandle);
- }, editor.config.onchangeTimeout);
- return _this;
- }
- (0, _defineProperty["default"])(RangeCache.prototype, "rangeHandle", {
- /**
- * 获取 Range 对象
- */
- get: function get() {
- var selection = document.getSelection();
- return selection && selection.rangeCount ? selection.getRangeAt(0) : document.createRange();
- },
- enumerable: false,
- configurable: true
- });
- /**
- * 初始化绑定
- */
- RangeCache.prototype.observe = function () {
- var self = this; // 同步节点数据
- this.root = this.editor.$textElem.elems[0];
- this.resetMaxSize(this.editor.config.historyMaxSize); // selection change 回调函数
- function selectionchange() {
- var handle = self.rangeHandle;
- if (self.root === handle.commonAncestorContainer || self.root.contains(handle.commonAncestorContainer)) {
- // 非中文输入状态下才进行记录
- if (!self.editor.isComposing) {
- self.updateLastRange();
- }
- }
- } // backspace 和 delete 手动更新 Range 缓存
- function deletecallback(e) {
- if (e.key == 'Backspace' || e.key == 'Delete') {
- // self.lastRange = rangeToObject(self.rangeHandle)
- self.updateLastRange();
- }
- } // 绑定事件(必须绑定在 document 上,不能绑定在 window 上)
- dom_core_1["default"](document).on('selectionchange', selectionchange); // 解除事件绑定
- this.editor.beforeDestroy(function () {
- dom_core_1["default"](document).off('selectionchange', selectionchange);
- }); // 删除文本时手动更新 range
- self.editor.$textElem.on('keydown', deletecallback);
- };
- /**
- * 保存 Range
- */
- RangeCache.prototype.save = function () {
- var current = rangeToObject(this.rangeHandle);
- _super.prototype.save.call(this, [this.lastRange, current]);
- this.lastRange = current;
- return this;
- };
- /**
- * 设置 Range,在 撤销/恢复 中调用
- * @param range 缓存的 Range 数据
- */
- RangeCache.prototype.set = function (range) {
- if (range) {
- var handle = this.rangeHandle;
- handle.setStart.apply(handle, range.start);
- handle.setEnd.apply(handle, range.end);
- this.editor.menus.changeActive();
- return true;
- }
- return false;
- };
- /**
- * 撤销
- */
- RangeCache.prototype.revoke = function () {
- var _this = this;
- return _super.prototype.revoke.call(this, function (data) {
- _this.set(data[0]);
- });
- };
- /**
- * 恢复
- */
- RangeCache.prototype.restore = function () {
- var _this = this;
- return _super.prototype.restore.call(this, function (data) {
- _this.set(data[1]);
- });
- };
- return RangeCache;
- }(cache_1["default"]);
- exports["default"] = RangeCache;
- /***/ }),
- /* 412 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _find = _interopRequireDefault(__webpack_require__(30));
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- var __importDefault = void 0 && (void 0).__importDefault || function (mod) {
- return mod && mod.__esModule ? mod : {
- "default": mod
- };
- };
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- var dom_core_1 = __importDefault(__webpack_require__(2));
- __webpack_require__(413);
- function disableInit(editor) {
- var isCurtain = false; // 避免重复生成幕布
- var $contentDom;
- var $menuDom; // 禁用期间,通过 js 修改内容后,刷新内容
- editor.txt.eventHooks.changeEvents.push(function () {
- if (isCurtain) {
- (0, _find["default"])($contentDom).call($contentDom, '.w-e-content-preview').html(editor.$textElem.html());
- }
- }); // 创建幕布
- function disable() {
- if (isCurtain) return; // 隐藏编辑区域
- editor.$textElem.hide(); // 生成div 渲染编辑内容
- var textContainerZindexValue = editor.zIndex.get('textContainer');
- var content = editor.txt.html();
- $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>");
- editor.$textContainerElem.append($contentDom); // 生成div 菜单膜布
- var menuZindexValue = editor.zIndex.get('menu');
- $menuDom = dom_core_1["default"]("<div class=\"w-e-menue-mantle\" style=\"z-index:" + menuZindexValue + "\"></div>");
- editor.$toolbarElem.append($menuDom);
- isCurtain = true;
- } // 销毁幕布并显示可编辑区域
- function enable() {
- if (!isCurtain) return;
- $contentDom.remove();
- $menuDom.remove();
- editor.$textElem.show();
- isCurtain = false;
- }
- return {
- disable: disable,
- enable: enable
- };
- }
- exports["default"] = disableInit;
- /***/ }),
- /* 413 */
- /***/ (function(module, exports, __webpack_require__) {
- var api = __webpack_require__(20);
- var content = __webpack_require__(414);
- content = content.__esModule ? content.default : content;
- if (typeof content === 'string') {
- content = [[module.i, content, '']];
- }
- var options = {};
- options.insert = "head";
- options.singleton = false;
- var update = api(content, options);
- module.exports = content.locals || {};
- /***/ }),
- /* 414 */
- /***/ (function(module, exports, __webpack_require__) {
- // Imports
- var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(21);
- exports = ___CSS_LOADER_API_IMPORT___(false);
- // Module
- exports.push([module.i, ".w-e-content-mantle {\n position: absolute;\n top: 0;\n left: 0;\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", ""]);
- // Exports
- module.exports = exports;
- /***/ }),
- /* 415 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var _interopRequireDefault = __webpack_require__(0);
- var _defineProperty = _interopRequireDefault(__webpack_require__(1));
- (0, _defineProperty["default"])(exports, "__esModule", {
- value: true
- });
- /***/ })
- /******/ ])["default"];
- });
- //# sourceMappingURL=wangEditor.js.map
|