@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/cjs/index.js CHANGED
@@ -79,5 +79,5 @@
79
79
  `,paragraphs:[{startIndex:r.length}],customRanges:[o]}}let i=n.replace(/(\r\n|\n)/g,"\r");i.endsWith(`\r
80
80
  `)||(i+=`\r
81
81
  `);const e=[];for(let t=0;t<i.length;t++)i[t]==="\r"&&e.push({startIndex:t});return{dataStream:i,paragraphs:e,sectionBreaks:[{startIndex:i.indexOf(`
82
- `)}]}}var hp=Object.getOwnPropertyDescriptor,mp=(n,i,e,t)=>{for(var r=t>1?void 0:t?hp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ge=(n,i)=>(e,t)=>i(e,t,n);const gp=[m.InsertColMutation.id,m.InsertRowMutation.id,m.RemoveColMutation.id,m.RemoveRowMutation.id,m.MoveRangeMutation.id,m.MoveRowsMutation.id,m.MoveColsMutation.id];let An=class extends a.RxDisposable{constructor(i,e,t,r,o,s,l,c,d,u){super();w(this,"_refreshOptionalPaste$",new x.Subject);w(this,"refreshOptionalPaste$",this._refreshOptionalPaste$.asObservable());this._injector=i,this._instanceService=e,this._renderManagerService=t,this._commandService=r,this._contextService=o,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 i=r=>{r.onPaste$.pipe(x.takeUntil(this.dispose$)).subscribe(o=>{var u,h;if(!ae(this._contextService))return;o.event.preventDefault();const s=o.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(di.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($.DocSelectionRenderService);e&&i(e),this._renderManagerService.created$.subscribe(r=>{var o;r.unitId===a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY&&(e=(o=this._renderManagerService.getRenderById(a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY))==null?void 0:o.with($.DocSelectionRenderService),e&&i(e))})}_resolveClipboardFiles(i){if(!i)return;const e=Array.from(i.items).map(t=>t.kind==="file"?t.getAsFile():void 0).filter(Boolean);return e.length>0?e:void 0}_init(){[je,Fi,ze].forEach(e=>this.disposeWithMe(this._commandService.registerMultipleCommand(e))),[gn,Sn,Lt,fn,di,Ul].forEach(e=>this.disposeWithMe(this._commandService.registerCommand(e))),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initCopyingHooks())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initPastingHook()));const i=this._initSpecialPasteHooks().map(e=>this._sheetClipboardService.addClipboardHook(e));this.disposeWithMe({dispose:()=>i.forEach(e=>e.dispose())})}_initCopyingHooks(){const i=this;let e=null;return{id:Se.DEFAULT_COPY,isDefaultHook:!0,onBeforeCopy(t,r){e=i._getWorksheet(t,r)},onCopyCellContent(t,r){var l,c,d,u;const o=e.getCell(t,r);return(c=(l=o==null?void 0:o.p)==null?void 0:l.body)!=null&&c.paragraphs||(u=(d=o==null?void 0:o.p)==null?void 0:d.body)!=null&&u.textRuns?a.convertBodyToHtml(o.p.body):o?a.extractPureTextFromCell(o):""},onCopyCellStyle:(t,r,o,s)=>{const l={};(o||s)&&(l.rowspan=`${o||1}`,l.colspan=`${s||1}`);const c=e.getRange(t,r),d=e.getMergedCell(t,r),u=c.getTextStyle();let h="";if(u&&(h=a.handleStyleToString(u)),d){const g=d.endRow,S=d.endColumn,p=e.getRange(g,S).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:r,endRow:o}=t,s=(c=i._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getActiveSheet(),l=[];if(!s)return l;for(let d=r;d<=o;d++)s.getRowFiltered(d)&&l.push(d);return l}}}_initPastingHook(){const i=this;let e=null,t=null,r=null;return{id:Se.DEFAULT_PASTE,isDefaultHook:!0,onBeforePaste({unitId:o,subUnitId:s,range:l}){r=i._getWorksheet(o,s),e=o,t=s;const c=i._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?(i._messageService.show({type:X.MessageType.Error,content:i._localService.t("clipboard.paste.exceedMaxCells")}),!1):!0},onPasteRows(o,s){const{range:l}=o,c=[],d=[],u=r.getMaxRows(),h=u-1,g=l.rows[l.rows.length-1]-h,S=s.length-g,f=r.getRowManager();if(g>0){const C={};s.slice(S).forEach((E,P)=>{const{height:y}=E||{};y&&(C[P]={h:Number.parseFloat(y),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},R={unitId:e,subUnitId:t,range:b,rowInfo:C};c.push({id:m.InsertRowMutation.id,params:R}),d.push({id:m.RemoveRowMutation.id,params:{unitId:e,subUnitId:t,range:b}})}const p={},v={};if(s.slice(0,S).forEach((C,b)=>{var E,P;const{height:R}=C;if(R){const y=f.getRow(l.rows[0]+b),M=Number.parseFloat(R);if(y){const{h:O=a.DEFAULT_WORKSHEET_ROW_HEIGHT,ah:A=0}=y,k=Math.max(O,A);M>k?(p[b+l.rows[0]]=M,v[b+l.rows[0]]=k):(p[b+l.rows[0]]=k,v[b+l.rows[0]]=k)}else p[b+l.rows[0]]=M,v[b+l.rows[0]]=(P=(E=f.getRow(l.rows[0]+b))==null?void 0:E.h)!=null?P: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(o,s,l){var R;const{range:c}=o,d=[],u=[],h=r.getMaxColumns(),g=h-1,S=c.cols[c.cols.length-1]-g,f=s.length-S,p=(R=i._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?R:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,v=c.cols,C=v[0];if(S>0){const E={startRow:c.rows[0],endRow:c.rows[c.rows.length-1],endColumn:c.cols[c.cols.length-1],startColumn:h},P={unitId:e,subUnitId:t,range:E,colInfo:s.slice(f).map((y,M)=>({w:y.width?Math.max(+y.width,r.getColumnWidth(v[M])):p,hd:a.BooleanNumber.FALSE}))};d.push({id:m.InsertColMutation.id,params:P}),u.push({id:m.RemoveColMutation.id,params:{unitId:e,subUnitId:t,range:E}})}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 E={...b,colWidth:s.slice(0,f).reduce((y,M,O)=>{var A;return y[O+C]=M.width?Math.max(+M.width,(A=r.getColumnWidth(v[O]))!=null?A:p):p,y},{})},P={...b,colWidth:s.slice(0,f).reduce((y,M,O)=>{var A;return y[O+C]=(A=r.getColumnWidth(v[O]))!=null?A:p,y},{})};d.push({id:m.SetWorksheetColWidthMutation.id,params:E}),u.push({id:m.SetWorksheetColWidthMutation.id,params:P})}return{redos:d,undos:u}},onPastePlainText(o,s,l){return i._onPastePlainText(o,s,l)},onPasteCells(o,s,l,c){return i._onPasteCells(o,s,l,c)},onAfterPaste(o){r=null}}}_generateDocumentDataModelSnapshot(i){var l,c;const e=(l=T.withCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService,this._instanceService,this._renderManagerService))==null?void 0:l.getCurrentParam();if(e==null)return null;const{skeleton:t}=e,r=(c=t.getBlankCellDocumentModel())==null?void 0:c.documentModel,s={...r==null?void 0:r.getSnapshot(),...i};return r==null||r.reset(s),r==null?void 0:r.getSnapshot()}_onPastePlainText(i,e,t){const{range:r,unitId:o,subUnitId:s}=i;let l;if(/\r|\n/.test(e)||a.Tools.isLegalUrl(e)){const d=up(e),u=this._generateDocumentDataModelSnapshot({body:d});l={[r.rows[0]]:{[r.cols[0]]:{p:u}}}}else a.isFormulaString(e)?l={[r.rows[0]]:{[r.cols[0]]:{f:e}}}:l={[r.rows[0]]:{[r.cols[0]]:{v:e}}};const c={unitId:o,subUnitId:s,cellValue:l};return{redos:[{id:m.SetRangeValuesMutation.id,params:c}],undos:[{id:m.SetRangeValuesMutation.id,params:m.SetRangeValuesUndoMutationFactory(this._injector,c)}]}}_onPasteCells(i,e,t,r){return this._injector.invoke(o=>lp(i,e,t,r,o))}_initSpecialPasteHooks(){const i=this,e={id:Se.SPECIAL_PASTE_VALUE,specialPasteInfo:{label:"specialPaste.value"},onPasteCells:(s,l,c)=>this._injector.invoke(d=>Zc(l,s,c,d))},t={id:Se.SPECIAL_PASTE_FORMAT,specialPasteInfo:{label:"specialPaste.format"},onPasteCells:(s,l,c)=>{const d=[],u=[],{undos:h,redos:g}=this._injector.invoke(C=>qc(l,c,C));d.push(...g),u.push(...h);const{undos:S,redos:f}=this._injector.invoke(C=>ts(l,c,C));d.push(...f),u.push(...S);const{undos:p,redos:v}=this._injector.invoke(C=>Kc(l,s,c,C));return d.push(...v),u.push(...p),{undos:u,redos:d}}},r={id:Se.SPECIAL_PASTE_COL_WIDTH,specialPasteInfo:{label:"specialPaste.colWidth"},onPasteCells(){return{undos:[],redos:[]}},onPasteColumns(s,l,c){var O,A;const d=i._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),u=d.getUnitId(),h=(O=d.getActiveSheet())==null?void 0:O.getSheetId();if(!u||!h)throw new Error("Cannot find unitId or subUnitId");const g=[],S=[],f=i._getWorksheet(u,h),{range:p}=s,v=p.cols,C=v[0],b=f.getMaxColumns(),R=p.cols[p.cols.length-1]-b,E=l.length-R,P=(A=i._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?A:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,y={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,E).reduce((k,D,N)=>{var W;return k[N+C]=D.width?Math.max(+D.width,(W=f.getColumnWidth(v[N]))!=null?W:P):P,k},{})},M={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,E).reduce((k,D,N)=>{var W;return k[N+C]=(W=f.getColumnWidth(v[N]))!=null?W:P,k},{})};return g.push({id:m.SetWorksheetColWidthMutation.id,params:y}),S.push({id:m.SetWorksheetColWidthMutation.id,params:M}),{redos:g,undos:S}}},o={id:Se.SPECIAL_PASTE_BESIDES_BORDER,specialPasteInfo:{label:"specialPaste.besidesBorder"},onPasteCells:(s,l,c,d)=>{i._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);const u=[],h=[],{range:g,unitId:S,subUnitId:f}=l,p=new a.ObjectMatrix;c.forValue((E,P,y)=>{const M=y.s;if(typeof M=="object"){const O=a.Tools.deepClone(y);O.s&&(O.s={...M,bd:null}),p.setValue(g.rows[E],g.cols[P],O)}});const v={unitId:S,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:R}=this._injector.invoke(E=>ts(l,c,E));return h.push(...b),u.push(...R),{redos:u,undos:h}}};return[e,t,r,o]}_getWorksheet(i,e){var r;const t=(r=this._instanceService.getUniverSheetInstance(i))==null?void 0:r.getSheetBySheetId(e);if(!t)throw new Error(`[SheetClipboardController]: cannot find a worksheet with unitId ${i} and subUnitId ${e}.`);return t}_initCommandListener(){var e;this.disposeWithMe(this._commandService.onCommandExecuted(t=>{t.id===yt.id?this._sheetClipboardService.removeMarkSelection():gp.includes(t.id)&&this._sheetClipboardService.removeMarkSelection()}));const i=this._configService.getConfig(Xe);(e=i==null?void 0:i.clipboardConfig)!=null&&e.hidePasteOptions||(this.disposeWithMe(this._commandService.onCommandExecuted(t=>{ap.includes(t.id)&&this._sheetClipboardService.disposePasteOptionsCache()})),this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===Be.id){if(!this._sheetClipboardService.getPasteMenuVisible())return;const o=t.params.unitId,s=this._sheetClipboardService.getPasteOptionsCache(),l=s==null?void 0:s.target.unitId;o===l&&this._refreshOptionalPaste$.next(Math.random())}})))}_initUIComponents(){var e;const i=this._configService.getConfig(Xe);(e=i==null?void 0:i.clipboardConfig)!=null&&e.hidePasteOptions||this.disposeWithMe(this._uiPartsService.registerComponent(I.BuiltInUIPart.CONTENT,()=>I.connectInjector(sp,this._injector)))}};An=mp([Ge(0,a.Inject(a.Injector)),Ge(1,a.IUniverInstanceService),Ge(2,T.IRenderManagerService),Ge(3,a.ICommandService),Ge(4,a.IContextService),Ge(5,a.IConfigService),Ge(6,Ue),Ge(7,I.IMessageService),Ge(8,a.Inject(a.LocaleService)),Ge(9,I.IUIPartsService)],An);var Sp=Object.getOwnPropertyDescriptor,fp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Sp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ua=(n,i)=>(e,t)=>i(e,t,n);exports.DragManagerService=class extends a.Disposable{constructor(e,t){super();w(this,"_currentCell$",new x.Subject);w(this,"currentCell$",this._currentCell$.asObservable().pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)})));w(this,"_endCell$",new x.Subject);w(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 r=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!r)return null;const o=r.getActiveSheet();if(!o)return;const s=this._renderManagerService.getRenderById(r.getUnitId());if(!s)return;const l=s.with(exports.SheetSkeletonManagerService).getCurrentParam(),d=s.with(exports.SheetScrollManagerService).getCurrentScrollState();if(!(!l||!d||!s))return Jl(s,r,o,l,e,t)}onDragOver(e){const{offsetX:t,offsetY:r,dataTransfer:o}=e,s=this._calcActiveCell(t,r);if(!s){this._currentCell$.next(null);return}const{location:l,position:c}=s;this._currentCell$.next({location:l,position:c,dataTransfer:o})}onDrop(e){const{offsetX:t,offsetY:r,dataTransfer:o}=e,s=this._calcActiveCell(t,r);if(!s){this._endCell$.next(null);return}const{location:l,position:c}=s;this._endCell$.next({location:l,position:c,dataTransfer:o})}};exports.DragManagerService=fp([Ua(0,a.IUniverInstanceService),Ua(1,T.IRenderManagerService)],exports.DragManagerService);var pp=Object.getOwnPropertyDescriptor,vp=(n,i,e,t)=>{for(var r=t>1?void 0:t?pp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Mo=(n,i)=>(e,t)=>i(e,t,n);exports.DragRenderController=class extends a.Disposable{constructor(i,e,t,r){super(),this._context=i,this._renderManagerService=e,this._dragManagerService=t,this._sheetSkeletonManagerService=r,this._initDragEvent()}_initDragEvent(){const i=new a.DisposableCollection,e=t=>{if(i.dispose(),!t)return;const{scene:r}=this._context,o=r.onDragOver$.subscribeEvent(l=>{this._dragManagerService.onDragOver(l)}),s=r.onDrop$.subscribeEvent(l=>{this._dragManagerService.onDrop(l)});i.add({dispose(){o.unsubscribe(),s.unsubscribe()}})};e(this._sheetSkeletonManagerService.getCurrentParam()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(t=>{e(t)}))}};exports.DragRenderController=vp([Mo(1,T.IRenderManagerService),Mo(2,a.Inject(exports.DragManagerService)),Mo(3,a.Inject(exports.SheetSkeletonManagerService))],exports.DragRenderController);const Bs=(n,i)=>{var h,g,S,f,p;const t=i.findNodePositionByCharIndex(n.startOffset,!0,n.segmentId,-1),r=i.getSkeletonData();let o=n.endOffset;if(n.segmentId){const v=(p=Array.from((g=(h=r==null?void 0:r.skeFooters.get(n.segmentId))==null?void 0:h.values())!=null?g:[])[0])!=null?p:Array.from((f=(S=r==null?void 0:r.skeHeaders.get(n.segmentId))==null?void 0:S.values())!=null?f:[])[0];v&&(o=Math.min(v.ed,o))}const s=i.findNodePositionByCharIndex(o,!0,n.segmentId,-1);if(!s||!t)return;const l={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},c=new $.NodePositionConvertToCursor(l,i),{borderBoxPointGroup:d}=c.getRangePointData(t,s);return $.getLineBounding(d).map(v=>({top:v.top,bottom:v.bottom,left:v.left,right:v.right}))},Cp=(n,i,e=-1)=>{const t=i.findPositionByGlyph(n,e);if(!t)return;const r={...t,isBack:!0},o={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},s=new $.NodePositionConvertToCursor(o,i),{borderBoxPointGroup:l}=s.getRangePointData(r,r),d=$.getLineBounding(l)[0];return{top:d.top,bottom:d.bottom,left:d.left,right:d.right}},Ip=(n,i,e=0,t=0)=>{const r=Bs({startOffset:i.startIndex,endOffset:i.endIndex+1},n);if(r)return{rects:r.map(o=>({top:o.top+t,bottom:o.bottom+t,left:o.left+e,right:o.right+e})),range:i}},_p=(n,i,e=0,t=0)=>{var h,g,S;const r=n.findNodeByCharIndex(i.startIndex),o=r==null?void 0:r.parent,s=o==null?void 0:o.parent,l=s==null?void 0:s.parent,c=l==null?void 0:l.lines.find(f=>f.paragraphStart&&f.paragraphIndex===i.startIndex),d=(S=(g=(h=c==null?void 0:c.divides)==null?void 0:h[0])==null?void 0:g.glyphGroup)==null?void 0:S[0];if(!d||!d)return;const u=Cp(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:i}},Qc=(n,i=0,e=0)=>{var l,c,d,u,h,g,S;const t=n.getViewModel().getDataModel(),r=(d=(c=(l=t.getBody())==null?void 0:l.customRanges)==null?void 0:c.filter(f=>f.rangeType===a.CustomRangeType.HYPERLINK))!=null?d:[],o=(g=(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?g:[],s=(S=n.getSkeletonData())==null?void 0:S.pages[0].skeDrawings;return{links:r.map(f=>Ip(n,f,i,e)).filter(Boolean),checkLists:o.map(f=>_p(n,f,i,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 Jc(n,i,e){var d,u,h,g,S,f;const t=(h=(u=(d=i.documentSkeleton)==null?void 0:d.getSkeletonData())==null?void 0:u.pages[0].height)!=null?h:0,r=(f=(S=(g=i.documentSkeleton)==null?void 0:g.getSkeletonData())==null?void 0:S.pages[0].width)!=null?f:0,o=i.verticalAlign,s=i.horizontalAlign;let l=0;switch(o){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-r;break;case a.HorizontalAlign.CENTER:c=(n.mergeInfo.endX-n.mergeInfo.startX-r)/2;break;case a.HorizontalAlign.UNSPECIFIED:{e&&(c=n.mergeInfo.endX-n.mergeInfo.startX-r);break}}return{paddingLeft:c,paddingTop:l}}const bp=(n,i,e,t,r,o)=>{var D,N,W;const s=n.get(a.IUniverInstanceService),l=n.get(T.IRenderManagerService),c=s.getUnit(i,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(exports.SheetSkeletonManagerService).getSkeletonParam(d.getSheetId()),g=h==null?void 0:h.skeleton;if(!g||!u)return;const S=g.getFont(t,r),f=S==null?void 0:S.documentSkeleton;if(!f)return null;const p=(N=(D=f.getViewModel().getBody())==null?void 0:D.customRanges)==null?void 0:N.find(H=>H.rangeId===o);if(!p)return null;const v=$.DOC_VERTICAL_PADDING,C=g.getCellWithCoordByIndex(t,r);let{actualColumn:b,actualRow:R}=C;g.overflowCache.forValue((H,L,U)=>{U.startRow<=R&&U.endRow>=R&&U.startColumn<=b&&U.endColumn>=b&&(b=L,R=H)});const E=g.getCellWithCoordByIndex(R,b),P=d.getCell(E.actualRow,E.actualColumn),{topOffset:y=0,leftOffset:M=0}=(W=P==null?void 0:P.fontRenderExtension)!=null?W:{},{paddingLeft:O,paddingTop:A}=Jc(E,S,!1),k=Bs({startOffset:p.startIndex,endOffset:p.endIndex},f);return{rects:k==null?void 0:k.map(H=>({top:H.top+E.mergeInfo.startY+A+y+v,bottom:H.bottom+E.mergeInfo.startY+A+y+v,left:H.left+E.mergeInfo.startX+O+M,right:H.right+E.mergeInfo.startX+O+M})),customRange:p,label:f.getViewModel().getBody().dataStream.slice(p.startIndex,p.endIndex+1)}},Rp=(n,i,e,t,r,o)=>{var M,O,A;const s=n.get(me),l=s.getEditCellState();if(!l||!s.isVisible().visible)return null;const{editorUnitId:d,unitId:u,sheetId:h,row:g,column:S}=l;if(i!==u||e!==h||g!==t||S!==r)return null;const f=n.get(T.IRenderManagerService),p=f.getRenderById(d),v=f.getRenderById(i);if(!p||!v)return null;const C=p.with(_e.DocSkeletonManagerService).getSkeleton(),b=(M=v.with(exports.SheetSkeletonManagerService).getSkeletonParam(h))==null?void 0:M.skeleton;if(!C||!b)return null;const R=(A=(O=C.getViewModel().getBody())==null?void 0:O.customRanges)==null?void 0:A.find(k=>k.rangeId===o);if(!R)return null;const E=4,P=Bs({startOffset:R.startIndex,endOffset:R.endIndex},C),y=p.engine.getCanvasElement().getBoundingClientRect();return{rects:P==null?void 0:P.map(k=>({top:k.top+y.top-E,bottom:k.bottom+y.top+E,left:k.left+y.left,right:k.right+y.left})),customRange:R,label:C.getViewModel().getBody().dataStream.slice(R.startIndex,R.endIndex+1)}};var Ep=Object.getOwnPropertyDescriptor,wp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Ep(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ba=(n,i)=>(e,t)=>i(e,t,n);function Nt(n){const{workbook:i,worksheet:e,...t}=n;return t}exports.HoverManagerService=class extends a.Disposable{constructor(e,t){super();w(this,"_currentCell$",new x.BehaviorSubject(null));w(this,"_currentRichText$",new x.BehaviorSubject(null));w(this,"_currentClickedCell$",new x.Subject);w(this,"_currentDbClickedCell$",new x.Subject);w(this,"_currentCellWithEvent$",new x.Subject);w(this,"_currentPointerDownCell$",new x.Subject);w(this,"_currentPointerUpCell$",new x.Subject);w(this,"_currentHoveredRowHeader$",new x.BehaviorSubject(null));w(this,"_currentHoveredColHeader$",new x.BehaviorSubject(null));w(this,"_currentRowHeaderClick$",new x.Subject);w(this,"_currentColHeaderClick$",new x.Subject);w(this,"_currentRowHeaderDbClick$",new x.Subject);w(this,"_currentColHeaderDbClick$",new x.Subject);w(this,"_currentRowHeaderPointerDown$",new x.Subject);w(this,"_currentColHeaderPointerDown$",new x.Subject);w(this,"_currentRowHeaderPointerUp$",new x.Subject);w(this,"_currentColHeaderPointerUp$",new x.Subject);w(this,"currentCell$",this._currentCell$.asObservable().pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)})));w(this,"currentRichTextNoDistinct$",this._currentRichText$.pipe(x.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})));w(this,"currentRichText$",this._currentRichText$.pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h,g,S,f,p,v,C,b,R,E,P;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)&&((g=e==null?void 0:e.customRange)==null?void 0:g.rangeId)===((S=t==null?void 0:t.customRange)==null?void 0:S.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)===((R=t==null?void 0:t.customRange)==null?void 0:R.endIndex)&&((E=e==null?void 0:e.drawing)==null?void 0:E.drawingId)===((P=t==null?void 0:t.drawing)==null?void 0:P.drawingId)}),x.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})));w(this,"currentCellPosWithEvent$",this._currentCellWithEvent$.pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)}),x.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,event:e.event})));w(this,"currentPosition$",this._currentCell$.asObservable());w(this,"currentClickedCell$",this._currentClickedCell$.asObservable());w(this,"currentDbClickedCell$",this._currentDbClickedCell$.asObservable());w(this,"currentPointerDownCell$",this._currentPointerDownCell$.asObservable());w(this,"currentPointerUpCell$",this._currentPointerUpCell$.asObservable());w(this,"currentHoveredRowHeader$",this._currentHoveredRowHeader$.asObservable());w(this,"currentHoveredColHeader$",this._currentHoveredColHeader$.asObservable());w(this,"currentRowHeaderClick$",this._currentRowHeaderClick$.asObservable());w(this,"currentColHeaderClick$",this._currentColHeaderClick$.asObservable());w(this,"currentRowHeaderDbClick$",this._currentRowHeaderDbClick$.asObservable());w(this,"currentColHeaderDbClick$",this._currentColHeaderDbClick$.asObservable());w(this,"currentRowHeaderPointerDown$",this._currentRowHeaderPointerDown$.asObservable());w(this,"currentColHeaderPointerDown$",this._currentColHeaderPointerDown$.asObservable());w(this,"currentRowHeaderPointerUp$",this._currentRowHeaderPointerUp$.asObservable());w(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,r;((t=this._currentCell$.getValue())==null?void 0:t.location.unitId)===e.getUnitId()&&this._currentCell$.next(null),((r=this._currentRichText$.getValue())==null?void 0:r.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 r=t.getActiveSheet();if(!r)return null;const o=this._renderManagerService.getRenderById(t.getUnitId());if(!o)return null;const s=o.with(exports.SheetSkeletonManagerService).getSkeletonParam(r.getSheetId());if(!s)return null;const l=o.with(exports.SheetScrollManagerService);if(!(!(l!=null&&l.getCurrentScrollState())||!o))return{currentRender:o,workbook:t,worksheet:r,skeletonParam:s}}_calcActiveCell(e,t,r,o,s,l){var y,M,O;const c=Jl(e,t,r,o,s,l),d=o.skeleton;if(!c)return null;const{position:u,overflowLocation:h,location:g}=c,S=d.getFont(h.row,h.col);let f=null,p=null,v=null;const C=d.getCellWithCoordByIndex(h.row,h.col),b=r.getCell(h.row,h.col),{topOffset:R=0,leftOffset:E=0}=(y=b==null?void 0:b.fontRenderExtension)!=null?y:{};if(S!=null&&S.documentSkeleton){const{paddingLeft:A,paddingTop:k}=Jc(C,S,(b==null?void 0:b.v)!==null&&(b==null?void 0:b.v)!==void 0?!Number.isNaN(+b.v):!1),D=Qc(S.documentSkeleton,A,k),N=s-u.startX-E,W=l-u.startY-R;f=D.links.find(H=>H.rects.some(L=>L.left<=N&&N<=L.right&&L.top<=W&&W<=L.bottom)),p=D.checkLists.find(H=>H.rect.left<=N&&N<=H.rect.right&&H.rect.top<=W&&W<=H.rect.bottom),v=D.drawings.find(H=>H.rect.left<=N&&N<=H.rect.right&&H.rect.top<=W&&W<=H.rect.bottom)}const P=(O=(M=f==null?void 0:f.rects.pop())!=null?M:p==null?void 0:p.rect)!=null?O:v==null?void 0:v.rect;return{location:g,position:u,overflowLocation:h,customRange:f==null?void 0:f.range,bullet:p==null?void 0:p.paragraph,drawing:v,rect:P&&{top:P.top+C.mergeInfo.startY+R,bottom:P.bottom+C.mergeInfo.startY+R,left:P.left+C.mergeInfo.startX+E,right:P.right+C.mergeInfo.startX+E}}}_calcActiveRowHeader(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,worksheet:l,skeletonParam:c}=o,{scaleY:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(S=>S.isHit(new T.Vector2(t,r)));if(!u||u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP&&u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},g=c.skeleton.getRowIndexByOffsetY(r,d,h);return{unitId:e,index:g,subUnitId:l.getSheetId()}}_calcActiveColHeader(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,worksheet:l,skeletonParam:c}=o,{scaleX:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(S=>S.isHit(new T.Vector2(t,r)));if(!u||u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT&&u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},g=c.skeleton.getColumnIndexByOffsetX(t,d,h);return{unitId:e,index:g,subUnitId:l.getSheetId()}}triggerPointerDown(e,t){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:o,workbook:s,worksheet:l,skeletonParam:c}=r,d=this._calcActiveCell(o,s,l,c,t.offsetX,t.offsetY);if(d&&d.location){const{unitId:u,subUnitId:h,row:g,col:S}=Nt(d.location);this._currentPointerDownCell$.next({unitId:u,subUnitId:h,row:g,col:S,event:t})}}triggerPointerUp(e,t){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:o,workbook:s,worksheet:l,skeletonParam:c}=r,d=this._calcActiveCell(o,s,l,c,t.offsetX,t.offsetY);if(d){const u=Nt(d.location);this._currentPointerUpCell$.next({...u,event:t})}}triggerMouseMove(e,t){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:o,workbook:s,worksheet:l,skeletonParam:c}=r,d=this._calcActiveCell(o,s,l,c,t.offsetX,t.offsetY);this._currentCell$.next(d&&{location:Nt(d.location),position:d.position}),this._currentRichText$.next(d&&{...d,location:Nt(d.overflowLocation)}),this._currentCellWithEvent$.next(d&&{...d,location:Nt(d.location),event:t})}triggerClick(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=o,u=this._calcActiveCell(s,l,c,d,t,r);u&&this._currentClickedCell$.next({...u,location:Nt(u.location)})}triggerDbClick(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=o,u=this._calcActiveCell(s,l,c,d,t,r);u&&this._currentDbClickedCell$.next({...u,location:Nt(u.location)})}triggerScroll(){this._currentCell$.next(null)}triggerRowHeaderClick(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderClick$.next(o)}triggerColHeaderClick(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderClick$.next(o)}triggerRowHeaderDbClick(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderDbClick$.next(o)}triggerColHeaderDbClick(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderDbClick$.next(o)}triggerRowHeaderMouseMove(e,t,r){this._currentHoveredRowHeader$.next(this._calcActiveRowHeader(e,t,r))}triggerColHeaderMouseMove(e,t,r){this._currentHoveredColHeader$.next(this._calcActiveColHeader(e,t,r))}triggerRowHeaderPoniterDown(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderPointerDown$.next(o)}triggerColHeaderPoniterDown(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderPointerDown$.next(o)}triggerRowHeaderPoniterUp(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderPointerUp$.next(o)}triggerColHeaderPoniterUp(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderPointerUp$.next(o)}};exports.HoverManagerService=wp([Ba(0,a.IUniverInstanceService),Ba(1,T.IRenderManagerService)],exports.HoverManagerService);var Tp=Object.getOwnPropertyDescriptor,yp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Tp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Yr=(n,i)=>(e,t)=>i(e,t,n);const Po="SHEET_FORCE_STRING_ALERT";let fi=class extends a.Disposable{constructor(n,i,e,t,r){super(),this._context=n,this._hoverManagerService=i,this._cellAlertManagerService=e,this._localeService=t,this._zenZoneService=r,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(n=>{var i;if(n){const t=this._context.unit.getActiveSheet();if(!t)return;const r=t.getCell(n.location.row,n.location.col);if((r==null?void 0:r.t)===a.CellValueType.FORCE_STRING&&r.v&&a.isRealNum(r.v)){const o=this._cellAlertManagerService.currentAlert.get(Po),s=(i=o==null?void 0:o.alert)==null?void 0:i.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:Po});return}}this._hideAlert()}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(n=>{n&&this._hideAlert()}))}_hideAlert(){this._cellAlertManagerService.removeAlert(Po)}};fi=yp([Yr(1,a.Inject(exports.HoverManagerService)),Yr(2,a.Inject(exports.CellAlertManagerService)),Yr(3,a.Inject(a.LocaleService)),Yr(4,I.IZenZoneService)],fi);var Mp=Object.getOwnPropertyDescriptor,Pp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Mp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Fa=(n,i)=>(e,t)=>i(e,t,n);let pi=class extends a.RxDisposable{constructor(n,i,e){super(),this._context=n,this._sheetSkeletonManagerService=i,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:(i,e,t)=>{var s,l;if(!((s=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:s.skeleton))return t(i);const o=e.worksheet.getCellRaw(e.row,e.col);if(!o||o.v===null||o.v===void 0)return t(i);if(((i==null?void 0:i.t)===a.CellValueType.FORCE_STRING||(i==null?void 0:i.t)===a.CellValueType.STRING)&&a.isRealNum(o.v)){const c=e.workbook.getStyles().get(o.s);return Ai.isTextFormat((l=c==null?void 0:c.n)==null?void 0:l.pattern)?t(i):t({...i,markers:{...i==null?void 0:i.markers,...n}})}return t(i)}}))}};pi=Pp([Fa(1,a.Inject(exports.SheetSkeletonManagerService)),Fa(2,a.Inject(m.SheetInterceptorService))],pi);var Op=Object.getOwnPropertyDescriptor,xp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Op(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Oo=(n,i)=>(e,t)=>i(e,t,n);exports.HoverRenderController=class extends a.Disposable{constructor(e,t,r,o){super();w(this,"_active",!1);this._context=e,this._hoverManagerService=t,this._sheetSkeletonManagerService=r,this._scrollManagerService=o,this._initPointerEvent(),this._initScrollEvent()}get active(){return this._active}_initPointerEvent(){const e=new a.DisposableCollection,t=r=>{if(e.dispose(),!r)return;const{mainComponent:o,unitId:s,components:l}=this._context;if(!o)return;e.add(o.onPointerEnter$.subscribeEvent(u=>{this._active=!0})),e.add(a.fromEventSubject(o.onPointerMove$).subscribe(u=>{this._active=!0,this._hoverManagerService.triggerMouseMove(s,u)})),e.add(o.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerDown(s,u)})),e.add(o.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerUp(s,u)})),e.add(o.onClick$.subscribeEvent(u=>{this._hoverManagerService.triggerClick(s,u.offsetX,u.offsetY)})),e.add(o.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerDbClick(s,u.offsetX,u.offsetY)})),e.add(o.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(r=>{t(r)}))}_initScrollEvent(){this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(()=>this._hoverManagerService.triggerScroll()))}};exports.HoverRenderController=xp([Oo(1,a.Inject(exports.HoverManagerService)),Oo(2,a.Inject(exports.SheetSkeletonManagerService)),Oo(3,a.Inject(exports.SheetScrollManagerService))],exports.HoverRenderController);var Ap=Object.getOwnPropertyDescriptor,kp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Ap(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},xo=(n,i)=>(e,t)=>i(e,t,n);let vi=class extends a.Disposable{constructor(n,i,e,t){super(),this._context=n,this._markSelectionService=i,this._commandService=e,this._sheetSkeletonManagerService=t,this._initListeners()}_initListeners(){this._addRemoveListener(),this._addRefreshListener()}_addRemoveListener(){const n=[fe.id];this.disposeWithMe(this._commandService.onCommandExecuted(i=>{n.includes(i.id)?this._markSelectionService.removeAllShapes():this._markSelectionService.getShapeMap().forEach((t,r)=>{t.exits.includes(i.id)&&this._markSelectionService.removeShape(r)})}))}_addRefreshListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(n=>{n&&this._markSelectionService.refreshShapes()}))}};vi=kp([xo(1,a.Inject(Qt)),xo(2,a.ICommandService),xo(3,a.Inject(exports.SheetSkeletonManagerService))],vi);const Dp="univer-mobile-sheet-bar-container",Np="univer-mobile-sheet-bar-slider",Hp="univer-mobile-sheet-bar-item",Vp="univer-mobile-sheet-bar-item-activated",Gr={mobileSheetBarContainer:Dp,mobileSheetBarSlider:Np,mobileSheetBarItem:Hp,mobileSheetBarItemActivated:Vp};function $c(){const n=Et();return n?_.jsx(Wp,{workbook:n}):null}function Wp(n){const{workbook:i}=n,[e,t]=V.useState([]),[r,o]=V.useState(""),s=V.useRef(new Map),l=I.useDependency(a.ICommandService),c=V.useCallback(()=>{const u=i.getActiveSheet().getSheetId(),h=i.getSheets(),g=i.getActiveSheet(),S=h.filter(f=>!f.isSheetHidden()).map((f,p)=>{var v;return{sheetId:f.getSheetId(),label:f.getName(),index:p,selected:g===f,color:(v=f.getTabColor())!=null?v:void 0}});if(t(S),o(u),s.current.has(u)){const f=s.current.get(u);f&&f.scrollIntoView({behavior:"smooth",block:"nearest"})}s.current.clear()},[i]);V.useEffect(()=>c(),[c]);const d=V.useCallback(u=>{l.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:i.getUnitId(),subUnitId:u})},[l,i]);return V.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:Gr.mobileSheetBarContainer,children:_.jsx("div",{className:Gr.mobileSheetBarSlider,children:e.map(u=>_.jsx("div",{className:X.clsx(Gr.mobileSheetBarItem,{[Gr.mobileSheetBarItemActivated]:u.sheetId===r}),onClick:()=>d(u.sheetId),ref:h=>{s.current.set(u.sheetId,h)},children:u.label},u.sheetId))})})}const Lp={[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 Up=Object.getOwnPropertyDescriptor,Bp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Up(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ht=(n,i)=>(e,t)=>i(e,t,n);let Ci=class extends a.Disposable{constructor(n,i,e,t,r,o,s){super(),this._injector=n,this._componentManager=i,this._layoutService=e,this._commandService=t,this._shortcutService=r,this._menuManagerService=o,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(et,Bl)),this.disposeWithMe(n.register(Us,oc)),this.disposeWithMe(n.register(Or,X.ColorPicker)),this.disposeWithMe(n.register(zi,I.FontFamily)),this.disposeWithMe(n.register(Xi,I.FontFamilyItem)),this.disposeWithMe(n.register(Yi,I.FontSize)),this.disposeWithMe(n.register(ar,sc))}_initCommands(){[Hs,yt,Ws,Vs,kn,De,xe,Je,Ur,Hr,On,xn,_r,br,Fe,_s,pr,Bi,m.SetBoldCommand,Yt,fe,fr,Jt,$t,en,tn,ks,Ds,Rr,Er,yn,m.SetItalicCommand,m.SetStrikeThroughCommand,m.SetFontFamilyCommand,m.SetFontSizeCommand,wr,ji,Nn,Tr,Be,Rn,ht,yr,Mr,m.SetUnderlineCommand,Dn,Le,Vr,Sr,Zt,Gt,Un,Ln,Ui,Ct,_n,qe,Ls,kr,Ut,Bt,Dr,Nr,Lr,Ft,jt,Wr].forEach(n=>{this.disposeWithMe(this._commandService.registerCommand(n))})}_initMenus(){this._menuManagerService.mergeMenu(Lp)}_initShortcuts(){[gc,Sc,fc,pc,vc,Cc,Ic,_c,bc,Rc,Ec,wc,Tc,yc,Mc,Pc,Oc,xc,Ac,kc,Dc,Uc,Fc,zc,Xc,Bc,jc,Nc,Hc,Vc,Wc,Lc,...Tl(),Ml,yl,Pl,xl,Al,kl,Ol,hc,mc].forEach(n=>{this.disposeWithMe(this._shortcutService.registerShortcut(n))})}_initWorkbenchParts(){this._uiPartsService.registerComponent(I.BuiltInUIPart.HEADER,()=>I.connectInjector($c,this._injector))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(a.UniverInstanceType.UNIVER_SHEET,n=>{}))}};Ci=Bp([Ht(0,a.Inject(a.Injector)),Ht(1,a.Inject(I.ComponentManager)),Ht(2,I.ILayoutService),Ht(3,a.ICommandService),Ht(4,I.IShortcutService),Ht(5,I.IMenuManagerService),Ht(6,I.IUIPartsService)],Ci);const Ao="UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID",ed="UNIVER_SHEET_PERMISSION_ALERT_DIALOG";var Fp=Object.getOwnPropertyDescriptor,jp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Fp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},nt=(n,i)=>(e,t)=>i(e,t,n);exports.SheetPermissionCheckUIController=class extends a.Disposable{constructor(e,t,r,o,s,l,c,d,u){super();w(this,"disposableCollection",new a.DisposableCollection);this._commandService=e,this._univerInstanceService=t,this._permissionService=r,this._dialogService=o,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:Ao,title:{title:"permission.dialog.alert"},children:{label:ed,errorMsg:e},width:320,destroyOnClose:!0,showOk:!0,onClose:()=>{this._dialogService.close(Ao)},onOk:()=>{this._dialogService.close(Ao)},className:"sheet-permission-user-dialog"};this._permissionService.getShowComponents()&&this._dialogService.open(t)}_getPermissionCheck(e,t){var s,l;let r=!0,o="";switch(e){case $.InsertCommand.id:case $.IMEInputCommand.id:if(this._contextService.getContextValue(a.FOCUSING_EDITOR_STANDALONE)===!0)break;r=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),o=this._localeService.t("permission.dialog.editErr");break;case fe.id:if(t.visible===!1)break;r=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),o=this._localeService.t("permission.dialog.editErr");break;case Lt.id:r=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetColumnStylePermission]}),o=this._localeService.t("permission.dialog.pasteErr");break;case di.id:r=this._permissionCheckByPaste(t),o=this._localeService.t("permission.dialog.pasteErr");break;case Tr.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetCellValuePermission,m.WorksheetSetCellStylePermission]}),o=this._localeService.t("permission.dialog.commonErr");break;case m.SetBackgroundColorCommand.id:case Jt.id:case $t.id:case en.id:case tn.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}),o=this._localeService.t("permission.dialog.setStyleErr");break;case je.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission],rangeTypes:[m.RangeProtectionPermissionViewPoint],worksheetTypes:[m.WorksheetCopyPermission]}),o=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||(o=this._localeService.t("permission.dialog.workbookCopyErr"));break;case Fi.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission,m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionViewPoint,m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetCopyPermission,m.WorksheetEditPermission]}),o=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||(o=this._localeService.t("permission.dialog.workbookCopyErr"));break;case Ct.id:r=this._permissionCheckByAutoFillCommand(t),o=this._localeService.t("permission.dialog.autoFillErr");break}r||this._sheetPermissionCheckController.blockExecuteWithoutPermission(o)}_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===Se.SPECIAL_PASTE_VALUE||e.value===Se.SPECIAL_PASTE_FORMULA?this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}):e.value===Se.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,r=m.getSheetCommandTarget(this._univerInstanceService);if(!r)return!1;const{worksheet:o,unitId:s,subUnitId:l}=r;return!this._rangeProtectionRuleModel.getSubunitRuleList(s,l).reduce((u,h)=>[...u,...h.ranges],[]).filter(u=>a.Rectangle.intersects(u,t)).some(u=>{var h,g;for(let S=u.startRow;S<=u.endRow;S++)for(let f=u.startColumn;f<=u.endColumn;f++){const p=(g=(h=o.getCell(S,f))==null?void 0:h.selectionProtection)==null?void 0:g[0];if((p==null?void 0:p[re.Edit])===!1)return!0}return!1})}};exports.SheetPermissionCheckUIController=jp([nt(0,a.ICommandService),nt(1,a.IUniverInstanceService),nt(2,a.IPermissionService),nt(3,I.IDialogService),nt(4,a.Inject(m.RangeProtectionRuleModel)),nt(5,wt),nt(6,a.Inject(a.LocaleService)),nt(7,a.IContextService),nt(8,a.Inject(m.SheetPermissionCheckController))],exports.SheetPermissionCheckUIController);var zp=Object.getOwnPropertyDescriptor,Xp=(n,i,e,t)=>{for(var r=t>1?void 0:t?zp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},rt=(n,i)=>(e,t)=>i(e,t,n);let Ii=class extends a.RxDisposable{constructor(i,e,t,r,o,s,l,c,d,u){super();w(this,"disposableCollection",new a.DisposableCollection);this._context=i,this._univerInstanceService=e,this._permissionService=t,this._selectionManagerService=r,this._rangeProtectionRuleModel=o,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 i=this._headerMoveRenderController.interceptor.getInterceptPoints().HEADER_MOVE_PERMISSION_CHECK;this.disposeWithMe(this._headerMoveRenderController.interceptor.intercept(i,{handler:(e,t)=>{const r=m.getSheetCommandTarget(this._univerInstanceService);if(!r)return!1;const{unitId:o,subUnitId:s}=r;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(o).id,new m.WorksheetEditPermission(o,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(o,s,c,[re.Edit])===!1)return!1}else for(let c=t.startColumn;c<=t.endColumn;c++)if(this._rangeProtectionCache.getColPermissionInfo(o,s,c,[re.Edit])===!1)return!1;return!0}}))}_initHeaderResizePermissionInterceptor(){this._headerResizeRenderController&&this.disposeWithMe(this._headerResizeRenderController.interceptor.intercept(this._headerResizeRenderController.interceptor.getInterceptPoints().HEADER_RESIZE_PERMISSION_CHECK,{handler:(i,e)=>{var s,l,c,d;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{unitId:r,subUnitId:o}=t;if(e.row){if(((l=(s=this._permissionService.getPermissionPoint(new m.WorksheetSetRowStylePermission(r,o).id))==null?void 0:s.value)!=null?l:!1)===!1)return!1}else if(e.col&&((d=(c=this._permissionService.getPermissionPoint(new m.WorksheetSetColumnStylePermission(r,o).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:(i,e)=>{var f,p,v;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:r,unitId:o,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(o).id,new m.WorksheetEditPermission(o,s).id,new m.WorksheetSetCellValuePermission(o,s).id,new m.WorksheetSetCellStylePermission(o,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=nr(e.x,e.y,e.scene,e.skeleton),R=e.skeleton.getCellWithCoordByIndex(C.endRow,C.endColumn),E=Math.abs(R.endX-b.x),P=Math.abs(R.endY-b.y);return E<=5&&P<=5});if(!d)return!0;const{startRow:u,endRow:h,startColumn:g,endColumn:S}=d;for(let C=u;C<=h;C++)for(let b=g;b<=S;b++){const R=(v=(p=r.getCell(C,b))==null?void 0:p.selectionProtection)==null?void 0:v[0];if((R==null?void 0:R[re.Edit])===!1||(R==null?void 0:R[re.View])===!1)return!1}return!0}}))}_initRangeMovePermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_MOVE_PERMISSION_CHECK,{handler:(i,e)=>{var g;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:r,unitId:o,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(o).id,new m.WorksheetEditPermission(o,s).id]).every(S=>S.value))return!1;const c=(g=this._selectionManagerService.getCurrentSelections())==null?void 0:g.map(S=>S.range),d=this._rangeProtectionRuleModel.getSubunitRuleList(o,s).reduce((S,f)=>[...S,...f.ranges],[]),u=c==null?void 0:c.filter(S=>d.some(f=>a.Rectangle.intersects(f,S)));return!(u==null?void 0:u.some(S=>{var b,R;const{startRow:f,startColumn:p,endRow:v,endColumn:C}=S;for(let E=f;E<=v;E++)for(let P=p;P<=C;P++){const y=(R=(b=r.getCell(E,P))==null?void 0:b.selectionProtection)==null?void 0:R[0];if((y==null?void 0:y[re.Edit])===!1)return!0}return!1}))}}))}_initFreezePermissionInterceptor(){this.disposeWithMe(this._headerFreezeRenderController.interceptor.intercept(this._headerFreezeRenderController.interceptor.getInterceptPoints().FREEZE_PERMISSION_CHECK,{handler:(i,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}}))}};Ii=Xp([rt(1,a.IUniverInstanceService),rt(2,a.IPermissionService),rt(3,a.Inject(m.SheetsSelectionsService)),rt(4,a.Inject(m.RangeProtectionRuleModel)),rt(5,a.Inject(exports.HeaderMoveRenderController)),rt(6,Ce),rt(7,a.Inject(exports.HeaderFreezeRenderController)),rt(8,a.Inject(m.RangeProtectionCache)),rt(9,a.Optional(exports.HeaderResizeRenderController))],Ii);var Yp=Object.getOwnPropertyDescriptor,Gp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Yp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Gn=(n,i)=>(e,t)=>i(e,t,n);const Zp="SHEET_PERMISSION_PASTE_PLUGIN";let ur=class extends a.Disposable{constructor(i,e,t,r,o){super();w(this,"disposableCollection",new a.DisposableCollection);this._univerInstanceService=i,this._selectionManagerService=e,this._localService=t,this._sheetClipboardService=r,this._sheetPermissionCheckController=o,this._initClipboardHook()}_initClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook({id:Zp,onBeforePaste:i=>{var g,S,f;const[e]=Kt([i.range]).ranges,t=(g=this._selectionManagerService.getCurrentLastSelection())==null?void 0:g.range;if(!t)return!1;const r={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}=r;let h=!0;for(let p=l;p<=c;p++)for(let v=d;v<=u;v++){const C=(f=(S=s.getCell(p,v))==null?void 0:S.selectionProtection)==null?void 0:f[0];if((C==null?void 0:C[re.Edit])===!1){h=!1;break}}return h||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localService.t("permission.dialog.pasteErr")),h}}))}};ur=Gp([Gn(0,a.IUniverInstanceService),Gn(1,a.Inject(m.SheetsSelectionsService)),Gn(2,a.Inject(a.LocaleService)),Gn(3,a.Inject(Ue)),Gn(4,a.Inject(m.SheetPermissionCheckController))],ur);var Kp=Object.getOwnPropertyDescriptor,qp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Kp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Zn=(n,i)=>(e,t)=>i(e,t,n);const Qp=a.createInterceptorKey("statusBarPermissionCorrect");class Jp{constructor(){w(this,"_sum",0);w(this,"_count",0);w(this,"_countNumber",0);w(this,"_min",Number.POSITIVE_INFINITY);w(this,"_max",Number.NEGATIVE_INFINITY)}add(i,e,t){if(!(i!=null&&i.v))return;const r=i==null?void 0:i.t;let{v:o}=i;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 S;if(!((S=c==null?void 0:c.n)!=null&&S.pattern))return;const{pattern:h}=c.n;u[h]||(u[h]=a.numfmt.getInfo(h)),u[h].isDate&&s(d)};if(typeof o=="string"&&r===a.CellValueType.NUMBER){const c=Number(o);Number.isNaN(c)||(o=c)}if(typeof o=="number"&&r!==a.CellValueType.STRING)s(o);else if(r===a.CellValueType.NUMBER&&i.s){const c=e.get(i.s);l(c,o,t)}this._count++}getResults(){return{sum:this._sum,count:this._countNumber,countA:this._count,min:this._min,max:this._max}}}function $p(n){const{sum:i,count:e,countA:t,min:r,max:o}=n.getResults();return[{func:K.FUNCTION_NAMES_STATISTICAL.MAX,value:o},{func:K.FUNCTION_NAMES_STATISTICAL.MIN,value:r},{func:K.FUNCTION_NAMES_MATH.SUM,value:i},{func:K.FUNCTION_NAMES_STATISTICAL.COUNTA,value:t},{func:K.FUNCTION_NAMES_STATISTICAL.COUNT,value:e},{func:K.FUNCTION_NAMES_STATISTICAL.AVERAGE,value:i/e}]}exports.StatusBarController=class extends a.Disposable{constructor(e,t,r,o,s){super();w(this,"interceptor",new a.InterceptorManager({STATUS_BAR_PERMISSION_CORRECT:Qp}));this._univerInstanceService=e,this._selectionManagerService=t,this._statusBarService=r,this._commandService=o,this._numfmtService=s,this._init()}_init(){this._registerSelectionListener()}_registerSelectionListener(){const e=a.debounce(r=>{var s;const o=(s=r[r.length-1])==null?void 0:s.primary;this._calculateSelection(r.map(l=>l.range),o)},100),t=a.debounce(r=>{var s;const o=(s=r[r.length-1])==null?void 0:s.primary;this._calculateSelection(r.map(l=>l.range),o)},500);this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoving$.subscribe(r=>{r&&t(r)}))),this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoveEnd$.subscribe(r=>{r&&e(r)}))),this.disposeWithMe(this._commandService.onCommandExecuted(r=>{if(r.id===m.SetRangeValuesMutation.id){const o=this._selectionManagerService.getCurrentSelections();o&&e(o)}}))}_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 r=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!r)return this._clearResult();const o=r.getUnitId(),s=r.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(R=>{const{startRow:E,endRow:P}=R;let y=null;for(let M=E;M<=P;M++)s.getRowVisible(M)?y===null&&(y=M):y!==null&&(u.push({...R,startRow:y,endRow:M-1}),y=null);y!==null&&u.push({...R,startRow:y,endRow:P})});const h=a.splitIntoGrid(u),g=new Jp,S=r.getStyles(),f={};for(const R of h){const{startRow:E,startColumn:P,endColumn:y,endRow:M}=this.getRangeStartEndInfo(R,s);for(let O=E;O<=M;O++)for(let A=P;A<=y;A++){const k=s.getCellRaw(O,A);g.add(k,S,f)}}const p=$p(g);if(p.every(R=>R===void 0))return;let v=null;if(t){const{actualRow:R,actualColumn:E}=t;v=(d=this._numfmtService.getValue(o,l,R,E))==null?void 0:d.pattern}const b={values:p.filter(R=>R!==void 0),pattern:v};this._statusBarService.setState(b)}else this._clearResult()}};exports.StatusBarController=qp([Zn(0,a.IUniverInstanceService),Zn(1,a.Inject(m.SheetsSelectionsService)),Zn(2,Ir),Zn(3,a.ICommandService),Zn(4,a.Inject(m.INumfmtService))],exports.StatusBarController);var ev=Object.getOwnPropertyDescriptor,tv=(n,i,e,t)=>{for(var r=t>1?void 0:t?ev(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Zr=(n,i)=>(e,t)=>i(e,t,n);let _i=class extends a.RxDisposable{constructor(i,e,t,r,o){super();w(this,"disposableCollection",new a.DisposableCollection);this._context=i,this._univerInstanceService=e,this._permissionService=t,this._statusBarController=r,this._rangeProtectionCache=o,this._initStatusBarPermissionInterceptor()}_initStatusBarPermissionInterceptor(){this.disposeWithMe(this._statusBarController.interceptor.intercept(this._statusBarController.interceptor.getInterceptPoints().STATUS_BAR_PERMISSION_CORRECT,{priority:100,handler:(i,e)=>{var c;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return i!=null?i:[];const{worksheet:r,unitId:o,subUnitId:s}=t;return((c=this._permissionService.getPermissionPoint(new m.WorksheetViewPermission(o,s).id))==null?void 0:c.value)===!1?e.forEach(d=>{const u=d.getArrayValue();u.forEach((h,g)=>{h.forEach((S,f)=>{u[g][f]=K.NullValueObject.create()})})}):e.forEach(d=>{const u=d.getArrayValue(),h=d.getCurrentRow(),g=d.getCurrentColumn();u.forEach((S,f)=>{S.forEach((p,v)=>{var R;if(((R=r.getCellRaw(f+h,v+g))==null?void 0:R.v)===void 0)return;const b=this._rangeProtectionCache.getCellInfo(o,s,f+h,v+g);(b==null?void 0:b[re.View])===!1&&(u[f][v]=K.NullValueObject.create())})})}),e}}))}};_i=tv([Zr(1,a.IUniverInstanceService),Zr(2,a.IPermissionService),Zr(3,a.Inject(exports.StatusBarController)),Zr(4,a.Inject(m.RangeProtectionCache))],_i);const td=(n,i,e,t,r)=>{const o=n.get(a.LocaleService),s=n.get(m.WorksheetProtectionRuleModel),l=n.get(m.RangeProtectionRuleModel);let c="";if(i.length===0)c=o.t("permission.panel.emptyRangeError");else if(i.length>1){let d=!1;for(let u=0;u<i.length;u++){for(let h=u+1;h<i.length;h++)if(a.Rectangle.intersects(i[u],i[h])){d=!0;break}if(d)break}d&&(c=o.t("permission.panel.rangeOverlapError"))}if(!c){if(s.getRule(t,r)&&!e)return c=o.t("permission.panel.rangeOverlapOverPermissionError"),c;const u=l.getSubunitRuleList(t,r).filter(g=>g.permissionId!==e).find(g=>g.ranges.some(S=>i.some(f=>a.Rectangle.intersects(S,f))));(u==null?void 0:u.ranges.find(g=>i.some(S=>a.Rectangle.intersects(g,S))))&&(c=o.t("permission.panel.rangeOverlapOverPermissionError"))}return c===""?void 0:c},nv=(n,i)=>{if(n.length!==1)return!1;const e=n[0],t=i.getRowCount(),r=i.getColumnCount(),{startRow:o,endRow:s,startColumn:l,endColumn:c}=e;return o===0&&l===0&&s===t-1&&c===r-1},rv=(n,i)=>{var c,d;const e=n.get(a.IUniverInstanceService),t=n.get(m.SheetsSelectionsService),r=e.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),o=r.getActiveSheet();let s=m.UnitObject.SelectRange,l=(d=(c=t.getCurrentSelections())==null?void 0:c.map(u=>u.range))!=null?d:[];return i&&(s=m.UnitObject.Worksheet,l=[{startRow:0,startColumn:0,endRow:o.getRowCount()-1,endColumn:o.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]),{unitId:r.getUnitId(),subUnitId:o.getSheetId(),permissionId:"",unitType:s,description:"",id:"",ranges:l,editState:m.EditStateEnum.OnlyMe,viewState:m.ViewStateEnum.OthersCanView}},iv=(n,i)=>{const r=n.get(a.IUniverInstanceService).getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getActiveSheet(),{unitType:o}=i;return o===m.UnitObject.Worksheet?{...i,ranges:[{startRow:0,startColumn:0,endRow:r.getRowCount()-1,endColumn:r.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]}:i},ov="univer-permission-panel-detail-wrapper",sv="univer-radio-group-vertical",av="univer-sheet-permission-design-person-panel",lv="univer-sheet-permission-design-person-panel-header",cv="univer-sheet-permission-design-person-panel-header-add",dv="univer-sheet-permission-design-person-panel-split",uv="univer-sheet-permission-design-person-panel-content-item",hv="univer-sheet-permission-design-person-panel-content-item-name",mv="univer-sheet-permission-design-person-panel-content-item-select",gv="univer-sheet-permission-design-person-panel-content",Sv="univer-sheet-permission-user-list-empty",fv="univer-sheet-permission-user-list-empty-text",pv="univer-sheet-permission-panel-title",vv="univer-sheet-permission-panel-footer",ve={permissionPanelDetailWrapper:ov,radioGroupVertical:sv,sheetPermissionDesignPersonPanel:av,sheetPermissionDesignPersonPanelHeader:lv,sheetPermissionDesignPersonPanelHeaderAdd:cv,sheetPermissionDesignPersonPanelSplit:dv,sheetPermissionDesignPersonPanelContentItem:uv,sheetPermissionDesignPersonPanelContentItemName:hv,sheetPermissionDesignPersonPanelContentItemSelect:mv,sheetPermissionDesignPersonPanelContent:gv,sheetPermissionUserListEmpty:Sv,sheetPermissionUserListEmptyText:fv,sheetPermissionPanelTitle:pv,sheetPermissionPanelFooter:vv},Cv=n=>{const{viewState:i,editState:e,permissionId:t,ranges:r,rangesErrMsg:o,desc:s,oldRule:l,id:c}=n,d=I.useDependency(Pn),u=I.useDependency(I.ISidebarService),h=I.useDependency(a.IAuthzIoService),g=I.useDependency(a.LocaleService),S=I.useDependency(a.ICommandService),f=I.useDependency(Mt),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(),R=C.getSheetId();return _.jsxs("div",{className:ve.sheetPermissionPanelFooter,children:[_.jsx(X.Button,{variant:"primary",onClick:async()=>{if(o)return;const E={unitId:b,subUnitId:R,permissionId:t,id:c,viewState:i,editState:e,unitType:m.UnitObject.SelectRange,ranges:r,description:s};nv(r,C)&&(E.unitType=m.UnitObject.Worksheet,E.ranges=[]);let y=f.selectUserList;E.editState===m.EditStateEnum.OnlyMe&&(y=[],f.setSelectUserList([]));const M={read:E.viewState===m.ViewStateEnum.OthersCanView?Ze.AllCollaborator:Ze.SomeCollaborator,edit:E.editState===m.EditStateEnum.DesignedUserCanEdit?Ze.SomeCollaborator:Ze.OneSelf};if(E.editState===m.EditStateEnum.DesignedUserCanEdit&&y.length===0&&(y=[],M.edit=Ze.OneSelf),E.permissionId){const A=TS(y.filter(H=>H.role===Ae.Editor),f.oldCollaboratorList.filter(H=>H.role===Ae.Editor)),k=(l==null?void 0:l.viewState)===E.viewState,D=(l==null?void 0:l.editState)===E.editState,N=E.unitType===(l==null?void 0:l.unitType)&&E.description===l.description&&E.ranges===l.ranges,W=!A||!k||!D;if(N&&W)await h.update({objectType:E.unitType,objectID:E.permissionId,unitID:E.unitId,share:void 0,name:"",strategies:[],scope:M,collaborators:{collaborators:y}});else{let H=E.permissionId;W&&(E.unitType===m.UnitObject.Worksheet?H=await h.create({worksheetObject:{collaborators:y,unitID:E.unitId,name:"",strategies:[{role:Ae.Editor,action:re.Edit},{role:Ae.Reader,action:re.View}],scope:M},objectType:m.UnitObject.Worksheet}):H=await h.create({selectRangeObject:{collaborators:y,unitID:E.unitId,name:"",scope:M},objectType:m.UnitObject.SelectRange})),S.executeCommand(m.SetProtectionCommand.id,{rule:{...E,permissionId:H},oldRule:l})}}else if(E.unitType===m.UnitObject.Worksheet){const A=await h.create({worksheetObject:{collaborators:y,unitID:E.unitId,name:"",strategies:[{role:Ae.Editor,action:re.Edit},{role:Ae.Reader,action:re.View}],scope:M},objectType:m.UnitObject.Worksheet}),{ranges:k=[],...D}=E;D.permissionId=A,S.executeCommand(m.AddWorksheetProtectionCommand.id,{rule:D,unitId:E.unitId})}else if(E.unitType===m.UnitObject.SelectRange){const A=await h.create({selectRangeObject:{collaborators:y,unitID:E.unitId,name:"",scope:M},objectType:m.UnitObject.SelectRange});S.executeCommand(m.AddRangeProtectionCommand.id,{rule:E,permissionId:A})}const O={header:{title:`${g.t("permission.panel.title")}`},children:{label:cr,showDetail:!1},width:330};u.open(O)},children:g.t("permission.button.confirm")}),_.jsx(X.Button,{className:ve.sheetPermissionPanelFooterCancel,onClick:()=>{d.reset(),f.reset(),u.close()},children:g.t("permission.button.cancel")})]})},Iv=n=>{const{ranges:i,onRangesChange:e,desc:t,onDescChange:r,rangesErrMsg:o,permissionId:s}=n,l=I.useDependency(I.ComponentManager),c=V.useMemo(()=>l.get(hs),[]),d=I.useDependency(a.IUniverInstanceService),u=I.useDependency(a.LocaleService),h=I.useDependency(a.Injector),g=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),S=g==null?void 0:g.getActiveSheet();if(!g||!S)return null;const f=g.getUnitId(),p=S.getSheetId(),v=C=>{const b=C.split(",").map(K.deserializeRangeWithSheet).map(A=>A.range);if(b.some(A=>!a.isValidRange(A)||A.endColumn<A.startColumn||A.endRow<A.startRow))return;const R=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),E=R==null?void 0:R.getActiveSheet();if(!R||!E)return;const P=R.getUnitId(),y=E.getSheetId(),M=b.map(A=>{const k=E.getRowCount(),D=E.getColumnCount();return m.setEndForRange(A,k,D),A}),O=td(h,M,s,P,y);e(M,O)};return _.jsxs(_.Fragment,{children:[_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:u.t("permission.panel.protectedRange"),error:o,children:c&&_.jsx(c,{unitId:f,subUnitId:p,initialValue:i==null?void 0:i.map(C=>K.serializeRange(C)).join(","),onChange:(C,b)=>v(b)})}),_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:u.t("permission.panel.permissionDirection"),children:_.jsx(X.Input,{value:t,onChange:C=>r(C),placeholder:u.t("permission.panel.permissionDirectionPlaceholder")})})]})},_v=n=>{var C,b;const{fromSheetBar:i,rule:e,oldRule:t}=n,r=I.useDependency(a.Injector),o=e?iv(r,e):rv(r,i),[s,l]=V.useState(o.ranges),[c,d]=V.useState(()=>td(r,o.ranges,o.permissionId,o.unitId,o.subUnitId)),[u,h]=V.useState(o.description),[g,S]=V.useState((C=o.editState)!=null?C:m.EditStateEnum.OnlyMe),[f,p]=V.useState((b=o.viewState)!=null?b:m.ViewStateEnum.OthersCanView),v=I.useComponentsOfPart(Mn);return V.useEffect(()=>{const R=r.get(a.IUniverInstanceService),E=r.get(I.ISidebarService),P=R.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!P)return;const y=P.getActiveSheet().getSheetId(),M=P.activeSheet$.subscribe(O=>{(O==null?void 0:O.getSheetId())!==y&&E.close()});return()=>{M.unsubscribe()}},[]),_.jsxs("div",{className:ve.permissionPanelDetailWrapper,children:[_.jsx(Iv,{permissionId:o.permissionId,ranges:s,onRangesChange:(R,E)=>{l(R),d(E)},rangesErrMsg:c,desc:u,onDescChange:R=>h(R)}),_.jsx(I.ComponentContainer,{components:v,sharedProps:{editState:g,onEditStateChange:R=>S(R),viewState:f,onViewStateChange:R=>p(R),permissionId:o.permissionId}},"user-part"),_.jsx(Cv,{permissionId:o.permissionId,id:o.id,ranges:s,rangesErrMsg:c,desc:u,viewState:f,editState:g,oldRule:t})]})},bv="",Rv="univer-sheet-permission-list-panel-wrapper",Ev="univer-sheet-permission-list-panel-header",wv="univer-sheet-permission-list-panel-header-type",Tv="univer-sheet-permission-list-panel-header-type-bottom",yv="univer-sheet-permission-list-panel-header-select",Mv="univer-sheet-permission-list-item-header-icon",Pv="univer-sheet-permission-list-item",Ov="univer-sheet-permission-list-item-header",xv="univer-sheet-permission-list-item-header-name",Av="univer-sheet-permission-list-item-header-operator",kv="univer-sheet-permission-list-item-split",Dv="univer-sheet-permission-list-item-content-edit",Nv="univer-sheet-permission-list-item-content-view",Hv="univer-sheet-permission-list-item-content-desc",Vv="univer-sheet-permission-list-empty",Wv="univer-sheet-permission-list-empty-text",Lv="univer-sheet-permission-list-item-content-title",Uv="univer-sheet-permission-list-item-content-sub",Bv="univer-sheet-permission-panel-add-wrapper",Fv="univer-sheet-permission-panel-add-button",de={sheetPermissionListPanelWrapper:Rv,sheetPermissionListPanelHeader:Ev,sheetPermissionListPanelHeaderType:wv,sheetPermissionListPanelHeaderTypeBottom:Tv,sheetPermissionListPanelHeaderSelect:yv,sheetPermissionListItemHeaderIcon:Mv,sheetPermissionListItem:Pv,sheetPermissionListItemHeader:Ov,sheetPermissionListItemHeaderName:xv,sheetPermissionListItemHeaderOperator:Av,sheetPermissionListItemSplit:kv,sheetPermissionListItemContentEdit:Dv,sheetPermissionListItemContentView:Nv,sheetPermissionListItemContentDesc:Hv,sheetPermissionListEmpty:Vv,sheetPermissionListEmptyText:Wv,sheetPermissionListItemContentTitle:Lv,sheetPermissionListItemContentSub:Uv,sheetPermissionPanelAddWrapper:Bv,sheetPermissionPanelAddButton:Fv},jv=()=>{var W;const[n,i]=V.useState(!0),[e,t]=V.useState(!1),r=I.useDependency(a.LocaleService),o=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),S=I.useDependency(a.UserManagerService).getCurrentUser(),[f,p]=V.useState([]),v=I.useDependency(Mt),C=I.useObservable(s.ruleRefresh$,""),b=I.useObservable(o.ruleRefresh$,""),R=l.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!R)return null;const E=R==null?void 0:R.getUnitId(),P=V.useCallback(async H=>{var G;const L=R.getActiveSheet(),U=R.getUnitId(),j=L.getSheetId(),B=[],z=[];R.getSheets().forEach(Y=>{const q=Y.getSheetId();o.getSubunitRuleList(U,q).forEach(ie=>{ie.permissionId&&B.push(ie.permissionId)});const ce=s.getRule(U,q);ce!=null&&ce.permissionId&&z.push(ce.permissionId)});const F=[...B,...z],Z=await u.list({objectIDs:F,unitID:U,actions:m.baseProtectionActions}),J=o.getSubunitRuleList(U,j).map(Y=>Y.permissionId),Q=(G=s.getRule(U,j))==null?void 0:G.permissionId;Q&&J.push(Q);const se=Z.filter(Y=>{var q;return J.includes(Y.objectID)||Y.objectID===((q=s.getRule(U,j))==null?void 0:q.permissionId)});return H?se:Z},[]),[y,M]=V.useState([]);V.useEffect(()=>{const H=x.merge(o.ruleChange$,s.ruleChange$).subscribe(async()=>{const L=await P(n);M(L)});return()=>{H.unsubscribe()}},[n]),V.useEffect(()=>{const H=R.activeSheet$.pipe(x.distinctUntilChanged((L,U)=>(L==null?void 0:L.getSheetId())===(U==null?void 0:U.getSheetId()))).subscribe(async()=>{const L=await P(n);M(L)});return()=>{H.unsubscribe()}},[n]),V.useEffect(()=>{(async()=>{if(C||b){const L=await P(!0);M(L)}})()},[C,b]);const O=H=>{const{unitId:L,subUnitId:U,unitType:j}=H;let B;j===dt.Worksheet?B=c.executeCommand(m.DeleteWorksheetProtectionCommand.id,{unitId:L,subUnitId:U,rule:H}):j===dt.SelectRange&&(B=c.executeCommand(m.DeleteRangeProtectionCommand.id,{unitId:L,subUnitId:U,rule:H})),B&&(t(!e),H.ranges===f&&p([]))};V.useEffect(()=>{v.reset()},[]),Yc(f);const A=new Map;R.getSheets().forEach(H=>{const L=H.getSheetId();o.getSubunitRuleList(E,L).forEach(B=>{A.set(B.permissionId,B)});const j=s.getRule(E,L);j&&A.set(j==null?void 0:j.permissionId,j)});const k=H=>{H.subUnitId!==R.getActiveSheet().getSheetId()&&c.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:H.unitId,subUnitId:H.subUnitId});const L={header:{title:"permission.panel.title"},children:{label:cr,showDetail:!0,rule:a.Tools.deepClone(H),oldRule:a.Tools.deepClone(H)},width:330};d.open(L)},D=H=>{i(H)},N=(W=h.getPermissionPoint(new m.WorkbookCreateProtectPermission(E).id))==null?void 0:W.value;return _.jsxs("div",{className:de.sheetPermissionListPanelWrapper,children:[_.jsxs("div",{className:de.sheetPermissionListPanelHeader,children:[_.jsxs("div",{className:de.sheetPermissionListPanelHeaderType,onClick:()=>D(!0),children:[_.jsx("div",{className:X.clsx({[de.sheetPermissionListPanelHeaderSelect]:n}),children:r.t("permission.panel.currentSheet")}),n&&_.jsx("div",{className:de.sheetPermissionListPanelHeaderTypeBottom})]}),_.jsxs("div",{className:de.sheetPermissionListPanelHeaderType,onClick:()=>D(!1),children:[_.jsx("div",{className:X.clsx({[de.sheetPermissionListPanelHeaderSelect]:!n}),children:r.t("permission.panel.allSheet")}),!n&&_.jsx("div",{className:de.sheetPermissionListPanelHeaderTypeBottom})]})]}),(y==null?void 0:y.length)>0?_.jsx("div",{className:de.sheetPermissionListPanelContent,children:y==null?void 0:y.map(H=>{var q,ne,ce,ie,oe;const L=A.get(H.objectID);if(!L)return null;const U=H.actions.find(ee=>ee.action===re.Edit),j=U==null?void 0:U.allowed,B=H.actions.find(ee=>ee.action===re.View),z=B==null?void 0:B.allowed,F=H.actions.find(ee=>ee.action===re.ManageCollaborator),Z=H.actions.find(ee=>ee.action===re.Delete),J=(F==null?void 0:F.allowed)||S.userID===((q=H.creator)==null?void 0:q.userID),Q=(Z==null?void 0:Z.allowed)||S.userID===((ne=H.creator)==null?void 0:ne.userID);let se="";const G=R.getSheetBySheetId(L.subUnitId),Y=G==null?void 0:G.getName();if(L.unitType===dt.SelectRange){const ee=L.ranges,ge=ee!=null&&ee.length?ee.map(pe=>{const we=K.serializeRange(pe);return we==="NaN"?"":we}).filter(pe=>!!pe).join(","):"";se=`${Y}(${ge})`}else L.unitType===dt.Worksheet&&(se=Y||"");return _.jsxs("div",{className:de.sheetPermissionListItem,onMouseMove:()=>{const{subUnitId:ee,unitType:ge}=L,pe=R.getActiveSheet();if(!pe)return!1;const we=pe.getSheetId();if(ee!==we)return!1;if(ge===dt.SelectRange){const Te=L.ranges||[];Te!==f&&p(Te)}else if(ge===dt.Worksheet){const Te=[{startRow:0,endRow:pe.getRowCount()-1,startColumn:0,endColumn:pe.getColumnCount()-1}];Te!==f&&p(Te)}},onMouseLeave:()=>p([]),children:[_.jsxs("div",{className:de.sheetPermissionListItemHeader,children:[_.jsx(X.Tooltip,{title:se,children:_.jsx("div",{className:de.sheetPermissionListItemHeaderName,children:se})}),(J||Q)&&_.jsxs("div",{className:de.sheetPermissionListItemHeaderOperator,children:[J&&_.jsx(X.Tooltip,{title:r.t("permission.panel.edit"),children:_.jsx("div",{className:de.sheetPermissionListItemHeaderIcon,onClick:()=>k(L),children:_.jsx(Ts,{})})}),Q&&_.jsx(X.Tooltip,{title:r.t("permission.panel.delete"),children:_.jsx("div",{className:de.sheetPermissionListItemHeaderIcon,onClick:()=>O(L),children:_.jsx(Li,{})})})]})]}),_.jsx("div",{className:de.sheetPermissionListItemSplit}),_.jsxs("div",{className:de.sheetPermissionListItemContent,children:[_.jsxs("div",{className:de.sheetPermissionListItemContentEdit,children:[_.jsx(X.Tooltip,{title:(ie=(ce=H.creator)==null?void 0:ce.name)!=null?ie:"",children:_.jsx("div",{children:_.jsx(X.Avatar,{src:(oe=H.creator)==null?void 0:oe.avatar,style:{marginRight:6},size:24})})}),_.jsx("span",{className:de.sheetPermissionListItemContentTitle,children:r.t("permission.panel.created")}),_.jsx("span",{className:de.sheetPermissionListItemContentSub,children:j?`${r.t("permission.panel.iCanEdit")}`:`${r.t("permission.panel.iCanNotEdit")}`})]}),_.jsxs("div",{className:de.sheetPermissionListItemContentView,children:[_.jsx("span",{className:de.sheetPermissionListItemContentTitle,children:r.t("permission.panel.viewPermission")}),_.jsx("span",{className:de.sheetPermissionListItemContentSub,children:z?`${r.t("permission.panel.iCanView")}`:`${r.t("permission.panel.iCanNotView")}`})]}),L.description&&_.jsx(X.Tooltip,{title:L.description,children:_.jsx("div",{className:de.sheetPermissionListItemContentDesc,children:L.description})})]})]},H.objectID)})}):_.jsxs("div",{className:de.sheetPermissionListEmpty,children:[_.jsx("img",{width:240,height:120,src:bv,alt:""}),_.jsx("p",{className:de.sheetPermissionListEmptyText,children:r.t("permission.dialog.listEmpty")})]}),N&&_.jsx("div",{className:de.sheetPermissionPanelAddWrapper,children:_.jsxs(X.Button,{className:de.sheetPermissionPanelAddButton,variant:"primary",onClick:()=>{const H={header:{title:`${r.t("permission.panel.title")}`},children:{label:cr,showDetail:!0},width:330};d.open(H)},children:[_.jsx("div",{children:"+ "}),r.t("permission.button.addNewPermission")]})})]})},zv=({showDetail:n,fromSheetBar:i,rule:e,oldRule:t})=>{var h;const r=I.useDependency(a.IUniverInstanceService),o=I.useDependency(m.SheetsSelectionsService);if(!I.useDependency(Pn).getVisible())return null;const l=m.getSheetCommandTarget(r);if(!l)return null;const{worksheet:c}=l,u=((h=o.getCurrentSelections())==null?void 0:h.map(g=>g.range)).reduce((g,S)=>g+K.serializeRangeWithSheet(c.getName(),S),"");return n?_.jsx(_v,{fromSheetBar:i,rule:e,oldRule:t},i?"sheet-bar":"normal"):_.jsx(jv,{},u)},Xv="univer-spin-container",Yv="univer-spin-overlay",Gv="univer-spinner",Zv="univer-content-blur",Kr={spinContainer:Xv,spinOverlay:Yv,spinner:Gv,contentBlur:Zv},Kv=({loading:n,children:i})=>_.jsxs("div",{className:Kr.spinContainer,children:[n&&_.jsx("div",{className:Kr.spinOverlay,children:_.jsx("div",{className:Kr.spinner})}),_.jsx("div",{className:n?Kr.contentBlur:"",children:i})]}),qv="univer-sheet-permission-dialog-wrapper",Qv="univer-sheet-permission-dialog-split",Jv="univer-sheet-permission-dialog-item",$v="univer-sheet-permission-user-dialog-footer",eC="univer-sheet-permission-user-dialog-footer-confirm",tC="univer-sheet-permission-user-dialog-button",ft={sheetPermissionDialogWrapper:qv,sheetPermissionDialogSplit:Qv,sheetPermissionDialogItem:Jv,sheetPermissionUserDialogFooter:$v,sheetPermissionUserDialogFooterConfirm:eC,sheetPermissionUserDialogButton:tC},nC=()=>{const n=I.useDependency(a.LocaleService),i=I.useDependency(a.IUniverInstanceService),e=I.useDependency(a.IAuthzIoService),t=I.useDependency(m.WorksheetProtectionPointModel),r=I.useDependency(I.IDialogService),o=I.useDependency(a.IPermissionService),s=i.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),l=s.getActiveSheet();if(!l)throw new Error("No active sheet found");const[c,d]=V.useState([]),u=I.useDependency(a.ICommandService),[h,g]=V.useState(()=>!!t.getRule(s.getUnitId(),l.getSheetId())),[S,f]=V.useState(()=>Object.keys(Xr).reduce((v,C)=>(v[C]={text:n.t(`permission.panel.${Xr[Number(C)]}`),allowed:!0},v),{}));V.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=await e.listCollaborators({objectID:C,unitID:C});d(b)})()},[]),V.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=t.getRule(C,l.getSheetId());if(!b)return;g(!0);const E=(await e.list({unitID:s.getUnitId(),objectIDs:[b.permissionId],actions:xS}))[0].strategies.reduce((P,y)=>(Xr[y.action]&&(P[y.action]={text:n.t(`permission.panel.${Xr[y.action]}`),allowed:y.role!==Ae.Owner}),P),{});f(E),setTimeout(()=>{g(!1)},100)})()},[]);const p=async()=>{const v=i.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(),R=C.getSheetId(),E=t.getRule(b,R),P=Object.keys(S).map(M=>({action:Number(M),role:S[M].allowed?Ae.Editor:Ae.Owner}));let y=E==null?void 0:E.permissionId;y?e.update({objectType:dt.Worksheet,objectID:y,unitID:b,strategies:P,share:void 0,name:"",scope:{read:Ze.AllCollaborator,edit:Ze.AllCollaborator},collaborators:void 0}).then(()=>{m.getAllWorksheetPermissionPoint().forEach(M=>{const O=new M(b,R),A=O.subType,k=P.find(D=>D.action===A);k&&o.updatePermissionPoint(O.id,k.role===Ae.Editor)})}):(y=await e.create({objectType:dt.Worksheet,worksheetObject:{unitID:b,collaborators:c,name:"",strategies:P,scope:{read:Ze.AllCollaborator,edit:Ze.AllCollaborator}}}),u.executeCommand(m.SetWorksheetPermissionPointsCommand.id,{rule:{permissionId:y,unitId:b,subUnitId:R}}))};return _.jsx(Kv,{loading:h,children:_.jsxs("div",{className:ft.sheetPermissionDialogWrapper,children:[_.jsx("div",{className:ft.sheetPermissionDialogSplit}),Object.keys(S).map(v=>{const C=S[v],{text:b,allowed:R}=C;return _.jsxs("div",{className:ft.sheetPermissionDialogItem,children:[_.jsx("div",{children:b}),_.jsx(X.Switch,{defaultChecked:R,onChange:()=>{f({...S,[v]:{...C,allowed:!R}})}})]},b)}),_.jsx("div",{className:ft.sheetPermissionDialogSplit}),_.jsxs("div",{className:ft.sheetPermissionUserDialogFooter,children:[_.jsx(X.Button,{className:ft.sheetPermissionUserDialogButton,onClick:()=>{r.close(mi)},children:n.t("permission.button.cancel")}),_.jsx(X.Button,{variant:"primary",onClick:()=>{p(),r.close(mi)},className:X.clsx(ft.sheetPermissionUserDialogFooterConfirm,ft.sheetPermissionUserDialogButton),children:n.t("permission.button.confirm")})]})]})})},nd="",rC="univer-sheet-permission-user-list",iC="univer-sheet-permission-user-list-empty",oC="univer-sheet-permission-user-item",sC="univer-sheet-permission-user-item-name",aC="univer-sheet-permission-split",lC="univer-sheet-permission-user-dialog-button",it={sheetPermissionUserList:rC,sheetPermissionUserListEmpty:iC,sheetPermissionUserItem:oC,sheetPermissionUserItemName:sC,sheetPermissionSplit:aC,sheetPermissionUserDialogButton:lC},cC=()=>{var u;const[n,i]=V.useState(""),e=I.useDependency(a.LocaleService),t=I.useDependency(I.IDialogService),r=I.useDependency(Mt),o=I.useObservable(r.userList$,r.userList),s=(u=o==null?void 0:o.filter(h=>{var g;return((g=h.subject)==null?void 0:g.name.toLocaleLowerCase().includes(n.toLocaleLowerCase()))&&h.role===Ae.Editor}))!=null?u:[],[l,c]=V.useState(r.selectUserList),d=h=>{if((l==null?void 0:l.findIndex(S=>{var f,p;return((f=S.subject)==null?void 0:f.userID)===((p=h.subject)==null?void 0:p.userID)}))===-1){const S={...h};c([...l,S])}else{const S=l.filter(f=>{var p,v;return((p=f.subject)==null?void 0:p.userID)!==((v=h.subject)==null?void 0:v.userID)});c(S)}};return _.jsxs("div",{children:[_.jsx("div",{className:it.sheetPermissionUserDialogSearch,children:_.jsx(X.Input,{className:"univer-w-full",placeholder:e.t("permission.dialog.search"),value:n,onChange:h=>i(h)})}),_.jsx("div",{className:it.sheetPermissionUserList,children:(s==null?void 0:s.length)>0?_.jsx(_.Fragment,{children:s==null?void 0:s.map(h=>{var g,S,f;return _.jsxs("div",{className:it.sheetPermissionUserItem,onClick:()=>d(h),children:[_.jsx(X.Avatar,{src:(g=h.subject)==null?void 0:g.avatar,size:24}),_.jsx("div",{className:it.sheetPermissionUserItemName,children:(S=h.subject)==null?void 0:S.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(Tt,{})})]},(f=h.subject)==null?void 0:f.userID)})}):_.jsxs("div",{className:it.sheetPermissionUserListEmpty,children:[_.jsx("img",{className:"univer-w-full",src:nd,alt:"empty list",draggable:!1}),_.jsx("p",{className:"univer-text-[13px] univer-text-gray-400",children:e.t("permission.dialog.userEmpty")})]})}),_.jsx("div",{className:it.sheetPermissionSplit}),_.jsxs("div",{className:"univer-flex univer-items-center univer-justify-end univer-gap-1 univer-py-1",children:[_.jsx(X.Button,{className:it.sheetPermissionUserDialogButton,onClick:()=>t.close(hi),children:e.t("permission.button.cancel")}),_.jsx(X.Button,{variant:"primary",onClick:()=>{r.setSelectUserList(l),t.close(hi)},className:X.clsx(it.sheetPermissionUserDialogFooterConfirm,it.sheetPermissionUserDialogButton),children:e.t("permission.button.confirm")})]})]})},dC=({errorMsg:n})=>{const i=I.useDependency(a.LocaleService);return _.jsx("div",{children:_.jsx("p",{className:"univer-m-0",children:n||i.t("permission.dialog.alertContent")})})},rd="",id="RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY",od="RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY",uC=25,hC=80;class sd extends T.SheetExtension{constructor(){super();w(this,"_pattern",null);w(this,"_img",new Image);w(this,"renderCache",new Set);this._img.src=rd}clearCache(){this.renderCache.clear()}draw(e,t,r){const{worksheet:o}=r;o&&(e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat")),this.renderCache.clear(),a.Range.foreach(r.rowColumnSegment,(s,l)=>{if(!o.getRowVisible(s)||!o.getColVisible(l))return;const{selectionProtection:c=[]}=o.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=r.getCellWithCoordByIndex(u.startRow,u.startColumn,!1),g=r.getCellWithCoordByIndex(u.endRow,u.endColumn,!1);e.fillRect(h.startX,h.startY,g.endX-h.startX,g.endY-h.startY)})}}))}),e.restore())}}class mC extends sd{constructor(){super();w(this,"uKey",id);w(this,"Z_INDEX",uC)}shouldRender(e){return(e==null?void 0:e[re.View])!==!1}}class gC extends sd{constructor(){super();w(this,"uKey",od);w(this,"Z_INDEX",hC)}shouldRender(e){return(e==null?void 0:e[re.View])===!1}}const ad="worksheet-protection",ja=25,SC=80;class fC extends T.SheetExtension{constructor(){super();w(this,"uKey",ad);w(this,"Z_INDEX",ja);w(this,"_pattern");w(this,"_img",new Image);this._img.src=rd}draw(e,t,r){const{worksheet:o}=r;if(!o)return!1;e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat"));const{startRow:s,startColumn:l,endRow:c,endColumn:d}=r.rowColumnSegment,u=r.getCellWithCoordByIndex(s,l,!1),h=r.getCellWithCoordByIndex(c,d,!1),{hasWorksheetRule:g=!1,selectionProtection:S=[]}=o.getCell(s,l)||{};if(this._pattern){if(S.length>0){const f=S[0];(f==null?void 0:f[re.View])?this.setZIndex(ja):this.setZIndex(SC)}e.fillStyle=this._pattern,g&&e.fillRect(u.startX,u.startY,h.endX-u.startX,h.endY-u.startY),e.restore()}}setZIndex(e){this.Z_INDEX=e}}const pC=n=>{const{editState:i,onEditStateChange:e,viewState:t,onViewStateChange:r,permissionId:o}=n,s=I.useDependency(a.LocaleService),l=I.useDependency(I.IDialogService),c=I.useDependency(a.IAuthzIoService),d=I.useDependency(Mt),u=I.useDependency(a.UserManagerService),h=I.useDependency(a.IUniverInstanceService),g=I.useObservable(d.selectUserList$,d.selectUserList),S=h.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),f=S==null?void 0:S.getActiveSheet();if(!S||!f)return null;const p=S.getUnitId(),v=async()=>{const C=await c.listCollaborators({objectID:p,unitID:p}),b=u.getCurrentUser();d.setCanEditUserList(C.filter(R=>{var E;return((E=R.subject)==null?void 0:E.userID)!==b.userID})),l.open({id:hi,title:{title:""},children:{label:ec},width:280,destroyOnClose:!0,closable:!1,onClose:()=>l.close(hi),className:"sheet-permission-user-dialog"})};return V.useEffect(()=>{o?(async()=>{const R=(await c.listCollaborators({objectID:o,unitID:p})).filter(E=>E.role===Ae.Editor);R.length>0&&e(m.EditStateEnum.DesignedUserCanEdit),d.setSelectUserList(R),d.setOldCollaboratorList(R)})():(d.setSelectUserList([]),d.setOldCollaboratorList([]))},[]),_.jsxs(_.Fragment,{children:[_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:s.t("permission.panel.editPermission"),children:_.jsxs(X.RadioGroup,{value:i,onChange:C=>e(C),className:ve.radioGroupVertical,children:[_.jsx(X.Radio,{value:m.EditStateEnum.OnlyMe,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.onlyICanEdit")})}),_.jsx(X.Radio,{value:m.EditStateEnum.DesignedUserCanEdit,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.designedUserCanEdit")})})]})}),i===m.EditStateEnum.DesignedUserCanEdit&&_.jsxs("div",{className:ve.sheetPermissionDesignPersonPanel,children:[_.jsxs("div",{className:ve.sheetPermissionDesignPersonPanelHeader,children:[_.jsx("span",{children:s.t("permission.panel.designedPerson")}),_.jsx("span",{className:ve.sheetPermissionDesignPersonPanelHeaderAdd,onClick:v,children:s.t("permission.panel.addPerson")})]}),_.jsx("div",{className:ve.sheetPermissionDesignPersonPanelSplit}),_.jsx("div",{className:ve.sheetPermissionDesignPersonPanelContent,children:(g==null?void 0:g.length)>0?g.map(C=>{var b,R,E;return _.jsxs("div",{className:ve.sheetPermissionDesignPersonPanelContentItem,children:[_.jsx(X.Avatar,{size:24,src:(b=C.subject)==null?void 0:b.avatar}),_.jsx("span",{className:ve.sheetPermissionDesignPersonPanelContentItemName,children:(R=C.subject)==null?void 0:R.name}),_.jsx(X.Select,{className:ve.sheetPermissionDesignPersonPanelContentItemSelect,value:"edit",onChange:P=>{P==="delete"&&d.setSelectUserList(g.filter(y=>{var M,O;return((M=y.subject)==null?void 0:M.userID)!==((O=C.subject)==null?void 0:O.userID)}))},options:[{label:`${s.t("permission.panel.canEdit")}`,value:"edit"},{label:`${s.t("permission.panel.delete")}`,value:"delete"}]})]},(E=C.subject)==null?void 0:E.userID)}):_.jsxs("div",{className:ve.sheetPermissionUserListEmpty,children:[_.jsx("img",{width:240,height:120,src:nd,alt:""}),_.jsx("p",{className:ve.sheetPermissionUserListEmptyText,children:s.t("permission.dialog.userEmpty")})]})})]}),_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:s.t("permission.panel.viewPermission"),children:_.jsxs(X.RadioGroup,{value:t,onChange:C=>r(C),className:ve.radioGroupVertical,children:[_.jsx(X.Radio,{value:m.ViewStateEnum.OthersCanView,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.othersCanView")})}),_.jsx(X.Radio,{value:m.ViewStateEnum.NoOneElseCanView,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.noOneElseCanView")})})]})})]})};var vC=Object.getOwnPropertyDescriptor,Fs=(n,i,e,t)=>{for(var r=t>1?void 0:t?vC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ve=(n,i)=>(e,t)=>i(e,t,n);let hr=class extends a.Disposable{constructor(n,i,e){super(),this._injector=n,this._componentManager=i,this._uiPartsService=e,this._init()}_init(){this._initComponents(),this._initUiPartComponents()}_initComponents(){[[nc,ml],[AS,Li],[kS,Ts],[DS,Tt],[rc,ws],[cr,zv],[ec,cC],[tc,nC],[ed,dC]].forEach(([n,i])=>{this.disposeWithMe(this._componentManager.register(n,i))})}_initUiPartComponents(){var e;const i=this._injector.get(a.IConfigService).getConfig(Xe);(e=i==null?void 0:i.customComponents)!=null&&e.has(Mn)||this.disposeWithMe(this._uiPartsService.registerComponent(Mn,()=>I.connectInjector(pC,this._injector)))}};hr=Fs([Ve(0,a.Inject(a.Injector)),Ve(1,a.Inject(I.ComponentManager)),Ve(2,a.Inject(I.IUIPartsService))],hr);let bi=class extends a.Disposable{constructor(i,e,t,r,o){var l;super();w(this,"_rangeProtectionCanViewRenderExtension",new mC);w(this,"_rangeProtectionCanNotViewRenderExtension",new gC);this._context=i,this._rangeProtectionRuleModel=e,this._sheetSkeletonManagerService=t,this._permissionService=r,this._configService=o;const s=this._configService.getConfig(Xe);(l=s==null?void 0:s.customComponents)!=null&&l.has(Zi)||(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 i=this._context.mainComponent;i&&(i.getExtensionByKey(id)||i.register(this._rangeProtectionCanViewRenderExtension),i.getExtensionByKey(od)||i.register(this._rangeProtectionCanNotViewRenderExtension))}_initSkeleton(){const i=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(x.merge(this._permissionService.permissionPointUpdate$.pipe(x.throttleTime(300,void 0,{trailing:!0})),this._rangeProtectionRuleModel.rangeRuleInitStateChange$,this._rangeProtectionRuleModel.ruleChange$).pipe().subscribe(i))}};bi=Fs([Ve(1,a.Inject(m.RangeProtectionRuleModel)),Ve(2,a.Inject(exports.SheetSkeletonManagerService)),Ve(3,a.IPermissionService),Ve(4,a.IConfigService)],bi);let Ri=class extends a.Disposable{constructor(i,e,t,r,o,s){var c;super();w(this,"_worksheetProtectionRenderExtension",new fC);this._context=i,this._renderManagerService=e,this._univerInstanceService=t,this._sheetSkeletonManagerService=r,this._worksheetProtectionRuleModel=o,this._configService=s;const l=this._configService.getConfig(Xe);(c=l==null?void 0:l.customComponents)!=null&&c.has(Zi)||(this._initRender(),this._initSkeleton())}_initRender(){const i=this._context.unitId,e=i&&this._renderManagerService.getRenderById(i),t=e&&e.mainComponent;t&&(t.getExtensionByKey(ad)||t.register(this._worksheetProtectionRenderExtension))}_initSkeleton(){const i=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(x.merge(this._worksheetProtectionRuleModel.worksheetRuleInitStateChange$).pipe().subscribe(i))}};Ri=Fs([Ve(1,a.Inject(T.IRenderManagerService)),Ve(2,a.Inject(a.IUniverInstanceService)),Ve(3,a.Inject(exports.SheetSkeletonManagerService)),Ve(4,a.Inject(m.WorksheetProtectionRuleModel)),Ve(5,a.Inject(a.IConfigService))],Ri);var CC=Object.getOwnPropertyDescriptor,IC=(n,i,e,t)=>{for(var r=t>1?void 0:t?CC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},ko=(n,i)=>(e,t)=>i(e,t,n);let Ei=class extends a.Disposable{constructor(n,i,e,t){super(),this._context=n,this._formatPainterService=i,this._selectionRenderService=e,this._commandService=t,this._initialize()}_initialize(){this._bindFormatPainterStatus(),this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._selectionRenderService.selectionMoveEnd$.subscribe(n=>{var i;if(this._formatPainterService.getStatus()!==ke.OFF){const{rangeWithCoord:e}=n[n.length-1];this._commandService.executeCommand(Tr.id,{unitId:this._context.unitId,subUnitId:((i=this._context.unit.getActiveSheet())==null?void 0:i.getSheetId())||"",range:{startRow:e.startRow,startColumn:e.startColumn,endRow:e.endRow,endColumn:e.endColumn}}),this._formatPainterService.getStatus()===ke.ONCE&&this._commandService.executeCommand(Nn.id)}}))}_bindFormatPainterStatus(){this.disposeWithMe(a.toDisposable(this._formatPainterService.status$.subscribe(n=>{const i=this._context.scene;i&&(n!==ke.OFF?i.setDefaultCursor(T.CURSOR_TYPE.CELL):i.setDefaultCursor(T.CURSOR_TYPE.DEFAULT))})))}};Ei=IC([ko(1,$e),ko(2,Ce),ko(3,a.ICommandService)],Ei);var _C=Object.getOwnPropertyDescriptor,bC=(n,i,e,t)=>{for(var r=t>1?void 0:t?_C(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Kn=(n,i)=>(e,t)=>i(e,t,n);let ns=class extends a.Disposable{constructor(n,i,e,t,r,o){super(),this._context=n,this._layoutService=i,this._contextMenuService=e,this._selectionManagerService=t,this._selectionRenderService=r,this._sheetSkeletonManagerService=o,this._init()}_init(){let n=!1;this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(()=>n=!0)),this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(i=>{const e=this._sheetSkeletonManagerService.getCurrentParam().skeleton;if(!e||!i||n===!1)return;n=!1;const t=i[0];if(!t.primary)return;const r=Pe(t,e),o=t.range.rangeType,{scene:s}=this._context,l=s.getViewport(T.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 g=e.rowHeaderWidth,S=this._layoutService.getContentElement().getBoundingClientRect();switch(o){case a.RANGE_TYPE.NORMAL:u=r.rangeWithCoord.startX+S.left-c,h=r.rangeWithCoord.endY+S.top-d;break;case a.RANGE_TYPE.COLUMN:u=r.rangeWithCoord.startX+S.left-c,h=Math.min(S.height/2,r.rangeWithCoord.endY)+40;break;case a.RANGE_TYPE.ROW:u=(S.width-g)/2+20,h=r.rangeWithCoord.endY+S.top-d;break;case a.RANGE_TYPE.ALL:u=r.rangeWithCoord.startX+S.left,h=r.rangeWithCoord.startY+S.top;break;default:u=r.rangeWithCoord.startX+S.left-c,h=r.rangeWithCoord.endY+S.top-d;break}u=a.Tools.clamp(u,g,S.width),h=a.Tools.clamp(h,S.top,S.height),this._contextMenuService.triggerContextMenu({clientX:u,clientY:h,preventDefault:()=>{},stopPropagation:()=>{}},I.ContextMenuPosition.MAIN_AREA)}))}};ns=bC([Kn(1,I.ILayoutService),Kn(2,I.IContextMenuService),Kn(3,a.Inject(m.SheetsSelectionsService)),Kn(4,Ce),Kn(5,a.Inject(exports.SheetSkeletonManagerService))],ns);var RC=Object.getOwnPropertyDescriptor,EC=(n,i,e,t)=>{for(var r=t>1?void 0:t?RC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},dn=(n,i)=>(e,t)=>i(e,t,n);const wC=[xe.id,Je.id];let rs=class extends a.Disposable{constructor(n,i,e,t,r,o,s){super(),this._context=n,this._sheetSkeletonManagerService=i,this._commandService=e,this._renderManagerService=t,this._selectionManagerService=r,this._scrollManagerService=o,this._univerInstanceService=s,this._init()}scrollToRange(n){let{endRow:i,endColumn:e,startColumn:t,startRow:r}=n;const o=this._getViewportBounding();if(n.rangeType===a.RANGE_TYPE.ROW?(t=0,e=0):n.rangeType===a.RANGE_TYPE.COLUMN&&(r=0,i=0),o){const s=o.startRow>i?r:i,l=o.startColumn>e?t:e;return this._scrollToCell(s,l)}else return this._scrollToCell(r,t)}_init(){this._initCommandListener(),this._initScrollEventListener(),this._initPointerScrollEvent(),this._initSkeletonListener()}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(wC.includes(n.id))this._scrollToSelection();else if(n.id===m.ScrollToCellOperation.id){const i=n.params.range;this.scrollToRange(i)}else if(n.id===De.id){const i=n.params;this._scrollToSelectionForExpand(i)}}))}_scrollToSelectionForExpand(n){setTimeout(()=>{const i=this._selectionManagerService.getCurrentLastSelection();if(i==null)return;const{startRow:e,startColumn:t,endRow:r,endColumn:o}=i.range,s=this._getViewportBounding();if(s==null)return;const{startRow:l,startColumn:c,endRow:d,endColumn:u}=s;let h=0,g=0;e>l?h=r:r<d?h=e:h=l,t>c?g=o:o<u?g=t:g=c,n.direction===a.Direction.DOWN?h=r:n.direction===a.Direction.UP?h=e:n.direction===a.Direction.RIGHT?g=o:n.direction===a.Direction.LEFT&&(g=t),this._scrollToCell(h,g)},0)}_getFreeze(){var i;const n=(i=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:i.skeleton.getWorksheetConfig();if(n!=null)return n.freeze}_initScrollEventListener(){const{scene:n}=this._context;if(n==null)return;const i=n.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);i&&(this.disposeWithMe(a.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(e=>{var g;if(e==null){i.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const t=(g=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:g.skeleton;if(!t)return;const{sheetViewStartRow:r,sheetViewStartColumn:o,offsetX:s,offsetY:l}=e,{startX:c,startY:d}=t.getCellWithCoordByIndex(r,o,!1),u=c+s,h=d+l;i.scrollToViewportPos({viewportScrollX:u,viewportScrollY:h})}))),this.disposeWithMe(i.onScrollAfter$.subscribeEvent(e=>{var f;if(!e)return;const t=(f=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:f.skeleton;if(t==null)return;const r=this._getSheetObject();if(t==null||r==null)return;const{viewportScrollX:o,viewportScrollY:s,scrollX:l,scrollY:c}=e,{row:d,column:u,rowOffset:h,columnOffset:g}=t.getOffsetRelativeToRowCol(o,s),S={sheetViewStartRow:d,sheetViewStartColumn:u,offsetX:g,offsetY:h,viewportScrollX:o,viewportScrollY:s,scrollX:l,scrollY:c};this._scrollManagerService.setValidScrollStateToCurrSheet(S),this._scrollManagerService.validViewportScrollInfo$.next({...S,scrollX:l,scrollY:c,viewportScrollX:o,viewportScrollY:s})})),this.disposeWithMe(i.onScrollByBar$.subscribeEvent(e=>{var g;const t=(g=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:g.skeleton;if(t==null||e.isTrigger===!1)return;const r=this._getSheetObject();if(t==null||r==null)return;const{viewportScrollX:o=0,viewportScrollY:s=0}=e,l=this._getFreeze(),{row:c,column:d,rowOffset:u,columnOffset:h}=t.getOffsetRelativeToRowCol(o,s);this._commandService.executeCommand(Fe.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 i={unitId:n.unitId,sheetId:n.sheetId};this._scrollManagerService.setSearchParam(i);const e=this._getSheetObject();if(!e)return;const r=e.scene.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),o=this._scrollManagerService.getScrollStateByParam(i),{viewportScrollX:s,viewportScrollY:l}=this._scrollManagerService.calcViewportScrollFromRowColOffset(o);r&&(o?(r.viewportScrollX=s,r.viewportScrollY=l):(r.viewportScrollX=0,r.viewportScrollY=0),this._updateSceneSize(n))})))}_initPointerScrollEvent(){const n=this._getSheetObject();if(!n)return;const i=this._scrollManagerService,e=n.scene,t=n.spreadsheet,r=e.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),o={x:0,y:0};let s=!1;const l={x:0,y:0},c=.95;let d=null;const u=()=>{if(!r)return;l.x*=c,l.y*=c,o.x+=l.x,o.y+=l.y;const g=l.x,S=l.y;(S!==0||g!==0)&&this._commandService.executeCommand(Rn.id,{offsetY:S,offsetX:g}),Math.abs(l.x)>1||Math.abs(l.y)>1?d=requestAnimationFrame(u):d=null},h=()=>{cancelAnimationFrame(d),d=null};t.onPointerDown$.subscribeEvent((g,S)=>{h(),r&&(o.x=g.offsetX,o.y=g.offsetY,s=!0,S.stopPropagation())}),t.onPointerMove$.subscribeEvent((g,S)=>{if(!s||!r)return;const f=g,p=-(f.offsetX-o.x),v=-(f.offsetY-o.y);l.x=-(f.offsetX-o.x),l.y=-(f.offsetY-o.y);const C=p,b=v;(p!==0||v!==0)&&(b!==0||C!==0)&&this._commandService.executeCommand(Rn.id,{offsetY:b,offsetX:C}),i.getCurrentScrollState(),o.x=f.offsetX,o.y=f.offsetY,S.stopPropagation()}),t.onPointerUp$.subscribeEvent(g=>{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:i}=this._context,{skeleton:e}=n,t=(h=this._renderManagerService.getRenderById(i))==null?void 0:h.scene;if(e==null||t==null)return;const{rowTotalHeight:r,columnTotalWidth:o,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+o,height:l+r})}_getSheetObject(){return Ye(this._context.unit,this._context)}_scrollToSelectionByDirection(n){const i=this._getViewportBounding();if(i==null)return!1;const{startRow:e,startColumn:t,endRow:r,endColumn:o}=i;let s=0,l=0;const{startRow:c,startColumn:d,endRow:u,endColumn:h}=n;c>=e&&(s=u),u<=r&&(s=c),d>=t&&(l=h),h<=o&&(l=d),this._scrollToCell(s,l)}_scrollToSelection(n=!0){const i=this._selectionManagerService.getCurrentLastSelection();if(i==null)return;const{startRow:e,startColumn:t,actualRow:r,actualColumn:o}=i.primary,s=n?r:e,l=n?o:t;this._scrollToCell(s,l)}_getViewportBounding(){var t,r;const n=(t=this._getSheetObject())==null?void 0:t.scene;if(n==null)return;const i=n.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(i==null)return;const e=(r=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:r.skeleton;if(e!=null)return e.getRangeByViewport(i.calcViewportInfo())}_scrollToCell(n,i){var P,y,M,O;const{rowHeightAccumulation:e,columnWidthAccumulation:t}=(y=(P=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:P.skeleton)!=null?y:{};if(e==null||t==null)return!1;const r=(M=this._getSheetObject())==null?void 0:M.scene;if(r==null)return!1;const o=r.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(o==null||((O=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:O.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(),g=this._getViewportBounding();if(g==null)return!1;const{startRow:S,startColumn:f,endRow:p,endColumn:v}=g;let C,b;if(n>=d&&i>=c-h&&(n<=S&&(C=n),n>=p)){const A=e[n]-o.height;for(let k=S;k<=n;k++)if(e[k]>=A){C=k+1;break}}if(i>=c&&n>=d-u&&(i<=f&&(b=i),i>=v)){const A=t[i]-o.width;for(let k=f;k<=i;k++)if(t[k]>=A){b=k+1;break}}if(C===void 0&&b===void 0)return!1;const{offsetX:R,offsetY:E}=this._scrollManagerService.getCurrentScrollState()||{};return this._commandService.syncExecuteCommand(Fe.id,{sheetViewStartRow:C,sheetViewStartColumn:b,offsetX:b===void 0?R:0,offsetY:C===void 0?E:0})}};rs=EC([dn(1,a.Inject(exports.SheetSkeletonManagerService)),dn(2,a.ICommandService),dn(3,T.IRenderManagerService),dn(4,a.Inject(m.SheetsSelectionsService)),dn(5,a.Inject(exports.SheetScrollManagerService)),dn(6,a.IUniverInstanceService)],rs);function ld(n){const{popup:i}=n,{extraProps:e}=i,{options:t,defaultValue:r,onChange:o}=e,[s,l]=V.useState(r!=null?r:[]);return _.jsx(X.CascaderList,{options:t,value:s,onChange:o})}ld.componentKey="sheets.dropdown.cascader";function cd(n){const{popup:i}=n,{extraProps:e}=i,{defaultValue:t,onChange:r}=e;return _.jsx(X.ColorPicker,{value:t,onChange:r})}cd.componentKey="sheets.dropdown.color";const TC="univer-dv-date-dropdown",yC="univer-dv-date-dropdown-btns",za={dvDateDropdown:TC,dvDateDropdownBtns:yC};function dd(n){const{popup:i}=n,{extraProps:e}=i,{hideFn:t,patternType:r,defaultValue:o,onChange:s,showTime:l}=e,[c,d]=V.useState(o),u=V.useMemo(()=>r!=="time"?a.dayjs():a.dayjs("1900-01-01 00:00:00"),[]),h=c&&c.isValid()?c:u,g=I.useDependency(a.LocaleService),S=async()=>{h&&await(s==null?void 0:s(h))!==!1&&t()};return _.jsxs("div",{className:za.dvDateDropdown,children:[_.jsx(X.DatePanel,{value:h,pickerValue:h,mode:r==="time"?"time":"date",showTime:(l!=null?l:r==="datetime"||r==="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:za.dvDateDropdownBtns,children:_.jsx(X.Button,{size:"small",variant:"primary",onClick:S,disabled:!h||!h.isValid(),children:g.t("dataValidation.alert.ok")})})]})}dd.componentKey="sheets.dropdown.date";const MC="univer-dv-list-dropdown",PC="univer-dv-list-dropdown-title",OC="univer-dv-list-dropdown-list",xC="univer-dv-list-dropdown-list-container",AC="univer-dv-list-dropdown-selected-icon",kC="univer-dv-list-dropdown-item-container",DC="univer-dv-list-dropdown-item",NC="univer-dv-list-dropdown-split",HC="univer-dv-list-dropdown-edit",ot={dvListDropdown:MC,dvListDropdownTitle:PC,dvListDropdownList:OC,dvListDropdownListContainer:xC,dvListDropdownSelectedIcon:AC,dvListDropdownItemContainer:kC,dvListDropdownItem:DC,dvListDropdownSplit:NC,dvListDropdownEdit:HC};function VC(n){return n.filter(Boolean).join(",")}function WC(n){return n.split(",").filter(Boolean)}const LC=n=>{const{value:i,onChange:e,multiple:t,options:r,title:o,onEdit:s,style:l,filter:c,location:d,showEdit:u}=n,h=I.useDependency(a.LocaleService),g=c==null?void 0:c.toLowerCase(),{row:S,col:f,unitId:p,subUnitId:v}=d,C=r.filter(E=>g?E.label.toLowerCase().includes(g):!0),b=I.useDependency(m.SheetPermissionCheckController),R=V.useMemo(()=>b.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission]},[{startColumn:f,startRow:S,endColumn:f,endRow:S}],p,v),[b,f,S,p,v]);return _.jsxs("div",{className:ot.dvListDropdown,style:l,children:[_.jsx("div",{className:ot.dvListDropdownTitle,children:o}),_.jsx("div",{className:ot.dvListDropdownList,children:_.jsx(X.Scrollbar,{children:_.jsx("div",{className:ot.dvListDropdownListContainer,children:C.map((E,P)=>{const y=i.indexOf(E.value)>-1,M=()=>{let A;y?A=new Set(i.filter(D=>D!==E.value)):A=new Set(t?[...i,E.value]:[E.value]);const k=[];r.forEach(D=>{A.has(D.value)&&k.push(D.value)}),e(k)},O=E.label.toLocaleLowerCase().indexOf(g);return _.jsxs("div",{className:ot.dvListDropdownItemContainer,onClick:M,children:[_.jsx("div",{className:ot.dvListDropdownItem,style:{background:E.color},children:g&&E.label.toLowerCase().includes(g)?_.jsxs(_.Fragment,{children:[_.jsx("span",{children:E.label.substring(0,O)}),_.jsx("span",{style:{fontWeight:"bold"},children:E.label.substring(O,O+g.length)}),_.jsx("span",{children:E.label.substring(O+g.length)})]}):E.label}),_.jsx("div",{className:ot.dvListDropdownSelectedIcon,children:y?_.jsx(Tt,{}):null})]},P)})})},c)}),u&&R?_.jsxs(_.Fragment,{children:[_.jsx("div",{className:ot.dvListDropdownSplit}),_.jsx("div",{className:ot.dvListDropdownEdit,children:_.jsx("a",{onClick:s,children:h.t("dataValidation.list.edit")})})]}):null]})};function ud(n){var P,y,M,O;const{popup:{extraProps:i}}=n,{location:e,hideFn:t,onChange:r,onEdit:o,options:s,defaultValue:l,multiple:c,showEdit:d}=i,{worksheet:u}=e,[h,g]=V.useState(""),S=I.useDependency(a.ICommandService),f=I.useDependency(a.LocaleService),[p,v]=V.useState(l),C=I.useDependency(me),b=I.useDependency(a.IUniverInstanceService),R=I.RectPopup.useContext(),E=((y=(P=R.current)==null?void 0:P.right)!=null?y:0)-((O=(M=R.current)==null?void 0:M.left)!=null?O:0);return V.useEffect(()=>{const A=S.onCommandExecuted(k=>{var D,N;if(k.id===_e.RichTextEditingMutation.id){const W=k.params,{unitId:H}=W,L=b.getUnit(H,a.UniverInstanceType.UNIVER_DOC);if(!L||!C.isVisible().visible)return;const U=a.BuildTextUtils.transform.getPlainText((N=(D=L.getSnapshot().body)==null?void 0:D.dataStream)!=null?N:"");g(U)}});return()=>{A.dispose()}},[S,C,b]),u?_.jsx(LC,{style:{minWidth:E,maxWidth:Math.max(E,200)},title:c?f.t("dataValidation.listMultiple.dropdown"):f.t("dataValidation.list.dropdown"),value:WC(p!=null?p:""),multiple:c,onChange:async A=>{const k=VC(A);v(k),await(r==null?void 0:r(A))!==!1&&t()},options:s,onEdit:o,filter:h,location:e,showEdit:d}):null}ud.componentKey="sheets.dropdown.list";const Xa={datepicker:dd,list:ud,color:cd,cascader:ld};var UC=Object.getOwnPropertyDescriptor,BC=(n,i,e,t)=>{for(var r=t>1?void 0:t?UC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},qr=(n,i)=>(e,t)=>i(e,t,n);const js=a.createIdentifier("ICellDropdownManagerService");exports.SheetCellDropdownManagerService=class extends a.Disposable{constructor(i,e,t,r){super(),this._canvasPopupManagerService=i,this._zenZoneService=e,this._renderManagerService=t,this._componentManager=r,Object.values(Xa).forEach(o=>{this.disposeWithMe(this._componentManager.register(o.componentKey,o))})}showDropdown(i){const{location:e,onHide:t,closeOnOutSide:r=!0}=i,{row:o,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=Xa[i.type],u=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),h=new a.DisposableCollection,g=this._canvasPopupManagerService.attachPopupToCell(o,s,{componentKey:d.componentKey,onClickOutside:()=>{r&&h.dispose()},offset:[0,3],excludeOutside:[u==null?void 0:u.engine.getCanvasElement()].filter(Boolean),extraProps:{...i,...i.props,hideFn:()=>{h.dispose()}}},l,c);if(!g)throw new Error("[SheetCellDropdownManagerService]: cannot show dropdown");return h.add(g),h.add({dispose:()=>{t==null||t()}}),h}};exports.SheetCellDropdownManagerService=BC([qr(0,a.Inject(exports.SheetCanvasPopManagerService)),qr(1,I.IZenZoneService),qr(2,T.IRenderManagerService),qr(3,a.Inject(I.ComponentManager))],exports.SheetCellDropdownManagerService);const FC=a.createInterceptorKey("PRINTING_RANGE"),jC=a.createInterceptorKey("PRINTING_COMPONENT_COLLECT"),zC=a.createInterceptorKey("PRINTING_DOM_COLLECT");class zs extends a.Disposable{constructor(){super();w(this,"interceptor",new a.InterceptorManager({PRINTING_RANGE:FC,PRINTING_COMPONENT_COLLECT:jC,PRINTING_DOM_COLLECT:zC}));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 XC extends mr{constructor(e,t,r,o){super(e,t,r,o);w(this,"_fillControlTopLeft");w(this,"_fillControlBottomRight");w(this,"_rangeType",a.RANGE_TYPE.NORMAL);this._scene=e,this._zIndex=t,this._themeService=r,this._rangeType=(o==null?void 0:o.rangeType)||a.RANGE_TYPE.NORMAL,this.initControlPoints()}initControlPoints(){const e=this.currentStyle,t=e.expandCornerSize||0,r=(e.expandCornerSize||0)/4,o=e.autofillStrokeWidth||0,s=e.stroke,l=e.autofillStroke,c=this.zIndex;this._fillControlTopLeft=new T.Rect(Bo.fillTopLeft+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualWidth:r,visualHeight:r,strokeWidth:o}),this._fillControlBottomRight=new T.Rect(Bo.fillBottomRight+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualHeight:r,visualWidth:r,strokeWidth:o});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,ii)}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 o,s;super._updateLayoutOfSelectionControl(e);const t=this.currentStyle;e==null&&(e=t);const{widgets:r=t.widgets}=e;if(this.currentStyle=e,this._enableAutoFill===!0&&!super._hasWidgets(r)){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(o=this.fillControlTopLeft)==null||o.hide(),(s=this.fillControlBottomRight)==null||s.hide()}getViewportMainScrollInfo(){const e=this.getScene().getViewport(T.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,r=0,o=0){const s=this.currentStyle,l=this.selectionModel.rangeType,c=s.expandCornerSize,{startX:d,startY:u,endX:h,endY:g}=this.selectionModel,S=this.getViewportMainScrollInfo(),f=S.width,p=S.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:g-u-c/2});break;case a.RANGE_TYPE.ROW:{const v=Math.min(f/2+e,r),C=-c/2+v;this.fillControlTopLeft.transformByState({left:C,top:-c/2}),this.fillControlBottomRight.transformByState({left:C,top:-c/2+g-u})}break;case a.RANGE_TYPE.COLUMN:{const v=Math.min(+p/2+t,o),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 YC=Object.getOwnPropertyDescriptor,GC=(n,i,e,t)=>{for(var r=t>1?void 0:t?YC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},st=(n,i)=>(e,t)=>i(e,t,n);let wi=class extends gs{constructor(i,e,t,r,o,s,l,c,d,u){super(e,t,r,s,d);w(this,"_workbookSelections");w(this,"_renderDisposable",null);w(this,"_expandingSelection",!1);w(this,"_selectionControls",[]);w(this,"expandingControlMode","bottom-right");this._context=i,this._logService=l,this._commandService=c,this._contextService=d,this._scrollManagerService=u,this._workbookSelections=o.getWorkbookSelections(this._context.unitId),this._init()}_init(){const i=this._getSheetObject();this._initEventListeners(i),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._updateControlPointWhenScrolling()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(i=>{if(i==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const e=this._context.unitId,{sheetId:t,skeleton:r}=i,{scene:o}=this._context,s=o.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._changeRuntime(r,o,s),this._workbookSelections.getCurrentLastSelection()||this._commandService.syncExecuteCommand(m.SetSelectionsOperation.id,{unitId:e,subUnitId:t,selections:[Vi(r)]})}))}_initSelectionChangeListener(){}_initEventListeners(i){const{spreadsheetRowHeader:e,spreadsheetColumnHeader:t,spreadsheet:r,spreadsheetLeftTopPlaceholder:o}=i,{scene:s}=this._context;this._initSpreadsheetEvent(i),this.disposeWithMe(e==null?void 0:e.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{row:u}=Ke(l.offsetX,l.offsetY,s,d);Gl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(r.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}=Ke(l.offsetX,l.offsetY,s,d);Zl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(r.zIndex||1)+1,a.RANGE_TYPE.COLUMN,this._getActiveViewport(l)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(o==null?void 0:o.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;this._reset();const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,u=Ss(d);this._addSelectionControlByModelData(u),this.refreshSelectionMoveStart(),c.stopPropagation(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}))}_initSpreadsheetEvent(i){const{spreadsheet:e}=i;let t;const r=500,o={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-o.x)>10||Math.abs(u.offsetY-o.y)>10)&&s()});const c=e==null?void 0:e.onPointerDown$.subscribeEvent((u,h)=>{o.x=u.offsetX,o.y=u.offsetY,t=setTimeout(()=>{l(u,!0)},r),h.stopPropagation()}),d=e==null?void 0:e.onPointerUp$.subscribeEvent((u,h)=>{if(this._normalSelectionDisabled())return;clearTimeout(t);const g=10;Math.abs(u.offsetX-o.x)>g||Math.abs(u.offsetY-o.y)>g||(l(u,!1),h.stopPropagation())});this.disposeWithMe(a.toDisposable(c)),this.disposeWithMe(a.toDisposable(d))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(i=>this._updateSelections(i,m.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(i=>this._updateSelections(i,m.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(m.REF_SELECTIONS_ENABLED).pipe(x.startWith(!1),x.distinctUntilChanged()).subscribe(i=>{var e;i?((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(i,e){const t=this._context.unit,r=t.getUnitId(),o=t.getActiveSheet().getSheetId();i.length!==0&&this._commandService.executeCommand(m.SetSelectionsOperation.id,{unitId:r,subUnitId:o,type:e,selections:i.map(s=>m.convertSelectionDataToRange(s))})}createNewSelection(i,e=0,t=a.RANGE_TYPE.NORMAL,r){this._rangeType=t;const o=this._skeleton,s=this._scene;if(!s||!o)return;r&&(this._activeViewport=r);const{offsetX:l,offsetY:c}=i,d=s.getCoordRelativeToViewport(T.Vector2.FromArray([l,c])),{x:u,y:h}=d;this._startViewportPosX=u,this._startViewportPosY=h;const g=s.getScrollXYInfoByViewport(d),{scaleX:S,scaleY:f}=s.getAncestorScale(),p=this._skeleton.getCellByOffset(u,h,S,f,g);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=Pe(v,this._skeleton);this._startRangeWhenPointerDown={...C.rangeWithCoord};let b=this.getActiveSelectionControl();const R={...C.rangeWithCoord};for(const E of this.getSelectionControls())if(E.model.isEqual(R)){b=E;break}(b==null?void 0:b.model.rangeType)!==t?(this._clearAllSelectionControls(),b=this.newSelectionControl(s,o,v)):b.updateRangeBySelectionWithCoord(C),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._expandingSelection=!1}newSelectionControl(i,e,t){const r=this.getSelectionControls(),{rowHeaderWidth:o,columnHeaderHeight:s}=e,l=t.range.rangeType,c=new XC(i,r.length,this._themeService,{highlightHeader:this._highlightHeader,rowHeaderWidth:o,columnHeaderHeight:s,rangeType:l}),d=Pe(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(g=>{this._expandingSelection=!0,this.expandingControlMode=u,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(g,l,this._activeViewport)}),c.fillControlBottomRight.onPointerDown$.subscribeEvent(g=>{this._expandingSelection=!0,this.expandingControlMode=h,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(g,l,this._activeViewport)}),(l===a.RANGE_TYPE.ROW||l===a.RANGE_TYPE.COLUMN)&&!i.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),c}_getActiveViewport(i){const e=this._getSheetObject();return e==null?void 0:e.scene.getActiveViewportByCoord(T.Vector2.FromArray([i.offsetX,i.offsetY]))}_getSheetObject(){return Ye(this._context.unit,this._context)}_normalSelectionDisabled(){return this._contextService.getContextValue(m.REF_SELECTIONS_ENABLED)}getSelectionControls(){return this._selectionControls}_fillControlPointerDownHandler(i,e=a.RANGE_TYPE.NORMAL,t,r=T.ScrollTimerType.ALL){var h,g,S;const o=this._skeleton,s=this._scene;if(!s||!o)return;t&&(this._activeViewport=t);const l=s.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=this.getActiveSelectionControl();if(!c)return;this._changeCurrCellWhenControlPointerDown(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._addEndingListeners(),this._scrollTimer=T.ScrollTimer.create(this._scene,r),this._scrollTimer.startScroll((h=l==null?void 0:l.left)!=null?h:0,(g=l==null?void 0:l.top)!=null?g:0,l),(S=s.getTransformer())==null||S.clearSelectedObjects();const d=s.getCoordRelativeToViewport(T.Vector2.FromArray([i.offsetX,i.offsetY]));this._setupPointerMoveListener(l,c,e,r,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 i=this.getActiveSelectionControl(),e=this._skeleton;let t;const{startRow:r,startColumn:o,endRow:s,endColumn:l}=i.model;switch(this.expandingControlMode){case"top-left":t=e.getCellWithCoordByIndex(s,l);break;case"bottom-right":t=e.getCellWithCoordByIndex(r,o);break;case"left":t=e.getCellWithCoordByIndex(r,l),t.isMerged=!1,t.isMergedMainCell=!1;break;case"right":t=e.getCellWithCoordByIndex(r,o),t.isMerged=!1,t.isMergedMainCell=!1;break;case"top":t=e.getCellWithCoordByIndex(s,o),t.isMerged=!1,t.isMergedMainCell=!1;break;case"bottom":t=e.getCellWithCoordByIndex(r,o),t.isMerged=!1,t.isMergedMainCell=!1;break;default:t=e.getCellWithCoordByIndex(r,o)}return i.updateCurrCell(t),t}_movingHandler(i,e,t,r){var O,A,k,D,N,W,H,L,U,j,B,z,F;this._rangeType=r;const o=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(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),d=(O=this._getViewportByCell(l.endRow,l.endColumn))!=null?O:c,u=s.getScrollXYInfoByViewport(T.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),d),{scaleX:h,scaleY:g}=s.getAncestorScale();r===a.RANGE_TYPE.ROW?i=Number.POSITIVE_INFINITY:r===a.RANGE_TYPE.COLUMN&&(e=Number.POSITIVE_INFINITY);const S=this._getSelectionWithCoordByOffset(i,e,h,g,u);if(!S)return!1;const{rangeWithCoord:f}=S,p=t.model.currentCell,v=(A=p==null?void 0:p.mergeInfo.startRow)!=null?A:-1,C=(k=p==null?void 0:p.mergeInfo.endRow)!=null?k:-1,b=(D=p==null?void 0:p.mergeInfo.startColumn)!=null?D:-1,R=(N=p==null?void 0:p.mergeInfo.endColumn)!=null?N:-1;let E={startRow:Math.min(f.startRow,v),startColumn:Math.min(f.startColumn,b),endRow:Math.max(f.endRow,C),endColumn:Math.max(f.endColumn,R)};if(r===a.RANGE_TYPE.NORMAL?E=o.expandRangeByMerge(E):r===a.RANGE_TYPE.COLUMN?E={startRow:Math.min(f.startRow,(W=p==null?void 0:p.actualRow)!=null?W:-1),startColumn:Math.min(f.startColumn,(H=p==null?void 0:p.actualColumn)!=null?H:-1),endRow:Math.max(f.endRow,(L=p==null?void 0:p.actualRow)!=null?L:-1),endColumn:Math.max(f.endColumn,(U=p==null?void 0:p.actualColumn)!=null?U:-1)}:r===a.RANGE_TYPE.ROW&&(E={startRow:Math.min(f.startRow,(j=p==null?void 0:p.actualRow)!=null?j:-1),startColumn:Math.min(f.startColumn,(B=p==null?void 0:p.actualColumn)!=null?B:-1),endRow:Math.max(f.endRow,(z=p==null?void 0:p.actualRow)!=null?z:-1),endColumn:Math.max(f.endColumn,(F=p==null?void 0:p.actualColumn)!=null?F:-1)}),!E)return!1;const y=Pe({range:E,style:null,primary:null},o);(l.startRow!==E.startRow||l.startColumn!==E.startColumn||l.endRow!==E.endRow||l.endColumn!==E.endColumn)&&t&&(t.updateRangeBySelectionWithCoord(y),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateControlPointWhenScrolling(){const{scene:i}=this._context;if(!i.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN))return;const t=this._scrollManagerService.validViewportScrollInfo$.subscribe(r=>{var g;if(r==null)return;const{viewportScrollX:o,viewportScrollY:s}=r,l=this.getActiveSelectionControl();if(l==null)return;const c=(g=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:g.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(o,0,u,d)});this.disposeWithMe(a.toDisposable(t))}};wi=GC([st(1,a.Inject(a.Injector)),st(2,a.Inject(a.ThemeService)),st(3,I.IShortcutService),st(4,a.Inject(m.SheetsSelectionsService)),st(5,a.Inject(exports.SheetSkeletonManagerService)),st(6,a.ILogService),st(7,a.ICommandService),st(8,a.IContextService),st(9,a.Inject(exports.SheetScrollManagerService))],wi);var ZC=Object.defineProperty,KC=Object.getOwnPropertyDescriptor,qC=(n,i,e)=>i in n?ZC(n,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[i]=e,QC=(n,i,e,t)=>{for(var r=t>1?void 0:t?KC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Do=(n,i)=>(e,t)=>i(e,t,n),hd=(n,i,e)=>qC(n,typeof i!="symbol"?i+"":i,e);exports.UniverSheetsMobileUIPlugin=class extends a.Plugin{constructor(i=Fo,e,t,r){super(),this._config=i,this._injector=e,this._renderManagerService=t,this._univerInstanceService=r}onStarting(){[[bn],[Ue,{useClass:exports.SheetClipboardService}],[qt,{useClass:fl}],[$e,{useClass:ui}],[wt,{useClass:exports.AutoFillService}],[zs],[Ce,{useClass:wi}],[Ir,{useClass:ys}],[Qt,{useClass:exports.MarkSelectionService}],[me,{useClass:exports.EditorBridgeService}],[exports.HoverManagerService],[exports.DragManagerService],[exports.SheetCanvasPopManagerService],[exports.CellAlertManagerService],[vs],[js,{useClass:exports.SheetCellDropdownManagerService}],[dr],[exports.AutoHeightController],[An],[exports.SheetsRenderService],[Ci],[exports.StatusBarController],[m.IRefSelectionsService,{useClass:m.RefSelectionsService}],[Pn],[Mt],[Ri],[ur],[exports.SheetPermissionCheckUIController],[hr]].forEach(i=>this._injector.add(i))}onReady(){this._markSheetAsFocused(),this._registerRenderBasics(),this._injector.get(Ci)}onRendered(){this._registerRenderModules()}_registerRenderBasics(){[[exports.SheetSkeletonManagerService],[exports.SheetRenderController],[Ce,{useClass:wi}],[exports.SheetScrollManagerService]].forEach(i=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,i))})}_registerRenderModules(){[[exports.HeaderMoveRenderController],[exports.HeaderFreezeRenderController],[rs],[or],[Ei],[Si],[fi],[vi],[exports.HoverRenderController],[exports.DragRenderController],[pi],[exports.CellCustomRenderController],[ns],[Ii],[_i],[bi]].forEach(i=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,i))})}_markSheetAsFocused(){const i=this._univerInstanceService;this.disposeWithMe(i.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).pipe(he.filter(e=>!!e)).subscribe(e=>{this._univerInstanceService.getFocusedUnit()!==e&&i.focusUnit(e.getUnitId())}))}};hd(exports.UniverSheetsMobileUIPlugin,"pluginName","SHEET_UI_PLUGIN");hd(exports.UniverSheetsMobileUIPlugin,"type",a.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsMobileUIPlugin=QC([a.DependentOn(m.UniverSheetsPlugin,I.UniverMobileUIPlugin),Do(1,a.Inject(a.Injector)),Do(2,T.IRenderManagerService),Do(3,a.IUniverInstanceService)],exports.UniverSheetsMobileUIPlugin);var JC=Object.getOwnPropertyDescriptor,$C=(n,i,e,t)=>{for(var r=t>1?void 0:t?JC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Qr=(n,i)=>(e,t)=>i(e,t,n);let Ti=class extends a.Disposable{constructor(i,e,t,r){super();w(this,"_isPointer",!1);this._hoverManagerService=i,this._instanceService=e,this._commandService=t,this._renderManagerService=r,this._initPointerEvent(),this._initHover()}get _mainComponent(){var i;return(i=T.getCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,this._instanceService,this._renderManagerService))==null?void 0:i.mainComponent}_initHover(){this.disposeWithMe(this._hoverManagerService.currentRichText$.subscribe(i=>{var e,t;i!=null&&i.bullet?(this._isPointer||(e=this._mainComponent)==null||e.setCursor(T.CURSOR_TYPE.POINTER),this._isPointer=!0):(this._isPointer&&((t=this._mainComponent)==null||t.setCursor(T.CURSOR_TYPE.AUTO)),this._isPointer=!1)}))}_initPointerEvent(){this.disposeWithMe(this._hoverManagerService.currentClickedCell$.subscribe(i=>{const{location:e,bullet:t}=i;t&&this._commandService.executeCommand(m.ToggleCellCheckboxCommand.id,{unitId:e.unitId,subUnitId:e.subUnitId,row:e.row,col:e.col,paragraphIndex:t.startIndex})}))}};Ti=$C([Qr(0,a.Inject(exports.HoverManagerService)),Qr(1,a.IUniverInstanceService),Qr(2,a.ICommandService),Qr(3,T.IRenderManagerService)],Ti);var eI=Object.getOwnPropertyDescriptor,tI=(n,i,e,t)=>{for(var r=t>1?void 0:t?eI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},qn=(n,i)=>(e,t)=>i(e,t,n);let yi=class extends a.Disposable{constructor(n,i,e,t,r){super(),this._selectionManagerService=n,this._themeService=i,this._instanceSrv=e,this._cmdSrv=t,this._definedNamesService=r,this._init()}_init(){this.disposeWithMe(x.merge(this._selectionManagerService.selectionMoveStart$,this._selectionManagerService.selectionMoving$,this._selectionManagerService.selectionMoveEnd$,this._selectionManagerService.selectionSet$).pipe(x.filter(n=>!!n)).subscribe(n=>{this._syncDefinedNameRange(n)})),this.disposeWithMe(this._definedNamesService.focusRange$.subscribe(async n=>{if(n==null)return;const{unitId:i}=n;let{formulaOrRefString:e}=n;if(e.substring(0,1)===K.operatorToken.EQUALS&&(e=e.substring(1)),!K.isReferenceStrings(e))return;const r=this._instanceSrv.getUnit(i),o=await this._getSelections(r,i,e);this._selectionManagerService.setSelections(o),this._cmdSrv.executeCommand(m.ScrollToCellOperation.id,{unitId:i,range:o[0].range})}))}_syncDefinedNameRange(n){if(n.length===0)return;const i=n[n.length-1],e=this._instanceSrv.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),t=e==null?void 0:e.getActiveSheet();t&&this._definedNamesService.setCurrentRange({range:i.range,unitId:e.getUnitId(),sheetId:t.getSheetId()})}async _getSelections(n,i,e){const t=e.split(",");let r=n.getActiveSheet();if(!r)return[];const o=[];for(let s=0;s<t.length;s++){const l=t[s].trim(),c=K.deserializeRangeWithSheet(l.trim());if(s===0){const u=n.getSheetBySheetName(c.sheetName);u&&r.getSheetId()!==u.getSheetId()&&(r=u,await this._cmdSrv.executeCommand(m.SetWorksheetActivateCommand.id,{subUnitId:r.getSheetId(),unitId:i}))}if(r.getName()!==c.sheetName)continue;let d=null;if(s===t.length-1){const u=c.range,{startRow:h,startColumn:g,endRow:S,endColumn:f}=u;d=m.getPrimaryForRange({startRow:h,startColumn:g,endRow:S,endColumn:f},r)}o.push({range:c.range,style:bt(this._themeService),primary:d})}return o}};yi=tI([qn(0,a.Inject(m.SheetsSelectionsService)),qn(1,a.Inject(a.ThemeService)),qn(2,a.IUniverInstanceService),qn(3,a.ICommandService),qn(4,K.IDefinedNamesService)],yi);var nI=Object.getOwnPropertyDescriptor,rI=(n,i,e,t)=>{for(var r=t>1?void 0:t?nI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},at=(n,i)=>(e,t)=>i(e,t,n);exports.FormulaEditorController=class extends a.RxDisposable{constructor(e,t,r,o,s,l,c,d,u){super();w(this,"_loadedMap",new WeakSet);w(this,"_scheduledCallback",-1);this._univerInstanceService=e,this._renderManagerService=t,this._editorBridgeService=r,this._commandService=o,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(x.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:r}=t;r===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:r}=t;r!=null&&(this._loadedMap.has(r)||this._loadedMap.add(r))}_listenFxBtnClick(){this._formulaEditorManagerService.fxBtnClick$.pipe(x.takeUntil(this.dispose$)).subscribe(()=>{var t,r;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 o=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(fe.id,{visible:!0,eventType:T.DeviceInputEventType.PointerDown,unitId:(t=o==null?void 0:o.getUnitId())!=null?t:""});const c=(r=s==null?void 0:s.getBody())==null?void 0:r.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($.CoverContentCommand.id,h),this._textSelectionManagerService.replaceDocRanges(u)}})}_syncEditorSize(){const e=this._univerInstanceService.unitAdded$.pipe(x.filter(t=>t.getUnitId()===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY));this.disposeWithMe(x.combineLatest([this._formulaEditorManagerService.position$,e]).subscribe(([t])=>{if(!t)return this._clearScheduledCallback();const r=ki(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,this._renderManagerService),o=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(r==null||o==null)return this._clearScheduledCallback();const{width:s,height:l}=t;if(s===0||l===0)return this._clearScheduledCallback();const{engine:c}=r;o.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(),r=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),o=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(t==null||e==null||r==null||o==null)return;const{marginTop:s=0,marginBottom:l=0}=o.getSnapshot().documentStyle,{scene:c,mainComponent:d}=r;let{actualHeight:u}=t.getActualSize();u+=s+l;const{width:h,height:g}=e,S=c.getViewport($.VIEWPORT_KEY.VIEW_MAIN);let f=S==null?void 0:S.getScrollBar();c.transformByState({width:h,height:u}),d==null||d.resize(h,u),u>g?f==null?S&&new T.ScrollBar(S,{enableHorizontal:!1,barSize:8}):S==null||S.resetCanvasSizeAndUpdateScroll():(f=null,S==null||S.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0}),(v=S==null?void 0:S.getScrollBar())==null||v.dispose())}};exports.FormulaEditorController=rI([at(0,a.IUniverInstanceService),at(1,T.IRenderManagerService),at(2,me),at(3,a.ICommandService),at(4,a.IContextService),at(5,Cr),at(6,a.IUndoRedoService),at(7,a.Inject(_e.DocSelectionManagerService)),at(8,$.IEditorService)],exports.FormulaEditorController);var iI=Object.getOwnPropertyDescriptor,oI=(n,i,e,t)=>{for(var r=t>1?void 0:t?iI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},pt=(n,i)=>(e,t)=>i(e,t,n);const sI={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 Mi=class extends a.Disposable{constructor(n,i,e,t,r,o,s,l){super(),this._univerInstanceService=n,this._renderManagerService=i,this._editorBridgeService=e,this._commandService=t,this._rangeProtectionRuleModel=r,this._worksheetProtectionRuleModel=o,this._formulaEditorController=s,this._formulaEditorManagerService=l,this._initialize()}_initialize(){this._syncFormulaEditorContent(),this._commandExecutedListener()}_getEditorViewModel(n){var i;return(i=this._renderManagerService.getRenderById(n))==null?void 0:i.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 r,o,s;let i=a.Tools.deepClone((r=n.documentLayoutObject.documentModel)==null?void 0:r.getBody());const e=a.Tools.deepClone((o=n.documentLayoutObject.documentModel)==null?void 0:o.drawings),t=a.Tools.deepClone((s=n.documentLayoutObject.documentModel)==null?void 0:s.getDrawingsOrder());(!i||n.isInArrayFormulaRange===!0&&this._editorBridgeService.isVisible().eventType===T.DeviceInputEventType.Dblclick)&&(i={dataStream:`\r
82
+ `)}]}}var hp=Object.getOwnPropertyDescriptor,mp=(n,i,e,t)=>{for(var r=t>1?void 0:t?hp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ge=(n,i)=>(e,t)=>i(e,t,n);const gp=[m.InsertColMutation.id,m.InsertRowMutation.id,m.RemoveColMutation.id,m.RemoveRowMutation.id,m.MoveRangeMutation.id,m.MoveRowsMutation.id,m.MoveColsMutation.id];let An=class extends a.RxDisposable{constructor(i,e,t,r,o,s,l,c,d,u){super();w(this,"_refreshOptionalPaste$",new x.Subject);w(this,"refreshOptionalPaste$",this._refreshOptionalPaste$.asObservable());this._injector=i,this._instanceService=e,this._renderManagerService=t,this._commandService=r,this._contextService=o,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 i=r=>{r.onPaste$.pipe(x.takeUntil(this.dispose$)).subscribe(o=>{var u,h;if(!ae(this._contextService))return;o.event.preventDefault();const s=o.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(di.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($.DocSelectionRenderService);e&&i(e),this._renderManagerService.created$.subscribe(r=>{var o;r.unitId===a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY&&(e=(o=this._renderManagerService.getRenderById(a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY))==null?void 0:o.with($.DocSelectionRenderService),e&&i(e))})}_resolveClipboardFiles(i){if(!i)return;const e=Array.from(i.items).map(t=>t.kind==="file"?t.getAsFile():void 0).filter(Boolean);return e.length>0?e:void 0}_init(){[je,Fi,ze].forEach(e=>this.disposeWithMe(this._commandService.registerMultipleCommand(e))),[gn,Sn,Lt,fn,di,Ul].forEach(e=>this.disposeWithMe(this._commandService.registerCommand(e))),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initCopyingHooks())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initPastingHook()));const i=this._initSpecialPasteHooks().map(e=>this._sheetClipboardService.addClipboardHook(e));this.disposeWithMe({dispose:()=>i.forEach(e=>e.dispose())})}_initCopyingHooks(){const i=this;let e=null;return{id:Se.DEFAULT_COPY,isDefaultHook:!0,onBeforeCopy(t,r){e=i._getWorksheet(t,r)},onCopyCellContent(t,r){var l,c,d,u;const o=e.getCell(t,r);return(c=(l=o==null?void 0:o.p)==null?void 0:l.body)!=null&&c.paragraphs||(u=(d=o==null?void 0:o.p)==null?void 0:d.body)!=null&&u.textRuns?a.convertBodyToHtml(o.p.body):o?a.extractPureTextFromCell(o):""},onCopyCellStyle:(t,r,o,s)=>{const l={};(o||s)&&(l.rowspan=`${o||1}`,l.colspan=`${s||1}`);const c=e.getRange(t,r),d=e.getMergedCell(t,r),u=c.getTextStyle();let h="";if(u&&(h=a.handleStyleToString(u)),d){const g=d.endRow,S=d.endColumn,p=e.getRange(g,S).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:r,endRow:o}=t,s=(c=i._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET))==null?void 0:c.getActiveSheet(),l=[];if(!s)return l;for(let d=r;d<=o;d++)s.getRowFiltered(d)&&l.push(d);return l}}}_initPastingHook(){const i=this;let e=null,t=null,r=null;return{id:Se.DEFAULT_PASTE,isDefaultHook:!0,onBeforePaste({unitId:o,subUnitId:s,range:l}){r=i._getWorksheet(o,s),e=o,t=s;const c=i._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?(i._messageService.show({type:X.MessageType.Error,content:i._localService.t("clipboard.paste.exceedMaxCells")}),!1):!0},onPasteRows(o,s){const{range:l}=o,c=[],d=[],u=r.getMaxRows(),h=u-1,g=l.rows[l.rows.length-1]-h,S=s.length-g,f=r.getRowManager();if(g>0){const C={};s.slice(S).forEach((E,P)=>{const{height:y}=E||{};y&&(C[P]={h:Number.parseFloat(y),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},R={unitId:e,subUnitId:t,range:b,rowInfo:C};c.push({id:m.InsertRowMutation.id,params:R}),d.push({id:m.RemoveRowMutation.id,params:{unitId:e,subUnitId:t,range:b}})}const p={},v={};if(s.slice(0,S).forEach((C,b)=>{var E,P;const{height:R}=C;if(R){const y=f.getRow(l.rows[0]+b),M=Number.parseFloat(R);if(y){const{h:O=a.DEFAULT_WORKSHEET_ROW_HEIGHT,ah:A=0}=y,k=Math.max(O,A);M>k?(p[b+l.rows[0]]=M,v[b+l.rows[0]]=k):(p[b+l.rows[0]]=k,v[b+l.rows[0]]=k)}else p[b+l.rows[0]]=M,v[b+l.rows[0]]=(P=(E=f.getRow(l.rows[0]+b))==null?void 0:E.h)!=null?P: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(o,s,l){var R;const{range:c}=o,d=[],u=[],h=r.getMaxColumns(),g=h-1,S=c.cols[c.cols.length-1]-g,f=s.length-S,p=(R=i._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?R:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,v=c.cols,C=v[0];if(S>0){const E={startRow:c.rows[0],endRow:c.rows[c.rows.length-1],endColumn:c.cols[c.cols.length-1],startColumn:h},P={unitId:e,subUnitId:t,range:E,colInfo:s.slice(f).map((y,M)=>({w:y.width?Math.max(+y.width,r.getColumnWidth(v[M])):p,hd:a.BooleanNumber.FALSE}))};d.push({id:m.InsertColMutation.id,params:P}),u.push({id:m.RemoveColMutation.id,params:{unitId:e,subUnitId:t,range:E}})}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 E={...b,colWidth:s.slice(0,f).reduce((y,M,O)=>{var A;return y[O+C]=M.width?Math.max(+M.width,(A=r.getColumnWidth(v[O]))!=null?A:p):p,y},{})},P={...b,colWidth:s.slice(0,f).reduce((y,M,O)=>{var A;return y[O+C]=(A=r.getColumnWidth(v[O]))!=null?A:p,y},{})};d.push({id:m.SetWorksheetColWidthMutation.id,params:E}),u.push({id:m.SetWorksheetColWidthMutation.id,params:P})}return{redos:d,undos:u}},onPastePlainText(o,s,l){return i._onPastePlainText(o,s,l)},onPasteCells(o,s,l,c){return i._onPasteCells(o,s,l,c)},onAfterPaste(o){r=null}}}_generateDocumentDataModelSnapshot(i){var l,c;const e=(l=T.withCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService,this._instanceService,this._renderManagerService))==null?void 0:l.getCurrentParam();if(e==null)return null;const{skeleton:t}=e,r=(c=t.getBlankCellDocumentModel())==null?void 0:c.documentModel,s={...r==null?void 0:r.getSnapshot(),...i};return r==null||r.reset(s),r==null?void 0:r.getSnapshot()}_onPastePlainText(i,e,t){const{range:r,unitId:o,subUnitId:s}=i;let l;if(/\r|\n/.test(e)||a.Tools.isLegalUrl(e)){const d=up(e),u=this._generateDocumentDataModelSnapshot({body:d});l={[r.rows[0]]:{[r.cols[0]]:{p:u}}}}else a.isFormulaString(e)?l={[r.rows[0]]:{[r.cols[0]]:{f:e}}}:l={[r.rows[0]]:{[r.cols[0]]:{v:e}}};const c={unitId:o,subUnitId:s,cellValue:l};return{redos:[{id:m.SetRangeValuesMutation.id,params:c}],undos:[{id:m.SetRangeValuesMutation.id,params:m.SetRangeValuesUndoMutationFactory(this._injector,c)}]}}_onPasteCells(i,e,t,r){return this._injector.invoke(o=>lp(i,e,t,r,o))}_initSpecialPasteHooks(){const i=this,e={id:Se.SPECIAL_PASTE_VALUE,specialPasteInfo:{label:"specialPaste.value"},onPasteCells:(s,l,c)=>this._injector.invoke(d=>Zc(l,s,c,d))},t={id:Se.SPECIAL_PASTE_FORMAT,specialPasteInfo:{label:"specialPaste.format"},onPasteCells:(s,l,c)=>{const d=[],u=[],{undos:h,redos:g}=this._injector.invoke(C=>qc(l,c,C));d.push(...g),u.push(...h);const{undos:S,redos:f}=this._injector.invoke(C=>ts(l,c,C));d.push(...f),u.push(...S);const{undos:p,redos:v}=this._injector.invoke(C=>Kc(l,s,c,C));return d.push(...v),u.push(...p),{undos:u,redos:d}}},r={id:Se.SPECIAL_PASTE_COL_WIDTH,specialPasteInfo:{label:"specialPaste.colWidth"},onPasteCells(){return{undos:[],redos:[]}},onPasteColumns(s,l,c){var O,A;const d=i._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),u=d.getUnitId(),h=(O=d.getActiveSheet())==null?void 0:O.getSheetId();if(!u||!h)throw new Error("Cannot find unitId or subUnitId");const g=[],S=[],f=i._getWorksheet(u,h),{range:p}=s,v=p.cols,C=v[0],b=f.getMaxColumns(),R=p.cols[p.cols.length-1]-b,E=l.length-R,P=(A=i._configService.getConfig(a.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?A:a.DEFAULT_WORKSHEET_COLUMN_WIDTH,y={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,E).reduce((k,D,N)=>{var W;return k[N+C]=D.width?Math.max(+D.width,(W=f.getColumnWidth(v[N]))!=null?W:P):P,k},{})},M={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,E).reduce((k,D,N)=>{var W;return k[N+C]=(W=f.getColumnWidth(v[N]))!=null?W:P,k},{})};return g.push({id:m.SetWorksheetColWidthMutation.id,params:y}),S.push({id:m.SetWorksheetColWidthMutation.id,params:M}),{redos:g,undos:S}}},o={id:Se.SPECIAL_PASTE_BESIDES_BORDER,specialPasteInfo:{label:"specialPaste.besidesBorder"},onPasteCells:(s,l,c,d)=>{i._instanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);const u=[],h=[],{range:g,unitId:S,subUnitId:f}=l,p=new a.ObjectMatrix;c.forValue((E,P,y)=>{const M=y.s;if(typeof M=="object"){const O=a.Tools.deepClone(y);O.s&&(O.s={...M,bd:null}),p.setValue(g.rows[E],g.cols[P],O)}});const v={unitId:S,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:R}=this._injector.invoke(E=>ts(l,c,E));return h.push(...b),u.push(...R),{redos:u,undos:h}}};return[e,t,r,o]}_getWorksheet(i,e){var r;const t=(r=this._instanceService.getUniverSheetInstance(i))==null?void 0:r.getSheetBySheetId(e);if(!t)throw new Error(`[SheetClipboardController]: cannot find a worksheet with unitId ${i} and subUnitId ${e}.`);return t}_initCommandListener(){var e;this.disposeWithMe(this._commandService.onCommandExecuted(t=>{t.id===yt.id?this._sheetClipboardService.removeMarkSelection():gp.includes(t.id)&&this._sheetClipboardService.removeMarkSelection()}));const i=this._configService.getConfig(Xe);(e=i==null?void 0:i.clipboardConfig)!=null&&e.hidePasteOptions||(this.disposeWithMe(this._commandService.onCommandExecuted(t=>{ap.includes(t.id)&&this._sheetClipboardService.disposePasteOptionsCache()})),this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===Be.id){if(!this._sheetClipboardService.getPasteMenuVisible())return;const o=t.params.unitId,s=this._sheetClipboardService.getPasteOptionsCache(),l=s==null?void 0:s.target.unitId;o===l&&this._refreshOptionalPaste$.next(Math.random())}})))}_initUIComponents(){var e;const i=this._configService.getConfig(Xe);(e=i==null?void 0:i.clipboardConfig)!=null&&e.hidePasteOptions||this.disposeWithMe(this._uiPartsService.registerComponent(I.BuiltInUIPart.CONTENT,()=>I.connectInjector(sp,this._injector)))}};An=mp([Ge(0,a.Inject(a.Injector)),Ge(1,a.IUniverInstanceService),Ge(2,T.IRenderManagerService),Ge(3,a.ICommandService),Ge(4,a.IContextService),Ge(5,a.IConfigService),Ge(6,Ue),Ge(7,I.IMessageService),Ge(8,a.Inject(a.LocaleService)),Ge(9,I.IUIPartsService)],An);var Sp=Object.getOwnPropertyDescriptor,fp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Sp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ua=(n,i)=>(e,t)=>i(e,t,n);exports.DragManagerService=class extends a.Disposable{constructor(e,t){super();w(this,"_currentCell$",new x.Subject);w(this,"currentCell$",this._currentCell$.asObservable().pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)})));w(this,"_endCell$",new x.Subject);w(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 r=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!r)return null;const o=r.getActiveSheet();if(!o)return;const s=this._renderManagerService.getRenderById(r.getUnitId());if(!s)return;const l=s.with(exports.SheetSkeletonManagerService).getCurrentParam(),d=s.with(exports.SheetScrollManagerService).getCurrentScrollState();if(!(!l||!d||!s))return Jl(s,r,o,l,e,t)}onDragOver(e){const{offsetX:t,offsetY:r,dataTransfer:o}=e,s=this._calcActiveCell(t,r);if(!s){this._currentCell$.next(null);return}const{location:l,position:c}=s;this._currentCell$.next({location:l,position:c,dataTransfer:o})}onDrop(e){const{offsetX:t,offsetY:r,dataTransfer:o}=e,s=this._calcActiveCell(t,r);if(!s){this._endCell$.next(null);return}const{location:l,position:c}=s;this._endCell$.next({location:l,position:c,dataTransfer:o})}};exports.DragManagerService=fp([Ua(0,a.IUniverInstanceService),Ua(1,T.IRenderManagerService)],exports.DragManagerService);var pp=Object.getOwnPropertyDescriptor,vp=(n,i,e,t)=>{for(var r=t>1?void 0:t?pp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Mo=(n,i)=>(e,t)=>i(e,t,n);exports.DragRenderController=class extends a.Disposable{constructor(i,e,t,r){super(),this._context=i,this._renderManagerService=e,this._dragManagerService=t,this._sheetSkeletonManagerService=r,this._initDragEvent()}_initDragEvent(){const i=new a.DisposableCollection,e=t=>{if(i.dispose(),!t)return;const{scene:r}=this._context,o=r.onDragOver$.subscribeEvent(l=>{this._dragManagerService.onDragOver(l)}),s=r.onDrop$.subscribeEvent(l=>{this._dragManagerService.onDrop(l)});i.add({dispose(){o.unsubscribe(),s.unsubscribe()}})};e(this._sheetSkeletonManagerService.getCurrentParam()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(t=>{e(t)}))}};exports.DragRenderController=vp([Mo(1,T.IRenderManagerService),Mo(2,a.Inject(exports.DragManagerService)),Mo(3,a.Inject(exports.SheetSkeletonManagerService))],exports.DragRenderController);const Bs=(n,i)=>{var h,g,S,f,p;const t=i.findNodePositionByCharIndex(n.startOffset,!0,n.segmentId,-1),r=i.getSkeletonData();let o=n.endOffset;if(n.segmentId){const v=(p=Array.from((g=(h=r==null?void 0:r.skeFooters.get(n.segmentId))==null?void 0:h.values())!=null?g:[])[0])!=null?p:Array.from((f=(S=r==null?void 0:r.skeHeaders.get(n.segmentId))==null?void 0:S.values())!=null?f:[])[0];v&&(o=Math.min(v.ed,o))}const s=i.findNodePositionByCharIndex(o,!0,n.segmentId,-1);if(!s||!t)return;const l={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},c=new $.NodePositionConvertToCursor(l,i),{borderBoxPointGroup:d}=c.getRangePointData(t,s);return $.getLineBounding(d).map(v=>({top:v.top,bottom:v.bottom,left:v.left,right:v.right}))},Cp=(n,i,e=-1)=>{const t=i.findPositionByGlyph(n,e);if(!t)return;const r={...t,isBack:!0},o={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},s=new $.NodePositionConvertToCursor(o,i),{borderBoxPointGroup:l}=s.getRangePointData(r,r),d=$.getLineBounding(l)[0];return{top:d.top,bottom:d.bottom,left:d.left,right:d.right}},Ip=(n,i,e=0,t=0)=>{const r=Bs({startOffset:i.startIndex,endOffset:i.endIndex+1},n);if(r)return{rects:r.map(o=>({top:o.top+t,bottom:o.bottom+t,left:o.left+e,right:o.right+e})),range:i}},_p=(n,i,e=0,t=0)=>{var h,g,S;const r=n.findNodeByCharIndex(i.startIndex),o=r==null?void 0:r.parent,s=o==null?void 0:o.parent,l=s==null?void 0:s.parent,c=l==null?void 0:l.lines.find(f=>f.paragraphStart&&f.paragraphIndex===i.startIndex),d=(S=(g=(h=c==null?void 0:c.divides)==null?void 0:h[0])==null?void 0:g.glyphGroup)==null?void 0:S[0];if(!d||!d)return;const u=Cp(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:i}},Qc=(n,i=0,e=0)=>{var l,c,d,u,h,g,S;const t=n.getViewModel().getDataModel(),r=(d=(c=(l=t.getBody())==null?void 0:l.customRanges)==null?void 0:c.filter(f=>f.rangeType===a.CustomRangeType.HYPERLINK))!=null?d:[],o=(g=(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?g:[],s=(S=n.getSkeletonData())==null?void 0:S.pages[0].skeDrawings;return{links:r.map(f=>Ip(n,f,i,e)).filter(Boolean),checkLists:o.map(f=>_p(n,f,i,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 Jc(n,i,e){var d,u,h,g,S,f;const t=(h=(u=(d=i.documentSkeleton)==null?void 0:d.getSkeletonData())==null?void 0:u.pages[0].height)!=null?h:0,r=(f=(S=(g=i.documentSkeleton)==null?void 0:g.getSkeletonData())==null?void 0:S.pages[0].width)!=null?f:0,o=i.verticalAlign,s=i.horizontalAlign;let l=0;switch(o){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-r;break;case a.HorizontalAlign.CENTER:c=(n.mergeInfo.endX-n.mergeInfo.startX-r)/2;break;case a.HorizontalAlign.UNSPECIFIED:{e&&(c=n.mergeInfo.endX-n.mergeInfo.startX-r);break}}return{paddingLeft:c,paddingTop:l}}const bp=(n,i,e,t,r,o)=>{var D,N,W;const s=n.get(a.IUniverInstanceService),l=n.get(T.IRenderManagerService),c=s.getUnit(i,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(exports.SheetSkeletonManagerService).getSkeletonParam(d.getSheetId()),g=h==null?void 0:h.skeleton;if(!g||!u)return;const S=g.getFont(t,r),f=S==null?void 0:S.documentSkeleton;if(!f)return null;const p=(N=(D=f.getViewModel().getBody())==null?void 0:D.customRanges)==null?void 0:N.find(H=>H.rangeId===o);if(!p)return null;const v=$.DOC_VERTICAL_PADDING,C=g.getCellWithCoordByIndex(t,r);let{actualColumn:b,actualRow:R}=C;g.overflowCache.forValue((H,L,U)=>{U.startRow<=R&&U.endRow>=R&&U.startColumn<=b&&U.endColumn>=b&&(b=L,R=H)});const E=g.getCellWithCoordByIndex(R,b),P=d.getCell(E.actualRow,E.actualColumn),{topOffset:y=0,leftOffset:M=0}=(W=P==null?void 0:P.fontRenderExtension)!=null?W:{},{paddingLeft:O,paddingTop:A}=Jc(E,S,!1),k=Bs({startOffset:p.startIndex,endOffset:p.endIndex},f);return{rects:k==null?void 0:k.map(H=>({top:H.top+E.mergeInfo.startY+A+y+v,bottom:H.bottom+E.mergeInfo.startY+A+y+v,left:H.left+E.mergeInfo.startX+O+M,right:H.right+E.mergeInfo.startX+O+M})),customRange:p,label:f.getViewModel().getBody().dataStream.slice(p.startIndex,p.endIndex+1)}},Rp=(n,i,e,t,r,o)=>{var M,O,A;const s=n.get(me),l=s.getEditCellState();if(!l||!s.isVisible().visible)return null;const{editorUnitId:d,unitId:u,sheetId:h,row:g,column:S}=l;if(i!==u||e!==h||g!==t||S!==r)return null;const f=n.get(T.IRenderManagerService),p=f.getRenderById(d),v=f.getRenderById(i);if(!p||!v)return null;const C=p.with(_e.DocSkeletonManagerService).getSkeleton(),b=(M=v.with(exports.SheetSkeletonManagerService).getSkeletonParam(h))==null?void 0:M.skeleton;if(!C||!b)return null;const R=(A=(O=C.getViewModel().getBody())==null?void 0:O.customRanges)==null?void 0:A.find(k=>k.rangeId===o);if(!R)return null;const E=4,P=Bs({startOffset:R.startIndex,endOffset:R.endIndex},C),y=p.engine.getCanvasElement().getBoundingClientRect();return{rects:P==null?void 0:P.map(k=>({top:k.top+y.top-E,bottom:k.bottom+y.top+E,left:k.left+y.left,right:k.right+y.left})),customRange:R,label:C.getViewModel().getBody().dataStream.slice(R.startIndex,R.endIndex+1)}};var Ep=Object.getOwnPropertyDescriptor,wp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Ep(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ba=(n,i)=>(e,t)=>i(e,t,n);function Nt(n){const{workbook:i,worksheet:e,...t}=n;return t}exports.HoverManagerService=class extends a.Disposable{constructor(e,t){super();w(this,"_currentCell$",new x.BehaviorSubject(null));w(this,"_currentRichText$",new x.BehaviorSubject(null));w(this,"_currentClickedCell$",new x.Subject);w(this,"_currentDbClickedCell$",new x.Subject);w(this,"_currentCellWithEvent$",new x.Subject);w(this,"_currentPointerDownCell$",new x.Subject);w(this,"_currentPointerUpCell$",new x.Subject);w(this,"_currentHoveredRowHeader$",new x.BehaviorSubject(null));w(this,"_currentHoveredColHeader$",new x.BehaviorSubject(null));w(this,"_currentRowHeaderClick$",new x.Subject);w(this,"_currentColHeaderClick$",new x.Subject);w(this,"_currentRowHeaderDbClick$",new x.Subject);w(this,"_currentColHeaderDbClick$",new x.Subject);w(this,"_currentRowHeaderPointerDown$",new x.Subject);w(this,"_currentColHeaderPointerDown$",new x.Subject);w(this,"_currentRowHeaderPointerUp$",new x.Subject);w(this,"_currentColHeaderPointerUp$",new x.Subject);w(this,"currentCell$",this._currentCell$.asObservable().pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)})));w(this,"currentRichTextNoDistinct$",this._currentRichText$.pipe(x.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})));w(this,"currentRichText$",this._currentRichText$.pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h,g,S,f,p,v,C,b,R,E,P;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)&&((g=e==null?void 0:e.customRange)==null?void 0:g.rangeId)===((S=t==null?void 0:t.customRange)==null?void 0:S.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)===((R=t==null?void 0:t.customRange)==null?void 0:R.endIndex)&&((E=e==null?void 0:e.drawing)==null?void 0:E.drawingId)===((P=t==null?void 0:t.drawing)==null?void 0:P.drawingId)}),x.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})));w(this,"currentCellPosWithEvent$",this._currentCellWithEvent$.pipe(x.distinctUntilChanged((e,t)=>{var r,o,s,l,c,d,u,h;return((r=e==null?void 0:e.location)==null?void 0:r.unitId)===((o=t==null?void 0:t.location)==null?void 0:o.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)}),x.map(e=>e&&{unitId:e.location.unitId,subUnitId:e.location.subUnitId,row:e.location.row,col:e.location.col,event:e.event})));w(this,"currentPosition$",this._currentCell$.asObservable());w(this,"currentClickedCell$",this._currentClickedCell$.asObservable());w(this,"currentDbClickedCell$",this._currentDbClickedCell$.asObservable());w(this,"currentPointerDownCell$",this._currentPointerDownCell$.asObservable());w(this,"currentPointerUpCell$",this._currentPointerUpCell$.asObservable());w(this,"currentHoveredRowHeader$",this._currentHoveredRowHeader$.asObservable());w(this,"currentHoveredColHeader$",this._currentHoveredColHeader$.asObservable());w(this,"currentRowHeaderClick$",this._currentRowHeaderClick$.asObservable());w(this,"currentColHeaderClick$",this._currentColHeaderClick$.asObservable());w(this,"currentRowHeaderDbClick$",this._currentRowHeaderDbClick$.asObservable());w(this,"currentColHeaderDbClick$",this._currentColHeaderDbClick$.asObservable());w(this,"currentRowHeaderPointerDown$",this._currentRowHeaderPointerDown$.asObservable());w(this,"currentColHeaderPointerDown$",this._currentColHeaderPointerDown$.asObservable());w(this,"currentRowHeaderPointerUp$",this._currentRowHeaderPointerUp$.asObservable());w(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,r;((t=this._currentCell$.getValue())==null?void 0:t.location.unitId)===e.getUnitId()&&this._currentCell$.next(null),((r=this._currentRichText$.getValue())==null?void 0:r.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 r=t.getActiveSheet();if(!r)return null;const o=this._renderManagerService.getRenderById(t.getUnitId());if(!o)return null;const s=o.with(exports.SheetSkeletonManagerService).getSkeletonParam(r.getSheetId());if(!s)return null;const l=o.with(exports.SheetScrollManagerService);if(!(!(l!=null&&l.getCurrentScrollState())||!o))return{currentRender:o,workbook:t,worksheet:r,skeletonParam:s}}_calcActiveCell(e,t,r,o,s,l){var y,M,O;const c=Jl(e,t,r,o,s,l),d=o.skeleton;if(!c)return null;const{position:u,overflowLocation:h,location:g}=c,S=d.getFont(h.row,h.col);let f=null,p=null,v=null;const C=d.getCellWithCoordByIndex(h.row,h.col),b=r.getCell(h.row,h.col),{topOffset:R=0,leftOffset:E=0}=(y=b==null?void 0:b.fontRenderExtension)!=null?y:{};if(S!=null&&S.documentSkeleton){const{paddingLeft:A,paddingTop:k}=Jc(C,S,(b==null?void 0:b.v)!==null&&(b==null?void 0:b.v)!==void 0?!Number.isNaN(+b.v):!1),D=Qc(S.documentSkeleton,A,k),N=s-u.startX-E,W=l-u.startY-R;f=D.links.find(H=>H.rects.some(L=>L.left<=N&&N<=L.right&&L.top<=W&&W<=L.bottom)),p=D.checkLists.find(H=>H.rect.left<=N&&N<=H.rect.right&&H.rect.top<=W&&W<=H.rect.bottom),v=D.drawings.find(H=>H.rect.left<=N&&N<=H.rect.right&&H.rect.top<=W&&W<=H.rect.bottom)}const P=(O=(M=f==null?void 0:f.rects.pop())!=null?M:p==null?void 0:p.rect)!=null?O:v==null?void 0:v.rect;return{location:g,position:u,overflowLocation:h,customRange:f==null?void 0:f.range,bullet:p==null?void 0:p.paragraph,drawing:v,rect:P&&{top:P.top+C.mergeInfo.startY+R,bottom:P.bottom+C.mergeInfo.startY+R,left:P.left+C.mergeInfo.startX+E,right:P.right+C.mergeInfo.startX+E}}}_calcActiveRowHeader(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,worksheet:l,skeletonParam:c}=o,{scaleY:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(S=>S.isHit(new T.Vector2(t,r)));if(!u||u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP&&u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},g=c.skeleton.getRowIndexByOffsetY(r,d,h);return{unitId:e,index:g,subUnitId:l.getSheetId()}}_calcActiveColHeader(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,worksheet:l,skeletonParam:c}=o,{scaleX:d}=s.scene.getAncestorScale(),u=s.scene.getViewports().find(S=>S.isHit(new T.Vector2(t,r)));if(!u||u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT&&u.viewportKey!==T.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT)return;const h={x:u.viewportScrollX,y:u.viewportScrollY},g=c.skeleton.getColumnIndexByOffsetX(t,d,h);return{unitId:e,index:g,subUnitId:l.getSheetId()}}triggerPointerDown(e,t){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:o,workbook:s,worksheet:l,skeletonParam:c}=r,d=this._calcActiveCell(o,s,l,c,t.offsetX,t.offsetY);if(d&&d.location){const{unitId:u,subUnitId:h,row:g,col:S}=Nt(d.location);this._currentPointerDownCell$.next({unitId:u,subUnitId:h,row:g,col:S,event:t})}}triggerPointerUp(e,t){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:o,workbook:s,worksheet:l,skeletonParam:c}=r,d=this._calcActiveCell(o,s,l,c,t.offsetX,t.offsetY);if(d){const u=Nt(d.location);this._currentPointerUpCell$.next({...u,event:t})}}triggerMouseMove(e,t){const r=this._getCalcDeps(e);if(!r)return;const{currentRender:o,workbook:s,worksheet:l,skeletonParam:c}=r,d=this._calcActiveCell(o,s,l,c,t.offsetX,t.offsetY);this._currentCell$.next(d&&{location:Nt(d.location),position:d.position}),this._currentRichText$.next(d&&{...d,location:Nt(d.overflowLocation)}),this._currentCellWithEvent$.next(d&&{...d,location:Nt(d.location),event:t})}triggerClick(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=o,u=this._calcActiveCell(s,l,c,d,t,r);u&&this._currentClickedCell$.next({...u,location:Nt(u.location)})}triggerDbClick(e,t,r){const o=this._getCalcDeps(e);if(!o)return;const{currentRender:s,workbook:l,worksheet:c,skeletonParam:d}=o,u=this._calcActiveCell(s,l,c,d,t,r);u&&this._currentDbClickedCell$.next({...u,location:Nt(u.location)})}triggerScroll(){this._currentCell$.next(null)}triggerRowHeaderClick(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderClick$.next(o)}triggerColHeaderClick(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderClick$.next(o)}triggerRowHeaderDbClick(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderDbClick$.next(o)}triggerColHeaderDbClick(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderDbClick$.next(o)}triggerRowHeaderMouseMove(e,t,r){this._currentHoveredRowHeader$.next(this._calcActiveRowHeader(e,t,r))}triggerColHeaderMouseMove(e,t,r){this._currentHoveredColHeader$.next(this._calcActiveColHeader(e,t,r))}triggerRowHeaderPoniterDown(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderPointerDown$.next(o)}triggerColHeaderPoniterDown(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderPointerDown$.next(o)}triggerRowHeaderPoniterUp(e,t,r){const o=this._calcActiveRowHeader(e,t,r);o&&this._currentRowHeaderPointerUp$.next(o)}triggerColHeaderPoniterUp(e,t,r){const o=this._calcActiveColHeader(e,t,r);o&&this._currentColHeaderPointerUp$.next(o)}};exports.HoverManagerService=wp([Ba(0,a.IUniverInstanceService),Ba(1,T.IRenderManagerService)],exports.HoverManagerService);var Tp=Object.getOwnPropertyDescriptor,yp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Tp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Yr=(n,i)=>(e,t)=>i(e,t,n);const Po="SHEET_FORCE_STRING_ALERT";let fi=class extends a.Disposable{constructor(n,i,e,t,r){super(),this._context=n,this._hoverManagerService=i,this._cellAlertManagerService=e,this._localeService=t,this._zenZoneService=r,this._init()}_init(){this._initCellAlertPopup(),this._initZenService()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(n=>{var i;if(n){const t=this._context.unit.getActiveSheet();if(!t)return;const r=t.getCell(n.location.row,n.location.col);if((r==null?void 0:r.t)===a.CellValueType.FORCE_STRING&&r.v&&a.isRealNum(r.v)){const o=this._cellAlertManagerService.currentAlert.get(Po),s=(i=o==null?void 0:o.alert)==null?void 0:i.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:Po});return}}this._hideAlert()}))}_initZenService(){this.disposeWithMe(this._zenZoneService.visible$.subscribe(n=>{n&&this._hideAlert()}))}_hideAlert(){this._cellAlertManagerService.removeAlert(Po)}};fi=yp([Yr(1,a.Inject(exports.HoverManagerService)),Yr(2,a.Inject(exports.CellAlertManagerService)),Yr(3,a.Inject(a.LocaleService)),Yr(4,I.IZenZoneService)],fi);var Mp=Object.getOwnPropertyDescriptor,Pp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Mp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Fa=(n,i)=>(e,t)=>i(e,t,n);let pi=class extends a.RxDisposable{constructor(n,i,e){super(),this._context=n,this._sheetSkeletonManagerService=i,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:(i,e,t)=>{var s,l;if(!((s=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:s.skeleton))return t(i);const o=e.worksheet.getCellRaw(e.row,e.col);if(!o||o.v===null||o.v===void 0)return t(i);if(((i==null?void 0:i.t)===a.CellValueType.FORCE_STRING||(i==null?void 0:i.t)===a.CellValueType.STRING)&&a.isRealNum(o.v)){const c=e.workbook.getStyles().get(o.s);return Ai.isTextFormat((l=c==null?void 0:c.n)==null?void 0:l.pattern)?t(i):t({...i,markers:{...i==null?void 0:i.markers,...n}})}return t(i)}}))}};pi=Pp([Fa(1,a.Inject(exports.SheetSkeletonManagerService)),Fa(2,a.Inject(m.SheetInterceptorService))],pi);var Op=Object.getOwnPropertyDescriptor,xp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Op(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Oo=(n,i)=>(e,t)=>i(e,t,n);exports.HoverRenderController=class extends a.Disposable{constructor(e,t,r,o){super();w(this,"_active",!1);this._context=e,this._hoverManagerService=t,this._sheetSkeletonManagerService=r,this._scrollManagerService=o,this._initPointerEvent(),this._initScrollEvent()}get active(){return this._active}_initPointerEvent(){const e=new a.DisposableCollection,t=r=>{if(e.dispose(),!r)return;const{mainComponent:o,unitId:s,components:l}=this._context;if(!o)return;e.add(o.onPointerEnter$.subscribeEvent(u=>{this._active=!0})),e.add(a.fromEventSubject(o.onPointerMove$).subscribe(u=>{this._active=!0,this._hoverManagerService.triggerMouseMove(s,u)})),e.add(o.onPointerDown$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerDown(s,u)})),e.add(o.onPointerUp$.subscribeEvent(u=>{this._hoverManagerService.triggerPointerUp(s,u)})),e.add(o.onClick$.subscribeEvent(u=>{this._hoverManagerService.triggerClick(s,u.offsetX,u.offsetY)})),e.add(o.onDblclick$.subscribeEvent(u=>{this._hoverManagerService.triggerDbClick(s,u.offsetX,u.offsetY)})),e.add(o.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(r=>{t(r)}))}_initScrollEvent(){this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(()=>this._hoverManagerService.triggerScroll()))}};exports.HoverRenderController=xp([Oo(1,a.Inject(exports.HoverManagerService)),Oo(2,a.Inject(exports.SheetSkeletonManagerService)),Oo(3,a.Inject(exports.SheetScrollManagerService))],exports.HoverRenderController);var Ap=Object.getOwnPropertyDescriptor,kp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Ap(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},xo=(n,i)=>(e,t)=>i(e,t,n);let vi=class extends a.Disposable{constructor(n,i,e,t){super(),this._context=n,this._markSelectionService=i,this._commandService=e,this._sheetSkeletonManagerService=t,this._initListeners()}_initListeners(){this._addRemoveListener(),this._addRefreshListener()}_addRemoveListener(){const n=[fe.id];this.disposeWithMe(this._commandService.onCommandExecuted(i=>{n.includes(i.id)?this._markSelectionService.removeAllShapes():this._markSelectionService.getShapeMap().forEach((t,r)=>{t.exits.includes(i.id)&&this._markSelectionService.removeShape(r)})}))}_addRefreshListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(n=>{n&&this._markSelectionService.refreshShapes()}))}};vi=kp([xo(1,a.Inject(Qt)),xo(2,a.ICommandService),xo(3,a.Inject(exports.SheetSkeletonManagerService))],vi);const Dp="univer-mobile-sheet-bar-container",Np="univer-mobile-sheet-bar-slider",Hp="univer-mobile-sheet-bar-item",Vp="univer-mobile-sheet-bar-item-activated",Gr={mobileSheetBarContainer:Dp,mobileSheetBarSlider:Np,mobileSheetBarItem:Hp,mobileSheetBarItemActivated:Vp};function $c(){const n=Et();return n?_.jsx(Wp,{workbook:n}):null}function Wp(n){const{workbook:i}=n,[e,t]=V.useState([]),[r,o]=V.useState(""),s=V.useRef(new Map),l=I.useDependency(a.ICommandService),c=V.useCallback(()=>{const u=i.getActiveSheet().getSheetId(),h=i.getSheets(),g=i.getActiveSheet(),S=h.filter(f=>!f.isSheetHidden()).map((f,p)=>{var v;return{sheetId:f.getSheetId(),label:f.getName(),index:p,selected:g===f,color:(v=f.getTabColor())!=null?v:void 0}});if(t(S),o(u),s.current.has(u)){const f=s.current.get(u);f&&f.scrollIntoView({behavior:"smooth",block:"nearest"})}s.current.clear()},[i]);V.useEffect(()=>c(),[c]);const d=V.useCallback(u=>{l.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:i.getUnitId(),subUnitId:u})},[l,i]);return V.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:Gr.mobileSheetBarContainer,children:_.jsx("div",{className:Gr.mobileSheetBarSlider,children:e.map(u=>_.jsx("div",{className:X.clsx(Gr.mobileSheetBarItem,{[Gr.mobileSheetBarItemActivated]:u.sheetId===r}),onClick:()=>d(u.sheetId),ref:h=>{s.current.set(u.sheetId,h)},children:u.label},u.sheetId))})})}const Lp={[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 Up=Object.getOwnPropertyDescriptor,Bp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Up(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ht=(n,i)=>(e,t)=>i(e,t,n);let Ci=class extends a.Disposable{constructor(n,i,e,t,r,o,s){super(),this._injector=n,this._componentManager=i,this._layoutService=e,this._commandService=t,this._shortcutService=r,this._menuManagerService=o,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(et,Bl)),this.disposeWithMe(n.register(Us,oc)),this.disposeWithMe(n.register(Or,X.ColorPicker)),this.disposeWithMe(n.register(zi,I.FontFamily)),this.disposeWithMe(n.register(Xi,I.FontFamilyItem)),this.disposeWithMe(n.register(Yi,I.FontSize)),this.disposeWithMe(n.register(ar,sc))}_initCommands(){[Hs,yt,Ws,Vs,kn,De,xe,Je,Ur,Hr,On,xn,_r,br,Fe,_s,pr,Bi,m.SetBoldCommand,Yt,fe,fr,Jt,$t,en,tn,ks,Ds,Rr,Er,yn,m.SetItalicCommand,m.SetStrikeThroughCommand,m.SetFontFamilyCommand,m.SetFontSizeCommand,wr,ji,Nn,Tr,Be,Rn,ht,yr,Mr,m.SetUnderlineCommand,Dn,Le,Vr,Sr,Zt,Gt,Un,Ln,Ui,Ct,_n,qe,Ls,kr,Ut,Bt,Dr,Nr,Lr,Ft,jt,Wr].forEach(n=>{this.disposeWithMe(this._commandService.registerCommand(n))})}_initMenus(){this._menuManagerService.mergeMenu(Lp)}_initShortcuts(){[gc,Sc,fc,pc,vc,Cc,Ic,_c,bc,Rc,Ec,wc,Tc,yc,Mc,Pc,Oc,xc,Ac,kc,Dc,Uc,Fc,zc,Xc,Bc,jc,Nc,Hc,Vc,Wc,Lc,...Tl(),Ml,yl,Pl,xl,Al,kl,Ol,hc,mc].forEach(n=>{this.disposeWithMe(this._shortcutService.registerShortcut(n))})}_initWorkbenchParts(){this._uiPartsService.registerComponent(I.BuiltInUIPart.HEADER,()=>I.connectInjector($c,this._injector))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(a.UniverInstanceType.UNIVER_SHEET,n=>{}))}};Ci=Bp([Ht(0,a.Inject(a.Injector)),Ht(1,a.Inject(I.ComponentManager)),Ht(2,I.ILayoutService),Ht(3,a.ICommandService),Ht(4,I.IShortcutService),Ht(5,I.IMenuManagerService),Ht(6,I.IUIPartsService)],Ci);const Ao="UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID",ed="UNIVER_SHEET_PERMISSION_ALERT_DIALOG";var Fp=Object.getOwnPropertyDescriptor,jp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Fp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},nt=(n,i)=>(e,t)=>i(e,t,n);exports.SheetPermissionCheckUIController=class extends a.Disposable{constructor(e,t,r,o,s,l,c,d,u){super();w(this,"disposableCollection",new a.DisposableCollection);this._commandService=e,this._univerInstanceService=t,this._permissionService=r,this._dialogService=o,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:Ao,title:{title:"permission.dialog.alert"},children:{label:ed,errorMsg:e},width:320,destroyOnClose:!0,showOk:!0,onClose:()=>{this._dialogService.close(Ao)},onOk:()=>{this._dialogService.close(Ao)},className:"sheet-permission-user-dialog"};this._permissionService.getShowComponents()&&this._dialogService.open(t)}_getPermissionCheck(e,t){var s,l;let r=!0,o="";switch(e){case $.InsertCommand.id:case $.IMEInputCommand.id:if(this._contextService.getContextValue(a.FOCUSING_EDITOR_STANDALONE)===!0)break;r=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),o=this._localeService.t("permission.dialog.editErr");break;case fe.id:if(t.visible===!1)break;r=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellValuePermission,m.WorksheetEditPermission]}),o=this._localeService.t("permission.dialog.editErr");break;case Lt.id:r=this._sheetPermissionCheckController.permissionCheckWithoutRange({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetColumnStylePermission]}),o=this._localeService.t("permission.dialog.pasteErr");break;case di.id:r=this._permissionCheckByPaste(t),o=this._localeService.t("permission.dialog.pasteErr");break;case Tr.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission,m.WorksheetSetCellValuePermission,m.WorksheetSetCellStylePermission]}),o=this._localeService.t("permission.dialog.commonErr");break;case m.SetBackgroundColorCommand.id:case Jt.id:case $t.id:case en.id:case tn.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}),o=this._localeService.t("permission.dialog.setStyleErr");break;case je.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission],rangeTypes:[m.RangeProtectionPermissionViewPoint],worksheetTypes:[m.WorksheetCopyPermission]}),o=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||(o=this._localeService.t("permission.dialog.workbookCopyErr"));break;case Fi.id:r=this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookCopyPermission,m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionViewPoint,m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetCopyPermission,m.WorksheetEditPermission]}),o=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||(o=this._localeService.t("permission.dialog.workbookCopyErr"));break;case Ct.id:r=this._permissionCheckByAutoFillCommand(t),o=this._localeService.t("permission.dialog.autoFillErr");break}r||this._sheetPermissionCheckController.blockExecuteWithoutPermission(o)}_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===Se.SPECIAL_PASTE_VALUE||e.value===Se.SPECIAL_PASTE_FORMULA?this._sheetPermissionCheckController.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetSetCellStylePermission,m.WorksheetEditPermission]}):e.value===Se.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,r=m.getSheetCommandTarget(this._univerInstanceService);if(!r)return!1;const{worksheet:o,unitId:s,subUnitId:l}=r;return!this._rangeProtectionRuleModel.getSubunitRuleList(s,l).reduce((u,h)=>[...u,...h.ranges],[]).filter(u=>a.Rectangle.intersects(u,t)).some(u=>{var h,g;for(let S=u.startRow;S<=u.endRow;S++)for(let f=u.startColumn;f<=u.endColumn;f++){const p=(g=(h=o.getCell(S,f))==null?void 0:h.selectionProtection)==null?void 0:g[0];if((p==null?void 0:p[re.Edit])===!1)return!0}return!1})}};exports.SheetPermissionCheckUIController=jp([nt(0,a.ICommandService),nt(1,a.IUniverInstanceService),nt(2,a.IPermissionService),nt(3,I.IDialogService),nt(4,a.Inject(m.RangeProtectionRuleModel)),nt(5,wt),nt(6,a.Inject(a.LocaleService)),nt(7,a.IContextService),nt(8,a.Inject(m.SheetPermissionCheckController))],exports.SheetPermissionCheckUIController);var zp=Object.getOwnPropertyDescriptor,Xp=(n,i,e,t)=>{for(var r=t>1?void 0:t?zp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},rt=(n,i)=>(e,t)=>i(e,t,n);let Ii=class extends a.RxDisposable{constructor(i,e,t,r,o,s,l,c,d,u){super();w(this,"disposableCollection",new a.DisposableCollection);this._context=i,this._univerInstanceService=e,this._permissionService=t,this._selectionManagerService=r,this._rangeProtectionRuleModel=o,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 i=this._headerMoveRenderController.interceptor.getInterceptPoints().HEADER_MOVE_PERMISSION_CHECK;this.disposeWithMe(this._headerMoveRenderController.interceptor.intercept(i,{handler:(e,t)=>{const r=m.getSheetCommandTarget(this._univerInstanceService);if(!r)return!1;const{unitId:o,subUnitId:s}=r;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(o).id,new m.WorksheetEditPermission(o,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(o,s,c,[re.Edit])===!1)return!1}else for(let c=t.startColumn;c<=t.endColumn;c++)if(this._rangeProtectionCache.getColPermissionInfo(o,s,c,[re.Edit])===!1)return!1;return!0}}))}_initHeaderResizePermissionInterceptor(){this._headerResizeRenderController&&this.disposeWithMe(this._headerResizeRenderController.interceptor.intercept(this._headerResizeRenderController.interceptor.getInterceptPoints().HEADER_RESIZE_PERMISSION_CHECK,{handler:(i,e)=>{var s,l,c,d;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{unitId:r,subUnitId:o}=t;if(e.row){if(((l=(s=this._permissionService.getPermissionPoint(new m.WorksheetSetRowStylePermission(r,o).id))==null?void 0:s.value)!=null?l:!1)===!1)return!1}else if(e.col&&((d=(c=this._permissionService.getPermissionPoint(new m.WorksheetSetColumnStylePermission(r,o).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:(i,e)=>{var f,p,v;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:r,unitId:o,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(o).id,new m.WorksheetEditPermission(o,s).id,new m.WorksheetSetCellValuePermission(o,s).id,new m.WorksheetSetCellStylePermission(o,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=nr(e.x,e.y,e.scene,e.skeleton),R=e.skeleton.getCellWithCoordByIndex(C.endRow,C.endColumn),E=Math.abs(R.endX-b.x),P=Math.abs(R.endY-b.y);return E<=5&&P<=5});if(!d)return!0;const{startRow:u,endRow:h,startColumn:g,endColumn:S}=d;for(let C=u;C<=h;C++)for(let b=g;b<=S;b++){const R=(v=(p=r.getCell(C,b))==null?void 0:p.selectionProtection)==null?void 0:v[0];if((R==null?void 0:R[re.Edit])===!1||(R==null?void 0:R[re.View])===!1)return!1}return!0}}))}_initRangeMovePermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_MOVE_PERMISSION_CHECK,{handler:(i,e)=>{var g;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return!1;const{worksheet:r,unitId:o,subUnitId:s}=t;if(!this._permissionService.composePermission([new m.WorkbookEditablePermission(o).id,new m.WorksheetEditPermission(o,s).id]).every(S=>S.value))return!1;const c=(g=this._selectionManagerService.getCurrentSelections())==null?void 0:g.map(S=>S.range),d=this._rangeProtectionRuleModel.getSubunitRuleList(o,s).reduce((S,f)=>[...S,...f.ranges],[]),u=c==null?void 0:c.filter(S=>d.some(f=>a.Rectangle.intersects(f,S)));return!(u==null?void 0:u.some(S=>{var b,R;const{startRow:f,startColumn:p,endRow:v,endColumn:C}=S;for(let E=f;E<=v;E++)for(let P=p;P<=C;P++){const y=(R=(b=r.getCell(E,P))==null?void 0:b.selectionProtection)==null?void 0:R[0];if((y==null?void 0:y[re.Edit])===!1)return!0}return!1}))}}))}_initFreezePermissionInterceptor(){this.disposeWithMe(this._headerFreezeRenderController.interceptor.intercept(this._headerFreezeRenderController.interceptor.getInterceptPoints().FREEZE_PERMISSION_CHECK,{handler:(i,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}}))}};Ii=Xp([rt(1,a.IUniverInstanceService),rt(2,a.IPermissionService),rt(3,a.Inject(m.SheetsSelectionsService)),rt(4,a.Inject(m.RangeProtectionRuleModel)),rt(5,a.Inject(exports.HeaderMoveRenderController)),rt(6,Ce),rt(7,a.Inject(exports.HeaderFreezeRenderController)),rt(8,a.Inject(m.RangeProtectionCache)),rt(9,a.Optional(exports.HeaderResizeRenderController))],Ii);var Yp=Object.getOwnPropertyDescriptor,Gp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Yp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Gn=(n,i)=>(e,t)=>i(e,t,n);const Zp="SHEET_PERMISSION_PASTE_PLUGIN";let ur=class extends a.Disposable{constructor(i,e,t,r,o){super();w(this,"disposableCollection",new a.DisposableCollection);this._univerInstanceService=i,this._selectionManagerService=e,this._localService=t,this._sheetClipboardService=r,this._sheetPermissionCheckController=o,this._initClipboardHook()}_initClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook({id:Zp,onBeforePaste:i=>{var g,S,f;const[e]=Kt([i.range]).ranges,t=(g=this._selectionManagerService.getCurrentLastSelection())==null?void 0:g.range;if(!t)return!1;const r={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}=r;let h=!0;for(let p=l;p<=c;p++)for(let v=d;v<=u;v++){const C=(f=(S=s.getCell(p,v))==null?void 0:S.selectionProtection)==null?void 0:f[0];if((C==null?void 0:C[re.Edit])===!1){h=!1;break}}return h||this._sheetPermissionCheckController.blockExecuteWithoutPermission(this._localService.t("permission.dialog.pasteErr")),h}}))}};ur=Gp([Gn(0,a.IUniverInstanceService),Gn(1,a.Inject(m.SheetsSelectionsService)),Gn(2,a.Inject(a.LocaleService)),Gn(3,a.Inject(Ue)),Gn(4,a.Inject(m.SheetPermissionCheckController))],ur);var Kp=Object.getOwnPropertyDescriptor,qp=(n,i,e,t)=>{for(var r=t>1?void 0:t?Kp(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Zn=(n,i)=>(e,t)=>i(e,t,n);const Qp=a.createInterceptorKey("statusBarPermissionCorrect");class Jp{constructor(){w(this,"_sum",0);w(this,"_count",0);w(this,"_countNumber",0);w(this,"_min",Number.POSITIVE_INFINITY);w(this,"_max",Number.NEGATIVE_INFINITY)}add(i,e,t){if(!(i!=null&&i.v))return;const r=i==null?void 0:i.t;let{v:o}=i;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 S;if(!((S=c==null?void 0:c.n)!=null&&S.pattern))return;const{pattern:h}=c.n;u[h]||(u[h]=a.numfmt.getInfo(h)),u[h].isDate&&s(d)};if(typeof o=="string"&&r===a.CellValueType.NUMBER){const c=Number(o);Number.isNaN(c)||(o=c)}if(typeof o=="number"&&r!==a.CellValueType.STRING)s(o);else if(r===a.CellValueType.NUMBER&&i.s){const c=e.get(i.s);l(c,o,t)}this._count++}getResults(){return{sum:this._sum,count:this._countNumber,countA:this._count,min:this._min,max:this._max}}}function $p(n){const{sum:i,count:e,countA:t,min:r,max:o}=n.getResults();return[{func:K.FUNCTION_NAMES_STATISTICAL.MAX,value:o},{func:K.FUNCTION_NAMES_STATISTICAL.MIN,value:r},{func:K.FUNCTION_NAMES_MATH.SUM,value:i},{func:K.FUNCTION_NAMES_STATISTICAL.COUNTA,value:t},{func:K.FUNCTION_NAMES_STATISTICAL.COUNT,value:e},{func:K.FUNCTION_NAMES_STATISTICAL.AVERAGE,value:i/e}]}exports.StatusBarController=class extends a.Disposable{constructor(e,t,r,o,s){super();w(this,"interceptor",new a.InterceptorManager({STATUS_BAR_PERMISSION_CORRECT:Qp}));this._univerInstanceService=e,this._selectionManagerService=t,this._statusBarService=r,this._commandService=o,this._numfmtService=s,this._init()}_init(){this._registerSelectionListener()}_registerSelectionListener(){const e=a.debounce(r=>{var s;const o=(s=r[r.length-1])==null?void 0:s.primary;this._calculateSelection(r.map(l=>l.range),o)},100),t=a.debounce(r=>{var s;const o=(s=r[r.length-1])==null?void 0:s.primary;this._calculateSelection(r.map(l=>l.range),o)},500);this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoving$.subscribe(r=>{r&&t(r)}))),this.disposeWithMe(a.toDisposable(this._selectionManagerService.selectionMoveEnd$.subscribe(r=>{r&&e(r)}))),this.disposeWithMe(this._commandService.onCommandExecuted(r=>{if(r.id===m.SetRangeValuesMutation.id){const o=this._selectionManagerService.getCurrentSelections();o&&e(o)}}))}_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 r=this._univerInstanceService.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!r)return this._clearResult();const o=r.getUnitId(),s=r.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(R=>{const{startRow:E,endRow:P}=R;let y=null;for(let M=E;M<=P;M++)s.getRowVisible(M)?y===null&&(y=M):y!==null&&(u.push({...R,startRow:y,endRow:M-1}),y=null);y!==null&&u.push({...R,startRow:y,endRow:P})});const h=a.splitIntoGrid(u),g=new Jp,S=r.getStyles(),f={};for(const R of h){const{startRow:E,startColumn:P,endColumn:y,endRow:M}=this.getRangeStartEndInfo(R,s);for(let O=E;O<=M;O++)for(let A=P;A<=y;A++){const k=s.getCellRaw(O,A);g.add(k,S,f)}}const p=$p(g);if(p.every(R=>R===void 0))return;let v=null;if(t){const{actualRow:R,actualColumn:E}=t;v=(d=this._numfmtService.getValue(o,l,R,E))==null?void 0:d.pattern}const b={values:p.filter(R=>R!==void 0),pattern:v};this._statusBarService.setState(b)}else this._clearResult()}};exports.StatusBarController=qp([Zn(0,a.IUniverInstanceService),Zn(1,a.Inject(m.SheetsSelectionsService)),Zn(2,Ir),Zn(3,a.ICommandService),Zn(4,a.Inject(m.INumfmtService))],exports.StatusBarController);var ev=Object.getOwnPropertyDescriptor,tv=(n,i,e,t)=>{for(var r=t>1?void 0:t?ev(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Zr=(n,i)=>(e,t)=>i(e,t,n);let _i=class extends a.RxDisposable{constructor(i,e,t,r,o){super();w(this,"disposableCollection",new a.DisposableCollection);this._context=i,this._univerInstanceService=e,this._permissionService=t,this._statusBarController=r,this._rangeProtectionCache=o,this._initStatusBarPermissionInterceptor()}_initStatusBarPermissionInterceptor(){this.disposeWithMe(this._statusBarController.interceptor.intercept(this._statusBarController.interceptor.getInterceptPoints().STATUS_BAR_PERMISSION_CORRECT,{priority:100,handler:(i,e)=>{var c;const t=m.getSheetCommandTarget(this._univerInstanceService);if(!t)return i!=null?i:[];const{worksheet:r,unitId:o,subUnitId:s}=t;return((c=this._permissionService.getPermissionPoint(new m.WorksheetViewPermission(o,s).id))==null?void 0:c.value)===!1?e.forEach(d=>{const u=d.getArrayValue();u.forEach((h,g)=>{h.forEach((S,f)=>{u[g][f]=K.NullValueObject.create()})})}):e.forEach(d=>{const u=d.getArrayValue(),h=d.getCurrentRow(),g=d.getCurrentColumn();u.forEach((S,f)=>{S.forEach((p,v)=>{var R;if(((R=r.getCellRaw(f+h,v+g))==null?void 0:R.v)===void 0)return;const b=this._rangeProtectionCache.getCellInfo(o,s,f+h,v+g);(b==null?void 0:b[re.View])===!1&&(u[f][v]=K.NullValueObject.create())})})}),e}}))}};_i=tv([Zr(1,a.IUniverInstanceService),Zr(2,a.IPermissionService),Zr(3,a.Inject(exports.StatusBarController)),Zr(4,a.Inject(m.RangeProtectionCache))],_i);const td=(n,i,e,t,r)=>{const o=n.get(a.LocaleService),s=n.get(m.WorksheetProtectionRuleModel),l=n.get(m.RangeProtectionRuleModel);let c="";if(i.length===0)c=o.t("permission.panel.emptyRangeError");else if(i.length>1){let d=!1;for(let u=0;u<i.length;u++){for(let h=u+1;h<i.length;h++)if(a.Rectangle.intersects(i[u],i[h])){d=!0;break}if(d)break}d&&(c=o.t("permission.panel.rangeOverlapError"))}if(!c){if(s.getRule(t,r)&&!e)return c=o.t("permission.panel.rangeOverlapOverPermissionError"),c;const u=l.getSubunitRuleList(t,r).filter(g=>g.permissionId!==e).find(g=>g.ranges.some(S=>i.some(f=>a.Rectangle.intersects(S,f))));(u==null?void 0:u.ranges.find(g=>i.some(S=>a.Rectangle.intersects(g,S))))&&(c=o.t("permission.panel.rangeOverlapOverPermissionError"))}return c===""?void 0:c},nv=(n,i)=>{if(n.length!==1)return!1;const e=n[0],t=i.getRowCount(),r=i.getColumnCount(),{startRow:o,endRow:s,startColumn:l,endColumn:c}=e;return o===0&&l===0&&s===t-1&&c===r-1},rv=(n,i)=>{var c,d;const e=n.get(a.IUniverInstanceService),t=n.get(m.SheetsSelectionsService),r=e.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),o=r.getActiveSheet();let s=m.UnitObject.SelectRange,l=(d=(c=t.getCurrentSelections())==null?void 0:c.map(u=>u.range))!=null?d:[];return i&&(s=m.UnitObject.Worksheet,l=[{startRow:0,startColumn:0,endRow:o.getRowCount()-1,endColumn:o.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]),{unitId:r.getUnitId(),subUnitId:o.getSheetId(),permissionId:"",unitType:s,description:"",id:"",ranges:l,editState:m.EditStateEnum.OnlyMe,viewState:m.ViewStateEnum.OthersCanView}},iv=(n,i)=>{const r=n.get(a.IUniverInstanceService).getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET).getActiveSheet(),{unitType:o}=i;return o===m.UnitObject.Worksheet?{...i,ranges:[{startRow:0,startColumn:0,endRow:r.getRowCount()-1,endColumn:r.getColumnCount()-1,rangeType:a.RANGE_TYPE.ALL}]}:i},ov="univer-permission-panel-detail-wrapper",sv="univer-radio-group-vertical",av="univer-sheet-permission-design-person-panel",lv="univer-sheet-permission-design-person-panel-header",cv="univer-sheet-permission-design-person-panel-header-add",dv="univer-sheet-permission-design-person-panel-split",uv="univer-sheet-permission-design-person-panel-content-item",hv="univer-sheet-permission-design-person-panel-content-item-name",mv="univer-sheet-permission-design-person-panel-content-item-select",gv="univer-sheet-permission-design-person-panel-content",Sv="univer-sheet-permission-user-list-empty",fv="univer-sheet-permission-user-list-empty-text",pv="univer-sheet-permission-panel-title",vv="univer-sheet-permission-panel-footer",ve={permissionPanelDetailWrapper:ov,radioGroupVertical:sv,sheetPermissionDesignPersonPanel:av,sheetPermissionDesignPersonPanelHeader:lv,sheetPermissionDesignPersonPanelHeaderAdd:cv,sheetPermissionDesignPersonPanelSplit:dv,sheetPermissionDesignPersonPanelContentItem:uv,sheetPermissionDesignPersonPanelContentItemName:hv,sheetPermissionDesignPersonPanelContentItemSelect:mv,sheetPermissionDesignPersonPanelContent:gv,sheetPermissionUserListEmpty:Sv,sheetPermissionUserListEmptyText:fv,sheetPermissionPanelTitle:pv,sheetPermissionPanelFooter:vv},Cv=n=>{const{viewState:i,editState:e,permissionId:t,ranges:r,rangesErrMsg:o,desc:s,oldRule:l,id:c}=n,d=I.useDependency(Pn),u=I.useDependency(I.ISidebarService),h=I.useDependency(a.IAuthzIoService),g=I.useDependency(a.LocaleService),S=I.useDependency(a.ICommandService),f=I.useDependency(Mt),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(),R=C.getSheetId();return _.jsxs("div",{className:ve.sheetPermissionPanelFooter,children:[_.jsx(X.Button,{variant:"primary",onClick:async()=>{if(o)return;const E={unitId:b,subUnitId:R,permissionId:t,id:c,viewState:i,editState:e,unitType:m.UnitObject.SelectRange,ranges:r,description:s};nv(r,C)&&(E.unitType=m.UnitObject.Worksheet,E.ranges=[]);let y=f.selectUserList;E.editState===m.EditStateEnum.OnlyMe&&(y=[],f.setSelectUserList([]));const M={read:E.viewState===m.ViewStateEnum.OthersCanView?Ze.AllCollaborator:Ze.SomeCollaborator,edit:E.editState===m.EditStateEnum.DesignedUserCanEdit?Ze.SomeCollaborator:Ze.OneSelf};if(E.editState===m.EditStateEnum.DesignedUserCanEdit&&y.length===0&&(y=[],M.edit=Ze.OneSelf),E.permissionId){const A=TS(y.filter(H=>H.role===Ae.Editor),f.oldCollaboratorList.filter(H=>H.role===Ae.Editor)),k=(l==null?void 0:l.viewState)===E.viewState,D=(l==null?void 0:l.editState)===E.editState,N=E.unitType===(l==null?void 0:l.unitType)&&E.description===l.description&&E.ranges===l.ranges,W=!A||!k||!D;if(N&&W)await h.update({objectType:E.unitType,objectID:E.permissionId,unitID:E.unitId,share:void 0,name:"",strategies:[],scope:M,collaborators:{collaborators:y}});else{let H=E.permissionId;W&&(E.unitType===m.UnitObject.Worksheet?H=await h.create({worksheetObject:{collaborators:y,unitID:E.unitId,name:"",strategies:[{role:Ae.Editor,action:re.Edit},{role:Ae.Reader,action:re.View}],scope:M},objectType:m.UnitObject.Worksheet}):H=await h.create({selectRangeObject:{collaborators:y,unitID:E.unitId,name:"",scope:M},objectType:m.UnitObject.SelectRange})),S.executeCommand(m.SetProtectionCommand.id,{rule:{...E,permissionId:H},oldRule:l})}}else if(E.unitType===m.UnitObject.Worksheet){const A=await h.create({worksheetObject:{collaborators:y,unitID:E.unitId,name:"",strategies:[{role:Ae.Editor,action:re.Edit},{role:Ae.Reader,action:re.View}],scope:M},objectType:m.UnitObject.Worksheet}),{ranges:k=[],...D}=E;D.permissionId=A,S.executeCommand(m.AddWorksheetProtectionCommand.id,{rule:D,unitId:E.unitId})}else if(E.unitType===m.UnitObject.SelectRange){const A=await h.create({selectRangeObject:{collaborators:y,unitID:E.unitId,name:"",scope:M},objectType:m.UnitObject.SelectRange});S.executeCommand(m.AddRangeProtectionCommand.id,{rule:E,permissionId:A})}const O={header:{title:`${g.t("permission.panel.title")}`},children:{label:cr,showDetail:!1},width:330};u.open(O)},children:g.t("permission.button.confirm")}),_.jsx(X.Button,{className:ve.sheetPermissionPanelFooterCancel,onClick:()=>{d.reset(),f.reset(),u.close()},children:g.t("permission.button.cancel")})]})},Iv=n=>{const{ranges:i,onRangesChange:e,desc:t,onDescChange:r,rangesErrMsg:o,permissionId:s}=n,l=I.useDependency(I.ComponentManager),c=V.useMemo(()=>l.get(hs),[]),d=I.useDependency(a.IUniverInstanceService),u=I.useDependency(a.LocaleService),h=I.useDependency(a.Injector),g=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),S=g==null?void 0:g.getActiveSheet();if(!g||!S)return null;const f=g.getUnitId(),p=S.getSheetId(),v=C=>{const b=C.split(",").map(K.deserializeRangeWithSheet).map(A=>A.range);if(b.some(A=>!a.isValidRange(A)||A.endColumn<A.startColumn||A.endRow<A.startRow))return;const R=d.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),E=R==null?void 0:R.getActiveSheet();if(!R||!E)return;const P=R.getUnitId(),y=E.getSheetId(),M=b.map(A=>{const k=E.getRowCount(),D=E.getColumnCount();return m.setEndForRange(A,k,D),A}),O=td(h,M,s,P,y);e(M,O)};return _.jsxs(_.Fragment,{children:[_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:u.t("permission.panel.protectedRange"),error:o,children:c&&_.jsx(c,{unitId:f,subUnitId:p,initialValue:i==null?void 0:i.map(C=>K.serializeRange(C)).join(","),onChange:(C,b)=>v(b)})}),_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:u.t("permission.panel.permissionDirection"),children:_.jsx(X.Input,{value:t,onChange:C=>r(C),placeholder:u.t("permission.panel.permissionDirectionPlaceholder")})})]})},_v=n=>{var C,b;const{fromSheetBar:i,rule:e,oldRule:t}=n,r=I.useDependency(a.Injector),o=e?iv(r,e):rv(r,i),[s,l]=V.useState(o.ranges),[c,d]=V.useState(()=>td(r,o.ranges,o.permissionId,o.unitId,o.subUnitId)),[u,h]=V.useState(o.description),[g,S]=V.useState((C=o.editState)!=null?C:m.EditStateEnum.OnlyMe),[f,p]=V.useState((b=o.viewState)!=null?b:m.ViewStateEnum.OthersCanView),v=I.useComponentsOfPart(Mn);return V.useEffect(()=>{const R=r.get(a.IUniverInstanceService),E=r.get(I.ISidebarService),P=R.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!P)return;const y=P.getActiveSheet().getSheetId(),M=P.activeSheet$.subscribe(O=>{(O==null?void 0:O.getSheetId())!==y&&E.close()});return()=>{M.unsubscribe()}},[]),_.jsxs("div",{className:ve.permissionPanelDetailWrapper,children:[_.jsx(Iv,{permissionId:o.permissionId,ranges:s,onRangesChange:(R,E)=>{l(R),d(E)},rangesErrMsg:c,desc:u,onDescChange:R=>h(R)}),_.jsx(I.ComponentContainer,{components:v,sharedProps:{editState:g,onEditStateChange:R=>S(R),viewState:f,onViewStateChange:R=>p(R),permissionId:o.permissionId}},"user-part"),_.jsx(Cv,{permissionId:o.permissionId,id:o.id,ranges:s,rangesErrMsg:c,desc:u,viewState:f,editState:g,oldRule:t})]})},bv="",Rv="univer-sheet-permission-list-panel-wrapper",Ev="univer-sheet-permission-list-panel-header",wv="univer-sheet-permission-list-panel-header-type",Tv="univer-sheet-permission-list-panel-header-type-bottom",yv="univer-sheet-permission-list-panel-header-select",Mv="univer-sheet-permission-list-item-header-icon",Pv="univer-sheet-permission-list-item",Ov="univer-sheet-permission-list-item-header",xv="univer-sheet-permission-list-item-header-name",Av="univer-sheet-permission-list-item-header-operator",kv="univer-sheet-permission-list-item-split",Dv="univer-sheet-permission-list-item-content-edit",Nv="univer-sheet-permission-list-item-content-view",Hv="univer-sheet-permission-list-item-content-desc",Vv="univer-sheet-permission-list-empty",Wv="univer-sheet-permission-list-empty-text",Lv="univer-sheet-permission-list-item-content-title",Uv="univer-sheet-permission-list-item-content-sub",Bv="univer-sheet-permission-panel-add-wrapper",Fv="univer-sheet-permission-panel-add-button",de={sheetPermissionListPanelWrapper:Rv,sheetPermissionListPanelHeader:Ev,sheetPermissionListPanelHeaderType:wv,sheetPermissionListPanelHeaderTypeBottom:Tv,sheetPermissionListPanelHeaderSelect:yv,sheetPermissionListItemHeaderIcon:Mv,sheetPermissionListItem:Pv,sheetPermissionListItemHeader:Ov,sheetPermissionListItemHeaderName:xv,sheetPermissionListItemHeaderOperator:Av,sheetPermissionListItemSplit:kv,sheetPermissionListItemContentEdit:Dv,sheetPermissionListItemContentView:Nv,sheetPermissionListItemContentDesc:Hv,sheetPermissionListEmpty:Vv,sheetPermissionListEmptyText:Wv,sheetPermissionListItemContentTitle:Lv,sheetPermissionListItemContentSub:Uv,sheetPermissionPanelAddWrapper:Bv,sheetPermissionPanelAddButton:Fv},jv=()=>{var W;const[n,i]=V.useState(!0),[e,t]=V.useState(!1),r=I.useDependency(a.LocaleService),o=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),S=I.useDependency(a.UserManagerService).getCurrentUser(),[f,p]=V.useState([]),v=I.useDependency(Mt),C=I.useObservable(s.ruleRefresh$,""),b=I.useObservable(o.ruleRefresh$,""),R=l.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET);if(!R)return null;const E=R==null?void 0:R.getUnitId(),P=V.useCallback(async H=>{var G;const L=R.getActiveSheet(),U=R.getUnitId(),j=L.getSheetId(),B=[],z=[];R.getSheets().forEach(Y=>{const q=Y.getSheetId();o.getSubunitRuleList(U,q).forEach(ie=>{ie.permissionId&&B.push(ie.permissionId)});const ce=s.getRule(U,q);ce!=null&&ce.permissionId&&z.push(ce.permissionId)});const F=[...B,...z],Z=await u.list({objectIDs:F,unitID:U,actions:m.baseProtectionActions}),J=o.getSubunitRuleList(U,j).map(Y=>Y.permissionId),Q=(G=s.getRule(U,j))==null?void 0:G.permissionId;Q&&J.push(Q);const se=Z.filter(Y=>{var q;return J.includes(Y.objectID)||Y.objectID===((q=s.getRule(U,j))==null?void 0:q.permissionId)});return H?se:Z},[]),[y,M]=V.useState([]);V.useEffect(()=>{const H=x.merge(o.ruleChange$,s.ruleChange$).subscribe(async()=>{const L=await P(n);M(L)});return()=>{H.unsubscribe()}},[n]),V.useEffect(()=>{const H=R.activeSheet$.pipe(x.distinctUntilChanged((L,U)=>(L==null?void 0:L.getSheetId())===(U==null?void 0:U.getSheetId()))).subscribe(async()=>{const L=await P(n);M(L)});return()=>{H.unsubscribe()}},[n]),V.useEffect(()=>{(async()=>{if(C||b){const L=await P(!0);M(L)}})()},[C,b]);const O=H=>{const{unitId:L,subUnitId:U,unitType:j}=H;let B;j===dt.Worksheet?B=c.executeCommand(m.DeleteWorksheetProtectionCommand.id,{unitId:L,subUnitId:U,rule:H}):j===dt.SelectRange&&(B=c.executeCommand(m.DeleteRangeProtectionCommand.id,{unitId:L,subUnitId:U,rule:H})),B&&(t(!e),H.ranges===f&&p([]))};V.useEffect(()=>{v.reset()},[]),Yc(f);const A=new Map;R.getSheets().forEach(H=>{const L=H.getSheetId();o.getSubunitRuleList(E,L).forEach(B=>{A.set(B.permissionId,B)});const j=s.getRule(E,L);j&&A.set(j==null?void 0:j.permissionId,j)});const k=H=>{H.subUnitId!==R.getActiveSheet().getSheetId()&&c.executeCommand(m.SetWorksheetActiveOperation.id,{unitId:H.unitId,subUnitId:H.subUnitId});const L={header:{title:"permission.panel.title"},children:{label:cr,showDetail:!0,rule:a.Tools.deepClone(H),oldRule:a.Tools.deepClone(H)},width:330};d.open(L)},D=H=>{i(H)},N=(W=h.getPermissionPoint(new m.WorkbookCreateProtectPermission(E).id))==null?void 0:W.value;return _.jsxs("div",{className:de.sheetPermissionListPanelWrapper,children:[_.jsxs("div",{className:de.sheetPermissionListPanelHeader,children:[_.jsxs("div",{className:de.sheetPermissionListPanelHeaderType,onClick:()=>D(!0),children:[_.jsx("div",{className:X.clsx({[de.sheetPermissionListPanelHeaderSelect]:n}),children:r.t("permission.panel.currentSheet")}),n&&_.jsx("div",{className:de.sheetPermissionListPanelHeaderTypeBottom})]}),_.jsxs("div",{className:de.sheetPermissionListPanelHeaderType,onClick:()=>D(!1),children:[_.jsx("div",{className:X.clsx({[de.sheetPermissionListPanelHeaderSelect]:!n}),children:r.t("permission.panel.allSheet")}),!n&&_.jsx("div",{className:de.sheetPermissionListPanelHeaderTypeBottom})]})]}),(y==null?void 0:y.length)>0?_.jsx("div",{className:de.sheetPermissionListPanelContent,children:y==null?void 0:y.map(H=>{var q,ne,ce,ie,oe;const L=A.get(H.objectID);if(!L)return null;const U=H.actions.find(ee=>ee.action===re.Edit),j=U==null?void 0:U.allowed,B=H.actions.find(ee=>ee.action===re.View),z=B==null?void 0:B.allowed,F=H.actions.find(ee=>ee.action===re.ManageCollaborator),Z=H.actions.find(ee=>ee.action===re.Delete),J=(F==null?void 0:F.allowed)||S.userID===((q=H.creator)==null?void 0:q.userID),Q=(Z==null?void 0:Z.allowed)||S.userID===((ne=H.creator)==null?void 0:ne.userID);let se="";const G=R.getSheetBySheetId(L.subUnitId),Y=G==null?void 0:G.getName();if(L.unitType===dt.SelectRange){const ee=L.ranges,ge=ee!=null&&ee.length?ee.map(pe=>{const we=K.serializeRange(pe);return we==="NaN"?"":we}).filter(pe=>!!pe).join(","):"";se=`${Y}(${ge})`}else L.unitType===dt.Worksheet&&(se=Y||"");return _.jsxs("div",{className:de.sheetPermissionListItem,onMouseMove:()=>{const{subUnitId:ee,unitType:ge}=L,pe=R.getActiveSheet();if(!pe)return!1;const we=pe.getSheetId();if(ee!==we)return!1;if(ge===dt.SelectRange){const Te=L.ranges||[];Te!==f&&p(Te)}else if(ge===dt.Worksheet){const Te=[{startRow:0,endRow:pe.getRowCount()-1,startColumn:0,endColumn:pe.getColumnCount()-1}];Te!==f&&p(Te)}},onMouseLeave:()=>p([]),children:[_.jsxs("div",{className:de.sheetPermissionListItemHeader,children:[_.jsx(X.Tooltip,{title:se,children:_.jsx("div",{className:de.sheetPermissionListItemHeaderName,children:se})}),(J||Q)&&_.jsxs("div",{className:de.sheetPermissionListItemHeaderOperator,children:[J&&_.jsx(X.Tooltip,{title:r.t("permission.panel.edit"),children:_.jsx("div",{className:de.sheetPermissionListItemHeaderIcon,onClick:()=>k(L),children:_.jsx(Ts,{})})}),Q&&_.jsx(X.Tooltip,{title:r.t("permission.panel.delete"),children:_.jsx("div",{className:de.sheetPermissionListItemHeaderIcon,onClick:()=>O(L),children:_.jsx(Li,{})})})]})]}),_.jsx("div",{className:de.sheetPermissionListItemSplit}),_.jsxs("div",{className:de.sheetPermissionListItemContent,children:[_.jsxs("div",{className:de.sheetPermissionListItemContentEdit,children:[_.jsx(X.Tooltip,{title:(ie=(ce=H.creator)==null?void 0:ce.name)!=null?ie:"",children:_.jsx("div",{children:_.jsx(X.Avatar,{src:(oe=H.creator)==null?void 0:oe.avatar,style:{marginRight:6},size:24})})}),_.jsx("span",{className:de.sheetPermissionListItemContentTitle,children:r.t("permission.panel.created")}),_.jsx("span",{className:de.sheetPermissionListItemContentSub,children:j?`${r.t("permission.panel.iCanEdit")}`:`${r.t("permission.panel.iCanNotEdit")}`})]}),_.jsxs("div",{className:de.sheetPermissionListItemContentView,children:[_.jsx("span",{className:de.sheetPermissionListItemContentTitle,children:r.t("permission.panel.viewPermission")}),_.jsx("span",{className:de.sheetPermissionListItemContentSub,children:z?`${r.t("permission.panel.iCanView")}`:`${r.t("permission.panel.iCanNotView")}`})]}),L.description&&_.jsx(X.Tooltip,{title:L.description,children:_.jsx("div",{className:de.sheetPermissionListItemContentDesc,children:L.description})})]})]},H.objectID)})}):_.jsxs("div",{className:de.sheetPermissionListEmpty,children:[_.jsx("img",{width:240,height:120,src:bv,alt:""}),_.jsx("p",{className:de.sheetPermissionListEmptyText,children:r.t("permission.dialog.listEmpty")})]}),N&&_.jsx("div",{className:de.sheetPermissionPanelAddWrapper,children:_.jsxs(X.Button,{className:de.sheetPermissionPanelAddButton,variant:"primary",onClick:()=>{const H={header:{title:`${r.t("permission.panel.title")}`},children:{label:cr,showDetail:!0},width:330};d.open(H)},children:[_.jsx("div",{children:"+ "}),r.t("permission.button.addNewPermission")]})})]})},zv=({showDetail:n,fromSheetBar:i,rule:e,oldRule:t})=>{var h;const r=I.useDependency(a.IUniverInstanceService),o=I.useDependency(m.SheetsSelectionsService);if(!I.useDependency(Pn).getVisible())return null;const l=m.getSheetCommandTarget(r);if(!l)return null;const{worksheet:c}=l,u=((h=o.getCurrentSelections())==null?void 0:h.map(g=>g.range)).reduce((g,S)=>g+K.serializeRangeWithSheet(c.getName(),S),"");return n?_.jsx(_v,{fromSheetBar:i,rule:e,oldRule:t},i?"sheet-bar":"normal"):_.jsx(jv,{},u)},Xv="univer-spin-container",Yv="univer-spin-overlay",Gv="univer-spinner",Zv="univer-content-blur",Kr={spinContainer:Xv,spinOverlay:Yv,spinner:Gv,contentBlur:Zv},Kv=({loading:n,children:i})=>_.jsxs("div",{className:Kr.spinContainer,children:[n&&_.jsx("div",{className:Kr.spinOverlay,children:_.jsx("div",{className:Kr.spinner})}),_.jsx("div",{className:n?Kr.contentBlur:"",children:i})]}),qv="univer-sheet-permission-dialog-wrapper",Qv="univer-sheet-permission-dialog-split",Jv="univer-sheet-permission-dialog-item",$v="univer-sheet-permission-user-dialog-footer",eC="univer-sheet-permission-user-dialog-footer-confirm",tC="univer-sheet-permission-user-dialog-button",ft={sheetPermissionDialogWrapper:qv,sheetPermissionDialogSplit:Qv,sheetPermissionDialogItem:Jv,sheetPermissionUserDialogFooter:$v,sheetPermissionUserDialogFooterConfirm:eC,sheetPermissionUserDialogButton:tC},nC=()=>{const n=I.useDependency(a.LocaleService),i=I.useDependency(a.IUniverInstanceService),e=I.useDependency(a.IAuthzIoService),t=I.useDependency(m.WorksheetProtectionPointModel),r=I.useDependency(I.IDialogService),o=I.useDependency(a.IPermissionService),s=i.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),l=s.getActiveSheet();if(!l)throw new Error("No active sheet found");const[c,d]=V.useState([]),u=I.useDependency(a.ICommandService),[h,g]=V.useState(()=>!!t.getRule(s.getUnitId(),l.getSheetId())),[S,f]=V.useState(()=>Object.keys(Xr).reduce((v,C)=>(v[C]={text:n.t(`permission.panel.${Xr[Number(C)]}`),allowed:!0},v),{}));V.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=await e.listCollaborators({objectID:C,unitID:C});d(b)})()},[]),V.useEffect(()=>{(async()=>{const C=s.getUnitId(),b=t.getRule(C,l.getSheetId());if(!b)return;g(!0);const E=(await e.list({unitID:s.getUnitId(),objectIDs:[b.permissionId],actions:xS}))[0].strategies.reduce((P,y)=>(Xr[y.action]&&(P[y.action]={text:n.t(`permission.panel.${Xr[y.action]}`),allowed:y.role!==Ae.Owner}),P),{});f(E),setTimeout(()=>{g(!1)},100)})()},[]);const p=async()=>{const v=i.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(),R=C.getSheetId(),E=t.getRule(b,R),P=Object.keys(S).map(M=>({action:Number(M),role:S[M].allowed?Ae.Editor:Ae.Owner}));let y=E==null?void 0:E.permissionId;y?e.update({objectType:dt.Worksheet,objectID:y,unitID:b,strategies:P,share:void 0,name:"",scope:{read:Ze.AllCollaborator,edit:Ze.AllCollaborator},collaborators:void 0}).then(()=>{m.getAllWorksheetPermissionPoint().forEach(M=>{const O=new M(b,R),A=O.subType,k=P.find(D=>D.action===A);k&&o.updatePermissionPoint(O.id,k.role===Ae.Editor)})}):(y=await e.create({objectType:dt.Worksheet,worksheetObject:{unitID:b,collaborators:c,name:"",strategies:P,scope:{read:Ze.AllCollaborator,edit:Ze.AllCollaborator}}}),u.executeCommand(m.SetWorksheetPermissionPointsCommand.id,{rule:{permissionId:y,unitId:b,subUnitId:R}}))};return _.jsx(Kv,{loading:h,children:_.jsxs("div",{className:ft.sheetPermissionDialogWrapper,children:[_.jsx("div",{className:ft.sheetPermissionDialogSplit}),Object.keys(S).map(v=>{const C=S[v],{text:b,allowed:R}=C;return _.jsxs("div",{className:ft.sheetPermissionDialogItem,children:[_.jsx("div",{children:b}),_.jsx(X.Switch,{defaultChecked:R,onChange:()=>{f({...S,[v]:{...C,allowed:!R}})}})]},b)}),_.jsx("div",{className:ft.sheetPermissionDialogSplit}),_.jsxs("div",{className:ft.sheetPermissionUserDialogFooter,children:[_.jsx(X.Button,{className:ft.sheetPermissionUserDialogButton,onClick:()=>{r.close(mi)},children:n.t("permission.button.cancel")}),_.jsx(X.Button,{variant:"primary",onClick:()=>{p(),r.close(mi)},className:X.clsx(ft.sheetPermissionUserDialogFooterConfirm,ft.sheetPermissionUserDialogButton),children:n.t("permission.button.confirm")})]})]})})},nd="",rC="univer-sheet-permission-user-list",iC="univer-sheet-permission-user-list-empty",oC="univer-sheet-permission-user-item",sC="univer-sheet-permission-user-item-name",aC="univer-sheet-permission-split",lC="univer-sheet-permission-user-dialog-button",it={sheetPermissionUserList:rC,sheetPermissionUserListEmpty:iC,sheetPermissionUserItem:oC,sheetPermissionUserItemName:sC,sheetPermissionSplit:aC,sheetPermissionUserDialogButton:lC},cC=()=>{var u;const[n,i]=V.useState(""),e=I.useDependency(a.LocaleService),t=I.useDependency(I.IDialogService),r=I.useDependency(Mt),o=I.useObservable(r.userList$,r.userList),s=(u=o==null?void 0:o.filter(h=>{var g;return((g=h.subject)==null?void 0:g.name.toLocaleLowerCase().includes(n.toLocaleLowerCase()))&&h.role===Ae.Editor}))!=null?u:[],[l,c]=V.useState(r.selectUserList),d=h=>{if((l==null?void 0:l.findIndex(S=>{var f,p;return((f=S.subject)==null?void 0:f.userID)===((p=h.subject)==null?void 0:p.userID)}))===-1){const S={...h};c([...l,S])}else{const S=l.filter(f=>{var p,v;return((p=f.subject)==null?void 0:p.userID)!==((v=h.subject)==null?void 0:v.userID)});c(S)}};return _.jsxs("div",{children:[_.jsx("div",{className:it.sheetPermissionUserDialogSearch,children:_.jsx(X.Input,{className:"univer-w-full",placeholder:e.t("permission.dialog.search"),value:n,onChange:h=>i(h)})}),_.jsx("div",{className:it.sheetPermissionUserList,children:(s==null?void 0:s.length)>0?_.jsx(_.Fragment,{children:s==null?void 0:s.map(h=>{var g,S,f;return _.jsxs("div",{className:it.sheetPermissionUserItem,onClick:()=>d(h),children:[_.jsx(X.Avatar,{src:(g=h.subject)==null?void 0:g.avatar,size:24}),_.jsx("div",{className:it.sheetPermissionUserItemName,children:(S=h.subject)==null?void 0:S.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(Tt,{})})]},(f=h.subject)==null?void 0:f.userID)})}):_.jsxs("div",{className:it.sheetPermissionUserListEmpty,children:[_.jsx("img",{className:"univer-w-full",src:nd,alt:"empty list",draggable:!1}),_.jsx("p",{className:"univer-text-[13px] univer-text-gray-400",children:e.t("permission.dialog.userEmpty")})]})}),_.jsx("div",{className:it.sheetPermissionSplit}),_.jsxs("div",{className:"univer-flex univer-items-center univer-justify-end univer-gap-1 univer-py-1",children:[_.jsx(X.Button,{className:it.sheetPermissionUserDialogButton,onClick:()=>t.close(hi),children:e.t("permission.button.cancel")}),_.jsx(X.Button,{variant:"primary",onClick:()=>{r.setSelectUserList(l),t.close(hi)},className:X.clsx(it.sheetPermissionUserDialogFooterConfirm,it.sheetPermissionUserDialogButton),children:e.t("permission.button.confirm")})]})]})},dC=({errorMsg:n})=>{const i=I.useDependency(a.LocaleService);return _.jsx("div",{children:_.jsx("p",{className:"univer-m-0",children:n||i.t("permission.dialog.alertContent")})})},rd="",id="RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY",od="RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY",uC=25,hC=80;class sd extends T.SheetExtension{constructor(){super();w(this,"_pattern",null);w(this,"_img",new Image);w(this,"renderCache",new Set);this._img.src=rd}clearCache(){this.renderCache.clear()}draw(e,t,r){const{worksheet:o}=r;o&&(e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat")),this.renderCache.clear(),a.Range.foreach(r.rowColumnSegment,(s,l)=>{if(!o.getRowVisible(s)||!o.getColVisible(l))return;const{selectionProtection:c=[]}=o.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=r.getCellWithCoordByIndex(u.startRow,u.startColumn,!1),g=r.getCellWithCoordByIndex(u.endRow,u.endColumn,!1);e.fillRect(h.startX,h.startY,g.endX-h.startX,g.endY-h.startY)})}}))}),e.restore())}}class mC extends sd{constructor(){super();w(this,"uKey",id);w(this,"Z_INDEX",uC)}shouldRender(e){return(e==null?void 0:e[re.View])!==!1}}class gC extends sd{constructor(){super();w(this,"uKey",od);w(this,"Z_INDEX",hC)}shouldRender(e){return(e==null?void 0:e[re.View])===!1}}const ad="worksheet-protection",ja=25,SC=80;class fC extends T.SheetExtension{constructor(){super();w(this,"uKey",ad);w(this,"Z_INDEX",ja);w(this,"_pattern");w(this,"_img",new Image);this._img.src=rd}draw(e,t,r){const{worksheet:o}=r;if(!o)return!1;e.save(),this._pattern||(this._pattern=e.createPattern(this._img,"repeat"));const{startRow:s,startColumn:l,endRow:c,endColumn:d}=r.rowColumnSegment,u=r.getCellWithCoordByIndex(s,l,!1),h=r.getCellWithCoordByIndex(c,d,!1),{hasWorksheetRule:g=!1,selectionProtection:S=[]}=o.getCell(s,l)||{};if(this._pattern){if(S.length>0){const f=S[0];(f==null?void 0:f[re.View])?this.setZIndex(ja):this.setZIndex(SC)}e.fillStyle=this._pattern,g&&e.fillRect(u.startX,u.startY,h.endX-u.startX,h.endY-u.startY),e.restore()}}setZIndex(e){this.Z_INDEX=e}}const pC=n=>{const{editState:i,onEditStateChange:e,viewState:t,onViewStateChange:r,permissionId:o}=n,s=I.useDependency(a.LocaleService),l=I.useDependency(I.IDialogService),c=I.useDependency(a.IAuthzIoService),d=I.useDependency(Mt),u=I.useDependency(a.UserManagerService),h=I.useDependency(a.IUniverInstanceService),g=I.useObservable(d.selectUserList$,d.selectUserList),S=h.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),f=S==null?void 0:S.getActiveSheet();if(!S||!f)return null;const p=S.getUnitId(),v=async()=>{const C=await c.listCollaborators({objectID:p,unitID:p}),b=u.getCurrentUser();d.setCanEditUserList(C.filter(R=>{var E;return((E=R.subject)==null?void 0:E.userID)!==b.userID})),l.open({id:hi,title:{title:""},children:{label:ec},width:280,destroyOnClose:!0,closable:!1,onClose:()=>l.close(hi),className:"sheet-permission-user-dialog"})};return V.useEffect(()=>{o?(async()=>{const R=(await c.listCollaborators({objectID:o,unitID:p})).filter(E=>E.role===Ae.Editor);R.length>0&&e(m.EditStateEnum.DesignedUserCanEdit),d.setSelectUserList(R),d.setOldCollaboratorList(R)})():(d.setSelectUserList([]),d.setOldCollaboratorList([]))},[]),_.jsxs(_.Fragment,{children:[_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:s.t("permission.panel.editPermission"),children:_.jsxs(X.RadioGroup,{value:i,onChange:C=>e(C),className:ve.radioGroupVertical,children:[_.jsx(X.Radio,{value:m.EditStateEnum.OnlyMe,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.onlyICanEdit")})}),_.jsx(X.Radio,{value:m.EditStateEnum.DesignedUserCanEdit,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.designedUserCanEdit")})})]})}),i===m.EditStateEnum.DesignedUserCanEdit&&_.jsxs("div",{className:ve.sheetPermissionDesignPersonPanel,children:[_.jsxs("div",{className:ve.sheetPermissionDesignPersonPanelHeader,children:[_.jsx("span",{children:s.t("permission.panel.designedPerson")}),_.jsx("span",{className:ve.sheetPermissionDesignPersonPanelHeaderAdd,onClick:v,children:s.t("permission.panel.addPerson")})]}),_.jsx("div",{className:ve.sheetPermissionDesignPersonPanelSplit}),_.jsx("div",{className:ve.sheetPermissionDesignPersonPanelContent,children:(g==null?void 0:g.length)>0?g.map(C=>{var b,R,E;return _.jsxs("div",{className:ve.sheetPermissionDesignPersonPanelContentItem,children:[_.jsx(X.Avatar,{size:24,src:(b=C.subject)==null?void 0:b.avatar}),_.jsx("span",{className:ve.sheetPermissionDesignPersonPanelContentItemName,children:(R=C.subject)==null?void 0:R.name}),_.jsx(X.Select,{className:ve.sheetPermissionDesignPersonPanelContentItemSelect,value:"edit",onChange:P=>{P==="delete"&&d.setSelectUserList(g.filter(y=>{var M,O;return((M=y.subject)==null?void 0:M.userID)!==((O=C.subject)==null?void 0:O.userID)}))},options:[{label:`${s.t("permission.panel.canEdit")}`,value:"edit"},{label:`${s.t("permission.panel.delete")}`,value:"delete"}]})]},(E=C.subject)==null?void 0:E.userID)}):_.jsxs("div",{className:ve.sheetPermissionUserListEmpty,children:[_.jsx("img",{width:240,height:120,src:nd,alt:""}),_.jsx("p",{className:ve.sheetPermissionUserListEmptyText,children:s.t("permission.dialog.userEmpty")})]})})]}),_.jsx(X.FormLayout,{className:ve.sheetPermissionPanelTitle,label:s.t("permission.panel.viewPermission"),children:_.jsxs(X.RadioGroup,{value:t,onChange:C=>r(C),className:ve.radioGroupVertical,children:[_.jsx(X.Radio,{value:m.ViewStateEnum.OthersCanView,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.othersCanView")})}),_.jsx(X.Radio,{value:m.ViewStateEnum.NoOneElseCanView,children:_.jsx("span",{className:ve.text,children:s.t("permission.panel.noOneElseCanView")})})]})})]})};var vC=Object.getOwnPropertyDescriptor,Fs=(n,i,e,t)=>{for(var r=t>1?void 0:t?vC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ve=(n,i)=>(e,t)=>i(e,t,n);let hr=class extends a.Disposable{constructor(n,i,e){super(),this._injector=n,this._componentManager=i,this._uiPartsService=e,this._init()}_init(){this._initComponents(),this._initUiPartComponents()}_initComponents(){[[nc,ml],[AS,Li],[kS,Ts],[DS,Tt],[rc,ws],[cr,zv],[ec,cC],[tc,nC],[ed,dC]].forEach(([n,i])=>{this.disposeWithMe(this._componentManager.register(n,i))})}_initUiPartComponents(){var e;const i=this._injector.get(a.IConfigService).getConfig(Xe);(e=i==null?void 0:i.customComponents)!=null&&e.has(Mn)||this.disposeWithMe(this._uiPartsService.registerComponent(Mn,()=>I.connectInjector(pC,this._injector)))}};hr=Fs([Ve(0,a.Inject(a.Injector)),Ve(1,a.Inject(I.ComponentManager)),Ve(2,a.Inject(I.IUIPartsService))],hr);let bi=class extends a.Disposable{constructor(i,e,t,r,o){var l;super();w(this,"_rangeProtectionCanViewRenderExtension",new mC);w(this,"_rangeProtectionCanNotViewRenderExtension",new gC);this._context=i,this._rangeProtectionRuleModel=e,this._sheetSkeletonManagerService=t,this._permissionService=r,this._configService=o;const s=this._configService.getConfig(Xe);this._initSkeleton(),!((l=s==null?void 0:s.customComponents)!=null&&l.has(Zi))&&(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 i=this._context.mainComponent;i&&(i.getExtensionByKey(id)||i.register(this._rangeProtectionCanViewRenderExtension),i.getExtensionByKey(od)||i.register(this._rangeProtectionCanNotViewRenderExtension))}_initSkeleton(){const i=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(x.merge(this._permissionService.permissionPointUpdate$.pipe(x.throttleTime(300,void 0,{trailing:!0})),this._rangeProtectionRuleModel.rangeRuleInitStateChange$,this._rangeProtectionRuleModel.ruleChange$).pipe().subscribe(i))}};bi=Fs([Ve(1,a.Inject(m.RangeProtectionRuleModel)),Ve(2,a.Inject(exports.SheetSkeletonManagerService)),Ve(3,a.IPermissionService),Ve(4,a.IConfigService)],bi);let Ri=class extends a.Disposable{constructor(i,e,t,r,o,s){var c;super();w(this,"_worksheetProtectionRenderExtension",new fC);this._context=i,this._renderManagerService=e,this._univerInstanceService=t,this._sheetSkeletonManagerService=r,this._worksheetProtectionRuleModel=o,this._configService=s;const l=this._configService.getConfig(Xe);this._initSkeleton(),!((c=l==null?void 0:l.customComponents)!=null&&c.has(Zi))&&this._initRender()}_initRender(){const i=this._context.unitId,e=i&&this._renderManagerService.getRenderById(i),t=e&&e.mainComponent;t&&(t.getExtensionByKey(ad)||t.register(this._worksheetProtectionRenderExtension))}_initSkeleton(){const i=()=>{var e;this._sheetSkeletonManagerService.reCalculate(),(e=this._context.mainComponent)==null||e.makeDirty()};this.disposeWithMe(x.merge(this._worksheetProtectionRuleModel.worksheetRuleInitStateChange$).pipe().subscribe(i))}};Ri=Fs([Ve(1,a.Inject(T.IRenderManagerService)),Ve(2,a.Inject(a.IUniverInstanceService)),Ve(3,a.Inject(exports.SheetSkeletonManagerService)),Ve(4,a.Inject(m.WorksheetProtectionRuleModel)),Ve(5,a.Inject(a.IConfigService))],Ri);var CC=Object.getOwnPropertyDescriptor,IC=(n,i,e,t)=>{for(var r=t>1?void 0:t?CC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},ko=(n,i)=>(e,t)=>i(e,t,n);let Ei=class extends a.Disposable{constructor(n,i,e,t){super(),this._context=n,this._formatPainterService=i,this._selectionRenderService=e,this._commandService=t,this._initialize()}_initialize(){this._bindFormatPainterStatus(),this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._selectionRenderService.selectionMoveEnd$.subscribe(n=>{var i;if(this._formatPainterService.getStatus()!==ke.OFF){const{rangeWithCoord:e}=n[n.length-1];this._commandService.executeCommand(Tr.id,{unitId:this._context.unitId,subUnitId:((i=this._context.unit.getActiveSheet())==null?void 0:i.getSheetId())||"",range:{startRow:e.startRow,startColumn:e.startColumn,endRow:e.endRow,endColumn:e.endColumn}}),this._formatPainterService.getStatus()===ke.ONCE&&this._commandService.executeCommand(Nn.id)}}))}_bindFormatPainterStatus(){this.disposeWithMe(a.toDisposable(this._formatPainterService.status$.subscribe(n=>{const i=this._context.scene;i&&(n!==ke.OFF?i.setDefaultCursor(T.CURSOR_TYPE.CELL):i.setDefaultCursor(T.CURSOR_TYPE.DEFAULT))})))}};Ei=IC([ko(1,$e),ko(2,Ce),ko(3,a.ICommandService)],Ei);var _C=Object.getOwnPropertyDescriptor,bC=(n,i,e,t)=>{for(var r=t>1?void 0:t?_C(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Kn=(n,i)=>(e,t)=>i(e,t,n);let ns=class extends a.Disposable{constructor(n,i,e,t,r,o){super(),this._context=n,this._layoutService=i,this._contextMenuService=e,this._selectionManagerService=t,this._selectionRenderService=r,this._sheetSkeletonManagerService=o,this._init()}_init(){let n=!1;this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(()=>n=!0)),this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(i=>{const e=this._sheetSkeletonManagerService.getCurrentParam().skeleton;if(!e||!i||n===!1)return;n=!1;const t=i[0];if(!t.primary)return;const r=Pe(t,e),o=t.range.rangeType,{scene:s}=this._context,l=s.getViewport(T.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 g=e.rowHeaderWidth,S=this._layoutService.getContentElement().getBoundingClientRect();switch(o){case a.RANGE_TYPE.NORMAL:u=r.rangeWithCoord.startX+S.left-c,h=r.rangeWithCoord.endY+S.top-d;break;case a.RANGE_TYPE.COLUMN:u=r.rangeWithCoord.startX+S.left-c,h=Math.min(S.height/2,r.rangeWithCoord.endY)+40;break;case a.RANGE_TYPE.ROW:u=(S.width-g)/2+20,h=r.rangeWithCoord.endY+S.top-d;break;case a.RANGE_TYPE.ALL:u=r.rangeWithCoord.startX+S.left,h=r.rangeWithCoord.startY+S.top;break;default:u=r.rangeWithCoord.startX+S.left-c,h=r.rangeWithCoord.endY+S.top-d;break}u=a.Tools.clamp(u,g,S.width),h=a.Tools.clamp(h,S.top,S.height),this._contextMenuService.triggerContextMenu({clientX:u,clientY:h,preventDefault:()=>{},stopPropagation:()=>{}},I.ContextMenuPosition.MAIN_AREA)}))}};ns=bC([Kn(1,I.ILayoutService),Kn(2,I.IContextMenuService),Kn(3,a.Inject(m.SheetsSelectionsService)),Kn(4,Ce),Kn(5,a.Inject(exports.SheetSkeletonManagerService))],ns);var RC=Object.getOwnPropertyDescriptor,EC=(n,i,e,t)=>{for(var r=t>1?void 0:t?RC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},dn=(n,i)=>(e,t)=>i(e,t,n);const wC=[xe.id,Je.id];let rs=class extends a.Disposable{constructor(n,i,e,t,r,o,s){super(),this._context=n,this._sheetSkeletonManagerService=i,this._commandService=e,this._renderManagerService=t,this._selectionManagerService=r,this._scrollManagerService=o,this._univerInstanceService=s,this._init()}scrollToRange(n){let{endRow:i,endColumn:e,startColumn:t,startRow:r}=n;const o=this._getViewportBounding();if(n.rangeType===a.RANGE_TYPE.ROW?(t=0,e=0):n.rangeType===a.RANGE_TYPE.COLUMN&&(r=0,i=0),o){const s=o.startRow>i?r:i,l=o.startColumn>e?t:e;return this._scrollToCell(s,l)}else return this._scrollToCell(r,t)}_init(){this._initCommandListener(),this._initScrollEventListener(),this._initPointerScrollEvent(),this._initSkeletonListener()}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{if(wC.includes(n.id))this._scrollToSelection();else if(n.id===m.ScrollToCellOperation.id){const i=n.params.range;this.scrollToRange(i)}else if(n.id===De.id){const i=n.params;this._scrollToSelectionForExpand(i)}}))}_scrollToSelectionForExpand(n){setTimeout(()=>{const i=this._selectionManagerService.getCurrentLastSelection();if(i==null)return;const{startRow:e,startColumn:t,endRow:r,endColumn:o}=i.range,s=this._getViewportBounding();if(s==null)return;const{startRow:l,startColumn:c,endRow:d,endColumn:u}=s;let h=0,g=0;e>l?h=r:r<d?h=e:h=l,t>c?g=o:o<u?g=t:g=c,n.direction===a.Direction.DOWN?h=r:n.direction===a.Direction.UP?h=e:n.direction===a.Direction.RIGHT?g=o:n.direction===a.Direction.LEFT&&(g=t),this._scrollToCell(h,g)},0)}_getFreeze(){var i;const n=(i=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:i.skeleton.getWorksheetConfig();if(n!=null)return n.freeze}_initScrollEventListener(){const{scene:n}=this._context;if(n==null)return;const i=n.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);i&&(this.disposeWithMe(a.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(e=>{var g;if(e==null){i.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const t=(g=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:g.skeleton;if(!t)return;const{sheetViewStartRow:r,sheetViewStartColumn:o,offsetX:s,offsetY:l}=e,{startX:c,startY:d}=t.getCellWithCoordByIndex(r,o,!1),u=c+s,h=d+l;i.scrollToViewportPos({viewportScrollX:u,viewportScrollY:h})}))),this.disposeWithMe(i.onScrollAfter$.subscribeEvent(e=>{var f;if(!e)return;const t=(f=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:f.skeleton;if(t==null)return;const r=this._getSheetObject();if(t==null||r==null)return;const{viewportScrollX:o,viewportScrollY:s,scrollX:l,scrollY:c}=e,{row:d,column:u,rowOffset:h,columnOffset:g}=t.getOffsetRelativeToRowCol(o,s),S={sheetViewStartRow:d,sheetViewStartColumn:u,offsetX:g,offsetY:h,viewportScrollX:o,viewportScrollY:s,scrollX:l,scrollY:c};this._scrollManagerService.setValidScrollStateToCurrSheet(S),this._scrollManagerService.validViewportScrollInfo$.next({...S,scrollX:l,scrollY:c,viewportScrollX:o,viewportScrollY:s})})),this.disposeWithMe(i.onScrollByBar$.subscribeEvent(e=>{var g;const t=(g=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:g.skeleton;if(t==null||e.isTrigger===!1)return;const r=this._getSheetObject();if(t==null||r==null)return;const{viewportScrollX:o=0,viewportScrollY:s=0}=e,l=this._getFreeze(),{row:c,column:d,rowOffset:u,columnOffset:h}=t.getOffsetRelativeToRowCol(o,s);this._commandService.executeCommand(Fe.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 i={unitId:n.unitId,sheetId:n.sheetId};this._scrollManagerService.setSearchParam(i);const e=this._getSheetObject();if(!e)return;const r=e.scene.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),o=this._scrollManagerService.getScrollStateByParam(i),{viewportScrollX:s,viewportScrollY:l}=this._scrollManagerService.calcViewportScrollFromRowColOffset(o);r&&(o?(r.viewportScrollX=s,r.viewportScrollY=l):(r.viewportScrollX=0,r.viewportScrollY=0),this._updateSceneSize(n))})))}_initPointerScrollEvent(){const n=this._getSheetObject();if(!n)return;const i=this._scrollManagerService,e=n.scene,t=n.spreadsheet,r=e.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),o={x:0,y:0};let s=!1;const l={x:0,y:0},c=.95;let d=null;const u=()=>{if(!r)return;l.x*=c,l.y*=c,o.x+=l.x,o.y+=l.y;const g=l.x,S=l.y;(S!==0||g!==0)&&this._commandService.executeCommand(Rn.id,{offsetY:S,offsetX:g}),Math.abs(l.x)>1||Math.abs(l.y)>1?d=requestAnimationFrame(u):d=null},h=()=>{cancelAnimationFrame(d),d=null};t.onPointerDown$.subscribeEvent((g,S)=>{h(),r&&(o.x=g.offsetX,o.y=g.offsetY,s=!0,S.stopPropagation())}),t.onPointerMove$.subscribeEvent((g,S)=>{if(!s||!r)return;const f=g,p=-(f.offsetX-o.x),v=-(f.offsetY-o.y);l.x=-(f.offsetX-o.x),l.y=-(f.offsetY-o.y);const C=p,b=v;(p!==0||v!==0)&&(b!==0||C!==0)&&this._commandService.executeCommand(Rn.id,{offsetY:b,offsetX:C}),i.getCurrentScrollState(),o.x=f.offsetX,o.y=f.offsetY,S.stopPropagation()}),t.onPointerUp$.subscribeEvent(g=>{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:i}=this._context,{skeleton:e}=n,t=(h=this._renderManagerService.getRenderById(i))==null?void 0:h.scene;if(e==null||t==null)return;const{rowTotalHeight:r,columnTotalWidth:o,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+o,height:l+r})}_getSheetObject(){return Ye(this._context.unit,this._context)}_scrollToSelectionByDirection(n){const i=this._getViewportBounding();if(i==null)return!1;const{startRow:e,startColumn:t,endRow:r,endColumn:o}=i;let s=0,l=0;const{startRow:c,startColumn:d,endRow:u,endColumn:h}=n;c>=e&&(s=u),u<=r&&(s=c),d>=t&&(l=h),h<=o&&(l=d),this._scrollToCell(s,l)}_scrollToSelection(n=!0){const i=this._selectionManagerService.getCurrentLastSelection();if(i==null)return;const{startRow:e,startColumn:t,actualRow:r,actualColumn:o}=i.primary,s=n?r:e,l=n?o:t;this._scrollToCell(s,l)}_getViewportBounding(){var t,r;const n=(t=this._getSheetObject())==null?void 0:t.scene;if(n==null)return;const i=n.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(i==null)return;const e=(r=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:r.skeleton;if(e!=null)return e.getRangeByViewport(i.calcViewportInfo())}_scrollToCell(n,i){var P,y,M,O;const{rowHeightAccumulation:e,columnWidthAccumulation:t}=(y=(P=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:P.skeleton)!=null?y:{};if(e==null||t==null)return!1;const r=(M=this._getSheetObject())==null?void 0:M.scene;if(r==null)return!1;const o=r.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(o==null||((O=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:O.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(),g=this._getViewportBounding();if(g==null)return!1;const{startRow:S,startColumn:f,endRow:p,endColumn:v}=g;let C,b;if(n>=d&&i>=c-h&&(n<=S&&(C=n),n>=p)){const A=e[n]-o.height;for(let k=S;k<=n;k++)if(e[k]>=A){C=k+1;break}}if(i>=c&&n>=d-u&&(i<=f&&(b=i),i>=v)){const A=t[i]-o.width;for(let k=f;k<=i;k++)if(t[k]>=A){b=k+1;break}}if(C===void 0&&b===void 0)return!1;const{offsetX:R,offsetY:E}=this._scrollManagerService.getCurrentScrollState()||{};return this._commandService.syncExecuteCommand(Fe.id,{sheetViewStartRow:C,sheetViewStartColumn:b,offsetX:b===void 0?R:0,offsetY:C===void 0?E:0})}};rs=EC([dn(1,a.Inject(exports.SheetSkeletonManagerService)),dn(2,a.ICommandService),dn(3,T.IRenderManagerService),dn(4,a.Inject(m.SheetsSelectionsService)),dn(5,a.Inject(exports.SheetScrollManagerService)),dn(6,a.IUniverInstanceService)],rs);function ld(n){const{popup:i}=n,{extraProps:e}=i,{options:t,defaultValue:r,onChange:o}=e,[s,l]=V.useState(r!=null?r:[]);return _.jsx(X.CascaderList,{options:t,value:s,onChange:o})}ld.componentKey="sheets.dropdown.cascader";function cd(n){const{popup:i}=n,{extraProps:e}=i,{defaultValue:t,onChange:r}=e;return _.jsx(X.ColorPicker,{value:t,onChange:r})}cd.componentKey="sheets.dropdown.color";const TC="univer-dv-date-dropdown",yC="univer-dv-date-dropdown-btns",za={dvDateDropdown:TC,dvDateDropdownBtns:yC};function dd(n){const{popup:i}=n,{extraProps:e}=i,{hideFn:t,patternType:r,defaultValue:o,onChange:s,showTime:l}=e,[c,d]=V.useState(o),u=V.useMemo(()=>r!=="time"?a.dayjs():a.dayjs("1900-01-01 00:00:00"),[]),h=c&&c.isValid()?c:u,g=I.useDependency(a.LocaleService),S=async()=>{h&&await(s==null?void 0:s(h))!==!1&&t()};return _.jsxs("div",{className:za.dvDateDropdown,children:[_.jsx(X.DatePanel,{value:h,pickerValue:h,mode:r==="time"?"time":"date",showTime:(l!=null?l:r==="datetime"||r==="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:za.dvDateDropdownBtns,children:_.jsx(X.Button,{size:"small",variant:"primary",onClick:S,disabled:!h||!h.isValid(),children:g.t("dataValidation.alert.ok")})})]})}dd.componentKey="sheets.dropdown.date";const MC="univer-dv-list-dropdown",PC="univer-dv-list-dropdown-title",OC="univer-dv-list-dropdown-list",xC="univer-dv-list-dropdown-list-container",AC="univer-dv-list-dropdown-selected-icon",kC="univer-dv-list-dropdown-item-container",DC="univer-dv-list-dropdown-item",NC="univer-dv-list-dropdown-split",HC="univer-dv-list-dropdown-edit",ot={dvListDropdown:MC,dvListDropdownTitle:PC,dvListDropdownList:OC,dvListDropdownListContainer:xC,dvListDropdownSelectedIcon:AC,dvListDropdownItemContainer:kC,dvListDropdownItem:DC,dvListDropdownSplit:NC,dvListDropdownEdit:HC};function VC(n){return n.filter(Boolean).join(",")}function WC(n){return n.split(",").filter(Boolean)}const LC=n=>{const{value:i,onChange:e,multiple:t,options:r,title:o,onEdit:s,style:l,filter:c,location:d,showEdit:u}=n,h=I.useDependency(a.LocaleService),g=c==null?void 0:c.toLowerCase(),{row:S,col:f,unitId:p,subUnitId:v}=d,C=r.filter(E=>g?E.label.toLowerCase().includes(g):!0),b=I.useDependency(m.SheetPermissionCheckController),R=V.useMemo(()=>b.permissionCheckWithRanges({workbookTypes:[m.WorkbookEditablePermission],rangeTypes:[m.RangeProtectionPermissionEditPoint],worksheetTypes:[m.WorksheetEditPermission]},[{startColumn:f,startRow:S,endColumn:f,endRow:S}],p,v),[b,f,S,p,v]);return _.jsxs("div",{className:ot.dvListDropdown,style:l,children:[_.jsx("div",{className:ot.dvListDropdownTitle,children:o}),_.jsx("div",{className:ot.dvListDropdownList,children:_.jsx(X.Scrollbar,{children:_.jsx("div",{className:ot.dvListDropdownListContainer,children:C.map((E,P)=>{const y=i.indexOf(E.value)>-1,M=()=>{let A;y?A=new Set(i.filter(D=>D!==E.value)):A=new Set(t?[...i,E.value]:[E.value]);const k=[];r.forEach(D=>{A.has(D.value)&&k.push(D.value)}),e(k)},O=E.label.toLocaleLowerCase().indexOf(g);return _.jsxs("div",{className:ot.dvListDropdownItemContainer,onClick:M,children:[_.jsx("div",{className:ot.dvListDropdownItem,style:{background:E.color},children:g&&E.label.toLowerCase().includes(g)?_.jsxs(_.Fragment,{children:[_.jsx("span",{children:E.label.substring(0,O)}),_.jsx("span",{style:{fontWeight:"bold"},children:E.label.substring(O,O+g.length)}),_.jsx("span",{children:E.label.substring(O+g.length)})]}):E.label}),_.jsx("div",{className:ot.dvListDropdownSelectedIcon,children:y?_.jsx(Tt,{}):null})]},P)})})},c)}),u&&R?_.jsxs(_.Fragment,{children:[_.jsx("div",{className:ot.dvListDropdownSplit}),_.jsx("div",{className:ot.dvListDropdownEdit,children:_.jsx("a",{onClick:s,children:h.t("dataValidation.list.edit")})})]}):null]})};function ud(n){var P,y,M,O;const{popup:{extraProps:i}}=n,{location:e,hideFn:t,onChange:r,onEdit:o,options:s,defaultValue:l,multiple:c,showEdit:d}=i,{worksheet:u}=e,[h,g]=V.useState(""),S=I.useDependency(a.ICommandService),f=I.useDependency(a.LocaleService),[p,v]=V.useState(l),C=I.useDependency(me),b=I.useDependency(a.IUniverInstanceService),R=I.RectPopup.useContext(),E=((y=(P=R.current)==null?void 0:P.right)!=null?y:0)-((O=(M=R.current)==null?void 0:M.left)!=null?O:0);return V.useEffect(()=>{const A=S.onCommandExecuted(k=>{var D,N;if(k.id===_e.RichTextEditingMutation.id){const W=k.params,{unitId:H}=W,L=b.getUnit(H,a.UniverInstanceType.UNIVER_DOC);if(!L||!C.isVisible().visible)return;const U=a.BuildTextUtils.transform.getPlainText((N=(D=L.getSnapshot().body)==null?void 0:D.dataStream)!=null?N:"");g(U)}});return()=>{A.dispose()}},[S,C,b]),u?_.jsx(LC,{style:{minWidth:E,maxWidth:Math.max(E,200)},title:c?f.t("dataValidation.listMultiple.dropdown"):f.t("dataValidation.list.dropdown"),value:WC(p!=null?p:""),multiple:c,onChange:async A=>{const k=VC(A);v(k),await(r==null?void 0:r(A))!==!1&&t()},options:s,onEdit:o,filter:h,location:e,showEdit:d}):null}ud.componentKey="sheets.dropdown.list";const Xa={datepicker:dd,list:ud,color:cd,cascader:ld};var UC=Object.getOwnPropertyDescriptor,BC=(n,i,e,t)=>{for(var r=t>1?void 0:t?UC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},qr=(n,i)=>(e,t)=>i(e,t,n);const js=a.createIdentifier("ICellDropdownManagerService");exports.SheetCellDropdownManagerService=class extends a.Disposable{constructor(i,e,t,r){super(),this._canvasPopupManagerService=i,this._zenZoneService=e,this._renderManagerService=t,this._componentManager=r,Object.values(Xa).forEach(o=>{this.disposeWithMe(this._componentManager.register(o.componentKey,o))})}showDropdown(i){const{location:e,onHide:t,closeOnOutSide:r=!0}=i,{row:o,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=Xa[i.type],u=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),h=new a.DisposableCollection,g=this._canvasPopupManagerService.attachPopupToCell(o,s,{componentKey:d.componentKey,onClickOutside:()=>{r&&h.dispose()},offset:[0,3],excludeOutside:[u==null?void 0:u.engine.getCanvasElement()].filter(Boolean),extraProps:{...i,...i.props,hideFn:()=>{h.dispose()}}},l,c);if(!g)throw new Error("[SheetCellDropdownManagerService]: cannot show dropdown");return h.add(g),h.add({dispose:()=>{t==null||t()}}),h}};exports.SheetCellDropdownManagerService=BC([qr(0,a.Inject(exports.SheetCanvasPopManagerService)),qr(1,I.IZenZoneService),qr(2,T.IRenderManagerService),qr(3,a.Inject(I.ComponentManager))],exports.SheetCellDropdownManagerService);const FC=a.createInterceptorKey("PRINTING_RANGE"),jC=a.createInterceptorKey("PRINTING_COMPONENT_COLLECT"),zC=a.createInterceptorKey("PRINTING_DOM_COLLECT");class zs extends a.Disposable{constructor(){super();w(this,"interceptor",new a.InterceptorManager({PRINTING_RANGE:FC,PRINTING_COMPONENT_COLLECT:jC,PRINTING_DOM_COLLECT:zC}));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 XC extends mr{constructor(e,t,r,o){super(e,t,r,o);w(this,"_fillControlTopLeft");w(this,"_fillControlBottomRight");w(this,"_rangeType",a.RANGE_TYPE.NORMAL);this._scene=e,this._zIndex=t,this._themeService=r,this._rangeType=(o==null?void 0:o.rangeType)||a.RANGE_TYPE.NORMAL,this.initControlPoints()}initControlPoints(){const e=this.currentStyle,t=e.expandCornerSize||0,r=(e.expandCornerSize||0)/4,o=e.autofillStrokeWidth||0,s=e.stroke,l=e.autofillStroke,c=this.zIndex;this._fillControlTopLeft=new T.Rect(Bo.fillTopLeft+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualWidth:r,visualHeight:r,strokeWidth:o}),this._fillControlBottomRight=new T.Rect(Bo.fillBottomRight+c,{zIndex:c+2,width:t,height:t,radius:t/2,visualHeight:r,visualWidth:r,strokeWidth:o});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,ii)}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 o,s;super._updateLayoutOfSelectionControl(e);const t=this.currentStyle;e==null&&(e=t);const{widgets:r=t.widgets}=e;if(this.currentStyle=e,this._enableAutoFill===!0&&!super._hasWidgets(r)){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(o=this.fillControlTopLeft)==null||o.hide(),(s=this.fillControlBottomRight)==null||s.hide()}getViewportMainScrollInfo(){const e=this.getScene().getViewport(T.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,r=0,o=0){const s=this.currentStyle,l=this.selectionModel.rangeType,c=s.expandCornerSize,{startX:d,startY:u,endX:h,endY:g}=this.selectionModel,S=this.getViewportMainScrollInfo(),f=S.width,p=S.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:g-u-c/2});break;case a.RANGE_TYPE.ROW:{const v=Math.min(f/2+e,r),C=-c/2+v;this.fillControlTopLeft.transformByState({left:C,top:-c/2}),this.fillControlBottomRight.transformByState({left:C,top:-c/2+g-u})}break;case a.RANGE_TYPE.COLUMN:{const v=Math.min(+p/2+t,o),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 YC=Object.getOwnPropertyDescriptor,GC=(n,i,e,t)=>{for(var r=t>1?void 0:t?YC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},st=(n,i)=>(e,t)=>i(e,t,n);let wi=class extends gs{constructor(i,e,t,r,o,s,l,c,d,u){super(e,t,r,s,d);w(this,"_workbookSelections");w(this,"_renderDisposable",null);w(this,"_expandingSelection",!1);w(this,"_selectionControls",[]);w(this,"expandingControlMode","bottom-right");this._context=i,this._logService=l,this._commandService=c,this._contextService=d,this._scrollManagerService=u,this._workbookSelections=o.getWorkbookSelections(this._context.unitId),this._init()}_init(){const i=this._getSheetObject();this._initEventListeners(i),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._updateControlPointWhenScrolling()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(i=>{if(i==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const e=this._context.unitId,{sheetId:t,skeleton:r}=i,{scene:o}=this._context,s=o.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._changeRuntime(r,o,s),this._workbookSelections.getCurrentLastSelection()||this._commandService.syncExecuteCommand(m.SetSelectionsOperation.id,{unitId:e,subUnitId:t,selections:[Vi(r)]})}))}_initSelectionChangeListener(){}_initEventListeners(i){const{spreadsheetRowHeader:e,spreadsheetColumnHeader:t,spreadsheet:r,spreadsheetLeftTopPlaceholder:o}=i,{scene:s}=this._context;this._initSpreadsheetEvent(i),this.disposeWithMe(e==null?void 0:e.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{row:u}=Ke(l.offsetX,l.offsetY,s,d);Gl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(r.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}=Ke(l.offsetX,l.offsetY,s,d);Zl(this._workbookSelections.getCurrentSelections(),u)||(this.createNewSelection(l,(r.zIndex||1)+1,a.RANGE_TYPE.COLUMN,this._getActiveViewport(l)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(o==null?void 0:o.onPointerUp$.subscribeEvent((l,c)=>{if(this._normalSelectionDisabled())return;this._reset();const d=this._sheetSkeletonManagerService.getCurrentParam().skeleton,u=Ss(d);this._addSelectionControlByModelData(u),this.refreshSelectionMoveStart(),c.stopPropagation(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}))}_initSpreadsheetEvent(i){const{spreadsheet:e}=i;let t;const r=500,o={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-o.x)>10||Math.abs(u.offsetY-o.y)>10)&&s()});const c=e==null?void 0:e.onPointerDown$.subscribeEvent((u,h)=>{o.x=u.offsetX,o.y=u.offsetY,t=setTimeout(()=>{l(u,!0)},r),h.stopPropagation()}),d=e==null?void 0:e.onPointerUp$.subscribeEvent((u,h)=>{if(this._normalSelectionDisabled())return;clearTimeout(t);const g=10;Math.abs(u.offsetX-o.x)>g||Math.abs(u.offsetY-o.y)>g||(l(u,!1),h.stopPropagation())});this.disposeWithMe(a.toDisposable(c)),this.disposeWithMe(a.toDisposable(d))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(i=>this._updateSelections(i,m.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(i=>this._updateSelections(i,m.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(m.REF_SELECTIONS_ENABLED).pipe(x.startWith(!1),x.distinctUntilChanged()).subscribe(i=>{var e;i?((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(i,e){const t=this._context.unit,r=t.getUnitId(),o=t.getActiveSheet().getSheetId();i.length!==0&&this._commandService.executeCommand(m.SetSelectionsOperation.id,{unitId:r,subUnitId:o,type:e,selections:i.map(s=>m.convertSelectionDataToRange(s))})}createNewSelection(i,e=0,t=a.RANGE_TYPE.NORMAL,r){this._rangeType=t;const o=this._skeleton,s=this._scene;if(!s||!o)return;r&&(this._activeViewport=r);const{offsetX:l,offsetY:c}=i,d=s.getCoordRelativeToViewport(T.Vector2.FromArray([l,c])),{x:u,y:h}=d;this._startViewportPosX=u,this._startViewportPosY=h;const g=s.getScrollXYInfoByViewport(d),{scaleX:S,scaleY:f}=s.getAncestorScale(),p=this._skeleton.getCellByOffset(u,h,S,f,g);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=Pe(v,this._skeleton);this._startRangeWhenPointerDown={...C.rangeWithCoord};let b=this.getActiveSelectionControl();const R={...C.rangeWithCoord};for(const E of this.getSelectionControls())if(E.model.isEqual(R)){b=E;break}(b==null?void 0:b.model.rangeType)!==t?(this._clearAllSelectionControls(),b=this.newSelectionControl(s,o,v)):b.updateRangeBySelectionWithCoord(C),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._expandingSelection=!1}newSelectionControl(i,e,t){const r=this.getSelectionControls(),{rowHeaderWidth:o,columnHeaderHeight:s}=e,l=t.range.rangeType,c=new XC(i,r.length,this._themeService,{highlightHeader:this._highlightHeader,rowHeaderWidth:o,columnHeaderHeight:s,rangeType:l}),d=Pe(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(g=>{this._expandingSelection=!0,this.expandingControlMode=u,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(g,l,this._activeViewport)}),c.fillControlBottomRight.onPointerDown$.subscribeEvent(g=>{this._expandingSelection=!0,this.expandingControlMode=h,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(g,l,this._activeViewport)}),(l===a.RANGE_TYPE.ROW||l===a.RANGE_TYPE.COLUMN)&&!i.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),c}_getActiveViewport(i){const e=this._getSheetObject();return e==null?void 0:e.scene.getActiveViewportByCoord(T.Vector2.FromArray([i.offsetX,i.offsetY]))}_getSheetObject(){return Ye(this._context.unit,this._context)}_normalSelectionDisabled(){return this._contextService.getContextValue(m.REF_SELECTIONS_ENABLED)}getSelectionControls(){return this._selectionControls}_fillControlPointerDownHandler(i,e=a.RANGE_TYPE.NORMAL,t,r=T.ScrollTimerType.ALL){var h,g,S;const o=this._skeleton,s=this._scene;if(!s||!o)return;t&&(this._activeViewport=t);const l=s.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=this.getActiveSelectionControl();if(!c)return;this._changeCurrCellWhenControlPointerDown(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._addEndingListeners(),this._scrollTimer=T.ScrollTimer.create(this._scene,r),this._scrollTimer.startScroll((h=l==null?void 0:l.left)!=null?h:0,(g=l==null?void 0:l.top)!=null?g:0,l),(S=s.getTransformer())==null||S.clearSelectedObjects();const d=s.getCoordRelativeToViewport(T.Vector2.FromArray([i.offsetX,i.offsetY]));this._setupPointerMoveListener(l,c,e,r,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 i=this.getActiveSelectionControl(),e=this._skeleton;let t;const{startRow:r,startColumn:o,endRow:s,endColumn:l}=i.model;switch(this.expandingControlMode){case"top-left":t=e.getCellWithCoordByIndex(s,l);break;case"bottom-right":t=e.getCellWithCoordByIndex(r,o);break;case"left":t=e.getCellWithCoordByIndex(r,l),t.isMerged=!1,t.isMergedMainCell=!1;break;case"right":t=e.getCellWithCoordByIndex(r,o),t.isMerged=!1,t.isMergedMainCell=!1;break;case"top":t=e.getCellWithCoordByIndex(s,o),t.isMerged=!1,t.isMergedMainCell=!1;break;case"bottom":t=e.getCellWithCoordByIndex(r,o),t.isMerged=!1,t.isMergedMainCell=!1;break;default:t=e.getCellWithCoordByIndex(r,o)}return i.updateCurrCell(t),t}_movingHandler(i,e,t,r){var O,A,k,D,N,W,H,L,U,j,B,z,F;this._rangeType=r;const o=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(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),d=(O=this._getViewportByCell(l.endRow,l.endColumn))!=null?O:c,u=s.getScrollXYInfoByViewport(T.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),d),{scaleX:h,scaleY:g}=s.getAncestorScale();r===a.RANGE_TYPE.ROW?i=Number.POSITIVE_INFINITY:r===a.RANGE_TYPE.COLUMN&&(e=Number.POSITIVE_INFINITY);const S=this._getSelectionWithCoordByOffset(i,e,h,g,u);if(!S)return!1;const{rangeWithCoord:f}=S,p=t.model.currentCell,v=(A=p==null?void 0:p.mergeInfo.startRow)!=null?A:-1,C=(k=p==null?void 0:p.mergeInfo.endRow)!=null?k:-1,b=(D=p==null?void 0:p.mergeInfo.startColumn)!=null?D:-1,R=(N=p==null?void 0:p.mergeInfo.endColumn)!=null?N:-1;let E={startRow:Math.min(f.startRow,v),startColumn:Math.min(f.startColumn,b),endRow:Math.max(f.endRow,C),endColumn:Math.max(f.endColumn,R)};if(r===a.RANGE_TYPE.NORMAL?E=o.expandRangeByMerge(E):r===a.RANGE_TYPE.COLUMN?E={startRow:Math.min(f.startRow,(W=p==null?void 0:p.actualRow)!=null?W:-1),startColumn:Math.min(f.startColumn,(H=p==null?void 0:p.actualColumn)!=null?H:-1),endRow:Math.max(f.endRow,(L=p==null?void 0:p.actualRow)!=null?L:-1),endColumn:Math.max(f.endColumn,(U=p==null?void 0:p.actualColumn)!=null?U:-1)}:r===a.RANGE_TYPE.ROW&&(E={startRow:Math.min(f.startRow,(j=p==null?void 0:p.actualRow)!=null?j:-1),startColumn:Math.min(f.startColumn,(B=p==null?void 0:p.actualColumn)!=null?B:-1),endRow:Math.max(f.endRow,(z=p==null?void 0:p.actualRow)!=null?z:-1),endColumn:Math.max(f.endColumn,(F=p==null?void 0:p.actualColumn)!=null?F:-1)}),!E)return!1;const y=Pe({range:E,style:null,primary:null},o);(l.startRow!==E.startRow||l.startColumn!==E.startColumn||l.endRow!==E.endRow||l.endColumn!==E.endColumn)&&t&&(t.updateRangeBySelectionWithCoord(y),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateControlPointWhenScrolling(){const{scene:i}=this._context;if(!i.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN))return;const t=this._scrollManagerService.validViewportScrollInfo$.subscribe(r=>{var g;if(r==null)return;const{viewportScrollX:o,viewportScrollY:s}=r,l=this.getActiveSelectionControl();if(l==null)return;const c=(g=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:g.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(o,0,u,d)});this.disposeWithMe(a.toDisposable(t))}};wi=GC([st(1,a.Inject(a.Injector)),st(2,a.Inject(a.ThemeService)),st(3,I.IShortcutService),st(4,a.Inject(m.SheetsSelectionsService)),st(5,a.Inject(exports.SheetSkeletonManagerService)),st(6,a.ILogService),st(7,a.ICommandService),st(8,a.IContextService),st(9,a.Inject(exports.SheetScrollManagerService))],wi);var ZC=Object.defineProperty,KC=Object.getOwnPropertyDescriptor,qC=(n,i,e)=>i in n?ZC(n,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[i]=e,QC=(n,i,e,t)=>{for(var r=t>1?void 0:t?KC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Do=(n,i)=>(e,t)=>i(e,t,n),hd=(n,i,e)=>qC(n,typeof i!="symbol"?i+"":i,e);exports.UniverSheetsMobileUIPlugin=class extends a.Plugin{constructor(i=Fo,e,t,r){super(),this._config=i,this._injector=e,this._renderManagerService=t,this._univerInstanceService=r}onStarting(){[[bn],[Ue,{useClass:exports.SheetClipboardService}],[qt,{useClass:fl}],[$e,{useClass:ui}],[wt,{useClass:exports.AutoFillService}],[zs],[Ce,{useClass:wi}],[Ir,{useClass:ys}],[Qt,{useClass:exports.MarkSelectionService}],[me,{useClass:exports.EditorBridgeService}],[exports.HoverManagerService],[exports.DragManagerService],[exports.SheetCanvasPopManagerService],[exports.CellAlertManagerService],[vs],[js,{useClass:exports.SheetCellDropdownManagerService}],[dr],[exports.AutoHeightController],[An],[exports.SheetsRenderService],[Ci],[exports.StatusBarController],[m.IRefSelectionsService,{useClass:m.RefSelectionsService}],[Pn],[Mt],[Ri],[ur],[exports.SheetPermissionCheckUIController],[hr]].forEach(i=>this._injector.add(i))}onReady(){this._markSheetAsFocused(),this._registerRenderBasics(),this._injector.get(Ci)}onRendered(){this._registerRenderModules()}_registerRenderBasics(){[[exports.SheetSkeletonManagerService],[exports.SheetRenderController],[Ce,{useClass:wi}],[exports.SheetScrollManagerService]].forEach(i=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,i))})}_registerRenderModules(){[[exports.HeaderMoveRenderController],[exports.HeaderFreezeRenderController],[rs],[or],[Ei],[Si],[fi],[vi],[exports.HoverRenderController],[exports.DragRenderController],[pi],[exports.CellCustomRenderController],[ns],[Ii],[_i],[bi]].forEach(i=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,i))})}_markSheetAsFocused(){const i=this._univerInstanceService;this.disposeWithMe(i.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).pipe(he.filter(e=>!!e)).subscribe(e=>{this._univerInstanceService.getFocusedUnit()!==e&&i.focusUnit(e.getUnitId())}))}};hd(exports.UniverSheetsMobileUIPlugin,"pluginName","SHEET_UI_PLUGIN");hd(exports.UniverSheetsMobileUIPlugin,"type",a.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsMobileUIPlugin=QC([a.DependentOn(m.UniverSheetsPlugin,I.UniverMobileUIPlugin),Do(1,a.Inject(a.Injector)),Do(2,T.IRenderManagerService),Do(3,a.IUniverInstanceService)],exports.UniverSheetsMobileUIPlugin);var JC=Object.getOwnPropertyDescriptor,$C=(n,i,e,t)=>{for(var r=t>1?void 0:t?JC(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Qr=(n,i)=>(e,t)=>i(e,t,n);let Ti=class extends a.Disposable{constructor(i,e,t,r){super();w(this,"_isPointer",!1);this._hoverManagerService=i,this._instanceService=e,this._commandService=t,this._renderManagerService=r,this._initPointerEvent(),this._initHover()}get _mainComponent(){var i;return(i=T.getCurrentTypeOfRenderer(a.UniverInstanceType.UNIVER_SHEET,this._instanceService,this._renderManagerService))==null?void 0:i.mainComponent}_initHover(){this.disposeWithMe(this._hoverManagerService.currentRichText$.subscribe(i=>{var e,t;i!=null&&i.bullet?(this._isPointer||(e=this._mainComponent)==null||e.setCursor(T.CURSOR_TYPE.POINTER),this._isPointer=!0):(this._isPointer&&((t=this._mainComponent)==null||t.setCursor(T.CURSOR_TYPE.AUTO)),this._isPointer=!1)}))}_initPointerEvent(){this.disposeWithMe(this._hoverManagerService.currentClickedCell$.subscribe(i=>{const{location:e,bullet:t}=i;t&&this._commandService.executeCommand(m.ToggleCellCheckboxCommand.id,{unitId:e.unitId,subUnitId:e.subUnitId,row:e.row,col:e.col,paragraphIndex:t.startIndex})}))}};Ti=$C([Qr(0,a.Inject(exports.HoverManagerService)),Qr(1,a.IUniverInstanceService),Qr(2,a.ICommandService),Qr(3,T.IRenderManagerService)],Ti);var eI=Object.getOwnPropertyDescriptor,tI=(n,i,e,t)=>{for(var r=t>1?void 0:t?eI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},qn=(n,i)=>(e,t)=>i(e,t,n);let yi=class extends a.Disposable{constructor(n,i,e,t,r){super(),this._selectionManagerService=n,this._themeService=i,this._instanceSrv=e,this._cmdSrv=t,this._definedNamesService=r,this._init()}_init(){this.disposeWithMe(x.merge(this._selectionManagerService.selectionMoveStart$,this._selectionManagerService.selectionMoving$,this._selectionManagerService.selectionMoveEnd$,this._selectionManagerService.selectionSet$).pipe(x.filter(n=>!!n)).subscribe(n=>{this._syncDefinedNameRange(n)})),this.disposeWithMe(this._definedNamesService.focusRange$.subscribe(async n=>{if(n==null)return;const{unitId:i}=n;let{formulaOrRefString:e}=n;if(e.substring(0,1)===K.operatorToken.EQUALS&&(e=e.substring(1)),!K.isReferenceStrings(e))return;const r=this._instanceSrv.getUnit(i),o=await this._getSelections(r,i,e);this._selectionManagerService.setSelections(o),this._cmdSrv.executeCommand(m.ScrollToCellOperation.id,{unitId:i,range:o[0].range})}))}_syncDefinedNameRange(n){if(n.length===0)return;const i=n[n.length-1],e=this._instanceSrv.getCurrentUnitForType(a.UniverInstanceType.UNIVER_SHEET),t=e==null?void 0:e.getActiveSheet();t&&this._definedNamesService.setCurrentRange({range:i.range,unitId:e.getUnitId(),sheetId:t.getSheetId()})}async _getSelections(n,i,e){const t=e.split(",");let r=n.getActiveSheet();if(!r)return[];const o=[];for(let s=0;s<t.length;s++){const l=t[s].trim(),c=K.deserializeRangeWithSheet(l.trim());if(s===0){const u=n.getSheetBySheetName(c.sheetName);u&&r.getSheetId()!==u.getSheetId()&&(r=u,await this._cmdSrv.executeCommand(m.SetWorksheetActivateCommand.id,{subUnitId:r.getSheetId(),unitId:i}))}if(r.getName()!==c.sheetName)continue;let d=null;if(s===t.length-1){const u=c.range,{startRow:h,startColumn:g,endRow:S,endColumn:f}=u;d=m.getPrimaryForRange({startRow:h,startColumn:g,endRow:S,endColumn:f},r)}o.push({range:c.range,style:bt(this._themeService),primary:d})}return o}};yi=tI([qn(0,a.Inject(m.SheetsSelectionsService)),qn(1,a.Inject(a.ThemeService)),qn(2,a.IUniverInstanceService),qn(3,a.ICommandService),qn(4,K.IDefinedNamesService)],yi);var nI=Object.getOwnPropertyDescriptor,rI=(n,i,e,t)=>{for(var r=t>1?void 0:t?nI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},at=(n,i)=>(e,t)=>i(e,t,n);exports.FormulaEditorController=class extends a.RxDisposable{constructor(e,t,r,o,s,l,c,d,u){super();w(this,"_loadedMap",new WeakSet);w(this,"_scheduledCallback",-1);this._univerInstanceService=e,this._renderManagerService=t,this._editorBridgeService=r,this._commandService=o,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(x.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:r}=t;r===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:r}=t;r!=null&&(this._loadedMap.has(r)||this._loadedMap.add(r))}_listenFxBtnClick(){this._formulaEditorManagerService.fxBtnClick$.pipe(x.takeUntil(this.dispose$)).subscribe(()=>{var t,r;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 o=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(fe.id,{visible:!0,eventType:T.DeviceInputEventType.PointerDown,unitId:(t=o==null?void 0:o.getUnitId())!=null?t:""});const c=(r=s==null?void 0:s.getBody())==null?void 0:r.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($.CoverContentCommand.id,h),this._textSelectionManagerService.replaceDocRanges(u)}})}_syncEditorSize(){const e=this._univerInstanceService.unitAdded$.pipe(x.filter(t=>t.getUnitId()===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY));this.disposeWithMe(x.combineLatest([this._formulaEditorManagerService.position$,e]).subscribe(([t])=>{if(!t)return this._clearScheduledCallback();const r=ki(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,this._renderManagerService),o=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(r==null||o==null)return this._clearScheduledCallback();const{width:s,height:l}=t;if(s===0||l===0)return this._clearScheduledCallback();const{engine:c}=r;o.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(),r=this._renderManagerService.getRenderById(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),o=this._univerInstanceService.getUniverDocInstance(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(t==null||e==null||r==null||o==null)return;const{marginTop:s=0,marginBottom:l=0}=o.getSnapshot().documentStyle,{scene:c,mainComponent:d}=r;let{actualHeight:u}=t.getActualSize();u+=s+l;const{width:h,height:g}=e,S=c.getViewport($.VIEWPORT_KEY.VIEW_MAIN);let f=S==null?void 0:S.getScrollBar();c.transformByState({width:h,height:u}),d==null||d.resize(h,u),u>g?f==null?S&&new T.ScrollBar(S,{enableHorizontal:!1,barSize:8}):S==null||S.resetCanvasSizeAndUpdateScroll():(f=null,S==null||S.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0}),(v=S==null?void 0:S.getScrollBar())==null||v.dispose())}};exports.FormulaEditorController=rI([at(0,a.IUniverInstanceService),at(1,T.IRenderManagerService),at(2,me),at(3,a.ICommandService),at(4,a.IContextService),at(5,Cr),at(6,a.IUndoRedoService),at(7,a.Inject(_e.DocSelectionManagerService)),at(8,$.IEditorService)],exports.FormulaEditorController);var iI=Object.getOwnPropertyDescriptor,oI=(n,i,e,t)=>{for(var r=t>1?void 0:t?iI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},pt=(n,i)=>(e,t)=>i(e,t,n);const sI={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 Mi=class extends a.Disposable{constructor(n,i,e,t,r,o,s,l){super(),this._univerInstanceService=n,this._renderManagerService=i,this._editorBridgeService=e,this._commandService=t,this._rangeProtectionRuleModel=r,this._worksheetProtectionRuleModel=o,this._formulaEditorController=s,this._formulaEditorManagerService=l,this._initialize()}_initialize(){this._syncFormulaEditorContent(),this._commandExecutedListener()}_getEditorViewModel(n){var i;return(i=this._renderManagerService.getRenderById(n))==null?void 0:i.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 r,o,s;let i=a.Tools.deepClone((r=n.documentLayoutObject.documentModel)==null?void 0:r.getBody());const e=a.Tools.deepClone((o=n.documentLayoutObject.documentModel)==null?void 0:o.drawings),t=a.Tools.deepClone((s=n.documentLayoutObject.documentModel)==null?void 0:s.getDrawingsOrder());(!i||n.isInArrayFormulaRange===!0&&this._editorBridgeService.isVisible().eventType===T.DeviceInputEventType.Dblclick)&&(i={dataStream:`\r
83
83
  `,paragraphs:[{startIndex:0}],textRuns:[]}),this._syncContentAndRender(a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,i,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:r,trigger:o,isSync:s}=t;if(s||o===$.ReplaceSnapshotCommand.id)return;if(n.includes(r)){const l=this._univerInstanceService.getUnit(r,a.UniverInstanceType.UNIVER_DOC),c=r===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 i=[m.SetRangeValuesMutation.id,m.MoveRangeMutation.id];this.disposeWithMe(this._commandService.onCommandExecuted(e=>{var t,r,o,s,l,c,d;if(i.includes(e.id)){const u=this._editorBridgeService.getLatestEditCellState();if(u==null)return;let h=!1;const{row:g,column:S}=u;if(e.id===m.SetRangeValuesMutation.id&&e.params?(r=(t=e.params.cellValue)==null?void 0:t[g])!=null&&r[S]&&(h=!0):e.id===m.MoveRangeMutation.id&&e.params&&(s=(o=e.params.to.value)==null?void 0:o[g])!=null&&s[S]&&(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,i){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 r=t.with(_e.DocSkeletonManagerService).getSkeleton(),o=this._univerInstanceService.getUnit(n,a.UniverInstanceType.UNIVER_DOC),s=this._getEditorViewModel(n);o==null||s==null||(this._commandService.syncExecuteCommand(_e.RichTextEditingMutation.id,{...i,textRanges:null,isSync:!0,unitId:n,syncer:i.unitId}),s.reset(o),r.calculate(),e.includes(n)&&((l=t.mainComponent)==null||l.makeDirty()))}_syncContentAndRender(n,i,e,t){var d,u;n===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&i.paragraphs&&(i.paragraphs=this._clearParagraph(i.paragraphs));const r=[a.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY],o=(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||o==null)return;s.getSnapshot().body=i,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&&(o.calculate(),r.includes(n)&&((u=c.mainComponent)==null||u.makeDirty()),n===a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&this._formulaEditorController.autoScroll())}_checkAndSetRenderStyleConfig(n){var o;const i=n.getSnapshot(),{body:e}=i;if(i.id!==a.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)return;i.documentStyle=sI;let t=i.documentStyle.renderConfig;t==null&&(t={},i.documentStyle.renderConfig=t);const r=this._formulaEditorManagerService.getPosition();if(r){const s=r.width;i.documentStyle.pageSize={width:s,height:1/0}}((o=e==null?void 0:e.dataStream)!=null?o:"").startsWith("=")?t.isRenderStyle=a.BooleanNumber.TRUE:t.isRenderStyle=a.BooleanNumber.FALSE}_clearParagraph(n){const i=a.Tools.deepClone(n);for(const e of i)e.paragraphStyle&&(e.paragraphStyle.horizontalAlign=a.HorizontalAlign.UNSPECIFIED);return i}};Mi=oI([pt(0,a.IUniverInstanceService),pt(1,T.IRenderManagerService),pt(2,me),pt(3,a.ICommandService),pt(4,a.Inject(m.RangeProtectionRuleModel)),pt(5,a.Inject(m.WorksheetProtectionRuleModel)),pt(6,a.Inject(exports.FormulaEditorController)),pt(7,Cr)],Mi);var aI=Object.getOwnPropertyDescriptor,lI=(n,i,e,t)=>{for(var r=t>1?void 0:t?aI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Vt=(n,i)=>(e,t)=>i(e,t,n);let Pi=class extends a.Disposable{constructor(n,i,e,t,r,o,s){super(),this._commandService=n,this._formatPainterService=i,this._univerInstanceService=e,this._renderManagerService=t,this._selectionManagerService=r,this._sheetInterceptorService=o,this._injector=s,this._initialize()}_initialize(){this._addDefaultHook()}_addDefaultHook(){const n={id:"default-format-painter",priority:0,isDefaultHook:!0,onStatusChange:i=>{if(i!==ke.OFF){const e=this._collectSelectionRangeFormat();e&&this._formatPainterService.setSelectionFormat(e)}},onApply:(i,e,t,r)=>this._getUndoRedoMutationInfo(i,e,t,r)};this._formatPainterService.addHook(n)}_collectSelectionRangeFormat(){const n=this._selectionManagerService.getCurrentLastSelection(),i=n==null?void 0:n.range;if(!i)return null;const{startRow:e,endRow:t,startColumn:r,endColumn:o}=i,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 g=e;g<=t;g++)for(let S=r;S<=o;S++){const f=c.getValue(g,S);u.setValue(g,S,d.getStyleByCell(f)||{});const{isMergedMainCell:p,...v}=l.getCellInfoInMergeData(g,S);p&&h.push({startRow:v.startRow,startColumn:v.startColumn,endRow:v.endRow,endColumn:v.endColumn})}return{styles:u,merges:h}}_getUndoRedoMutationInfo(n,i,e,t){const r=this._sheetInterceptorService,o=this._univerInstanceService,{merges:s,styles:l}=t;if(!l)return{undos:[],redos:[]};const{startRow:c,startColumn:d,endRow:u,endColumn:h}=l.getDataRange(),g=u-c+1,S=h-d+1,f=e.startRow===e.endRow&&e.startColumn===e.endColumn?{startRow:e.startRow,startColumn:e.startColumn,endRow:e.startRow+g-1,endColumn:e.startColumn+S-1}:e,p=Array.from({length:f.endRow-f.startRow+1},()=>Array.from({length:f.endColumn-f.startColumn+1},()=>({}))),v=[];p.forEach((B,z)=>{B.forEach((F,Z)=>{const J=z%g+c,Q=Z%S+d,se=l.getValue(J,Q);se&&(p[z][Z].s=Object.keys(se).length>0?se:null)})}),s.forEach(B=>{const z={startRow:B.startRow-c,startColumn:B.startColumn-d,endRow:B.endRow-c,endColumn:B.endColumn-d},F=Math.max(1,Math.floor((f.endRow-f.startRow+1)/g)),Z=Math.max(1,Math.floor((f.endColumn-f.startColumn+1)/S));for(let J=0;J<F;J++)for(let Q=0;Q<Z;Q++)v.push({startRow:z.startRow+J*g+f.startRow,startColumn:z.startColumn+Q*S+f.startColumn,endRow:z.endRow+J*g+f.startRow,endColumn:z.endColumn+Q*S+f.startColumn})});const C=[f],b=new a.ObjectMatrix,R=new a.ObjectMatrix;if(a.Tools.isArray(p))for(let B=0;B<C.length;B++){const{startRow:z,startColumn:F,endRow:Z,endColumn:J}=C[B];for(let Q=0;Q<=Z-z;Q++)for(let se=0;se<=J-F;se++)b.setValue(Q+z,se+F,{s:null}),R.setValue(Q+z,se+F,p[Q][se])}const E={subUnitId:i,unitId:n,cellValue:b.getMatrix()},P={subUnitId:i,unitId:n,cellValue:R.getMatrix()},y=this._injector.invoke(m.SetRangeValuesUndoMutationFactory,E),{undos:M,redos:O}=r.onCommandExecute({id:m.SetRangeValuesCommand.id,params:{...P,range:C}}),A=m.getAddMergeMutationRangeByType(v),k=[],D=[],N=o.getUnit(n).getSheetBySheetId(i),W=Kl(N,A),H={unitId:n,subUnitId:i,ranges:A},L={unitId:n,subUnitId:i,ranges:A};k.push({id:m.RemoveWorksheetMergeMutation.id,params:H}),k.push({id:m.AddWorksheetMergeMutation.id,params:L});const U=this._injector.invoke(m.RemoveMergeUndoMutationFactory,H),j=this._injector.invoke(m.AddMergeUndoMutationFactory,L);if(D.push({id:m.RemoveWorksheetMergeMutation.id,params:j}),D.push({id:m.AddWorksheetMergeMutation.id,params:U}),W){const B=this._injector.invoke(z=>ql(z,n,N,A));k.unshift(...B.redos),D.push(...B.undos)}return{undos:[{id:m.SetRangeValuesMutation.id,params:E},{id:m.SetRangeValuesMutation.id,params:y},...M,...D],redos:[{id:m.SetRangeValuesMutation.id,params:E},{id:m.SetRangeValuesMutation.id,params:P},...O,...k]}}};Pi=lI([Vt(0,a.ICommandService),Vt(1,$e),Vt(2,a.IUniverInstanceService),Vt(3,T.IRenderManagerService),Vt(4,a.Inject(m.SheetsSelectionsService)),Vt(5,a.Inject(m.SheetInterceptorService)),Vt(6,a.Inject(a.Injector))],Pi);var cI=Object.getOwnPropertyDescriptor,dI=(n,i,e,t)=>{for(var r=t>1?void 0:t?cI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},No=(n,i)=>(e,t)=>i(e,t,n);let is=class extends a.Disposable{constructor(i,e,t,r){super();w(this,"_initialize",()=>{const i=new a.DisposableCollection;this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(()=>{i.dispose(),this._selectionRenderService.getSelectionControls().forEach(t=>{i.add(a.toDisposable(t.selectionMoveEnd$.subscribe(r=>{if(!r)return;const o=t.model.getRange(),s={startRow:o.startRow,startColumn:o.startColumn,endRow:o.endRow,endColumn:o.endColumn,rangeType:o.rangeType},l={startRow:r.startRow,startColumn:r.startColumn,endRow:r.endRow,endColumn:r.endColumn,rangeType:o.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=i,this._selectionRenderService=e,this._selectionManagerService=t,this._commandService=r,this._initialize()}};is=dI([No(1,a.Inject(Ce)),No(2,a.Inject(m.SheetsSelectionsService)),No(3,a.Inject(a.ICommandService))],is);var uI=Object.getOwnPropertyDescriptor,hI=(n,i,e,t)=>{for(var r=t>1?void 0:t?uI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},mI=(n,i)=>(e,t)=>i(e,t,n);let Oi=class extends a.Disposable{constructor(n){super(),this._sheetPermissionInitController=n,this._initPermission()}_initPermission(){this._sheetPermissionInitController.initPermission()}};Oi=hI([mI(0,a.Inject(m.SheetPermissionInitController))],Oi);var gI=Object.getOwnPropertyDescriptor,SI=(n,i,e,t)=>{for(var r=t>1?void 0:t?gI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ho=(n,i)=>(e,t)=>i(e,t,n);let os=class extends a.Disposable{constructor(n,i,e,t){super(),this._context=n,this._sheetSkeletonManagerService=i,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 i=this._sheetClipboardService.getPasteOptionsCache(),e=i==null?void 0:i.target.unitId;n.unitId===e&&this._sheetClipboardController.refreshOptionalPaste()})))}};os=SI([Ho(1,a.Inject(exports.SheetSkeletonManagerService)),Ho(2,Ue),Ho(3,a.Inject(An))],os);var fI=Object.getOwnPropertyDescriptor,pI=(n,i,e,t)=>{for(var r=t>1?void 0:t?fI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Vo=(n,i)=>(e,t)=>i(e,t,n);let ss=class extends a.Disposable{constructor(n,i,e,t){super(),this._context=n,this._contextMenuService=i,this._selectionManagerService=e,this._selectionRenderService=t,this._init()}_init(){var l,c;const i=((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 g=h.range.rangeType,S=this._selectionRenderService.getSkeleton(),p=Pe(h,S).rangeWithCoord,v=()=>{if(!p)return!1;const b=d.offsetX,R=d.offsetY;switch(g){case a.RANGE_TYPE.ROW:return p.startY<=R&&p.endY>=R;case a.RANGE_TYPE.COLUMN:return p.startX<=b&&p.endX>=b;default:return p.startX<=b&&p.endX>=b&&p.startY<=R&&p.endY>=R}},C=b=>{this._contextMenuService.triggerContextMenu(d,b)};v()?g===a.RANGE_TYPE.COLUMN?C(I.ContextMenuPosition.COL_HEADER):g===a.RANGE_TYPE.ROW?C(I.ContextMenuPosition.ROW_HEADER):C(I.ContextMenuPosition.MAIN_AREA):C(I.ContextMenuPosition.MAIN_AREA)}});this.disposeWithMe(i);const e=this._context.components.get(ue.COLUMN),r=this._context.components.get(ue.ROW).onPointerDown$.subscribeEvent(d=>{d.button===2&&this._contextMenuService.triggerContextMenu(d,I.ContextMenuPosition.ROW_HEADER)});this.disposeWithMe(r);const s=e.onPointerDown$.subscribeEvent(d=>{d.button===2&&this._contextMenuService.triggerContextMenu(d,I.ContextMenuPosition.COL_HEADER)});this.disposeWithMe(s)}};ss=pI([Vo(1,I.IContextMenuService),Vo(2,a.Inject(m.SheetsSelectionsService)),Vo(3,Ce)],ss);var as=(n=>(n[n.NORMAL=0]="NORMAL",n[n.HIGHLIGHT=1]="HIGHLIGHT",n))(as||{});const vI="rgba(0, 0, 0, 0.15)",lt="rgb(0, 0, 0)",Jr="rgb(255, 255, 255, 1)";class CI extends T.Shape{constructor(e,t){super(e,t);w(this,"_size",12);w(this,"_iconRatio",.4);w(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&&T.Rect.drawWith(e,{width:this._size,height:this._size,radius:this._size,fill:vI});const t=this._size*.5*this._iconRatio,r=Math.PI/180*60,o=t*Math.sin(r),s=t*Math.cos(r);T.RegularPolygon.drawWith(e,{pointsGroup:[[{x:-o+this._size/2,y:-s+this._size/2},{x:o+this._size/2,y:-s+this._size/2},{x:this._size/2,y:t+this._size/2}]],fill:lt})}}var II=Object.getOwnPropertyDescriptor,_I=(n,i,e,t)=>{for(var r=t>1?void 0:t?II(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},$r=(n,i)=>(e,t)=>i(e,t,n);const bI="__SpreadsheetHeaderMenuSHAPEControllerShape__",RI="__SpreadsheetHeaderMenuMAINControllerShape__",EI="rgba(0, 0, 0, 0.1)";let ls=class extends a.Disposable{constructor(i,e,t,r,o){super();w(this,"_hoverRect");w(this,"_hoverMenu");w(this,"_currentColumn",Number.POSITIVE_INFINITY);w(this,"_headerPointerSubs");w(this,"_colHeaderPointerSubs");this._context=i,this._sheetSkeletonManagerService=e,this._contextMenuService=t,this._commandService=r,this._selectionManagerService=o,this._initialize()}dispose(){var i,e,t;(i=this._hoverRect)==null||i.dispose(),(e=this._hoverMenu)==null||e.dispose(),(t=this._headerPointerSubs)==null||t.unsubscribe(),this._headerPointerSubs=null}_initialize(){const i=this._context.scene;this._hoverRect=new T.Rect(bI,{fill:EI,evented:!1}),this._hoverMenu=new CI(RI,{zIndex:100,visible:!1}),i.addObjects([this._hoverRect,this._hoverMenu],_t),this._initialHover(0),this._initialHover(1),this._initialHoverMenu()}_initialHover(i=0){var h,g,S;const e=this._context.components.get(ue.COLUMN),t=this._context.components.get(ue.ROW),r=i===0?t:e,o=f=>{var M,O,A;const p=(M=this._sheetSkeletonManagerService.getCurrentParam())==null?void 0:M.skeleton;if(p==null)return;const{rowHeaderWidth:v,columnHeaderHeight:C}=p,{startX:b,startY:R,endX:E,endY:P,column:y}=Ke(f.offsetX,f.offsetY,this._context.scene,p);if(i===0)(O=this._hoverRect)==null||O.transformByState({width:v,height:P-R,left:0,top:R});else{if(this._currentColumn=y,(A=this._hoverRect)==null||A.transformByState({width:E-b,height:C,left:b,top:0}),this._hoverMenu==null)return;if(E-b<C*2){this._hoverMenu.hide();return}const k=C*.8;this._hoverMenu.transformByState({left:E-C,top:C/2-k/2}),this._hoverMenu.setShapeProps({size:k}),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 x.Subscription;const c=r.onPointerMove$.subscribeEvent(o),d=r.onPointerEnter$.subscribeEvent(s),u=r.onPointerLeave$.subscribeEvent(l);(h=this._headerPointerSubs)==null||h.add(c),(g=this._headerPointerSubs)==null||g.add(d),(S=this._headerPointerSubs)==null||S.add(u)}_initialHoverMenu(){this._hoverMenu!=null&&(this._hoverMenu.onPointerEnter$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:as.HIGHLIGHT,visible:!0}),this._context.scene.setCursor(T.CURSOR_TYPE.POINTER))}),this._hoverMenu.onPointerLeave$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:as.NORMAL,visible:!1}),this._context.scene.resetCursor())}),this._hoverMenu.onPointerDown$.subscribeEvent(i=>{var o;const e=this._currentColumn,t=(o=this._selectionManagerService.getCurrentSelections())==null?void 0:o.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)}i.stopPropagation(),i.preventDefault(),this._contextMenuService.triggerContextMenu(i,I.ContextMenuPosition.COL_HEADER)}))}_getSelectionOnColumn(i){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:i,endRow:t.getRowCount()-1,endColumn:i,rangeType:a.RANGE_TYPE.COLUMN},primary:{startRow:0,startColumn:i,endRow:0,endColumn:i,actualRow:0,actualColumn:i,isMerged:!1,isMergedMainCell:!1},style:null}]}}};ls=_I([$r(1,a.Inject(exports.SheetSkeletonManagerService)),$r(2,I.IContextMenuService),$r(3,a.ICommandService),$r(4,a.Inject(m.SheetsSelectionsService))],ls);var cs=(n=>(n[n.ROW=0]="ROW",n[n.COLUMN=1]="COLUMN",n))(cs||{});const er=12,wI=.4;class Ya extends T.Shape{constructor(e,t,r){super(e,t);w(this,"_size",er);w(this,"_iconRatio",wI);w(this,"_hovered",!0);w(this,"_hasPrevious",!0);w(this,"_hasNext",!0);w(this,"_unhideType");t&&this.setShapeProps(t),this.onPointerEnter$.subscribeEvent(()=>this.setShapeProps({hovered:!0})),this.onPointerLeave$.subscribeEvent(()=>this.setShapeProps({hovered:!1})),this.onPointerDown$.subscribeEvent(()=>r==null?void 0:r())}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?T.Rect.drawWith(e,{width:this._size,height:this._size,stroke:lt,fill:Jr}):T.Rect.drawWith(e,{width:this._size,height:2*this._size,stroke:lt,fill:Jr}));const t=this._size*.5*this._iconRatio,r=Math.PI/3,o=t*Math.cos(r),s=t*Math.sin(r);if(this._hasPrevious&&T.RegularPolygon.drawWith(e,{pointsGroup:[[{x:this._size/2,y:this._size/2-s},{x:this._size/2-s,y:this._size/2+o},{x:this._size/2+s,y:this._size/2+o}]],fill:lt}),this._hasNext){const l=this._hasPrevious?3:1;T.RegularPolygon.drawWith(e,{pointsGroup:[[{x:this._size/2,y:this._size*l/2+s},{x:this._size/2-s,y:this._size*l/2-o},{x:this._size/2+s,y:this._size*l/2-o}]],fill:lt})}}_drawOnCol(e){this._hovered&&(!this._hasNext||!this._hasPrevious?T.Rect.drawWith(e,{width:this._size,height:this._size,stroke:lt,fill:Jr}):T.Rect.drawWith(e,{width:2*this._size,height:this._size,stroke:lt,fill:Jr}));const t=this._size*.5*this._iconRatio,r=Math.PI/3,o=t*Math.cos(r),s=t*Math.sin(r);if(this._hasPrevious&&T.RegularPolygon.drawWith(e,{pointsGroup:[[{x:-o+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:lt}),this._hasNext){const l=this._hasPrevious?3:1;T.RegularPolygon.drawWith(e,{pointsGroup:[[{x:o+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:lt})}}}var TI=Object.getOwnPropertyDescriptor,yI=(n,i,e,t)=>{for(var r=t>1?void 0:t?TI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ga=(n,i)=>(e,t)=>i(e,t,n);const Za="__SpreadsheetHeaderUnhideSHAPEControllerShape__";let ds=class extends a.RxDisposable{constructor(i,e,t){super();w(this,"_shapes",{cols:[],rows:[]});this._context=i,this._sheetSkeletonManagerService=e,this._commandService=t,this._init()}get _workbook(){return this._context.unit}dispose(){super.dispose(),this._clearShapes()}_init(){let i="";this._context.unit.activeSheet$.pipe(x.takeUntil(this.dispose$)).subscribe(e=>{if(this._clearShapes(),!e){i="";return}i=e.getSheetId(),this._update(this._workbook,e)}),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(e=>{if(e){const{unitId:t,sheetId:r}=e;if(t===this._workbook.getUnitId()&&r===i){const o=this._workbook.getSheetBySheetId(r);o&&this._update(this._workbook,o)}}}))}_update(i,e){var g;const t=(g=this._sheetSkeletonManagerService.getSkeletonParam(e.getSheetId()))==null?void 0:g.skeleton;if(!t)return;const r=e.getHiddenRows(),o=e.getHiddenCols(),s=this._getSheetObject(),{scene:l}=s,c=e.getRowCount(),d=r.map(S=>{const{startRow:f,endRow:p}=S,v=zo(f,0,l,t),C=f!==0,b=p!==c-1;return new Ya(Za,{type:cs.ROW,hovered:!1,hasPrevious:C,hasNext:b,top:v.startY-(C?er:0),left:v.startX-er},()=>this._commandService.executeCommand(m.SetSpecificRowsVisibleCommand.id,{unitId:i.getUnitId(),subUnitId:e.getSheetId(),ranges:[S]}))}),u=e.getColumnCount(),h=o.map(S=>{const{startColumn:f,endColumn:p}=S,v=zo(0,f,l,t),C=f!==0,b=p!==u-1;return new Ya(Za,{type:cs.COLUMN,hovered:!1,hasPrevious:C,hasNext:b,top:20-er,left:v.startX-(C?er:0)},()=>this._commandService.executeCommand(m.SetSpecificColsVisibleCommand.id,{unitId:i.getUnitId(),subUnitId:e.getSheetId(),ranges:[S]}))});l.addObjects(h,Ys),l.addObjects(d,Ys),this._clearShapes(),this._shapes={cols:h,rows:d}}_clearShapes(){this._shapes.cols.forEach(i=>i.dispose()),this._shapes.rows.forEach(i=>i.dispose()),this._shapes={cols:[],rows:[]}}_getSheetObject(){return Ye(this._workbook,this._context)}};ds=yI([Ga(1,a.Inject(exports.SheetSkeletonManagerService)),Ga(2,a.ICommandService)],ds);var MI=Object.getOwnPropertyDescriptor,PI=(n,i,e,t)=>{for(var r=t>1?void 0:t?MI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Ka=(n,i)=>(e,t)=>i(e,t,n);let us=class extends a.Disposable{constructor(n,i,e){super(),this._context=n,this._sheetSkeletonManagerService=i,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:i}=this._context,{skeleton:e}=n,t=(u=this._renderManagerService.getRenderById(i))==null?void 0:u.scene;if(e==null||t==null)return;const{rowTotalHeight:r,columnTotalWidth:o,rowHeaderWidthAndMarginLeft:s,columnHeaderHeightAndMarginTop:l}=e;this._context.unit.getActiveSheet()&&(t==null||t.transformByState({width:s+o,height:l+r}))}};us=PI([Ka(1,a.Inject(exports.SheetSkeletonManagerService)),Ka(2,T.IRenderManagerService)],us);var OI=Object.getOwnPropertyDescriptor,xI=(n,i,e,t)=>{for(var r=t>1?void 0:t?OI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},vt=(n,i)=>(e,t)=>i(e,t,n);exports.SheetSelectionRenderService=class extends gs{constructor(e,t,r,o,s,l,c,d,u){super(t,r,o,l,u);w(this,"_workbookSelections");w(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:r,spreadsheet:o,spreadsheetLeftTopPlaceholder:s}=e,{scene:l}=this._context;this.disposeWithMe(o==null?void 0:o.onPointerDown$.subscribeEvent((c,d)=>{this.isSelectionDisabled()||this.inRefSelectionMode()||(this._onPointerDown(c,o.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}=Ke(c.offsetX,c.offsetY,l,u);Gl(this._workbookSelections.getCurrentSelections(),h)||(this._onPointerDown(c,(o.zIndex||1)+1,a.RANGE_TYPE.ROW,this._getActiveViewport(c),T.ScrollTimerType.Y),c.button!==2&&d.stopPropagation())})),this.disposeWithMe(r==null?void 0:r.onPointerDown$.subscribeEvent((c,d)=>{if(this.isSelectionDisabled()||this.inRefSelectionMode())return;const u=this._sheetSkeletonManagerService.getCurrentParam().skeleton,{column:h}=Ke(c.offsetX,c.offsetY,l,u);Zl(this._workbookSelections.getCurrentSelections(),h)||(this._onPointerDown(c,(o.zIndex||1)+1,a.RANGE_TYPE.COLUMN,this._getActiveViewport(c),T.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=Ss(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(x.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 r=e[t];r.style=bt(this._selectionTheme)}this.resetSelectionsByModelData(e)}showSelection(){const e=this._themeService.getCurrentTheme();this.setSelectionTheme(e);const t=this._workbookSelections.getCurrentSelections();for(let r=0;r<t.length;r++){const o=t[r];o.style&&(o.style=bt(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(x.startWith(!1),x.distinctUntilChanged()).subscribe(e=>{e&&this._reset()})),this.disposeWithMe(this._contextService.subscribeContextValue$(m.SELECTIONS_ENABLED).pipe(x.startWith(!0),x.distinctUntilChanged()).subscribe(e=>{var t;e?this._renderDisposable=a.toDisposable(this.selectionMoveEnd$.subscribe(r=>{this._updateSelections(r,m.SelectionMoveType.MOVE_END)})):((t=this._renderDisposable)==null||t.dispose(),this._renderDisposable=null,this._reset())}))}_updateSelections(e,t){const r=this._context.unit,o=r.getUnitId(),s=r.getActiveSheet().getSheetId();if(e.length===0)return;const l=e.map(c=>m.convertSelectionDataToRange(c));this._commandService.executeCommand(m.SetSelectionsOperation.id,{unitId:o,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:r,skeleton:o}=e,{scene:s}=this._context,l=s.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN),c=(h=(u=this._skeleton)==null?void 0:u.worksheet)==null?void 0:h.getSheetId();if(this._changeRuntime(o,s,l),c!==o.worksheet.getSheetId()){const g=this._workbookSelections.getCurrentSelections();this._commandService.syncExecuteCommand(m.SetSelectionsOperation.id,{unitId:t,subUnitId:r,selections:g.length!==0?g:[Vi(o)]})}const d=this._workbookSelections.getCurrentSelections();d!=null&&this.resetSelectionsByModelData(d)}))}_getActiveViewport(e){const t=this._getSheetObject();return t==null?void 0:t.scene.getActiveViewportByCoord(T.Vector2.FromArray([e.offsetX,e.offsetY]))}_getSheetObject(){return Ye(this._context.unit,this._context)}_onPointerDown(e,t=0,r=a.RANGE_TYPE.NORMAL,o,s=T.ScrollTimerType.ALL){var D,N;this._rangeType=r;const l=this._skeleton,c=this._scene;if(!c||!l)return;o&&(this._activeViewport=o);const{offsetX:d,offsetY:u}=e,h=c.getViewport(T.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!h)return;const g=c.getCoordRelativeToViewport(T.Vector2.FromArray([d,u])),{x:S,y:f}=g;this._startViewportPosX=S,this._startViewportPosY=f;const p=c.getScrollXYInfoByViewport(g),{scaleX:v,scaleY:C}=c.getAncestorScale(),b=this._skeleton.getCellByOffset(S,f,v,C,p);if(!b)return;switch(r){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 R={range:b,primary:b,style:null};R.range.rangeType=r;const E=Pe(R,this._skeleton);this._startRangeWhenPointerDown={...E.rangeWithCoord};let P=this.getActiveSelectionControl();const y={...E.rangeWithCoord,rangeType:r},M=this.getSelectionControls();for(const W of M)if(e.button===2&&a.Rectangle.contains(W.model,y)){P=W;return}this._checkClearPreviousControls(e);const O=P==null?void 0:P.model.currentCell,A=e.shiftKey&&O,k=this._remainLastEnabled&&!e.ctrlKey&&!e.shiftKey&&!this._skipLastEnabled&&!this._singleSelectionEnabled;A&&O?this._makeSelectionByTwoCells(O,y,l,r,P):k&&P?P.updateRangeBySelectionWithCoord(E):P=this.newSelectionControl(c,l,R);for(let W=0;W<this.getSelectionControls().length-1;W++)this.getSelectionControls()[W].clearHighlight();c.disableObjectsEvent(),this._clearUpdatingListeners(),this._addEndingListeners(),(D=c.getTransformer())==null||D.clearSelectedObjects(),this._setupPointerMoveListener(h,P,r,s,S,f),this._escapeShortcutDisposable=this._shortcutService.forceEscape(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._scenePointerUpSub=c.onPointerUp$.subscribeEvent(()=>{var W;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(W=this._escapeShortcutDisposable)==null||W.dispose(),this._escapeShortcutDisposable=null}),(N=this._scene.getEngine())==null||N.setCapture()}};exports.SheetSelectionRenderService=xI([vt(1,a.Inject(a.Injector)),vt(2,a.Inject(a.ThemeService)),vt(3,I.IShortcutService),vt(4,a.Inject(m.SheetsSelectionsService)),vt(5,a.Inject(exports.SheetSkeletonManagerService)),vt(6,a.ILogService),vt(7,a.ICommandService),vt(8,a.IContextService)],exports.SheetSelectionRenderService);var AI=Object.defineProperty,kI=Object.getOwnPropertyDescriptor,DI=(n,i,e)=>i in n?AI(n,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[i]=e,NI=(n,i,e,t)=>{for(var r=t>1?void 0:t?kI(i,e):i,o=n.length-1,s;o>=0;o--)(s=n[o])&&(r=s(r)||r);return r},Qn=(n,i)=>(e,t)=>i(e,t,n),md=(n,i,e)=>DI(n,typeof i!="symbol"?i+"":i,e);exports.UniverSheetsUIPlugin=class extends a.Plugin{constructor(i=Fo,e,t,r,o,s){super(),this._config=i,this._injector=e,this._renderManagerService=t,this._configService=r,this._univerInstanceService=o,this._componentManager=s;const{menu:l,...c}=a.merge({},Fo,this._config),{customComponents:d=new Set}=c;c.protectedRangeShadow===!1&&d.add(Zi),c.protectedRangeUserSelector&&(d.add(Mn),this._componentManager.register(Mn,c.protectedRangeUserSelector.component,{framework:c.protectedRangeUserSelector.framework})),l&&this._configService.setConfig("menu",l,{merge:!0}),this._configService.setConfig(Xe,{...c,customComponents:d})}onStarting(){a.registerDependencies(this._injector,a.mergeOverrideWithDependencies([[bn],[me,{useClass:exports.EditorBridgeService}],[Ue,{useClass:exports.SheetClipboardService}],[qt,{useClass:fl}],[$e,{useClass:ui}],[vr,{useClass:rl}],[Cr,{useClass:ch}],[m.IRefSelectionsService,{useClass:m.RefSelectionsService}],[wt,{useClass:exports.AutoFillService}],[zs],[Ir,{useClass:ys}],[Qt,{useClass:exports.MarkSelectionService}],[exports.HoverManagerService],[exports.DragManagerService],[exports.SheetCanvasPopManagerService],[exports.CellAlertManagerService],[vs],[js,{useClass:exports.SheetCellDropdownManagerService}],[exports.SheetCellEditorResizeService],[dr],[exports.AutoHeightController],[exports.AutoWidthController],[exports.FormulaEditorController],[exports.SheetsRenderService],[exports.SheetUIController],[exports.StatusBarController],[exports.AutoFillController],[Pi],[yi],[Mi],[Ti],[exports.EditingRenderController],[Pn],[Oi],[Mt],[ur],[exports.SheetPermissionCheckUIController],[hr]],this._config.override))}onReady(){this._config.disableAutoFocus||this._initAutoFocus(),a.registerDependencies(this._injector,[[An]]),this._registerRenderBasics(),a.touchDependencies(this._injector,[[exports.SheetUIController],[exports.SheetsRenderService],[dr],[exports.SheetPermissionCheckUIController],[Oi]])}onRendered(){this._registerRenderModules(),a.touchDependencies(this._injector,[[hr],[Pn],[An],[exports.FormulaEditorController],[yi],[exports.StatusBarController],[exports.AutoHeightController],[exports.AutoWidthController],[Mi],[Ti],[exports.EditingRenderController]])}onSteady(){a.touchDependencies(this._injector,[[Pi],[exports.AutoFillController],[ur]])}_registerRenderBasics(){[[exports.SheetSkeletonManagerService],[us],[exports.SheetRenderController],[Ce,{useClass:exports.SheetSelectionRenderService}]].forEach(i=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,i))})}_registerRenderModules(){var r;const i=[[exports.HeaderMoveRenderController],[ds],[exports.HeaderResizeRenderController],[exports.SheetScrollManagerService],[exports.SheetsScrollRenderController],[exports.HeaderFreezeRenderController],[or],[Ei],[os],[Si],[fi],[vi],[exports.HoverRenderController],[exports.DragRenderController],[pi],[exports.CellCustomRenderController],[ss],[is],[li],[Ii],[_i],[bi],[Ri]],e=this._configService.getConfig(I.UI_PLUGIN_CONFIG_KEY);((r=e==null?void 0:e.contextMenu)!=null?r:!0)&&i.push([ls]),i.forEach(o=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(a.UniverInstanceType.UNIVER_SHEET,o))})}_initAutoFocus(){const i=this._univerInstanceService;this.disposeWithMe(i.getCurrentTypeOfUnit$(a.UniverInstanceType.UNIVER_SHEET).pipe(he.filter(e=>!!e)).subscribe(e=>i.focusUnit(e.getUnitId())))}};md(exports.UniverSheetsUIPlugin,"pluginName","SHEET_UI_PLUGIN");md(exports.UniverSheetsUIPlugin,"type",a.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsUIPlugin=NI([a.DependentOn(m.UniverSheetsPlugin),Qn(1,a.Inject(a.Injector)),Qn(2,T.IRenderManagerService),Qn(3,a.IConfigService),Qn(4,a.IUniverInstanceService),Qn(5,a.Inject(I.ComponentManager))],exports.UniverSheetsUIPlugin);const gd="embedding_formula_editor",HI=n=>n.includes(gd);function VI(n,i,e,t){const{from:r,to:o}=e,{column:s,columnOffset:l,row:c,rowOffset:d}=r,{column:u,columnOffset:h,row:g,rowOffset:S}=o,f=t.ensureSkeleton(i);if(f==null)throw new Error("No current skeleton");const p=Cn(f,{startColumn:s,endColumn:s,startRow:c,endRow:c}),v=Cn(f,{startColumn:u,endColumn:u,startRow:g,endRow:g}),{startX:C,startY:b}=p,{startX:R,startY:E}=v,P=T.precisionTo(C+l,1),y=T.precisionTo(b+d,1);let M=T.precisionTo(R+h-P,1),O=T.precisionTo(E+S-y,1);return p.startX===v.endX&&(M=0),p.startY===v.endY&&(O=0),{unitId:n,subUnitId:i,left:P,top:y,width:M,height:O}}function WI(n,i,e,t,r,o,s){const{column:l,columnOffset:c,row:d,rowOffset:u}=e,h=s.ensureSkeleton(i);if(h==null)throw new Error("No current skeleton");const g=Cn(h,{startColumn:l,endColumn:l,startRow:d,endRow:d}),{startX:S,startY:f}=g,p=T.precisionTo(S+c,1),v=T.precisionTo(f+u,1),C=o.getCellWithCoordByOffset(p+t,v+r,h);if(C==null)throw new Error("No end selection cell");const b={column:C.actualColumn,columnOffset:T.precisionTo(p+t-C.startX,1),row:C.actualRow,rowOffset:T.precisionTo(v+r-C.startY,1)};return{unitId:n,subUnitId:i,sheetTransform:{from:{column:l,columnOffset:c,row:d,rowOffset:u},to:b},transform:{left:p,top:v,width:t,height:r}}}exports.AFFECT_LAYOUT_STYLES=ps;exports.APPLY_TYPE=le;exports.AddRangeProtectionFromContextMenuCommand=Ut;exports.AddRangeProtectionFromSheetBarCommand=Dr;exports.AddRangeProtectionFromToolbarCommand=kr;exports.ApplyFormatPainterCommand=Tr;exports.AutoClearContentCommand=_n;exports.AutoFillCommand=Ct;exports.BaseSelectionRenderService=gs;exports.COPY_TYPE=ct;exports.CellAlertType=vn;exports.CellEditorManagerService=rl;exports.ChangeSheetProtectionFromSheetBarCommand=Lr;exports.ChangeZoomRatioCommand=kn;exports.DATA_TYPE=be;exports.DeleteRangeMoveLeftConfirmCommand=Ln;exports.DeleteRangeMoveUpConfirmCommand=Gt;exports.DeleteRangeProtectionFromContextMenuCommand=Ft;exports.DeleteWorksheetProtectionFormSheetBarCommand=Wr;exports.EMBEDDING_FORMULA_EDITOR=gd;exports.EMBEDDING_FORMULA_EDITOR_COMPONENT_KEY=Di;exports.ExpandSelectionCommand=De;exports.FONT_FAMILY_COMPONENT=zi;exports.FONT_FAMILY_ITEM_COMPONENT=Xi;exports.FONT_SIZE_COMPONENT=Yi;exports.FormatPainterStatus=ke;exports.FormulaBar=Sl;exports.HideColConfirmCommand=br;exports.HideRowConfirmCommand=_r;exports.IAutoFillService=wt;exports.ICellEditorManagerService=vr;exports.IEditorBridgeService=me;exports.IFormatPainterService=$e;exports.IFormulaEditorManagerService=Cr;exports.IMarkSelectionService=Qt;exports.ISheetCellDropdownManagerService=js;exports.ISheetClipboardService=Ue;exports.ISheetSelectionRenderService=Ce;exports.IStatusBarService=Ir;exports.InsertRangeMoveDownConfirmCommand=Zt;exports.InsertRangeMoveRightConfirmCommand=Un;exports.JumpOver=Qe;exports.MobileSheetBar=$c;exports.MoveSelectionCommand=xe;exports.MoveSelectionEnterAndTabCommand=Je;exports.PASTE_SPECIAL_MENU_ID=rr;exports.PREDEFINED_HOOK_NAME=Se;exports.RANGE_SELECTOR_COMPONENT_KEY=hs;exports.RANGE_SELECTOR_SYMBOLS=Dl;exports.RefillCommand=Sr;exports.RemoveColConfirmCommand=xn;exports.RemoveRowConfirmCommand=On;exports.RemoveSheetConfirmCommand=Hr;exports.RenameSheetOperation=Ur;exports.RenderSheetContent=_l;exports.RenderSheetFooter=Cl;exports.RenderSheetHeader=Il;exports.ResetRangeTextColorCommand=Ns;exports.ResetScrollCommand=Tu;exports.SELECTION_SHAPE_DEPTH=ms;exports.SHEET_UI_PLUGIN_NAME=xd;exports.SHEET_VIEW_KEY=ue;exports.ScrollCommand=Fe;exports.ScrollToCellCommand=_s;exports.ScrollToRangeOperation=bs;exports.SelectAllCommand=pr;exports.SelectionControl=mr;exports.SelectionShape=mr;exports.SelectionShapeExtension=qa;exports.SetActivateCellEditOperation=Bi;exports.SetCellEditVisibleArrowOperation=Yt;exports.SetCellEditVisibleOperation=fe;exports.SetCellEditVisibleWithF2Operation=fr;exports.SetColumnFrozenCommand=Mr;exports.SetColumnHeaderHeightCommand=Hi;exports.SetFormatPainterOperation=wr;exports.SetInfiniteFormatPainterCommand=ji;exports.SetOnceFormatPainterCommand=Nn;exports.SetRangeBoldCommand=Jt;exports.SetRangeFontFamilyCommand=Er;exports.SetRangeFontSizeCommand=Rr;exports.SetRangeItalicCommand=$t;exports.SetRangeProtectionFromContextMenuCommand=jt;exports.SetRangeStrickThroughCommand=tn;exports.SetRangeSubscriptCommand=ks;exports.SetRangeSuperscriptCommand=Ds;exports.SetRangeTextColorCommand=yn;exports.SetRangeUnderlineCommand=en;exports.SetRowFrozenCommand=yr;exports.SetRowHeaderWidthCommand=Ni;exports.SetScrollOperation=Be;exports.SetScrollRelativeCommand=Rn;exports.SetSelectionFrozenCommand=ht;exports.SetWorksheetColAutoWidthCommand=Pr;exports.SetZoomRatioCommand=Dn;exports.SetZoomRatioOperation=Le;exports.SheetBar=pl;exports.SheetCopyCommand=je;exports.SheetCutCommand=Fi;exports.SheetMenuPosition=Xl;exports.SheetPasteBesidesBorderCommand=fn;exports.SheetPasteColWidthCommand=Lt;exports.SheetPasteCommand=ze;exports.SheetPasteFormatCommand=Sn;exports.SheetPasteShortKeyCommand=di;exports.SheetPasteValueCommand=gn;exports.SheetPermissionOpenDialogOperation=Ls;exports.SheetPermissionOpenPanelOperation=qe;exports.SheetPermissionUserManagerService=Mt;exports.SheetPrintInterceptorService=zs;exports.SheetsUIMenuSchema=uc;exports.SheetsUIPart=fs;exports.ShowMenuListCommand=Vr;exports.SidebarDefinedNameOperation=Ui;exports.StatusBarService=ys;exports.UNIVER_SHEET_PERMISSION_BACKGROUND=Zi;exports.UNIVER_SHEET_PERMISSION_USER_PART=Mn;exports.ViewSheetPermissionFromContextMenuCommand=Bt;exports.ViewSheetPermissionFromSheetBarCommand=Nr;exports.attachPrimaryWithCoord=ir;exports.attachRangeWithCoord=Cn;exports.attachSelectionWithCoord=Pe;exports.calculateDocSkeletonRects=Qc;exports.checkInHeaderRanges=lr;exports.convertPositionCellToSheetOverGrid=WI;exports.convertPositionSheetOverGridToAbsolute=VI;exports.deriveStateFromActiveSheet$=Re;exports.discreteRangeToRange=Rt;exports.functionDisplayNames=ti;exports.genNormalSelectionStyle=bt;exports.genSelectionByRange=Qa;exports.getAllSelection=Ss;exports.getAutoFillRepeatRange=Zd;exports.getCellRealRange=Ql;exports.getCoordByCell=zo;exports.getCoordByOffset=Ke;exports.getCurrentExclusiveRangeInterest$=Fl;exports.getCurrentRangeDisable$=te;exports.getCustomRangePosition=bp;exports.getEditingCustomRangePosition=Rp;exports.getEditorObject=ki;exports.getMatrixPlainText=Ll;exports.getObservableWithExclusiveRange$=nn;exports.getRepeatRange=lg;exports.getSheetObject=Ye;exports.getTopLeftSelectionOfCurrSheet=Vi;exports.getTransformCoord=nr;exports.isEmbeddingFormulaEditor=HI;exports.isRangeSelector=Nl;exports.mergeSetRangeValues=Qo;exports.useActiveWorkbook=Et;exports.useActiveWorksheet=Pd;exports.useHighlightRange=Yc;exports.useWorkbooks=Od;exports.virtualizeDiscreteRanges=Kt;exports.whenFormulaEditorActivated=Rm;exports.whenSheetEditorFocused=ae;