@netless/appliance-plugin 1.1.11 → 1.1.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cdn/cdn.js +1 -1
- package/cdn/{fullWorker-CnB3KR.js → fullWorker-gIfxem.js} +111 -111
- package/cdn/{subWorker-1E_izA.js → subWorker-BA8EkW.js} +111 -111
- package/dist/appliance-plugin.js +1 -1
- package/dist/appliance-plugin.mjs +1 -1
- package/dist/core/mainEngine.d.ts +8 -0
- package/dist/core/mainThread/subLocalThread.d.ts +1 -2
- package/dist/core/tools/arrow.d.ts +1 -1
- package/dist/core/tools/ellipse.d.ts +1 -1
- package/dist/core/tools/pencil.d.ts +1 -1
- package/dist/core/tools/polygon.d.ts +1 -1
- package/dist/core/tools/rectangle.d.ts +1 -1
- package/dist/core/tools/speechBalloon.d.ts +1 -1
- package/dist/core/tools/star.d.ts +1 -1
- package/dist/core/tools/straight.d.ts +1 -1
- package/dist/core/types.d.ts +4 -0
- package/dist/core/vNodeManager.d.ts +5 -1
- package/dist/core/worker/fullWorkerLocal.d.ts +1 -0
- package/dist/fullWorker.js +111 -111
- package/dist/{index-Bd_LdZxD.mjs → index-0fBM84zK.mjs} +1987 -1914
- package/dist/{index-Db4VURLT.mjs → index-BbDR836g.mjs} +644 -618
- package/dist/index-BwLQzsnp.js +1 -0
- package/dist/index-Wi09G9p1.js +1 -0
- package/dist/plugin/baseApplianceManager.d.ts +3 -0
- package/dist/plugin/types.d.ts +2 -1
- package/dist/subWorker.js +111 -111
- package/package.json +1 -1
- package/dist/index-8E5yX5Xn.js +0 -1
- package/dist/index-qS7tU8QD.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";var F=Object.defineProperty;var B=(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)=>B(v,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./index-Wi09G9p1.js"),O=require("spritejs"),L=require("lodash");require("lineclip");require("white-web-sdk");require("react-dom");require("react");require("eventemitter2");class U{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",o.DefaultAppliancePluginOptions.syncOpt.interval);this.vNodes=t.vNodes,this.thread=t.thread}createLocalWork(t){const{workId:e,opt:s,toolsType:r}=t;if(e&&s){const a=e.toString();!this.getToolsOpt()&&r&&this.setToolsOpt({toolsType:r,toolsOpt:s}),this.setWorkOptions(a,s)}}getLocalWorkShape(t){return this.localWorkShapes.get(t)}createLocalWorkShape(t,e){if(t&&this.tmpOpt){const s={toolsType:this.tmpOpt.toolsType,toolsOpt:e||this.tmpOpt.toolsOpt},r=this.createWorkShapeNode({...s,workId:t});return r&&this.localWorkShapes.set(t,{node:r,toolsType:r.toolsType,workState:o.EvevtWorkState.Start}),r}}canUseTopLayer(t){return t===o.EToolsKey.LaserPen}destroy(){this.clearAll()}clearAll(){this.thread.topLayer.children.length&&(this.thread.topLayer.parent.children.forEach(t=>{t.name!=="viewport"&&t.remove()}),this.thread.serviceLayer.removeAllChildren()),this.serviceWorkShapes.clear(),this.localWorkShapes.clear()}consumeDraw(t){const{workId:e,dataType:s}=t;if(s===o.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=o.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===o.EToolsKey.LaserPen)return o.getShapeInstance({...t,vNodes:this.vNodes,fullLayer:this.thread.topLayer,drawLayer:this.thread.topLayer})}setNodeKey(t,e,s,r){return e.toolsType=s,e.node=this.createWorkShapeNode({workId:t,toolsType:s,toolsOpt:r}),e}activeServiceWorkShape(t){var y,d;const{workId:e,opt:s,toolsType:r,type:a,updateNodeOpt:i,ops:n,op:c}=t;if(!e)return;const l=e.toString(),p=(y=this.vNodes.get(l))==null?void 0:y.rect;if(!((d=this.serviceWorkShapes)!=null&&d.has(l))){let k={toolsType:r,animationWorkData:c||[],animationIndex:0,type:a,updateNodeOpt:i,ops:n,oldRect:p};r&&s&&(k=this.setNodeKey(l,k,r,s)),this.serviceWorkShapes.set(l,k)}const h=this.serviceWorkShapes.get(l);a&&(h.type=a),n&&(h.animationWorkData=o.transformToNormalData(n),h.ops=n),i&&(h.updateNodeOpt=i),c&&(h.animationWorkData=c),h.node&&h.node.getWorkId()!==l&&h.node.setWorkId(l),p&&(h.oldRect=p),r&&s&&(h.toolsType!==r&&r&&s&&this.setNodeKey(l,h,r,s),h.node&&h.node.setWorkOptions(s))}computNextAnimationIndex(t,e){var a;const s=((a=t.node)==null?void 0:a.syncUnitTime)||this.syncUnitTime,r=Math.floor((t.animationWorkData||[]).slice(t.animationIndex).length*32/e/s)*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,s=[];for(const[c,l]of this.serviceWorkShapes.entries())switch(l.toolsType){case o.EToolsKey.LaserPen:{const h=this.computNextAnimationIndex(l,8),y=Math.max(0,l.animationIndex||0),d=(l.animationWorkData||[]).slice(y,h);if((l.animationIndex||0)<h&&((r=l.node)==null||r.consumeService({op:d,isFullWork:!1}),l.animationIndex=h,d.length&&e.set(c,{workState:y===0?o.EvevtWorkState.Start:h===((a=l.animationWorkData)==null?void 0:a.length)?o.EvevtWorkState.Done:o.EvevtWorkState.Doing,op:d.slice(-2)})),l.isDel){(i=l.node)==null||i.clearTmpPoints(),this.serviceWorkShapes.delete(c);break}l.ops&&l.animationIndex===((n=l.animationWorkData)==null?void 0:n.length)&&!l.isDel&&(this.thread.topLayer.getElementsByName(c.toString())[0]||(l.isDel=!0,this.serviceWorkShapes.set(c,l))),t=!0;break}}for(const[c,l]of this.localWorkShapes.entries()){const{result:p,toolsType:h,isDel:y,workState:d}=l;switch(h){case o.EToolsKey.LaserPen:{if(y){l.node.clearTmpPoints(),this.localWorkShapes.delete(c),s.push({removeIds:[c.toString()],type:o.EPostMessageType.RemoveNode});break}p&&((p.op||p.ops)&&s.push(p),l.result=void 0),!this.thread.topLayer.getElementsByName(c.toString())[0]&&d===o.EvevtWorkState.Done&&(l.isDel=!0,this.localWorkShapes.set(c,l)),t=!0;break}}}t&&this.runAnimation(),e.size&&e.forEach((c,l)=>{s.push({type:o.EPostMessageType.Cursor,uid:l.split(o.Storage_Splitter)[0],op:c.op,workState:c.workState,viewId:this.thread.viewId})}),s.length&&this.thread.post({sp:s})}runAnimation(){this.animationId||(this.animationId=requestAnimationFrame(this.animationDraw.bind(this)))}setWorkOptions(t,e){var r;let s=(r=this.localWorkShapes.get(t))==null?void 0:r.node;if(!s&&this.tmpOpt){const{toolsType:a}=this.tmpOpt;this.tmpOpt.toolsOpt=e,s=this.createWorkShapeNode({workId:t,toolsType:a,toolsOpt:e}),s&&this.localWorkShapes.set(t,{node:s,toolsType:a,workState:o.EvevtWorkState.Start}),this.setToolsOpt(this.tmpOpt)}e!=null&&e.syncUnitTime||(e.syncUnitTime=this.syncUnitTime),s&&s.setWorkOptions(e)}consumeDrawAll(t){const{workId:e,dataType:s}=t;if(s===o.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=o.EvevtWorkState.Done,r&&this.localWorkShapes.set(r,a)}this.runAnimation()}}class _{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",o.DefaultAppliancePluginOptions.syncOpt.interval);u(this,"drawCount",0);u(this,"drawWorkActiveId");u(this,"consumeCount",0);u(this,"batchEraserCombine",o.throttle(()=>{this.updateBatchEraserCombineNode(this.batchEraserWorks,this.batchEraserRemoveNodes),this.batchEraserWorks.clear(),this.batchEraserRemoveNodes.clear()},100,{leading:!1}));this.vNodes=t.vNodes,this.thread=t.thread}async loadImageBitMap(t){return await this.thread.loadImageBitMap(t)}createLocalWork(t){const{workId:e,opt:s,toolsType:r}=t;if(e&&s){const a=e.toString();!this.getToolsOpt()&&r&&this.setToolsOpt({toolsType:r,toolsOpt:s}),this.setWorkOptions(a,s)}}async updateSelector(t){var y;const e=this.workShapes.get(o.Storage_Selector_key);if(!((y=e==null?void 0:e.selectIds)!=null&&y.length))return;const{callback:s,...r}=t,{updateSelectorOpt:a,willSerializeData:i}=r,n=await(e==null?void 0:e.updateSelector({updateSelectorOpt:a,selectIds:L.cloneDeep(e.selectIds),vNodes:this.vNodes,willSerializeData:i,worker:this})),c=new Map;let l;n!=null&&n.selectIds&&(l=L.xor(e.selectIds,n.selectIds),n.selectIds.forEach(d=>{const k=this.vNodes.get(d);if(k){const{toolsType:m,op:S,opt:T}=k;c.set(d,{opt:T,toolsType:m,ops:(S==null?void 0:S.length)&&o.transformToSerializableData(S)||void 0})}}),e.selectIds=n.selectIds);const p=[],h=s&&s({res:n,workShapeNode:e,param:r,postData:{sp:p},newServiceStore:c})||{sp:p};l&&h.sp.push({type:o.EPostMessageType.RemoveNode,removeIds:l,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()}),this.thread.localLayer.removeAllChildren()),this.workShapes.get(o.Storage_Selector_key)){const e=[];e.push({type:o.EPostMessageType.Select,dataType:o.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:s,dataType:r}=t;if(e!=null&&e.length){let a;for(const i of this.vNodes.curNodeMap.values()){const{rect:n,name:c,toolsType:l,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(l===o.EToolsKey.Text&&o.isIntersectForPoint([h,y],n)&&p.workState===o.EvevtWorkState.Done){a=c;break}}a&&(await this.blurSelector({viewId:s,msgType:o.EPostMessageType.Select,dataType:r,isSync:!0}),this.thread.post({sp:[{type:o.EPostMessageType.GetTextActive,toolsType:o.EToolsKey.Text,workId:a}]}))}}cursorHover(t){const{opt:e,toolsType:s,point:r}=t,a=this.setFullWork({workId:o.Cursor_Hover_Id,toolsType:s,opt:e});a&&r&&a.cursorHover(r)}updateFullSelectWork(t){var r,a,i,n,c;const e=this.workShapes.get(o.Storage_Selector_key),{selectIds:s}=t;if(!(s!=null&&s.length)){this.blurSelector(t);return}if(!e){const l=this.setFullWork(t);!l&&t.workId&&this.tmpOpt&&((r=this.tmpOpt)==null?void 0:r.toolsType)===o.EToolsKey.Selector&&this.setWorkOptions(t.workId.toString(),t.opt||this.tmpOpt.toolsOpt),l&&this.updateFullSelectWork(t);return}if(e&&(s!=null&&s.length)){const{selectRect:l}=e.updateSelectIds(s),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:((c=t.opt)==null?void 0:c.textOpt)||e.textOpt,canTextEdit:e.canTextEdit,canRotate:e.canRotate,scaleType:e.scaleType,type:o.EPostMessageType.Select,selectRect:l,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===o.EToolsKey.Text)return{type:o.EPostMessageType.TextUpdate,toolsType:o.EToolsKey.Text,workId:t,dataType:o.EDataType.Local}}async removeSelector(t){const{willSyncService:e}=t,s=[],r=[],a=this.workShapes.get(o.Storage_Selector_key);if(!a)return;const i=a.selectIds&&[...a.selectIds]||[];for(const n of i){if(this.vNodes.get(n)){const l=this.commandDeleteText(n);l&&s.push(l)}this.removeNode(n),r.push(n)}r.length&&s.push({type:o.EPostMessageType.RemoveNode,removeIds:r}),s.push({type:o.EPostMessageType.Select,selectIds:[],willSyncService:e}),await this.blurSelector(),s.length&&this.thread.post({sp:s})}removeWork(t){const{workId:e}=t,s=e==null?void 0:e.toString();s&&this.removeNode(s)}removeNode(t){var r;this.vNodes.get(t)&&((r=this.thread.fullLayer)==null||r.getElementsByName(t).forEach(a=>{a.remove()}),this.vNodes.delete(t)),this.workShapes.has(t)&&(this.thread.localLayer.getElementsByName(t).forEach(a=>{a.remove()}),this.clearWorkShapeNodeCache(t))}setFullWork(t){const{workId:e,opt:s,toolsType:r}=t;if(e&&s&&r){const a=e.toString();let i;return e&&this.workShapes.has(a)?(i=this.workShapes.get(a),i==null||i.setWorkOptions(s)):i=this.createWorkShapeNode({toolsOpt:s,toolsType:r,workId:a}),i?(this.workShapes.set(a,i),i):void 0}}async consumeFull(t){var r;const e=this.setFullWork(t),s=t.ops&&o.transformToNormalData(t.ops);if(e){const a=(r=t.workId)==null?void 0:r.toString();e.toolsType===o.EToolsKey.Image?await e.consumeServiceAsync({isFullWork:!0,replaceId:a,worker:this}):e.toolsType===o.EToolsKey.Text?await e.consumeServiceAsync({isFullWork:!0,replaceId:a}):e.consumeService({op:s,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:o.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(o.Storage_Selector_key),{workId:s,msgType:r}=t;if(e&&s&&e.selectIds&&e.selectIds.includes(s.toString())){r===o.EPostMessageType.RemoveNode?e.selectIds=e.selectIds.filter(a=>a!==s.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 s of this.effectSelectNodeData.values()){const r=this.setFullWork(s);if(r){const a=(e=s.workId)==null?void 0:e.toString();if(r.toolsType===o.EToolsKey.Image)await r.consumeServiceAsync({isFullWork:!0,replaceId:a,worker:this});else if(r.toolsType===o.EToolsKey.Text)await r.consumeServiceAsync({isFullWork:!0,replaceId:a});else{const i=s.ops&&o.transformToNormalData(s.ops);r.consumeService({op:i,isFullWork:!0,replaceId:a}),s!=null&&s.updateNodeOpt&&r.updataOptService(s.updateNodeOpt)}s.workId&&this.workShapes.delete(s.workId.toString())}}this.reRenderSelector(t)}hasSelector(){return this.workShapes.has(o.Storage_Selector_key)}getSelector(){return this.workShapes.get(o.Storage_Selector_key)}reRenderSelector(t=!1){var r;const e=this.workShapes.get(o.Storage_Selector_key);if(!e)return;if(e&&!((r=e.selectIds)!=null&&r.length))return this.blurSelector();const s=e.reRenderSelector();s&&this.thread.post({sp:[{type:o.EPostMessageType.Select,selectIds:e.selectIds,selectRect:s,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(o.Storage_Selector_key),s=e==null?void 0:e.blurSelector();if(this.clearWorkShapeNodeCache(o.Storage_Selector_key),((r=this.thread.fullLayer)==null?void 0:r.parent).children.forEach(a=>{a.name===o.Storage_Selector_key&&a.remove()}),s){const a=[];a.push({...s,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)}drawBitMapEraser(t){const e=[];t.op&&e.push(t),this.thread.post({sp:e,consumeCount:this.consumeCount})}async drawBitMapEraserFull(t,e,s){const{willUpdateNodes:r,willDeleteNodes:a}=e,i=t.getWorkId(),n=[{type:o.EPostMessageType.RemoveNode,removeIds:[i],viewId:this.thread.viewId}];if(s&&n.push({type:o.EPostMessageType.None,isLockSentEventCursor:s}),r!=null&&r.size||a!=null&&a.size){if(await(t==null?void 0:t.reRenderEffectNodes({willDeleteNodes:a,willUpdateNodes:r,worker:this})),r!=null&&r.size)for(const[c,l]of r)n.push({type:o.EPostMessageType.UpdateNode,dataType:o.EDataType.Local,opt:l.opt,workId:c,updateNodeOpt:{useAnimation:!1}});a!=null&&a.size&&n.push({type:o.EPostMessageType.RemoveNode,removeIds:[...a],viewId:this.thread.viewId})}n.length&&this.thread.post({sp:n})}drawPencilEraser(t,e){var r,a;const s=[];if((r=t.newWorkDatas)!=null&&r.size){for(const i of t.newWorkDatas.values()){const n=i.workId.toString();this.batchEraserWorks.add(n),s.push({type:o.EPostMessageType.FullWork,workId:n,ops:o.transformToSerializableData(i.op),opt:i.opt,toolsType:i.toolsType,updateNodeOpt:{useAnimation:!1}})}delete t.newWorkDatas}(a=t.removeIds)==null||a.forEach(i=>{this.batchEraserRemoveNodes.add(i)}),e&&s.push({type:o.EPostMessageType.None,isLockSentEventCursor:e}),t.rect,this.thread.post({sp:s,consumeCount:this.consumeCount}),this.batchEraserCombine()}drawEraser(t,e){const s=[];t.removeIds&&s.push(t),e&&s.push({type:o.EPostMessageType.None,isLockSentEventCursor:e}),this.thread.post({sp:s,consumeCount:this.consumeCount})}updateBatchEraserCombineNode(t,e){for(const s of e.keys())this.thread.fullLayer.getElementsByName(s).forEach(r=>{r.remove()});t.forEach(s=>{const r=this.vNodes.get(s);if(r&&r.toolsType===o.EToolsKey.Pencil&&!this.thread.fullLayer.getElementsByName(s)[0]){const i=this.setFullWork({...r,workId:s});i&&i.consumeService({op:r.op,isFullWork:!0})}})}getWorkShape(t){return this.workShapes.get(t)}getWorkShapes(){return this.workShapes}consumeDraw(t,e){const{op:s,workId:r,scenePath:a,postCount:i}=t;if(s!=null&&s.length&&r){const n=r.toString(),c=this.workShapes.get(n);if(!c)return;const l=c.toolsType;if(l===o.EToolsKey.LaserPen)return;switch(this.drawWorkActiveId&&this.drawWorkActiveId!==n&&(this.consumeDrawAll({workId:this.drawWorkActiveId,scenePath:a,viewId:this.thread.viewId,msgType:o.EPostMessageType.DrawWork,dataType:o.EDataType.Local},e),this.drawWorkActiveId=void 0),!this.drawWorkActiveId&&n!==o.Storage_Selector_key&&(this.drawWorkActiveId=n),L.isNumber(i)&&(this.consumeCount=i),l){case o.EToolsKey.Selector:{const p=c.consume({data:t,isFullWork:!0});p.type===o.EPostMessageType.Select&&(p.selectIds&&e.runReverseSelectWork(p.selectIds),this.thread.post({sp:[p]}))}break;case o.EToolsKey.PencilEraser:{const p=c.consume({data:t,isFullWork:!0});this.drawPencilEraser(p)}break;case o.EToolsKey.BitMapEraser:{const p=c.consume({data:t,isFullWork:!0});this.drawBitMapEraser(p);break}case o.EToolsKey.Eraser:{const p=c.consume({data:t,isFullWork:!0});this.drawEraser(p)}break;case o.EToolsKey.Arrow:case o.EToolsKey.Straight:case o.EToolsKey.Ellipse:case o.EToolsKey.Rectangle:case o.EToolsKey.Star:case o.EToolsKey.Polygon:case o.EToolsKey.SpeechBalloon:case o.EToolsKey.Pencil:{const p=c.consume({data:t,isFullWork:!1,isMainThread:!0});p&&(this.drawCount++,this.thread.post({drawCount:this.drawCount,sp:p.op&&[{...p,scenePath:a}]||void 0}))}break}}}consumeDrawAll(t,e){var i,n,c,l;const{workId:s,scenePath:r,isLockSentEventCursor:a}=t;if(s){const p=s.toString();this.drawWorkActiveId===p&&(this.drawWorkActiveId=void 0);const h=this.workShapes.get(p);if(!h)return;const y=h.toolsType;if(y===o.EToolsKey.LaserPen)return;const d=this.workShapes.get(o.Cursor_Hover_Id),k=(i=d==null?void 0:d.selectIds)==null?void 0:i[0],m=h.consumeAll({data:t});switch(y){case o.EToolsKey.Selector:m.selectIds&&k&&((n=m.selectIds)!=null&&n.includes(k))&&d.cursorBlur(),m.type===o.EPostMessageType.Select&&(m.selectIds&&e.runReverseSelectWork(m.selectIds),this.thread.post({sp:[{...m,scenePath:r}]})),(c=h.selectIds)!=null&&c.length?h.clearTmpPoints():this.clearWorkShapeNodeCache(p);break;case o.EToolsKey.PencilEraser:this.drawPencilEraser({...m,scenePath:r},a),h.clearTmpPoints();break;case o.EToolsKey.BitMapEraser:(m.rect||(l=m.newWorkDatas)!=null&&l.size)&&this.drawBitMapEraserFull(h,m,a);break;case o.EToolsKey.Eraser:this.drawEraser({...m,scenePath:r},a),h.clearTmpPoints();break;case o.EToolsKey.Arrow:case o.EToolsKey.Straight:case o.EToolsKey.Ellipse:case o.EToolsKey.Rectangle:case o.EToolsKey.Star:case o.EToolsKey.Polygon:case o.EToolsKey.SpeechBalloon:case o.EToolsKey.Pencil:{const S=[];a&&S.push({type:o.EPostMessageType.None,isLockSentEventCursor:a}),m&&(S.push(m),this.drawCount=0,this.thread.post({drawCount:this.drawCount,sp:S})),this.clearWorkShapeNodeCache(p);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 s=this.workShapes.get(t);if(!s&&this.tmpOpt){const{toolsType:r}=this.tmpOpt;this.tmpOpt.toolsOpt=e,s=this.createWorkShapeNode({workId:t,toolsType:r,toolsOpt:e}),s&&this.workShapes.set(t,s),this.setToolsOpt(this.tmpOpt)}e.syncUnitTime||(e.syncUnitTime=this.syncUnitTime),s==null||s.setWorkOptions(e)}createWorkShapeNode(t){return o.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",o.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()}),this.thread.serviceLayer.removeAllChildren()),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 s,r;const e=this.selectorWorkShapes.get(t);e&&e.selectIds&&((s=e.node)==null||s.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,s=e==null?void 0:e.toString();s&&this.willRunEffectSelectorIds.add(s),this.runEffect()}removeWork(t){const{workId:e}=t,s=e==null?void 0:e.toString();if(s){if(this.workShapes.get(s)){this.workShapes.delete(s),this.removeNode(s,t);return}this.removeNode(s,t)}}consumeFull(t){this.activeWorkShape(t),this.runAnimation()}runReverseSelectWork(t){t.forEach(e=>{this.selectorWorkShapes.forEach((s,r)=>{var a;if((a=s.selectIds)!=null&&a.length){const i=s.selectIds.indexOf(e);i>-1&&(s.selectIds.splice(i,1),this.willRunEffectSelectorIds.add(r))}})}),this.willRunEffectSelectorIds.size&&this.runEffect()}consumeDraw(t){this.activeWorkShape(t),this.runAnimation()}computNextAnimationIndex(t,e){const s=Math.floor((t.animationWorkData||[]).slice(t.animationIndex).length*32/e/this.syncUnitTime)*e;return Math.min((t.animationIndex||0)+(s||e),(t.animationWorkData||[]).length)}async animationDraw(){var s,r,a,i,n,c,l,p,h,y,d,k,m,S,T,E,b,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 o.EToolsKey.Image:{await((s=f.node)==null?void 0:s.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 o.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 o.EToolsKey.Arrow:case o.EToolsKey.Straight:case o.EToolsKey.Rectangle:case o.EToolsKey.Ellipse:case o.EToolsKey.Star:case o.EToolsKey.Polygon:case o.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 D;(D=W.selectIds)!=null&&D.includes(g)&&(this.willRunEffectSelectorIds.add(M),this.runEffect())}),(c=f.node)==null||c.clearTmpPoints(),this.workShapes.delete(g)),e.set(g,{workState:I?f.ops?o.EvevtWorkState.Done:o.EvevtWorkState.Doing:o.EvevtWorkState.Start,op:f.animationWorkData.filter((W,M)=>{if(M%3!==2)return!0}).slice(-2)}),f.animationWorkData.length=0}break}case o.EToolsKey.Pencil:{if(!f.useAnimation&&f.ops)(l=f.node)==null||l.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),D=(k=(d=f.node)==null?void 0:d.getWorkId())==null?void 0:k.toString();if((f.animationIndex||0)<I||f.isDiff){if((m=f.node)==null||m.consumeService({op:M,isFullWork:!1}),f.animationIndex=I,f.isDiff&&(f.isDiff=!1),M.length){const C=M.filter((P,A)=>{if(A%w!==w-1)return!0}).slice(-2);e.set(g,{workState:W===0?o.EvevtWorkState.Start:I===((S=f.animationWorkData)==null?void 0:S.length)?o.EvevtWorkState.Done:o.EvevtWorkState.Doing,op:C})}}else f.ops&&((T=f.node)==null||T.consumeService({op:f.animationWorkData||[],isFullWork:!0,replaceId:D}),f.isDel=!0,e.set(g,{workState:o.EvevtWorkState.Done,op:M.filter((C,P)=>{if(P%w!==w-1)return!0}).slice(-2)}));t=!0;break}break}case o.EToolsKey.BitMapEraser:case o.EToolsKey.PencilEraser:{if(f.isDel){(E=f.node)==null||E.clearTmpPoints(),this.workShapes.delete(g);break}if(f.ops&&((b=f.animationWorkData)!=null&&b.length)){const w=f.animationWorkData.slice(-3,-1);e.set(g,{workState:o.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:f.toolsType!==o.EToolsKey.BitMapEraser}),f.animationIndex=I,f.isDiff&&(f.isDiff=!1),M.length)){const D=M.filter((C,P)=>{if(P%3!==2)return!0}).slice(-2);e.set(g,{workState:W===0?o.EvevtWorkState.Start:I===((x=f.animationWorkData)==null?void 0:x.length)?o.EvevtWorkState.Done:o.EvevtWorkState.Doing,op:D})}t=!0;break}break}}if(t&&this.runAnimation(),e.size){const g=[];e.forEach((f,w)=>{g.push({type:o.EPostMessageType.Cursor,uid:w.split(o.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,s){const r=t.length;if(e.length<r)return!0;switch(s){case o.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 o.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 k,m,S,T;const{workId:e,opt:s,toolsType:r,type:a,updateNodeOpt:i,ops:n,op:c,useAnimation:l,imageBitmap:p}=t;if(!e)return;const h=e.toString(),y=(k=this.vNodes.get(h))==null?void 0:k.rect;if(!((m=this.workShapes)!=null&&m.has(h))){let E={toolsType:r,animationWorkData:c||[],animationIndex:0,type:a,updateNodeOpt:i,ops:n,useAnimation:typeof l<"u"?l:typeof(i==null?void 0:i.useAnimation)<"u"?i==null?void 0:i.useAnimation:!0,oldRect:y,isDiff:!1,imageBitmap:p};r&&s&&(E=this.setNodeKey(h,E,r,s)),(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=o.transformToNormalData(n),d.ops=n),i&&(d.updateNodeOpt=i),c&&(d.isDiff=this.hasDiffData(d.animationWorkData||[],c,d.toolsType),d.animationWorkData=c),d.node&&d.node.getWorkId()!==h&&d.node.setWorkId(h),y&&(d.oldRect=y),r&&s&&(s.syncUnitTime&&(this.syncUnitTime=s.syncUnitTime),d.toolsType!==r&&r&&s&&this.setNodeKey(h,d,r,s),d.node&&d.node.setWorkOptions(s)),p&&(d.imageBitmap=p)}removeNode(t,e){t.indexOf(o.Storage_Selector_key)>-1&&this.removeSelectWork(e),this.thread.fullLayer.getElementsByName(t).forEach(s=>{s.remove()}),this.thread.serviceLayer.getElementsByName(t).forEach(s=>{s.remove()}),this.vNodes.delete(t)}removeSelectWork(t){const{workId:e}=t,s=e==null?void 0:e.toString();s&&(this.activeSelectorShape(t),this.willRunEffectSelectorIds.add(s)),this.runEffect()}activeSelectorShape(t){var l,p,h;const{workId:e,opt:s,toolsType:r,type:a,selectIds:i}=t;if(!e)return;const n=e.toString();if(!((l=this.selectorWorkShapes)!=null&&l.has(n))){let y={toolsType:r,selectIds:i,type:a,opt:s};r&&s&&(y=this.setNodeKey(n,y,r,s)),(p=this.selectorWorkShapes)==null||p.set(n,y)}const c=(h=this.selectorWorkShapes)==null?void 0:h.get(n);a&&(c.type=a),c.node&&c.node.getWorkId()!==n&&c.node.setWorkId(n),c.selectIds=i||[]}setNodeKey(t,e,s,r){return e.toolsType=s,e.node=o.getShapeInstance({toolsType:s,toolsOpt:r,vNodes:this.vNodes,fullLayer:this.thread.fullLayer,drawLayer:this.thread.serviceLayer,workId:t},this),e}}class N{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 N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.CopyNode)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.FullWork&&r===o.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var r;const{workId:s}=e;s&&await((r=this.localWork)==null?void 0:r.consumeFull(e))}}class q extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.SetColorNode)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:c}=e;s===o.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:c,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:s,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n,textUpdateForWoker:c}=s,l=r.sp||[];if(i)for(const[p,h]of a.entries())c&&h.toolsType===o.EToolsKey.Text?l.push({...h,workId:p,type:o.EPostMessageType.TextUpdate,dataType:o.EDataType.Local,willSyncService:!0}):l.push({...h,workId:p,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:l}}}class H extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.ZIndexNode)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;s===o.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:s,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n}=s,c=r.sp||[];if(i&&c)for(const[l,p]of a.entries())c.push({...p,workId:l,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:c}}}class V extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.TranslateNode)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var p,h;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:c,emitEventType:l}=e;s===o.Storage_Selector_key&&r&&(r.workState===o.EvevtWorkState.Done&&(r!=null&&r.translate)&&(r.translate[0]||r.translate[1])||r.workState!==o.EvevtWorkState.Done?await((p=this.localWork)==null?void 0:p.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,isSync:!0,textUpdateForWoker:c,emitEventType:l,callback:this.updateSelectorCallback})):r.workState===o.EvevtWorkState.Done&&((h=this.localWork)==null||h.vNodes.deleteLastTarget()))}updateSelectorCallback(e){const{param:s,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:c,isSync:l,updateSelectorOpt:p,textUpdateForWoker:h}=s,y=p.workState,d=r.sp||[];if(y===o.EvevtWorkState.Start)return{sp:[],render:[]};const k=n==null?void 0:n.selectRect;if(c){y===o.EvevtWorkState.Doing&&d.push({type:o.EPostMessageType.Select,selectIds:i.selectIds,selectRect:k,willSyncService:!0,isSync:!0,points:i.getChildrenPoints(),textOpt:i.textOpt});for(const[m,S]of a.entries())h&&S.toolsType===o.EToolsKey.Text?d.push({...S,workId:m,type:o.EPostMessageType.TextUpdate,dataType:o.EDataType.Local,willSyncService:!0}):d.push({...S,workId:m,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:l})}return{sp:d}}}class $ extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.DeleteNode)}async consume(){return!1}}class G extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.ScaleNode)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var n;const{workId:s,updateNodeOpt:r,willSyncService:a,willSerializeData:i}=e;s===o.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:s,postData:r,workShapeNode:a,res:i,newServiceStore:n}=e,{updateSelectorOpt:c,willSyncService:l}=s,p=c.workState,h=r.sp||[],y=i==null?void 0:i.selectRect;if(p===o.EvevtWorkState.Start)return{sp:[],render:[]};if(l){h.push({type:o.EPostMessageType.Select,selectIds:a.selectIds,selectRect:y,willSyncService:!0,isSync:!0,points:p===o.EvevtWorkState.Done&&a.getChildrenPoints()||void 0,textOpt:a.textOpt});for(const[d,k]of n.entries())k.toolsType===o.EToolsKey.Text?h.push({...k,workId:d,type:o.EPostMessageType.TextUpdate,dataType:o.EDataType.Local,willSyncService:!0}):h.push({...k,workId:d,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:!0})}return{sp:h}}}class j extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.RotateNode)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,emitEventType:c}=e;s===o.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,emitEventType:c,isSync:!0,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:s,postData:r,workShapeNode:a,res:i,newServiceStore:n}=e,{updateSelectorOpt:c,willSyncService:l,willSerializeData:p,isSync:h}=s,y=c.workState,d=r.sp||[],k=i==null?void 0:i.selectRect;if(l){p&&y===o.EvevtWorkState.Done&&d.push({type:o.EPostMessageType.Select,selectIds:a.selectIds,selectRect:k,willSyncService:!0,isSync:h,points:a.getChildrenPoints()});for(const[m,S]of n.entries())d.push({...S,workId:m,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:h})}return{sp:d}}}class Z extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.SetFontStyle)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return await this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:c}=e;s===o.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:c,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:s,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:c,isSync:l,updateSelectorOpt:p,textUpdateForWoker:h}=s,y=r.sp||[],d=n==null?void 0:n.selectRect;if(c&&y){p.fontSize&&y.push({type:o.EPostMessageType.Select,selectIds:i.selectIds,selectRect:d,willSyncService:c,isSync:l,points:i.getChildrenPoints()});for(const[k,m]of a.entries())h&&m.toolsType===o.EToolsKey.Text?y.push({...m,workId:k,type:o.EPostMessageType.TextUpdate,dataType:o.EDataType.Local,willSyncService:!0}):y.push({...m,workId:k,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:l})}return{sp:y}}}class X extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.SetPoint)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var l;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,textUpdateForWoker:c}=e;s===o.Storage_Selector_key&&r&&await((l=this.localWork)==null?void 0:l.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,emitEventType:this.emitEventType,willSerializeData:n,isSync:!0,textUpdateForWoker:c,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:s,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:c,isSync:l}=s,p=r.sp||[],h=n==null?void 0:n.selectRect;if(c&&p){for(const[y,d]of a.entries())p.push({...d,workId:y,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:l});p.push({type:o.EPostMessageType.Select,selectIds:i.selectIds,selectRect:h,willSyncService:c,isSync:l,points:i.getChildrenPoints()})}return{sp:p}}}class Y extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.SetLock)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;s===o.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:s,postData:r,newServiceStore:a,workShapeNode:i,res:n}=e,{willSyncService:c,isSync:l,updateSelectorOpt:p}=s,h=r.sp||[],y=n==null?void 0:n.selectRect;if(c&&h){for(const[d,k]of a.entries())h.push({...k,workId:d,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:l});h.push({isLocked:p.isLocked,selectorColor:i.selectorColor,scaleType:i.scaleType,canRotate:i.canRotate,type:o.EPostMessageType.Select,selectIds:i.selectIds,selectRect:y,willSyncService:c,isSync:l})}return{sp:h}}}class Q extends N{constructor(){super(...arguments);u(this,"emitEventType",o.EmitEventType.SetShapeOpt)}async consume(e){const{msgType:s,dataType:r,emitEventType:a}=e;if(s===o.EPostMessageType.UpdateNode&&r===o.EDataType.Local&&a===this.emitEventType)return this.consumeForLocalWorker(e),!0}async consumeForLocalWorker(e){var c;const{workId:s,updateNodeOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n}=e;s===o.Storage_Selector_key&&r&&await((c=this.localWork)==null?void 0:c.updateSelector({updateSelectorOpt:r,willRefreshSelector:a,willSyncService:i,willSerializeData:n,callback:this.updateSelectorCallback}))}updateSelectorCallback(e){const{param:s,postData:r,newServiceStore:a}=e,{willSyncService:i,isSync:n}=s,c=r.sp||[];if(i&&c)for(const[l,p]of a.entries())c.push({...p,workId:l,type:o.EPostMessageType.UpdateNode,updateNodeOpt:{useAnimation:!1},isSync:n});return{sp:c}}}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 o.EmitEventType.TranslateNode:return new V;case o.EmitEventType.ZIndexNode:return new H;case o.EmitEventType.CopyNode:return new z;case o.EmitEventType.SetColorNode:return new q;case o.EmitEventType.DeleteNode:return new $;case o.EmitEventType.ScaleNode:return new G;case o.EmitEventType.RotateNode:return new j;case o.EmitEventType.SetFontStyle:return new Z;case o.EmitEventType.SetPoint:return new X;case o.EmitEventType.SetLock:return new Y;case o.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 s=o.DefaultAppliancePluginOptions.bufferSize.full,r=o.DefaultAppliancePluginOptions.bufferSize.sub;this.fullLayer=this.createLayer("fullLayer",this.scene,{...e.layerOpt,bufferSize:this.viewId===o.Main_View_Id?s:r*2}),this.topLayer=this.createLayer("topLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===o.Main_View_Id,r),contextType:"2d"}),this.localLayer=this.createLayer("localLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===o.Main_View_Id,r),contextType:"2d"}),this.serviceLayer=this.createLayer("serviceLayer",this.scene,{...e.layerOpt,bufferSize:(this.viewId===o.Main_View_Id,r),contextType:"2d"}),this.vNodes=new o.VNodeManager(t,this.scene);const a={thread:this,vNodes:this.vNodes};this.localWork=new _(a),this.serviceWork=new K(a),this.topWork=new U(a),this.vNodes.init(this.fullLayer),this.methodBuilder=new J([o.EmitEventType.CopyNode,o.EmitEventType.SetColorNode,o.EmitEventType.DeleteNode,o.EmitEventType.RotateNode,o.EmitEventType.ScaleNode,o.EmitEventType.TranslateNode,o.EmitEventType.ZIndexNode,o.EmitEventType.SetFontStyle,o.EmitEventType.SetPoint,o.EmitEventType.SetLock,o.EmitEventType.SetShapeOpt]).registerForMainThread(this)}getCachedImages(t){var e;return(e=this.cacheImages.get(t))==null?void 0:e.imageBitmap}getCachedImagesByWorkId(t){for(const[e,s]of this.cacheImages.entries())if(e===t&&s.imageBitmap)return s.imageBitmap}deleteCachedImagesByWorkId(t){for(const[e,s]of this.cacheImages.entries())s.workId===t&&(s.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:s,opt:r,dataType:a,workId:i,workState:n,imageSrc:c,imageBitmap:l,workIds:p}=t,h=i==null?void 0:i.toString();switch(e){case o.EPostMessageType.UpdateDpr:L.isNumber(t.dpr)&&this.updateDpr(t.dpr);break;case o.EPostMessageType.AuthClear:{const{clearUids:y,localUid:d}=t;this.vNodes.setCanClearUids(y),this.vNodes.setLocalUid(d);break}case o.EPostMessageType.Destroy:this.destroy();break;case o.EPostMessageType.Clear:this.clearAll();break;case o.EPostMessageType.UpdateCamera:await this.updateCamera(t);break;case o.EPostMessageType.UpdateTools:if(s&&r){const y={toolsType:s,toolsOpt:r};this.topWork.canUseTopLayer(s)?this.topWork.setToolsOpt(y):this.localWork.setToolsOpt(y)}break;case o.EPostMessageType.CreateWork:if(h&&r&&s){if(this.topWork.canUseTopLayer(s)){this.topWork.getToolsOpt()||this.topWork.setToolsOpt({toolsType:s,toolsOpt:r}),this.topWork.setWorkOptions(h,r);break}this.localWork.getToolsOpt()||this.localWork.setToolsOpt({toolsType:s,toolsOpt:r}),this.localWork.setWorkOptions(h,r)}break;case o.EPostMessageType.DrawWork:n===o.EvevtWorkState.Done&&a===o.EDataType.Local?this.consumeDrawAll(a,t):this.consumeDraw(a,t);break;case o.EPostMessageType.UpdateNode:case o.EPostMessageType.FullWork:if(s&&this.topWork.canUseTopLayer(s)){this.consumeDrawAll(a,t);break}this.consumeFull(a,t);break;case o.EPostMessageType.RemoveNode:await this.removeNode(t);return;case o.EPostMessageType.Select:a===o.EDataType.Service&&(i===o.Storage_Selector_key?this.localWork.updateFullSelectWork(t):this.serviceWork.runSelectWork(t));break;case o.EPostMessageType.CursorHover:this.localWork.cursorHover(t);break;case o.EPostMessageType.GetTextActive:a===o.EDataType.Local&&this.localWork.checkTextActive(t);break;case o.EPostMessageType.GetImageBitMap:if(c&&l&&i){const y=i.toString();this.deleteCachedImagesByWorkId(y),this.cacheImages.set(c,{imageBitmap:l,workId:y});const d=this.imageResolveMap.get(c);if(d){const{resolve:k,timer:m}=d;m&&clearTimeout(m),k&&k(c)}}break;case o.EPostMessageType.GetVNodeInfo:if(i&&p){const y=p.map(d=>this.vNodes.get(d));this.post({sp:[{type:o.EPostMessageType.GetVNodeInfo,dataType:o.EDataType.Local,workId:i,vInfo:y}]})}break}}}getIconSize(t,e,s){const r=t*s,a=e*s;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:s,workId:r}=t;if(e===o.EToolsKey.Image&&s&&r){const a=r.toString(),{src:i,type:n,width:c,height:l,strokeColor:p}=s;if(!i||!n||!c||!l)return;let h=i;if(n===o.EImageType.Iconify){const[m,S]=this.getIconSize(c,l,this.opt.displayer.dpr);h=`${i}?width=${m}&height=${S}&color=${p}`}if(this.cacheImages.has(h)){const m=this.getCachedImages(h);if(m)return m}if(this.imageResolveMap.has(h)){const m=this.getCachedImagesByWorkId(a);if(m)return m}const k=await new Promise(m=>{const S=this.imageResolveMap.get(h)||{resolve:void 0,timer:void 0};S.timer&&clearTimeout(S.timer),S.resolve=m,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:o.EPostMessageType.GetImageBitMap}]})});return this.imageResolveMap.delete(k),this.getCachedImages(h)}}async removeNode(t){const{dataType:e,workId:s,removeIds:r}=t,a=r||[];if(s&&a.push(s.toString()),a.length)for(const i of a){if(i===o.Storage_Selector_key){await this.localWork.removeSelector(t);continue}e===o.EDataType.Local?this.localWork.removeWork(t):e===o.EDataType.Service&&this.serviceWork.removeWork(t),await this.localWork.colloctEffectSelectWork(t)}}async consumeFull(t,e){const s=await this.localWork.colloctEffectSelectWork(e);s&&t===o.EDataType.Local&&await this.localWork.consumeFull(s),s&&t===o.EDataType.Service&&this.serviceWork.consumeFull(s)}setCameraOpt(t){this.cameraOpt=t;const{scale:e,centerX:s,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",[-s,-r]),this.topLayer.setAttribute("scale",[e,e]),this.topLayer.setAttribute("translate",[-s,-r]),this.localLayer.setAttribute("scale",[e,e]),this.localLayer.setAttribute("translate",[-s,-r]),this.serviceLayer.setAttribute("scale",[e,e]),this.serviceLayer.setAttribute("translate",[-s,-r])}runBatchPostData(){this.mainThreadPostId||(this.mainThreadPostId=requestAnimationFrame(this.combinePost.bind(this)))}combinePostData(){var r;this.mainThreadPostId=void 0;const t=[];let e,s;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 c of t)if(L.isEqual(i,c)){n=!0;break}n||t.push(i)}L.isNumber(a.drawCount)&&(e=a.drawCount),L.isNumber(a.consumeCount)&&(s=a.consumeCount)}return this.combinePostMsg.clear(),{sp:t,drawCount:e,consumeCount:s}}combinePost(){var s,r;const t=this.combinePostData(),e=(s=t.sp)==null?void 0:s.filter(a=>a.type!==o.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.drawCount===void 0&&delete t.drawCount,(t!=null&&t.consumeCount||t!=null&&t.drawCount||(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()}),this.fullLayer.removeAllChildren()),this.clearCacheImages(),this.clearImageResolveMap(),this.localWork.clearAll(),this.topWork.clearAll(),this.serviceWork.clearAll(),this.vNodes.clear(),this.post({sp:[{type:o.EPostMessageType.Clear}]})}consumeDrawAll(t,e){const{toolsType:s,workId:r}=e;if(r){const a=r.toString();if(s&&this.topWork.canUseTopLayer(s)){t===o.EDataType.Local&&(this.topWork.getLocalWorkShape(r.toString())||this.topWork.createLocalWork(e)),this.topWork.consumeDrawAll(e);return}t===o.EDataType.Local&&(this.localWork.getWorkShape(a)||this.localWork.createLocalWork(e),this.localWork.consumeDrawAll(e,this.serviceWork))}}consumeDraw(t,e){const{opt:s,workId:r,toolsType:a}=e;if(r&&a&&s){const i=r.toString();if(this.topWork.canUseTopLayer(a)){t===o.EDataType.Local&&(this.topWork.getLocalWorkShape(i)||this.topWork.createLocalWork(e)),this.topWork.consumeDraw(e);return}t===o.EDataType.Local?(this.localWork.getWorkShape(i)||this.localWork.createLocalWork(e),this.localWork.consumeDraw(e,this.serviceWork)):t===o.EDataType.Service&&this.serviceWork.consumeDraw(e);return}}async updateCamera(t){var r;const{cameraOpt:e,scenePath:s}=t;if(e&&!L.isEqual(this.cameraOpt,e)){if(this.taskUpdateCameraId&&(clearTimeout(this.taskUpdateCameraId),this.taskUpdateCameraId=void 0),s){let l=!1;for(const[p,h]of this.localWork.getWorkShapes().entries())switch(h.toolsType){case o.EToolsKey.Text:case o.EToolsKey.BitMapEraser:case o.EToolsKey.PencilEraser:case o.EToolsKey.Eraser:case o.EToolsKey.Selector:case o.EToolsKey.LaserPen:break;default:p!==o.Cursor_Hover_Id&&p!==o.Storage_Selector_key&&(l=!0);break}if(l){this.taskUpdateCameraId=setTimeout(()=>{this.taskUpdateCameraId=void 0,this.updateCamera(t)},o.Task_Time_Interval);return}}const a=new Map;for(const[l,p]of this.vNodes.getNodesByType(o.EToolsKey.Text).entries()){const h=p.rect;a.set(l,L.cloneDeep(h))}const i=new Set(a.keys());let n=!1;if(this.localWork.hasSelector()){const l=(r=this.localWork.getSelector())==null?void 0:r.selectIds;if(l){n=!0;for(const p of l)i.add(p)}}let c=!1;if(this.serviceWork.selectorWorkShapes.size)for(const l of this.serviceWork.selectorWorkShapes.values()){const p=l.selectIds;if(p){c=!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[l,p]of a.entries()){const h=this.vNodes.get(l);if(h){const y=p,d=h.rect,k=this.getSceneRect(),m=o.getRectMatrixrRelation(y,k),S=o.getRectMatrixrRelation(d,k);let T=!1;if((m!==S||y.w!==d.w||y.h!==d.h||S===o.EMatrixrRelationType.intersect)&&(T=!0),T){const{toolsType:E,opt:b}=h;E===o.EToolsKey.Text&&b.workState===o.EvevtWorkState.Done&&this.debounceUpdateCache.add(l)}}}if(n&&this.localWork.reRenderSelector(),c)for(const[l,p]of this.serviceWork.selectorWorkShapes.entries())this.serviceWork.runSelectWork({workId:l,selectIds:p.selectIds,msgType:o.EPostMessageType.Select,dataType:o.EDataType.Service,viewId:this.viewId});this.debounceUpdateCameraId=setTimeout(()=>{var p;this.debounceUpdateCameraId=void 0;const l=[];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:k,opt:m,rect:S}=d,T=this.localWork.setFullWork({toolsType:k,opt:m,workId:h});if(T){const E=this.getSceneRect(),b=o.getRectMatrixrRelation(S,E);l.push(T.consumeServiceAsync({isFullWork:!0,replaceId:h,isDrawLabel:b!==o.EMatrixrRelationType.outside}))}}}this.debounceUpdateCache.delete(h)}this.vNodes.updateLowLevelNodesRect(),this.vNodes.clearHighLevelIds()},o.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 O.Scene({displayRatio:this.opt.displayer.dpr,depth:!1,desynchronized:!0,...t,autoRender:!0,id:this.viewId,contextType:"2d"})}createLayer(t,e,s){const{width:r,height:a}=s,i=`canvas-${t}`,n=e.layer(i,{...s,offscreen:!1}),c=new O.Group({anchor:[.5,.5],pos:[r*.5,a*.5],size:[r,a],name:"viewport",id:t});return n.append(c),c}updateScene(t){this.scene.attr({...t});const{width:e,height:s}=t;this.scene.width=e,this.scene.height=s,this.updateLayer({width:e,height:s})}updateLayer(t){const{width:e,height:s}=t;this.fullLayer.parent.setAttribute("width",e),this.fullLayer.parent.setAttribute("height",s),this.fullLayer.setAttribute("size",[e,s]),this.fullLayer.setAttribute("pos",[e*.5,s*.5]),this.topLayer.parent.setAttribute("width",e),this.topLayer.parent.setAttribute("height",s),this.topLayer.setAttribute("size",[e,s]),this.topLayer.setAttribute("pos",[e*.5,s*.5]),this.localLayer.parent.setAttribute("width",e),this.localLayer.parent.setAttribute("height",s),this.localLayer.setAttribute("size",[e,s]),this.localLayer.setAttribute("pos",[e*.5,s*.5]),this.serviceLayer.parent.setAttribute("width",e),this.serviceLayer.parent.setAttribute("height",s),this.serviceLayer.setAttribute("size",[e,s]),this.serviceLayer.setAttribute("pos",[e*.5,s*.5])}destroy(){this.clearCacheImages(),this.clearImageResolveMap(),this.vNodes.clear(),this.fullLayer.remove(),this.topLayer.remove(),this.localLayer.remove(),this.serviceLayer.remove(),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===o.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,s]of this.cacheImages.entries())if(e===t&&s.imageBitmap)return s.imageBitmap}deleteCachedImagesByWorkId(t){for(const[e,s]of this.cacheImages.entries())s.workId===t&&(s.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:s,imageBitmap:r,workId:a}=t;switch(e){case o.EPostMessageType.Snapshot:await this.getSnapshot(t),this.destroy();return;case o.EPostMessageType.BoundingBox:await this.getBoundingRect(t),this.destroy();return;case o.EPostMessageType.GetImageBitMap:if(s&&r&&a){const i=a.toString();this.deleteCachedImagesByWorkId(i),this.cacheImages.set(s,{imageBitmap:r,workId:i});const n=this.imageResolveMap.get(s);if(n){const{resolve:c,timer:l}=n;l&&clearTimeout(l),c&&c(s)}}break}}getIconSize(t,e,s){const r=t*s,a=e*s;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:s,workId:r}=t;if(e===o.EToolsKey.Image&&s&&r){const a=r.toString(),{src:i,type:n,width:c,height:l,strokeColor:p}=s;if(!i||!n||!c||!l)return;let h=i;if(n===o.EImageType.Iconify){const[m,S]=this.getIconSize(c,l,this.opt.displayer.dpr);h=`${i}?width=${m}&height=${S}&color=${p}`}if(this.cacheImages.has(h)){const m=this.getCachedImages(h);if(m)return m}if(this.imageResolveMap.has(h)){const m=this.getCachedImagesByWorkId(a);if(m)return m}const k=await new Promise(m=>{const S=this.imageResolveMap.get(h)||{resolve:void 0,timer:void 0};S.timer&&clearTimeout(S.timer),S.resolve=m,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:o.EPostMessageType.GetImageBitMap}]})});return this.imageResolveMap.delete(k),this.getCachedImages(h)}}createWorkShapeNode(t){return o.getShapeInstance({...t,fullLayer:this.fullLayer,drawLayer:void 0})}setFullWork(t){const{workId:e,opt:s,toolsType:r}=t;if(e&&s&&r){const a=e.toString();let i;return e&&this.workShapes.has(a)?(i=this.workShapes.get(a),i==null||i.setWorkOptions(s)):i=this.createWorkShapeNode({toolsOpt:s,toolsType:r,workId:a}),i?(this.workShapes.set(a,i),i):void 0}}async runFullWork(t){var r;const e=this.setFullWork(t),s=t.ops&&o.transformToNormalData(t.ops);if(e){let a,i;const n=(r=e.getWorkId())==null?void 0:r.toString();return e.toolsType===o.EToolsKey.Image?a=await e.consumeServiceAsync({isFullWork:!0,worker:this}):e.toolsType===o.EToolsKey.Text?a=await e.consumeServiceAsync({isFullWork:!0,replaceId:n,isDrawLabel:!0}):(a=e.consumeService({op:s,isFullWork:!0,replaceId:n}),i=(t==null?void 0:t.updateNodeOpt)&&e.updataOptService(t.updateNodeOpt)),o.computRect(a,i)}}async getSnapshot(t){const{scenePath:e,scenes:s,cameraOpt:r,w:a,h:i}=t;if(e&&s&&r){this.setCameraOpt(r);let n;for(const[l,p]of Object.entries(s))if(p!=null&&p.type)switch(p==null?void 0:p.type){case o.EPostMessageType.UpdateNode:case o.EPostMessageType.FullWork:{const{opt:h}=p,y={...p,opt:h,workId:l,msgType:o.EPostMessageType.FullWork,dataType:o.EDataType.Service,viewId:this.viewId},d=await this.runFullWork(y);n=o.computRect(n,d);break}}let c;a&&i&&(c={resizeWidth:a,resizeHeight:i}),await this.getSnapshotRender({scenePath:e,options:c})}}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 s=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,s,r,a,i,e)}async getSnapshotRender(t){var a,i;const{scenePath:e,options:s}=t;((a=this.fullLayer)==null?void 0:a.parent).render();const r=await this.getRectImageBitmap(this.getSceneRect(),s);r&&(this.post({sp:[{type:o.EPostMessageType.Snapshot,scenePath:e,imageBitmap:r,viewId:this.viewId}]}),(i=this.fullLayer)==null||i.removeAllChildren())}async getBoundingRect(t){const{scenePath:e,scenes:s,cameraOpt:r}=t;if(e&&s&&r){this.setCameraOpt(r);let a;for(const[i,n]of Object.entries(s))if(n!=null&&n.type)switch(n==null?void 0:n.type){case o.EPostMessageType.UpdateNode:case o.EPostMessageType.FullWork:{const c=await this.runFullWork({...n,workId:i,msgType:o.EPostMessageType.FullWork,dataType:o.EDataType.Service,viewId:this.viewId});a=o.computRect(a,c);break}}a&&this.post({sp:[{type:o.EPostMessageType.BoundingBox,scenePath:e,rect:a}]})}}setCameraOpt(t){const{scale:e,centerX:s,centerY:r,width:a,height:i}=t;this.updateScene({width:a,height:i}),this.fullLayer.setAttribute("scale",[e,e]),this.fullLayer.setAttribute("translate",[-s,-r])}runBatchPostData(){this.mainThreadPostId||(this.mainThreadPostId=requestAnimationFrame(this.combinePost.bind(this)))}combinePostData(){var e;this.mainThreadPostId=void 0;const t=[];for(const s of this.combinePostMsg.values())if((e=s.sp)!=null&&e.length)for(const r of s.sp){let a=!1;for(const i of t)if(o.isEqual(r,i)){a=!0;break}a||t.push(r)}return this.combinePostMsg.clear(),{sp:t}}combinePost(){var s,r;const t=this.combinePostData(),e=(s=t.sp)==null?void 0:s.filter(a=>a.type!==o.EPostMessageType.None||a.isLockSentEventCursor);e!=null&&e.length?t.sp=e.map(a=>a.viewId?a:{...a,viewId:this.viewId}):delete t.sp,(t!=null&&t.drawCount||(r=t.sp)!=null&&r.length)&&this.opt.post(t)}createScene(t){return new O.Scene({displayRatio:this.opt.displayer.dpr,depth:!1,desynchronized:!0,...t,autoRender:!1,contextType:"2d"})}createLayer(t,e,s){const{width:r,height:a}=s,i=`canvas-${t}`,n=e.layer(i,s),c=new O.Group({anchor:[.5,.5],pos:[r*.5,a*.5],size:[r,a],name:"viewport",id:t});return n.append(c),c}updateScene(t){this.scene.attr({...t});const{width:e,height:s}=t;this.scene.width=e,this.scene.height=s,this.updateLayer({width:e,height:s})}updateLayer(t){const{width:e,height:s}=t;this.fullLayer.parent.setAttribute("width",e),this.fullLayer.parent.setAttribute("height",s),this.fullLayer.setAttribute("size",[e,s]),this.fullLayer.setAttribute("pos",[e*.5,s*.5])}destroy(){this.clearCacheImages(),this.clearImageResolveMap(),this.fullLayer.remove(),this.scene.remove()}}class se{constructor(t){u(this,"mainThreadMap",new Map);u(this,"snapshotThread");u(this,"master");this.master=t}post(t){const{drawCount:e,sp:s,workerTasksqueueCount:r,consumeCount:a}=t;this.master.isBusy&&o.isNumber(r)&&this.master.setWorkerTasksqueueCount(r),o.isNumber(e)&&this.master.setMaxDrawCount(e),o.isNumber(a)&&this.master.setConsumeCount(a),s&&this.master.collectorSyncData(s)}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,s,r,a;for(const i of t.values()){const{msgType:n,viewId:c,tasksqueue:l,mainTasksqueueCount:p,layerOpt:h,offscreenCanvasOpt:y,cameraOpt:d,isSubWorker:k}=i;if(n===o.EPostMessageType.Console){console.log(this);continue}if(n===o.EPostMessageType.Init){const S=(e=this.master.control.viewContainerManager.getView(c))==null?void 0:e.displayer,T=S==null?void 0:S.canvasContainerRef.current;if(S&&T&&h&&y){const E=this.createMainThread(c,{displayer:S,container:T,layerOpt:h,master:this.master,canvasOpt:y,post:this.post.bind(this)});this.mainThreadMap.set(c,E),E&&d&&E.setCameraOpt(d)}continue}if((n===o.EPostMessageType.Snapshot||n===o.EPostMessageType.BoundingBox)&&c===((s=this.master.control.viewContainerManager.mainView)==null?void 0:s.id)){const S=(r=this.master.control.viewContainerManager.getView(c))==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={...o.ViewContainerManager.defaultLayerOpt,offscreen:!1,width:d.width,height:d.height},b={...o.ViewContainerManager.defaultScreenCanvasOpt,width:d.width,height:d.height};this.snapshotThread=this.createSnapshotThread(c,{displayer:S,container:T,layerOpt:E,master:this.master,canvasOpt:b,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===o.EPostMessageType.GetImageBitMap&&k&&this.snapshotThread){this.snapshotThread.on(i);continue}if(n===o.EPostMessageType.TasksQueue&&(l!=null&&l.size)){for(const[S,T]of this.mainThreadMap.entries()){const E=l.get(S);E&&(await T.on(E),p&&this.post({workerTasksqueueCount:p}))}continue}if(c===o.Storage_ViewId_ALL){for(const S of this.mainThreadMap.values())S.on(i),n===o.EPostMessageType.Destroy&&this.mainThreadMap.delete(c);continue}const m=this.mainThreadMap.get(c);m&&(m.on(i),n===o.EPostMessageType.Destroy&&this.mainThreadMap.delete(c))}}}exports.MainThreadManagerImpl=se;
|