@univerjs/drawing-ui 0.2.3 → 0.2.4-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/index.js +1 -1
- package/lib/es/index.js +11 -13
- package/lib/types/controllers/drawing-ui.controller.d.ts +1 -2
- package/lib/types/plugin.d.ts +1 -2
- package/lib/umd/index.js +1 -1
- package/package.json +15 -17
package/lib/cjs/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var Qe=Object.defineProperty;var en=(a,t,n)=>t in a?Qe(a,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):a[t]=n;var Q=(a,t,n)=>en(a,typeof t!="symbol"?t+"":t,n);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const I=require("@univerjs/drawing"),b=require("@univerjs/engine-render"),v=require("@univerjs/core"),$=require("@wendellhu/redi/react-bindings"),i=require("react"),W=require("@univerjs/design"),U=require("clsx"),ee=require("@wendellhu/redi"),Se=require("@univerjs/ui"),Me=require("rxjs");function nn(a,t,n,e){const r=e.getDrawingByParam(a);if(r==null)return;const s=I.getDrawingShapeKeyByDrawingSearch(a),o=n.getObject(s);if(o&&!(o instanceof b.Group))return;if(o!=null){o.addObject(t);return}const c=new b.Group(s);n.addObject(c,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(c),c.addObject(t);const{transform:l}=r;l&&c.transformByState({left:l.left,top:l.top,angle:l.angle})}function ye(a){var r;const t=a.getFocusedUnit();if(t==null)return;const n=t.getUnitId();let e;return t.type===v.UniverInstanceType.UNIVER_SHEET?e=(r=t.getActiveSheet())==null?void 0:r.getSheetId():(t.type===v.UniverInstanceType.UNIVER_DOC||t.type===v.UniverInstanceType.UNIVER_SLIDE)&&(e=n),{unitId:n,subUnitId:e}}var tn=Object.defineProperty,rn=Object.getOwnPropertyDescriptor,an=(a,t,n,e)=>{for(var r=e>1?void 0:e?rn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&tn(t,n,r),r},De=(a,t)=>(n,e)=>t(n,e,a);exports.DrawingRenderService=class{constructor(t,n){this._drawingManagerService=t,this._imageIoService=n}async renderImage(t,n){const{transform:e,drawingType:r,source:s,imageSourceType:o,srcRect:c,prstGeom:l,groupId:g,unitId:u,subUnitId:d,drawingId:h}=t;if(r!==I.DrawingTypeEnum.DRAWING_IMAGE||!this._drawingManagerService.getDrawingVisible()||e==null)return;const{left:f,top:S,width:w,height:p,angle:D,flipX:_,flipY:O,skewX:y,skewY:N}=e,P=I.getDrawingShapeKeyByDrawingSearch({unitId:u,subUnitId:d,drawingId:h}),R=n.getObject(P);if(R!=null){R.transformByState({left:f,top:S,width:w,height:p,angle:D,flipX:_,flipY:O,skewX:y,skewY:N});return}const E=this._drawingManagerService.getDrawingOrder(u,d),T=E.indexOf(h),M={...e,zIndex:T===-1?E.length-1:T},j=this._imageIoService.getImageSourceCache(s,o);let L=!1;if(j!=null)M.image=j;else{if(o===I.ImageSourceType.UUID)try{M.url=await this._imageIoService.getImage(s)}catch(oe){console.error(oe);return}else M.url=s;L=!0}M.printable=!0;const k=new b.Image(P,M);if(L&&this._imageIoService.addImageSourceCache(s,o,k.getNative()),!this._drawingManagerService.getDrawingVisible())return;const z=n.addObject(k,b.DRAWING_OBJECT_LAYER_INDEX);return this._drawingManagerService.getDrawingEditable()&&z.attachTransformerTo(k),g&&nn({drawingId:g,unitId:u,subUnitId:d},k,n,this._drawingManagerService),l!=null&&k.setPrstGeom(l),c!=null&&k.setSrcRect(c),k}renderDrawing(t,n){const e=this._drawingManagerService.getDrawingByParam(t);if(e!=null)switch(e.drawingType){case I.DrawingTypeEnum.DRAWING_IMAGE:return this.renderImage(e,n)}}};exports.DrawingRenderService=an([De(0,I.IDrawingManagerService),De(1,I.IImageIoService)],exports.DrawingRenderService);function ue(a,t){const n=[];return a.forEach(e=>{const{oKey:r,left:s,top:o,height:c,width:l,angle:g}=e,u=t.getDrawingOKey(r);if(u==null)return n.push(null),!0;const{unitId:d,subUnitId:h,drawingId:f,drawingType:S}=u,w={unitId:d,subUnitId:h,drawingId:f,drawingType:S,transform:{left:s,top:o,height:c,width:l,angle:g}};S===I.DrawingTypeEnum.DRAWING_IMAGE&&(w.srcRect=e.srcRect),n.push(w)}),n}var K=function(){return K=Object.assign||function(a){for(var t,n=1,e=arguments.length;n<e;n++){t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(a[r]=t[r])}return a},K.apply(this,arguments)},on=function(a,t){var n={};for(var e in a)Object.prototype.hasOwnProperty.call(a,e)&&t.indexOf(e)<0&&(n[e]=a[e]);if(a!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,e=Object.getOwnPropertySymbols(a);r<e.length;r++)t.indexOf(e[r])<0&&Object.prototype.propertyIsEnumerable.call(a,e[r])&&(n[e[r]]=a[e[r]]);return n},q=i.forwardRef(function(a,t){var n=a.icon,e=a.id,r=a.className,s=a.extend,o=on(a,["icon","id","className","extend"]),c="univerjs-icon univerjs-icon-".concat(e," ").concat(r||"").trim(),l=i.useRef("_".concat(ln()));return Te(n,"".concat(e),{defIds:n.defIds,idSuffix:l.current},K({ref:t,className:c},o),s)});function Te(a,t,n,e,r){return i.createElement(a.tag,K(K({key:t},sn(a,n,r)),e),(cn(a,n).children||[]).map(function(s,o){return Te(s,"".concat(t,"-").concat(a.tag,"-").concat(o),n,void 0,r)}))}function sn(a,t,n){var e=K({},a.attrs);n!=null&&n.colorChannel1&&e.fill==="colorChannel1"&&(e.fill=n.colorChannel1);var r=t.defIds;return!r||r.length===0||(a.tag==="use"&&e["xlink:href"]&&(e["xlink:href"]=e["xlink:href"]+t.idSuffix),Object.entries(e).forEach(function(s){var o=s[0],c=s[1];typeof c=="string"&&(e[o]=c.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),e}function cn(a,t){var n,e=t.defIds;return!e||e.length===0?a:a.tag==="defs"&&(!((n=a.children)===null||n===void 0)&&n.length)?K(K({},a),{children:a.children.map(function(r){return typeof r.attrs.id=="string"&&e&&e.indexOf(r.attrs.id)>-1?K(K({},r),{attrs:K(K({},r.attrs),{id:r.attrs.id+t.idSuffix})}):r})}):a}function ln(){return Math.random().toString(36).substring(2,8)}q.displayName="UniverIcon";var mn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"colorChannel1",d:"M11.0363 12.2367V14.0367C11.0363 14.3681 11.3049 14.6367 11.6363 14.6367C11.9676 14.6367 12.2363 14.3681 12.2363 14.0367V12.2367H14.0364C14.3677 12.2367 14.6364 11.9681 14.6364 11.6367C14.6364 11.3054 14.3677 11.0367 14.0364 11.0367H12.2363V9.23672C12.2363 8.90535 11.9676 8.63672 11.6363 8.63672C11.3049 8.63672 11.0363 8.90535 11.0363 9.23672V11.0367H9.23635C8.90498 11.0367 8.63635 11.3054 8.63635 11.6367C8.63635 11.9681 8.90498 12.2367 9.23635 12.2367H11.0363Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.56365 1.36377C1.90091 1.36377 1.36365 1.90103 1.36365 2.56377V6.16377C1.36365 6.82651 1.90091 7.36377 2.56365 7.36377H6.16365C6.82639 7.36377 7.36365 6.82651 7.36365 6.16377V2.56377C7.36365 1.90103 6.82639 1.36377 6.16365 1.36377H2.56365zM6.16365 2.56377H2.56365L2.56365 6.16377H6.16365V2.56377zM2.56365 8.63647C1.90091 8.63647 1.36365 9.17373 1.36365 9.83647V13.4365C1.36365 14.0992 1.90091 14.6365 2.56365 14.6365H6.16365C6.82639 14.6365 7.36365 14.0992 7.36365 13.4365V9.83647C7.36365 9.17373 6.82639 8.63647 6.16365 8.63647H2.56365zM6.16365 9.83647H2.56365L2.56365 13.4365H6.16365V9.83647zM9.83635 7.36377C9.17361 7.36377 8.63635 6.82651 8.63635 6.16377V2.56377C8.63635 1.90103 9.17361 1.36377 9.83635 1.36377H13.4364C14.0991 1.36377 14.6364 1.90103 14.6364 2.56377V6.16377C14.6364 6.82651 14.0991 7.36377 13.4364 7.36377H9.83635zM9.83635 6.16377V2.56377L13.4364 2.56377V6.16377H9.83635z",fillRule:"evenodd",clipRule:"evenodd"}}]},Be=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"autofill",ref:t,icon:mn}))});Be.displayName="Autofill";var gn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.0045 4.4334C14.8881 4.4334 15.6045 3.71705 15.6045 2.8334 15.6045 1.94974 14.8881 1.2334 14.0045 1.2334H3.70449C2.82084 1.2334 2.10449 1.94974 2.10449 2.8334 2.10449 3.71705 2.82084 4.4334 3.70449 4.4334H14.0045zM14.4045 2.8334C14.4045 3.05431 14.2254 3.2334 14.0045 3.2334H3.70449C3.48358 3.2334 3.30449 3.05431 3.30449 2.8334 3.30449 2.61248 3.48358 2.4334 3.70449 2.4334H14.0045C14.2254 2.4334 14.4045 2.61249 14.4045 2.8334zM14.1544 8.5999C15.038 8.5999 15.7544 7.88356 15.7544 6.9999 15.7544 6.11625 15.038 5.3999 14.1544 5.3999H3.85439C2.97074 5.3999 2.25439 6.11625 2.25439 6.9999 2.25439 7.88356 2.97074 8.5999 3.85439 8.5999H14.1544zM14.5544 6.9999C14.5544 7.22082 14.3753 7.3999 14.1544 7.3999H3.85439C3.63348 7.3999 3.45439 7.22082 3.45439 6.9999 3.45439 6.77899 3.63348 6.5999 3.85439 6.5999H14.1544C14.3753 6.5999 14.5544 6.77899 14.5544 6.9999z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M8.57975 14.5902L6.58023 12.5907C6.34591 12.3564 6.34591 11.9765 6.58023 11.7421 6.81454 11.5078 7.19444 11.5078 7.42876 11.7421L8.40449 12.7179V10.1664C8.40449 9.83504 8.67312 9.56641 9.00449 9.56641 9.33586 9.56641 9.60449 9.83504 9.60449 10.1664V12.7179L10.5802 11.7421C10.8145 11.5078 11.1944 11.5078 11.4288 11.7421 11.6631 11.9765 11.6631 12.3564 11.4288 12.5907L9.42923 14.5902M8.57975 14.5902C8.58121 14.5917 8.58268 14.5931 8.58416 14.5946 8.64077 14.6502 8.70566 14.6923 8.77482 14.7209 8.84557 14.7502 8.92314 14.7664 9.00449 14.7664 9.08585 14.7664 9.16342 14.7502 9.23416 14.7209 9.30332 14.6923 9.36821 14.6502 9.42482 14.5946"}}]},Ue=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"bottom-single",ref:t,icon:gn}))});Ue.displayName="BottomSingle";var un={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.97705 7.51296C5.97705 7.18159 6.24568 6.91296 6.57705 6.91296H8.48632C8.81769 6.91296 9.08632 7.18159 9.08632 7.51296 9.08632 7.84433 8.81769 8.11296 8.48632 8.11296H6.57705C6.24568 8.11296 5.97705 7.84433 5.97705 7.51296zM6.57705 9.41028C6.24568 9.41028 5.97705 9.67891 5.97705 10.0103 5.97705 10.3416 6.24568 10.6103 6.57705 10.6103H10.8199C11.1512 10.6103 11.4199 10.3416 11.4199 10.0103 11.4199 9.67891 11.1512 9.41028 10.8199 9.41028H6.57705z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.51074 2.37063C3.51074 1.48697 4.22709 0.77063 5.11074 0.77063H9.80318L9.81294 0.770708C9.97168 0.768161 10.1311 0.82824 10.2511 0.95055L14.4317 5.21408C14.5165 5.30049 14.5697 5.406 14.5917 5.51645C14.6041 5.5644 14.6106 5.61467 14.6106 5.66648V11.6406C14.6106 12.5243 13.8943 13.2406 13.0106 13.2406H5.11074C4.22709 13.2406 3.51074 12.5243 3.51074 11.6406V2.37063ZM10.4032 4.66648V2.81964L12.6063 5.06648H10.8032C10.5823 5.06648 10.4032 4.88739 10.4032 4.66648ZM5.11074 1.97063C4.88983 1.97063 4.71074 2.14972 4.71074 2.37063V11.6406C4.71074 11.8615 4.88983 12.0406 5.11074 12.0406H13.0106C13.2316 12.0406 13.4106 11.8615 13.4106 11.6406V6.26648H10.8032C9.91953 6.26648 9.20318 5.55013 9.20318 4.66648V1.97063H5.11074Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.58916 6.6741C2.58916 6.34273 2.32053 6.0741 1.98916 6.0741C1.65779 6.0741 1.38916 6.34273 1.38916 6.6741V12.6294C1.38916 14.0653 2.55322 15.2294 3.98916 15.2294H9.41408C9.74545 15.2294 10.0141 14.9607 10.0141 14.6294C10.0141 14.298 9.74545 14.0294 9.41408 14.0294H3.98916C3.21596 14.0294 2.58916 13.4026 2.58916 12.6294V6.6741Z"}}]},je=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"create-copy-single",ref:t,icon:un}))});je.displayName="CreateCopySingle";var dn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.38125 1.16211C6.49759 1.16211 5.78125 1.87845 5.78125 2.76211V5.6377H2.87783C1.99418 5.6377 1.27783 6.35404 1.27783 7.2377V13.2377C1.27783 14.1214 1.99418 14.8377 2.87783 14.8377H8.87783C9.76149 14.8377 10.4778 14.1214 10.4778 13.2377V10.3621H13.3813C14.2649 10.3621 14.9813 9.64577 14.9813 8.76211V2.76211C14.9813 1.87845 14.2649 1.16211 13.3813 1.16211H7.38125ZM10.4778 9.16211H13.3813C13.6022 9.16211 13.7812 8.98302 13.7812 8.76211V2.76211C13.7812 2.5412 13.6022 2.36211 13.3813 2.36211H7.38125C7.16034 2.36211 6.98125 2.5412 6.98125 2.76211V5.6377H8.87783C9.76149 5.6377 10.4778 6.35404 10.4778 7.2377V9.16211ZM6.98125 6.8377H8.87783C9.09875 6.8377 9.27783 7.01678 9.27783 7.2377V9.16211H7.38125C7.16034 9.16211 6.98125 8.98302 6.98125 8.76211V6.8377ZM5.78125 6.8377V8.76211C5.78125 9.64577 6.49759 10.3621 7.38125 10.3621H9.27783V13.2377C9.27783 13.4586 9.09875 13.6377 8.87783 13.6377H2.87783C2.65692 13.6377 2.47783 13.4586 2.47783 13.2377V7.2377C2.47783 7.01678 2.65692 6.8377 2.87783 6.8377H5.78125Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Le=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"group-single",ref:t,icon:dn}))});Le.displayName="GroupSingle";var hn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M11.3536 6.14645C11.5488 6.34171 11.5488 6.65829 11.3536 6.85355L8.35355 9.85355C8.15829 10.0488 7.84171 10.0488 7.64645 9.85355L4.64645 6.85355C4.45118 6.65829 4.45118 6.34171 4.64645 6.14645C4.84171 5.95118 5.15829 5.95118 5.35355 6.14645L8 8.79289L10.6464 6.14645C10.8417 5.95118 11.1583 5.95118 11.3536 6.14645Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ae=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"more-down-single",ref:t,icon:hn}))});Ae.displayName="MoreDownSingle";var fn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 2.96401C1.25 3.84767 1.96634 4.56401 2.85 4.56401H13.15C14.0337 4.56401 14.75 3.84767 14.75 2.96401C14.75 2.08036 14.0337 1.36401 13.15 1.36401H2.85C1.96635 1.36401 1.25 2.08036 1.25 2.96401ZM2.85 3.36401C2.62909 3.36401 2.45 3.18493 2.45 2.96401C2.45 2.7431 2.62909 2.56401 2.85 2.56401H13.15C13.3709 2.56401 13.55 2.7431 13.55 2.96401C13.55 3.18493 13.3709 3.36401 13.15 3.36401H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 11.6118C5.80995 11.3774 6.18985 11.3774 6.42417 11.6118L7.3999 12.5875V6.36951C7.3999 6.03814 7.66853 5.76951 7.9999 5.76951C8.33127 5.76951 8.5999 6.03814 8.5999 6.36951V12.5875L9.57564 11.6118C9.80995 11.3774 10.1899 11.3774 10.4242 11.6118C10.6585 11.8461 10.6585 12.226 10.4242 12.4603L8.4324 14.452C8.32324 14.5655 8.16982 14.6362 7.9999 14.6362C7.82998 14.6362 7.67655 14.5655 7.56739 14.452L5.57564 12.4603C5.34132 12.226 5.34132 11.8461 5.57564 11.6118Z"}}]},He=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"move-down-single",ref:t,icon:fn}))});He.displayName="MoveDownSingle";var pn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 13.036C1.25 12.1523 1.96634 11.436 2.85 11.436H13.15C14.0337 11.436 14.75 12.1523 14.75 13.036C14.75 13.9196 14.0337 14.636 13.15 14.636H2.85C1.96635 14.636 1.25 13.9196 1.25 13.036ZM2.85 12.636C2.62909 12.636 2.45 12.8151 2.45 13.036C2.45 13.2569 2.62909 13.436 2.85 13.436H13.15C13.3709 13.436 13.55 13.2569 13.55 13.036C13.55 12.8151 13.3709 12.636 13.15 12.636H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 4.38825C5.80995 4.62256 6.18985 4.62256 6.42417 4.38825L7.3999 3.41251V9.63049C7.3999 9.96186 7.66853 10.2305 7.9999 10.2305C8.33127 10.2305 8.5999 9.96186 8.5999 9.63049V3.41251L9.57564 4.38825C9.80995 4.62256 10.1899 4.62256 10.4242 4.38825C10.6585 4.15393 10.6585 3.77403 10.4242 3.53972L8.4324 1.54796C8.32324 1.43445 8.16982 1.36382 7.9999 1.36382C7.82998 1.36382 7.67655 1.43446 7.56739 1.54797L5.57564 3.53972C5.34132 3.77403 5.34132 4.15393 5.57564 4.38825Z"}}]},Ge=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"move-up-single",ref:t,icon:pn}))});Ge.displayName="MoveUpSingle";var Cn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.82994 1.40913C7.88746 1.35161 7.95376 1.30821 8.02453 1.27893C8.09527 1.24959 8.17285 1.2334 8.2542 1.2334C8.33555 1.2334 8.41313 1.24959 8.48387 1.27893C8.55464 1.30821 8.62094 1.35161 8.67846 1.40913L10.6785 3.40913C10.9128 3.64345 10.9128 4.02335 10.6785 4.25766C10.4441 4.49198 10.0642 4.49198 9.82994 4.25766L8.8542 3.28193V5.8334C8.8542 6.16477 8.58557 6.4334 8.2542 6.4334C7.92283 6.4334 7.6542 6.16477 7.6542 5.8334V3.28193L6.67846 4.25766C6.44415 4.49198 6.06425 4.49198 5.82994 4.25766C5.59562 4.02335 5.59562 3.64345 5.82994 3.40913L7.82994 1.40913Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1.50439 9C1.50439 8.11634 2.22074 7.4 3.10439 7.4H13.4044C14.288 7.4 15.0044 8.11634 15.0044 9 15.0044 9.88366 14.2881 10.6 13.4044 10.6H3.1044C2.22074 10.6 1.50439 9.88366 1.50439 9zM3.10439 8.6C2.88348 8.6 2.70439 8.77909 2.70439 9 2.70439 9.22091 2.88348 9.4 3.1044 9.4H13.4044C13.6253 9.4 13.8044 9.22091 13.8044 9 13.8044 8.77909 13.6253 8.6 13.4044 8.6H3.10439zM1.6543 13.1665C1.6543 12.2828 2.37064 11.5665 3.2543 11.5665H13.5543C14.438 11.5665 15.1543 12.2828 15.1543 13.1665 15.1543 14.0502 14.438 14.7665 13.5543 14.7665H3.2543C2.37064 14.7665 1.6543 14.0502 1.6543 13.1665zM3.2543 12.7665C3.03338 12.7665 2.8543 12.9456 2.8543 13.1665 2.8543 13.3874 3.03338 13.5665 3.2543 13.5665H13.5543C13.7752 13.5665 13.9543 13.3874 13.9543 13.1665 13.9543 12.9456 13.7752 12.7665 13.5543 12.7665H3.2543z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ve=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"topmost-single",ref:t,icon:Cn}))});Ve.displayName="TopmostSingle";var wn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.46855 2.83731C7.46855 2.61639 7.64764 2.4373 7.86855 2.4373H13.8603C14.0812 2.4373 14.2603 2.61639 14.2603 2.8373V9.5049C14.2603 9.72581 14.0812 9.90489 13.8603 9.90489H12.866C12.5346 9.90489 12.266 10.1735 12.266 10.5049C12.266 10.8363 12.5346 11.1049 12.866 11.1049H13.8603C14.7439 11.1049 15.4603 10.3886 15.4603 9.5049V2.8373C15.4603 1.95365 14.7439 1.2373 13.8603 1.2373H7.86855C6.9849 1.2373 6.26855 1.95365 6.26855 2.83731V3.48688C6.26855 3.81825 6.53718 4.08688 6.86855 4.08688C7.19993 4.08688 7.46855 3.81825 7.46855 3.48688V2.83731Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.19888 5.56299C2.31522 5.56299 1.59888 6.27933 1.59888 7.16299V13.163C1.59888 14.0466 2.31522 14.763 3.19888 14.763H9.19888C10.0825 14.763 10.7989 14.0466 10.7989 13.163V7.16299C10.7989 6.27933 10.0825 5.56299 9.19888 5.56299H3.19888ZM2.79888 7.16299C2.79888 6.94207 2.97796 6.76299 3.19888 6.76299H9.19888C9.41979 6.76299 9.59888 6.94207 9.59888 7.16299V13.163C9.59888 13.3839 9.41979 13.563 9.19888 13.563H3.19888C2.97796 13.563 2.79888 13.3839 2.79888 13.163V7.16299Z",fillRule:"evenodd",clipRule:"evenodd"}}]},xe=i.forwardRef(function(a,t){return i.createElement(q,Object.assign({},a,{id:"ungroup-single",ref:t,icon:wn}))});xe.displayName="UngroupSingle";const vn="univer-image-common-panel",Sn="univer-image-common-panel-grid",_n="univer-image-common-panel-border",In="univer-image-common-panel-title",bn="univer-image-common-panel-subtitle",yn="univer-image-common-panel-row",Pn="univer-image-common-panel-row-vertical",En="univer-image-common-panel-column",Rn="univer-image-common-panel-column-center",Mn="univer-image-common-panel-inline",Dn="univer-image-common-panel-span2",On="univer-image-common-panel-span3",Nn="univer-image-common-panel-input",m={imageCommonPanel:vn,imageCommonPanelGrid:Sn,imageCommonPanelBorder:_n,imageCommonPanelTitle:In,imageCommonPanelSubtitle:bn,imageCommonPanelRow:yn,imageCommonPanelRowVertical:Pn,imageCommonPanelColumn:En,imageCommonPanelColumnCenter:Rn,imageCommonPanelInline:Mn,imageCommonPanelSpan2:Dn,imageCommonPanelSpan3:On,imageCommonPanelInput:Nn},Tn=a=>{const{arrangeShow:t,drawings:n}=a,e=$.useDependency(v.LocaleService),r=$.useDependency(I.IDrawingManagerService),s=g=>g?"block":"none",[o,c]=i.useState(n);i.useEffect(()=>{const g=r.focus$.subscribe(u=>{c(u)});return()=>{g.unsubscribe()}},[]);const l=g=>{const u=o[0].unitId,d=o[0].subUnitId,h=o.map(f=>f.drawingId);r.featurePluginOrderUpdateNotification({unitId:u,subUnitId:d,drawingIds:h,arrangeType:g})};return i.createElement("div",{className:m.imageCommonPanelGrid,style:{display:s(t)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,e.t("image-panel.arrange.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.forward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ge,null),e.t("image-panel.arrange.forward")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.backward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(He,null),e.t("image-panel.arrange.backward"))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.front)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ve,null),e.t("image-panel.arrange.front")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.back)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ue,null),e.t("image-panel.arrange.back"))))))},re=20,Bn=20,Un=[-3600,3600],he=300,jn=a=>{var Re;const t=$.useDependency(v.LocaleService),n=$.useDependency(I.IDrawingManagerService),e=$.useDependency(b.IRenderManagerService),{drawings:r,transformShow:s}=a,o=r[0];if(o==null)return;const c=o.transform;if(c==null)return;const{unitId:l,subUnitId:g,drawingId:u,drawingType:d}=o,h=e.getRenderById(l),f=h==null?void 0:h.scene;if(f==null)return;const S=(Re=f.getEngine())==null?void 0:Re.activeScene;if(S==null)return;const w=f.getTransformerByCreate(),{width:p=0,height:D=0,left:_=0,top:O=0,angle:y=0}=c,[N,P]=i.useState(p),[R,E]=i.useState(D),[T,M]=i.useState(_),[j,L]=i.useState(O),[k,z]=i.useState(y),[oe,ze]=i.useState(w.keepRatio),de=(C,V,x,G)=>{const{width:H,height:J}=S,{ancestorLeft:F,ancestorTop:Y}=f;let Z=C,X=V,ne=x,se=G;return C+F<0&&(Z=-F),V+Y<0&&(X=-Y),ne=H-Z-F,ne<re&&(ne=re),se=J-X-Y,se<re&&(se=re),C+ne+F>H&&(Z=H-x-F),V+se+Y>J&&(X=J-G-Y),{limitLeft:Z,limitTop:X,limitWidth:ne,limitHeight:se}},Ee=C=>{const{objects:V}=C,x=ue(V,n);if(x.length!==1)return;const G=x[0];if(G==null)return;const{transform:H}=G;if(H==null)return;const{width:J,height:F,left:Y,top:Z,angle:X}=H;J!=null&&P(J),F!=null&&E(F),Y!=null&&M(Y),Z!=null&&L(Z),X!=null&&z(X)};i.useEffect(()=>{const C=w.changeStart$.subscribe(G=>{Ee(G)}),V=w.changing$.subscribe(G=>{Ee(G)}),x=n.focus$.subscribe(G=>{if(G.length!==1)return;const H=n.getDrawingByParam(G[0]);if(H==null)return;const J=H.transform;if(J==null)return;const{width:F,height:Y,left:Z,top:X,angle:ne}=J;F!=null&&P(F),Y!=null&&E(Y),Z!=null&&M(Z),X!=null&&L(X),ne!=null&&z(ne)});return()=>{V.unsubscribe(),C.unsubscribe(),x.unsubscribe()}},[]);const Ke=v.debounce(C=>{if(C==null)return;C=Math.max(C,re);const{limitWidth:V,limitHeight:x}=de(T,j,C,R);C=Math.min(C,V);const G={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{width:C}};if(oe){let H=C/N*R;if(H=Math.max(H,Bn),H>x)return;E(H),G.transform.height=H}P(C),n.featurePluginUpdateNotification([G]),w.refreshControls().changeNotification()},he),Fe=v.debounce(C=>{if(C==null)return;C=Math.max(C,re);const{limitHeight:V,limitWidth:x}=de(T,j,N,C);C=Math.min(C,V);const G={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{height:C}};if(oe){let H=C/R*N;if(H=Math.max(H,re),H>x)return;P(H),G.transform.width=H}E(C),n.featurePluginUpdateNotification([G]),w.refreshControls().changeNotification()},he),Ye=v.debounce(C=>{if(C==null)return;const{limitLeft:V}=de(C,j,N,R);C=V;const x={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{left:C}};M(C),n.featurePluginUpdateNotification([x]),w.refreshControls().changeNotification()},he),Ze=v.debounce(C=>{if(C==null)return;const{limitTop:V}=de(T,C,N,R);C=V;const x={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{top:C}};L(C),n.featurePluginUpdateNotification([x]),w.refreshControls().changeNotification()},he),Xe=C=>{if(C==null)return;const[V,x]=Un;C<V&&(C=V),C>x&&(C=x);const G={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{angle:C}};z(C),n.featurePluginUpdateNotification([G]),w.refreshControls().changeNotification()},qe=C=>{ze(C),w.keepRatio=C},Je=C=>C?"block":"none";return i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:Je(s)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.transform.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.width"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:N,onChange:C=>{Ke(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.height"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:R,onChange:C=>{Fe(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.lock"))),i.createElement("div",{className:U(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.Checkbox,{checked:oe,onChange:qe})))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.x"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:T,onChange:C=>{Ye(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.y"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:j,onChange:C=>{Ze(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.rotate"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:k,onChange:Xe,className:m.imageCommonPanelInput})))))))};var B=(a=>(a.default="0",a.left="1",a.center="2",a.right="3",a.top="4",a.middle="5",a.bottom="6",a.horizon="7",a.vertical="8",a))(B||{});const Ie={id:"sheet.operation.set-image-align",type:v.CommandType.OPERATION,handler:(a,t)=>!0},Ln=a=>{const t=$.useDependency(v.ICommandService),n=$.useDependency(v.LocaleService),{alignShow:e}=a,[r,s]=i.useState(B.default),o=[{label:n.t("image-panel.align.default"),value:B.default},{options:[{label:n.t("image-panel.align.left"),value:B.left},{label:n.t("image-panel.align.center"),value:B.center},{label:n.t("image-panel.align.right"),value:B.right}]},{options:[{label:n.t("image-panel.align.top"),value:B.top},{label:n.t("image-panel.align.middle"),value:B.middle},{label:n.t("image-panel.align.bottom"),value:B.bottom}]},{options:[{label:n.t("image-panel.align.horizon"),value:B.horizon},{label:n.t("image-panel.align.vertical"),value:B.vertical}]}];function c(g){s(g),t.executeCommand(Ie.id,{alignType:g})}const l=g=>g?"block":"none";return i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:l(e)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.align.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn)},i.createElement(W.Select,{value:r,options:o,onChange:c}))))},_e={id:"sheet.operation.open-image-crop",type:v.CommandType.OPERATION,handler:(a,t)=>!0},te={id:"sheet.operation.close-image-crop",type:v.CommandType.OPERATION,handler:(a,t)=>!0};var A=(a=>(a.FREE="0",a.R1_1="1",a.R16_9="2",a.R9_16="3",a.R5_4="4",a.R4_5="5",a.R4_3="6",a.R3_4="7",a.R3_2="8",a.R2_3="9",a))(A||{});const ge={id:"sheet.operation.Auto-image-crop",type:v.CommandType.OPERATION,handler:(a,t)=>!0},An=a=>{const t=$.useDependency(v.ICommandService),n=$.useDependency(v.LocaleService),{drawings:e,cropperShow:r}=a;if(e[0]==null)return;const[o,c]=i.useState(A.FREE),l=i.useRef(!1),g=[{label:n.t("image-panel.crop.mode"),value:A.FREE},{label:"1:1",value:A.R1_1},{label:"16:9",value:A.R16_9},{label:"9:16",value:A.R9_16},{label:"5:4",value:A.R5_4},{label:"4:5",value:A.R4_5},{label:"4:3",value:A.R4_3},{label:"3:4",value:A.R3_4},{label:"3:2",value:A.R3_2},{label:"2:3",value:A.R2_3}];i.useEffect(()=>{const f=t.onCommandExecuted(S=>{if(S.id===te.id){const w=S.params;w!=null&&w.isAuto||(l.current=!1)}});return()=>{f==null||f.dispose()}},[]);function u(f){c(f),l.current&&t.executeCommand(ge.id,{cropType:f})}const d=f=>f?"block":"none",h=f=>{t.executeCommand(ge.id,{cropType:f}),l.current=!0};return i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:d(r)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.crop.title")))),i.createElement("div",{className:U(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{h(o)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(je,null),n.t("image-panel.crop.start")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Select,{value:o,options:g,onChange:u}))))},Hn=a=>{const t=$.useDependency(v.LocaleService),n=$.useDependency(b.IRenderManagerService),e=$.useDependency(I.IDrawingManagerService),{hasGroup:r,drawings:s}=a,[o,c]=i.useState(!1),[l,g]=i.useState(!0),[u,d]=i.useState(!0),h=p=>p?"block":"none",f=()=>{const p=e.getFocusDrawings(),{unitId:D,subUnitId:_}=p[0],O=v.Tools.generateRandomId(10),y=b.getGroupState(0,0,p.map(R=>R.transform||{})),N={unitId:D,subUnitId:_,drawingId:O,drawingType:I.DrawingTypeEnum.DRAWING_GROUP,transform:y},P=p.map(R=>{const E=R.transform||{left:0,top:0},{unitId:T,subUnitId:M,drawingId:j}=R;return{unitId:T,subUnitId:M,drawingId:j,transform:{...E,left:E.left-y.left,top:E.top-y.top},groupId:O}});e.featurePluginGroupUpdateNotification([{parent:N,children:P}])},S=p=>{if(p.drawingType!==I.DrawingTypeEnum.DRAWING_GROUP)return;const{unitId:D,subUnitId:_,drawingId:O,transform:y={width:0,height:0}}=p;if(y==null)return;const N=e.getDrawingsByGroup({unitId:D,subUnitId:_,drawingId:O});if(N.length===0)return;const P=N.map(R=>{const{transform:E}=R,{unitId:T,subUnitId:M,drawingId:j}=R,L=b.transformObjectOutOfGroup(E||{},y,y.width||0,y.height||0);return{unitId:T,subUnitId:M,drawingId:j,transform:{...E,...L},groupId:void 0}});return{parent:p,children:P}},w=()=>{const D=e.getFocusDrawings().map(_=>S(_)).filter(_=>_!=null);D.length!==0&&e.featurePluginUngroupUpdateNotification(D)};return i.useEffect(()=>{const p=s[0];if(p==null)return;const{unitId:D}=p,_=n.getRenderById(D),O=_==null?void 0:_.scene;if(O==null)return;const y=O.getTransformerByCreate(),N=y.clearControl$.subscribe(R=>{R===!0&&c(!1)}),P=y.changeStart$.subscribe(R=>{const{objects:E}=R,T=ue(E,e),M=T.filter(z=>(z==null?void 0:z.drawingType)===I.DrawingTypeEnum.DRAWING_GROUP);let j=!1,L=!1;T.length>1&&(j=!0),M.length>0&&(L=!0),c(j||L),g(j),d(L)});return()=>{P.unsubscribe(),N.unsubscribe()}},[]),i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:h(r===!0?o:!1)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.group.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement(W.Button,{size:"small",onClick:()=>{f()},style:{display:h(l)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Le,null),t.t("image-panel.group.group")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement(W.Button,{size:"small",onClick:()=>{w()},style:{display:h(u)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(xe,null),t.t("image-panel.group.unGroup"))))))},Gn=a=>{const t=$.useDependency(I.IDrawingManagerService),n=$.useDependency(b.IRenderManagerService),e=$.useDependency(v.LocaleService),{drawings:r,hasArrange:s=!0,hasTransform:o=!0,hasAlign:c=!0,hasCropper:l=!0,hasGroup:g=!0}=a,u=r[0];if(u==null)return;const{unitId:d}=u,h=n.getRenderById(d),f=h==null?void 0:h.scene;if(f==null)return;const S=f.getTransformerByCreate(),[w,p]=i.useState(!0),[D,_]=i.useState(!0),[O,y]=i.useState(!1),[N,P]=i.useState(!0),[R,E]=i.useState(!1);return i.useEffect(()=>{const T=S.clearControl$.subscribe(L=>{L===!0&&(p(!1),_(!1),y(!1),P(!1),E(!0))}),M=S.changeStart$.subscribe(L=>{const{objects:k}=L,z=ue(k,t);z.length===0?(p(!1),_(!1),y(!1),P(!1),E(!0)):z.length===1?(p(!0),_(!0),y(!1),P(!0),E(!1)):(p(!0),_(!1),y(!0),P(!1),E(!1))}),j=t.focus$.subscribe(L=>{L.length===0?(p(!1),_(!1),y(!1),P(!1),E(!0)):L.length===1?(p(!0),_(!0),y(!1),P(!0),E(!1)):(p(!0),_(!1),y(!0),P(!1),E(!1))});return()=>{M.unsubscribe(),T.unsubscribe(),j.unsubscribe()}},[]),i.createElement(i.Fragment,null,i.createElement("div",{style:{display:R===!0?"block":"none",height:"100%"}},i.createElement("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100%",top:"50%",marginTop:"-100px"}},i.createElement("span",null,e.t("image-panel.null")))),i.createElement(Tn,{arrangeShow:s===!0?w:!1,drawings:r}),i.createElement(jn,{transformShow:o===!0?D:!1,drawings:r}),i.createElement(Ln,{alignShow:c===!0?O:!1,drawings:r}),i.createElement(An,{cropperShow:l===!0?N:!1,drawings:r}),i.createElement(Hn,{hasGroup:g,drawings:r}))},Vn="univer-image-popup-menu",xn="univer-image-popup-menu-item",Wn="univer-image-popup-menu-item-icon",$n="univer-image-popup-menu-item-title",kn="univer-image-popup-menu-item-hide",zn="univer-btn-container",Kn="univer-btn-container-expand",ce={imagePopupMenu:Vn,imagePopupMenuItem:xn,imagePopupMenuItemIcon:Wn,imagePopupMenuItemTitle:$n,imagePopupMenuItemHide:kn,btnContainer:zn,btnContainerExpand:Kn},We=a=>{var S,w;const t=(w=(S=a.popup)==null?void 0:S.extraProps)==null?void 0:w.menuItems;if(!t)return null;const n=$.useDependency(v.ICommandService),e=$.useDependency(v.LocaleService),[r,s]=i.useState(!1),[o,c]=i.useState(!1),l=()=>{c(!0)},g=()=>{c(!1)},u=p=>{s(p)},d=p=>{n.executeCommand(p.commandId,p.commandParams),s(!1)},h=r||o,f=t.filter(p=>!p.disable);return i.createElement("div",{onMouseEnter:l,onMouseLeave:g},i.createElement(W.Dropdown,{placement:"bottomLeft",trigger:["click"],overlay:i.createElement("ul",{className:ce.imagePopupMenu},f.map(p=>i.createElement("li",{key:p.index,onClick:()=>d(p),className:ce.imagePopupMenuItem},i.createElement("span",{className:ce.imagePopupMenuItemTitle},e.t(p.label))))),visible:r,onVisibleChange:u},i.createElement("div",{className:U(ce.btnContainer,{[ce.btnContainerExpand]:r})},i.createElement(Be,{style:{color:"#35322B"},extend:{colorChannel1:"rgb(var(--green-700, #409f11))"}}),h&&i.createElement(Ae,{style:{color:"#CCCCCC",fontSize:"8px",marginLeft:"8px"}}))))},$e="COMPONENT_IMAGE_POPUP_MENU";var Fn=Object.defineProperty,Yn=Object.getOwnPropertyDescriptor,Zn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Yn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Fn(t,n,r),r},fe=(a,t)=>(n,e)=>t(n,e,a);let pe=class extends v.Disposable{constructor(t,n,e,r){super();Q(this,"_sceneListenerOnDrawingMap",new WeakSet);this._currentUniverService=t,this._commandService=n,this._renderManagerService=e,this._drawingManagerService=r,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._drawingRemoveListener(),this._drawingUpdateListener(),this._commandExecutedListener(),this._drawingArrangeListener(),this._drawingGroupListener(),this._drawingRefreshListener(),this._drawingVisibleListener()}_recoveryImages(){const t=this._drawingManagerService.drawingManagerData,n=ye(this._currentUniverService);if(n==null)return;const{unitId:e,subUnitId:r}=n;Object.keys(t).forEach(s=>{Object.keys(t[s]).forEach(o=>{const c=t[s][o].data;c==null||s!==e||o!==r||Object.keys(c).forEach(l=>{c[l]&&this._insertDrawing([{unitId:s,subUnitId:o,drawingId:l}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===Ie.id){const n=t.params;if(n==null)return;this._drawingAlign(n)}}))}_drawingGroupListener(){this.disposeWithMe(this._drawingManagerService.group$.subscribe(t=>{this._groupDrawings(t)})),this.disposeWithMe(this._drawingManagerService.ungroup$.subscribe(t=>{this._ungroupDrawings(t)}))}_getSceneAndTransformerByDrawingSearch(t){if(t==null)return;const n=this._renderManagerService.getRenderById(t),e=n==null?void 0:n.scene;if(e==null)return null;const r=e.getTransformerByCreate();return{scene:e,transformer:r}}_groupDrawings(t){t.forEach(n=>{this._groupDrawing(n)})}_groupDrawing(t){const{parent:n,children:e}=t,{unitId:r,subUnitId:s,drawingId:o}=n,c=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(c==null)return;const{scene:l,transformer:g}=c;this._commandService.syncExecuteCommand(te.id);const u=[];if(e.forEach(f=>{const S=I.getDrawingShapeKeyByDrawingSearch(f),w=l.getObjectIncludeInGroup(S);if(w==null||u.includes(w))return;u.push(w);const{transform:p}=f;p!=null&&(w.classType===b.RENDER_CLASS_TYPE.GROUP?w.transformByState({left:p.left,top:p.top}):w.transformByState(p))}),u.length===0)return;const d=I.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),h=new b.Group(d);l.addObject(h,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(h),h.addObjects(...u),n.transform&&h.transformByState({left:n.transform.left,top:n.transform.top}),g.clearSelectedObjects(),g.setSelectedControl(h)}_ungroupDrawings(t){t.forEach(n=>{this._ungroupDrawing(n)})}_ungroupDrawing(t){const{parent:n,children:e}=t,r=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(r==null)return;const{scene:s,transformer:o}=r;e.forEach(d=>{const h=I.getDrawingShapeKeyByDrawingSearch(d),f=s.getObjectIncludeInGroup(h);if(f==null)return!0;if(f==null)return;const{transform:S}=d;S!=null&&(f.classType===b.RENDER_CLASS_TYPE.GROUP?f.transformByState({left:S.left,top:S.top}):f.transformByState(S))});const c=I.getDrawingShapeKeyByDrawingSearch(n),l=s.getObject(c),{width:g,height:u}=l;l.getObjects().forEach(d=>{l.removeSelfObjectAndTransform(d.oKey,g,u)}),l.dispose(),o.clearSelectedObjects()}_drawingAlign(t){const{alignType:n}=t,e=this._drawingManagerService.getFocusDrawings();if(n===B.default)return;const r=[];let s=Number.POSITIVE_INFINITY,o=Number.POSITIVE_INFINITY,c=Number.NEGATIVE_INFINITY,l=Number.NEGATIVE_INFINITY,g=0;e.forEach(u=>{const{unitId:d,subUnitId:h,drawingId:f,drawingType:S}=u,w=this._drawingManagerService.getDrawingByParam({unitId:d,subUnitId:h,drawingId:f});if(w==null||w.transform==null)return;r.push({unitId:d,subUnitId:h,drawingId:f,drawingType:S,transform:w.transform});const{left:p=0,top:D=0,width:_=0,height:O=0}=w.transform;s=Math.min(s,p),o=Math.min(o,D),c=Math.max(c,p+_),l=Math.max(l,D+O),g++}),g!==0&&(this._sortDrawingTransform(r,n),this._applyAlignType(r,n,s,o,c,l,g))}_applyAlignType(t,n,e,r,s,o,c){const l=Math.round((s-e)/c*10)/10,g=Math.round((o-r)/c*10)/10,u=[],d=this._getSceneAndTransformerByDrawingSearch(t[0].unitId);if(d==null)return;const{scene:h,transformer:f}=d;t.forEach((S,w)=>{const{unitId:p,subUnitId:D,drawingId:_,transform:O,drawingType:y}=S,{left:N=0,top:P=0,width:R=0,height:E=0}=O;let T=N,M=P;switch(n){case B.left:T=e;break;case B.center:T=e+(s-e)/2-R/2;break;case B.right:T=s-R;break;case B.top:M=r;break;case B.middle:M=r+(o-r)/2-E/2;break;case B.bottom:M=o-E;break;case B.horizon:T=e+l*w;break;case B.vertical:M=r+g*w;break}(T!==N||M!==P)&&u.push({unitId:p,subUnitId:D,drawingId:_,drawingType:y,transform:{left:T,top:M}})}),this._drawingManagerService.featurePluginUpdateNotification(u),f.refreshControls().changeNotification()}_sortDrawingTransform(t,n){t.sort((e,r)=>{const s=e.transform,o=r.transform,{left:c=0,top:l=0,width:g=0,height:u=0}=s,{left:d=0,top:h=0,width:f=0,height:S=0}=o;switch(n){case B.left:return c-d;case B.center:return c+g/2-(d+f/2);case B.right:return c+g-(d+f);case B.top:return l-h;case B.middle:return l+u/2-(h+S/2);case B.bottom:return l+u-(h+S);case B.horizon:return c+g/2-(d+f/2);case B.vertical:return l+u/2-(h+S/2);default:return 0}})}_drawingArrangeListener(){this.disposeWithMe(this._drawingManagerService.order$.subscribe(t=>{this._drawingArrange(t)}))}_drawingArrange(t){const{unitId:n,subUnitId:e,drawingIds:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n);if(s==null)return;const{scene:o,transformer:c}=s;r.forEach(l=>{const g=I.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:l}),u=o.getObject(g);if(u==null)return;const d=this._drawingManagerService.getDrawingOrder(n,e).indexOf(l);u.setProps({zIndex:d}),u.makeDirty()})}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(t=>{this._insertDrawing(t)}))}_insertDrawing(t){const n=[];t.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e;if(this._drawingManagerService.getDrawingByParam(e)==null)return;const l=this._getSceneAndTransformerByDrawingSearch(r);if(l==null)return;const{scene:g,transformer:u}=l;n.includes(g)||n.push(g)}),n.forEach(e=>{this._sceneListenerOnDrawingMap.has(e)||(this._addListenerOnDrawing(e),this._sceneListenerOnDrawingMap.add(e))})}_drawingRemoveListener(){this.disposeWithMe(this._drawingManagerService.remove$.subscribe(t=>{t.forEach(n=>{var d;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:c,transformer:l}=o,g=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),u=c.getObject(g);u!=null&&(u.dispose(),(d=c.getTransformer())==null||d.clearSelectedObjects())})}))}_drawingUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._drawingManagerService.getDrawingByParam(n);if(o==null)return;const{transform:c,drawingType:l}=o,g=this._getSceneAndTransformerByDrawingSearch(e);if(g==null)return;const{scene:u,transformer:d}=g;if(c==null)return!0;const{left:h=0,top:f=0,width:S=0,height:w=0,angle:p=0,flipX:D=!1,flipY:_=!1,skewX:O=0,skewY:y=0}=c,N=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),P=u.getObject(N);if(P==null)return!0;P.transformByState({left:h,top:f,width:S,height:w,angle:p,flipX:D,flipY:_,skewX:O,skewY:y})})}))}_drawingRefreshListener(){this.disposeWithMe(this._drawingManagerService.refreshTransform$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:c,transformer:l}=o,g=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),u=c.getObject(g);if(u==null)return!0;const d=this._drawingManagerService.getDrawingByParam(n);if(d==null)return;const{transform:h}=d;if(h==null)return!0;const{left:f=0,top:S=0,width:w=0,height:p=0,angle:D=0,flipX:_=!1,flipY:O=!1,skewX:y=0,skewY:N=0}=h;u.transformByState({left:f,top:S,width:w,height:p,angle:D,flipX:_,flipY:O,skewX:y,skewY:N})})}))}_drawingVisibleListener(){this.disposeWithMe(this._drawingManagerService.visible$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s,visible:o}=n,c=this._getSceneAndTransformerByDrawingSearch(e);if(c==null)return;const{scene:l,transformer:g}=c,u=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),d=l.getObject(u);if(d==null)return!0;o?d.show():d.hide()})}))}_filterUpdateParams(t,n){return t.filter((e,r)=>{if(e==null)return!1;const{transform:s}=e;return v.checkIfMove(s,n==null?void 0:n[r])})}_addListenerOnDrawing(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(v.toDisposable(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=Array.from(s.values()),c=[];e=o.map(l=>{const{left:g,top:u,height:d,width:h,angle:f,oKey:S,groupKey:w,isInGroup:p}=l,D=this._drawingManagerService.getDrawingOKey(S);if(p||l instanceof b.Group){let _=l.ancestorGroup;if(_==null&&l instanceof b.Group&&(_=l),_==null)return null;const O=this._drawingManagerService.getDrawingOKey(_.oKey);if(O){const{unitId:y,subUnitId:N,drawingId:P}=O;c.push({unitId:y,subUnitId:N,drawingId:P});const{left:R,top:E,height:T,width:M,angle:j}=_;return{left:R,top:E,height:T,width:M,angle:j}}}else if(D!=null){const{unitId:_,subUnitId:O,drawingId:y}=D;return c.push({unitId:_,subUnitId:O,drawingId:y}),{left:g,top:u,height:d,width:h,angle:f}}return null}).filter(l=>l!=null),c.length>0?this._drawingManagerService.focusDrawing(c):this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(v.toDisposable(n.changeEnd$.subscribe(r=>{const{objects:s}=r;this._filterUpdateParams(ue(s,this._drawingManagerService),e).length>0})))}};pe=Zn([v.OnLifecycle(v.LifecycleStages.Rendered,pe),fe(0,v.IUniverInstanceService),fe(1,v.ICommandService),fe(2,b.IRenderManagerService),fe(3,I.IDrawingManagerService)],pe);const Xn=a=>{const{src:t}=a;return t?i.createElement("div",null,i.createElement("img",{src:t,alt:"Univer Image Viewer",style:{width:"100%",height:"100%",position:"relative"}})):null},ke="COMPONENT_IMAGE_VIEWER",Pe={id:"sheet.operation.image-reset-size",type:v.CommandType.OPERATION,handler:(a,t)=>!0};var qn=Object.defineProperty,Jn=Object.getOwnPropertyDescriptor,Qn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Jn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&qn(t,n,r),r},le=(a,t)=>(n,e)=>t(n,e,a);let Ce=class extends v.Disposable{constructor(a,t,n,e,r){super(),this._injector=a,this._componentManager=t,this._menuService=n,this._commandService=e,this._localeService=r,this._init()}_initCustomComponents(){const a=this._componentManager;this.disposeWithMe(a.register($e,We)),this.disposeWithMe(a.register(ke,Xn))}_initMenus(){}_initCommands(){[_e,te,Pe,Ie,ge].forEach(a=>this.disposeWithMe(this._commandService.registerCommand(a)))}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus()}};Ce=Qn([v.OnLifecycle(v.LifecycleStages.Rendered,Ce),le(0,ee.Inject(ee.Injector)),le(1,ee.Inject(Se.ComponentManager)),le(2,Se.IMenuService),le(3,v.ICommandService),le(4,ee.Inject(v.LocaleService))],Ce);class me extends b.Shape{constructor(n,e){e==null&&(e={}),e.transformerConfig={keepRatio:!1,isCropper:!0,anchorFill:"rgb(0, 0, 0)",anchorStroke:"rgb(255, 255, 255)",anchorSize:24};super(n,e);Q(this,"_srcRect");Q(this,"_prstGeom");Q(this,"_applyTransform");Q(this,"_dragPadding",8);Q(this,"_cacheCanvas");e!=null&&e.srcRect&&(this._srcRect=e.srcRect),e!=null&&e.prstGeom&&(this._prstGeom=e.prstGeom),e!=null&&e.applyTransform&&(this._applyTransform=e.applyTransform),e!=null&&e.dragPadding&&(this._dragPadding=e.dragPadding),this._applyProps()}refreshSrcRect(n,e){this._srcRect=n,this._applyTransform=e,this._applyProps()}get srcRect(){return this._srcRect}dispose(){var n;super.dispose(),(n=this._cacheCanvas)==null||n.dispose(),this._srcRect=null}isHit(n){const e=this.getInverseCoord(n);return e.x>=-this.strokeWidth/2&&e.x<=this.width+this.strokeWidth/2&&e.y>=-this.strokeWidth/2&&e.y<=this.height+this.strokeWidth/2&&!this._inSurround(e)}_inSurround(n){const e=this._dragPadding;return n.x>=e-this.strokeWidth/2&&n.x<=this.width+this.strokeWidth/2-e&&n.y>=e-this.strokeWidth/2&&n.y<=this.height+this.strokeWidth/2-e}render(n,e){return this.visible?(n.save(),this._draw(n),n.restore(),this.makeDirty(!1),this):(this.makeDirty(!1),this)}_draw(n){var l,g;const r=this.getScene().getEngine(),{width:s,height:o}=r;this._initialCacheCanvas(),(l=this._cacheCanvas)==null||l.clear();const c=(g=this._cacheCanvas)==null?void 0:g.getContext();c!=null&&(c.save(),b.Rect.drawWith(c,{left:0,top:0,width:s,height:o,fill:"rgba(0, 0, 0, 0.5)"}),c.setTransform(n.getTransform()),this._clipForApplyObject(c),this._applyCache(n),c.restore())}_clipForApplyObject(n){let e=0;if(this._prstGeom!=null&&(e=1),n.globalCompositeOperation="destination-out",n.beginPath(),e===0){const r=this.transform.getMatrix();n.transform(r[0],r[1],r[2],r[3],r[4],r[5]),n.rect(0,0,this.width,this.height),n.fill()}}_applyProps(){if(this._applyTransform==null)return;let n=0,e=0,r=0,s=0;const{left:o=0,top:c=0,width:l=0,height:g=0,angle:u}=this._applyTransform;if(this._srcRect!=null){const{left:f=0,top:S=0,right:w=0,bottom:p=0}=this._srcRect;n=f,e=S,r=w,s=p}const d=o+n,h=c+e;this.transformByState({left:d,top:h,width:o+l-r-d,height:c+g-s-h,angle:u})}_applyCache(n){if(!n||this._cacheCanvas==null)return;const e=this._cacheCanvas.getContext();e.save(),n.save(),n.setTransform(1,0,0,1,0,0),e.setTransform(1,0,0,1,0,0),n.drawImage(this._cacheCanvas.getCanvasEle(),0,0),n.restore(),e.restore()}_initialCacheCanvas(){if(this._cacheCanvas!=null)return;this._cacheCanvas=new b.Canvas;const n=this.getScene().getEngine();this._cacheCanvas.setSize(n.width,n.height),n.onTransformChange$.subscribeEvent(()=>{var e;(e=this._cacheCanvas)==null||e.setSize(n.width,n.height),this.makeDirty(!0)})}}var et=Object.defineProperty,nt=Object.getOwnPropertyDescriptor,tt=(a,t,n,e)=>{for(var r=e>1?void 0:e?nt(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&et(t,n,r),r},ie=(a,t)=>(n,e)=>t(n,e,a);let we=class extends v.Disposable{constructor(t,n,e,r,s,o){super();Q(this,"_sceneListenerOnImageMap",new WeakSet);this._commandService=t,this._drawingManagerService=n,this._renderManagerService=e,this._univerInstanceService=r,this._messageService=s,this._localeService=o,this._init()}_init(){this._initOpenCrop(),this._initCloseCrop(),this._initAutoCrop()}_initAutoCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==ge.id)return;const n=t.params;if(n==null)return;const{cropType:e}=n,r=this._drawingManagerService.getFocusDrawings();if(r.length!==1)return;const s=r[0],{unitId:o,subUnitId:c,drawingId:l}=s,g=this._renderManagerService.getRenderById(o),u=g==null?void 0:g.scene;if(u==null)return!0;this._searchCropObject(u)!=null&&this._commandService.syncExecuteCommand(te.id,{isAuto:!0});const h=I.getDrawingShapeKeyByDrawingSearch({unitId:o,subUnitId:c,drawingId:l}),f=u.getObject(h);if(!(f instanceof b.Image)){this._messageService.show({type:W.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}f!=null&&(this._updateCropperObject(e,f),this._commandService.executeCommand(_e.id,{unitId:o,subUnitId:c,drawingId:l}))}))}_calculateSrcRectByRatio(t,n,e,r,s,o){const c=e/r,l=s/o;let g=e,u=r;c>l?g=r*l:u=e/l;const d=(e-g)/2,h=(r-u)/2;return{left:b.precisionTo(d,1),top:b.precisionTo(h,1),right:b.precisionTo(e-(d+g),1),bottom:b.precisionTo(r-(h+u),1)}}_updateCropperObject(t,n){const{left:e,top:r,width:s,height:o}=n.calculateTransformWithSrcRect();let c;switch(t){case A.R1_1:c=this._calculateSrcRectByRatio(e,r,s,o,1,1);break;case A.R16_9:c=this._calculateSrcRectByRatio(e,r,s,o,16,9);break;case A.R9_16:c=this._calculateSrcRectByRatio(e,r,s,o,9,16);break;case A.R5_4:c=this._calculateSrcRectByRatio(e,r,s,o,5,4);break;case A.R4_5:c=this._calculateSrcRectByRatio(e,r,s,o,4,5);break;case A.R4_3:c=this._calculateSrcRectByRatio(e,r,s,o,4,3);break;case A.R3_4:c=this._calculateSrcRectByRatio(e,r,s,o,3,4);break;case A.R3_2:c=this._calculateSrcRectByRatio(e,r,s,o,3,2);break;case A.R2_3:c=this._calculateSrcRectByRatio(e,r,s,o,2,3);break;case A.FREE:}if(c==null)return;n.setSrcRect(c);const{left:l=0,top:g=0,bottom:u=0,right:d=0}=c;n.transformByStateCloseCropper({left:e+l,top:r+g,width:s-d-l,height:o-u-g})}_initOpenCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==_e.id)return;const n=t.params;if(n==null)return;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._renderManagerService.getRenderById(e),c=o==null?void 0:o.scene;if(c==null)return!0;if(this._sceneListenerOnImageMap.has(c)||(this._addListenerOnImage(c),this._sceneListenerOnImageMap.add(c)),this._drawingManagerService.getDrawingByParam({unitId:e,subUnitId:r,drawingId:s})==null)return;const g=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),u=c.getObject(g);if(u==null)return;if(!(u instanceof b.Image)){this._messageService.show({type:W.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}const d=c.getTransformer();d==null||d.clearControls();const h=new me(`${g}-crop`,{srcRect:u.srcRect,prstGeom:u.prstGeom,applyTransform:u.calculateTransformWithSrcRect()});c.addObject(h,u.getLayerIndex()+1).attachTransformerTo(h),d==null||d.createControlForCopper(h),this._addHoverForImageCopper(h),u.openRenderByCropper(),d==null||d.refreshControls(),h.makeDirty(!0),this._drawingManagerService.focusDrawing([{unitId:e,subUnitId:r,drawingId:s}])}))}_searchCropObject(t){const n=t.getAllObjects();for(const e of n)if(e instanceof me)return e}_initCloseCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(n.id!==te.id)return;const e=this._univerInstanceService.getFocusedUnit();if(e==null)return;const r=e.getUnitId(),s=this._renderManagerService.getRenderById(r),o=s==null?void 0:s.scene;if(o==null)return!0;const c=this._searchCropObject(o);if(c==null)return;const l=this._getApplyObjectByCropObject(c);if(l==null)return;const g=o.getTransformerByCreate();g.detachFrom(c),g.clearCopperControl();const u=this._getSrcRectByTransformState(l,c),d=this._drawingManagerService.getDrawingOKey(l.oKey);if(d!=null){const{left:h,top:f,height:S,width:w}=c;this._drawingManagerService.featurePluginUpdateNotification([{...d,transform:{...d.transform,left:h,top:f,height:S,width:w},srcRect:u.srcRectAngle}])}l.setSrcRect({...u.srcRectAngle}),l.closeRenderByCropper(),l.makeDirty(!0),c==null||c.dispose()}));const t=this._univerInstanceService.getCurrentTypeOfUnit$(v.UniverInstanceType.UNIVER_SHEET).pipe(Me.filter(n=>!!n),Me.switchMap(n=>n.activeSheet$));this.disposeWithMe(t.subscribe(()=>{this._commandService.syncExecuteCommand(te.id)}))}_getApplyObjectByCropObject(t){const n=t.oKey,e=n.slice(0,n.length-5),r=t.getScene().getObject(e);return r==null?null:r}_addListenerOnImage(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof me))return;const{left:c,top:l,height:g,width:u,angle:d}=o;e={left:c,top:l,height:g,width:u,angle:d},n.clearCopperControl()})),this.disposeWithMe(n.changeEnd$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof me))return;const{left:c,top:l,height:g,width:u,angle:d}=o;if(!v.checkIfMove({left:c,top:l,height:g,width:u,angle:d},e))return;const h=this._getApplyObjectByCropObject(o);if(h==null)return;const f=this._getSrcRectByTransformState(h,o);o.refreshSrcRect(f.srcRect,h.getState()),n.createControlForCopper(o)})),this._endCropListener(t)}_addHoverForImageCopper(t){this.disposeWithMe(t.onPointerEnter$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.MOVE})),this.disposeWithMe(t.onPointerLeave$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.DEFAULT}))}_endCropListener(t){const n=t.getTransformerByCreate();this.disposeWithMe(n.clearControl$.subscribe(e=>{e===!0&&this._commandService.syncExecuteCommand(te.id)}))}_getSrcRectByTransformState(t,n){const{left:e,top:r,height:s,width:o,strokeWidth:c,angle:l}=n,{left:g,top:u,width:d,height:h,angle:f,strokeWidth:S}=t,w=e-g,p=r-u,D={left:w,top:p,right:d-w-o,bottom:h-p-s},_={...D};if(f!==0){const O=e+o/2,y=r+s/2,N=new b.Vector2(O,y),P=d/2+g,R=h/2+u,E=new b.Vector2(P,R),T=new b.Vector2(g,u);T.rotateByPoint(b.degToRad(f),E);const M=T.clone();M.rotateByPoint(b.degToRad(-f),N);const j=e-M.x,L=r-M.y;_.left=j,_.top=L,_.right=d-j-o,_.bottom=h-L-s}return{srcRect:D,srcRectAngle:_}}};we=tt([v.OnLifecycle(v.LifecycleStages.Rendered,we),ie(0,v.ICommandService),ie(1,I.IDrawingManagerService),ie(2,b.IRenderManagerService),ie(3,v.IUniverInstanceService),ie(4,Se.IMessageService),ie(5,ee.Inject(v.LocaleService))],we);var rt=Object.defineProperty,at=Object.getOwnPropertyDescriptor,it=(a,t,n,e)=>{for(var r=e>1?void 0:e?at(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&rt(t,n,r),r},ae=(a,t)=>(n,e)=>t(n,e,a);const Oe=50;let ve=class extends v.Disposable{constructor(a,t,n,e,r,s,o){super(),this._commandService=a,this._renderManagerService=t,this._drawingManagerService=n,this._dialogService=e,this._imageIoService=r,this._currentUniverService=s,this._drawingRenderService=o,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._commandExecutedListener(),this._imageUpdateListener()}_recoveryImages(){const a=this._drawingManagerService.drawingManagerData,t=ye(this._currentUniverService);if(t==null)return;const{unitId:n,subUnitId:e}=t;Object.keys(a).forEach(r=>{Object.keys(a[r]).forEach(s=>{const o=a[r][s].data;o==null||r!==n||s!==e||Object.keys(o).forEach(c=>{o[c]&&this._insertImages([{unitId:r,subUnitId:s,drawingId:c}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(a=>{if(a.id===Pe.id){const t=a.params;if(t==null)return;this._resetImageSize(t)}}))}_getSceneAndTransformerByDrawingSearch(a){if(a==null)return;const t=this._renderManagerService.getRenderById(a),n=t==null?void 0:t.scene;if(n==null)return null;const e=n.getTransformerByCreate();return{scene:n,transformer:e}}_resetImageSize(a){const t=[],n=[];a.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e,c=this._getSceneAndTransformerByDrawingSearch(r);if(c==null)return;const{scene:l}=c,g=I.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),u=l.getObject(g);if(u==null)return!0;const d=this._drawingManagerService.getDrawingByParam(e);if(d==null)return!0;if(d.drawingType!==I.DrawingTypeEnum.DRAWING_IMAGE)return;u.resetSize();const{width:h,height:f}=u.getNativeSize();n.includes(l)===!1&&n.push(l),t.push({...d,transform:{...d.transform,height:f,width:h,angle:0},srcRect:null,prstGeom:null})}),this._drawingManagerService.featurePluginUpdateNotification(t),n.forEach(e=>{e.getTransformerByCreate().refreshControls().changeNotification()}),this._drawingManagerService.focusDrawing(a)}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(a=>{this._insertImages(a)}))}_insertImages(a){a.forEach(async t=>{var g;const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n),o=(g=ye(this._currentUniverService))==null?void 0:g.subUnitId;if(s==null||o!==e)return;const c=this._drawingManagerService.getDrawingByParam(t);if(c==null)return;const l=await this._drawingRenderService.renderImage(c,s.scene);l!=null&&(this._addHoverForImage(l),this._addDialogForImage(l))})}_imageUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(a=>{a.forEach(t=>{const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._drawingManagerService.getDrawingByParam(t);if(s==null)return;const{transform:o,drawingType:c,srcRect:l,prstGeom:g,source:u,imageSourceType:d}=s;if(c!==I.DrawingTypeEnum.DRAWING_IMAGE)return;const h=this._getSceneAndTransformerByDrawingSearch(n);if(h==null)return;const{scene:f,transformer:S}=h;if(o==null)return!0;const w=I.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:r}),p=f.getObject(w);if(p==null)return!0;p.setSrcRect(l),p.setPrstGeom(g)})}))}_addHoverForImage(a){this.disposeWithMe(v.toDisposable(a.onPointerEnter$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.GRAB}))),this.disposeWithMe(v.toDisposable(a.onPointerLeave$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.DEFAULT})))}_addDialogForImage(a){this.disposeWithMe(v.toDisposable(a.onDblclick$.subscribeEvent(()=>{var c;const t=`${a.oKey}-viewer-dialog`,n=a.getNativeSize(),e=window.innerWidth-Oe,r=window.innerHeight-Oe,s=this._adjustImageSize(n.width,n.height,e,r),o=this._dialogService.open({width:s.width,id:t,style:{margin:"0",top:"50%",left:"50%",transform:"translate(-50%, -50%)"},children:{label:{name:ke,props:{src:(c=a.getNative())==null?void 0:c.src,width:s.width,height:s.height}}},destroyOnClose:!0,draggable:!1,onClose:()=>{this._dialogService.close(t),o.dispose()}})})))}_adjustImageSize(a,t,n,e){if(a<=n&&t<=e)return{width:a,height:t};const r=n/a,s=e/t,o=Math.min(r,s);return{width:Math.floor(a*o),height:Math.floor(t*o)}}};ve=it([v.OnLifecycle(v.LifecycleStages.Rendered,ve),ae(0,v.ICommandService),ae(1,b.IRenderManagerService),ae(2,I.IDrawingManagerService),ae(3,Se.IDialogService),ae(4,I.IImageIoService),ae(5,v.IUniverInstanceService),ae(6,ee.Inject(exports.DrawingRenderService))],ve);var ot=Object.defineProperty,st=Object.getOwnPropertyDescriptor,ct=(a,t,n,e)=>{for(var r=e>1?void 0:e?st(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&ot(t,n,r),r},Ne=(a,t)=>(n,e)=>t(n,e,a);const lt="DRAWING_UI_PLUGIN";var be;exports.UniverDrawingUIPlugin=(be=class extends v.Plugin{constructor(t,n,e){super(),this._injector=n,this._localeService=e}onStarting(t){this._initDependencies(t)}_initDependencies(t){[[exports.DrawingRenderService],[pe],[Ce],[we],[ve]].forEach(e=>t.add(e))}},Q(be,"pluginName",lt),be);exports.UniverDrawingUIPlugin=ct([Ne(1,ee.Inject(ee.Injector)),Ne(2,ee.Inject(v.LocaleService))],exports.UniverDrawingUIPlugin);exports.AutoImageCropOperation=ge;exports.COMPONENT_IMAGE_POPUP_MENU=$e;exports.CloseImageCropOperation=te;exports.DrawingCommonPanel=Gn;exports.ImageCropperObject=me;exports.ImagePopupMenu=We;exports.ImageResetSizeOperation=Pe;exports.OpenImageCropOperation=_e;exports.SetDrawingAlignOperation=Ie;exports.getUpdateParams=ue;
|
|
1
|
+
"use strict";var qe=Object.defineProperty;var Je=(a,t,n)=>t in a?qe(a,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):a[t]=n;var J=(a,t,n)=>Je(a,typeof t!="symbol"?t+"":t,n);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const I=require("@univerjs/drawing"),b=require("@univerjs/engine-render"),h=require("@univerjs/core"),i=require("react"),W=require("@univerjs/design"),U=require("clsx"),we=require("@univerjs/ui"),Ee=require("rxjs");function Qe(a,t,n,e){const r=e.getDrawingByParam(a);if(r==null)return;const s=I.getDrawingShapeKeyByDrawingSearch(a),o=n.getObject(s);if(o&&!(o instanceof b.Group))return;if(o!=null){o.addObject(t);return}const c=new b.Group(s);n.addObject(c,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(c),c.addObject(t);const{transform:l}=r;l&&c.transformByState({left:l.left,top:l.top,angle:l.angle})}function Ie(a){var r;const t=a.getFocusedUnit();if(t==null)return;const n=t.getUnitId();let e;return t.type===h.UniverInstanceType.UNIVER_SHEET?e=(r=t.getActiveSheet())==null?void 0:r.getSheetId():(t.type===h.UniverInstanceType.UNIVER_DOC||t.type===h.UniverInstanceType.UNIVER_SLIDE)&&(e=n),{unitId:n,subUnitId:e}}var en=Object.defineProperty,nn=Object.getOwnPropertyDescriptor,tn=(a,t,n,e)=>{for(var r=e>1?void 0:e?nn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&en(t,n,r),r},Re=(a,t)=>(n,e)=>t(n,e,a);exports.DrawingRenderService=class{constructor(t,n){this._drawingManagerService=t,this._imageIoService=n}async renderImage(t,n){const{transform:e,drawingType:r,source:s,imageSourceType:o,srcRect:c,prstGeom:l,groupId:g,unitId:u,subUnitId:d,drawingId:f}=t;if(r!==I.DrawingTypeEnum.DRAWING_IMAGE||!this._drawingManagerService.getDrawingVisible()||e==null)return;const{left:p,top:S,width:v,height:C,angle:D,flipX:_,flipY:O,skewX:y,skewY:N}=e,P=I.getDrawingShapeKeyByDrawingSearch({unitId:u,subUnitId:d,drawingId:f}),R=n.getObject(P);if(R!=null){R.transformByState({left:p,top:S,width:v,height:C,angle:D,flipX:_,flipY:O,skewX:y,skewY:N});return}const E=this._drawingManagerService.getDrawingOrder(u,d),T=E.indexOf(f),M={...e,zIndex:T===-1?E.length-1:T},j=this._imageIoService.getImageSourceCache(s,o);let L=!1;if(j!=null)M.image=j;else{if(o===I.ImageSourceType.UUID)try{M.url=await this._imageIoService.getImage(s)}catch(ae){console.error(ae);return}else M.url=s;L=!0}M.printable=!0;const $=new b.Image(P,M);if(L&&this._imageIoService.addImageSourceCache(s,o,$.getNative()),!this._drawingManagerService.getDrawingVisible())return;const k=n.addObject($,b.DRAWING_OBJECT_LAYER_INDEX);return this._drawingManagerService.getDrawingEditable()&&k.attachTransformerTo($),g&&Qe({drawingId:g,unitId:u,subUnitId:d},$,n,this._drawingManagerService),l!=null&&$.setPrstGeom(l),c!=null&&$.setSrcRect(c),$}renderDrawing(t,n){const e=this._drawingManagerService.getDrawingByParam(t);if(e!=null)switch(e.drawingType){case I.DrawingTypeEnum.DRAWING_IMAGE:return this.renderImage(e,n)}}};exports.DrawingRenderService=tn([Re(0,I.IDrawingManagerService),Re(1,I.IImageIoService)],exports.DrawingRenderService);function me(a,t){const n=[];return a.forEach(e=>{const{oKey:r,left:s,top:o,height:c,width:l,angle:g}=e,u=t.getDrawingOKey(r);if(u==null)return n.push(null),!0;const{unitId:d,subUnitId:f,drawingId:p,drawingType:S}=u,v={unitId:d,subUnitId:f,drawingId:p,drawingType:S,transform:{left:s,top:o,height:c,width:l,angle:g}};S===I.DrawingTypeEnum.DRAWING_IMAGE&&(v.srcRect=e.srcRect),n.push(v)}),n}var z=function(){return z=Object.assign||function(a){for(var t,n=1,e=arguments.length;n<e;n++){t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(a[r]=t[r])}return a},z.apply(this,arguments)},rn=function(a,t){var n={};for(var e in a)Object.prototype.hasOwnProperty.call(a,e)&&t.indexOf(e)<0&&(n[e]=a[e]);if(a!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,e=Object.getOwnPropertySymbols(a);r<e.length;r++)t.indexOf(e[r])<0&&Object.prototype.propertyIsEnumerable.call(a,e[r])&&(n[e[r]]=a[e[r]]);return n},X=i.forwardRef(function(a,t){var n=a.icon,e=a.id,r=a.className,s=a.extend,o=rn(a,["icon","id","className","extend"]),c="univerjs-icon univerjs-icon-".concat(e," ").concat(r||"").trim(),l=i.useRef("_".concat(sn()));return Oe(n,"".concat(e),{defIds:n.defIds,idSuffix:l.current},z({ref:t,className:c},o),s)});function Oe(a,t,n,e,r){return i.createElement(a.tag,z(z({key:t},an(a,n,r)),e),(on(a,n).children||[]).map(function(s,o){return Oe(s,"".concat(t,"-").concat(a.tag,"-").concat(o),n,void 0,r)}))}function an(a,t,n){var e=z({},a.attrs);n!=null&&n.colorChannel1&&e.fill==="colorChannel1"&&(e.fill=n.colorChannel1);var r=t.defIds;return!r||r.length===0||(a.tag==="use"&&e["xlink:href"]&&(e["xlink:href"]=e["xlink:href"]+t.idSuffix),Object.entries(e).forEach(function(s){var o=s[0],c=s[1];typeof c=="string"&&(e[o]=c.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),e}function on(a,t){var n,e=t.defIds;return!e||e.length===0?a:a.tag==="defs"&&(!((n=a.children)===null||n===void 0)&&n.length)?z(z({},a),{children:a.children.map(function(r){return typeof r.attrs.id=="string"&&e&&e.indexOf(r.attrs.id)>-1?z(z({},r),{attrs:z(z({},r.attrs),{id:r.attrs.id+t.idSuffix})}):r})}):a}function sn(){return Math.random().toString(36).substring(2,8)}X.displayName="UniverIcon";var cn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"colorChannel1",d:"M11.0363 12.2367V14.0367C11.0363 14.3681 11.3049 14.6367 11.6363 14.6367C11.9676 14.6367 12.2363 14.3681 12.2363 14.0367V12.2367H14.0364C14.3677 12.2367 14.6364 11.9681 14.6364 11.6367C14.6364 11.3054 14.3677 11.0367 14.0364 11.0367H12.2363V9.23672C12.2363 8.90535 11.9676 8.63672 11.6363 8.63672C11.3049 8.63672 11.0363 8.90535 11.0363 9.23672V11.0367H9.23635C8.90498 11.0367 8.63635 11.3054 8.63635 11.6367C8.63635 11.9681 8.90498 12.2367 9.23635 12.2367H11.0363Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.56365 1.36377C1.90091 1.36377 1.36365 1.90103 1.36365 2.56377V6.16377C1.36365 6.82651 1.90091 7.36377 2.56365 7.36377H6.16365C6.82639 7.36377 7.36365 6.82651 7.36365 6.16377V2.56377C7.36365 1.90103 6.82639 1.36377 6.16365 1.36377H2.56365zM6.16365 2.56377H2.56365L2.56365 6.16377H6.16365V2.56377zM2.56365 8.63647C1.90091 8.63647 1.36365 9.17373 1.36365 9.83647V13.4365C1.36365 14.0992 1.90091 14.6365 2.56365 14.6365H6.16365C6.82639 14.6365 7.36365 14.0992 7.36365 13.4365V9.83647C7.36365 9.17373 6.82639 8.63647 6.16365 8.63647H2.56365zM6.16365 9.83647H2.56365L2.56365 13.4365H6.16365V9.83647zM9.83635 7.36377C9.17361 7.36377 8.63635 6.82651 8.63635 6.16377V2.56377C8.63635 1.90103 9.17361 1.36377 9.83635 1.36377H13.4364C14.0991 1.36377 14.6364 1.90103 14.6364 2.56377V6.16377C14.6364 6.82651 14.0991 7.36377 13.4364 7.36377H9.83635zM9.83635 6.16377V2.56377L13.4364 2.56377V6.16377H9.83635z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ne=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"autofill",ref:t,icon:cn}))});Ne.displayName="Autofill";var ln={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.0045 4.4334C14.8881 4.4334 15.6045 3.71705 15.6045 2.8334 15.6045 1.94974 14.8881 1.2334 14.0045 1.2334H3.70449C2.82084 1.2334 2.10449 1.94974 2.10449 2.8334 2.10449 3.71705 2.82084 4.4334 3.70449 4.4334H14.0045zM14.4045 2.8334C14.4045 3.05431 14.2254 3.2334 14.0045 3.2334H3.70449C3.48358 3.2334 3.30449 3.05431 3.30449 2.8334 3.30449 2.61248 3.48358 2.4334 3.70449 2.4334H14.0045C14.2254 2.4334 14.4045 2.61249 14.4045 2.8334zM14.1544 8.5999C15.038 8.5999 15.7544 7.88356 15.7544 6.9999 15.7544 6.11625 15.038 5.3999 14.1544 5.3999H3.85439C2.97074 5.3999 2.25439 6.11625 2.25439 6.9999 2.25439 7.88356 2.97074 8.5999 3.85439 8.5999H14.1544zM14.5544 6.9999C14.5544 7.22082 14.3753 7.3999 14.1544 7.3999H3.85439C3.63348 7.3999 3.45439 7.22082 3.45439 6.9999 3.45439 6.77899 3.63348 6.5999 3.85439 6.5999H14.1544C14.3753 6.5999 14.5544 6.77899 14.5544 6.9999z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M8.57975 14.5902L6.58023 12.5907C6.34591 12.3564 6.34591 11.9765 6.58023 11.7421 6.81454 11.5078 7.19444 11.5078 7.42876 11.7421L8.40449 12.7179V10.1664C8.40449 9.83504 8.67312 9.56641 9.00449 9.56641 9.33586 9.56641 9.60449 9.83504 9.60449 10.1664V12.7179L10.5802 11.7421C10.8145 11.5078 11.1944 11.5078 11.4288 11.7421 11.6631 11.9765 11.6631 12.3564 11.4288 12.5907L9.42923 14.5902M8.57975 14.5902C8.58121 14.5917 8.58268 14.5931 8.58416 14.5946 8.64077 14.6502 8.70566 14.6923 8.77482 14.7209 8.84557 14.7502 8.92314 14.7664 9.00449 14.7664 9.08585 14.7664 9.16342 14.7502 9.23416 14.7209 9.30332 14.6923 9.36821 14.6502 9.42482 14.5946"}}]},Te=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"bottom-single",ref:t,icon:ln}))});Te.displayName="BottomSingle";var mn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.97705 7.51296C5.97705 7.18159 6.24568 6.91296 6.57705 6.91296H8.48632C8.81769 6.91296 9.08632 7.18159 9.08632 7.51296 9.08632 7.84433 8.81769 8.11296 8.48632 8.11296H6.57705C6.24568 8.11296 5.97705 7.84433 5.97705 7.51296zM6.57705 9.41028C6.24568 9.41028 5.97705 9.67891 5.97705 10.0103 5.97705 10.3416 6.24568 10.6103 6.57705 10.6103H10.8199C11.1512 10.6103 11.4199 10.3416 11.4199 10.0103 11.4199 9.67891 11.1512 9.41028 10.8199 9.41028H6.57705z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.51074 2.37063C3.51074 1.48697 4.22709 0.77063 5.11074 0.77063H9.80318L9.81294 0.770708C9.97168 0.768161 10.1311 0.82824 10.2511 0.95055L14.4317 5.21408C14.5165 5.30049 14.5697 5.406 14.5917 5.51645C14.6041 5.5644 14.6106 5.61467 14.6106 5.66648V11.6406C14.6106 12.5243 13.8943 13.2406 13.0106 13.2406H5.11074C4.22709 13.2406 3.51074 12.5243 3.51074 11.6406V2.37063ZM10.4032 4.66648V2.81964L12.6063 5.06648H10.8032C10.5823 5.06648 10.4032 4.88739 10.4032 4.66648ZM5.11074 1.97063C4.88983 1.97063 4.71074 2.14972 4.71074 2.37063V11.6406C4.71074 11.8615 4.88983 12.0406 5.11074 12.0406H13.0106C13.2316 12.0406 13.4106 11.8615 13.4106 11.6406V6.26648H10.8032C9.91953 6.26648 9.20318 5.55013 9.20318 4.66648V1.97063H5.11074Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.58916 6.6741C2.58916 6.34273 2.32053 6.0741 1.98916 6.0741C1.65779 6.0741 1.38916 6.34273 1.38916 6.6741V12.6294C1.38916 14.0653 2.55322 15.2294 3.98916 15.2294H9.41408C9.74545 15.2294 10.0141 14.9607 10.0141 14.6294C10.0141 14.298 9.74545 14.0294 9.41408 14.0294H3.98916C3.21596 14.0294 2.58916 13.4026 2.58916 12.6294V6.6741Z"}}]},Be=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"create-copy-single",ref:t,icon:mn}))});Be.displayName="CreateCopySingle";var gn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.38125 1.16211C6.49759 1.16211 5.78125 1.87845 5.78125 2.76211V5.6377H2.87783C1.99418 5.6377 1.27783 6.35404 1.27783 7.2377V13.2377C1.27783 14.1214 1.99418 14.8377 2.87783 14.8377H8.87783C9.76149 14.8377 10.4778 14.1214 10.4778 13.2377V10.3621H13.3813C14.2649 10.3621 14.9813 9.64577 14.9813 8.76211V2.76211C14.9813 1.87845 14.2649 1.16211 13.3813 1.16211H7.38125ZM10.4778 9.16211H13.3813C13.6022 9.16211 13.7812 8.98302 13.7812 8.76211V2.76211C13.7812 2.5412 13.6022 2.36211 13.3813 2.36211H7.38125C7.16034 2.36211 6.98125 2.5412 6.98125 2.76211V5.6377H8.87783C9.76149 5.6377 10.4778 6.35404 10.4778 7.2377V9.16211ZM6.98125 6.8377H8.87783C9.09875 6.8377 9.27783 7.01678 9.27783 7.2377V9.16211H7.38125C7.16034 9.16211 6.98125 8.98302 6.98125 8.76211V6.8377ZM5.78125 6.8377V8.76211C5.78125 9.64577 6.49759 10.3621 7.38125 10.3621H9.27783V13.2377C9.27783 13.4586 9.09875 13.6377 8.87783 13.6377H2.87783C2.65692 13.6377 2.47783 13.4586 2.47783 13.2377V7.2377C2.47783 7.01678 2.65692 6.8377 2.87783 6.8377H5.78125Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ue=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"group-single",ref:t,icon:gn}))});Ue.displayName="GroupSingle";var un={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M11.3536 6.14645C11.5488 6.34171 11.5488 6.65829 11.3536 6.85355L8.35355 9.85355C8.15829 10.0488 7.84171 10.0488 7.64645 9.85355L4.64645 6.85355C4.45118 6.65829 4.45118 6.34171 4.64645 6.14645C4.84171 5.95118 5.15829 5.95118 5.35355 6.14645L8 8.79289L10.6464 6.14645C10.8417 5.95118 11.1583 5.95118 11.3536 6.14645Z",fillRule:"evenodd",clipRule:"evenodd"}}]},je=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"more-down-single",ref:t,icon:un}))});je.displayName="MoreDownSingle";var dn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 2.96401C1.25 3.84767 1.96634 4.56401 2.85 4.56401H13.15C14.0337 4.56401 14.75 3.84767 14.75 2.96401C14.75 2.08036 14.0337 1.36401 13.15 1.36401H2.85C1.96635 1.36401 1.25 2.08036 1.25 2.96401ZM2.85 3.36401C2.62909 3.36401 2.45 3.18493 2.45 2.96401C2.45 2.7431 2.62909 2.56401 2.85 2.56401H13.15C13.3709 2.56401 13.55 2.7431 13.55 2.96401C13.55 3.18493 13.3709 3.36401 13.15 3.36401H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 11.6118C5.80995 11.3774 6.18985 11.3774 6.42417 11.6118L7.3999 12.5875V6.36951C7.3999 6.03814 7.66853 5.76951 7.9999 5.76951C8.33127 5.76951 8.5999 6.03814 8.5999 6.36951V12.5875L9.57564 11.6118C9.80995 11.3774 10.1899 11.3774 10.4242 11.6118C10.6585 11.8461 10.6585 12.226 10.4242 12.4603L8.4324 14.452C8.32324 14.5655 8.16982 14.6362 7.9999 14.6362C7.82998 14.6362 7.67655 14.5655 7.56739 14.452L5.57564 12.4603C5.34132 12.226 5.34132 11.8461 5.57564 11.6118Z"}}]},Le=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"move-down-single",ref:t,icon:dn}))});Le.displayName="MoveDownSingle";var hn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 13.036C1.25 12.1523 1.96634 11.436 2.85 11.436H13.15C14.0337 11.436 14.75 12.1523 14.75 13.036C14.75 13.9196 14.0337 14.636 13.15 14.636H2.85C1.96635 14.636 1.25 13.9196 1.25 13.036ZM2.85 12.636C2.62909 12.636 2.45 12.8151 2.45 13.036C2.45 13.2569 2.62909 13.436 2.85 13.436H13.15C13.3709 13.436 13.55 13.2569 13.55 13.036C13.55 12.8151 13.3709 12.636 13.15 12.636H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 4.38825C5.80995 4.62256 6.18985 4.62256 6.42417 4.38825L7.3999 3.41251V9.63049C7.3999 9.96186 7.66853 10.2305 7.9999 10.2305C8.33127 10.2305 8.5999 9.96186 8.5999 9.63049V3.41251L9.57564 4.38825C9.80995 4.62256 10.1899 4.62256 10.4242 4.38825C10.6585 4.15393 10.6585 3.77403 10.4242 3.53972L8.4324 1.54796C8.32324 1.43445 8.16982 1.36382 7.9999 1.36382C7.82998 1.36382 7.67655 1.43446 7.56739 1.54797L5.57564 3.53972C5.34132 3.77403 5.34132 4.15393 5.57564 4.38825Z"}}]},Ae=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"move-up-single",ref:t,icon:hn}))});Ae.displayName="MoveUpSingle";var fn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.82994 1.40913C7.88746 1.35161 7.95376 1.30821 8.02453 1.27893C8.09527 1.24959 8.17285 1.2334 8.2542 1.2334C8.33555 1.2334 8.41313 1.24959 8.48387 1.27893C8.55464 1.30821 8.62094 1.35161 8.67846 1.40913L10.6785 3.40913C10.9128 3.64345 10.9128 4.02335 10.6785 4.25766C10.4441 4.49198 10.0642 4.49198 9.82994 4.25766L8.8542 3.28193V5.8334C8.8542 6.16477 8.58557 6.4334 8.2542 6.4334C7.92283 6.4334 7.6542 6.16477 7.6542 5.8334V3.28193L6.67846 4.25766C6.44415 4.49198 6.06425 4.49198 5.82994 4.25766C5.59562 4.02335 5.59562 3.64345 5.82994 3.40913L7.82994 1.40913Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1.50439 9C1.50439 8.11634 2.22074 7.4 3.10439 7.4H13.4044C14.288 7.4 15.0044 8.11634 15.0044 9 15.0044 9.88366 14.2881 10.6 13.4044 10.6H3.1044C2.22074 10.6 1.50439 9.88366 1.50439 9zM3.10439 8.6C2.88348 8.6 2.70439 8.77909 2.70439 9 2.70439 9.22091 2.88348 9.4 3.1044 9.4H13.4044C13.6253 9.4 13.8044 9.22091 13.8044 9 13.8044 8.77909 13.6253 8.6 13.4044 8.6H3.10439zM1.6543 13.1665C1.6543 12.2828 2.37064 11.5665 3.2543 11.5665H13.5543C14.438 11.5665 15.1543 12.2828 15.1543 13.1665 15.1543 14.0502 14.438 14.7665 13.5543 14.7665H3.2543C2.37064 14.7665 1.6543 14.0502 1.6543 13.1665zM3.2543 12.7665C3.03338 12.7665 2.8543 12.9456 2.8543 13.1665 2.8543 13.3874 3.03338 13.5665 3.2543 13.5665H13.5543C13.7752 13.5665 13.9543 13.3874 13.9543 13.1665 13.9543 12.9456 13.7752 12.7665 13.5543 12.7665H3.2543z",fillRule:"evenodd",clipRule:"evenodd"}}]},He=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"topmost-single",ref:t,icon:fn}))});He.displayName="TopmostSingle";var pn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.46855 2.83731C7.46855 2.61639 7.64764 2.4373 7.86855 2.4373H13.8603C14.0812 2.4373 14.2603 2.61639 14.2603 2.8373V9.5049C14.2603 9.72581 14.0812 9.90489 13.8603 9.90489H12.866C12.5346 9.90489 12.266 10.1735 12.266 10.5049C12.266 10.8363 12.5346 11.1049 12.866 11.1049H13.8603C14.7439 11.1049 15.4603 10.3886 15.4603 9.5049V2.8373C15.4603 1.95365 14.7439 1.2373 13.8603 1.2373H7.86855C6.9849 1.2373 6.26855 1.95365 6.26855 2.83731V3.48688C6.26855 3.81825 6.53718 4.08688 6.86855 4.08688C7.19993 4.08688 7.46855 3.81825 7.46855 3.48688V2.83731Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.19888 5.56299C2.31522 5.56299 1.59888 6.27933 1.59888 7.16299V13.163C1.59888 14.0466 2.31522 14.763 3.19888 14.763H9.19888C10.0825 14.763 10.7989 14.0466 10.7989 13.163V7.16299C10.7989 6.27933 10.0825 5.56299 9.19888 5.56299H3.19888ZM2.79888 7.16299C2.79888 6.94207 2.97796 6.76299 3.19888 6.76299H9.19888C9.41979 6.76299 9.59888 6.94207 9.59888 7.16299V13.163C9.59888 13.3839 9.41979 13.563 9.19888 13.563H3.19888C2.97796 13.563 2.79888 13.3839 2.79888 13.163V7.16299Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ge=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"ungroup-single",ref:t,icon:pn}))});Ge.displayName="UngroupSingle";const Cn="univer-image-common-panel",wn="univer-image-common-panel-grid",vn="univer-image-common-panel-border",Sn="univer-image-common-panel-title",_n="univer-image-common-panel-subtitle",In="univer-image-common-panel-row",bn="univer-image-common-panel-row-vertical",yn="univer-image-common-panel-column",Pn="univer-image-common-panel-column-center",En="univer-image-common-panel-inline",Rn="univer-image-common-panel-span2",Mn="univer-image-common-panel-span3",Dn="univer-image-common-panel-input",m={imageCommonPanel:Cn,imageCommonPanelGrid:wn,imageCommonPanelBorder:vn,imageCommonPanelTitle:Sn,imageCommonPanelSubtitle:_n,imageCommonPanelRow:In,imageCommonPanelRowVertical:bn,imageCommonPanelColumn:yn,imageCommonPanelColumnCenter:Pn,imageCommonPanelInline:En,imageCommonPanelSpan2:Rn,imageCommonPanelSpan3:Mn,imageCommonPanelInput:Dn},On=a=>{const{arrangeShow:t,drawings:n}=a,e=h.useDependency(h.LocaleService),r=h.useDependency(I.IDrawingManagerService),s=g=>g?"block":"none",[o,c]=i.useState(n);i.useEffect(()=>{const g=r.focus$.subscribe(u=>{c(u)});return()=>{g.unsubscribe()}},[]);const l=g=>{const u=o[0].unitId,d=o[0].subUnitId,f=o.map(p=>p.drawingId);r.featurePluginOrderUpdateNotification({unitId:u,subUnitId:d,drawingIds:f,arrangeType:g})};return i.createElement("div",{className:m.imageCommonPanelGrid,style:{display:s(t)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,e.t("image-panel.arrange.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.forward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ae,null),e.t("image-panel.arrange.forward")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.backward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Le,null),e.t("image-panel.arrange.backward"))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.front)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(He,null),e.t("image-panel.arrange.front")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{l(I.ArrangeTypeEnum.back)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Te,null),e.t("image-panel.arrange.back"))))))},ne=20,Nn=20,Tn=[-3600,3600],ue=300,Bn=a=>{var Pe;const t=h.useDependency(h.LocaleService),n=h.useDependency(I.IDrawingManagerService),e=h.useDependency(b.IRenderManagerService),{drawings:r,transformShow:s}=a,o=r[0];if(o==null)return;const c=o.transform;if(c==null)return;const{unitId:l,subUnitId:g,drawingId:u,drawingType:d}=o,f=e.getRenderById(l),p=f==null?void 0:f.scene;if(p==null)return;const S=(Pe=p.getEngine())==null?void 0:Pe.activeScene;if(S==null)return;const v=p.getTransformerByCreate(),{width:C=0,height:D=0,left:_=0,top:O=0,angle:y=0}=c,[N,P]=i.useState(C),[R,E]=i.useState(D),[T,M]=i.useState(_),[j,L]=i.useState(O),[$,k]=i.useState(y),[ae,$e]=i.useState(v.keepRatio),ge=(w,V,x,G)=>{const{width:H,height:q}=S,{ancestorLeft:K,ancestorTop:F}=p;let Y=w,Z=V,Q=x,ie=G;return w+K<0&&(Y=-K),V+F<0&&(Z=-F),Q=H-Y-K,Q<ne&&(Q=ne),ie=q-Z-F,ie<ne&&(ie=ne),w+Q+K>H&&(Y=H-x-K),V+ie+F>q&&(Z=q-G-F),{limitLeft:Y,limitTop:Z,limitWidth:Q,limitHeight:ie}},ye=w=>{const{objects:V}=w,x=me(V,n);if(x.length!==1)return;const G=x[0];if(G==null)return;const{transform:H}=G;if(H==null)return;const{width:q,height:K,left:F,top:Y,angle:Z}=H;q!=null&&P(q),K!=null&&E(K),F!=null&&M(F),Y!=null&&L(Y),Z!=null&&k(Z)};i.useEffect(()=>{const w=v.changeStart$.subscribe(G=>{ye(G)}),V=v.changing$.subscribe(G=>{ye(G)}),x=n.focus$.subscribe(G=>{if(G.length!==1)return;const H=n.getDrawingByParam(G[0]);if(H==null)return;const q=H.transform;if(q==null)return;const{width:K,height:F,left:Y,top:Z,angle:Q}=q;K!=null&&P(K),F!=null&&E(F),Y!=null&&M(Y),Z!=null&&L(Z),Q!=null&&k(Q)});return()=>{V.unsubscribe(),w.unsubscribe(),x.unsubscribe()}},[]);const ke=h.debounce(w=>{if(w==null)return;w=Math.max(w,ne);const{limitWidth:V,limitHeight:x}=ge(T,j,w,R);w=Math.min(w,V);const G={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{width:w}};if(ae){let H=w/N*R;if(H=Math.max(H,Nn),H>x)return;E(H),G.transform.height=H}P(w),n.featurePluginUpdateNotification([G]),v.refreshControls().changeNotification()},ue),ze=h.debounce(w=>{if(w==null)return;w=Math.max(w,ne);const{limitHeight:V,limitWidth:x}=ge(T,j,N,w);w=Math.min(w,V);const G={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{height:w}};if(ae){let H=w/R*N;if(H=Math.max(H,ne),H>x)return;P(H),G.transform.width=H}E(w),n.featurePluginUpdateNotification([G]),v.refreshControls().changeNotification()},ue),Ke=h.debounce(w=>{if(w==null)return;const{limitLeft:V}=ge(w,j,N,R);w=V;const x={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{left:w}};M(w),n.featurePluginUpdateNotification([x]),v.refreshControls().changeNotification()},ue),Fe=h.debounce(w=>{if(w==null)return;const{limitTop:V}=ge(T,w,N,R);w=V;const x={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{top:w}};L(w),n.featurePluginUpdateNotification([x]),v.refreshControls().changeNotification()},ue),Ye=w=>{if(w==null)return;const[V,x]=Tn;w<V&&(w=V),w>x&&(w=x);const G={unitId:l,subUnitId:g,drawingId:u,drawingType:d,transform:{angle:w}};k(w),n.featurePluginUpdateNotification([G]),v.refreshControls().changeNotification()},Ze=w=>{$e(w),v.keepRatio=w},Xe=w=>w?"block":"none";return i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:Xe(s)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.transform.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.width"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:N,onChange:w=>{ke(w)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.height"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:R,onChange:w=>{ze(w)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.lock"))),i.createElement("div",{className:U(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.Checkbox,{checked:ae,onChange:Ze})))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.x"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:T,onChange:w=>{Ke(w)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.y"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:j,onChange:w=>{Fe(w)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.rotate"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement(W.InputNumber,{precision:1,value:$,onChange:Ye,className:m.imageCommonPanelInput})))))))};var B=(a=>(a.default="0",a.left="1",a.center="2",a.right="3",a.top="4",a.middle="5",a.bottom="6",a.horizon="7",a.vertical="8",a))(B||{});const Se={id:"sheet.operation.set-image-align",type:h.CommandType.OPERATION,handler:(a,t)=>!0},Un=a=>{const t=h.useDependency(h.ICommandService),n=h.useDependency(h.LocaleService),{alignShow:e}=a,[r,s]=i.useState(B.default),o=[{label:n.t("image-panel.align.default"),value:B.default},{options:[{label:n.t("image-panel.align.left"),value:B.left},{label:n.t("image-panel.align.center"),value:B.center},{label:n.t("image-panel.align.right"),value:B.right}]},{options:[{label:n.t("image-panel.align.top"),value:B.top},{label:n.t("image-panel.align.middle"),value:B.middle},{label:n.t("image-panel.align.bottom"),value:B.bottom}]},{options:[{label:n.t("image-panel.align.horizon"),value:B.horizon},{label:n.t("image-panel.align.vertical"),value:B.vertical}]}];function c(g){s(g),t.executeCommand(Se.id,{alignType:g})}const l=g=>g?"block":"none";return i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:l(e)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.align.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn)},i.createElement(W.Select,{value:r,options:o,onChange:c}))))},ve={id:"sheet.operation.open-image-crop",type:h.CommandType.OPERATION,handler:(a,t)=>!0},ee={id:"sheet.operation.close-image-crop",type:h.CommandType.OPERATION,handler:(a,t)=>!0};var A=(a=>(a.FREE="0",a.R1_1="1",a.R16_9="2",a.R9_16="3",a.R5_4="4",a.R4_5="5",a.R4_3="6",a.R3_4="7",a.R3_2="8",a.R2_3="9",a))(A||{});const le={id:"sheet.operation.Auto-image-crop",type:h.CommandType.OPERATION,handler:(a,t)=>!0},jn=a=>{const t=h.useDependency(h.ICommandService),n=h.useDependency(h.LocaleService),{drawings:e,cropperShow:r}=a;if(e[0]==null)return;const[o,c]=i.useState(A.FREE),l=i.useRef(!1),g=[{label:n.t("image-panel.crop.mode"),value:A.FREE},{label:"1:1",value:A.R1_1},{label:"16:9",value:A.R16_9},{label:"9:16",value:A.R9_16},{label:"5:4",value:A.R5_4},{label:"4:5",value:A.R4_5},{label:"4:3",value:A.R4_3},{label:"3:4",value:A.R3_4},{label:"3:2",value:A.R3_2},{label:"2:3",value:A.R2_3}];i.useEffect(()=>{const p=t.onCommandExecuted(S=>{if(S.id===ee.id){const v=S.params;v!=null&&v.isAuto||(l.current=!1)}});return()=>{p==null||p.dispose()}},[]);function u(p){c(p),l.current&&t.executeCommand(le.id,{cropType:p})}const d=p=>p?"block":"none",f=p=>{t.executeCommand(le.id,{cropType:p}),l.current=!0};return i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:d(r)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.crop.title")))),i.createElement("div",{className:U(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Button,{size:"small",onClick:()=>{f(o)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Be,null),n.t("image-panel.crop.start")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement(W.Select,{value:o,options:g,onChange:u}))))},Ln=a=>{const t=h.useDependency(h.LocaleService),n=h.useDependency(b.IRenderManagerService),e=h.useDependency(I.IDrawingManagerService),{hasGroup:r,drawings:s}=a,[o,c]=i.useState(!1),[l,g]=i.useState(!0),[u,d]=i.useState(!0),f=C=>C?"block":"none",p=()=>{const C=e.getFocusDrawings(),{unitId:D,subUnitId:_}=C[0],O=h.Tools.generateRandomId(10),y=b.getGroupState(0,0,C.map(R=>R.transform||{})),N={unitId:D,subUnitId:_,drawingId:O,drawingType:I.DrawingTypeEnum.DRAWING_GROUP,transform:y},P=C.map(R=>{const E=R.transform||{left:0,top:0},{unitId:T,subUnitId:M,drawingId:j}=R;return{unitId:T,subUnitId:M,drawingId:j,transform:{...E,left:E.left-y.left,top:E.top-y.top},groupId:O}});e.featurePluginGroupUpdateNotification([{parent:N,children:P}])},S=C=>{if(C.drawingType!==I.DrawingTypeEnum.DRAWING_GROUP)return;const{unitId:D,subUnitId:_,drawingId:O,transform:y={width:0,height:0}}=C;if(y==null)return;const N=e.getDrawingsByGroup({unitId:D,subUnitId:_,drawingId:O});if(N.length===0)return;const P=N.map(R=>{const{transform:E}=R,{unitId:T,subUnitId:M,drawingId:j}=R,L=b.transformObjectOutOfGroup(E||{},y,y.width||0,y.height||0);return{unitId:T,subUnitId:M,drawingId:j,transform:{...E,...L},groupId:void 0}});return{parent:C,children:P}},v=()=>{const D=e.getFocusDrawings().map(_=>S(_)).filter(_=>_!=null);D.length!==0&&e.featurePluginUngroupUpdateNotification(D)};return i.useEffect(()=>{const C=s[0];if(C==null)return;const{unitId:D}=C,_=n.getRenderById(D),O=_==null?void 0:_.scene;if(O==null)return;const y=O.getTransformerByCreate(),N=y.clearControl$.subscribe(R=>{R===!0&&c(!1)}),P=y.changeStart$.subscribe(R=>{const{objects:E}=R,T=me(E,e),M=T.filter(k=>(k==null?void 0:k.drawingType)===I.DrawingTypeEnum.DRAWING_GROUP);let j=!1,L=!1;T.length>1&&(j=!0),M.length>0&&(L=!0),c(j||L),g(j),d(L)});return()=>{P.unsubscribe(),N.unsubscribe()}},[]),i.createElement("div",{className:U(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:f(r===!0?o:!1)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.group.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement(W.Button,{size:"small",onClick:()=>{p()},style:{display:f(l)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ue,null),t.t("image-panel.group.group")))),i.createElement("div",{className:U(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement(W.Button,{size:"small",onClick:()=>{v()},style:{display:f(u)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ge,null),t.t("image-panel.group.unGroup"))))))},An=a=>{const t=h.useDependency(I.IDrawingManagerService),n=h.useDependency(b.IRenderManagerService),e=h.useDependency(h.LocaleService),{drawings:r,hasArrange:s=!0,hasTransform:o=!0,hasAlign:c=!0,hasCropper:l=!0,hasGroup:g=!0}=a,u=r[0];if(u==null)return;const{unitId:d}=u,f=n.getRenderById(d),p=f==null?void 0:f.scene;if(p==null)return;const S=p.getTransformerByCreate(),[v,C]=i.useState(!0),[D,_]=i.useState(!0),[O,y]=i.useState(!1),[N,P]=i.useState(!0),[R,E]=i.useState(!1);return i.useEffect(()=>{const T=S.clearControl$.subscribe(L=>{L===!0&&(C(!1),_(!1),y(!1),P(!1),E(!0))}),M=S.changeStart$.subscribe(L=>{const{objects:$}=L,k=me($,t);k.length===0?(C(!1),_(!1),y(!1),P(!1),E(!0)):k.length===1?(C(!0),_(!0),y(!1),P(!0),E(!1)):(C(!0),_(!1),y(!0),P(!1),E(!1))}),j=t.focus$.subscribe(L=>{L.length===0?(C(!1),_(!1),y(!1),P(!1),E(!0)):L.length===1?(C(!0),_(!0),y(!1),P(!0),E(!1)):(C(!0),_(!1),y(!0),P(!1),E(!1))});return()=>{M.unsubscribe(),T.unsubscribe(),j.unsubscribe()}},[]),i.createElement(i.Fragment,null,i.createElement("div",{style:{display:R===!0?"block":"none",height:"100%"}},i.createElement("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100%",top:"50%",marginTop:"-100px"}},i.createElement("span",null,e.t("image-panel.null")))),i.createElement(On,{arrangeShow:s===!0?v:!1,drawings:r}),i.createElement(Bn,{transformShow:o===!0?D:!1,drawings:r}),i.createElement(Un,{alignShow:c===!0?O:!1,drawings:r}),i.createElement(jn,{cropperShow:l===!0?N:!1,drawings:r}),i.createElement(Ln,{hasGroup:g,drawings:r}))},Hn="univer-image-popup-menu",Gn="univer-image-popup-menu-item",Vn="univer-image-popup-menu-item-icon",xn="univer-image-popup-menu-item-title",Wn="univer-image-popup-menu-item-hide",$n="univer-btn-container",kn="univer-btn-container-expand",oe={imagePopupMenu:Hn,imagePopupMenuItem:Gn,imagePopupMenuItemIcon:Vn,imagePopupMenuItemTitle:xn,imagePopupMenuItemHide:Wn,btnContainer:$n,btnContainerExpand:kn},Ve=a=>{var S,v;const t=(v=(S=a.popup)==null?void 0:S.extraProps)==null?void 0:v.menuItems;if(!t)return null;const n=h.useDependency(h.ICommandService),e=h.useDependency(h.LocaleService),[r,s]=i.useState(!1),[o,c]=i.useState(!1),l=()=>{c(!0)},g=()=>{c(!1)},u=C=>{s(C)},d=C=>{n.executeCommand(C.commandId,C.commandParams),s(!1)},f=r||o,p=t.filter(C=>!C.disable);return i.createElement("div",{onMouseEnter:l,onMouseLeave:g},i.createElement(W.Dropdown,{placement:"bottomLeft",trigger:["click"],overlay:i.createElement("ul",{className:oe.imagePopupMenu},p.map(C=>i.createElement("li",{key:C.index,onClick:()=>d(C),className:oe.imagePopupMenuItem},i.createElement("span",{className:oe.imagePopupMenuItemTitle},e.t(C.label))))),visible:r,onVisibleChange:u},i.createElement("div",{className:U(oe.btnContainer,{[oe.btnContainerExpand]:r})},i.createElement(Ne,{style:{color:"#35322B"},extend:{colorChannel1:"rgb(var(--green-700, #409f11))"}}),f&&i.createElement(je,{style:{color:"#CCCCCC",fontSize:"8px",marginLeft:"8px"}}))))},xe="COMPONENT_IMAGE_POPUP_MENU";var zn=Object.defineProperty,Kn=Object.getOwnPropertyDescriptor,Fn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Kn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&zn(t,n,r),r},de=(a,t)=>(n,e)=>t(n,e,a);let he=class extends h.Disposable{constructor(t,n,e,r){super();J(this,"_sceneListenerOnDrawingMap",new WeakSet);this._currentUniverService=t,this._commandService=n,this._renderManagerService=e,this._drawingManagerService=r,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._drawingRemoveListener(),this._drawingUpdateListener(),this._commandExecutedListener(),this._drawingArrangeListener(),this._drawingGroupListener(),this._drawingRefreshListener(),this._drawingVisibleListener()}_recoveryImages(){const t=this._drawingManagerService.drawingManagerData,n=Ie(this._currentUniverService);if(n==null)return;const{unitId:e,subUnitId:r}=n;Object.keys(t).forEach(s=>{Object.keys(t[s]).forEach(o=>{const c=t[s][o].data;c==null||s!==e||o!==r||Object.keys(c).forEach(l=>{c[l]&&this._insertDrawing([{unitId:s,subUnitId:o,drawingId:l}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===Se.id){const n=t.params;if(n==null)return;this._drawingAlign(n)}}))}_drawingGroupListener(){this.disposeWithMe(this._drawingManagerService.group$.subscribe(t=>{this._groupDrawings(t)})),this.disposeWithMe(this._drawingManagerService.ungroup$.subscribe(t=>{this._ungroupDrawings(t)}))}_getSceneAndTransformerByDrawingSearch(t){if(t==null)return;const n=this._renderManagerService.getRenderById(t),e=n==null?void 0:n.scene;if(e==null)return null;const r=e.getTransformerByCreate();return{scene:e,transformer:r}}_groupDrawings(t){t.forEach(n=>{this._groupDrawing(n)})}_groupDrawing(t){const{parent:n,children:e}=t,{unitId:r,subUnitId:s,drawingId:o}=n,c=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(c==null)return;const{scene:l,transformer:g}=c;this._commandService.syncExecuteCommand(ee.id);const u=[];if(e.forEach(p=>{const S=I.getDrawingShapeKeyByDrawingSearch(p),v=l.getObjectIncludeInGroup(S);if(v==null||u.includes(v))return;u.push(v);const{transform:C}=p;C!=null&&(v.classType===b.RENDER_CLASS_TYPE.GROUP?v.transformByState({left:C.left,top:C.top}):v.transformByState(C))}),u.length===0)return;const d=I.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),f=new b.Group(d);l.addObject(f,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(f),f.addObjects(...u),n.transform&&f.transformByState({left:n.transform.left,top:n.transform.top}),g.clearSelectedObjects(),g.setSelectedControl(f)}_ungroupDrawings(t){t.forEach(n=>{this._ungroupDrawing(n)})}_ungroupDrawing(t){const{parent:n,children:e}=t,r=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(r==null)return;const{scene:s,transformer:o}=r;e.forEach(d=>{const f=I.getDrawingShapeKeyByDrawingSearch(d),p=s.getObjectIncludeInGroup(f);if(p==null)return!0;if(p==null)return;const{transform:S}=d;S!=null&&(p.classType===b.RENDER_CLASS_TYPE.GROUP?p.transformByState({left:S.left,top:S.top}):p.transformByState(S))});const c=I.getDrawingShapeKeyByDrawingSearch(n),l=s.getObject(c),{width:g,height:u}=l;l.getObjects().forEach(d=>{l.removeSelfObjectAndTransform(d.oKey,g,u)}),l.dispose(),o.clearSelectedObjects()}_drawingAlign(t){const{alignType:n}=t,e=this._drawingManagerService.getFocusDrawings();if(n===B.default)return;const r=[];let s=Number.POSITIVE_INFINITY,o=Number.POSITIVE_INFINITY,c=Number.NEGATIVE_INFINITY,l=Number.NEGATIVE_INFINITY,g=0;e.forEach(u=>{const{unitId:d,subUnitId:f,drawingId:p,drawingType:S}=u,v=this._drawingManagerService.getDrawingByParam({unitId:d,subUnitId:f,drawingId:p});if(v==null||v.transform==null)return;r.push({unitId:d,subUnitId:f,drawingId:p,drawingType:S,transform:v.transform});const{left:C=0,top:D=0,width:_=0,height:O=0}=v.transform;s=Math.min(s,C),o=Math.min(o,D),c=Math.max(c,C+_),l=Math.max(l,D+O),g++}),g!==0&&(this._sortDrawingTransform(r,n),this._applyAlignType(r,n,s,o,c,l,g))}_applyAlignType(t,n,e,r,s,o,c){const l=Math.round((s-e)/c*10)/10,g=Math.round((o-r)/c*10)/10,u=[],d=this._getSceneAndTransformerByDrawingSearch(t[0].unitId);if(d==null)return;const{scene:f,transformer:p}=d;t.forEach((S,v)=>{const{unitId:C,subUnitId:D,drawingId:_,transform:O,drawingType:y}=S,{left:N=0,top:P=0,width:R=0,height:E=0}=O;let T=N,M=P;switch(n){case B.left:T=e;break;case B.center:T=e+(s-e)/2-R/2;break;case B.right:T=s-R;break;case B.top:M=r;break;case B.middle:M=r+(o-r)/2-E/2;break;case B.bottom:M=o-E;break;case B.horizon:T=e+l*v;break;case B.vertical:M=r+g*v;break}(T!==N||M!==P)&&u.push({unitId:C,subUnitId:D,drawingId:_,drawingType:y,transform:{left:T,top:M}})}),this._drawingManagerService.featurePluginUpdateNotification(u),p.refreshControls().changeNotification()}_sortDrawingTransform(t,n){t.sort((e,r)=>{const s=e.transform,o=r.transform,{left:c=0,top:l=0,width:g=0,height:u=0}=s,{left:d=0,top:f=0,width:p=0,height:S=0}=o;switch(n){case B.left:return c-d;case B.center:return c+g/2-(d+p/2);case B.right:return c+g-(d+p);case B.top:return l-f;case B.middle:return l+u/2-(f+S/2);case B.bottom:return l+u-(f+S);case B.horizon:return c+g/2-(d+p/2);case B.vertical:return l+u/2-(f+S/2);default:return 0}})}_drawingArrangeListener(){this.disposeWithMe(this._drawingManagerService.order$.subscribe(t=>{this._drawingArrange(t)}))}_drawingArrange(t){const{unitId:n,subUnitId:e,drawingIds:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n);if(s==null)return;const{scene:o,transformer:c}=s;r.forEach(l=>{const g=I.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:l}),u=o.getObject(g);if(u==null)return;const d=this._drawingManagerService.getDrawingOrder(n,e).indexOf(l);u.setProps({zIndex:d}),u.makeDirty()})}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(t=>{this._insertDrawing(t)}))}_insertDrawing(t){const n=[];t.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e;if(this._drawingManagerService.getDrawingByParam(e)==null)return;const l=this._getSceneAndTransformerByDrawingSearch(r);if(l==null)return;const{scene:g,transformer:u}=l;n.includes(g)||n.push(g)}),n.forEach(e=>{this._sceneListenerOnDrawingMap.has(e)||(this._addListenerOnDrawing(e),this._sceneListenerOnDrawingMap.add(e))})}_drawingRemoveListener(){this.disposeWithMe(this._drawingManagerService.remove$.subscribe(t=>{t.forEach(n=>{var d;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:c,transformer:l}=o,g=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),u=c.getObject(g);u!=null&&(u.dispose(),(d=c.getTransformer())==null||d.clearSelectedObjects())})}))}_drawingUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._drawingManagerService.getDrawingByParam(n);if(o==null)return;const{transform:c,drawingType:l}=o,g=this._getSceneAndTransformerByDrawingSearch(e);if(g==null)return;const{scene:u,transformer:d}=g;if(c==null)return!0;const{left:f=0,top:p=0,width:S=0,height:v=0,angle:C=0,flipX:D=!1,flipY:_=!1,skewX:O=0,skewY:y=0}=c,N=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),P=u.getObject(N);if(P==null)return!0;P.transformByState({left:f,top:p,width:S,height:v,angle:C,flipX:D,flipY:_,skewX:O,skewY:y})})}))}_drawingRefreshListener(){this.disposeWithMe(this._drawingManagerService.refreshTransform$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:c,transformer:l}=o,g=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),u=c.getObject(g);if(u==null)return!0;const d=this._drawingManagerService.getDrawingByParam(n);if(d==null)return;const{transform:f}=d;if(f==null)return!0;const{left:p=0,top:S=0,width:v=0,height:C=0,angle:D=0,flipX:_=!1,flipY:O=!1,skewX:y=0,skewY:N=0}=f;u.transformByState({left:p,top:S,width:v,height:C,angle:D,flipX:_,flipY:O,skewX:y,skewY:N})})}))}_drawingVisibleListener(){this.disposeWithMe(this._drawingManagerService.visible$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s,visible:o}=n,c=this._getSceneAndTransformerByDrawingSearch(e);if(c==null)return;const{scene:l,transformer:g}=c,u=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),d=l.getObject(u);if(d==null)return!0;o?d.show():d.hide()})}))}_filterUpdateParams(t,n){return t.filter((e,r)=>{if(e==null)return!1;const{transform:s}=e;return h.checkIfMove(s,n==null?void 0:n[r])})}_addListenerOnDrawing(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(h.toDisposable(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=Array.from(s.values()),c=[];e=o.map(l=>{const{left:g,top:u,height:d,width:f,angle:p,oKey:S,groupKey:v,isInGroup:C}=l,D=this._drawingManagerService.getDrawingOKey(S);if(C||l instanceof b.Group){let _=l.ancestorGroup;if(_==null&&l instanceof b.Group&&(_=l),_==null)return null;const O=this._drawingManagerService.getDrawingOKey(_.oKey);if(O){const{unitId:y,subUnitId:N,drawingId:P}=O;c.push({unitId:y,subUnitId:N,drawingId:P});const{left:R,top:E,height:T,width:M,angle:j}=_;return{left:R,top:E,height:T,width:M,angle:j}}}else if(D!=null){const{unitId:_,subUnitId:O,drawingId:y}=D;return c.push({unitId:_,subUnitId:O,drawingId:y}),{left:g,top:u,height:d,width:f,angle:p}}return null}).filter(l=>l!=null),c.length>0?this._drawingManagerService.focusDrawing(c):this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(h.toDisposable(n.changeEnd$.subscribe(r=>{const{objects:s}=r;this._filterUpdateParams(me(s,this._drawingManagerService),e).length>0})))}};he=Fn([h.OnLifecycle(h.LifecycleStages.Rendered,he),de(0,h.IUniverInstanceService),de(1,h.ICommandService),de(2,b.IRenderManagerService),de(3,I.IDrawingManagerService)],he);const Yn=a=>{const{src:t}=a;return t?i.createElement("div",null,i.createElement("img",{src:t,alt:"Univer Image Viewer",style:{width:"100%",height:"100%",position:"relative"}})):null},We="COMPONENT_IMAGE_VIEWER",be={id:"sheet.operation.image-reset-size",type:h.CommandType.OPERATION,handler:(a,t)=>!0};var Zn=Object.defineProperty,Xn=Object.getOwnPropertyDescriptor,qn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Xn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Zn(t,n,r),r},se=(a,t)=>(n,e)=>t(n,e,a);let fe=class extends h.Disposable{constructor(a,t,n,e,r){super(),this._injector=a,this._componentManager=t,this._menuService=n,this._commandService=e,this._localeService=r,this._init()}_initCustomComponents(){const a=this._componentManager;this.disposeWithMe(a.register(xe,Ve)),this.disposeWithMe(a.register(We,Yn))}_initMenus(){}_initCommands(){[ve,ee,be,Se,le].forEach(a=>this.disposeWithMe(this._commandService.registerCommand(a)))}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus()}};fe=qn([h.OnLifecycle(h.LifecycleStages.Rendered,fe),se(0,h.Inject(h.Injector)),se(1,h.Inject(we.ComponentManager)),se(2,we.IMenuService),se(3,h.ICommandService),se(4,h.Inject(h.LocaleService))],fe);class ce extends b.Shape{constructor(n,e){e==null&&(e={}),e.transformerConfig={keepRatio:!1,isCropper:!0,anchorFill:"rgb(0, 0, 0)",anchorStroke:"rgb(255, 255, 255)",anchorSize:24};super(n,e);J(this,"_srcRect");J(this,"_prstGeom");J(this,"_applyTransform");J(this,"_dragPadding",8);J(this,"_cacheCanvas");e!=null&&e.srcRect&&(this._srcRect=e.srcRect),e!=null&&e.prstGeom&&(this._prstGeom=e.prstGeom),e!=null&&e.applyTransform&&(this._applyTransform=e.applyTransform),e!=null&&e.dragPadding&&(this._dragPadding=e.dragPadding),this._applyProps()}refreshSrcRect(n,e){this._srcRect=n,this._applyTransform=e,this._applyProps()}get srcRect(){return this._srcRect}dispose(){var n;super.dispose(),(n=this._cacheCanvas)==null||n.dispose(),this._srcRect=null}isHit(n){const e=this.getInverseCoord(n);return e.x>=-this.strokeWidth/2&&e.x<=this.width+this.strokeWidth/2&&e.y>=-this.strokeWidth/2&&e.y<=this.height+this.strokeWidth/2&&!this._inSurround(e)}_inSurround(n){const e=this._dragPadding;return n.x>=e-this.strokeWidth/2&&n.x<=this.width+this.strokeWidth/2-e&&n.y>=e-this.strokeWidth/2&&n.y<=this.height+this.strokeWidth/2-e}render(n,e){return this.visible?(n.save(),this._draw(n),n.restore(),this.makeDirty(!1),this):(this.makeDirty(!1),this)}_draw(n){var l,g;const r=this.getScene().getEngine(),{width:s,height:o}=r;this._initialCacheCanvas(),(l=this._cacheCanvas)==null||l.clear();const c=(g=this._cacheCanvas)==null?void 0:g.getContext();c!=null&&(c.save(),b.Rect.drawWith(c,{left:0,top:0,width:s,height:o,fill:"rgba(0, 0, 0, 0.5)"}),c.setTransform(n.getTransform()),this._clipForApplyObject(c),this._applyCache(n),c.restore())}_clipForApplyObject(n){let e=0;if(this._prstGeom!=null&&(e=1),n.globalCompositeOperation="destination-out",n.beginPath(),e===0){const r=this.transform.getMatrix();n.transform(r[0],r[1],r[2],r[3],r[4],r[5]),n.rect(0,0,this.width,this.height),n.fill()}}_applyProps(){if(this._applyTransform==null)return;let n=0,e=0,r=0,s=0;const{left:o=0,top:c=0,width:l=0,height:g=0,angle:u}=this._applyTransform;if(this._srcRect!=null){const{left:p=0,top:S=0,right:v=0,bottom:C=0}=this._srcRect;n=p,e=S,r=v,s=C}const d=o+n,f=c+e;this.transformByState({left:d,top:f,width:o+l-r-d,height:c+g-s-f,angle:u})}_applyCache(n){if(!n||this._cacheCanvas==null)return;const e=this._cacheCanvas.getContext();e.save(),n.save(),n.setTransform(1,0,0,1,0,0),e.setTransform(1,0,0,1,0,0),n.drawImage(this._cacheCanvas.getCanvasEle(),0,0),n.restore(),e.restore()}_initialCacheCanvas(){if(this._cacheCanvas!=null)return;this._cacheCanvas=new b.Canvas;const n=this.getScene().getEngine();this._cacheCanvas.setSize(n.width,n.height),n.onTransformChange$.subscribeEvent(()=>{var e;(e=this._cacheCanvas)==null||e.setSize(n.width,n.height),this.makeDirty(!0)})}}var Jn=Object.defineProperty,Qn=Object.getOwnPropertyDescriptor,et=(a,t,n,e)=>{for(var r=e>1?void 0:e?Qn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Jn(t,n,r),r},re=(a,t)=>(n,e)=>t(n,e,a);let pe=class extends h.Disposable{constructor(t,n,e,r,s,o){super();J(this,"_sceneListenerOnImageMap",new WeakSet);this._commandService=t,this._drawingManagerService=n,this._renderManagerService=e,this._univerInstanceService=r,this._messageService=s,this._localeService=o,this._init()}_init(){this._initOpenCrop(),this._initCloseCrop(),this._initAutoCrop()}_initAutoCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==le.id)return;const n=t.params;if(n==null)return;const{cropType:e}=n,r=this._drawingManagerService.getFocusDrawings();if(r.length!==1)return;const s=r[0],{unitId:o,subUnitId:c,drawingId:l}=s,g=this._renderManagerService.getRenderById(o),u=g==null?void 0:g.scene;if(u==null)return!0;this._searchCropObject(u)!=null&&this._commandService.syncExecuteCommand(ee.id,{isAuto:!0});const f=I.getDrawingShapeKeyByDrawingSearch({unitId:o,subUnitId:c,drawingId:l}),p=u.getObject(f);if(!(p instanceof b.Image)){this._messageService.show({type:W.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}p!=null&&(this._updateCropperObject(e,p),this._commandService.executeCommand(ve.id,{unitId:o,subUnitId:c,drawingId:l}))}))}_calculateSrcRectByRatio(t,n,e,r,s,o){const c=e/r,l=s/o;let g=e,u=r;c>l?g=r*l:u=e/l;const d=(e-g)/2,f=(r-u)/2;return{left:b.precisionTo(d,1),top:b.precisionTo(f,1),right:b.precisionTo(e-(d+g),1),bottom:b.precisionTo(r-(f+u),1)}}_updateCropperObject(t,n){const{left:e,top:r,width:s,height:o}=n.calculateTransformWithSrcRect();let c;switch(t){case A.R1_1:c=this._calculateSrcRectByRatio(e,r,s,o,1,1);break;case A.R16_9:c=this._calculateSrcRectByRatio(e,r,s,o,16,9);break;case A.R9_16:c=this._calculateSrcRectByRatio(e,r,s,o,9,16);break;case A.R5_4:c=this._calculateSrcRectByRatio(e,r,s,o,5,4);break;case A.R4_5:c=this._calculateSrcRectByRatio(e,r,s,o,4,5);break;case A.R4_3:c=this._calculateSrcRectByRatio(e,r,s,o,4,3);break;case A.R3_4:c=this._calculateSrcRectByRatio(e,r,s,o,3,4);break;case A.R3_2:c=this._calculateSrcRectByRatio(e,r,s,o,3,2);break;case A.R2_3:c=this._calculateSrcRectByRatio(e,r,s,o,2,3);break;case A.FREE:}if(c==null)return;n.setSrcRect(c);const{left:l=0,top:g=0,bottom:u=0,right:d=0}=c;n.transformByStateCloseCropper({left:e+l,top:r+g,width:s-d-l,height:o-u-g})}_initOpenCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==ve.id)return;const n=t.params;if(n==null)return;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._renderManagerService.getRenderById(e),c=o==null?void 0:o.scene;if(c==null)return!0;if(this._sceneListenerOnImageMap.has(c)||(this._addListenerOnImage(c),this._sceneListenerOnImageMap.add(c)),this._drawingManagerService.getDrawingByParam({unitId:e,subUnitId:r,drawingId:s})==null)return;const g=I.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),u=c.getObject(g);if(u==null)return;if(!(u instanceof b.Image)){this._messageService.show({type:W.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}const d=c.getTransformer();d==null||d.clearControls();const f=new ce(`${g}-crop`,{srcRect:u.srcRect,prstGeom:u.prstGeom,applyTransform:u.calculateTransformWithSrcRect()});c.addObject(f,u.getLayerIndex()+1).attachTransformerTo(f),d==null||d.createControlForCopper(f),this._addHoverForImageCopper(f),u.openRenderByCropper(),d==null||d.refreshControls(),f.makeDirty(!0),this._drawingManagerService.focusDrawing([{unitId:e,subUnitId:r,drawingId:s}])}))}_searchCropObject(t){const n=t.getAllObjects();for(const e of n)if(e instanceof ce)return e}_initCloseCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(n.id!==ee.id)return;const e=this._univerInstanceService.getFocusedUnit();if(e==null)return;const r=e.getUnitId(),s=this._renderManagerService.getRenderById(r),o=s==null?void 0:s.scene;if(o==null)return!0;const c=this._searchCropObject(o);if(c==null)return;const l=this._getApplyObjectByCropObject(c);if(l==null)return;const g=o.getTransformerByCreate();g.detachFrom(c),g.clearCopperControl();const u=this._getSrcRectByTransformState(l,c),d=this._drawingManagerService.getDrawingOKey(l.oKey);if(d!=null){const{left:f,top:p,height:S,width:v}=c;this._drawingManagerService.featurePluginUpdateNotification([{...d,transform:{...d.transform,left:f,top:p,height:S,width:v},srcRect:u.srcRectAngle}])}l.setSrcRect({...u.srcRectAngle}),l.closeRenderByCropper(),l.makeDirty(!0),c==null||c.dispose()}));const t=this._univerInstanceService.getCurrentTypeOfUnit$(h.UniverInstanceType.UNIVER_SHEET).pipe(Ee.filter(n=>!!n),Ee.switchMap(n=>n.activeSheet$));this.disposeWithMe(t.subscribe(()=>{this._commandService.syncExecuteCommand(ee.id)}))}_getApplyObjectByCropObject(t){const n=t.oKey,e=n.slice(0,n.length-5),r=t.getScene().getObject(e);return r==null?null:r}_addListenerOnImage(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof ce))return;const{left:c,top:l,height:g,width:u,angle:d}=o;e={left:c,top:l,height:g,width:u,angle:d},n.clearCopperControl()})),this.disposeWithMe(n.changeEnd$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof ce))return;const{left:c,top:l,height:g,width:u,angle:d}=o;if(!h.checkIfMove({left:c,top:l,height:g,width:u,angle:d},e))return;const f=this._getApplyObjectByCropObject(o);if(f==null)return;const p=this._getSrcRectByTransformState(f,o);o.refreshSrcRect(p.srcRect,f.getState()),n.createControlForCopper(o)})),this._endCropListener(t)}_addHoverForImageCopper(t){this.disposeWithMe(t.onPointerEnter$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.MOVE})),this.disposeWithMe(t.onPointerLeave$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.DEFAULT}))}_endCropListener(t){const n=t.getTransformerByCreate();this.disposeWithMe(n.clearControl$.subscribe(e=>{e===!0&&this._commandService.syncExecuteCommand(ee.id)}))}_getSrcRectByTransformState(t,n){const{left:e,top:r,height:s,width:o,strokeWidth:c,angle:l}=n,{left:g,top:u,width:d,height:f,angle:p,strokeWidth:S}=t,v=e-g,C=r-u,D={left:v,top:C,right:d-v-o,bottom:f-C-s},_={...D};if(p!==0){const O=e+o/2,y=r+s/2,N=new b.Vector2(O,y),P=d/2+g,R=f/2+u,E=new b.Vector2(P,R),T=new b.Vector2(g,u);T.rotateByPoint(b.degToRad(p),E);const M=T.clone();M.rotateByPoint(b.degToRad(-p),N);const j=e-M.x,L=r-M.y;_.left=j,_.top=L,_.right=d-j-o,_.bottom=f-L-s}return{srcRect:D,srcRectAngle:_}}};pe=et([h.OnLifecycle(h.LifecycleStages.Rendered,pe),re(0,h.ICommandService),re(1,I.IDrawingManagerService),re(2,b.IRenderManagerService),re(3,h.IUniverInstanceService),re(4,we.IMessageService),re(5,h.Inject(h.LocaleService))],pe);var nt=Object.defineProperty,tt=Object.getOwnPropertyDescriptor,rt=(a,t,n,e)=>{for(var r=e>1?void 0:e?tt(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&nt(t,n,r),r},te=(a,t)=>(n,e)=>t(n,e,a);const Me=50;let Ce=class extends h.Disposable{constructor(a,t,n,e,r,s,o){super(),this._commandService=a,this._renderManagerService=t,this._drawingManagerService=n,this._dialogService=e,this._imageIoService=r,this._currentUniverService=s,this._drawingRenderService=o,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._commandExecutedListener(),this._imageUpdateListener()}_recoveryImages(){const a=this._drawingManagerService.drawingManagerData,t=Ie(this._currentUniverService);if(t==null)return;const{unitId:n,subUnitId:e}=t;Object.keys(a).forEach(r=>{Object.keys(a[r]).forEach(s=>{const o=a[r][s].data;o==null||r!==n||s!==e||Object.keys(o).forEach(c=>{o[c]&&this._insertImages([{unitId:r,subUnitId:s,drawingId:c}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(a=>{if(a.id===be.id){const t=a.params;if(t==null)return;this._resetImageSize(t)}}))}_getSceneAndTransformerByDrawingSearch(a){if(a==null)return;const t=this._renderManagerService.getRenderById(a),n=t==null?void 0:t.scene;if(n==null)return null;const e=n.getTransformerByCreate();return{scene:n,transformer:e}}_resetImageSize(a){const t=[],n=[];a.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e,c=this._getSceneAndTransformerByDrawingSearch(r);if(c==null)return;const{scene:l}=c,g=I.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),u=l.getObject(g);if(u==null)return!0;const d=this._drawingManagerService.getDrawingByParam(e);if(d==null)return!0;if(d.drawingType!==I.DrawingTypeEnum.DRAWING_IMAGE)return;u.resetSize();const{width:f,height:p}=u.getNativeSize();n.includes(l)===!1&&n.push(l),t.push({...d,transform:{...d.transform,height:p,width:f,angle:0},srcRect:null,prstGeom:null})}),this._drawingManagerService.featurePluginUpdateNotification(t),n.forEach(e=>{e.getTransformerByCreate().refreshControls().changeNotification()}),this._drawingManagerService.focusDrawing(a)}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(a=>{this._insertImages(a)}))}_insertImages(a){a.forEach(async t=>{var g;const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n),o=(g=Ie(this._currentUniverService))==null?void 0:g.subUnitId;if(s==null||o!==e)return;const c=this._drawingManagerService.getDrawingByParam(t);if(c==null)return;const l=await this._drawingRenderService.renderImage(c,s.scene);l!=null&&(this._addHoverForImage(l),this._addDialogForImage(l))})}_imageUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(a=>{a.forEach(t=>{const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._drawingManagerService.getDrawingByParam(t);if(s==null)return;const{transform:o,drawingType:c,srcRect:l,prstGeom:g,source:u,imageSourceType:d}=s;if(c!==I.DrawingTypeEnum.DRAWING_IMAGE)return;const f=this._getSceneAndTransformerByDrawingSearch(n);if(f==null)return;const{scene:p,transformer:S}=f;if(o==null)return!0;const v=I.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:r}),C=p.getObject(v);if(C==null)return!0;C.setSrcRect(l),C.setPrstGeom(g)})}))}_addHoverForImage(a){this.disposeWithMe(h.toDisposable(a.onPointerEnter$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.GRAB}))),this.disposeWithMe(h.toDisposable(a.onPointerLeave$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.DEFAULT})))}_addDialogForImage(a){this.disposeWithMe(h.toDisposable(a.onDblclick$.subscribeEvent(()=>{var c;const t=`${a.oKey}-viewer-dialog`,n=a.getNativeSize(),e=window.innerWidth-Me,r=window.innerHeight-Me,s=this._adjustImageSize(n.width,n.height,e,r),o=this._dialogService.open({width:s.width,id:t,style:{margin:"0",top:"50%",left:"50%",transform:"translate(-50%, -50%)"},children:{label:{name:We,props:{src:(c=a.getNative())==null?void 0:c.src,width:s.width,height:s.height}}},destroyOnClose:!0,draggable:!1,onClose:()=>{this._dialogService.close(t),o.dispose()}})})))}_adjustImageSize(a,t,n,e){if(a<=n&&t<=e)return{width:a,height:t};const r=n/a,s=e/t,o=Math.min(r,s);return{width:Math.floor(a*o),height:Math.floor(t*o)}}};Ce=rt([h.OnLifecycle(h.LifecycleStages.Rendered,Ce),te(0,h.ICommandService),te(1,b.IRenderManagerService),te(2,I.IDrawingManagerService),te(3,we.IDialogService),te(4,I.IImageIoService),te(5,h.IUniverInstanceService),te(6,h.Inject(exports.DrawingRenderService))],Ce);var at=Object.defineProperty,it=Object.getOwnPropertyDescriptor,ot=(a,t,n,e)=>{for(var r=e>1?void 0:e?it(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&at(t,n,r),r},De=(a,t)=>(n,e)=>t(n,e,a);const st="DRAWING_UI_PLUGIN";var _e;exports.UniverDrawingUIPlugin=(_e=class extends h.Plugin{constructor(t,n,e){super(),this._injector=n,this._localeService=e}onStarting(t){this._initDependencies(t)}_initDependencies(t){[[exports.DrawingRenderService],[he],[fe],[pe],[Ce]].forEach(e=>t.add(e))}},J(_e,"pluginName",st),_e);exports.UniverDrawingUIPlugin=ot([De(1,h.Inject(h.Injector)),De(2,h.Inject(h.LocaleService))],exports.UniverDrawingUIPlugin);exports.AutoImageCropOperation=le;exports.COMPONENT_IMAGE_POPUP_MENU=xe;exports.CloseImageCropOperation=ee;exports.DrawingCommonPanel=An;exports.ImageCropperObject=ce;exports.ImagePopupMenu=Ve;exports.ImageResetSizeOperation=be;exports.OpenImageCropOperation=ve;exports.SetDrawingAlignOperation=Se;exports.getUpdateParams=me;
|
package/lib/es/index.js
CHANGED
|
@@ -3,12 +3,10 @@ var Ot = (a, n, e) => n in a ? Mt(a, n, { enumerable: !0, configurable: !0, writ
|
|
|
3
3
|
var Q = (a, n, e) => Ot(a, typeof n != "symbol" ? n + "" : n, e);
|
|
4
4
|
import { getDrawingShapeKeyByDrawingSearch as G, DrawingTypeEnum as te, ImageSourceType as Nt, IDrawingManagerService as ne, IImageIoService as rt, ArrangeTypeEnum as Se } from "@univerjs/drawing";
|
|
5
5
|
import { Group as pe, DRAWING_OBJECT_LAYER_INDEX as ze, Image as We, IRenderManagerService as ge, getGroupState as Dt, transformObjectOutOfGroup as Tt, RENDER_CLASS_TYPE as Xe, Shape as Bt, Rect as jt, Canvas as Ut, precisionTo as be, CURSOR_TYPE as Te, Vector2 as xe, degToRad as Je } from "@univerjs/engine-render";
|
|
6
|
-
import { UniverInstanceType as Re, LocaleService as Z, debounce as Ie, CommandType as we, ICommandService as ce, Tools as Ht, Disposable as Ue, checkIfMove as at, toDisposable as Ce, OnLifecycle as He, LifecycleStages as Le, IUniverInstanceService as Fe, Plugin as Lt } from "@univerjs/core";
|
|
7
|
-
import {
|
|
8
|
-
import
|
|
9
|
-
import { Button as ie, InputNumber as de, Checkbox as At, Select as ot, Dropdown as Vt, MessageType as qe } from "@univerjs/design";
|
|
6
|
+
import { UniverInstanceType as Re, useDependency as x, LocaleService as Z, debounce as Ie, CommandType as we, ICommandService as ce, Tools as Ht, Disposable as Ue, checkIfMove as at, toDisposable as Ce, OnLifecycle as He, LifecycleStages as Le, IUniverInstanceService as Fe, Inject as se, Injector as it, Plugin as Lt } from "@univerjs/core";
|
|
7
|
+
import c, { forwardRef as Y, useRef as ot, createElement as X, useState as L, useEffect as ve } from "react";
|
|
8
|
+
import { Button as ie, InputNumber as de, Checkbox as At, Select as st, Dropdown as Vt, MessageType as qe } from "@univerjs/design";
|
|
10
9
|
import T from "clsx";
|
|
11
|
-
import { Inject as se, Injector as st } from "@wendellhu/redi";
|
|
12
10
|
import { ComponentManager as xt, IMenuService as Gt, IMessageService as Wt, IDialogService as $t } from "@univerjs/ui";
|
|
13
11
|
import { filter as kt, switchMap as zt } from "rxjs";
|
|
14
12
|
function Ft(a, n, e, t) {
|
|
@@ -134,7 +132,7 @@ var $ = function() {
|
|
|
134
132
|
n.indexOf(t[r]) < 0 && Object.prototype.propertyIsEnumerable.call(a, t[r]) && (e[t[r]] = a[t[r]]);
|
|
135
133
|
return e;
|
|
136
134
|
}, J = Y(function(a, n) {
|
|
137
|
-
var e = a.icon, t = a.id, r = a.className, o = a.extend, i = Xt(a, ["icon", "id", "className", "extend"]), s = "univerjs-icon univerjs-icon-".concat(t, " ").concat(r || "").trim(), l =
|
|
135
|
+
var e = a.icon, t = a.id, r = a.className, o = a.extend, i = Xt(a, ["icon", "id", "className", "extend"]), s = "univerjs-icon univerjs-icon-".concat(t, " ").concat(r || "").trim(), l = ot("_".concat(Qt()));
|
|
138
136
|
return ct(e, "".concat(t), { defIds: e.defIds, idSuffix: l.current }, $({ ref: n, className: s }, i), o);
|
|
139
137
|
});
|
|
140
138
|
function ct(a, n, e, t, r) {
|
|
@@ -469,7 +467,7 @@ const Ke = {
|
|
|
469
467
|
});
|
|
470
468
|
}
|
|
471
469
|
const l = (g) => g ? "block" : "none";
|
|
472
|
-
return /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelGrid, m.imageCommonPanelBorder), style: { display: l(t) } }, /* @__PURE__ */ c.createElement("div", { className: m.imageCommonPanelRow }, /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn, m.imageCommonPanelTitle) }, /* @__PURE__ */ c.createElement("div", null, e.t("image-panel.align.title")))), /* @__PURE__ */ c.createElement("div", { className: m.imageCommonPanelRow }, /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn) }, /* @__PURE__ */ c.createElement(
|
|
470
|
+
return /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelGrid, m.imageCommonPanelBorder), style: { display: l(t) } }, /* @__PURE__ */ c.createElement("div", { className: m.imageCommonPanelRow }, /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn, m.imageCommonPanelTitle) }, /* @__PURE__ */ c.createElement("div", null, e.t("image-panel.align.title")))), /* @__PURE__ */ c.createElement("div", { className: m.imageCommonPanelRow }, /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn) }, /* @__PURE__ */ c.createElement(st, { value: r, options: i, onChange: s }))));
|
|
473
471
|
}, ke = {
|
|
474
472
|
id: "sheet.operation.open-image-crop",
|
|
475
473
|
type: we.OPERATION,
|
|
@@ -488,7 +486,7 @@ const je = {
|
|
|
488
486
|
const n = x(ce), e = x(Z), { drawings: t, cropperShow: r } = a;
|
|
489
487
|
if (t[0] == null)
|
|
490
488
|
return;
|
|
491
|
-
const [i, s] = L(j.FREE), l =
|
|
489
|
+
const [i, s] = L(j.FREE), l = ot(!1), g = [
|
|
492
490
|
{
|
|
493
491
|
label: e.t("image-panel.crop.mode"),
|
|
494
492
|
value: j.FREE
|
|
@@ -553,7 +551,7 @@ const je = {
|
|
|
553
551
|
};
|
|
554
552
|
return /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelGrid, m.imageCommonPanelBorder), style: { display: d(r) } }, /* @__PURE__ */ c.createElement("div", { className: m.imageCommonPanelRow }, /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn, m.imageCommonPanelTitle) }, /* @__PURE__ */ c.createElement("div", null, e.t("image-panel.crop.title")))), /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelRow, m.imageCommonPanelRowVertical) }, /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn, m.imageCommonPanelSpan2) }, /* @__PURE__ */ c.createElement(ie, { size: "small", onClick: () => {
|
|
555
553
|
h(i);
|
|
556
|
-
} }, /* @__PURE__ */ c.createElement("span", { className: m.imageCommonPanelInline }, /* @__PURE__ */ c.createElement(gt, null), e.t("image-panel.crop.start")))), /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn, m.imageCommonPanelSpan2) }, /* @__PURE__ */ c.createElement(
|
|
554
|
+
} }, /* @__PURE__ */ c.createElement("span", { className: m.imageCommonPanelInline }, /* @__PURE__ */ c.createElement(gt, null), e.t("image-panel.crop.start")))), /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn, m.imageCommonPanelSpan2) }, /* @__PURE__ */ c.createElement(st, { value: i, options: g, onChange: u }))));
|
|
557
555
|
}, On = (a) => {
|
|
558
556
|
const n = x(Z), e = x(ge), t = x(ne), { hasGroup: r, drawings: o } = a, [i, s] = L(!1), [l, g] = L(!0), [u, d] = L(!0), h = (p) => p ? "block" : "none", f = () => {
|
|
559
557
|
const p = t.getFocusDrawings(), { unitId: E, subUnitId: _ } = p[0], M = Ht.generateRandomId(10), S = Dt(0, 0, p.map((y) => y.transform || {})), R = {
|
|
@@ -634,7 +632,7 @@ const je = {
|
|
|
634
632
|
}, style: { display: h(l) } }, /* @__PURE__ */ c.createElement("span", { className: m.imageCommonPanelInline }, /* @__PURE__ */ c.createElement(ut, null), n.t("image-panel.group.group")))), /* @__PURE__ */ c.createElement("div", { className: T(m.imageCommonPanelColumn, m.imageCommonPanelSpan2, m.imageCommonPanelColumnCenter) }, /* @__PURE__ */ c.createElement(ie, { size: "small", onClick: () => {
|
|
635
633
|
w();
|
|
636
634
|
}, style: { display: h(u) } }, /* @__PURE__ */ c.createElement("span", { className: m.imageCommonPanelInline }, /* @__PURE__ */ c.createElement(Ct, null), n.t("image-panel.group.unGroup"))))));
|
|
637
|
-
},
|
|
635
|
+
}, gr = (a) => {
|
|
638
636
|
const n = x(ne), e = x(ge), t = x(Z), { drawings: r, hasArrange: o = !0, hasTransform: i = !0, hasAlign: s = !0, hasCropper: l = !0, hasGroup: g = !0 } = a, u = r[0];
|
|
639
637
|
if (u == null)
|
|
640
638
|
return;
|
|
@@ -1208,7 +1206,7 @@ let Oe = class extends Ue {
|
|
|
1208
1206
|
};
|
|
1209
1207
|
Oe = zn([
|
|
1210
1208
|
He(Le.Rendered, Oe),
|
|
1211
|
-
fe(0, se(
|
|
1209
|
+
fe(0, se(it)),
|
|
1212
1210
|
fe(1, se(xt)),
|
|
1213
1211
|
fe(2, Gt),
|
|
1214
1212
|
fe(3, ce),
|
|
@@ -1789,14 +1787,14 @@ let nt = (Ge = class extends Lt {
|
|
|
1789
1787
|
}
|
|
1790
1788
|
}, Q(Ge, "pluginName", tr), Ge);
|
|
1791
1789
|
nt = er([
|
|
1792
|
-
tt(1, se(
|
|
1790
|
+
tt(1, se(it)),
|
|
1793
1791
|
tt(2, se(Z))
|
|
1794
1792
|
], nt);
|
|
1795
1793
|
export {
|
|
1796
1794
|
je as AutoImageCropOperation,
|
|
1797
1795
|
An as COMPONENT_IMAGE_POPUP_MENU,
|
|
1798
1796
|
oe as CloseImageCropOperation,
|
|
1799
|
-
|
|
1797
|
+
gr as DrawingCommonPanel,
|
|
1800
1798
|
Be as DrawingRenderService,
|
|
1801
1799
|
Ee as ImageCropperObject,
|
|
1802
1800
|
Ln as ImagePopupMenu,
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { Disposable, ICommandService, LocaleService } from '@univerjs/core';
|
|
1
|
+
import { Disposable, ICommandService, Injector, LocaleService } from '@univerjs/core';
|
|
2
2
|
import { ComponentManager, IMenuService } from '@univerjs/ui';
|
|
3
|
-
import { Injector } from '@wendellhu/redi';
|
|
4
3
|
|
|
5
4
|
export declare class DrawingUIController extends Disposable {
|
|
6
5
|
private readonly _injector;
|
package/lib/types/plugin.d.ts
CHANGED
package/lib/umd/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(y,S){typeof exports=="object"&&typeof module<"u"?S(exports,require("@univerjs/drawing"),require("@univerjs/engine-render"),require("@univerjs/core"),require("@wendellhu/redi/react-bindings"),require("react"),require("@univerjs/design"),require("clsx"),require("@wendellhu/redi"),require("@univerjs/ui"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/drawing","@univerjs/engine-render","@univerjs/core","@wendellhu/redi/react-bindings","react","@univerjs/design","clsx","@wendellhu/redi","@univerjs/ui","rxjs"],S):(y=typeof globalThis<"u"?globalThis:y||self,S(y.UniverDrawingUi={},y.UniverDrawing,y.UniverEngineRender,y.UniverCore,y["@wendellhu/redi/react-bindings"],y.React,y.UniverDesign,y.clsx,y["@wendellhu/redi"],y.UniverUi,y.rxjs))})(this,function(y,S,b,v,z,i,$,L,Q,he,Me){"use strict";var Rn=Object.defineProperty;var zn=(y,S,b)=>S in y?Rn(y,S,{enumerable:!0,configurable:!0,writable:!0,value:b}):y[S]=b;var ne=(y,S,b)=>zn(y,typeof S!="symbol"?S+"":S,b);var Ee;function xe(a,t,n,e){const r=e.getDrawingByParam(a);if(r==null)return;const s=S.getDrawingShapeKeyByDrawingSearch(a),o=n.getObject(s);if(o&&!(o instanceof b.Group))return;if(o!=null){o.addObject(t);return}const l=new b.Group(s);n.addObject(l,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(l),l.addObject(t);const{transform:c}=r;c&&l.transformByState({left:c.left,top:c.top,angle:c.angle})}function ye(a){var r;const t=a.getFocusedUnit();if(t==null)return;const n=t.getUnitId();let e;return t.type===v.UniverInstanceType.UNIVER_SHEET?e=(r=t.getActiveSheet())==null?void 0:r.getSheetId():(t.type===v.UniverInstanceType.UNIVER_DOC||t.type===v.UniverInstanceType.UNIVER_SLIDE)&&(e=n),{unitId:n,subUnitId:e}}var Fe=Object.defineProperty,Ye=Object.getOwnPropertyDescriptor,Ze=(a,t,n,e)=>{for(var r=e>1?void 0:e?Ye(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Fe(t,n,r),r},De=(a,t)=>(n,e)=>t(n,e,a);y.DrawingRenderService=class{constructor(t,n){this._drawingManagerService=t,this._imageIoService=n}async renderImage(t,n){const{transform:e,drawingType:r,source:s,imageSourceType:o,srcRect:l,prstGeom:c,groupId:u,unitId:g,subUnitId:d,drawingId:h}=t;if(r!==S.DrawingTypeEnum.DRAWING_IMAGE||!this._drawingManagerService.getDrawingVisible()||e==null)return;const{left:f,top:_,width:w,height:p,angle:N,flipX:I,flipY:U,skewX:P,skewY:j}=e,E=S.getDrawingShapeKeyByDrawingSearch({unitId:g,subUnitId:d,drawingId:h}),D=n.getObject(E);if(D!=null){D.transformByState({left:f,top:_,width:w,height:p,angle:N,flipX:I,flipY:U,skewX:P,skewY:j});return}const M=this._drawingManagerService.getDrawingOrder(g,d),B=M.indexOf(h),O={...e,zIndex:B===-1?M.length-1:B},H=this._imageIoService.getImageSourceCache(s,o);let G=!1;if(H!=null)O.image=H;else{if(o===S.ImageSourceType.UUID)try{O.url=await this._imageIoService.getImage(s)}catch(ge){console.error(ge);return}else O.url=s;G=!0}O.printable=!0;const x=new b.Image(E,O);if(G&&this._imageIoService.addImageSourceCache(s,o,x.getNative()),!this._drawingManagerService.getDrawingVisible())return;const F=n.addObject(x,b.DRAWING_OBJECT_LAYER_INDEX);return this._drawingManagerService.getDrawingEditable()&&F.attachTransformerTo(x),u&&xe({drawingId:u,unitId:g,subUnitId:d},x,n,this._drawingManagerService),c!=null&&x.setPrstGeom(c),l!=null&&x.setSrcRect(l),x}renderDrawing(t,n){const e=this._drawingManagerService.getDrawingByParam(t);if(e!=null)switch(e.drawingType){case S.DrawingTypeEnum.DRAWING_IMAGE:return this.renderImage(e,n)}}},y.DrawingRenderService=Ze([De(0,S.IDrawingManagerService),De(1,S.IImageIoService)],y.DrawingRenderService);function se(a,t){const n=[];return a.forEach(e=>{const{oKey:r,left:s,top:o,height:l,width:c,angle:u}=e,g=t.getDrawingOKey(r);if(g==null)return n.push(null),!0;const{unitId:d,subUnitId:h,drawingId:f,drawingType:_}=g,w={unitId:d,subUnitId:h,drawingId:f,drawingType:_,transform:{left:s,top:o,height:l,width:c,angle:u}};_===S.DrawingTypeEnum.DRAWING_IMAGE&&(w.srcRect=e.srcRect),n.push(w)}),n}var K=function(){return K=Object.assign||function(a){for(var t,n=1,e=arguments.length;n<e;n++){t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(a[r]=t[r])}return a},K.apply(this,arguments)},Xe=function(a,t){var n={};for(var e in a)Object.prototype.hasOwnProperty.call(a,e)&&t.indexOf(e)<0&&(n[e]=a[e]);if(a!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,e=Object.getOwnPropertySymbols(a);r<e.length;r++)t.indexOf(e[r])<0&&Object.prototype.propertyIsEnumerable.call(a,e[r])&&(n[e[r]]=a[e[r]]);return n},X=i.forwardRef(function(a,t){var n=a.icon,e=a.id,r=a.className,s=a.extend,o=Xe(a,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(e," ").concat(r||"").trim(),c=i.useRef("_".concat(Qe()));return Oe(n,"".concat(e),{defIds:n.defIds,idSuffix:c.current},K({ref:t,className:l},o),s)});function Oe(a,t,n,e,r){return i.createElement(a.tag,K(K({key:t},qe(a,n,r)),e),(Je(a,n).children||[]).map(function(s,o){return Oe(s,"".concat(t,"-").concat(a.tag,"-").concat(o),n,void 0,r)}))}function qe(a,t,n){var e=K({},a.attrs);n!=null&&n.colorChannel1&&e.fill==="colorChannel1"&&(e.fill=n.colorChannel1);var r=t.defIds;return!r||r.length===0||(a.tag==="use"&&e["xlink:href"]&&(e["xlink:href"]=e["xlink:href"]+t.idSuffix),Object.entries(e).forEach(function(s){var o=s[0],l=s[1];typeof l=="string"&&(e[o]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),e}function Je(a,t){var n,e=t.defIds;return!e||e.length===0?a:a.tag==="defs"&&(!((n=a.children)===null||n===void 0)&&n.length)?K(K({},a),{children:a.children.map(function(r){return typeof r.attrs.id=="string"&&e&&e.indexOf(r.attrs.id)>-1?K(K({},r),{attrs:K(K({},r.attrs),{id:r.attrs.id+t.idSuffix})}):r})}):a}function Qe(){return Math.random().toString(36).substring(2,8)}X.displayName="UniverIcon";var en={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"colorChannel1",d:"M11.0363 12.2367V14.0367C11.0363 14.3681 11.3049 14.6367 11.6363 14.6367C11.9676 14.6367 12.2363 14.3681 12.2363 14.0367V12.2367H14.0364C14.3677 12.2367 14.6364 11.9681 14.6364 11.6367C14.6364 11.3054 14.3677 11.0367 14.0364 11.0367H12.2363V9.23672C12.2363 8.90535 11.9676 8.63672 11.6363 8.63672C11.3049 8.63672 11.0363 8.90535 11.0363 9.23672V11.0367H9.23635C8.90498 11.0367 8.63635 11.3054 8.63635 11.6367C8.63635 11.9681 8.90498 12.2367 9.23635 12.2367H11.0363Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.56365 1.36377C1.90091 1.36377 1.36365 1.90103 1.36365 2.56377V6.16377C1.36365 6.82651 1.90091 7.36377 2.56365 7.36377H6.16365C6.82639 7.36377 7.36365 6.82651 7.36365 6.16377V2.56377C7.36365 1.90103 6.82639 1.36377 6.16365 1.36377H2.56365zM6.16365 2.56377H2.56365L2.56365 6.16377H6.16365V2.56377zM2.56365 8.63647C1.90091 8.63647 1.36365 9.17373 1.36365 9.83647V13.4365C1.36365 14.0992 1.90091 14.6365 2.56365 14.6365H6.16365C6.82639 14.6365 7.36365 14.0992 7.36365 13.4365V9.83647C7.36365 9.17373 6.82639 8.63647 6.16365 8.63647H2.56365zM6.16365 9.83647H2.56365L2.56365 13.4365H6.16365V9.83647zM9.83635 7.36377C9.17361 7.36377 8.63635 6.82651 8.63635 6.16377V2.56377C8.63635 1.90103 9.17361 1.36377 9.83635 1.36377H13.4364C14.0991 1.36377 14.6364 1.90103 14.6364 2.56377V6.16377C14.6364 6.82651 14.0991 7.36377 13.4364 7.36377H9.83635zM9.83635 6.16377V2.56377L13.4364 2.56377V6.16377H9.83635z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ne=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"autofill",ref:t,icon:en}))});Ne.displayName="Autofill";var nn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.0045 4.4334C14.8881 4.4334 15.6045 3.71705 15.6045 2.8334 15.6045 1.94974 14.8881 1.2334 14.0045 1.2334H3.70449C2.82084 1.2334 2.10449 1.94974 2.10449 2.8334 2.10449 3.71705 2.82084 4.4334 3.70449 4.4334H14.0045zM14.4045 2.8334C14.4045 3.05431 14.2254 3.2334 14.0045 3.2334H3.70449C3.48358 3.2334 3.30449 3.05431 3.30449 2.8334 3.30449 2.61248 3.48358 2.4334 3.70449 2.4334H14.0045C14.2254 2.4334 14.4045 2.61249 14.4045 2.8334zM14.1544 8.5999C15.038 8.5999 15.7544 7.88356 15.7544 6.9999 15.7544 6.11625 15.038 5.3999 14.1544 5.3999H3.85439C2.97074 5.3999 2.25439 6.11625 2.25439 6.9999 2.25439 7.88356 2.97074 8.5999 3.85439 8.5999H14.1544zM14.5544 6.9999C14.5544 7.22082 14.3753 7.3999 14.1544 7.3999H3.85439C3.63348 7.3999 3.45439 7.22082 3.45439 6.9999 3.45439 6.77899 3.63348 6.5999 3.85439 6.5999H14.1544C14.3753 6.5999 14.5544 6.77899 14.5544 6.9999z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M8.57975 14.5902L6.58023 12.5907C6.34591 12.3564 6.34591 11.9765 6.58023 11.7421 6.81454 11.5078 7.19444 11.5078 7.42876 11.7421L8.40449 12.7179V10.1664C8.40449 9.83504 8.67312 9.56641 9.00449 9.56641 9.33586 9.56641 9.60449 9.83504 9.60449 10.1664V12.7179L10.5802 11.7421C10.8145 11.5078 11.1944 11.5078 11.4288 11.7421 11.6631 11.9765 11.6631 12.3564 11.4288 12.5907L9.42923 14.5902M8.57975 14.5902C8.58121 14.5917 8.58268 14.5931 8.58416 14.5946 8.64077 14.6502 8.70566 14.6923 8.77482 14.7209 8.84557 14.7502 8.92314 14.7664 9.00449 14.7664 9.08585 14.7664 9.16342 14.7502 9.23416 14.7209 9.30332 14.6923 9.36821 14.6502 9.42482 14.5946"}}]},Te=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"bottom-single",ref:t,icon:nn}))});Te.displayName="BottomSingle";var tn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.97705 7.51296C5.97705 7.18159 6.24568 6.91296 6.57705 6.91296H8.48632C8.81769 6.91296 9.08632 7.18159 9.08632 7.51296 9.08632 7.84433 8.81769 8.11296 8.48632 8.11296H6.57705C6.24568 8.11296 5.97705 7.84433 5.97705 7.51296zM6.57705 9.41028C6.24568 9.41028 5.97705 9.67891 5.97705 10.0103 5.97705 10.3416 6.24568 10.6103 6.57705 10.6103H10.8199C11.1512 10.6103 11.4199 10.3416 11.4199 10.0103 11.4199 9.67891 11.1512 9.41028 10.8199 9.41028H6.57705z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.51074 2.37063C3.51074 1.48697 4.22709 0.77063 5.11074 0.77063H9.80318L9.81294 0.770708C9.97168 0.768161 10.1311 0.82824 10.2511 0.95055L14.4317 5.21408C14.5165 5.30049 14.5697 5.406 14.5917 5.51645C14.6041 5.5644 14.6106 5.61467 14.6106 5.66648V11.6406C14.6106 12.5243 13.8943 13.2406 13.0106 13.2406H5.11074C4.22709 13.2406 3.51074 12.5243 3.51074 11.6406V2.37063ZM10.4032 4.66648V2.81964L12.6063 5.06648H10.8032C10.5823 5.06648 10.4032 4.88739 10.4032 4.66648ZM5.11074 1.97063C4.88983 1.97063 4.71074 2.14972 4.71074 2.37063V11.6406C4.71074 11.8615 4.88983 12.0406 5.11074 12.0406H13.0106C13.2316 12.0406 13.4106 11.8615 13.4106 11.6406V6.26648H10.8032C9.91953 6.26648 9.20318 5.55013 9.20318 4.66648V1.97063H5.11074Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.58916 6.6741C2.58916 6.34273 2.32053 6.0741 1.98916 6.0741C1.65779 6.0741 1.38916 6.34273 1.38916 6.6741V12.6294C1.38916 14.0653 2.55322 15.2294 3.98916 15.2294H9.41408C9.74545 15.2294 10.0141 14.9607 10.0141 14.6294C10.0141 14.298 9.74545 14.0294 9.41408 14.0294H3.98916C3.21596 14.0294 2.58916 13.4026 2.58916 12.6294V6.6741Z"}}]},Ue=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"create-copy-single",ref:t,icon:tn}))});Ue.displayName="CreateCopySingle";var rn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.38125 1.16211C6.49759 1.16211 5.78125 1.87845 5.78125 2.76211V5.6377H2.87783C1.99418 5.6377 1.27783 6.35404 1.27783 7.2377V13.2377C1.27783 14.1214 1.99418 14.8377 2.87783 14.8377H8.87783C9.76149 14.8377 10.4778 14.1214 10.4778 13.2377V10.3621H13.3813C14.2649 10.3621 14.9813 9.64577 14.9813 8.76211V2.76211C14.9813 1.87845 14.2649 1.16211 13.3813 1.16211H7.38125ZM10.4778 9.16211H13.3813C13.6022 9.16211 13.7812 8.98302 13.7812 8.76211V2.76211C13.7812 2.5412 13.6022 2.36211 13.3813 2.36211H7.38125C7.16034 2.36211 6.98125 2.5412 6.98125 2.76211V5.6377H8.87783C9.76149 5.6377 10.4778 6.35404 10.4778 7.2377V9.16211ZM6.98125 6.8377H8.87783C9.09875 6.8377 9.27783 7.01678 9.27783 7.2377V9.16211H7.38125C7.16034 9.16211 6.98125 8.98302 6.98125 8.76211V6.8377ZM5.78125 6.8377V8.76211C5.78125 9.64577 6.49759 10.3621 7.38125 10.3621H9.27783V13.2377C9.27783 13.4586 9.09875 13.6377 8.87783 13.6377H2.87783C2.65692 13.6377 2.47783 13.4586 2.47783 13.2377V7.2377C2.47783 7.01678 2.65692 6.8377 2.87783 6.8377H5.78125Z",fillRule:"evenodd",clipRule:"evenodd"}}]},je=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"group-single",ref:t,icon:rn}))});je.displayName="GroupSingle";var an={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M11.3536 6.14645C11.5488 6.34171 11.5488 6.65829 11.3536 6.85355L8.35355 9.85355C8.15829 10.0488 7.84171 10.0488 7.64645 9.85355L4.64645 6.85355C4.45118 6.65829 4.45118 6.34171 4.64645 6.14645C4.84171 5.95118 5.15829 5.95118 5.35355 6.14645L8 8.79289L10.6464 6.14645C10.8417 5.95118 11.1583 5.95118 11.3536 6.14645Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Be=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"more-down-single",ref:t,icon:an}))});Be.displayName="MoreDownSingle";var on={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 2.96401C1.25 3.84767 1.96634 4.56401 2.85 4.56401H13.15C14.0337 4.56401 14.75 3.84767 14.75 2.96401C14.75 2.08036 14.0337 1.36401 13.15 1.36401H2.85C1.96635 1.36401 1.25 2.08036 1.25 2.96401ZM2.85 3.36401C2.62909 3.36401 2.45 3.18493 2.45 2.96401C2.45 2.7431 2.62909 2.56401 2.85 2.56401H13.15C13.3709 2.56401 13.55 2.7431 13.55 2.96401C13.55 3.18493 13.3709 3.36401 13.15 3.36401H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 11.6118C5.80995 11.3774 6.18985 11.3774 6.42417 11.6118L7.3999 12.5875V6.36951C7.3999 6.03814 7.66853 5.76951 7.9999 5.76951C8.33127 5.76951 8.5999 6.03814 8.5999 6.36951V12.5875L9.57564 11.6118C9.80995 11.3774 10.1899 11.3774 10.4242 11.6118C10.6585 11.8461 10.6585 12.226 10.4242 12.4603L8.4324 14.452C8.32324 14.5655 8.16982 14.6362 7.9999 14.6362C7.82998 14.6362 7.67655 14.5655 7.56739 14.452L5.57564 12.4603C5.34132 12.226 5.34132 11.8461 5.57564 11.6118Z"}}]},Le=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"move-down-single",ref:t,icon:on}))});Le.displayName="MoveDownSingle";var sn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 13.036C1.25 12.1523 1.96634 11.436 2.85 11.436H13.15C14.0337 11.436 14.75 12.1523 14.75 13.036C14.75 13.9196 14.0337 14.636 13.15 14.636H2.85C1.96635 14.636 1.25 13.9196 1.25 13.036ZM2.85 12.636C2.62909 12.636 2.45 12.8151 2.45 13.036C2.45 13.2569 2.62909 13.436 2.85 13.436H13.15C13.3709 13.436 13.55 13.2569 13.55 13.036C13.55 12.8151 13.3709 12.636 13.15 12.636H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 4.38825C5.80995 4.62256 6.18985 4.62256 6.42417 4.38825L7.3999 3.41251V9.63049C7.3999 9.96186 7.66853 10.2305 7.9999 10.2305C8.33127 10.2305 8.5999 9.96186 8.5999 9.63049V3.41251L9.57564 4.38825C9.80995 4.62256 10.1899 4.62256 10.4242 4.38825C10.6585 4.15393 10.6585 3.77403 10.4242 3.53972L8.4324 1.54796C8.32324 1.43445 8.16982 1.36382 7.9999 1.36382C7.82998 1.36382 7.67655 1.43446 7.56739 1.54797L5.57564 3.53972C5.34132 3.77403 5.34132 4.15393 5.57564 4.38825Z"}}]},Ae=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"move-up-single",ref:t,icon:sn}))});Ae.displayName="MoveUpSingle";var ln={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.82994 1.40913C7.88746 1.35161 7.95376 1.30821 8.02453 1.27893C8.09527 1.24959 8.17285 1.2334 8.2542 1.2334C8.33555 1.2334 8.41313 1.24959 8.48387 1.27893C8.55464 1.30821 8.62094 1.35161 8.67846 1.40913L10.6785 3.40913C10.9128 3.64345 10.9128 4.02335 10.6785 4.25766C10.4441 4.49198 10.0642 4.49198 9.82994 4.25766L8.8542 3.28193V5.8334C8.8542 6.16477 8.58557 6.4334 8.2542 6.4334C7.92283 6.4334 7.6542 6.16477 7.6542 5.8334V3.28193L6.67846 4.25766C6.44415 4.49198 6.06425 4.49198 5.82994 4.25766C5.59562 4.02335 5.59562 3.64345 5.82994 3.40913L7.82994 1.40913Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1.50439 9C1.50439 8.11634 2.22074 7.4 3.10439 7.4H13.4044C14.288 7.4 15.0044 8.11634 15.0044 9 15.0044 9.88366 14.2881 10.6 13.4044 10.6H3.1044C2.22074 10.6 1.50439 9.88366 1.50439 9zM3.10439 8.6C2.88348 8.6 2.70439 8.77909 2.70439 9 2.70439 9.22091 2.88348 9.4 3.1044 9.4H13.4044C13.6253 9.4 13.8044 9.22091 13.8044 9 13.8044 8.77909 13.6253 8.6 13.4044 8.6H3.10439zM1.6543 13.1665C1.6543 12.2828 2.37064 11.5665 3.2543 11.5665H13.5543C14.438 11.5665 15.1543 12.2828 15.1543 13.1665 15.1543 14.0502 14.438 14.7665 13.5543 14.7665H3.2543C2.37064 14.7665 1.6543 14.0502 1.6543 13.1665zM3.2543 12.7665C3.03338 12.7665 2.8543 12.9456 2.8543 13.1665 2.8543 13.3874 3.03338 13.5665 3.2543 13.5665H13.5543C13.7752 13.5665 13.9543 13.3874 13.9543 13.1665 13.9543 12.9456 13.7752 12.7665 13.5543 12.7665H3.2543z",fillRule:"evenodd",clipRule:"evenodd"}}]},He=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"topmost-single",ref:t,icon:ln}))});He.displayName="TopmostSingle";var cn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.46855 2.83731C7.46855 2.61639 7.64764 2.4373 7.86855 2.4373H13.8603C14.0812 2.4373 14.2603 2.61639 14.2603 2.8373V9.5049C14.2603 9.72581 14.0812 9.90489 13.8603 9.90489H12.866C12.5346 9.90489 12.266 10.1735 12.266 10.5049C12.266 10.8363 12.5346 11.1049 12.866 11.1049H13.8603C14.7439 11.1049 15.4603 10.3886 15.4603 9.5049V2.8373C15.4603 1.95365 14.7439 1.2373 13.8603 1.2373H7.86855C6.9849 1.2373 6.26855 1.95365 6.26855 2.83731V3.48688C6.26855 3.81825 6.53718 4.08688 6.86855 4.08688C7.19993 4.08688 7.46855 3.81825 7.46855 3.48688V2.83731Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.19888 5.56299C2.31522 5.56299 1.59888 6.27933 1.59888 7.16299V13.163C1.59888 14.0466 2.31522 14.763 3.19888 14.763H9.19888C10.0825 14.763 10.7989 14.0466 10.7989 13.163V7.16299C10.7989 6.27933 10.0825 5.56299 9.19888 5.56299H3.19888ZM2.79888 7.16299C2.79888 6.94207 2.97796 6.76299 3.19888 6.76299H9.19888C9.41979 6.76299 9.59888 6.94207 9.59888 7.16299V13.163C9.59888 13.3839 9.41979 13.563 9.19888 13.563H3.19888C2.97796 13.563 2.79888 13.3839 2.79888 13.163V7.16299Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ge=i.forwardRef(function(a,t){return i.createElement(X,Object.assign({},a,{id:"ungroup-single",ref:t,icon:cn}))});Ge.displayName="UngroupSingle";const m={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"},mn=a=>{const{arrangeShow:t,drawings:n}=a,e=z.useDependency(v.LocaleService),r=z.useDependency(S.IDrawingManagerService),s=u=>u?"block":"none",[o,l]=i.useState(n);i.useEffect(()=>{const u=r.focus$.subscribe(g=>{l(g)});return()=>{u.unsubscribe()}},[]);const c=u=>{const g=o[0].unitId,d=o[0].subUnitId,h=o.map(f=>f.drawingId);r.featurePluginOrderUpdateNotification({unitId:g,subUnitId:d,drawingIds:h,arrangeType:u})};return i.createElement("div",{className:m.imageCommonPanelGrid,style:{display:s(t)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,e.t("image-panel.arrange.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.forward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ae,null),e.t("image-panel.arrange.forward")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.backward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Le,null),e.t("image-panel.arrange.backward"))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.front)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(He,null),e.t("image-panel.arrange.front")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.back)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Te,null),e.t("image-panel.arrange.back"))))))},ae=20,un=20,gn=[-3600,3600],fe=300,dn=a=>{var Ke;const t=z.useDependency(v.LocaleService),n=z.useDependency(S.IDrawingManagerService),e=z.useDependency(b.IRenderManagerService),{drawings:r,transformShow:s}=a,o=r[0];if(o==null)return;const l=o.transform;if(l==null)return;const{unitId:c,subUnitId:u,drawingId:g,drawingType:d}=o,h=e.getRenderById(c),f=h==null?void 0:h.scene;if(f==null)return;const _=(Ke=f.getEngine())==null?void 0:Ke.activeScene;if(_==null)return;const w=f.getTransformerByCreate(),{width:p=0,height:N=0,left:I=0,top:U=0,angle:P=0}=l,[j,E]=i.useState(p),[D,M]=i.useState(N),[B,O]=i.useState(I),[H,G]=i.useState(U),[x,F]=i.useState(P),[ge,Ln]=i.useState(w.keepRatio),be=(C,k,R,W)=>{const{width:V,height:ee}=_,{ancestorLeft:Y,ancestorTop:Z}=f;let q=C,J=k,re=R,de=W;return C+Y<0&&(q=-Y),k+Z<0&&(J=-Z),re=V-q-Y,re<ae&&(re=ae),de=ee-J-Z,de<ae&&(de=ae),C+re+Y>V&&(q=V-R-Y),k+de+Z>ee&&(J=ee-W-Z),{limitLeft:q,limitTop:J,limitWidth:re,limitHeight:de}},ze=C=>{const{objects:k}=C,R=se(k,n);if(R.length!==1)return;const W=R[0];if(W==null)return;const{transform:V}=W;if(V==null)return;const{width:ee,height:Y,left:Z,top:q,angle:J}=V;ee!=null&&E(ee),Y!=null&&M(Y),Z!=null&&O(Z),q!=null&&G(q),J!=null&&F(J)};i.useEffect(()=>{const C=w.changeStart$.subscribe(W=>{ze(W)}),k=w.changing$.subscribe(W=>{ze(W)}),R=n.focus$.subscribe(W=>{if(W.length!==1)return;const V=n.getDrawingByParam(W[0]);if(V==null)return;const ee=V.transform;if(ee==null)return;const{width:Y,height:Z,left:q,top:J,angle:re}=ee;Y!=null&&E(Y),Z!=null&&M(Z),q!=null&&O(q),J!=null&&G(J),re!=null&&F(re)});return()=>{k.unsubscribe(),C.unsubscribe(),R.unsubscribe()}},[]);const An=v.debounce(C=>{if(C==null)return;C=Math.max(C,ae);const{limitWidth:k,limitHeight:R}=be(B,H,C,D);C=Math.min(C,k);const W={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{width:C}};if(ge){let V=C/j*D;if(V=Math.max(V,un),V>R)return;M(V),W.transform.height=V}E(C),n.featurePluginUpdateNotification([W]),w.refreshControls().changeNotification()},fe),Hn=v.debounce(C=>{if(C==null)return;C=Math.max(C,ae);const{limitHeight:k,limitWidth:R}=be(B,H,j,C);C=Math.min(C,k);const W={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{height:C}};if(ge){let V=C/D*j;if(V=Math.max(V,ae),V>R)return;E(V),W.transform.width=V}M(C),n.featurePluginUpdateNotification([W]),w.refreshControls().changeNotification()},fe),Gn=v.debounce(C=>{if(C==null)return;const{limitLeft:k}=be(C,H,j,D);C=k;const R={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{left:C}};O(C),n.featurePluginUpdateNotification([R]),w.refreshControls().changeNotification()},fe),Vn=v.debounce(C=>{if(C==null)return;const{limitTop:k}=be(B,C,j,D);C=k;const R={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{top:C}};G(C),n.featurePluginUpdateNotification([R]),w.refreshControls().changeNotification()},fe),Wn=C=>{if(C==null)return;const[k,R]=gn;C<k&&(C=k),C>R&&(C=R);const W={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{angle:C}};F(C),n.featurePluginUpdateNotification([W]),w.refreshControls().changeNotification()},$n=C=>{Ln(C),w.keepRatio=C},kn=C=>C?"block":"none";return i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:kn(s)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.transform.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.width"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:j,onChange:C=>{An(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.height"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:D,onChange:C=>{Hn(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.lock"))),i.createElement("div",{className:L(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.Checkbox,{checked:ge,onChange:$n})))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.x"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:B,onChange:C=>{Gn(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.y"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:H,onChange:C=>{Vn(C)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.rotate"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:x,onChange:Wn,className:m.imageCommonPanelInput})))))))};var T=(a=>(a.default="0",a.left="1",a.center="2",a.right="3",a.top="4",a.middle="5",a.bottom="6",a.horizon="7",a.vertical="8",a))(T||{});const pe={id:"sheet.operation.set-image-align",type:v.CommandType.OPERATION,handler:(a,t)=>!0},hn=a=>{const t=z.useDependency(v.ICommandService),n=z.useDependency(v.LocaleService),{alignShow:e}=a,[r,s]=i.useState(T.default),o=[{label:n.t("image-panel.align.default"),value:T.default},{options:[{label:n.t("image-panel.align.left"),value:T.left},{label:n.t("image-panel.align.center"),value:T.center},{label:n.t("image-panel.align.right"),value:T.right}]},{options:[{label:n.t("image-panel.align.top"),value:T.top},{label:n.t("image-panel.align.middle"),value:T.middle},{label:n.t("image-panel.align.bottom"),value:T.bottom}]},{options:[{label:n.t("image-panel.align.horizon"),value:T.horizon},{label:n.t("image-panel.align.vertical"),value:T.vertical}]}];function l(u){s(u),t.executeCommand(pe.id,{alignType:u})}const c=u=>u?"block":"none";return i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:c(e)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.align.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn)},i.createElement($.Select,{value:r,options:o,onChange:l}))))},Ce={id:"sheet.operation.open-image-crop",type:v.CommandType.OPERATION,handler:(a,t)=>!0},te={id:"sheet.operation.close-image-crop",type:v.CommandType.OPERATION,handler:(a,t)=>!0};var A=(a=>(a.FREE="0",a.R1_1="1",a.R16_9="2",a.R9_16="3",a.R5_4="4",a.R4_5="5",a.R4_3="6",a.R3_4="7",a.R3_2="8",a.R2_3="9",a))(A||{});const le={id:"sheet.operation.Auto-image-crop",type:v.CommandType.OPERATION,handler:(a,t)=>!0},fn=a=>{const t=z.useDependency(v.ICommandService),n=z.useDependency(v.LocaleService),{drawings:e,cropperShow:r}=a;if(e[0]==null)return;const[o,l]=i.useState(A.FREE),c=i.useRef(!1),u=[{label:n.t("image-panel.crop.mode"),value:A.FREE},{label:"1:1",value:A.R1_1},{label:"16:9",value:A.R16_9},{label:"9:16",value:A.R9_16},{label:"5:4",value:A.R5_4},{label:"4:5",value:A.R4_5},{label:"4:3",value:A.R4_3},{label:"3:4",value:A.R3_4},{label:"3:2",value:A.R3_2},{label:"2:3",value:A.R2_3}];i.useEffect(()=>{const f=t.onCommandExecuted(_=>{if(_.id===te.id){const w=_.params;w!=null&&w.isAuto||(c.current=!1)}});return()=>{f==null||f.dispose()}},[]);function g(f){l(f),c.current&&t.executeCommand(le.id,{cropType:f})}const d=f=>f?"block":"none",h=f=>{t.executeCommand(le.id,{cropType:f}),c.current=!0};return i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:d(r)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.crop.title")))),i.createElement("div",{className:L(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{h(o)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ue,null),n.t("image-panel.crop.start")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Select,{value:o,options:u,onChange:g}))))},pn=a=>{const t=z.useDependency(v.LocaleService),n=z.useDependency(b.IRenderManagerService),e=z.useDependency(S.IDrawingManagerService),{hasGroup:r,drawings:s}=a,[o,l]=i.useState(!1),[c,u]=i.useState(!0),[g,d]=i.useState(!0),h=p=>p?"block":"none",f=()=>{const p=e.getFocusDrawings(),{unitId:N,subUnitId:I}=p[0],U=v.Tools.generateRandomId(10),P=b.getGroupState(0,0,p.map(D=>D.transform||{})),j={unitId:N,subUnitId:I,drawingId:U,drawingType:S.DrawingTypeEnum.DRAWING_GROUP,transform:P},E=p.map(D=>{const M=D.transform||{left:0,top:0},{unitId:B,subUnitId:O,drawingId:H}=D;return{unitId:B,subUnitId:O,drawingId:H,transform:{...M,left:M.left-P.left,top:M.top-P.top},groupId:U}});e.featurePluginGroupUpdateNotification([{parent:j,children:E}])},_=p=>{if(p.drawingType!==S.DrawingTypeEnum.DRAWING_GROUP)return;const{unitId:N,subUnitId:I,drawingId:U,transform:P={width:0,height:0}}=p;if(P==null)return;const j=e.getDrawingsByGroup({unitId:N,subUnitId:I,drawingId:U});if(j.length===0)return;const E=j.map(D=>{const{transform:M}=D,{unitId:B,subUnitId:O,drawingId:H}=D,G=b.transformObjectOutOfGroup(M||{},P,P.width||0,P.height||0);return{unitId:B,subUnitId:O,drawingId:H,transform:{...M,...G},groupId:void 0}});return{parent:p,children:E}},w=()=>{const N=e.getFocusDrawings().map(I=>_(I)).filter(I=>I!=null);N.length!==0&&e.featurePluginUngroupUpdateNotification(N)};return i.useEffect(()=>{const p=s[0];if(p==null)return;const{unitId:N}=p,I=n.getRenderById(N),U=I==null?void 0:I.scene;if(U==null)return;const P=U.getTransformerByCreate(),j=P.clearControl$.subscribe(D=>{D===!0&&l(!1)}),E=P.changeStart$.subscribe(D=>{const{objects:M}=D,B=se(M,e),O=B.filter(F=>(F==null?void 0:F.drawingType)===S.DrawingTypeEnum.DRAWING_GROUP);let H=!1,G=!1;B.length>1&&(H=!0),O.length>0&&(G=!0),l(H||G),u(H),d(G)});return()=>{E.unsubscribe(),j.unsubscribe()}},[]),i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:h(r===!0?o:!1)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.group.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement($.Button,{size:"small",onClick:()=>{f()},style:{display:h(c)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(je,null),t.t("image-panel.group.group")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement($.Button,{size:"small",onClick:()=>{w()},style:{display:h(g)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ge,null),t.t("image-panel.group.unGroup"))))))},Cn=a=>{const t=z.useDependency(S.IDrawingManagerService),n=z.useDependency(b.IRenderManagerService),e=z.useDependency(v.LocaleService),{drawings:r,hasArrange:s=!0,hasTransform:o=!0,hasAlign:l=!0,hasCropper:c=!0,hasGroup:u=!0}=a,g=r[0];if(g==null)return;const{unitId:d}=g,h=n.getRenderById(d),f=h==null?void 0:h.scene;if(f==null)return;const _=f.getTransformerByCreate(),[w,p]=i.useState(!0),[N,I]=i.useState(!0),[U,P]=i.useState(!1),[j,E]=i.useState(!0),[D,M]=i.useState(!1);return i.useEffect(()=>{const B=_.clearControl$.subscribe(G=>{G===!0&&(p(!1),I(!1),P(!1),E(!1),M(!0))}),O=_.changeStart$.subscribe(G=>{const{objects:x}=G,F=se(x,t);F.length===0?(p(!1),I(!1),P(!1),E(!1),M(!0)):F.length===1?(p(!0),I(!0),P(!1),E(!0),M(!1)):(p(!0),I(!1),P(!0),E(!1),M(!1))}),H=t.focus$.subscribe(G=>{G.length===0?(p(!1),I(!1),P(!1),E(!1),M(!0)):G.length===1?(p(!0),I(!0),P(!1),E(!0),M(!1)):(p(!0),I(!1),P(!0),E(!1),M(!1))});return()=>{O.unsubscribe(),B.unsubscribe(),H.unsubscribe()}},[]),i.createElement(i.Fragment,null,i.createElement("div",{style:{display:D===!0?"block":"none",height:"100%"}},i.createElement("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100%",top:"50%",marginTop:"-100px"}},i.createElement("span",null,e.t("image-panel.null")))),i.createElement(mn,{arrangeShow:s===!0?w:!1,drawings:r}),i.createElement(dn,{transformShow:o===!0?N:!1,drawings:r}),i.createElement(hn,{alignShow:l===!0?U:!1,drawings:r}),i.createElement(fn,{cropperShow:c===!0?j:!1,drawings:r}),i.createElement(pn,{hasGroup:u,drawings:r}))},ce={imagePopupMenu:"univer-image-popup-menu",imagePopupMenuItem:"univer-image-popup-menu-item",imagePopupMenuItemIcon:"univer-image-popup-menu-item-icon",imagePopupMenuItemTitle:"univer-image-popup-menu-item-title",imagePopupMenuItemHide:"univer-image-popup-menu-item-hide",btnContainer:"univer-btn-container",btnContainerExpand:"univer-btn-container-expand"},Ve=a=>{var _,w;const t=(w=(_=a.popup)==null?void 0:_.extraProps)==null?void 0:w.menuItems;if(!t)return null;const n=z.useDependency(v.ICommandService),e=z.useDependency(v.LocaleService),[r,s]=i.useState(!1),[o,l]=i.useState(!1),c=()=>{l(!0)},u=()=>{l(!1)},g=p=>{s(p)},d=p=>{n.executeCommand(p.commandId,p.commandParams),s(!1)},h=r||o,f=t.filter(p=>!p.disable);return i.createElement("div",{onMouseEnter:c,onMouseLeave:u},i.createElement($.Dropdown,{placement:"bottomLeft",trigger:["click"],overlay:i.createElement("ul",{className:ce.imagePopupMenu},f.map(p=>i.createElement("li",{key:p.index,onClick:()=>d(p),className:ce.imagePopupMenuItem},i.createElement("span",{className:ce.imagePopupMenuItemTitle},e.t(p.label))))),visible:r,onVisibleChange:g},i.createElement("div",{className:L(ce.btnContainer,{[ce.btnContainerExpand]:r})},i.createElement(Ne,{style:{color:"#35322B"},extend:{colorChannel1:"rgb(var(--green-700, #409f11))"}}),h&&i.createElement(Be,{style:{color:"#CCCCCC",fontSize:"8px",marginLeft:"8px"}}))))},We="COMPONENT_IMAGE_POPUP_MENU";var vn=Object.defineProperty,wn=Object.getOwnPropertyDescriptor,Sn=(a,t,n,e)=>{for(var r=e>1?void 0:e?wn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&vn(t,n,r),r},ve=(a,t)=>(n,e)=>t(n,e,a);let we=class extends v.Disposable{constructor(t,n,e,r){super();ne(this,"_sceneListenerOnDrawingMap",new WeakSet);this._currentUniverService=t,this._commandService=n,this._renderManagerService=e,this._drawingManagerService=r,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._drawingRemoveListener(),this._drawingUpdateListener(),this._commandExecutedListener(),this._drawingArrangeListener(),this._drawingGroupListener(),this._drawingRefreshListener(),this._drawingVisibleListener()}_recoveryImages(){const t=this._drawingManagerService.drawingManagerData,n=ye(this._currentUniverService);if(n==null)return;const{unitId:e,subUnitId:r}=n;Object.keys(t).forEach(s=>{Object.keys(t[s]).forEach(o=>{const l=t[s][o].data;l==null||s!==e||o!==r||Object.keys(l).forEach(c=>{l[c]&&this._insertDrawing([{unitId:s,subUnitId:o,drawingId:c}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===pe.id){const n=t.params;if(n==null)return;this._drawingAlign(n)}}))}_drawingGroupListener(){this.disposeWithMe(this._drawingManagerService.group$.subscribe(t=>{this._groupDrawings(t)})),this.disposeWithMe(this._drawingManagerService.ungroup$.subscribe(t=>{this._ungroupDrawings(t)}))}_getSceneAndTransformerByDrawingSearch(t){if(t==null)return;const n=this._renderManagerService.getRenderById(t),e=n==null?void 0:n.scene;if(e==null)return null;const r=e.getTransformerByCreate();return{scene:e,transformer:r}}_groupDrawings(t){t.forEach(n=>{this._groupDrawing(n)})}_groupDrawing(t){const{parent:n,children:e}=t,{unitId:r,subUnitId:s,drawingId:o}=n,l=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(l==null)return;const{scene:c,transformer:u}=l;this._commandService.syncExecuteCommand(te.id);const g=[];if(e.forEach(f=>{const _=S.getDrawingShapeKeyByDrawingSearch(f),w=c.getObjectIncludeInGroup(_);if(w==null||g.includes(w))return;g.push(w);const{transform:p}=f;p!=null&&(w.classType===b.RENDER_CLASS_TYPE.GROUP?w.transformByState({left:p.left,top:p.top}):w.transformByState(p))}),g.length===0)return;const d=S.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),h=new b.Group(d);c.addObject(h,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(h),h.addObjects(...g),n.transform&&h.transformByState({left:n.transform.left,top:n.transform.top}),u.clearSelectedObjects(),u.setSelectedControl(h)}_ungroupDrawings(t){t.forEach(n=>{this._ungroupDrawing(n)})}_ungroupDrawing(t){const{parent:n,children:e}=t,r=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(r==null)return;const{scene:s,transformer:o}=r;e.forEach(d=>{const h=S.getDrawingShapeKeyByDrawingSearch(d),f=s.getObjectIncludeInGroup(h);if(f==null)return!0;if(f==null)return;const{transform:_}=d;_!=null&&(f.classType===b.RENDER_CLASS_TYPE.GROUP?f.transformByState({left:_.left,top:_.top}):f.transformByState(_))});const l=S.getDrawingShapeKeyByDrawingSearch(n),c=s.getObject(l),{width:u,height:g}=c;c.getObjects().forEach(d=>{c.removeSelfObjectAndTransform(d.oKey,u,g)}),c.dispose(),o.clearSelectedObjects()}_drawingAlign(t){const{alignType:n}=t,e=this._drawingManagerService.getFocusDrawings();if(n===T.default)return;const r=[];let s=Number.POSITIVE_INFINITY,o=Number.POSITIVE_INFINITY,l=Number.NEGATIVE_INFINITY,c=Number.NEGATIVE_INFINITY,u=0;e.forEach(g=>{const{unitId:d,subUnitId:h,drawingId:f,drawingType:_}=g,w=this._drawingManagerService.getDrawingByParam({unitId:d,subUnitId:h,drawingId:f});if(w==null||w.transform==null)return;r.push({unitId:d,subUnitId:h,drawingId:f,drawingType:_,transform:w.transform});const{left:p=0,top:N=0,width:I=0,height:U=0}=w.transform;s=Math.min(s,p),o=Math.min(o,N),l=Math.max(l,p+I),c=Math.max(c,N+U),u++}),u!==0&&(this._sortDrawingTransform(r,n),this._applyAlignType(r,n,s,o,l,c,u))}_applyAlignType(t,n,e,r,s,o,l){const c=Math.round((s-e)/l*10)/10,u=Math.round((o-r)/l*10)/10,g=[],d=this._getSceneAndTransformerByDrawingSearch(t[0].unitId);if(d==null)return;const{scene:h,transformer:f}=d;t.forEach((_,w)=>{const{unitId:p,subUnitId:N,drawingId:I,transform:U,drawingType:P}=_,{left:j=0,top:E=0,width:D=0,height:M=0}=U;let B=j,O=E;switch(n){case T.left:B=e;break;case T.center:B=e+(s-e)/2-D/2;break;case T.right:B=s-D;break;case T.top:O=r;break;case T.middle:O=r+(o-r)/2-M/2;break;case T.bottom:O=o-M;break;case T.horizon:B=e+c*w;break;case T.vertical:O=r+u*w;break}(B!==j||O!==E)&&g.push({unitId:p,subUnitId:N,drawingId:I,drawingType:P,transform:{left:B,top:O}})}),this._drawingManagerService.featurePluginUpdateNotification(g),f.refreshControls().changeNotification()}_sortDrawingTransform(t,n){t.sort((e,r)=>{const s=e.transform,o=r.transform,{left:l=0,top:c=0,width:u=0,height:g=0}=s,{left:d=0,top:h=0,width:f=0,height:_=0}=o;switch(n){case T.left:return l-d;case T.center:return l+u/2-(d+f/2);case T.right:return l+u-(d+f);case T.top:return c-h;case T.middle:return c+g/2-(h+_/2);case T.bottom:return c+g-(h+_);case T.horizon:return l+u/2-(d+f/2);case T.vertical:return c+g/2-(h+_/2);default:return 0}})}_drawingArrangeListener(){this.disposeWithMe(this._drawingManagerService.order$.subscribe(t=>{this._drawingArrange(t)}))}_drawingArrange(t){const{unitId:n,subUnitId:e,drawingIds:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n);if(s==null)return;const{scene:o,transformer:l}=s;r.forEach(c=>{const u=S.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:c}),g=o.getObject(u);if(g==null)return;const d=this._drawingManagerService.getDrawingOrder(n,e).indexOf(c);g.setProps({zIndex:d}),g.makeDirty()})}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(t=>{this._insertDrawing(t)}))}_insertDrawing(t){const n=[];t.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e;if(this._drawingManagerService.getDrawingByParam(e)==null)return;const c=this._getSceneAndTransformerByDrawingSearch(r);if(c==null)return;const{scene:u,transformer:g}=c;n.includes(u)||n.push(u)}),n.forEach(e=>{this._sceneListenerOnDrawingMap.has(e)||(this._addListenerOnDrawing(e),this._sceneListenerOnDrawingMap.add(e))})}_drawingRemoveListener(){this.disposeWithMe(this._drawingManagerService.remove$.subscribe(t=>{t.forEach(n=>{var d;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:l,transformer:c}=o,u=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),g=l.getObject(u);g!=null&&(g.dispose(),(d=l.getTransformer())==null||d.clearSelectedObjects())})}))}_drawingUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._drawingManagerService.getDrawingByParam(n);if(o==null)return;const{transform:l,drawingType:c}=o,u=this._getSceneAndTransformerByDrawingSearch(e);if(u==null)return;const{scene:g,transformer:d}=u;if(l==null)return!0;const{left:h=0,top:f=0,width:_=0,height:w=0,angle:p=0,flipX:N=!1,flipY:I=!1,skewX:U=0,skewY:P=0}=l,j=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),E=g.getObject(j);if(E==null)return!0;E.transformByState({left:h,top:f,width:_,height:w,angle:p,flipX:N,flipY:I,skewX:U,skewY:P})})}))}_drawingRefreshListener(){this.disposeWithMe(this._drawingManagerService.refreshTransform$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:l,transformer:c}=o,u=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),g=l.getObject(u);if(g==null)return!0;const d=this._drawingManagerService.getDrawingByParam(n);if(d==null)return;const{transform:h}=d;if(h==null)return!0;const{left:f=0,top:_=0,width:w=0,height:p=0,angle:N=0,flipX:I=!1,flipY:U=!1,skewX:P=0,skewY:j=0}=h;g.transformByState({left:f,top:_,width:w,height:p,angle:N,flipX:I,flipY:U,skewX:P,skewY:j})})}))}_drawingVisibleListener(){this.disposeWithMe(this._drawingManagerService.visible$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s,visible:o}=n,l=this._getSceneAndTransformerByDrawingSearch(e);if(l==null)return;const{scene:c,transformer:u}=l,g=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),d=c.getObject(g);if(d==null)return!0;o?d.show():d.hide()})}))}_filterUpdateParams(t,n){return t.filter((e,r)=>{if(e==null)return!1;const{transform:s}=e;return v.checkIfMove(s,n==null?void 0:n[r])})}_addListenerOnDrawing(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(v.toDisposable(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=Array.from(s.values()),l=[];e=o.map(c=>{const{left:u,top:g,height:d,width:h,angle:f,oKey:_,groupKey:w,isInGroup:p}=c,N=this._drawingManagerService.getDrawingOKey(_);if(p||c instanceof b.Group){let I=c.ancestorGroup;if(I==null&&c instanceof b.Group&&(I=c),I==null)return null;const U=this._drawingManagerService.getDrawingOKey(I.oKey);if(U){const{unitId:P,subUnitId:j,drawingId:E}=U;l.push({unitId:P,subUnitId:j,drawingId:E});const{left:D,top:M,height:B,width:O,angle:H}=I;return{left:D,top:M,height:B,width:O,angle:H}}}else if(N!=null){const{unitId:I,subUnitId:U,drawingId:P}=N;return l.push({unitId:I,subUnitId:U,drawingId:P}),{left:u,top:g,height:d,width:h,angle:f}}return null}).filter(c=>c!=null),l.length>0?this._drawingManagerService.focusDrawing(l):this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(v.toDisposable(n.changeEnd$.subscribe(r=>{const{objects:s}=r;this._filterUpdateParams(se(s,this._drawingManagerService),e).length>0})))}};we=Sn([v.OnLifecycle(v.LifecycleStages.Rendered,we),ve(0,v.IUniverInstanceService),ve(1,v.ICommandService),ve(2,b.IRenderManagerService),ve(3,S.IDrawingManagerService)],we);const _n=a=>{const{src:t}=a;return t?i.createElement("div",null,i.createElement("img",{src:t,alt:"Univer Image Viewer",style:{width:"100%",height:"100%",position:"relative"}})):null},$e="COMPONENT_IMAGE_VIEWER",Pe={id:"sheet.operation.image-reset-size",type:v.CommandType.OPERATION,handler:(a,t)=>!0};var In=Object.defineProperty,bn=Object.getOwnPropertyDescriptor,yn=(a,t,n,e)=>{for(var r=e>1?void 0:e?bn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&In(t,n,r),r},me=(a,t)=>(n,e)=>t(n,e,a);let Se=class extends v.Disposable{constructor(a,t,n,e,r){super(),this._injector=a,this._componentManager=t,this._menuService=n,this._commandService=e,this._localeService=r,this._init()}_initCustomComponents(){const a=this._componentManager;this.disposeWithMe(a.register(We,Ve)),this.disposeWithMe(a.register($e,_n))}_initMenus(){}_initCommands(){[Ce,te,Pe,pe,le].forEach(a=>this.disposeWithMe(this._commandService.registerCommand(a)))}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus()}};Se=yn([v.OnLifecycle(v.LifecycleStages.Rendered,Se),me(0,Q.Inject(Q.Injector)),me(1,Q.Inject(he.ComponentManager)),me(2,he.IMenuService),me(3,v.ICommandService),me(4,Q.Inject(v.LocaleService))],Se);class ue extends b.Shape{constructor(n,e){e==null&&(e={}),e.transformerConfig={keepRatio:!1,isCropper:!0,anchorFill:"rgb(0, 0, 0)",anchorStroke:"rgb(255, 255, 255)",anchorSize:24};super(n,e);ne(this,"_srcRect");ne(this,"_prstGeom");ne(this,"_applyTransform");ne(this,"_dragPadding",8);ne(this,"_cacheCanvas");e!=null&&e.srcRect&&(this._srcRect=e.srcRect),e!=null&&e.prstGeom&&(this._prstGeom=e.prstGeom),e!=null&&e.applyTransform&&(this._applyTransform=e.applyTransform),e!=null&&e.dragPadding&&(this._dragPadding=e.dragPadding),this._applyProps()}refreshSrcRect(n,e){this._srcRect=n,this._applyTransform=e,this._applyProps()}get srcRect(){return this._srcRect}dispose(){var n;super.dispose(),(n=this._cacheCanvas)==null||n.dispose(),this._srcRect=null}isHit(n){const e=this.getInverseCoord(n);return e.x>=-this.strokeWidth/2&&e.x<=this.width+this.strokeWidth/2&&e.y>=-this.strokeWidth/2&&e.y<=this.height+this.strokeWidth/2&&!this._inSurround(e)}_inSurround(n){const e=this._dragPadding;return n.x>=e-this.strokeWidth/2&&n.x<=this.width+this.strokeWidth/2-e&&n.y>=e-this.strokeWidth/2&&n.y<=this.height+this.strokeWidth/2-e}render(n,e){return this.visible?(n.save(),this._draw(n),n.restore(),this.makeDirty(!1),this):(this.makeDirty(!1),this)}_draw(n){var c,u;const r=this.getScene().getEngine(),{width:s,height:o}=r;this._initialCacheCanvas(),(c=this._cacheCanvas)==null||c.clear();const l=(u=this._cacheCanvas)==null?void 0:u.getContext();l!=null&&(l.save(),b.Rect.drawWith(l,{left:0,top:0,width:s,height:o,fill:"rgba(0, 0, 0, 0.5)"}),l.setTransform(n.getTransform()),this._clipForApplyObject(l),this._applyCache(n),l.restore())}_clipForApplyObject(n){let e=0;if(this._prstGeom!=null&&(e=1),n.globalCompositeOperation="destination-out",n.beginPath(),e===0){const r=this.transform.getMatrix();n.transform(r[0],r[1],r[2],r[3],r[4],r[5]),n.rect(0,0,this.width,this.height),n.fill()}}_applyProps(){if(this._applyTransform==null)return;let n=0,e=0,r=0,s=0;const{left:o=0,top:l=0,width:c=0,height:u=0,angle:g}=this._applyTransform;if(this._srcRect!=null){const{left:f=0,top:_=0,right:w=0,bottom:p=0}=this._srcRect;n=f,e=_,r=w,s=p}const d=o+n,h=l+e;this.transformByState({left:d,top:h,width:o+c-r-d,height:l+u-s-h,angle:g})}_applyCache(n){if(!n||this._cacheCanvas==null)return;const e=this._cacheCanvas.getContext();e.save(),n.save(),n.setTransform(1,0,0,1,0,0),e.setTransform(1,0,0,1,0,0),n.drawImage(this._cacheCanvas.getCanvasEle(),0,0),n.restore(),e.restore()}_initialCacheCanvas(){if(this._cacheCanvas!=null)return;this._cacheCanvas=new b.Canvas;const n=this.getScene().getEngine();this._cacheCanvas.setSize(n.width,n.height),n.onTransformChange$.subscribeEvent(()=>{var e;(e=this._cacheCanvas)==null||e.setSize(n.width,n.height),this.makeDirty(!0)})}}var Pn=Object.defineProperty,En=Object.getOwnPropertyDescriptor,Mn=(a,t,n,e)=>{for(var r=e>1?void 0:e?En(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Pn(t,n,r),r},oe=(a,t)=>(n,e)=>t(n,e,a);let _e=class extends v.Disposable{constructor(t,n,e,r,s,o){super();ne(this,"_sceneListenerOnImageMap",new WeakSet);this._commandService=t,this._drawingManagerService=n,this._renderManagerService=e,this._univerInstanceService=r,this._messageService=s,this._localeService=o,this._init()}_init(){this._initOpenCrop(),this._initCloseCrop(),this._initAutoCrop()}_initAutoCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==le.id)return;const n=t.params;if(n==null)return;const{cropType:e}=n,r=this._drawingManagerService.getFocusDrawings();if(r.length!==1)return;const s=r[0],{unitId:o,subUnitId:l,drawingId:c}=s,u=this._renderManagerService.getRenderById(o),g=u==null?void 0:u.scene;if(g==null)return!0;this._searchCropObject(g)!=null&&this._commandService.syncExecuteCommand(te.id,{isAuto:!0});const h=S.getDrawingShapeKeyByDrawingSearch({unitId:o,subUnitId:l,drawingId:c}),f=g.getObject(h);if(!(f instanceof b.Image)){this._messageService.show({type:$.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}f!=null&&(this._updateCropperObject(e,f),this._commandService.executeCommand(Ce.id,{unitId:o,subUnitId:l,drawingId:c}))}))}_calculateSrcRectByRatio(t,n,e,r,s,o){const l=e/r,c=s/o;let u=e,g=r;l>c?u=r*c:g=e/c;const d=(e-u)/2,h=(r-g)/2;return{left:b.precisionTo(d,1),top:b.precisionTo(h,1),right:b.precisionTo(e-(d+u),1),bottom:b.precisionTo(r-(h+g),1)}}_updateCropperObject(t,n){const{left:e,top:r,width:s,height:o}=n.calculateTransformWithSrcRect();let l;switch(t){case A.R1_1:l=this._calculateSrcRectByRatio(e,r,s,o,1,1);break;case A.R16_9:l=this._calculateSrcRectByRatio(e,r,s,o,16,9);break;case A.R9_16:l=this._calculateSrcRectByRatio(e,r,s,o,9,16);break;case A.R5_4:l=this._calculateSrcRectByRatio(e,r,s,o,5,4);break;case A.R4_5:l=this._calculateSrcRectByRatio(e,r,s,o,4,5);break;case A.R4_3:l=this._calculateSrcRectByRatio(e,r,s,o,4,3);break;case A.R3_4:l=this._calculateSrcRectByRatio(e,r,s,o,3,4);break;case A.R3_2:l=this._calculateSrcRectByRatio(e,r,s,o,3,2);break;case A.R2_3:l=this._calculateSrcRectByRatio(e,r,s,o,2,3);break;case A.FREE:}if(l==null)return;n.setSrcRect(l);const{left:c=0,top:u=0,bottom:g=0,right:d=0}=l;n.transformByStateCloseCropper({left:e+c,top:r+u,width:s-d-c,height:o-g-u})}_initOpenCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==Ce.id)return;const n=t.params;if(n==null)return;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._renderManagerService.getRenderById(e),l=o==null?void 0:o.scene;if(l==null)return!0;if(this._sceneListenerOnImageMap.has(l)||(this._addListenerOnImage(l),this._sceneListenerOnImageMap.add(l)),this._drawingManagerService.getDrawingByParam({unitId:e,subUnitId:r,drawingId:s})==null)return;const u=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),g=l.getObject(u);if(g==null)return;if(!(g instanceof b.Image)){this._messageService.show({type:$.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}const d=l.getTransformer();d==null||d.clearControls();const h=new ue(`${u}-crop`,{srcRect:g.srcRect,prstGeom:g.prstGeom,applyTransform:g.calculateTransformWithSrcRect()});l.addObject(h,g.getLayerIndex()+1).attachTransformerTo(h),d==null||d.createControlForCopper(h),this._addHoverForImageCopper(h),g.openRenderByCropper(),d==null||d.refreshControls(),h.makeDirty(!0),this._drawingManagerService.focusDrawing([{unitId:e,subUnitId:r,drawingId:s}])}))}_searchCropObject(t){const n=t.getAllObjects();for(const e of n)if(e instanceof ue)return e}_initCloseCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(n.id!==te.id)return;const e=this._univerInstanceService.getFocusedUnit();if(e==null)return;const r=e.getUnitId(),s=this._renderManagerService.getRenderById(r),o=s==null?void 0:s.scene;if(o==null)return!0;const l=this._searchCropObject(o);if(l==null)return;const c=this._getApplyObjectByCropObject(l);if(c==null)return;const u=o.getTransformerByCreate();u.detachFrom(l),u.clearCopperControl();const g=this._getSrcRectByTransformState(c,l),d=this._drawingManagerService.getDrawingOKey(c.oKey);if(d!=null){const{left:h,top:f,height:_,width:w}=l;this._drawingManagerService.featurePluginUpdateNotification([{...d,transform:{...d.transform,left:h,top:f,height:_,width:w},srcRect:g.srcRectAngle}])}c.setSrcRect({...g.srcRectAngle}),c.closeRenderByCropper(),c.makeDirty(!0),l==null||l.dispose()}));const t=this._univerInstanceService.getCurrentTypeOfUnit$(v.UniverInstanceType.UNIVER_SHEET).pipe(Me.filter(n=>!!n),Me.switchMap(n=>n.activeSheet$));this.disposeWithMe(t.subscribe(()=>{this._commandService.syncExecuteCommand(te.id)}))}_getApplyObjectByCropObject(t){const n=t.oKey,e=n.slice(0,n.length-5),r=t.getScene().getObject(e);return r==null?null:r}_addListenerOnImage(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof ue))return;const{left:l,top:c,height:u,width:g,angle:d}=o;e={left:l,top:c,height:u,width:g,angle:d},n.clearCopperControl()})),this.disposeWithMe(n.changeEnd$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof ue))return;const{left:l,top:c,height:u,width:g,angle:d}=o;if(!v.checkIfMove({left:l,top:c,height:u,width:g,angle:d},e))return;const h=this._getApplyObjectByCropObject(o);if(h==null)return;const f=this._getSrcRectByTransformState(h,o);o.refreshSrcRect(f.srcRect,h.getState()),n.createControlForCopper(o)})),this._endCropListener(t)}_addHoverForImageCopper(t){this.disposeWithMe(t.onPointerEnter$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.MOVE})),this.disposeWithMe(t.onPointerLeave$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.DEFAULT}))}_endCropListener(t){const n=t.getTransformerByCreate();this.disposeWithMe(n.clearControl$.subscribe(e=>{e===!0&&this._commandService.syncExecuteCommand(te.id)}))}_getSrcRectByTransformState(t,n){const{left:e,top:r,height:s,width:o,strokeWidth:l,angle:c}=n,{left:u,top:g,width:d,height:h,angle:f,strokeWidth:_}=t,w=e-u,p=r-g,N={left:w,top:p,right:d-w-o,bottom:h-p-s},I={...N};if(f!==0){const U=e+o/2,P=r+s/2,j=new b.Vector2(U,P),E=d/2+u,D=h/2+g,M=new b.Vector2(E,D),B=new b.Vector2(u,g);B.rotateByPoint(b.degToRad(f),M);const O=B.clone();O.rotateByPoint(b.degToRad(-f),j);const H=e-O.x,G=r-O.y;I.left=H,I.top=G,I.right=d-H-o,I.bottom=h-G-s}return{srcRect:N,srcRectAngle:I}}};_e=Mn([v.OnLifecycle(v.LifecycleStages.Rendered,_e),oe(0,v.ICommandService),oe(1,S.IDrawingManagerService),oe(2,b.IRenderManagerService),oe(3,v.IUniverInstanceService),oe(4,he.IMessageService),oe(5,Q.Inject(v.LocaleService))],_e);var Dn=Object.defineProperty,On=Object.getOwnPropertyDescriptor,Nn=(a,t,n,e)=>{for(var r=e>1?void 0:e?On(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Dn(t,n,r),r},ie=(a,t)=>(n,e)=>t(n,e,a);const ke=50;let Ie=class extends v.Disposable{constructor(a,t,n,e,r,s,o){super(),this._commandService=a,this._renderManagerService=t,this._drawingManagerService=n,this._dialogService=e,this._imageIoService=r,this._currentUniverService=s,this._drawingRenderService=o,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._commandExecutedListener(),this._imageUpdateListener()}_recoveryImages(){const a=this._drawingManagerService.drawingManagerData,t=ye(this._currentUniverService);if(t==null)return;const{unitId:n,subUnitId:e}=t;Object.keys(a).forEach(r=>{Object.keys(a[r]).forEach(s=>{const o=a[r][s].data;o==null||r!==n||s!==e||Object.keys(o).forEach(l=>{o[l]&&this._insertImages([{unitId:r,subUnitId:s,drawingId:l}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(a=>{if(a.id===Pe.id){const t=a.params;if(t==null)return;this._resetImageSize(t)}}))}_getSceneAndTransformerByDrawingSearch(a){if(a==null)return;const t=this._renderManagerService.getRenderById(a),n=t==null?void 0:t.scene;if(n==null)return null;const e=n.getTransformerByCreate();return{scene:n,transformer:e}}_resetImageSize(a){const t=[],n=[];a.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e,l=this._getSceneAndTransformerByDrawingSearch(r);if(l==null)return;const{scene:c}=l,u=S.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),g=c.getObject(u);if(g==null)return!0;const d=this._drawingManagerService.getDrawingByParam(e);if(d==null)return!0;if(d.drawingType!==S.DrawingTypeEnum.DRAWING_IMAGE)return;g.resetSize();const{width:h,height:f}=g.getNativeSize();n.includes(c)===!1&&n.push(c),t.push({...d,transform:{...d.transform,height:f,width:h,angle:0},srcRect:null,prstGeom:null})}),this._drawingManagerService.featurePluginUpdateNotification(t),n.forEach(e=>{e.getTransformerByCreate().refreshControls().changeNotification()}),this._drawingManagerService.focusDrawing(a)}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(a=>{this._insertImages(a)}))}_insertImages(a){a.forEach(async t=>{var u;const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n),o=(u=ye(this._currentUniverService))==null?void 0:u.subUnitId;if(s==null||o!==e)return;const l=this._drawingManagerService.getDrawingByParam(t);if(l==null)return;const c=await this._drawingRenderService.renderImage(l,s.scene);c!=null&&(this._addHoverForImage(c),this._addDialogForImage(c))})}_imageUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(a=>{a.forEach(t=>{const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._drawingManagerService.getDrawingByParam(t);if(s==null)return;const{transform:o,drawingType:l,srcRect:c,prstGeom:u,source:g,imageSourceType:d}=s;if(l!==S.DrawingTypeEnum.DRAWING_IMAGE)return;const h=this._getSceneAndTransformerByDrawingSearch(n);if(h==null)return;const{scene:f,transformer:_}=h;if(o==null)return!0;const w=S.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:r}),p=f.getObject(w);if(p==null)return!0;p.setSrcRect(c),p.setPrstGeom(u)})}))}_addHoverForImage(a){this.disposeWithMe(v.toDisposable(a.onPointerEnter$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.GRAB}))),this.disposeWithMe(v.toDisposable(a.onPointerLeave$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.DEFAULT})))}_addDialogForImage(a){this.disposeWithMe(v.toDisposable(a.onDblclick$.subscribeEvent(()=>{var l;const t=`${a.oKey}-viewer-dialog`,n=a.getNativeSize(),e=window.innerWidth-ke,r=window.innerHeight-ke,s=this._adjustImageSize(n.width,n.height,e,r),o=this._dialogService.open({width:s.width,id:t,style:{margin:"0",top:"50%",left:"50%",transform:"translate(-50%, -50%)"},children:{label:{name:$e,props:{src:(l=a.getNative())==null?void 0:l.src,width:s.width,height:s.height}}},destroyOnClose:!0,draggable:!1,onClose:()=>{this._dialogService.close(t),o.dispose()}})})))}_adjustImageSize(a,t,n,e){if(a<=n&&t<=e)return{width:a,height:t};const r=n/a,s=e/t,o=Math.min(r,s);return{width:Math.floor(a*o),height:Math.floor(t*o)}}};Ie=Nn([v.OnLifecycle(v.LifecycleStages.Rendered,Ie),ie(0,v.ICommandService),ie(1,b.IRenderManagerService),ie(2,S.IDrawingManagerService),ie(3,he.IDialogService),ie(4,S.IImageIoService),ie(5,v.IUniverInstanceService),ie(6,Q.Inject(y.DrawingRenderService))],Ie);var Tn=Object.defineProperty,Un=Object.getOwnPropertyDescriptor,jn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Un(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Tn(t,n,r),r},Re=(a,t)=>(n,e)=>t(n,e,a);const Bn="DRAWING_UI_PLUGIN";y.UniverDrawingUIPlugin=(Ee=class extends v.Plugin{constructor(t,n,e){super(),this._injector=n,this._localeService=e}onStarting(t){this._initDependencies(t)}_initDependencies(t){[[y.DrawingRenderService],[we],[Se],[_e],[Ie]].forEach(e=>t.add(e))}},ne(Ee,"pluginName",Bn),Ee),y.UniverDrawingUIPlugin=jn([Re(1,Q.Inject(Q.Injector)),Re(2,Q.Inject(v.LocaleService))],y.UniverDrawingUIPlugin),y.AutoImageCropOperation=le,y.COMPONENT_IMAGE_POPUP_MENU=We,y.CloseImageCropOperation=te,y.DrawingCommonPanel=Cn,y.ImageCropperObject=ue,y.ImagePopupMenu=Ve,y.ImageResetSizeOperation=Pe,y.OpenImageCropOperation=Ce,y.SetDrawingAlignOperation=pe,y.getUpdateParams=se,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})});
|
|
1
|
+
(function(y,S){typeof exports=="object"&&typeof module<"u"?S(exports,require("@univerjs/drawing"),require("@univerjs/engine-render"),require("@univerjs/core"),require("react"),require("@univerjs/design"),require("clsx"),require("@univerjs/ui"),require("rxjs")):typeof define=="function"&&define.amd?define(["exports","@univerjs/drawing","@univerjs/engine-render","@univerjs/core","react","@univerjs/design","clsx","@univerjs/ui","rxjs"],S):(y=typeof globalThis<"u"?globalThis:y||self,S(y.UniverDrawingUi={},y.UniverDrawing,y.UniverEngineRender,y.UniverCore,y.React,y.UniverDesign,y.clsx,y.UniverUi,y.rxjs))})(this,function(y,S,b,h,i,$,L,ge,Pe){"use strict";var $n=Object.defineProperty;var kn=(y,S,b)=>S in y?$n(y,S,{enumerable:!0,configurable:!0,writable:!0,value:b}):y[S]=b;var Q=(y,S,b)=>kn(y,typeof S!="symbol"?S+"":S,b);var ye;function ze(a,t,n,e){const r=e.getDrawingByParam(a);if(r==null)return;const s=S.getDrawingShapeKeyByDrawingSearch(a),o=n.getObject(s);if(o&&!(o instanceof b.Group))return;if(o!=null){o.addObject(t);return}const l=new b.Group(s);n.addObject(l,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(l),l.addObject(t);const{transform:c}=r;c&&l.transformByState({left:c.left,top:c.top,angle:c.angle})}function Ie(a){var r;const t=a.getFocusedUnit();if(t==null)return;const n=t.getUnitId();let e;return t.type===h.UniverInstanceType.UNIVER_SHEET?e=(r=t.getActiveSheet())==null?void 0:r.getSheetId():(t.type===h.UniverInstanceType.UNIVER_DOC||t.type===h.UniverInstanceType.UNIVER_SLIDE)&&(e=n),{unitId:n,subUnitId:e}}var Ke=Object.defineProperty,xe=Object.getOwnPropertyDescriptor,Fe=(a,t,n,e)=>{for(var r=e>1?void 0:e?xe(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Ke(t,n,r),r},Ee=(a,t)=>(n,e)=>t(n,e,a);y.DrawingRenderService=class{constructor(t,n){this._drawingManagerService=t,this._imageIoService=n}async renderImage(t,n){const{transform:e,drawingType:r,source:s,imageSourceType:o,srcRect:l,prstGeom:c,groupId:u,unitId:g,subUnitId:d,drawingId:f}=t;if(r!==S.DrawingTypeEnum.DRAWING_IMAGE||!this._drawingManagerService.getDrawingVisible()||e==null)return;const{left:p,top:_,width:w,height:C,angle:N,flipX:I,flipY:B,skewX:P,skewY:U}=e,E=S.getDrawingShapeKeyByDrawingSearch({unitId:g,subUnitId:d,drawingId:f}),D=n.getObject(E);if(D!=null){D.transformByState({left:p,top:_,width:w,height:C,angle:N,flipX:I,flipY:B,skewX:P,skewY:U});return}const M=this._drawingManagerService.getDrawingOrder(g,d),j=M.indexOf(f),O={...e,zIndex:j===-1?M.length-1:j},H=this._imageIoService.getImageSourceCache(s,o);let G=!1;if(H!=null)O.image=H;else{if(o===S.ImageSourceType.UUID)try{O.url=await this._imageIoService.getImage(s)}catch(me){console.error(me);return}else O.url=s;G=!0}O.printable=!0;const K=new b.Image(E,O);if(G&&this._imageIoService.addImageSourceCache(s,o,K.getNative()),!this._drawingManagerService.getDrawingVisible())return;const x=n.addObject(K,b.DRAWING_OBJECT_LAYER_INDEX);return this._drawingManagerService.getDrawingEditable()&&x.attachTransformerTo(K),u&&ze({drawingId:u,unitId:g,subUnitId:d},K,n,this._drawingManagerService),c!=null&&K.setPrstGeom(c),l!=null&&K.setSrcRect(l),K}renderDrawing(t,n){const e=this._drawingManagerService.getDrawingByParam(t);if(e!=null)switch(e.drawingType){case S.DrawingTypeEnum.DRAWING_IMAGE:return this.renderImage(e,n)}}},y.DrawingRenderService=Fe([Ee(0,S.IDrawingManagerService),Ee(1,S.IImageIoService)],y.DrawingRenderService);function ie(a,t){const n=[];return a.forEach(e=>{const{oKey:r,left:s,top:o,height:l,width:c,angle:u}=e,g=t.getDrawingOKey(r);if(g==null)return n.push(null),!0;const{unitId:d,subUnitId:f,drawingId:p,drawingType:_}=g,w={unitId:d,subUnitId:f,drawingId:p,drawingType:_,transform:{left:s,top:o,height:l,width:c,angle:u}};_===S.DrawingTypeEnum.DRAWING_IMAGE&&(w.srcRect=e.srcRect),n.push(w)}),n}var z=function(){return z=Object.assign||function(a){for(var t,n=1,e=arguments.length;n<e;n++){t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(a[r]=t[r])}return a},z.apply(this,arguments)},Ye=function(a,t){var n={};for(var e in a)Object.prototype.hasOwnProperty.call(a,e)&&t.indexOf(e)<0&&(n[e]=a[e]);if(a!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,e=Object.getOwnPropertySymbols(a);r<e.length;r++)t.indexOf(e[r])<0&&Object.prototype.propertyIsEnumerable.call(a,e[r])&&(n[e[r]]=a[e[r]]);return n},Z=i.forwardRef(function(a,t){var n=a.icon,e=a.id,r=a.className,s=a.extend,o=Ye(a,["icon","id","className","extend"]),l="univerjs-icon univerjs-icon-".concat(e," ").concat(r||"").trim(),c=i.useRef("_".concat(qe()));return Me(n,"".concat(e),{defIds:n.defIds,idSuffix:c.current},z({ref:t,className:l},o),s)});function Me(a,t,n,e,r){return i.createElement(a.tag,z(z({key:t},Ze(a,n,r)),e),(Xe(a,n).children||[]).map(function(s,o){return Me(s,"".concat(t,"-").concat(a.tag,"-").concat(o),n,void 0,r)}))}function Ze(a,t,n){var e=z({},a.attrs);n!=null&&n.colorChannel1&&e.fill==="colorChannel1"&&(e.fill=n.colorChannel1);var r=t.defIds;return!r||r.length===0||(a.tag==="use"&&e["xlink:href"]&&(e["xlink:href"]=e["xlink:href"]+t.idSuffix),Object.entries(e).forEach(function(s){var o=s[0],l=s[1];typeof l=="string"&&(e[o]=l.replace(/url\(#(.*)\)/,"url(#$1".concat(t.idSuffix,")")))})),e}function Xe(a,t){var n,e=t.defIds;return!e||e.length===0?a:a.tag==="defs"&&(!((n=a.children)===null||n===void 0)&&n.length)?z(z({},a),{children:a.children.map(function(r){return typeof r.attrs.id=="string"&&e&&e.indexOf(r.attrs.id)>-1?z(z({},r),{attrs:z(z({},r.attrs),{id:r.attrs.id+t.idSuffix})}):r})}):a}function qe(){return Math.random().toString(36).substring(2,8)}Z.displayName="UniverIcon";var Je={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"colorChannel1",d:"M11.0363 12.2367V14.0367C11.0363 14.3681 11.3049 14.6367 11.6363 14.6367C11.9676 14.6367 12.2363 14.3681 12.2363 14.0367V12.2367H14.0364C14.3677 12.2367 14.6364 11.9681 14.6364 11.6367C14.6364 11.3054 14.3677 11.0367 14.0364 11.0367H12.2363V9.23672C12.2363 8.90535 11.9676 8.63672 11.6363 8.63672C11.3049 8.63672 11.0363 8.90535 11.0363 9.23672V11.0367H9.23635C8.90498 11.0367 8.63635 11.3054 8.63635 11.6367C8.63635 11.9681 8.90498 12.2367 9.23635 12.2367H11.0363Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.56365 1.36377C1.90091 1.36377 1.36365 1.90103 1.36365 2.56377V6.16377C1.36365 6.82651 1.90091 7.36377 2.56365 7.36377H6.16365C6.82639 7.36377 7.36365 6.82651 7.36365 6.16377V2.56377C7.36365 1.90103 6.82639 1.36377 6.16365 1.36377H2.56365zM6.16365 2.56377H2.56365L2.56365 6.16377H6.16365V2.56377zM2.56365 8.63647C1.90091 8.63647 1.36365 9.17373 1.36365 9.83647V13.4365C1.36365 14.0992 1.90091 14.6365 2.56365 14.6365H6.16365C6.82639 14.6365 7.36365 14.0992 7.36365 13.4365V9.83647C7.36365 9.17373 6.82639 8.63647 6.16365 8.63647H2.56365zM6.16365 9.83647H2.56365L2.56365 13.4365H6.16365V9.83647zM9.83635 7.36377C9.17361 7.36377 8.63635 6.82651 8.63635 6.16377V2.56377C8.63635 1.90103 9.17361 1.36377 9.83635 1.36377H13.4364C14.0991 1.36377 14.6364 1.90103 14.6364 2.56377V6.16377C14.6364 6.82651 14.0991 7.36377 13.4364 7.36377H9.83635zM9.83635 6.16377V2.56377L13.4364 2.56377V6.16377H9.83635z",fillRule:"evenodd",clipRule:"evenodd"}}]},De=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"autofill",ref:t,icon:Je}))});De.displayName="Autofill";var Qe={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M14.0045 4.4334C14.8881 4.4334 15.6045 3.71705 15.6045 2.8334 15.6045 1.94974 14.8881 1.2334 14.0045 1.2334H3.70449C2.82084 1.2334 2.10449 1.94974 2.10449 2.8334 2.10449 3.71705 2.82084 4.4334 3.70449 4.4334H14.0045zM14.4045 2.8334C14.4045 3.05431 14.2254 3.2334 14.0045 3.2334H3.70449C3.48358 3.2334 3.30449 3.05431 3.30449 2.8334 3.30449 2.61248 3.48358 2.4334 3.70449 2.4334H14.0045C14.2254 2.4334 14.4045 2.61249 14.4045 2.8334zM14.1544 8.5999C15.038 8.5999 15.7544 7.88356 15.7544 6.9999 15.7544 6.11625 15.038 5.3999 14.1544 5.3999H3.85439C2.97074 5.3999 2.25439 6.11625 2.25439 6.9999 2.25439 7.88356 2.97074 8.5999 3.85439 8.5999H14.1544zM14.5544 6.9999C14.5544 7.22082 14.3753 7.3999 14.1544 7.3999H3.85439C3.63348 7.3999 3.45439 7.22082 3.45439 6.9999 3.45439 6.77899 3.63348 6.5999 3.85439 6.5999H14.1544C14.3753 6.5999 14.5544 6.77899 14.5544 6.9999z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M8.57975 14.5902L6.58023 12.5907C6.34591 12.3564 6.34591 11.9765 6.58023 11.7421 6.81454 11.5078 7.19444 11.5078 7.42876 11.7421L8.40449 12.7179V10.1664C8.40449 9.83504 8.67312 9.56641 9.00449 9.56641 9.33586 9.56641 9.60449 9.83504 9.60449 10.1664V12.7179L10.5802 11.7421C10.8145 11.5078 11.1944 11.5078 11.4288 11.7421 11.6631 11.9765 11.6631 12.3564 11.4288 12.5907L9.42923 14.5902M8.57975 14.5902C8.58121 14.5917 8.58268 14.5931 8.58416 14.5946 8.64077 14.6502 8.70566 14.6923 8.77482 14.7209 8.84557 14.7502 8.92314 14.7664 9.00449 14.7664 9.08585 14.7664 9.16342 14.7502 9.23416 14.7209 9.30332 14.6923 9.36821 14.6502 9.42482 14.5946"}}]},Oe=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"bottom-single",ref:t,icon:Qe}))});Oe.displayName="BottomSingle";var en={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M5.97705 7.51296C5.97705 7.18159 6.24568 6.91296 6.57705 6.91296H8.48632C8.81769 6.91296 9.08632 7.18159 9.08632 7.51296 9.08632 7.84433 8.81769 8.11296 8.48632 8.11296H6.57705C6.24568 8.11296 5.97705 7.84433 5.97705 7.51296zM6.57705 9.41028C6.24568 9.41028 5.97705 9.67891 5.97705 10.0103 5.97705 10.3416 6.24568 10.6103 6.57705 10.6103H10.8199C11.1512 10.6103 11.4199 10.3416 11.4199 10.0103 11.4199 9.67891 11.1512 9.41028 10.8199 9.41028H6.57705z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.51074 2.37063C3.51074 1.48697 4.22709 0.77063 5.11074 0.77063H9.80318L9.81294 0.770708C9.97168 0.768161 10.1311 0.82824 10.2511 0.95055L14.4317 5.21408C14.5165 5.30049 14.5697 5.406 14.5917 5.51645C14.6041 5.5644 14.6106 5.61467 14.6106 5.66648V11.6406C14.6106 12.5243 13.8943 13.2406 13.0106 13.2406H5.11074C4.22709 13.2406 3.51074 12.5243 3.51074 11.6406V2.37063ZM10.4032 4.66648V2.81964L12.6063 5.06648H10.8032C10.5823 5.06648 10.4032 4.88739 10.4032 4.66648ZM5.11074 1.97063C4.88983 1.97063 4.71074 2.14972 4.71074 2.37063V11.6406C4.71074 11.8615 4.88983 12.0406 5.11074 12.0406H13.0106C13.2316 12.0406 13.4106 11.8615 13.4106 11.6406V6.26648H10.8032C9.91953 6.26648 9.20318 5.55013 9.20318 4.66648V1.97063H5.11074Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M2.58916 6.6741C2.58916 6.34273 2.32053 6.0741 1.98916 6.0741C1.65779 6.0741 1.38916 6.34273 1.38916 6.6741V12.6294C1.38916 14.0653 2.55322 15.2294 3.98916 15.2294H9.41408C9.74545 15.2294 10.0141 14.9607 10.0141 14.6294C10.0141 14.298 9.74545 14.0294 9.41408 14.0294H3.98916C3.21596 14.0294 2.58916 13.4026 2.58916 12.6294V6.6741Z"}}]},Ne=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"create-copy-single",ref:t,icon:en}))});Ne.displayName="CreateCopySingle";var nn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.38125 1.16211C6.49759 1.16211 5.78125 1.87845 5.78125 2.76211V5.6377H2.87783C1.99418 5.6377 1.27783 6.35404 1.27783 7.2377V13.2377C1.27783 14.1214 1.99418 14.8377 2.87783 14.8377H8.87783C9.76149 14.8377 10.4778 14.1214 10.4778 13.2377V10.3621H13.3813C14.2649 10.3621 14.9813 9.64577 14.9813 8.76211V2.76211C14.9813 1.87845 14.2649 1.16211 13.3813 1.16211H7.38125ZM10.4778 9.16211H13.3813C13.6022 9.16211 13.7812 8.98302 13.7812 8.76211V2.76211C13.7812 2.5412 13.6022 2.36211 13.3813 2.36211H7.38125C7.16034 2.36211 6.98125 2.5412 6.98125 2.76211V5.6377H8.87783C9.76149 5.6377 10.4778 6.35404 10.4778 7.2377V9.16211ZM6.98125 6.8377H8.87783C9.09875 6.8377 9.27783 7.01678 9.27783 7.2377V9.16211H7.38125C7.16034 9.16211 6.98125 8.98302 6.98125 8.76211V6.8377ZM5.78125 6.8377V8.76211C5.78125 9.64577 6.49759 10.3621 7.38125 10.3621H9.27783V13.2377C9.27783 13.4586 9.09875 13.6377 8.87783 13.6377H2.87783C2.65692 13.6377 2.47783 13.4586 2.47783 13.2377V7.2377C2.47783 7.01678 2.65692 6.8377 2.87783 6.8377H5.78125Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Te=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"group-single",ref:t,icon:nn}))});Te.displayName="GroupSingle";var tn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M11.3536 6.14645C11.5488 6.34171 11.5488 6.65829 11.3536 6.85355L8.35355 9.85355C8.15829 10.0488 7.84171 10.0488 7.64645 9.85355L4.64645 6.85355C4.45118 6.65829 4.45118 6.34171 4.64645 6.14645C4.84171 5.95118 5.15829 5.95118 5.35355 6.14645L8 8.79289L10.6464 6.14645C10.8417 5.95118 11.1583 5.95118 11.3536 6.14645Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Be=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"more-down-single",ref:t,icon:tn}))});Be.displayName="MoreDownSingle";var rn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 2.96401C1.25 3.84767 1.96634 4.56401 2.85 4.56401H13.15C14.0337 4.56401 14.75 3.84767 14.75 2.96401C14.75 2.08036 14.0337 1.36401 13.15 1.36401H2.85C1.96635 1.36401 1.25 2.08036 1.25 2.96401ZM2.85 3.36401C2.62909 3.36401 2.45 3.18493 2.45 2.96401C2.45 2.7431 2.62909 2.56401 2.85 2.56401H13.15C13.3709 2.56401 13.55 2.7431 13.55 2.96401C13.55 3.18493 13.3709 3.36401 13.15 3.36401H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 11.6118C5.80995 11.3774 6.18985 11.3774 6.42417 11.6118L7.3999 12.5875V6.36951C7.3999 6.03814 7.66853 5.76951 7.9999 5.76951C8.33127 5.76951 8.5999 6.03814 8.5999 6.36951V12.5875L9.57564 11.6118C9.80995 11.3774 10.1899 11.3774 10.4242 11.6118C10.6585 11.8461 10.6585 12.226 10.4242 12.4603L8.4324 14.452C8.32324 14.5655 8.16982 14.6362 7.9999 14.6362C7.82998 14.6362 7.67655 14.5655 7.56739 14.452L5.57564 12.4603C5.34132 12.226 5.34132 11.8461 5.57564 11.6118Z"}}]},Ue=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"move-down-single",ref:t,icon:rn}))});Ue.displayName="MoveDownSingle";var an={tag:"svg",attrs:{fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M1.25 13.036C1.25 12.1523 1.96634 11.436 2.85 11.436H13.15C14.0337 11.436 14.75 12.1523 14.75 13.036C14.75 13.9196 14.0337 14.636 13.15 14.636H2.85C1.96635 14.636 1.25 13.9196 1.25 13.036ZM2.85 12.636C2.62909 12.636 2.45 12.8151 2.45 13.036C2.45 13.2569 2.62909 13.436 2.85 13.436H13.15C13.3709 13.436 13.55 13.2569 13.55 13.036C13.55 12.8151 13.3709 12.636 13.15 12.636H2.85Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M5.57564 4.38825C5.80995 4.62256 6.18985 4.62256 6.42417 4.38825L7.3999 3.41251V9.63049C7.3999 9.96186 7.66853 10.2305 7.9999 10.2305C8.33127 10.2305 8.5999 9.96186 8.5999 9.63049V3.41251L9.57564 4.38825C9.80995 4.62256 10.1899 4.62256 10.4242 4.38825C10.6585 4.15393 10.6585 3.77403 10.4242 3.53972L8.4324 1.54796C8.32324 1.43445 8.16982 1.36382 7.9999 1.36382C7.82998 1.36382 7.67655 1.43446 7.56739 1.54797L5.57564 3.53972C5.34132 3.77403 5.34132 4.15393 5.57564 4.38825Z"}}]},je=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"move-up-single",ref:t,icon:an}))});je.displayName="MoveUpSingle";var on={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.82994 1.40913C7.88746 1.35161 7.95376 1.30821 8.02453 1.27893C8.09527 1.24959 8.17285 1.2334 8.2542 1.2334C8.33555 1.2334 8.41313 1.24959 8.48387 1.27893C8.55464 1.30821 8.62094 1.35161 8.67846 1.40913L10.6785 3.40913C10.9128 3.64345 10.9128 4.02335 10.6785 4.25766C10.4441 4.49198 10.0642 4.49198 9.82994 4.25766L8.8542 3.28193V5.8334C8.8542 6.16477 8.58557 6.4334 8.2542 6.4334C7.92283 6.4334 7.6542 6.16477 7.6542 5.8334V3.28193L6.67846 4.25766C6.44415 4.49198 6.06425 4.49198 5.82994 4.25766C5.59562 4.02335 5.59562 3.64345 5.82994 3.40913L7.82994 1.40913Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M1.50439 9C1.50439 8.11634 2.22074 7.4 3.10439 7.4H13.4044C14.288 7.4 15.0044 8.11634 15.0044 9 15.0044 9.88366 14.2881 10.6 13.4044 10.6H3.1044C2.22074 10.6 1.50439 9.88366 1.50439 9zM3.10439 8.6C2.88348 8.6 2.70439 8.77909 2.70439 9 2.70439 9.22091 2.88348 9.4 3.1044 9.4H13.4044C13.6253 9.4 13.8044 9.22091 13.8044 9 13.8044 8.77909 13.6253 8.6 13.4044 8.6H3.10439zM1.6543 13.1665C1.6543 12.2828 2.37064 11.5665 3.2543 11.5665H13.5543C14.438 11.5665 15.1543 12.2828 15.1543 13.1665 15.1543 14.0502 14.438 14.7665 13.5543 14.7665H3.2543C2.37064 14.7665 1.6543 14.0502 1.6543 13.1665zM3.2543 12.7665C3.03338 12.7665 2.8543 12.9456 2.8543 13.1665 2.8543 13.3874 3.03338 13.5665 3.2543 13.5665H13.5543C13.7752 13.5665 13.9543 13.3874 13.9543 13.1665 13.9543 12.9456 13.7752 12.7665 13.5543 12.7665H3.2543z",fillRule:"evenodd",clipRule:"evenodd"}}]},Le=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"topmost-single",ref:t,icon:on}))});Le.displayName="TopmostSingle";var sn={tag:"svg",attrs:{fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M7.46855 2.83731C7.46855 2.61639 7.64764 2.4373 7.86855 2.4373H13.8603C14.0812 2.4373 14.2603 2.61639 14.2603 2.8373V9.5049C14.2603 9.72581 14.0812 9.90489 13.8603 9.90489H12.866C12.5346 9.90489 12.266 10.1735 12.266 10.5049C12.266 10.8363 12.5346 11.1049 12.866 11.1049H13.8603C14.7439 11.1049 15.4603 10.3886 15.4603 9.5049V2.8373C15.4603 1.95365 14.7439 1.2373 13.8603 1.2373H7.86855C6.9849 1.2373 6.26855 1.95365 6.26855 2.83731V3.48688C6.26855 3.81825 6.53718 4.08688 6.86855 4.08688C7.19993 4.08688 7.46855 3.81825 7.46855 3.48688V2.83731Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.19888 5.56299C2.31522 5.56299 1.59888 6.27933 1.59888 7.16299V13.163C1.59888 14.0466 2.31522 14.763 3.19888 14.763H9.19888C10.0825 14.763 10.7989 14.0466 10.7989 13.163V7.16299C10.7989 6.27933 10.0825 5.56299 9.19888 5.56299H3.19888ZM2.79888 7.16299C2.79888 6.94207 2.97796 6.76299 3.19888 6.76299H9.19888C9.41979 6.76299 9.59888 6.94207 9.59888 7.16299V13.163C9.59888 13.3839 9.41979 13.563 9.19888 13.563H3.19888C2.97796 13.563 2.79888 13.3839 2.79888 13.163V7.16299Z",fillRule:"evenodd",clipRule:"evenodd"}}]},Ae=i.forwardRef(function(a,t){return i.createElement(Z,Object.assign({},a,{id:"ungroup-single",ref:t,icon:sn}))});Ae.displayName="UngroupSingle";const m={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"},ln=a=>{const{arrangeShow:t,drawings:n}=a,e=h.useDependency(h.LocaleService),r=h.useDependency(S.IDrawingManagerService),s=u=>u?"block":"none",[o,l]=i.useState(n);i.useEffect(()=>{const u=r.focus$.subscribe(g=>{l(g)});return()=>{u.unsubscribe()}},[]);const c=u=>{const g=o[0].unitId,d=o[0].subUnitId,f=o.map(p=>p.drawingId);r.featurePluginOrderUpdateNotification({unitId:g,subUnitId:d,drawingIds:f,arrangeType:u})};return i.createElement("div",{className:m.imageCommonPanelGrid,style:{display:s(t)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,e.t("image-panel.arrange.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.forward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(je,null),e.t("image-panel.arrange.forward")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.backward)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ue,null),e.t("image-panel.arrange.backward"))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.front)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Le,null),e.t("image-panel.arrange.front")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{c(S.ArrangeTypeEnum.back)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Oe,null),e.t("image-panel.arrange.back"))))))},te=20,cn=20,mn=[-3600,3600],de=300,un=a=>{var Re;const t=h.useDependency(h.LocaleService),n=h.useDependency(S.IDrawingManagerService),e=h.useDependency(b.IRenderManagerService),{drawings:r,transformShow:s}=a,o=r[0];if(o==null)return;const l=o.transform;if(l==null)return;const{unitId:c,subUnitId:u,drawingId:g,drawingType:d}=o,f=e.getRenderById(c),p=f==null?void 0:f.scene;if(p==null)return;const _=(Re=p.getEngine())==null?void 0:Re.activeScene;if(_==null)return;const w=p.getTransformerByCreate(),{width:C=0,height:N=0,left:I=0,top:B=0,angle:P=0}=l,[U,E]=i.useState(C),[D,M]=i.useState(N),[j,O]=i.useState(I),[H,G]=i.useState(B),[K,x]=i.useState(P),[me,Un]=i.useState(w.keepRatio),_e=(v,k,R,W)=>{const{width:V,height:J}=_,{ancestorLeft:F,ancestorTop:Y}=p;let X=v,q=k,ne=R,ue=W;return v+F<0&&(X=-F),k+Y<0&&(q=-Y),ne=V-X-F,ne<te&&(ne=te),ue=J-q-Y,ue<te&&(ue=te),v+ne+F>V&&(X=V-R-F),k+ue+Y>J&&(q=J-W-Y),{limitLeft:X,limitTop:q,limitWidth:ne,limitHeight:ue}},ke=v=>{const{objects:k}=v,R=ie(k,n);if(R.length!==1)return;const W=R[0];if(W==null)return;const{transform:V}=W;if(V==null)return;const{width:J,height:F,left:Y,top:X,angle:q}=V;J!=null&&E(J),F!=null&&M(F),Y!=null&&O(Y),X!=null&&G(X),q!=null&&x(q)};i.useEffect(()=>{const v=w.changeStart$.subscribe(W=>{ke(W)}),k=w.changing$.subscribe(W=>{ke(W)}),R=n.focus$.subscribe(W=>{if(W.length!==1)return;const V=n.getDrawingByParam(W[0]);if(V==null)return;const J=V.transform;if(J==null)return;const{width:F,height:Y,left:X,top:q,angle:ne}=J;F!=null&&E(F),Y!=null&&M(Y),X!=null&&O(X),q!=null&&G(q),ne!=null&&x(ne)});return()=>{k.unsubscribe(),v.unsubscribe(),R.unsubscribe()}},[]);const jn=h.debounce(v=>{if(v==null)return;v=Math.max(v,te);const{limitWidth:k,limitHeight:R}=_e(j,H,v,D);v=Math.min(v,k);const W={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{width:v}};if(me){let V=v/U*D;if(V=Math.max(V,cn),V>R)return;M(V),W.transform.height=V}E(v),n.featurePluginUpdateNotification([W]),w.refreshControls().changeNotification()},de),Ln=h.debounce(v=>{if(v==null)return;v=Math.max(v,te);const{limitHeight:k,limitWidth:R}=_e(j,H,U,v);v=Math.min(v,k);const W={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{height:v}};if(me){let V=v/D*U;if(V=Math.max(V,te),V>R)return;E(V),W.transform.width=V}M(v),n.featurePluginUpdateNotification([W]),w.refreshControls().changeNotification()},de),An=h.debounce(v=>{if(v==null)return;const{limitLeft:k}=_e(v,H,U,D);v=k;const R={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{left:v}};O(v),n.featurePluginUpdateNotification([R]),w.refreshControls().changeNotification()},de),Hn=h.debounce(v=>{if(v==null)return;const{limitTop:k}=_e(j,v,U,D);v=k;const R={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{top:v}};G(v),n.featurePluginUpdateNotification([R]),w.refreshControls().changeNotification()},de),Gn=v=>{if(v==null)return;const[k,R]=mn;v<k&&(v=k),v>R&&(v=R);const W={unitId:c,subUnitId:u,drawingId:g,drawingType:d,transform:{angle:v}};x(v),n.featurePluginUpdateNotification([W]),w.refreshControls().changeNotification()},Vn=v=>{Un(v),w.keepRatio=v},Wn=v=>v?"block":"none";return i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:Wn(s)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.transform.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.width"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:U,onChange:v=>{jn(v)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.height"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:D,onChange:v=>{Ln(v)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.lock"))),i.createElement("div",{className:L(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.Checkbox,{checked:me,onChange:Vn})))))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.x"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:j,onChange:v=>{An(v)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.y"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:H,onChange:v=>{Hn(v)},className:m.imageCommonPanelInput}))))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan3)},i.createElement("label",null,i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},t.t("image-panel.transform.rotate"))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:m.imageCommonPanelColumn},i.createElement($.InputNumber,{precision:1,value:K,onChange:Gn,className:m.imageCommonPanelInput})))))))};var T=(a=>(a.default="0",a.left="1",a.center="2",a.right="3",a.top="4",a.middle="5",a.bottom="6",a.horizon="7",a.vertical="8",a))(T||{});const he={id:"sheet.operation.set-image-align",type:h.CommandType.OPERATION,handler:(a,t)=>!0},gn=a=>{const t=h.useDependency(h.ICommandService),n=h.useDependency(h.LocaleService),{alignShow:e}=a,[r,s]=i.useState(T.default),o=[{label:n.t("image-panel.align.default"),value:T.default},{options:[{label:n.t("image-panel.align.left"),value:T.left},{label:n.t("image-panel.align.center"),value:T.center},{label:n.t("image-panel.align.right"),value:T.right}]},{options:[{label:n.t("image-panel.align.top"),value:T.top},{label:n.t("image-panel.align.middle"),value:T.middle},{label:n.t("image-panel.align.bottom"),value:T.bottom}]},{options:[{label:n.t("image-panel.align.horizon"),value:T.horizon},{label:n.t("image-panel.align.vertical"),value:T.vertical}]}];function l(u){s(u),t.executeCommand(he.id,{alignType:u})}const c=u=>u?"block":"none";return i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:c(e)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.align.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn)},i.createElement($.Select,{value:r,options:o,onChange:l}))))},fe={id:"sheet.operation.open-image-crop",type:h.CommandType.OPERATION,handler:(a,t)=>!0},ee={id:"sheet.operation.close-image-crop",type:h.CommandType.OPERATION,handler:(a,t)=>!0};var A=(a=>(a.FREE="0",a.R1_1="1",a.R16_9="2",a.R9_16="3",a.R5_4="4",a.R4_5="5",a.R4_3="6",a.R3_4="7",a.R3_2="8",a.R2_3="9",a))(A||{});const oe={id:"sheet.operation.Auto-image-crop",type:h.CommandType.OPERATION,handler:(a,t)=>!0},dn=a=>{const t=h.useDependency(h.ICommandService),n=h.useDependency(h.LocaleService),{drawings:e,cropperShow:r}=a;if(e[0]==null)return;const[o,l]=i.useState(A.FREE),c=i.useRef(!1),u=[{label:n.t("image-panel.crop.mode"),value:A.FREE},{label:"1:1",value:A.R1_1},{label:"16:9",value:A.R16_9},{label:"9:16",value:A.R9_16},{label:"5:4",value:A.R5_4},{label:"4:5",value:A.R4_5},{label:"4:3",value:A.R4_3},{label:"3:4",value:A.R3_4},{label:"3:2",value:A.R3_2},{label:"2:3",value:A.R2_3}];i.useEffect(()=>{const p=t.onCommandExecuted(_=>{if(_.id===ee.id){const w=_.params;w!=null&&w.isAuto||(c.current=!1)}});return()=>{p==null||p.dispose()}},[]);function g(p){l(p),c.current&&t.executeCommand(oe.id,{cropType:p})}const d=p=>p?"block":"none",f=p=>{t.executeCommand(oe.id,{cropType:p}),c.current=!0};return i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:d(r)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,n.t("image-panel.crop.title")))),i.createElement("div",{className:L(m.imageCommonPanelRow,m.imageCommonPanelRowVertical)},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Button,{size:"small",onClick:()=>{f(o)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ne,null),n.t("image-panel.crop.start")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2)},i.createElement($.Select,{value:o,options:u,onChange:g}))))},hn=a=>{const t=h.useDependency(h.LocaleService),n=h.useDependency(b.IRenderManagerService),e=h.useDependency(S.IDrawingManagerService),{hasGroup:r,drawings:s}=a,[o,l]=i.useState(!1),[c,u]=i.useState(!0),[g,d]=i.useState(!0),f=C=>C?"block":"none",p=()=>{const C=e.getFocusDrawings(),{unitId:N,subUnitId:I}=C[0],B=h.Tools.generateRandomId(10),P=b.getGroupState(0,0,C.map(D=>D.transform||{})),U={unitId:N,subUnitId:I,drawingId:B,drawingType:S.DrawingTypeEnum.DRAWING_GROUP,transform:P},E=C.map(D=>{const M=D.transform||{left:0,top:0},{unitId:j,subUnitId:O,drawingId:H}=D;return{unitId:j,subUnitId:O,drawingId:H,transform:{...M,left:M.left-P.left,top:M.top-P.top},groupId:B}});e.featurePluginGroupUpdateNotification([{parent:U,children:E}])},_=C=>{if(C.drawingType!==S.DrawingTypeEnum.DRAWING_GROUP)return;const{unitId:N,subUnitId:I,drawingId:B,transform:P={width:0,height:0}}=C;if(P==null)return;const U=e.getDrawingsByGroup({unitId:N,subUnitId:I,drawingId:B});if(U.length===0)return;const E=U.map(D=>{const{transform:M}=D,{unitId:j,subUnitId:O,drawingId:H}=D,G=b.transformObjectOutOfGroup(M||{},P,P.width||0,P.height||0);return{unitId:j,subUnitId:O,drawingId:H,transform:{...M,...G},groupId:void 0}});return{parent:C,children:E}},w=()=>{const N=e.getFocusDrawings().map(I=>_(I)).filter(I=>I!=null);N.length!==0&&e.featurePluginUngroupUpdateNotification(N)};return i.useEffect(()=>{const C=s[0];if(C==null)return;const{unitId:N}=C,I=n.getRenderById(N),B=I==null?void 0:I.scene;if(B==null)return;const P=B.getTransformerByCreate(),U=P.clearControl$.subscribe(D=>{D===!0&&l(!1)}),E=P.changeStart$.subscribe(D=>{const{objects:M}=D,j=ie(M,e),O=j.filter(x=>(x==null?void 0:x.drawingType)===S.DrawingTypeEnum.DRAWING_GROUP);let H=!1,G=!1;j.length>1&&(H=!0),O.length>0&&(G=!0),l(H||G),u(H),d(G)});return()=>{E.unsubscribe(),U.unsubscribe()}},[]),i.createElement("div",{className:L(m.imageCommonPanelGrid,m.imageCommonPanelBorder),style:{display:f(r===!0?o:!1)}},i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelTitle)},i.createElement("div",null,t.t("image-panel.group.title")))),i.createElement("div",{className:m.imageCommonPanelRow},i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement($.Button,{size:"small",onClick:()=>{p()},style:{display:f(c)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Te,null),t.t("image-panel.group.group")))),i.createElement("div",{className:L(m.imageCommonPanelColumn,m.imageCommonPanelSpan2,m.imageCommonPanelColumnCenter)},i.createElement($.Button,{size:"small",onClick:()=>{w()},style:{display:f(g)}},i.createElement("span",{className:m.imageCommonPanelInline},i.createElement(Ae,null),t.t("image-panel.group.unGroup"))))))},fn=a=>{const t=h.useDependency(S.IDrawingManagerService),n=h.useDependency(b.IRenderManagerService),e=h.useDependency(h.LocaleService),{drawings:r,hasArrange:s=!0,hasTransform:o=!0,hasAlign:l=!0,hasCropper:c=!0,hasGroup:u=!0}=a,g=r[0];if(g==null)return;const{unitId:d}=g,f=n.getRenderById(d),p=f==null?void 0:f.scene;if(p==null)return;const _=p.getTransformerByCreate(),[w,C]=i.useState(!0),[N,I]=i.useState(!0),[B,P]=i.useState(!1),[U,E]=i.useState(!0),[D,M]=i.useState(!1);return i.useEffect(()=>{const j=_.clearControl$.subscribe(G=>{G===!0&&(C(!1),I(!1),P(!1),E(!1),M(!0))}),O=_.changeStart$.subscribe(G=>{const{objects:K}=G,x=ie(K,t);x.length===0?(C(!1),I(!1),P(!1),E(!1),M(!0)):x.length===1?(C(!0),I(!0),P(!1),E(!0),M(!1)):(C(!0),I(!1),P(!0),E(!1),M(!1))}),H=t.focus$.subscribe(G=>{G.length===0?(C(!1),I(!1),P(!1),E(!1),M(!0)):G.length===1?(C(!0),I(!0),P(!1),E(!0),M(!1)):(C(!0),I(!1),P(!0),E(!1),M(!1))});return()=>{O.unsubscribe(),j.unsubscribe(),H.unsubscribe()}},[]),i.createElement(i.Fragment,null,i.createElement("div",{style:{display:D===!0?"block":"none",height:"100%"}},i.createElement("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100%",top:"50%",marginTop:"-100px"}},i.createElement("span",null,e.t("image-panel.null")))),i.createElement(ln,{arrangeShow:s===!0?w:!1,drawings:r}),i.createElement(un,{transformShow:o===!0?N:!1,drawings:r}),i.createElement(gn,{alignShow:l===!0?B:!1,drawings:r}),i.createElement(dn,{cropperShow:c===!0?U:!1,drawings:r}),i.createElement(hn,{hasGroup:u,drawings:r}))},se={imagePopupMenu:"univer-image-popup-menu",imagePopupMenuItem:"univer-image-popup-menu-item",imagePopupMenuItemIcon:"univer-image-popup-menu-item-icon",imagePopupMenuItemTitle:"univer-image-popup-menu-item-title",imagePopupMenuItemHide:"univer-image-popup-menu-item-hide",btnContainer:"univer-btn-container",btnContainerExpand:"univer-btn-container-expand"},He=a=>{var _,w;const t=(w=(_=a.popup)==null?void 0:_.extraProps)==null?void 0:w.menuItems;if(!t)return null;const n=h.useDependency(h.ICommandService),e=h.useDependency(h.LocaleService),[r,s]=i.useState(!1),[o,l]=i.useState(!1),c=()=>{l(!0)},u=()=>{l(!1)},g=C=>{s(C)},d=C=>{n.executeCommand(C.commandId,C.commandParams),s(!1)},f=r||o,p=t.filter(C=>!C.disable);return i.createElement("div",{onMouseEnter:c,onMouseLeave:u},i.createElement($.Dropdown,{placement:"bottomLeft",trigger:["click"],overlay:i.createElement("ul",{className:se.imagePopupMenu},p.map(C=>i.createElement("li",{key:C.index,onClick:()=>d(C),className:se.imagePopupMenuItem},i.createElement("span",{className:se.imagePopupMenuItemTitle},e.t(C.label))))),visible:r,onVisibleChange:g},i.createElement("div",{className:L(se.btnContainer,{[se.btnContainerExpand]:r})},i.createElement(De,{style:{color:"#35322B"},extend:{colorChannel1:"rgb(var(--green-700, #409f11))"}}),f&&i.createElement(Be,{style:{color:"#CCCCCC",fontSize:"8px",marginLeft:"8px"}}))))},Ge="COMPONENT_IMAGE_POPUP_MENU";var pn=Object.defineProperty,Cn=Object.getOwnPropertyDescriptor,vn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Cn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&pn(t,n,r),r},pe=(a,t)=>(n,e)=>t(n,e,a);let Ce=class extends h.Disposable{constructor(t,n,e,r){super();Q(this,"_sceneListenerOnDrawingMap",new WeakSet);this._currentUniverService=t,this._commandService=n,this._renderManagerService=e,this._drawingManagerService=r,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._drawingRemoveListener(),this._drawingUpdateListener(),this._commandExecutedListener(),this._drawingArrangeListener(),this._drawingGroupListener(),this._drawingRefreshListener(),this._drawingVisibleListener()}_recoveryImages(){const t=this._drawingManagerService.drawingManagerData,n=Ie(this._currentUniverService);if(n==null)return;const{unitId:e,subUnitId:r}=n;Object.keys(t).forEach(s=>{Object.keys(t[s]).forEach(o=>{const l=t[s][o].data;l==null||s!==e||o!==r||Object.keys(l).forEach(c=>{l[c]&&this._insertDrawing([{unitId:s,subUnitId:o,drawingId:c}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===he.id){const n=t.params;if(n==null)return;this._drawingAlign(n)}}))}_drawingGroupListener(){this.disposeWithMe(this._drawingManagerService.group$.subscribe(t=>{this._groupDrawings(t)})),this.disposeWithMe(this._drawingManagerService.ungroup$.subscribe(t=>{this._ungroupDrawings(t)}))}_getSceneAndTransformerByDrawingSearch(t){if(t==null)return;const n=this._renderManagerService.getRenderById(t),e=n==null?void 0:n.scene;if(e==null)return null;const r=e.getTransformerByCreate();return{scene:e,transformer:r}}_groupDrawings(t){t.forEach(n=>{this._groupDrawing(n)})}_groupDrawing(t){const{parent:n,children:e}=t,{unitId:r,subUnitId:s,drawingId:o}=n,l=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(l==null)return;const{scene:c,transformer:u}=l;this._commandService.syncExecuteCommand(ee.id);const g=[];if(e.forEach(p=>{const _=S.getDrawingShapeKeyByDrawingSearch(p),w=c.getObjectIncludeInGroup(_);if(w==null||g.includes(w))return;g.push(w);const{transform:C}=p;C!=null&&(w.classType===b.RENDER_CLASS_TYPE.GROUP?w.transformByState({left:C.left,top:C.top}):w.transformByState(C))}),g.length===0)return;const d=S.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),f=new b.Group(d);c.addObject(f,b.DRAWING_OBJECT_LAYER_INDEX).attachTransformerTo(f),f.addObjects(...g),n.transform&&f.transformByState({left:n.transform.left,top:n.transform.top}),u.clearSelectedObjects(),u.setSelectedControl(f)}_ungroupDrawings(t){t.forEach(n=>{this._ungroupDrawing(n)})}_ungroupDrawing(t){const{parent:n,children:e}=t,r=this._getSceneAndTransformerByDrawingSearch(n.unitId);if(r==null)return;const{scene:s,transformer:o}=r;e.forEach(d=>{const f=S.getDrawingShapeKeyByDrawingSearch(d),p=s.getObjectIncludeInGroup(f);if(p==null)return!0;if(p==null)return;const{transform:_}=d;_!=null&&(p.classType===b.RENDER_CLASS_TYPE.GROUP?p.transformByState({left:_.left,top:_.top}):p.transformByState(_))});const l=S.getDrawingShapeKeyByDrawingSearch(n),c=s.getObject(l),{width:u,height:g}=c;c.getObjects().forEach(d=>{c.removeSelfObjectAndTransform(d.oKey,u,g)}),c.dispose(),o.clearSelectedObjects()}_drawingAlign(t){const{alignType:n}=t,e=this._drawingManagerService.getFocusDrawings();if(n===T.default)return;const r=[];let s=Number.POSITIVE_INFINITY,o=Number.POSITIVE_INFINITY,l=Number.NEGATIVE_INFINITY,c=Number.NEGATIVE_INFINITY,u=0;e.forEach(g=>{const{unitId:d,subUnitId:f,drawingId:p,drawingType:_}=g,w=this._drawingManagerService.getDrawingByParam({unitId:d,subUnitId:f,drawingId:p});if(w==null||w.transform==null)return;r.push({unitId:d,subUnitId:f,drawingId:p,drawingType:_,transform:w.transform});const{left:C=0,top:N=0,width:I=0,height:B=0}=w.transform;s=Math.min(s,C),o=Math.min(o,N),l=Math.max(l,C+I),c=Math.max(c,N+B),u++}),u!==0&&(this._sortDrawingTransform(r,n),this._applyAlignType(r,n,s,o,l,c,u))}_applyAlignType(t,n,e,r,s,o,l){const c=Math.round((s-e)/l*10)/10,u=Math.round((o-r)/l*10)/10,g=[],d=this._getSceneAndTransformerByDrawingSearch(t[0].unitId);if(d==null)return;const{scene:f,transformer:p}=d;t.forEach((_,w)=>{const{unitId:C,subUnitId:N,drawingId:I,transform:B,drawingType:P}=_,{left:U=0,top:E=0,width:D=0,height:M=0}=B;let j=U,O=E;switch(n){case T.left:j=e;break;case T.center:j=e+(s-e)/2-D/2;break;case T.right:j=s-D;break;case T.top:O=r;break;case T.middle:O=r+(o-r)/2-M/2;break;case T.bottom:O=o-M;break;case T.horizon:j=e+c*w;break;case T.vertical:O=r+u*w;break}(j!==U||O!==E)&&g.push({unitId:C,subUnitId:N,drawingId:I,drawingType:P,transform:{left:j,top:O}})}),this._drawingManagerService.featurePluginUpdateNotification(g),p.refreshControls().changeNotification()}_sortDrawingTransform(t,n){t.sort((e,r)=>{const s=e.transform,o=r.transform,{left:l=0,top:c=0,width:u=0,height:g=0}=s,{left:d=0,top:f=0,width:p=0,height:_=0}=o;switch(n){case T.left:return l-d;case T.center:return l+u/2-(d+p/2);case T.right:return l+u-(d+p);case T.top:return c-f;case T.middle:return c+g/2-(f+_/2);case T.bottom:return c+g-(f+_);case T.horizon:return l+u/2-(d+p/2);case T.vertical:return c+g/2-(f+_/2);default:return 0}})}_drawingArrangeListener(){this.disposeWithMe(this._drawingManagerService.order$.subscribe(t=>{this._drawingArrange(t)}))}_drawingArrange(t){const{unitId:n,subUnitId:e,drawingIds:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n);if(s==null)return;const{scene:o,transformer:l}=s;r.forEach(c=>{const u=S.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:c}),g=o.getObject(u);if(g==null)return;const d=this._drawingManagerService.getDrawingOrder(n,e).indexOf(c);g.setProps({zIndex:d}),g.makeDirty()})}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(t=>{this._insertDrawing(t)}))}_insertDrawing(t){const n=[];t.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e;if(this._drawingManagerService.getDrawingByParam(e)==null)return;const c=this._getSceneAndTransformerByDrawingSearch(r);if(c==null)return;const{scene:u,transformer:g}=c;n.includes(u)||n.push(u)}),n.forEach(e=>{this._sceneListenerOnDrawingMap.has(e)||(this._addListenerOnDrawing(e),this._sceneListenerOnDrawingMap.add(e))})}_drawingRemoveListener(){this.disposeWithMe(this._drawingManagerService.remove$.subscribe(t=>{t.forEach(n=>{var d;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:l,transformer:c}=o,u=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),g=l.getObject(u);g!=null&&(g.dispose(),(d=l.getTransformer())==null||d.clearSelectedObjects())})}))}_drawingUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._drawingManagerService.getDrawingByParam(n);if(o==null)return;const{transform:l,drawingType:c}=o,u=this._getSceneAndTransformerByDrawingSearch(e);if(u==null)return;const{scene:g,transformer:d}=u;if(l==null)return!0;const{left:f=0,top:p=0,width:_=0,height:w=0,angle:C=0,flipX:N=!1,flipY:I=!1,skewX:B=0,skewY:P=0}=l,U=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),E=g.getObject(U);if(E==null)return!0;E.transformByState({left:f,top:p,width:_,height:w,angle:C,flipX:N,flipY:I,skewX:B,skewY:P})})}))}_drawingRefreshListener(){this.disposeWithMe(this._drawingManagerService.refreshTransform$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._getSceneAndTransformerByDrawingSearch(e);if(o==null)return;const{scene:l,transformer:c}=o,u=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),g=l.getObject(u);if(g==null)return!0;const d=this._drawingManagerService.getDrawingByParam(n);if(d==null)return;const{transform:f}=d;if(f==null)return!0;const{left:p=0,top:_=0,width:w=0,height:C=0,angle:N=0,flipX:I=!1,flipY:B=!1,skewX:P=0,skewY:U=0}=f;g.transformByState({left:p,top:_,width:w,height:C,angle:N,flipX:I,flipY:B,skewX:P,skewY:U})})}))}_drawingVisibleListener(){this.disposeWithMe(this._drawingManagerService.visible$.subscribe(t=>{t.forEach(n=>{const{unitId:e,subUnitId:r,drawingId:s,visible:o}=n,l=this._getSceneAndTransformerByDrawingSearch(e);if(l==null)return;const{scene:c,transformer:u}=l,g=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),d=c.getObject(g);if(d==null)return!0;o?d.show():d.hide()})}))}_filterUpdateParams(t,n){return t.filter((e,r)=>{if(e==null)return!1;const{transform:s}=e;return h.checkIfMove(s,n==null?void 0:n[r])})}_addListenerOnDrawing(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(h.toDisposable(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=Array.from(s.values()),l=[];e=o.map(c=>{const{left:u,top:g,height:d,width:f,angle:p,oKey:_,groupKey:w,isInGroup:C}=c,N=this._drawingManagerService.getDrawingOKey(_);if(C||c instanceof b.Group){let I=c.ancestorGroup;if(I==null&&c instanceof b.Group&&(I=c),I==null)return null;const B=this._drawingManagerService.getDrawingOKey(I.oKey);if(B){const{unitId:P,subUnitId:U,drawingId:E}=B;l.push({unitId:P,subUnitId:U,drawingId:E});const{left:D,top:M,height:j,width:O,angle:H}=I;return{left:D,top:M,height:j,width:O,angle:H}}}else if(N!=null){const{unitId:I,subUnitId:B,drawingId:P}=N;return l.push({unitId:I,subUnitId:B,drawingId:P}),{left:u,top:g,height:d,width:f,angle:p}}return null}).filter(c=>c!=null),l.length>0?this._drawingManagerService.focusDrawing(l):this._drawingManagerService.focusDrawing(null)}))),this.disposeWithMe(h.toDisposable(n.changeEnd$.subscribe(r=>{const{objects:s}=r;this._filterUpdateParams(ie(s,this._drawingManagerService),e).length>0})))}};Ce=vn([h.OnLifecycle(h.LifecycleStages.Rendered,Ce),pe(0,h.IUniverInstanceService),pe(1,h.ICommandService),pe(2,b.IRenderManagerService),pe(3,S.IDrawingManagerService)],Ce);const wn=a=>{const{src:t}=a;return t?i.createElement("div",null,i.createElement("img",{src:t,alt:"Univer Image Viewer",style:{width:"100%",height:"100%",position:"relative"}})):null},Ve="COMPONENT_IMAGE_VIEWER",be={id:"sheet.operation.image-reset-size",type:h.CommandType.OPERATION,handler:(a,t)=>!0};var Sn=Object.defineProperty,_n=Object.getOwnPropertyDescriptor,In=(a,t,n,e)=>{for(var r=e>1?void 0:e?_n(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&Sn(t,n,r),r},le=(a,t)=>(n,e)=>t(n,e,a);let ve=class extends h.Disposable{constructor(a,t,n,e,r){super(),this._injector=a,this._componentManager=t,this._menuService=n,this._commandService=e,this._localeService=r,this._init()}_initCustomComponents(){const a=this._componentManager;this.disposeWithMe(a.register(Ge,He)),this.disposeWithMe(a.register(Ve,wn))}_initMenus(){}_initCommands(){[fe,ee,be,he,oe].forEach(a=>this.disposeWithMe(this._commandService.registerCommand(a)))}_init(){this._initCommands(),this._initCustomComponents(),this._initMenus()}};ve=In([h.OnLifecycle(h.LifecycleStages.Rendered,ve),le(0,h.Inject(h.Injector)),le(1,h.Inject(ge.ComponentManager)),le(2,ge.IMenuService),le(3,h.ICommandService),le(4,h.Inject(h.LocaleService))],ve);class ce extends b.Shape{constructor(n,e){e==null&&(e={}),e.transformerConfig={keepRatio:!1,isCropper:!0,anchorFill:"rgb(0, 0, 0)",anchorStroke:"rgb(255, 255, 255)",anchorSize:24};super(n,e);Q(this,"_srcRect");Q(this,"_prstGeom");Q(this,"_applyTransform");Q(this,"_dragPadding",8);Q(this,"_cacheCanvas");e!=null&&e.srcRect&&(this._srcRect=e.srcRect),e!=null&&e.prstGeom&&(this._prstGeom=e.prstGeom),e!=null&&e.applyTransform&&(this._applyTransform=e.applyTransform),e!=null&&e.dragPadding&&(this._dragPadding=e.dragPadding),this._applyProps()}refreshSrcRect(n,e){this._srcRect=n,this._applyTransform=e,this._applyProps()}get srcRect(){return this._srcRect}dispose(){var n;super.dispose(),(n=this._cacheCanvas)==null||n.dispose(),this._srcRect=null}isHit(n){const e=this.getInverseCoord(n);return e.x>=-this.strokeWidth/2&&e.x<=this.width+this.strokeWidth/2&&e.y>=-this.strokeWidth/2&&e.y<=this.height+this.strokeWidth/2&&!this._inSurround(e)}_inSurround(n){const e=this._dragPadding;return n.x>=e-this.strokeWidth/2&&n.x<=this.width+this.strokeWidth/2-e&&n.y>=e-this.strokeWidth/2&&n.y<=this.height+this.strokeWidth/2-e}render(n,e){return this.visible?(n.save(),this._draw(n),n.restore(),this.makeDirty(!1),this):(this.makeDirty(!1),this)}_draw(n){var c,u;const r=this.getScene().getEngine(),{width:s,height:o}=r;this._initialCacheCanvas(),(c=this._cacheCanvas)==null||c.clear();const l=(u=this._cacheCanvas)==null?void 0:u.getContext();l!=null&&(l.save(),b.Rect.drawWith(l,{left:0,top:0,width:s,height:o,fill:"rgba(0, 0, 0, 0.5)"}),l.setTransform(n.getTransform()),this._clipForApplyObject(l),this._applyCache(n),l.restore())}_clipForApplyObject(n){let e=0;if(this._prstGeom!=null&&(e=1),n.globalCompositeOperation="destination-out",n.beginPath(),e===0){const r=this.transform.getMatrix();n.transform(r[0],r[1],r[2],r[3],r[4],r[5]),n.rect(0,0,this.width,this.height),n.fill()}}_applyProps(){if(this._applyTransform==null)return;let n=0,e=0,r=0,s=0;const{left:o=0,top:l=0,width:c=0,height:u=0,angle:g}=this._applyTransform;if(this._srcRect!=null){const{left:p=0,top:_=0,right:w=0,bottom:C=0}=this._srcRect;n=p,e=_,r=w,s=C}const d=o+n,f=l+e;this.transformByState({left:d,top:f,width:o+c-r-d,height:l+u-s-f,angle:g})}_applyCache(n){if(!n||this._cacheCanvas==null)return;const e=this._cacheCanvas.getContext();e.save(),n.save(),n.setTransform(1,0,0,1,0,0),e.setTransform(1,0,0,1,0,0),n.drawImage(this._cacheCanvas.getCanvasEle(),0,0),n.restore(),e.restore()}_initialCacheCanvas(){if(this._cacheCanvas!=null)return;this._cacheCanvas=new b.Canvas;const n=this.getScene().getEngine();this._cacheCanvas.setSize(n.width,n.height),n.onTransformChange$.subscribeEvent(()=>{var e;(e=this._cacheCanvas)==null||e.setSize(n.width,n.height),this.makeDirty(!0)})}}var bn=Object.defineProperty,yn=Object.getOwnPropertyDescriptor,Pn=(a,t,n,e)=>{for(var r=e>1?void 0:e?yn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&bn(t,n,r),r},ae=(a,t)=>(n,e)=>t(n,e,a);let we=class extends h.Disposable{constructor(t,n,e,r,s,o){super();Q(this,"_sceneListenerOnImageMap",new WeakSet);this._commandService=t,this._drawingManagerService=n,this._renderManagerService=e,this._univerInstanceService=r,this._messageService=s,this._localeService=o,this._init()}_init(){this._initOpenCrop(),this._initCloseCrop(),this._initAutoCrop()}_initAutoCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==oe.id)return;const n=t.params;if(n==null)return;const{cropType:e}=n,r=this._drawingManagerService.getFocusDrawings();if(r.length!==1)return;const s=r[0],{unitId:o,subUnitId:l,drawingId:c}=s,u=this._renderManagerService.getRenderById(o),g=u==null?void 0:u.scene;if(g==null)return!0;this._searchCropObject(g)!=null&&this._commandService.syncExecuteCommand(ee.id,{isAuto:!0});const f=S.getDrawingShapeKeyByDrawingSearch({unitId:o,subUnitId:l,drawingId:c}),p=g.getObject(f);if(!(p instanceof b.Image)){this._messageService.show({type:$.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}p!=null&&(this._updateCropperObject(e,p),this._commandService.executeCommand(fe.id,{unitId:o,subUnitId:l,drawingId:c}))}))}_calculateSrcRectByRatio(t,n,e,r,s,o){const l=e/r,c=s/o;let u=e,g=r;l>c?u=r*c:g=e/c;const d=(e-u)/2,f=(r-g)/2;return{left:b.precisionTo(d,1),top:b.precisionTo(f,1),right:b.precisionTo(e-(d+u),1),bottom:b.precisionTo(r-(f+g),1)}}_updateCropperObject(t,n){const{left:e,top:r,width:s,height:o}=n.calculateTransformWithSrcRect();let l;switch(t){case A.R1_1:l=this._calculateSrcRectByRatio(e,r,s,o,1,1);break;case A.R16_9:l=this._calculateSrcRectByRatio(e,r,s,o,16,9);break;case A.R9_16:l=this._calculateSrcRectByRatio(e,r,s,o,9,16);break;case A.R5_4:l=this._calculateSrcRectByRatio(e,r,s,o,5,4);break;case A.R4_5:l=this._calculateSrcRectByRatio(e,r,s,o,4,5);break;case A.R4_3:l=this._calculateSrcRectByRatio(e,r,s,o,4,3);break;case A.R3_4:l=this._calculateSrcRectByRatio(e,r,s,o,3,4);break;case A.R3_2:l=this._calculateSrcRectByRatio(e,r,s,o,3,2);break;case A.R2_3:l=this._calculateSrcRectByRatio(e,r,s,o,2,3);break;case A.FREE:}if(l==null)return;n.setSrcRect(l);const{left:c=0,top:u=0,bottom:g=0,right:d=0}=l;n.transformByStateCloseCropper({left:e+c,top:r+u,width:s-d-c,height:o-g-u})}_initOpenCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id!==fe.id)return;const n=t.params;if(n==null)return;const{unitId:e,subUnitId:r,drawingId:s}=n,o=this._renderManagerService.getRenderById(e),l=o==null?void 0:o.scene;if(l==null)return!0;if(this._sceneListenerOnImageMap.has(l)||(this._addListenerOnImage(l),this._sceneListenerOnImageMap.add(l)),this._drawingManagerService.getDrawingByParam({unitId:e,subUnitId:r,drawingId:s})==null)return;const u=S.getDrawingShapeKeyByDrawingSearch({unitId:e,subUnitId:r,drawingId:s}),g=l.getObject(u);if(g==null)return;if(!(g instanceof b.Image)){this._messageService.show({type:$.MessageType.Error,content:this._localeService.t("image-cropper.error")});return}const d=l.getTransformer();d==null||d.clearControls();const f=new ce(`${u}-crop`,{srcRect:g.srcRect,prstGeom:g.prstGeom,applyTransform:g.calculateTransformWithSrcRect()});l.addObject(f,g.getLayerIndex()+1).attachTransformerTo(f),d==null||d.createControlForCopper(f),this._addHoverForImageCopper(f),g.openRenderByCropper(),d==null||d.refreshControls(),f.makeDirty(!0),this._drawingManagerService.focusDrawing([{unitId:e,subUnitId:r,drawingId:s}])}))}_searchCropObject(t){const n=t.getAllObjects();for(const e of n)if(e instanceof ce)return e}_initCloseCrop(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(n.id!==ee.id)return;const e=this._univerInstanceService.getFocusedUnit();if(e==null)return;const r=e.getUnitId(),s=this._renderManagerService.getRenderById(r),o=s==null?void 0:s.scene;if(o==null)return!0;const l=this._searchCropObject(o);if(l==null)return;const c=this._getApplyObjectByCropObject(l);if(c==null)return;const u=o.getTransformerByCreate();u.detachFrom(l),u.clearCopperControl();const g=this._getSrcRectByTransformState(c,l),d=this._drawingManagerService.getDrawingOKey(c.oKey);if(d!=null){const{left:f,top:p,height:_,width:w}=l;this._drawingManagerService.featurePluginUpdateNotification([{...d,transform:{...d.transform,left:f,top:p,height:_,width:w},srcRect:g.srcRectAngle}])}c.setSrcRect({...g.srcRectAngle}),c.closeRenderByCropper(),c.makeDirty(!0),l==null||l.dispose()}));const t=this._univerInstanceService.getCurrentTypeOfUnit$(h.UniverInstanceType.UNIVER_SHEET).pipe(Pe.filter(n=>!!n),Pe.switchMap(n=>n.activeSheet$));this.disposeWithMe(t.subscribe(()=>{this._commandService.syncExecuteCommand(ee.id)}))}_getApplyObjectByCropObject(t){const n=t.oKey,e=n.slice(0,n.length-5),r=t.getScene().getObject(e);return r==null?null:r}_addListenerOnImage(t){const n=t.getTransformerByCreate();let e=null;this.disposeWithMe(n.changeStart$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof ce))return;const{left:l,top:c,height:u,width:g,angle:d}=o;e={left:l,top:c,height:u,width:g,angle:d},n.clearCopperControl()})),this.disposeWithMe(n.changeEnd$.subscribe(r=>{const{objects:s}=r,o=s.values().next().value;if(o==null||!(o instanceof ce))return;const{left:l,top:c,height:u,width:g,angle:d}=o;if(!h.checkIfMove({left:l,top:c,height:u,width:g,angle:d},e))return;const f=this._getApplyObjectByCropObject(o);if(f==null)return;const p=this._getSrcRectByTransformState(f,o);o.refreshSrcRect(p.srcRect,f.getState()),n.createControlForCopper(o)})),this._endCropListener(t)}_addHoverForImageCopper(t){this.disposeWithMe(t.onPointerEnter$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.MOVE})),this.disposeWithMe(t.onPointerLeave$.subscribeEvent(()=>{t.cursor=b.CURSOR_TYPE.DEFAULT}))}_endCropListener(t){const n=t.getTransformerByCreate();this.disposeWithMe(n.clearControl$.subscribe(e=>{e===!0&&this._commandService.syncExecuteCommand(ee.id)}))}_getSrcRectByTransformState(t,n){const{left:e,top:r,height:s,width:o,strokeWidth:l,angle:c}=n,{left:u,top:g,width:d,height:f,angle:p,strokeWidth:_}=t,w=e-u,C=r-g,N={left:w,top:C,right:d-w-o,bottom:f-C-s},I={...N};if(p!==0){const B=e+o/2,P=r+s/2,U=new b.Vector2(B,P),E=d/2+u,D=f/2+g,M=new b.Vector2(E,D),j=new b.Vector2(u,g);j.rotateByPoint(b.degToRad(p),M);const O=j.clone();O.rotateByPoint(b.degToRad(-p),U);const H=e-O.x,G=r-O.y;I.left=H,I.top=G,I.right=d-H-o,I.bottom=f-G-s}return{srcRect:N,srcRectAngle:I}}};we=Pn([h.OnLifecycle(h.LifecycleStages.Rendered,we),ae(0,h.ICommandService),ae(1,S.IDrawingManagerService),ae(2,b.IRenderManagerService),ae(3,h.IUniverInstanceService),ae(4,ge.IMessageService),ae(5,h.Inject(h.LocaleService))],we);var En=Object.defineProperty,Mn=Object.getOwnPropertyDescriptor,Dn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Mn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&En(t,n,r),r},re=(a,t)=>(n,e)=>t(n,e,a);const We=50;let Se=class extends h.Disposable{constructor(a,t,n,e,r,s,o){super(),this._commandService=a,this._renderManagerService=t,this._drawingManagerService=n,this._dialogService=e,this._imageIoService=r,this._currentUniverService=s,this._drawingRenderService=o,this._initialize()}dispose(){super.dispose()}_initialize(){this._recoveryImages(),this._drawingAddListener(),this._commandExecutedListener(),this._imageUpdateListener()}_recoveryImages(){const a=this._drawingManagerService.drawingManagerData,t=Ie(this._currentUniverService);if(t==null)return;const{unitId:n,subUnitId:e}=t;Object.keys(a).forEach(r=>{Object.keys(a[r]).forEach(s=>{const o=a[r][s].data;o==null||r!==n||s!==e||Object.keys(o).forEach(l=>{o[l]&&this._insertImages([{unitId:r,subUnitId:s,drawingId:l}])})})})}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(a=>{if(a.id===be.id){const t=a.params;if(t==null)return;this._resetImageSize(t)}}))}_getSceneAndTransformerByDrawingSearch(a){if(a==null)return;const t=this._renderManagerService.getRenderById(a),n=t==null?void 0:t.scene;if(n==null)return null;const e=n.getTransformerByCreate();return{scene:n,transformer:e}}_resetImageSize(a){const t=[],n=[];a.forEach(e=>{const{unitId:r,subUnitId:s,drawingId:o}=e,l=this._getSceneAndTransformerByDrawingSearch(r);if(l==null)return;const{scene:c}=l,u=S.getDrawingShapeKeyByDrawingSearch({unitId:r,subUnitId:s,drawingId:o}),g=c.getObject(u);if(g==null)return!0;const d=this._drawingManagerService.getDrawingByParam(e);if(d==null)return!0;if(d.drawingType!==S.DrawingTypeEnum.DRAWING_IMAGE)return;g.resetSize();const{width:f,height:p}=g.getNativeSize();n.includes(c)===!1&&n.push(c),t.push({...d,transform:{...d.transform,height:p,width:f,angle:0},srcRect:null,prstGeom:null})}),this._drawingManagerService.featurePluginUpdateNotification(t),n.forEach(e=>{e.getTransformerByCreate().refreshControls().changeNotification()}),this._drawingManagerService.focusDrawing(a)}_drawingAddListener(){this.disposeWithMe(this._drawingManagerService.add$.subscribe(a=>{this._insertImages(a)}))}_insertImages(a){a.forEach(async t=>{var u;const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._getSceneAndTransformerByDrawingSearch(n),o=(u=Ie(this._currentUniverService))==null?void 0:u.subUnitId;if(s==null||o!==e)return;const l=this._drawingManagerService.getDrawingByParam(t);if(l==null)return;const c=await this._drawingRenderService.renderImage(l,s.scene);c!=null&&(this._addHoverForImage(c),this._addDialogForImage(c))})}_imageUpdateListener(){this.disposeWithMe(this._drawingManagerService.update$.subscribe(a=>{a.forEach(t=>{const{unitId:n,subUnitId:e,drawingId:r}=t,s=this._drawingManagerService.getDrawingByParam(t);if(s==null)return;const{transform:o,drawingType:l,srcRect:c,prstGeom:u,source:g,imageSourceType:d}=s;if(l!==S.DrawingTypeEnum.DRAWING_IMAGE)return;const f=this._getSceneAndTransformerByDrawingSearch(n);if(f==null)return;const{scene:p,transformer:_}=f;if(o==null)return!0;const w=S.getDrawingShapeKeyByDrawingSearch({unitId:n,subUnitId:e,drawingId:r}),C=p.getObject(w);if(C==null)return!0;C.setSrcRect(c),C.setPrstGeom(u)})}))}_addHoverForImage(a){this.disposeWithMe(h.toDisposable(a.onPointerEnter$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.GRAB}))),this.disposeWithMe(h.toDisposable(a.onPointerLeave$.subscribeEvent(()=>{a.cursor=b.CURSOR_TYPE.DEFAULT})))}_addDialogForImage(a){this.disposeWithMe(h.toDisposable(a.onDblclick$.subscribeEvent(()=>{var l;const t=`${a.oKey}-viewer-dialog`,n=a.getNativeSize(),e=window.innerWidth-We,r=window.innerHeight-We,s=this._adjustImageSize(n.width,n.height,e,r),o=this._dialogService.open({width:s.width,id:t,style:{margin:"0",top:"50%",left:"50%",transform:"translate(-50%, -50%)"},children:{label:{name:Ve,props:{src:(l=a.getNative())==null?void 0:l.src,width:s.width,height:s.height}}},destroyOnClose:!0,draggable:!1,onClose:()=>{this._dialogService.close(t),o.dispose()}})})))}_adjustImageSize(a,t,n,e){if(a<=n&&t<=e)return{width:a,height:t};const r=n/a,s=e/t,o=Math.min(r,s);return{width:Math.floor(a*o),height:Math.floor(t*o)}}};Se=Dn([h.OnLifecycle(h.LifecycleStages.Rendered,Se),re(0,h.ICommandService),re(1,b.IRenderManagerService),re(2,S.IDrawingManagerService),re(3,ge.IDialogService),re(4,S.IImageIoService),re(5,h.IUniverInstanceService),re(6,h.Inject(y.DrawingRenderService))],Se);var On=Object.defineProperty,Nn=Object.getOwnPropertyDescriptor,Tn=(a,t,n,e)=>{for(var r=e>1?void 0:e?Nn(t,n):t,s=a.length-1,o;s>=0;s--)(o=a[s])&&(r=(e?o(t,n,r):o(r))||r);return e&&r&&On(t,n,r),r},$e=(a,t)=>(n,e)=>t(n,e,a);const Bn="DRAWING_UI_PLUGIN";y.UniverDrawingUIPlugin=(ye=class extends h.Plugin{constructor(t,n,e){super(),this._injector=n,this._localeService=e}onStarting(t){this._initDependencies(t)}_initDependencies(t){[[y.DrawingRenderService],[Ce],[ve],[we],[Se]].forEach(e=>t.add(e))}},Q(ye,"pluginName",Bn),ye),y.UniverDrawingUIPlugin=Tn([$e(1,h.Inject(h.Injector)),$e(2,h.Inject(h.LocaleService))],y.UniverDrawingUIPlugin),y.AutoImageCropOperation=oe,y.COMPONENT_IMAGE_POPUP_MENU=Ge,y.CloseImageCropOperation=ee,y.DrawingCommonPanel=fn,y.ImageCropperObject=ce,y.ImagePopupMenu=He,y.ImageResetSizeOperation=be,y.OpenImageCropOperation=fe,y.SetDrawingAlignOperation=he,y.getUpdateParams=ie,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@univerjs/drawing-ui",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.4-alpha.0",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "",
|
|
6
6
|
"author": "DreamNum <developer@univer.ai>",
|
|
@@ -48,34 +48,32 @@
|
|
|
48
48
|
"lib"
|
|
49
49
|
],
|
|
50
50
|
"peerDependencies": {
|
|
51
|
-
"@wendellhu/redi": "0.15.5",
|
|
52
51
|
"clsx": ">=2.0.0",
|
|
53
52
|
"react": "^16.9.0 || ^17.0.0 || ^18.0.0",
|
|
54
53
|
"rxjs": ">=7.0.0",
|
|
55
|
-
"@univerjs/
|
|
56
|
-
"@univerjs/
|
|
57
|
-
"@univerjs/
|
|
58
|
-
"@univerjs/
|
|
59
|
-
"@univerjs/
|
|
54
|
+
"@univerjs/ui": "0.2.4-alpha.0",
|
|
55
|
+
"@univerjs/engine-render": "0.2.4-alpha.0",
|
|
56
|
+
"@univerjs/core": "0.2.4-alpha.0",
|
|
57
|
+
"@univerjs/drawing": "0.2.4-alpha.0",
|
|
58
|
+
"@univerjs/design": "0.2.4-alpha.0"
|
|
60
59
|
},
|
|
61
60
|
"dependencies": {
|
|
62
|
-
"@univerjs/icons": "^0.1.
|
|
61
|
+
"@univerjs/icons": "^0.1.64"
|
|
63
62
|
},
|
|
64
63
|
"devDependencies": {
|
|
65
|
-
"@wendellhu/redi": "0.15.5",
|
|
66
64
|
"clsx": "^2.1.1",
|
|
67
65
|
"less": "^4.2.0",
|
|
68
66
|
"react": "18.3.1",
|
|
69
67
|
"rxjs": "^7.8.1",
|
|
70
68
|
"typescript": "^5.5.3",
|
|
71
|
-
"vite": "^5.3.
|
|
72
|
-
"vitest": "^
|
|
73
|
-
"@univerjs/
|
|
74
|
-
"@univerjs/
|
|
75
|
-
"@univerjs/
|
|
76
|
-
"@univerjs/
|
|
77
|
-
"@univerjs/
|
|
78
|
-
"@univerjs/
|
|
69
|
+
"vite": "^5.3.4",
|
|
70
|
+
"vitest": "^2.0.3",
|
|
71
|
+
"@univerjs/design": "0.2.4-alpha.0",
|
|
72
|
+
"@univerjs/drawing": "0.2.4-alpha.0",
|
|
73
|
+
"@univerjs/core": "0.2.4-alpha.0",
|
|
74
|
+
"@univerjs/engine-render": "0.2.4-alpha.0",
|
|
75
|
+
"@univerjs/shared": "0.2.4-alpha.0",
|
|
76
|
+
"@univerjs/ui": "0.2.4-alpha.0"
|
|
79
77
|
},
|
|
80
78
|
"univerSpace": {
|
|
81
79
|
".": {
|