@netless/appliance-plugin 1.1.18-beta.1 → 1.1.18

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.
@@ -1 +1 @@
1
- "use strict";var F=Object.defineProperty;var _=(v,t,e)=>t in v?F(v,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):v[t]=e;var u=(v,t,e)=>_(v,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-u5GMq5Ct.js"),C=require("spritejs"),N=require("lodash");require("clipper-lib");require("lineclip");require("white-web-sdk");require("react-dom");require("react");require("eventemitter2");class B{constructor(t){u(this,"vNodes");u(this,"thread");u(this,"serviceWorkShapes",new Map);u(this,"localWorkShapes",new Map);u(this,"tmpOpt");u(this,"animationId");u(this,"syncUnitTime",s.DefaultAppliancePluginOptions.syncOpt.interval);this.vNodes=t.vNodes,this.thread=t.thread}createLocalWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o){const a=e.toString();!this.getToolsOpt()&&r&&this.setToolsOpt({toolsType:r,toolsOpt:o}),this.setWorkOptions(a,o)}}getLocalWorkShape(t){return this.localWorkShapes.get(t)}createLocalWorkShape(t,e){if(t&&this.tmpOpt){const o={toolsType:this.tmpOpt.toolsType,toolsOpt:e||this.tmpOpt.toolsOpt},r=this.createWorkShapeNode({...o,workId:t});return r&&this.localWorkShapes.set(t,{node:r,toolsType:r.toolsType,workState:s.EvevtWorkState.Start}),r}}canUseTopLayer(t){return t===s.EToolsKey.LaserPen}destroy(){this.clearAll()}clearAll(){this.thread.topLayer.children.length&&(this.thread.topLayer.parent.children.forEach(t=>{t.name!=="viewport"&&t.remove()}),s.removeAllChildren(this.thread.serviceLayer,this.thread.serviceLayer.parent)),this.serviceWorkShapes.clear(),this.localWorkShapes.clear()}consumeDraw(t){const{workId:e,dataType:o}=t;if(o===s.EDataType.Service)this.activeServiceWorkShape(t);else{const r=e==null?void 0:e.toString(),a=r&&this.localWorkShapes.get(r);if(!a)return;const i=a.node.consume({data:t,isFullWork:!1,isSubWorker:!0});i.rect&&(a.result=i,a.workState=s.EvevtWorkState.Doing,r&&this.localWorkShapes.set(r,a))}this.runAnimation()}setToolsOpt(t){var e;this.tmpOpt=t,(e=t.toolsOpt)!=null&&e.syncUnitTime&&(this.syncUnitTime=t.toolsOpt.syncUnitTime)}getToolsOpt(){return this.tmpOpt}createWorkShapeNode(t){const{toolsType:e}=t;if(e===s.EToolsKey.LaserPen)return s.getShapeInstance({...t,vNodes:this.vNodes,fullLayer:this.thread.topLayer,drawLayer:this.thread.topLayer})}setNodeKey(t,e,o,r){return e.toolsType=o,e.node=this.createWorkShapeNode({workId:t,toolsType:o,toolsOpt:r}),e}activeServiceWorkShape(t){var y,d;const{workId:e,opt:o,toolsType:r,type:a,updateNodeOpt:i,ops:n,op:l}=t;if(!e)return;const c=e.toString(),p=(y=this.vNodes.get(c))==null?void 0:y.rect;if(!((d=this.serviceWorkShapes)!=null&&d.has(c))){let m={toolsType:r,animationWorkData:l||[],animationIndex:0,type:a,updateNodeOpt:i,ops:n,oldRect:p};r&&o&&(m=this.setNodeKey(c,m,r,o)),this.serviceWorkShapes.set(c,m)}const h=this.serviceWorkShapes.get(c);a&&(h.type=a),n&&(h.animationWorkData=s.transformToNormalData(n),h.ops=n),i&&(h.updateNodeOpt=i),l&&(h.animationWorkData=l),h.node&&h.node.getWorkId()!==c&&h.node.setWorkId(c),p&&(h.oldRect=p),r&&o&&(h.toolsType!==r&&r&&o&&this.setNodeKey(c,h,r,o),h.node&&h.node.setWorkOptions(o))}computNextAnimationIndex(t,e){var a;const o=((a=t.node)==null?void 0:a.syncUnitTime)||this.syncUnitTime,r=Math.floor((t.animationWorkData||[]).slice(t.animationIndex).length*32/e/o)*e;return Math.min((t.animationIndex||0)+(r||e),(t.animationWorkData||[]).length)}animationDraw(){var r,a,i,n;this.animationId=void 0;let t=!1;const e=new Map,o=[];for(const[l,c]of this.serviceWorkShapes.entries())switch(c.toolsType){case s.EToolsKey.LaserPen:{const h=this.computNextAnimationIndex(c,8),y=Math.max(0,c.animationIndex||0),d=(c.animationWorkData||[]).slice(y,h);if((c.animationIndex||0)<h&&((r=c.node)==null||r.consumeService({op:d,isFullWork:!1}),c.animationIndex=h,d.length&&e.set(l,{workState:y===0?s.EvevtWorkState.Start:h===((a=c.animationWorkData)==null?void 0:a.length)?s.EvevtWorkState.Done:s.EvevtWorkState.Doing,op:d.slice(-2)})),c.isDel){(i=c.node)==null||i.clearTmpPoints(),this.serviceWorkShapes.delete(l);break}c.ops&&c.animationIndex===((n=c.animationWorkData)==null?void 0:n.length)&&!c.isDel&&(this.thread.topLayer.getElementsByName(l.toString())[0]||(c.isDel=!0,this.serviceWorkShapes.set(l,c))),t=!0;break}}for(const[l,c]of this.localWorkShapes.entries()){const{result:p,toolsType:h,isDel:y,workState:d}=c;switch(h){case s.EToolsKey.LaserPen:{if(y){c.node.clearTmpPoints(),this.localWorkShapes.delete(l),o.push({removeIds:[l.toString()],type:s.EPostMessageType.RemoveNode});break}p&&((p.op||p.ops)&&o.push(p),c.result=void 0),!this.thread.topLayer.getElementsByName(l.toString())[0]&&d===s.EvevtWorkState.Done&&(c.isDel=!0,this.localWorkShapes.set(l,c)),t=!0;break}}}t&&this.runAnimation(),e.size&&e.forEach((l,c)=>{o.push({type:s.EPostMessageType.Cursor,uid:c.split(s.Storage_Splitter)[0],op:l.op,workState:l.workState,viewId:this.thread.viewId})}),o.length&&this.thread.post({sp:o})}runAnimation(){this.animationId||(this.animationId=requestAnimationFrame(this.animationDraw.bind(this)))}setWorkOptions(t,e){var r;let o=(r=this.localWorkShapes.get(t))==null?void 0:r.node;if(!o&&this.tmpOpt){const{toolsType:a}=this.tmpOpt;this.tmpOpt.toolsOpt=e,o=this.createWorkShapeNode({workId:t,toolsType:a,toolsOpt:e}),o&&this.localWorkShapes.set(t,{node:o,toolsType:a,workState:s.EvevtWorkState.Start}),this.setToolsOpt(this.tmpOpt)}e!=null&&e.syncUnitTime||(e.syncUnitTime=this.syncUnitTime),o&&o.setWorkOptions(e)}consumeDrawAll(t){const{workId:e,dataType:o}=t;if(o===s.EDataType.Service)this.activeServiceWorkShape(t);else{const r=e==null?void 0:e.toString(),a=r&&this.localWorkShapes.get(r);if(!a)return;const i=a.node.consumeAll({data:t});a.result=i,a.workState=s.EvevtWorkState.Done,r&&this.localWorkShapes.set(r,a)}this.runAnimation()}}class U{constructor(t){u(this,"vNodes");u(this,"thread");u(this,"workShapes",new Map);u(this,"effectSelectNodeData",new Set);u(this,"batchEraserRemoveNodes",new Set);u(this,"batchEraserWorks",new Set);u(this,"tmpOpt");u(this,"syncUnitTime",s.DefaultAppliancePluginOptions.syncOpt.interval);u(this,"fullWorkerDrawCount",0);u(this,"drawWorkActiveId");u(this,"consumeCount",0);this.vNodes=t.vNodes,this.thread=t.thread}async loadImageBitMap(t){return await this.thread.loadImageBitMap(t)}createLocalWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o){const a=e.toString();!this.getToolsOpt()&&r&&this.setToolsOpt({toolsType:r,toolsOpt:o}),this.setWorkOptions(a,o)}}async updateSelector(t){var y;const e=this.workShapes.get(s.Storage_Selector_key);if(!((y=e==null?void 0:e.selectIds)!=null&&y.length))return;const{callback:o,...r}=t,{updateSelectorOpt:a,willSerializeData:i}=r,n=await(e==null?void 0:e.updateSelector({updateSelectorOpt:a,selectIds:N.cloneDeep(e.selectIds),vNodes:this.vNodes,willSerializeData:i,worker:this})),l=new Map;let c;n!=null&&n.selectIds&&(c=N.xor(e.selectIds,n.selectIds),n.selectIds.forEach(d=>{const m=this.vNodes.get(d);if(m){const{toolsType:k,op:S,opt:T}=m;l.set(d,{opt:T,toolsType:k,ops:(S==null?void 0:S.length)&&s.transformToSerializableData(S)||void 0})}}),e.selectIds=n.selectIds);const p=[],h=o&&o({res:n,workShapeNode:e,param:r,postData:{sp:p},newServiceStore:l})||{sp:p};c&&h.sp.push({type:s.EPostMessageType.RemoveNode,removeIds:c,viewId:this.thread.viewId}),h.sp.length&&this.thread.post(h)}destroy(){this.clearAll()}clearAll(){if(this.thread.localLayer.children.length&&(this.thread.topLayer.parent.children.forEach(e=>{e.name!=="viewport"&&e.remove()}),s.removeAllChildren(this.thread.localLayer,this.thread.localLayer.parent)),this.workShapes.get(s.Storage_Selector_key)){const e=[];e.push({type:s.EPostMessageType.Select,dataType:s.EDataType.Local,selectIds:[],willSyncService:!1}),this.thread.post({sp:e})}this.workShapes.clear(),this.effectSelectNodeData.clear(),this.batchEraserWorks.clear(),this.batchEraserRemoveNodes.clear()}async checkTextActive(t){const{op:e,viewId:o,dataType:r}=t;if(e!=null&&e.length){let a;for(const i of this.vNodes.curNodeMap.values()){const{rect:n,name:l,toolsType:c,opt:p}=i,h=e[0]*this.thread.fullLayer.worldScaling[0]+this.thread.fullLayer.worldPosition[0],y=e[1]*this.thread.fullLayer.worldScaling[1]+this.thread.fullLayer.worldPosition[1];if(c===s.EToolsKey.Text&&s.isIntersectForPoint([h,y],n)&&p.workState===s.EvevtWorkState.Done){a=l;break}}a&&(await this.blurSelector({viewId:o,msgType:s.EPostMessageType.Select,dataType:r,isSync:!0}),this.thread.post({sp:[{type:s.EPostMessageType.GetTextActive,toolsType:s.EToolsKey.Text,workId:a}]}))}}cursorHover(t){const{opt:e,toolsType:o,point:r}=t,a=this.setFullWork({workId:s.Cursor_Hover_Id,toolsType:o,opt:e});a&&r&&a.cursorHover(r)}cursorBlur(){var e;const t=this.getWorkShape(s.Cursor_Hover_Id);t&&((e=t.selectIds)!=null&&e.length)&&(t.cursorBlur(),this.clearWorkShapeNodeCache(s.Cursor_Hover_Id)),this.thread.fullLayer.parent.children.forEach(o=>{o.name==="Cursor_Hover_Id"&&o.remove()})}updateFullSelectWork(t){var r,a,i,n,l;const e=this.workShapes.get(s.Storage_Selector_key),{selectIds:o}=t;if(!(o!=null&&o.length)){this.blurSelector(t);return}if(!e){const c=this.setFullWork(t);!c&&t.workId&&this.tmpOpt&&((r=this.tmpOpt)==null?void 0:r.toolsType)===s.EToolsKey.Selector&&this.setWorkOptions(t.workId.toString(),t.opt||this.tmpOpt.toolsOpt),c&&this.updateFullSelectWork(t);return}if(e&&(o!=null&&o.length)){const{selectRect:c}=e.updateSelectIds(o),p=[{...t,selectorColor:((a=t.opt)==null?void 0:a.strokeColor)||e.selectorColor,strokeColor:((i=t.opt)==null?void 0:i.strokeColor)||e.strokeColor,fillColor:((n=t.opt)==null?void 0:n.fillColor)||e.fillColor,textOpt:((l=t.opt)==null?void 0:l.textOpt)||e.textOpt,canTextEdit:e.canTextEdit,canRotate:e.canRotate,scaleType:e.scaleType,type:s.EPostMessageType.Select,selectRect:c,points:e.getChildrenPoints(),willSyncService:(t==null?void 0:t.willSyncService)||!1,opt:(t==null?void 0:t.willSyncService)&&e.getWorkOptions()||void 0,canLock:e.canLock,isLocked:e.isLocked,toolsTypes:e.toolsTypes,shapeOpt:e.shapeOpt,thickness:e.thickness,useStroke:e.useStroke,strokeType:e.strokeType}];this.thread.post({sp:p})}}commandDeleteText(t){const e=this.vNodes.get(t);if(e&&e.toolsType===s.EToolsKey.Text)return{type:s.EPostMessageType.TextUpdate,toolsType:s.EToolsKey.Text,workId:t,dataType:s.EDataType.Local}}async removeSelector(t){const{willSyncService:e}=t,o=[],r=[],a=this.workShapes.get(s.Storage_Selector_key);if(!a)return;const i=a.selectIds&&[...a.selectIds]||[];for(const n of i){if(this.vNodes.get(n)){const c=this.commandDeleteText(n);c&&o.push(c)}this.removeNode(n),r.push(n)}r.length&&o.push({type:s.EPostMessageType.RemoveNode,removeIds:r}),o.push({type:s.EPostMessageType.Select,selectIds:[],willSyncService:e}),await this.blurSelector(),o.length&&this.thread.post({sp:o})}removeWork(t){const{workId:e}=t,o=e==null?void 0:e.toString();o&&this.removeNode(o)}removeNode(t){var r;this.vNodes.get(t)&&((r=this.thread.fullLayer)==null||r.getElementsByName(t).forEach(a=>{a.remove(),s.removeTexture(a,this.thread.fullLayer.parent)}),this.vNodes.delete(t)),this.workShapes.has(t)&&(this.thread.localLayer.getElementsByName(t).forEach(a=>{a.remove(),s.removeTexture(a,this.thread.localLayer.parent)}),this.clearWorkShapeNodeCache(t))}setFullWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o&&r){const a=e.toString();let i;return e&&this.workShapes.has(a)?(i=this.workShapes.get(a),i==null||i.setWorkOptions(o)):i=this.createWorkShapeNode({toolsOpt:o,toolsType:r,workId:a}),i?(this.workShapes.set(a,i),i):void 0}}async consumeFull(t){var r;const e=this.setFullWork(t),o=t.ops&&s.transformToNormalData(t.ops);if(e){const a=(r=t.workId)==null?void 0:r.toString();e.toolsType===s.EToolsKey.Image?await e.consumeServiceAsync({isFullWork:!0,replaceId:a,worker:this}):e.toolsType===s.EToolsKey.Text?await e.consumeServiceAsync({isFullWork:!0,replaceId:a}):e.consumeService({op:o,isFullWork:!0,replaceId:a}),t!=null&&t.updateNodeOpt&&e.updataOptService(t.updateNodeOpt);const i=[];t.workId&&this.workShapes.delete(t.workId.toString()),t.willSyncService&&i.push({opt:t.opt,toolsType:t.toolsType,type:s.EPostMessageType.FullWork,workId:t.workId,ops:t.ops,updateNodeOpt:t.updateNodeOpt,viewId:this.thread.viewId}),i.length&&this.thread.post({sp:i})}}async colloctEffectSelectWork(t){const e=this.workShapes.get(s.Storage_Selector_key),{workId:o,msgType:r}=t;if(e&&o&&e.selectIds&&e.selectIds.includes(o.toString())){r===s.EPostMessageType.RemoveNode?e.selectIds=e.selectIds.filter(a=>a!==o.toString()):this.effectSelectNodeData.add(t),await new Promise(a=>{setTimeout(()=>{a(!0)},0)}),await this.runEffectSelectWork(!0).then(()=>{var a;(a=this.effectSelectNodeData)==null||a.clear()});return}return t}async runEffectSelectWork(t){var e;for(const o of this.effectSelectNodeData.values()){const r=this.setFullWork(o);if(r){const a=(e=o.workId)==null?void 0:e.toString();if(r.toolsType===s.EToolsKey.Image)await r.consumeServiceAsync({isFullWork:!0,replaceId:a,worker:this});else if(r.toolsType===s.EToolsKey.Text)await r.consumeServiceAsync({isFullWork:!0,replaceId:a});else{const i=o.ops&&s.transformToNormalData(o.ops);r.consumeService({op:i,isFullWork:!0,replaceId:a}),o!=null&&o.updateNodeOpt&&r.updataOptService(o.updateNodeOpt)}o.workId&&this.workShapes.delete(o.workId.toString())}}this.reRenderSelector(t)}hasSelector(){return this.workShapes.has(s.Storage_Selector_key)}getSelector(){return this.workShapes.get(s.Storage_Selector_key)}reRenderSelector(t=!1){var r;const e=this.workShapes.get(s.Storage_Selector_key);if(!e)return;if(e&&!((r=e.selectIds)!=null&&r.length))return this.blurSelector();const o=e.reRenderSelector();o&&this.thread.post({sp:[{type:s.EPostMessageType.Select,selectIds:e.selectIds,selectRect:o,willSyncService:t,viewId:this.thread.viewId,points:e.getChildrenPoints(),textOpt:e.textOpt,selectorColor:e.selectorColor,strokeColor:e.strokeColor,fillColor:e.fillColor,canTextEdit:e.canTextEdit,canRotate:e.canRotate,scaleType:e.scaleType,opt:e.getWorkOptions()||void 0,canLock:e.canLock,isLocked:e.isLocked,toolsTypes:e.toolsTypes,shapeOpt:e.shapeOpt,thickness:e.thickness,useStroke:e.useStroke,strokeType:e.strokeType}]})}async blurSelector(t){var r;const e=this.workShapes.get(s.Storage_Selector_key),o=e==null?void 0:e.blurSelector();if(this.clearWorkShapeNodeCache(s.Storage_Selector_key),((r=this.thread.fullLayer)==null?void 0:r.parent).children.forEach(a=>{a.name===s.Storage_Selector_key&&a.remove()}),o){const a=[];a.push({...o,isSync:t==null?void 0:t.isSync}),this.thread.post({sp:a})}}clearWorkShapeNodeCache(t){var e;(e=this.getWorkShape(t))==null||e.clearTmpPoints(),this.workShapes.delete(t)}async drawBitMapEraserFull(t,e,o){const{willUpdateNodes:r,willDeleteNodes:a}=e,i=t.getWorkId(),n=[{type:s.EPostMessageType.RemoveNode,removeIds:[i],viewId:this.thread.viewId}];if(o&&n.push({type:s.EPostMessageType.None,isLockSentEventCursor:o}),r!=null&&r.size||a!=null&&a.size){if(r!=null&&r.size)for(const[l,c]of r)n.push({type:s.EPostMessageType.UpdateNode,dataType:s.EDataType.Local,opt:c.opt,workId:l,updateNodeOpt:{useAnimation:!1}});a!=null&&a.size&&n.push({type:s.EPostMessageType.RemoveNode,removeIds:[...a],viewId:this.thread.viewId})}n.length&&this.thread.post({sp:n})}drawPencilEraserFull(t,e,o){const{willNewNodes:r,willDeleteNodes:a}=e,i=t.getWorkId(),n=[{type:s.EPostMessageType.RemoveNode,removeIds:[i],viewId:this.thread.viewId}];if(o&&n.push({type:s.EPostMessageType.None,isLockSentEventCursor:o}),r!=null&&r.size||a!=null&&a.size){if(r!=null&&r.size)for(const[l,c]of r)n.push({type:s.EPostMessageType.FullWork,dataType:s.EDataType.Local,ops:s.transformToSerializableData(c.op),opt:c.opt,workId:l,updateNodeOpt:{useAnimation:!1}});a!=null&&a.size&&n.push({type:s.EPostMessageType.RemoveNode,removeIds:[...a],viewId:this.thread.viewId})}n.length&&this.thread.post({sp:n})}drawEraser(t,e){const o=[];t.removeIds&&o.push(t),e&&o.push({type:s.EPostMessageType.None,isLockSentEventCursor:e}),this.thread.post({sp:o,consumeCount:this.consumeCount})}getWorkShape(t){return this.workShapes.get(t)}getWorkShapes(){return this.workShapes}consumeDraw(t,e){const{op:o,workId:r,scenePath:a,postCount:i}=t;if(o!=null&&o.length&&r){const n=r.toString(),l=this.workShapes.get(n);if(!l)return;const c=l.toolsType;if(c===s.EToolsKey.LaserPen)return;switch(this.drawWorkActiveId&&this.drawWorkActiveId!==n&&(this.consumeDrawAll({workId:this.drawWorkActiveId,scenePath:a,viewId:this.thread.viewId,msgType:s.EPostMessageType.DrawWork,dataType:s.EDataType.Local},e),this.drawWorkActiveId=void 0),!this.drawWorkActiveId&&n!==s.Storage_Selector_key&&(this.drawWorkActiveId=n),N.isNumber(i)&&(this.consumeCount=i),c){case s.EToolsKey.Selector:{const p=l.consume({data:t,isFullWork:!0,isMainThread:!0});this.fullWorkerDrawCount++;const h=[];p.type===s.EPostMessageType.Select&&(p.selectIds&&e.runReverseSelectWork(p.selectIds),h.push(p)),this.thread.post({consumeCount:this.consumeCount,fullWorkerDrawCount:this.fullWorkerDrawCount,sp:h})}break;case s.EToolsKey.PencilEraser:case s.EToolsKey.BitMapEraser:{const p=l.consume({data:t,isFullWork:!1,isMainThread:!0});this.fullWorkerDrawCount++,this.thread.post({consumeCount:this.consumeCount,fullWorkerDrawCount:this.fullWorkerDrawCount,sp:p.op&&[{...p,scenePath:a}]||void 0});break}case s.EToolsKey.Eraser:{const p=l.consume({data:t,isFullWork:!0});this.drawEraser(p)}break;case s.EToolsKey.Arrow:case s.EToolsKey.Straight:case s.EToolsKey.Ellipse:case s.EToolsKey.Rectangle:case s.EToolsKey.Star:case s.EToolsKey.Polygon:case s.EToolsKey.SpeechBalloon:case s.EToolsKey.Pencil:{const p=l.consume({data:t,isFullWork:!1,isMainThread:!0});p&&(this.fullWorkerDrawCount++,this.thread.post({consumeCount:this.consumeCount,fullWorkerDrawCount:this.fullWorkerDrawCount,sp:p.op&&[{...p,scenePath:a}]||void 0}))}break}}}consumeDrawAll(t,e){var i,n,l;const{workId:o,scenePath:r,isLockSentEventCursor:a}=t;if(o){const c=o.toString();this.drawWorkActiveId===c&&(this.drawWorkActiveId=void 0);const p=this.workShapes.get(c);if(!p)return;const h=p.toolsType;if(h===s.EToolsKey.LaserPen)return;const y=this.workShapes.get(s.Cursor_Hover_Id),d=(i=y==null?void 0:y.selectIds)==null?void 0:i[0],m=p.consumeAll({data:t,workerEngine:this});switch(h){case s.EToolsKey.Selector:{m.selectIds&&d&&((n=m.selectIds)!=null&&n.includes(d))&&y.cursorBlur();const k=[];a&&k.push({type:s.EPostMessageType.None,isLockSentEventCursor:a}),m.type===s.EPostMessageType.Select&&(m.selectIds&&e.runReverseSelectWork(m.selectIds),k.push({...m,scenePath:r})),k.length&&this.thread.post({sp:k}),(l=p.selectIds)!=null&&l.length?p.clearTmpPoints():this.clearWorkShapeNodeCache(c)}break;case s.EToolsKey.PencilEraser:this.drawPencilEraserFull(p,m,a),this.fullWorkerDrawCount=0,this.clearWorkShapeNodeCache(c);break;case s.EToolsKey.BitMapEraser:this.drawBitMapEraserFull(p,m,a),this.fullWorkerDrawCount=0,this.clearWorkShapeNodeCache(c);break;case s.EToolsKey.Eraser:this.drawEraser({...m,scenePath:r},a),p.clearTmpPoints();break;case s.EToolsKey.Arrow:case s.EToolsKey.Straight:case s.EToolsKey.Ellipse:case s.EToolsKey.Rectangle:case s.EToolsKey.Star:case s.EToolsKey.Polygon:case s.EToolsKey.SpeechBalloon:case s.EToolsKey.Pencil:{const k=[];a&&k.push({type:s.EPostMessageType.None,isLockSentEventCursor:a}),m&&(k.push(m),this.fullWorkerDrawCount=0,this.thread.post({fullWorkerDrawCount:this.fullWorkerDrawCount,sp:k})),this.clearWorkShapeNodeCache(c);break}}}}getToolsOpt(){return this.tmpOpt}setToolsOpt(t){var e;this.tmpOpt=t,(e=t.toolsOpt)!=null&&e.syncUnitTime&&(this.syncUnitTime=t.toolsOpt.syncUnitTime)}setWorkOptions(t,e){let o=this.workShapes.get(t);if(!o&&this.tmpOpt){const{toolsType:r}=this.tmpOpt;this.tmpOpt.toolsOpt=e,o=this.createWorkShapeNode({workId:t,toolsType:r,toolsOpt:e}),o&&this.workShapes.set(t,o),this.setToolsOpt(this.tmpOpt)}e.syncUnitTime||(e.syncUnitTime=this.syncUnitTime),o==null||o.setWorkOptions(e)}createWorkShapeNode(t){return s.getShapeInstance({...t,vNodes:this.vNodes,fullLayer:this.thread.fullLayer,drawLayer:this.thread.localLayer},this.thread.serviceWork)}}class K{constructor(t){u(this,"vNodes");u(this,"thread");u(this,"workShapes",new Map);u(this,"selectorWorkShapes",new Map);u(this,"willRunEffectSelectorIds",new Set);u(this,"runEffectId");u(this,"animationId");u(this,"syncUnitTime",s.DefaultAppliancePluginOptions.syncOpt.interval);this.vNodes=t.vNodes,this.thread=t.thread}async loadImageBitMap(t){return await this.thread.loadImageBitMap(t)}destroy(){this.clearAll()}clearAll(){this.thread.serviceLayer.children.length&&(this.thread.serviceLayer.parent.children.forEach(t=>{t.name!=="viewport"&&t.remove()}),s.removeAllChildren(this.thread.serviceLayer,this.thread.serviceLayer.parent)),this.workShapes.clear(),this.selectorWorkShapes.clear(),this.willRunEffectSelectorIds.clear()}runEffect(){this.runEffectId||(this.runEffectId=setTimeout(this.effectRunSelector.bind(this),0))}effectRunSelector(){this.runEffectId=void 0,this.willRunEffectSelectorIds.forEach(t=>{var o,r;const e=this.selectorWorkShapes.get(t);e&&e.selectIds&&((o=e.node)==null||o.selectServiceNode(t,e,!0)),(r=e==null?void 0:e.selectIds)!=null&&r.length||this.selectorWorkShapes.delete(t)}),this.willRunEffectSelectorIds.clear()}runSelectWork(t){this.activeSelectorShape(t);const{workId:e}=t,o=e==null?void 0:e.toString();o&&this.willRunEffectSelectorIds.add(o),this.runEffect()}removeWork(t){const{workId:e}=t,o=e==null?void 0:e.toString();if(o){if(this.workShapes.get(o)){this.workShapes.delete(o),this.removeNode(o,t);return}this.removeNode(o,t)}}consumeFull(t){this.activeWorkShape(t),this.runAnimation()}runReverseSelectWork(t){t.forEach(e=>{this.selectorWorkShapes.forEach((o,r)=>{var a;if((a=o.selectIds)!=null&&a.length){const i=o.selectIds.indexOf(e);i>-1&&(o.selectIds.splice(i,1),this.willRunEffectSelectorIds.add(r))}})}),this.willRunEffectSelectorIds.size&&this.runEffect()}consumeDraw(t){this.activeWorkShape(t),this.runAnimation()}computNextAnimationIndex(t,e){const o=Math.floor((t.animationWorkData||[]).slice(t.animationIndex).length*32/e/this.syncUnitTime)*e;return Math.min((t.animationIndex||0)+(o||e),(t.animationWorkData||[]).length)}async animationDraw(){var o,r,a,i,n,l,c,p,h,y,d,m,k,S,T,E,D,R,x;this.animationId=void 0;let t=!1;const e=new Map;for(const[g,f]of this.workShapes.entries())switch(f.toolsType){case s.EToolsKey.Image:{await((o=f.node)==null?void 0:o.consumeServiceAsync({isFullWork:!0,worker:this})),this.selectorWorkShapes.forEach((w,I)=>{var W;(W=w.selectIds)!=null&&W.includes(g)&&(this.willRunEffectSelectorIds.add(I),this.runEffect())}),this.workShapes.delete(g);break}case s.EToolsKey.Text:{f.node&&(await((r=f.node)==null?void 0:r.consumeServiceAsync({isFullWork:!0,replaceId:g})),this.selectorWorkShapes.forEach((w,I)=>{var W;(W=w.selectIds)!=null&&W.includes(g)&&(this.willRunEffectSelectorIds.add(I),this.runEffect())}),(a=f.node)==null||a.clearTmpPoints(),this.workShapes.delete(g));break}case s.EToolsKey.Arrow:case s.EToolsKey.Straight:case s.EToolsKey.Rectangle:case s.EToolsKey.Ellipse:case s.EToolsKey.Star:case s.EToolsKey.Polygon:case s.EToolsKey.SpeechBalloon:{const w=!!f.ops;if((i=f.animationWorkData)!=null&&i.length){const I=f.oldRect;(n=f.node)==null||n.consumeService({op:f.animationWorkData,isFullWork:w}),w&&(this.selectorWorkShapes.forEach((W,M)=>{var P;(P=W.selectIds)!=null&&P.includes(g)&&(this.willRunEffectSelectorIds.add(M),this.runEffect())}),(l=f.node)==null||l.clearTmpPoints(),this.workShapes.delete(g)),e.set(g,{workState:I?f.ops?s.EvevtWorkState.Done:s.EvevtWorkState.Doing:s.EvevtWorkState.Start,op:f.animationWorkData.filter((W,M)=>{if(M%3!==2)return!0}).slice(-2)}),f.animationWorkData.length=0}break}case s.EToolsKey.Pencil:{if(!f.useAnimation&&f.ops)(c=f.node)==null||c.consumeService({op:f.animationWorkData||[],isFullWork:!0,replaceId:g}),(p=f.node)==null||p.updataOptService(f.updateNodeOpt),this.selectorWorkShapes.forEach((w,I)=>{var W;(W=w.selectIds)!=null&&W.includes(g)&&(this.willRunEffectSelectorIds.add(I),this.runEffect())}),(h=f.node)==null||h.clearTmpPoints(),this.workShapes.delete(g);else if(f.useAnimation){if(f.isDel){(y=f.node)==null||y.clearTmpPoints(),this.workShapes.delete(g);break}const w=3,I=this.computNextAnimationIndex(f,w),W=f.isDiff?0:Math.max(0,(f.animationIndex||0)-w),M=(f.animationWorkData||[]).slice(W,I),P=(m=(d=f.node)==null?void 0:d.getWorkId())==null?void 0:m.toString();if((f.animationIndex||0)<I||f.isDiff){if((k=f.node)==null||k.consumeService({op:M,isFullWork:!1}),f.animationIndex=I,f.isDiff&&(f.isDiff=!1),M.length){const O=M.filter((b,A)=>{if(A%w!==w-1)return!0}).slice(-2);e.set(g,{workState:W===0?s.EvevtWorkState.Start:I===((S=f.animationWorkData)==null?void 0:S.length)?s.EvevtWorkState.Done:s.EvevtWorkState.Doing,op:O})}}else f.ops&&((T=f.node)==null||T.consumeService({op:f.animationWorkData||[],isFullWork:!0,replaceId:P}),f.isDel=!0,e.set(g,{workState:s.EvevtWorkState.Done,op:M.filter((O,b)=>{if(b%w!==w-1)return!0}).slice(-2)}));t=!0;break}break}case s.EToolsKey.BitMapEraser:case s.EToolsKey.PencilEraser:{if(f.isDel){(E=f.node)==null||E.clearTmpPoints(),this.workShapes.delete(g);break}if(f.ops&&((D=f.animationWorkData)!=null&&D.length)){const w=f.animationWorkData.slice(-3,-1);e.set(g,{workState:s.EvevtWorkState.Done,op:w}),f.isDel=!0;break}if(f.useAnimation){const I=this.computNextAnimationIndex(f,3),W=f.isDiff?0:Math.max(0,(f.animationIndex||0)-3),M=(f.animationWorkData||[]).slice(W,I);if(((f.animationIndex||0)<I||f.isDiff)&&((R=f.node)==null||R.consumeService({op:M,isFullWork:!1}),f.animationIndex=I,f.isDiff&&(f.isDiff=!1),M.length)){const P=M.filter((O,b)=>{if(b%3!==2)return!0}).slice(-2);e.set(g,{workState:W===0?s.EvevtWorkState.Start:I===((x=f.animationWorkData)==null?void 0:x.length)?s.EvevtWorkState.Done:s.EvevtWorkState.Doing,op:P})}t=!0;break}break}}if(t&&this.runAnimation(),e.size){const g=[];e.forEach((f,w)=>{g.push({type:s.EPostMessageType.Cursor,uid:w.split(s.Storage_Splitter)[0],op:f.op,workState:f.workState,viewId:this.thread.viewId})}),this.thread.post({sp:g})}}runAnimation(){this.animationId||(this.animationId=requestAnimationFrame(this.animationDraw.bind(this)))}hasDiffData(t,e,o){const r=t.length;if(e.length<r)return!0;switch(o){case s.EToolsKey.Pencil:{for(let a=0;a<r;a+=3)if(e[a]!==t[a]||e[a+1]!==t[a+1])return!0;break}case s.EToolsKey.LaserPen:{for(let a=0;a<r;a+=2)if(e[a]!==t[a]||e[a+1]!==t[a+1])return!0;break}}return!1}activeWorkShape(t){var m,k,S,T;const{workId:e,opt:o,toolsType:r,type:a,updateNodeOpt:i,ops:n,op:l,useAnimation:c,imageBitmap:p}=t;if(!e)return;const h=e.toString(),y=(m=this.vNodes.get(h))==null?void 0:m.rect;if(!((k=this.workShapes)!=null&&k.has(h))){let E={toolsType:r,animationWorkData:l||[],animationIndex:0,type:a,updateNodeOpt:i,ops:n,useAnimation:typeof c<"u"?c:typeof(i==null?void 0:i.useAnimation)<"u"?i==null?void 0:i.useAnimation:!0,oldRect:y,isDiff:!1,imageBitmap:p};r&&o&&(E=this.setNodeKey(h,E,r,o)),(S=this.workShapes)==null||S.set(h,E)}const d=(T=this.workShapes)==null?void 0:T.get(h);a&&(d.type=a),n&&(d.animationWorkData=s.transformToNormalData(n),d.ops=n),i&&(d.updateNodeOpt=i),l&&(d.isDiff=this.hasDiffData(d.animationWorkData||[],l,d.toolsType),d.animationWorkData=l),d.node&&d.node.getWorkId()!==h&&d.node.setWorkId(h),y&&(d.oldRect=y),r&&o&&(o.syncUnitTime&&(this.syncUnitTime=o.syncUnitTime),d.toolsType!==r&&r&&o&&this.setNodeKey(h,d,r,o),d.node&&d.node.setWorkOptions(o)),p&&(d.imageBitmap=p)}removeNode(t,e){t.indexOf(s.Storage_Selector_key)>-1&&this.removeSelectWork(e),this.thread.fullLayer.getElementsByName(t).forEach(o=>{o.remove(),s.removeTexture(o,this.thread.fullLayer.parent)}),this.thread.serviceLayer.getElementsByName(t).forEach(o=>{o.remove(),s.removeTexture(o,this.thread.serviceLayer.parent)}),this.vNodes.delete(t)}removeSelectWork(t){const{workId:e}=t,o=e==null?void 0:e.toString();o&&(this.activeSelectorShape(t),this.willRunEffectSelectorIds.add(o)),this.runEffect()}activeSelectorShape(t){var c,p,h;const{workId:e,opt:o,toolsType:r,type:a,selectIds:i}=t;if(!e)return;const n=e.toString();if(!((c=this.selectorWorkShapes)!=null&&c.has(n))){let y={toolsType:r,selectIds:i,type:a,opt:o};r&&o&&(y=this.setNodeKey(n,y,r,o)),(p=this.selectorWorkShapes)==null||p.set(n,y)}const l=(h=this.selectorWorkShapes)==null?void 0:h.get(n);a&&(l.type=a),l.node&&l.node.getWorkId()!==n&&l.node.setWorkId(n),l.selectIds=i||[]}setNodeKey(t,e,o,r){return e.toolsType=o,e.node=s.getShapeInstance({toolsType:o,toolsOpt:r,vNodes:this.vNodes,fullLayer:this.thread.fullLayer,drawLayer:this.thread.serviceLayer,workId:t},this),e}}class L{constructor(){u(this,"localWork");u(this,"serviceWork");u(this,"threadEngine")}registerMainThread(t){return this.threadEngine=t,this.localWork=t.localWork,this.serviceWork=t.serviceWork,this}}class z extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.CopyNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.FullWork&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var r;const{workId:o}=e;o&&await((r=this.localWork)==null?void 0:r.consumeFull(e))}}class q extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetColorNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n,textUpdateForWoker:l}=o,c=r.sp||[];if(i)for(const[p,h]of a.entries())l&&h.toolsType===s.EToolsKey.Text?c.push({...h,workId:p,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):c.push({...h,workId:p,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:c}}}class H extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.ZIndexNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;o===s.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n}=o,l=r.sp||[];if(i&&l)for(const[c,p]of a.entries())l.push({...p,workId:c,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:l}}}class V extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.TranslateNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var p,h;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l,emitEventType:c}=e;o===s.Storage_Selector_key&&r&&(r.workState===s.EvevtWorkState.Done&&(r!=null&&r.translate)&&(r.translate[0]||r.translate[1])||r.workState!==s.EvevtWorkState.Done?await((p=this.localWork)==null?void 0:p.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,isSync:!0,textUpdateForWoker:l,emitEventType:c,callback:this.updateSelectorCallback})):r.workState===s.EvevtWorkState.Done&&((h=this.localWork)==null||h.vNodes.deleteLastTarget()))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c,updateSelectorOpt:p,textUpdateForWoker:h}=o,y=p.workState,d=r.sp||[];if(y===s.EvevtWorkState.Start)return{sp:[],render:[]};const m=n==null?void 0:n.selectRect;if(l){y===s.EvevtWorkState.Doing&&d.push({type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:m,willSyncService:!0,isSync:!0,points:i.getChildrenPoints(),textOpt:i.textOpt});for(const[k,S]of a.entries())h&&S.toolsType===s.EToolsKey.Text?d.push({...S,workId:k,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):d.push({...S,workId:k,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c})}return{sp:d}}}class $ extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.DeleteNode)}async consume(){return!1}}class G extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.ScaleNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var n;const{workId:o,updateNodeOpt:r,willSyncService:a,willSerializeData:i}=e;o===s.Storage_Selector_key&&r&&await((n=this.localWork)==null?void 0:n.updateSelector({updateSelectorOpt:r,willSyncService:a,willSerializeData:i,isSync:!0,callback:this.updateSelectorCallback.bind(this)}))}updateSelectorCallback(e){const{param:o,postData:r,workShapeNode:a,res:i,newServiceStore:n}=e,{updateSelectorOpt:l,willSyncService:c}=o,p=l.workState,h=r.sp||[],y=i==null?void 0:i.selectRect;if(p===s.EvevtWorkState.Start)return{sp:[],render:[]};if(c){h.push({type:s.EPostMessageType.Select,selectIds:a.selectIds,selectRect:y,willSyncService:!0,isSync:!0,points:p===s.EvevtWorkState.Done&&a.getChildrenPoints()||void 0,textOpt:a.textOpt});for(const[d,m]of n.entries())m.toolsType===s.EToolsKey.Text?h.push({...m,workId:d,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):h.push({...m,workId:d,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:!0})}return{sp:h}}}class j extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.RotateNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,emitEventType:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,emitEventType:l,isSync:!0,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,workShapeNode:a,res:i,newServiceStore:n}=e,{updateSelectorOpt:l,willSyncService:c,willSerializeData:p,isSync:h}=o,y=l.workState,d=r.sp||[],m=i==null?void 0:i.selectRect;if(c){p&&y===s.EvevtWorkState.Done&&d.push({type:s.EPostMessageType.Select,selectIds:a.selectIds,selectRect:m,willSyncService:!0,isSync:h,points:a.getChildrenPoints()});for(const[k,S]of n.entries())d.push({...S,workId:k,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:h})}return{sp:d}}}class Z extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetFontStyle)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c,updateSelectorOpt:p,textUpdateForWoker:h}=o,y=r.sp||[],d=n==null?void 0:n.selectRect;if(l&&y){p.fontSize&&y.push({type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:d,willSyncService:l,isSync:c,points:i.getChildrenPoints()});for(const[m,k]of a.entries())h&&k.toolsType===s.EToolsKey.Text?y.push({...k,workId:m,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):y.push({...k,workId:m,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c})}return{sp:y}}}class X extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetPoint)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,emitEventType:this.emitEventType,willSerializeData:n,isSync:!0,textUpdateForWoker:l,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c}=o,p=r.sp||[],h=n==null?void 0:n.selectRect;if(l&&p){for(const[y,d]of a.entries())p.push({...d,workId:y,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c});p.push({type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:h,willSyncService:l,isSync:c,points:i.getChildrenPoints()})}return{sp:p}}}class Y extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetLock)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;o===s.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c,updateSelectorOpt:p}=o,h=r.sp||[],y=n==null?void 0:n.selectRect;if(l&&h){for(const[d,m]of a.entries())h.push({...m,workId:d,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c});h.push({isLocked:p.isLocked,selectorColor:i.selectorColor,scaleType:i.scaleType,canRotate:i.canRotate,type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:y,willSyncService:l,isSync:c})}return{sp:h}}}class Q extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetShapeOpt)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;o===s.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n}=o,l=r.sp||[];if(i&&l)for(const[c,p]of a.entries())l.push({...p,workId:c,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:l}}}class J{constructor(t){u(this,"builders",new Map);this.builders=new Map(t.map(e=>[e,this.build(e)]))}build(t){switch(t){case s.EmitEventType.TranslateNode:return new V;case s.EmitEventType.ZIndexNode:return new H;case s.EmitEventType.CopyNode:return new z;case s.EmitEventType.SetColorNode:return new q;case s.EmitEventType.DeleteNode:return new $;case s.EmitEventType.ScaleNode:return new G;case s.EmitEventType.RotateNode:return new j;case s.EmitEventType.SetFontStyle:return new Z;case s.EmitEventType.SetPoint:return new X;case s.EmitEventType.SetLock:return new Y;case s.EmitEventType.SetShapeOpt:return new Q}}registerForMainThread(t){return this.builders.forEach(e=>{e&&e.registerMainThread(t)}),this}async consumeForMainThread(t){for(const e of this.builders.values())if(await(e==null?void 0:e.consume(t)))return!0;return!1}}class ee{constructor(t,e){u(this,"viewId");u(this,"fullLayer");u(this,"topLayer");u(this,"localLayer");u(this,"serviceLayer");u(this,"snapshotFullLayer");u(this,"vNodes");u(this,"master");u(this,"opt");u(this,"cameraOpt");u(this,"scene");u(this,"localWork");u(this,"serviceWork");u(this,"topWork");u(this,"taskUpdateCameraId");u(this,"debounceUpdateCameraId");u(this,"debounceUpdateCache",new Set);u(this,"mainThreadPostId");u(this,"combinePostMsg",new Set);u(this,"methodBuilder");u(this,"cacheImages",new Map);u(this,"imageResolveMap",new Map);this.viewId=t,this.opt=e,this.scene=this.createScene({...e.canvasOpt,container:e.container}),this.master=e.master;const o=s.DefaultAppliancePluginOptions.bufferSize.full,r=s.DefaultAppliancePluginOptions.bufferSize.sub;this.fullLayer=this.createLayer("fullLayer",this.scene,{...e.layerOpt,bufferSize:this.viewId===s.Main_View_Id?o:r*2}),this.topLayer=this.createLayer("topLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===s.Main_View_Id,r),contextType:"2d"}),this.localLayer=this.createLayer("localLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===s.Main_View_Id,r),contextType:"2d"}),this.serviceLayer=this.createLayer("serviceLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===s.Main_View_Id,r),contextType:"2d"}),this.vNodes=new s.VNodeManager(t,this.scene);const a={thread:this,vNodes:this.vNodes};this.localWork=new U(a),this.serviceWork=new K(a),this.topWork=new B(a),this.vNodes.init(this.fullLayer),this.methodBuilder=new J([s.EmitEventType.CopyNode,s.EmitEventType.SetColorNode,s.EmitEventType.DeleteNode,s.EmitEventType.RotateNode,s.EmitEventType.ScaleNode,s.EmitEventType.TranslateNode,s.EmitEventType.ZIndexNode,s.EmitEventType.SetFontStyle,s.EmitEventType.SetPoint,s.EmitEventType.SetLock,s.EmitEventType.SetShapeOpt]).registerForMainThread(this)}getCachedImages(t){var e;return(e=this.cacheImages.get(t))==null?void 0:e.imageBitmap}getCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())if(e===t&&o.imageBitmap)return o.imageBitmap}deleteCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())o.workId===t&&(o.imageBitmap.close(),this.cacheImages.delete(e))}clearCacheImages(){this.cacheImages.forEach(t=>t.imageBitmap.close()),this.cacheImages.clear()}clearImageResolveMap(){this.imageResolveMap.forEach(({timer:t})=>{t&&clearTimeout(t)}),this.imageResolveMap.clear()}post(t){this.combinePostMsg.add(t),this.runBatchPostData()}updateDpr(t){this.scene.displayRatio=t}async on(t){if(!await this.methodBuilder.consumeForMainThread(t)){const{msgType:e,toolsType:o,opt:r,dataType:a,workId:i,workState:n,imageSrc:l,imageBitmap:c,workIds:p,isLockSentEventCursor:h}=t,y=i==null?void 0:i.toString();switch(e){case s.EPostMessageType.UpdateDpr:N.isNumber(t.dpr)&&this.updateDpr(t.dpr);break;case s.EPostMessageType.AuthClear:{const{clearUids:d,localUid:m}=t;this.vNodes.setCanClearUids(d),this.vNodes.setLocalUid(m);break}case s.EPostMessageType.Destroy:this.destroy();break;case s.EPostMessageType.Clear:this.clearAll();break;case s.EPostMessageType.UpdateCamera:await this.updateCamera(t);break;case s.EPostMessageType.UpdateTools:if(o&&r){const d={toolsType:o,toolsOpt:r};this.topWork.canUseTopLayer(o)?this.topWork.setToolsOpt(d):this.localWork.setToolsOpt(d)}break;case s.EPostMessageType.CreateWork:if(y&&r&&o){if(this.topWork.canUseTopLayer(o)){this.topWork.getToolsOpt()||this.topWork.setToolsOpt({toolsType:o,toolsOpt:r}),this.topWork.setWorkOptions(y,r);break}this.localWork.getToolsOpt()||this.localWork.setToolsOpt({toolsType:o,toolsOpt:r}),this.localWork.setWorkOptions(y,r)}break;case s.EPostMessageType.DrawWork:n===s.EvevtWorkState.Done&&a===s.EDataType.Local?(this.consumeDrawAll(a,t),o===s.EToolsKey.LaserPen&&h&&this.post({sp:[{type:s.EPostMessageType.None,isLockSentEventCursor:h}]})):this.consumeDraw(a,t);break;case s.EPostMessageType.UpdateNode:case s.EPostMessageType.FullWork:if(o&&this.topWork.canUseTopLayer(o)){this.consumeDrawAll(a,t);break}this.consumeFull(a,t);break;case s.EPostMessageType.RemoveNode:await this.removeNode(t);return;case s.EPostMessageType.Select:a===s.EDataType.Service&&(i===s.Storage_Selector_key?this.localWork.updateFullSelectWork(t):this.serviceWork.runSelectWork(t));break;case s.EPostMessageType.CursorBlur:this.localWork.cursorBlur();return;case s.EPostMessageType.CursorHover:this.localWork.cursorHover(t);break;case s.EPostMessageType.GetTextActive:a===s.EDataType.Local&&this.localWork.checkTextActive(t);break;case s.EPostMessageType.GetImageBitMap:if(l&&c&&i){const d=i.toString();this.deleteCachedImagesByWorkId(d),this.cacheImages.set(l,{imageBitmap:c,workId:d});const m=this.imageResolveMap.get(l);if(m){const{resolve:k,timer:S}=m;S&&clearTimeout(S),k&&k(l)}}break;case s.EPostMessageType.GetVNodeInfo:if(i&&p){const d=p.map(m=>this.vNodes.get(m));this.post({sp:[{type:s.EPostMessageType.GetVNodeInfo,dataType:s.EDataType.Local,workId:i,vInfo:d}]})}break}}}getIconSize(t,e,o){const r=t*o,a=e*o;return r<=50||a<=50?[50,50]:r<=100||a<=100?[100,100]:r<=200||a<=200?[200,200]:r<=400||a<=400?[400,400]:r<=800||a<=800?[800,800]:[1600,1600]}async loadImageBitMap(t){const{toolsType:e,opt:o,workId:r}=t;if(e===s.EToolsKey.Image&&o&&r){const a=r.toString(),{src:i,type:n,width:l,height:c,strokeColor:p}=o;if(!i||!n||!l||!c)return;let h=i;if(n===s.EImageType.Iconify){const[k,S]=this.getIconSize(l,c,this.opt.displayer.dpr);h=`${i}?width=${k}&height=${S}&color=${p}`}if(this.cacheImages.has(h)){const k=this.getCachedImages(h);if(k)return k}if(this.imageResolveMap.has(h)){const k=this.getCachedImagesByWorkId(a);if(k)return k}const m=await new Promise(k=>{const S=this.imageResolveMap.get(h)||{resolve:void 0,timer:void 0};S.timer&&clearTimeout(S.timer),S.resolve=k,S.timer=setTimeout(()=>{const T=this.imageResolveMap.get(h);T!=null&&T.resolve&&T.resolve(h)},5e3),this.imageResolveMap.set(h,S),this.opt.post({sp:[{imageSrc:h,workId:a,viewId:this.viewId,isgl:!!this.fullLayer.parent.gl,isSubWorker:!1,type:s.EPostMessageType.GetImageBitMap}]})});return this.imageResolveMap.delete(m),this.getCachedImages(h)}}async removeNode(t){const{dataType:e,workId:o,removeIds:r}=t,a=r||[];if(o&&a.push(o.toString()),a.length)for(const i of a){if(i===s.Storage_Selector_key){await this.localWork.removeSelector(t);continue}e===s.EDataType.Local?this.localWork.removeWork(t):e===s.EDataType.Service&&this.serviceWork.removeWork(t),await this.localWork.colloctEffectSelectWork(t)}}async consumeFull(t,e){const o=await this.localWork.colloctEffectSelectWork(e);o&&t===s.EDataType.Local&&await this.localWork.consumeFull(o),o&&t===s.EDataType.Service&&this.serviceWork.consumeFull(o)}setCameraOpt(t){this.cameraOpt=t;const{scale:e,centerX:o,centerY:r,width:a,height:i}=t;(a!==this.scene.width||i!==this.scene.height)&&this.updateScene({width:a,height:i}),this.fullLayer.setAttribute("scale",[e,e]),this.fullLayer.setAttribute("translate",[-o,-r]),this.topLayer.setAttribute("scale",[e,e]),this.topLayer.setAttribute("translate",[-o,-r]),this.localLayer.setAttribute("scale",[e,e]),this.localLayer.setAttribute("translate",[-o,-r]),this.serviceLayer.setAttribute("scale",[e,e]),this.serviceLayer.setAttribute("translate",[-o,-r])}runBatchPostData(){this.mainThreadPostId||(this.mainThreadPostId=requestAnimationFrame(this.combinePost.bind(this)))}combinePostData(){var r;this.mainThreadPostId=void 0;const t=[];let e,o;for(const a of this.combinePostMsg.values()){if((r=a.sp)!=null&&r.length)for(const i of a.sp){let n=!1;for(const l of t)if(N.isEqual(i,l)){n=!0;break}n||t.push(i)}N.isNumber(a.fullWorkerDrawCount)&&(e=a.fullWorkerDrawCount),N.isNumber(a.consumeCount)&&(o=a.consumeCount)}return this.combinePostMsg.clear(),{sp:t,fullWorkerDrawCount:e,consumeCount:o}}combinePost(){var o,r;const t=this.combinePostData(),e=(o=t.sp)==null?void 0:o.filter(a=>a.type!==s.EPostMessageType.None||a.isLockSentEventCursor);e!=null&&e.length?t.sp=e.map(a=>a.viewId?a:{...a,viewId:this.viewId}):delete t.sp,t.consumeCount===void 0&&delete t.consumeCount,t.fullWorkerDrawCount===void 0&&delete t.fullWorkerDrawCount,(t!=null&&t.consumeCount||t!=null&&t.fullWorkerDrawCount||(r=t.sp)!=null&&r.length)&&this.opt.post(t)}clearAll(){this.fullLayer.children.length&&(this.fullLayer.parent.children.forEach(t=>{t.name!=="viewport"&&t.remove()}),s.removeAllChildren(this.fullLayer,this.fullLayer.parent)),this.clearCacheImages(),this.clearImageResolveMap(),this.localWork.clearAll(),this.topWork.clearAll(),this.serviceWork.clearAll(),this.vNodes.clear(),this.post({sp:[{type:s.EPostMessageType.Clear}]})}consumeDrawAll(t,e){const{toolsType:o,workId:r}=e;if(r){const a=r.toString();if(o&&this.topWork.canUseTopLayer(o)){t===s.EDataType.Local&&(this.topWork.getLocalWorkShape(r.toString())||this.topWork.createLocalWork(e)),this.topWork.consumeDrawAll(e);return}t===s.EDataType.Local&&(this.localWork.getWorkShape(a)||this.localWork.createLocalWork(e),this.localWork.consumeDrawAll(e,this.serviceWork))}}consumeDraw(t,e){const{opt:o,workId:r,toolsType:a}=e;if(r&&a&&o){const i=r.toString();if(this.topWork.canUseTopLayer(a)){t===s.EDataType.Local&&(this.topWork.getLocalWorkShape(i)||this.topWork.createLocalWork(e)),this.topWork.consumeDraw(e);return}t===s.EDataType.Local?(this.localWork.getWorkShape(i)||this.localWork.createLocalWork(e),this.localWork.consumeDraw(e,this.serviceWork)):t===s.EDataType.Service&&this.serviceWork.consumeDraw(e);return}}async updateCamera(t){var r;const{cameraOpt:e,scenePath:o}=t;if(e&&!N.isEqual(this.cameraOpt,e)){if(this.taskUpdateCameraId&&(clearTimeout(this.taskUpdateCameraId),this.taskUpdateCameraId=void 0),o){let c=!1;for(const[p,h]of this.localWork.getWorkShapes().entries())switch(h.toolsType){case s.EToolsKey.Text:case s.EToolsKey.BitMapEraser:case s.EToolsKey.PencilEraser:case s.EToolsKey.Eraser:case s.EToolsKey.Selector:case s.EToolsKey.LaserPen:break;default:p!==s.Cursor_Hover_Id&&p!==s.Storage_Selector_key&&(c=!0);break}if(c){this.taskUpdateCameraId=setTimeout(()=>{this.taskUpdateCameraId=void 0,this.updateCamera(t)},s.Task_Time_Interval);return}}const a=new Map;for(const[c,p]of this.vNodes.getNodesByType(s.EToolsKey.Text).entries()){const h=p.rect;a.set(c,N.cloneDeep(h))}const i=new Set(a.keys());let n=!1;if(this.localWork.hasSelector()){const c=(r=this.localWork.getSelector())==null?void 0:r.selectIds;if(c){n=!0;for(const p of c)i.add(p)}}let l=!1;if(this.serviceWork.selectorWorkShapes.size)for(const c of this.serviceWork.selectorWorkShapes.values()){const p=c.selectIds;if(p){l=!0;for(const h of p)i.add(h)}}if(this.setCameraOpt(e),this.vNodes.curNodeMap.size){this.vNodes.clearTarget(),this.vNodes.updateHighLevelNodesRect(i),this.debounceUpdateCameraId&&clearTimeout(this.debounceUpdateCameraId);for(const[c,p]of a.entries()){const h=this.vNodes.get(c);if(h){const y=p,d=h.rect,m=this.getSceneRect(),k=s.getRectMatrixrRelation(y,m),S=s.getRectMatrixrRelation(d,m);let T=!1;if((k!==S||y.w!==d.w||y.h!==d.h||S===s.EMatrixrRelationType.intersect)&&(T=!0),T){const{toolsType:E,opt:D}=h;E===s.EToolsKey.Text&&D.workState===s.EvevtWorkState.Done&&this.debounceUpdateCache.add(c)}}}if(n&&this.localWork.reRenderSelector(),l)for(const[c,p]of this.serviceWork.selectorWorkShapes.entries())this.serviceWork.runSelectWork({workId:c,selectIds:p.selectIds,msgType:s.EPostMessageType.Select,dataType:s.EDataType.Service,viewId:this.viewId});this.debounceUpdateCameraId=setTimeout(()=>{var p;this.debounceUpdateCameraId=void 0;const c=[];for(const h of this.debounceUpdateCache.values()){if((p=this.fullLayer)==null?void 0:p.getElementsByName(h)[0]){const d=this.vNodes.get(h);if(d){const{toolsType:m,opt:k,rect:S}=d,T=this.localWork.setFullWork({toolsType:m,opt:k,workId:h});if(T){const E=this.getSceneRect(),D=s.getRectMatrixrRelation(S,E);c.push(T.consumeServiceAsync({isFullWork:!0,replaceId:h,isDrawLabel:D!==s.EMatrixrRelationType.outside}))}}}this.debounceUpdateCache.delete(h)}this.vNodes.updateLowLevelNodesRect(),this.vNodes.clearHighLevelIds()},s.Task_Time_Interval)}}}getSceneRect(){const{width:t,height:e}=this.scene;return{x:0,y:0,w:Math.floor(t),h:Math.floor(e)}}createScene(t){return new C.Scene({displayRatio:this.opt.displayer.dpr,depth:!1,desynchronized:!0,...t,autoRender:!0,id:this.viewId,contextType:"2d"})}createLayer(t,e,o){const{width:r,height:a}=o,i=`canvas-${t}`,n=e.layer(i,{...o,offscreen:!1}),l=new C.Group({anchor:[.5,.5],pos:[r*.5,a*.5],size:[r,a],name:"viewport",id:t});return n.append(l),l}updateScene(t){this.scene.attr({...t});const{width:e,height:o}=t;this.scene.width=e,this.scene.height=o,this.updateLayer({width:e,height:o})}updateLayer(t){const{width:e,height:o}=t;this.fullLayer.parent.setAttribute("width",e),this.fullLayer.parent.setAttribute("height",o),this.fullLayer.setAttribute("size",[e,o]),this.fullLayer.setAttribute("pos",[e*.5,o*.5]),this.topLayer.parent.setAttribute("width",e),this.topLayer.parent.setAttribute("height",o),this.topLayer.setAttribute("size",[e,o]),this.topLayer.setAttribute("pos",[e*.5,o*.5]),this.localLayer.parent.setAttribute("width",e),this.localLayer.parent.setAttribute("height",o),this.localLayer.setAttribute("size",[e,o]),this.localLayer.setAttribute("pos",[e*.5,o*.5]),this.serviceLayer.parent.setAttribute("width",e),this.serviceLayer.parent.setAttribute("height",o),this.serviceLayer.setAttribute("size",[e,o]),this.serviceLayer.setAttribute("pos",[e*.5,o*.5])}destroy(){this.clearCacheImages(),this.clearImageResolveMap(),this.vNodes.clear(),this.fullLayer.remove(),s.removeTexture(this.fullLayer,this.fullLayer.parent),this.topLayer.remove(),s.removeTexture(this.topLayer,this.topLayer.parent),this.localLayer.remove(),s.removeTexture(this.localLayer,this.localLayer.parent),this.serviceLayer.remove(),s.removeTexture(this.serviceLayer,this.serviceLayer.parent),this.scene.remove(),this.localWork.destroy(),this.serviceWork.destroy(),this.topWork.destroy()}}class te{constructor(t,e){u(this,"viewId");u(this,"fullLayer");u(this,"master");u(this,"opt");u(this,"scene");u(this,"mainThreadPostId");u(this,"combinePostMsg",new Set);u(this,"workShapes",new Map);u(this,"cacheImages",new Map);u(this,"imageResolveMap",new Map);this.viewId=t,this.opt=e,this.scene=this.createScene({...e.canvasOpt,container:e.container}),this.master=e.master,this.fullLayer=this.createLayer("fullLayer",this.scene,{...e.layerOpt,bufferSize:this.viewId===s.Main_View_Id?6e3:3e3,contextType:"2d"})}getCachedImages(t){var e;return(e=this.cacheImages.get(t))==null?void 0:e.imageBitmap}getCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())if(e===t&&o.imageBitmap)return o.imageBitmap}deleteCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())o.workId===t&&(o.imageBitmap.close(),this.cacheImages.delete(e))}clearCacheImages(){this.cacheImages.forEach(t=>t.imageBitmap.close()),this.cacheImages.clear()}clearImageResolveMap(){this.imageResolveMap.forEach(({timer:t})=>{t&&clearTimeout(t)}),this.imageResolveMap.clear()}post(t){this.combinePostMsg.add(t),this.runBatchPostData()}async on(t){const{msgType:e,imageSrc:o,imageBitmap:r,workId:a}=t;switch(e){case s.EPostMessageType.Snapshot:await this.getSnapshot(t),this.destroy();return;case s.EPostMessageType.BoundingBox:await this.getBoundingRect(t),this.destroy();return;case s.EPostMessageType.GetImageBitMap:if(o&&r&&a){const i=a.toString();this.deleteCachedImagesByWorkId(i),this.cacheImages.set(o,{imageBitmap:r,workId:i});const n=this.imageResolveMap.get(o);if(n){const{resolve:l,timer:c}=n;c&&clearTimeout(c),l&&l(o)}}break}}getIconSize(t,e,o){const r=t*o,a=e*o;return r<=50||a<=50?[50,50]:r<=100||a<=100?[100,100]:r<=200||a<=200?[200,200]:r<=400||a<=400?[400,400]:r<=800||a<=800?[800,800]:[1600,1600]}async loadImageBitMap(t){const{toolsType:e,opt:o,workId:r}=t;if(e===s.EToolsKey.Image&&o&&r){const a=r.toString(),{src:i,type:n,width:l,height:c,strokeColor:p}=o;if(!i||!n||!l||!c)return;let h=i;if(n===s.EImageType.Iconify){const[k,S]=this.getIconSize(l,c,this.opt.displayer.dpr);h=`${i}?width=${k}&height=${S}&color=${p}`}if(this.cacheImages.has(h)){const k=this.getCachedImages(h);if(k)return k}if(this.imageResolveMap.has(h)){const k=this.getCachedImagesByWorkId(a);if(k)return k}const m=await new Promise(k=>{const S=this.imageResolveMap.get(h)||{resolve:void 0,timer:void 0};S.timer&&clearTimeout(S.timer),S.resolve=k,S.timer=setTimeout(()=>{const T=this.imageResolveMap.get(h);T!=null&&T.resolve&&T.resolve(h)},5e3),this.imageResolveMap.set(h,S),this.opt.post({sp:[{imageSrc:h,workId:a,viewId:this.viewId,isgl:!!this.fullLayer.parent.gl,isSubWorker:!0,type:s.EPostMessageType.GetImageBitMap}]})});return this.imageResolveMap.delete(m),this.getCachedImages(h)}}createWorkShapeNode(t){return s.getShapeInstance({...t,fullLayer:this.fullLayer,drawLayer:void 0})}setFullWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o&&r){const a=e.toString();let i;return e&&this.workShapes.has(a)?(i=this.workShapes.get(a),i==null||i.setWorkOptions(o)):i=this.createWorkShapeNode({toolsOpt:o,toolsType:r,workId:a}),i?(this.workShapes.set(a,i),i):void 0}}async runFullWork(t){var r;const e=this.setFullWork(t),o=t.ops&&s.transformToNormalData(t.ops);if(e){let a,i;const n=(r=e.getWorkId())==null?void 0:r.toString();return e.toolsType===s.EToolsKey.Image?a=await e.consumeServiceAsync({isFullWork:!0,worker:this}):e.toolsType===s.EToolsKey.Text?a=await e.consumeServiceAsync({isFullWork:!0,replaceId:n,isDrawLabel:!0}):(a=e.consumeService({op:o,isFullWork:!0,replaceId:n}),i=(t==null?void 0:t.updateNodeOpt)&&e.updataOptService(t.updateNodeOpt)),s.computRect(a,i)}}async getSnapshot(t){const{scenePath:e,scenes:o,cameraOpt:r,w:a,h:i}=t;if(e&&o&&r){this.setCameraOpt(r);let n;for(const[c,p]of Object.entries(o))if(p!=null&&p.type)switch(p==null?void 0:p.type){case s.EPostMessageType.UpdateNode:case s.EPostMessageType.FullWork:{const{opt:h}=p,y={...p,opt:h,workId:c,msgType:s.EPostMessageType.FullWork,dataType:s.EDataType.Service,viewId:this.viewId},d=await this.runFullWork(y);n=s.computRect(n,d);break}}let l;a&&i&&(l={resizeWidth:a,resizeHeight:i}),await this.getSnapshotRender({scenePath:e,options:l})}}getSceneRect(){const{width:t,height:e}=this.scene;return{x:0,y:0,w:Math.floor(t),h:Math.floor(e)}}getRectImageBitmap(t,e){const o=Math.floor(t.x*this.opt.displayer.dpr),r=Math.floor(t.y*this.opt.displayer.dpr),a=t.w>0&&Math.floor(t.w*this.opt.displayer.dpr||1)||1,i=t.h>0&&Math.floor(t.h*this.opt.displayer.dpr||1)||1;return createImageBitmap(this.fullLayer.parent.canvas,o,r,a,i,e)}async getSnapshotRender(t){var a;const{scenePath:e,options:o}=t;((a=this.fullLayer)==null?void 0:a.parent).render();const r=await this.getRectImageBitmap(this.getSceneRect(),o);r&&(this.post({sp:[{type:s.EPostMessageType.Snapshot,scenePath:e,imageBitmap:r,viewId:this.viewId}]}),this.fullLayer&&s.removeAllChildren(this.fullLayer,this.fullLayer.parent))}async getBoundingRect(t){const{scenePath:e,scenes:o,cameraOpt:r}=t;if(e&&o&&r){this.setCameraOpt(r);let a;for(const[i,n]of Object.entries(o))if(n!=null&&n.type)switch(n==null?void 0:n.type){case s.EPostMessageType.UpdateNode:case s.EPostMessageType.FullWork:{const l=await this.runFullWork({...n,workId:i,msgType:s.EPostMessageType.FullWork,dataType:s.EDataType.Service,viewId:this.viewId});a=s.computRect(a,l);break}}a&&this.post({sp:[{type:s.EPostMessageType.BoundingBox,scenePath:e,rect:a}]})}}setCameraOpt(t){const{scale:e,centerX:o,centerY:r,width:a,height:i}=t;this.updateScene({width:a,height:i}),this.fullLayer.setAttribute("scale",[e,e]),this.fullLayer.setAttribute("translate",[-o,-r])}runBatchPostData(){this.mainThreadPostId||(this.mainThreadPostId=requestAnimationFrame(this.combinePost.bind(this)))}combinePostData(){var e;this.mainThreadPostId=void 0;const t=[];for(const o of this.combinePostMsg.values())if((e=o.sp)!=null&&e.length)for(const r of o.sp){let a=!1;for(const i of t)if(s.isEqual(r,i)){a=!0;break}a||t.push(r)}return this.combinePostMsg.clear(),{sp:t}}combinePost(){var o,r;const t=this.combinePostData(),e=(o=t.sp)==null?void 0:o.filter(a=>a.type!==s.EPostMessageType.None||a.isLockSentEventCursor);e!=null&&e.length?t.sp=e.map(a=>a.viewId?a:{...a,viewId:this.viewId}):delete t.sp,(r=t.sp)!=null&&r.length&&this.opt.post(t)}createScene(t){return new C.Scene({displayRatio:this.opt.displayer.dpr,depth:!1,desynchronized:!0,...t,autoRender:!1,contextType:"2d"})}createLayer(t,e,o){const{width:r,height:a}=o,i=`canvas-${t}`,n=e.layer(i,o),l=new C.Group({anchor:[.5,.5],pos:[r*.5,a*.5],size:[r,a],name:"viewport",id:t});return n.append(l),l}updateScene(t){this.scene.attr({...t});const{width:e,height:o}=t;this.scene.width=e,this.scene.height=o,this.updateLayer({width:e,height:o})}updateLayer(t){const{width:e,height:o}=t;this.fullLayer.parent.setAttribute("width",e),this.fullLayer.parent.setAttribute("height",o),this.fullLayer.setAttribute("size",[e,o]),this.fullLayer.setAttribute("pos",[e*.5,o*.5])}destroy(){this.clearCacheImages(),this.clearImageResolveMap(),this.fullLayer.remove(),s.removeTexture(this.fullLayer,this.fullLayer.parent),this.scene.remove()}}class se{constructor(t){u(this,"mainThreadMap",new Map);u(this,"snapshotThread");u(this,"master");this.master=t}post(t){const{fullWorkerDrawCount:e,sp:o,workerTasksqueueCount:r,consumeCount:a}=t;this.master.isBusy&&s.isNumber(r)&&this.master.setWorkerTasksqueueCount(r),s.isNumber(e)&&this.master.setMaxDrawCount(e),s.isNumber(a)&&this.master.setConsumeCount(a),o&&this.master.collectorSyncData(o)}destroy(){this.mainThreadMap.clear()}createMainThread(t,e){return new ee(t,e)}createSnapshotThread(t,e){return new te(t,e)}async consume(t){var e,o,r,a;for(const i of t.values()){const{msgType:n,viewId:l,tasksqueue:c,mainTasksqueueCount:p,layerOpt:h,offscreenCanvasOpt:y,cameraOpt:d,isSubWorker:m}=i;if(n===s.EPostMessageType.Console){console.log(this);continue}if(n===s.EPostMessageType.Init){const S=(e=this.master.control.viewContainerManager.getView(l))==null?void 0:e.displayer,T=S==null?void 0:S.canvasContainerRef.current;if(S&&T&&h&&y){const E=this.createMainThread(l,{displayer:S,container:T,layerOpt:h,master:this.master,canvasOpt:y,post:this.post.bind(this)});this.mainThreadMap.set(l,E),E&&d&&E.setCameraOpt(d)}continue}if((n===s.EPostMessageType.Snapshot||n===s.EPostMessageType.BoundingBox)&&l===((o=this.master.control.viewContainerManager.mainView)==null?void 0:o.id)){const S=(r=this.master.control.viewContainerManager.getView(l))==null?void 0:r.displayer,T=(a=S.snapshotContainerRef)==null?void 0:a.current;if(S&&T&&d){T.style.width=`${d.width}px`,T.style.height=`${d.height}px`;const E={...s.ViewContainerManager.defaultLayerOpt,offscreen:!1,width:d.width,height:d.height},D={...s.ViewContainerManager.defaultScreenCanvasOpt,width:d.width,height:d.height};this.snapshotThread=this.createSnapshotThread(l,{displayer:S,container:T,layerOpt:E,master:this.master,canvasOpt:D,post:this.post.bind(this)}),this.snapshotThread.on(i).then(()=>{this.snapshotThread=void 0,T.innerHTML="",T.style.width="",T.style.height=""});continue}}if(n===s.EPostMessageType.GetImageBitMap&&m&&this.snapshotThread){this.snapshotThread.on(i);continue}if(n===s.EPostMessageType.TasksQueue&&(c!=null&&c.size)){for(const[S,T]of this.mainThreadMap.entries()){const E=c.get(S);E&&(await T.on(E),p&&this.post({workerTasksqueueCount:p}))}continue}if(l===s.Storage_ViewId_ALL){for(const S of this.mainThreadMap.values())S.on(i),n===s.EPostMessageType.Destroy&&this.mainThreadMap.delete(l);continue}const k=this.mainThreadMap.get(l);k&&(k.on(i),n===s.EPostMessageType.Destroy&&this.mainThreadMap.delete(l))}}}exports.MainThreadManagerImpl=se;
1
+ "use strict";var F=Object.defineProperty;var _=(v,t,e)=>t in v?F(v,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):v[t]=e;var u=(v,t,e)=>_(v,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-C9F49Gge.js"),C=require("spritejs"),N=require("lodash");require("clipper-lib");require("lineclip");require("white-web-sdk");require("react-dom");require("react");require("eventemitter2");class B{constructor(t){u(this,"vNodes");u(this,"thread");u(this,"serviceWorkShapes",new Map);u(this,"localWorkShapes",new Map);u(this,"tmpOpt");u(this,"animationId");u(this,"syncUnitTime",s.DefaultAppliancePluginOptions.syncOpt.interval);this.vNodes=t.vNodes,this.thread=t.thread}createLocalWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o){const a=e.toString();!this.getToolsOpt()&&r&&this.setToolsOpt({toolsType:r,toolsOpt:o}),this.setWorkOptions(a,o)}}getLocalWorkShape(t){return this.localWorkShapes.get(t)}createLocalWorkShape(t,e){if(t&&this.tmpOpt){const o={toolsType:this.tmpOpt.toolsType,toolsOpt:e||this.tmpOpt.toolsOpt},r=this.createWorkShapeNode({...o,workId:t});return r&&this.localWorkShapes.set(t,{node:r,toolsType:r.toolsType,workState:s.EvevtWorkState.Start}),r}}canUseTopLayer(t){return t===s.EToolsKey.LaserPen}destroy(){this.clearAll()}clearAll(){this.thread.topLayer.children.length&&(this.thread.topLayer.parent.children.forEach(t=>{t.name!=="viewport"&&t.remove()}),s.removeAllChildren(this.thread.serviceLayer,this.thread.serviceLayer.parent)),this.serviceWorkShapes.clear(),this.localWorkShapes.clear()}consumeDraw(t){const{workId:e,dataType:o}=t;if(o===s.EDataType.Service)this.activeServiceWorkShape(t);else{const r=e==null?void 0:e.toString(),a=r&&this.localWorkShapes.get(r);if(!a)return;const i=a.node.consume({data:t,isFullWork:!1,isSubWorker:!0});i.rect&&(a.result=i,a.workState=s.EvevtWorkState.Doing,r&&this.localWorkShapes.set(r,a))}this.runAnimation()}setToolsOpt(t){var e;this.tmpOpt=t,(e=t.toolsOpt)!=null&&e.syncUnitTime&&(this.syncUnitTime=t.toolsOpt.syncUnitTime)}getToolsOpt(){return this.tmpOpt}createWorkShapeNode(t){const{toolsType:e}=t;if(e===s.EToolsKey.LaserPen)return s.getShapeInstance({...t,vNodes:this.vNodes,fullLayer:this.thread.topLayer,drawLayer:this.thread.topLayer})}setNodeKey(t,e,o,r){return e.toolsType=o,e.node=this.createWorkShapeNode({workId:t,toolsType:o,toolsOpt:r}),e}activeServiceWorkShape(t){var y,d;const{workId:e,opt:o,toolsType:r,type:a,updateNodeOpt:i,ops:n,op:l}=t;if(!e)return;const c=e.toString(),p=(y=this.vNodes.get(c))==null?void 0:y.rect;if(!((d=this.serviceWorkShapes)!=null&&d.has(c))){let m={toolsType:r,animationWorkData:l||[],animationIndex:0,type:a,updateNodeOpt:i,ops:n,oldRect:p};r&&o&&(m=this.setNodeKey(c,m,r,o)),this.serviceWorkShapes.set(c,m)}const h=this.serviceWorkShapes.get(c);a&&(h.type=a),n&&(h.animationWorkData=s.transformToNormalData(n),h.ops=n),i&&(h.updateNodeOpt=i),l&&(h.animationWorkData=l),h.node&&h.node.getWorkId()!==c&&h.node.setWorkId(c),p&&(h.oldRect=p),r&&o&&(h.toolsType!==r&&r&&o&&this.setNodeKey(c,h,r,o),h.node&&h.node.setWorkOptions(o))}computNextAnimationIndex(t,e){var a;const o=((a=t.node)==null?void 0:a.syncUnitTime)||this.syncUnitTime,r=Math.floor((t.animationWorkData||[]).slice(t.animationIndex).length*32/e/o)*e;return Math.min((t.animationIndex||0)+(r||e),(t.animationWorkData||[]).length)}animationDraw(){var r,a,i,n;this.animationId=void 0;let t=!1;const e=new Map,o=[];for(const[l,c]of this.serviceWorkShapes.entries())switch(c.toolsType){case s.EToolsKey.LaserPen:{const h=this.computNextAnimationIndex(c,8),y=Math.max(0,c.animationIndex||0),d=(c.animationWorkData||[]).slice(y,h);if((c.animationIndex||0)<h&&((r=c.node)==null||r.consumeService({op:d,isFullWork:!1}),c.animationIndex=h,d.length&&e.set(l,{workState:y===0?s.EvevtWorkState.Start:h===((a=c.animationWorkData)==null?void 0:a.length)?s.EvevtWorkState.Done:s.EvevtWorkState.Doing,op:d.slice(-2)})),c.isDel){(i=c.node)==null||i.clearTmpPoints(),this.serviceWorkShapes.delete(l);break}c.ops&&c.animationIndex===((n=c.animationWorkData)==null?void 0:n.length)&&!c.isDel&&(this.thread.topLayer.getElementsByName(l.toString())[0]||(c.isDel=!0,this.serviceWorkShapes.set(l,c))),t=!0;break}}for(const[l,c]of this.localWorkShapes.entries()){const{result:p,toolsType:h,isDel:y,workState:d}=c;switch(h){case s.EToolsKey.LaserPen:{if(y){c.node.clearTmpPoints(),this.localWorkShapes.delete(l),o.push({removeIds:[l.toString()],type:s.EPostMessageType.RemoveNode});break}p&&((p.op||p.ops)&&o.push(p),c.result=void 0),!this.thread.topLayer.getElementsByName(l.toString())[0]&&d===s.EvevtWorkState.Done&&(c.isDel=!0,this.localWorkShapes.set(l,c)),t=!0;break}}}t&&this.runAnimation(),e.size&&e.forEach((l,c)=>{o.push({type:s.EPostMessageType.Cursor,uid:c.split(s.Storage_Splitter)[0],op:l.op,workState:l.workState,viewId:this.thread.viewId})}),o.length&&this.thread.post({sp:o})}runAnimation(){this.animationId||(this.animationId=requestAnimationFrame(this.animationDraw.bind(this)))}setWorkOptions(t,e){var r;let o=(r=this.localWorkShapes.get(t))==null?void 0:r.node;if(!o&&this.tmpOpt){const{toolsType:a}=this.tmpOpt;this.tmpOpt.toolsOpt=e,o=this.createWorkShapeNode({workId:t,toolsType:a,toolsOpt:e}),o&&this.localWorkShapes.set(t,{node:o,toolsType:a,workState:s.EvevtWorkState.Start}),this.setToolsOpt(this.tmpOpt)}e!=null&&e.syncUnitTime||(e.syncUnitTime=this.syncUnitTime),o&&o.setWorkOptions(e)}consumeDrawAll(t){const{workId:e,dataType:o}=t;if(o===s.EDataType.Service)this.activeServiceWorkShape(t);else{const r=e==null?void 0:e.toString(),a=r&&this.localWorkShapes.get(r);if(!a)return;const i=a.node.consumeAll({data:t});a.result=i,a.workState=s.EvevtWorkState.Done,r&&this.localWorkShapes.set(r,a)}this.runAnimation()}}class U{constructor(t){u(this,"vNodes");u(this,"thread");u(this,"workShapes",new Map);u(this,"effectSelectNodeData",new Set);u(this,"batchEraserRemoveNodes",new Set);u(this,"batchEraserWorks",new Set);u(this,"tmpOpt");u(this,"syncUnitTime",s.DefaultAppliancePluginOptions.syncOpt.interval);u(this,"fullWorkerDrawCount",0);u(this,"drawWorkActiveId");u(this,"consumeCount",0);this.vNodes=t.vNodes,this.thread=t.thread}async loadImageBitMap(t){return await this.thread.loadImageBitMap(t)}createLocalWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o){const a=e.toString();!this.getToolsOpt()&&r&&this.setToolsOpt({toolsType:r,toolsOpt:o}),this.setWorkOptions(a,o)}}async updateSelector(t){var y;const e=this.workShapes.get(s.Storage_Selector_key);if(!((y=e==null?void 0:e.selectIds)!=null&&y.length))return;const{callback:o,...r}=t,{updateSelectorOpt:a,willSerializeData:i}=r,n=await(e==null?void 0:e.updateSelector({updateSelectorOpt:a,selectIds:N.cloneDeep(e.selectIds),vNodes:this.vNodes,willSerializeData:i,worker:this})),l=new Map;let c;n!=null&&n.selectIds&&(c=N.xor(e.selectIds,n.selectIds),n.selectIds.forEach(d=>{const m=this.vNodes.get(d);if(m){const{toolsType:k,op:S,opt:T}=m;l.set(d,{opt:T,toolsType:k,ops:(S==null?void 0:S.length)&&s.transformToSerializableData(S)||void 0})}}),e.selectIds=n.selectIds);const p=[],h=o&&o({res:n,workShapeNode:e,param:r,postData:{sp:p},newServiceStore:l})||{sp:p};c&&h.sp.push({type:s.EPostMessageType.RemoveNode,removeIds:c,viewId:this.thread.viewId}),h.sp.length&&this.thread.post(h)}destroy(){this.clearAll()}clearAll(){if(this.thread.localLayer.children.length&&(this.thread.topLayer.parent.children.forEach(e=>{e.name!=="viewport"&&e.remove()}),s.removeAllChildren(this.thread.localLayer,this.thread.localLayer.parent)),this.workShapes.get(s.Storage_Selector_key)){const e=[];e.push({type:s.EPostMessageType.Select,dataType:s.EDataType.Local,selectIds:[],willSyncService:!1}),this.thread.post({sp:e})}this.workShapes.clear(),this.effectSelectNodeData.clear(),this.batchEraserWorks.clear(),this.batchEraserRemoveNodes.clear()}async checkTextActive(t){const{op:e,viewId:o,dataType:r}=t;if(e!=null&&e.length){let a;for(const i of this.vNodes.curNodeMap.values()){const{rect:n,name:l,toolsType:c,opt:p}=i,h=e[0]*this.thread.fullLayer.worldScaling[0]+this.thread.fullLayer.worldPosition[0],y=e[1]*this.thread.fullLayer.worldScaling[1]+this.thread.fullLayer.worldPosition[1];if(c===s.EToolsKey.Text&&s.isIntersectForPoint([h,y],n)&&p.workState===s.EvevtWorkState.Done){a=l;break}}a&&(await this.blurSelector({viewId:o,msgType:s.EPostMessageType.Select,dataType:r,isSync:!0}),this.thread.post({sp:[{type:s.EPostMessageType.GetTextActive,toolsType:s.EToolsKey.Text,workId:a}]}))}}cursorHover(t){const{opt:e,toolsType:o,point:r}=t,a=this.setFullWork({workId:s.Cursor_Hover_Id,toolsType:o,opt:e});a&&r&&a.cursorHover(r)}cursorBlur(){var e;const t=this.getWorkShape(s.Cursor_Hover_Id);t&&((e=t.selectIds)!=null&&e.length)&&(t.cursorBlur(),this.clearWorkShapeNodeCache(s.Cursor_Hover_Id)),this.thread.fullLayer.parent.children.forEach(o=>{o.name==="Cursor_Hover_Id"&&o.remove()})}updateFullSelectWork(t){var r,a,i,n,l;const e=this.workShapes.get(s.Storage_Selector_key),{selectIds:o}=t;if(!(o!=null&&o.length)){this.blurSelector(t);return}if(!e){const c=this.setFullWork(t);!c&&t.workId&&this.tmpOpt&&((r=this.tmpOpt)==null?void 0:r.toolsType)===s.EToolsKey.Selector&&this.setWorkOptions(t.workId.toString(),t.opt||this.tmpOpt.toolsOpt),c&&this.updateFullSelectWork(t);return}if(e&&(o!=null&&o.length)){const{selectRect:c}=e.updateSelectIds(o),p=[{...t,selectorColor:((a=t.opt)==null?void 0:a.strokeColor)||e.selectorColor,strokeColor:((i=t.opt)==null?void 0:i.strokeColor)||e.strokeColor,fillColor:((n=t.opt)==null?void 0:n.fillColor)||e.fillColor,textOpt:((l=t.opt)==null?void 0:l.textOpt)||e.textOpt,canTextEdit:e.canTextEdit,canRotate:e.canRotate,scaleType:e.scaleType,type:s.EPostMessageType.Select,selectRect:c,points:e.getChildrenPoints(),willSyncService:(t==null?void 0:t.willSyncService)||!1,opt:(t==null?void 0:t.willSyncService)&&e.getWorkOptions()||void 0,canLock:e.canLock,isLocked:e.isLocked,toolsTypes:e.toolsTypes,shapeOpt:e.shapeOpt,thickness:e.thickness,useStroke:e.useStroke,strokeType:e.strokeType}];this.thread.post({sp:p})}}commandDeleteText(t){const e=this.vNodes.get(t);if(e&&e.toolsType===s.EToolsKey.Text)return{type:s.EPostMessageType.TextUpdate,toolsType:s.EToolsKey.Text,workId:t,dataType:s.EDataType.Local}}async removeSelector(t){const{willSyncService:e}=t,o=[],r=[],a=this.workShapes.get(s.Storage_Selector_key);if(!a)return;const i=a.selectIds&&[...a.selectIds]||[];for(const n of i){if(this.vNodes.get(n)){const c=this.commandDeleteText(n);c&&o.push(c)}this.removeNode(n),r.push(n)}r.length&&o.push({type:s.EPostMessageType.RemoveNode,removeIds:r}),o.push({type:s.EPostMessageType.Select,selectIds:[],willSyncService:e}),await this.blurSelector(),o.length&&this.thread.post({sp:o})}removeWork(t){const{workId:e}=t,o=e==null?void 0:e.toString();o&&this.removeNode(o)}removeNode(t){var r;this.vNodes.get(t)&&((r=this.thread.fullLayer)==null||r.getElementsByName(t).forEach(a=>{a.remove(),s.removeTexture(a,this.thread.fullLayer.parent)}),this.vNodes.delete(t)),this.workShapes.has(t)&&(this.thread.localLayer.getElementsByName(t).forEach(a=>{a.remove(),s.removeTexture(a,this.thread.localLayer.parent)}),this.clearWorkShapeNodeCache(t))}setFullWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o&&r){const a=e.toString();let i;return e&&this.workShapes.has(a)?(i=this.workShapes.get(a),i==null||i.setWorkOptions(o)):i=this.createWorkShapeNode({toolsOpt:o,toolsType:r,workId:a}),i?(this.workShapes.set(a,i),i):void 0}}async consumeFull(t){var r;const e=this.setFullWork(t),o=t.ops&&s.transformToNormalData(t.ops);if(e){const a=(r=t.workId)==null?void 0:r.toString();e.toolsType===s.EToolsKey.Image?await e.consumeServiceAsync({isFullWork:!0,replaceId:a,worker:this}):e.toolsType===s.EToolsKey.Text?await e.consumeServiceAsync({isFullWork:!0,replaceId:a}):e.consumeService({op:o,isFullWork:!0,replaceId:a}),t!=null&&t.updateNodeOpt&&e.updataOptService(t.updateNodeOpt);const i=[];t.workId&&this.workShapes.delete(t.workId.toString()),t.willSyncService&&i.push({opt:t.opt,toolsType:t.toolsType,type:s.EPostMessageType.FullWork,workId:t.workId,ops:t.ops,updateNodeOpt:t.updateNodeOpt,viewId:this.thread.viewId}),i.length&&this.thread.post({sp:i})}}async colloctEffectSelectWork(t){const e=this.workShapes.get(s.Storage_Selector_key),{workId:o,msgType:r}=t;if(e&&o&&e.selectIds&&e.selectIds.includes(o.toString())){r===s.EPostMessageType.RemoveNode?e.selectIds=e.selectIds.filter(a=>a!==o.toString()):this.effectSelectNodeData.add(t),await new Promise(a=>{setTimeout(()=>{a(!0)},0)}),await this.runEffectSelectWork(!0).then(()=>{var a;(a=this.effectSelectNodeData)==null||a.clear()});return}return t}async runEffectSelectWork(t){var e;for(const o of this.effectSelectNodeData.values()){const r=this.setFullWork(o);if(r){const a=(e=o.workId)==null?void 0:e.toString();if(r.toolsType===s.EToolsKey.Image)await r.consumeServiceAsync({isFullWork:!0,replaceId:a,worker:this});else if(r.toolsType===s.EToolsKey.Text)await r.consumeServiceAsync({isFullWork:!0,replaceId:a});else{const i=o.ops&&s.transformToNormalData(o.ops);r.consumeService({op:i,isFullWork:!0,replaceId:a}),o!=null&&o.updateNodeOpt&&r.updataOptService(o.updateNodeOpt)}o.workId&&this.workShapes.delete(o.workId.toString())}}this.reRenderSelector(t)}hasSelector(){return this.workShapes.has(s.Storage_Selector_key)}getSelector(){return this.workShapes.get(s.Storage_Selector_key)}reRenderSelector(t=!1){var r;const e=this.workShapes.get(s.Storage_Selector_key);if(!e)return;if(e&&!((r=e.selectIds)!=null&&r.length))return this.blurSelector();const o=e.reRenderSelector();o&&this.thread.post({sp:[{type:s.EPostMessageType.Select,selectIds:e.selectIds,selectRect:o,willSyncService:t,viewId:this.thread.viewId,points:e.getChildrenPoints(),textOpt:e.textOpt,selectorColor:e.selectorColor,strokeColor:e.strokeColor,fillColor:e.fillColor,canTextEdit:e.canTextEdit,canRotate:e.canRotate,scaleType:e.scaleType,opt:e.getWorkOptions()||void 0,canLock:e.canLock,isLocked:e.isLocked,toolsTypes:e.toolsTypes,shapeOpt:e.shapeOpt,thickness:e.thickness,useStroke:e.useStroke,strokeType:e.strokeType}]})}async blurSelector(t){var r;const e=this.workShapes.get(s.Storage_Selector_key),o=e==null?void 0:e.blurSelector();if(this.clearWorkShapeNodeCache(s.Storage_Selector_key),((r=this.thread.fullLayer)==null?void 0:r.parent).children.forEach(a=>{a.name===s.Storage_Selector_key&&a.remove()}),o){const a=[];a.push({...o,isSync:t==null?void 0:t.isSync}),this.thread.post({sp:a})}}clearWorkShapeNodeCache(t){var e;(e=this.getWorkShape(t))==null||e.clearTmpPoints(),this.workShapes.delete(t)}async drawBitMapEraserFull(t,e,o){const{willUpdateNodes:r,willDeleteNodes:a}=e,i=t.getWorkId(),n=[{type:s.EPostMessageType.RemoveNode,removeIds:[i],viewId:this.thread.viewId}];if(o&&n.push({type:s.EPostMessageType.None,isLockSentEventCursor:o}),r!=null&&r.size||a!=null&&a.size){if(r!=null&&r.size)for(const[l,c]of r)n.push({type:s.EPostMessageType.UpdateNode,dataType:s.EDataType.Local,opt:c.opt,workId:l,updateNodeOpt:{useAnimation:!1}});a!=null&&a.size&&n.push({type:s.EPostMessageType.RemoveNode,removeIds:[...a],viewId:this.thread.viewId})}n.length&&this.thread.post({sp:n})}drawPencilEraserFull(t,e,o){const{willNewNodes:r,willDeleteNodes:a}=e,i=t.getWorkId(),n=[{type:s.EPostMessageType.RemoveNode,removeIds:[i],viewId:this.thread.viewId}];if(o&&n.push({type:s.EPostMessageType.None,isLockSentEventCursor:o}),r!=null&&r.size||a!=null&&a.size){if(r!=null&&r.size)for(const[l,c]of r)n.push({type:s.EPostMessageType.FullWork,dataType:s.EDataType.Local,ops:s.transformToSerializableData(c.op),opt:c.opt,workId:l,updateNodeOpt:{useAnimation:!1}});a!=null&&a.size&&n.push({type:s.EPostMessageType.RemoveNode,removeIds:[...a],viewId:this.thread.viewId})}n.length&&this.thread.post({sp:n})}drawEraser(t,e){const o=[];t.removeIds&&o.push(t),e&&o.push({type:s.EPostMessageType.None,isLockSentEventCursor:e}),this.thread.post({sp:o,consumeCount:this.consumeCount})}getWorkShape(t){return this.workShapes.get(t)}getWorkShapes(){return this.workShapes}consumeDraw(t,e){const{op:o,workId:r,scenePath:a,postCount:i}=t;if(o!=null&&o.length&&r){const n=r.toString(),l=this.workShapes.get(n);if(!l)return;const c=l.toolsType;if(c===s.EToolsKey.LaserPen)return;switch(this.drawWorkActiveId&&this.drawWorkActiveId!==n&&(this.consumeDrawAll({workId:this.drawWorkActiveId,scenePath:a,viewId:this.thread.viewId,msgType:s.EPostMessageType.DrawWork,dataType:s.EDataType.Local},e),this.drawWorkActiveId=void 0),!this.drawWorkActiveId&&n!==s.Storage_Selector_key&&(this.drawWorkActiveId=n),N.isNumber(i)&&(this.consumeCount=i),c){case s.EToolsKey.Selector:{const p=l.consume({data:t,isFullWork:!0,isMainThread:!0});this.fullWorkerDrawCount++;const h=[];p.type===s.EPostMessageType.Select&&(p.selectIds&&e.runReverseSelectWork(p.selectIds),h.push(p)),this.thread.post({consumeCount:this.consumeCount,fullWorkerDrawCount:this.fullWorkerDrawCount,sp:h})}break;case s.EToolsKey.PencilEraser:case s.EToolsKey.BitMapEraser:{const p=l.consume({data:t,isFullWork:!1,isMainThread:!0});this.fullWorkerDrawCount++,this.thread.post({consumeCount:this.consumeCount,fullWorkerDrawCount:this.fullWorkerDrawCount,sp:p.op&&[{...p,scenePath:a}]||void 0});break}case s.EToolsKey.Eraser:{const p=l.consume({data:t,isFullWork:!0});this.drawEraser(p)}break;case s.EToolsKey.Arrow:case s.EToolsKey.Straight:case s.EToolsKey.Ellipse:case s.EToolsKey.Rectangle:case s.EToolsKey.Star:case s.EToolsKey.Polygon:case s.EToolsKey.SpeechBalloon:case s.EToolsKey.Pencil:{const p=l.consume({data:t,isFullWork:!1,isMainThread:!0});p&&(this.fullWorkerDrawCount++,this.thread.post({consumeCount:this.consumeCount,fullWorkerDrawCount:this.fullWorkerDrawCount,sp:p.op&&[{...p,scenePath:a}]||void 0}))}break}}}consumeDrawAll(t,e){var i,n,l;const{workId:o,scenePath:r,isLockSentEventCursor:a}=t;if(o){const c=o.toString();this.drawWorkActiveId===c&&(this.drawWorkActiveId=void 0);const p=this.workShapes.get(c);if(!p)return;const h=p.toolsType;if(h===s.EToolsKey.LaserPen)return;const y=this.workShapes.get(s.Cursor_Hover_Id),d=(i=y==null?void 0:y.selectIds)==null?void 0:i[0],m=p.consumeAll({data:t,workerEngine:this});switch(h){case s.EToolsKey.Selector:{m.selectIds&&d&&((n=m.selectIds)!=null&&n.includes(d))&&y.cursorBlur();const k=[];a&&k.push({type:s.EPostMessageType.None,isLockSentEventCursor:a}),m.type===s.EPostMessageType.Select&&(m.selectIds&&e.runReverseSelectWork(m.selectIds),k.push({...m,scenePath:r})),k.length&&this.thread.post({sp:k}),(l=p.selectIds)!=null&&l.length?p.clearTmpPoints():this.clearWorkShapeNodeCache(c)}break;case s.EToolsKey.PencilEraser:this.drawPencilEraserFull(p,m,a),this.fullWorkerDrawCount=0,this.clearWorkShapeNodeCache(c);break;case s.EToolsKey.BitMapEraser:this.drawBitMapEraserFull(p,m,a),this.fullWorkerDrawCount=0,this.clearWorkShapeNodeCache(c);break;case s.EToolsKey.Eraser:this.drawEraser({...m,scenePath:r},a),p.clearTmpPoints();break;case s.EToolsKey.Arrow:case s.EToolsKey.Straight:case s.EToolsKey.Ellipse:case s.EToolsKey.Rectangle:case s.EToolsKey.Star:case s.EToolsKey.Polygon:case s.EToolsKey.SpeechBalloon:case s.EToolsKey.Pencil:{const k=[];a&&k.push({type:s.EPostMessageType.None,isLockSentEventCursor:a}),m&&(k.push(m),this.fullWorkerDrawCount=0,this.thread.post({fullWorkerDrawCount:this.fullWorkerDrawCount,sp:k})),this.clearWorkShapeNodeCache(c);break}}}}getToolsOpt(){return this.tmpOpt}setToolsOpt(t){var e;this.tmpOpt=t,(e=t.toolsOpt)!=null&&e.syncUnitTime&&(this.syncUnitTime=t.toolsOpt.syncUnitTime)}setWorkOptions(t,e){let o=this.workShapes.get(t);if(!o&&this.tmpOpt){const{toolsType:r}=this.tmpOpt;this.tmpOpt.toolsOpt=e,o=this.createWorkShapeNode({workId:t,toolsType:r,toolsOpt:e}),o&&this.workShapes.set(t,o),this.setToolsOpt(this.tmpOpt)}e.syncUnitTime||(e.syncUnitTime=this.syncUnitTime),o==null||o.setWorkOptions(e)}createWorkShapeNode(t){return s.getShapeInstance({...t,vNodes:this.vNodes,fullLayer:this.thread.fullLayer,drawLayer:this.thread.localLayer},this.thread.serviceWork)}}class K{constructor(t){u(this,"vNodes");u(this,"thread");u(this,"workShapes",new Map);u(this,"selectorWorkShapes",new Map);u(this,"willRunEffectSelectorIds",new Set);u(this,"runEffectId");u(this,"animationId");u(this,"syncUnitTime",s.DefaultAppliancePluginOptions.syncOpt.interval);this.vNodes=t.vNodes,this.thread=t.thread}async loadImageBitMap(t){return await this.thread.loadImageBitMap(t)}destroy(){this.clearAll()}clearAll(){this.thread.serviceLayer.children.length&&(this.thread.serviceLayer.parent.children.forEach(t=>{t.name!=="viewport"&&t.remove()}),s.removeAllChildren(this.thread.serviceLayer,this.thread.serviceLayer.parent)),this.workShapes.clear(),this.selectorWorkShapes.clear(),this.willRunEffectSelectorIds.clear()}runEffect(){this.runEffectId||(this.runEffectId=setTimeout(this.effectRunSelector.bind(this),0))}effectRunSelector(){this.runEffectId=void 0,this.willRunEffectSelectorIds.forEach(t=>{var o,r;const e=this.selectorWorkShapes.get(t);e&&e.selectIds&&((o=e.node)==null||o.selectServiceNode(t,e,!0)),(r=e==null?void 0:e.selectIds)!=null&&r.length||this.selectorWorkShapes.delete(t)}),this.willRunEffectSelectorIds.clear()}runSelectWork(t){this.activeSelectorShape(t);const{workId:e}=t,o=e==null?void 0:e.toString();o&&this.willRunEffectSelectorIds.add(o),this.runEffect()}removeWork(t){const{workId:e}=t,o=e==null?void 0:e.toString();if(o){if(this.workShapes.get(o)){this.workShapes.delete(o),this.removeNode(o,t);return}this.removeNode(o,t)}}consumeFull(t){this.activeWorkShape(t),this.runAnimation()}runReverseSelectWork(t){t.forEach(e=>{this.selectorWorkShapes.forEach((o,r)=>{var a;if((a=o.selectIds)!=null&&a.length){const i=o.selectIds.indexOf(e);i>-1&&(o.selectIds.splice(i,1),this.willRunEffectSelectorIds.add(r))}})}),this.willRunEffectSelectorIds.size&&this.runEffect()}consumeDraw(t){this.activeWorkShape(t),this.runAnimation()}computNextAnimationIndex(t,e){const o=Math.floor((t.animationWorkData||[]).slice(t.animationIndex).length*32/e/this.syncUnitTime)*e;return Math.min((t.animationIndex||0)+(o||e),(t.animationWorkData||[]).length)}async animationDraw(){var o,r,a,i,n,l,c,p,h,y,d,m,k,S,T,E,D,R,x;this.animationId=void 0;let t=!1;const e=new Map;for(const[g,f]of this.workShapes.entries())switch(f.toolsType){case s.EToolsKey.Image:{await((o=f.node)==null?void 0:o.consumeServiceAsync({isFullWork:!0,worker:this})),this.selectorWorkShapes.forEach((w,I)=>{var W;(W=w.selectIds)!=null&&W.includes(g)&&(this.willRunEffectSelectorIds.add(I),this.runEffect())}),this.workShapes.delete(g);break}case s.EToolsKey.Text:{f.node&&(await((r=f.node)==null?void 0:r.consumeServiceAsync({isFullWork:!0,replaceId:g})),this.selectorWorkShapes.forEach((w,I)=>{var W;(W=w.selectIds)!=null&&W.includes(g)&&(this.willRunEffectSelectorIds.add(I),this.runEffect())}),(a=f.node)==null||a.clearTmpPoints(),this.workShapes.delete(g));break}case s.EToolsKey.Arrow:case s.EToolsKey.Straight:case s.EToolsKey.Rectangle:case s.EToolsKey.Ellipse:case s.EToolsKey.Star:case s.EToolsKey.Polygon:case s.EToolsKey.SpeechBalloon:{const w=!!f.ops;if((i=f.animationWorkData)!=null&&i.length){const I=f.oldRect;(n=f.node)==null||n.consumeService({op:f.animationWorkData,isFullWork:w}),w&&(this.selectorWorkShapes.forEach((W,M)=>{var P;(P=W.selectIds)!=null&&P.includes(g)&&(this.willRunEffectSelectorIds.add(M),this.runEffect())}),(l=f.node)==null||l.clearTmpPoints(),this.workShapes.delete(g)),e.set(g,{workState:I?f.ops?s.EvevtWorkState.Done:s.EvevtWorkState.Doing:s.EvevtWorkState.Start,op:f.animationWorkData.filter((W,M)=>{if(M%3!==2)return!0}).slice(-2)}),f.animationWorkData.length=0}break}case s.EToolsKey.Pencil:{if(!f.useAnimation&&f.ops)(c=f.node)==null||c.consumeService({op:f.animationWorkData||[],isFullWork:!0,replaceId:g}),(p=f.node)==null||p.updataOptService(f.updateNodeOpt),this.selectorWorkShapes.forEach((w,I)=>{var W;(W=w.selectIds)!=null&&W.includes(g)&&(this.willRunEffectSelectorIds.add(I),this.runEffect())}),(h=f.node)==null||h.clearTmpPoints(),this.workShapes.delete(g);else if(f.useAnimation){if(f.isDel){(y=f.node)==null||y.clearTmpPoints(),this.workShapes.delete(g);break}const w=3,I=this.computNextAnimationIndex(f,w),W=f.isDiff?0:Math.max(0,(f.animationIndex||0)-w),M=(f.animationWorkData||[]).slice(W,I),P=(m=(d=f.node)==null?void 0:d.getWorkId())==null?void 0:m.toString();if((f.animationIndex||0)<I||f.isDiff){if((k=f.node)==null||k.consumeService({op:M,isFullWork:!1}),f.animationIndex=I,f.isDiff&&(f.isDiff=!1),M.length){const O=M.filter((b,A)=>{if(A%w!==w-1)return!0}).slice(-2);e.set(g,{workState:W===0?s.EvevtWorkState.Start:I===((S=f.animationWorkData)==null?void 0:S.length)?s.EvevtWorkState.Done:s.EvevtWorkState.Doing,op:O})}}else f.ops&&((T=f.node)==null||T.consumeService({op:f.animationWorkData||[],isFullWork:!0,replaceId:P}),f.isDel=!0,e.set(g,{workState:s.EvevtWorkState.Done,op:M.filter((O,b)=>{if(b%w!==w-1)return!0}).slice(-2)}));t=!0;break}break}case s.EToolsKey.BitMapEraser:case s.EToolsKey.PencilEraser:{if(f.isDel){(E=f.node)==null||E.clearTmpPoints(),this.workShapes.delete(g);break}if(f.ops&&((D=f.animationWorkData)!=null&&D.length)){const w=f.animationWorkData.slice(-3,-1);e.set(g,{workState:s.EvevtWorkState.Done,op:w}),f.isDel=!0;break}if(f.useAnimation){const I=this.computNextAnimationIndex(f,3),W=f.isDiff?0:Math.max(0,(f.animationIndex||0)-3),M=(f.animationWorkData||[]).slice(W,I);if(((f.animationIndex||0)<I||f.isDiff)&&((R=f.node)==null||R.consumeService({op:M,isFullWork:!1}),f.animationIndex=I,f.isDiff&&(f.isDiff=!1),M.length)){const P=M.filter((O,b)=>{if(b%3!==2)return!0}).slice(-2);e.set(g,{workState:W===0?s.EvevtWorkState.Start:I===((x=f.animationWorkData)==null?void 0:x.length)?s.EvevtWorkState.Done:s.EvevtWorkState.Doing,op:P})}t=!0;break}break}}if(t&&this.runAnimation(),e.size){const g=[];e.forEach((f,w)=>{g.push({type:s.EPostMessageType.Cursor,uid:w.split(s.Storage_Splitter)[0],op:f.op,workState:f.workState,viewId:this.thread.viewId})}),this.thread.post({sp:g})}}runAnimation(){this.animationId||(this.animationId=requestAnimationFrame(this.animationDraw.bind(this)))}hasDiffData(t,e,o){const r=t.length;if(e.length<r)return!0;switch(o){case s.EToolsKey.Pencil:{for(let a=0;a<r;a+=3)if(e[a]!==t[a]||e[a+1]!==t[a+1])return!0;break}case s.EToolsKey.LaserPen:{for(let a=0;a<r;a+=2)if(e[a]!==t[a]||e[a+1]!==t[a+1])return!0;break}}return!1}activeWorkShape(t){var m,k,S,T;const{workId:e,opt:o,toolsType:r,type:a,updateNodeOpt:i,ops:n,op:l,useAnimation:c,imageBitmap:p}=t;if(!e)return;const h=e.toString(),y=(m=this.vNodes.get(h))==null?void 0:m.rect;if(!((k=this.workShapes)!=null&&k.has(h))){let E={toolsType:r,animationWorkData:l||[],animationIndex:0,type:a,updateNodeOpt:i,ops:n,useAnimation:typeof c<"u"?c:typeof(i==null?void 0:i.useAnimation)<"u"?i==null?void 0:i.useAnimation:!0,oldRect:y,isDiff:!1,imageBitmap:p};r&&o&&(E=this.setNodeKey(h,E,r,o)),(S=this.workShapes)==null||S.set(h,E)}const d=(T=this.workShapes)==null?void 0:T.get(h);a&&(d.type=a),n&&(d.animationWorkData=s.transformToNormalData(n),d.ops=n),i&&(d.updateNodeOpt=i),l&&(d.isDiff=this.hasDiffData(d.animationWorkData||[],l,d.toolsType),d.animationWorkData=l),d.node&&d.node.getWorkId()!==h&&d.node.setWorkId(h),y&&(d.oldRect=y),r&&o&&(o.syncUnitTime&&(this.syncUnitTime=o.syncUnitTime),d.toolsType!==r&&r&&o&&this.setNodeKey(h,d,r,o),d.node&&d.node.setWorkOptions(o)),p&&(d.imageBitmap=p)}removeNode(t,e){t.indexOf(s.Storage_Selector_key)>-1&&this.removeSelectWork(e),this.thread.fullLayer.getElementsByName(t).forEach(o=>{o.remove(),s.removeTexture(o,this.thread.fullLayer.parent)}),this.thread.serviceLayer.getElementsByName(t).forEach(o=>{o.remove(),s.removeTexture(o,this.thread.serviceLayer.parent)}),this.vNodes.delete(t)}removeSelectWork(t){const{workId:e}=t,o=e==null?void 0:e.toString();o&&(this.activeSelectorShape(t),this.willRunEffectSelectorIds.add(o)),this.runEffect()}activeSelectorShape(t){var c,p,h;const{workId:e,opt:o,toolsType:r,type:a,selectIds:i}=t;if(!e)return;const n=e.toString();if(!((c=this.selectorWorkShapes)!=null&&c.has(n))){let y={toolsType:r,selectIds:i,type:a,opt:o};r&&o&&(y=this.setNodeKey(n,y,r,o)),(p=this.selectorWorkShapes)==null||p.set(n,y)}const l=(h=this.selectorWorkShapes)==null?void 0:h.get(n);a&&(l.type=a),l.node&&l.node.getWorkId()!==n&&l.node.setWorkId(n),l.selectIds=i||[]}setNodeKey(t,e,o,r){return e.toolsType=o,e.node=s.getShapeInstance({toolsType:o,toolsOpt:r,vNodes:this.vNodes,fullLayer:this.thread.fullLayer,drawLayer:this.thread.serviceLayer,workId:t},this),e}}class L{constructor(){u(this,"localWork");u(this,"serviceWork");u(this,"threadEngine")}registerMainThread(t){return this.threadEngine=t,this.localWork=t.localWork,this.serviceWork=t.serviceWork,this}}class z extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.CopyNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.FullWork&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var r;const{workId:o}=e;o&&await((r=this.localWork)==null?void 0:r.consumeFull(e))}}class q extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetColorNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n,textUpdateForWoker:l}=o,c=r.sp||[];if(i)for(const[p,h]of a.entries())l&&h.toolsType===s.EToolsKey.Text?c.push({...h,workId:p,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):c.push({...h,workId:p,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:c}}}class H extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.ZIndexNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;o===s.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n}=o,l=r.sp||[];if(i&&l)for(const[c,p]of a.entries())l.push({...p,workId:c,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:l}}}class V extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.TranslateNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var p,h;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l,emitEventType:c}=e;o===s.Storage_Selector_key&&r&&(r.workState===s.EvevtWorkState.Done&&(r!=null&&r.translate)&&(r.translate[0]||r.translate[1])||r.workState!==s.EvevtWorkState.Done?await((p=this.localWork)==null?void 0:p.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,isSync:!0,textUpdateForWoker:l,emitEventType:c,callback:this.updateSelectorCallback})):r.workState===s.EvevtWorkState.Done&&((h=this.localWork)==null||h.vNodes.deleteLastTarget()))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c,updateSelectorOpt:p,textUpdateForWoker:h}=o,y=p.workState,d=r.sp||[];if(y===s.EvevtWorkState.Start)return{sp:[],render:[]};const m=n==null?void 0:n.selectRect;if(l){y===s.EvevtWorkState.Doing&&d.push({type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:m,willSyncService:!0,isSync:!0,points:i.getChildrenPoints(),textOpt:i.textOpt});for(const[k,S]of a.entries())h&&S.toolsType===s.EToolsKey.Text?d.push({...S,workId:k,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):d.push({...S,workId:k,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c})}return{sp:d}}}class $ extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.DeleteNode)}async consume(){return!1}}class G extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.ScaleNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var n;const{workId:o,updateNodeOpt:r,willSyncService:a,willSerializeData:i}=e;o===s.Storage_Selector_key&&r&&await((n=this.localWork)==null?void 0:n.updateSelector({updateSelectorOpt:r,willSyncService:a,willSerializeData:i,isSync:!0,callback:this.updateSelectorCallback.bind(this)}))}updateSelectorCallback(e){const{param:o,postData:r,workShapeNode:a,res:i,newServiceStore:n}=e,{updateSelectorOpt:l,willSyncService:c}=o,p=l.workState,h=r.sp||[],y=i==null?void 0:i.selectRect;if(p===s.EvevtWorkState.Start)return{sp:[],render:[]};if(c){h.push({type:s.EPostMessageType.Select,selectIds:a.selectIds,selectRect:y,willSyncService:!0,isSync:!0,points:p===s.EvevtWorkState.Done&&a.getChildrenPoints()||void 0,textOpt:a.textOpt});for(const[d,m]of n.entries())m.toolsType===s.EToolsKey.Text?h.push({...m,workId:d,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):h.push({...m,workId:d,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:!0})}return{sp:h}}}class j extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.RotateNode)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,emitEventType:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,emitEventType:l,isSync:!0,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,workShapeNode:a,res:i,newServiceStore:n}=e,{updateSelectorOpt:l,willSyncService:c,willSerializeData:p,isSync:h}=o,y=l.workState,d=r.sp||[],m=i==null?void 0:i.selectRect;if(c){p&&y===s.EvevtWorkState.Done&&d.push({type:s.EPostMessageType.Select,selectIds:a.selectIds,selectRect:m,willSyncService:!0,isSync:h,points:a.getChildrenPoints()});for(const[k,S]of n.entries())d.push({...S,workId:k,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:h})}return{sp:d}}}class Z extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetFontStyle)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c,updateSelectorOpt:p,textUpdateForWoker:h}=o,y=r.sp||[],d=n==null?void 0:n.selectRect;if(l&&y){p.fontSize&&y.push({type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:d,willSyncService:l,isSync:c,points:i.getChildrenPoints()});for(const[m,k]of a.entries())h&&k.toolsType===s.EToolsKey.Text?y.push({...k,workId:m,type:s.EPostMessageType.TextUpdate,dataType:s.EDataType.Local,willSyncService:!0}):y.push({...k,workId:m,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c})}return{sp:y}}}class X extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetPoint)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:l}=e;o===s.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,emitEventType:this.emitEventType,willSerializeData:n,isSync:!0,textUpdateForWoker:l,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c}=o,p=r.sp||[],h=n==null?void 0:n.selectRect;if(l&&p){for(const[y,d]of a.entries())p.push({...d,workId:y,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c});p.push({type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:h,willSyncService:l,isSync:c,points:i.getChildrenPoints()})}return{sp:p}}}class Y extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetLock)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;o===s.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:l,isSync:c,updateSelectorOpt:p}=o,h=r.sp||[],y=n==null?void 0:n.selectRect;if(l&&h){for(const[d,m]of a.entries())h.push({...m,workId:d,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:c});h.push({isLocked:p.isLocked,selectorColor:i.selectorColor,scaleType:i.scaleType,canRotate:i.canRotate,type:s.EPostMessageType.Select,selectIds:i.selectIds,selectRect:y,willSyncService:l,isSync:c})}return{sp:h}}}class Q extends L{constructor(){super(...arguments);u(this,"emitEventType",s.EmitEventType.SetShapeOpt)}async consume(e){const{msgType:o,dataType:r,emitEventType:a}=e;if(o===s.EPostMessageType.UpdateNode&&r===s.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:o,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;o===s.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:o,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n}=o,l=r.sp||[];if(i&&l)for(const[c,p]of a.entries())l.push({...p,workId:c,type:s.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:l}}}class J{constructor(t){u(this,"builders",new Map);this.builders=new Map(t.map(e=>[e,this.build(e)]))}build(t){switch(t){case s.EmitEventType.TranslateNode:return new V;case s.EmitEventType.ZIndexNode:return new H;case s.EmitEventType.CopyNode:return new z;case s.EmitEventType.SetColorNode:return new q;case s.EmitEventType.DeleteNode:return new $;case s.EmitEventType.ScaleNode:return new G;case s.EmitEventType.RotateNode:return new j;case s.EmitEventType.SetFontStyle:return new Z;case s.EmitEventType.SetPoint:return new X;case s.EmitEventType.SetLock:return new Y;case s.EmitEventType.SetShapeOpt:return new Q}}registerForMainThread(t){return this.builders.forEach(e=>{e&&e.registerMainThread(t)}),this}async consumeForMainThread(t){for(const e of this.builders.values())if(await(e==null?void 0:e.consume(t)))return!0;return!1}}class ee{constructor(t,e){u(this,"viewId");u(this,"fullLayer");u(this,"topLayer");u(this,"localLayer");u(this,"serviceLayer");u(this,"snapshotFullLayer");u(this,"vNodes");u(this,"master");u(this,"opt");u(this,"cameraOpt");u(this,"scene");u(this,"localWork");u(this,"serviceWork");u(this,"topWork");u(this,"taskUpdateCameraId");u(this,"debounceUpdateCameraId");u(this,"debounceUpdateCache",new Set);u(this,"mainThreadPostId");u(this,"combinePostMsg",new Set);u(this,"methodBuilder");u(this,"cacheImages",new Map);u(this,"imageResolveMap",new Map);this.viewId=t,this.opt=e,this.scene=this.createScene({...e.canvasOpt,container:e.container}),this.master=e.master;const o=s.DefaultAppliancePluginOptions.bufferSize.full,r=s.DefaultAppliancePluginOptions.bufferSize.sub;this.fullLayer=this.createLayer("fullLayer",this.scene,{...e.layerOpt,bufferSize:this.viewId===s.Main_View_Id?o:r*2}),this.topLayer=this.createLayer("topLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===s.Main_View_Id,r),contextType:"2d"}),this.localLayer=this.createLayer("localLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===s.Main_View_Id,r),contextType:"2d"}),this.serviceLayer=this.createLayer("serviceLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===s.Main_View_Id,r),contextType:"2d"}),this.vNodes=new s.VNodeManager(t,this.scene);const a={thread:this,vNodes:this.vNodes};this.localWork=new U(a),this.serviceWork=new K(a),this.topWork=new B(a),this.vNodes.init(this.fullLayer),this.methodBuilder=new J([s.EmitEventType.CopyNode,s.EmitEventType.SetColorNode,s.EmitEventType.DeleteNode,s.EmitEventType.RotateNode,s.EmitEventType.ScaleNode,s.EmitEventType.TranslateNode,s.EmitEventType.ZIndexNode,s.EmitEventType.SetFontStyle,s.EmitEventType.SetPoint,s.EmitEventType.SetLock,s.EmitEventType.SetShapeOpt]).registerForMainThread(this)}getCachedImages(t){var e;return(e=this.cacheImages.get(t))==null?void 0:e.imageBitmap}getCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())if(e===t&&o.imageBitmap)return o.imageBitmap}deleteCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())o.workId===t&&(o.imageBitmap.close(),this.cacheImages.delete(e))}clearCacheImages(){this.cacheImages.forEach(t=>t.imageBitmap.close()),this.cacheImages.clear()}clearImageResolveMap(){this.imageResolveMap.forEach(({timer:t})=>{t&&clearTimeout(t)}),this.imageResolveMap.clear()}post(t){this.combinePostMsg.add(t),this.runBatchPostData()}updateDpr(t){this.scene.displayRatio=t}async on(t){if(!await this.methodBuilder.consumeForMainThread(t)){const{msgType:e,toolsType:o,opt:r,dataType:a,workId:i,workState:n,imageSrc:l,imageBitmap:c,workIds:p,isLockSentEventCursor:h}=t,y=i==null?void 0:i.toString();switch(e){case s.EPostMessageType.UpdateDpr:N.isNumber(t.dpr)&&this.updateDpr(t.dpr);break;case s.EPostMessageType.AuthClear:{const{clearUids:d,localUid:m}=t;this.vNodes.setCanClearUids(d),this.vNodes.setLocalUid(m);break}case s.EPostMessageType.Destroy:this.destroy();break;case s.EPostMessageType.Clear:this.clearAll();break;case s.EPostMessageType.UpdateCamera:await this.updateCamera(t);break;case s.EPostMessageType.UpdateTools:if(o&&r){const d={toolsType:o,toolsOpt:r};this.topWork.canUseTopLayer(o)?this.topWork.setToolsOpt(d):this.localWork.setToolsOpt(d)}break;case s.EPostMessageType.CreateWork:if(y&&r&&o){if(this.topWork.canUseTopLayer(o)){this.topWork.getToolsOpt()||this.topWork.setToolsOpt({toolsType:o,toolsOpt:r}),this.topWork.setWorkOptions(y,r);break}this.localWork.getToolsOpt()||this.localWork.setToolsOpt({toolsType:o,toolsOpt:r}),this.localWork.setWorkOptions(y,r)}break;case s.EPostMessageType.DrawWork:n===s.EvevtWorkState.Done&&a===s.EDataType.Local?(this.consumeDrawAll(a,t),o===s.EToolsKey.LaserPen&&h&&this.post({sp:[{type:s.EPostMessageType.None,isLockSentEventCursor:h}]})):this.consumeDraw(a,t);break;case s.EPostMessageType.UpdateNode:case s.EPostMessageType.FullWork:if(o&&this.topWork.canUseTopLayer(o)){this.consumeDrawAll(a,t);break}this.consumeFull(a,t);break;case s.EPostMessageType.RemoveNode:await this.removeNode(t);return;case s.EPostMessageType.Select:a===s.EDataType.Service&&(i===s.Storage_Selector_key?this.localWork.updateFullSelectWork(t):this.serviceWork.runSelectWork(t));break;case s.EPostMessageType.CursorBlur:this.localWork.cursorBlur();return;case s.EPostMessageType.CursorHover:this.localWork.cursorHover(t);break;case s.EPostMessageType.GetTextActive:a===s.EDataType.Local&&this.localWork.checkTextActive(t);break;case s.EPostMessageType.GetImageBitMap:if(l&&c&&i){const d=i.toString();this.deleteCachedImagesByWorkId(d),this.cacheImages.set(l,{imageBitmap:c,workId:d});const m=this.imageResolveMap.get(l);if(m){const{resolve:k,timer:S}=m;S&&clearTimeout(S),k&&k(l)}}break;case s.EPostMessageType.GetVNodeInfo:if(i&&p){const d=p.map(m=>this.vNodes.get(m));this.post({sp:[{type:s.EPostMessageType.GetVNodeInfo,dataType:s.EDataType.Local,workId:i,vInfo:d}]})}break}}}getIconSize(t,e,o){const r=t*o,a=e*o;return r<=50||a<=50?[50,50]:r<=100||a<=100?[100,100]:r<=200||a<=200?[200,200]:r<=400||a<=400?[400,400]:r<=800||a<=800?[800,800]:[1600,1600]}async loadImageBitMap(t){const{toolsType:e,opt:o,workId:r}=t;if(e===s.EToolsKey.Image&&o&&r){const a=r.toString(),{src:i,type:n,width:l,height:c,strokeColor:p}=o;if(!i||!n||!l||!c)return;let h=i;if(n===s.EImageType.Iconify){const[k,S]=this.getIconSize(l,c,this.opt.displayer.dpr);h=`${i}?width=${k}&height=${S}&color=${p}`}if(this.cacheImages.has(h)){const k=this.getCachedImages(h);if(k)return k}if(this.imageResolveMap.has(h)){const k=this.getCachedImagesByWorkId(a);if(k)return k}const m=await new Promise(k=>{const S=this.imageResolveMap.get(h)||{resolve:void 0,timer:void 0};S.timer&&clearTimeout(S.timer),S.resolve=k,S.timer=setTimeout(()=>{const T=this.imageResolveMap.get(h);T!=null&&T.resolve&&T.resolve(h)},5e3),this.imageResolveMap.set(h,S),this.opt.post({sp:[{imageSrc:h,workId:a,viewId:this.viewId,isgl:!!this.fullLayer.parent.gl,isSubWorker:!1,type:s.EPostMessageType.GetImageBitMap}]})});return this.imageResolveMap.delete(m),this.getCachedImages(h)}}async removeNode(t){const{dataType:e,workId:o,removeIds:r}=t,a=r||[];if(o&&a.push(o.toString()),a.length)for(const i of a){if(i===s.Storage_Selector_key){await this.localWork.removeSelector(t);continue}e===s.EDataType.Local?this.localWork.removeWork(t):e===s.EDataType.Service&&this.serviceWork.removeWork(t),await this.localWork.colloctEffectSelectWork(t)}}async consumeFull(t,e){const o=await this.localWork.colloctEffectSelectWork(e);o&&t===s.EDataType.Local&&await this.localWork.consumeFull(o),o&&t===s.EDataType.Service&&this.serviceWork.consumeFull(o)}setCameraOpt(t){this.cameraOpt=t;const{scale:e,centerX:o,centerY:r,width:a,height:i}=t;(a!==this.scene.width||i!==this.scene.height)&&this.updateScene({width:a,height:i}),this.fullLayer.setAttribute("scale",[e,e]),this.fullLayer.setAttribute("translate",[-o,-r]),this.topLayer.setAttribute("scale",[e,e]),this.topLayer.setAttribute("translate",[-o,-r]),this.localLayer.setAttribute("scale",[e,e]),this.localLayer.setAttribute("translate",[-o,-r]),this.serviceLayer.setAttribute("scale",[e,e]),this.serviceLayer.setAttribute("translate",[-o,-r])}runBatchPostData(){this.mainThreadPostId||(this.mainThreadPostId=requestAnimationFrame(this.combinePost.bind(this)))}combinePostData(){var r;this.mainThreadPostId=void 0;const t=[];let e,o;for(const a of this.combinePostMsg.values()){if((r=a.sp)!=null&&r.length)for(const i of a.sp){let n=!1;for(const l of t)if(N.isEqual(i,l)){n=!0;break}n||t.push(i)}N.isNumber(a.fullWorkerDrawCount)&&(e=a.fullWorkerDrawCount),N.isNumber(a.consumeCount)&&(o=a.consumeCount)}return this.combinePostMsg.clear(),{sp:t,fullWorkerDrawCount:e,consumeCount:o}}combinePost(){var o,r;const t=this.combinePostData(),e=(o=t.sp)==null?void 0:o.filter(a=>a.type!==s.EPostMessageType.None||a.isLockSentEventCursor);e!=null&&e.length?t.sp=e.map(a=>a.viewId?a:{...a,viewId:this.viewId}):delete t.sp,t.consumeCount===void 0&&delete t.consumeCount,t.fullWorkerDrawCount===void 0&&delete t.fullWorkerDrawCount,(t!=null&&t.consumeCount||t!=null&&t.fullWorkerDrawCount||(r=t.sp)!=null&&r.length)&&this.opt.post(t)}clearAll(){this.fullLayer.children.length&&(this.fullLayer.parent.children.forEach(t=>{t.name!=="viewport"&&t.remove()}),s.removeAllChildren(this.fullLayer,this.fullLayer.parent)),this.clearCacheImages(),this.clearImageResolveMap(),this.localWork.clearAll(),this.topWork.clearAll(),this.serviceWork.clearAll(),this.vNodes.clear(),this.post({sp:[{type:s.EPostMessageType.Clear}]})}consumeDrawAll(t,e){const{toolsType:o,workId:r}=e;if(r){const a=r.toString();if(o&&this.topWork.canUseTopLayer(o)){t===s.EDataType.Local&&(this.topWork.getLocalWorkShape(r.toString())||this.topWork.createLocalWork(e)),this.topWork.consumeDrawAll(e);return}t===s.EDataType.Local&&(this.localWork.getWorkShape(a)||this.localWork.createLocalWork(e),this.localWork.consumeDrawAll(e,this.serviceWork))}}consumeDraw(t,e){const{opt:o,workId:r,toolsType:a}=e;if(r&&a&&o){const i=r.toString();if(this.topWork.canUseTopLayer(a)){t===s.EDataType.Local&&(this.topWork.getLocalWorkShape(i)||this.topWork.createLocalWork(e)),this.topWork.consumeDraw(e);return}t===s.EDataType.Local?(this.localWork.getWorkShape(i)||this.localWork.createLocalWork(e),this.localWork.consumeDraw(e,this.serviceWork)):t===s.EDataType.Service&&this.serviceWork.consumeDraw(e);return}}async updateCamera(t){var r;const{cameraOpt:e,scenePath:o}=t;if(e&&!N.isEqual(this.cameraOpt,e)){if(this.taskUpdateCameraId&&(clearTimeout(this.taskUpdateCameraId),this.taskUpdateCameraId=void 0),o){let c=!1;for(const[p,h]of this.localWork.getWorkShapes().entries())switch(h.toolsType){case s.EToolsKey.Text:case s.EToolsKey.BitMapEraser:case s.EToolsKey.PencilEraser:case s.EToolsKey.Eraser:case s.EToolsKey.Selector:case s.EToolsKey.LaserPen:break;default:p!==s.Cursor_Hover_Id&&p!==s.Storage_Selector_key&&(c=!0);break}if(c){this.taskUpdateCameraId=setTimeout(()=>{this.taskUpdateCameraId=void 0,this.updateCamera(t)},s.Task_Time_Interval);return}}const a=new Map;for(const[c,p]of this.vNodes.getNodesByType(s.EToolsKey.Text).entries()){const h=p.rect;a.set(c,N.cloneDeep(h))}const i=new Set(a.keys());let n=!1;if(this.localWork.hasSelector()){const c=(r=this.localWork.getSelector())==null?void 0:r.selectIds;if(c){n=!0;for(const p of c)i.add(p)}}let l=!1;if(this.serviceWork.selectorWorkShapes.size)for(const c of this.serviceWork.selectorWorkShapes.values()){const p=c.selectIds;if(p){l=!0;for(const h of p)i.add(h)}}if(this.setCameraOpt(e),this.vNodes.curNodeMap.size){this.vNodes.clearTarget(),this.vNodes.updateHighLevelNodesRect(i),this.debounceUpdateCameraId&&clearTimeout(this.debounceUpdateCameraId);for(const[c,p]of a.entries()){const h=this.vNodes.get(c);if(h){const y=p,d=h.rect,m=this.getSceneRect(),k=s.getRectMatrixrRelation(y,m),S=s.getRectMatrixrRelation(d,m);let T=!1;if((k!==S||y.w!==d.w||y.h!==d.h||S===s.EMatrixrRelationType.intersect)&&(T=!0),T){const{toolsType:E,opt:D}=h;E===s.EToolsKey.Text&&D.workState===s.EvevtWorkState.Done&&this.debounceUpdateCache.add(c)}}}if(n&&this.localWork.reRenderSelector(),l)for(const[c,p]of this.serviceWork.selectorWorkShapes.entries())this.serviceWork.runSelectWork({workId:c,selectIds:p.selectIds,msgType:s.EPostMessageType.Select,dataType:s.EDataType.Service,viewId:this.viewId});this.debounceUpdateCameraId=setTimeout(()=>{var p;this.debounceUpdateCameraId=void 0;const c=[];for(const h of this.debounceUpdateCache.values()){if((p=this.fullLayer)==null?void 0:p.getElementsByName(h)[0]){const d=this.vNodes.get(h);if(d){const{toolsType:m,opt:k,rect:S}=d,T=this.localWork.setFullWork({toolsType:m,opt:k,workId:h});if(T){const E=this.getSceneRect(),D=s.getRectMatrixrRelation(S,E);c.push(T.consumeServiceAsync({isFullWork:!0,replaceId:h,isDrawLabel:D!==s.EMatrixrRelationType.outside}))}}}this.debounceUpdateCache.delete(h)}this.vNodes.updateLowLevelNodesRect(),this.vNodes.clearHighLevelIds()},s.Task_Time_Interval)}}}getSceneRect(){const{width:t,height:e}=this.scene;return{x:0,y:0,w:Math.floor(t),h:Math.floor(e)}}createScene(t){return new C.Scene({displayRatio:this.opt.displayer.dpr,depth:!1,desynchronized:!0,...t,autoRender:!0,id:this.viewId,contextType:"2d"})}createLayer(t,e,o){const{width:r,height:a}=o,i=`canvas-${t}`,n=e.layer(i,{...o,offscreen:!1}),l=new C.Group({anchor:[.5,.5],pos:[r*.5,a*.5],size:[r,a],name:"viewport",id:t});return n.append(l),l}updateScene(t){this.scene.attr({...t});const{width:e,height:o}=t;this.scene.width=e,this.scene.height=o,this.updateLayer({width:e,height:o})}updateLayer(t){const{width:e,height:o}=t;this.fullLayer.parent.setAttribute("width",e),this.fullLayer.parent.setAttribute("height",o),this.fullLayer.setAttribute("size",[e,o]),this.fullLayer.setAttribute("pos",[e*.5,o*.5]),this.topLayer.parent.setAttribute("width",e),this.topLayer.parent.setAttribute("height",o),this.topLayer.setAttribute("size",[e,o]),this.topLayer.setAttribute("pos",[e*.5,o*.5]),this.localLayer.parent.setAttribute("width",e),this.localLayer.parent.setAttribute("height",o),this.localLayer.setAttribute("size",[e,o]),this.localLayer.setAttribute("pos",[e*.5,o*.5]),this.serviceLayer.parent.setAttribute("width",e),this.serviceLayer.parent.setAttribute("height",o),this.serviceLayer.setAttribute("size",[e,o]),this.serviceLayer.setAttribute("pos",[e*.5,o*.5])}destroy(){this.clearCacheImages(),this.clearImageResolveMap(),this.vNodes.clear(),this.fullLayer.remove(),s.removeTexture(this.fullLayer,this.fullLayer.parent),this.topLayer.remove(),s.removeTexture(this.topLayer,this.topLayer.parent),this.localLayer.remove(),s.removeTexture(this.localLayer,this.localLayer.parent),this.serviceLayer.remove(),s.removeTexture(this.serviceLayer,this.serviceLayer.parent),this.scene.remove(),this.localWork.destroy(),this.serviceWork.destroy(),this.topWork.destroy()}}class te{constructor(t,e){u(this,"viewId");u(this,"fullLayer");u(this,"master");u(this,"opt");u(this,"scene");u(this,"mainThreadPostId");u(this,"combinePostMsg",new Set);u(this,"workShapes",new Map);u(this,"cacheImages",new Map);u(this,"imageResolveMap",new Map);this.viewId=t,this.opt=e,this.scene=this.createScene({...e.canvasOpt,container:e.container}),this.master=e.master,this.fullLayer=this.createLayer("fullLayer",this.scene,{...e.layerOpt,bufferSize:this.viewId===s.Main_View_Id?6e3:3e3,contextType:"2d"})}getCachedImages(t){var e;return(e=this.cacheImages.get(t))==null?void 0:e.imageBitmap}getCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())if(e===t&&o.imageBitmap)return o.imageBitmap}deleteCachedImagesByWorkId(t){for(const[e,o]of this.cacheImages.entries())o.workId===t&&(o.imageBitmap.close(),this.cacheImages.delete(e))}clearCacheImages(){this.cacheImages.forEach(t=>t.imageBitmap.close()),this.cacheImages.clear()}clearImageResolveMap(){this.imageResolveMap.forEach(({timer:t})=>{t&&clearTimeout(t)}),this.imageResolveMap.clear()}post(t){this.combinePostMsg.add(t),this.runBatchPostData()}async on(t){const{msgType:e,imageSrc:o,imageBitmap:r,workId:a}=t;switch(e){case s.EPostMessageType.Snapshot:await this.getSnapshot(t),this.destroy();return;case s.EPostMessageType.BoundingBox:await this.getBoundingRect(t),this.destroy();return;case s.EPostMessageType.GetImageBitMap:if(o&&r&&a){const i=a.toString();this.deleteCachedImagesByWorkId(i),this.cacheImages.set(o,{imageBitmap:r,workId:i});const n=this.imageResolveMap.get(o);if(n){const{resolve:l,timer:c}=n;c&&clearTimeout(c),l&&l(o)}}break}}getIconSize(t,e,o){const r=t*o,a=e*o;return r<=50||a<=50?[50,50]:r<=100||a<=100?[100,100]:r<=200||a<=200?[200,200]:r<=400||a<=400?[400,400]:r<=800||a<=800?[800,800]:[1600,1600]}async loadImageBitMap(t){const{toolsType:e,opt:o,workId:r}=t;if(e===s.EToolsKey.Image&&o&&r){const a=r.toString(),{src:i,type:n,width:l,height:c,strokeColor:p}=o;if(!i||!n||!l||!c)return;let h=i;if(n===s.EImageType.Iconify){const[k,S]=this.getIconSize(l,c,this.opt.displayer.dpr);h=`${i}?width=${k}&height=${S}&color=${p}`}if(this.cacheImages.has(h)){const k=this.getCachedImages(h);if(k)return k}if(this.imageResolveMap.has(h)){const k=this.getCachedImagesByWorkId(a);if(k)return k}const m=await new Promise(k=>{const S=this.imageResolveMap.get(h)||{resolve:void 0,timer:void 0};S.timer&&clearTimeout(S.timer),S.resolve=k,S.timer=setTimeout(()=>{const T=this.imageResolveMap.get(h);T!=null&&T.resolve&&T.resolve(h)},5e3),this.imageResolveMap.set(h,S),this.opt.post({sp:[{imageSrc:h,workId:a,viewId:this.viewId,isgl:!!this.fullLayer.parent.gl,isSubWorker:!0,type:s.EPostMessageType.GetImageBitMap}]})});return this.imageResolveMap.delete(m),this.getCachedImages(h)}}createWorkShapeNode(t){return s.getShapeInstance({...t,fullLayer:this.fullLayer,drawLayer:void 0})}setFullWork(t){const{workId:e,opt:o,toolsType:r}=t;if(e&&o&&r){const a=e.toString();let i;return e&&this.workShapes.has(a)?(i=this.workShapes.get(a),i==null||i.setWorkOptions(o)):i=this.createWorkShapeNode({toolsOpt:o,toolsType:r,workId:a}),i?(this.workShapes.set(a,i),i):void 0}}async runFullWork(t){var r;const e=this.setFullWork(t),o=t.ops&&s.transformToNormalData(t.ops);if(e){let a,i;const n=(r=e.getWorkId())==null?void 0:r.toString();return e.toolsType===s.EToolsKey.Image?a=await e.consumeServiceAsync({isFullWork:!0,worker:this}):e.toolsType===s.EToolsKey.Text?a=await e.consumeServiceAsync({isFullWork:!0,replaceId:n,isDrawLabel:!0}):(a=e.consumeService({op:o,isFullWork:!0,replaceId:n}),i=(t==null?void 0:t.updateNodeOpt)&&e.updataOptService(t.updateNodeOpt)),s.computRect(a,i)}}async getSnapshot(t){const{scenePath:e,scenes:o,cameraOpt:r,w:a,h:i}=t;if(e&&o&&r){this.setCameraOpt(r);let n;for(const[c,p]of Object.entries(o))if(p!=null&&p.type)switch(p==null?void 0:p.type){case s.EPostMessageType.UpdateNode:case s.EPostMessageType.FullWork:{const{opt:h}=p,y={...p,opt:h,workId:c,msgType:s.EPostMessageType.FullWork,dataType:s.EDataType.Service,viewId:this.viewId},d=await this.runFullWork(y);n=s.computRect(n,d);break}}let l;a&&i&&(l={resizeWidth:a,resizeHeight:i}),await this.getSnapshotRender({scenePath:e,options:l})}}getSceneRect(){const{width:t,height:e}=this.scene;return{x:0,y:0,w:Math.floor(t),h:Math.floor(e)}}getRectImageBitmap(t,e){const o=Math.floor(t.x*this.opt.displayer.dpr),r=Math.floor(t.y*this.opt.displayer.dpr),a=t.w>0&&Math.floor(t.w*this.opt.displayer.dpr||1)||1,i=t.h>0&&Math.floor(t.h*this.opt.displayer.dpr||1)||1;return createImageBitmap(this.fullLayer.parent.canvas,o,r,a,i,e)}async getSnapshotRender(t){var a;const{scenePath:e,options:o}=t;((a=this.fullLayer)==null?void 0:a.parent).render();const r=await this.getRectImageBitmap(this.getSceneRect(),o);r&&(this.post({sp:[{type:s.EPostMessageType.Snapshot,scenePath:e,imageBitmap:r,viewId:this.viewId}]}),this.fullLayer&&s.removeAllChildren(this.fullLayer,this.fullLayer.parent))}async getBoundingRect(t){const{scenePath:e,scenes:o,cameraOpt:r}=t;if(e&&o&&r){this.setCameraOpt(r);let a;for(const[i,n]of Object.entries(o))if(n!=null&&n.type)switch(n==null?void 0:n.type){case s.EPostMessageType.UpdateNode:case s.EPostMessageType.FullWork:{const l=await this.runFullWork({...n,workId:i,msgType:s.EPostMessageType.FullWork,dataType:s.EDataType.Service,viewId:this.viewId});a=s.computRect(a,l);break}}a&&this.post({sp:[{type:s.EPostMessageType.BoundingBox,scenePath:e,rect:a}]})}}setCameraOpt(t){const{scale:e,centerX:o,centerY:r,width:a,height:i}=t;this.updateScene({width:a,height:i}),this.fullLayer.setAttribute("scale",[e,e]),this.fullLayer.setAttribute("translate",[-o,-r])}runBatchPostData(){this.mainThreadPostId||(this.mainThreadPostId=requestAnimationFrame(this.combinePost.bind(this)))}combinePostData(){var e;this.mainThreadPostId=void 0;const t=[];for(const o of this.combinePostMsg.values())if((e=o.sp)!=null&&e.length)for(const r of o.sp){let a=!1;for(const i of t)if(s.isEqual(r,i)){a=!0;break}a||t.push(r)}return this.combinePostMsg.clear(),{sp:t}}combinePost(){var o,r;const t=this.combinePostData(),e=(o=t.sp)==null?void 0:o.filter(a=>a.type!==s.EPostMessageType.None||a.isLockSentEventCursor);e!=null&&e.length?t.sp=e.map(a=>a.viewId?a:{...a,viewId:this.viewId}):delete t.sp,(r=t.sp)!=null&&r.length&&this.opt.post(t)}createScene(t){return new C.Scene({displayRatio:this.opt.displayer.dpr,depth:!1,desynchronized:!0,...t,autoRender:!1,contextType:"2d"})}createLayer(t,e,o){const{width:r,height:a}=o,i=`canvas-${t}`,n=e.layer(i,o),l=new C.Group({anchor:[.5,.5],pos:[r*.5,a*.5],size:[r,a],name:"viewport",id:t});return n.append(l),l}updateScene(t){this.scene.attr({...t});const{width:e,height:o}=t;this.scene.width=e,this.scene.height=o,this.updateLayer({width:e,height:o})}updateLayer(t){const{width:e,height:o}=t;this.fullLayer.parent.setAttribute("width",e),this.fullLayer.parent.setAttribute("height",o),this.fullLayer.setAttribute("size",[e,o]),this.fullLayer.setAttribute("pos",[e*.5,o*.5])}destroy(){this.clearCacheImages(),this.clearImageResolveMap(),this.fullLayer.remove(),s.removeTexture(this.fullLayer,this.fullLayer.parent),this.scene.remove()}}class se{constructor(t){u(this,"mainThreadMap",new Map);u(this,"snapshotThread");u(this,"master");this.master=t}post(t){const{fullWorkerDrawCount:e,sp:o,workerTasksqueueCount:r,consumeCount:a}=t;this.master.isBusy&&s.isNumber(r)&&this.master.setWorkerTasksqueueCount(r),s.isNumber(e)&&this.master.setMaxDrawCount(e),s.isNumber(a)&&this.master.setConsumeCount(a),o&&this.master.collectorSyncData(o)}destroy(){this.mainThreadMap.clear()}createMainThread(t,e){return new ee(t,e)}createSnapshotThread(t,e){return new te(t,e)}async consume(t){var e,o,r,a;for(const i of t.values()){const{msgType:n,viewId:l,tasksqueue:c,mainTasksqueueCount:p,layerOpt:h,offscreenCanvasOpt:y,cameraOpt:d,isSubWorker:m}=i;if(n===s.EPostMessageType.Console){console.log(this);continue}if(n===s.EPostMessageType.Init){const S=(e=this.master.control.viewContainerManager.getView(l))==null?void 0:e.displayer,T=S==null?void 0:S.canvasContainerRef.current;if(S&&T&&h&&y){const E=this.createMainThread(l,{displayer:S,container:T,layerOpt:h,master:this.master,canvasOpt:y,post:this.post.bind(this)});this.mainThreadMap.set(l,E),E&&d&&E.setCameraOpt(d)}continue}if((n===s.EPostMessageType.Snapshot||n===s.EPostMessageType.BoundingBox)&&l===((o=this.master.control.viewContainerManager.mainView)==null?void 0:o.id)){const S=(r=this.master.control.viewContainerManager.getView(l))==null?void 0:r.displayer,T=(a=S.snapshotContainerRef)==null?void 0:a.current;if(S&&T&&d){T.style.width=`${d.width}px`,T.style.height=`${d.height}px`;const E={...s.ViewContainerManager.defaultLayerOpt,offscreen:!1,width:d.width,height:d.height},D={...s.ViewContainerManager.defaultScreenCanvasOpt,width:d.width,height:d.height};this.snapshotThread=this.createSnapshotThread(l,{displayer:S,container:T,layerOpt:E,master:this.master,canvasOpt:D,post:this.post.bind(this)}),this.snapshotThread.on(i).then(()=>{this.snapshotThread=void 0,T.innerHTML="",T.style.width="",T.style.height=""});continue}}if(n===s.EPostMessageType.GetImageBitMap&&m&&this.snapshotThread){this.snapshotThread.on(i);continue}if(n===s.EPostMessageType.TasksQueue&&(c!=null&&c.size)){for(const[S,T]of this.mainThreadMap.entries()){const E=c.get(S);E&&(await T.on(E),p&&this.post({workerTasksqueueCount:p}))}continue}if(l===s.Storage_ViewId_ALL){for(const S of this.mainThreadMap.values())S.on(i),n===s.EPostMessageType.Destroy&&this.mainThreadMap.delete(l);continue}const k=this.mainThreadMap.get(l);k&&(k.on(i),n===s.EPostMessageType.Destroy&&this.mainThreadMap.delete(l))}}}exports.MainThreadManagerImpl=se;
package/dist/subWorker.js CHANGED
@@ -396,7 +396,7 @@ _inherits(o,_r$default22);return _createClass(o,[{key:"texture",get:function get
396
396
  f=="length"||// Node.js 0.10 has enumerable non-index properties on buffers.
397
397
  n&&(f=="offset"||f=="parent")||// PhantomJS 2 has enumerable non-index properties on typed arrays.
398
398
  i&&(f=="buffer"||f=="byteLength"||f=="byteOffset")||// Skip index properties.
399
- Rf(f,a)))&&o.push(f);return o;}var Oi=Bf,Wf=Object.prototype;function Ff(u){var e=u&&u.constructor,t=typeof e=="function"&&e.prototype||Wf;return u===t;}var tn=Ff;function Uf(u,e){return function(t){return u(e(t));};}var Mi=Uf,jf=Mi,Yf=jf(Object.keys,Object),Xf=Yf,zf=tn,$f=Xf,Gf=Object.prototype,Hf=Gf.hasOwnProperty;function kf(u){if(!zf(u))return $f(u);var e=[];for(var t in Object(u))Hf.call(u,t)&&t!="constructor"&&e.push(t);return e;}var Vf=kf,Kf=pi,Zf=Ci;function Jf(u){return u!=null&&Zf(u.length)&&!Kf(u);}var en=Jf,Qf=Oi,qf=Vf,_f=en;function th(u){return _f(u)?Qf(u):qf(u);}var rn=th,eh=Br,rh=rn;function nh(u,e){return u&&eh(e,rh(e),u);}var ih=nh;function sh(u){var e=[];if(u!=null)for(var t in Object(u))e.push(t);return e;}var oh=sh,ah=hr,lh=tn,ch=oh,fh=Object.prototype,hh=fh.hasOwnProperty;function uh(u){if(!ah(u))return ch(u);var e=lh(u),t=[];for(var r in u)r=="constructor"&&(e||!hh.call(u,r))||t.push(r);return t;}var dh=uh,ph=Oi,mh=dh,vh=en;function yh(u){return vh(u)?ph(u,!0):mh(u);}var nn=yh,gh=Br,Ph=nn;function xh(u,e){return u&&gh(e,Ph(e),u);}var Sh=xh,xr={exports:{}};xr.exports;(function(u,e){var t=Le,r=e&&!e.nodeType&&e,n=r&&!0&&u&&!u.nodeType&&u,i=n&&n.exports===r,l=i?t.Buffer:void 0,o=l?l.allocUnsafe:void 0;function a(f,g){if(g)return f.slice();var c=f.length,m=o?o(c):new f.constructor(c);return f.copy(m),m;}u.exports=a;})(xr,xr.exports);var Th=xr.exports;function Ch(u,e){var t=-1,r=u.length;for(e||(e=Array(r));++t<r;)e[t]=u[t];return e;}var Ih=Ch;function Oh(u,e){for(var t=-1,r=u==null?0:u.length,n=0,i=[];++t<r;){var l=u[t];e(l,t,u)&&(i[n++]=l);}return i;}var Ei=Oh;function Mh(){return[];}var Ai=Mh,Eh=Ei,Ah=Ai,Lh=Object.prototype,wh=Lh.propertyIsEnumerable,wn=Object.getOwnPropertySymbols,Rh=wn?function(u){return u==null?[]:(u=Object(u),Eh(wn(u),function(e){return wh.call(u,e);}));}:Ah,sn=Rh,Dh=Br,bh=sn;function Nh(u,e){return Dh(u,bh(u),e);}var Bh=Nh;function Wh(u,e){for(var t=-1,r=e.length,n=u.length;++t<r;)u[n+t]=e[t];return u;}var on=Wh,Fh=Mi,Uh=Fh(Object.getPrototypeOf,Object),Li=Uh,jh=on,Yh=Li,Xh=sn,zh=Ai,$h=Object.getOwnPropertySymbols,Gh=$h?function(u){for(var e=[];u;)jh(e,Xh(u)),u=Yh(u);return e;}:zh,wi=Gh,Hh=Br,kh=wi;function Vh(u,e){return Hh(u,kh(u),e);}var Kh=Vh,Zh=on,Jh=ur;function Qh(u,e,t){var r=e(u);return Jh(u)?r:Zh(r,t(u));}var Ri=Qh,qh=Ri,_h=sn,tu=rn;function eu(u){return qh(u,tu,_h);}var Di=eu,ru=Ri,nu=wi,iu=nn;function su(u){return ru(u,iu,nu);}var ou=su,au=Ue,lu=Le,cu=au(lu,"DataView"),fu=cu,hu=Ue,uu=Le,du=hu(uu,"Promise"),pu=du,mu=Ue,vu=Le,yu=mu(vu,"Set"),bi=yu,gu=Ue,Pu=Le,xu=gu(Pu,"WeakMap"),Su=xu,zr=fu,$r=Qr,Gr=pu,Hr=bi,kr=Su,Ni=Je,er=mi,Rn="[object Map]",Tu="[object Object]",Dn="[object Promise]",bn="[object Set]",Nn="[object WeakMap]",Bn="[object DataView]",Cu=er(zr),Iu=er($r),Ou=er(Gr),Mu=er(Hr),Eu=er(kr),Fe=Ni;(zr&&Fe(new zr(new ArrayBuffer(1)))!=Bn||$r&&Fe(new $r())!=Rn||Gr&&Fe(Gr.resolve())!=Dn||Hr&&Fe(new Hr())!=bn||kr&&Fe(new kr())!=Nn)&&(Fe=function Fe(u){var e=Ni(u),t=e==Tu?u.constructor:void 0,r=t?er(t):"";if(r)switch(r){case Cu:return Bn;case Iu:return Rn;case Ou:return Dn;case Mu:return bn;case Eu:return Nn;}return e;});var Fr=Fe,Au=Object.prototype,Lu=Au.hasOwnProperty;function wu(u){var e=u.length,t=new u.constructor(e);return e&&typeof u[0]=="string"&&Lu.call(u,"index")&&(t.index=u.index,t.input=u.input),t;}var Ru=wu,Du=Le,bu=Du.Uint8Array,Bi=bu,Wn=Bi;function Nu(u){var e=new u.constructor(u.byteLength);return new Wn(e).set(new Wn(u)),e;}var an=Nu,Bu=an;function Wu(u,e){var t=e?Bu(u.buffer):u.buffer;return new u.constructor(t,u.byteOffset,u.byteLength);}var Fu=Wu,Uu=/\w*$/;function ju(u){var e=new u.constructor(u.source,Uu.exec(u));return e.lastIndex=u.lastIndex,e;}var Yu=ju,Fn=fr,Un=Fn?Fn.prototype:void 0,jn=Un?Un.valueOf:void 0;function Xu(u){return jn?Object(jn.call(u)):{};}var zu=Xu,$u=an;function Gu(u,e){var t=e?$u(u.buffer):u.buffer;return new u.constructor(t,u.byteOffset,u.length);}var Hu=Gu,ku=an,Vu=Fu,Ku=Yu,Zu=zu,Ju=Hu,Qu="[object Boolean]",qu="[object Date]",_u="[object Map]",td="[object Number]",ed="[object RegExp]",rd="[object Set]",nd="[object String]",id="[object Symbol]",sd="[object ArrayBuffer]",od="[object DataView]",ad="[object Float32Array]",ld="[object Float64Array]",cd="[object Int8Array]",fd="[object Int16Array]",hd="[object Int32Array]",ud="[object Uint8Array]",dd="[object Uint8ClampedArray]",pd="[object Uint16Array]",md="[object Uint32Array]";function vd(u,e,t){var r=u.constructor;switch(e){case sd:return ku(u);case Qu:case qu:return new r(+u);case od:return Vu(u,t);case ad:case ld:case cd:case fd:case hd:case ud:case dd:case pd:case md:return Ju(u,t);case _u:return new r();case td:case nd:return new r(u);case ed:return Ku(u);case rd:return new r();case id:return Zu(u);}}var yd=vd,gd=hr,Yn=Object.create,Pd=/* @__PURE__ */function(){function u(){}return function(e){if(!gd(e))return{};if(Yn)return Yn(e);u.prototype=e;var t=new u();return u.prototype=void 0,t;};}(),xd=Pd,Sd=xd,Td=Li,Cd=tn;function Id(u){return typeof u.constructor=="function"&&!Cd(u)?Sd(Td(u)):{};}var Od=Id,Md=Fr,Ed=De,Ad="[object Map]";function Ld(u){return Ed(u)&&Md(u)==Ad;}var wd=Ld,Rd=wd,Dd=Wr,Xn=_r,zn=Xn&&Xn.isMap,bd=zn?Dd(zn):Rd,Nd=bd,Bd=Fr,Wd=De,Fd="[object Set]";function Ud(u){return Wd(u)&&Bd(u)==Fd;}var jd=Ud,Yd=jd,Xd=Wr,$n=_r,Gn=$n&&$n.isSet,zd=Gn?Xd(Gn):Yd,Wi=zd,$d=/* @__PURE__ */Ne(Wi),Gd=yi,Hd=mc,kd=xi,Vd=ih,Kd=Sh,Zd=Th,Jd=Ih,Qd=Bh,qd=Kh,_d=Di,tp=ou,ep=Fr,rp=Ru,np=yd,ip=Od,sp=ur,op=qr,ap=Nd,lp=hr,cp=Wi,fp=rn,hp=nn,up=1,dp=2,pp=4,Fi="[object Arguments]",mp="[object Array]",vp="[object Boolean]",yp="[object Date]",gp="[object Error]",Ui="[object Function]",Pp="[object GeneratorFunction]",xp="[object Map]",Sp="[object Number]",ji="[object Object]",Tp="[object RegExp]",Cp="[object Set]",Ip="[object String]",Op="[object Symbol]",Mp="[object WeakMap]",Ep="[object ArrayBuffer]",Ap="[object DataView]",Lp="[object Float32Array]",wp="[object Float64Array]",Rp="[object Int8Array]",Dp="[object Int16Array]",bp="[object Int32Array]",Np="[object Uint8Array]",Bp="[object Uint8ClampedArray]",Wp="[object Uint16Array]",Fp="[object Uint32Array]",re={};re[Fi]=re[mp]=re[Ep]=re[Ap]=re[vp]=re[yp]=re[Lp]=re[wp]=re[Rp]=re[Dp]=re[bp]=re[xp]=re[Sp]=re[ji]=re[Tp]=re[Cp]=re[Ip]=re[Op]=re[Np]=re[Bp]=re[Wp]=re[Fp]=!0;re[gp]=re[Ui]=re[Mp]=!1;function yr(u,e,t,r,n,i){var l,o=e&up,a=e&dp,f=e&pp;if(t&&(l=n?t(u,r,n,i):t(u)),l!==void 0)return l;if(!lp(u))return u;var g=sp(u);if(g){if(l=rp(u),!o)return Jd(u,l);}else{var c=ep(u),m=c==Ui||c==Pp;if(op(u))return Zd(u,o);if(c==ji||c==Fi||m&&!n){if(l=a||m?{}:ip(u),!o)return a?qd(u,Kd(l,u)):Qd(u,Vd(l,u));}else{if(!re[c])return n?u:{};l=np(u,c,o);}}i||(i=new Gd());var x=i.get(u);if(x)return x;i.set(u,l),cp(u)?u.forEach(function(P){l.add(yr(P,e,t,P,u,i));}):ap(u)&&u.forEach(function(P,T){l.set(T,yr(P,e,t,T,u,i));});var M=f?a?tp:_d:a?hp:fp,S=g?void 0:M(u);return Hd(S||u,function(P,T){S&&(T=P,P=u[T]),kd(l,T,yr(P,e,t,T,u,i));}),l;}var Up=yr,jp=Up,Yp=1,Xp=4;function zp(u){return jp(u,Yp|Xp);}var $p=zp,ue=/* @__PURE__ */Ne($p);var Yi="1.1.18-beta.1",Gp="@netless/appliance-plugin";if((typeof window==="undefined"?"undefined":_typeof(window))<"u"){var u=window.__netlessUA||"";u+=" ".concat(Gp,"@").concat(Yi),window.__netlessUA=u;}var Se={syncOpt:{interval:300},cdn:{subWorkerUrl:"https://cdn.jsdelivr.net/npm/@netless/appliance-plugin@latest/dist/subWorker.js",fullWorkerUrl:"https://cdn.jsdelivr.net/npm/@netless/appliance-plugin@latest/dist/fullWorker.js"},cursor:{expirationTime:5e3},bufferSize:{full:2e4,sub:600},bezier:{maxDrawCount:1/0,combineUnitTime:300},pencilEraser:{useBitMap:!0,maxImageWidth:1920,maxImageHeight:1920},strokeWidth:{min:1,max:10},textEditor:{showFloatBar:!0,canSelectorSwitch:!0,rightBoundBreak:!1}};function Ee(u){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:!0;var t=u.length;if(t<2)return"";var r=u[0],n=u[1];if(t===2)return"M".concat(ze(r),"L").concat(ze(n));var i="";for(var l=2,o=t-1;l<o;l++)r=u[l],n=u[l+1],i+=$e(r,n);return e?"M".concat($e(u[0],u[1]),"Q").concat(ze(u[1])).concat($e(u[1],u[2]),"T").concat(i).concat($e(u[t-1],u[0])).concat($e(u[0],u[1]),"Z"):"M".concat(ze(u[0]),"Q").concat(ze(u[1])).concat($e(u[1],u[2])).concat(u.length>3?"T":"").concat(i,"L").concat(ze(u[t-1]));}var Pe=/*#__PURE__*/function(){function Pe(e){_classCallCheck(this,Pe);at(this,"maxImageWidth",Se.pencilEraser.maxImageWidth);at(this,"maxImageHeight",Se.pencilEraser.maxImageHeight);at(this,"syncUnitTime",Se.syncOpt.interval);at(this,"vNodes");at(this,"drawLayer");at(this,"fullLayer");at(this,"workId");at(this,"isDelete",!1);var t=e.vNodes,r=e.fullLayer,n=e.drawLayer,i=e.workId,l=e.toolsOpt;this.vNodes=t,this.fullLayer=r,this.drawLayer=n,this.workId=i,this.syncUnitTime=l.syncUnitTime||this.syncUnitTime;}return _createClass(Pe,[{key:"baseConsumeResult",get:function get(){return{workId:this.workId,toolsType:this.toolsType,opt:this.workOptions};}},{key:"filterSamePoints",value:function filterSamePoints(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:0.01;return e.reduce(function(r,n){var i=r[r.length-1];return(n&&!i||n&&i&&!n.isNear(i,t))&&r.push(n),r;},[]);}/** 设置工作id */},{key:"setWorkId",value:function setWorkId(e){this.workId=e;}},{key:"getWorkId",value:function getWorkId(){return this.workId;}/** 获取工作选项配置 */},{key:"getWorkOptions",value:function getWorkOptions(){return this.workOptions;}/** 设置工作选项配置 */},{key:"setWorkOptions",value:function setWorkOptions(e){var n,i,l;this.workOptions=e,this.syncUnitTime=e.syncUnitTime||this.syncUnitTime;var t=(n=this.workId)==null?void 0:n.toString(),r=t&&((i=this.vNodes)==null?void 0:i.get(t))||void 0;t&&r&&(r.opt=e,(l=this.vNodes)==null||l.setInfo(t,r));}/** 更新服务端同步配置,返回绘制结果 */},{key:"updataOptService",value:function updataOptService(e){var n,i;var t;var r=(n=this.workId)==null?void 0:n.toString();if(r&&e){var l=this.fullLayer.getElementsByName(r)||this.drawLayer&&this.drawLayer.getElementsByName(r)||[];if(l.length!==1)return;var o=l[0],a=e.pos,f=e.zIndex,g=e.scale,c=e.angle,m=e.translate,x={};he(f)&&(x.zIndex=f),a&&(x.pos=[a[0],a[1]]),g&&(x.scale=g),c&&(x.rotate=c),m&&(x.translate=m),o.attr(x);var M=o==null?void 0:o.getBoundingClientRect();return M&&(t=Wt(t,{x:Math.floor(M.x-Pe.SafeBorderPadding),y:Math.floor(M.y-Pe.SafeBorderPadding),w:Math.floor(M.width+Pe.SafeBorderPadding*2),h:Math.floor(M.height+Pe.SafeBorderPadding*2)})),(i=this.vNodes)==null||i.setInfo(r,{rect:t,centerPos:a}),t;}}},{key:"drawEraserlines",value:function drawEraserlines(e,t){var r=e.group,n=e.eraserlines,i=e.pos,l=e.layer,o=l.parent;if(t)try{var f=(l.renderer.glRenderer||l.renderer.canvasRenderer).options.displayRatio,g=r.getBoundingClientRect(),c=g.width*f*l.worldScaling[0],m=g.height*f*l.worldScaling[1];var x=1;(c>this.maxImageWidth||m>this.maxImageHeight)&&(x=Math.min(this.maxImageWidth/c,this.maxImageHeight/m));var M=l.getAttribute("scale");M=[M[0]*x,M[1]*x];var S=l.parent.parent,P=l.getAttribute("translate"),_T28=this.createVmRenderNode("".concat(this.workId,"_bitMapLayer"),S,{offscreen:o.offscreen,width:o.width,height:o.height,contextType:"2d",autoRender:!1,bufferSize:500},M,P),_h26=r.cloneNode(!0);this.addEraserlines(_h26,n,i,!1),_T28.appendChild(_h26);var p=_T28.parent;p.render();var d=_T28.renderer.canvasRenderer,y=d.context;if(!y)return;var O=d.options.displayRatio,E=_h26.getBoundingClientRect(),w={x:E.x,y:E.y,w:E.width,h:E.height},B={x:0,y:0,w:S.width,h:S.height};if(sr(w,B)===ye.outside){xe(_h26,p),S.removeChild(p),this.isDelete=!0;return;}var b=ue(w);b.x=Math.floor(Math.max(w.x,0)),b.y=Math.floor(Math.max(w.y,0)),b.w=Math.min(w.x+w.w,S.width)-b.x,b.h=Math.min(w.y+w.h,S.height)-b.y;var W=this.getGroupRect(b,O),D=W.x,R=W.y,j=W.w,k=W.h;var J=y.getImageData(D,R,j,k);if(this.isTransparentRectByCanvas(J)){xe(_h26,p),S.removeChild(p),this.isDelete=!0,J=null;return;}xe(r,o);var st=this.createSpriteNode({imageData:J,safariRect:b,originRect:w,worldScaling:_T28.worldScaling});st&&r.append(st),xe(_h26,p),S.removeChild(p),o.deleteTexture(J),J=null;}catch(a){console.error("[BaseShapeTool] drawEraserlines error:",a);return;}}},{key:"createVmRenderNode",value:function createVmRenderNode(e,t,r,n,i){var l=r.width,o=r.height,a="bitMap-".concat(e),f=t.layer(a,r),g=new de({anchor:[0.5,0.5],pos:[l*0.5,o*0.5],size:[l,o],name:"viewport",id:e});return g.setAttribute("scale",n),g.setAttribute("translate",i),f.append(g),g;}},{key:"getGroupRect",value:function getGroupRect(e,t){var r=Math.floor(e.x*t),n=Math.floor(e.y*t),i=Math.floor(e.w*t),l=Math.floor(e.h*t);return{x:r,y:n,w:i,h:l};}},{key:"addEraserlines",value:function addEraserlines(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:!0;var _iterator13=_createForOfIteratorHelper(t),_step13;try{for(_iterator13.s();!(_step13=_iterator13.n()).done;){var i=_step13.value;var l=i.thickness,o=i.op;var _iterator14=_createForOfIteratorHelper(o),_step14;try{for(_iterator14.s();!(_step14=_iterator14.n()).done;){var a=_step14.value;var f=a.map(function(M,S){return S%2?M-r[1]:M-r[0];}),g=this.computEraserPoints(f,l),c=Ee(g,!0),m={pos:[0,0],d:c,fillColor:"rgba(0,0,0,1)"},x=new Ae(m);x.addEventListener("beforerender",function(_ref164){var M=_ref164.detail;var S=M.context;n?S.blendFuncSeparate(S.ZERO,S.ZERO,S.ZERO,S.ZERO):S.globalCompositeOperation="destination-out";}),x.addEventListener("afterrender",function(_ref165){var M=_ref165.detail;var S=M.context;n?S.blendFuncSeparate(S.SRC_ALPHA,S.ONE_MINUS_SRC_ALPHA,S.ONE,S.ONE_MINUS_SRC_ALPHA):S.globalCompositeOperation="source-over";}),e.append(x);}}catch(err){_iterator14.e(err);}finally{_iterator14.f();}}}catch(err){_iterator13.e(err);}finally{_iterator13.f();}}},{key:"isTransparentRectByCanvas",value:function isTransparentRectByCanvas(e){var t=!0;for(var r=0;r<e.data.length;r+=4)if(e.data[r+3]!==0){t=!1;break;}return t;}},{key:"createSpriteNode",value:function createSpriteNode(e){var t=e.imageData,r=e.worldScaling,n=e.safariRect,i=e.originRect;var l;if(typeof OffscreenCanvas=="function"){l=new OffscreenCanvas(t.width,t.height);var g=l.getContext("2d");g&&g.putImageData(t,0,0);}else if((typeof document==="undefined"?"undefined":_typeof(document))<"u"){l=document.createElement("canvas"),l.width=t.width,l.height=t.height;var _g3=l.getContext("2d");_g3&&_g3.putImageData(t,0,0);}if(!l)return console.warn("Failed to create imageEraserBitmap Sprite"),null;var o=[Math.floor(i.w/r[0]),Math.floor(i.h/r[1])],a=[Math.floor((n.x-i.x)/r[0]),Math.floor((n.y-i.y)/r[1]),Math.floor(n.w/r[0]),Math.floor(n.h/r[1])],f={name:"eraserTexture",anchor:[0.5,0.5],pos:[0,0],size:o,texture:l,textureRect:a};return new hi(f);}},{key:"computEraserPoints",value:function computEraserPoints(e,t){var r=Math.ceil(t/2);return e.length===2?this.computDot(e,r):this.computLine(e,r);}},{key:"computDot",value:function computDot(e,t){var r=new Dt(e[0],e[1]);return Dt.GetDotStroke(r,t,8);}},{key:"computLine",value:function computLine(e,t){var r=[],n=[];var i,l;for(var o=0;o<e.length;o+=2){var a=new Dt(e[o],e[o+1]);var f=void 0;if(o==e.length-2){var g=new Dt(e[o-2],e[o-1]);f=ot.Sub(a,g).uni(),i=a;}else{o===0&&(l=a);var _g4=new Dt(e[o+2],e[o+3]);f=ot.Sub(_g4,a).uni();}if(f){var _g5=ot.Per(f).mul(t);r.push(Dt.Sub(a,_g5)),n.push(Dt.Add(a,_g5));}}if(i&&l){var _o3=Dt.GetSemicircleStroke(i,r[r.length-1],-1,8),_a4=Dt.GetSemicircleStroke(l,n[0],-1,8);return r.concat(_o3,n.reverse(),_a4);}return[];}},{key:"replace",value:function replace(e,t,r){var _this61=this;var i;if(!t){r&&e.append(r);return;}var n=e.getElementsByName(t);if(n.length){var _iterator15=_createForOfIteratorHelper(n),_step15;try{for(_iterator15.s();!(_step15=_iterator15.n()).done;){var l=_step15.value;r?gm(r,l,e):(l.remove(),_me(l,e.parent));}}catch(err){_iterator15.e(err);}finally{_iterator15.f();}}else r&&e.append(r);this.fullLayer!==this.drawLayer&&(this.fullLayer===e?(i=this.drawLayer)==null||i.getElementsByName(t).forEach(function(o){var a;o.remove(),_me(o,(a=_this61.drawLayer)==null?void 0:a.parent);}):this.fullLayer.getElementsByName(t).forEach(function(o){o.remove(),_me(o,_this61.fullLayer.parent);}));}},{key:"removeDrawCountNodes",value:function removeDrawCountNodes(e,t){var r=[];e.getElementsByName(this.workId).forEach(function(n){n.id&&t&&Number(n.id)<t&&r.push(n);});for(var _i2=0,_r3=r;_i2<_r3.length;_i2++){var n=_r3[_i2];n.remove(),_me(n,e.parent);}}}],[{key:"updateNodeOpt",value:function updateNodeOpt(e){var h;var t=e.node,r=e.opt,n=e.vNodes,i=e.willSerializeData,l=e.targetNode,o=r.zIndex,a=r.translate,f=r.angle,g=r.originPoint,c=r.scenePoint,m=r.scale,x=r.pointMap,M=r.thickness;var S;var P=l&&ue(l)||n.get(t.name);if(!P)return;he(o)&&(t.setAttribute("zIndex",o),P.opt.zIndex=o);var T=t.parent;if(T){if(g&&m&&l){var p=[P.op[0],P.op[1]];mn(P.op,c,m,a);var d=[P.op[0],P.op[1]],y=[d[0]-p[0],d[1]-p[1]];if(P.centerPos=[P.centerPos[0]+y[0],P.centerPos[1]+y[1]],P.opt.translate=void 0,P.opt.scale=void 0,P.opt.eraserlines)for(var _i3=0,_Object$values=Object.values(P.opt.eraserlines);_i3<_Object$values.length;_i3++){var O=_Object$values[_i3];var E=O.op,w=O.thickness;O.thickness=w*Math.max(m[0],m[1]);for(var B=0;B<E.length;B++)vn(E[B],c,m,a);}}else if(a){if(t.setAttribute("translate",a),P.opt.translate=a,l){var _p6=[a[0]*T.worldScaling[0],a[1]*T.worldScaling[1]];S=cr(P.rect,_p6),P.rect=S;}else{var _p7=Pe.getRectFromLayer(T,t.name);P.rect=_p7||P.rect;}}else if(he(f))if(t.setAttribute("rotate",f),P.opt.rotate=f,l)S=ns(P.rect,f),P.rect=S;else{var _p8=Pe.getRectFromLayer(T,t.name);P.rect=_p8||P.rect;}if(x){var _p9=x.get(t.name);if(_p9)for(var _d11=0,_y9=0;_d11<P.op.length;_d11+=3,_y9++)P.op[_d11]=_p9[_y9][0],P.op[_d11+1]=_p9[_y9][1];}if(M&&(h=P==null?void 0:P.opt)!=null&&h.thickness&&(P.opt.thickness=M),i&&!(g&&m&&l)){if(a){var _p10=P.op.map(function(d,y){var O=y%3;return O===0?d+a[0]:O===1?d+a[1]:d;});if(P.op=_p10,P.centerPos=[P.centerPos[0]+a[0],P.centerPos[1]+a[1]],P!=null&&P.opt&&(P.opt.translate=void 0),P.opt.eraserlines)for(var _i4=0,_Object$values2=Object.values(P.opt.eraserlines);_i4<_Object$values2.length;_i4++){var _d12=_Object$values2[_i4];var _y10=_d12.op;for(var _O6=0;_O6<_y10.length;_O6++){var _E3=_y10[_O6].map(function(w,B){return B%2?w+a[1]:w+a[0];});_d12.op[_O6]=_E3;}}}else if(he(f)){var _p11=P.op;if(fm(_p11,P.centerPos,f),P.op=_p11,P!=null&&P.opt&&(P.opt.rotate=void 0),P.opt.eraserlines)for(var _i5=0,_Object$values3=Object.values(P.opt.eraserlines);_i5<_Object$values3.length;_i5++){var _d13=_Object$values3[_i5];var _y11=_d13.op;for(var _O7=0;_O7<_y11.length;_O7++)hm(_y11[_O7],P.centerPos,f);}}}P&&n.setInfo(t.name,P);}}},{key:"getCenterPos",value:function getCenterPos(e,t){var r=t.worldPosition,n=t.worldScaling;return[(e.x+e.w/2-r[0])/n[0],(e.y+e.h/2-r[1])/n[1]];}},{key:"getRectFromLayer",value:function getRectFromLayer(e,t){var r=e.getElementsByName(t)[0];if(r){var n=r.getBoundingClientRect();return{x:Math.floor(n.x-Pe.SafeBorderPadding),y:Math.floor(n.y-Pe.SafeBorderPadding),w:Math.floor(n.width+Pe.SafeBorderPadding*2),h:Math.floor(n.height+Pe.SafeBorderPadding*2)};}}},{key:"isWillRefresh",value:function isWillRefresh(e){var t=e.toolsType,r=e.opt,n=e.node,i=e.updateOpt,l=e.willSerializeData;return!!(l&&(i.angle||i.translate)||i.thickness&&r.thickness&&r.thickness!==i.thickness||i.strokeType&&r.strokeType&&r.strokeType!==i.strokeType||i.originPoint&&i.scenePoint&&i.scale||i.pointMap&&i.pointMap.has(n.name)||t===St.Text&&(i.fontSize||i.translate||i.textInfos&&i.textInfos.get(n.name))||t===St.Image&&(i.angle||i.translate||i.scale||i.strokeColor&&i.type===Zr.Iconify)||t===i.toolsType&&i.willRefresh||r.eraserlines&&r.eraserlines.length&&(i.strokeColor||i.fillColor));}}]);}();at(Pe,"SafeBorderPadding",10);var Mt=Pe;var ln=Object.freeze([Object.freeze({width:18,height:26}),Object.freeze({width:26,height:34}),Object.freeze({width:34,height:50}),Object.freeze({width:48,height:74})]);var cn={exports:{}};cn.exports;(function(u){var e=function(){var t=String.fromCharCode,r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-$",i={};function l(a,f){if(!i[a]){i[a]={};for(var g=0;g<a.length;g++)i[a][a.charAt(g)]=g;}return i[a][f];}var o={compressToBase64:function compressToBase64(a){if(a==null)return"";var f=o._compress(a,6,function(g){return r.charAt(g);});switch(f.length%4){default:case 0:return f;case 1:return f+"===";case 2:return f+"==";case 3:return f+"=";}},decompressFromBase64:function decompressFromBase64(a){return a==null?"":a==""?null:o._decompress(a.length,32,function(f){return l(r,a.charAt(f));});},compressToUTF16:function compressToUTF16(a){return a==null?"":o._compress(a,15,function(f){return t(f+32);})+" ";},decompressFromUTF16:function decompressFromUTF16(a){return a==null?"":a==""?null:o._decompress(a.length,16384,function(f){return a.charCodeAt(f)-32;});},//compress into uint8array (UCS-2 big endian format)
399
+ Rf(f,a)))&&o.push(f);return o;}var Oi=Bf,Wf=Object.prototype;function Ff(u){var e=u&&u.constructor,t=typeof e=="function"&&e.prototype||Wf;return u===t;}var tn=Ff;function Uf(u,e){return function(t){return u(e(t));};}var Mi=Uf,jf=Mi,Yf=jf(Object.keys,Object),Xf=Yf,zf=tn,$f=Xf,Gf=Object.prototype,Hf=Gf.hasOwnProperty;function kf(u){if(!zf(u))return $f(u);var e=[];for(var t in Object(u))Hf.call(u,t)&&t!="constructor"&&e.push(t);return e;}var Vf=kf,Kf=pi,Zf=Ci;function Jf(u){return u!=null&&Zf(u.length)&&!Kf(u);}var en=Jf,Qf=Oi,qf=Vf,_f=en;function th(u){return _f(u)?Qf(u):qf(u);}var rn=th,eh=Br,rh=rn;function nh(u,e){return u&&eh(e,rh(e),u);}var ih=nh;function sh(u){var e=[];if(u!=null)for(var t in Object(u))e.push(t);return e;}var oh=sh,ah=hr,lh=tn,ch=oh,fh=Object.prototype,hh=fh.hasOwnProperty;function uh(u){if(!ah(u))return ch(u);var e=lh(u),t=[];for(var r in u)r=="constructor"&&(e||!hh.call(u,r))||t.push(r);return t;}var dh=uh,ph=Oi,mh=dh,vh=en;function yh(u){return vh(u)?ph(u,!0):mh(u);}var nn=yh,gh=Br,Ph=nn;function xh(u,e){return u&&gh(e,Ph(e),u);}var Sh=xh,xr={exports:{}};xr.exports;(function(u,e){var t=Le,r=e&&!e.nodeType&&e,n=r&&!0&&u&&!u.nodeType&&u,i=n&&n.exports===r,l=i?t.Buffer:void 0,o=l?l.allocUnsafe:void 0;function a(f,g){if(g)return f.slice();var c=f.length,m=o?o(c):new f.constructor(c);return f.copy(m),m;}u.exports=a;})(xr,xr.exports);var Th=xr.exports;function Ch(u,e){var t=-1,r=u.length;for(e||(e=Array(r));++t<r;)e[t]=u[t];return e;}var Ih=Ch;function Oh(u,e){for(var t=-1,r=u==null?0:u.length,n=0,i=[];++t<r;){var l=u[t];e(l,t,u)&&(i[n++]=l);}return i;}var Ei=Oh;function Mh(){return[];}var Ai=Mh,Eh=Ei,Ah=Ai,Lh=Object.prototype,wh=Lh.propertyIsEnumerable,wn=Object.getOwnPropertySymbols,Rh=wn?function(u){return u==null?[]:(u=Object(u),Eh(wn(u),function(e){return wh.call(u,e);}));}:Ah,sn=Rh,Dh=Br,bh=sn;function Nh(u,e){return Dh(u,bh(u),e);}var Bh=Nh;function Wh(u,e){for(var t=-1,r=e.length,n=u.length;++t<r;)u[n+t]=e[t];return u;}var on=Wh,Fh=Mi,Uh=Fh(Object.getPrototypeOf,Object),Li=Uh,jh=on,Yh=Li,Xh=sn,zh=Ai,$h=Object.getOwnPropertySymbols,Gh=$h?function(u){for(var e=[];u;)jh(e,Xh(u)),u=Yh(u);return e;}:zh,wi=Gh,Hh=Br,kh=wi;function Vh(u,e){return Hh(u,kh(u),e);}var Kh=Vh,Zh=on,Jh=ur;function Qh(u,e,t){var r=e(u);return Jh(u)?r:Zh(r,t(u));}var Ri=Qh,qh=Ri,_h=sn,tu=rn;function eu(u){return qh(u,tu,_h);}var Di=eu,ru=Ri,nu=wi,iu=nn;function su(u){return ru(u,iu,nu);}var ou=su,au=Ue,lu=Le,cu=au(lu,"DataView"),fu=cu,hu=Ue,uu=Le,du=hu(uu,"Promise"),pu=du,mu=Ue,vu=Le,yu=mu(vu,"Set"),bi=yu,gu=Ue,Pu=Le,xu=gu(Pu,"WeakMap"),Su=xu,zr=fu,$r=Qr,Gr=pu,Hr=bi,kr=Su,Ni=Je,er=mi,Rn="[object Map]",Tu="[object Object]",Dn="[object Promise]",bn="[object Set]",Nn="[object WeakMap]",Bn="[object DataView]",Cu=er(zr),Iu=er($r),Ou=er(Gr),Mu=er(Hr),Eu=er(kr),Fe=Ni;(zr&&Fe(new zr(new ArrayBuffer(1)))!=Bn||$r&&Fe(new $r())!=Rn||Gr&&Fe(Gr.resolve())!=Dn||Hr&&Fe(new Hr())!=bn||kr&&Fe(new kr())!=Nn)&&(Fe=function Fe(u){var e=Ni(u),t=e==Tu?u.constructor:void 0,r=t?er(t):"";if(r)switch(r){case Cu:return Bn;case Iu:return Rn;case Ou:return Dn;case Mu:return bn;case Eu:return Nn;}return e;});var Fr=Fe,Au=Object.prototype,Lu=Au.hasOwnProperty;function wu(u){var e=u.length,t=new u.constructor(e);return e&&typeof u[0]=="string"&&Lu.call(u,"index")&&(t.index=u.index,t.input=u.input),t;}var Ru=wu,Du=Le,bu=Du.Uint8Array,Bi=bu,Wn=Bi;function Nu(u){var e=new u.constructor(u.byteLength);return new Wn(e).set(new Wn(u)),e;}var an=Nu,Bu=an;function Wu(u,e){var t=e?Bu(u.buffer):u.buffer;return new u.constructor(t,u.byteOffset,u.byteLength);}var Fu=Wu,Uu=/\w*$/;function ju(u){var e=new u.constructor(u.source,Uu.exec(u));return e.lastIndex=u.lastIndex,e;}var Yu=ju,Fn=fr,Un=Fn?Fn.prototype:void 0,jn=Un?Un.valueOf:void 0;function Xu(u){return jn?Object(jn.call(u)):{};}var zu=Xu,$u=an;function Gu(u,e){var t=e?$u(u.buffer):u.buffer;return new u.constructor(t,u.byteOffset,u.length);}var Hu=Gu,ku=an,Vu=Fu,Ku=Yu,Zu=zu,Ju=Hu,Qu="[object Boolean]",qu="[object Date]",_u="[object Map]",td="[object Number]",ed="[object RegExp]",rd="[object Set]",nd="[object String]",id="[object Symbol]",sd="[object ArrayBuffer]",od="[object DataView]",ad="[object Float32Array]",ld="[object Float64Array]",cd="[object Int8Array]",fd="[object Int16Array]",hd="[object Int32Array]",ud="[object Uint8Array]",dd="[object Uint8ClampedArray]",pd="[object Uint16Array]",md="[object Uint32Array]";function vd(u,e,t){var r=u.constructor;switch(e){case sd:return ku(u);case Qu:case qu:return new r(+u);case od:return Vu(u,t);case ad:case ld:case cd:case fd:case hd:case ud:case dd:case pd:case md:return Ju(u,t);case _u:return new r();case td:case nd:return new r(u);case ed:return Ku(u);case rd:return new r();case id:return Zu(u);}}var yd=vd,gd=hr,Yn=Object.create,Pd=/* @__PURE__ */function(){function u(){}return function(e){if(!gd(e))return{};if(Yn)return Yn(e);u.prototype=e;var t=new u();return u.prototype=void 0,t;};}(),xd=Pd,Sd=xd,Td=Li,Cd=tn;function Id(u){return typeof u.constructor=="function"&&!Cd(u)?Sd(Td(u)):{};}var Od=Id,Md=Fr,Ed=De,Ad="[object Map]";function Ld(u){return Ed(u)&&Md(u)==Ad;}var wd=Ld,Rd=wd,Dd=Wr,Xn=_r,zn=Xn&&Xn.isMap,bd=zn?Dd(zn):Rd,Nd=bd,Bd=Fr,Wd=De,Fd="[object Set]";function Ud(u){return Wd(u)&&Bd(u)==Fd;}var jd=Ud,Yd=jd,Xd=Wr,$n=_r,Gn=$n&&$n.isSet,zd=Gn?Xd(Gn):Yd,Wi=zd,$d=/* @__PURE__ */Ne(Wi),Gd=yi,Hd=mc,kd=xi,Vd=ih,Kd=Sh,Zd=Th,Jd=Ih,Qd=Bh,qd=Kh,_d=Di,tp=ou,ep=Fr,rp=Ru,np=yd,ip=Od,sp=ur,op=qr,ap=Nd,lp=hr,cp=Wi,fp=rn,hp=nn,up=1,dp=2,pp=4,Fi="[object Arguments]",mp="[object Array]",vp="[object Boolean]",yp="[object Date]",gp="[object Error]",Ui="[object Function]",Pp="[object GeneratorFunction]",xp="[object Map]",Sp="[object Number]",ji="[object Object]",Tp="[object RegExp]",Cp="[object Set]",Ip="[object String]",Op="[object Symbol]",Mp="[object WeakMap]",Ep="[object ArrayBuffer]",Ap="[object DataView]",Lp="[object Float32Array]",wp="[object Float64Array]",Rp="[object Int8Array]",Dp="[object Int16Array]",bp="[object Int32Array]",Np="[object Uint8Array]",Bp="[object Uint8ClampedArray]",Wp="[object Uint16Array]",Fp="[object Uint32Array]",re={};re[Fi]=re[mp]=re[Ep]=re[Ap]=re[vp]=re[yp]=re[Lp]=re[wp]=re[Rp]=re[Dp]=re[bp]=re[xp]=re[Sp]=re[ji]=re[Tp]=re[Cp]=re[Ip]=re[Op]=re[Np]=re[Bp]=re[Wp]=re[Fp]=!0;re[gp]=re[Ui]=re[Mp]=!1;function yr(u,e,t,r,n,i){var l,o=e&up,a=e&dp,f=e&pp;if(t&&(l=n?t(u,r,n,i):t(u)),l!==void 0)return l;if(!lp(u))return u;var g=sp(u);if(g){if(l=rp(u),!o)return Jd(u,l);}else{var c=ep(u),m=c==Ui||c==Pp;if(op(u))return Zd(u,o);if(c==ji||c==Fi||m&&!n){if(l=a||m?{}:ip(u),!o)return a?qd(u,Kd(l,u)):Qd(u,Vd(l,u));}else{if(!re[c])return n?u:{};l=np(u,c,o);}}i||(i=new Gd());var x=i.get(u);if(x)return x;i.set(u,l),cp(u)?u.forEach(function(P){l.add(yr(P,e,t,P,u,i));}):ap(u)&&u.forEach(function(P,T){l.set(T,yr(P,e,t,T,u,i));});var M=f?a?tp:_d:a?hp:fp,S=g?void 0:M(u);return Hd(S||u,function(P,T){S&&(T=P,P=u[T]),kd(l,T,yr(P,e,t,T,u,i));}),l;}var Up=yr,jp=Up,Yp=1,Xp=4;function zp(u){return jp(u,Yp|Xp);}var $p=zp,ue=/* @__PURE__ */Ne($p);var Yi="1.1.18",Gp="@netless/appliance-plugin";if((typeof window==="undefined"?"undefined":_typeof(window))<"u"){var u=window.__netlessUA||"";u+=" ".concat(Gp,"@").concat(Yi),window.__netlessUA=u;}var Se={syncOpt:{interval:300},cdn:{subWorkerUrl:"https://cdn.jsdelivr.net/npm/@netless/appliance-plugin@latest/dist/subWorker.js",fullWorkerUrl:"https://cdn.jsdelivr.net/npm/@netless/appliance-plugin@latest/dist/fullWorker.js"},cursor:{expirationTime:5e3},bufferSize:{full:2e4,sub:600},bezier:{maxDrawCount:1/0,combineUnitTime:300},pencilEraser:{useBitMap:!0,maxImageWidth:1920,maxImageHeight:1920},strokeWidth:{min:1,max:10},textEditor:{showFloatBar:!0,canSelectorSwitch:!0,rightBoundBreak:!1}};function Ee(u){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:!0;var t=u.length;if(t<2)return"";var r=u[0],n=u[1];if(t===2)return"M".concat(ze(r),"L").concat(ze(n));var i="";for(var l=2,o=t-1;l<o;l++)r=u[l],n=u[l+1],i+=$e(r,n);return e?"M".concat($e(u[0],u[1]),"Q").concat(ze(u[1])).concat($e(u[1],u[2]),"T").concat(i).concat($e(u[t-1],u[0])).concat($e(u[0],u[1]),"Z"):"M".concat(ze(u[0]),"Q").concat(ze(u[1])).concat($e(u[1],u[2])).concat(u.length>3?"T":"").concat(i,"L").concat(ze(u[t-1]));}var Pe=/*#__PURE__*/function(){function Pe(e){_classCallCheck(this,Pe);at(this,"maxImageWidth",Se.pencilEraser.maxImageWidth);at(this,"maxImageHeight",Se.pencilEraser.maxImageHeight);at(this,"syncUnitTime",Se.syncOpt.interval);at(this,"vNodes");at(this,"drawLayer");at(this,"fullLayer");at(this,"workId");at(this,"isDelete",!1);var t=e.vNodes,r=e.fullLayer,n=e.drawLayer,i=e.workId,l=e.toolsOpt;this.vNodes=t,this.fullLayer=r,this.drawLayer=n,this.workId=i,this.syncUnitTime=l.syncUnitTime||this.syncUnitTime;}return _createClass(Pe,[{key:"baseConsumeResult",get:function get(){return{workId:this.workId,toolsType:this.toolsType,opt:this.workOptions};}},{key:"filterSamePoints",value:function filterSamePoints(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:0.01;return e.reduce(function(r,n){var i=r[r.length-1];return(n&&!i||n&&i&&!n.isNear(i,t))&&r.push(n),r;},[]);}/** 设置工作id */},{key:"setWorkId",value:function setWorkId(e){this.workId=e;}},{key:"getWorkId",value:function getWorkId(){return this.workId;}/** 获取工作选项配置 */},{key:"getWorkOptions",value:function getWorkOptions(){return this.workOptions;}/** 设置工作选项配置 */},{key:"setWorkOptions",value:function setWorkOptions(e){var n,i,l;this.workOptions=e,this.syncUnitTime=e.syncUnitTime||this.syncUnitTime;var t=(n=this.workId)==null?void 0:n.toString(),r=t&&((i=this.vNodes)==null?void 0:i.get(t))||void 0;t&&r&&(r.opt=e,(l=this.vNodes)==null||l.setInfo(t,r));}/** 更新服务端同步配置,返回绘制结果 */},{key:"updataOptService",value:function updataOptService(e){var n,i;var t;var r=(n=this.workId)==null?void 0:n.toString();if(r&&e){var l=this.fullLayer.getElementsByName(r)||this.drawLayer&&this.drawLayer.getElementsByName(r)||[];if(l.length!==1)return;var o=l[0],a=e.pos,f=e.zIndex,g=e.scale,c=e.angle,m=e.translate,x={};he(f)&&(x.zIndex=f),a&&(x.pos=[a[0],a[1]]),g&&(x.scale=g),c&&(x.rotate=c),m&&(x.translate=m),o.attr(x);var M=o==null?void 0:o.getBoundingClientRect();return M&&(t=Wt(t,{x:Math.floor(M.x-Pe.SafeBorderPadding),y:Math.floor(M.y-Pe.SafeBorderPadding),w:Math.floor(M.width+Pe.SafeBorderPadding*2),h:Math.floor(M.height+Pe.SafeBorderPadding*2)})),(i=this.vNodes)==null||i.setInfo(r,{rect:t,centerPos:a}),t;}}},{key:"drawEraserlines",value:function drawEraserlines(e,t){var r=e.group,n=e.eraserlines,i=e.pos,l=e.layer,o=l.parent;if(t)try{var f=(l.renderer.glRenderer||l.renderer.canvasRenderer).options.displayRatio,g=r.getBoundingClientRect(),c=g.width*f*l.worldScaling[0],m=g.height*f*l.worldScaling[1];var x=1;(c>this.maxImageWidth||m>this.maxImageHeight)&&(x=Math.min(this.maxImageWidth/c,this.maxImageHeight/m));var M=l.getAttribute("scale");M=[M[0]*x,M[1]*x];var S=l.parent.parent,P=l.getAttribute("translate"),_T28=this.createVmRenderNode("".concat(this.workId,"_bitMapLayer"),S,{offscreen:o.offscreen,width:o.width,height:o.height,contextType:"2d",autoRender:!1,bufferSize:500},M,P),_h26=r.cloneNode(!0);this.addEraserlines(_h26,n,i,!1),_T28.appendChild(_h26);var p=_T28.parent;p.render();var d=_T28.renderer.canvasRenderer,y=d.context;if(!y)return;var O=d.options.displayRatio,E=_h26.getBoundingClientRect(),w={x:E.x,y:E.y,w:E.width,h:E.height},B={x:0,y:0,w:S.width,h:S.height};if(sr(w,B)===ye.outside){xe(_h26,p),S.removeChild(p),this.isDelete=!0;return;}var b=ue(w);b.x=Math.floor(Math.max(w.x,0)),b.y=Math.floor(Math.max(w.y,0)),b.w=Math.min(w.x+w.w,S.width)-b.x,b.h=Math.min(w.y+w.h,S.height)-b.y;var W=this.getGroupRect(b,O),D=W.x,R=W.y,j=W.w,k=W.h;var J=y.getImageData(D,R,j,k);if(this.isTransparentRectByCanvas(J)){xe(_h26,p),S.removeChild(p),this.isDelete=!0,J=null;return;}xe(r,o);var st=this.createSpriteNode({imageData:J,safariRect:b,originRect:w,worldScaling:_T28.worldScaling});st&&r.append(st),xe(_h26,p),S.removeChild(p),o.deleteTexture(J),J=null;}catch(a){console.error("[BaseShapeTool] drawEraserlines error:",a);return;}}},{key:"createVmRenderNode",value:function createVmRenderNode(e,t,r,n,i){var l=r.width,o=r.height,a="bitMap-".concat(e),f=t.layer(a,r),g=new de({anchor:[0.5,0.5],pos:[l*0.5,o*0.5],size:[l,o],name:"viewport",id:e});return g.setAttribute("scale",n),g.setAttribute("translate",i),f.append(g),g;}},{key:"getGroupRect",value:function getGroupRect(e,t){var r=Math.floor(e.x*t),n=Math.floor(e.y*t),i=Math.floor(e.w*t),l=Math.floor(e.h*t);return{x:r,y:n,w:i,h:l};}},{key:"addEraserlines",value:function addEraserlines(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:!0;var _iterator13=_createForOfIteratorHelper(t),_step13;try{for(_iterator13.s();!(_step13=_iterator13.n()).done;){var i=_step13.value;var l=i.thickness,o=i.op;var _iterator14=_createForOfIteratorHelper(o),_step14;try{for(_iterator14.s();!(_step14=_iterator14.n()).done;){var a=_step14.value;var f=a.map(function(M,S){return S%2?M-r[1]:M-r[0];}),g=this.computEraserPoints(f,l),c=Ee(g,!0),m={pos:[0,0],d:c,fillColor:"rgba(0,0,0,1)"},x=new Ae(m);x.addEventListener("beforerender",function(_ref164){var M=_ref164.detail;var S=M.context;n?S.blendFuncSeparate(S.ZERO,S.ZERO,S.ZERO,S.ZERO):S.globalCompositeOperation="destination-out";}),x.addEventListener("afterrender",function(_ref165){var M=_ref165.detail;var S=M.context;n?S.blendFuncSeparate(S.SRC_ALPHA,S.ONE_MINUS_SRC_ALPHA,S.ONE,S.ONE_MINUS_SRC_ALPHA):S.globalCompositeOperation="source-over";}),e.append(x);}}catch(err){_iterator14.e(err);}finally{_iterator14.f();}}}catch(err){_iterator13.e(err);}finally{_iterator13.f();}}},{key:"isTransparentRectByCanvas",value:function isTransparentRectByCanvas(e){var t=!0;for(var r=0;r<e.data.length;r+=4)if(e.data[r+3]!==0){t=!1;break;}return t;}},{key:"createSpriteNode",value:function createSpriteNode(e){var t=e.imageData,r=e.worldScaling,n=e.safariRect,i=e.originRect;var l;if(typeof OffscreenCanvas=="function"){l=new OffscreenCanvas(t.width,t.height);var g=l.getContext("2d");g&&g.putImageData(t,0,0);}else if((typeof document==="undefined"?"undefined":_typeof(document))<"u"){l=document.createElement("canvas"),l.width=t.width,l.height=t.height;var _g3=l.getContext("2d");_g3&&_g3.putImageData(t,0,0);}if(!l)return console.warn("Failed to create imageEraserBitmap Sprite"),null;var o=[Math.floor(i.w/r[0]),Math.floor(i.h/r[1])],a=[Math.floor((n.x-i.x)/r[0]),Math.floor((n.y-i.y)/r[1]),Math.floor(n.w/r[0]),Math.floor(n.h/r[1])],f={name:"eraserTexture",anchor:[0.5,0.5],pos:[0,0],size:o,texture:l,textureRect:a};return new hi(f);}},{key:"computEraserPoints",value:function computEraserPoints(e,t){var r=Math.ceil(t/2);return e.length===2?this.computDot(e,r):this.computLine(e,r);}},{key:"computDot",value:function computDot(e,t){var r=new Dt(e[0],e[1]);return Dt.GetDotStroke(r,t,8);}},{key:"computLine",value:function computLine(e,t){var r=[],n=[];var i,l;for(var o=0;o<e.length;o+=2){var a=new Dt(e[o],e[o+1]);var f=void 0;if(o==e.length-2){var g=new Dt(e[o-2],e[o-1]);f=ot.Sub(a,g).uni(),i=a;}else{o===0&&(l=a);var _g4=new Dt(e[o+2],e[o+3]);f=ot.Sub(_g4,a).uni();}if(f){var _g5=ot.Per(f).mul(t);r.push(Dt.Sub(a,_g5)),n.push(Dt.Add(a,_g5));}}if(i&&l){var _o3=Dt.GetSemicircleStroke(i,r[r.length-1],-1,8),_a4=Dt.GetSemicircleStroke(l,n[0],-1,8);return r.concat(_o3,n.reverse(),_a4);}return[];}},{key:"replace",value:function replace(e,t,r){var _this61=this;var i;if(!t){r&&e.append(r);return;}var n=e.getElementsByName(t);if(n.length){var _iterator15=_createForOfIteratorHelper(n),_step15;try{for(_iterator15.s();!(_step15=_iterator15.n()).done;){var l=_step15.value;r?gm(r,l,e):(l.remove(),_me(l,e.parent));}}catch(err){_iterator15.e(err);}finally{_iterator15.f();}}else r&&e.append(r);this.fullLayer!==this.drawLayer&&(this.fullLayer===e?(i=this.drawLayer)==null||i.getElementsByName(t).forEach(function(o){var a;o.remove(),_me(o,(a=_this61.drawLayer)==null?void 0:a.parent);}):this.fullLayer.getElementsByName(t).forEach(function(o){o.remove(),_me(o,_this61.fullLayer.parent);}));}},{key:"removeDrawCountNodes",value:function removeDrawCountNodes(e,t){var r=[];e.getElementsByName(this.workId).forEach(function(n){n.id&&t&&Number(n.id)<t&&r.push(n);});for(var _i2=0,_r3=r;_i2<_r3.length;_i2++){var n=_r3[_i2];n.remove(),_me(n,e.parent);}}}],[{key:"updateNodeOpt",value:function updateNodeOpt(e){var h;var t=e.node,r=e.opt,n=e.vNodes,i=e.willSerializeData,l=e.targetNode,o=r.zIndex,a=r.translate,f=r.angle,g=r.originPoint,c=r.scenePoint,m=r.scale,x=r.pointMap,M=r.thickness;var S;var P=l&&ue(l)||n.get(t.name);if(!P)return;he(o)&&(t.setAttribute("zIndex",o),P.opt.zIndex=o);var T=t.parent;if(T){if(g&&m&&l){var p=[P.op[0],P.op[1]];mn(P.op,c,m,a);var d=[P.op[0],P.op[1]],y=[d[0]-p[0],d[1]-p[1]];if(P.centerPos=[P.centerPos[0]+y[0],P.centerPos[1]+y[1]],P.opt.translate=void 0,P.opt.scale=void 0,P.opt.eraserlines)for(var _i3=0,_Object$values=Object.values(P.opt.eraserlines);_i3<_Object$values.length;_i3++){var O=_Object$values[_i3];var E=O.op,w=O.thickness;O.thickness=w*Math.max(m[0],m[1]);for(var B=0;B<E.length;B++)vn(E[B],c,m,a);}}else if(a){if(t.setAttribute("translate",a),P.opt.translate=a,l){var _p6=[a[0]*T.worldScaling[0],a[1]*T.worldScaling[1]];S=cr(P.rect,_p6),P.rect=S;}else{var _p7=Pe.getRectFromLayer(T,t.name);P.rect=_p7||P.rect;}}else if(he(f))if(t.setAttribute("rotate",f),P.opt.rotate=f,l)S=ns(P.rect,f),P.rect=S;else{var _p8=Pe.getRectFromLayer(T,t.name);P.rect=_p8||P.rect;}if(x){var _p9=x.get(t.name);if(_p9)for(var _d11=0,_y9=0;_d11<P.op.length;_d11+=3,_y9++)P.op[_d11]=_p9[_y9][0],P.op[_d11+1]=_p9[_y9][1];}if(M&&(h=P==null?void 0:P.opt)!=null&&h.thickness&&(P.opt.thickness=M),i&&!(g&&m&&l)){if(a){var _p10=P.op.map(function(d,y){var O=y%3;return O===0?d+a[0]:O===1?d+a[1]:d;});if(P.op=_p10,P.centerPos=[P.centerPos[0]+a[0],P.centerPos[1]+a[1]],P!=null&&P.opt&&(P.opt.translate=void 0),P.opt.eraserlines)for(var _i4=0,_Object$values2=Object.values(P.opt.eraserlines);_i4<_Object$values2.length;_i4++){var _d12=_Object$values2[_i4];var _y10=_d12.op;for(var _O6=0;_O6<_y10.length;_O6++){var _E3=_y10[_O6].map(function(w,B){return B%2?w+a[1]:w+a[0];});_d12.op[_O6]=_E3;}}}else if(he(f)){var _p11=P.op;if(fm(_p11,P.centerPos,f),P.op=_p11,P!=null&&P.opt&&(P.opt.rotate=void 0),P.opt.eraserlines)for(var _i5=0,_Object$values3=Object.values(P.opt.eraserlines);_i5<_Object$values3.length;_i5++){var _d13=_Object$values3[_i5];var _y11=_d13.op;for(var _O7=0;_O7<_y11.length;_O7++)hm(_y11[_O7],P.centerPos,f);}}}P&&n.setInfo(t.name,P);}}},{key:"getCenterPos",value:function getCenterPos(e,t){var r=t.worldPosition,n=t.worldScaling;return[(e.x+e.w/2-r[0])/n[0],(e.y+e.h/2-r[1])/n[1]];}},{key:"getRectFromLayer",value:function getRectFromLayer(e,t){var r=e.getElementsByName(t)[0];if(r){var n=r.getBoundingClientRect();return{x:Math.floor(n.x-Pe.SafeBorderPadding),y:Math.floor(n.y-Pe.SafeBorderPadding),w:Math.floor(n.width+Pe.SafeBorderPadding*2),h:Math.floor(n.height+Pe.SafeBorderPadding*2)};}}},{key:"isWillRefresh",value:function isWillRefresh(e){var t=e.toolsType,r=e.opt,n=e.node,i=e.updateOpt,l=e.willSerializeData;return!!(l&&(i.angle||i.translate)||i.thickness&&r.thickness&&r.thickness!==i.thickness||i.strokeType&&r.strokeType&&r.strokeType!==i.strokeType||i.originPoint&&i.scenePoint&&i.scale||i.pointMap&&i.pointMap.has(n.name)||t===St.Text&&(i.fontSize||i.translate||i.textInfos&&i.textInfos.get(n.name))||t===St.Image&&(i.angle||i.translate||i.scale||i.strokeColor&&i.type===Zr.Iconify)||t===i.toolsType&&i.willRefresh||r.eraserlines&&r.eraserlines.length&&(i.strokeColor||i.fillColor));}}]);}();at(Pe,"SafeBorderPadding",10);var Mt=Pe;var ln=Object.freeze([Object.freeze({width:18,height:26}),Object.freeze({width:26,height:34}),Object.freeze({width:34,height:50}),Object.freeze({width:48,height:74})]);var cn={exports:{}};cn.exports;(function(u){var e=function(){var t=String.fromCharCode,r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-$",i={};function l(a,f){if(!i[a]){i[a]={};for(var g=0;g<a.length;g++)i[a][a.charAt(g)]=g;}return i[a][f];}var o={compressToBase64:function compressToBase64(a){if(a==null)return"";var f=o._compress(a,6,function(g){return r.charAt(g);});switch(f.length%4){default:case 0:return f;case 1:return f+"===";case 2:return f+"==";case 3:return f+"=";}},decompressFromBase64:function decompressFromBase64(a){return a==null?"":a==""?null:o._decompress(a.length,32,function(f){return l(r,a.charAt(f));});},compressToUTF16:function compressToUTF16(a){return a==null?"":o._compress(a,15,function(f){return t(f+32);})+" ";},decompressFromUTF16:function decompressFromUTF16(a){return a==null?"":a==""?null:o._decompress(a.length,16384,function(f){return a.charCodeAt(f)-32;});},//compress into uint8array (UCS-2 big endian format)
400
400
  compressToUint8Array:function compressToUint8Array(a){for(var f=o.compress(a),g=new Uint8Array(f.length*2),c=0,m=f.length;c<m;c++){var x=f.charCodeAt(c);g[c*2]=x>>>8,g[c*2+1]=x%256;}return g;},//decompress from uint8array (UCS-2 big endian format)
401
401
  decompressFromUint8Array:function decompressFromUint8Array(a){if(a==null)return o.decompress(a);for(var f=new Array(a.length/2),g=0,c=f.length;g<c;g++)f[g]=a[g*2]*256+a[g*2+1];var m=[];return f.forEach(function(x){m.push(t(x));}),o.decompress(m.join(""));},//compress into a string that is already URI encoded
402
402
  compressToEncodedURIComponent:function compressToEncodedURIComponent(a){return a==null?"":o._compress(a,6,function(f){return n.charAt(f);});},//decompress from an output of compressToEncodedURIComponent
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@netless/appliance-plugin",
3
- "version": "1.1.18-beta.1",
3
+ "version": "1.1.18",
4
4
  "files": [
5
5
  "dist",
6
6
  "cdn"