@univerjs/docs-drawing-ui 0.6.10-nightly.202504271606 → 0.6.10-nightly.202504281607
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/index.js +1 -1
- package/lib/es/index.js +296 -288
- package/lib/index.js +296 -288
- package/lib/types/views/printing-float-dom/index.d.ts +2 -1
- package/lib/umd/index.js +1 -1
- package/package.json +10 -10
package/lib/cjs/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var xn=Object.defineProperty;var Pn=(r,e,t)=>e in r?xn(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t;var le=(r,e,t)=>Pn(r,typeof e!="symbol"?e+"":e,t);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("@univerjs/core"),ve=require("@univerjs/docs-drawing"),X=require("@univerjs/drawing"),fe=require("@univerjs/drawing-ui"),L=require("@univerjs/engine-render"),k=require("@univerjs/ui"),W=require("@univerjs/docs"),G=require("@univerjs/docs-ui"),N=require("@univerjs/design"),Z=require("rxjs"),u=require("react/jsx-runtime"),K=require("react"),Nn="docs-drawing-ui.config",cn={};var ce=function(){return ce=Object.assign||function(r){for(var e,t=1,n=arguments.length;t<n;t++){e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(r[i]=e[i])}return r},ce.apply(this,arguments)},En=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t},mn=K.forwardRef(function(r,e){var t=r.icon,n=r.id,i=r.className,s=r.extend,a=En(r,["icon","id","className","extend"]),d="univerjs-icon univerjs-icon-".concat(n," ").concat(i||"").trim(),l=K.useRef("_".concat(Un()));return un(t,"".concat(n),{defIds:t.defIds,idSuffix:l.current},ce({ref:e,className:d},a),s)});function un(r,e,t,n,i){return K.createElement(r.tag,ce(ce({key:e},An(r,t,i)),n),(jn(r,t).children||[]).map(function(s,a){return un(s,"".concat(e,"-").concat(r.tag,"-").concat(a),t,void 0,i)}))}function An(r,e,t){var n=ce({},r.attrs);t!=null&&t.colorChannel1&&n.fill==="colorChannel1"&&(n.fill=t.colorChannel1),r.tag==="mask"&&n.id&&(n.id=n.id+e.idSuffix),Object.entries(n).forEach(function(s){var a=s[0],d=s[1];a==="mask"&&typeof d=="string"&&(n[a]=d.replace(/url\(#(.*)\)/,"url(#$1".concat(e.idSuffix,")")))});var i=e.defIds;return!i||i.length===0||(r.tag==="use"&&n["xlink:href"]&&(n["xlink:href"]=n["xlink:href"]+e.idSuffix),Object.entries(n).forEach(function(s){var a=s[0],d=s[1];typeof d=="string"&&(n[a]=d.replace(/url\(#(.*)\)/,"url(#$1".concat(e.idSuffix,")")))})),n}function jn(r,e){var t,n=e.defIds;return!n||n.length===0?r:r.tag==="defs"&&(!((t=r.children)===null||t===void 0)&&t.length)?ce(ce({},r),{children:r.children.map(function(i){return typeof i.attrs.id=="string"&&n&&n.indexOf(i.attrs.id)>-1?ce(ce({},i),{attrs:ce(ce({},i.attrs),{id:i.attrs.id+e.idSuffix})}):i})}):r}function Un(){return Math.random().toString(36).substring(2,8)}mn.displayName="UniverIcon";var Ln={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M2.2498 3.65005C2.2498 2.87685 2.87661 2.25005 3.64981 2.25005H7.9998C8.33118 2.25005 8.5998 1.98142 8.5998 1.65005C8.5998 1.31868 8.33118 1.05005 7.9998 1.05005H3.64981C2.21387 1.05005 1.0498 2.21411 1.0498 3.65005V12.35C1.0498 13.786 2.21386 14.95 3.6498 14.95H12.3498C13.7857 14.95 14.9498 13.786 14.9498 12.3501V8.00005C14.9498 7.66868 14.6812 7.40005 14.3498 7.40005C14.0184 7.40005 13.7498 7.66868 13.7498 8.00005V9.23974L12.2385 8.1063C11.7252 7.72129 11.0068 7.7723 10.5531 8.22605L9.00869 9.77041L6.73916 7.8251C6.24387 7.40055 5.5095 7.41278 5.02864 7.85359L2.2498 10.4009V3.65005ZM2.2498 12.0287V12.35C2.2498 13.1232 2.87661 13.75 3.6498 13.75H12.3498C13.123 13.75 13.7498 13.1232 13.7498 12.3501V10.7397L11.5186 9.06631C11.4829 9.03956 11.433 9.04314 11.4016 9.07458L9.92249 10.5537L11.1015 11.5642C11.3531 11.7799 11.3822 12.1587 11.1666 12.4103C10.9509 12.6619 10.5721 12.691 10.3205 12.4753L5.9582 8.7362C5.92384 8.70674 5.87288 8.70758 5.83952 8.73816L2.2498 12.0287Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M11.8097 1.14783C12.1411 1.14783 12.4097 1.41646 12.4097 1.74783V3.297H14.1541C14.4855 3.297 14.7541 3.56563 14.7541 3.897C14.7541 4.22837 14.4855 4.497 14.1541 4.497H12.4097V6.24167C12.4097 6.57304 12.1411 6.84167 11.8097 6.84167C11.4783 6.84167 11.2097 6.57304 11.2097 6.24167V4.497H9.6603C9.32893 4.497 9.0603 4.22837 9.0603 3.897C9.0603 3.56563 9.32893 3.297 9.6603 3.297H11.2097V1.74783C11.2097 1.41646 11.4783 1.14783 11.8097 1.14783Z"}}]},hn=K.forwardRef(function(r,e){return K.createElement(mn,Object.assign({},r,{id:"add-image-single",ref:e,icon:Ln}))});hn.displayName="AddImageSingle";const Ge={id:"doc.command.remove-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{var x,M,A,H;const t=r.get(o.ICommandService),n=r.get(o.IUniverInstanceService),i=r.get(L.IRenderManagerService),s=n.getCurrentUniverDocInstance();if(e==null||s==null)return!1;const a=i.getRenderById(e.unitId).with(G.DocSelectionRenderService),{drawings:d}=e,l=(x=a.getSegment())!=null?x:"",c=new o.TextX,g=o.JSONX.getInstance(),h=(A=(M=s.getSelfOrHeaderFooterModel(l).getBody())==null?void 0:M.customBlocks)!=null?A:[],m=d.map(E=>h.find(_=>_.blockId===E.drawingId)).filter(E=>!!E).sort((E,_)=>E.startIndex>_.startIndex?1:-1),f=d[0].unitId,p=new o.MemoryCursor;p.reset();const w=m[0].startIndex,S=[{startOffset:w,endOffset:w}],I={id:W.RichTextEditingMutation.id,params:{unitId:f,actions:[],textRanges:S}},T=[];for(const E of m){const{startIndex:_}=E;_>p.cursor&&c.push({t:o.TextXActionType.RETAIN,len:_-p.cursor}),c.push({t:o.TextXActionType.DELETE,len:1}),p.moveCursorTo(_+1)}const y=G.getRichTextEditPath(s,l);T.push(g.editOp(c.serialize(),y));for(const E of m){const{blockId:_}=E,F=((H=s.getDrawings())!=null?H:{})[_],U=s.getDrawingsOrder().indexOf(_),q=g.removeOp(["drawings",_],F),D=g.removeOp(["drawingsOrder",U],_);T.push(q),T.push(D)}return I.params.actions=T.reduce((E,_)=>o.JSONX.compose(E,_),null),!!t.syncExecuteCommand(I.id,I.params)}},Je={id:"doc.command.delete-drawing",type:o.CommandType.COMMAND,handler:r=>{const e=r.get(o.ICommandService),n=r.get(ve.IDocDrawingService).getFocusDrawings();if(n.length===0)return!1;const{unitId:i}=n[0],s=n.map(a=>{const{unitId:d,subUnitId:l,drawingId:c,drawingType:g}=a;return{unitId:d,subUnitId:l,drawingId:c,drawingType:g}});return e.executeCommand(Ge.id,{unitId:i,drawings:s})}},Ze={id:"doc.command.group-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{r.get(o.ICommandService),r.get(o.IUndoRedoService);const t=r.get(ve.IDocDrawingService);if(!e)return!1;const n=[];e.forEach(({parent:g,children:h})=>{n.push(g.unitId),h.forEach(m=>{n.push(m.unitId)})});const i=t.getGroupDrawingOp(e),{unitId:s,subUnitId:a,undo:d,redo:l,objects:c}=i;return!1}},Ve={id:"doc.command.insert-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{var M,A,H,E;if(e==null)return!1;const t=r.get(o.ICommandService),n=r.get(W.DocSelectionManagerService),i=r.get(o.IUniverInstanceService),s=n.getActiveTextRange(),a=i.getCurrentUniverDocInstance();if(s==null||a==null)return!1;const d=a.getUnitId(),{drawings:l}=e,{collapsed:c,startOffset:g,segmentId:h}=s,m=a.getSelfOrHeaderFooterModel(h).getBody();if(m==null)return!1;const f=new o.TextX,p=o.JSONX.getInstance(),w=[],S=(A=(M=a.getSnapshot().drawingsOrder)==null?void 0:M.length)!=null?A:0;let I=0;if(c)g>0&&f.push({t:o.TextXActionType.RETAIN,len:g});else{const _=o.BuildTextUtils.selection.delete([s],m,0,null,!1);f.push(..._);const F=G.getCustomBlockIdsInSelections(m,[s]),z=(H=a.getDrawings())!=null?H:{},U=(E=a.getDrawingsOrder())!=null?E:[],q=F.sort((D,C)=>U.indexOf(D)>U.indexOf(C)?-1:U.indexOf(D)<U.indexOf(C)?1:0);if(q.length>0)for(const D of q){const C=z[D],P=U.indexOf(D);if(C==null||P<0)continue;const b=p.removeOp(["drawings",D],C),B=p.removeOp(["drawingsOrder",P],D);w.push(b),w.push(B),I++}}f.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b".repeat(l.length),customBlocks:l.map((_,F)=>({startIndex:F,blockId:_.drawingId}))},len:l.length});const T=G.getRichTextEditPath(a,h),y=p.editOp(f.serialize(),T);w.push(y);for(const _ of l){const{drawingId:F}=_,z=p.insertOp(["drawings",F],_),U=p.insertOp(["drawingsOrder",S-I],F);w.push(z),w.push(U)}const O={id:W.RichTextEditingMutation.id,params:{unitId:d,actions:[],textRanges:[]}};return O.params.actions=w.reduce((_,F)=>o.JSONX.compose(_,F),null),!!t.syncExecuteCommand(O.id,O.params)}},Qe={id:"doc.command.set-drawing-arrange",type:o.CommandType.COMMAND,handler:(r,e)=>{const t=r.get(o.ICommandService),n=r.get(ve.IDocDrawingService);if(e==null)return!1;const{unitId:i,subUnitId:s,drawingIds:a,arrangeType:d}=e,l={unitId:i,subUnitId:s,drawingIds:a};let c;if(d===o.ArrangeTypeEnum.forward?c=n.getForwardDrawingsOp(l):d===o.ArrangeTypeEnum.backward?c=n.getBackwardDrawingOp(l):d===o.ArrangeTypeEnum.front?c=n.getFrontDrawingsOp(l):d===o.ArrangeTypeEnum.back&&(c=n.getBackDrawingsOp(l)),c==null)return!1;const{redo:g}=c;if(g==null)return!1;const h=[];let m=o.Tools.deepClone(g);m=m.slice(3),m.unshift("drawingsOrder"),h.push(m);const f={id:W.RichTextEditingMutation.id,params:{unitId:i,actions:[],textRanges:null}};return f.params.actions=h.reduce((w,S)=>o.JSONX.compose(w,S),null),!!t.syncExecuteCommand(f.id,f.params)}},en={id:"doc.command.ungroup-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{r.get(o.ICommandService),r.get(o.IUndoRedoService);const t=r.get(ve.IDocDrawingService);if(!e)return!1;const n=[];e.forEach(({parent:g,children:h})=>{n.push(g.unitId),h.forEach(m=>{n.push(m.unitId)})});const i=t.getUngroupDrawingOp(e),{unitId:s,subUnitId:a,undo:d,redo:l,objects:c}=i;return!1}};class $e{constructor(){le(this,"_refreshDrawings$",new Z.BehaviorSubject(null));le(this,"refreshDrawings$",this._refreshDrawings$.asObservable())}refreshDrawings(e){this._refreshDrawings$.next(e)}}var Fn=Object.getOwnPropertyDescriptor,Bn=(r,e,t,n)=>{for(var i=n>1?void 0:n?Fn(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},se=(r,e)=>(t,n)=>e(t,n,r);let Le=class extends o.Disposable{constructor(r,e,t,n,i,s,a,d,l,c,g,h,m){super(),this._context=r,this._commandService=e,this._docSelectionManagerService=t,this._renderManagerSrv=n,this._imageIoService=i,this._docDrawingService=s,this._drawingManagerService=a,this._contextService=d,this._messageService=l,this._localeService=c,this._docSelectionRenderService=g,this._docRefreshDrawingsService=h,this._fileOpenerService=m,this._updateOrderListener(),this._groupDrawingListener(),this._focusDrawingListener(),this._transformDrawingListener(),this._editAreaChangeListener()}async insertDocImage(){const r=await this._fileOpenerService.openFile({multiple:!0,accept:X.DRAWING_IMAGE_ALLOW_IMAGE_LIST.map(t=>`.${t.replace("image/","")}`).join(",")}),e=r.length;return e>X.DRAWING_IMAGE_COUNT_LIMIT?(this._messageService.show({type:N.MessageType.Error,content:this._localeService.t("update-status.exceedMaxCount",String(X.DRAWING_IMAGE_COUNT_LIMIT))}),!1):e===0?!1:(await this._insertFloatImages(r),!0)}async _insertFloatImages(r){let e=[];try{e=await Promise.all(r.map(i=>this._imageIoService.saveImage(i)))}catch(i){const s=i.message;let a="";switch(s){case X.ImageUploadStatusType.ERROR_EXCEED_SIZE:a=this._localeService.t("update-status.exceedMaxSize",String(X.DRAWING_IMAGE_ALLOW_SIZE/(1024*1024)));break;case X.ImageUploadStatusType.ERROR_IMAGE_TYPE:a=this._localeService.t("update-status.invalidImageType");break;case X.ImageUploadStatusType.ERROR_IMAGE:a=this._localeService.t("update-status.invalidImage");break}this._messageService.show({type:N.MessageType.Error,content:a})}if(e.length===0)return;const{unitId:t}=this._context,n=[];for(const i of e){if(i==null)continue;const{imageId:s,imageSourceType:a,source:d,base64Cache:l}=i,{width:c,height:g,image:h}=await X.getImageSize(l||"");this._imageIoService.addImageSourceCache(s,a,h);let m=1;if(c>X.DRAWING_IMAGE_WIDTH_LIMIT||g>X.DRAWING_IMAGE_HEIGHT_LIMIT){const S=X.DRAWING_IMAGE_WIDTH_LIMIT/c,I=X.DRAWING_IMAGE_HEIGHT_LIMIT/g;m=Math.min(S,I)}const f=this._getImagePosition(c*m,g*m);if(f==null)return;const p={unitId:t,subUnitId:t,drawingId:s,drawingType:o.DrawingTypeEnum.DRAWING_IMAGE,imageSourceType:a,source:d,transform:G.docDrawingPositionToTransform(f),docTransform:f,behindDoc:o.BooleanNumber.FALSE,title:"",description:"",layoutType:o.PositionedObjectLayoutType.INLINE,wrapText:o.WrapTextType.BOTH_SIDES,distB:0,distL:0,distR:0,distT:0};this._isInsertInHeaderFooter()&&(p.isMultiTransform=o.BooleanNumber.TRUE,p.transforms=p.transform?[p.transform]:null),n.push(p)}this._commandService.executeCommand(Ve.id,{unitId:t,drawings:n})}_isInsertInHeaderFooter(){var n;const{unitId:r}=this._context,e=(n=this._renderManagerSrv.getRenderById(r))==null?void 0:n.with(W.DocSkeletonManagerService).getViewModel(),t=e==null?void 0:e.getEditArea();return t===L.DocumentEditArea.HEADER||t===L.DocumentEditArea.FOOTER}_getImagePosition(r,e){const t=this._docSelectionRenderService.getActiveTextRange(),n=(t==null?void 0:t.getAbsolutePosition())||{left:0};return{size:{width:r,height:e},positionH:{relativeFrom:o.ObjectRelativeFromH.PAGE,posOffset:n.left},positionV:{relativeFrom:o.ObjectRelativeFromV.PARAGRAPH,posOffset:0},angle:0}}_updateOrderListener(){this._drawingManagerService.featurePluginOrderUpdate$.subscribe(r=>{const{unitId:e,subUnitId:t,drawingIds:n,arrangeType:i}=r;this._commandService.executeCommand(Qe.id,{unitId:e,subUnitId:t,drawingIds:n,arrangeType:i})})}_groupDrawingListener(){this._drawingManagerService.featurePluginGroupUpdate$.subscribe(r=>{this._commandService.executeCommand(Ze.id,r)}),this._drawingManagerService.featurePluginUngroupUpdate$.subscribe(r=>{this._commandService.executeCommand(en.id,r)})}_getCurrentSceneAndTransformer(){const{scene:r,mainComponent:e}=this._context;if(r==null||e==null)return;const t=r.getTransformerByCreate(),{docsLeft:n,docsTop:i}=e.getOffsetConfig();return{scene:r,transformer:t,docsLeft:n,docsTop:i}}_transformDrawingListener(){const r=this._getCurrentSceneAndTransformer();if(r&&r.transformer)this.disposeWithMe(r.transformer.changeEnd$.pipe(Z.debounceTime(30)).subscribe(e=>{this._docSelectionManagerService.refreshSelection()}));else throw new Error("transformer is not init")}_focusDrawingListener(){this.disposeWithMe(this._drawingManagerService.focus$.subscribe(r=>{var i;const{transformer:e,docsLeft:t,docsTop:n}=(i=this._getCurrentSceneAndTransformer())!=null?i:{};if(r==null||r.length===0)this._contextService.setContextValue(o.FOCUSING_COMMON_DRAWINGS,!1),this._docDrawingService.focusDrawing([]),e&&e.resetProps({zeroTop:0,zeroLeft:0});else{this._contextService.setContextValue(o.FOCUSING_COMMON_DRAWINGS,!0),this._docDrawingService.focusDrawing(r),this._setDrawingSelections(r);const s=this._docSelectionRenderService.getSegment(),a=this._findSegmentIdByDrawingId(r[0].drawingId);s!==a&&this._docSelectionRenderService.setSegment(a),e&&e.resetProps({zeroTop:n,zeroLeft:t})}}))}_findSegmentIdByDrawingId(r){var a,d,l;const{unit:e}=this._context,{body:t,headers:n={},footers:i={}}=e.getSnapshot();if(((a=t==null?void 0:t.customBlocks)!=null?a:[]).some(c=>c.blockId===r))return"";for(const c of Object.keys(n))if((d=n[c].body.customBlocks)!=null&&d.some(g=>g.blockId===r))return c;for(const c of Object.keys(i))if((l=i[c].body.customBlocks)!=null&&l.some(g=>g.blockId===r))return c;return""}_updateDrawingsEditStatus(){var d;const{unit:r,scene:e,unitId:t}=this._context,n=(d=this._renderManagerSrv.getRenderById(t))==null?void 0:d.with(W.DocSkeletonManagerService).getViewModel();if(n==null||r==null)return;const i=r.getSnapshot(),{drawings:s={}}=i,a=n.getEditArea()===L.DocumentEditArea.BODY;for(const l of Object.keys(s)){const c=s[l],g=X.getDrawingShapeKeyByDrawingSearch({unitId:t,drawingId:c.drawingId,subUnitId:t}),h=e.fuzzyMathObjects(g,!0);if(h.length)for(const m of h){e.detachTransformerFrom(m);try{m.setOpacity(.5)}catch{}if(a&&c.isMultiTransform!==o.BooleanNumber.TRUE||!a&&c.isMultiTransform===o.BooleanNumber.TRUE){c.allowTransform!==!1&&e.attachTransformerTo(m);try{m.setOpacity(1)}catch{}}}}}_editAreaChangeListener(){var t;const{unitId:r}=this._context,e=(t=this._renderManagerSrv.getRenderById(r))==null?void 0:t.with(W.DocSkeletonManagerService).getViewModel();e!=null&&(this._updateDrawingsEditStatus(),this.disposeWithMe(e.editAreaChange$.subscribe(()=>{this._updateDrawingsEditStatus()})),this._docRefreshDrawingsService.refreshDrawings$.subscribe(n=>{n!=null&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})}),this.disposeWithMe(this._commandService.onCommandExecuted(async n=>{n.id===W.RichTextEditingMutation.id&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})})))}_setDrawingSelections(r){var i,s;const{unit:e}=this._context,t=(s=(i=e.getSnapshot().body)==null?void 0:i.customBlocks)!=null?s:[],n=r.map(a=>{const d=a.drawingId,l=t.find(c=>c.blockId===d);return l?l.startIndex:null}).filter(a=>a!==null).map(a=>({startOffset:a,endOffset:a+1}));this._docSelectionManagerService.replaceDocRanges(n)}};Le=Bn([se(1,o.ICommandService),se(2,o.Inject(W.DocSelectionManagerService)),se(3,L.IRenderManagerService),se(4,X.IImageIoService),se(5,ve.IDocDrawingService),se(6,X.IDrawingManagerService),se(7,o.IContextService),se(8,k.IMessageService),se(9,o.Inject(o.LocaleService)),se(10,o.Inject(G.DocSelectionRenderService)),se(11,o.Inject($e)),se(12,k.ILocalFileService)],Le);const nn={id:"doc.command.insert-float-image",type:o.CommandType.COMMAND,handler:r=>{var n,i;const e=r.get(o.IUniverInstanceService),t=r.get(L.IRenderManagerService);return(i=(n=L.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_DOC,e,t))==null?void 0:n.with(Le).insertDocImage())!=null?i:!1}};var ae=(r=>(r.INLINE="inline",r.BEHIND_TEXT="behindText",r.IN_FRONT_OF_TEXT="inFrontOfText",r.WRAP_SQUARE="wrapSquare",r.WRAP_TOP_AND_BOTTOM="wrapTopAndBottom",r))(ae||{});const kn={inline:o.PositionedObjectLayoutType.INLINE,wrapSquare:o.PositionedObjectLayoutType.WRAP_SQUARE,wrapTopAndBottom:o.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM,inFrontOfText:o.PositionedObjectLayoutType.WRAP_NONE,behindText:o.PositionedObjectLayoutType.WRAP_NONE};function pn(r,e,t,n,i,s,a){var f,p;const d=new o.TextX,l=o.JSONX.getInstance(),c=[],g=s.getSelfOrHeaderFooterModel(e).getBody(),h=s.getSelfOrHeaderFooterModel(r).getBody();if(g==null||h==null)return;const m=(p=(f=g.customBlocks)==null?void 0:f.find(w=>w.blockId===i))==null?void 0:p.startIndex;if(m!=null){if(n=Math.min(h.dataStream.length-2,n),r===e){if(n<m?(n>0&&d.push({t:o.TextXActionType.RETAIN,len:n}),d.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:i}]},len:1}),d.push({t:o.TextXActionType.RETAIN,len:m-n}),d.push({t:o.TextXActionType.DELETE,len:1})):(m>0&&d.push({t:o.TextXActionType.RETAIN,len:m}),d.push({t:o.TextXActionType.DELETE,len:1}),n-m-1>0&&d.push({t:o.TextXActionType.RETAIN,len:n-m-1}),d.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:i}]},len:1})),n!==m){const w=G.getRichTextEditPath(s,e),S=l.editOp(d.serialize(),w);c.push(S)}}else{m>0&&d.push({t:o.TextXActionType.RETAIN,len:m}),d.push({t:o.TextXActionType.DELETE,len:1});let w=G.getRichTextEditPath(s,e),S=l.editOp(d.serialize(),w);c.push(S),d.empty(),n>0&&d.push({t:o.TextXActionType.RETAIN,len:n}),d.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:i}]},len:1}),w=G.getRichTextEditPath(s,r),S=l.editOp(d.serialize(),w),c.push(S),a.setSegment(r),a.setSegmentPage(t)}return c}}const fn={id:"doc.command.update-doc-drawing-wrapping-style",type:o.CommandType.COMMAND,handler:(r,e)=>{var A,H;if(e==null)return!1;const{drawings:t,wrappingStyle:n,unitId:i}=e,s=r.get(o.ICommandService),a=r.get(o.IUniverInstanceService),l=r.get(L.IRenderManagerService).getRenderById(i),c=l==null?void 0:l.with(W.DocSkeletonManagerService).getSkeleton().getSkeletonData(),g=l==null?void 0:l.with(W.DocSkeletonManagerService).getViewModel(),h=l==null?void 0:l.scene,m=a.getCurrentUniverDocInstance();if(m==null||c==null||h==null||g==null)return!1;const f=g.getEditArea(),p=h.getTransformerByCreate(),{pages:w,skeHeaders:S,skeFooters:I}=c,T=o.JSONX.getInstance(),y=[],{drawings:O={}}=m.getSnapshot();for(const E of t){const{drawingId:_}=E,F=O[_].layoutType,z=kn[n];if(F!==z){const C=T.replaceOp(["drawings",_,"layoutType"],F,z);y.push(C)}if(n==="behindText"||n==="inFrontOfText"){const C=O[_].behindDoc,P=n==="behindText"?o.BooleanNumber.TRUE:o.BooleanNumber.FALSE;if(C!==P){const b=T.replaceOp(["drawings",_,"behindDoc"],C,P);y.push(b)}}if(n==="inline")continue;let U=null,q=0,D=0;for(const C of w){const{headerId:P,footerId:b,marginTop:B,marginLeft:V,marginBottom:R,pageWidth:j,pageHeight:Y}=C;switch(f){case L.DocumentEditArea.HEADER:{const $=(A=S.get(P))==null?void 0:A.get(j);$!=null&&$.skeDrawings.has(_)&&(U=$.skeDrawings.get(_),q=$.marginTop,D=V);break}case L.DocumentEditArea.FOOTER:{const $=(H=I.get(b))==null?void 0:H.get(j);$!=null&&$.skeDrawings.has(_)&&(U=$.skeDrawings.get(_),q=Y-R+$.marginTop,D=V);break}case L.DocumentEditArea.BODY:{C.skeDrawings.has(_)&&(U=C.skeDrawings.get(_),q=B,D=V);break}}if(U!=null)break}if(U!=null){const{aTop:C,aLeft:P}=U,b=O[_].docTransform.positionH;let B=P;b.relativeFrom===o.ObjectRelativeFromH.MARGIN?B-=D:b.relativeFrom===o.ObjectRelativeFromH.COLUMN&&(B-=U.columnLeft);const V={relativeFrom:b.relativeFrom,posOffset:B};if(b.posOffset!==V.posOffset){const $=T.replaceOp(["drawings",_,"docTransform","positionH"],b,V);y.push($)}const R=O[_].docTransform.positionV;let j=C;R.relativeFrom===o.ObjectRelativeFromV.PAGE?j+=q:R.relativeFrom===o.ObjectRelativeFromV.LINE?j-=U.lineTop:R.relativeFrom===o.ObjectRelativeFromV.PARAGRAPH&&(j-=U.blockAnchorTop);const Y={relativeFrom:R.relativeFrom,posOffset:j};if(R.posOffset!==Y.posOffset){const $=T.replaceOp(["drawings",_,"docTransform","positionV"],R,Y);y.push($)}}}const x={id:W.RichTextEditingMutation.id,params:{unitId:i,actions:[],textRanges:null}};x.params.actions=y.reduce((E,_)=>o.JSONX.compose(E,_),null);const M=s.syncExecuteCommand(x.id,x.params);return p.refreshControls(),!!M}},vn={id:"doc.command.update-doc-drawing-distance",type:o.CommandType.COMMAND,handler:(r,e)=>{if(e==null)return!1;const t=r.get(o.ICommandService),i=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(i==null)return!1;const{drawings:s,dist:a,unitId:d}=e,l=o.JSONX.getInstance(),c=[],{drawings:g={}}=i.getSnapshot();for(const f of s){const{drawingId:p}=f;for(const[w,S]of Object.entries(a)){const I=g[p][w];if(I!==S){const T=l.replaceOp(["drawings",p,w],I,S);c.push(T)}}}const h={id:W.RichTextEditingMutation.id,params:{unitId:d,actions:[],textRanges:null}};return h.params.actions=c.reduce((f,p)=>o.JSONX.compose(f,p),null),!!t.syncExecuteCommand(h.id,h.params)}},In={id:"doc.command.update-doc-drawing-wrap-text",type:o.CommandType.COMMAND,handler:(r,e)=>{if(e==null)return!1;const t=r.get(o.ICommandService),i=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(i==null)return!1;const{drawings:s,wrapText:a,unitId:d}=e,l=o.JSONX.getInstance(),c=[],{drawings:g={}}=i.getSnapshot();for(const f of s){const{drawingId:p}=f,w=g[p].wrapText;if(w!==a){const S=l.replaceOp(["drawings",p,"wrapText"],w,a);c.push(S)}}const h={id:W.RichTextEditingMutation.id,params:{unitId:d,actions:[],textRanges:null}};return h.params.actions=c.reduce((f,p)=>o.JSONX.compose(f,p),null),!!t.syncExecuteCommand(h.id,h.params)}},Pe={id:"doc.command.update-drawing-doc-transform",type:o.CommandType.COMMAND,handler:(r,e)=>{if(e==null)return!1;const t=r.get(o.ICommandService),n=r.get(o.IUniverInstanceService),s=r.get(L.IRenderManagerService).getRenderById(e.unitId),a=s==null?void 0:s.scene;if(a==null)return!1;const d=a.getTransformerByCreate(),l=n.getCurrentUniverDocInstance();if(l==null)return!1;const{drawings:c,unitId:g}=e,h=o.JSONX.getInstance(),m=[],{drawings:f={}}=l.getSnapshot();for(const S of c){const{drawingId:I,key:T,value:y}=S,O=f[I].docTransform[T];if(!o.Tools.diffValue(O,y)){const x=h.replaceOp(["drawings",I,"docTransform",T],O,y);m.push(x)}}const p={id:W.RichTextEditingMutation.id,params:{unitId:g,actions:[],textRanges:null,debounce:!0}};p.params.actions=m.reduce((S,I)=>o.JSONX.compose(S,I),null);const w=t.syncExecuteCommand(p.id,p.params);return d.refreshControls(),!!w}},wn={id:"doc.command.move-inline-drawing",type:o.CommandType.COMMAND,handler:(r,e)=>{var H,E;if(e==null)return!1;const t=r.get(L.IRenderManagerService),n=(H=t.getRenderById(e.unitId))==null?void 0:H.with(G.DocSelectionRenderService),i=r.get($e),s=t.getRenderById(e.unitId),a=s==null?void 0:s.scene,d=s==null?void 0:s.with(W.DocSkeletonManagerService).getSkeleton();if(a==null||n==null)return!1;const l=a.getTransformerByCreate(),c=r.get(o.ICommandService),h=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(h==null)return!1;const{drawing:m,unitId:f,offset:p,segmentId:w,segmentPage:S,needRefreshDrawings:I}=e;if(I)return i.refreshDrawings(d),l.refreshControls(),!0;const T=[],{drawingId:y}=m,O=(E=n.getSegment())!=null?E:"",x=pn(w,O,S,p,y,h,n);if(x==null||x.length===0)return i.refreshDrawings(d),l.refreshControls(),!1;T.push(...x);const M={id:W.RichTextEditingMutation.id,params:{unitId:f,actions:[],textRanges:null}};M.params.actions=T.reduce((_,F)=>o.JSONX.compose(_,F),null);const A=c.syncExecuteCommand(M.id,M.params);return l.refreshControls(),!!A}},Sn={id:"doc.command.transform-non-inline-drawing",type:o.CommandType.COMMAND,handler:(r,e)=>{var U,q;if(e==null)return!1;const t=r.get(L.IRenderManagerService),n=(U=t.getRenderById(e.unitId))==null?void 0:U.with(G.DocSelectionRenderService),i=t.getRenderById(e.unitId),s=i==null?void 0:i.scene;if(s==null||n==null)return!1;const a=s.getTransformerByCreate(),d=r.get(o.ICommandService),c=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(c==null)return!1;const{drawing:g,unitId:h,offset:m,docTransform:f,segmentId:p,segmentPage:w}=e,S=[],{drawingId:I}=g,T=(q=n.getSegment())!=null?q:"",y=pn(p,T,w,m,I,c,n);if(y==null)return!1;y.length>0&&S.push(...y);const O=o.JSONX.getInstance(),{drawings:x={}}=c.getSnapshot(),M=x[I].docTransform,{positionH:A,positionV:H,size:E,angle:_}=M;if(!o.Tools.diffValue(A,f.positionH)){const D=O.replaceOp(["drawings",I,"docTransform","positionH"],A,f.positionH);S.push(D)}if(!o.Tools.diffValue(H,f.positionV)){const D=O.replaceOp(["drawings",I,"docTransform","positionV"],H,f.positionV);S.push(D)}if(!o.Tools.diffValue(E,f.size)){const D=O.replaceOp(["drawings",I,"docTransform","size"],E,f.size);S.push(D)}if(!o.Tools.diffValue(_,f.angle)){const D=O.replaceOp(["drawings",I,"docTransform","angle"],_,f.angle);S.push(D)}const F={id:W.RichTextEditingMutation.id,params:{unitId:h,actions:[],textRanges:null,debounce:!0}};F.params.actions=S.reduce((D,C)=>o.JSONX.compose(D,C),null);const z=d.syncExecuteCommand(F.id,F.params);return a.refreshControls(),!!z}},ye={id:"doc.command.move-drawing",type:o.CommandType.COMMAND,handler:(r,e)=>{const t=r.get(o.ICommandService),n=r.get(ve.IDocDrawingService),i=r.get(o.IUniverInstanceService),s=r.get(L.IRenderManagerService),{direction:a}=e,d=n.getFocusDrawings();if(d.length===0)return!1;const l=d[0].unitId,c=s.getRenderById(l),g=c==null?void 0:c.scene;if(g==null)return!1;const h=g.getTransformerByCreate(),m=i.getUniverDocInstance(l),f=d.map(w=>{var M,A,H,E,_;const{drawingId:S}=w,I=(M=m==null?void 0:m.getSnapshot().drawings)==null?void 0:M[S];if(I==null||I.layoutType===o.PositionedObjectLayoutType.INLINE)return null;const{positionH:T,positionV:y}=I.docTransform,O={...T},x={...y};return a===o.Direction.UP?x.posOffset=((A=x.posOffset)!=null?A:0)-2:a===o.Direction.DOWN?x.posOffset=((H=x.posOffset)!=null?H:0)+2:a===o.Direction.LEFT?O.posOffset=((E=O.posOffset)!=null?E:0)-2:a===o.Direction.RIGHT&&(O.posOffset=((_=O.posOffset)!=null?_:0)+2),{drawingId:S,key:a===o.Direction.UP||a===o.Direction.DOWN?"positionV":"positionH",value:a===o.Direction.UP||a===o.Direction.DOWN?x:O}}).filter(w=>w!=null);if(f.length===0)return!1;const p=t.syncExecuteCommand(Pe.id,{unitId:l,subUnitId:l,drawings:f});return h.refreshControls(),!!p}},_n={id:"doc.operation.clear-drawing-transformer",type:o.CommandType.MUTATION,handler:(r,e)=>{const t=r.get(L.IRenderManagerService);return e.forEach(n=>{var i,s;(s=(i=t.getRenderById(n))==null?void 0:i.scene.getTransformer())==null||s.debounceRefreshControls()}),!0}},Dn="COMPONENT_DOC_DRAWING_PANEL",tn={id:"sidebar.operation.doc-image",type:o.CommandType.COMMAND,handler:async(r,e)=>{const t=r.get(k.ISidebarService),n=r.get(o.LocaleService),i=r.get(X.IDrawingManagerService);switch(e.value){case"open":t.open({header:{title:n.t("docImage.panel.title")},children:{label:Dn},onClose:()=>{i.focusDrawing(null)},width:360});break;case"close":default:t.close();break}return!0}},rn={id:"doc.operation.edit-doc-image",type:o.CommandType.OPERATION,handler:(r,e)=>{const t=r.get(X.IDrawingManagerService),n=r.get(o.ICommandService);return e==null?!1:(t.focusDrawing([e]),n.executeCommand(tn.id,{value:"open"}),!0)}},Wn="univer-image-common-panel",Hn="univer-image-common-panel-grid",Gn="univer-image-common-panel-border",Vn="univer-image-common-panel-title",$n="univer-image-common-panel-subtitle",Xn="univer-image-common-panel-row",zn="univer-image-common-panel-column",qn="univer-image-common-panel-span2",Kn="univer-image-common-panel-input",v={imageCommonPanel:Wn,imageCommonPanelGrid:Hn,imageCommonPanelBorder:Gn,imageCommonPanelTitle:Vn,imageCommonPanelSubtitle:$n,imageCommonPanelRow:Xn,imageCommonPanelColumn:zn,imageCommonPanelSpan2:qn,imageCommonPanelInput:Kn},dn=-1e3,ln=1e3,Yn=r=>{const e=k.useDependency(o.ICommandService),t=k.useDependency(o.LocaleService),n=k.useDependency(X.IDrawingManagerService),i=k.useDependency(L.IRenderManagerService),s=k.useDependency(o.IUniverInstanceService),{drawings:a}=r,d=a[0];if(d==null)return;const{unitId:l}=d,c=s.getUniverDocInstance(l),g=c==null?void 0:c.getSnapshot().documentStyle.documentFlavor,h=i.getRenderById(l),m=h==null?void 0:h.scene;if(m==null)return;const f=m.getTransformerByCreate(),p=[{label:t.t("image-position.column"),value:String(o.ObjectRelativeFromH.COLUMN)},{label:t.t("image-position.page"),value:String(o.ObjectRelativeFromH.PAGE)},{label:t.t("image-position.margin"),value:String(o.ObjectRelativeFromH.MARGIN)}],w=[{label:t.t("image-position.line"),value:String(o.ObjectRelativeFromV.LINE),disabled:g===o.DocumentFlavor.MODERN},{label:t.t("image-position.page"),value:String(o.ObjectRelativeFromV.PAGE),disabled:g===o.DocumentFlavor.MODERN},{label:t.t("image-position.margin"),value:String(o.ObjectRelativeFromV.MARGIN),disabled:g===o.DocumentFlavor.MODERN},{label:t.t("image-position.paragraph"),value:String(o.ObjectRelativeFromV.PARAGRAPH)}],[S,I]=K.useState(!0),[T,y]=K.useState({relativeFrom:o.ObjectRelativeFromH.PAGE,posOffset:0}),[O,x]=K.useState({relativeFrom:o.ObjectRelativeFromV.PAGE,posOffset:0}),[M,A]=K.useState(!0),[H,E]=K.useState(!0);function _(C,P){var R;C==="positionH"?y(P):x(P);const b=n.getFocusDrawings();if(b.length===0)return;const B=b.map(j=>({unitId:j.unitId,subUnitId:j.subUnitId,drawingId:j.drawingId}));e.executeCommand(Pe.id,{unitId:b[0].unitId,subUnitId:b[0].unitId,drawings:B.map(j=>({drawingId:j.drawingId,key:C,value:P}))});const V=(R=i.getRenderById(l))==null?void 0:R.with(G.DocSelectionRenderService);V&&V.blur(),f.refreshControls()}function F(C){var ee,ge,me;const P=T.relativeFrom,b=T.posOffset,B=Number(C);if(P===B)return;const V=n.getFocusDrawings();if(V.length===0)return;const R=V[0].drawingId,j=V[0].unitId;let Y=null,$=0;const J=(ee=i.getRenderById(j))==null?void 0:ee.with(W.DocSkeletonManagerService).getSkeleton(),ne=J==null?void 0:J.getSkeletonData();if(ne==null)return;const{pages:Ce,skeHeaders:Ie,skeFooters:Oe}=ne;for(const ie of Ce){const{marginLeft:ue,skeDrawings:he,headerId:we,footerId:Se,pageWidth:pe}=ie;if(he.has(R)){Y=he.get(R),$=ue;break}const re=(ge=Ie.get(we))==null?void 0:ge.get(pe);if(re!=null&&re.skeDrawings.has(R)){Y=re==null?void 0:re.skeDrawings.get(R),$=ue;break}const oe=(me=Oe.get(Se))==null?void 0:me.get(pe);if(oe!=null&&oe.skeDrawings.has(R)){Y=oe==null?void 0:oe.skeDrawings.get(R),$=ue;break}}if(Y==null)return;let te=0;P===o.ObjectRelativeFromH.COLUMN?te-=Y.columnLeft:P===o.ObjectRelativeFromH.MARGIN&&(te-=$),B===o.ObjectRelativeFromH.COLUMN?te+=Y.columnLeft:B===o.ObjectRelativeFromH.MARGIN?te+=$:o.ObjectRelativeFromH.PAGE;const Q={relativeFrom:B,posOffset:(b!=null?b:0)-te};_("positionH",Q)}function z(C){var he,we,Se,pe,re,oe;const P=O.relativeFrom,b=O.posOffset,B=Number(C);if(P===B)return;const V=n.getFocusDrawings();if(V.length===0)return;const{drawingId:R,unitId:j}=V[0],Y=s.getUniverDocInstance(j),$=(he=i.getRenderById(j))==null?void 0:he.with(W.DocSkeletonManagerService).getSkeleton(),J=(we=i.getRenderById(j))==null?void 0:we.with(G.DocSelectionRenderService),ne=J==null?void 0:J.getSegment(),Ce=J==null?void 0:J.getSegmentPage(),Ie=(pe=(Se=Y==null?void 0:Y.getSelfOrHeaderFooterModel(ne).getBody())==null?void 0:Se.customBlocks)==null?void 0:pe.find(_e=>_e.blockId===R);if(Ie==null||$==null||J==null)return;const{startIndex:Oe}=Ie,te=$.findNodeByCharIndex(Oe,ne,Ce),Q=(re=te==null?void 0:te.parent)==null?void 0:re.parent,ee=Q==null?void 0:Q.parent,ge=ee==null?void 0:ee.lines.find(_e=>_e.paragraphIndex===(Q==null?void 0:Q.paragraphIndex)&&_e.paragraphStart),me=(oe=ee==null?void 0:ee.parent)==null?void 0:oe.parent;if(te==null||Q==null||ge==null||ee==null||me==null)return;let ie=0;P===o.ObjectRelativeFromV.PARAGRAPH?ie-=ge.top:P===o.ObjectRelativeFromV.LINE?ie-=Q.top:P===o.ObjectRelativeFromV.PAGE&&(ie+=me.marginTop),B===o.ObjectRelativeFromV.PARAGRAPH?ie+=ge.top:B===o.ObjectRelativeFromV.LINE?ie+=Q.top:B===o.ObjectRelativeFromV.PAGE&&(ie-=me.marginTop);const ue={relativeFrom:B,posOffset:(b!=null?b:0)-ie};_("positionV",ue)}function U(C){var j;const P=c==null?void 0:c.getSnapshot(),b=(j=P==null?void 0:P.drawings)==null?void 0:j[C.drawingId];if(b==null)return;const{layoutType:B}=b,{positionH:V,positionV:R}=b.docTransform;y(V),x(R),I(B===o.PositionedObjectLayoutType.INLINE),A(R.relativeFrom===o.ObjectRelativeFromV.PARAGRAPH||R.relativeFrom===o.ObjectRelativeFromV.LINE)}function q(){const C=n.getFocusDrawings();C.length!==0&&U(C[0])}function D(C){A(C),z(String(C?o.ObjectRelativeFromV.PARAGRAPH:o.ObjectRelativeFromV.PAGE))}return K.useEffect(()=>{q();const C=n.focus$.subscribe(b=>{if(b.length===0){E(!1);return}E(!0),U(b[0])}),P=e.onCommandExecuted(async b=>{b.id===W.RichTextEditingMutation.id&&q()});return()=>{C.unsubscribe(),P.dispose()}},[]),u.jsxs("div",{className:N.clsx(v.imageCommonPanelGrid,v.imageCommonPanelBorder),style:{display:H?"block":"none"},children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelTitle),children:u.jsx("div",{children:t.t("image-position.title")})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-position.horizontal")})})}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.absolutePosition")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:dn,max:ln,precision:1,disabled:S,value:T.posOffset,onChange:C=>{_("positionH",{relativeFrom:T.relativeFrom,posOffset:C})},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.toTheRightOf")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.Select,{value:String(T.relativeFrom),disabled:S,options:p,onChange:F})})})]})})]}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-position.vertical")})})}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.absolutePosition")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:dn,max:ln,precision:1,disabled:S,value:O.posOffset,onChange:C=>{_("positionV",{relativeFrom:O.relativeFrom,posOffset:C})},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.bellow")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.Select,{disabled:S,value:String(O.relativeFrom),options:w,onChange:z})})})]})})]}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-position.options")})})}),u.jsx("div",{className:v.imageCommonPanelRow,style:{marginBottom:"50px"},children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.Checkbox,{disabled:S,checked:M,onChange:D,children:t.t("image-position.moveObjectWithText")})})})]})},Ee=0,Ae=100,Jn=r=>{const e=k.useDependency(o.ICommandService),t=k.useDependency(o.LocaleService),n=k.useDependency(X.IDrawingManagerService),i=k.useDependency(L.IRenderManagerService),s=k.useDependency(o.IUniverInstanceService),{drawings:a}=r,d=a[0];if(d==null)return null;const{unitId:l}=d,c=s.getUniverDocInstance(l),g=i.getRenderById(l);if((g==null?void 0:g.scene)==null)return null;const[m,f]=K.useState(!0),[p,w]=K.useState(!0),[S,I]=K.useState(!0),[T,y]=K.useState(ae.INLINE),[O,x]=K.useState(""),[M,A]=K.useState({distT:0,distL:0,distB:0,distR:0}),[H,E]=K.useState(!0);function _(D){y(D);const C=n.getFocusDrawings();if(C.length===0)return;const{unitId:P,subUnitId:b}=C[0],B=C.map(({unitId:V,subUnitId:R,drawingId:j})=>({unitId:V,subUnitId:R,drawingId:j}));e.executeCommand(fn.id,{unitId:P,subUnitId:b,drawings:B,wrappingStyle:D})}function F(D){x(D);const C=n.getFocusDrawings();if(C.length===0)return;const P=C.map(b=>({unitId:b.unitId,subUnitId:b.subUnitId,drawingId:b.drawingId}));e.executeCommand(In.id,{unitId:C[0].unitId,subUnitId:C[0].unitId,drawings:P,wrapText:D})}function z(D,C){if(D==null)return;const P={...M,[C]:D};A(P);const b=n.getFocusDrawings();if(b.length===0)return;const B=b.map(V=>({unitId:V.unitId,subUnitId:V.subUnitId,drawingId:V.drawingId}));e.executeCommand(vn.id,{unitId:b[0].unitId,subUnitId:b[0].unitId,drawings:B,dist:{[C]:D}})}function U(){const D=n.getFocusDrawings();D.length!==0&&q(D[0])}function q(D){var J,ne;const C=(ne=(J=c==null?void 0:c.getSnapshot())==null?void 0:J.drawings)==null?void 0:ne[D.drawingId];if(C==null)return;const{distT:P=0,distL:b=0,distB:B=0,distR:V=0,layoutType:R=o.PositionedObjectLayoutType.INLINE,behindDoc:j=o.BooleanNumber.FALSE,wrapText:Y=o.WrapTextType.BOTH_SIDES}=C;if(A({distT:P,distL:b,distB:B,distR:V}),x(Y),f(R!==o.PositionedObjectLayoutType.WRAP_SQUARE),R===o.PositionedObjectLayoutType.WRAP_NONE||R===o.PositionedObjectLayoutType.INLINE?w(!0):w(!1),R===o.PositionedObjectLayoutType.WRAP_NONE||R===o.PositionedObjectLayoutType.INLINE||R===o.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM?I(!0):I(!1),R===o.PositionedObjectLayoutType.WRAP_NONE)j===o.BooleanNumber.TRUE?y(ae.BEHIND_TEXT):y(ae.IN_FRONT_OF_TEXT);else switch(R){case o.PositionedObjectLayoutType.INLINE:y(ae.INLINE);break;case o.PositionedObjectLayoutType.WRAP_SQUARE:y(ae.WRAP_SQUARE);break;case o.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM:y(ae.WRAP_TOP_AND_BOTTOM);break;default:throw new Error(`Unsupported layout type: ${R}`)}}return K.useEffect(()=>{U();const D=n.focus$.subscribe(P=>{if(P.length===0){E(!1);return}E(!0),q(P[0])}),C=e.onCommandExecuted(async P=>{P.id===W.RichTextEditingMutation.id&&U()});return()=>{D.unsubscribe(),C.dispose()}},[]),u.jsxs("div",{className:N.clsx(v.imageCommonPanelGrid,v.imageCommonPanelBorder),style:{display:H?"block":"none"},children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelTitle),children:u.jsx("div",{children:t.t("image-text-wrap.title")})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-text-wrap.wrappingStyle")})})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelRow),children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn),children:u.jsxs(N.RadioGroup,{value:T,onChange:_,direction:"vertical",children:[u.jsx(N.Radio,{value:ae.INLINE,children:t.t("image-text-wrap.inline")}),u.jsx(N.Radio,{value:ae.WRAP_SQUARE,children:t.t("image-text-wrap.square")}),u.jsx(N.Radio,{value:ae.WRAP_TOP_AND_BOTTOM,children:t.t("image-text-wrap.topAndBottom")}),u.jsx(N.Radio,{value:ae.BEHIND_TEXT,children:t.t("image-text-wrap.behindText")}),u.jsx(N.Radio,{value:ae.IN_FRONT_OF_TEXT,children:t.t("image-text-wrap.inFrontText")})]})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-text-wrap.wrapText")})})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelRow),children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn),children:u.jsxs(N.RadioGroup,{disabled:m,value:O,onChange:F,direction:"horizontal",children:[u.jsx(N.Radio,{value:o.WrapTextType.BOTH_SIDES,children:t.t("image-text-wrap.bothSide")}),u.jsx(N.Radio,{value:o.WrapTextType.LEFT,children:t.t("image-text-wrap.leftOnly")}),u.jsx(N.Radio,{value:o.WrapTextType.RIGHT,children:t.t("image-text-wrap.rightOnly")})]})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-text-wrap.distanceFromText")})})}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.top")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:p,precision:1,value:M.distT,onChange:D=>{z(D,"distT")},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.left")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:S,precision:1,value:M.distL,onChange:D=>{z(D,"distL")},className:v.imageCommonPanelInput})})})]})})]}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.bottom")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:p,precision:1,value:M.distB,onChange:D=>{z(D,"distB")},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.right")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:S,precision:1,value:M.distR,onChange:D=>{z(D,"distR")},className:v.imageCommonPanelInput})})})]})})]})]})},Zn=()=>{const r=k.useDependency(X.IDrawingManagerService),e=r.getFocusDrawings(),[t,n]=K.useState(e);return K.useEffect(()=>{const i=r.focus$.subscribe(s=>{n(s)});return()=>{i.unsubscribe()}},[]),!!(t!=null&&t.length)&&u.jsxs("div",{className:v.imageCommonPanel,children:[u.jsx(fe.DrawingCommonPanel,{drawings:t,hasAlign:!1,hasCropper:!1,hasGroup:!1,hasTransform:!1}),u.jsx(Jn,{drawings:t}),u.jsx(Yn,{drawings:t})]})},Cn="addition-and-subtraction-single",on="doc.menu.image",Tn=nn.id,Qn=r=>{const e=r.get(W.DocSelectionManagerService),t=r.get(o.IUniverInstanceService);return new Z.Observable(n=>{const i=e.textSelection$.subscribe(()=>{var a;const s=e.getActiveTextRange();if(s){const{segmentId:d,startOffset:l,endOffset:c}=s,g=t.getCurrentUniverDocInstance(),h=(a=g==null?void 0:g.getSelfOrHeaderFooterModel(d).getBody())==null?void 0:a.tables;if(h&&h.length&&h.some(m=>{const{startIndex:f,endIndex:p}=m;return l>=f&&l<p||c>=f&&c<p})){n.next(!0);return}}else{n.next(!0);return}n.next(!1)});return()=>i.unsubscribe()})};function et(r){return{id:on,type:k.MenuItemType.SUBITEMS,icon:Cn,tooltip:"docImage.title",disabled$:Qn(r),hidden$:k.getMenuHiddenObservable(r,o.UniverInstanceType.UNIVER_DOC,void 0,o.DOCS_ZEN_EDITOR_UNIT_ID_KEY)}}function nt(r){return{id:Tn,title:"docImage.upload.float",type:k.MenuItemType.BUTTON,hidden$:k.getMenuHiddenObservable(r,o.UniverInstanceType.UNIVER_DOC,void 0,o.DOCS_ZEN_EDITOR_UNIT_ID_KEY)}}const tt={[k.RibbonStartGroup.LAYOUT]:{[on]:{order:0,menuItemFactory:et,[Tn]:{order:0,menuItemFactory:nt}}}};function Ne(r){return r.getContextValue(o.FOCUSING_UNIVER_EDITOR)&&r.getContextValue(o.FOCUSING_COMMON_DRAWINGS)}const it={id:ye.id,description:"shortcut.drawing-move-down",group:"4_drawing-view",binding:k.KeyCode.ARROW_DOWN,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.DOWN}},rt={id:ye.id,description:"shortcut.drawing-move-up",group:"4_drawing-view",binding:k.KeyCode.ARROW_UP,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.UP}},ot={id:ye.id,description:"shortcut.drawing-move-left",group:"4_drawing-view",binding:k.KeyCode.ARROW_LEFT,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.LEFT}},st={id:ye.id,description:"shortcut.drawing-move-right",group:"4_drawing-view",binding:k.KeyCode.ARROW_RIGHT,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.RIGHT}},at={id:Je.id,description:"shortcut.drawing-delete",group:"4_drawing-view",preconditions:Ne,binding:k.KeyCode.DELETE,mac:k.KeyCode.BACKSPACE};var ct=Object.getOwnPropertyDescriptor,dt=(r,e,t,n)=>{for(var i=n>1?void 0:n?ct(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},je=(r,e)=>(t,n)=>e(t,n,r);let Fe=class extends o.Disposable{constructor(r,e,t,n){super(),this._componentManager=r,this._menuManagerService=e,this._commandService=t,this._shortcutService=n,this._init()}_initCustomComponents(){const r=this._componentManager;this.disposeWithMe(r.register(Cn,hn)),this.disposeWithMe(r.register(Dn,Zn))}_initMenus(){this._menuManagerService.mergeMenu(tt)}_initCommands(){[nn,Ve,fn,vn,In,Pe,wn,Sn,Ge,tn,_n,rn,Ze,en,ye,Je,Qe].forEach(r=>this.disposeWithMe(this._commandService.registerCommand(r)))}_initShortcuts(){[it,rt,ot,st,at].forEach(r=>{this.disposeWithMe(this._shortcutService.registerShortcut(r))})}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus(),this._initShortcuts()}};Fe=dt([je(0,o.Inject(k.ComponentManager)),je(1,k.IMenuManagerService),je(2,o.ICommandService),je(3,k.IShortcutService)],Fe);var lt=Object.getOwnPropertyDescriptor,gt=(r,e,t,n)=>{for(var i=n>1?void 0:n?lt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Me=(r,e)=>(t,n)=>e(t,n,r);function mt(r){var n,i,s,a;if(o.JSONX.isNoop(r)||!Array.isArray(r))return null;const e=r.find(d=>Array.isArray(d)&&(d==null?void 0:d[0])==="drawings");if(e==null||!Array.isArray(e)||e.length<3||typeof e[1]=="string"&&typeof e[2]!="object"||Array.isArray(e[1])&&typeof e[1][1]!="object")return null;const t=[];if(Array.isArray(e==null?void 0:e[1]))for(const d of e)Array.isArray(d)&&t.push({type:(n=d==null?void 0:d[1])!=null&&n.i?"add":"remove",drawingId:d==null?void 0:d[0],drawing:(i=d==null?void 0:d[1])==null?void 0:i.i});else t.push({type:(s=e[2])!=null&&s.i?"add":"remove",drawingId:e[1],drawing:(a=e[2])==null?void 0:a.i});return t}function ut(r){if(!Array.isArray(r)||r.length<3||r[0]!=="drawingsOrder")return[];const e=[];for(let t=1;t<r.length;t++){const n=r[t];if(Array.isArray(n)&&typeof n[0]=="number"&&typeof n[1]=="object")e.push(n[0]);else{e.length=0;break}}return e}let Be=class extends o.Disposable{constructor(r,e,t,n,i){super(),this._univerInstanceService=r,this._commandService=e,this._drawingManagerService=t,this._docDrawingService=n,this._renderManagerService=i,this._initialize()}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(r=>{if(r.id!==W.RichTextEditingMutation.id)return;const e=r.params,{unitId:t,actions:n}=e,i=mt(n);if(i!=null)for(const{type:s,drawingId:a,drawing:d}of i)s==="add"?this._addDrawings(t,[d]):this._removeDrawings(t,[a])})),this.disposeWithMe(this._commandService.onCommandExecuted(r=>{if(r.id!==W.RichTextEditingMutation.id)return;const e=r.params,{unitId:t,actions:n}=e;ut(n).length>0&&this._updateDrawingsOrder(t)})),this.disposeWithMe(this._commandService.onCommandExecuted(r=>{var a;if(r.id!==o.UndoCommand.id&&r.id!==o.RedoCommand.id)return;const e=(a=this._univerInstanceService.getCurrentUniverDocInstance())==null?void 0:a.getUnitId(),t=this._drawingManagerService.getFocusDrawings();if(e==null||t.length===0)return;const n=this._renderManagerService.getRenderById(e),i=n==null?void 0:n.scene;if(i==null)return!1;i.getTransformerByCreate().refreshControls()}))}_addDrawings(r,e){const t=this._drawingManagerService,n=this._docDrawingService,i=this._docDrawingService.getBatchAddOp(e),{subUnitId:s,redo:a,objects:d}=i;t.applyJson1(r,s,a),n.applyJson1(r,s,a),t.addNotification(d),n.addNotification(d)}_removeDrawings(r,e){const t=this._drawingManagerService,n=this._docDrawingService,i=this._docDrawingService.getBatchRemoveOp(e.map(l=>({unitId:r,subUnitId:r,drawingId:l}))),{subUnitId:s,redo:a,objects:d}=i;t.applyJson1(r,s,a),n.applyJson1(r,s,a),t.removeNotification(d),n.removeNotification(d)}_updateDrawingsOrder(r){const e=this._univerInstanceService.getUniverDocInstance(r);if(e==null)return;const t=e.getSnapshot().drawingsOrder;if(t==null)return;const n=this._drawingManagerService,i=this._docDrawingService;n.setDrawingOrder(r,r,t),i.setDrawingOrder(r,r,t);const s={unitId:r,subUnitId:r,drawingIds:t};n.orderNotification(s),i.orderNotification(s)}};Be=gt([Me(0,o.IUniverInstanceService),Me(1,o.ICommandService),Me(2,X.IDrawingManagerService),Me(3,ve.IDocDrawingService),Me(4,L.IRenderManagerService)],Be);var ht=Object.getOwnPropertyDescriptor,pt=(r,e,t,n)=>{for(var i=n>1?void 0:n?ht(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Te=(r,e)=>(t,n)=>e(t,n,r);function yn(r,e,t=1,n=0){const{top:i,left:s,bottom:a,right:d}=r,l=d-s,c=a-i,g=e.getViewport(G.VIEWPORT_KEY.VIEW_MAIN),{viewportScrollX:h,viewportScrollY:m}=g,{scaleX:f,scaleY:p}=e.getAncestorScale();return{startX:(s-h)*f,startY:(i-m)*p,endX:(s+l-h)*f,endY:(i+c-m)*p,width:l*f,height:c*p,rotate:n,absolute:{left:!1,top:!1},opacity:t!=null?t:1}}function qe(r,e){const{top:t,left:n,width:i,height:s,angle:a,opacity:d}=r;return yn({top:t,left:n,bottom:t+s,right:n+i},e.scene,d,a)}exports.DocFloatDomController=class extends o.Disposable{constructor(t,n,i,s,a,d){super();le(this,"_domLayerInfoMap",new Map);this._renderManagerService=t,this._drawingManagerService=n,this._drawingRenderService=i,this._canvasFloatDomService=s,this._univerInstanceService=a,this._commandService=d,this._initialize()}dispose(){super.dispose()}_initialize(){this._drawingAddRemoveListener(),this._initScrollAndZoomEvent()}_getSceneAndTransformerByDrawingSearch(t){if(t==null)return;const n=this._renderManagerService.getRenderById(t);if(n==null)return null;const i=n.scene,s=i.getTransformerByCreate();return{scene:i,transformer:s,renderUnit:n,canvas:n.engine.getCanvasElement()}}_drawingAddRemoveListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(t=>{this._insertRects(t)})),this.disposeWithMe(this._drawingManagerService.remove$.subscribe(t=>{t.forEach(n=>{this._removeDom(n.drawingId)})}))}_insertRects(t){t.forEach(async n=>{const{unitId:i}=n;if(!this._univerInstanceService.getUnit(i,o.UniverInstanceType.UNIVER_DOC))return;const a=this._getSceneAndTransformerByDrawingSearch(i);if(a==null)return;const d=this._drawingManagerService.getDrawingByParam(n);if(d==null)return;const l=await this._drawingRenderService.renderFloatDom(d,a.scene);if(!(l==null||l.length===0))for(const c of l){this._addHoverForRect(c);const g=new o.DisposableCollection,h=qe(c,a.renderUnit),m=new Z.BehaviorSubject(h),f=a.canvas,p=d.data,w={dispose:g,rect:c,position$:m,unitId:i};this._canvasFloatDomService.addFloatDom({position$:m,id:d.drawingId,componentKey:d.componentKey,onPointerDown:I=>{f.dispatchEvent(new PointerEvent(I.type,I))},onPointerMove:I=>{f.dispatchEvent(new PointerEvent(I.type,I))},onPointerUp:I=>{f.dispatchEvent(new PointerEvent(I.type,I))},onWheel:I=>{f.dispatchEvent(new WheelEvent(I.type,I))},data:p,unitId:i});const S=c.onTransformChange$.subscribeEvent(()=>{const I=qe(c,a.renderUnit);m.next(I)});g.add(()=>{this._canvasFloatDomService.removeFloatDom(d.drawingId)}),S&&g.add(S),this._domLayerInfoMap.set(d.drawingId,w)}})}_addHoverForRect(t){this.disposeWithMe(o.toDisposable(t.onPointerEnter$.subscribeEvent(()=>{t.cursor=L.CURSOR_TYPE.GRAB}))),this.disposeWithMe(o.toDisposable(t.onPointerLeave$.subscribeEvent(()=>{t.cursor=L.CURSOR_TYPE.DEFAULT})))}_removeDom(t){const n=this._domLayerInfoMap.get(t);if(!n)return;const{unitId:i}=n;this._domLayerInfoMap.delete(t),n.dispose.dispose();const s=this._getSceneAndTransformerByDrawingSearch(i);s&&s.scene.removeObject(n.rect)}_initScrollAndZoomEvent(){const t=n=>{const i=this._getSceneAndTransformerByDrawingSearch(n);i&&this._domLayerInfoMap.forEach(s=>{if(s.unitId!==n)return;const a=qe(s.rect,i.renderUnit);s.position$.next(a)})};this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_DOC).pipe(Z.map(n=>{if(!n)return null;const i=n.getUnitId(),s=this._renderManagerService.getRenderById(i);return s?{render:s,unitId:i}:null}),Z.switchMap(n=>n?o.fromEventSubject(n.render.scene.getViewport(G.VIEWPORT_KEY.VIEW_MAIN).onScrollAfter$).pipe(Z.map(()=>({unitId:n.unitId}))):Z.of(null))).subscribe(n=>{if(!n)return;const{unitId:i}=n;t(i)})),this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(n.id===G.SetDocZoomRatioOperation.id){const i=n.params,{unitId:s}=i;t(s)}}))}insertFloatDom(t,n){var S,I,T;const i=this._univerInstanceService.getCurrentUnitOfType(o.UniverInstanceType.UNIVER_DOC);if(!i)return!1;const s=this._getSceneAndTransformerByDrawingSearch(i.getUnitId());if(!s)return!1;const l=(S=s.renderUnit.with(W.DocSkeletonManagerService).getSkeleton().getSkeletonData())==null?void 0:S.pages[0];if(!l)return!1;const{pageWidth:c,marginLeft:g,marginRight:h}=l,m=c-g-h,f={size:{width:(I=n.width)!=null?I:m,height:n.height},positionH:{relativeFrom:o.ObjectRelativeFromH.PAGE,posOffset:0},positionV:{relativeFrom:o.ObjectRelativeFromV.PAGE,posOffset:0},angle:0},p=(T=n.drawingId)!=null?T:o.generateRandomId(),w={unitId:i.getUnitId(),drawings:[{drawingId:p,drawingType:o.DrawingTypeEnum.DRAWING_DOM,subUnitId:i.getUnitId(),unitId:i.getUnitId(),...t,title:"",description:"",docTransform:f,layoutType:o.PositionedObjectLayoutType.INLINE,transform:G.docDrawingPositionToTransform(f)}]};return this._commandService.syncExecuteCommand(Ve.id,w),p}};exports.DocFloatDomController=pt([Te(0,L.IRenderManagerService),Te(1,X.IDrawingManagerService),Te(2,o.Inject(fe.DrawingRenderService)),Te(3,o.Inject(k.CanvasFloatDomService)),Te(4,o.IUniverInstanceService),Te(5,o.ICommandService)],exports.DocFloatDomController);const ft=r=>{const{floatDomInfos:e,scene:t,offset:n}=r,i=K.useMemo(()=>e.map(s=>{const{width:a,height:d,left:l,top:c}=s.transform,h=yn({left:l!=null?l:0-n.x,right:(l!=null?l:0)+(a!=null?a:0)-n.x,top:c!=null?c:0-n.y,bottom:(c!=null?c:0)+(d!=null?d:0)-n.y},t),m={position$:new Z.BehaviorSubject(h),position:h,id:s.drawingId,componentKey:s.componentKey,onPointerMove:()=>{},onPointerDown:()=>{},onPointerUp:()=>{},onWheel:()=>{},unitId:s.unitId};return[s.drawingId,m]}),[e,t,n]);return u.jsx("div",{style:{position:"absolute",top:0,left:0},children:i.map(([s,a])=>u.jsx(k.PrintFloatDomSingle,{layer:a,id:s,position:a.position},s))})};var vt=Object.getOwnPropertyDescriptor,It=(r,e,t,n)=>{for(var i=n>1?void 0:n?vt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Re=(r,e)=>(t,n)=>e(t,n,r);let ke=class extends o.Disposable{constructor(r,e,t,n,i){super(),this._docPrintInterceptorService=r,this._drawingRenderService=e,this._drawingManagerService=t,this._componetManager=n,this._injector=i,this._initPrinting(),this._initPrintingDom()}_initPrinting(){this.disposeWithMe(this._docPrintInterceptorService.interceptor.intercept(this._docPrintInterceptorService.interceptor.getInterceptPoints().PRINTING_COMPONENT_COLLECT,{handler:(r,e,t)=>{const{unitId:n,scene:i}=e,s=this._drawingManagerService.getDrawingDataForUnit(n),a=s==null?void 0:s[n];return a&&a.order.forEach(d=>{const l=a.data[d];l.drawingType!==o.DrawingTypeEnum.DRAWING_CHART&&l.drawingType!==o.DrawingTypeEnum.DRAWING_DOM&&this._drawingRenderService.renderDrawing(l,i)}),t()}}))}_initPrintingDom(){this.disposeWithMe(this._docPrintInterceptorService.interceptor.intercept(this._docPrintInterceptorService.interceptor.getInterceptPoints().PRINTING_DOM_COLLECT,{handler:(r,e,t)=>{const{unitId:n}=e,i=this._drawingManagerService.getDrawingDataForUnit(n),s=i==null?void 0:i[n];if(s){const a=s.order.map(l=>{const c=s.data[l];return c.drawingType===o.DrawingTypeEnum.DRAWING_CHART?{...c,componentKey:this._componetManager.get(o.PRINT_CHART_COMPONENT_KEY)}:c.drawingType===o.DrawingTypeEnum.DRAWING_DOM?{...c,componentKey:this._componetManager.get(c.componentKey)}:null}).filter(Boolean),d=k.connectInjector(ft,this._injector);return N.render(u.jsx(d,{unitId:n,floatDomInfos:a,scene:e.scene,skeleton:e.skeleton,offset:e.offset}),e.root),r==null||r.add(()=>{N.unmount(e.root)}),t(r)}}}))}};ke=It([Re(0,o.Inject(G.DocPrintInterceptorService)),Re(1,o.Inject(fe.DrawingRenderService)),Re(2,X.IDrawingManagerService),Re(3,o.Inject(k.ComponentManager)),Re(4,o.Inject(o.Injector))],ke);var wt=Object.getOwnPropertyDescriptor,St=(r,e,t,n)=>{for(var i=n>1?void 0:n?wt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Ue=(r,e)=>(t,n)=>e(t,n,r);const _t="__InlineDrawingAnchor__";function gn(r){const{path:e}=r;return e.some(t=>t==="cells")}let We=class extends o.Disposable{constructor(e,t,n,i){super();le(this,"_liquid",new L.Liquid);le(this,"_listenerOnImageMap",new Set);le(this,"_transformerCache",new Map);le(this,"_anchorShape");this._commandService=e,this._univerInstanceService=t,this._drawingManagerService=n,this._renderManagerService=i,this._init()}_init(){this._listenDrawingFocus()}_listenDrawingFocus(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(e=>{if(e.length!==0)for(const t of e){const{unitId:n}=t;this._listenerOnImageMap.has(n)||(this._listenTransformerChange(n),this._listenerOnImageMap.add(n))}}))}_listenTransformerChange(e){var i;const t=(i=this._getSceneAndTransformerByDrawingSearch(e))==null?void 0:i.transformer;if(t==null)return;this.disposeWithMe(o.toDisposable(t.changeStart$.subscribe(s=>{var d;this._transformerCache.clear();const{objects:a}=s;for(const l of a.values()){const{oKey:c,width:g,height:h,left:m,top:f,angle:p}=l,w=this._drawingManagerService.getDrawingOKey(c);if(w==null)continue;const S=this._univerInstanceService.getUniverDocInstance(w.unitId),I=(d=S==null?void 0:S.getSnapshot().drawings)==null?void 0:d[w.drawingId];if((I==null?void 0:I.layoutType)===o.PositionedObjectLayoutType.INLINE)try{l.setOpacity(.2)}catch{}I!=null&&this._transformerCache.set(w.drawingId,{drawing:I,top:f,left:m,width:g,height:h,angle:p})}})));const n=o.throttle(this._updateMultipleDrawingDocTransform.bind(this),50);o.throttle(this._nonInlineDrawingTransform.bind(this),50),this.disposeWithMe(o.toDisposable(t.changing$.subscribe(s=>{const{objects:a,offsetX:d,offsetY:l}=s;if(a.size>1)n(a);else if(a.size===1){const c=this._transformerCache.values().next().value,g=a.values().next().value,{width:h,height:m,top:f,left:p,angle:w}=g;if(c&&h===c.width&&m===c.height&&f===c.top&&p===c.left&&w===c.angle)return;c&&(c.drawing.layoutType,o.PositionedObjectLayoutType.INLINE),c&&c.drawing.layoutType===o.PositionedObjectLayoutType.INLINE&&d!=null&&l!=null&&this._updateInlineDrawingAnchor(c.drawing,d,l)}}))),this.disposeWithMe(o.toDisposable(t.changeEnd$.subscribe(s=>{const{objects:a,offsetX:d,offsetY:l}=s;for(const c of a.values()){const g=this._drawingManagerService.getDrawingOKey(c.oKey);if(g==null)continue;const h=this._transformerCache.get(g==null?void 0:g.drawingId);if((h==null?void 0:h.drawing.layoutType)===o.PositionedObjectLayoutType.INLINE)try{c.setOpacity(1)}catch{}}if(this._anchorShape&&this._anchorShape.hide(),a.size>1)this._updateMultipleDrawingDocTransform(a);else if(a.size===1){const c=this._transformerCache.values().next().value,g=a.values().next().value,{width:h,height:m,top:f,left:p,angle:w}=g;if(c&&h===c.width&&m===c.height&&f===c.top&&p===c.left&&w===c.angle)return;c&&c.drawing.layoutType===o.PositionedObjectLayoutType.INLINE?h!==c.width||m!==c.height||w!==c.angle?this._updateDrawingSize(c,g):d!=null&&l!=null&&this._moveInlineDrawing(c.drawing,d,l):c&&this._nonInlineDrawingTransform(c.drawing,g)}this._transformerCache.clear()})))}_updateMultipleDrawingDocTransform(e){if(e.size<1)return;const t=[];let n,i;for(const s of e.values()){const{oKey:a,left:d,top:l,angle:c}=s;let{width:g,height:h}=s;const m=this._drawingManagerService.getDrawingOKey(a);if(m==null)continue;n==null&&(n=m.unitId),i==null&&(i=m.subUnitId);const f=this._transformerCache.get(m.drawingId);if(f==null)continue;const{drawing:p,top:w,left:S,width:I,height:T,angle:y}=f,{width:O,height:x}=this._getPageContentSize(p);if(g=Math.min(g,O),h=Math.min(h,x),(I!==g||T!==h)&&t.push({drawingId:m.drawingId,key:"size",value:{width:g,height:h}}),y!==c&&t.push({drawingId:m.drawingId,key:"angle",value:c}),w!==l||S!==d){const M=l-w,A=d-S;M!==0&&t.push({drawingId:m.drawingId,key:"positionV",value:{relativeFrom:p.docTransform.positionV.relativeFrom,posOffset:p.docTransform.positionV.posOffset+M}}),A!==0&&t.push({drawingId:m.drawingId,key:"positionH",value:{relativeFrom:p.docTransform.positionH.relativeFrom,posOffset:p.docTransform.positionH.posOffset+A}})}}t.length>0&&n&&i&&this._commandService.executeCommand(Pe.id,{unitId:n,subUnitId:i,drawings:t})}_updateDrawingAnchor(e){if(this._transformerCache.size!==1)return;const t=this._transformerCache.values().next().value,n=e.values().next().value;this._getDrawingAnchor(t.drawing,n)}_updateInlineDrawingAnchor(e,t,n){var s;if(this._transformerCache.size!==1)return;const{contentBoxPointGroup:i}=(s=this._getInlineDrawingAnchor(e,t,n))!=null?s:{};i!=null&&this._createOrUpdateInlineAnchor(e.unitId,i)}_getInlineDrawingAnchor(e,t,n){var U,q;const i=this._renderManagerService.getRenderById(e.unitId),s=i==null?void 0:i.with(W.DocSkeletonManagerService).getSkeleton();if(i==null)return;const{mainComponent:a,scene:d}=i,l=a,c=d.getViewports()[0],{pageLayoutType:g=L.PageLayoutType.VERTICAL,pageMarginLeft:h,pageMarginTop:m}=l.getOffsetConfig();let f=null,p=!1,w=-1,S="";const I=.5,T=this._getTransformCoordForDocumentOffset(l,c,t,n);if(T==null)return;const y=(U=this._renderManagerService.getRenderById(e.unitId))==null?void 0:U.with(G.DocSelectionRenderService);if(y==null)return;const O=s==null?void 0:s.findNodeByCoord(T,g,h,m,{strict:!1,segmentId:y.getSegment(),segmentPage:y.getSegmentPage()});if(O){const{node:D,ratioX:C,segmentPage:P,segmentId:b}=O;p=C<I,f=D,w=P,S=b}if(f==null)return;const x=s==null?void 0:s.findPositionByGlyph(f,w),M=this._getDocObject();if(x==null||s==null||M==null||gn(x))return;const A={...x,isBack:p},H=M.document.getOffsetConfig(),E=new G.NodePositionConvertToCursor(H,s),{cursorList:_,contentBoxPointGroup:F}=E.getRangePointData(A,A),{startOffset:z}=(q=G.getOneTextSelectionRange(_))!=null?q:{};if(z!=null)return{offset:z,contentBoxPointGroup:F,segmentId:S,segmentPage:w}}_getDrawingAnchor(e,t){var ge,me,ie,ue,he,we,Se,pe,re,oe,_e;const n=this._renderManagerService.getRenderById(e.unitId),i=n==null?void 0:n.with(W.DocSkeletonManagerService).getSkeleton(),s=i==null?void 0:i.getSkeletonData();if(s==null||n==null)return;const{pages:a,skeHeaders:d,skeFooters:l}=s,{mainComponent:c,scene:g}=n,h=c,m=g.getViewports()[0],{pageLayoutType:f=L.PageLayoutType.VERTICAL,pageMarginLeft:p,pageMarginTop:w,docsLeft:S,docsTop:I}=h.getOffsetConfig(),{left:T,top:y,angle:O}=t;let{width:x,height:M}=t;const{positionV:A,positionH:H}=e.docTransform,{width:E,height:_}=this._getPageContentSize(e);x=Math.min(x,E),M=Math.min(M,_);let F=null,z="",U=-1;const q=!1,D={...e.docTransform,size:{width:x,height:M},angle:O},{x:C,y:P}=g.getViewportScrollXY(m),b=this._getTransformCoordForDocumentOffset(h,m,T-C,y-P);if(b==null)return;const B=(ge=this._renderManagerService.getRenderById(e.unitId))==null?void 0:ge.with(G.DocSelectionRenderService);if(B==null)return;const V=i==null?void 0:i.findNodeByCoord(b,f,p,w,{strict:!1,segmentId:B.getSegment(),segmentPage:B.getSegmentPage()});if(V){const{node:de,segmentPage:Xe,segmentId:ze}=V;F=de,U=Xe,z=ze}if(F==null)return;const R=(me=F.parent)==null?void 0:me.parent,j=R==null?void 0:R.parent,Y=(ie=j==null?void 0:j.lines.find(de=>de.paragraphIndex===(R==null?void 0:R.paragraphIndex)&&de.paragraphStart))!=null?ie:j==null?void 0:j.lines[0],$=(ue=j==null?void 0:j.parent)==null?void 0:ue.parent;if(R==null||j==null||Y==null||$==null)return;this._liquid.reset();const J=$.type;for(const de of a){const{headerId:Xe,footerId:ze,pageHeight:bn,pageWidth:sn,marginLeft:an,marginBottom:Mn}=de,Rn=a.indexOf(de);if(U>-1&&Rn===U){switch(J){case L.DocumentSkeletonPageType.HEADER:{const be=(he=d.get(Xe))==null?void 0:he.get(sn);if(be)this._liquid.translatePagePadding({marginTop:be.marginTop,marginLeft:an});else throw new Error("header skeleton not found");break}case L.DocumentSkeletonPageType.FOOTER:{const be=(we=l.get(ze))==null?void 0:we.get(sn);if(be)this._liquid.translatePagePadding({marginTop:bn-Mn+be.marginTop,marginLeft:an});else throw new Error("footer skeleton not found");break}}break}if(this._liquid.translatePagePadding(de),de===$)break;this._liquid.restorePagePadding(de),this._liquid.translatePage(de,f,p,w)}switch(A.relativeFrom===o.ObjectRelativeFromV.LINE?F=R.divides[0].glyphGroup[0]:F=(oe=(re=(pe=(Se=Y.divides)==null?void 0:Se[0])==null?void 0:pe.glyphGroup)==null?void 0:re[0])!=null?oe:F,D.positionH={relativeFrom:H.relativeFrom,posOffset:T-this._liquid.x-S},H.relativeFrom){case o.ObjectRelativeFromH.MARGIN:{D.positionH.posOffset=T-this._liquid.x-S-$.marginLeft;break}case o.ObjectRelativeFromH.COLUMN:{D.positionH.posOffset=T-this._liquid.x-S-j.left;break}}switch(D.positionV={relativeFrom:A.relativeFrom,posOffset:y-this._liquid.y-I},A.relativeFrom){case o.ObjectRelativeFromV.PAGE:{D.positionV.posOffset=y-this._liquid.y-I-$.marginTop;break}case o.ObjectRelativeFromV.LINE:{D.positionV.posOffset=y-this._liquid.y-I-R.top;break}case o.ObjectRelativeFromV.PARAGRAPH:{D.positionV.posOffset=y-this._liquid.y-I-Y.top;break}}if(F==null)return;const ne=i==null?void 0:i.findPositionByGlyph(F,U),Ce=this._getDocObject();if(ne==null||i==null||Ce==null||gn(ne))return;const Ie={...ne,isBack:q},Oe=Ce.document.getOffsetConfig(),te=new G.NodePositionConvertToCursor(Oe,i),{cursorList:Q}=te.getRangePointData(Ie,Ie),{startOffset:ee}=(_e=G.getOneTextSelectionRange(Q))!=null?_e:{};if(ee!=null)return{offset:ee,docTransform:D,segmentId:z,segmentPage:U}}_updateDrawingSize(e,t){const n=[],{drawing:i,width:s,height:a,angle:d}=e,{unitId:l,subUnitId:c}=i;let{width:g,height:h,angle:m}=t;const{width:f,height:p}=this._getPageContentSize(i);g=Math.min(f,g),h=Math.min(p,h),(g!==s||h!==a)&&n.push({drawingId:i.drawingId,key:"size",value:{width:g,height:h}}),m!==d&&n.push({drawingId:i.drawingId,key:"angle",value:m}),n.length>0&&l&&c&&this._commandService.executeCommand(Pe.id,{unitId:l,subUnitId:c,drawings:n})}_moveInlineDrawing(e,t,n){const i=this._getInlineDrawingAnchor(e,t,n),{offset:s,segmentId:a,segmentPage:d}=i!=null?i:{};return this._commandService.executeCommand(wn.id,{unitId:e.unitId,subUnitId:e.unitId,drawing:e,offset:s,segmentId:a,segmentPage:d,needRefreshDrawings:s==null})}_limitDrawingInPage(e,t){const n=this._renderManagerService.getRenderById(e.unitId),{left:i,top:s,width:a,height:d,angle:l}=t,c=n==null?void 0:n.with(W.DocSkeletonManagerService).getSkeleton(),g=c==null?void 0:c.getSkeletonData(),{pages:h}=g!=null?g:{};if(g==null||n==null||h==null)return{left:i,top:s,width:a,height:d,angle:l};const{mainComponent:m}=n,f=m,{top:p,pageLayoutType:w,pageMarginLeft:S,pageMarginTop:I}=f;let T=s;this._liquid.reset();for(const y of h){const{marginBottom:O,pageHeight:x}=y,M=h.indexOf(y),A=h[M+1];if(A==null)continue;if(o.Tools.hasIntersectionBetweenTwoRanges(s,s+d,this._liquid.y+p+x-O,this._liquid.y+p+x+I+A.marginTop)){const E=s+d/2,_=this._liquid.y+p+x+I/2;E<_?T=Math.min(s,this._liquid.y+p+x-O-d):T=Math.max(s,this._liquid.y+p+x+I+A.marginTop)}this._liquid.translatePage(y,w,S,I)}return{left:i,top:T,width:a,height:d,angle:l}}_nonInlineDrawingTransform(e,t,n=!1){const i=e.isMultiTransform===o.BooleanNumber.TRUE?t:this._limitDrawingInPage(e,t);if(n&&i.top!==t.top)return;const s=this._getDrawingAnchor(e,i),{offset:a,docTransform:d,segmentId:l,segmentPage:c}=s!=null?s:{};return a==null||d==null?this._updateMultipleDrawingDocTransform(new Map([[e.drawingId,t]])):this._commandService.executeCommand(Sn.id,{unitId:e.unitId,subUnitId:e.unitId,drawing:e,offset:a,docTransform:d,segmentId:l,segmentPage:c})}_getSceneAndTransformerByDrawingSearch(e){if(e==null)return;const t=this._renderManagerService.getRenderById(e),n=t==null?void 0:t.scene;if(n==null)return;const i=n.getTransformerByCreate();return{scene:n,transformer:i}}_getTransformCoordForDocumentOffset(e,t,n,i){const{documentTransform:s}=e.getOffsetConfig(),a=t.transformVector2SceneCoord(L.Vector2.FromArray([n,i]));if(a)return s.clone().invert().applyPoint(a)}_createOrUpdateInlineAnchor(e,t){const n=this._renderManagerService.getRenderById(e);if(n==null)return;const{mainComponent:i,scene:s}=n,a=i,{docsLeft:d,docsTop:l}=a.getOffsetConfig(),c=G.getAnchorBounding(t),{left:g,top:h,height:m}=c,f=g+d,p=h+l;if(this._anchorShape){this._anchorShape.transformByState({left:f,top:p,height:m}),this._anchorShape.show();return}const w=6,S=new L.Rect(_t+o.Tools.generateRandomId(w),{left:f,top:p,height:m,strokeWidth:2,stroke:L.getColor(o.COLORS.darkGray,1),evented:!1});this._anchorShape=S,s.addObject(S,G.TEXT_RANGE_LAYER_INDEX)}_getDocObject(){return G.getDocObject(this._univerInstanceService,this._renderManagerService)}_getPageContentSize(e){const t=this._renderManagerService.getRenderById(e.unitId),n=t==null?void 0:t.with(W.DocSkeletonManagerService).getSkeleton(),i=500,s=500,a=n==null?void 0:n.getSkeletonData();if(a==null||t==null)return{width:i,height:s};const{pages:d}=a;let l=null;for(const c of d){const{skeDrawings:g}=c;if(g.has(e.drawingId)){l=c;break}}if(l){const{pageWidth:c,pageHeight:g,marginLeft:h,marginBottom:m,marginRight:f,marginTop:p}=l;return{width:Math.max(i,c-h-f),height:Math.max(s,g-p-m)}}else return{width:i,height:s}}};We=St([Ue(0,o.ICommandService),Ue(1,o.IUniverInstanceService),Ue(2,X.IDrawingManagerService),Ue(3,L.IRenderManagerService)],We);var Dt=Object.getOwnPropertyDescriptor,Ct=(r,e,t,n)=>{for(var i=n>1?void 0:n?Dt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},xe=(r,e)=>(t,n)=>e(t,n,r);let He=class extends o.RxDisposable{constructor(e,t,n,i,s){super();le(this,"_initImagePopupMenu",new Set);this._drawingManagerService=e,this._canvasPopManagerService=t,this._renderManagerService=n,this._univerInstanceService=i,this._contextService=s,this._init()}_init(){this._univerInstanceService.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_DOC).pipe(Z.takeUntil(this.dispose$)).subscribe(e=>this._create(e)),this._univerInstanceService.getTypeOfUnitDisposed$(o.UniverInstanceType.UNIVER_DOC).pipe(Z.takeUntil(this.dispose$)).subscribe(e=>this._dispose(e)),this._univerInstanceService.getAllUnitsForType(o.UniverInstanceType.UNIVER_DOC).forEach(e=>this._create(e))}_dispose(e){const t=e.getUnitId();this._renderManagerService.removeRender(t)}_create(e){if(!e)return;const t=e.getUnitId();this._renderManagerService.has(t)&&!this._initImagePopupMenu.has(t)&&(this._popupMenuListener(t),this._initImagePopupMenu.add(t))}_hasCropObject(e){const t=e.getAllObjects();for(const n of t)if(n instanceof fe.ImageCropperObject)return!0;return!1}_popupMenuListener(e){var s;const t=(s=this._renderManagerService.getRenderById(e))==null?void 0:s.scene;if(!t)return;const n=t.getTransformerByCreate();if(!n)return;const i=[];this.disposeWithMe(o.toDisposable(n.createControl$.subscribe(()=>{if(this._hasCropObject(t))return;const a=n.getSelectedObjectMap();if(i.forEach(I=>I.dispose()),i.length=0,a.size>1)return;const d=a.values().next().value;if(!d)return;const l=d.oKey,c=this._drawingManagerService.getDrawingOKey(l);if(!c||c.drawingType===o.DrawingTypeEnum.DRAWING_DOM)return;const{unitId:g,subUnitId:h,drawingId:m,drawingType:f}=c,p=this._canvasPopManagerService.attachPopupToObject(d,{componentKey:fe.COMPONENT_IMAGE_POPUP_MENU,direction:"horizontal",offset:[2,0],extraProps:{menuItems:this._getImageMenuItems(g,h,m,f)}},g);i.push(this.disposeWithMe(p)),!this._drawingManagerService.getFocusDrawings().find(I=>I.unitId===g&&I.subUnitId===h&&I.drawingId===m)&&this._drawingManagerService.focusDrawing([{unitId:g,subUnitId:h,drawingId:m}])}))),this.disposeWithMe(o.toDisposable(n.clearControl$.subscribe(()=>{i.forEach(a=>a.dispose()),i.length=0,this._contextService.setContextValue(o.FOCUSING_COMMON_DRAWINGS,!1),this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(o.toDisposable(n.changing$.subscribe(()=>{i.forEach(a=>a.dispose()),i.length=0}))),this.disposeWithMe(o.toDisposable(n.changeStart$.subscribe(()=>{i.forEach(a=>a.dispose()),i.length=0})))}_getImageMenuItems(e,t,n,i){return[{label:"image-popup.edit",index:0,commandId:rn.id,commandParams:{unitId:e,subUnitId:t,drawingId:n},disable:!0},{label:"image-popup.delete",index:1,commandId:Ge.id,commandParams:{unitId:e,drawings:[{unitId:e,subUnitId:t,drawingId:n}]},disable:!1},{label:"image-popup.crop",index:2,commandId:fe.OpenImageCropOperation.id,commandParams:{unitId:e,subUnitId:t,drawingId:n},disable:!0},{label:"image-popup.reset",index:3,commandId:fe.ImageResetSizeOperation.id,commandParams:[{unitId:e,subUnitId:t,drawingId:n}],disable:!0}]}};He=Ct([xe(0,X.IDrawingManagerService),xe(1,o.Inject(G.DocCanvasPopManagerService)),xe(2,L.IRenderManagerService),xe(3,o.IUniverInstanceService),xe(4,o.IContextService)],He);var Tt=Object.getOwnPropertyDescriptor,yt=(r,e,t,n)=>{for(var i=n>1?void 0:n?Tt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},De=(r,e)=>(t,n)=>e(t,n,r);let Ye=class extends o.Disposable{constructor(e,t,n,i,s,a,d,l){super();le(this,"_liquid",new L.Liquid);this._context=e,this._docSkeletonManagerService=t,this._commandService=n,this._editorService=i,this._drawingManagerService=s,this._docRefreshDrawingsService=a,this._univerInstanceService=d,this._lifecycleService=l,this._initialize(),this._commandExecutedListener()}_initialize(){this._initialRenderRefresh(),this._drawingInitializeListener(),this._initResize()}_initialRenderRefresh(){this._docSkeletonManagerService.currentSkeleton$.subscribe(e=>{e!=null&&this._refreshDrawing(e)}),this._docRefreshDrawingsService.refreshDrawings$.subscribe(e=>{e!=null&&this._refreshDrawing(e)})}_commandExecutedListener(){const e=[W.RichTextEditingMutation.id,G.SetDocZoomRatioOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(e.includes(t.id)){const n=t.params,{unitId:i}=n,{unitId:s,mainComponent:a}=this._context;if(i!==s)return;const d=this._docSkeletonManagerService.getSkeleton();if(d==null)return;if(this._editorService.isEditor(s)&&s!==o.DOCS_ZEN_EDITOR_UNIT_ID_KEY){a==null||a.makeDirty();return}this._refreshDrawing(d)}}))}_initResize(){this.disposeWithMe(o.fromEventSubject(this._context.engine.onTransformChange$).pipe(Z.filter(e=>e.type===L.TRANSFORM_CHANGE_OBSERVABLE_TYPE.resize),Z.debounceTime(16)).subscribe(()=>{var n;const e=this._docSkeletonManagerService.getSkeleton(),{scene:t}=this._context;(n=t.getTransformer())==null||n.refreshControls(),this._refreshDrawing(e)}))}_refreshDrawing(e){var T,y;const t=e==null?void 0:e.getSkeletonData(),{mainComponent:n,unitId:i}=this._context,s=n;if(!t)return;const{left:a,top:d,pageLayoutType:l,pageMarginLeft:c,pageMarginTop:g}=s,{pages:h,skeHeaders:m,skeFooters:f}=t,p={};this._liquid.reset();for(let O=0,x=h.length;O<x;O++){const M=h[O],{headerId:A,footerId:H,pageWidth:E}=M;if(A){const _=(T=m.get(A))==null?void 0:T.get(E);_&&this._calculateDrawingPosition(i,_,a,d,p,_.marginTop,M.marginLeft)}if(H){const _=(y=f.get(H))==null?void 0:y.get(E);_&&this._calculateDrawingPosition(i,_,a,d,p,M.pageHeight-M.marginBottom+_.marginTop,M.marginLeft)}this._calculateDrawingPosition(i,M,a,d,p,M.marginTop,M.marginLeft),this._liquid.translatePage(M,l,c,g)}const w=Object.values(p),S=w.filter(O=>!O.isMultiTransform),I=w.filter(O=>O.isMultiTransform);S.length>0&&this._drawingManagerService.refreshTransform(S),this._handleMultiDrawingsTransform(I)}_handleMultiDrawingsTransform(e){const{scene:t,unitId:n}=this._context,i=t.getTransformerByCreate();e.forEach(l=>{const c=this._drawingManagerService.getDrawingByParam(l);c!=null&&(c.transform=l.transform,c.transforms=l.transforms,c.isMultiTransform=l.isMultiTransform)});const a=[...i.getSelectedObjectMap().keys()],d=Object.values(this._drawingManagerService.getDrawingData(n,n)).filter(l=>l.isMultiTransform===o.BooleanNumber.TRUE);this._drawingManagerService.removeNotification(d),e.length>0&&this._drawingManagerService.addNotification(e);for(const l of a){const c=t.getObject(l);c&&i.setSelectedControl(c)}}_calculateDrawingPosition(e,t,n,i,s,a,d){const{skeDrawings:l}=t;this._liquid.translatePagePadding({marginTop:a,marginLeft:d}),l.forEach(c=>{const{aLeft:g,aTop:h,height:m,width:f,angle:p,drawingId:w,drawingOrigin:S}=c,I=S.layoutType===o.PositionedObjectLayoutType.WRAP_NONE&&S.behindDoc===o.BooleanNumber.TRUE,{isMultiTransform:T=o.BooleanNumber.FALSE}=S,y={left:g+n+this._liquid.x,top:h+i+this._liquid.y,width:f,height:m,angle:p};s[w]==null?s[w]={unitId:e,subUnitId:e,drawingId:w,behindText:I,transform:y,transforms:[y],isMultiTransform:T}:T===o.BooleanNumber.TRUE&&s[w].transforms.push(y)}),this._liquid.restorePagePadding({marginTop:a,marginLeft:d})}_drawingInitializeListener(){const e=()=>{const t=this._docSkeletonManagerService.getSkeleton();t!=null&&(this._refreshDrawing(t),this._drawingManagerService.initializeNotification(this._context.unitId))};this._lifecycleService.stage>=o.LifecycleStages.Rendered?this._docSkeletonManagerService.getSkeleton()?e():setTimeout(e,500):this._lifecycleService.lifecycle$.pipe(Z.filter(t=>t===o.LifecycleStages.Rendered)).subscribe(e)}};Ye=yt([De(1,o.Inject(W.DocSkeletonManagerService)),De(2,o.ICommandService),De(3,G.IEditorService),De(4,X.IDrawingManagerService),De(5,o.Inject($e)),De(6,o.IUniverInstanceService),De(7,o.Inject(o.LifecycleService))],Ye);var Ot=Object.defineProperty,bt=Object.getOwnPropertyDescriptor,Mt=(r,e,t)=>e in r?Ot(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,Rt=(r,e,t,n)=>{for(var i=n>1?void 0:n?bt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Ke=(r,e)=>(t,n)=>e(t,n,r),On=(r,e,t)=>Mt(r,typeof e!="symbol"?e+"":e,t);const xt="DOC_DRAWING_UI_PLUGIN";exports.UniverDocsDrawingUIPlugin=class extends o.Plugin{constructor(e=cn,t,n,i){super(),this._config=e,this._injector=t,this._renderManagerSrv=n,this._configService=i;const{...s}=o.merge({},cn,this._config);this._configService.setConfig(Nn,s)}onStarting(){[[Fe],[He],[We],[Be],[$e],[exports.DocFloatDomController],[ke]].forEach(t=>this._injector.add(t))}onReady(){[[Le],[Ye]].forEach(e=>this._renderManagerSrv.registerRenderModule(o.UniverInstanceType.UNIVER_DOC,e)),this._injector.get(Be),this._injector.get(Fe),this._injector.get(We),this._injector.get(ke)}onRendered(){this._injector.get(He),this._injector.get(exports.DocFloatDomController)}};On(exports.UniverDocsDrawingUIPlugin,"type",o.UniverInstanceType.UNIVER_DOC);On(exports.UniverDocsDrawingUIPlugin,"pluginName",xt);exports.UniverDocsDrawingUIPlugin=Rt([o.DependentOn(fe.UniverDrawingUIPlugin,X.UniverDrawingPlugin,ve.UniverDocsDrawingPlugin,k.UniverUIPlugin),Ke(1,o.Inject(o.Injector)),Ke(2,L.IRenderManagerService),Ke(3,o.IConfigService)],exports.UniverDocsDrawingUIPlugin);exports.ClearDocDrawingTransformerOperation=_n;exports.DOCS_IMAGE_MENU_ID=on;exports.DeleteDocDrawingsCommand=Je;exports.EditDocDrawingOperation=rn;exports.GroupDocDrawingCommand=Ze;exports.InsertDocDrawingCommand=Ve;exports.InsertDocImageCommand=nn;exports.MoveDocDrawingsCommand=ye;exports.RemoveDocDrawingCommand=Ge;exports.SetDocDrawingArrangeCommand=Qe;exports.SidebarDocDrawingOperation=tn;exports.UngroupDocDrawingCommand=en;
|
|
1
|
+
"use strict";var Pn=Object.defineProperty;var xn=(r,e,t)=>e in r?Pn(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t;var le=(r,e,t)=>xn(r,typeof e!="symbol"?e+"":e,t);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("@univerjs/core"),ve=require("@univerjs/docs-drawing"),X=require("@univerjs/drawing"),fe=require("@univerjs/drawing-ui"),L=require("@univerjs/engine-render"),k=require("@univerjs/ui"),W=require("@univerjs/docs"),G=require("@univerjs/docs-ui"),N=require("@univerjs/design"),Z=require("rxjs"),u=require("react/jsx-runtime"),K=require("react"),Nn="docs-drawing-ui.config",cn={};var ce=function(){return ce=Object.assign||function(r){for(var e,t=1,n=arguments.length;t<n;t++){e=arguments[t];for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&(r[i]=e[i])}return r},ce.apply(this,arguments)},En=function(r,e){var t={};for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&e.indexOf(n)<0&&(t[n]=r[n]);if(r!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,n=Object.getOwnPropertySymbols(r);i<n.length;i++)e.indexOf(n[i])<0&&Object.prototype.propertyIsEnumerable.call(r,n[i])&&(t[n[i]]=r[n[i]]);return t},mn=K.forwardRef(function(r,e){var t=r.icon,n=r.id,i=r.className,s=r.extend,a=En(r,["icon","id","className","extend"]),d="univerjs-icon univerjs-icon-".concat(n," ").concat(i||"").trim(),l=K.useRef("_".concat(Un()));return un(t,"".concat(n),{defIds:t.defIds,idSuffix:l.current},ce({ref:e,className:d},a),s)});function un(r,e,t,n,i){return K.createElement(r.tag,ce(ce({key:e},An(r,t,i)),n),(jn(r,t).children||[]).map(function(s,a){return un(s,"".concat(e,"-").concat(r.tag,"-").concat(a),t,void 0,i)}))}function An(r,e,t){var n=ce({},r.attrs);t!=null&&t.colorChannel1&&n.fill==="colorChannel1"&&(n.fill=t.colorChannel1),r.tag==="mask"&&n.id&&(n.id=n.id+e.idSuffix),Object.entries(n).forEach(function(s){var a=s[0],d=s[1];a==="mask"&&typeof d=="string"&&(n[a]=d.replace(/url\(#(.*)\)/,"url(#$1".concat(e.idSuffix,")")))});var i=e.defIds;return!i||i.length===0||(r.tag==="use"&&n["xlink:href"]&&(n["xlink:href"]=n["xlink:href"]+e.idSuffix),Object.entries(n).forEach(function(s){var a=s[0],d=s[1];typeof d=="string"&&(n[a]=d.replace(/url\(#(.*)\)/,"url(#$1".concat(e.idSuffix,")")))})),n}function jn(r,e){var t,n=e.defIds;return!n||n.length===0?r:r.tag==="defs"&&(!((t=r.children)===null||t===void 0)&&t.length)?ce(ce({},r),{children:r.children.map(function(i){return typeof i.attrs.id=="string"&&n&&n.indexOf(i.attrs.id)>-1?ce(ce({},i),{attrs:ce(ce({},i.attrs),{id:i.attrs.id+e.idSuffix})}):i})}):r}function Un(){return Math.random().toString(36).substring(2,8)}mn.displayName="UniverIcon";var Ln={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M2.2498 3.65005C2.2498 2.87685 2.87661 2.25005 3.64981 2.25005H7.9998C8.33118 2.25005 8.5998 1.98142 8.5998 1.65005C8.5998 1.31868 8.33118 1.05005 7.9998 1.05005H3.64981C2.21387 1.05005 1.0498 2.21411 1.0498 3.65005V12.35C1.0498 13.786 2.21386 14.95 3.6498 14.95H12.3498C13.7857 14.95 14.9498 13.786 14.9498 12.3501V8.00005C14.9498 7.66868 14.6812 7.40005 14.3498 7.40005C14.0184 7.40005 13.7498 7.66868 13.7498 8.00005V9.23974L12.2385 8.1063C11.7252 7.72129 11.0068 7.7723 10.5531 8.22605L9.00869 9.77041L6.73916 7.8251C6.24387 7.40055 5.5095 7.41278 5.02864 7.85359L2.2498 10.4009V3.65005ZM2.2498 12.0287V12.35C2.2498 13.1232 2.87661 13.75 3.6498 13.75H12.3498C13.123 13.75 13.7498 13.1232 13.7498 12.3501V10.7397L11.5186 9.06631C11.4829 9.03956 11.433 9.04314 11.4016 9.07458L9.92249 10.5537L11.1015 11.5642C11.3531 11.7799 11.3822 12.1587 11.1666 12.4103C10.9509 12.6619 10.5721 12.691 10.3205 12.4753L5.9582 8.7362C5.92384 8.70674 5.87288 8.70758 5.83952 8.73816L2.2498 12.0287Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M11.8097 1.14783C12.1411 1.14783 12.4097 1.41646 12.4097 1.74783V3.297H14.1541C14.4855 3.297 14.7541 3.56563 14.7541 3.897C14.7541 4.22837 14.4855 4.497 14.1541 4.497H12.4097V6.24167C12.4097 6.57304 12.1411 6.84167 11.8097 6.84167C11.4783 6.84167 11.2097 6.57304 11.2097 6.24167V4.497H9.6603C9.32893 4.497 9.0603 4.22837 9.0603 3.897C9.0603 3.56563 9.32893 3.297 9.6603 3.297H11.2097V1.74783C11.2097 1.41646 11.4783 1.14783 11.8097 1.14783Z"}}]},hn=K.forwardRef(function(r,e){return K.createElement(mn,Object.assign({},r,{id:"add-image-single",ref:e,icon:Ln}))});hn.displayName="AddImageSingle";const Ge={id:"doc.command.remove-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{var P,M,A,H;const t=r.get(o.ICommandService),n=r.get(o.IUniverInstanceService),i=r.get(L.IRenderManagerService),s=n.getCurrentUniverDocInstance();if(e==null||s==null)return!1;const a=i.getRenderById(e.unitId).with(G.DocSelectionRenderService),{drawings:d}=e,l=(P=a.getSegment())!=null?P:"",c=new o.TextX,g=o.JSONX.getInstance(),h=(A=(M=s.getSelfOrHeaderFooterModel(l).getBody())==null?void 0:M.customBlocks)!=null?A:[],m=d.map(E=>h.find(_=>_.blockId===E.drawingId)).filter(E=>!!E).sort((E,_)=>E.startIndex>_.startIndex?1:-1),f=d[0].unitId,p=new o.MemoryCursor;p.reset();const w=m[0].startIndex,S=[{startOffset:w,endOffset:w}],I={id:W.RichTextEditingMutation.id,params:{unitId:f,actions:[],textRanges:S}},T=[];for(const E of m){const{startIndex:_}=E;_>p.cursor&&c.push({t:o.TextXActionType.RETAIN,len:_-p.cursor}),c.push({t:o.TextXActionType.DELETE,len:1}),p.moveCursorTo(_+1)}const y=G.getRichTextEditPath(s,l);T.push(g.editOp(c.serialize(),y));for(const E of m){const{blockId:_}=E,F=((H=s.getDrawings())!=null?H:{})[_],U=s.getDrawingsOrder().indexOf(_),q=g.removeOp(["drawings",_],F),D=g.removeOp(["drawingsOrder",U],_);T.push(q),T.push(D)}return I.params.actions=T.reduce((E,_)=>o.JSONX.compose(E,_),null),!!t.syncExecuteCommand(I.id,I.params)}},Je={id:"doc.command.delete-drawing",type:o.CommandType.COMMAND,handler:r=>{const e=r.get(o.ICommandService),n=r.get(ve.IDocDrawingService).getFocusDrawings();if(n.length===0)return!1;const{unitId:i}=n[0],s=n.map(a=>{const{unitId:d,subUnitId:l,drawingId:c,drawingType:g}=a;return{unitId:d,subUnitId:l,drawingId:c,drawingType:g}});return e.executeCommand(Ge.id,{unitId:i,drawings:s})}},Ze={id:"doc.command.group-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{r.get(o.ICommandService),r.get(o.IUndoRedoService);const t=r.get(ve.IDocDrawingService);if(!e)return!1;const n=[];e.forEach(({parent:g,children:h})=>{n.push(g.unitId),h.forEach(m=>{n.push(m.unitId)})});const i=t.getGroupDrawingOp(e),{unitId:s,subUnitId:a,undo:d,redo:l,objects:c}=i;return!1}},Ve={id:"doc.command.insert-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{var M,A,H,E;if(e==null)return!1;const t=r.get(o.ICommandService),n=r.get(W.DocSelectionManagerService),i=r.get(o.IUniverInstanceService),s=n.getActiveTextRange(),a=i.getCurrentUniverDocInstance();if(s==null||a==null)return!1;const d=a.getUnitId(),{drawings:l}=e,{collapsed:c,startOffset:g,segmentId:h}=s,m=a.getSelfOrHeaderFooterModel(h).getBody();if(m==null)return!1;const f=new o.TextX,p=o.JSONX.getInstance(),w=[],S=(A=(M=a.getSnapshot().drawingsOrder)==null?void 0:M.length)!=null?A:0;let I=0;if(c)g>0&&f.push({t:o.TextXActionType.RETAIN,len:g});else{const _=o.BuildTextUtils.selection.delete([s],m,0,null,!1);f.push(..._);const F=G.getCustomBlockIdsInSelections(m,[s]),z=(H=a.getDrawings())!=null?H:{},U=(E=a.getDrawingsOrder())!=null?E:[],q=F.sort((D,C)=>U.indexOf(D)>U.indexOf(C)?-1:U.indexOf(D)<U.indexOf(C)?1:0);if(q.length>0)for(const D of q){const C=z[D],x=U.indexOf(D);if(C==null||x<0)continue;const b=p.removeOp(["drawings",D],C),B=p.removeOp(["drawingsOrder",x],D);w.push(b),w.push(B),I++}}f.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b".repeat(l.length),customBlocks:l.map((_,F)=>({startIndex:F,blockId:_.drawingId}))},len:l.length});const T=G.getRichTextEditPath(a,h),y=p.editOp(f.serialize(),T);w.push(y);for(const _ of l){const{drawingId:F}=_,z=p.insertOp(["drawings",F],_),U=p.insertOp(["drawingsOrder",S-I],F);w.push(z),w.push(U)}const O={id:W.RichTextEditingMutation.id,params:{unitId:d,actions:[],textRanges:[]}};return O.params.actions=w.reduce((_,F)=>o.JSONX.compose(_,F),null),!!t.syncExecuteCommand(O.id,O.params)}},Qe={id:"doc.command.set-drawing-arrange",type:o.CommandType.COMMAND,handler:(r,e)=>{const t=r.get(o.ICommandService),n=r.get(ve.IDocDrawingService);if(e==null)return!1;const{unitId:i,subUnitId:s,drawingIds:a,arrangeType:d}=e,l={unitId:i,subUnitId:s,drawingIds:a};let c;if(d===o.ArrangeTypeEnum.forward?c=n.getForwardDrawingsOp(l):d===o.ArrangeTypeEnum.backward?c=n.getBackwardDrawingOp(l):d===o.ArrangeTypeEnum.front?c=n.getFrontDrawingsOp(l):d===o.ArrangeTypeEnum.back&&(c=n.getBackDrawingsOp(l)),c==null)return!1;const{redo:g}=c;if(g==null)return!1;const h=[];let m=o.Tools.deepClone(g);m=m.slice(3),m.unshift("drawingsOrder"),h.push(m);const f={id:W.RichTextEditingMutation.id,params:{unitId:i,actions:[],textRanges:null}};return f.params.actions=h.reduce((w,S)=>o.JSONX.compose(w,S),null),!!t.syncExecuteCommand(f.id,f.params)}},en={id:"doc.command.ungroup-doc-image",type:o.CommandType.COMMAND,handler:(r,e)=>{r.get(o.ICommandService),r.get(o.IUndoRedoService);const t=r.get(ve.IDocDrawingService);if(!e)return!1;const n=[];e.forEach(({parent:g,children:h})=>{n.push(g.unitId),h.forEach(m=>{n.push(m.unitId)})});const i=t.getUngroupDrawingOp(e),{unitId:s,subUnitId:a,undo:d,redo:l,objects:c}=i;return!1}};class $e{constructor(){le(this,"_refreshDrawings$",new Z.BehaviorSubject(null));le(this,"refreshDrawings$",this._refreshDrawings$.asObservable())}refreshDrawings(e){this._refreshDrawings$.next(e)}}var Fn=Object.getOwnPropertyDescriptor,Bn=(r,e,t,n)=>{for(var i=n>1?void 0:n?Fn(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},se=(r,e)=>(t,n)=>e(t,n,r);let Le=class extends o.Disposable{constructor(r,e,t,n,i,s,a,d,l,c,g,h,m){super(),this._context=r,this._commandService=e,this._docSelectionManagerService=t,this._renderManagerSrv=n,this._imageIoService=i,this._docDrawingService=s,this._drawingManagerService=a,this._contextService=d,this._messageService=l,this._localeService=c,this._docSelectionRenderService=g,this._docRefreshDrawingsService=h,this._fileOpenerService=m,this._updateOrderListener(),this._groupDrawingListener(),this._focusDrawingListener(),this._transformDrawingListener(),this._editAreaChangeListener()}async insertDocImage(){const r=await this._fileOpenerService.openFile({multiple:!0,accept:X.DRAWING_IMAGE_ALLOW_IMAGE_LIST.map(t=>`.${t.replace("image/","")}`).join(",")}),e=r.length;return e>X.DRAWING_IMAGE_COUNT_LIMIT?(this._messageService.show({type:N.MessageType.Error,content:this._localeService.t("update-status.exceedMaxCount",String(X.DRAWING_IMAGE_COUNT_LIMIT))}),!1):e===0?!1:(await this._insertFloatImages(r),!0)}async _insertFloatImages(r){let e=[];try{e=await Promise.all(r.map(i=>this._imageIoService.saveImage(i)))}catch(i){const s=i.message;let a="";switch(s){case X.ImageUploadStatusType.ERROR_EXCEED_SIZE:a=this._localeService.t("update-status.exceedMaxSize",String(X.DRAWING_IMAGE_ALLOW_SIZE/(1024*1024)));break;case X.ImageUploadStatusType.ERROR_IMAGE_TYPE:a=this._localeService.t("update-status.invalidImageType");break;case X.ImageUploadStatusType.ERROR_IMAGE:a=this._localeService.t("update-status.invalidImage");break}this._messageService.show({type:N.MessageType.Error,content:a})}if(e.length===0)return;const{unitId:t}=this._context,n=[];for(const i of e){if(i==null)continue;const{imageId:s,imageSourceType:a,source:d,base64Cache:l}=i,{width:c,height:g,image:h}=await X.getImageSize(l||"");this._imageIoService.addImageSourceCache(s,a,h);let m=1;if(c>X.DRAWING_IMAGE_WIDTH_LIMIT||g>X.DRAWING_IMAGE_HEIGHT_LIMIT){const S=X.DRAWING_IMAGE_WIDTH_LIMIT/c,I=X.DRAWING_IMAGE_HEIGHT_LIMIT/g;m=Math.min(S,I)}const f=this._getImagePosition(c*m,g*m);if(f==null)return;const p={unitId:t,subUnitId:t,drawingId:s,drawingType:o.DrawingTypeEnum.DRAWING_IMAGE,imageSourceType:a,source:d,transform:G.docDrawingPositionToTransform(f),docTransform:f,behindDoc:o.BooleanNumber.FALSE,title:"",description:"",layoutType:o.PositionedObjectLayoutType.INLINE,wrapText:o.WrapTextType.BOTH_SIDES,distB:0,distL:0,distR:0,distT:0};this._isInsertInHeaderFooter()&&(p.isMultiTransform=o.BooleanNumber.TRUE,p.transforms=p.transform?[p.transform]:null),n.push(p)}this._commandService.executeCommand(Ve.id,{unitId:t,drawings:n})}_isInsertInHeaderFooter(){var n;const{unitId:r}=this._context,e=(n=this._renderManagerSrv.getRenderById(r))==null?void 0:n.with(W.DocSkeletonManagerService).getViewModel(),t=e==null?void 0:e.getEditArea();return t===L.DocumentEditArea.HEADER||t===L.DocumentEditArea.FOOTER}_getImagePosition(r,e){const t=this._docSelectionRenderService.getActiveTextRange(),n=(t==null?void 0:t.getAbsolutePosition())||{left:0};return{size:{width:r,height:e},positionH:{relativeFrom:o.ObjectRelativeFromH.PAGE,posOffset:n.left},positionV:{relativeFrom:o.ObjectRelativeFromV.PARAGRAPH,posOffset:0},angle:0}}_updateOrderListener(){this._drawingManagerService.featurePluginOrderUpdate$.subscribe(r=>{const{unitId:e,subUnitId:t,drawingIds:n,arrangeType:i}=r;this._commandService.executeCommand(Qe.id,{unitId:e,subUnitId:t,drawingIds:n,arrangeType:i})})}_groupDrawingListener(){this._drawingManagerService.featurePluginGroupUpdate$.subscribe(r=>{this._commandService.executeCommand(Ze.id,r)}),this._drawingManagerService.featurePluginUngroupUpdate$.subscribe(r=>{this._commandService.executeCommand(en.id,r)})}_getCurrentSceneAndTransformer(){const{scene:r,mainComponent:e}=this._context;if(r==null||e==null)return;const t=r.getTransformerByCreate(),{docsLeft:n,docsTop:i}=e.getOffsetConfig();return{scene:r,transformer:t,docsLeft:n,docsTop:i}}_transformDrawingListener(){const r=this._getCurrentSceneAndTransformer();if(r&&r.transformer)this.disposeWithMe(r.transformer.changeEnd$.pipe(Z.debounceTime(30)).subscribe(e=>{this._docSelectionManagerService.refreshSelection()}));else throw new Error("transformer is not init")}_focusDrawingListener(){this.disposeWithMe(this._drawingManagerService.focus$.subscribe(r=>{var i;const{transformer:e,docsLeft:t,docsTop:n}=(i=this._getCurrentSceneAndTransformer())!=null?i:{};if(r==null||r.length===0)this._contextService.setContextValue(o.FOCUSING_COMMON_DRAWINGS,!1),this._docDrawingService.focusDrawing([]),e&&e.resetProps({zeroTop:0,zeroLeft:0});else{this._contextService.setContextValue(o.FOCUSING_COMMON_DRAWINGS,!0),this._docDrawingService.focusDrawing(r),this._setDrawingSelections(r);const s=this._docSelectionRenderService.getSegment(),a=this._findSegmentIdByDrawingId(r[0].drawingId);s!==a&&this._docSelectionRenderService.setSegment(a),e&&e.resetProps({zeroTop:n,zeroLeft:t})}}))}_findSegmentIdByDrawingId(r){var a,d,l;const{unit:e}=this._context,{body:t,headers:n={},footers:i={}}=e.getSnapshot();if(((a=t==null?void 0:t.customBlocks)!=null?a:[]).some(c=>c.blockId===r))return"";for(const c of Object.keys(n))if((d=n[c].body.customBlocks)!=null&&d.some(g=>g.blockId===r))return c;for(const c of Object.keys(i))if((l=i[c].body.customBlocks)!=null&&l.some(g=>g.blockId===r))return c;return""}_updateDrawingsEditStatus(){var d;const{unit:r,scene:e,unitId:t}=this._context,n=(d=this._renderManagerSrv.getRenderById(t))==null?void 0:d.with(W.DocSkeletonManagerService).getViewModel();if(n==null||r==null)return;const i=r.getSnapshot(),{drawings:s={}}=i,a=n.getEditArea()===L.DocumentEditArea.BODY;for(const l of Object.keys(s)){const c=s[l],g=X.getDrawingShapeKeyByDrawingSearch({unitId:t,drawingId:c.drawingId,subUnitId:t}),h=e.fuzzyMathObjects(g,!0);if(h.length)for(const m of h){e.detachTransformerFrom(m);try{m.setOpacity(.5)}catch{}if(a&&c.isMultiTransform!==o.BooleanNumber.TRUE||!a&&c.isMultiTransform===o.BooleanNumber.TRUE){c.allowTransform!==!1&&e.attachTransformerTo(m);try{m.setOpacity(1)}catch{}}}}}_editAreaChangeListener(){var t;const{unitId:r}=this._context,e=(t=this._renderManagerSrv.getRenderById(r))==null?void 0:t.with(W.DocSkeletonManagerService).getViewModel();e!=null&&(this._updateDrawingsEditStatus(),this.disposeWithMe(e.editAreaChange$.subscribe(()=>{this._updateDrawingsEditStatus()})),this._docRefreshDrawingsService.refreshDrawings$.subscribe(n=>{n!=null&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})}),this.disposeWithMe(this._commandService.onCommandExecuted(async n=>{n.id===W.RichTextEditingMutation.id&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})})))}_setDrawingSelections(r){var i,s;const{unit:e}=this._context,t=(s=(i=e.getSnapshot().body)==null?void 0:i.customBlocks)!=null?s:[],n=r.map(a=>{const d=a.drawingId,l=t.find(c=>c.blockId===d);return l?l.startIndex:null}).filter(a=>a!==null).map(a=>({startOffset:a,endOffset:a+1}));this._docSelectionManagerService.replaceDocRanges(n)}};Le=Bn([se(1,o.ICommandService),se(2,o.Inject(W.DocSelectionManagerService)),se(3,L.IRenderManagerService),se(4,X.IImageIoService),se(5,ve.IDocDrawingService),se(6,X.IDrawingManagerService),se(7,o.IContextService),se(8,k.IMessageService),se(9,o.Inject(o.LocaleService)),se(10,o.Inject(G.DocSelectionRenderService)),se(11,o.Inject($e)),se(12,k.ILocalFileService)],Le);const nn={id:"doc.command.insert-float-image",type:o.CommandType.COMMAND,handler:r=>{var n,i;const e=r.get(o.IUniverInstanceService),t=r.get(L.IRenderManagerService);return(i=(n=L.getCurrentTypeOfRenderer(o.UniverInstanceType.UNIVER_DOC,e,t))==null?void 0:n.with(Le).insertDocImage())!=null?i:!1}};var ae=(r=>(r.INLINE="inline",r.BEHIND_TEXT="behindText",r.IN_FRONT_OF_TEXT="inFrontOfText",r.WRAP_SQUARE="wrapSquare",r.WRAP_TOP_AND_BOTTOM="wrapTopAndBottom",r))(ae||{});const kn={inline:o.PositionedObjectLayoutType.INLINE,wrapSquare:o.PositionedObjectLayoutType.WRAP_SQUARE,wrapTopAndBottom:o.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM,inFrontOfText:o.PositionedObjectLayoutType.WRAP_NONE,behindText:o.PositionedObjectLayoutType.WRAP_NONE};function pn(r,e,t,n,i,s,a){var f,p;const d=new o.TextX,l=o.JSONX.getInstance(),c=[],g=s.getSelfOrHeaderFooterModel(e).getBody(),h=s.getSelfOrHeaderFooterModel(r).getBody();if(g==null||h==null)return;const m=(p=(f=g.customBlocks)==null?void 0:f.find(w=>w.blockId===i))==null?void 0:p.startIndex;if(m!=null){if(n=Math.min(h.dataStream.length-2,n),r===e){if(n<m?(n>0&&d.push({t:o.TextXActionType.RETAIN,len:n}),d.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:i}]},len:1}),d.push({t:o.TextXActionType.RETAIN,len:m-n}),d.push({t:o.TextXActionType.DELETE,len:1})):(m>0&&d.push({t:o.TextXActionType.RETAIN,len:m}),d.push({t:o.TextXActionType.DELETE,len:1}),n-m-1>0&&d.push({t:o.TextXActionType.RETAIN,len:n-m-1}),d.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:i}]},len:1})),n!==m){const w=G.getRichTextEditPath(s,e),S=l.editOp(d.serialize(),w);c.push(S)}}else{m>0&&d.push({t:o.TextXActionType.RETAIN,len:m}),d.push({t:o.TextXActionType.DELETE,len:1});let w=G.getRichTextEditPath(s,e),S=l.editOp(d.serialize(),w);c.push(S),d.empty(),n>0&&d.push({t:o.TextXActionType.RETAIN,len:n}),d.push({t:o.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:i}]},len:1}),w=G.getRichTextEditPath(s,r),S=l.editOp(d.serialize(),w),c.push(S),a.setSegment(r),a.setSegmentPage(t)}return c}}const fn={id:"doc.command.update-doc-drawing-wrapping-style",type:o.CommandType.COMMAND,handler:(r,e)=>{var A,H;if(e==null)return!1;const{drawings:t,wrappingStyle:n,unitId:i}=e,s=r.get(o.ICommandService),a=r.get(o.IUniverInstanceService),l=r.get(L.IRenderManagerService).getRenderById(i),c=l==null?void 0:l.with(W.DocSkeletonManagerService).getSkeleton().getSkeletonData(),g=l==null?void 0:l.with(W.DocSkeletonManagerService).getViewModel(),h=l==null?void 0:l.scene,m=a.getCurrentUniverDocInstance();if(m==null||c==null||h==null||g==null)return!1;const f=g.getEditArea(),p=h.getTransformerByCreate(),{pages:w,skeHeaders:S,skeFooters:I}=c,T=o.JSONX.getInstance(),y=[],{drawings:O={}}=m.getSnapshot();for(const E of t){const{drawingId:_}=E,F=O[_].layoutType,z=kn[n];if(F!==z){const C=T.replaceOp(["drawings",_,"layoutType"],F,z);y.push(C)}if(n==="behindText"||n==="inFrontOfText"){const C=O[_].behindDoc,x=n==="behindText"?o.BooleanNumber.TRUE:o.BooleanNumber.FALSE;if(C!==x){const b=T.replaceOp(["drawings",_,"behindDoc"],C,x);y.push(b)}}if(n==="inline")continue;let U=null,q=0,D=0;for(const C of w){const{headerId:x,footerId:b,marginTop:B,marginLeft:V,marginBottom:R,pageWidth:j,pageHeight:Y}=C;switch(f){case L.DocumentEditArea.HEADER:{const $=(A=S.get(x))==null?void 0:A.get(j);$!=null&&$.skeDrawings.has(_)&&(U=$.skeDrawings.get(_),q=$.marginTop,D=V);break}case L.DocumentEditArea.FOOTER:{const $=(H=I.get(b))==null?void 0:H.get(j);$!=null&&$.skeDrawings.has(_)&&(U=$.skeDrawings.get(_),q=Y-R+$.marginTop,D=V);break}case L.DocumentEditArea.BODY:{C.skeDrawings.has(_)&&(U=C.skeDrawings.get(_),q=B,D=V);break}}if(U!=null)break}if(U!=null){const{aTop:C,aLeft:x}=U,b=O[_].docTransform.positionH;let B=x;b.relativeFrom===o.ObjectRelativeFromH.MARGIN?B-=D:b.relativeFrom===o.ObjectRelativeFromH.COLUMN&&(B-=U.columnLeft);const V={relativeFrom:b.relativeFrom,posOffset:B};if(b.posOffset!==V.posOffset){const $=T.replaceOp(["drawings",_,"docTransform","positionH"],b,V);y.push($)}const R=O[_].docTransform.positionV;let j=C;R.relativeFrom===o.ObjectRelativeFromV.PAGE?j+=q:R.relativeFrom===o.ObjectRelativeFromV.LINE?j-=U.lineTop:R.relativeFrom===o.ObjectRelativeFromV.PARAGRAPH&&(j-=U.blockAnchorTop);const Y={relativeFrom:R.relativeFrom,posOffset:j};if(R.posOffset!==Y.posOffset){const $=T.replaceOp(["drawings",_,"docTransform","positionV"],R,Y);y.push($)}}}const P={id:W.RichTextEditingMutation.id,params:{unitId:i,actions:[],textRanges:null}};P.params.actions=y.reduce((E,_)=>o.JSONX.compose(E,_),null);const M=s.syncExecuteCommand(P.id,P.params);return p.refreshControls(),!!M}},vn={id:"doc.command.update-doc-drawing-distance",type:o.CommandType.COMMAND,handler:(r,e)=>{if(e==null)return!1;const t=r.get(o.ICommandService),i=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(i==null)return!1;const{drawings:s,dist:a,unitId:d}=e,l=o.JSONX.getInstance(),c=[],{drawings:g={}}=i.getSnapshot();for(const f of s){const{drawingId:p}=f;for(const[w,S]of Object.entries(a)){const I=g[p][w];if(I!==S){const T=l.replaceOp(["drawings",p,w],I,S);c.push(T)}}}const h={id:W.RichTextEditingMutation.id,params:{unitId:d,actions:[],textRanges:null}};return h.params.actions=c.reduce((f,p)=>o.JSONX.compose(f,p),null),!!t.syncExecuteCommand(h.id,h.params)}},In={id:"doc.command.update-doc-drawing-wrap-text",type:o.CommandType.COMMAND,handler:(r,e)=>{if(e==null)return!1;const t=r.get(o.ICommandService),i=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(i==null)return!1;const{drawings:s,wrapText:a,unitId:d}=e,l=o.JSONX.getInstance(),c=[],{drawings:g={}}=i.getSnapshot();for(const f of s){const{drawingId:p}=f,w=g[p].wrapText;if(w!==a){const S=l.replaceOp(["drawings",p,"wrapText"],w,a);c.push(S)}}const h={id:W.RichTextEditingMutation.id,params:{unitId:d,actions:[],textRanges:null}};return h.params.actions=c.reduce((f,p)=>o.JSONX.compose(f,p),null),!!t.syncExecuteCommand(h.id,h.params)}},xe={id:"doc.command.update-drawing-doc-transform",type:o.CommandType.COMMAND,handler:(r,e)=>{if(e==null)return!1;const t=r.get(o.ICommandService),n=r.get(o.IUniverInstanceService),s=r.get(L.IRenderManagerService).getRenderById(e.unitId),a=s==null?void 0:s.scene;if(a==null)return!1;const d=a.getTransformerByCreate(),l=n.getCurrentUniverDocInstance();if(l==null)return!1;const{drawings:c,unitId:g}=e,h=o.JSONX.getInstance(),m=[],{drawings:f={}}=l.getSnapshot();for(const S of c){const{drawingId:I,key:T,value:y}=S,O=f[I].docTransform[T];if(!o.Tools.diffValue(O,y)){const P=h.replaceOp(["drawings",I,"docTransform",T],O,y);m.push(P)}}const p={id:W.RichTextEditingMutation.id,params:{unitId:g,actions:[],textRanges:null,debounce:!0}};p.params.actions=m.reduce((S,I)=>o.JSONX.compose(S,I),null);const w=t.syncExecuteCommand(p.id,p.params);return d.refreshControls(),!!w}},wn={id:"doc.command.move-inline-drawing",type:o.CommandType.COMMAND,handler:(r,e)=>{var H,E;if(e==null)return!1;const t=r.get(L.IRenderManagerService),n=(H=t.getRenderById(e.unitId))==null?void 0:H.with(G.DocSelectionRenderService),i=r.get($e),s=t.getRenderById(e.unitId),a=s==null?void 0:s.scene,d=s==null?void 0:s.with(W.DocSkeletonManagerService).getSkeleton();if(a==null||n==null)return!1;const l=a.getTransformerByCreate(),c=r.get(o.ICommandService),h=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(h==null)return!1;const{drawing:m,unitId:f,offset:p,segmentId:w,segmentPage:S,needRefreshDrawings:I}=e;if(I)return i.refreshDrawings(d),l.refreshControls(),!0;const T=[],{drawingId:y}=m,O=(E=n.getSegment())!=null?E:"",P=pn(w,O,S,p,y,h,n);if(P==null||P.length===0)return i.refreshDrawings(d),l.refreshControls(),!1;T.push(...P);const M={id:W.RichTextEditingMutation.id,params:{unitId:f,actions:[],textRanges:null}};M.params.actions=T.reduce((_,F)=>o.JSONX.compose(_,F),null);const A=c.syncExecuteCommand(M.id,M.params);return l.refreshControls(),!!A}},Sn={id:"doc.command.transform-non-inline-drawing",type:o.CommandType.COMMAND,handler:(r,e)=>{var U,q;if(e==null)return!1;const t=r.get(L.IRenderManagerService),n=(U=t.getRenderById(e.unitId))==null?void 0:U.with(G.DocSelectionRenderService),i=t.getRenderById(e.unitId),s=i==null?void 0:i.scene;if(s==null||n==null)return!1;const a=s.getTransformerByCreate(),d=r.get(o.ICommandService),c=r.get(o.IUniverInstanceService).getCurrentUniverDocInstance();if(c==null)return!1;const{drawing:g,unitId:h,offset:m,docTransform:f,segmentId:p,segmentPage:w}=e,S=[],{drawingId:I}=g,T=(q=n.getSegment())!=null?q:"",y=pn(p,T,w,m,I,c,n);if(y==null)return!1;y.length>0&&S.push(...y);const O=o.JSONX.getInstance(),{drawings:P={}}=c.getSnapshot(),M=P[I].docTransform,{positionH:A,positionV:H,size:E,angle:_}=M;if(!o.Tools.diffValue(A,f.positionH)){const D=O.replaceOp(["drawings",I,"docTransform","positionH"],A,f.positionH);S.push(D)}if(!o.Tools.diffValue(H,f.positionV)){const D=O.replaceOp(["drawings",I,"docTransform","positionV"],H,f.positionV);S.push(D)}if(!o.Tools.diffValue(E,f.size)){const D=O.replaceOp(["drawings",I,"docTransform","size"],E,f.size);S.push(D)}if(!o.Tools.diffValue(_,f.angle)){const D=O.replaceOp(["drawings",I,"docTransform","angle"],_,f.angle);S.push(D)}const F={id:W.RichTextEditingMutation.id,params:{unitId:h,actions:[],textRanges:null,debounce:!0}};F.params.actions=S.reduce((D,C)=>o.JSONX.compose(D,C),null);const z=d.syncExecuteCommand(F.id,F.params);return a.refreshControls(),!!z}},ye={id:"doc.command.move-drawing",type:o.CommandType.COMMAND,handler:(r,e)=>{const t=r.get(o.ICommandService),n=r.get(ve.IDocDrawingService),i=r.get(o.IUniverInstanceService),s=r.get(L.IRenderManagerService),{direction:a}=e,d=n.getFocusDrawings();if(d.length===0)return!1;const l=d[0].unitId,c=s.getRenderById(l),g=c==null?void 0:c.scene;if(g==null)return!1;const h=g.getTransformerByCreate(),m=i.getUniverDocInstance(l),f=d.map(w=>{var M,A,H,E,_;const{drawingId:S}=w,I=(M=m==null?void 0:m.getSnapshot().drawings)==null?void 0:M[S];if(I==null||I.layoutType===o.PositionedObjectLayoutType.INLINE)return null;const{positionH:T,positionV:y}=I.docTransform,O={...T},P={...y};return a===o.Direction.UP?P.posOffset=((A=P.posOffset)!=null?A:0)-2:a===o.Direction.DOWN?P.posOffset=((H=P.posOffset)!=null?H:0)+2:a===o.Direction.LEFT?O.posOffset=((E=O.posOffset)!=null?E:0)-2:a===o.Direction.RIGHT&&(O.posOffset=((_=O.posOffset)!=null?_:0)+2),{drawingId:S,key:a===o.Direction.UP||a===o.Direction.DOWN?"positionV":"positionH",value:a===o.Direction.UP||a===o.Direction.DOWN?P:O}}).filter(w=>w!=null);if(f.length===0)return!1;const p=t.syncExecuteCommand(xe.id,{unitId:l,subUnitId:l,drawings:f});return h.refreshControls(),!!p}},_n={id:"doc.operation.clear-drawing-transformer",type:o.CommandType.MUTATION,handler:(r,e)=>{const t=r.get(L.IRenderManagerService);return e.forEach(n=>{var i,s;(s=(i=t.getRenderById(n))==null?void 0:i.scene.getTransformer())==null||s.debounceRefreshControls()}),!0}},Dn="COMPONENT_DOC_DRAWING_PANEL",tn={id:"sidebar.operation.doc-image",type:o.CommandType.COMMAND,handler:async(r,e)=>{const t=r.get(k.ISidebarService),n=r.get(o.LocaleService),i=r.get(X.IDrawingManagerService);switch(e.value){case"open":t.open({header:{title:n.t("docImage.panel.title")},children:{label:Dn},onClose:()=>{i.focusDrawing(null)},width:360});break;case"close":default:t.close();break}return!0}},rn={id:"doc.operation.edit-doc-image",type:o.CommandType.OPERATION,handler:(r,e)=>{const t=r.get(X.IDrawingManagerService),n=r.get(o.ICommandService);return e==null?!1:(t.focusDrawing([e]),n.executeCommand(tn.id,{value:"open"}),!0)}},Wn="univer-image-common-panel",Hn="univer-image-common-panel-grid",Gn="univer-image-common-panel-border",Vn="univer-image-common-panel-title",$n="univer-image-common-panel-subtitle",Xn="univer-image-common-panel-row",zn="univer-image-common-panel-column",qn="univer-image-common-panel-span2",Kn="univer-image-common-panel-input",v={imageCommonPanel:Wn,imageCommonPanelGrid:Hn,imageCommonPanelBorder:Gn,imageCommonPanelTitle:Vn,imageCommonPanelSubtitle:$n,imageCommonPanelRow:Xn,imageCommonPanelColumn:zn,imageCommonPanelSpan2:qn,imageCommonPanelInput:Kn},dn=-1e3,ln=1e3,Yn=r=>{const e=k.useDependency(o.ICommandService),t=k.useDependency(o.LocaleService),n=k.useDependency(X.IDrawingManagerService),i=k.useDependency(L.IRenderManagerService),s=k.useDependency(o.IUniverInstanceService),{drawings:a}=r,d=a[0];if(d==null)return;const{unitId:l}=d,c=s.getUniverDocInstance(l),g=c==null?void 0:c.getSnapshot().documentStyle.documentFlavor,h=i.getRenderById(l),m=h==null?void 0:h.scene;if(m==null)return;const f=m.getTransformerByCreate(),p=[{label:t.t("image-position.column"),value:String(o.ObjectRelativeFromH.COLUMN)},{label:t.t("image-position.page"),value:String(o.ObjectRelativeFromH.PAGE)},{label:t.t("image-position.margin"),value:String(o.ObjectRelativeFromH.MARGIN)}],w=[{label:t.t("image-position.line"),value:String(o.ObjectRelativeFromV.LINE),disabled:g===o.DocumentFlavor.MODERN},{label:t.t("image-position.page"),value:String(o.ObjectRelativeFromV.PAGE),disabled:g===o.DocumentFlavor.MODERN},{label:t.t("image-position.margin"),value:String(o.ObjectRelativeFromV.MARGIN),disabled:g===o.DocumentFlavor.MODERN},{label:t.t("image-position.paragraph"),value:String(o.ObjectRelativeFromV.PARAGRAPH)}],[S,I]=K.useState(!0),[T,y]=K.useState({relativeFrom:o.ObjectRelativeFromH.PAGE,posOffset:0}),[O,P]=K.useState({relativeFrom:o.ObjectRelativeFromV.PAGE,posOffset:0}),[M,A]=K.useState(!0),[H,E]=K.useState(!0);function _(C,x){var R;C==="positionH"?y(x):P(x);const b=n.getFocusDrawings();if(b.length===0)return;const B=b.map(j=>({unitId:j.unitId,subUnitId:j.subUnitId,drawingId:j.drawingId}));e.executeCommand(xe.id,{unitId:b[0].unitId,subUnitId:b[0].unitId,drawings:B.map(j=>({drawingId:j.drawingId,key:C,value:x}))});const V=(R=i.getRenderById(l))==null?void 0:R.with(G.DocSelectionRenderService);V&&V.blur(),f.refreshControls()}function F(C){var ee,ge,me;const x=T.relativeFrom,b=T.posOffset,B=Number(C);if(x===B)return;const V=n.getFocusDrawings();if(V.length===0)return;const R=V[0].drawingId,j=V[0].unitId;let Y=null,$=0;const J=(ee=i.getRenderById(j))==null?void 0:ee.with(W.DocSkeletonManagerService).getSkeleton(),ne=J==null?void 0:J.getSkeletonData();if(ne==null)return;const{pages:Ce,skeHeaders:Ie,skeFooters:Oe}=ne;for(const ie of Ce){const{marginLeft:ue,skeDrawings:he,headerId:we,footerId:Se,pageWidth:pe}=ie;if(he.has(R)){Y=he.get(R),$=ue;break}const re=(ge=Ie.get(we))==null?void 0:ge.get(pe);if(re!=null&&re.skeDrawings.has(R)){Y=re==null?void 0:re.skeDrawings.get(R),$=ue;break}const oe=(me=Oe.get(Se))==null?void 0:me.get(pe);if(oe!=null&&oe.skeDrawings.has(R)){Y=oe==null?void 0:oe.skeDrawings.get(R),$=ue;break}}if(Y==null)return;let te=0;x===o.ObjectRelativeFromH.COLUMN?te-=Y.columnLeft:x===o.ObjectRelativeFromH.MARGIN&&(te-=$),B===o.ObjectRelativeFromH.COLUMN?te+=Y.columnLeft:B===o.ObjectRelativeFromH.MARGIN?te+=$:o.ObjectRelativeFromH.PAGE;const Q={relativeFrom:B,posOffset:(b!=null?b:0)-te};_("positionH",Q)}function z(C){var he,we,Se,pe,re,oe;const x=O.relativeFrom,b=O.posOffset,B=Number(C);if(x===B)return;const V=n.getFocusDrawings();if(V.length===0)return;const{drawingId:R,unitId:j}=V[0],Y=s.getUniverDocInstance(j),$=(he=i.getRenderById(j))==null?void 0:he.with(W.DocSkeletonManagerService).getSkeleton(),J=(we=i.getRenderById(j))==null?void 0:we.with(G.DocSelectionRenderService),ne=J==null?void 0:J.getSegment(),Ce=J==null?void 0:J.getSegmentPage(),Ie=(pe=(Se=Y==null?void 0:Y.getSelfOrHeaderFooterModel(ne).getBody())==null?void 0:Se.customBlocks)==null?void 0:pe.find(_e=>_e.blockId===R);if(Ie==null||$==null||J==null)return;const{startIndex:Oe}=Ie,te=$.findNodeByCharIndex(Oe,ne,Ce),Q=(re=te==null?void 0:te.parent)==null?void 0:re.parent,ee=Q==null?void 0:Q.parent,ge=ee==null?void 0:ee.lines.find(_e=>_e.paragraphIndex===(Q==null?void 0:Q.paragraphIndex)&&_e.paragraphStart),me=(oe=ee==null?void 0:ee.parent)==null?void 0:oe.parent;if(te==null||Q==null||ge==null||ee==null||me==null)return;let ie=0;x===o.ObjectRelativeFromV.PARAGRAPH?ie-=ge.top:x===o.ObjectRelativeFromV.LINE?ie-=Q.top:x===o.ObjectRelativeFromV.PAGE&&(ie+=me.marginTop),B===o.ObjectRelativeFromV.PARAGRAPH?ie+=ge.top:B===o.ObjectRelativeFromV.LINE?ie+=Q.top:B===o.ObjectRelativeFromV.PAGE&&(ie-=me.marginTop);const ue={relativeFrom:B,posOffset:(b!=null?b:0)-ie};_("positionV",ue)}function U(C){var j;const x=c==null?void 0:c.getSnapshot(),b=(j=x==null?void 0:x.drawings)==null?void 0:j[C.drawingId];if(b==null)return;const{layoutType:B}=b,{positionH:V,positionV:R}=b.docTransform;y(V),P(R),I(B===o.PositionedObjectLayoutType.INLINE),A(R.relativeFrom===o.ObjectRelativeFromV.PARAGRAPH||R.relativeFrom===o.ObjectRelativeFromV.LINE)}function q(){const C=n.getFocusDrawings();C.length!==0&&U(C[0])}function D(C){A(C),z(String(C?o.ObjectRelativeFromV.PARAGRAPH:o.ObjectRelativeFromV.PAGE))}return K.useEffect(()=>{q();const C=n.focus$.subscribe(b=>{if(b.length===0){E(!1);return}E(!0),U(b[0])}),x=e.onCommandExecuted(async b=>{b.id===W.RichTextEditingMutation.id&&q()});return()=>{C.unsubscribe(),x.dispose()}},[]),u.jsxs("div",{className:N.clsx(v.imageCommonPanelGrid,v.imageCommonPanelBorder),style:{display:H?"block":"none"},children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelTitle),children:u.jsx("div",{children:t.t("image-position.title")})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-position.horizontal")})})}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.absolutePosition")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:dn,max:ln,precision:1,disabled:S,value:T.posOffset,onChange:C=>{_("positionH",{relativeFrom:T.relativeFrom,posOffset:C})},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.toTheRightOf")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.Select,{value:String(T.relativeFrom),disabled:S,options:p,onChange:F})})})]})})]}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-position.vertical")})})}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.absolutePosition")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:dn,max:ln,precision:1,disabled:S,value:O.posOffset,onChange:C=>{_("positionV",{relativeFrom:O.relativeFrom,posOffset:C})},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-position.bellow")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.Select,{disabled:S,value:String(O.relativeFrom),options:w,onChange:z})})})]})})]}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-position.options")})})}),u.jsx("div",{className:v.imageCommonPanelRow,style:{marginBottom:"50px"},children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.Checkbox,{disabled:S,checked:M,onChange:D,children:t.t("image-position.moveObjectWithText")})})})]})},Ee=0,Ae=100,Jn=r=>{const e=k.useDependency(o.ICommandService),t=k.useDependency(o.LocaleService),n=k.useDependency(X.IDrawingManagerService),i=k.useDependency(L.IRenderManagerService),s=k.useDependency(o.IUniverInstanceService),{drawings:a}=r,d=a[0];if(d==null)return null;const{unitId:l}=d,c=s.getUniverDocInstance(l),g=i.getRenderById(l);if((g==null?void 0:g.scene)==null)return null;const[m,f]=K.useState(!0),[p,w]=K.useState(!0),[S,I]=K.useState(!0),[T,y]=K.useState(ae.INLINE),[O,P]=K.useState(""),[M,A]=K.useState({distT:0,distL:0,distB:0,distR:0}),[H,E]=K.useState(!0);function _(D){y(D);const C=n.getFocusDrawings();if(C.length===0)return;const{unitId:x,subUnitId:b}=C[0],B=C.map(({unitId:V,subUnitId:R,drawingId:j})=>({unitId:V,subUnitId:R,drawingId:j}));e.executeCommand(fn.id,{unitId:x,subUnitId:b,drawings:B,wrappingStyle:D})}function F(D){P(D);const C=n.getFocusDrawings();if(C.length===0)return;const x=C.map(b=>({unitId:b.unitId,subUnitId:b.subUnitId,drawingId:b.drawingId}));e.executeCommand(In.id,{unitId:C[0].unitId,subUnitId:C[0].unitId,drawings:x,wrapText:D})}function z(D,C){if(D==null)return;const x={...M,[C]:D};A(x);const b=n.getFocusDrawings();if(b.length===0)return;const B=b.map(V=>({unitId:V.unitId,subUnitId:V.subUnitId,drawingId:V.drawingId}));e.executeCommand(vn.id,{unitId:b[0].unitId,subUnitId:b[0].unitId,drawings:B,dist:{[C]:D}})}function U(){const D=n.getFocusDrawings();D.length!==0&&q(D[0])}function q(D){var J,ne;const C=(ne=(J=c==null?void 0:c.getSnapshot())==null?void 0:J.drawings)==null?void 0:ne[D.drawingId];if(C==null)return;const{distT:x=0,distL:b=0,distB:B=0,distR:V=0,layoutType:R=o.PositionedObjectLayoutType.INLINE,behindDoc:j=o.BooleanNumber.FALSE,wrapText:Y=o.WrapTextType.BOTH_SIDES}=C;if(A({distT:x,distL:b,distB:B,distR:V}),P(Y),f(R!==o.PositionedObjectLayoutType.WRAP_SQUARE),R===o.PositionedObjectLayoutType.WRAP_NONE||R===o.PositionedObjectLayoutType.INLINE?w(!0):w(!1),R===o.PositionedObjectLayoutType.WRAP_NONE||R===o.PositionedObjectLayoutType.INLINE||R===o.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM?I(!0):I(!1),R===o.PositionedObjectLayoutType.WRAP_NONE)j===o.BooleanNumber.TRUE?y(ae.BEHIND_TEXT):y(ae.IN_FRONT_OF_TEXT);else switch(R){case o.PositionedObjectLayoutType.INLINE:y(ae.INLINE);break;case o.PositionedObjectLayoutType.WRAP_SQUARE:y(ae.WRAP_SQUARE);break;case o.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM:y(ae.WRAP_TOP_AND_BOTTOM);break;default:throw new Error(`Unsupported layout type: ${R}`)}}return K.useEffect(()=>{U();const D=n.focus$.subscribe(x=>{if(x.length===0){E(!1);return}E(!0),q(x[0])}),C=e.onCommandExecuted(async x=>{x.id===W.RichTextEditingMutation.id&&U()});return()=>{D.unsubscribe(),C.dispose()}},[]),u.jsxs("div",{className:N.clsx(v.imageCommonPanelGrid,v.imageCommonPanelBorder),style:{display:H?"block":"none"},children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelTitle),children:u.jsx("div",{children:t.t("image-text-wrap.title")})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-text-wrap.wrappingStyle")})})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelRow),children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn),children:u.jsxs(N.RadioGroup,{value:T,onChange:_,direction:"vertical",children:[u.jsx(N.Radio,{value:ae.INLINE,children:t.t("image-text-wrap.inline")}),u.jsx(N.Radio,{value:ae.WRAP_SQUARE,children:t.t("image-text-wrap.square")}),u.jsx(N.Radio,{value:ae.WRAP_TOP_AND_BOTTOM,children:t.t("image-text-wrap.topAndBottom")}),u.jsx(N.Radio,{value:ae.BEHIND_TEXT,children:t.t("image-text-wrap.behindText")}),u.jsx(N.Radio,{value:ae.IN_FRONT_OF_TEXT,children:t.t("image-text-wrap.inFrontText")})]})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-text-wrap.wrapText")})})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelRow),children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn),children:u.jsxs(N.RadioGroup,{disabled:m,value:O,onChange:F,direction:"horizontal",children:[u.jsx(N.Radio,{value:o.WrapTextType.BOTH_SIDES,children:t.t("image-text-wrap.bothSide")}),u.jsx(N.Radio,{value:o.WrapTextType.LEFT,children:t.t("image-text-wrap.leftOnly")}),u.jsx(N.Radio,{value:o.WrapTextType.RIGHT,children:t.t("image-text-wrap.rightOnly")})]})})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSubtitle),children:u.jsx("div",{children:t.t("image-text-wrap.distanceFromText")})})}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.top")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:p,precision:1,value:M.distT,onChange:D=>{z(D,"distT")},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.left")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:S,precision:1,value:M.distL,onChange:D=>{z(D,"distL")},className:v.imageCommonPanelInput})})})]})})]}),u.jsxs("div",{className:v.imageCommonPanelRow,children:[u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.bottom")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:p,precision:1,value:M.distB,onChange:D=>{z(D,"distB")},className:v.imageCommonPanelInput})})})]})}),u.jsx("div",{className:N.clsx(v.imageCommonPanelColumn,v.imageCommonPanelSpan2),children:u.jsxs("label",{children:[u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:t.t("image-text-wrap.right")})}),u.jsx("div",{className:v.imageCommonPanelRow,children:u.jsx("div",{className:v.imageCommonPanelColumn,children:u.jsx(N.InputNumber,{min:Ee,max:Ae,disabled:S,precision:1,value:M.distR,onChange:D=>{z(D,"distR")},className:v.imageCommonPanelInput})})})]})})]})]})},Zn=()=>{const r=k.useDependency(X.IDrawingManagerService),e=r.getFocusDrawings(),[t,n]=K.useState(e);return K.useEffect(()=>{const i=r.focus$.subscribe(s=>{n(s)});return()=>{i.unsubscribe()}},[]),!!(t!=null&&t.length)&&u.jsxs("div",{className:v.imageCommonPanel,children:[u.jsx(fe.DrawingCommonPanel,{drawings:t,hasAlign:!1,hasCropper:!1,hasGroup:!1,hasTransform:!1}),u.jsx(Jn,{drawings:t}),u.jsx(Yn,{drawings:t})]})},Cn="addition-and-subtraction-single",on="doc.menu.image",Tn=nn.id,Qn=r=>{const e=r.get(W.DocSelectionManagerService),t=r.get(o.IUniverInstanceService);return new Z.Observable(n=>{const i=e.textSelection$.subscribe(()=>{var a;const s=e.getActiveTextRange();if(s){const{segmentId:d,startOffset:l,endOffset:c}=s,g=t.getCurrentUniverDocInstance(),h=(a=g==null?void 0:g.getSelfOrHeaderFooterModel(d).getBody())==null?void 0:a.tables;if(h&&h.length&&h.some(m=>{const{startIndex:f,endIndex:p}=m;return l>=f&&l<p||c>=f&&c<p})){n.next(!0);return}}else{n.next(!0);return}n.next(!1)});return()=>i.unsubscribe()})};function et(r){return{id:on,type:k.MenuItemType.SUBITEMS,icon:Cn,tooltip:"docImage.title",disabled$:Qn(r),hidden$:k.getMenuHiddenObservable(r,o.UniverInstanceType.UNIVER_DOC,void 0,o.DOCS_ZEN_EDITOR_UNIT_ID_KEY)}}function nt(r){return{id:Tn,title:"docImage.upload.float",type:k.MenuItemType.BUTTON,hidden$:k.getMenuHiddenObservable(r,o.UniverInstanceType.UNIVER_DOC,void 0,o.DOCS_ZEN_EDITOR_UNIT_ID_KEY)}}const tt={[k.RibbonStartGroup.LAYOUT]:{[on]:{order:0,menuItemFactory:et,[Tn]:{order:0,menuItemFactory:nt}}}};function Ne(r){return r.getContextValue(o.FOCUSING_UNIVER_EDITOR)&&r.getContextValue(o.FOCUSING_COMMON_DRAWINGS)}const it={id:ye.id,description:"shortcut.drawing-move-down",group:"4_drawing-view",binding:k.KeyCode.ARROW_DOWN,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.DOWN}},rt={id:ye.id,description:"shortcut.drawing-move-up",group:"4_drawing-view",binding:k.KeyCode.ARROW_UP,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.UP}},ot={id:ye.id,description:"shortcut.drawing-move-left",group:"4_drawing-view",binding:k.KeyCode.ARROW_LEFT,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.LEFT}},st={id:ye.id,description:"shortcut.drawing-move-right",group:"4_drawing-view",binding:k.KeyCode.ARROW_RIGHT,priority:100,preconditions:Ne,staticParameters:{direction:o.Direction.RIGHT}},at={id:Je.id,description:"shortcut.drawing-delete",group:"4_drawing-view",preconditions:Ne,binding:k.KeyCode.DELETE,mac:k.KeyCode.BACKSPACE};var ct=Object.getOwnPropertyDescriptor,dt=(r,e,t,n)=>{for(var i=n>1?void 0:n?ct(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},je=(r,e)=>(t,n)=>e(t,n,r);let Fe=class extends o.Disposable{constructor(r,e,t,n){super(),this._componentManager=r,this._menuManagerService=e,this._commandService=t,this._shortcutService=n,this._init()}_initCustomComponents(){const r=this._componentManager;this.disposeWithMe(r.register(Cn,hn)),this.disposeWithMe(r.register(Dn,Zn))}_initMenus(){this._menuManagerService.mergeMenu(tt)}_initCommands(){[nn,Ve,fn,vn,In,xe,wn,Sn,Ge,tn,_n,rn,Ze,en,ye,Je,Qe].forEach(r=>this.disposeWithMe(this._commandService.registerCommand(r)))}_initShortcuts(){[it,rt,ot,st,at].forEach(r=>{this.disposeWithMe(this._shortcutService.registerShortcut(r))})}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus(),this._initShortcuts()}};Fe=dt([je(0,o.Inject(k.ComponentManager)),je(1,k.IMenuManagerService),je(2,o.ICommandService),je(3,k.IShortcutService)],Fe);var lt=Object.getOwnPropertyDescriptor,gt=(r,e,t,n)=>{for(var i=n>1?void 0:n?lt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Me=(r,e)=>(t,n)=>e(t,n,r);function mt(r){var n,i,s,a;if(o.JSONX.isNoop(r)||!Array.isArray(r))return null;const e=r.find(d=>Array.isArray(d)&&(d==null?void 0:d[0])==="drawings");if(e==null||!Array.isArray(e)||e.length<3||typeof e[1]=="string"&&typeof e[2]!="object"||Array.isArray(e[1])&&typeof e[1][1]!="object")return null;const t=[];if(Array.isArray(e==null?void 0:e[1]))for(const d of e)Array.isArray(d)&&t.push({type:(n=d==null?void 0:d[1])!=null&&n.i?"add":"remove",drawingId:d==null?void 0:d[0],drawing:(i=d==null?void 0:d[1])==null?void 0:i.i});else t.push({type:(s=e[2])!=null&&s.i?"add":"remove",drawingId:e[1],drawing:(a=e[2])==null?void 0:a.i});return t}function ut(r){if(!Array.isArray(r)||r.length<3||r[0]!=="drawingsOrder")return[];const e=[];for(let t=1;t<r.length;t++){const n=r[t];if(Array.isArray(n)&&typeof n[0]=="number"&&typeof n[1]=="object")e.push(n[0]);else{e.length=0;break}}return e}let Be=class extends o.Disposable{constructor(r,e,t,n,i){super(),this._univerInstanceService=r,this._commandService=e,this._drawingManagerService=t,this._docDrawingService=n,this._renderManagerService=i,this._initialize()}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(r=>{if(r.id!==W.RichTextEditingMutation.id)return;const e=r.params,{unitId:t,actions:n}=e,i=mt(n);if(i!=null)for(const{type:s,drawingId:a,drawing:d}of i)s==="add"?this._addDrawings(t,[d]):this._removeDrawings(t,[a])})),this.disposeWithMe(this._commandService.onCommandExecuted(r=>{if(r.id!==W.RichTextEditingMutation.id)return;const e=r.params,{unitId:t,actions:n}=e;ut(n).length>0&&this._updateDrawingsOrder(t)})),this.disposeWithMe(this._commandService.onCommandExecuted(r=>{var a;if(r.id!==o.UndoCommand.id&&r.id!==o.RedoCommand.id)return;const e=(a=this._univerInstanceService.getCurrentUniverDocInstance())==null?void 0:a.getUnitId(),t=this._drawingManagerService.getFocusDrawings();if(e==null||t.length===0)return;const n=this._renderManagerService.getRenderById(e),i=n==null?void 0:n.scene;if(i==null)return!1;i.getTransformerByCreate().refreshControls()}))}_addDrawings(r,e){const t=this._drawingManagerService,n=this._docDrawingService,i=this._docDrawingService.getBatchAddOp(e),{subUnitId:s,redo:a,objects:d}=i;t.applyJson1(r,s,a),n.applyJson1(r,s,a),t.addNotification(d),n.addNotification(d)}_removeDrawings(r,e){const t=this._drawingManagerService,n=this._docDrawingService,i=this._docDrawingService.getBatchRemoveOp(e.map(l=>({unitId:r,subUnitId:r,drawingId:l}))),{subUnitId:s,redo:a,objects:d}=i;t.applyJson1(r,s,a),n.applyJson1(r,s,a),t.removeNotification(d),n.removeNotification(d)}_updateDrawingsOrder(r){const e=this._univerInstanceService.getUniverDocInstance(r);if(e==null)return;const t=e.getSnapshot().drawingsOrder;if(t==null)return;const n=this._drawingManagerService,i=this._docDrawingService;n.setDrawingOrder(r,r,t),i.setDrawingOrder(r,r,t);const s={unitId:r,subUnitId:r,drawingIds:t};n.orderNotification(s),i.orderNotification(s)}};Be=gt([Me(0,o.IUniverInstanceService),Me(1,o.ICommandService),Me(2,X.IDrawingManagerService),Me(3,ve.IDocDrawingService),Me(4,L.IRenderManagerService)],Be);var ht=Object.getOwnPropertyDescriptor,pt=(r,e,t,n)=>{for(var i=n>1?void 0:n?ht(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Te=(r,e)=>(t,n)=>e(t,n,r);function yn(r,e,t=1,n=0){const{top:i,left:s,bottom:a,right:d}=r,l=d-s,c=a-i,g=e.getViewport(G.VIEWPORT_KEY.VIEW_MAIN),{viewportScrollX:h,viewportScrollY:m}=g,{scaleX:f,scaleY:p}=e.getAncestorScale();return{startX:(s-h)*f,startY:(i-m)*p,endX:(s+l-h)*f,endY:(i+c-m)*p,width:l*f,height:c*p,rotate:n,absolute:{left:!1,top:!1},opacity:t!=null?t:1}}function qe(r,e){const{top:t,left:n,width:i,height:s,angle:a,opacity:d}=r;return yn({top:t,left:n,bottom:t+s,right:n+i},e.scene,d,a)}exports.DocFloatDomController=class extends o.Disposable{constructor(t,n,i,s,a,d){super();le(this,"_domLayerInfoMap",new Map);this._renderManagerService=t,this._drawingManagerService=n,this._drawingRenderService=i,this._canvasFloatDomService=s,this._univerInstanceService=a,this._commandService=d,this._initialize()}dispose(){super.dispose()}_initialize(){this._drawingAddRemoveListener(),this._initScrollAndZoomEvent()}_getSceneAndTransformerByDrawingSearch(t){if(t==null)return;const n=this._renderManagerService.getRenderById(t);if(n==null)return null;const i=n.scene,s=i.getTransformerByCreate();return{scene:i,transformer:s,renderUnit:n,canvas:n.engine.getCanvasElement()}}_drawingAddRemoveListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(t=>{this._insertRects(t)})),this.disposeWithMe(this._drawingManagerService.remove$.subscribe(t=>{t.forEach(n=>{this._removeDom(n.drawingId)})}))}_insertRects(t){t.forEach(async n=>{const{unitId:i}=n;if(!this._univerInstanceService.getUnit(i,o.UniverInstanceType.UNIVER_DOC))return;const a=this._getSceneAndTransformerByDrawingSearch(i);if(a==null)return;const d=this._drawingManagerService.getDrawingByParam(n);if(d==null)return;const l=await this._drawingRenderService.renderFloatDom(d,a.scene);if(!(l==null||l.length===0))for(const c of l){this._addHoverForRect(c);const g=new o.DisposableCollection,h=qe(c,a.renderUnit),m=new Z.BehaviorSubject(h),f=a.canvas,p=d.data,w={dispose:g,rect:c,position$:m,unitId:i};this._canvasFloatDomService.addFloatDom({position$:m,id:d.drawingId,componentKey:d.componentKey,onPointerDown:I=>{f.dispatchEvent(new PointerEvent(I.type,I))},onPointerMove:I=>{f.dispatchEvent(new PointerEvent(I.type,I))},onPointerUp:I=>{f.dispatchEvent(new PointerEvent(I.type,I))},onWheel:I=>{f.dispatchEvent(new WheelEvent(I.type,I))},data:p,unitId:i});const S=c.onTransformChange$.subscribeEvent(()=>{const I=qe(c,a.renderUnit);m.next(I)});g.add(()=>{this._canvasFloatDomService.removeFloatDom(d.drawingId)}),S&&g.add(S),this._domLayerInfoMap.set(d.drawingId,w)}})}_addHoverForRect(t){this.disposeWithMe(o.toDisposable(t.onPointerEnter$.subscribeEvent(()=>{t.cursor=L.CURSOR_TYPE.GRAB}))),this.disposeWithMe(o.toDisposable(t.onPointerLeave$.subscribeEvent(()=>{t.cursor=L.CURSOR_TYPE.DEFAULT})))}_removeDom(t){const n=this._domLayerInfoMap.get(t);if(!n)return;const{unitId:i}=n;this._domLayerInfoMap.delete(t),n.dispose.dispose();const s=this._getSceneAndTransformerByDrawingSearch(i);s&&s.scene.removeObject(n.rect)}_initScrollAndZoomEvent(){const t=n=>{const i=this._getSceneAndTransformerByDrawingSearch(n);i&&this._domLayerInfoMap.forEach(s=>{if(s.unitId!==n)return;const a=qe(s.rect,i.renderUnit);s.position$.next(a)})};this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_DOC).pipe(Z.map(n=>{if(!n)return null;const i=n.getUnitId(),s=this._renderManagerService.getRenderById(i);return s?{render:s,unitId:i}:null}),Z.switchMap(n=>n?o.fromEventSubject(n.render.scene.getViewport(G.VIEWPORT_KEY.VIEW_MAIN).onScrollAfter$).pipe(Z.map(()=>({unitId:n.unitId}))):Z.of(null))).subscribe(n=>{if(!n)return;const{unitId:i}=n;t(i)})),this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(n.id===G.SetDocZoomRatioOperation.id){const i=n.params,{unitId:s}=i;t(s)}}))}insertFloatDom(t,n){var S,I,T;const i=this._univerInstanceService.getCurrentUnitOfType(o.UniverInstanceType.UNIVER_DOC);if(!i)return!1;const s=this._getSceneAndTransformerByDrawingSearch(i.getUnitId());if(!s)return!1;const l=(S=s.renderUnit.with(W.DocSkeletonManagerService).getSkeleton().getSkeletonData())==null?void 0:S.pages[0];if(!l)return!1;const{pageWidth:c,marginLeft:g,marginRight:h}=l,m=c-g-h,f={size:{width:(I=n.width)!=null?I:m,height:n.height},positionH:{relativeFrom:o.ObjectRelativeFromH.PAGE,posOffset:0},positionV:{relativeFrom:o.ObjectRelativeFromV.PAGE,posOffset:0},angle:0},p=(T=n.drawingId)!=null?T:o.generateRandomId(),w={unitId:i.getUnitId(),drawings:[{drawingId:p,drawingType:o.DrawingTypeEnum.DRAWING_DOM,subUnitId:i.getUnitId(),unitId:i.getUnitId(),...t,title:"",description:"",docTransform:f,layoutType:o.PositionedObjectLayoutType.INLINE,transform:G.docDrawingPositionToTransform(f)}]};return this._commandService.syncExecuteCommand(Ve.id,w),p}};exports.DocFloatDomController=pt([Te(0,L.IRenderManagerService),Te(1,X.IDrawingManagerService),Te(2,o.Inject(fe.DrawingRenderService)),Te(3,o.Inject(k.CanvasFloatDomService)),Te(4,o.IUniverInstanceService),Te(5,o.ICommandService)],exports.DocFloatDomController);const ft=r=>{const{floatDomInfos:e,scene:t,offset:n,bound:i}=r,s=i.right-i.left,a=i.bottom-i.top,d=K.useMemo(()=>e.map(l=>{const{width:c=0,height:g=0,left:h=0,top:m=0}=l.transform,p=yn({left:h,right:h+c,top:m,bottom:m+g},t),w={position$:new Z.BehaviorSubject(p),position:p,id:l.drawingId,componentKey:l.componentKey,onPointerMove:()=>{},onPointerDown:()=>{},onPointerUp:()=>{},onWheel:()=>{},unitId:l.unitId,data:l.data};return[l.drawingId,w]}).filter(([l,c])=>!(c.position.endX<0||c.position.endY<0||c.position.startX>s||c.position.startY>a)),[e,t,n,s,a]);return u.jsx("div",{style:{position:"absolute",top:0,left:0},children:d.map(([l,c])=>u.jsx(k.PrintFloatDomSingle,{layer:c,id:l,position:c.position},l))})};var vt=Object.getOwnPropertyDescriptor,It=(r,e,t,n)=>{for(var i=n>1?void 0:n?vt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Re=(r,e)=>(t,n)=>e(t,n,r);let ke=class extends o.Disposable{constructor(r,e,t,n,i){super(),this._docPrintInterceptorService=r,this._drawingRenderService=e,this._drawingManagerService=t,this._componetManager=n,this._injector=i,this._initPrinting(),this._initPrintingDom()}_initPrinting(){this.disposeWithMe(this._docPrintInterceptorService.interceptor.intercept(this._docPrintInterceptorService.interceptor.getInterceptPoints().PRINTING_COMPONENT_COLLECT,{handler:(r,e,t)=>{const{unitId:n,scene:i}=e,s=this._drawingManagerService.getDrawingDataForUnit(n),a=s==null?void 0:s[n];return a&&a.order.forEach(d=>{const l=a.data[d];l.drawingType!==o.DrawingTypeEnum.DRAWING_CHART&&l.drawingType!==o.DrawingTypeEnum.DRAWING_DOM&&this._drawingRenderService.renderDrawing(l,i)}),t()}}))}_initPrintingDom(){this.disposeWithMe(this._docPrintInterceptorService.interceptor.intercept(this._docPrintInterceptorService.interceptor.getInterceptPoints().PRINTING_DOM_COLLECT,{handler:(r,e,t)=>{const{unitId:n}=e,i=this._drawingManagerService.getDrawingDataForUnit(n),s=i==null?void 0:i[n];if(s){const a=s.order.map(l=>{const c=s.data[l];if(c.drawingType===o.DrawingTypeEnum.DRAWING_CHART)return{...c,componentKey:this._componetManager.get(o.DOC_DRAWING_PRINTING_COMPONENT_KEY)};if(c.drawingType===o.DrawingTypeEnum.DRAWING_DOM){const g=this._docPrintInterceptorService.getPrintComponent(c.componentKey);return{...c,componentKey:this._componetManager.get(g||c.componentKey)}}return null}).filter(Boolean),d=k.connectInjector(ft,this._injector);return N.render(u.jsx(d,{unitId:n,floatDomInfos:a,scene:e.scene,skeleton:e.skeleton,offset:e.offset,bound:e.bound}),e.root),r==null||r.add(()=>{N.unmount(e.root)}),t(r)}}}))}};ke=It([Re(0,o.Inject(G.DocPrintInterceptorService)),Re(1,o.Inject(fe.DrawingRenderService)),Re(2,X.IDrawingManagerService),Re(3,o.Inject(k.ComponentManager)),Re(4,o.Inject(o.Injector))],ke);var wt=Object.getOwnPropertyDescriptor,St=(r,e,t,n)=>{for(var i=n>1?void 0:n?wt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Ue=(r,e)=>(t,n)=>e(t,n,r);const _t="__InlineDrawingAnchor__";function gn(r){const{path:e}=r;return e.some(t=>t==="cells")}let We=class extends o.Disposable{constructor(e,t,n,i){super();le(this,"_liquid",new L.Liquid);le(this,"_listenerOnImageMap",new Set);le(this,"_transformerCache",new Map);le(this,"_anchorShape");this._commandService=e,this._univerInstanceService=t,this._drawingManagerService=n,this._renderManagerService=i,this._init()}_init(){this._listenDrawingFocus()}_listenDrawingFocus(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(e=>{if(e.length!==0)for(const t of e){const{unitId:n}=t;this._listenerOnImageMap.has(n)||(this._listenTransformerChange(n),this._listenerOnImageMap.add(n))}}))}_listenTransformerChange(e){var i;const t=(i=this._getSceneAndTransformerByDrawingSearch(e))==null?void 0:i.transformer;if(t==null)return;this.disposeWithMe(o.toDisposable(t.changeStart$.subscribe(s=>{var d;this._transformerCache.clear();const{objects:a}=s;for(const l of a.values()){const{oKey:c,width:g,height:h,left:m,top:f,angle:p}=l,w=this._drawingManagerService.getDrawingOKey(c);if(w==null)continue;const S=this._univerInstanceService.getUniverDocInstance(w.unitId),I=(d=S==null?void 0:S.getSnapshot().drawings)==null?void 0:d[w.drawingId];if((I==null?void 0:I.layoutType)===o.PositionedObjectLayoutType.INLINE)try{l.setOpacity(.2)}catch{}I!=null&&this._transformerCache.set(w.drawingId,{drawing:I,top:f,left:m,width:g,height:h,angle:p})}})));const n=o.throttle(this._updateMultipleDrawingDocTransform.bind(this),50);o.throttle(this._nonInlineDrawingTransform.bind(this),50),this.disposeWithMe(o.toDisposable(t.changing$.subscribe(s=>{const{objects:a,offsetX:d,offsetY:l}=s;if(a.size>1)n(a);else if(a.size===1){const c=this._transformerCache.values().next().value,g=a.values().next().value,{width:h,height:m,top:f,left:p,angle:w}=g;if(c&&h===c.width&&m===c.height&&f===c.top&&p===c.left&&w===c.angle)return;c&&(c.drawing.layoutType,o.PositionedObjectLayoutType.INLINE),c&&c.drawing.layoutType===o.PositionedObjectLayoutType.INLINE&&d!=null&&l!=null&&this._updateInlineDrawingAnchor(c.drawing,d,l)}}))),this.disposeWithMe(o.toDisposable(t.changeEnd$.subscribe(s=>{const{objects:a,offsetX:d,offsetY:l}=s;for(const c of a.values()){const g=this._drawingManagerService.getDrawingOKey(c.oKey);if(g==null)continue;const h=this._transformerCache.get(g==null?void 0:g.drawingId);if((h==null?void 0:h.drawing.layoutType)===o.PositionedObjectLayoutType.INLINE)try{c.setOpacity(1)}catch{}}if(this._anchorShape&&this._anchorShape.hide(),a.size>1)this._updateMultipleDrawingDocTransform(a);else if(a.size===1){const c=this._transformerCache.values().next().value,g=a.values().next().value,{width:h,height:m,top:f,left:p,angle:w}=g;if(c&&h===c.width&&m===c.height&&f===c.top&&p===c.left&&w===c.angle)return;c&&c.drawing.layoutType===o.PositionedObjectLayoutType.INLINE?h!==c.width||m!==c.height||w!==c.angle?this._updateDrawingSize(c,g):d!=null&&l!=null&&this._moveInlineDrawing(c.drawing,d,l):c&&this._nonInlineDrawingTransform(c.drawing,g)}this._transformerCache.clear()})))}_updateMultipleDrawingDocTransform(e){if(e.size<1)return;const t=[];let n,i;for(const s of e.values()){const{oKey:a,left:d,top:l,angle:c}=s;let{width:g,height:h}=s;const m=this._drawingManagerService.getDrawingOKey(a);if(m==null)continue;n==null&&(n=m.unitId),i==null&&(i=m.subUnitId);const f=this._transformerCache.get(m.drawingId);if(f==null)continue;const{drawing:p,top:w,left:S,width:I,height:T,angle:y}=f,{width:O,height:P}=this._getPageContentSize(p);if(g=Math.min(g,O),h=Math.min(h,P),(I!==g||T!==h)&&t.push({drawingId:m.drawingId,key:"size",value:{width:g,height:h}}),y!==c&&t.push({drawingId:m.drawingId,key:"angle",value:c}),w!==l||S!==d){const M=l-w,A=d-S;M!==0&&t.push({drawingId:m.drawingId,key:"positionV",value:{relativeFrom:p.docTransform.positionV.relativeFrom,posOffset:p.docTransform.positionV.posOffset+M}}),A!==0&&t.push({drawingId:m.drawingId,key:"positionH",value:{relativeFrom:p.docTransform.positionH.relativeFrom,posOffset:p.docTransform.positionH.posOffset+A}})}}t.length>0&&n&&i&&this._commandService.executeCommand(xe.id,{unitId:n,subUnitId:i,drawings:t})}_updateDrawingAnchor(e){if(this._transformerCache.size!==1)return;const t=this._transformerCache.values().next().value,n=e.values().next().value;this._getDrawingAnchor(t.drawing,n)}_updateInlineDrawingAnchor(e,t,n){var s;if(this._transformerCache.size!==1)return;const{contentBoxPointGroup:i}=(s=this._getInlineDrawingAnchor(e,t,n))!=null?s:{};i!=null&&this._createOrUpdateInlineAnchor(e.unitId,i)}_getInlineDrawingAnchor(e,t,n){var U,q;const i=this._renderManagerService.getRenderById(e.unitId),s=i==null?void 0:i.with(W.DocSkeletonManagerService).getSkeleton();if(i==null)return;const{mainComponent:a,scene:d}=i,l=a,c=d.getViewports()[0],{pageLayoutType:g=L.PageLayoutType.VERTICAL,pageMarginLeft:h,pageMarginTop:m}=l.getOffsetConfig();let f=null,p=!1,w=-1,S="";const I=.5,T=this._getTransformCoordForDocumentOffset(l,c,t,n);if(T==null)return;const y=(U=this._renderManagerService.getRenderById(e.unitId))==null?void 0:U.with(G.DocSelectionRenderService);if(y==null)return;const O=s==null?void 0:s.findNodeByCoord(T,g,h,m,{strict:!1,segmentId:y.getSegment(),segmentPage:y.getSegmentPage()});if(O){const{node:D,ratioX:C,segmentPage:x,segmentId:b}=O;p=C<I,f=D,w=x,S=b}if(f==null)return;const P=s==null?void 0:s.findPositionByGlyph(f,w),M=this._getDocObject();if(P==null||s==null||M==null||gn(P))return;const A={...P,isBack:p},H=M.document.getOffsetConfig(),E=new G.NodePositionConvertToCursor(H,s),{cursorList:_,contentBoxPointGroup:F}=E.getRangePointData(A,A),{startOffset:z}=(q=G.getOneTextSelectionRange(_))!=null?q:{};if(z!=null)return{offset:z,contentBoxPointGroup:F,segmentId:S,segmentPage:w}}_getDrawingAnchor(e,t){var ge,me,ie,ue,he,we,Se,pe,re,oe,_e;const n=this._renderManagerService.getRenderById(e.unitId),i=n==null?void 0:n.with(W.DocSkeletonManagerService).getSkeleton(),s=i==null?void 0:i.getSkeletonData();if(s==null||n==null)return;const{pages:a,skeHeaders:d,skeFooters:l}=s,{mainComponent:c,scene:g}=n,h=c,m=g.getViewports()[0],{pageLayoutType:f=L.PageLayoutType.VERTICAL,pageMarginLeft:p,pageMarginTop:w,docsLeft:S,docsTop:I}=h.getOffsetConfig(),{left:T,top:y,angle:O}=t;let{width:P,height:M}=t;const{positionV:A,positionH:H}=e.docTransform,{width:E,height:_}=this._getPageContentSize(e);P=Math.min(P,E),M=Math.min(M,_);let F=null,z="",U=-1;const q=!1,D={...e.docTransform,size:{width:P,height:M},angle:O},{x:C,y:x}=g.getViewportScrollXY(m),b=this._getTransformCoordForDocumentOffset(h,m,T-C,y-x);if(b==null)return;const B=(ge=this._renderManagerService.getRenderById(e.unitId))==null?void 0:ge.with(G.DocSelectionRenderService);if(B==null)return;const V=i==null?void 0:i.findNodeByCoord(b,f,p,w,{strict:!1,segmentId:B.getSegment(),segmentPage:B.getSegmentPage()});if(V){const{node:de,segmentPage:Xe,segmentId:ze}=V;F=de,U=Xe,z=ze}if(F==null)return;const R=(me=F.parent)==null?void 0:me.parent,j=R==null?void 0:R.parent,Y=(ie=j==null?void 0:j.lines.find(de=>de.paragraphIndex===(R==null?void 0:R.paragraphIndex)&&de.paragraphStart))!=null?ie:j==null?void 0:j.lines[0],$=(ue=j==null?void 0:j.parent)==null?void 0:ue.parent;if(R==null||j==null||Y==null||$==null)return;this._liquid.reset();const J=$.type;for(const de of a){const{headerId:Xe,footerId:ze,pageHeight:bn,pageWidth:sn,marginLeft:an,marginBottom:Mn}=de,Rn=a.indexOf(de);if(U>-1&&Rn===U){switch(J){case L.DocumentSkeletonPageType.HEADER:{const be=(he=d.get(Xe))==null?void 0:he.get(sn);if(be)this._liquid.translatePagePadding({marginTop:be.marginTop,marginLeft:an});else throw new Error("header skeleton not found");break}case L.DocumentSkeletonPageType.FOOTER:{const be=(we=l.get(ze))==null?void 0:we.get(sn);if(be)this._liquid.translatePagePadding({marginTop:bn-Mn+be.marginTop,marginLeft:an});else throw new Error("footer skeleton not found");break}}break}if(this._liquid.translatePagePadding(de),de===$)break;this._liquid.restorePagePadding(de),this._liquid.translatePage(de,f,p,w)}switch(A.relativeFrom===o.ObjectRelativeFromV.LINE?F=R.divides[0].glyphGroup[0]:F=(oe=(re=(pe=(Se=Y.divides)==null?void 0:Se[0])==null?void 0:pe.glyphGroup)==null?void 0:re[0])!=null?oe:F,D.positionH={relativeFrom:H.relativeFrom,posOffset:T-this._liquid.x-S},H.relativeFrom){case o.ObjectRelativeFromH.MARGIN:{D.positionH.posOffset=T-this._liquid.x-S-$.marginLeft;break}case o.ObjectRelativeFromH.COLUMN:{D.positionH.posOffset=T-this._liquid.x-S-j.left;break}}switch(D.positionV={relativeFrom:A.relativeFrom,posOffset:y-this._liquid.y-I},A.relativeFrom){case o.ObjectRelativeFromV.PAGE:{D.positionV.posOffset=y-this._liquid.y-I-$.marginTop;break}case o.ObjectRelativeFromV.LINE:{D.positionV.posOffset=y-this._liquid.y-I-R.top;break}case o.ObjectRelativeFromV.PARAGRAPH:{D.positionV.posOffset=y-this._liquid.y-I-Y.top;break}}if(F==null)return;const ne=i==null?void 0:i.findPositionByGlyph(F,U),Ce=this._getDocObject();if(ne==null||i==null||Ce==null||gn(ne))return;const Ie={...ne,isBack:q},Oe=Ce.document.getOffsetConfig(),te=new G.NodePositionConvertToCursor(Oe,i),{cursorList:Q}=te.getRangePointData(Ie,Ie),{startOffset:ee}=(_e=G.getOneTextSelectionRange(Q))!=null?_e:{};if(ee!=null)return{offset:ee,docTransform:D,segmentId:z,segmentPage:U}}_updateDrawingSize(e,t){const n=[],{drawing:i,width:s,height:a,angle:d}=e,{unitId:l,subUnitId:c}=i;let{width:g,height:h,angle:m}=t;const{width:f,height:p}=this._getPageContentSize(i);g=Math.min(f,g),h=Math.min(p,h),(g!==s||h!==a)&&n.push({drawingId:i.drawingId,key:"size",value:{width:g,height:h}}),m!==d&&n.push({drawingId:i.drawingId,key:"angle",value:m}),n.length>0&&l&&c&&this._commandService.executeCommand(xe.id,{unitId:l,subUnitId:c,drawings:n})}_moveInlineDrawing(e,t,n){const i=this._getInlineDrawingAnchor(e,t,n),{offset:s,segmentId:a,segmentPage:d}=i!=null?i:{};return this._commandService.executeCommand(wn.id,{unitId:e.unitId,subUnitId:e.unitId,drawing:e,offset:s,segmentId:a,segmentPage:d,needRefreshDrawings:s==null})}_limitDrawingInPage(e,t){const n=this._renderManagerService.getRenderById(e.unitId),{left:i,top:s,width:a,height:d,angle:l}=t,c=n==null?void 0:n.with(W.DocSkeletonManagerService).getSkeleton(),g=c==null?void 0:c.getSkeletonData(),{pages:h}=g!=null?g:{};if(g==null||n==null||h==null)return{left:i,top:s,width:a,height:d,angle:l};const{mainComponent:m}=n,f=m,{top:p,pageLayoutType:w,pageMarginLeft:S,pageMarginTop:I}=f;let T=s;this._liquid.reset();for(const y of h){const{marginBottom:O,pageHeight:P}=y,M=h.indexOf(y),A=h[M+1];if(A==null)continue;if(o.Tools.hasIntersectionBetweenTwoRanges(s,s+d,this._liquid.y+p+P-O,this._liquid.y+p+P+I+A.marginTop)){const E=s+d/2,_=this._liquid.y+p+P+I/2;E<_?T=Math.min(s,this._liquid.y+p+P-O-d):T=Math.max(s,this._liquid.y+p+P+I+A.marginTop)}this._liquid.translatePage(y,w,S,I)}return{left:i,top:T,width:a,height:d,angle:l}}_nonInlineDrawingTransform(e,t,n=!1){const i=e.isMultiTransform===o.BooleanNumber.TRUE?t:this._limitDrawingInPage(e,t);if(n&&i.top!==t.top)return;const s=this._getDrawingAnchor(e,i),{offset:a,docTransform:d,segmentId:l,segmentPage:c}=s!=null?s:{};return a==null||d==null?this._updateMultipleDrawingDocTransform(new Map([[e.drawingId,t]])):this._commandService.executeCommand(Sn.id,{unitId:e.unitId,subUnitId:e.unitId,drawing:e,offset:a,docTransform:d,segmentId:l,segmentPage:c})}_getSceneAndTransformerByDrawingSearch(e){if(e==null)return;const t=this._renderManagerService.getRenderById(e),n=t==null?void 0:t.scene;if(n==null)return;const i=n.getTransformerByCreate();return{scene:n,transformer:i}}_getTransformCoordForDocumentOffset(e,t,n,i){const{documentTransform:s}=e.getOffsetConfig(),a=t.transformVector2SceneCoord(L.Vector2.FromArray([n,i]));if(a)return s.clone().invert().applyPoint(a)}_createOrUpdateInlineAnchor(e,t){const n=this._renderManagerService.getRenderById(e);if(n==null)return;const{mainComponent:i,scene:s}=n,a=i,{docsLeft:d,docsTop:l}=a.getOffsetConfig(),c=G.getAnchorBounding(t),{left:g,top:h,height:m}=c,f=g+d,p=h+l;if(this._anchorShape){this._anchorShape.transformByState({left:f,top:p,height:m}),this._anchorShape.show();return}const w=6,S=new L.Rect(_t+o.Tools.generateRandomId(w),{left:f,top:p,height:m,strokeWidth:2,stroke:L.getColor(o.COLORS.darkGray,1),evented:!1});this._anchorShape=S,s.addObject(S,G.TEXT_RANGE_LAYER_INDEX)}_getDocObject(){return G.getDocObject(this._univerInstanceService,this._renderManagerService)}_getPageContentSize(e){const t=this._renderManagerService.getRenderById(e.unitId),n=t==null?void 0:t.with(W.DocSkeletonManagerService).getSkeleton(),i=500,s=500,a=n==null?void 0:n.getSkeletonData();if(a==null||t==null)return{width:i,height:s};const{pages:d}=a;let l=null;for(const c of d){const{skeDrawings:g}=c;if(g.has(e.drawingId)){l=c;break}}if(l){const{pageWidth:c,pageHeight:g,marginLeft:h,marginBottom:m,marginRight:f,marginTop:p}=l;return{width:Math.max(i,c-h-f),height:Math.max(s,g-p-m)}}else return{width:i,height:s}}};We=St([Ue(0,o.ICommandService),Ue(1,o.IUniverInstanceService),Ue(2,X.IDrawingManagerService),Ue(3,L.IRenderManagerService)],We);var Dt=Object.getOwnPropertyDescriptor,Ct=(r,e,t,n)=>{for(var i=n>1?void 0:n?Dt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Pe=(r,e)=>(t,n)=>e(t,n,r);let He=class extends o.RxDisposable{constructor(e,t,n,i,s){super();le(this,"_initImagePopupMenu",new Set);this._drawingManagerService=e,this._canvasPopManagerService=t,this._renderManagerService=n,this._univerInstanceService=i,this._contextService=s,this._init()}_init(){this._univerInstanceService.getCurrentTypeOfUnit$(o.UniverInstanceType.UNIVER_DOC).pipe(Z.takeUntil(this.dispose$)).subscribe(e=>this._create(e)),this._univerInstanceService.getTypeOfUnitDisposed$(o.UniverInstanceType.UNIVER_DOC).pipe(Z.takeUntil(this.dispose$)).subscribe(e=>this._dispose(e)),this._univerInstanceService.getAllUnitsForType(o.UniverInstanceType.UNIVER_DOC).forEach(e=>this._create(e))}_dispose(e){const t=e.getUnitId();this._renderManagerService.removeRender(t)}_create(e){if(!e)return;const t=e.getUnitId();this._renderManagerService.has(t)&&!this._initImagePopupMenu.has(t)&&(this._popupMenuListener(t),this._initImagePopupMenu.add(t))}_hasCropObject(e){const t=e.getAllObjects();for(const n of t)if(n instanceof fe.ImageCropperObject)return!0;return!1}_popupMenuListener(e){var s;const t=(s=this._renderManagerService.getRenderById(e))==null?void 0:s.scene;if(!t)return;const n=t.getTransformerByCreate();if(!n)return;const i=[];this.disposeWithMe(o.toDisposable(n.createControl$.subscribe(()=>{if(this._hasCropObject(t))return;const a=n.getSelectedObjectMap();if(i.forEach(I=>I.dispose()),i.length=0,a.size>1)return;const d=a.values().next().value;if(!d)return;const l=d.oKey,c=this._drawingManagerService.getDrawingOKey(l);if(!c||c.drawingType===o.DrawingTypeEnum.DRAWING_DOM)return;const{unitId:g,subUnitId:h,drawingId:m,drawingType:f}=c,p=this._canvasPopManagerService.attachPopupToObject(d,{componentKey:fe.COMPONENT_IMAGE_POPUP_MENU,direction:"horizontal",offset:[2,0],extraProps:{menuItems:this._getImageMenuItems(g,h,m,f)}},g);i.push(this.disposeWithMe(p)),!this._drawingManagerService.getFocusDrawings().find(I=>I.unitId===g&&I.subUnitId===h&&I.drawingId===m)&&this._drawingManagerService.focusDrawing([{unitId:g,subUnitId:h,drawingId:m}])}))),this.disposeWithMe(o.toDisposable(n.clearControl$.subscribe(()=>{i.forEach(a=>a.dispose()),i.length=0,this._contextService.setContextValue(o.FOCUSING_COMMON_DRAWINGS,!1),this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(o.toDisposable(n.changing$.subscribe(()=>{i.forEach(a=>a.dispose()),i.length=0}))),this.disposeWithMe(o.toDisposable(n.changeStart$.subscribe(()=>{i.forEach(a=>a.dispose()),i.length=0})))}_getImageMenuItems(e,t,n,i){return[{label:"image-popup.edit",index:0,commandId:rn.id,commandParams:{unitId:e,subUnitId:t,drawingId:n},disable:!0},{label:"image-popup.delete",index:1,commandId:Ge.id,commandParams:{unitId:e,drawings:[{unitId:e,subUnitId:t,drawingId:n}]},disable:!1},{label:"image-popup.crop",index:2,commandId:fe.OpenImageCropOperation.id,commandParams:{unitId:e,subUnitId:t,drawingId:n},disable:!0},{label:"image-popup.reset",index:3,commandId:fe.ImageResetSizeOperation.id,commandParams:[{unitId:e,subUnitId:t,drawingId:n}],disable:!0}]}};He=Ct([Pe(0,X.IDrawingManagerService),Pe(1,o.Inject(G.DocCanvasPopManagerService)),Pe(2,L.IRenderManagerService),Pe(3,o.IUniverInstanceService),Pe(4,o.IContextService)],He);var Tt=Object.getOwnPropertyDescriptor,yt=(r,e,t,n)=>{for(var i=n>1?void 0:n?Tt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},De=(r,e)=>(t,n)=>e(t,n,r);let Ye=class extends o.Disposable{constructor(e,t,n,i,s,a,d,l){super();le(this,"_liquid",new L.Liquid);this._context=e,this._docSkeletonManagerService=t,this._commandService=n,this._editorService=i,this._drawingManagerService=s,this._docRefreshDrawingsService=a,this._univerInstanceService=d,this._lifecycleService=l,this._initialize(),this._commandExecutedListener()}_initialize(){this._initialRenderRefresh(),this._drawingInitializeListener(),this._initResize()}_initialRenderRefresh(){this._docSkeletonManagerService.currentSkeleton$.subscribe(e=>{e!=null&&this._refreshDrawing(e)}),this._docRefreshDrawingsService.refreshDrawings$.subscribe(e=>{e!=null&&this._refreshDrawing(e)})}_commandExecutedListener(){const e=[W.RichTextEditingMutation.id,G.SetDocZoomRatioOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(e.includes(t.id)){const n=t.params,{unitId:i}=n,{unitId:s,mainComponent:a}=this._context;if(i!==s)return;const d=this._docSkeletonManagerService.getSkeleton();if(d==null)return;if(this._editorService.isEditor(s)&&s!==o.DOCS_ZEN_EDITOR_UNIT_ID_KEY){a==null||a.makeDirty();return}this._refreshDrawing(d)}}))}_initResize(){this.disposeWithMe(o.fromEventSubject(this._context.engine.onTransformChange$).pipe(Z.filter(e=>e.type===L.TRANSFORM_CHANGE_OBSERVABLE_TYPE.resize),Z.debounceTime(16)).subscribe(()=>{var n;const e=this._docSkeletonManagerService.getSkeleton(),{scene:t}=this._context;(n=t.getTransformer())==null||n.refreshControls(),this._refreshDrawing(e)}))}_refreshDrawing(e){var T,y;const t=e==null?void 0:e.getSkeletonData(),{mainComponent:n,unitId:i}=this._context,s=n;if(!t)return;const{left:a,top:d,pageLayoutType:l,pageMarginLeft:c,pageMarginTop:g}=s,{pages:h,skeHeaders:m,skeFooters:f}=t,p={};this._liquid.reset();for(let O=0,P=h.length;O<P;O++){const M=h[O],{headerId:A,footerId:H,pageWidth:E}=M;if(A){const _=(T=m.get(A))==null?void 0:T.get(E);_&&this._calculateDrawingPosition(i,_,a,d,p,_.marginTop,M.marginLeft)}if(H){const _=(y=f.get(H))==null?void 0:y.get(E);_&&this._calculateDrawingPosition(i,_,a,d,p,M.pageHeight-M.marginBottom+_.marginTop,M.marginLeft)}this._calculateDrawingPosition(i,M,a,d,p,M.marginTop,M.marginLeft),this._liquid.translatePage(M,l,c,g)}const w=Object.values(p),S=w.filter(O=>!O.isMultiTransform),I=w.filter(O=>O.isMultiTransform);S.length>0&&this._drawingManagerService.refreshTransform(S),this._handleMultiDrawingsTransform(I)}_handleMultiDrawingsTransform(e){const{scene:t,unitId:n}=this._context,i=t.getTransformerByCreate();e.forEach(l=>{const c=this._drawingManagerService.getDrawingByParam(l);c!=null&&(c.transform=l.transform,c.transforms=l.transforms,c.isMultiTransform=l.isMultiTransform)});const a=[...i.getSelectedObjectMap().keys()],d=Object.values(this._drawingManagerService.getDrawingData(n,n)).filter(l=>l.isMultiTransform===o.BooleanNumber.TRUE);this._drawingManagerService.removeNotification(d),e.length>0&&this._drawingManagerService.addNotification(e);for(const l of a){const c=t.getObject(l);c&&i.setSelectedControl(c)}}_calculateDrawingPosition(e,t,n,i,s,a,d){const{skeDrawings:l}=t;this._liquid.translatePagePadding({marginTop:a,marginLeft:d}),l.forEach(c=>{const{aLeft:g,aTop:h,height:m,width:f,angle:p,drawingId:w,drawingOrigin:S}=c,I=S.layoutType===o.PositionedObjectLayoutType.WRAP_NONE&&S.behindDoc===o.BooleanNumber.TRUE,{isMultiTransform:T=o.BooleanNumber.FALSE}=S,y={left:g+n+this._liquid.x,top:h+i+this._liquid.y,width:f,height:m,angle:p};s[w]==null?s[w]={unitId:e,subUnitId:e,drawingId:w,behindText:I,transform:y,transforms:[y],isMultiTransform:T}:T===o.BooleanNumber.TRUE&&s[w].transforms.push(y)}),this._liquid.restorePagePadding({marginTop:a,marginLeft:d})}_drawingInitializeListener(){const e=()=>{const t=this._docSkeletonManagerService.getSkeleton();t!=null&&(this._refreshDrawing(t),this._drawingManagerService.initializeNotification(this._context.unitId))};this._lifecycleService.stage>=o.LifecycleStages.Rendered?this._docSkeletonManagerService.getSkeleton()?e():setTimeout(e,500):this._lifecycleService.lifecycle$.pipe(Z.filter(t=>t===o.LifecycleStages.Rendered)).subscribe(e)}};Ye=yt([De(1,o.Inject(W.DocSkeletonManagerService)),De(2,o.ICommandService),De(3,G.IEditorService),De(4,X.IDrawingManagerService),De(5,o.Inject($e)),De(6,o.IUniverInstanceService),De(7,o.Inject(o.LifecycleService))],Ye);var Ot=Object.defineProperty,bt=Object.getOwnPropertyDescriptor,Mt=(r,e,t)=>e in r?Ot(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,Rt=(r,e,t,n)=>{for(var i=n>1?void 0:n?bt(e,t):e,s=r.length-1,a;s>=0;s--)(a=r[s])&&(i=a(i)||i);return i},Ke=(r,e)=>(t,n)=>e(t,n,r),On=(r,e,t)=>Mt(r,typeof e!="symbol"?e+"":e,t);const Pt="DOC_DRAWING_UI_PLUGIN";exports.UniverDocsDrawingUIPlugin=class extends o.Plugin{constructor(e=cn,t,n,i){super(),this._config=e,this._injector=t,this._renderManagerSrv=n,this._configService=i;const{...s}=o.merge({},cn,this._config);this._configService.setConfig(Nn,s)}onStarting(){[[Fe],[He],[We],[Be],[$e],[exports.DocFloatDomController],[ke]].forEach(t=>this._injector.add(t))}onReady(){[[Le],[Ye]].forEach(e=>this._renderManagerSrv.registerRenderModule(o.UniverInstanceType.UNIVER_DOC,e)),this._injector.get(Be),this._injector.get(Fe),this._injector.get(We),this._injector.get(ke)}onRendered(){this._injector.get(He),this._injector.get(exports.DocFloatDomController)}};On(exports.UniverDocsDrawingUIPlugin,"type",o.UniverInstanceType.UNIVER_DOC);On(exports.UniverDocsDrawingUIPlugin,"pluginName",Pt);exports.UniverDocsDrawingUIPlugin=Rt([o.DependentOn(fe.UniverDrawingUIPlugin,X.UniverDrawingPlugin,ve.UniverDocsDrawingPlugin,k.UniverUIPlugin),Ke(1,o.Inject(o.Injector)),Ke(2,L.IRenderManagerService),Ke(3,o.IConfigService)],exports.UniverDocsDrawingUIPlugin);exports.ClearDocDrawingTransformerOperation=_n;exports.DOCS_IMAGE_MENU_ID=on;exports.DeleteDocDrawingsCommand=Je;exports.EditDocDrawingOperation=rn;exports.GroupDocDrawingCommand=Ze;exports.InsertDocDrawingCommand=Ve;exports.InsertDocImageCommand=nn;exports.MoveDocDrawingsCommand=ye;exports.RemoveDocDrawingCommand=Ge;exports.SetDocDrawingArrangeCommand=Qe;exports.SidebarDocDrawingOperation=tn;exports.UngroupDocDrawingCommand=en;
|