@univerjs/sheets-ui 0.6.10-nightly.202504221607 → 0.6.10-nightly.202504231607

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/umd/index.js CHANGED
@@ -79,5 +79,5 @@
79
79
  `,paragraphs:[{startIndex:i.length}],customRanges:[r]}}let o=n.replace(/(\r\n|\n)/g,"\r");o.endsWith(`\r
80
80
  `)||(o+=`\r
81
81
  `);const e=[];for(let t=0;t<o.length;t++)o[t]==="\r"&&e.push({startIndex:t});return{dataStream:o,paragraphs:e,sectionBreaks:[{startIndex:o.indexOf(`
82
- `)}]}}var Zg=Object.getOwnPropertyDescriptor,Kg=(n,o,e,t)=>{for(var i=t>1?void 0:t?Zg(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},tt=(n,o)=>(e,t)=>o(e,t,n);const qg=[m.InsertColMutation.id,m.InsertRowMutation.id,m.RemoveColMutation.id,m.RemoveRowMutation.id,m.MoveRangeMutation.id,m.MoveRowsMutation.id,m.MoveColsMutation.id];let Ln=class extends a.RxDisposable{constructor(o,e,t,i,r,s,l,c,d,u){super();T(this,"_refreshOptionalPaste$",new D.Subject);T(this,"refreshOptionalPaste$",this._refreshOptionalPaste$.asObservable());this._injector=o,this._instanceService=e,this._renderManagerService=t,this._commandService=i,this._contextService=r,this._configService=s,this._sheetClipboardService=l,this._messageService=c,this._localService=d,this._uiPartsService=u,this._init(),this._initCommandListener(),this._initUIComponents(),this._pasteWithDoc()}refreshOptionalPaste(){this._refreshOptionalPaste$.next(Math.random())}_pasteWithDoc(){var t;const o=i=>{i.onPaste$.pipe(D.takeUntil(this.dispose$)).subscribe(r=>{var u,h;if(!le(this._contextService))return;r.event.preventDefault();const s=r.event,l=(u=s.clipboardData)==null?void 0:u.getData("text/html"),c=(h=s.clipboardData)==null?void 0:h.getData("text/plain"),d=this._resolveClipboardFiles(s.clipboardData);this._commandService.executeCommand(uo.id,{htmlContent:l,textContent:c,files:d})})};let e=(t=this._renderManagerService.getRenderById(a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY))==null?void 0:t.with(Q.DocSelectionRenderService);e&&o(e),this._renderManagerService.created$.subscribe(i=>{var r;i.unitId===a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY&&(e=(r=this._renderManagerService.getRenderById(a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY))==null?void 0:r.with(Q.DocSelectionRenderService),e&&o(e))})}_resolveClipboardFiles(o){if(!o)return;const e=Array.from(o.items).map(t=>t.kind==="file"?t.getAsFile():void 0).filter(Boolean);return e.length>0?e:void 0}_init(){[je,co,Ge].forEach(e=>this.disposeWithMe(this._commandService.registerMultipleCommand(e))),[In,_n,Bt,bn,uo,ul].forEach(e=>this.disposeWithMe(this._commandService.registerCommand(e))),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initCopyingHooks())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initPastingHook()));const o=this._initSpecialPasteHooks().map(e=>this._sheetClipboardService.addClipboardHook(e));this.disposeWithMe({dispose:()=>o.forEach(e=>e.dispose())})}_initCopyingHooks(){const o=this;let e=null;return{id:fe.DEFAULT_COPY,isDefaultHook:!0,onBeforeCopy(t,i){e=o._getWorksheet(t,i)},onCopyCellContent(t,i){var l,c,d,u;const r=e.getCell(t,i);return(c=(l=r==null?void 0:r.p)==null?void 0:l.body)!=null&&c.paragraphs||(u=(d=r==null?void 0:r.p)==null?void 0:d.body)!=null&&u.textRuns?a.convertBodyToHtml(r.p.body):r?a.extractPureTextFromCell(r):""},onCopyCellStyle:(t,i,r,s)=>{const l={};(r||s)&&(l.rowspan=`${r||1}`,l.colspan=`${s||1}`);const c=e.getRange(t,i),d=e.getMergedCell(t,i),u=c.getTextStyle();let h="";if(u&&(h=a.handleStyleToString(u)),d){const S=d.endRow,g=d.endColumn,p=e.getRange(S,g).getTextStyle();if(p){const v=a.handleStyleToString(p);h?h+=v?`;${v}`:"":h=v}}return h&&(l.style=h),Object.keys(l).length?l:null},onCopyColumn(t){return{width:`${e.getColumnWidth(t)}`}},onCopyRow(t){return{style:`height: ${e.getRowHeight(t)}px;`}},onAfterCopy(){e=null},getFilteredOutRows(t){var c;const{startRow:i,endRow:r}=t,s=(c=o._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getActiveSheet(),l=[];if(!s)return l;for(let d=i;d<=r;d++)s.getRowFiltered(d)&&l.push(d);return l}}}_initPastingHook(){const o=this;let e=null,t=null,i=null;return{id:fe.DEFAULT_PASTE,isDefaultHook:!0,onBeforePaste({unitId:r,subUnitId:s,range:l}){i=o._getWorksheet(r,s),e=r,t=s;const c=o._configService.getConfig(m.MAX_CELL_PER_SHEET_KEY),d=l.rows[l.rows.length-1],u=l.cols[l.cols.length-1];return c&&d*u>c?(o._messageService.show({type:j.MessageType.Error,content:o._localService.t("clipboard.paste.exceedMaxCells")}),!1):!0},onPasteRows(r,s){const{range:l}=r,c=[],d=[],u=i.getMaxRows(),h=u-1,S=l.rows[l.rows.length-1]-h,g=s.length-S,f=i.getRowManager();if(S>0){const C={};s.slice(g).forEach((w,O)=>{const{height:R}=w||{};R&&(C[O]={h:Number.parseFloat(R),hd:a.BooleanNumber.FALSE})});const b={startColumn:l.cols[0],endColumn:l.cols[l.cols.length-1],endRow:l.rows[l.rows.length-1],startRow:u},E={unitId:e,subUnitId:t,range:b,rowInfo:C};c.push({id:m.InsertRowMutation.id,params:E}),d.push({id:m.RemoveRowMutation.id,params:{unitId:e,subUnitId:t,range:b}})}const p={},v={};if(s.slice(0,g).forEach((C,b)=>{var w,O;const{height:E}=C;if(E){const R=f.getRow(l.rows[0]+b),P=Number.parseFloat(E);if(R){const{h:A=a.DEFAULT_WORKSHEET_ROW_HEIGHT,ah:k=0}=R,N=Math.max(A,k);P>N?(p[b+l.rows[0]]=P,v[b+l.rows[0]]=N):(p[b+l.rows[0]]=N,v[b+l.rows[0]]=N)}else p[b+l.rows[0]]=P,v[b+l.rows[0]]=(O=(w=f.getRow(l.rows[0]+b))==null?void 0:w.h)!=null?O:a.DEFAULT_WORKSHEET_ROW_HEIGHT}}),Object.keys(p).length){const C={unitId:e,subUnitId:t,ranges:[{startRow:l.rows[0],endRow:Math.min(l.rows[l.rows.length-1],u),startColumn:l.cols[0],endColumn:l.cols[l.cols.length-1]}],rowHeight:p};c.push({id:m.SetWorksheetRowHeightMutation.id,params:C}),d.push({id:m.SetWorksheetRowHeightMutation.id,params:{...C,rowHeight:v}})}return{redos:c,undos:d}},onPasteColumns(r,s,l){var E;const{range:c}=r,d=[],u=[],h=i.getMaxColumns(),S=h-1,g=c.cols[c.cols.length-1]-S,f=s.length-g,p=(E=o._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?E:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,v=c.cols,C=v[0];if(g>0){const w={startRow:c.rows[0],endRow:c.rows[c.rows.length-1],endColumn:c.cols[c.cols.length-1],startColumn:h},O={unitId:e,subUnitId:t,range:w,colInfo:s.slice(f).map((R,P)=>({w:R.width?Math.max(+R.width,i.getColumnWidth(v[P])):p,hd:a.BooleanNumber.FALSE}))};d.push({id:m.InsertColMutation.id,params:O}),u.push({id:m.RemoveColMutation.id,params:{unitId:e,subUnitId:t,range:w}})}const b={unitId:e,subUnitId:t,ranges:[{startRow:c.rows[0],endRow:c.rows[c.rows.length-1],startColumn:c.cols[0],endColumn:Math.min(c.cols[c.cols.length-1],h)}]};if(s.length>0){const w={...b,colWidth:s.slice(0,f).reduce((R,P,A)=>{var k;return R[A+C]=P.width?Math.max(+P.width,(k=i.getColumnWidth(v[A]))!=null?k:p):p,R},{})},O={...b,colWidth:s.slice(0,f).reduce((R,P,A)=>{var k;return R[A+C]=(k=i.getColumnWidth(v[A]))!=null?k:p,R},{})};d.push({id:m.SetWorksheetColWidthMutation.id,params:w}),u.push({id:m.SetWorksheetColWidthMutation.id,params:O})}return{redos:d,undos:u}},onPastePlainText(r,s,l){return o._onPastePlainText(r,s,l)},onPasteCells(r,s,l,c){return o._onPasteCells(r,s,l,c)},onAfterPaste(r){i=null}}}_generateDocumentDataModelSnapshot(o){var l,c;const e=(l=M.withCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,y.SheetSkeletonManagerService,this._instanceService,this._renderManagerService))==null?void 0:l.getCurrentParam();if(e==null)return null;const{skeleton:t}=e,i=(c=t.getBlankCellDocumentModel())==null?void 0:c.documentModel,s={...i==null?void 0:i.getSnapshot(),...o};return i==null||i.reset(s),i==null?void 0:i.getSnapshot()}_onPastePlainText(o,e,t){const{range:i,unitId:r,subUnitId:s}=o;let l;if(/\r|\n/.test(e)||a.Tools.isLegalUrl(e)){const d=Gg(e),u=this._generateDocumentDataModelSnapshot({body:d});l={[i.rows[0]]:{[i.cols[0]]:{p:u}}}}else a.isFormulaString(e)?l={[i.rows[0]]:{[i.cols[0]]:{f:e}}}:l={[i.rows[0]]:{[i.cols[0]]:{v:e}}};const c={unitId:r,subUnitId:s,cellValue:l};return{redos:[{id:m.SetRangeValuesMutation.id,params:c}],undos:[{id:m.SetRangeValuesMutation.id,params:m.SetRangeValuesUndoMutationFactory(this._injector,c)}]}}_onPasteCells(o,e,t,i){return this._injector.invoke(r=>Xg(o,e,t,i,r))}_initSpecialPasteHooks(){const o=this,e={id:fe.SPECIAL_PASTE_VALUE,specialPasteInfo:{label:"specialPaste.value"},onPasteCells:(s,l,c)=>this._injector.invoke(d=>Uc(l,s,c,d))},t={id:fe.SPECIAL_PASTE_FORMAT,specialPasteInfo:{label:"specialPaste.format"},onPasteCells:(s,l,c)=>{const d=[],u=[],{undos:h,redos:S}=this._injector.invoke(C=>xc(l,c,C));d.push(...S),u.push(...h);const{undos:g,redos:f}=this._injector.invoke(C=>_s(l,c,C));d.push(...f),u.push(...g);const{undos:p,redos:v}=this._injector.invoke(C=>Bc(l,s,c,C));return d.push(...v),u.push(...p),{undos:u,redos:d}}},i={id:fe.SPECIAL_PASTE_COL_WIDTH,specialPasteInfo:{label:"specialPaste.colWidth"},onPasteCells(){return{undos:[],redos:[]}},onPasteColumns(s,l,c){var A,k;const d=o._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),u=d.getUnitId(),h=(A=d.getActiveSheet())==null?void 0:A.getSheetId();if(!u||!h)throw new Error("Cannot find unitId or subUnitId");const S=[],g=[],f=o._getWorksheet(u,h),{range:p}=s,v=p.cols,C=v[0],b=f.getMaxColumns(),E=p.cols[p.cols.length-1]-b,w=l.length-E,O=(k=o._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?k:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,R={unitId:u,subUnitId:h,ranges:[{startRow:p.rows[0],endRow:Math.min(p.cols[p.cols.length-1],b),startColumn:p.cols[0],endColumn:p.cols[p.cols.length-1]}],colWidth:l.slice(0,w).reduce((N,H,V)=>{var U;return N[V+C]=H.width?Math.max(+H.width,(U=f.getColumnWidth(v[V]))!=null?U:O):O,N},{})},P={unitId:u,subUnitId:h,ranges:[{startRow:p.rows[0],endRow:Math.min(p.cols[p.cols.length-1],b),startColumn:p.cols[0],endColumn:p.cols[p.cols.length-1]}],colWidth:l.slice(0,w).reduce((N,H,V)=>{var U;return N[V+C]=(U=f.getColumnWidth(v[V]))!=null?U:O,N},{})};return S.push({id:m.SetWorksheetColWidthMutation.id,params:R}),g.push({id:m.SetWorksheetColWidthMutation.id,params:P}),{redos:S,undos:g}}},r={id:fe.SPECIAL_PASTE_BESIDES_BORDER,specialPasteInfo:{label:"specialPaste.besidesBorder"},onPasteCells:(s,l,c,d)=>{o._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);const u=[],h=[],{range:S,unitId:g,subUnitId:f}=l,p=new a.ObjectMatrix;c.forValue((w,O,R)=>{const P=R.s;if(typeof P=="object"){const A=a.Tools.deepClone(R);A.s&&(A.s={...P,bd:null}),p.setValue(S.rows[w],S.cols[O],A)}});const v={unitId:g,subUnitId:f,cellValue:p.getData()};u.push({id:m.SetRangeValuesMutation.id,params:v});const C=this._injector.invoke(m.SetRangeValuesUndoMutationFactory,v);h.push({id:m.SetRangeValuesMutation.id,params:C});const{undos:b,redos:E}=this._injector.invoke(w=>_s(l,c,w));return h.push(...b),u.push(...E),{redos:u,undos:h}}};return[e,t,i,r]}_getWorksheet(o,e){var i;const t=(i=this._instanceService.getUniverSheetInstance(o))==null?void 0:i.getSheetBySheetId(e);if(!t)throw new Error(`[SheetClipboardController]: cannot find a worksheet with unitId ${o} and subUnitId ${e}.`);return t}_initCommandListener(){var e;this.disposeWithMe(this._commandService.onCommandExecuted(t=>{t.id===bt.id?this._sheetClipboardService.removeMarkSelection():qg.includes(t.id)&&this._sheetClipboardService.removeMarkSelection()}));const o=this._configService.getConfig(Fe);(e=o==null?void 0:o.clipboardConfig)!=null&&e.hidePasteOptions||(this.disposeWithMe(this._commandService.onCommandExecuted(t=>{zg.includes(t.id)&&this._sheetClipboardService.disposePasteOptionsCache()})),this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===Xe.id){if(!this._sheetClipboardService.getPasteMenuVisible())return;const r=t.params.unitId,s=this._sheetClipboardService.getPasteOptionsCache(),l=s==null?void 0:s.target.unitId;r===l&&this._refreshOptionalPaste$.next(Math.random())}})))}_initUIComponents(){var e;const o=this._configService.getConfig(Fe);(e=o==null?void 0:o.clipboardConfig)!=null&&e.hidePasteOptions||this.disposeWithMe(this._uiPartsService.registerComponent(I.BuiltInUIPart.CONTENT,()=>I.connectInjector(Fg,this._injector)))}};Ln=Kg([tt(0,a.Inject(a.Injector)),tt(1,a.IUniverInstanceService),tt(2,M.IRenderManagerService),tt(3,a.ICommandService),tt(4,a.IContextService),tt(5,a.IConfigService),tt(6,Be),tt(7,I.IMessageService),tt(8,a.Inject(a.LocaleService)),tt(9,I.IUIPartsService)],Ln);var Qg=Object.getOwnPropertyDescriptor,Jg=(n,o,e,t)=>{for(var i=t>1?void 0:t?Qg(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Fc=(n,o)=>(e,t)=>o(e,t,n);y.DragManagerService=class extends a.Disposable{constructor(e,t){super();T(this,"_currentCell$",new D.Subject);T(this,"currentCell$",this._currentCell$.asObservable().pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)})));T(this,"_endCell$",new D.Subject);T(this,"endCell$",this._endCell$.asObservable());this._univerInstanceService=e,this._renderManagerService=t,this._initCellDisposableListener()}dispose(){super.dispose(),this._currentCell$.complete(),this._endCell$.complete()}_initCellDisposableListener(){this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{e||(this._currentCell$.next(null),this._endCell$.next(null))}))}_calcActiveCell(e,t){const i=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!i)return null;const r=i.getActiveSheet();if(!r)return;const s=this._renderManagerService.getRenderById(i.getUnitId());if(!s)return;const l=s.with(y.SheetSkeletonManagerService).getCurrentParam(),d=s.with(y.SheetScrollManagerService).getCurrentScrollState();if(!(!l||!d||!s))return Nl(s,i,r,l,e,t)}onDragOver(e){const{offsetX:t,offsetY:i,dataTransfer:r}=e,s=this._calcActiveCell(t,i);if(!s){this._currentCell$.next(null);return}const{location:l,position:c}=s;this._currentCell$.next({location:l,position:c,dataTransfer:r})}onDrop(e){const{offsetX:t,offsetY:i,dataTransfer:r}=e,s=this._calcActiveCell(t,i);if(!s){this._endCell$.next(null);return}const{location:l,position:c}=s;this._endCell$.next({location:l,position:c,dataTransfer:r})}},y.DragManagerService=Jg([Fc(0,a.IUniverInstanceService),Fc(1,M.IRenderManagerService)],y.DragManagerService);var $g=Object.getOwnPropertyDescriptor,ef=(n,o,e,t)=>{for(var i=t>1?void 0:t?$g(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},bs=(n,o)=>(e,t)=>o(e,t,n);y.DragRenderController=class extends a.Disposable{constructor(o,e,t,i){super(),this._context=o,this._renderManagerService=e,this._dragManagerService=t,this._sheetSkeletonManagerService=i,this._initDragEvent()}_initDragEvent(){const o=new a.DisposableCollection,e=t=>{if(o.dispose(),!t)return;const{scene:i}=this._context,r=i.onDragOver$.subscribeEvent(l=>{this._dragManagerService.onDragOver(l)}),s=i.onDrop$.subscribeEvent(l=>{this._dragManagerService.onDrop(l)});o.add({dispose(){r.unsubscribe(),s.unsubscribe()}})};e(this._sheetSkeletonManagerService.getCurrentParam()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(t=>{e(t)}))}},y.DragRenderController=ef([bs(1,M.IRenderManagerService),bs(2,a.Inject(y.DragManagerService)),bs(3,a.Inject(y.SheetSkeletonManagerService))],y.DragRenderController);const Es=(n,o)=>{var h,S,g,f,p;const t=o.findNodePositionByCharIndex(n.startOffset,!0,n.segmentId,-1),i=o.getSkeletonData();let r=n.endOffset;if(n.segmentId){const v=(p=Array.from((S=(h=i==null?void 0:i.skeFooters.get(n.segmentId))==null?void 0:h.values())!=null?S:[])[0])!=null?p:Array.from((f=(g=i==null?void 0:i.skeHeaders.get(n.segmentId))==null?void 0:g.values())!=null?f:[])[0];v&&(r=Math.min(v.ed,r))}const s=o.findNodePositionByCharIndex(r,!0,n.segmentId,-1);if(!s||!t)return;const l={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},c=new Q.NodePositionConvertToCursor(l,o),{borderBoxPointGroup:d}=c.getRangePointData(t,s);return Q.getLineBounding(d).map(v=>({top:v.top,bottom:v.bottom,left:v.left,right:v.right}))},tf=(n,o,e=-1)=>{const t=o.findPositionByGlyph(n,e);if(!t)return;const i={...t,isBack:!0},r={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},s=new Q.NodePositionConvertToCursor(r,o),{borderBoxPointGroup:l}=s.getRangePointData(i,i),d=Q.getLineBounding(l)[0];return{top:d.top,bottom:d.bottom,left:d.left,right:d.right}},nf=(n,o,e=0,t=0)=>{const i=Es({startOffset:o.startIndex,endOffset:o.endIndex+1},n);if(i)return{rects:i.map(r=>({top:r.top+t,bottom:r.bottom+t,left:r.left+e,right:r.right+e})),range:o}},of=(n,o,e=0,t=0)=>{var h,S,g;const i=n.findNodeByCharIndex(o.startIndex),r=i==null?void 0:i.parent,s=r==null?void 0:r.parent,l=s==null?void 0:s.parent,c=l==null?void 0:l.lines.find(f=>f.paragraphStart&&f.paragraphIndex===o.startIndex),d=(g=(S=(h=c==null?void 0:c.divides)==null?void 0:h[0])==null?void 0:S.glyphGroup)==null?void 0:g[0];if(!d||!d)return;const u=tf(d,n);if(u)return{rect:{top:u.top+t,bottom:u.bottom+t,left:u.left+e,right:u.right+e},segmentId:void 0,segmentPageIndex:-1,paragraph:o}},zc=(n,o=0,e=0)=>{var l,c,d,u,h,S,g;const t=n.getViewModel().getDataModel(),i=(d=(c=(l=t.getBody())==null?void 0:l.customRanges)==null?void 0:c.filter(f=>f.rangeType===a.CustomRangeType.HYPERLINK))!=null?d:[],r=(S=(h=(u=t.getBody())==null?void 0:u.paragraphs)==null?void 0:h.filter(f=>{var p;return((p=f.bullet)==null?void 0:p.listType.indexOf(a.PresetListType.CHECK_LIST))===0}))!=null?S:[],s=(g=n.getSkeletonData())==null?void 0:g.pages[0].skeDrawings;return{links:i.map(f=>nf(n,f,o,e)).filter(Boolean),checkLists:r.map(f=>of(n,f,o,e)).filter(Boolean),drawings:s?Array.from(s.keys()).map(f=>({drawingId:f,rect:{top:s.get(f).aTop,bottom:s.get(f).aTop+s.get(f).width,left:s.get(f).aLeft,right:s.get(f).aLeft+s.get(f).height},drawing:s.get(f)})):[]}};function Xc(n,o,e){var d,u,h,S,g,f;const t=(h=(u=(d=o.documentSkeleton)==null?void 0:d.getSkeletonData())==null?void 0:u.pages[0].height)!=null?h:0,i=(f=(g=(S=o.documentSkeleton)==null?void 0:S.getSkeletonData())==null?void 0:g.pages[0].width)!=null?f:0,r=o.verticalAlign,s=o.horizontalAlign;let l=0;switch(r){case a.VerticalAlign.UNSPECIFIED:case a.VerticalAlign.BOTTOM:l=n.mergeInfo.endY-n.mergeInfo.startY-t;break;case a.VerticalAlign.MIDDLE:l=(n.mergeInfo.endY-n.mergeInfo.startY-t)/2;break}let c=0;switch(s){case a.HorizontalAlign.RIGHT:c=n.mergeInfo.endX-n.mergeInfo.startX-i;break;case a.HorizontalAlign.CENTER:c=(n.mergeInfo.endX-n.mergeInfo.startX-i)/2;break;case a.HorizontalAlign.UNSPECIFIED:{e&&(c=n.mergeInfo.endX-n.mergeInfo.startX-i);break}}return{paddingLeft:c,paddingTop:l}}const rf=(n,o,e,t,i,r)=>{var H,V,U;const s=n.get(a.IUniverInstanceService),l=n.get(M.IRenderManagerService),c=s.getUnit(o,a.UniverInstanceType.UNIVER_SHEET);if(!c)return null;const d=c.getSheetBySheetId(e);if(!d)return null;const u=l.getRenderById(c.getUnitId()),h=u==null?void 0:u.with(y.SheetSkeletonManagerService).getSkeletonParam(d.getSheetId()),S=h==null?void 0:h.skeleton;if(!S||!u)return;const g=S.getFont(t,i),f=g==null?void 0:g.documentSkeleton;if(!f)return null;const p=(V=(H=f.getViewModel().getBody())==null?void 0:H.customRanges)==null?void 0:V.find(W=>W.rangeId===r);if(!p)return null;const v=Q.DOC_VERTICAL_PADDING,C=S.getCellWithCoordByIndex(t,i);let{actualColumn:b,actualRow:E}=C;S.overflowCache.forValue((W,B,x)=>{x.startRow<=E&&x.endRow>=E&&x.startColumn<=b&&x.endColumn>=b&&(b=B,E=W)});const w=S.getCellWithCoordByIndex(E,b),O=d.getCell(w.actualRow,w.actualColumn),{topOffset:R=0,leftOffset:P=0}=(U=O==null?void 0:O.fontRenderExtension)!=null?U:{},{paddingLeft:A,paddingTop:k}=Xc(w,g,!1),N=Es({startOffset:p.startIndex,endOffset:p.endIndex},f);return{rects:N==null?void 0:N.map(W=>({top:W.top+w.mergeInfo.startY+k+R+v,bottom:W.bottom+w.mergeInfo.startY+k+R+v,left:W.left+w.mergeInfo.startX+A+P,right:W.right+w.mergeInfo.startX+A+P})),customRange:p,label:f.getViewModel().getBody().dataStream.slice(p.startIndex,p.endIndex+1)}},sf=(n,o,e,t,i,r)=>{var P,A,k;const s=n.get(Se),l=s.getEditCellState();if(!l||!s.isVisible().visible)return null;const{editorUnitId:d,unitId:u,sheetId:h,row:S,column:g}=l;if(o!==u||e!==h||S!==t||g!==i)return null;const f=n.get(M.IRenderManagerService),p=f.getRenderById(d),v=f.getRenderById(o);if(!p||!v)return null;const C=p.with(_e.DocSkeletonManagerService).getSkeleton(),b=(P=v.with(y.SheetSkeletonManagerService).getSkeletonParam(h))==null?void 0:P.skeleton;if(!C||!b)return null;const E=(k=(A=C.getViewModel().getBody())==null?void 0:A.customRanges)==null?void 0:k.find(N=>N.rangeId===r);if(!E)return null;const w=4,O=Es({startOffset:E.startIndex,endOffset:E.endIndex},C),R=p.engine.getCanvasElement().getBoundingClientRect();return{rects:O==null?void 0:O.map(N=>({top:N.top+R.top-w,bottom:N.bottom+R.top+w,left:N.left+R.left,right:N.right+R.left})),customRange:E,label:C.getViewModel().getBody().dataStream.slice(E.startIndex,E.endIndex+1)}};var af=Object.getOwnPropertyDescriptor,lf=(n,o,e,t)=>{for(var i=t>1?void 0:t?af(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Yc=(n,o)=>(e,t)=>o(e,t,n);function en(n){const{workbook:o,worksheet:e,...t}=n;return t}y.HoverManagerService=class extends a.Disposable{constructor(e,t){super();T(this,"_currentCell$",new D.BehaviorSubject(null));T(this,"_currentRichText$",new D.BehaviorSubject(null));T(this,"_currentClickedCell$",new D.Subject);T(this,"_currentDbClickedCell$",new D.Subject);T(this,"_currentCellWithEvent$",new D.Subject);T(this,"_currentPointerDownCell$",new D.Subject);T(this,"_currentPointerUpCell$",new D.Subject);T(this,"_currentHoveredRowHeader$",new D.BehaviorSubject(null));T(this,"_currentHoveredColHeader$",new D.BehaviorSubject(null));T(this,"_currentRowHeaderClick$",new D.Subject);T(this,"_currentColHeaderClick$",new D.Subject);T(this,"_currentRowHeaderDbClick$",new D.Subject);T(this,"_currentColHeaderDbClick$",new D.Subject);T(this,"_currentRowHeaderPointerDown$",new D.Subject);T(this,"_currentColHeaderPointerDown$",new D.Subject);T(this,"_currentRowHeaderPointerUp$",new D.Subject);T(this,"_currentColHeaderPointerUp$",new D.Subject);T(this,"currentCell$",this._currentCell$.asObservable().pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)})));T(this,"currentRichTextNoDistinct$",this._currentRichText$.pipe(D.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,customRange:e.customRange,bullet:e.bullet,rect:e.rect,drawing:e.drawing})));T(this,"currentRichText$",this._currentRichText$.pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h,S,g,f,p,v,C,b,E,w,O;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)&&((S=e==null?void 0:e.customRange)==null?void 0:S.rangeId)===((g=t==null?void 0:t.customRange)==null?void 0:g.rangeId)&&((f=e==null?void 0:e.bullet)==null?void 0:f.startIndex)===((p=t==null?void 0:t.bullet)==null?void 0:p.startIndex)&&((v=e==null?void 0:e.customRange)==null?void 0:v.startIndex)===((C=t==null?void 0:t.customRange)==null?void 0:C.startIndex)&&((b=e==null?void 0:e.customRange)==null?void 0:b.endIndex)===((E=t==null?void 0:t.customRange)==null?void 0:E.endIndex)&&((w=e==null?void 0:e.drawing)==null?void 0:w.drawingId)===((O=t==null?void 0:t.drawing)==null?void 0:O.drawingId)}),D.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,customRange:e.customRange,bullet:e.bullet,rect:e.rect,drawing:e.drawing})));T(this,"currentCellPosWithEvent$",this._currentCellWithEvent$.pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)}),D.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,event:e.event})));T(this,"currentPosition$",this._currentCell$.asObservable());T(this,"currentClickedCell$",this._currentClickedCell$.asObservable());T(this,"currentDbClickedCell$",this._currentDbClickedCell$.asObservable());T(this,"currentPointerDownCell$",this._currentPointerDownCell$.asObservable());T(this,"currentPointerUpCell$",this._currentPointerUpCell$.asObservable());T(this,"currentHoveredRowHeader$",this._currentHoveredRowHeader$.asObservable());T(this,"currentHoveredColHeader$",this._currentHoveredColHeader$.asObservable());T(this,"currentRowHeaderClick$",this._currentRowHeaderClick$.asObservable());T(this,"currentColHeaderClick$",this._currentColHeaderClick$.asObservable());T(this,"currentRowHeaderDbClick$",this._currentRowHeaderDbClick$.asObservable());T(this,"currentColHeaderDbClick$",this._currentColHeaderDbClick$.asObservable());T(this,"currentRowHeaderPointerDown$",this._currentRowHeaderPointerDown$.asObservable());T(this,"currentColHeaderPointerDown$",this._currentColHeaderPointerDown$.asObservable());T(this,"currentRowHeaderPointerUp$",this._currentRowHeaderPointerUp$.asObservable());T(this,"currentColHeaderPointerUp$",this._currentColHeaderPointerUp$.asObservable());this._univerInstanceService=e,this._renderManagerService=t,this._initCellDisposableListener()}dispose(){super.dispose(),this._currentCell$.complete(),this._currentClickedCell$.complete(),this._currentPointerDownCell$.complete(),this._currentPointerUpCell$.complete(),this._currentCellWithEvent$.complete()}_initCellDisposableListener(){this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{e||this._currentCell$.next(null)})),this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(e=>{var t,i;((t=this._currentCell$.getValue())==null?void 0:t.location.unitId)===e.getUnitId()&&this._currentCell$.next(null),((i=this._currentRichText$.getValue())==null?void 0:i.location.unitId)===e.getUnitId()&&this._currentRichText$.next(null)}))}_getCalcDeps(e){const t=this._univerInstanceService.getUnit(e,a.UniverInstanceType.UNIVER_SHEET);if(!t)return null;const i=t.getActiveSheet();if(!i)return null;const r=this._renderManagerService.getRenderById(t.getUnitId());if(!r)return null;const s=r.with(y.SheetSkeletonManagerService).getSkeletonParam(i.getSheetId());if(!s)return null;const l=r.with(y.SheetScrollManagerService);if(!(!(l!=null&&l.getCurrentScrollState())||!r))return{currentRender:r,workbook:t,worksheet:i,skeletonParam:s}}_calcActiveCell(e,t,i,r,s,l){var R,P,A;const c=Nl(e,t,i,r,s,l),d=r.skeleton;if(!c)return null;const{position:u,overflowLocation:h,location:S}=c,g=d.getFont(h.row,h.col);let f=null,p=null,v=null;const C=d.getCellWithCoordByIndex(h.row,h.col),b=i.getCell(h.row,h.col),{topOffset:E=0,leftOffset:w=0}=(R=b==null?void 0:b.fontRenderExtension)!=null?R:{};if(g!=null&&g.documentSkeleton){const{paddingLeft:k,paddingTop:N}=Xc(C,g,(b==null?void 0:b.v)!==null&&(b==null?void 0:b.v)!==void 0?!Number.isNaN(+b.v):!1),H=zc(g.documentSkeleton,k,N),V=s-u.startX-w,U=l-u.startY-E;f=H.links.find(W=>W.rects.some(B=>B.left<=V&&V<=B.right&&B.top<=U&&U<=B.bottom)),p=H.checkLists.find(W=>W.rect.left<=V&&V<=W.rect.right&&W.rect.top<=U&&U<=W.rect.bottom),v=H.drawings.find(W=>W.rect.left<=V&&V<=W.rect.right&&W.rect.top<=U&&U<=W.rect.bottom)}const O=(A=(P=f==null?void 0:f.rects.pop())!=null?P:p==null?void 0:p.rect)!=null?A:v==null?void 0:v.rect;return{location:S,position:u,overflowLocation:h,customRange:f==null?void 0:f.range,bullet:p==null?void 0:p.paragraph,drawing:v,rect:O&&{top:O.top+C.mergeInfo.startY+E,bottom:O.bottom+C.mergeInfo.startY+E,left:O.left+C.mergeInfo.startX+w,right:O.right+C.mergeInfo.startX+w}}}_calcActiveRowHeader(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,worksheet:l,skeletonParam:c}=r,{scaleY:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(g=>g.isHit(new M.Vector2(t,i)));if(!u||u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP&&u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},S=c.skeleton.getRowIndexByOffsetY(i,d,h);return{unitId:e,index:S,subUnitId:l.getSheetId()}}_calcActiveColHeader(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,worksheet:l,skeletonParam:c}=r,{scaleX:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(g=>g.isHit(new M.Vector2(t,i)));if(!u||u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT&&u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},S=c.skeleton.getColumnIndexByOffsetX(t,d,h);return{unitId:e,index:S,subUnitId:l.getSheetId()}}triggerPointerDown(e,t){const i=this._getCalcDeps(e);if(!i)return;const{currentRender:r,workbook:s,worksheet:l,skeletonParam:c}=i,d=this._calcActiveCell(r,s,l,c,t.offsetX,t.offsetY);if(d&&d.location){const{unitId:u,subUnitId:h,row:S,col:g}=en(d.location);this._currentPointerDownCell$.next({unitId:u,subUnitId:h,row:S,col:g,event:t})}}triggerPointerUp(e,t){const i=this._getCalcDeps(e);if(!i)return;const{currentRender:r,workbook:s,worksheet:l,skeletonParam:c}=i,d=this._calcActiveCell(r,s,l,c,t.offsetX,t.offsetY);if(d){const u=en(d.location);this._currentPointerUpCell$.next({...u,event:t})}}triggerMouseMove(e,t){const i=this._getCalcDeps(e);if(!i)return;const{currentRender:r,workbook:s,worksheet:l,skeletonParam:c}=i,d=this._calcActiveCell(r,s,l,c,t.offsetX,t.offsetY);this._currentCell$.next(d&&{location:en(d.location),position:d.position}),this._currentRichText$.next(d&&{...d,location:en(d.overflowLocation)}),this._currentCellWithEvent$.next(d&&{...d,location:en(d.location),event:t})}triggerClick(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=r,u=this._calcActiveCell(s,l,c,d,t,i);u&&this._currentClickedCell$.next({...u,location:en(u.location)})}triggerDbClick(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=r,u=this._calcActiveCell(s,l,c,d,t,i);u&&this._currentDbClickedCell$.next({...u,location:en(u.location)})}triggerScroll(){this._currentCell$.next(null)}triggerRowHeaderClick(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderClick$.next(r)}triggerColHeaderClick(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderClick$.next(r)}triggerRowHeaderDbClick(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderDbClick$.next(r)}triggerColHeaderDbClick(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderDbClick$.next(r)}triggerRowHeaderMouseMove(e,t,i){this._currentHoveredRowHeader$.next(this._calcActiveRowHeader(e,t,i))}triggerColHeaderMouseMove(e,t,i){this._currentHoveredColHeader$.next(this._calcActiveColHeader(e,t,i))}triggerRowHeaderPoniterDown(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderPointerDown$.next(r)}triggerColHeaderPoniterDown(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderPointerDown$.next(r)}triggerRowHeaderPoniterUp(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderPointerUp$.next(r)}triggerColHeaderPoniterUp(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderPointerUp$.next(r)}},y.HoverManagerService=lf([Yc(0,a.IUniverInstanceService),Yc(1,M.IRenderManagerService)],y.HoverManagerService);var cf=Object.getOwnPropertyDescriptor,df=(n,o,e,t)=>{for(var i=t>1?void 0:t?cf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},yo=(n,o)=>(e,t)=>o(e,t,n);const ws="SHEET_FORCE_STRING_ALERT";let Mo=class extends a.Disposable{constructor(n,o,e,t,i){super(),this._context=n,this._hoverManagerService=o,this._cellAlertManagerService=e,this._localeService=t,this._zenZoneService=i,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(n=>{var o;if(n){const t=this._context.unit.getActiveSheet();if(!t)return;const i=t.getCell(n.location.row,n.location.col);if((i==null?void 0:i.t)===a.CellValueType.FORCE_STRING&&i.v&&a.isRealNum(i.v)){const r=this._cellAlertManagerService.currentAlert.get(ws),s=(o=r==null?void 0:r.alert)==null?void 0:o.location;if(s&&s.row===n.location.row&&s.col===n.location.col&&s.subUnitId===n.location.subUnitId&&s.unitId===n.location.unitId)return;this._cellAlertManagerService.showAlert({type:Vn.ERROR,title:this._localeService.t("info.error"),message:this._localeService.t("info.forceStringInfo"),location:n.location,width:200,height:74,key:ws});return}}this._hideAlert()}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(n=>{n&&this._hideAlert()}))}_hideAlert(){this._cellAlertManagerService.removeAlert(ws)}};Mo=df([yo(1,a.Inject(y.HoverManagerService)),yo(2,a.Inject(y.CellAlertManagerService)),yo(3,a.Inject(a.LocaleService)),yo(4,I.IZenZoneService)],Mo);var uf=Object.getOwnPropertyDescriptor,hf=(n,o,e,t)=>{for(var i=t>1?void 0:t?uf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},jc=(n,o)=>(e,t)=>o(e,t,n);let Ro=class extends a.RxDisposable{constructor(n,o,e){super(),this._context=n,this._sheetSkeletonManagerService=o,this._sheetInterceptorService=e,this._initViewModelIntercept()}_initViewModelIntercept(){const n={tl:{size:6,color:"#409f11"}};this.disposeWithMe(this._sheetInterceptorService.intercept(m.INTERCEPTOR_POINT.CELL_CONTENT,{priority:10,effect:a.InterceptorEffectEnum.Style,handler:(o,e,t)=>{var s,l;if(!((s=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:s.skeleton))return t(o);const r=e.worksheet.getCellRaw(e.row,e.col);if(!r||r.v===null||r.v===void 0)return t(o);if(((o==null?void 0:o.t)===a.CellValueType.FORCE_STRING||(o==null?void 0:o.t)===a.CellValueType.STRING)&&a.isRealNum(r.v)){const c=e.workbook.getStyles().get(r.s);return Fi.isTextFormat((l=c==null?void 0:c.n)==null?void 0:l.pattern)?t(o):t({...o,markers:{...o==null?void 0:o.markers,...n}})}return t(o)}}))}};Ro=hf([jc(1,a.Inject(y.SheetSkeletonManagerService)),jc(2,a.Inject(m.SheetInterceptorService))],Ro);var mf=Object.getOwnPropertyDescriptor,Sf=(n,o,e,t)=>{for(var i=t>1?void 0:t?mf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ts=(n,o)=>(e,t)=>o(e,t,n);y.HoverRenderController=class extends a.Disposable{constructor(e,t,i,r){super();T(this,"_active",!1);this._context=e,this._hoverManagerService=t,this._sheetSkeletonManagerService=i,this._scrollManagerService=r,this._initPointerEvent(),this._initScrollEvent()}get active(){return this._active}_initPointerEvent(){const e=new a.DisposableCollection,t=i=>{if(e.dispose(),!i)return;const{mainComponent:r,unitId:s,components:l}=this._context;if(!r)return;e.add(r.onPointerEnter$.subscribeEvent(u=>{this._active=!0})),e.add(a.fromEventSubject(r.onPointerMove$).subscribe(u=>{this._active=!0,this._hoverManagerService.triggerMouseMove(s,u)})),e.add(r.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerDown(s,u)})),e.add(r.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerUp(s,u)})),e.add(r.onClick$.subscribeEvent(u=>{this._hoverManagerService.triggerClick(s,u.offsetX,u.offsetY)})),e.add(r.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerDbClick(s,u.offsetX,u.offsetY)})),e.add(r.onPointerLeave$.subscribeEvent(()=>{this._active=!1}));const c=l.get(ue.ROW),d=l.get(ue.COLUMN);c&&(e.add(c.onPointerMove$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderMouseMove(s,u.offsetX,u.offsetY)})),e.add(c.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderPoniterDown(s,u.offsetX,u.offsetY)})),e.add(c.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderPoniterUp(s,u.offsetX,u.offsetY),this._hoverManagerService.triggerRowHeaderClick(s,u.offsetX,u.offsetY)})),e.add(c.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderDbClick(s,u.offsetX,u.offsetY)}))),d&&(e.add(d.onPointerMove$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderMouseMove(s,u.offsetX,u.offsetY)})),e.add(d.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderPoniterDown(s,u.offsetX,u.offsetY)})),e.add(d.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderPoniterUp(s,u.offsetX,u.offsetY),this._hoverManagerService.triggerColHeaderClick(s,u.offsetX,u.offsetY)})),e.add(d.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderDbClick(s,u.offsetX,u.offsetY)})))};t(this._sheetSkeletonManagerService.getCurrentParam()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(i=>{t(i)}))}_initScrollEvent(){this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(()=>this._hoverManagerService.triggerScroll()))}},y.HoverRenderController=Sf([Ts(1,a.Inject(y.HoverManagerService)),Ts(2,a.Inject(y.SheetSkeletonManagerService)),Ts(3,a.Inject(y.SheetScrollManagerService))],y.HoverRenderController);var gf=Object.getOwnPropertyDescriptor,ff=(n,o,e,t)=>{for(var i=t>1?void 0:t?gf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ys=(n,o)=>(e,t)=>o(e,t,n);let Po=class extends a.Disposable{constructor(n,o,e,t){super(),this._context=n,this._markSelectionService=o,this._commandService=e,this._sheetSkeletonManagerService=t,this._initListeners()}_initListeners(){this._addRemoveListener(),this._addRefreshListener()}_addRemoveListener(){const n=[ge.id];this.disposeWithMe(this._commandService.onCommandExecuted(o=>{n.includes(o.id)?this._markSelectionService.removeAllShapes():this._markSelectionService.getShapeMap().forEach((t,i)=>{t.exits.includes(o.id)&&this._markSelectionService.removeShape(i)})}))}_addRefreshListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(n=>{n&&this._markSelectionService.refreshShapes()}))}};Po=ff([ys(1,a.Inject(Ut)),ys(2,a.ICommandService),ys(3,a.Inject(y.SheetSkeletonManagerService))],Po);const Oo={mobileSheetBarContainer:"univer-mobile-sheet-bar-container",mobileSheetBarSlider:"univer-mobile-sheet-bar-slider",mobileSheetBarItem:"univer-mobile-sheet-bar-item",mobileSheetBarItemActivated:"univer-mobile-sheet-bar-item-activated"};function Gc(){const n=ft();return n?_.jsx(pf,{workbook:n}):null}function pf(n){const{workbook:o}=n,[e,t]=L.useState([]),[i,r]=L.useState(""),s=L.useRef(new Map),l=I.useDependency(a.ICommandService),c=L.useCallback(()=>{const u=o.getActiveSheet().getSheetId(),h=o.getSheets(),S=o.getActiveSheet(),g=h.filter(f=>!f.isSheetHidden()).map((f,p)=>{var v;return{sheetId:f.getSheetId(),label:f.getName(),index:p,selected:S===f,color:(v=f.getTabColor())!=null?v:void 0}});if(t(g),r(u),s.current.has(u)){const f=s.current.get(u);f&&f.scrollIntoView({behavior:"smooth",block:"nearest"})}s.current.clear()},[o]);L.useEffect(()=>c(),[c]);const d=L.useCallback(u=>{l.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:o.getUnitId(),subUnitId:u})},[l,o]);return L.useEffect(()=>{const u=l.onCommandExecuted(h=>{switch(h.id){case m.SetWorksheetHideMutation.id:case m.RemoveSheetMutation.id:case m.SetWorksheetNameMutation.id:case m.InsertSheetMutation.id:case m.SetWorksheetOrderMutation.id:case m.SetWorksheetActiveOperation.id:c();break}});return()=>u.dispose()},[l,c]),_.jsx("div",{className:Oo.mobileSheetBarContainer,children:_.jsx("div",{className:Oo.mobileSheetBarSlider,children:e.map(u=>_.jsx("div",{className:j.clsx(Oo.mobileSheetBarItem,{[Oo.mobileSheetBarItemActivated]:u.sheetId===i}),onClick:()=>d(u.sheetId),ref:h=>{s.current.set(u.sheetId,h)},children:u.label},u.sheetId))})})}const vf={[I.ContextMenuPosition.MAIN_AREA]:{[I.ContextMenuGroup.FORMAT]:{[je.name]:{order:0,menuItemFactory:Pn}},[I.ContextMenuGroup.DATA]:{order:2},[I.ContextMenuGroup.OTHERS]:{order:3}},[I.ContextMenuPosition.COL_HEADER]:{[I.ContextMenuGroup.FORMAT]:{[je.name]:{order:0,menuItemFactory:Pn}},[I.ContextMenuGroup.LAYOUT]:{order:1},[I.ContextMenuGroup.DATA]:{order:2},[I.ContextMenuGroup.OTHERS]:{order:3}},[I.ContextMenuPosition.ROW_HEADER]:{[I.ContextMenuGroup.FORMAT]:{[je.name]:{order:0,menuItemFactory:Pn}},[I.ContextMenuGroup.LAYOUT]:{order:1},[I.ContextMenuGroup.DATA]:{order:2},[I.ContextMenuGroup.OTHERS]:{order:3}}};var Cf=Object.getOwnPropertyDescriptor,If=(n,o,e,t)=>{for(var i=t>1?void 0:t?Cf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},tn=(n,o)=>(e,t)=>o(e,t,n);let Ao=class extends a.Disposable{constructor(n,o,e,t,i,r,s){super(),this._injector=n,this._componentManager=o,this._layoutService=e,this._commandService=t,this._shortcutService=i,this._menuManagerService=r,this._uiPartsService=s,this._init()}_init(){this._initCustomComponents(),this._initCommands(),this._initMenus(),this._initShortcuts(),this._initWorkbenchParts(),this._initFocusHandler()}_initCustomComponents(){const n=this._componentManager;this.disposeWithMe(n.register(Je,ml)),this.disposeWithMe(n.register(cs,zl)),this.disposeWithMe(n.register(fi,j.ColorPicker)),this.disposeWithMe(n.register(So,I.FontFamily)),this.disposeWithMe(n.register(go,I.FontFamilyItem)),this.disposeWithMe(n.register(fo,I.FontSize)),this.disposeWithMe(n.register(ni,Yl))}_initCommands(){[rs,bt,as,ss,dn,ke,Ae,qe,Di,Ri,Nn,Hn,ai,li,Ye,pr,$n,so,m.SetBoldCommand,Nt,ge,Zn,xt,Ft,zt,Xt,Lr,Ur,ci,di,En,m.SetItalicCommand,m.SetStrikeThroughCommand,m.SetFontFamilyCommand,m.SetFontSizeCommand,ui,mo,Tn,hi,Xe,mn,ot,mi,Si,m.SetUnderlineCommand,un,We,Pi,Gn,Zt,Gt,An,On,no,Ct,cn,et,ls,Ti,Kt,qt,yi,Mi,Ai,Qt,Jt,Oi].forEach(n=>{this.disposeWithMe(this._commandService.registerCommand(n))})}_initMenus(){this._menuManagerService.mergeMenu(vf)}_initShortcuts(){[tc,nc,ic,oc,rc,sc,ac,lc,cc,dc,uc,hc,mc,Sc,gc,fc,pc,vc,Cc,Ic,_c,Mc,Pc,Ac,Dc,Rc,Oc,bc,Ec,wc,Tc,yc,...Ba(),Fa,xa,za,Ya,ja,Ga,Xa,$l,ec].forEach(n=>{this.disposeWithMe(this._shortcutService.registerShortcut(n))})}_initWorkbenchParts(){this._uiPartsService.registerComponent(I.BuiltInUIPart.HEADER,()=>I.connectInjector(Gc,this._injector))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(a.UniverInstanceType.UNIVER_SHEET,n=>{}))}};Ao=If([tn(0,a.Inject(a.Injector)),tn(1,a.Inject(I.ComponentManager)),tn(2,I.ILayoutService),tn(3,a.ICommandService),tn(4,I.IShortcutService),tn(5,I.IMenuManagerService),tn(6,I.IUIPartsService)],Ao);const Ms="UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID",Zc="UNIVER_SHEET_PERMISSION_ALERT_DIALOG";var _f=Object.getOwnPropertyDescriptor,bf=(n,o,e,t)=>{for(var i=t>1?void 0:t?_f(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},at=(n,o)=>(e,t)=>o(e,t,n);y.SheetPermissionCheckUIController=class extends a.Disposable{constructor(e,t,i,r,s,l,c,d,u){super();T(this,"disposableCollection",new a.DisposableCollection);this._commandService=e,this._univerInstanceService=t,this._permissionService=i,this._dialogService=r,this._rangeProtectionRuleModel=s,this._autoFillService=l,this._localeService=c,this._contextService=d,this._sheetPermissionCheckController=u,this._initialize(),this._initUIEvent()}_initUIEvent(){this.disposeWithMe(this._sheetPermissionCheckController.triggerPermissionUIEvent$.subscribe(e=>{this._haveNotPermissionHandle(e)}))}_haveNotPermissionHandle(e){const t={id:Ms,title:{title:"permission.dialog.alert"},children:{label:Zc,errorMsg:e},width:320,destroyOnClose:!0,showOk:!0,onClose:()=>{this._dialogService.close(Ms)},onOk:()=>{this._dialogService.close(Ms)},className:"sheet-permission-user-dialog"};this._permissionService.getShowComponents()&&this._dialogService.open(t)}_getPermissionCheck(e,t){var s,l;let i=!0,r="";switch(e){case Q.InsertCommand.id:case Q.IMEInputCommand.id:if(this._contextService.getContextValue(a.FOCUSING_EDITOR_STANDALONE)===!0)break;i=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.editErr");break;case ge.id:if(t.visible===!1)break;i=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.editErr");break;case Bt.id:i=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetColumnStylePermission]}),r=this._localeService.t("permission.dialog.pasteErr");break;case uo.id:i=this._permissionCheckByPaste(t),r=this._localeService.t("permission.dialog.pasteErr");break;case hi.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetCellValuePermission,m.WorksheetSetCellStylePermission]}),r=this._localeService.t("permission.dialog.commonErr");break;case m.SetBackgroundColorCommand.id:case xt.id:case Ft.id:case zt.id:case Xt.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.setStyleErr");break;case je.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission],rangeTypes:[m.RangeProtectionPermissionViewPoint],worksheetTypes:[m.WorksheetCopyPermission]}),r=this._localeService.t("permission.dialog.copyErr"),(s=this._permissionService.getPermissionPoint(new m.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&s.value||(r=this._localeService.t("permission.dialog.workbookCopyErr"));break;case co.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission,m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionViewPoint,m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetCopyPermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.copyErr"),(l=this._permissionService.getPermissionPoint(new m.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&l.value||(r=this._localeService.t("permission.dialog.workbookCopyErr"));break;case Ct.id:i=this._permissionCheckByAutoFillCommand(t),r=this._localeService.t("permission.dialog.autoFillErr");break}i||this._sheetPermissionCheckController.blockExecuteWithoutPermission(r)}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(e=>{this._getPermissionCheck(e.id,e==null?void 0:e.params)}))}_permissionCheckByPaste(e){return e.value===fe.SPECIAL_PASTE_VALUE||e.value===fe.SPECIAL_PASTE_FORMULA?this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}):e.value===fe.SPECIAL_PASTE_FORMAT?this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}):this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]})}_permissionCheckByAutoFillCommand(e){if(!e)return!1;const{targetRange:t}=e,i=m.getSheetCommandTarget(this._univerInstanceService);if(!i)return!1;const{worksheet:r,unitId:s,subUnitId:l}=i;return!this._rangeProtectionRuleModel.getSubunitRuleList(s,l).reduce((u,h)=>[...u,...h.ranges],[]).filter(u=>a.Rectangle.intersects(u,t)).some(u=>{var h,S;for(let g=u.startRow;g<=u.endRow;g++)for(let f=u.startColumn;f<=u.endColumn;f++){const p=(S=(h=r.getCell(g,f))==null?void 0:h.selectionProtection)==null?void 0:S[0];if((p==null?void 0:p[ie.Edit])===!1)return!0}return!1})}},y.SheetPermissionCheckUIController=bf([at(0,a.ICommandService),at(1,a.IUniverInstanceService),at(2,a.IPermissionService),at(3,I.IDialogService),at(4,a.Inject(m.RangeProtectionRuleModel)),at(5,vt),at(6,a.Inject(a.LocaleService)),at(7,a.IContextService),at(8,a.Inject(m.SheetPermissionCheckController))],y.SheetPermissionCheckUIController);var Ef=Object.getOwnPropertyDescriptor,wf=(n,o,e,t)=>{for(var i=t>1?void 0:t?Ef(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},lt=(n,o)=>(e,t)=>o(e,t,n);let Do=class extends a.RxDisposable{constructor(o,e,t,i,r,s,l,c,d,u){super();T(this,"disposableCollection",new a.DisposableCollection);this._context=o,this._univerInstanceService=e,this._permissionService=t,this._selectionManagerService=i,this._rangeProtectionRuleModel=r,this._headerMoveRenderController=s,this._selectionRenderService=l,this._headerFreezeRenderController=c,this._rangeProtectionCache=d,this._headerResizeRenderController=u,this._initHeaderMovePermissionInterceptor(),this._initHeaderResizePermissionInterceptor(),this._initRangeFillPermissionInterceptor(),this._initRangeMovePermissionInterceptor()}_initHeaderMovePermissionInterceptor(){const o=this._headerMoveRenderController.interceptor.getInterceptPoints().HEADER_MOVE_PERMISSION_CHECK;this.disposeWithMe(this._headerMoveRenderController.interceptor.intercept(o,{handler:(e,t)=>{const i=m.getSheetCommandTarget(this._univerInstanceService);if(!i)return!1;const{unitId:r,subUnitId:s}=i;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(r).id,new m.WorksheetEditPermission(r,s).id]).every(c=>c.value))return!1;if(!t)return!0;if(t.rangeType!==a.RANGE_TYPE.ROW&&t.rangeType!==a.RANGE_TYPE.COLUMN)return e;if(t.rangeType===a.RANGE_TYPE.ROW){for(let c=t.startRow;c<=t.endRow;c++)if(this._rangeProtectionCache.getRowPermissionInfo(r,s,c,[ie.Edit])===!1)return!1}else for(let c=t.startColumn;c<=t.endColumn;c++)if(this._rangeProtectionCache.getColPermissionInfo(r,s,c,[ie.Edit])===!1)return!1;return!0}}))}_initHeaderResizePermissionInterceptor(){this._headerResizeRenderController&&this.disposeWithMe(this._headerResizeRenderController.interceptor.intercept(this._headerResizeRenderController.interceptor.getInterceptPoints().HEADER_RESIZE_PERMISSION_CHECK,{handler:(o,e)=>{var s,l,c,d;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{unitId:i,subUnitId:r}=t;if(e.row){if(((l=(s=this._permissionService.getPermissionPoint(new m.WorksheetSetRowStylePermission(i,r).id))==null?void 0:s.value)!=null?l:!1)===!1)return!1}else if(e.col&&((d=(c=this._permissionService.getPermissionPoint(new m.WorksheetSetColumnStylePermission(i,r).id))==null?void 0:c.value)!=null?d:!1)===!1)return!1;return!0}}))}_initRangeFillPermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_FILL_PERMISSION_CHECK,{handler:(o,e)=>{var f,p,v;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:i,unitId:r,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(r).id,new m.WorksheetEditPermission(r,s).id,new m.WorksheetSetCellValuePermission(r,s).id,new m.WorksheetSetCellStylePermission(r,s).id]).every(C=>C.value))return!1;const c=(f=this._selectionManagerService.getCurrentSelections())==null?void 0:f.map(C=>C.range),d=c==null?void 0:c.find(C=>{const b=Kn(e.x,e.y,e.scene,e.skeleton),E=e.skeleton.getCellWithCoordByIndex(C.endRow,C.endColumn),w=Math.abs(E.endX-b.x),O=Math.abs(E.endY-b.y);return w<=5&&O<=5});if(!d)return!0;const{startRow:u,endRow:h,startColumn:S,endColumn:g}=d;for(let C=u;C<=h;C++)for(let b=S;b<=g;b++){const E=(v=(p=i.getCell(C,b))==null?void 0:p.selectionProtection)==null?void 0:v[0];if((E==null?void 0:E[ie.Edit])===!1||(E==null?void 0:E[ie.View])===!1)return!1}return!0}}))}_initRangeMovePermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_MOVE_PERMISSION_CHECK,{handler:(o,e)=>{var S;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:i,unitId:r,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(r).id,new m.WorksheetEditPermission(r,s).id]).every(g=>g.value))return!1;const c=(S=this._selectionManagerService.getCurrentSelections())==null?void 0:S.map(g=>g.range),d=this._rangeProtectionRuleModel.getSubunitRuleList(r,s).reduce((g,f)=>[...g,...f.ranges],[]),u=c==null?void 0:c.filter(g=>d.some(f=>a.Rectangle.intersects(f,g)));return!(u==null?void 0:u.some(g=>{var b,E;const{startRow:f,startColumn:p,endRow:v,endColumn:C}=g;for(let w=f;w<=v;w++)for(let O=p;O<=C;O++){const R=(E=(b=i.getCell(w,O))==null?void 0:b.selectionProtection)==null?void 0:E[0];if((R==null?void 0:R[ie.Edit])===!1)return!0}return!1}))}}))}_initFreezePermissionInterceptor(){this.disposeWithMe(this._headerFreezeRenderController.interceptor.intercept(this._headerFreezeRenderController.interceptor.getInterceptPoints().FREEZE_PERMISSION_CHECK,{handler:(o,e)=>{var s,l;const t=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);return!(t==null?void 0:t.getActiveSheet())||!t?!1:(l=(s=this._permissionService.getPermissionPoint(new m.WorkbookEditablePermission(t.getUnitId()).id))==null?void 0:s.value)!=null?l:!1}}))}};Do=wf([lt(1,a.IUniverInstanceService),lt(2,a.IPermissionService),lt(3,a.Inject(m.SheetsSelectionsService)),lt(4,a.Inject(m.RangeProtectionRuleModel)),lt(5,a.Inject(y.HeaderMoveRenderController)),lt(6,ve),lt(7,a.Inject(y.HeaderFreezeRenderController)),lt(8,a.Inject(m.RangeProtectionCache)),lt(9,a.Optional(y.HeaderResizeRenderController))],Do);var Tf=Object.getOwnPropertyDescriptor,yf=(n,o,e,t)=>{for(var i=t>1?void 0:t?Tf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ni=(n,o)=>(e,t)=>o(e,t,n);const Mf="SHEET_PERMISSION_PASTE_PLUGIN";let Hi=class extends a.Disposable{constructor(o,e,t,i,r){super();T(this,"disposableCollection",new a.DisposableCollection);this._univerInstanceService=o,this._selectionManagerService=e,this._localService=t,this._sheetClipboardService=i,this._sheetPermissionCheckController=r,this._initClipboardHook()}_initClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook({id:Mf,onBeforePaste:o=>{var S,g,f;const[e]=Ot([o.range]).ranges,t=(S=this._selectionManagerService.getCurrentLastSelection())==null?void 0:S.range;if(!t)return!1;const i={startRow:t.startRow+e.startRow,endRow:t.startRow+e.endRow,startColumn:t.startColumn+e.startColumn,endColumn:t.startColumn+e.endColumn},s=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!s)return!1;const{startRow:l,endRow:c,startColumn:d,endColumn:u}=i;let h=!0;for(let p=l;p<=c;p++)for(let v=d;v<=u;v++){const C=(f=(g=s.getCell(p,v))==null?void 0:g.selectionProtection)==null?void 0:f[0];if((C==null?void 0:C[ie.Edit])===!1){h=!1;break}}return h||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localService.t("permission.dialog.pasteErr")),h}}))}};Hi=yf([Ni(0,a.IUniverInstanceService),Ni(1,a.Inject(m.SheetsSelectionsService)),Ni(2,a.Inject(a.LocaleService)),Ni(3,a.Inject(Be)),Ni(4,a.Inject(m.SheetPermissionCheckController))],Hi);var Rf=Object.getOwnPropertyDescriptor,Pf=(n,o,e,t)=>{for(var i=t>1?void 0:t?Rf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Vi=(n,o)=>(e,t)=>o(e,t,n);const Of=a.createInterceptorKey("statusBarPermissionCorrect");class Af{constructor(){T(this,"_sum",0);T(this,"_count",0);T(this,"_countNumber",0);T(this,"_min",Number.POSITIVE_INFINITY);T(this,"_max",Number.NEGATIVE_INFINITY)}add(o,e,t){if(!(o!=null&&o.v))return;const i=o==null?void 0:o.t;let{v:r}=o;const s=c=>{this._sum+=c,this._countNumber++,this._min=Math.min(this._min,c),this._max=Math.max(this._max,c)},l=(c,d,u)=>{var g;if(!((g=c==null?void 0:c.n)!=null&&g.pattern))return;const{pattern:h}=c.n;u[h]||(u[h]=a.numfmt.getInfo(h)),u[h].isDate&&s(d)};if(typeof r=="string"&&i===a.CellValueType.NUMBER){const c=Number(r);Number.isNaN(c)||(r=c)}if(typeof r=="number"&&i!==a.CellValueType.STRING)s(r);else if(i===a.CellValueType.NUMBER&&o.s){const c=e.get(o.s);l(c,r,t)}this._count++}getResults(){return{sum:this._sum,count:this._countNumber,countA:this._count,min:this._min,max:this._max}}}function Df(n){const{sum:o,count:e,countA:t,min:i,max:r}=n.getResults();return[{func:q.FUNCTION_NAMES_STATISTICAL.MAX,value:r},{func:q.FUNCTION_NAMES_STATISTICAL.MIN,value:i},{func:q.FUNCTION_NAMES_MATH.SUM,value:o},{func:q.FUNCTION_NAMES_STATISTICAL.COUNTA,value:t},{func:q.FUNCTION_NAMES_STATISTICAL.COUNT,value:e},{func:q.FUNCTION_NAMES_STATISTICAL.AVERAGE,value:o/e}]}y.StatusBarController=class extends a.Disposable{constructor(e,t,i,r,s){super();T(this,"interceptor",new a.InterceptorManager({STATUS_BAR_PERMISSION_CORRECT:Of}));this._univerInstanceService=e,this._selectionManagerService=t,this._statusBarService=i,this._commandService=r,this._numfmtService=s,this._init()}_init(){this._registerSelectionListener()}_registerSelectionListener(){const e=a.debounce(i=>{var s;const r=(s=i[i.length-1])==null?void 0:s.primary;this._calculateSelection(i.map(l=>l.range),r)},100),t=a.debounce(i=>{var s;const r=(s=i[i.length-1])==null?void 0:s.primary;this._calculateSelection(i.map(l=>l.range),r)},500);this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoving$.subscribe(i=>{i&&t(i)}))),this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoveEnd$.subscribe(i=>{i&&e(i)}))),this.disposeWithMe(this._commandService.onCommandExecuted(i=>{if(i.id===m.SetRangeValuesMutation.id){const r=this._selectionManagerService.getCurrentSelections();r&&e(r)}}))}_clearResult(){this._statusBarService.setState(null)}getRangeStartEndInfo(e,t){return e.rangeType===a.RANGE_TYPE.ALL?{startRow:0,startColumn:0,endRow:t.getRowCount()-1,endColumn:t.getColumnCount()-1}:e.rangeType===a.RANGE_TYPE.COLUMN?{startRow:0,startColumn:e.startColumn,endRow:t.getRowCount()-1,endColumn:e.endColumn}:e.rangeType===a.RANGE_TYPE.ROW?{startRow:e.startRow,startColumn:0,endRow:e.endRow,endColumn:t.getColumnCount()-1}:{startRow:e.startRow,startColumn:e.startColumn,endRow:e.endRow,endColumn:e.endColumn}}_calculateSelection(e,t){var d;const i=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!i)return this._clearResult();const r=i.getUnitId(),s=i.getActiveSheet(),l=s==null?void 0:s.getSheetId();if(!l)return this._clearResult();const c={};if(this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getSheets().forEach(u=>{const h=u.getConfig();c[u.getSheetId()]={cellData:new a.ObjectMatrix(h.cellData),rowCount:h.rowCount,columnCount:h.columnCount,rowData:h.rowData,columnData:h.columnData}}),e!=null&&e.length){const u=[];e.forEach(E=>{const{startRow:w,endRow:O}=E;let R=null;for(let P=w;P<=O;P++)s.getRowVisible(P)?R===null&&(R=P):R!==null&&(u.push({...E,startRow:R,endRow:P-1}),R=null);R!==null&&u.push({...E,startRow:R,endRow:O})});const h=a.splitIntoGrid(u),S=new Af,g=i.getStyles(),f={};for(const E of h){const{startRow:w,startColumn:O,endColumn:R,endRow:P}=this.getRangeStartEndInfo(E,s);for(let A=w;A<=P;A++)for(let k=O;k<=R;k++){const N=s.getCellRaw(A,k);S.add(N,g,f)}}const p=Df(S);if(p.every(E=>E===void 0))return;let v=null;if(t){const{actualRow:E,actualColumn:w}=t;v=(d=this._numfmtService.getValue(r,l,E,w))==null?void 0:d.pattern}const b={values:p.filter(E=>E!==void 0),pattern:v};this._statusBarService.setState(b)}else this._clearResult()}},y.StatusBarController=Pf([Vi(0,a.IUniverInstanceService),Vi(1,a.Inject(m.SheetsSelectionsService)),Vi(2,ii),Vi(3,a.ICommandService),Vi(4,a.Inject(m.INumfmtService))],y.StatusBarController);var kf=Object.getOwnPropertyDescriptor,Nf=(n,o,e,t)=>{for(var i=t>1?void 0:t?kf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ko=(n,o)=>(e,t)=>o(e,t,n);let No=class extends a.RxDisposable{constructor(o,e,t,i,r){super();T(this,"disposableCollection",new a.DisposableCollection);this._context=o,this._univerInstanceService=e,this._permissionService=t,this._statusBarController=i,this._rangeProtectionCache=r,this._initStatusBarPermissionInterceptor()}_initStatusBarPermissionInterceptor(){this.disposeWithMe(this._statusBarController.interceptor.intercept(this._statusBarController.interceptor.getInterceptPoints().STATUS_BAR_PERMISSION_CORRECT,{priority:100,handler:(o,e)=>{var c;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return o!=null?o:[];const{worksheet:i,unitId:r,subUnitId:s}=t;return((c=this._permissionService.getPermissionPoint(new m.WorksheetViewPermission(r,s).id))==null?void 0:c.value)===!1?e.forEach(d=>{const u=d.getArrayValue();u.forEach((h,S)=>{h.forEach((g,f)=>{u[S][f]=q.NullValueObject.create()})})}):e.forEach(d=>{const u=d.getArrayValue(),h=d.getCurrentRow(),S=d.getCurrentColumn();u.forEach((g,f)=>{g.forEach((p,v)=>{var E;if(((E=i.getCellRaw(f+h,v+S))==null?void 0:E.v)===void 0)return;const b=this._rangeProtectionCache.getCellInfo(r,s,f+h,v+S);(b==null?void 0:b[ie.View])===!1&&(u[f][v]=q.NullValueObject.create())})})}),e}}))}};No=Nf([ko(1,a.IUniverInstanceService),ko(2,a.IPermissionService),ko(3,a.Inject(y.StatusBarController)),ko(4,a.Inject(m.RangeProtectionCache))],No);const Kc=(n,o,e,t,i)=>{const r=n.get(a.LocaleService),s=n.get(m.WorksheetProtectionRuleModel),l=n.get(m.RangeProtectionRuleModel);let c="";if(o.length===0)c=r.t("permission.panel.emptyRangeError");else if(o.length>1){let d=!1;for(let u=0;u<o.length;u++){for(let h=u+1;h<o.length;h++)if(a.Rectangle.intersects(o[u],o[h])){d=!0;break}if(d)break}d&&(c=r.t("permission.panel.rangeOverlapError"))}if(!c){if(s.getRule(t,i)&&!e)return c=r.t("permission.panel.rangeOverlapOverPermissionError"),c;const u=l.getSubunitRuleList(t,i).filter(S=>S.permissionId!==e).find(S=>S.ranges.some(g=>o.some(f=>a.Rectangle.intersects(g,f))));(u==null?void 0:u.ranges.find(S=>o.some(g=>a.Rectangle.intersects(S,g))))&&(c=r.t("permission.panel.rangeOverlapOverPermissionError"))}return c===""?void 0:c},Hf=(n,o)=>{if(n.length!==1)return!1;const e=n[0],t=o.getRowCount(),i=o.getColumnCount(),{startRow:r,endRow:s,startColumn:l,endColumn:c}=e;return r===0&&l===0&&s===t-1&&c===i-1},Vf=(n,o)=>{var c,d;const e=n.get(a.IUniverInstanceService),t=n.get(m.SheetsSelectionsService),i=e.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),r=i.getActiveSheet();let s=m.UnitObject.SelectRange,l=(d=(c=t.getCurrentSelections())==null?void 0:c.map(u=>u.range))!=null?d:[];return o&&(s=m.UnitObject.Worksheet,l=[{startRow:0,startColumn:0,endRow:r.getRowCount()-1,endColumn:r.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]),{unitId:i.getUnitId(),subUnitId:r.getSheetId(),permissionId:"",unitType:s,description:"",id:"",ranges:l,editState:m.EditStateEnum.OnlyMe,viewState:m.ViewStateEnum.OthersCanView}},Wf=(n,o)=>{const i=n.get(a.IUniverInstanceService).getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getActiveSheet(),{unitType:r}=o;return r===m.UnitObject.Worksheet?{...o,ranges:[{startRow:0,startColumn:0,endRow:i.getRowCount()-1,endColumn:i.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]}:o},Ce={permissionPanelDetailWrapper:"univer-permission-panel-detail-wrapper",radioGroupVertical:"univer-radio-group-vertical",sheetPermissionDesignPersonPanel:"univer-sheet-permission-design-person-panel",sheetPermissionDesignPersonPanelHeader:"univer-sheet-permission-design-person-panel-header",sheetPermissionDesignPersonPanelHeaderAdd:"univer-sheet-permission-design-person-panel-header-add",sheetPermissionDesignPersonPanelSplit:"univer-sheet-permission-design-person-panel-split",sheetPermissionDesignPersonPanelContentItem:"univer-sheet-permission-design-person-panel-content-item",sheetPermissionDesignPersonPanelContentItemName:"univer-sheet-permission-design-person-panel-content-item-name",sheetPermissionDesignPersonPanelContentItemSelect:"univer-sheet-permission-design-person-panel-content-item-select",sheetPermissionDesignPersonPanelContent:"univer-sheet-permission-design-person-panel-content",sheetPermissionUserListEmpty:"univer-sheet-permission-user-list-empty",sheetPermissionUserListEmptyText:"univer-sheet-permission-user-list-empty-text",sheetPermissionPanelTitle:"univer-sheet-permission-panel-title",sheetPermissionPanelFooter:"univer-sheet-permission-panel-footer"},Lf=n=>{const{viewState:o,editState:e,permissionId:t,ranges:i,rangesErrMsg:r,desc:s,oldRule:l,id:c}=n,d=I.useDependency(kn),u=I.useDependency(I.ISidebarService),h=I.useDependency(a.IAuthzIoService),S=I.useDependency(a.LocaleService),g=I.useDependency(a.ICommandService),f=I.useDependency(Et),v=I.useDependency(a.IUniverInstanceService).getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),C=v==null?void 0:v.getActiveSheet();if(!v||!C)return null;const b=v.getUnitId(),E=C.getSheetId();return _.jsxs("div",{className:Ce.sheetPermissionPanelFooter,children:[_.jsx(j.Button,{variant:"primary",onClick:async()=>{if(r)return;const w={unitId:b,subUnitId:E,permissionId:t,id:c,viewState:o,editState:e,unitType:m.UnitObject.SelectRange,ranges:i,description:s};Hf(i,C)&&(w.unitType=m.UnitObject.Worksheet,w.ranges=[]);let R=f.selectUserList;w.editState===m.EditStateEnum.OnlyMe&&(R=[],f.setSelectUserList([]));const P={read:w.viewState===m.ViewStateEnum.OthersCanView?$e.AllCollaborator:$e.SomeCollaborator,edit:w.editState===m.EditStateEnum.DesignedUserCanEdit?$e.SomeCollaborator:$e.OneSelf};if(w.editState===m.EditStateEnum.DesignedUserCanEdit&&R.length===0&&(R=[],P.edit=$e.OneSelf),w.permissionId){const k=bS(R.filter(W=>W.role===He.Editor),f.oldCollaboratorList.filter(W=>W.role===He.Editor)),N=(l==null?void 0:l.viewState)===w.viewState,H=(l==null?void 0:l.editState)===w.editState,V=w.unitType===(l==null?void 0:l.unitType)&&w.description===l.description&&w.ranges===l.ranges,U=!k||!N||!H;if(V&&U)await h.update({objectType:w.unitType,objectID:w.permissionId,unitID:w.unitId,share:void 0,name:"",strategies:[],scope:P,collaborators:{collaborators:R}});else{let W=w.permissionId;U&&(w.unitType===m.UnitObject.Worksheet?W=await h.create({worksheetObject:{collaborators:R,unitID:w.unitId,name:"",strategies:[{role:He.Editor,action:ie.Edit},{role:He.Reader,action:ie.View}],scope:P},objectType:m.UnitObject.Worksheet}):W=await h.create({selectRangeObject:{collaborators:R,unitID:w.unitId,name:"",scope:P},objectType:m.UnitObject.SelectRange})),g.executeCommand(m.SetProtectionCommand.id,{rule:{...w,permissionId:W},oldRule:l})}}else if(w.unitType===m.UnitObject.Worksheet){const k=await h.create({worksheetObject:{collaborators:R,unitID:w.unitId,name:"",strategies:[{role:He.Editor,action:ie.Edit},{role:He.Reader,action:ie.View}],scope:P},objectType:m.UnitObject.Worksheet}),{ranges:N=[],...H}=w;H.permissionId=k,g.executeCommand(m.AddWorksheetProtectionCommand.id,{rule:H,unitId:w.unitId})}else if(w.unitType===m.UnitObject.SelectRange){const k=await h.create({selectRangeObject:{collaborators:R,unitID:w.unitId,name:"",scope:P},objectType:m.UnitObject.SelectRange});g.executeCommand(m.AddRangeProtectionCommand.id,{rule:w,permissionId:k})}const A={header:{title:`${S.t("permission.panel.title")}`},children:{label:wi,showDetail:!1},width:330};u.open(A)},children:S.t("permission.button.confirm")}),_.jsx(j.Button,{className:Ce.sheetPermissionPanelFooterCancel,onClick:()=>{d.reset(),f.reset(),u.close()},children:S.t("permission.button.cancel")})]})},Uf=n=>{const{ranges:o,onRangesChange:e,desc:t,onDescChange:i,rangesErrMsg:r,permissionId:s}=n,l=I.useDependency(I.ComponentManager),c=L.useMemo(()=>l.get(Jo),[]),d=I.useDependency(a.IUniverInstanceService),u=I.useDependency(a.LocaleService),h=I.useDependency(a.Injector),S=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),g=S==null?void 0:S.getActiveSheet();if(!S||!g)return null;const f=S.getUnitId(),p=g.getSheetId(),v=C=>{const b=C.split(",").map(q.deserializeRangeWithSheet).map(k=>k.range);if(b.some(k=>!a.isValidRange(k)||k.endColumn<k.startColumn||k.endRow<k.startRow))return;const E=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),w=E==null?void 0:E.getActiveSheet();if(!E||!w)return;const O=E.getUnitId(),R=w.getSheetId(),P=b.map(k=>{const N=w.getRowCount(),H=w.getColumnCount();return m.setEndForRange(k,N,H),k}),A=Kc(h,P,s,O,R);e(P,A)};return _.jsxs(_.Fragment,{children:[_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:u.t("permission.panel.protectedRange"),error:r,children:c&&_.jsx(c,{unitId:f,subUnitId:p,initialValue:o==null?void 0:o.map(C=>q.serializeRange(C)).join(","),onChange:(C,b)=>v(b)})}),_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:u.t("permission.panel.permissionDirection"),children:_.jsx(j.Input,{value:t,onChange:C=>i(C),placeholder:u.t("permission.panel.permissionDirectionPlaceholder")})})]})},Bf=n=>{var C,b;const{fromSheetBar:o,rule:e,oldRule:t}=n,i=I.useDependency(a.Injector),r=e?Wf(i,e):Vf(i,o),[s,l]=L.useState(r.ranges),[c,d]=L.useState(()=>Kc(i,r.ranges,r.permissionId,r.unitId,r.subUnitId)),[u,h]=L.useState(r.description),[S,g]=L.useState((C=r.editState)!=null?C:m.EditStateEnum.OnlyMe),[f,p]=L.useState((b=r.viewState)!=null?b:m.ViewStateEnum.OthersCanView),v=I.useComponentsOfPart(Dn);return L.useEffect(()=>{const E=i.get(a.IUniverInstanceService),w=i.get(I.ISidebarService),O=E.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!O)return;const R=O.getActiveSheet().getSheetId(),P=O.activeSheet$.subscribe(A=>{(A==null?void 0:A.getSheetId())!==R&&w.close()});return()=>{P.unsubscribe()}},[]),_.jsxs("div",{className:Ce.permissionPanelDetailWrapper,children:[_.jsx(Uf,{permissionId:r.permissionId,ranges:s,onRangesChange:(E,w)=>{l(E),d(w)},rangesErrMsg:c,desc:u,onDescChange:E=>h(E)}),_.jsx(I.ComponentContainer,{components:v,sharedProps:{editState:S,onEditStateChange:E=>g(E),viewState:f,onViewStateChange:E=>p(E),permissionId:r.permissionId}},"user-part"),_.jsx(Lf,{permissionId:r.permissionId,id:r.id,ranges:s,rangesErrMsg:c,desc:u,viewState:f,editState:S,oldRule:t})]})},xf="",he={sheetPermissionListPanelWrapper:"univer-sheet-permission-list-panel-wrapper",sheetPermissionListPanelHeader:"univer-sheet-permission-list-panel-header",sheetPermissionListPanelHeaderType:"univer-sheet-permission-list-panel-header-type",sheetPermissionListPanelHeaderTypeBottom:"univer-sheet-permission-list-panel-header-type-bottom",sheetPermissionListPanelHeaderSelect:"univer-sheet-permission-list-panel-header-select",sheetPermissionListItemHeaderIcon:"univer-sheet-permission-list-item-header-icon",sheetPermissionListItem:"univer-sheet-permission-list-item",sheetPermissionListItemHeader:"univer-sheet-permission-list-item-header",sheetPermissionListItemHeaderName:"univer-sheet-permission-list-item-header-name",sheetPermissionListItemHeaderOperator:"univer-sheet-permission-list-item-header-operator",sheetPermissionListItemSplit:"univer-sheet-permission-list-item-split",sheetPermissionListItemContentEdit:"univer-sheet-permission-list-item-content-edit",sheetPermissionListItemContentView:"univer-sheet-permission-list-item-content-view",sheetPermissionListItemContentDesc:"univer-sheet-permission-list-item-content-desc",sheetPermissionListEmpty:"univer-sheet-permission-list-empty",sheetPermissionListEmptyText:"univer-sheet-permission-list-empty-text",sheetPermissionListItemContentTitle:"univer-sheet-permission-list-item-content-title",sheetPermissionListItemContentSub:"univer-sheet-permission-list-item-content-sub",sheetPermissionPanelAddWrapper:"univer-sheet-permission-panel-add-wrapper",sheetPermissionPanelAddButton:"univer-sheet-permission-panel-add-button"},Ff=()=>{var U;const[n,o]=L.useState(!0),[e,t]=L.useState(!1),i=I.useDependency(a.LocaleService),r=I.useDependency(m.RangeProtectionRuleModel),s=I.useDependency(m.WorksheetProtectionRuleModel),l=I.useDependency(a.IUniverInstanceService),c=I.useDependency(a.ICommandService),d=I.useDependency(I.ISidebarService),u=I.useDependency(a.IAuthzIoService),h=I.useDependency(a.IPermissionService),g=I.useDependency(a.UserManagerService).getCurrentUser(),[f,p]=L.useState([]),v=I.useDependency(Et),C=I.useObservable(s.ruleRefresh$,""),b=I.useObservable(r.ruleRefresh$,""),E=l.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!E)return null;const w=E==null?void 0:E.getUnitId(),O=L.useCallback(async W=>{var Z;const B=E.getActiveSheet(),x=E.getUnitId(),X=B.getSheetId(),F=[],Y=[];E.getSheets().forEach(G=>{const J=G.getSheetId();r.getSubunitRuleList(x,J).forEach(re=>{re.permissionId&&F.push(re.permissionId)});const de=s.getRule(x,J);de!=null&&de.permissionId&&Y.push(de.permissionId)});const z=[...F,...Y],K=await u.list({objectIDs:z,unitID:x,actions:m.baseProtectionActions}),ee=r.getSubunitRuleList(x,X).map(G=>G.permissionId),$=(Z=s.getRule(x,X))==null?void 0:Z.permissionId;$&&ee.push($);const ae=K.filter(G=>{var J;return ee.includes(G.objectID)||G.objectID===((J=s.getRule(x,X))==null?void 0:J.permissionId)});return W?ae:K},[]),[R,P]=L.useState([]);L.useEffect(()=>{const W=D.merge(r.ruleChange$,s.ruleChange$).subscribe(async()=>{const B=await O(n);P(B)});return()=>{W.unsubscribe()}},[n]),L.useEffect(()=>{const W=E.activeSheet$.pipe(D.distinctUntilChanged((B,x)=>(B==null?void 0:B.getSheetId())===(x==null?void 0:x.getSheetId()))).subscribe(async()=>{const B=await O(n);P(B)});return()=>{W.unsubscribe()}},[n]),L.useEffect(()=>{(async()=>{if(C||b){const B=await O(!0);P(B)}})()},[C,b]);const A=W=>{const{unitId:B,subUnitId:x,unitType:X}=W;let F;X===rt.Worksheet?F=c.executeCommand(m.DeleteWorksheetProtectionCommand.id,{unitId:B,subUnitId:x,rule:W}):X===rt.SelectRange&&(F=c.executeCommand(m.DeleteRangeProtectionCommand.id,{unitId:B,subUnitId:x,rule:W})),F&&(t(!e),W.ranges===f&&p([]))};L.useEffect(()=>{v.reset()},[]),kc(f);const k=new Map;E.getSheets().forEach(W=>{const B=W.getSheetId();r.getSubunitRuleList(w,B).forEach(F=>{k.set(F.permissionId,F)});const X=s.getRule(w,B);X&&k.set(X==null?void 0:X.permissionId,X)});const N=W=>{W.subUnitId!==E.getActiveSheet().getSheetId()&&c.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:W.unitId,subUnitId:W.subUnitId});const B={header:{title:"permission.panel.title"},children:{label:wi,showDetail:!0,rule:a.Tools.deepClone(W),oldRule:a.Tools.deepClone(W)},width:330};d.open(B)},H=W=>{o(W)},V=(U=h.getPermissionPoint(new m.WorkbookCreateProtectPermission(w).id))==null?void 0:U.value;return _.jsxs("div",{className:he.sheetPermissionListPanelWrapper,children:[_.jsxs("div",{className:he.sheetPermissionListPanelHeader,children:[_.jsxs("div",{className:he.sheetPermissionListPanelHeaderType,onClick:()=>H(!0),children:[_.jsx("div",{className:j.clsx({[he.sheetPermissionListPanelHeaderSelect]:n}),children:i.t("permission.panel.currentSheet")}),n&&_.jsx("div",{className:he.sheetPermissionListPanelHeaderTypeBottom})]}),_.jsxs("div",{className:he.sheetPermissionListPanelHeaderType,onClick:()=>H(!1),children:[_.jsx("div",{className:j.clsx({[he.sheetPermissionListPanelHeaderSelect]:!n}),children:i.t("permission.panel.allSheet")}),!n&&_.jsx("div",{className:he.sheetPermissionListPanelHeaderTypeBottom})]})]}),(R==null?void 0:R.length)>0?_.jsx("div",{className:he.sheetPermissionListPanelContent,children:R==null?void 0:R.map(W=>{var J,oe,de,re,se;const B=k.get(W.objectID);if(!B)return null;const x=W.actions.find(ne=>ne.action===ie.Edit),X=x==null?void 0:x.allowed,F=W.actions.find(ne=>ne.action===ie.View),Y=F==null?void 0:F.allowed,z=W.actions.find(ne=>ne.action===ie.ManageCollaborator),K=W.actions.find(ne=>ne.action===ie.Delete),ee=(z==null?void 0:z.allowed)||g.userID===((J=W.creator)==null?void 0:J.userID),$=(K==null?void 0:K.allowed)||g.userID===((oe=W.creator)==null?void 0:oe.userID);let ae="";const Z=E.getSheetBySheetId(B.subUnitId),G=Z==null?void 0:Z.getName();if(B.unitType===rt.SelectRange){const ne=B.ranges,pe=ne!=null&&ne.length?ne.map(Ie=>{const ye=q.serializeRange(Ie);return ye==="NaN"?"":ye}).filter(Ie=>!!Ie).join(","):"";ae=`${G}(${pe})`}else B.unitType===rt.Worksheet&&(ae=G||"");return _.jsxs("div",{className:he.sheetPermissionListItem,onMouseMove:()=>{const{subUnitId:ne,unitType:pe}=B,Ie=E.getActiveSheet();if(!Ie)return!1;const ye=Ie.getSheetId();if(ne!==ye)return!1;if(pe===rt.SelectRange){const Me=B.ranges||[];Me!==f&&p(Me)}else if(pe===rt.Worksheet){const Me=[{startRow:0,endRow:Ie.getRowCount()-1,startColumn:0,endColumn:Ie.getColumnCount()-1}];Me!==f&&p(Me)}},onMouseLeave:()=>p([]),children:[_.jsxs("div",{className:he.sheetPermissionListItemHeader,children:[_.jsx(j.Tooltip,{title:ae,children:_.jsx("div",{className:he.sheetPermissionListItemHeaderName,children:ae})}),(ee||$)&&_.jsxs("div",{className:he.sheetPermissionListItemHeaderOperator,children:[ee&&_.jsx(j.Tooltip,{title:i.t("permission.panel.edit"),children:_.jsx("div",{className:he.sheetPermissionListItemHeaderIcon,onClick:()=>N(B),children:_.jsx(Tr,{})})}),$&&_.jsx(j.Tooltip,{title:i.t("permission.panel.delete"),children:_.jsx("div",{className:he.sheetPermissionListItemHeaderIcon,onClick:()=>A(B),children:_.jsx(eo,{})})})]})]}),_.jsx("div",{className:he.sheetPermissionListItemSplit}),_.jsxs("div",{className:he.sheetPermissionListItemContent,children:[_.jsxs("div",{className:he.sheetPermissionListItemContentEdit,children:[_.jsx(j.Tooltip,{title:(re=(de=W.creator)==null?void 0:de.name)!=null?re:"",children:_.jsx("div",{children:_.jsx(j.Avatar,{src:(se=W.creator)==null?void 0:se.avatar,style:{marginRight:6},size:24})})}),_.jsx("span",{className:he.sheetPermissionListItemContentTitle,children:i.t("permission.panel.created")}),_.jsx("span",{className:he.sheetPermissionListItemContentSub,children:X?`${i.t("permission.panel.iCanEdit")}`:`${i.t("permission.panel.iCanNotEdit")}`})]}),_.jsxs("div",{className:he.sheetPermissionListItemContentView,children:[_.jsx("span",{className:he.sheetPermissionListItemContentTitle,children:i.t("permission.panel.viewPermission")}),_.jsx("span",{className:he.sheetPermissionListItemContentSub,children:Y?`${i.t("permission.panel.iCanView")}`:`${i.t("permission.panel.iCanNotView")}`})]}),B.description&&_.jsx(j.Tooltip,{title:B.description,children:_.jsx("div",{className:he.sheetPermissionListItemContentDesc,children:B.description})})]})]},W.objectID)})}):_.jsxs("div",{className:he.sheetPermissionListEmpty,children:[_.jsx("img",{width:240,height:120,src:xf,alt:""}),_.jsx("p",{className:he.sheetPermissionListEmptyText,children:i.t("permission.dialog.listEmpty")})]}),V&&_.jsx("div",{className:he.sheetPermissionPanelAddWrapper,children:_.jsxs(j.Button,{className:he.sheetPermissionPanelAddButton,variant:"primary",onClick:()=>{const W={header:{title:`${i.t("permission.panel.title")}`},children:{label:wi,showDetail:!0},width:330};d.open(W)},children:[_.jsx("div",{children:"+ "}),i.t("permission.button.addNewPermission")]})})]})},zf=({showDetail:n,fromSheetBar:o,rule:e,oldRule:t})=>{var h;const i=I.useDependency(a.IUniverInstanceService),r=I.useDependency(m.SheetsSelectionsService);if(!I.useDependency(kn).getVisible())return null;const l=m.getSheetCommandTarget(i);if(!l)return null;const{worksheet:c}=l,u=((h=r.getCurrentSelections())==null?void 0:h.map(S=>S.range)).reduce((S,g)=>S+q.serializeRangeWithSheet(c.getName(),g),"");return n?_.jsx(Bf,{fromSheetBar:o,rule:e,oldRule:t},o?"sheet-bar":"normal"):_.jsx(Ff,{},u)},Ho={spinContainer:"univer-spin-container",spinOverlay:"univer-spin-overlay",spinner:"univer-spinner",contentBlur:"univer-content-blur"},Xf=({loading:n,children:o})=>_.jsxs("div",{className:Ho.spinContainer,children:[n&&_.jsx("div",{className:Ho.spinOverlay,children:_.jsx("div",{className:Ho.spinner})}),_.jsx("div",{className:n?Ho.contentBlur:"",children:o})]}),Tt={sheetPermissionDialogWrapper:"univer-sheet-permission-dialog-wrapper",sheetPermissionDialogSplit:"univer-sheet-permission-dialog-split",sheetPermissionDialogItem:"univer-sheet-permission-dialog-item",sheetPermissionUserDialogFooter:"univer-sheet-permission-user-dialog-footer",sheetPermissionUserDialogFooterConfirm:"univer-sheet-permission-user-dialog-footer-confirm",sheetPermissionUserDialogButton:"univer-sheet-permission-user-dialog-button"},Yf=()=>{const n=I.useDependency(a.LocaleService),o=I.useDependency(a.IUniverInstanceService),e=I.useDependency(a.IAuthzIoService),t=I.useDependency(m.WorksheetProtectionPointModel),i=I.useDependency(I.IDialogService),r=I.useDependency(a.IPermissionService),s=o.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),l=s.getActiveSheet();if(!l)throw new Error("No active sheet found");const[c,d]=L.useState([]),u=I.useDependency(a.ICommandService),[h,S]=L.useState(()=>!!t.getRule(s.getUnitId(),l.getSheetId())),[g,f]=L.useState(()=>Object.keys(_o).reduce((v,C)=>(v[C]={text:n.t(`permission.panel.${_o[Number(C)]}`),allowed:!0},v),{}));L.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=await e.listCollaborators({objectID:C,unitID:C});d(b)})()},[]),L.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=t.getRule(C,l.getSheetId());if(!b)return;S(!0);const w=(await e.list({unitID:s.getUnitId(),objectIDs:[b.permissionId],actions:MS}))[0].strategies.reduce((O,R)=>(_o[R.action]&&(O[R.action]={text:n.t(`permission.panel.${_o[R.action]}`),allowed:R.role!==He.Owner}),O),{});f(w),setTimeout(()=>{S(!1)},100)})()},[]);const p=async()=>{const v=o.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),C=v==null?void 0:v.getActiveSheet();if(!C)throw new Error("No active sheet found");const b=v.getUnitId(),E=C.getSheetId(),w=t.getRule(b,E),O=Object.keys(g).map(P=>({action:Number(P),role:g[P].allowed?He.Editor:He.Owner}));let R=w==null?void 0:w.permissionId;R?e.update({objectType:rt.Worksheet,objectID:R,unitID:b,strategies:O,share:void 0,name:"",scope:{read:$e.AllCollaborator,edit:$e.AllCollaborator},collaborators:void 0}).then(()=>{m.getAllWorksheetPermissionPoint().forEach(P=>{const A=new P(b,E),k=A.subType,N=O.find(H=>H.action===k);N&&r.updatePermissionPoint(A.id,N.role===He.Editor)})}):(R=await e.create({objectType:rt.Worksheet,worksheetObject:{unitID:b,collaborators:c,name:"",strategies:O,scope:{read:$e.AllCollaborator,edit:$e.AllCollaborator}}}),u.executeCommand(m.SetWorksheetPermissionPointsCommand.id,{rule:{permissionId:R,unitId:b,subUnitId:E}}))};return _.jsx(Xf,{loading:h,children:_.jsxs("div",{className:Tt.sheetPermissionDialogWrapper,children:[_.jsx("div",{className:Tt.sheetPermissionDialogSplit}),Object.keys(g).map(v=>{const C=g[v],{text:b,allowed:E}=C;return _.jsxs("div",{className:Tt.sheetPermissionDialogItem,children:[_.jsx("div",{children:b}),_.jsx(j.Switch,{defaultChecked:E,onChange:()=>{f({...g,[v]:{...C,allowed:!E}})}})]},b)}),_.jsx("div",{className:Tt.sheetPermissionDialogSplit}),_.jsxs("div",{className:Tt.sheetPermissionUserDialogFooter,children:[_.jsx(j.Button,{className:Tt.sheetPermissionUserDialogButton,onClick:()=>{i.close(Io)},children:n.t("permission.button.cancel")}),_.jsx(j.Button,{variant:"primary",onClick:()=>{p(),i.close(Io)},className:j.clsx(Tt.sheetPermissionUserDialogFooterConfirm,Tt.sheetPermissionUserDialogButton),children:n.t("permission.button.confirm")})]})]})})},qc="",ct={sheetPermissionUserList:"univer-sheet-permission-user-list",sheetPermissionUserListEmpty:"univer-sheet-permission-user-list-empty",sheetPermissionUserItem:"univer-sheet-permission-user-item",sheetPermissionUserItemName:"univer-sheet-permission-user-item-name",sheetPermissionSplit:"univer-sheet-permission-split",sheetPermissionUserDialogButton:"univer-sheet-permission-user-dialog-button"},jf=()=>{var u;const[n,o]=L.useState(""),e=I.useDependency(a.LocaleService),t=I.useDependency(I.IDialogService),i=I.useDependency(Et),r=I.useObservable(i.userList$,i.userList),s=(u=r==null?void 0:r.filter(h=>{var S;return((S=h.subject)==null?void 0:S.name.toLocaleLowerCase().includes(n.toLocaleLowerCase()))&&h.role===He.Editor}))!=null?u:[],[l,c]=L.useState(i.selectUserList),d=h=>{if((l==null?void 0:l.findIndex(g=>{var f,p;return((f=g.subject)==null?void 0:f.userID)===((p=h.subject)==null?void 0:p.userID)}))===-1){const g={...h};c([...l,g])}else{const g=l.filter(f=>{var p,v;return((p=f.subject)==null?void 0:p.userID)!==((v=h.subject)==null?void 0:v.userID)});c(g)}};return _.jsxs("div",{children:[_.jsx("div",{className:ct.sheetPermissionUserDialogSearch,children:_.jsx(j.Input,{className:"univer-w-full",placeholder:e.t("permission.dialog.search"),value:n,onChange:h=>o(h)})}),_.jsx("div",{className:ct.sheetPermissionUserList,children:(s==null?void 0:s.length)>0?_.jsx(_.Fragment,{children:s==null?void 0:s.map(h=>{var S,g,f;return _.jsxs("div",{className:ct.sheetPermissionUserItem,onClick:()=>d(h),children:[_.jsx(j.Avatar,{src:(S=h.subject)==null?void 0:S.avatar,size:24}),_.jsx("div",{className:ct.sheetPermissionUserItemName,children:(g=h.subject)==null?void 0:g.name}),(l==null?void 0:l.findIndex(p=>{var v,C;return((v=p.subject)==null?void 0:v.userID)===((C=h.subject)==null?void 0:C.userID)}))!==-1&&_.jsx("div",{children:_.jsx(_t,{})})]},(f=h.subject)==null?void 0:f.userID)})}):_.jsxs("div",{className:ct.sheetPermissionUserListEmpty,children:[_.jsx("img",{className:"univer-w-full",src:qc,alt:"empty list",draggable:!1}),_.jsx("p",{className:"univer-text-[13px] univer-text-gray-400",children:e.t("permission.dialog.userEmpty")})]})}),_.jsx("div",{className:ct.sheetPermissionSplit}),_.jsxs("div",{className:"univer-flex univer-items-center univer-justify-end univer-gap-1 univer-py-1",children:[_.jsx(j.Button,{className:ct.sheetPermissionUserDialogButton,onClick:()=>t.close(Co),children:e.t("permission.button.cancel")}),_.jsx(j.Button,{variant:"primary",onClick:()=>{i.setSelectUserList(l),t.close(Co)},className:j.clsx(ct.sheetPermissionUserDialogFooterConfirm,ct.sheetPermissionUserDialogButton),children:e.t("permission.button.confirm")})]})]})},Gf=({errorMsg:n})=>{const o=I.useDependency(a.LocaleService);return _.jsx("div",{children:_.jsx("p",{className:"univer-m-0",children:n||o.t("permission.dialog.alertContent")})})},Qc="",Jc="RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY",$c="RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY",Zf=25,Kf=80;class ed extends M.SheetExtension{constructor(){super();T(this,"_pattern",null);T(this,"_img",new Image);T(this,"renderCache",new Set);this._img.src=Qc}clearCache(){this.renderCache.clear()}draw(e,t,i){const{worksheet:r}=i;r&&(e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat")),this.renderCache.clear(),a.Range.foreach(i.rowColumnSegment,(s,l)=>{if(!r.getRowVisible(s)||!r.getColVisible(l))return;const{selectionProtection:c=[]}=r.getCell(s,l)||{};this._pattern&&(e.fillStyle=this._pattern,c.forEach(d=>{if(d.ruleId&&this.shouldRender(d)){if(this.renderCache.has(d.ruleId))return;this.renderCache.add(d.ruleId),d.ranges.forEach(u=>{const h=i.getCellWithCoordByIndex(u.startRow,u.startColumn,!1),S=i.getCellWithCoordByIndex(u.endRow,u.endColumn,!1);e.fillRect(h.startX,h.startY,S.endX-h.startX,S.endY-h.startY)})}}))}),e.restore())}}class qf extends ed{constructor(){super();T(this,"uKey",Jc);T(this,"Z_INDEX",Zf)}shouldRender(e){return(e==null?void 0:e[ie.View])!==!1}}class Qf extends ed{constructor(){super();T(this,"uKey",$c);T(this,"Z_INDEX",Kf)}shouldRender(e){return(e==null?void 0:e[ie.View])===!1}}const td="worksheet-protection",nd=25,Jf=80;class $f extends M.SheetExtension{constructor(){super();T(this,"uKey",td);T(this,"Z_INDEX",nd);T(this,"_pattern");T(this,"_img",new Image);this._img.src=Qc}draw(e,t,i){const{worksheet:r}=i;if(!r)return!1;e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat"));const{startRow:s,startColumn:l,endRow:c,endColumn:d}=i.rowColumnSegment,u=i.getCellWithCoordByIndex(s,l,!1),h=i.getCellWithCoordByIndex(c,d,!1),{hasWorksheetRule:S=!1,selectionProtection:g=[]}=r.getCell(s,l)||{};if(this._pattern){if(g.length>0){const f=g[0];(f==null?void 0:f[ie.View])?this.setZIndex(nd):this.setZIndex(Jf)}e.fillStyle=this._pattern,S&&e.fillRect(u.startX,u.startY,h.endX-u.startX,h.endY-u.startY),e.restore()}}setZIndex(e){this.Z_INDEX=e}}const ep=n=>{const{editState:o,onEditStateChange:e,viewState:t,onViewStateChange:i,permissionId:r}=n,s=I.useDependency(a.LocaleService),l=I.useDependency(I.IDialogService),c=I.useDependency(a.IAuthzIoService),d=I.useDependency(Et),u=I.useDependency(a.UserManagerService),h=I.useDependency(a.IUniverInstanceService),S=I.useObservable(d.selectUserList$,d.selectUserList),g=h.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),f=g==null?void 0:g.getActiveSheet();if(!g||!f)return null;const p=g.getUnitId(),v=async()=>{const C=await c.listCollaborators({objectID:p,unitID:p}),b=u.getCurrentUser();d.setCanEditUserList(C.filter(E=>{var w;return((w=E.subject)==null?void 0:w.userID)!==b.userID})),l.open({id:Co,title:{title:""},children:{label:Vl},width:280,destroyOnClose:!0,closable:!1,onClose:()=>l.close(Co),className:"sheet-permission-user-dialog"})};return L.useEffect(()=>{r?(async()=>{const E=(await c.listCollaborators({objectID:r,unitID:p})).filter(w=>w.role===He.Editor);E.length>0&&e(m.EditStateEnum.DesignedUserCanEdit),d.setSelectUserList(E),d.setOldCollaboratorList(E)})():(d.setSelectUserList([]),d.setOldCollaboratorList([]))},[]),_.jsxs(_.Fragment,{children:[_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:s.t("permission.panel.editPermission"),children:_.jsxs(j.RadioGroup,{value:o,onChange:C=>e(C),className:Ce.radioGroupVertical,children:[_.jsx(j.Radio,{value:m.EditStateEnum.OnlyMe,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.onlyICanEdit")})}),_.jsx(j.Radio,{value:m.EditStateEnum.DesignedUserCanEdit,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.designedUserCanEdit")})})]})}),o===m.EditStateEnum.DesignedUserCanEdit&&_.jsxs("div",{className:Ce.sheetPermissionDesignPersonPanel,children:[_.jsxs("div",{className:Ce.sheetPermissionDesignPersonPanelHeader,children:[_.jsx("span",{children:s.t("permission.panel.designedPerson")}),_.jsx("span",{className:Ce.sheetPermissionDesignPersonPanelHeaderAdd,onClick:v,children:s.t("permission.panel.addPerson")})]}),_.jsx("div",{className:Ce.sheetPermissionDesignPersonPanelSplit}),_.jsx("div",{className:Ce.sheetPermissionDesignPersonPanelContent,children:(S==null?void 0:S.length)>0?S.map(C=>{var b,E,w;return _.jsxs("div",{className:Ce.sheetPermissionDesignPersonPanelContentItem,children:[_.jsx(j.Avatar,{size:24,src:(b=C.subject)==null?void 0:b.avatar}),_.jsx("span",{className:Ce.sheetPermissionDesignPersonPanelContentItemName,children:(E=C.subject)==null?void 0:E.name}),_.jsx(j.Select,{className:Ce.sheetPermissionDesignPersonPanelContentItemSelect,value:"edit",onChange:O=>{O==="delete"&&d.setSelectUserList(S.filter(R=>{var P,A;return((P=R.subject)==null?void 0:P.userID)!==((A=C.subject)==null?void 0:A.userID)}))},options:[{label:`${s.t("permission.panel.canEdit")}`,value:"edit"},{label:`${s.t("permission.panel.delete")}`,value:"delete"}]})]},(w=C.subject)==null?void 0:w.userID)}):_.jsxs("div",{className:Ce.sheetPermissionUserListEmpty,children:[_.jsx("img",{width:240,height:120,src:qc,alt:""}),_.jsx("p",{className:Ce.sheetPermissionUserListEmptyText,children:s.t("permission.dialog.userEmpty")})]})})]}),_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:s.t("permission.panel.viewPermission"),children:_.jsxs(j.RadioGroup,{value:t,onChange:C=>i(C),className:Ce.radioGroupVertical,children:[_.jsx(j.Radio,{value:m.ViewStateEnum.OthersCanView,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.othersCanView")})}),_.jsx(j.Radio,{value:m.ViewStateEnum.NoOneElseCanView,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.noOneElseCanView")})})]})})]})};var tp=Object.getOwnPropertyDescriptor,Rs=(n,o,e,t)=>{for(var i=t>1?void 0:t?tp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},xe=(n,o)=>(e,t)=>o(e,t,n);let Wi=class extends a.Disposable{constructor(n,o,e){super(),this._injector=n,this._componentManager=o,this._uiPartsService=e,this._init()}_init(){this._initComponents(),this._initUiPartComponents()}_initComponents(){[[Ll,ba],[RS,eo],[PS,Tr],[OS,_t],[Ul,br],[wi,zf],[Vl,jf],[Wl,Yf],[Zc,Gf]].forEach(([n,o])=>{this.disposeWithMe(this._componentManager.register(n,o))})}_initUiPartComponents(){var e;const o=this._injector.get(a.IConfigService).getConfig(Fe);(e=o==null?void 0:o.customComponents)!=null&&e.has(Dn)||this.disposeWithMe(this._uiPartsService.registerComponent(Dn,()=>I.connectInjector(ep,this._injector)))}};Wi=Rs([xe(0,a.Inject(a.Injector)),xe(1,a.Inject(I.ComponentManager)),xe(2,a.Inject(I.IUIPartsService))],Wi);let Vo=class extends a.Disposable{constructor(o,e,t,i,r){var l;super();T(this,"_rangeProtectionCanViewRenderExtension",new qf);T(this,"_rangeProtectionCanNotViewRenderExtension",new Qf);this._context=o,this._rangeProtectionRuleModel=e,this._sheetSkeletonManagerService=t,this._permissionService=i,this._configService=r;const s=this._configService.getConfig(Fe);(l=s==null?void 0:s.customComponents)!=null&&l.has(vo)||(this._initRender(),this._initSkeleton(),this.disposeWithMe(this._rangeProtectionRuleModel.ruleChange$.subscribe(c=>{var d,u;((d=c.oldRule)!=null&&d.id&&this._rangeProtectionCanViewRenderExtension.renderCache.has(c.oldRule.id)||this._rangeProtectionCanViewRenderExtension.renderCache.has(c.rule.id))&&this._rangeProtectionCanViewRenderExtension.clearCache(),((u=c.oldRule)!=null&&u.id&&this._rangeProtectionCanNotViewRenderExtension.renderCache.has(c.oldRule.id)||this._rangeProtectionCanNotViewRenderExtension.renderCache.has(c.rule.id))&&this._rangeProtectionCanNotViewRenderExtension.clearCache()})))}_initRender(){const o=this._context.mainComponent;o&&(o.getExtensionByKey(Jc)||o.register(this._rangeProtectionCanViewRenderExtension),o.getExtensionByKey($c)||o.register(this._rangeProtectionCanNotViewRenderExtension))}_initSkeleton(){const o=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(D.merge(this._permissionService.permissionPointUpdate$.pipe(D.throttleTime(300,void 0,{trailing:!0})),this._rangeProtectionRuleModel.rangeRuleInitStateChange$,this._rangeProtectionRuleModel.ruleChange$).pipe().subscribe(o))}};Vo=Rs([xe(1,a.Inject(m.RangeProtectionRuleModel)),xe(2,a.Inject(y.SheetSkeletonManagerService)),xe(3,a.IPermissionService),xe(4,a.IConfigService)],Vo);let Wo=class extends a.Disposable{constructor(o,e,t,i,r,s){var c;super();T(this,"_worksheetProtectionRenderExtension",new $f);this._context=o,this._renderManagerService=e,this._univerInstanceService=t,this._sheetSkeletonManagerService=i,this._worksheetProtectionRuleModel=r,this._configService=s;const l=this._configService.getConfig(Fe);(c=l==null?void 0:l.customComponents)!=null&&c.has(vo)||(this._initRender(),this._initSkeleton())}_initRender(){const o=this._context.unitId,e=o&&this._renderManagerService.getRenderById(o),t=e&&e.mainComponent;t&&(t.getExtensionByKey(td)||t.register(this._worksheetProtectionRenderExtension))}_initSkeleton(){const o=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(D.merge(this._worksheetProtectionRuleModel.worksheetRuleInitStateChange$).pipe().subscribe(o))}};Wo=Rs([xe(1,a.Inject(M.IRenderManagerService)),xe(2,a.Inject(a.IUniverInstanceService)),xe(3,a.Inject(y.SheetSkeletonManagerService)),xe(4,a.Inject(m.WorksheetProtectionRuleModel)),xe(5,a.Inject(a.IConfigService))],Wo);var np=Object.getOwnPropertyDescriptor,ip=(n,o,e,t)=>{for(var i=t>1?void 0:t?np(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ps=(n,o)=>(e,t)=>o(e,t,n);let Lo=class extends a.Disposable{constructor(n,o,e,t){super(),this._context=n,this._formatPainterService=o,this._selectionRenderService=e,this._commandService=t,this._initialize()}_initialize(){this._bindFormatPainterStatus(),this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._selectionRenderService.selectionMoveEnd$.subscribe(n=>{var o;if(this._formatPainterService.getStatus()!==Ne.OFF){const{rangeWithCoord:e}=n[n.length-1];this._commandService.executeCommand(hi.id,{unitId:this._context.unitId,subUnitId:((o=this._context.unit.getActiveSheet())==null?void 0:o.getSheetId())||"",range:{startRow:e.startRow,startColumn:e.startColumn,endRow:e.endRow,endColumn:e.endColumn}}),this._formatPainterService.getStatus()===Ne.ONCE&&this._commandService.executeCommand(Tn.id)}}))}_bindFormatPainterStatus(){this.disposeWithMe(a.toDisposable(this._formatPainterService.status$.subscribe(n=>{const o=this._context.scene;o&&(n!==Ne.OFF?o.setDefaultCursor(M.CURSOR_TYPE.CELL):o.setDefaultCursor(M.CURSOR_TYPE.DEFAULT))})))}};Lo=ip([Ps(1,Qe),Ps(2,ve),Ps(3,a.ICommandService)],Lo);var op=Object.getOwnPropertyDescriptor,rp=(n,o,e,t)=>{for(var i=t>1?void 0:t?op(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Li=(n,o)=>(e,t)=>o(e,t,n);let Os=class extends a.Disposable{constructor(n,o,e,t,i,r){super(),this._context=n,this._layoutService=o,this._contextMenuService=e,this._selectionManagerService=t,this._selectionRenderService=i,this._sheetSkeletonManagerService=r,this._init()}_init(){let n=!1;this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(()=>n=!0)),this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(o=>{const e=this._sheetSkeletonManagerService.getCurrentParam().skeleton;if(!e||!o||n===!1)return;n=!1;const t=o[0];if(!t.primary)return;const i=Re(t,e),r=t.range.rangeType,{scene:s}=this._context,l=s.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=(l==null?void 0:l.viewportScrollX)||0,d=(l==null?void 0:l.viewportScrollY)||0;let u=0,h=0;const S=e.rowHeaderWidth,g=this._layoutService.getContentElement().getBoundingClientRect();switch(r){case a.RANGE_TYPE.NORMAL:u=i.rangeWithCoord.startX+g.left-c,h=i.rangeWithCoord.endY+g.top-d;break;case a.RANGE_TYPE.COLUMN:u=i.rangeWithCoord.startX+g.left-c,h=Math.min(g.height/2,i.rangeWithCoord.endY)+40;break;case a.RANGE_TYPE.ROW:u=(g.width-S)/2+20,h=i.rangeWithCoord.endY+g.top-d;break;case a.RANGE_TYPE.ALL:u=i.rangeWithCoord.startX+g.left,h=i.rangeWithCoord.startY+g.top;break;default:u=i.rangeWithCoord.startX+g.left-c,h=i.rangeWithCoord.endY+g.top-d;break}u=a.Tools.clamp(u,S,g.width),h=a.Tools.clamp(h,g.top,g.height),this._contextMenuService.triggerContextMenu({clientX:u,clientY:h,preventDefault:()=>{},stopPropagation:()=>{}},I.ContextMenuPosition.MAIN_AREA)}))}};Os=rp([Li(1,I.ILayoutService),Li(2,I.IContextMenuService),Li(3,a.Inject(m.SheetsSelectionsService)),Li(4,ve),Li(5,a.Inject(y.SheetSkeletonManagerService))],Os);var sp=Object.getOwnPropertyDescriptor,ap=(n,o,e,t)=>{for(var i=t>1?void 0:t?sp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Un=(n,o)=>(e,t)=>o(e,t,n);const lp=[Ae.id,qe.id];let As=class extends a.Disposable{constructor(n,o,e,t,i,r,s){super(),this._context=n,this._sheetSkeletonManagerService=o,this._commandService=e,this._renderManagerService=t,this._selectionManagerService=i,this._scrollManagerService=r,this._univerInstanceService=s,this._init()}scrollToRange(n){let{endRow:o,endColumn:e,startColumn:t,startRow:i}=n;const r=this._getViewportBounding();if(n.rangeType===a.RANGE_TYPE.ROW?(t=0,e=0):n.rangeType===a.RANGE_TYPE.COLUMN&&(i=0,o=0),r){const s=r.startRow>o?i:o,l=r.startColumn>e?t:e;return this._scrollToCell(s,l)}else return this._scrollToCell(i,t)}_init(){this._initCommandListener(),this._initScrollEventListener(),this._initPointerScrollEvent(),this._initSkeletonListener()}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(lp.includes(n.id))this._scrollToSelection();else if(n.id===m.ScrollToCellOperation.id){const o=n.params.range;this.scrollToRange(o)}else if(n.id===ke.id){const o=n.params;this._scrollToSelectionForExpand(o)}}))}_scrollToSelectionForExpand(n){setTimeout(()=>{const o=this._selectionManagerService.getCurrentLastSelection();if(o==null)return;const{startRow:e,startColumn:t,endRow:i,endColumn:r}=o.range,s=this._getViewportBounding();if(s==null)return;const{startRow:l,startColumn:c,endRow:d,endColumn:u}=s;let h=0,S=0;e>l?h=i:i<d?h=e:h=l,t>c?S=r:r<u?S=t:S=c,n.direction===a.Direction.DOWN?h=i:n.direction===a.Direction.UP?h=e:n.direction===a.Direction.RIGHT?S=r:n.direction===a.Direction.LEFT&&(S=t),this._scrollToCell(h,S)},0)}_getFreeze(){var o;const n=(o=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:o.skeleton.getWorksheetConfig();if(n!=null)return n.freeze}_initScrollEventListener(){const{scene:n}=this._context;if(n==null)return;const o=n.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);o&&(this.disposeWithMe(a.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(e=>{var S;if(e==null){o.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const t=(S=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:S.skeleton;if(!t)return;const{sheetViewStartRow:i,sheetViewStartColumn:r,offsetX:s,offsetY:l}=e,{startX:c,startY:d}=t.getCellWithCoordByIndex(i,r,!1),u=c+s,h=d+l;o.scrollToViewportPos({viewportScrollX:u,viewportScrollY:h})}))),this.disposeWithMe(o.onScrollAfter$.subscribeEvent(e=>{var f;if(!e)return;const t=(f=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:f.skeleton;if(t==null)return;const i=this._getSheetObject();if(t==null||i==null)return;const{viewportScrollX:r,viewportScrollY:s,scrollX:l,scrollY:c}=e,{row:d,column:u,rowOffset:h,columnOffset:S}=t.getOffsetRelativeToRowCol(r,s),g={sheetViewStartRow:d,sheetViewStartColumn:u,offsetX:S,offsetY:h,viewportScrollX:r,viewportScrollY:s,scrollX:l,scrollY:c};this._scrollManagerService.setValidScrollStateToCurrSheet(g),this._scrollManagerService.validViewportScrollInfo$.next({...g,scrollX:l,scrollY:c,viewportScrollX:r,viewportScrollY:s})})),this.disposeWithMe(o.onScrollByBar$.subscribeEvent(e=>{var S;const t=(S=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:S.skeleton;if(t==null||e.isTrigger===!1)return;const i=this._getSheetObject();if(t==null||i==null)return;const{viewportScrollX:r=0,viewportScrollY:s=0}=e,l=this._getFreeze(),{row:c,column:d,rowOffset:u,columnOffset:h}=t.getOffsetRelativeToRowCol(r,s);this._commandService.executeCommand(Ye.id,{sheetViewStartRow:c+((l==null?void 0:l.ySplit)||0),sheetViewStartColumn:d+((l==null?void 0:l.xSplit)||0),offsetX:h,offsetY:u})})))}_initSkeletonListener(){this.disposeWithMe(a.toDisposable(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(n=>{if(n==null)return;const o={unitId:n.unitId,sheetId:n.sheetId};this._scrollManagerService.setSearchParam(o);const e=this._getSheetObject();if(!e)return;const i=e.scene.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),r=this._scrollManagerService.getScrollStateByParam(o),{viewportScrollX:s,viewportScrollY:l}=this._scrollManagerService.calcViewportScrollFromRowColOffset(r);i&&(r?(i.viewportScrollX=s,i.viewportScrollY=l):(i.viewportScrollX=0,i.viewportScrollY=0),this._updateSceneSize(n))})))}_initPointerScrollEvent(){const n=this._getSheetObject();if(!n)return;const o=this._scrollManagerService,e=n.scene,t=n.spreadsheet,i=e.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),r={x:0,y:0};let s=!1;const l={x:0,y:0},c=.95;let d=null;const u=()=>{if(!i)return;l.x*=c,l.y*=c,r.x+=l.x,r.y+=l.y;const S=l.x,g=l.y;(g!==0||S!==0)&&this._commandService.executeCommand(mn.id,{offsetY:g,offsetX:S}),Math.abs(l.x)>1||Math.abs(l.y)>1?d=requestAnimationFrame(u):d=null},h=()=>{cancelAnimationFrame(d),d=null};t.onPointerDown$.subscribeEvent((S,g)=>{h(),i&&(r.x=S.offsetX,r.y=S.offsetY,s=!0,g.stopPropagation())}),t.onPointerMove$.subscribeEvent((S,g)=>{if(!s||!i)return;const f=S,p=-(f.offsetX-r.x),v=-(f.offsetY-r.y);l.x=-(f.offsetX-r.x),l.y=-(f.offsetY-r.y);const C=p,b=v;(p!==0||v!==0)&&(b!==0||C!==0)&&this._commandService.executeCommand(mn.id,{offsetY:b,offsetX:C}),o.getCurrentScrollState(),r.x=f.offsetX,r.y=f.offsetY,g.stopPropagation()}),t.onPointerUp$.subscribeEvent(S=>{s=!1,d=requestAnimationFrame(u)}),t.onPointerLeave$.subscribeEvent(()=>{s=!1}),t.onPointerOut$.subscribeEvent(()=>{s=!1}),e.onPointerOut$.subscribeEvent(()=>{s=!1}),e.onPointerCancel$.subscribeEvent(()=>{s=!1})}_updateSceneSize(n){var h;if(n==null)return;const{unitId:o}=this._context,{skeleton:e}=n,t=(h=this._renderManagerService.getRenderById(o))==null?void 0:h.scene;if(e==null||t==null)return;const{rowTotalHeight:i,columnTotalWidth:r,rowHeaderWidthAndMarginLeft:s,columnHeaderHeightAndMarginTop:l}=e,d=this._context.unit.getActiveSheet();if(!d)return;const u=d.getZoomRatio()||1;t==null||t.setScaleValueOnly(u,u),t==null||t.transformByState({width:s+r,height:l+i})}_getSheetObject(){return ze(this._context.unit,this._context)}_scrollToSelectionByDirection(n){const o=this._getViewportBounding();if(o==null)return!1;const{startRow:e,startColumn:t,endRow:i,endColumn:r}=o;let s=0,l=0;const{startRow:c,startColumn:d,endRow:u,endColumn:h}=n;c>=e&&(s=u),u<=i&&(s=c),d>=t&&(l=h),h<=r&&(l=d),this._scrollToCell(s,l)}_scrollToSelection(n=!0){const o=this._selectionManagerService.getCurrentLastSelection();if(o==null)return;const{startRow:e,startColumn:t,actualRow:i,actualColumn:r}=o.primary,s=n?i:e,l=n?r:t;this._scrollToCell(s,l)}_getViewportBounding(){var t,i;const n=(t=this._getSheetObject())==null?void 0:t.scene;if(n==null)return;const o=n.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(o==null)return;const e=(i=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:i.skeleton;if(e!=null)return e.getRangeByViewport(o.calcViewportInfo())}_scrollToCell(n,o){var O,R,P,A;const{rowHeightAccumulation:e,columnWidthAccumulation:t}=(R=(O=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:O.skeleton)!=null?R:{};if(e==null||t==null)return!1;const i=(P=this._getSheetObject())==null?void 0:P.scene;if(i==null)return!1;const r=i.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(r==null||((A=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:A.skeleton)==null)return!1;const l=this._context.unit.getActiveSheet();if(!l)return!1;const{startColumn:c,startRow:d,ySplit:u,xSplit:h}=l.getFreeze(),S=this._getViewportBounding();if(S==null)return!1;const{startRow:g,startColumn:f,endRow:p,endColumn:v}=S;let C,b;if(n>=d&&o>=c-h&&(n<=g&&(C=n),n>=p)){const k=e[n]-r.height;for(let N=g;N<=n;N++)if(e[N]>=k){C=N+1;break}}if(o>=c&&n>=d-u&&(o<=f&&(b=o),o>=v)){const k=t[o]-r.width;for(let N=f;N<=o;N++)if(t[N]>=k){b=N+1;break}}if(C===void 0&&b===void 0)return!1;const{offsetX:E,offsetY:w}=this._scrollManagerService.getCurrentScrollState()||{};return this._commandService.syncExecuteCommand(Ye.id,{sheetViewStartRow:C,sheetViewStartColumn:b,offsetX:b===void 0?E:0,offsetY:C===void 0?w:0})}};As=ap([Un(1,a.Inject(y.SheetSkeletonManagerService)),Un(2,a.ICommandService),Un(3,M.IRenderManagerService),Un(4,a.Inject(m.SheetsSelectionsService)),Un(5,a.Inject(y.SheetScrollManagerService)),Un(6,a.IUniverInstanceService)],As);function id(n){const{popup:o}=n,{extraProps:e}=o,{options:t,defaultValue:i,onChange:r}=e,[s,l]=L.useState(i!=null?i:[]);return _.jsx(j.CascaderList,{options:t,value:s,onChange:r})}id.componentKey="sheets.dropdown.cascader";function od(n){const{popup:o}=n,{extraProps:e}=o,{defaultValue:t,onChange:i}=e;return _.jsx(j.ColorPicker,{value:t,onChange:i})}od.componentKey="sheets.dropdown.color";const rd={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"};function sd(n){const{popup:o}=n,{extraProps:e}=o,{hideFn:t,patternType:i,defaultValue:r,onChange:s,showTime:l}=e,[c,d]=L.useState(r),u=L.useMemo(()=>i!=="time"?a.dayjs():a.dayjs("1900-01-01 00:00:00"),[]),h=c&&c.isValid()?c:u,S=I.useDependency(a.LocaleService),g=async()=>{h&&await(s==null?void 0:s(h))!==!1&&t()};return _.jsxs("div",{className:rd.dvDateDropdown,children:[_.jsx(j.DatePanel,{value:h,pickerValue:h,mode:i==="time"?"time":"date",showTime:(l!=null?l:i==="datetime"||i==="time")||void 0,onSelect:async f=>{d(f)},onPanelChange:f=>{d(f)},disabledDate:f=>!a.numfmt.parseDate(f.format("YYYY-MM-DD"))}),_.jsx("div",{className:rd.dvDateDropdownBtns,children:_.jsx(j.Button,{size:"small",variant:"primary",onClick:g,disabled:!h||!h.isValid(),children:S.t("dataValidation.alert.ok")})})]})}sd.componentKey="sheets.dropdown.date";const dt={dvListDropdown:"univer-dv-list-dropdown",dvListDropdownTitle:"univer-dv-list-dropdown-title",dvListDropdownList:"univer-dv-list-dropdown-list",dvListDropdownListContainer:"univer-dv-list-dropdown-list-container",dvListDropdownSelectedIcon:"univer-dv-list-dropdown-selected-icon",dvListDropdownItemContainer:"univer-dv-list-dropdown-item-container",dvListDropdownItem:"univer-dv-list-dropdown-item",dvListDropdownSplit:"univer-dv-list-dropdown-split",dvListDropdownEdit:"univer-dv-list-dropdown-edit"};function cp(n){return n.filter(Boolean).join(",")}function dp(n){return n.split(",").filter(Boolean)}const up=n=>{const{value:o,onChange:e,multiple:t,options:i,title:r,onEdit:s,style:l,filter:c,location:d,showEdit:u}=n,h=I.useDependency(a.LocaleService),S=c==null?void 0:c.toLowerCase(),{row:g,col:f,unitId:p,subUnitId:v}=d,C=i.filter(w=>S?w.label.toLowerCase().includes(S):!0),b=I.useDependency(m.SheetPermissionCheckController),E=L.useMemo(()=>b.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission]},[{startColumn:f,startRow:g,endColumn:f,endRow:g}],p,v),[b,f,g,p,v]);return _.jsxs("div",{className:dt.dvListDropdown,style:l,children:[_.jsx("div",{className:dt.dvListDropdownTitle,children:r}),_.jsx("div",{className:dt.dvListDropdownList,children:_.jsx(j.Scrollbar,{children:_.jsx("div",{className:dt.dvListDropdownListContainer,children:C.map((w,O)=>{const R=o.indexOf(w.value)>-1,P=()=>{let k;R?k=new Set(o.filter(H=>H!==w.value)):k=new Set(t?[...o,w.value]:[w.value]);const N=[];i.forEach(H=>{k.has(H.value)&&N.push(H.value)}),e(N)},A=w.label.toLocaleLowerCase().indexOf(S);return _.jsxs("div",{className:dt.dvListDropdownItemContainer,onClick:P,children:[_.jsx("div",{className:dt.dvListDropdownItem,style:{background:w.color},children:S&&w.label.toLowerCase().includes(S)?_.jsxs(_.Fragment,{children:[_.jsx("span",{children:w.label.substring(0,A)}),_.jsx("span",{style:{fontWeight:"bold"},children:w.label.substring(A,A+S.length)}),_.jsx("span",{children:w.label.substring(A+S.length)})]}):w.label}),_.jsx("div",{className:dt.dvListDropdownSelectedIcon,children:R?_.jsx(_t,{}):null})]},O)})})},c)}),u&&E?_.jsxs(_.Fragment,{children:[_.jsx("div",{className:dt.dvListDropdownSplit}),_.jsx("div",{className:dt.dvListDropdownEdit,children:_.jsx("a",{onClick:s,children:h.t("dataValidation.list.edit")})})]}):null]})};function ad(n){var O,R,P,A;const{popup:{extraProps:o}}=n,{location:e,hideFn:t,onChange:i,onEdit:r,options:s,defaultValue:l,multiple:c,showEdit:d}=o,{worksheet:u}=e,[h,S]=L.useState(""),g=I.useDependency(a.ICommandService),f=I.useDependency(a.LocaleService),[p,v]=L.useState(l),C=I.useDependency(Se),b=I.useDependency(a.IUniverInstanceService),E=I.RectPopup.useContext(),w=((R=(O=E.current)==null?void 0:O.right)!=null?R:0)-((A=(P=E.current)==null?void 0:P.left)!=null?A:0);return L.useEffect(()=>{const k=g.onCommandExecuted(N=>{var H,V;if(N.id===_e.RichTextEditingMutation.id){const U=N.params,{unitId:W}=U,B=b.getUnit(W,a.UniverInstanceType.UNIVER_DOC);if(!B||!C.isVisible().visible)return;const x=a.BuildTextUtils.transform.getPlainText((V=(H=B.getSnapshot().body)==null?void 0:H.dataStream)!=null?V:"");S(x)}});return()=>{k.dispose()}},[g,C,b]),u?_.jsx(up,{style:{minWidth:w,maxWidth:Math.max(w,200)},title:c?f.t("dataValidation.listMultiple.dropdown"):f.t("dataValidation.list.dropdown"),value:dp(p!=null?p:""),multiple:c,onChange:async k=>{const N=cp(k);v(N),await(i==null?void 0:i(k))!==!1&&t()},options:s,onEdit:r,filter:h,location:e,showEdit:d}):null}ad.componentKey="sheets.dropdown.list";const ld={datepicker:sd,list:ad,color:od,cascader:id};var hp=Object.getOwnPropertyDescriptor,mp=(n,o,e,t)=>{for(var i=t>1?void 0:t?hp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Uo=(n,o)=>(e,t)=>o(e,t,n);const Ds=a.createIdentifier("ICellDropdownManagerService");y.SheetCellDropdownManagerService=class extends a.Disposable{constructor(o,e,t,i){super(),this._canvasPopupManagerService=o,this._zenZoneService=e,this._renderManagerService=t,this._componentManager=i,Object.values(ld).forEach(r=>{this.disposeWithMe(this._componentManager.register(r.componentKey,r))})}showDropdown(o){const{location:e,onHide:t,closeOnOutSide:i=!0}=o,{row:r,col:s,unitId:l,subUnitId:c}=e;if(this._zenZoneService.visible)throw new Error("[SheetCellDropdownManagerService]: cannot show dropdown when zen mode is visible");const d=ld[o.type],u=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),h=new a.DisposableCollection,S=this._canvasPopupManagerService.attachPopupToCell(r,s,{componentKey:d.componentKey,onClickOutside:()=>{i&&h.dispose()},offset:[0,3],excludeOutside:[u==null?void 0:u.engine.getCanvasElement()].filter(Boolean),extraProps:{...o,...o.props,hideFn:()=>{h.dispose()}}},l,c);if(!S)throw new Error("[SheetCellDropdownManagerService]: cannot show dropdown");return h.add(S),h.add({dispose:()=>{t==null||t()}}),h}},y.SheetCellDropdownManagerService=mp([Uo(0,a.Inject(y.SheetCanvasPopManagerService)),Uo(1,I.IZenZoneService),Uo(2,M.IRenderManagerService),Uo(3,a.Inject(I.ComponentManager))],y.SheetCellDropdownManagerService);const Sp=a.createInterceptorKey("PRINTING_RANGE"),gp=a.createInterceptorKey("PRINTING_COMPONENT_COLLECT"),fp=a.createInterceptorKey("PRINTING_DOM_COLLECT");class ks extends a.Disposable{constructor(){super();T(this,"interceptor",new a.InterceptorManager({PRINTING_RANGE:Sp,PRINTING_COMPONENT_COLLECT:gp,PRINTING_DOM_COLLECT:fp}));this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_RANGE,{priority:-1,handler:e=>e})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_COMPONENT_COLLECT,{priority:-1,handler:e=>e})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_DOM_COLLECT,{priority:-1,handler:e=>e}))}}class pp extends zn{constructor(e,t,i,r){super(e,t,i,r);T(this,"_fillControlTopLeft");T(this,"_fillControlBottomRight");T(this,"_rangeType",a.RANGE_TYPE.NORMAL);this._scene=e,this._zIndex=t,this._themeService=i,this._rangeType=(r==null?void 0:r.rangeType)||a.RANGE_TYPE.NORMAL,this.initControlPoints()}initControlPoints(){const e=this.currentStyle,t=e.expandCornerSize||0,i=(e.expandCornerSize||0)/4,r=e.autofillStrokeWidth||0,s=e.stroke,l=e.autofillStroke,c=this.zIndex;this._fillControlTopLeft=new M.Rect(nr.fillTopLeft+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualWidth:i,visualHeight:i,strokeWidth:r}),this._fillControlBottomRight=new M.Rect(nr.fillBottomRight+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualHeight:i,visualWidth:i,strokeWidth:r});const d={fill:s,stroke:l,strokeScaleEnabled:!1};this._fillControlTopLeft.setProps({...d}),this._fillControlBottomRight.setProps({...d});const u=[this._fillControlTopLeft,this._fillControlBottomRight];switch(this._rangeType){case a.RANGE_TYPE.ROW:this.rowHeaderGroup.addObjects(...u);break;case a.RANGE_TYPE.COLUMN:this.columnHeaderGroup.addObjects(...u);break;case a.RANGE_TYPE.NORMAL:this.selectionShapeGroup.addObjects(...u)}this.getScene().addObjects(u,Yi)}get fillControlTopLeft(){return this._fillControlTopLeft}set fillControlTopLeft(e){this._fillControlTopLeft=e}get fillControlBottomRight(){return this._fillControlBottomRight}set fillControlBottomRight(e){this._fillControlBottomRight=e}get rangeType(){return this._rangeType}set rangeType(e){this._rangeType=e}dispose(){var e,t;(e=this._fillControlBottomRight)==null||e.dispose(),(t=this._fillControlTopLeft)==null||t.dispose(),super.dispose()}_updateLayoutOfSelectionControl(e){var r,s;super._updateLayoutOfSelectionControl(e);const t=this.currentStyle;e==null&&(e=t);const{widgets:i=t.widgets}=e;if(this.currentStyle=e,this._enableAutoFill===!0&&!super._hasWidgets(i)){const{viewportScrollX:l,viewportScrollY:c}=this.getViewportMainScrollInfo(),{endX:d,endY:u}=this.selectionModel;this.transformControlPoint(l,c,d,u),this.fillControlTopLeft.show(),this.fillControlBottomRight.show()}else(r=this.fillControlTopLeft)==null||r.hide(),(s=this.fillControlBottomRight)==null||s.hide()}getViewportMainScrollInfo(){const e=this.getScene().getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);return{viewportScrollX:(e==null?void 0:e.viewportScrollX)||0,viewportScrollY:(e==null?void 0:e.viewportScrollY)||0,width:(e==null?void 0:e.width)||0,height:(e==null?void 0:e.height)||0}}transformControlPoint(e=0,t=0,i=0,r=0){const s=this.currentStyle,l=this.selectionModel.rangeType,c=s.expandCornerSize,{startX:d,startY:u,endX:h,endY:S}=this.selectionModel,g=this.getViewportMainScrollInfo(),f=g.width,p=g.height;switch(l){case a.RANGE_TYPE.NORMAL:this.fillControlTopLeft.transformByState({left:-c/2,top:-c/2}),this.fillControlBottomRight.transformByState({left:h-d-c/2,top:S-u-c/2});break;case a.RANGE_TYPE.ROW:{const v=Math.min(f/2+e,i),C=-c/2+v;this.fillControlTopLeft.transformByState({left:C,top:-c/2}),this.fillControlBottomRight.transformByState({left:C,top:-c/2+S-u})}break;case a.RANGE_TYPE.COLUMN:{const v=Math.min(+p/2+t,r),C=-c/2+v;this.fillControlTopLeft.transformByState({left:-c/2,top:C}),this.fillControlBottomRight.transformByState({left:-c/2+h-d,top:C})}break;default:console.error("unknown range type")}}}var vp=Object.getOwnPropertyDescriptor,Cp=(n,o,e,t)=>{for(var i=t>1?void 0:t?vp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ut=(n,o)=>(e,t)=>o(e,t,n);let Bo=class extends ir{constructor(o,e,t,i,r,s,l,c,d,u){super(e,t,i,s,d);T(this,"_workbookSelections");T(this,"_renderDisposable",null);T(this,"_expandingSelection",!1);T(this,"_selectionControls",[]);T(this,"expandingControlMode","bottom-right");this._context=o,this._logService=l,this._commandService=c,this._contextService=d,this._scrollManagerService=u,this._workbookSelections=r.getWorkbookSelections(this._context.unitId),this._init()}_init(){const o=this._getSheetObject();this._initEventListeners(o),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._updateControlPointWhenScrolling()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(o=>{if(o==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const e=this._context.unitId,{sheetId:t,skeleton:i}=o,{scene:r}=this._context,s=r.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._changeRuntime(i,r,s),this._workbookSelections.getCurrentLastSelection()||this._commandService.syncExecuteCommand(m.SetSelectionsOperation.id,{unitId:e,subUnitId:t,selections:[Zi(i)]})}))}_initSelectionChangeListener(){}_initEventListeners(o){const{spreadsheetRowHeader:e,spreadsheetColumnHeader:t,spreadsheet:i,spreadsheetLeftTopPlaceholder:r}=o,{scene:s}=this._context;this._initSpreadsheetEvent(o),this.disposeWithMe(e==null?void 0:e.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{row:u}=Ze(l.offsetX,l.offsetY,s,d);wl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(i.zIndex||1)+1,a.RANGE_TYPE.ROW,this._getActiveViewport(l)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(t==null?void 0:t.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{column:u}=Ze(l.offsetX,l.offsetY,s,d);Tl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(i.zIndex||1)+1,a.RANGE_TYPE.COLUMN,this._getActiveViewport(l)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(r==null?void 0:r.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;this._reset();const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,u=or(d);this._addSelectionControlByModelData(u),this.refreshSelectionMoveStart(),c.stopPropagation(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}))}_initSpreadsheetEvent(o){const{spreadsheet:e}=o;let t;const i=500,r={x:0,y:0},s=()=>{clearTimeout(t)},l=(u,h)=>{this.createNewSelection(u,e.zIndex+1,a.RANGE_TYPE.NORMAL,this._getActiveViewport(u)),h&&this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())};e==null||e.onPointerMove$.subscribeEvent((u,h)=>{(Math.abs(u.offsetX-r.x)>10||Math.abs(u.offsetY-r.y)>10)&&s()});const c=e==null?void 0:e.onPointerDown$.subscribeEvent((u,h)=>{r.x=u.offsetX,r.y=u.offsetY,t=setTimeout(()=>{l(u,!0)},i),h.stopPropagation()}),d=e==null?void 0:e.onPointerUp$.subscribeEvent((u,h)=>{if(this._normalSelectionDisabled())return;clearTimeout(t);const S=10;Math.abs(u.offsetX-r.x)>S||Math.abs(u.offsetY-r.y)>S||(l(u,!1),h.stopPropagation())});this.disposeWithMe(a.toDisposable(c)),this.disposeWithMe(a.toDisposable(d))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(o=>this._updateSelections(o,m.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(o=>this._updateSelections(o,m.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(m.REF_SELECTIONS_ENABLED).pipe(D.startWith(!1),D.distinctUntilChanged()).subscribe(o=>{var e;o?((e=this._renderDisposable)==null||e.dispose(),this._renderDisposable=null,this._reset()):this._renderDisposable=a.toDisposable(this.selectionMoveEnd$.subscribe(t=>this._updateSelections(t,m.SelectionMoveType.MOVE_END)))}))}_updateSelections(o,e){const t=this._context.unit,i=t.getUnitId(),r=t.getActiveSheet().getSheetId();o.length!==0&&this._commandService.executeCommand(m.SetSelectionsOperation.id,{unitId:i,subUnitId:r,type:e,selections:o.map(s=>m.convertSelectionDataToRange(s))})}createNewSelection(o,e=0,t=a.RANGE_TYPE.NORMAL,i){this._rangeType=t;const r=this._skeleton,s=this._scene;if(!s||!r)return;i&&(this._activeViewport=i);const{offsetX:l,offsetY:c}=o,d=s.getCoordRelativeToViewport(M.Vector2.FromArray([l,c])),{x:u,y:h}=d;this._startViewportPosX=u,this._startViewportPosY=h;const S=s.getScrollXYInfoByViewport(d),{scaleX:g,scaleY:f}=s.getAncestorScale(),p=this._skeleton.getCellByOffset(u,h,g,f,S);if(!p)return;switch(t){case a.RANGE_TYPE.NORMAL:break;case a.RANGE_TYPE.ROW:p.startColumn=0,p.endColumn=this._skeleton.getColumnCount()-1;break;case a.RANGE_TYPE.COLUMN:p.startRow=0,p.endRow=this._skeleton.getRowCount()-1;break;case a.RANGE_TYPE.ALL:p.startRow=0,p.startColumn=0,p.endRow=this._skeleton.getRowCount()-1,p.endColumn=this._skeleton.getColumnCount()-1}const v={range:p,primary:p,style:null};v.range.rangeType=t;const C=Re(v,this._skeleton);this._startRangeWhenPointerDown={...C.rangeWithCoord};let b=this.getActiveSelectionControl();const E={...C.rangeWithCoord};for(const w of this.getSelectionControls())if(w.model.isEqual(E)){b=w;break}(b==null?void 0:b.model.rangeType)!==t?(this._clearAllSelectionControls(),b=this.newSelectionControl(s,r,v)):b.updateRangeBySelectionWithCoord(C),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._expandingSelection=!1}newSelectionControl(o,e,t){const i=this.getSelectionControls(),{rowHeaderWidth:r,columnHeaderHeight:s}=e,l=t.range.rangeType,c=new pp(o,i.length,this._themeService,{highlightHeader:this._highlightHeader,rowHeaderWidth:r,columnHeaderHeight:s,rangeType:l}),d=Re(t,e);c.updateRangeBySelectionWithCoord(d),this._selectionControls.push(c);const{expandingModeForTopLeft:u,expandingModeForBottomRight:h}=(()=>{switch(l){case a.RANGE_TYPE.NORMAL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};case a.RANGE_TYPE.ROW:return{expandingModeForTopLeft:"top",expandingModeForBottomRight:"bottom"};case a.RANGE_TYPE.COLUMN:return{expandingModeForTopLeft:"left",expandingModeForBottomRight:"right"};case a.RANGE_TYPE.ALL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};default:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"}}})();return c.fillControlTopLeft.onPointerDown$.subscribeEvent(S=>{this._expandingSelection=!0,this.expandingControlMode=u,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(S,l,this._activeViewport)}),c.fillControlBottomRight.onPointerDown$.subscribeEvent(S=>{this._expandingSelection=!0,this.expandingControlMode=h,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(S,l,this._activeViewport)}),(l===a.RANGE_TYPE.ROW||l===a.RANGE_TYPE.COLUMN)&&!o.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),c}_getActiveViewport(o){const e=this._getSheetObject();return e==null?void 0:e.scene.getActiveViewportByCoord(M.Vector2.FromArray([o.offsetX,o.offsetY]))}_getSheetObject(){return ze(this._context.unit,this._context)}_normalSelectionDisabled(){return this._contextService.getContextValue(m.REF_SELECTIONS_ENABLED)}getSelectionControls(){return this._selectionControls}_fillControlPointerDownHandler(o,e=a.RANGE_TYPE.NORMAL,t,i=M.ScrollTimerType.ALL){var h,S,g;const r=this._skeleton,s=this._scene;if(!s||!r)return;t&&(this._activeViewport=t);const l=s.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=this.getActiveSelectionControl();if(!c)return;this._changeCurrCellWhenControlPointerDown(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._addEndingListeners(),this._scrollTimer=M.ScrollTimer.create(this._scene,i),this._scrollTimer.startScroll((h=l==null?void 0:l.left)!=null?h:0,(S=l==null?void 0:l.top)!=null?S:0,l),(g=s.getTransformer())==null||g.clearSelectedObjects();const d=s.getCoordRelativeToViewport(M.Vector2.FromArray([o.offsetX,o.offsetY]));this._setupPointerMoveListener(l,c,e,i,d.x,d.y);const u=this._shortcutService.forceEscape();this._scenePointerUpSub=s.onPointerUp$.subscribeEvent(f=>{this.endSelection(),this._expandingSelection=!1,this.expandingControlMode="bottom-right",this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),u.dispose()})}_changeCurrCellWhenControlPointerDown(){const o=this.getActiveSelectionControl(),e=this._skeleton;let t;const{startRow:i,startColumn:r,endRow:s,endColumn:l}=o.model;switch(this.expandingControlMode){case"top-left":t=e.getCellWithCoordByIndex(s,l);break;case"bottom-right":t=e.getCellWithCoordByIndex(i,r);break;case"left":t=e.getCellWithCoordByIndex(i,l),t.isMerged=!1,t.isMergedMainCell=!1;break;case"right":t=e.getCellWithCoordByIndex(i,r),t.isMerged=!1,t.isMergedMainCell=!1;break;case"top":t=e.getCellWithCoordByIndex(s,r),t.isMerged=!1,t.isMergedMainCell=!1;break;case"bottom":t=e.getCellWithCoordByIndex(i,r),t.isMerged=!1,t.isMergedMainCell=!1;break;default:t=e.getCellWithCoordByIndex(i,r)}return o.updateCurrCell(t),t}_movingHandler(o,e,t,i){var A,k,N,H,V,U,W,B,x,X,F,Y,z;this._rangeType=i;const r=this._skeleton,s=this._scene,l={startRow:t.model.startRow,endRow:t.model.endRow,startColumn:t.model.startColumn,endColumn:t.model.endColumn},c=s.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),d=(A=this._getViewportByCell(l.endRow,l.endColumn))!=null?A:c,u=s.getScrollXYInfoByViewport(M.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),d),{scaleX:h,scaleY:S}=s.getAncestorScale();i===a.RANGE_TYPE.ROW?o=Number.POSITIVE_INFINITY:i===a.RANGE_TYPE.COLUMN&&(e=Number.POSITIVE_INFINITY);const g=this._getSelectionWithCoordByOffset(o,e,h,S,u);if(!g)return!1;const{rangeWithCoord:f}=g,p=t.model.currentCell,v=(k=p==null?void 0:p.mergeInfo.startRow)!=null?k:-1,C=(N=p==null?void 0:p.mergeInfo.endRow)!=null?N:-1,b=(H=p==null?void 0:p.mergeInfo.startColumn)!=null?H:-1,E=(V=p==null?void 0:p.mergeInfo.endColumn)!=null?V:-1;let w={startRow:Math.min(f.startRow,v),startColumn:Math.min(f.startColumn,b),endRow:Math.max(f.endRow,C),endColumn:Math.max(f.endColumn,E)};if(i===a.RANGE_TYPE.NORMAL?w=r.expandRangeByMerge(w):i===a.RANGE_TYPE.COLUMN?w={startRow:Math.min(f.startRow,(U=p==null?void 0:p.actualRow)!=null?U:-1),startColumn:Math.min(f.startColumn,(W=p==null?void 0:p.actualColumn)!=null?W:-1),endRow:Math.max(f.endRow,(B=p==null?void 0:p.actualRow)!=null?B:-1),endColumn:Math.max(f.endColumn,(x=p==null?void 0:p.actualColumn)!=null?x:-1)}:i===a.RANGE_TYPE.ROW&&(w={startRow:Math.min(f.startRow,(X=p==null?void 0:p.actualRow)!=null?X:-1),startColumn:Math.min(f.startColumn,(F=p==null?void 0:p.actualColumn)!=null?F:-1),endRow:Math.max(f.endRow,(Y=p==null?void 0:p.actualRow)!=null?Y:-1),endColumn:Math.max(f.endColumn,(z=p==null?void 0:p.actualColumn)!=null?z:-1)}),!w)return!1;const R=Re({range:w,style:null,primary:null},r);(l.startRow!==w.startRow||l.startColumn!==w.startColumn||l.endRow!==w.endRow||l.endColumn!==w.endColumn)&&t&&(t.updateRangeBySelectionWithCoord(R),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateControlPointWhenScrolling(){const{scene:o}=this._context;if(!o.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN))return;const t=this._scrollManagerService.validViewportScrollInfo$.subscribe(i=>{var S;if(i==null)return;const{viewportScrollX:r,viewportScrollY:s}=i,l=this.getActiveSelectionControl();if(l==null)return;const c=(S=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:S.skeleton,d=c==null?void 0:c.rowTotalHeight,u=c==null?void 0:c.columnTotalWidth,h=l.rangeType;h===a.RANGE_TYPE.COLUMN?l.transformControlPoint(0,s,u,d):h===a.RANGE_TYPE.ROW&&l.transformControlPoint(r,0,u,d)});this.disposeWithMe(a.toDisposable(t))}};Bo=Cp([ut(1,a.Inject(a.Injector)),ut(2,a.Inject(a.ThemeService)),ut(3,I.IShortcutService),ut(4,a.Inject(m.SheetsSelectionsService)),ut(5,a.Inject(y.SheetSkeletonManagerService)),ut(6,a.ILogService),ut(7,a.ICommandService),ut(8,a.IContextService),ut(9,a.Inject(y.SheetScrollManagerService))],Bo);var Ip=Object.defineProperty,_p=Object.getOwnPropertyDescriptor,bp=(n,o,e)=>o in n?Ip(n,o,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[o]=e,Ep=(n,o,e,t)=>{for(var i=t>1?void 0:t?_p(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ns=(n,o)=>(e,t)=>o(e,t,n),cd=(n,o,e)=>bp(n,typeof o!="symbol"?o+"":o,e);y.UniverSheetsMobileUIPlugin=class extends a.Plugin{constructor(o=sr,e,t,i){super(),this._config=o,this._injector=e,this._renderManagerService=t,this._univerInstanceService=i}onStarting(){[[hn],[Be,{useClass:y.SheetClipboardService}],[Vt,{useClass:Ma}],[Qe,{useClass:ho}],[vt,{useClass:y.AutoFillService}],[ks],[ve,{useClass:Bo}],[ii,{useClass:yr}],[Ut,{useClass:y.MarkSelectionService}],[Se,{useClass:y.EditorBridgeService}],[y.HoverManagerService],[y.DragManagerService],[y.SheetCanvasPopManagerService],[y.CellAlertManagerService],[mr],[Ds,{useClass:y.SheetCellDropdownManagerService}],[ki],[y.AutoHeightController],[Ln],[y.SheetsRenderService],[Ao],[y.StatusBarController],[m.IRefSelectionsService,{useClass:m.RefSelectionsService}],[kn],[Et],[Wo],[Hi],[y.SheetPermissionCheckUIController],[Wi]].forEach(o=>this._injector.add(o))}onReady(){this._markSheetAsFocused(),this._registerRenderBasics(),this._injector.get(Ao)}onRendered(){this._registerRenderModules()}_registerRenderBasics(){[[y.SheetSkeletonManagerService],[y.SheetRenderController],[ve,{useClass:Bo}],[y.SheetScrollManagerService]].forEach(o=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,o))})}_registerRenderModules(){[[y.HeaderMoveRenderController],[y.HeaderFreezeRenderController],[As],[qn],[Lo],[To],[Mo],[Po],[y.HoverRenderController],[y.DragRenderController],[Ro],[y.CellCustomRenderController],[Os],[Do],[No],[Vo]].forEach(o=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,o))})}_markSheetAsFocused(){const o=this._univerInstanceService;this.disposeWithMe(o.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).pipe(me.filter(e=>!!e)).subscribe(e=>{this._univerInstanceService.getFocusedUnit()!==e&&o.focusUnit(e.getUnitId())}))}},cd(y.UniverSheetsMobileUIPlugin,"pluginName","SHEET_UI_PLUGIN"),cd(y.UniverSheetsMobileUIPlugin,"type",a.UniverInstanceType.UNIVER_SHEET),y.UniverSheetsMobileUIPlugin=Ep([a.DependentOn(m.UniverSheetsPlugin,I.UniverMobileUIPlugin),Ns(1,a.Inject(a.Injector)),Ns(2,M.IRenderManagerService),Ns(3,a.IUniverInstanceService)],y.UniverSheetsMobileUIPlugin);var wp=Object.getOwnPropertyDescriptor,Tp=(n,o,e,t)=>{for(var i=t>1?void 0:t?wp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},xo=(n,o)=>(e,t)=>o(e,t,n);let Fo=class extends a.Disposable{constructor(o,e,t,i){super();T(this,"_isPointer",!1);this._hoverManagerService=o,this._instanceService=e,this._commandService=t,this._renderManagerService=i,this._initPointerEvent(),this._initHover()}get _mainComponent(){var o;return(o=M.getCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,this._instanceService,this._renderManagerService))==null?void 0:o.mainComponent}_initHover(){this.disposeWithMe(this._hoverManagerService.currentRichText$.subscribe(o=>{var e,t;o!=null&&o.bullet?(this._isPointer||(e=this._mainComponent)==null||e.setCursor(M.CURSOR_TYPE.POINTER),this._isPointer=!0):(this._isPointer&&((t=this._mainComponent)==null||t.setCursor(M.CURSOR_TYPE.AUTO)),this._isPointer=!1)}))}_initPointerEvent(){this.disposeWithMe(this._hoverManagerService.currentClickedCell$.subscribe(o=>{const{location:e,bullet:t}=o;t&&this._commandService.executeCommand(m.ToggleCellCheckboxCommand.id,{unitId:e.unitId,subUnitId:e.subUnitId,row:e.row,col:e.col,paragraphIndex:t.startIndex})}))}};Fo=Tp([xo(0,a.Inject(y.HoverManagerService)),xo(1,a.IUniverInstanceService),xo(2,a.ICommandService),xo(3,M.IRenderManagerService)],Fo);var yp=Object.getOwnPropertyDescriptor,Mp=(n,o,e,t)=>{for(var i=t>1?void 0:t?yp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ui=(n,o)=>(e,t)=>o(e,t,n);let zo=class extends a.Disposable{constructor(n,o,e,t,i){super(),this._selectionManagerService=n,this._themeService=o,this._instanceSrv=e,this._cmdSrv=t,this._definedNamesService=i,this._init()}_init(){this.disposeWithMe(D.merge(this._selectionManagerService.selectionMoveStart$,this._selectionManagerService.selectionMoving$,this._selectionManagerService.selectionMoveEnd$,this._selectionManagerService.selectionSet$).pipe(D.filter(n=>!!n)).subscribe(n=>{this._syncDefinedNameRange(n)})),this.disposeWithMe(this._definedNamesService.focusRange$.subscribe(async n=>{if(n==null)return;const{unitId:o}=n;let{formulaOrRefString:e}=n;if(e.substring(0,1)===q.operatorToken.EQUALS&&(e=e.substring(1)),!q.isReferenceStrings(e))return;const i=this._instanceSrv.getUnit(o),r=await this._getSelections(i,o,e);this._selectionManagerService.setSelections(r),this._cmdSrv.executeCommand(m.ScrollToCellOperation.id,{unitId:o,range:r[0].range})}))}_syncDefinedNameRange(n){if(n.length===0)return;const o=n[n.length-1],e=this._instanceSrv.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),t=e==null?void 0:e.getActiveSheet();t&&this._definedNamesService.setCurrentRange({range:o.range,unitId:e.getUnitId(),sheetId:t.getSheetId()})}async _getSelections(n,o,e){const t=e.split(",");let i=n.getActiveSheet();if(!i)return[];const r=[];for(let s=0;s<t.length;s++){const l=t[s].trim(),c=q.deserializeRangeWithSheet(l.trim());if(s===0){const u=n.getSheetBySheetName(c.sheetName);u&&i.getSheetId()!==u.getSheetId()&&(i=u,await this._cmdSrv.executeCommand(m.SetWorksheetActivateCommand.id,{subUnitId:i.getSheetId(),unitId:o}))}if(i.getName()!==c.sheetName)continue;let d=null;if(s===t.length-1){const u=c.range,{startRow:h,startColumn:S,endRow:g,endColumn:f}=u;d=m.getPrimaryForRange({startRow:h,startColumn:S,endRow:g,endColumn:f},i)}r.push({range:c.range,style:gt(this._themeService),primary:d})}return r}};zo=Mp([Ui(0,a.Inject(m.SheetsSelectionsService)),Ui(1,a.Inject(a.ThemeService)),Ui(2,a.IUniverInstanceService),Ui(3,a.ICommandService),Ui(4,q.IDefinedNamesService)],zo);var Rp=Object.getOwnPropertyDescriptor,Pp=(n,o,e,t)=>{for(var i=t>1?void 0:t?Rp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ht=(n,o)=>(e,t)=>o(e,t,n);y.FormulaEditorController=class extends a.RxDisposable{constructor(e,t,i,r,s,l,c,d,u){super();T(this,"_loadedMap",new WeakSet);T(this,"_scheduledCallback",-1);this._univerInstanceService=e,this._renderManagerService=t,this._editorBridgeService=i,this._commandService=r,this._contextService=s,this._formulaEditorManagerService=l,this._undoRedoService=c,this._textSelectionManagerService=d,this._editorService=u,this._initialize()}_initialize(){this._syncEditorSize(),this._listenFxBtnClick(),this._handleContentChange(),this._univerInstanceService.focused$.pipe(D.takeUntil(this.dispose$)).subscribe(e=>{this._create(e)}),this._create(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),this.disposeWithMe(this._editorService.focus$.subscribe(()=>{var t;((t=this._editorService.getFocusEditor())==null?void 0:t.getEditorId())!==a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY?this._contextService.setContextValue(a.FOCUSING_FX_BAR_EDITOR,!1):this._contextService.setContextValue(a.FOCUSING_FX_BAR_EDITOR,!0)}))}_handleContentChange(){this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===_e.RichTextEditingMutation.id){const t=e.params,{unitId:i}=t;i===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&this.autoScroll()}}))}_create(e){if(e!==a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)return;const t=this._renderManagerService.getRenderById(e);if(t==null)return;const{mainComponent:i}=t;i!=null&&(this._loadedMap.has(i)||this._loadedMap.add(i))}_listenFxBtnClick(){this._formulaEditorManagerService.fxBtnClick$.pipe(D.takeUntil(this.dispose$)).subscribe(()=>{var t,i;if(this._contextService.getContextValue(a.FOCUSING_EDITOR_BUT_HIDDEN)&&!this._contextService.getContextValue(a.EDITOR_ACTIVATED)){this._univerInstanceService.setCurrentUnitForType(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),this._contextService.setContextValue(a.FOCUSING_FX_BAR_EDITOR,!0);const r=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),s=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);this._editorBridgeService.isVisible().visible===!1&&this._commandService.syncExecuteCommand(ge.id,{visible:!0,eventType:M.DeviceInputEventType.PointerDown,unitId:(t=r==null?void 0:r.getUnitId())!=null?t:""});const c=(i=s==null?void 0:s.getBody())==null?void 0:i.dataStream;if(c==null)return;let d=c.startsWith("=")?c:`=${c}`;d=d.replace(/\r\n$/,"");const u=[{startOffset:d.length,endOffset:d.length}],h={unitId:a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,body:{dataStream:d},segmentId:""};this._commandService.executeCommand(Q.CoverContentCommand.id,h),this._textSelectionManagerService.replaceDocRanges(u)}})}_syncEditorSize(){const e=this._univerInstanceService.unitAdded$.pipe(D.filter(t=>t.getUnitId()===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY));this.disposeWithMe(D.combineLatest([this._formulaEditorManagerService.position$,e]).subscribe(([t])=>{if(!t)return this._clearScheduledCallback();const i=zi(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,this._renderManagerService),r=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(i==null||r==null)return this._clearScheduledCallback();const{width:s,height:l}=t;if(s===0||l===0)return this._clearScheduledCallback();const{engine:c}=i;r.updateDocumentDataPageSize(s),this.autoScroll(),this._scheduledCallback=requestIdleCallback(()=>c.resizeBySize(s,l))}))}_clearScheduledCallback(){this._scheduledCallback!==-1&&cancelIdleCallback(this._scheduledCallback),this._scheduledCallback=-1}autoScroll(){var p,v;const e=this._formulaEditorManagerService.getPosition(),t=(p=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY))==null?void 0:p.with(_e.DocSkeletonManagerService).getSkeleton(),i=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),r=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(t==null||e==null||i==null||r==null)return;const{marginTop:s=0,marginBottom:l=0}=r.getSnapshot().documentStyle,{scene:c,mainComponent:d}=i;let{actualHeight:u}=t.getActualSize();u+=s+l;const{width:h,height:S}=e,g=c.getViewport(Q.VIEWPORT_KEY.VIEW_MAIN);let f=g==null?void 0:g.getScrollBar();c.transformByState({width:h,height:u}),d==null||d.resize(h,u),u>S?f==null?g&&new M.ScrollBar(g,{enableHorizontal:!1,barSize:8}):g==null||g.resetCanvasSizeAndUpdateScroll():(f=null,g==null||g.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0}),(v=g==null?void 0:g.getScrollBar())==null||v.dispose())}},y.FormulaEditorController=Pp([ht(0,a.IUniverInstanceService),ht(1,M.IRenderManagerService),ht(2,Se),ht(3,a.ICommandService),ht(4,a.IContextService),ht(5,ti),ht(6,a.IUndoRedoService),ht(7,a.Inject(_e.DocSelectionManagerService)),ht(8,Q.IEditorService)],y.FormulaEditorController);var Op=Object.getOwnPropertyDescriptor,Ap=(n,o,e,t)=>{for(var i=t>1?void 0:t?Op(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},yt=(n,o)=>(e,t)=>o(e,t,n);const Dp={pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},documentFlavor:a.DocumentFlavor.UNSPECIFIED,marginTop:5,marginBottom:5,marginRight:0,marginLeft:0,paragraphLineGapDefault:0,renderConfig:{horizontalAlign:a.HorizontalAlign.UNSPECIFIED,verticalAlign:a.VerticalAlign.TOP,centerAngle:0,vertexAngle:0,wrapStrategy:a.WrapStrategy.WRAP,isRenderStyle:a.BooleanNumber.FALSE}};let Xo=class extends a.Disposable{constructor(n,o,e,t,i,r,s,l){super(),this._univerInstanceService=n,this._renderManagerService=o,this._editorBridgeService=e,this._commandService=t,this._rangeProtectionRuleModel=i,this._worksheetProtectionRuleModel=r,this._formulaEditorController=s,this._formulaEditorManagerService=l,this._initialize()}_initialize(){this._syncFormulaEditorContent(),this._commandExecutedListener()}_getEditorViewModel(n){var o;return(o=this._renderManagerService.getRenderById(n))==null?void 0:o.with(_e.DocSkeletonManagerService).getViewModel()}_syncFormulaEditorContent(){this.disposeWithMe(this._editorBridgeService.currentEditCellState$.subscribe(n=>{n==null||this._editorBridgeService.isForceKeepVisible()||!this._rangeProtectionRuleModel.getRangeRuleInitState()||!this._worksheetProtectionRuleModel.getSheetRuleInitState()||this._editorSyncHandler(n)}))}_editorSyncHandler(n){var i,r,s;let o=a.Tools.deepClone((i=n.documentLayoutObject.documentModel)==null?void 0:i.getBody());const e=a.Tools.deepClone((r=n.documentLayoutObject.documentModel)==null?void 0:r.drawings),t=a.Tools.deepClone((s=n.documentLayoutObject.documentModel)==null?void 0:s.getDrawingsOrder());(!o||n.isInArrayFormulaRange===!0&&this._editorBridgeService.isVisible().eventType===M.DeviceInputEventType.Dblclick)&&(o={dataStream:`\r
82
+ `)}]}}var Zg=Object.getOwnPropertyDescriptor,Kg=(n,o,e,t)=>{for(var i=t>1?void 0:t?Zg(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},tt=(n,o)=>(e,t)=>o(e,t,n);const qg=[m.InsertColMutation.id,m.InsertRowMutation.id,m.RemoveColMutation.id,m.RemoveRowMutation.id,m.MoveRangeMutation.id,m.MoveRowsMutation.id,m.MoveColsMutation.id];let Ln=class extends a.RxDisposable{constructor(o,e,t,i,r,s,l,c,d,u){super();T(this,"_refreshOptionalPaste$",new D.Subject);T(this,"refreshOptionalPaste$",this._refreshOptionalPaste$.asObservable());this._injector=o,this._instanceService=e,this._renderManagerService=t,this._commandService=i,this._contextService=r,this._configService=s,this._sheetClipboardService=l,this._messageService=c,this._localService=d,this._uiPartsService=u,this._init(),this._initCommandListener(),this._initUIComponents(),this._pasteWithDoc()}refreshOptionalPaste(){this._refreshOptionalPaste$.next(Math.random())}_pasteWithDoc(){var t;const o=i=>{i.onPaste$.pipe(D.takeUntil(this.dispose$)).subscribe(r=>{var u,h;if(!le(this._contextService))return;r.event.preventDefault();const s=r.event,l=(u=s.clipboardData)==null?void 0:u.getData("text/html"),c=(h=s.clipboardData)==null?void 0:h.getData("text/plain"),d=this._resolveClipboardFiles(s.clipboardData);this._commandService.executeCommand(uo.id,{htmlContent:l,textContent:c,files:d})})};let e=(t=this._renderManagerService.getRenderById(a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY))==null?void 0:t.with(Q.DocSelectionRenderService);e&&o(e),this._renderManagerService.created$.subscribe(i=>{var r;i.unitId===a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY&&(e=(r=this._renderManagerService.getRenderById(a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY))==null?void 0:r.with(Q.DocSelectionRenderService),e&&o(e))})}_resolveClipboardFiles(o){if(!o)return;const e=Array.from(o.items).map(t=>t.kind==="file"?t.getAsFile():void 0).filter(Boolean);return e.length>0?e:void 0}_init(){[je,co,Ge].forEach(e=>this.disposeWithMe(this._commandService.registerMultipleCommand(e))),[In,_n,Bt,bn,uo,ul].forEach(e=>this.disposeWithMe(this._commandService.registerCommand(e))),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initCopyingHooks())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initPastingHook()));const o=this._initSpecialPasteHooks().map(e=>this._sheetClipboardService.addClipboardHook(e));this.disposeWithMe({dispose:()=>o.forEach(e=>e.dispose())})}_initCopyingHooks(){const o=this;let e=null;return{id:fe.DEFAULT_COPY,isDefaultHook:!0,onBeforeCopy(t,i){e=o._getWorksheet(t,i)},onCopyCellContent(t,i){var l,c,d,u;const r=e.getCell(t,i);return(c=(l=r==null?void 0:r.p)==null?void 0:l.body)!=null&&c.paragraphs||(u=(d=r==null?void 0:r.p)==null?void 0:d.body)!=null&&u.textRuns?a.convertBodyToHtml(r.p.body):r?a.extractPureTextFromCell(r):""},onCopyCellStyle:(t,i,r,s)=>{const l={};(r||s)&&(l.rowspan=`${r||1}`,l.colspan=`${s||1}`);const c=e.getRange(t,i),d=e.getMergedCell(t,i),u=c.getTextStyle();let h="";if(u&&(h=a.handleStyleToString(u)),d){const S=d.endRow,g=d.endColumn,p=e.getRange(S,g).getTextStyle();if(p){const v=a.handleStyleToString(p);h?h+=v?`;${v}`:"":h=v}}return h&&(l.style=h),Object.keys(l).length?l:null},onCopyColumn(t){return{width:`${e.getColumnWidth(t)}`}},onCopyRow(t){return{style:`height: ${e.getRowHeight(t)}px;`}},onAfterCopy(){e=null},getFilteredOutRows(t){var c;const{startRow:i,endRow:r}=t,s=(c=o._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getActiveSheet(),l=[];if(!s)return l;for(let d=i;d<=r;d++)s.getRowFiltered(d)&&l.push(d);return l}}}_initPastingHook(){const o=this;let e=null,t=null,i=null;return{id:fe.DEFAULT_PASTE,isDefaultHook:!0,onBeforePaste({unitId:r,subUnitId:s,range:l}){i=o._getWorksheet(r,s),e=r,t=s;const c=o._configService.getConfig(m.MAX_CELL_PER_SHEET_KEY),d=l.rows[l.rows.length-1],u=l.cols[l.cols.length-1];return c&&d*u>c?(o._messageService.show({type:j.MessageType.Error,content:o._localService.t("clipboard.paste.exceedMaxCells")}),!1):!0},onPasteRows(r,s){const{range:l}=r,c=[],d=[],u=i.getMaxRows(),h=u-1,S=l.rows[l.rows.length-1]-h,g=s.length-S,f=i.getRowManager();if(S>0){const C={};s.slice(g).forEach((w,O)=>{const{height:R}=w||{};R&&(C[O]={h:Number.parseFloat(R),hd:a.BooleanNumber.FALSE})});const b={startColumn:l.cols[0],endColumn:l.cols[l.cols.length-1],endRow:l.rows[l.rows.length-1],startRow:u},E={unitId:e,subUnitId:t,range:b,rowInfo:C};c.push({id:m.InsertRowMutation.id,params:E}),d.push({id:m.RemoveRowMutation.id,params:{unitId:e,subUnitId:t,range:b}})}const p={},v={};if(s.slice(0,g).forEach((C,b)=>{var w,O;const{height:E}=C;if(E){const R=f.getRow(l.rows[0]+b),P=Number.parseFloat(E);if(R){const{h:A=a.DEFAULT_WORKSHEET_ROW_HEIGHT,ah:k=0}=R,N=Math.max(A,k);P>N?(p[b+l.rows[0]]=P,v[b+l.rows[0]]=N):(p[b+l.rows[0]]=N,v[b+l.rows[0]]=N)}else p[b+l.rows[0]]=P,v[b+l.rows[0]]=(O=(w=f.getRow(l.rows[0]+b))==null?void 0:w.h)!=null?O:a.DEFAULT_WORKSHEET_ROW_HEIGHT}}),Object.keys(p).length){const C={unitId:e,subUnitId:t,ranges:[{startRow:l.rows[0],endRow:Math.min(l.rows[l.rows.length-1],u),startColumn:l.cols[0],endColumn:l.cols[l.cols.length-1]}],rowHeight:p};c.push({id:m.SetWorksheetRowHeightMutation.id,params:C}),d.push({id:m.SetWorksheetRowHeightMutation.id,params:{...C,rowHeight:v}})}return{redos:c,undos:d}},onPasteColumns(r,s,l){var E;const{range:c}=r,d=[],u=[],h=i.getMaxColumns(),S=h-1,g=c.cols[c.cols.length-1]-S,f=s.length-g,p=(E=o._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?E:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,v=c.cols,C=v[0];if(g>0){const w={startRow:c.rows[0],endRow:c.rows[c.rows.length-1],endColumn:c.cols[c.cols.length-1],startColumn:h},O={unitId:e,subUnitId:t,range:w,colInfo:s.slice(f).map((R,P)=>({w:R.width?Math.max(+R.width,i.getColumnWidth(v[P])):p,hd:a.BooleanNumber.FALSE}))};d.push({id:m.InsertColMutation.id,params:O}),u.push({id:m.RemoveColMutation.id,params:{unitId:e,subUnitId:t,range:w}})}const b={unitId:e,subUnitId:t,ranges:[{startRow:c.rows[0],endRow:c.rows[c.rows.length-1],startColumn:c.cols[0],endColumn:Math.min(c.cols[c.cols.length-1],h)}]};if(s.length>0){const w={...b,colWidth:s.slice(0,f).reduce((R,P,A)=>{var k;return R[A+C]=P.width?Math.max(+P.width,(k=i.getColumnWidth(v[A]))!=null?k:p):p,R},{})},O={...b,colWidth:s.slice(0,f).reduce((R,P,A)=>{var k;return R[A+C]=(k=i.getColumnWidth(v[A]))!=null?k:p,R},{})};d.push({id:m.SetWorksheetColWidthMutation.id,params:w}),u.push({id:m.SetWorksheetColWidthMutation.id,params:O})}return{redos:d,undos:u}},onPastePlainText(r,s,l){return o._onPastePlainText(r,s,l)},onPasteCells(r,s,l,c){return o._onPasteCells(r,s,l,c)},onAfterPaste(r){i=null}}}_generateDocumentDataModelSnapshot(o){var l,c;const e=(l=M.withCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,y.SheetSkeletonManagerService,this._instanceService,this._renderManagerService))==null?void 0:l.getCurrentParam();if(e==null)return null;const{skeleton:t}=e,i=(c=t.getBlankCellDocumentModel())==null?void 0:c.documentModel,s={...i==null?void 0:i.getSnapshot(),...o};return i==null||i.reset(s),i==null?void 0:i.getSnapshot()}_onPastePlainText(o,e,t){const{range:i,unitId:r,subUnitId:s}=o;let l;if(/\r|\n/.test(e)||a.Tools.isLegalUrl(e)){const d=Gg(e),u=this._generateDocumentDataModelSnapshot({body:d});l={[i.rows[0]]:{[i.cols[0]]:{p:u}}}}else a.isFormulaString(e)?l={[i.rows[0]]:{[i.cols[0]]:{f:e}}}:l={[i.rows[0]]:{[i.cols[0]]:{v:e}}};const c={unitId:r,subUnitId:s,cellValue:l};return{redos:[{id:m.SetRangeValuesMutation.id,params:c}],undos:[{id:m.SetRangeValuesMutation.id,params:m.SetRangeValuesUndoMutationFactory(this._injector,c)}]}}_onPasteCells(o,e,t,i){return this._injector.invoke(r=>Xg(o,e,t,i,r))}_initSpecialPasteHooks(){const o=this,e={id:fe.SPECIAL_PASTE_VALUE,specialPasteInfo:{label:"specialPaste.value"},onPasteCells:(s,l,c)=>this._injector.invoke(d=>Uc(l,s,c,d))},t={id:fe.SPECIAL_PASTE_FORMAT,specialPasteInfo:{label:"specialPaste.format"},onPasteCells:(s,l,c)=>{const d=[],u=[],{undos:h,redos:S}=this._injector.invoke(C=>xc(l,c,C));d.push(...S),u.push(...h);const{undos:g,redos:f}=this._injector.invoke(C=>_s(l,c,C));d.push(...f),u.push(...g);const{undos:p,redos:v}=this._injector.invoke(C=>Bc(l,s,c,C));return d.push(...v),u.push(...p),{undos:u,redos:d}}},i={id:fe.SPECIAL_PASTE_COL_WIDTH,specialPasteInfo:{label:"specialPaste.colWidth"},onPasteCells(){return{undos:[],redos:[]}},onPasteColumns(s,l,c){var A,k;const d=o._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),u=d.getUnitId(),h=(A=d.getActiveSheet())==null?void 0:A.getSheetId();if(!u||!h)throw new Error("Cannot find unitId or subUnitId");const S=[],g=[],f=o._getWorksheet(u,h),{range:p}=s,v=p.cols,C=v[0],b=f.getMaxColumns(),E=p.cols[p.cols.length-1]-b,w=l.length-E,O=(k=o._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?k:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,R={unitId:u,subUnitId:h,ranges:[{startRow:p.rows[0],endRow:Math.min(p.cols[p.cols.length-1],b),startColumn:p.cols[0],endColumn:p.cols[p.cols.length-1]}],colWidth:l.slice(0,w).reduce((N,H,V)=>{var U;return N[V+C]=H.width?Math.max(+H.width,(U=f.getColumnWidth(v[V]))!=null?U:O):O,N},{})},P={unitId:u,subUnitId:h,ranges:[{startRow:p.rows[0],endRow:Math.min(p.cols[p.cols.length-1],b),startColumn:p.cols[0],endColumn:p.cols[p.cols.length-1]}],colWidth:l.slice(0,w).reduce((N,H,V)=>{var U;return N[V+C]=(U=f.getColumnWidth(v[V]))!=null?U:O,N},{})};return S.push({id:m.SetWorksheetColWidthMutation.id,params:R}),g.push({id:m.SetWorksheetColWidthMutation.id,params:P}),{redos:S,undos:g}}},r={id:fe.SPECIAL_PASTE_BESIDES_BORDER,specialPasteInfo:{label:"specialPaste.besidesBorder"},onPasteCells:(s,l,c,d)=>{o._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);const u=[],h=[],{range:S,unitId:g,subUnitId:f}=l,p=new a.ObjectMatrix;c.forValue((w,O,R)=>{const P=R.s;if(typeof P=="object"){const A=a.Tools.deepClone(R);A.s&&(A.s={...P,bd:null}),p.setValue(S.rows[w],S.cols[O],A)}});const v={unitId:g,subUnitId:f,cellValue:p.getData()};u.push({id:m.SetRangeValuesMutation.id,params:v});const C=this._injector.invoke(m.SetRangeValuesUndoMutationFactory,v);h.push({id:m.SetRangeValuesMutation.id,params:C});const{undos:b,redos:E}=this._injector.invoke(w=>_s(l,c,w));return h.push(...b),u.push(...E),{redos:u,undos:h}}};return[e,t,i,r]}_getWorksheet(o,e){var i;const t=(i=this._instanceService.getUniverSheetInstance(o))==null?void 0:i.getSheetBySheetId(e);if(!t)throw new Error(`[SheetClipboardController]: cannot find a worksheet with unitId ${o} and subUnitId ${e}.`);return t}_initCommandListener(){var e;this.disposeWithMe(this._commandService.onCommandExecuted(t=>{t.id===bt.id?this._sheetClipboardService.removeMarkSelection():qg.includes(t.id)&&this._sheetClipboardService.removeMarkSelection()}));const o=this._configService.getConfig(Fe);(e=o==null?void 0:o.clipboardConfig)!=null&&e.hidePasteOptions||(this.disposeWithMe(this._commandService.onCommandExecuted(t=>{zg.includes(t.id)&&this._sheetClipboardService.disposePasteOptionsCache()})),this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===Xe.id){if(!this._sheetClipboardService.getPasteMenuVisible())return;const r=t.params.unitId,s=this._sheetClipboardService.getPasteOptionsCache(),l=s==null?void 0:s.target.unitId;r===l&&this._refreshOptionalPaste$.next(Math.random())}})))}_initUIComponents(){var e;const o=this._configService.getConfig(Fe);(e=o==null?void 0:o.clipboardConfig)!=null&&e.hidePasteOptions||this.disposeWithMe(this._uiPartsService.registerComponent(I.BuiltInUIPart.CONTENT,()=>I.connectInjector(Fg,this._injector)))}};Ln=Kg([tt(0,a.Inject(a.Injector)),tt(1,a.IUniverInstanceService),tt(2,M.IRenderManagerService),tt(3,a.ICommandService),tt(4,a.IContextService),tt(5,a.IConfigService),tt(6,Be),tt(7,I.IMessageService),tt(8,a.Inject(a.LocaleService)),tt(9,I.IUIPartsService)],Ln);var Qg=Object.getOwnPropertyDescriptor,Jg=(n,o,e,t)=>{for(var i=t>1?void 0:t?Qg(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Fc=(n,o)=>(e,t)=>o(e,t,n);y.DragManagerService=class extends a.Disposable{constructor(e,t){super();T(this,"_currentCell$",new D.Subject);T(this,"currentCell$",this._currentCell$.asObservable().pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)})));T(this,"_endCell$",new D.Subject);T(this,"endCell$",this._endCell$.asObservable());this._univerInstanceService=e,this._renderManagerService=t,this._initCellDisposableListener()}dispose(){super.dispose(),this._currentCell$.complete(),this._endCell$.complete()}_initCellDisposableListener(){this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{e||(this._currentCell$.next(null),this._endCell$.next(null))}))}_calcActiveCell(e,t){const i=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!i)return null;const r=i.getActiveSheet();if(!r)return;const s=this._renderManagerService.getRenderById(i.getUnitId());if(!s)return;const l=s.with(y.SheetSkeletonManagerService).getCurrentParam(),d=s.with(y.SheetScrollManagerService).getCurrentScrollState();if(!(!l||!d||!s))return Nl(s,i,r,l,e,t)}onDragOver(e){const{offsetX:t,offsetY:i,dataTransfer:r}=e,s=this._calcActiveCell(t,i);if(!s){this._currentCell$.next(null);return}const{location:l,position:c}=s;this._currentCell$.next({location:l,position:c,dataTransfer:r})}onDrop(e){const{offsetX:t,offsetY:i,dataTransfer:r}=e,s=this._calcActiveCell(t,i);if(!s){this._endCell$.next(null);return}const{location:l,position:c}=s;this._endCell$.next({location:l,position:c,dataTransfer:r})}},y.DragManagerService=Jg([Fc(0,a.IUniverInstanceService),Fc(1,M.IRenderManagerService)],y.DragManagerService);var $g=Object.getOwnPropertyDescriptor,ef=(n,o,e,t)=>{for(var i=t>1?void 0:t?$g(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},bs=(n,o)=>(e,t)=>o(e,t,n);y.DragRenderController=class extends a.Disposable{constructor(o,e,t,i){super(),this._context=o,this._renderManagerService=e,this._dragManagerService=t,this._sheetSkeletonManagerService=i,this._initDragEvent()}_initDragEvent(){const o=new a.DisposableCollection,e=t=>{if(o.dispose(),!t)return;const{scene:i}=this._context,r=i.onDragOver$.subscribeEvent(l=>{this._dragManagerService.onDragOver(l)}),s=i.onDrop$.subscribeEvent(l=>{this._dragManagerService.onDrop(l)});o.add({dispose(){r.unsubscribe(),s.unsubscribe()}})};e(this._sheetSkeletonManagerService.getCurrentParam()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(t=>{e(t)}))}},y.DragRenderController=ef([bs(1,M.IRenderManagerService),bs(2,a.Inject(y.DragManagerService)),bs(3,a.Inject(y.SheetSkeletonManagerService))],y.DragRenderController);const Es=(n,o)=>{var h,S,g,f,p;const t=o.findNodePositionByCharIndex(n.startOffset,!0,n.segmentId,-1),i=o.getSkeletonData();let r=n.endOffset;if(n.segmentId){const v=(p=Array.from((S=(h=i==null?void 0:i.skeFooters.get(n.segmentId))==null?void 0:h.values())!=null?S:[])[0])!=null?p:Array.from((f=(g=i==null?void 0:i.skeHeaders.get(n.segmentId))==null?void 0:g.values())!=null?f:[])[0];v&&(r=Math.min(v.ed,r))}const s=o.findNodePositionByCharIndex(r,!0,n.segmentId,-1);if(!s||!t)return;const l={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},c=new Q.NodePositionConvertToCursor(l,o),{borderBoxPointGroup:d}=c.getRangePointData(t,s);return Q.getLineBounding(d).map(v=>({top:v.top,bottom:v.bottom,left:v.left,right:v.right}))},tf=(n,o,e=-1)=>{const t=o.findPositionByGlyph(n,e);if(!t)return;const i={...t,isBack:!0},r={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},s=new Q.NodePositionConvertToCursor(r,o),{borderBoxPointGroup:l}=s.getRangePointData(i,i),d=Q.getLineBounding(l)[0];return{top:d.top,bottom:d.bottom,left:d.left,right:d.right}},nf=(n,o,e=0,t=0)=>{const i=Es({startOffset:o.startIndex,endOffset:o.endIndex+1},n);if(i)return{rects:i.map(r=>({top:r.top+t,bottom:r.bottom+t,left:r.left+e,right:r.right+e})),range:o}},of=(n,o,e=0,t=0)=>{var h,S,g;const i=n.findNodeByCharIndex(o.startIndex),r=i==null?void 0:i.parent,s=r==null?void 0:r.parent,l=s==null?void 0:s.parent,c=l==null?void 0:l.lines.find(f=>f.paragraphStart&&f.paragraphIndex===o.startIndex),d=(g=(S=(h=c==null?void 0:c.divides)==null?void 0:h[0])==null?void 0:S.glyphGroup)==null?void 0:g[0];if(!d||!d)return;const u=tf(d,n);if(u)return{rect:{top:u.top+t,bottom:u.bottom+t,left:u.left+e,right:u.right+e},segmentId:void 0,segmentPageIndex:-1,paragraph:o}},zc=(n,o=0,e=0)=>{var l,c,d,u,h,S,g;const t=n.getViewModel().getDataModel(),i=(d=(c=(l=t.getBody())==null?void 0:l.customRanges)==null?void 0:c.filter(f=>f.rangeType===a.CustomRangeType.HYPERLINK))!=null?d:[],r=(S=(h=(u=t.getBody())==null?void 0:u.paragraphs)==null?void 0:h.filter(f=>{var p;return((p=f.bullet)==null?void 0:p.listType.indexOf(a.PresetListType.CHECK_LIST))===0}))!=null?S:[],s=(g=n.getSkeletonData())==null?void 0:g.pages[0].skeDrawings;return{links:i.map(f=>nf(n,f,o,e)).filter(Boolean),checkLists:r.map(f=>of(n,f,o,e)).filter(Boolean),drawings:s?Array.from(s.keys()).map(f=>({drawingId:f,rect:{top:s.get(f).aTop,bottom:s.get(f).aTop+s.get(f).width,left:s.get(f).aLeft,right:s.get(f).aLeft+s.get(f).height},drawing:s.get(f)})):[]}};function Xc(n,o,e){var d,u,h,S,g,f;const t=(h=(u=(d=o.documentSkeleton)==null?void 0:d.getSkeletonData())==null?void 0:u.pages[0].height)!=null?h:0,i=(f=(g=(S=o.documentSkeleton)==null?void 0:S.getSkeletonData())==null?void 0:g.pages[0].width)!=null?f:0,r=o.verticalAlign,s=o.horizontalAlign;let l=0;switch(r){case a.VerticalAlign.UNSPECIFIED:case a.VerticalAlign.BOTTOM:l=n.mergeInfo.endY-n.mergeInfo.startY-t;break;case a.VerticalAlign.MIDDLE:l=(n.mergeInfo.endY-n.mergeInfo.startY-t)/2;break}let c=0;switch(s){case a.HorizontalAlign.RIGHT:c=n.mergeInfo.endX-n.mergeInfo.startX-i;break;case a.HorizontalAlign.CENTER:c=(n.mergeInfo.endX-n.mergeInfo.startX-i)/2;break;case a.HorizontalAlign.UNSPECIFIED:{e&&(c=n.mergeInfo.endX-n.mergeInfo.startX-i);break}}return{paddingLeft:c,paddingTop:l}}const rf=(n,o,e,t,i,r)=>{var H,V,U;const s=n.get(a.IUniverInstanceService),l=n.get(M.IRenderManagerService),c=s.getUnit(o,a.UniverInstanceType.UNIVER_SHEET);if(!c)return null;const d=c.getSheetBySheetId(e);if(!d)return null;const u=l.getRenderById(c.getUnitId()),h=u==null?void 0:u.with(y.SheetSkeletonManagerService).getSkeletonParam(d.getSheetId()),S=h==null?void 0:h.skeleton;if(!S||!u)return;const g=S.getFont(t,i),f=g==null?void 0:g.documentSkeleton;if(!f)return null;const p=(V=(H=f.getViewModel().getBody())==null?void 0:H.customRanges)==null?void 0:V.find(W=>W.rangeId===r);if(!p)return null;const v=Q.DOC_VERTICAL_PADDING,C=S.getCellWithCoordByIndex(t,i);let{actualColumn:b,actualRow:E}=C;S.overflowCache.forValue((W,B,x)=>{x.startRow<=E&&x.endRow>=E&&x.startColumn<=b&&x.endColumn>=b&&(b=B,E=W)});const w=S.getCellWithCoordByIndex(E,b),O=d.getCell(w.actualRow,w.actualColumn),{topOffset:R=0,leftOffset:P=0}=(U=O==null?void 0:O.fontRenderExtension)!=null?U:{},{paddingLeft:A,paddingTop:k}=Xc(w,g,!1),N=Es({startOffset:p.startIndex,endOffset:p.endIndex},f);return{rects:N==null?void 0:N.map(W=>({top:W.top+w.mergeInfo.startY+k+R+v,bottom:W.bottom+w.mergeInfo.startY+k+R+v,left:W.left+w.mergeInfo.startX+A+P,right:W.right+w.mergeInfo.startX+A+P})),customRange:p,label:f.getViewModel().getBody().dataStream.slice(p.startIndex,p.endIndex+1)}},sf=(n,o,e,t,i,r)=>{var P,A,k;const s=n.get(Se),l=s.getEditCellState();if(!l||!s.isVisible().visible)return null;const{editorUnitId:d,unitId:u,sheetId:h,row:S,column:g}=l;if(o!==u||e!==h||S!==t||g!==i)return null;const f=n.get(M.IRenderManagerService),p=f.getRenderById(d),v=f.getRenderById(o);if(!p||!v)return null;const C=p.with(_e.DocSkeletonManagerService).getSkeleton(),b=(P=v.with(y.SheetSkeletonManagerService).getSkeletonParam(h))==null?void 0:P.skeleton;if(!C||!b)return null;const E=(k=(A=C.getViewModel().getBody())==null?void 0:A.customRanges)==null?void 0:k.find(N=>N.rangeId===r);if(!E)return null;const w=4,O=Es({startOffset:E.startIndex,endOffset:E.endIndex},C),R=p.engine.getCanvasElement().getBoundingClientRect();return{rects:O==null?void 0:O.map(N=>({top:N.top+R.top-w,bottom:N.bottom+R.top+w,left:N.left+R.left,right:N.right+R.left})),customRange:E,label:C.getViewModel().getBody().dataStream.slice(E.startIndex,E.endIndex+1)}};var af=Object.getOwnPropertyDescriptor,lf=(n,o,e,t)=>{for(var i=t>1?void 0:t?af(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Yc=(n,o)=>(e,t)=>o(e,t,n);function en(n){const{workbook:o,worksheet:e,...t}=n;return t}y.HoverManagerService=class extends a.Disposable{constructor(e,t){super();T(this,"_currentCell$",new D.BehaviorSubject(null));T(this,"_currentRichText$",new D.BehaviorSubject(null));T(this,"_currentClickedCell$",new D.Subject);T(this,"_currentDbClickedCell$",new D.Subject);T(this,"_currentCellWithEvent$",new D.Subject);T(this,"_currentPointerDownCell$",new D.Subject);T(this,"_currentPointerUpCell$",new D.Subject);T(this,"_currentHoveredRowHeader$",new D.BehaviorSubject(null));T(this,"_currentHoveredColHeader$",new D.BehaviorSubject(null));T(this,"_currentRowHeaderClick$",new D.Subject);T(this,"_currentColHeaderClick$",new D.Subject);T(this,"_currentRowHeaderDbClick$",new D.Subject);T(this,"_currentColHeaderDbClick$",new D.Subject);T(this,"_currentRowHeaderPointerDown$",new D.Subject);T(this,"_currentColHeaderPointerDown$",new D.Subject);T(this,"_currentRowHeaderPointerUp$",new D.Subject);T(this,"_currentColHeaderPointerUp$",new D.Subject);T(this,"currentCell$",this._currentCell$.asObservable().pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)})));T(this,"currentRichTextNoDistinct$",this._currentRichText$.pipe(D.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,customRange:e.customRange,bullet:e.bullet,rect:e.rect,drawing:e.drawing})));T(this,"currentRichText$",this._currentRichText$.pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h,S,g,f,p,v,C,b,E,w,O;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)&&((S=e==null?void 0:e.customRange)==null?void 0:S.rangeId)===((g=t==null?void 0:t.customRange)==null?void 0:g.rangeId)&&((f=e==null?void 0:e.bullet)==null?void 0:f.startIndex)===((p=t==null?void 0:t.bullet)==null?void 0:p.startIndex)&&((v=e==null?void 0:e.customRange)==null?void 0:v.startIndex)===((C=t==null?void 0:t.customRange)==null?void 0:C.startIndex)&&((b=e==null?void 0:e.customRange)==null?void 0:b.endIndex)===((E=t==null?void 0:t.customRange)==null?void 0:E.endIndex)&&((w=e==null?void 0:e.drawing)==null?void 0:w.drawingId)===((O=t==null?void 0:t.drawing)==null?void 0:O.drawingId)}),D.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,customRange:e.customRange,bullet:e.bullet,rect:e.rect,drawing:e.drawing})));T(this,"currentCellPosWithEvent$",this._currentCellWithEvent$.pipe(D.distinctUntilChanged((e,t)=>{var i,r,s,l,c,d,u,h;return((i=e==null?void 0:e.location)==null?void 0:i.unitId)===((r=t==null?void 0:t.location)==null?void 0:r.unitId)&&((s=e==null?void 0:e.location)==null?void 0:s.subUnitId)===((l=t==null?void 0:t.location)==null?void 0:l.subUnitId)&&((c=e==null?void 0:e.location)==null?void 0:c.row)===((d=t==null?void 0:t.location)==null?void 0:d.row)&&((u=e==null?void 0:e.location)==null?void 0:u.col)===((h=t==null?void 0:t.location)==null?void 0:h.col)}),D.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,event:e.event})));T(this,"currentPosition$",this._currentCell$.asObservable());T(this,"currentClickedCell$",this._currentClickedCell$.asObservable());T(this,"currentDbClickedCell$",this._currentDbClickedCell$.asObservable());T(this,"currentPointerDownCell$",this._currentPointerDownCell$.asObservable());T(this,"currentPointerUpCell$",this._currentPointerUpCell$.asObservable());T(this,"currentHoveredRowHeader$",this._currentHoveredRowHeader$.asObservable());T(this,"currentHoveredColHeader$",this._currentHoveredColHeader$.asObservable());T(this,"currentRowHeaderClick$",this._currentRowHeaderClick$.asObservable());T(this,"currentColHeaderClick$",this._currentColHeaderClick$.asObservable());T(this,"currentRowHeaderDbClick$",this._currentRowHeaderDbClick$.asObservable());T(this,"currentColHeaderDbClick$",this._currentColHeaderDbClick$.asObservable());T(this,"currentRowHeaderPointerDown$",this._currentRowHeaderPointerDown$.asObservable());T(this,"currentColHeaderPointerDown$",this._currentColHeaderPointerDown$.asObservable());T(this,"currentRowHeaderPointerUp$",this._currentRowHeaderPointerUp$.asObservable());T(this,"currentColHeaderPointerUp$",this._currentColHeaderPointerUp$.asObservable());this._univerInstanceService=e,this._renderManagerService=t,this._initCellDisposableListener()}dispose(){super.dispose(),this._currentCell$.complete(),this._currentClickedCell$.complete(),this._currentPointerDownCell$.complete(),this._currentPointerUpCell$.complete(),this._currentCellWithEvent$.complete()}_initCellDisposableListener(){this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).subscribe(e=>{e||this._currentCell$.next(null)})),this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(e=>{var t,i;((t=this._currentCell$.getValue())==null?void 0:t.location.unitId)===e.getUnitId()&&this._currentCell$.next(null),((i=this._currentRichText$.getValue())==null?void 0:i.location.unitId)===e.getUnitId()&&this._currentRichText$.next(null)}))}_getCalcDeps(e){const t=this._univerInstanceService.getUnit(e,a.UniverInstanceType.UNIVER_SHEET);if(!t)return null;const i=t.getActiveSheet();if(!i)return null;const r=this._renderManagerService.getRenderById(t.getUnitId());if(!r)return null;const s=r.with(y.SheetSkeletonManagerService).getSkeletonParam(i.getSheetId());if(!s)return null;const l=r.with(y.SheetScrollManagerService);if(!(!(l!=null&&l.getCurrentScrollState())||!r))return{currentRender:r,workbook:t,worksheet:i,skeletonParam:s}}_calcActiveCell(e,t,i,r,s,l){var R,P,A;const c=Nl(e,t,i,r,s,l),d=r.skeleton;if(!c)return null;const{position:u,overflowLocation:h,location:S}=c,g=d.getFont(h.row,h.col);let f=null,p=null,v=null;const C=d.getCellWithCoordByIndex(h.row,h.col),b=i.getCell(h.row,h.col),{topOffset:E=0,leftOffset:w=0}=(R=b==null?void 0:b.fontRenderExtension)!=null?R:{};if(g!=null&&g.documentSkeleton){const{paddingLeft:k,paddingTop:N}=Xc(C,g,(b==null?void 0:b.v)!==null&&(b==null?void 0:b.v)!==void 0?!Number.isNaN(+b.v):!1),H=zc(g.documentSkeleton,k,N),V=s-u.startX-w,U=l-u.startY-E;f=H.links.find(W=>W.rects.some(B=>B.left<=V&&V<=B.right&&B.top<=U&&U<=B.bottom)),p=H.checkLists.find(W=>W.rect.left<=V&&V<=W.rect.right&&W.rect.top<=U&&U<=W.rect.bottom),v=H.drawings.find(W=>W.rect.left<=V&&V<=W.rect.right&&W.rect.top<=U&&U<=W.rect.bottom)}const O=(A=(P=f==null?void 0:f.rects.pop())!=null?P:p==null?void 0:p.rect)!=null?A:v==null?void 0:v.rect;return{location:S,position:u,overflowLocation:h,customRange:f==null?void 0:f.range,bullet:p==null?void 0:p.paragraph,drawing:v,rect:O&&{top:O.top+C.mergeInfo.startY+E,bottom:O.bottom+C.mergeInfo.startY+E,left:O.left+C.mergeInfo.startX+w,right:O.right+C.mergeInfo.startX+w}}}_calcActiveRowHeader(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,worksheet:l,skeletonParam:c}=r,{scaleY:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(g=>g.isHit(new M.Vector2(t,i)));if(!u||u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP&&u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},S=c.skeleton.getRowIndexByOffsetY(i,d,h);return{unitId:e,index:S,subUnitId:l.getSheetId()}}_calcActiveColHeader(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,worksheet:l,skeletonParam:c}=r,{scaleX:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(g=>g.isHit(new M.Vector2(t,i)));if(!u||u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT&&u.viewportKey!==M.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},S=c.skeleton.getColumnIndexByOffsetX(t,d,h);return{unitId:e,index:S,subUnitId:l.getSheetId()}}triggerPointerDown(e,t){const i=this._getCalcDeps(e);if(!i)return;const{currentRender:r,workbook:s,worksheet:l,skeletonParam:c}=i,d=this._calcActiveCell(r,s,l,c,t.offsetX,t.offsetY);if(d&&d.location){const{unitId:u,subUnitId:h,row:S,col:g}=en(d.location);this._currentPointerDownCell$.next({unitId:u,subUnitId:h,row:S,col:g,event:t})}}triggerPointerUp(e,t){const i=this._getCalcDeps(e);if(!i)return;const{currentRender:r,workbook:s,worksheet:l,skeletonParam:c}=i,d=this._calcActiveCell(r,s,l,c,t.offsetX,t.offsetY);if(d){const u=en(d.location);this._currentPointerUpCell$.next({...u,event:t})}}triggerMouseMove(e,t){const i=this._getCalcDeps(e);if(!i)return;const{currentRender:r,workbook:s,worksheet:l,skeletonParam:c}=i,d=this._calcActiveCell(r,s,l,c,t.offsetX,t.offsetY);this._currentCell$.next(d&&{location:en(d.location),position:d.position}),this._currentRichText$.next(d&&{...d,location:en(d.overflowLocation)}),this._currentCellWithEvent$.next(d&&{...d,location:en(d.location),event:t})}triggerClick(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=r,u=this._calcActiveCell(s,l,c,d,t,i);u&&this._currentClickedCell$.next({...u,location:en(u.location)})}triggerDbClick(e,t,i){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=r,u=this._calcActiveCell(s,l,c,d,t,i);u&&this._currentDbClickedCell$.next({...u,location:en(u.location)})}triggerScroll(){this._currentCell$.next(null)}triggerRowHeaderClick(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderClick$.next(r)}triggerColHeaderClick(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderClick$.next(r)}triggerRowHeaderDbClick(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderDbClick$.next(r)}triggerColHeaderDbClick(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderDbClick$.next(r)}triggerRowHeaderMouseMove(e,t,i){this._currentHoveredRowHeader$.next(this._calcActiveRowHeader(e,t,i))}triggerColHeaderMouseMove(e,t,i){this._currentHoveredColHeader$.next(this._calcActiveColHeader(e,t,i))}triggerRowHeaderPoniterDown(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderPointerDown$.next(r)}triggerColHeaderPoniterDown(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderPointerDown$.next(r)}triggerRowHeaderPoniterUp(e,t,i){const r=this._calcActiveRowHeader(e,t,i);r&&this._currentRowHeaderPointerUp$.next(r)}triggerColHeaderPoniterUp(e,t,i){const r=this._calcActiveColHeader(e,t,i);r&&this._currentColHeaderPointerUp$.next(r)}},y.HoverManagerService=lf([Yc(0,a.IUniverInstanceService),Yc(1,M.IRenderManagerService)],y.HoverManagerService);var cf=Object.getOwnPropertyDescriptor,df=(n,o,e,t)=>{for(var i=t>1?void 0:t?cf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},yo=(n,o)=>(e,t)=>o(e,t,n);const ws="SHEET_FORCE_STRING_ALERT";let Mo=class extends a.Disposable{constructor(n,o,e,t,i){super(),this._context=n,this._hoverManagerService=o,this._cellAlertManagerService=e,this._localeService=t,this._zenZoneService=i,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(n=>{var o;if(n){const t=this._context.unit.getActiveSheet();if(!t)return;const i=t.getCell(n.location.row,n.location.col);if((i==null?void 0:i.t)===a.CellValueType.FORCE_STRING&&i.v&&a.isRealNum(i.v)){const r=this._cellAlertManagerService.currentAlert.get(ws),s=(o=r==null?void 0:r.alert)==null?void 0:o.location;if(s&&s.row===n.location.row&&s.col===n.location.col&&s.subUnitId===n.location.subUnitId&&s.unitId===n.location.unitId)return;this._cellAlertManagerService.showAlert({type:Vn.ERROR,title:this._localeService.t("info.error"),message:this._localeService.t("info.forceStringInfo"),location:n.location,width:200,height:74,key:ws});return}}this._hideAlert()}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(n=>{n&&this._hideAlert()}))}_hideAlert(){this._cellAlertManagerService.removeAlert(ws)}};Mo=df([yo(1,a.Inject(y.HoverManagerService)),yo(2,a.Inject(y.CellAlertManagerService)),yo(3,a.Inject(a.LocaleService)),yo(4,I.IZenZoneService)],Mo);var uf=Object.getOwnPropertyDescriptor,hf=(n,o,e,t)=>{for(var i=t>1?void 0:t?uf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},jc=(n,o)=>(e,t)=>o(e,t,n);let Ro=class extends a.RxDisposable{constructor(n,o,e){super(),this._context=n,this._sheetSkeletonManagerService=o,this._sheetInterceptorService=e,this._initViewModelIntercept()}_initViewModelIntercept(){const n={tl:{size:6,color:"#409f11"}};this.disposeWithMe(this._sheetInterceptorService.intercept(m.INTERCEPTOR_POINT.CELL_CONTENT,{priority:10,effect:a.InterceptorEffectEnum.Style,handler:(o,e,t)=>{var s,l;if(!((s=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:s.skeleton))return t(o);const r=e.worksheet.getCellRaw(e.row,e.col);if(!r||r.v===null||r.v===void 0)return t(o);if(((o==null?void 0:o.t)===a.CellValueType.FORCE_STRING||(o==null?void 0:o.t)===a.CellValueType.STRING)&&a.isRealNum(r.v)){const c=e.workbook.getStyles().get(r.s);return Fi.isTextFormat((l=c==null?void 0:c.n)==null?void 0:l.pattern)?t(o):t({...o,markers:{...o==null?void 0:o.markers,...n}})}return t(o)}}))}};Ro=hf([jc(1,a.Inject(y.SheetSkeletonManagerService)),jc(2,a.Inject(m.SheetInterceptorService))],Ro);var mf=Object.getOwnPropertyDescriptor,Sf=(n,o,e,t)=>{for(var i=t>1?void 0:t?mf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ts=(n,o)=>(e,t)=>o(e,t,n);y.HoverRenderController=class extends a.Disposable{constructor(e,t,i,r){super();T(this,"_active",!1);this._context=e,this._hoverManagerService=t,this._sheetSkeletonManagerService=i,this._scrollManagerService=r,this._initPointerEvent(),this._initScrollEvent()}get active(){return this._active}_initPointerEvent(){const e=new a.DisposableCollection,t=i=>{if(e.dispose(),!i)return;const{mainComponent:r,unitId:s,components:l}=this._context;if(!r)return;e.add(r.onPointerEnter$.subscribeEvent(u=>{this._active=!0})),e.add(a.fromEventSubject(r.onPointerMove$).subscribe(u=>{this._active=!0,this._hoverManagerService.triggerMouseMove(s,u)})),e.add(r.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerDown(s,u)})),e.add(r.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerUp(s,u)})),e.add(r.onClick$.subscribeEvent(u=>{this._hoverManagerService.triggerClick(s,u.offsetX,u.offsetY)})),e.add(r.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerDbClick(s,u.offsetX,u.offsetY)})),e.add(r.onPointerLeave$.subscribeEvent(()=>{this._active=!1}));const c=l.get(ue.ROW),d=l.get(ue.COLUMN);c&&(e.add(c.onPointerMove$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderMouseMove(s,u.offsetX,u.offsetY)})),e.add(c.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderPoniterDown(s,u.offsetX,u.offsetY)})),e.add(c.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderPoniterUp(s,u.offsetX,u.offsetY),this._hoverManagerService.triggerRowHeaderClick(s,u.offsetX,u.offsetY)})),e.add(c.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerRowHeaderDbClick(s,u.offsetX,u.offsetY)}))),d&&(e.add(d.onPointerMove$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderMouseMove(s,u.offsetX,u.offsetY)})),e.add(d.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderPoniterDown(s,u.offsetX,u.offsetY)})),e.add(d.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderPoniterUp(s,u.offsetX,u.offsetY),this._hoverManagerService.triggerColHeaderClick(s,u.offsetX,u.offsetY)})),e.add(d.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerColHeaderDbClick(s,u.offsetX,u.offsetY)})))};t(this._sheetSkeletonManagerService.getCurrentParam()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(i=>{t(i)}))}_initScrollEvent(){this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(()=>this._hoverManagerService.triggerScroll()))}},y.HoverRenderController=Sf([Ts(1,a.Inject(y.HoverManagerService)),Ts(2,a.Inject(y.SheetSkeletonManagerService)),Ts(3,a.Inject(y.SheetScrollManagerService))],y.HoverRenderController);var gf=Object.getOwnPropertyDescriptor,ff=(n,o,e,t)=>{for(var i=t>1?void 0:t?gf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ys=(n,o)=>(e,t)=>o(e,t,n);let Po=class extends a.Disposable{constructor(n,o,e,t){super(),this._context=n,this._markSelectionService=o,this._commandService=e,this._sheetSkeletonManagerService=t,this._initListeners()}_initListeners(){this._addRemoveListener(),this._addRefreshListener()}_addRemoveListener(){const n=[ge.id];this.disposeWithMe(this._commandService.onCommandExecuted(o=>{n.includes(o.id)?this._markSelectionService.removeAllShapes():this._markSelectionService.getShapeMap().forEach((t,i)=>{t.exits.includes(o.id)&&this._markSelectionService.removeShape(i)})}))}_addRefreshListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(n=>{n&&this._markSelectionService.refreshShapes()}))}};Po=ff([ys(1,a.Inject(Ut)),ys(2,a.ICommandService),ys(3,a.Inject(y.SheetSkeletonManagerService))],Po);const Oo={mobileSheetBarContainer:"univer-mobile-sheet-bar-container",mobileSheetBarSlider:"univer-mobile-sheet-bar-slider",mobileSheetBarItem:"univer-mobile-sheet-bar-item",mobileSheetBarItemActivated:"univer-mobile-sheet-bar-item-activated"};function Gc(){const n=ft();return n?_.jsx(pf,{workbook:n}):null}function pf(n){const{workbook:o}=n,[e,t]=L.useState([]),[i,r]=L.useState(""),s=L.useRef(new Map),l=I.useDependency(a.ICommandService),c=L.useCallback(()=>{const u=o.getActiveSheet().getSheetId(),h=o.getSheets(),S=o.getActiveSheet(),g=h.filter(f=>!f.isSheetHidden()).map((f,p)=>{var v;return{sheetId:f.getSheetId(),label:f.getName(),index:p,selected:S===f,color:(v=f.getTabColor())!=null?v:void 0}});if(t(g),r(u),s.current.has(u)){const f=s.current.get(u);f&&f.scrollIntoView({behavior:"smooth",block:"nearest"})}s.current.clear()},[o]);L.useEffect(()=>c(),[c]);const d=L.useCallback(u=>{l.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:o.getUnitId(),subUnitId:u})},[l,o]);return L.useEffect(()=>{const u=l.onCommandExecuted(h=>{switch(h.id){case m.SetWorksheetHideMutation.id:case m.RemoveSheetMutation.id:case m.SetWorksheetNameMutation.id:case m.InsertSheetMutation.id:case m.SetWorksheetOrderMutation.id:case m.SetWorksheetActiveOperation.id:c();break}});return()=>u.dispose()},[l,c]),_.jsx("div",{className:Oo.mobileSheetBarContainer,children:_.jsx("div",{className:Oo.mobileSheetBarSlider,children:e.map(u=>_.jsx("div",{className:j.clsx(Oo.mobileSheetBarItem,{[Oo.mobileSheetBarItemActivated]:u.sheetId===i}),onClick:()=>d(u.sheetId),ref:h=>{s.current.set(u.sheetId,h)},children:u.label},u.sheetId))})})}const vf={[I.ContextMenuPosition.MAIN_AREA]:{[I.ContextMenuGroup.FORMAT]:{[je.name]:{order:0,menuItemFactory:Pn}},[I.ContextMenuGroup.DATA]:{order:2},[I.ContextMenuGroup.OTHERS]:{order:3}},[I.ContextMenuPosition.COL_HEADER]:{[I.ContextMenuGroup.FORMAT]:{[je.name]:{order:0,menuItemFactory:Pn}},[I.ContextMenuGroup.LAYOUT]:{order:1},[I.ContextMenuGroup.DATA]:{order:2},[I.ContextMenuGroup.OTHERS]:{order:3}},[I.ContextMenuPosition.ROW_HEADER]:{[I.ContextMenuGroup.FORMAT]:{[je.name]:{order:0,menuItemFactory:Pn}},[I.ContextMenuGroup.LAYOUT]:{order:1},[I.ContextMenuGroup.DATA]:{order:2},[I.ContextMenuGroup.OTHERS]:{order:3}}};var Cf=Object.getOwnPropertyDescriptor,If=(n,o,e,t)=>{for(var i=t>1?void 0:t?Cf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},tn=(n,o)=>(e,t)=>o(e,t,n);let Ao=class extends a.Disposable{constructor(n,o,e,t,i,r,s){super(),this._injector=n,this._componentManager=o,this._layoutService=e,this._commandService=t,this._shortcutService=i,this._menuManagerService=r,this._uiPartsService=s,this._init()}_init(){this._initCustomComponents(),this._initCommands(),this._initMenus(),this._initShortcuts(),this._initWorkbenchParts(),this._initFocusHandler()}_initCustomComponents(){const n=this._componentManager;this.disposeWithMe(n.register(Je,ml)),this.disposeWithMe(n.register(cs,zl)),this.disposeWithMe(n.register(fi,j.ColorPicker)),this.disposeWithMe(n.register(So,I.FontFamily)),this.disposeWithMe(n.register(go,I.FontFamilyItem)),this.disposeWithMe(n.register(fo,I.FontSize)),this.disposeWithMe(n.register(ni,Yl))}_initCommands(){[rs,bt,as,ss,dn,ke,Ae,qe,Di,Ri,Nn,Hn,ai,li,Ye,pr,$n,so,m.SetBoldCommand,Nt,ge,Zn,xt,Ft,zt,Xt,Lr,Ur,ci,di,En,m.SetItalicCommand,m.SetStrikeThroughCommand,m.SetFontFamilyCommand,m.SetFontSizeCommand,ui,mo,Tn,hi,Xe,mn,ot,mi,Si,m.SetUnderlineCommand,un,We,Pi,Gn,Zt,Gt,An,On,no,Ct,cn,et,ls,Ti,Kt,qt,yi,Mi,Ai,Qt,Jt,Oi].forEach(n=>{this.disposeWithMe(this._commandService.registerCommand(n))})}_initMenus(){this._menuManagerService.mergeMenu(vf)}_initShortcuts(){[tc,nc,ic,oc,rc,sc,ac,lc,cc,dc,uc,hc,mc,Sc,gc,fc,pc,vc,Cc,Ic,_c,Mc,Pc,Ac,Dc,Rc,Oc,bc,Ec,wc,Tc,yc,...Ba(),Fa,xa,za,Ya,ja,Ga,Xa,$l,ec].forEach(n=>{this.disposeWithMe(this._shortcutService.registerShortcut(n))})}_initWorkbenchParts(){this._uiPartsService.registerComponent(I.BuiltInUIPart.HEADER,()=>I.connectInjector(Gc,this._injector))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(a.UniverInstanceType.UNIVER_SHEET,n=>{}))}};Ao=If([tn(0,a.Inject(a.Injector)),tn(1,a.Inject(I.ComponentManager)),tn(2,I.ILayoutService),tn(3,a.ICommandService),tn(4,I.IShortcutService),tn(5,I.IMenuManagerService),tn(6,I.IUIPartsService)],Ao);const Ms="UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID",Zc="UNIVER_SHEET_PERMISSION_ALERT_DIALOG";var _f=Object.getOwnPropertyDescriptor,bf=(n,o,e,t)=>{for(var i=t>1?void 0:t?_f(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},at=(n,o)=>(e,t)=>o(e,t,n);y.SheetPermissionCheckUIController=class extends a.Disposable{constructor(e,t,i,r,s,l,c,d,u){super();T(this,"disposableCollection",new a.DisposableCollection);this._commandService=e,this._univerInstanceService=t,this._permissionService=i,this._dialogService=r,this._rangeProtectionRuleModel=s,this._autoFillService=l,this._localeService=c,this._contextService=d,this._sheetPermissionCheckController=u,this._initialize(),this._initUIEvent()}_initUIEvent(){this.disposeWithMe(this._sheetPermissionCheckController.triggerPermissionUIEvent$.subscribe(e=>{this._haveNotPermissionHandle(e)}))}_haveNotPermissionHandle(e){const t={id:Ms,title:{title:"permission.dialog.alert"},children:{label:Zc,errorMsg:e},width:320,destroyOnClose:!0,showOk:!0,onClose:()=>{this._dialogService.close(Ms)},onOk:()=>{this._dialogService.close(Ms)},className:"sheet-permission-user-dialog"};this._permissionService.getShowComponents()&&this._dialogService.open(t)}_getPermissionCheck(e,t){var s,l;let i=!0,r="";switch(e){case Q.InsertCommand.id:case Q.IMEInputCommand.id:if(this._contextService.getContextValue(a.FOCUSING_EDITOR_STANDALONE)===!0)break;i=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.editErr");break;case ge.id:if(t.visible===!1)break;i=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.editErr");break;case Bt.id:i=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetColumnStylePermission]}),r=this._localeService.t("permission.dialog.pasteErr");break;case uo.id:i=this._permissionCheckByPaste(t),r=this._localeService.t("permission.dialog.pasteErr");break;case hi.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetCellValuePermission,m.WorksheetSetCellStylePermission]}),r=this._localeService.t("permission.dialog.commonErr");break;case m.SetBackgroundColorCommand.id:case xt.id:case Ft.id:case zt.id:case Xt.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.setStyleErr");break;case je.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission],rangeTypes:[m.RangeProtectionPermissionViewPoint],worksheetTypes:[m.WorksheetCopyPermission]}),r=this._localeService.t("permission.dialog.copyErr"),(s=this._permissionService.getPermissionPoint(new m.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&s.value||(r=this._localeService.t("permission.dialog.workbookCopyErr"));break;case co.id:i=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission,m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionViewPoint,m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetCopyPermission,m.WorksheetEditPermission]}),r=this._localeService.t("permission.dialog.copyErr"),(l=this._permissionService.getPermissionPoint(new m.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&l.value||(r=this._localeService.t("permission.dialog.workbookCopyErr"));break;case Ct.id:i=this._permissionCheckByAutoFillCommand(t),r=this._localeService.t("permission.dialog.autoFillErr");break}i||this._sheetPermissionCheckController.blockExecuteWithoutPermission(r)}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(e=>{this._getPermissionCheck(e.id,e==null?void 0:e.params)}))}_permissionCheckByPaste(e){return e.value===fe.SPECIAL_PASTE_VALUE||e.value===fe.SPECIAL_PASTE_FORMULA?this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}):e.value===fe.SPECIAL_PASTE_FORMAT?this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}):this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]})}_permissionCheckByAutoFillCommand(e){if(!e)return!1;const{targetRange:t}=e,i=m.getSheetCommandTarget(this._univerInstanceService);if(!i)return!1;const{worksheet:r,unitId:s,subUnitId:l}=i;return!this._rangeProtectionRuleModel.getSubunitRuleList(s,l).reduce((u,h)=>[...u,...h.ranges],[]).filter(u=>a.Rectangle.intersects(u,t)).some(u=>{var h,S;for(let g=u.startRow;g<=u.endRow;g++)for(let f=u.startColumn;f<=u.endColumn;f++){const p=(S=(h=r.getCell(g,f))==null?void 0:h.selectionProtection)==null?void 0:S[0];if((p==null?void 0:p[ie.Edit])===!1)return!0}return!1})}},y.SheetPermissionCheckUIController=bf([at(0,a.ICommandService),at(1,a.IUniverInstanceService),at(2,a.IPermissionService),at(3,I.IDialogService),at(4,a.Inject(m.RangeProtectionRuleModel)),at(5,vt),at(6,a.Inject(a.LocaleService)),at(7,a.IContextService),at(8,a.Inject(m.SheetPermissionCheckController))],y.SheetPermissionCheckUIController);var Ef=Object.getOwnPropertyDescriptor,wf=(n,o,e,t)=>{for(var i=t>1?void 0:t?Ef(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},lt=(n,o)=>(e,t)=>o(e,t,n);let Do=class extends a.RxDisposable{constructor(o,e,t,i,r,s,l,c,d,u){super();T(this,"disposableCollection",new a.DisposableCollection);this._context=o,this._univerInstanceService=e,this._permissionService=t,this._selectionManagerService=i,this._rangeProtectionRuleModel=r,this._headerMoveRenderController=s,this._selectionRenderService=l,this._headerFreezeRenderController=c,this._rangeProtectionCache=d,this._headerResizeRenderController=u,this._initHeaderMovePermissionInterceptor(),this._initHeaderResizePermissionInterceptor(),this._initRangeFillPermissionInterceptor(),this._initRangeMovePermissionInterceptor()}_initHeaderMovePermissionInterceptor(){const o=this._headerMoveRenderController.interceptor.getInterceptPoints().HEADER_MOVE_PERMISSION_CHECK;this.disposeWithMe(this._headerMoveRenderController.interceptor.intercept(o,{handler:(e,t)=>{const i=m.getSheetCommandTarget(this._univerInstanceService);if(!i)return!1;const{unitId:r,subUnitId:s}=i;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(r).id,new m.WorksheetEditPermission(r,s).id]).every(c=>c.value))return!1;if(!t)return!0;if(t.rangeType!==a.RANGE_TYPE.ROW&&t.rangeType!==a.RANGE_TYPE.COLUMN)return e;if(t.rangeType===a.RANGE_TYPE.ROW){for(let c=t.startRow;c<=t.endRow;c++)if(this._rangeProtectionCache.getRowPermissionInfo(r,s,c,[ie.Edit])===!1)return!1}else for(let c=t.startColumn;c<=t.endColumn;c++)if(this._rangeProtectionCache.getColPermissionInfo(r,s,c,[ie.Edit])===!1)return!1;return!0}}))}_initHeaderResizePermissionInterceptor(){this._headerResizeRenderController&&this.disposeWithMe(this._headerResizeRenderController.interceptor.intercept(this._headerResizeRenderController.interceptor.getInterceptPoints().HEADER_RESIZE_PERMISSION_CHECK,{handler:(o,e)=>{var s,l,c,d;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{unitId:i,subUnitId:r}=t;if(e.row){if(((l=(s=this._permissionService.getPermissionPoint(new m.WorksheetSetRowStylePermission(i,r).id))==null?void 0:s.value)!=null?l:!1)===!1)return!1}else if(e.col&&((d=(c=this._permissionService.getPermissionPoint(new m.WorksheetSetColumnStylePermission(i,r).id))==null?void 0:c.value)!=null?d:!1)===!1)return!1;return!0}}))}_initRangeFillPermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_FILL_PERMISSION_CHECK,{handler:(o,e)=>{var f,p,v;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:i,unitId:r,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(r).id,new m.WorksheetEditPermission(r,s).id,new m.WorksheetSetCellValuePermission(r,s).id,new m.WorksheetSetCellStylePermission(r,s).id]).every(C=>C.value))return!1;const c=(f=this._selectionManagerService.getCurrentSelections())==null?void 0:f.map(C=>C.range),d=c==null?void 0:c.find(C=>{const b=Kn(e.x,e.y,e.scene,e.skeleton),E=e.skeleton.getCellWithCoordByIndex(C.endRow,C.endColumn),w=Math.abs(E.endX-b.x),O=Math.abs(E.endY-b.y);return w<=5&&O<=5});if(!d)return!0;const{startRow:u,endRow:h,startColumn:S,endColumn:g}=d;for(let C=u;C<=h;C++)for(let b=S;b<=g;b++){const E=(v=(p=i.getCell(C,b))==null?void 0:p.selectionProtection)==null?void 0:v[0];if((E==null?void 0:E[ie.Edit])===!1||(E==null?void 0:E[ie.View])===!1)return!1}return!0}}))}_initRangeMovePermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_MOVE_PERMISSION_CHECK,{handler:(o,e)=>{var S;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:i,unitId:r,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(r).id,new m.WorksheetEditPermission(r,s).id]).every(g=>g.value))return!1;const c=(S=this._selectionManagerService.getCurrentSelections())==null?void 0:S.map(g=>g.range),d=this._rangeProtectionRuleModel.getSubunitRuleList(r,s).reduce((g,f)=>[...g,...f.ranges],[]),u=c==null?void 0:c.filter(g=>d.some(f=>a.Rectangle.intersects(f,g)));return!(u==null?void 0:u.some(g=>{var b,E;const{startRow:f,startColumn:p,endRow:v,endColumn:C}=g;for(let w=f;w<=v;w++)for(let O=p;O<=C;O++){const R=(E=(b=i.getCell(w,O))==null?void 0:b.selectionProtection)==null?void 0:E[0];if((R==null?void 0:R[ie.Edit])===!1)return!0}return!1}))}}))}_initFreezePermissionInterceptor(){this.disposeWithMe(this._headerFreezeRenderController.interceptor.intercept(this._headerFreezeRenderController.interceptor.getInterceptPoints().FREEZE_PERMISSION_CHECK,{handler:(o,e)=>{var s,l;const t=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);return!(t==null?void 0:t.getActiveSheet())||!t?!1:(l=(s=this._permissionService.getPermissionPoint(new m.WorkbookEditablePermission(t.getUnitId()).id))==null?void 0:s.value)!=null?l:!1}}))}};Do=wf([lt(1,a.IUniverInstanceService),lt(2,a.IPermissionService),lt(3,a.Inject(m.SheetsSelectionsService)),lt(4,a.Inject(m.RangeProtectionRuleModel)),lt(5,a.Inject(y.HeaderMoveRenderController)),lt(6,ve),lt(7,a.Inject(y.HeaderFreezeRenderController)),lt(8,a.Inject(m.RangeProtectionCache)),lt(9,a.Optional(y.HeaderResizeRenderController))],Do);var Tf=Object.getOwnPropertyDescriptor,yf=(n,o,e,t)=>{for(var i=t>1?void 0:t?Tf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ni=(n,o)=>(e,t)=>o(e,t,n);const Mf="SHEET_PERMISSION_PASTE_PLUGIN";let Hi=class extends a.Disposable{constructor(o,e,t,i,r){super();T(this,"disposableCollection",new a.DisposableCollection);this._univerInstanceService=o,this._selectionManagerService=e,this._localService=t,this._sheetClipboardService=i,this._sheetPermissionCheckController=r,this._initClipboardHook()}_initClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook({id:Mf,onBeforePaste:o=>{var S,g,f;const[e]=Ot([o.range]).ranges,t=(S=this._selectionManagerService.getCurrentLastSelection())==null?void 0:S.range;if(!t)return!1;const i={startRow:t.startRow+e.startRow,endRow:t.startRow+e.endRow,startColumn:t.startColumn+e.startColumn,endColumn:t.startColumn+e.endColumn},s=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!s)return!1;const{startRow:l,endRow:c,startColumn:d,endColumn:u}=i;let h=!0;for(let p=l;p<=c;p++)for(let v=d;v<=u;v++){const C=(f=(g=s.getCell(p,v))==null?void 0:g.selectionProtection)==null?void 0:f[0];if((C==null?void 0:C[ie.Edit])===!1){h=!1;break}}return h||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localService.t("permission.dialog.pasteErr")),h}}))}};Hi=yf([Ni(0,a.IUniverInstanceService),Ni(1,a.Inject(m.SheetsSelectionsService)),Ni(2,a.Inject(a.LocaleService)),Ni(3,a.Inject(Be)),Ni(4,a.Inject(m.SheetPermissionCheckController))],Hi);var Rf=Object.getOwnPropertyDescriptor,Pf=(n,o,e,t)=>{for(var i=t>1?void 0:t?Rf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Vi=(n,o)=>(e,t)=>o(e,t,n);const Of=a.createInterceptorKey("statusBarPermissionCorrect");class Af{constructor(){T(this,"_sum",0);T(this,"_count",0);T(this,"_countNumber",0);T(this,"_min",Number.POSITIVE_INFINITY);T(this,"_max",Number.NEGATIVE_INFINITY)}add(o,e,t){if(!(o!=null&&o.v))return;const i=o==null?void 0:o.t;let{v:r}=o;const s=c=>{this._sum+=c,this._countNumber++,this._min=Math.min(this._min,c),this._max=Math.max(this._max,c)},l=(c,d,u)=>{var g;if(!((g=c==null?void 0:c.n)!=null&&g.pattern))return;const{pattern:h}=c.n;u[h]||(u[h]=a.numfmt.getInfo(h)),u[h].isDate&&s(d)};if(typeof r=="string"&&i===a.CellValueType.NUMBER){const c=Number(r);Number.isNaN(c)||(r=c)}if(typeof r=="number"&&i!==a.CellValueType.STRING)s(r);else if(i===a.CellValueType.NUMBER&&o.s){const c=e.get(o.s);l(c,r,t)}this._count++}getResults(){return{sum:this._sum,count:this._countNumber,countA:this._count,min:this._min,max:this._max}}}function Df(n){const{sum:o,count:e,countA:t,min:i,max:r}=n.getResults();return[{func:q.FUNCTION_NAMES_STATISTICAL.MAX,value:r},{func:q.FUNCTION_NAMES_STATISTICAL.MIN,value:i},{func:q.FUNCTION_NAMES_MATH.SUM,value:o},{func:q.FUNCTION_NAMES_STATISTICAL.COUNTA,value:t},{func:q.FUNCTION_NAMES_STATISTICAL.COUNT,value:e},{func:q.FUNCTION_NAMES_STATISTICAL.AVERAGE,value:o/e}]}y.StatusBarController=class extends a.Disposable{constructor(e,t,i,r,s){super();T(this,"interceptor",new a.InterceptorManager({STATUS_BAR_PERMISSION_CORRECT:Of}));this._univerInstanceService=e,this._selectionManagerService=t,this._statusBarService=i,this._commandService=r,this._numfmtService=s,this._init()}_init(){this._registerSelectionListener()}_registerSelectionListener(){const e=a.debounce(i=>{var s;const r=(s=i[i.length-1])==null?void 0:s.primary;this._calculateSelection(i.map(l=>l.range),r)},100),t=a.debounce(i=>{var s;const r=(s=i[i.length-1])==null?void 0:s.primary;this._calculateSelection(i.map(l=>l.range),r)},500);this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoving$.subscribe(i=>{i&&t(i)}))),this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoveEnd$.subscribe(i=>{i&&e(i)}))),this.disposeWithMe(this._commandService.onCommandExecuted(i=>{if(i.id===m.SetRangeValuesMutation.id){const r=this._selectionManagerService.getCurrentSelections();r&&e(r)}}))}_clearResult(){this._statusBarService.setState(null)}getRangeStartEndInfo(e,t){return e.rangeType===a.RANGE_TYPE.ALL?{startRow:0,startColumn:0,endRow:t.getRowCount()-1,endColumn:t.getColumnCount()-1}:e.rangeType===a.RANGE_TYPE.COLUMN?{startRow:0,startColumn:e.startColumn,endRow:t.getRowCount()-1,endColumn:e.endColumn}:e.rangeType===a.RANGE_TYPE.ROW?{startRow:e.startRow,startColumn:0,endRow:e.endRow,endColumn:t.getColumnCount()-1}:{startRow:e.startRow,startColumn:e.startColumn,endRow:e.endRow,endColumn:e.endColumn}}_calculateSelection(e,t){var d;const i=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!i)return this._clearResult();const r=i.getUnitId(),s=i.getActiveSheet(),l=s==null?void 0:s.getSheetId();if(!l)return this._clearResult();const c={};if(this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getSheets().forEach(u=>{const h=u.getConfig();c[u.getSheetId()]={cellData:new a.ObjectMatrix(h.cellData),rowCount:h.rowCount,columnCount:h.columnCount,rowData:h.rowData,columnData:h.columnData}}),e!=null&&e.length){const u=[];e.forEach(E=>{const{startRow:w,endRow:O}=E;let R=null;for(let P=w;P<=O;P++)s.getRowVisible(P)?R===null&&(R=P):R!==null&&(u.push({...E,startRow:R,endRow:P-1}),R=null);R!==null&&u.push({...E,startRow:R,endRow:O})});const h=a.splitIntoGrid(u),S=new Af,g=i.getStyles(),f={};for(const E of h){const{startRow:w,startColumn:O,endColumn:R,endRow:P}=this.getRangeStartEndInfo(E,s);for(let A=w;A<=P;A++)for(let k=O;k<=R;k++){const N=s.getCellRaw(A,k);S.add(N,g,f)}}const p=Df(S);if(p.every(E=>E===void 0))return;let v=null;if(t){const{actualRow:E,actualColumn:w}=t;v=(d=this._numfmtService.getValue(r,l,E,w))==null?void 0:d.pattern}const b={values:p.filter(E=>E!==void 0),pattern:v};this._statusBarService.setState(b)}else this._clearResult()}},y.StatusBarController=Pf([Vi(0,a.IUniverInstanceService),Vi(1,a.Inject(m.SheetsSelectionsService)),Vi(2,ii),Vi(3,a.ICommandService),Vi(4,a.Inject(m.INumfmtService))],y.StatusBarController);var kf=Object.getOwnPropertyDescriptor,Nf=(n,o,e,t)=>{for(var i=t>1?void 0:t?kf(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ko=(n,o)=>(e,t)=>o(e,t,n);let No=class extends a.RxDisposable{constructor(o,e,t,i,r){super();T(this,"disposableCollection",new a.DisposableCollection);this._context=o,this._univerInstanceService=e,this._permissionService=t,this._statusBarController=i,this._rangeProtectionCache=r,this._initStatusBarPermissionInterceptor()}_initStatusBarPermissionInterceptor(){this.disposeWithMe(this._statusBarController.interceptor.intercept(this._statusBarController.interceptor.getInterceptPoints().STATUS_BAR_PERMISSION_CORRECT,{priority:100,handler:(o,e)=>{var c;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return o!=null?o:[];const{worksheet:i,unitId:r,subUnitId:s}=t;return((c=this._permissionService.getPermissionPoint(new m.WorksheetViewPermission(r,s).id))==null?void 0:c.value)===!1?e.forEach(d=>{const u=d.getArrayValue();u.forEach((h,S)=>{h.forEach((g,f)=>{u[S][f]=q.NullValueObject.create()})})}):e.forEach(d=>{const u=d.getArrayValue(),h=d.getCurrentRow(),S=d.getCurrentColumn();u.forEach((g,f)=>{g.forEach((p,v)=>{var E;if(((E=i.getCellRaw(f+h,v+S))==null?void 0:E.v)===void 0)return;const b=this._rangeProtectionCache.getCellInfo(r,s,f+h,v+S);(b==null?void 0:b[ie.View])===!1&&(u[f][v]=q.NullValueObject.create())})})}),e}}))}};No=Nf([ko(1,a.IUniverInstanceService),ko(2,a.IPermissionService),ko(3,a.Inject(y.StatusBarController)),ko(4,a.Inject(m.RangeProtectionCache))],No);const Kc=(n,o,e,t,i)=>{const r=n.get(a.LocaleService),s=n.get(m.WorksheetProtectionRuleModel),l=n.get(m.RangeProtectionRuleModel);let c="";if(o.length===0)c=r.t("permission.panel.emptyRangeError");else if(o.length>1){let d=!1;for(let u=0;u<o.length;u++){for(let h=u+1;h<o.length;h++)if(a.Rectangle.intersects(o[u],o[h])){d=!0;break}if(d)break}d&&(c=r.t("permission.panel.rangeOverlapError"))}if(!c){if(s.getRule(t,i)&&!e)return c=r.t("permission.panel.rangeOverlapOverPermissionError"),c;const u=l.getSubunitRuleList(t,i).filter(S=>S.permissionId!==e).find(S=>S.ranges.some(g=>o.some(f=>a.Rectangle.intersects(g,f))));(u==null?void 0:u.ranges.find(S=>o.some(g=>a.Rectangle.intersects(S,g))))&&(c=r.t("permission.panel.rangeOverlapOverPermissionError"))}return c===""?void 0:c},Hf=(n,o)=>{if(n.length!==1)return!1;const e=n[0],t=o.getRowCount(),i=o.getColumnCount(),{startRow:r,endRow:s,startColumn:l,endColumn:c}=e;return r===0&&l===0&&s===t-1&&c===i-1},Vf=(n,o)=>{var c,d;const e=n.get(a.IUniverInstanceService),t=n.get(m.SheetsSelectionsService),i=e.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),r=i.getActiveSheet();let s=m.UnitObject.SelectRange,l=(d=(c=t.getCurrentSelections())==null?void 0:c.map(u=>u.range))!=null?d:[];return o&&(s=m.UnitObject.Worksheet,l=[{startRow:0,startColumn:0,endRow:r.getRowCount()-1,endColumn:r.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]),{unitId:i.getUnitId(),subUnitId:r.getSheetId(),permissionId:"",unitType:s,description:"",id:"",ranges:l,editState:m.EditStateEnum.OnlyMe,viewState:m.ViewStateEnum.OthersCanView}},Wf=(n,o)=>{const i=n.get(a.IUniverInstanceService).getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getActiveSheet(),{unitType:r}=o;return r===m.UnitObject.Worksheet?{...o,ranges:[{startRow:0,startColumn:0,endRow:i.getRowCount()-1,endColumn:i.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]}:o},Ce={permissionPanelDetailWrapper:"univer-permission-panel-detail-wrapper",radioGroupVertical:"univer-radio-group-vertical",sheetPermissionDesignPersonPanel:"univer-sheet-permission-design-person-panel",sheetPermissionDesignPersonPanelHeader:"univer-sheet-permission-design-person-panel-header",sheetPermissionDesignPersonPanelHeaderAdd:"univer-sheet-permission-design-person-panel-header-add",sheetPermissionDesignPersonPanelSplit:"univer-sheet-permission-design-person-panel-split",sheetPermissionDesignPersonPanelContentItem:"univer-sheet-permission-design-person-panel-content-item",sheetPermissionDesignPersonPanelContentItemName:"univer-sheet-permission-design-person-panel-content-item-name",sheetPermissionDesignPersonPanelContentItemSelect:"univer-sheet-permission-design-person-panel-content-item-select",sheetPermissionDesignPersonPanelContent:"univer-sheet-permission-design-person-panel-content",sheetPermissionUserListEmpty:"univer-sheet-permission-user-list-empty",sheetPermissionUserListEmptyText:"univer-sheet-permission-user-list-empty-text",sheetPermissionPanelTitle:"univer-sheet-permission-panel-title",sheetPermissionPanelFooter:"univer-sheet-permission-panel-footer"},Lf=n=>{const{viewState:o,editState:e,permissionId:t,ranges:i,rangesErrMsg:r,desc:s,oldRule:l,id:c}=n,d=I.useDependency(kn),u=I.useDependency(I.ISidebarService),h=I.useDependency(a.IAuthzIoService),S=I.useDependency(a.LocaleService),g=I.useDependency(a.ICommandService),f=I.useDependency(Et),v=I.useDependency(a.IUniverInstanceService).getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),C=v==null?void 0:v.getActiveSheet();if(!v||!C)return null;const b=v.getUnitId(),E=C.getSheetId();return _.jsxs("div",{className:Ce.sheetPermissionPanelFooter,children:[_.jsx(j.Button,{variant:"primary",onClick:async()=>{if(r)return;const w={unitId:b,subUnitId:E,permissionId:t,id:c,viewState:o,editState:e,unitType:m.UnitObject.SelectRange,ranges:i,description:s};Hf(i,C)&&(w.unitType=m.UnitObject.Worksheet,w.ranges=[]);let R=f.selectUserList;w.editState===m.EditStateEnum.OnlyMe&&(R=[],f.setSelectUserList([]));const P={read:w.viewState===m.ViewStateEnum.OthersCanView?$e.AllCollaborator:$e.SomeCollaborator,edit:w.editState===m.EditStateEnum.DesignedUserCanEdit?$e.SomeCollaborator:$e.OneSelf};if(w.editState===m.EditStateEnum.DesignedUserCanEdit&&R.length===0&&(R=[],P.edit=$e.OneSelf),w.permissionId){const k=bS(R.filter(W=>W.role===He.Editor),f.oldCollaboratorList.filter(W=>W.role===He.Editor)),N=(l==null?void 0:l.viewState)===w.viewState,H=(l==null?void 0:l.editState)===w.editState,V=w.unitType===(l==null?void 0:l.unitType)&&w.description===l.description&&w.ranges===l.ranges,U=!k||!N||!H;if(V&&U)await h.update({objectType:w.unitType,objectID:w.permissionId,unitID:w.unitId,share:void 0,name:"",strategies:[],scope:P,collaborators:{collaborators:R}});else{let W=w.permissionId;U&&(w.unitType===m.UnitObject.Worksheet?W=await h.create({worksheetObject:{collaborators:R,unitID:w.unitId,name:"",strategies:[{role:He.Editor,action:ie.Edit},{role:He.Reader,action:ie.View}],scope:P},objectType:m.UnitObject.Worksheet}):W=await h.create({selectRangeObject:{collaborators:R,unitID:w.unitId,name:"",scope:P},objectType:m.UnitObject.SelectRange})),g.executeCommand(m.SetProtectionCommand.id,{rule:{...w,permissionId:W},oldRule:l})}}else if(w.unitType===m.UnitObject.Worksheet){const k=await h.create({worksheetObject:{collaborators:R,unitID:w.unitId,name:"",strategies:[{role:He.Editor,action:ie.Edit},{role:He.Reader,action:ie.View}],scope:P},objectType:m.UnitObject.Worksheet}),{ranges:N=[],...H}=w;H.permissionId=k,g.executeCommand(m.AddWorksheetProtectionCommand.id,{rule:H,unitId:w.unitId})}else if(w.unitType===m.UnitObject.SelectRange){const k=await h.create({selectRangeObject:{collaborators:R,unitID:w.unitId,name:"",scope:P},objectType:m.UnitObject.SelectRange});g.executeCommand(m.AddRangeProtectionCommand.id,{rule:w,permissionId:k})}const A={header:{title:`${S.t("permission.panel.title")}`},children:{label:wi,showDetail:!1},width:330};u.open(A)},children:S.t("permission.button.confirm")}),_.jsx(j.Button,{className:Ce.sheetPermissionPanelFooterCancel,onClick:()=>{d.reset(),f.reset(),u.close()},children:S.t("permission.button.cancel")})]})},Uf=n=>{const{ranges:o,onRangesChange:e,desc:t,onDescChange:i,rangesErrMsg:r,permissionId:s}=n,l=I.useDependency(I.ComponentManager),c=L.useMemo(()=>l.get(Jo),[]),d=I.useDependency(a.IUniverInstanceService),u=I.useDependency(a.LocaleService),h=I.useDependency(a.Injector),S=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),g=S==null?void 0:S.getActiveSheet();if(!S||!g)return null;const f=S.getUnitId(),p=g.getSheetId(),v=C=>{const b=C.split(",").map(q.deserializeRangeWithSheet).map(k=>k.range);if(b.some(k=>!a.isValidRange(k)||k.endColumn<k.startColumn||k.endRow<k.startRow))return;const E=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),w=E==null?void 0:E.getActiveSheet();if(!E||!w)return;const O=E.getUnitId(),R=w.getSheetId(),P=b.map(k=>{const N=w.getRowCount(),H=w.getColumnCount();return m.setEndForRange(k,N,H),k}),A=Kc(h,P,s,O,R);e(P,A)};return _.jsxs(_.Fragment,{children:[_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:u.t("permission.panel.protectedRange"),error:r,children:c&&_.jsx(c,{unitId:f,subUnitId:p,initialValue:o==null?void 0:o.map(C=>q.serializeRange(C)).join(","),onChange:(C,b)=>v(b)})}),_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:u.t("permission.panel.permissionDirection"),children:_.jsx(j.Input,{value:t,onChange:C=>i(C),placeholder:u.t("permission.panel.permissionDirectionPlaceholder")})})]})},Bf=n=>{var C,b;const{fromSheetBar:o,rule:e,oldRule:t}=n,i=I.useDependency(a.Injector),r=e?Wf(i,e):Vf(i,o),[s,l]=L.useState(r.ranges),[c,d]=L.useState(()=>Kc(i,r.ranges,r.permissionId,r.unitId,r.subUnitId)),[u,h]=L.useState(r.description),[S,g]=L.useState((C=r.editState)!=null?C:m.EditStateEnum.OnlyMe),[f,p]=L.useState((b=r.viewState)!=null?b:m.ViewStateEnum.OthersCanView),v=I.useComponentsOfPart(Dn);return L.useEffect(()=>{const E=i.get(a.IUniverInstanceService),w=i.get(I.ISidebarService),O=E.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!O)return;const R=O.getActiveSheet().getSheetId(),P=O.activeSheet$.subscribe(A=>{(A==null?void 0:A.getSheetId())!==R&&w.close()});return()=>{P.unsubscribe()}},[]),_.jsxs("div",{className:Ce.permissionPanelDetailWrapper,children:[_.jsx(Uf,{permissionId:r.permissionId,ranges:s,onRangesChange:(E,w)=>{l(E),d(w)},rangesErrMsg:c,desc:u,onDescChange:E=>h(E)}),_.jsx(I.ComponentContainer,{components:v,sharedProps:{editState:S,onEditStateChange:E=>g(E),viewState:f,onViewStateChange:E=>p(E),permissionId:r.permissionId}},"user-part"),_.jsx(Lf,{permissionId:r.permissionId,id:r.id,ranges:s,rangesErrMsg:c,desc:u,viewState:f,editState:S,oldRule:t})]})},xf="",he={sheetPermissionListPanelWrapper:"univer-sheet-permission-list-panel-wrapper",sheetPermissionListPanelHeader:"univer-sheet-permission-list-panel-header",sheetPermissionListPanelHeaderType:"univer-sheet-permission-list-panel-header-type",sheetPermissionListPanelHeaderTypeBottom:"univer-sheet-permission-list-panel-header-type-bottom",sheetPermissionListPanelHeaderSelect:"univer-sheet-permission-list-panel-header-select",sheetPermissionListItemHeaderIcon:"univer-sheet-permission-list-item-header-icon",sheetPermissionListItem:"univer-sheet-permission-list-item",sheetPermissionListItemHeader:"univer-sheet-permission-list-item-header",sheetPermissionListItemHeaderName:"univer-sheet-permission-list-item-header-name",sheetPermissionListItemHeaderOperator:"univer-sheet-permission-list-item-header-operator",sheetPermissionListItemSplit:"univer-sheet-permission-list-item-split",sheetPermissionListItemContentEdit:"univer-sheet-permission-list-item-content-edit",sheetPermissionListItemContentView:"univer-sheet-permission-list-item-content-view",sheetPermissionListItemContentDesc:"univer-sheet-permission-list-item-content-desc",sheetPermissionListEmpty:"univer-sheet-permission-list-empty",sheetPermissionListEmptyText:"univer-sheet-permission-list-empty-text",sheetPermissionListItemContentTitle:"univer-sheet-permission-list-item-content-title",sheetPermissionListItemContentSub:"univer-sheet-permission-list-item-content-sub",sheetPermissionPanelAddWrapper:"univer-sheet-permission-panel-add-wrapper",sheetPermissionPanelAddButton:"univer-sheet-permission-panel-add-button"},Ff=()=>{var U;const[n,o]=L.useState(!0),[e,t]=L.useState(!1),i=I.useDependency(a.LocaleService),r=I.useDependency(m.RangeProtectionRuleModel),s=I.useDependency(m.WorksheetProtectionRuleModel),l=I.useDependency(a.IUniverInstanceService),c=I.useDependency(a.ICommandService),d=I.useDependency(I.ISidebarService),u=I.useDependency(a.IAuthzIoService),h=I.useDependency(a.IPermissionService),g=I.useDependency(a.UserManagerService).getCurrentUser(),[f,p]=L.useState([]),v=I.useDependency(Et),C=I.useObservable(s.ruleRefresh$,""),b=I.useObservable(r.ruleRefresh$,""),E=l.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!E)return null;const w=E==null?void 0:E.getUnitId(),O=L.useCallback(async W=>{var Z;const B=E.getActiveSheet(),x=E.getUnitId(),X=B.getSheetId(),F=[],Y=[];E.getSheets().forEach(G=>{const J=G.getSheetId();r.getSubunitRuleList(x,J).forEach(re=>{re.permissionId&&F.push(re.permissionId)});const de=s.getRule(x,J);de!=null&&de.permissionId&&Y.push(de.permissionId)});const z=[...F,...Y],K=await u.list({objectIDs:z,unitID:x,actions:m.baseProtectionActions}),ee=r.getSubunitRuleList(x,X).map(G=>G.permissionId),$=(Z=s.getRule(x,X))==null?void 0:Z.permissionId;$&&ee.push($);const ae=K.filter(G=>{var J;return ee.includes(G.objectID)||G.objectID===((J=s.getRule(x,X))==null?void 0:J.permissionId)});return W?ae:K},[]),[R,P]=L.useState([]);L.useEffect(()=>{const W=D.merge(r.ruleChange$,s.ruleChange$).subscribe(async()=>{const B=await O(n);P(B)});return()=>{W.unsubscribe()}},[n]),L.useEffect(()=>{const W=E.activeSheet$.pipe(D.distinctUntilChanged((B,x)=>(B==null?void 0:B.getSheetId())===(x==null?void 0:x.getSheetId()))).subscribe(async()=>{const B=await O(n);P(B)});return()=>{W.unsubscribe()}},[n]),L.useEffect(()=>{(async()=>{if(C||b){const B=await O(!0);P(B)}})()},[C,b]);const A=W=>{const{unitId:B,subUnitId:x,unitType:X}=W;let F;X===rt.Worksheet?F=c.executeCommand(m.DeleteWorksheetProtectionCommand.id,{unitId:B,subUnitId:x,rule:W}):X===rt.SelectRange&&(F=c.executeCommand(m.DeleteRangeProtectionCommand.id,{unitId:B,subUnitId:x,rule:W})),F&&(t(!e),W.ranges===f&&p([]))};L.useEffect(()=>{v.reset()},[]),kc(f);const k=new Map;E.getSheets().forEach(W=>{const B=W.getSheetId();r.getSubunitRuleList(w,B).forEach(F=>{k.set(F.permissionId,F)});const X=s.getRule(w,B);X&&k.set(X==null?void 0:X.permissionId,X)});const N=W=>{W.subUnitId!==E.getActiveSheet().getSheetId()&&c.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:W.unitId,subUnitId:W.subUnitId});const B={header:{title:"permission.panel.title"},children:{label:wi,showDetail:!0,rule:a.Tools.deepClone(W),oldRule:a.Tools.deepClone(W)},width:330};d.open(B)},H=W=>{o(W)},V=(U=h.getPermissionPoint(new m.WorkbookCreateProtectPermission(w).id))==null?void 0:U.value;return _.jsxs("div",{className:he.sheetPermissionListPanelWrapper,children:[_.jsxs("div",{className:he.sheetPermissionListPanelHeader,children:[_.jsxs("div",{className:he.sheetPermissionListPanelHeaderType,onClick:()=>H(!0),children:[_.jsx("div",{className:j.clsx({[he.sheetPermissionListPanelHeaderSelect]:n}),children:i.t("permission.panel.currentSheet")}),n&&_.jsx("div",{className:he.sheetPermissionListPanelHeaderTypeBottom})]}),_.jsxs("div",{className:he.sheetPermissionListPanelHeaderType,onClick:()=>H(!1),children:[_.jsx("div",{className:j.clsx({[he.sheetPermissionListPanelHeaderSelect]:!n}),children:i.t("permission.panel.allSheet")}),!n&&_.jsx("div",{className:he.sheetPermissionListPanelHeaderTypeBottom})]})]}),(R==null?void 0:R.length)>0?_.jsx("div",{className:he.sheetPermissionListPanelContent,children:R==null?void 0:R.map(W=>{var J,oe,de,re,se;const B=k.get(W.objectID);if(!B)return null;const x=W.actions.find(ne=>ne.action===ie.Edit),X=x==null?void 0:x.allowed,F=W.actions.find(ne=>ne.action===ie.View),Y=F==null?void 0:F.allowed,z=W.actions.find(ne=>ne.action===ie.ManageCollaborator),K=W.actions.find(ne=>ne.action===ie.Delete),ee=(z==null?void 0:z.allowed)||g.userID===((J=W.creator)==null?void 0:J.userID),$=(K==null?void 0:K.allowed)||g.userID===((oe=W.creator)==null?void 0:oe.userID);let ae="";const Z=E.getSheetBySheetId(B.subUnitId),G=Z==null?void 0:Z.getName();if(B.unitType===rt.SelectRange){const ne=B.ranges,pe=ne!=null&&ne.length?ne.map(Ie=>{const ye=q.serializeRange(Ie);return ye==="NaN"?"":ye}).filter(Ie=>!!Ie).join(","):"";ae=`${G}(${pe})`}else B.unitType===rt.Worksheet&&(ae=G||"");return _.jsxs("div",{className:he.sheetPermissionListItem,onMouseMove:()=>{const{subUnitId:ne,unitType:pe}=B,Ie=E.getActiveSheet();if(!Ie)return!1;const ye=Ie.getSheetId();if(ne!==ye)return!1;if(pe===rt.SelectRange){const Me=B.ranges||[];Me!==f&&p(Me)}else if(pe===rt.Worksheet){const Me=[{startRow:0,endRow:Ie.getRowCount()-1,startColumn:0,endColumn:Ie.getColumnCount()-1}];Me!==f&&p(Me)}},onMouseLeave:()=>p([]),children:[_.jsxs("div",{className:he.sheetPermissionListItemHeader,children:[_.jsx(j.Tooltip,{title:ae,children:_.jsx("div",{className:he.sheetPermissionListItemHeaderName,children:ae})}),(ee||$)&&_.jsxs("div",{className:he.sheetPermissionListItemHeaderOperator,children:[ee&&_.jsx(j.Tooltip,{title:i.t("permission.panel.edit"),children:_.jsx("div",{className:he.sheetPermissionListItemHeaderIcon,onClick:()=>N(B),children:_.jsx(Tr,{})})}),$&&_.jsx(j.Tooltip,{title:i.t("permission.panel.delete"),children:_.jsx("div",{className:he.sheetPermissionListItemHeaderIcon,onClick:()=>A(B),children:_.jsx(eo,{})})})]})]}),_.jsx("div",{className:he.sheetPermissionListItemSplit}),_.jsxs("div",{className:he.sheetPermissionListItemContent,children:[_.jsxs("div",{className:he.sheetPermissionListItemContentEdit,children:[_.jsx(j.Tooltip,{title:(re=(de=W.creator)==null?void 0:de.name)!=null?re:"",children:_.jsx("div",{children:_.jsx(j.Avatar,{src:(se=W.creator)==null?void 0:se.avatar,style:{marginRight:6},size:24})})}),_.jsx("span",{className:he.sheetPermissionListItemContentTitle,children:i.t("permission.panel.created")}),_.jsx("span",{className:he.sheetPermissionListItemContentSub,children:X?`${i.t("permission.panel.iCanEdit")}`:`${i.t("permission.panel.iCanNotEdit")}`})]}),_.jsxs("div",{className:he.sheetPermissionListItemContentView,children:[_.jsx("span",{className:he.sheetPermissionListItemContentTitle,children:i.t("permission.panel.viewPermission")}),_.jsx("span",{className:he.sheetPermissionListItemContentSub,children:Y?`${i.t("permission.panel.iCanView")}`:`${i.t("permission.panel.iCanNotView")}`})]}),B.description&&_.jsx(j.Tooltip,{title:B.description,children:_.jsx("div",{className:he.sheetPermissionListItemContentDesc,children:B.description})})]})]},W.objectID)})}):_.jsxs("div",{className:he.sheetPermissionListEmpty,children:[_.jsx("img",{width:240,height:120,src:xf,alt:""}),_.jsx("p",{className:he.sheetPermissionListEmptyText,children:i.t("permission.dialog.listEmpty")})]}),V&&_.jsx("div",{className:he.sheetPermissionPanelAddWrapper,children:_.jsxs(j.Button,{className:he.sheetPermissionPanelAddButton,variant:"primary",onClick:()=>{const W={header:{title:`${i.t("permission.panel.title")}`},children:{label:wi,showDetail:!0},width:330};d.open(W)},children:[_.jsx("div",{children:"+ "}),i.t("permission.button.addNewPermission")]})})]})},zf=({showDetail:n,fromSheetBar:o,rule:e,oldRule:t})=>{var h;const i=I.useDependency(a.IUniverInstanceService),r=I.useDependency(m.SheetsSelectionsService);if(!I.useDependency(kn).getVisible())return null;const l=m.getSheetCommandTarget(i);if(!l)return null;const{worksheet:c}=l,u=((h=r.getCurrentSelections())==null?void 0:h.map(S=>S.range)).reduce((S,g)=>S+q.serializeRangeWithSheet(c.getName(),g),"");return n?_.jsx(Bf,{fromSheetBar:o,rule:e,oldRule:t},o?"sheet-bar":"normal"):_.jsx(Ff,{},u)},Ho={spinContainer:"univer-spin-container",spinOverlay:"univer-spin-overlay",spinner:"univer-spinner",contentBlur:"univer-content-blur"},Xf=({loading:n,children:o})=>_.jsxs("div",{className:Ho.spinContainer,children:[n&&_.jsx("div",{className:Ho.spinOverlay,children:_.jsx("div",{className:Ho.spinner})}),_.jsx("div",{className:n?Ho.contentBlur:"",children:o})]}),Tt={sheetPermissionDialogWrapper:"univer-sheet-permission-dialog-wrapper",sheetPermissionDialogSplit:"univer-sheet-permission-dialog-split",sheetPermissionDialogItem:"univer-sheet-permission-dialog-item",sheetPermissionUserDialogFooter:"univer-sheet-permission-user-dialog-footer",sheetPermissionUserDialogFooterConfirm:"univer-sheet-permission-user-dialog-footer-confirm",sheetPermissionUserDialogButton:"univer-sheet-permission-user-dialog-button"},Yf=()=>{const n=I.useDependency(a.LocaleService),o=I.useDependency(a.IUniverInstanceService),e=I.useDependency(a.IAuthzIoService),t=I.useDependency(m.WorksheetProtectionPointModel),i=I.useDependency(I.IDialogService),r=I.useDependency(a.IPermissionService),s=o.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),l=s.getActiveSheet();if(!l)throw new Error("No active sheet found");const[c,d]=L.useState([]),u=I.useDependency(a.ICommandService),[h,S]=L.useState(()=>!!t.getRule(s.getUnitId(),l.getSheetId())),[g,f]=L.useState(()=>Object.keys(_o).reduce((v,C)=>(v[C]={text:n.t(`permission.panel.${_o[Number(C)]}`),allowed:!0},v),{}));L.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=await e.listCollaborators({objectID:C,unitID:C});d(b)})()},[]),L.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=t.getRule(C,l.getSheetId());if(!b)return;S(!0);const w=(await e.list({unitID:s.getUnitId(),objectIDs:[b.permissionId],actions:MS}))[0].strategies.reduce((O,R)=>(_o[R.action]&&(O[R.action]={text:n.t(`permission.panel.${_o[R.action]}`),allowed:R.role!==He.Owner}),O),{});f(w),setTimeout(()=>{S(!1)},100)})()},[]);const p=async()=>{const v=o.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),C=v==null?void 0:v.getActiveSheet();if(!C)throw new Error("No active sheet found");const b=v.getUnitId(),E=C.getSheetId(),w=t.getRule(b,E),O=Object.keys(g).map(P=>({action:Number(P),role:g[P].allowed?He.Editor:He.Owner}));let R=w==null?void 0:w.permissionId;R?e.update({objectType:rt.Worksheet,objectID:R,unitID:b,strategies:O,share:void 0,name:"",scope:{read:$e.AllCollaborator,edit:$e.AllCollaborator},collaborators:void 0}).then(()=>{m.getAllWorksheetPermissionPoint().forEach(P=>{const A=new P(b,E),k=A.subType,N=O.find(H=>H.action===k);N&&r.updatePermissionPoint(A.id,N.role===He.Editor)})}):(R=await e.create({objectType:rt.Worksheet,worksheetObject:{unitID:b,collaborators:c,name:"",strategies:O,scope:{read:$e.AllCollaborator,edit:$e.AllCollaborator}}}),u.executeCommand(m.SetWorksheetPermissionPointsCommand.id,{rule:{permissionId:R,unitId:b,subUnitId:E}}))};return _.jsx(Xf,{loading:h,children:_.jsxs("div",{className:Tt.sheetPermissionDialogWrapper,children:[_.jsx("div",{className:Tt.sheetPermissionDialogSplit}),Object.keys(g).map(v=>{const C=g[v],{text:b,allowed:E}=C;return _.jsxs("div",{className:Tt.sheetPermissionDialogItem,children:[_.jsx("div",{children:b}),_.jsx(j.Switch,{defaultChecked:E,onChange:()=>{f({...g,[v]:{...C,allowed:!E}})}})]},b)}),_.jsx("div",{className:Tt.sheetPermissionDialogSplit}),_.jsxs("div",{className:Tt.sheetPermissionUserDialogFooter,children:[_.jsx(j.Button,{className:Tt.sheetPermissionUserDialogButton,onClick:()=>{i.close(Io)},children:n.t("permission.button.cancel")}),_.jsx(j.Button,{variant:"primary",onClick:()=>{p(),i.close(Io)},className:j.clsx(Tt.sheetPermissionUserDialogFooterConfirm,Tt.sheetPermissionUserDialogButton),children:n.t("permission.button.confirm")})]})]})})},qc="",ct={sheetPermissionUserList:"univer-sheet-permission-user-list",sheetPermissionUserListEmpty:"univer-sheet-permission-user-list-empty",sheetPermissionUserItem:"univer-sheet-permission-user-item",sheetPermissionUserItemName:"univer-sheet-permission-user-item-name",sheetPermissionSplit:"univer-sheet-permission-split",sheetPermissionUserDialogButton:"univer-sheet-permission-user-dialog-button"},jf=()=>{var u;const[n,o]=L.useState(""),e=I.useDependency(a.LocaleService),t=I.useDependency(I.IDialogService),i=I.useDependency(Et),r=I.useObservable(i.userList$,i.userList),s=(u=r==null?void 0:r.filter(h=>{var S;return((S=h.subject)==null?void 0:S.name.toLocaleLowerCase().includes(n.toLocaleLowerCase()))&&h.role===He.Editor}))!=null?u:[],[l,c]=L.useState(i.selectUserList),d=h=>{if((l==null?void 0:l.findIndex(g=>{var f,p;return((f=g.subject)==null?void 0:f.userID)===((p=h.subject)==null?void 0:p.userID)}))===-1){const g={...h};c([...l,g])}else{const g=l.filter(f=>{var p,v;return((p=f.subject)==null?void 0:p.userID)!==((v=h.subject)==null?void 0:v.userID)});c(g)}};return _.jsxs("div",{children:[_.jsx("div",{className:ct.sheetPermissionUserDialogSearch,children:_.jsx(j.Input,{className:"univer-w-full",placeholder:e.t("permission.dialog.search"),value:n,onChange:h=>o(h)})}),_.jsx("div",{className:ct.sheetPermissionUserList,children:(s==null?void 0:s.length)>0?_.jsx(_.Fragment,{children:s==null?void 0:s.map(h=>{var S,g,f;return _.jsxs("div",{className:ct.sheetPermissionUserItem,onClick:()=>d(h),children:[_.jsx(j.Avatar,{src:(S=h.subject)==null?void 0:S.avatar,size:24}),_.jsx("div",{className:ct.sheetPermissionUserItemName,children:(g=h.subject)==null?void 0:g.name}),(l==null?void 0:l.findIndex(p=>{var v,C;return((v=p.subject)==null?void 0:v.userID)===((C=h.subject)==null?void 0:C.userID)}))!==-1&&_.jsx("div",{children:_.jsx(_t,{})})]},(f=h.subject)==null?void 0:f.userID)})}):_.jsxs("div",{className:ct.sheetPermissionUserListEmpty,children:[_.jsx("img",{className:"univer-w-full",src:qc,alt:"empty list",draggable:!1}),_.jsx("p",{className:"univer-text-[13px] univer-text-gray-400",children:e.t("permission.dialog.userEmpty")})]})}),_.jsx("div",{className:ct.sheetPermissionSplit}),_.jsxs("div",{className:"univer-flex univer-items-center univer-justify-end univer-gap-1 univer-py-1",children:[_.jsx(j.Button,{className:ct.sheetPermissionUserDialogButton,onClick:()=>t.close(Co),children:e.t("permission.button.cancel")}),_.jsx(j.Button,{variant:"primary",onClick:()=>{i.setSelectUserList(l),t.close(Co)},className:j.clsx(ct.sheetPermissionUserDialogFooterConfirm,ct.sheetPermissionUserDialogButton),children:e.t("permission.button.confirm")})]})]})},Gf=({errorMsg:n})=>{const o=I.useDependency(a.LocaleService);return _.jsx("div",{children:_.jsx("p",{className:"univer-m-0",children:n||o.t("permission.dialog.alertContent")})})},Qc="",Jc="RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY",$c="RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY",Zf=25,Kf=80;class ed extends M.SheetExtension{constructor(){super();T(this,"_pattern",null);T(this,"_img",new Image);T(this,"renderCache",new Set);this._img.src=Qc}clearCache(){this.renderCache.clear()}draw(e,t,i){const{worksheet:r}=i;r&&(e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat")),this.renderCache.clear(),a.Range.foreach(i.rowColumnSegment,(s,l)=>{if(!r.getRowVisible(s)||!r.getColVisible(l))return;const{selectionProtection:c=[]}=r.getCell(s,l)||{};this._pattern&&(e.fillStyle=this._pattern,c.forEach(d=>{if(d.ruleId&&this.shouldRender(d)){if(this.renderCache.has(d.ruleId))return;this.renderCache.add(d.ruleId),d.ranges.forEach(u=>{const h=i.getCellWithCoordByIndex(u.startRow,u.startColumn,!1),S=i.getCellWithCoordByIndex(u.endRow,u.endColumn,!1);e.fillRect(h.startX,h.startY,S.endX-h.startX,S.endY-h.startY)})}}))}),e.restore())}}class qf extends ed{constructor(){super();T(this,"uKey",Jc);T(this,"Z_INDEX",Zf)}shouldRender(e){return(e==null?void 0:e[ie.View])!==!1}}class Qf extends ed{constructor(){super();T(this,"uKey",$c);T(this,"Z_INDEX",Kf)}shouldRender(e){return(e==null?void 0:e[ie.View])===!1}}const td="worksheet-protection",nd=25,Jf=80;class $f extends M.SheetExtension{constructor(){super();T(this,"uKey",td);T(this,"Z_INDEX",nd);T(this,"_pattern");T(this,"_img",new Image);this._img.src=Qc}draw(e,t,i){const{worksheet:r}=i;if(!r)return!1;e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat"));const{startRow:s,startColumn:l,endRow:c,endColumn:d}=i.rowColumnSegment,u=i.getCellWithCoordByIndex(s,l,!1),h=i.getCellWithCoordByIndex(c,d,!1),{hasWorksheetRule:S=!1,selectionProtection:g=[]}=r.getCell(s,l)||{};if(this._pattern){if(g.length>0){const f=g[0];(f==null?void 0:f[ie.View])?this.setZIndex(nd):this.setZIndex(Jf)}e.fillStyle=this._pattern,S&&e.fillRect(u.startX,u.startY,h.endX-u.startX,h.endY-u.startY),e.restore()}}setZIndex(e){this.Z_INDEX=e}}const ep=n=>{const{editState:o,onEditStateChange:e,viewState:t,onViewStateChange:i,permissionId:r}=n,s=I.useDependency(a.LocaleService),l=I.useDependency(I.IDialogService),c=I.useDependency(a.IAuthzIoService),d=I.useDependency(Et),u=I.useDependency(a.UserManagerService),h=I.useDependency(a.IUniverInstanceService),S=I.useObservable(d.selectUserList$,d.selectUserList),g=h.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),f=g==null?void 0:g.getActiveSheet();if(!g||!f)return null;const p=g.getUnitId(),v=async()=>{const C=await c.listCollaborators({objectID:p,unitID:p}),b=u.getCurrentUser();d.setCanEditUserList(C.filter(E=>{var w;return((w=E.subject)==null?void 0:w.userID)!==b.userID})),l.open({id:Co,title:{title:""},children:{label:Vl},width:280,destroyOnClose:!0,closable:!1,onClose:()=>l.close(Co),className:"sheet-permission-user-dialog"})};return L.useEffect(()=>{r?(async()=>{const E=(await c.listCollaborators({objectID:r,unitID:p})).filter(w=>w.role===He.Editor);E.length>0&&e(m.EditStateEnum.DesignedUserCanEdit),d.setSelectUserList(E),d.setOldCollaboratorList(E)})():(d.setSelectUserList([]),d.setOldCollaboratorList([]))},[]),_.jsxs(_.Fragment,{children:[_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:s.t("permission.panel.editPermission"),children:_.jsxs(j.RadioGroup,{value:o,onChange:C=>e(C),className:Ce.radioGroupVertical,children:[_.jsx(j.Radio,{value:m.EditStateEnum.OnlyMe,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.onlyICanEdit")})}),_.jsx(j.Radio,{value:m.EditStateEnum.DesignedUserCanEdit,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.designedUserCanEdit")})})]})}),o===m.EditStateEnum.DesignedUserCanEdit&&_.jsxs("div",{className:Ce.sheetPermissionDesignPersonPanel,children:[_.jsxs("div",{className:Ce.sheetPermissionDesignPersonPanelHeader,children:[_.jsx("span",{children:s.t("permission.panel.designedPerson")}),_.jsx("span",{className:Ce.sheetPermissionDesignPersonPanelHeaderAdd,onClick:v,children:s.t("permission.panel.addPerson")})]}),_.jsx("div",{className:Ce.sheetPermissionDesignPersonPanelSplit}),_.jsx("div",{className:Ce.sheetPermissionDesignPersonPanelContent,children:(S==null?void 0:S.length)>0?S.map(C=>{var b,E,w;return _.jsxs("div",{className:Ce.sheetPermissionDesignPersonPanelContentItem,children:[_.jsx(j.Avatar,{size:24,src:(b=C.subject)==null?void 0:b.avatar}),_.jsx("span",{className:Ce.sheetPermissionDesignPersonPanelContentItemName,children:(E=C.subject)==null?void 0:E.name}),_.jsx(j.Select,{className:Ce.sheetPermissionDesignPersonPanelContentItemSelect,value:"edit",onChange:O=>{O==="delete"&&d.setSelectUserList(S.filter(R=>{var P,A;return((P=R.subject)==null?void 0:P.userID)!==((A=C.subject)==null?void 0:A.userID)}))},options:[{label:`${s.t("permission.panel.canEdit")}`,value:"edit"},{label:`${s.t("permission.panel.delete")}`,value:"delete"}]})]},(w=C.subject)==null?void 0:w.userID)}):_.jsxs("div",{className:Ce.sheetPermissionUserListEmpty,children:[_.jsx("img",{width:240,height:120,src:qc,alt:""}),_.jsx("p",{className:Ce.sheetPermissionUserListEmptyText,children:s.t("permission.dialog.userEmpty")})]})})]}),_.jsx(j.FormLayout,{className:Ce.sheetPermissionPanelTitle,label:s.t("permission.panel.viewPermission"),children:_.jsxs(j.RadioGroup,{value:t,onChange:C=>i(C),className:Ce.radioGroupVertical,children:[_.jsx(j.Radio,{value:m.ViewStateEnum.OthersCanView,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.othersCanView")})}),_.jsx(j.Radio,{value:m.ViewStateEnum.NoOneElseCanView,children:_.jsx("span",{className:Ce.text,children:s.t("permission.panel.noOneElseCanView")})})]})})]})};var tp=Object.getOwnPropertyDescriptor,Rs=(n,o,e,t)=>{for(var i=t>1?void 0:t?tp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},xe=(n,o)=>(e,t)=>o(e,t,n);let Wi=class extends a.Disposable{constructor(n,o,e){super(),this._injector=n,this._componentManager=o,this._uiPartsService=e,this._init()}_init(){this._initComponents(),this._initUiPartComponents()}_initComponents(){[[Ll,ba],[RS,eo],[PS,Tr],[OS,_t],[Ul,br],[wi,zf],[Vl,jf],[Wl,Yf],[Zc,Gf]].forEach(([n,o])=>{this.disposeWithMe(this._componentManager.register(n,o))})}_initUiPartComponents(){var e;const o=this._injector.get(a.IConfigService).getConfig(Fe);(e=o==null?void 0:o.customComponents)!=null&&e.has(Dn)||this.disposeWithMe(this._uiPartsService.registerComponent(Dn,()=>I.connectInjector(ep,this._injector)))}};Wi=Rs([xe(0,a.Inject(a.Injector)),xe(1,a.Inject(I.ComponentManager)),xe(2,a.Inject(I.IUIPartsService))],Wi);let Vo=class extends a.Disposable{constructor(o,e,t,i,r){var l;super();T(this,"_rangeProtectionCanViewRenderExtension",new qf);T(this,"_rangeProtectionCanNotViewRenderExtension",new Qf);this._context=o,this._rangeProtectionRuleModel=e,this._sheetSkeletonManagerService=t,this._permissionService=i,this._configService=r;const s=this._configService.getConfig(Fe);this._initSkeleton(),!((l=s==null?void 0:s.customComponents)!=null&&l.has(vo))&&(this._initRender(),this.disposeWithMe(this._rangeProtectionRuleModel.ruleChange$.subscribe(c=>{var d,u;((d=c.oldRule)!=null&&d.id&&this._rangeProtectionCanViewRenderExtension.renderCache.has(c.oldRule.id)||this._rangeProtectionCanViewRenderExtension.renderCache.has(c.rule.id))&&this._rangeProtectionCanViewRenderExtension.clearCache(),((u=c.oldRule)!=null&&u.id&&this._rangeProtectionCanNotViewRenderExtension.renderCache.has(c.oldRule.id)||this._rangeProtectionCanNotViewRenderExtension.renderCache.has(c.rule.id))&&this._rangeProtectionCanNotViewRenderExtension.clearCache()})))}_initRender(){const o=this._context.mainComponent;o&&(o.getExtensionByKey(Jc)||o.register(this._rangeProtectionCanViewRenderExtension),o.getExtensionByKey($c)||o.register(this._rangeProtectionCanNotViewRenderExtension))}_initSkeleton(){const o=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(D.merge(this._permissionService.permissionPointUpdate$.pipe(D.throttleTime(300,void 0,{trailing:!0})),this._rangeProtectionRuleModel.rangeRuleInitStateChange$,this._rangeProtectionRuleModel.ruleChange$).pipe().subscribe(o))}};Vo=Rs([xe(1,a.Inject(m.RangeProtectionRuleModel)),xe(2,a.Inject(y.SheetSkeletonManagerService)),xe(3,a.IPermissionService),xe(4,a.IConfigService)],Vo);let Wo=class extends a.Disposable{constructor(o,e,t,i,r,s){var c;super();T(this,"_worksheetProtectionRenderExtension",new $f);this._context=o,this._renderManagerService=e,this._univerInstanceService=t,this._sheetSkeletonManagerService=i,this._worksheetProtectionRuleModel=r,this._configService=s;const l=this._configService.getConfig(Fe);this._initSkeleton(),!((c=l==null?void 0:l.customComponents)!=null&&c.has(vo))&&this._initRender()}_initRender(){const o=this._context.unitId,e=o&&this._renderManagerService.getRenderById(o),t=e&&e.mainComponent;t&&(t.getExtensionByKey(td)||t.register(this._worksheetProtectionRenderExtension))}_initSkeleton(){const o=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(D.merge(this._worksheetProtectionRuleModel.worksheetRuleInitStateChange$).pipe().subscribe(o))}};Wo=Rs([xe(1,a.Inject(M.IRenderManagerService)),xe(2,a.Inject(a.IUniverInstanceService)),xe(3,a.Inject(y.SheetSkeletonManagerService)),xe(4,a.Inject(m.WorksheetProtectionRuleModel)),xe(5,a.Inject(a.IConfigService))],Wo);var np=Object.getOwnPropertyDescriptor,ip=(n,o,e,t)=>{for(var i=t>1?void 0:t?np(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ps=(n,o)=>(e,t)=>o(e,t,n);let Lo=class extends a.Disposable{constructor(n,o,e,t){super(),this._context=n,this._formatPainterService=o,this._selectionRenderService=e,this._commandService=t,this._initialize()}_initialize(){this._bindFormatPainterStatus(),this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._selectionRenderService.selectionMoveEnd$.subscribe(n=>{var o;if(this._formatPainterService.getStatus()!==Ne.OFF){const{rangeWithCoord:e}=n[n.length-1];this._commandService.executeCommand(hi.id,{unitId:this._context.unitId,subUnitId:((o=this._context.unit.getActiveSheet())==null?void 0:o.getSheetId())||"",range:{startRow:e.startRow,startColumn:e.startColumn,endRow:e.endRow,endColumn:e.endColumn}}),this._formatPainterService.getStatus()===Ne.ONCE&&this._commandService.executeCommand(Tn.id)}}))}_bindFormatPainterStatus(){this.disposeWithMe(a.toDisposable(this._formatPainterService.status$.subscribe(n=>{const o=this._context.scene;o&&(n!==Ne.OFF?o.setDefaultCursor(M.CURSOR_TYPE.CELL):o.setDefaultCursor(M.CURSOR_TYPE.DEFAULT))})))}};Lo=ip([Ps(1,Qe),Ps(2,ve),Ps(3,a.ICommandService)],Lo);var op=Object.getOwnPropertyDescriptor,rp=(n,o,e,t)=>{for(var i=t>1?void 0:t?op(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Li=(n,o)=>(e,t)=>o(e,t,n);let Os=class extends a.Disposable{constructor(n,o,e,t,i,r){super(),this._context=n,this._layoutService=o,this._contextMenuService=e,this._selectionManagerService=t,this._selectionRenderService=i,this._sheetSkeletonManagerService=r,this._init()}_init(){let n=!1;this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(()=>n=!0)),this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(o=>{const e=this._sheetSkeletonManagerService.getCurrentParam().skeleton;if(!e||!o||n===!1)return;n=!1;const t=o[0];if(!t.primary)return;const i=Re(t,e),r=t.range.rangeType,{scene:s}=this._context,l=s.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=(l==null?void 0:l.viewportScrollX)||0,d=(l==null?void 0:l.viewportScrollY)||0;let u=0,h=0;const S=e.rowHeaderWidth,g=this._layoutService.getContentElement().getBoundingClientRect();switch(r){case a.RANGE_TYPE.NORMAL:u=i.rangeWithCoord.startX+g.left-c,h=i.rangeWithCoord.endY+g.top-d;break;case a.RANGE_TYPE.COLUMN:u=i.rangeWithCoord.startX+g.left-c,h=Math.min(g.height/2,i.rangeWithCoord.endY)+40;break;case a.RANGE_TYPE.ROW:u=(g.width-S)/2+20,h=i.rangeWithCoord.endY+g.top-d;break;case a.RANGE_TYPE.ALL:u=i.rangeWithCoord.startX+g.left,h=i.rangeWithCoord.startY+g.top;break;default:u=i.rangeWithCoord.startX+g.left-c,h=i.rangeWithCoord.endY+g.top-d;break}u=a.Tools.clamp(u,S,g.width),h=a.Tools.clamp(h,g.top,g.height),this._contextMenuService.triggerContextMenu({clientX:u,clientY:h,preventDefault:()=>{},stopPropagation:()=>{}},I.ContextMenuPosition.MAIN_AREA)}))}};Os=rp([Li(1,I.ILayoutService),Li(2,I.IContextMenuService),Li(3,a.Inject(m.SheetsSelectionsService)),Li(4,ve),Li(5,a.Inject(y.SheetSkeletonManagerService))],Os);var sp=Object.getOwnPropertyDescriptor,ap=(n,o,e,t)=>{for(var i=t>1?void 0:t?sp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Un=(n,o)=>(e,t)=>o(e,t,n);const lp=[Ae.id,qe.id];let As=class extends a.Disposable{constructor(n,o,e,t,i,r,s){super(),this._context=n,this._sheetSkeletonManagerService=o,this._commandService=e,this._renderManagerService=t,this._selectionManagerService=i,this._scrollManagerService=r,this._univerInstanceService=s,this._init()}scrollToRange(n){let{endRow:o,endColumn:e,startColumn:t,startRow:i}=n;const r=this._getViewportBounding();if(n.rangeType===a.RANGE_TYPE.ROW?(t=0,e=0):n.rangeType===a.RANGE_TYPE.COLUMN&&(i=0,o=0),r){const s=r.startRow>o?i:o,l=r.startColumn>e?t:e;return this._scrollToCell(s,l)}else return this._scrollToCell(i,t)}_init(){this._initCommandListener(),this._initScrollEventListener(),this._initPointerScrollEvent(),this._initSkeletonListener()}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(lp.includes(n.id))this._scrollToSelection();else if(n.id===m.ScrollToCellOperation.id){const o=n.params.range;this.scrollToRange(o)}else if(n.id===ke.id){const o=n.params;this._scrollToSelectionForExpand(o)}}))}_scrollToSelectionForExpand(n){setTimeout(()=>{const o=this._selectionManagerService.getCurrentLastSelection();if(o==null)return;const{startRow:e,startColumn:t,endRow:i,endColumn:r}=o.range,s=this._getViewportBounding();if(s==null)return;const{startRow:l,startColumn:c,endRow:d,endColumn:u}=s;let h=0,S=0;e>l?h=i:i<d?h=e:h=l,t>c?S=r:r<u?S=t:S=c,n.direction===a.Direction.DOWN?h=i:n.direction===a.Direction.UP?h=e:n.direction===a.Direction.RIGHT?S=r:n.direction===a.Direction.LEFT&&(S=t),this._scrollToCell(h,S)},0)}_getFreeze(){var o;const n=(o=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:o.skeleton.getWorksheetConfig();if(n!=null)return n.freeze}_initScrollEventListener(){const{scene:n}=this._context;if(n==null)return;const o=n.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);o&&(this.disposeWithMe(a.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(e=>{var S;if(e==null){o.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const t=(S=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:S.skeleton;if(!t)return;const{sheetViewStartRow:i,sheetViewStartColumn:r,offsetX:s,offsetY:l}=e,{startX:c,startY:d}=t.getCellWithCoordByIndex(i,r,!1),u=c+s,h=d+l;o.scrollToViewportPos({viewportScrollX:u,viewportScrollY:h})}))),this.disposeWithMe(o.onScrollAfter$.subscribeEvent(e=>{var f;if(!e)return;const t=(f=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:f.skeleton;if(t==null)return;const i=this._getSheetObject();if(t==null||i==null)return;const{viewportScrollX:r,viewportScrollY:s,scrollX:l,scrollY:c}=e,{row:d,column:u,rowOffset:h,columnOffset:S}=t.getOffsetRelativeToRowCol(r,s),g={sheetViewStartRow:d,sheetViewStartColumn:u,offsetX:S,offsetY:h,viewportScrollX:r,viewportScrollY:s,scrollX:l,scrollY:c};this._scrollManagerService.setValidScrollStateToCurrSheet(g),this._scrollManagerService.validViewportScrollInfo$.next({...g,scrollX:l,scrollY:c,viewportScrollX:r,viewportScrollY:s})})),this.disposeWithMe(o.onScrollByBar$.subscribeEvent(e=>{var S;const t=(S=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:S.skeleton;if(t==null||e.isTrigger===!1)return;const i=this._getSheetObject();if(t==null||i==null)return;const{viewportScrollX:r=0,viewportScrollY:s=0}=e,l=this._getFreeze(),{row:c,column:d,rowOffset:u,columnOffset:h}=t.getOffsetRelativeToRowCol(r,s);this._commandService.executeCommand(Ye.id,{sheetViewStartRow:c+((l==null?void 0:l.ySplit)||0),sheetViewStartColumn:d+((l==null?void 0:l.xSplit)||0),offsetX:h,offsetY:u})})))}_initSkeletonListener(){this.disposeWithMe(a.toDisposable(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(n=>{if(n==null)return;const o={unitId:n.unitId,sheetId:n.sheetId};this._scrollManagerService.setSearchParam(o);const e=this._getSheetObject();if(!e)return;const i=e.scene.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),r=this._scrollManagerService.getScrollStateByParam(o),{viewportScrollX:s,viewportScrollY:l}=this._scrollManagerService.calcViewportScrollFromRowColOffset(r);i&&(r?(i.viewportScrollX=s,i.viewportScrollY=l):(i.viewportScrollX=0,i.viewportScrollY=0),this._updateSceneSize(n))})))}_initPointerScrollEvent(){const n=this._getSheetObject();if(!n)return;const o=this._scrollManagerService,e=n.scene,t=n.spreadsheet,i=e.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),r={x:0,y:0};let s=!1;const l={x:0,y:0},c=.95;let d=null;const u=()=>{if(!i)return;l.x*=c,l.y*=c,r.x+=l.x,r.y+=l.y;const S=l.x,g=l.y;(g!==0||S!==0)&&this._commandService.executeCommand(mn.id,{offsetY:g,offsetX:S}),Math.abs(l.x)>1||Math.abs(l.y)>1?d=requestAnimationFrame(u):d=null},h=()=>{cancelAnimationFrame(d),d=null};t.onPointerDown$.subscribeEvent((S,g)=>{h(),i&&(r.x=S.offsetX,r.y=S.offsetY,s=!0,g.stopPropagation())}),t.onPointerMove$.subscribeEvent((S,g)=>{if(!s||!i)return;const f=S,p=-(f.offsetX-r.x),v=-(f.offsetY-r.y);l.x=-(f.offsetX-r.x),l.y=-(f.offsetY-r.y);const C=p,b=v;(p!==0||v!==0)&&(b!==0||C!==0)&&this._commandService.executeCommand(mn.id,{offsetY:b,offsetX:C}),o.getCurrentScrollState(),r.x=f.offsetX,r.y=f.offsetY,g.stopPropagation()}),t.onPointerUp$.subscribeEvent(S=>{s=!1,d=requestAnimationFrame(u)}),t.onPointerLeave$.subscribeEvent(()=>{s=!1}),t.onPointerOut$.subscribeEvent(()=>{s=!1}),e.onPointerOut$.subscribeEvent(()=>{s=!1}),e.onPointerCancel$.subscribeEvent(()=>{s=!1})}_updateSceneSize(n){var h;if(n==null)return;const{unitId:o}=this._context,{skeleton:e}=n,t=(h=this._renderManagerService.getRenderById(o))==null?void 0:h.scene;if(e==null||t==null)return;const{rowTotalHeight:i,columnTotalWidth:r,rowHeaderWidthAndMarginLeft:s,columnHeaderHeightAndMarginTop:l}=e,d=this._context.unit.getActiveSheet();if(!d)return;const u=d.getZoomRatio()||1;t==null||t.setScaleValueOnly(u,u),t==null||t.transformByState({width:s+r,height:l+i})}_getSheetObject(){return ze(this._context.unit,this._context)}_scrollToSelectionByDirection(n){const o=this._getViewportBounding();if(o==null)return!1;const{startRow:e,startColumn:t,endRow:i,endColumn:r}=o;let s=0,l=0;const{startRow:c,startColumn:d,endRow:u,endColumn:h}=n;c>=e&&(s=u),u<=i&&(s=c),d>=t&&(l=h),h<=r&&(l=d),this._scrollToCell(s,l)}_scrollToSelection(n=!0){const o=this._selectionManagerService.getCurrentLastSelection();if(o==null)return;const{startRow:e,startColumn:t,actualRow:i,actualColumn:r}=o.primary,s=n?i:e,l=n?r:t;this._scrollToCell(s,l)}_getViewportBounding(){var t,i;const n=(t=this._getSheetObject())==null?void 0:t.scene;if(n==null)return;const o=n.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(o==null)return;const e=(i=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:i.skeleton;if(e!=null)return e.getRangeByViewport(o.calcViewportInfo())}_scrollToCell(n,o){var O,R,P,A;const{rowHeightAccumulation:e,columnWidthAccumulation:t}=(R=(O=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:O.skeleton)!=null?R:{};if(e==null||t==null)return!1;const i=(P=this._getSheetObject())==null?void 0:P.scene;if(i==null)return!1;const r=i.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(r==null||((A=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:A.skeleton)==null)return!1;const l=this._context.unit.getActiveSheet();if(!l)return!1;const{startColumn:c,startRow:d,ySplit:u,xSplit:h}=l.getFreeze(),S=this._getViewportBounding();if(S==null)return!1;const{startRow:g,startColumn:f,endRow:p,endColumn:v}=S;let C,b;if(n>=d&&o>=c-h&&(n<=g&&(C=n),n>=p)){const k=e[n]-r.height;for(let N=g;N<=n;N++)if(e[N]>=k){C=N+1;break}}if(o>=c&&n>=d-u&&(o<=f&&(b=o),o>=v)){const k=t[o]-r.width;for(let N=f;N<=o;N++)if(t[N]>=k){b=N+1;break}}if(C===void 0&&b===void 0)return!1;const{offsetX:E,offsetY:w}=this._scrollManagerService.getCurrentScrollState()||{};return this._commandService.syncExecuteCommand(Ye.id,{sheetViewStartRow:C,sheetViewStartColumn:b,offsetX:b===void 0?E:0,offsetY:C===void 0?w:0})}};As=ap([Un(1,a.Inject(y.SheetSkeletonManagerService)),Un(2,a.ICommandService),Un(3,M.IRenderManagerService),Un(4,a.Inject(m.SheetsSelectionsService)),Un(5,a.Inject(y.SheetScrollManagerService)),Un(6,a.IUniverInstanceService)],As);function id(n){const{popup:o}=n,{extraProps:e}=o,{options:t,defaultValue:i,onChange:r}=e,[s,l]=L.useState(i!=null?i:[]);return _.jsx(j.CascaderList,{options:t,value:s,onChange:r})}id.componentKey="sheets.dropdown.cascader";function od(n){const{popup:o}=n,{extraProps:e}=o,{defaultValue:t,onChange:i}=e;return _.jsx(j.ColorPicker,{value:t,onChange:i})}od.componentKey="sheets.dropdown.color";const rd={dvDateDropdown:"univer-dv-date-dropdown",dvDateDropdownBtns:"univer-dv-date-dropdown-btns"};function sd(n){const{popup:o}=n,{extraProps:e}=o,{hideFn:t,patternType:i,defaultValue:r,onChange:s,showTime:l}=e,[c,d]=L.useState(r),u=L.useMemo(()=>i!=="time"?a.dayjs():a.dayjs("1900-01-01 00:00:00"),[]),h=c&&c.isValid()?c:u,S=I.useDependency(a.LocaleService),g=async()=>{h&&await(s==null?void 0:s(h))!==!1&&t()};return _.jsxs("div",{className:rd.dvDateDropdown,children:[_.jsx(j.DatePanel,{value:h,pickerValue:h,mode:i==="time"?"time":"date",showTime:(l!=null?l:i==="datetime"||i==="time")||void 0,onSelect:async f=>{d(f)},onPanelChange:f=>{d(f)},disabledDate:f=>!a.numfmt.parseDate(f.format("YYYY-MM-DD"))}),_.jsx("div",{className:rd.dvDateDropdownBtns,children:_.jsx(j.Button,{size:"small",variant:"primary",onClick:g,disabled:!h||!h.isValid(),children:S.t("dataValidation.alert.ok")})})]})}sd.componentKey="sheets.dropdown.date";const dt={dvListDropdown:"univer-dv-list-dropdown",dvListDropdownTitle:"univer-dv-list-dropdown-title",dvListDropdownList:"univer-dv-list-dropdown-list",dvListDropdownListContainer:"univer-dv-list-dropdown-list-container",dvListDropdownSelectedIcon:"univer-dv-list-dropdown-selected-icon",dvListDropdownItemContainer:"univer-dv-list-dropdown-item-container",dvListDropdownItem:"univer-dv-list-dropdown-item",dvListDropdownSplit:"univer-dv-list-dropdown-split",dvListDropdownEdit:"univer-dv-list-dropdown-edit"};function cp(n){return n.filter(Boolean).join(",")}function dp(n){return n.split(",").filter(Boolean)}const up=n=>{const{value:o,onChange:e,multiple:t,options:i,title:r,onEdit:s,style:l,filter:c,location:d,showEdit:u}=n,h=I.useDependency(a.LocaleService),S=c==null?void 0:c.toLowerCase(),{row:g,col:f,unitId:p,subUnitId:v}=d,C=i.filter(w=>S?w.label.toLowerCase().includes(S):!0),b=I.useDependency(m.SheetPermissionCheckController),E=L.useMemo(()=>b.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission]},[{startColumn:f,startRow:g,endColumn:f,endRow:g}],p,v),[b,f,g,p,v]);return _.jsxs("div",{className:dt.dvListDropdown,style:l,children:[_.jsx("div",{className:dt.dvListDropdownTitle,children:r}),_.jsx("div",{className:dt.dvListDropdownList,children:_.jsx(j.Scrollbar,{children:_.jsx("div",{className:dt.dvListDropdownListContainer,children:C.map((w,O)=>{const R=o.indexOf(w.value)>-1,P=()=>{let k;R?k=new Set(o.filter(H=>H!==w.value)):k=new Set(t?[...o,w.value]:[w.value]);const N=[];i.forEach(H=>{k.has(H.value)&&N.push(H.value)}),e(N)},A=w.label.toLocaleLowerCase().indexOf(S);return _.jsxs("div",{className:dt.dvListDropdownItemContainer,onClick:P,children:[_.jsx("div",{className:dt.dvListDropdownItem,style:{background:w.color},children:S&&w.label.toLowerCase().includes(S)?_.jsxs(_.Fragment,{children:[_.jsx("span",{children:w.label.substring(0,A)}),_.jsx("span",{style:{fontWeight:"bold"},children:w.label.substring(A,A+S.length)}),_.jsx("span",{children:w.label.substring(A+S.length)})]}):w.label}),_.jsx("div",{className:dt.dvListDropdownSelectedIcon,children:R?_.jsx(_t,{}):null})]},O)})})},c)}),u&&E?_.jsxs(_.Fragment,{children:[_.jsx("div",{className:dt.dvListDropdownSplit}),_.jsx("div",{className:dt.dvListDropdownEdit,children:_.jsx("a",{onClick:s,children:h.t("dataValidation.list.edit")})})]}):null]})};function ad(n){var O,R,P,A;const{popup:{extraProps:o}}=n,{location:e,hideFn:t,onChange:i,onEdit:r,options:s,defaultValue:l,multiple:c,showEdit:d}=o,{worksheet:u}=e,[h,S]=L.useState(""),g=I.useDependency(a.ICommandService),f=I.useDependency(a.LocaleService),[p,v]=L.useState(l),C=I.useDependency(Se),b=I.useDependency(a.IUniverInstanceService),E=I.RectPopup.useContext(),w=((R=(O=E.current)==null?void 0:O.right)!=null?R:0)-((A=(P=E.current)==null?void 0:P.left)!=null?A:0);return L.useEffect(()=>{const k=g.onCommandExecuted(N=>{var H,V;if(N.id===_e.RichTextEditingMutation.id){const U=N.params,{unitId:W}=U,B=b.getUnit(W,a.UniverInstanceType.UNIVER_DOC);if(!B||!C.isVisible().visible)return;const x=a.BuildTextUtils.transform.getPlainText((V=(H=B.getSnapshot().body)==null?void 0:H.dataStream)!=null?V:"");S(x)}});return()=>{k.dispose()}},[g,C,b]),u?_.jsx(up,{style:{minWidth:w,maxWidth:Math.max(w,200)},title:c?f.t("dataValidation.listMultiple.dropdown"):f.t("dataValidation.list.dropdown"),value:dp(p!=null?p:""),multiple:c,onChange:async k=>{const N=cp(k);v(N),await(i==null?void 0:i(k))!==!1&&t()},options:s,onEdit:r,filter:h,location:e,showEdit:d}):null}ad.componentKey="sheets.dropdown.list";const ld={datepicker:sd,list:ad,color:od,cascader:id};var hp=Object.getOwnPropertyDescriptor,mp=(n,o,e,t)=>{for(var i=t>1?void 0:t?hp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Uo=(n,o)=>(e,t)=>o(e,t,n);const Ds=a.createIdentifier("ICellDropdownManagerService");y.SheetCellDropdownManagerService=class extends a.Disposable{constructor(o,e,t,i){super(),this._canvasPopupManagerService=o,this._zenZoneService=e,this._renderManagerService=t,this._componentManager=i,Object.values(ld).forEach(r=>{this.disposeWithMe(this._componentManager.register(r.componentKey,r))})}showDropdown(o){const{location:e,onHide:t,closeOnOutSide:i=!0}=o,{row:r,col:s,unitId:l,subUnitId:c}=e;if(this._zenZoneService.visible)throw new Error("[SheetCellDropdownManagerService]: cannot show dropdown when zen mode is visible");const d=ld[o.type],u=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),h=new a.DisposableCollection,S=this._canvasPopupManagerService.attachPopupToCell(r,s,{componentKey:d.componentKey,onClickOutside:()=>{i&&h.dispose()},offset:[0,3],excludeOutside:[u==null?void 0:u.engine.getCanvasElement()].filter(Boolean),extraProps:{...o,...o.props,hideFn:()=>{h.dispose()}}},l,c);if(!S)throw new Error("[SheetCellDropdownManagerService]: cannot show dropdown");return h.add(S),h.add({dispose:()=>{t==null||t()}}),h}},y.SheetCellDropdownManagerService=mp([Uo(0,a.Inject(y.SheetCanvasPopManagerService)),Uo(1,I.IZenZoneService),Uo(2,M.IRenderManagerService),Uo(3,a.Inject(I.ComponentManager))],y.SheetCellDropdownManagerService);const Sp=a.createInterceptorKey("PRINTING_RANGE"),gp=a.createInterceptorKey("PRINTING_COMPONENT_COLLECT"),fp=a.createInterceptorKey("PRINTING_DOM_COLLECT");class ks extends a.Disposable{constructor(){super();T(this,"interceptor",new a.InterceptorManager({PRINTING_RANGE:Sp,PRINTING_COMPONENT_COLLECT:gp,PRINTING_DOM_COLLECT:fp}));this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_RANGE,{priority:-1,handler:e=>e})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_COMPONENT_COLLECT,{priority:-1,handler:e=>e})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_DOM_COLLECT,{priority:-1,handler:e=>e}))}}class pp extends zn{constructor(e,t,i,r){super(e,t,i,r);T(this,"_fillControlTopLeft");T(this,"_fillControlBottomRight");T(this,"_rangeType",a.RANGE_TYPE.NORMAL);this._scene=e,this._zIndex=t,this._themeService=i,this._rangeType=(r==null?void 0:r.rangeType)||a.RANGE_TYPE.NORMAL,this.initControlPoints()}initControlPoints(){const e=this.currentStyle,t=e.expandCornerSize||0,i=(e.expandCornerSize||0)/4,r=e.autofillStrokeWidth||0,s=e.stroke,l=e.autofillStroke,c=this.zIndex;this._fillControlTopLeft=new M.Rect(nr.fillTopLeft+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualWidth:i,visualHeight:i,strokeWidth:r}),this._fillControlBottomRight=new M.Rect(nr.fillBottomRight+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualHeight:i,visualWidth:i,strokeWidth:r});const d={fill:s,stroke:l,strokeScaleEnabled:!1};this._fillControlTopLeft.setProps({...d}),this._fillControlBottomRight.setProps({...d});const u=[this._fillControlTopLeft,this._fillControlBottomRight];switch(this._rangeType){case a.RANGE_TYPE.ROW:this.rowHeaderGroup.addObjects(...u);break;case a.RANGE_TYPE.COLUMN:this.columnHeaderGroup.addObjects(...u);break;case a.RANGE_TYPE.NORMAL:this.selectionShapeGroup.addObjects(...u)}this.getScene().addObjects(u,Yi)}get fillControlTopLeft(){return this._fillControlTopLeft}set fillControlTopLeft(e){this._fillControlTopLeft=e}get fillControlBottomRight(){return this._fillControlBottomRight}set fillControlBottomRight(e){this._fillControlBottomRight=e}get rangeType(){return this._rangeType}set rangeType(e){this._rangeType=e}dispose(){var e,t;(e=this._fillControlBottomRight)==null||e.dispose(),(t=this._fillControlTopLeft)==null||t.dispose(),super.dispose()}_updateLayoutOfSelectionControl(e){var r,s;super._updateLayoutOfSelectionControl(e);const t=this.currentStyle;e==null&&(e=t);const{widgets:i=t.widgets}=e;if(this.currentStyle=e,this._enableAutoFill===!0&&!super._hasWidgets(i)){const{viewportScrollX:l,viewportScrollY:c}=this.getViewportMainScrollInfo(),{endX:d,endY:u}=this.selectionModel;this.transformControlPoint(l,c,d,u),this.fillControlTopLeft.show(),this.fillControlBottomRight.show()}else(r=this.fillControlTopLeft)==null||r.hide(),(s=this.fillControlBottomRight)==null||s.hide()}getViewportMainScrollInfo(){const e=this.getScene().getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);return{viewportScrollX:(e==null?void 0:e.viewportScrollX)||0,viewportScrollY:(e==null?void 0:e.viewportScrollY)||0,width:(e==null?void 0:e.width)||0,height:(e==null?void 0:e.height)||0}}transformControlPoint(e=0,t=0,i=0,r=0){const s=this.currentStyle,l=this.selectionModel.rangeType,c=s.expandCornerSize,{startX:d,startY:u,endX:h,endY:S}=this.selectionModel,g=this.getViewportMainScrollInfo(),f=g.width,p=g.height;switch(l){case a.RANGE_TYPE.NORMAL:this.fillControlTopLeft.transformByState({left:-c/2,top:-c/2}),this.fillControlBottomRight.transformByState({left:h-d-c/2,top:S-u-c/2});break;case a.RANGE_TYPE.ROW:{const v=Math.min(f/2+e,i),C=-c/2+v;this.fillControlTopLeft.transformByState({left:C,top:-c/2}),this.fillControlBottomRight.transformByState({left:C,top:-c/2+S-u})}break;case a.RANGE_TYPE.COLUMN:{const v=Math.min(+p/2+t,r),C=-c/2+v;this.fillControlTopLeft.transformByState({left:-c/2,top:C}),this.fillControlBottomRight.transformByState({left:-c/2+h-d,top:C})}break;default:console.error("unknown range type")}}}var vp=Object.getOwnPropertyDescriptor,Cp=(n,o,e,t)=>{for(var i=t>1?void 0:t?vp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ut=(n,o)=>(e,t)=>o(e,t,n);let Bo=class extends ir{constructor(o,e,t,i,r,s,l,c,d,u){super(e,t,i,s,d);T(this,"_workbookSelections");T(this,"_renderDisposable",null);T(this,"_expandingSelection",!1);T(this,"_selectionControls",[]);T(this,"expandingControlMode","bottom-right");this._context=o,this._logService=l,this._commandService=c,this._contextService=d,this._scrollManagerService=u,this._workbookSelections=r.getWorkbookSelections(this._context.unitId),this._init()}_init(){const o=this._getSheetObject();this._initEventListeners(o),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._updateControlPointWhenScrolling()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(o=>{if(o==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const e=this._context.unitId,{sheetId:t,skeleton:i}=o,{scene:r}=this._context,s=r.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._changeRuntime(i,r,s),this._workbookSelections.getCurrentLastSelection()||this._commandService.syncExecuteCommand(m.SetSelectionsOperation.id,{unitId:e,subUnitId:t,selections:[Zi(i)]})}))}_initSelectionChangeListener(){}_initEventListeners(o){const{spreadsheetRowHeader:e,spreadsheetColumnHeader:t,spreadsheet:i,spreadsheetLeftTopPlaceholder:r}=o,{scene:s}=this._context;this._initSpreadsheetEvent(o),this.disposeWithMe(e==null?void 0:e.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{row:u}=Ze(l.offsetX,l.offsetY,s,d);wl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(i.zIndex||1)+1,a.RANGE_TYPE.ROW,this._getActiveViewport(l)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(t==null?void 0:t.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{column:u}=Ze(l.offsetX,l.offsetY,s,d);Tl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(i.zIndex||1)+1,a.RANGE_TYPE.COLUMN,this._getActiveViewport(l)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(r==null?void 0:r.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;this._reset();const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,u=or(d);this._addSelectionControlByModelData(u),this.refreshSelectionMoveStart(),c.stopPropagation(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}))}_initSpreadsheetEvent(o){const{spreadsheet:e}=o;let t;const i=500,r={x:0,y:0},s=()=>{clearTimeout(t)},l=(u,h)=>{this.createNewSelection(u,e.zIndex+1,a.RANGE_TYPE.NORMAL,this._getActiveViewport(u)),h&&this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())};e==null||e.onPointerMove$.subscribeEvent((u,h)=>{(Math.abs(u.offsetX-r.x)>10||Math.abs(u.offsetY-r.y)>10)&&s()});const c=e==null?void 0:e.onPointerDown$.subscribeEvent((u,h)=>{r.x=u.offsetX,r.y=u.offsetY,t=setTimeout(()=>{l(u,!0)},i),h.stopPropagation()}),d=e==null?void 0:e.onPointerUp$.subscribeEvent((u,h)=>{if(this._normalSelectionDisabled())return;clearTimeout(t);const S=10;Math.abs(u.offsetX-r.x)>S||Math.abs(u.offsetY-r.y)>S||(l(u,!1),h.stopPropagation())});this.disposeWithMe(a.toDisposable(c)),this.disposeWithMe(a.toDisposable(d))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(o=>this._updateSelections(o,m.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(o=>this._updateSelections(o,m.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(m.REF_SELECTIONS_ENABLED).pipe(D.startWith(!1),D.distinctUntilChanged()).subscribe(o=>{var e;o?((e=this._renderDisposable)==null||e.dispose(),this._renderDisposable=null,this._reset()):this._renderDisposable=a.toDisposable(this.selectionMoveEnd$.subscribe(t=>this._updateSelections(t,m.SelectionMoveType.MOVE_END)))}))}_updateSelections(o,e){const t=this._context.unit,i=t.getUnitId(),r=t.getActiveSheet().getSheetId();o.length!==0&&this._commandService.executeCommand(m.SetSelectionsOperation.id,{unitId:i,subUnitId:r,type:e,selections:o.map(s=>m.convertSelectionDataToRange(s))})}createNewSelection(o,e=0,t=a.RANGE_TYPE.NORMAL,i){this._rangeType=t;const r=this._skeleton,s=this._scene;if(!s||!r)return;i&&(this._activeViewport=i);const{offsetX:l,offsetY:c}=o,d=s.getCoordRelativeToViewport(M.Vector2.FromArray([l,c])),{x:u,y:h}=d;this._startViewportPosX=u,this._startViewportPosY=h;const S=s.getScrollXYInfoByViewport(d),{scaleX:g,scaleY:f}=s.getAncestorScale(),p=this._skeleton.getCellByOffset(u,h,g,f,S);if(!p)return;switch(t){case a.RANGE_TYPE.NORMAL:break;case a.RANGE_TYPE.ROW:p.startColumn=0,p.endColumn=this._skeleton.getColumnCount()-1;break;case a.RANGE_TYPE.COLUMN:p.startRow=0,p.endRow=this._skeleton.getRowCount()-1;break;case a.RANGE_TYPE.ALL:p.startRow=0,p.startColumn=0,p.endRow=this._skeleton.getRowCount()-1,p.endColumn=this._skeleton.getColumnCount()-1}const v={range:p,primary:p,style:null};v.range.rangeType=t;const C=Re(v,this._skeleton);this._startRangeWhenPointerDown={...C.rangeWithCoord};let b=this.getActiveSelectionControl();const E={...C.rangeWithCoord};for(const w of this.getSelectionControls())if(w.model.isEqual(E)){b=w;break}(b==null?void 0:b.model.rangeType)!==t?(this._clearAllSelectionControls(),b=this.newSelectionControl(s,r,v)):b.updateRangeBySelectionWithCoord(C),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._expandingSelection=!1}newSelectionControl(o,e,t){const i=this.getSelectionControls(),{rowHeaderWidth:r,columnHeaderHeight:s}=e,l=t.range.rangeType,c=new pp(o,i.length,this._themeService,{highlightHeader:this._highlightHeader,rowHeaderWidth:r,columnHeaderHeight:s,rangeType:l}),d=Re(t,e);c.updateRangeBySelectionWithCoord(d),this._selectionControls.push(c);const{expandingModeForTopLeft:u,expandingModeForBottomRight:h}=(()=>{switch(l){case a.RANGE_TYPE.NORMAL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};case a.RANGE_TYPE.ROW:return{expandingModeForTopLeft:"top",expandingModeForBottomRight:"bottom"};case a.RANGE_TYPE.COLUMN:return{expandingModeForTopLeft:"left",expandingModeForBottomRight:"right"};case a.RANGE_TYPE.ALL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};default:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"}}})();return c.fillControlTopLeft.onPointerDown$.subscribeEvent(S=>{this._expandingSelection=!0,this.expandingControlMode=u,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(S,l,this._activeViewport)}),c.fillControlBottomRight.onPointerDown$.subscribeEvent(S=>{this._expandingSelection=!0,this.expandingControlMode=h,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(S,l,this._activeViewport)}),(l===a.RANGE_TYPE.ROW||l===a.RANGE_TYPE.COLUMN)&&!o.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),c}_getActiveViewport(o){const e=this._getSheetObject();return e==null?void 0:e.scene.getActiveViewportByCoord(M.Vector2.FromArray([o.offsetX,o.offsetY]))}_getSheetObject(){return ze(this._context.unit,this._context)}_normalSelectionDisabled(){return this._contextService.getContextValue(m.REF_SELECTIONS_ENABLED)}getSelectionControls(){return this._selectionControls}_fillControlPointerDownHandler(o,e=a.RANGE_TYPE.NORMAL,t,i=M.ScrollTimerType.ALL){var h,S,g;const r=this._skeleton,s=this._scene;if(!s||!r)return;t&&(this._activeViewport=t);const l=s.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=this.getActiveSelectionControl();if(!c)return;this._changeCurrCellWhenControlPointerDown(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._addEndingListeners(),this._scrollTimer=M.ScrollTimer.create(this._scene,i),this._scrollTimer.startScroll((h=l==null?void 0:l.left)!=null?h:0,(S=l==null?void 0:l.top)!=null?S:0,l),(g=s.getTransformer())==null||g.clearSelectedObjects();const d=s.getCoordRelativeToViewport(M.Vector2.FromArray([o.offsetX,o.offsetY]));this._setupPointerMoveListener(l,c,e,i,d.x,d.y);const u=this._shortcutService.forceEscape();this._scenePointerUpSub=s.onPointerUp$.subscribeEvent(f=>{this.endSelection(),this._expandingSelection=!1,this.expandingControlMode="bottom-right",this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),u.dispose()})}_changeCurrCellWhenControlPointerDown(){const o=this.getActiveSelectionControl(),e=this._skeleton;let t;const{startRow:i,startColumn:r,endRow:s,endColumn:l}=o.model;switch(this.expandingControlMode){case"top-left":t=e.getCellWithCoordByIndex(s,l);break;case"bottom-right":t=e.getCellWithCoordByIndex(i,r);break;case"left":t=e.getCellWithCoordByIndex(i,l),t.isMerged=!1,t.isMergedMainCell=!1;break;case"right":t=e.getCellWithCoordByIndex(i,r),t.isMerged=!1,t.isMergedMainCell=!1;break;case"top":t=e.getCellWithCoordByIndex(s,r),t.isMerged=!1,t.isMergedMainCell=!1;break;case"bottom":t=e.getCellWithCoordByIndex(i,r),t.isMerged=!1,t.isMergedMainCell=!1;break;default:t=e.getCellWithCoordByIndex(i,r)}return o.updateCurrCell(t),t}_movingHandler(o,e,t,i){var A,k,N,H,V,U,W,B,x,X,F,Y,z;this._rangeType=i;const r=this._skeleton,s=this._scene,l={startRow:t.model.startRow,endRow:t.model.endRow,startColumn:t.model.startColumn,endColumn:t.model.endColumn},c=s.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),d=(A=this._getViewportByCell(l.endRow,l.endColumn))!=null?A:c,u=s.getScrollXYInfoByViewport(M.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),d),{scaleX:h,scaleY:S}=s.getAncestorScale();i===a.RANGE_TYPE.ROW?o=Number.POSITIVE_INFINITY:i===a.RANGE_TYPE.COLUMN&&(e=Number.POSITIVE_INFINITY);const g=this._getSelectionWithCoordByOffset(o,e,h,S,u);if(!g)return!1;const{rangeWithCoord:f}=g,p=t.model.currentCell,v=(k=p==null?void 0:p.mergeInfo.startRow)!=null?k:-1,C=(N=p==null?void 0:p.mergeInfo.endRow)!=null?N:-1,b=(H=p==null?void 0:p.mergeInfo.startColumn)!=null?H:-1,E=(V=p==null?void 0:p.mergeInfo.endColumn)!=null?V:-1;let w={startRow:Math.min(f.startRow,v),startColumn:Math.min(f.startColumn,b),endRow:Math.max(f.endRow,C),endColumn:Math.max(f.endColumn,E)};if(i===a.RANGE_TYPE.NORMAL?w=r.expandRangeByMerge(w):i===a.RANGE_TYPE.COLUMN?w={startRow:Math.min(f.startRow,(U=p==null?void 0:p.actualRow)!=null?U:-1),startColumn:Math.min(f.startColumn,(W=p==null?void 0:p.actualColumn)!=null?W:-1),endRow:Math.max(f.endRow,(B=p==null?void 0:p.actualRow)!=null?B:-1),endColumn:Math.max(f.endColumn,(x=p==null?void 0:p.actualColumn)!=null?x:-1)}:i===a.RANGE_TYPE.ROW&&(w={startRow:Math.min(f.startRow,(X=p==null?void 0:p.actualRow)!=null?X:-1),startColumn:Math.min(f.startColumn,(F=p==null?void 0:p.actualColumn)!=null?F:-1),endRow:Math.max(f.endRow,(Y=p==null?void 0:p.actualRow)!=null?Y:-1),endColumn:Math.max(f.endColumn,(z=p==null?void 0:p.actualColumn)!=null?z:-1)}),!w)return!1;const R=Re({range:w,style:null,primary:null},r);(l.startRow!==w.startRow||l.startColumn!==w.startColumn||l.endRow!==w.endRow||l.endColumn!==w.endColumn)&&t&&(t.updateRangeBySelectionWithCoord(R),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateControlPointWhenScrolling(){const{scene:o}=this._context;if(!o.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN))return;const t=this._scrollManagerService.validViewportScrollInfo$.subscribe(i=>{var S;if(i==null)return;const{viewportScrollX:r,viewportScrollY:s}=i,l=this.getActiveSelectionControl();if(l==null)return;const c=(S=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:S.skeleton,d=c==null?void 0:c.rowTotalHeight,u=c==null?void 0:c.columnTotalWidth,h=l.rangeType;h===a.RANGE_TYPE.COLUMN?l.transformControlPoint(0,s,u,d):h===a.RANGE_TYPE.ROW&&l.transformControlPoint(r,0,u,d)});this.disposeWithMe(a.toDisposable(t))}};Bo=Cp([ut(1,a.Inject(a.Injector)),ut(2,a.Inject(a.ThemeService)),ut(3,I.IShortcutService),ut(4,a.Inject(m.SheetsSelectionsService)),ut(5,a.Inject(y.SheetSkeletonManagerService)),ut(6,a.ILogService),ut(7,a.ICommandService),ut(8,a.IContextService),ut(9,a.Inject(y.SheetScrollManagerService))],Bo);var Ip=Object.defineProperty,_p=Object.getOwnPropertyDescriptor,bp=(n,o,e)=>o in n?Ip(n,o,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[o]=e,Ep=(n,o,e,t)=>{for(var i=t>1?void 0:t?_p(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ns=(n,o)=>(e,t)=>o(e,t,n),cd=(n,o,e)=>bp(n,typeof o!="symbol"?o+"":o,e);y.UniverSheetsMobileUIPlugin=class extends a.Plugin{constructor(o=sr,e,t,i){super(),this._config=o,this._injector=e,this._renderManagerService=t,this._univerInstanceService=i}onStarting(){[[hn],[Be,{useClass:y.SheetClipboardService}],[Vt,{useClass:Ma}],[Qe,{useClass:ho}],[vt,{useClass:y.AutoFillService}],[ks],[ve,{useClass:Bo}],[ii,{useClass:yr}],[Ut,{useClass:y.MarkSelectionService}],[Se,{useClass:y.EditorBridgeService}],[y.HoverManagerService],[y.DragManagerService],[y.SheetCanvasPopManagerService],[y.CellAlertManagerService],[mr],[Ds,{useClass:y.SheetCellDropdownManagerService}],[ki],[y.AutoHeightController],[Ln],[y.SheetsRenderService],[Ao],[y.StatusBarController],[m.IRefSelectionsService,{useClass:m.RefSelectionsService}],[kn],[Et],[Wo],[Hi],[y.SheetPermissionCheckUIController],[Wi]].forEach(o=>this._injector.add(o))}onReady(){this._markSheetAsFocused(),this._registerRenderBasics(),this._injector.get(Ao)}onRendered(){this._registerRenderModules()}_registerRenderBasics(){[[y.SheetSkeletonManagerService],[y.SheetRenderController],[ve,{useClass:Bo}],[y.SheetScrollManagerService]].forEach(o=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,o))})}_registerRenderModules(){[[y.HeaderMoveRenderController],[y.HeaderFreezeRenderController],[As],[qn],[Lo],[To],[Mo],[Po],[y.HoverRenderController],[y.DragRenderController],[Ro],[y.CellCustomRenderController],[Os],[Do],[No],[Vo]].forEach(o=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,o))})}_markSheetAsFocused(){const o=this._univerInstanceService;this.disposeWithMe(o.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).pipe(me.filter(e=>!!e)).subscribe(e=>{this._univerInstanceService.getFocusedUnit()!==e&&o.focusUnit(e.getUnitId())}))}},cd(y.UniverSheetsMobileUIPlugin,"pluginName","SHEET_UI_PLUGIN"),cd(y.UniverSheetsMobileUIPlugin,"type",a.UniverInstanceType.UNIVER_SHEET),y.UniverSheetsMobileUIPlugin=Ep([a.DependentOn(m.UniverSheetsPlugin,I.UniverMobileUIPlugin),Ns(1,a.Inject(a.Injector)),Ns(2,M.IRenderManagerService),Ns(3,a.IUniverInstanceService)],y.UniverSheetsMobileUIPlugin);var wp=Object.getOwnPropertyDescriptor,Tp=(n,o,e,t)=>{for(var i=t>1?void 0:t?wp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},xo=(n,o)=>(e,t)=>o(e,t,n);let Fo=class extends a.Disposable{constructor(o,e,t,i){super();T(this,"_isPointer",!1);this._hoverManagerService=o,this._instanceService=e,this._commandService=t,this._renderManagerService=i,this._initPointerEvent(),this._initHover()}get _mainComponent(){var o;return(o=M.getCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,this._instanceService,this._renderManagerService))==null?void 0:o.mainComponent}_initHover(){this.disposeWithMe(this._hoverManagerService.currentRichText$.subscribe(o=>{var e,t;o!=null&&o.bullet?(this._isPointer||(e=this._mainComponent)==null||e.setCursor(M.CURSOR_TYPE.POINTER),this._isPointer=!0):(this._isPointer&&((t=this._mainComponent)==null||t.setCursor(M.CURSOR_TYPE.AUTO)),this._isPointer=!1)}))}_initPointerEvent(){this.disposeWithMe(this._hoverManagerService.currentClickedCell$.subscribe(o=>{const{location:e,bullet:t}=o;t&&this._commandService.executeCommand(m.ToggleCellCheckboxCommand.id,{unitId:e.unitId,subUnitId:e.subUnitId,row:e.row,col:e.col,paragraphIndex:t.startIndex})}))}};Fo=Tp([xo(0,a.Inject(y.HoverManagerService)),xo(1,a.IUniverInstanceService),xo(2,a.ICommandService),xo(3,M.IRenderManagerService)],Fo);var yp=Object.getOwnPropertyDescriptor,Mp=(n,o,e,t)=>{for(var i=t>1?void 0:t?yp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ui=(n,o)=>(e,t)=>o(e,t,n);let zo=class extends a.Disposable{constructor(n,o,e,t,i){super(),this._selectionManagerService=n,this._themeService=o,this._instanceSrv=e,this._cmdSrv=t,this._definedNamesService=i,this._init()}_init(){this.disposeWithMe(D.merge(this._selectionManagerService.selectionMoveStart$,this._selectionManagerService.selectionMoving$,this._selectionManagerService.selectionMoveEnd$,this._selectionManagerService.selectionSet$).pipe(D.filter(n=>!!n)).subscribe(n=>{this._syncDefinedNameRange(n)})),this.disposeWithMe(this._definedNamesService.focusRange$.subscribe(async n=>{if(n==null)return;const{unitId:o}=n;let{formulaOrRefString:e}=n;if(e.substring(0,1)===q.operatorToken.EQUALS&&(e=e.substring(1)),!q.isReferenceStrings(e))return;const i=this._instanceSrv.getUnit(o),r=await this._getSelections(i,o,e);this._selectionManagerService.setSelections(r),this._cmdSrv.executeCommand(m.ScrollToCellOperation.id,{unitId:o,range:r[0].range})}))}_syncDefinedNameRange(n){if(n.length===0)return;const o=n[n.length-1],e=this._instanceSrv.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),t=e==null?void 0:e.getActiveSheet();t&&this._definedNamesService.setCurrentRange({range:o.range,unitId:e.getUnitId(),sheetId:t.getSheetId()})}async _getSelections(n,o,e){const t=e.split(",");let i=n.getActiveSheet();if(!i)return[];const r=[];for(let s=0;s<t.length;s++){const l=t[s].trim(),c=q.deserializeRangeWithSheet(l.trim());if(s===0){const u=n.getSheetBySheetName(c.sheetName);u&&i.getSheetId()!==u.getSheetId()&&(i=u,await this._cmdSrv.executeCommand(m.SetWorksheetActivateCommand.id,{subUnitId:i.getSheetId(),unitId:o}))}if(i.getName()!==c.sheetName)continue;let d=null;if(s===t.length-1){const u=c.range,{startRow:h,startColumn:S,endRow:g,endColumn:f}=u;d=m.getPrimaryForRange({startRow:h,startColumn:S,endRow:g,endColumn:f},i)}r.push({range:c.range,style:gt(this._themeService),primary:d})}return r}};zo=Mp([Ui(0,a.Inject(m.SheetsSelectionsService)),Ui(1,a.Inject(a.ThemeService)),Ui(2,a.IUniverInstanceService),Ui(3,a.ICommandService),Ui(4,q.IDefinedNamesService)],zo);var Rp=Object.getOwnPropertyDescriptor,Pp=(n,o,e,t)=>{for(var i=t>1?void 0:t?Rp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ht=(n,o)=>(e,t)=>o(e,t,n);y.FormulaEditorController=class extends a.RxDisposable{constructor(e,t,i,r,s,l,c,d,u){super();T(this,"_loadedMap",new WeakSet);T(this,"_scheduledCallback",-1);this._univerInstanceService=e,this._renderManagerService=t,this._editorBridgeService=i,this._commandService=r,this._contextService=s,this._formulaEditorManagerService=l,this._undoRedoService=c,this._textSelectionManagerService=d,this._editorService=u,this._initialize()}_initialize(){this._syncEditorSize(),this._listenFxBtnClick(),this._handleContentChange(),this._univerInstanceService.focused$.pipe(D.takeUntil(this.dispose$)).subscribe(e=>{this._create(e)}),this._create(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),this.disposeWithMe(this._editorService.focus$.subscribe(()=>{var t;((t=this._editorService.getFocusEditor())==null?void 0:t.getEditorId())!==a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY?this._contextService.setContextValue(a.FOCUSING_FX_BAR_EDITOR,!1):this._contextService.setContextValue(a.FOCUSING_FX_BAR_EDITOR,!0)}))}_handleContentChange(){this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===_e.RichTextEditingMutation.id){const t=e.params,{unitId:i}=t;i===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&this.autoScroll()}}))}_create(e){if(e!==a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)return;const t=this._renderManagerService.getRenderById(e);if(t==null)return;const{mainComponent:i}=t;i!=null&&(this._loadedMap.has(i)||this._loadedMap.add(i))}_listenFxBtnClick(){this._formulaEditorManagerService.fxBtnClick$.pipe(D.takeUntil(this.dispose$)).subscribe(()=>{var t,i;if(this._contextService.getContextValue(a.FOCUSING_EDITOR_BUT_HIDDEN)&&!this._contextService.getContextValue(a.EDITOR_ACTIVATED)){this._univerInstanceService.setCurrentUnitForType(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),this._contextService.setContextValue(a.FOCUSING_FX_BAR_EDITOR,!0);const r=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),s=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);this._editorBridgeService.isVisible().visible===!1&&this._commandService.syncExecuteCommand(ge.id,{visible:!0,eventType:M.DeviceInputEventType.PointerDown,unitId:(t=r==null?void 0:r.getUnitId())!=null?t:""});const c=(i=s==null?void 0:s.getBody())==null?void 0:i.dataStream;if(c==null)return;let d=c.startsWith("=")?c:`=${c}`;d=d.replace(/\r\n$/,"");const u=[{startOffset:d.length,endOffset:d.length}],h={unitId:a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,body:{dataStream:d},segmentId:""};this._commandService.executeCommand(Q.CoverContentCommand.id,h),this._textSelectionManagerService.replaceDocRanges(u)}})}_syncEditorSize(){const e=this._univerInstanceService.unitAdded$.pipe(D.filter(t=>t.getUnitId()===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY));this.disposeWithMe(D.combineLatest([this._formulaEditorManagerService.position$,e]).subscribe(([t])=>{if(!t)return this._clearScheduledCallback();const i=zi(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,this._renderManagerService),r=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(i==null||r==null)return this._clearScheduledCallback();const{width:s,height:l}=t;if(s===0||l===0)return this._clearScheduledCallback();const{engine:c}=i;r.updateDocumentDataPageSize(s),this.autoScroll(),this._scheduledCallback=requestIdleCallback(()=>c.resizeBySize(s,l))}))}_clearScheduledCallback(){this._scheduledCallback!==-1&&cancelIdleCallback(this._scheduledCallback),this._scheduledCallback=-1}autoScroll(){var p,v;const e=this._formulaEditorManagerService.getPosition(),t=(p=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY))==null?void 0:p.with(_e.DocSkeletonManagerService).getSkeleton(),i=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),r=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(t==null||e==null||i==null||r==null)return;const{marginTop:s=0,marginBottom:l=0}=r.getSnapshot().documentStyle,{scene:c,mainComponent:d}=i;let{actualHeight:u}=t.getActualSize();u+=s+l;const{width:h,height:S}=e,g=c.getViewport(Q.VIEWPORT_KEY.VIEW_MAIN);let f=g==null?void 0:g.getScrollBar();c.transformByState({width:h,height:u}),d==null||d.resize(h,u),u>S?f==null?g&&new M.ScrollBar(g,{enableHorizontal:!1,barSize:8}):g==null||g.resetCanvasSizeAndUpdateScroll():(f=null,g==null||g.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0}),(v=g==null?void 0:g.getScrollBar())==null||v.dispose())}},y.FormulaEditorController=Pp([ht(0,a.IUniverInstanceService),ht(1,M.IRenderManagerService),ht(2,Se),ht(3,a.ICommandService),ht(4,a.IContextService),ht(5,ti),ht(6,a.IUndoRedoService),ht(7,a.Inject(_e.DocSelectionManagerService)),ht(8,Q.IEditorService)],y.FormulaEditorController);var Op=Object.getOwnPropertyDescriptor,Ap=(n,o,e,t)=>{for(var i=t>1?void 0:t?Op(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},yt=(n,o)=>(e,t)=>o(e,t,n);const Dp={pageSize:{width:Number.POSITIVE_INFINITY,height:Number.POSITIVE_INFINITY},documentFlavor:a.DocumentFlavor.UNSPECIFIED,marginTop:5,marginBottom:5,marginRight:0,marginLeft:0,paragraphLineGapDefault:0,renderConfig:{horizontalAlign:a.HorizontalAlign.UNSPECIFIED,verticalAlign:a.VerticalAlign.TOP,centerAngle:0,vertexAngle:0,wrapStrategy:a.WrapStrategy.WRAP,isRenderStyle:a.BooleanNumber.FALSE}};let Xo=class extends a.Disposable{constructor(n,o,e,t,i,r,s,l){super(),this._univerInstanceService=n,this._renderManagerService=o,this._editorBridgeService=e,this._commandService=t,this._rangeProtectionRuleModel=i,this._worksheetProtectionRuleModel=r,this._formulaEditorController=s,this._formulaEditorManagerService=l,this._initialize()}_initialize(){this._syncFormulaEditorContent(),this._commandExecutedListener()}_getEditorViewModel(n){var o;return(o=this._renderManagerService.getRenderById(n))==null?void 0:o.with(_e.DocSkeletonManagerService).getViewModel()}_syncFormulaEditorContent(){this.disposeWithMe(this._editorBridgeService.currentEditCellState$.subscribe(n=>{n==null||this._editorBridgeService.isForceKeepVisible()||!this._rangeProtectionRuleModel.getRangeRuleInitState()||!this._worksheetProtectionRuleModel.getSheetRuleInitState()||this._editorSyncHandler(n)}))}_editorSyncHandler(n){var i,r,s;let o=a.Tools.deepClone((i=n.documentLayoutObject.documentModel)==null?void 0:i.getBody());const e=a.Tools.deepClone((r=n.documentLayoutObject.documentModel)==null?void 0:r.drawings),t=a.Tools.deepClone((s=n.documentLayoutObject.documentModel)==null?void 0:s.getDrawingsOrder());(!o||n.isInArrayFormulaRange===!0&&this._editorBridgeService.isVisible().eventType===M.DeviceInputEventType.Dblclick)&&(o={dataStream:`\r
83
83
  `,paragraphs:[{startIndex:0}],textRuns:[]}),this._syncContentAndRender(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,o,e,t)}_commandExecutedListener(){const n=[a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY];this.disposeWithMe(this._commandService.onCommandExecuted(e=>{if(e.id===_e.RichTextEditingMutation.id){const t=e.params,{unitId:i,trigger:r,isSync:s}=t;if(s||r===Q.ReplaceSnapshotCommand.id)return;if(n.includes(i)){const l=this._univerInstanceService.getUnit(i,a.UniverInstanceType.UNIVER_DOC),c=i===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY?a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY:a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY;this._checkAndSetRenderStyleConfig(l),this._syncActionsAndRender(c,t)}}}));const o=[m.SetRangeValuesMutation.id,m.MoveRangeMutation.id];this.disposeWithMe(this._commandService.onCommandExecuted(e=>{var t,i,r,s,l,c,d;if(o.includes(e.id)){const u=this._editorBridgeService.getLatestEditCellState();if(u==null)return;let h=!1;const{row:S,column:g}=u;if(e.id===m.SetRangeValuesMutation.id&&e.params?(i=(t=e.params.cellValue)==null?void 0:t[S])!=null&&i[g]&&(h=!0):e.id===m.MoveRangeMutation.id&&e.params&&(s=(r=e.params.to.value)==null?void 0:r[S])!=null&&s[g]&&(h=!0),h){const f=a.Tools.deepClone((l=u.documentLayoutObject.documentModel)==null?void 0:l.getBody()),p=a.Tools.deepClone((c=u.documentLayoutObject.documentModel)==null?void 0:c.drawings),v=a.Tools.deepClone((d=u.documentLayoutObject.documentModel)==null?void 0:d.getDrawingsOrder());if(f==null)return;this._syncContentAndRender(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,f,p,v)}}}))}_syncActionsAndRender(n,o){var l;const e=[a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY],t=this._renderManagerService.getRenderById(n);if(t==null)return;const i=t.with(_e.DocSkeletonManagerService).getSkeleton(),r=this._univerInstanceService.getUnit(n,a.UniverInstanceType.UNIVER_DOC),s=this._getEditorViewModel(n);r==null||s==null||(this._commandService.syncExecuteCommand(_e.RichTextEditingMutation.id,{...o,textRanges:null,isSync:!0,unitId:n,syncer:o.unitId}),s.reset(r),i.calculate(),e.includes(n)&&((l=t.mainComponent)==null||l.makeDirty()))}_syncContentAndRender(n,o,e,t){var d,u;n===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&o.paragraphs&&(o.paragraphs=this._clearParagraph(o.paragraphs));const i=[a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY],r=(d=this._renderManagerService.getRenderById(n))==null?void 0:d.with(_e.DocSkeletonManagerService).getSkeleton(),s=this._univerInstanceService.getUnit(n,a.UniverInstanceType.UNIVER_DOC),l=this._getEditorViewModel(n);if(s==null||l==null||r==null)return;s.getSnapshot().body=o,s.getSnapshot().drawings=e!=null?e:{},s.getSnapshot().drawingsOrder=t!=null?t:[],this._checkAndSetRenderStyleConfig(s),l.reset(s);const c=this._renderManagerService.getRenderById(n);c!=null&&(r.calculate(),i.includes(n)&&((u=c.mainComponent)==null||u.makeDirty()),n===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&this._formulaEditorController.autoScroll())}_checkAndSetRenderStyleConfig(n){var r;const o=n.getSnapshot(),{body:e}=o;if(o.id!==a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)return;o.documentStyle=Dp;let t=o.documentStyle.renderConfig;t==null&&(t={},o.documentStyle.renderConfig=t);const i=this._formulaEditorManagerService.getPosition();if(i){const s=i.width;o.documentStyle.pageSize={width:s,height:1/0}}((r=e==null?void 0:e.dataStream)!=null?r:"").startsWith("=")?t.isRenderStyle=a.BooleanNumber.TRUE:t.isRenderStyle=a.BooleanNumber.FALSE}_clearParagraph(n){const o=a.Tools.deepClone(n);for(const e of o)e.paragraphStyle&&(e.paragraphStyle.horizontalAlign=a.HorizontalAlign.UNSPECIFIED);return o}};Xo=Ap([yt(0,a.IUniverInstanceService),yt(1,M.IRenderManagerService),yt(2,Se),yt(3,a.ICommandService),yt(4,a.Inject(m.RangeProtectionRuleModel)),yt(5,a.Inject(m.WorksheetProtectionRuleModel)),yt(6,a.Inject(y.FormulaEditorController)),yt(7,ti)],Xo);var kp=Object.getOwnPropertyDescriptor,Np=(n,o,e,t)=>{for(var i=t>1?void 0:t?kp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},nn=(n,o)=>(e,t)=>o(e,t,n);let Yo=class extends a.Disposable{constructor(n,o,e,t,i,r,s){super(),this._commandService=n,this._formatPainterService=o,this._univerInstanceService=e,this._renderManagerService=t,this._selectionManagerService=i,this._sheetInterceptorService=r,this._injector=s,this._initialize()}_initialize(){this._addDefaultHook()}_addDefaultHook(){const n={id:"default-format-painter",priority:0,isDefaultHook:!0,onStatusChange:o=>{if(o!==Ne.OFF){const e=this._collectSelectionRangeFormat();e&&this._formatPainterService.setSelectionFormat(e)}},onApply:(o,e,t,i)=>this._getUndoRedoMutationInfo(o,e,t,i)};this._formatPainterService.addHook(n)}_collectSelectionRangeFormat(){const n=this._selectionManagerService.getCurrentLastSelection(),o=n==null?void 0:n.range;if(!o)return null;const{startRow:e,endRow:t,startColumn:i,endColumn:r}=o,s=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),l=s==null?void 0:s.getActiveSheet();if(!l)return null;const c=l.getCellMatrix(),d=s.getStyles(),u=new a.ObjectMatrix,h=[];for(let S=e;S<=t;S++)for(let g=i;g<=r;g++){const f=c.getValue(S,g);u.setValue(S,g,d.getStyleByCell(f)||{});const{isMergedMainCell:p,...v}=l.getCellInfoInMergeData(S,g);p&&h.push({startRow:v.startRow,startColumn:v.startColumn,endRow:v.endRow,endColumn:v.endColumn})}return{styles:u,merges:h}}_getUndoRedoMutationInfo(n,o,e,t){const i=this._sheetInterceptorService,r=this._univerInstanceService,{merges:s,styles:l}=t;if(!l)return{undos:[],redos:[]};const{startRow:c,startColumn:d,endRow:u,endColumn:h}=l.getDataRange(),S=u-c+1,g=h-d+1,f=e.startRow===e.endRow&&e.startColumn===e.endColumn?{startRow:e.startRow,startColumn:e.startColumn,endRow:e.startRow+S-1,endColumn:e.startColumn+g-1}:e,p=Array.from({length:f.endRow-f.startRow+1},()=>Array.from({length:f.endColumn-f.startColumn+1},()=>({}))),v=[];p.forEach((F,Y)=>{F.forEach((z,K)=>{const ee=Y%S+c,$=K%g+d,ae=l.getValue(ee,$);ae&&(p[Y][K].s=Object.keys(ae).length>0?ae:null)})}),s.forEach(F=>{const Y={startRow:F.startRow-c,startColumn:F.startColumn-d,endRow:F.endRow-c,endColumn:F.endColumn-d},z=Math.max(1,Math.floor((f.endRow-f.startRow+1)/S)),K=Math.max(1,Math.floor((f.endColumn-f.startColumn+1)/g));for(let ee=0;ee<z;ee++)for(let $=0;$<K;$++)v.push({startRow:Y.startRow+ee*S+f.startRow,startColumn:Y.startColumn+$*g+f.startColumn,endRow:Y.endRow+ee*S+f.startRow,endColumn:Y.endColumn+$*g+f.startColumn})});const C=[f],b=new a.ObjectMatrix,E=new a.ObjectMatrix;if(a.Tools.isArray(p))for(let F=0;F<C.length;F++){const{startRow:Y,startColumn:z,endRow:K,endColumn:ee}=C[F];for(let $=0;$<=K-Y;$++)for(let ae=0;ae<=ee-z;ae++)b.setValue($+Y,ae+z,{s:null}),E.setValue($+Y,ae+z,p[$][ae])}const w={subUnitId:o,unitId:n,cellValue:b.getMatrix()},O={subUnitId:o,unitId:n,cellValue:E.getMatrix()},R=this._injector.invoke(m.SetRangeValuesUndoMutationFactory,w),{undos:P,redos:A}=i.onCommandExecute({id:m.SetRangeValuesCommand.id,params:{...O,range:C}}),k=m.getAddMergeMutationRangeByType(v),N=[],H=[],V=r.getUnit(n).getSheetBySheetId(o),U=Pl(V,k),W={unitId:n,subUnitId:o,ranges:k},B={unitId:n,subUnitId:o,ranges:k};N.push({id:m.RemoveWorksheetMergeMutation.id,params:W}),N.push({id:m.AddWorksheetMergeMutation.id,params:B});const x=this._injector.invoke(m.RemoveMergeUndoMutationFactory,W),X=this._injector.invoke(m.AddMergeUndoMutationFactory,B);if(H.push({id:m.RemoveWorksheetMergeMutation.id,params:X}),H.push({id:m.AddWorksheetMergeMutation.id,params:x}),U){const F=this._injector.invoke(Y=>Ol(Y,n,V,k));N.unshift(...F.redos),H.push(...F.undos)}return{undos:[{id:m.SetRangeValuesMutation.id,params:w},{id:m.SetRangeValuesMutation.id,params:R},...P,...H],redos:[{id:m.SetRangeValuesMutation.id,params:w},{id:m.SetRangeValuesMutation.id,params:O},...A,...N]}}};Yo=Np([nn(0,a.ICommandService),nn(1,Qe),nn(2,a.IUniverInstanceService),nn(3,M.IRenderManagerService),nn(4,a.Inject(m.SheetsSelectionsService)),nn(5,a.Inject(m.SheetInterceptorService)),nn(6,a.Inject(a.Injector))],Yo);var Hp=Object.getOwnPropertyDescriptor,Vp=(n,o,e,t)=>{for(var i=t>1?void 0:t?Hp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Hs=(n,o)=>(e,t)=>o(e,t,n);let Vs=class extends a.Disposable{constructor(o,e,t,i){super();T(this,"_initialize",()=>{const o=new a.DisposableCollection;this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(()=>{o.dispose(),this._selectionRenderService.getSelectionControls().forEach(t=>{o.add(a.toDisposable(t.selectionMoveEnd$.subscribe(i=>{if(!i)return;const r=t.model.getRange(),s={startRow:r.startRow,startColumn:r.startColumn,endRow:r.endRow,endColumn:r.endColumn,rangeType:r.rangeType},l={startRow:i.startRow,startColumn:i.startColumn,endRow:i.endRow,endColumn:i.endColumn,rangeType:r.rangeType};if(s.startRow===l.startRow&&s.startColumn===l.startColumn||l.startRow<0||l.startColumn<0)return;const c={fromRange:s,toRange:l};this._commandService.executeCommand(m.MoveRangeCommand.id,c)})))})}))});this._context=o,this._selectionRenderService=e,this._selectionManagerService=t,this._commandService=i,this._initialize()}};Vs=Vp([Hs(1,a.Inject(ve)),Hs(2,a.Inject(m.SheetsSelectionsService)),Hs(3,a.Inject(a.ICommandService))],Vs);var Wp=Object.getOwnPropertyDescriptor,Lp=(n,o,e,t)=>{for(var i=t>1?void 0:t?Wp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Up=(n,o)=>(e,t)=>o(e,t,n);let jo=class extends a.Disposable{constructor(n){super(),this._sheetPermissionInitController=n,this._initPermission()}_initPermission(){this._sheetPermissionInitController.initPermission()}};jo=Lp([Up(0,a.Inject(m.SheetPermissionInitController))],jo);var Bp=Object.getOwnPropertyDescriptor,xp=(n,o,e,t)=>{for(var i=t>1?void 0:t?Bp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Ws=(n,o)=>(e,t)=>o(e,t,n);let Ls=class extends a.Disposable{constructor(n,o,e,t){super(),this._context=n,this._sheetSkeletonManagerService=o,this._sheetClipboardService=e,this._sheetClipboardController=t,this._initialize()}_initialize(){this.disposeWithMe(a.toDisposable(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(n=>{if(!(n!=null&&n.unitId)||!this._sheetClipboardService.getPasteMenuVisible())return;const o=this._sheetClipboardService.getPasteOptionsCache(),e=o==null?void 0:o.target.unitId;n.unitId===e&&this._sheetClipboardController.refreshOptionalPaste()})))}};Ls=xp([Ws(1,a.Inject(y.SheetSkeletonManagerService)),Ws(2,Be),Ws(3,a.Inject(Ln))],Ls);var Fp=Object.getOwnPropertyDescriptor,zp=(n,o,e,t)=>{for(var i=t>1?void 0:t?Fp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Us=(n,o)=>(e,t)=>o(e,t,n);let Bs=class extends a.Disposable{constructor(n,o,e,t){super(),this._context=n,this._contextMenuService=o,this._selectionManagerService=e,this._selectionRenderService=t,this._init()}_init(){var l,c;const o=((c=(l=this._context)==null?void 0:l.mainComponent)==null?void 0:c.onPointerDown$).subscribeEvent(d=>{if(d.button===2){const u=this._selectionManagerService.getCurrentSelections(),h=u==null?void 0:u[0];if(!h)return;const S=h.range.rangeType,g=this._selectionRenderService.getSkeleton(),p=Re(h,g).rangeWithCoord,v=()=>{if(!p)return!1;const b=d.offsetX,E=d.offsetY;switch(S){case a.RANGE_TYPE.ROW:return p.startY<=E&&p.endY>=E;case a.RANGE_TYPE.COLUMN:return p.startX<=b&&p.endX>=b;default:return p.startX<=b&&p.endX>=b&&p.startY<=E&&p.endY>=E}},C=b=>{this._contextMenuService.triggerContextMenu(d,b)};v()?S===a.RANGE_TYPE.COLUMN?C(I.ContextMenuPosition.COL_HEADER):S===a.RANGE_TYPE.ROW?C(I.ContextMenuPosition.ROW_HEADER):C(I.ContextMenuPosition.MAIN_AREA):C(I.ContextMenuPosition.MAIN_AREA)}});this.disposeWithMe(o);const e=this._context.components.get(ue.COLUMN),i=this._context.components.get(ue.ROW).onPointerDown$.subscribeEvent(d=>{d.button===2&&this._contextMenuService.triggerContextMenu(d,I.ContextMenuPosition.ROW_HEADER)});this.disposeWithMe(i);const s=e.onPointerDown$.subscribeEvent(d=>{d.button===2&&this._contextMenuService.triggerContextMenu(d,I.ContextMenuPosition.COL_HEADER)});this.disposeWithMe(s)}};Bs=zp([Us(1,I.IContextMenuService),Us(2,a.Inject(m.SheetsSelectionsService)),Us(3,ve)],Bs);var xs=(n=>(n[n.NORMAL=0]="NORMAL",n[n.HIGHLIGHT=1]="HIGHLIGHT",n))(xs||{});const Xp="rgba(0, 0, 0, 0.15)",mt="rgb(0, 0, 0)",Go="rgb(255, 255, 255, 1)";class Yp extends M.Shape{constructor(e,t){super(e,t);T(this,"_size",12);T(this,"_iconRatio",.4);T(this,"_mode",0);this.setShapeProps(t)}setShapeProps(e){e!=null&&e.size&&(this._size=e.size),e!=null&&e.mode&&(this._mode=e.mode),this.transformByState({width:this._size,height:this._size})}_draw(e){this._mode===1&&M.Rect.drawWith(e,{width:this._size,height:this._size,radius:this._size,fill:Xp});const t=this._size*.5*this._iconRatio,i=Math.PI/180*60,r=t*Math.sin(i),s=t*Math.cos(i);M.RegularPolygon.drawWith(e,{pointsGroup:[[{x:-r+this._size/2,y:-s+this._size/2},{x:r+this._size/2,y:-s+this._size/2},{x:this._size/2,y:t+this._size/2}]],fill:mt})}}var jp=Object.getOwnPropertyDescriptor,Gp=(n,o,e,t)=>{for(var i=t>1?void 0:t?jp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Zo=(n,o)=>(e,t)=>o(e,t,n);const Zp="__SpreadsheetHeaderMenuSHAPEControllerShape__",Kp="__SpreadsheetHeaderMenuMAINControllerShape__",qp="rgba(0, 0, 0, 0.1)";let Fs=class extends a.Disposable{constructor(o,e,t,i,r){super();T(this,"_hoverRect");T(this,"_hoverMenu");T(this,"_currentColumn",Number.POSITIVE_INFINITY);T(this,"_headerPointerSubs");T(this,"_colHeaderPointerSubs");this._context=o,this._sheetSkeletonManagerService=e,this._contextMenuService=t,this._commandService=i,this._selectionManagerService=r,this._initialize()}dispose(){var o,e,t;(o=this._hoverRect)==null||o.dispose(),(e=this._hoverMenu)==null||e.dispose(),(t=this._headerPointerSubs)==null||t.unsubscribe(),this._headerPointerSubs=null}_initialize(){const o=this._context.scene;this._hoverRect=new M.Rect(Zp,{fill:qp,evented:!1}),this._hoverMenu=new Yp(Kp,{zIndex:100,visible:!1}),o.addObjects([this._hoverRect,this._hoverMenu],St),this._initialHover(0),this._initialHover(1),this._initialHoverMenu()}_initialHover(o=0){var h,S,g;const e=this._context.components.get(ue.COLUMN),t=this._context.components.get(ue.ROW),i=o===0?t:e,r=f=>{var P,A,k;const p=(P=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:P.skeleton;if(p==null)return;const{rowHeaderWidth:v,columnHeaderHeight:C}=p,{startX:b,startY:E,endX:w,endY:O,column:R}=Ze(f.offsetX,f.offsetY,this._context.scene,p);if(o===0)(A=this._hoverRect)==null||A.transformByState({width:v,height:O-E,left:0,top:E});else{if(this._currentColumn=R,(k=this._hoverRect)==null||k.transformByState({width:w-b,height:C,left:b,top:0}),this._hoverMenu==null)return;if(w-b<C*2){this._hoverMenu.hide();return}const N=C*.8;this._hoverMenu.transformByState({left:w-C,top:C/2-N/2}),this._hoverMenu.setShapeProps({size:N}),this._hoverMenu.show()}},s=()=>{var f;(f=this._hoverRect)==null||f.show()},l=()=>{var f,p;(f=this._hoverRect)==null||f.hide(),(p=this._hoverMenu)==null||p.hide()};this._headerPointerSubs=new D.Subscription;const c=i.onPointerMove$.subscribeEvent(r),d=i.onPointerEnter$.subscribeEvent(s),u=i.onPointerLeave$.subscribeEvent(l);(h=this._headerPointerSubs)==null||h.add(c),(S=this._headerPointerSubs)==null||S.add(d),(g=this._headerPointerSubs)==null||g.add(u)}_initialHoverMenu(){this._hoverMenu!=null&&(this._hoverMenu.onPointerEnter$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:xs.HIGHLIGHT,visible:!0}),this._context.scene.setCursor(M.CURSOR_TYPE.POINTER))}),this._hoverMenu.onPointerLeave$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:xs.NORMAL,visible:!1}),this._context.scene.resetCursor())}),this._hoverMenu.onPointerDown$.subscribeEvent(o=>{var r;const e=this._currentColumn,t=(r=this._selectionManagerService.getCurrentSelections())==null?void 0:r.map(s=>s.range);if(!!!(t!=null&&t.filter(s=>s.rangeType===a.RANGE_TYPE.COLUMN).find(s=>{const{startColumn:l,endColumn:c}=s;return e>=l&&e<=c}))){const s=this._getSelectionOnColumn(e);this._commandService.syncExecuteCommand(m.SetSelectionsOperation.id,s)}o.stopPropagation(),o.preventDefault(),this._contextMenuService.triggerContextMenu(o,I.ContextMenuPosition.COL_HEADER)}))}_getSelectionOnColumn(o){const e=this._context.unit,t=e.getActiveSheet();if(!t)throw new Error("No active worksheet");return{unitId:e.getUnitId(),subUnitId:t.getSheetId(),selections:[{range:{startRow:0,startColumn:o,endRow:t.getRowCount()-1,endColumn:o,rangeType:a.RANGE_TYPE.COLUMN},primary:{startRow:0,startColumn:o,endRow:0,endColumn:o,actualRow:0,actualColumn:o,isMerged:!1,isMergedMainCell:!1},style:null}]}}};Fs=Gp([Zo(1,a.Inject(y.SheetSkeletonManagerService)),Zo(2,I.IContextMenuService),Zo(3,a.ICommandService),Zo(4,a.Inject(m.SheetsSelectionsService))],Fs);var zs=(n=>(n[n.ROW=0]="ROW",n[n.COLUMN=1]="COLUMN",n))(zs||{});const Bi=12,Qp=.4;class dd extends M.Shape{constructor(e,t,i){super(e,t);T(this,"_size",Bi);T(this,"_iconRatio",Qp);T(this,"_hovered",!0);T(this,"_hasPrevious",!0);T(this,"_hasNext",!0);T(this,"_unhideType");t&&this.setShapeProps(t),this.onPointerEnter$.subscribeEvent(()=>this.setShapeProps({hovered:!0})),this.onPointerLeave$.subscribeEvent(()=>this.setShapeProps({hovered:!1})),this.onPointerDown$.subscribeEvent(()=>i==null?void 0:i())}setShapeProps(e){e.type!==void 0&&(this._unhideType=e.type),e.hovered!==void 0&&(this._hovered=e.hovered),e.hasPrevious!==void 0&&(this._hasPrevious=e.hasPrevious),e.hasNext!==void 0&&(this._hasNext=e.hasNext),this.transformByState({width:this._size*(this._unhideType===1?2:1),height:this._size*(this._unhideType===0?2:1)})}_draw(e){this._unhideType===0?this._drawOnRow(e):this._drawOnCol(e)}_drawOnRow(e){this._hovered&&(!this._hasNext||!this._hasPrevious?M.Rect.drawWith(e,{width:this._size,height:this._size,stroke:mt,fill:Go}):M.Rect.drawWith(e,{width:this._size,height:2*this._size,stroke:mt,fill:Go}));const t=this._size*.5*this._iconRatio,i=Math.PI/3,r=t*Math.cos(i),s=t*Math.sin(i);if(this._hasPrevious&&M.RegularPolygon.drawWith(e,{pointsGroup:[[{x:this._size/2,y:this._size/2-s},{x:this._size/2-s,y:this._size/2+r},{x:this._size/2+s,y:this._size/2+r}]],fill:mt}),this._hasNext){const l=this._hasPrevious?3:1;M.RegularPolygon.drawWith(e,{pointsGroup:[[{x:this._size/2,y:this._size*l/2+s},{x:this._size/2-s,y:this._size*l/2-r},{x:this._size/2+s,y:this._size*l/2-r}]],fill:mt})}}_drawOnCol(e){this._hovered&&(!this._hasNext||!this._hasPrevious?M.Rect.drawWith(e,{width:this._size,height:this._size,stroke:mt,fill:Go}):M.Rect.drawWith(e,{width:2*this._size,height:this._size,stroke:mt,fill:Go}));const t=this._size*.5*this._iconRatio,i=Math.PI/3,r=t*Math.cos(i),s=t*Math.sin(i);if(this._hasPrevious&&M.RegularPolygon.drawWith(e,{pointsGroup:[[{x:-r+this._size/2,y:this._size/2},{x:this._size/2+s,y:this._size/2-s},{x:this._size/2+s,y:this._size/2+s}]],fill:mt}),this._hasNext){const l=this._hasPrevious?3:1;M.RegularPolygon.drawWith(e,{pointsGroup:[[{x:r+this._size*l/2,y:this._size/2},{x:-s+this._size*l/2,y:this._size/2-s},{x:-s+this._size*l/2,y:this._size/2+s}]],fill:mt})}}}var Jp=Object.getOwnPropertyDescriptor,$p=(n,o,e,t)=>{for(var i=t>1?void 0:t?Jp(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},ud=(n,o)=>(e,t)=>o(e,t,n);const hd="__SpreadsheetHeaderUnhideSHAPEControllerShape__";let Xs=class extends a.RxDisposable{constructor(o,e,t){super();T(this,"_shapes",{cols:[],rows:[]});this._context=o,this._sheetSkeletonManagerService=e,this._commandService=t,this._init()}get _workbook(){return this._context.unit}dispose(){super.dispose(),this._clearShapes()}_init(){let o="";this._context.unit.activeSheet$.pipe(D.takeUntil(this.dispose$)).subscribe(e=>{if(this._clearShapes(),!e){o="";return}o=e.getSheetId(),this._update(this._workbook,e)}),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(e=>{if(e){const{unitId:t,sheetId:i}=e;if(t===this._workbook.getUnitId()&&i===o){const r=this._workbook.getSheetBySheetId(i);r&&this._update(this._workbook,r)}}}))}_update(o,e){var S;const t=(S=this._sheetSkeletonManagerService.getSkeletonParam(e.getSheetId()))==null?void 0:S.skeleton;if(!t)return;const i=e.getHiddenRows(),r=e.getHiddenCols(),s=this._getSheetObject(),{scene:l}=s,c=e.getRowCount(),d=i.map(g=>{const{startRow:f,endRow:p}=g,v=dr(f,0,l,t),C=f!==0,b=p!==c-1;return new dd(hd,{type:zs.ROW,hovered:!1,hasPrevious:C,hasNext:b,top:v.startY-(C?Bi:0),left:v.startX-Bi},()=>this._commandService.executeCommand(m.SetSpecificRowsVisibleCommand.id,{unitId:o.getUnitId(),subUnitId:e.getSheetId(),ranges:[g]}))}),u=e.getColumnCount(),h=r.map(g=>{const{startColumn:f,endColumn:p}=g,v=dr(0,f,l,t),C=f!==0,b=p!==u-1;return new dd(hd,{type:zs.COLUMN,hovered:!1,hasPrevious:C,hasNext:b,top:20-Bi,left:v.startX-(C?Bi:0)},()=>this._commandService.executeCommand(m.SetSpecificColsVisibleCommand.id,{unitId:o.getUnitId(),subUnitId:e.getSheetId(),ranges:[g]}))});l.addObjects(h,Gs),l.addObjects(d,Gs),this._clearShapes(),this._shapes={cols:h,rows:d}}_clearShapes(){this._shapes.cols.forEach(o=>o.dispose()),this._shapes.rows.forEach(o=>o.dispose()),this._shapes={cols:[],rows:[]}}_getSheetObject(){return ze(this._workbook,this._context)}};Xs=$p([ud(1,a.Inject(y.SheetSkeletonManagerService)),ud(2,a.ICommandService)],Xs);var ev=Object.getOwnPropertyDescriptor,tv=(n,o,e,t)=>{for(var i=t>1?void 0:t?ev(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},md=(n,o)=>(e,t)=>o(e,t,n);let Ys=class extends a.Disposable{constructor(n,o,e){super(),this._context=n,this._sheetSkeletonManagerService=o,this._renderManagerService=e,this.disposeWithMe(this._context.unit.sheetDisposed$.subscribe(t=>{this._sheetSkeletonManagerService.disposeSkeleton(t.getSheetId())})),this._sheetSkeletonManagerService.currentSkeleton$.subscribe(t=>{this._updateSceneSize(t)})}_updateSceneSize(n){var u;if(n==null)return;const{unitId:o}=this._context,{skeleton:e}=n,t=(u=this._renderManagerService.getRenderById(o))==null?void 0:u.scene;if(e==null||t==null)return;const{rowTotalHeight:i,columnTotalWidth:r,rowHeaderWidthAndMarginLeft:s,columnHeaderHeightAndMarginTop:l}=e;this._context.unit.getActiveSheet()&&(t==null||t.transformByState({width:s+r,height:l+i}))}};Ys=tv([md(1,a.Inject(y.SheetSkeletonManagerService)),md(2,M.IRenderManagerService)],Ys);var nv=Object.getOwnPropertyDescriptor,iv=(n,o,e,t)=>{for(var i=t>1?void 0:t?nv(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},Mt=(n,o)=>(e,t)=>o(e,t,n);y.SheetSelectionRenderService=class extends ir{constructor(e,t,i,r,s,l,c,d,u){super(t,i,r,l,u);T(this,"_workbookSelections");T(this,"_renderDisposable",null);this._context=e,this._logService=c,this._commandService=d,this._contextService=u,this._workbookSelections=s.getWorkbookSelections(this._context.unitId),this._init()}_init(){const e=this._getSheetObject();this._contextService.setContextValue(m.SELECTIONS_ENABLED,!0),this._initEventListeners(e),this._initSelectionModelChangeListener(),this._initThemeChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener()}_initEventListeners(e){const{spreadsheetRowHeader:t,spreadsheetColumnHeader:i,spreadsheet:r,spreadsheetLeftTopPlaceholder:s}=e,{scene:l}=this._context;this.disposeWithMe(r==null?void 0:r.onPointerDown$.subscribeEvent((c,d)=>{this.isSelectionDisabled()||this.inRefSelectionMode()||(this._onPointerDown(c,r.zIndex+1,a.RANGE_TYPE.NORMAL,this._getActiveViewport(c)),c.button!==2&&d.stopPropagation())})),this.disposeWithMe(t==null?void 0:t.onPointerDown$.subscribeEvent((c,d)=>{if(this.isSelectionDisabled()||this.inRefSelectionMode())return;const u=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{row:h}=Ze(c.offsetX,c.offsetY,l,u);wl(this._workbookSelections.getCurrentSelections(),h)||(this._onPointerDown(c,(r.zIndex||1)+1,a.RANGE_TYPE.ROW,this._getActiveViewport(c),M.ScrollTimerType.Y),c.button!==2&&d.stopPropagation())})),this.disposeWithMe(i==null?void 0:i.onPointerDown$.subscribeEvent((c,d)=>{if(this.isSelectionDisabled()||this.inRefSelectionMode())return;const u=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{column:h}=Ze(c.offsetX,c.offsetY,l,u);Tl(this._workbookSelections.getCurrentSelections(),h)||(this._onPointerDown(c,(r.zIndex||1)+1,a.RANGE_TYPE.COLUMN,this._getActiveViewport(c),M.ScrollTimerType.X),c.button!==2&&d.stopPropagation())})),this.disposeWithMe(s==null?void 0:s.onPointerDown$.subscribeEvent((c,d)=>{if(this.isSelectionDisabled()||this.inRefSelectionMode())return;this._reset();const u=this._sheetSkeletonManagerService.getCurrentParam().skeleton,h=or(u);this._addSelectionControlByModelData(h),this.refreshSelectionMoveEnd(),c.button!==2&&d.stopPropagation()}))}_initThemeChangeListener(){this.disposeWithMe(this._themeService.currentTheme$.subscribe(()=>{this._initSelectionThemeFromThemeService();const e=this._workbookSelections.getCurrentSelections();e&&this.resetSelectionsByModelData(e)}))}_initSelectionModelChangeListener(){this.disposeWithMe(D.merge(this._workbookSelections.selectionMoveEnd$,this._workbookSelections.selectionSet$).subscribe(e=>{this.resetSelectionsByModelData(e)}))}disableSelection(){this._contextService.setContextValue(m.SELECTIONS_ENABLED,!1)}enableSelection(){this._contextService.setContextValue(m.SELECTIONS_ENABLED,!0)}transparentSelection(){this.setSelectionTheme({primaryColor:"transparent"});const e=this._workbookSelections.getCurrentSelections();for(let t=0;t<e.length;t++){const i=e[t];i.style=gt(this._selectionTheme)}this.resetSelectionsByModelData(e)}showSelection(){const e=this._themeService.getCurrentTheme();this.setSelectionTheme(e);const t=this._workbookSelections.getCurrentSelections();for(let i=0;i<t.length;i++){const r=t[i];r.style&&(r.style=gt(this._selectionTheme))}this.resetSelectionsByModelData(t)}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(e=>this._updateSelections(e,m.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(e=>this._updateSelections(e,m.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(m.REF_SELECTIONS_ENABLED).pipe(D.startWith(!1),D.distinctUntilChanged()).subscribe(e=>{e&&this._reset()})),this.disposeWithMe(this._contextService.subscribeContextValue$(m.SELECTIONS_ENABLED).pipe(D.startWith(!0),D.distinctUntilChanged()).subscribe(e=>{var t;e?this._renderDisposable=a.toDisposable(this.selectionMoveEnd$.subscribe(i=>{this._updateSelections(i,m.SelectionMoveType.MOVE_END)})):((t=this._renderDisposable)==null||t.dispose(),this._renderDisposable=null,this._reset())}))}_updateSelections(e,t){const i=this._context.unit,r=i.getUnitId(),s=i.getActiveSheet().getSheetId();if(e.length===0)return;const l=e.map(c=>m.convertSelectionDataToRange(c));this._commandService.executeCommand(m.SetSelectionsOperation.id,{unitId:r,subUnitId:s,type:t,selections:l})}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(e=>{var u,h;if(e==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const t=this._context.unitId,{sheetId:i,skeleton:r}=e,{scene:s}=this._context,l=s.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=(h=(u=this._skeleton)==null?void 0:u.worksheet)==null?void 0:h.getSheetId();if(this._changeRuntime(r,s,l),c!==r.worksheet.getSheetId()){const S=this._workbookSelections.getCurrentSelections();this._commandService.syncExecuteCommand(m.SetSelectionsOperation.id,{unitId:t,subUnitId:i,selections:S.length!==0?S:[Zi(r)]})}const d=this._workbookSelections.getCurrentSelections();d!=null&&this.resetSelectionsByModelData(d)}))}_getActiveViewport(e){const t=this._getSheetObject();return t==null?void 0:t.scene.getActiveViewportByCoord(M.Vector2.FromArray([e.offsetX,e.offsetY]))}_getSheetObject(){return ze(this._context.unit,this._context)}_onPointerDown(e,t=0,i=a.RANGE_TYPE.NORMAL,r,s=M.ScrollTimerType.ALL){var H,V;this._rangeType=i;const l=this._skeleton,c=this._scene;if(!c||!l)return;r&&(this._activeViewport=r);const{offsetX:d,offsetY:u}=e,h=c.getViewport(M.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!h)return;const S=c.getCoordRelativeToViewport(M.Vector2.FromArray([d,u])),{x:g,y:f}=S;this._startViewportPosX=g,this._startViewportPosY=f;const p=c.getScrollXYInfoByViewport(S),{scaleX:v,scaleY:C}=c.getAncestorScale(),b=this._skeleton.getCellByOffset(g,f,v,C,p);if(!b)return;switch(i){case a.RANGE_TYPE.NORMAL:break;case a.RANGE_TYPE.ROW:b.startColumn=0,b.endColumn=this._skeleton.getColumnCount()-1,b.startRow=b.actualRow,b.endRow=b.actualRow;break;case a.RANGE_TYPE.COLUMN:b.startRow=0,b.endRow=this._skeleton.getRowCount()-1,b.startColumn=b.actualColumn,b.endColumn=b.actualColumn;break;case a.RANGE_TYPE.ALL:b.startRow=0,b.startColumn=0,b.endRow=this._skeleton.getRowCount()-1,b.endColumn=this._skeleton.getColumnCount()-1}const E={range:b,primary:b,style:null};E.range.rangeType=i;const w=Re(E,this._skeleton);this._startRangeWhenPointerDown={...w.rangeWithCoord};let O=this.getActiveSelectionControl();const R={...w.rangeWithCoord,rangeType:i},P=this.getSelectionControls();for(const U of P)if(e.button===2&&a.Rectangle.contains(U.model,R)){O=U;return}this._checkClearPreviousControls(e);const A=O==null?void 0:O.model.currentCell,k=e.shiftKey&&A,N=this._remainLastEnabled&&!e.ctrlKey&&!e.shiftKey&&!this._skipLastEnabled&&!this._singleSelectionEnabled;k&&A?this._makeSelectionByTwoCells(A,R,l,i,O):N&&O?O.updateRangeBySelectionWithCoord(w):O=this.newSelectionControl(c,l,E);for(let U=0;U<this.getSelectionControls().length-1;U++)this.getSelectionControls()[U].clearHighlight();c.disableObjectsEvent(),this._clearUpdatingListeners(),this._addEndingListeners(),(H=c.getTransformer())==null||H.clearSelectedObjects(),this._setupPointerMoveListener(h,O,i,s,g,f),this._escapeShortcutDisposable=this._shortcutService.forceEscape(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._scenePointerUpSub=c.onPointerUp$.subscribeEvent(()=>{var U;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(U=this._escapeShortcutDisposable)==null||U.dispose(),this._escapeShortcutDisposable=null}),(V=this._scene.getEngine())==null||V.setCapture()}},y.SheetSelectionRenderService=iv([Mt(1,a.Inject(a.Injector)),Mt(2,a.Inject(a.ThemeService)),Mt(3,I.IShortcutService),Mt(4,a.Inject(m.SheetsSelectionsService)),Mt(5,a.Inject(y.SheetSkeletonManagerService)),Mt(6,a.ILogService),Mt(7,a.ICommandService),Mt(8,a.IContextService)],y.SheetSelectionRenderService);var ov=Object.defineProperty,rv=Object.getOwnPropertyDescriptor,sv=(n,o,e)=>o in n?ov(n,o,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[o]=e,av=(n,o,e,t)=>{for(var i=t>1?void 0:t?rv(o,e):o,r=n.length-1,s;r>=0;r--)(s=n[r])&&(i=s(i)||i);return i},xi=(n,o)=>(e,t)=>o(e,t,n),Sd=(n,o,e)=>sv(n,typeof o!="symbol"?o+"":o,e);y.UniverSheetsUIPlugin=class extends a.Plugin{constructor(o=sr,e,t,i,r,s){super(),this._config=o,this._injector=e,this._renderManagerService=t,this._configService=i,this._univerInstanceService=r,this._componentManager=s;const{menu:l,...c}=a.merge({},sr,this._config),{customComponents:d=new Set}=c;c.protectedRangeShadow===!1&&d.add(vo),c.protectedRangeUserSelector&&(d.add(Dn),this._componentManager.register(Dn,c.protectedRangeUserSelector.component,{framework:c.protectedRangeUserSelector.framework})),l&&this._configService.setConfig("menu",l,{merge:!0}),this._configService.setConfig(Fe,{...c,customComponents:d})}onStarting(){a.registerDependencies(this._injector,a.mergeOverrideWithDependencies([[hn],[Se,{useClass:y.EditorBridgeService}],[Be,{useClass:y.SheetClipboardService}],[Vt,{useClass:Ma}],[Qe,{useClass:ho}],[ei,{useClass:ha}],[ti,{useClass:eh}],[m.IRefSelectionsService,{useClass:m.RefSelectionsService}],[vt,{useClass:y.AutoFillService}],[ks],[ii,{useClass:yr}],[Ut,{useClass:y.MarkSelectionService}],[y.HoverManagerService],[y.DragManagerService],[y.SheetCanvasPopManagerService],[y.CellAlertManagerService],[mr],[Ds,{useClass:y.SheetCellDropdownManagerService}],[y.SheetCellEditorResizeService],[ki],[y.AutoHeightController],[y.AutoWidthController],[y.FormulaEditorController],[y.SheetsRenderService],[y.SheetUIController],[y.StatusBarController],[y.AutoFillController],[Yo],[zo],[Xo],[Fo],[y.EditingRenderController],[kn],[jo],[Et],[Hi],[y.SheetPermissionCheckUIController],[Wi]],this._config.override))}onReady(){this._config.disableAutoFocus||this._initAutoFocus(),a.registerDependencies(this._injector,[[Ln]]),this._registerRenderBasics(),a.touchDependencies(this._injector,[[y.SheetUIController],[y.SheetsRenderService],[ki],[y.SheetPermissionCheckUIController],[jo]])}onRendered(){this._registerRenderModules(),a.touchDependencies(this._injector,[[Wi],[kn],[Ln],[y.FormulaEditorController],[zo],[y.StatusBarController],[y.AutoHeightController],[y.AutoWidthController],[Xo],[Fo],[y.EditingRenderController]])}onSteady(){a.touchDependencies(this._injector,[[Yo],[y.AutoFillController],[Hi]])}_registerRenderBasics(){[[y.SheetSkeletonManagerService],[Ys],[y.SheetRenderController],[ve,{useClass:y.SheetSelectionRenderService}]].forEach(o=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,o))})}_registerRenderModules(){var i;const o=[[y.HeaderMoveRenderController],[Xs],[y.HeaderResizeRenderController],[y.SheetScrollManagerService],[y.SheetsScrollRenderController],[y.HeaderFreezeRenderController],[qn],[Lo],[Ls],[To],[Mo],[Po],[y.HoverRenderController],[y.DragRenderController],[Ro],[y.CellCustomRenderController],[Bs],[Vs],[ao],[Do],[No],[Vo],[Wo]],e=this._configService.getConfig(I.UI_PLUGIN_CONFIG_KEY);((i=e==null?void 0:e.contextMenu)!=null?i:!0)&&o.push([Fs]),o.forEach(r=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,r))})}_initAutoFocus(){const o=this._univerInstanceService;this.disposeWithMe(o.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).pipe(me.filter(e=>!!e)).subscribe(e=>o.focusUnit(e.getUnitId())))}},Sd(y.UniverSheetsUIPlugin,"pluginName","SHEET_UI_PLUGIN"),Sd(y.UniverSheetsUIPlugin,"type",a.UniverInstanceType.UNIVER_SHEET),y.UniverSheetsUIPlugin=av([a.DependentOn(m.UniverSheetsPlugin),xi(1,a.Inject(a.Injector)),xi(2,M.IRenderManagerService),xi(3,a.IConfigService),xi(4,a.IUniverInstanceService),xi(5,a.Inject(I.ComponentManager))],y.UniverSheetsUIPlugin);const gd="embedding_formula_editor",lv=n=>n.includes(gd);function cv(n,o,e,t){const{from:i,to:r}=e,{column:s,columnOffset:l,row:c,rowOffset:d}=i,{column:u,columnOffset:h,row:S,rowOffset:g}=r,f=t.ensureSkeleton(o);if(f==null)throw new Error("No current skeleton");const p=rn(f,{startColumn:s,endColumn:s,startRow:c,endRow:c}),v=rn(f,{startColumn:u,endColumn:u,startRow:S,endRow:S}),{startX:C,startY:b}=p,{startX:E,startY:w}=v,O=M.precisionTo(C+l,1),R=M.precisionTo(b+d,1);let P=M.precisionTo(E+h-O,1),A=M.precisionTo(w+g-R,1);return p.startX===v.endX&&(P=0),p.startY===v.endY&&(A=0),{unitId:n,subUnitId:o,left:O,top:R,width:P,height:A}}function dv(n,o,e,t,i,r,s){const{column:l,columnOffset:c,row:d,rowOffset:u}=e,h=s.ensureSkeleton(o);if(h==null)throw new Error("No current skeleton");const S=rn(h,{startColumn:l,endColumn:l,startRow:d,endRow:d}),{startX:g,startY:f}=S,p=M.precisionTo(g+c,1),v=M.precisionTo(f+u,1),C=r.getCellWithCoordByOffset(p+t,v+i,h);if(C==null)throw new Error("No end selection cell");const b={column:C.actualColumn,columnOffset:M.precisionTo(p+t-C.startX,1),row:C.actualRow,rowOffset:M.precisionTo(v+i-C.startY,1)};return{unitId:n,subUnitId:o,sheetTransform:{from:{column:l,columnOffset:c,row:d,rowOffset:u},to:b},transform:{left:p,top:v,width:t,height:i}}}y.AFFECT_LAYOUT_STYLES=ar,y.APPLY_TYPE=ce,y.AddRangeProtectionFromContextMenuCommand=Kt,y.AddRangeProtectionFromSheetBarCommand=yi,y.AddRangeProtectionFromToolbarCommand=Ti,y.ApplyFormatPainterCommand=hi,y.AutoClearContentCommand=cn,y.AutoFillCommand=Ct,y.BaseSelectionRenderService=ir,y.COPY_TYPE=it,y.CellAlertType=Vn,y.CellEditorManagerService=ha,y.ChangeSheetProtectionFromSheetBarCommand=Ai,y.ChangeZoomRatioCommand=dn,y.DATA_TYPE=be,y.DeleteRangeMoveLeftConfirmCommand=On,y.DeleteRangeMoveUpConfirmCommand=Gt,y.DeleteRangeProtectionFromContextMenuCommand=Qt,y.DeleteWorksheetProtectionFormSheetBarCommand=Oi,y.EMBEDDING_FORMULA_EDITOR=gd,y.EMBEDDING_FORMULA_EDITOR_COMPONENT_KEY=Xi,y.ExpandSelectionCommand=ke,y.FONT_FAMILY_COMPONENT=So,y.FONT_FAMILY_ITEM_COMPONENT=go,y.FONT_SIZE_COMPONENT=fo,y.FormatPainterStatus=Ne,y.FormulaBar=ya,y.HideColConfirmCommand=li,y.HideRowConfirmCommand=ai,y.IAutoFillService=vt,y.ICellEditorManagerService=ei,y.IEditorBridgeService=Se,y.IFormatPainterService=Qe,y.IFormulaEditorManagerService=ti,y.IMarkSelectionService=Ut,y.ISheetCellDropdownManagerService=Ds,y.ISheetClipboardService=Be,y.ISheetSelectionRenderService=ve,y.IStatusBarService=ii,y.InsertRangeMoveDownConfirmCommand=Zt,y.InsertRangeMoveRightConfirmCommand=An,y.JumpOver=Ke,y.MobileSheetBar=Gc,y.MoveSelectionCommand=Ae,y.MoveSelectionEnterAndTabCommand=qe,y.PASTE_SPECIAL_MENU_ID=vi,y.PREDEFINED_HOOK_NAME=fe,y.RANGE_SELECTOR_COMPONENT_KEY=Jo,y.RANGE_SELECTOR_SYMBOLS=Za,y.RefillCommand=Gn,y.RemoveColConfirmCommand=Hn,y.RemoveRowConfirmCommand=Nn,y.RemoveSheetConfirmCommand=Ri,y.RenameSheetOperation=Di,y.RenderSheetContent=ka,y.RenderSheetFooter=Aa,y.RenderSheetHeader=Da,y.ResetRangeTextColorCommand=Br,y.ResetScrollCommand=Iu,y.SELECTION_SHAPE_DEPTH=tr,y.SHEET_UI_PLUGIN_NAME=Td,y.SHEET_VIEW_KEY=ue,y.ScrollCommand=Ye,y.ScrollToCellCommand=pr,y.ScrollToRangeOperation=vr,y.SelectAllCommand=$n,y.SelectionControl=zn,y.SelectionShape=zn,y.SelectionShapeExtension=Ks,y.SetActivateCellEditOperation=so,y.SetCellEditVisibleArrowOperation=Nt,y.SetCellEditVisibleOperation=ge,y.SetCellEditVisibleWithF2Operation=Zn,y.SetColumnFrozenCommand=Si,y.SetColumnHeaderHeightCommand=Gi,y.SetFormatPainterOperation=ui,y.SetInfiniteFormatPainterCommand=mo,y.SetOnceFormatPainterCommand=Tn,y.SetRangeBoldCommand=xt,y.SetRangeFontFamilyCommand=di,y.SetRangeFontSizeCommand=ci,y.SetRangeItalicCommand=Ft,y.SetRangeProtectionFromContextMenuCommand=Jt,y.SetRangeStrickThroughCommand=Xt,y.SetRangeSubscriptCommand=Lr,y.SetRangeSuperscriptCommand=Ur,y.SetRangeTextColorCommand=En,y.SetRangeUnderlineCommand=zt,y.SetRowFrozenCommand=mi,y.SetRowHeaderWidthCommand=ji,y.SetScrollOperation=Xe,y.SetScrollRelativeCommand=mn,y.SetSelectionFrozenCommand=ot,y.SetWorksheetColAutoWidthCommand=gi,y.SetZoomRatioCommand=un,y.SetZoomRatioOperation=We,y.SheetBar=Ra,y.SheetCopyCommand=je,y.SheetCutCommand=co,y.SheetMenuPosition=pl,y.SheetPasteBesidesBorderCommand=bn,y.SheetPasteColWidthCommand=Bt,y.SheetPasteCommand=Ge,y.SheetPasteFormatCommand=_n,y.SheetPasteShortKeyCommand=uo,y.SheetPasteValueCommand=In,y.SheetPermissionOpenDialogOperation=ls,y.SheetPermissionOpenPanelOperation=et,y.SheetPermissionUserManagerService=Et,y.SheetPrintInterceptorService=ks,y.SheetsUIMenuSchema=Jl,y.SheetsUIPart=rr,y.ShowMenuListCommand=Pi,y.SidebarDefinedNameOperation=no,y.StatusBarService=yr,y.UNIVER_SHEET_PERMISSION_BACKGROUND=vo,y.UNIVER_SHEET_PERMISSION_USER_PART=Dn,y.ViewSheetPermissionFromContextMenuCommand=qt,y.ViewSheetPermissionFromSheetBarCommand=Mi,y.attachPrimaryWithCoord=Fn,y.attachRangeWithCoord=rn,y.attachSelectionWithCoord=Re,y.calculateDocSkeletonRects=zc,y.checkInHeaderRanges=_i,y.convertPositionCellToSheetOverGrid=dv,y.convertPositionSheetOverGridToAbsolute=cv,y.deriveStateFromActiveSheet$=we,y.discreteRangeToRange=pt,y.functionDisplayNames=ro,y.genNormalSelectionStyle=gt,y.genSelectionByRange=Qs,y.getAllSelection=or,y.getAutoFillRepeatRange=Fd,y.getCellRealRange=kl,y.getCoordByCell=dr,y.getCoordByOffset=Ze,y.getCurrentExclusiveRangeInterest$=Sl,y.getCurrentRangeDisable$=te,y.getCustomRangePosition=rf,y.getEditingCustomRangePosition=sf,y.getEditorObject=zi,y.getMatrixPlainText=dl,y.getObservableWithExclusiveRange$=Yt,y.getRepeatRange=am,y.getSheetObject=ze,y.getTopLeftSelectionOfCurrSheet=Zi,y.getTransformCoord=Kn,y.isEmbeddingFormulaEditor=lv,y.isRangeSelector=Ka,y.mergeSetRangeValues=Hr,y.useActiveWorkbook=ft,y.useActiveWorksheet=Ed,y.useHighlightRange=kc,y.useWorkbooks=wd,y.virtualizeDiscreteRanges=Ot,y.whenFormulaEditorActivated=bh,y.whenSheetEditorFocused=le,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})});