| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499105001050110502105031050410505105061050710508105091051010511105121051310514105151051610517105181051910520105211052210523105241052510526105271052810529105301053110532105331053410535105361053710538105391054010541105421054310544105451054610547105481054910550105511055210553105541055510556105571055810559105601056110562105631056410565105661056710568105691057010571105721057310574105751057610577105781057910580105811058210583105841058510586105871058810589105901059110592105931059410595105961059710598105991060010601106021060310604106051060610607106081060910610106111061210613106141061510616106171061810619106201062110622106231062410625106261062710628106291063010631106321063310634106351063610637106381063910640106411064210643106441064510646106471064810649106501065110652106531065410655106561065710658106591066010661106621066310664106651066610667106681066910670106711067210673106741067510676106771067810679106801068110682106831068410685106861068710688106891069010691106921069310694106951069610697106981069910700107011070210703107041070510706107071070810709107101071110712107131071410715107161071710718107191072010721107221072310724107251072610727107281072910730107311073210733107341073510736107371073810739107401074110742107431074410745107461074710748107491075010751107521075310754107551075610757107581075910760107611076210763107641076510766107671076810769107701077110772107731077410775107761077710778107791078010781107821078310784107851078610787107881078910790107911079210793107941079510796107971079810799108001080110802108031080410805108061080710808108091081010811108121081310814108151081610817108181081910820108211082210823108241082510826108271082810829108301083110832108331083410835108361083710838108391084010841108421084310844108451084610847108481084910850108511085210853108541085510856108571085810859108601086110862108631086410865108661086710868108691087010871108721087310874108751087610877108781087910880108811088210883108841088510886108871088810889108901089110892108931089410895108961089710898108991090010901109021090310904109051090610907109081090910910109111091210913109141091510916109171091810919109201092110922109231092410925109261092710928109291093010931109321093310934109351093610937109381093910940109411094210943109441094510946109471094810949109501095110952109531095410955109561095710958109591096010961109621096310964109651096610967109681096910970109711097210973109741097510976109771097810979109801098110982109831098410985109861098710988109891099010991109921099310994109951099610997109981099911000110011100211003110041100511006110071100811009110101101111012110131101411015110161101711018110191102011021110221102311024110251102611027110281102911030110311103211033110341103511036110371103811039110401104111042110431104411045110461104711048110491105011051110521105311054110551105611057110581105911060110611106211063110641106511066110671106811069110701107111072110731107411075110761107711078110791108011081110821108311084110851108611087110881108911090110911109211093110941109511096110971109811099111001110111102111031110411105111061110711108111091111011111111121111311114111151111611117111181111911120111211112211123111241112511126111271112811129111301113111132111331113411135111361113711138111391114011141111421114311144111451114611147111481114911150111511115211153111541115511156111571115811159111601116111162111631116411165 |
- var Fa = Object.defineProperty;
- var Ha = (n, e, t) => e in n ? Fa(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t;
- var x = (n, e, t) => Ha(n, typeof e != "symbol" ? e + "" : e, t);
- import { Inject as z, Disposable as ue, toDisposable as Zn, UniverInstanceType as _, BuildTextUtils as Ce, IUniverInstanceService as Q, JSONX as k, ObjectRelativeFromH as $n, ObjectRelativeFromV as ot, useDependency as $, ICommandService as y, generateRandomId as pt, DisposableCollection as Dn, CommandType as N, debounce as fi, Tools as X, IUndoRedoService as eo, TextX as me, TextXActionType as W, DOC_RANGE_TYPE as Ge, RANGE_DIRECTION as xe, COLORS as tn, BooleanNumber as L, Rectangle as ka, RxDisposable as At, DataStreamTreeTokenType as U, ILogService as fs, isInternalEditorID as to, createIdentifier as ps, EDITOR_ACTIVATED as wn, FOCUSING_EDITOR_STANDALONE as lr, DEFAULT_EMPTY_DOCUMENT_VALUE as pi, VerticalAlign as Va, HorizontalAlign as _e, IContextService as ms, Direction as se, createInternalEditorID as ja, useObservable as Nn, LocaleService as Ze, DocumentFlavor as ye, PresetListType as Oe, sequenceExecuteAsync as Es, FOCUSING_DOC as hn, FOCUSING_UNIVER_EDITOR as Ss, FOCUSING_COMMON_DRAWINGS as mi, MemoryCursor as St, BaselineOffset as Ne, getBodySlice as Ei, PRESET_LIST_TYPE as Wa, GridType as za, sortRulesFactory as Ga, UpdateDocsAttributeType as no, TableRowHeightRule as Ya, TableSizeType as Si, TableAlignmentType as qa, TableTextWrapType as Ka, SHEET_EDITOR_UNITS as Is, PositionedObjectLayoutType as oo, LRUMap as Xa, ColorKit as dr, DrawingTypeEnum as Cs, skipParseTagNames as Ja, CustomRangeType as Ii, DataStreamTreeNodeType as qt, SliceBodyType as ur, DOCS_NORMAL_EDITOR_UNIT_ID_KEY as vs, normalizeBody as Za, SpacingRule as Bt, DEFAULT_STYLES as Ci, ThemeService as vi, DOCS_ZEN_EDITOR_UNIT_ID_KEY as $e, Injector as so, connectInjector as $a, IConfigService as Rs, QuickListTypeMap as bo, fromEventSubject as nn, DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY as ec, checkForSubstrings as tc, UndoCommandId as hr, RedoCommandId as gr, DependentOn as nc, Plugin as oc, merge as sc, touchDependencies as fr, mergeOverrideWithDependencies as rc } from "@univerjs/core";
- import { DocSelectionManagerService as G, RichTextEditingMutation as J, DocSkeletonManagerService as ie, SetTextSelectionsOperation as De, DocStateEmitService as ic, DocInterceptorService as ac } from "@univerjs/docs";
- import { DeviceInputEventType as Ri, ScrollBar as Vo, IRenderManagerService as fe, Liquid as bi, GlyphType as xi, DocumentSkeletonPageType as Ie, getPageFromPath as jo, getTableIdAndSliceIndex as pr, NORMAL_TEXT_SELECTION_PLUGIN_STYLE as sn, getColor as on, RegularPolygon as Oi, Rect as yn, getOffsetRectForDom as cc, ScrollTimer as Ac, CURSOR_TYPE as mt, getSystemHighlightColor as lc, Vector2 as rn, PageLayoutType as an, DocumentEditArea as ge, Shape as dc, Path as mr, getCharSpaceApply as uc, getNumberUnitValue as ze, hasListGlyph as hc, isIndentByGlyph as gc, isFirstGlyph as fc, getParagraphByGlyph as pc, pixelToPt as mc, ptToPixel as Er, parseDataStreamToTree as Ec, Viewport as Sc, Layer as Sr, Documents as Ic, DocBackground as Cc, lineIterator as vc, getLastColumn as Rc, getLastLine as bc, pxToNum as Ti, TRANSFORM_CHANGE_OBSERVABLE_TYPE as yi, UniverRenderEnginePlugin as xc } from "@univerjs/engine-render";
- import { IShortcutService as ro, KeyCode as j, ILayoutService as bs, MetaKeys as K, useEvent as xo, ComponentManager as io, ISidebarService as Bi, IClipboardInterfaceService as Mi, FILE_PNG_CLIPBOARD_MIME_TYPE as _i, FILE__WEBP_CLIPBOARD_MIME_TYPE as Pi, FILE__JPEG_CLIPBOARD_MIME_TYPE as Di, FILE__BMP_CLIPBOARD_MIME_TYPE as wi, HTML_CLIPBOARD_MIME_TYPE as Ni, PLAIN_TEXT_CLIPBOARD_MIME_TYPE as Qi, CopyCommand as Oc, CutCommand as Tc, PasteCommand as yc, IConfirmService as Bc, MenuItemType as Z, getMenuHiddenObservable as ee, FONT_FAMILY_LIST as Mc, FONT_SIZE_LIST as _c, RibbonStartGroup as Ir, ContextMenuPosition as Ui, ContextMenuGroup as Cr, FontFamily as Pc, FontFamilyItem as Dc, FontSize as wc, BuiltInUIPart as Nc, IMenuManagerService as Qc, IUIPartsService as Uc, ICanvasPopupService as Lc, IContextMenuService as Fc } from "@univerjs/ui";
- import * as Hc from "react";
- import Wo, { useMemo as Fe, useEffect as Re, useCallback as Li, useState as ve, useLayoutEffect as kc, useRef as cn, forwardRef as It, useImperativeHandle as Vc, createElement as Ft } from "react";
- import { Subject as Ee, BehaviorSubject as Le, merge as Fi, filter as Qn, takeUntil as st, fromEvent as Ue, combineLatest as ao, Observable as pe, map as gn, distinctUntilChanged as vr, throttleTime as Hi, switchMap as jc, take as Wc, animationFrameScheduler as zc } from "rxjs";
- import { filter as zo, bufferTime as Gc, map as Yc } from "rxjs/operators";
- import { Checkbox as Rr, InputNumber as An, Button as qc, Slider as Kc, Tooltip as Xc, Select as Jc, ColorPicker as Zc } from "@univerjs/design";
- import { ImageSourceType as xs } from "@univerjs/drawing";
- var $c = Object.defineProperty, eA = Object.getOwnPropertyDescriptor, tA = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? eA(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && $c(e, t, s), s;
- }, br = (n, e) => (t, o) => e(t, o, n);
- function nA(n, e) {
- var i, a;
- const { startOffset: t, endOffset: o } = n, s = [];
- let r = -1;
- for (let c = 0; c < e.length; c++) {
- const A = e[c], l = e[c - 1], { startIndex: d } = A;
- t > r && t <= d || o > r && o <= d ? s.push({
- ...A,
- paragraphStart: ((i = l == null ? void 0 : l.startIndex) != null ? i : -1) + 1,
- paragraphEnd: A.startIndex
- }) : d >= t && d <= o && s.push({
- ...A,
- paragraphStart: ((a = l == null ? void 0 : l.startIndex) != null ? a : -1) + 1,
- paragraphEnd: A.startIndex
- }), r = d;
- }
- return s;
- }
- let Et = class extends ue {
- constructor(e, t) {
- super();
- x(this, "_matches", /* @__PURE__ */ new Map());
- this._univerInstanceService = e, this._textSelectionManagerService = t;
- }
- registerAutoFormat(e) {
- const t = this._matches.get(e.id);
- return t ? (t.push(e), t.sort((o, s) => {
- var r, i;
- return ((r = s.priority) != null ? r : 0) - ((i = o.priority) != null ? i : 0);
- })) : this._matches.set(e.id, [e]), Zn(() => {
- const o = this._matches.get(e.id);
- if (o) {
- const s = o.findIndex((r) => r === e);
- s >= 0 && o.splice(s, 1);
- }
- });
- }
- onAutoFormat(e, t) {
- var a, c, A, l, d, h, u;
- const o = (a = this._matches.get(e)) != null ? a : [], s = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC), r = this._textSelectionManagerService.getDocRanges(), i = (c = r.find((g) => g.isActive)) != null ? c : r[0];
- if (s && i) {
- const g = s.getSelfOrHeaderFooterModel(i.segmentId), f = {
- unit: g,
- selection: i,
- isBody: !i.segmentId,
- paragraphs: nA(i, (l = (A = g.getBody()) == null ? void 0 : A.paragraphs) != null ? l : []),
- customRanges: Ce.customRange.getCustomRangesInterestsWithSelection(i, (h = (d = g.getBody()) == null ? void 0 : d.customRanges) != null ? h : []),
- commandId: e,
- commandParams: t
- }, p = o.find((m) => m.match(f));
- return (u = p == null ? void 0 : p.getMutations(f)) != null ? u : [];
- }
- return [];
- }
- };
- Et = tA([
- br(0, Q),
- br(1, z(G))
- ], Et);
- const oA = {
- undo: !0,
- redo: !0,
- // Undo redo
- font: !0,
- // 'font'
- fontSize: !0,
- // 'Font size'
- bold: !0,
- // 'Bold (Ctrl+B)'
- italic: !0,
- // 'Italic (Ctrl+I)'
- strikethrough: !0,
- // 'Strikethrough (Alt+Shift+5)'
- underline: !0,
- // 'Underline (Alt+Shift+6)'
- textColor: !0,
- // 'Text color'
- fillColor: !0,
- // 'Cell color'
- horizontalAlignMode: !0,
- // 'Horizontal alignment'
- verticalAlignMode: !0,
- // 'Vertical alignment'
- textWrapMode: !0,
- // 'Wrap mode'
- textRotateMode: !0
- // 'Text Rotation Mode'
- }, sA = {
- outerLeft: !1,
- outerRight: !1,
- header: !0,
- footer: !0,
- innerLeft: !1,
- innerRight: !1,
- frozenHeaderLT: !1,
- frozenHeaderRT: !1,
- frozenHeaderLM: !1,
- frozenContent: !1,
- infoBar: !0,
- toolbar: !0
- }, rA = "DOC_UI_PLUGIN";
- var We = /* @__PURE__ */ ((n) => (n.MAIN = "__Document_Render_Main__", n.BACKGROUND = "__Document_Render_Background__", n))(We || {}), Xe = /* @__PURE__ */ ((n) => (n.VIEW_MAIN = "viewMain", n.VIEW_TOP = "viewTop", n.VIEW_LEFT = "viewLeft", n.VIEW_LEFT_TOP = "viewLeftTop", n))(Xe || {});
- const iA = 0, Oo = 2, aA = 4, xr = 10, ef = "normalTextSelectionPluginName";
- function rt(n) {
- const { mainComponent: e, scene: t, engine: o, components: s } = n, r = e, i = s.get(We.BACKGROUND);
- return {
- document: r,
- docBackground: i,
- scene: t,
- engine: o
- };
- }
- function cA(n, e) {
- const t = n.getCurrentUnitForType(_.UNIVER_DOC);
- if (!t)
- return null;
- const o = t.getUnitId(), s = e.getRenderById(o);
- if (s == null)
- return;
- const { mainComponent: r, scene: i, engine: a, components: c } = s, A = r, l = c.get(We.BACKGROUND);
- return {
- document: A,
- docBackground: l,
- scene: i,
- engine: a
- };
- }
- function tf(n, e) {
- const t = e.getRenderById(n);
- if (t == null)
- return;
- const { mainComponent: o, scene: s, engine: r, components: i } = t, a = o, c = i.get(We.BACKGROUND);
- return {
- document: a,
- docBackground: c,
- scene: s,
- engine: r
- };
- }
- function AA(n) {
- const { unitId: e, ranges: t, id: o, type: s, segmentId: r } = n, i = {
- id: J.id,
- params: {
- unitId: e,
- actions: [],
- textRanges: void 0,
- // noHistory: true,
- segmentId: r
- }
- }, a = k.getInstance(), c = Ce.customDecoration.add({ ranges: t, id: o, type: s });
- return i.params.actions = a.editOp(c.serialize()), i;
- }
- function nf(n, e) {
- const { segmentId: t, id: o, type: s, unitId: r } = e, i = n.get(G), a = n.get(Q), c = r ? a.getUnit(r, _.UNIVER_DOC) : a.getCurrentUnitForType(_.UNIVER_DOC);
- if (!c)
- return !1;
- const A = c.getUnitId(), l = i.getTextRanges({ unitId: A, subUnitId: A });
- return !l || !c.getBody() ? !1 : AA(
- {
- unitId: A,
- ranges: l,
- id: o,
- type: s,
- segmentId: t
- }
- );
- }
- function of(n, e) {
- const { unitId: t, id: o, segmentId: s } = e, i = n.get(Q).getUnit(t);
- if (!i)
- return !1;
- const a = {
- id: J.id,
- params: {
- unitId: t,
- actions: [],
- textRanges: void 0,
- // noHistory: true,
- segmentId: s
- }
- }, c = Ce.customDecoration.delete({ id: o, segmentId: s, documentDataModel: i });
- if (!c)
- return !1;
- const A = k.getInstance();
- return a.params.actions = A.editOp(c.serialize()), a;
- }
- function sf(n, e) {
- return e.some((t) => n.startIndex > t.startIndex && n.startIndex < t.endIndex);
- }
- function co(n, e, t, o) {
- const s = {
- st: 0,
- ed: 0,
- ts: t
- };
- for (let r = n.length - 1; r >= 0; r--) {
- const i = n[r], { st: a, ed: c } = i;
- e > a && e <= c && (s.st = a, s.ed = c, s.ts = {
- ...s.ts,
- ...i.ts
- });
- }
- if (e === 0) {
- const r = n == null ? void 0 : n[0];
- r && r.st === 0 && (s.ts = {
- ...s.ts,
- ...r.ts
- });
- }
- return o && (s.ts = {
- ...s.ts,
- ...o
- }), s;
- }
- function Os(n, e, t) {
- if (t) {
- const s = n.find((r) => e >= r.startIndex && e <= r.endIndex + 1);
- return s != null && s.wholeEntity ? null : s;
- }
- const o = n.find((s) => e > s.startIndex && e <= s.endIndex);
- return o != null && o.wholeEntity ? null : o;
- }
- function Ts(n, e) {
- return n.filter((t) => e > t.startIndex && e <= t.endIndex);
- }
- function rf(n) {
- return {
- left: n.positionH.posOffset,
- top: n.positionV.posOffset,
- width: n.size.width,
- height: n.size.height
- };
- }
- function af(n, e = 0, t = 0) {
- return {
- size: {
- width: n.width,
- height: n.height
- },
- positionH: {
- relativeFrom: $n.MARGIN,
- posOffset: (n.left || 0) - e
- },
- positionV: {
- relativeFrom: ot.PAGE,
- posOffset: (n.top || 0) - t
- },
- angle: n.angle || 0
- };
- }
- function lA(n, e, t) {
- const o = $(y), s = $(ro), r = Fe(() => pt(4), []);
- Re(() => {
- if (!t || !n || !e)
- return;
- const a = `sheet.operation.editor-${t.getEditorId()}-keyboard-${r}`, c = new Dn();
- return c.add(o.registerCommand({
- id: a,
- type: N.OPERATION,
- handler(A, l) {
- const { keyCode: d, metaKey: h } = l;
- e.handler(d, h);
- }
- })), e.keyCodes.map((A) => ({
- id: a,
- binding: A.metaKey ? A.keyCode | A.metaKey : A.keyCode,
- preconditions: () => !0,
- priority: 901,
- staticParameters: {
- eventType: Ri.Keyboard,
- keyCode: A.keyCode,
- metaKey: A.metaKey
- }
- })).forEach((A) => {
- c.add(s.registerShortcut(A));
- }), () => {
- c.dispose();
- };
- }, [o, e, t, n, r, s]);
- }
- const dA = (n, e = !0, t, o) => {
- const s = Li(() => {
- if (n) {
- const { scene: i, mainComponent: a } = n.render, c = n.render.with(ie), { width: A, height: l } = n.getBoundingClientRect();
- c.getViewModel().getDataModel().updateDocumentDataPageSize(e ? 1 / 0 : A, 1 / 0), i.transformByState({
- width: A,
- height: l
- }), a == null || a.resize(A, l);
- }
- }, [n, e]), r = Fe(() => fi(() => {
- var E, I;
- if (!t || !n || !t)
- return;
- const a = n.render.with(ie).getSkeleton(), { scene: c, mainComponent: A } = n.render, l = c.getViewport(Xe.VIEW_MAIN), { actualWidth: d, actualHeight: h } = a.getActualSize(), { width: u, height: g } = n.getBoundingClientRect();
- let f = l == null ? void 0 : l.getScrollBar();
- const p = Math.max(d, u), m = Math.max(h, g);
- c.transformByState({
- width: p,
- height: m
- }), A == null || A.resize(p, m), e ? d > u ? (f == null ? l && new Vo(l, {
- barSize: 8,
- enableVertical: !1,
- enableHorizontal: !0,
- minThumbSizeV: 8
- }) : l == null || l.resetCanvasSizeAndUpdateScroll(), o && (l == null || l.scrollToBarPos({ x: 1 / 0, y: 0 }))) : (f = null, l == null || l.scrollToBarPos({ x: 0, y: 0 }), (I = l == null ? void 0 : l.getScrollBar()) == null || I.dispose()) : h > g ? (f == null ? l && (f = new Vo(l, {
- enableHorizontal: !1,
- enableVertical: !0,
- barSize: 8,
- minThumbSizeV: 8
- })) : l == null || l.resetCanvasSizeAndUpdateScroll(), o && (l == null || l.scrollToBarPos({ x: 0, y: 1 / 0 }))) : (f = null, l == null || l.scrollToBarPos({ x: 0, y: 0 }), (E = l == null ? void 0 : l.getScrollBar()) == null || E.dispose());
- }, 30), [n, t, e, o]);
- return Re(() => {
- if (t && n) {
- const i = setTimeout(() => {
- s(), r();
- }, 500);
- return () => {
- clearTimeout(i);
- };
- }
- }, [n, t, s, r]), Re(() => {
- if (t && n) {
- const i = n.input$.subscribe(() => {
- r();
- });
- return () => {
- i.unsubscribe();
- };
- }
- }, [n, t, r]), { resize: s, checkScrollBar: r };
- };
- var To = { exports: {} }, Kt = {};
- /**
- * @license React
- * react-jsx-runtime.production.min.js
- *
- * Copyright (c) Facebook, Inc. and its affiliates.
- *
- * This source code is licensed under the MIT license found in the
- * LICENSE file in the root directory of this source tree.
- */
- var Or;
- function uA() {
- if (Or) return Kt;
- Or = 1;
- var n = Wo, e = Symbol.for("react.element"), t = Symbol.for("react.fragment"), o = Object.prototype.hasOwnProperty, s = n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, r = { key: !0, ref: !0, __self: !0, __source: !0 };
- function i(a, c, A) {
- var l, d = {}, h = null, u = null;
- A !== void 0 && (h = "" + A), c.key !== void 0 && (h = "" + c.key), c.ref !== void 0 && (u = c.ref);
- for (l in c) o.call(c, l) && !r.hasOwnProperty(l) && (d[l] = c[l]);
- if (a && a.defaultProps) for (l in c = a.defaultProps, c) d[l] === void 0 && (d[l] = c[l]);
- return { $$typeof: e, type: a, key: h, ref: u, props: d, _owner: s.current };
- }
- return Kt.Fragment = t, Kt.jsx = i, Kt.jsxs = i, Kt;
- }
- var Tr;
- function hA() {
- return Tr || (Tr = 1, To.exports = uA()), To.exports;
- }
- var w = hA();
- function ki(n) {
- var e, t, o = "";
- if (typeof n == "string" || typeof n == "number") o += n;
- else if (typeof n == "object") if (Array.isArray(n)) {
- var s = n.length;
- for (e = 0; e < s; e++) n[e] && (t = ki(n[e])) && (o && (o += " "), o += t);
- } else for (t in n) n[t] && (o && (o += " "), o += t);
- return o;
- }
- function Un() {
- for (var n, e, t = 0, o = "", s = arguments.length; t < s; t++) (n = arguments[t]) && (e = ki(n)) && (o && (o += " "), o += e);
- return o;
- }
- function ke(n, e) {
- var o;
- return (o = n.get(fe).getRenderById(e)) == null ? void 0 : o.with(ie);
- }
- function le(n, e = "") {
- if (!e)
- return ["body"];
- const { headers: t, footers: o } = n.getSnapshot();
- if (t == null && o == null)
- throw new Error("Document data model must have headers or footers when update by segment id");
- if ((t == null ? void 0 : t[e]) != null)
- return ["headers", e, "body"];
- if ((o == null ? void 0 : o[e]) != null)
- return ["footers", e, "body"];
- throw new Error("Segment id not found in headers or footers");
- }
- const Vi = {
- id: "doc.command-replace-snapshot",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function, complexity
- handler: (n, e) => {
- const { unitId: t, snapshot: o, textRanges: s, segmentId: r = "", options: i } = e, a = n.get(Q), c = n.get(y), A = n.get(G), l = a.getUnit(t, _.UNIVER_DOC), d = l == null ? void 0 : l.getSelfOrHeaderFooterModel(r).getSnapshot();
- if (l == null || d == null)
- return !1;
- const { body: h, tableSource: u, footers: g, headers: f, lists: p, drawings: m, drawingsOrder: E, documentStyle: I } = X.deepClone(o), {
- body: v,
- tableSource: R,
- footers: S,
- headers: C,
- lists: T,
- drawings: O,
- drawingsOrder: P,
- documentStyle: b
- } = d;
- if (h == null || v == null)
- return !1;
- if (X.diffValue(h, v) && s)
- return A.replaceDocRanges(s, {
- unitId: t,
- subUnitId: t
- }, !1), !0;
- const B = {
- id: J.id,
- params: {
- unitId: t,
- actions: [],
- textRanges: s
- }
- };
- i && (B.params.options = i);
- const M = [], H = k.getInstance();
- if (!X.diffValue(b, I)) {
- const D = H.replaceOp(["documentStyle"], b, I);
- D != null && M.push(D);
- }
- if (!X.diffValue(h, v)) {
- const D = H.replaceOp(["body"], v, h);
- D != null && M.push(D);
- }
- if (!X.diffValue(u, R)) {
- const D = H.replaceOp(["tableSource"], R, u);
- D != null && M.push(D);
- }
- if (!X.diffValue(g, S)) {
- const D = H.replaceOp(["footers"], S, g);
- D != null && M.push(D);
- }
- if (!X.diffValue(f, C)) {
- const D = H.replaceOp(["headers"], C, f);
- D != null && M.push(D);
- }
- if (!X.diffValue(p, T)) {
- const D = H.replaceOp(["lists"], T, p);
- D != null && M.push(D);
- }
- if (!X.diffValue(m, O)) {
- const D = H.replaceOp(["drawings"], O, m);
- D != null && M.push(D);
- }
- if (!X.diffValue(E, P)) {
- const D = H.replaceOp(["drawingsOrder"], P, E);
- D != null && M.push(D);
- }
- return B.params.actions = M.reduce((D, te) => k.compose(D, te), null), !!c.syncExecuteCommand(B.id, B.params);
- }
- }, gA = {
- id: "doc.command-replace-content",
- type: N.COMMAND,
- handler: async (n, e) => {
- const { unitId: t, body: o, textRanges: s, segmentId: r = "", options: i } = e, a = n.get(Q), c = n.get(y), A = n.get(G), l = a.getUnit(t, _.UNIVER_DOC), d = l == null ? void 0 : l.getSelfOrHeaderFooterModel(r).getSnapshot().body;
- if (l == null || d == null)
- return !1;
- const h = ji(t, r, l, d, o);
- return h.params.textRanges = s, i && (h.params.options = i), h.params.actions == null && s ? (A.replaceDocRanges(s, {
- unitId: t,
- subUnitId: t
- }, !1), !0) : !!c.syncExecuteCommand(h.id, h.params);
- }
- }, fA = {
- id: "doc.command-cover-content",
- type: N.COMMAND,
- handler: async (n, e) => {
- const { unitId: t, body: o, segmentId: s = "" } = e, r = n.get(Q), i = n.get(y), a = n.get(eo), c = r.getUniverDocInstance(t), A = c == null ? void 0 : c.getSnapshot().body;
- if (c == null || A == null)
- return !1;
- const l = ji(t, s, c, A, o);
- return l.params.noNeedSetTextRange = !0, l.params.noHistory = !0, i.syncExecuteCommand(
- l.id,
- l.params
- ), a.clearUndoRedo(t), !0;
- }
- };
- function pA(n, e, t, o) {
- const s = new me(), r = k.getInstance(), i = (t == null ? void 0 : t.dataStream.length) - 2;
- i > 0 && s.push({
- t: W.DELETE,
- len: i
- }), o.dataStream.length > 0 && s.push({
- t: W.INSERT,
- body: o,
- len: o.dataStream.length
- });
- const a = le(e, n);
- return r.editOp(s.serialize(), a);
- }
- function ji(n, e, t, o, s) {
- const r = {
- id: J.id,
- params: {
- unitId: n,
- actions: [],
- textRanges: []
- }
- }, i = pA(e, t, o, s);
- return r.params.actions = i, r;
- }
- N.COMMAND;
- const mA = {
- id: "doc.command.replace-text-runs",
- type: N.COMMAND,
- handler: (n, e) => {
- const { unitId: t, body: o, textRanges: s, segmentId: r = "", options: i } = e, a = n.get(Q), c = n.get(y), A = a.getUnit(t, _.UNIVER_DOC), l = A == null ? void 0 : A.getSelfOrHeaderFooterModel(r).getSnapshot().body;
- if (A == null || l == null)
- return !1;
- const d = Ce.selection.replaceTextRuns({
- doc: A,
- body: o,
- selection: {
- startOffset: 0,
- endOffset: l.dataStream.length - 2,
- collapsed: !1
- }
- });
- if (!d)
- return !1;
- const h = {
- id: J.id,
- params: {
- unitId: t,
- actions: [],
- textRanges: s,
- noHistory: !0
- }
- }, u = k.getInstance(), g = le(A, r);
- return h.params.actions = u.editOp(d.serialize(), g), h.params.textRanges = s, i && (h.params.options = i), !!c.syncExecuteCommand(h.id, h.params);
- }
- };
- var Bn = /* @__PURE__ */ ((n) => (n[n.page = 0] = "page", n[n.section = 1] = "section", n[n.column = 2] = "column", n[n.line = 3] = "line", n[n.divide = 4] = "divide", n[n.glyph = 5] = "glyph", n))(Bn || {});
- const Tt = {
- page: 0,
- section: 1,
- column: 2,
- line: 3,
- divide: 4,
- glyph: 5
- };
- function ys(n, e) {
- return n.page > e.page ? !1 : n.page < e.page ? !0 : n.section > e.section ? !1 : n.section < e.section ? !0 : n.column > e.column ? !1 : n.column < e.column ? !0 : n.line > e.line ? !1 : n.line < e.line ? !0 : n.divide > e.divide ? !1 : n.divide < e.divide ? !0 : n.glyph > e.glyph ? !1 : (n.glyph < e.glyph, !0);
- }
- function Go(n, e) {
- return ys(n, e) ? {
- start: n,
- end: e
- } : {
- start: e,
- end: n
- };
- }
- function yr(n) {
- const e = n.length;
- if (e === 0)
- return;
- const t = n[0], o = n[e - 1], s = n.length === 1 && t.collapsed;
- return {
- startOffset: t.startOffset,
- endOffset: o.endOffset,
- collapsed: s
- };
- }
- function EA(n, e, t, o) {
- let s = o, r = o;
- for (let i = 0; i < n.length; i++) {
- const c = n[i].count;
- i < e && (s += c), i < t && (r += c);
- }
- return {
- startOffset: s,
- endOffset: r
- };
- }
- function Yo(n) {
- const { startX: e, startY: t, endX: o, endY: s } = n, r = [];
- return r.push({
- x: e,
- y: t
- }), r.push({
- x: o,
- y: t
- }), r.push({
- x: o,
- y: s
- }), r.push({
- x: e,
- y: s
- }), r.push({
- x: e,
- y: t
- }), r;
- }
- class it {
- constructor(e, t) {
- x(this, "_liquid", new bi());
- x(this, "_currentStartState", {
- page: 0,
- section: 0,
- column: 0,
- line: 0,
- divide: 0,
- glyph: 0
- /* NORMAL */
- });
- x(this, "_currentEndState", {
- page: 0,
- section: 0,
- column: 0,
- line: 0,
- divide: 0,
- glyph: 0
- /* NORMAL */
- });
- this._documentOffsetConfig = e, this._docSkeleton = t;
- }
- // eslint-disable-next-line max-lines-per-function
- getRangePointData(e, t) {
- const o = [], s = [], r = [];
- if (e == null || t == null)
- return {
- borderBoxPointGroup: o,
- contentBoxPointGroup: s,
- cursorList: r
- };
- if (!this._isValidPosition(e, t))
- throw new Error(
- `
- Invalid positions in NodePositionConvertToCursor,
- they are not in the same segment page when in header or footer.`
- );
- const { start: a, end: c } = Go(e, t);
- return this._selectionIterator(a, c, (A, l, d, h, u, g) => {
- const { lineHeight: f, asc: p, paddingTop: m, marginTop: E, marginBottom: I } = g, { glyphGroup: v, st: R } = u;
- if (v.length === 0)
- return;
- const { x: S, y: C } = this._liquid;
- let T, O;
- const P = v[A], b = v[l], B = v[A - 1], M = (P == null ? void 0 : P.left) || 0, H = (P == null ? void 0 : P.width) || 0, F = (b == null ? void 0 : b.left) || 0, D = (b == null ? void 0 : b.width) || 0, te = (P == null ? void 0 : P.glyphType) === xi.LIST, { startOffset: q, endOffset: V } = EA(v, A, l, R), Y = a.glyph === A && d ? a.isBack : !0, oe = c.glyph === l && h ? c.isBack : !1, ce = a === c, he = Y && B != null ? B : P;
- if (A === 0 && l === v.length - 1)
- T = {
- startX: S + M + (te ? H : 0),
- startY: C,
- endX: S + F + (oe ? 0 : D),
- endY: C + f - E - I
- }, O = {
- startX: S + M + (te ? H : 0),
- startY: C + m + p - he.bBox.ba,
- endX: S + F + (oe ? 0 : D),
- endY: C + m + p + he.bBox.bd
- };
- else {
- const Ae = Y && !te;
- T = {
- startX: S + M + (Ae ? 0 : H),
- startY: C,
- endX: S + F + (oe ? 0 : D),
- endY: C + f - E - I
- }, O = {
- startX: S + M + (Ae ? 0 : H),
- startY: C + m + p - he.bBox.ba,
- endX: S + F + (oe ? 0 : D),
- endY: C + m + p + he.bBox.bd
- };
- }
- o.push(Yo(T)), s.push(Yo(O)), r.push({
- startOffset: Y ? q : q + P.count,
- endOffset: oe ? V : V + b.count,
- collapsed: ce
- });
- }), {
- borderBoxPointGroup: o,
- contentBoxPointGroup: s,
- cursorList: r
- };
- }
- _isValidPosition(e, t) {
- const { segmentPage: o, pageType: s } = e, { segmentPage: r, pageType: i } = t;
- return s !== i ? !1 : s === Ie.HEADER || s === Ie.FOOTER ? o === r : !0;
- }
- _resetCurrentNodePositionState() {
- this._currentStartState = {
- page: 0,
- section: 0,
- column: 0,
- line: 0,
- divide: 0,
- glyph: 0
- /* NORMAL */
- }, this._currentEndState = {
- page: 0,
- section: 0,
- column: 0,
- line: 0,
- divide: 0,
- glyph: 0
- /* NORMAL */
- };
- }
- _setNodePositionState(e = 0, t, o, s) {
- s === t ? this._currentStartState[e] = 1 : this._currentStartState[e] = 0, s === o ? this._currentEndState[e] = 2 : this._currentEndState[e] = 0;
- }
- _checkPreviousNodePositionState(e, t = !0) {
- let o = e, s;
- for (; o >= 0; ) {
- const r = Bn[o];
- let i;
- if (t ? i = this._currentStartState[r] : i = this._currentEndState[r], i === void 0)
- return;
- if (s === void 0 && (s = i), i !== s)
- return 0;
- o--;
- }
- return s;
- }
- _getSelectionRuler(e, t, o, s, r) {
- let i = 0, a = s;
- const c = Bn[e], A = Bn[e + 1];
- if (A === null || c === null)
- return {
- start_next: i,
- end_next: a
- };
- const l = t[c], d = o[c];
- this._setNodePositionState(c, l, d, r);
- const h = this._checkPreviousNodePositionState(e), u = this._checkPreviousNodePositionState(e, !1);
- return h === 1 && (i = t[A]), u === 2 && (a = o[A]), {
- start_next: i,
- end_next: a
- };
- }
- // eslint-disable-next-line max-lines-per-function, complexity
- _selectionIterator(e, t, o) {
- var v, R;
- const s = this._docSkeleton;
- if (!s)
- return [];
- const { pageType: r, path: i } = e;
- this._liquid.reset();
- const a = s.getSkeletonData();
- if (a == null)
- return [];
- const { pages: c, skeHeaders: A, skeFooters: l } = a, { page: d, segmentPage: h } = e, { page: u, segmentPage: g } = t;
- if (this._resetCurrentNodePositionState(), this._documentOffsetConfig == null)
- return [];
- const { pageLayoutType: f, pageMarginLeft: p, pageMarginTop: m } = this._documentOffsetConfig, E = r === Ie.BODY || r === Ie.CELL ? d : h;
- for (let S = 0; S < E; S++) {
- const C = c[S];
- this._liquid.translatePage(C, f, p, m);
- }
- const I = r === Ie.BODY || r === Ie.CELL ? u : g;
- for (let S = E; S <= I; S++) {
- const C = c[S], { headerId: T, footerId: O, pageWidth: P } = C;
- let b = C;
- if (r === Ie.HEADER ? b = (v = A.get(T)) == null ? void 0 : v.get(P) : r === Ie.FOOTER ? b = (R = l.get(O)) == null ? void 0 : R.get(P) : r === Ie.CELL && (b = jo(a, i)), b == null) {
- this._liquid.translatePage(C, f, p, m);
- continue;
- }
- const B = b.sections, { start_next: M, end_next: H } = this._getSelectionRuler(
- Tt.page,
- e,
- t,
- B.length - 1,
- r === Ie.BODY || r === Ie.CELL ? S : 0
- );
- switch (this._liquid.translateSave(), r) {
- case Ie.HEADER:
- this._liquid.translatePagePadding({
- ...b,
- marginLeft: C.marginLeft
- // Because header or footer margin Left is 0.
- });
- break;
- case Ie.FOOTER: {
- const F = C.pageHeight - b.height - b.marginBottom;
- this._liquid.translate(C.marginLeft, F);
- break;
- }
- case Ie.CELL: {
- this._liquid.translatePagePadding(C);
- const F = b.parent, D = F.parent, { left: te } = b, { top: q, left: V } = D, { top: Y } = F;
- this._liquid.translate(V + te, q + Y), this._liquid.translatePagePadding(b);
- break;
- }
- default:
- this._liquid.translatePagePadding(C);
- break;
- }
- for (let F = M; F <= H; F++) {
- const D = B[F], te = D.columns, { start_next: q, end_next: V } = this._getSelectionRuler(
- Tt.section,
- e,
- t,
- te.length - 1,
- F
- );
- this._liquid.translateSection(D);
- for (let Y = q; Y <= V; Y++) {
- const oe = te[Y], ce = oe.lines, { start_next: he, end_next: Ae } = this._getSelectionRuler(
- Tt.column,
- e,
- t,
- ce.length - 1,
- Y
- );
- this._liquid.translateColumn(oe);
- for (let ne = he; ne <= Ae; ne++) {
- const ae = ce[ne], { divides: Te } = ae, { start_next: je, end_next: ut } = this._getSelectionRuler(
- Tt.line,
- e,
- t,
- Te.length - 1,
- ne
- );
- this._liquid.translateSave(), this._liquid.translateLine(ae, !0, !1);
- for (let we = je; we <= ut; we++) {
- const Yt = Te[we];
- this._liquid.translateSave(), this._liquid.translateDivide(Yt);
- const { glyphGroup: Qa } = Yt, { start_next: Ua, end_next: La } = this._getSelectionRuler(
- Tt.divide,
- e,
- t,
- Qa.length - 1,
- we
- );
- let cr = !1, Ar = !1;
- S === E && F === M && Y === q && ne === he && we === je && (cr = !0), S === I && F === H && Y === V && ne === Ae && we === ut && (Ar = !0), o && o(Ua, La, cr, Ar, Yt, ae, oe, D, b), this._liquid.translateRestore();
- }
- this._liquid.translateRestore();
- }
- }
- }
- this._liquid.translateRestore(), this._liquid.translatePage(C, f, p, m);
- }
- }
- }
- function SA(n, e) {
- const { path: t } = n, { path: o } = e;
- if (t.length !== o.length || t.indexOf("cells") === -1)
- return !1;
- const s = t.indexOf("skeTables") + 1, r = t.indexOf("rows") + 1, i = t.indexOf("cells") + 1, { tableId: a, sliceIndex: c } = pr(t[s]), { tableId: A, sliceIndex: l } = pr(o[s]);
- if (a !== A)
- return !1;
- const d = t[r], h = o[r], u = t[i], g = o[i];
- return !(d === h && u === g && c === l);
- }
- function Wi(n, e) {
- const { path: t } = n, { path: o } = e;
- return t.indexOf("cells") === -1 || o.indexOf("cells") === -1 || t.length !== o.length ? !1 : X.diffValue(t, o);
- }
- function zi(n, e, t) {
- var u, g, f, p, m, E, I, v;
- const { path: o } = e, { path: s } = t;
- if (o.indexOf("cells") === -1 || s.indexOf("cells") === -1)
- return !1;
- const r = n.findGlyphByPosition(e), i = n.findGlyphByPosition(t), a = (p = (f = (g = (u = r == null ? void 0 : r.parent) == null ? void 0 : u.parent) == null ? void 0 : g.parent) == null ? void 0 : f.parent) == null ? void 0 : p.parent, c = (v = (I = (E = (m = i == null ? void 0 : i.parent) == null ? void 0 : m.parent) == null ? void 0 : E.parent) == null ? void 0 : I.parent) == null ? void 0 : v.parent;
- if (a == null || c == null)
- return !1;
- const A = a.parent, l = c.parent, d = A.cells.indexOf(a), h = l.cells.indexOf(c);
- return d === h && A.index === l.index;
- }
- function yo(n, e) {
- if (Wi(n, e))
- return ys(n, e);
- const { path: t } = n, { path: o } = e, s = t[t.length - 5], r = o[o.length - 5];
- if (s !== r && typeof s == "string" && typeof r == "string") {
- const l = s.split("#-#")[1], d = r.split("#-#")[1];
- return +l < +d;
- }
- const i = t[t.length - 3], a = o[o.length - 3], c = t[t.length - 1], A = o[o.length - 1];
- return i < a ? !0 : i > a ? !1 : c <= A;
- }
- function vt(n) {
- return n.sections[0].columns[0].lines.length === 0;
- }
- function IA(n, e, t) {
- let o = e, s = t, r = n[o], i = n[s];
- for (; o < s && (vt(r) || vt(i)); )
- vt(r) ? (o++, r = n[o]) : vt(i) && (s--, i = n[s]);
- if (!vt(r) && !vt(i))
- return [r, i];
- }
- class Gi {
- constructor(e, t) {
- x(this, "_liquid", new bi());
- this._documentOffsetConfig = e, this._docSkeleton = t;
- }
- // eslint-disable-next-line max-lines-per-function
- getRangePointData(e, t) {
- const o = [], r = this._docSkeleton.getSkeletonData();
- if (r == null)
- return;
- const { pages: i } = r, { segmentPage: a, page: c, pageType: A } = e, l = this._getTableRectRangeInfo(e, t);
- if (l == null)
- return;
- const {
- tableId: d,
- startRowIndex: h,
- startColumnIndex: u,
- endRowIndex: g,
- endColumnIndex: f
- } = l;
- this._liquid.reset();
- const { pageLayoutType: p, pageMarginLeft: m, pageMarginTop: E } = this._documentOffsetConfig, I = A === Ie.BODY || A === Ie.CELL ? c : a;
- for (let v = 0; v < I; v++) {
- const R = i[v];
- this._liquid.translatePage(R, p, m, E);
- }
- for (let v = I; v < i.length; v++) {
- const R = i[v];
- this._liquid.translatePagePadding(R);
- const { skeTables: S } = R;
- let C = null;
- for (const [b, B] of S.entries())
- b.startsWith(d) && (C = B);
- if (C == null) {
- this._liquid.restorePagePadding(R), this._liquid.translatePage(R, p, m, E);
- continue;
- }
- this._liquid.translateSave(), this._liquid.translate(0, C.top);
- const { x: T, y: O } = this._liquid, { left: P } = C;
- for (const b of C.rows)
- if (b.index >= h && b.index <= g) {
- const B = IA(b.cells, u, f);
- if (B == null)
- continue;
- const [M, H] = B, F = {
- startX: T + M.left + P,
- startY: O + b.top,
- endX: T + H.left + H.pageWidth + P,
- endY: O + b.top + b.height
- };
- o.push(Yo(F));
- }
- this._liquid.translateRestore(), this._liquid.restorePagePadding(R), this._liquid.translatePage(R, p, m, E);
- }
- return {
- pointGroup: o,
- startRow: h,
- startColumn: u,
- endRow: g,
- endColumn: f,
- tableId: d
- };
- }
- getNodePositionGroup(e, t) {
- const o = [], s = this._docSkeleton.findCharIndexByPosition(e), r = this._docSkeleton.findCharIndexByPosition(t);
- if (s == null || r == null)
- return;
- const i = s < r, a = this._getTableRectRangeInfo(e, t);
- if (a == null)
- return;
- const { tableId: c, startRowIndex: A, startColumnIndex: l, endRowIndex: d, endColumnIndex: h } = a, u = this._docSkeleton.getViewModel().findTableNodeById(c);
- if (u == null)
- return;
- const g = u.children[0].children.length;
- if (l === 0 && h === g - 1) {
- const p = u.children[A].children[l], m = this._docSkeleton.findNodePositionByCharIndex(p.startIndex + 1), E = u.children[d].children[h], I = this._docSkeleton.findNodePositionByCharIndex(E.endIndex - 2);
- if (m == null || I == null)
- return;
- o.push({
- anchor: i ? m : I,
- focus: i ? I : m
- });
- } else
- for (let p = A; p <= d; p++) {
- const m = u.children[p], E = m.children[l], I = m.children[h], v = this._docSkeleton.findNodePositionByCharIndex(E.startIndex + 1), R = this._docSkeleton.findNodePositionByCharIndex(I.endIndex - 2);
- if (v == null || R == null)
- return;
- o.push({
- anchor: i ? v : R,
- focus: i ? R : v
- });
- }
- return o;
- }
- _getTableRectRangeInfo(e, t) {
- const s = this._docSkeleton.getSkeletonData();
- if (s == null)
- return;
- const { pages: r } = s, { path: i } = e, { path: a } = t, c = jo(s, i), A = jo(s, a);
- if (c == null || A == null)
- return;
- const l = c.segmentId, d = c.parent.index, h = c.parent.cells.indexOf(c), u = (A == null ? void 0 : A.parent).index, g = (A == null ? void 0 : A.parent).cells.indexOf(A), f = Math.min(d, u), p = Math.max(d, u), m = Math.min(h, g), E = Math.max(h, g);
- return {
- pages: r,
- tableId: l,
- startRowIndex: f,
- startColumnIndex: m,
- endRowIndex: p,
- endColumnIndex: E
- };
- }
- }
- const CA = "__TestSelectionRange__", vA = "__TestSelectionAnchor__", Br = 6, Bo = 500, RA = 500, qo = 3;
- function Mn(n) {
- const e = n[0], t = e[0], o = e[2], { x: s, y: r } = t, { x: i, y: a } = o;
- return {
- left: s,
- top: r,
- width: i - s,
- height: a - r
- };
- }
- function Bs(n) {
- return n.map((e) => {
- let t = 1 / 0, o = -1 / 0, s = 1 / 0, r = -1 / 0;
- return e.forEach((i) => {
- t = Math.min(i.x, t), o = Math.max(i.x, o), r = Math.max(i.y, r), s = Math.min(i.y, s);
- }), {
- left: t,
- right: o,
- top: s,
- bottom: r
- };
- });
- }
- class Mt {
- constructor(e, t, o, s, r, i = sn, a = "", c = -1) {
- x(this, "rangeType", Ge.TEXT);
- // Identifies whether the range is the current one, most of which is the last range.
- x(this, "_current", !1);
- // The rendered range graphic when collapsed is false
- x(this, "_rangeShape");
- // The rendered range graphic when collapsed is true
- x(this, "_anchorShape");
- x(this, "_cursorList", []);
- x(this, "_anchorBlinkTimer", null);
- this._scene = e, this._document = t, this._docSkeleton = o, this.anchorNodePosition = s, this.focusNodePosition = r, this.style = i, this._segmentId = a, this._segmentPage = c, this._anchorBlink(), this.refresh();
- }
- _anchorBlink() {
- setTimeout(() => {
- this._anchorShape && this._anchorShape.visible && this.deactivateStatic();
- }, Bo), this._anchorBlinkTimer = setInterval(() => {
- this._anchorShape && this._anchorShape.visible && (this.activeStatic(), setTimeout(() => {
- this.deactivateStatic();
- }, Bo));
- }, RA + Bo);
- }
- // The start position of the range
- get startOffset() {
- var s;
- const { startOffset: e } = (s = yr(this._cursorList)) != null ? s : {}, t = this._docSkeleton.getViewModel().getDataModel().getSelfOrHeaderFooterModel(this._segmentId).getBody();
- if (e == null || t == null)
- return e;
- const o = t.dataStream.length - 2;
- return Math.min(o, e);
- }
- // The end position of the range
- get endOffset() {
- var s;
- const { endOffset: e } = (s = yr(this._cursorList)) != null ? s : {}, t = this._docSkeleton.getViewModel().getDataModel().getSelfOrHeaderFooterModel(this._segmentId).getBody();
- if (e == null || t == null)
- return e;
- const o = t.dataStream.length - 2;
- return Math.min(e, o);
- }
- get collapsed() {
- const { startOffset: e, endOffset: t } = this;
- return e != null && e === t;
- }
- get startNodePosition() {
- if (this.anchorNodePosition == null)
- return null;
- if (this.focusNodePosition == null)
- return this.anchorNodePosition;
- const { start: e } = Go(this.anchorNodePosition, this.focusNodePosition);
- return e;
- }
- get endNodePosition() {
- if (this.anchorNodePosition == null)
- return this.focusNodePosition;
- if (this.focusNodePosition == null)
- return null;
- const { end: e } = Go(this.anchorNodePosition, this.focusNodePosition);
- return e;
- }
- get direction() {
- const { collapsed: e, anchorNodePosition: t, focusNodePosition: o } = this;
- return e || t == null || o == null ? xe.NONE : ys(t, o) ? xe.FORWARD : xe.BACKWARD;
- }
- get segmentId() {
- return this._segmentId;
- }
- get segmentPage() {
- return this._segmentPage;
- }
- getAbsolutePosition() {
- const e = this.anchorNodePosition, t = this.focusNodePosition;
- if (this._isEmpty())
- return;
- const o = this._document.getOffsetConfig(), { docsLeft: s, docsTop: r } = o, i = new it(o, this._docSkeleton);
- if (this._isCollapsed()) {
- const { contentBoxPointGroup: l, cursorList: d } = i.getRangePointData(e, e);
- if (this._setCursorList(d), l.length === 0)
- return;
- const h = Mn(l);
- return {
- ...h,
- left: h.left + s,
- top: h.top + r
- };
- }
- const { borderBoxPointGroup: a, cursorList: c } = i.getRangePointData(e, t);
- if (this._setCursorList(c), a.length === 0)
- return;
- const A = Mn(a);
- return {
- ...A,
- left: A.left + s,
- top: A.top + r
- };
- }
- getAnchor() {
- return this._anchorShape;
- }
- activeStatic() {
- var e, t;
- (t = this._anchorShape) == null || t.setProps({
- stroke: ((e = this.style) == null ? void 0 : e.strokeActive) || on(tn.black, 1)
- });
- }
- deactivateStatic() {
- var e, t;
- (t = this._anchorShape) == null || t.setProps({
- stroke: ((e = this.style) == null ? void 0 : e.stroke) || on(tn.black, 0)
- });
- }
- isActive() {
- return this._current === !0;
- }
- activate() {
- this._current = !0;
- }
- deactivate() {
- this._current = !1;
- }
- dispose() {
- var e, t;
- (e = this._rangeShape) == null || e.dispose(), this._rangeShape = null, (t = this._anchorShape) == null || t.dispose(), this._anchorShape = null, this._anchorBlinkTimer && (clearInterval(this._anchorBlinkTimer), this._anchorBlinkTimer = null);
- }
- isIntersection(e) {
- const { startOffset: t, endOffset: o } = this, { startOffset: s, endOffset: r } = e;
- return t == null || o == null || s == null || r == null ? !1 : t <= r && o >= s;
- }
- // render cursor and selection.
- refresh() {
- var d, h;
- const { _document: e, _docSkeleton: t } = this, o = this.anchorNodePosition, s = this.focusNodePosition;
- if ((d = this._anchorShape) == null || d.hide(), (h = this._rangeShape) == null || h.hide(), this._isEmpty())
- return;
- const r = e.getOffsetConfig(), { docsLeft: i, docsTop: a } = r, c = new it(r, t);
- if (this._isCollapsed()) {
- const { contentBoxPointGroup: u, cursorList: g } = c.getRangePointData(o, o);
- if (this._setCursorList(g), u.length > 0) {
- const f = t.findGlyphByPosition(o);
- this._createOrUpdateAnchor(u, i, a, f);
- }
- return;
- }
- const { borderBoxPointGroup: A, cursorList: l } = c.getRangePointData(o, s);
- this._setCursorList(l), A.length > 0 && this._createOrUpdateRange(A, i, a);
- }
- _isEmpty() {
- return this.anchorNodePosition == null && this.focusNodePosition == null;
- }
- _isCollapsed() {
- const e = this.anchorNodePosition, t = this.focusNodePosition;
- if (e != null && t == null)
- return !0;
- if (e == null || t == null)
- return !1;
- const o = Object.keys(Tt);
- for (const s of o) {
- const r = e[s], i = t[s];
- if (r !== i)
- return !1;
- }
- return e.isBack === t.isBack;
- }
- _createOrUpdateRange(e, t, o) {
- var i;
- if (this._rangeShape) {
- this._rangeShape.translate(t, o), this._rangeShape.updatePointGroup(e), this._rangeShape.show();
- return;
- }
- const s = 0.3, r = new Oi(CA + X.generateRandomId(Br), {
- pointsGroup: e,
- fill: ((i = this.style) == null ? void 0 : i.fill) || on(tn.black, s),
- left: t,
- top: o,
- evented: !1,
- debounceParentDirty: !1
- });
- this._rangeShape = r, this._scene.addObject(r, qo);
- }
- _createOrUpdateAnchor(e, t, o, s) {
- var f, p, m;
- const r = Mn(e), { left: i } = r;
- let { top: a, height: c } = r;
- const A = 14;
- c < A && (a -= A - c, c = A);
- const l = 12;
- let d = i + t;
- const h = a + o, u = ((f = s == null ? void 0 : s.ts) == null ? void 0 : f.it) === L.TRUE;
- if (u && (d += c * Math.tan(l * Math.PI / 180) / 2), this._anchorShape) {
- this._anchorShape.transformByState({ left: d, top: h, height: c }), this._anchorShape.show(), u ? this._anchorShape.skew(-12, 0) : this._anchorShape.skew(0, 0);
- return;
- }
- const g = new yn(vA + X.generateRandomId(Br), {
- left: d,
- top: h,
- height: c,
- strokeWidth: ((p = this.style) == null ? void 0 : p.strokeWidth) || 1.5,
- stroke: ((m = this.style) == null ? void 0 : m.strokeActive) || on(tn.black, 1),
- evented: !1
- });
- u && g.skew(-12, 0), this._anchorShape = g, this._scene.addObject(g, qo), this.activeStatic();
- }
- _setCursorList(e) {
- e.length !== 0 && (this._cursorList = e);
- }
- }
- const bA = "__DocTableRectRange__", xA = 6;
- function Mo(n, e, t, o, s, r = sn, i = "", a = -1) {
- const c = e.getOffsetConfig(), l = new Gi(c, t).getNodePositionGroup(o, s);
- return (l != null ? l : []).map((d) => new Yi(
- n,
- e,
- t,
- d.anchor,
- d.focus,
- r,
- i,
- a
- ));
- }
- class Yi {
- constructor(e, t, o, s, r, i = sn, a = "", c = -1) {
- x(this, "rangeType", Ge.RECT);
- // The rendered rect range
- x(this, "_rangeShape");
- // Identifies whether the range is the current one, most of which is the last range.
- x(this, "_current", !1);
- // Rect Range start row.
- x(this, "_startRow");
- // Rect Range start column.
- x(this, "_startCol");
- // Rect Range end row.
- x(this, "_endRow");
- // Rect Range end column.
- x(this, "_endCol");
- // table id in view model.
- x(this, "_tableId");
- this._scene = e, this._document = t, this._docSkeleton = o, this.anchorNodePosition = s, this.focusNodePosition = r, this.style = i, this._segmentId = a, this._segmentPage = c, this.refresh();
- }
- get startOffset() {
- const { startNodePosition: e } = this;
- return this._docSkeleton.findCharIndexByPosition(e);
- }
- get endOffset() {
- const { endNodePosition: e } = this;
- return this._docSkeleton.findCharIndexByPosition(e);
- }
- get collapsed() {
- return !1;
- }
- get startRow() {
- return this._startRow;
- }
- get startColumn() {
- return this._startCol;
- }
- get endRow() {
- return this._endRow;
- }
- get endColumn() {
- return this._endCol;
- }
- get tableId() {
- return this._tableId;
- }
- get segmentId() {
- return this._segmentId;
- }
- get segmentPage() {
- return this._segmentPage;
- }
- get spanEntireRow() {
- var i;
- const t = (i = this._docSkeleton.getViewModel().getSnapshot().tableSource) == null ? void 0 : i[this._tableId], { _startCol: o, _endCol: s } = this;
- if (t == null)
- throw new Error("Table is not found.");
- const { tableColumns: r } = t;
- return o === 0 && s === r.length - 1;
- }
- get spanEntireColumn() {
- var i;
- const t = (i = this._docSkeleton.getViewModel().getSnapshot().tableSource) == null ? void 0 : i[this._tableId], { _startRow: o, _endRow: s } = this;
- if (t == null)
- throw new Error("Table is not found.");
- const { tableRows: r } = t;
- return o === 0 && s === r.length - 1;
- }
- get spanEntireTable() {
- return this.spanEntireRow && this.spanEntireColumn;
- }
- get startNodePosition() {
- const { anchorNodePosition: e, focusNodePosition: t } = this;
- return yo(e, t) ? e : t;
- }
- get endNodePosition() {
- const { anchorNodePosition: e, focusNodePosition: t } = this;
- return yo(e, t) ? t : e;
- }
- get direction() {
- const { anchorNodePosition: e, focusNodePosition: t } = this;
- return yo(e, t) ? xe.FORWARD : xe.BACKWARD;
- }
- isActive() {
- return this._current === !0;
- }
- activate() {
- this._current = !0;
- }
- deactivate() {
- this._current = !1;
- }
- dispose() {
- var e;
- (e = this._rangeShape) == null || e.dispose(), this._rangeShape = null;
- }
- isIntersection(e) {
- const { startRow: t, startColumn: o, endRow: s, endColumn: r } = this, { startRow: i, startColumn: a, endRow: c, endColumn: A } = e, l = {
- left: o,
- top: t,
- right: r,
- bottom: s
- }, d = {
- left: a,
- top: i,
- right: A,
- bottom: c
- };
- return ka.hasIntersectionBetweenTwoRect(l, d);
- }
- refresh() {
- var p;
- (p = this._rangeShape) == null || p.hide();
- const { startNodePosition: e, endNodePosition: t, _document: o, _docSkeleton: s } = this, r = o.getOffsetConfig(), { docsLeft: i, docsTop: a } = r, A = new Gi(r, s).getRangePointData(e, t);
- if (A == null)
- return;
- const { pointGroup: l = [], startRow: d, endRow: h, startColumn: u, endColumn: g, tableId: f } = A;
- (l == null ? void 0 : l.length) > 0 && this._createOrUpdateRange(l, i, a), this._updateTableInfo(d, h, u, g, f);
- }
- _updateTableInfo(e, t, o, s, r) {
- this._startRow = e, this._endRow = t, this._startCol = o, this._endCol = s, this._tableId = r;
- }
- _createOrUpdateRange(e, t, o) {
- var i;
- if (this._rangeShape) {
- this._rangeShape.translate(t, o), this._rangeShape.updatePointGroup(e), this._rangeShape.show();
- return;
- }
- const s = 0.3, r = new Oi(bA + X.generateRandomId(xA), {
- pointsGroup: e,
- fill: ((i = this.style) == null ? void 0 : i.fill) || on(tn.black, s),
- left: t,
- top: o,
- evented: !1,
- debounceParentDirty: !1
- });
- this._rangeShape = r, this._scene.addObject(r, qo);
- }
- }
- function Mr(n, e, t, o, s, r, i, a, c = !0, A = !0) {
- const l = s.findNodePositionByCharIndex(n, c, i, a), d = s.findNodePositionByCharIndex(e, A, i, a);
- if (!(l == null || d == null))
- return new Mt(t, o, s, l, d, r, i, a);
- }
- function OA(n, e, t, o, s, r, i, a) {
- const c = s.findNodePositionByCharIndex(n, !0, i, a), A = s.findNodePositionByCharIndex(e, !0, i, a);
- if (!(c == null || A == null))
- return new Yi(t, o, s, c, A, r, i, a);
- }
- function TA(n, e, t, o, s, r, i, a) {
- const c = s.findNodePositionByCharIndex(n, !0, i, a), A = s.findNodePositionByCharIndex(e, !0, i, a);
- if (!(c == null || A == null))
- return Ko(
- c,
- A,
- t,
- o,
- s,
- r,
- i,
- a
- );
- }
- function Ko(n, e, t, o, s, r, i, a) {
- const c = [], A = [], l = [t, o, s, n, e, r, i, a];
- if (zi(s, n, e)) {
- if (Wi(n, e))
- return c.push(new Mt(...l)), {
- textRanges: c,
- rectRanges: A
- };
- {
- const I = Mo(
- ...l
- );
- return A.push(...I), {
- textRanges: c,
- rectRanges: A
- };
- }
- }
- if (SA(n, e)) {
- const I = Mo(
- ...l
- );
- return A.push(...I), {
- textRanges: c,
- rectRanges: A
- };
- }
- const d = s.getViewModel().getSelfOrHeaderFooterViewModel(i), h = s.findCharIndexByPosition(n), u = s.findCharIndexByPosition(e);
- if (h == null || u == null)
- return;
- const g = h <= u ? xe.FORWARD : xe.BACKWARD, f = Math.min(h, u), p = Math.max(h, u);
- let m = f, E = p;
- for (const I of d.getChildren())
- for (const v of I.children) {
- const { startIndex: R, endIndex: S, children: C } = v, T = I.children.indexOf(v), O = I.children[T + 1], P = C[0];
- let b = !1;
- if (P) {
- const { startIndex: B, endIndex: M, children: H } = P;
- let F = null, D = null;
- const te = H.find((V) => V.startIndex <= f && V.endIndex >= f), q = H.find((V) => V.startIndex <= p && V.endIndex >= p);
- if (f > B && f < M)
- F = s.findNodePositionByCharIndex(te.startIndex + 2, !0, i, a), D = s.findNodePositionByCharIndex(M - 4, !0, i, a), m = M + 1;
- else if (p > B && p < M)
- F = s.findNodePositionByCharIndex(B + 3, !0, i, a), D = s.findNodePositionByCharIndex(q.endIndex - 3, !0, i, a), E = B - 1, b = !0;
- else if (B > f && M < p) {
- if (F = s.findNodePositionByCharIndex(B + 3, !0, i, a), D = s.findNodePositionByCharIndex(M - 4, !0, i, a), m <= B - 1) {
- const V = s.findNodePositionByCharIndex(m, !0, i, a), Y = s.findNodePositionByCharIndex(B - 1, !1, i, a), oe = g === xe.FORWARD ? V : Y, ce = g === xe.FORWARD ? Y : V;
- c.push(new Mt(t, o, s, oe, ce, r, i, a));
- }
- m = M + 1;
- }
- if (F && D) {
- const V = g === xe.FORWARD ? F : D, Y = g === xe.FORWARD ? D : F;
- A.push(...Mo(
- t,
- o,
- s,
- V,
- Y,
- r,
- i,
- a
- ));
- }
- }
- if (E === S + 1 && !b && O && O.children.length && (E = S, b = !0), E >= R && E <= S || b) {
- const B = s.findNodePositionByCharIndex(m, !0, i, a), M = s.findNodePositionByCharIndex(E, !b, i, a), H = g === xe.FORWARD ? B : M, F = g === xe.FORWARD ? M : B;
- if (A.length && X.diffValue(H, F))
- continue;
- c.push(new Mt(t, o, s, H, F, r, i, a));
- }
- }
- return {
- textRanges: c,
- rectRanges: A
- };
- }
- function yA(n) {
- const e = n == null ? void 0 : n.getCanvasElement();
- if (!e)
- return {
- left: 0,
- top: 0
- };
- const { top: t, left: o } = cc(e);
- return {
- left: o,
- top: t
- };
- }
- function _r(n) {
- var c;
- const e = (c = n.parent) == null ? void 0 : c.parent, t = e == null ? void 0 : e.parent;
- if (e == null || t == null)
- return;
- const { paragraphIndex: o } = e, s = t.lines.filter((A) => A.paragraphIndex === o);
- let r = -1, i = "", a = !1;
- for (const A of s)
- for (const l of A.divides)
- for (const d of l.glyphGroup)
- a || (r += d.count), d === n && (a = !0), i += d.count > 0 ? d.content : "";
- return {
- st: s[0].st,
- ed: o,
- content: i,
- nodeIndex: r
- };
- }
- function Xo(n) {
- const { startOffset: e, endOffset: t, collapsed: o, rangeType: s, startNodePosition: r, endNodePosition: i, direction: a, segmentId: c, segmentPage: A } = n;
- return {
- startOffset: e,
- endOffset: t,
- collapsed: o,
- rangeType: s,
- startNodePosition: r,
- endNodePosition: i,
- direction: a,
- segmentId: c,
- segmentPage: A,
- isActive: n.isActive()
- };
- }
- function BA(n) {
- const e = Xo(n), {
- startRow: t,
- startColumn: o,
- endRow: s,
- endColumn: r,
- tableId: i,
- spanEntireRow: a,
- spanEntireColumn: c,
- spanEntireTable: A
- } = n;
- return {
- ...e,
- startRow: t,
- startColumn: o,
- endRow: s,
- endColumn: r,
- tableId: i,
- spanEntireRow: a,
- spanEntireColumn: c,
- spanEntireTable: A
- };
- }
- var MA = Object.defineProperty, _A = Object.getOwnPropertyDescriptor, PA = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? _A(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && MA(e, t, s), s;
- }, Cn = (n, e) => (t, o) => e(t, o, n);
- let Se = class extends At {
- constructor(e, t, o, s, r) {
- super();
- x(this, "_onInputBefore$", new Ee());
- x(this, "onInputBefore$", this._onInputBefore$.asObservable());
- x(this, "_onKeydown$", new Ee());
- x(this, "onKeydown$", this._onKeydown$.asObservable());
- x(this, "_onInput$", new Ee());
- x(this, "onInput$", this._onInput$.asObservable());
- x(this, "_onCompositionstart$", new Le(null));
- x(this, "onCompositionstart$", this._onCompositionstart$.asObservable());
- x(this, "_onCompositionupdate$", new Le(null));
- x(this, "onCompositionupdate$", this._onCompositionupdate$.asObservable());
- x(this, "_onCompositionend$", new Le(null));
- x(this, "onCompositionend$", this._onCompositionend$.asObservable());
- x(this, "_onSelectionStart$", new Le(null));
- x(this, "onSelectionStart$", this._onSelectionStart$.asObservable());
- x(this, "onChangeByEvent$", Fi(
- this._onInput$,
- this._onKeydown$.pipe(Qn((e) => e.event.keyCode === j.BACKSPACE)),
- this._onCompositionend$
- ));
- x(this, "_onPaste$", new Ee());
- x(this, "onPaste$", this._onPaste$.asObservable());
- x(this, "_textSelectionInner$", new Le(null));
- x(this, "textSelectionInner$", this._textSelectionInner$.asObservable());
- x(this, "_onFocus$", new Ee());
- x(this, "onFocus$", this._onFocus$.asObservable());
- x(this, "_onBlur$", new Ee());
- x(this, "onBlur$", this._onBlur$.asObservable());
- x(this, "_onPointerDown$", new Ee());
- x(this, "onPointerDown$", this._onPointerDown$.asObservable());
- x(this, "_container");
- x(this, "_inputParent");
- x(this, "_input");
- x(this, "_scrollTimers", []);
- x(this, "_rangeList", []);
- // Use to cache range list in moving.
- x(this, "_rangeListCache", []);
- // Rect range list.
- x(this, "_rectRangeList", []);
- // Use to cache rect range list in moving.
- x(this, "_rectRangeListCache", []);
- x(this, "_anchorNodePosition", null);
- x(this, "_focusNodePosition", null);
- x(this, "_currentSegmentId", "");
- x(this, "_currentSegmentPage", -1);
- x(this, "_selectionStyle", sn);
- x(this, "_onPointerEvent", !1);
- x(this, "_viewPortObserverMap", /* @__PURE__ */ new Map());
- x(this, "_isIMEInputApply", !1);
- x(this, "_scenePointerMoveSubs", []);
- x(this, "_scenePointerUpSubs", []);
- // When the user switches editors, whether to clear the doc ranges.
- x(this, "_reserveRanges", !1);
- this._context = e, this._layoutService = t, this._logService = o, this._univerInstanceService = s, this._docSkeletonManagerService = r, this._initDOM(), this._registerContainer(), this._setSystemHighlightColorToStyle(), this._listenCurrentUnitChange();
- }
- get isOnPointerEvent() {
- return this._onPointerEvent;
- }
- get isFocusing() {
- return this._input === document.activeElement;
- }
- get canFocusing() {
- return this.isFocusing || document.activeElement === document.body || document.activeElement === null;
- }
- _listenCurrentUnitChange() {
- this._univerInstanceService.getCurrentTypeOfUnit$(_.UNIVER_DOC).pipe(st(this.dispose$)).subscribe((e) => {
- if (e == null)
- return;
- e.getUnitId() !== this._context.unitId && !this._reserveRanges && this.removeAllRanges();
- });
- }
- get activeViewPort() {
- return this._context.scene.getViewports()[0];
- }
- setSegment(e) {
- this._currentSegmentId = e;
- }
- getSegment() {
- return this._currentSegmentId;
- }
- setSegmentPage(e) {
- this._currentSegmentPage = e;
- }
- getSegmentPage() {
- return this._currentSegmentPage;
- }
- setReserveRangesStatus(e) {
- this._reserveRanges = e;
- }
- _setRangeStyle(e = sn) {
- this._selectionStyle = e;
- }
- // eslint-disable-next-line max-lines-per-function
- addDocRanges(e, t = !0, o) {
- const {
- _currentSegmentId: s,
- _currentSegmentPage: r,
- _selectionStyle: i
- } = this, { scene: a, mainComponent: c } = this._context, A = c, l = this._docSkeletonManagerService.getSkeleton(), d = (h, u) => {
- const g = TA(
- h,
- u,
- a,
- A,
- l,
- i,
- s,
- r
- );
- if (g == null)
- return;
- const { textRanges: f, rectRanges: p } = g;
- for (const m of f)
- this._addTextRange(m);
- this._addRectRanges(p);
- };
- for (const h of e) {
- const { startOffset: u, endOffset: g, rangeType: f, startNodePosition: p, endNodePosition: m } = h;
- if (f === Ge.RECT) {
- const E = OA(
- u,
- g,
- a,
- A,
- l,
- i,
- s,
- r
- );
- E && this._addRectRanges([E]);
- } else if (f === Ge.TEXT)
- try {
- let E = null;
- p && m ? E = Mr(
- p.isBack ? u : u - 1,
- m.isBack ? g : g - 1,
- a,
- A,
- l,
- i,
- s,
- r,
- p.isBack,
- m.isBack
- ) : E = Mr(
- u,
- g,
- a,
- A,
- l,
- i,
- s,
- r
- ), E && this._addTextRange(E);
- } catch {
- d(u, g);
- }
- else
- d(u, g);
- }
- this._textSelectionInner$.next({
- textRanges: this._getAllTextRanges(),
- rectRanges: this._getAllRectRanges(),
- segmentId: s,
- segmentPage: r,
- style: i,
- isEditing: t,
- options: o
- }), this._updateInputPosition(o == null ? void 0 : o.forceFocus);
- }
- setCursorManually(e, t) {
- const o = this._findNodeByCoord(e, t, {
- strict: !0,
- segmentId: this._currentSegmentId,
- segmentPage: this._currentSegmentPage
- }), s = this._getNodePosition(o);
- if (s == null) {
- this._removeAllRanges();
- return;
- }
- (o == null ? void 0 : o.node.streamType) === U.PARAGRAPH && (s.isBack = !0), this._createTextRangeByAnchorPosition(s), this._textSelectionInner$.next({
- textRanges: this._getAllTextRanges(),
- rectRanges: this._getAllRectRanges(),
- segmentId: this._currentSegmentId,
- segmentPage: this._currentSegmentPage,
- style: this._selectionStyle,
- isEditing: !1
- });
- }
- // Sync canvas selection to dom selection.
- sync() {
- this._updateInputPosition();
- }
- /**
- * @deprecated
- */
- activate(e, t, o = !1) {
- this._container.style.left = `${e}px`, this._container.style.top = `${t}px`, this._container.style.zIndex = "1000", (this.canFocusing || o) && this.focus();
- }
- hasFocus() {
- return document.activeElement === this._input;
- }
- focus() {
- this._input.focus();
- }
- blur() {
- this._input.blur();
- }
- // FIXME: for editor cell editor we don't need to blur the input element
- /**
- * @deprecated
- */
- deactivate() {
- this._container.style.left = "0px", this._container.style.top = "0px";
- }
- // Handler double click.
- __handleDblClick(e) {
- const { offsetX: t, offsetY: o } = e, s = this._findNodeByCoord(t, o, {
- strict: !1,
- segmentId: this._currentSegmentId,
- segmentPage: this._currentSegmentPage
- });
- if (s == null || s.node == null)
- return;
- const r = _r(s.node);
- if (r == null)
- return;
- const { content: i, st: a, nodeIndex: c } = r;
- if (c === -1 || Intl.Segmenter == null)
- return;
- const l = new Intl.Segmenter(void 0, { granularity: "word" }).segment(i);
- let d = Number.NEGATIVE_INFINITY, h = Number.NEGATIVE_INFINITY;
- for (const { segment: u, index: g, isWordLike: f } of l)
- if (g <= c && c < g + u.length && f) {
- d = g + a, h = g + a + u.length;
- break;
- }
- if (Number.isFinite(d) && Number.isFinite(h)) {
- this.removeAllRanges();
- const u = [
- {
- startOffset: d,
- endOffset: h
- }
- ];
- this.addDocRanges(u, !1, { forceFocus: !0 });
- }
- }
- __handleTripleClick(e) {
- const { offsetX: t, offsetY: o } = e, s = this._findNodeByCoord(t, o, {
- strict: !1,
- segmentId: this._currentSegmentId,
- segmentPage: this._currentSegmentPage
- });
- if (s == null || s.node == null)
- return;
- const r = _r(s.node);
- if (r == null)
- return;
- this.removeAllRanges();
- const { st: i, ed: a } = r, c = [
- {
- startOffset: i,
- endOffset: a
- }
- ];
- this.addDocRanges(c, !1, { forceFocus: !0 });
- }
- // Handle pointer down.
- // eslint-disable-next-line max-lines-per-function, complexity
- __onPointDown(e) {
- var f, p;
- const { scene: t, mainComponent: o } = this._context, s = this._docSkeletonManagerService.getSkeleton(), { offsetX: r, offsetY: i } = e, a = this._findNodeByCoord(r, i, {
- strict: !1,
- segmentId: this._currentSegmentId,
- segmentPage: this._currentSegmentPage
- }), c = this._getNodePosition(a);
- if (c == null || a == null) {
- this._removeAllRanges();
- return;
- }
- (a == null ? void 0 : a.node.streamType) === U.PARAGRAPH && (c.isBack = !0);
- const A = this._textSelectionInner$.value;
- if (a && e.button === 2 && A) {
- const m = s.findCharIndexByPosition(c);
- if (typeof m == "number" && A.textRanges.some((E) => E.startOffset <= m && E.endOffset > m) || typeof m == "number" && A.rectRanges.some((E) => E.startOffset <= m && E.endOffset >= m))
- return;
- }
- const { segmentId: l, segmentPage: d } = a;
- l && this._currentSegmentId && l !== this._currentSegmentId && this.setSegment(l), l && d !== this._currentSegmentPage && this.setSegmentPage(d), this._anchorNodePosition = c, e.shiftKey && this._getActiveRangeInstance() ? this._updateActiveRangePosition(c) : e.ctrlKey ? this._removeAllCollapsedTextRanges() : this._isEmpty() || this._removeAllRanges(), t.disableObjectsEvent();
- const h = Ac.create(t);
- this._scrollTimers.push(h), h.startScroll(r, i), this._onSelectionStart$.next((f = this._getActiveRangeInstance()) == null ? void 0 : f.startNodePosition), (p = t.getTransformer()) == null || p.clearSelectedObjects();
- let u = r, g = i;
- this._onPointerEvent = !0, this._scenePointerMoveSubs.push(t.onPointerMove$.subscribeEvent((m) => {
- const { offsetX: E, offsetY: I } = m;
- t.setCursor(mt.TEXT), !(Math.sqrt((E - u) ** 2 + (I - g) ** 2) < 3) && (this._moving(E, I), h.scrolling(E, I, () => {
- this._moving(E, I);
- }), u = E, g = I);
- })), this._scenePointerUpSubs.push(t.onPointerUp$.subscribeEvent(() => {
- if ([...this._scenePointerMoveSubs, ...this._scenePointerUpSubs].forEach((E) => {
- E.unsubscribe();
- }), this._onPointerEvent = !1, t.enableObjectsEvent(), this._anchorNodePosition && !this._focusNodePosition) {
- if (e.ctrlKey) {
- this._disposeScrollTimers();
- return;
- }
- const E = new Mt(t, o, s, this._anchorNodePosition, void 0, this._selectionStyle, this._currentSegmentId, this._currentSegmentPage);
- this._addTextRange(E);
- } else if (this._anchorNodePosition && this._focusNodePosition) {
- for (const E of this._rangeListCache)
- e.ctrlKey ? E.collapsed ? E.dispose() : this._addTextRange(E) : this._addTextRange(E);
- this._addRectRanges(this._rectRangeListCache), this._rangeListCache = [], this._rectRangeListCache = [];
- }
- this._anchorNodePosition = null, this._focusNodePosition = null;
- const m = {
- textRanges: this._getAllTextRanges(),
- rectRanges: this._getAllRectRanges(),
- segmentId: this._currentSegmentId,
- segmentPage: this._currentSegmentPage,
- style: this._selectionStyle,
- isEditing: !1
- };
- this._textSelectionInner$.next(m), this._disposeScrollTimers(), this._updateInputPosition(!0);
- }));
- }
- removeAllRanges() {
- this._removeAllRanges(), this.deactivate();
- }
- getActiveTextRange() {
- return this._getActiveRangeInstance();
- }
- _disposeScrollTimers() {
- this._scrollTimers.forEach((e) => {
- e == null || e.dispose();
- }), this._scrollTimers = [];
- }
- _setSystemHighlightColorToStyle() {
- const { r: e, g: t, b: o, a: s } = lc(), r = {
- strokeWidth: 1.5,
- stroke: "rgba(0, 0, 0, 0)",
- strokeActive: "rgba(0, 0, 0, 1)",
- fill: `rgba(${e}, ${t}, ${o}, ${s != null ? s : 0.3})`
- };
- this._setRangeStyle(r);
- }
- _getAllTextRanges() {
- return this._rangeList.map(Xo);
- }
- _getAllRectRanges() {
- return this._rectRangeList.map(BA);
- }
- getAllTextRanges() {
- return this._getAllTextRanges();
- }
- getAllRectRanges() {
- return this._getAllRectRanges();
- }
- _getActiveRange() {
- const e = this._rangeList.find((s) => s.isActive());
- if (e == null)
- return null;
- const { startOffset: t, endOffset: o } = e;
- return t == null || o == null ? null : Xo(e);
- }
- _getActiveRangeInstance() {
- return this._rangeList.find((e) => e.isActive());
- }
- dispose() {
- super.dispose(), this._detachEvent(), this._removeAllRanges(), this._container.remove();
- }
- _initDOM() {
- const { unitId: e } = this._context, t = document.createElement("div");
- t.style.position = "fixed", t.style.left = "0px", t.style.top = "0px", t.id = `univer-doc-selection-container-${e}`;
- const o = document.createElement("div"), s = document.createElement("div");
- o.appendChild(s), t.appendChild(o), this._container = t, this._inputParent = o, this._input = s, this._initInput(), this._initInputEvents(), document.body.appendChild(t);
- }
- _registerContainer() {
- this.disposeWithMe(
- // the content editable div should be regarded as part of the applications container
- this._layoutService.registerContainerElement(this._container)
- );
- }
- _initInput() {
- this._inputParent.style.cssText = `
- position:absolute;
- height:1px;
- width:1px;
- overflow: hidden;
- `, this._input.contentEditable = "true", this._input.classList.add("univer-editor"), this._input.id = `__editor_${this._context.unitId}`, this._input.style.cssText = `
- position: absolute;
- overflow: hidden;
- opacity: 1;
- background: #000;
- color: transparent;
- outline: none;
- z-index: -2;
- caret-color: transparent;
- white-space: pre-wrap;
- user-select: text;
- `;
- }
- _getNodePosition(e) {
- if (e == null)
- return;
- const { node: t, ratioX: o, segmentPage: s } = e, i = this._docSkeletonManagerService.getSkeleton().findPositionByGlyph(t, s);
- if (i == null)
- return;
- let c = o < 0.5;
- return t.glyphType === xi.LIST && (c = !0), {
- ...i,
- isBack: c
- };
- }
- _interactTextRanges(e) {
- const t = [];
- for (const o of this._rangeList) {
- if (e.some((s) => s.isIntersection(o))) {
- o.dispose();
- continue;
- }
- t.push(o);
- }
- this._rangeList = t;
- }
- _interactRectRanges(e) {
- const t = [];
- for (const o of this._rectRangeList) {
- if (e.some((s) => s.isIntersection(o))) {
- o.dispose();
- continue;
- }
- t.push(o);
- }
- this._rectRangeList = t;
- }
- _removeAllRanges() {
- this._removeAllTextRanges(), this._removeAllRectRanges();
- }
- _removeAllCacheRanges() {
- this._rangeListCache.forEach((e) => {
- e.dispose();
- }), this._rectRangeListCache.forEach((e) => {
- e.dispose();
- }), this._rangeListCache = [], this._rectRangeListCache = [];
- }
- _removeAllTextRanges() {
- this._rangeList.forEach((e) => {
- e.dispose();
- }), this._rangeList = [];
- }
- _removeAllRectRanges() {
- this._rectRangeList.forEach((e) => {
- e.dispose();
- }), this._rectRangeList = [];
- }
- _removeAllCollapsedTextRanges() {
- for (const e of this._rangeList)
- e.collapsed && e.dispose();
- }
- _deactivateAllTextRanges() {
- this._rangeList.forEach((e) => {
- e.deactivate();
- });
- }
- _deactivateAllRectRanges() {
- this._rectRangeList.forEach((e) => {
- e.deactivate();
- });
- }
- _addTextRangesToCache(e) {
- this._rangeListCache.push(...e);
- }
- _addTextRange(e) {
- this._deactivateAllTextRanges(), e.activate(), this._rangeList.push(e);
- }
- _addRectRangesToCache(e) {
- this._rectRangeListCache.push(...e);
- }
- _addRectRanges(e) {
- e.length !== 0 && (this._deactivateAllRectRanges(), e[e.length - 1].activate(), this._rectRangeList.push(...e));
- }
- _createTextRangeByAnchorPosition(e) {
- this._removeAllRanges();
- const { scene: t, mainComponent: o } = this._context, s = this._docSkeletonManagerService.getSkeleton(), r = new Mt(t, o, s, e, void 0, this._selectionStyle, this._currentSegmentId, this._currentSegmentPage);
- this._addTextRange(r);
- }
- _updateActiveRangePosition(e) {
- const t = this._getActiveRangeInstance();
- if (t == null || t.anchorNodePosition == null) {
- this._logService.error(
- "[DocSelectionRenderService] _updateActiveRangeFocusPosition: active range has no anchor"
- );
- return;
- }
- this._removeAllRanges(), this._anchorNodePosition = t.anchorNodePosition, this._focusNodePosition = e;
- const { scene: o, mainComponent: s } = this._context, r = this._docSkeletonManagerService.getSkeleton(), { _anchorNodePosition: i, _focusNodePosition: a, _selectionStyle: c, _currentSegmentId: A, _currentSegmentPage: l } = this;
- if (i == null || a == null || s == null)
- return;
- const d = Ko(
- i,
- a,
- o,
- s,
- r,
- c,
- A,
- l
- );
- if (d == null)
- return;
- const { textRanges: h, rectRanges: u } = d;
- this._addTextRangesToCache(h), this._addRectRangesToCache(u), this.deactivate();
- }
- _isEmpty() {
- return this._rangeList.length === 0 && this._rectRangeList.length === 0;
- }
- _getCanvasOffset() {
- var t;
- const e = (t = this._context.scene) == null ? void 0 : t.getEngine();
- return yA(e);
- }
- _updateInputPosition(e = !1) {
- const t = this._getActiveRangeInstance(), o = t == null ? void 0 : t.getAnchor();
- if (!o || o && !o.visible || this.activeViewPort == null) {
- this.focus();
- return;
- }
- const { left: s, top: r } = o, i = this.activeViewPort.getAbsoluteVector(rn.FromArray([s, r])), { x: a, y: c } = i;
- let { left: A, top: l } = this._getCanvasOffset();
- A += a, l += c, this.activate(A, l, e);
- }
- _moving(e, t) {
- var m, E;
- const { _currentSegmentId: o, _currentSegmentPage: s } = this, r = this._findNodeByCoord(e, t, {
- strict: !0,
- segmentId: o,
- segmentPage: s
- }), i = this._getNodePosition(r);
- if (i == null || r == null)
- return;
- const a = r == null ? void 0 : r.node.parent, c = a == null ? void 0 : a.glyphGroup[a.glyphGroup.indexOf(r.node) + 1];
- (r == null ? void 0 : r.node.streamType) === U.PARAGRAPH && (c == null ? void 0 : c.streamType) === U.SECTION_BREAK && (i.isBack = !0), this._focusNodePosition = i, this._removeAllCacheRanges();
- const { _anchorNodePosition: A, _selectionStyle: l } = this, { scene: d, mainComponent: h } = this._context, u = this._docSkeletonManagerService.getSkeleton();
- if (A == null || h == null)
- return;
- const g = Ko(
- A,
- i,
- d,
- h,
- u,
- l,
- o,
- s
- );
- if (g == null)
- return;
- const { textRanges: f, rectRanges: p } = g;
- this._rangeList.length > 0 && f.length > 0 && this._interactTextRanges(f), this._rectRangeList.length > 0 && p.length > 0 && this._interactRectRanges(p), this._addTextRangesToCache(f), this._addRectRangesToCache(p), this.deactivate(), (E = (m = this._context.scene) == null ? void 0 : m.getEngine()) == null || E.setCapture();
- }
- __attachScrollEvent() {
- const e = this.activeViewPort;
- if (!e)
- return;
- const { unitId: t } = this._context;
- if (this._viewPortObserverMap.has(t))
- return;
- const o = e.onScrollAfter$.subscribeEvent((r) => {
- if (!r.viewport)
- return;
- const a = this._getActiveRangeInstance();
- a == null || a.activeStatic();
- }), s = e.onScrollEnd$.subscribeEvent((r) => {
- const i = r.viewport;
- if (!i)
- return;
- const a = i.getBounding(), c = this._getActiveRangeInstance(), A = c == null ? void 0 : c.getAnchor();
- if (!(!A || A && !A.visible)) {
- if (a) {
- const { left: l, top: d, right: h, bottom: u } = a.viewBound;
- if (A.left < l || A.left > h || A.top < d || A.top > u) {
- c == null || c.deactivateStatic();
- return;
- }
- }
- this._updateInputPosition();
- }
- });
- this._viewPortObserverMap.set(t, {
- scrollBefore: o,
- scrollStop: s
- });
- }
- // FIXME: listeners here are not correctly disposed
- // eslint-disable-next-line max-lines-per-function
- _initInputEvents() {
- this.disposeWithMe(
- Ue(this._input, "keydown").subscribe((e) => {
- this._isIMEInputApply || this._eventHandle(e, (t) => {
- this._onKeydown$.next(t);
- });
- })
- ), this.disposeWithMe(
- Ue(this._input, "input").subscribe((e) => {
- if (!(e.inputType === "historyUndo" || e.inputType === "historyRedo")) {
- if (this._rectRangeList.length > 0)
- return e.stopPropagation(), e.preventDefault();
- this._isIMEInputApply || this._eventHandle(e, (t) => {
- this._onInputBefore$.next(t), this._onInput$.next(t);
- });
- }
- })
- ), this.disposeWithMe(
- Ue(this._input, "compositionstart").subscribe((e) => {
- if (this._rectRangeList.length > 0)
- return e.stopPropagation(), e.preventDefault();
- this._isIMEInputApply = !0, this._eventHandle(e, (t) => {
- this._onCompositionstart$.next(t);
- });
- })
- ), this.disposeWithMe(
- Ue(this._input, "compositionend").subscribe((e) => {
- this._isIMEInputApply = !1, this._eventHandle(e, (t) => {
- this._onCompositionend$.next(t);
- });
- })
- ), this.disposeWithMe(
- Ue(this._input, "compositionupdate").subscribe((e) => {
- this._eventHandle(e, (t) => {
- this._onInputBefore$.next(t), this._onCompositionupdate$.next(t);
- });
- })
- ), this.disposeWithMe(
- Ue(this._input, "paste").subscribe((e) => {
- this._eventHandle(e, (t) => {
- this._onPaste$.next(t);
- });
- })
- ), this.disposeWithMe(
- Ue(this._input, "focus").subscribe((e) => {
- this._eventHandle(e, (t) => {
- this._onFocus$.next(t);
- });
- })
- ), this.disposeWithMe(
- Ue(this._input, "blur").subscribe((e) => {
- this._eventHandle(e, (t) => {
- this._onBlur$.next(t);
- });
- })
- );
- }
- _eventHandle(e, t) {
- const o = this._input.textContent || "";
- this._input.innerHTML = "";
- const s = this._getActiveRange(), r = this._getAllTextRanges();
- t({
- event: e,
- content: o,
- activeRange: s,
- rangeList: r
- });
- }
- _getTransformCoordForDocumentOffset(e, t) {
- const o = this._context.mainComponent, { documentTransform: s } = o.getOffsetConfig();
- if (this.activeViewPort == null || s == null)
- return;
- const r = this.activeViewPort.transformVector2SceneCoord(rn.FromArray([e, t]));
- if (r)
- return s.clone().invert().applyPoint(r);
- }
- _findNodeByCoord(e, t, o) {
- const s = this._getTransformCoordForDocumentOffset(e, t);
- if (s == null)
- return;
- const r = this._context.mainComponent, i = this._docSkeletonManagerService.getSkeleton(), {
- pageLayoutType: a = an.VERTICAL,
- pageMarginLeft: c,
- pageMarginTop: A
- } = r.getOffsetConfig();
- return i.findNodeByCoord(
- s,
- a,
- c,
- A,
- o
- );
- }
- _detachEvent() {
- this._onInputBefore$.complete(), this._onKeydown$.complete(), this._onInput$.complete(), this._onCompositionstart$.complete(), this._onCompositionupdate$.complete(), this._onCompositionend$.complete(), this._onSelectionStart$.complete(), this._textSelectionInner$.complete(), this._onPaste$.complete(), this._onFocus$.complete(), this._onBlur$.complete(), this._onPointerDown$.complete();
- }
- };
- Se = PA([
- Cn(1, bs),
- Cn(2, fs),
- Cn(3, Q),
- Cn(4, z(ie))
- ], Se);
- class DA extends ue {
- constructor(t, o, s, r, i) {
- super();
- // Emit change event when editor lose focus.
- x(this, "_change$", new Ee());
- x(this, "change$", this._change$.asObservable());
- // The input event fires when the value of a editor has been changed as a direct result of a user action.
- x(this, "_input$", new Ee());
- x(this, "input$", this._input$.asObservable());
- // paste event.
- x(this, "_paste$", new Ee());
- x(this, "paste$", this._paste$.asObservable());
- // Editor get focus.
- x(this, "_focus$", new Ee());
- x(this, "focus$", this._focus$.asObservable());
- // Editor lose focus.
- x(this, "_blur$", new Ee());
- x(this, "blur$", this._blur$.asObservable());
- // Emit when doc selection changed.
- x(this, "_selectionChange$", new Ee());
- x(this, "selectionChange$", this._selectionChange$.asObservable());
- this._param = t, this._univerInstanceService = o, this._docSelectionManagerService = s, this._commandService = r, this._undoRedoService = i, this._listenSelection();
- }
- get docSelectionRenderService() {
- return this._param.render.with(Se);
- }
- _listenSelection() {
- const t = this._param.render.with(Se);
- this.disposeWithMe(
- t.onBlur$.subscribe((o) => {
- this._blur$.next(o);
- const s = this.getDocumentData();
- this._change$.next({
- target: this,
- data: s
- });
- })
- ), this.disposeWithMe(
- t.onFocus$.subscribe((o) => {
- this._focus$.next(o);
- })
- ), this.disposeWithMe(
- t.onPaste$.subscribe((o) => {
- this._paste$.next(o);
- })
- ), this.disposeWithMe(
- Fi(
- t.onInput$,
- t.onKeydown$.pipe(zo((o) => {
- const s = o.event;
- return s.ctrlKey || s.metaKey ? [j.X, j.V].includes(s.keyCode) : [j.BACKSPACE].includes(s.keyCode);
- })),
- t.onCompositionupdate$,
- t.onCompositionend$,
- t.onPaste$
- ).subscribe((o) => {
- if (o == null)
- return;
- const { content: s = "" } = o, r = this.getDocumentData();
- this._input$.next({
- target: this,
- content: s,
- data: r,
- isComposing: o.event.type === "compositionupdate"
- });
- })
- ), this.disposeWithMe(
- this._docSelectionManagerService.textSelection$.subscribe((o) => {
- if (o == null)
- return;
- const { unitId: s, subUnitId: r, ...i } = o, a = this.getEditorId();
- s === a && this._selectionChange$.next(i);
- })
- );
- }
- isFocus() {
- const t = this._param.render.with(Se);
- return t.isFocusing && !!t.getActiveTextRange();
- }
- /**
- * @deprecated use `IEditorService.focus` as instead. this is for internal usage.
- */
- focus() {
- const t = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC), o = this.getEditorId();
- (t == null || t.getUnitId() !== o) && this._univerInstanceService.setCurrentUnitForType(o), this._param.render.with(Se).focus();
- }
- /**
- * @deprecated use `IEditorService.blur` as instead. this is for internal usage.
- */
- blur() {
- this._param.render.with(Se).blur();
- }
- // Selects the entire content of the editor.
- // Calling editor.select() will not necessarily focus the editor, so it is often used with Editor.focus
- select() {
- const t = this.getDocumentData();
- return this.setSelectionRanges([{
- startOffset: 0,
- endOffset: t.body ? t.body.dataStream.length - 2 : 0
- }]);
- }
- // Selects the specified range of characters within editor.
- setSelectionRanges(t) {
- const o = this.getEditorId(), s = {
- unitId: o,
- subUnitId: o
- };
- return this._docSelectionManagerService.replaceDocRanges(t, s, !1);
- }
- // Get current doc ranges. include text range and rect range.
- getSelectionRanges() {
- const t = this.getEditorId(), o = {
- unitId: t,
- subUnitId: t
- };
- return this._docSelectionManagerService.getDocRanges(o);
- }
- getCursorPosition() {
- var o, s;
- return (s = (o = this.getSelectionRanges().find((r) => r.collapsed)) == null ? void 0 : o.startOffset) != null ? s : -1;
- }
- // get editor id.
- getEditorId() {
- return this._getEditorId();
- }
- // get document data.
- getDocumentData() {
- return this._getDocDataModel().getSnapshot();
- }
- getDocumentDataModel() {
- return this._getDocDataModel();
- }
- // Set the new document data.
- setDocumentData(t, o) {
- const { id: s } = t;
- this._commandService.syncExecuteCommand(Vi.id, {
- unitId: s,
- snapshot: t,
- textRanges: o
- });
- }
- replaceText(t, o = !0) {
- const s = this.getDocumentData();
- this.setDocumentData(
- {
- ...s,
- body: {
- dataStream: `${t}\r
- `,
- paragraphs: [{
- startIndex: 0
- }],
- customRanges: [],
- sectionBreaks: [],
- tables: [],
- textRuns: []
- }
- },
- o ? [{
- startOffset: t.length,
- endOffset: t.length,
- collapsed: !0
- }] : null
- );
- }
- // Clear the undo redo history of this editor.
- clearUndoRedoHistory() {
- const t = this.getEditorId();
- return this._undoRedoService.clearUndoRedo(t);
- }
- dispose() {
- this._getDocDataModel().dispose();
- }
- /**
- * @deprecated use getEditorId.
- */
- get editorUnitId() {
- return this._param.editorUnitId;
- }
- /**
- * @deprecated @TODO: @JOCS remove this in the future.
- */
- get params() {
- return this._param;
- }
- get cancelDefaultResizeListener() {
- return this._param.cancelDefaultResizeListener;
- }
- get render() {
- return this._param.render;
- }
- isReadOnly() {
- return this._param.readonly === !0;
- }
- getBoundingClientRect() {
- return this._param.editorDom.getBoundingClientRect();
- }
- get editorDOM() {
- return this._param.editorDom;
- }
- isVisible() {
- return this._param.visible;
- }
- isSheetEditor() {
- return to(this._getEditorId());
- }
- /**
- * @deprecated use getDocumentData.
- */
- getValue() {
- var s;
- return (((s = this._getDocDataModel().getBody()) == null ? void 0 : s.dataStream) || "").replace(/\r\n/g, "").replace(/\n/g, "").replace(/\n/g, "");
- }
- /**
- * @deprecated use getDocumentData.
- */
- getBody() {
- return this._getDocDataModel().getBody();
- }
- /**
- * @deprecated.
- */
- update(t) {
- this._param = {
- ...this._param,
- ...t
- };
- }
- /**
- * @deprecated.
- */
- updateCanvasStyle() {
- var s;
- const t = this._getDocDataModel();
- if (t == null)
- return;
- const o = {};
- (s = this._param.canvasStyle) != null && s.fontSize && (o.textStyle == null && (o.textStyle = {}), o.textStyle.fs = this._param.canvasStyle.fontSize), t.updateDocumentStyle(o);
- }
- _getDocDataModel() {
- const t = this._getEditorId();
- return this._univerInstanceService.getUnit(t, _.UNIVER_DOC);
- }
- _getEditorId() {
- var t;
- return ((t = this._param.initialSnapshot) == null ? void 0 : t.id) || this._param.editorUnitId || "";
- }
- }
- var wA = Object.defineProperty, NA = Object.getOwnPropertyDescriptor, QA = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? NA(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && wA(e, t, s), s;
- }, Rt = (n, e) => (t, o) => e(t, o, n);
- const UA = [
- "univer-editor",
- "univer-range-selector",
- "univer-range-selector-editor",
- "univer-render-canvas",
- "univer-text-editor-container-placeholder"
- ];
- let Jo = class extends ue {
- constructor(e, t, o, s, r, i) {
- super();
- x(this, "_editors", /* @__PURE__ */ new Map());
- x(this, "_focusEditorUnitId");
- x(this, "_blur$", new Ee());
- x(this, "blur$", this._blur$.asObservable());
- x(this, "_focus$", new Ee());
- x(this, "focus$", this._focus$.asObservable());
- this._univerInstanceService = e, this._renderManagerService = t, this._docSelectionManagerService = o, this._contextService = s, this._commandService = r, this._undoRedoService = i, this._initUniverFocusListener();
- }
- // REFACTOR: @Gggpound The specific business processing should not be placed here,
- // I moved from the layout service. https://github.com/dream-num/univer-pro/issues/1708
- _initUniverFocusListener() {
- this.disposeWithMe(
- Ue(window, "focusin").subscribe((e) => {
- const t = e.target;
- this._blurSheetEditor(t);
- })
- );
- }
- _blurSheetEditor(e) {
- if (UA.some((o) => e.classList.contains(o)))
- return;
- const t = this.getFocusEditor();
- t && t.isSheetEditor() !== !0 && this.blur();
- }
- _setFocusId(e) {
- this._focusEditorUnitId = e;
- }
- getFocusId() {
- return this._focusEditorUnitId;
- }
- getFocusEditor() {
- if (this._focusEditorUnitId)
- return this.getEditor(this._focusEditorUnitId);
- }
- isEditor(e) {
- return this._editors.has(e);
- }
- isSheetEditor(e) {
- const t = this._editors.get(e);
- return !!(t && t.isSheetEditor());
- }
- blur() {
- this._setFocusId(null), this._contextService.setContextValue(wn, !1), this._contextService.setContextValue(lr, !1);
- const e = this.getFocusEditor();
- e == null || e.blur(), this._blur$.next(null);
- }
- focus(e) {
- if (this._focusEditorUnitId && this.blur(), e == null)
- return;
- const t = this.getEditor(e);
- if (t == null)
- return;
- this._univerInstanceService.setCurrentUnitForType(e);
- const o = t.getValue().length;
- this._contextService.setContextValue(wn, !0), to(e) || this._contextService.setContextValue(lr, !0), t.focus(), this._setFocusId(e), this._focus$.next({
- startOffset: o,
- endOffset: o
- });
- }
- dispose() {
- this._editors.clear(), super.dispose();
- }
- getEditor(e = this._getCurrentEditorUnitId()) {
- return this._editors.get(e);
- }
- getAllEditor() {
- return this._editors;
- }
- register(e, t) {
- var c, A, l, d;
- const { initialSnapshot: o, canvasStyle: s = {} } = e, r = o.id;
- this._univerInstanceService.getUnit(r, _.UNIVER_DOC) == null && this._univerInstanceService.createUnit(
- _.UNIVER_DOC,
- o || this._getBlank(r),
- { makeCurrent: !1 }
- );
- let a = this._renderManagerService.getRenderById(r);
- if (a == null && (this._renderManagerService.create(r), a = this._renderManagerService.getRenderById(r)), a) {
- a.engine.setContainer(t);
- const h = new DA(
- { ...e, render: a, editorDom: t, canvasStyle: s },
- this._univerInstanceService,
- this._docSelectionManagerService,
- this._commandService,
- this._undoRedoService
- );
- this._editors.set(r, h), e.scrollBar || (d = (l = (A = (c = a.mainComponent) == null ? void 0 : c.getScene()) == null ? void 0 : A.getViewports()) == null ? void 0 : l[0].getScrollBar()) == null || d.dispose();
- }
- return Zn(() => {
- this._unRegister(r);
- });
- }
- _unRegister(e) {
- const t = this._editors.get(e);
- t != null && (this._renderManagerService.removeRender(e), t.dispose(), this._editors.delete(e), this._univerInstanceService.disposeUnit(e));
- }
- _getCurrentEditorUnitId() {
- return this._univerInstanceService.getCurrentUniverDocInstance().getUnitId();
- }
- _getBlank(e) {
- return {
- id: e,
- body: {
- dataStream: `${pi}`,
- textRuns: [],
- paragraphs: [
- {
- startIndex: 0
- }
- ]
- },
- documentStyle: {
- renderConfig: {
- verticalAlign: Va.TOP,
- horizontalAlign: _e.LEFT
- },
- marginLeft: 3,
- marginTop: 0,
- marginRight: 3
- }
- };
- }
- };
- Jo = QA([
- Rt(0, Q),
- Rt(1, fe),
- Rt(2, z(G)),
- Rt(3, ms),
- Rt(4, y),
- Rt(5, eo)
- ], Jo);
- const He = ps("univer.editor.service");
- function LA(n) {
- const { editorId: e, initialValue: t, container: o, autoFocus: s, isSingle: r } = n, i = Fe(() => s != null ? s : !1, []), [a, c] = ve(), A = $(He);
- return kc(() => {
- var l, d;
- if (o.current) {
- const h = {
- body: {
- dataStream: `\r
- `,
- textRuns: [],
- customBlocks: [],
- customDecorations: [],
- customRanges: [],
- paragraphs: [{
- startIndex: 0
- }]
- },
- ...t,
- documentStyle: {
- ...t == null ? void 0 : t.documentStyle,
- pageSize: {
- width: r ? 1 / 0 : o.current.clientWidth,
- height: 1 / 0
- }
- },
- id: e
- }, u = A.register(
- {
- autofocus: !0,
- editorUnitId: e,
- initialSnapshot: h
- },
- o.current
- ), g = A.getEditor(e);
- if (c(g), i) {
- g.focus();
- const f = ((d = (l = h.body) == null ? void 0 : l.dataStream.length) != null ? d : 2) - 2;
- g.setSelectionRanges([{ startOffset: f, endOffset: f }]);
- }
- return () => {
- u == null || u.dispose();
- };
- }
- }, []), a;
- }
- const at = {
- id: "doc.operation.move-cursor",
- type: N.OPERATION,
- handler: (n, e) => !!e
- }, ct = {
- id: "doc.operation.move-selection",
- type: N.OPERATION,
- handler: (n, e) => !!e
- }, FA = (n, e, t, o) => {
- const s = $(y), r = $(ro), i = cn(e);
- i.current = e;
- const a = cn(o);
- a.current = o, Re(() => {
- if (!t || !n)
- return;
- const A = `sheet.formula-embedding-editor.${t.getEditorId()}`, l = new Dn(), d = (u, g) => {
- if (a.current) {
- a.current(u, g);
- return;
- }
- let f = se.LEFT;
- u === j.ARROW_DOWN ? f = se.DOWN : u === j.ARROW_UP ? f = se.UP : u === j.ARROW_RIGHT && (f = se.RIGHT), g === K.SHIFT ? s.executeCommand(ct.id, {
- direction: f
- }) : s.executeCommand(at.id, {
- direction: f
- });
- };
- return l.add(s.registerCommand({
- id: A,
- type: N.OPERATION,
- handler(u, g) {
- const { keyCode: f } = g;
- d(f);
- }
- })), [
- { keyCode: j.ARROW_DOWN },
- { keyCode: j.ARROW_LEFT },
- { keyCode: j.ARROW_RIGHT },
- { keyCode: j.ARROW_UP },
- { keyCode: j.ARROW_DOWN, metaKey: K.SHIFT },
- { keyCode: j.ARROW_LEFT, metaKey: K.SHIFT },
- { keyCode: j.ARROW_RIGHT, metaKey: K.SHIFT },
- { keyCode: j.ARROW_UP, metaKey: K.SHIFT },
- { keyCode: j.ARROW_DOWN, metaKey: K.CTRL_COMMAND },
- { keyCode: j.ARROW_LEFT, metaKey: K.CTRL_COMMAND },
- { keyCode: j.ARROW_RIGHT, metaKey: K.CTRL_COMMAND },
- { keyCode: j.ARROW_UP, metaKey: K.CTRL_COMMAND },
- { keyCode: j.ARROW_DOWN, metaKey: K.CTRL_COMMAND | K.SHIFT },
- { keyCode: j.ARROW_LEFT, metaKey: K.CTRL_COMMAND | K.SHIFT },
- { keyCode: j.ARROW_RIGHT, metaKey: K.CTRL_COMMAND | K.SHIFT },
- { keyCode: j.ARROW_UP, metaKey: K.CTRL_COMMAND | K.SHIFT }
- ].map(({ keyCode: u, metaKey: g }) => ({
- id: A,
- binding: g ? u | g : u,
- preconditions: () => !0,
- priority: 900,
- staticParameters: {
- eventType: Ri.Keyboard,
- keyCode: u
- }
- })).forEach((u) => {
- l.add(r.registerShortcut(u));
- }), () => {
- l.dispose();
- };
- }, [s, t, n, r]);
- };
- function HA(n, e) {
- const t = $(y);
- Re(() => {
- if (!n) return;
- const o = t.onCommandExecuted((s) => {
- if (s.id === J.id) {
- if (s.params.unitId !== n.getEditorId()) return;
- e(n.getDocumentData());
- }
- });
- return () => {
- o.dispose();
- };
- }, [n, e, t]);
- }
- const kA = "univer-rich-text-editor-active", VA = "univer-rich-text-editor-wrap", jA = "univer-rich-text-editor-text", WA = "univer-rich-text-editor-error-wrap", zA = "univer-rich-text-editor-placeholder", Xt = {
- richTextEditorActive: kA,
- richTextEditorWrap: VA,
- richTextEditorText: jA,
- richTextEditorErrorWrap: WA,
- richTextEditorPlaceholder: zA
- }, cf = It((n, e) => {
- var te;
- const {
- className: t,
- autoFocus: o,
- onFocusChange: s,
- initialValue: r,
- onClickOutside: i,
- keyboardEventConfig: a,
- moveCursor: c = !0,
- style: A,
- isSingle: l,
- editorId: d,
- onHeightChange: h,
- onChange: u,
- defaultHeight: g = 32,
- maxHeight: f = 32
- } = n, p = $(He), m = xo(s), E = xo(i), [I, v] = ve(g), R = Wo.useRef(null), S = Fe(() => d != null ? d : ja(`RICH_TEXT_EDITOR-${pt(4)}`), [d]), C = LA({
- editorId: S,
- initialValue: r,
- container: R,
- autoFocus: o,
- isSingle: l
- }), O = $(fe).getRenderById(S), P = O == null ? void 0 : O.with(Se), b = (te = P == null ? void 0 : P.isFocusing) != null ? te : !1, B = Wo.useRef(null), [M, H] = ve(() => {
- var q, V;
- return !Ce.transform.getPlainText((V = (q = C == null ? void 0 : C.getDocumentData().body) == null ? void 0 : q.dataStream) != null ? V : "");
- }), { checkScrollBar: F } = dA(C, l, !0, !0), D = xo((q) => {
- const V = O == null ? void 0 : O.with(ie), Y = V == null ? void 0 : V.getSkeleton().getActualSize();
- Y && (h == null || h(Y.actualHeight), v(Math.max(g, Math.min(Y.actualHeight + 10, f)))), u == null || u(q), F();
- });
- return Re(() => {
- var V, Y;
- H(!Ce.transform.getPlainText((Y = (V = C == null ? void 0 : C.getDocumentData().body) == null ? void 0 : V.dataStream) != null ? Y : ""));
- const q = C == null ? void 0 : C.selectionChange$.subscribe(() => {
- var oe, ce;
- H(!Ce.transform.getPlainText((ce = (oe = C == null ? void 0 : C.getDocumentData().body) == null ? void 0 : oe.dataStream) != null ? ce : ""));
- });
- return () => q == null ? void 0 : q.unsubscribe();
- }, [C]), Nn(C == null ? void 0 : C.blur$), Nn(C == null ? void 0 : C.focus$), Re(() => {
- m == null || m(b);
- }, [b, m]), Re(() => {
- const q = (V) => {
- var oe, ce;
- p.getFocusId() !== S || ((ce = (oe = V.target) == null ? void 0 : oe.dataset) == null ? void 0 : ce.editorid) === S || B.current && !B.current.contains(V.target) && (E == null || E());
- };
- return setTimeout(() => {
- document.addEventListener("click", q);
- }, 100), () => {
- document.removeEventListener("click", q);
- };
- }, [C, S, p, E]), FA(b && c, !1, C), lA(b, a, C), Vc(e, () => C, [C]), HA(C, D), /* @__PURE__ */ w.jsx("div", { className: Un(Xt.richTextEditor, t), style: A, children: /* @__PURE__ */ w.jsxs(
- "div",
- {
- className: Un(Xt.richTextEditorWrap, {
- [Xt.richTextEditorActive]: b
- }),
- style: { height: I },
- ref: B,
- children: [
- /* @__PURE__ */ w.jsx(
- "div",
- {
- className: Xt.richTextEditorText,
- ref: R,
- onMouseUp: () => C == null ? void 0 : C.focus()
- }
- ),
- M ? /* @__PURE__ */ w.jsx("div", { className: Xt.richTextEditorPlaceholder, children: n.placeholder }) : null
- ]
- }
- ) });
- });
- var Qe = function() {
- return Qe = Object.assign || function(n) {
- for (var e, t = 1, o = arguments.length; t < o; t++) {
- e = arguments[t];
- for (var s in e) Object.prototype.hasOwnProperty.call(e, s) && (n[s] = e[s]);
- }
- return n;
- }, Qe.apply(this, arguments);
- }, GA = function(n, e) {
- var t = {};
- for (var o in n) Object.prototype.hasOwnProperty.call(n, o) && e.indexOf(o) < 0 && (t[o] = n[o]);
- if (n != null && typeof Object.getOwnPropertySymbols == "function")
- for (var s = 0, o = Object.getOwnPropertySymbols(n); s < o.length; s++)
- e.indexOf(o[s]) < 0 && Object.prototype.propertyIsEnumerable.call(n, o[s]) && (t[o[s]] = n[o[s]]);
- return t;
- }, Ht = It(function(n, e) {
- var t = n.icon, o = n.id, s = n.className, r = n.extend, i = GA(n, ["icon", "id", "className", "extend"]), a = "univerjs-icon univerjs-icon-".concat(o, " ").concat(s || "").trim(), c = cn("_".concat(KA()));
- return qi(t, "".concat(o), { defIds: t.defIds, idSuffix: c.current }, Qe({ ref: e, className: a }, i), r);
- });
- function qi(n, e, t, o, s) {
- return Ft(n.tag, Qe(Qe({ key: e }, YA(n, t, s)), o), (qA(n, t).children || []).map(function(r, i) {
- return qi(r, "".concat(e, "-").concat(n.tag, "-").concat(i), t, void 0, s);
- }));
- }
- function YA(n, e, t) {
- var o = Qe({}, n.attrs);
- t != null && t.colorChannel1 && o.fill === "colorChannel1" && (o.fill = t.colorChannel1);
- var s = e.defIds;
- return !s || s.length === 0 || (n.tag === "use" && o["xlink:href"] && (o["xlink:href"] = o["xlink:href"] + e.idSuffix), Object.entries(o).forEach(function(r) {
- var i = r[0], a = r[1];
- typeof a == "string" && (o[i] = a.replace(/url\(#(.*)\)/, "url(#$1".concat(e.idSuffix, ")")));
- })), o;
- }
- function qA(n, e) {
- var t, o = e.defIds;
- return !o || o.length === 0 ? n : n.tag === "defs" && (!((t = n.children) === null || t === void 0) && t.length) ? Qe(Qe({}, n), { children: n.children.map(function(s) {
- return typeof s.attrs.id == "string" && o && o.indexOf(s.attrs.id) > -1 ? Qe(Qe({}, s), { attrs: Qe(Qe({}, s.attrs), { id: s.attrs.id + e.idSuffix }) }) : s;
- }) }) : n;
- }
- function KA() {
- return Math.random().toString(36).substring(2, 8);
- }
- Ht.displayName = "UniverIcon";
- var XA = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM1.9999 5.56641C1.66853 5.56641 1.3999 5.83504 1.3999 6.16641 1.3999 6.49778 1.66853 6.76641 1.9999 6.76641H13.9999C14.3313 6.76641 14.5999 6.49778 14.5999 6.16641 14.5999 5.83504 14.3313 5.56641 13.9999 5.56641H1.9999zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM1.9999 12.9004C1.66853 12.9004 1.3999 13.169 1.3999 13.5004 1.3999 13.8318 1.66853 14.1004 1.9999 14.1004H13.9999C14.3313 14.1004 14.5999 13.8318 14.5999 13.5004 14.5999 13.169 14.3313 12.9004 13.9999 12.9004H1.9999z" } }] }, Ki = It(function(n, e) {
- return Ft(Ht, Object.assign({}, n, {
- id: "align-text-both-single",
- ref: e,
- icon: XA
- }));
- });
- Ki.displayName = "AlignTextBothSingle";
- var JA = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM3.33315 5.56641C3.00178 5.56641 2.73315 5.83504 2.73315 6.16641 2.73315 6.49778 3.00178 6.76641 3.33315 6.76641H12.6665C12.9979 6.76641 13.2665 6.49778 13.2665 6.16641 13.2665 5.83504 12.9979 5.56641 12.6665 5.56641H3.33315zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM3.33315 12.9004C3.00178 12.9004 2.73315 13.169 2.73315 13.5004 2.73315 13.8318 3.00178 14.1004 3.33315 14.1004H12.6665C12.9979 14.1004 13.2665 13.8318 13.2665 13.5004 13.2665 13.169 12.9979 12.9004 12.6665 12.9004H3.33315z" } }] }, Xi = It(function(n, e) {
- return Ft(Ht, Object.assign({}, n, {
- id: "horizontally-single",
- ref: e,
- icon: JA
- }));
- });
- Xi.displayName = "HorizontallySingle";
- var ZA = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM1.9999 5.56641C1.66853 5.56641 1.3999 5.83504 1.3999 6.16641 1.3999 6.49778 1.66853 6.76641 1.9999 6.76641H11.3332C11.6646 6.76641 11.9332 6.49778 11.9332 6.16641 11.9332 5.83504 11.6646 5.56641 11.3332 5.56641H1.9999zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM1.9999 12.9004C1.66853 12.9004 1.3999 13.169 1.3999 13.5004 1.3999 13.8318 1.66853 14.1004 1.9999 14.1004H11.3332C11.6646 14.1004 11.9332 13.8318 11.9332 13.5004 11.9332 13.169 11.6646 12.9004 11.3332 12.9004H1.9999z" } }] }, Ji = It(function(n, e) {
- return Ft(Ht, Object.assign({}, n, {
- id: "left-justifying-single",
- ref: e,
- icon: ZA
- }));
- });
- Ji.displayName = "LeftJustifyingSingle";
- var $A = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM4.66665 5.56641C4.33528 5.56641 4.06665 5.83504 4.06665 6.16641 4.06665 6.49778 4.33528 6.76641 4.66665 6.76641H14C14.3314 6.76641 14.6 6.49778 14.6 6.16641 14.6 5.83504 14.3314 5.56641 14 5.56641H4.66665zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM4.66665 12.9004C4.33528 12.9004 4.06665 13.169 4.06665 13.5004 4.06665 13.8318 4.33528 14.1004 4.66665 14.1004H14C14.3314 14.1004 14.6 13.8318 14.6 13.5004 14.6 13.169 14.3314 12.9004 14 12.9004H4.66665z" } }] }, Zi = It(function(n, e) {
- return Ft(Ht, Object.assign({}, n, {
- id: "right-justifying-single",
- ref: e,
- icon: $A
- }));
- });
- Zi.displayName = "RightJustifyingSingle";
- var el = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M4.96372 2.59116C5.19803 2.35684 5.19803 1.97695 4.96372 1.74263 4.7294 1.50832 4.3495 1.50832 4.11519 1.74263L2.53945 3.31837 1.96372 2.74263C1.7294 2.50832 1.3495 2.50832 1.11519 2.74263.880874 2.97695.880874 3.35684 1.11519 3.59116L2.11519 4.59116C2.3495 4.82547 2.7294 4.82547 2.96372 4.59116L4.96372 2.59116zM14.4605 2.56689H6.8981C6.56672 2.56689 6.2981 2.83552 6.2981 3.16689 6.2981 3.49827 6.56672 3.76689 6.8981 3.76689H14.4605C14.7918 3.76689 15.0605 3.49827 15.0605 3.16689 15.0605 2.83552 14.7918 2.56689 14.4605 2.56689zM6.8981 7.2334C6.56672 7.2334 6.2981 7.50203 6.2981 7.8334 6.2981 8.16477 6.56672 8.4334 6.8981 8.4334H14.4605C14.7918 8.4334 15.0605 8.16477 15.0605 7.8334 15.0605 7.50203 14.7918 7.2334 14.4605 7.2334H6.8981zM6.2981 12.4999C6.2981 12.1685 6.56672 11.8999 6.8981 11.8999H14.4605C14.7918 11.8999 15.0605 12.1685 15.0605 12.4999 15.0605 12.8313 14.7918 13.0999 14.4605 13.0999H6.8981C6.56672 13.0999 6.2981 12.8313 6.2981 12.4999z" } }, { tag: "path", attrs: { fill: "currentColor", d: "M2.87279 5.8999C1.80504 5.8999.939453 6.76549.939453 7.83324.939453 8.90099 1.80504 9.76657 2.87279 9.76657 3.94054 9.76657 4.80612 8.90099 4.80612 7.83324 4.80612 6.76549 3.94054 5.8999 2.87279 5.8999zM2.13945 7.83324C2.13945 7.42823 2.46778 7.0999 2.87279 7.0999 3.2778 7.0999 3.60612 7.42823 3.60612 7.83324 3.60612 8.23824 3.2778 8.56657 2.87279 8.56657 2.46778 8.56657 2.13945 8.23824 2.13945 7.83324zM.939453 12.5002C.939453 11.4325 1.80504 10.5669 2.87279 10.5669 3.94054 10.5669 4.80612 11.4325 4.80612 12.5002 4.80612 13.568 3.94054 14.4336 2.87279 14.4336 1.80504 14.4336.939453 13.568.939453 12.5002zM2.87279 11.7669C2.46778 11.7669 2.13945 12.0952 2.13945 12.5002 2.13945 12.9052 2.46778 13.2336 2.87279 13.2336 3.2778 13.2336 3.60612 12.9052 3.60612 12.5002 3.60612 12.0952 3.2778 11.7669 2.87279 11.7669z", fillRule: "evenodd", clipRule: "evenodd" } }] }, $i = It(function(n, e) {
- return Ft(Ht, Object.assign({}, n, {
- id: "todo-list",
- ref: e,
- icon: el
- }));
- });
- $i.displayName = "TodoList";
- function ea(n) {
- var o;
- const { dataStream: e } = (o = n.body) != null ? o : {}, t = [
- U.TABLE_START,
- U.TABLE_CELL_END,
- U.TABLE_CELL_START,
- U.TABLE_END,
- U.TABLE_ROW_END,
- U.TABLE_ROW_START,
- U.COLUMN_BREAK,
- U.PAGE_BREAK,
- U.TAB,
- U.DOCS_END,
- U.CUSTOM_BLOCK
- ];
- if (typeof e == "string")
- for (let s = 0; s < e.length; s++) {
- const r = e[s];
- if (!t.includes(r))
- return s;
- }
- return 0;
- }
- const ta = "COMPONENT_DOC_HEADER_FOOTER_PANEL", tl = "univer-panel", nl = "univer-options-section", ol = "univer-options-form-item", sl = "univer-options-input", rl = "univer-options-margin-setting", Pe = {
- panel: tl,
- optionsSection: nl,
- optionsFormItem: ol,
- optionsInput: sl,
- optionsMarginSetting: rl
- };
- function il(n, e, t) {
- const { useFirstPageHeaderFooter: o, evenAndOddHeaders: s, defaultHeaderId: r, defaultFooterId: i, firstPageHeaderId: a, firstPageFooterId: c, evenPageHeaderId: A, evenPageFooterId: l } = n;
- return e === ge.HEADER ? o === L.TRUE ? t === 0 ? a : s === L.TRUE && t % 2 === 1 ? A : r : s === L.TRUE && t % 2 === 1 ? A : r : o === L.TRUE ? t === 0 ? c : s === L.TRUE && t % 2 === 1 ? l : i : s === L.TRUE && t % 2 === 1 ? l : i;
- }
- const al = (n) => {
- const e = $(Ze), t = $(Q), o = $(fe), s = $(y), r = $(bs), { unitId: i } = n, a = o.getRenderById(i).with(Se), [c, A] = ve({}), l = (u, g) => {
- var C;
- A((T) => ({
- ...T,
- [g]: u ? L.TRUE : L.FALSE
- }));
- const f = t.getUniverDocInstance(i), p = f == null ? void 0 : f.getSnapshot().documentStyle, m = (C = o.getRenderById(i)) == null ? void 0 : C.with(ie), E = m == null ? void 0 : m.getViewModel();
- if (p == null || E == null)
- return;
- const I = E.getEditArea();
- let v = !1;
- const R = a.getSegmentPage();
- let S = !1;
- if (g === "useFirstPageHeaderFooter" && u === !0 && ((I === ge.HEADER && !p.firstPageHeaderId || I === ge.FOOTER && !p.firstPageFooterId) && (v = !0), v && R === 0 && (S = !0)), g === "evenAndOddHeaders" && u === !0 && ((I === ge.HEADER && !p.evenPageHeaderId || I === ge.FOOTER && !p.evenPageFooterId) && (v = !0), v && R % 2 === 1 && (S = !0)), v) {
- const O = X.generateRandomId(6);
- S && a.setSegment(O), s.executeCommand(_n, {
- unitId: i,
- segmentId: O,
- headerFooterProps: {
- [g]: u ? L.TRUE : L.FALSE
- }
- });
- } else {
- const T = a.getSegmentPage(), O = a.getSegment(), P = il(
- {
- ...p,
- [g]: u ? L.TRUE : L.FALSE
- },
- I,
- T
- );
- P && P !== O && a.setSegment(P), s.executeCommand(_n, {
- unitId: i,
- headerFooterProps: {
- [g]: u ? L.TRUE : L.FALSE
- }
- });
- }
- r.focus();
- }, d = async (u, g) => {
- A((f) => ({
- ...f,
- [g]: u
- })), await s.executeCommand(_n, {
- unitId: i,
- headerFooterProps: {
- [g]: u
- }
- }), a.removeAllRanges(), a.blur();
- }, h = () => {
- s.executeCommand(Ps.id, {
- unitId: i
- });
- };
- return Re(() => {
- const u = t.getUniverDocInstance(i), g = u == null ? void 0 : u.getSnapshot().documentStyle;
- if (g) {
- const {
- marginHeader: f = 0,
- marginFooter: p = 0,
- useFirstPageHeaderFooter: m = L.FALSE,
- evenAndOddHeaders: E = L.FALSE
- } = g;
- A({
- marginHeader: f,
- marginFooter: p,
- useFirstPageHeaderFooter: m,
- evenAndOddHeaders: E
- });
- }
- }, [i]), /* @__PURE__ */ w.jsxs("div", { className: Pe.options, children: [
- /* @__PURE__ */ w.jsxs("div", { className: Pe.optionsSection, children: [
- /* @__PURE__ */ w.jsx("div", { className: Pe.optionsFormItem, children: /* @__PURE__ */ w.jsx(
- Rr,
- {
- checked: c.useFirstPageHeaderFooter === L.TRUE,
- onChange: (u) => {
- l(u, "useFirstPageHeaderFooter");
- },
- children: e.t("headerFooter.firstPageCheckBox")
- }
- ) }),
- /* @__PURE__ */ w.jsx("div", { className: Pe.optionsFormItem, children: /* @__PURE__ */ w.jsx(
- Rr,
- {
- checked: c.evenAndOddHeaders === L.TRUE,
- onChange: (u) => {
- l(u, "evenAndOddHeaders");
- },
- children: e.t("headerFooter.oddEvenCheckBox")
- }
- ) })
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: Un(Pe.optionsSection, Pe.optionsMarginSetting), children: [
- /* @__PURE__ */ w.jsxs("div", { className: Pe.optionsMarginItem, children: [
- /* @__PURE__ */ w.jsx("span", { children: e.t("headerFooter.headerTopMargin") }),
- /* @__PURE__ */ w.jsx(
- An,
- {
- min: 0,
- max: 200,
- precision: 1,
- value: c.marginHeader,
- onChange: (u) => {
- d(u, "marginHeader");
- },
- className: Pe.optionsInput
- }
- )
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: Pe.optionsMarginItem, children: [
- /* @__PURE__ */ w.jsx("span", { children: e.t("headerFooter.footerBottomMargin") }),
- /* @__PURE__ */ w.jsx(
- An,
- {
- min: 0,
- max: 200,
- precision: 1,
- value: c.marginFooter,
- onChange: (u) => {
- d(u, "marginFooter");
- },
- className: Pe.optionsInput
- }
- )
- ] })
- ] }),
- /* @__PURE__ */ w.jsx("div", { className: Pe.optionsSection, children: /* @__PURE__ */ w.jsx(qc, { onClick: h, children: e.t("headerFooter.closeHeaderFooter") }) })
- ] });
- }, cl = () => {
- var A;
- const n = $(Ze), e = $(fe), s = $(Q).getCurrentUniverDocInstance().getUnitId(), i = ((A = e.getRenderById(s)) == null ? void 0 : A.with(ie)).getViewModel(), [a, c] = ve(!0);
- return Re(() => {
- const l = i.getEditArea();
- c(l !== ge.BODY);
- const d = i.editAreaChange$.subscribe((h) => {
- h != null && c(h !== ge.BODY);
- });
- return () => {
- d.unsubscribe();
- };
- }, []), /* @__PURE__ */ w.jsx("div", { className: Pe.panel, children: a ? /* @__PURE__ */ w.jsx(al, { unitId: s }) : /* @__PURE__ */ w.jsx("div", { className: Pe.panelDisableText, children: n.t("headerFooter.disableText") }) });
- }, Pr = 18, Dr = 200, _o = 6, Al = 4;
- function ll(n, e) {
- let { radius: t, width: o, height: s } = e;
- t = t != null ? t : 0, o = o != null ? o : 30, s = s != null ? s : 30;
- let r = 0;
- r = Math.min(t, o / 2, s / 2), n.beginPath(), n.moveTo(0, 0), n.lineTo(o, 0), n.lineTo(o, s - r), n.arc(o - r, s - r, r, 0, Math.PI / 2, !1), n.lineTo(0, s), n.lineTo(0, 0), n.closePath(), e.fill && (n.save(), n.fillStyle = e.fill, e.fillRule === "evenodd" ? n.fill("evenodd") : n.fill(), n.restore());
- }
- class Ln extends dc {
- constructor(t, o) {
- super(t, o);
- x(this, "color");
- x(this, "text");
- this.color = o == null ? void 0 : o.color, this.text = o == null ? void 0 : o.text;
- }
- static drawWith(t, o) {
- const { text: s, color: r } = o;
- t.save(), t.font = "13px Source Han Sans CN";
- const i = t.measureText(s).width, a = Math.min(
- i + 2 * _o,
- Dr
- );
- ll(t, {
- height: Pr,
- width: a,
- radius: 4,
- fill: r,
- evented: !1
- }), t.fillStyle = "rgba(58, 96, 247, 1)";
- const c = _o, A = Pr - Al, l = Dr - 2 * _o;
- if (i > l) {
- let d = "", h = 0;
- for (const u of s) {
- const g = t.measureText(u).width;
- if (h + g <= l - t.measureText("...").width)
- d += u, h += g;
- else {
- d += "...";
- break;
- }
- }
- t.fillText(d, c, A);
- } else
- t.fillText(s, c, A);
- t.restore();
- }
- _draw(t) {
- Ln.drawWith(t, this);
- }
- }
- var dl = Object.defineProperty, ul = Object.getOwnPropertyDescriptor, hl = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? ul(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && dl(e, t, s), s;
- }, nt = (n, e) => (t, o) => e(t, o, n);
- const wr = "rgba(58, 96, 247, 1)", Nr = "rgba(58, 96, 247, 0.08)";
- var Me = /* @__PURE__ */ ((n) => (n[n.FIRST_PAGE_HEADER = 0] = "FIRST_PAGE_HEADER", n[n.FIRST_PAGE_FOOTER = 1] = "FIRST_PAGE_FOOTER", n[n.DEFAULT_HEADER = 2] = "DEFAULT_HEADER", n[n.DEFAULT_FOOTER = 3] = "DEFAULT_FOOTER", n[n.EVEN_PAGE_HEADER = 4] = "EVEN_PAGE_HEADER", n[n.EVEN_PAGE_FOOTER = 5] = "EVEN_PAGE_FOOTER", n))(Me || {});
- function gl(n, e, t) {
- const { documentStyle: o } = n.getDataModel().getSnapshot(), {
- defaultHeaderId: s,
- defaultFooterId: r,
- evenPageHeaderId: i,
- evenPageFooterId: a,
- firstPageHeaderId: c,
- firstPageFooterId: A,
- evenAndOddHeaders: l,
- useFirstPageHeaderFooter: d
- } = o;
- switch (e) {
- case ge.BODY:
- return {
- createType: null,
- headerFooterId: null
- };
- case ge.HEADER:
- return d === L.TRUE && !c ? {
- createType: 0,
- headerFooterId: null
- } : l === L.TRUE && t % 2 === 0 && !i ? {
- createType: 4,
- headerFooterId: null
- } : s ? {
- createType: null,
- headerFooterId: s
- } : {
- createType: 2,
- headerFooterId: null
- };
- case ge.FOOTER:
- return d === L.TRUE && !A ? {
- createType: 1,
- headerFooterId: null
- } : l === L.TRUE && t % 2 === 0 && !a ? {
- createType: 5,
- headerFooterId: null
- } : r ? {
- createType: null,
- headerFooterId: r
- } : {
- createType: 3,
- headerFooterId: null
- };
- default:
- throw new Error(`Invalid editArea: ${e}`);
- }
- }
- let Zo = class extends ue {
- constructor(e, t, o, s, r, i, a, c, A) {
- super();
- x(this, "_loadedMap", /* @__PURE__ */ new WeakSet());
- this._context = e, this._commandService = t, this._editorService = o, this._instanceSrv = s, this._renderManagerService = r, this._docSkeletonManagerService = i, this._docSelectionRenderService = a, this._localeService = c, this._componentManager = A, this._initialize();
- }
- _initialize() {
- this._init(), this._drawHeaderFooterLabel(), this._initCustomComponents(), this._listenSwitchMode();
- }
- // Close header footer panel when switch mode.
- _listenSwitchMode() {
- this.disposeWithMe(
- this._commandService.onCommandExecuted((e) => {
- if (J.id === e.id) {
- const t = this._context.unit, s = this._docSkeletonManagerService.getViewModel().getEditArea(), r = t.getSnapshot().documentStyle.documentFlavor;
- s !== ge.BODY && r === ye.MODERN && this._commandService.executeCommand(Ps.id, {
- unitId: this._context.unitId
- });
- }
- })
- );
- }
- _initCustomComponents() {
- const e = this._componentManager;
- this.disposeWithMe(e.register(ta, cl));
- }
- _init() {
- const { unitId: e } = this._context, t = rt(this._context);
- t == null || t.document == null || this._loadedMap.has(t.document) || (this._initialMain(e), this._loadedMap.add(t.document));
- }
- _initialMain(e) {
- const t = rt(this._context), { document: o } = t;
- this.disposeWithMe(o.onDblclick$.subscribeEvent(async (s) => {
- if (this._isEditorReadOnly(e) || !this._isTraditionalMode())
- return;
- const { offsetX: r, offsetY: i } = s, {
- pageLayoutType: a = an.VERTICAL,
- pageMarginLeft: c,
- pageMarginTop: A
- } = o.getOffsetConfig(), l = this._getTransformCoordForDocumentOffset(r, i);
- if (l == null)
- return;
- const d = this._docSkeletonManagerService.getViewModel(), h = this._docSkeletonManagerService.getSkeleton(), u = d.getEditArea(), { editArea: g, pageNumber: f } = h.findEditAreaByCoord(
- l,
- a,
- c,
- A
- );
- if (u === g)
- return;
- d.setEditArea(g);
- const { createType: p, headerFooterId: m } = gl(d, g, f);
- if (g === ge.BODY)
- this._docSelectionRenderService.setSegment(""), this._docSelectionRenderService.setSegmentPage(-1), this._docSelectionRenderService.setCursorManually(r, i);
- else if (p != null) {
- const I = X.generateRandomId(6);
- this._docSelectionRenderService.setSegment(I), this._docSelectionRenderService.setSegmentPage(f), await this._commandService.executeCommand(na.id, {
- unitId: e,
- createType: p,
- segmentId: I
- });
- } else m != null && (this._docSelectionRenderService.setSegment(m), this._docSelectionRenderService.setSegmentPage(f), this._docSelectionRenderService.setCursorManually(r, i));
- }));
- }
- _getTransformCoordForDocumentOffset(e, t) {
- const o = rt(this._context), { document: s, scene: r } = o, { documentTransform: i } = s.getOffsetConfig(), a = r.getViewports()[0];
- if (a == null)
- return;
- const c = a.transformVector2SceneCoord(rn.FromArray([e, t]));
- return i.clone().invert().applyPoint(c);
- }
- // eslint-disable-next-line max-lines-per-function
- _drawHeaderFooterLabel() {
- const e = this._localeService;
- this._renderManagerService.currentRender$.subscribe((t) => {
- if (t == null)
- return;
- const o = this._renderManagerService.getRenderById(t);
- if (this._editorService.isEditor(t) || this._instanceSrv.getUniverDocInstance(t) == null || o == null)
- return;
- const { mainComponent: s } = o, r = s;
- this.disposeWithMe(
- Zn(
- // eslint-disable-next-line max-lines-per-function
- r.pageRender$.subscribe((i) => {
- if (this._editorService.isEditor(t) || !this._isTraditionalMode())
- return;
- const A = this._docSkeletonManagerService.getViewModel().getEditArea() === ge.BODY, { page: l, pageLeft: d, pageTop: h, ctx: u } = i, { pageWidth: g, pageHeight: f, marginTop: p, marginBottom: m } = l;
- if (u.save(), u.translate(d - 0.5, h - 0.5), A ? (yn.drawWith(u, {
- left: 0,
- top: 0,
- width: g,
- height: p,
- fill: "rgba(255, 255, 255, 0.5)"
- }), u.save(), u.translate(0, f - m), yn.drawWith(u, {
- left: 0,
- top: 0,
- width: g,
- height: m,
- fill: "rgba(255, 255, 255, 0.5)"
- }), u.restore()) : (u.save(), u.translate(0, p), yn.drawWith(u, {
- left: 0,
- top: p,
- width: g,
- height: f - p - m,
- fill: "rgba(255, 255, 255, 0.5)"
- }), u.restore()), !A) {
- const E = {
- dataArray: [{
- command: "M",
- points: [0, p]
- }, {
- command: "L",
- points: [g, p]
- }],
- strokeWidth: 1,
- stroke: wr
- }, I = {
- dataArray: [{
- command: "M",
- points: [0, f - m]
- }, {
- command: "L",
- points: [g, f - m]
- }],
- strokeWidth: 1,
- stroke: wr
- };
- mr.drawWith(u, E), mr.drawWith(u, I), u.translate(0, p + 1), Ln.drawWith(u, {
- text: e.t("headerFooter.header"),
- color: Nr
- }), u.translate(0, f - p - m), Ln.drawWith(u, {
- text: e.t("headerFooter.footer"),
- color: Nr
- });
- }
- u.restore();
- })
- )
- );
- });
- }
- _isEditorReadOnly(e) {
- const t = this._editorService.getEditor(e);
- return t ? t.isReadOnly() : !1;
- }
- _isTraditionalMode() {
- return this._context.unit.getSnapshot().documentStyle.documentFlavor === ye.TRADITIONAL;
- }
- };
- Zo = hl([
- nt(1, y),
- nt(2, He),
- nt(3, Q),
- nt(4, fe),
- nt(5, z(ie)),
- nt(6, z(Se)),
- nt(7, z(Ze)),
- nt(8, z(io))
- ], Zo);
- const Ms = {
- id: "sidebar.operation.doc-header-footer-panel",
- type: N.OPERATION,
- handler: async (n, e) => {
- const t = n.get(Bi), o = n.get(Ze);
- switch (e.value) {
- case "open":
- t.open({
- header: { title: o.t("headerFooter.panel") },
- children: { label: ta },
- onClose: () => {
- },
- width: 400
- });
- break;
- case "close":
- default:
- t.close();
- break;
- }
- return !0;
- }
- };
- function Qr() {
- return {
- dataStream: `\r
- `,
- textRuns: [{
- st: 0,
- ed: 0,
- ts: {
- fs: 9
- // The default header footer text size.
- }
- }],
- customBlocks: [],
- paragraphs: [
- {
- startIndex: 0,
- paragraphStyle: {
- spaceAbove: { v: 0 },
- lineSpacing: 1.5,
- spaceBelow: { v: 0 }
- }
- }
- ],
- sectionBreaks: [
- {
- startIndex: 1
- }
- ]
- };
- }
- function Po(n, e, t, o) {
- const s = k.getInstance(), r = 6, i = n != null ? n : X.generateRandomId(r), a = e === Me.DEFAULT_HEADER || e === Me.FIRST_PAGE_HEADER || e === Me.EVEN_PAGE_HEADER, c = s.insertOp([a ? "headers" : "footers", i], {
- [a ? "headerId" : "footerId"]: i,
- body: Qr()
- });
- o.push(c);
- const A = X.generateRandomId(r), l = s.insertOp([a ? "footers" : "headers", A], {
- [a ? "footerId" : "headerId"]: A,
- body: Qr()
- });
- o.push(l);
- let d = "defaultHeaderId", h = "defaultFooterId";
- switch (e) {
- case Me.DEFAULT_HEADER:
- d = "defaultHeaderId", h = "defaultFooterId";
- break;
- case Me.DEFAULT_FOOTER:
- d = "defaultFooterId", h = "defaultHeaderId";
- break;
- case Me.FIRST_PAGE_HEADER:
- d = "firstPageHeaderId", h = "firstPageFooterId";
- break;
- case Me.FIRST_PAGE_FOOTER:
- d = "firstPageFooterId", h = "firstPageHeaderId";
- break;
- case Me.EVEN_PAGE_HEADER:
- d = "evenPageHeaderId", h = "evenPageFooterId";
- break;
- case Me.EVEN_PAGE_FOOTER:
- d = "evenPageFooterId", h = "evenPageHeaderId";
- break;
- default:
- throw new Error(`Unknown header footer type: ${e}`);
- }
- for (const [u, g] of [[d, i], [h, A]])
- if (t[u] != null) {
- const f = s.replaceOp(["documentStyle", u], t[u], g);
- o.push(f);
- } else {
- const f = s.insertOp(["documentStyle", u], g);
- o.push(f);
- }
- return o;
- }
- const _n = "doc.command.core-header-footer", na = {
- id: _n,
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n, e) => {
- var v;
- const t = n.get(y), o = n.get(Q), s = n.get(fe), { unitId: r, segmentId: i, createType: a, headerFooterProps: c } = e, A = (v = s.getRenderById(r)) == null ? void 0 : v.with(ie), l = o.getUniverDocInstance(r), d = A == null ? void 0 : A.getViewModel();
- if (l == null || d == null)
- return !1;
- const h = d.getEditArea(), { documentStyle: u } = l.getSnapshot(), g = (c == null ? void 0 : c.marginFooter) != null || (c == null ? void 0 : c.marginHeader) != null, f = [{
- startOffset: 0,
- endOffset: 0,
- collapsed: !0
- }], p = {
- id: J.id,
- params: {
- unitId: r,
- actions: [],
- textRanges: f,
- debounce: !0
- }
- };
- g && (p.params.noNeedSetTextRange = !0);
- const m = k.getInstance(), E = [];
- return a != null && Po(i, a, u, E), c != null && Object.keys(c).forEach((R) => {
- const S = c[R], C = u[R];
- if (S === C)
- return;
- let T;
- if (C === void 0 ? T = m.insertOp(["documentStyle", R], S) : T = m.replaceOp(["documentStyle", R], C, S), E.push(T), R === "useFirstPageHeaderFooter" && S === L.TRUE && !u.firstPageHeaderId) {
- const O = h === ge.HEADER ? Me.FIRST_PAGE_HEADER : Me.FIRST_PAGE_FOOTER;
- Po(i, O, u, E);
- } else if (R === "evenAndOddHeaders" && S === L.TRUE && !u.evenPageHeaderId) {
- const O = h === ge.HEADER ? Me.EVEN_PAGE_HEADER : Me.EVEN_PAGE_FOOTER;
- Po(i, O, u, E);
- }
- }), E.length === 0 ? !1 : (p.params.actions = E.reduce((R, S) => k.compose(R, S), null), !!t.syncExecuteCommand(p.id, p.params));
- }
- }, _s = {
- id: "doc.command.open-header-footer-panel",
- type: N.COMMAND,
- handler: async (n, e) => n.get(y).executeCommand(Ms.id, { value: "open" })
- }, Ps = {
- id: "doc.command.close-header-footer",
- type: N.COMMAND,
- handler: async (n, e) => {
- var g;
- const t = n.get(y), o = n.get(fe), s = n.get(G), r = n.get(Q), { unitId: i } = e, a = o.getRenderById(i);
- if (a == null)
- return !1;
- const { scene: c } = a, A = c.getTransformerByCreate(), l = a.with(ie), d = a.with(Se), h = l == null ? void 0 : l.getSkeleton(), u = l == null ? void 0 : l.getViewModel();
- return u == null || h == null ? !1 : (s.replaceDocRanges([]), A.clearSelectedObjects(), d.setSegment(""), d.setSegmentPage(-1), u.setEditArea(ge.BODY), h.calculate(), (g = a.mainComponent) == null || g.makeDirty(!0), queueMicrotask(() => {
- const f = r.getUnit(i), p = f == null ? void 0 : f.getSnapshot();
- if (p == null)
- return;
- const m = ea(p);
- s.replaceDocRanges([
- {
- startOffset: m,
- endOffset: m
- }
- ]);
- }), t.executeCommand(Ms.id, { value: "close" }), !0);
- }
- }, kt = "UI_PLUGIN_DOCS", Ds = `${kt}_COLOR_PICKER_COMPONENT`, oa = `${kt}_FONT_FAMILY_COMPONENT`, sa = `${kt}_FONT_FAMILY_ITEM_COMPONENT`, ra = `${kt}_FONT_SIZE_COMPONENT`, fl = "univer-doc-list-type-picker", pl = "univer-doc-list-type-picker-item", ml = "univer-doc-list-type-picker-item-active", Do = {
- docListTypePicker: fl,
- docListTypePickerItem: pl,
- docListTypePickerItemActive: ml
- }, ia = (n) => {
- const { value: e, onChange: t, options: o } = n;
- return /* @__PURE__ */ w.jsx("div", { className: Do.docListTypePicker, children: o.map((s) => /* @__PURE__ */ w.jsx(
- "img",
- {
- className: Do.docListTypePickerItem + (e === s.value ? `
- ${Do.docListTypePickerItemActive}
- ` : ""),
- onClick: () => {
- t(s.value);
- },
- src: s.img
- },
- s.value
- )) });
- }, El = [
- {
- value: Oe.ORDER_LIST,
- img: ""
- },
- {
- value: Oe.ORDER_LIST_1,
- img: ""
- },
- {
- value: Oe.ORDER_LIST_2,
- img: ""
- },
- {
- value: Oe.ORDER_LIST_3,
- img: ""
- },
- {
- value: Oe.ORDER_LIST_4,
- img: ""
- },
- {
- value: Oe.ORDER_LIST_5,
- img: ""
- }
- ], Sl = (n) => /* @__PURE__ */ w.jsx(
- ia,
- {
- ...n,
- options: El
- }
- ), Il = [
- {
- value: Oe.BULLET_LIST,
- img: ""
- },
- {
- value: Oe.BULLET_LIST_1,
- img: ""
- },
- {
- value: Oe.BULLET_LIST_2,
- img: ""
- },
- {
- value: Oe.BULLET_LIST_3,
- img: ""
- },
- {
- value: Oe.BULLET_LIST_4,
- img: ""
- },
- {
- value: Oe.BULLET_LIST_5,
- img: ""
- }
- ], Cl = (n) => /* @__PURE__ */ w.jsx(
- ia,
- {
- ...n,
- options: Il
- }
- ), aa = `${kt}_ORDER_LIST_TYPE_COMPONENT`, ca = `${kt}_BULLET_LIST_TYPE_COMPONENT`, vl = "doc.command.tab", _t = {
- id: vl,
- type: N.COMMAND,
- async handler(n, e) {
- const o = n.get(Et).onAutoFormat(_t.id, e);
- return (await Es(o, n.get(y))).result;
- }
- }, Rl = "doc.command.after-space", Ao = {
- id: Rl,
- type: N.COMMAND,
- async handler(n) {
- const t = n.get(Et).onAutoFormat(Ao.id);
- return (await Es(t, n.get(y))).result;
- }
- }, ln = {
- id: "doc.command.enter",
- type: N.COMMAND,
- async handler(n) {
- const t = n.get(Et).onAutoFormat(ln.id);
- return (await Es(t, n.get(y))).result;
- }
- };
- function de(n) {
- return n.getContextValue(hn) && n.getContextValue(Ss) && !n.getContextValue(mi);
- }
- function bl(n) {
- return n.getContextValue(hn) && n.getContextValue(Ss) && !n.getContextValue(mi);
- }
- const xl = {
- id: _t.id,
- binding: j.TAB,
- preconditions: de
- }, Ol = {
- id: _t.id,
- binding: j.TAB | K.SHIFT,
- preconditions: de,
- staticParameters: {
- shift: !0
- }
- };
- var Tl = Object.defineProperty, yl = Object.getOwnPropertyDescriptor, Bl = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? yl(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Tl(e, t, s), s;
- }, wo = (n, e) => (t, o) => e(t, o, n);
- const Ml = 11, _l = 9, vn = {
- /**
- * fontFamily
- */
- ff: "Arial",
- /**
- * fontSize
- */
- fs: Ml
- };
- let Je = class extends ue {
- constructor(e, t, o) {
- super();
- x(this, "_cacheStyle", null);
- this._textSelectionManagerService = e, this._univerInstanceService = t, this._renderManagerService = o, this._init();
- }
- _init() {
- this._listenDocRangeChange();
- }
- _listenDocRangeChange() {
- this.disposeWithMe(
- this._textSelectionManagerService.textSelection$.subscribe(() => {
- this._clearStyleCache();
- })
- );
- }
- getStyleCache() {
- return this._cacheStyle;
- }
- getDefaultStyle() {
- var i;
- const e = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC);
- if (e == null)
- return {
- ...vn
- };
- const t = e == null ? void 0 : e.getUnitId(), o = (i = this._renderManagerService.getRenderById(t)) == null ? void 0 : i.with(ie), s = o == null ? void 0 : o.getViewModel();
- return s == null ? {
- ...vn
- } : s.getEditArea() === ge.BODY ? {
- ...vn
- } : {
- ...vn,
- fs: _l
- };
- }
- setStyleCache(e) {
- this._cacheStyle = {
- ...this._cacheStyle,
- ...e
- };
- }
- _clearStyleCache() {
- this._cacheStyle = null;
- }
- };
- Je = Bl([
- wo(0, z(G)),
- wo(1, Q),
- wo(2, fe)
- ], Je);
- function Ve(n, e, t) {
- return t.executeCommand(lt.id, {
- preCommandId: n,
- ...e != null ? e : {}
- });
- }
- const Ur = "doc.command.set-inline-format-bold", Vt = {
- id: Ur,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Ur,
- e,
- t
- );
- }
- }, Lr = "doc.command.set-inline-format-italic", jt = {
- id: Lr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Lr,
- e,
- t
- );
- }
- }, Fr = "doc.command.set-inline-format-underline", Wt = {
- id: Fr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Fr,
- e,
- t
- );
- }
- }, Hr = "doc.command.set-inline-format-strikethrough", zt = {
- id: Hr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Hr,
- e,
- t
- );
- }
- }, kr = "doc.command.set-inline-format-subscript", Ct = {
- id: kr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- kr,
- e,
- t
- );
- }
- }, Vr = "doc.command.set-inline-format-superscript", Gt = {
- id: Vr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Vr,
- e,
- t
- );
- }
- }, jr = "doc.command.set-inline-format-fontsize", Pt = {
- id: jr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- jr,
- e,
- t
- );
- }
- }, Wr = "doc.command.set-inline-format-font-family", Dt = {
- id: Wr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Wr,
- e,
- t
- );
- }
- }, zr = "doc.command.set-inline-format-text-color", wt = {
- id: zr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- zr,
- e,
- t
- );
- }
- }, Gr = "doc.command.set-inline-format-text-background-color", Nt = {
- id: Gr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Gr,
- e,
- t
- );
- }
- }, Yr = "doc.command.reset-inline-format-text-background-color", fn = {
- id: Yr,
- type: N.COMMAND,
- handler: async (n, e) => {
- const t = n.get(y);
- return Ve(
- Yr,
- e,
- t
- );
- }
- }, $o = {
- [Vt.id]: "bl",
- [jt.id]: "it",
- [Wt.id]: "ul",
- [zt.id]: "st",
- [Pt.id]: "fs",
- [Dt.id]: "ff",
- [wt.id]: "cl",
- [Nt.id]: "bg",
- [fn.id]: "bg",
- [Ct.id]: "va",
- [Gt.id]: "va"
- }, lt = {
- id: "doc.command.set-inline-format",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function, complexity
- handler: async (n, e) => {
- var R;
- const { value: t, preCommandId: o } = e, s = n.get(y), r = n.get(G), i = n.get(Q), a = n.get(Je), c = r.getDocRanges(), A = (R = c.find((S) => S.isActive)) != null ? R : c[0];
- if (c.length === 0)
- return !1;
- const { segmentId: l } = c[0], d = i.getCurrentUnitForType(_.UNIVER_DOC);
- if (d == null)
- return !1;
- const h = d.getSelfOrHeaderFooterModel(l).getBody();
- if (h == null)
- return !1;
- const u = d.getUnitId();
- let g;
- switch (o) {
- case Vt.id:
- // fallthrough
- case jt.id:
- // fallthrough
- case Wt.id:
- // fallthrough
- case zt.id:
- // fallthrough
- case Ct.id:
- // fallthrough
- case Gt.id: {
- const S = a.getDefaultStyle(), C = la(
- h,
- A,
- S
- );
- g = Dl(
- C,
- o
- );
- break;
- }
- case Pt.id:
- case Dt.id: {
- g = t;
- break;
- }
- case wt.id:
- case Nt.id: {
- g = {
- rgb: t
- };
- break;
- }
- case fn.id: {
- g = {
- rgb: null
- };
- break;
- }
- default:
- throw new Error(`Unknown command: ${o} in handleInlineFormat`);
- }
- const f = {
- id: J.id,
- params: {
- unitId: u,
- actions: [],
- textRanges: c
- }
- }, p = new me(), m = k.getInstance(), E = new St();
- E.reset();
- for (const S of c) {
- let { startOffset: C, endOffset: T, rangeType: O } = S;
- if (C == null || T == null)
- continue;
- if (O === Ge.RECT && (C = C - 1), C === T) {
- const B = a.getStyleCache(), M = $o[o];
- a.setStyleCache(
- {
- [M]: (B == null ? void 0 : B[M]) !== void 0 ? Aa(
- B,
- M,
- o
- ) : g
- }
- );
- continue;
- }
- const P = {
- dataStream: "",
- textRuns: [
- {
- st: 0,
- ed: T - C,
- ts: {
- [$o[o]]: g
- }
- }
- ]
- }, b = C - E.cursor;
- b !== 0 && p.push({
- t: W.RETAIN,
- len: b
- }), p.push({
- t: W.RETAIN,
- body: P,
- len: T - C
- }), E.reset(), E.moveCursor(T);
- }
- const I = le(d, l);
- return f.params.actions = m.editOp(p.serialize(), I), !!s.syncExecuteCommand(f.id, f.params);
- }
- };
- function Pl(n) {
- return n !== null && typeof n == "object";
- }
- function Aa(n, e, t) {
- if (/bl|it/.test(e))
- return (n == null ? void 0 : n[e]) === L.TRUE ? L.FALSE : L.TRUE;
- if (/ul|st/.test(e))
- return Pl(n == null ? void 0 : n[e]) && (n == null ? void 0 : n[e]).s === L.TRUE ? {
- s: L.FALSE
- } : {
- s: L.TRUE
- };
- if (/va/.test(e))
- return t === Ct.id ? (n == null ? void 0 : n[e]) === Ne.SUBSCRIPT ? Ne.NORMAL : Ne.SUBSCRIPT : (n == null ? void 0 : n[e]) === Ne.SUPERSCRIPT ? Ne.NORMAL : Ne.SUPERSCRIPT;
- }
- function la(n, e, t) {
- var A, l, d, h, u, g, f, p, m, E, I, v, R, S;
- const { startOffset: o, endOffset: s, collapsed: r } = e;
- if (r) {
- const C = (A = n.textRuns) != null ? A : [];
- let T = null;
- for (let O = C.length - 1; O >= 0; O--) {
- const P = C[O];
- if (P.st < o && o <= P.ed) {
- T = P;
- break;
- }
- }
- return T != null && T.ts ? { ...t, ...T.ts } : t;
- }
- const { textRuns: i = [] } = Ei(n, o, s), a = X.deepClone(t);
- a.fs = Math.max(a.fs, ...i.map((C) => {
- var T, O;
- return (O = (T = C == null ? void 0 : C.ts) == null ? void 0 : T.fs) != null ? O : a.fs;
- })), a.ff = (h = (d = (l = i.find((C) => {
- var T;
- return ((T = C.ts) == null ? void 0 : T.ff) != null;
- })) == null ? void 0 : l.ts) == null ? void 0 : d.ff) != null ? h : a.ff, a.it = i.length && i.every((C) => {
- var T;
- return ((T = C.ts) == null ? void 0 : T.it) === L.TRUE;
- }) ? L.TRUE : L.FALSE, a.bl = i.length && i.every((C) => {
- var T;
- return ((T = C.ts) == null ? void 0 : T.bl) === L.TRUE;
- }) ? L.TRUE : L.FALSE, a.ul = i.length && i.every((C) => {
- var T, O;
- return ((O = (T = C.ts) == null ? void 0 : T.ul) == null ? void 0 : O.s) === L.TRUE;
- }) ? (u = i[0].ts) == null ? void 0 : u.ul : a.ul, a.st = i.length && i.every((C) => {
- var T, O;
- return ((O = (T = C.ts) == null ? void 0 : T.st) == null ? void 0 : O.s) === L.TRUE;
- }) ? (g = i[0].ts) == null ? void 0 : g.st : a.st, a.bg = (m = (p = (f = i.find((C) => {
- var T;
- return ((T = C.ts) == null ? void 0 : T.bg) != null;
- })) == null ? void 0 : f.ts) == null ? void 0 : p.bg) != null ? m : a.bg, a.cl = (v = (I = (E = i.find((C) => {
- var T;
- return ((T = C.ts) == null ? void 0 : T.cl) != null;
- })) == null ? void 0 : E.ts) == null ? void 0 : I.cl) != null ? v : a.cl;
- const c = i.filter((C) => {
- var T;
- return ((T = C == null ? void 0 : C.ts) == null ? void 0 : T.va) != null;
- });
- if (c.length > 0 && c.length === i.length) {
- const C = (R = c[0].ts) == null ? void 0 : R.va;
- let T = !0;
- for (let O = 1; O < c.length; O++)
- if (((S = c[O].ts) == null ? void 0 : S.va) !== C) {
- T = !1;
- break;
- }
- T && (a.va = C);
- }
- return a;
- }
- function Dl(n, e) {
- const t = $o[e];
- return Aa(n, t, e);
- }
- const pn = {
- id: "doc.command.list-operation",
- type: N.COMMAND,
- handler: (n, e) => {
- var E, I;
- const t = n.get(G), o = n.get(Q), s = n.get(y), r = e.listType, i = o.getCurrentUnitForType(_.UNIVER_DOC), a = (E = t.getDocRanges()) != null ? E : [];
- if (i == null || a.length === 0)
- return !1;
- const c = a[0].segmentId, A = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
- if (A == null)
- return !1;
- const l = mn(a, A), d = i.getUnitId(), h = {
- id: J.id,
- params: {
- unitId: d,
- actions: [],
- textRanges: a,
- isEditing: !1
- }
- };
- new St().reset();
- const g = Ce.paragraph.bullet.switch({
- paragraphs: l,
- listType: r,
- document: i,
- segmentId: c
- }), f = k.getInstance(), p = le(i, c);
- return h.params.actions = f.editOp(g.serialize(), p), !!s.syncExecuteCommand(h.id, h.params);
- }
- }, lo = {
- id: "doc.command.change-list-type",
- type: N.COMMAND,
- handler: (n, e) => {
- var E, I;
- const t = n.get(G), o = n.get(Q), s = n.get(y), { listType: r } = e, i = o.getCurrentUnitForType(_.UNIVER_DOC), a = t.getDocRanges();
- if (i == null || a == null || !a.length)
- return !1;
- const { segmentId: c } = a[0], A = (E = t.getDocRanges()) != null ? E : [], l = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
- if (l == null)
- return !1;
- const d = mn(A, l), h = i.getUnitId(), u = Ce.paragraph.bullet.set({
- paragraphs: d,
- listType: r,
- segmentId: c,
- document: i
- });
- if (!u)
- return !1;
- const g = k.getInstance(), f = {
- id: J.id,
- params: {
- unitId: h,
- actions: [],
- textRanges: A,
- isEditing: !1
- }
- }, p = le(i, c);
- return f.params.actions = g.editOp(u.serialize(), p), !!s.syncExecuteCommand(f.id, f.params);
- }
- };
- var Pn = /* @__PURE__ */ ((n) => (n[n.increase = 1] = "increase", n[n.decrease = -1] = "decrease", n))(Pn || {});
- const es = {
- id: "doc.command.change-list-nesting-level",
- type: N.COMMAND,
- handler: (n, e) => {
- var E, I;
- if (!e)
- return !1;
- const { type: t } = e, o = n.get(G), s = n.get(Q), r = n.get(y), i = s.getCurrentUnitForType(_.UNIVER_DOC), a = o.getActiveTextRange();
- if (i == null || a == null)
- return !1;
- const { segmentId: c } = a, A = (E = o.getDocRanges()) != null ? E : [], l = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
- if (l == null)
- return !1;
- const d = Qs(a, l), h = i.getUnitId(), u = k.getInstance(), g = Ce.paragraph.bullet.changeNestLevel({
- paragraphs: d,
- type: t,
- segmentId: c,
- document: i
- }), f = {
- id: J.id,
- params: {
- unitId: h,
- actions: [],
- textRanges: A,
- isEditing: !1
- }
- }, p = le(i, c);
- return f.params.actions = u.editOp(g.serialize(), p), !!r.syncExecuteCommand(f.id, f.params);
- }
- }, uo = {
- id: "doc.command.bullet-list",
- type: N.COMMAND,
- handler: (n, e) => {
- const t = n.get(y);
- return e != null && e.value ? t.syncExecuteCommand(lo.id, {
- listType: e.value
- }) : t.syncExecuteCommand(pn.id, {
- listType: Oe.BULLET_LIST
- });
- }
- }, ws = {
- id: "doc.command.check-list",
- type: N.COMMAND,
- handler: (n, e) => {
- const t = n.get(y);
- return e != null && e.value ? t.syncExecuteCommand(lo.id, {
- listType: e.value
- }) : t.syncExecuteCommand(pn.id, {
- listType: Oe.CHECK_LIST
- });
- }
- }, Ns = {
- id: "doc.command.toggle-check-list",
- type: N.COMMAND,
- handler: (n, e) => {
- var f;
- if (!e)
- return !1;
- const t = n.get(Q), o = n.get(y), { index: s, segmentId: r, textRanges: i } = e, a = t.getCurrentUnitForType(_.UNIVER_DOC);
- if (a == null || ((f = a.getSelfOrHeaderFooterModel(r).getBody()) == null ? void 0 : f.paragraphs) == null)
- return !1;
- const A = a.getUnitId(), l = {
- id: J.id,
- params: {
- unitId: A,
- actions: [],
- textRanges: i != null ? i : [],
- segmentId: r,
- isEditing: !1
- }
- }, d = Ce.paragraph.bullet.toggleChecklist({
- document: a,
- paragraphIndex: s,
- segmentId: r
- });
- if (!d)
- return !1;
- const h = k.getInstance(), u = le(a, r);
- return l.params.actions = h.editOp(d.serialize(), u), !!o.syncExecuteCommand(l.id, l.params);
- }
- }, ho = {
- id: "doc.command.order-list",
- type: N.COMMAND,
- handler: (n, e) => {
- const t = n.get(y);
- return e != null && e.value ? t.syncExecuteCommand(lo.id, {
- listType: e.value
- }) : t.syncExecuteCommand(pn.id, {
- listType: Oe.ORDER_LIST
- });
- }
- }, da = {
- id: "doc.command.quick-list",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler(n, e) {
- var oe, ce, he, Ae, ne;
- if (!e)
- return !1;
- const t = n.get(G), o = n.get(Q), s = n.get(y), r = o.getCurrentUnitForType(_.UNIVER_DOC), i = t.getActiveTextRange();
- if (r == null || i == null)
- return !1;
- const { segmentId: a } = i, { listType: c, paragraph: A } = e, { paragraphStart: l, paragraphEnd: d } = A, h = new me(), u = k.getInstance(), { defaultTabStop: g = 36 } = r.getSnapshot().documentStyle, f = (ce = (oe = r.getSelfOrHeaderFooterModel(a).getBody()) == null ? void 0 : oe.sectionBreaks) != null ? ce : [], { startIndex: p, paragraphStyle: m = {} } = A, { indentFirstLine: E, snapToGrid: I, indentStart: v } = m, R = Wa[c].nestingLevel[0].paragraphProperties || {}, { hanging: S, indentStart: C } = R, T = R.textStyle, { charSpace: O, gridType: P } = wl(p, f) || { charSpace: 0, gridType: za.LINES }, b = uc(O, g, P, I);
- let M = X.generateRandomId(6);
- const H = (Ae = (he = r.getBody()) == null ? void 0 : he.paragraphs) != null ? Ae : [], F = H.findIndex((ae) => ae.startIndex === A.startIndex), D = H[F - 1], te = H[F + 1];
- D && D.bullet && D.bullet.listType.indexOf(c) === 0 ? M = D.bullet.listId : te && te.bullet && te.bullet.listType.indexOf(c) === 0 && (M = te.bullet.listId);
- const q = {
- id: J.id,
- params: {
- unitId: r.getUnitId(),
- actions: [],
- textRanges: [{
- startOffset: l,
- endOffset: l,
- collapsed: !0
- }],
- isEditing: !1
- }
- };
- h.push({
- t: W.RETAIN,
- len: l
- }), h.push({
- t: W.DELETE,
- len: d - l
- }), h.push({
- t: W.RETAIN,
- len: 1,
- body: {
- dataStream: "",
- paragraphs: [
- {
- startIndex: 0,
- paragraphStyle: {
- ...m,
- textStyle: {
- ...m.textStyle,
- ...T
- },
- indentFirstLine: void 0,
- hanging: S,
- indentStart: { v: ze(C, b) - ze(S, b) + ze(E, b) + ze(v, b) }
- },
- bullet: {
- ...(ne = A.bullet) != null ? ne : {
- nestingLevel: 0,
- textStyle: {
- fs: 20
- }
- },
- listType: c,
- listId: M
- }
- }
- ]
- }
- });
- const V = le(r, a);
- return q.params.actions = u.editOp(h.serialize(), V), !!s.syncExecuteCommand(q.id, q.params);
- }
- };
- function Qs(n, e) {
- const { startOffset: t, endOffset: o } = n, s = [];
- let r = -1;
- for (const i of e) {
- const { startIndex: a } = i;
- (t > r && t <= a || o > r && o <= a || a >= t && a <= o) && s.push(i), r = a;
- }
- return s;
- }
- function mn(n, e) {
- const t = [];
- for (const o of n) {
- const s = Qs(o, e);
- t.push(...s);
- }
- return t;
- }
- function wl(n, e) {
- const t = e.sort(Ga("startIndex"));
- for (let o = 0; o < t.length; o++) {
- const s = e[o];
- if (s.startIndex >= n)
- return s;
- }
- }
- const et = {
- id: "doc.command.align-action",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: (n, e) => {
- var I;
- const t = n.get(G), o = n.get(Q), s = n.get(y), { alignType: r } = e, i = o.getCurrentUniverDocInstance();
- if (i == null)
- return !1;
- const a = t.getDocRanges();
- if (a.length === 0)
- return !1;
- const c = a[0].segmentId, A = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
- if (A == null)
- return !1;
- const l = mn(a, A), d = i.getUnitId(), h = l.every((v) => {
- var R;
- return ((R = v.paragraphStyle) == null ? void 0 : R.horizontalAlign) === r;
- }), u = {
- id: J.id,
- params: {
- unitId: d,
- actions: [],
- textRanges: a
- }
- }, g = new St();
- g.reset();
- const f = new me(), p = k.getInstance();
- for (const v of l) {
- const { startIndex: R } = v;
- f.push({
- t: W.RETAIN,
- len: R - g.cursor
- });
- const S = {
- ...v.paragraphStyle,
- horizontalAlign: h ? _e.UNSPECIFIED : r
- };
- f.push({
- t: W.RETAIN,
- len: 1,
- body: {
- dataStream: "",
- paragraphs: [
- {
- ...v,
- paragraphStyle: S,
- startIndex: 0
- }
- ]
- },
- coverType: no.REPLACE
- }), g.moveCursorTo(R + 1);
- }
- const m = le(i, c);
- return u.params.actions = p.editOp(f.serialize(), m), !!s.syncExecuteCommand(u.id, u.params);
- }
- }, go = {
- id: "doc.command.align-left",
- type: N.COMMAND,
- handler: (n) => n.get(y).syncExecuteCommand(et.id, {
- alignType: _e.LEFT
- })
- }, fo = {
- id: "doc.command.align-center",
- type: N.COMMAND,
- handler: (n) => n.get(y).syncExecuteCommand(et.id, {
- alignType: _e.CENTER
- })
- }, po = {
- id: "doc.command.align-right",
- type: N.COMMAND,
- handler: (n) => n.get(y).syncExecuteCommand(et.id, {
- alignType: _e.RIGHT
- })
- }, mo = {
- id: "doc.command.align-justify",
- type: N.COMMAND,
- handler: (n) => n.get(y).syncExecuteCommand(et.id, {
- alignType: _e.JUSTIFIED
- })
- }, Nl = {
- id: Vt.id,
- binding: j.B | K.CTRL_COMMAND,
- preconditions: de
- }, Ql = {
- id: jt.id,
- binding: j.I | K.CTRL_COMMAND,
- preconditions: de
- }, Ul = {
- id: Wt.id,
- binding: j.U | K.CTRL_COMMAND,
- preconditions: de
- }, Ll = {
- id: zt.id,
- binding: j.X | K.SHIFT | K.CTRL_COMMAND,
- preconditions: de
- }, Fl = {
- id: Ct.id,
- binding: j.COMMA | K.CTRL_COMMAND,
- preconditions: de
- }, Hl = {
- id: Gt.id,
- binding: j.PERIOD | K.CTRL_COMMAND,
- preconditions: de
- }, kl = {
- id: go.id,
- binding: j.L | K.CTRL_COMMAND | K.SHIFT,
- preconditions: de
- }, Vl = {
- id: po.id,
- binding: j.R | K.CTRL_COMMAND | K.SHIFT,
- preconditions: de
- }, jl = {
- id: fo.id,
- binding: j.E | K.CTRL_COMMAND | K.SHIFT,
- preconditions: de
- }, Wl = {
- id: mo.id,
- binding: j.J | K.CTRL_COMMAND | K.SHIFT,
- preconditions: de
- }, zl = {
- id: ho.id,
- binding: j.Digit7 | K.CTRL_COMMAND | K.SHIFT,
- preconditions: de
- }, Gl = {
- id: uo.id,
- binding: j.Digit8 | K.CTRL_COMMAND | K.SHIFT,
- preconditions: de
- }, Yl = "univer-doc-count-bar", ql = {
- docCountBar: Yl
- }, Kl = (n, e) => {
- const t = n.get(Q).getUniverDocInstance(e.unitId), o = (t == null ? void 0 : t.zoomRatio) || 1;
- return {
- ...X.deepClone(e),
- zoomRatio: o
- };
- }, Ye = {
- id: "doc.operation.set-zoom-ratio",
- type: N.OPERATION,
- handler: (n, e) => {
- const t = n.get(Q).getUniverDocInstance(e.unitId);
- if (!t)
- return !1;
- const o = t.getSnapshot();
- return o.settings == null ? o.settings = {
- zoomRatio: e.zoomRatio
- } : o.settings.zoomRatio = e.zoomRatio, !0;
- }
- }, Xl = [50, 80, 100, 130, 150, 170, 200, 400], Jl = [10, 400];
- function Zl() {
- const n = $(y), e = $(Q), t = Fe(() => e.getCurrentTypeOfUnit$(_.UNIVER_DOC), []), o = Nn(t), s = Li(() => {
- var A, l;
- if (!o) return 100;
- const c = ((l = (A = o.getSettings()) == null ? void 0 : A.zoomRatio) != null ? l : 1) * 100;
- return Math.round(c);
- }, [o]), [r, i] = ve(() => s());
- Re(() => (i(s()), n.onCommandExecuted((A) => {
- if (A.id === Ye.id) {
- const l = s();
- i(l);
- }
- }).dispose), [n, s]);
- function a(c) {
- if (i(c), o == null)
- return;
- const A = c / 100;
- n.executeCommand(Ye.id, {
- unitId: o.getUnitId(),
- zoomRatio: A
- });
- }
- return /* @__PURE__ */ w.jsx(
- Kc,
- {
- min: Jl[0],
- value: r,
- shortcuts: Xl,
- onChange: a
- }
- );
- }
- function $l(n) {
- return /* @__PURE__ */ w.jsx("section", { className: ql.docCountBar, children: /* @__PURE__ */ w.jsx(Zl, {}) });
- }
- const ed = "univer-doc-footer-container", td = {
- docFooterContainer: ed
- }, nd = () => /* @__PURE__ */ w.jsxs("div", { className: td.docFooterContainer, children: [
- /* @__PURE__ */ w.jsx("div", {}),
- /* @__PURE__ */ w.jsx($l, {})
- ] }), Us = "docs-ui.config", qr = {
- layout: {
- docContainerConfig: sA,
- toolbarConfig: oA
- }
- };
- var Eo = /* @__PURE__ */ ((n) => (n[n.ABOVE = 0] = "ABOVE", n[n.BELLOW = 1] = "BELLOW", n))(Eo || {}), Ls = /* @__PURE__ */ ((n) => (n[n.LEFT = 0] = "LEFT", n[n.RIGHT = 1] = "RIGHT", n))(Ls || {});
- function od(n, e) {
- let t = U.TABLE_START;
- const o = [], s = [];
- for (let r = 0; r < n; r++) {
- t += U.TABLE_ROW_START;
- for (let i = 0; i < e; i++)
- t += `${U.TABLE_CELL_START}\r
- ${U.TABLE_CELL_END}`, o.push({
- startIndex: t.length - 3,
- paragraphStyle: {
- spaceAbove: { v: 3 },
- lineSpacing: 2,
- spaceBelow: { v: 0 }
- }
- }), s.push({
- startIndex: t.length - 2
- });
- t += U.TABLE_ROW_END;
- }
- return t += U.TABLE_END, {
- dataStream: t,
- paragraphs: o,
- sectionBreaks: s
- };
- }
- function Fs() {
- return {
- margin: {
- start: {
- v: 10
- },
- end: {
- v: 10
- },
- top: {
- v: 5
- },
- bottom: {
- v: 5
- }
- }
- };
- }
- function Hs(n) {
- const e = Fs();
- return {
- tableCells: [...new Array(n).fill(null).map(() => X.deepClone(e))],
- trHeight: {
- val: { v: 30 },
- hRule: Ya.AUTO
- }
- };
- }
- function ks(n) {
- return {
- size: {
- type: Si.SPECIFIED,
- width: {
- v: n
- }
- }
- };
- }
- function ua(n, e, t) {
- const o = ks(t / e), s = Hs(e), r = [...new Array(n).fill(null).map(() => X.deepClone(s))], i = [...new Array(e).fill(null).map(() => X.deepClone(o))], a = pt(6);
- return {
- tableRows: r,
- tableColumns: i,
- tableId: a,
- align: qa.START,
- indent: {
- v: 0
- },
- textWrap: Ka.NONE,
- position: {
- positionH: {
- relativeFrom: $n.PAGE,
- posOffset: 0
- },
- positionV: {
- relativeFrom: ot.PAGE,
- posOffset: 0
- }
- },
- dist: {
- distB: 0,
- distL: 0,
- distR: 0,
- distT: 0
- },
- cellMargin: {
- start: {
- v: 10
- },
- end: {
- v: 10
- },
- top: {
- v: 5
- },
- bottom: {
- v: 5
- }
- },
- size: {
- type: Si.UNSPECIFIED,
- width: {
- v: t
- }
- }
- };
- }
- function En(n, e) {
- if (!n && !e)
- return null;
- if (e && e.length > 0) {
- let t = Number.POSITIVE_INFINITY, o = Number.NEGATIVE_INFINITY;
- const s = "";
- for (const r of e) {
- const { startOffset: i, endOffset: a, segmentId: c } = r;
- i == null || a == null || c == null || (t = Math.min(t, i), o = Math.max(o, a));
- }
- if (Number.isFinite(t) && Number.isFinite(o))
- return {
- startOffset: t,
- endOffset: o,
- segmentId: s
- };
- } else if (n) {
- const { startOffset: t, endOffset: o, segmentId: s } = n;
- return t == null || o == null || s == null ? null : {
- startOffset: t,
- endOffset: o,
- segmentId: s
- };
- }
- }
- function sd(n) {
- let e = U.TABLE_ROW_START;
- const t = [], o = [];
- for (let s = 0; s < n; s++)
- e += `${U.TABLE_CELL_START}\r
- ${U.TABLE_CELL_END}`, t.push({
- startIndex: e.length - 3,
- paragraphStyle: {
- spaceAbove: { v: 3 },
- lineSpacing: 2,
- spaceBelow: { v: 0 }
- }
- }), o.push({
- startIndex: e.length - 2
- });
- return e += U.TABLE_ROW_END, {
- dataStream: e,
- paragraphs: t,
- sectionBreaks: o
- };
- }
- function rd() {
- const n = `${U.TABLE_CELL_START}\r
- ${U.TABLE_CELL_END}`, e = [], t = [];
- return e.push({
- startIndex: 1,
- paragraphStyle: {
- spaceAbove: { v: 3 },
- lineSpacing: 2,
- spaceBelow: { v: 0 }
- }
- }), t.push({
- startIndex: 2
- }), {
- dataStream: n,
- paragraphs: e,
- sectionBreaks: t
- };
- }
- function id(n, e, t) {
- var d, h, u;
- const { startOffset: o, endOffset: s, segmentId: r } = n, i = t.getSelfOrHeaderFooterViewModel(r), a = e === 0 ? o : s;
- let c = null;
- const A = (u = (h = (d = t.getBody()) == null ? void 0 : d.tables) == null ? void 0 : h.find((g) => a >= g.startIndex && a <= g.endIndex)) == null ? void 0 : u.tableId;
- let l = 0;
- for (const g of i.getChildren()) {
- for (const f of g.children) {
- const { children: p } = f, m = p[0];
- if (m) {
- for (const E of m.children)
- if (E.startIndex <= a && a <= E.endIndex) {
- l = m.children.indexOf(E), c = E;
- break;
- }
- }
- if (c)
- break;
- }
- if (c)
- break;
- }
- return c == null || A == null ? null : {
- offset: e === 0 ? c.startIndex : c.endIndex + 1,
- colCount: c.children.length,
- tableId: A,
- insertRowIndex: e === 0 ? l : l + 1
- };
- }
- function ad(n, e, t) {
- var u, g, f;
- const { startOffset: o, endOffset: s, segmentId: r } = n, i = t.getSelfOrHeaderFooterViewModel(r), a = e === 0 ? o : s, c = (f = (g = (u = t.getBody()) == null ? void 0 : u.tables) == null ? void 0 : g.find((p) => a >= p.startIndex && a <= p.endIndex)) == null ? void 0 : f.tableId, A = [];
- let l = null, d = -1;
- for (const p of i.getChildren()) {
- for (const m of p.children) {
- const { children: E } = m, I = E[0];
- if (I) {
- if (a < I.startIndex || a > I.endIndex)
- continue;
- l = I;
- for (const v of I.children) {
- for (const R of v.children) {
- const S = v.children.indexOf(R);
- if (a >= R.startIndex && a <= R.endIndex) {
- d = S;
- break;
- }
- }
- if (d !== -1)
- break;
- }
- }
- if (l)
- break;
- }
- if (l)
- break;
- }
- if (l == null || c == null || d === -1)
- return null;
- let h = 0;
- for (const p of l.children) {
- const m = p.children[d], E = e === 0 ? m.startIndex : m.endIndex + 1;
- A.push(E - h), h = E;
- }
- return {
- offsets: A,
- tableId: c,
- columnIndex: d,
- rowCount: l.children.length
- };
- }
- function cd(n, e, t) {
- const o = [];
- let s = e[t].size.width.v, r = 0;
- for (let i = 0; i < e.length; i++)
- r += e[i].size.width.v;
- r += s;
- for (let i = 0; i < e.length; i++)
- o.push(e[i].size.width.v / r * n);
- return s = s / r * n, {
- widths: o,
- newColWidth: s
- };
- }
- function ha(n, e) {
- var h, u, g;
- const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (g = (u = (h = e.getBody()) == null ? void 0 : h.tables) == null ? void 0 : u.find((f) => t >= f.startIndex && o <= f.endIndex)) == null ? void 0 : g.tableId, a = [];
- let c = -1, A = 0, l = -1, d = !1;
- for (const f of r.getChildren()) {
- for (const p of f.children) {
- const { children: m } = p, E = m[0];
- if (E) {
- if (t < E.startIndex || o > E.endIndex)
- continue;
- l = E.startIndex + 3;
- for (const I of E.children) {
- const v = E.children.indexOf(I), { startIndex: R, endIndex: S } = I;
- t >= R && t <= S ? (c = R, a.push(v), A += S - R + 1) : (R > t && S < o || o >= R && o <= S) && (a.push(v), A += S - R + 1), a.length === E.children.length && (d = !0);
- }
- }
- if (a.length)
- break;
- }
- if (a.length)
- break;
- }
- return i == null || a.length === 0 ? null : {
- tableId: i,
- rowIndexes: a,
- offset: c,
- len: A,
- cursor: l,
- selectWholeTable: d
- };
- }
- function Ad(n, e) {
- var g, f, p;
- const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (p = (f = (g = e.getBody()) == null ? void 0 : g.tables) == null ? void 0 : f.find((m) => t >= m.startIndex && o <= m.endIndex)) == null ? void 0 : p.tableId, a = [];
- let c = null;
- const A = [];
- let l = -1, d = -1, h = -1;
- for (const m of r.getChildren()) {
- for (const E of m.children) {
- const { children: I } = E, v = I[0];
- if (v) {
- if (t < v.startIndex || o > v.endIndex)
- continue;
- c = v;
- for (const R of v.children)
- for (const S of R.children) {
- const C = R.children.indexOf(S);
- t >= S.startIndex && t <= S.endIndex && (d = C), o >= S.startIndex && o <= S.endIndex && (h = C);
- }
- }
- if (c)
- break;
- }
- if (c)
- break;
- }
- if (c == null || i == null)
- return null;
- for (let m = d; m <= h; m++)
- A.push(m);
- let u = 0;
- for (const m of c.children) {
- const E = m.children[d], I = m.children[h];
- a.push({
- retain: E.startIndex - u,
- delete: I.endIndex - E.startIndex + 1
- }), u = I.endIndex + 1;
- }
- return l = c.startIndex + 3, {
- offsets: a,
- tableId: i,
- columnIndexes: A,
- cursor: l,
- selectWholeTable: A.length === c.children[0].children.length,
- rowCount: c.children.length
- };
- }
- function ga(n, e) {
- var l, d, h;
- const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (h = (d = (l = e.getBody()) == null ? void 0 : l.tables) == null ? void 0 : d.find((u) => t >= u.startIndex && o <= u.endIndex)) == null ? void 0 : h.tableId;
- let a = -1, c = 0, A = -1;
- for (const u of r.getChildren()) {
- for (const g of u.children) {
- const { children: f } = g, p = f[0];
- if (p) {
- if (t < p.startIndex || o > p.endIndex)
- continue;
- a = p.startIndex, c = p.endIndex - p.startIndex + 1, A = p.startIndex;
- }
- if (p)
- break;
- }
- if (c > 0)
- break;
- }
- return i == null ? null : {
- tableId: i,
- offset: a,
- len: c,
- cursor: A
- };
- }
- function ld(n, e) {
- var g, f, p;
- const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (p = (f = (g = e.getBody()) == null ? void 0 : g.tables) == null ? void 0 : f.find((m) => t >= m.startIndex && o <= m.endIndex)) == null ? void 0 : p.tableId, a = [];
- let c = null, A = -1, l = -1, d = -1, h = -1;
- for (const m of r.getChildren()) {
- for (const E of m.children) {
- const { children: I } = E, v = I[0];
- if (v) {
- if (t < v.startIndex || o > v.endIndex)
- continue;
- c = v;
- for (const R of v.children) {
- const S = v.children.indexOf(R);
- for (const C of R.children) {
- const T = R.children.indexOf(C);
- t >= C.startIndex && t <= C.endIndex && (l = S, d = T), o >= C.startIndex && o <= C.endIndex && (h = T);
- }
- }
- }
- if (c)
- break;
- }
- if (c)
- break;
- }
- if (c == null || i == null || l === -1)
- return null;
- const u = c.children[l];
- for (let m = d; m <= h; m++) {
- const E = u.children[m];
- a.push({
- retain: E.startIndex + 1,
- delete: E.endIndex - E.startIndex - 3
- });
- }
- return A = c.startIndex + 3, {
- offsets: a,
- tableId: i,
- cursor: A,
- rowCount: c.children.length
- };
- }
- var ts = /* @__PURE__ */ ((n) => (n[n.NEXT = 0] = "NEXT", n[n.PREV = 1] = "PREV", n))(ts || {});
- function Kr(n, e, t) {
- const { startOffset: o } = e;
- let s = null;
- for (const A of n.getChildren()) {
- for (const l of A.children) {
- const d = l.children[0];
- if (d && o > d.startIndex && o < d.endIndex) {
- s = d;
- break;
- }
- }
- if (s)
- break;
- }
- if (s == null)
- return null;
- let r = -1, i = -1, a = null;
- for (const A of s.children) {
- for (const l of A.children)
- if (o > l.startIndex && o < l.endIndex) {
- r = A.children.indexOf(l), i = s.children.indexOf(A), a = A;
- break;
- }
- if (r > -1)
- break;
- }
- if (r === -1 || i === -1 || a == null)
- return null;
- let c = null;
- if (t === 0) {
- if (c = a.children[r + 1], !c) {
- const A = s.children[i + 1];
- A && (c = A.children[0]);
- }
- } else if (c = a.children[r - 1], !c) {
- const A = s.children[i - 1];
- A && (c = A.children[A.children.length - 1]);
- }
- if (c) {
- const { startIndex: A, endIndex: l } = c;
- return {
- startOffset: A + 1,
- endOffset: l - 2
- };
- }
- }
- function dd(n, e) {
- const t = [], { customBlocks: o = [] } = n;
- for (const s of e) {
- const { startOffset: r, endOffset: i } = s;
- if (!(r == null || i == null))
- for (const a of o) {
- const { startIndex: c } = a;
- c >= r && c < i && t.push(a.blockId);
- }
- }
- return t;
- }
- function ud(n) {
- return n.some((e) => {
- const { startNodePosition: t } = e;
- return t ? (t == null ? void 0 : t.path.indexOf("cells")) > -1 : !1;
- });
- }
- const hd = Is, fa = {
- id: "doc.command.inner-paste",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function, complexity
- handler: async (n, e) => {
- var O, P, b, B, M, H;
- const { segmentId: t, textRanges: o, doc: s } = e, r = n.get(y), i = n.get(G), a = n.get(Q), c = i.getTextRanges(), A = i.getRectRanges(), { body: l, tableSource: d, drawings: h } = s;
- if (!Array.isArray(c) || c.length === 0 || l == null)
- return !1;
- const u = a.getCurrentUniverDocInstance(), g = u == null ? void 0 : u.getSelfOrHeaderFooterModel(t).getBody();
- if (u == null || g == null)
- return !1;
- const f = u.getUnitId(), p = {
- id: J.id,
- params: {
- unitId: f,
- actions: [],
- textRanges: o,
- segmentId: t
- }
- }, m = new St();
- m.reset();
- const E = new me(), I = k.getInstance(), v = [], R = !!((O = l.tables) != null && O.length), S = !!((P = l.customBlocks) != null && P.length);
- if (R && t || R && ud(c) || c.length && (A != null && A.length))
- return !1;
- for (let F = 0; F < c.length; F++) {
- const D = c[F], { startOffset: te, endOffset: q, collapsed: V } = D, Y = te - m.cursor, oe = X.deepClone(l);
- if (R)
- for (const Ae of oe.tables) {
- const { tableId: ne } = Ae, ae = X.generateRandomId(6);
- Ae.tableId = ae;
- const Te = X.deepClone(d[ne]);
- Te.tableId = ae;
- const je = I.insertOp(["tableSource", ae], Te);
- v.push(je);
- }
- if (S && h) {
- const Ae = (B = (b = u.getSnapshot().drawingsOrder) == null ? void 0 : b.length) != null ? B : 0;
- for (const ne of oe.customBlocks) {
- const { blockId: ae } = ne, Te = X.generateRandomId(6);
- ne.blockId = Te;
- const je = X.deepClone(h[ae]);
- je.drawingId = Te;
- const ut = I.insertOp(["drawings", Te], je), we = I.insertOp(["drawingsOrder", Ae], Te);
- v.push(ut), v.push(we);
- }
- }
- const ce = Os((M = g.customRanges) != null ? M : [], q, hd.includes(f)), he = Ts((H = g.customDecorations) != null ? H : [], q);
- if (ce && (oe.customRanges = [{
- ...ce,
- startIndex: 0,
- endIndex: l.dataStream.length - 1
- }]), he.length && (oe.customDecorations = he.map((Ae) => ({
- ...Ae,
- startIndex: 0,
- endIndex: l.dataStream.length - 1
- }))), V)
- E.push({
- t: W.RETAIN,
- len: Y
- }), E.push({
- t: W.INSERT,
- body: oe,
- len: l.dataStream.length
- });
- else {
- const Ae = Ce.selection.delete([D], l, m.cursor, oe, c.length === 1);
- E.push(...Ae);
- }
- m.reset(), m.moveCursor(q);
- }
- const C = le(u, t);
- return v.push(I.editOp(E.serialize(), C)), p.params.actions = v.reduce((F, D) => k.compose(F, D), null), !!r.syncExecuteCommand(p.id, p.params);
- }
- };
- function gd(n, e) {
- const { startOffset: t, endOffset: o } = n, s = e.some((i) => i.startIndex === o), r = Math.max(t, s ? o - 1 : o);
- return {
- ...n,
- endOffset: r,
- collapsed: t === r
- };
- }
- function fd(n, e, t) {
- var g, f;
- const o = e.getSelfOrHeaderFooterModel(t).getBody(), s = new me(), r = k.getInstance(), i = [];
- if (o == null)
- return i;
- const { tables: a = [] } = o, c = new St();
- c.reset();
- for (let p = 0; p < n.length; p++) {
- const m = gd(n[p], a), { startOffset: E, endOffset: I, collapsed: v } = m, R = E - c.cursor;
- v ? s.push({
- t: W.RETAIN,
- len: R
- }) : s.push(...Ce.selection.delete([m], o, c.cursor, null, !1)), c.reset(), c.moveCursor(I);
- }
- const A = le(e, t);
- i.push(r.editOp(s.serialize(), A));
- const l = dd(o, n), d = (g = e.getDrawings()) != null ? g : {}, h = (f = e.getDrawingsOrder()) != null ? f : [], u = l.sort((p, m) => h.indexOf(p) > h.indexOf(m) ? -1 : h.indexOf(p) < h.indexOf(m) ? 1 : 0);
- if (u.length > 0)
- for (const p of u) {
- const m = d[p], E = h.indexOf(p);
- if (m == null || E < 0)
- continue;
- const I = r.removeOp(["drawings", p], m), v = r.removeOp(["drawingsOrder", E], p);
- i.push(I), i.push(v);
- }
- return i.reduce((p, m) => k.compose(p, m), null);
- }
- function pd(n, e, t, o) {
- const s = [];
- if (e.getSelfOrHeaderFooterModel(o).getBody() == null)
- return s;
- const i = new me(), a = k.getInstance(), c = new St();
- c.reset();
- for (const l of n) {
- const { startOffset: d, endOffset: h, spanEntireRow: u, spanEntireTable: g } = l;
- if (!(d == null || h == null))
- if (g) {
- const f = ga({ startOffset: d, endOffset: h, segmentId: o }, t);
- if (f == null)
- continue;
- const { offset: p, len: m, tableId: E } = f;
- p - c.cursor > 0 && i.push({
- t: W.RETAIN,
- len: p - c.cursor
- }), i.push({
- t: W.DELETE,
- len: m
- });
- const I = a.removeOp(["tableSource", E]);
- s.push(I), c.moveCursorTo(p + m);
- } else if (u) {
- const f = ha({ startOffset: d, endOffset: h, segmentId: o }, t);
- if (f == null)
- continue;
- const { offset: p, rowIndexes: m, len: E, tableId: I } = f;
- p - c.cursor > 0 && i.push({
- t: W.RETAIN,
- len: p - c.cursor
- }), i.push({
- t: W.DELETE,
- len: E
- });
- for (const v of m.reverse()) {
- const R = a.removeOp(["tableSource", I, "tableRows", v]);
- s.push(R);
- }
- c.moveCursorTo(p + E);
- } else {
- const f = ld({ startOffset: d, endOffset: h, segmentId: o }, t);
- if (f == null)
- continue;
- const { offsets: p } = f;
- for (const m of p) {
- const { retain: E, delete: I } = m;
- E - c.cursor > 0 && i.push({
- t: W.RETAIN,
- len: E - c.cursor
- }), i.push({
- t: W.DELETE,
- len: I
- }), c.moveCursorTo(E + I);
- }
- }
- }
- const A = le(e, o);
- return s.push(a.editOp(i.serialize(), A)), s.reduce((l, d) => k.compose(l, d), null);
- }
- function md(n, e, t, o, s) {
- let r = [];
- if (Array.isArray(n) && (n == null ? void 0 : n.length) !== 0 && (r = fd(n, t, s)), Array.isArray(e) && (e == null ? void 0 : e.length) !== 0) {
- const i = pd(e, t, o, s);
- r == null || r.length === 0 ? r = i : r = k.compose(
- r,
- k.transform(i, r, "right")
- );
- }
- return r;
- }
- const Qt = {
- id: "doc.command.inner-cut",
- type: N.COMMAND,
- handler: async (n, e) => {
- var f, p;
- const { segmentId: t, textRanges: o } = e, s = n.get(y), r = n.get(G), i = n.get(Q), a = (f = e.selections) != null ? f : r.getTextRanges(), c = r.getRectRanges();
- if ((!Array.isArray(a) || a.length === 0) && (!Array.isArray(c) || c.length === 0))
- return !1;
- const A = (p = i.getCurrentUniverDocInstance()) == null ? void 0 : p.getUnitId();
- if (!A)
- return !1;
- const l = i.getUniverDocInstance(A);
- if (l == null)
- return !1;
- const d = ke(n, A);
- if (d == null)
- return !1;
- const h = d.getViewModel(), u = {
- id: J.id,
- params: {
- unitId: A,
- actions: [],
- textRanges: o
- }
- };
- return u.params.actions = md(a, c, l, h, t), !!s.syncExecuteCommand(u.id, u.params);
- }
- };
- var Be = /* @__PURE__ */ ((n) => (n[n.LEFT = 0] = "LEFT", n[n.RIGHT = 1] = "RIGHT", n))(Be || {});
- const Ed = "doc.command.insert-text", Vs = {
- id: Ed,
- type: N.COMMAND,
- handler: async (n, e) => {
- var S;
- const t = n.get(y), { range: o, segmentId: s, body: r, unitId: i, cursorOffset: a } = e, c = n.get(G), l = n.get(Q).getUnit(i, _.UNIVER_DOC);
- if (l == null)
- return !1;
- const d = c.getActiveTextRange(), h = l.getSelfOrHeaderFooterModel((S = d == null ? void 0 : d.segmentId) != null ? S : "").getBody();
- if (h == null)
- return !1;
- const { startOffset: u, collapsed: g } = o, f = a != null ? a : r.dataStream.length, p = [
- {
- startOffset: u + f,
- endOffset: u + f,
- style: d == null ? void 0 : d.style,
- collapsed: g
- }
- ], m = {
- id: J.id,
- params: {
- unitId: i,
- actions: [],
- textRanges: p,
- debounce: !0
- }
- }, E = new me(), I = k.getInstance();
- if (g)
- u > 0 && E.push({
- t: W.RETAIN,
- len: u
- }), E.push({
- t: W.INSERT,
- body: r,
- len: r.dataStream.length
- });
- else {
- const C = Ce.selection.delete([o], h, 0, r);
- E.push(...C);
- }
- m.params.textRanges = [{
- startOffset: u + f,
- endOffset: u + f,
- collapsed: g
- }];
- const v = le(l, s);
- return m.params.actions = I.editOp(E.serialize(), v), !!t.syncExecuteCommand(m.id, m.params);
- }
- }, dn = {
- id: "doc.command.delete-text",
- type: N.COMMAND,
- handler: async (n, e) => {
- var R;
- const t = n.get(y), o = n.get(Q), { range: s, segmentId: r, unitId: i, direction: a, len: c = 1 } = e, A = o.getUnit(i, _.UNIVER_DOC), l = A == null ? void 0 : A.getSelfOrHeaderFooterModel(r).getBody();
- if (A == null || l == null)
- return !1;
- const { startOffset: d } = s;
- let h = a === Be.LEFT ? d - c : d, u = a === Be.LEFT ? d - 1 : d + c - 1;
- const g = (R = l.customRanges) == null ? void 0 : R.find((S) => S.startIndex <= h && S.endIndex >= u);
- g != null && g.wholeEntity && (h = g.startIndex, u = Math.max(u, g.endIndex));
- const f = {
- id: J.id,
- params: {
- unitId: i,
- actions: [],
- textRanges: [{
- startOffset: h,
- endOffset: h,
- collapsed: !0
- }],
- debounce: !0
- }
- }, p = new me(), m = k.getInstance();
- p.push({
- t: W.RETAIN,
- len: h - 0
- }), p.push({
- t: W.DELETE,
- len: u - h + 1
- });
- const I = le(A, r);
- return f.params.actions = m.editOp(p.serialize(), I), !!t.syncExecuteCommand(f.id, f.params);
- }
- }, pa = {
- id: "doc.command.update-text",
- type: N.COMMAND,
- handler: async (n, e) => {
- const { range: t, segmentId: o, updateBody: s, coverType: r, unitId: i, textRanges: a } = e, c = n.get(y), l = n.get(Q).getCurrentUniverDocInstance();
- if (l == null)
- return !1;
- const d = {
- id: J.id,
- params: {
- unitId: i,
- actions: [],
- textRanges: a
- }
- }, h = new me(), u = k.getInstance(), { startOffset: g, endOffset: f } = t;
- h.push({
- t: W.RETAIN,
- len: g
- }), h.push({
- t: W.RETAIN,
- body: s,
- len: f - g,
- coverType: r
- });
- const p = le(l, o);
- return d.params.actions = u.editOp(h.serialize(), p), !!c.syncExecuteCommand(d.id, d.params);
- }
- }, js = {
- id: "doc.command.delete-custom-block",
- type: N.COMMAND,
- handler: async (n, e) => {
- var b;
- const t = n.get(G), o = n.get(Q), s = n.get(y), r = t.getActiveTextRange(), i = o.getCurrentUniverDocInstance();
- if (r == null || i == null)
- return !1;
- const { direction: a, range: c, unitId: A, drawingId: l } = e, { startOffset: d, segmentId: h, style: u } = r, g = a === Be.LEFT ? d - 1 : d, f = [
- {
- startOffset: g,
- endOffset: g,
- style: u
- }
- ], p = {
- id: J.id,
- params: {
- unitId: A,
- actions: [],
- textRanges: f,
- prevTextRanges: [c]
- }
- }, m = new me(), E = k.getInstance(), I = [];
- d > 0 && m.push({
- t: W.RETAIN,
- len: a === Be.LEFT ? d - 1 : d
- }), m.push({
- t: W.DELETE,
- len: 1
- });
- const v = le(i, h);
- I.push(E.editOp(m.serialize(), v));
- const R = ((b = i.getDrawings()) != null ? b : {})[l], C = i.getDrawingsOrder().indexOf(l), T = E.removeOp(["drawings", l], R), O = E.removeOp(["drawingsOrder", C], l);
- return I.push(T), I.push(O), p.params.actions = I.reduce((B, M) => k.compose(B, M), null), !!s.syncExecuteCommand(p.id, p.params);
- }
- }, Ws = {
- id: "doc.command.merge-two-paragraph",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n, e) => {
- const t = n.get(G), o = n.get(Q), s = n.get(y), { direction: r, range: i } = e, a = t.getActiveTextRange(), c = t.getTextRanges();
- if (a == null || c == null)
- return !1;
- const { segmentId: A, style: l } = a, d = o.getCurrentUnitForType(_.UNIVER_DOC), h = d == null ? void 0 : d.getSelfOrHeaderFooterModel(A).getBody();
- if (d == null || h == null)
- return !1;
- const u = a, g = d.getUnitId(), { startOffset: f, collapsed: p } = u;
- if (!p)
- return !1;
- const m = r === Be.LEFT ? f : f + 1;
- let E, I;
- for (const b of h.paragraphs) {
- if (b.startIndex >= m) {
- I = b;
- break;
- }
- E = b;
- }
- if (E == null || I == null)
- return !1;
- const v = r === Be.LEFT ? f - 1 : f, R = [
- {
- startOffset: v,
- endOffset: v,
- style: l
- }
- ], S = {
- id: J.id,
- params: {
- unitId: g,
- actions: [],
- textRanges: R,
- prevTextRanges: [i]
- }
- }, C = new me(), T = k.getInstance();
- E.startIndex > 0 && C.push({
- t: W.RETAIN,
- len: E.startIndex
- }), C.push({
- t: W.DELETE,
- len: 1
- }), I.startIndex > E.startIndex + 1 && C.push({
- t: W.RETAIN,
- len: I.startIndex - E.startIndex - 1
- }), C.push({
- t: W.RETAIN,
- len: 1,
- coverType: no.REPLACE,
- body: {
- dataStream: "",
- paragraphs: [
- {
- ...X.deepClone(E),
- startIndex: 0
- }
- ]
- }
- });
- const O = le(d, A);
- return S.params.actions = T.editOp(C.serialize(), O), !!s.syncExecuteCommand(S.id, S.params);
- }
- };
- function zs(n, e) {
- let t = 0;
- if (n == null || n.length === 0) {
- if (typeof e[0].startOffset == "number") {
- const o = e[0], { spanEntireRow: s, spanEntireTable: r } = o;
- r ? t = o.startOffset - 3 : s ? o.startRow > 0 ? t = o.startOffset - 6 : t = o.startOffset : t = e[0].startOffset;
- }
- } else if (n.length > 0 && e.length > 0) {
- const o = n[0], s = e[0];
- if (o.startOffset != null && s.startOffset != null) {
- if (o.startOffset < s.startOffset)
- t = o.startOffset;
- else if (o.startOffset >= s.startOffset) {
- const { spanEntireRow: r, spanEntireTable: i } = s;
- i ? t = s.startOffset - 3 : r && (t = s.startOffset - 6);
- }
- }
- }
- return t;
- }
- const So = {
- id: "doc.command.delete-left",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function, complexity
- handler: async (n) => {
- var O, P;
- const e = n.get(G), t = n.get(Q), o = n.get(y);
- let s = !0;
- const r = t.getCurrentUniverDocInstance();
- if (r == null)
- return !1;
- const i = r.getUnitId(), a = ke(n, i), c = e.getActiveTextRange(), A = e.getRectRanges(), l = e.getTextRanges(), d = a == null ? void 0 : a.getSkeleton();
- if (d == null)
- return !1;
- if (A != null && A.length) {
- const b = zs(l, A), B = A[0].segmentId, M = [
- {
- startOffset: b,
- endOffset: b
- }
- ];
- return o.executeCommand(Qt.id, {
- segmentId: B,
- textRanges: M
- });
- }
- if (c == null || l == null)
- return !1;
- const { segmentId: h, style: u, segmentPage: g } = c, f = r.getSelfOrHeaderFooterModel(h).getBody();
- if (f == null)
- return !1;
- const p = c, { startOffset: m, collapsed: E } = p, I = d.findNodeByCharIndex(m, h, g), v = hc(I), R = gc(I, f);
- let S = m;
- const C = d.findNodeByCharIndex(m - 1, h, g);
- if (fc(I) && C !== I && (v === !0 || R === !0) && E) {
- const b = pc(I, f);
- if (b == null)
- return !1;
- const B = b == null ? void 0 : b.startIndex, M = { startIndex: 0 }, H = b.paragraphStyle;
- if (v === !0) {
- const D = b.paragraphStyle;
- if (D) {
- M.paragraphStyle = D;
- const { hanging: te } = D;
- te && (M.paragraphStyle.indentStart = te, M.paragraphStyle.hanging = void 0);
- }
- } else if (R === !0) {
- const D = b.bullet;
- D && (M.bullet = D), H != null && (M.paragraphStyle = { ...H }, delete M.paragraphStyle.hanging, delete M.paragraphStyle.indentStart);
- }
- const F = [
- {
- startOffset: S,
- endOffset: S,
- style: u
- }
- ];
- s = await o.executeCommand(pa.id, {
- unitId: r.getUnitId(),
- updateBody: {
- dataStream: "",
- paragraphs: [{ ...M }]
- },
- range: {
- startOffset: B,
- endOffset: B + 1
- },
- textRanges: F,
- coverType: no.REPLACE,
- segmentId: h
- });
- } else if (E === !0) {
- if (C == null)
- return !0;
- if (C.content === "\r")
- s = await o.executeCommand(Ws.id, {
- direction: Be.LEFT,
- range: p
- });
- else if (C.streamType === "\b") {
- const b = (P = r.getSnapshot().drawings) == null ? void 0 : P[(O = C.drawingId) != null ? O : ""];
- if (b == null)
- return !0;
- if (b.layoutType === oo.INLINE) {
- const M = r.getUnitId();
- s = await o.executeCommand(js.id, {
- direction: Be.LEFT,
- range: c,
- unitId: M,
- drawingId: C.drawingId
- });
- } else {
- const M = d.findNodeByCharIndex(m - 2);
- if (M == null)
- return !0;
- S -= C.count, S -= M.count;
- const H = [
- {
- startOffset: S,
- endOffset: S,
- style: u
- }
- ];
- s = await o.executeCommand(dn.id, {
- unitId: r.getUnitId(),
- range: {
- ...c,
- startOffset: c.startOffset - 1,
- endOffset: c.endOffset - 1
- },
- segmentId: h,
- direction: Be.LEFT,
- len: M.count,
- textRanges: H
- });
- }
- } else
- S -= C.count, s = await o.executeCommand(dn.id, {
- unitId: r.getUnitId(),
- range: p,
- segmentId: h,
- direction: Be.LEFT,
- len: C.count
- });
- } else {
- const b = Ea(p, [p]);
- s = await o.executeCommand(Qt.id, {
- segmentId: h,
- textRanges: b,
- selections: [p]
- });
- }
- return s;
- }
- }, ma = {
- id: "doc.command.delete-right",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function, complexity
- handler: async (n) => {
- var I, v;
- const e = n.get(G), o = n.get(Q).getCurrentUniverDocInstance();
- if (!o)
- return !1;
- const s = ke(n, o.getUnitId()), r = n.get(y), i = e.getActiveTextRange(), a = e.getRectRanges(), c = e.getTextRanges(), A = s == null ? void 0 : s.getSkeleton();
- if (a != null && a.length) {
- const R = zs(c, a), S = a[0].segmentId, C = [
- {
- startOffset: R,
- endOffset: R
- }
- ];
- return r.executeCommand(Qt.id, {
- segmentId: S,
- textRanges: C
- });
- }
- if (i == null || A == null || c == null)
- return !1;
- const { segmentId: l, style: d, segmentPage: h } = i, u = o == null ? void 0 : o.getSelfOrHeaderFooterModel(l).getBody();
- if (!o || !u)
- return !1;
- const g = i, { startOffset: f, endOffset: p, collapsed: m } = g;
- if (f === u.dataStream.length - 2 && m)
- return !0;
- let E = !1;
- if (m === !0) {
- const R = A.findNodeByCharIndex(f, l, h), S = A.findNodeByCharIndex(f + 1);
- if (R.streamType === U.PARAGRAPH && (S == null ? void 0 : S.streamType) === U.SECTION_BREAK)
- return !1;
- if (R.content === "\r")
- E = await r.executeCommand(Ws.id, {
- direction: Be.RIGHT,
- range: i
- });
- else if (R.streamType === "\b") {
- const C = (v = o.getSnapshot().drawings) == null ? void 0 : v[(I = R.drawingId) != null ? I : ""];
- if (C == null)
- return !0;
- if (C.layoutType === oo.INLINE) {
- const O = o.getUnitId();
- E = await r.executeCommand(js.id, {
- direction: Be.RIGHT,
- range: i,
- unitId: O,
- drawingId: R.drawingId
- });
- } else {
- if (S == null)
- return !0;
- const O = [
- {
- startOffset: f + 1,
- endOffset: f + 1,
- style: d
- }
- ];
- E = await r.executeCommand(dn.id, {
- unitId: o.getUnitId(),
- range: {
- ...i,
- startOffset: f + 1,
- endOffset: p + 1
- },
- segmentId: l,
- direction: Be.RIGHT,
- textRanges: O,
- len: S.count
- });
- }
- } else {
- const C = [
- {
- startOffset: f,
- endOffset: f,
- style: d
- }
- ];
- E = await r.executeCommand(dn.id, {
- unitId: o.getUnitId(),
- range: g,
- segmentId: l,
- direction: Be.RIGHT,
- textRanges: C,
- len: R.count
- });
- }
- } else {
- const R = Ea(g, [g]);
- E = await r.executeCommand(Qt.id, {
- segmentId: l,
- textRanges: R,
- selections: [g]
- });
- }
- return E;
- }
- };
- function Ea(n, e) {
- let t = n.endOffset;
- for (const s of e) {
- const { startOffset: r, endOffset: i } = s;
- r == null || i == null || i <= n.endOffset && (t -= i - r);
- }
- return [
- {
- startOffset: t,
- endOffset: t,
- style: n.style
- }
- ];
- }
- const Sd = 10, Id = 6;
- function Cd() {
- return X.generateRandomId(Id);
- }
- function vd(n) {
- const e = n.match(/data-copy-id="([^\s]+)"/);
- return e && e[1] ? e[1] : null;
- }
- class Rd {
- constructor() {
- x(this, "_cache", new Xa(Sd));
- }
- set(e, t) {
- this._cache.set(e, t);
- }
- get(e) {
- return this._cache.get(e);
- }
- clear() {
- this._cache.clear();
- }
- }
- const No = new Rd();
- function Gs(n) {
- const e = n.style, t = {}, o = n.tagName.toLowerCase();
- switch (o) {
- case "b":
- case "em":
- case "strong": {
- t.bl = L.TRUE;
- break;
- }
- case "s": {
- t.st = {
- s: L.TRUE
- };
- break;
- }
- case "u": {
- t.ul = {
- s: L.TRUE
- };
- break;
- }
- case "i": {
- t.it = L.TRUE;
- break;
- }
- case "sub":
- case "sup": {
- t.va = o === "sup" ? Ne.SUPERSCRIPT : Ne.SUBSCRIPT;
- break;
- }
- }
- for (let s = 0; s < e.length; s++) {
- const r = e[s], i = e.getPropertyValue(r);
- switch (r) {
- case "font-family": {
- t.ff = i.replace(/^"/g, "").replace(/"$/g, "");
- break;
- }
- case "font-size": {
- const a = Number.parseInt(i);
- Number.isNaN(a) || (i.endsWith("pt") ? t.fs = a : i.endsWith("px") && (t.fs = mc(a)));
- break;
- }
- case "font-style": {
- i === "italic" && (t.it = L.TRUE);
- break;
- }
- case "font-weight": {
- (Number(i) > 400 || String(i) === "bold") && (t.bl = L.TRUE);
- break;
- }
- case "text-decoration": {
- /underline/.test(i) ? t.ul = {
- s: L.TRUE
- } : /overline/.test(i) ? t.ol = {
- s: L.TRUE
- } : /line-through/.test(i) && (t.st = {
- s: L.TRUE
- });
- break;
- }
- case "color": {
- try {
- const a = new dr(i);
- a.isValid && (t.cl = {
- rgb: a.toRgbString()
- });
- } catch {
- }
- break;
- }
- case "background-color": {
- const a = new dr(i);
- a.isValid && (t.bg = {
- rgb: a.toRgbString()
- });
- break;
- }
- }
- }
- return t;
- }
- function bd(n) {
- const e = new DOMParser(), t = `<x-univer id="univer-root">${n}</x-univer>`;
- return e.parseFromString(t, "text/html").querySelector("#univer-root");
- }
- function Xr(n, e) {
- const t = n.tagName.toLowerCase();
- return typeof e == "string" ? t === e : Array.isArray(e) ? e.some((o) => o === t) : e(n);
- }
- const Jr = 660, Jn = class Jn {
- constructor() {
- x(this, "_tableCache", []);
- x(this, "_styleCache", /* @__PURE__ */ new Map());
- x(this, "_styleRules", []);
- x(this, "_afterProcessRules", []);
- }
- static use(e) {
- if (this._pluginList.includes(e))
- throw new Error(`Univer paste plugin ${e.name} already added`);
- this._pluginList.push(e);
- }
- convert(e, t = {}) {
- var a;
- const o = Jn._pluginList.find((c) => c.checkPasteType(e)), s = bd(e), i = {
- body: {
- dataStream: "",
- paragraphs: [],
- sectionBreaks: [],
- tables: [],
- textRuns: [],
- customBlocks: []
- },
- tableSource: {},
- id: (a = t == null ? void 0 : t.unitId) != null ? a : ""
- };
- return o && (this._styleRules = [...o.stylesRules], this._afterProcessRules = [...o.afterProcessRules]), this._tableCache = [], this._styleCache.clear(), this._process(null, s.childNodes, i), this._styleCache.clear(), this._styleRules = [], this._afterProcessRules = [], i;
- }
- // eslint-disable-next-line max-lines-per-function, complexity
- _process(e, t, o) {
- var r, i, a, c;
- const s = o.body;
- for (const A of t)
- if (A.nodeType === Node.TEXT_NODE) {
- if (((r = A.nodeValue) == null ? void 0 : r.trim()) === "")
- continue;
- const l = (i = A.nodeValue) == null ? void 0 : i.replace(/[\r\n]/g, "");
- let d;
- e && this._styleCache.has(e) && (d = this._styleCache.get(e)), s.dataStream += l, d && Object.getOwnPropertyNames(d).length && s.textRuns.push({
- st: s.dataStream.length - l.length,
- ed: s.dataStream.length,
- ts: d
- });
- } else if (A.nodeName === "IMG") {
- const l = A, d = l.dataset.imageSourceType, h = d === xs.UUID ? l.dataset.source : l.src;
- if (h && d) {
- const u = Number(l.dataset.width || 100), g = Number(l.dataset.height || 100), f = Number(l.dataset.docTransformWidth || u), p = Number(l.dataset.docTransformHeight || g), m = X.generateRandomId(6);
- (c = (a = o.body) == null ? void 0 : a.customBlocks) == null || c.push({ startIndex: s.dataStream.length, blockId: m }), s.dataStream += "\b", o.drawings || (o.drawings = {}), o.drawings[m] = {
- drawingId: m,
- title: "",
- description: "",
- imageSourceType: d,
- source: h,
- transform: { width: u, height: g, left: 0 },
- docTransform: {
- size: { width: f, height: p },
- angle: 0,
- positionH: {
- relativeFrom: $n.PAGE,
- posOffset: 0
- },
- positionV: {
- relativeFrom: ot.PARAGRAPH,
- posOffset: 0
- }
- },
- layoutType: oo.INLINE,
- drawingType: Cs.DRAWING_IMAGE,
- unitId: o.id || "",
- subUnitId: o.id || ""
- };
- }
- } else {
- if (Ja.includes(A.nodeName.toLowerCase()))
- continue;
- if (A.nodeType === Node.ELEMENT_NODE) {
- const l = A, d = this._processBeforeLink(l, o), h = e ? this._styleCache.get(e) : {}, u = this._styleRules.find(({ filter: m }) => Xr(A, m)), g = u ? u.getStyle(A) : Gs(A);
- this._styleCache.set(A, { ...h, ...g });
- const { childNodes: f } = A;
- this._processBeforeTable(A, o), this._process(A, f, o), this._processAfterTable(A, o);
- const p = this._afterProcessRules.find(
- ({ filter: m }) => Xr(A, m)
- );
- p && p.handler(o, A), this._processAfterLink(l, o, d);
- }
- }
- }
- _processBeforeTable(e, t) {
- var r;
- const o = e.tagName.toUpperCase(), s = t.body;
- switch (o) {
- case "TABLE": {
- s.dataStream[s.dataStream.length - 1] !== "\r" && (s.dataStream += "\r", s.paragraphs == null && (s.paragraphs = []), (r = s.paragraphs) == null || r.push({
- startIndex: s.dataStream.length - 1
- }));
- const i = ua(0, 0, Jr);
- this._tableCache.push({
- table: i,
- startIndex: s.dataStream.length
- }), s.dataStream += U.TABLE_START;
- break;
- }
- case "TR": {
- const i = Hs(0);
- this._tableCache[this._tableCache.length - 1].table.tableRows.push(i), s.dataStream += U.TABLE_ROW_START;
- break;
- }
- case "TD": {
- const i = Fs(), a = this._tableCache[this._tableCache.length - 1].table;
- a.tableRows[a.tableRows.length - 1].tableCells.push(i), s.dataStream += U.TABLE_CELL_START;
- break;
- }
- }
- }
- _processAfterTable(e, t) {
- var i, a;
- const o = e.tagName.toUpperCase(), s = t.body;
- t.tableSource == null && (t.tableSource = {}), s.tables == null && (s.tables = []), s.sectionBreaks == null && (s.sectionBreaks = []);
- const { tableSource: r } = t;
- switch (o) {
- case "TABLE": {
- const c = this._tableCache.pop(), { startIndex: A, table: l } = c, d = l.tableRows[0].tableCells.length, h = ks(Jr / d), u = [...new Array(d).fill(null).map(() => X.deepClone(h))];
- l.tableColumns = u, r[l.tableId] = l, s.dataStream += U.TABLE_END, s.tables.push({
- startIndex: A,
- endIndex: s.dataStream.length,
- tableId: l.tableId
- });
- break;
- }
- case "TR": {
- s.dataStream += U.TABLE_ROW_END;
- break;
- }
- case "TD": {
- s.dataStream[s.dataStream.length - 1] !== "\r" && ((i = s.paragraphs) == null || i.push({
- startIndex: s.dataStream.length
- }), s.dataStream += "\r"), (a = s.sectionBreaks) == null || a.push({
- startIndex: s.dataStream.length
- }), s.dataStream += `
- ${U.TABLE_CELL_END}`;
- break;
- }
- }
- }
- _processBeforeLink(e, t) {
- return t.body.dataStream.length;
- }
- _processAfterLink(e, t, o) {
- var i, a;
- const s = t.body, r = e;
- r.tagName.toUpperCase() === "A" && (s.customRanges = (i = s.customRanges) != null ? i : [], s.customRanges.push({
- startIndex: o,
- endIndex: s.dataStream.length - 1,
- rangeId: (a = r.dataset.rangeid) != null ? a : pt(),
- rangeType: Ii.HYPERLINK,
- properties: { url: r.href }
- }));
- }
- };
- x(Jn, "_pluginList", []);
- let Ut = Jn;
- const xd = {
- name: "univer-doc-paste-plugin-lark",
- checkPasteType(n) {
- return /lark-record-clipboard/i.test(n);
- },
- // TODO: @JOCS, support inline code copy from lark.
- stylesRules: [
- {
- filter: ["s"],
- getStyle(n) {
- const e = Gs(n);
- return {
- st: {
- s: L.TRUE
- },
- ...e
- };
- }
- }
- ],
- afterProcessRules: [
- {
- filter(n) {
- return n.tagName === "DIV" && /ace-line/i.test(n.className);
- },
- handler(n) {
- const e = n.body;
- e.paragraphs == null && (e.paragraphs = []), e.paragraphs.push({
- startIndex: e.dataStream.length
- }), e.dataStream += "\r";
- }
- }
- ]
- };
- function Sa(n) {
- const e = n.style, t = {};
- for (let o = 0; o < e.length; o++) {
- const s = e[o], r = e.getPropertyValue(s);
- switch (s) {
- case "margin-top": {
- const i = Number.parseInt(r);
- t.spaceAbove = { v: /pt/.test(r) ? Er(i) : i };
- break;
- }
- case "margin-bottom": {
- const i = Number.parseInt(r);
- t.spaceBelow = { v: /pt/.test(r) ? Er(i) : i };
- break;
- }
- case "line-height": {
- let i = Number.parseFloat(r);
- r.endsWith("%") && (i /= 100), t.lineSpacing = i;
- break;
- }
- }
- }
- return Object.getOwnPropertyNames(t).length ? t : null;
- }
- const Od = {
- name: "univer-doc-paste-plugin-univer",
- checkPasteType(n) {
- return /UniverNormal/i.test(n);
- },
- stylesRules: [],
- afterProcessRules: [
- {
- filter(n) {
- return n.tagName === "P" && /UniverNormal/i.test(n.className);
- },
- handler(n, e) {
- const t = n.body;
- t.paragraphs == null && (t.paragraphs = []);
- const o = {
- startIndex: t.dataStream.length
- }, s = Sa(e);
- s && (o.paragraphStyle = s), t.paragraphs.push(o), t.dataStream += "\r";
- }
- }
- ]
- }, Td = {
- name: "univer-doc-paste-plugin-word",
- checkPasteType(n) {
- return /word|mso/i.test(n);
- },
- stylesRules: [
- {
- filter: ["b"],
- getStyle(n) {
- const e = Gs(n);
- return { bl: L.TRUE, ...e };
- }
- }
- ],
- afterProcessRules: [
- {
- filter(n) {
- return n.tagName === "P";
- },
- handler(n, e) {
- const t = n.body;
- t.paragraphs == null && (t.paragraphs = []);
- const o = {
- startIndex: t.dataStream.length
- }, s = Sa(e);
- s && (o.paragraphStyle = s), t.paragraphs.push(o), t.dataStream += "\r";
- }
- }
- ]
- };
- function yd(n) {
- var o, s;
- const e = (r) => {
- let i = "";
- return Object.keys(r).forEach((a) => {
- r[a] !== void 0 && (i += ` ${a}=${r[a]}`);
- }), i;
- }, t = {
- "data-doc-transform-height": n.docTransform.size.height,
- "data-doc-transform-width": n.docTransform.size.width,
- "data-width": (o = n.transform) == null ? void 0 : o.width,
- "data-height": (s = n.transform) == null ? void 0 : s.height,
- "data-image-source-type": n.imageSourceType,
- "data-source": n.imageSourceType === xs.UUID ? n.source : void 0,
- src: n.source
- };
- return `<img ${e(t)}></img>`;
- }
- function Zr(n, e) {
- const { st: t, ed: o, ts: s = {} } = e, { ff: r, fs: i, it: a, bl: c, ul: A, st: l, ol: d, bg: h, cl: u, va: g } = s;
- let f = n.slice(t, o);
- const p = [];
- return a === L.TRUE && (f = `<i>${f}</i>`), g === Ne.SUPERSCRIPT ? f = `<sup>${f}</sup>` : g === Ne.SUBSCRIPT && (f = `<sub>${f}</sub>`), (A == null ? void 0 : A.s) === L.TRUE && (f = `<u>${f}</u>`), (l == null ? void 0 : l.s) === L.TRUE && (f = `<s>${f}</s>`), c === L.TRUE && (f = `<strong>${f}</strong>`), r && p.push(`font-family: ${r}`), u && p.push(`color: ${u.rgb}`), i && p.push(`font-size: ${i}pt`), d && p.push("text-decoration: overline"), h && p.push(`background: ${h.rgb}`), p.length ? `<span style="${p.join("; ")};">${f}</span>` : f;
- }
- function Qo(n, e, t) {
- const { dataStream: o, textRuns: s = [] } = n;
- if (e === t)
- return "";
- let r = e;
- const i = [];
- for (const a of s) {
- const { st: c, ed: A } = a;
- X.hasIntersectionBetweenTwoRanges(e, t, c, A) && (c > r ? (i.push(o.slice(r, c)), i.push(Zr(o, {
- ...a,
- ed: Math.min(A, t)
- }))) : i.push(Zr(o, {
- ...a,
- st: r,
- ed: Math.min(A, t)
- }))), r = Math.max(e, Math.min(A, t));
- }
- return r !== t && i.push(o.slice(r, t)), i.join("");
- }
- function Bd(n, e, t) {
- const o = n.body, s = n.drawings || {}, { customRanges: r = [], customBlocks: i = [] } = o || {}, a = [...i], c = r.filter((u) => u.startIndex >= e && u.endIndex <= t);
- let A = e, l = "";
- const d = (u, g) => {
- let f = "", p = 0, m = u, E = a.findIndex((I) => u <= I.startIndex && g >= I.startIndex);
- if (E === -1)
- return f = Qo(o, u, g), { sliceHtml: f, customBlockLength: p };
- for (; E !== -1; ) {
- const I = a[E];
- a.splice(E, 1), f += Qo(o, m, I.startIndex);
- const v = s[I.blockId];
- if (v)
- switch (v.drawingType) {
- case Cs.DRAWING_IMAGE: {
- f += yd(v), p++;
- break;
- }
- }
- m = I.startIndex + 1, E = a.findIndex((R) => m <= R.startIndex && g >= R.startIndex);
- }
- return f = f + Qo(o, m, g + 1), { sliceHtml: f, customBlockLength: p };
- };
- c.forEach((u) => {
- var v, R;
- const { startIndex: g, endIndex: f, rangeType: p, rangeId: m } = u, E = d(A, g);
- l += E.sliceHtml;
- const I = d(g, f + 1);
- switch (p) {
- case Ii.HYPERLINK: {
- l += `<a data-rangeid="${m}" href="${(R = (v = u.properties) == null ? void 0 : v.url) != null ? R : ""}">${I.sliceHtml}</a>`;
- break;
- }
- default: {
- l += I.sliceHtml;
- break;
- }
- }
- A = f + 1 + (E.customBlockLength + I.customBlockLength);
- });
- const h = d(A, t);
- return l += h.sliceHtml, l;
- }
- function Md(n) {
- const e = n.body || {}, { paragraphs: t = [], sectionBreaks: o = [] } = e;
- let { dataStream: s = "" } = e;
- s.endsWith(`\r
- `) || (s += `\r
- `, t.push({
- startIndex: s.length - 2
- }), o.push({
- startIndex: s.length - 1
- }), e.dataStream = s, e.paragraphs = t, e.sectionBreaks = o);
- const r = { html: "" }, i = Ec(s).sectionList;
- for (const a of i)
- yt(a, n, r);
- return r.html;
- }
- function yt(n, e, t) {
- var o, s;
- switch (n.nodeType) {
- case qt.SECTION_BREAK: {
- for (const r of n.children)
- yt(r, e, t);
- break;
- }
- case qt.PARAGRAPH: {
- const { children: r, startIndex: i, endIndex: a } = n, c = (s = (o = e.body) == null ? void 0 : o.paragraphs.find((g) => g.startIndex === a)) != null ? s : {}, { paragraphStyle: A = {} } = c, { spaceAbove: l, spaceBelow: d, lineSpacing: h } = A, u = [];
- if (l != null && (typeof l == "number" ? u.push(`margin-top: ${l}px`) : u.push(`margin-top: ${l.v}px`)), d != null && (typeof d == "number" ? u.push(`margin-bottom: ${d}px`) : u.push(`margin-bottom: ${d.v}px`)), h != null && u.push(`line-height: ${h}`), t.html += `<p class="UniverNormal" ${u.length ? `style="${u.join("; ")};"` : ""}>`, r.length)
- for (const g of r)
- yt(g, e, t);
- t.html += `${Bd(e, i, a)}</p>`;
- break;
- }
- case qt.TABLE: {
- const { children: r } = n;
- t.html += '<table class="UniverTable" style="width: 100%; border-collapse: collapse;"><tbody>';
- for (const i of r)
- yt(i, e, t);
- t.html += "</tbody></table>";
- break;
- }
- case qt.TABLE_ROW: {
- const { children: r } = n;
- t.html += '<tr class="UniverTableRow">';
- for (const i of r)
- yt(i, e, t);
- t.html += "</tr>";
- break;
- }
- case qt.TABLE_CELL: {
- const { children: r } = n;
- t.html += '<td class="UniverTableCell">';
- for (const i of r)
- yt(i, e, t);
- t.html += "</td>";
- break;
- }
- default:
- throw new Error(`Unknown node type: ${n.nodeType}`);
- }
- }
- class _d {
- convert(e) {
- if (e.length === 0)
- throw new Error("The bodyList length at least to be 1");
- let t = "";
- for (const o of X.deepClone(e))
- t += Md(o);
- return t;
- }
- }
- var Pd = Object.defineProperty, Dd = Object.getOwnPropertyDescriptor, wd = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Dd(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Pd(e, t, s), s;
- }, Jt = (n, e) => (t, o) => e(t, o, n);
- Ut.use(Td);
- Ut.use(xd);
- Ut.use(Od);
- function $r(n, e, t) {
- var r, i, a;
- const o = Ei(n, e, t + 2), s = U.TABLE_START + U.TABLE_ROW_START + U.TABLE_CELL_START + o.dataStream + U.TABLE_CELL_END + U.TABLE_ROW_END + U.TABLE_END;
- return o.dataStream = s, (r = o.textRuns) == null || r.forEach((c) => {
- const { st: A, ed: l } = c;
- c.st = A + 3, c.ed = l + 3;
- }), (i = o.tables) == null || i.forEach((c) => {
- const { startIndex: A, endIndex: l } = c;
- c.startIndex = A + 3, c.endIndex = l + 3;
- }), (a = o.paragraphs) == null || a.forEach((c) => {
- const { startIndex: A } = c;
- c.startIndex = A + 3;
- }), o;
- }
- const Sn = ps("doc.clipboard-service");
- let ns = class extends ue {
- constructor(e, t, o, s, r) {
- super();
- x(this, "_clipboardHooks", []);
- x(this, "_htmlToUDM", new Ut());
- x(this, "_umdToHtml", new _d());
- this._univerInstanceService = e, this._logService = t, this._commandService = o, this._clipboardInterfaceService = s, this._docSelectionManagerService = r;
- }
- async copy(e = ur.copy) {
- var r;
- const { newSnapshotList: t = [], needCache: o = !1, snapshot: s } = (r = this._getDocumentBodyInRanges(e)) != null ? r : {};
- if (t.length === 0 || s == null)
- return !1;
- try {
- const i = this._docSelectionManagerService.getActiveTextRange(), a = !!(i != null && i.segmentId);
- this._setClipboardData(t, !a && o);
- } catch (i) {
- return this._logService.error("[DocClipboardService] copy failed", i), !1;
- }
- return !0;
- }
- async cut() {
- return this._cut();
- }
- async paste(e) {
- const t = await this._genDocDataFromClipboardItems(e);
- return this._paste(t);
- }
- async legacyPaste(e) {
- let { html: t, text: o, files: s } = e;
- const r = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC), i = (r == null ? void 0 : r.getUnitId()) || "";
- !t && !o && s.length && (t = await this._createImagePasteHtml(s));
- const a = this._genDocDataFromHtmlAndText(t, o, i);
- if (i === vs)
- if (o) {
- const c = Ce.transform.fromPlainText(o);
- return this._paste({ body: c });
- } else
- a.body.textRuns = [];
- return this._paste(a);
- }
- async _cut() {
- var i, a, c;
- const {
- segmentId: e,
- endOffset: t,
- style: o
- } = (i = this._docSelectionManagerService.getActiveTextRange()) != null ? i : {}, s = (a = this._docSelectionManagerService.getTextRanges()) != null ? a : [], r = (c = this._docSelectionManagerService.getRectRanges()) != null ? c : [];
- if (e == null && this._logService.error("[DocClipboardController] segmentId is not existed"), s.length === 0 && r.length === 0)
- return !1;
- this.copy(ur.cut);
- try {
- let A = 0;
- if (r.length > 0)
- A = zs(s, r);
- else if (t != null) {
- A = t;
- for (const d of s) {
- const { startOffset: h, endOffset: u } = d;
- h == null || u == null || u <= t && (A -= u - h);
- }
- }
- const l = [
- {
- startOffset: A,
- endOffset: A,
- style: o
- }
- ];
- return this._commandService.executeCommand(Qt.id, { segmentId: e, textRanges: l });
- } catch {
- return this._logService.error("[DocClipboardController] cut content failed"), !1;
- }
- }
- async _paste(e) {
- var l, d;
- const { body: t } = e;
- if (t == null)
- return !1;
- let o = Za(t);
- if (!((l = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC)) == null ? void 0 : l.getUnitId()))
- return !1;
- this._clipboardHooks.forEach((h) => {
- h.onBeforePaste && (o = h.onBeforePaste(o));
- }), o.customRanges = (d = o.customRanges) == null ? void 0 : d.map(Ce.customRange.copyCustomRange);
- const r = this._docSelectionManagerService.getActiveTextRange(), { segmentId: i, endOffset: a, style: c } = r || {}, A = this._docSelectionManagerService.getTextRanges();
- if (i == null && this._logService.error("[DocClipboardController] segmentId does not exist!"), a == null || A == null)
- return !1;
- try {
- let h = a;
- for (const g of A) {
- const { startOffset: f, endOffset: p } = g;
- f == null || p == null || p <= a && (h += o.dataStream.length - (p - f));
- }
- const u = [
- {
- startOffset: h,
- endOffset: h,
- style: c
- }
- ];
- return this._commandService.executeCommand(fa.id, {
- doc: {
- ...e,
- body: o
- },
- segmentId: i,
- textRanges: u
- });
- } catch {
- return this._logService.error("[DocClipboardController]", "clipboard is empty."), !1;
- }
- }
- async _setClipboardData(e, t = !0) {
- var i, a, c, A;
- const o = Cd(), s = (e.length > 1 ? e.map((l) => {
- var d;
- return ((d = l.body) == null ? void 0 : d.dataStream) || "";
- }).join(`
- `) : ((i = e[0].body) == null ? void 0 : i.dataStream) || "").replaceAll(U.TABLE_START, "").replaceAll(U.TABLE_END, "").replaceAll(U.TABLE_ROW_START, "").replaceAll(U.TABLE_ROW_END, "").replaceAll(U.TABLE_CELL_START, "").replaceAll(U.TABLE_CELL_END, "").replaceAll(`\r
- `, " ");
- let r = this._umdToHtml.convert(e);
- if (e.length === 1 && t) {
- r = r.replace(/(<[a-z]+)/, (h, u) => `${u} data-copy-id="${o}"`);
- const l = e[0], d = { body: l.body };
- if ((c = (a = l.body) == null ? void 0 : a.customBlocks) != null && c.length) {
- d.drawings = {};
- for (const h of l.body.customBlocks) {
- const { blockId: u } = h, g = (A = l.drawings) == null ? void 0 : A[u];
- if (g) {
- const f = X.generateRandomId(6);
- h.blockId = f, d.drawings[f] = {
- ...X.deepClone(g),
- drawingId: f
- };
- }
- }
- }
- No.set(o, d);
- }
- return this._clipboardInterfaceService.write(s, r);
- }
- addClipboardHook(e) {
- return this._clipboardHooks.push(e), Zn(() => {
- const t = this._clipboardHooks.indexOf(e);
- t > -1 && this._clipboardHooks.splice(t, 1);
- });
- }
- _getDocumentBodyInRanges(e) {
- var A;
- const t = this._univerInstanceService.getCurrentUniverDocInstance(), o = this._docSelectionManagerService.getDocRanges(), s = [];
- let r = !0;
- if (t == null || o.length === 0)
- return;
- const i = o[0].segmentId, a = (A = t == null ? void 0 : t.getSelfOrHeaderFooterModel(i)) == null ? void 0 : A.getBody(), c = t.getSnapshot();
- if (a != null) {
- for (const l of o) {
- const { startOffset: d, endOffset: h, collapsed: u, rangeType: g } = l;
- if (u || d == null || h == null)
- continue;
- if (g === Ge.RECT) {
- r = !1;
- const { spanEntireRow: m } = l;
- let E;
- E = $r(a, d, h), s.push(E);
- continue;
- }
- const f = { startOffset: d, endOffset: h, collapsed: u }, p = t.getSelfOrHeaderFooterModel(i).sliceBody(f.startOffset, f.endOffset, e);
- p != null && s.push(p);
- }
- return {
- newSnapshotList: s.map((l) => ({ ...c, body: l })),
- needCache: r,
- snapshot: c
- };
- }
- }
- async _genDocDataFromClipboardItems(e) {
- try {
- let t = "", o = "";
- const s = [];
- for (const r of e)
- for (const i of r.types)
- switch (i) {
- case Qi: {
- o = await r.getType(i).then((a) => a && a.text());
- break;
- }
- case Ni: {
- t = await r.getType(i).then((a) => a && a.text());
- break;
- }
- case wi:
- case Di:
- case Pi:
- case _i: {
- const a = await r.getType(i), c = new File([a], `pasted_image.${i.split("/")[1]}`, { type: i });
- s.push(c);
- break;
- }
- }
- return !t && !o && s.length && (t = await this._createImagePasteHtml(s)), this._genDocDataFromHtmlAndText(t, o);
- } catch (t) {
- return Promise.reject(t);
- }
- }
- _genDocDataFromHtmlAndText(e, t, o) {
- if (!e) {
- if (t)
- return { body: Ce.transform.fromPlainText(t) };
- throw new Error("[DocClipboardService] html and text cannot be both empty!");
- }
- const s = vd(e);
- if (s) {
- const i = No.get(s);
- if (i)
- return i;
- }
- if (!o) {
- const i = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC);
- o = (i == null ? void 0 : i.getUnitId()) || "";
- }
- const r = this._htmlToUDM.convert(e, { unitId: o });
- return s && No.set(s, r), r;
- }
- async _createImagePasteHtml(e) {
- var a, c;
- const t = {
- id: "",
- documentStyle: {},
- body: {
- dataStream: "",
- customBlocks: []
- },
- drawings: {}
- }, o = async (A) => {
- const l = new FileReader();
- return new Promise((d) => {
- l.onloadend = function() {
- d({
- source: l.result,
- imageSourceType: xs.BASE64
- });
- }, l.readAsDataURL(A);
- });
- }, s = (A) => {
- const l = new Image(), d = 500;
- return new Promise((h) => {
- l.src = typeof A == "string" ? A : URL.createObjectURL(A), l.onload = () => {
- const u = Math.min(d, l.naturalWidth), g = l.naturalHeight / l.naturalWidth;
- h({ width: u, height: u * g });
- };
- });
- }, r = (c = (a = this._clipboardHooks.find((A) => A.onBeforePasteImage)) == null ? void 0 : a.onBeforePasteImage) != null ? c : o;
- return await Promise.all(e.map(async (A, l) => {
- var m;
- const d = await r(A);
- if (!d)
- return Promise.resolve();
- const { width: h = 100, height: u = 100 } = await s(A), g = `paste_image_id_${l}`, f = t.body, p = t.drawings;
- f.dataStream += "\b", (m = f.customBlocks) == null || m.push({ startIndex: l, blockId: g }), p[g] = {
- drawingId: g,
- unitId: "",
- subUnitId: "",
- imageSourceType: d.imageSourceType,
- title: "",
- source: d.source,
- description: "",
- layoutType: oo.INLINE,
- drawingType: Cs.DRAWING_IMAGE,
- transform: {
- width: h,
- height: u,
- angle: 0
- },
- docTransform: {
- angle: 0,
- size: { width: h, height: u },
- positionH: { relativeFrom: $n.CHARACTER, posOffset: 0 },
- positionV: { relativeFrom: ot.LINE, posOffset: 0 }
- }
- };
- })), this._umdToHtml.convert([t]);
- }
- };
- ns = wd([
- Jt(0, Q),
- Jt(1, fs),
- Jt(2, y),
- Jt(3, Mi),
- Jt(4, z(G))
- ], ns);
- function Io(n) {
- return n.getContextValue(hn) || n.getContextValue(wn);
- }
- const Ys = 999, Fn = {
- id: Oc.id,
- name: "doc.command.copy",
- type: N.COMMAND,
- multi: !0,
- priority: Ys,
- preconditions: Io,
- handler: async (n) => n.get(Sn).copy()
- }, qs = {
- id: Tc.id,
- name: "doc.command.cut",
- type: N.COMMAND,
- multi: !0,
- priority: Ys,
- preconditions: Io,
- handler: async (n) => n.get(Sn).cut()
- }, Ks = {
- id: yc.id,
- name: "doc.command.paste",
- type: N.COMMAND,
- multi: !0,
- priority: Ys,
- preconditions: Io,
- handler: async (n) => {
- const e = n.get(Sn), o = await n.get(Mi).read();
- return o.length === 0 ? !1 : e.paste(o);
- }
- }, Co = {
- id: "doc.command.switch-mode",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function, complexity
- handler: async (n) => {
- var E, I, v, R, S;
- const e = n.get(y), t = n.get(fe), o = n.get(G), r = n.get(Q).getCurrentUniverDocInstance();
- if (r == null)
- return !1;
- const i = r.getUnitId(), a = (E = t.getRenderById(i)) == null ? void 0 : E.with(ie).getSkeleton(), c = (I = t.getRenderById(i)) == null ? void 0 : I.with(Se);
- if (a == null || c == null)
- return !1;
- const A = c == null ? void 0 : c.getSegment(), l = c == null ? void 0 : c.getSegmentPage(), d = r.getSnapshot().documentStyle.documentFlavor, h = o.getDocRanges(), u = {
- id: J.id,
- params: {
- unitId: i,
- actions: [],
- textRanges: d === ye.TRADITIONAL && A ? [] : h
- }
- }, g = k.getInstance(), f = [];
- let p;
- if (d === void 0 ? p = g.insertOp(["documentStyle", "documentFlavor"], ye.MODERN) : d === ye.MODERN ? p = g.replaceOp(["documentStyle", "documentFlavor"], d, ye.TRADITIONAL) : p = g.replaceOp(["documentStyle", "documentFlavor"], d, ye.MODERN), p)
- f.push(p);
- else
- return !1;
- if (d !== ye.MODERN) {
- const C = r.getSnapshot(), { drawings: T = {}, body: O } = C, P = (v = O == null ? void 0 : O.customBlocks) != null ? v : [];
- for (const b in T) {
- const B = T[b], M = P.find((ae) => ae.blockId === b);
- if (M == null)
- continue;
- const H = B.docTransform.positionV, { relativeFrom: F, posOffset: D } = H;
- if (F === ot.PARAGRAPH)
- continue;
- const { startIndex: te } = M, q = a.findNodeByCharIndex(te, A, l), V = (R = q == null ? void 0 : q.parent) == null ? void 0 : R.parent, Y = V == null ? void 0 : V.parent, oe = Y == null ? void 0 : Y.lines.find((ae) => ae.paragraphIndex === (V == null ? void 0 : V.paragraphIndex) && ae.paragraphStart), ce = (S = Y == null ? void 0 : Y.parent) == null ? void 0 : S.parent;
- if (q == null || V == null || oe == null || Y == null || ce == null)
- continue;
- let he = 0;
- F === ot.LINE ? he -= V.top : F === ot.PAGE && (he += ce.marginTop), he += oe.top;
- const Ae = {
- ...H,
- relativeFrom: ot.PARAGRAPH,
- posOffset: (D != null ? D : 0) - he
- }, ne = g.replaceOp(["drawings", b, "docTransform", "positionV"], H, Ae);
- ne && f.push(ne);
- }
- }
- return u.params.actions = f.reduce((C, T) => k.compose(C, T), null), !!e.syncExecuteCommand(u.id, u.params);
- }
- }, Xs = {
- id: "doc.table.delete-rows",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n) => {
- const e = n.get(G), t = n.get(Q), o = n.get(y), s = e.getRectRanges(), r = e.getActiveTextRange(), i = En(r, s);
- if (i == null)
- return !1;
- const { segmentId: a } = i, c = t.getCurrentUniverDocInstance(), A = c == null ? void 0 : c.getSelfOrHeaderFooterModel(a).getBody();
- if (c == null || A == null)
- return !1;
- const l = ke(n, c.getUnitId());
- if (l == null)
- return !1;
- const d = l.getViewModel(), h = c == null ? void 0 : c.getUnitId(), u = new me(), g = k.getInstance(), f = ha(i, d);
- if (f == null)
- return !1;
- const { offset: p, rowIndexes: m, len: E, tableId: I, cursor: v, selectWholeTable: R } = f;
- if (R)
- return o.executeCommand(In.id);
- const S = [], C = [{
- startOffset: v,
- endOffset: v,
- collapsed: !0
- }], T = {
- id: J.id,
- params: {
- unitId: h,
- actions: [],
- textRanges: C
- }
- };
- p > 0 && u.push({
- t: W.RETAIN,
- len: p
- }), u.push({
- t: W.DELETE,
- len: E
- });
- const O = le(c, a);
- S.push(g.editOp(u.serialize(), O));
- for (const b of m.reverse()) {
- const B = g.removeOp(["tableSource", I, "tableRows", b]);
- S.push(B);
- }
- return T.params.actions = S.reduce((b, B) => k.compose(b, B), null), !!o.syncExecuteCommand(T.id, T.params);
- }
- }, Js = {
- id: "doc.table.delete-columns",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n) => {
- const e = n.get(G), t = n.get(Q), o = n.get(y), s = e.getRectRanges(), r = e.getActiveTextRange(), i = En(r, s);
- if (i == null)
- return !1;
- const { segmentId: a } = i, c = t.getCurrentUniverDocInstance(), A = c == null ? void 0 : c.getSelfOrHeaderFooterModel(a).getBody();
- if (c == null || A == null)
- return !1;
- const l = ke(n, c.getUnitId());
- if (l == null)
- return !1;
- const d = l.getViewModel(), h = c == null ? void 0 : c.getUnitId(), u = new me(), g = k.getInstance(), f = Ad(i, d);
- if (f == null)
- return !1;
- const { offsets: p, columnIndexes: m, tableId: E, cursor: I, rowCount: v, selectWholeTable: R } = f;
- if (R)
- return o.executeCommand(In.id);
- const S = [], C = [{
- startOffset: I,
- endOffset: I,
- collapsed: !0
- }], T = {
- id: J.id,
- params: {
- unitId: h,
- actions: [],
- textRanges: C
- }
- };
- for (const b of p) {
- const { retain: B, delete: M } = b;
- B > 0 && u.push({
- t: W.RETAIN,
- len: B
- }), u.push({
- t: W.DELETE,
- len: M
- });
- }
- const O = le(c, a);
- S.push(g.editOp(u.serialize(), O)), m.reverse();
- for (let b = 0; b < v; b++)
- for (const B of m) {
- const M = g.removeOp(["tableSource", E, "tableRows", b, "tableCells", B]);
- S.push(M);
- }
- for (const b of m) {
- const B = g.removeOp(["tableSource", E, "tableColumns", b]);
- S.push(B);
- }
- return T.params.actions = S.reduce((b, B) => k.compose(b, B), null), !!o.syncExecuteCommand(T.id, T.params);
- }
- }, In = {
- id: "doc.table.delete-table",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n) => {
- const e = n.get(G), t = n.get(Q), o = n.get(y), s = e.getRectRanges(), r = e.getActiveTextRange(), i = En(r, s);
- if (i == null)
- return !1;
- const { segmentId: a } = i, c = t.getCurrentUniverDocInstance(), A = c == null ? void 0 : c.getSelfOrHeaderFooterModel(a).getBody();
- if (c == null || A == null)
- return !1;
- const l = ke(n, c.getUnitId());
- if (l == null)
- return !1;
- const d = l.getViewModel(), h = c == null ? void 0 : c.getUnitId(), u = new me(), g = k.getInstance(), f = ga(i, d);
- if (f == null)
- return !1;
- const { offset: p, len: m, tableId: E, cursor: I } = f, v = [], R = [{
- startOffset: I,
- endOffset: I,
- collapsed: !0
- }], S = {
- id: J.id,
- params: {
- unitId: h,
- actions: [],
- textRanges: R
- }
- };
- p > 0 && u.push({
- t: W.RETAIN,
- len: p
- }), u.push({
- t: W.DELETE,
- len: m
- });
- const C = le(c, a);
- v.push(g.editOp(u.serialize(), C));
- const T = g.removeOp(["tableSource", E]);
- return v.push(T), S.params.actions = v.reduce((P, b) => k.compose(P, b), null), !!o.syncExecuteCommand(S.id, S.params);
- }
- }, Zs = "doc.command.table-insert-row", $s = "doc.command.table-insert-column", Nd = "doc.command.table-insert-row-above", Qd = "doc.command.table-insert-row-bellow", Ud = "doc.command.table-insert-column-left", Ld = "doc.command.table-insert-column-right", er = {
- id: Nd,
- type: N.COMMAND,
- handler: async (n) => n.get(y).executeCommand(Zs, { position: Eo.ABOVE })
- }, tr = {
- id: Qd,
- type: N.COMMAND,
- handler: async (n) => n.get(y).executeCommand(Zs, { position: Eo.BELLOW })
- }, nr = {
- id: Ud,
- type: N.COMMAND,
- handler: async (n) => n.get(y).executeCommand($s, { position: Ls.LEFT })
- }, or = {
- id: Ld,
- type: N.COMMAND,
- handler: async (n) => n.get(y).executeCommand($s, { position: Ls.RIGHT })
- }, Ia = {
- id: Zs,
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n, e) => {
- const { position: t } = e, o = n.get(G), s = n.get(Q), r = n.get(y), i = o.getRectRanges(), a = o.getActiveTextRange(), c = En(a, i);
- if (c == null)
- return !1;
- const { segmentId: A } = c, l = s.getCurrentUnitForType(_.UNIVER_DOC), d = l == null ? void 0 : l.getSelfOrHeaderFooterModel(A).getBody();
- if (l == null || d == null)
- return !1;
- const h = ke(n, l.getUnitId());
- if (h == null)
- return !1;
- const u = h.getViewModel(), g = l == null ? void 0 : l.getUnitId(), f = new me(), p = k.getInstance(), m = id(c, t, u);
- if (m == null)
- return !1;
- const { offset: E, colCount: I, tableId: v, insertRowIndex: R } = m, S = [], C = E + 2, T = [{
- startOffset: C,
- endOffset: C,
- collapsed: !0
- }], O = {
- id: J.id,
- params: {
- unitId: g,
- actions: [],
- textRanges: T
- }
- };
- E > 0 && f.push({
- t: W.RETAIN,
- len: E
- });
- const P = sd(I);
- f.push({
- t: W.INSERT,
- body: P,
- len: P.dataStream.length
- });
- const b = le(l, A);
- S.push(p.editOp(f.serialize(), b));
- const B = Hs(I), M = p.insertOp(["tableSource", v, "tableRows", R], B);
- return S.push(M), O.params.actions = S.reduce((F, D) => k.compose(F, D), null), !!r.syncExecuteCommand(O.id, O.params);
- }
- }, Fd = {
- id: $s,
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n, e) => {
- var ce, he, Ae;
- const { position: t } = e, o = n.get(G), s = n.get(Q), r = n.get(y), i = o.getRectRanges(), a = o.getActiveTextRange(), c = En(a, i);
- if (c == null)
- return !1;
- const { segmentId: A } = c, l = s.getCurrentUniverDocInstance(), d = l == null ? void 0 : l.getSelfOrHeaderFooterModel(A).getBody();
- if (l == null || d == null)
- return !1;
- const h = ke(n, l.getUnitId());
- if (h == null)
- return !1;
- const u = h.getViewModel(), g = l == null ? void 0 : l.getUnitId(), f = new me(), p = k.getInstance(), m = ad(c, t, u);
- if (m == null)
- return !1;
- const { offsets: E, columnIndex: I, tableId: v, rowCount: R } = m, S = [], C = E[0] + 1, T = [{
- startOffset: C,
- endOffset: C,
- collapsed: !0
- }], O = {
- id: J.id,
- params: {
- unitId: g,
- actions: [],
- textRanges: T
- }
- };
- for (const ne of E) {
- f.push({
- t: W.RETAIN,
- len: ne
- });
- const ae = rd();
- f.push({
- t: W.INSERT,
- body: ae,
- len: ae.dataStream.length
- });
- }
- const P = le(l, A);
- S.push(p.editOp(f.serialize(), P));
- for (let ne = 0; ne < R; ne++) {
- const ae = Fs(), Te = p.insertOp(["tableSource", v, "tableRows", ne, "tableCells", I], ae);
- S.push(Te);
- }
- const b = l.getSnapshot(), B = b.documentStyle, { marginLeft: M = 0, marginRight: H = 0 } = B, F = ((he = (ce = B.pageSize) == null ? void 0 : ce.width) != null ? he : 800) - M - H, D = (Ae = b == null ? void 0 : b.tableSource) == null ? void 0 : Ae[v].tableColumns, { newColWidth: te, widths: q } = cd(F, D, I);
- for (let ne = 0; ne < q.length; ne++) {
- const ae = p.replaceOp(["tableSource", v, "tableColumns", ne, "size", "width", "v"], D[ne].size.width.v, q[ne]);
- S.push(ae);
- }
- const V = ks(te), Y = p.insertOp(["tableSource", v, "tableColumns", I], V);
- return S.push(Y), O.params.actions = S.reduce((ne, ae) => k.compose(ne, ae), null), !!r.syncExecuteCommand(O.id, O.params);
- }
- }, Ca = "COMPONENT_DOC_CREATE_TABLE_CONFIRM";
- function va(n, e) {
- const t = [];
- for (let o = 0, s = n.length; o < s; o++)
- n[o] === U.PARAGRAPH && t.push({
- startIndex: o
- });
- if (e)
- for (const o of t)
- e.bullet && (o.bullet = X.deepClone(e.bullet)), e.paragraphStyle && (o.paragraphStyle = X.deepClone(e.paragraphStyle));
- return t;
- }
- const Ra = {
- id: "doc.command.break-line",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n) => {
- var S, C, T;
- const e = n.get(G), t = n.get(Q), o = n.get(y), s = n.get(Je), r = e.getActiveTextRange(), i = e.getRectRanges();
- if (r == null)
- return !1;
- if (i && i.length) {
- const { startOffset: O } = r;
- return e.replaceDocRanges([{
- startOffset: O,
- endOffset: O
- }]), !0;
- }
- const { segmentId: a } = r, c = t.getCurrentUnitForType(_.UNIVER_DOC), A = c == null ? void 0 : c.getSelfOrHeaderFooterModel(a != null ? a : "").getBody();
- if (c == null || A == null)
- return !1;
- const l = c.getUnitId(), { startOffset: d, endOffset: h } = r, g = ((S = A.paragraphs) != null ? S : []).find((O) => O.startIndex >= d);
- if (!g)
- return !1;
- const f = g.startIndex, p = s.getDefaultStyle(), m = s.getStyleCache(), E = co((C = A.textRuns) != null ? C : [], h, p, m), I = {
- dataStream: U.PARAGRAPH,
- paragraphs: va(U.PARAGRAPH, g),
- textRuns: [{
- st: 0,
- ed: 1,
- ts: {
- ...E.ts
- }
- }]
- }, v = {
- startOffset: d,
- endOffset: h,
- collapsed: d === h
- }, R = await o.executeCommand(Vs.id, {
- unitId: l,
- body: I,
- range: v,
- segmentId: a
- });
- if (((T = g.bullet) == null ? void 0 : T.listType) === Oe.CHECK_LIST_CHECKED) {
- const O = {
- index: f + 1 - (h - d),
- segmentId: a,
- textRanges: [{
- startOffset: d + 1,
- endOffset: d + 1
- }]
- };
- return !!await o.executeCommand(Ns.id, O) && R;
- }
- return R;
- }
- }, Hd = "doc.command.create-table", ba = {
- id: Hd,
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n, e) => {
- var Ae, ne, ae, Te, je, ut;
- const { rowCount: t, colCount: o } = e, s = n.get(G), r = n.get(Q), i = n.get(y), a = n.get(Je), c = s.getActiveTextRange();
- if (c == null)
- return !1;
- const { segmentId: A, segmentPage: l } = c, d = r.getCurrentUniverDocInstance(), h = d == null ? void 0 : d.getSelfOrHeaderFooterModel(A).getBody();
- if (d == null || h == null)
- return !1;
- const u = d.getUnitId(), g = ke(n, u), f = g == null ? void 0 : g.getSkeleton();
- if (f == null)
- return !1;
- const { startOffset: p } = c, E = ((Ae = h.paragraphs) != null ? Ae : []).find((we) => we.startIndex >= p), I = f.findNodeByCharIndex(p, A, l);
- if (I == null)
- return !1;
- const v = new me(), R = k.getInstance(), S = [], C = p + 4, T = [{
- startOffset: C,
- endOffset: C,
- collapsed: !0
- }], O = {
- id: J.id,
- params: {
- unitId: u,
- actions: [],
- textRanges: T
- }
- };
- p > 0 && v.push({
- t: W.RETAIN,
- len: p
- }), v.push({
- t: W.INSERT,
- body: {
- dataStream: U.PARAGRAPH,
- paragraphs: va(U.PARAGRAPH, E)
- },
- len: 1
- });
- const P = a.getDefaultStyle(), b = a.getStyleCache(), B = co(
- (ne = h.textRuns) != null ? ne : [],
- p,
- P,
- b
- ), { dataStream: M, paragraphs: H, sectionBreaks: F } = od(t, o), D = (ut = (je = (Te = (ae = I.parent) == null ? void 0 : ae.parent) == null ? void 0 : Te.parent) == null ? void 0 : je.parent) == null ? void 0 : ut.parent;
- if (D == null)
- return !1;
- const { pageWidth: te, marginLeft: q, marginRight: V } = D, Y = ua(t, o, te - q - V);
- v.push({
- t: W.INSERT,
- body: {
- dataStream: M,
- paragraphs: H,
- sectionBreaks: F,
- textRuns: [{
- ...B,
- st: 0,
- ed: M.length
- }],
- tables: [
- {
- startIndex: 0,
- endIndex: M.length,
- tableId: Y.tableId
- }
- ]
- },
- len: M.length
- });
- const oe = le(d, A);
- S.push(R.editOp(v.serialize(), oe));
- const ce = R.insertOp(["tableSource", Y.tableId], Y);
- return S.push(ce), O.params.actions = S.reduce((we, Yt) => k.compose(we, Yt), null), !!i.syncExecuteCommand(O.id, O.params);
- }
- }, Uo = "doc.component.create-table-confirm", sr = {
- id: "doc.operation.create-table",
- type: N.COMMAND,
- handler: async (n) => {
- const e = n.get(Ze), t = n.get(Bc), o = n.get(y), s = {
- rowCount: 3,
- colCount: 5
- }, r = (i, a) => {
- s.rowCount = i, s.colCount = a;
- };
- return await t.open({
- id: Uo,
- children: {
- label: {
- name: Ca,
- props: {
- handleRowColChange: r,
- tableCreateParams: s
- }
- }
- },
- width: 400,
- title: { title: e.t("toolbar.table.insert") },
- onConfirm: () => {
- o.executeCommand(ba.id, s), t.close(Uo);
- },
- onClose: () => {
- t.close(Uo);
- }
- }), !0;
- }
- }, qe = {
- id: "doc-paragraph-setting.command",
- type: N.COMMAND,
- handler: async (n, e) => {
- var m, E;
- const t = n.get(G), o = n.get(Q), s = n.get(y), r = o.getCurrentUnitForType(_.UNIVER_DOC), i = t.getDocRanges();
- if (!r || i.length === 0 || !e)
- return !1;
- const a = i[0].segmentId, c = r.getUnitId(), A = (E = (m = r.getSelfOrHeaderFooterModel(a).getBody()) == null ? void 0 : m.paragraphs) != null ? E : [], l = mn(i, A), d = {
- id: J.id,
- params: {
- unitId: c,
- actions: [],
- textRanges: i
- }
- }, h = new St();
- h.reset();
- const u = new me(), g = k.getInstance();
- for (const I of l) {
- const { startIndex: v } = I;
- u.push({
- t: W.RETAIN,
- len: v - h.cursor
- });
- const R = {
- ...I.paragraphStyle,
- ...e.paragraph
- };
- u.push({
- t: W.RETAIN,
- len: 1,
- body: {
- dataStream: "",
- paragraphs: [
- {
- ...I,
- paragraphStyle: R,
- startIndex: 0
- }
- ]
- },
- coverType: no.REPLACE
- }), h.moveCursorTo(v + 1);
- }
- const f = le(r, a);
- return d.params.actions = g.editOp(u.serialize(), f), !!s.syncExecuteCommand(d.id, d.params);
- }
- }, kd = () => {
- const n = $(G), e = $(Lt), t = Fe(() => n.getDocRanges(), []);
- return Re(() => {
- t.length || e.closePanel();
- }, [t]), t;
- }, Vd = () => {
- var i, a;
- const e = $(Q).getCurrentUnitForType(_.UNIVER_DOC), t = kd();
- if (!e || t.length === 0)
- return [];
- const o = t[0].segmentId, s = (a = (i = e.getSelfOrHeaderFooterModel(o).getBody()) == null ? void 0 : i.paragraphs) != null ? a : [];
- return mn(t, s);
- }, jd = (n, e) => {
- const t = $(y), [o, s] = ve(() => {
- var a, c;
- const i = n[0];
- return i ? String((c = (a = i.paragraphStyle) == null ? void 0 : a.horizontalAlign) != null ? c : e) : e;
- });
- return [o, (i) => (s(i), t.executeCommand(qe.id, {
- paragraph: { horizontalAlign: Number(i) }
- }))];
- }, Wd = (n) => {
- const e = $(y), [t, o] = ve(() => {
- var i;
- const r = n[0];
- return r ? ze((i = r.paragraphStyle) == null ? void 0 : i.indentStart, 0) : 0;
- });
- return [t, (r) => (o(r), e.executeCommand(qe.id, {
- paragraph: { indentStart: { v: r } }
- }))];
- }, zd = (n) => {
- const e = $(y), [t, o] = ve(() => {
- var i;
- const r = n[0];
- return r ? ze((i = r.paragraphStyle) == null ? void 0 : i.indentEnd, 0) : 0;
- });
- return [t, (r) => (o(r), e.executeCommand(qe.id, {
- paragraph: { indentEnd: { v: r } }
- }))];
- }, Gd = (n) => {
- const e = $(y), [t, o] = ve(() => {
- var i;
- const r = n[0];
- return r ? ze((i = r.paragraphStyle) == null ? void 0 : i.indentFirstLine, 0) : 0;
- });
- return [t, (r) => (o(r), e.executeCommand(qe.id, {
- paragraph: { indentFirstLine: { v: r } }
- }))];
- }, Yd = (n) => {
- const e = $(y), [t, o] = ve(() => {
- var i;
- const r = n[0];
- return r ? ze((i = r.paragraphStyle) == null ? void 0 : i.hanging, 0) : 0;
- });
- return [t, (r) => (o(r), e.executeCommand(qe.id, {
- paragraph: { hanging: { v: r } }
- }))];
- }, qd = (n) => {
- const e = $(y), [t, o] = ve(() => {
- var i;
- const r = n[0];
- return r ? ze((i = r.paragraphStyle) == null ? void 0 : i.spaceAbove, 0) : 0;
- });
- return [t, (r) => (o(r), e.executeCommand(qe.id, {
- paragraph: { spaceAbove: { v: r } }
- }))];
- }, Kd = (n) => {
- const e = $(y), [t, o] = ve(() => {
- var i;
- const r = n[0];
- return r ? ze((i = r.paragraphStyle) == null ? void 0 : i.spaceBelow, 0) : 0;
- });
- return [t, (r) => (o(r), e.executeCommand(qe.id, {
- paragraph: { spaceBelow: { v: r } }
- }))];
- }, Xd = (n) => {
- const e = $(y), t = $(fe), o = $(Q), s = Fe(() => {
- var g;
- const u = o.getCurrentUnitForType(_.UNIVER_DOC);
- if (u)
- return (g = t.getRenderById(u == null ? void 0 : u.getUnitId())) == null ? void 0 : g.with(ie).getSkeleton();
- }, []), r = Fe(() => new Le({}), []), [i, a] = ve(() => {
- var g, f;
- const u = n[0];
- return u && (f = (g = u.paragraphStyle) == null ? void 0 : g.lineSpacing) != null ? f : 1;
- }), c = cn(i), [A, l] = ve(() => {
- var g, f;
- const u = n[0];
- return u ? (f = (g = u.paragraphStyle) == null ? void 0 : g.spacingRule) != null ? f : Bt.AUTO : Bt.AUTO;
- }), d = async (u) => {
- a(u), r.next({ lineSpacing: u, spacingRule: A });
- }, h = async (u) => {
- if (u !== A) {
- let g = c.current;
- if (u === Bt.AT_LEAST) {
- const f = s == null ? void 0 : s.findNodeByCharIndex(n[0].startIndex), p = f == null ? void 0 : f.parent, m = p == null ? void 0 : p.parent;
- (m == null ? void 0 : m.contentHeight) !== void 0 && (g = Math.max(m.contentHeight, g));
- } else
- g > 5 && (g = 2);
- c.current = i, d(g), l(u), r.next({ spacingRule: u });
- }
- };
- return Re(() => {
- const u = r.pipe(
- zo((g) => !!Object.keys(g).length),
- Gc(16),
- zo((g) => !!g.length),
- Yc((g) => g.reduce((f, p) => (Object.keys(p).forEach((m) => {
- f[m] = p[m];
- }), f), {}))
- ).subscribe((g) => e.executeCommand(qe.id, {
- paragraph: { ...g }
- }));
- return () => u.unsubscribe();
- }, []), {
- lineSpacing: [i, d],
- spacingRule: [A, h]
- };
- }, Jd = "univer-paragraph-setting-icon-list", Zd = "univer-paragraph-setting-icon-list-item", $d = "univer-paragraph-setting-icon-list-active", eu = "univer-paragraph-setting-title", tu = "univer-paragraph-setting-label", nu = "univer-paragraph-setting-mt-base", ou = "univer-paragraph-setting-flex-col", su = "univer-paragraph-setting-space-line", re = {
- paragraphSettingIconList: Jd,
- paragraphSettingIconListItem: Zd,
- paragraphSettingIconListActive: $d,
- paragraphSettingTitle: eu,
- paragraphSettingLabel: tu,
- paragraphSettingMtBase: nu,
- paragraphSettingFlexCol: ou,
- paragraphSettingSpaceLine: su
- }, ht = (n) => {
- const { value: e, onChange: t, className: o = "", min: s = 0, max: r = 100, step: i = 1 } = n, a = Hc.useRef(null);
- return /* @__PURE__ */ w.jsx(
- An,
- {
- step: i,
- ref: a,
- min: s,
- max: r,
- value: e,
- onChange: (c) => {
- t(c != null ? c : 0).finally(() => {
- setTimeout(() => {
- var A;
- (A = a.current) == null || A.focus();
- }, 30);
- });
- },
- className: o
- }
- );
- };
- function ru() {
- const n = $(Ze), e = Fe(
- () => [
- { label: n.t("toolbar.alignLeft"), value: String(_e.LEFT), icon: /* @__PURE__ */ w.jsx(Ji, {}) },
- { label: n.t("toolbar.alignCenter"), value: String(_e.CENTER), icon: /* @__PURE__ */ w.jsx(Xi, {}) },
- { label: n.t("toolbar.alignRight"), value: String(_e.RIGHT), icon: /* @__PURE__ */ w.jsx(Zi, {}) },
- { label: n.t("toolbar.alignJustify"), value: String(_e.JUSTIFIED), icon: /* @__PURE__ */ w.jsx(Ki, {}) }
- ],
- []
- ), t = Vd(), [o, s] = jd(t, e[0].value), [r, i] = Wd(t), [a, c] = zd(t), [A, l] = Gd(t), [d, h] = Yd(t), [u, g] = qd(t), [f, p] = Kd(t), { lineSpacing: [m, E], spacingRule: [I, v] } = Xd(t), R = Fe(() => I === Bt.AUTO ? { min: 1, max: 5, step: m < 2 ? 0.5 : 1 } : { min: 1, max: 100 }, [I, m]);
- return /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSetting, children: [
- /* @__PURE__ */ w.jsx("div", { className: re.paragraphSettingTitle, children: n.t("doc.paragraphSetting.alignment") }),
- /* @__PURE__ */ w.jsx(
- "div",
- {
- className: `
- ${re.paragraphSettingIconList}
- ${re.paragraphSettingMtBase}
- `,
- children: e.map((S) => /* @__PURE__ */ w.jsx(Xc, { title: S.label, placement: "bottom", children: /* @__PURE__ */ w.jsx(
- "span",
- {
- className: Un(
- re.paragraphSettingIconListItem,
- { [re.paragraphSettingIconListActive]: o === S.value }
- ),
- onClick: () => s(S.value),
- children: S.icon
- }
- ) }, S.value))
- }
- ),
- /* @__PURE__ */ w.jsx("div", { className: re.paragraphSettingTitle, children: n.t("doc.paragraphSetting.indentation") }),
- /* @__PURE__ */ w.jsxs("div", { children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingFlexCol, children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingLabel, children: [
- n.t("doc.paragraphSetting.left"),
- "(px)"
- ] }),
- /* @__PURE__ */ w.jsx(ht, { className: re.paragraphSettingMtBase, value: r, onChange: (S) => i(S != null ? S : 0) })
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingFlexCol, children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingLabel, children: [
- n.t("doc.paragraphSetting.right"),
- "(px)"
- ] }),
- /* @__PURE__ */ w.jsx(ht, { className: re.paragraphSettingMtBase, value: a, onChange: (S) => c(S != null ? S : 0) })
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingFlexCol, children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingLabel, children: [
- n.t("doc.paragraphSetting.firstLine"),
- "(px)"
- ] }),
- /* @__PURE__ */ w.jsx(ht, { className: re.paragraphSettingMtBase, value: A, onChange: (S) => l(S != null ? S : 0) })
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingFlexCol, children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingLabel, children: [
- n.t("doc.paragraphSetting.hanging"),
- "(px)"
- ] }),
- /* @__PURE__ */ w.jsx(ht, { className: re.paragraphSettingMtBase, value: d, onChange: (S) => h(S != null ? S : 0) })
- ] })
- ] }),
- /* @__PURE__ */ w.jsx("div", { className: re.paragraphSettingTitle, children: n.t("doc.paragraphSetting.spacing") }),
- /* @__PURE__ */ w.jsxs("div", { children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingFlexCol, children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingLabel, children: [
- n.t("doc.paragraphSetting.before"),
- "(px)"
- ] }),
- /* @__PURE__ */ w.jsx(ht, { className: re.paragraphSettingMtBase, value: u, onChange: (S) => g(S != null ? S : 0) })
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingFlexCol, children: [
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingLabel, children: [
- n.t("doc.paragraphSetting.after"),
- "(px)"
- ] }),
- /* @__PURE__ */ w.jsx(ht, { className: re.paragraphSettingMtBase, value: f, onChange: (S) => p(S != null ? S : 0) })
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: re.paragraphSettingFlexCol, children: [
- /* @__PURE__ */ w.jsx("div", { className: re.paragraphSettingLabel, children: n.t("doc.paragraphSetting.lineSpace") }),
- /* @__PURE__ */ w.jsxs(
- "div",
- {
- className: `
- ${re.paragraphSettingMtBase}
- ${re.paragraphSettingSpaceLine}
- `,
- style: { width: 162 },
- children: [
- /* @__PURE__ */ w.jsx(
- Jc,
- {
- value: `${I}`,
- options: [
- { label: n.t("doc.paragraphSetting.multiSpace"), value: `${Bt.AUTO}` },
- { label: n.t("doc.paragraphSetting.fixedValue"), value: `${Bt.AT_LEAST}` }
- ],
- onChange: (S) => v(Number(S))
- }
- ),
- /* @__PURE__ */ w.jsx(
- ht,
- {
- ...R,
- value: m,
- onChange: (S) => E(S != null ? S : 0)
- }
- )
- ]
- }
- )
- ] })
- ] })
- ] });
- }
- const iu = (n, e) => e.length === n.length && n.some((t) => e.some((o) => o.startOffset === t.startOffset && o.endOffset === t.endOffset));
- function au() {
- const n = $(y), e = $(Ze), t = Nn(e.currentLocale$), [o, s] = ve(""), r = Fe(() => fi(() => s(pt(4)), 300), []), i = cn([]);
- return Re(() => {
- const a = n.onCommandExecuted((c) => {
- if (De.id === c.id) {
- const A = c.params.ranges;
- iu(A, i.current) || s(pt(4)), i.current = A;
- }
- J.id === c.id && c.params.trigger !== qe.id && r();
- });
- return () => a.dispose();
- }, [r]), Re(() => {
- s(pt(4));
- }, [t]), Re(() => () => r.cancel(), [r]), /* @__PURE__ */ w.jsx(ru, {}, o);
- }
- var cu = Object.defineProperty, Au = Object.getOwnPropertyDescriptor, lu = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Au(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && cu(e, t, s), s;
- }, Lo = (n, e) => (t, o) => e(t, o, n);
- const ei = "doc_ui_paragraph-setting-panel";
- let Lt = class extends ue {
- constructor(e, t, o) {
- super();
- x(this, "_id");
- this._commandService = e, this._componentManager = t, this._sidebarService = o, this._init();
- }
- _init() {
- this.disposeWithMe(this._componentManager.register(ei, au));
- }
- openPanel() {
- const e = {
- header: { title: "doc.slider.paragraphSetting" },
- id: this._id,
- children: {
- label: ei
- },
- width: 300
- };
- this._sidebarService.open(e);
- }
- closePanel() {
- this._sidebarService.close(this._id);
- }
- };
- Lt = lu([
- Lo(0, y),
- Lo(1, z(io)),
- Lo(2, z(Bi))
- ], Lt);
- const rr = {
- id: "sidebar.operation.doc-paragraph-setting-panel",
- type: N.OPERATION,
- handler: (n) => (n.get(Lt).openPanel(), !0)
- }, ir = (n) => {
- const e = n.get(G);
- return new pe((t) => {
- const o = e.textSelection$.subscribe(() => {
- e.getDocRanges().some((i) => i.collapsed === !1 || i.rangeType === Ge.RECT) ? t.next(!1) : t.next(!0);
- });
- return () => o.unsubscribe();
- });
- };
- function du(n) {
- if (n.length < 2)
- return !0;
- const e = n.map((t) => t.tableId);
- return e.every((t) => t === e[0]);
- }
- function ti(n, e, t) {
- var r;
- const o = e.getRectRanges(), s = e.getActiveTextRange();
- if (o && o.length && du(o) && s == null) {
- n.next(!1);
- return;
- }
- if (s && (o == null || o.length === 0)) {
- const { segmentId: i, startOffset: a, endOffset: c } = s, A = t.getCurrentUniverDocInstance(), l = (r = A == null ? void 0 : A.getSelfOrHeaderFooterModel(i).getBody()) == null ? void 0 : r.tables;
- if (l && l.length && l.some((d) => {
- const { startIndex: h, endIndex: u } = d;
- return a > h && a < u || c > h && c < u;
- })) {
- n.next(!1);
- return;
- }
- }
- n.next(!0);
- }
- const tt = (n) => {
- const e = n.get(G), t = n.get(Q);
- return new pe((o) => {
- const s = e.textSelection$.subscribe(() => {
- ti(o, e, t);
- });
- return ti(o, e, t), () => s.unsubscribe();
- });
- }, uu = (n) => ({
- id: Fn.name,
- commandId: Fn.id,
- type: Z.BUTTON,
- icon: "Copy",
- title: "rightClick.copy",
- disabled$: ir(n),
- hidden$: ee(n, _.UNIVER_DOC)
- }), hu = (n) => ({
- id: rr.id,
- type: Z.BUTTON,
- icon: "MenuSingle24",
- title: "doc.menu.paragraphSetting",
- hidden$: ee(n, _.UNIVER_DOC)
- }), gu = (n) => ({
- id: qs.id,
- type: Z.BUTTON,
- icon: "Copy",
- title: "rightClick.cut",
- disabled$: ir(n),
- hidden$: ee(n, _.UNIVER_DOC)
- }), fu = (n) => ({
- id: Ks.id,
- type: Z.BUTTON,
- icon: "PasteSpecial",
- title: "rightClick.paste",
- hidden$: ee(n, _.UNIVER_DOC)
- }), pu = (n) => ({
- id: So.id,
- type: Z.BUTTON,
- icon: "PasteSpecial",
- title: "rightClick.delete",
- disabled$: ir(n),
- hidden$: ee(n, _.UNIVER_DOC)
- }), xa = "doc.menu.table-insert";
- function mu(n) {
- return {
- id: xa,
- type: Z.SUBITEMS,
- title: "table.insert",
- icon: "Insert",
- hidden$: ao(ee(n, _.UNIVER_DOC), tt(n), (e, t) => e || t)
- };
- }
- function Eu(n) {
- return {
- id: er.id,
- type: Z.BUTTON,
- title: "table.insertRowAbove",
- icon: "InsertRowAbove",
- disabled$: tt(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Su(n) {
- return {
- id: tr.id,
- type: Z.BUTTON,
- title: "table.insertRowBelow",
- icon: "InsertRowBelow",
- disabled$: tt(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Iu(n) {
- return {
- id: nr.id,
- type: Z.BUTTON,
- title: "table.insertColumnLeft",
- icon: "LeftInsertColumn",
- disabled$: tt(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Cu(n) {
- return {
- id: or.id,
- type: Z.BUTTON,
- title: "table.insertColumnRight",
- icon: "RightInsertColumn",
- disabled$: tt(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- const Oa = "doc.menu.table-delete";
- function vu(n) {
- return {
- id: Oa,
- type: Z.SUBITEMS,
- title: "table.delete",
- icon: "Reduce",
- hidden$: ao(ee(n, _.UNIVER_DOC), tt(n), (e, t) => e || t)
- };
- }
- function Ru(n) {
- return {
- id: Xs.id,
- type: Z.BUTTON,
- title: "table.deleteRows",
- icon: "DeleteRow",
- disabled$: tt(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function bu(n) {
- return {
- id: Js.id,
- type: Z.BUTTON,
- title: "table.deleteColumns",
- icon: "DeleteColumn",
- disabled$: tt(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function xu(n) {
- return {
- id: In.id,
- type: Z.BUTTON,
- title: "table.deleteTable",
- icon: "GridSingle",
- disabled$: tt(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Ou(n) {
- const e = n.get(Q), t = n.get(fe);
- return new pe((o) => {
- const s = e.focused$.subscribe((a) => {
- if (a == null || e.getUnitType(a) !== _.UNIVER_DOC)
- return o.next(!0);
- const A = t.getRenderById(a);
- if (A == null)
- return o.next(!0);
- A.with(ie).getViewModel().editAreaChange$.subscribe((d) => {
- o.next(d === ge.HEADER || d === ge.FOOTER);
- });
- }), r = t.getCurrentTypeOfRenderer(_.UNIVER_DOC);
- if (r == null)
- return o.next(!0);
- const i = r.with(ie).getViewModel();
- return o.next(i.getEditArea() !== ge.BODY), () => s.unsubscribe();
- });
- }
- function Tu(n) {
- const e = n.get(Q), t = n.get(y);
- return new pe((o) => {
- const s = t.onCommandExecuted((c) => {
- if (c.id === J.id) {
- const { unitId: A } = c.params, l = e.getUnit(A);
- if (l == null) {
- o.next(!0);
- return;
- }
- const { documentStyle: d } = l.getSnapshot();
- o.next((d == null ? void 0 : d.documentFlavor) !== ye.TRADITIONAL);
- }
- }), r = e.focused$.subscribe((c) => {
- if (c == null)
- return o.next(!0);
- const A = e.getUniverDocInstance(c), l = A == null ? void 0 : A.getSnapshot().documentStyle.documentFlavor;
- o.next(l !== ye.TRADITIONAL);
- }), i = e.getCurrentUniverDocInstance();
- if (i == null)
- return o.next(!0);
- const a = i == null ? void 0 : i.getSnapshot().documentStyle.documentFlavor;
- return o.next(a !== ye.TRADITIONAL), () => {
- s.dispose(), r.unsubscribe();
- };
- });
- }
- function yu(n) {
- const e = n.get(G), t = n.get(Q);
- return new pe((o) => {
- const s = e.textSelection$.subscribe((r) => {
- if (r == null) {
- o.next(!0);
- return;
- }
- const { textRanges: i } = r;
- if (i.length !== 1) {
- o.next(!0);
- return;
- }
- const a = i[0], { collapsed: c, startNodePosition: A, startOffset: l } = a;
- if (!c || l == null) {
- o.next(!0);
- return;
- }
- const d = t.getCurrentUniverDocInstance();
- if (d == null) {
- o.next(!0);
- return;
- }
- const h = ke(n, d.getUnitId());
- if (h == null) {
- o.next(!0);
- return;
- }
- if (h.getViewModel().getCustomRangeRaw(l)) {
- o.next(!0);
- return;
- }
- if (A != null) {
- const { path: f } = A;
- if (f.indexOf("cells") !== -1) {
- o.next(!0);
- return;
- }
- }
- o.next(!1);
- });
- return () => s.unsubscribe();
- });
- }
- function be(n) {
- const e = n.get(G);
- return new pe((t) => {
- const o = e.textSelection$.subscribe((s) => {
- if (s == null) {
- t.next(!0);
- return;
- }
- const { textRanges: r, rectRanges: i } = s;
- if (r.length === 0 && i.length === 0) {
- t.next(!0);
- return;
- }
- t.next(!1);
- });
- return () => o.unsubscribe();
- });
- }
- function Bu(n) {
- const e = n.get(y);
- return {
- id: Vt.id,
- type: Z.BUTTON,
- icon: "BoldSingle",
- title: "Set bold",
- tooltip: "toolbar.bold",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === lt.id) {
- const a = dt(n);
- if (a == null) {
- t.next(!1);
- return;
- }
- const c = (i = a.ts) == null ? void 0 : i.bl;
- t.next(c === L.TRUE);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Mu(n) {
- const e = n.get(y);
- return {
- id: jt.id,
- type: Z.BUTTON,
- icon: "ItalicSingle",
- title: "Set italic",
- tooltip: "toolbar.italic",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === lt.id) {
- const a = dt(n);
- if (a == null) {
- t.next(!1);
- return;
- }
- const c = (i = a.ts) == null ? void 0 : i.it;
- t.next(c === L.TRUE);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function _u(n) {
- const e = n.get(y);
- return {
- id: Wt.id,
- type: Z.BUTTON,
- icon: "UnderlineSingle",
- title: "Set underline",
- tooltip: "toolbar.underline",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === lt.id) {
- const a = dt(n);
- if (a == null) {
- t.next(!1);
- return;
- }
- const c = (i = a.ts) == null ? void 0 : i.ul;
- t.next((c == null ? void 0 : c.s) === L.TRUE);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Pu(n) {
- const e = n.get(y);
- return {
- id: zt.id,
- type: Z.BUTTON,
- icon: "StrikethroughSingle",
- title: "Set strike through",
- tooltip: "toolbar.strikethrough",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === lt.id) {
- const a = dt(n);
- if (a == null) {
- t.next(!1);
- return;
- }
- const c = (i = a.ts) == null ? void 0 : i.st;
- t.next((c == null ? void 0 : c.s) === L.TRUE);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Du(n) {
- const e = n.get(y);
- return {
- id: Ct.id,
- type: Z.BUTTON,
- icon: "SubscriptSingle",
- tooltip: "toolbar.subscript",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === lt.id) {
- const a = dt(n);
- if (a == null) {
- t.next(!1);
- return;
- }
- const c = (i = a.ts) == null ? void 0 : i.va;
- t.next(c === Ne.SUBSCRIPT);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function wu(n) {
- const e = n.get(y);
- return {
- id: Gt.id,
- type: Z.BUTTON,
- icon: "SuperscriptSingle",
- tooltip: "toolbar.superscript",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === lt.id) {
- const a = dt(n);
- if (a == null) {
- t.next(!1);
- return;
- }
- const c = (i = a.ts) == null ? void 0 : i.va;
- t.next(c === Ne.SUPERSCRIPT);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Nu(n) {
- const e = n.get(y);
- return {
- id: Dt.id,
- tooltip: "toolbar.font",
- type: Z.SELECTOR,
- label: oa,
- selections: Mc.map((t) => ({
- label: {
- name: sa,
- hoverable: !0
- },
- value: t.value
- })),
- // disabled$: getCurrentSheetDisabled$(accessor),
- value$: new pe((t) => {
- const o = Ci.ff, s = e.onCommandExecuted((r) => {
- var a;
- const i = r.id;
- if (i === De.id || i === Dt.id) {
- const c = dt(n);
- if (c == null) {
- t.next(o);
- return;
- }
- const A = (a = c.ts) == null ? void 0 : a.ff;
- t.next(A != null ? A : o);
- }
- });
- return t.next(o), s.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Qu(n) {
- const e = n.get(y);
- return {
- id: Pt.id,
- type: Z.SELECTOR,
- tooltip: "toolbar.fontSize",
- label: {
- name: ra,
- props: {
- min: 1,
- max: 400
- // disabled$,
- }
- },
- selections: _c,
- // disabled$,
- value$: new pe((t) => {
- const o = Ci.fs, s = e.onCommandExecuted((r) => {
- var a;
- const i = r.id;
- if (i === De.id || i === Pt.id) {
- const c = dt(n);
- if (c == null) {
- t.next(o);
- return;
- }
- const A = (a = c.ts) == null ? void 0 : a.fs;
- t.next(A != null ? A : o);
- }
- });
- return t.next(o), s.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Uu(n) {
- const e = n.get(y), t = n.get(vi);
- return {
- id: wt.id,
- icon: "FontColor",
- tooltip: "toolbar.textColor.main",
- type: Z.BUTTON_SELECTOR,
- selections: [
- {
- label: {
- name: Ds,
- hoverable: !1
- }
- }
- ],
- value$: new pe((o) => {
- const s = t.getCurrentTheme().textColor, r = e.onCommandExecuted((i) => {
- if (i.id === wt.id) {
- const a = i.params.value;
- o.next(a != null ? a : s);
- }
- });
- return o.next(s), r.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- // disabled$: getCurrentSheetDisabled$(accessor),
- };
- }
- function Lu(n) {
- return {
- id: _s.id,
- type: Z.BUTTON,
- icon: "HeaderFooterSingle",
- tooltip: "toolbar.headerFooter",
- hidden$: ao(ee(n, _.UNIVER_DOC, void 0, $e), Tu(n), (e, t) => e || t)
- };
- }
- const Fu = "GridSingle", Ta = "doc.menu.table";
- function Hu(n) {
- return {
- id: Ta,
- type: Z.SUBITEMS,
- icon: Fu,
- tooltip: "toolbar.table.main",
- disabled$: yu(n),
- // Do not show header footer menu and insert table at zen mode.
- hidden$: ao(ee(n, _.UNIVER_DOC, void 0, $e), Ou(n), (e, t) => e || t)
- };
- }
- function ku(n) {
- return {
- id: sr.id,
- title: "toolbar.table.insert",
- type: Z.BUTTON,
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function Vu(n) {
- const e = n.get(y);
- return {
- id: go.id,
- type: Z.BUTTON,
- icon: "LeftJustifyingSingle",
- tooltip: "toolbar.alignLeft",
- disabled$: be(n),
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === et.id) {
- const a = vo(n);
- if (a == null)
- return;
- const c = (i = a.paragraphStyle) == null ? void 0 : i.horizontalAlign;
- t.next(c === _e.LEFT);
- }
- });
- return t.next(!1), o.dispose;
- }),
- hidden$: ee(n, _.UNIVER_DOC, void 0, $e)
- };
- }
- function ju(n) {
- const e = n.get(y);
- return {
- id: fo.id,
- type: Z.BUTTON,
- icon: "HorizontallySingle",
- tooltip: "toolbar.alignCenter",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === et.id) {
- const a = vo(n);
- if (a == null)
- return;
- const c = (i = a.paragraphStyle) == null ? void 0 : i.horizontalAlign;
- t.next(c === _e.CENTER);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC, void 0, $e)
- };
- }
- function Wu(n) {
- const e = n.get(y);
- return {
- id: po.id,
- type: Z.BUTTON,
- icon: "RightJustifyingSingle",
- tooltip: "toolbar.alignRight",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === et.id) {
- const a = vo(n);
- if (a == null)
- return;
- const c = (i = a.paragraphStyle) == null ? void 0 : i.horizontalAlign;
- t.next(c === _e.RIGHT);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC, void 0, $e)
- };
- }
- function zu(n) {
- const e = n.get(y);
- return {
- id: mo.id,
- type: Z.BUTTON,
- icon: "AlignTextBothSingle",
- tooltip: "toolbar.alignJustify",
- activated$: new pe((t) => {
- const o = e.onCommandExecuted((s) => {
- var i;
- const r = s.id;
- if (r === De.id || r === et.id) {
- const a = vo(n);
- if (a == null)
- return;
- const c = (i = a.paragraphStyle) == null ? void 0 : i.horizontalAlign;
- t.next(c === _e.JUSTIFIED);
- }
- });
- return t.next(!1), o.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC, void 0, $e)
- };
- }
- const un = (n) => new pe((e) => {
- const t = n.get(Q), o = n.get(G);
- let s;
- const r = t.focused$.subscribe((i) => {
- if (s == null || s.unsubscribe(), i == null)
- return;
- const a = t.getUniverDocInstance(i);
- a != null && (s = o.textSelection$.subscribe(() => {
- var l, d, h;
- const c = o.getDocRanges(), A = (l = c.find((u) => u.isActive)) != null ? l : c[0];
- if (A) {
- const u = a.getSelfOrHeaderFooterModel(A == null ? void 0 : A.segmentId), g = Qs(A, (h = (d = u.getBody()) == null ? void 0 : d.paragraphs) != null ? h : []);
- let f;
- if (g.every((p) => {
- var m;
- return f || (f = (m = p.bullet) == null ? void 0 : m.listType), p.bullet && p.bullet.listType === f;
- })) {
- e.next(f);
- return;
- }
- }
- e.next(void 0);
- }));
- });
- return () => {
- r.unsubscribe(), s == null || s.unsubscribe();
- };
- });
- function Gu(n) {
- return {
- id: ho.id,
- type: Z.BUTTON_SELECTOR,
- selections: [
- {
- label: {
- name: aa,
- hoverable: !1
- },
- value$: un(n)
- }
- ],
- icon: "OrderSingle",
- tooltip: "toolbar.order",
- hidden$: ee(n, _.UNIVER_DOC),
- disabled$: be(n),
- activated$: un(n).pipe(gn((e) => e && e.indexOf("ORDER_LIST") === 0))
- };
- }
- function Yu(n) {
- return {
- id: uo.id,
- type: Z.BUTTON_SELECTOR,
- selections: [
- {
- label: {
- name: ca,
- hoverable: !1
- },
- value$: un(n)
- }
- ],
- icon: "UnorderSingle",
- tooltip: "toolbar.unorder",
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC),
- activated$: un(n).pipe(gn((e) => e && e.indexOf("BULLET_LIST") === 0))
- };
- }
- function qu(n) {
- return {
- id: ws.id,
- type: Z.BUTTON,
- icon: "TodoList",
- tooltip: "toolbar.checklist",
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC),
- activated$: un(n).pipe(gn((e) => e && e.indexOf("CHECK_LIST") === 0))
- };
- }
- function Ku(n) {
- const e = n.get(y), t = n.get(Q);
- return {
- id: Co.id,
- type: Z.BUTTON,
- icon: "KeyboardSingle",
- tooltip: "toolbar.documentFlavor",
- hidden$: ee(n, _.UNIVER_DOC, void 0, $e),
- activated$: new pe((o) => {
- var i;
- const s = e.onCommandExecuted((a) => {
- var c;
- if (a.id === J.id) {
- const A = t.getCurrentUnitForType(_.UNIVER_DOC);
- o.next(((c = A == null ? void 0 : A.getSnapshot()) == null ? void 0 : c.documentStyle.documentFlavor) === ye.MODERN);
- }
- }), r = t.getCurrentUnitForType(_.UNIVER_DOC);
- return o.next(((i = r == null ? void 0 : r.getSnapshot()) == null ? void 0 : i.documentStyle.documentFlavor) === ye.MODERN), () => s.dispose();
- })
- };
- }
- function Xu(n) {
- return {
- id: fn.id,
- type: Z.BUTTON,
- title: "toolbar.resetColor",
- icon: "NoColor"
- };
- }
- function Ju(n) {
- const e = n.get(y), t = n.get(vi);
- return {
- id: Nt.id,
- tooltip: "toolbar.fillColor.main",
- type: Z.BUTTON_SELECTOR,
- icon: "PaintBucket",
- selections: [
- {
- label: {
- name: Ds,
- hoverable: !1
- }
- }
- ],
- value$: new pe((o) => {
- const s = t.getCurrentTheme().primaryColor, r = e.onCommandExecuted((i) => {
- if (i.id === Nt.id) {
- const a = i.params.value;
- o.next(a != null ? a : s);
- }
- });
- return o.next(s), r.dispose;
- }),
- disabled$: be(n),
- hidden$: ee(n, _.UNIVER_DOC)
- };
- }
- function dt(n) {
- var h, u;
- const e = n.get(Q), t = n.get(G), o = n.get(Je), s = e.getCurrentUnitForType(_.UNIVER_DOC), r = t.getDocRanges(), i = (h = r.find((g) => g.isActive)) != null ? h : r[0], a = o.getDefaultStyle(), c = (u = o.getStyleCache()) != null ? u : {};
- if (s == null || i == null)
- return {
- ts: {
- ...a,
- ...c
- }
- };
- const { segmentId: A } = i, l = s.getSelfOrHeaderFooterModel(A).getBody();
- return l == null ? {
- ts: {
- ...a,
- ...c
- }
- } : {
- ts: {
- ...la(l, i, a),
- ...c
- }
- };
- }
- function vo(n) {
- var l, d;
- const e = n.get(Q), t = n.get(G), o = e.getCurrentUniverDocInstance(), s = t.getDocRanges(), r = (l = s.find((h) => h.isActive)) != null ? l : s[0];
- if (o == null || r == null)
- return;
- const { startOffset: i, segmentId: a } = r, c = (d = o.getSelfOrHeaderFooterModel(a).getBody()) == null ? void 0 : d.paragraphs;
- if (c == null)
- return;
- let A = -1;
- for (const h of c) {
- const { startIndex: u } = h;
- if (i > A && i <= u)
- return h;
- A = u;
- }
- return null;
- }
- const Zu = {
- [Ir.FORMAT]: {
- [Vt.id]: {
- order: 0,
- menuItemFactory: Bu
- },
- [jt.id]: {
- order: 1,
- menuItemFactory: Mu
- },
- [Wt.id]: {
- order: 2,
- menuItemFactory: _u
- },
- [zt.id]: {
- order: 3,
- menuItemFactory: Pu
- },
- [Ct.id]: {
- order: 4,
- menuItemFactory: Du
- },
- [Gt.id]: {
- order: 5,
- menuItemFactory: wu
- },
- [Pt.id]: {
- order: 6,
- menuItemFactory: Qu
- },
- [Dt.id]: {
- order: 7,
- menuItemFactory: Nu
- },
- [wt.id]: {
- order: 8,
- menuItemFactory: Uu
- },
- [Nt.id]: {
- order: 9,
- menuItemFactory: Ju,
- [fn.id]: {
- order: 0,
- menuItemFactory: Xu
- }
- }
- },
- [Ir.LAYOUT]: {
- [Ta]: {
- order: 1,
- menuItemFactory: Hu,
- [sr.id]: {
- order: 0,
- menuItemFactory: ku
- }
- },
- [go.id]: {
- order: 2,
- menuItemFactory: Vu
- },
- [fo.id]: {
- order: 3,
- menuItemFactory: ju
- },
- [po.id]: {
- order: 4,
- menuItemFactory: Wu
- },
- [mo.id]: {
- order: 5,
- menuItemFactory: zu
- },
- [ho.id]: {
- order: 6,
- menuItemFactory: Gu
- },
- [uo.id]: {
- order: 7,
- menuItemFactory: Yu
- },
- [ws.id]: {
- order: 8,
- menuItemFactory: qu
- },
- [_s.id]: {
- order: 9,
- menuItemFactory: Lu
- },
- [Co.id]: {
- order: 10,
- menuItemFactory: Ku
- }
- },
- [Ui.MAIN_AREA]: {
- [Cr.FORMAT]: {
- [Fn.name]: {
- order: 0,
- menuItemFactory: uu
- },
- [qs.id]: {
- order: 1,
- menuItemFactory: gu
- },
- [Ks.id]: {
- order: 2,
- menuItemFactory: fu
- },
- [So.id]: {
- order: 3,
- menuItemFactory: pu
- }
- },
- [Cr.LAYOUT]: {
- [rr.id]: {
- order: 0,
- menuItemFactory: hu
- },
- [xa]: {
- order: 1,
- menuItemFactory: mu,
- [er.id]: {
- order: 1,
- menuItemFactory: Eu
- },
- [tr.id]: {
- order: 2,
- menuItemFactory: Su
- },
- [nr.id]: {
- order: 3,
- menuItemFactory: Iu
- },
- [or.id]: {
- order: 4,
- menuItemFactory: Cu
- }
- },
- [Oa]: {
- order: 2,
- menuItemFactory: vu,
- [Xs.id]: {
- order: 1,
- menuItemFactory: Ru
- },
- [Js.id]: {
- order: 2,
- menuItemFactory: bu
- },
- [In.id]: {
- order: 3,
- menuItemFactory: xu
- }
- }
- }
- }
- };
- var $u = Object.defineProperty, eh = Object.getOwnPropertyDescriptor, th = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? eh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && $u(e, t, s), s;
- }, Ke = (n, e) => (t, o) => e(t, o, n);
- let Hn = class extends ue {
- constructor(n, e, t, o, s, r, i, a, c) {
- super(), this._injector = n, this._componentManager = e, this._commandService = t, this._layoutService = o, this._menuManagerService = s, this._uiPartsService = r, this._univerInstanceService = i, this._shortcutService = a, this._configService = c, this._init();
- }
- _initCustomComponents() {
- const n = this._componentManager;
- this.disposeWithMe(n.register(Ds, Zc)), this.disposeWithMe(n.register(oa, Pc)), this.disposeWithMe(n.register(sa, Dc)), this.disposeWithMe(n.register(ra, wc)), this.disposeWithMe(n.register(ca, Cl)), this.disposeWithMe(n.register(aa, Sl)), this.disposeWithMe(n.register("TodoList", $i));
- }
- // TODO: @zhangwei, why add workbook to docs-ui?
- _initUiParts() {
- var t, o;
- const n = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_SHEET), e = this._configService.getConfig(Us);
- (o = (t = e == null ? void 0 : e.layout) == null ? void 0 : t.docContainerConfig) != null && o.footer && !n && this.disposeWithMe(this._uiPartsService.registerComponent(Nc.FOOTER, () => $a(nd, this._injector)));
- }
- _initMenus() {
- this._menuManagerService.mergeMenu(Zu);
- }
- _initShortCut() {
- [
- Nl,
- Ql,
- Ul,
- Ll,
- Fl,
- Hl,
- jl,
- Wl,
- Vl,
- kl,
- zl,
- Gl,
- xl
- ].forEach((n) => {
- this.disposeWithMe(this._shortcutService.registerShortcut(n));
- });
- }
- _init() {
- this._initCustomComponents(), this._initMenus(), this._initFocusHandler(), this._initCommands(), this._initUiParts(), this._initShortCut();
- }
- _initCommands() {
- [
- na,
- _s,
- Ms
- ].forEach((n) => this.disposeWithMe(this._commandService.registerCommand(n)));
- }
- _initFocusHandler() {
- this.disposeWithMe(
- this._layoutService.registerFocusHandler(_.UNIVER_DOC, (n) => {
- this._injector.get(fe).getRenderById(n).with(Se).focus();
- })
- );
- }
- };
- Hn = th([
- Ke(0, z(so)),
- Ke(1, z(io)),
- Ke(2, y),
- Ke(3, bs),
- Ke(4, Qc),
- Ke(5, Uc),
- Ke(6, Q),
- Ke(7, ro),
- Ke(8, Rs)
- ], Hn);
- var nh = Object.defineProperty, oh = Object.getOwnPropertyDescriptor, sh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? oh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && nh(e, t, s), s;
- }, Fo = (n, e) => (t, o) => e(t, o, n);
- const ni = 1.5;
- let kn = class extends At {
- constructor(n, e, t, o) {
- super(), this._context = n, this._textSelectionManagerService = e, this._editorService = t, this._docSkeletonManagerService = o, this._init();
- }
- _init() {
- this._textSelectionManagerService.textSelection$.pipe(st(this.dispose$)).subscribe((n) => {
- if (n == null)
- return;
- const { isEditing: e, unitId: t } = n;
- t !== this._context.unitId || !e || this._context.unitId !== vs && this._scrollToSelection();
- });
- }
- scrollToRange(n) {
- const e = this._docSkeletonManagerService.getSkeleton();
- if (!e)
- return;
- const { startOffset: t } = n, o = e.findNodePositionByCharIndex(t);
- o && this.scrollToNode(o);
- }
- scrollToNode(n) {
- var O;
- const { unitId: e, scene: t, mainComponent: o } = this._context, s = this._docSkeletonManagerService.getSkeleton();
- if (o == null || s == null)
- return;
- const r = o.getOffsetConfig(), { docsLeft: i, docsTop: a } = r, c = new it(r, s), { contentBoxPointGroup: A } = c.getRangePointData(n, n), { left: l, top: d, height: h } = Mn(A), u = l + i, g = d + a, f = t.getViewport(Xe.VIEW_MAIN), p = this._editorService.getEditor(e);
- if (f == null)
- return;
- const {
- left: m,
- top: E,
- right: I,
- bottom: v
- } = f.getBounding().viewBound;
- let R = 0, S = 0;
- const C = p ? (O = p.params.backScrollOffset) != null ? O : 0 : 100;
- g < E ? R = g - E - C : g > v - h && (R = g - v + h + C), u < m ? S = u - m : u > I - ni && (S = u - I + ni);
- const T = f.transViewportScroll2ScrollValue(S, R);
- f.scrollByBarDeltaValue(T);
- }
- // Let the selection show on the current screen.
- _scrollToSelection() {
- const n = this._textSelectionManagerService.getActiveTextRange();
- if (n == null)
- return;
- const { collapsed: e, startNodePosition: t } = n;
- e && this.scrollToNode(t);
- }
- };
- kn = sh([
- Fo(1, z(G)),
- Fo(2, He),
- Fo(3, z(ie))
- ], kn);
- var rh = Object.defineProperty, ih = Object.getOwnPropertyDescriptor, ah = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? ih(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && rh(e, t, s), s;
- }, bt = (n, e) => (t, o) => e(t, o, n);
- let os = class extends At {
- constructor(n, e, t, o, s, r, i) {
- super(), this._context = n, this._commandService = e, this._docSelectionRenderService = t, this._docSkeletonManagerService = o, this._editorService = s, this._renderManagerService = r, this._univerInstanceService = i, this._addNewRender(), this._initRenderRefresh(), this._initCommandListener();
- }
- reRender(n) {
- var r, i;
- const e = (r = this._renderManagerService.getRenderById(n)) == null ? void 0 : r.with(ie), t = e == null ? void 0 : e.getSkeleton();
- if (!t || !!t.getViewModel().getDataModel().getSnapshot().disabled)
- return;
- t.calculate();
- const s = this._editorService.getEditor(n);
- if (this._editorService.isEditor(n) && !(s != null && s.params.scrollBar)) {
- (i = this._context.mainComponent) == null || i.makeDirty();
- return;
- }
- this._recalculateSizeBySkeleton(t);
- }
- _addNewRender() {
- const { scene: n, engine: e } = this._context, t = new Sc(Xe.VIEW_MAIN, n, {
- left: 0,
- top: 0,
- bottom: 0,
- right: 0,
- isWheelPreventDefaultX: !0
- });
- n.attachControl(), n.onMouseWheel$.subscribeEvent((o, s) => {
- const r = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC);
- if ((r == null ? void 0 : r.getUnitId()) !== this._context.unitId)
- return;
- const i = o;
- if (i.ctrlKey) {
- const a = Math.abs(i.deltaX);
- let c = a < 40 ? 0.2 : a < 80 ? 0.4 : 0.2;
- c *= i.deltaY > 0 ? -1 : 1, n.scaleX < 1 && (c /= 2), n.scaleX + c > 4 ? n.scale(4, 4) : n.scaleX + c < 0.1 ? n.scale(0.1, 0.1) : i.preventDefault();
- } else
- t.onMouseWheel(i, s);
- }), new Vo(t), n.addLayer(
- new Sr(n, [], Oo),
- new Sr(n, [], aA)
- ), this._addComponent(), e.runRenderLoop(() => {
- n.render();
- }), this._docSelectionRenderService.__attachScrollEvent();
- }
- _addComponent() {
- const { scene: n, unit: e, components: t } = this._context, r = {
- pageMarginLeft: 20,
- pageMarginTop: 20
- }, i = new Ic(We.MAIN, void 0, r);
- i.zIndex = xr;
- const a = new Cc(We.BACKGROUND, void 0, r);
- a.zIndex = xr, this._context.mainComponent = i, t.set(We.MAIN, i), t.set(We.BACKGROUND, a), n.addObjects([i], Oo), n.addObjects([a], iA), this._editorService.getEditor(e.getUnitId()) == null && n.enableLayerCache(Oo);
- }
- _initRenderRefresh() {
- this._docSkeletonManagerService.currentSkeletonBefore$.pipe(st(this.dispose$)).subscribe((n) => {
- this._create(n);
- });
- }
- _create(n) {
- var a;
- if (!n)
- return;
- const { mainComponent: e, components: t } = this._context, o = e, s = t.get(We.BACKGROUND);
- o.changeSkeleton(n), s.changeSkeleton(n);
- const { unitId: r } = this._context, i = this._editorService.getEditor(r);
- if (this._editorService.isEditor(r) && !(i != null && i.params.scrollBar)) {
- (a = this._context.mainComponent) == null || a.makeDirty();
- return;
- }
- this._recalculateSizeBySkeleton(n);
- }
- _initCommandListener() {
- const n = [J.id];
- this.disposeWithMe(this._commandService.onCommandExecuted((e) => {
- if (n.includes(e.id)) {
- const t = e.params, { unitId: o } = t;
- this.reRender(o);
- }
- }));
- }
- _recalculateSizeBySkeleton(n) {
- var u;
- const { mainComponent: e, scene: t, unitId: o, components: s } = this._context, r = e, i = s.get(We.BACKGROUND), a = (u = n.getSkeletonData()) == null ? void 0 : u.pages;
- if (a == null)
- return;
- let c = 0, A = 0;
- const d = this._context.unit.getSnapshot().documentStyle.documentFlavor;
- for (let g = 0, f = a.length; g < f; g++) {
- const p = a[g];
- let { pageWidth: m, pageHeight: E } = p;
- if (d === ye.MODERN) {
- const I = ch(p);
- m = I.pageWidth, E = I.pageHeight;
- }
- r.pageLayoutType === an.VERTICAL ? (A += E, A += r.pageMarginTop, g === f - 1 && (A += r.pageMarginTop), c = Math.max(c, m)) : r.pageLayoutType === an.HORIZONTAL && (c += m, g !== f - 1 && (c += r.pageMarginLeft), A = Math.max(A, E));
- }
- r.resize(c, A), i.resize(c, A);
- const h = this._editorService.getEditor(o);
- (!this._editorService.isEditor(o) || h != null && h.params.scrollBar) && t.resize(c, A);
- }
- };
- os = ah([
- bt(1, y),
- bt(2, z(Se)),
- bt(3, z(ie)),
- bt(4, He),
- bt(5, fe),
- bt(6, Q)
- ], os);
- function ch(n) {
- let { pageWidth: e, pageHeight: t } = n;
- const { marginLeft: o, marginRight: s, marginTop: r, marginBottom: i, skeDrawings: a, skeTables: c } = n;
- e === Number.POSITIVE_INFINITY && (e = n.width + o + s), t === Number.POSITIVE_INFINITY && (t = n.height + r + i);
- for (const A of a.values())
- e = Math.max(e, A.aLeft + A.width + o + s), t = Math.max(t, A.aTop + A.height + r + i);
- for (const A of c.values())
- e = Math.max(e, A.left + A.width + o + s), t = Math.max(t, A.top + A.height + r + i);
- return { pageWidth: e, pageHeight: t };
- }
- const ya = {
- id: "doc.command.select-all",
- type: N.COMMAND,
- handler: async (n) => {
- var h;
- const e = n.get(Q), t = n.get(G), o = e.getCurrentUnitForType(_.UNIVER_DOC), s = t.getDocRanges(), r = (h = s.find((u) => u.isActive)) != null ? h : s[0];
- if (o == null || r == null)
- return !1;
- const { segmentId: i } = r, a = o.getUnitId(), c = o.getSelfOrHeaderFooterModel(i).getSnapshot().body;
- if (c == null)
- return !1;
- const { tables: A = [] } = c, l = [];
- let d = 0;
- for (const u of A) {
- const { startIndex: g, endIndex: f } = u;
- d !== g && l.push({
- startOffset: d,
- endOffset: g - 1,
- rangeType: Ge.TEXT
- }), l.push({
- startOffset: g + 3,
- // 3 is TABLE_START, ROW_START, CELL_START.
- endOffset: f - 5,
- // 4 is CELL_END, ROW_END, TABLE_END AND \n.
- rangeType: Ge.RECT
- }), d = f;
- }
- return d !== c.dataStream.length - 2 && l.push({
- startOffset: d,
- endOffset: c.dataStream.length - 2,
- rangeType: Ge.TEXT
- }), t.replaceDocRanges(l, {
- unitId: a,
- subUnitId: a
- }, !1), !0;
- }
- };
- class Ro extends At {
- constructor(t) {
- super();
- x(this, "_previousActiveRange", null);
- x(this, "_undoMutationParamsCache", []);
- x(this, "_redoMutationParamsCache", []);
- this._context = t;
- }
- clearUndoRedoMutationParamsCache() {
- this._undoMutationParamsCache = [], this._redoMutationParamsCache = [];
- }
- getUndoRedoMutationParamsCache() {
- return {
- undoCache: this._undoMutationParamsCache,
- redoCache: this._redoMutationParamsCache
- };
- }
- setUndoRedoMutationParamsCache({ undoCache: t = [], redoCache: o = [] }) {
- this._undoMutationParamsCache = t, this._redoMutationParamsCache = o;
- }
- getActiveRange() {
- return this._previousActiveRange;
- }
- setActiveRange(t) {
- this._previousActiveRange = t;
- }
- pushUndoRedoMutationParams(t, o) {
- this._undoMutationParamsCache.push(t), this._redoMutationParamsCache.push(o);
- }
- fetchComposedUndoRedoMutationParams() {
- if (this._undoMutationParamsCache.length === 0 || this._previousActiveRange == null || this._redoMutationParamsCache.length === 0)
- return null;
- const { unitId: t } = this._undoMutationParamsCache[0], o = {
- unitId: t,
- actions: this._undoMutationParamsCache.reverse().reduce((r, i) => k.compose(r, i.actions), null),
- textRanges: []
- // Add empty array, will never use, just fix type error
- };
- return { redoMutationParams: {
- unitId: t,
- actions: this._redoMutationParamsCache.reduce((r, i) => k.compose(r, i.actions), null),
- textRanges: []
- // Add empty array, will never use, just fix type error
- }, undoMutationParams: o, previousActiveRange: this._previousActiveRange };
- }
- dispose() {
- this._undoMutationParamsCache = [], this._redoMutationParamsCache = [], this._previousActiveRange = null;
- }
- }
- const Ah = Is, Ba = {
- id: "doc.command.ime-input",
- type: N.COMMAND,
- // eslint-disable-next-line max-lines-per-function
- handler: async (n, e) => {
- var D, te, q, V;
- const { unitId: t, newText: o, oldTextLen: s, isCompositionEnd: r, isCompositionStart: i } = e, a = n.get(y), c = n.get(fe), A = n.get(Q), l = n.get(Je), d = (D = c.getRenderById(t)) == null ? void 0 : D.with(Ro), h = A.getUnit(t, _.UNIVER_DOC);
- if (h == null || d == null)
- return !1;
- const u = d.getActiveRange();
- if (u == null)
- return !1;
- const { style: g, segmentId: f } = u, p = h.getSelfOrHeaderFooterModel(f).getBody();
- if (p == null)
- return !1;
- Object.assign(u, u);
- const { startOffset: E, endOffset: I } = u, v = o.length, R = [
- {
- startOffset: E + v,
- endOffset: E + v,
- collapsed: !0,
- style: g
- }
- ], S = {
- id: J.id,
- params: {
- unitId: t,
- actions: [],
- textRanges: R
- }
- }, C = l.getDefaultStyle(), T = l.getStyleCache(), O = Os((te = p.customRanges) != null ? te : [], E + s, Ah.includes(t)), P = co(
- (q = p.textRuns) != null ? q : [],
- i ? I : E + s,
- C,
- T
- ), b = Ts((V = p.customDecorations) != null ? V : [], E + s), B = new me(), M = k.getInstance();
- if (!u.collapsed && i) {
- const Y = Ce.selection.delete([u], p, 0, null, !1);
- B.push(...Y), S.params.textRanges = [{
- startOffset: E + v,
- endOffset: E + v,
- collapsed: !0
- }];
- } else
- B.push({
- t: W.RETAIN,
- len: E
- });
- s > 0 && B.push({
- t: W.DELETE,
- len: s
- }), B.push({
- t: W.INSERT,
- body: {
- dataStream: o,
- textRuns: P ? [{
- ...P,
- st: 0,
- ed: o.length
- }] : [],
- customRanges: O ? [{
- ...O,
- startIndex: 0,
- endIndex: o.length - 1
- }] : [],
- customDecorations: b.map((Y) => ({
- ...Y,
- startIndex: 0,
- endIndex: o.length - 1
- }))
- },
- len: o.length
- });
- const H = le(h, f);
- S.params.actions = M.editOp(B.serialize(), H), S.params.noHistory = !r, S.params.isCompositionEnd = r;
- const F = a.syncExecuteCommand(S.id, S.params);
- return d.pushUndoRedoMutationParams(F, S.params), !!F;
- }
- }, ss = {
- type: N.COMMAND,
- id: "doc.command.set-zoom-ratio",
- handler: async (n, e) => {
- var d, h, u;
- const t = n.get(y), o = n.get(eo), s = n.get(Q);
- let r = (d = s.getCurrentUniverDocInstance()) == null ? void 0 : d.getUnitId();
- if (!r) return !1;
- let i = 1;
- if (e && (r = (h = e.documentId) != null ? h : r, i = (u = e.zoomRatio) != null ? u : i), !s.getUniverDocInstance(r)) return !1;
- const c = {
- zoomRatio: i,
- unitId: r
- }, A = Kl(n, c);
- return t.syncExecuteCommand(Ye.id, c) ? (o.pushUndoRedo({
- unitID: r,
- undoMutations: [{ id: Ye.id, params: A }],
- redoMutations: [{ id: Ye.id, params: c }]
- }), !0) : !1;
- }
- }, Ma = {
- id: "doc.table.tab-in-table",
- type: N.COMMAND,
- handler: async (n, e) => {
- var g;
- const { shift: t } = e, o = n.get(G), s = o.getDocRanges(), r = n.get(y), a = n.get(Q).getCurrentUniverDocInstance();
- if (!a)
- return !1;
- const c = (g = s.find((f) => f.isActive)) != null ? g : s[0], A = a.getUnitId(), l = ke(n, A), d = l == null ? void 0 : l.getSkeleton(), h = d == null ? void 0 : d.getViewModel().getSelfOrHeaderFooterViewModel(c == null ? void 0 : c.segmentId);
- if (h == null || c == null)
- return !1;
- let u = null;
- if (t ? u = Kr(h, c, ts.PREV) : u = Kr(h, c, ts.NEXT), u) {
- const { startOffset: f, endOffset: p } = u, m = [{
- startOffset: f,
- endOffset: p
- }];
- return o.replaceDocRanges(m), !0;
- }
- return t === !1 ? await r.executeCommand(Ia.id, {
- position: Eo.BELLOW
- }) : !0;
- }
- };
- var lh = Object.defineProperty, dh = Object.getOwnPropertyDescriptor, uh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? dh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && lh(e, t, s), s;
- }, Ho = (n, e) => (t, o) => e(t, o, n);
- let rs = class {
- constructor(n, e, t) {
- x(this, "_docContainer");
- // 获取SheetContainer组件
- x(this, "getComponent", (n) => {
- if (this._docContainer = n, !n.getContentRef().current)
- throw new Error("container is not ready");
- });
- /**
- * Change language
- * @param {string} lang new language
- *
- * e: {target: HTMLSelectElement } reference from https://stackoverflow.com/a/48443771
- *
- */
- x(this, "changeLocale", (n) => {
- this._localeService.setLocale(n);
- });
- this._localeService = n, this._injector = e, this._configService = t;
- }
- getUIConfig() {
- return {
- injector: this._injector,
- config: this._configService.getConfig(Us),
- changeLocale: this.changeLocale,
- getComponent: this.getComponent
- };
- }
- getContentRef() {
- return this._docContainer.getContentRef();
- }
- UIDidMount(n) {
- if (this._docContainer)
- return n(this._docContainer);
- }
- getDocContainer() {
- return this._docContainer;
- }
- };
- rs = uh([
- Ho(0, z(Ze)),
- Ho(1, z(so)),
- Ho(2, Rs)
- ], rs);
- var hh = Object.defineProperty, gh = Object.getOwnPropertyDescriptor, fh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? gh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && hh(e, t, s), s;
- }, ph = (n, e) => (t, o) => e(t, o, n);
- let Vn = class extends At {
- constructor(e) {
- super();
- x(this, "_docContainerController");
- this._injector = e, this._docContainerController = this._injector.createInstance(rs);
- }
- };
- Vn = fh([
- ph(0, z(so))
- ], Vn);
- var mh = Object.defineProperty, Eh = Object.getOwnPropertyDescriptor, Sh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Eh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && mh(e, t, s), s;
- }, oi = (n, e) => (t, o) => e(t, o, n);
- let jn = class extends ue {
- constructor(n, e) {
- super(), this._docAutoFormatService = n, this._renderManagerService = e, this._initListTabAutoFormat(), this._initListSpaceAutoFormat(), this._initDefaultEnterFormat(), this._initExitListAutoFormat();
- }
- _initListTabAutoFormat() {
- this.disposeWithMe(
- this._docAutoFormatService.registerAutoFormat({
- id: _t.id,
- match: (n) => {
- var s;
- const { selection: e, paragraphs: t, unit: o } = n;
- if (t.length === 1 && e.startOffset === t[0].paragraphStart && t[0].bullet) {
- const r = (s = o.getBody()) == null ? void 0 : s.paragraphs, i = r == null ? void 0 : r.filter((a) => {
- var c;
- return ((c = a.bullet) == null ? void 0 : c.listId) === t[0].bullet.listId;
- });
- return (i == null ? void 0 : i.findIndex((a) => a.startIndex === t[0].startIndex)) !== 0;
- } else if (t.length > 1 && t.some((r) => r.bullet))
- return !0;
- return !1;
- },
- // traverse all paragraphs, set paragraph
- getMutations(n) {
- const e = n.commandParams;
- return [{
- id: es.id,
- params: {
- type: e != null && e.shift ? Pn.decrease : Pn.increase
- }
- }];
- },
- priority: 100
- })
- ), this.disposeWithMe(
- this._docAutoFormatService.registerAutoFormat({
- id: _t.id,
- match: (n) => {
- const { selection: e, unit: t } = n, { startNodePosition: o, endNodePosition: s } = e, r = this._renderManagerService.getRenderById(t.getUnitId()), i = r == null ? void 0 : r.with(ie).getSkeleton();
- return i == null ? !1 : !!(o && s && zi(i, o, s) || o && !s && o.path.indexOf("cells") > -1);
- },
- getMutations(n) {
- const e = n.commandParams;
- return [{
- id: Ma.id,
- params: {
- shift: !!(e != null && e.shift)
- }
- }];
- },
- priority: 99
- })
- );
- }
- _initListSpaceAutoFormat() {
- this.disposeWithMe(
- this._docAutoFormatService.registerAutoFormat({
- id: Ao.id,
- match: (n) => {
- var r;
- const { selection: e, paragraphs: t, unit: o } = n;
- if (!e.collapsed || t.length !== 1)
- return !1;
- const s = (r = o.getBody()) == null ? void 0 : r.dataStream.slice(t[0].paragraphStart, t[0].paragraphEnd - 1);
- return !!(s && Object.keys(bo).includes(s));
- },
- getMutations(n) {
- var s;
- const { paragraphs: e, unit: t } = n, o = (s = t.getBody()) == null ? void 0 : s.dataStream.slice(e[0].paragraphStart, e[0].paragraphEnd - 1);
- if (o && Object.keys(bo).includes(o)) {
- const r = bo[o];
- return [{
- id: da.id,
- params: {
- listType: r,
- paragraph: e[0]
- }
- }];
- }
- return [];
- }
- })
- );
- }
- _initExitListAutoFormat() {
- this.disposeWithMe(
- this._docAutoFormatService.registerAutoFormat({
- id: ln.id,
- match: (n) => {
- const { paragraphs: e } = n;
- return !!(e.length === 1 && e[0].bullet && e[0].paragraphStart === e[0].paragraphEnd);
- },
- getMutations: (n) => {
- const e = n.paragraphs[0].bullet;
- return e ? e.nestingLevel > 0 ? [{
- id: es.id,
- params: {
- type: Pn.decrease
- }
- }] : [{
- id: pn.id,
- params: {
- listType: n.paragraphs[0].bullet.listType
- }
- }] : [];
- }
- })
- );
- }
- _initDefaultEnterFormat() {
- this.disposeWithMe(
- this._docAutoFormatService.registerAutoFormat({
- id: ln.id,
- match: () => !0,
- getMutations() {
- return [{
- id: Ra.id
- }];
- },
- priority: -9999
- })
- );
- }
- };
- jn = Sh([
- oi(0, z(Et)),
- oi(1, fe)
- ], jn);
- function Ih(n) {
- return n.rows[0].cells[0].sections[0].columns[0].lines[0];
- }
- function Ch(n) {
- const e = n.rows[n.rows.length - 1], t = e.cells[e.cells.length - 1];
- return bc(t);
- }
- function vh(n, e) {
- const { ed: t } = n, { skeTables: o } = e;
- let s = null;
- for (const r of o.values())
- if (r.st === t + 1) {
- s = r;
- break;
- }
- return s;
- }
- function si(n) {
- const e = n == null ? void 0 : n.parent;
- let t = null, o = null;
- if (n == null || e == null)
- return {
- lineBeforeTable: t,
- lineAfterTable: o
- };
- const { st: s, ed: r } = n, i = e.type === Ie.CELL ? [e] : e.parent.pages;
- return vc(i, (a) => {
- a.st === r + 1 ? o = a : a.ed === s - 1 && (t = a);
- }), {
- lineBeforeTable: t,
- lineAfterTable: o
- };
- }
- function _a(n) {
- return n.sections[0].columns[0].lines.length === 0;
- }
- function Pa(n) {
- var i, a;
- const e = n.parent, t = e == null ? void 0 : e.parent, o = t == null ? void 0 : t.tableId;
- if (e == null || t == null)
- return;
- const s = e.cells.indexOf(n);
- let r = t.rows[t.rows.indexOf(e) + 1];
- if (r == null && o.indexOf("#-#")) {
- const [c, A] = o.split("#-#"), l = (a = (i = t.parent) == null ? void 0 : i.parent) == null ? void 0 : a.pages, d = `${c}#-#${Number.parseInt(A) + 1}`;
- if (l)
- for (const h of l) {
- const { skeTables: u } = h;
- if (u.has(d)) {
- const g = u.get(d);
- if (g != null && g.rows.length) {
- r = g.rows.find((f) => !f.isRepeatRow);
- break;
- }
- }
- }
- }
- if (r != null) {
- const c = r.cells[s];
- return _a(c) ? Pa(c) : c;
- }
- }
- function Da(n) {
- var r, i;
- const e = n.parent, t = e == null ? void 0 : e.parent;
- if (e == null || t == null)
- return;
- let o = t.rows[t.rows.indexOf(e) - 1];
- const s = e.cells.indexOf(n);
- if ((o == null || o.isRepeatRow) && t.tableId.indexOf("#-#")) {
- const [a, c] = t.tableId.split("#-#"), A = (i = (r = t.parent) == null ? void 0 : r.parent) == null ? void 0 : i.pages, l = `${a}#-#${Number.parseInt(c) - 1}`;
- if (A)
- for (const d of A) {
- const { skeTables: h } = d;
- if (h.has(l)) {
- const u = h.get(l);
- if (u != null && u.rows.length) {
- o = u.rows[u.rows.length - 1];
- break;
- }
- }
- }
- }
- if (o != null) {
- const a = o.cells[s];
- return _a(a) ? Da(a) : a;
- }
- }
- function Rh(n, e) {
- const { st: t } = n, { skeTables: o } = e;
- let s = null;
- for (const r of o.values())
- if (r.ed === t - 1) {
- s = r;
- break;
- }
- return s;
- }
- function bh(n) {
- return n.sections[0].columns[0].lines[0];
- }
- function xh(n) {
- const e = Rc(n);
- return e.lines[e.lines.length - 1];
- }
- var Oh = Object.defineProperty, Th = Object.getOwnPropertyDescriptor, yh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Th(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Oh(e, t, s), s;
- }, Rn = (n, e) => (t, o) => e(t, o, n);
- let Wn = class extends ue {
- constructor(e, t, o, s) {
- super();
- x(this, "_onInputSubscription");
- this._univerInstanceService = e, this._renderManagerService = t, this._textSelectionManagerService = o, this._commandService = s, this._commandExecutedListener();
- }
- dispose() {
- var e;
- super.dispose(), (e = this._onInputSubscription) == null || e.unsubscribe();
- }
- _commandExecutedListener() {
- const e = [at.id, ct.id];
- this.disposeWithMe(
- this._commandService.onCommandExecuted((t) => {
- if (!e.includes(t.id))
- return;
- const o = t.params;
- switch (t.id) {
- case at.id:
- return this._handleMoveCursor(o.direction);
- case ct.id:
- return this._handleShiftMoveSelection(o.direction);
- default:
- throw new Error("Unknown command");
- }
- })
- );
- }
- // eslint-disable-next-line max-lines-per-function, complexity
- _handleShiftMoveSelection(e) {
- var I, v, R;
- const t = this._textSelectionManagerService.getActiveTextRange(), o = this._textSelectionManagerService.getTextRanges(), s = this._univerInstanceService.getCurrentUniverDocInstance();
- if (s == null)
- return;
- const r = (I = this._renderManagerService.getRenderById(s.getUnitId())) == null ? void 0 : I.with(ie).getSkeleton(), i = this._getDocObject();
- if (t == null || r == null || i == null)
- return;
- const {
- startOffset: a,
- endOffset: c,
- style: A,
- collapsed: l,
- direction: d,
- segmentId: h,
- startNodePosition: u,
- endNodePosition: g,
- segmentPage: f
- } = t;
- if (o.length > 1) {
- let S = Number.POSITIVE_INFINITY, C = Number.NEGATIVE_INFINITY;
- for (const T of o)
- S = Math.min(S, T.startOffset), C = Math.max(C, T.endOffset);
- this._textSelectionManagerService.replaceTextRanges([
- {
- startOffset: e === se.LEFT || e === se.UP ? C : S,
- endOffset: e === se.LEFT || e === se.UP ? S : C,
- style: A
- }
- ], !1);
- return;
- }
- const p = l || d === xe.FORWARD ? a : c;
- let m = l || d === xe.FORWARD ? c : a;
- const E = (v = s.getSelfOrHeaderFooterModel(h).getBody().dataStream.length) != null ? v : Number.POSITIVE_INFINITY;
- if (e === se.LEFT || e === se.RIGHT) {
- const S = r.findNodeByCharIndex(m - 1, h, f), C = r.findNodeByCharIndex(m, h, f);
- m = e === se.RIGHT ? m + C.count : m - ((R = S == null ? void 0 : S.count) != null ? R : 0), m = Math.min(E - 2, Math.max(0, m)), this._textSelectionManagerService.replaceTextRanges([
- {
- startOffset: p,
- endOffset: m,
- style: A
- }
- ], !1), this._scrollToFocusNodePosition(s.getUnitId(), m);
- } else {
- const S = r.findNodeByCharIndex(m, h, f), C = i.document.getOffsetConfig(), T = l ? u : d === xe.FORWARD ? g : u, O = this._getTopOrBottomPosition(r, S, T, e === se.DOWN, !0);
- if (O == null) {
- const b = e === se.UP ? 0 : E - 2;
- if (b === m)
- return;
- this._textSelectionManagerService.replaceTextRanges([
- {
- startOffset: p,
- endOffset: b,
- style: A
- }
- ], !1);
- return;
- }
- const P = new it(C, r).getRangePointData(
- O,
- O
- ).cursorList[0];
- this._textSelectionManagerService.replaceTextRanges([
- {
- startOffset: p,
- endOffset: P.endOffset,
- style: A
- }
- ], !1), this._scrollToFocusNodePosition(s.getUnitId(), P.endOffset);
- }
- }
- // eslint-disable-next-line max-lines-per-function, complexity
- _handleMoveCursor(e) {
- var E, I, v, R;
- const t = this._textSelectionManagerService.getActiveTextRange(), o = this._textSelectionManagerService.getTextRanges(), s = this._univerInstanceService.getCurrentUniverDocInstance();
- if (s == null)
- return !1;
- const r = (E = this._renderManagerService.getRenderById(s.getUnitId())) == null ? void 0 : E.with(ie).getSkeleton(), i = this._getDocObject();
- if (t == null || r == null || i == null || o == null)
- return;
- const { startOffset: a, endOffset: c, style: A, collapsed: l, segmentId: d, startNodePosition: h, endNodePosition: u, segmentPage: g } = t, f = s.getSelfOrHeaderFooterModel(d).getBody();
- if (f == null)
- return;
- const p = (I = f.dataStream.length) != null ? I : Number.POSITIVE_INFINITY, m = (v = s.getCustomRanges()) != null ? v : [];
- if (e === se.LEFT || e === se.RIGHT) {
- let S;
- if (!t.collapsed || o.length > 1) {
- let O = Number.POSITIVE_INFINITY, P = Number.NEGATIVE_INFINITY;
- for (const b of o)
- O = Math.min(O, b.startOffset), P = Math.max(P, b.endOffset);
- S = e === se.LEFT ? O : P;
- } else {
- const O = r.findNodeByCharIndex(a - 1, d, g), P = r.findNodeByCharIndex(a, d, g), b = r.findNodeByCharIndex(a + 1, d, g);
- e === se.LEFT ? S = Math.max(0, a - ((R = O == null ? void 0 : O.count) != null ? R : 1)) : S = Math.min(p - 2, c + P.count + ((b == null ? void 0 : b.streamType) === U.SECTION_BREAK ? 1 : 0));
- }
- const C = [
- U.TABLE_START,
- U.TABLE_END,
- U.TABLE_ROW_START,
- U.TABLE_ROW_END,
- U.TABLE_CELL_START,
- U.TABLE_CELL_END,
- U.SECTION_BREAK
- ];
- if (e === se.LEFT)
- for (; C.includes(f.dataStream[S]); )
- S--;
- else
- for (; C.includes(f.dataStream[S]); )
- S++;
- m.filter((O) => O.wholeEntity && O.startIndex < S && O.endIndex >= S).forEach((O) => {
- e === se.LEFT ? S = Math.min(O.startIndex, S) : S = Math.max(O.endIndex + 1, S);
- }), this._textSelectionManagerService.replaceTextRanges([
- {
- startOffset: Math.max(0, S),
- endOffset: Math.max(0, S),
- style: A
- }
- ], !1), this._scrollToFocusNodePosition(s.getUnitId(), S);
- } else {
- const S = r.findNodeByCharIndex(a, d, g), C = r.findNodeByCharIndex(c, d, g), T = i.document.getOffsetConfig(), O = this._getTopOrBottomPosition(
- r,
- e === se.UP || l ? S : C,
- e === se.UP || l ? h : u,
- e === se.DOWN
- );
- if (O == null) {
- let b;
- l ? b = e === se.UP ? 0 : p - 2 : b = e === se.UP ? a : c, this._textSelectionManagerService.replaceTextRanges([
- {
- startOffset: Math.max(0, b),
- endOffset: Math.max(0, b),
- style: A
- }
- ], !1);
- return;
- }
- const P = new it(T, r).getRangePointData(
- O,
- O
- ).cursorList[0];
- this._textSelectionManagerService.replaceTextRanges([
- {
- ...P,
- style: A
- }
- ], !1), this._scrollToFocusNodePosition(s.getUnitId(), P.endOffset);
- }
- }
- _getTopOrBottomPosition(e, t, o, s, r = !1) {
- if (t == null || o == null)
- return;
- const i = this._getGlyphLeftOffsetInLine(t), a = this._getNextOrPrevLine(t, s, r);
- if (a == null)
- return;
- const c = this._matchPositionByLeftOffset(e, a, i, o);
- if (c != null)
- return { ...c, isBack: !0 };
- }
- _getGlyphLeftOffsetInLine(e) {
- const t = e.parent;
- if (t == null)
- return Number.NEGATIVE_INFINITY;
- const o = t.left, { left: s } = e;
- return o + s;
- }
- _matchPositionByLeftOffset(e, t, o, s) {
- const r = {
- distance: Number.POSITIVE_INFINITY
- };
- for (const a of t.divides) {
- const c = a.left;
- for (const A of a.glyphGroup) {
- if (A.streamType === U.SECTION_BREAK)
- continue;
- const { left: l } = A, d = c + l, h = Math.abs(o - d);
- h < r.distance && (r.glyph = A, r.distance = h);
- }
- }
- if (r.glyph == null)
- return;
- const { segmentPage: i } = s;
- return e.findPositionByGlyph(r.glyph, i);
- }
- // eslint-disable-next-line max-lines-per-function, complexity
- _getNextOrPrevLine(e, t, o = !1) {
- var f, p, m, E, I, v, R, S, C, T, O, P;
- const s = e.parent, r = s == null ? void 0 : s.parent, i = r == null ? void 0 : r.parent, a = i == null ? void 0 : i.parent, c = a == null ? void 0 : a.parent;
- if (s == null || r == null || i == null || a == null || c == null)
- return;
- const A = i.lines.indexOf(r);
- if (A === -1)
- return;
- let l;
- if (c.type === Ie.CELL && o) {
- const b = ri(c, t);
- if (b)
- return b;
- }
- if (t === !0) {
- l = i.lines[A + 1];
- const b = vh(r, c);
- if (b) {
- const B = Ih(b);
- B && (l = B);
- }
- } else {
- l = i.lines[A - 1];
- const b = Rh(r, c);
- if (b) {
- const B = Ch(b);
- B && (l = B);
- }
- }
- if (l != null)
- return l;
- const d = a.columns.indexOf(i);
- if (d === -1)
- return;
- if (t === !0)
- l = (f = a.columns[d + 1]) == null ? void 0 : f.lines[0];
- else {
- const b = (m = (p = a.columns) == null ? void 0 : p[d - 1]) == null ? void 0 : m.lines;
- l = b == null ? void 0 : b[b.length - 1];
- }
- if (l != null)
- return l;
- const h = c.sections.indexOf(a);
- if (h === -1)
- return;
- if (t === !0)
- l = (I = (E = c.sections[h - 1]) == null ? void 0 : E.columns[0]) == null ? void 0 : I.lines[0];
- else {
- const b = (R = (v = c.sections) == null ? void 0 : v[h - 1]) == null ? void 0 : R.columns, B = b == null ? void 0 : b[b.length - 1], M = B == null ? void 0 : B.lines;
- l = M == null ? void 0 : M[M.length - 1];
- }
- if (l != null)
- return l;
- if (c.type === Ie.CELL)
- return ri(c, t);
- const u = c.parent;
- if (u == null)
- return;
- const g = u.pages.indexOf(c);
- if (g !== -1) {
- if (t === !0)
- l = (T = (C = (S = u.pages[g + 1]) == null ? void 0 : S.sections[0]) == null ? void 0 : C.columns[0]) == null ? void 0 : T.lines[0];
- else {
- const b = (O = u.pages[g - 1]) == null ? void 0 : O.sections;
- if (b == null)
- return;
- const B = (P = b[b.length - 1]) == null ? void 0 : P.columns, M = B[B.length - 1], H = M == null ? void 0 : M.lines;
- l = H[H.length - 1];
- }
- if (l != null)
- return l;
- }
- }
- _scrollToFocusNodePosition(e, t) {
- var s;
- const o = (s = this._renderManagerService.getRenderById(e)) == null ? void 0 : s.with(kn);
- o != null && o.scrollToRange({
- startOffset: t,
- endOffset: t,
- collapsed: !0
- });
- }
- _getDocObject() {
- return cA(this._univerInstanceService, this._renderManagerService);
- }
- };
- Wn = yh([
- Rn(0, Q),
- Rn(1, fe),
- Rn(2, z(G)),
- Rn(3, y)
- ], Wn);
- function ri(n, e) {
- var o, s;
- let t = null;
- if (e === !0) {
- const r = Pa(n);
- if (r)
- t = bh(r);
- else {
- const i = (o = n.parent) == null ? void 0 : o.parent, { lineAfterTable: a } = si(i);
- a && (t = a);
- }
- } else {
- const r = Da(n);
- if (r)
- t = xh(r);
- else {
- const i = (s = n.parent) == null ? void 0 : s.parent, { lineBeforeTable: a } = si(i);
- a && (t = a);
- }
- }
- return t;
- }
- const Bh = "univer-create", Mh = "univer-create-item", _h = "univer-create-label", Ph = "univer-create-input", gt = {
- create: Bh,
- createItem: Mh,
- createLabel: _h,
- createInput: Ph
- }, Dh = ({
- handleRowColChange: n,
- tableCreateParams: e
- }) => {
- const t = $(Ze), [o, s] = ve(3), [r, i] = ve(5);
- function a(c, A) {
- s(c), i(A), n(c, A);
- }
- return Re(() => {
- s(e.rowCount), i(e.colCount);
- }, [e]), /* @__PURE__ */ w.jsxs("div", { className: gt.create, children: [
- /* @__PURE__ */ w.jsxs("div", { className: gt.createItem, children: [
- /* @__PURE__ */ w.jsx("span", { className: gt.createLabel, children: t.t("toolbar.table.rowCount") }),
- /* @__PURE__ */ w.jsx(
- An,
- {
- min: 1,
- max: 20,
- precision: 0,
- value: o,
- onChange: (c) => {
- a(c, r);
- },
- className: gt.createInput
- }
- )
- ] }),
- /* @__PURE__ */ w.jsxs("div", { className: gt.createItem, children: [
- /* @__PURE__ */ w.jsx("span", { className: gt.createLabel, children: t.t("toolbar.table.colCount") }),
- /* @__PURE__ */ w.jsx(
- An,
- {
- min: 1,
- max: 20,
- precision: 0,
- value: r,
- onChange: (c) => {
- a(o, c);
- },
- className: gt.createInput
- }
- )
- ] })
- ] });
- };
- var wh = Object.defineProperty, Nh = Object.getOwnPropertyDescriptor, Qh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Nh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && wh(e, t, s), s;
- }, ii = (n, e) => (t, o) => e(t, o, n);
- let zn = class extends ue {
- constructor(n, e) {
- super(), this._commandService = n, this._componentManager = e, this._initialize();
- }
- _initialize() {
- this._init(), this._registerCommands(), this._initCustomComponents();
- }
- _registerCommands() {
- [
- sr
- ].forEach((n) => this.disposeWithMe(this._commandService.registerCommand(n)));
- }
- _initCustomComponents() {
- const n = this._componentManager;
- this.disposeWithMe(n.register(Ca, Dh));
- }
- _init() {
- }
- };
- zn = Qh([
- ii(0, y),
- ii(1, z(io))
- ], zn);
- const ai = 4;
- var Uh = Object.defineProperty, Lh = Object.getOwnPropertyDescriptor, Fh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Lh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Uh(e, t, s), s;
- }, bn = (n, e) => (t, o) => e(t, o, n);
- function wa(n, e) {
- const t = ci(n.left, n.top, e), o = ci(n.right, n.bottom, e);
- return {
- left: t.x,
- top: t.y,
- right: o.x,
- bottom: o.y
- };
- }
- function ci(n, e, t) {
- const { scaleX: o, scaleY: s } = t.getAncestorScale(), r = t.getViewport(Xe.VIEW_MAIN);
- if (!r)
- return {
- x: n,
- y: e
- };
- const { viewportScrollX: i, viewportScrollY: a } = r, c = (n - i) * o, A = (e - a) * s;
- return {
- x: c,
- y: A
- };
- }
- function Ai(n, e, t) {
- const { scaleX: o, scaleY: s } = t.getAncestorScale(), r = t.getViewport(Xe.VIEW_MAIN);
- if (!r)
- return {
- x: n,
- y: e
- };
- const { viewportScrollX: i, viewportScrollY: a } = r, c = n / o + i, A = e / s + a;
- return {
- x: c,
- y: A
- };
- }
- const ko = (n, e) => {
- const { scene: t, mainComponent: o, engine: s } = e, r = e.with(ie).getSkeleton(), i = r.findNodePositionByCharIndex(n.startOffset, !0, n.segmentId, n.segmentPage), a = r.findNodePositionByCharIndex(n.endOffset, !0, n.segmentId, n.segmentPage), c = o;
- if (!a || !i)
- return;
- const A = c.getOffsetConfig(), { docsLeft: l, docsTop: d } = A, h = s.getCanvasElement(), u = h.getBoundingClientRect(), g = Ti(h.style.width), { top: f, left: p, width: m } = u, E = m / g, { scaleX: I, scaleY: v } = t.getAncestorScale(), R = new it(A, r), { borderBoxPointGroup: S } = R.getRangePointData(i, a);
- return Bs(S).map((O) => wa(O, t)).map((O) => ({
- left: (O.left + l * I) * E + p,
- right: (O.right + l * I) * E + p,
- top: (O.top + d * v) * E + f,
- bottom: (O.bottom + d * v) * E + f
- }));
- };
- let is = class extends ue {
- constructor(n, e, t, o) {
- super(), this._globalPopupManagerService = n, this._renderManagerService = e, this._univerInstanceService = t, this._commandService = o;
- }
- _createObjectPositionObserver(n, e) {
- const t = () => {
- const { scene: a, engine: c } = e, { left: A, top: l, width: d, height: h } = n, u = {
- left: A,
- right: A + d,
- top: l,
- bottom: l + h
- }, g = c.getCanvasElement(), f = g.getBoundingClientRect(), p = Ti(g.style.width), m = wa(u, a), { top: E, left: I, width: v } = f, R = v / p;
- return {
- left: m.left * R + I,
- right: m.right * R + I,
- top: m.top * R + E,
- bottom: m.bottom * R + E
- };
- }, o = t(), s = new Le(o), r = new Dn();
- r.add(this._commandService.onCommandExecuted((a) => {
- if (a.id === Ye.id || a.id === J.id) {
- const c = t();
- c && s.next(c);
- }
- }));
- const i = e.scene.getViewport(Xe.VIEW_MAIN);
- return i && r.add(i.onScrollAfter$.subscribeEvent(() => {
- s.next(t());
- })), {
- position: o,
- position$: s,
- disposable: r
- };
- }
- _createRangePositionObserver(n, e) {
- var i;
- const t = (i = ko(n, e)) != null ? i : [], o = new Le(t), s = new Dn();
- s.add(this._commandService.onCommandExecuted((a) => {
- if ((a.id === Ye.id || a.id === J.id) && a.params.unitId === e.unitId) {
- const A = ko(n, e);
- A && o.next(A);
- }
- }));
- const r = e.scene.getViewport(Xe.VIEW_MAIN);
- return r && s.add(r.onScrollAfter$.subscribeEvent(() => {
- const a = ko(n, e);
- a && o.next(a);
- })), {
- positions: t,
- positions$: o,
- disposable: s
- };
- }
- // #region attach to object
- /**
- * attach a popup to canvas object
- * @param targetObject target canvas object
- * @param popup popup item
- * @returns disposable
- */
- attachPopupToObject(n, e, t) {
- const o = this._renderManagerService.getRenderById(t);
- if (!o)
- throw new Error(`Current render not found, unitId: ${t}`);
- const { position: s, position$: r, disposable: i } = this._createObjectPositionObserver(n, o), a = this._globalPopupManagerService.addPopup({
- ...e,
- unitId: t,
- subUnitId: "default",
- anchorRect: s,
- anchorRect$: r,
- canvasElement: o.engine.getCanvasElement()
- });
- return {
- dispose: () => {
- this._globalPopupManagerService.removePopup(a), r.complete(), i.dispose();
- }
- };
- }
- // #endregion
- // #region attach to range
- /**
- * attach a popup to doc range
- * @param range doc range
- * @param popup popup item
- * @param unitId unit id
- * @returns disposable
- */
- attachPopupToRange(n, e, t) {
- if (!this._univerInstanceService.getUnit(t))
- throw new Error(`Document not found, unitId: ${t}`);
- const { direction: s = "top", multipleDirection: r } = e, i = this._renderManagerService.getRenderById(t);
- if (!i)
- throw new Error(`Current render not found, unitId: ${t}`);
- const { positions: a, positions$: c, disposable: A } = this._createRangePositionObserver(n, i), l = c.pipe(gn((h) => s.includes("top") ? h[0] : h[h.length - 1])), d = this._globalPopupManagerService.addPopup({
- ...e,
- unitId: t,
- subUnitId: "default",
- anchorRect: s.includes("top") ? a[0] : a[a.length - 1],
- anchorRect$: l,
- excludeRects: a,
- excludeRects$: c,
- direction: s.includes("top") || s.includes("bottom") ? a.length > 1 ? r : s : "bottom",
- canvasElement: i.engine.getCanvasElement()
- });
- return {
- dispose: () => {
- this._globalPopupManagerService.removePopup(d), c.complete(), A.dispose();
- },
- canDispose: () => this._globalPopupManagerService.activePopupId !== d
- };
- }
- // #endregion
- };
- is = Fh([
- bn(0, z(Lc)),
- bn(1, fe),
- bn(2, Q),
- bn(3, y)
- ], is);
- var Hh = Object.defineProperty, kh = Object.getOwnPropertyDescriptor, Vh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? kh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Hh(e, t, s), s;
- }, jh = (n, e) => (t, o) => e(t, o, n);
- const Wh = (n, e, t, o) => {
- var h, u, g, f, p;
- const s = t.findNodePositionByCharIndex(n.startOffset, !0, n.segmentId, o), r = t.getSkeletonData();
- let i = n.endOffset;
- if (n.segmentId) {
- const m = (p = Array.from((u = (h = r == null ? void 0 : r.skeFooters.get(n.segmentId)) == null ? void 0 : h.values()) != null ? u : [])[0]) != null ? p : Array.from((f = (g = r == null ? void 0 : r.skeHeaders.get(n.segmentId)) == null ? void 0 : g.values()) != null ? f : [])[0];
- m && (i = Math.min(m.ed, i));
- }
- const a = t.findNodePositionByCharIndex(i, !0, n.segmentId, o);
- if (!a || !s)
- return;
- const c = e.getOffsetConfig(), A = new it(c, t), { borderBoxPointGroup: l } = A.getRangePointData(s, a);
- return Bs(l).map((m) => ({
- top: m.top + c.docsTop - ai,
- bottom: m.bottom + c.docsTop + ai,
- left: m.left + c.docsLeft,
- right: m.right + c.docsLeft
- }));
- }, zh = (n, e, t, o = -1) => {
- const s = t.findPositionByGlyph(n, o);
- if (!s)
- return;
- const r = e.getOffsetConfig(), i = { ...s, isBack: !0 }, a = new it(r, t), { borderBoxPointGroup: c } = a.getRangePointData(i, i), l = Bs(c)[0];
- return {
- top: l.top + r.docsTop,
- bottom: l.bottom + r.docsTop,
- left: l.left + r.docsLeft,
- right: l.left + r.docsLeft + n.width
- };
- };
- let Gn = class extends ue {
- constructor(e, t) {
- super();
- x(this, "_hoverCustomRanges$", new Le([]));
- x(this, "hoverCustomRanges$", this._hoverCustomRanges$.pipe(vr((e, t) => e.length === t.length && e.every((o, s) => t[s].range.rangeId === o.range.rangeId && t[s].segmentId === o.segmentId && t[s].segmentPageIndex === o.segmentPageIndex && t[s].range.startIndex === o.range.startIndex))));
- x(this, "_clickCustomRanges$", new Ee());
- x(this, "clickCustomRanges$", this._clickCustomRanges$.asObservable());
- x(this, "_hoverBullet$", new Ee());
- x(this, "hoverBullet$", this._hoverBullet$.pipe(vr((e, t) => (e == null ? void 0 : e.paragraph.startIndex) === (t == null ? void 0 : t.paragraph.startIndex) && (e == null ? void 0 : e.segmentId) === (t == null ? void 0 : t.segmentId) && (e == null ? void 0 : e.segmentPageIndex) === (t == null ? void 0 : t.segmentPageIndex))));
- x(this, "_clickBullet$", new Ee());
- x(this, "clickBullets$", this._clickBullet$.asObservable());
- x(this, "_customRangeDirty", !0);
- x(this, "_bulletDirty", !0);
- /**
- * cache the bounding of custom ranges,
- * it will be updated when the doc-skeleton is recalculated
- */
- x(this, "_customRangeBounds", []);
- /**
- * cache the bounding of bullets,
- * it will be updated when the doc-skeleton is recalculated
- */
- x(this, "_bulletBounds", []);
- this._context = e, this._docSkeletonManagerService = t, this._initResetDirty(), this._initEvents(), this._initPointer();
- }
- get _skeleton() {
- return this._docSkeletonManagerService.getSkeleton();
- }
- get _documents() {
- return this._context.mainComponent;
- }
- dispose() {
- this._hoverCustomRanges$.complete(), this._clickCustomRanges$.complete(), super.dispose();
- }
- _initPointer() {
- let e = mt.TEXT;
- this.disposeWithMe(this.hoverCustomRanges$.subscribe((t) => {
- t.length ? (e = this._context.scene.getCursor(), this._context.scene.setCursor(mt.POINTER)) : this._context.scene.setCursor(e);
- }));
- }
- _initResetDirty() {
- this.disposeWithMe(this._skeleton.dirty$.subscribe(() => {
- this._customRangeDirty = !0, this._bulletDirty = !0;
- })), this.disposeWithMe(
- nn(this._context.engine.onTransformChange$).pipe(
- Qn((e) => e.type === yi.resize)
- ).subscribe(() => {
- this._customRangeDirty = !0, this._bulletDirty = !0;
- })
- );
- }
- _initEvents() {
- this.disposeWithMe(nn(this._context.scene.onPointerMove$).pipe(Hi(30)).subscribe((o) => {
- this._hoverCustomRanges$.next(
- this._calcActiveRanges(o)
- ), this._hoverBullet$.next(
- this._calcActiveBullet(o)
- );
- })), this.disposeWithMe(this._context.scene.onPointerEnter$.subscribeEvent(() => {
- this._hoverBullet$.next(null), this._hoverCustomRanges$.next([]);
- }));
- const e = nn(this._context.mainComponent.onPointerDown$), t = nn(this._context.scene.onPointerUp$);
- this.disposeWithMe(e.pipe(
- jc((o) => t.pipe(Wc(1), gn((s) => ({ down: o, up: s })))),
- Qn(({ down: o, up: s }) => o.target === s.target && s.timeStamp - o.timeStamp < 300)
- // filter(({ down, up }) => down.offsetX === up.offsetX && down.offsetY === up.offsetY)
- ).subscribe(({ down: o }) => {
- if (o.button === 2)
- return;
- const s = this._calcActiveRanges(o);
- s.length && this._clickCustomRanges$.next(s.pop());
- const r = this._calcActiveBullet(o);
- r && this._clickBullet$.next(r);
- }));
- }
- _buildCustomRangeBoundsBySegment(e, t = -1) {
- var r, i, a;
- const o = (a = (i = (r = this._context.unit.getSelfOrHeaderFooterModel(e)) == null ? void 0 : r.getBody()) == null ? void 0 : i.customRanges) != null ? a : [], s = [];
- return o.forEach((c) => {
- const A = {
- startOffset: c.startIndex,
- endOffset: c.endIndex + 1,
- collapsed: !1,
- segmentId: e
- }, l = Wh(A, this._documents, this._skeleton, t);
- if (!l)
- return null;
- s.push({
- customRange: c,
- rects: l,
- segmentId: e,
- segmentPageIndex: t
- });
- }), s;
- }
- _buildCustomRangeBounds() {
- var t;
- if (!this._customRangeDirty)
- return;
- this._customRangeDirty = !1;
- const e = [];
- e.push(...this._buildCustomRangeBoundsBySegment()), (t = this._skeleton.getSkeletonData()) == null || t.pages.forEach((o, s) => {
- o.headerId && e.push(...this._buildCustomRangeBoundsBySegment(o.headerId, s)), o.footerId && e.push(...this._buildCustomRangeBoundsBySegment(o.footerId, s));
- }), this._customRangeBounds = e;
- }
- _calcActiveRanges(e) {
- this._buildCustomRangeBounds();
- const { offsetX: t, offsetY: o } = e, { x: s, y: r } = Ai(t, o, this._context.scene);
- return this._customRangeBounds.filter((a) => a.rects.some((c) => {
- const { left: A, right: l, top: d, bottom: h } = c;
- return s >= A && s <= l && r >= d && r <= h;
- })).map(
- (a) => ({
- segmentId: a.segmentId,
- range: a.customRange,
- segmentPageIndex: a.segmentPageIndex,
- rects: a.rects
- })
- );
- }
- _buildBulletBoundsBySegment(e, t = -1) {
- var c, A, l, d, h;
- const o = (c = this._context.unit.getSelfOrHeaderFooterModel(e)) == null ? void 0 : c.getBody(), s = ((A = o == null ? void 0 : o.paragraphs) != null ? A : []).filter((u) => u.bullet && u.bullet.listType.indexOf("CHECK_LIST") === 0), r = [], i = this._skeleton.getSkeletonData();
- if (!i)
- return r;
- const a = (u) => {
- var g, f, p;
- for (const m of u) {
- const E = [...m.sections];
- if (m.skeTables) {
- const I = Array.from(m.skeTables.values());
- E.push(...I.map((v) => v.rows.map((R) => R.cells.map((S) => S.sections))).flat(4));
- }
- for (const I of E)
- for (const v of I.columns)
- for (const R of v.lines)
- if (R.paragraphStart) {
- const S = s.find((C) => C.startIndex === R.paragraphIndex);
- if (S) {
- const C = R, T = (p = (f = (g = C == null ? void 0 : C.divides) == null ? void 0 : g[0]) == null ? void 0 : f.glyphGroup) == null ? void 0 : p[0];
- if (!T)
- continue;
- const O = zh(T, this._documents, this._skeleton, t);
- if (!O)
- continue;
- r.push({
- rect: O,
- segmentId: e,
- segmentPageIndex: t,
- paragraph: S
- });
- }
- }
- }
- return r;
- };
- if (e) {
- const u = (h = (l = i.skeFooters.get(e)) == null ? void 0 : l.values()) != null ? h : (d = i.skeHeaders.get(e)) == null ? void 0 : d.values();
- return u ? a(Array.from(u)) : r;
- }
- return a(i.pages);
- }
- _buildBulletBounds() {
- var e;
- this._bulletDirty && (this._bulletDirty = !1, this._bulletBounds = [], this._bulletBounds.push(...this._buildBulletBoundsBySegment()), (e = this._skeleton.getSkeletonData()) == null || e.pages.forEach((t, o) => {
- t.headerId && this._bulletBounds.push(...this._buildBulletBoundsBySegment(t.headerId, o)), t.footerId && this._bulletBounds.push(...this._buildBulletBoundsBySegment(t.footerId, o));
- }));
- }
- _calcActiveBullet(e) {
- this._buildBulletBounds();
- const { offsetX: t, offsetY: o } = e, { x: s, y: r } = Ai(t, o, this._context.scene);
- return this._bulletBounds.find((a) => {
- const { left: c, right: A, top: l, bottom: d } = a.rect;
- return s >= c && s <= A && r >= l && r <= d;
- });
- }
- };
- Gn = Vh([
- jh(1, z(ie))
- ], Gn);
- var Gh = Object.defineProperty, Yh = Object.getOwnPropertyDescriptor, qh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Yh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Gh(e, t, s), s;
- }, xn = (n, e) => (t, o) => e(t, o, n);
- let as = class extends ue {
- constructor(n, e, t, o, s) {
- super(), this._context = n, this._docSkeletonManagerService = e, this._commandService = t, this._docEventManagerService = o, this._textSelectionManagerService = s, this._initPointerDownObserver(), this._initHoverCursor();
- }
- _initPointerDownObserver() {
- this._docEventManagerService.clickBullets$.subscribe((n) => {
- const e = this._textSelectionManagerService.getTextRanges();
- this._commandService.executeCommand(Ns.id, {
- index: n.paragraph.startIndex,
- segmentId: n.segmentId,
- textRanges: e
- });
- });
- }
- _initHoverCursor() {
- this.disposeWithMe(
- this._docEventManagerService.hoverBullet$.subscribe((n) => {
- n ? this._context.mainComponent.setCursor(mt.POINTER) : this._context.mainComponent.setCursor(mt.TEXT);
- })
- );
- }
- _getTransformCoordForDocumentOffset(n, e, t, o) {
- const { documentTransform: s } = n.getOffsetConfig(), r = e.transformVector2SceneCoord(rn.FromArray([t, o]));
- if (r)
- return s.clone().invert().applyPoint(r);
- }
- };
- as = qh([
- xn(1, z(ie)),
- xn(2, y),
- xn(3, z(Gn)),
- xn(4, z(G))
- ], as);
- var Kh = Object.defineProperty, Xh = Object.getOwnPropertyDescriptor, Jh = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Xh(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Kh(e, t, s), s;
- }, Zt = (n, e) => (t, o) => e(t, o, n);
- let Yn = class extends At {
- constructor(n, e, t, o, s, r) {
- super(), this._context = n, this._commandService = e, this._docClipboardService = t, this._docSelectionRenderService = o, this._contextService = s, this._editorService = r, this._init();
- }
- _init() {
- this._initLegacyPasteCommand();
- }
- _initLegacyPasteCommand() {
- var n;
- (n = this._docSelectionRenderService) == null || n.onPaste$.pipe(st(this.dispose$)).subscribe((e) => {
- var c, A, l;
- if (!Io(this._contextService))
- return;
- e.event.preventDefault();
- const t = e.event;
- let o = (c = t.clipboardData) == null ? void 0 : c.getData(Ni);
- const s = (A = t.clipboardData) == null ? void 0 : A.getData(Qi), r = [
- wi,
- Di,
- Pi,
- _i
- ], i = [...((l = t.clipboardData) == null ? void 0 : l.items) || []].filter((d) => r.includes(d.type)).map((d) => d.getAsFile()).filter((d) => !!d);
- this._editorService.getEditor(this._context.unitId) && (o != null ? o : "").indexOf("</table>") > -1 && (o = ""), this._docClipboardService.legacyPaste({ html: o, text: s, files: i });
- });
- }
- };
- Yn = Jh([
- Zt(1, y),
- Zt(2, Sn),
- Zt(3, z(Se)),
- Zt(4, ms),
- Zt(5, He)
- ], Yn);
- var Zh = Object.defineProperty, $h = Object.getOwnPropertyDescriptor, eg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? $h(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Zh(e, t, s), s;
- }, li = (n, e) => (t, o) => e(t, o, n);
- const tg = [
- pi,
- ec,
- vs,
- $e
- ];
- let cs = class extends ue {
- constructor(n, e, t) {
- super(), this._context = n, this._contextMenuService = e, this._commandService = t, tg.includes(this._context.unitId) || (this._initPointerDown(), this._initEditChange());
- }
- _initPointerDown() {
- var t, o;
- const e = ((o = (t = this._context) == null ? void 0 : t.mainComponent) == null ? void 0 : o.onPointerDown$).subscribeEvent((s) => {
- s.button === 2 && this._contextMenuService.triggerContextMenu(s, Ui.MAIN_AREA);
- });
- this.disposeWithMe(e);
- }
- _initEditChange() {
- this.disposeWithMe(
- this._commandService.onCommandExecuted((n) => {
- n.id === J.id && this._contextMenuService.visible && this._contextMenuService.hideContextMenu();
- })
- );
- }
- };
- cs = eg([
- li(1, Fc),
- li(2, y)
- ], cs);
- var ng = Object.defineProperty, og = Object.getOwnPropertyDescriptor, sg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? og(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && ng(e, t, s), s;
- }, xt = (n, e) => (t, o) => e(t, o, n);
- let qn = class extends ue {
- constructor(e, t, o, s, r, i, a) {
- super();
- x(this, "_initialEditors", /* @__PURE__ */ new Set());
- this._context = e, this._univerInstanceService = t, this._editorService = o, this._commandService = s, this._docSelectionRenderService = r, this._docSkeletonManagerService = i, this._renderManagerService = a, this._initialize();
- }
- _initialize() {
- this._editorService.getAllEditor().forEach((e) => {
- const t = e.getEditorId();
- t === this._context.unitId && (this._initialEditors.has(t) || (this._initialEditors.add(t), this._resize(t)));
- }), this._commandExecutedListener(), this._initialBlur(), this._initialFocus();
- }
- _resize(e) {
- if (e == null)
- return;
- const t = this._editorService.getEditor(e);
- if ((t == null ? void 0 : t.cancelDefaultResizeListener) === !0)
- return;
- const o = this._univerInstanceService.getUniverDocInstance(e);
- if (!o)
- return;
- const s = this._docSkeletonManagerService.getSkeleton();
- if (t == null || t.render == null || s == null || o == null)
- return;
- s.calculate();
- const { marginTop: r = 0, marginBottom: i = 0, marginLeft: a = 0, marginRight: c = 0 } = o.getSnapshot().documentStyle, { scene: A, mainComponent: l } = t.render;
- let { actualHeight: d, actualWidth: h } = s.getActualSize();
- d += r + i, h += a + c;
- const { width: u, height: g } = t.getBoundingClientRect(), f = Math.max(h, u), p = Math.max(d, g);
- A.transformByState({
- width: f,
- height: p
- }), l == null || l.resize(f, p);
- }
- _initialBlur() {
- this.disposeWithMe(
- this._editorService.blur$.subscribe(() => {
- this._docSelectionRenderService.blur();
- })
- ), this.disposeWithMe(
- this._docSelectionRenderService.onBlur$.subscribe(() => {
- const { unitId: e } = this._context, t = this._editorService.getEditor(e), o = this._editorService.getFocusEditor();
- t == null || t.isSheetEditor() || o && o.getEditorId() === e || e.includes("range_selector") || e.includes("embedding_formula_editor") || this._editorService.blur();
- })
- );
- }
- _initialFocus() {
- const e = [
- "univer-formula-search",
- "univer-formula-help",
- "formula-help-decorator",
- "univer-formula-help-param"
- ];
- this.disposeWithMe(
- Ue(window, "mousedown").subscribe((o) => {
- const r = o.target.classList[0] || "";
- tc(r, e) && o.stopPropagation();
- })
- ), this._univerInstanceService.getAllUnitsForType(_.UNIVER_SHEET).forEach((o) => {
- const s = o.getUnitId(), r = this._renderManagerService.getRenderById(s), i = r == null ? void 0 : r.engine.getCanvas().getCanvasEle();
- i != null && Ue(i, "mousedown").subscribe((a) => {
- a.stopPropagation();
- });
- });
- }
- /**
- * Listen to document edits to refresh the size of the formula editor.
- */
- _commandExecutedListener() {
- const e = [J.id];
- this.disposeWithMe(
- this._commandService.onCommandExecuted((t) => {
- if (e.includes(t.id)) {
- const o = t.params, { unitId: s } = o;
- if (this._editorService.isSheetEditor(s) || s !== this._context.unitId)
- return;
- const r = this._editorService.getEditor(s);
- r && !r.params.scrollBar && this._resize(s);
- }
- })
- );
- }
- };
- qn = sg([
- xt(1, Q),
- xt(2, He),
- xt(3, y),
- xt(4, z(Se)),
- xt(5, z(ie)),
- xt(6, fe)
- ], qn);
- var rg = Object.defineProperty, ig = Object.getOwnPropertyDescriptor, ag = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? ig(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && rg(e, t, s), s;
- }, On = (n, e) => (t, o) => e(t, o, n);
- let As = class extends ue {
- constructor(e, t, o, s, r) {
- super();
- x(this, "_previousIMEContent", "");
- x(this, "_isCompositionStart", !0);
- x(this, "_onStartSubscription");
- x(this, "_onUpdateSubscription");
- x(this, "_onEndSubscription");
- this._context = e, this._docSelectionRenderService = t, this._docImeInputManagerService = o, this._docSkeletonManagerService = s, this._commandService = r, this._initialize();
- }
- dispose() {
- var e, t, o;
- (e = this._onStartSubscription) == null || e.unsubscribe(), (t = this._onUpdateSubscription) == null || t.unsubscribe(), (o = this._onEndSubscription) == null || o.unsubscribe();
- }
- _initialize() {
- this._initialOnCompositionstart(), this._initialOnCompositionUpdate(), this._initialOnCompositionend();
- }
- _initialOnCompositionstart() {
- this._onStartSubscription = this._docSelectionRenderService.onCompositionstart$.subscribe((e) => {
- if (e == null)
- return;
- this._resetIME();
- const { activeRange: t } = e;
- t != null && this._docImeInputManagerService.setActiveRange(X.deepClone(t));
- });
- }
- _initialOnCompositionUpdate() {
- this._onUpdateSubscription = this._docSelectionRenderService.onCompositionupdate$.subscribe((e) => {
- this._updateContent(e, !0);
- });
- }
- _initialOnCompositionend() {
- this._onEndSubscription = this._docSelectionRenderService.onCompositionend$.subscribe((e) => {
- this._updateContent(e, !1);
- });
- }
- async _updateContent(e, t) {
- if (e == null)
- return;
- const o = this._context.unitId, s = this._docSkeletonManagerService.getSkeleton(), { event: r, activeRange: i } = e;
- if (s == null || i == null)
- return;
- const c = r.data;
- c === this._previousIMEContent && t || (await this._commandService.executeCommand(Ba.id, {
- unitId: o,
- newText: c,
- oldTextLen: this._previousIMEContent.length,
- isCompositionStart: this._isCompositionStart,
- isCompositionEnd: !t
- }), t ? (this._isCompositionStart && (this._isCompositionStart = !1), this._previousIMEContent = c) : this._resetIME());
- }
- _resetIME() {
- this._previousIMEContent = "", this._isCompositionStart = !0, this._docImeInputManagerService.clearUndoRedoMutationParamsCache(), this._docImeInputManagerService.setActiveRange(null);
- }
- };
- As = ag([
- On(1, z(Se)),
- On(2, z(Ro)),
- On(3, z(ie)),
- On(4, y)
- ], As);
- var cg = Object.defineProperty, Ag = Object.getOwnPropertyDescriptor, lg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Ag(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && cg(e, t, s), s;
- }, Tn = (n, e) => (t, o) => e(t, o, n);
- let ls = class extends ue {
- constructor(e, t, o, s, r) {
- super();
- x(this, "_onInputSubscription");
- this._context = e, this._docSelectionRenderService = t, this._docSkeletonManagerService = o, this._commandService = s, this._docMenuStyleService = r, this._init();
- }
- dispose() {
- var e;
- super.dispose(), (e = this._onInputSubscription) == null || e.unsubscribe();
- }
- _init() {
- this._initialNormalInput();
- }
- _initialNormalInput() {
- this._onInputSubscription = this._docSelectionRenderService.onInput$.subscribe(async (e) => {
- var p, m, E;
- if (e == null)
- return;
- const { unitId: t } = this._context, { event: o, content: s = "", activeRange: r } = e, i = o, a = this._docSkeletonManagerService.getSkeleton();
- if (i.data == null || a == null || r == null)
- return;
- const { segmentId: c } = r, l = this._context.unit.getSelfOrHeaderFooterModel(c).getBody(), d = this._docMenuStyleService.getDefaultStyle(), h = this._docMenuStyleService.getStyleCache(), u = Os((p = l == null ? void 0 : l.customRanges) != null ? p : [], r.endOffset, Is.includes(t)), g = co((m = l == null ? void 0 : l.textRuns) != null ? m : [], r.endOffset, d, h), f = Ts((E = l == null ? void 0 : l.customDecorations) != null ? E : [], r.endOffset);
- await this._commandService.executeCommand(Vs.id, {
- unitId: t,
- body: {
- dataStream: s,
- textRuns: g ? [
- {
- ...g,
- st: 0,
- ed: s.length
- }
- ] : [],
- customRanges: u ? [{
- ...u,
- startIndex: 0,
- endIndex: s.length - 1
- }] : [],
- customDecorations: f.map((I) => ({
- ...I,
- startIndex: 0,
- endIndex: s.length - 1
- }))
- },
- range: r,
- segmentId: c
- }), s === " " && await this._commandService.executeCommand(Ao.id);
- });
- }
- };
- ls = lg([
- Tn(1, z(Se)),
- Tn(2, z(ie)),
- Tn(3, y),
- Tn(4, z(Je))
- ], ls);
- class ar extends ue {
- constructor(e) {
- super(), this._context = e;
- }
- calculatePagePosition() {
- var v, R;
- const e = rt(this._context), o = (R = (v = this._context.unit.getSettings()) == null ? void 0 : v.zoomRatio) != null ? R : 1, { document: s, scene: r, docBackground: i } = e, a = r == null ? void 0 : r.getParent(), { width: c, height: A, pageMarginLeft: l, pageMarginTop: d } = s;
- if (a == null || c === Number.POSITIVE_INFINITY || A === Number.POSITIVE_INFINITY)
- return;
- const { width: h, height: u } = a;
- let g = 0, f = d, p = 0, m = 0, E = Number.POSITIVE_INFINITY;
- h > (c + l * 2) * o ? (g = h / 2 - c * o / 2, g /= o, p = (h - l * 2) / o, E = 0) : (g = l, p = c + l * 2, E = (p - h / o) / 2), u > A ? m = (u - d * 2) / o : m = A + d * 2, r.resize(p, m), h <= 1 && (g = -1e4, f = -1e4), s.translate(g, f), i.translate(g, f);
- const I = r.getViewport(Xe.VIEW_MAIN);
- return E !== Number.POSITIVE_INFINITY && I != null && I.scrollToViewportPos({
- viewportScrollX: E
- }), this;
- }
- }
- var dg = Object.defineProperty, ug = Object.getOwnPropertyDescriptor, hg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? ug(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && dg(e, t, s), s;
- }, di = (n, e) => (t, o) => e(t, o, n);
- let ds = class extends ue {
- constructor(n, e, t) {
- super(), this._context = n, this._docPageLayoutService = e, this._textSelectionManagerService = t;
- const o = this._context.unitId;
- if (to(o) && o !== $e) return this;
- this._initResize();
- }
- _initResize() {
- this.disposeWithMe(
- nn(this._context.engine.onTransformChange$).pipe(
- Qn((n) => n.type === yi.resize),
- Hi(0, zc)
- ).subscribe(() => {
- this._docPageLayoutService.calculatePagePosition(), this._textSelectionManagerService.refreshSelection();
- })
- );
- }
- };
- ds = hg([
- di(1, z(ar)),
- di(2, z(G))
- ], ds);
- var gg = Object.defineProperty, fg = Object.getOwnPropertyDescriptor, pg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? fg(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && gg(e, t, s), s;
- }, Ot = (n, e) => (t, o) => e(t, o, n);
- let us = class extends ue {
- constructor(e, t, o, s, r, i, a) {
- super();
- x(this, "_loadedMap", /* @__PURE__ */ new WeakSet());
- this._context = e, this._commandService = t, this._editorService = o, this._instanceSrv = s, this._docSelectionRenderService = r, this._docSkeletonManagerService = i, this._docSelectionManagerService = a, this._initialize();
- }
- _initialize() {
- this._init(), this._skeletonListener(), this._commandExecutedListener(), this._refreshListener(), this._syncSelection();
- }
- _init() {
- const { unitId: e } = this._context, t = rt(this._context);
- t == null || t.document == null || this._loadedMap.has(t.document) || (this._initialMain(e), this._loadedMap.add(t.document));
- }
- _refreshListener() {
- this.disposeWithMe(
- this._docSelectionManagerService.refreshSelection$.subscribe((e) => {
- if (e == null)
- return;
- const { unitId: t, docRanges: o, isEditing: s, options: r } = e;
- t === this._context.unitId && (this._docSelectionRenderService.removeAllRanges(), this._docSelectionRenderService.addDocRanges(o, s, r));
- })
- );
- }
- _syncSelection() {
- this.disposeWithMe(
- this._docSelectionRenderService.textSelectionInner$.subscribe((e) => {
- e != null && this._docSelectionManagerService.__replaceTextRangesWithNoRefresh(e, {
- unitId: this._context.unitId,
- subUnitId: this._context.unitId
- });
- })
- );
- }
- // eslint-disable-next-line max-lines-per-function
- _initialMain(e) {
- const t = rt(this._context), { document: o, scene: s } = t;
- this.disposeWithMe(o.onPointerEnter$.subscribeEvent(() => {
- this._isEditorReadOnly(e) || (o.cursor = mt.TEXT);
- })), this.disposeWithMe(o.onPointerLeave$.subscribeEvent(() => {
- o.cursor = mt.DEFAULT, s.resetCursor();
- })), this.disposeWithMe(o.onPointerDown$.subscribeEvent((r, i) => {
- if (this._isEditorReadOnly(e))
- return;
- const a = this._instanceSrv.getCurrentUnitForType(_.UNIVER_DOC);
- (a == null ? void 0 : a.getUnitId()) !== e && this._instanceSrv.setCurrentUnitForType(e);
- const c = this._docSkeletonManagerService.getSkeleton(), { offsetX: A, offsetY: l } = r, d = this._getTransformCoordForDocumentOffset(A, l);
- if (d != null) {
- const {
- pageLayoutType: h = an.VERTICAL,
- pageMarginLeft: u,
- pageMarginTop: g
- } = o.getOffsetConfig(), { editArea: f } = c.findEditAreaByCoord(
- d,
- h,
- u,
- g
- ), p = this._docSkeletonManagerService.getViewModel(), m = p.getEditArea();
- m !== ge.BODY && f !== ge.BODY && f !== m && p.setEditArea(f);
- }
- if (this._docSelectionRenderService.__onPointDown(r), this._editorService.getEditor(e)) {
- this._setEditorFocus(e);
- const { offsetX: h, offsetY: u } = r;
- setTimeout(() => {
- e !== this._editorService.getFocusId() && (this._setEditorFocus(e), this._docSelectionRenderService.setCursorManually(h, u));
- }, 0);
- }
- r.button !== 2 && i.stopPropagation();
- })), this.disposeWithMe(o.onDblclick$.subscribeEvent((r) => {
- this._isEditorReadOnly(e) || this._docSelectionRenderService.__handleDblClick(r);
- })), this.disposeWithMe(o.onTripleClick$.subscribeEvent((r) => {
- this._isEditorReadOnly(e) || this._docSelectionRenderService.__handleTripleClick(r);
- }));
- }
- _getTransformCoordForDocumentOffset(e, t) {
- const o = rt(this._context), { document: s, scene: r } = o, { documentTransform: i } = s.getOffsetConfig(), a = r.getViewports()[0];
- if (a == null)
- return;
- const c = a.transformVector2SceneCoord(rn.FromArray([e, t]));
- return i.clone().invert().applyPoint(c);
- }
- _isEditorReadOnly(e) {
- const t = this._editorService.getEditor(e);
- return t ? t.isReadOnly() : !1;
- }
- _setEditorFocus(e) {
- this._editorService.focus(e);
- }
- _commandExecutedListener() {
- const e = [Ye.id];
- this.disposeWithMe(
- this._commandService.onCommandExecuted((t) => {
- var o;
- if (e.includes(t.id)) {
- const s = t.params, { unitId: r } = s, i = (o = this._docSelectionManagerService.__getCurrentSelection()) == null ? void 0 : o.unitId;
- if (r !== i)
- return;
- this._docSelectionManagerService.refreshSelection();
- }
- })
- );
- }
- _skeletonListener() {
- this.disposeWithMe(this._docSkeletonManagerService.currentSkeleton$.subscribe((e) => {
- if (!e) return;
- const { unitId: t } = this._context;
- if (!to(t)) {
- this._docSelectionRenderService.focus();
- const r = this._context.unit.getSnapshot(), i = ea(r);
- this._docSelectionManagerService.replaceDocRanges([
- {
- startOffset: i,
- endOffset: i
- }
- ], {
- unitId: t,
- subUnitId: t
- }, !1);
- }
- }));
- }
- };
- us = pg([
- Ot(1, y),
- Ot(2, He),
- Ot(3, Q),
- Ot(4, z(Se)),
- Ot(5, z(ie)),
- Ot(6, z(G))
- ], us);
- var mg = Object.defineProperty, Eg = Object.getOwnPropertyDescriptor, Sg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Eg(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && mg(e, t, s), s;
- }, ft = (n, e) => (t, o) => e(t, o, n);
- let hs = class extends ue {
- constructor(n, e, t, o, s, r, i, a) {
- super(), this._context = n, this._contextService = e, this._docSkeletonManagerService = t, this._univerInstanceService = o, this._commandService = s, this._textSelectionManagerService = r, this._editorService = i, this._docPageLayoutService = a, this._initSkeletonListener(), this._initCommandExecutedListener(), this._initRenderRefresher(), setTimeout(() => this.updateViewZoom(1, !0), 20);
- }
- _initRenderRefresher() {
- this._docSkeletonManagerService.currentSkeleton$.subscribe((n) => {
- if (n == null)
- return;
- const { unitId: e, scene: t } = this._context;
- this._editorService.isEditor(e) || this.disposeWithMe(t.onMouseWheel$.subscribeEvent((o) => {
- if (!o.ctrlKey || !this._contextService.getContextValue(hn))
- return;
- const s = this._univerInstanceService.getCurrentUniverDocInstance();
- if (!s)
- return;
- const { documentFlavor: r } = s.getSnapshot().documentStyle;
- if (r === ye.MODERN)
- return;
- const i = Math.abs(o.deltaX);
- let a = i < 40 ? 0.2 : i < 80 ? 0.4 : 0.2;
- a *= o.deltaY > 0 ? -1 : 1, t.scaleX < 1 && (a /= 2);
- const c = s.zoomRatio;
- let A = +Number.parseFloat(`${c + a}`).toFixed(1);
- A = A >= 4 ? 4 : A <= 0.1 ? 0.1 : A, this._commandService.executeCommand(ss.id, {
- zoomRatio: A,
- unitId: s.getUnitId()
- }), o.preventDefault();
- }));
- });
- }
- _initSkeletonListener() {
- this.disposeWithMe(this._docSkeletonManagerService.currentSkeleton$.subscribe((n) => {
- if (n == null)
- return;
- const e = this._univerInstanceService.getCurrentUniverDocInstance();
- if (!e) return;
- const t = e.zoomRatio || 1;
- this.updateViewZoom(t, !1);
- }));
- }
- _initCommandExecutedListener() {
- const n = [Ye.id];
- this.disposeWithMe(this._commandService.onCommandExecuted((e) => {
- if (n.includes(e.id) && e.params.unitId === this._context.unitId) {
- const o = this._context.unit.zoomRatio || 1;
- this.updateViewZoom(o);
- }
- })), this.disposeWithMe(
- this._commandService.beforeCommandExecuted((e) => {
- e.id === Co.id && this._commandService.executeCommand(ss.id, {
- zoomRatio: 1,
- unitId: this._context.unitId
- });
- })
- );
- }
- updateViewZoom(n, e = !0) {
- var o;
- const t = rt(this._context);
- t.scene.scale(n, n), this._editorService.isEditor(this._context.unitId) || this._docPageLayoutService.calculatePagePosition(), e && !this._editorService.isEditor(this._context.unitId) && this._textSelectionManagerService.refreshSelection(), (o = t.scene.getTransformer()) == null || o.clearSelectedObjects();
- }
- };
- hs = Sg([
- ft(1, ms),
- ft(2, z(ie)),
- ft(3, Q),
- ft(4, y),
- ft(5, z(G)),
- ft(6, He),
- ft(7, z(ar))
- ], hs);
- var Ig = Object.defineProperty, Cg = Object.getOwnPropertyDescriptor, vg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Cg(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Ig(e, t, s), s;
- }, $t = (n, e) => (t, o) => e(t, o, n);
- const ui = 300;
- let Kn = class extends At {
- constructor(e, t, o, s, r) {
- super();
- x(this, "_docStateChange$", new Le(null));
- x(this, "docStateChange$", this._docStateChange$.asObservable());
- // This cache used for history compose.
- x(this, "_historyStateCache", /* @__PURE__ */ new Map());
- // This cache used for collaboration state compose.
- x(this, "_changeStateCache", /* @__PURE__ */ new Map());
- x(this, "_historyTimer", null);
- x(this, "_changeStateCacheTimer", null);
- this._undoRedoService = e, this._commandService = t, this._univerInstanceService = o, this._docStateEmitService = s, this._renderManagerService = r, this._initialize(), this._listenDocStateChange();
- }
- getStateCache(e) {
- var t, o;
- return {
- history: (t = this._historyStateCache.get(e)) != null ? t : [],
- collaboration: (o = this._changeStateCache.get(e)) != null ? o : []
- };
- }
- setStateCache(e, t) {
- this._historyStateCache.set(e, t.history), this._changeStateCache.set(e, t.collaboration);
- }
- _setChangeState(e) {
- this._cacheChangeState(e, "history"), this._cacheChangeState(e, "collaboration");
- }
- _initialize() {
- this.disposeWithMe(
- this._commandService.beforeCommandExecuted((e) => {
- if (e.id === hr || e.id === gr) {
- const t = this._univerInstanceService.getCurrentUniverDocInstance();
- if (t == null)
- return;
- const o = t.getUnitId();
- this._pushHistory(o), this._emitChangeState(o);
- }
- })
- );
- }
- _listenDocStateChange() {
- this._docStateEmitService.docStateChangeParams$.pipe(st(this.dispose$)).subscribe((e) => {
- var a;
- if (e == null)
- return;
- const { isCompositionEnd: t, isSync: o, syncer: s, ...r } = e, i = (a = this._renderManagerService.getRenderById(o ? s : e.unitId)) == null ? void 0 : a.with(Ro);
- if (i != null) {
- if (t) {
- const c = i.fetchComposedUndoRedoMutationParams();
- if (c == null)
- throw new Error("historyParams is null in RichTextEditingMutation");
- const { undoMutationParams: A, redoMutationParams: l, previousActiveRange: d } = c;
- r.redoState.actions = l.actions, r.undoState.actions = A.actions, r.undoState.textRanges = [d];
- }
- this._setChangeState(r);
- }
- });
- }
- _cacheChangeState(e, t = "history") {
- const { trigger: o, unitId: s, noHistory: r, debounce: i = !1 } = e;
- if (r || o == null || t === "history" && (o === gr || o === hr))
- return;
- const a = t === "history" ? this._historyStateCache : this._changeStateCache, c = t === "history" ? this._pushHistory.bind(this) : this._emitChangeState.bind(this);
- if (a.has(s)) {
- const A = a.get(s);
- A == null || A.push(e);
- } else
- a.set(s, [e]);
- i ? t === "history" ? (this._historyTimer && clearTimeout(this._historyTimer), this._historyTimer = setTimeout(() => {
- c(s);
- }, ui)) : (this._changeStateCacheTimer && clearTimeout(this._changeStateCacheTimer), this._changeStateCacheTimer = setTimeout(() => {
- c(s);
- }, ui)) : c(s);
- }
- _pushHistory(e) {
- const t = this._undoRedoService, o = this._historyStateCache.get(e);
- if (!Array.isArray(o) || o.length === 0)
- return;
- const s = o.length, r = o[0].commandId, i = o[0], a = o[s - 1], c = {
- unitId: e,
- actions: o.reduce((l, d) => k.compose(l, d.redoState.actions), null),
- textRanges: a.redoState.textRanges
- }, A = {
- unitId: e,
- // Always need to put undoParams after redoParams, because `reverse` will change the `cacheStates` order.
- actions: o.reverse().reduce((l, d) => k.compose(l, d.undoState.actions), null),
- textRanges: i.undoState.textRanges
- };
- t.pushUndoRedo({
- unitID: e,
- undoMutations: [{ id: r, params: A }],
- redoMutations: [{ id: r, params: c }]
- }), o.length = 0;
- }
- _emitChangeState(e) {
- const t = this._changeStateCache.get(e);
- if (!Array.isArray(t) || t.length === 0)
- return;
- const o = t.length, { commandId: s, trigger: r, segmentId: i, noHistory: a, debounce: c } = t[0], A = t[0], l = t[o - 1], d = {
- unitId: e,
- actions: t.reduce((g, f) => k.compose(g, f.redoState.actions), null),
- textRanges: l.redoState.textRanges
- }, h = {
- unitId: e,
- // Always need to put undoParams after redoParams, because `reverse` will change the `cacheStates` order.
- actions: t.reverse().reduce((g, f) => k.compose(g, f.undoState.actions), null),
- textRanges: A.undoState.textRanges
- }, u = {
- commandId: s,
- unitId: e,
- trigger: r,
- redoState: d,
- undoState: h,
- segmentId: i,
- noHistory: a,
- debounce: c
- };
- t.length = 0, this._docStateChange$.next(u);
- }
- };
- Kn = vg([
- $t(0, z(eo)),
- $t(1, y),
- $t(2, Q),
- $t(3, z(ic)),
- $t(4, fe)
- ], Kn);
- var Rg = Object.defineProperty, bg = Object.getOwnPropertyDescriptor, xg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? bg(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Rg(e, t, s), s;
- }, hi = (n, e) => (t, o) => e(t, o, n);
- const gi = "univer-doc-main-canvas";
- let Xn = class extends At {
- constructor(n, e) {
- super(), this._instanceSrv = n, this._renderManagerService = e, this._init();
- }
- _init() {
- this._renderManagerService.createRender$.pipe(st(this.dispose$)).subscribe((n) => this._createRenderWithId(n)), this._instanceSrv.getAllUnitsForType(_.UNIVER_DOC).forEach((n) => this._createRenderer(n)), this._instanceSrv.getTypeOfUnitAdded$(_.UNIVER_DOC).pipe(st(this.dispose$)).subscribe((n) => this._createRenderer(n)), this._instanceSrv.getTypeOfUnitDisposed$(_.UNIVER_DOC).pipe(st(this.dispose$)).subscribe((n) => this._disposeRenderer(n));
- }
- _createRenderer(n) {
- var o;
- const e = n.getUnitId(), t = (o = this._instanceSrv.getCurrentUnitForType(_.UNIVER_DOC)) == null ? void 0 : o.getUnitId();
- this._renderManagerService.created$.subscribe((s) => {
- s.unitId === t && (s.engine.getCanvas().setId(gi), s.engine.getCanvas().getContext().setId(gi));
- }), this._renderManagerService.has(e) || (this._createRenderWithId(e), this._renderManagerService.setCurrent(e));
- }
- _createRenderWithId(n) {
- this._renderManagerService.createRender(n);
- }
- _disposeRenderer(n) {
- const e = n.getUnitId();
- this._renderManagerService.removeRender(e);
- }
- };
- Xn = xg([
- hi(0, Q),
- hi(1, fe)
- ], Xn);
- class Og extends ue {
- constructor() {
- super(...arguments);
- x(this, "_currentSelectorId");
- x(this, "_selectionChange$", new Ee());
- x(this, "selectionChange$", this._selectionChange$.asObservable());
- x(this, "_openSelector$", new Ee());
- x(this, "openSelector$", this._openSelector$.asObservable());
- x(this, "_selectorModalVisible$", new Le(!1));
- x(this, "selectorModalVisible$", this._selectorModalVisible$.asObservable());
- }
- get selectorModalVisible() {
- return this._selectorModalVisible$.getValue();
- }
- setCurrentSelectorId(t) {
- this._currentSelectorId = t;
- }
- getCurrentSelectorId() {
- return this._currentSelectorId;
- }
- selectionChange(t) {
- this._currentSelectorId && this._selectionChange$.next(t);
- }
- openSelector() {
- this._openSelector$.next(null);
- }
- triggerModalVisibleChange(t) {
- this._selectorModalVisible$.next(t);
- }
- }
- const Tg = ps(
- "univer.range-selector.service"
- ), yg = {
- id: ln.id,
- preconditions: bl,
- binding: j.ENTER
- }, Bg = {
- id: So.id,
- preconditions: de,
- binding: j.BACKSPACE
- }, Mg = {
- id: ma.id,
- preconditions: de,
- binding: j.DELETE
- }, _g = {
- id: at.id,
- binding: j.ARROW_UP,
- preconditions: de,
- staticParameters: {
- direction: se.UP
- }
- }, Pg = {
- id: at.id,
- binding: j.ARROW_DOWN,
- preconditions: de,
- staticParameters: {
- direction: se.DOWN
- }
- }, Dg = {
- id: at.id,
- binding: j.ARROW_LEFT,
- preconditions: de,
- staticParameters: {
- direction: se.LEFT
- }
- }, wg = {
- id: at.id,
- binding: j.ARROW_RIGHT,
- preconditions: de,
- staticParameters: {
- direction: se.RIGHT
- }
- }, Ng = {
- id: ct.id,
- binding: j.ARROW_UP | K.SHIFT,
- preconditions: de,
- staticParameters: {
- direction: se.UP
- }
- }, Qg = {
- id: ct.id,
- binding: j.ARROW_DOWN | K.SHIFT,
- preconditions: de,
- staticParameters: {
- direction: se.DOWN
- }
- }, Ug = {
- id: ct.id,
- binding: j.ARROW_LEFT | K.SHIFT,
- preconditions: de,
- staticParameters: {
- direction: se.LEFT
- }
- }, Lg = {
- id: ct.id,
- binding: j.ARROW_RIGHT | K.SHIFT,
- preconditions: de,
- staticParameters: {
- direction: se.RIGHT
- }
- }, Fg = {
- id: ya.id,
- binding: j.A | K.CTRL_COMMAND,
- preconditions: (n) => n.getContextValue(Ss) && (n.getContextValue(hn) || n.getContextValue(wn))
- };
- var Na = Object.defineProperty, Hg = Object.getOwnPropertyDescriptor, kg = (n, e, t) => e in n ? Na(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t, Vg = (n, e, t, o) => {
- for (var s = o > 1 ? void 0 : o ? Hg(e, t) : e, r = n.length - 1, i; r >= 0; r--)
- (i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
- return o && s && Na(e, t, s), s;
- }, en = (n, e) => (t, o) => e(t, o, n), jg = (n, e, t) => kg(n, e + "", t);
- let gs = class extends oc {
- // static override type = UniverInstanceType.UNIVER_DOC;
- constructor(n = qr, e, t, o, s, r) {
- super(), this._config = n, this._injector = e, this._renderManagerSrv = t, this._commandService = o, this._logService = s, this._configService = r;
- const { menu: i, ...a } = sc(
- {},
- qr,
- this._config
- );
- i && this._configService.setConfig("menu", i, { merge: !0 }), this._configService.setConfig(Us, a), this._initDependencies(e), this._initializeShortcut(), this._initCommand();
- }
- onReady() {
- this._initRenderBasics(), this._markDocAsFocused(), fr(this._injector, [
- [Kn],
- [Xn]
- ]);
- }
- onRendered() {
- this._initUI(), this._initRenderModules(), fr(this._injector, [
- [jn],
- [Wn],
- [Lt],
- [zn],
- // FIXME: LifecycleStages.Rendered must be used, otherwise the menu cannot be added to the DOM, but the sheet ui
- // plugin can be added in LifecycleStages.Ready
- [Hn]
- ]);
- }
- _initCommand() {
- [
- So,
- ma,
- Vt,
- jt,
- Wt,
- zt,
- Ct,
- Gt,
- Pt,
- Dt,
- wt,
- fn,
- Nt,
- lt,
- Ra,
- Vs,
- dn,
- js,
- pa,
- Ws,
- Ye,
- ho,
- uo,
- pn,
- go,
- fo,
- po,
- et,
- mo,
- ba,
- Ia,
- er,
- tr,
- Fd,
- nr,
- or,
- Xs,
- Js,
- In,
- Ps,
- Ma,
- _t,
- Ao,
- ln,
- es,
- lo,
- ws,
- Ns,
- da,
- Ba,
- Co,
- qe,
- fa,
- Qt,
- gA,
- Vi,
- fA,
- ss,
- ya,
- rr,
- at,
- ct,
- mA
- ].forEach((n) => {
- this._commandService.registerCommand(n);
- }), [Fn, qs, Ks].forEach((n) => this.disposeWithMe(this._commandService.registerMultipleCommand(n)));
- }
- _initializeShortcut() {
- [
- _g,
- Pg,
- wg,
- Dg,
- Ng,
- Qg,
- Ug,
- Lg,
- Fg,
- Bg,
- Mg,
- yg,
- Ol
- ].forEach((n) => {
- this._injector.get(ro).registerShortcut(n);
- });
- }
- _initDependencies(n) {
- rc([
- [Yn],
- [qn],
- [Hn],
- [jn],
- [zn],
- [Wn],
- [Vn],
- [Lt],
- [He, { useClass: Jo }],
- [Tg, { useClass: Og }],
- [Sn, { useClass: ns }],
- [is],
- [Xn],
- [Kn],
- [Et],
- [Je]
- ], this._config.override).forEach((t) => n.add(t));
- }
- _markDocAsFocused() {
- const n = this._injector.get(Q), e = this._injector.get(He);
- try {
- const t = n.getCurrentUnitForType(_.UNIVER_DOC);
- if (!t) return;
- const o = t.getUnitId();
- e.isEditor(o) || n.focusUnit(t.getUnitId());
- } catch (t) {
- this._logService.warn(t);
- }
- }
- _initUI() {
- this._injector.get(Vn);
- }
- _initRenderBasics() {
- [
- [ie],
- [Se],
- [ac],
- [ar],
- [Ro],
- [os],
- [hs]
- ].forEach((n) => {
- this._renderManagerSrv.registerRenderModule(_.UNIVER_DOC, n);
- });
- }
- _initRenderModules() {
- [
- [Gn],
- [kn],
- [us],
- [Zo],
- [ds],
- [cs],
- [as],
- [Yn],
- [ls],
- [As],
- [qn]
- ].forEach((n) => {
- this._renderManagerSrv.registerRenderModule(_.UNIVER_DOC, n);
- });
- }
- };
- jg(gs, "pluginName", rA);
- gs = Vg([
- nc(xc),
- en(1, z(so)),
- en(2, fe),
- en(3, y),
- en(4, fs),
- en(5, Rs)
- ], gs);
- export {
- Ao as AfterSpaceCommand,
- fo as AlignCenterCommand,
- mo as AlignJustifyCommand,
- go as AlignLeftCommand,
- et as AlignOperationCommand,
- po as AlignRightCommand,
- Ra as BreakLineCommand,
- uo as BulletListCommand,
- es as ChangeListNestingLevelCommand,
- Pn as ChangeListNestingLevelType,
- lo as ChangeListTypeCommand,
- ws as CheckListCommand,
- fA as CoverContentCommand,
- ba as CreateDocTableCommand,
- Qt as CutContentCommand,
- iA as DOCS_COMPONENT_BACKGROUND_LAYER_INDEX,
- xr as DOCS_COMPONENT_DEFAULT_Z_INDEX,
- aA as DOCS_COMPONENT_HEADER_LAYER_INDEX,
- Oo as DOCS_COMPONENT_MAIN_LAYER_INDEX,
- We as DOCS_VIEW_KEY,
- rA as DOC_UI_PLUGIN_NAME,
- ai as DOC_VERTICAL_PADDING,
- sA as DefaultDocContainerConfig,
- oA as DefaultToolbarConfig,
- dn as DeleteCommand,
- js as DeleteCustomBlockCommand,
- So as DeleteLeftCommand,
- ma as DeleteRightCommand,
- Et as DocAutoFormatService,
- kn as DocBackScrollRenderController,
- is as DocCanvasPopManagerService,
- Fn as DocCopyCommand,
- sr as DocCreateTableOperation,
- qs as DocCutCommand,
- Gn as DocEventManagerService,
- Ro as DocIMEInputManagerService,
- Ks as DocPasteCommand,
- os as DocRenderController,
- ya as DocSelectAllCommand,
- Se as DocSelectionRenderService,
- Kn as DocStateChangeManagerService,
- Js as DocTableDeleteColumnsCommand,
- Xs as DocTableDeleteRowsCommand,
- In as DocTableDeleteTableCommand,
- Fd as DocTableInsertColumnCommand,
- nr as DocTableInsertColumnLeftCommand,
- or as DocTableInsertColumnRightCommand,
- er as DocTableInsertRowAboveCommand,
- tr as DocTableInsertRowBellowCommand,
- Ia as DocTableInsertRowCommand,
- Ma as DocTableTabCommand,
- Hn as DocUIController,
- Xn as DocsRenderService,
- Zu as DocsUIMenuSchema,
- DA as Editor,
- Ed as EditorInsertTextCommandId,
- Jo as EditorService,
- ln as EnterCommand,
- Sn as IDocClipboardService,
- He as IEditorService,
- Ba as IMEInputCommand,
- Tg as IRangeSelectorService,
- fa as InnerPasteCommand,
- Vs as InsertCommand,
- pn as ListOperationCommand,
- Ws as MergeTwoParagraphCommand,
- at as MoveCursorOperation,
- ct as MoveSelectionOperation,
- ef as NORMAL_TEXT_SELECTION_PLUGIN_NAME,
- it as NodePositionConvertToCursor,
- Gi as NodePositionConvertToRectRange,
- ho as OrderListCommand,
- xd as PastePluginLark,
- Od as PastePluginUniver,
- Td as PastePluginWord,
- da as QuickListCommand,
- Og as RangeSelectorService,
- Yi as RectRange,
- gA as ReplaceContentCommand,
- Vi as ReplaceSnapshotCommand,
- mA as ReplaceTextRunsCommand,
- fn as ResetInlineFormatTextBackgroundColorCommand,
- cf as RichTextEditor,
- ss as SetDocZoomRatioCommand,
- Ye as SetDocZoomRatioOperation,
- Vt as SetInlineFormatBoldCommand,
- lt as SetInlineFormatCommand,
- Dt as SetInlineFormatFontFamilyCommand,
- Pt as SetInlineFormatFontSizeCommand,
- jt as SetInlineFormatItalicCommand,
- zt as SetInlineFormatStrikethroughCommand,
- Ct as SetInlineFormatSubscriptCommand,
- Gt as SetInlineFormatSuperscriptCommand,
- Nt as SetInlineFormatTextBackgroundColorCommand,
- wt as SetInlineFormatTextColorCommand,
- Wt as SetInlineFormatUnderlineCommand,
- qo as TEXT_RANGE_LAYER_INDEX,
- _t as TabCommand,
- Mt as TextRange,
- Ns as ToggleCheckListCommand,
- gs as UniverDocsUIPlugin,
- pa as UpdateCommand,
- Xe as VIEWPORT_KEY,
- nf as addCustomDecorationBySelectionFactory,
- AA as addCustomDecorationFactory,
- ko as calcDocRangePositions,
- Mo as convertPositionsToRectRanges,
- of as deleteCustomDecorationFactory,
- rf as docDrawingPositionToTransform,
- ua as genTableSource,
- va as generateParagraphs,
- Mn as getAnchorBounding,
- yA as getCanvasOffsetByEngine,
- ke as getCommandSkeleton,
- zs as getCursorWhenDelete,
- dd as getCustomBlockIdsInSelections,
- md as getCutActionsFromDocRanges,
- cA as getDocObject,
- tf as getDocObjectById,
- Fs as getEmptyTableCell,
- Hs as getEmptyTableRow,
- Bs as getLineBounding,
- yr as getOneTextSelectionRange,
- Qs as getParagraphsInRange,
- mn as getParagraphsInRanges,
- le as getRichTextEditPath,
- ks as getTableColumn,
- sf as hasParagraphInTable,
- Wi as isInSameTableCell,
- SA as isValidRectRange,
- rt as neoGetDocObject,
- af as transformToDocDrawingPosition,
- lA as useKeyboardEvent,
- dA as useResize,
- de as whenDocAndEditorFocused
- };
|