@univerjs/docs-drawing-ui 0.5.5-nightly.202501210925 → 0.5.5-nightly.202501220324
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 -9
- package/lib/cjs/locale/en-US.js +1 -1
- package/lib/cjs/locale/fa-IR.js +1 -1
- package/lib/cjs/locale/fr-FR.js +1 -1
- package/lib/cjs/locale/ru-RU.js +1 -1
- package/lib/cjs/locale/vi-VN.js +1 -1
- package/lib/cjs/locale/zh-CN.js +1 -1
- package/lib/cjs/locale/zh-TW.js +1 -1
- package/lib/es/index.js +55 -85
- package/lib/types/views/doc-image-panel/DocDrawingPanel.d.ts +16 -2
- package/lib/types/views/doc-image-panel/DocDrawingPosition.d.ts +1 -2
- package/lib/types/views/doc-image-panel/DocDrawingTextWrap.d.ts +1 -2
- package/lib/umd/index.js +1 -9
- package/lib/umd/locale/en-US.js +1 -1
- package/lib/umd/locale/fa-IR.js +1 -1
- package/lib/umd/locale/fr-FR.js +1 -1
- package/lib/umd/locale/ru-RU.js +1 -1
- package/lib/umd/locale/vi-VN.js +1 -1
- package/lib/umd/locale/zh-CN.js +1 -1
- package/lib/umd/locale/zh-TW.js +1 -1
- package/package.json +11 -11
package/lib/umd/index.js
CHANGED
|
@@ -1,9 +1 @@
|
|
|
1
|
-
(function(E,i){typeof exports=="object"&&typeof module<"u"?i(exports,require("@univerjs/core"),require("@univerjs/docs-drawing"),require("@univerjs/drawing"),require("@univerjs/drawing-ui"),require("@univerjs/engine-render"),require("@univerjs/ui"),require("@univerjs/docs"),require("@univerjs/docs-ui"),require("rxjs"),require("@univerjs/design"),require("react")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@univerjs/docs-drawing","@univerjs/drawing","@univerjs/drawing-ui","@univerjs/engine-render","@univerjs/ui","@univerjs/docs","@univerjs/docs-ui","rxjs","@univerjs/design","react"],i):(E=typeof globalThis<"u"?globalThis:E||self,i(E.UniverDocsDrawingUi={},E.UniverCore,E.UniverDocsDrawing,E.UniverDrawing,E.UniverDrawingUi,E.UniverEngineRender,E.UniverUi,E.UniverDocs,E.UniverDocsUi,E.rxjs,E.UniverDesign,E.React))})(this,function(E,i,ee,W,Te,B,Z,k,X,pe,$,J){"use strict";var Ot=Object.defineProperty;var yt=(E,i,ee)=>i in E?Ot(E,i,{enumerable:!0,configurable:!0,writable:!0,value:ee}):E[i]=ee;var fe=(E,i,ee)=>yt(E,typeof i!="symbol"?i+"":i,ee);const xn="docs-drawing-ui.config",on={};var Rn=Object.defineProperty,Nn=Object.getOwnPropertyDescriptor,En=(a,e,n,t)=>{for(var r=t>1?void 0:t?Nn(e,n):e,o=a.length-1,s;o>=0;o--)(s=a[o])&&(r=(t?s(e,n,r):s(r))||r);return t&&r&&Rn(e,n,r),r},be=(a,e)=>(n,t)=>e(n,t,a);function An(a){var t,r,o,s;if(i.JSONX.isNoop(a)||!Array.isArray(a))return null;const e=a.find(c=>Array.isArray(c)&&(c==null?void 0:c[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 n=[];if(Array.isArray(e==null?void 0:e[1]))for(const c of e)Array.isArray(c)&&n.push({type:(t=c==null?void 0:c[1])!=null&&t.i?"add":"remove",drawingId:c==null?void 0:c[0],drawing:(r=c==null?void 0:c[1])==null?void 0:r.i});else n.push({type:(o=e[2])!=null&&o.i?"add":"remove",drawingId:e[1],drawing:(s=e[2])==null?void 0:s.i});return n}function jn(a){if(!Array.isArray(a)||a.length<3||a[0]!=="drawingsOrder")return[];const e=[];for(let n=1;n<a.length;n++){const t=a[n];if(Array.isArray(t)&&typeof t[0]=="number"&&typeof t[1]=="object")e.push(t[0]);else{e.length=0;break}}return e}let Ae=class extends i.Disposable{constructor(a,e,n,t,r){super(),this._univerInstanceService=a,this._commandService=e,this._drawingManagerService=n,this._docDrawingService=t,this._renderManagerService=r,this._initialize()}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(a=>{if(a.id!==k.RichTextEditingMutation.id)return;const e=a.params,{unitId:n,actions:t}=e,r=An(t);if(r!=null)for(const{type:o,drawingId:s,drawing:c}of r)o==="add"?this._addDrawings(n,[c]):this._removeDrawings(n,[s])})),this.disposeWithMe(this._commandService.onCommandExecuted(a=>{if(a.id!==k.RichTextEditingMutation.id)return;const e=a.params,{unitId:n,actions:t}=e;jn(t).length>0&&this._updateDrawingsOrder(n)})),this.disposeWithMe(this._commandService.onCommandExecuted(a=>{var s;if(a.id!==i.UndoCommand.id&&a.id!==i.RedoCommand.id)return;const e=(s=this._univerInstanceService.getCurrentUniverDocInstance())==null?void 0:s.getUnitId(),n=this._drawingManagerService.getFocusDrawings();if(e==null||n.length===0)return;const t=this._renderManagerService.getRenderById(e),r=t==null?void 0:t.scene;if(r==null)return!1;r.getTransformerByCreate().refreshControls()}))}_addDrawings(a,e){const n=this._drawingManagerService,t=this._docDrawingService,r=this._docDrawingService.getBatchAddOp(e),{subUnitId:o,redo:s,objects:c}=r;n.applyJson1(a,o,s),t.applyJson1(a,o,s),n.addNotification(c),t.addNotification(c)}_removeDrawings(a,e){const n=this._drawingManagerService,t=this._docDrawingService,r=this._docDrawingService.getBatchRemoveOp(e.map(d=>({unitId:a,subUnitId:a,drawingId:d}))),{subUnitId:o,redo:s,objects:c}=r;n.applyJson1(a,o,s),t.applyJson1(a,o,s),n.removeNotification(c),t.removeNotification(c)}_updateDrawingsOrder(a){const e=this._univerInstanceService.getUniverDocInstance(a);if(e==null)return;const n=e.getSnapshot().drawingsOrder;if(n==null)return;const t=this._drawingManagerService,r=this._docDrawingService;t.setDrawingOrder(a,a,n),r.setDrawingOrder(a,a,n);const o={unitId:a,subUnitId:a,drawingIds:n};t.orderNotification(o),r.orderNotification(o)}};Ae=En([be(0,i.IUniverInstanceService),be(1,i.ICommandService),be(2,W.IDrawingManagerService),be(3,ee.IDocDrawingService),be(4,B.IRenderManagerService)],Ae);class je{constructor(){fe(this,"_refreshDrawings$",new pe.BehaviorSubject(null));fe(this,"refreshDrawings$",this._refreshDrawings$.asObservable())}refreshDrawings(e){this._refreshDrawings$.next(e)}}var ie=(a=>(a.INLINE="inline",a.BEHIND_TEXT="behindText",a.IN_FRONT_OF_TEXT="inFrontOfText",a.WRAP_SQUARE="wrapSquare",a.WRAP_TOP_AND_BOTTOM="wrapTopAndBottom",a))(ie||{});const Ln={inline:i.PositionedObjectLayoutType.INLINE,wrapSquare:i.PositionedObjectLayoutType.WRAP_SQUARE,wrapTopAndBottom:i.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM,inFrontOfText:i.PositionedObjectLayoutType.WRAP_NONE,behindText:i.PositionedObjectLayoutType.WRAP_NONE};function sn(a,e,n,t,r,o,s){var v,h;const c=new i.TextX,d=i.JSONX.getInstance(),l=[],m=o.getSelfOrHeaderFooterModel(e).getBody(),f=o.getSelfOrHeaderFooterModel(a).getBody();if(m==null||f==null)return;const u=(h=(v=m.customBlocks)==null?void 0:v.find(w=>w.blockId===r))==null?void 0:h.startIndex;if(u!=null){if(t=Math.min(f.dataStream.length-2,t),a===e){if(t<u?(t>0&&c.push({t:i.TextXActionType.RETAIN,len:t}),c.push({t:i.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:r}]},len:1}),c.push({t:i.TextXActionType.RETAIN,len:u-t}),c.push({t:i.TextXActionType.DELETE,len:1})):(u>0&&c.push({t:i.TextXActionType.RETAIN,len:u}),c.push({t:i.TextXActionType.DELETE,len:1}),t-u-1>0&&c.push({t:i.TextXActionType.RETAIN,len:t-u-1}),c.push({t:i.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:r}]},len:1})),t!==u){const w=X.getRichTextEditPath(o,e),I=d.editOp(c.serialize(),w);l.push(I)}}else{u>0&&c.push({t:i.TextXActionType.RETAIN,len:u}),c.push({t:i.TextXActionType.DELETE,len:1});let w=X.getRichTextEditPath(o,e),I=d.editOp(c.serialize(),w);l.push(I),c.empty(),t>0&&c.push({t:i.TextXActionType.RETAIN,len:t}),c.push({t:i.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:r}]},len:1}),w=X.getRichTextEditPath(o,a),I=d.editOp(c.serialize(),w),l.push(I),s.setSegment(a),s.setSegmentPage(n)}return l}}const cn={id:"doc.command.update-doc-drawing-wrapping-style",type:i.CommandType.COMMAND,handler:(a,e)=>{var A,H;if(e==null)return!1;const{drawings:n,wrappingStyle:t,unitId:r}=e,o=a.get(i.ICommandService),s=a.get(i.IUniverInstanceService),d=a.get(B.IRenderManagerService).getRenderById(r),l=d==null?void 0:d.with(k.DocSkeletonManagerService).getSkeleton().getSkeletonData(),m=d==null?void 0:d.with(k.DocSkeletonManagerService).getViewModel(),f=d==null?void 0:d.scene,u=s.getCurrentUniverDocInstance();if(u==null||l==null||f==null||m==null)return!1;const v=m.getEditArea(),h=f.getTransformerByCreate(),{pages:w,skeHeaders:I,skeFooters:D}=l,O=i.JSONX.getInstance(),T=[],{drawings:y={}}=u.getSnapshot();for(const N of n){const{drawingId:S}=N,F=y[S].layoutType,z=Ln[t];if(F!==z){const C=O.replaceOp(["drawings",S,"layoutType"],F,z);T.push(C)}if(t==="behindText"||t==="inFrontOfText"){const C=y[S].behindDoc,R=t==="behindText"?i.BooleanNumber.TRUE:i.BooleanNumber.FALSE;if(C!==R){const b=O.replaceOp(["drawings",S,"behindDoc"],C,R);T.push(b)}}if(t==="inline")continue;let L=null,q=0,_=0;for(const C of w){const{headerId:R,footerId:b,marginTop:U,marginLeft:V,marginBottom:M,pageWidth:j,pageHeight:Y}=C;switch(v){case B.DocumentEditArea.HEADER:{const G=(A=I.get(R))==null?void 0:A.get(j);G!=null&&G.skeDrawings.has(S)&&(L=G.skeDrawings.get(S),q=G.marginTop,_=V);break}case B.DocumentEditArea.FOOTER:{const G=(H=D.get(b))==null?void 0:H.get(j);G!=null&&G.skeDrawings.has(S)&&(L=G.skeDrawings.get(S),q=Y-M+G.marginTop,_=V);break}case B.DocumentEditArea.BODY:{C.skeDrawings.has(S)&&(L=C.skeDrawings.get(S),q=U,_=V);break}}if(L!=null)break}if(L!=null){const{aTop:C,aLeft:R}=L,b=y[S].docTransform.positionH;let U=R;b.relativeFrom===i.ObjectRelativeFromH.MARGIN?U-=_:b.relativeFrom===i.ObjectRelativeFromH.COLUMN&&(U-=L.columnLeft);const V={relativeFrom:b.relativeFrom,posOffset:U};if(b.posOffset!==V.posOffset){const G=O.replaceOp(["drawings",S,"docTransform","positionH"],b,V);T.push(G)}const M=y[S].docTransform.positionV;let j=C;M.relativeFrom===i.ObjectRelativeFromV.PAGE?j+=q:M.relativeFrom===i.ObjectRelativeFromV.LINE?j-=L.lineTop:M.relativeFrom===i.ObjectRelativeFromV.PARAGRAPH&&(j-=L.blockAnchorTop);const Y={relativeFrom:M.relativeFrom,posOffset:j};if(M.posOffset!==Y.posOffset){const G=O.replaceOp(["drawings",S,"docTransform","positionV"],M,Y);T.push(G)}}}const x={id:k.RichTextEditingMutation.id,params:{unitId:r,actions:[],textRanges:null}};x.params.actions=T.reduce((N,S)=>i.JSONX.compose(N,S),null);const P=o.syncExecuteCommand(x.id,x.params);return h.refreshControls(),!!P}},ln={id:"doc.command.update-doc-drawing-distance",type:i.CommandType.COMMAND,handler:(a,e)=>{if(e==null)return!1;const n=a.get(i.ICommandService),r=a.get(i.IUniverInstanceService).getCurrentUniverDocInstance();if(r==null)return!1;const{drawings:o,dist:s,unitId:c}=e,d=i.JSONX.getInstance(),l=[],{drawings:m={}}=r.getSnapshot();for(const v of o){const{drawingId:h}=v;for(const[w,I]of Object.entries(s)){const D=m[h][w];if(D!==I){const O=d.replaceOp(["drawings",h,w],D,I);l.push(O)}}}const f={id:k.RichTextEditingMutation.id,params:{unitId:c,actions:[],textRanges:null}};return f.params.actions=l.reduce((v,h)=>i.JSONX.compose(v,h),null),!!n.syncExecuteCommand(f.id,f.params)}},dn={id:"doc.command.update-doc-drawing-wrap-text",type:i.CommandType.COMMAND,handler:(a,e)=>{if(e==null)return!1;const n=a.get(i.ICommandService),r=a.get(i.IUniverInstanceService).getCurrentUniverDocInstance();if(r==null)return!1;const{drawings:o,wrapText:s,unitId:c}=e,d=i.JSONX.getInstance(),l=[],{drawings:m={}}=r.getSnapshot();for(const v of o){const{drawingId:h}=v,w=m[h].wrapText;if(w!==s){const I=d.replaceOp(["drawings",h,"wrapText"],w,s);l.push(I)}}const f={id:k.RichTextEditingMutation.id,params:{unitId:c,actions:[],textRanges:null}};return f.params.actions=l.reduce((v,h)=>i.JSONX.compose(v,h),null),!!n.syncExecuteCommand(f.id,f.params)}},Pe={id:"doc.command.update-drawing-doc-transform",type:i.CommandType.COMMAND,handler:(a,e)=>{if(e==null)return!1;const n=a.get(i.ICommandService),t=a.get(i.IUniverInstanceService),o=a.get(B.IRenderManagerService).getRenderById(e.unitId),s=o==null?void 0:o.scene;if(s==null)return!1;const c=s.getTransformerByCreate(),d=t.getCurrentUniverDocInstance();if(d==null)return!1;const{drawings:l,unitId:m}=e,f=i.JSONX.getInstance(),u=[],{drawings:v={}}=d.getSnapshot();for(const I of l){const{drawingId:D,key:O,value:T}=I,y=v[D].docTransform[O];if(!i.Tools.diffValue(y,T)){const x=f.replaceOp(["drawings",D,"docTransform",O],y,T);u.push(x)}}const h={id:k.RichTextEditingMutation.id,params:{unitId:m,actions:[],textRanges:null,debounce:!0}};h.params.actions=u.reduce((I,D)=>i.JSONX.compose(I,D),null);const w=n.syncExecuteCommand(h.id,h.params);return c.refreshControls(),!!w}},mn={id:"doc.command.move-inline-drawing",type:i.CommandType.COMMAND,handler:(a,e)=>{var H,N;if(e==null)return!1;const n=a.get(B.IRenderManagerService),t=(H=n.getRenderById(e.unitId))==null?void 0:H.with(X.DocSelectionRenderService),r=a.get(je),o=n.getRenderById(e.unitId),s=o==null?void 0:o.scene,c=o==null?void 0:o.with(k.DocSkeletonManagerService).getSkeleton();if(s==null||t==null)return!1;const d=s.getTransformerByCreate(),l=a.get(i.ICommandService),f=a.get(i.IUniverInstanceService).getCurrentUniverDocInstance();if(f==null)return!1;const{drawing:u,unitId:v,offset:h,segmentId:w,segmentPage:I,needRefreshDrawings:D}=e;if(D)return r.refreshDrawings(c),d.refreshControls(),!0;const O=[],{drawingId:T}=u,y=(N=t.getSegment())!=null?N:"",x=sn(w,y,I,h,T,f,t);if(x==null||x.length===0)return r.refreshDrawings(c),d.refreshControls(),!1;O.push(...x);const P={id:k.RichTextEditingMutation.id,params:{unitId:v,actions:[],textRanges:null}};P.params.actions=O.reduce((S,F)=>i.JSONX.compose(S,F),null);const A=l.syncExecuteCommand(P.id,P.params);return d.refreshControls(),!!A}},gn={id:"doc.command.transform-non-inline-drawing",type:i.CommandType.COMMAND,handler:(a,e)=>{var L,q;if(e==null)return!1;const n=a.get(B.IRenderManagerService),t=(L=n.getRenderById(e.unitId))==null?void 0:L.with(X.DocSelectionRenderService),r=n.getRenderById(e.unitId),o=r==null?void 0:r.scene;if(o==null||t==null)return!1;const s=o.getTransformerByCreate(),c=a.get(i.ICommandService),l=a.get(i.IUniverInstanceService).getCurrentUniverDocInstance();if(l==null)return!1;const{drawing:m,unitId:f,offset:u,docTransform:v,segmentId:h,segmentPage:w}=e,I=[],{drawingId:D}=m,O=(q=t.getSegment())!=null?q:"",T=sn(h,O,w,u,D,l,t);if(T==null)return!1;T.length>0&&I.push(...T);const y=i.JSONX.getInstance(),{drawings:x={}}=l.getSnapshot(),P=x[D].docTransform,{positionH:A,positionV:H,size:N,angle:S}=P;if(!i.Tools.diffValue(A,v.positionH)){const _=y.replaceOp(["drawings",D,"docTransform","positionH"],A,v.positionH);I.push(_)}if(!i.Tools.diffValue(H,v.positionV)){const _=y.replaceOp(["drawings",D,"docTransform","positionV"],H,v.positionV);I.push(_)}if(!i.Tools.diffValue(N,v.size)){const _=y.replaceOp(["drawings",D,"docTransform","size"],N,v.size);I.push(_)}if(!i.Tools.diffValue(S,v.angle)){const _=y.replaceOp(["drawings",D,"docTransform","angle"],S,v.angle);I.push(_)}const F={id:k.RichTextEditingMutation.id,params:{unitId:f,actions:[],textRanges:null,debounce:!0}};F.params.actions=I.reduce((_,C)=>i.JSONX.compose(_,C),null);const z=c.syncExecuteCommand(F.id,F.params);return s.refreshControls(),!!z}};var Fn=Object.defineProperty,Un=Object.getOwnPropertyDescriptor,Bn=(a,e,n,t)=>{for(var r=t>1?void 0:t?Un(e,n):e,o=a.length-1,s;o>=0;o--)(s=a[o])&&(r=(t?s(e,n,r):s(r))||r);return t&&r&&Fn(e,n,r),r},Le=(a,e)=>(n,t)=>e(n,t,a);const kn="__InlineDrawingAnchor__";function un(a){const{path:e}=a;return e.some(n=>n==="cells")}let Fe=class extends i.Disposable{constructor(e,n,t,r){super();fe(this,"_liquid",new B.Liquid);fe(this,"_listenerOnImageMap",new Set);fe(this,"_transformerCache",new Map);fe(this,"_anchorShape");this._commandService=e,this._univerInstanceService=n,this._drawingManagerService=t,this._renderManagerService=r,this._init()}_init(){this._listenDrawingFocus()}_listenDrawingFocus(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(e=>{if(e.length!==0)for(const n of e){const{unitId:t}=n;this._listenerOnImageMap.has(t)||(this._listenTransformerChange(t),this._listenerOnImageMap.add(t))}}))}_listenTransformerChange(e){var r;const n=(r=this._getSceneAndTransformerByDrawingSearch(e))==null?void 0:r.transformer;if(n==null)return;this.disposeWithMe(i.toDisposable(n.changeStart$.subscribe(o=>{var c;this._transformerCache.clear();const{objects:s}=o;for(const d of s.values()){const{oKey:l,width:m,height:f,left:u,top:v,angle:h}=d,w=this._drawingManagerService.getDrawingOKey(l);if(w==null)continue;const I=this._univerInstanceService.getUniverDocInstance(w.unitId),D=(c=I==null?void 0:I.getSnapshot().drawings)==null?void 0:c[w.drawingId];(D==null?void 0:D.layoutType)===i.PositionedObjectLayoutType.INLINE&&d.setOpacity(.2),D!=null&&this._transformerCache.set(w.drawingId,{drawing:D,top:v,left:u,width:m,height:f,angle:h})}})));const t=i.throttle(this._updateMultipleDrawingDocTransform.bind(this),50);i.throttle(this._nonInlineDrawingTransform.bind(this),50),this.disposeWithMe(i.toDisposable(n.changing$.subscribe(o=>{const{objects:s,offsetX:c,offsetY:d}=o;if(s.size>1)t(s);else if(s.size===1){const l=this._transformerCache.values().next().value,m=s.values().next().value,{width:f,height:u,top:v,left:h,angle:w}=m;if(l&&f===l.width&&u===l.height&&v===l.top&&h===l.left&&w===l.angle)return;l&&(l.drawing.layoutType,i.PositionedObjectLayoutType.INLINE),l&&l.drawing.layoutType===i.PositionedObjectLayoutType.INLINE&&c!=null&&d!=null&&this._updateInlineDrawingAnchor(l.drawing,c,d)}}))),this.disposeWithMe(i.toDisposable(n.changeEnd$.subscribe(o=>{const{objects:s,offsetX:c,offsetY:d}=o;for(const l of s.values()){const m=this._drawingManagerService.getDrawingOKey(l.oKey);if(m==null)continue;const f=this._transformerCache.get(m==null?void 0:m.drawingId);(f==null?void 0:f.drawing.layoutType)===i.PositionedObjectLayoutType.INLINE&&l.setOpacity(1)}if(this._anchorShape&&this._anchorShape.hide(),s.size>1)this._updateMultipleDrawingDocTransform(s);else if(s.size===1){const l=this._transformerCache.values().next().value,m=s.values().next().value,{width:f,height:u,top:v,left:h,angle:w}=m;if(l&&f===l.width&&u===l.height&&v===l.top&&h===l.left&&w===l.angle)return;l&&l.drawing.layoutType===i.PositionedObjectLayoutType.INLINE?f!==l.width||u!==l.height||w!==l.angle?this._updateDrawingSize(l,m):c!=null&&d!=null&&this._moveInlineDrawing(l.drawing,c,d):l&&this._nonInlineDrawingTransform(l.drawing,m)}this._transformerCache.clear()})))}_updateMultipleDrawingDocTransform(e){if(e.size<1)return;const n=[];let t,r;for(const o of e.values()){const{oKey:s,left:c,top:d,angle:l}=o;let{width:m,height:f}=o;const u=this._drawingManagerService.getDrawingOKey(s);if(u==null)continue;t==null&&(t=u.unitId),r==null&&(r=u.subUnitId);const v=this._transformerCache.get(u.drawingId);if(v==null)continue;const{drawing:h,top:w,left:I,width:D,height:O,angle:T}=v,{width:y,height:x}=this._getPageContentSize(h);if(m=Math.min(m,y),f=Math.min(f,x),(D!==m||O!==f)&&n.push({drawingId:u.drawingId,key:"size",value:{width:m,height:f}}),T!==l&&n.push({drawingId:u.drawingId,key:"angle",value:l}),w!==d||I!==c){const P=d-w,A=c-I;P!==0&&n.push({drawingId:u.drawingId,key:"positionV",value:{relativeFrom:h.docTransform.positionV.relativeFrom,posOffset:h.docTransform.positionV.posOffset+P}}),A!==0&&n.push({drawingId:u.drawingId,key:"positionH",value:{relativeFrom:h.docTransform.positionH.relativeFrom,posOffset:h.docTransform.positionH.posOffset+A}})}}n.length>0&&t&&r&&this._commandService.executeCommand(Pe.id,{unitId:t,subUnitId:r,drawings:n})}_updateDrawingAnchor(e){if(this._transformerCache.size!==1)return;const n=this._transformerCache.values().next().value,t=e.values().next().value;this._getDrawingAnchor(n.drawing,t)}_updateInlineDrawingAnchor(e,n,t){var o;if(this._transformerCache.size!==1)return;const{contentBoxPointGroup:r}=(o=this._getInlineDrawingAnchor(e,n,t))!=null?o:{};r!=null&&this._createOrUpdateInlineAnchor(e.unitId,r)}_getInlineDrawingAnchor(e,n,t){var L,q;const r=this._renderManagerService.getRenderById(e.unitId),o=r==null?void 0:r.with(k.DocSkeletonManagerService).getSkeleton();if(r==null)return;const{mainComponent:s,scene:c}=r,d=s,l=c.getViewports()[0],{pageLayoutType:m=B.PageLayoutType.VERTICAL,pageMarginLeft:f,pageMarginTop:u}=d.getOffsetConfig();let v=null,h=!1,w=-1,I="";const D=.5,O=this._getTransformCoordForDocumentOffset(d,l,n,t);if(O==null)return;const T=(L=this._renderManagerService.getRenderById(e.unitId))==null?void 0:L.with(X.DocSelectionRenderService);if(T==null)return;const y=o==null?void 0:o.findNodeByCoord(O,m,f,u,{strict:!1,segmentId:T.getSegment(),segmentPage:T.getSegmentPage()});if(y){const{node:_,ratioX:C,segmentPage:R,segmentId:b}=y;h=C<D,v=_,w=R,I=b}if(v==null)return;const x=o==null?void 0:o.findPositionByGlyph(v,w),P=this._getDocObject();if(x==null||o==null||P==null||un(x))return;const A={...x,isBack:h},H=P.document.getOffsetConfig(),N=new X.NodePositionConvertToCursor(H,o),{cursorList:S,contentBoxPointGroup:F}=N.getRangePointData(A,A),{startOffset:z}=(q=X.getOneTextSelectionRange(S))!=null?q:{};if(z!=null)return{offset:z,contentBoxPointGroup:F,segmentId:I,segmentPage:w}}_getDrawingAnchor(e,n){var ge,ue,ce,he,ve,_e,De,Ie,le,de,Ce;const t=this._renderManagerService.getRenderById(e.unitId),r=t==null?void 0:t.with(k.DocSkeletonManagerService).getSkeleton(),o=r==null?void 0:r.getSkeletonData();if(o==null||t==null)return;const{pages:s,skeHeaders:c,skeFooters:d}=o,{mainComponent:l,scene:m}=t,f=l,u=m.getViewports()[0],{pageLayoutType:v=B.PageLayoutType.VERTICAL,pageMarginLeft:h,pageMarginTop:w,docsLeft:I,docsTop:D}=f.getOffsetConfig(),{left:O,top:T,angle:y}=n;let{width:x,height:P}=n;const{positionV:A,positionH:H}=e.docTransform,{width:N,height:S}=this._getPageContentSize(e);x=Math.min(x,N),P=Math.min(P,S);let F=null,z="",L=-1;const q=!1,_={...e.docTransform,size:{width:x,height:P},angle:y},{x:C,y:R}=m.getViewportScrollXY(u),b=this._getTransformCoordForDocumentOffset(f,u,O-C,T-R);if(b==null)return;const U=(ge=this._renderManagerService.getRenderById(e.unitId))==null?void 0:ge.with(X.DocSelectionRenderService);if(U==null)return;const V=r==null?void 0:r.findNodeByCoord(b,v,h,w,{strict:!1,segmentId:U.getSegment(),segmentPage:U.getSegmentPage()});if(V){const{node:me,segmentPage:an,segmentId:rn}=V;F=me,L=an,z=rn}if(F==null)return;const M=(ue=F.parent)==null?void 0:ue.parent,j=M==null?void 0:M.parent,Y=(ce=j==null?void 0:j.lines.find(me=>me.paragraphIndex===(M==null?void 0:M.paragraphIndex)&&me.paragraphStart))!=null?ce:j==null?void 0:j.lines[0],G=(he=j==null?void 0:j.parent)==null?void 0:he.parent;if(M==null||j==null||Y==null||G==null)return;this._liquid.reset();const Q=G.type;for(const me of s){const{headerId:an,footerId:rn,pageHeight:Dt,pageWidth:Pn,marginLeft:Mn,marginBottom:Ct}=me,Tt=s.indexOf(me);if(L>-1&&Tt===L){switch(Q){case B.DocumentSkeletonPageType.HEADER:{const Ee=(ve=c.get(an))==null?void 0:ve.get(Pn);if(Ee)this._liquid.translatePagePadding({marginTop:Ee.marginTop,marginLeft:Mn});else throw new Error("header skeleton not found");break}case B.DocumentSkeletonPageType.FOOTER:{const Ee=(_e=d.get(rn))==null?void 0:_e.get(Pn);if(Ee)this._liquid.translatePagePadding({marginTop:Dt-Ct+Ee.marginTop,marginLeft:Mn});else throw new Error("footer skeleton not found");break}}break}if(this._liquid.translatePagePadding(me),me===G)break;this._liquid.restorePagePadding(me),this._liquid.translatePage(me,v,h,w)}switch(A.relativeFrom===i.ObjectRelativeFromV.LINE?F=M.divides[0].glyphGroup[0]:F=(de=(le=(Ie=(De=Y.divides)==null?void 0:De[0])==null?void 0:Ie.glyphGroup)==null?void 0:le[0])!=null?de:F,_.positionH={relativeFrom:H.relativeFrom,posOffset:O-this._liquid.x-I},H.relativeFrom){case i.ObjectRelativeFromH.MARGIN:{_.positionH.posOffset=O-this._liquid.x-I-G.marginLeft;break}case i.ObjectRelativeFromH.COLUMN:{_.positionH.posOffset=O-this._liquid.x-I-j.left;break}}switch(_.positionV={relativeFrom:A.relativeFrom,posOffset:T-this._liquid.y-D},A.relativeFrom){case i.ObjectRelativeFromV.PAGE:{_.positionV.posOffset=T-this._liquid.y-D-G.marginTop;break}case i.ObjectRelativeFromV.LINE:{_.positionV.posOffset=T-this._liquid.y-D-M.top;break}case i.ObjectRelativeFromV.PARAGRAPH:{_.positionV.posOffset=T-this._liquid.y-D-Y.top;break}}if(F==null)return;const oe=r==null?void 0:r.findPositionByGlyph(F,L),ye=this._getDocObject();if(oe==null||r==null||ye==null||un(oe))return;const Se={...oe,isBack:q},Ne=ye.document.getOffsetConfig(),se=new X.NodePositionConvertToCursor(Ne,r),{cursorList:ne}=se.getRangePointData(Se,Se),{startOffset:te}=(Ce=X.getOneTextSelectionRange(ne))!=null?Ce:{};if(te!=null)return{offset:te,docTransform:_,segmentId:z,segmentPage:L}}_updateDrawingSize(e,n){const t=[],{drawing:r,width:o,height:s,angle:c}=e,{unitId:d,subUnitId:l}=r;let{width:m,height:f,angle:u}=n;const{width:v,height:h}=this._getPageContentSize(r);m=Math.min(v,m),f=Math.min(h,f),(m!==o||f!==s)&&t.push({drawingId:r.drawingId,key:"size",value:{width:m,height:f}}),u!==c&&t.push({drawingId:r.drawingId,key:"angle",value:u}),t.length>0&&d&&l&&this._commandService.executeCommand(Pe.id,{unitId:d,subUnitId:l,drawings:t})}_moveInlineDrawing(e,n,t){const r=this._getInlineDrawingAnchor(e,n,t),{offset:o,segmentId:s,segmentPage:c}=r!=null?r:{};return this._commandService.executeCommand(mn.id,{unitId:e.unitId,subUnitId:e.unitId,drawing:e,offset:o,segmentId:s,segmentPage:c,needRefreshDrawings:o==null})}_limitDrawingInPage(e,n){const t=this._renderManagerService.getRenderById(e.unitId),{left:r,top:o,width:s,height:c,angle:d}=n,l=t==null?void 0:t.with(k.DocSkeletonManagerService).getSkeleton(),m=l==null?void 0:l.getSkeletonData(),{pages:f}=m!=null?m:{};if(m==null||t==null||f==null)return{left:r,top:o,width:s,height:c,angle:d};const{mainComponent:u}=t,v=u,{top:h,pageLayoutType:w,pageMarginLeft:I,pageMarginTop:D}=v;let O=o;this._liquid.reset();for(const T of f){const{marginBottom:y,pageHeight:x}=T,P=f.indexOf(T),A=f[P+1];if(A==null)continue;if(i.Tools.hasIntersectionBetweenTwoRanges(o,o+c,this._liquid.y+h+x-y,this._liquid.y+h+x+D+A.marginTop)){const N=o+c/2,S=this._liquid.y+h+x+D/2;N<S?O=Math.min(o,this._liquid.y+h+x-y-c):O=Math.max(o,this._liquid.y+h+x+D+A.marginTop)}this._liquid.translatePage(T,w,I,D)}return{left:r,top:O,width:s,height:c,angle:d}}_nonInlineDrawingTransform(e,n,t=!1){const r=e.isMultiTransform===i.BooleanNumber.TRUE?n:this._limitDrawingInPage(e,n);if(t&&r.top!==n.top)return;const o=this._getDrawingAnchor(e,r),{offset:s,docTransform:c,segmentId:d,segmentPage:l}=o!=null?o:{};return s==null||c==null?this._updateMultipleDrawingDocTransform(new Map([[e.drawingId,n]])):this._commandService.executeCommand(gn.id,{unitId:e.unitId,subUnitId:e.unitId,drawing:e,offset:s,docTransform:c,segmentId:d,segmentPage:l})}_getSceneAndTransformerByDrawingSearch(e){if(e==null)return;const n=this._renderManagerService.getRenderById(e),t=n==null?void 0:n.scene;if(t==null)return;const r=t.getTransformerByCreate();return{scene:t,transformer:r}}_getTransformCoordForDocumentOffset(e,n,t,r){const{documentTransform:o}=e.getOffsetConfig(),s=n.transformVector2SceneCoord(B.Vector2.FromArray([t,r]));if(s)return o.clone().invert().applyPoint(s)}_createOrUpdateInlineAnchor(e,n){const t=this._renderManagerService.getRenderById(e);if(t==null)return;const{mainComponent:r,scene:o}=t,s=r,{docsLeft:c,docsTop:d}=s.getOffsetConfig(),l=X.getAnchorBounding(n),{left:m,top:f,height:u}=l,v=m+c,h=f+d;if(this._anchorShape){this._anchorShape.transformByState({left:v,top:h,height:u}),this._anchorShape.show();return}const w=6,I=new B.Rect(kn+i.Tools.generateRandomId(w),{left:v,top:h,height:u,strokeWidth:2,stroke:B.getColor(i.COLORS.darkGray,1),evented:!1});this._anchorShape=I,o.addObject(I,X.TEXT_RANGE_LAYER_INDEX)}_getDocObject(){return X.getDocObject(this._univerInstanceService,this._renderManagerService)}_getPageContentSize(e){const n=this._renderManagerService.getRenderById(e.unitId),t=n==null?void 0:n.with(k.DocSkeletonManagerService).getSkeleton(),r=500,o=500,s=t==null?void 0:t.getSkeletonData();if(s==null||n==null)return{width:r,height:o};const{pages:c}=s;let d=null;for(const l of c){const{skeDrawings:m}=l;if(m.has(e.drawingId)){d=l;break}}if(d){const{pageWidth:l,pageHeight:m,marginLeft:f,marginBottom:u,marginRight:v,marginTop:h}=d;return{width:Math.max(r,l-f-v),height:Math.max(o,m-h-u)}}else return{width:r,height:o}}};Fe=Bn([Le(0,i.ICommandService),Le(1,i.IUniverInstanceService),Le(2,W.IDrawingManagerService),Le(3,B.IRenderManagerService)],Fe);var ae=function(){return ae=Object.assign||function(a){for(var e,n=1,t=arguments.length;n<t;n++){e=arguments[n];for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&(a[r]=e[r])}return a},ae.apply(this,arguments)},Hn=function(a,e){var n={};for(var t in a)Object.prototype.hasOwnProperty.call(a,t)&&e.indexOf(t)<0&&(n[t]=a[t]);if(a!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,t=Object.getOwnPropertySymbols(a);r<t.length;r++)e.indexOf(t[r])<0&&Object.prototype.propertyIsEnumerable.call(a,t[r])&&(n[t[r]]=a[t[r]]);return n},fn=J.forwardRef(function(a,e){var n=a.icon,t=a.id,r=a.className,o=a.extend,s=Hn(a,["icon","id","className","extend"]),c="univerjs-icon univerjs-icon-".concat(t," ").concat(r||"").trim(),d=J.useRef("_".concat(Wn()));return pn(n,"".concat(t),{defIds:n.defIds,idSuffix:d.current},ae({ref:e,className:c},s),o)});function pn(a,e,n,t,r){return J.createElement(a.tag,ae(ae({key:e},Vn(a,n,r)),t),(Gn(a,n).children||[]).map(function(o,s){return pn(o,"".concat(e,"-").concat(a.tag,"-").concat(s),n,void 0,r)}))}function Vn(a,e,n){var t=ae({},a.attrs);n!=null&&n.colorChannel1&&t.fill==="colorChannel1"&&(t.fill=n.colorChannel1);var r=e.defIds;return!r||r.length===0||(a.tag==="use"&&t["xlink:href"]&&(t["xlink:href"]=t["xlink:href"]+e.idSuffix),Object.entries(t).forEach(function(o){var s=o[0],c=o[1];typeof c=="string"&&(t[s]=c.replace(/url\(#(.*)\)/,"url(#$1".concat(e.idSuffix,")")))})),t}function Gn(a,e){var n,t=e.defIds;return!t||t.length===0?a:a.tag==="defs"&&(!((n=a.children)===null||n===void 0)&&n.length)?ae(ae({},a),{children:a.children.map(function(r){return typeof r.attrs.id=="string"&&t&&t.indexOf(r.attrs.id)>-1?ae(ae({},r),{attrs:ae(ae({},r.attrs),{id:r.attrs.id+e.idSuffix})}):r})}):a}function Wn(){return Math.random().toString(36).substring(2,8)}fn.displayName="UniverIcon";var Xn={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=J.forwardRef(function(a,e){return J.createElement(fn,Object.assign({},a,{id:"add-image-single",ref:e,icon:Xn}))});hn.displayName="AddImageSingle";const Ue={id:"doc.command.remove-doc-image",type:i.CommandType.COMMAND,handler:(a,e)=>{var x,P,A,H;const n=a.get(i.ICommandService),t=a.get(i.IUniverInstanceService),r=a.get(B.IRenderManagerService),o=t.getCurrentUniverDocInstance();if(e==null||o==null)return!1;const s=r.getRenderById(e.unitId).with(X.DocSelectionRenderService),{drawings:c}=e,d=(x=s.getSegment())!=null?x:"",l=new i.TextX,m=i.JSONX.getInstance(),f=(A=(P=o.getSelfOrHeaderFooterModel(d).getBody())==null?void 0:P.customBlocks)!=null?A:[],u=c.map(N=>f.find(S=>S.blockId===N.drawingId)).filter(N=>!!N).sort((N,S)=>N.startIndex>S.startIndex?1:-1),v=c[0].unitId,h=new i.MemoryCursor;h.reset();const w=u[0].startIndex,I=[{startOffset:w,endOffset:w}],D={id:k.RichTextEditingMutation.id,params:{unitId:v,actions:[],textRanges:I}},O=[];for(const N of u){const{startIndex:S}=N;S>h.cursor&&l.push({t:i.TextXActionType.RETAIN,len:S-h.cursor}),l.push({t:i.TextXActionType.DELETE,len:1}),h.moveCursorTo(S+1)}const T=X.getRichTextEditPath(o,d);O.push(m.editOp(l.serialize(),T));for(const N of u){const{blockId:S}=N,F=((H=o.getDrawings())!=null?H:{})[S],L=o.getDrawingsOrder().indexOf(S),q=m.removeOp(["drawings",S],F),_=m.removeOp(["drawingsOrder",L],S);O.push(q),O.push(_)}return D.params.actions=O.reduce((N,S)=>i.JSONX.compose(N,S),null),!!n.syncExecuteCommand(D.id,D.params)}},Xe={id:"doc.command.delete-drawing",type:i.CommandType.COMMAND,handler:a=>{const e=a.get(i.ICommandService),t=a.get(ee.IDocDrawingService).getFocusDrawings();if(t.length===0)return!1;const{unitId:r}=t[0],o=t.map(s=>{const{unitId:c,subUnitId:d,drawingId:l,drawingType:m}=s;return{unitId:c,subUnitId:d,drawingId:l,drawingType:m}});return e.executeCommand(Ue.id,{unitId:r,drawings:o})}},ze={id:"doc.command.group-doc-image",type:i.CommandType.COMMAND,handler:(a,e)=>{a.get(i.ICommandService),a.get(i.IUndoRedoService);const n=a.get(ee.IDocDrawingService);if(!e)return!1;const t=[];return e.forEach(({parent:r,children:o})=>{t.push(r.unitId),o.forEach(s=>{t.push(s.unitId)})}),n.getGroupDrawingOp(e),!1}},qe={id:"doc.command.insert-doc-image",type:i.CommandType.COMMAND,handler:(a,e)=>{var P,A,H,N;if(e==null)return!1;const n=a.get(i.ICommandService),t=a.get(k.DocSelectionManagerService),r=a.get(i.IUniverInstanceService),o=t.getActiveTextRange(),s=r.getCurrentUniverDocInstance();if(o==null||s==null)return!1;const c=s.getUnitId(),{drawings:d}=e,{collapsed:l,startOffset:m,segmentId:f}=o,u=s.getSelfOrHeaderFooterModel(f).getBody();if(u==null)return!1;const v=new i.TextX,h=i.JSONX.getInstance(),w=[],I=(A=(P=s.getSnapshot().drawingsOrder)==null?void 0:P.length)!=null?A:0;let D=0;if(l)m>0&&v.push({t:i.TextXActionType.RETAIN,len:m});else{const S=i.BuildTextUtils.selection.delete([o],u,0,null,!1);v.push(...S);const F=X.getCustomBlockIdsInSelections(u,[o]),z=(H=s.getDrawings())!=null?H:{},L=(N=s.getDrawingsOrder())!=null?N:[],q=F.sort((_,C)=>L.indexOf(_)>L.indexOf(C)?-1:L.indexOf(_)<L.indexOf(C)?1:0);if(q.length>0)for(const _ of q){const C=z[_],R=L.indexOf(_);if(C==null||R<0)continue;const b=h.removeOp(["drawings",_],C),U=h.removeOp(["drawingsOrder",R],_);w.push(b),w.push(U),D++}}v.push({t:i.TextXActionType.INSERT,body:{dataStream:"\b".repeat(d.length),customBlocks:d.map((S,F)=>({startIndex:F,blockId:S.drawingId}))},len:d.length});const O=X.getRichTextEditPath(s,f),T=h.editOp(v.serialize(),O);w.push(T);for(const S of d){const{drawingId:F}=S,z=h.insertOp(["drawings",F],S),L=h.insertOp(["drawingsOrder",I-D],F);w.push(z),w.push(L)}const y={id:k.RichTextEditingMutation.id,params:{unitId:c,actions:[],textRanges:[]}};return y.params.actions=w.reduce((S,F)=>i.JSONX.compose(S,F),null),!!n.syncExecuteCommand(y.id,y.params)}},Je={id:"doc.command.set-drawing-arrange",type:i.CommandType.COMMAND,handler:(a,e)=>{const n=a.get(i.ICommandService),t=a.get(ee.IDocDrawingService);if(e==null)return!1;const{unitId:r,subUnitId:o,drawingIds:s,arrangeType:c}=e,d={unitId:r,subUnitId:o,drawingIds:s};let l;if(c===i.ArrangeTypeEnum.forward?l=t.getForwardDrawingsOp(d):c===i.ArrangeTypeEnum.backward?l=t.getBackwardDrawingOp(d):c===i.ArrangeTypeEnum.front?l=t.getFrontDrawingsOp(d):c===i.ArrangeTypeEnum.back&&(l=t.getBackDrawingsOp(d)),l==null)return!1;const{redo:m}=l;if(m==null)return!1;const f=[];let u=i.Tools.deepClone(m);u=u.slice(3),u.unshift("drawingsOrder"),f.push(u);const v={id:k.RichTextEditingMutation.id,params:{unitId:r,actions:[],textRanges:null}};return v.params.actions=f.reduce((w,I)=>i.JSONX.compose(w,I),null),!!n.syncExecuteCommand(v.id,v.params)}},Ke={id:"doc.command.ungroup-doc-image",type:i.CommandType.COMMAND,handler:(a,e)=>{a.get(i.ICommandService),a.get(i.IUndoRedoService);const n=a.get(ee.IDocDrawingService);if(!e)return!1;const t=[];return e.forEach(({parent:r,children:o})=>{t.push(r.unitId),o.forEach(s=>{t.push(s.unitId)})}),n.getUngroupDrawingOp(e),!1}};var zn=Object.defineProperty,qn=Object.getOwnPropertyDescriptor,Jn=(a,e,n,t)=>{for(var r=t>1?void 0:t?qn(e,n):e,o=a.length-1,s;o>=0;o--)(s=a[o])&&(r=(t?s(e,n,r):s(r))||r);return t&&r&&zn(e,n,r),r},re=(a,e)=>(n,t)=>e(n,t,a);let Be=class extends i.Disposable{constructor(a,e,n,t,r,o,s,c,d,l,m,f,u){super(),this._context=a,this._commandService=e,this._docSelectionManagerService=n,this._renderManagerSrv=t,this._imageIoService=r,this._docDrawingService=o,this._drawingManagerService=s,this._contextService=c,this._messageService=d,this._localeService=l,this._docSelectionRenderService=m,this._docRefreshDrawingsService=f,this._fileOpenerService=u,this._updateOrderListener(),this._groupDrawingListener(),this._focusDrawingListener(),this._transformDrawingListener(),this._editAreaChangeListener()}async insertDocImage(){const a=await this._fileOpenerService.openFile({multiple:!0,accept:W.DRAWING_IMAGE_ALLOW_IMAGE_LIST.map(n=>`.${n.replace("image/","")}`).join(",")}),e=a.length;return e>W.DRAWING_IMAGE_COUNT_LIMIT?(this._messageService.show({type:$.MessageType.Error,content:this._localeService.t("update-status.exceedMaxCount",String(W.DRAWING_IMAGE_COUNT_LIMIT))}),!1):e===0?!1:(await this._insertFloatImages(a),!0)}async _insertFloatImages(a){let e=[];try{e=await Promise.all(a.map(r=>this._imageIoService.saveImage(r)))}catch(r){const o=r.message;let s="";switch(o){case W.ImageUploadStatusType.ERROR_EXCEED_SIZE:s=this._localeService.t("update-status.exceedMaxSize",String(W.DRAWING_IMAGE_ALLOW_SIZE/(1024*1024)));break;case W.ImageUploadStatusType.ERROR_IMAGE_TYPE:s=this._localeService.t("update-status.invalidImageType");break;case W.ImageUploadStatusType.ERROR_IMAGE:s=this._localeService.t("update-status.invalidImage");break}this._messageService.show({type:$.MessageType.Error,content:s})}if(e.length===0)return;const{unitId:n}=this._context,t=[];for(const r of e){if(r==null)continue;const{imageId:o,imageSourceType:s,source:c,base64Cache:d}=r,{width:l,height:m,image:f}=await W.getImageSize(d||"");this._imageIoService.addImageSourceCache(o,s,f);let u=1;if(l>W.DRAWING_IMAGE_WIDTH_LIMIT||m>W.DRAWING_IMAGE_HEIGHT_LIMIT){const I=W.DRAWING_IMAGE_WIDTH_LIMIT/l,D=W.DRAWING_IMAGE_HEIGHT_LIMIT/m;u=Math.min(I,D)}const v=this._getImagePosition(l*u,m*u);if(v==null)return;const h={unitId:n,subUnitId:n,drawingId:o,drawingType:i.DrawingTypeEnum.DRAWING_IMAGE,imageSourceType:s,source:c,transform:X.docDrawingPositionToTransform(v),docTransform:v,behindDoc:i.BooleanNumber.FALSE,title:"",description:"",layoutType:i.PositionedObjectLayoutType.INLINE,wrapText:i.WrapTextType.BOTH_SIDES,distB:0,distL:0,distR:0,distT:0};this._isInsertInHeaderFooter()&&(h.isMultiTransform=i.BooleanNumber.TRUE,h.transforms=h.transform?[h.transform]:null),t.push(h)}this._commandService.executeCommand(qe.id,{unitId:n,drawings:t})}_isInsertInHeaderFooter(){var t;const{unitId:a}=this._context,e=(t=this._renderManagerSrv.getRenderById(a))==null?void 0:t.with(k.DocSkeletonManagerService).getViewModel(),n=e==null?void 0:e.getEditArea();return n===B.DocumentEditArea.HEADER||n===B.DocumentEditArea.FOOTER}_getImagePosition(a,e){const n=this._docSelectionRenderService.getActiveTextRange(),t=(n==null?void 0:n.getAbsolutePosition())||{left:0,top:0};return{size:{width:a,height:e},positionH:{relativeFrom:i.ObjectRelativeFromH.PAGE,posOffset:t.left},positionV:{relativeFrom:i.ObjectRelativeFromV.PARAGRAPH,posOffset:0},angle:0}}_updateOrderListener(){this._drawingManagerService.featurePluginOrderUpdate$.subscribe(a=>{const{unitId:e,subUnitId:n,drawingIds:t,arrangeType:r}=a;this._commandService.executeCommand(Je.id,{unitId:e,subUnitId:n,drawingIds:t,arrangeType:r})})}_groupDrawingListener(){this._drawingManagerService.featurePluginGroupUpdate$.subscribe(a=>{this._commandService.executeCommand(ze.id,a)}),this._drawingManagerService.featurePluginUngroupUpdate$.subscribe(a=>{this._commandService.executeCommand(Ke.id,a)})}_getCurrentSceneAndTransformer(){const{scene:a,mainComponent:e}=this._context;if(a==null||e==null)return;const n=a.getTransformerByCreate(),{docsLeft:t,docsTop:r}=e.getOffsetConfig();return{scene:a,transformer:n,docsLeft:t,docsTop:r}}_transformDrawingListener(){const a=this._getCurrentSceneAndTransformer();if(a&&a.transformer)this.disposeWithMe(a.transformer.changeEnd$.pipe(pe.debounceTime(30)).subscribe(e=>{this._docSelectionManagerService.refreshSelection()}));else throw new Error("transformer is not init")}_focusDrawingListener(){this.disposeWithMe(this._drawingManagerService.focus$.subscribe(a=>{var r;const{transformer:e,docsLeft:n,docsTop:t}=(r=this._getCurrentSceneAndTransformer())!=null?r:{};if(a==null||a.length===0)this._contextService.setContextValue(i.FOCUSING_COMMON_DRAWINGS,!1),this._docDrawingService.focusDrawing([]),e&&e.resetProps({zeroTop:0,zeroLeft:0});else{this._contextService.setContextValue(i.FOCUSING_COMMON_DRAWINGS,!0),this._docDrawingService.focusDrawing(a),this._setDrawingSelections(a);const o=this._docSelectionRenderService.getSegment(),s=this._findSegmentIdByDrawingId(a[0].drawingId);o!==s&&this._docSelectionRenderService.setSegment(s),e&&e.resetProps({zeroTop:t,zeroLeft:n})}}))}_findSegmentIdByDrawingId(a){var s,c,d;const{unit:e}=this._context,{body:n,headers:t={},footers:r={}}=e.getSnapshot();if(((s=n==null?void 0:n.customBlocks)!=null?s:[]).some(l=>l.blockId===a))return"";for(const l of Object.keys(t))if((c=t[l].body.customBlocks)!=null&&c.some(m=>m.blockId===a))return l;for(const l of Object.keys(r))if((d=r[l].body.customBlocks)!=null&&d.some(m=>m.blockId===a))return l;return""}_updateDrawingsEditStatus(){var c;const{unit:a,scene:e,unitId:n}=this._context,t=(c=this._renderManagerSrv.getRenderById(n))==null?void 0:c.with(k.DocSkeletonManagerService).getViewModel();if(t==null||a==null)return;const r=a.getSnapshot(),{drawings:o={}}=r,s=t.getEditArea()===B.DocumentEditArea.BODY;for(const d of Object.keys(o)){const l=o[d],m=W.getDrawingShapeKeyByDrawingSearch({unitId:n,drawingId:l.drawingId,subUnitId:n}),f=e.fuzzyMathObjects(m,!0);if(f.length)for(const u of f)e.detachTransformerFrom(u),u.setOpacity(.5),(s&&l.isMultiTransform!==i.BooleanNumber.TRUE||!s&&l.isMultiTransform===i.BooleanNumber.TRUE)&&(e.attachTransformerTo(u),u.setOpacity(1))}}_editAreaChangeListener(){var n;const{unitId:a}=this._context,e=(n=this._renderManagerSrv.getRenderById(a))==null?void 0:n.with(k.DocSkeletonManagerService).getViewModel();e!=null&&(this._updateDrawingsEditStatus(),this.disposeWithMe(e.editAreaChange$.subscribe(()=>{this._updateDrawingsEditStatus()})),this._docRefreshDrawingsService.refreshDrawings$.subscribe(t=>{t!=null&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})}),this.disposeWithMe(this._commandService.onCommandExecuted(async t=>{t.id===k.RichTextEditingMutation.id&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})})))}_setDrawingSelections(a){var r,o;const{unit:e}=this._context,n=(o=(r=e.getSnapshot().body)==null?void 0:r.customBlocks)!=null?o:[],t=a.map(s=>{const c=s.drawingId,d=n.find(l=>l.blockId===c);return d?d.startIndex:null}).filter(s=>s!==null).map(s=>({startOffset:s,endOffset:s+1}));this._docSelectionManagerService.replaceDocRanges(t)}};Be=Jn([re(1,i.ICommandService),re(2,i.Inject(k.DocSelectionManagerService)),re(3,B.IRenderManagerService),re(4,W.IImageIoService),re(5,ee.IDocDrawingService),re(6,W.IDrawingManagerService),re(7,i.IContextService),re(8,Z.IMessageService),re(9,i.Inject(i.LocaleService)),re(10,i.Inject(X.DocSelectionRenderService)),re(11,i.Inject(je)),re(12,Z.ILocalFileService)],Be);const $e={id:"doc.command.insert-float-image",type:i.CommandType.COMMAND,handler:a=>{var n,t;return(t=(n=a.get(B.IRenderManagerService).getCurrentTypeOfRenderer(i.UniverInstanceType.UNIVER_DOC))==null?void 0:n.with(Be).insertDocImage())!=null?t:!1}},Oe={id:"doc.command.move-drawing",type:i.CommandType.COMMAND,handler:(a,e)=>{const n=a.get(i.ICommandService),t=a.get(ee.IDocDrawingService),r=a.get(i.IUniverInstanceService),o=a.get(B.IRenderManagerService),{direction:s}=e,c=t.getFocusDrawings();if(c.length===0)return!1;const d=c[0].unitId,l=o.getRenderById(d),m=l==null?void 0:l.scene;if(m==null)return!1;const f=m.getTransformerByCreate(),u=r.getUniverDocInstance(d),v=c.map(w=>{var P,A,H,N,S;const{drawingId:I}=w,D=(P=u==null?void 0:u.getSnapshot().drawings)==null?void 0:P[I];if(D==null||D.layoutType===i.PositionedObjectLayoutType.INLINE)return null;const{positionH:O,positionV:T}=D.docTransform,y={...O},x={...T};return s===i.Direction.UP?x.posOffset=((A=x.posOffset)!=null?A:0)-2:s===i.Direction.DOWN?x.posOffset=((H=x.posOffset)!=null?H:0)+2:s===i.Direction.LEFT?y.posOffset=((N=y.posOffset)!=null?N:0)-2:s===i.Direction.RIGHT&&(y.posOffset=((S=y.posOffset)!=null?S:0)+2),{drawingId:I,key:s===i.Direction.UP||s===i.Direction.DOWN?"positionV":"positionH",value:s===i.Direction.UP||s===i.Direction.DOWN?x:y}}).filter(w=>w!=null);if(v.length===0)return!1;const h=n.syncExecuteCommand(Pe.id,{unitId:d,subUnitId:d,drawings:v});return f.refreshControls(),!!h}},vn={id:"doc.operation.clear-drawing-transformer",type:i.CommandType.MUTATION,handler:(a,e)=>{const n=a.get(B.IRenderManagerService);return e.forEach(t=>{var r,o;(o=(r=n.getRenderById(t))==null?void 0:r.scene.getTransformer())==null||o.debounceRefreshControls()}),!0}},In="COMPONENT_DOC_DRAWING_PANEL",Ye={id:"sidebar.operation.doc-image",type:i.CommandType.COMMAND,handler:async(a,e)=>{const n=a.get(Z.ISidebarService),t=a.get(i.LocaleService),r=a.get(W.IDrawingManagerService);switch(e.value){case"open":n.open({header:{title:t.t("docImage.panel.title")},children:{label:In},onClose:()=>{r.focusDrawing(null)},width:360});break;case"close":default:n.close();break}return!0}},Ze={id:"doc.operation.edit-doc-image",type:i.CommandType.OPERATION,handler:(a,e)=>{const n=a.get(W.IDrawingManagerService),t=a.get(i.ICommandService);return e==null?!1:(n.focusDrawing([e]),t.executeCommand(Ye.id,{value:"open"}),!0)}};var Qe={exports:{}},Me={};/**
|
|
2
|
-
* @license React
|
|
3
|
-
* react-jsx-runtime.production.min.js
|
|
4
|
-
*
|
|
5
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
6
|
-
*
|
|
7
|
-
* This source code is licensed under the MIT license found in the
|
|
8
|
-
* LICENSE file in the root directory of this source tree.
|
|
9
|
-
*/var wn;function Kn(){if(wn)return Me;wn=1;var a=J,e=Symbol.for("react.element"),n=Symbol.for("react.fragment"),t=Object.prototype.hasOwnProperty,r=a.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,o={key:!0,ref:!0,__self:!0,__source:!0};function s(c,d,l){var m,f={},u=null,v=null;l!==void 0&&(u=""+l),d.key!==void 0&&(u=""+d.key),d.ref!==void 0&&(v=d.ref);for(m in d)t.call(d,m)&&!o.hasOwnProperty(m)&&(f[m]=d[m]);if(c&&c.defaultProps)for(m in d=c.defaultProps,d)f[m]===void 0&&(f[m]=d[m]);return{$$typeof:e,type:c,key:u,ref:v,props:f,_owner:r.current}}return Me.Fragment=n,Me.jsx=s,Me.jsxs=s,Me}var Sn;function $n(){return Sn||(Sn=1,Qe.exports=Kn()),Qe.exports}var g=$n();function _n(a){var e,n,t="";if(typeof a=="string"||typeof a=="number")t+=a;else if(typeof a=="object")if(Array.isArray(a)){var r=a.length;for(e=0;e<r;e++)a[e]&&(n=_n(a[e]))&&(t&&(t+=" "),t+=n)}else for(n in a)a[n]&&(t&&(t+=" "),t+=n);return t}function K(){for(var a,e,n=0,t="",r=arguments.length;n<r;n++)(a=arguments[n])&&(e=_n(a))&&(t&&(t+=" "),t+=e);return t}const p={imageCommonPanel:"univer-image-common-panel",imageCommonPanelGrid:"univer-image-common-panel-grid",imageCommonPanelBorder:"univer-image-common-panel-border",imageCommonPanelTitle:"univer-image-common-panel-title",imageCommonPanelSubtitle:"univer-image-common-panel-subtitle",imageCommonPanelRow:"univer-image-common-panel-row",imageCommonPanelRowVertical:"univer-image-common-panel-row-vertical",imageCommonPanelColumn:"univer-image-common-panel-column",imageCommonPanelColumnCenter:"univer-image-common-panel-column-center",imageCommonPanelInline:"univer-image-common-panel-inline",imageCommonPanelSpan2:"univer-image-common-panel-span2",imageCommonPanelSpan3:"univer-image-common-panel-span3",imageCommonPanelInput:"univer-image-common-panel-input",sheetImageMenu:"univer-sheet-image-menu",sheetImageMenuInput:"univer-sheet-image-menu-input"},Dn=-1e3,Cn=1e3,Yn=a=>{const e=i.useDependency(i.ICommandService),n=i.useDependency(i.LocaleService),t=i.useDependency(W.IDrawingManagerService),r=i.useDependency(B.IRenderManagerService),o=i.useDependency(i.IUniverInstanceService),{drawings:s}=a,c=s[0];if(c==null)return;const{unitId:d}=c,l=o.getUniverDocInstance(d),m=l==null?void 0:l.getSnapshot().documentStyle.documentFlavor,f=r.getRenderById(d),u=f==null?void 0:f.scene;if(u==null)return;const v=u.getTransformerByCreate(),h=[{label:n.t("image-position.column"),value:String(i.ObjectRelativeFromH.COLUMN)},{label:n.t("image-position.page"),value:String(i.ObjectRelativeFromH.PAGE)},{label:n.t("image-position.margin"),value:String(i.ObjectRelativeFromH.MARGIN)}],w=[{label:n.t("image-position.line"),value:String(i.ObjectRelativeFromV.LINE),disabled:m===i.DocumentFlavor.MODERN},{label:n.t("image-position.page"),value:String(i.ObjectRelativeFromV.PAGE),disabled:m===i.DocumentFlavor.MODERN},{label:n.t("image-position.margin"),value:String(i.ObjectRelativeFromV.MARGIN),disabled:m===i.DocumentFlavor.MODERN},{label:n.t("image-position.paragraph"),value:String(i.ObjectRelativeFromV.PARAGRAPH)}],[I,D]=J.useState(!0),[O,T]=J.useState({relativeFrom:i.ObjectRelativeFromH.PAGE,posOffset:0}),[y,x]=J.useState({relativeFrom:i.ObjectRelativeFromV.PAGE,posOffset:0}),[P,A]=J.useState(!0),[H,N]=J.useState(!0);function S(C,R){var M;C==="positionH"?T(R):x(R);const b=t.getFocusDrawings();if(b.length===0)return;const U=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:U.map(j=>({drawingId:j.drawingId,key:C,value:R}))});const V=(M=r.getRenderById(d))==null?void 0:M.with(X.DocSelectionRenderService);V&&V.blur(),v.refreshControls()}function F(C){var te,ge,ue;const R=O.relativeFrom,b=O.posOffset,U=Number(C);if(R===U)return;const V=t.getFocusDrawings();if(V.length===0)return;const M=V[0].drawingId,j=V[0].unitId;let Y=null,G=0;const Q=(te=r.getRenderById(j))==null?void 0:te.with(k.DocSkeletonManagerService).getSkeleton(),oe=Q==null?void 0:Q.getSkeletonData();if(oe==null)return;const{pages:ye,skeHeaders:Se,skeFooters:Ne}=oe;for(const ce of ye){const{marginLeft:he,skeDrawings:ve,headerId:_e,footerId:De,pageWidth:Ie}=ce;if(ve.has(M)){Y=ve.get(M),G=he;break}const le=(ge=Se.get(_e))==null?void 0:ge.get(Ie);if(le!=null&&le.skeDrawings.has(M)){Y=le==null?void 0:le.skeDrawings.get(M),G=he;break}const de=(ue=Ne.get(De))==null?void 0:ue.get(Ie);if(de!=null&&de.skeDrawings.has(M)){Y=de==null?void 0:de.skeDrawings.get(M),G=he;break}}if(Y==null)return;let se=0;R===i.ObjectRelativeFromH.COLUMN?se-=Y.columnLeft:R===i.ObjectRelativeFromH.MARGIN&&(se-=G),U===i.ObjectRelativeFromH.COLUMN?se+=Y.columnLeft:U===i.ObjectRelativeFromH.MARGIN?se+=G:i.ObjectRelativeFromH.PAGE;const ne={relativeFrom:U,posOffset:(b!=null?b:0)-se};S("positionH",ne)}function z(C){var ve,_e,De,Ie,le,de;const R=y.relativeFrom,b=y.posOffset,U=Number(C);if(R===U)return;const V=t.getFocusDrawings();if(V.length===0)return;const{drawingId:M,unitId:j}=V[0],Y=o.getUniverDocInstance(j),G=(ve=r.getRenderById(j))==null?void 0:ve.with(k.DocSkeletonManagerService).getSkeleton(),Q=(_e=r.getRenderById(j))==null?void 0:_e.with(X.DocSelectionRenderService),oe=Q==null?void 0:Q.getSegment(),ye=Q==null?void 0:Q.getSegmentPage(),Se=(Ie=(De=Y==null?void 0:Y.getSelfOrHeaderFooterModel(oe).getBody())==null?void 0:De.customBlocks)==null?void 0:Ie.find(Ce=>Ce.blockId===M);if(Se==null||G==null||Q==null)return;const{startIndex:Ne}=Se,se=G.findNodeByCharIndex(Ne,oe,ye),ne=(le=se==null?void 0:se.parent)==null?void 0:le.parent,te=ne==null?void 0:ne.parent,ge=te==null?void 0:te.lines.find(Ce=>Ce.paragraphIndex===(ne==null?void 0:ne.paragraphIndex)&&Ce.paragraphStart),ue=(de=te==null?void 0:te.parent)==null?void 0:de.parent;if(se==null||ne==null||ge==null||te==null||ue==null)return;let ce=0;R===i.ObjectRelativeFromV.PARAGRAPH?ce-=ge.top:R===i.ObjectRelativeFromV.LINE?ce-=ne.top:R===i.ObjectRelativeFromV.PAGE&&(ce+=ue.marginTop),U===i.ObjectRelativeFromV.PARAGRAPH?ce+=ge.top:U===i.ObjectRelativeFromV.LINE?ce+=ne.top:U===i.ObjectRelativeFromV.PAGE&&(ce-=ue.marginTop);const he={relativeFrom:U,posOffset:(b!=null?b:0)-ce};S("positionV",he)}function L(C){var j;const R=l==null?void 0:l.getSnapshot(),b=(j=R==null?void 0:R.drawings)==null?void 0:j[C.drawingId];if(b==null)return;const{layoutType:U}=b,{positionH:V,positionV:M}=b.docTransform;T(V),x(M),D(U===i.PositionedObjectLayoutType.INLINE),A(M.relativeFrom===i.ObjectRelativeFromV.PARAGRAPH||M.relativeFrom===i.ObjectRelativeFromV.LINE)}function q(){const C=t.getFocusDrawings();C.length!==0&&L(C[0])}function _(C){A(C),z(String(C?i.ObjectRelativeFromV.PARAGRAPH:i.ObjectRelativeFromV.PAGE))}return J.useEffect(()=>{q();const C=t.focus$.subscribe(b=>{if(b.length===0){N(!1);return}N(!0),L(b[0])}),R=e.onCommandExecuted(async b=>{b.id===k.RichTextEditingMutation.id&&q()});return()=>{C.unsubscribe(),R.dispose()}},[]),g.jsxs("div",{className:K(p.imageCommonPanelGrid,p.imageCommonPanelBorder),style:{display:H?"block":"none"},children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelTitle),children:g.jsx("div",{children:n.t("image-position.title")})})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSubtitle),children:g.jsx("div",{children:n.t("image-position.horizontal")})})}),g.jsxs("div",{className:p.imageCommonPanelRow,children:[g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-position.absolutePosition")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.InputNumber,{min:Dn,max:Cn,precision:1,disabled:I,value:O.posOffset,onChange:C=>{S("positionH",{relativeFrom:O.relativeFrom,posOffset:C})},className:p.imageCommonPanelInput})})})]})}),g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-position.toTheRightOf")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.Select,{value:String(O.relativeFrom),disabled:I,options:h,onChange:F})})})]})})]}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSubtitle),children:g.jsx("div",{children:n.t("image-position.vertical")})})}),g.jsxs("div",{className:p.imageCommonPanelRow,children:[g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-position.absolutePosition")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.InputNumber,{min:Dn,max:Cn,precision:1,disabled:I,value:y.posOffset,onChange:C=>{S("positionV",{relativeFrom:y.relativeFrom,posOffset:C})},className:p.imageCommonPanelInput})})})]})}),g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-position.bellow")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.Select,{disabled:I,value:String(y.relativeFrom),options:w,onChange:z})})})]})})]}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSubtitle),children:g.jsx("div",{children:n.t("image-position.options")})})}),g.jsx("div",{className:p.imageCommonPanelRow,style:{marginBottom:"50px"},children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.Checkbox,{disabled:I,checked:P,onChange:_,children:n.t("image-position.moveObjectWithText")})})})]})},ke=0,He=100,Zn=a=>{const e=i.useDependency(i.ICommandService),n=i.useDependency(i.LocaleService),t=i.useDependency(W.IDrawingManagerService),r=i.useDependency(B.IRenderManagerService),o=i.useDependency(i.IUniverInstanceService),{drawings:s}=a,c=s[0];if(c==null)return null;const{unitId:d}=c,l=o.getUniverDocInstance(d),m=r.getRenderById(d);if((m==null?void 0:m.scene)==null)return null;const[u,v]=J.useState(!0),[h,w]=J.useState(!0),[I,D]=J.useState(!0),[O,T]=J.useState(ie.INLINE),[y,x]=J.useState(""),[P,A]=J.useState({distT:0,distL:0,distB:0,distR:0}),[H,N]=J.useState(!0);function S(_){T(_);const C=t.getFocusDrawings();if(C.length===0)return;const{unitId:R,subUnitId:b}=C[0],U=C.map(({unitId:V,subUnitId:M,drawingId:j})=>({unitId:V,subUnitId:M,drawingId:j}));e.executeCommand(cn.id,{unitId:R,subUnitId:b,drawings:U,wrappingStyle:_})}function F(_){x(_);const C=t.getFocusDrawings();if(C.length===0)return;const R=C.map(b=>({unitId:b.unitId,subUnitId:b.subUnitId,drawingId:b.drawingId}));e.executeCommand(dn.id,{unitId:C[0].unitId,subUnitId:C[0].unitId,drawings:R,wrapText:_})}function z(_,C){if(_==null)return;const R={...P,[C]:_};A(R);const b=t.getFocusDrawings();if(b.length===0)return;const U=b.map(V=>({unitId:V.unitId,subUnitId:V.subUnitId,drawingId:V.drawingId}));e.executeCommand(ln.id,{unitId:b[0].unitId,subUnitId:b[0].unitId,drawings:U,dist:{[C]:_}})}function L(){const _=t.getFocusDrawings();_.length!==0&&q(_[0])}function q(_){var Q,oe;const C=(oe=(Q=l==null?void 0:l.getSnapshot())==null?void 0:Q.drawings)==null?void 0:oe[_.drawingId];if(C==null)return;const{distT:R=0,distL:b=0,distB:U=0,distR:V=0,layoutType:M=i.PositionedObjectLayoutType.INLINE,behindDoc:j=i.BooleanNumber.FALSE,wrapText:Y=i.WrapTextType.BOTH_SIDES}=C;if(A({distT:R,distL:b,distB:U,distR:V}),x(Y),v(M!==i.PositionedObjectLayoutType.WRAP_SQUARE),M===i.PositionedObjectLayoutType.WRAP_NONE||M===i.PositionedObjectLayoutType.INLINE?w(!0):w(!1),M===i.PositionedObjectLayoutType.WRAP_NONE||M===i.PositionedObjectLayoutType.INLINE||M===i.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM?D(!0):D(!1),M===i.PositionedObjectLayoutType.WRAP_NONE)j===i.BooleanNumber.TRUE?T(ie.BEHIND_TEXT):T(ie.IN_FRONT_OF_TEXT);else switch(M){case i.PositionedObjectLayoutType.INLINE:T(ie.INLINE);break;case i.PositionedObjectLayoutType.WRAP_SQUARE:T(ie.WRAP_SQUARE);break;case i.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM:T(ie.WRAP_TOP_AND_BOTTOM);break;default:throw new Error(`Unsupported layout type: ${M}`)}}return J.useEffect(()=>{L();const _=t.focus$.subscribe(R=>{if(R.length===0){N(!1);return}N(!0),q(R[0])}),C=e.onCommandExecuted(async R=>{R.id===k.RichTextEditingMutation.id&&L()});return()=>{_.unsubscribe(),C.dispose()}},[]),g.jsxs("div",{className:K(p.imageCommonPanelGrid,p.imageCommonPanelBorder),style:{display:H?"block":"none"},children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelTitle),children:g.jsx("div",{children:n.t("image-text-wrap.title")})})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSubtitle),children:g.jsx("div",{children:n.t("image-text-wrap.wrappingStyle")})})}),g.jsx("div",{className:K(p.imageCommonPanelRow),children:g.jsx("div",{className:K(p.imageCommonPanelColumn),children:g.jsxs($.RadioGroup,{value:O,onChange:S,direction:"vertical",children:[g.jsx($.Radio,{value:ie.INLINE,children:n.t("image-text-wrap.inline")}),g.jsx($.Radio,{value:ie.WRAP_SQUARE,children:n.t("image-text-wrap.square")}),g.jsx($.Radio,{value:ie.WRAP_TOP_AND_BOTTOM,children:n.t("image-text-wrap.topAndBottom")}),g.jsx($.Radio,{value:ie.BEHIND_TEXT,children:n.t("image-text-wrap.behindText")}),g.jsx($.Radio,{value:ie.IN_FRONT_OF_TEXT,children:n.t("image-text-wrap.inFrontText")})]})})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSubtitle),children:g.jsx("div",{children:n.t("image-text-wrap.wrapText")})})}),g.jsx("div",{className:K(p.imageCommonPanelRow),children:g.jsx("div",{className:K(p.imageCommonPanelColumn),children:g.jsxs($.RadioGroup,{disabled:u,value:y,onChange:F,direction:"horizontal",children:[g.jsx($.Radio,{value:i.WrapTextType.BOTH_SIDES,children:n.t("image-text-wrap.bothSide")}),g.jsx($.Radio,{value:i.WrapTextType.LEFT,children:n.t("image-text-wrap.leftOnly")}),g.jsx($.Radio,{value:i.WrapTextType.RIGHT,children:n.t("image-text-wrap.rightOnly")})]})})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSubtitle),children:g.jsx("div",{children:n.t("image-text-wrap.distanceFromText")})})}),g.jsxs("div",{className:p.imageCommonPanelRow,children:[g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-text-wrap.top")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.InputNumber,{min:ke,max:He,disabled:h,precision:1,value:P.distT,onChange:_=>{z(_,"distT")},className:p.imageCommonPanelInput})})})]})}),g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-text-wrap.left")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.InputNumber,{min:ke,max:He,disabled:I,precision:1,value:P.distL,onChange:_=>{z(_,"distL")},className:p.imageCommonPanelInput})})})]})})]}),g.jsxs("div",{className:p.imageCommonPanelRow,children:[g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-text-wrap.bottom")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.InputNumber,{min:ke,max:He,disabled:h,precision:1,value:P.distB,onChange:_=>{z(_,"distB")},className:p.imageCommonPanelInput})})})]})}),g.jsx("div",{className:K(p.imageCommonPanelColumn,p.imageCommonPanelSpan2),children:g.jsxs("label",{children:[g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:n.t("image-text-wrap.right")})}),g.jsx("div",{className:p.imageCommonPanelRow,children:g.jsx("div",{className:p.imageCommonPanelColumn,children:g.jsx($.InputNumber,{min:ke,max:He,disabled:I,precision:1,value:P.distR,onChange:_=>{z(_,"distR")},className:p.imageCommonPanelInput})})})]})})]})]})},Qn=()=>{const a=i.useDependency(W.IDrawingManagerService),e=a.getFocusDrawings(),[n,t]=J.useState(e);return J.useEffect(()=>{const r=a.focus$.subscribe(o=>{t(o)});return()=>{r.unsubscribe()}},[]),!!(n!=null&&n.length)&&g.jsxs("div",{className:p.imageCommonPanel,children:[g.jsx(Te.DrawingCommonPanel,{drawings:n,hasAlign:!1,hasCropper:!1,hasGroup:!1,hasTransform:!1}),g.jsx(Zn,{drawings:n}),g.jsx(Yn,{drawings:n})]})},Tn="addition-and-subtraction-single",en="doc.menu.image",On=$e.id,et=a=>{const e=a.get(k.DocSelectionManagerService),n=a.get(i.IUniverInstanceService);return new pe.Observable(t=>{const r=e.textSelection$.subscribe(()=>{var s;const o=e.getActiveTextRange();if(o){const{segmentId:c,startOffset:d,endOffset:l}=o,m=n.getCurrentUniverDocInstance(),f=(s=m==null?void 0:m.getSelfOrHeaderFooterModel(c).getBody())==null?void 0:s.tables;if(f&&f.length&&f.some(u=>{const{startIndex:v,endIndex:h}=u;return d>=v&&d<h||l>=v&&l<h})){t.next(!0);return}}else{t.next(!0);return}t.next(!1)});return()=>r.unsubscribe()})};function nt(a){return{id:en,type:Z.MenuItemType.SUBITEMS,icon:Tn,tooltip:"docImage.title",disabled$:et(a),hidden$:Z.getMenuHiddenObservable(a,i.UniverInstanceType.UNIVER_DOC)}}function tt(a){return{id:On,title:"docImage.upload.float",type:Z.MenuItemType.BUTTON,hidden$:Z.getMenuHiddenObservable(a,i.UniverInstanceType.UNIVER_DOC)}}const it={[Z.RibbonStartGroup.LAYOUT]:{[en]:{order:0,menuItemFactory:nt,[On]:{order:0,menuItemFactory:tt}}}};function xe(a){return a.getContextValue(i.FOCUSING_UNIVER_EDITOR)&&a.getContextValue(i.FOCUSING_COMMON_DRAWINGS)}const at={id:Oe.id,description:"shortcut.doc.drawing-move-down",group:"4_doc-drawing-view",binding:Z.KeyCode.ARROW_DOWN,priority:100,preconditions:xe,staticParameters:{direction:i.Direction.DOWN}},rt={id:Oe.id,description:"shortcut.doc.drawing-move-up",group:"4_doc-drawing-view",binding:Z.KeyCode.ARROW_UP,priority:100,preconditions:xe,staticParameters:{direction:i.Direction.UP}},ot={id:Oe.id,description:"shortcut.doc.drawing-move-left",group:"4_doc-drawing-view",binding:Z.KeyCode.ARROW_LEFT,priority:100,preconditions:xe,staticParameters:{direction:i.Direction.LEFT}},st={id:Oe.id,description:"shortcut.doc.drawing-move-right",group:"4_doc-drawing-view",binding:Z.KeyCode.ARROW_RIGHT,priority:100,preconditions:xe,staticParameters:{direction:i.Direction.RIGHT}},ct={id:Xe.id,description:"shortcut.doc.drawing-delete",group:"4_doc-drawing-view",preconditions:xe,binding:Z.KeyCode.DELETE,mac:Z.KeyCode.BACKSPACE};var lt=Object.defineProperty,dt=Object.getOwnPropertyDescriptor,mt=(a,e,n,t)=>{for(var r=t>1?void 0:t?dt(e,n):e,o=a.length-1,s;o>=0;o--)(s=a[o])&&(r=(t?s(e,n,r):s(r))||r);return t&&r&<(e,n,r),r},Ve=(a,e)=>(n,t)=>e(n,t,a);let Ge=class extends i.Disposable{constructor(a,e,n,t){super(),this._componentManager=a,this._menuManagerService=e,this._commandService=n,this._shortcutService=t,this._init()}_initCustomComponents(){const a=this._componentManager;this.disposeWithMe(a.register(Tn,hn)),this.disposeWithMe(a.register(In,Qn))}_initMenus(){this._menuManagerService.mergeMenu(it)}_initCommands(){[$e,qe,cn,ln,dn,Pe,mn,gn,Ue,Ye,vn,Ze,ze,Ke,Oe,Xe,Je].forEach(a=>this.disposeWithMe(this._commandService.registerCommand(a)))}_initShortcuts(){[at,rt,ot,st,ct].forEach(a=>{this.disposeWithMe(this._shortcutService.registerShortcut(a))})}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus(),this._initShortcuts()}};Ge=mt([Ve(0,i.Inject(Z.ComponentManager)),Ve(1,Z.IMenuManagerService),Ve(2,i.ICommandService),Ve(3,Z.IShortcutService)],Ge);var gt=Object.defineProperty,ut=Object.getOwnPropertyDescriptor,ft=(a,e,n,t)=>{for(var r=t>1?void 0:t?ut(e,n):e,o=a.length-1,s;o>=0;o--)(s=a[o])&&(r=(t?s(e,n,r):s(r))||r);return t&&r&>(e,n,r),r},Re=(a,e)=>(n,t)=>e(n,t,a);let We=class extends i.RxDisposable{constructor(e,n,t,r,o){super();fe(this,"_initImagePopupMenu",new Set);this._drawingManagerService=e,this._canvasPopManagerService=n,this._renderManagerService=t,this._univerInstanceService=r,this._contextService=o,this._init()}_init(){this._univerInstanceService.getCurrentTypeOfUnit$(i.UniverInstanceType.UNIVER_DOC).pipe(pe.takeUntil(this.dispose$)).subscribe(e=>this._create(e)),this._univerInstanceService.getTypeOfUnitDisposed$(i.UniverInstanceType.UNIVER_DOC).pipe(pe.takeUntil(this.dispose$)).subscribe(e=>this._dispose(e)),this._univerInstanceService.getAllUnitsForType(i.UniverInstanceType.UNIVER_DOC).forEach(e=>this._create(e))}_dispose(e){const n=e.getUnitId();this._renderManagerService.removeRender(n)}_create(e){if(!e)return;const n=e.getUnitId();this._renderManagerService.has(n)&&!this._initImagePopupMenu.has(n)&&(this._popupMenuListener(n),this._initImagePopupMenu.add(n))}_hasCropObject(e){const n=e.getAllObjects();for(const t of n)if(t instanceof Te.ImageCropperObject)return!0;return!1}_popupMenuListener(e){var o;const n=(o=this._renderManagerService.getRenderById(e))==null?void 0:o.scene;if(!n)return;const t=n.getTransformerByCreate();if(!t)return;const r=[];this.disposeWithMe(i.toDisposable(t.createControl$.subscribe(()=>{if(this._hasCropObject(n))return;const s=t.getSelectedObjectMap();if(r.forEach(I=>I.dispose()),r.length=0,s.size>1)return;const c=s.values().next().value;if(!c)return;const d=c.oKey,l=this._drawingManagerService.getDrawingOKey(d);if(!l)return;const{unitId:m,subUnitId:f,drawingId:u}=l,v=this._canvasPopManagerService.attachPopupToObject(c,{componentKey:Te.COMPONENT_IMAGE_POPUP_MENU,direction:"horizontal",offset:[2,0],extraProps:{menuItems:this._getImageMenuItems(m,f,u)}},m);r.push(this.disposeWithMe(v)),!this._drawingManagerService.getFocusDrawings().find(I=>I.unitId===m&&I.subUnitId===f&&I.drawingId===u)&&this._drawingManagerService.focusDrawing([{unitId:m,subUnitId:f,drawingId:u}])}))),this.disposeWithMe(i.toDisposable(t.clearControl$.subscribe(()=>{r.forEach(s=>s.dispose()),r.length=0,this._contextService.setContextValue(i.FOCUSING_COMMON_DRAWINGS,!1),this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(i.toDisposable(t.changing$.subscribe(()=>{r.forEach(s=>s.dispose()),r.length=0}))),this.disposeWithMe(i.toDisposable(t.changeStart$.subscribe(()=>{r.forEach(s=>s.dispose()),r.length=0})))}_getImageMenuItems(e,n,t){return[{label:"image-popup.edit",index:0,commandId:Ze.id,commandParams:{unitId:e,subUnitId:n,drawingId:t},disable:!!i.SHEET_EDITOR_UNITS.includes(e)},{label:"image-popup.delete",index:1,commandId:Ue.id,commandParams:{unitId:e,drawings:[{unitId:e,subUnitId:n,drawingId:t}]},disable:!1},{label:"image-popup.crop",index:2,commandId:Te.OpenImageCropOperation.id,commandParams:{unitId:e,subUnitId:n,drawingId:t},disable:!0},{label:"image-popup.reset",index:3,commandId:Te.ImageResetSizeOperation.id,commandParams:[{unitId:e,subUnitId:n,drawingId:t}],disable:!0}]}};We=ft([Re(0,W.IDrawingManagerService),Re(1,i.Inject(X.DocCanvasPopManagerService)),Re(2,B.IRenderManagerService),Re(3,i.IUniverInstanceService),Re(4,i.IContextService)],We);var pt=Object.defineProperty,ht=Object.getOwnPropertyDescriptor,vt=(a,e,n,t)=>{for(var r=t>1?void 0:t?ht(e,n):e,o=a.length-1,s;o>=0;o--)(s=a[o])&&(r=(t?s(e,n,r):s(r))||r);return t&&r&&pt(e,n,r),r},we=(a,e)=>(n,t)=>e(n,t,a);let nn=class extends i.Disposable{constructor(e,n,t,r,o,s,c,d){super();fe(this,"_liquid",new B.Liquid);this._context=e,this._docSkeletonManagerService=n,this._commandService=t,this._editorService=r,this._drawingManagerService=o,this._docRefreshDrawingsService=s,this._univerInstanceService=c,this._lifecycleService=d,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=[k.RichTextEditingMutation.id,X.SetDocZoomRatioOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(e.includes(n.id)){const t=n.params,{unitId:r}=t,{unitId:o,mainComponent:s}=this._context;if(r!==o)return;const c=this._docSkeletonManagerService.getSkeleton();if(c==null)return;if(this._editorService.isEditor(o)&&o!==i.DOCS_ZEN_EDITOR_UNIT_ID_KEY){s==null||s.makeDirty();return}this._refreshDrawing(c)}}))}_initResize(){this.disposeWithMe(i.fromEventSubject(this._context.engine.onTransformChange$).pipe(pe.filter(e=>e.type===B.TRANSFORM_CHANGE_OBSERVABLE_TYPE.resize),pe.debounceTime(16)).subscribe(()=>{var t;const e=this._docSkeletonManagerService.getSkeleton(),{scene:n}=this._context;(t=n.getTransformer())==null||t.refreshControls(),this._refreshDrawing(e)}))}_refreshDrawing(e){var O,T;const n=e==null?void 0:e.getSkeletonData(),{mainComponent:t,unitId:r}=this._context,o=t;if(!n)return;const{left:s,top:c,pageLayoutType:d,pageMarginLeft:l,pageMarginTop:m}=o,{pages:f,skeHeaders:u,skeFooters:v}=n,h={};this._liquid.reset();for(let y=0,x=f.length;y<x;y++){const P=f[y],{headerId:A,footerId:H,pageWidth:N}=P;if(A){const S=(O=u.get(A))==null?void 0:O.get(N);S&&this._calculateDrawingPosition(r,S,s,c,h,S.marginTop,P.marginLeft)}if(H){const S=(T=v.get(H))==null?void 0:T.get(N);S&&this._calculateDrawingPosition(r,S,s,c,h,P.pageHeight-P.marginBottom+S.marginTop,P.marginLeft)}this._calculateDrawingPosition(r,P,s,c,h,P.marginTop,P.marginLeft),this._liquid.translatePage(P,d,l,m)}const w=Object.values(h),I=w.filter(y=>!y.isMultiTransform),D=w.filter(y=>y.isMultiTransform);I.length>0&&this._drawingManagerService.refreshTransform(I),this._handleMultiDrawingsTransform(D)}_handleMultiDrawingsTransform(e){const{scene:n,unitId:t}=this._context,r=n.getTransformerByCreate();e.forEach(d=>{const l=this._drawingManagerService.getDrawingByParam(d);l!=null&&(l.transform=d.transform,l.transforms=d.transforms,l.isMultiTransform=d.isMultiTransform)});const s=[...r.getSelectedObjectMap().keys()],c=Object.values(this._drawingManagerService.getDrawingData(t,t)).filter(d=>d.isMultiTransform===i.BooleanNumber.TRUE);this._drawingManagerService.removeNotification(c),e.length>0&&this._drawingManagerService.addNotification(e);for(const d of s){const l=n.getObject(d);l&&r.setSelectedControl(l)}}_calculateDrawingPosition(e,n,t,r,o,s,c){const{skeDrawings:d}=n;this._liquid.translatePagePadding({marginTop:s,marginLeft:c}),d.forEach(l=>{const{aLeft:m,aTop:f,height:u,width:v,angle:h,drawingId:w,drawingOrigin:I}=l,D=I.layoutType===i.PositionedObjectLayoutType.WRAP_NONE&&I.behindDoc===i.BooleanNumber.TRUE,{isMultiTransform:O=i.BooleanNumber.FALSE}=I,T={left:m+t+this._liquid.x,top:f+r+this._liquid.y,width:v,height:u,angle:h};o[w]==null?o[w]={unitId:e,subUnitId:e,drawingId:w,behindText:D,transform:T,transforms:[T],isMultiTransform:O}:O===i.BooleanNumber.TRUE&&o[w].transforms.push(T)}),this._liquid.restorePagePadding({marginTop:s,marginLeft:c})}_drawingInitializeListener(){const e=()=>{const n=this._docSkeletonManagerService.getSkeleton();n!=null&&(this._refreshDrawing(n),this._drawingManagerService.initializeNotification(this._context.unitId))};this._lifecycleService.stage===i.LifecycleStages.Steady?setTimeout(()=>{e()},1e3):this._lifecycleService.lifecycle$.pipe(pe.filter(n=>n===i.LifecycleStages.Steady)).subscribe(e)}};nn=vt([we(1,i.Inject(k.DocSkeletonManagerService)),we(2,i.ICommandService),we(3,X.IEditorService),we(4,W.IDrawingManagerService),we(5,i.Inject(je)),we(6,i.IUniverInstanceService),we(7,i.Inject(i.LifecycleService))],nn);var yn=Object.defineProperty,It=Object.getOwnPropertyDescriptor,wt=(a,e,n)=>e in a?yn(a,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):a[e]=n,St=(a,e,n,t)=>{for(var r=t>1?void 0:t?It(e,n):e,o=a.length-1,s;o>=0;o--)(s=a[o])&&(r=(t?s(e,n,r):s(r))||r);return t&&r&&yn(e,n,r),r},tn=(a,e)=>(n,t)=>e(n,t,a),bn=(a,e,n)=>wt(a,typeof e!="symbol"?e+"":e,n);const _t="DOC_DRAWING_UI_PLUGIN";E.UniverDocsDrawingUIPlugin=class extends i.Plugin{constructor(e=on,n,t,r){super(),this._config=e,this._injector=n,this._renderManagerSrv=t,this._configService=r;const{...o}=i.merge({},on,this._config);this._configService.setConfig(xn,o)}onStarting(){[[Ge],[We],[Fe],[Ae],[je]].forEach(n=>this._injector.add(n))}onReady(){[[Be],[nn]].forEach(e=>this._renderManagerSrv.registerRenderModule(i.UniverInstanceType.UNIVER_DOC,e)),this._injector.get(Ae),this._injector.get(Ge),this._injector.get(Fe)}onRendered(){this._injector.get(We)}},bn(E.UniverDocsDrawingUIPlugin,"type",i.UniverInstanceType.UNIVER_DOC),bn(E.UniverDocsDrawingUIPlugin,"pluginName",_t),E.UniverDocsDrawingUIPlugin=St([i.DependentOn(Te.UniverDrawingUIPlugin,W.UniverDrawingPlugin,ee.UniverDocsDrawingPlugin,Z.UniverUIPlugin),tn(1,i.Inject(i.Injector)),tn(2,B.IRenderManagerService),tn(3,i.IConfigService)],E.UniverDocsDrawingUIPlugin),E.ClearDocDrawingTransformerOperation=vn,E.DOCS_IMAGE_MENU_ID=en,E.DeleteDocDrawingsCommand=Xe,E.EditDocDrawingOperation=Ze,E.GroupDocDrawingCommand=ze,E.InsertDocDrawingCommand=qe,E.InsertDocImageCommand=$e,E.MoveDocDrawingsCommand=Oe,E.RemoveDocDrawingCommand=Ue,E.SetDocDrawingArrangeCommand=Je,E.SidebarDocDrawingOperation=Ye,E.UngroupDocDrawingCommand=Ke,Object.defineProperty(E,Symbol.toStringTag,{value:"Module"})});
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?factory(exports,require("@univerjs/core"),require("@univerjs/docs-drawing"),require("@univerjs/drawing"),require("@univerjs/drawing-ui"),require("@univerjs/engine-render"),require("@univerjs/ui"),require("@univerjs/docs"),require("@univerjs/docs-ui"),require("rxjs"),require("@univerjs/design"),require("react/jsx-runtime"),require("react")):typeof define=="function"&&define.amd?define(["exports","@univerjs/core","@univerjs/docs-drawing","@univerjs/drawing","@univerjs/drawing-ui","@univerjs/engine-render","@univerjs/ui","@univerjs/docs","@univerjs/docs-ui","rxjs","@univerjs/design","react/jsx-runtime","react"],factory):(global=typeof globalThis<"u"?globalThis:global||self,factory(global.UniverDocsDrawingUi={},global.UniverCore,global.UniverDocsDrawing,global.UniverDrawing,global.UniverDrawingUi,global.UniverEngineRender,global.UniverUi,global.UniverDocs,global.UniverDocsUi,global.rxjs,global.UniverDesign,global.React,global.React))})(this,function(exports2,core,docsDrawing,drawing,drawingUi,engineRender,ui,docs,docsUi,rxjs,design,jsxRuntime,react){"use strict";var __defProp=Object.defineProperty;var __defNormalProp=(obj,key,value)=>key in obj?__defProp(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value;var __name=(target,value)=>__defProp(target,"name",{value,configurable:!0});var __publicField=(obj,key,value)=>__defNormalProp(obj,typeof key!="symbol"?key+"":key,value);var _a,_b,_c,_d,_e,_f,_g;const DOCS_DRAWING_UI_PLUGIN_CONFIG_KEY="docs-drawing-ui.config",defaultPluginConfig={};var __defProp$6=Object.defineProperty,__getOwnPropDesc$6=Object.getOwnPropertyDescriptor,__decorateClass$6=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$6(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$6(target,key,result),result},"__decorateClass$6"),__decorateParam$6=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$6");function getAddOrRemoveDrawings(actions){var _a2,_b2,_c2,_d2;if(core.JSONX.isNoop(actions)||!Array.isArray(actions))return null;const drawingsOp=actions.find(action=>Array.isArray(action)&&(action==null?void 0:action[0])==="drawings");if(drawingsOp==null||!Array.isArray(drawingsOp)||drawingsOp.length<3||typeof drawingsOp[1]=="string"&&typeof drawingsOp[2]!="object"||Array.isArray(drawingsOp[1])&&typeof drawingsOp[1][1]!="object")return null;const drawings=[];if(Array.isArray(drawingsOp==null?void 0:drawingsOp[1]))for(const op of drawingsOp)Array.isArray(op)&&drawings.push({type:(_a2=op==null?void 0:op[1])!=null&&_a2.i?"add":"remove",drawingId:op==null?void 0:op[0],drawing:(_b2=op==null?void 0:op[1])==null?void 0:_b2.i});else drawings.push({type:(_c2=drawingsOp[2])!=null&&_c2.i?"add":"remove",drawingId:drawingsOp[1],drawing:(_d2=drawingsOp[2])==null?void 0:_d2.i});return drawings}__name(getAddOrRemoveDrawings,"getAddOrRemoveDrawings");function getReOrderedDrawings(actions){if(!Array.isArray(actions)||actions.length<3||actions[0]!=="drawingsOrder")return[];const drawingIndexes=[];for(let i=1;i<actions.length;i++){const action=actions[i];if(Array.isArray(action)&&typeof action[0]=="number"&&typeof action[1]=="object")drawingIndexes.push(action[0]);else{drawingIndexes.length=0;break}}return drawingIndexes}__name(getReOrderedDrawings,"getReOrderedDrawings");let DocDrawingAddRemoveController=(_a=class extends core.Disposable{constructor(_univerInstanceService,_commandService,_drawingManagerService,_docDrawingService,_renderManagerService){super(),this._univerInstanceService=_univerInstanceService,this._commandService=_commandService,this._drawingManagerService=_drawingManagerService,this._docDrawingService=_docDrawingService,this._renderManagerService=_renderManagerService,this._initialize()}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(command=>{if(command.id!==docs.RichTextEditingMutation.id)return;const params=command.params,{unitId,actions}=params,addOrRemoveDrawings=getAddOrRemoveDrawings(actions);if(addOrRemoveDrawings!=null)for(const{type,drawingId,drawing:drawing2}of addOrRemoveDrawings)type==="add"?this._addDrawings(unitId,[drawing2]):this._removeDrawings(unitId,[drawingId])})),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id!==docs.RichTextEditingMutation.id)return;const params=command.params,{unitId,actions}=params;getReOrderedDrawings(actions).length>0&&this._updateDrawingsOrder(unitId)})),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{var _a2;if(command.id!==core.UndoCommand.id&&command.id!==core.RedoCommand.id)return;const unitId=(_a2=this._univerInstanceService.getCurrentUniverDocInstance())==null?void 0:_a2.getUnitId(),focusedDrawings=this._drawingManagerService.getFocusDrawings();if(unitId==null||focusedDrawings.length===0)return;const renderObject=this._renderManagerService.getRenderById(unitId),scene=renderObject==null?void 0:renderObject.scene;if(scene==null)return!1;scene.getTransformerByCreate().refreshControls()}))}_addDrawings(unitId,drawings){const drawingManagerService=this._drawingManagerService,docDrawingService=this._docDrawingService,jsonOp=this._docDrawingService.getBatchAddOp(drawings),{subUnitId,redo:op,objects}=jsonOp;drawingManagerService.applyJson1(unitId,subUnitId,op),docDrawingService.applyJson1(unitId,subUnitId,op),drawingManagerService.addNotification(objects),docDrawingService.addNotification(objects)}_removeDrawings(unitId,drawingIds){const drawingManagerService=this._drawingManagerService,docDrawingService=this._docDrawingService,jsonOp=this._docDrawingService.getBatchRemoveOp(drawingIds.map(drawingId=>({unitId,subUnitId:unitId,drawingId}))),{subUnitId,redo:op,objects}=jsonOp;drawingManagerService.applyJson1(unitId,subUnitId,op),docDrawingService.applyJson1(unitId,subUnitId,op),drawingManagerService.removeNotification(objects),docDrawingService.removeNotification(objects)}_updateDrawingsOrder(unitId){const documentDataModel=this._univerInstanceService.getUniverDocInstance(unitId);if(documentDataModel==null)return;const drawingsOrder=documentDataModel.getSnapshot().drawingsOrder;if(drawingsOrder==null)return;const drawingManagerService=this._drawingManagerService,docDrawingService=this._docDrawingService;drawingManagerService.setDrawingOrder(unitId,unitId,drawingsOrder),docDrawingService.setDrawingOrder(unitId,unitId,drawingsOrder);const objects={unitId,subUnitId:unitId,drawingIds:drawingsOrder};drawingManagerService.orderNotification(objects),docDrawingService.orderNotification(objects)}},__name(_a,"DocDrawingAddRemoveController"),_a);DocDrawingAddRemoveController=__decorateClass$6([__decorateParam$6(0,core.IUniverInstanceService),__decorateParam$6(1,core.ICommandService),__decorateParam$6(2,drawing.IDrawingManagerService),__decorateParam$6(3,docsDrawing.IDocDrawingService),__decorateParam$6(4,engineRender.IRenderManagerService)],DocDrawingAddRemoveController);const _DocRefreshDrawingsService=class _DocRefreshDrawingsService{constructor(){__publicField(this,"_refreshDrawings$",new rxjs.BehaviorSubject(null));__publicField(this,"refreshDrawings$",this._refreshDrawings$.asObservable())}refreshDrawings(skeleton){this._refreshDrawings$.next(skeleton)}};__name(_DocRefreshDrawingsService,"DocRefreshDrawingsService");let DocRefreshDrawingsService=_DocRefreshDrawingsService;var TextWrappingStyle=(TextWrappingStyle2=>(TextWrappingStyle2.INLINE="inline",TextWrappingStyle2.BEHIND_TEXT="behindText",TextWrappingStyle2.IN_FRONT_OF_TEXT="inFrontOfText",TextWrappingStyle2.WRAP_SQUARE="wrapSquare",TextWrappingStyle2.WRAP_TOP_AND_BOTTOM="wrapTopAndBottom",TextWrappingStyle2))(TextWrappingStyle||{});const WRAPPING_STYLE_TO_LAYOUT_TYPE={inline:core.PositionedObjectLayoutType.INLINE,wrapSquare:core.PositionedObjectLayoutType.WRAP_SQUARE,wrapTopAndBottom:core.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM,inFrontOfText:core.PositionedObjectLayoutType.WRAP_NONE,behindText:core.PositionedObjectLayoutType.WRAP_NONE};function getDeleteAndInsertCustomBlockActions(segmentId,oldSegmentId,segmentPage,offset,drawingId,documentDataModel,docSelectionRenderManager){var _a2,_b2;const textX=new core.TextX,jsonX=core.JSONX.getInstance(),rawActions=[],oldBody=documentDataModel.getSelfOrHeaderFooterModel(oldSegmentId).getBody(),body=documentDataModel.getSelfOrHeaderFooterModel(segmentId).getBody();if(oldBody==null||body==null)return;const oldOffset=(_b2=(_a2=oldBody.customBlocks)==null?void 0:_a2.find(block=>block.blockId===drawingId))==null?void 0:_b2.startIndex;if(oldOffset!=null){if(offset=Math.min(body.dataStream.length-2,offset),segmentId===oldSegmentId){if(offset<oldOffset?(offset>0&&textX.push({t:core.TextXActionType.RETAIN,len:offset}),textX.push({t:core.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:drawingId}]},len:1}),textX.push({t:core.TextXActionType.RETAIN,len:oldOffset-offset}),textX.push({t:core.TextXActionType.DELETE,len:1})):(oldOffset>0&&textX.push({t:core.TextXActionType.RETAIN,len:oldOffset}),textX.push({t:core.TextXActionType.DELETE,len:1}),offset-oldOffset-1>0&&textX.push({t:core.TextXActionType.RETAIN,len:offset-oldOffset-1}),textX.push({t:core.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:drawingId}]},len:1})),offset!==oldOffset){const path=docsUi.getRichTextEditPath(documentDataModel,oldSegmentId),action=jsonX.editOp(textX.serialize(),path);rawActions.push(action)}}else{oldOffset>0&&textX.push({t:core.TextXActionType.RETAIN,len:oldOffset}),textX.push({t:core.TextXActionType.DELETE,len:1});let path=docsUi.getRichTextEditPath(documentDataModel,oldSegmentId),action=jsonX.editOp(textX.serialize(),path);rawActions.push(action),textX.empty(),offset>0&&textX.push({t:core.TextXActionType.RETAIN,len:offset}),textX.push({t:core.TextXActionType.INSERT,body:{dataStream:"\b",customBlocks:[{startIndex:0,blockId:drawingId}]},len:1}),path=docsUi.getRichTextEditPath(documentDataModel,segmentId),action=jsonX.editOp(textX.serialize(),path),rawActions.push(action),docSelectionRenderManager.setSegment(segmentId),docSelectionRenderManager.setSegmentPage(segmentPage)}return rawActions}}__name(getDeleteAndInsertCustomBlockActions,"getDeleteAndInsertCustomBlockActions");const UpdateDocDrawingWrappingStyleCommand={id:"doc.command.update-doc-drawing-wrapping-style",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a2,_b2;if(params==null)return!1;const{drawings,wrappingStyle,unitId}=params,commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),renderObject=accessor.get(engineRender.IRenderManagerService).getRenderById(unitId),skeletonData=renderObject==null?void 0:renderObject.with(docs.DocSkeletonManagerService).getSkeleton().getSkeletonData(),viewModel=renderObject==null?void 0:renderObject.with(docs.DocSkeletonManagerService).getViewModel(),scene=renderObject==null?void 0:renderObject.scene,documentDataModel=univerInstanceService.getCurrentUniverDocInstance();if(documentDataModel==null||skeletonData==null||scene==null||viewModel==null)return!1;const editArea=viewModel.getEditArea(),transformer=scene.getTransformerByCreate(),{pages,skeHeaders,skeFooters}=skeletonData,jsonX=core.JSONX.getInstance(),rawActions=[],{drawings:oldDrawings={}}=documentDataModel.getSnapshot();for(const drawing2 of drawings){const{drawingId}=drawing2,oldLayoutType=oldDrawings[drawingId].layoutType,newLayoutType=WRAPPING_STYLE_TO_LAYOUT_TYPE[wrappingStyle];if(oldLayoutType!==newLayoutType){const updateLayoutTypeAction=jsonX.replaceOp(["drawings",drawingId,"layoutType"],oldLayoutType,newLayoutType);rawActions.push(updateLayoutTypeAction)}if(wrappingStyle==="behindText"||wrappingStyle==="inFrontOfText"){const oldBehindDoc=oldDrawings[drawingId].behindDoc,newBehindDoc=wrappingStyle==="behindText"?core.BooleanNumber.TRUE:core.BooleanNumber.FALSE;if(oldBehindDoc!==newBehindDoc){const updateBehindDocAction=jsonX.replaceOp(["drawings",drawingId,"behindDoc"],oldBehindDoc,newBehindDoc);rawActions.push(updateBehindDocAction)}}if(wrappingStyle==="inline")continue;let skeDrawing=null,pageMarginTop=0,pageMarginLeft=0;for(const page of pages){const{headerId,footerId,marginTop,marginLeft,marginBottom,pageWidth,pageHeight}=page;switch(editArea){case engineRender.DocumentEditArea.HEADER:{const headerSke=(_a2=skeHeaders.get(headerId))==null?void 0:_a2.get(pageWidth);headerSke!=null&&headerSke.skeDrawings.has(drawingId)&&(skeDrawing=headerSke.skeDrawings.get(drawingId),pageMarginTop=headerSke.marginTop,pageMarginLeft=marginLeft);break}case engineRender.DocumentEditArea.FOOTER:{const footerSke=(_b2=skeFooters.get(footerId))==null?void 0:_b2.get(pageWidth);footerSke!=null&&footerSke.skeDrawings.has(drawingId)&&(skeDrawing=footerSke.skeDrawings.get(drawingId),pageMarginTop=pageHeight-marginBottom+footerSke.marginTop,pageMarginLeft=marginLeft);break}case engineRender.DocumentEditArea.BODY:{page.skeDrawings.has(drawingId)&&(skeDrawing=page.skeDrawings.get(drawingId),pageMarginTop=marginTop,pageMarginLeft=marginLeft);break}}if(skeDrawing!=null)break}if(skeDrawing!=null){const{aTop,aLeft}=skeDrawing,oldPositionH=oldDrawings[drawingId].docTransform.positionH;let posOffsetH=aLeft;oldPositionH.relativeFrom===core.ObjectRelativeFromH.MARGIN?posOffsetH-=pageMarginLeft:oldPositionH.relativeFrom===core.ObjectRelativeFromH.COLUMN&&(posOffsetH-=skeDrawing.columnLeft);const newPositionH={relativeFrom:oldPositionH.relativeFrom,posOffset:posOffsetH};if(oldPositionH.posOffset!==newPositionH.posOffset){const action=jsonX.replaceOp(["drawings",drawingId,"docTransform","positionH"],oldPositionH,newPositionH);rawActions.push(action)}const oldPositionV=oldDrawings[drawingId].docTransform.positionV;let posOffsetV=aTop;oldPositionV.relativeFrom===core.ObjectRelativeFromV.PAGE?posOffsetV+=pageMarginTop:oldPositionV.relativeFrom===core.ObjectRelativeFromV.LINE?posOffsetV-=skeDrawing.lineTop:oldPositionV.relativeFrom===core.ObjectRelativeFromV.PARAGRAPH&&(posOffsetV-=skeDrawing.blockAnchorTop);const newPositionV={relativeFrom:oldPositionV.relativeFrom,posOffset:posOffsetV};if(oldPositionV.posOffset!==newPositionV.posOffset){const action=jsonX.replaceOp(["drawings",drawingId,"docTransform","positionV"],oldPositionV,newPositionV);rawActions.push(action)}}}const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:null}};doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null);const result=commandService.syncExecuteCommand(doMutation.id,doMutation.params);return transformer.refreshControls(),!!result},"handler")},UpdateDocDrawingDistanceCommand={id:"doc.command.update-doc-drawing-distance",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{if(params==null)return!1;const commandService=accessor.get(core.ICommandService),documentDataModel=accessor.get(core.IUniverInstanceService).getCurrentUniverDocInstance();if(documentDataModel==null)return!1;const{drawings,dist,unitId}=params,jsonX=core.JSONX.getInstance(),rawActions=[],{drawings:oldDrawings={}}=documentDataModel.getSnapshot();for(const drawing2 of drawings){const{drawingId}=drawing2;for(const[key,value]of Object.entries(dist)){const oldValue=oldDrawings[drawingId][key];if(oldValue!==value){const action=jsonX.replaceOp(["drawings",drawingId,key],oldValue,value);rawActions.push(action)}}}const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:null}};return doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null),!!commandService.syncExecuteCommand(doMutation.id,doMutation.params)},"handler")},UpdateDocDrawingWrapTextCommand={id:"doc.command.update-doc-drawing-wrap-text",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{if(params==null)return!1;const commandService=accessor.get(core.ICommandService),documentDataModel=accessor.get(core.IUniverInstanceService).getCurrentUniverDocInstance();if(documentDataModel==null)return!1;const{drawings,wrapText,unitId}=params,jsonX=core.JSONX.getInstance(),rawActions=[],{drawings:oldDrawings={}}=documentDataModel.getSnapshot();for(const drawing2 of drawings){const{drawingId}=drawing2,oldWrapText=oldDrawings[drawingId].wrapText;if(oldWrapText!==wrapText){const action=jsonX.replaceOp(["drawings",drawingId,"wrapText"],oldWrapText,wrapText);rawActions.push(action)}}const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:null}};return doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null),!!commandService.syncExecuteCommand(doMutation.id,doMutation.params)},"handler")},UpdateDrawingDocTransformCommand={id:"doc.command.update-drawing-doc-transform",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{if(params==null)return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),renderObject=accessor.get(engineRender.IRenderManagerService).getRenderById(params.unitId),scene=renderObject==null?void 0:renderObject.scene;if(scene==null)return!1;const transformer=scene.getTransformerByCreate(),documentDataModel=univerInstanceService.getCurrentUniverDocInstance();if(documentDataModel==null)return!1;const{drawings,unitId}=params,jsonX=core.JSONX.getInstance(),rawActions=[],{drawings:oldDrawings={}}=documentDataModel.getSnapshot();for(const drawing2 of drawings){const{drawingId,key,value}=drawing2,oldValue=oldDrawings[drawingId].docTransform[key];if(!core.Tools.diffValue(oldValue,value)){const action=jsonX.replaceOp(["drawings",drawingId,"docTransform",key],oldValue,value);rawActions.push(action)}}const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:null,debounce:!0}};doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null);const result=commandService.syncExecuteCommand(doMutation.id,doMutation.params);return transformer.refreshControls(),!!result},"handler")},IMoveInlineDrawingCommand={id:"doc.command.move-inline-drawing",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a2,_b2;if(params==null)return!1;const renderManagerService=accessor.get(engineRender.IRenderManagerService),docSelectionRenderService=(_a2=renderManagerService.getRenderById(params.unitId))==null?void 0:_a2.with(docsUi.DocSelectionRenderService),docRefreshDrawingsService=accessor.get(DocRefreshDrawingsService),renderObject=renderManagerService.getRenderById(params.unitId),scene=renderObject==null?void 0:renderObject.scene,skeleton=renderObject==null?void 0:renderObject.with(docs.DocSkeletonManagerService).getSkeleton();if(scene==null||docSelectionRenderService==null)return!1;const transformer=scene.getTransformerByCreate(),commandService=accessor.get(core.ICommandService),documentDataModel=accessor.get(core.IUniverInstanceService).getCurrentUniverDocInstance();if(documentDataModel==null)return!1;const{drawing:drawing2,unitId,offset,segmentId:newSegmentId,segmentPage,needRefreshDrawings}=params;if(needRefreshDrawings)return docRefreshDrawingsService.refreshDrawings(skeleton),transformer.refreshControls(),!0;const rawActions=[],{drawingId}=drawing2,segmentId=(_b2=docSelectionRenderService.getSegment())!=null?_b2:"",actions=getDeleteAndInsertCustomBlockActions(newSegmentId,segmentId,segmentPage,offset,drawingId,documentDataModel,docSelectionRenderService);if(actions==null||actions.length===0)return docRefreshDrawingsService.refreshDrawings(skeleton),transformer.refreshControls(),!1;rawActions.push(...actions);const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:null}};doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null);const result=commandService.syncExecuteCommand(doMutation.id,doMutation.params);return transformer.refreshControls(),!!result},"handler")},ITransformNonInlineDrawingCommand={id:"doc.command.transform-non-inline-drawing",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a2,_b2;if(params==null)return!1;const renderManagerService=accessor.get(engineRender.IRenderManagerService),docSelectionRenderService=(_a2=renderManagerService.getRenderById(params.unitId))==null?void 0:_a2.with(docsUi.DocSelectionRenderService),renderObject=renderManagerService.getRenderById(params.unitId),scene=renderObject==null?void 0:renderObject.scene;if(scene==null||docSelectionRenderService==null)return!1;const transformer=scene.getTransformerByCreate(),commandService=accessor.get(core.ICommandService),documentDataModel=accessor.get(core.IUniverInstanceService).getCurrentUniverDocInstance();if(documentDataModel==null)return!1;const{drawing:drawing2,unitId,offset,docTransform,segmentId:newSegmentId,segmentPage}=params,rawActions=[],{drawingId}=drawing2,segmentId=(_b2=docSelectionRenderService.getSegment())!=null?_b2:"",actions=getDeleteAndInsertCustomBlockActions(newSegmentId,segmentId,segmentPage,offset,drawingId,documentDataModel,docSelectionRenderService);if(actions==null)return!1;actions.length>0&&rawActions.push(...actions);const jsonX=core.JSONX.getInstance(),{drawings:oldDrawings={}}=documentDataModel.getSnapshot(),oldDocTransform=oldDrawings[drawingId].docTransform,{positionH:oldPositionH,positionV:oldPositionV,size:oldSize,angle:oldAngle}=oldDocTransform;if(!core.Tools.diffValue(oldPositionH,docTransform.positionH)){const updateAction=jsonX.replaceOp(["drawings",drawingId,"docTransform","positionH"],oldPositionH,docTransform.positionH);rawActions.push(updateAction)}if(!core.Tools.diffValue(oldPositionV,docTransform.positionV)){const updateAction=jsonX.replaceOp(["drawings",drawingId,"docTransform","positionV"],oldPositionV,docTransform.positionV);rawActions.push(updateAction)}if(!core.Tools.diffValue(oldSize,docTransform.size)){const updateAction=jsonX.replaceOp(["drawings",drawingId,"docTransform","size"],oldSize,docTransform.size);rawActions.push(updateAction)}if(!core.Tools.diffValue(oldAngle,docTransform.angle)){const updateAction=jsonX.replaceOp(["drawings",drawingId,"docTransform","angle"],oldAngle,docTransform.angle);rawActions.push(updateAction)}const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:null,debounce:!0}};doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null);const result=commandService.syncExecuteCommand(doMutation.id,doMutation.params);return transformer.refreshControls(),!!result},"handler")};var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__decorateClass$5=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$5(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$5(target,key,result),result},"__decorateClass$5"),__decorateParam$5=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$5");const INLINE_DRAWING_ANCHOR_KEY_PREFIX="__InlineDrawingAnchor__";function isInTableCell(nodePosition){const{path}=nodePosition;return path.some(p=>p==="cells")}__name(isInTableCell,"isInTableCell");let DocDrawingTransformerController=(_b=class extends core.Disposable{constructor(_commandService,_univerInstanceService,_drawingManagerService,_renderManagerService){super();__publicField(this,"_liquid",new engineRender.Liquid);__publicField(this,"_listenerOnImageMap",new Set);__publicField(this,"_transformerCache",new Map);__publicField(this,"_anchorShape");this._commandService=_commandService,this._univerInstanceService=_univerInstanceService,this._drawingManagerService=_drawingManagerService,this._renderManagerService=_renderManagerService,this._init()}_init(){this._listenDrawingFocus()}_listenDrawingFocus(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(drawingParams=>{if(drawingParams.length!==0)for(const drawingParam of drawingParams){const{unitId}=drawingParam;this._listenerOnImageMap.has(unitId)||(this._listenTransformerChange(unitId),this._listenerOnImageMap.add(unitId))}}))}_listenTransformerChange(unitId){var _a2;const transformer=(_a2=this._getSceneAndTransformerByDrawingSearch(unitId))==null?void 0:_a2.transformer;if(transformer==null)return;this.disposeWithMe(core.toDisposable(transformer.changeStart$.subscribe(state=>{var _a3;this._transformerCache.clear();const{objects}=state;for(const object of objects.values()){const{oKey,width,height,left,top,angle}=object,drawing2=this._drawingManagerService.getDrawingOKey(oKey);if(drawing2==null)continue;const documentDataModel=this._univerInstanceService.getUniverDocInstance(drawing2.unitId),drawingData=(_a3=documentDataModel==null?void 0:documentDataModel.getSnapshot().drawings)==null?void 0:_a3[drawing2.drawingId];(drawingData==null?void 0:drawingData.layoutType)===core.PositionedObjectLayoutType.INLINE&&object.setOpacity(.2),drawingData!=null&&this._transformerCache.set(drawing2.drawingId,{drawing:drawingData,top,left,width,height,angle})}})));const throttleMultipleDrawingUpdate=core.throttle(this._updateMultipleDrawingDocTransform.bind(this),50);core.throttle(this._nonInlineDrawingTransform.bind(this),50),this.disposeWithMe(core.toDisposable(transformer.changing$.subscribe(state=>{const{objects,offsetX,offsetY}=state;if(objects.size>1)throttleMultipleDrawingUpdate(objects);else if(objects.size===1){const drawingCache=this._transformerCache.values().next().value,object=objects.values().next().value,{width,height,top,left,angle}=object;if(drawingCache&&width===drawingCache.width&&height===drawingCache.height&&top===drawingCache.top&&left===drawingCache.left&&angle===drawingCache.angle)return;drawingCache&&(drawingCache.drawing.layoutType,core.PositionedObjectLayoutType.INLINE),drawingCache&&drawingCache.drawing.layoutType===core.PositionedObjectLayoutType.INLINE&&offsetX!=null&&offsetY!=null&&this._updateInlineDrawingAnchor(drawingCache.drawing,offsetX,offsetY)}}))),this.disposeWithMe(core.toDisposable(transformer.changeEnd$.subscribe(state=>{const{objects,offsetX,offsetY}=state;for(const object of objects.values()){const drawing2=this._drawingManagerService.getDrawingOKey(object.oKey);if(drawing2==null)continue;const drawingCache=this._transformerCache.get(drawing2==null?void 0:drawing2.drawingId);(drawingCache==null?void 0:drawingCache.drawing.layoutType)===core.PositionedObjectLayoutType.INLINE&&object.setOpacity(1)}if(this._anchorShape&&this._anchorShape.hide(),objects.size>1)this._updateMultipleDrawingDocTransform(objects);else if(objects.size===1){const drawingCache=this._transformerCache.values().next().value,object=objects.values().next().value,{width,height,top,left,angle}=object;if(drawingCache&&width===drawingCache.width&&height===drawingCache.height&&top===drawingCache.top&&left===drawingCache.left&&angle===drawingCache.angle)return;drawingCache&&drawingCache.drawing.layoutType===core.PositionedObjectLayoutType.INLINE?width!==drawingCache.width||height!==drawingCache.height||angle!==drawingCache.angle?this._updateDrawingSize(drawingCache,object):offsetX!=null&&offsetY!=null&&this._moveInlineDrawing(drawingCache.drawing,offsetX,offsetY):drawingCache&&this._nonInlineDrawingTransform(drawingCache.drawing,object)}this._transformerCache.clear()})))}_updateMultipleDrawingDocTransform(objects){if(objects.size<1)return;const drawings=[];let unitId,subUnitId;for(const object of objects.values()){const{oKey,left,top,angle}=object;let{width,height}=object;const drawing2=this._drawingManagerService.getDrawingOKey(oKey);if(drawing2==null)continue;unitId==null&&(unitId=drawing2.unitId),subUnitId==null&&(subUnitId=drawing2.subUnitId);const drawingCache=this._transformerCache.get(drawing2.drawingId);if(drawingCache==null)continue;const{drawing:drawingData,top:oldTop,left:oldLeft,width:oldWidth,height:oldHeight,angle:oldAngle}=drawingCache,{width:maxWidth,height:maxHeight}=this._getPageContentSize(drawingData);if(width=Math.min(width,maxWidth),height=Math.min(height,maxHeight),(oldWidth!==width||oldHeight!==height)&&drawings.push({drawingId:drawing2.drawingId,key:"size",value:{width,height}}),oldAngle!==angle&&drawings.push({drawingId:drawing2.drawingId,key:"angle",value:angle}),oldTop!==top||oldLeft!==left){const verticalDelta=top-oldTop,horizontalDelta=left-oldLeft;verticalDelta!==0&&drawings.push({drawingId:drawing2.drawingId,key:"positionV",value:{relativeFrom:drawingData.docTransform.positionV.relativeFrom,posOffset:drawingData.docTransform.positionV.posOffset+verticalDelta}}),horizontalDelta!==0&&drawings.push({drawingId:drawing2.drawingId,key:"positionH",value:{relativeFrom:drawingData.docTransform.positionH.relativeFrom,posOffset:drawingData.docTransform.positionH.posOffset+horizontalDelta}})}}drawings.length>0&&unitId&&subUnitId&&this._commandService.executeCommand(UpdateDrawingDocTransformCommand.id,{unitId,subUnitId,drawings})}_updateDrawingAnchor(objects){if(this._transformerCache.size!==1)return;const drawingCache=this._transformerCache.values().next().value,object=objects.values().next().value;this._getDrawingAnchor(drawingCache.drawing,object)}_updateInlineDrawingAnchor(drawing2,offsetX,offsetY){var _a2;if(this._transformerCache.size!==1)return;const{contentBoxPointGroup}=(_a2=this._getInlineDrawingAnchor(drawing2,offsetX,offsetY))!=null?_a2:{};contentBoxPointGroup!=null&&this._createOrUpdateInlineAnchor(drawing2.unitId,contentBoxPointGroup)}_getInlineDrawingAnchor(drawing2,offsetX,offsetY){var _a2,_b2;const currentRender=this._renderManagerService.getRenderById(drawing2.unitId),skeleton=currentRender==null?void 0:currentRender.with(docs.DocSkeletonManagerService).getSkeleton();if(currentRender==null)return;const{mainComponent,scene}=currentRender,documentComponent=mainComponent,activeViewport=scene.getViewports()[0],{pageLayoutType=engineRender.PageLayoutType.VERTICAL,pageMarginLeft,pageMarginTop}=documentComponent.getOffsetConfig();let glyphAnchor=null,isBack=!1,segmentPageIndex=-1,segmentId="";const HALF=.5,coord=this._getTransformCoordForDocumentOffset(documentComponent,activeViewport,offsetX,offsetY);if(coord==null)return;const docSelectionRenderService=(_a2=this._renderManagerService.getRenderById(drawing2.unitId))==null?void 0:_a2.with(docsUi.DocSelectionRenderService);if(docSelectionRenderService==null)return;const nodeInfo=skeleton==null?void 0:skeleton.findNodeByCoord(coord,pageLayoutType,pageMarginLeft,pageMarginTop,{strict:!1,segmentId:docSelectionRenderService.getSegment(),segmentPage:docSelectionRenderService.getSegmentPage()});if(nodeInfo){const{node,ratioX,segmentPage,segmentId:nodeSegmentId}=nodeInfo;isBack=ratioX<HALF,glyphAnchor=node,segmentPageIndex=segmentPage,segmentId=nodeSegmentId}if(glyphAnchor==null)return;const nodePosition=skeleton==null?void 0:skeleton.findPositionByGlyph(glyphAnchor,segmentPageIndex),docObject=this._getDocObject();if(nodePosition==null||skeleton==null||docObject==null||isInTableCell(nodePosition))return;const positionWithIsBack={...nodePosition,isBack},documentOffsetConfig=docObject.document.getOffsetConfig(),convertor=new docsUi.NodePositionConvertToCursor(documentOffsetConfig,skeleton),{cursorList,contentBoxPointGroup}=convertor.getRangePointData(positionWithIsBack,positionWithIsBack),{startOffset}=(_b2=docsUi.getOneTextSelectionRange(cursorList))!=null?_b2:{};if(startOffset!=null)return{offset:startOffset,contentBoxPointGroup,segmentId,segmentPage:segmentPageIndex}}_getDrawingAnchor(drawing2,object){var _a2,_b2,_c2,_d2,_e2,_f2,_g2,_h,_i,_j,_k;const currentRender=this._renderManagerService.getRenderById(drawing2.unitId),skeleton=currentRender==null?void 0:currentRender.with(docs.DocSkeletonManagerService).getSkeleton(),skeletonData=skeleton==null?void 0:skeleton.getSkeletonData();if(skeletonData==null||currentRender==null)return;const{pages,skeHeaders,skeFooters}=skeletonData,{mainComponent,scene}=currentRender,documentComponent=mainComponent,activeViewport=scene.getViewports()[0],{pageLayoutType=engineRender.PageLayoutType.VERTICAL,pageMarginLeft,pageMarginTop,docsLeft,docsTop}=documentComponent.getOffsetConfig(),{left,top,angle}=object;let{width,height}=object;const{positionV,positionH}=drawing2.docTransform,{width:maxWidth,height:maxHeight}=this._getPageContentSize(drawing2);width=Math.min(width,maxWidth),height=Math.min(height,maxHeight);let glyphAnchor=null,segmentId="",segmentPage=-1;const isBack=!1,docTransform={...drawing2.docTransform,size:{width,height},angle},{x,y}=scene.getViewportScrollXY(activeViewport),coord=this._getTransformCoordForDocumentOffset(documentComponent,activeViewport,left-x,top-y);if(coord==null)return;const docSelectionRenderService=(_a2=this._renderManagerService.getRenderById(drawing2.unitId))==null?void 0:_a2.with(docsUi.DocSelectionRenderService);if(docSelectionRenderService==null)return;const nodeInfo=skeleton==null?void 0:skeleton.findNodeByCoord(coord,pageLayoutType,pageMarginLeft,pageMarginTop,{strict:!1,segmentId:docSelectionRenderService.getSegment(),segmentPage:docSelectionRenderService.getSegmentPage()});if(nodeInfo){const{node,segmentPage:segmentPageIndex,segmentId:nodeSegmentId}=nodeInfo;glyphAnchor=node,segmentPage=segmentPageIndex,segmentId=nodeSegmentId}if(glyphAnchor==null)return;const line=(_b2=glyphAnchor.parent)==null?void 0:_b2.parent,column=line==null?void 0:line.parent,paragraphStartLine=(_c2=column==null?void 0:column.lines.find(l=>l.paragraphIndex===(line==null?void 0:line.paragraphIndex)&&l.paragraphStart))!=null?_c2:column==null?void 0:column.lines[0],page=(_d2=column==null?void 0:column.parent)==null?void 0:_d2.parent;if(line==null||column==null||paragraphStartLine==null||page==null)return;this._liquid.reset();const pageType=page.type;for(const p of pages){const{headerId,footerId,pageHeight,pageWidth,marginLeft,marginBottom}=p,pIndex=pages.indexOf(p);if(segmentPage>-1&&pIndex===segmentPage){switch(pageType){case engineRender.DocumentSkeletonPageType.HEADER:{const headerSke=(_e2=skeHeaders.get(headerId))==null?void 0:_e2.get(pageWidth);if(headerSke)this._liquid.translatePagePadding({marginTop:headerSke.marginTop,marginLeft});else throw new Error("header skeleton not found");break}case engineRender.DocumentSkeletonPageType.FOOTER:{const footerSke=(_f2=skeFooters.get(footerId))==null?void 0:_f2.get(pageWidth);if(footerSke)this._liquid.translatePagePadding({marginTop:pageHeight-marginBottom+footerSke.marginTop,marginLeft});else throw new Error("footer skeleton not found");break}}break}if(this._liquid.translatePagePadding(p),p===page)break;this._liquid.restorePagePadding(p),this._liquid.translatePage(p,pageLayoutType,pageMarginLeft,pageMarginTop)}switch(positionV.relativeFrom===core.ObjectRelativeFromV.LINE?glyphAnchor=line.divides[0].glyphGroup[0]:glyphAnchor=(_j=(_i=(_h=(_g2=paragraphStartLine.divides)==null?void 0:_g2[0])==null?void 0:_h.glyphGroup)==null?void 0:_i[0])!=null?_j:glyphAnchor,docTransform.positionH={relativeFrom:positionH.relativeFrom,posOffset:left-this._liquid.x-docsLeft},positionH.relativeFrom){case core.ObjectRelativeFromH.MARGIN:{docTransform.positionH.posOffset=left-this._liquid.x-docsLeft-page.marginLeft;break}case core.ObjectRelativeFromH.COLUMN:{docTransform.positionH.posOffset=left-this._liquid.x-docsLeft-column.left;break}}switch(docTransform.positionV={relativeFrom:positionV.relativeFrom,posOffset:top-this._liquid.y-docsTop},positionV.relativeFrom){case core.ObjectRelativeFromV.PAGE:{docTransform.positionV.posOffset=top-this._liquid.y-docsTop-page.marginTop;break}case core.ObjectRelativeFromV.LINE:{docTransform.positionV.posOffset=top-this._liquid.y-docsTop-line.top;break}case core.ObjectRelativeFromV.PARAGRAPH:{docTransform.positionV.posOffset=top-this._liquid.y-docsTop-paragraphStartLine.top;break}}if(glyphAnchor==null)return;const nodePosition=skeleton==null?void 0:skeleton.findPositionByGlyph(glyphAnchor,segmentPage),docObject=this._getDocObject();if(nodePosition==null||skeleton==null||docObject==null||isInTableCell(nodePosition))return;const positionWithIsBack={...nodePosition,isBack},documentOffsetConfig=docObject.document.getOffsetConfig(),convertor=new docsUi.NodePositionConvertToCursor(documentOffsetConfig,skeleton),{cursorList}=convertor.getRangePointData(positionWithIsBack,positionWithIsBack),{startOffset}=(_k=docsUi.getOneTextSelectionRange(cursorList))!=null?_k:{};if(startOffset!=null)return{offset:startOffset,docTransform,segmentId,segmentPage}}_updateDrawingSize(drawingCache,object){const drawings=[],{drawing:drawing2,width:oldWidth,height:oldHeight,angle:oldAngle}=drawingCache,{unitId,subUnitId}=drawing2;let{width,height,angle}=object;const{width:maxWidth,height:maxHeight}=this._getPageContentSize(drawing2);width=Math.min(maxWidth,width),height=Math.min(maxHeight,height),(width!==oldWidth||height!==oldHeight)&&drawings.push({drawingId:drawing2.drawingId,key:"size",value:{width,height}}),angle!==oldAngle&&drawings.push({drawingId:drawing2.drawingId,key:"angle",value:angle}),drawings.length>0&&unitId&&subUnitId&&this._commandService.executeCommand(UpdateDrawingDocTransformCommand.id,{unitId,subUnitId,drawings})}_moveInlineDrawing(drawing2,offsetX,offsetY){const anchor=this._getInlineDrawingAnchor(drawing2,offsetX,offsetY),{offset,segmentId,segmentPage}=anchor!=null?anchor:{};return this._commandService.executeCommand(IMoveInlineDrawingCommand.id,{unitId:drawing2.unitId,subUnitId:drawing2.unitId,drawing:drawing2,offset,segmentId,segmentPage,needRefreshDrawings:offset==null})}_limitDrawingInPage(drawing2,object){const currentRender=this._renderManagerService.getRenderById(drawing2.unitId),{left,top,width,height,angle}=object,skeleton=currentRender==null?void 0:currentRender.with(docs.DocSkeletonManagerService).getSkeleton(),skeletonData=skeleton==null?void 0:skeleton.getSkeletonData(),{pages}=skeletonData!=null?skeletonData:{};if(skeletonData==null||currentRender==null||pages==null)return{left,top,width,height,angle};const{mainComponent}=currentRender,documentComponent=mainComponent,{top:docsTop,pageLayoutType,pageMarginLeft,pageMarginTop}=documentComponent;let newTop=top;this._liquid.reset();for(const page of pages){const{marginBottom,pageHeight}=page,index=pages.indexOf(page),nextPage=pages[index+1];if(nextPage==null)continue;if(core.Tools.hasIntersectionBetweenTwoRanges(top,top+height,this._liquid.y+docsTop+pageHeight-marginBottom,this._liquid.y+docsTop+pageHeight+pageMarginTop+nextPage.marginTop)){const drawingVMiddle=top+height/2,pagesMiddle=this._liquid.y+docsTop+pageHeight+pageMarginTop/2;drawingVMiddle<pagesMiddle?newTop=Math.min(top,this._liquid.y+docsTop+pageHeight-marginBottom-height):newTop=Math.max(top,this._liquid.y+docsTop+pageHeight+pageMarginTop+nextPage.marginTop)}this._liquid.translatePage(page,pageLayoutType,pageMarginLeft,pageMarginTop)}return{left,top:newTop,width,height,angle}}_nonInlineDrawingTransform(drawing2,object,isMoving=!1){const objectPosition=drawing2.isMultiTransform===core.BooleanNumber.TRUE?object:this._limitDrawingInPage(drawing2,object);if(isMoving&&objectPosition.top!==object.top)return;const anchor=this._getDrawingAnchor(drawing2,objectPosition),{offset,docTransform,segmentId,segmentPage}=anchor!=null?anchor:{};return offset==null||docTransform==null?this._updateMultipleDrawingDocTransform(new Map([[drawing2.drawingId,object]])):this._commandService.executeCommand(ITransformNonInlineDrawingCommand.id,{unitId:drawing2.unitId,subUnitId:drawing2.unitId,drawing:drawing2,offset,docTransform,segmentId,segmentPage})}_getSceneAndTransformerByDrawingSearch(unitId){if(unitId==null)return;const renderObject=this._renderManagerService.getRenderById(unitId),scene=renderObject==null?void 0:renderObject.scene;if(scene==null)return;const transformer=scene.getTransformerByCreate();return{scene,transformer}}_getTransformCoordForDocumentOffset(document,viewport,evtOffsetX,evtOffsetY){const{documentTransform}=document.getOffsetConfig(),originCoord=viewport.transformVector2SceneCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY]));if(originCoord)return documentTransform.clone().invert().applyPoint(originCoord)}_createOrUpdateInlineAnchor(unitId,pointsGroup){const currentRender=this._renderManagerService.getRenderById(unitId);if(currentRender==null)return;const{mainComponent,scene}=currentRender,documentComponent=mainComponent,{docsLeft,docsTop}=documentComponent.getOffsetConfig(),bounding=docsUi.getAnchorBounding(pointsGroup),{left:boundingLeft,top:boundingTop,height}=bounding,left=boundingLeft+docsLeft,top=boundingTop+docsTop;if(this._anchorShape){this._anchorShape.transformByState({left,top,height}),this._anchorShape.show();return}const ID_LENGTH=6,anchor=new engineRender.Rect(INLINE_DRAWING_ANCHOR_KEY_PREFIX+core.Tools.generateRandomId(ID_LENGTH),{left,top,height,strokeWidth:2,stroke:engineRender.getColor(core.COLORS.darkGray,1),evented:!1});this._anchorShape=anchor,scene.addObject(anchor,docsUi.TEXT_RANGE_LAYER_INDEX)}_getDocObject(){return docsUi.getDocObject(this._univerInstanceService,this._renderManagerService)}_getPageContentSize(drawing2){const currentRender=this._renderManagerService.getRenderById(drawing2.unitId),skeleton=currentRender==null?void 0:currentRender.with(docs.DocSkeletonManagerService).getSkeleton(),MAX_WIDTH=500,MAX_HEIGHT=500,skeletonData=skeleton==null?void 0:skeleton.getSkeletonData();if(skeletonData==null||currentRender==null)return{width:MAX_WIDTH,height:MAX_HEIGHT};const{pages}=skeletonData;let page=null;for(const p of pages){const{skeDrawings}=p;if(skeDrawings.has(drawing2.drawingId)){page=p;break}}if(page){const{pageWidth,pageHeight,marginLeft,marginBottom,marginRight,marginTop}=page;return{width:Math.max(MAX_WIDTH,pageWidth-marginLeft-marginRight),height:Math.max(MAX_HEIGHT,pageHeight-marginTop-marginBottom)}}else return{width:MAX_WIDTH,height:MAX_HEIGHT}}},__name(_b,"DocDrawingTransformerController"),_b);DocDrawingTransformerController=__decorateClass$5([__decorateParam$5(0,core.ICommandService),__decorateParam$5(1,core.IUniverInstanceService),__decorateParam$5(2,drawing.IDrawingManagerService),__decorateParam$5(3,engineRender.IRenderManagerService)],DocDrawingTransformerController);var __assign=function(){return __assign=Object.assign||function(t){for(var s,i=1,n=arguments.length;i<n;i++){s=arguments[i];for(var p in s)Object.prototype.hasOwnProperty.call(s,p)&&(t[p]=s[p])}return t},__assign.apply(this,arguments)},__rest=function(s,e){var t={};for(var p in s)Object.prototype.hasOwnProperty.call(s,p)&&e.indexOf(p)<0&&(t[p]=s[p]);if(s!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,p=Object.getOwnPropertySymbols(s);i<p.length;i++)e.indexOf(p[i])<0&&Object.prototype.propertyIsEnumerable.call(s,p[i])&&(t[p[i]]=s[p[i]]);return t},IconBase=react.forwardRef(function(props,ref){var icon=props.icon,id=props.id,className=props.className,extend=props.extend,restProps=__rest(props,["icon","id","className","extend"]),cls="univerjs-icon univerjs-icon-".concat(id," ").concat(className||"").trim(),idSuffix=react.useRef("_".concat(generateShortUuid()));return render(icon,"".concat(id),{defIds:icon.defIds,idSuffix:idSuffix.current},__assign({ref,className:cls},restProps),extend)});function render(node,id,runtimeProps,rootProps,extend){return react.createElement(node.tag,__assign(__assign({key:id},replaceRuntimeIdsAndExtInAttrs(node,runtimeProps,extend)),rootProps),(replaceRuntimeIdsInDefs(node,runtimeProps).children||[]).map(function(child,index){return render(child,"".concat(id,"-").concat(node.tag,"-").concat(index),runtimeProps,void 0,extend)}))}__name(render,"render");function replaceRuntimeIdsAndExtInAttrs(node,runtimeProps,extend){var attrs=__assign({},node.attrs);extend!=null&&extend.colorChannel1&&attrs.fill==="colorChannel1"&&(attrs.fill=extend.colorChannel1);var defIds=runtimeProps.defIds;return!defIds||defIds.length===0||(node.tag==="use"&&attrs["xlink:href"]&&(attrs["xlink:href"]=attrs["xlink:href"]+runtimeProps.idSuffix),Object.entries(attrs).forEach(function(_a2){var key=_a2[0],value=_a2[1];typeof value=="string"&&(attrs[key]=value.replace(/url\(#(.*)\)/,"url(#$1".concat(runtimeProps.idSuffix,")")))})),attrs}__name(replaceRuntimeIdsAndExtInAttrs,"replaceRuntimeIdsAndExtInAttrs");function replaceRuntimeIdsInDefs(node,runtimeProps){var _a2,defIds=runtimeProps.defIds;return!defIds||defIds.length===0?node:node.tag==="defs"&&(!((_a2=node.children)===null||_a2===void 0)&&_a2.length)?__assign(__assign({},node),{children:node.children.map(function(child){return typeof child.attrs.id=="string"&&defIds&&defIds.indexOf(child.attrs.id)>-1?__assign(__assign({},child),{attrs:__assign(__assign({},child.attrs),{id:child.attrs.id+runtimeProps.idSuffix})}):child})}):node}__name(replaceRuntimeIdsInDefs,"replaceRuntimeIdsInDefs");function generateShortUuid(){return Math.random().toString(36).substring(2,8)}__name(generateShortUuid,"generateShortUuid"),IconBase.displayName="UniverIcon";var element={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"}}]},AddImageSingle=react.forwardRef(function(props,ref){return react.createElement(IconBase,Object.assign({},props,{id:"add-image-single",ref,icon:element}))});AddImageSingle.displayName="AddImageSingle";const RemoveDocDrawingCommand={id:"doc.command.remove-doc-image",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a2,_b2,_c2,_d2;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),renderManagerService=accessor.get(engineRender.IRenderManagerService),documentDataModel=univerInstanceService.getCurrentUniverDocInstance();if(params==null||documentDataModel==null)return!1;const docSelectionRenderService=renderManagerService.getRenderById(params.unitId).with(docsUi.DocSelectionRenderService),{drawings:removeDrawings}=params,segmentId=(_a2=docSelectionRenderService.getSegment())!=null?_a2:"",textX=new core.TextX,jsonX=core.JSONX.getInstance(),customBlocks=(_c2=(_b2=documentDataModel.getSelfOrHeaderFooterModel(segmentId).getBody())==null?void 0:_b2.customBlocks)!=null?_c2:[],removeCustomBlocks=removeDrawings.map(drawing2=>customBlocks.find(customBlock=>customBlock.blockId===drawing2.drawingId)).filter(block=>!!block).sort((a,b)=>a.startIndex>b.startIndex?1:-1),unitId=removeDrawings[0].unitId,memoryCursor=new core.MemoryCursor;memoryCursor.reset();const cursorIndex=removeCustomBlocks[0].startIndex,textRanges=[{startOffset:cursorIndex,endOffset:cursorIndex}],doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges}},rawActions=[];for(const block of removeCustomBlocks){const{startIndex}=block;startIndex>memoryCursor.cursor&&textX.push({t:core.TextXActionType.RETAIN,len:startIndex-memoryCursor.cursor}),textX.push({t:core.TextXActionType.DELETE,len:1}),memoryCursor.moveCursorTo(startIndex+1)}const path=docsUi.getRichTextEditPath(documentDataModel,segmentId);rawActions.push(jsonX.editOp(textX.serialize(),path));for(const block of removeCustomBlocks){const{blockId}=block,drawing2=((_d2=documentDataModel.getDrawings())!=null?_d2:{})[blockId],drawingIndex=documentDataModel.getDrawingsOrder().indexOf(blockId),removeDrawingAction=jsonX.removeOp(["drawings",blockId],drawing2),removeDrawingOrderAction=jsonX.removeOp(["drawingsOrder",drawingIndex],blockId);rawActions.push(removeDrawingAction),rawActions.push(removeDrawingOrderAction)}return doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null),!!commandService.syncExecuteCommand(doMutation.id,doMutation.params)},"handler")},DeleteDocDrawingsCommand={id:"doc.command.delete-drawing",type:core.CommandType.COMMAND,handler:__name(accessor=>{const commandService=accessor.get(core.ICommandService),drawings=accessor.get(docsDrawing.IDocDrawingService).getFocusDrawings();if(drawings.length===0)return!1;const{unitId}=drawings[0],newDrawings=drawings.map(drawing2=>{const{unitId:unitId2,subUnitId,drawingId,drawingType}=drawing2;return{unitId:unitId2,subUnitId,drawingId,drawingType}});return commandService.executeCommand(RemoveDocDrawingCommand.id,{unitId,drawings:newDrawings})},"handler")},GroupDocDrawingCommand={id:"doc.command.group-doc-image",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{accessor.get(core.ICommandService),accessor.get(core.IUndoRedoService);const docDrawingService=accessor.get(docsDrawing.IDocDrawingService);if(!params)return!1;const unitIds=[];return params.forEach(({parent,children})=>{unitIds.push(parent.unitId),children.forEach(child=>{unitIds.push(child.unitId)})}),docDrawingService.getGroupDrawingOp(params),!1},"handler")},InsertDocDrawingCommand={id:"doc.command.insert-doc-image",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a2,_b2,_c2,_d2;if(params==null)return!1;const commandService=accessor.get(core.ICommandService),docSelectionManagerService=accessor.get(docs.DocSelectionManagerService),univerInstanceService=accessor.get(core.IUniverInstanceService),activeTextRange=docSelectionManagerService.getActiveTextRange(),documentDataModel=univerInstanceService.getCurrentUniverDocInstance();if(activeTextRange==null||documentDataModel==null)return!1;const unitId=documentDataModel.getUnitId(),{drawings}=params,{collapsed,startOffset,segmentId}=activeTextRange,body=documentDataModel.getSelfOrHeaderFooterModel(segmentId).getBody();if(body==null)return!1;const textX=new core.TextX,jsonX=core.JSONX.getInstance(),rawActions=[],drawingOrderLength=(_b2=(_a2=documentDataModel.getSnapshot().drawingsOrder)==null?void 0:_a2.length)!=null?_b2:0;let removeDrawingLen=0;if(collapsed)startOffset>0&&textX.push({t:core.TextXActionType.RETAIN,len:startOffset});else{const dos=core.BuildTextUtils.selection.delete([activeTextRange],body,0,null,!1);textX.push(...dos);const removedCustomBlockIds=docsUi.getCustomBlockIdsInSelections(body,[activeTextRange]),drawings2=(_c2=documentDataModel.getDrawings())!=null?_c2:{},drawingOrder=(_d2=documentDataModel.getDrawingsOrder())!=null?_d2:[],sortedRemovedCustomBlockIds=removedCustomBlockIds.sort((a,b)=>drawingOrder.indexOf(a)>drawingOrder.indexOf(b)?-1:drawingOrder.indexOf(a)<drawingOrder.indexOf(b)?1:0);if(sortedRemovedCustomBlockIds.length>0)for(const blockId of sortedRemovedCustomBlockIds){const drawing2=drawings2[blockId],drawingIndex=drawingOrder.indexOf(blockId);if(drawing2==null||drawingIndex<0)continue;const removeDrawingAction=jsonX.removeOp(["drawings",blockId],drawing2),removeDrawingOrderAction=jsonX.removeOp(["drawingsOrder",drawingIndex],blockId);rawActions.push(removeDrawingAction),rawActions.push(removeDrawingOrderAction),removeDrawingLen++}}textX.push({t:core.TextXActionType.INSERT,body:{dataStream:"\b".repeat(drawings.length),customBlocks:drawings.map((drawing2,i)=>({startIndex:i,blockId:drawing2.drawingId}))},len:drawings.length});const path=docsUi.getRichTextEditPath(documentDataModel,segmentId),placeHolderAction=jsonX.editOp(textX.serialize(),path);rawActions.push(placeHolderAction);for(const drawing2 of drawings){const{drawingId}=drawing2,addDrawingAction=jsonX.insertOp(["drawings",drawingId],drawing2),addDrawingOrderAction=jsonX.insertOp(["drawingsOrder",drawingOrderLength-removeDrawingLen],drawingId);rawActions.push(addDrawingAction),rawActions.push(addDrawingOrderAction)}const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:[]}};return doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null),!!commandService.syncExecuteCommand(doMutation.id,doMutation.params)},"handler")},SetDocDrawingArrangeCommand={id:"doc.command.set-drawing-arrange",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),docDrawingService=accessor.get(docsDrawing.IDocDrawingService);if(params==null)return!1;const{unitId,subUnitId,drawingIds,arrangeType}=params,drawingOrderMapParam={unitId,subUnitId,drawingIds};let jsonOp;if(arrangeType===core.ArrangeTypeEnum.forward?jsonOp=docDrawingService.getForwardDrawingsOp(drawingOrderMapParam):arrangeType===core.ArrangeTypeEnum.backward?jsonOp=docDrawingService.getBackwardDrawingOp(drawingOrderMapParam):arrangeType===core.ArrangeTypeEnum.front?jsonOp=docDrawingService.getFrontDrawingsOp(drawingOrderMapParam):arrangeType===core.ArrangeTypeEnum.back&&(jsonOp=docDrawingService.getBackDrawingsOp(drawingOrderMapParam)),jsonOp==null)return!1;const{redo}=jsonOp;if(redo==null)return!1;const rawActions=[];let redoCopy=core.Tools.deepClone(redo);redoCopy=redoCopy.slice(3),redoCopy.unshift("drawingsOrder"),rawActions.push(redoCopy);const doMutation={id:docs.RichTextEditingMutation.id,params:{unitId,actions:[],textRanges:null}};return doMutation.params.actions=rawActions.reduce((acc,cur)=>core.JSONX.compose(acc,cur),null),!!commandService.syncExecuteCommand(doMutation.id,doMutation.params)},"handler")},UngroupDocDrawingCommand={id:"doc.command.ungroup-doc-image",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{accessor.get(core.ICommandService),accessor.get(core.IUndoRedoService);const docDrawingService=accessor.get(docsDrawing.IDocDrawingService);if(!params)return!1;const unitIds=[];return params.forEach(({parent,children})=>{unitIds.push(parent.unitId),children.forEach(child=>{unitIds.push(child.unitId)})}),docDrawingService.getUngroupDrawingOp(params),!1},"handler")};var __defProp$4=Object.defineProperty,__getOwnPropDesc$4=Object.getOwnPropertyDescriptor,__decorateClass$4=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$4(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$4(target,key,result),result},"__decorateClass$4"),__decorateParam$4=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$4");let DocDrawingUpdateRenderController=(_c=class extends core.Disposable{constructor(_context,_commandService,_docSelectionManagerService,_renderManagerSrv,_imageIoService,_docDrawingService,_drawingManagerService,_contextService,_messageService,_localeService,_docSelectionRenderService,_docRefreshDrawingsService,_fileOpenerService){super(),this._context=_context,this._commandService=_commandService,this._docSelectionManagerService=_docSelectionManagerService,this._renderManagerSrv=_renderManagerSrv,this._imageIoService=_imageIoService,this._docDrawingService=_docDrawingService,this._drawingManagerService=_drawingManagerService,this._contextService=_contextService,this._messageService=_messageService,this._localeService=_localeService,this._docSelectionRenderService=_docSelectionRenderService,this._docRefreshDrawingsService=_docRefreshDrawingsService,this._fileOpenerService=_fileOpenerService,this._updateOrderListener(),this._groupDrawingListener(),this._focusDrawingListener(),this._transformDrawingListener(),this._editAreaChangeListener()}async insertDocImage(){const files=await this._fileOpenerService.openFile({multiple:!0,accept:drawing.DRAWING_IMAGE_ALLOW_IMAGE_LIST.map(image=>`.${image.replace("image/","")}`).join(",")}),fileLength=files.length;return fileLength>drawing.DRAWING_IMAGE_COUNT_LIMIT?(this._messageService.show({type:design.MessageType.Error,content:this._localeService.t("update-status.exceedMaxCount",String(drawing.DRAWING_IMAGE_COUNT_LIMIT))}),!1):fileLength===0?!1:(await this._insertFloatImages(files),!0)}async _insertFloatImages(files){let imageParams=[];try{imageParams=await Promise.all(files.map(file=>this._imageIoService.saveImage(file)))}catch(error){const type=error.message;let content="";switch(type){case drawing.ImageUploadStatusType.ERROR_EXCEED_SIZE:content=this._localeService.t("update-status.exceedMaxSize",String(drawing.DRAWING_IMAGE_ALLOW_SIZE/(1024*1024)));break;case drawing.ImageUploadStatusType.ERROR_IMAGE_TYPE:content=this._localeService.t("update-status.invalidImageType");break;case drawing.ImageUploadStatusType.ERROR_IMAGE:content=this._localeService.t("update-status.invalidImage");break}this._messageService.show({type:design.MessageType.Error,content})}if(imageParams.length===0)return;const{unitId}=this._context,docDrawingParams=[];for(const imageParam of imageParams){if(imageParam==null)continue;const{imageId,imageSourceType,source,base64Cache}=imageParam,{width,height,image}=await drawing.getImageSize(base64Cache||"");this._imageIoService.addImageSourceCache(imageId,imageSourceType,image);let scale=1;if(width>drawing.DRAWING_IMAGE_WIDTH_LIMIT||height>drawing.DRAWING_IMAGE_HEIGHT_LIMIT){const scaleWidth=drawing.DRAWING_IMAGE_WIDTH_LIMIT/width,scaleHeight=drawing.DRAWING_IMAGE_HEIGHT_LIMIT/height;scale=Math.min(scaleWidth,scaleHeight)}const docTransform=this._getImagePosition(width*scale,height*scale);if(docTransform==null)return;const docDrawingParam={unitId,subUnitId:unitId,drawingId:imageId,drawingType:core.DrawingTypeEnum.DRAWING_IMAGE,imageSourceType,source,transform:docsUi.docDrawingPositionToTransform(docTransform),docTransform,behindDoc:core.BooleanNumber.FALSE,title:"",description:"",layoutType:core.PositionedObjectLayoutType.INLINE,wrapText:core.WrapTextType.BOTH_SIDES,distB:0,distL:0,distR:0,distT:0};this._isInsertInHeaderFooter()&&(docDrawingParam.isMultiTransform=core.BooleanNumber.TRUE,docDrawingParam.transforms=docDrawingParam.transform?[docDrawingParam.transform]:null),docDrawingParams.push(docDrawingParam)}this._commandService.executeCommand(InsertDocDrawingCommand.id,{unitId,drawings:docDrawingParams})}_isInsertInHeaderFooter(){var _a2;const{unitId}=this._context,viewModel=(_a2=this._renderManagerSrv.getRenderById(unitId))==null?void 0:_a2.with(docs.DocSkeletonManagerService).getViewModel(),editArea=viewModel==null?void 0:viewModel.getEditArea();return editArea===engineRender.DocumentEditArea.HEADER||editArea===engineRender.DocumentEditArea.FOOTER}_getImagePosition(imageWidth,imageHeight){const activeTextRange=this._docSelectionRenderService.getActiveTextRange(),position=(activeTextRange==null?void 0:activeTextRange.getAbsolutePosition())||{left:0,top:0};return{size:{width:imageWidth,height:imageHeight},positionH:{relativeFrom:core.ObjectRelativeFromH.PAGE,posOffset:position.left},positionV:{relativeFrom:core.ObjectRelativeFromV.PARAGRAPH,posOffset:0},angle:0}}_updateOrderListener(){this._drawingManagerService.featurePluginOrderUpdate$.subscribe(params=>{const{unitId,subUnitId,drawingIds,arrangeType}=params;this._commandService.executeCommand(SetDocDrawingArrangeCommand.id,{unitId,subUnitId,drawingIds,arrangeType})})}_groupDrawingListener(){this._drawingManagerService.featurePluginGroupUpdate$.subscribe(params=>{this._commandService.executeCommand(GroupDocDrawingCommand.id,params)}),this._drawingManagerService.featurePluginUngroupUpdate$.subscribe(params=>{this._commandService.executeCommand(UngroupDocDrawingCommand.id,params)})}_getCurrentSceneAndTransformer(){const{scene,mainComponent}=this._context;if(scene==null||mainComponent==null)return;const transformer=scene.getTransformerByCreate(),{docsLeft,docsTop}=mainComponent.getOffsetConfig();return{scene,transformer,docsLeft,docsTop}}_transformDrawingListener(){const res=this._getCurrentSceneAndTransformer();if(res&&res.transformer)this.disposeWithMe(res.transformer.changeEnd$.pipe(rxjs.debounceTime(30)).subscribe(params=>{this._docSelectionManagerService.refreshSelection()}));else throw new Error("transformer is not init")}_focusDrawingListener(){this.disposeWithMe(this._drawingManagerService.focus$.subscribe(params=>{var _a2;const{transformer,docsLeft,docsTop}=(_a2=this._getCurrentSceneAndTransformer())!=null?_a2:{};if(params==null||params.length===0)this._contextService.setContextValue(core.FOCUSING_COMMON_DRAWINGS,!1),this._docDrawingService.focusDrawing([]),transformer&&transformer.resetProps({zeroTop:0,zeroLeft:0});else{this._contextService.setContextValue(core.FOCUSING_COMMON_DRAWINGS,!0),this._docDrawingService.focusDrawing(params),this._setDrawingSelections(params);const prevSegmentId=this._docSelectionRenderService.getSegment(),segmentId=this._findSegmentIdByDrawingId(params[0].drawingId);prevSegmentId!==segmentId&&this._docSelectionRenderService.setSegment(segmentId),transformer&&transformer.resetProps({zeroTop:docsTop,zeroLeft:docsLeft})}}))}_findSegmentIdByDrawingId(drawingId){var _a2,_b2,_c2;const{unit:DocDataModel}=this._context,{body,headers={},footers={}}=DocDataModel.getSnapshot();if(((_a2=body==null?void 0:body.customBlocks)!=null?_a2:[]).some(b=>b.blockId===drawingId))return"";for(const headerId of Object.keys(headers))if((_b2=headers[headerId].body.customBlocks)!=null&&_b2.some(b=>b.blockId===drawingId))return headerId;for(const footerId of Object.keys(footers))if((_c2=footers[footerId].body.customBlocks)!=null&&_c2.some(b=>b.blockId===drawingId))return footerId;return""}_updateDrawingsEditStatus(){var _a2;const{unit:docDataModel,scene,unitId}=this._context,viewModel=(_a2=this._renderManagerSrv.getRenderById(unitId))==null?void 0:_a2.with(docs.DocSkeletonManagerService).getViewModel();if(viewModel==null||docDataModel==null)return;const snapshot=docDataModel.getSnapshot(),{drawings={}}=snapshot,isEditBody=viewModel.getEditArea()===engineRender.DocumentEditArea.BODY;for(const key of Object.keys(drawings)){const drawing$1=drawings[key],objectKey=drawing.getDrawingShapeKeyByDrawingSearch({unitId,drawingId:drawing$1.drawingId,subUnitId:unitId}),drawingShapes=scene.fuzzyMathObjects(objectKey,!0);if(drawingShapes.length)for(const shape of drawingShapes)scene.detachTransformerFrom(shape),shape.setOpacity(.5),(isEditBody&&drawing$1.isMultiTransform!==core.BooleanNumber.TRUE||!isEditBody&&drawing$1.isMultiTransform===core.BooleanNumber.TRUE)&&(scene.attachTransformerTo(shape),shape.setOpacity(1))}}_editAreaChangeListener(){var _a2;const{unitId}=this._context,viewModel=(_a2=this._renderManagerSrv.getRenderById(unitId))==null?void 0:_a2.with(docs.DocSkeletonManagerService).getViewModel();viewModel!=null&&(this._updateDrawingsEditStatus(),this.disposeWithMe(viewModel.editAreaChange$.subscribe(()=>{this._updateDrawingsEditStatus()})),this._docRefreshDrawingsService.refreshDrawings$.subscribe(skeleton=>{skeleton!=null&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})}),this.disposeWithMe(this._commandService.onCommandExecuted(async command=>{command.id===docs.RichTextEditingMutation.id&&queueMicrotask(()=>{this._updateDrawingsEditStatus()})})))}_setDrawingSelections(params){var _a2,_b2;const{unit}=this._context,customBlocks=(_b2=(_a2=unit.getSnapshot().body)==null?void 0:_a2.customBlocks)!=null?_b2:[],ranges=params.map(item=>{const id=item.drawingId,block=customBlocks.find(b=>b.blockId===id);return block?block.startIndex:null}).filter(e=>e!==null).map(offset=>({startOffset:offset,endOffset:offset+1}));this._docSelectionManagerService.replaceDocRanges(ranges)}},__name(_c,"DocDrawingUpdateRenderController"),_c);DocDrawingUpdateRenderController=__decorateClass$4([__decorateParam$4(1,core.ICommandService),__decorateParam$4(2,core.Inject(docs.DocSelectionManagerService)),__decorateParam$4(3,engineRender.IRenderManagerService),__decorateParam$4(4,drawing.IImageIoService),__decorateParam$4(5,docsDrawing.IDocDrawingService),__decorateParam$4(6,drawing.IDrawingManagerService),__decorateParam$4(7,core.IContextService),__decorateParam$4(8,ui.IMessageService),__decorateParam$4(9,core.Inject(core.LocaleService)),__decorateParam$4(10,core.Inject(docsUi.DocSelectionRenderService)),__decorateParam$4(11,core.Inject(DocRefreshDrawingsService)),__decorateParam$4(12,ui.ILocalFileService)],DocDrawingUpdateRenderController);const InsertDocImageCommand={id:"doc.command.insert-float-image",type:core.CommandType.COMMAND,handler:__name(accessor=>{var _a2,_b2;return(_b2=(_a2=accessor.get(engineRender.IRenderManagerService).getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a2.with(DocDrawingUpdateRenderController).insertDocImage())!=null?_b2:!1},"handler")},MoveDocDrawingsCommand={id:"doc.command.move-drawing",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),docDrawingService=accessor.get(docsDrawing.IDocDrawingService),univerInstanceService=accessor.get(core.IUniverInstanceService),renderManagerService=accessor.get(engineRender.IRenderManagerService),{direction}=params,drawings=docDrawingService.getFocusDrawings();if(drawings.length===0)return!1;const unitId=drawings[0].unitId,renderObject=renderManagerService.getRenderById(unitId),scene=renderObject==null?void 0:renderObject.scene;if(scene==null)return!1;const transformer=scene.getTransformerByCreate(),documentDataModel=univerInstanceService.getUniverDocInstance(unitId),newDrawings=drawings.map(drawing2=>{var _a2,_b2,_c2,_d2,_e2;const{drawingId}=drawing2,drawingData=(_a2=documentDataModel==null?void 0:documentDataModel.getSnapshot().drawings)==null?void 0:_a2[drawingId];if(drawingData==null||drawingData.layoutType===core.PositionedObjectLayoutType.INLINE)return null;const{positionH,positionV}=drawingData.docTransform,newPositionH={...positionH},newPositionV={...positionV};return direction===core.Direction.UP?newPositionV.posOffset=((_b2=newPositionV.posOffset)!=null?_b2:0)-2:direction===core.Direction.DOWN?newPositionV.posOffset=((_c2=newPositionV.posOffset)!=null?_c2:0)+2:direction===core.Direction.LEFT?newPositionH.posOffset=((_d2=newPositionH.posOffset)!=null?_d2:0)-2:direction===core.Direction.RIGHT&&(newPositionH.posOffset=((_e2=newPositionH.posOffset)!=null?_e2:0)+2),{drawingId,key:direction===core.Direction.UP||direction===core.Direction.DOWN?"positionV":"positionH",value:direction===core.Direction.UP||direction===core.Direction.DOWN?newPositionV:newPositionH}}).filter(drawing2=>drawing2!=null);if(newDrawings.length===0)return!1;const result=commandService.syncExecuteCommand(UpdateDrawingDocTransformCommand.id,{unitId,subUnitId:unitId,drawings:newDrawings});return transformer.refreshControls(),!!result},"handler")},ClearDocDrawingTransformerOperation={id:"doc.operation.clear-drawing-transformer",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const renderManagerService=accessor.get(engineRender.IRenderManagerService);return params.forEach(unitId=>{var _a2,_b2;(_b2=(_a2=renderManagerService.getRenderById(unitId))==null?void 0:_a2.scene.getTransformer())==null||_b2.debounceRefreshControls()}),!0},"handler")},COMPONENT_DOC_DRAWING_PANEL="COMPONENT_DOC_DRAWING_PANEL",SidebarDocDrawingOperation={id:"sidebar.operation.doc-image",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const sidebarService=accessor.get(ui.ISidebarService),localeService=accessor.get(core.LocaleService),drawingManagerService=accessor.get(drawing.IDrawingManagerService);switch(params.value){case"open":sidebarService.open({header:{title:localeService.t("docImage.panel.title")},children:{label:COMPONENT_DOC_DRAWING_PANEL},onClose:__name(()=>{drawingManagerService.focusDrawing(null)},"onClose"),width:360});break;case"close":default:sidebarService.close();break}return!0},"handler")},EditDocDrawingOperation={id:"doc.operation.edit-doc-image",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{const drawingManagerService=accessor.get(drawing.IDrawingManagerService),commandService=accessor.get(core.ICommandService);return params==null?!1:(drawingManagerService.focusDrawing([params]),commandService.executeCommand(SidebarDocDrawingOperation.id,{value:"open"}),!0)},"handler")};function r(e){var t,f,n="";if(typeof e=="string"||typeof e=="number")n+=e;else if(typeof e=="object")if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=" "),n+=f)}else for(f in e)e[f]&&(n&&(n+=" "),n+=f);return n}__name(r,"r");function clsx(){for(var e,t,f=0,n="",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=" "),n+=t);return n}__name(clsx,"clsx");const styles={imageCommonPanel:"univer-image-common-panel",imageCommonPanelGrid:"univer-image-common-panel-grid",imageCommonPanelBorder:"univer-image-common-panel-border",imageCommonPanelTitle:"univer-image-common-panel-title",imageCommonPanelSubtitle:"univer-image-common-panel-subtitle",imageCommonPanelRow:"univer-image-common-panel-row",imageCommonPanelRowVertical:"univer-image-common-panel-row-vertical",imageCommonPanelColumn:"univer-image-common-panel-column",imageCommonPanelColumnCenter:"univer-image-common-panel-column-center",imageCommonPanelInline:"univer-image-common-panel-inline",imageCommonPanelSpan2:"univer-image-common-panel-span2",imageCommonPanelSpan3:"univer-image-common-panel-span3",imageCommonPanelInput:"univer-image-common-panel-input",sheetImageMenu:"univer-sheet-image-menu",sheetImageMenuInput:"univer-sheet-image-menu-input"},MIN_OFFSET=-1e3,MAX_OFFSET=1e3,DocDrawingPosition=__name(props=>{const commandService=core.useDependency(core.ICommandService),localeService=core.useDependency(core.LocaleService),drawingManagerService=core.useDependency(drawing.IDrawingManagerService),renderManagerService=core.useDependency(engineRender.IRenderManagerService),univerInstanceService=core.useDependency(core.IUniverInstanceService),{drawings}=props,drawingParam=drawings[0];if(drawingParam==null)return;const{unitId}=drawingParam,documentDataModel=univerInstanceService.getUniverDocInstance(unitId),documentFlavor=documentDataModel==null?void 0:documentDataModel.getSnapshot().documentStyle.documentFlavor,renderObject=renderManagerService.getRenderById(unitId),scene=renderObject==null?void 0:renderObject.scene;if(scene==null)return;const transformer=scene.getTransformerByCreate(),HORIZONTAL_RELATIVE_FROM=[{label:localeService.t("image-position.column"),value:String(core.ObjectRelativeFromH.COLUMN)},{label:localeService.t("image-position.page"),value:String(core.ObjectRelativeFromH.PAGE)},{label:localeService.t("image-position.margin"),value:String(core.ObjectRelativeFromH.MARGIN)}],VERTICAL_RELATIVE_FROM=[{label:localeService.t("image-position.line"),value:String(core.ObjectRelativeFromV.LINE),disabled:documentFlavor===core.DocumentFlavor.MODERN},{label:localeService.t("image-position.page"),value:String(core.ObjectRelativeFromV.PAGE),disabled:documentFlavor===core.DocumentFlavor.MODERN},{label:localeService.t("image-position.margin"),value:String(core.ObjectRelativeFromV.MARGIN),disabled:documentFlavor===core.DocumentFlavor.MODERN},{label:localeService.t("image-position.paragraph"),value:String(core.ObjectRelativeFromV.PARAGRAPH)}],[disabled,setDisabled]=react.useState(!0),[hPosition,setHPosition]=react.useState({relativeFrom:core.ObjectRelativeFromH.PAGE,posOffset:0}),[vPosition,setVPosition]=react.useState({relativeFrom:core.ObjectRelativeFromV.PAGE,posOffset:0}),[followTextMove,setFollowTextMove]=react.useState(!0),[showPanel,setShowPanel]=react.useState(!0);function handlePositionChange(direction,value){var _a2;direction==="positionH"?setHPosition(value):setVPosition(value);const focusDrawings=drawingManagerService.getFocusDrawings();if(focusDrawings.length===0)return;const drawings2=focusDrawings.map(drawing2=>({unitId:drawing2.unitId,subUnitId:drawing2.subUnitId,drawingId:drawing2.drawingId}));commandService.executeCommand(UpdateDrawingDocTransformCommand.id,{unitId:focusDrawings[0].unitId,subUnitId:focusDrawings[0].unitId,drawings:drawings2.map(drawing2=>({drawingId:drawing2.drawingId,key:direction,value}))});const docSelectionRenderService=(_a2=renderManagerService.getRenderById(unitId))==null?void 0:_a2.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&docSelectionRenderService.blur(),transformer.refreshControls()}__name(handlePositionChange,"handlePositionChange");function handleHorizontalRelativeFromChange(value){var _a2,_b2,_c2;const prevRelativeFrom=hPosition.relativeFrom,prevPosOffset=hPosition.posOffset,relativeFrom=Number(value);if(prevRelativeFrom===relativeFrom)return;const focusDrawings=drawingManagerService.getFocusDrawings();if(focusDrawings.length===0)return;const drawingId=focusDrawings[0].drawingId,unitId2=focusDrawings[0].unitId;let drawing2=null,pageMarginLeft=0;const skeleton=(_a2=renderManagerService.getRenderById(unitId2))==null?void 0:_a2.with(docs.DocSkeletonManagerService).getSkeleton(),skeletonData=skeleton==null?void 0:skeleton.getSkeletonData();if(skeletonData==null)return;const{pages,skeHeaders,skeFooters}=skeletonData;for(const page of pages){const{marginLeft,skeDrawings,headerId,footerId,pageWidth}=page;if(skeDrawings.has(drawingId)){drawing2=skeDrawings.get(drawingId),pageMarginLeft=marginLeft;break}const headerPage=(_b2=skeHeaders.get(headerId))==null?void 0:_b2.get(pageWidth);if(headerPage!=null&&headerPage.skeDrawings.has(drawingId)){drawing2=headerPage==null?void 0:headerPage.skeDrawings.get(drawingId),pageMarginLeft=marginLeft;break}const footerPage=(_c2=skeFooters.get(footerId))==null?void 0:_c2.get(pageWidth);if(footerPage!=null&&footerPage.skeDrawings.has(drawingId)){drawing2=footerPage==null?void 0:footerPage.skeDrawings.get(drawingId),pageMarginLeft=marginLeft;break}}if(drawing2==null)return;let delta=0;prevRelativeFrom===core.ObjectRelativeFromH.COLUMN?delta-=drawing2.columnLeft:prevRelativeFrom===core.ObjectRelativeFromH.MARGIN&&(delta-=pageMarginLeft),relativeFrom===core.ObjectRelativeFromH.COLUMN?delta+=drawing2.columnLeft:relativeFrom===core.ObjectRelativeFromH.MARGIN?delta+=pageMarginLeft:core.ObjectRelativeFromH.PAGE;const newPositionH={relativeFrom,posOffset:(prevPosOffset!=null?prevPosOffset:0)-delta};handlePositionChange("positionH",newPositionH)}__name(handleHorizontalRelativeFromChange,"handleHorizontalRelativeFromChange");function handleVerticalRelativeFromChange(value){var _a2,_b2,_c2,_d2,_e2,_f2;const prevRelativeFrom=vPosition.relativeFrom,prevPosOffset=vPosition.posOffset,relativeFrom=Number(value);if(prevRelativeFrom===relativeFrom)return;const focusDrawings=drawingManagerService.getFocusDrawings();if(focusDrawings.length===0)return;const{drawingId,unitId:unitId2}=focusDrawings[0],documentDataModel2=univerInstanceService.getUniverDocInstance(unitId2),skeleton=(_a2=renderManagerService.getRenderById(unitId2))==null?void 0:_a2.with(docs.DocSkeletonManagerService).getSkeleton(),docSelectionRenderService=(_b2=renderManagerService.getRenderById(unitId2))==null?void 0:_b2.with(docsUi.DocSelectionRenderService),segmentId=docSelectionRenderService==null?void 0:docSelectionRenderService.getSegment(),segmentPage=docSelectionRenderService==null?void 0:docSelectionRenderService.getSegmentPage(),drawing2=(_d2=(_c2=documentDataModel2==null?void 0:documentDataModel2.getSelfOrHeaderFooterModel(segmentId).getBody())==null?void 0:_c2.customBlocks)==null?void 0:_d2.find(c=>c.blockId===drawingId);if(drawing2==null||skeleton==null||docSelectionRenderService==null)return;const{startIndex}=drawing2,glyph=skeleton.findNodeByCharIndex(startIndex,segmentId,segmentPage),line=(_e2=glyph==null?void 0:glyph.parent)==null?void 0:_e2.parent,column=line==null?void 0:line.parent,paragraphStartLine=column==null?void 0:column.lines.find(l=>l.paragraphIndex===(line==null?void 0:line.paragraphIndex)&&l.paragraphStart),page=(_f2=column==null?void 0:column.parent)==null?void 0:_f2.parent;if(glyph==null||line==null||paragraphStartLine==null||column==null||page==null)return;let delta=0;prevRelativeFrom===core.ObjectRelativeFromV.PARAGRAPH?delta-=paragraphStartLine.top:prevRelativeFrom===core.ObjectRelativeFromV.LINE?delta-=line.top:prevRelativeFrom===core.ObjectRelativeFromV.PAGE&&(delta+=page.marginTop),relativeFrom===core.ObjectRelativeFromV.PARAGRAPH?delta+=paragraphStartLine.top:relativeFrom===core.ObjectRelativeFromV.LINE?delta+=line.top:relativeFrom===core.ObjectRelativeFromV.PAGE&&(delta-=page.marginTop);const newPositionV={relativeFrom,posOffset:(prevPosOffset!=null?prevPosOffset:0)-delta};handlePositionChange("positionV",newPositionV)}__name(handleVerticalRelativeFromChange,"handleVerticalRelativeFromChange");function updateState(drawingParam2){var _a2;const snapshot=documentDataModel==null?void 0:documentDataModel.getSnapshot(),drawing2=(_a2=snapshot==null?void 0:snapshot.drawings)==null?void 0:_a2[drawingParam2.drawingId];if(drawing2==null)return;const{layoutType}=drawing2,{positionH,positionV}=drawing2.docTransform;setHPosition(positionH),setVPosition(positionV),setDisabled(layoutType===core.PositionedObjectLayoutType.INLINE),setFollowTextMove(positionV.relativeFrom===core.ObjectRelativeFromV.PARAGRAPH||positionV.relativeFrom===core.ObjectRelativeFromV.LINE)}__name(updateState,"updateState");function updateFocusDrawingState(){const focusDrawings=drawingManagerService.getFocusDrawings();focusDrawings.length!==0&&updateState(focusDrawings[0])}__name(updateFocusDrawingState,"updateFocusDrawingState");function handleFollowTextMoveCheck(val){setFollowTextMove(val),handleVerticalRelativeFromChange(String(val?core.ObjectRelativeFromV.PARAGRAPH:core.ObjectRelativeFromV.PAGE))}return __name(handleFollowTextMoveCheck,"handleFollowTextMoveCheck"),react.useEffect(()=>{updateFocusDrawingState();const subscription=drawingManagerService.focus$.subscribe(drawingParams=>{if(drawingParams.length===0){setShowPanel(!1);return}setShowPanel(!0),updateState(drawingParams[0])}),mutationListener=commandService.onCommandExecuted(async command=>{command.id===docs.RichTextEditingMutation.id&&updateFocusDrawingState()});return()=>{subscription.unsubscribe(),mutationListener.dispose()}},[]),jsxRuntime.jsxs("div",{className:clsx(styles.imageCommonPanelGrid,styles.imageCommonPanelBorder),style:{display:showPanel?"block":"none"},children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelTitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-position.title")})})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSubtitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-position.horizontal")})})}),jsxRuntime.jsxs("div",{className:styles.imageCommonPanelRow,children:[jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-position.absolutePosition")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.InputNumber,{min:MIN_OFFSET,max:MAX_OFFSET,precision:1,disabled,value:hPosition.posOffset,onChange:__name(val=>{handlePositionChange("positionH",{relativeFrom:hPosition.relativeFrom,posOffset:val})},"onChange"),className:styles.imageCommonPanelInput})})})]})}),jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-position.toTheRightOf")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.Select,{value:String(hPosition.relativeFrom),disabled,options:HORIZONTAL_RELATIVE_FROM,onChange:handleHorizontalRelativeFromChange})})})]})})]}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSubtitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-position.vertical")})})}),jsxRuntime.jsxs("div",{className:styles.imageCommonPanelRow,children:[jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-position.absolutePosition")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.InputNumber,{min:MIN_OFFSET,max:MAX_OFFSET,precision:1,disabled,value:vPosition.posOffset,onChange:__name(val=>{handlePositionChange("positionV",{relativeFrom:vPosition.relativeFrom,posOffset:val})},"onChange"),className:styles.imageCommonPanelInput})})})]})}),jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-position.bellow")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.Select,{disabled,value:String(vPosition.relativeFrom),options:VERTICAL_RELATIVE_FROM,onChange:handleVerticalRelativeFromChange})})})]})})]}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSubtitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-position.options")})})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,style:{marginBottom:"50px"},children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.Checkbox,{disabled,checked:followTextMove,onChange:handleFollowTextMoveCheck,children:localeService.t("image-position.moveObjectWithText")})})})]})},"DocDrawingPosition"),MIN_MARGIN=0,MAX_MARGIN=100,DocDrawingTextWrap=__name(props=>{const commandService=core.useDependency(core.ICommandService),localeService=core.useDependency(core.LocaleService),drawingManagerService=core.useDependency(drawing.IDrawingManagerService),renderManagerService=core.useDependency(engineRender.IRenderManagerService),univerInstanceService=core.useDependency(core.IUniverInstanceService),{drawings}=props,drawingParam=drawings[0];if(drawingParam==null)return null;const{unitId}=drawingParam,documentDataModel=univerInstanceService.getUniverDocInstance(unitId),renderObject=renderManagerService.getRenderById(unitId);if((renderObject==null?void 0:renderObject.scene)==null)return null;const[disableWrapText,setDisableWrapText]=react.useState(!0),[disableDistTB,setDisableDistTB]=react.useState(!0),[disableDistLR,setDisableDistLR]=react.useState(!0),[wrappingStyle,setWrappingStyle]=react.useState(TextWrappingStyle.INLINE),[wrapText,setWrapText]=react.useState(""),[distToText,setDistToText]=react.useState({distT:0,distL:0,distB:0,distR:0}),[showPanel,setShowPanel]=react.useState(!0);function handleWrappingStyleChange(value){setWrappingStyle(value);const focusDrawings=drawingManagerService.getFocusDrawings();if(focusDrawings.length===0)return;const{unitId:unitId2,subUnitId}=focusDrawings[0],drawings2=focusDrawings.map(({unitId:unitId3,subUnitId:subUnitId2,drawingId})=>({unitId:unitId3,subUnitId:subUnitId2,drawingId}));commandService.executeCommand(UpdateDocDrawingWrappingStyleCommand.id,{unitId:unitId2,subUnitId,drawings:drawings2,wrappingStyle:value})}__name(handleWrappingStyleChange,"handleWrappingStyleChange");function handleWrapTextChange(value){setWrapText(value);const focusDrawings=drawingManagerService.getFocusDrawings();if(focusDrawings.length===0)return;const drawings2=focusDrawings.map(drawing2=>({unitId:drawing2.unitId,subUnitId:drawing2.subUnitId,drawingId:drawing2.drawingId}));commandService.executeCommand(UpdateDocDrawingWrapTextCommand.id,{unitId:focusDrawings[0].unitId,subUnitId:focusDrawings[0].unitId,drawings:drawings2,wrapText:value})}__name(handleWrapTextChange,"handleWrapTextChange");function handleDistToTextChange(value,direction){if(value==null)return;const newDistToText={...distToText,[direction]:value};setDistToText(newDistToText);const focusDrawings=drawingManagerService.getFocusDrawings();if(focusDrawings.length===0)return;const drawings2=focusDrawings.map(drawing2=>({unitId:drawing2.unitId,subUnitId:drawing2.subUnitId,drawingId:drawing2.drawingId}));commandService.executeCommand(UpdateDocDrawingDistanceCommand.id,{unitId:focusDrawings[0].unitId,subUnitId:focusDrawings[0].unitId,drawings:drawings2,dist:{[direction]:value}})}__name(handleDistToTextChange,"handleDistToTextChange");function updateFocusDrawingState(){const focusDrawings=drawingManagerService.getFocusDrawings();focusDrawings.length!==0&&updateState(focusDrawings[0])}__name(updateFocusDrawingState,"updateFocusDrawingState");function updateState(drawingParam2){var _a2,_b2;const drawing2=(_b2=(_a2=documentDataModel==null?void 0:documentDataModel.getSnapshot())==null?void 0:_a2.drawings)==null?void 0:_b2[drawingParam2.drawingId];if(drawing2==null)return;const{distT=0,distL=0,distB=0,distR=0,layoutType=core.PositionedObjectLayoutType.INLINE,behindDoc=core.BooleanNumber.FALSE,wrapText:wrapText2=core.WrapTextType.BOTH_SIDES}=drawing2;if(setDistToText({distT,distL,distB,distR}),setWrapText(wrapText2),setDisableWrapText(layoutType!==core.PositionedObjectLayoutType.WRAP_SQUARE),layoutType===core.PositionedObjectLayoutType.WRAP_NONE||layoutType===core.PositionedObjectLayoutType.INLINE?setDisableDistTB(!0):setDisableDistTB(!1),layoutType===core.PositionedObjectLayoutType.WRAP_NONE||layoutType===core.PositionedObjectLayoutType.INLINE||layoutType===core.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM?setDisableDistLR(!0):setDisableDistLR(!1),layoutType===core.PositionedObjectLayoutType.WRAP_NONE)behindDoc===core.BooleanNumber.TRUE?setWrappingStyle(TextWrappingStyle.BEHIND_TEXT):setWrappingStyle(TextWrappingStyle.IN_FRONT_OF_TEXT);else switch(layoutType){case core.PositionedObjectLayoutType.INLINE:setWrappingStyle(TextWrappingStyle.INLINE);break;case core.PositionedObjectLayoutType.WRAP_SQUARE:setWrappingStyle(TextWrappingStyle.WRAP_SQUARE);break;case core.PositionedObjectLayoutType.WRAP_TOP_AND_BOTTOM:setWrappingStyle(TextWrappingStyle.WRAP_TOP_AND_BOTTOM);break;default:throw new Error(`Unsupported layout type: ${layoutType}`)}}return __name(updateState,"updateState"),react.useEffect(()=>{updateFocusDrawingState();const subscription=drawingManagerService.focus$.subscribe(drawingParams=>{if(drawingParams.length===0){setShowPanel(!1);return}setShowPanel(!0),updateState(drawingParams[0])}),mutationListener=commandService.onCommandExecuted(async command=>{command.id===docs.RichTextEditingMutation.id&&updateFocusDrawingState()});return()=>{subscription.unsubscribe(),mutationListener.dispose()}},[]),jsxRuntime.jsxs("div",{className:clsx(styles.imageCommonPanelGrid,styles.imageCommonPanelBorder),style:{display:showPanel?"block":"none"},children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelTitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-text-wrap.title")})})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSubtitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-text-wrap.wrappingStyle")})})}),jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelRow),children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn),children:jsxRuntime.jsxs(design.RadioGroup,{value:wrappingStyle,onChange:handleWrappingStyleChange,direction:"vertical",children:[jsxRuntime.jsx(design.Radio,{value:TextWrappingStyle.INLINE,children:localeService.t("image-text-wrap.inline")}),jsxRuntime.jsx(design.Radio,{value:TextWrappingStyle.WRAP_SQUARE,children:localeService.t("image-text-wrap.square")}),jsxRuntime.jsx(design.Radio,{value:TextWrappingStyle.WRAP_TOP_AND_BOTTOM,children:localeService.t("image-text-wrap.topAndBottom")}),jsxRuntime.jsx(design.Radio,{value:TextWrappingStyle.BEHIND_TEXT,children:localeService.t("image-text-wrap.behindText")}),jsxRuntime.jsx(design.Radio,{value:TextWrappingStyle.IN_FRONT_OF_TEXT,children:localeService.t("image-text-wrap.inFrontText")})]})})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSubtitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-text-wrap.wrapText")})})}),jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelRow),children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn),children:jsxRuntime.jsxs(design.RadioGroup,{disabled:disableWrapText,value:wrapText,onChange:handleWrapTextChange,direction:"horizontal",children:[jsxRuntime.jsx(design.Radio,{value:core.WrapTextType.BOTH_SIDES,children:localeService.t("image-text-wrap.bothSide")}),jsxRuntime.jsx(design.Radio,{value:core.WrapTextType.LEFT,children:localeService.t("image-text-wrap.leftOnly")}),jsxRuntime.jsx(design.Radio,{value:core.WrapTextType.RIGHT,children:localeService.t("image-text-wrap.rightOnly")})]})})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSubtitle),children:jsxRuntime.jsx("div",{children:localeService.t("image-text-wrap.distanceFromText")})})}),jsxRuntime.jsxs("div",{className:styles.imageCommonPanelRow,children:[jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-text-wrap.top")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.InputNumber,{min:MIN_MARGIN,max:MAX_MARGIN,disabled:disableDistTB,precision:1,value:distToText.distT,onChange:__name(val=>{handleDistToTextChange(val,"distT")},"onChange"),className:styles.imageCommonPanelInput})})})]})}),jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-text-wrap.left")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.InputNumber,{min:MIN_MARGIN,max:MAX_MARGIN,disabled:disableDistLR,precision:1,value:distToText.distL,onChange:__name(val=>{handleDistToTextChange(val,"distL")},"onChange"),className:styles.imageCommonPanelInput})})})]})})]}),jsxRuntime.jsxs("div",{className:styles.imageCommonPanelRow,children:[jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-text-wrap.bottom")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.InputNumber,{min:MIN_MARGIN,max:MAX_MARGIN,disabled:disableDistTB,precision:1,value:distToText.distB,onChange:__name(val=>{handleDistToTextChange(val,"distB")},"onChange"),className:styles.imageCommonPanelInput})})})]})}),jsxRuntime.jsx("div",{className:clsx(styles.imageCommonPanelColumn,styles.imageCommonPanelSpan2),children:jsxRuntime.jsxs("label",{children:[jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:localeService.t("image-text-wrap.right")})}),jsxRuntime.jsx("div",{className:styles.imageCommonPanelRow,children:jsxRuntime.jsx("div",{className:styles.imageCommonPanelColumn,children:jsxRuntime.jsx(design.InputNumber,{min:MIN_MARGIN,max:MAX_MARGIN,disabled:disableDistLR,precision:1,value:distToText.distR,onChange:__name(val=>{handleDistToTextChange(val,"distR")},"onChange"),className:styles.imageCommonPanelInput})})})]})})]})]})},"DocDrawingTextWrap"),DocDrawingPanel=__name(()=>{const drawingManagerService=core.useDependency(drawing.IDrawingManagerService),focusDrawings=drawingManagerService.getFocusDrawings(),[drawings,setDrawings]=react.useState(focusDrawings);return react.useEffect(()=>{const focusDispose=drawingManagerService.focus$.subscribe(drawings2=>{setDrawings(drawings2)});return()=>{focusDispose.unsubscribe()}},[]),!!(drawings!=null&&drawings.length)&&jsxRuntime.jsxs("div",{className:styles.imageCommonPanel,children:[jsxRuntime.jsx(drawingUi.DrawingCommonPanel,{drawings,hasAlign:!1,hasCropper:!1,hasGroup:!1,hasTransform:!1}),jsxRuntime.jsx(DocDrawingTextWrap,{drawings}),jsxRuntime.jsx(DocDrawingPosition,{drawings})]})},"DocDrawingPanel"),ImageUploadIcon="addition-and-subtraction-single",DOCS_IMAGE_MENU_ID="doc.menu.image",IMAGE_MENU_UPLOAD_FLOAT_ID=InsertDocImageCommand.id,getDisableWhenSelectionInTableObservable=__name(accessor=>{const docSelectionManagerService=accessor.get(docs.DocSelectionManagerService),univerInstanceService=accessor.get(core.IUniverInstanceService);return new rxjs.Observable(subscriber=>{const observable=docSelectionManagerService.textSelection$.subscribe(()=>{var _a2;const activeRange=docSelectionManagerService.getActiveTextRange();if(activeRange){const{segmentId,startOffset,endOffset}=activeRange,docDataModel=univerInstanceService.getCurrentUniverDocInstance(),tables=(_a2=docDataModel==null?void 0:docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody())==null?void 0:_a2.tables;if(tables&&tables.length&&tables.some(table=>{const{startIndex,endIndex}=table;return startOffset>=startIndex&&startOffset<endIndex||endOffset>=startIndex&&endOffset<endIndex})){subscriber.next(!0);return}}else{subscriber.next(!0);return}subscriber.next(!1)});return()=>observable.unsubscribe()})},"getDisableWhenSelectionInTableObservable");function ImageMenuFactory(accessor){return{id:DOCS_IMAGE_MENU_ID,type:ui.MenuItemType.SUBITEMS,icon:ImageUploadIcon,tooltip:"docImage.title",disabled$:getDisableWhenSelectionInTableObservable(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_DOC)}}__name(ImageMenuFactory,"ImageMenuFactory");function UploadFloatImageMenuFactory(_accessor){return{id:IMAGE_MENU_UPLOAD_FLOAT_ID,title:"docImage.upload.float",type:ui.MenuItemType.BUTTON,hidden$:ui.getMenuHiddenObservable(_accessor,core.UniverInstanceType.UNIVER_DOC)}}__name(UploadFloatImageMenuFactory,"UploadFloatImageMenuFactory");const menuSchema={[ui.RibbonStartGroup.LAYOUT]:{[DOCS_IMAGE_MENU_ID]:{order:0,menuItemFactory:ImageMenuFactory,[IMAGE_MENU_UPLOAD_FLOAT_ID]:{order:0,menuItemFactory:UploadFloatImageMenuFactory}}}};function whenDocDrawingFocused(contextService){return contextService.getContextValue(core.FOCUSING_UNIVER_EDITOR)&&contextService.getContextValue(core.FOCUSING_COMMON_DRAWINGS)}__name(whenDocDrawingFocused,"whenDocDrawingFocused");const MoveDrawingDownShortcutItem={id:MoveDocDrawingsCommand.id,description:"shortcut.doc.drawing-move-down",group:"4_doc-drawing-view",binding:ui.KeyCode.ARROW_DOWN,priority:100,preconditions:whenDocDrawingFocused,staticParameters:{direction:core.Direction.DOWN}},MoveDrawingUpShortcutItem={id:MoveDocDrawingsCommand.id,description:"shortcut.doc.drawing-move-up",group:"4_doc-drawing-view",binding:ui.KeyCode.ARROW_UP,priority:100,preconditions:whenDocDrawingFocused,staticParameters:{direction:core.Direction.UP}},MoveDrawingLeftShortcutItem={id:MoveDocDrawingsCommand.id,description:"shortcut.doc.drawing-move-left",group:"4_doc-drawing-view",binding:ui.KeyCode.ARROW_LEFT,priority:100,preconditions:whenDocDrawingFocused,staticParameters:{direction:core.Direction.LEFT}},MoveDrawingRightShortcutItem={id:MoveDocDrawingsCommand.id,description:"shortcut.doc.drawing-move-right",group:"4_doc-drawing-view",binding:ui.KeyCode.ARROW_RIGHT,priority:100,preconditions:whenDocDrawingFocused,staticParameters:{direction:core.Direction.RIGHT}},DeleteDrawingsShortcutItem={id:DeleteDocDrawingsCommand.id,description:"shortcut.doc.drawing-delete",group:"4_doc-drawing-view",preconditions:whenDocDrawingFocused,binding:ui.KeyCode.DELETE,mac:ui.KeyCode.BACKSPACE};var __defProp$3=Object.defineProperty,__getOwnPropDesc$3=Object.getOwnPropertyDescriptor,__decorateClass$3=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$3(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$3(target,key,result),result},"__decorateClass$3"),__decorateParam$3=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$3");let DocDrawingUIController=(_d=class extends core.Disposable{constructor(_componentManager,_menuManagerService,_commandService,_shortcutService){super(),this._componentManager=_componentManager,this._menuManagerService=_menuManagerService,this._commandService=_commandService,this._shortcutService=_shortcutService,this._init()}_initCustomComponents(){const componentManager=this._componentManager;this.disposeWithMe(componentManager.register(ImageUploadIcon,AddImageSingle)),this.disposeWithMe(componentManager.register(COMPONENT_DOC_DRAWING_PANEL,DocDrawingPanel))}_initMenus(){this._menuManagerService.mergeMenu(menuSchema)}_initCommands(){[InsertDocImageCommand,InsertDocDrawingCommand,UpdateDocDrawingWrappingStyleCommand,UpdateDocDrawingDistanceCommand,UpdateDocDrawingWrapTextCommand,UpdateDrawingDocTransformCommand,IMoveInlineDrawingCommand,ITransformNonInlineDrawingCommand,RemoveDocDrawingCommand,SidebarDocDrawingOperation,ClearDocDrawingTransformerOperation,EditDocDrawingOperation,GroupDocDrawingCommand,UngroupDocDrawingCommand,MoveDocDrawingsCommand,DeleteDocDrawingsCommand,SetDocDrawingArrangeCommand].forEach(command=>this.disposeWithMe(this._commandService.registerCommand(command)))}_initShortcuts(){[MoveDrawingDownShortcutItem,MoveDrawingUpShortcutItem,MoveDrawingLeftShortcutItem,MoveDrawingRightShortcutItem,DeleteDrawingsShortcutItem].forEach(item=>{this.disposeWithMe(this._shortcutService.registerShortcut(item))})}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus(),this._initShortcuts()}},__name(_d,"DocDrawingUIController"),_d);DocDrawingUIController=__decorateClass$3([__decorateParam$3(0,core.Inject(ui.ComponentManager)),__decorateParam$3(1,ui.IMenuManagerService),__decorateParam$3(2,core.ICommandService),__decorateParam$3(3,ui.IShortcutService)],DocDrawingUIController);var __defProp$2=Object.defineProperty,__getOwnPropDesc$2=Object.getOwnPropertyDescriptor,__decorateClass$2=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$2(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$2(target,key,result),result},"__decorateClass$2"),__decorateParam$2=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$2");let DocDrawingPopupMenuController=(_e=class extends core.RxDisposable{constructor(_drawingManagerService,_canvasPopManagerService,_renderManagerService,_univerInstanceService,_contextService){super();__publicField(this,"_initImagePopupMenu",new Set);this._drawingManagerService=_drawingManagerService,this._canvasPopManagerService=_canvasPopManagerService,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._contextService=_contextService,this._init()}_init(){this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_DOC).pipe(rxjs.takeUntil(this.dispose$)).subscribe(documentDataModel=>this._create(documentDataModel)),this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_DOC).pipe(rxjs.takeUntil(this.dispose$)).subscribe(documentDataModel=>this._dispose(documentDataModel)),this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_DOC).forEach(documentDataModel=>this._create(documentDataModel))}_dispose(documentDataModel){const unitId=documentDataModel.getUnitId();this._renderManagerService.removeRender(unitId)}_create(documentDataModel){if(!documentDataModel)return;const unitId=documentDataModel.getUnitId();this._renderManagerService.has(unitId)&&!this._initImagePopupMenu.has(unitId)&&(this._popupMenuListener(unitId),this._initImagePopupMenu.add(unitId))}_hasCropObject(scene){const objects=scene.getAllObjects();for(const object of objects)if(object instanceof drawingUi.ImageCropperObject)return!0;return!1}_popupMenuListener(unitId){var _a2;const scene=(_a2=this._renderManagerService.getRenderById(unitId))==null?void 0:_a2.scene;if(!scene)return;const transformer=scene.getTransformerByCreate();if(!transformer)return;const disposePopups=[];this.disposeWithMe(core.toDisposable(transformer.createControl$.subscribe(()=>{if(this._hasCropObject(scene))return;const selectedObjects=transformer.getSelectedObjectMap();if(disposePopups.forEach(dispose=>dispose.dispose()),disposePopups.length=0,selectedObjects.size>1)return;const object=selectedObjects.values().next().value;if(!object)return;const oKey=object.oKey,drawingParam=this._drawingManagerService.getDrawingOKey(oKey);if(!drawingParam)return;const{unitId:unitId2,subUnitId,drawingId}=drawingParam,popup=this._canvasPopManagerService.attachPopupToObject(object,{componentKey:drawingUi.COMPONENT_IMAGE_POPUP_MENU,direction:"horizontal",offset:[2,0],extraProps:{menuItems:this._getImageMenuItems(unitId2,subUnitId,drawingId)}},unitId2);disposePopups.push(this.disposeWithMe(popup)),!this._drawingManagerService.getFocusDrawings().find(drawing2=>drawing2.unitId===unitId2&&drawing2.subUnitId===subUnitId&&drawing2.drawingId===drawingId)&&this._drawingManagerService.focusDrawing([{unitId:unitId2,subUnitId,drawingId}])}))),this.disposeWithMe(core.toDisposable(transformer.clearControl$.subscribe(()=>{disposePopups.forEach(dispose=>dispose.dispose()),disposePopups.length=0,this._contextService.setContextValue(core.FOCUSING_COMMON_DRAWINGS,!1),this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(core.toDisposable(transformer.changing$.subscribe(()=>{disposePopups.forEach(dispose=>dispose.dispose()),disposePopups.length=0}))),this.disposeWithMe(core.toDisposable(transformer.changeStart$.subscribe(()=>{disposePopups.forEach(dispose=>dispose.dispose()),disposePopups.length=0})))}_getImageMenuItems(unitId,subUnitId,drawingId){return[{label:"image-popup.edit",index:0,commandId:EditDocDrawingOperation.id,commandParams:{unitId,subUnitId,drawingId},disable:!!core.SHEET_EDITOR_UNITS.includes(unitId)},{label:"image-popup.delete",index:1,commandId:RemoveDocDrawingCommand.id,commandParams:{unitId,drawings:[{unitId,subUnitId,drawingId}]},disable:!1},{label:"image-popup.crop",index:2,commandId:drawingUi.OpenImageCropOperation.id,commandParams:{unitId,subUnitId,drawingId},disable:!0},{label:"image-popup.reset",index:3,commandId:drawingUi.ImageResetSizeOperation.id,commandParams:[{unitId,subUnitId,drawingId}],disable:!0}]}},__name(_e,"DocDrawingPopupMenuController"),_e);DocDrawingPopupMenuController=__decorateClass$2([__decorateParam$2(0,drawing.IDrawingManagerService),__decorateParam$2(1,core.Inject(docsUi.DocCanvasPopManagerService)),__decorateParam$2(2,engineRender.IRenderManagerService),__decorateParam$2(3,core.IUniverInstanceService),__decorateParam$2(4,core.IContextService)],DocDrawingPopupMenuController);var __defProp$1=Object.defineProperty,__getOwnPropDesc$1=Object.getOwnPropertyDescriptor,__decorateClass$1=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$1(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$1(target,key,result),result},"__decorateClass$1"),__decorateParam$1=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$1");let DocDrawingTransformUpdateController=(_f=class extends core.Disposable{constructor(_context,_docSkeletonManagerService,_commandService,_editorService,_drawingManagerService,_docRefreshDrawingsService,_univerInstanceService,_lifecycleService){super();__publicField(this,"_liquid",new engineRender.Liquid);this._context=_context,this._docSkeletonManagerService=_docSkeletonManagerService,this._commandService=_commandService,this._editorService=_editorService,this._drawingManagerService=_drawingManagerService,this._docRefreshDrawingsService=_docRefreshDrawingsService,this._univerInstanceService=_univerInstanceService,this._lifecycleService=_lifecycleService,this._initialize(),this._commandExecutedListener()}_initialize(){this._initialRenderRefresh(),this._drawingInitializeListener(),this._initResize()}_initialRenderRefresh(){this._docSkeletonManagerService.currentSkeleton$.subscribe(documentSkeleton=>{documentSkeleton!=null&&this._refreshDrawing(documentSkeleton)}),this._docRefreshDrawingsService.refreshDrawings$.subscribe(skeleton=>{skeleton!=null&&this._refreshDrawing(skeleton)})}_commandExecutedListener(){const updateCommandList=[docs.RichTextEditingMutation.id,docsUi.SetDocZoomRatioOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(updateCommandList.includes(command.id)){const params=command.params,{unitId:commandUnitId}=params,{unitId,mainComponent}=this._context;if(commandUnitId!==unitId)return;const skeleton=this._docSkeletonManagerService.getSkeleton();if(skeleton==null)return;if(this._editorService.isEditor(unitId)&&unitId!==core.DOCS_ZEN_EDITOR_UNIT_ID_KEY){mainComponent==null||mainComponent.makeDirty();return}this._refreshDrawing(skeleton)}}))}_initResize(){this.disposeWithMe(core.fromEventSubject(this._context.engine.onTransformChange$).pipe(rxjs.filter(evt=>evt.type===engineRender.TRANSFORM_CHANGE_OBSERVABLE_TYPE.resize),rxjs.debounceTime(16)).subscribe(()=>{var _a2;const skeleton=this._docSkeletonManagerService.getSkeleton(),{scene}=this._context;(_a2=scene.getTransformer())==null||_a2.refreshControls(),this._refreshDrawing(skeleton)}))}_refreshDrawing(skeleton){var _a2,_b2;const skeletonData=skeleton==null?void 0:skeleton.getSkeletonData(),{mainComponent,unitId}=this._context,documentComponent=mainComponent;if(!skeletonData)return;const{left:docsLeft,top:docsTop,pageLayoutType,pageMarginLeft,pageMarginTop}=documentComponent,{pages,skeHeaders,skeFooters}=skeletonData,updateDrawingMap={};this._liquid.reset();for(let i=0,len=pages.length;i<len;i++){const page=pages[i],{headerId,footerId,pageWidth}=page;if(headerId){const headerPage=(_a2=skeHeaders.get(headerId))==null?void 0:_a2.get(pageWidth);headerPage&&this._calculateDrawingPosition(unitId,headerPage,docsLeft,docsTop,updateDrawingMap,headerPage.marginTop,page.marginLeft)}if(footerId){const footerPage=(_b2=skeFooters.get(footerId))==null?void 0:_b2.get(pageWidth);footerPage&&this._calculateDrawingPosition(unitId,footerPage,docsLeft,docsTop,updateDrawingMap,page.pageHeight-page.marginBottom+footerPage.marginTop,page.marginLeft)}this._calculateDrawingPosition(unitId,page,docsLeft,docsTop,updateDrawingMap,page.marginTop,page.marginLeft),this._liquid.translatePage(page,pageLayoutType,pageMarginLeft,pageMarginTop)}const updateDrawings=Object.values(updateDrawingMap),nonMultiDrawings=updateDrawings.filter(drawing2=>!drawing2.isMultiTransform),multiDrawings=updateDrawings.filter(drawing2=>drawing2.isMultiTransform);nonMultiDrawings.length>0&&this._drawingManagerService.refreshTransform(nonMultiDrawings),this._handleMultiDrawingsTransform(multiDrawings)}_handleMultiDrawingsTransform(multiDrawings){const{scene,unitId}=this._context,transformer=scene.getTransformerByCreate();multiDrawings.forEach(updateParam=>{const param=this._drawingManagerService.getDrawingByParam(updateParam);param!=null&&(param.transform=updateParam.transform,param.transforms=updateParam.transforms,param.isMultiTransform=updateParam.isMultiTransform)});const selectedObjectKeys=[...transformer.getSelectedObjectMap().keys()],allMultiDrawings=Object.values(this._drawingManagerService.getDrawingData(unitId,unitId)).filter(drawing2=>drawing2.isMultiTransform===core.BooleanNumber.TRUE);this._drawingManagerService.removeNotification(allMultiDrawings),multiDrawings.length>0&&this._drawingManagerService.addNotification(multiDrawings);for(const key of selectedObjectKeys){const drawingShape=scene.getObject(key);drawingShape&&transformer.setSelectedControl(drawingShape)}}_calculateDrawingPosition(unitId,page,docsLeft,docsTop,updateDrawingMap,marginTop,marginLeft){const{skeDrawings}=page;this._liquid.translatePagePadding({marginTop,marginLeft}),skeDrawings.forEach(drawing2=>{const{aLeft,aTop,height,width,angle,drawingId,drawingOrigin}=drawing2,behindText=drawingOrigin.layoutType===core.PositionedObjectLayoutType.WRAP_NONE&&drawingOrigin.behindDoc===core.BooleanNumber.TRUE,{isMultiTransform=core.BooleanNumber.FALSE}=drawingOrigin,transform={left:aLeft+docsLeft+this._liquid.x,top:aTop+docsTop+this._liquid.y,width,height,angle};updateDrawingMap[drawingId]==null?updateDrawingMap[drawingId]={unitId,subUnitId:unitId,drawingId,behindText,transform,transforms:[transform],isMultiTransform}:isMultiTransform===core.BooleanNumber.TRUE&&updateDrawingMap[drawingId].transforms.push(transform)}),this._liquid.restorePagePadding({marginTop,marginLeft})}_drawingInitializeListener(){const init=__name(()=>{const skeleton=this._docSkeletonManagerService.getSkeleton();skeleton!=null&&(this._refreshDrawing(skeleton),this._drawingManagerService.initializeNotification(this._context.unitId))},"init");this._lifecycleService.stage===core.LifecycleStages.Steady?setTimeout(()=>{init()},1e3):this._lifecycleService.lifecycle$.pipe(rxjs.filter(stage=>stage===core.LifecycleStages.Steady)).subscribe(init)}},__name(_f,"DocDrawingTransformUpdateController"),_f);DocDrawingTransformUpdateController=__decorateClass$1([__decorateParam$1(1,core.Inject(docs.DocSkeletonManagerService)),__decorateParam$1(2,core.ICommandService),__decorateParam$1(3,docsUi.IEditorService),__decorateParam$1(4,drawing.IDrawingManagerService),__decorateParam$1(5,core.Inject(DocRefreshDrawingsService)),__decorateParam$1(6,core.IUniverInstanceService),__decorateParam$1(7,core.Inject(core.LifecycleService))],DocDrawingTransformUpdateController);var __defProp2=Object.defineProperty,__getOwnPropDesc=Object.getOwnPropertyDescriptor,__defNormalProp2=__name((obj,key,value)=>key in obj?__defProp2(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp"),__decorateClass=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp2(target,key,result),result},"__decorateClass"),__decorateParam=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam"),__publicField2=__name((obj,key,value)=>__defNormalProp2(obj,typeof key!="symbol"?key+"":key,value),"__publicField");const PLUGIN_NAME="DOC_DRAWING_UI_PLUGIN";exports2.UniverDocsDrawingUIPlugin=(_g=class extends core.Plugin{constructor(_config=defaultPluginConfig,_injector,_renderManagerSrv,_configService){super(),this._config=_config,this._injector=_injector,this._renderManagerSrv=_renderManagerSrv,this._configService=_configService;const{...rest}=core.merge({},defaultPluginConfig,this._config);this._configService.setConfig(DOCS_DRAWING_UI_PLUGIN_CONFIG_KEY,rest)}onStarting(){[[DocDrawingUIController],[DocDrawingPopupMenuController],[DocDrawingTransformerController],[DocDrawingAddRemoveController],[DocRefreshDrawingsService]].forEach(dependency=>this._injector.add(dependency))}onReady(){[[DocDrawingUpdateRenderController],[DocDrawingTransformUpdateController]].forEach(m=>this._renderManagerSrv.registerRenderModule(core.UniverInstanceType.UNIVER_DOC,m)),this._injector.get(DocDrawingAddRemoveController),this._injector.get(DocDrawingUIController),this._injector.get(DocDrawingTransformerController)}onRendered(){this._injector.get(DocDrawingPopupMenuController)}},__name(_g,"UniverDocsDrawingUIPlugin"),_g),__publicField2(exports2.UniverDocsDrawingUIPlugin,"type",core.UniverInstanceType.UNIVER_DOC),__publicField2(exports2.UniverDocsDrawingUIPlugin,"pluginName",PLUGIN_NAME),exports2.UniverDocsDrawingUIPlugin=__decorateClass([core.DependentOn(drawingUi.UniverDrawingUIPlugin,drawing.UniverDrawingPlugin,docsDrawing.UniverDocsDrawingPlugin,ui.UniverUIPlugin),__decorateParam(1,core.Inject(core.Injector)),__decorateParam(2,engineRender.IRenderManagerService),__decorateParam(3,core.IConfigService)],exports2.UniverDocsDrawingUIPlugin),exports2.ClearDocDrawingTransformerOperation=ClearDocDrawingTransformerOperation,exports2.DOCS_IMAGE_MENU_ID=DOCS_IMAGE_MENU_ID,exports2.DeleteDocDrawingsCommand=DeleteDocDrawingsCommand,exports2.EditDocDrawingOperation=EditDocDrawingOperation,exports2.GroupDocDrawingCommand=GroupDocDrawingCommand,exports2.InsertDocDrawingCommand=InsertDocDrawingCommand,exports2.InsertDocImageCommand=InsertDocImageCommand,exports2.MoveDocDrawingsCommand=MoveDocDrawingsCommand,exports2.RemoveDocDrawingCommand=RemoveDocDrawingCommand,exports2.SetDocDrawingArrangeCommand=SetDocDrawingArrangeCommand,exports2.SidebarDocDrawingOperation=SidebarDocDrawingOperation,exports2.UngroupDocDrawingCommand=UngroupDocDrawingCommand,Object.defineProperty(exports2,Symbol.toStringTag,{value:"Module"})});
|
package/lib/umd/locale/en-US.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?module.exports=factory():typeof define=="function"&&define.amd?define(factory):(global=typeof globalThis<"u"?globalThis:global||self,global.UniverDocsDrawingUiEnUS=factory())})(this,function(){"use strict";return{docImage:{title:"Image",upload:{float:"Insert Image"},panel:{title:"Edit Image"}},"image-popup":{replace:"Replace",delete:"Delete",edit:"Edit",crop:"Crop",reset:"Reset Size"},"image-text-wrap":{title:"Text Wrapping",wrappingStyle:"Wrapping Style",square:"Square",topAndBottom:"Top and Bottom",inline:"In line with text",behindText:"Behind text",inFrontText:"In front of text",wrapText:"Wrap text",bothSide:"Both sides",leftOnly:"Left only",rightOnly:"Right only",distanceFromText:"Distance from text",top:"Top(px)",left:"Left(px)",bottom:"Bottom(px)",right:"Right(px)"},"image-position":{title:"Position",horizontal:"Horizontal",vertical:"Vertical",absolutePosition:"Absolute Position(px)",relativePosition:"Relative Position",toTheRightOf:"to the right of",relativeTo:"relative to",bellow:"bellow",options:"Options",moveObjectWithText:"Move object with text",column:"Column",margin:"Margin",page:"Page",line:"Line",paragraph:"Paragraph"},"update-status":{exceedMaxSize:"Image size exceeds limit, limit is {0}M",invalidImageType:"Invalid image type",exceedMaxCount:"Only {0} images can be uploaded at a time",invalidImage:"Invalid image"}}});
|
package/lib/umd/locale/fa-IR.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?module.exports=factory():typeof define=="function"&&define.amd?define(factory):(global=typeof globalThis<"u"?globalThis:global||self,global.UniverDocsDrawingUiFaIR=factory())})(this,function(){"use strict";return{docImage:{title:"تصویر",upload:{float:"درج تصویر"},panel:{title:"ویرایش تصویر"}},"image-popup":{replace:"تعویض",delete:"حذف",edit:"ویرایش",crop:"کراپ",reset:"بازنشانی اندازه"},"image-text-wrap":{title:"پیچش متن",wrappingStyle:"سبک پیچش",square:"مربع",topAndBottom:"بالا و پایین",inline:"در یک خط با متن",behindText:"پشت متن",inFrontText:"جلوی متن",wrapText:"پیچش متن",bothSide:"هر دو طرف",leftOnly:"فقط سمت چپ",rightOnly:"فقط سمت راست",distanceFromText:"فاصله از متن",top:"بالا(px)",left:"چپ(px)",bottom:"پایین(px)",right:"راست(px)"},"image-position":{title:"موقعیت",horizontal:"افقی",vertical:"عمودی",absolutePosition:"موقعیت مطلق(px)",relativePosition:"موقعیت نسبی",toTheRightOf:"سمت راست",relativeTo:"نسبت به",bellow:"زیر",options:"گزینهها",moveObjectWithText:"جابهجایی شیء با متن",column:"ستون",margin:"حاشیه",page:"صفحه",line:"خط",paragraph:"پاراگراف"},"update-status":{exceedMaxSize:"اندازه تصویر از حد مجاز فراتر رفته است، حد مجاز {0}M است",invalidImageType:"نوع تصویر نامعتبر است",exceedMaxCount:"فقط {0} تصویر میتوانند همزمان آپلود شوند",invalidImage:"تصویر نامعتبر است"}}});
|
package/lib/umd/locale/fr-FR.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?module.exports=factory():typeof define=="function"&&define.amd?define(factory):(global=typeof globalThis<"u"?globalThis:global||self,global.UniverDocsDrawingUiFrFR=factory())})(this,function(){"use strict";return{docImage:{title:"Image",upload:{float:"Insérer une image"},panel:{title:"Modifier l'image"}},"image-popup":{replace:"Remplacer",delete:"Supprimer",edit:"Modifier",crop:"Rogner",reset:"Réinitialiser la taille"},"image-text-wrap":{title:"Habillage du texte",wrappingStyle:"Style d'habillage",square:"Carré",topAndBottom:"Haut et bas",inline:"Aligné avec le texte",behindText:"Derrière le texte",inFrontText:"Devant le texte",wrapText:"Habiller le texte",bothSide:"Des deux côtés",leftOnly:"Seulement à gauche",rightOnly:"Seulement à droite",distanceFromText:"Distance du texte",top:"Haut(px)",left:"Gauche(px)",bottom:"Bas(px)",right:"Droite(px)"},"image-position":{title:"Position",horizontal:"Horizontal",vertical:"Vertical",absolutePosition:"Position absolue(px)",relativePosition:"Position relative",toTheRightOf:"à droite de",relativeTo:"par rapport à",bellow:"en dessous",options:"Options",moveObjectWithText:"Déplacer l'objet avec le texte",column:"Colonne",margin:"Marge",page:"Page",line:"Ligne",paragraph:"Paragraphe"},"update-status":{exceedMaxSize:"La taille de l'image dépasse la limite, la limite est de {0}M",invalidImageType:"Type d'image invalide",exceedMaxCount:"Seulement {0} images peuvent être téléchargées à la fois",invalidImage:"Image invalide"}}});
|
package/lib/umd/locale/ru-RU.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?module.exports=factory():typeof define=="function"&&define.amd?define(factory):(global=typeof globalThis<"u"?globalThis:global||self,global.UniverDocsDrawingUiRuRU=factory())})(this,function(){"use strict";return{docImage:{title:"Изображение",upload:{float:"Вставить изображение"},panel:{title:"Редактировать изображение"}},"image-popup":{replace:"Заменить",delete:"Удалить",edit:"Редактировать",crop:"Обрезать",reset:"Сбросить размер"},"image-text-wrap":{title:"Text Wrapping",wrappingStyle:"Wrapping Style",square:"Square",topAndBottom:"Top and Bottom",inline:"In line with text",behindText:"Behind text",inFrontText:"In front of text",wrapText:"Wrap text",bothSide:"Both sides",leftOnly:"Left only",rightOnly:"Right only",distanceFromText:"Distance from text",top:"Top(px)",left:"Left(px)",bottom:"Bottom(px)",right:"Right(px)"},"image-position":{title:"Position",horizontal:"Horizontal",vertical:"Vertical",absolutePosition:"Absolute Position(px)",relativePosition:"Relative Position",toTheRightOf:"to the right of",relativeTo:"relative to",bellow:"bellow",options:"Options",moveObjectWithText:"Move object with text",column:"Column",margin:"Margin",page:"Page",line:"Line",paragraph:"Paragraph"},"update-status":{exceedMaxSize:"Размер изображения превышает лимит, лимит составляет {0}М",invalidImageType:"Недопустимый тип изображения",exceedMaxCount:"За один раз можно загрузить только {0} изображений",invalidImage:"Недопустимое изображение"}}});
|
package/lib/umd/locale/vi-VN.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?module.exports=factory():typeof define=="function"&&define.amd?define(factory):(global=typeof globalThis<"u"?globalThis:global||self,global.UniverDocsDrawingUiViVN=factory())})(this,function(){"use strict";return{docImage:{title:"Hình ảnh",upload:{float:"Chèn hình ảnh"},panel:{title:"Chỉnh sửa hình ảnh"}},"image-popup":{replace:"Thay thế",delete:"Xóa",edit:"Chỉnh sửa",crop:"Cắt",reset:"Đặt lại kích thước"},"image-text-wrap":{title:"Text Wrapping",wrappingStyle:"Wrapping Style",square:"Square",topAndBottom:"Top and Bottom",inline:"In line with text",behindText:"Behind text",inFrontText:"In front of text",wrapText:"Wrap text",bothSide:"Both sides",leftOnly:"Left only",rightOnly:"Right only",distanceFromText:"Distance from text",top:"Top(px)",left:"Left(px)",bottom:"Bottom(px)",right:"Right(px)"},"image-position":{title:"Position",horizontal:"Horizontal",vertical:"Vertical",absolutePosition:"Absolute Position(px)",relativePosition:"Relative Position",toTheRightOf:"to the right of",relativeTo:"relative to",bellow:"bellow",options:"Options",moveObjectWithText:"Move object with text",column:"Column",margin:"Margin",page:"Page",line:"Line",paragraph:"Paragraph"},"update-status":{exceedMaxSize:"Kích thước hình ảnh vượt quá giới hạn, giới hạn là {0}M",invalidImageType:"Loại hình ảnh không hợp lệ",exceedMaxCount:"Chỉ có thể tải lên tối đa {0} hình ảnh một lần",invalidImage:"Hình ảnh không hợp lệ"}}});
|
package/lib/umd/locale/zh-CN.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?module.exports=factory():typeof define=="function"&&define.amd?define(factory):(global=typeof globalThis<"u"?globalThis:global||self,global.UniverDocsDrawingUiZhCN=factory())})(this,function(){"use strict";return{docImage:{title:"图片",upload:{float:"插入图片"},panel:{title:"编辑图片"}},"image-popup":{replace:"替换",delete:"删除",edit:"编辑",crop:"裁剪",reset:"重置大小"},"image-text-wrap":{title:"文字环绕",wrappingStyle:"环绕方式",square:"四周型",topAndBottom:"上下型",inline:"嵌入型",behindText:"衬于文字下方",inFrontText:"浮于文字上方",wrapText:"自动换行",bothSide:"两侧",leftOnly:"左侧",rightOnly:"右侧",distanceFromText:"距正文",top:"上(px)",left:"左(px)",bottom:"下(px)",right:"右(px)"},"image-position":{title:"位置",horizontal:"水平",vertical:"垂直",absolutePosition:"绝对位置(px)",relativePosition:"相对位置",toTheRightOf:"右侧",relativeTo:"相对于",bellow:"下方",options:"选项",moveObjectWithText:"对象随文字移动",column:"栏",margin:"页边距",page:"页面",line:"行",paragraph:"段落"},"update-status":{exceedMaxSize:"图片大小超过限制, 限制为{0}M",invalidImageType:"图片类型错误",exceedMaxCount:"图片只能一次上传{0}张",invalidImage:"无效图片"}}});
|
package/lib/umd/locale/zh-TW.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?module.exports=factory():typeof define=="function"&&define.amd?define(factory):(global=typeof globalThis<"u"?globalThis:global||self,global.UniverDocsDrawingUiZhTW=factory())})(this,function(){"use strict";return{docImage:{title:"圖片",upload:{float:"插入圖片"},panel:{title:"編圖"}},"image-popup":{replace:"替換",delete:"刪除",edit:"編輯",crop:"裁切",reset:"重置大小"},"image-text-wrap":{title:"文字环绕",wrappingStyle:"环绕方式",square:"四周型",topAndBottom:"上下型",inline:"嵌入型",behindText:"衬于文字下方",inFrontText:"浮于文字上方",wrapText:"自动换行",bothSide:"两侧",leftOnly:"左侧",rightOnly:"右侧",distanceFromText:"距正文",top:"上(px)",left:"左(px)",bottom:"下(px)",right:"右(px)"},"image-position":{title:"位置",horizontal:"水平",vertical:"垂直",absolutePosition:"绝对位置(px)",relativePosition:"相对位置",toTheRightOf:"右侧",relativeTo:"相对于",bellow:"下方",options:"选项",moveObjectWithText:"对象随文字移动",column:"栏",margin:"页边距",page:"页面",line:"行",paragraph:"段落"},"update-status":{exceedMaxSize:"圖片大小超過限制, 限制為{0}M",invalidImageType:"圖片類型錯誤",exceedMaxCount:"圖片只能一次上傳{0}張",invalidImage:"無效圖片"}}});
|