@univerjs/sheets-ui 0.4.0 → 0.4.1

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
@@ -22,4 +22,4 @@
22
22
  `)||(dataStream+=`\r
23
23
  `);const paragraphs=[];for(let i=0;i<dataStream.length;i++)dataStream[i]==="\r"&&paragraphs.push({startIndex:i});return{dataStream,paragraphs,sectionBreaks:[{startIndex:dataStream.indexOf(`
24
24
  `)}]}}__name(generateBody,"generateBody");var __defProp$x=Object.defineProperty,__getOwnPropDesc$x=Object.getOwnPropertyDescriptor,__decorateClass$x=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$x(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$x(target,key,result),result},"__decorateClass$x"),__decorateParam$x=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$x"),_a25;let SheetClipboardController=(_a25=class extends core.RxDisposable{constructor(_injector,_currentUniverSheet,_renderManagerService,_commandService,_contextService,_configService,_sheetClipboardService,_messageService,_localService){var _a61;super(),this._injector=_injector,this._currentUniverSheet=_currentUniverSheet,this._renderManagerService=_renderManagerService,this._commandService=_commandService,this._contextService=_contextService,this._configService=_configService,this._sheetClipboardService=_sheetClipboardService,this._messageService=_messageService,this._localService=_localService,this._init(),this._initCommandListener();const docSelectionRenderService=(_a61=this._renderManagerService.getRenderById(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY))==null?void 0:_a61.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&docSelectionRenderService.onPaste$.pipe(rxjs.takeUntil(this.dispose$)).subscribe(config=>{var _a62,_b;if(!whenSheetEditorFocused(this._contextService))return;config.event.preventDefault();const clipboardEvent=config.event,htmlContent=(_a62=clipboardEvent.clipboardData)==null?void 0:_a62.getData("text/html"),textContent=(_b=clipboardEvent.clipboardData)==null?void 0:_b.getData("text/plain");this._commandService.executeCommand(SheetPasteShortKeyCommand.id,{htmlContent,textContent})})}_init(){[SheetCopyCommand,SheetCutCommand,SheetPasteCommand].forEach(command=>this.disposeWithMe(this._commandService.registerMultipleCommand(command))),[SheetPasteValueCommand,SheetPasteFormatCommand,SheetPasteColWidthCommand,SheetPasteBesidesBorderCommand,SheetPasteShortKeyCommand].forEach(command=>this.disposeWithMe(this._commandService.registerCommand(command))),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initCopyingHooks())),this.disposeWithMe(this._sheetClipboardService.addClipboardHook(this._initPastingHook()));const disposables=this._initSpecialPasteHooks().map(hook=>this._sheetClipboardService.addClipboardHook(hook));this.disposeWithMe({dispose:__name(()=>disposables.forEach(d=>d.dispose()),"dispose")})}_initCopyingHooks(){const self=this;let currentSheet=null;return{id:PREDEFINED_HOOK_NAME.DEFAULT_COPY,isDefaultHook:!0,onBeforeCopy(unitId,subUnitId){currentSheet=self._getWorksheet(unitId,subUnitId)},onCopyCellContent(row,col){var _a61,_b,_c,_d;const cell=currentSheet.getCell(row,col);return(_b=(_a61=cell==null?void 0:cell.p)==null?void 0:_a61.body)!=null&&_b.paragraphs||(_d=(_c=cell==null?void 0:cell.p)==null?void 0:_c.body)!=null&&_d.textRuns?core.convertBodyToHtml(cell.p.body):cell?core.extractPureTextFromCell(cell):""},onCopyCellStyle:__name((row,col,rowSpan,colSpan)=>{const properties={};(rowSpan||colSpan)&&(properties.rowspan=`${rowSpan||1}`,properties.colspan=`${colSpan||1}`);const range=currentSheet.getRange(row,col),mergedCellByRowCol=currentSheet.getMergedCell(row,col),textStyle=range.getTextStyle();let style="";if(textStyle&&(style=core.handleStyleToString(textStyle)),mergedCellByRowCol){const endRow=mergedCellByRowCol.endRow,endColumn=mergedCellByRowCol.endColumn,lastTextStyle=currentSheet.getRange(endRow,endColumn).getTextStyle();if(lastTextStyle){const lastStyle=core.handleStyleToString(lastTextStyle);style?style+=lastStyle?`;${lastStyle}`:"":style=lastStyle}}return style&&(properties.style=style),properties},"onCopyCellStyle"),onCopyColumn(col){return{width:`${currentSheet.getColumnWidth(col)}`}},onCopyRow(row){return{style:`height: ${currentSheet.getRowHeight(row)}px;`}},onAfterCopy(){currentSheet=null},getFilteredOutRows(range){var _a61;const{startRow,endRow}=range,worksheet=(_a61=self._currentUniverSheet.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_a61.getActiveSheet(),res=[];if(!worksheet)return res;for(let r2=startRow;r2<=endRow;r2++)worksheet.getRowFiltered(r2)&&res.push(r2);return res}}}_initPastingHook(){const self=this;let unitId=null,subUnitId=null,currentSheet=null;return{id:PREDEFINED_HOOK_NAME.DEFAULT_PASTE,isDefaultHook:!0,onBeforePaste({unitId:unitId_,subUnitId:subUnitId_,range}){currentSheet=self._getWorksheet(unitId_,subUnitId_),unitId=unitId_,subUnitId=subUnitId_;const maxConfig=self._configService.getConfig(sheets.MAX_CELL_PER_SHEET_KEY),endRow=range.rows[range.rows.length-1],endColumn=range.cols[range.cols.length-1];return maxConfig&&endRow*endColumn>maxConfig?(self._messageService.show({type:design.MessageType.Error,content:self._localService.t("clipboard.paste.exceedMaxCells")}),!1):!0},onPasteRows(pasteTo,rowProperties){const{range}=pasteTo,redoMutations=[],undoMutations=[],maxRow=currentSheet.getMaxRows(),rowCount=maxRow-1,addingRowsCount=range.rows[range.rows.length-1]-rowCount,existingRowsCount=rowProperties.length-addingRowsCount,rowManager=currentSheet.getRowManager();if(addingRowsCount>0){const rowInfo={};rowProperties.slice(existingRowsCount).forEach((property,index)=>{const{height:PropertyHeight}=property||{};PropertyHeight&&(rowInfo[index]={h:Number.parseFloat(PropertyHeight),hd:core.BooleanNumber.FALSE})});const addRowRange={startColumn:range.cols[0],endColumn:range.cols[range.cols.length-1],endRow:range.rows[range.rows.length-1],startRow:maxRow},addRowMutation={unitId,subUnitId,range:addRowRange,rowInfo};redoMutations.push({id:sheets.InsertRowMutation.id,params:addRowMutation}),undoMutations.push({id:sheets.RemoveRowMutation.id,params:{unitId,subUnitId,range:addRowRange}})}const rowHeight={},originRowHeight={};if(rowProperties.slice(0,existingRowsCount).forEach((property,index)=>{var _a61,_b;const{height:propertyHeight}=property;if(propertyHeight){const rowConfigBeforePaste=rowManager.getRow(range.rows[0]+index),willSetHeight=Number.parseFloat(propertyHeight);if(rowConfigBeforePaste){const{h=core.DEFAULT_WORKSHEET_ROW_HEIGHT,ah=0}=rowConfigBeforePaste,nowRowHeight=Math.max(h,ah);willSetHeight>nowRowHeight?(rowHeight[index+range.rows[0]]=willSetHeight,originRowHeight[index+range.rows[0]]=nowRowHeight):(rowHeight[index+range.rows[0]]=nowRowHeight,originRowHeight[index+range.rows[0]]=nowRowHeight)}else rowHeight[index+range.rows[0]]=willSetHeight,originRowHeight[index+range.rows[0]]=(_b=(_a61=rowManager.getRow(range.rows[0]+index))==null?void 0:_a61.h)!=null?_b:core.DEFAULT_WORKSHEET_ROW_HEIGHT}}),Object.keys(rowHeight).length){const setRowPropertyMutation={unitId,subUnitId,ranges:[{startRow:range.rows[0],endRow:Math.min(range.rows[range.rows.length-1],maxRow),startColumn:range.cols[0],endColumn:range.cols[range.cols.length-1]}],rowHeight};redoMutations.push({id:sheets.SetWorksheetRowHeightMutation.id,params:setRowPropertyMutation}),undoMutations.push({id:sheets.SetWorksheetRowHeightMutation.id,params:{...setRowPropertyMutation,rowHeight:originRowHeight}})}return{redos:redoMutations,undos:undoMutations}},onPasteColumns(pasteTo,colProperties,pasteType){var _a61;const{range}=pasteTo,redoMutations=[],undoMutations=[],maxColumn=currentSheet.getMaxColumns(),colCount=maxColumn-1,addingColsCount=range.cols[range.cols.length-1]-colCount,existingColsCount=colProperties.length-addingColsCount,defaultColumnWidth=(_a61=self._configService.getConfig(core.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?_a61:core.DEFAULT_WORKSHEET_COLUMN_WIDTH,pasteToCols=range.cols,startColumn=pasteToCols[0];if(addingColsCount>0){const addColRange={startRow:range.rows[0],endRow:range.rows[range.rows.length-1],endColumn:range.cols[range.cols.length-1],startColumn:maxColumn},addColMutation={unitId,subUnitId,range:addColRange,colInfo:colProperties.slice(existingColsCount).map((property,index)=>({w:property.width?Math.max(+property.width,currentSheet.getColumnWidth(pasteToCols[index])):defaultColumnWidth,hd:core.BooleanNumber.FALSE}))};redoMutations.push({id:sheets.InsertColMutation.id,params:addColMutation}),undoMutations.push({id:sheets.RemoveColMutation.id,params:{unitId,subUnitId,range:addColRange}})}const targetSetColPropertyParams={unitId,subUnitId,ranges:[{startRow:range.rows[0],endRow:range.rows[range.rows.length-1],startColumn:range.cols[0],endColumn:Math.min(range.cols[range.cols.length-1],maxColumn)}]};if(colProperties.length>0){const setColPropertyMutation={...targetSetColPropertyParams,colWidth:colProperties.slice(0,existingColsCount).reduce((p2,c,index)=>{var _a62;return p2[index+startColumn]=c.width?Math.max(+c.width,(_a62=currentSheet.getColumnWidth(pasteToCols[index]))!=null?_a62:defaultColumnWidth):defaultColumnWidth,p2},{})},undoSetColPropertyParams={...targetSetColPropertyParams,colWidth:colProperties.slice(0,existingColsCount).reduce((p2,c,index)=>{var _a62;return p2[index+startColumn]=(_a62=currentSheet.getColumnWidth(pasteToCols[index]))!=null?_a62:defaultColumnWidth,p2},{})};redoMutations.push({id:sheets.SetWorksheetColWidthMutation.id,params:setColPropertyMutation}),undoMutations.push({id:sheets.SetWorksheetColWidthMutation.id,params:undoSetColPropertyParams})}return{redos:redoMutations,undos:undoMutations}},onPastePlainText(pasteTo,text,payload){return self._onPastePlainText(pasteTo,text,payload)},onPasteCells(pasteFrom,pasteTo,data,payload){return self._onPasteCells(pasteFrom,pasteTo,data,payload)},onAfterPaste(success){currentSheet=null}}}_generateDocumentDataModelSnapshot(snapshot){var _a61,_b;const currentSkeleton=(_a61=this._renderManagerService.withCurrentTypeOfUnit(core.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService))==null?void 0:_a61.getCurrent();if(currentSkeleton==null)return null;const{skeleton}=currentSkeleton,documentModel=(_b=skeleton.getBlankCellDocumentModel())==null?void 0:_b.documentModel,documentData={...documentModel==null?void 0:documentModel.getSnapshot(),...snapshot};return documentModel==null||documentModel.reset(documentData),documentModel==null?void 0:documentModel.getSnapshot()}_onPastePlainText(pasteTo,text,payload){const{range,unitId,subUnitId}=pasteTo;let cellValue;if(/\r|\n/.test(text)||core.Tools.isLegalUrl(text)){const body=generateBody(text),p2=this._generateDocumentDataModelSnapshot({body});cellValue={[range.rows[0]]:{[range.cols[0]]:{p:p2}}}}else core.isFormulaString(text)?cellValue={[range.rows[0]]:{[range.cols[0]]:{f:text}}}:cellValue={[range.rows[0]]:{[range.cols[0]]:{v:text}}};const setRangeValuesParams={unitId,subUnitId,cellValue};return{redos:[{id:sheets.SetRangeValuesMutation.id,params:setRangeValuesParams}],undos:[{id:sheets.SetRangeValuesMutation.id,params:sheets.SetRangeValuesUndoMutationFactory(this._injector,setRangeValuesParams)}]}}_onPasteCells(pasteFrom,pasteTo,data,payload){return this._injector.invoke(accessor=>getDefaultOnPasteCellMutations(pasteFrom,pasteTo,data,payload,accessor))}_initSpecialPasteHooks(){const self=this,specialPasteValueHook={id:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,specialPasteInfo:{label:"specialPaste.value"},onPasteCells:__name((pasteFrom,pasteTo,data)=>this._injector.invoke(accessor=>getSetCellValueMutations(pasteTo,pasteFrom,data,accessor)),"onPasteCells")},specialPasteFormatHook={id:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,specialPasteInfo:{label:"specialPaste.format"},onPasteCells:__name((pasteFrom,pasteTo,matrix)=>{const redoMutationsInfo=[],undoMutationsInfo=[],{undos:styleUndos,redos:styleRedos}=this._injector.invoke(accessor=>getClearCellStyleMutations(pasteTo,matrix,accessor));redoMutationsInfo.push(...styleRedos),undoMutationsInfo.push(...styleUndos);const{undos:mergeUndos,redos:mergeRedos}=this._injector.invoke(accessor=>getClearAndSetMergeMutations(pasteTo,matrix,accessor));redoMutationsInfo.push(...mergeRedos),undoMutationsInfo.push(...mergeUndos);const{undos:setStyleUndos,redos:setStyleRedos}=this._injector.invoke(accessor=>getSetCellStyleMutations(pasteTo,matrix,accessor));return redoMutationsInfo.push(...setStyleRedos),undoMutationsInfo.push(...setStyleUndos),{undos:undoMutationsInfo,redos:redoMutationsInfo}},"onPasteCells")},specialPasteColWidthHook={id:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,specialPasteInfo:{label:"specialPaste.colWidth"},onPasteCells(){return{undos:[],redos:[]}},onPasteColumns(pasteTo,colProperties,payload){var _a61,_b;const workbook=self._currentUniverSheet.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),subUnitId=(_a61=workbook.getActiveSheet())==null?void 0:_a61.getSheetId();if(!unitId||!subUnitId)throw new Error("Cannot find unitId or subUnitId");const redoMutations=[],undoMutations=[],currentSheet=self._getWorksheet(unitId,subUnitId),{range}=pasteTo,pasteToCols=range.cols,startColumn=pasteToCols[0],maxColumn=currentSheet.getMaxColumns(),addingColsCount=range.cols[range.cols.length-1]-maxColumn,existingColsCount=colProperties.length-addingColsCount,defaultColumnWidth=(_b=self._configService.getConfig(core.DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY))!=null?_b:core.DEFAULT_WORKSHEET_COLUMN_WIDTH,setColPropertyMutation={unitId,subUnitId,ranges:[{startRow:range.rows[0],endRow:Math.min(range.cols[range.cols.length-1],maxColumn),startColumn:range.cols[0],endColumn:range.cols[range.cols.length-1]}],colWidth:colProperties.slice(0,existingColsCount).reduce((p2,c,index)=>{var _a62;return p2[index+startColumn]=c.width?Math.max(+c.width,(_a62=currentSheet.getColumnWidth(pasteToCols[index]))!=null?_a62:defaultColumnWidth):defaultColumnWidth,p2},{})},undoSetColPropertyMutation={unitId,subUnitId,ranges:[{startRow:range.rows[0],endRow:Math.min(range.cols[range.cols.length-1],maxColumn),startColumn:range.cols[0],endColumn:range.cols[range.cols.length-1]}],colWidth:colProperties.slice(0,existingColsCount).reduce((p2,c,index)=>{var _a62;return p2[index+startColumn]=(_a62=currentSheet.getColumnWidth(pasteToCols[index]))!=null?_a62:defaultColumnWidth,p2},{})};return redoMutations.push({id:sheets.SetWorksheetColWidthMutation.id,params:setColPropertyMutation}),undoMutations.push({id:sheets.SetWorksheetColWidthMutation.id,params:undoSetColPropertyMutation}),{redos:redoMutations,undos:undoMutations}}},specialPasteBesidesBorder={id:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_BESIDES_BORDER,specialPasteInfo:{label:"specialPaste.besidesBorder"},onPasteCells:__name((pasteFrom,pasteTo,matrix,payload)=>{self._currentUniverSheet.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);const redoMutationsInfo=[],undoMutationsInfo=[],{range,unitId,subUnitId}=pasteTo,valueMatrix=new core.ObjectMatrix;matrix.forValue((row,col,value)=>{const style=value.s;typeof style=="object"&&valueMatrix.setValue(range.rows[row],range.cols[col],{s:{...style,bd:void 0},v:value.v})});const setValuesMutation={unitId,subUnitId,cellValue:valueMatrix.getData()};redoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:setValuesMutation});const undoSetValuesMutation=this._injector.invoke(sheets.SetRangeValuesUndoMutationFactory,setValuesMutation);undoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:undoSetValuesMutation});const{undos,redos}=this._injector.invoke(accessor=>getClearAndSetMergeMutations(pasteTo,matrix,accessor));return undoMutationsInfo.push(...undos),redoMutationsInfo.push(...redos),{redos:redoMutationsInfo,undos:undoMutationsInfo}},"onPasteCells")};return[specialPasteValueHook,specialPasteFormatHook,specialPasteColWidthHook,specialPasteBesidesBorder]}_getWorksheet(unitId,subUnitId){var _a61;const worksheet=(_a61=this._currentUniverSheet.getUniverSheetInstance(unitId))==null?void 0:_a61.getSheetBySheetId(subUnitId);if(!worksheet)throw new Error(`[SheetClipboardController]: cannot find a worksheet with unitId ${unitId} and subUnitId ${subUnitId}.`);return worksheet}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{command.id===AddWorksheetMergeCommand.id&&this._sheetClipboardService.removeMarkSelection()}))}},__name(_a25,"SheetClipboardController"),_a25);SheetClipboardController=__decorateClass$x([__decorateParam$x(0,core.Inject(core.Injector)),__decorateParam$x(1,core.IUniverInstanceService),__decorateParam$x(2,engineRender.IRenderManagerService),__decorateParam$x(3,core.ICommandService),__decorateParam$x(4,core.IContextService),__decorateParam$x(5,core.IConfigService),__decorateParam$x(6,ISheetClipboardService),__decorateParam$x(7,ui.IMessageService),__decorateParam$x(8,core.Inject(core.LocaleService))],SheetClipboardController);var __defProp$w=Object.defineProperty,__getOwnPropDesc$w=Object.getOwnPropertyDescriptor,__decorateClass$w=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$w(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$w(target,key,result),result},"__decorateClass$w"),__decorateParam$w=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$w"),_a26;let SheetsDefinedNameController=(_a26=class extends core.Disposable{constructor(_selectionManagerService,_themeService,_instanceSrv,_cmdSrv,_definedNamesService){super(),this._selectionManagerService=_selectionManagerService,this._themeService=_themeService,this._instanceSrv=_instanceSrv,this._cmdSrv=_cmdSrv,this._definedNamesService=_definedNamesService,this._init()}_init(){this.disposeWithMe(rxjs.merge(this._selectionManagerService.selectionMoveStart$,this._selectionManagerService.selectionMoving$,this._selectionManagerService.selectionMoveEnd$).pipe(rxjs.filter(params=>!!params)).subscribe(params=>{this._syncDefinedNameRange(params)})),this.disposeWithMe(this._definedNamesService.focusRange$.subscribe(async item=>{if(item==null)return;const{unitId}=item;let{formulaOrRefString}=item;if(formulaOrRefString.substring(0,1)===engineFormula.operatorToken.EQUALS&&(formulaOrRefString=formulaOrRefString.substring(1)),!engineFormula.isReferenceStrings(formulaOrRefString))return;const workbook=this._instanceSrv.getUnit(unitId),selections=await this._getSelections(workbook,unitId,formulaOrRefString);this._selectionManagerService.setSelections(selections),this._cmdSrv.executeCommand(sheets.ScrollToCellOperation.id,selections[0].range)}))}_syncDefinedNameRange(params){if(params.length===0)return;const lastSelection=params[params.length-1],workbook=this._instanceSrv.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();worksheet&&this._definedNamesService.setCurrentRange({range:lastSelection.range,unitId:workbook.getUnitId(),sheetId:worksheet.getSheetId()})}async _getSelections(workbook,unitId,formulaOrRefString){const valueArray=formulaOrRefString.split(",");let worksheet=workbook.getActiveSheet();if(!worksheet)return[];const selections=[];for(let i=0;i<valueArray.length;i++){const refString=valueArray[i].trim(),unitRange=engineFormula.deserializeRangeWithSheet(refString.trim());if(i===0){const worksheetCache=workbook.getSheetBySheetName(unitRange.sheetName);worksheetCache&&worksheet.getSheetId()!==worksheetCache.getSheetId()&&(worksheet=worksheetCache,await this._cmdSrv.executeCommand(sheets.SetWorksheetActivateCommand.id,{subUnitId:worksheet.getSheetId(),unitId}))}if(worksheet.getName()!==unitRange.sheetName)continue;let primary=null;if(i===valueArray.length-1){const range=unitRange.range,{startRow,startColumn,endRow,endColumn}=range;primary=sheets.getPrimaryForRange({startRow,startColumn,endRow,endColumn},worksheet)}selections.push({range:unitRange.range,style:sheets.getNormalSelectionStyle(this._themeService),primary})}return selections}},__name(_a26,"SheetsDefinedNameController"),_a26);SheetsDefinedNameController=__decorateClass$w([__decorateParam$w(0,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$w(1,core.Inject(core.ThemeService)),__decorateParam$w(2,core.IUniverInstanceService),__decorateParam$w(3,core.ICommandService),__decorateParam$w(4,engineFormula.IDefinedNamesService)],SheetsDefinedNameController);var __defProp$v=Object.defineProperty,__getOwnPropDesc$v=Object.getOwnPropertyDescriptor,__decorateClass$v=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$v(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$v(target,key,result),result},"__decorateClass$v"),__decorateParam$v=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$v"),_a27;exports.DragManagerService=(_a27=class extends core.Disposable{constructor(_univerInstanceService,_renderManagerService){super();__publicField(this,"_currentCell$",new rxjs.Subject);__publicField(this,"currentCell$",this._currentCell$.asObservable().pipe(rxjs.distinctUntilChanged((pre,aft)=>{var _a61,_b,_c,_d,_e,_f,_g,_h;return((_a61=pre==null?void 0:pre.location)==null?void 0:_a61.unitId)===((_b=aft==null?void 0:aft.location)==null?void 0:_b.unitId)&&((_c=pre==null?void 0:pre.location)==null?void 0:_c.subUnitId)===((_d=aft==null?void 0:aft.location)==null?void 0:_d.subUnitId)&&((_e=pre==null?void 0:pre.location)==null?void 0:_e.row)===((_f=aft==null?void 0:aft.location)==null?void 0:_f.row)&&((_g=pre==null?void 0:pre.location)==null?void 0:_g.col)===((_h=aft==null?void 0:aft.location)==null?void 0:_h.col)})));__publicField(this,"_endCell$",new rxjs.Subject);__publicField(this,"endCell$",this._endCell$.asObservable());this._univerInstanceService=_univerInstanceService,this._renderManagerService=_renderManagerService,this._initCellDisposableListener()}dispose(){super.dispose(),this._currentCell$.complete(),this._endCell$.complete()}_initCellDisposableListener(){this.disposeWithMe(this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{workbook||(this._currentCell$.next(null),this._endCell$.next(null))}))}_calcActiveCell(offsetX,offsetY){const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const worksheet=workbook.getActiveSheet();if(!worksheet)return;const currentRender=this._renderManagerService.getRenderById(workbook.getUnitId());if(!currentRender)return;const skeletonParam=currentRender.with(exports.SheetSkeletonManagerService).getCurrent(),scrollInfo=currentRender.with(SheetScrollManagerService).getCurrentScrollState();if(!(!skeletonParam||!scrollInfo||!currentRender))return getHoverCellPosition(currentRender,workbook,worksheet,skeletonParam,offsetX,offsetY)}onDragOver(evt){const{offsetX,offsetY,dataTransfer}=evt,activeCell=this._calcActiveCell(offsetX,offsetY);if(!activeCell){this._currentCell$.next(null);return}const{location,position}=activeCell;this._currentCell$.next({location,position,dataTransfer})}onDrop(evt){const{offsetX,offsetY,dataTransfer}=evt,activeCell=this._calcActiveCell(offsetX,offsetY);if(!activeCell){this._endCell$.next(null);return}const{location,position}=activeCell;this._endCell$.next({location,position,dataTransfer})}},__name(_a27,"DragManagerService"),_a27);exports.DragManagerService=__decorateClass$v([__decorateParam$v(0,core.IUniverInstanceService),__decorateParam$v(1,engineRender.IRenderManagerService)],exports.DragManagerService);var __defProp$u=Object.defineProperty,__getOwnPropDesc$u=Object.getOwnPropertyDescriptor,__decorateClass$u=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$u(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$u(target,key,result),result},"__decorateClass$u"),__decorateParam$u=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$u"),_a28;exports.DragRenderController=(_a28=class extends core.Disposable{constructor(_context,_renderManagerService,_dragManagerService,_sheetSkeletonManagerService){super(),this._context=_context,this._renderManagerService=_renderManagerService,this._dragManagerService=_dragManagerService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._initDragEvent()}_initDragEvent(){const disposeSet=new core.DisposableCollection,handleSkeletonChange=__name(skeletonParam=>{if(disposeSet.dispose(),!skeletonParam)return;const{scene}=this._context,dragOverSub=scene.onDragOver$.subscribeEvent(evt=>{this._dragManagerService.onDragOver(evt)}),dropSub=scene.onDrop$.subscribeEvent(evt=>{this._dragManagerService.onDrop(evt)});disposeSet.add({dispose(){dragOverSub.unsubscribe(),dropSub.unsubscribe()}})},"handleSkeletonChange");handleSkeletonChange(this._sheetSkeletonManagerService.getCurrent()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(skeletonParam=>{handleSkeletonChange(skeletonParam)}))}},__name(_a28,"DragRenderController"),_a28);exports.DragRenderController=__decorateClass$u([__decorateParam$u(1,engineRender.IRenderManagerService),__decorateParam$u(2,core.Inject(exports.DragManagerService)),__decorateParam$u(3,core.Inject(exports.SheetSkeletonManagerService))],exports.DragRenderController);var __defProp$t=Object.defineProperty,__getOwnPropDesc$t=Object.getOwnPropertyDescriptor,__decorateClass$t=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$t(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$t(target,key,result),result},"__decorateClass$t"),__decorateParam$t=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$t"),_a29;exports.FormulaEditorController=(_a29=class extends core.RxDisposable{constructor(_univerInstanceService,_renderManagerService,_editorBridgeService,_commandService,_contextService,_formulaEditorManagerService,_undoRedoService,_textSelectionManagerService){super();__publicField(this,"_loadedMap",new WeakSet);__publicField(this,"_scheduledCallback",-1);this._univerInstanceService=_univerInstanceService,this._renderManagerService=_renderManagerService,this._editorBridgeService=_editorBridgeService,this._commandService=_commandService,this._contextService=_contextService,this._formulaEditorManagerService=_formulaEditorManagerService,this._undoRedoService=_undoRedoService,this._textSelectionManagerService=_textSelectionManagerService,this._initialize()}_initialize(){this._syncEditorSize(),this._listenFxBtnClick(),this._handleContentChange(),this._renderManagerService.currentRender$.pipe(rxjs.takeUntil(this.dispose$)).subscribe(unitId=>{this._create(unitId)}),this._create(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),this._textSelectionManagerService.textSelection$.pipe(rxjs.takeUntil(this.dispose$)).subscribe(param=>{if(param==null)return;const{unitId}=param;unitId!==core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&(this._contextService.setContextValue(core.FOCUSING_FX_BAR_EDITOR,!1),this._undoRedoService.clearUndoRedo(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY))})}_handleContentChange(){this.disposeWithMe(this._commandService.onCommandExecuted(commandInfo=>{if(commandInfo.id===docs.RichTextEditingMutation.id){const params=commandInfo.params,{unitId}=params;unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&this.autoScroll()}}))}_create(unitId){if(unitId!==core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)return;const formulaEditorDocObject=this._renderManagerService.getRenderById(unitId);if(formulaEditorDocObject==null)return;const{mainComponent:documentComponent}=formulaEditorDocObject;documentComponent!=null&&(this._loadedMap.has(documentComponent)||(this._initialMain(unitId),this._loadedMap.add(documentComponent)))}_listenFxBtnClick(){this._formulaEditorManagerService.fxBtnClick$.pipe(rxjs.takeUntil(this.dispose$)).subscribe(()=>{var _a61,_b;if(this._contextService.getContextValue(core.FOCUSING_EDITOR_BUT_HIDDEN)&&!this._contextService.getContextValue(core.EDITOR_ACTIVATED)){this._univerInstanceService.setCurrentUnitForType(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),this._contextService.setContextValue(core.FOCUSING_FX_BAR_EDITOR,!0);const currentSheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),formulaEditorDataModel=this._univerInstanceService.getUniverDocInstance(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);this._editorBridgeService.isVisible().visible===!1&&this._editorBridgeService.changeVisible({visible:!0,eventType:engineRender.DeviceInputEventType.PointerDown,unitId:(_a61=currentSheet==null?void 0:currentSheet.getUnitId())!=null?_a61:""});const content=(_b=formulaEditorDataModel==null?void 0:formulaEditorDataModel.getBody())==null?void 0:_b.dataStream;if(content==null)return;let newContent=content.startsWith("=")?content:`=${content}`;newContent=newContent.replace(/\r\n$/,"");const textRanges=[{startOffset:newContent.length,endOffset:newContent.length}],coverContentParams={unitId:core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,body:{dataStream:newContent},segmentId:""};this._commandService.executeCommand(docsUi.CoverContentCommand.id,coverContentParams),this._textSelectionManagerService.replaceDocRanges(textRanges)}})}_initialMain(unitId){const formulaEditorDocObject=this._renderManagerService.getRenderById(unitId);if(formulaEditorDocObject==null)return;const{mainComponent:documentComponent}=formulaEditorDocObject;documentComponent!=null&&this.disposeWithMe(documentComponent.onPointerDown$.subscribeEvent(()=>{this._editorBridgeService.isVisible().visible===!1&&(this._editorBridgeService.changeVisible({visible:!0,eventType:engineRender.DeviceInputEventType.Dblclick,unitId}),this._undoRedoService.clearUndoRedo(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)),this._contextService.setContextValue(core.FOCUSING_FX_BAR_EDITOR,!0)}))}_syncEditorSize(){this._formulaEditorManagerService.position$.pipe(rxjs.takeUntil(this.dispose$)).subscribe(position=>{if(!position)return this._clearScheduledCallback();const editorObject=getEditorObject(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,this._renderManagerService),formulaEditorDataModel=this._univerInstanceService.getUniverDocInstance(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(editorObject==null||formulaEditorDataModel==null)return this._clearScheduledCallback();const{width,height}=position;if(width===0||height===0)return this._clearScheduledCallback();const{engine}=editorObject;formulaEditorDataModel.updateDocumentDataPageSize(width),this.autoScroll(),this._scheduledCallback=requestIdleCallback(()=>engine.resizeBySize(width,height))})}_clearScheduledCallback(){this._scheduledCallback!==-1&&cancelIdleCallback(this._scheduledCallback),this._scheduledCallback=-1}autoScroll(){var _a61,_b;const position=this._formulaEditorManagerService.getPosition(),skeleton=(_a61=this._renderManagerService.getRenderById(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY))==null?void 0:_a61.with(docs.DocSkeletonManagerService).getSkeleton(),editorObject=this._renderManagerService.getRenderById(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY),formulaEditorDataModel=this._univerInstanceService.getUniverDocInstance(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY);if(skeleton==null||position==null||editorObject==null||formulaEditorDataModel==null)return;const{marginTop=0,marginBottom=0}=formulaEditorDataModel.getSnapshot().documentStyle,{scene,mainComponent}=editorObject;let{actualHeight}=skeleton.getActualSize();actualHeight+=marginTop+marginBottom;const{width,height}=position,viewportMain=scene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN);let scrollBar=viewportMain==null?void 0:viewportMain.getScrollBar();scene.transformByState({width,height:actualHeight}),mainComponent==null||mainComponent.resize(width,actualHeight),actualHeight>height?scrollBar==null?viewportMain&&new engineRender.ScrollBar(viewportMain,{enableHorizontal:!1,barSize:8}):viewportMain==null||viewportMain.resetCanvasSizeAndUpdateScroll():(scrollBar=null,viewportMain==null||viewportMain.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0}),(_b=viewportMain==null?void 0:viewportMain.getScrollBar())==null||_b.dispose())}},__name(_a29,"FormulaEditorController"),_a29);exports.FormulaEditorController=__decorateClass$t([__decorateParam$t(0,core.IUniverInstanceService),__decorateParam$t(1,engineRender.IRenderManagerService),__decorateParam$t(2,IEditorBridgeService),__decorateParam$t(3,core.ICommandService),__decorateParam$t(4,core.IContextService),__decorateParam$t(5,IFormulaEditorManagerService),__decorateParam$t(6,core.IUndoRedoService),__decorateParam$t(7,core.Inject(docs.DocSelectionManagerService))],exports.FormulaEditorController);var __defProp$s=Object.defineProperty,__getOwnPropDesc$s=Object.getOwnPropertyDescriptor,__decorateClass$s=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$s(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$s(target,key,result),result},"__decorateClass$s"),__decorateParam$s=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$s"),_a30;let EditorDataSyncController=(_a30=class extends core.Disposable{constructor(_univerInstanceService,_renderManagerService,_editorBridgeService,_commandService,_rangeProtectionRuleModel,_worksheetProtectionRuleModel,_formulaEditorController){super(),this._univerInstanceService=_univerInstanceService,this._renderManagerService=_renderManagerService,this._editorBridgeService=_editorBridgeService,this._commandService=_commandService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._formulaEditorController=_formulaEditorController,this._initialize()}_initialize(){this._syncFormulaEditorContent(),this._commandExecutedListener()}_getEditorViewModel(unitId){var _a61;return(_a61=this._renderManagerService.getRenderById(unitId))==null?void 0:_a61.with(docs.DocSkeletonManagerService).getViewModel()}_syncFormulaEditorContent(){this.disposeWithMe(this._editorBridgeService.currentEditCellState$.subscribe(editCellState=>{editCellState==null||this._editorBridgeService.isForceKeepVisible()||!this._rangeProtectionRuleModel.getRangeRuleInitState()||!this._worksheetProtectionRuleModel.getSheetRuleInitState()||this._editorSyncHandler(editCellState)}))}_editorSyncHandler(param){var _a61;let body=core.Tools.deepClone((_a61=param.documentLayoutObject.documentModel)==null?void 0:_a61.getBody());(!body||param.isInArrayFormulaRange===!0&&this._editorBridgeService.isVisible().eventType===engineRender.DeviceInputEventType.Dblclick)&&(body={dataStream:`\r
25
- `,paragraphs:[{startIndex:0}],textRuns:[]}),this._syncContentAndRender(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,body)}_commandExecutedListener(){const INCLUDE_LIST=[core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id===docs.RichTextEditingMutation.id||command.id===ui.SetEditorResizeOperation.id){const params=command.params,{unitId}=params;if(params.isSync)return;if(INCLUDE_LIST.includes(unitId)){const editorDocDataModel=this._univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_DOC),syncId=unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY?core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY:core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY;this._checkAndSetRenderStyleConfig(editorDocDataModel),this._syncActionsAndRender(syncId,params)}}}));const needUpdateFormulaEditorContentCommandList=[sheets.SetRangeValuesMutation.id,sheets.MoveRangeMutation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{var _a61,_b,_c,_d,_e;if(needUpdateFormulaEditorContentCommandList.includes(command.id)){const editCellState=this._editorBridgeService.getLatestEditCellState();if(editCellState==null)return;let needUpdate=!1;const{row,column}=editCellState;if(command.id===sheets.SetRangeValuesMutation.id&&command.params?(_b=(_a61=command.params.cellValue)==null?void 0:_a61[row])!=null&&_b[column]&&(needUpdate=!0):command.id===sheets.MoveRangeMutation.id&&command.params&&(_d=(_c=command.params.to.value)==null?void 0:_c[row])!=null&&_d[column]&&(needUpdate=!0),needUpdate){const body=(_e=editCellState.documentLayoutObject.documentModel)==null?void 0:_e.getBody();if(body==null)return;this._syncContentAndRender(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,core.Tools.deepClone(body))}}}))}_syncActionsAndRender(unitId,parmas){var _a61;const INCLUDE_LIST=[core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY],currentRender=this._renderManagerService.getRenderById(unitId);if(currentRender==null)return;const skeleton=currentRender.with(docs.DocSkeletonManagerService).getSkeleton(),docDataModel=this._univerInstanceService.getUniverDocInstance(unitId),docViewModel=this._getEditorViewModel(unitId);docDataModel==null||docViewModel==null||(this._commandService.syncExecuteCommand(docs.RichTextEditingMutation.id,{...parmas,isSync:!0,unitId}),docViewModel.reset(docDataModel),skeleton.calculate(),INCLUDE_LIST.includes(unitId)&&((_a61=currentRender.mainComponent)==null||_a61.makeDirty()))}_syncContentAndRender(unitId,body){var _a61,_b;unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&body.paragraphs&&(body.paragraphs=this._clearParagraph(body.paragraphs));const INCLUDE_LIST=[core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY],skeleton=(_a61=this._renderManagerService.getRenderById(unitId))==null?void 0:_a61.with(docs.DocSkeletonManagerService).getSkeleton(),docDataModel=this._univerInstanceService.getUniverDocInstance(unitId),docViewModel=this._getEditorViewModel(unitId);if(docDataModel==null||docViewModel==null||skeleton==null)return;docDataModel.getSnapshot().body=body,this._checkAndSetRenderStyleConfig(docDataModel),docViewModel.reset(docDataModel);const currentRender=this._renderManagerService.getRenderById(unitId);currentRender!=null&&(skeleton.calculate(),INCLUDE_LIST.includes(unitId)&&((_b=currentRender.mainComponent)==null||_b.makeDirty()),unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&this._formulaEditorController.autoScroll())}_checkAndSetRenderStyleConfig(documentDataModel){var _a61;const snapshot=documentDataModel.getSnapshot(),{body}=snapshot;if(snapshot.id!==core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)return;let renderConfig=snapshot.documentStyle.renderConfig;renderConfig==null&&(renderConfig={},snapshot.documentStyle.renderConfig=renderConfig),((_a61=body==null?void 0:body.dataStream)!=null?_a61:"").startsWith("=")?renderConfig.isRenderStyle=core.BooleanNumber.TRUE:renderConfig.isRenderStyle=core.BooleanNumber.FALSE}_clearParagraph(paragraphs){const newParagraphs=core.Tools.deepClone(paragraphs);for(const paragraph of newParagraphs)paragraph.paragraphStyle&&(paragraph.paragraphStyle.horizontalAlign=core.HorizontalAlign.UNSPECIFIED);return newParagraphs}},__name(_a30,"EditorDataSyncController"),_a30);EditorDataSyncController=__decorateClass$s([__decorateParam$s(0,core.IUniverInstanceService),__decorateParam$s(1,engineRender.IRenderManagerService),__decorateParam$s(2,IEditorBridgeService),__decorateParam$s(3,core.ICommandService),__decorateParam$s(4,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$s(5,core.Inject(sheets.WorksheetProtectionRuleModel)),__decorateParam$s(6,core.Inject(exports.FormulaEditorController))],EditorDataSyncController);var __defProp$r=Object.defineProperty,__getOwnPropDesc$r=Object.getOwnPropertyDescriptor,__decorateClass$r=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$r(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$r(target,key,result),result},"__decorateClass$r"),__decorateParam$r=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$r");const ALERT_KEY="SHEET_FORCE_STRING_ALERT";var _a31;let ForceStringAlertRenderController=(_a31=class extends core.Disposable{constructor(_context,_hoverManagerService,_cellAlertManagerService,_localeService){super(),this._context=_context,this._hoverManagerService=_hoverManagerService,this._cellAlertManagerService=_cellAlertManagerService,this._localeService=_localeService,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(cellPos=>{var _a61;if(cellPos){const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const cellData=worksheet.getCell(cellPos.location.row,cellPos.location.col);if((cellData==null?void 0:cellData.t)===core.CellValueType.FORCE_STRING&&cellData.v&&core.isRealNum(cellData.v)){const currentAlert=this._cellAlertManagerService.currentAlert.get(ALERT_KEY),currentLoc=(_a61=currentAlert==null?void 0:currentAlert.alert)==null?void 0:_a61.location;if(currentLoc&&currentLoc.row===cellPos.location.row&&currentLoc.col===cellPos.location.col&&currentLoc.subUnitId===cellPos.location.subUnitId&&currentLoc.unitId===cellPos.location.unitId)return;this._cellAlertManagerService.showAlert({type:CellAlertType.ERROR,title:this._localeService.t("info.error"),message:this._localeService.t("info.forceStringInfo"),location:cellPos.location,width:200,height:74,key:ALERT_KEY});return}}this._cellAlertManagerService.removeAlert(ALERT_KEY)}))}},__name(_a31,"ForceStringAlertRenderController"),_a31);ForceStringAlertRenderController=__decorateClass$r([__decorateParam$r(1,core.Inject(exports.HoverManagerService)),__decorateParam$r(2,core.Inject(exports.CellAlertManagerService)),__decorateParam$r(3,core.Inject(core.LocaleService))],ForceStringAlertRenderController);var __defProp$q=Object.defineProperty,__getOwnPropDesc$q=Object.getOwnPropertyDescriptor,__decorateClass$q=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$q(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$q(target,key,result),result},"__decorateClass$q"),__decorateParam$q=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$q"),_a32;let ForceStringRenderController=(_a32=class extends core.RxDisposable{constructor(_context,_sheetSkeletonManagerService,_sheetInterceptorService){super(),this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._sheetInterceptorService=_sheetInterceptorService,this._initViewModelIntercept()}_initViewModelIntercept(){const FORCE_STRING_MARK={tl:{size:6,color:"#409f11"}};this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:10,effect:core.InterceptorEffectEnum.Style,handler:__name((cell,pos,next)=>{var _a61;if(!((_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton))return next(cell);const cellRaw=pos.worksheet.getCellRaw(pos.row,pos.col);return!cellRaw||cellRaw.v===null||cellRaw.v===void 0?next(cell):(cell==null?void 0:cell.t)===core.CellValueType.FORCE_STRING&&core.isRealNum(cellRaw.v)?next({...cell,markers:{...cell==null?void 0:cell.markers,...FORCE_STRING_MARK}}):next(cell)},"handler")}))}},__name(_a32,"ForceStringRenderController"),_a32);ForceStringRenderController=__decorateClass$q([__decorateParam$q(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$q(2,core.Inject(sheets.SheetInterceptorService))],ForceStringRenderController);var __defProp$p=Object.defineProperty,__getOwnPropDesc$p=Object.getOwnPropertyDescriptor,__decorateClass$p=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$p(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$p(target,key,result),result},"__decorateClass$p"),__decorateParam$p=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$p"),_a33;let FormatPainterController=(_a33=class extends core.Disposable{constructor(_commandService,_formatPainterService,_univerInstanceService,_renderManagerService,_selectionManagerService,_sheetInterceptorService,_injector){super(),this._commandService=_commandService,this._formatPainterService=_formatPainterService,this._univerInstanceService=_univerInstanceService,this._renderManagerService=_renderManagerService,this._selectionManagerService=_selectionManagerService,this._sheetInterceptorService=_sheetInterceptorService,this._injector=_injector,this._initialize()}_initialize(){this._commandExecutedListener(),this._addDefaultHook()}_commandExecutedListener(){const selectionRenderService=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET).with(ISheetSelectionRenderService);this.disposeWithMe(selectionRenderService.selectionMoveEnd$.subscribe(selections=>{var _a61,_b;if(this._formatPainterService.getStatus()!==FormatPainterStatus.OFF){const{rangeWithCoord}=selections[selections.length-1];this._commandService.executeCommand(ApplyFormatPainterCommand.id,{unitId:((_a61=this._univerInstanceService.getFocusedUnit())==null?void 0:_a61.getUnitId())||"",subUnitId:((_b=this._univerInstanceService.getFocusedUnit().getActiveSheet())==null?void 0:_b.getSheetId())||"",range:{startRow:rangeWithCoord.startRow,startColumn:rangeWithCoord.startColumn,endRow:rangeWithCoord.endRow,endColumn:rangeWithCoord.endColumn}}),this._formatPainterService.getStatus()===FormatPainterStatus.ONCE&&this._commandService.executeCommand(SetOnceFormatPainterCommand.id)}}))}_addDefaultHook(){const defaultHook={id:"default-format-painter",priority:0,isDefaultHook:!0,onStatusChange:__name(status=>{if(status!==FormatPainterStatus.OFF){const format=this._collectSelectionRangeFormat();format&&this._formatPainterService.setSelectionFormat(format)}},"onStatusChange"),onApply:__name((unitId,subUnitId,range,format)=>this._getUndoRedoMutationInfo(unitId,subUnitId,range,format),"onApply")};this._formatPainterService.addHook(defaultHook)}_collectSelectionRangeFormat(){const selection=this._selectionManagerService.getCurrentLastSelection(),range=selection==null?void 0:selection.range;if(!range)return null;const{startRow,endRow,startColumn,endColumn}=range,workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!worksheet)return null;const cellData=worksheet.getCellMatrix(),styles2=workbook.getStyles(),stylesMatrix=new core.ObjectMatrix,merges=[];for(let r2=startRow;r2<=endRow;r2++)for(let c=startColumn;c<=endColumn;c++){const cell=cellData.getValue(r2,c);stylesMatrix.setValue(r2,c,styles2.getStyleByCell(cell)||{});const{isMergedMainCell,...mergeInfo}=worksheet.getCellInfoInMergeData(r2,c);isMergedMainCell&&merges.push({startRow:mergeInfo.startRow,startColumn:mergeInfo.startColumn,endRow:mergeInfo.endRow,endColumn:mergeInfo.endColumn})}return{styles:stylesMatrix,merges}}_getUndoRedoMutationInfo(unitId,subUnitId,originRange,format){const sheetInterceptorService=this._sheetInterceptorService,univerInstanceService=this._univerInstanceService,{merges,styles:stylesMatrix}=format;if(!stylesMatrix)return{undos:[],redos:[]};const{startRow,startColumn,endRow,endColumn}=stylesMatrix.getDataRange(),styleRowsNum=endRow-startRow+1,styleColsNum=endColumn-startColumn+1,range=originRange.startRow===originRange.endRow&&originRange.startColumn===originRange.endColumn?{startRow:originRange.startRow,startColumn:originRange.startColumn,endRow:originRange.startRow+styleRowsNum-1,endColumn:originRange.startColumn+styleColsNum-1}:originRange,styleValues=Array.from({length:range.endRow-range.startRow+1},()=>Array.from({length:range.endColumn-range.startColumn+1},()=>({}))),mergeRanges=[];styleValues.forEach((row,rowIndex)=>{row.forEach((col,colIndex)=>{const mappedRowIndex=rowIndex%styleRowsNum+startRow,mappedColIndex=colIndex%styleColsNum+startColumn,style=stylesMatrix.getValue(mappedRowIndex,mappedColIndex);style&&(styleValues[rowIndex][colIndex].s=Object.keys(style).length>0?style:null)})}),merges.forEach(merge=>{const relatedRange={startRow:merge.startRow-startRow,startColumn:merge.startColumn-startColumn,endRow:merge.endRow-startRow,endColumn:merge.endColumn-startColumn},rowRepeats=Math.max(1,Math.floor((range.endRow-range.startRow+1)/styleRowsNum)),colRepeats=Math.max(1,Math.floor((range.endColumn-range.startColumn+1)/styleColsNum));for(let i=0;i<rowRepeats;i++)for(let j=0;j<colRepeats;j++)mergeRanges.push({startRow:relatedRange.startRow+i*styleRowsNum+range.startRow,startColumn:relatedRange.startColumn+j*styleColsNum+range.startColumn,endRow:relatedRange.endRow+i*styleRowsNum+range.startRow,endColumn:relatedRange.endColumn+j*styleColsNum+range.startColumn})});const currentSelections=[range],clearCellValue=new core.ObjectMatrix,cellValue=new core.ObjectMatrix;if(core.Tools.isArray(styleValues))for(let i=0;i<currentSelections.length;i++){const{startRow:startRow2,startColumn:startColumn2,endRow:endRow2,endColumn:endColumn2}=currentSelections[i];for(let r2=0;r2<=endRow2-startRow2;r2++)for(let c=0;c<=endColumn2-startColumn2;c++)clearCellValue.setValue(r2+startRow2,c+startColumn2,{s:null}),cellValue.setValue(r2+startRow2,c+startColumn2,styleValues[r2][c])}const clearStyleMutationParams={subUnitId,unitId,cellValue:clearCellValue.getMatrix()},setRangeValuesMutationParams={subUnitId,unitId,cellValue:cellValue.getMatrix()},undoSetRangeValuesMutationParams=this._injector.invoke(sheets.SetRangeValuesUndoMutationFactory,clearStyleMutationParams),{undos:interceptorUndos,redos:interceptorRedos}=sheetInterceptorService.onCommandExecute({id:sheets.SetRangeValuesCommand.id,params:{...setRangeValuesMutationParams,range:currentSelections}}),ranges=sheets.getAddMergeMutationRangeByType(mergeRanges),mergeRedos=[],mergeUndos=[],worksheet=univerInstanceService.getUnit(unitId).getSheetBySheetId(subUnitId),willRemoveSomeCell=checkCellContentInRanges(worksheet,ranges),removeMergeMutationParams={unitId,subUnitId,ranges},addMergeMutationParams={unitId,subUnitId,ranges};mergeRedos.push({id:sheets.RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}),mergeRedos.push({id:sheets.AddWorksheetMergeMutation.id,params:addMergeMutationParams});const undoRemoveMergeMutationParams=this._injector.invoke(sheets.RemoveMergeUndoMutationFactory,removeMergeMutationParams),undoMutationParams=this._injector.invoke(sheets.AddMergeUndoMutationFactory,addMergeMutationParams);if(mergeUndos.push({id:sheets.RemoveWorksheetMergeMutation.id,params:undoMutationParams}),mergeUndos.push({id:sheets.AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),willRemoveSomeCell){const data=this._injector.invoke(accessor=>getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges));mergeRedos.unshift(...data.redos),mergeUndos.push(...data.undos)}return{undos:[{id:sheets.SetRangeValuesMutation.id,params:clearStyleMutationParams},{id:sheets.SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams},...interceptorUndos,...mergeUndos],redos:[{id:sheets.SetRangeValuesMutation.id,params:clearStyleMutationParams},{id:sheets.SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...interceptorRedos,...mergeRedos]}}},__name(_a33,"FormatPainterController"),_a33);FormatPainterController=__decorateClass$p([__decorateParam$p(0,core.ICommandService),__decorateParam$p(1,IFormatPainterService),__decorateParam$p(2,core.IUniverInstanceService),__decorateParam$p(3,engineRender.IRenderManagerService),__decorateParam$p(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$p(5,core.Inject(sheets.SheetInterceptorService)),__decorateParam$p(6,core.Inject(core.Injector))],FormatPainterController);var __defProp$o=Object.defineProperty,__getOwnPropDesc$o=Object.getOwnPropertyDescriptor,__decorateClass$o=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$o(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$o(target,key,result),result},"__decorateClass$o"),__decorateParam$o=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$o"),_a34;exports.HoverRenderController=(_a34=class extends core.Disposable{constructor(_context,_hoverManagerService,_sheetSkeletonManagerService,_scrollManagerService){super();__publicField(this,"_active",!1);this._context=_context,this._hoverManagerService=_hoverManagerService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._scrollManagerService=_scrollManagerService,this._initPointerEvent(),this._initScrollEvent()}get active(){return this._active}_initPointerEvent(){const disposeSet=new core.DisposableCollection,handleSkeletonChange=__name(skeletonParam=>{if(disposeSet.dispose(),!skeletonParam)return;const{mainComponent,unitId}=this._context;mainComponent&&(disposeSet.add(mainComponent.onPointerEnter$.subscribeEvent(evt=>{this._active=!0})),disposeSet.add(core.fromEventSubject(mainComponent.onPointerMove$).pipe(rxjs.throttleTime(30)).subscribe(evt=>{this._active=!0,this._hoverManagerService.triggerMouseMove(unitId,evt.offsetX,evt.offsetY)})),disposeSet.add(mainComponent.onPointerUp$.subscribeEvent(evt=>{this._hoverManagerService.triggerClick(unitId,evt.offsetX,evt.offsetY)})),disposeSet.add(mainComponent.onPointerLeave$.subscribeEvent(()=>{this._active=!1})))},"handleSkeletonChange");handleSkeletonChange(this._sheetSkeletonManagerService.getCurrent()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(skeletonParam=>{handleSkeletonChange(skeletonParam)}))}_initScrollEvent(){this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(()=>this._hoverManagerService.triggerScroll()))}},__name(_a34,"HoverRenderController"),_a34);exports.HoverRenderController=__decorateClass$o([__decorateParam$o(1,core.Inject(exports.HoverManagerService)),__decorateParam$o(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$o(3,core.Inject(SheetScrollManagerService))],exports.HoverRenderController);var __defProp$n=Object.defineProperty,__getOwnPropDesc$n=Object.getOwnPropertyDescriptor,__decorateClass$n=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$n(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$n(target,key,result),result},"__decorateClass$n"),__decorateParam$n=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$n"),_a35;let MarkSelectionRenderController=(_a35=class extends core.Disposable{constructor(_context,_markSelectionService,_commandService,_sheetSkeletonManagerService){super(),this._context=_context,this._markSelectionService=_markSelectionService,this._commandService=_commandService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._initListeners()}_initListeners(){this._addRemoveListener(),this._addRefreshListener()}_addRemoveListener(){const removeCommands=[SetCellEditVisibleOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{removeCommands.includes(command.id)?this._markSelectionService.removeAllShapes():this._markSelectionService.getShapeMap().forEach((shape,id)=>{shape.exits.includes(command.id)&&this._markSelectionService.removeShape(id)})}))}_addRefreshListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(skeleton=>{skeleton&&this._markSelectionService.refreshShapes()}))}},__name(_a35,"MarkSelectionRenderController"),_a35);MarkSelectionRenderController=__decorateClass$n([__decorateParam$n(1,core.Inject(IMarkSelectionService)),__decorateParam$n(2,core.ICommandService),__decorateParam$n(3,core.Inject(exports.SheetSkeletonManagerService))],MarkSelectionRenderController);var __defProp$m=Object.defineProperty,__getOwnPropDesc$m=Object.getOwnPropertyDescriptor,__decorateClass$m=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$m(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$m(target,key,result),result},"__decorateClass$m"),__decorateParam$m=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$m"),_a36;let MoveRangeRenderController=(_a36=class extends core.Disposable{constructor(_context,_selectionRenderService,_selectionManagerService,_commandService){super();__publicField(this,"_initialize",__name(()=>{const disposableCollection=new core.DisposableCollection;this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(()=>{disposableCollection.dispose(),this._selectionRenderService.getSelectionControls().forEach(controlSelection=>{disposableCollection.add(core.toDisposable(controlSelection.selectionMoved$.subscribe(_toRange=>{if(!_toRange)return;const _fromRange=controlSelection.model.getRange(),fromRange={startRow:_fromRange.startRow,startColumn:_fromRange.startColumn,endRow:_fromRange.endRow,endColumn:_fromRange.endColumn,rangeType:_fromRange.rangeType},toRange={startRow:_toRange.startRow,startColumn:_toRange.startColumn,endRow:_toRange.endRow,endColumn:_toRange.endColumn,rangeType:_fromRange.rangeType};if(fromRange.startRow===toRange.startRow&&fromRange.startColumn===toRange.startColumn||toRange.startRow<0||toRange.startColumn<0)return;const params={fromRange,toRange};this._commandService.executeCommand(sheets.MoveRangeCommand.id,params)})))})}))},"_initialize"));this._context=_context,this._selectionRenderService=_selectionRenderService,this._selectionManagerService=_selectionManagerService,this._commandService=_commandService,this._initialize()}},__name(_a36,"MoveRangeRenderController"),_a36);MoveRangeRenderController=__decorateClass$m([__decorateParam$m(1,core.Inject(ISheetSelectionRenderService)),__decorateParam$m(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$m(3,core.Inject(core.ICommandService))],MoveRangeRenderController);var __defProp$l=Object.defineProperty,__getOwnPropDesc$l=Object.getOwnPropertyDescriptor,__decorateClass$l=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$l(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$l(target,key,result),result},"__decorateClass$l"),__decorateParam$l=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$l"),_a37;exports.SheetPermissionInitController=(_a37=class extends core.Disposable{constructor(_univerInstanceService,_permissionService,_authzIoService,_rangeProtectionRuleModel,_worksheetProtectionRuleModel,_userManagerService,_worksheetProtectionPointRuleModel,_sheetInterceptorService,_undoRedoService,_commandService,_rangeProtectionCache){super(),this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._authzIoService=_authzIoService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._userManagerService=_userManagerService,this._worksheetProtectionPointRuleModel=_worksheetProtectionPointRuleModel,this._sheetInterceptorService=_sheetInterceptorService,this._undoRedoService=_undoRedoService,this._commandService=_commandService,this._rangeProtectionCache=_rangeProtectionCache,this._initRangePermissionFromSnapshot(),this._initRangePermissionChange(),this._initWorksheetPermissionFromSnapshot(),this._initWorksheetPermissionChange(),this._initWorksheetPermissionPointsChange(),this._initWorkbookPermissionFromSnapshot(),this._initUserChange(),this._initViewModelByRangeInterceptor(),this._initViewModelBySheetInterceptor(),this._refreshPermissionByCollaCreate()}async _initRangePermissionFromSnapshot(){const initRangePermissionFunc=__name(async workbook=>{const allAllowedParams=[],unitId=workbook.getUnitId(),allSheets=workbook.getSheets(),permissionIdWithRuleInstanceMap=new Map;if(allSheets.forEach(sheet=>{const subunitId=sheet.getSheetId();this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subunitId).forEach(rule=>{permissionIdWithRuleInstanceMap.set(rule.permissionId,rule),allAllowedParams.push({objectID:rule.permissionId,unitID:unitId,objectType:L.SelectRange,actions:[D.View,D.Edit]})})}),!allAllowedParams.length){this._rangeProtectionRuleModel.changeRuleInitState(!0);return}this._authzIoService.batchAllowed(allAllowedParams).then(permissionMap=>{permissionMap.forEach(item=>{const rule=permissionIdWithRuleInstanceMap.get(item.objectID);rule&&sheets.getAllRangePermissionPoint().forEach(F=>{const instance=new F(unitId,rule.subUnitId,item.objectID),unitActionName=instance.subType,result=item.actions.find(action=>action.action===unitActionName);(result==null?void 0:result.allowed)!==void 0&&this._permissionService.updatePermissionPoint(instance.id,result.allowed)})}),this._rangeProtectionRuleModel.changeRuleInitState(!0)})},"initRangePermissionFunc");await Promise.all(this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).map(workbook=>initRangePermissionFunc(workbook))),this._rangeProtectionRuleModel.changeRuleInitState(!0)}_initRangePermissionChange(){this.disposeWithMe(this._rangeProtectionRuleModel.ruleChange$.subscribe(info=>{info.type!=="delete"?this._authzIoService.allowed({objectID:info.rule.permissionId,unitID:info.unitId,objectType:L.SelectRange,actions:[D.Edit,D.View]}).then(actionList=>{sheets.getAllRangePermissionPoint().forEach(F=>{if(info.type==="set"){const{rule:rule2,oldRule}=info;if(rule2.permissionId===(oldRule==null?void 0:oldRule.permissionId))return}const rule=info.rule,instance=new F(rule.unitId,rule.subUnitId,rule.permissionId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})}):this._rangeProtectionRuleModel.getSubunitRuleList(info.unitId,info.subUnitId).length===0&&(this._worksheetProtectionPointRuleModel.deleteRule(info.unitId,info.subUnitId),[...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,instance.value)}))}))}async initWorkbookPermissionChange(_unitId){var _a61;const unitId=_unitId||((_a61=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_a61.getUnitId());unitId&&this._authzIoService.allowed({objectID:unitId,objectType:L.Workbook,unitID:unitId,actions:sheets.defaultWorkbookPermissionPoints}).then(actionList=>{sheets.getAllWorkbookPermissionPoint().forEach(F=>{const instance=new F(unitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})})}async _initWorkbookPermissionFromSnapshot(){await Promise.all(this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).map(workbook=>this.initWorkbookPermissionChange(workbook.getUnitId())))}_initWorksheetPermissionChange(){this.disposeWithMe(this._worksheetProtectionRuleModel.ruleChange$.subscribe(info=>{info.type!=="delete"?this._authzIoService.allowed({objectID:info.rule.permissionId,unitID:info.unitId,objectType:L.Worksheet,actions:[D.Edit,D.View]}).then(actionList=>{sheets.getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})}):([...sheets.getAllWorksheetPermissionPoint(),...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,!0)}),this._worksheetProtectionPointRuleModel.deleteRule(info.unitId,info.subUnitId))}))}_initWorksheetPermissionPointsChange(){this.disposeWithMe(this._worksheetProtectionPointRuleModel.pointChange$.subscribe(info=>{this._authzIoService.allowed({objectID:info.permissionId,unitID:info.unitId,objectType:L.Worksheet,actions:sheets.defaultWorksheetPermissionPoint}).then(actionList=>{sheets.getAllWorksheetPermissionPointByPointPanel().forEach(F=>{const instance=new F(info.unitId,info.subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})})}))}async _initWorksheetPermissionFromSnapshot(){const initSheetPermissionFunc=__name(async workbook=>{const allAllowedParams=[],unitId=workbook.getUnitId(),allSheets=workbook.getSheets(),permissionIdWithRuleInstanceMap=new Map;if(allSheets.forEach(sheet=>{const subUnitId=sheet.getSheetId(),rule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId);rule&&(permissionIdWithRuleInstanceMap.set(rule.permissionId,rule),allAllowedParams.push({objectID:rule.permissionId,unitID:unitId,objectType:L.Worksheet,actions:[D.Edit,D.View]}));const pointRule=this._worksheetProtectionPointRuleModel.getRule(unitId,subUnitId);pointRule&&(permissionIdWithRuleInstanceMap.set(pointRule.permissionId,pointRule),allAllowedParams.push({objectID:pointRule.permissionId,unitID:unitId,objectType:L.Worksheet,actions:sheets.defaultWorksheetPermissionPoint}))}),!allAllowedParams.length){this._worksheetProtectionRuleModel.changeRuleInitState(!0);return}this._authzIoService.batchAllowed(allAllowedParams).then(permissionMap=>{permissionMap.forEach(item=>{const rule=permissionIdWithRuleInstanceMap.get(item.objectID);rule&&[...sheets.getAllWorksheetPermissionPoint(),...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,rule.subUnitId),unitActionName=instance.subType,result=item.actions.find(action=>action.action===unitActionName);(result==null?void 0:result.allowed)!==void 0&&this._permissionService.updatePermissionPoint(instance.id,result.allowed)})}),this._worksheetProtectionRuleModel.changeRuleInitState(!0)})},"initSheetPermissionFunc");await Promise.all(this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).map(workbook=>initSheetPermissionFunc(workbook))),this._worksheetProtectionRuleModel.changeRuleInitState(!0)}_initUserChange(){this.disposeWithMe(this._userManagerService.currentUser$.pipe(rxjs.skip(1)).subscribe(()=>{const _map=this._permissionService.getAllPermissionPoint();this._permissionService.clearPermissionMap(),this._worksheetProtectionRuleModel.changeRuleInitState(!1),this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>{const unitId=workbook.getUnitId();sheets.getAllWorkbookPermissionPoint().forEach(F=>{let instance=new F(unitId);_map.has(instance.id)&&(instance=_map.get(instance.id)),this._permissionService.addPermissionPoint(instance)}),workbook.getSheets().forEach(sheet=>{const subUnitId=sheet.getSheetId();[...sheets.getAllWorksheetPermissionPoint(),...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{let instance=new F(unitId,subUnitId);_map.has(instance.id)&&(instance=_map.get(instance.id)),this._permissionService.addPermissionPoint(instance)}),this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{sheets.getAllRangePermissionPoint().forEach(F=>{let instance=new F(unitId,subUnitId,rule.permissionId);_map.has(instance.id)&&(instance=_map.get(instance.id)),this._permissionService.addPermissionPoint(instance)})})}),this._initWorkbookPermissionFromSnapshot(),this._initWorksheetPermissionFromSnapshot(),this._initRangePermissionFromSnapshot()})}))}_initViewModelByRangeInterceptor(){this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:999,effect:core.InterceptorEffectEnum.Value|core.InterceptorEffectEnum.Style,handler:__name((cell={},context,next)=>{const{unitId,subUnitId,row,col}=context,selectionProtection=this._rangeProtectionCache.getCellInfo(unitId,subUnitId,row,col);if(selectionProtection){const isSkipRender=selectionProtection[D.View]===!1,_cellData={...cell,selectionProtection:[selectionProtection]};return isSkipRender?(delete _cellData.s,delete _cellData.v,delete _cellData.p,_cellData):next(_cellData)}return next(cell)},"handler")}))}_initViewModelBySheetInterceptor(){this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:999,effect:core.InterceptorEffectEnum.Value|core.InterceptorEffectEnum.Style,handler:__name((cell={},context,next)=>{var _a61,_b,_c,_d,_e;const{unitId,subUnitId}=context,worksheetRule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId);if(worksheetRule!=null&&worksheetRule.permissionId){const selectionProtection=[{[D.View]:(_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorksheetViewPermission(unitId,subUnitId).id))==null?void 0:_a61.value)!=null?_b:!1,[D.Edit]:(_d=(_c=this._permissionService.getPermissionPoint(new sheets.WorksheetEditPermission(unitId,subUnitId).id))==null?void 0:_c.value)!=null?_d:!1}],isSkipRender=!((_e=selectionProtection[0])!=null&&_e[D.View]),_cellData={...cell,hasWorksheetRule:!0,selectionProtection};return isSkipRender?(delete _cellData.s,delete _cellData.v,delete _cellData.p,_cellData):next(_cellData)}return next(cell)},"handler")}))}refreshPermission(unitId,permissionId){const sheetRuleItem=this._worksheetProtectionRuleModel.getTargetByPermissionId(unitId,permissionId);let needClearUndoRedo=!1;if(sheetRuleItem){const[_,subUnitId]=sheetRuleItem;this._authzIoService.allowed({objectID:permissionId,unitID:unitId,objectType:L.Worksheet,actions:[D.Edit,D.View]}).then(actionList=>{let key="";sheets.getAllWorksheetPermissionPoint().forEach(F=>{var _a61;const instance=new F(unitId,subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&(((_a61=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a61.value)!==action.allowed&&(needClearUndoRedo=!0),this._permissionService.updatePermissionPoint(instance.id,action.allowed),key+=`${action.action}_${action.allowed}`)}),this._worksheetProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`),needClearUndoRedo&&this._undoRedoService.clearUndoRedo(unitId)})}const sheetPointItem=this._worksheetProtectionPointRuleModel.getTargetByPermissionId(unitId,permissionId);if(sheetPointItem){const[_,subUnitId]=sheetPointItem;this._authzIoService.allowed({objectID:permissionId,unitID:unitId,objectType:L.Worksheet,actions:sheets.defaultWorksheetPermissionPoint}).then(actionList=>{sheets.getAllWorksheetPermissionPointByPointPanel().forEach(F=>{var _a61;const instance=new F(unitId,subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&(((_a61=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a61.value)!==action.allowed&&(needClearUndoRedo=!0),this._permissionService.updatePermissionPoint(instance.id,action.allowed))}),needClearUndoRedo&&this._undoRedoService.clearUndoRedo(unitId)})}const rangeRuleItem=this._rangeProtectionRuleModel.getTargetByPermissionId(unitId,permissionId);if(rangeRuleItem){const[_,subUnitId]=rangeRuleItem;this._authzIoService.allowed({objectID:permissionId,unitID:unitId,objectType:L.SelectRange,actions:[D.Edit,D.View]}).then(actionList=>{let key="";sheets.getAllRangePermissionPoint().forEach(F=>{var _a61;const instance=new F(unitId,subUnitId,permissionId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&(((_a61=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a61.value)!==action.allowed&&(needClearUndoRedo=!0),this._permissionService.updatePermissionPoint(instance.id,action.allowed),key+=`${action.action}_${action.allowed}`)}),this._rangeProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`),needClearUndoRedo&&this._undoRedoService.clearUndoRedo(unitId)})}}_refreshPermissionByCollaCreate(){this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{if(options!=null&&options.fromCollab&&(command.id===sheets.AddRangeProtectionMutation.id||command.id===sheets.AddWorksheetProtectionMutation.id||command.id===sheets.SetWorksheetPermissionPointsMutation.id)){const params=command.params;this._undoRedoService.clearUndoRedo(params.unitId)}}))}},__name(_a37,"SheetPermissionInitController"),_a37);exports.SheetPermissionInitController=__decorateClass$l([__decorateParam$l(0,core.IUniverInstanceService),__decorateParam$l(1,core.IPermissionService),__decorateParam$l(2,core.IAuthzIoService),__decorateParam$l(3,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$l(4,core.Inject(sheets.WorksheetProtectionRuleModel)),__decorateParam$l(5,core.Inject(core.UserManagerService)),__decorateParam$l(6,core.Inject(sheets.WorksheetProtectionPointModel)),__decorateParam$l(7,core.Inject(sheets.SheetInterceptorService)),__decorateParam$l(8,core.Inject(core.IUndoRedoService)),__decorateParam$l(9,core.Inject(core.ICommandService)),__decorateParam$l(10,core.Inject(sheets.RangeProtectionCache))],exports.SheetPermissionInitController);const UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID="UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID",UNIVER_SHEET_PERMISSION_ALERT_DIALOG="UNIVER_SHEET_PERMISSION_ALERT_DIALOG";var __defProp$k=Object.defineProperty,__getOwnPropDesc$k=Object.getOwnPropertyDescriptor,__decorateClass$k=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$k(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$k(target,key,result),result},"__decorateClass$k"),__decorateParam$k=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$k"),_a38;exports.SheetPermissionInterceptorBaseController=(_a38=class extends core.Disposable{constructor(_commandService,_univerInstanceService,_permissionService,_selectionManagerService,_dialogService,_rangeProtectionRuleModel,_worksheetProtectionRuleModel,_autoFillService,_localeService,_lexerTreeBuilder,_contextService,_definedNamesService){super();__publicField(this,"disposableCollection",new core.DisposableCollection);__publicField(this,"_showPermissionDialog",!0);this._commandService=_commandService,this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._selectionManagerService=_selectionManagerService,this._dialogService=_dialogService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._autoFillService=_autoFillService,this._localeService=_localeService,this._lexerTreeBuilder=_lexerTreeBuilder,this._contextService=_contextService,this._definedNamesService=_definedNamesService,this._initialize()}setShowPermissionDialog(value){this._showPermissionDialog=value}haveNotPermissionHandle(errorMsg){const dialogProps={id:UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID,title:{title:""},children:{label:UNIVER_SHEET_PERMISSION_ALERT_DIALOG,errorMsg},width:320,destroyOnClose:!0,onClose:__name(()=>this._dialogService.close(UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID),"onClose"),className:"sheet-permission-user-dialog"};throw this._showPermissionDialog&&this._dialogService.open(dialogProps),new core.CustomCommandExecutionError("have not permission")}_getPermissionCheck(id,params){var _a61,_b,_c;let permission=!0,errorMsg="";switch(id){case docsUi.InsertCommand.id:case docsUi.IMEInputCommand.id:if(this._contextService.getContextValue(core.FOCUSING_EDITOR_STANDALONE)===!0)break;permission=this.permissionCheckWithoutRange({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.editErr");break;case SetCellEditVisibleOperation.id:if(params.visible===!1)break;permission=this.permissionCheckWithoutRange({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.editErr");break;case sheets.SetRangeValuesCommand.id:core.isICellData(params.value)&&params.value.f?(permission=this._permissionCheckWithFormula(params),errorMsg=this._localeService.t("permission.dialog.formulaErr")):permission=this._permissionCheckBySetRangeValue({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]},params);break;case sheets.ClearSelectionContentCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.editErr");break;case SheetPasteColWidthCommand.id:permission=this.permissionCheckWithoutRange({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission]}),errorMsg=this._localeService.t("permission.dialog.pasteErr");break;case SheetPasteShortKeyCommand.id:permission=this._permissionCheckByPaste(params),errorMsg=this._localeService.t("permission.dialog.pasteErr");break;case ApplyFormatPainterCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission]}),errorMsg=this._localeService.t("permission.dialog.commonErr");break;case sheets.SetBackgroundColorCommand.id:case SetRangeBoldCommand.id:case SetRangeItalicCommand.id:case SetRangeUnderlineCommand.id:case SetRangeStrickThroughCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.setStyleErr");break;case SheetCopyCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookCopyPermission],rangeTypes:[sheets.RangeProtectionPermissionViewPoint],worksheetTypes:[sheets.WorksheetCopyPermission]}),errorMsg=this._localeService.t("permission.dialog.copyErr"),(_a61=this._permissionService.getPermissionPoint(new sheets.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&_a61.value||(errorMsg=this._localeService.t("permission.dialog.workbookCopyErr"));break;case SheetCutCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookCopyPermission,sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionViewPoint,sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetCopyPermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.copyErr"),(_b=this._permissionService.getPermissionPoint(new sheets.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&_b.value||(errorMsg=this._localeService.t("permission.dialog.workbookCopyErr"));break;case sheets.DeltaColumnWidthCommand.id:case sheets.SetColWidthCommand.id:permission=this.permissionCheckWithoutRange({worksheetTypes:[sheets.WorksheetSetColumnStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.DeltaRowHeightCommand.id:case sheets.SetRowHeightCommand.id:case sheets.SetWorksheetRowIsAutoHeightCommand.id:permission=this.permissionCheckWithoutRange({worksheetTypes:[sheets.WorksheetSetRowStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.MoveColsCommand.id:case sheets.MoveRowsCommand.id:permission=this._permissionCheckByMoveCommand(params),errorMsg=this._localeService.t("permission.dialog.moveRowColErr");break;case sheets.MoveRangeCommand.id:permission=this._permissionCheckByMoveRangeCommand(params),errorMsg=this._localeService.t("permission.dialog.moveRangeErr");break;case AutoFillCommand.id:permission=this._permissionCheckByAutoFillCommand((_c=this._autoFillService.autoFillLocation)==null?void 0:_c.target),errorMsg=this._localeService.t("permission.dialog.autoFillErr");break;case sheets.SetWorksheetOrderCommand.id:permission=this._permissionCheckByWorksheetCommand([sheets.WorkbookEditablePermission,sheets.WorkbookMoveSheetPermission]),errorMsg=this._localeService.t("permission.dialog.operatorSheetErr"),permission===!1&&this._worksheetProtectionRuleModel.resetOrder();break;case sheets.SetWorksheetNameCommand.id:permission=this._permissionCheckByWorksheetCommand([sheets.WorkbookEditablePermission,sheets.WorkbookRenameSheetPermission]),errorMsg=this._localeService.t("permission.dialog.operatorSheetErr"),permission===!1&&this._worksheetProtectionRuleModel.resetOrder();break;case sheets.SetWorksheetShowCommand.id:{const{unitId,subUnitId}=params;permission=this._permissionCheckByWorksheetCommand([sheets.WorkbookEditablePermission,sheets.WorkbookHideSheetPermission],unitId,subUnitId),errorMsg=this._localeService.t("permission.dialog.operatorSheetErr"),permission===!1&&this._worksheetProtectionRuleModel.resetOrder()}break;case sheets.SetSpecificColsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission]},params.ranges),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.SetSpecificRowsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission]},params.ranges),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.SetSelectedColsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.SetSelectedRowsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.InsertRangeMoveRightCommand.id:permission=this._permissionCheckWithInsertRangeMove("right"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break;case sheets.InsertRangeMoveDownCommand.id:permission=this._permissionCheckWithInsertRangeMove("bottom"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break;case sheets.DeleteRangeMoveLeftCommand.id:permission=this._permissionCheckWithInsertRangeMove("left"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break;case sheets.DeleteRangeMoveUpCommand.id:permission=this._permissionCheckWithInsertRangeMove("top"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break}permission||this.haveNotPermissionHandle(errorMsg)}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(command=>{this._getPermissionCheck(command.id,command==null?void 0:command.params)})),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{var _a61;if(command.id===sheets.SetWorksheetNameMutation.id){const params=command.params,{unitId=(_a61=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_a61.getUnitId(),subUnitId}=params;if(!unitId||!subUnitId)return;const worksheetRule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId),selectionRuleList=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId);worksheetRule&&this._worksheetProtectionRuleModel.ruleRefresh(worksheetRule.permissionId),selectionRuleList.length&&this._rangeProtectionRuleModel.ruleRefresh(subUnitId)}}))}_permissionCheckWithInsertRangeMove(direction){var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,selectionRange=core.Tools.deepClone((_a61=this._selectionManagerService.getCurrentLastSelection())==null?void 0:_a61.range);return!(!selectionRange||(direction==="top"||direction==="bottom"?selectionRange.endRow=worksheet.getRowCount()-1:(direction==="left"||direction==="right")&&(selectionRange.endColumn=worksheet.getColumnCount()-1),this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).map(rule=>rule.ranges).flat().some(range=>core.Rectangle.getIntersects(selectionRange,range))))}_permissionCheckByWorksheetCommand(types,targetUnitId,targetSubUnitId){var _a61,_b;const target=sheets.getSheetCommandTarget(this._univerInstanceService,{unitId:targetUnitId,subUnitId:targetSubUnitId});if(!target)return!1;const{unitId,subUnitId}=target,worksheetRule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId),selectionRule=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).length>0;return worksheetRule||selectionRule?(_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_a61.value)!=null?_b:!1:this._permissionService.composePermission(types.map(F=>new F(unitId).id)).every(permission=>permission.value)}permissionCheckWithoutRange(permissionTypes){var _a61,_b,_c,_d;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,selection=this._selectionManagerService.getCurrentLastSelection();if(!selection)return!0;const row=(_b=(_a61=selection==null?void 0:selection.primary)==null?void 0:_a61.actualRow)!=null?_b:0,col=(_d=(_c=selection==null?void 0:selection.primary)==null?void 0:_c.actualColumn)!=null?_d:0,{workbookTypes,worksheetTypes,rangeTypes}=permissionTypes;return!(workbookTypes&&workbookTypes.some(F=>{var _a62,_b2;const instance=new F(unitId);return((_b2=(_a62=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a62.value)!=null?_b2:!1)===!1})===!0||worksheetTypes&&worksheetTypes.some(F=>{var _a62,_b2;const instance=new F(unitId,subUnitId);return((_b2=(_a62=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a62.value)!=null?_b2:!1)===!1})===!0||rangeTypes&&rangeTypes.some(F=>{var _a62,_b2,_c2,_d2,_e;const cellInfo=(_b2=(_a62=worksheet.getCell(row,col))==null?void 0:_a62.selectionProtection)==null?void 0:_b2[0];if(!(cellInfo!=null&&cellInfo.ruleId))return!1;const permissionId=(_c2=this._rangeProtectionRuleModel.getRule(unitId,subUnitId,cellInfo.ruleId))==null?void 0:_c2.permissionId;if(!permissionId)return!1;const instance=new F(unitId,subUnitId,permissionId);return((_e=(_d2=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_d2.value)!=null?_e:!1)===!1})===!0)}permissionCheckWithRanges(permissionTypes,selectionRanges,unitId,subUnitId){var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{workbook,worksheet}=target;unitId||(unitId=workbook.getUnitId()),subUnitId||(subUnitId=worksheet.getSheetId());const ranges=selectionRanges!=null?selectionRanges:(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range);if(!ranges)return!1;const{workbookTypes,worksheetTypes,rangeTypes}=permissionTypes,permissionIds=[];return workbookTypes&&permissionIds.push(...workbookTypes.map(F=>new F(unitId).id)),worksheetTypes&&permissionIds.push(...worksheetTypes.map(F=>new F(unitId,subUnitId).id)),rangeTypes&&this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{ranges.some(range=>rule.ranges.some(r2=>core.Rectangle.intersects(r2,range)))&&permissionIds.push(...rangeTypes.map(F=>new F(unitId,subUnitId,rule.permissionId).id))}),permissionIds.length?this._permissionService.composePermission(permissionIds).every(permission=>permission.value):!0}_permissionCheckByPaste(params){return params.value===PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE||params.value===PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA?this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]}):params.value===PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT?this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]}):this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]})}_permissionCheckByMoveCommand(params){const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,toRange=params.toRange;toRange.endRow===worksheet.getRowCount()-1?toRange.endColumn=toRange.startColumn:toRange.endRow=toRange.startRow;const permissionLapRanges=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]).filter(range=>core.Rectangle.intersects(range,toRange));return permissionLapRanges.length>0?!1:(permissionLapRanges.forEach(range=>{var _a61,_b;for(let row=range.startRow;row<=range.endRow;row++)for(let col=range.startColumn;col<=range.endColumn;col++){const permission=(_b=(_a61=worksheet.getCell(row,col))==null?void 0:_a61.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!1}}),!0)}_permissionCheckByAutoFillCommand(params){if(!params)return!1;const{rows,cols}=params,startRow=rows[0],endRow=rows[rows.length-1],startCol=cols[0],endCol=cols[cols.length-1],targetRange={startRow,endRow,startColumn:startCol,endColumn:endCol},target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;return!this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]).filter(range=>core.Rectangle.intersects(range,targetRange)).some(range=>{var _a61,_b;for(let row=range.startRow;row<=range.endRow;row++)for(let col=range.startColumn;col<=range.endColumn;col++){const permission=(_b=(_a61=worksheet.getCell(row,col))==null?void 0:_a61.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!0}return!1})}_permissionCheckByMoveRangeCommand(params){const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,toRange=params.toRange,permissionLapRanges=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]).filter(range=>core.Rectangle.intersects(range,toRange));return permissionLapRanges.length>0?!1:(permissionLapRanges.forEach(range=>{var _a61,_b;for(let row=range.startRow;row<=range.endRow;row++)for(let col=range.startColumn;col<=range.endColumn;col++){const permission=(_b=(_a61=worksheet.getCell(row,col))==null?void 0:_a61.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!1}}),!0)}_permissionCheckBySetRangeValue(permissionTypes,setRangeValueParams){let ranges=[];setRangeValueParams.range?ranges=[setRangeValueParams.range]:ranges=[new core.ObjectMatrix(setRangeValueParams.value).getDataRange()];const{unitId,subUnitId}=setRangeValueParams;return this.permissionCheckWithRanges(permissionTypes,ranges,unitId,subUnitId)}_permissionCheckWithFormula(params){var _a61,_b,_c,_d,_e;const value=params.value,range=params.range,formulaString=value.f;if(formulaString){const definedNameStr=formulaString.substring(1),workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=(_a61=params.unitId)!=null?_a61:workbook.getUnitId(),definedName2=this._definedNamesService.getValueByName(unitId,definedNameStr);if(definedName2){let formulaOrRefString=definedName2.formulaOrRefString;formulaOrRefString.startsWith(engineFormula.operatorToken.EQUALS)&&(formulaOrRefString=formulaOrRefString.slice(1));const refRangesArr=formulaOrRefString.split(",");for(let i=0;i<refRangesArr.length;i++){const refRange=refRangesArr[i],sequenceGrid=engineFormula.deserializeRangeWithSheet(refRange);if(sequenceGrid.sheetName){const targetSheet=workbook.getSheetBySheetName(sequenceGrid.sheetName);if(!targetSheet)return!0;const{startRow,endRow,startColumn,endColumn}=sequenceGrid.range;for(let i2=startRow;i2<=endRow;i2++)for(let j=startColumn;j<=endColumn;j++){const permission=(_c=(_b=targetSheet.getCell(i2,j))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[D.View])===!1)return!1}}}return!0}else{const sequenceNodes=this._lexerTreeBuilder.sequenceNodesBuilder(formulaString);if(!sequenceNodes)return!0;for(let i=0;i<sequenceNodes.length;i++){const node=sequenceNodes[i];if(typeof node=="string"||node.nodeType!==engineFormula.sequenceNodeType.REFERENCE)continue;const{token}=node,sequenceGrid=engineFormula.deserializeRangeWithSheet(token),workbook2=sequenceGrid.unitId?this._univerInstanceService.getUnit(sequenceGrid.unitId):this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook2)return!0;let targetSheet=sequenceGrid.sheetName?workbook2.getSheetBySheetName(sequenceGrid.sheetName):workbook2.getActiveSheet();const unitId2=workbook2.getUnitId();if(sequenceGrid.sheetName){if(targetSheet=workbook2.getSheetBySheetName(sequenceGrid.sheetName),!targetSheet)return!0;const subUnitId=targetSheet==null?void 0:targetSheet.getSheetId();if(!this._permissionService.getPermissionPoint(new sheets.WorksheetViewPermission(unitId2,subUnitId).id))return!1}if(!targetSheet)return!0;const{startRow,endRow,startColumn,endColumn}=sequenceGrid.range;for(let i2=startRow;i2<=endRow;i2++)for(let j=startColumn;j<=endColumn;j++){const permission=(_e=(_d=targetSheet.getCell(i2,j))==null?void 0:_d.selectionProtection)==null?void 0:_e[0];if((permission==null?void 0:permission[D.View])===!1)return!1}}return!0}}if(range){const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const unitId=params.unitId||target.unitId,subunitId=params.subUnitId||target.subUnitId,permissionIds=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subunitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(ruleRange,range))).map(rule=>new sheets.RangeProtectionPermissionEditPoint(unitId,subunitId,rule.permissionId).id);if(!this._permissionService.composePermission(permissionIds).every(permission=>permission.value))return!1}return!0}},__name(_a38,"SheetPermissionInterceptorBaseController"),_a38);exports.SheetPermissionInterceptorBaseController=__decorateClass$k([__decorateParam$k(0,core.ICommandService),__decorateParam$k(1,core.IUniverInstanceService),__decorateParam$k(2,core.IPermissionService),__decorateParam$k(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$k(4,ui.IDialogService),__decorateParam$k(5,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$k(6,core.Inject(sheets.WorksheetProtectionRuleModel)),__decorateParam$k(7,IAutoFillService),__decorateParam$k(8,core.Inject(core.LocaleService)),__decorateParam$k(9,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$k(10,core.IContextService),__decorateParam$k(11,engineFormula.IDefinedNamesService)],exports.SheetPermissionInterceptorBaseController);var __defProp$j=Object.defineProperty,__getOwnPropDesc$j=Object.getOwnPropertyDescriptor,__decorateClass$j=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$j(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$j(target,key,result),result},"__decorateClass$j"),__decorateParam$j=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$j");const FREEZE_ROW_MAIN_NAME="__SpreadsheetFreezeRowMainName__",FREEZE_ROW_HEADER_NAME="__SpreadsheetFreezeRowHeaderName__",FREEZE_COLUMN_MAIN_NAME="__SpreadsheetFreezeColumnMainName__",FREEZE_COLUMN_HEADER_NAME="__SpreadsheetFreezeColumnHeaderName__",FREEZE_SIZE_NORMAL=2,AUXILIARY_CLICK_HIDDEN_OBJECT_TRANSPARENCY=.01,FREEZE_PERMISSION_CHECK=core.createInterceptorKey("freezePermissionCheck");var _a39;exports.HeaderFreezeRenderController=(_a39=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService,_selectionManagerService,_scrollManagerService,_themeService,_sheetInterceptorService,_injector){super();__publicField(this,"_rowFreezeHeaderRect");__publicField(this,"_rowFreezeMainRect");__publicField(this,"_columnFreezeHeaderRect");__publicField(this,"_columnFreezeMainRect");__publicField(this,"_freezeDownSubs");__publicField(this,"_freezePointerEnterSubs");__publicField(this,"_freezePointerLeaveSubs");__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_changeToRow",-1);__publicField(this,"_changeToColumn",-1);__publicField(this,"_changeToOffsetX",0);__publicField(this,"_changeToOffsetY",0);__publicField(this,"_activeViewport",null);__publicField(this,"_freezeNormalHeaderColor","");__publicField(this,"_freezeNormalMainColor","");__publicField(this,"_freezeActiveColor","");__publicField(this,"_freezeHoverColor","");__publicField(this,"_lastFreeze");__publicField(this,"interceptor",new core.InterceptorManager({FREEZE_PERMISSION_CHECK}));this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._selectionManagerService=_selectionManagerService,this._scrollManagerService=_scrollManagerService,this._themeService=_themeService,this._sheetInterceptorService=_sheetInterceptorService,this._injector=_injector,this._initialize()}dispose(){super.dispose()}_initialize(){this._skeletonListener(),this._commandExecutedListener(),this._themeChangeListener(),this._interceptorCommands(),this._bindViewportScroll(),this._zoomRefresh()}_createFreeze(freezeDirectionType=0,freezeConfig){var _a61;const config=freezeConfig!=null?freezeConfig:this._getFreeze();if(config==null)return null;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton,{startRow:freezeRow,startColumn:freezeColumn}=config,position=this._getPositionByIndex(freezeRow,freezeColumn);if(position==null||skeleton==null)return null;const sheetObject=this._getSheetObject(),engine=sheetObject.engine,canvasMaxWidth=(engine==null?void 0:engine.width)||0,canvasMaxHeight=(engine==null?void 0:engine.height)||0,scene=sheetObject.scene,{startX,startY}=position,{rowTotalHeight,columnTotalWidth,rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,shapeWidth=canvasMaxWidth>columnTotalWidth+rowHeaderWidthAndMarginLeft?canvasMaxWidth:columnTotalWidth+columnHeaderHeightAndMarginTop,shapeHeight=canvasMaxHeight>rowTotalHeight+columnHeaderHeightAndMarginTop?canvasMaxHeight:rowTotalHeight+columnHeaderHeightAndMarginTop;this._changeToRow=freezeRow,this._changeToColumn=freezeColumn,this._changeToOffsetX=startX,this._changeToOffsetY=startY;const scale=Math.max(scene.scaleX,scene.scaleY);let FREEZE_SIZE=FREEZE_SIZE_NORMAL/(scale<1?1:scale);if(freezeDirectionType===0){(freezeRow===-1||freezeRow===0)&&(FREEZE_SIZE=FREEZE_SIZE*2);const FREEZE_OFFSET=FREEZE_SIZE;this._rowFreezeHeaderRect=new engineRender.Rect(FREEZE_ROW_HEADER_NAME,{fill:this._freezeNormalHeaderColor,width:rowHeaderWidthAndMarginLeft,height:FREEZE_SIZE,left:0,top:startY-FREEZE_OFFSET,zIndex:3});let fill=this._freezeNormalHeaderColor;(freezeRow===-1||freezeRow===0)&&(fill=this._freezeNormalMainColor),this._rowFreezeMainRect=new engineRender.Rect(FREEZE_ROW_MAIN_NAME,{fill,width:shapeWidth*2/scale,height:FREEZE_SIZE,left:rowHeaderWidthAndMarginLeft,top:startY-FREEZE_OFFSET,zIndex:3}),scene.addObjects([this._rowFreezeHeaderRect,this._rowFreezeMainRect],SHEET_COMPONENT_HEADER_LAYER_INDEX)}else{(freezeColumn===-1||freezeColumn===0)&&(FREEZE_SIZE=FREEZE_SIZE*2);const FREEZE_OFFSET=FREEZE_SIZE;this._columnFreezeHeaderRect=new engineRender.Rect(FREEZE_COLUMN_HEADER_NAME,{fill:this._freezeNormalHeaderColor,width:FREEZE_SIZE,height:columnHeaderHeightAndMarginTop,left:startX-FREEZE_OFFSET,top:0,zIndex:3});let fill=this._freezeNormalHeaderColor;(freezeColumn===-1||freezeColumn===0)&&(fill=this._freezeNormalMainColor),this._columnFreezeMainRect=new engineRender.Rect(FREEZE_COLUMN_MAIN_NAME,{fill,width:FREEZE_SIZE,height:shapeHeight*2/scale,left:startX-FREEZE_OFFSET,top:columnHeaderHeightAndMarginTop,zIndex:3}),scene.addObjects([this._columnFreezeHeaderRect,this._columnFreezeMainRect],SHEET_COMPONENT_HEADER_LAYER_INDEX)}this._eventBinding(freezeDirectionType)}_eventBinding(freezeDirectionType=0){let freezeObjectHeaderRect=this._rowFreezeHeaderRect,freezeObjectMainRect=this._rowFreezeMainRect;freezeDirectionType===1&&(freezeObjectHeaderRect=this._columnFreezeHeaderRect,freezeObjectMainRect=this._columnFreezeMainRect);const sheetObject=this._getSheetObject();if(sheetObject==null)return;const{scene}=sheetObject;if(this._freezePointerEnterSubs=new rxjs.Subscription,this._freezePointerLeaveSubs=new rxjs.Subscription,this._freezeDownSubs=new rxjs.Subscription,freezeObjectMainRect){const _freezeObjectMainRectEnterSub=freezeObjectMainRect.onPointerEnter$.subscribeEvent(()=>{if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeHoverColor,zIndex:4}),scene.setCursor(engineRender.CURSOR_TYPE.GRAB)});this._freezePointerEnterSubs.add(_freezeObjectMainRectEnterSub);const _freezeObjectMainPointerLeaveSub=freezeObjectMainRect.onPointerLeave$.subscribeEvent(()=>{freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor,zIndex:3}),scene.resetCursor()});this._freezePointerLeaveSubs.add(_freezeObjectMainPointerLeaveSub)}if(freezeObjectHeaderRect){const _freezeObjHeaderPointerEnterSub=freezeObjectHeaderRect.onPointerEnter$.subscribeEvent(()=>{if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeHoverColor,zIndex:4}),scene.setCursor(engineRender.CURSOR_TYPE.GRAB)});this._freezePointerEnterSubs.add(_freezeObjHeaderPointerEnterSub);const _freezeObjHeaderPointerLeaveSub=freezeObjectHeaderRect.onPointerLeave$.subscribeEvent(()=>{freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor,zIndex:3}),scene.resetCursor()});this._freezePointerLeaveSubs.add(_freezeObjHeaderPointerLeaveSub)}const s1=freezeObjectHeaderRect==null?void 0:freezeObjectHeaderRect.onPointerDown$.subscribeEvent(evt=>{this._freezeDown(evt,freezeObjectHeaderRect,freezeObjectMainRect,freezeDirectionType)});s1&&this._freezeDownSubs.add(s1);const s2=freezeObjectMainRect==null?void 0:freezeObjectMainRect.onPointerDown$.subscribeEvent(evt=>{this._freezeDown(evt,freezeObjectHeaderRect,freezeObjectMainRect,freezeDirectionType)});s2&&this._freezeDownSubs.add(s2)}_getCurrentLastVisible(){var _a61,_b,_c,_d,_e,_f,_g;const sheetObject=this._getSheetObject();if(sheetObject==null)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const scene=sheetObject.scene,scale=Math.max(scene.scaleX,scene.scaleY),currentScroll=this._scrollManagerService.getCurrentScrollState(),skeletonViewHeight=(sheetObject.engine.height-skeleton.columnHeaderHeight)/scale,skeletonViewWidth=(sheetObject.engine.width-skeleton.rowHeaderWidth)/scale,startRow=(_b=currentScroll==null?void 0:currentScroll.sheetViewStartRow)!=null?_b:0,startHeight=startRow===0?-((_c=currentScroll==null?void 0:currentScroll.offsetY)!=null?_c:0):skeleton.rowHeightAccumulation[startRow-1]-((_d=currentScroll==null?void 0:currentScroll.offsetY)!=null?_d:0);let lastRow=0,hadFind=!1;for(let i=startRow,len=skeleton.rowHeightAccumulation.length;i<len;i++)if(skeleton.rowHeightAccumulation[i]-startHeight>skeletonViewHeight){lastRow=i,hadFind=!0;break}hadFind||(lastRow=skeleton.rowHeightAccumulation.length-1);const startColumn=(_e=currentScroll==null?void 0:currentScroll.sheetViewStartColumn)!=null?_e:0,startWidth=startColumn===0?-((_f=currentScroll==null?void 0:currentScroll.offsetX)!=null?_f:0):skeleton.columnWidthAccumulation[startColumn-1]-((_g=currentScroll==null?void 0:currentScroll.offsetX)!=null?_g:0);let lastColumn=0,hadFindCol=!1;for(let i=startColumn,len=skeleton.columnWidthAccumulation.length;i<len;i++)if(skeleton.columnWidthAccumulation[i]-startWidth>skeletonViewWidth){lastColumn=i,hadFindCol=!0;break}return hadFindCol||(lastColumn=skeleton.columnWidthAccumulation.length-1),{lastRow,lastColumn}}_getActiveViewport(evt){var _a61;const viewports=(_a61=this._getSheetObject())==null?void 0:_a61.scene.getViewports();return viewports&&viewports.find(i=>i.isHit(new engineRender.Vector2(evt.offsetX,evt.offsetY)))||null}_freezeDown(evt,freezeObjectHeaderRect,freezeObjectMainRect,freezeDirectionType=0){var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const sheetObject=this._getSheetObject();if(sheetObject==null)return;if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;const{scene}=sheetObject;scene.setCursor(engineRender.CURSOR_TYPE.GRABBING),scene.disableObjectsEvent();const last=this._getCurrentLastVisible(),lastRowY=last===void 0?Number.POSITIVE_INFINITY:skeleton.rowHeightAccumulation[last.lastRow],lastColumnX=last===void 0?Number.POSITIVE_INFINITY:skeleton.columnWidthAccumulation[last.lastColumn-1]+skeleton.rowHeaderWidth;this._activeViewport=null;const oldFreeze=this._getFreeze();oldFreeze&&(this._changeToColumn=oldFreeze.startColumn,this._changeToRow=oldFreeze.startRow),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a62,_b,_c,_d;const activeViewport=this._getActiveViewport(moveEvt),{startX,startY,row,column}=getCoordByOffset(moveEvt.offsetX,moveEvt.offsetY,scene,skeleton,activeViewport||void 0,!0);if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;scene.setCursor(engineRender.CURSOR_TYPE.GRABBING);const FREEZE_SIZE=FREEZE_SIZE_NORMAL/Math.max(scene.scaleX,scene.scaleY);freezeDirectionType===0?((_a62=freezeObjectHeaderRect.transformByState({top:Math.min(startY,lastRowY)-FREEZE_SIZE/2}))==null||_a62.setProps({fill:this._freezeActiveColor}),(_b=freezeObjectMainRect.transformByState({top:Math.min(startY,lastRowY)-FREEZE_SIZE/2}))==null||_b.setProps({fill:this._freezeNormalHeaderColor}),this._changeToRow=last===void 0?row:Math.min(row,last.lastRow),this._changeToOffsetY=Math.min(startY,lastRowY),this._activeViewport=activeViewport):((_c=freezeObjectHeaderRect.transformByState({left:Math.min(startX,lastColumnX)-FREEZE_SIZE/2}))==null||_c.setProps({fill:this._freezeActiveColor}),(_d=freezeObjectMainRect.transformByState({left:Math.min(startX,lastColumnX)-FREEZE_SIZE/2}))==null||_d.setProps({fill:this._freezeNormalHeaderColor}),this._changeToColumn=last===void 0?column:Math.min(column,last.lastColumn),this._changeToOffsetX=startX,this._activeViewport=activeViewport)}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a62,_b;scene.resetCursor(),scene.enableObjectsEvent(),this._clearObserverEvent();const{rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton;freezeDirectionType===0&&(this._changeToRow===0||this._changeToRow===-1)||freezeDirectionType===1&&(this._changeToColumn===0||this._changeToColumn===-1)?(freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor}),freezeObjectMainRect.setProps({fill:this._freezeNormalMainColor})):(freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor}),freezeObjectMainRect==null||freezeObjectMainRect.setProps({fill:this._freezeNormalHeaderColor}));const FREEZE_SIZE=FREEZE_SIZE_NORMAL/Math.max(scene.scaleX,scene.scaleY);freezeDirectionType===0?(this._changeToRow===0||this._changeToRow===-1)&&(freezeObjectHeaderRect.transformByState({top:columnHeaderHeightAndMarginTop-FREEZE_SIZE}),freezeObjectMainRect.transformByState({top:columnHeaderHeightAndMarginTop-FREEZE_SIZE})):(this._changeToColumn===0||this._changeToColumn===-1)&&(freezeObjectHeaderRect.transformByState({left:rowHeaderWidthAndMarginLeft-FREEZE_SIZE}),freezeObjectMainRect.transformByState({left:rowHeaderWidthAndMarginLeft-FREEZE_SIZE}));const sheetViewScroll=this._scrollManagerService.getCurrentScrollState()||{sheetViewStartRow:0,sheetViewStartColumn:0},{sheetViewStartRow,sheetViewStartColumn}=sheetViewScroll;if(sheetViewStartColumn==null||sheetViewStartRow==null)return;const workbook=this._context.unit,worksheet=workbook.getActiveSheet();if(!worksheet)return;const oldFreeze2=(_a62=worksheet.getConfig())==null?void 0:_a62.freeze;let xSplit=(oldFreeze2==null?void 0:oldFreeze2.xSplit)||0,ySplit=(oldFreeze2==null?void 0:oldFreeze2.ySplit)||0;const viewPortKey=(_b=this._activeViewport)==null?void 0:_b.viewportKey;freezeDirectionType===0&&(!viewPortKey||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP?ySplit=this._changeToRow-(oldFreeze2.startRow-oldFreeze2.ySplit):ySplit=this._changeToRow-sheetViewStartRow,ySplit=ySplit<0?0:ySplit),freezeDirectionType===1&&(!viewPortKey||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT?xSplit=this._changeToColumn-(oldFreeze2.startColumn-oldFreeze2.xSplit):xSplit=this._changeToColumn-sheetViewStartColumn,xSplit=xSplit<0?0:xSplit),this._commandService.executeCommand(sheets.SetFrozenCommand.id,{startRow:ySplit===0?-1:this._changeToRow,startColumn:xSplit===0?-1:this._changeToColumn,ySplit,xSplit,unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId()})})}_getViewports(){const sheetObject=this._getSheetObject();if(sheetObject==null)return;const{scene}=sheetObject,viewColumnLeft=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT),viewColumnRight=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT),viewRowTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP),viewRowBottom=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM),viewLeftTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP),viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),viewMainLeftTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP),viewMainLeft=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT),viewMainTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP);if(!(viewColumnLeft==null||viewColumnRight==null||viewRowTop==null||viewRowBottom==null||viewLeftTop==null||viewMain==null||viewMainLeftTop==null||viewMainLeft==null||viewMainTop==null))return{viewMain,viewMainLeftTop,viewMainLeft,viewMainTop,viewColumnLeft,viewColumnRight,viewRowTop,viewRowBottom,viewLeftTop}}_bindViewportScroll(){const viewports=this._getViewports();if(!viewports)return;const{viewRowBottom,viewColumnRight,viewMainLeft,viewMainTop}=viewports;this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(param=>{if(!param)return;const{scrollX,scrollY,viewportScrollX,viewportScrollY}=param;viewRowBottom.isActive&&viewRowBottom.updateScrollVal({scrollY,viewportScrollY}),viewColumnRight.isActive&&viewColumnRight.updateScrollVal({scrollX,viewportScrollX}),viewMainLeft.isActive&&viewMainLeft.updateScrollVal({scrollY,viewportScrollY}),viewMainTop.isActive&&viewMainTop.updateScrollVal({scrollX,viewportScrollX})}))}_updateViewport(row=-1,column=-1,ySplit=0,xSplit=0,resetScroll=3){var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const{rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,viewports=this._getViewports();if(!viewports)return;const{viewMain,viewMainLeftTop,viewMainLeft,viewMainTop,viewColumnLeft,viewColumnRight,viewRowTop,viewRowBottom,viewLeftTop}=viewports;viewColumnRight.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:0,height:columnHeaderHeightAndMarginTop,right:0}),viewRowBottom.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop,bottom:0,width:rowHeaderWidthAndMarginLeft}),viewLeftTop.resizeWhenFreezeChange({left:0,top:0,width:rowHeaderWidthAndMarginLeft,height:columnHeaderHeightAndMarginTop});let isTopView=!0,isLeftView=!0;viewMainLeftTop.enable(),(row===-1||row===0)&&(isTopView=!1),(column===-1||column===0)&&(isLeftView=!1);const startSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(row-ySplit,column-xSplit),endSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(row,column);if(viewMainLeftTop.disable(),viewMainTop.disable(),viewMainLeft.disable(),viewRowTop.disable(),viewColumnLeft.disable(),viewMainLeftTop.resetPadding(),viewMainTop.resetPadding(),viewMainLeft.resetPadding(),viewRowTop.resetPadding(),viewColumnLeft.resetPadding(),isTopView===!1&&isLeftView===!1)viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,bottom:0,right:0}),viewMain.resetPadding();else if(isTopView===!0&&isLeftView===!1){const topGap=endSheetView.startY-startSheetView.startY;viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,right:0}),viewMain.setPadding({startY:startSheetView.startY,endY:endSheetView.startY,startX:0,endX:0}),resetScroll&2&&this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartRow:0,offsetY:0}),viewMainTop.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,height:topGap,right:0}),viewMainTop.updateScrollVal({viewportScrollY:startSheetView.startY,rawScrollX:viewMain.scrollX,viewportScrollX:viewMain.viewportScrollX}),viewRowTop.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop,width:rowHeaderWidthAndMarginLeft,height:topGap}),viewRowTop.updateScrollVal({viewportScrollY:startSheetView.startY}),viewRowBottom.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,width:rowHeaderWidthAndMarginLeft}),viewMainTop.enable(),viewRowTop.enable()}else if(isTopView===!1&&isLeftView===!0){const leftGap=endSheetView.startX-startSheetView.startX;viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:columnHeaderHeightAndMarginTop,bottom:0,right:0}),viewMain.setPadding({startX:startSheetView.startX,endX:endSheetView.startX,startY:0,endY:0}),resetScroll&1&&this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartColumn:0,offsetX:0}),viewMainLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,width:leftGap,bottom:0,right:0}),viewMainLeft.updateScrollVal({viewportScrollX:startSheetView.startX,rawScrollY:viewMain.scrollY,viewportScrollY:viewMain.viewportScrollY}),viewColumnLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:0,width:leftGap,height:columnHeaderHeightAndMarginTop}),viewColumnLeft.updateScrollVal({viewportScrollX:startSheetView.startX}),viewColumnRight.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:0,height:columnHeaderHeightAndMarginTop,right:0}),viewMainLeft.enable(),viewColumnLeft.enable()}else{const leftGap=endSheetView.startX-startSheetView.startX,topGap=endSheetView.startY-startSheetView.startY;viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,right:0}),viewMain.setPadding({startY:startSheetView.startY,endY:endSheetView.startY,startX:startSheetView.startX,endX:endSheetView.startX}),resetScroll&&this._commandService.executeCommand(ScrollCommand.id,{...resetScroll&1?{sheetViewStartColumn:0,offsetX:0}:null,...resetScroll&2?{sheetViewStartRow:0,offsetY:0}:null}),viewMainLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop+topGap,width:leftGap,bottom:0}),viewMainLeft.updateScrollVal({viewportScrollX:startSheetView.startX,rawScrollY:viewMain.scrollY,viewportScrollY:viewMain.viewportScrollY}),viewMainTop.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:columnHeaderHeightAndMarginTop,height:topGap,right:0}),viewMainTop.updateScrollVal({viewportScrollY:startSheetView.startY,rawScrollX:viewMain.scrollX,viewportScrollX:viewMain.viewportScrollX}),viewMainLeftTop.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,width:leftGap,height:topGap}),viewMainLeftTop.updateScrollVal({viewportScrollX:startSheetView.startX,viewportScrollY:startSheetView.startY}),viewRowTop.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop,width:rowHeaderWidthAndMarginLeft,height:topGap}),viewRowTop.updateScrollVal({viewportScrollY:startSheetView.startY}),viewRowBottom.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,width:rowHeaderWidthAndMarginLeft}),viewColumnLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:0,width:leftGap,height:columnHeaderHeightAndMarginTop}),viewColumnLeft.updateScrollVal({viewportScrollX:startSheetView.startX}),viewColumnRight.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:0,height:columnHeaderHeightAndMarginTop,right:0}),viewMainLeftTop.enable(),viewMainTop.enable(),viewMainLeft.enable(),viewRowTop.enable(),viewColumnLeft.enable()}}_skeletonListener(){this.disposeWithMe(core.toDisposable(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{[sheets.SetWorksheetActiveOperation.id,sheets.InsertRangeMoveDownCommand.id,sheets.InsertRangeMoveRightCommand.id].includes((param==null?void 0:param.commandId)||"")&&this._refreshCurrent()})))}_refreshCurrent(){const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const freeze=worksheet.getConfig().freeze,{startRow=-1,startColumn=-1,ySplit=0,xSplit=0}=freeze;this._refreshFreeze(startRow,startColumn,ySplit,xSplit,0)}_themeChangeListener(){this._themeChange(this._themeService.getCurrentTheme()),this.disposeWithMe(this._themeService.currentTheme$.subscribe(style=>{this._clearFreeze(),this._themeChange(style),this._refreshCurrent()}))}_themeChange(style){this._freezeNormalHeaderColor=style.grey400,this._freezeNormalMainColor=new core.ColorKit(style.grey400).setAlpha(AUXILIARY_CLICK_HIDDEN_OBJECT_TRANSPARENCY).toRgbString(),this._freezeActiveColor=style.primaryColor,this._freezeHoverColor=style.grey500}_interceptorCommands(){this.disposeWithMe(this._sheetInterceptorService.interceptCommand({getMutations:__name(command=>{const empty={redos:[],undos:[]},freeze=this._getFreeze();if(!freeze)return empty;const createFreezeMutationAndRefresh=__name(newFreeze=>{const workbook=this._context.unit,unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return empty;const subUnitId=worksheet.getSheetId();this._refreshFreeze(newFreeze.startRow,newFreeze.startColumn,newFreeze.ySplit,newFreeze.xSplit,0);const redoMutationParams={...newFreeze,unitId,subUnitId,resetScroll:!1},undoMutationParams=sheets.SetFrozenMutationFactory(this._injector,redoMutationParams);return{undos:[{id:sheets.SetFrozenMutation.id,params:undoMutationParams}],redos:[{id:sheets.SetFrozenMutation.id,params:redoMutationParams}]}},"createFreezeMutationAndRefresh");if(command.id===sheets.InsertRowCommand.id){const params=command.params,{range,direction}=params,insertCount=range.endRow-range.startRow+1;if(range.startRow+1<freeze.startRow||range.startRow+1===freeze.startRow&&direction===core.Direction.UP){const newFreeze={...freeze,startRow:Math.max(1,freeze.startRow+insertCount),ySplit:Math.max(1,freeze.ySplit+insertCount)};return createFreezeMutationAndRefresh(newFreeze)}}if(command.id===sheets.InsertColCommand.id){const params=command.params,{range,direction}=params,insertCount=range.endColumn-range.startColumn+1;if(range.startColumn+1<freeze.startColumn||range.startColumn+1===freeze.startColumn&&direction===core.Direction.LEFT){const newFreeze={...freeze,startColumn:Math.max(1,freeze.startColumn+insertCount),xSplit:Math.max(1,freeze.xSplit+insertCount)};return createFreezeMutationAndRefresh(newFreeze)}}if(command.id===sheets.MoveColsCommand.id){const selections=this._selectionManagerService.getCurrentSelections(),{fromRange:{startColumn:fromCol},toRange:{startColumn:toCol}}=command.params,filteredSelections=selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.COLUMN&&selection.range.startColumn<=fromCol&&fromCol<=selection.range.endColumn);if(!(filteredSelections!=null&&filteredSelections.length))return empty;const sourceRange=filteredSelections[0].range,targetRange={...sourceRange,startColumn:toCol,endColumn:toCol+sourceRange.endColumn-sourceRange.startColumn};if(!freeze||freeze.startColumn<=0||sourceRange.startColumn>=freeze.startColumn&&targetRange.startColumn>=freeze.startColumn||sourceRange.startColumn===targetRange.startColumn||sourceRange.endColumn<freeze.startColumn&&targetRange.startColumn<freeze.startColumn)return empty;const totalColCount=sourceRange.endColumn-sourceRange.startColumn+1,moveFreezeColCount=Math.max(Math.min(freeze.startColumn,sourceRange.endColumn+1)-sourceRange.startColumn,0);let newStartColumn,newXSplit;targetRange.startColumn>=freeze.startColumn?(newStartColumn=Math.max(freeze.startColumn-moveFreezeColCount,1),newXSplit=Math.max(freeze.xSplit-moveFreezeColCount,1)):(newStartColumn=freeze.startColumn+totalColCount-moveFreezeColCount,newXSplit=freeze.xSplit+totalColCount-moveFreezeColCount);const redoMutationParams={...freeze,startColumn:newStartColumn,xSplit:newXSplit};return createFreezeMutationAndRefresh(redoMutationParams)}if(command.id===sheets.MoveRowsCommand.id){const selections=this._selectionManagerService.getCurrentSelections(),{fromRange:{startRow:fromRow},toRange:{startRow:toRow}}=command.params,filteredSelections=selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.ROW&&selection.range.startRow<=fromRow&&fromRow<=selection.range.endRow);if(!(filteredSelections!=null&&filteredSelections.length))return empty;const sourceRange=filteredSelections[0].range,targetRange={...sourceRange,startRow:toRow,endRow:toRow+sourceRange.endRow-sourceRange.startRow};if(!freeze||freeze.startRow<=0||sourceRange.startRow>=freeze.startRow&&targetRange.startRow>=freeze.startRow||sourceRange.startRow===targetRange.startRow||sourceRange.endRow<freeze.startRow&&targetRange.startRow<freeze.startRow)return empty;const totalColCount=sourceRange.endRow-sourceRange.startRow+1,moveFreezeColCount=Math.max(Math.min(freeze.startRow,sourceRange.endRow+1)-sourceRange.startRow,0);let newStartRow,newYSplit;targetRange.startRow>=freeze.startRow?(newStartRow=Math.max(freeze.startRow-moveFreezeColCount,1),newYSplit=Math.max(freeze.ySplit-moveFreezeColCount,1)):(newStartRow=freeze.startRow+totalColCount-moveFreezeColCount,newYSplit=freeze.ySplit+totalColCount-moveFreezeColCount);const redoMutationParams={...freeze,startRow:newStartRow,ySplit:newYSplit};return createFreezeMutationAndRefresh(redoMutationParams)}if(command.id===sheets.RemoveColCommand.id||command.id===sheets.RemoveRowCommand.id){const params=command.params,range=params.range;if(range.rangeType===core.RANGE_TYPE.COLUMN&&range.startColumn<freeze.startColumn){const deleteFreezeColCount=Math.min(freeze.startColumn,range.endColumn+1)-range.startColumn,newFreeze={...freeze,startColumn:Math.max(1,freeze.startColumn-deleteFreezeColCount),xSplit:Math.max(1,freeze.xSplit-deleteFreezeColCount)};return createFreezeMutationAndRefresh(newFreeze)}if(params.range.rangeType===core.RANGE_TYPE.ROW&&range.startRow<freeze.startRow){const deleteFreezeRowCount=Math.min(freeze.startRow,range.endRow+1)-range.startRow,newFreeze={...freeze,startRow:Math.max(1,freeze.startRow-deleteFreezeRowCount),ySplit:Math.max(1,freeze.ySplit-deleteFreezeRowCount)};return createFreezeMutationAndRefresh(newFreeze)}}return empty},"getMutations")}))}_commandExecutedListener(){const updateCommandList=[sheets.SetFrozenMutation.id,SetZoomRatioOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(updateCommandList.includes(command.id)){const lastFreeze=this._lastFreeze,workbook=this._context.unit,worksheet=workbook.getActiveSheet(),params=command.params,{unitId,subUnitId}=params;if(!(unitId===workbook.getUnitId()&&subUnitId===(worksheet==null?void 0:worksheet.getSheetId())))return;const freeze=worksheet.getConfig().freeze;if(this._lastFreeze=freeze,freeze==null)return;let resetScroll=0;const{startRow=-1,startColumn=-1,ySplit=0,xSplit=0}=freeze;(!lastFreeze||lastFreeze.startRow!==startRow||lastFreeze.ySplit!==ySplit)&&(resetScroll|=2),(!lastFreeze||lastFreeze.startColumn!==startColumn||lastFreeze.xSplit!==xSplit)&&(resetScroll|=1),params.resetScroll===!1&&(resetScroll=0),this._refreshFreeze(startRow,startColumn,ySplit,xSplit,resetScroll)}else if(command.id===sheets.SetWorksheetRowHeightMutation.id){const freeze=this._getFreeze(),isRefresh=freeze&&command.params.ranges.some(i=>i.startRow<freeze.startRow);command.params&&isRefresh&&this._refreshCurrent()}else if(command.id===sheets.SetWorksheetColWidthMutation.id){const freeze=this._getFreeze();command.params&&freeze&&command.params.ranges.some(i=>i.startColumn<freeze.startColumn)&&this._refreshCurrent()}else if(command.id===sheets.SetWorksheetRowAutoHeightMutation.id){const params=command.params,freeze=this._getFreeze();if(freeze&&freeze.startRow>-1&&params.rowsAutoHeightInfo.some(info=>info.row<freeze.startRow)){const subscription=this._sheetSkeletonManagerService.currentSkeleton$.subscribe(()=>{this._refreshCurrent(),setTimeout(()=>{subscription.unsubscribe()})})}}else if(command.id===sheets.SetColHiddenMutation.id||command.id===sheets.SetColVisibleMutation.id){const params=command.params,freeze=this._getFreeze(),ranges=params.ranges;freeze&&freeze.startColumn>-1&&ranges.some(range=>range.startColumn<freeze.startColumn)&&this._refreshCurrent()}else if(command.id===sheets.SetRowHiddenMutation.id||command.id===sheets.SetRowVisibleMutation.id){const params=command.params,freeze=this._getFreeze(),ranges=params.ranges;freeze&&freeze.startRow>-1&&ranges.some(range=>range.startRow<freeze.startRow)&&this._refreshCurrent()}}))}_zoomRefresh(){const sheetObject=this._getSheetObject();if(sheetObject==null)return;const{scene}=sheetObject;scene.onTransformChange$.subscribeEvent(state=>{state.type===engineRender.TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale&&this._refreshCurrent()})}_clearObserverEvent(){var _a61,_b;this._getSheetObject()!=null&&((_a61=this._scenePointerMoveSub)==null||_a61.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null)}_clearFreeze(){var _a61,_b,_c,_d,_e,_f;(_a61=this._rowFreezeHeaderRect)==null||_a61.dispose(),(_b=this._rowFreezeMainRect)==null||_b.dispose(),(_c=this._columnFreezeHeaderRect)==null||_c.dispose(),(_d=this._columnFreezeMainRect)==null||_d.dispose(),this._getSheetObject()!=null&&([this._freezeDownSubs,this._freezePointerEnterSubs,this._freezePointerLeaveSubs].forEach(s=>{s==null||s.unsubscribe()}),this._freezeDownSubs=null,this._freezePointerEnterSubs=null,this._freezePointerLeaveSubs=null,(_e=this._scenePointerMoveSub)==null||_e.unsubscribe(),(_f=this._scenePointerUpSub)==null||_f.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null)}_getPositionByIndex(row,column){var _a61;if(this._getSheetObject()==null)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton,position=skeleton==null?void 0:skeleton.getNoMergeCellPositionByIndex(row,column);if(skeleton==null)return;if(position!=null&&(!isNaN(position.endX)||!isNaN(position.endY)))return position;const{rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton;return{startX:rowHeaderWidthAndMarginLeft,endX:rowHeaderWidthAndMarginLeft,startY:columnHeaderHeightAndMarginTop,endY:columnHeaderHeightAndMarginTop}}_getFreeze(){var _a61;const config=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton.getWorksheetConfig();if(config!=null)return config.freeze}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_refreshFreeze(startRow,startColumn,ySplit,xSplit,resetScroll){var _a61;const newFreeze={startRow,startColumn,ySplit,xSplit};this._clearFreeze(),this._createFreeze(0,newFreeze),this._createFreeze(1,newFreeze),this._updateViewport(startRow,startColumn,ySplit,xSplit,resetScroll),(_a61=this._getSheetObject())==null||_a61.spreadsheet.makeForceDirty()}},__name(_a39,"HeaderFreezeRenderController"),_a39);exports.HeaderFreezeRenderController=__decorateClass$j([__decorateParam$j(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$j(2,core.ICommandService),__decorateParam$j(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$j(4,core.Inject(SheetScrollManagerService)),__decorateParam$j(5,core.Inject(core.ThemeService)),__decorateParam$j(6,core.Inject(sheets.SheetInterceptorService)),__decorateParam$j(7,core.Inject(core.Injector))],exports.HeaderFreezeRenderController);var __defProp$i=Object.defineProperty,__getOwnPropDesc$i=Object.getOwnPropertyDescriptor,__decorateClass$i=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$i(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$i(target,key,result),result},"__decorateClass$i"),__decorateParam$i=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$i");const HEADER_MOVE_CONTROLLER_BACKGROUND="__SpreadsheetHeaderMoveControllerBackground__",HEADER_MOVE_CONTROLLER_LINE="__SpreadsheetHeaderMoveControllerShapeLine__",HEADER_MOVE_CONTROLLER_BACKGROUND_FILL="rgba(0, 0, 0, 0.1)",HEADER_MOVE_CONTROLLER_LINE_FILL="rgb(119, 119, 119)",HEADER_MOVE_CONTROLLER_LINE_SIZE=4,HEADER_MOVE_PERMISSION_CHECK=core.createInterceptorKey("headerMovePermissionCheck");var _a40;exports.HeaderMoveRenderController=(_a40=class extends core.Disposable{constructor(_context,selectionManagerService,_sheetSkeletonManagerService,_commandService){super();__publicField(this,"_startOffsetX",Number.NEGATIVE_INFINITY);__publicField(this,"_startOffsetY",Number.NEGATIVE_INFINITY);__publicField(this,"_moveHelperBackgroundShape");__publicField(this,"_moveHelperLineShape");__publicField(this,"_headerPointerDownSubs");__publicField(this,"_headerPointerMoveSubs");__publicField(this,"_headerPointerLeaveSubs");__publicField(this,"_dragHeaderMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_scrollTimer");__publicField(this,"_changeFromColumn",-1);__publicField(this,"_changeFromRow",-1);__publicField(this,"_changeToColumn",-1);__publicField(this,"_changeToRow",-1);__publicField(this,"interceptor",new core.InterceptorManager({HEADER_MOVE_PERMISSION_CHECK}));__publicField(this,"_workbookSelections");this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._workbookSelections=selectionManagerService.getWorkbookSelections(this._context.unitId),this._init()}dispose(){var _a61,_b,_c,_d,_e,_f,_g,_h;(_a61=this._moveHelperBackgroundShape)==null||_a61.dispose(),(_b=this._moveHelperLineShape)==null||_b.dispose(),(_c=this._headerPointerMoveSubs)==null||_c.unsubscribe(),(_d=this._headerPointerLeaveSubs)==null||_d.unsubscribe(),(_e=this._headerPointerDownSubs)==null||_e.unsubscribe(),this._headerPointerMoveSubs=null,this._headerPointerLeaveSubs=null,this._headerPointerDownSubs=null,(_f=this._dragHeaderMoveSub)==null||_f.unsubscribe(),(_g=this._scenePointerUpSub)==null||_g.unsubscribe(),this._dragHeaderMoveSub=null,this._scenePointerUpSub=null,(_h=this._scrollTimer)==null||_h.dispose()}_init(){this._initialRowOrColumn(core.RANGE_TYPE.ROW),this._initialRowOrColumn(core.RANGE_TYPE.COLUMN)}_initialRowOrColumn(initialType=core.RANGE_TYPE.ROW){const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetRowHeader=this._context.components.get(SHEET_VIEW_KEY.ROW),scene=this._context.scene,eventBindingObject=initialType===core.RANGE_TYPE.ROW?spreadsheetRowHeader:spreadsheetColumnHeader,pointerMoveHandler=__name(evt=>{var _a61,_b;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const selectionRange=(_b=this._workbookSelections.getCurrentLastSelection())==null?void 0:_b.range;if(!selectionRange||!this.interceptor.fetchThroughInterceptors(HEADER_MOVE_PERMISSION_CHECK)(!1,selectionRange))return;const currentSelections=this._workbookSelections.getCurrentSelections(),{row,column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);if(!matchedSelectionByRowColIndex(currentSelections,initialType===core.RANGE_TYPE.ROW?row:column,initialType)){scene.resetCursor();return}scene.setCursor(engineRender.CURSOR_TYPE.GRAB)},"pointerMoveHandler"),pointerLeaveHandler=__name(()=>{var _a61,_b;(_a61=this._moveHelperBackgroundShape)==null||_a61.hide(),(_b=this._moveHelperLineShape)==null||_b.hide(),scene.resetCursor()},"pointerLeaveHandler"),pointerDownHandler=__name((evt,state)=>{var _a61,_b;if(state.isStopPropagation)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const selectionRange=(_b=this._workbookSelections.getCurrentLastSelection())==null?void 0:_b.range;if(!selectionRange||!this.interceptor.fetchThroughInterceptors(HEADER_MOVE_PERMISSION_CHECK)(!1,selectionRange))return;const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords;this._startOffsetX=newEvtOffsetX,this._startOffsetY=newEvtOffsetY;const{row,column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);let scrollType;initialType===core.RANGE_TYPE.ROW?(this._changeFromRow=row,scrollType=engineRender.ScrollTimerType.Y):(this._changeFromColumn=column,scrollType=engineRender.ScrollTimerType.X);const currentSelections=this._workbookSelections.getCurrentSelections(),matchSelectionData=matchedSelectionByRowColIndex(currentSelections,initialType===core.RANGE_TYPE.ROW?row:column,initialType);if(!matchSelectionData)return;const startScrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startOffsetX,this._startOffsetY]));this._newBackgroundAndLine(),scene.setCursor(engineRender.CURSOR_TYPE.GRABBING),scene.disableObjectsEvent();let scrollTimerInitd=!1,scrollTimer;const initScrollTimer=__name(()=>{if(scrollTimerInitd)return;scrollTimer=engineRender.ScrollTimer.create(scene,scrollType),this._scrollTimer=scrollTimer;const mainViewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY,mainViewport),scrollTimerInitd=!0},"initScrollTimer");this._dragHeaderMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{initScrollTimer();const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._rowColumnMoving(newMoveOffsetX,newMoveOffsetY,matchSelectionData,startScrollXY,initialType),scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._rowColumnMoving(newMoveOffsetX,newMoveOffsetY,matchSelectionData,startScrollXY,initialType)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a62,_b2,_c;this._disposeBackgroundAndLine(),scene.resetCursor(),scene.enableObjectsEvent(),this._clearObserverEvent(),(_a62=this._scrollTimer)==null||_a62.dispose();const selections=this._workbookSelections.getCurrentSelections();if(initialType===core.RANGE_TYPE.ROW){if(this._changeFromRow!==this._changeToRow&&this._changeToRow!==-1){const range=(_b2=((selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.ROW&&selection.range.startRow<=this._changeFromRow&&this._changeFromRow<=selection.range.endRow))||[])[0])==null?void 0:_b2.range;range&&this._commandService.executeCommand(sheets.MoveRowsCommand.id,{fromRange:range,toRange:{...range,startRow:this._changeToRow,endRow:this._changeToRow+range.endRow-range.startRow}})}this._changeToRow=this._changeFromRow=-1}else{if(this._changeFromColumn!==this._changeToColumn&&this._changeToColumn!==-1){const range=(_c=((selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.COLUMN&&selection.range.startColumn<=this._changeFromColumn&&this._changeFromColumn<=selection.range.endColumn))||[])[0])==null?void 0:_c.range;range&&this._commandService.executeCommand(sheets.MoveColsCommand.id,{fromRange:range,toRange:{...range,startColumn:this._changeToColumn,endColumn:this._changeToColumn+range.endColumn-range.startColumn}})}this._changeToColumn=this._changeFromColumn=-1}})},"pointerDownHandler");this._headerPointerMoveSubs=new rxjs.Subscription,this._headerPointerMoveSubs.add(eventBindingObject.onPointerMove$.subscribeEvent(pointerMoveHandler)),this._headerPointerLeaveSubs=new rxjs.Subscription,this._headerPointerLeaveSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerLeave$.subscribeEvent(pointerLeaveHandler)),this._headerPointerDownSubs=new rxjs.Subscription,this._headerPointerDownSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerDown$.subscribeEvent(pointerDownHandler))}_rowColumnMoving(moveOffsetX,moveOffsetY,matchSelectionData,startScrollXY,initialType){var _a61,_b,_c,_d,_e,_f,_g;const scene=this._context.scene,skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const{rowHeaderWidth,columnHeaderHeight,rowTotalHeight,columnTotalWidth}=skeleton,scrollXY=scene.getViewportScrollXY(scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN)),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,startCell=skeleton.getNoMergeCellPositionByIndex(row,column),{startX:cellStartX,startY:cellStartY,endX:cellEndX,endY:cellEndY}=startCell,selectionWithCoord=this._sheetSkeletonManagerService.attachRangeWithCoord(matchSelectionData.range);if(selectionWithCoord==null)return;const scale=Math.max(scaleX,scaleX),{startX:selectedStartX,endX:selectedEndX,startY:selectedStartY,endY:selectedEndY,startRow:selectedStartRow,startColumn:selectedStartColumn,endRow:selectedEndRow,endColumn:selectedEndColumn}=selectionWithCoord;initialType===core.RANGE_TYPE.ROW?(_b=this._moveHelperBackgroundShape)==null||_b.transformByState({height:selectedEndY-selectedStartY,width:columnTotalWidth+rowHeaderWidth,left:0,top:selectedStartY+(moveOffsetY-this._startOffsetY)/scale+scrollXY.y-startScrollXY.y}):(_c=this._moveHelperBackgroundShape)==null||_c.transformByState({height:rowTotalHeight+columnHeaderHeight,width:selectedEndX-selectedStartX,left:selectedStartX+(moveOffsetX-this._startOffsetX)/scale+scrollXY.x-startScrollXY.x,top:0}),(_d=this._moveHelperBackgroundShape)==null||_d.show();const HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE=HEADER_MOVE_CONTROLLER_LINE_SIZE/scale;if(initialType===core.RANGE_TYPE.ROW){let top=0;if(row<=selectedStartRow)top=cellStartY-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToRow=row;else if(row>selectedEndRow)top=cellEndY-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToRow=row+1;else return;(_e=this._moveHelperLineShape)==null||_e.transformByState({height:HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE,width:columnTotalWidth,left:rowHeaderWidth,top})}else{let left=0;if(column<=selectedStartColumn)left=cellStartX-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToColumn=column;else if(column>selectedEndColumn)left=cellEndX-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToColumn=column+1;else return;(_f=this._moveHelperLineShape)==null||_f.transformByState({height:rowTotalHeight,width:HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE,left,top:columnHeaderHeight})}(_g=this._moveHelperLineShape)==null||_g.show()}_clearObserverEvent(){var _a61,_b;(_a61=this._dragHeaderMoveSub)==null||_a61.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._dragHeaderMoveSub=null,this._scenePointerUpSub=null}_newBackgroundAndLine(){const scene=this._context.scene;this._moveHelperBackgroundShape=new engineRender.Rect(HEADER_MOVE_CONTROLLER_BACKGROUND,{fill:HEADER_MOVE_CONTROLLER_BACKGROUND_FILL,evented:!1,zIndex:100}),this._moveHelperLineShape=new engineRender.Rect(HEADER_MOVE_CONTROLLER_LINE,{fill:HEADER_MOVE_CONTROLLER_LINE_FILL,evented:!1,zIndex:100}),scene.addObjects([this._moveHelperBackgroundShape,this._moveHelperLineShape],SHEET_COMPONENT_HEADER_LAYER_INDEX)}_disposeBackgroundAndLine(){var _a61,_b;(_a61=this._moveHelperBackgroundShape)==null||_a61.dispose(),(_b=this._moveHelperLineShape)==null||_b.dispose()}},__name(_a40,"HeaderMoveRenderController"),_a40);exports.HeaderMoveRenderController=__decorateClass$i([__decorateParam$i(1,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$i(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$i(3,core.ICommandService)],exports.HeaderMoveRenderController);var HEADER_RESIZE_SHAPE_TYPE=(HEADER_RESIZE_SHAPE_TYPE2=>(HEADER_RESIZE_SHAPE_TYPE2[HEADER_RESIZE_SHAPE_TYPE2.VERTICAL=0]="VERTICAL",HEADER_RESIZE_SHAPE_TYPE2[HEADER_RESIZE_SHAPE_TYPE2.HORIZONTAL=1]="HORIZONTAL",HEADER_RESIZE_SHAPE_TYPE2))(HEADER_RESIZE_SHAPE_TYPE||{});const HEADER_MENU_SHAPE_RECT_BACKGROUND_FILL="rgba(120, 120, 120, 0.01)",HEADER_MENU_SHAPE_RECT_FILL="rgb(68, 71, 70)",HEADER_MENU_SHAPE_SIZE=12,MAX_HEADER_MENU_SHAPE_SIZE=44,HEADER_MENU_SHAPE_THUMB_SIZE=4,_HeaderMenuResizeShape=class _HeaderMenuResizeShape extends engineRender.Shape{constructor(key,props){super(key,props);__publicField(this,"_size",HEADER_MENU_SHAPE_SIZE);__publicField(this,"_color",HEADER_MENU_SHAPE_RECT_FILL);__publicField(this,"_mode",0);this.setShapeProps(props)}get size(){return this._size}get mode(){return this._mode}get color(){return this._color}_draw(ctx){const scene=this.getScene();if(!scene)return;const{scaleX,scaleY}=scene.getAncestorScale(),scale=Math.max(scaleX,scaleY),HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE=HEADER_MENU_SHAPE_SIZE/scale,HEADER_MENU_SHAPE_THUMB_SIZE_SCALE=HEADER_MENU_SHAPE_THUMB_SIZE/scale;let{width,height}=this,left=0,top=0;this.mode===0?(width=HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,left=HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE):(height=HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,top=HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE),engineRender.Rect.drawWith(ctx,{width:this.width,height:this.height,left:0,top:0,fill:HEADER_MENU_SHAPE_RECT_BACKGROUND_FILL}),engineRender.Rect.drawWith(ctx,{width,height,fill:HEADER_MENU_SHAPE_RECT_FILL,radius:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE}),ctx.save(),ctx.transform(1,0,0,1,left,top),engineRender.Rect.drawWith(ctx,{width,height,fill:HEADER_MENU_SHAPE_RECT_FILL,radius:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE}),ctx.restore()}setShapeProps(props){return props!=null&&props.size&&(this._size=props.size),props!=null&&props.mode&&(this._mode=props.mode),props!=null&&props.color&&(this._color=props.color),this.mode===0?this.transformByState({width:HEADER_MENU_SHAPE_SIZE,height:this.size}):this.transformByState({width:this.size,height:HEADER_MENU_SHAPE_SIZE}),this}};__name(_HeaderMenuResizeShape,"HeaderMenuResizeShape");let HeaderMenuResizeShape=_HeaderMenuResizeShape;var __defProp$h=Object.defineProperty,__getOwnPropDesc$h=Object.getOwnPropertyDescriptor,__decorateClass$h=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$h(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$h(target,key,result),result},"__decorateClass$h"),__decorateParam$h=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$h");const HEADER_RESIZE_CONTROLLER_SHAPE_ROW="__SpreadsheetHeaderResizeControllerShapeRow__",HEADER_RESIZE_CONTROLLER_SHAPE_COLUMN="__SpreadsheetHeaderResizeControllerShapeColumn__",HEADER_RESIZE_CONTROLLER_SHAPE_HELPER="__SpreadsheetHeaderResizeControllerShapeHelper__",HEADER_RESIZE_CONTROLLER_SHAPE_HELPER_COLOR="rgb(199, 199, 199)",MINIMAL_OFFSET=2,HEADER_RESIZE_PERMISSION_CHECK=core.createInterceptorKey("headerResizePermissionCheck");var _a41;exports.HeaderResizeRenderController=(_a41=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService){super();__publicField(this,"_currentRow",0);__publicField(this,"_currentColumn",0);__publicField(this,"_rowResizeRect");__publicField(this,"_columnResizeRect");__publicField(this,"_headerPointerSubs");__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_resizeHelperShape");__publicField(this,"_startOffsetX",Number.POSITIVE_INFINITY);__publicField(this,"_startOffsetY",Number.POSITIVE_INFINITY);__publicField(this,"interceptor",new core.InterceptorManager({HEADER_RESIZE_PERMISSION_CHECK}));this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._init()}dispose(){var _a61,_b,_c;(_a61=this._rowResizeRect)==null||_a61.dispose(),this._rowResizeRect=null,(_b=this._columnResizeRect)==null||_b.dispose(),this._columnResizeRect=null,(_c=this._headerPointerSubs)==null||_c.unsubscribe(),this._headerPointerSubs=null}_init(){const scene=this._context.scene;this._rowResizeRect=new HeaderMenuResizeShape(HEADER_RESIZE_CONTROLLER_SHAPE_ROW,{visible:!1,mode:HEADER_RESIZE_SHAPE_TYPE.HORIZONTAL,zIndex:100}),this._columnResizeRect=new HeaderMenuResizeShape(HEADER_RESIZE_CONTROLLER_SHAPE_COLUMN,{visible:!1,mode:HEADER_RESIZE_SHAPE_TYPE.VERTICAL,zIndex:100}),scene.addObjects([this._rowResizeRect,this._columnResizeRect],SHEET_COMPONENT_HEADER_LAYER_INDEX),this._initialHover(0),this._initialHover(1),this._initialHoverResize(0),this._initialHoverResize(1)}_initialHover(initialType=0){const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetRowHeader=this._context.components.get(SHEET_VIEW_KEY.ROW),scene=this._context.scene,eventBindingObject=initialType===0?spreadsheetRowHeader:spreadsheetColumnHeader,pointerLeaveEvent=__name((_evt,_state)=>{var _a61,_b;(_a61=this._rowResizeRect)==null||_a61.hide(),(_b=this._columnResizeRect)==null||_b.hide()},"pointerLeaveEvent"),pointerMoveEvent=__name((evt,_state)=>{var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null||this._rowResizeRect==null||this._columnResizeRect==null)return;const{rowHeaderWidth,columnHeaderHeight}=skeleton,{startX,startY,endX,endY,row,column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton),transformCoord=getTransformCoord(evt.offsetX,evt.offsetY,scene),{scaleX,scaleY}=scene.getAncestorScale(),scale=Math.max(scaleX,scaleY),HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE=HEADER_MENU_SHAPE_SIZE/scale;if(initialType===0){let top=startY-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;if(transformCoord.y<=startY+HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.y>=startY)this._currentRow=row-1;else if(transformCoord.y>=endY-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.y<=endY)this._currentRow=row,top=endY-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;else{this._rowResizeRect.hide();return}if(this._currentRow===-1)return;if(!this.interceptor.fetchThroughInterceptors(HEADER_RESIZE_PERMISSION_CHECK)(null,{row:this._currentRow}))return!1;const rowSize=Math.min(MAX_HEADER_MENU_SHAPE_SIZE,rowHeaderWidth/3);this._rowResizeRect.transformByState({left:rowHeaderWidth/2-rowSize/2,top}),this._rowResizeRect.setShapeProps({size:rowSize}),this._rowResizeRect.show()}else{let left=startX-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;if(transformCoord.x<=startX+HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.x>=startX)this._currentColumn=column-1;else if(transformCoord.x>=endX-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.x<=endX)this._currentColumn=column,left=endX-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;else{this._columnResizeRect.hide();return}if(this._currentColumn===-1)return;if(!this.interceptor.fetchThroughInterceptors(HEADER_RESIZE_PERMISSION_CHECK)(null,{col:this._currentColumn}))return!1;const columnSize=columnHeaderHeight*.7;this._columnResizeRect.transformByState({left,top:columnHeaderHeight/2-columnSize/2}),this._columnResizeRect.setShapeProps({size:columnSize}),this._columnResizeRect.show()}},"pointerMoveEvent");this._headerPointerSubs=new rxjs.Subscription,this._headerPointerSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerMove$.subscribeEvent(pointerMoveEvent)),this._headerPointerSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerLeave$.subscribeEvent(pointerLeaveEvent))}_initialHoverResize(initialType=0){const scene=this._context.scene,eventBindingObject=initialType===0?this._rowResizeRect:this._columnResizeRect;eventBindingObject!=null&&(this.disposeWithMe(core.toDisposable(eventBindingObject.onPointerEnter$.subscribeEvent(()=>{eventBindingObject!=null&&(eventBindingObject.show(),scene.setCursor(initialType===0?engineRender.CURSOR_TYPE.ROW_RESIZE:engineRender.CURSOR_TYPE.COLUMN_RESIZE))}))),this.disposeWithMe(core.toDisposable(eventBindingObject.onPointerLeave$.subscribeEvent(()=>{eventBindingObject!=null&&(eventBindingObject.hide(),scene.resetCursor())}))),this.disposeWithMe(core.toDisposable(eventBindingObject.onPointerDown$.subscribeEvent(evt=>{var _a61,_b,_c,_d,_e,_f,_g;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const scene2=this._context.scene,engine=scene2.getEngine(),canvasMaxHeight=(engine==null?void 0:engine.height)||0,canvasMaxWidth=(engine==null?void 0:engine.width)||0,viewPort=scene2.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollBarHorizontalHeight=(((_c=(_b=viewPort==null?void 0:viewPort.getScrollBar())==null?void 0:_b.horizonScrollTrack)==null?void 0:_c.height)||0)+10,scrollBarVerticalWidth=(((_e=(_d=viewPort==null?void 0:viewPort.getScrollBar())==null?void 0:_d.verticalScrollTrack)==null?void 0:_e.width)||0)+10,transformCoord=getTransformCoord(evt.offsetX,evt.offsetY,scene2),{scaleX,scaleY}=scene2.getAncestorScale();this._startOffsetX=transformCoord.x,this._startOffsetY=transformCoord.y;const currentOffsetX=skeleton.getOffsetByPositionX(this._currentColumn),currentOffsetY=skeleton.getOffsetByPositionY(this._currentRow),cell=skeleton.getNoMergeCellPositionByIndex(this._currentRow,this._currentColumn);let isStartMove=!1,moveChangeX=0,moveChangeY=0;const{columnTotalWidth,rowHeaderWidth,rowTotalHeight,columnHeaderHeight}=skeleton,shapeWidth=canvasMaxWidth>columnTotalWidth+rowHeaderWidth?canvasMaxWidth:columnTotalWidth+rowHeaderWidth,shapeHeight=canvasMaxHeight>rowTotalHeight+columnHeaderHeight?canvasMaxHeight:rowTotalHeight+columnHeaderHeight,scale=Math.max(scaleX,scaleY),HEADER_MENU_SHAPE_THUMB_SIZE_SCALE=HEADER_MENU_SHAPE_THUMB_SIZE/scale;initialType===0?this._resizeHelperShape=new engineRender.Rect(HEADER_RESIZE_CONTROLLER_SHAPE_HELPER,{width:shapeWidth,height:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,fill:HEADER_RESIZE_CONTROLLER_SHAPE_HELPER_COLOR,left:0,top:currentOffsetY-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE/2}):this._resizeHelperShape=new engineRender.Rect(HEADER_RESIZE_CONTROLLER_SHAPE_HELPER,{width:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,height:shapeHeight,fill:HEADER_RESIZE_CONTROLLER_SHAPE_HELPER_COLOR,left:currentOffsetX-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE/2,top:0});const rowResizeRectX=((_f=this._columnResizeRect)==null?void 0:_f.left)||0,rowResizeRectY=((_g=this._rowResizeRect)==null?void 0:_g.top)||0;scene2.addObject(this._resizeHelperShape,SHEET_COMPONENT_HEADER_LAYER_INDEX),scene2.disableObjectsEvent(),this._scenePointerMoveSub=scene2.onPointerMove$.subscribeEvent(moveEvt=>{var _a62,_b2,_c2,_d2,_e2,_f2;const relativeCoords=scene2.getRelativeToViewportCoord(engineRender.Vector2.FromArray([this._startOffsetX,this._startOffsetY])),scrollXY=scene2.getVpScrollXYInfoByPosToVp(relativeCoords,viewPort),transformCoord2=getTransformCoord(moveEvt.offsetX,moveEvt.offsetY,scene2),{x:moveOffsetX,y:moveOffsetY}=transformCoord2,{scaleX:scaleX2,scaleY:scaleY2}=scene2.getAncestorScale(),scale2=Math.max(scaleX2,scaleY2),HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2=HEADER_MENU_SHAPE_THUMB_SIZE/scale2;moveChangeX=moveOffsetX-this._startOffsetX-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2,moveChangeY=moveOffsetY-this._startOffsetY-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2,Math.abs(initialType===0?moveChangeY:moveChangeX)>=MINIMAL_OFFSET&&(isStartMove=!0),initialType===0?(moveChangeY>canvasMaxHeight-scrollBarHorizontalHeight+scrollXY.y-cell.startY&&(moveChangeY=canvasMaxHeight-scrollBarHorizontalHeight+scrollXY.y-cell.startY),moveChangeY<-(cell.endY-cell.startY)+2&&(moveChangeY=-(cell.endY-cell.startY)+2),isStartMove&&((_a62=this._resizeHelperShape)==null||_a62.transformByState({top:currentOffsetY+moveChangeY}),(_b2=this._rowResizeRect)==null||_b2.transformByState({top:rowResizeRectY+moveChangeY+HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2}),(_c2=this._rowResizeRect)==null||_c2.show(),scene2.setCursor(engineRender.CURSOR_TYPE.ROW_RESIZE))):(moveChangeX>canvasMaxWidth-scrollBarVerticalWidth+scrollXY.x-cell.startX&&(moveChangeX=canvasMaxWidth-scrollBarVerticalWidth+scrollXY.x-cell.startX),moveChangeX<-(cell.endX-cell.startX)+2&&(moveChangeX=-(cell.endX-cell.startX)+2),isStartMove&&((_d2=this._resizeHelperShape)==null||_d2.transformByState({left:currentOffsetX+moveChangeX}),(_e2=this._columnResizeRect)==null||_e2.transformByState({left:rowResizeRectX+moveChangeX+HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2}),(_f2=this._columnResizeRect)==null||_f2.show(),scene2.setCursor(engineRender.CURSOR_TYPE.COLUMN_RESIZE)))}),this._scenePointerUpSub=scene2.onPointerUp$.subscribeEvent(upEvt=>{var _a62,_b2,_c2;const scene3=this._context.scene;this._clearObserverEvent(),(_a62=this._resizeHelperShape)==null||_a62.dispose(),this._resizeHelperShape=null,scene3.enableObjectsEvent(),isStartMove&&(scene3.resetCursor(),(_b2=this._rowResizeRect)==null||_b2.hide(),(_c2=this._columnResizeRect)==null||_c2.hide(),initialType===0?this._commandService.executeCommand(sheets.DeltaRowHeightCommand.id,{deltaY:moveChangeY,anchorRow:this._currentRow}):this._commandService.executeCommand(sheets.DeltaColumnWidthCommand.id,{deltaX:moveChangeX,anchorCol:this._currentColumn}))})}))),this.disposeWithMe(core.toDisposable(eventBindingObject.onDblclick$.subscribeEvent(()=>{var _a61,_b;initialType===0&&(this._context.scene.resetCursor(),this._commandService.executeCommand(sheets.SetWorksheetRowIsAutoHeightCommand.id,{ranges:[{startRow:this._currentRow,endRow:this._currentRow,startColumn:0,endColumn:((_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton.worksheet.getColumnCount())||0}]}),(_b=this._rowResizeRect)==null||_b.hide())}))))}_clearObserverEvent(){var _a61,_b;(_a61=this._scenePointerMoveSub)==null||_a61.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null}},__name(_a41,"HeaderResizeRenderController"),_a41);exports.HeaderResizeRenderController=__decorateClass$h([__decorateParam$h(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$h(2,core.ICommandService)],exports.HeaderResizeRenderController);var __defProp$g=Object.defineProperty,__getOwnPropDesc$g=Object.getOwnPropertyDescriptor,__decorateClass$g=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$g(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$g(target,key,result),result},"__decorateClass$g"),__decorateParam$g=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$g"),_a42;let SheetPermissionInterceptorCanvasRenderController=(_a42=class extends core.RxDisposable{constructor(_context,_univerInstanceService,_permissionService,_selectionManagerService,_rangeProtectionRuleModel,_headerMoveRenderController,_selectionRenderService,_headerFreezeRenderController,_rangeProtectionCache,_headerResizeRenderController){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._context=_context,this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._selectionManagerService=_selectionManagerService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._headerMoveRenderController=_headerMoveRenderController,this._selectionRenderService=_selectionRenderService,this._headerFreezeRenderController=_headerFreezeRenderController,this._rangeProtectionCache=_rangeProtectionCache,this._headerResizeRenderController=_headerResizeRenderController,this._initHeaderMovePermissionInterceptor(),this._initHeaderResizePermissionInterceptor(),this._initRangeFillPermissionInterceptor(),this._initRangeMovePermissionInterceptor()}_initHeaderMovePermissionInterceptor(){const headerMoveInterceptor=this._headerMoveRenderController.interceptor.getInterceptPoints().HEADER_MOVE_PERMISSION_CHECK;this.disposeWithMe(this._headerMoveRenderController.interceptor.intercept(headerMoveInterceptor,{handler:__name((defaultValue,selectionRange)=>{const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target;if(!this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id]).every(permission=>permission.value))return!1;if(!selectionRange)return!0;if(selectionRange.rangeType!==core.RANGE_TYPE.ROW&&selectionRange.rangeType!==core.RANGE_TYPE.COLUMN)return defaultValue;if(selectionRange.rangeType===core.RANGE_TYPE.ROW){for(let i=selectionRange.startRow;i<=selectionRange.endRow;i++)if(this._rangeProtectionCache.getRowPermissionInfo(unitId,subUnitId,i,[D.Edit])===!1)return!1}else for(let i=selectionRange.startColumn;i<=selectionRange.endColumn;i++)if(this._rangeProtectionCache.getColPermissionInfo(unitId,subUnitId,i,[D.Edit])===!1)return!1;return!0},"handler")}))}_initHeaderResizePermissionInterceptor(){this._headerResizeRenderController&&this.disposeWithMe(this._headerResizeRenderController.interceptor.intercept(this._headerResizeRenderController.interceptor.getInterceptPoints().HEADER_RESIZE_PERMISSION_CHECK,{handler:__name((defaultValue,rangeParams)=>{var _a61,_b,_c,_d;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target;if(rangeParams.row){if(((_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorksheetSetRowStylePermission(unitId,subUnitId).id))==null?void 0:_a61.value)!=null?_b:!1)===!1)return!1}else if(rangeParams.col&&((_d=(_c=this._permissionService.getPermissionPoint(new sheets.WorksheetSetColumnStylePermission(unitId,subUnitId).id))==null?void 0:_c.value)!=null?_d:!1)===!1)return!1;return!0},"handler")}))}_initRangeFillPermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_FILL_PERMISSION_CHECK,{handler:__name((_,position)=>{var _a61,_b,_c;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;if(!this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id,new sheets.WorksheetSetCellValuePermission(unitId,subUnitId).id,new sheets.WorksheetSetCellStylePermission(unitId,subUnitId).id]).every(permission=>permission.value))return!1;const ranges=(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range),selectionRange=ranges==null?void 0:ranges.find(range=>{const transformCoord=getTransformCoord(position.x,position.y,position.scene,position.skeleton),cellPosition=position.skeleton.getCellByIndex(range.endRow,range.endColumn),missX=Math.abs(cellPosition.endX-transformCoord.x),missY=Math.abs(cellPosition.endY-transformCoord.y);return missX<=5&&missY<=5});if(!selectionRange)return!0;const{startRow,endRow,startColumn,endColumn}=selectionRange;for(let row=startRow;row<=endRow;row++)for(let col=startColumn;col<=endColumn;col++){const permission=(_c=(_b=worksheet.getCell(row,col))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[D.Edit])===!1||(permission==null?void 0:permission[D.View])===!1)return!1}return!0},"handler")}))}_initRangeMovePermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_MOVE_PERMISSION_CHECK,{handler:__name((_,_cellInfo)=>{var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;if(!this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id]).every(permission=>permission.value))return!1;const ranges=(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range),ruleRanges=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]),permissionLapRanges=ranges==null?void 0:ranges.filter(range=>ruleRanges.some(ruleRange=>core.Rectangle.intersects(ruleRange,range)));return!(permissionLapRanges==null?void 0:permissionLapRanges.some(range=>{var _a62,_b;const{startRow,startColumn,endRow,endColumn}=range;for(let row=startRow;row<=endRow;row++)for(let col=startColumn;col<=endColumn;col++){const permission=(_b=(_a62=worksheet.getCell(row,col))==null?void 0:_a62.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!0}return!1}))},"handler")}))}_initFreezePermissionInterceptor(){this.disposeWithMe(this._headerFreezeRenderController.interceptor.intercept(this._headerFreezeRenderController.interceptor.getInterceptPoints().FREEZE_PERMISSION_CHECK,{handler:__name((_,__)=>{var _a61,_b;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);return!(workbook==null?void 0:workbook.getActiveSheet())||!workbook?!1:(_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorkbookEditablePermission(workbook.getUnitId()).id))==null?void 0:_a61.value)!=null?_b:!1},"handler")}))}},__name(_a42,"SheetPermissionInterceptorCanvasRenderController"),_a42);SheetPermissionInterceptorCanvasRenderController=__decorateClass$g([__decorateParam$g(1,core.IUniverInstanceService),__decorateParam$g(2,core.IPermissionService),__decorateParam$g(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$g(4,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$g(5,core.Inject(exports.HeaderMoveRenderController)),__decorateParam$g(6,ISheetSelectionRenderService),__decorateParam$g(7,core.Inject(exports.HeaderFreezeRenderController)),__decorateParam$g(8,core.Inject(sheets.RangeProtectionCache)),__decorateParam$g(9,core.Optional(exports.HeaderResizeRenderController))],SheetPermissionInterceptorCanvasRenderController);var __defProp$f=Object.defineProperty,__getOwnPropDesc$f=Object.getOwnPropertyDescriptor,__decorateClass$f=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$f(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$f(target,key,result),result},"__decorateClass$f"),__decorateParam$f=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$f");const SHEET_PERMISSION_PASTE_PLUGIN="SHEET_PERMISSION_PASTE_PLUGIN";var _a43;let SheetPermissionInterceptorClipboardController=(_a43=class extends core.Disposable{constructor(_univerInstanceService,_selectionManagerService,_localService,_sheetClipboardService,_sheetPermissionInterceptorBaseController){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._localService=_localService,this._sheetClipboardService=_sheetClipboardService,this._sheetPermissionInterceptorBaseController=_sheetPermissionInterceptorBaseController,this._initClipboardHook()}_initClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook({id:SHEET_PERMISSION_PASTE_PLUGIN,onBeforePaste:__name(pasteTo=>{var _a61,_b,_c;const[ranges]=virtualizeDiscreteRanges([pasteTo.range]).ranges,startRange=(_a61=this._selectionManagerService.getCurrentLastSelection())==null?void 0:_a61.range;if(!startRange)return!1;const targetRange={startRow:startRange.startRow+ranges.startRow,endRow:startRange.startRow+ranges.endRow,startColumn:startRange.startColumn+ranges.startColumn,endColumn:startRange.startColumn+ranges.endColumn},worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)return!1;const{startRow,endRow,startColumn,endColumn}=targetRange;let hasPermission=!0;for(let row=startRow;row<=endRow;row++)for(let col=startColumn;col<=endColumn;col++){const permission=(_c=(_b=worksheet.getCell(row,col))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[D.Edit])===!1){hasPermission=!1;break}}return hasPermission||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localService.t("permission.dialog.pasteErr")),hasPermission},"onBeforePaste")}))}},__name(_a43,"SheetPermissionInterceptorClipboardController"),_a43);SheetPermissionInterceptorClipboardController=__decorateClass$f([__decorateParam$f(0,core.IUniverInstanceService),__decorateParam$f(1,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$f(2,core.Inject(core.LocaleService)),__decorateParam$f(3,core.Inject(ISheetClipboardService)),__decorateParam$f(4,core.Inject(exports.SheetPermissionInterceptorBaseController))],SheetPermissionInterceptorClipboardController);var __defProp$e=Object.defineProperty,__getOwnPropDesc$e=Object.getOwnPropertyDescriptor,__decorateClass$e=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$e(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$e(target,key,result),result},"__decorateClass$e"),__decorateParam$e=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$e");const STATUS_BAR_PERMISSION_CORRECT=core.createInterceptorKey("statusBarPermissionCorrect"),_CalculateValueSet=class _CalculateValueSet{constructor(){__publicField(this,"_sum",0);__publicField(this,"_count",0);__publicField(this,"_countNumber",0);__publicField(this,"_min",Number.POSITIVE_INFINITY);__publicField(this,"_max",Number.NEGATIVE_INFINITY)}add(value){const v=value==null?void 0:value.v,t=value==null?void 0:value.t;v!=null&&(typeof v=="number"&&t!==core.CellValueType.STRING&&(this._sum+=v,this._countNumber++,this._min=Math.min(this._min,v),this._max=Math.max(this._max,v)),this._count++)}getResults(){return{sum:this._sum,count:this._countNumber,countA:this._count,min:this._min,max:this._max}}};__name(_CalculateValueSet,"CalculateValueSet");let CalculateValueSet=_CalculateValueSet;function calculateValues(valueSet){const{sum,count,countA,min,max}=valueSet.getResults();return[{func:engineFormula.FUNCTION_NAMES_STATISTICAL.MAX,value:max},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.MIN,value:min},{func:engineFormula.FUNCTION_NAMES_MATH.SUM,value:sum},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.COUNTA,value:countA},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.COUNT,value:count},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.AVERAGE,value:sum/count}]}__name(calculateValues,"calculateValues");var _a44;exports.StatusBarController=(_a44=class extends core.Disposable{constructor(_univerInstanceService,_selectionManagerService,_statusBarService,_commandService,_numfmtService){super();__publicField(this,"interceptor",new core.InterceptorManager({STATUS_BAR_PERMISSION_CORRECT}));this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._statusBarService=_statusBarService,this._commandService=_commandService,this._numfmtService=_numfmtService,this._init()}_init(){this._registerSelectionListener()}_registerSelectionListener(){const _statisticsHandler=core.debounce(selections=>{var _a61;const primary=(_a61=selections[selections.length-1])==null?void 0:_a61.primary;this._calculateSelection(selections.map(selection=>selection.range),primary)},100);this.disposeWithMe(core.toDisposable(this._selectionManagerService.selectionMoving$.subscribe(selections=>{selections&&_statisticsHandler(selections)}))),this.disposeWithMe(core.toDisposable(this._selectionManagerService.selectionMoveEnd$.subscribe(selections=>{selections&&_statisticsHandler(selections)}))),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id===sheets.SetRangeValuesMutation.id){const selections=this._selectionManagerService.getCurrentSelections();selections&&_statisticsHandler(selections)}}))}_clearResult(){this._statusBarService.setState(null)}getRangeStartEndInfo(range,sheet){return range.rangeType===core.RANGE_TYPE.ALL?{startRow:0,startColumn:0,endRow:sheet.getRowCount()-1,endColumn:sheet.getColumnCount()-1}:range.rangeType===core.RANGE_TYPE.COLUMN?{startRow:0,startColumn:range.startColumn,endRow:sheet.getRowCount()-1,endColumn:range.endColumn}:range.rangeType===core.RANGE_TYPE.ROW?{startRow:range.startRow,startColumn:0,endRow:range.endRow,endColumn:sheet.getColumnCount()-1}:{startRow:range.startRow,startColumn:range.startColumn,endRow:range.endRow,endColumn:range.endColumn}}_calculateSelection(selections,primary){var _a61;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return this._clearResult();const unitId=workbook.getUnitId(),sheet=workbook.getActiveSheet(),sheetId=sheet==null?void 0:sheet.getSheetId();if(!sheetId)return this._clearResult();const sheetData={};if(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getSheets().forEach(sheet2=>{const sheetConfig=sheet2.getConfig();sheetData[sheet2.getSheetId()]={cellData:new core.ObjectMatrix(sheetConfig.cellData),rowCount:sheetConfig.rowCount,columnCount:sheetConfig.columnCount,rowData:sheetConfig.rowData,columnData:sheetConfig.columnData}}),selections!=null&&selections.length){const realSelections=[];selections.forEach(selection=>{const{startRow:start,endRow:end}=selection;let prev=null;for(let r2=start;r2<=end;r2++)sheet.getRowVisible(r2)?prev===null&&(prev=r2):prev!==null&&(realSelections.push({...selection,startRow:prev,endRow:r2-1}),prev=null);prev!==null&&realSelections.push({...selection,startRow:prev,endRow:end})});const noDuplicate=core.splitIntoGrid(realSelections),calculateValueSet=new CalculateValueSet;for(const range of noDuplicate){const{startRow,startColumn,endColumn,endRow}=this.getRangeStartEndInfo(range,sheet);for(let r2=startRow;r2<=endRow;r2++)for(let c=startColumn;c<=endColumn;c++){const value=sheet.getCell(r2,c);calculateValueSet.add(value)}}const calcResult=calculateValues(calculateValueSet);if(calcResult.every(r2=>r2===void 0))return;let pattern=null;if(primary){const{actualRow,actualColumn}=primary;pattern=(_a61=this._numfmtService.getValue(unitId,sheetId,actualRow,actualColumn))==null?void 0:_a61.pattern}const newState={values:calcResult.filter(r2=>r2!==void 0),pattern};this._statusBarService.setState(newState)}else this._clearResult()}},__name(_a44,"StatusBarController"),_a44);exports.StatusBarController=__decorateClass$e([__decorateParam$e(0,core.IUniverInstanceService),__decorateParam$e(1,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$e(2,IStatusBarService),__decorateParam$e(3,core.ICommandService),__decorateParam$e(4,core.Inject(sheets.INumfmtService))],exports.StatusBarController);var __defProp$d=Object.defineProperty,__getOwnPropDesc$d=Object.getOwnPropertyDescriptor,__decorateClass$d=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$d(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$d(target,key,result),result},"__decorateClass$d"),__decorateParam$d=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$d"),_a45;let SheetPermissionInterceptorFormulaRenderController=(_a45=class extends core.RxDisposable{constructor(_context,_univerInstanceService,_permissionService,_statusBarController,_rangeProtectionCache){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._context=_context,this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._statusBarController=_statusBarController,this._rangeProtectionCache=_rangeProtectionCache,this._initStatusBarPermissionInterceptor()}_initStatusBarPermissionInterceptor(){this.disposeWithMe(this._statusBarController.interceptor.intercept(this._statusBarController.interceptor.getInterceptPoints().STATUS_BAR_PERMISSION_CORRECT,{priority:100,handler:__name((defaultValue,originValue)=>{var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return defaultValue!=null?defaultValue:[];const{worksheet,unitId,subUnitId}=target;return((_a61=this._permissionService.getPermissionPoint(new sheets.WorksheetViewPermission(unitId,subUnitId).id))==null?void 0:_a61.value)===!1?originValue.forEach(item=>{const itemValue=item.getArrayValue();itemValue.forEach((row,rowIndex)=>{row.forEach((col,colIndex)=>{itemValue[rowIndex][colIndex]=engineFormula.NullValueObject.create()})})}):originValue.forEach(item=>{const itemValue=item.getArrayValue(),startRow=item.getCurrentRow(),startCol=item.getCurrentColumn();itemValue.forEach((row,rowIndex)=>{row.forEach((col,colIndex)=>{var _a62;if(((_a62=worksheet.getCellRaw(rowIndex+startRow,colIndex+startCol))==null?void 0:_a62.v)===void 0)return;const permission=this._rangeProtectionCache.getCellInfo(unitId,subUnitId,rowIndex+startRow,colIndex+startCol);(permission==null?void 0:permission[D.View])===!1&&(itemValue[rowIndex][colIndex]=engineFormula.NullValueObject.create())})})}),originValue},"handler")}))}},__name(_a45,"SheetPermissionInterceptorFormulaRenderController"),_a45);SheetPermissionInterceptorFormulaRenderController=__decorateClass$d([__decorateParam$d(1,core.IUniverInstanceService),__decorateParam$d(2,core.IPermissionService),__decorateParam$d(3,core.Inject(exports.StatusBarController)),__decorateParam$d(4,core.Inject(sheets.RangeProtectionCache))],SheetPermissionInterceptorFormulaRenderController);const sheetPermissionPanelFooter="univer-sheet-permission-panel-footer",sheetPermissionPanelFooterCancel="univer-sheet-permission-panel-footer-cancel",sheetPermissionPanelAddButton="univer-sheet-permission-panel-add-button",styles$7={sheetPermissionPanelFooter,sheetPermissionPanelFooterCancel,sheetPermissionPanelAddButton},SheetPermissionPanelAddFooter=__name(()=>{var _a61,_b,_c,_d;const sidebarService=core.useDependency(ui.ISidebarService),localeService=core.useDependency(core.LocaleService),univerInstanceService=core.useDependency(core.IUniverInstanceService),permissionService=core.useDependency(core.IPermissionService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),activeSheet$=ui.useObservable(workbook.activeSheet$),workbookEditPermission=(_b=(_a61=permissionService.getPermissionPoint(new sheets.WorkbookEditablePermission(unitId).id))==null?void 0:_a61.value)!=null?_b:!1,workbookManagePermission=(_d=(_c=permissionService.getPermissionPoint(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_c.value)!=null?_d:!1,hasSetProtectPermission=workbookEditPermission&&workbookManagePermission,sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),worksheetProtectionRuleModel=core.useDependency(sheets.WorksheetProtectionRuleModel),subUnitId=activeSheet$==null?void 0:activeSheet$.getSheetId();if(!subUnitId)return null;const worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return!hasSetProtectPermission||worksheetRule?null:jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsxs(design.Button,{className:styles$7.sheetPermissionPanelAddButton,type:"primary",onClick:__name(()=>{sheetPermissionPanelModel.resetRule();const sidebarProps={header:{title:`${localeService.t("permission.panel.title")}`},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail:!0},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail:!0}};sidebarService.open(sidebarProps)},"onClick"),children:[jsxRuntimeExports.jsx("div",{children:"+ "}),localeService.t("permission.button.addNewPermission")]})})},"SheetPermissionPanelAddFooter"),SheetPermissionPanelDetailFooter=__name(()=>{const sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),activeRule=ui.useObservable(sheetPermissionPanelModel.rule$,sheetPermissionPanelModel.rule),sidebarService=core.useDependency(ui.ISidebarService),authzIoService=core.useDependency(core.IAuthzIoService),localeService=core.useDependency(core.LocaleService),commandService=core.useDependency(core.ICommandService),sheetPermissionUserManagerService=core.useDependency(SheetPermissionUserManagerService),rangeErrMsg=ui.useObservable(sheetPermissionPanelModel.rangeErrorMsg$);return jsxRuntimeExports.jsxs("div",{className:styles$7.sheetPermissionPanelFooter,children:[jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(async()=>{if(!activeRule.name||rangeErrMsg)return;let collaborators=sheetPermissionUserManagerService.selectUserList;activeRule.editStatus===editState.onlyMe&&(collaborators=[],sheetPermissionUserManagerService.setSelectUserList([]));const scopeObj={read:activeRule.viewStatus===viewState.othersCanView?T.AllCollaborator:T.SomeCollaborator,edit:activeRule.editStatus===editState.designedUserCanEdit?T.SomeCollaborator:T.OneSelf};if(activeRule.editStatus===editState.designedUserCanEdit&&collaborators.length===0&&(collaborators=[],scopeObj.edit=T.OneSelf),activeRule.permissionId){const oldRule=sheetPermissionPanelModel.oldRule,isSameCollaborators=getUserListEqual(collaborators.filter(user=>user.role===S.Editor),sheetPermissionUserManagerService.oldCollaboratorList.filter(user=>user.role===S.Editor)),isSameReadStatus=(oldRule==null?void 0:oldRule.viewStatus)===activeRule.viewStatus,isSameEditStatus=(oldRule==null?void 0:oldRule.editStatus)===activeRule.editStatus,ruleConfigIsOrigin=activeRule.unitType===(oldRule==null?void 0:oldRule.unitType)&&activeRule.name===oldRule.name&&activeRule.description===oldRule.description&&activeRule.ranges===oldRule.ranges,collaboratorsIsChange=!isSameCollaborators||!isSameReadStatus||!isSameEditStatus;if(ruleConfigIsOrigin&&collaboratorsIsChange)await authzIoService.update({objectType:activeRule.unitType,objectID:activeRule.permissionId,unitID:activeRule.unitId,share:void 0,name:"",strategies:[],scope:scopeObj,collaborators:{collaborators}});else{let newPermissionId=activeRule.permissionId;collaboratorsIsChange&&(activeRule.unitType===L.Worksheet?newPermissionId=await authzIoService.create({worksheetObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,strategies:[{role:S.Editor,action:D.Edit},{role:S.Reader,action:D.View}],scope:scopeObj},objectType:L.Worksheet}):newPermissionId=await authzIoService.create({selectRangeObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,scope:scopeObj},objectType:L.SelectRange})),commandService.executeCommand(SetProtectionCommand.id,{rule:{...activeRule,permissionId:newPermissionId}})}}else if(activeRule.unitType===L.Worksheet){const permissionId=await authzIoService.create({worksheetObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,strategies:[{role:S.Editor,action:D.Edit},{role:S.Reader,action:D.View}],scope:scopeObj},objectType:L.Worksheet}),{ranges:_range=[],...sheetRule}=activeRule;sheetRule.permissionId=permissionId,commandService.executeCommand(AddWorksheetProtectionCommand.id,{rule:sheetRule,unitId:activeRule.unitId})}else if(activeRule.unitType===L.SelectRange){const permissionId=await authzIoService.create({selectRangeObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,scope:scopeObj},objectType:L.SelectRange});commandService.executeCommand(sheets.AddRangeProtectionCommand.id,{rule:activeRule,permissionId})}sheetPermissionPanelModel.resetRule(),sheetPermissionUserManagerService.reset();const sidebarProps={header:{title:`${localeService.t("permission.panel.title")}`},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail:!1},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail:!1}};sidebarService.open(sidebarProps)},"onClick"),children:localeService.t("permission.button.confirm")}),jsxRuntimeExports.jsx(design.Button,{className:styles$7.sheetPermissionPanelFooterCancel,onClick:__name(()=>{sheetPermissionPanelModel.reset(),sheetPermissionUserManagerService.reset(),sidebarService.close()},"onClick"),children:localeService.t("permission.button.cancel")})]})},"SheetPermissionPanelDetailFooter"),SheetPermissionPanelFooter=__name(({showDetail})=>showDetail?jsxRuntimeExports.jsx(SheetPermissionPanelDetailFooter,{}):jsxRuntimeExports.jsx(SheetPermissionPanelAddFooter,{}),"SheetPermissionPanelFooter"),useHighlightRange=__name((ranges=[])=>{const markSelectionService=core.useDependency(IMarkSelectionService);React.useEffect(()=>{const ids=ranges.map(range=>markSelectionService.addShape({range,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:range.startColumn,endColumn:range.endColumn,startRow:range.startRow,endRow:range.endRow,actualRow:range.startRow,actualColumn:range.startColumn,isMerged:!1,isMergedMainCell:!1}}));return()=>{ids.forEach(id=>{id&&markSelectionService.removeShape(id)})}},[ranges])},"useHighlightRange"),panelListEmptyBase64="",sheetPermissionListPanelWrapper="univer-sheet-permission-list-panel-wrapper",sheetPermissionListPanelHeader="univer-sheet-permission-list-panel-header",sheetPermissionListPanelHeaderType="univer-sheet-permission-list-panel-header-type",sheetPermissionListPanelHeaderTypeBottom="univer-sheet-permission-list-panel-header-type-bottom",sheetPermissionListPanelHeaderSelect="univer-sheet-permission-list-panel-header-select",sheetPermissionListItemHeaderIcon="univer-sheet-permission-list-item-header-icon",sheetPermissionListItem="univer-sheet-permission-list-item",sheetPermissionListItemHeader="univer-sheet-permission-list-item-header",sheetPermissionListItemHeaderName="univer-sheet-permission-list-item-header-name",sheetPermissionListItemHeaderOperator="univer-sheet-permission-list-item-header-operator",sheetPermissionListItemSplit="univer-sheet-permission-list-item-split",sheetPermissionListItemContentEdit="univer-sheet-permission-list-item-content-edit",sheetPermissionListItemContentView="univer-sheet-permission-list-item-content-view",sheetPermissionListItemContentDesc="univer-sheet-permission-list-item-content-desc",sheetPermissionListEmpty="univer-sheet-permission-list-empty",sheetPermissionListEmptyText="univer-sheet-permission-list-empty-text",sheetPermissionListItemContentTitle="univer-sheet-permission-list-item-content-title",sheetPermissionListItemContentSub="univer-sheet-permission-list-item-content-sub",styles$6={sheetPermissionListPanelWrapper,sheetPermissionListPanelHeader,sheetPermissionListPanelHeaderType,sheetPermissionListPanelHeaderTypeBottom,sheetPermissionListPanelHeaderSelect,sheetPermissionListItemHeaderIcon,sheetPermissionListItem,sheetPermissionListItemHeader,sheetPermissionListItemHeaderName,sheetPermissionListItemHeaderOperator,sheetPermissionListItemSplit,sheetPermissionListItemContentEdit,sheetPermissionListItemContentView,sheetPermissionListItemContentDesc,sheetPermissionListEmpty,sheetPermissionListEmptyText,sheetPermissionListItemContentTitle,sheetPermissionListItemContentSub},SheetPermissionPanelList=__name(()=>{const[isCurrentSheet,setIsCurrentSheet]=React.useState(!0),[forceUpdateFlag,setForceUpdateFlag]=React.useState(!1),sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),localeService=core.useDependency(core.LocaleService),rangeProtectionRuleModel=core.useDependency(sheets.RangeProtectionRuleModel),worksheetProtectionModel=core.useDependency(sheets.WorksheetProtectionRuleModel),workbook=core.useDependency(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),commandService=core.useDependency(core.ICommandService),sidebarService=core.useDependency(ui.ISidebarService),authzIoService=core.useDependency(core.IAuthzIoService),permissionService=core.useDependency(core.IPermissionService),currentUser=core.useDependency(core.UserManagerService).getCurrentUser(),[currentRuleRanges,currentRuleRangesSet]=React.useState([]),_sheetRuleRefresh=ui.useObservable(worksheetProtectionModel.ruleRefresh$,""),_rangeRuleRefresh=ui.useObservable(rangeProtectionRuleModel.ruleRefresh$,""),getRuleList=React.useCallback(async isCurrentSheet2=>{var _a61;const worksheet=workbook.getActiveSheet(),unitId2=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),allRangePermissionId=[],allSheetPermissionId=[];workbook.getSheets().forEach(sheet=>{const sheetId=sheet.getSheetId();rangeProtectionRuleModel.getSubunitRuleList(unitId2,sheetId).forEach(rule=>{rule.permissionId&&rule.name&&allRangePermissionId.push(rule.permissionId)});const worksheetPermissionRule=worksheetProtectionModel.getRule(unitId2,sheetId);worksheetPermissionRule!=null&&worksheetPermissionRule.permissionId&&worksheetPermissionRule.name&&allSheetPermissionId.push(worksheetPermissionRule.permissionId)});const allPermissionId=[...allRangePermissionId,...allSheetPermissionId],allPermissionRule=await authzIoService.list({objectIDs:allPermissionId,unitID:unitId2,actions:[D.View,D.Edit]}),subUnitPermissionIds=rangeProtectionRuleModel.getSubunitRuleList(unitId2,subUnitId).map(item=>item.permissionId),sheetPermissionId=(_a61=worksheetProtectionModel.getRule(unitId2,subUnitId))==null?void 0:_a61.permissionId;sheetPermissionId&&subUnitPermissionIds.push(sheetPermissionId);const subUnitRuleList=allPermissionRule.filter(item=>{var _a62;return subUnitPermissionIds.includes(item.objectID)||item.objectID===((_a62=worksheetProtectionModel.getRule(unitId2,subUnitId))==null?void 0:_a62.permissionId)});return isCurrentSheet2?subUnitRuleList:allPermissionRule},[]),[ruleList,setRuleList]=React.useState([]);React.useEffect(()=>{const subscription=rxjs.merge(rangeProtectionRuleModel.ruleChange$,worksheetProtectionModel.ruleChange$).subscribe(async()=>{const ruleList2=await getRuleList(isCurrentSheet);setRuleList(ruleList2)});return()=>{subscription.unsubscribe()}},[isCurrentSheet]),React.useEffect(()=>{const subscribe=workbook.activeSheet$.subscribe(async()=>{const ruleList2=await getRuleList(!0);setRuleList(ruleList2)});return()=>{subscribe.unsubscribe()}},[]),React.useEffect(()=>{__name(async()=>{if(_sheetRuleRefresh||_rangeRuleRefresh){const ruleList2=await getRuleList(!0);setRuleList(ruleList2)}},"getRuleListByRefresh")()},[_sheetRuleRefresh,_rangeRuleRefresh]);const handleDelete=__name(rule=>{const{unitId:unitId2,subUnitId,unitType}=rule;let res;unitType===L.Worksheet?res=commandService.executeCommand(DeleteWorksheetProtectionCommand.id,{unitId:unitId2,subUnitId,rule}):unitType===L.SelectRange&&(res=commandService.executeCommand(sheets.DeleteRangeProtectionCommand.id,{unitId:unitId2,subUnitId,rule})),res&&(setForceUpdateFlag(!forceUpdateFlag),rule.ranges===currentRuleRanges&&currentRuleRangesSet([]))},"handleDelete");useHighlightRange(currentRuleRanges);const allRuleMap=new Map;workbook.getSheets().forEach(sheet=>{const sheetId=sheet.getSheetId();rangeProtectionRuleModel.getSubunitRuleList(unitId,sheetId).forEach(rule=>{allRuleMap.set(rule.permissionId,rule)});const sheetRule=worksheetProtectionModel.getRule(unitId,sheetId);sheetRule&&allRuleMap.set(sheetRule==null?void 0:sheetRule.permissionId,sheetRule)});const handleEdit=__name(rule=>{sheetPermissionPanelModel.setRule(rule),sheetPermissionPanelModel.setOldRule(rule),rule.subUnitId!==workbook.getActiveSheet().getSheetId()&&commandService.executeCommand(sheets.SetWorksheetActiveOperation.id,{unitId:rule.unitId,subUnitId:rule.subUnitId});const sidebarProps={header:{title:"permission.panel.title"},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail:!0},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail:!0}};sidebarService.open(sidebarProps)},"handleEdit"),handleChangeHeaderType=__name(async isCurrentSheet2=>{setIsCurrentSheet(isCurrentSheet2);const ruleList2=await getRuleList(isCurrentSheet2);setRuleList(ruleList2)},"handleChangeHeaderType");return jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelWrapper,children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelHeader,children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelHeaderType,onClick:__name(()=>handleChangeHeaderType(!0),"onClick"),children:[jsxRuntimeExports.jsx("div",{className:clsx({[styles$6.sheetPermissionListPanelHeaderSelect]:isCurrentSheet}),children:localeService.t("permission.panel.currentSheet")}),isCurrentSheet&&jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListPanelHeaderTypeBottom})]}),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelHeaderType,onClick:__name(()=>handleChangeHeaderType(!1),"onClick"),children:[jsxRuntimeExports.jsx("div",{className:clsx({[styles$6.sheetPermissionListPanelHeaderSelect]:!isCurrentSheet}),children:localeService.t("permission.panel.allSheet")}),!isCurrentSheet&&jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListPanelHeaderTypeBottom})]})]}),(ruleList==null?void 0:ruleList.length)>0?jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListPanelContent,children:ruleList==null?void 0:ruleList.map(item=>{var _a61,_b,_c,_d,_e;const rule=allRuleMap.get(item.objectID);if(!rule)return null;const editAction=item.actions.find(action=>action.action===D.Edit),editPermission=editAction==null?void 0:editAction.allowed,viewAction=item.actions.find(action=>action.action===D.View),viewPermission=viewAction==null?void 0:viewAction.allowed,hasManagerPermission=((_b=(_a61=permissionService.getPermissionPoint(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_a61.value)!=null?_b:!1)||currentUser.userID===((_c=item.creator)==null?void 0:_c.userID);let ruleName="";const targetSheet=workbook.getSheetBySheetId(rule.subUnitId),targetName=targetSheet==null?void 0:targetSheet.getName();if(rule.unitType===L.SelectRange){const ranges=rule.ranges,rangeStr=ranges!=null&&ranges.length?ranges.map(range=>{const v=engineFormula.serializeRange(range);return v==="NaN"?"":v}).filter(r2=>!!r2).join(","):"";ruleName=`${targetName}(${rangeStr})`}else rule.unitType===L.Worksheet&&(ruleName=targetName||"");return jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItem,onMouseMove:__name(()=>{const{subUnitId,unitType}=rule,activeSheet=workbook.getActiveSheet();if(!activeSheet)return!1;const activeSubUnitId=activeSheet.getSheetId();if(subUnitId!==activeSubUnitId)return!1;if(unitType===L.SelectRange){const ranges=rule.ranges||[];ranges!==currentRuleRanges&&currentRuleRangesSet(ranges)}else if(unitType===L.Worksheet){const ranges=[{startRow:0,endRow:activeSheet.getRowCount()-1,startColumn:0,endColumn:activeSheet.getColumnCount()-1}];ranges!==currentRuleRanges&&currentRuleRangesSet(ranges)}},"onMouseMove"),onMouseLeave:__name(()=>currentRuleRangesSet([]),"onMouseLeave"),children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemHeader,children:[jsxRuntimeExports.jsx(design.Tooltip,{title:ruleName,children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemHeaderName,children:ruleName})}),hasManagerPermission&&jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemHeaderOperator,children:[jsxRuntimeExports.jsx(design.Tooltip,{title:localeService.t("permission.panel.edit"),children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemHeaderIcon,onClick:__name(()=>handleEdit(rule),"onClick"),children:jsxRuntimeExports.jsx(WriteSingle,{})})}),jsxRuntimeExports.jsx(design.Tooltip,{title:localeService.t("permission.panel.delete"),children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemHeaderIcon,onClick:__name(()=>handleDelete(rule),"onClick"),children:jsxRuntimeExports.jsx(DeleteSingle,{})})})]})]}),jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemSplit}),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemContent,children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemContentEdit,children:[jsxRuntimeExports.jsx(design.Tooltip,{title:(_d=item.creator)==null?void 0:_d.userID,children:jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsx(design.Avatar,{src:(_e=item.creator)==null?void 0:_e.avatar,style:{marginRight:6},size:24})})}),jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentTitle,children:localeService.t("permission.panel.created")}),jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentSub,children:editPermission?`${localeService.t("permission.panel.iCanEdit")}`:`${localeService.t("permission.panel.iCanNotEdit")}`})]}),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemContentView,children:[jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentTitle,children:localeService.t("permission.panel.viewPermission")}),jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentSub,children:viewPermission?`${localeService.t("permission.panel.iCanView")}`:`${localeService.t("permission.panel.iCanNotView")}`})]}),rule.description&&jsxRuntimeExports.jsx(design.Tooltip,{title:rule.description,children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemContentDesc,children:rule.description})})]})]},item.objectID)})}):jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListEmpty,children:[jsxRuntimeExports.jsx("img",{width:240,height:120,src:panelListEmptyBase64,alt:""}),jsxRuntimeExports.jsx("p",{className:styles$6.sheetPermissionListEmptyText,children:localeService.t("permission.dialog.listEmpty")})]})]})},"SheetPermissionPanelList"),spinContainer="univer-spin-container",spinOverlay="univer-spin-overlay",spinner="univer-spinner",spin="univer-spin",contentBlur="univer-content-blur",styles$5={spinContainer,spinOverlay,spinner,spin,contentBlur},Spin=__name(({loading,children})=>jsxRuntimeExports.jsxs("div",{className:styles$5.spinContainer,children:[loading&&jsxRuntimeExports.jsx("div",{className:styles$5.spinOverlay,children:jsxRuntimeExports.jsx("div",{className:styles$5.spinner})}),jsxRuntimeExports.jsx("div",{className:loading?styles$5.contentBlur:"",children})]}),"Spin"),UserEmptyBase64="",permissionPanelDetailWrapper="univer-permission-panel-detail-wrapper",radioGroupVertical="univer-radio-group-vertical",sheetPermissionDesignPersonPanel="univer-sheet-permission-design-person-panel",sheetPermissionDesignPersonPanelHeader="univer-sheet-permission-design-person-panel-header",sheetPermissionDesignPersonPanelHeaderAdd="univer-sheet-permission-design-person-panel-header-add",sheetPermissionDesignPersonPanelSplit="univer-sheet-permission-design-person-panel-split",sheetPermissionDesignPersonPanelContentItem="univer-sheet-permission-design-person-panel-content-item",sheetPermissionDesignPersonPanelContentItemName="univer-sheet-permission-design-person-panel-content-item-name",sheetPermissionDesignPersonPanelContentItemSelect="univer-sheet-permission-design-person-panel-content-item-select",sheetPermissionDesignPersonPanelContent="univer-sheet-permission-design-person-panel-content",sheetPermissionUserListEmpty$1="univer-sheet-permission-user-list-empty",sheetPermissionUserListEmptyText$1="univer-sheet-permission-user-list-empty-text",sheetPermissionPanelTitle="univer-sheet-permission-panel-title",permissionRangeSelector="univer-permission-range-selector",permissionRangeSelectorError="univer-permission-range-selector-error",sheetPermissionPanelNameInputError="univer-sheet-permission-panel-name-input-error",permissionRangeSelectorErrorText="univer-permission-range-selector-error-text",sheetPermissionPanelNameInputErrorText="univer-sheet-permission-panel-name-input-error-text",styles$4={permissionPanelDetailWrapper,radioGroupVertical,sheetPermissionDesignPersonPanel,sheetPermissionDesignPersonPanelHeader,sheetPermissionDesignPersonPanelHeaderAdd,sheetPermissionDesignPersonPanelSplit,sheetPermissionDesignPersonPanelContentItem,sheetPermissionDesignPersonPanelContentItemName,sheetPermissionDesignPersonPanelContentItemSelect,sheetPermissionDesignPersonPanelContent,sheetPermissionUserListEmpty:sheetPermissionUserListEmpty$1,sheetPermissionUserListEmptyText:sheetPermissionUserListEmptyText$1,sheetPermissionPanelTitle,permissionRangeSelector,permissionRangeSelectorError,sheetPermissionPanelNameInputError,permissionRangeSelectorErrorText,sheetPermissionPanelNameInputErrorText},SheetPermissionPanelDetail=__name(({fromSheetBar})=>{var _a61,_b;const localeService=core.useDependency(core.LocaleService),dialogService=core.useDependency(ui.IDialogService),univerInstanceService=core.useDependency(core.IUniverInstanceService),selectionManagerService=core.useDependency(sheets.SheetsSelectionsService),sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),activeRule=ui.useObservable(sheetPermissionPanelModel.rule$,sheetPermissionPanelModel.rule),userManagerService=core.useDependency(core.UserManagerService),sheetPermissionUserManagerService=core.useDependency(SheetPermissionUserManagerService),authzIoService=core.useDependency(core.IAuthzIoService),sidebarService=core.useDependency(ui.ISidebarService),rangeProtectionRuleModel=core.useDependency(sheets.RangeProtectionRuleModel),worksheetRuleModel=core.useDependency(sheets.WorksheetProtectionRuleModel),componentManager=core.useDependency(ui.ComponentManager),RangeSelector=React.useMemo(()=>componentManager.get(RANGE_SELECTOR_COMPONENT_KEY),[]),rangeErrorMsg=ui.useObservable(sheetPermissionPanelModel.rangeErrorMsg$),rangeSelectorActionsRef=React.useRef({}),[isFocusRangeSelector,isFocusRangeSelectorSet]=React.useState(!1),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),selectUserList=ui.useObservable(sheetPermissionUserManagerService.selectUserList$,sheetPermissionUserManagerService.selectUserList),[editorGroupValue,setEditorGroupValue]=React.useState(selectUserList.length?editState.designedUserCanEdit:editState.onlyMe),[viewGroupValue,setViewGroupValue]=React.useState(viewState.othersCanView),[loading,setLoading]=React.useState(!!(activeRule!=null&&activeRule.permissionId)),[rangeInitialization,setRangeInitialization]=React.useState(!1),handleAddPerson=__name(async()=>{const userList=await authzIoService.listCollaborators({objectID:unitId,unitID:unitId});userList.forEach(user=>{user!=null&&user.subject&&userManagerService.addUser(user.subject)}),sheetPermissionUserManagerService.setUserList(userList),dialogService.open({id:UNIVER_SHEET_PERMISSION_USER_DIALOG_ID,title:{title:""},children:{label:UNIVER_SHEET_PERMISSION_USER_DIALOG},width:280,destroyOnClose:!0,onClose:__name(()=>dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID),"onClose"),className:"sheet-permission-user-dialog"})},"handleAddPerson"),checkRangeValid=__name(permissionRanges=>{let rangeErrorString="";if(permissionRanges.length===0)rangeErrorString=localeService.t("permission.panel.emptyRangeError");else if(permissionRanges.length>1){let hasLap=!1;for(let i=0;i<permissionRanges.length;i++){for(let j=i+1;j<permissionRanges.length;j++)if(core.Rectangle.intersects(permissionRanges[i],permissionRanges[j])){hasLap=!0;break}if(hasLap)break}hasLap&&(rangeErrorString=localeService.t("permission.panel.rangeOverlapError"))}if(!rangeErrorString){if(worksheetRuleModel.getRule(unitId,subUnitId)&&!(activeRule!=null&&activeRule.permissionId))return rangeErrorString=localeService.t("permission.panel.rangeOverlapOverPermissionError"),rangeErrorString;const lapRule=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.permissionId!==(activeRule==null?void 0:activeRule.permissionId)).find(rule=>rule.ranges.some(ruleRange=>permissionRanges.some(r2=>core.Rectangle.intersects(ruleRange,r2))));(lapRule==null?void 0:lapRule.ranges.find(range=>permissionRanges.some(r2=>core.Rectangle.intersects(range,r2))))&&(rangeErrorString=localeService.t("permission.panel.rangeOverlapOverPermissionError"))}return rangeErrorString===""?void 0:rangeErrorString},"checkRangeValid");React.useEffect(()=>{var _a62,_b2;if(activeRule==null?void 0:activeRule.permissionId){activeRule.unitType===L.Worksheet&&sheetPermissionPanelModel.setRule({ranges:[{startRow:0,startColumn:0,endRow:worksheet.getRowCount()-1,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL}]});return}fromSheetBar&&(selectionManagerService.clearCurrentSelections(),selectionManagerService.addSelections([{primary:null,style:null,range:{startRow:0,startColumn:0,endRow:worksheet.getRowCount()-1,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL}}]));const ranges=(_b2=(_a62=selectionManagerService.getCurrentSelections())==null?void 0:_a62.map(s=>s.range))!=null?_b2:[],rangeErrorString=checkRangeValid(ranges);sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString);const rangeStr2=ranges!=null&&ranges.length?ranges.map(range=>{const v=engineFormula.serializeRange(range);return v==="NaN"?"":v}).filter(r2=>!!r2).join(","):"",sheetName=worksheet.getName();sheetPermissionPanelModel.setRule({ranges,name:fromSheetBar?`${sheetName}`:`${sheetName}(${rangeStr2})`,unitId,subUnitId,unitType:fromSheetBar?L.Worksheet:L.SelectRange}),setRangeInitialization(!0)},[activeRule==null?void 0:activeRule.permissionId,fromSheetBar,selectionManagerService,sheetPermissionPanelModel,subUnitId,unitId,worksheet]),React.useEffect(()=>{const getSelectUserList=__name(async()=>{const permissionId=activeRule==null?void 0:activeRule.permissionId,selectUserList2=(await authzIoService.listCollaborators({objectID:permissionId,unitID:unitId})).filter(user=>user.role===S.Editor);sheetPermissionUserManagerService.setSelectUserList(selectUserList2),sheetPermissionUserManagerService.setOldCollaboratorList(selectUserList2)},"getSelectUserList");activeRule!=null&&activeRule.permissionId?getSelectUserList():(sheetPermissionUserManagerService.setSelectUserList([]),sheetPermissionUserManagerService.setOldCollaboratorList([]))},[activeRule==null?void 0:activeRule.permissionId]),React.useEffect(()=>{if(!activeRule.permissionId){sheetPermissionPanelModel.setRule({viewStatus:viewState.othersCanView});return}__name(async()=>{var _a62,_b2;try{const res=await authzIoService.list({unitID:unitId,objectIDs:[activeRule==null?void 0:activeRule.permissionId],actions:[D.View,D.Edit]});if(!res.length)setViewGroupValue(viewState.othersCanView),setEditorGroupValue(editState.onlyMe),sheetPermissionPanelModel.setRule({viewStatus:viewState.othersCanView,editStatus:editState.onlyMe});else{const isAllCanView=((_a62=res[0].scope)==null?void 0:_a62.read)===T.AllCollaborator,isSomeCanEdit=((_b2=res[0].scope)==null?void 0:_b2.edit)===T.SomeCollaborator,viewValue=isAllCanView?viewState.othersCanView:viewState.noOneElseCanView,editValue=isSomeCanEdit?editState.designedUserCanEdit:editState.onlyMe;setViewGroupValue(viewValue),setEditorGroupValue(editValue),sheetPermissionPanelModel.setRule({viewStatus:viewValue,editStatus:editValue})}}catch(error){console.error(error)}finally{setTimeout(()=>{setLoading(!1)},100)}},"getCollaboratorInit")()},[activeRule.permissionId]),React.useEffect(()=>{__name(async()=>{const userList=await authzIoService.listCollaborators({objectID:unitId,unitID:unitId});userList.forEach(user=>{user!=null&&user.subject&&userManagerService.addUser(user.subject)}),sheetPermissionUserManagerService.setUserList(userList.filter(user=>user.role===S.Editor)),sheetPermissionUserManagerService.setAllUserList(userList.filter(user=>user.role===S.Editor||user.role===S.Reader))},"getListCollaborators")()},[]),React.useEffect(()=>{const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook2)return;const activeSheetSubscribe=workbook2.activeSheet$.subscribe(sheet=>{(sheet==null?void 0:sheet.getSheetId())!==subUnitId&&sidebarService.close()});return()=>{activeSheetSubscribe.unsubscribe()}},[sidebarService,subUnitId,univerInstanceService]);const handleRangeChange=__name(rangeText=>{const newRange=rangeText.split(",").map(engineFormula.deserializeRangeWithSheet).map(item=>item.range);if(newRange.some(i=>!core.isValidRange(i)||i.endColumn<i.startColumn||i.endRow<i.startRow))return;const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet2=workbook2.getActiveSheet(),unitId2=workbook2.getUnitId(),subUnitId2=worksheet2.getSheetId(),transformedRange=newRange.map(range=>{const rowCount=worksheet2.getRowCount(),colCount=worksheet2.getColumnCount();return sheets.setEndForRange(range,rowCount,colCount),range}),rangeErrorString=checkRangeValid(transformedRange);if(sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString),rangeErrorString)return;const sheetName=worksheet2.getName(),rangeStr2=transformedRange.map(range=>{const v=engineFormula.serializeRange(range);return v==="NaN"?"":v}).filter(r2=>!!r2).join(","),rule={ranges:transformedRange,unitId:unitId2,subUnitId:subUnitId2,unitType:L.SelectRange,name:`${sheetName}(${rangeStr2})`};if(rule.ranges.length===1){const{startRow,endRow,startColumn,endColumn}=rule.ranges[0];startRow===0&&endRow===worksheet2.getRowCount()-1&&startColumn===0&&worksheet2.getColumnCount()-1===endColumn&&(rule.unitType=L.Worksheet,rule.name=`${sheetName}`)}sheetPermissionPanelModel.setRule(rule)},"handleRangeChange"),handlePanelClick=__name(e=>{var _a62;const handleOutClick=(_a62=rangeSelectorActionsRef.current)==null?void 0:_a62.handleOutClick;handleOutClick&&handleOutClick(e,isFocusRangeSelectorSet)},"handlePanelClick"),rangeStr=(_a61=activeRule==null?void 0:activeRule.ranges)==null?void 0:_a61.map(i=>engineFormula.serializeRange(i)).join(",");return jsxRuntimeExports.jsx("div",{className:styles$4.permissionPanelDetailWrapper,onClick:handlePanelClick,children:jsxRuntimeExports.jsxs(Spin,{loading,children:[jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.protectedRange"),children:RangeSelector&&rangeInitialization&&jsxRuntimeExports.jsx(RangeSelector,{unitId,errorText:rangeErrorMsg,subUnitId,initValue:rangeStr,onChange:handleRangeChange,isFocus:isFocusRangeSelector,actions:rangeSelectorActionsRef.current})}),jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.permissionDirection"),children:jsxRuntimeExports.jsx(design.Input,{value:(_b=activeRule==null?void 0:activeRule.description)!=null?_b:"",onChange:__name(v=>sheetPermissionPanelModel.setRule({description:v}),"onChange"),placeholder:localeService.t("permission.panel.permissionDirectionPlaceholder")})}),jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.editPermission"),children:jsxRuntimeExports.jsxs(design.RadioGroup,{value:editorGroupValue,onChange:__name(v=>{setEditorGroupValue(v),sheetPermissionPanelModel.setRule({editStatus:v})},"onChange"),className:styles$4.radioGroupVertical,children:[jsxRuntimeExports.jsx(design.Radio,{value:editState.onlyMe,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.onlyICanEdit")})}),jsxRuntimeExports.jsx(design.Radio,{value:editState.designedUserCanEdit,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.designedUserCanEdit")})})]})}),editorGroupValue==="designedUserCanEdit"&&jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionDesignPersonPanel,children:[jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionDesignPersonPanelHeader,children:[jsxRuntimeExports.jsx("span",{children:localeService.t("permission.panel.designedPerson")}),jsxRuntimeExports.jsx("span",{className:styles$4.sheetPermissionDesignPersonPanelHeaderAdd,onClick:handleAddPerson,children:localeService.t("permission.panel.addPerson")})]}),jsxRuntimeExports.jsx("div",{className:styles$4.sheetPermissionDesignPersonPanelSplit}),jsxRuntimeExports.jsx("div",{className:styles$4.sheetPermissionDesignPersonPanelContent,children:(selectUserList==null?void 0:selectUserList.length)>0?selectUserList.map(item=>{var _a62,_b2,_c;return jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionDesignPersonPanelContentItem,children:[jsxRuntimeExports.jsx(design.Avatar,{size:24,src:(_a62=item.subject)==null?void 0:_a62.avatar}),jsxRuntimeExports.jsx("span",{className:styles$4.sheetPermissionDesignPersonPanelContentItemName,children:(_b2=item.subject)==null?void 0:_b2.name}),jsxRuntimeExports.jsx(design.Select,{className:styles$4.sheetPermissionDesignPersonPanelContentItemSelect,value:"edit",onChange:__name(v=>{v==="delete"&&sheetPermissionUserManagerService.setSelectUserList(selectUserList.filter(i=>{var _a63,_b3;return((_a63=i.subject)==null?void 0:_a63.userID)!==((_b3=item.subject)==null?void 0:_b3.userID)}))},"onChange"),options:[{label:`${localeService.t("permission.panel.canEdit")}`,value:"edit"},{label:`${localeService.t("permission.panel.delete")}`,value:"delete"}]})]},(_c=item.subject)==null?void 0:_c.userID)}):jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionUserListEmpty,children:[jsxRuntimeExports.jsx("img",{width:240,height:120,src:UserEmptyBase64,alt:""}),jsxRuntimeExports.jsx("p",{className:styles$4.sheetPermissionUserListEmptyText,children:localeService.t("permission.dialog.userEmpty")})]})})]}),jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.viewPermission"),children:jsxRuntimeExports.jsxs(design.RadioGroup,{value:viewGroupValue,onChange:__name(v=>{setViewGroupValue(v),sheetPermissionPanelModel.setRule({viewStatus:v})},"onChange"),className:styles$4.radioGroupVertical,children:[jsxRuntimeExports.jsx(design.Radio,{value:viewState.othersCanView,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.othersCanView")})}),jsxRuntimeExports.jsx(design.Radio,{value:viewState.noOneElseCanView,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.noOneElseCanView")})})]})})]})})},"SheetPermissionPanelDetail"),SheetPermissionPanel=__name(({showDetail,fromSheetBar})=>{var _a61;const univerInstanceService=core.useDependency(core.IUniverInstanceService),sheetsSelectionsService=core.useDependency(sheets.SheetsSelectionsService);if(!core.useDependency(SheetPermissionPanelModel).getVisible())return null;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return null;const{worksheet}=target,key=((_a61=sheetsSelectionsService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range)).reduce((acc,range)=>acc+engineFormula.serializeRangeWithSheet(worksheet.getName(),range),"");return showDetail?jsxRuntimeExports.jsx(SheetPermissionPanelDetail,{fromSheetBar},key):jsxRuntimeExports.jsx(SheetPermissionPanelList,{},key)},"SheetPermissionPanel"),sheetPermissionDialogWrapper="univer-sheet-permission-dialog-wrapper",sheetPermissionDialogSplit="univer-sheet-permission-dialog-split",sheetPermissionDialogItem="univer-sheet-permission-dialog-item",sheetPermissionUserDialogFooter$1="univer-sheet-permission-user-dialog-footer",sheetPermissionUserDialogFooterConfirm$1="univer-sheet-permission-user-dialog-footer-confirm",sheetPermissionUserDialogButton$1="univer-sheet-permission-user-dialog-button",styles$3={sheetPermissionDialogWrapper,sheetPermissionDialogSplit,sheetPermissionDialogItem,sheetPermissionUserDialogFooter:sheetPermissionUserDialogFooter$1,sheetPermissionUserDialogFooterConfirm:sheetPermissionUserDialogFooterConfirm$1,sheetPermissionUserDialogButton:sheetPermissionUserDialogButton$1},SheetPermissionDialog=__name(()=>{const localeService=core.useDependency(core.LocaleService),univerInstanceService=core.useDependency(core.IUniverInstanceService),authzIoService=core.useDependency(core.IAuthzIoService),worksheetProtectionPointRuleModel=core.useDependency(sheets.WorksheetProtectionPointModel),dialogService=core.useDependency(ui.IDialogService),permissionService=core.useDependency(core.IPermissionService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const[collaborators,setCollaborators]=React.useState([]),commandService=core.useDependency(core.ICommandService),[loading,setLoading]=React.useState(()=>!!worksheetProtectionPointRuleModel.getRule(workbook.getUnitId(),worksheet.getSheetId())),[permissionMap,setPermissionMap]=React.useState(()=>Object.keys(subUnitPermissionTypeMap).reduce((acc,action)=>(acc[action]={text:localeService.t(`permission.panel.${subUnitPermissionTypeMap[Number(action)]}`),allowed:!0},acc),{}));React.useEffect(()=>{__name(async()=>{const unitId=workbook.getUnitId(),collaborators2=await authzIoService.listCollaborators({objectID:unitId,unitID:unitId});setCollaborators(collaborators2)},"getUserList")()},[]),React.useEffect(()=>{__name(async()=>{const unitId=workbook.getUnitId(),worksheetPointRule=worksheetProtectionPointRuleModel.getRule(unitId,worksheet.getSheetId());if(!worksheetPointRule)return;setLoading(!0);const actions=(await authzIoService.list({unitID:workbook.getUnitId(),objectIDs:[worksheetPointRule.permissionId],actions:defaultWorksheetUnitActionList}))[0].strategies.reduce((p2,c)=>(subUnitPermissionTypeMap[c.action]&&(p2[c.action]={text:localeService.t(`permission.panel.${subUnitPermissionTypeMap[c.action]}`),allowed:c.role!==S.Owner}),p2),{});setPermissionMap(actions),setTimeout(()=>{setLoading(!1)},100)},"getPermissionPoints")()},[]);const handleChangeActionPermission=__name(async()=>{const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet2=workbook2==null?void 0:workbook2.getActiveSheet();if(!worksheet2)throw new Error("No active sheet found");const unitId=workbook2.getUnitId(),subUnitId=worksheet2.getSheetId(),pointRule=worksheetProtectionPointRuleModel.getRule(unitId,subUnitId),actions=Object.keys(permissionMap).map(action=>({action:Number(action),role:permissionMap[action].allowed?S.Editor:S.Owner}));let permissionId=pointRule==null?void 0:pointRule.permissionId;permissionId?authzIoService.update({objectType:L.Worksheet,objectID:permissionId,unitID:unitId,strategies:actions,share:void 0,name:"",scope:{read:T.AllCollaborator,edit:T.AllCollaborator},collaborators:void 0}).then(()=>{sheets.getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(unitId,subUnitId),unitActionName=instance.subType,action=actions.find(item=>item.action===unitActionName);action&&permissionService.updatePermissionPoint(instance.id,action.role===S.Editor)})}):(permissionId=await authzIoService.create({objectType:L.Worksheet,worksheetObject:{unitID:unitId,collaborators,name:"",strategies:actions,scope:{read:T.AllCollaborator,edit:T.AllCollaborator}}}),commandService.executeCommand(sheets.SetWorksheetPermissionPointsCommand.id,{rule:{permissionId,unitId,subUnitId}}))},"handleChangeActionPermission");return jsxRuntimeExports.jsx(Spin,{loading,children:jsxRuntimeExports.jsxs("div",{className:styles$3.sheetPermissionDialogWrapper,children:[jsxRuntimeExports.jsx("div",{className:styles$3.sheetPermissionDialogSplit}),Object.keys(permissionMap).map(action=>{const actionItem=permissionMap[action],{text,allowed}=actionItem;return jsxRuntimeExports.jsxs("div",{className:styles$3.sheetPermissionDialogItem,children:[jsxRuntimeExports.jsx("div",{children:text}),jsxRuntimeExports.jsx(design.Switch,{defaultChecked:allowed,onChange:__name(()=>{setPermissionMap({...permissionMap,[action]:{...actionItem,allowed:!allowed}})},"onChange")})]},text)}),jsxRuntimeExports.jsx("div",{className:styles$3.sheetPermissionDialogSplit}),jsxRuntimeExports.jsxs("div",{className:styles$3.sheetPermissionUserDialogFooter,children:[jsxRuntimeExports.jsx(design.Button,{className:styles$3.sheetPermissionUserDialogButton,onClick:__name(()=>{dialogService.close(UNIVER_SHEET_PERMISSION_DIALOG_ID)},"onClick"),children:localeService.t("permission.button.cancel")}),jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(()=>{handleChangeActionPermission(),dialogService.close(UNIVER_SHEET_PERMISSION_DIALOG_ID)},"onClick"),className:clsx(styles$3.sheetPermissionUserDialogFooterConfirm,styles$3.sheetPermissionUserDialogButton),children:localeService.t("permission.button.confirm")})]})]})})},"SheetPermissionDialog"),sheetPermissionUserDialogWrapper="univer-sheet-permission-user-dialog-wrapper",sheetPermissionUserDialogSearchInput="univer-sheet-permission-user-dialog-search-input",sheetPermissionUserList="univer-sheet-permission-user-list",sheetPermissionUserListEmpty="univer-sheet-permission-user-list-empty",sheetPermissionUserListEmptyText="univer-sheet-permission-user-list-empty-text",sheetPermissionUserItem="univer-sheet-permission-user-item",sheetPermissionUserItemName="univer-sheet-permission-user-item-name",sheetPermissionSplit="univer-sheet-permission-split",sheetPermissionUserDialogFooter="univer-sheet-permission-user-dialog-footer",sheetPermissionUserDialogFooterConfirm="univer-sheet-permission-user-dialog-footer-confirm",sheetPermissionUserDialogButton="univer-sheet-permission-user-dialog-button",styles$2={sheetPermissionUserDialogWrapper,sheetPermissionUserDialogSearchInput,sheetPermissionUserList,sheetPermissionUserListEmpty,sheetPermissionUserListEmptyText,sheetPermissionUserItem,sheetPermissionUserItemName,sheetPermissionSplit,sheetPermissionUserDialogFooter,sheetPermissionUserDialogFooterConfirm,sheetPermissionUserDialogButton},SheetPermissionUserDialog=__name(()=>{const[inputValue,setInputValue]=React.useState(""),localeService=core.useDependency(core.LocaleService),dialogService=core.useDependency(ui.IDialogService),sheetPermissionUserManagerService=core.useDependency(SheetPermissionUserManagerService),searchUserList=sheetPermissionUserManagerService.userList.filter(item=>{var _a61;return((_a61=item.subject)==null?void 0:_a61.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase()))&&item.role===S.Editor}),[selectUserInfo,setSelectUserInfo]=React.useState(sheetPermissionUserManagerService.selectUserList),handleChangeUser=__name(item=>{if((selectUserInfo==null?void 0:selectUserInfo.findIndex(v=>{var _a61,_b;return((_a61=v.subject)==null?void 0:_a61.userID)===((_b=item.subject)==null?void 0:_b.userID)}))===-1){const select={...item};setSelectUserInfo([...selectUserInfo,select])}else{const newSelectUserInfo=selectUserInfo.filter(v=>{var _a61,_b;return((_a61=v.subject)==null?void 0:_a61.userID)!==((_b=item.subject)==null?void 0:_b.userID)});setSelectUserInfo(newSelectUserInfo)}},"handleChangeUser");return jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserDialogWrapper,children:[jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionUserDialogSearch,children:jsxRuntimeExports.jsx(design.Input,{placeholder:"search",className:styles$2.sheetPermissionUserDialogSearchInput,value:inputValue,onChange:__name(v=>setInputValue(v),"onChange")})}),jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionUserList,children:(searchUserList==null?void 0:searchUserList.length)>0?jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{children:searchUserList==null?void 0:searchUserList.map(item=>{var _a61,_b,_c;return jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserItem,onClick:__name(()=>handleChangeUser(item),"onClick"),children:[jsxRuntimeExports.jsx(design.Avatar,{src:(_a61=item.subject)==null?void 0:_a61.avatar,size:24}),jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionUserItemName,children:(_b=item.subject)==null?void 0:_b.name}),(selectUserInfo==null?void 0:selectUserInfo.findIndex(v=>{var _a62,_b2;return((_a62=v.subject)==null?void 0:_a62.userID)===((_b2=item.subject)==null?void 0:_b2.userID)}))!==-1&&jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsx(CheckMarkSingle,{})})]},(_c=item.subject)==null?void 0:_c.userID)})}):jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserListEmpty,children:[jsxRuntimeExports.jsx("img",{width:240,height:120,src:UserEmptyBase64,alt:""}),jsxRuntimeExports.jsx("p",{className:styles$2.sheetPermissionUserListEmptyText,children:localeService.t("permission.dialog.userEmpty")})]})}),jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionSplit}),jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserDialogFooter,children:[jsxRuntimeExports.jsx(design.Button,{className:styles$2.sheetPermissionUserDialogButton,onClick:__name(()=>dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID),"onClick"),children:localeService.t("permission.button.cancel")}),jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(()=>{sheetPermissionUserManagerService.setSelectUserList(selectUserInfo),dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID)},"onClick"),className:clsx(styles$2.sheetPermissionUserDialogFooterConfirm,styles$2.sheetPermissionUserDialogButton),children:localeService.t("permission.button.confirm")})]})]})},"SheetPermissionUserDialog"),sheetPermissionAlertDialog="univer-sheet-permission-alert-dialog",sheetPermissionAlertDialogTitle="univer-sheet-permission-alert-dialog-title",sheetPermissionAlertDialogButton="univer-sheet-permission-alert-dialog-button",styles$1={sheetPermissionAlertDialog,sheetPermissionAlertDialogTitle,sheetPermissionAlertDialogButton},AlertDialog=__name(({errorMsg})=>{const localeService=core.useDependency(core.LocaleService),dialogService=core.useDependency(ui.IDialogService);return jsxRuntimeExports.jsxs("div",{className:styles$1.sheetPermissionAlertDialog,children:[jsxRuntimeExports.jsx("h1",{className:styles$1.sheetPermissionAlertDialogTitle,children:localeService.t("permission.dialog.alert")}),jsxRuntimeExports.jsx("p",{children:errorMsg||localeService.t("permission.dialog.alertContent")}),jsxRuntimeExports.jsx("div",{className:styles$1.sheetPermissionAlertDialogButton,children:jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(()=>{dialogService.close(UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID)},"onClick"),children:localeService.t("permission.button.confirm")})})]})},"AlertDialog"),base64="",RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY="RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY",RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY="RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY",EXTENSION_CAN_VIEW_Z_INDEX$1=25,EXTENSION_CAN_NOT_VIEW_Z_INDEX$1=80,_RangeProtectionRenderExtension=class _RangeProtectionRenderExtension extends engineRender.SheetExtension{constructor(){super();__publicField(this,"_pattern",null);__publicField(this,"_img",new Image);__publicField(this,"renderCache",new Set);this._img.src=base64}clearCache(){this.renderCache.clear()}draw(ctx,_parentScale,spreadsheetSkeleton){const{worksheet}=spreadsheetSkeleton;worksheet&&(ctx.save(),this._pattern||(this._pattern=ctx.createPattern(this._img,"repeat")),this.renderCache.clear(),core.Range.foreach(spreadsheetSkeleton.rowColumnSegment,(row,col)=>{if(!worksheet.getRowVisible(row)||!worksheet.getColVisible(col))return;const{selectionProtection=[]}=worksheet.getCell(row,col)||{};this._pattern&&(ctx.fillStyle=this._pattern,selectionProtection.forEach(config=>{if(config.ruleId&&this.shouldRender(config)){if(this.renderCache.has(config.ruleId))return;this.renderCache.add(config.ruleId),config.ranges.forEach(range=>{const start=spreadsheetSkeleton.getCellByIndexWithNoHeader(range.startRow,range.startColumn),end=spreadsheetSkeleton.getCellByIndexWithNoHeader(range.endRow,range.endColumn);ctx.fillRect(start.startX,start.startY,end.endX-start.startX,end.endY-start.startY)})}}))}),ctx.restore())}};__name(_RangeProtectionRenderExtension,"RangeProtectionRenderExtension");let RangeProtectionRenderExtension=_RangeProtectionRenderExtension;const _RangeProtectionCanViewRenderExtension=class _RangeProtectionCanViewRenderExtension extends RangeProtectionRenderExtension{constructor(){super();__publicField(this,"uKey",RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY);__publicField(this,"Z_INDEX",EXTENSION_CAN_VIEW_Z_INDEX$1)}shouldRender(config){return(config==null?void 0:config[D.View])!==!1}};__name(_RangeProtectionCanViewRenderExtension,"RangeProtectionCanViewRenderExtension");let RangeProtectionCanViewRenderExtension=_RangeProtectionCanViewRenderExtension;const _RangeProtectionCanNotViewRenderExtension=class _RangeProtectionCanNotViewRenderExtension extends RangeProtectionRenderExtension{constructor(){super();__publicField(this,"uKey",RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY);__publicField(this,"Z_INDEX",EXTENSION_CAN_NOT_VIEW_Z_INDEX$1)}shouldRender(config){return(config==null?void 0:config[D.View])===!1}};__name(_RangeProtectionCanNotViewRenderExtension,"RangeProtectionCanNotViewRenderExtension");let RangeProtectionCanNotViewRenderExtension=_RangeProtectionCanNotViewRenderExtension;const worksheetProtectionKey="worksheet-protection",EXTENSION_CAN_VIEW_Z_INDEX=25,EXTENSION_CAN_NOT_VIEW_Z_INDEX=80,_WorksheetProtectionRenderExtension=class _WorksheetProtectionRenderExtension extends engineRender.SheetExtension{constructor(){super();__publicField(this,"uKey",worksheetProtectionKey);__publicField(this,"Z_INDEX",EXTENSION_CAN_VIEW_Z_INDEX);__publicField(this,"_pattern");__publicField(this,"_img",new Image);this._img.src=base64}draw(ctx,_parentScale,spreadsheetSkeleton){const{worksheet}=spreadsheetSkeleton;if(!worksheet)return!1;ctx.save(),this._pattern||(this._pattern=ctx.createPattern(this._img,"repeat"));const{startRow,startColumn,endRow,endColumn}=spreadsheetSkeleton.rowColumnSegment,start=spreadsheetSkeleton.getCellByIndexWithNoHeader(startRow,startColumn),end=spreadsheetSkeleton.getCellByIndexWithNoHeader(endRow,endColumn),{hasWorksheetRule=!1,selectionProtection=[]}=worksheet.getCell(startRow,startColumn)||{};if(this._pattern){if(selectionProtection.length>0){const cellProtectionConfig=selectionProtection[0];(cellProtectionConfig==null?void 0:cellProtectionConfig[D.View])?this.setZIndex(EXTENSION_CAN_VIEW_Z_INDEX):this.setZIndex(EXTENSION_CAN_NOT_VIEW_Z_INDEX)}ctx.fillStyle=this._pattern,hasWorksheetRule&&ctx.fillRect(start.startX,start.startY,end.endX-start.startX,end.endY-start.startY),ctx.restore()}}setZIndex(zIndex){this.Z_INDEX=zIndex}};__name(_WorksheetProtectionRenderExtension,"WorksheetProtectionRenderExtension");let WorksheetProtectionRenderExtension=_WorksheetProtectionRenderExtension;var __defProp$c=Object.defineProperty,__getOwnPropDesc$c=Object.getOwnPropertyDescriptor,__decorateClass$c=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$c(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$c(target,key,result),result},"__decorateClass$c"),__decorateParam$c=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$c"),_a46;let SheetPermissionRenderManagerController=(_a46=class extends core.Disposable{constructor(_componentManager){super(),this._componentManager=_componentManager,this._init()}_init(){this._initComponents()}_initComponents(){[[permissionMenuIconKey,ProtectSingle],[permissionDeleteIconKey,DeleteSingle],[permissionEditIconKey,WriteSingle],[permissionCheckIconKey,CheckMarkSingle],[permissionLockIconKey,LockSingle],[UNIVER_SHEET_PERMISSION_PANEL,SheetPermissionPanel],[UNIVER_SHEET_PERMISSION_PANEL_FOOTER,SheetPermissionPanelFooter],[UNIVER_SHEET_PERMISSION_USER_DIALOG,SheetPermissionUserDialog],[UNIVER_SHEET_PERMISSION_DIALOG,SheetPermissionDialog],[UNIVER_SHEET_PERMISSION_ALERT_DIALOG,AlertDialog]].forEach(([key,component])=>{this.disposeWithMe(this._componentManager.register(key,component))})}},__name(_a46,"SheetPermissionRenderManagerController"),_a46);SheetPermissionRenderManagerController=__decorateClass$c([__decorateParam$c(0,core.Inject(ui.ComponentManager))],SheetPermissionRenderManagerController);var _a47;let SheetPermissionRenderController=(_a47=class extends core.Disposable{constructor(_context,_rangeProtectionRuleModel,_sheetSkeletonManagerService,_permissionService){super();__publicField(this,"_rangeProtectionCanViewRenderExtension",new RangeProtectionCanViewRenderExtension);__publicField(this,"_rangeProtectionCanNotViewRenderExtension",new RangeProtectionCanNotViewRenderExtension);this._context=_context,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._permissionService=_permissionService,this._initRender(),this._initSkeleton(),this._rangeProtectionRuleModel.ruleChange$.subscribe(info=>{var _a61,_b;((_a61=info.oldRule)!=null&&_a61.id&&this._rangeProtectionCanViewRenderExtension.renderCache.has(info.oldRule.id)||this._rangeProtectionCanViewRenderExtension.renderCache.has(info.rule.id))&&this._rangeProtectionCanViewRenderExtension.clearCache(),((_b=info.oldRule)!=null&&_b.id&&this._rangeProtectionCanNotViewRenderExtension.renderCache.has(info.oldRule.id)||this._rangeProtectionCanNotViewRenderExtension.renderCache.has(info.rule.id))&&this._rangeProtectionCanNotViewRenderExtension.clearCache()})}_initRender(){const spreadsheetRender=this._context.mainComponent;spreadsheetRender&&(spreadsheetRender.getExtensionByKey(RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY)||spreadsheetRender.register(this._rangeProtectionCanViewRenderExtension),spreadsheetRender.getExtensionByKey(RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY)||spreadsheetRender.register(this._rangeProtectionCanNotViewRenderExtension))}_initSkeleton(){const markDirtySkeleton=__name(()=>{var _a61;this._sheetSkeletonManagerService.reCalculate(),(_a61=this._context.mainComponent)==null||_a61.makeDirty()},"markDirtySkeleton");this.disposeWithMe(rxjs.merge(this._permissionService.permissionPointUpdate$.pipe(rxjs.throttleTime(300,void 0,{trailing:!0})),this._rangeProtectionRuleModel.rangeRuleInitStateChange$,this._rangeProtectionRuleModel.ruleChange$).pipe().subscribe(markDirtySkeleton))}},__name(_a47,"SheetPermissionRenderController"),_a47);SheetPermissionRenderController=__decorateClass$c([__decorateParam$c(1,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$c(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$c(3,core.IPermissionService)],SheetPermissionRenderController);var _a48;let WorksheetProtectionRenderController=(_a48=class extends core.Disposable{constructor(_context,_renderManagerService,_univerInstanceService,_sheetSkeletonManagerService,_worksheetProtectionRuleModel){super();__publicField(this,"_worksheetProtectionRenderExtension",new WorksheetProtectionRenderExtension);this._context=_context,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._initRender(),this._initSkeleton()}_initRender(){const renderId=this._context.unitId,render2=renderId&&this._renderManagerService.getRenderById(renderId),spreadsheetRender=render2&&render2.mainComponent;spreadsheetRender&&(spreadsheetRender.getExtensionByKey(worksheetProtectionKey)||spreadsheetRender.register(this._worksheetProtectionRenderExtension))}_initSkeleton(){const markDirtySkeleton=__name(()=>{var _a61;this._sheetSkeletonManagerService.reCalculate(),(_a61=this._context.mainComponent)==null||_a61.makeDirty()},"markDirtySkeleton");this.disposeWithMe(rxjs.merge(this._worksheetProtectionRuleModel.worksheetRuleInitStateChange$).pipe().subscribe(markDirtySkeleton))}},__name(_a48,"WorksheetProtectionRenderController"),_a48);WorksheetProtectionRenderController=__decorateClass$c([__decorateParam$c(1,core.Inject(engineRender.IRenderManagerService)),__decorateParam$c(2,core.Inject(core.IUniverInstanceService)),__decorateParam$c(3,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$c(4,core.Inject(sheets.WorksheetProtectionRuleModel))],WorksheetProtectionRenderController);var __defProp$b=Object.defineProperty,__getOwnPropDesc$b=Object.getOwnPropertyDescriptor,__decorateClass$b=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$b(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$b(target,key,result),result},"__decorateClass$b"),__decorateParam$b=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$b"),_a49;let SheetContextMenuRenderController=(_a49=class extends core.Disposable{constructor(_context,_contextMenuService,_selectionManagerService,_selectionRenderService){super(),this._context=_context,this._contextMenuService=_contextMenuService,this._selectionManagerService=_selectionManagerService,this._selectionRenderService=_selectionRenderService,this._init()}_init(){var _a61,_b;const spreadsheetSubscription=((_b=(_a61=this._context)==null?void 0:_a61.mainComponent)==null?void 0:_b.onPointerDown$).subscribeEvent(event=>{if(event.button===2){const selections=this._selectionManagerService.getCurrentSelections(),currentSelection=selections==null?void 0:selections[0];if(!currentSelection)return;const rangeType=currentSelection.range.rangeType,skeleton=this._selectionRenderService.getSkeleton(),range=attachSelectionWithCoord(currentSelection,skeleton).rangeWithCoord,isPointerInRange=__name(()=>{if(!range)return!1;const x=event.offsetX,y=event.offsetY;switch(rangeType){case core.RANGE_TYPE.ROW:return range.startY<=y&&range.endY>=y;case core.RANGE_TYPE.COLUMN:return range.startX<=x&&range.endX>=x;default:return range.startX<=x&&range.endX>=x&&range.startY<=y&&range.endY>=y}},"isPointerInRange"),triggerMenu=__name(position=>{this._contextMenuService.triggerContextMenu(event,position)},"triggerMenu");isPointerInRange()?rangeType===core.RANGE_TYPE.COLUMN?triggerMenu(ui.ContextMenuPosition.COL_HEADER):rangeType===core.RANGE_TYPE.ROW?triggerMenu(ui.ContextMenuPosition.ROW_HEADER):triggerMenu(ui.ContextMenuPosition.MAIN_AREA):triggerMenu(ui.ContextMenuPosition.MAIN_AREA)}});this.disposeWithMe(spreadsheetSubscription);const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),rowHeaderSub=this._context.components.get(SHEET_VIEW_KEY.ROW).onPointerDown$.subscribeEvent(event=>{event.button===2&&this._contextMenuService.triggerContextMenu(event,ui.ContextMenuPosition.ROW_HEADER)});this.disposeWithMe(rowHeaderSub);const colHeaderObserver=spreadsheetColumnHeader.onPointerDown$.subscribeEvent(event=>{event.button===2&&this._contextMenuService.triggerContextMenu(event,ui.ContextMenuPosition.COL_HEADER)});this.disposeWithMe(colHeaderObserver)}},__name(_a49,"SheetContextMenuRenderController"),_a49);SheetContextMenuRenderController=__decorateClass$b([__decorateParam$b(1,ui.IContextMenuService),__decorateParam$b(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$b(3,ISheetSelectionRenderService)],SheetContextMenuRenderController);var __defProp$a=Object.defineProperty,__getOwnPropDesc$a=Object.getOwnPropertyDescriptor,__decorateClass$a=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$a(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$a(target,key,result),result},"__decorateClass$a"),__decorateParam$a=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$a"),_a50;let EditorBridgeRenderController=(_a50=class extends core.RxDisposable{constructor(_context,_instanceSrv,_commandService,_editorBridgeService,_selectionManagerService,_rangeSelectorService,_contextService,_renderManagerService,_editorService,_sheetSkeletonManagerService){super();__publicField(this,"_d");this._context=_context,this._instanceSrv=_instanceSrv,this._commandService=_commandService,this._editorBridgeService=_editorBridgeService,this._selectionManagerService=_selectionManagerService,this._rangeSelectorService=_rangeSelectorService,this._contextService=_contextService,this._renderManagerService=_renderManagerService,this._editorService=_editorService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this.disposeWithMe(this._instanceSrv.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{workbook&&workbook.getUnitId()===this._context.unitId?this._d=this._init():this._disposeCurrent()})),this._initialRangeSelector()}_init(){const d=new core.DisposableCollection;return this._initSelectionChangeListener(d),this._initEventListener(d),this._commandExecutedListener(d),this._initialKeyboardListener(d),d}_disposeCurrent(){var _a61;(_a61=this._d)==null||_a61.dispose(),this._d=null}_initSelectionChangeListener(d){d.add(rxjs.merge(this._selectionManagerService.selectionMoveEnd$,this._selectionManagerService.selectionMoveStart$).subscribe(params=>this._updateEditorPosition(params)))}_updateEditorPosition(params){var _a61,_b,_c;if(this._editorBridgeService.isVisible().visible||this._rangeSelectorService.selectorModalVisible)return;const primary=(_a61=params==null?void 0:params[params.length-1])==null?void 0:_a61.primary;if(primary){const sheetObject=this._getSheetObject(),{scene,engine}=sheetObject,unitId=this._context.unitId,sheetId=(_b=this._context.unit.getActiveSheet())==null?void 0:_b.getSheetId();if(!sheetId)return;const mergeInfo=(_c=this._sheetSkeletonManagerService.getWorksheetSkeleton(sheetId))==null?void 0:_c.skeleton.getCellByIndex(primary.actualRow,primary.actualColumn),newPrimary=mergeInfo?{actualRow:mergeInfo.actualRow,actualColumn:mergeInfo.actualColumn,isMerged:mergeInfo.isMerged,startRow:mergeInfo.mergeInfo.startRow,startColumn:mergeInfo.mergeInfo.startColumn,endRow:mergeInfo.mergeInfo.endRow,endColumn:mergeInfo.mergeInfo.endColumn,isMergedMainCell:mergeInfo.isMergedMainCell}:primary;this._commandService.executeCommand(SetActivateCellEditOperation.id,{scene,engine,primary:newPrimary,unitId,sheetId})}}_initEventListener(d){const sheetObject=this._getSheetObject(),{spreadsheet,spreadsheetColumnHeader,spreadsheetLeftTopPlaceholder,spreadsheetRowHeader}=sheetObject;d.add(spreadsheet.onDblclick$.subscribeEvent(evt=>{evt.button!==2&&this._commandService.executeCommand(SetCellEditVisibleOperation.id,{visible:!0,eventType:engineRender.DeviceInputEventType.Dblclick,unitId:this._context.unitId})})),d.add(spreadsheet.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1})),d.add(spreadsheetColumnHeader.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1})),d.add(spreadsheetLeftTopPlaceholder.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1})),d.add(spreadsheetRowHeader.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1}))}_initialKeyboardListener(d){var _a61;const docSelectionRenderService=(_a61=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a61.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&d.add(docSelectionRenderService.onInputBefore$.subscribe(config=>{var _a62;if(!this._isCurrentSheetFocused())return;const isFocusFormulaEditor=this._contextService.getContextValue(core.FOCUSING_FX_BAR_EDITOR),isFocusSheets=this._contextService.getContextValue(core.FOCUSING_SHEET),unitId=(_a62=this._instanceSrv.getCurrentUniverDocInstance())==null?void 0:_a62.getUnitId();this._editorBridgeService.isVisible().visible||unitId&&isFocusSheets&&!isFocusFormulaEditor&&this._editorService.isSheetEditor(unitId)&&this._showEditorByKeyboard(config)}))}_commandExecutedListener(d){const refreshCommandSet=new Set([sheets.ClearSelectionFormatCommand.id,sheets.SetRangeValuesMutation.id,SetZoomRatioCommand.id]);d.add(this._commandService.onCommandExecuted(command=>{if(refreshCommandSet.has(command.id)){if(this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellState()}})),d.add(this._commandService.beforeCommandExecuted((command,options)=>{options!=null&&options.fromCollab||command.id===sheets.SetWorksheetActiveOperation.id&&this._tryHideEditor()}))}_showEditorByKeyboard(config){if(config==null)return;const event=config.event;this._commandService.executeCommand(SetCellEditVisibleOperation.id,{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:event.which,unitId:this._context.unitId})}_tryHideEditor(){this._editorBridgeService.isForceKeepVisible()||this._hideEditor()}_hideEditor(){this._editorBridgeService.isVisible().visible===!0&&this._commandService.syncExecuteCommand(SetCellEditVisibleOperation.id,{visible:!1,eventType:engineRender.DeviceInputEventType.PointerDown,unitId:this._context.unitId})}_initialRangeSelector(){this.disposeWithMe(this._selectionManagerService.selectionMoving$.subscribe(this._rangeSelector.bind(this))),this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(this._rangeSelector.bind(this))),this.disposeWithMe(this._rangeSelectorService.openSelector$.subscribe(()=>{const{unitId,sheetId,sheetName}=this._getCurrentUnitIdAndSheetId();if(!sheetId||!sheetName)return;const selectionWithStyle=this._selectionManagerService.getCurrentSelections(),ranges=selectionWithStyle==null?void 0:selectionWithStyle.map(value=>({range:value.range,unitId,sheetId,sheetName}));ranges&&this._rangeSelectorService.selectionChange(ranges)}))}_rangeSelector(selectionWithStyle){if(!selectionWithStyle)return;const{unitId,sheetId,sheetName}=this._getCurrentUnitIdAndSheetId();if(!sheetId||!sheetName)return;const ranges=selectionWithStyle.map(value=>({range:value.range,unitId,sheetId,sheetName}));this._rangeSelectorService.selectionChange(ranges)}_getCurrentUnitIdAndSheetId(){const workbook=this._context.unit,worksheet=workbook.getActiveSheet();return{unitId:workbook.getUnitId(),sheetId:worksheet==null?void 0:worksheet.getSheetId(),sheetName:worksheet==null?void 0:worksheet.getName()}}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_isCurrentSheetFocused(){var _a61;return((_a61=this._instanceSrv.getFocusedUnit())==null?void 0:_a61.getUnitId())===this._context.unitId}},__name(_a50,"EditorBridgeRenderController"),_a50);EditorBridgeRenderController=__decorateClass$a([__decorateParam$a(1,core.IUniverInstanceService),__decorateParam$a(2,core.ICommandService),__decorateParam$a(3,IEditorBridgeService),__decorateParam$a(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$a(5,docsUi.IRangeSelectorService),__decorateParam$a(6,core.IContextService),__decorateParam$a(7,engineRender.IRenderManagerService),__decorateParam$a(8,docsUi.IEditorService),__decorateParam$a(9,core.Inject(exports.SheetSkeletonManagerService))],EditorBridgeRenderController);var __defProp$9=Object.defineProperty,__getOwnPropDesc$9=Object.getOwnPropertyDescriptor,__decorateClass$9=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$9(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$9(target,key,result),result},"__decorateClass$9"),__decorateParam$9=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$9"),_a51;let FormatPainterRenderController=(_a51=class extends core.Disposable{constructor(_context,_formatPainterService){super(),this._context=_context,this._formatPainterService=_formatPainterService,this._initialize()}_initialize(){this._bindFormatPainterStatus()}_bindFormatPainterStatus(){this.disposeWithMe(core.toDisposable(this._formatPainterService.status$.subscribe(status=>{const scene=this._context.scene;scene&&(status!==FormatPainterStatus.OFF?scene.setDefaultCursor(engineRender.CURSOR_TYPE.CELL):scene.setDefaultCursor(engineRender.CURSOR_TYPE.DEFAULT))})))}},__name(_a51,"FormatPainterRenderController"),_a51);FormatPainterRenderController=__decorateClass$9([__decorateParam$9(1,IFormatPainterService)],FormatPainterRenderController);var HEADER_MENU_SHAPE_TYPE=(HEADER_MENU_SHAPE_TYPE2=>(HEADER_MENU_SHAPE_TYPE2[HEADER_MENU_SHAPE_TYPE2.NORMAL=0]="NORMAL",HEADER_MENU_SHAPE_TYPE2[HEADER_MENU_SHAPE_TYPE2.HIGHLIGHT=1]="HIGHLIGHT",HEADER_MENU_SHAPE_TYPE2))(HEADER_MENU_SHAPE_TYPE||{});const HEADER_MENU_SHAPE_CIRCLE_FILL="rgba(0, 0, 0, 0.15)",HEADER_MENU_SHAPE_TRIANGLE_FILL="rgb(0, 0, 0)",HEADER_MENU_BACKGROUND_COLOR="rgb(255, 255, 255, 1)",_HeaderMenuShape=class _HeaderMenuShape extends engineRender.Shape{constructor(key,props){super(key,props);__publicField(this,"_size",12);__publicField(this,"_iconRatio",.4);__publicField(this,"_mode",0);this.setShapeProps(props)}setShapeProps(props){props!=null&&props.size&&(this._size=props.size),props!=null&&props.mode&&(this._mode=props.mode),this.transformByState({width:this._size,height:this._size})}_draw(ctx){this._mode===1&&engineRender.Rect.drawWith(ctx,{width:this._size,height:this._size,radius:this._size,fill:HEADER_MENU_SHAPE_CIRCLE_FILL});const iconSize=this._size*.5*this._iconRatio,sixtyDegree=Math.PI/180*60,left=iconSize*Math.sin(sixtyDegree),top=iconSize*Math.cos(sixtyDegree);engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:-left+this._size/2,y:-top+this._size/2},{x:left+this._size/2,y:-top+this._size/2},{x:this._size/2,y:iconSize+this._size/2}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL})}};__name(_HeaderMenuShape,"HeaderMenuShape");let HeaderMenuShape=_HeaderMenuShape;var __defProp$8=Object.defineProperty,__getOwnPropDesc$8=Object.getOwnPropertyDescriptor,__decorateClass$8=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$8(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$8(target,key,result),result},"__decorateClass$8"),__decorateParam$8=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$8");const HEADER_MENU_CONTROLLER_SHAPE="__SpreadsheetHeaderMenuSHAPEControllerShape__",HEADER_MENU_CONTROLLER_MENU="__SpreadsheetHeaderMenuMAINControllerShape__",HEADER_MENU_CONTROLLER_SHAPE_COLOR="rgba(0, 0, 0, 0.1)";var _a52;let HeaderMenuRenderController=(_a52=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_contextMenuService,_commandService,_selectionManagerService){super();__publicField(this,"_hoverRect");__publicField(this,"_hoverMenu");__publicField(this,"_currentColumn",Number.POSITIVE_INFINITY);__publicField(this,"_headerPointerSubs");__publicField(this,"_colHeaderPointerSubs");this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._contextMenuService=_contextMenuService,this._commandService=_commandService,this._selectionManagerService=_selectionManagerService,this._initialize()}dispose(){var _a61,_b,_c;(_a61=this._hoverRect)==null||_a61.dispose(),(_b=this._hoverMenu)==null||_b.dispose(),(_c=this._headerPointerSubs)==null||_c.unsubscribe(),this._headerPointerSubs=null}_initialize(){const scene=this._context.scene;this._hoverRect=new engineRender.Rect(HEADER_MENU_CONTROLLER_SHAPE,{fill:HEADER_MENU_CONTROLLER_SHAPE_COLOR,evented:!1}),this._hoverMenu=new HeaderMenuShape(HEADER_MENU_CONTROLLER_MENU,{zIndex:100,visible:!1}),scene.addObjects([this._hoverRect,this._hoverMenu],SHEET_COMPONENT_HEADER_LAYER_INDEX),this._initialHover(0),this._initialHover(1),this._initialHoverMenu()}_initialHover(initialType=0){var _a61,_b,_c;const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetRowHeader=this._context.components.get(SHEET_VIEW_KEY.ROW),eventBindingObject=initialType===0?spreadsheetRowHeader:spreadsheetColumnHeader,pointerMoveHandler=__name(evt=>{var _a62,_b2,_c2;const skeleton=(_a62=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a62.skeleton;if(skeleton==null)return;const{rowHeaderWidth,columnHeaderHeight}=skeleton,{startX,startY,endX,endY,column}=getCoordByOffset(evt.offsetX,evt.offsetY,this._context.scene,skeleton);if(initialType===0)(_b2=this._hoverRect)==null||_b2.transformByState({width:rowHeaderWidth,height:endY-startY,left:0,top:startY});else{if(this._currentColumn=column,(_c2=this._hoverRect)==null||_c2.transformByState({width:endX-startX,height:columnHeaderHeight,left:startX,top:0}),this._hoverMenu==null)return;if(endX-startX<columnHeaderHeight*2){this._hoverMenu.hide();return}const menuSize=columnHeaderHeight*.8;this._hoverMenu.transformByState({left:endX-columnHeaderHeight,top:columnHeaderHeight/2-menuSize/2}),this._hoverMenu.setShapeProps({size:menuSize}),this._hoverMenu.show()}},"pointerMoveHandler"),pointerEnterHandler=__name(()=>{var _a62;(_a62=this._hoverRect)==null||_a62.show()},"pointerEnterHandler"),pointerLeaveHandler=__name(()=>{var _a62,_b2;(_a62=this._hoverRect)==null||_a62.hide(),(_b2=this._hoverMenu)==null||_b2.hide()},"pointerLeaveHandler");this._headerPointerSubs=new rxjs.Subscription;const headerPointerMoveSub=eventBindingObject.onPointerMove$.subscribeEvent(pointerMoveHandler),headerPointerEnterSub=eventBindingObject.onPointerEnter$.subscribeEvent(pointerEnterHandler),headerPointerLeaveSub=eventBindingObject.onPointerLeave$.subscribeEvent(pointerLeaveHandler);(_a61=this._headerPointerSubs)==null||_a61.add(headerPointerMoveSub),(_b=this._headerPointerSubs)==null||_b.add(headerPointerEnterSub),(_c=this._headerPointerSubs)==null||_c.add(headerPointerLeaveSub)}_initialHoverMenu(){this._hoverMenu!=null&&(this._hoverMenu.onPointerEnter$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:HEADER_MENU_SHAPE_TYPE.HIGHLIGHT,visible:!0}),this._context.scene.setCursor(engineRender.CURSOR_TYPE.POINTER))}),this._hoverMenu.onPointerLeave$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:HEADER_MENU_SHAPE_TYPE.NORMAL,visible:!1}),this._context.scene.resetCursor())}),this._hoverMenu.onPointerDown$.subscribeEvent(evt=>{var _a61;const currentColumn=this._currentColumn,currentSelectionDatas=(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(s=>s.range);if(!!!(currentSelectionDatas!=null&&currentSelectionDatas.filter(range=>range.rangeType===core.RANGE_TYPE.COLUMN).find(data=>{const{startColumn,endColumn}=data;return currentColumn>=startColumn&&currentColumn<=endColumn}))){const selection=this._getSelectionOnColumn(currentColumn);this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,selection)}evt.stopPropagation(),evt.preventDefault(),this._contextMenuService.triggerContextMenu(evt,ui.ContextMenuPosition.COL_HEADER)}))}_getSelectionOnColumn(column){const workbook=this._context.unit,worksheet=workbook.getActiveSheet();if(!worksheet)throw new Error("No active worksheet");return{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),selections:[{range:{startRow:0,startColumn:column,endRow:worksheet.getRowCount()-1,endColumn:column,rangeType:core.RANGE_TYPE.COLUMN},primary:{startRow:0,startColumn:column,endRow:0,endColumn:column,actualRow:0,actualColumn:column,isMerged:!1,isMergedMainCell:!1},style:null}]}}},__name(_a52,"HeaderMenuRenderController"),_a52);HeaderMenuRenderController=__decorateClass$8([__decorateParam$8(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$8(2,ui.IContextMenuService),__decorateParam$8(3,core.ICommandService),__decorateParam$8(4,core.Inject(sheets.SheetsSelectionsService))],HeaderMenuRenderController);var HeaderUnhideShapeType=(HeaderUnhideShapeType2=>(HeaderUnhideShapeType2[HeaderUnhideShapeType2.ROW=0]="ROW",HeaderUnhideShapeType2[HeaderUnhideShapeType2.COLUMN=1]="COLUMN",HeaderUnhideShapeType2))(HeaderUnhideShapeType||{});const UNHIDE_ICON_SIZE=12,UNHIDE_ARROW_RATIO=.4,_HeaderUnhideShape=class _HeaderUnhideShape extends engineRender.Shape{constructor(key,props,onClick){super(key,props);__publicField(this,"_size",UNHIDE_ICON_SIZE);__publicField(this,"_iconRatio",UNHIDE_ARROW_RATIO);__publicField(this,"_hovered",!0);__publicField(this,"_hasPrevious",!0);__publicField(this,"_hasNext",!0);__publicField(this,"_unhideType");props&&this.setShapeProps(props),this.onPointerEnter$.subscribeEvent(()=>this.setShapeProps({hovered:!0})),this.onPointerLeave$.subscribeEvent(()=>this.setShapeProps({hovered:!1})),this.onPointerDown$.subscribeEvent(()=>onClick==null?void 0:onClick())}setShapeProps(props){props.type!==void 0&&(this._unhideType=props.type),props.hovered!==void 0&&(this._hovered=props.hovered),props.hasPrevious!==void 0&&(this._hasPrevious=props.hasPrevious),props.hasNext!==void 0&&(this._hasNext=props.hasNext),this.transformByState({width:this._size*(this._unhideType===1?2:1),height:this._size*(this._unhideType===0?2:1)})}_draw(ctx){this._unhideType===0?this._drawOnRow(ctx):this._drawOnCol(ctx)}_drawOnRow(ctx){this._hovered&&(!this._hasNext||!this._hasPrevious?engineRender.Rect.drawWith(ctx,{width:this._size,height:this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}):engineRender.Rect.drawWith(ctx,{width:this._size,height:2*this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}));const iconSize=this._size*.5*this._iconRatio,sixtyDegree=Math.PI/3,top=iconSize*Math.cos(sixtyDegree),left=iconSize*Math.sin(sixtyDegree);if(this._hasPrevious&&engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:this._size/2,y:this._size/2-left},{x:this._size/2-left,y:this._size/2+top},{x:this._size/2+left,y:this._size/2+top}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL}),this._hasNext){const offset=this._hasPrevious?3:1;engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:this._size/2,y:this._size*offset/2+left},{x:this._size/2-left,y:this._size*offset/2-top},{x:this._size/2+left,y:this._size*offset/2-top}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL})}}_drawOnCol(ctx){this._hovered&&(!this._hasNext||!this._hasPrevious?engineRender.Rect.drawWith(ctx,{width:this._size,height:this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}):engineRender.Rect.drawWith(ctx,{width:2*this._size,height:this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}));const iconSize=this._size*.5*this._iconRatio,sixtyDegree=Math.PI/3,top=iconSize*Math.cos(sixtyDegree),left=iconSize*Math.sin(sixtyDegree);if(this._hasPrevious&&engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:-top+this._size/2,y:this._size/2},{x:this._size/2+left,y:this._size/2-left},{x:this._size/2+left,y:this._size/2+left}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL}),this._hasNext){const offset=this._hasPrevious?3:1;engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:top+this._size*offset/2,y:this._size/2},{x:-left+this._size*offset/2,y:this._size/2-left},{x:-left+this._size*offset/2,y:this._size/2+left}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL})}}};__name(_HeaderUnhideShape,"HeaderUnhideShape");let HeaderUnhideShape=_HeaderUnhideShape;var __defProp$7=Object.defineProperty,__getOwnPropDesc$7=Object.getOwnPropertyDescriptor,__decorateClass$7=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$7(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$7(target,key,result),result},"__decorateClass$7"),__decorateParam$7=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$7");const HEADER_UNHIDE_CONTROLLER_SHAPE="__SpreadsheetHeaderUnhideSHAPEControllerShape__";sheets.InsertColMutation.id,sheets.InsertRowMutation.id,sheets.RemoveColMutation.id,sheets.RemoveRowMutation.id,sheets.MoveColsMutation.id,sheets.MoveRowsMutation.id,sheets.SetWorksheetColWidthMutation.id,sheets.SetWorksheetRowIsAutoHeightMutation.id,sheets.SetRowHiddenMutation.id,sheets.SetRowVisibleMutation.id,sheets.SetColHiddenMutation.id,sheets.SetColVisibleMutation.id;var _a53;let HeaderUnhideRenderController=(_a53=class extends core.RxDisposable{constructor(_context,_sheetSkeletonManagerService,_commandService){super();__publicField(this,"_shapes",{cols:[],rows:[]});this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._init()}get _workbook(){return this._context.unit}dispose(){super.dispose(),this._clearShapes()}_init(){let activeSheetId="";this._context.unit.activeSheet$.pipe(rxjs.takeUntil(this.dispose$)).subscribe(worksheet=>{if(this._clearShapes(),!worksheet){activeSheetId="";return}activeSheetId=worksheet.getSheetId(),this._update(this._workbook,worksheet)}),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{if(param){const{unitId,sheetId}=param;if(unitId===this._workbook.getUnitId()&&sheetId===activeSheetId){const worksheet=this._workbook.getSheetBySheetId(sheetId);worksheet&&this._update(this._workbook,worksheet)}}}))}_update(workbook,worksheet){var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getWorksheetSkeleton(worksheet.getSheetId()))==null?void 0:_a61.skeleton;if(!skeleton)return;const hiddenRowRanges=worksheet.getHiddenRows(),hiddenColRanges=worksheet.getHiddenCols(),sheetObject=this._getSheetObject(),{scene}=sheetObject,rowCount=worksheet.getRowCount(),rowShapes=hiddenRowRanges.map(range=>{const{startRow,endRow}=range,position=getCoordByCell(startRow,0,scene,skeleton),hasPrevious=startRow!==0,hasNext=endRow!==rowCount-1;return new HeaderUnhideShape(HEADER_UNHIDE_CONTROLLER_SHAPE,{type:HeaderUnhideShapeType.ROW,hovered:!1,hasPrevious,hasNext,top:position.startY-(hasPrevious?UNHIDE_ICON_SIZE:0),left:position.startX-UNHIDE_ICON_SIZE},()=>this._commandService.executeCommand(sheets.SetSpecificRowsVisibleCommand.id,{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),ranges:[range]}))}),colCount=worksheet.getColumnCount(),colShapes=hiddenColRanges.map(range=>{const{startColumn,endColumn}=range,position=getCoordByCell(0,startColumn,scene,skeleton),hasPrevious=startColumn!==0,hasNext=endColumn!==colCount-1;return new HeaderUnhideShape(HEADER_UNHIDE_CONTROLLER_SHAPE,{type:HeaderUnhideShapeType.COLUMN,hovered:!1,hasPrevious,hasNext,top:20-UNHIDE_ICON_SIZE,left:position.startX-(hasPrevious?UNHIDE_ICON_SIZE:0)},()=>this._commandService.executeCommand(sheets.SetSpecificColsVisibleCommand.id,{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),ranges:[range]}))});scene.addObjects(colShapes,SHEET_COMPONENT_UNHIDE_LAYER_INDEX),scene.addObjects(rowShapes,SHEET_COMPONENT_UNHIDE_LAYER_INDEX),this._clearShapes(),this._shapes={cols:colShapes,rows:rowShapes}}_clearShapes(){this._shapes.cols.forEach(shape=>shape.dispose()),this._shapes.rows.forEach(shape=>shape.dispose()),this._shapes={cols:[],rows:[]}}_getSheetObject(){return getSheetObject(this._workbook,this._context)}},__name(_a53,"HeaderUnhideRenderController"),_a53);HeaderUnhideRenderController=__decorateClass$7([__decorateParam$7(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$7(2,core.ICommandService)],HeaderUnhideRenderController);var __defProp$6=Object.defineProperty,__getOwnPropDesc$6=Object.getOwnPropertyDescriptor,__decorateClass$6=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$6(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$6(target,key,result),result},"__decorateClass$6"),__decorateParam$6=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$6");const FRAME_STACK_THRESHOLD=60;var _a54;exports.SheetRenderController=(_a54=class extends core.RxDisposable{constructor(_context,_contextService,_sheetSkeletonManagerService,_sheetRenderService,_commandService,_telemetryService){super();__publicField(this,"_renderFrameTimeMetric",null);__publicField(this,"_renderFrameTags",{});__publicField(this,"_afterRenderMetric$",new rxjs.Subject);this._context=_context,this._contextService=_contextService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._sheetRenderService=_sheetRenderService,this._commandService=_commandService,this._telemetryService=_telemetryService,this._addNewRender(),this._initRenderMetricSubscriber()}_addNewRender(){const{scene,engine,unit:workbook}=this._context;this._addComponent(workbook),this._initRerenderScheduler(),this._initCommandListener();const worksheet=this._context.unit.getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const sheetId=worksheet.getSheetId();this._sheetSkeletonManagerService.setCurrent({sheetId}),engine.runRenderLoop(()=>scene.render())}_initRenderMetricSubscriber(){if(!this._telemetryService)return;const{engine}=this._context;engine.beginFrame$.subscribe(()=>{this._renderFrameTimeMetric=null,this._renderFrameTags={}}),engine.endFrame$.subscribe(()=>{this._renderFrameTimeMetric&&Object.keys(this._renderFrameTimeMetric).filter(key=>key.startsWith(engineRender.SHEET_EXTENSION_PREFIX)).length>0&&this._afterRenderMetric$.next({frameTimeMetric:this._renderFrameTimeMetric,tags:this._renderFrameTags})}),engine.renderFrameTimeMetric$.subscribe(([key,value])=>{this._renderFrameTimeMetric||(this._renderFrameTimeMetric={}),this._renderFrameTimeMetric[key]||(this._renderFrameTimeMetric[key]=[]),value=Math.round(value*100)/100,this._renderFrameTimeMetric[key].push(value)}),engine.renderFrameTags$.subscribe(([key,value])=>{this._renderFrameTags[key]=value});const frameInfoList=[];this._afterRenderMetric$.pipe(rxjs.withLatestFrom(engine.endFrame$)).subscribe(([sceneRenderDetail,basicFrameTimeInfo])=>{frameInfoList.push({FPS:basicFrameTimeInfo.FPS,elapsedTime:basicFrameTimeInfo.elapsedTime,frameTime:Math.round(basicFrameTimeInfo.frameTime*100)/100,...sceneRenderDetail.frameTimeMetric,...sceneRenderDetail.tags}),frameInfoList.length>FRAME_STACK_THRESHOLD&&(this._renderMetricCapture(frameInfoList),frameInfoList.length=0)})}_renderMetricCapture(frameInfoList){const filteredFrameInfo=frameInfoList;if(filteredFrameInfo.length===0)return;const sumValueForNumListFields=__name(data=>{let totalSum=0;const sums=Object.entries(data).filter(([_,value])=>Array.isArray(value)).map(([key])=>key).reduce((acc,key)=>{const keySum=data[key].reduce((sum,num)=>sum+num,0);return acc[key]=keySum,acc},{});return Object.keys(data).filter(key=>key.startsWith(engineRender.SHEET_EXTENSION_PREFIX)).forEach(key=>{totalSum+=sums[key]}),{...sums,extensionTotal:totalSum}},"sumValueForNumListFields"),frameTimeListAfterSum=frameInfoList.map(info=>({...info,...sumValueForNumListFields(info)})),summaryFrameStats=__name(list=>Object.entries(list[0]).filter(([key,_])=>!["elapsedTime"].includes(key)).filter(([_,value])=>typeof value=="number").map(([key])=>key).reduce((acc,key)=>{const values=list.map(obj=>obj[key]),max=Math.max(...values),min=Math.min(...values),avg=values.reduce((sum,val)=>sum+val,0)/values.length;return acc[key]={max:Math.round(max*100)/100,min:Math.round(min*100)/100,avg:Math.round(avg*100)/100},acc},{}),"getSummaryStats")(frameTimeListAfterSum),elapsedTimeToStart=filteredFrameInfo[filteredFrameInfo.length-1].elapsedTime,sheetId=this._context.unit.getActiveSheet().getSheetId(),unitId=this._context.unit.getUnitId(),telemetryData={sheetId,unitId,elapsedTimeToStart,...summaryFrameStats};this._telemetryService.capture("sheet_render_cost",telemetryData)}_addComponent(workbook){const{scene,components}=this._context,worksheet=workbook.getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const spreadsheet=new engineRender.Spreadsheet(SHEET_VIEW_KEY.MAIN);this._addViewport(worksheet);const spreadsheetRowHeader=new engineRender.SpreadsheetRowHeader(SHEET_VIEW_KEY.ROW),spreadsheetColumnHeader=new engineRender.SpreadsheetColumnHeader(SHEET_VIEW_KEY.COLUMN),SpreadsheetLeftTopPlaceholder=new engineRender.Rect(SHEET_VIEW_KEY.LEFT_TOP,{zIndex:2,left:-1,top:-1,fill:"rgb(248, 249, 250)",stroke:"rgb(217, 217, 217)",strokeWidth:1});this._context.mainComponent=spreadsheet,components.set(SHEET_VIEW_KEY.MAIN,spreadsheet),components.set(SHEET_VIEW_KEY.ROW,spreadsheetRowHeader),components.set(SHEET_VIEW_KEY.COLUMN,spreadsheetColumnHeader),components.set(SHEET_VIEW_KEY.LEFT_TOP,SpreadsheetLeftTopPlaceholder),scene.addObjects([spreadsheet],SHEET_COMPONENT_MAIN_LAYER_INDEX),scene.addObjects([spreadsheetRowHeader,spreadsheetColumnHeader,SpreadsheetLeftTopPlaceholder],SHEET_COMPONENT_HEADER_LAYER_INDEX),scene.enableLayerCache(SHEET_COMPONENT_MAIN_LAYER_INDEX,SHEET_COMPONENT_HEADER_LAYER_INDEX)}_initViewports(scene,rowHeader,columnHeader){const viewMain=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN,scene,{left:rowHeader.width,top:columnHeader.height,bottom:0,right:0,isWheelPreventDefaultX:!0,allowCache:!0,bufferEdgeX:100,bufferEdgeY:100}),viewMainLeftTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP,scene,{isWheelPreventDefaultX:!0,active:!1,allowCache:!0,bufferEdgeX:0,bufferEdgeY:0}),viewMainLeft=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT,scene,{isWheelPreventDefaultX:!0,active:!1,allowCache:!0,bufferEdgeX:0,bufferEdgeY:100}),viewMainTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP,scene,{isWheelPreventDefaultX:!0,active:!1,allowCache:!0,bufferEdgeX:100,bufferEdgeY:0}),viewRowTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP,scene,{active:!1,isWheelPreventDefaultX:!0}),viewRowBottom=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM,scene,{left:0,top:columnHeader.height,bottom:0,width:rowHeader.width,isWheelPreventDefaultX:!0}),viewColumnLeft=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT,scene,{active:!1,isWheelPreventDefaultX:!0}),viewColumnRight=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT,scene,{left:rowHeader.width,top:0,height:columnHeader.height,right:0,isWheelPreventDefaultX:!0}),viewLeftTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP,scene,{left:0,top:0,width:rowHeader.width,height:columnHeader.height,isWheelPreventDefaultX:!0});return{viewMain,viewLeftTop,viewMainLeftTop,viewMainLeft,viewMainTop,viewColumnLeft,viewRowTop,viewRowBottom,viewColumnRight}}_addViewport(worksheet){const scene=this._context.scene;if(scene==null)return;const{rowHeader,columnHeader}=worksheet.getConfig(),{viewMain}=this._initViewports(scene,rowHeader,columnHeader);return new engineRender.ScrollBar(viewMain),scene.attachControl(),viewMain}_initRerenderScheduler(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{if(!param)return null;const{skeleton:spreadsheetSkeleton,sheetId}=param,workbook=this._context.unit,worksheet=workbook==null?void 0:workbook.getSheetBySheetId(sheetId);if(workbook==null||worksheet==null)return;const{mainComponent,components}=this._context,spreadsheet=mainComponent,spreadsheetRowHeader=components.get(SHEET_VIEW_KEY.ROW),spreadsheetColumnHeader=components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetLeftTopPlaceholder=components.get(SHEET_VIEW_KEY.LEFT_TOP),{rowHeaderWidth,columnHeaderHeight}=spreadsheetSkeleton;spreadsheet==null||spreadsheet.updateSkeleton(spreadsheetSkeleton),spreadsheetRowHeader==null||spreadsheetRowHeader.updateSkeleton(spreadsheetSkeleton),spreadsheetColumnHeader==null||spreadsheetColumnHeader.updateSkeleton(spreadsheetSkeleton),spreadsheetLeftTopPlaceholder==null||spreadsheetLeftTopPlaceholder.transformByState({width:rowHeaderWidth,height:columnHeaderHeight})}))}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{const{unit:workbook,unitId:workbookId}=this._context,{id:commandId}=command;if(sheets.COMMAND_LISTENER_SKELETON_CHANGE.includes(commandId)||this._sheetRenderService.checkMutationShouldTriggerRerender(commandId)){const worksheet=workbook.getActiveSheet();if(!worksheet)return;const workbookId2=this._context.unitId,worksheetId=worksheet.getSheetId(),params=command.params,{unitId,subUnitId}=params;if(unitId!==workbookId2||subUnitId!==worksheetId)return;commandId!==sheets.SetWorksheetActiveOperation.id&&this._sheetSkeletonManagerService.makeDirty({sheetId:worksheetId,commandId},!0),this._sheetSkeletonManagerService.setCurrent({sheetId:worksheetId,commandId})}else sheets.COMMAND_LISTENER_VALUE_CHANGE.includes(commandId)&&this._sheetSkeletonManagerService.reCalculate();command.type===core.CommandType.MUTATION&&this._markUnitDirty(workbookId,command)}))}_markUnitDirty(unitId,command){const{mainComponent:spreadsheet,scene}=this._context;if(spreadsheet&&spreadsheet.makeDirty(),scene.makeDirty(),!command.params)return;const cmdParams=command.params,viewports=this._spreadsheetViewports(scene);if(command.id===sheets.SetRangeValuesMutation.id&&cmdParams.cellValue){const dirtyRange=this._cellValueToRange(cmdParams.cellValue),dirtyBounds=this._rangeToBounds([dirtyRange]);this._markViewportDirty(viewports,dirtyBounds),spreadsheet.setDirtyArea(dirtyBounds)}if(command.id===sheets.MoveRangeMutation.id&&cmdParams.from&&cmdParams.to){const fromRange=cmdParams.fromRange||this._cellValueToRange(cmdParams.from.value),toRange=cmdParams.toRange||this._cellValueToRange(cmdParams.to.value),dirtyBounds=this._rangeToBounds([fromRange,toRange]);this._markViewportDirty(viewports,dirtyBounds),spreadsheet.setDirtyArea(dirtyBounds)}}_cellValueToRange(cellValue){let minCol=0,maxCol=0,minRow=0,maxRow=0;for(const[_row,columnObj]of Object.entries(cellValue)){for(const column in columnObj)minCol>Number(column)&&(minCol=Number(column)),maxCol<Number(column)&&(maxCol=Number(column));minRow>Number(_row)&&(minRow=Number(_row)),maxRow<Number(_row)&&(maxRow=Number(_row))}return{startRow:minRow,endRow:maxRow,startColumn:minCol,endColumn:maxCol}}_rangeToBounds(ranges){const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{rowHeightAccumulation,columnWidthAccumulation,rowHeaderWidth,columnHeaderHeight}=skeleton,dirtyBounds=[];for(const r2 of ranges){const{startRow,endRow,startColumn,endColumn}=r2,top=startRow===0?0:rowHeightAccumulation[startRow-1]+columnHeaderHeight,bottom=rowHeightAccumulation[endRow]+columnHeaderHeight,left=startColumn===0?0:columnWidthAccumulation[startColumn-1]+rowHeaderWidth,right=columnWidthAccumulation[endColumn]+rowHeaderWidth;dirtyBounds.push({top,left,bottom,right,width:right-left,height:bottom-top})}return dirtyBounds}_markViewportDirty(viewports,dirtyBounds){const activeViewports=viewports.filter(vp=>vp.isActive&&vp.cacheBound);for(const vp of activeViewports)for(const b of dirtyBounds)core.Rectangle.hasIntersectionBetweenTwoRect(vp.cacheBound,b)&&vp.markDirty(!0)}_spreadsheetViewports(scene){return scene.getViewports().filter(v=>["viewMain","viewMainLeftTop","viewMainTop","viewMainLeft"].includes(v.viewportKey))}},__name(_a54,"SheetRenderController"),_a54);exports.SheetRenderController=__decorateClass$6([__decorateParam$6(1,core.IContextService),__decorateParam$6(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$6(3,core.Inject(exports.SheetsRenderService)),__decorateParam$6(4,core.ICommandService),__decorateParam$6(5,core.Optional(telemetry.ITelemetryService))],exports.SheetRenderController);const PRINTING_RANGE=core.createInterceptorKey("PRINTING_RANGE"),PRINTING_COMPONENT_COLLECT=core.createInterceptorKey("PRINTING_COMPONENT_COLLECT"),_SheetPrintInterceptorService=class _SheetPrintInterceptorService extends core.Disposable{constructor(){super();__publicField(this,"interceptor",new core.InterceptorManager({PRINTING_RANGE,PRINTING_COMPONENT_COLLECT}));this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_RANGE,{priority:-1,handler:__name(_value=>_value,"handler")})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_COMPONENT_COLLECT,{priority:-1,handler:__name(_value=>_value,"handler")}))}};__name(_SheetPrintInterceptorService,"SheetPrintInterceptorService");let SheetPrintInterceptorService=_SheetPrintInterceptorService;var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__defNormalProp$1=__name((obj,key,value)=>key in obj?__defProp$5(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp$1"),__decorateClass$5=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$5(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$5(target,key,result),result},"__decorateClass$5"),__decorateParam$5=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$5"),__publicField$1=__name((obj,key,value)=>__defNormalProp$1(obj,typeof key!="symbol"?key+"":key,value),"__publicField$1"),_a55;exports.UniverSheetsUIPlugin=(_a55=class extends core.Plugin{constructor(_config=defaultPluginConfig,_injector,_renderManagerService,_configService,_univerInstanceService){super(),this._config=_config,this._injector=_injector,this._renderManagerService=_renderManagerService,this._configService=_configService,this._univerInstanceService=_univerInstanceService;const{menu,...rest}=this._config;menu&&this._configService.setConfig("menu",menu,{merge:!0}),this._configService.setConfig(PLUGIN_CONFIG_KEY,rest)}onStarting(){core.registerDependencies(this._injector,core.mergeOverrideWithDependencies([[ShortcutExperienceService],[IEditorBridgeService,{useClass:exports.EditorBridgeService}],[ISheetClipboardService,{useClass:exports.SheetClipboardService}],[ISheetBarService,{useClass:SheetBarService}],[IFormatPainterService,{useClass:FormatPainterService}],[ICellEditorManagerService,{useClass:CellEditorManagerService}],[IFormulaEditorManagerService,{useClass:FormulaEditorManagerService}],[sheets.IRefSelectionsService,{useClass:sheets.RefSelectionsService}],[IAutoFillService,{useClass:exports.AutoFillService}],[SheetPrintInterceptorService],[IStatusBarService,{useClass:StatusBarService}],[IMarkSelectionService,{useClass:exports.MarkSelectionService}],[exports.HoverManagerService],[exports.DragManagerService],[exports.SheetCanvasPopManagerService],[exports.CellAlertManagerService],[SelectAllService],[ActiveWorksheetController],[exports.AutoHeightController],[exports.FormulaEditorController],[SheetClipboardController],[exports.SheetsRenderService],[exports.SheetUIController],[exports.StatusBarController],[exports.AutoFillController],[FormatPainterController],[SheetsDefinedNameController],[EditorDataSyncController],[SheetCheckboxController],[SheetPermissionPanelModel],[SheetPermissionUserManagerService],[SheetPermissionInterceptorClipboardController],[exports.SheetPermissionInterceptorBaseController],[exports.SheetPermissionInitController],[SheetPermissionRenderManagerController]],this._config.override)),core.touchDependencies(this._injector,[[SheetPermissionPanelModel]])}onReady(){this._config.disableAutoFocus||this._initAutoFocus(),this._registerRenderBasics(),core.touchDependencies(this._injector,[[exports.SheetUIController],[exports.SheetsRenderService],[ActiveWorksheetController],[exports.SheetPermissionInterceptorBaseController]])}onRendered(){this._registerRenderModules(),core.touchDependencies(this._injector,[[exports.SheetPermissionInitController],[SheetPermissionRenderManagerController],[SheetClipboardController],[exports.FormulaEditorController],[SheetsDefinedNameController],[exports.StatusBarController],[exports.AutoHeightController],[EditorDataSyncController],[SheetCheckboxController]])}onSteady(){core.touchDependencies(this._injector,[[FormatPainterController],[exports.AutoFillController],[SheetPermissionInterceptorClipboardController]])}_registerRenderBasics(){[[exports.SheetSkeletonManagerService],[exports.SheetRenderController],[ISheetSelectionRenderService,{useClass:exports.SheetSelectionRenderService}]].forEach(m2=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,m2))})}_registerRenderModules(){var _a61;const modules=[[exports.HeaderMoveRenderController],[HeaderUnhideRenderController],[exports.HeaderResizeRenderController],[SheetScrollManagerService],[exports.SheetsScrollRenderController],[exports.HeaderFreezeRenderController],[SheetsZoomRenderController],[SheetCellEditorResizeService],[FormatPainterRenderController],[CellAlertRenderController],[ForceStringAlertRenderController],[MarkSelectionRenderController],[exports.HoverRenderController],[exports.DragRenderController],[ForceStringRenderController],[exports.CellCustomRenderController],[SheetContextMenuRenderController],[MoveRangeRenderController],[EditorBridgeRenderController],[exports.EditingRenderController],[SheetPermissionInterceptorCanvasRenderController],[SheetPermissionInterceptorFormulaRenderController],[SheetPermissionRenderController],[WorksheetProtectionRenderController]],config=this._configService.getConfig(ui.PLUGIN_CONFIG_KEY);((_a61=config==null?void 0:config.contextMenu)!=null?_a61:!0)&&modules.push([HeaderMenuRenderController]),modules.forEach(m2=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,m2))})}_initAutoFocus(){const univerInstanceService=this._univerInstanceService;this.disposeWithMe(univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.filter(v=>!!v)).subscribe(workbook=>univerInstanceService.focusUnit(workbook.getUnitId())))}},__name(_a55,"UniverSheetsUIPlugin"),_a55);__publicField$1(exports.UniverSheetsUIPlugin,"pluginName","SHEET_UI_PLUGIN");__publicField$1(exports.UniverSheetsUIPlugin,"type",core.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsUIPlugin=__decorateClass$5([core.DependentOn(sheets.UniverSheetsPlugin),__decorateParam$5(1,core.Inject(core.Injector)),__decorateParam$5(2,engineRender.IRenderManagerService),__decorateParam$5(3,core.IConfigService),__decorateParam$5(4,core.IUniverInstanceService)],exports.UniverSheetsUIPlugin);var __defProp$4=Object.defineProperty,__getOwnPropDesc$4=Object.getOwnPropertyDescriptor,__decorateClass$4=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$4(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$4(target,key,result),result},"__decorateClass$4"),__decorateParam$4=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$4");const SHEET_NAVIGATION_COMMANDS=[MoveSelectionCommand.id,MoveSelectionEnterAndTabCommand.id];var _a56;let MobileSheetsScrollRenderController=(_a56=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService,_renderManagerService,_selectionManagerService,_scrollManagerService,_univerInstanceService){super(),this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._renderManagerService=_renderManagerService,this._selectionManagerService=_selectionManagerService,this._scrollManagerService=_scrollManagerService,this._univerInstanceService=_univerInstanceService,this._init()}scrollToRange(range){let{endRow,endColumn,startColumn,startRow}=range;const bounding=this._getViewportBounding();if(range.rangeType===core.RANGE_TYPE.ROW?(startColumn=0,endColumn=0):range.rangeType===core.RANGE_TYPE.COLUMN&&(startRow=0,endRow=0),bounding){const row=bounding.startRow>endRow?startRow:endRow,col=bounding.startColumn>endColumn?startColumn:endColumn;return this._scrollToCell(row,col)}else return this._scrollToCell(startRow,startColumn)}_init(){this._initCommandListener(),this._initScrollEventListener(),this._initPointerScrollEvent(),this._initSkeletonListener()}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(SHEET_NAVIGATION_COMMANDS.includes(command.id))this._scrollToSelection();else if(command.id===sheets.ScrollToCellOperation.id){const param=command.params;this.scrollToRange(param)}else if(command.id===ExpandSelectionCommand.id){const param=command.params;this._scrollToSelectionForExpand(param)}}))}_scrollToSelectionForExpand(param){setTimeout(()=>{const selection=this._selectionManagerService.getCurrentLastSelection();if(selection==null)return;const{startRow,startColumn,endRow,endColumn}=selection.range,bounds=this._getViewportBounding();if(bounds==null)return;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;startRow>viewportStartRow?row=endRow:endRow<viewportEndRow?row=startRow:row=viewportStartRow,startColumn>viewportStartColumn?column=endColumn:endColumn<viewportEndColumn?column=startColumn:column=viewportStartColumn,param.direction===core.Direction.DOWN?row=endRow:param.direction===core.Direction.UP?row=startRow:param.direction===core.Direction.RIGHT?column=endColumn:param.direction===core.Direction.LEFT&&(column=startColumn),this._scrollToCell(row,column)},0)}_getFreeze(){var _a61;const snapshot=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton.getWorksheetConfig();if(snapshot!=null)return snapshot.freeze}_initScrollEventListener(){const{scene}=this._context;if(scene==null)return;const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);viewportMain&&(this.disposeWithMe(core.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(rawScrollInfo=>{var _a61;if(rawScrollInfo==null){viewportMain.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(!skeleton)return;const{sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY}=rawScrollInfo,{startX,startY}=skeleton.getCellByIndexWithNoHeader(sheetViewStartRow,sheetViewStartColumn),viewportScrollX=startX+offsetX,viewportScrollY=startY+offsetY;viewportMain.scrollToViewportPos({viewportScrollX,viewportScrollY})}))),this.disposeWithMe(viewportMain.onScrollAfter$.subscribeEvent(scrollAfterParam=>{var _a61;if(!scrollAfterParam)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX,viewportScrollY,scrollX,scrollY}=scrollAfterParam,{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY),scrollInfo={sheetViewStartRow:row,sheetViewStartColumn:column,offsetX:columnOffset,offsetY:rowOffset};this._scrollManagerService.setScrollStateToCurrSheet(scrollInfo),this._scrollManagerService.validViewportScrollInfo$.next({...scrollInfo,scrollX,scrollY,viewportScrollX,viewportScrollY})})),this.disposeWithMe(viewportMain.onScrollByBar$.subscribeEvent(param=>{var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null||param.isTrigger===!1)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX=0,viewportScrollY=0}=param,freeze=this._getFreeze(),{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY);this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartRow:row+((freeze==null?void 0:freeze.ySplit)||0),sheetViewStartColumn:column+((freeze==null?void 0:freeze.xSplit)||0),offsetX:columnOffset,offsetY:rowOffset})})))}_initSkeletonListener(){this.disposeWithMe(core.toDisposable(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(param=>{if(param==null)return;const scrollParam={unitId:param.unitId,sheetId:param.sheetId};this._scrollManagerService.setSearchParam(scrollParam);const sheetObject=this._getSheetObject();if(!sheetObject)return;const viewportMain=sheetObject.scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),currScrollInfo=this._scrollManagerService.getScrollStateByParam(scrollParam),{viewportScrollX,viewportScrollY}=this._scrollManagerService.calcViewportScrollFromRowColOffset(currScrollInfo);viewportMain&&(currScrollInfo?(viewportMain.viewportScrollX=viewportScrollX,viewportMain.viewportScrollY=viewportScrollY):(viewportMain.viewportScrollX=0,viewportMain.viewportScrollY=0),this._updateSceneSize(param))})))}_initPointerScrollEvent(){const sheetObject=this._getSheetObject();if(!sheetObject)return;const scrollManagerService=this._scrollManagerService,scene=sheetObject.scene,spreadsheet=sheetObject.spreadsheet,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),lastPointerPos={x:0,y:0};let _pointerScrolling=!1;const velocity={x:0,y:0},deceleration=.95;let scrollInertiaAnimationID=null;const pointerScrollInertia=__name(()=>{if(!viewportMain)return;velocity.x*=deceleration,velocity.y*=deceleration,lastPointerPos.x+=velocity.x,lastPointerPos.y+=velocity.y;const offsetX=velocity.x,offsetY=velocity.y;(offsetY!==0||offsetX!==0)&&this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetY,offsetX}),Math.abs(velocity.x)>1||Math.abs(velocity.y)>1?scrollInertiaAnimationID=requestAnimationFrame(pointerScrollInertia):scrollInertiaAnimationID=null},"pointerScrollInertia"),cancelInertiaAnimation=__name(()=>{cancelAnimationFrame(scrollInertiaAnimationID),scrollInertiaAnimationID=null},"cancelInertiaAnimation");spreadsheet.onPointerDown$.subscribeEvent((evt,state)=>{cancelInertiaAnimation(),viewportMain&&(lastPointerPos.x=evt.offsetX,lastPointerPos.y=evt.offsetY,_pointerScrolling=!0,state.stopPropagation())}),spreadsheet.onPointerMove$.subscribeEvent((evt,state)=>{if(!_pointerScrolling||!viewportMain)return;const e=evt,deltaX=-(e.offsetX-lastPointerPos.x),deltaY=-(e.offsetY-lastPointerPos.y);velocity.x=-(e.offsetX-lastPointerPos.x),velocity.y=-(e.offsetY-lastPointerPos.y);const offsetX=deltaX,offsetY=deltaY;(deltaX!==0||deltaY!==0)&&(offsetY!==0||offsetX!==0)&&this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetY,offsetX}),scrollManagerService.getCurrentScrollState(),lastPointerPos.x=e.offsetX,lastPointerPos.y=e.offsetY,state.stopPropagation()}),spreadsheet.onPointerUp$.subscribeEvent(_evt=>{_pointerScrolling=!1,scrollInertiaAnimationID=requestAnimationFrame(pointerScrollInertia)}),spreadsheet.onPointerLeave$.subscribeEvent(()=>{_pointerScrolling=!1}),spreadsheet.onPointerOut$.subscribeEvent(()=>{_pointerScrolling=!1}),scene.onPointerOut$.subscribeEvent(()=>{_pointerScrolling=!1}),scene.onPointerCancel$.subscribeEvent(()=>{_pointerScrolling=!1})}_updateSceneSize(param){var _a61;if(param==null)return;const{unitId}=this._context,{skeleton}=param,scene=(_a61=this._renderManagerService.getRenderById(unitId))==null?void 0:_a61.scene;if(skeleton==null||scene==null)return;const{rowTotalHeight,columnTotalWidth,rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const zoomRatio=worksheet.getZoomRatio()||1;scene==null||scene.setScaleValue(zoomRatio,zoomRatio),scene==null||scene.transformByState({width:rowHeaderWidthAndMarginLeft+columnTotalWidth,height:columnHeaderHeightAndMarginTop+rowTotalHeight})}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_scrollToSelectionByDirection(range){const bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;const{startRow,startColumn,endRow,endColumn}=range;startRow>=viewportStartRow&&(row=endRow),endRow<=viewportEndRow&&(row=startRow),startColumn>=viewportStartColumn&&(column=endColumn),endColumn<=viewportEndColumn&&(column=startColumn),this._scrollToCell(row,column)}_scrollToSelection(targetIsActualRowAndColumn=!0){const selection=this._selectionManagerService.getCurrentLastSelection();if(selection==null)return;const{startRow,startColumn,actualRow,actualColumn}=selection.primary,selectionStartRow=targetIsActualRowAndColumn?actualRow:startRow,selectionStartColumn=targetIsActualRowAndColumn?actualColumn:startColumn;this._scrollToCell(selectionStartRow,selectionStartColumn)}_getViewportBounding(){var _a61,_b;const scene=(_a61=this._getSheetObject())==null?void 0:_a61.scene;if(scene==null)return;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null)return;const skeleton=(_b=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_b.skeleton;if(skeleton==null)return;const bounds=viewport.getBounding();return skeleton.getRowColumnSegment(bounds)}_scrollToCell(row,column){var _a61,_b,_c,_d;const{rowHeightAccumulation,columnWidthAccumulation}=(_b=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton)!=null?_b:{};if(rowHeightAccumulation==null||columnWidthAccumulation==null)return!1;const scene=(_c=this._getSheetObject())==null?void 0:_c.scene;if(scene==null)return!1;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null||((_d=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_d.skeleton)==null)return!1;const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return!1;const{startColumn:freezeStartColumn,startRow:freezeStartRow,ySplit:freezeYSplit,xSplit:freezeXSplit}=worksheet.getFreeze(),bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let startSheetViewRow,startSheetViewColumn;if(row>=freezeStartRow&&column>=freezeStartColumn-freezeXSplit&&(row<=viewportStartRow&&(startSheetViewRow=row),row>=viewportEndRow)){const minRowAccumulation=rowHeightAccumulation[row]-viewport.height;for(let r2=viewportStartRow;r2<=row;r2++)if(rowHeightAccumulation[r2]>=minRowAccumulation){startSheetViewRow=r2+1;break}}if(column>=freezeStartColumn&&row>=freezeStartRow-freezeYSplit&&(column<=viewportStartColumn&&(startSheetViewColumn=column),column>=viewportEndColumn)){const minColumnAccumulation=columnWidthAccumulation[column]-viewport.width;for(let c=viewportStartColumn;c<=column;c++)if(columnWidthAccumulation[c]>=minColumnAccumulation){startSheetViewColumn=c+1;break}}if(startSheetViewRow===void 0&&startSheetViewColumn===void 0)return!1;const{offsetX,offsetY}=this._scrollManagerService.getCurrentScrollState()||{};return this._commandService.syncExecuteCommand(ScrollCommand.id,{sheetViewStartRow:startSheetViewRow,sheetViewStartColumn:startSheetViewColumn,offsetX:startSheetViewColumn===void 0?offsetX:0,offsetY:startSheetViewRow===void 0?offsetY:0})}},__name(_a56,"MobileSheetsScrollRenderController"),_a56);MobileSheetsScrollRenderController=__decorateClass$4([__decorateParam$4(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$4(2,core.ICommandService),__decorateParam$4(3,engineRender.IRenderManagerService),__decorateParam$4(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$4(5,core.Inject(SheetScrollManagerService)),__decorateParam$4(6,core.IUniverInstanceService)],MobileSheetsScrollRenderController);const mobileSheetBarContainer="univer-mobile-sheet-bar-container",mobileSheetBarSlider="univer-mobile-sheet-bar-slider",mobileSheetBarItem="univer-mobile-sheet-bar-item",mobileSheetBarItemActivated="univer-mobile-sheet-bar-item-activated",styles={mobileSheetBarContainer,mobileSheetBarSlider,mobileSheetBarItem,mobileSheetBarItemActivated};function MobileSheetBar(){const workbook=useActiveWorkbook();return workbook?jsxRuntimeExports.jsx(MobileSheetBarImpl,{workbook}):null}__name(MobileSheetBar,"MobileSheetBar");function MobileSheetBarImpl(props){const{workbook}=props,[sheetList,setSheetList]=React.useState([]),[activeKey,setActiveKey]=React.useState(""),tabMapRef=React.useRef(new Map),commandService=core.useDependency(core.ICommandService),updateSheetItems=React.useCallback(()=>{const currentSubUnitId=workbook.getActiveSheet().getSheetId(),sheets2=workbook.getSheets(),activeSheet=workbook.getActiveSheet(),sheetListItems=sheets2.filter(sheet=>!sheet.isSheetHidden()).map((sheet,index)=>{var _a61;return{sheetId:sheet.getSheetId(),label:sheet.getName(),index,selected:activeSheet===sheet,color:(_a61=sheet.getTabColor())!=null?_a61:void 0}});if(setSheetList(sheetListItems),setActiveKey(currentSubUnitId),tabMapRef.current.has(currentSubUnitId)){const element2=tabMapRef.current.get(currentSubUnitId);element2&&element2.scrollIntoView({behavior:"smooth",block:"nearest"})}tabMapRef.current.clear()},[workbook]);React.useEffect(()=>updateSheetItems(),[updateSheetItems]);const onTabClick=React.useCallback(sheetId=>{commandService.executeCommand(sheets.SetWorksheetActiveOperation.id,{unitId:workbook.getUnitId(),subUnitId:sheetId})},[commandService,workbook]);return React.useEffect(()=>{const disposable=commandService.onCommandExecuted(commandInfo=>{switch(commandInfo.id){case sheets.SetWorksheetHideMutation.id:case sheets.RemoveSheetMutation.id:case sheets.SetWorksheetNameMutation.id:case sheets.InsertSheetMutation.id:case sheets.SetWorksheetOrderMutation.id:case sheets.SetWorksheetActiveOperation.id:updateSheetItems();break}});return()=>disposable.dispose()},[commandService,updateSheetItems]),jsxRuntimeExports.jsx("div",{className:styles.mobileSheetBarContainer,children:jsxRuntimeExports.jsx("div",{className:styles.mobileSheetBarSlider,children:sheetList.map(sheet=>jsxRuntimeExports.jsx("div",{className:clsx(styles.mobileSheetBarItem,{[styles.mobileSheetBarItemActivated]:sheet.sheetId===activeKey}),onClick:__name(()=>onTabClick(sheet.sheetId),"onClick"),ref:__name(element2=>tabMapRef.current.set(sheet.sheetId,element2),"ref"),children:sheet.label},sheet.sheetId))})})}__name(MobileSheetBarImpl,"MobileSheetBarImpl");const menuSchema={[ui.ContextMenuPosition.MAIN_AREA]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.COL_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory}},[ui.ContextMenuGroup.LAYOUT]:{order:1},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.ROW_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory}},[ui.ContextMenuGroup.LAYOUT]:{order:1},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}}};var __defProp$3=Object.defineProperty,__getOwnPropDesc$3=Object.getOwnPropertyDescriptor,__decorateClass$3=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$3(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$3(target,key,result),result},"__decorateClass$3"),__decorateParam$3=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$3"),_a57;let SheetUIMobileController=(_a57=class extends core.Disposable{constructor(_injector,_componentManager,_layoutService,_commandService,_shortcutService,_menuManagerService,_uiPartsService){super(),this._injector=_injector,this._componentManager=_componentManager,this._layoutService=_layoutService,this._commandService=_commandService,this._shortcutService=_shortcutService,this._menuManagerService=_menuManagerService,this._uiPartsService=_uiPartsService,this._init()}_init(){this._initCustomComponents(),this._initCommands(),this._initMenus(),this._initShortcuts(),this._initWorkbenchParts(),this._initFocusHandler()}_initCustomComponents(){const componentManager=this._componentManager;this.disposeWithMe(componentManager.register(MENU_ITEM_INPUT_COMPONENT,MenuItemInput)),this.disposeWithMe(componentManager.register(BORDER_PANEL_COMPONENT,BorderPanel)),this.disposeWithMe(componentManager.register(COLOR_PICKER_COMPONENT,design.ColorPicker)),this.disposeWithMe(componentManager.register(FONT_FAMILY_COMPONENT,ui.FontFamily)),this.disposeWithMe(componentManager.register(FONT_FAMILY_ITEM_COMPONENT,ui.FontFamilyItem)),this.disposeWithMe(componentManager.register(FONT_SIZE_COMPONENT,ui.FontSize)),this.disposeWithMe(componentManager.register(DEFINED_NAME_CONTAINER,DefinedNameContainer))}_initCommands(){[AddWorksheetMergeAllCommand,AddWorksheetMergeCommand,AddWorksheetMergeHorizontalCommand,AddWorksheetMergeVerticalCommand,ChangeZoomRatioCommand,ExpandSelectionCommand,MoveSelectionCommand,MoveSelectionEnterAndTabCommand,RenameSheetOperation,RemoveSheetConfirmCommand,RemoveRowConfirmCommand,RemoveColConfirmCommand,HideRowConfirmCommand,HideColConfirmCommand,ScrollCommand,ScrollToCellCommand,SelectAllCommand,SetActivateCellEditOperation,sheets.SetBoldCommand,SetCellEditVisibleArrowOperation,SetCellEditVisibleOperation,SetCellEditVisibleWithF2Operation,SetRangeBoldCommand,SetRangeItalicCommand,SetRangeUnderlineCommand,SetRangeStrickThroughCommand,SetRangeSubscriptCommand,SetRangeSuperscriptCommand,SetRangeFontSizeCommand,SetRangeFontFamilyCommand,SetRangeTextColorCommand,sheets.SetItalicCommand,sheets.SetStrikeThroughCommand,sheets.SetFontFamilyCommand,sheets.SetFontSizeCommand,SetFormatPainterOperation,SetInfiniteFormatPainterCommand,SetOnceFormatPainterCommand,ApplyFormatPainterCommand,SetScrollOperation,SetScrollRelativeCommand,SetSelectionFrozenCommand,SetRowFrozenCommand,SetColumnFrozenCommand,CancelFrozenCommand,sheets.SetUnderlineCommand,SetZoomRatioCommand,SetZoomRatioOperation,ShowMenuListCommand,RefillCommand,InsertRangeMoveDownConfirmCommand,DeleteRangeMoveUpConfirmCommand,InsertRangeMoveRightConfirmCommand,DeleteRangeMoveLeftConfirmCommand,SidebarDefinedNameOperation,AutoFillCommand,AutoClearContentCommand,SheetPermissionOpenPanelOperation,SheetPermissionOpenDialogOperation,AddRangeProtectionFromToolbarCommand,AddRangeProtectionFromContextMenuCommand,ViewSheetPermissionFromContextMenuCommand,AddRangeProtectionFromSheetBarCommand,ViewSheetPermissionFromSheetBarCommand,ChangeSheetProtectionFromSheetBarCommand,DeleteRangeProtectionFromContextMenuCommand,SetRangeProtectionFromContextMenuCommand,AddWorksheetProtectionCommand,DeleteWorksheetProtectionCommand,SetWorksheetProtectionCommand,DeleteWorksheetProtectionFormSheetBarCommand,SetProtectionCommand].forEach(c=>{this.disposeWithMe(this._commandService.registerCommand(c))})}_initMenus(){this._menuManagerService.mergeMenu(menuSchema)}_initShortcuts(){[MoveSelectionDownShortcutItem,MoveSelectionUpShortcutItem,MoveSelectionLeftShortcutItem,MoveSelectionRightShortcutItem,MoveSelectionTabShortcutItem,MoveSelectionTabLeftShortcutItem,MoveSelectionEnterShortcutItem,MoveSelectionEnterUpShortcutItem,MoveSelectionEndDownShortcutItem,MoveSelectionEndUpShortcutItem,MoveSelectionEndLeftShortcutItem,MoveSelectionEndRightShortcutItem,ExpandSelectionDownShortcutItem,ExpandSelectionUpShortcutItem,ExpandSelectionLeftShortcutItem,ExpandSelectionRightShortcutItem,ExpandSelectionEndDownShortcutItem,ExpandSelectionEndUpShortcutItem,ExpandSelectionEndLeftShortcutItem,ExpandSelectionEndRightShortcutItem,SelectAllShortcutItem,ZoomInShortcutItem,ZoomOutShortcutItem,ResetZoomShortcutItem,PreventDefaultResetZoomShortcutItem,PreventDefaultZoomInShortcutItem,PreventDefaultZoomOutShortcutItem,SetBoldShortcutItem,SetItalicShortcutItem,SetUnderlineShortcutItem,SetStrikeThroughShortcutItem,ClearSelectionValueShortcutItem,...generateArrowSelectionShortCutItem(),EditorCursorEnterShortcut,StartEditWithF2Shortcut,EditorCursorTabShortcut,EditorBreakLineShortcut,EditorDeleteLeftShortcut,EditorDeleteLeftShortcutInActive,EditorCursorEscShortcut,SetRowHiddenShortcutItem,SetColHiddenShortcutItem].forEach(item=>{this.disposeWithMe(this._shortcutService.registerShortcut(item))})}_initWorkbenchParts(){this._uiPartsService.registerComponent(ui.BuiltInUIPart.HEADER,()=>core.connectInjector(MobileSheetBar,this._injector))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(core.UniverInstanceType.UNIVER_SHEET,_unitId=>{}))}},__name(_a57,"SheetUIMobileController"),_a57);SheetUIMobileController=__decorateClass$3([__decorateParam$3(0,core.Inject(core.Injector)),__decorateParam$3(1,core.Inject(ui.ComponentManager)),__decorateParam$3(2,ui.ILayoutService),__decorateParam$3(3,core.ICommandService),__decorateParam$3(4,ui.IShortcutService),__decorateParam$3(5,ui.IMenuManagerService),__decorateParam$3(6,ui.IUIPartsService)],SheetUIMobileController);var __defProp$2=Object.defineProperty,__getOwnPropDesc$2=Object.getOwnPropertyDescriptor,__decorateClass$2=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$2(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$2(target,key,result),result},"__decorateClass$2"),__decorateParam$2=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$2"),_a58;let SheetContextMenuMobileRenderController=(_a58=class extends core.Disposable{constructor(_context,_layoutService,_contextMenuService,_selectionManagerService,_selectionRenderService,_sheetSkeletonManagerService){super(),this._context=_context,this._layoutService=_layoutService,this._contextMenuService=_contextMenuService,this._selectionManagerService=_selectionManagerService,this._selectionRenderService=_selectionRenderService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._init()}_init(){let listenToSelectionChangeEvent=!1;this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(()=>listenToSelectionChangeEvent=!0)),this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(selectionsList=>{if(!selectionsList||listenToSelectionChangeEvent===!1)return;listenToSelectionChangeEvent=!1;const selectionRangeWithStyle=selectionsList[0];if(!selectionRangeWithStyle.primary)return;const canvasRect=this._layoutService.getContentElement().getBoundingClientRect(),range=this._selectionRenderService.attachSelectionWithCoord(selectionRangeWithStyle),rangeType=selectionRangeWithStyle.range.rangeType,{scene}=this._context,viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),viewportScrollX=(viewMain==null?void 0:viewMain.viewportScrollX)||0,viewportScrollY=(viewMain==null?void 0:viewMain.viewportScrollY)||0;let clientX=0,clientY=0;const rowHeaderWidth=this._sheetSkeletonManagerService.getCurrent().skeleton.rowHeaderWidth;switch(rangeType){case core.RANGE_TYPE.NORMAL:clientX=range.rangeWithCoord.startX+canvasRect.left-viewportScrollX,clientY=range.rangeWithCoord.endY+canvasRect.top-viewportScrollY;break;case core.RANGE_TYPE.COLUMN:clientX=range.rangeWithCoord.startX+canvasRect.left-viewportScrollX,clientY=Math.min(canvasRect.height/2,range.rangeWithCoord.endY)+40;break;case core.RANGE_TYPE.ROW:clientX=(canvasRect.width-rowHeaderWidth)/2+20,clientY=range.rangeWithCoord.endY+canvasRect.top-viewportScrollY;break;case core.RANGE_TYPE.ALL:clientX=range.rangeWithCoord.startX+canvasRect.left,clientY=range.rangeWithCoord.startY+canvasRect.top;break;default:clientX=range.rangeWithCoord.startX+canvasRect.left-viewportScrollX,clientY=range.rangeWithCoord.endY+canvasRect.top-viewportScrollY;break}clientX=core.Tools.clamp(clientX,rowHeaderWidth,canvasRect.width),clientY=core.Tools.clamp(clientY,canvasRect.top,canvasRect.height),this._contextMenuService.triggerContextMenu({clientX,clientY,preventDefault:__name(()=>{},"preventDefault"),stopPropagation:__name(()=>{},"stopPropagation")},ui.ContextMenuPosition.MAIN_AREA)}))}},__name(_a58,"SheetContextMenuMobileRenderController"),_a58);SheetContextMenuMobileRenderController=__decorateClass$2([__decorateParam$2(1,ui.ILayoutService),__decorateParam$2(2,ui.IContextMenuService),__decorateParam$2(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$2(4,ISheetSelectionRenderService),__decorateParam$2(5,core.Inject(exports.SheetSkeletonManagerService))],SheetContextMenuMobileRenderController);const _MobileSelectionControl=class _MobileSelectionControl extends SelectionControl{constructor(_scene,_zIndex,_highlightHeader=!0,_themeService,_rangeType=core.RANGE_TYPE.NORMAL){super(_scene,_zIndex,_themeService,_highlightHeader);__publicField(this,"_fillControlTopLeft");__publicField(this,"_fillControlBottomRight");this._scene=_scene,this._zIndex=_zIndex,this._highlightHeader=_highlightHeader,this._themeService=_themeService,this._rangeType=_rangeType,this.initControlPoints()}initControlPoints(){const defaultStyle=this.defaultStyle,expandCornerSize=defaultStyle.expandCornerSize||0,expandCornerInnerSize=(defaultStyle.expandCornerSize||0)/4,AutofillStrokeWidth=defaultStyle.AutofillStrokeWidth||0,stroke=defaultStyle.stroke,AutofillStroke=defaultStyle.AutofillStroke,zIndex=this.zIndex;this._fillControlTopLeft=new engineRender.Rect(SELECTION_MANAGER_KEY.fillTopLeft+zIndex,{zIndex:zIndex+2,width:expandCornerSize,height:expandCornerSize,radius:expandCornerSize/2,visualWidth:expandCornerInnerSize,visualHeight:expandCornerInnerSize,strokeWidth:AutofillStrokeWidth}),this._fillControlBottomRight=new engineRender.Rect(SELECTION_MANAGER_KEY.fillBottomRight+zIndex,{zIndex:zIndex+2,width:expandCornerSize,height:expandCornerSize,radius:expandCornerSize/2,visualHeight:expandCornerInnerSize,visualWidth:expandCornerInnerSize,strokeWidth:AutofillStrokeWidth});const fillProps={fill:stroke,stroke:AutofillStroke,strokeScaleEnabled:!1};this._fillControlTopLeft.setProps({...fillProps}),this._fillControlBottomRight.setProps({...fillProps});const objs=[this._fillControlTopLeft,this._fillControlBottomRight];switch(this._rangeType){case core.RANGE_TYPE.ROW:this.rowHeaderGroup.addObjects(...objs);break;case core.RANGE_TYPE.COLUMN:this.columnHeaderGroup.addObjects(...objs);break;case core.RANGE_TYPE.NORMAL:this.selectionShapeGroup.addObjects(...objs)}this.getScene().addObjects(objs,SHEET_COMPONENT_SELECTION_LAYER_INDEX)}get fillControlTopLeft(){return this._fillControlTopLeft}set fillControlTopLeft(value){this._fillControlTopLeft=value}get fillControlBottomRight(){return this._fillControlBottomRight}set fillControlBottomRight(value){this._fillControlBottomRight=value}get rangeType(){return this._rangeType}set rangeType(value){this._rangeType=value}dispose(){var _a61,_b;(_a61=this._fillControlBottomRight)==null||_a61.dispose(),(_b=this._fillControlTopLeft)==null||_b.dispose(),super.dispose()}_setSizeAndStyleForSelectionControl(style){var _a61,_b;super._setSizeAndStyleForSelectionControl(style);const defaultStyle=this.defaultStyle;style==null&&(style=defaultStyle);const{widgets=defaultStyle.widgets,hasAutoFill:autoFillEnabled=defaultStyle.hasAutoFill}=style;if(this.currentStyle=style,autoFillEnabled===!0&&!super._hasWidgets(widgets)){const{viewportScrollX,viewportScrollY}=this.getViewportMainScrollInfo(),{endX,endY}=this.selectionModel;this.transformControlPoint(viewportScrollX,viewportScrollY,endX,endY),this.fillControlTopLeft.show(),this.fillControlBottomRight.show()}else(_a61=this.fillControlTopLeft)==null||_a61.hide(),(_b=this.fillControlBottomRight)==null||_b.hide()}getViewportMainScrollInfo(){const viewMain=this.getScene().getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);return{viewportScrollX:(viewMain==null?void 0:viewMain.viewportScrollX)||0,viewportScrollY:(viewMain==null?void 0:viewMain.viewportScrollY)||0,width:(viewMain==null?void 0:viewMain.width)||0,height:(viewMain==null?void 0:viewMain.height)||0}}transformControlPoint(viewportScrollX=0,viewportScrollY=0,sheetContentWidth=0,sheetContentHeight=0){const style=this.currentStyle,rangeType=this.selectionModel.rangeType,expandCornerSize=style.expandCornerSize,{startX,startY,endX,endY}=this.selectionModel,viewportSizeInfo=this.getViewportMainScrollInfo(),viewportW=viewportSizeInfo.width,viewportH=viewportSizeInfo.height;switch(rangeType){case core.RANGE_TYPE.NORMAL:this.fillControlTopLeft.transformByState({left:-expandCornerSize/2,top:-expandCornerSize/2}),this.fillControlBottomRight.transformByState({left:endX-startX-expandCornerSize/2,top:endY-startY-expandCornerSize/2});break;case core.RANGE_TYPE.ROW:{const left=Math.min(viewportW/2+viewportScrollX,sheetContentWidth),controlLeft=-expandCornerSize/2+left;this.fillControlTopLeft.transformByState({left:controlLeft,top:-expandCornerSize/2}),this.fillControlBottomRight.transformByState({left:controlLeft,top:-expandCornerSize/2+endY-startY})}break;case core.RANGE_TYPE.COLUMN:{const top=Math.min(+viewportH/2+viewportScrollY,sheetContentHeight),controlTop=-expandCornerSize/2+top;this.fillControlTopLeft.transformByState({left:-expandCornerSize/2,top:controlTop}),this.fillControlBottomRight.transformByState({left:-expandCornerSize/2+endX-startX,top:controlTop})}break;default:console.error("unknown range type")}}};__name(_MobileSelectionControl,"MobileSelectionControl");let MobileSelectionControl=_MobileSelectionControl;var __defProp$1=Object.defineProperty,__getOwnPropDesc$1=Object.getOwnPropertyDescriptor,__decorateClass$1=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$1(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$1(target,key,result),result},"__decorateClass$1"),__decorateParam$1=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$1"),_a59;let MobileSheetsSelectionRenderService=(_a59=class extends BaseSelectionRenderService{constructor(_context,injector,themeService,shortcutService,selectionManagerService,sheetSkeletonManagerService,_logService,_commandService,_contextService,_scrollManagerService){super(injector,themeService,shortcutService,sheetSkeletonManagerService);__publicField(this,"_workbookSelections");__publicField(this,"_renderDisposable",null);__publicField(this,"_expandingSelection",!1);__publicField(this,"_selectionControls",[]);__publicField(this,"expandingControlMode","bottom-right");this._context=_context,this._logService=_logService,this._commandService=_commandService,this._contextService=_contextService,this._scrollManagerService=_scrollManagerService,this._workbookSelections=selectionManagerService.getWorkbookSelections(this._context.unitId),this._init()}_init(){const sheetObject=this._getSheetObject();this._initEventListeners(sheetObject),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._updateControlPointWhenScrolling()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{if(param==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const unitId=this._context.unitId,{sheetId,skeleton}=param,{scene}=this._context,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._changeRuntime(skeleton,scene,viewportMain),this._workbookSelections.getCurrentLastSelection()||this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,selections:[getTopLeftSelection(skeleton)]})}))}_initSelectionChangeListener(){this.disposeWithMe(this._workbookSelections.selectionMoveEnd$.subscribe(params=>{this._reset();for(const selectionWithStyle of params){const selectionData=attachSelectionWithCoord(selectionWithStyle,this._skeleton);this._addSelectionControlBySelectionData(selectionData)}}))}_initEventListeners(sheetObject){const{spreadsheetRowHeader,spreadsheetColumnHeader,spreadsheet,spreadsheetLeftTopPlaceholder}=sheetObject,{scene}=this._context;this._initSpreadsheetEvent(sheetObject),this.disposeWithMe(spreadsheetRowHeader==null?void 0:spreadsheetRowHeader.onPointerUp$.subscribeEvent((evt,_state)=>{if(this._normalSelectionDisabled())return;const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{row}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);isThisRowSelected(this._workbookSelections.getCurrentSelections(),row)||(this.createNewSelection(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.ROW,this._getActiveViewport(evt)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(spreadsheetColumnHeader==null?void 0:spreadsheetColumnHeader.onPointerUp$.subscribeEvent((evt,_state)=>{if(this._normalSelectionDisabled())return;const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);isThisColSelected(this._workbookSelections.getCurrentSelections(),column)||(this.createNewSelection(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.COLUMN,this._getActiveViewport(evt)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(spreadsheetLeftTopPlaceholder==null?void 0:spreadsheetLeftTopPlaceholder.onPointerUp$.subscribeEvent((_evt,state)=>{if(this._normalSelectionDisabled())return;this._reset();const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,selectionWithStyle=getAllSelection(skeleton),selectionData=attachSelectionWithCoord(selectionWithStyle,skeleton);this._addSelectionControlBySelectionData(selectionData),this.refreshSelectionMoveStart(),state.stopPropagation(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}))}_initSpreadsheetEvent(sheetObject){const{spreadsheet}=sheetObject;let longPressTimer;const longPressDuration=500,pointerDownPos={x:0,y:0},clearLongPressTimer=__name(()=>{clearTimeout(longPressTimer)},"clearLongPressTimer"),createNewSelection=__name((evt,showContextMenu)=>{this.createNewSelection(evt,spreadsheet.zIndex+1,core.RANGE_TYPE.NORMAL,this._getActiveViewport(evt)),showContextMenu&&this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())},"createNewSelection");spreadsheet==null||spreadsheet.onPointerMove$.subscribeEvent((evt,_state)=>{(Math.abs(evt.offsetX-pointerDownPos.x)>10||Math.abs(evt.offsetY-pointerDownPos.y)>10)&&clearLongPressTimer()});const spreadsheetPointerDownSub=spreadsheet==null?void 0:spreadsheet.onPointerDown$.subscribeEvent((evt,state)=>{pointerDownPos.x=evt.offsetX,pointerDownPos.y=evt.offsetY,longPressTimer=setTimeout(()=>{createNewSelection(evt,!0)},longPressDuration),state.stopPropagation()}),spreadsheetPointerUpSub=spreadsheet==null?void 0:spreadsheet.onPointerUp$.subscribeEvent((evt,state)=>{if(this._normalSelectionDisabled())return;clearTimeout(longPressTimer);const edge=10;Math.abs(evt.offsetX-pointerDownPos.x)>edge||Math.abs(evt.offsetY-pointerDownPos.y)>edge||(createNewSelection(evt,!1),state.stopPropagation())});this.disposeWithMe(core.toDisposable(spreadsheetPointerDownSub)),this.disposeWithMe(core.toDisposable(spreadsheetPointerUpSub))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(sheets.DISABLE_NORMAL_SELECTIONS).pipe(rxjs.startWith(!1),rxjs.distinctUntilChanged()).subscribe(disabled=>{var _a61;disabled?((_a61=this._renderDisposable)==null||_a61.dispose(),this._renderDisposable=null,this._reset()):this._renderDisposable=core.toDisposable(this.selectionMoveEnd$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVE_END)))}))}_updateSelections(selectionDataWithStyleList,type){const workbook=this._context.unit,unitId=workbook.getUnitId(),sheetId=workbook.getActiveSheet().getSheetId();selectionDataWithStyleList.length!==0&&this._commandService.executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,type,selections:selectionDataWithStyleList.map(selectionDataWithStyle=>sheets.convertSelectionDataToRange(selectionDataWithStyle))})}createNewSelection(evt,_zIndex=0,rangeType=core.RANGE_TYPE.NORMAL,viewport){this._shouldDetectMergedCells=rangeType===core.RANGE_TYPE.NORMAL;const skeleton=this._skeleton,scene=this._scene;if(!scene||!skeleton)return;viewport&&(this._activeViewport=viewport);const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY]));let{x:viewportPosX,y:viewportPosY}=relativeCoords;const scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords),{scaleX,scaleY}=scene.getAncestorScale(),cursorCellRangeInfo=this._getCellRangeByCursorPosition(viewportPosX,viewportPosY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return!1;const{rangeWithCoord:cursorCellRange,primaryWithCoord:primaryCursorCellRange}=cursorCellRangeInfo,cursorCellRangeWithRangeType={...cursorCellRange,rangeType};this._startRangeWhenPointerDown={...cursorCellRange,rangeType};let activeSelectionControl=this.getActiveSelectionControl();for(const control of this.getSelectionControls())if(control.model.isEqual(cursorCellRangeWithRangeType)){activeSelectionControl=control;break}(activeSelectionControl==null?void 0:activeSelectionControl.model.rangeType)!==rangeType&&(this._clearSelectionControls(),activeSelectionControl=this.newSelectionControl(scene,rangeType)),this._updateSelectionControlByRange(activeSelectionControl,cursorCellRangeWithRangeType,primaryCursorCellRange),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._expandingSelection=!1,(rangeType===core.RANGE_TYPE.ROW||rangeType===core.RANGE_TYPE.COLUMN)&&(rangeType===core.RANGE_TYPE.ROW?viewportPosX=0:rangeType===core.RANGE_TYPE.COLUMN&&(viewportPosY=0),this._movingHandler(viewportPosX,viewportPosY,activeSelectionControl,rangeType))}newSelectionControl(scene,rangeType){const selectionControls=this.getSelectionControls(),control=new MobileSelectionControl(scene,selectionControls.length,this._isHeaderHighlight,this._themeService,rangeType);this._selectionControls.push(control);const{expandingModeForTopLeft,expandingModeForBottomRight}=(()=>{switch(rangeType){case core.RANGE_TYPE.NORMAL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};case core.RANGE_TYPE.ROW:return{expandingModeForTopLeft:"top",expandingModeForBottomRight:"bottom"};case core.RANGE_TYPE.COLUMN:return{expandingModeForTopLeft:"left",expandingModeForBottomRight:"right"};case core.RANGE_TYPE.ALL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};default:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"}}})();return control.fillControlTopLeft.onPointerDown$.subscribeEvent(evt=>{this._expandingSelection=!0,this.expandingControlMode=expandingModeForTopLeft,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(evt,rangeType,this._activeViewport)}),control.fillControlBottomRight.onPointerDown$.subscribeEvent(evt=>{this._expandingSelection=!0,this.expandingControlMode=expandingModeForBottomRight,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(evt,rangeType,this._activeViewport)}),(rangeType===core.RANGE_TYPE.ROW||rangeType===core.RANGE_TYPE.COLUMN)&&!scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),control}_getActiveViewport(evt){const sheetObject=this._getSheetObject();return sheetObject==null?void 0:sheetObject.scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([evt.offsetX,evt.offsetY]))}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_normalSelectionDisabled(){return this._contextService.getContextValue(sheets.DISABLE_NORMAL_SELECTIONS)}getSelectionControls(){return this._selectionControls}_fillControlPointerDownHandler(evt,rangeType=core.RANGE_TYPE.NORMAL,viewport,scrollTimerType=engineRender.ScrollTimerType.ALL){var _a61,_b,_c;const skeleton=this._skeleton,scene=this._scene;if(!scene||!skeleton)return;viewport&&(this._activeViewport=viewport);const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),activeSelectionControl=this.getActiveSelectionControl();if(!activeSelectionControl)return;this._changeCurrCellWhenControlPointerDown(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._addEndingListeners(),this._scrollTimer=engineRender.ScrollTimer.create(this._scene,scrollTimerType),this._scrollTimer.startScroll((_a61=viewportMain==null?void 0:viewportMain.left)!=null?_a61:0,(_b=viewportMain==null?void 0:viewportMain.top)!=null?_b:0,viewportMain),(_c=scene.getTransformer())==null||_c.clearSelectedObjects();const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evt.offsetX,evt.offsetY]));this._setupPointerMoveListener(viewportMain,activeSelectionControl,rangeType,scrollTimerType,relativeCoords.x,relativeCoords.y);const disposableShortcut=this._shortcutService.forceEscape();this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(_evt=>{this.endSelection(),this._expandingSelection=!1,this.expandingControlMode="bottom-right",this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),disposableShortcut.dispose()})}_changeCurrCellWhenControlPointerDown(){const activeSelectionControl=this.getActiveSelectionControl(),skeleton=this._skeleton;let currCellRange;const{startRow,startColumn,endRow,endColumn}=activeSelectionControl.model;switch(this.expandingControlMode){case"top-left":currCellRange=skeleton.getCellByIndex(endRow,endColumn);break;case"bottom-right":currCellRange=skeleton.getCellByIndex(startRow,startColumn);break;case"left":currCellRange=skeleton.getCellByIndex(startRow,endColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;case"right":currCellRange=skeleton.getCellByIndex(startRow,startColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;case"top":currCellRange=skeleton.getCellByIndex(endRow,startColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;case"bottom":currCellRange=skeleton.getCellByIndex(startRow,startColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;default:currCellRange=skeleton.getCellByIndex(startRow,startColumn)}return activeSelectionControl.updateCurrCell(currCellRange),currCellRange}_movingHandler(offsetX,offsetY,activeSelectionControl,rangeType){var _a61,_b,_c,_d,_e,_f,_g,_h,_i,_j,_k,_l,_m;this._shouldDetectMergedCells=rangeType===core.RANGE_TYPE.NORMAL;const skeleton=this._skeleton,scene=this._scene,currSelectionRange={startRow:activeSelectionControl.model.startRow,endRow:activeSelectionControl.model.endRow,startColumn:activeSelectionControl.model.startColumn,endColumn:activeSelectionControl.model.endColumn},viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),targetViewport=(_a61=this._getViewportByCell(currSelectionRange.endRow,currSelectionRange.endColumn))!=null?_a61:viewportMain,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),targetViewport),{scaleX,scaleY}=scene.getAncestorScale();rangeType===core.RANGE_TYPE.ROW?offsetX=Number.POSITIVE_INFINITY:rangeType===core.RANGE_TYPE.COLUMN&&(offsetY=Number.POSITIVE_INFINITY);const cursorCellRangeInfo=this._getCellRangeByCursorPosition(offsetX,offsetY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return!1;const{rangeWithCoord:cursorCellRange}=cursorCellRangeInfo,currCellRange=activeSelectionControl.model.currentCell,startRowOfActiveCell=(_b=currCellRange==null?void 0:currCellRange.mergeInfo.startRow)!=null?_b:-1,endRowOfActiveCell=(_c=currCellRange==null?void 0:currCellRange.mergeInfo.endRow)!=null?_c:-1,startColumnOfActiveCell=(_d=currCellRange==null?void 0:currCellRange.mergeInfo.startColumn)!=null?_d:-1,endColOfActiveCell=(_e=currCellRange==null?void 0:currCellRange.mergeInfo.endColumn)!=null?_e:-1;let newSelectionRange={startRow:Math.min(cursorCellRange.startRow,startRowOfActiveCell),startColumn:Math.min(cursorCellRange.startColumn,startColumnOfActiveCell),endRow:Math.max(cursorCellRange.endRow,endRowOfActiveCell),endColumn:Math.max(cursorCellRange.endColumn,endColOfActiveCell)};if(rangeType===core.RANGE_TYPE.NORMAL?newSelectionRange=skeleton.getSelectionMergeBounding(newSelectionRange.startRow,newSelectionRange.startColumn,newSelectionRange.endRow,newSelectionRange.endColumn):rangeType===core.RANGE_TYPE.COLUMN?newSelectionRange={startRow:Math.min(cursorCellRange.startRow,(_f=currCellRange==null?void 0:currCellRange.actualRow)!=null?_f:-1),startColumn:Math.min(cursorCellRange.startColumn,(_g=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_g:-1),endRow:Math.max(cursorCellRange.endRow,(_h=currCellRange==null?void 0:currCellRange.actualRow)!=null?_h:-1),endColumn:Math.max(cursorCellRange.endColumn,(_i=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_i:-1)}:rangeType===core.RANGE_TYPE.ROW&&(newSelectionRange={startRow:Math.min(cursorCellRange.startRow,(_j=currCellRange==null?void 0:currCellRange.actualRow)!=null?_j:-1),startColumn:Math.min(cursorCellRange.startColumn,(_k=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_k:-1),endRow:Math.max(cursorCellRange.endRow,(_l=currCellRange==null?void 0:currCellRange.actualRow)!=null?_l:-1),endColumn:Math.max(cursorCellRange.endColumn,(_m=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_m:-1)}),!newSelectionRange)return!1;const startCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.startRow,newSelectionRange.startColumn),endCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.endRow,newSelectionRange.endColumn),newSelectionRangeWithCoord={startColumn:newSelectionRange.startColumn,startRow:newSelectionRange.startRow,endColumn:newSelectionRange.endColumn,endRow:newSelectionRange.endRow,startY:(startCellXY==null?void 0:startCellXY.startY)||0,endY:(endCellXY==null?void 0:endCellXY.endY)||0,startX:(startCellXY==null?void 0:startCellXY.startX)||0,endX:(endCellXY==null?void 0:endCellXY.endX)||0};(currSelectionRange.startRow!==newSelectionRange.startRow||currSelectionRange.startColumn!==newSelectionRange.startColumn||currSelectionRange.endRow!==newSelectionRange.endRow||currSelectionRange.endColumn!==newSelectionRange.endColumn)&&activeSelectionControl&&(this._updateSelectionControlByRange(activeSelectionControl,newSelectionRangeWithCoord),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateControlPointWhenScrolling(){const{scene}=this._context;if(!scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN))return;const sub=this._scrollManagerService.validViewportScrollInfo$.subscribe(param=>{var _a61;if(param==null)return;const{viewportScrollX,viewportScrollY}=param,activeControl=this.getActiveSelectionControl();if(activeControl==null)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton,sheetContentHeight=skeleton==null?void 0:skeleton.rowTotalHeight,sheetContentWidth=skeleton==null?void 0:skeleton.columnTotalWidth,rangeType=activeControl.rangeType;rangeType===core.RANGE_TYPE.COLUMN?activeControl.transformControlPoint(0,viewportScrollY,sheetContentWidth,sheetContentHeight):rangeType===core.RANGE_TYPE.ROW&&activeControl.transformControlPoint(viewportScrollX,0,sheetContentWidth,sheetContentHeight)});this.disposeWithMe(core.toDisposable(sub))}},__name(_a59,"MobileSheetsSelectionRenderService"),_a59);MobileSheetsSelectionRenderService=__decorateClass$1([__decorateParam$1(1,core.Inject(core.Injector)),__decorateParam$1(2,core.Inject(core.ThemeService)),__decorateParam$1(3,ui.IShortcutService),__decorateParam$1(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$1(5,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$1(6,core.ILogService),__decorateParam$1(7,core.ICommandService),__decorateParam$1(8,core.IContextService),__decorateParam$1(9,core.Inject(SheetScrollManagerService))],MobileSheetsSelectionRenderService);var __defProp2=Object.defineProperty,__getOwnPropDesc=Object.getOwnPropertyDescriptor,__defNormalProp2=__name((obj,key,value)=>key in obj?__defProp2(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp"),__decorateClass=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp2(target,key,result),result},"__decorateClass"),__decorateParam=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam"),__publicField2=__name((obj,key,value)=>__defNormalProp2(obj,typeof key!="symbol"?key+"":key,value),"__publicField"),_a60;exports.UniverSheetsMobileUIPlugin=(_a60=class extends core.Plugin{constructor(_config=defaultPluginConfig,_injector,_renderManagerService,_univerInstanceService){super(),this._config=_config,this._injector=_injector,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService}onStarting(){[[ShortcutExperienceService],[ISheetClipboardService,{useClass:exports.SheetClipboardService}],[ISheetBarService,{useClass:SheetBarService}],[IFormatPainterService,{useClass:FormatPainterService}],[IAutoFillService,{useClass:exports.AutoFillService}],[SheetPrintInterceptorService],[ISheetSelectionRenderService,{useClass:MobileSheetsSelectionRenderService}],[IStatusBarService,{useClass:StatusBarService}],[IMarkSelectionService,{useClass:exports.MarkSelectionService}],[exports.HoverManagerService],[exports.DragManagerService],[exports.SheetCanvasPopManagerService],[exports.CellAlertManagerService],[SelectAllService],[ActiveWorksheetController],[exports.AutoHeightController],[SheetClipboardController],[exports.SheetsRenderService],[SheetUIMobileController],[exports.StatusBarController],[SheetPermissionPanelModel],[SheetPermissionUserManagerService],[WorksheetProtectionRenderController],[SheetPermissionInterceptorClipboardController],[exports.SheetPermissionInterceptorBaseController],[exports.SheetPermissionInitController],[SheetPermissionRenderManagerController]].forEach(d=>this._injector.add(d))}onReady(){this._markSheetAsFocused(),this._registerRenderBasics(),this._injector.get(SheetUIMobileController)}onRendered(){this._registerRenderModules()}_registerRenderBasics(){[[exports.SheetSkeletonManagerService],[exports.SheetRenderController],[ISheetSelectionRenderService,{useClass:MobileSheetsSelectionRenderService}],[SheetScrollManagerService]].forEach(renderDep=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,renderDep))})}_registerRenderModules(){[[exports.HeaderMoveRenderController],[exports.HeaderFreezeRenderController],[MobileSheetsScrollRenderController],[SheetsZoomRenderController],[FormatPainterRenderController],[CellAlertRenderController],[ForceStringAlertRenderController],[MarkSelectionRenderController],[exports.HoverRenderController],[exports.DragRenderController],[ForceStringRenderController],[exports.CellCustomRenderController],[SheetContextMenuMobileRenderController],[SheetPermissionInterceptorCanvasRenderController],[SheetPermissionInterceptorFormulaRenderController],[SheetPermissionRenderController]].forEach(renderModule=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,renderModule))})}_markSheetAsFocused(){const univerInstanceService=this._univerInstanceService;this.disposeWithMe(univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.filter(v=>!!v)).subscribe(workbook=>{univerInstanceService.focusUnit(workbook.getUnitId())}))}},__name(_a60,"UniverSheetsMobileUIPlugin"),_a60);__publicField2(exports.UniverSheetsMobileUIPlugin,"pluginName","SHEET_UI_PLUGIN");__publicField2(exports.UniverSheetsMobileUIPlugin,"type",core.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsMobileUIPlugin=__decorateClass([core.DependentOn(sheets.UniverSheetsPlugin,ui.UniverMobileUIPlugin),__decorateParam(1,core.Inject(core.Injector)),__decorateParam(2,engineRender.IRenderManagerService),__decorateParam(3,core.IUniverInstanceService)],exports.UniverSheetsMobileUIPlugin);exports.AFFECT_LAYOUT_STYLES=AFFECT_LAYOUT_STYLES;exports.APPLY_TYPE=APPLY_TYPE;exports.AddRangeProtectionCommand=AddRangeProtectionCommand;exports.AddRangeProtectionFromContextMenuCommand=AddRangeProtectionFromContextMenuCommand;exports.AddRangeProtectionFromSheetBarCommand=AddRangeProtectionFromSheetBarCommand;exports.AddRangeProtectionFromToolbarCommand=AddRangeProtectionFromToolbarCommand;exports.AddWorksheetMergeAllCommand=AddWorksheetMergeAllCommand;exports.AddWorksheetMergeCommand=AddWorksheetMergeCommand;exports.AddWorksheetMergeHorizontalCommand=AddWorksheetMergeHorizontalCommand;exports.AddWorksheetMergeVerticalCommand=AddWorksheetMergeVerticalCommand;exports.AddWorksheetProtectionCommand=AddWorksheetProtectionCommand;exports.ApplyFormatPainterCommand=ApplyFormatPainterCommand;exports.AutoClearContentCommand=AutoClearContentCommand;exports.AutoFillCommand=AutoFillCommand;exports.BaseSelectionRenderService=BaseSelectionRenderService;exports.COPY_TYPE=COPY_TYPE;exports.CancelFrozenCommand=CancelFrozenCommand;exports.CellAlertType=CellAlertType;exports.CellEditorManagerService=CellEditorManagerService;exports.ChangeSheetProtectionFromSheetBarCommand=ChangeSheetProtectionFromSheetBarCommand;exports.ChangeZoomRatioCommand=ChangeZoomRatioCommand;exports.DATA_TYPE=DATA_TYPE;exports.DeleteRangeMoveLeftConfirmCommand=DeleteRangeMoveLeftConfirmCommand;exports.DeleteRangeMoveUpConfirmCommand=DeleteRangeMoveUpConfirmCommand;exports.DeleteRangeProtectionFromContextMenuCommand=DeleteRangeProtectionFromContextMenuCommand;exports.DeleteRangeSelectionCommand=DeleteRangeSelectionCommand;exports.DeleteWorksheetProtectionCommand=DeleteWorksheetProtectionCommand;exports.DeleteWorksheetProtectionFormSheetBarCommand=DeleteWorksheetProtectionFormSheetBarCommand;exports.ExpandSelectionCommand=ExpandSelectionCommand;exports.FONT_FAMILY_COMPONENT=FONT_FAMILY_COMPONENT;exports.FONT_FAMILY_ITEM_COMPONENT=FONT_FAMILY_ITEM_COMPONENT;exports.FONT_SIZE_COMPONENT=FONT_SIZE_COMPONENT;exports.FormatPainterStatus=FormatPainterStatus;exports.HideColConfirmCommand=HideColConfirmCommand;exports.HideRowConfirmCommand=HideRowConfirmCommand;exports.IAutoFillService=IAutoFillService;exports.ICellEditorManagerService=ICellEditorManagerService;exports.IEditorBridgeService=IEditorBridgeService;exports.IFormatPainterService=IFormatPainterService;exports.IFormulaEditorManagerService=IFormulaEditorManagerService;exports.IMarkSelectionService=IMarkSelectionService;exports.ISheetClipboardService=ISheetClipboardService;exports.ISheetSelectionRenderService=ISheetSelectionRenderService;exports.InsertRangeMoveDownConfirmCommand=InsertRangeMoveDownConfirmCommand;exports.InsertRangeMoveRightConfirmCommand=InsertRangeMoveRightConfirmCommand;exports.JumpOver=JumpOver;exports.MobileSheetBar=MobileSheetBar;exports.MoveSelectionCommand=MoveSelectionCommand;exports.MoveSelectionEnterAndTabCommand=MoveSelectionEnterAndTabCommand;exports.PASTE_SPECIAL_MENU_ID=PASTE_SPECIAL_MENU_ID;exports.PREDEFINED_HOOK_NAME=PREDEFINED_HOOK_NAME;exports.RANGE_SELECTOR_COMPONENT_KEY=RANGE_SELECTOR_COMPONENT_KEY;exports.RANGE_SELECTOR_SYMBOLS=RANGE_SELECTOR_SYMBOLS;exports.RefillCommand=RefillCommand;exports.RemoveColConfirmCommand=RemoveColConfirmCommand;exports.RemoveRowConfirmCommand=RemoveRowConfirmCommand;exports.RemoveSheetConfirmCommand=RemoveSheetConfirmCommand;exports.RenameSheetOperation=RenameSheetOperation;exports.RenderSheetContent=RenderSheetContent;exports.RenderSheetFooter=RenderSheetFooter;exports.RenderSheetHeader=RenderSheetHeader;exports.ResetScrollCommand=ResetScrollCommand;exports.SELECTION_SHAPE_DEPTH=SELECTION_SHAPE_DEPTH;exports.SHEET_UI_PLUGIN_NAME=SHEET_UI_PLUGIN_NAME;exports.SHEET_VIEW_KEY=SHEET_VIEW_KEY;exports.ScrollCommand=ScrollCommand;exports.ScrollToCellCommand=ScrollToCellCommand;exports.ScrollToRangeOperation=ScrollToRangeOperation;exports.SelectAllCommand=SelectAllCommand;exports.SelectionShape=SelectionControl;exports.SetActivateCellEditOperation=SetActivateCellEditOperation;exports.SetCellEditVisibleArrowOperation=SetCellEditVisibleArrowOperation;exports.SetCellEditVisibleOperation=SetCellEditVisibleOperation;exports.SetCellEditVisibleWithF2Operation=SetCellEditVisibleWithF2Operation;exports.SetColumnFrozenCommand=SetColumnFrozenCommand;exports.SetFormatPainterOperation=SetFormatPainterOperation;exports.SetInfiniteFormatPainterCommand=SetInfiniteFormatPainterCommand;exports.SetOnceFormatPainterCommand=SetOnceFormatPainterCommand;exports.SetProtectionCommand=SetProtectionCommand;exports.SetRangeBoldCommand=SetRangeBoldCommand;exports.SetRangeFontFamilyCommand=SetRangeFontFamilyCommand;exports.SetRangeFontSizeCommand=SetRangeFontSizeCommand;exports.SetRangeItalicCommand=SetRangeItalicCommand;exports.SetRangeProtectionCommand=SetRangeProtectionCommand;exports.SetRangeProtectionFromContextMenuCommand=SetRangeProtectionFromContextMenuCommand;exports.SetRangeStrickThroughCommand=SetRangeStrickThroughCommand;exports.SetRangeSubscriptCommand=SetRangeSubscriptCommand;exports.SetRangeSuperscriptCommand=SetRangeSuperscriptCommand;exports.SetRangeTextColorCommand=SetRangeTextColorCommand;exports.SetRangeUnderlineCommand=SetRangeUnderlineCommand;exports.SetRowFrozenCommand=SetRowFrozenCommand;exports.SetScrollOperation=SetScrollOperation;exports.SetScrollRelativeCommand=SetScrollRelativeCommand;exports.SetSelectionFrozenCommand=SetSelectionFrozenCommand;exports.SetWorksheetProtectionCommand=SetWorksheetProtectionCommand;exports.SetZoomRatioCommand=SetZoomRatioCommand;exports.SetZoomRatioOperation=SetZoomRatioOperation;exports.SheetBar=SheetBar;exports.SheetCopyCommand=SheetCopyCommand;exports.SheetCutCommand=SheetCutCommand;exports.SheetMenuPosition=SheetMenuPosition;exports.SheetPasteBesidesBorderCommand=SheetPasteBesidesBorderCommand;exports.SheetPasteColWidthCommand=SheetPasteColWidthCommand;exports.SheetPasteCommand=SheetPasteCommand;exports.SheetPasteFormatCommand=SheetPasteFormatCommand;exports.SheetPasteShortKeyCommand=SheetPasteShortKeyCommand;exports.SheetPasteValueCommand=SheetPasteValueCommand;exports.SheetPermissionOpenDialogOperation=SheetPermissionOpenDialogOperation;exports.SheetPermissionOpenPanelOperation=SheetPermissionOpenPanelOperation;exports.SheetPrintInterceptorService=SheetPrintInterceptorService;exports.SheetsUIPart=SheetsUIPart;exports.ShowMenuListCommand=ShowMenuListCommand;exports.SidebarDefinedNameOperation=SidebarDefinedNameOperation;exports.VIEWPORT_KEY=SHEET_VIEWPORT_KEY;exports.ViewSheetPermissionFromContextMenuCommand=ViewSheetPermissionFromContextMenuCommand;exports.ViewSheetPermissionFromSheetBarCommand=ViewSheetPermissionFromSheetBarCommand;exports.attachPrimaryWithCoord=attachPrimaryWithCoord;exports.attachRangeWithCoord=attachRangeWithCoord;exports.attachSelectionWithCoord=attachSelectionWithCoord;exports.calculateDocSkeletonRects=calculateDocSkeletonRects;exports.checkInHeaderRanges=matchedSelectionByRowColIndex;exports.deriveStateFromActiveSheet$=deriveStateFromActiveSheet$;exports.getAllSelection=getAllSelection;exports.getAutoFillRepeatRange=getAutoFillRepeatRange;exports.getCellRealRange=getCellRealRange;exports.getCoordByCell=getCoordByCell;exports.getCoordByOffset=getCoordByOffset;exports.getCurrentExclusiveRangeInterest$=getCurrentExclusiveRangeInterest$;exports.getCurrentRangeDisable$=getCurrentRangeDisable$;exports.getCustomRangePosition=getCustomRangePosition;exports.getEditingCustomRangePosition=getEditingCustomRangePosition;exports.getEditorObject=getEditorObject;exports.getObservableWithExclusiveRange$=getObservableWithExclusiveRange$;exports.getRepeatRange=getRepeatRange;exports.getSheetObject=getSheetObject;exports.getTopLeftSelection=getTopLeftSelection;exports.getTransformCoord=getTransformCoord;exports.isRangeSelector=isRangeSelector;exports.menuSchema=menuSchema$1;exports.mergeSetRangeValues=mergeSetRangeValues;exports.rangeToDiscreteRange=rangeToDiscreteRange;exports.useActiveWorkbook=useActiveWorkbook;exports.useActiveWorksheet=useActiveWorksheet;exports.useHighlightRange=useHighlightRange;exports.useWorkbooks=useWorkbooks;exports.virtualizeDiscreteRanges=virtualizeDiscreteRanges;exports.whenFormulaEditorActivated=whenFormulaEditorActivated;exports.whenSheetEditorFocused=whenSheetEditorFocused;
25
+ `,paragraphs:[{startIndex:0}],textRuns:[]}),this._syncContentAndRender(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,body)}_commandExecutedListener(){const INCLUDE_LIST=[core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id===docs.RichTextEditingMutation.id||command.id===ui.SetEditorResizeOperation.id){const params=command.params,{unitId}=params;if(params.isSync)return;if(INCLUDE_LIST.includes(unitId)){const editorDocDataModel=this._univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_DOC),syncId=unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY?core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY:core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY;this._checkAndSetRenderStyleConfig(editorDocDataModel),this._syncActionsAndRender(syncId,params)}}}));const needUpdateFormulaEditorContentCommandList=[sheets.SetRangeValuesMutation.id,sheets.MoveRangeMutation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{var _a61,_b,_c,_d,_e;if(needUpdateFormulaEditorContentCommandList.includes(command.id)){const editCellState=this._editorBridgeService.getLatestEditCellState();if(editCellState==null)return;let needUpdate=!1;const{row,column}=editCellState;if(command.id===sheets.SetRangeValuesMutation.id&&command.params?(_b=(_a61=command.params.cellValue)==null?void 0:_a61[row])!=null&&_b[column]&&(needUpdate=!0):command.id===sheets.MoveRangeMutation.id&&command.params&&(_d=(_c=command.params.to.value)==null?void 0:_c[row])!=null&&_d[column]&&(needUpdate=!0),needUpdate){const body=(_e=editCellState.documentLayoutObject.documentModel)==null?void 0:_e.getBody();if(body==null)return;this._syncContentAndRender(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,core.Tools.deepClone(body))}}}))}_syncActionsAndRender(unitId,parmas){var _a61;const INCLUDE_LIST=[core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY],currentRender=this._renderManagerService.getRenderById(unitId);if(currentRender==null)return;const skeleton=currentRender.with(docs.DocSkeletonManagerService).getSkeleton(),docDataModel=this._univerInstanceService.getUniverDocInstance(unitId),docViewModel=this._getEditorViewModel(unitId);docDataModel==null||docViewModel==null||(this._commandService.syncExecuteCommand(docs.RichTextEditingMutation.id,{...parmas,isSync:!0,unitId}),docViewModel.reset(docDataModel),skeleton.calculate(),INCLUDE_LIST.includes(unitId)&&((_a61=currentRender.mainComponent)==null||_a61.makeDirty()))}_syncContentAndRender(unitId,body){var _a61,_b;unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&body.paragraphs&&(body.paragraphs=this._clearParagraph(body.paragraphs));const INCLUDE_LIST=[core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY],skeleton=(_a61=this._renderManagerService.getRenderById(unitId))==null?void 0:_a61.with(docs.DocSkeletonManagerService).getSkeleton(),docDataModel=this._univerInstanceService.getUniverDocInstance(unitId),docViewModel=this._getEditorViewModel(unitId);if(docDataModel==null||docViewModel==null||skeleton==null)return;docDataModel.getSnapshot().body=body,this._checkAndSetRenderStyleConfig(docDataModel),docViewModel.reset(docDataModel);const currentRender=this._renderManagerService.getRenderById(unitId);currentRender!=null&&(skeleton.calculate(),INCLUDE_LIST.includes(unitId)&&((_b=currentRender.mainComponent)==null||_b.makeDirty()),unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY&&this._formulaEditorController.autoScroll())}_checkAndSetRenderStyleConfig(documentDataModel){var _a61;const snapshot=documentDataModel.getSnapshot(),{body}=snapshot;if(snapshot.id!==core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)return;let renderConfig=snapshot.documentStyle.renderConfig;renderConfig==null&&(renderConfig={},snapshot.documentStyle.renderConfig=renderConfig),((_a61=body==null?void 0:body.dataStream)!=null?_a61:"").startsWith("=")?renderConfig.isRenderStyle=core.BooleanNumber.TRUE:renderConfig.isRenderStyle=core.BooleanNumber.FALSE}_clearParagraph(paragraphs){const newParagraphs=core.Tools.deepClone(paragraphs);for(const paragraph of newParagraphs)paragraph.paragraphStyle&&(paragraph.paragraphStyle.horizontalAlign=core.HorizontalAlign.UNSPECIFIED);return newParagraphs}},__name(_a30,"EditorDataSyncController"),_a30);EditorDataSyncController=__decorateClass$s([__decorateParam$s(0,core.IUniverInstanceService),__decorateParam$s(1,engineRender.IRenderManagerService),__decorateParam$s(2,IEditorBridgeService),__decorateParam$s(3,core.ICommandService),__decorateParam$s(4,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$s(5,core.Inject(sheets.WorksheetProtectionRuleModel)),__decorateParam$s(6,core.Inject(exports.FormulaEditorController))],EditorDataSyncController);var __defProp$r=Object.defineProperty,__getOwnPropDesc$r=Object.getOwnPropertyDescriptor,__decorateClass$r=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$r(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$r(target,key,result),result},"__decorateClass$r"),__decorateParam$r=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$r");const ALERT_KEY="SHEET_FORCE_STRING_ALERT";var _a31;let ForceStringAlertRenderController=(_a31=class extends core.Disposable{constructor(_context,_hoverManagerService,_cellAlertManagerService,_localeService){super(),this._context=_context,this._hoverManagerService=_hoverManagerService,this._cellAlertManagerService=_cellAlertManagerService,this._localeService=_localeService,this._init()}_init(){this._initCellAlertPopup()}_initCellAlertPopup(){this.disposeWithMe(this._hoverManagerService.currentCell$.subscribe(cellPos=>{var _a61;if(cellPos){const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const cellData=worksheet.getCell(cellPos.location.row,cellPos.location.col);if((cellData==null?void 0:cellData.t)===core.CellValueType.FORCE_STRING&&cellData.v&&core.isRealNum(cellData.v)){const currentAlert=this._cellAlertManagerService.currentAlert.get(ALERT_KEY),currentLoc=(_a61=currentAlert==null?void 0:currentAlert.alert)==null?void 0:_a61.location;if(currentLoc&&currentLoc.row===cellPos.location.row&&currentLoc.col===cellPos.location.col&&currentLoc.subUnitId===cellPos.location.subUnitId&&currentLoc.unitId===cellPos.location.unitId)return;this._cellAlertManagerService.showAlert({type:CellAlertType.ERROR,title:this._localeService.t("info.error"),message:this._localeService.t("info.forceStringInfo"),location:cellPos.location,width:200,height:74,key:ALERT_KEY});return}}this._cellAlertManagerService.removeAlert(ALERT_KEY)}))}},__name(_a31,"ForceStringAlertRenderController"),_a31);ForceStringAlertRenderController=__decorateClass$r([__decorateParam$r(1,core.Inject(exports.HoverManagerService)),__decorateParam$r(2,core.Inject(exports.CellAlertManagerService)),__decorateParam$r(3,core.Inject(core.LocaleService))],ForceStringAlertRenderController);var __defProp$q=Object.defineProperty,__getOwnPropDesc$q=Object.getOwnPropertyDescriptor,__decorateClass$q=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$q(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$q(target,key,result),result},"__decorateClass$q"),__decorateParam$q=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$q"),_a32;let ForceStringRenderController=(_a32=class extends core.RxDisposable{constructor(_context,_sheetSkeletonManagerService,_sheetInterceptorService){super(),this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._sheetInterceptorService=_sheetInterceptorService,this._initViewModelIntercept()}_initViewModelIntercept(){const FORCE_STRING_MARK={tl:{size:6,color:"#409f11"}};this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:10,effect:core.InterceptorEffectEnum.Style,handler:__name((cell,pos,next)=>{var _a61;if(!((_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton))return next(cell);const cellRaw=pos.worksheet.getCellRaw(pos.row,pos.col);return!cellRaw||cellRaw.v===null||cellRaw.v===void 0?next(cell):(cell==null?void 0:cell.t)===core.CellValueType.FORCE_STRING&&core.isRealNum(cellRaw.v)?next({...cell,markers:{...cell==null?void 0:cell.markers,...FORCE_STRING_MARK}}):next(cell)},"handler")}))}},__name(_a32,"ForceStringRenderController"),_a32);ForceStringRenderController=__decorateClass$q([__decorateParam$q(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$q(2,core.Inject(sheets.SheetInterceptorService))],ForceStringRenderController);var __defProp$p=Object.defineProperty,__getOwnPropDesc$p=Object.getOwnPropertyDescriptor,__decorateClass$p=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$p(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$p(target,key,result),result},"__decorateClass$p"),__decorateParam$p=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$p"),_a33;let FormatPainterController=(_a33=class extends core.Disposable{constructor(_commandService,_formatPainterService,_univerInstanceService,_renderManagerService,_selectionManagerService,_sheetInterceptorService,_injector){super(),this._commandService=_commandService,this._formatPainterService=_formatPainterService,this._univerInstanceService=_univerInstanceService,this._renderManagerService=_renderManagerService,this._selectionManagerService=_selectionManagerService,this._sheetInterceptorService=_sheetInterceptorService,this._injector=_injector,this._initialize()}_initialize(){this._commandExecutedListener(),this._addDefaultHook()}_commandExecutedListener(){const selectionRenderService=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET).with(ISheetSelectionRenderService);this.disposeWithMe(selectionRenderService.selectionMoveEnd$.subscribe(selections=>{var _a61,_b;if(this._formatPainterService.getStatus()!==FormatPainterStatus.OFF){const{rangeWithCoord}=selections[selections.length-1];this._commandService.executeCommand(ApplyFormatPainterCommand.id,{unitId:((_a61=this._univerInstanceService.getFocusedUnit())==null?void 0:_a61.getUnitId())||"",subUnitId:((_b=this._univerInstanceService.getFocusedUnit().getActiveSheet())==null?void 0:_b.getSheetId())||"",range:{startRow:rangeWithCoord.startRow,startColumn:rangeWithCoord.startColumn,endRow:rangeWithCoord.endRow,endColumn:rangeWithCoord.endColumn}}),this._formatPainterService.getStatus()===FormatPainterStatus.ONCE&&this._commandService.executeCommand(SetOnceFormatPainterCommand.id)}}))}_addDefaultHook(){const defaultHook={id:"default-format-painter",priority:0,isDefaultHook:!0,onStatusChange:__name(status=>{if(status!==FormatPainterStatus.OFF){const format=this._collectSelectionRangeFormat();format&&this._formatPainterService.setSelectionFormat(format)}},"onStatusChange"),onApply:__name((unitId,subUnitId,range,format)=>this._getUndoRedoMutationInfo(unitId,subUnitId,range,format),"onApply")};this._formatPainterService.addHook(defaultHook)}_collectSelectionRangeFormat(){const selection=this._selectionManagerService.getCurrentLastSelection(),range=selection==null?void 0:selection.range;if(!range)return null;const{startRow,endRow,startColumn,endColumn}=range,workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!worksheet)return null;const cellData=worksheet.getCellMatrix(),styles2=workbook.getStyles(),stylesMatrix=new core.ObjectMatrix,merges=[];for(let r2=startRow;r2<=endRow;r2++)for(let c=startColumn;c<=endColumn;c++){const cell=cellData.getValue(r2,c);stylesMatrix.setValue(r2,c,styles2.getStyleByCell(cell)||{});const{isMergedMainCell,...mergeInfo}=worksheet.getCellInfoInMergeData(r2,c);isMergedMainCell&&merges.push({startRow:mergeInfo.startRow,startColumn:mergeInfo.startColumn,endRow:mergeInfo.endRow,endColumn:mergeInfo.endColumn})}return{styles:stylesMatrix,merges}}_getUndoRedoMutationInfo(unitId,subUnitId,originRange,format){const sheetInterceptorService=this._sheetInterceptorService,univerInstanceService=this._univerInstanceService,{merges,styles:stylesMatrix}=format;if(!stylesMatrix)return{undos:[],redos:[]};const{startRow,startColumn,endRow,endColumn}=stylesMatrix.getDataRange(),styleRowsNum=endRow-startRow+1,styleColsNum=endColumn-startColumn+1,range=originRange.startRow===originRange.endRow&&originRange.startColumn===originRange.endColumn?{startRow:originRange.startRow,startColumn:originRange.startColumn,endRow:originRange.startRow+styleRowsNum-1,endColumn:originRange.startColumn+styleColsNum-1}:originRange,styleValues=Array.from({length:range.endRow-range.startRow+1},()=>Array.from({length:range.endColumn-range.startColumn+1},()=>({}))),mergeRanges=[];styleValues.forEach((row,rowIndex)=>{row.forEach((col,colIndex)=>{const mappedRowIndex=rowIndex%styleRowsNum+startRow,mappedColIndex=colIndex%styleColsNum+startColumn,style=stylesMatrix.getValue(mappedRowIndex,mappedColIndex);style&&(styleValues[rowIndex][colIndex].s=Object.keys(style).length>0?style:null)})}),merges.forEach(merge=>{const relatedRange={startRow:merge.startRow-startRow,startColumn:merge.startColumn-startColumn,endRow:merge.endRow-startRow,endColumn:merge.endColumn-startColumn},rowRepeats=Math.max(1,Math.floor((range.endRow-range.startRow+1)/styleRowsNum)),colRepeats=Math.max(1,Math.floor((range.endColumn-range.startColumn+1)/styleColsNum));for(let i=0;i<rowRepeats;i++)for(let j=0;j<colRepeats;j++)mergeRanges.push({startRow:relatedRange.startRow+i*styleRowsNum+range.startRow,startColumn:relatedRange.startColumn+j*styleColsNum+range.startColumn,endRow:relatedRange.endRow+i*styleRowsNum+range.startRow,endColumn:relatedRange.endColumn+j*styleColsNum+range.startColumn})});const currentSelections=[range],clearCellValue=new core.ObjectMatrix,cellValue=new core.ObjectMatrix;if(core.Tools.isArray(styleValues))for(let i=0;i<currentSelections.length;i++){const{startRow:startRow2,startColumn:startColumn2,endRow:endRow2,endColumn:endColumn2}=currentSelections[i];for(let r2=0;r2<=endRow2-startRow2;r2++)for(let c=0;c<=endColumn2-startColumn2;c++)clearCellValue.setValue(r2+startRow2,c+startColumn2,{s:null}),cellValue.setValue(r2+startRow2,c+startColumn2,styleValues[r2][c])}const clearStyleMutationParams={subUnitId,unitId,cellValue:clearCellValue.getMatrix()},setRangeValuesMutationParams={subUnitId,unitId,cellValue:cellValue.getMatrix()},undoSetRangeValuesMutationParams=this._injector.invoke(sheets.SetRangeValuesUndoMutationFactory,clearStyleMutationParams),{undos:interceptorUndos,redos:interceptorRedos}=sheetInterceptorService.onCommandExecute({id:sheets.SetRangeValuesCommand.id,params:{...setRangeValuesMutationParams,range:currentSelections}}),ranges=sheets.getAddMergeMutationRangeByType(mergeRanges),mergeRedos=[],mergeUndos=[],worksheet=univerInstanceService.getUnit(unitId).getSheetBySheetId(subUnitId),willRemoveSomeCell=checkCellContentInRanges(worksheet,ranges),removeMergeMutationParams={unitId,subUnitId,ranges},addMergeMutationParams={unitId,subUnitId,ranges};mergeRedos.push({id:sheets.RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}),mergeRedos.push({id:sheets.AddWorksheetMergeMutation.id,params:addMergeMutationParams});const undoRemoveMergeMutationParams=this._injector.invoke(sheets.RemoveMergeUndoMutationFactory,removeMergeMutationParams),undoMutationParams=this._injector.invoke(sheets.AddMergeUndoMutationFactory,addMergeMutationParams);if(mergeUndos.push({id:sheets.RemoveWorksheetMergeMutation.id,params:undoMutationParams}),mergeUndos.push({id:sheets.AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),willRemoveSomeCell){const data=this._injector.invoke(accessor=>getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges));mergeRedos.unshift(...data.redos),mergeUndos.push(...data.undos)}return{undos:[{id:sheets.SetRangeValuesMutation.id,params:clearStyleMutationParams},{id:sheets.SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams},...interceptorUndos,...mergeUndos],redos:[{id:sheets.SetRangeValuesMutation.id,params:clearStyleMutationParams},{id:sheets.SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...interceptorRedos,...mergeRedos]}}},__name(_a33,"FormatPainterController"),_a33);FormatPainterController=__decorateClass$p([__decorateParam$p(0,core.ICommandService),__decorateParam$p(1,IFormatPainterService),__decorateParam$p(2,core.IUniverInstanceService),__decorateParam$p(3,engineRender.IRenderManagerService),__decorateParam$p(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$p(5,core.Inject(sheets.SheetInterceptorService)),__decorateParam$p(6,core.Inject(core.Injector))],FormatPainterController);var __defProp$o=Object.defineProperty,__getOwnPropDesc$o=Object.getOwnPropertyDescriptor,__decorateClass$o=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$o(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$o(target,key,result),result},"__decorateClass$o"),__decorateParam$o=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$o"),_a34;exports.HoverRenderController=(_a34=class extends core.Disposable{constructor(_context,_hoverManagerService,_sheetSkeletonManagerService,_scrollManagerService){super();__publicField(this,"_active",!1);this._context=_context,this._hoverManagerService=_hoverManagerService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._scrollManagerService=_scrollManagerService,this._initPointerEvent(),this._initScrollEvent()}get active(){return this._active}_initPointerEvent(){const disposeSet=new core.DisposableCollection,handleSkeletonChange=__name(skeletonParam=>{if(disposeSet.dispose(),!skeletonParam)return;const{mainComponent,unitId}=this._context;mainComponent&&(disposeSet.add(mainComponent.onPointerEnter$.subscribeEvent(evt=>{this._active=!0})),disposeSet.add(core.fromEventSubject(mainComponent.onPointerMove$).pipe(rxjs.throttleTime(30)).subscribe(evt=>{this._active=!0,this._hoverManagerService.triggerMouseMove(unitId,evt.offsetX,evt.offsetY)})),disposeSet.add(mainComponent.onPointerUp$.subscribeEvent(evt=>{this._hoverManagerService.triggerClick(unitId,evt.offsetX,evt.offsetY)})),disposeSet.add(mainComponent.onPointerLeave$.subscribeEvent(()=>{this._active=!1})))},"handleSkeletonChange");handleSkeletonChange(this._sheetSkeletonManagerService.getCurrent()),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(skeletonParam=>{handleSkeletonChange(skeletonParam)}))}_initScrollEvent(){this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(()=>this._hoverManagerService.triggerScroll()))}},__name(_a34,"HoverRenderController"),_a34);exports.HoverRenderController=__decorateClass$o([__decorateParam$o(1,core.Inject(exports.HoverManagerService)),__decorateParam$o(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$o(3,core.Inject(SheetScrollManagerService))],exports.HoverRenderController);var __defProp$n=Object.defineProperty,__getOwnPropDesc$n=Object.getOwnPropertyDescriptor,__decorateClass$n=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$n(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$n(target,key,result),result},"__decorateClass$n"),__decorateParam$n=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$n"),_a35;let MarkSelectionRenderController=(_a35=class extends core.Disposable{constructor(_context,_markSelectionService,_commandService,_sheetSkeletonManagerService){super(),this._context=_context,this._markSelectionService=_markSelectionService,this._commandService=_commandService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._initListeners()}_initListeners(){this._addRemoveListener(),this._addRefreshListener()}_addRemoveListener(){const removeCommands=[SetCellEditVisibleOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{removeCommands.includes(command.id)?this._markSelectionService.removeAllShapes():this._markSelectionService.getShapeMap().forEach((shape,id)=>{shape.exits.includes(command.id)&&this._markSelectionService.removeShape(id)})}))}_addRefreshListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(skeleton=>{skeleton&&this._markSelectionService.refreshShapes()}))}},__name(_a35,"MarkSelectionRenderController"),_a35);MarkSelectionRenderController=__decorateClass$n([__decorateParam$n(1,core.Inject(IMarkSelectionService)),__decorateParam$n(2,core.ICommandService),__decorateParam$n(3,core.Inject(exports.SheetSkeletonManagerService))],MarkSelectionRenderController);var __defProp$m=Object.defineProperty,__getOwnPropDesc$m=Object.getOwnPropertyDescriptor,__decorateClass$m=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$m(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$m(target,key,result),result},"__decorateClass$m"),__decorateParam$m=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$m"),_a36;let MoveRangeRenderController=(_a36=class extends core.Disposable{constructor(_context,_selectionRenderService,_selectionManagerService,_commandService){super();__publicField(this,"_initialize",__name(()=>{const disposableCollection=new core.DisposableCollection;this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(()=>{disposableCollection.dispose(),this._selectionRenderService.getSelectionControls().forEach(controlSelection=>{disposableCollection.add(core.toDisposable(controlSelection.selectionMoved$.subscribe(_toRange=>{if(!_toRange)return;const _fromRange=controlSelection.model.getRange(),fromRange={startRow:_fromRange.startRow,startColumn:_fromRange.startColumn,endRow:_fromRange.endRow,endColumn:_fromRange.endColumn,rangeType:_fromRange.rangeType},toRange={startRow:_toRange.startRow,startColumn:_toRange.startColumn,endRow:_toRange.endRow,endColumn:_toRange.endColumn,rangeType:_fromRange.rangeType};if(fromRange.startRow===toRange.startRow&&fromRange.startColumn===toRange.startColumn||toRange.startRow<0||toRange.startColumn<0)return;const params={fromRange,toRange};this._commandService.executeCommand(sheets.MoveRangeCommand.id,params)})))})}))},"_initialize"));this._context=_context,this._selectionRenderService=_selectionRenderService,this._selectionManagerService=_selectionManagerService,this._commandService=_commandService,this._initialize()}},__name(_a36,"MoveRangeRenderController"),_a36);MoveRangeRenderController=__decorateClass$m([__decorateParam$m(1,core.Inject(ISheetSelectionRenderService)),__decorateParam$m(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$m(3,core.Inject(core.ICommandService))],MoveRangeRenderController);var __defProp$l=Object.defineProperty,__getOwnPropDesc$l=Object.getOwnPropertyDescriptor,__decorateClass$l=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$l(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$l(target,key,result),result},"__decorateClass$l"),__decorateParam$l=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$l"),_a37;exports.SheetPermissionInitController=(_a37=class extends core.Disposable{constructor(_univerInstanceService,_permissionService,_authzIoService,_rangeProtectionRuleModel,_worksheetProtectionRuleModel,_userManagerService,_worksheetProtectionPointRuleModel,_sheetInterceptorService,_undoRedoService,_commandService,_rangeProtectionCache){super(),this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._authzIoService=_authzIoService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._userManagerService=_userManagerService,this._worksheetProtectionPointRuleModel=_worksheetProtectionPointRuleModel,this._sheetInterceptorService=_sheetInterceptorService,this._undoRedoService=_undoRedoService,this._commandService=_commandService,this._rangeProtectionCache=_rangeProtectionCache,this._initRangePermissionFromSnapshot(),this._initRangePermissionChange(),this._initWorksheetPermissionFromSnapshot(),this._initWorksheetPermissionChange(),this._initWorksheetPermissionPointsChange(),this._initWorkbookPermissionFromSnapshot(),this._initUserChange(),this._initViewModelByRangeInterceptor(),this._initViewModelBySheetInterceptor(),this._refreshPermissionByCollaCreate()}async _initRangePermissionFromSnapshot(){const initRangePermissionFunc=__name(async workbook=>{const allAllowedParams=[],unitId=workbook.getUnitId(),allSheets=workbook.getSheets(),permissionIdWithRuleInstanceMap=new Map;if(allSheets.forEach(sheet=>{const subunitId=sheet.getSheetId();this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subunitId).forEach(rule=>{permissionIdWithRuleInstanceMap.set(rule.permissionId,rule),allAllowedParams.push({objectID:rule.permissionId,unitID:unitId,objectType:L.SelectRange,actions:[D.View,D.Edit]})})}),!allAllowedParams.length){this._rangeProtectionRuleModel.changeRuleInitState(!0);return}this._authzIoService.batchAllowed(allAllowedParams).then(permissionMap=>{permissionMap.forEach(item=>{const rule=permissionIdWithRuleInstanceMap.get(item.objectID);rule&&sheets.getAllRangePermissionPoint().forEach(F=>{const instance=new F(unitId,rule.subUnitId,item.objectID),unitActionName=instance.subType,result=item.actions.find(action=>action.action===unitActionName);(result==null?void 0:result.allowed)!==void 0&&this._permissionService.updatePermissionPoint(instance.id,result.allowed)})}),this._rangeProtectionRuleModel.changeRuleInitState(!0)})},"initRangePermissionFunc");await Promise.all(this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).map(workbook=>initRangePermissionFunc(workbook))),this._rangeProtectionRuleModel.changeRuleInitState(!0)}_initRangePermissionChange(){this.disposeWithMe(this._rangeProtectionRuleModel.ruleChange$.subscribe(info=>{info.type!=="delete"?this._authzIoService.allowed({objectID:info.rule.permissionId,unitID:info.unitId,objectType:L.SelectRange,actions:[D.Edit,D.View]}).then(actionList=>{sheets.getAllRangePermissionPoint().forEach(F=>{if(info.type==="set"){const{rule:rule2,oldRule}=info;if(rule2.permissionId===(oldRule==null?void 0:oldRule.permissionId))return}const rule=info.rule,instance=new F(rule.unitId,rule.subUnitId,rule.permissionId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})}):this._rangeProtectionRuleModel.getSubunitRuleList(info.unitId,info.subUnitId).length===0&&(this._worksheetProtectionPointRuleModel.deleteRule(info.unitId,info.subUnitId),[...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,instance.value)}))}))}async initWorkbookPermissionChange(_unitId){var _a61;const unitId=_unitId||((_a61=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_a61.getUnitId());unitId&&this._authzIoService.allowed({objectID:unitId,objectType:L.Workbook,unitID:unitId,actions:sheets.defaultWorkbookPermissionPoints}).then(actionList=>{sheets.getAllWorkbookPermissionPoint().forEach(F=>{const instance=new F(unitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})})}async _initWorkbookPermissionFromSnapshot(){await Promise.all(this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).map(workbook=>this.initWorkbookPermissionChange(workbook.getUnitId())))}_initWorksheetPermissionChange(){this.disposeWithMe(this._worksheetProtectionRuleModel.ruleChange$.subscribe(info=>{info.type!=="delete"?this._authzIoService.allowed({objectID:info.rule.permissionId,unitID:info.unitId,objectType:L.Worksheet,actions:[D.Edit,D.View]}).then(actionList=>{sheets.getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})}):([...sheets.getAllWorksheetPermissionPoint(),...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,!0)}),this._worksheetProtectionPointRuleModel.deleteRule(info.unitId,info.subUnitId))}))}_initWorksheetPermissionPointsChange(){this.disposeWithMe(this._worksheetProtectionPointRuleModel.pointChange$.subscribe(info=>{this._authzIoService.allowed({objectID:info.permissionId,unitID:info.unitId,objectType:L.Worksheet,actions:sheets.defaultWorksheetPermissionPoint}).then(actionList=>{sheets.getAllWorksheetPermissionPointByPointPanel().forEach(F=>{const instance=new F(info.unitId,info.subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&this._permissionService.updatePermissionPoint(instance.id,action.allowed)})})}))}async _initWorksheetPermissionFromSnapshot(){const initSheetPermissionFunc=__name(async workbook=>{const allAllowedParams=[],unitId=workbook.getUnitId(),allSheets=workbook.getSheets(),permissionIdWithRuleInstanceMap=new Map;if(allSheets.forEach(sheet=>{const subUnitId=sheet.getSheetId(),rule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId);rule&&(permissionIdWithRuleInstanceMap.set(rule.permissionId,rule),allAllowedParams.push({objectID:rule.permissionId,unitID:unitId,objectType:L.Worksheet,actions:[D.Edit,D.View]}));const pointRule=this._worksheetProtectionPointRuleModel.getRule(unitId,subUnitId);pointRule&&(permissionIdWithRuleInstanceMap.set(pointRule.permissionId,pointRule),allAllowedParams.push({objectID:pointRule.permissionId,unitID:unitId,objectType:L.Worksheet,actions:sheets.defaultWorksheetPermissionPoint}))}),!allAllowedParams.length){this._worksheetProtectionRuleModel.changeRuleInitState(!0);return}this._authzIoService.batchAllowed(allAllowedParams).then(permissionMap=>{permissionMap.forEach(item=>{const rule=permissionIdWithRuleInstanceMap.get(item.objectID);rule&&[...sheets.getAllWorksheetPermissionPoint(),...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,rule.subUnitId),unitActionName=instance.subType,result=item.actions.find(action=>action.action===unitActionName);(result==null?void 0:result.allowed)!==void 0&&this._permissionService.updatePermissionPoint(instance.id,result.allowed)})}),this._worksheetProtectionRuleModel.changeRuleInitState(!0)})},"initSheetPermissionFunc");await Promise.all(this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).map(workbook=>initSheetPermissionFunc(workbook))),this._worksheetProtectionRuleModel.changeRuleInitState(!0)}_initUserChange(){this.disposeWithMe(this._userManagerService.currentUser$.pipe(rxjs.skip(1)).subscribe(()=>{const _map=this._permissionService.getAllPermissionPoint();this._permissionService.clearPermissionMap(),this._worksheetProtectionRuleModel.changeRuleInitState(!1),this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>{const unitId=workbook.getUnitId();sheets.getAllWorkbookPermissionPoint().forEach(F=>{let instance=new F(unitId);_map.has(instance.id)&&(instance=_map.get(instance.id)),this._permissionService.addPermissionPoint(instance)}),workbook.getSheets().forEach(sheet=>{const subUnitId=sheet.getSheetId();[...sheets.getAllWorksheetPermissionPoint(),...sheets.getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{let instance=new F(unitId,subUnitId);_map.has(instance.id)&&(instance=_map.get(instance.id)),this._permissionService.addPermissionPoint(instance)}),this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{sheets.getAllRangePermissionPoint().forEach(F=>{let instance=new F(unitId,subUnitId,rule.permissionId);_map.has(instance.id)&&(instance=_map.get(instance.id)),this._permissionService.addPermissionPoint(instance)})})}),this._initWorkbookPermissionFromSnapshot(),this._initWorksheetPermissionFromSnapshot(),this._initRangePermissionFromSnapshot()})}))}_initViewModelByRangeInterceptor(){this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:999,effect:core.InterceptorEffectEnum.Value|core.InterceptorEffectEnum.Style,handler:__name((cell={},context,next)=>{const{unitId,subUnitId,row,col}=context,selectionProtection=this._rangeProtectionCache.getCellInfo(unitId,subUnitId,row,col);if(selectionProtection){const isSkipRender=selectionProtection[D.View]===!1,_cellData={...cell,selectionProtection:[selectionProtection]};return isSkipRender?(delete _cellData.s,delete _cellData.v,delete _cellData.p,_cellData):next(_cellData)}return next(cell)},"handler")}))}_initViewModelBySheetInterceptor(){this.disposeWithMe(this._sheetInterceptorService.intercept(sheets.INTERCEPTOR_POINT.CELL_CONTENT,{priority:999,effect:core.InterceptorEffectEnum.Value|core.InterceptorEffectEnum.Style,handler:__name((cell={},context,next)=>{var _a61,_b,_c,_d,_e;const{unitId,subUnitId}=context,worksheetRule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId);if(worksheetRule!=null&&worksheetRule.permissionId){const selectionProtection=[{[D.View]:(_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorksheetViewPermission(unitId,subUnitId).id))==null?void 0:_a61.value)!=null?_b:!1,[D.Edit]:(_d=(_c=this._permissionService.getPermissionPoint(new sheets.WorksheetEditPermission(unitId,subUnitId).id))==null?void 0:_c.value)!=null?_d:!1}],isSkipRender=!((_e=selectionProtection[0])!=null&&_e[D.View]),_cellData={...cell,hasWorksheetRule:!0,selectionProtection};return isSkipRender?(delete _cellData.s,delete _cellData.v,delete _cellData.p,_cellData):next(_cellData)}return next(cell)},"handler")}))}refreshPermission(unitId,permissionId){const sheetRuleItem=this._worksheetProtectionRuleModel.getTargetByPermissionId(unitId,permissionId);let needClearUndoRedo=!1;if(sheetRuleItem){const[_,subUnitId]=sheetRuleItem;this._authzIoService.allowed({objectID:permissionId,unitID:unitId,objectType:L.Worksheet,actions:[D.Edit,D.View]}).then(actionList=>{let key="";sheets.getAllWorksheetPermissionPoint().forEach(F=>{var _a61;const instance=new F(unitId,subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&(((_a61=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a61.value)!==action.allowed&&(needClearUndoRedo=!0),this._permissionService.updatePermissionPoint(instance.id,action.allowed),key+=`${action.action}_${action.allowed}`)}),this._worksheetProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`),needClearUndoRedo&&this._undoRedoService.clearUndoRedo(unitId)})}const sheetPointItem=this._worksheetProtectionPointRuleModel.getTargetByPermissionId(unitId,permissionId);if(sheetPointItem){const[_,subUnitId]=sheetPointItem;this._authzIoService.allowed({objectID:permissionId,unitID:unitId,objectType:L.Worksheet,actions:sheets.defaultWorksheetPermissionPoint}).then(actionList=>{sheets.getAllWorksheetPermissionPointByPointPanel().forEach(F=>{var _a61;const instance=new F(unitId,subUnitId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&(((_a61=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a61.value)!==action.allowed&&(needClearUndoRedo=!0),this._permissionService.updatePermissionPoint(instance.id,action.allowed))}),needClearUndoRedo&&this._undoRedoService.clearUndoRedo(unitId)})}const rangeRuleItem=this._rangeProtectionRuleModel.getTargetByPermissionId(unitId,permissionId);if(rangeRuleItem){const[_,subUnitId]=rangeRuleItem;this._authzIoService.allowed({objectID:permissionId,unitID:unitId,objectType:L.SelectRange,actions:[D.Edit,D.View]}).then(actionList=>{let key="";sheets.getAllRangePermissionPoint().forEach(F=>{var _a61;const instance=new F(unitId,subUnitId,permissionId),unitActionName=instance.subType,action=actionList.find(item=>item.action===unitActionName);action&&(((_a61=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a61.value)!==action.allowed&&(needClearUndoRedo=!0),this._permissionService.updatePermissionPoint(instance.id,action.allowed),key+=`${action.action}_${action.allowed}`)}),this._rangeProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`),needClearUndoRedo&&this._undoRedoService.clearUndoRedo(unitId)})}}_refreshPermissionByCollaCreate(){this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{if(options!=null&&options.fromCollab&&(command.id===sheets.AddRangeProtectionMutation.id||command.id===sheets.AddWorksheetProtectionMutation.id||command.id===sheets.SetWorksheetPermissionPointsMutation.id)){const params=command.params;this._undoRedoService.clearUndoRedo(params.unitId)}}))}},__name(_a37,"SheetPermissionInitController"),_a37);exports.SheetPermissionInitController=__decorateClass$l([__decorateParam$l(0,core.IUniverInstanceService),__decorateParam$l(1,core.IPermissionService),__decorateParam$l(2,core.IAuthzIoService),__decorateParam$l(3,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$l(4,core.Inject(sheets.WorksheetProtectionRuleModel)),__decorateParam$l(5,core.Inject(core.UserManagerService)),__decorateParam$l(6,core.Inject(sheets.WorksheetProtectionPointModel)),__decorateParam$l(7,core.Inject(sheets.SheetInterceptorService)),__decorateParam$l(8,core.Inject(core.IUndoRedoService)),__decorateParam$l(9,core.Inject(core.ICommandService)),__decorateParam$l(10,core.Inject(sheets.RangeProtectionCache))],exports.SheetPermissionInitController);const UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID="UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID",UNIVER_SHEET_PERMISSION_ALERT_DIALOG="UNIVER_SHEET_PERMISSION_ALERT_DIALOG";var __defProp$k=Object.defineProperty,__getOwnPropDesc$k=Object.getOwnPropertyDescriptor,__decorateClass$k=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$k(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$k(target,key,result),result},"__decorateClass$k"),__decorateParam$k=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$k"),_a38;exports.SheetPermissionInterceptorBaseController=(_a38=class extends core.Disposable{constructor(_commandService,_univerInstanceService,_permissionService,_selectionManagerService,_dialogService,_rangeProtectionRuleModel,_worksheetProtectionRuleModel,_autoFillService,_localeService,_lexerTreeBuilder,_contextService,_definedNamesService){super();__publicField(this,"disposableCollection",new core.DisposableCollection);__publicField(this,"_showPermissionDialog",!0);this._commandService=_commandService,this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._selectionManagerService=_selectionManagerService,this._dialogService=_dialogService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._autoFillService=_autoFillService,this._localeService=_localeService,this._lexerTreeBuilder=_lexerTreeBuilder,this._contextService=_contextService,this._definedNamesService=_definedNamesService,this._initialize()}setShowPermissionDialog(value){this._showPermissionDialog=value}haveNotPermissionHandle(errorMsg){const dialogProps={id:UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID,title:{title:""},children:{label:UNIVER_SHEET_PERMISSION_ALERT_DIALOG,errorMsg},width:320,destroyOnClose:!0,onClose:__name(()=>this._dialogService.close(UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID),"onClose"),className:"sheet-permission-user-dialog"};throw this._showPermissionDialog&&this._dialogService.open(dialogProps),new core.CustomCommandExecutionError("have not permission")}_getPermissionCheck(id,params){var _a61,_b,_c;let permission=!0,errorMsg="";switch(id){case docsUi.InsertCommand.id:case docsUi.IMEInputCommand.id:if(this._contextService.getContextValue(core.FOCUSING_EDITOR_STANDALONE)===!0)break;permission=this.permissionCheckWithoutRange({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.editErr");break;case SetCellEditVisibleOperation.id:if(params.visible===!1)break;permission=this.permissionCheckWithoutRange({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.editErr");break;case sheets.SetRangeValuesCommand.id:core.isICellData(params.value)&&params.value.f?(permission=this._permissionCheckWithFormula(params),errorMsg=this._localeService.t("permission.dialog.formulaErr")):permission=this._permissionCheckBySetRangeValue({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]},params);break;case sheets.ClearSelectionContentCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.editErr");break;case SheetPasteColWidthCommand.id:permission=this.permissionCheckWithoutRange({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission]}),errorMsg=this._localeService.t("permission.dialog.pasteErr");break;case SheetPasteShortKeyCommand.id:permission=this._permissionCheckByPaste(params),errorMsg=this._localeService.t("permission.dialog.pasteErr");break;case ApplyFormatPainterCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission]}),errorMsg=this._localeService.t("permission.dialog.commonErr");break;case sheets.SetBackgroundColorCommand.id:case SetRangeBoldCommand.id:case SetRangeItalicCommand.id:case SetRangeUnderlineCommand.id:case SetRangeStrickThroughCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.setStyleErr");break;case SheetCopyCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookCopyPermission],rangeTypes:[sheets.RangeProtectionPermissionViewPoint],worksheetTypes:[sheets.WorksheetCopyPermission]}),errorMsg=this._localeService.t("permission.dialog.copyErr"),(_a61=this._permissionService.getPermissionPoint(new sheets.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&_a61.value||(errorMsg=this._localeService.t("permission.dialog.workbookCopyErr"));break;case SheetCutCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookCopyPermission,sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionViewPoint,sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetCopyPermission,sheets.WorksheetEditPermission]}),errorMsg=this._localeService.t("permission.dialog.copyErr"),(_b=this._permissionService.getPermissionPoint(new sheets.WorkbookCopyPermission(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).id))!=null&&_b.value||(errorMsg=this._localeService.t("permission.dialog.workbookCopyErr"));break;case sheets.DeltaColumnWidthCommand.id:case sheets.SetColWidthCommand.id:permission=this.permissionCheckWithoutRange({worksheetTypes:[sheets.WorksheetSetColumnStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.DeltaRowHeightCommand.id:case sheets.SetRowHeightCommand.id:case sheets.SetWorksheetRowIsAutoHeightCommand.id:permission=this.permissionCheckWithoutRange({worksheetTypes:[sheets.WorksheetSetRowStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.MoveColsCommand.id:case sheets.MoveRowsCommand.id:permission=this._permissionCheckByMoveCommand(params),errorMsg=this._localeService.t("permission.dialog.moveRowColErr");break;case sheets.MoveRangeCommand.id:permission=this._permissionCheckByMoveRangeCommand(params),errorMsg=this._localeService.t("permission.dialog.moveRangeErr");break;case AutoFillCommand.id:permission=this._permissionCheckByAutoFillCommand((_c=this._autoFillService.autoFillLocation)==null?void 0:_c.target),errorMsg=this._localeService.t("permission.dialog.autoFillErr");break;case sheets.SetWorksheetOrderCommand.id:permission=this._permissionCheckByWorksheetCommand([sheets.WorkbookEditablePermission,sheets.WorkbookMoveSheetPermission]),errorMsg=this._localeService.t("permission.dialog.operatorSheetErr"),permission===!1&&this._worksheetProtectionRuleModel.resetOrder();break;case sheets.SetWorksheetNameCommand.id:permission=this._permissionCheckByWorksheetCommand([sheets.WorkbookEditablePermission,sheets.WorkbookRenameSheetPermission]),errorMsg=this._localeService.t("permission.dialog.operatorSheetErr"),permission===!1&&this._worksheetProtectionRuleModel.resetOrder();break;case sheets.SetWorksheetShowCommand.id:{const{unitId,subUnitId}=params;permission=this._permissionCheckByWorksheetCommand([sheets.WorkbookEditablePermission,sheets.WorkbookHideSheetPermission],unitId,subUnitId),errorMsg=this._localeService.t("permission.dialog.operatorSheetErr"),permission===!1&&this._worksheetProtectionRuleModel.resetOrder()}break;case sheets.SetSpecificColsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission]},params.ranges),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.SetSpecificRowsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission]},params.ranges),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.SetSelectedColsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.SetSelectedRowsVisibleCommand.id:permission=this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission]}),errorMsg=this._localeService.t("permission.dialog.setRowColStyleErr");break;case sheets.InsertRangeMoveRightCommand.id:permission=this._permissionCheckWithInsertRangeMove("right"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break;case sheets.InsertRangeMoveDownCommand.id:permission=this._permissionCheckWithInsertRangeMove("bottom"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break;case sheets.DeleteRangeMoveLeftCommand.id:permission=this._permissionCheckWithInsertRangeMove("left"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break;case sheets.DeleteRangeMoveUpCommand.id:permission=this._permissionCheckWithInsertRangeMove("top"),errorMsg=this._localeService.t("permission.dialog.insertOrDeleteMoveRangeErr");break}permission||this.haveNotPermissionHandle(errorMsg)}_initialize(){this._commandExecutedListener()}_commandExecutedListener(){this.disposeWithMe(this._commandService.beforeCommandExecuted(command=>{this._getPermissionCheck(command.id,command==null?void 0:command.params)})),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{var _a61;if(command.id===sheets.SetWorksheetNameMutation.id){const params=command.params,{unitId=(_a61=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_a61.getUnitId(),subUnitId}=params;if(!unitId||!subUnitId)return;const worksheetRule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId),selectionRuleList=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId);worksheetRule&&this._worksheetProtectionRuleModel.ruleRefresh(worksheetRule.permissionId),selectionRuleList.length&&this._rangeProtectionRuleModel.ruleRefresh(subUnitId)}}))}_permissionCheckWithInsertRangeMove(direction){var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,selectionRange=core.Tools.deepClone((_a61=this._selectionManagerService.getCurrentLastSelection())==null?void 0:_a61.range);return!(!selectionRange||(direction==="top"||direction==="bottom"?selectionRange.endRow=worksheet.getRowCount()-1:(direction==="left"||direction==="right")&&(selectionRange.endColumn=worksheet.getColumnCount()-1),this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).map(rule=>rule.ranges).flat().some(range=>core.Rectangle.getIntersects(selectionRange,range))))}_permissionCheckByWorksheetCommand(types,targetUnitId,targetSubUnitId){var _a61,_b;const target=sheets.getSheetCommandTarget(this._univerInstanceService,{unitId:targetUnitId,subUnitId:targetSubUnitId});if(!target)return!1;const{unitId,subUnitId}=target,worksheetRule=this._worksheetProtectionRuleModel.getRule(unitId,subUnitId),selectionRule=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).length>0;return worksheetRule||selectionRule?(_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_a61.value)!=null?_b:!1:this._permissionService.composePermission(types.map(F=>new F(unitId).id)).every(permission=>permission.value)}permissionCheckWithoutRange(permissionTypes){var _a61,_b,_c,_d;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,selection=this._selectionManagerService.getCurrentLastSelection();if(!selection)return!0;const row=(_b=(_a61=selection==null?void 0:selection.primary)==null?void 0:_a61.actualRow)!=null?_b:0,col=(_d=(_c=selection==null?void 0:selection.primary)==null?void 0:_c.actualColumn)!=null?_d:0,{workbookTypes,worksheetTypes,rangeTypes}=permissionTypes;return!(workbookTypes&&workbookTypes.some(F=>{var _a62,_b2;const instance=new F(unitId);return((_b2=(_a62=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a62.value)!=null?_b2:!1)===!1})===!0||worksheetTypes&&worksheetTypes.some(F=>{var _a62,_b2;const instance=new F(unitId,subUnitId);return((_b2=(_a62=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_a62.value)!=null?_b2:!1)===!1})===!0||rangeTypes&&rangeTypes.some(F=>{var _a62,_b2,_c2,_d2,_e;const cellInfo=(_b2=(_a62=worksheet.getCell(row,col))==null?void 0:_a62.selectionProtection)==null?void 0:_b2[0];if(!(cellInfo!=null&&cellInfo.ruleId))return!1;const permissionId=(_c2=this._rangeProtectionRuleModel.getRule(unitId,subUnitId,cellInfo.ruleId))==null?void 0:_c2.permissionId;if(!permissionId)return!1;const instance=new F(unitId,subUnitId,permissionId);return((_e=(_d2=this._permissionService.getPermissionPoint(instance.id))==null?void 0:_d2.value)!=null?_e:!1)===!1})===!0)}permissionCheckWithRanges(permissionTypes,selectionRanges,unitId,subUnitId){var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{workbook,worksheet}=target;unitId||(unitId=workbook.getUnitId()),subUnitId||(subUnitId=worksheet.getSheetId());const ranges=selectionRanges!=null?selectionRanges:(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range);if(!ranges)return!1;const{workbookTypes,worksheetTypes,rangeTypes}=permissionTypes,permissionIds=[];return workbookTypes&&permissionIds.push(...workbookTypes.map(F=>new F(unitId).id)),worksheetTypes&&permissionIds.push(...worksheetTypes.map(F=>new F(unitId,subUnitId).id)),rangeTypes&&this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{ranges.some(range=>rule.ranges.some(r2=>core.Rectangle.intersects(r2,range)))&&permissionIds.push(...rangeTypes.map(F=>new F(unitId,subUnitId,rule.permissionId).id))}),permissionIds.length?this._permissionService.composePermission(permissionIds).every(permission=>permission.value):!0}_permissionCheckByPaste(params){return params.value===PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE||params.value===PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMULA?this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]}):params.value===PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT?this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]}):this.permissionCheckWithRanges({workbookTypes:[sheets.WorkbookEditablePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission]})}_permissionCheckByMoveCommand(params){const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,toRange=params.toRange;toRange.endRow===worksheet.getRowCount()-1?toRange.endColumn=toRange.startColumn:toRange.endRow=toRange.startRow;const permissionLapRanges=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]).filter(range=>core.Rectangle.intersects(range,toRange));return permissionLapRanges.length>0?!1:(permissionLapRanges.forEach(range=>{var _a61,_b;for(let row=range.startRow;row<=range.endRow;row++)for(let col=range.startColumn;col<=range.endColumn;col++){const permission=(_b=(_a61=worksheet.getCell(row,col))==null?void 0:_a61.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!1}}),!0)}_permissionCheckByAutoFillCommand(params){if(!params)return!1;const{rows,cols}=params,startRow=rows[0],endRow=rows[rows.length-1],startCol=cols[0],endCol=cols[cols.length-1],targetRange={startRow,endRow,startColumn:startCol,endColumn:endCol},target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;return!this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]).filter(range=>core.Rectangle.intersects(range,targetRange)).some(range=>{var _a61,_b;for(let row=range.startRow;row<=range.endRow;row++)for(let col=range.startColumn;col<=range.endColumn;col++){const permission=(_b=(_a61=worksheet.getCell(row,col))==null?void 0:_a61.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!0}return!1})}_permissionCheckByMoveRangeCommand(params){const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,toRange=params.toRange,permissionLapRanges=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]).filter(range=>core.Rectangle.intersects(range,toRange));return permissionLapRanges.length>0?!1:(permissionLapRanges.forEach(range=>{var _a61,_b;for(let row=range.startRow;row<=range.endRow;row++)for(let col=range.startColumn;col<=range.endColumn;col++){const permission=(_b=(_a61=worksheet.getCell(row,col))==null?void 0:_a61.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!1}}),!0)}_permissionCheckBySetRangeValue(permissionTypes,setRangeValueParams){let ranges=[];setRangeValueParams.range?ranges=[setRangeValueParams.range]:ranges=[new core.ObjectMatrix(setRangeValueParams.value).getDataRange()];const{unitId,subUnitId}=setRangeValueParams;return this.permissionCheckWithRanges(permissionTypes,ranges,unitId,subUnitId)}_permissionCheckWithFormula(params){var _a61,_b,_c,_d,_e;const value=params.value,range=params.range,formulaString=value.f;if(formulaString){const definedNameStr=formulaString.substring(1),workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=(_a61=params.unitId)!=null?_a61:workbook.getUnitId(),definedName2=this._definedNamesService.getValueByName(unitId,definedNameStr);if(definedName2){let formulaOrRefString=definedName2.formulaOrRefString;formulaOrRefString.startsWith(engineFormula.operatorToken.EQUALS)&&(formulaOrRefString=formulaOrRefString.slice(1));const refRangesArr=formulaOrRefString.split(",");for(let i=0;i<refRangesArr.length;i++){const refRange=refRangesArr[i],sequenceGrid=engineFormula.deserializeRangeWithSheet(refRange);if(sequenceGrid.sheetName){const targetSheet=workbook.getSheetBySheetName(sequenceGrid.sheetName);if(!targetSheet)return!0;const{startRow,endRow,startColumn,endColumn}=sequenceGrid.range;for(let i2=startRow;i2<=endRow;i2++)for(let j=startColumn;j<=endColumn;j++){const permission=(_c=(_b=targetSheet.getCell(i2,j))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[D.View])===!1)return!1}}}return!0}else{const sequenceNodes=this._lexerTreeBuilder.sequenceNodesBuilder(formulaString);if(!sequenceNodes)return!0;for(let i=0;i<sequenceNodes.length;i++){const node=sequenceNodes[i];if(typeof node=="string"||node.nodeType!==engineFormula.sequenceNodeType.REFERENCE)continue;const{token}=node,sequenceGrid=engineFormula.deserializeRangeWithSheet(token),workbook2=sequenceGrid.unitId?this._univerInstanceService.getUnit(sequenceGrid.unitId):this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook2)return!0;let targetSheet=sequenceGrid.sheetName?workbook2.getSheetBySheetName(sequenceGrid.sheetName):workbook2.getActiveSheet();const unitId2=workbook2.getUnitId();if(sequenceGrid.sheetName){if(targetSheet=workbook2.getSheetBySheetName(sequenceGrid.sheetName),!targetSheet)return!0;const subUnitId=targetSheet==null?void 0:targetSheet.getSheetId();if(!this._permissionService.getPermissionPoint(new sheets.WorksheetViewPermission(unitId2,subUnitId).id))return!1}if(!targetSheet)return!0;const{startRow,endRow,startColumn,endColumn}=sequenceGrid.range;for(let i2=startRow;i2<=endRow;i2++)for(let j=startColumn;j<=endColumn;j++){const permission=(_e=(_d=targetSheet.getCell(i2,j))==null?void 0:_d.selectionProtection)==null?void 0:_e[0];if((permission==null?void 0:permission[D.View])===!1)return!1}}return!0}}if(range){const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const unitId=params.unitId||target.unitId,subunitId=params.subUnitId||target.subUnitId,permissionIds=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subunitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(ruleRange,range))).map(rule=>new sheets.RangeProtectionPermissionEditPoint(unitId,subunitId,rule.permissionId).id);if(!this._permissionService.composePermission(permissionIds).every(permission=>permission.value))return!1}return!0}},__name(_a38,"SheetPermissionInterceptorBaseController"),_a38);exports.SheetPermissionInterceptorBaseController=__decorateClass$k([__decorateParam$k(0,core.ICommandService),__decorateParam$k(1,core.IUniverInstanceService),__decorateParam$k(2,core.IPermissionService),__decorateParam$k(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$k(4,ui.IDialogService),__decorateParam$k(5,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$k(6,core.Inject(sheets.WorksheetProtectionRuleModel)),__decorateParam$k(7,IAutoFillService),__decorateParam$k(8,core.Inject(core.LocaleService)),__decorateParam$k(9,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$k(10,core.IContextService),__decorateParam$k(11,engineFormula.IDefinedNamesService)],exports.SheetPermissionInterceptorBaseController);var __defProp$j=Object.defineProperty,__getOwnPropDesc$j=Object.getOwnPropertyDescriptor,__decorateClass$j=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$j(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$j(target,key,result),result},"__decorateClass$j"),__decorateParam$j=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$j");const FREEZE_ROW_MAIN_NAME="__SpreadsheetFreezeRowMainName__",FREEZE_ROW_HEADER_NAME="__SpreadsheetFreezeRowHeaderName__",FREEZE_COLUMN_MAIN_NAME="__SpreadsheetFreezeColumnMainName__",FREEZE_COLUMN_HEADER_NAME="__SpreadsheetFreezeColumnHeaderName__",FREEZE_SIZE_NORMAL=2,AUXILIARY_CLICK_HIDDEN_OBJECT_TRANSPARENCY=.01,FREEZE_PERMISSION_CHECK=core.createInterceptorKey("freezePermissionCheck");var _a39;exports.HeaderFreezeRenderController=(_a39=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService,_selectionManagerService,_scrollManagerService,_themeService,_sheetInterceptorService,_injector){super();__publicField(this,"_rowFreezeHeaderRect");__publicField(this,"_rowFreezeMainRect");__publicField(this,"_columnFreezeHeaderRect");__publicField(this,"_columnFreezeMainRect");__publicField(this,"_freezeDownSubs");__publicField(this,"_freezePointerEnterSubs");__publicField(this,"_freezePointerLeaveSubs");__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_changeToRow",-1);__publicField(this,"_changeToColumn",-1);__publicField(this,"_changeToOffsetX",0);__publicField(this,"_changeToOffsetY",0);__publicField(this,"_activeViewport",null);__publicField(this,"_freezeNormalHeaderColor","");__publicField(this,"_freezeNormalMainColor","");__publicField(this,"_freezeActiveColor","");__publicField(this,"_freezeHoverColor","");__publicField(this,"_lastFreeze");__publicField(this,"interceptor",new core.InterceptorManager({FREEZE_PERMISSION_CHECK}));this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._selectionManagerService=_selectionManagerService,this._scrollManagerService=_scrollManagerService,this._themeService=_themeService,this._sheetInterceptorService=_sheetInterceptorService,this._injector=_injector,this._initialize()}dispose(){super.dispose()}_initialize(){this._skeletonListener(),this._commandExecutedListener(),this._themeChangeListener(),this._interceptorCommands(),this._bindViewportScroll(),this._zoomRefresh()}_createFreeze(freezeDirectionType=0,freezeConfig){var _a61;const config=freezeConfig!=null?freezeConfig:this._getFreeze();if(config==null)return null;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton,{startRow:freezeRow,startColumn:freezeColumn}=config,position=this._getPositionByIndex(freezeRow,freezeColumn);if(position==null||skeleton==null)return null;const sheetObject=this._getSheetObject(),engine=sheetObject.engine,canvasMaxWidth=(engine==null?void 0:engine.width)||0,canvasMaxHeight=(engine==null?void 0:engine.height)||0,scene=sheetObject.scene,{startX,startY}=position,{rowTotalHeight,columnTotalWidth,rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,shapeWidth=canvasMaxWidth>columnTotalWidth+rowHeaderWidthAndMarginLeft?canvasMaxWidth:columnTotalWidth+columnHeaderHeightAndMarginTop,shapeHeight=canvasMaxHeight>rowTotalHeight+columnHeaderHeightAndMarginTop?canvasMaxHeight:rowTotalHeight+columnHeaderHeightAndMarginTop;this._changeToRow=freezeRow,this._changeToColumn=freezeColumn,this._changeToOffsetX=startX,this._changeToOffsetY=startY;const scale=Math.max(scene.scaleX,scene.scaleY);let FREEZE_SIZE=FREEZE_SIZE_NORMAL/(scale<1?1:scale);if(freezeDirectionType===0){(freezeRow===-1||freezeRow===0)&&(FREEZE_SIZE=FREEZE_SIZE*2);const FREEZE_OFFSET=FREEZE_SIZE;this._rowFreezeHeaderRect=new engineRender.Rect(FREEZE_ROW_HEADER_NAME,{fill:this._freezeNormalHeaderColor,width:rowHeaderWidthAndMarginLeft,height:FREEZE_SIZE,left:0,top:startY-FREEZE_OFFSET,zIndex:3});let fill=this._freezeNormalHeaderColor;(freezeRow===-1||freezeRow===0)&&(fill=this._freezeNormalMainColor),this._rowFreezeMainRect=new engineRender.Rect(FREEZE_ROW_MAIN_NAME,{fill,width:shapeWidth*2/scale,height:FREEZE_SIZE,left:rowHeaderWidthAndMarginLeft,top:startY-FREEZE_OFFSET,zIndex:3}),scene.addObjects([this._rowFreezeHeaderRect,this._rowFreezeMainRect],SHEET_COMPONENT_HEADER_LAYER_INDEX)}else{(freezeColumn===-1||freezeColumn===0)&&(FREEZE_SIZE=FREEZE_SIZE*2);const FREEZE_OFFSET=FREEZE_SIZE;this._columnFreezeHeaderRect=new engineRender.Rect(FREEZE_COLUMN_HEADER_NAME,{fill:this._freezeNormalHeaderColor,width:FREEZE_SIZE,height:columnHeaderHeightAndMarginTop,left:startX-FREEZE_OFFSET,top:0,zIndex:3});let fill=this._freezeNormalHeaderColor;(freezeColumn===-1||freezeColumn===0)&&(fill=this._freezeNormalMainColor),this._columnFreezeMainRect=new engineRender.Rect(FREEZE_COLUMN_MAIN_NAME,{fill,width:FREEZE_SIZE,height:shapeHeight*2/scale,left:startX-FREEZE_OFFSET,top:columnHeaderHeightAndMarginTop,zIndex:3}),scene.addObjects([this._columnFreezeHeaderRect,this._columnFreezeMainRect],SHEET_COMPONENT_HEADER_LAYER_INDEX)}this._eventBinding(freezeDirectionType)}_eventBinding(freezeDirectionType=0){let freezeObjectHeaderRect=this._rowFreezeHeaderRect,freezeObjectMainRect=this._rowFreezeMainRect;freezeDirectionType===1&&(freezeObjectHeaderRect=this._columnFreezeHeaderRect,freezeObjectMainRect=this._columnFreezeMainRect);const sheetObject=this._getSheetObject();if(sheetObject==null)return;const{scene}=sheetObject;if(this._freezePointerEnterSubs=new rxjs.Subscription,this._freezePointerLeaveSubs=new rxjs.Subscription,this._freezeDownSubs=new rxjs.Subscription,freezeObjectMainRect){const _freezeObjectMainRectEnterSub=freezeObjectMainRect.onPointerEnter$.subscribeEvent(()=>{if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeHoverColor,zIndex:4}),scene.setCursor(engineRender.CURSOR_TYPE.GRAB)});this._freezePointerEnterSubs.add(_freezeObjectMainRectEnterSub);const _freezeObjectMainPointerLeaveSub=freezeObjectMainRect.onPointerLeave$.subscribeEvent(()=>{freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor,zIndex:3}),scene.resetCursor()});this._freezePointerLeaveSubs.add(_freezeObjectMainPointerLeaveSub)}if(freezeObjectHeaderRect){const _freezeObjHeaderPointerEnterSub=freezeObjectHeaderRect.onPointerEnter$.subscribeEvent(()=>{if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeHoverColor,zIndex:4}),scene.setCursor(engineRender.CURSOR_TYPE.GRAB)});this._freezePointerEnterSubs.add(_freezeObjHeaderPointerEnterSub);const _freezeObjHeaderPointerLeaveSub=freezeObjectHeaderRect.onPointerLeave$.subscribeEvent(()=>{freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor,zIndex:3}),scene.resetCursor()});this._freezePointerLeaveSubs.add(_freezeObjHeaderPointerLeaveSub)}const s1=freezeObjectHeaderRect==null?void 0:freezeObjectHeaderRect.onPointerDown$.subscribeEvent(evt=>{this._freezeDown(evt,freezeObjectHeaderRect,freezeObjectMainRect,freezeDirectionType)});s1&&this._freezeDownSubs.add(s1);const s2=freezeObjectMainRect==null?void 0:freezeObjectMainRect.onPointerDown$.subscribeEvent(evt=>{this._freezeDown(evt,freezeObjectHeaderRect,freezeObjectMainRect,freezeDirectionType)});s2&&this._freezeDownSubs.add(s2)}_getCurrentLastVisible(){var _a61,_b,_c,_d,_e,_f,_g;const sheetObject=this._getSheetObject();if(sheetObject==null)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const scene=sheetObject.scene,scale=Math.max(scene.scaleX,scene.scaleY),currentScroll=this._scrollManagerService.getCurrentScrollState(),skeletonViewHeight=(sheetObject.engine.height-skeleton.columnHeaderHeight)/scale,skeletonViewWidth=(sheetObject.engine.width-skeleton.rowHeaderWidth)/scale,startRow=(_b=currentScroll==null?void 0:currentScroll.sheetViewStartRow)!=null?_b:0,startHeight=startRow===0?-((_c=currentScroll==null?void 0:currentScroll.offsetY)!=null?_c:0):skeleton.rowHeightAccumulation[startRow-1]-((_d=currentScroll==null?void 0:currentScroll.offsetY)!=null?_d:0);let lastRow=0,hadFind=!1;for(let i=startRow,len=skeleton.rowHeightAccumulation.length;i<len;i++)if(skeleton.rowHeightAccumulation[i]-startHeight>skeletonViewHeight){lastRow=i,hadFind=!0;break}hadFind||(lastRow=skeleton.rowHeightAccumulation.length-1);const startColumn=(_e=currentScroll==null?void 0:currentScroll.sheetViewStartColumn)!=null?_e:0,startWidth=startColumn===0?-((_f=currentScroll==null?void 0:currentScroll.offsetX)!=null?_f:0):skeleton.columnWidthAccumulation[startColumn-1]-((_g=currentScroll==null?void 0:currentScroll.offsetX)!=null?_g:0);let lastColumn=0,hadFindCol=!1;for(let i=startColumn,len=skeleton.columnWidthAccumulation.length;i<len;i++)if(skeleton.columnWidthAccumulation[i]-startWidth>skeletonViewWidth){lastColumn=i,hadFindCol=!0;break}return hadFindCol||(lastColumn=skeleton.columnWidthAccumulation.length-1),{lastRow,lastColumn}}_getActiveViewport(evt){var _a61;const viewports=(_a61=this._getSheetObject())==null?void 0:_a61.scene.getViewports();return viewports&&viewports.find(i=>i.isHit(new engineRender.Vector2(evt.offsetX,evt.offsetY)))||null}_freezeDown(evt,freezeObjectHeaderRect,freezeObjectMainRect,freezeDirectionType=0){var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const sheetObject=this._getSheetObject();if(sheetObject==null)return;if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;const{scene}=sheetObject;scene.setCursor(engineRender.CURSOR_TYPE.GRABBING),scene.disableObjectsEvent();const last=this._getCurrentLastVisible(),lastRowY=last===void 0?Number.POSITIVE_INFINITY:skeleton.rowHeightAccumulation[last.lastRow],lastColumnX=last===void 0?Number.POSITIVE_INFINITY:skeleton.columnWidthAccumulation[last.lastColumn-1]+skeleton.rowHeaderWidth;this._activeViewport=null;const oldFreeze=this._getFreeze();oldFreeze&&(this._changeToColumn=oldFreeze.startColumn,this._changeToRow=oldFreeze.startRow),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a62,_b,_c,_d;const activeViewport=this._getActiveViewport(moveEvt),{startX,startY,row,column}=getCoordByOffset(moveEvt.offsetX,moveEvt.offsetY,scene,skeleton,activeViewport||void 0,!0);if(!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0,null))return!1;scene.setCursor(engineRender.CURSOR_TYPE.GRABBING);const FREEZE_SIZE=FREEZE_SIZE_NORMAL/Math.max(scene.scaleX,scene.scaleY);freezeDirectionType===0?((_a62=freezeObjectHeaderRect.transformByState({top:Math.min(startY,lastRowY)-FREEZE_SIZE/2}))==null||_a62.setProps({fill:this._freezeActiveColor}),(_b=freezeObjectMainRect.transformByState({top:Math.min(startY,lastRowY)-FREEZE_SIZE/2}))==null||_b.setProps({fill:this._freezeNormalHeaderColor}),this._changeToRow=last===void 0?row:Math.min(row,last.lastRow),this._changeToOffsetY=Math.min(startY,lastRowY),this._activeViewport=activeViewport):((_c=freezeObjectHeaderRect.transformByState({left:Math.min(startX,lastColumnX)-FREEZE_SIZE/2}))==null||_c.setProps({fill:this._freezeActiveColor}),(_d=freezeObjectMainRect.transformByState({left:Math.min(startX,lastColumnX)-FREEZE_SIZE/2}))==null||_d.setProps({fill:this._freezeNormalHeaderColor}),this._changeToColumn=last===void 0?column:Math.min(column,last.lastColumn),this._changeToOffsetX=startX,this._activeViewport=activeViewport)}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a62,_b;scene.resetCursor(),scene.enableObjectsEvent(),this._clearObserverEvent();const{rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton;freezeDirectionType===0&&(this._changeToRow===0||this._changeToRow===-1)||freezeDirectionType===1&&(this._changeToColumn===0||this._changeToColumn===-1)?(freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor}),freezeObjectMainRect.setProps({fill:this._freezeNormalMainColor})):(freezeObjectHeaderRect==null||freezeObjectHeaderRect.setProps({fill:this._freezeNormalHeaderColor}),freezeObjectMainRect==null||freezeObjectMainRect.setProps({fill:this._freezeNormalHeaderColor}));const FREEZE_SIZE=FREEZE_SIZE_NORMAL/Math.max(scene.scaleX,scene.scaleY);freezeDirectionType===0?(this._changeToRow===0||this._changeToRow===-1)&&(freezeObjectHeaderRect.transformByState({top:columnHeaderHeightAndMarginTop-FREEZE_SIZE}),freezeObjectMainRect.transformByState({top:columnHeaderHeightAndMarginTop-FREEZE_SIZE})):(this._changeToColumn===0||this._changeToColumn===-1)&&(freezeObjectHeaderRect.transformByState({left:rowHeaderWidthAndMarginLeft-FREEZE_SIZE}),freezeObjectMainRect.transformByState({left:rowHeaderWidthAndMarginLeft-FREEZE_SIZE}));const sheetViewScroll=this._scrollManagerService.getCurrentScrollState()||{sheetViewStartRow:0,sheetViewStartColumn:0},{sheetViewStartRow,sheetViewStartColumn}=sheetViewScroll;if(sheetViewStartColumn==null||sheetViewStartRow==null)return;const workbook=this._context.unit,worksheet=workbook.getActiveSheet();if(!worksheet)return;const oldFreeze2=(_a62=worksheet.getConfig())==null?void 0:_a62.freeze;let xSplit=(oldFreeze2==null?void 0:oldFreeze2.xSplit)||0,ySplit=(oldFreeze2==null?void 0:oldFreeze2.ySplit)||0;const viewPortKey=(_b=this._activeViewport)==null?void 0:_b.viewportKey;freezeDirectionType===0&&(!viewPortKey||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP?ySplit=this._changeToRow-(oldFreeze2.startRow-oldFreeze2.ySplit):ySplit=this._changeToRow-sheetViewStartRow,ySplit=ySplit<0?0:ySplit),freezeDirectionType===1&&(!viewPortKey||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT||viewPortKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT?xSplit=this._changeToColumn-(oldFreeze2.startColumn-oldFreeze2.xSplit):xSplit=this._changeToColumn-sheetViewStartColumn,xSplit=xSplit<0?0:xSplit),this._commandService.executeCommand(sheets.SetFrozenCommand.id,{startRow:ySplit===0?-1:this._changeToRow,startColumn:xSplit===0?-1:this._changeToColumn,ySplit,xSplit,unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId()})})}_getViewports(){const sheetObject=this._getSheetObject();if(sheetObject==null)return;const{scene}=sheetObject,viewColumnLeft=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT),viewColumnRight=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT),viewRowTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP),viewRowBottom=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM),viewLeftTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP),viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),viewMainLeftTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP),viewMainLeft=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT),viewMainTop=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP);if(!(viewColumnLeft==null||viewColumnRight==null||viewRowTop==null||viewRowBottom==null||viewLeftTop==null||viewMain==null||viewMainLeftTop==null||viewMainLeft==null||viewMainTop==null))return{viewMain,viewMainLeftTop,viewMainLeft,viewMainTop,viewColumnLeft,viewColumnRight,viewRowTop,viewRowBottom,viewLeftTop}}_bindViewportScroll(){const viewports=this._getViewports();if(!viewports)return;const{viewRowBottom,viewColumnRight,viewMainLeft,viewMainTop}=viewports;this.disposeWithMe(this._scrollManagerService.validViewportScrollInfo$.subscribe(param=>{if(!param)return;const{scrollX,scrollY,viewportScrollX,viewportScrollY}=param;viewRowBottom.isActive&&viewRowBottom.updateScrollVal({scrollY,viewportScrollY}),viewColumnRight.isActive&&viewColumnRight.updateScrollVal({scrollX,viewportScrollX}),viewMainLeft.isActive&&viewMainLeft.updateScrollVal({scrollY,viewportScrollY}),viewMainTop.isActive&&viewMainTop.updateScrollVal({scrollX,viewportScrollX})}))}_updateViewport(row=-1,column=-1,ySplit=0,xSplit=0,resetScroll=3){var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const{rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,viewports=this._getViewports();if(!viewports)return;const{viewMain,viewMainLeftTop,viewMainLeft,viewMainTop,viewColumnLeft,viewColumnRight,viewRowTop,viewRowBottom,viewLeftTop}=viewports;viewColumnRight.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:0,height:columnHeaderHeightAndMarginTop,right:0}),viewRowBottom.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop,bottom:0,width:rowHeaderWidthAndMarginLeft}),viewLeftTop.resizeWhenFreezeChange({left:0,top:0,width:rowHeaderWidthAndMarginLeft,height:columnHeaderHeightAndMarginTop});let isTopView=!0,isLeftView=!0;viewMainLeftTop.enable(),(row===-1||row===0)&&(isTopView=!1),(column===-1||column===0)&&(isLeftView=!1);const startSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(row-ySplit,column-xSplit),endSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(row,column);if(viewMainLeftTop.disable(),viewMainTop.disable(),viewMainLeft.disable(),viewRowTop.disable(),viewColumnLeft.disable(),viewMainLeftTop.resetPadding(),viewMainTop.resetPadding(),viewMainLeft.resetPadding(),viewRowTop.resetPadding(),viewColumnLeft.resetPadding(),isTopView===!1&&isLeftView===!1)viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,bottom:0,right:0}),viewMain.resetPadding();else if(isTopView===!0&&isLeftView===!1){const topGap=endSheetView.startY-startSheetView.startY;viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,right:0}),viewMain.setPadding({startY:startSheetView.startY,endY:endSheetView.startY,startX:0,endX:0}),resetScroll&2&&this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartRow:0,offsetY:0}),viewMainTop.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,height:topGap,right:0}),viewMainTop.updateScrollVal({viewportScrollY:startSheetView.startY,rawScrollX:viewMain.scrollX,viewportScrollX:viewMain.viewportScrollX}),viewRowTop.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop,width:rowHeaderWidthAndMarginLeft,height:topGap}),viewRowTop.updateScrollVal({viewportScrollY:startSheetView.startY}),viewRowBottom.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,width:rowHeaderWidthAndMarginLeft}),viewMainTop.enable(),viewRowTop.enable()}else if(isTopView===!1&&isLeftView===!0){const leftGap=endSheetView.startX-startSheetView.startX;viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:columnHeaderHeightAndMarginTop,bottom:0,right:0}),viewMain.setPadding({startX:startSheetView.startX,endX:endSheetView.startX,startY:0,endY:0}),resetScroll&1&&this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartColumn:0,offsetX:0}),viewMainLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,width:leftGap,bottom:0,right:0}),viewMainLeft.updateScrollVal({viewportScrollX:startSheetView.startX,rawScrollY:viewMain.scrollY,viewportScrollY:viewMain.viewportScrollY}),viewColumnLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:0,width:leftGap,height:columnHeaderHeightAndMarginTop}),viewColumnLeft.updateScrollVal({viewportScrollX:startSheetView.startX}),viewColumnRight.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:0,height:columnHeaderHeightAndMarginTop,right:0}),viewMainLeft.enable(),viewColumnLeft.enable()}else{const leftGap=endSheetView.startX-startSheetView.startX,topGap=endSheetView.startY-startSheetView.startY;viewMain.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,right:0}),viewMain.setPadding({startY:startSheetView.startY,endY:endSheetView.startY,startX:startSheetView.startX,endX:endSheetView.startX}),resetScroll&&this._commandService.executeCommand(ScrollCommand.id,{...resetScroll&1?{sheetViewStartColumn:0,offsetX:0}:null,...resetScroll&2?{sheetViewStartRow:0,offsetY:0}:null}),viewMainLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop+topGap,width:leftGap,bottom:0}),viewMainLeft.updateScrollVal({viewportScrollX:startSheetView.startX,rawScrollY:viewMain.scrollY,viewportScrollY:viewMain.viewportScrollY}),viewMainTop.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:columnHeaderHeightAndMarginTop,height:topGap,right:0}),viewMainTop.updateScrollVal({viewportScrollY:startSheetView.startY,rawScrollX:viewMain.scrollX,viewportScrollX:viewMain.viewportScrollX}),viewMainLeftTop.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:columnHeaderHeightAndMarginTop,width:leftGap,height:topGap}),viewMainLeftTop.updateScrollVal({viewportScrollX:startSheetView.startX,viewportScrollY:startSheetView.startY}),viewRowTop.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop,width:rowHeaderWidthAndMarginLeft,height:topGap}),viewRowTop.updateScrollVal({viewportScrollY:startSheetView.startY}),viewRowBottom.resizeWhenFreezeChange({left:0,top:columnHeaderHeightAndMarginTop+topGap,bottom:0,width:rowHeaderWidthAndMarginLeft}),viewColumnLeft.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft,top:0,width:leftGap,height:columnHeaderHeightAndMarginTop}),viewColumnLeft.updateScrollVal({viewportScrollX:startSheetView.startX}),viewColumnRight.resizeWhenFreezeChange({left:rowHeaderWidthAndMarginLeft+leftGap,top:0,height:columnHeaderHeightAndMarginTop,right:0}),viewMainLeftTop.enable(),viewMainTop.enable(),viewMainLeft.enable(),viewRowTop.enable(),viewColumnLeft.enable()}}_skeletonListener(){this.disposeWithMe(core.toDisposable(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{[sheets.SetWorksheetActiveOperation.id,sheets.InsertRangeMoveDownCommand.id,sheets.InsertRangeMoveRightCommand.id].includes((param==null?void 0:param.commandId)||"")&&this._refreshCurrent()})))}_refreshCurrent(){const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const freeze=worksheet.getConfig().freeze,{startRow=-1,startColumn=-1,ySplit=0,xSplit=0}=freeze;this._refreshFreeze(startRow,startColumn,ySplit,xSplit,0)}_themeChangeListener(){this._themeChange(this._themeService.getCurrentTheme()),this.disposeWithMe(this._themeService.currentTheme$.subscribe(style=>{this._clearFreeze(),this._themeChange(style),this._refreshCurrent()}))}_themeChange(style){this._freezeNormalHeaderColor=style.grey400,this._freezeNormalMainColor=new core.ColorKit(style.grey400).setAlpha(AUXILIARY_CLICK_HIDDEN_OBJECT_TRANSPARENCY).toRgbString(),this._freezeActiveColor=style.primaryColor,this._freezeHoverColor=style.grey500}_interceptorCommands(){this.disposeWithMe(this._sheetInterceptorService.interceptCommand({getMutations:__name(command=>{const empty={redos:[],undos:[]},freeze=this._getFreeze();if(!freeze)return empty;const createFreezeMutationAndRefresh=__name(newFreeze=>{const workbook=this._context.unit,unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return empty;const subUnitId=worksheet.getSheetId();this._refreshFreeze(newFreeze.startRow,newFreeze.startColumn,newFreeze.ySplit,newFreeze.xSplit,0);const redoMutationParams={...newFreeze,unitId,subUnitId,resetScroll:!1},undoMutationParams=sheets.SetFrozenMutationFactory(this._injector,redoMutationParams);return{undos:[{id:sheets.SetFrozenMutation.id,params:undoMutationParams}],redos:[{id:sheets.SetFrozenMutation.id,params:redoMutationParams}]}},"createFreezeMutationAndRefresh");if(command.id===sheets.InsertRowCommand.id){const params=command.params,{range,direction}=params,insertCount=range.endRow-range.startRow+1;if(range.startRow+1<freeze.startRow||range.startRow+1===freeze.startRow&&direction===core.Direction.UP){const newFreeze={...freeze,startRow:Math.max(1,freeze.startRow+insertCount),ySplit:Math.max(1,freeze.ySplit+insertCount)};return createFreezeMutationAndRefresh(newFreeze)}}if(command.id===sheets.InsertColCommand.id){const params=command.params,{range,direction}=params,insertCount=range.endColumn-range.startColumn+1;if(range.startColumn+1<freeze.startColumn||range.startColumn+1===freeze.startColumn&&direction===core.Direction.LEFT){const newFreeze={...freeze,startColumn:Math.max(1,freeze.startColumn+insertCount),xSplit:Math.max(1,freeze.xSplit+insertCount)};return createFreezeMutationAndRefresh(newFreeze)}}if(command.id===sheets.MoveColsCommand.id){const selections=this._selectionManagerService.getCurrentSelections(),{fromRange:{startColumn:fromCol},toRange:{startColumn:toCol}}=command.params,filteredSelections=selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.COLUMN&&selection.range.startColumn<=fromCol&&fromCol<=selection.range.endColumn);if(!(filteredSelections!=null&&filteredSelections.length))return empty;const sourceRange=filteredSelections[0].range,targetRange={...sourceRange,startColumn:toCol,endColumn:toCol+sourceRange.endColumn-sourceRange.startColumn};if(!freeze||freeze.startColumn<=0||sourceRange.startColumn>=freeze.startColumn&&targetRange.startColumn>=freeze.startColumn||sourceRange.startColumn===targetRange.startColumn||sourceRange.endColumn<freeze.startColumn&&targetRange.startColumn<freeze.startColumn)return empty;const totalColCount=sourceRange.endColumn-sourceRange.startColumn+1,moveFreezeColCount=Math.max(Math.min(freeze.startColumn,sourceRange.endColumn+1)-sourceRange.startColumn,0);let newStartColumn,newXSplit;targetRange.startColumn>=freeze.startColumn?(newStartColumn=Math.max(freeze.startColumn-moveFreezeColCount,1),newXSplit=Math.max(freeze.xSplit-moveFreezeColCount,1)):(newStartColumn=freeze.startColumn+totalColCount-moveFreezeColCount,newXSplit=freeze.xSplit+totalColCount-moveFreezeColCount);const redoMutationParams={...freeze,startColumn:newStartColumn,xSplit:newXSplit};return createFreezeMutationAndRefresh(redoMutationParams)}if(command.id===sheets.MoveRowsCommand.id){const selections=this._selectionManagerService.getCurrentSelections(),{fromRange:{startRow:fromRow},toRange:{startRow:toRow}}=command.params,filteredSelections=selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.ROW&&selection.range.startRow<=fromRow&&fromRow<=selection.range.endRow);if(!(filteredSelections!=null&&filteredSelections.length))return empty;const sourceRange=filteredSelections[0].range,targetRange={...sourceRange,startRow:toRow,endRow:toRow+sourceRange.endRow-sourceRange.startRow};if(!freeze||freeze.startRow<=0||sourceRange.startRow>=freeze.startRow&&targetRange.startRow>=freeze.startRow||sourceRange.startRow===targetRange.startRow||sourceRange.endRow<freeze.startRow&&targetRange.startRow<freeze.startRow)return empty;const totalColCount=sourceRange.endRow-sourceRange.startRow+1,moveFreezeColCount=Math.max(Math.min(freeze.startRow,sourceRange.endRow+1)-sourceRange.startRow,0);let newStartRow,newYSplit;targetRange.startRow>=freeze.startRow?(newStartRow=Math.max(freeze.startRow-moveFreezeColCount,1),newYSplit=Math.max(freeze.ySplit-moveFreezeColCount,1)):(newStartRow=freeze.startRow+totalColCount-moveFreezeColCount,newYSplit=freeze.ySplit+totalColCount-moveFreezeColCount);const redoMutationParams={...freeze,startRow:newStartRow,ySplit:newYSplit};return createFreezeMutationAndRefresh(redoMutationParams)}if(command.id===sheets.RemoveColCommand.id||command.id===sheets.RemoveRowCommand.id){const params=command.params,range=params.range;if(range.rangeType===core.RANGE_TYPE.COLUMN&&range.startColumn<freeze.startColumn){const deleteFreezeColCount=Math.min(freeze.startColumn,range.endColumn+1)-range.startColumn,newFreeze={...freeze,startColumn:Math.max(1,freeze.startColumn-deleteFreezeColCount),xSplit:Math.max(1,freeze.xSplit-deleteFreezeColCount)};return createFreezeMutationAndRefresh(newFreeze)}if(params.range.rangeType===core.RANGE_TYPE.ROW&&range.startRow<freeze.startRow){const deleteFreezeRowCount=Math.min(freeze.startRow,range.endRow+1)-range.startRow,newFreeze={...freeze,startRow:Math.max(1,freeze.startRow-deleteFreezeRowCount),ySplit:Math.max(1,freeze.ySplit-deleteFreezeRowCount)};return createFreezeMutationAndRefresh(newFreeze)}}return empty},"getMutations")}))}_commandExecutedListener(){const updateCommandList=[sheets.SetFrozenMutation.id,SetZoomRatioOperation.id];this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(updateCommandList.includes(command.id)){const lastFreeze=this._lastFreeze,workbook=this._context.unit,worksheet=workbook.getActiveSheet(),params=command.params,{unitId,subUnitId}=params;if(!(unitId===workbook.getUnitId()&&subUnitId===(worksheet==null?void 0:worksheet.getSheetId())))return;const freeze=worksheet.getConfig().freeze;if(this._lastFreeze=freeze,freeze==null)return;let resetScroll=0;const{startRow=-1,startColumn=-1,ySplit=0,xSplit=0}=freeze;(!lastFreeze||lastFreeze.startRow!==startRow||lastFreeze.ySplit!==ySplit)&&(resetScroll|=2),(!lastFreeze||lastFreeze.startColumn!==startColumn||lastFreeze.xSplit!==xSplit)&&(resetScroll|=1),params.resetScroll===!1&&(resetScroll=0),this._refreshFreeze(startRow,startColumn,ySplit,xSplit,resetScroll)}else if(command.id===sheets.SetWorksheetRowHeightMutation.id){const freeze=this._getFreeze(),isRefresh=freeze&&command.params.ranges.some(i=>i.startRow<freeze.startRow);command.params&&isRefresh&&this._refreshCurrent()}else if(command.id===sheets.SetWorksheetColWidthMutation.id){const freeze=this._getFreeze();command.params&&freeze&&command.params.ranges.some(i=>i.startColumn<freeze.startColumn)&&this._refreshCurrent()}else if(command.id===sheets.SetWorksheetRowAutoHeightMutation.id){const params=command.params,freeze=this._getFreeze();if(freeze&&freeze.startRow>-1&&params.rowsAutoHeightInfo.some(info=>info.row<freeze.startRow)){const subscription=this._sheetSkeletonManagerService.currentSkeleton$.subscribe(()=>{this._refreshCurrent(),setTimeout(()=>{subscription.unsubscribe()})})}}else if(command.id===sheets.SetColHiddenMutation.id||command.id===sheets.SetColVisibleMutation.id){const params=command.params,freeze=this._getFreeze(),ranges=params.ranges;freeze&&freeze.startColumn>-1&&ranges.some(range=>range.startColumn<freeze.startColumn)&&this._refreshCurrent()}else if(command.id===sheets.SetRowHiddenMutation.id||command.id===sheets.SetRowVisibleMutation.id){const params=command.params,freeze=this._getFreeze(),ranges=params.ranges;freeze&&freeze.startRow>-1&&ranges.some(range=>range.startRow<freeze.startRow)&&this._refreshCurrent()}}))}_zoomRefresh(){const sheetObject=this._getSheetObject();if(sheetObject==null)return;const{scene}=sheetObject;scene.onTransformChange$.subscribeEvent(state=>{state.type===engineRender.TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale&&this._refreshCurrent()})}_clearObserverEvent(){var _a61,_b;this._getSheetObject()!=null&&((_a61=this._scenePointerMoveSub)==null||_a61.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null)}_clearFreeze(){var _a61,_b,_c,_d,_e,_f;(_a61=this._rowFreezeHeaderRect)==null||_a61.dispose(),(_b=this._rowFreezeMainRect)==null||_b.dispose(),(_c=this._columnFreezeHeaderRect)==null||_c.dispose(),(_d=this._columnFreezeMainRect)==null||_d.dispose(),this._getSheetObject()!=null&&([this._freezeDownSubs,this._freezePointerEnterSubs,this._freezePointerLeaveSubs].forEach(s=>{s==null||s.unsubscribe()}),this._freezeDownSubs=null,this._freezePointerEnterSubs=null,this._freezePointerLeaveSubs=null,(_e=this._scenePointerMoveSub)==null||_e.unsubscribe(),(_f=this._scenePointerUpSub)==null||_f.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null)}_getPositionByIndex(row,column){var _a61;if(this._getSheetObject()==null)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton,position=skeleton==null?void 0:skeleton.getNoMergeCellPositionByIndex(row,column);if(skeleton==null)return;if(position!=null&&(!isNaN(position.endX)||!isNaN(position.endY)))return position;const{rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton;return{startX:rowHeaderWidthAndMarginLeft,endX:rowHeaderWidthAndMarginLeft,startY:columnHeaderHeightAndMarginTop,endY:columnHeaderHeightAndMarginTop}}_getFreeze(){var _a61;const config=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton.getWorksheetConfig();if(config!=null)return config.freeze}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_refreshFreeze(startRow,startColumn,ySplit,xSplit,resetScroll){var _a61;const newFreeze={startRow,startColumn,ySplit,xSplit};this._clearFreeze(),this._createFreeze(0,newFreeze),this._createFreeze(1,newFreeze),this._updateViewport(startRow,startColumn,ySplit,xSplit,resetScroll),(_a61=this._getSheetObject())==null||_a61.spreadsheet.makeForceDirty()}},__name(_a39,"HeaderFreezeRenderController"),_a39);exports.HeaderFreezeRenderController=__decorateClass$j([__decorateParam$j(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$j(2,core.ICommandService),__decorateParam$j(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$j(4,core.Inject(SheetScrollManagerService)),__decorateParam$j(5,core.Inject(core.ThemeService)),__decorateParam$j(6,core.Inject(sheets.SheetInterceptorService)),__decorateParam$j(7,core.Inject(core.Injector))],exports.HeaderFreezeRenderController);var __defProp$i=Object.defineProperty,__getOwnPropDesc$i=Object.getOwnPropertyDescriptor,__decorateClass$i=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$i(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$i(target,key,result),result},"__decorateClass$i"),__decorateParam$i=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$i");const HEADER_MOVE_CONTROLLER_BACKGROUND="__SpreadsheetHeaderMoveControllerBackground__",HEADER_MOVE_CONTROLLER_LINE="__SpreadsheetHeaderMoveControllerShapeLine__",HEADER_MOVE_CONTROLLER_BACKGROUND_FILL="rgba(0, 0, 0, 0.1)",HEADER_MOVE_CONTROLLER_LINE_FILL="rgb(119, 119, 119)",HEADER_MOVE_CONTROLLER_LINE_SIZE=4,HEADER_MOVE_PERMISSION_CHECK=core.createInterceptorKey("headerMovePermissionCheck");var _a40;exports.HeaderMoveRenderController=(_a40=class extends core.Disposable{constructor(_context,selectionManagerService,_sheetSkeletonManagerService,_commandService){super();__publicField(this,"_startOffsetX",Number.NEGATIVE_INFINITY);__publicField(this,"_startOffsetY",Number.NEGATIVE_INFINITY);__publicField(this,"_moveHelperBackgroundShape");__publicField(this,"_moveHelperLineShape");__publicField(this,"_headerPointerDownSubs");__publicField(this,"_headerPointerMoveSubs");__publicField(this,"_headerPointerLeaveSubs");__publicField(this,"_dragHeaderMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_scrollTimer");__publicField(this,"_changeFromColumn",-1);__publicField(this,"_changeFromRow",-1);__publicField(this,"_changeToColumn",-1);__publicField(this,"_changeToRow",-1);__publicField(this,"interceptor",new core.InterceptorManager({HEADER_MOVE_PERMISSION_CHECK}));__publicField(this,"_workbookSelections");this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._workbookSelections=selectionManagerService.getWorkbookSelections(this._context.unitId),this._init()}dispose(){var _a61,_b,_c,_d,_e,_f,_g,_h;(_a61=this._moveHelperBackgroundShape)==null||_a61.dispose(),(_b=this._moveHelperLineShape)==null||_b.dispose(),(_c=this._headerPointerMoveSubs)==null||_c.unsubscribe(),(_d=this._headerPointerLeaveSubs)==null||_d.unsubscribe(),(_e=this._headerPointerDownSubs)==null||_e.unsubscribe(),this._headerPointerMoveSubs=null,this._headerPointerLeaveSubs=null,this._headerPointerDownSubs=null,(_f=this._dragHeaderMoveSub)==null||_f.unsubscribe(),(_g=this._scenePointerUpSub)==null||_g.unsubscribe(),this._dragHeaderMoveSub=null,this._scenePointerUpSub=null,(_h=this._scrollTimer)==null||_h.dispose()}_init(){this._initialRowOrColumn(core.RANGE_TYPE.ROW),this._initialRowOrColumn(core.RANGE_TYPE.COLUMN)}_initialRowOrColumn(initialType=core.RANGE_TYPE.ROW){const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetRowHeader=this._context.components.get(SHEET_VIEW_KEY.ROW),scene=this._context.scene,eventBindingObject=initialType===core.RANGE_TYPE.ROW?spreadsheetRowHeader:spreadsheetColumnHeader,pointerMoveHandler=__name(evt=>{var _a61,_b;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const selectionRange=(_b=this._workbookSelections.getCurrentLastSelection())==null?void 0:_b.range;if(!selectionRange||!this.interceptor.fetchThroughInterceptors(HEADER_MOVE_PERMISSION_CHECK)(!1,selectionRange))return;const currentSelections=this._workbookSelections.getCurrentSelections(),{row,column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);if(!matchedSelectionByRowColIndex(currentSelections,initialType===core.RANGE_TYPE.ROW?row:column,initialType)){scene.resetCursor();return}scene.setCursor(engineRender.CURSOR_TYPE.GRAB)},"pointerMoveHandler"),pointerLeaveHandler=__name(()=>{var _a61,_b;(_a61=this._moveHelperBackgroundShape)==null||_a61.hide(),(_b=this._moveHelperLineShape)==null||_b.hide(),scene.resetCursor()},"pointerLeaveHandler"),pointerDownHandler=__name((evt,state)=>{var _a61,_b;if(state.isStopPropagation)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const selectionRange=(_b=this._workbookSelections.getCurrentLastSelection())==null?void 0:_b.range;if(!selectionRange||!this.interceptor.fetchThroughInterceptors(HEADER_MOVE_PERMISSION_CHECK)(!1,selectionRange))return;const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords;this._startOffsetX=newEvtOffsetX,this._startOffsetY=newEvtOffsetY;const{row,column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);let scrollType;initialType===core.RANGE_TYPE.ROW?(this._changeFromRow=row,scrollType=engineRender.ScrollTimerType.Y):(this._changeFromColumn=column,scrollType=engineRender.ScrollTimerType.X);const currentSelections=this._workbookSelections.getCurrentSelections(),matchSelectionData=matchedSelectionByRowColIndex(currentSelections,initialType===core.RANGE_TYPE.ROW?row:column,initialType);if(!matchSelectionData)return;const startScrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startOffsetX,this._startOffsetY]));this._newBackgroundAndLine(),scene.setCursor(engineRender.CURSOR_TYPE.GRABBING),scene.disableObjectsEvent();let scrollTimerInitd=!1,scrollTimer;const initScrollTimer=__name(()=>{if(scrollTimerInitd)return;scrollTimer=engineRender.ScrollTimer.create(scene,scrollType),this._scrollTimer=scrollTimer;const mainViewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY,mainViewport),scrollTimerInitd=!0},"initScrollTimer");this._dragHeaderMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{initScrollTimer();const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._rowColumnMoving(newMoveOffsetX,newMoveOffsetY,matchSelectionData,startScrollXY,initialType),scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._rowColumnMoving(newMoveOffsetX,newMoveOffsetY,matchSelectionData,startScrollXY,initialType)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a62,_b2,_c;this._disposeBackgroundAndLine(),scene.resetCursor(),scene.enableObjectsEvent(),this._clearObserverEvent(),(_a62=this._scrollTimer)==null||_a62.dispose();const selections=this._workbookSelections.getCurrentSelections();if(initialType===core.RANGE_TYPE.ROW){if(this._changeFromRow!==this._changeToRow&&this._changeToRow!==-1){const range=(_b2=((selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.ROW&&selection.range.startRow<=this._changeFromRow&&this._changeFromRow<=selection.range.endRow))||[])[0])==null?void 0:_b2.range;range&&this._commandService.executeCommand(sheets.MoveRowsCommand.id,{fromRange:range,toRange:{...range,startRow:this._changeToRow,endRow:this._changeToRow+range.endRow-range.startRow}})}this._changeToRow=this._changeFromRow=-1}else{if(this._changeFromColumn!==this._changeToColumn&&this._changeToColumn!==-1){const range=(_c=((selections==null?void 0:selections.filter(selection=>selection.range.rangeType===core.RANGE_TYPE.COLUMN&&selection.range.startColumn<=this._changeFromColumn&&this._changeFromColumn<=selection.range.endColumn))||[])[0])==null?void 0:_c.range;range&&this._commandService.executeCommand(sheets.MoveColsCommand.id,{fromRange:range,toRange:{...range,startColumn:this._changeToColumn,endColumn:this._changeToColumn+range.endColumn-range.startColumn}})}this._changeToColumn=this._changeFromColumn=-1}})},"pointerDownHandler");this._headerPointerMoveSubs=new rxjs.Subscription,this._headerPointerMoveSubs.add(eventBindingObject.onPointerMove$.subscribeEvent(pointerMoveHandler)),this._headerPointerLeaveSubs=new rxjs.Subscription,this._headerPointerLeaveSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerLeave$.subscribeEvent(pointerLeaveHandler)),this._headerPointerDownSubs=new rxjs.Subscription,this._headerPointerDownSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerDown$.subscribeEvent(pointerDownHandler))}_rowColumnMoving(moveOffsetX,moveOffsetY,matchSelectionData,startScrollXY,initialType){var _a61,_b,_c,_d,_e,_f,_g;const scene=this._context.scene,skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const{rowHeaderWidth,columnHeaderHeight,rowTotalHeight,columnTotalWidth}=skeleton,scrollXY=scene.getViewportScrollXY(scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN)),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,startCell=skeleton.getNoMergeCellPositionByIndex(row,column),{startX:cellStartX,startY:cellStartY,endX:cellEndX,endY:cellEndY}=startCell,selectionWithCoord=this._sheetSkeletonManagerService.attachRangeWithCoord(matchSelectionData.range);if(selectionWithCoord==null)return;const scale=Math.max(scaleX,scaleX),{startX:selectedStartX,endX:selectedEndX,startY:selectedStartY,endY:selectedEndY,startRow:selectedStartRow,startColumn:selectedStartColumn,endRow:selectedEndRow,endColumn:selectedEndColumn}=selectionWithCoord;initialType===core.RANGE_TYPE.ROW?(_b=this._moveHelperBackgroundShape)==null||_b.transformByState({height:selectedEndY-selectedStartY,width:columnTotalWidth+rowHeaderWidth,left:0,top:selectedStartY+(moveOffsetY-this._startOffsetY)/scale+scrollXY.y-startScrollXY.y}):(_c=this._moveHelperBackgroundShape)==null||_c.transformByState({height:rowTotalHeight+columnHeaderHeight,width:selectedEndX-selectedStartX,left:selectedStartX+(moveOffsetX-this._startOffsetX)/scale+scrollXY.x-startScrollXY.x,top:0}),(_d=this._moveHelperBackgroundShape)==null||_d.show();const HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE=HEADER_MOVE_CONTROLLER_LINE_SIZE/scale;if(initialType===core.RANGE_TYPE.ROW){let top=0;if(row<=selectedStartRow)top=cellStartY-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToRow=row;else if(row>selectedEndRow)top=cellEndY-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToRow=row+1;else return;(_e=this._moveHelperLineShape)==null||_e.transformByState({height:HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE,width:columnTotalWidth,left:rowHeaderWidth,top})}else{let left=0;if(column<=selectedStartColumn)left=cellStartX-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToColumn=column;else if(column>selectedEndColumn)left=cellEndX-HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE/2,this._changeToColumn=column+1;else return;(_f=this._moveHelperLineShape)==null||_f.transformByState({height:rowTotalHeight,width:HEADER_MOVE_CONTROLLER_LINE_SIZE_SCALE,left,top:columnHeaderHeight})}(_g=this._moveHelperLineShape)==null||_g.show()}_clearObserverEvent(){var _a61,_b;(_a61=this._dragHeaderMoveSub)==null||_a61.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._dragHeaderMoveSub=null,this._scenePointerUpSub=null}_newBackgroundAndLine(){const scene=this._context.scene;this._moveHelperBackgroundShape=new engineRender.Rect(HEADER_MOVE_CONTROLLER_BACKGROUND,{fill:HEADER_MOVE_CONTROLLER_BACKGROUND_FILL,evented:!1,zIndex:100}),this._moveHelperLineShape=new engineRender.Rect(HEADER_MOVE_CONTROLLER_LINE,{fill:HEADER_MOVE_CONTROLLER_LINE_FILL,evented:!1,zIndex:100}),scene.addObjects([this._moveHelperBackgroundShape,this._moveHelperLineShape],SHEET_COMPONENT_HEADER_LAYER_INDEX)}_disposeBackgroundAndLine(){var _a61,_b;(_a61=this._moveHelperBackgroundShape)==null||_a61.dispose(),(_b=this._moveHelperLineShape)==null||_b.dispose()}},__name(_a40,"HeaderMoveRenderController"),_a40);exports.HeaderMoveRenderController=__decorateClass$i([__decorateParam$i(1,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$i(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$i(3,core.ICommandService)],exports.HeaderMoveRenderController);var HEADER_RESIZE_SHAPE_TYPE=(HEADER_RESIZE_SHAPE_TYPE2=>(HEADER_RESIZE_SHAPE_TYPE2[HEADER_RESIZE_SHAPE_TYPE2.VERTICAL=0]="VERTICAL",HEADER_RESIZE_SHAPE_TYPE2[HEADER_RESIZE_SHAPE_TYPE2.HORIZONTAL=1]="HORIZONTAL",HEADER_RESIZE_SHAPE_TYPE2))(HEADER_RESIZE_SHAPE_TYPE||{});const HEADER_MENU_SHAPE_RECT_BACKGROUND_FILL="rgba(120, 120, 120, 0.01)",HEADER_MENU_SHAPE_RECT_FILL="rgb(68, 71, 70)",HEADER_MENU_SHAPE_SIZE=12,MAX_HEADER_MENU_SHAPE_SIZE=44,HEADER_MENU_SHAPE_THUMB_SIZE=4,_HeaderMenuResizeShape=class _HeaderMenuResizeShape extends engineRender.Shape{constructor(key,props){super(key,props);__publicField(this,"_size",HEADER_MENU_SHAPE_SIZE);__publicField(this,"_color",HEADER_MENU_SHAPE_RECT_FILL);__publicField(this,"_mode",0);this.setShapeProps(props)}get size(){return this._size}get mode(){return this._mode}get color(){return this._color}_draw(ctx){const scene=this.getScene();if(!scene)return;const{scaleX,scaleY}=scene.getAncestorScale(),scale=Math.max(scaleX,scaleY),HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE=HEADER_MENU_SHAPE_SIZE/scale,HEADER_MENU_SHAPE_THUMB_SIZE_SCALE=HEADER_MENU_SHAPE_THUMB_SIZE/scale;let{width,height}=this,left=0,top=0;this.mode===0?(width=HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,left=HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE):(height=HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,top=HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE),engineRender.Rect.drawWith(ctx,{width:this.width,height:this.height,left:0,top:0,fill:HEADER_MENU_SHAPE_RECT_BACKGROUND_FILL}),engineRender.Rect.drawWith(ctx,{width,height,fill:HEADER_MENU_SHAPE_RECT_FILL,radius:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE}),ctx.save(),ctx.transform(1,0,0,1,left,top),engineRender.Rect.drawWith(ctx,{width,height,fill:HEADER_MENU_SHAPE_RECT_FILL,radius:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE}),ctx.restore()}setShapeProps(props){return props!=null&&props.size&&(this._size=props.size),props!=null&&props.mode&&(this._mode=props.mode),props!=null&&props.color&&(this._color=props.color),this.mode===0?this.transformByState({width:HEADER_MENU_SHAPE_SIZE,height:this.size}):this.transformByState({width:this.size,height:HEADER_MENU_SHAPE_SIZE}),this}};__name(_HeaderMenuResizeShape,"HeaderMenuResizeShape");let HeaderMenuResizeShape=_HeaderMenuResizeShape;var __defProp$h=Object.defineProperty,__getOwnPropDesc$h=Object.getOwnPropertyDescriptor,__decorateClass$h=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$h(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$h(target,key,result),result},"__decorateClass$h"),__decorateParam$h=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$h");const HEADER_RESIZE_CONTROLLER_SHAPE_ROW="__SpreadsheetHeaderResizeControllerShapeRow__",HEADER_RESIZE_CONTROLLER_SHAPE_COLUMN="__SpreadsheetHeaderResizeControllerShapeColumn__",HEADER_RESIZE_CONTROLLER_SHAPE_HELPER="__SpreadsheetHeaderResizeControllerShapeHelper__",HEADER_RESIZE_CONTROLLER_SHAPE_HELPER_COLOR="rgb(199, 199, 199)",MINIMAL_OFFSET=2,HEADER_RESIZE_PERMISSION_CHECK=core.createInterceptorKey("headerResizePermissionCheck");var _a41;exports.HeaderResizeRenderController=(_a41=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService){super();__publicField(this,"_currentRow",0);__publicField(this,"_currentColumn",0);__publicField(this,"_rowResizeRect");__publicField(this,"_columnResizeRect");__publicField(this,"_headerPointerSubs");__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_resizeHelperShape");__publicField(this,"_startOffsetX",Number.POSITIVE_INFINITY);__publicField(this,"_startOffsetY",Number.POSITIVE_INFINITY);__publicField(this,"interceptor",new core.InterceptorManager({HEADER_RESIZE_PERMISSION_CHECK}));this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._init()}dispose(){var _a61,_b,_c;(_a61=this._rowResizeRect)==null||_a61.dispose(),this._rowResizeRect=null,(_b=this._columnResizeRect)==null||_b.dispose(),this._columnResizeRect=null,(_c=this._headerPointerSubs)==null||_c.unsubscribe(),this._headerPointerSubs=null}_init(){const scene=this._context.scene;this._rowResizeRect=new HeaderMenuResizeShape(HEADER_RESIZE_CONTROLLER_SHAPE_ROW,{visible:!1,mode:HEADER_RESIZE_SHAPE_TYPE.HORIZONTAL,zIndex:100}),this._columnResizeRect=new HeaderMenuResizeShape(HEADER_RESIZE_CONTROLLER_SHAPE_COLUMN,{visible:!1,mode:HEADER_RESIZE_SHAPE_TYPE.VERTICAL,zIndex:100}),scene.addObjects([this._rowResizeRect,this._columnResizeRect],SHEET_COMPONENT_HEADER_LAYER_INDEX),this._initialHover(0),this._initialHover(1),this._initialHoverResize(0),this._initialHoverResize(1)}_initialHover(initialType=0){const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetRowHeader=this._context.components.get(SHEET_VIEW_KEY.ROW),scene=this._context.scene,eventBindingObject=initialType===0?spreadsheetRowHeader:spreadsheetColumnHeader,pointerLeaveEvent=__name((_evt,_state)=>{var _a61,_b;(_a61=this._rowResizeRect)==null||_a61.hide(),(_b=this._columnResizeRect)==null||_b.hide()},"pointerLeaveEvent"),pointerMoveEvent=__name((evt,_state)=>{var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null||this._rowResizeRect==null||this._columnResizeRect==null)return;const{rowHeaderWidth,columnHeaderHeight}=skeleton,{startX,startY,endX,endY,row,column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton),transformCoord=getTransformCoord(evt.offsetX,evt.offsetY,scene),{scaleX,scaleY}=scene.getAncestorScale(),scale=Math.max(scaleX,scaleY),HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE=HEADER_MENU_SHAPE_SIZE/scale;if(initialType===0){let top=startY-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;if(transformCoord.y<=startY+HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.y>=startY)this._currentRow=row-1;else if(transformCoord.y>=endY-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.y<=endY)this._currentRow=row,top=endY-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;else{this._rowResizeRect.hide();return}if(this._currentRow===-1)return;if(!this.interceptor.fetchThroughInterceptors(HEADER_RESIZE_PERMISSION_CHECK)(null,{row:this._currentRow}))return!1;const rowSize=Math.min(MAX_HEADER_MENU_SHAPE_SIZE,rowHeaderWidth/3);this._rowResizeRect.transformByState({left:rowHeaderWidth/2-rowSize/2,top}),this._rowResizeRect.setShapeProps({size:rowSize}),this._rowResizeRect.show()}else{let left=startX-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;if(transformCoord.x<=startX+HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.x>=startX)this._currentColumn=column-1;else if(transformCoord.x>=endX-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2&&transformCoord.x<=endX)this._currentColumn=column,left=endX-HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE/2;else{this._columnResizeRect.hide();return}if(this._currentColumn===-1)return;if(!this.interceptor.fetchThroughInterceptors(HEADER_RESIZE_PERMISSION_CHECK)(null,{col:this._currentColumn}))return!1;const columnSize=columnHeaderHeight*.7;this._columnResizeRect.transformByState({left,top:columnHeaderHeight/2-columnSize/2}),this._columnResizeRect.setShapeProps({size:columnSize}),this._columnResizeRect.show()}},"pointerMoveEvent");this._headerPointerSubs=new rxjs.Subscription,this._headerPointerSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerMove$.subscribeEvent(pointerMoveEvent)),this._headerPointerSubs.add(eventBindingObject==null?void 0:eventBindingObject.onPointerLeave$.subscribeEvent(pointerLeaveEvent))}_initialHoverResize(initialType=0){const scene=this._context.scene,eventBindingObject=initialType===0?this._rowResizeRect:this._columnResizeRect;eventBindingObject!=null&&(this.disposeWithMe(core.toDisposable(eventBindingObject.onPointerEnter$.subscribeEvent(()=>{eventBindingObject!=null&&(eventBindingObject.show(),scene.setCursor(initialType===0?engineRender.CURSOR_TYPE.ROW_RESIZE:engineRender.CURSOR_TYPE.COLUMN_RESIZE))}))),this.disposeWithMe(core.toDisposable(eventBindingObject.onPointerLeave$.subscribeEvent(()=>{eventBindingObject!=null&&(eventBindingObject.hide(),scene.resetCursor())}))),this.disposeWithMe(core.toDisposable(eventBindingObject.onPointerDown$.subscribeEvent(evt=>{var _a61,_b,_c,_d,_e,_f,_g;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const scene2=this._context.scene,engine=scene2.getEngine(),canvasMaxHeight=(engine==null?void 0:engine.height)||0,canvasMaxWidth=(engine==null?void 0:engine.width)||0,viewPort=scene2.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollBarHorizontalHeight=(((_c=(_b=viewPort==null?void 0:viewPort.getScrollBar())==null?void 0:_b.horizonScrollTrack)==null?void 0:_c.height)||0)+10,scrollBarVerticalWidth=(((_e=(_d=viewPort==null?void 0:viewPort.getScrollBar())==null?void 0:_d.verticalScrollTrack)==null?void 0:_e.width)||0)+10,transformCoord=getTransformCoord(evt.offsetX,evt.offsetY,scene2),{scaleX,scaleY}=scene2.getAncestorScale();this._startOffsetX=transformCoord.x,this._startOffsetY=transformCoord.y;const currentOffsetX=skeleton.getOffsetByPositionX(this._currentColumn),currentOffsetY=skeleton.getOffsetByPositionY(this._currentRow),cell=skeleton.getNoMergeCellPositionByIndex(this._currentRow,this._currentColumn);let isStartMove=!1,moveChangeX=0,moveChangeY=0;const{columnTotalWidth,rowHeaderWidth,rowTotalHeight,columnHeaderHeight}=skeleton,shapeWidth=canvasMaxWidth>columnTotalWidth+rowHeaderWidth?canvasMaxWidth:columnTotalWidth+rowHeaderWidth,shapeHeight=canvasMaxHeight>rowTotalHeight+columnHeaderHeight?canvasMaxHeight:rowTotalHeight+columnHeaderHeight,scale=Math.max(scaleX,scaleY),HEADER_MENU_SHAPE_THUMB_SIZE_SCALE=HEADER_MENU_SHAPE_THUMB_SIZE/scale;initialType===0?this._resizeHelperShape=new engineRender.Rect(HEADER_RESIZE_CONTROLLER_SHAPE_HELPER,{width:shapeWidth,height:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,fill:HEADER_RESIZE_CONTROLLER_SHAPE_HELPER_COLOR,left:0,top:currentOffsetY-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE/2}):this._resizeHelperShape=new engineRender.Rect(HEADER_RESIZE_CONTROLLER_SHAPE_HELPER,{width:HEADER_MENU_SHAPE_THUMB_SIZE_SCALE,height:shapeHeight,fill:HEADER_RESIZE_CONTROLLER_SHAPE_HELPER_COLOR,left:currentOffsetX-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE/2,top:0});const rowResizeRectX=((_f=this._columnResizeRect)==null?void 0:_f.left)||0,rowResizeRectY=((_g=this._rowResizeRect)==null?void 0:_g.top)||0;scene2.addObject(this._resizeHelperShape,SHEET_COMPONENT_HEADER_LAYER_INDEX),scene2.disableObjectsEvent(),this._scenePointerMoveSub=scene2.onPointerMove$.subscribeEvent(moveEvt=>{var _a62,_b2,_c2,_d2,_e2,_f2;const relativeCoords=scene2.getRelativeToViewportCoord(engineRender.Vector2.FromArray([this._startOffsetX,this._startOffsetY])),scrollXY=scene2.getVpScrollXYInfoByPosToVp(relativeCoords,viewPort),transformCoord2=getTransformCoord(moveEvt.offsetX,moveEvt.offsetY,scene2),{x:moveOffsetX,y:moveOffsetY}=transformCoord2,{scaleX:scaleX2,scaleY:scaleY2}=scene2.getAncestorScale(),scale2=Math.max(scaleX2,scaleY2),HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2=HEADER_MENU_SHAPE_THUMB_SIZE/scale2;moveChangeX=moveOffsetX-this._startOffsetX-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2,moveChangeY=moveOffsetY-this._startOffsetY-HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2,Math.abs(initialType===0?moveChangeY:moveChangeX)>=MINIMAL_OFFSET&&(isStartMove=!0),initialType===0?(moveChangeY>canvasMaxHeight-scrollBarHorizontalHeight+scrollXY.y-cell.startY&&(moveChangeY=canvasMaxHeight-scrollBarHorizontalHeight+scrollXY.y-cell.startY),moveChangeY<-(cell.endY-cell.startY)+2&&(moveChangeY=-(cell.endY-cell.startY)+2),isStartMove&&((_a62=this._resizeHelperShape)==null||_a62.transformByState({top:currentOffsetY+moveChangeY}),(_b2=this._rowResizeRect)==null||_b2.transformByState({top:rowResizeRectY+moveChangeY+HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2}),(_c2=this._rowResizeRect)==null||_c2.show(),scene2.setCursor(engineRender.CURSOR_TYPE.ROW_RESIZE))):(moveChangeX>canvasMaxWidth-scrollBarVerticalWidth+scrollXY.x-cell.startX&&(moveChangeX=canvasMaxWidth-scrollBarVerticalWidth+scrollXY.x-cell.startX),moveChangeX<-(cell.endX-cell.startX)+2&&(moveChangeX=-(cell.endX-cell.startX)+2),isStartMove&&((_d2=this._resizeHelperShape)==null||_d2.transformByState({left:currentOffsetX+moveChangeX}),(_e2=this._columnResizeRect)==null||_e2.transformByState({left:rowResizeRectX+moveChangeX+HEADER_MENU_SHAPE_THUMB_SIZE_SCALE2/2}),(_f2=this._columnResizeRect)==null||_f2.show(),scene2.setCursor(engineRender.CURSOR_TYPE.COLUMN_RESIZE)))}),this._scenePointerUpSub=scene2.onPointerUp$.subscribeEvent(upEvt=>{var _a62,_b2,_c2;const scene3=this._context.scene;this._clearObserverEvent(),(_a62=this._resizeHelperShape)==null||_a62.dispose(),this._resizeHelperShape=null,scene3.enableObjectsEvent(),isStartMove&&(scene3.resetCursor(),(_b2=this._rowResizeRect)==null||_b2.hide(),(_c2=this._columnResizeRect)==null||_c2.hide(),initialType===0?this._commandService.executeCommand(sheets.DeltaRowHeightCommand.id,{deltaY:moveChangeY,anchorRow:this._currentRow}):this._commandService.executeCommand(sheets.DeltaColumnWidthCommand.id,{deltaX:moveChangeX,anchorCol:this._currentColumn}))})}))),this.disposeWithMe(core.toDisposable(eventBindingObject.onDblclick$.subscribeEvent(()=>{var _a61,_b;initialType===0&&(this._context.scene.resetCursor(),this._commandService.executeCommand(sheets.SetWorksheetRowIsAutoHeightCommand.id,{ranges:[{startRow:this._currentRow,endRow:this._currentRow,startColumn:0,endColumn:((_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton.worksheet.getColumnCount())||0}]}),(_b=this._rowResizeRect)==null||_b.hide())}))))}_clearObserverEvent(){var _a61,_b;(_a61=this._scenePointerMoveSub)==null||_a61.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null}},__name(_a41,"HeaderResizeRenderController"),_a41);exports.HeaderResizeRenderController=__decorateClass$h([__decorateParam$h(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$h(2,core.ICommandService)],exports.HeaderResizeRenderController);var __defProp$g=Object.defineProperty,__getOwnPropDesc$g=Object.getOwnPropertyDescriptor,__decorateClass$g=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$g(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$g(target,key,result),result},"__decorateClass$g"),__decorateParam$g=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$g"),_a42;let SheetPermissionInterceptorCanvasRenderController=(_a42=class extends core.RxDisposable{constructor(_context,_univerInstanceService,_permissionService,_selectionManagerService,_rangeProtectionRuleModel,_headerMoveRenderController,_selectionRenderService,_headerFreezeRenderController,_rangeProtectionCache,_headerResizeRenderController){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._context=_context,this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._selectionManagerService=_selectionManagerService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._headerMoveRenderController=_headerMoveRenderController,this._selectionRenderService=_selectionRenderService,this._headerFreezeRenderController=_headerFreezeRenderController,this._rangeProtectionCache=_rangeProtectionCache,this._headerResizeRenderController=_headerResizeRenderController,this._initHeaderMovePermissionInterceptor(),this._initHeaderResizePermissionInterceptor(),this._initRangeFillPermissionInterceptor(),this._initRangeMovePermissionInterceptor()}_initHeaderMovePermissionInterceptor(){const headerMoveInterceptor=this._headerMoveRenderController.interceptor.getInterceptPoints().HEADER_MOVE_PERMISSION_CHECK;this.disposeWithMe(this._headerMoveRenderController.interceptor.intercept(headerMoveInterceptor,{handler:__name((defaultValue,selectionRange)=>{const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target;if(!this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id]).every(permission=>permission.value))return!1;if(!selectionRange)return!0;if(selectionRange.rangeType!==core.RANGE_TYPE.ROW&&selectionRange.rangeType!==core.RANGE_TYPE.COLUMN)return defaultValue;if(selectionRange.rangeType===core.RANGE_TYPE.ROW){for(let i=selectionRange.startRow;i<=selectionRange.endRow;i++)if(this._rangeProtectionCache.getRowPermissionInfo(unitId,subUnitId,i,[D.Edit])===!1)return!1}else for(let i=selectionRange.startColumn;i<=selectionRange.endColumn;i++)if(this._rangeProtectionCache.getColPermissionInfo(unitId,subUnitId,i,[D.Edit])===!1)return!1;return!0},"handler")}))}_initHeaderResizePermissionInterceptor(){this._headerResizeRenderController&&this.disposeWithMe(this._headerResizeRenderController.interceptor.intercept(this._headerResizeRenderController.interceptor.getInterceptPoints().HEADER_RESIZE_PERMISSION_CHECK,{handler:__name((defaultValue,rangeParams)=>{var _a61,_b,_c,_d;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target;if(rangeParams.row){if(((_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorksheetSetRowStylePermission(unitId,subUnitId).id))==null?void 0:_a61.value)!=null?_b:!1)===!1)return!1}else if(rangeParams.col&&((_d=(_c=this._permissionService.getPermissionPoint(new sheets.WorksheetSetColumnStylePermission(unitId,subUnitId).id))==null?void 0:_c.value)!=null?_d:!1)===!1)return!1;return!0},"handler")}))}_initRangeFillPermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_FILL_PERMISSION_CHECK,{handler:__name((_,position)=>{var _a61,_b,_c;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;if(!this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id,new sheets.WorksheetSetCellValuePermission(unitId,subUnitId).id,new sheets.WorksheetSetCellStylePermission(unitId,subUnitId).id]).every(permission=>permission.value))return!1;const ranges=(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range),selectionRange=ranges==null?void 0:ranges.find(range=>{const transformCoord=getTransformCoord(position.x,position.y,position.scene,position.skeleton),cellPosition=position.skeleton.getCellByIndex(range.endRow,range.endColumn),missX=Math.abs(cellPosition.endX-transformCoord.x),missY=Math.abs(cellPosition.endY-transformCoord.y);return missX<=5&&missY<=5});if(!selectionRange)return!0;const{startRow,endRow,startColumn,endColumn}=selectionRange;for(let row=startRow;row<=endRow;row++)for(let col=startColumn;col<=endColumn;col++){const permission=(_c=(_b=worksheet.getCell(row,col))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[D.Edit])===!1||(permission==null?void 0:permission[D.View])===!1)return!1}return!0},"handler")}))}_initRangeMovePermissionInterceptor(){this.disposeWithMe(this._selectionRenderService.interceptor.intercept(this._selectionRenderService.interceptor.getInterceptPoints().RANGE_MOVE_PERMISSION_CHECK,{handler:__name((_,_cellInfo)=>{var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;if(!this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id]).every(permission=>permission.value))return!1;const ranges=(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range),ruleRanges=this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p2,c)=>[...p2,...c.ranges],[]),permissionLapRanges=ranges==null?void 0:ranges.filter(range=>ruleRanges.some(ruleRange=>core.Rectangle.intersects(ruleRange,range)));return!(permissionLapRanges==null?void 0:permissionLapRanges.some(range=>{var _a62,_b;const{startRow,startColumn,endRow,endColumn}=range;for(let row=startRow;row<=endRow;row++)for(let col=startColumn;col<=endColumn;col++){const permission=(_b=(_a62=worksheet.getCell(row,col))==null?void 0:_a62.selectionProtection)==null?void 0:_b[0];if((permission==null?void 0:permission[D.Edit])===!1)return!0}return!1}))},"handler")}))}_initFreezePermissionInterceptor(){this.disposeWithMe(this._headerFreezeRenderController.interceptor.intercept(this._headerFreezeRenderController.interceptor.getInterceptPoints().FREEZE_PERMISSION_CHECK,{handler:__name((_,__)=>{var _a61,_b;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);return!(workbook==null?void 0:workbook.getActiveSheet())||!workbook?!1:(_b=(_a61=this._permissionService.getPermissionPoint(new sheets.WorkbookEditablePermission(workbook.getUnitId()).id))==null?void 0:_a61.value)!=null?_b:!1},"handler")}))}},__name(_a42,"SheetPermissionInterceptorCanvasRenderController"),_a42);SheetPermissionInterceptorCanvasRenderController=__decorateClass$g([__decorateParam$g(1,core.IUniverInstanceService),__decorateParam$g(2,core.IPermissionService),__decorateParam$g(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$g(4,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$g(5,core.Inject(exports.HeaderMoveRenderController)),__decorateParam$g(6,ISheetSelectionRenderService),__decorateParam$g(7,core.Inject(exports.HeaderFreezeRenderController)),__decorateParam$g(8,core.Inject(sheets.RangeProtectionCache)),__decorateParam$g(9,core.Optional(exports.HeaderResizeRenderController))],SheetPermissionInterceptorCanvasRenderController);var __defProp$f=Object.defineProperty,__getOwnPropDesc$f=Object.getOwnPropertyDescriptor,__decorateClass$f=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$f(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$f(target,key,result),result},"__decorateClass$f"),__decorateParam$f=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$f");const SHEET_PERMISSION_PASTE_PLUGIN="SHEET_PERMISSION_PASTE_PLUGIN";var _a43;let SheetPermissionInterceptorClipboardController=(_a43=class extends core.Disposable{constructor(_univerInstanceService,_selectionManagerService,_localService,_sheetClipboardService,_sheetPermissionInterceptorBaseController){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._localService=_localService,this._sheetClipboardService=_sheetClipboardService,this._sheetPermissionInterceptorBaseController=_sheetPermissionInterceptorBaseController,this._initClipboardHook()}_initClipboardHook(){this.disposeWithMe(this._sheetClipboardService.addClipboardHook({id:SHEET_PERMISSION_PASTE_PLUGIN,onBeforePaste:__name(pasteTo=>{var _a61,_b,_c;const[ranges]=virtualizeDiscreteRanges([pasteTo.range]).ranges,startRange=(_a61=this._selectionManagerService.getCurrentLastSelection())==null?void 0:_a61.range;if(!startRange)return!1;const targetRange={startRow:startRange.startRow+ranges.startRow,endRow:startRange.startRow+ranges.endRow,startColumn:startRange.startColumn+ranges.startColumn,endColumn:startRange.startColumn+ranges.endColumn},worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)return!1;const{startRow,endRow,startColumn,endColumn}=targetRange;let hasPermission=!0;for(let row=startRow;row<=endRow;row++)for(let col=startColumn;col<=endColumn;col++){const permission=(_c=(_b=worksheet.getCell(row,col))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[D.Edit])===!1){hasPermission=!1;break}}return hasPermission||this._sheetPermissionInterceptorBaseController.haveNotPermissionHandle(this._localService.t("permission.dialog.pasteErr")),hasPermission},"onBeforePaste")}))}},__name(_a43,"SheetPermissionInterceptorClipboardController"),_a43);SheetPermissionInterceptorClipboardController=__decorateClass$f([__decorateParam$f(0,core.IUniverInstanceService),__decorateParam$f(1,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$f(2,core.Inject(core.LocaleService)),__decorateParam$f(3,core.Inject(ISheetClipboardService)),__decorateParam$f(4,core.Inject(exports.SheetPermissionInterceptorBaseController))],SheetPermissionInterceptorClipboardController);var __defProp$e=Object.defineProperty,__getOwnPropDesc$e=Object.getOwnPropertyDescriptor,__decorateClass$e=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$e(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$e(target,key,result),result},"__decorateClass$e"),__decorateParam$e=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$e");const STATUS_BAR_PERMISSION_CORRECT=core.createInterceptorKey("statusBarPermissionCorrect"),_CalculateValueSet=class _CalculateValueSet{constructor(){__publicField(this,"_sum",0);__publicField(this,"_count",0);__publicField(this,"_countNumber",0);__publicField(this,"_min",Number.POSITIVE_INFINITY);__publicField(this,"_max",Number.NEGATIVE_INFINITY)}add(value){const v=value==null?void 0:value.v,t=value==null?void 0:value.t;v!=null&&(typeof v=="number"&&t!==core.CellValueType.STRING&&(this._sum+=v,this._countNumber++,this._min=Math.min(this._min,v),this._max=Math.max(this._max,v)),this._count++)}getResults(){return{sum:this._sum,count:this._countNumber,countA:this._count,min:this._min,max:this._max}}};__name(_CalculateValueSet,"CalculateValueSet");let CalculateValueSet=_CalculateValueSet;function calculateValues(valueSet){const{sum,count,countA,min,max}=valueSet.getResults();return[{func:engineFormula.FUNCTION_NAMES_STATISTICAL.MAX,value:max},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.MIN,value:min},{func:engineFormula.FUNCTION_NAMES_MATH.SUM,value:sum},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.COUNTA,value:countA},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.COUNT,value:count},{func:engineFormula.FUNCTION_NAMES_STATISTICAL.AVERAGE,value:sum/count}]}__name(calculateValues,"calculateValues");var _a44;exports.StatusBarController=(_a44=class extends core.Disposable{constructor(_univerInstanceService,_selectionManagerService,_statusBarService,_commandService,_numfmtService){super();__publicField(this,"interceptor",new core.InterceptorManager({STATUS_BAR_PERMISSION_CORRECT}));this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._statusBarService=_statusBarService,this._commandService=_commandService,this._numfmtService=_numfmtService,this._init()}_init(){this._registerSelectionListener()}_registerSelectionListener(){const _statisticsHandler=core.debounce(selections=>{var _a61;const primary=(_a61=selections[selections.length-1])==null?void 0:_a61.primary;this._calculateSelection(selections.map(selection=>selection.range),primary)},100);this.disposeWithMe(core.toDisposable(this._selectionManagerService.selectionMoving$.subscribe(selections=>{selections&&_statisticsHandler(selections)}))),this.disposeWithMe(core.toDisposable(this._selectionManagerService.selectionMoveEnd$.subscribe(selections=>{selections&&_statisticsHandler(selections)}))),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id===sheets.SetRangeValuesMutation.id){const selections=this._selectionManagerService.getCurrentSelections();selections&&_statisticsHandler(selections)}}))}_clearResult(){this._statusBarService.setState(null)}getRangeStartEndInfo(range,sheet){return range.rangeType===core.RANGE_TYPE.ALL?{startRow:0,startColumn:0,endRow:sheet.getRowCount()-1,endColumn:sheet.getColumnCount()-1}:range.rangeType===core.RANGE_TYPE.COLUMN?{startRow:0,startColumn:range.startColumn,endRow:sheet.getRowCount()-1,endColumn:range.endColumn}:range.rangeType===core.RANGE_TYPE.ROW?{startRow:range.startRow,startColumn:0,endRow:range.endRow,endColumn:sheet.getColumnCount()-1}:{startRow:range.startRow,startColumn:range.startColumn,endRow:range.endRow,endColumn:range.endColumn}}_calculateSelection(selections,primary){var _a61;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return this._clearResult();const unitId=workbook.getUnitId(),sheet=workbook.getActiveSheet(),sheetId=sheet==null?void 0:sheet.getSheetId();if(!sheetId)return this._clearResult();const sheetData={};if(this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getSheets().forEach(sheet2=>{const sheetConfig=sheet2.getConfig();sheetData[sheet2.getSheetId()]={cellData:new core.ObjectMatrix(sheetConfig.cellData),rowCount:sheetConfig.rowCount,columnCount:sheetConfig.columnCount,rowData:sheetConfig.rowData,columnData:sheetConfig.columnData}}),selections!=null&&selections.length){const realSelections=[];selections.forEach(selection=>{const{startRow:start,endRow:end}=selection;let prev=null;for(let r2=start;r2<=end;r2++)sheet.getRowVisible(r2)?prev===null&&(prev=r2):prev!==null&&(realSelections.push({...selection,startRow:prev,endRow:r2-1}),prev=null);prev!==null&&realSelections.push({...selection,startRow:prev,endRow:end})});const noDuplicate=core.splitIntoGrid(realSelections),calculateValueSet=new CalculateValueSet;for(const range of noDuplicate){const{startRow,startColumn,endColumn,endRow}=this.getRangeStartEndInfo(range,sheet);for(let r2=startRow;r2<=endRow;r2++)for(let c=startColumn;c<=endColumn;c++){const value=sheet.getCell(r2,c);calculateValueSet.add(value)}}const calcResult=calculateValues(calculateValueSet);if(calcResult.every(r2=>r2===void 0))return;let pattern=null;if(primary){const{actualRow,actualColumn}=primary;pattern=(_a61=this._numfmtService.getValue(unitId,sheetId,actualRow,actualColumn))==null?void 0:_a61.pattern}const newState={values:calcResult.filter(r2=>r2!==void 0),pattern};this._statusBarService.setState(newState)}else this._clearResult()}},__name(_a44,"StatusBarController"),_a44);exports.StatusBarController=__decorateClass$e([__decorateParam$e(0,core.IUniverInstanceService),__decorateParam$e(1,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$e(2,IStatusBarService),__decorateParam$e(3,core.ICommandService),__decorateParam$e(4,core.Inject(sheets.INumfmtService))],exports.StatusBarController);var __defProp$d=Object.defineProperty,__getOwnPropDesc$d=Object.getOwnPropertyDescriptor,__decorateClass$d=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$d(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$d(target,key,result),result},"__decorateClass$d"),__decorateParam$d=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$d"),_a45;let SheetPermissionInterceptorFormulaRenderController=(_a45=class extends core.RxDisposable{constructor(_context,_univerInstanceService,_permissionService,_statusBarController,_rangeProtectionCache){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._context=_context,this._univerInstanceService=_univerInstanceService,this._permissionService=_permissionService,this._statusBarController=_statusBarController,this._rangeProtectionCache=_rangeProtectionCache,this._initStatusBarPermissionInterceptor()}_initStatusBarPermissionInterceptor(){this.disposeWithMe(this._statusBarController.interceptor.intercept(this._statusBarController.interceptor.getInterceptPoints().STATUS_BAR_PERMISSION_CORRECT,{priority:100,handler:__name((defaultValue,originValue)=>{var _a61;const target=sheets.getSheetCommandTarget(this._univerInstanceService);if(!target)return defaultValue!=null?defaultValue:[];const{worksheet,unitId,subUnitId}=target;return((_a61=this._permissionService.getPermissionPoint(new sheets.WorksheetViewPermission(unitId,subUnitId).id))==null?void 0:_a61.value)===!1?originValue.forEach(item=>{const itemValue=item.getArrayValue();itemValue.forEach((row,rowIndex)=>{row.forEach((col,colIndex)=>{itemValue[rowIndex][colIndex]=engineFormula.NullValueObject.create()})})}):originValue.forEach(item=>{const itemValue=item.getArrayValue(),startRow=item.getCurrentRow(),startCol=item.getCurrentColumn();itemValue.forEach((row,rowIndex)=>{row.forEach((col,colIndex)=>{var _a62;if(((_a62=worksheet.getCellRaw(rowIndex+startRow,colIndex+startCol))==null?void 0:_a62.v)===void 0)return;const permission=this._rangeProtectionCache.getCellInfo(unitId,subUnitId,rowIndex+startRow,colIndex+startCol);(permission==null?void 0:permission[D.View])===!1&&(itemValue[rowIndex][colIndex]=engineFormula.NullValueObject.create())})})}),originValue},"handler")}))}},__name(_a45,"SheetPermissionInterceptorFormulaRenderController"),_a45);SheetPermissionInterceptorFormulaRenderController=__decorateClass$d([__decorateParam$d(1,core.IUniverInstanceService),__decorateParam$d(2,core.IPermissionService),__decorateParam$d(3,core.Inject(exports.StatusBarController)),__decorateParam$d(4,core.Inject(sheets.RangeProtectionCache))],SheetPermissionInterceptorFormulaRenderController);const sheetPermissionPanelFooter="univer-sheet-permission-panel-footer",sheetPermissionPanelFooterCancel="univer-sheet-permission-panel-footer-cancel",sheetPermissionPanelAddButton="univer-sheet-permission-panel-add-button",styles$7={sheetPermissionPanelFooter,sheetPermissionPanelFooterCancel,sheetPermissionPanelAddButton},SheetPermissionPanelAddFooter=__name(()=>{var _a61,_b,_c,_d;const sidebarService=core.useDependency(ui.ISidebarService),localeService=core.useDependency(core.LocaleService),univerInstanceService=core.useDependency(core.IUniverInstanceService),permissionService=core.useDependency(core.IPermissionService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),activeSheet$=ui.useObservable(workbook.activeSheet$),workbookEditPermission=(_b=(_a61=permissionService.getPermissionPoint(new sheets.WorkbookEditablePermission(unitId).id))==null?void 0:_a61.value)!=null?_b:!1,workbookManagePermission=(_d=(_c=permissionService.getPermissionPoint(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_c.value)!=null?_d:!1,hasSetProtectPermission=workbookEditPermission&&workbookManagePermission,sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),worksheetProtectionRuleModel=core.useDependency(sheets.WorksheetProtectionRuleModel),subUnitId=activeSheet$==null?void 0:activeSheet$.getSheetId();if(!subUnitId)return null;const worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return!hasSetProtectPermission||worksheetRule?null:jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsxs(design.Button,{className:styles$7.sheetPermissionPanelAddButton,type:"primary",onClick:__name(()=>{sheetPermissionPanelModel.resetRule();const sidebarProps={header:{title:`${localeService.t("permission.panel.title")}`},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail:!0},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail:!0}};sidebarService.open(sidebarProps)},"onClick"),children:[jsxRuntimeExports.jsx("div",{children:"+ "}),localeService.t("permission.button.addNewPermission")]})})},"SheetPermissionPanelAddFooter"),SheetPermissionPanelDetailFooter=__name(()=>{const sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),activeRule=ui.useObservable(sheetPermissionPanelModel.rule$,sheetPermissionPanelModel.rule),sidebarService=core.useDependency(ui.ISidebarService),authzIoService=core.useDependency(core.IAuthzIoService),localeService=core.useDependency(core.LocaleService),commandService=core.useDependency(core.ICommandService),sheetPermissionUserManagerService=core.useDependency(SheetPermissionUserManagerService),rangeErrMsg=ui.useObservable(sheetPermissionPanelModel.rangeErrorMsg$);return jsxRuntimeExports.jsxs("div",{className:styles$7.sheetPermissionPanelFooter,children:[jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(async()=>{if(!activeRule.name||rangeErrMsg)return;let collaborators=sheetPermissionUserManagerService.selectUserList;activeRule.editStatus===editState.onlyMe&&(collaborators=[],sheetPermissionUserManagerService.setSelectUserList([]));const scopeObj={read:activeRule.viewStatus===viewState.othersCanView?T.AllCollaborator:T.SomeCollaborator,edit:activeRule.editStatus===editState.designedUserCanEdit?T.SomeCollaborator:T.OneSelf};if(activeRule.editStatus===editState.designedUserCanEdit&&collaborators.length===0&&(collaborators=[],scopeObj.edit=T.OneSelf),activeRule.permissionId){const oldRule=sheetPermissionPanelModel.oldRule,isSameCollaborators=getUserListEqual(collaborators.filter(user=>user.role===S.Editor),sheetPermissionUserManagerService.oldCollaboratorList.filter(user=>user.role===S.Editor)),isSameReadStatus=(oldRule==null?void 0:oldRule.viewStatus)===activeRule.viewStatus,isSameEditStatus=(oldRule==null?void 0:oldRule.editStatus)===activeRule.editStatus,ruleConfigIsOrigin=activeRule.unitType===(oldRule==null?void 0:oldRule.unitType)&&activeRule.name===oldRule.name&&activeRule.description===oldRule.description&&activeRule.ranges===oldRule.ranges,collaboratorsIsChange=!isSameCollaborators||!isSameReadStatus||!isSameEditStatus;if(ruleConfigIsOrigin&&collaboratorsIsChange)await authzIoService.update({objectType:activeRule.unitType,objectID:activeRule.permissionId,unitID:activeRule.unitId,share:void 0,name:"",strategies:[],scope:scopeObj,collaborators:{collaborators}});else{let newPermissionId=activeRule.permissionId;collaboratorsIsChange&&(activeRule.unitType===L.Worksheet?newPermissionId=await authzIoService.create({worksheetObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,strategies:[{role:S.Editor,action:D.Edit},{role:S.Reader,action:D.View}],scope:scopeObj},objectType:L.Worksheet}):newPermissionId=await authzIoService.create({selectRangeObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,scope:scopeObj},objectType:L.SelectRange})),commandService.executeCommand(SetProtectionCommand.id,{rule:{...activeRule,permissionId:newPermissionId}})}}else if(activeRule.unitType===L.Worksheet){const permissionId=await authzIoService.create({worksheetObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,strategies:[{role:S.Editor,action:D.Edit},{role:S.Reader,action:D.View}],scope:scopeObj},objectType:L.Worksheet}),{ranges:_range=[],...sheetRule}=activeRule;sheetRule.permissionId=permissionId,commandService.executeCommand(AddWorksheetProtectionCommand.id,{rule:sheetRule,unitId:activeRule.unitId})}else if(activeRule.unitType===L.SelectRange){const permissionId=await authzIoService.create({selectRangeObject:{collaborators,unitID:activeRule.unitId,name:activeRule.name,scope:scopeObj},objectType:L.SelectRange});commandService.executeCommand(sheets.AddRangeProtectionCommand.id,{rule:activeRule,permissionId})}sheetPermissionPanelModel.resetRule(),sheetPermissionUserManagerService.reset();const sidebarProps={header:{title:`${localeService.t("permission.panel.title")}`},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail:!1},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail:!1}};sidebarService.open(sidebarProps)},"onClick"),children:localeService.t("permission.button.confirm")}),jsxRuntimeExports.jsx(design.Button,{className:styles$7.sheetPermissionPanelFooterCancel,onClick:__name(()=>{sheetPermissionPanelModel.reset(),sheetPermissionUserManagerService.reset(),sidebarService.close()},"onClick"),children:localeService.t("permission.button.cancel")})]})},"SheetPermissionPanelDetailFooter"),SheetPermissionPanelFooter=__name(({showDetail})=>showDetail?jsxRuntimeExports.jsx(SheetPermissionPanelDetailFooter,{}):jsxRuntimeExports.jsx(SheetPermissionPanelAddFooter,{}),"SheetPermissionPanelFooter"),useHighlightRange=__name((ranges=[])=>{const markSelectionService=core.useDependency(IMarkSelectionService);React.useEffect(()=>{const ids=ranges.map(range=>markSelectionService.addShape({range,style:{hasAutoFill:!1,fill:"rgba(73, 184, 17, 0.05)",strokeWidth:1,stroke:"#49B811",widgets:{}},primary:{startColumn:range.startColumn,endColumn:range.endColumn,startRow:range.startRow,endRow:range.endRow,actualRow:range.startRow,actualColumn:range.startColumn,isMerged:!1,isMergedMainCell:!1}}));return()=>{ids.forEach(id=>{id&&markSelectionService.removeShape(id)})}},[ranges])},"useHighlightRange"),panelListEmptyBase64="",sheetPermissionListPanelWrapper="univer-sheet-permission-list-panel-wrapper",sheetPermissionListPanelHeader="univer-sheet-permission-list-panel-header",sheetPermissionListPanelHeaderType="univer-sheet-permission-list-panel-header-type",sheetPermissionListPanelHeaderTypeBottom="univer-sheet-permission-list-panel-header-type-bottom",sheetPermissionListPanelHeaderSelect="univer-sheet-permission-list-panel-header-select",sheetPermissionListItemHeaderIcon="univer-sheet-permission-list-item-header-icon",sheetPermissionListItem="univer-sheet-permission-list-item",sheetPermissionListItemHeader="univer-sheet-permission-list-item-header",sheetPermissionListItemHeaderName="univer-sheet-permission-list-item-header-name",sheetPermissionListItemHeaderOperator="univer-sheet-permission-list-item-header-operator",sheetPermissionListItemSplit="univer-sheet-permission-list-item-split",sheetPermissionListItemContentEdit="univer-sheet-permission-list-item-content-edit",sheetPermissionListItemContentView="univer-sheet-permission-list-item-content-view",sheetPermissionListItemContentDesc="univer-sheet-permission-list-item-content-desc",sheetPermissionListEmpty="univer-sheet-permission-list-empty",sheetPermissionListEmptyText="univer-sheet-permission-list-empty-text",sheetPermissionListItemContentTitle="univer-sheet-permission-list-item-content-title",sheetPermissionListItemContentSub="univer-sheet-permission-list-item-content-sub",styles$6={sheetPermissionListPanelWrapper,sheetPermissionListPanelHeader,sheetPermissionListPanelHeaderType,sheetPermissionListPanelHeaderTypeBottom,sheetPermissionListPanelHeaderSelect,sheetPermissionListItemHeaderIcon,sheetPermissionListItem,sheetPermissionListItemHeader,sheetPermissionListItemHeaderName,sheetPermissionListItemHeaderOperator,sheetPermissionListItemSplit,sheetPermissionListItemContentEdit,sheetPermissionListItemContentView,sheetPermissionListItemContentDesc,sheetPermissionListEmpty,sheetPermissionListEmptyText,sheetPermissionListItemContentTitle,sheetPermissionListItemContentSub},SheetPermissionPanelList=__name(()=>{const[isCurrentSheet,setIsCurrentSheet]=React.useState(!0),[forceUpdateFlag,setForceUpdateFlag]=React.useState(!1),sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),localeService=core.useDependency(core.LocaleService),rangeProtectionRuleModel=core.useDependency(sheets.RangeProtectionRuleModel),worksheetProtectionModel=core.useDependency(sheets.WorksheetProtectionRuleModel),workbook=core.useDependency(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),commandService=core.useDependency(core.ICommandService),sidebarService=core.useDependency(ui.ISidebarService),authzIoService=core.useDependency(core.IAuthzIoService),permissionService=core.useDependency(core.IPermissionService),currentUser=core.useDependency(core.UserManagerService).getCurrentUser(),[currentRuleRanges,currentRuleRangesSet]=React.useState([]),_sheetRuleRefresh=ui.useObservable(worksheetProtectionModel.ruleRefresh$,""),_rangeRuleRefresh=ui.useObservable(rangeProtectionRuleModel.ruleRefresh$,""),getRuleList=React.useCallback(async isCurrentSheet2=>{var _a61;const worksheet=workbook.getActiveSheet(),unitId2=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),allRangePermissionId=[],allSheetPermissionId=[];workbook.getSheets().forEach(sheet=>{const sheetId=sheet.getSheetId();rangeProtectionRuleModel.getSubunitRuleList(unitId2,sheetId).forEach(rule=>{rule.permissionId&&rule.name&&allRangePermissionId.push(rule.permissionId)});const worksheetPermissionRule=worksheetProtectionModel.getRule(unitId2,sheetId);worksheetPermissionRule!=null&&worksheetPermissionRule.permissionId&&worksheetPermissionRule.name&&allSheetPermissionId.push(worksheetPermissionRule.permissionId)});const allPermissionId=[...allRangePermissionId,...allSheetPermissionId],allPermissionRule=await authzIoService.list({objectIDs:allPermissionId,unitID:unitId2,actions:[D.View,D.Edit]}),subUnitPermissionIds=rangeProtectionRuleModel.getSubunitRuleList(unitId2,subUnitId).map(item=>item.permissionId),sheetPermissionId=(_a61=worksheetProtectionModel.getRule(unitId2,subUnitId))==null?void 0:_a61.permissionId;sheetPermissionId&&subUnitPermissionIds.push(sheetPermissionId);const subUnitRuleList=allPermissionRule.filter(item=>{var _a62;return subUnitPermissionIds.includes(item.objectID)||item.objectID===((_a62=worksheetProtectionModel.getRule(unitId2,subUnitId))==null?void 0:_a62.permissionId)});return isCurrentSheet2?subUnitRuleList:allPermissionRule},[]),[ruleList,setRuleList]=React.useState([]);React.useEffect(()=>{const subscription=rxjs.merge(rangeProtectionRuleModel.ruleChange$,worksheetProtectionModel.ruleChange$).subscribe(async()=>{const ruleList2=await getRuleList(isCurrentSheet);setRuleList(ruleList2)});return()=>{subscription.unsubscribe()}},[isCurrentSheet]),React.useEffect(()=>{const subscribe=workbook.activeSheet$.subscribe(async()=>{const ruleList2=await getRuleList(!0);setRuleList(ruleList2)});return()=>{subscribe.unsubscribe()}},[]),React.useEffect(()=>{__name(async()=>{if(_sheetRuleRefresh||_rangeRuleRefresh){const ruleList2=await getRuleList(!0);setRuleList(ruleList2)}},"getRuleListByRefresh")()},[_sheetRuleRefresh,_rangeRuleRefresh]);const handleDelete=__name(rule=>{const{unitId:unitId2,subUnitId,unitType}=rule;let res;unitType===L.Worksheet?res=commandService.executeCommand(DeleteWorksheetProtectionCommand.id,{unitId:unitId2,subUnitId,rule}):unitType===L.SelectRange&&(res=commandService.executeCommand(sheets.DeleteRangeProtectionCommand.id,{unitId:unitId2,subUnitId,rule})),res&&(setForceUpdateFlag(!forceUpdateFlag),rule.ranges===currentRuleRanges&&currentRuleRangesSet([]))},"handleDelete");useHighlightRange(currentRuleRanges);const allRuleMap=new Map;workbook.getSheets().forEach(sheet=>{const sheetId=sheet.getSheetId();rangeProtectionRuleModel.getSubunitRuleList(unitId,sheetId).forEach(rule=>{allRuleMap.set(rule.permissionId,rule)});const sheetRule=worksheetProtectionModel.getRule(unitId,sheetId);sheetRule&&allRuleMap.set(sheetRule==null?void 0:sheetRule.permissionId,sheetRule)});const handleEdit=__name(rule=>{sheetPermissionPanelModel.setRule(rule),sheetPermissionPanelModel.setOldRule(rule),rule.subUnitId!==workbook.getActiveSheet().getSheetId()&&commandService.executeCommand(sheets.SetWorksheetActiveOperation.id,{unitId:rule.unitId,subUnitId:rule.subUnitId});const sidebarProps={header:{title:"permission.panel.title"},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail:!0},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail:!0}};sidebarService.open(sidebarProps)},"handleEdit"),handleChangeHeaderType=__name(async isCurrentSheet2=>{setIsCurrentSheet(isCurrentSheet2);const ruleList2=await getRuleList(isCurrentSheet2);setRuleList(ruleList2)},"handleChangeHeaderType");return jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelWrapper,children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelHeader,children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelHeaderType,onClick:__name(()=>handleChangeHeaderType(!0),"onClick"),children:[jsxRuntimeExports.jsx("div",{className:clsx({[styles$6.sheetPermissionListPanelHeaderSelect]:isCurrentSheet}),children:localeService.t("permission.panel.currentSheet")}),isCurrentSheet&&jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListPanelHeaderTypeBottom})]}),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListPanelHeaderType,onClick:__name(()=>handleChangeHeaderType(!1),"onClick"),children:[jsxRuntimeExports.jsx("div",{className:clsx({[styles$6.sheetPermissionListPanelHeaderSelect]:!isCurrentSheet}),children:localeService.t("permission.panel.allSheet")}),!isCurrentSheet&&jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListPanelHeaderTypeBottom})]})]}),(ruleList==null?void 0:ruleList.length)>0?jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListPanelContent,children:ruleList==null?void 0:ruleList.map(item=>{var _a61,_b,_c,_d,_e;const rule=allRuleMap.get(item.objectID);if(!rule)return null;const editAction=item.actions.find(action=>action.action===D.Edit),editPermission=editAction==null?void 0:editAction.allowed,viewAction=item.actions.find(action=>action.action===D.View),viewPermission=viewAction==null?void 0:viewAction.allowed,hasManagerPermission=((_b=(_a61=permissionService.getPermissionPoint(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_a61.value)!=null?_b:!1)||currentUser.userID===((_c=item.creator)==null?void 0:_c.userID);let ruleName="";const targetSheet=workbook.getSheetBySheetId(rule.subUnitId),targetName=targetSheet==null?void 0:targetSheet.getName();if(rule.unitType===L.SelectRange){const ranges=rule.ranges,rangeStr=ranges!=null&&ranges.length?ranges.map(range=>{const v=engineFormula.serializeRange(range);return v==="NaN"?"":v}).filter(r2=>!!r2).join(","):"";ruleName=`${targetName}(${rangeStr})`}else rule.unitType===L.Worksheet&&(ruleName=targetName||"");return jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItem,onMouseMove:__name(()=>{const{subUnitId,unitType}=rule,activeSheet=workbook.getActiveSheet();if(!activeSheet)return!1;const activeSubUnitId=activeSheet.getSheetId();if(subUnitId!==activeSubUnitId)return!1;if(unitType===L.SelectRange){const ranges=rule.ranges||[];ranges!==currentRuleRanges&&currentRuleRangesSet(ranges)}else if(unitType===L.Worksheet){const ranges=[{startRow:0,endRow:activeSheet.getRowCount()-1,startColumn:0,endColumn:activeSheet.getColumnCount()-1}];ranges!==currentRuleRanges&&currentRuleRangesSet(ranges)}},"onMouseMove"),onMouseLeave:__name(()=>currentRuleRangesSet([]),"onMouseLeave"),children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemHeader,children:[jsxRuntimeExports.jsx(design.Tooltip,{title:ruleName,children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemHeaderName,children:ruleName})}),hasManagerPermission&&jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemHeaderOperator,children:[jsxRuntimeExports.jsx(design.Tooltip,{title:localeService.t("permission.panel.edit"),children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemHeaderIcon,onClick:__name(()=>handleEdit(rule),"onClick"),children:jsxRuntimeExports.jsx(WriteSingle,{})})}),jsxRuntimeExports.jsx(design.Tooltip,{title:localeService.t("permission.panel.delete"),children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemHeaderIcon,onClick:__name(()=>handleDelete(rule),"onClick"),children:jsxRuntimeExports.jsx(DeleteSingle,{})})})]})]}),jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemSplit}),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemContent,children:[jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemContentEdit,children:[jsxRuntimeExports.jsx(design.Tooltip,{title:(_d=item.creator)==null?void 0:_d.userID,children:jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsx(design.Avatar,{src:(_e=item.creator)==null?void 0:_e.avatar,style:{marginRight:6},size:24})})}),jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentTitle,children:localeService.t("permission.panel.created")}),jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentSub,children:editPermission?`${localeService.t("permission.panel.iCanEdit")}`:`${localeService.t("permission.panel.iCanNotEdit")}`})]}),jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListItemContentView,children:[jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentTitle,children:localeService.t("permission.panel.viewPermission")}),jsxRuntimeExports.jsx("span",{className:styles$6.sheetPermissionListItemContentSub,children:viewPermission?`${localeService.t("permission.panel.iCanView")}`:`${localeService.t("permission.panel.iCanNotView")}`})]}),rule.description&&jsxRuntimeExports.jsx(design.Tooltip,{title:rule.description,children:jsxRuntimeExports.jsx("div",{className:styles$6.sheetPermissionListItemContentDesc,children:rule.description})})]})]},item.objectID)})}):jsxRuntimeExports.jsxs("div",{className:styles$6.sheetPermissionListEmpty,children:[jsxRuntimeExports.jsx("img",{width:240,height:120,src:panelListEmptyBase64,alt:""}),jsxRuntimeExports.jsx("p",{className:styles$6.sheetPermissionListEmptyText,children:localeService.t("permission.dialog.listEmpty")})]})]})},"SheetPermissionPanelList"),spinContainer="univer-spin-container",spinOverlay="univer-spin-overlay",spinner="univer-spinner",spin="univer-spin",contentBlur="univer-content-blur",styles$5={spinContainer,spinOverlay,spinner,spin,contentBlur},Spin=__name(({loading,children})=>jsxRuntimeExports.jsxs("div",{className:styles$5.spinContainer,children:[loading&&jsxRuntimeExports.jsx("div",{className:styles$5.spinOverlay,children:jsxRuntimeExports.jsx("div",{className:styles$5.spinner})}),jsxRuntimeExports.jsx("div",{className:loading?styles$5.contentBlur:"",children})]}),"Spin"),UserEmptyBase64="",permissionPanelDetailWrapper="univer-permission-panel-detail-wrapper",radioGroupVertical="univer-radio-group-vertical",sheetPermissionDesignPersonPanel="univer-sheet-permission-design-person-panel",sheetPermissionDesignPersonPanelHeader="univer-sheet-permission-design-person-panel-header",sheetPermissionDesignPersonPanelHeaderAdd="univer-sheet-permission-design-person-panel-header-add",sheetPermissionDesignPersonPanelSplit="univer-sheet-permission-design-person-panel-split",sheetPermissionDesignPersonPanelContentItem="univer-sheet-permission-design-person-panel-content-item",sheetPermissionDesignPersonPanelContentItemName="univer-sheet-permission-design-person-panel-content-item-name",sheetPermissionDesignPersonPanelContentItemSelect="univer-sheet-permission-design-person-panel-content-item-select",sheetPermissionDesignPersonPanelContent="univer-sheet-permission-design-person-panel-content",sheetPermissionUserListEmpty$1="univer-sheet-permission-user-list-empty",sheetPermissionUserListEmptyText$1="univer-sheet-permission-user-list-empty-text",sheetPermissionPanelTitle="univer-sheet-permission-panel-title",permissionRangeSelector="univer-permission-range-selector",permissionRangeSelectorError="univer-permission-range-selector-error",sheetPermissionPanelNameInputError="univer-sheet-permission-panel-name-input-error",permissionRangeSelectorErrorText="univer-permission-range-selector-error-text",sheetPermissionPanelNameInputErrorText="univer-sheet-permission-panel-name-input-error-text",styles$4={permissionPanelDetailWrapper,radioGroupVertical,sheetPermissionDesignPersonPanel,sheetPermissionDesignPersonPanelHeader,sheetPermissionDesignPersonPanelHeaderAdd,sheetPermissionDesignPersonPanelSplit,sheetPermissionDesignPersonPanelContentItem,sheetPermissionDesignPersonPanelContentItemName,sheetPermissionDesignPersonPanelContentItemSelect,sheetPermissionDesignPersonPanelContent,sheetPermissionUserListEmpty:sheetPermissionUserListEmpty$1,sheetPermissionUserListEmptyText:sheetPermissionUserListEmptyText$1,sheetPermissionPanelTitle,permissionRangeSelector,permissionRangeSelectorError,sheetPermissionPanelNameInputError,permissionRangeSelectorErrorText,sheetPermissionPanelNameInputErrorText},SheetPermissionPanelDetail=__name(({fromSheetBar})=>{var _a61,_b;const localeService=core.useDependency(core.LocaleService),dialogService=core.useDependency(ui.IDialogService),univerInstanceService=core.useDependency(core.IUniverInstanceService),selectionManagerService=core.useDependency(sheets.SheetsSelectionsService),sheetPermissionPanelModel=core.useDependency(SheetPermissionPanelModel),activeRule=ui.useObservable(sheetPermissionPanelModel.rule$,sheetPermissionPanelModel.rule),userManagerService=core.useDependency(core.UserManagerService),sheetPermissionUserManagerService=core.useDependency(SheetPermissionUserManagerService),authzIoService=core.useDependency(core.IAuthzIoService),sidebarService=core.useDependency(ui.ISidebarService),rangeProtectionRuleModel=core.useDependency(sheets.RangeProtectionRuleModel),worksheetRuleModel=core.useDependency(sheets.WorksheetProtectionRuleModel),componentManager=core.useDependency(ui.ComponentManager),RangeSelector=React.useMemo(()=>componentManager.get(RANGE_SELECTOR_COMPONENT_KEY),[]),rangeErrorMsg=ui.useObservable(sheetPermissionPanelModel.rangeErrorMsg$),rangeSelectorActionsRef=React.useRef({}),[isFocusRangeSelector,isFocusRangeSelectorSet]=React.useState(!1),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),selectUserList=ui.useObservable(sheetPermissionUserManagerService.selectUserList$,sheetPermissionUserManagerService.selectUserList),[editorGroupValue,setEditorGroupValue]=React.useState(selectUserList.length?editState.designedUserCanEdit:editState.onlyMe),[viewGroupValue,setViewGroupValue]=React.useState(viewState.othersCanView),[loading,setLoading]=React.useState(!!(activeRule!=null&&activeRule.permissionId)),[rangeInitialization,setRangeInitialization]=React.useState(!1),handleAddPerson=__name(async()=>{const userList=await authzIoService.listCollaborators({objectID:unitId,unitID:unitId});userList.forEach(user=>{user!=null&&user.subject&&userManagerService.addUser(user.subject)}),sheetPermissionUserManagerService.setUserList(userList),dialogService.open({id:UNIVER_SHEET_PERMISSION_USER_DIALOG_ID,title:{title:""},children:{label:UNIVER_SHEET_PERMISSION_USER_DIALOG},width:280,destroyOnClose:!0,onClose:__name(()=>dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID),"onClose"),className:"sheet-permission-user-dialog"})},"handleAddPerson"),checkRangeValid=__name(permissionRanges=>{let rangeErrorString="";if(permissionRanges.length===0)rangeErrorString=localeService.t("permission.panel.emptyRangeError");else if(permissionRanges.length>1){let hasLap=!1;for(let i=0;i<permissionRanges.length;i++){for(let j=i+1;j<permissionRanges.length;j++)if(core.Rectangle.intersects(permissionRanges[i],permissionRanges[j])){hasLap=!0;break}if(hasLap)break}hasLap&&(rangeErrorString=localeService.t("permission.panel.rangeOverlapError"))}if(!rangeErrorString){if(worksheetRuleModel.getRule(unitId,subUnitId)&&!(activeRule!=null&&activeRule.permissionId))return rangeErrorString=localeService.t("permission.panel.rangeOverlapOverPermissionError"),rangeErrorString;const lapRule=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.permissionId!==(activeRule==null?void 0:activeRule.permissionId)).find(rule=>rule.ranges.some(ruleRange=>permissionRanges.some(r2=>core.Rectangle.intersects(ruleRange,r2))));(lapRule==null?void 0:lapRule.ranges.find(range=>permissionRanges.some(r2=>core.Rectangle.intersects(range,r2))))&&(rangeErrorString=localeService.t("permission.panel.rangeOverlapOverPermissionError"))}return rangeErrorString===""?void 0:rangeErrorString},"checkRangeValid");React.useEffect(()=>{var _a62,_b2;if(activeRule==null?void 0:activeRule.permissionId){activeRule.unitType===L.Worksheet&&sheetPermissionPanelModel.setRule({ranges:[{startRow:0,startColumn:0,endRow:worksheet.getRowCount()-1,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL}]});return}fromSheetBar&&(selectionManagerService.clearCurrentSelections(),selectionManagerService.addSelections([{primary:null,style:null,range:{startRow:0,startColumn:0,endRow:worksheet.getRowCount()-1,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL}}]));const ranges=(_b2=(_a62=selectionManagerService.getCurrentSelections())==null?void 0:_a62.map(s=>s.range))!=null?_b2:[],rangeErrorString=checkRangeValid(ranges);sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString);const rangeStr2=ranges!=null&&ranges.length?ranges.map(range=>{const v=engineFormula.serializeRange(range);return v==="NaN"?"":v}).filter(r2=>!!r2).join(","):"",sheetName=worksheet.getName();sheetPermissionPanelModel.setRule({ranges,name:fromSheetBar?`${sheetName}`:`${sheetName}(${rangeStr2})`,unitId,subUnitId,unitType:fromSheetBar?L.Worksheet:L.SelectRange}),setRangeInitialization(!0)},[activeRule==null?void 0:activeRule.permissionId,fromSheetBar,selectionManagerService,sheetPermissionPanelModel,subUnitId,unitId,worksheet]),React.useEffect(()=>{const getSelectUserList=__name(async()=>{const permissionId=activeRule==null?void 0:activeRule.permissionId,selectUserList2=(await authzIoService.listCollaborators({objectID:permissionId,unitID:unitId})).filter(user=>user.role===S.Editor);sheetPermissionUserManagerService.setSelectUserList(selectUserList2),sheetPermissionUserManagerService.setOldCollaboratorList(selectUserList2)},"getSelectUserList");activeRule!=null&&activeRule.permissionId?getSelectUserList():(sheetPermissionUserManagerService.setSelectUserList([]),sheetPermissionUserManagerService.setOldCollaboratorList([]))},[activeRule==null?void 0:activeRule.permissionId]),React.useEffect(()=>{if(!activeRule.permissionId){sheetPermissionPanelModel.setRule({viewStatus:viewState.othersCanView});return}__name(async()=>{var _a62,_b2;try{const res=await authzIoService.list({unitID:unitId,objectIDs:[activeRule==null?void 0:activeRule.permissionId],actions:[D.View,D.Edit]});if(!res.length)setViewGroupValue(viewState.othersCanView),setEditorGroupValue(editState.onlyMe),sheetPermissionPanelModel.setRule({viewStatus:viewState.othersCanView,editStatus:editState.onlyMe});else{const isAllCanView=((_a62=res[0].scope)==null?void 0:_a62.read)===T.AllCollaborator,isSomeCanEdit=((_b2=res[0].scope)==null?void 0:_b2.edit)===T.SomeCollaborator,viewValue=isAllCanView?viewState.othersCanView:viewState.noOneElseCanView,editValue=isSomeCanEdit?editState.designedUserCanEdit:editState.onlyMe;setViewGroupValue(viewValue),setEditorGroupValue(editValue),sheetPermissionPanelModel.setRule({viewStatus:viewValue,editStatus:editValue})}}catch(error){console.error(error)}finally{setTimeout(()=>{setLoading(!1)},100)}},"getCollaboratorInit")()},[activeRule.permissionId]),React.useEffect(()=>{__name(async()=>{const userList=await authzIoService.listCollaborators({objectID:unitId,unitID:unitId});userList.forEach(user=>{user!=null&&user.subject&&userManagerService.addUser(user.subject)}),sheetPermissionUserManagerService.setUserList(userList.filter(user=>user.role===S.Editor)),sheetPermissionUserManagerService.setAllUserList(userList.filter(user=>user.role===S.Editor||user.role===S.Reader))},"getListCollaborators")()},[]),React.useEffect(()=>{const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook2)return;const activeSheetSubscribe=workbook2.activeSheet$.subscribe(sheet=>{(sheet==null?void 0:sheet.getSheetId())!==subUnitId&&sidebarService.close()});return()=>{activeSheetSubscribe.unsubscribe()}},[sidebarService,subUnitId,univerInstanceService]);const handleRangeChange=__name(rangeText=>{const newRange=rangeText.split(",").map(engineFormula.deserializeRangeWithSheet).map(item=>item.range);if(newRange.some(i=>!core.isValidRange(i)||i.endColumn<i.startColumn||i.endRow<i.startRow))return;const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet2=workbook2.getActiveSheet(),unitId2=workbook2.getUnitId(),subUnitId2=worksheet2.getSheetId(),transformedRange=newRange.map(range=>{const rowCount=worksheet2.getRowCount(),colCount=worksheet2.getColumnCount();return sheets.setEndForRange(range,rowCount,colCount),range}),rangeErrorString=checkRangeValid(transformedRange);if(sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString),rangeErrorString)return;const sheetName=worksheet2.getName(),rangeStr2=transformedRange.map(range=>{const v=engineFormula.serializeRange(range);return v==="NaN"?"":v}).filter(r2=>!!r2).join(","),rule={ranges:transformedRange,unitId:unitId2,subUnitId:subUnitId2,unitType:L.SelectRange,name:`${sheetName}(${rangeStr2})`};if(rule.ranges.length===1){const{startRow,endRow,startColumn,endColumn}=rule.ranges[0];startRow===0&&endRow===worksheet2.getRowCount()-1&&startColumn===0&&worksheet2.getColumnCount()-1===endColumn&&(rule.unitType=L.Worksheet,rule.name=`${sheetName}`)}sheetPermissionPanelModel.setRule(rule)},"handleRangeChange"),handlePanelClick=__name(e=>{var _a62;const handleOutClick=(_a62=rangeSelectorActionsRef.current)==null?void 0:_a62.handleOutClick;handleOutClick&&handleOutClick(e,isFocusRangeSelectorSet)},"handlePanelClick"),rangeStr=(_a61=activeRule==null?void 0:activeRule.ranges)==null?void 0:_a61.map(i=>engineFormula.serializeRange(i)).join(",");return jsxRuntimeExports.jsx("div",{className:styles$4.permissionPanelDetailWrapper,onClick:handlePanelClick,children:jsxRuntimeExports.jsxs(Spin,{loading,children:[jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.protectedRange"),children:RangeSelector&&rangeInitialization&&jsxRuntimeExports.jsx(RangeSelector,{unitId,errorText:rangeErrorMsg,subUnitId,initValue:rangeStr,onChange:handleRangeChange,isFocus:isFocusRangeSelector,actions:rangeSelectorActionsRef.current})}),jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.permissionDirection"),children:jsxRuntimeExports.jsx(design.Input,{value:(_b=activeRule==null?void 0:activeRule.description)!=null?_b:"",onChange:__name(v=>sheetPermissionPanelModel.setRule({description:v}),"onChange"),placeholder:localeService.t("permission.panel.permissionDirectionPlaceholder")})}),jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.editPermission"),children:jsxRuntimeExports.jsxs(design.RadioGroup,{value:editorGroupValue,onChange:__name(v=>{setEditorGroupValue(v),sheetPermissionPanelModel.setRule({editStatus:v})},"onChange"),className:styles$4.radioGroupVertical,children:[jsxRuntimeExports.jsx(design.Radio,{value:editState.onlyMe,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.onlyICanEdit")})}),jsxRuntimeExports.jsx(design.Radio,{value:editState.designedUserCanEdit,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.designedUserCanEdit")})})]})}),editorGroupValue==="designedUserCanEdit"&&jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionDesignPersonPanel,children:[jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionDesignPersonPanelHeader,children:[jsxRuntimeExports.jsx("span",{children:localeService.t("permission.panel.designedPerson")}),jsxRuntimeExports.jsx("span",{className:styles$4.sheetPermissionDesignPersonPanelHeaderAdd,onClick:handleAddPerson,children:localeService.t("permission.panel.addPerson")})]}),jsxRuntimeExports.jsx("div",{className:styles$4.sheetPermissionDesignPersonPanelSplit}),jsxRuntimeExports.jsx("div",{className:styles$4.sheetPermissionDesignPersonPanelContent,children:(selectUserList==null?void 0:selectUserList.length)>0?selectUserList.map(item=>{var _a62,_b2,_c;return jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionDesignPersonPanelContentItem,children:[jsxRuntimeExports.jsx(design.Avatar,{size:24,src:(_a62=item.subject)==null?void 0:_a62.avatar}),jsxRuntimeExports.jsx("span",{className:styles$4.sheetPermissionDesignPersonPanelContentItemName,children:(_b2=item.subject)==null?void 0:_b2.name}),jsxRuntimeExports.jsx(design.Select,{className:styles$4.sheetPermissionDesignPersonPanelContentItemSelect,value:"edit",onChange:__name(v=>{v==="delete"&&sheetPermissionUserManagerService.setSelectUserList(selectUserList.filter(i=>{var _a63,_b3;return((_a63=i.subject)==null?void 0:_a63.userID)!==((_b3=item.subject)==null?void 0:_b3.userID)}))},"onChange"),options:[{label:`${localeService.t("permission.panel.canEdit")}`,value:"edit"},{label:`${localeService.t("permission.panel.delete")}`,value:"delete"}]})]},(_c=item.subject)==null?void 0:_c.userID)}):jsxRuntimeExports.jsxs("div",{className:styles$4.sheetPermissionUserListEmpty,children:[jsxRuntimeExports.jsx("img",{width:240,height:120,src:UserEmptyBase64,alt:""}),jsxRuntimeExports.jsx("p",{className:styles$4.sheetPermissionUserListEmptyText,children:localeService.t("permission.dialog.userEmpty")})]})})]}),jsxRuntimeExports.jsx(design.FormLayout,{className:styles$4.sheetPermissionPanelTitle,label:localeService.t("permission.panel.viewPermission"),children:jsxRuntimeExports.jsxs(design.RadioGroup,{value:viewGroupValue,onChange:__name(v=>{setViewGroupValue(v),sheetPermissionPanelModel.setRule({viewStatus:v})},"onChange"),className:styles$4.radioGroupVertical,children:[jsxRuntimeExports.jsx(design.Radio,{value:viewState.othersCanView,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.othersCanView")})}),jsxRuntimeExports.jsx(design.Radio,{value:viewState.noOneElseCanView,children:jsxRuntimeExports.jsx("span",{className:styles$4.text,children:localeService.t("permission.panel.noOneElseCanView")})})]})})]})})},"SheetPermissionPanelDetail"),SheetPermissionPanel=__name(({showDetail,fromSheetBar})=>{var _a61;const univerInstanceService=core.useDependency(core.IUniverInstanceService),sheetsSelectionsService=core.useDependency(sheets.SheetsSelectionsService);if(!core.useDependency(SheetPermissionPanelModel).getVisible())return null;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return null;const{worksheet}=target,key=((_a61=sheetsSelectionsService.getCurrentSelections())==null?void 0:_a61.map(selection=>selection.range)).reduce((acc,range)=>acc+engineFormula.serializeRangeWithSheet(worksheet.getName(),range),"");return showDetail?jsxRuntimeExports.jsx(SheetPermissionPanelDetail,{fromSheetBar},key):jsxRuntimeExports.jsx(SheetPermissionPanelList,{},key)},"SheetPermissionPanel"),sheetPermissionDialogWrapper="univer-sheet-permission-dialog-wrapper",sheetPermissionDialogSplit="univer-sheet-permission-dialog-split",sheetPermissionDialogItem="univer-sheet-permission-dialog-item",sheetPermissionUserDialogFooter$1="univer-sheet-permission-user-dialog-footer",sheetPermissionUserDialogFooterConfirm$1="univer-sheet-permission-user-dialog-footer-confirm",sheetPermissionUserDialogButton$1="univer-sheet-permission-user-dialog-button",styles$3={sheetPermissionDialogWrapper,sheetPermissionDialogSplit,sheetPermissionDialogItem,sheetPermissionUserDialogFooter:sheetPermissionUserDialogFooter$1,sheetPermissionUserDialogFooterConfirm:sheetPermissionUserDialogFooterConfirm$1,sheetPermissionUserDialogButton:sheetPermissionUserDialogButton$1},SheetPermissionDialog=__name(()=>{const localeService=core.useDependency(core.LocaleService),univerInstanceService=core.useDependency(core.IUniverInstanceService),authzIoService=core.useDependency(core.IAuthzIoService),worksheetProtectionPointRuleModel=core.useDependency(sheets.WorksheetProtectionPointModel),dialogService=core.useDependency(ui.IDialogService),permissionService=core.useDependency(core.IPermissionService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const[collaborators,setCollaborators]=React.useState([]),commandService=core.useDependency(core.ICommandService),[loading,setLoading]=React.useState(()=>!!worksheetProtectionPointRuleModel.getRule(workbook.getUnitId(),worksheet.getSheetId())),[permissionMap,setPermissionMap]=React.useState(()=>Object.keys(subUnitPermissionTypeMap).reduce((acc,action)=>(acc[action]={text:localeService.t(`permission.panel.${subUnitPermissionTypeMap[Number(action)]}`),allowed:!0},acc),{}));React.useEffect(()=>{__name(async()=>{const unitId=workbook.getUnitId(),collaborators2=await authzIoService.listCollaborators({objectID:unitId,unitID:unitId});setCollaborators(collaborators2)},"getUserList")()},[]),React.useEffect(()=>{__name(async()=>{const unitId=workbook.getUnitId(),worksheetPointRule=worksheetProtectionPointRuleModel.getRule(unitId,worksheet.getSheetId());if(!worksheetPointRule)return;setLoading(!0);const actions=(await authzIoService.list({unitID:workbook.getUnitId(),objectIDs:[worksheetPointRule.permissionId],actions:defaultWorksheetUnitActionList}))[0].strategies.reduce((p2,c)=>(subUnitPermissionTypeMap[c.action]&&(p2[c.action]={text:localeService.t(`permission.panel.${subUnitPermissionTypeMap[c.action]}`),allowed:c.role!==S.Owner}),p2),{});setPermissionMap(actions),setTimeout(()=>{setLoading(!1)},100)},"getPermissionPoints")()},[]);const handleChangeActionPermission=__name(async()=>{const workbook2=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet2=workbook2==null?void 0:workbook2.getActiveSheet();if(!worksheet2)throw new Error("No active sheet found");const unitId=workbook2.getUnitId(),subUnitId=worksheet2.getSheetId(),pointRule=worksheetProtectionPointRuleModel.getRule(unitId,subUnitId),actions=Object.keys(permissionMap).map(action=>({action:Number(action),role:permissionMap[action].allowed?S.Editor:S.Owner}));let permissionId=pointRule==null?void 0:pointRule.permissionId;permissionId?authzIoService.update({objectType:L.Worksheet,objectID:permissionId,unitID:unitId,strategies:actions,share:void 0,name:"",scope:{read:T.AllCollaborator,edit:T.AllCollaborator},collaborators:void 0}).then(()=>{sheets.getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(unitId,subUnitId),unitActionName=instance.subType,action=actions.find(item=>item.action===unitActionName);action&&permissionService.updatePermissionPoint(instance.id,action.role===S.Editor)})}):(permissionId=await authzIoService.create({objectType:L.Worksheet,worksheetObject:{unitID:unitId,collaborators,name:"",strategies:actions,scope:{read:T.AllCollaborator,edit:T.AllCollaborator}}}),commandService.executeCommand(sheets.SetWorksheetPermissionPointsCommand.id,{rule:{permissionId,unitId,subUnitId}}))},"handleChangeActionPermission");return jsxRuntimeExports.jsx(Spin,{loading,children:jsxRuntimeExports.jsxs("div",{className:styles$3.sheetPermissionDialogWrapper,children:[jsxRuntimeExports.jsx("div",{className:styles$3.sheetPermissionDialogSplit}),Object.keys(permissionMap).map(action=>{const actionItem=permissionMap[action],{text,allowed}=actionItem;return jsxRuntimeExports.jsxs("div",{className:styles$3.sheetPermissionDialogItem,children:[jsxRuntimeExports.jsx("div",{children:text}),jsxRuntimeExports.jsx(design.Switch,{defaultChecked:allowed,onChange:__name(()=>{setPermissionMap({...permissionMap,[action]:{...actionItem,allowed:!allowed}})},"onChange")})]},text)}),jsxRuntimeExports.jsx("div",{className:styles$3.sheetPermissionDialogSplit}),jsxRuntimeExports.jsxs("div",{className:styles$3.sheetPermissionUserDialogFooter,children:[jsxRuntimeExports.jsx(design.Button,{className:styles$3.sheetPermissionUserDialogButton,onClick:__name(()=>{dialogService.close(UNIVER_SHEET_PERMISSION_DIALOG_ID)},"onClick"),children:localeService.t("permission.button.cancel")}),jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(()=>{handleChangeActionPermission(),dialogService.close(UNIVER_SHEET_PERMISSION_DIALOG_ID)},"onClick"),className:clsx(styles$3.sheetPermissionUserDialogFooterConfirm,styles$3.sheetPermissionUserDialogButton),children:localeService.t("permission.button.confirm")})]})]})})},"SheetPermissionDialog"),sheetPermissionUserDialogWrapper="univer-sheet-permission-user-dialog-wrapper",sheetPermissionUserDialogSearchInput="univer-sheet-permission-user-dialog-search-input",sheetPermissionUserList="univer-sheet-permission-user-list",sheetPermissionUserListEmpty="univer-sheet-permission-user-list-empty",sheetPermissionUserListEmptyText="univer-sheet-permission-user-list-empty-text",sheetPermissionUserItem="univer-sheet-permission-user-item",sheetPermissionUserItemName="univer-sheet-permission-user-item-name",sheetPermissionSplit="univer-sheet-permission-split",sheetPermissionUserDialogFooter="univer-sheet-permission-user-dialog-footer",sheetPermissionUserDialogFooterConfirm="univer-sheet-permission-user-dialog-footer-confirm",sheetPermissionUserDialogButton="univer-sheet-permission-user-dialog-button",styles$2={sheetPermissionUserDialogWrapper,sheetPermissionUserDialogSearchInput,sheetPermissionUserList,sheetPermissionUserListEmpty,sheetPermissionUserListEmptyText,sheetPermissionUserItem,sheetPermissionUserItemName,sheetPermissionSplit,sheetPermissionUserDialogFooter,sheetPermissionUserDialogFooterConfirm,sheetPermissionUserDialogButton},SheetPermissionUserDialog=__name(()=>{const[inputValue,setInputValue]=React.useState(""),localeService=core.useDependency(core.LocaleService),dialogService=core.useDependency(ui.IDialogService),sheetPermissionUserManagerService=core.useDependency(SheetPermissionUserManagerService),searchUserList=sheetPermissionUserManagerService.userList.filter(item=>{var _a61;return((_a61=item.subject)==null?void 0:_a61.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase()))&&item.role===S.Editor}),[selectUserInfo,setSelectUserInfo]=React.useState(sheetPermissionUserManagerService.selectUserList),handleChangeUser=__name(item=>{if((selectUserInfo==null?void 0:selectUserInfo.findIndex(v=>{var _a61,_b;return((_a61=v.subject)==null?void 0:_a61.userID)===((_b=item.subject)==null?void 0:_b.userID)}))===-1){const select={...item};setSelectUserInfo([...selectUserInfo,select])}else{const newSelectUserInfo=selectUserInfo.filter(v=>{var _a61,_b;return((_a61=v.subject)==null?void 0:_a61.userID)!==((_b=item.subject)==null?void 0:_b.userID)});setSelectUserInfo(newSelectUserInfo)}},"handleChangeUser");return jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserDialogWrapper,children:[jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionUserDialogSearch,children:jsxRuntimeExports.jsx(design.Input,{placeholder:"search",className:styles$2.sheetPermissionUserDialogSearchInput,value:inputValue,onChange:__name(v=>setInputValue(v),"onChange")})}),jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionUserList,children:(searchUserList==null?void 0:searchUserList.length)>0?jsxRuntimeExports.jsx(jsxRuntimeExports.Fragment,{children:searchUserList==null?void 0:searchUserList.map(item=>{var _a61,_b,_c;return jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserItem,onClick:__name(()=>handleChangeUser(item),"onClick"),children:[jsxRuntimeExports.jsx(design.Avatar,{src:(_a61=item.subject)==null?void 0:_a61.avatar,size:24}),jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionUserItemName,children:(_b=item.subject)==null?void 0:_b.name}),(selectUserInfo==null?void 0:selectUserInfo.findIndex(v=>{var _a62,_b2;return((_a62=v.subject)==null?void 0:_a62.userID)===((_b2=item.subject)==null?void 0:_b2.userID)}))!==-1&&jsxRuntimeExports.jsx("div",{children:jsxRuntimeExports.jsx(CheckMarkSingle,{})})]},(_c=item.subject)==null?void 0:_c.userID)})}):jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserListEmpty,children:[jsxRuntimeExports.jsx("img",{width:240,height:120,src:UserEmptyBase64,alt:""}),jsxRuntimeExports.jsx("p",{className:styles$2.sheetPermissionUserListEmptyText,children:localeService.t("permission.dialog.userEmpty")})]})}),jsxRuntimeExports.jsx("div",{className:styles$2.sheetPermissionSplit}),jsxRuntimeExports.jsxs("div",{className:styles$2.sheetPermissionUserDialogFooter,children:[jsxRuntimeExports.jsx(design.Button,{className:styles$2.sheetPermissionUserDialogButton,onClick:__name(()=>dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID),"onClick"),children:localeService.t("permission.button.cancel")}),jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(()=>{sheetPermissionUserManagerService.setSelectUserList(selectUserInfo),dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID)},"onClick"),className:clsx(styles$2.sheetPermissionUserDialogFooterConfirm,styles$2.sheetPermissionUserDialogButton),children:localeService.t("permission.button.confirm")})]})]})},"SheetPermissionUserDialog"),sheetPermissionAlertDialog="univer-sheet-permission-alert-dialog",sheetPermissionAlertDialogTitle="univer-sheet-permission-alert-dialog-title",sheetPermissionAlertDialogButton="univer-sheet-permission-alert-dialog-button",styles$1={sheetPermissionAlertDialog,sheetPermissionAlertDialogTitle,sheetPermissionAlertDialogButton},AlertDialog=__name(({errorMsg})=>{const localeService=core.useDependency(core.LocaleService),dialogService=core.useDependency(ui.IDialogService);return jsxRuntimeExports.jsxs("div",{className:styles$1.sheetPermissionAlertDialog,children:[jsxRuntimeExports.jsx("h1",{className:styles$1.sheetPermissionAlertDialogTitle,children:localeService.t("permission.dialog.alert")}),jsxRuntimeExports.jsx("p",{children:errorMsg||localeService.t("permission.dialog.alertContent")}),jsxRuntimeExports.jsx("div",{className:styles$1.sheetPermissionAlertDialogButton,children:jsxRuntimeExports.jsx(design.Button,{type:"primary",onClick:__name(()=>{dialogService.close(UNIVER_SHEET_PERMISSION_ALERT_DIALOG_ID)},"onClick"),children:localeService.t("permission.button.confirm")})})]})},"AlertDialog"),base64="",RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY="RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY",RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY="RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY",EXTENSION_CAN_VIEW_Z_INDEX$1=25,EXTENSION_CAN_NOT_VIEW_Z_INDEX$1=80,_RangeProtectionRenderExtension=class _RangeProtectionRenderExtension extends engineRender.SheetExtension{constructor(){super();__publicField(this,"_pattern",null);__publicField(this,"_img",new Image);__publicField(this,"renderCache",new Set);this._img.src=base64}clearCache(){this.renderCache.clear()}draw(ctx,_parentScale,spreadsheetSkeleton){const{worksheet}=spreadsheetSkeleton;worksheet&&(ctx.save(),this._pattern||(this._pattern=ctx.createPattern(this._img,"repeat")),this.renderCache.clear(),core.Range.foreach(spreadsheetSkeleton.rowColumnSegment,(row,col)=>{if(!worksheet.getRowVisible(row)||!worksheet.getColVisible(col))return;const{selectionProtection=[]}=worksheet.getCell(row,col)||{};this._pattern&&(ctx.fillStyle=this._pattern,selectionProtection.forEach(config=>{if(config.ruleId&&this.shouldRender(config)){if(this.renderCache.has(config.ruleId))return;this.renderCache.add(config.ruleId),config.ranges.forEach(range=>{const start=spreadsheetSkeleton.getCellByIndexWithNoHeader(range.startRow,range.startColumn),end=spreadsheetSkeleton.getCellByIndexWithNoHeader(range.endRow,range.endColumn);ctx.fillRect(start.startX,start.startY,end.endX-start.startX,end.endY-start.startY)})}}))}),ctx.restore())}};__name(_RangeProtectionRenderExtension,"RangeProtectionRenderExtension");let RangeProtectionRenderExtension=_RangeProtectionRenderExtension;const _RangeProtectionCanViewRenderExtension=class _RangeProtectionCanViewRenderExtension extends RangeProtectionRenderExtension{constructor(){super();__publicField(this,"uKey",RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY);__publicField(this,"Z_INDEX",EXTENSION_CAN_VIEW_Z_INDEX$1)}shouldRender(config){return(config==null?void 0:config[D.View])!==!1}};__name(_RangeProtectionCanViewRenderExtension,"RangeProtectionCanViewRenderExtension");let RangeProtectionCanViewRenderExtension=_RangeProtectionCanViewRenderExtension;const _RangeProtectionCanNotViewRenderExtension=class _RangeProtectionCanNotViewRenderExtension extends RangeProtectionRenderExtension{constructor(){super();__publicField(this,"uKey",RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY);__publicField(this,"Z_INDEX",EXTENSION_CAN_NOT_VIEW_Z_INDEX$1)}shouldRender(config){return(config==null?void 0:config[D.View])===!1}};__name(_RangeProtectionCanNotViewRenderExtension,"RangeProtectionCanNotViewRenderExtension");let RangeProtectionCanNotViewRenderExtension=_RangeProtectionCanNotViewRenderExtension;const worksheetProtectionKey="worksheet-protection",EXTENSION_CAN_VIEW_Z_INDEX=25,EXTENSION_CAN_NOT_VIEW_Z_INDEX=80,_WorksheetProtectionRenderExtension=class _WorksheetProtectionRenderExtension extends engineRender.SheetExtension{constructor(){super();__publicField(this,"uKey",worksheetProtectionKey);__publicField(this,"Z_INDEX",EXTENSION_CAN_VIEW_Z_INDEX);__publicField(this,"_pattern");__publicField(this,"_img",new Image);this._img.src=base64}draw(ctx,_parentScale,spreadsheetSkeleton){const{worksheet}=spreadsheetSkeleton;if(!worksheet)return!1;ctx.save(),this._pattern||(this._pattern=ctx.createPattern(this._img,"repeat"));const{startRow,startColumn,endRow,endColumn}=spreadsheetSkeleton.rowColumnSegment,start=spreadsheetSkeleton.getCellByIndexWithNoHeader(startRow,startColumn),end=spreadsheetSkeleton.getCellByIndexWithNoHeader(endRow,endColumn),{hasWorksheetRule=!1,selectionProtection=[]}=worksheet.getCell(startRow,startColumn)||{};if(this._pattern){if(selectionProtection.length>0){const cellProtectionConfig=selectionProtection[0];(cellProtectionConfig==null?void 0:cellProtectionConfig[D.View])?this.setZIndex(EXTENSION_CAN_VIEW_Z_INDEX):this.setZIndex(EXTENSION_CAN_NOT_VIEW_Z_INDEX)}ctx.fillStyle=this._pattern,hasWorksheetRule&&ctx.fillRect(start.startX,start.startY,end.endX-start.startX,end.endY-start.startY),ctx.restore()}}setZIndex(zIndex){this.Z_INDEX=zIndex}};__name(_WorksheetProtectionRenderExtension,"WorksheetProtectionRenderExtension");let WorksheetProtectionRenderExtension=_WorksheetProtectionRenderExtension;var __defProp$c=Object.defineProperty,__getOwnPropDesc$c=Object.getOwnPropertyDescriptor,__decorateClass$c=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$c(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$c(target,key,result),result},"__decorateClass$c"),__decorateParam$c=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$c"),_a46;let SheetPermissionRenderManagerController=(_a46=class extends core.Disposable{constructor(_componentManager){super(),this._componentManager=_componentManager,this._init()}_init(){this._initComponents()}_initComponents(){[[permissionMenuIconKey,ProtectSingle],[permissionDeleteIconKey,DeleteSingle],[permissionEditIconKey,WriteSingle],[permissionCheckIconKey,CheckMarkSingle],[permissionLockIconKey,LockSingle],[UNIVER_SHEET_PERMISSION_PANEL,SheetPermissionPanel],[UNIVER_SHEET_PERMISSION_PANEL_FOOTER,SheetPermissionPanelFooter],[UNIVER_SHEET_PERMISSION_USER_DIALOG,SheetPermissionUserDialog],[UNIVER_SHEET_PERMISSION_DIALOG,SheetPermissionDialog],[UNIVER_SHEET_PERMISSION_ALERT_DIALOG,AlertDialog]].forEach(([key,component])=>{this.disposeWithMe(this._componentManager.register(key,component))})}},__name(_a46,"SheetPermissionRenderManagerController"),_a46);SheetPermissionRenderManagerController=__decorateClass$c([__decorateParam$c(0,core.Inject(ui.ComponentManager))],SheetPermissionRenderManagerController);var _a47;let SheetPermissionRenderController=(_a47=class extends core.Disposable{constructor(_context,_rangeProtectionRuleModel,_sheetSkeletonManagerService,_permissionService){super();__publicField(this,"_rangeProtectionCanViewRenderExtension",new RangeProtectionCanViewRenderExtension);__publicField(this,"_rangeProtectionCanNotViewRenderExtension",new RangeProtectionCanNotViewRenderExtension);this._context=_context,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._permissionService=_permissionService,this._initRender(),this._initSkeleton(),this._rangeProtectionRuleModel.ruleChange$.subscribe(info=>{var _a61,_b;((_a61=info.oldRule)!=null&&_a61.id&&this._rangeProtectionCanViewRenderExtension.renderCache.has(info.oldRule.id)||this._rangeProtectionCanViewRenderExtension.renderCache.has(info.rule.id))&&this._rangeProtectionCanViewRenderExtension.clearCache(),((_b=info.oldRule)!=null&&_b.id&&this._rangeProtectionCanNotViewRenderExtension.renderCache.has(info.oldRule.id)||this._rangeProtectionCanNotViewRenderExtension.renderCache.has(info.rule.id))&&this._rangeProtectionCanNotViewRenderExtension.clearCache()})}_initRender(){const spreadsheetRender=this._context.mainComponent;spreadsheetRender&&(spreadsheetRender.getExtensionByKey(RANGE_PROTECTION_CAN_VIEW_RENDER_EXTENSION_KEY)||spreadsheetRender.register(this._rangeProtectionCanViewRenderExtension),spreadsheetRender.getExtensionByKey(RANGE_PROTECTION_CAN_NOT_VIEW_RENDER_EXTENSION_KEY)||spreadsheetRender.register(this._rangeProtectionCanNotViewRenderExtension))}_initSkeleton(){const markDirtySkeleton=__name(()=>{var _a61;this._sheetSkeletonManagerService.reCalculate(),(_a61=this._context.mainComponent)==null||_a61.makeDirty()},"markDirtySkeleton");this.disposeWithMe(rxjs.merge(this._permissionService.permissionPointUpdate$.pipe(rxjs.throttleTime(300,void 0,{trailing:!0})),this._rangeProtectionRuleModel.rangeRuleInitStateChange$,this._rangeProtectionRuleModel.ruleChange$).pipe().subscribe(markDirtySkeleton))}},__name(_a47,"SheetPermissionRenderController"),_a47);SheetPermissionRenderController=__decorateClass$c([__decorateParam$c(1,core.Inject(sheets.RangeProtectionRuleModel)),__decorateParam$c(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$c(3,core.IPermissionService)],SheetPermissionRenderController);var _a48;let WorksheetProtectionRenderController=(_a48=class extends core.Disposable{constructor(_context,_renderManagerService,_univerInstanceService,_sheetSkeletonManagerService,_worksheetProtectionRuleModel){super();__publicField(this,"_worksheetProtectionRenderExtension",new WorksheetProtectionRenderExtension);this._context=_context,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._initRender(),this._initSkeleton()}_initRender(){const renderId=this._context.unitId,render2=renderId&&this._renderManagerService.getRenderById(renderId),spreadsheetRender=render2&&render2.mainComponent;spreadsheetRender&&(spreadsheetRender.getExtensionByKey(worksheetProtectionKey)||spreadsheetRender.register(this._worksheetProtectionRenderExtension))}_initSkeleton(){const markDirtySkeleton=__name(()=>{var _a61;this._sheetSkeletonManagerService.reCalculate(),(_a61=this._context.mainComponent)==null||_a61.makeDirty()},"markDirtySkeleton");this.disposeWithMe(rxjs.merge(this._worksheetProtectionRuleModel.worksheetRuleInitStateChange$).pipe().subscribe(markDirtySkeleton))}},__name(_a48,"WorksheetProtectionRenderController"),_a48);WorksheetProtectionRenderController=__decorateClass$c([__decorateParam$c(1,core.Inject(engineRender.IRenderManagerService)),__decorateParam$c(2,core.Inject(core.IUniverInstanceService)),__decorateParam$c(3,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$c(4,core.Inject(sheets.WorksheetProtectionRuleModel))],WorksheetProtectionRenderController);var __defProp$b=Object.defineProperty,__getOwnPropDesc$b=Object.getOwnPropertyDescriptor,__decorateClass$b=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$b(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$b(target,key,result),result},"__decorateClass$b"),__decorateParam$b=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$b"),_a49;let SheetContextMenuRenderController=(_a49=class extends core.Disposable{constructor(_context,_contextMenuService,_selectionManagerService,_selectionRenderService){super(),this._context=_context,this._contextMenuService=_contextMenuService,this._selectionManagerService=_selectionManagerService,this._selectionRenderService=_selectionRenderService,this._init()}_init(){var _a61,_b;const spreadsheetSubscription=((_b=(_a61=this._context)==null?void 0:_a61.mainComponent)==null?void 0:_b.onPointerDown$).subscribeEvent(event=>{if(event.button===2){const selections=this._selectionManagerService.getCurrentSelections(),currentSelection=selections==null?void 0:selections[0];if(!currentSelection)return;const rangeType=currentSelection.range.rangeType,skeleton=this._selectionRenderService.getSkeleton(),range=attachSelectionWithCoord(currentSelection,skeleton).rangeWithCoord,isPointerInRange=__name(()=>{if(!range)return!1;const x=event.offsetX,y=event.offsetY;switch(rangeType){case core.RANGE_TYPE.ROW:return range.startY<=y&&range.endY>=y;case core.RANGE_TYPE.COLUMN:return range.startX<=x&&range.endX>=x;default:return range.startX<=x&&range.endX>=x&&range.startY<=y&&range.endY>=y}},"isPointerInRange"),triggerMenu=__name(position=>{this._contextMenuService.triggerContextMenu(event,position)},"triggerMenu");isPointerInRange()?rangeType===core.RANGE_TYPE.COLUMN?triggerMenu(ui.ContextMenuPosition.COL_HEADER):rangeType===core.RANGE_TYPE.ROW?triggerMenu(ui.ContextMenuPosition.ROW_HEADER):triggerMenu(ui.ContextMenuPosition.MAIN_AREA):triggerMenu(ui.ContextMenuPosition.MAIN_AREA)}});this.disposeWithMe(spreadsheetSubscription);const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),rowHeaderSub=this._context.components.get(SHEET_VIEW_KEY.ROW).onPointerDown$.subscribeEvent(event=>{event.button===2&&this._contextMenuService.triggerContextMenu(event,ui.ContextMenuPosition.ROW_HEADER)});this.disposeWithMe(rowHeaderSub);const colHeaderObserver=spreadsheetColumnHeader.onPointerDown$.subscribeEvent(event=>{event.button===2&&this._contextMenuService.triggerContextMenu(event,ui.ContextMenuPosition.COL_HEADER)});this.disposeWithMe(colHeaderObserver)}},__name(_a49,"SheetContextMenuRenderController"),_a49);SheetContextMenuRenderController=__decorateClass$b([__decorateParam$b(1,ui.IContextMenuService),__decorateParam$b(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$b(3,ISheetSelectionRenderService)],SheetContextMenuRenderController);var __defProp$a=Object.defineProperty,__getOwnPropDesc$a=Object.getOwnPropertyDescriptor,__decorateClass$a=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$a(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$a(target,key,result),result},"__decorateClass$a"),__decorateParam$a=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$a"),_a50;let EditorBridgeRenderController=(_a50=class extends core.RxDisposable{constructor(_context,_instanceSrv,_commandService,_editorBridgeService,_selectionManagerService,_rangeSelectorService,_contextService,_renderManagerService,_editorService,_sheetSkeletonManagerService){super();__publicField(this,"_d");this._context=_context,this._instanceSrv=_instanceSrv,this._commandService=_commandService,this._editorBridgeService=_editorBridgeService,this._selectionManagerService=_selectionManagerService,this._rangeSelectorService=_rangeSelectorService,this._contextService=_contextService,this._renderManagerService=_renderManagerService,this._editorService=_editorService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this.disposeWithMe(this._instanceSrv.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{workbook&&workbook.getUnitId()===this._context.unitId?this._d=this._init():this._disposeCurrent()})),this._initialRangeSelector()}_init(){const d=new core.DisposableCollection;return this._initSelectionChangeListener(d),this._initEventListener(d),this._commandExecutedListener(d),this._initialKeyboardListener(d),d}_disposeCurrent(){var _a61;(_a61=this._d)==null||_a61.dispose(),this._d=null}_initSelectionChangeListener(d){d.add(rxjs.merge(this._selectionManagerService.selectionMoveEnd$,this._selectionManagerService.selectionMoveStart$).subscribe(params=>this._updateEditorPosition(params)))}_updateEditorPosition(params){var _a61,_b,_c;if(this._editorBridgeService.isVisible().visible||this._rangeSelectorService.selectorModalVisible)return;const primary=(_a61=params==null?void 0:params[params.length-1])==null?void 0:_a61.primary;if(primary){const sheetObject=this._getSheetObject(),{scene,engine}=sheetObject,unitId=this._context.unitId,sheetId=(_b=this._context.unit.getActiveSheet())==null?void 0:_b.getSheetId();if(!sheetId)return;const mergeInfo=(_c=this._sheetSkeletonManagerService.getWorksheetSkeleton(sheetId))==null?void 0:_c.skeleton.getCellByIndex(primary.actualRow,primary.actualColumn),newPrimary=mergeInfo?{actualRow:mergeInfo.actualRow,actualColumn:mergeInfo.actualColumn,isMerged:mergeInfo.isMerged,startRow:mergeInfo.mergeInfo.startRow,startColumn:mergeInfo.mergeInfo.startColumn,endRow:mergeInfo.mergeInfo.endRow,endColumn:mergeInfo.mergeInfo.endColumn,isMergedMainCell:mergeInfo.isMergedMainCell}:primary;this._commandService.executeCommand(SetActivateCellEditOperation.id,{scene,engine,primary:newPrimary,unitId,sheetId})}}_initEventListener(d){const sheetObject=this._getSheetObject(),{spreadsheet,spreadsheetColumnHeader,spreadsheetLeftTopPlaceholder,spreadsheetRowHeader}=sheetObject;d.add(spreadsheet.onDblclick$.subscribeEvent(evt=>{evt.button!==2&&this._commandService.executeCommand(SetCellEditVisibleOperation.id,{visible:!0,eventType:engineRender.DeviceInputEventType.Dblclick,unitId:this._context.unitId})})),d.add(spreadsheet.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1})),d.add(spreadsheetColumnHeader.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1})),d.add(spreadsheetLeftTopPlaceholder.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1})),d.add(spreadsheetRowHeader.onPointerDown$.subscribeEvent({next:this._tryHideEditor.bind(this),priority:-1}))}_initialKeyboardListener(d){let disposable=null;const addEvent=__name(render22=>{const docSelectionRenderService=render22.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&(disposable=core.toDisposable(docSelectionRenderService.onInputBefore$.subscribe(config=>{if(!this._isCurrentSheetFocused())return;const isFocusFormulaEditor=this._contextService.getContextValue(core.FOCUSING_FX_BAR_EDITOR),isFocusSheets=this._contextService.getContextValue(core.FOCUSING_SHEET),unitId=render22.unitId;this._editorBridgeService.isVisible().visible||unitId&&isFocusSheets&&!isFocusFormulaEditor&&this._editorService.isSheetEditor(unitId)&&this._showEditorByKeyboard(config)})),d.add(disposable))},"addEvent"),render2=this._renderManagerService.getRenderById(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY);render2?addEvent(render2):this.disposeWithMe(this._renderManagerService.created$.pipe(rxjs.filter(render22=>render22.unitId===core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY)).subscribe(render22=>{disposable==null||disposable.dispose(),addEvent(render22)}))}_commandExecutedListener(d){const refreshCommandSet=new Set([sheets.ClearSelectionFormatCommand.id,sheets.SetRangeValuesMutation.id,SetZoomRatioCommand.id]);d.add(this._commandService.onCommandExecuted(command=>{if(refreshCommandSet.has(command.id)){if(this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellState()}})),d.add(this._commandService.beforeCommandExecuted((command,options)=>{options!=null&&options.fromCollab||command.id===sheets.SetWorksheetActiveOperation.id&&this._tryHideEditor()}))}_showEditorByKeyboard(config){if(config==null)return;const event=config.event;this._commandService.executeCommand(SetCellEditVisibleOperation.id,{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:event.which,unitId:this._context.unitId})}_tryHideEditor(){this._editorBridgeService.isForceKeepVisible()||this._hideEditor()}_hideEditor(){this._editorBridgeService.isVisible().visible===!0&&this._commandService.syncExecuteCommand(SetCellEditVisibleOperation.id,{visible:!1,eventType:engineRender.DeviceInputEventType.PointerDown,unitId:this._context.unitId})}_initialRangeSelector(){this.disposeWithMe(this._selectionManagerService.selectionMoving$.subscribe(this._rangeSelector.bind(this))),this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(this._rangeSelector.bind(this))),this.disposeWithMe(this._rangeSelectorService.openSelector$.subscribe(()=>{const{unitId,sheetId,sheetName}=this._getCurrentUnitIdAndSheetId();if(!sheetId||!sheetName)return;const selectionWithStyle=this._selectionManagerService.getCurrentSelections(),ranges=selectionWithStyle==null?void 0:selectionWithStyle.map(value=>({range:value.range,unitId,sheetId,sheetName}));ranges&&this._rangeSelectorService.selectionChange(ranges)}))}_rangeSelector(selectionWithStyle){if(!selectionWithStyle)return;const{unitId,sheetId,sheetName}=this._getCurrentUnitIdAndSheetId();if(!sheetId||!sheetName)return;const ranges=selectionWithStyle.map(value=>({range:value.range,unitId,sheetId,sheetName}));this._rangeSelectorService.selectionChange(ranges)}_getCurrentUnitIdAndSheetId(){const workbook=this._context.unit,worksheet=workbook.getActiveSheet();return{unitId:workbook.getUnitId(),sheetId:worksheet==null?void 0:worksheet.getSheetId(),sheetName:worksheet==null?void 0:worksheet.getName()}}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_isCurrentSheetFocused(){var _a61;return((_a61=this._instanceSrv.getFocusedUnit())==null?void 0:_a61.getUnitId())===this._context.unitId}},__name(_a50,"EditorBridgeRenderController"),_a50);EditorBridgeRenderController=__decorateClass$a([__decorateParam$a(1,core.IUniverInstanceService),__decorateParam$a(2,core.ICommandService),__decorateParam$a(3,IEditorBridgeService),__decorateParam$a(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$a(5,docsUi.IRangeSelectorService),__decorateParam$a(6,core.IContextService),__decorateParam$a(7,engineRender.IRenderManagerService),__decorateParam$a(8,docsUi.IEditorService),__decorateParam$a(9,core.Inject(exports.SheetSkeletonManagerService))],EditorBridgeRenderController);var __defProp$9=Object.defineProperty,__getOwnPropDesc$9=Object.getOwnPropertyDescriptor,__decorateClass$9=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$9(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$9(target,key,result),result},"__decorateClass$9"),__decorateParam$9=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$9"),_a51;let FormatPainterRenderController=(_a51=class extends core.Disposable{constructor(_context,_formatPainterService){super(),this._context=_context,this._formatPainterService=_formatPainterService,this._initialize()}_initialize(){this._bindFormatPainterStatus()}_bindFormatPainterStatus(){this.disposeWithMe(core.toDisposable(this._formatPainterService.status$.subscribe(status=>{const scene=this._context.scene;scene&&(status!==FormatPainterStatus.OFF?scene.setDefaultCursor(engineRender.CURSOR_TYPE.CELL):scene.setDefaultCursor(engineRender.CURSOR_TYPE.DEFAULT))})))}},__name(_a51,"FormatPainterRenderController"),_a51);FormatPainterRenderController=__decorateClass$9([__decorateParam$9(1,IFormatPainterService)],FormatPainterRenderController);var HEADER_MENU_SHAPE_TYPE=(HEADER_MENU_SHAPE_TYPE2=>(HEADER_MENU_SHAPE_TYPE2[HEADER_MENU_SHAPE_TYPE2.NORMAL=0]="NORMAL",HEADER_MENU_SHAPE_TYPE2[HEADER_MENU_SHAPE_TYPE2.HIGHLIGHT=1]="HIGHLIGHT",HEADER_MENU_SHAPE_TYPE2))(HEADER_MENU_SHAPE_TYPE||{});const HEADER_MENU_SHAPE_CIRCLE_FILL="rgba(0, 0, 0, 0.15)",HEADER_MENU_SHAPE_TRIANGLE_FILL="rgb(0, 0, 0)",HEADER_MENU_BACKGROUND_COLOR="rgb(255, 255, 255, 1)",_HeaderMenuShape=class _HeaderMenuShape extends engineRender.Shape{constructor(key,props){super(key,props);__publicField(this,"_size",12);__publicField(this,"_iconRatio",.4);__publicField(this,"_mode",0);this.setShapeProps(props)}setShapeProps(props){props!=null&&props.size&&(this._size=props.size),props!=null&&props.mode&&(this._mode=props.mode),this.transformByState({width:this._size,height:this._size})}_draw(ctx){this._mode===1&&engineRender.Rect.drawWith(ctx,{width:this._size,height:this._size,radius:this._size,fill:HEADER_MENU_SHAPE_CIRCLE_FILL});const iconSize=this._size*.5*this._iconRatio,sixtyDegree=Math.PI/180*60,left=iconSize*Math.sin(sixtyDegree),top=iconSize*Math.cos(sixtyDegree);engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:-left+this._size/2,y:-top+this._size/2},{x:left+this._size/2,y:-top+this._size/2},{x:this._size/2,y:iconSize+this._size/2}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL})}};__name(_HeaderMenuShape,"HeaderMenuShape");let HeaderMenuShape=_HeaderMenuShape;var __defProp$8=Object.defineProperty,__getOwnPropDesc$8=Object.getOwnPropertyDescriptor,__decorateClass$8=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$8(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$8(target,key,result),result},"__decorateClass$8"),__decorateParam$8=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$8");const HEADER_MENU_CONTROLLER_SHAPE="__SpreadsheetHeaderMenuSHAPEControllerShape__",HEADER_MENU_CONTROLLER_MENU="__SpreadsheetHeaderMenuMAINControllerShape__",HEADER_MENU_CONTROLLER_SHAPE_COLOR="rgba(0, 0, 0, 0.1)";var _a52;let HeaderMenuRenderController=(_a52=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_contextMenuService,_commandService,_selectionManagerService){super();__publicField(this,"_hoverRect");__publicField(this,"_hoverMenu");__publicField(this,"_currentColumn",Number.POSITIVE_INFINITY);__publicField(this,"_headerPointerSubs");__publicField(this,"_colHeaderPointerSubs");this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._contextMenuService=_contextMenuService,this._commandService=_commandService,this._selectionManagerService=_selectionManagerService,this._initialize()}dispose(){var _a61,_b,_c;(_a61=this._hoverRect)==null||_a61.dispose(),(_b=this._hoverMenu)==null||_b.dispose(),(_c=this._headerPointerSubs)==null||_c.unsubscribe(),this._headerPointerSubs=null}_initialize(){const scene=this._context.scene;this._hoverRect=new engineRender.Rect(HEADER_MENU_CONTROLLER_SHAPE,{fill:HEADER_MENU_CONTROLLER_SHAPE_COLOR,evented:!1}),this._hoverMenu=new HeaderMenuShape(HEADER_MENU_CONTROLLER_MENU,{zIndex:100,visible:!1}),scene.addObjects([this._hoverRect,this._hoverMenu],SHEET_COMPONENT_HEADER_LAYER_INDEX),this._initialHover(0),this._initialHover(1),this._initialHoverMenu()}_initialHover(initialType=0){var _a61,_b,_c;const spreadsheetColumnHeader=this._context.components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetRowHeader=this._context.components.get(SHEET_VIEW_KEY.ROW),eventBindingObject=initialType===0?spreadsheetRowHeader:spreadsheetColumnHeader,pointerMoveHandler=__name(evt=>{var _a62,_b2,_c2;const skeleton=(_a62=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a62.skeleton;if(skeleton==null)return;const{rowHeaderWidth,columnHeaderHeight}=skeleton,{startX,startY,endX,endY,column}=getCoordByOffset(evt.offsetX,evt.offsetY,this._context.scene,skeleton);if(initialType===0)(_b2=this._hoverRect)==null||_b2.transformByState({width:rowHeaderWidth,height:endY-startY,left:0,top:startY});else{if(this._currentColumn=column,(_c2=this._hoverRect)==null||_c2.transformByState({width:endX-startX,height:columnHeaderHeight,left:startX,top:0}),this._hoverMenu==null)return;if(endX-startX<columnHeaderHeight*2){this._hoverMenu.hide();return}const menuSize=columnHeaderHeight*.8;this._hoverMenu.transformByState({left:endX-columnHeaderHeight,top:columnHeaderHeight/2-menuSize/2}),this._hoverMenu.setShapeProps({size:menuSize}),this._hoverMenu.show()}},"pointerMoveHandler"),pointerEnterHandler=__name(()=>{var _a62;(_a62=this._hoverRect)==null||_a62.show()},"pointerEnterHandler"),pointerLeaveHandler=__name(()=>{var _a62,_b2;(_a62=this._hoverRect)==null||_a62.hide(),(_b2=this._hoverMenu)==null||_b2.hide()},"pointerLeaveHandler");this._headerPointerSubs=new rxjs.Subscription;const headerPointerMoveSub=eventBindingObject.onPointerMove$.subscribeEvent(pointerMoveHandler),headerPointerEnterSub=eventBindingObject.onPointerEnter$.subscribeEvent(pointerEnterHandler),headerPointerLeaveSub=eventBindingObject.onPointerLeave$.subscribeEvent(pointerLeaveHandler);(_a61=this._headerPointerSubs)==null||_a61.add(headerPointerMoveSub),(_b=this._headerPointerSubs)==null||_b.add(headerPointerEnterSub),(_c=this._headerPointerSubs)==null||_c.add(headerPointerLeaveSub)}_initialHoverMenu(){this._hoverMenu!=null&&(this._hoverMenu.onPointerEnter$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:HEADER_MENU_SHAPE_TYPE.HIGHLIGHT,visible:!0}),this._context.scene.setCursor(engineRender.CURSOR_TYPE.POINTER))}),this._hoverMenu.onPointerLeave$.subscribeEvent(()=>{this._hoverMenu!=null&&(this._hoverMenu.setProps({mode:HEADER_MENU_SHAPE_TYPE.NORMAL,visible:!1}),this._context.scene.resetCursor())}),this._hoverMenu.onPointerDown$.subscribeEvent(evt=>{var _a61;const currentColumn=this._currentColumn,currentSelectionDatas=(_a61=this._selectionManagerService.getCurrentSelections())==null?void 0:_a61.map(s=>s.range);if(!!!(currentSelectionDatas!=null&&currentSelectionDatas.filter(range=>range.rangeType===core.RANGE_TYPE.COLUMN).find(data=>{const{startColumn,endColumn}=data;return currentColumn>=startColumn&&currentColumn<=endColumn}))){const selection=this._getSelectionOnColumn(currentColumn);this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,selection)}evt.stopPropagation(),evt.preventDefault(),this._contextMenuService.triggerContextMenu(evt,ui.ContextMenuPosition.COL_HEADER)}))}_getSelectionOnColumn(column){const workbook=this._context.unit,worksheet=workbook.getActiveSheet();if(!worksheet)throw new Error("No active worksheet");return{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),selections:[{range:{startRow:0,startColumn:column,endRow:worksheet.getRowCount()-1,endColumn:column,rangeType:core.RANGE_TYPE.COLUMN},primary:{startRow:0,startColumn:column,endRow:0,endColumn:column,actualRow:0,actualColumn:column,isMerged:!1,isMergedMainCell:!1},style:null}]}}},__name(_a52,"HeaderMenuRenderController"),_a52);HeaderMenuRenderController=__decorateClass$8([__decorateParam$8(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$8(2,ui.IContextMenuService),__decorateParam$8(3,core.ICommandService),__decorateParam$8(4,core.Inject(sheets.SheetsSelectionsService))],HeaderMenuRenderController);var HeaderUnhideShapeType=(HeaderUnhideShapeType2=>(HeaderUnhideShapeType2[HeaderUnhideShapeType2.ROW=0]="ROW",HeaderUnhideShapeType2[HeaderUnhideShapeType2.COLUMN=1]="COLUMN",HeaderUnhideShapeType2))(HeaderUnhideShapeType||{});const UNHIDE_ICON_SIZE=12,UNHIDE_ARROW_RATIO=.4,_HeaderUnhideShape=class _HeaderUnhideShape extends engineRender.Shape{constructor(key,props,onClick){super(key,props);__publicField(this,"_size",UNHIDE_ICON_SIZE);__publicField(this,"_iconRatio",UNHIDE_ARROW_RATIO);__publicField(this,"_hovered",!0);__publicField(this,"_hasPrevious",!0);__publicField(this,"_hasNext",!0);__publicField(this,"_unhideType");props&&this.setShapeProps(props),this.onPointerEnter$.subscribeEvent(()=>this.setShapeProps({hovered:!0})),this.onPointerLeave$.subscribeEvent(()=>this.setShapeProps({hovered:!1})),this.onPointerDown$.subscribeEvent(()=>onClick==null?void 0:onClick())}setShapeProps(props){props.type!==void 0&&(this._unhideType=props.type),props.hovered!==void 0&&(this._hovered=props.hovered),props.hasPrevious!==void 0&&(this._hasPrevious=props.hasPrevious),props.hasNext!==void 0&&(this._hasNext=props.hasNext),this.transformByState({width:this._size*(this._unhideType===1?2:1),height:this._size*(this._unhideType===0?2:1)})}_draw(ctx){this._unhideType===0?this._drawOnRow(ctx):this._drawOnCol(ctx)}_drawOnRow(ctx){this._hovered&&(!this._hasNext||!this._hasPrevious?engineRender.Rect.drawWith(ctx,{width:this._size,height:this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}):engineRender.Rect.drawWith(ctx,{width:this._size,height:2*this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}));const iconSize=this._size*.5*this._iconRatio,sixtyDegree=Math.PI/3,top=iconSize*Math.cos(sixtyDegree),left=iconSize*Math.sin(sixtyDegree);if(this._hasPrevious&&engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:this._size/2,y:this._size/2-left},{x:this._size/2-left,y:this._size/2+top},{x:this._size/2+left,y:this._size/2+top}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL}),this._hasNext){const offset=this._hasPrevious?3:1;engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:this._size/2,y:this._size*offset/2+left},{x:this._size/2-left,y:this._size*offset/2-top},{x:this._size/2+left,y:this._size*offset/2-top}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL})}}_drawOnCol(ctx){this._hovered&&(!this._hasNext||!this._hasPrevious?engineRender.Rect.drawWith(ctx,{width:this._size,height:this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}):engineRender.Rect.drawWith(ctx,{width:2*this._size,height:this._size,stroke:HEADER_MENU_SHAPE_TRIANGLE_FILL,fill:HEADER_MENU_BACKGROUND_COLOR}));const iconSize=this._size*.5*this._iconRatio,sixtyDegree=Math.PI/3,top=iconSize*Math.cos(sixtyDegree),left=iconSize*Math.sin(sixtyDegree);if(this._hasPrevious&&engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:-top+this._size/2,y:this._size/2},{x:this._size/2+left,y:this._size/2-left},{x:this._size/2+left,y:this._size/2+left}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL}),this._hasNext){const offset=this._hasPrevious?3:1;engineRender.RegularPolygon.drawWith(ctx,{pointsGroup:[[{x:top+this._size*offset/2,y:this._size/2},{x:-left+this._size*offset/2,y:this._size/2-left},{x:-left+this._size*offset/2,y:this._size/2+left}]],fill:HEADER_MENU_SHAPE_TRIANGLE_FILL})}}};__name(_HeaderUnhideShape,"HeaderUnhideShape");let HeaderUnhideShape=_HeaderUnhideShape;var __defProp$7=Object.defineProperty,__getOwnPropDesc$7=Object.getOwnPropertyDescriptor,__decorateClass$7=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$7(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$7(target,key,result),result},"__decorateClass$7"),__decorateParam$7=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$7");const HEADER_UNHIDE_CONTROLLER_SHAPE="__SpreadsheetHeaderUnhideSHAPEControllerShape__";sheets.InsertColMutation.id,sheets.InsertRowMutation.id,sheets.RemoveColMutation.id,sheets.RemoveRowMutation.id,sheets.MoveColsMutation.id,sheets.MoveRowsMutation.id,sheets.SetWorksheetColWidthMutation.id,sheets.SetWorksheetRowIsAutoHeightMutation.id,sheets.SetRowHiddenMutation.id,sheets.SetRowVisibleMutation.id,sheets.SetColHiddenMutation.id,sheets.SetColVisibleMutation.id;var _a53;let HeaderUnhideRenderController=(_a53=class extends core.RxDisposable{constructor(_context,_sheetSkeletonManagerService,_commandService){super();__publicField(this,"_shapes",{cols:[],rows:[]});this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._init()}get _workbook(){return this._context.unit}dispose(){super.dispose(),this._clearShapes()}_init(){let activeSheetId="";this._context.unit.activeSheet$.pipe(rxjs.takeUntil(this.dispose$)).subscribe(worksheet=>{if(this._clearShapes(),!worksheet){activeSheetId="";return}activeSheetId=worksheet.getSheetId(),this._update(this._workbook,worksheet)}),this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{if(param){const{unitId,sheetId}=param;if(unitId===this._workbook.getUnitId()&&sheetId===activeSheetId){const worksheet=this._workbook.getSheetBySheetId(sheetId);worksheet&&this._update(this._workbook,worksheet)}}}))}_update(workbook,worksheet){var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getWorksheetSkeleton(worksheet.getSheetId()))==null?void 0:_a61.skeleton;if(!skeleton)return;const hiddenRowRanges=worksheet.getHiddenRows(),hiddenColRanges=worksheet.getHiddenCols(),sheetObject=this._getSheetObject(),{scene}=sheetObject,rowCount=worksheet.getRowCount(),rowShapes=hiddenRowRanges.map(range=>{const{startRow,endRow}=range,position=getCoordByCell(startRow,0,scene,skeleton),hasPrevious=startRow!==0,hasNext=endRow!==rowCount-1;return new HeaderUnhideShape(HEADER_UNHIDE_CONTROLLER_SHAPE,{type:HeaderUnhideShapeType.ROW,hovered:!1,hasPrevious,hasNext,top:position.startY-(hasPrevious?UNHIDE_ICON_SIZE:0),left:position.startX-UNHIDE_ICON_SIZE},()=>this._commandService.executeCommand(sheets.SetSpecificRowsVisibleCommand.id,{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),ranges:[range]}))}),colCount=worksheet.getColumnCount(),colShapes=hiddenColRanges.map(range=>{const{startColumn,endColumn}=range,position=getCoordByCell(0,startColumn,scene,skeleton),hasPrevious=startColumn!==0,hasNext=endColumn!==colCount-1;return new HeaderUnhideShape(HEADER_UNHIDE_CONTROLLER_SHAPE,{type:HeaderUnhideShapeType.COLUMN,hovered:!1,hasPrevious,hasNext,top:20-UNHIDE_ICON_SIZE,left:position.startX-(hasPrevious?UNHIDE_ICON_SIZE:0)},()=>this._commandService.executeCommand(sheets.SetSpecificColsVisibleCommand.id,{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),ranges:[range]}))});scene.addObjects(colShapes,SHEET_COMPONENT_UNHIDE_LAYER_INDEX),scene.addObjects(rowShapes,SHEET_COMPONENT_UNHIDE_LAYER_INDEX),this._clearShapes(),this._shapes={cols:colShapes,rows:rowShapes}}_clearShapes(){this._shapes.cols.forEach(shape=>shape.dispose()),this._shapes.rows.forEach(shape=>shape.dispose()),this._shapes={cols:[],rows:[]}}_getSheetObject(){return getSheetObject(this._workbook,this._context)}},__name(_a53,"HeaderUnhideRenderController"),_a53);HeaderUnhideRenderController=__decorateClass$7([__decorateParam$7(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$7(2,core.ICommandService)],HeaderUnhideRenderController);var __defProp$6=Object.defineProperty,__getOwnPropDesc$6=Object.getOwnPropertyDescriptor,__decorateClass$6=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$6(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$6(target,key,result),result},"__decorateClass$6"),__decorateParam$6=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$6");const FRAME_STACK_THRESHOLD=60;var _a54;exports.SheetRenderController=(_a54=class extends core.RxDisposable{constructor(_context,_contextService,_sheetSkeletonManagerService,_sheetRenderService,_commandService,_telemetryService){super();__publicField(this,"_renderFrameTimeMetric",null);__publicField(this,"_renderFrameTags",{});__publicField(this,"_afterRenderMetric$",new rxjs.Subject);this._context=_context,this._contextService=_contextService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._sheetRenderService=_sheetRenderService,this._commandService=_commandService,this._telemetryService=_telemetryService,this._addNewRender(),this._initRenderMetricSubscriber()}_addNewRender(){const{scene,engine,unit:workbook}=this._context;this._addComponent(workbook),this._initRerenderScheduler(),this._initCommandListener();const worksheet=this._context.unit.getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const sheetId=worksheet.getSheetId();this._sheetSkeletonManagerService.setCurrent({sheetId}),engine.runRenderLoop(()=>scene.render())}_initRenderMetricSubscriber(){if(!this._telemetryService)return;const{engine}=this._context;engine.beginFrame$.subscribe(()=>{this._renderFrameTimeMetric=null,this._renderFrameTags={}}),engine.endFrame$.subscribe(()=>{this._renderFrameTimeMetric&&Object.keys(this._renderFrameTimeMetric).filter(key=>key.startsWith(engineRender.SHEET_EXTENSION_PREFIX)).length>0&&this._afterRenderMetric$.next({frameTimeMetric:this._renderFrameTimeMetric,tags:this._renderFrameTags})}),engine.renderFrameTimeMetric$.subscribe(([key,value])=>{this._renderFrameTimeMetric||(this._renderFrameTimeMetric={}),this._renderFrameTimeMetric[key]||(this._renderFrameTimeMetric[key]=[]),value=Math.round(value*100)/100,this._renderFrameTimeMetric[key].push(value)}),engine.renderFrameTags$.subscribe(([key,value])=>{this._renderFrameTags[key]=value});const frameInfoList=[];this._afterRenderMetric$.pipe(rxjs.withLatestFrom(engine.endFrame$)).subscribe(([sceneRenderDetail,basicFrameTimeInfo])=>{frameInfoList.push({FPS:basicFrameTimeInfo.FPS,elapsedTime:basicFrameTimeInfo.elapsedTime,frameTime:Math.round(basicFrameTimeInfo.frameTime*100)/100,...sceneRenderDetail.frameTimeMetric,...sceneRenderDetail.tags}),frameInfoList.length>FRAME_STACK_THRESHOLD&&(this._renderMetricCapture(frameInfoList),frameInfoList.length=0)})}_renderMetricCapture(frameInfoList){const filteredFrameInfo=frameInfoList;if(filteredFrameInfo.length===0)return;const sumValueForNumListFields=__name(data=>{let totalSum=0;const sums=Object.entries(data).filter(([_,value])=>Array.isArray(value)).map(([key])=>key).reduce((acc,key)=>{const keySum=data[key].reduce((sum,num)=>sum+num,0);return acc[key]=keySum,acc},{});return Object.keys(data).filter(key=>key.startsWith(engineRender.SHEET_EXTENSION_PREFIX)).forEach(key=>{totalSum+=sums[key]}),{...sums,extensionTotal:totalSum}},"sumValueForNumListFields"),frameTimeListAfterSum=frameInfoList.map(info=>({...info,...sumValueForNumListFields(info)})),summaryFrameStats=__name(list=>Object.entries(list[0]).filter(([key,_])=>!["elapsedTime"].includes(key)).filter(([_,value])=>typeof value=="number").map(([key])=>key).reduce((acc,key)=>{const values=list.map(obj=>obj[key]),max=Math.max(...values),min=Math.min(...values),avg=values.reduce((sum,val)=>sum+val,0)/values.length;return acc[key]={max:Math.round(max*100)/100,min:Math.round(min*100)/100,avg:Math.round(avg*100)/100},acc},{}),"getSummaryStats")(frameTimeListAfterSum),elapsedTimeToStart=filteredFrameInfo[filteredFrameInfo.length-1].elapsedTime,sheetId=this._context.unit.getActiveSheet().getSheetId(),unitId=this._context.unit.getUnitId(),telemetryData={sheetId,unitId,elapsedTimeToStart,...summaryFrameStats};this._telemetryService.capture("sheet_render_cost",telemetryData)}_addComponent(workbook){const{scene,components}=this._context,worksheet=workbook.getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const spreadsheet=new engineRender.Spreadsheet(SHEET_VIEW_KEY.MAIN);this._addViewport(worksheet);const spreadsheetRowHeader=new engineRender.SpreadsheetRowHeader(SHEET_VIEW_KEY.ROW),spreadsheetColumnHeader=new engineRender.SpreadsheetColumnHeader(SHEET_VIEW_KEY.COLUMN),SpreadsheetLeftTopPlaceholder=new engineRender.Rect(SHEET_VIEW_KEY.LEFT_TOP,{zIndex:2,left:-1,top:-1,fill:"rgb(248, 249, 250)",stroke:"rgb(217, 217, 217)",strokeWidth:1});this._context.mainComponent=spreadsheet,components.set(SHEET_VIEW_KEY.MAIN,spreadsheet),components.set(SHEET_VIEW_KEY.ROW,spreadsheetRowHeader),components.set(SHEET_VIEW_KEY.COLUMN,spreadsheetColumnHeader),components.set(SHEET_VIEW_KEY.LEFT_TOP,SpreadsheetLeftTopPlaceholder),scene.addObjects([spreadsheet],SHEET_COMPONENT_MAIN_LAYER_INDEX),scene.addObjects([spreadsheetRowHeader,spreadsheetColumnHeader,SpreadsheetLeftTopPlaceholder],SHEET_COMPONENT_HEADER_LAYER_INDEX),scene.enableLayerCache(SHEET_COMPONENT_MAIN_LAYER_INDEX,SHEET_COMPONENT_HEADER_LAYER_INDEX)}_initViewports(scene,rowHeader,columnHeader){const viewMain=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN,scene,{left:rowHeader.width,top:columnHeader.height,bottom:0,right:0,isWheelPreventDefaultX:!0,allowCache:!0,bufferEdgeX:100,bufferEdgeY:100}),viewMainLeftTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP,scene,{isWheelPreventDefaultX:!0,active:!1,allowCache:!0,bufferEdgeX:0,bufferEdgeY:0}),viewMainLeft=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT,scene,{isWheelPreventDefaultX:!0,active:!1,allowCache:!0,bufferEdgeX:0,bufferEdgeY:100}),viewMainTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP,scene,{isWheelPreventDefaultX:!0,active:!1,allowCache:!0,bufferEdgeX:100,bufferEdgeY:0}),viewRowTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP,scene,{active:!1,isWheelPreventDefaultX:!0}),viewRowBottom=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM,scene,{left:0,top:columnHeader.height,bottom:0,width:rowHeader.width,isWheelPreventDefaultX:!0}),viewColumnLeft=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT,scene,{active:!1,isWheelPreventDefaultX:!0}),viewColumnRight=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT,scene,{left:rowHeader.width,top:0,height:columnHeader.height,right:0,isWheelPreventDefaultX:!0}),viewLeftTop=new engineRender.Viewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP,scene,{left:0,top:0,width:rowHeader.width,height:columnHeader.height,isWheelPreventDefaultX:!0});return{viewMain,viewLeftTop,viewMainLeftTop,viewMainLeft,viewMainTop,viewColumnLeft,viewRowTop,viewRowBottom,viewColumnRight}}_addViewport(worksheet){const scene=this._context.scene;if(scene==null)return;const{rowHeader,columnHeader}=worksheet.getConfig(),{viewMain}=this._initViewports(scene,rowHeader,columnHeader);return new engineRender.ScrollBar(viewMain),scene.attachControl(),viewMain}_initRerenderScheduler(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{if(!param)return null;const{skeleton:spreadsheetSkeleton,sheetId}=param,workbook=this._context.unit,worksheet=workbook==null?void 0:workbook.getSheetBySheetId(sheetId);if(workbook==null||worksheet==null)return;const{mainComponent,components}=this._context,spreadsheet=mainComponent,spreadsheetRowHeader=components.get(SHEET_VIEW_KEY.ROW),spreadsheetColumnHeader=components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetLeftTopPlaceholder=components.get(SHEET_VIEW_KEY.LEFT_TOP),{rowHeaderWidth,columnHeaderHeight}=spreadsheetSkeleton;spreadsheet==null||spreadsheet.updateSkeleton(spreadsheetSkeleton),spreadsheetRowHeader==null||spreadsheetRowHeader.updateSkeleton(spreadsheetSkeleton),spreadsheetColumnHeader==null||spreadsheetColumnHeader.updateSkeleton(spreadsheetSkeleton),spreadsheetLeftTopPlaceholder==null||spreadsheetLeftTopPlaceholder.transformByState({width:rowHeaderWidth,height:columnHeaderHeight})}))}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{const{unit:workbook,unitId:workbookId}=this._context,{id:commandId}=command;if(sheets.COMMAND_LISTENER_SKELETON_CHANGE.includes(commandId)||this._sheetRenderService.checkMutationShouldTriggerRerender(commandId)){const worksheet=workbook.getActiveSheet();if(!worksheet)return;const workbookId2=this._context.unitId,worksheetId=worksheet.getSheetId(),params=command.params,{unitId,subUnitId}=params;if(unitId!==workbookId2||subUnitId!==worksheetId)return;commandId!==sheets.SetWorksheetActiveOperation.id&&this._sheetSkeletonManagerService.makeDirty({sheetId:worksheetId,commandId},!0),this._sheetSkeletonManagerService.setCurrent({sheetId:worksheetId,commandId})}else sheets.COMMAND_LISTENER_VALUE_CHANGE.includes(commandId)&&this._sheetSkeletonManagerService.reCalculate();command.type===core.CommandType.MUTATION&&this._markUnitDirty(workbookId,command)}))}_markUnitDirty(unitId,command){const{mainComponent:spreadsheet,scene}=this._context;if(command.id===engineFormula.SetFormulaCalculationNotificationMutation.id&&command.params.stageInfo!=null||(spreadsheet&&spreadsheet.makeDirty(),scene.makeDirty(),!command.params))return;const cmdParams=command.params,viewports=this._spreadsheetViewports(scene);if(command.id===sheets.SetRangeValuesMutation.id&&cmdParams.cellValue){const dirtyRange=this._cellValueToRange(cmdParams.cellValue),dirtyBounds=this._rangeToBounds([dirtyRange]);this._markViewportDirty(viewports,dirtyBounds),spreadsheet.setDirtyArea(dirtyBounds)}if(command.id===sheets.MoveRangeMutation.id&&cmdParams.from&&cmdParams.to){const fromRange=cmdParams.fromRange||this._cellValueToRange(cmdParams.from.value),toRange=cmdParams.toRange||this._cellValueToRange(cmdParams.to.value),dirtyBounds=this._rangeToBounds([fromRange,toRange]);this._markViewportDirty(viewports,dirtyBounds),spreadsheet.setDirtyArea(dirtyBounds)}}_cellValueToRange(cellValue){let minCol=0,maxCol=0,minRow=0,maxRow=0;for(const[_row,columnObj]of Object.entries(cellValue)){for(const column in columnObj)minCol>Number(column)&&(minCol=Number(column)),maxCol<Number(column)&&(maxCol=Number(column));minRow>Number(_row)&&(minRow=Number(_row)),maxRow<Number(_row)&&(maxRow=Number(_row))}return{startRow:minRow,endRow:maxRow,startColumn:minCol,endColumn:maxCol}}_rangeToBounds(ranges){const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{rowHeightAccumulation,columnWidthAccumulation,rowHeaderWidth,columnHeaderHeight}=skeleton,dirtyBounds=[];for(const r2 of ranges){const{startRow,endRow,startColumn,endColumn}=r2,top=startRow===0?0:rowHeightAccumulation[startRow-1]+columnHeaderHeight,bottom=rowHeightAccumulation[endRow]+columnHeaderHeight,left=startColumn===0?0:columnWidthAccumulation[startColumn-1]+rowHeaderWidth,right=columnWidthAccumulation[endColumn]+rowHeaderWidth;dirtyBounds.push({top,left,bottom,right,width:right-left,height:bottom-top})}return dirtyBounds}_markViewportDirty(viewports,dirtyBounds){const activeViewports=viewports.filter(vp=>vp.isActive&&vp.cacheBound);for(const vp of activeViewports)for(const b of dirtyBounds)core.Rectangle.hasIntersectionBetweenTwoRect(vp.cacheBound,b)&&vp.markDirty(!0)}_spreadsheetViewports(scene){return scene.getViewports().filter(v=>["viewMain","viewMainLeftTop","viewMainTop","viewMainLeft"].includes(v.viewportKey))}},__name(_a54,"SheetRenderController"),_a54);exports.SheetRenderController=__decorateClass$6([__decorateParam$6(1,core.IContextService),__decorateParam$6(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$6(3,core.Inject(exports.SheetsRenderService)),__decorateParam$6(4,core.ICommandService),__decorateParam$6(5,core.Optional(telemetry.ITelemetryService))],exports.SheetRenderController);const PRINTING_RANGE=core.createInterceptorKey("PRINTING_RANGE"),PRINTING_COMPONENT_COLLECT=core.createInterceptorKey("PRINTING_COMPONENT_COLLECT"),_SheetPrintInterceptorService=class _SheetPrintInterceptorService extends core.Disposable{constructor(){super();__publicField(this,"interceptor",new core.InterceptorManager({PRINTING_RANGE,PRINTING_COMPONENT_COLLECT}));this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_RANGE,{priority:-1,handler:__name(_value=>_value,"handler")})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().PRINTING_COMPONENT_COLLECT,{priority:-1,handler:__name(_value=>_value,"handler")}))}};__name(_SheetPrintInterceptorService,"SheetPrintInterceptorService");let SheetPrintInterceptorService=_SheetPrintInterceptorService;var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__defNormalProp$1=__name((obj,key,value)=>key in obj?__defProp$5(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp$1"),__decorateClass$5=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$5(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$5(target,key,result),result},"__decorateClass$5"),__decorateParam$5=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$5"),__publicField$1=__name((obj,key,value)=>__defNormalProp$1(obj,typeof key!="symbol"?key+"":key,value),"__publicField$1"),_a55;exports.UniverSheetsUIPlugin=(_a55=class extends core.Plugin{constructor(_config=defaultPluginConfig,_injector,_renderManagerService,_configService,_univerInstanceService){super(),this._config=_config,this._injector=_injector,this._renderManagerService=_renderManagerService,this._configService=_configService,this._univerInstanceService=_univerInstanceService;const{menu,...rest}=this._config;menu&&this._configService.setConfig("menu",menu,{merge:!0}),this._configService.setConfig(PLUGIN_CONFIG_KEY,rest)}onStarting(){core.registerDependencies(this._injector,core.mergeOverrideWithDependencies([[ShortcutExperienceService],[IEditorBridgeService,{useClass:exports.EditorBridgeService}],[ISheetClipboardService,{useClass:exports.SheetClipboardService}],[ISheetBarService,{useClass:SheetBarService}],[IFormatPainterService,{useClass:FormatPainterService}],[ICellEditorManagerService,{useClass:CellEditorManagerService}],[IFormulaEditorManagerService,{useClass:FormulaEditorManagerService}],[sheets.IRefSelectionsService,{useClass:sheets.RefSelectionsService}],[IAutoFillService,{useClass:exports.AutoFillService}],[SheetPrintInterceptorService],[IStatusBarService,{useClass:StatusBarService}],[IMarkSelectionService,{useClass:exports.MarkSelectionService}],[exports.HoverManagerService],[exports.DragManagerService],[exports.SheetCanvasPopManagerService],[exports.CellAlertManagerService],[SelectAllService],[ActiveWorksheetController],[exports.AutoHeightController],[exports.FormulaEditorController],[SheetClipboardController],[exports.SheetsRenderService],[exports.SheetUIController],[exports.StatusBarController],[exports.AutoFillController],[FormatPainterController],[SheetsDefinedNameController],[EditorDataSyncController],[SheetCheckboxController],[SheetPermissionPanelModel],[SheetPermissionUserManagerService],[SheetPermissionInterceptorClipboardController],[exports.SheetPermissionInterceptorBaseController],[exports.SheetPermissionInitController],[SheetPermissionRenderManagerController]],this._config.override)),core.touchDependencies(this._injector,[[SheetPermissionPanelModel]])}onReady(){this._config.disableAutoFocus||this._initAutoFocus(),this._registerRenderBasics(),core.touchDependencies(this._injector,[[exports.SheetUIController],[exports.SheetsRenderService],[ActiveWorksheetController],[exports.SheetPermissionInterceptorBaseController]])}onRendered(){this._registerRenderModules(),core.touchDependencies(this._injector,[[exports.SheetPermissionInitController],[SheetPermissionRenderManagerController],[SheetClipboardController],[exports.FormulaEditorController],[SheetsDefinedNameController],[exports.StatusBarController],[exports.AutoHeightController],[EditorDataSyncController],[SheetCheckboxController]])}onSteady(){core.touchDependencies(this._injector,[[FormatPainterController],[exports.AutoFillController],[SheetPermissionInterceptorClipboardController]])}_registerRenderBasics(){[[exports.SheetSkeletonManagerService],[exports.SheetRenderController],[ISheetSelectionRenderService,{useClass:exports.SheetSelectionRenderService}]].forEach(m2=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,m2))})}_registerRenderModules(){var _a61;const modules=[[exports.HeaderMoveRenderController],[HeaderUnhideRenderController],[exports.HeaderResizeRenderController],[SheetScrollManagerService],[exports.SheetsScrollRenderController],[exports.HeaderFreezeRenderController],[SheetsZoomRenderController],[SheetCellEditorResizeService],[FormatPainterRenderController],[CellAlertRenderController],[ForceStringAlertRenderController],[MarkSelectionRenderController],[exports.HoverRenderController],[exports.DragRenderController],[ForceStringRenderController],[exports.CellCustomRenderController],[SheetContextMenuRenderController],[MoveRangeRenderController],[EditorBridgeRenderController],[exports.EditingRenderController],[SheetPermissionInterceptorCanvasRenderController],[SheetPermissionInterceptorFormulaRenderController],[SheetPermissionRenderController],[WorksheetProtectionRenderController]],config=this._configService.getConfig(ui.PLUGIN_CONFIG_KEY);((_a61=config==null?void 0:config.contextMenu)!=null?_a61:!0)&&modules.push([HeaderMenuRenderController]),modules.forEach(m2=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,m2))})}_initAutoFocus(){const univerInstanceService=this._univerInstanceService;this.disposeWithMe(univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.filter(v=>!!v)).subscribe(workbook=>univerInstanceService.focusUnit(workbook.getUnitId())))}},__name(_a55,"UniverSheetsUIPlugin"),_a55);__publicField$1(exports.UniverSheetsUIPlugin,"pluginName","SHEET_UI_PLUGIN");__publicField$1(exports.UniverSheetsUIPlugin,"type",core.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsUIPlugin=__decorateClass$5([core.DependentOn(sheets.UniverSheetsPlugin),__decorateParam$5(1,core.Inject(core.Injector)),__decorateParam$5(2,engineRender.IRenderManagerService),__decorateParam$5(3,core.IConfigService),__decorateParam$5(4,core.IUniverInstanceService)],exports.UniverSheetsUIPlugin);var __defProp$4=Object.defineProperty,__getOwnPropDesc$4=Object.getOwnPropertyDescriptor,__decorateClass$4=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$4(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$4(target,key,result),result},"__decorateClass$4"),__decorateParam$4=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$4");const SHEET_NAVIGATION_COMMANDS=[MoveSelectionCommand.id,MoveSelectionEnterAndTabCommand.id];var _a56;let MobileSheetsScrollRenderController=(_a56=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService,_renderManagerService,_selectionManagerService,_scrollManagerService,_univerInstanceService){super(),this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._renderManagerService=_renderManagerService,this._selectionManagerService=_selectionManagerService,this._scrollManagerService=_scrollManagerService,this._univerInstanceService=_univerInstanceService,this._init()}scrollToRange(range){let{endRow,endColumn,startColumn,startRow}=range;const bounding=this._getViewportBounding();if(range.rangeType===core.RANGE_TYPE.ROW?(startColumn=0,endColumn=0):range.rangeType===core.RANGE_TYPE.COLUMN&&(startRow=0,endRow=0),bounding){const row=bounding.startRow>endRow?startRow:endRow,col=bounding.startColumn>endColumn?startColumn:endColumn;return this._scrollToCell(row,col)}else return this._scrollToCell(startRow,startColumn)}_init(){this._initCommandListener(),this._initScrollEventListener(),this._initPointerScrollEvent(),this._initSkeletonListener()}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(SHEET_NAVIGATION_COMMANDS.includes(command.id))this._scrollToSelection();else if(command.id===sheets.ScrollToCellOperation.id){const param=command.params;this.scrollToRange(param)}else if(command.id===ExpandSelectionCommand.id){const param=command.params;this._scrollToSelectionForExpand(param)}}))}_scrollToSelectionForExpand(param){setTimeout(()=>{const selection=this._selectionManagerService.getCurrentLastSelection();if(selection==null)return;const{startRow,startColumn,endRow,endColumn}=selection.range,bounds=this._getViewportBounding();if(bounds==null)return;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;startRow>viewportStartRow?row=endRow:endRow<viewportEndRow?row=startRow:row=viewportStartRow,startColumn>viewportStartColumn?column=endColumn:endColumn<viewportEndColumn?column=startColumn:column=viewportStartColumn,param.direction===core.Direction.DOWN?row=endRow:param.direction===core.Direction.UP?row=startRow:param.direction===core.Direction.RIGHT?column=endColumn:param.direction===core.Direction.LEFT&&(column=startColumn),this._scrollToCell(row,column)},0)}_getFreeze(){var _a61;const snapshot=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton.getWorksheetConfig();if(snapshot!=null)return snapshot.freeze}_initScrollEventListener(){const{scene}=this._context;if(scene==null)return;const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);viewportMain&&(this.disposeWithMe(core.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(rawScrollInfo=>{var _a61;if(rawScrollInfo==null){viewportMain.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(!skeleton)return;const{sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY}=rawScrollInfo,{startX,startY}=skeleton.getCellByIndexWithNoHeader(sheetViewStartRow,sheetViewStartColumn),viewportScrollX=startX+offsetX,viewportScrollY=startY+offsetY;viewportMain.scrollToViewportPos({viewportScrollX,viewportScrollY})}))),this.disposeWithMe(viewportMain.onScrollAfter$.subscribeEvent(scrollAfterParam=>{var _a61;if(!scrollAfterParam)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX,viewportScrollY,scrollX,scrollY}=scrollAfterParam,{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY),scrollInfo={sheetViewStartRow:row,sheetViewStartColumn:column,offsetX:columnOffset,offsetY:rowOffset};this._scrollManagerService.setScrollStateToCurrSheet(scrollInfo),this._scrollManagerService.validViewportScrollInfo$.next({...scrollInfo,scrollX,scrollY,viewportScrollX,viewportScrollY})})),this.disposeWithMe(viewportMain.onScrollByBar$.subscribeEvent(param=>{var _a61;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton;if(skeleton==null||param.isTrigger===!1)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX=0,viewportScrollY=0}=param,freeze=this._getFreeze(),{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY);this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartRow:row+((freeze==null?void 0:freeze.ySplit)||0),sheetViewStartColumn:column+((freeze==null?void 0:freeze.xSplit)||0),offsetX:columnOffset,offsetY:rowOffset})})))}_initSkeletonListener(){this.disposeWithMe(core.toDisposable(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(param=>{if(param==null)return;const scrollParam={unitId:param.unitId,sheetId:param.sheetId};this._scrollManagerService.setSearchParam(scrollParam);const sheetObject=this._getSheetObject();if(!sheetObject)return;const viewportMain=sheetObject.scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),currScrollInfo=this._scrollManagerService.getScrollStateByParam(scrollParam),{viewportScrollX,viewportScrollY}=this._scrollManagerService.calcViewportScrollFromRowColOffset(currScrollInfo);viewportMain&&(currScrollInfo?(viewportMain.viewportScrollX=viewportScrollX,viewportMain.viewportScrollY=viewportScrollY):(viewportMain.viewportScrollX=0,viewportMain.viewportScrollY=0),this._updateSceneSize(param))})))}_initPointerScrollEvent(){const sheetObject=this._getSheetObject();if(!sheetObject)return;const scrollManagerService=this._scrollManagerService,scene=sheetObject.scene,spreadsheet=sheetObject.spreadsheet,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),lastPointerPos={x:0,y:0};let _pointerScrolling=!1;const velocity={x:0,y:0},deceleration=.95;let scrollInertiaAnimationID=null;const pointerScrollInertia=__name(()=>{if(!viewportMain)return;velocity.x*=deceleration,velocity.y*=deceleration,lastPointerPos.x+=velocity.x,lastPointerPos.y+=velocity.y;const offsetX=velocity.x,offsetY=velocity.y;(offsetY!==0||offsetX!==0)&&this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetY,offsetX}),Math.abs(velocity.x)>1||Math.abs(velocity.y)>1?scrollInertiaAnimationID=requestAnimationFrame(pointerScrollInertia):scrollInertiaAnimationID=null},"pointerScrollInertia"),cancelInertiaAnimation=__name(()=>{cancelAnimationFrame(scrollInertiaAnimationID),scrollInertiaAnimationID=null},"cancelInertiaAnimation");spreadsheet.onPointerDown$.subscribeEvent((evt,state)=>{cancelInertiaAnimation(),viewportMain&&(lastPointerPos.x=evt.offsetX,lastPointerPos.y=evt.offsetY,_pointerScrolling=!0,state.stopPropagation())}),spreadsheet.onPointerMove$.subscribeEvent((evt,state)=>{if(!_pointerScrolling||!viewportMain)return;const e=evt,deltaX=-(e.offsetX-lastPointerPos.x),deltaY=-(e.offsetY-lastPointerPos.y);velocity.x=-(e.offsetX-lastPointerPos.x),velocity.y=-(e.offsetY-lastPointerPos.y);const offsetX=deltaX,offsetY=deltaY;(deltaX!==0||deltaY!==0)&&(offsetY!==0||offsetX!==0)&&this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetY,offsetX}),scrollManagerService.getCurrentScrollState(),lastPointerPos.x=e.offsetX,lastPointerPos.y=e.offsetY,state.stopPropagation()}),spreadsheet.onPointerUp$.subscribeEvent(_evt=>{_pointerScrolling=!1,scrollInertiaAnimationID=requestAnimationFrame(pointerScrollInertia)}),spreadsheet.onPointerLeave$.subscribeEvent(()=>{_pointerScrolling=!1}),spreadsheet.onPointerOut$.subscribeEvent(()=>{_pointerScrolling=!1}),scene.onPointerOut$.subscribeEvent(()=>{_pointerScrolling=!1}),scene.onPointerCancel$.subscribeEvent(()=>{_pointerScrolling=!1})}_updateSceneSize(param){var _a61;if(param==null)return;const{unitId}=this._context,{skeleton}=param,scene=(_a61=this._renderManagerService.getRenderById(unitId))==null?void 0:_a61.scene;if(skeleton==null||scene==null)return;const{rowTotalHeight,columnTotalWidth,rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const zoomRatio=worksheet.getZoomRatio()||1;scene==null||scene.setScaleValue(zoomRatio,zoomRatio),scene==null||scene.transformByState({width:rowHeaderWidthAndMarginLeft+columnTotalWidth,height:columnHeaderHeightAndMarginTop+rowTotalHeight})}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_scrollToSelectionByDirection(range){const bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;const{startRow,startColumn,endRow,endColumn}=range;startRow>=viewportStartRow&&(row=endRow),endRow<=viewportEndRow&&(row=startRow),startColumn>=viewportStartColumn&&(column=endColumn),endColumn<=viewportEndColumn&&(column=startColumn),this._scrollToCell(row,column)}_scrollToSelection(targetIsActualRowAndColumn=!0){const selection=this._selectionManagerService.getCurrentLastSelection();if(selection==null)return;const{startRow,startColumn,actualRow,actualColumn}=selection.primary,selectionStartRow=targetIsActualRowAndColumn?actualRow:startRow,selectionStartColumn=targetIsActualRowAndColumn?actualColumn:startColumn;this._scrollToCell(selectionStartRow,selectionStartColumn)}_getViewportBounding(){var _a61,_b;const scene=(_a61=this._getSheetObject())==null?void 0:_a61.scene;if(scene==null)return;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null)return;const skeleton=(_b=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_b.skeleton;if(skeleton==null)return;const bounds=viewport.getBounding();return skeleton.getRowColumnSegment(bounds)}_scrollToCell(row,column){var _a61,_b,_c,_d;const{rowHeightAccumulation,columnWidthAccumulation}=(_b=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton)!=null?_b:{};if(rowHeightAccumulation==null||columnWidthAccumulation==null)return!1;const scene=(_c=this._getSheetObject())==null?void 0:_c.scene;if(scene==null)return!1;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null||((_d=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_d.skeleton)==null)return!1;const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return!1;const{startColumn:freezeStartColumn,startRow:freezeStartRow,ySplit:freezeYSplit,xSplit:freezeXSplit}=worksheet.getFreeze(),bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let startSheetViewRow,startSheetViewColumn;if(row>=freezeStartRow&&column>=freezeStartColumn-freezeXSplit&&(row<=viewportStartRow&&(startSheetViewRow=row),row>=viewportEndRow)){const minRowAccumulation=rowHeightAccumulation[row]-viewport.height;for(let r2=viewportStartRow;r2<=row;r2++)if(rowHeightAccumulation[r2]>=minRowAccumulation){startSheetViewRow=r2+1;break}}if(column>=freezeStartColumn&&row>=freezeStartRow-freezeYSplit&&(column<=viewportStartColumn&&(startSheetViewColumn=column),column>=viewportEndColumn)){const minColumnAccumulation=columnWidthAccumulation[column]-viewport.width;for(let c=viewportStartColumn;c<=column;c++)if(columnWidthAccumulation[c]>=minColumnAccumulation){startSheetViewColumn=c+1;break}}if(startSheetViewRow===void 0&&startSheetViewColumn===void 0)return!1;const{offsetX,offsetY}=this._scrollManagerService.getCurrentScrollState()||{};return this._commandService.syncExecuteCommand(ScrollCommand.id,{sheetViewStartRow:startSheetViewRow,sheetViewStartColumn:startSheetViewColumn,offsetX:startSheetViewColumn===void 0?offsetX:0,offsetY:startSheetViewRow===void 0?offsetY:0})}},__name(_a56,"MobileSheetsScrollRenderController"),_a56);MobileSheetsScrollRenderController=__decorateClass$4([__decorateParam$4(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$4(2,core.ICommandService),__decorateParam$4(3,engineRender.IRenderManagerService),__decorateParam$4(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$4(5,core.Inject(SheetScrollManagerService)),__decorateParam$4(6,core.IUniverInstanceService)],MobileSheetsScrollRenderController);const mobileSheetBarContainer="univer-mobile-sheet-bar-container",mobileSheetBarSlider="univer-mobile-sheet-bar-slider",mobileSheetBarItem="univer-mobile-sheet-bar-item",mobileSheetBarItemActivated="univer-mobile-sheet-bar-item-activated",styles={mobileSheetBarContainer,mobileSheetBarSlider,mobileSheetBarItem,mobileSheetBarItemActivated};function MobileSheetBar(){const workbook=useActiveWorkbook();return workbook?jsxRuntimeExports.jsx(MobileSheetBarImpl,{workbook}):null}__name(MobileSheetBar,"MobileSheetBar");function MobileSheetBarImpl(props){const{workbook}=props,[sheetList,setSheetList]=React.useState([]),[activeKey,setActiveKey]=React.useState(""),tabMapRef=React.useRef(new Map),commandService=core.useDependency(core.ICommandService),updateSheetItems=React.useCallback(()=>{const currentSubUnitId=workbook.getActiveSheet().getSheetId(),sheets2=workbook.getSheets(),activeSheet=workbook.getActiveSheet(),sheetListItems=sheets2.filter(sheet=>!sheet.isSheetHidden()).map((sheet,index)=>{var _a61;return{sheetId:sheet.getSheetId(),label:sheet.getName(),index,selected:activeSheet===sheet,color:(_a61=sheet.getTabColor())!=null?_a61:void 0}});if(setSheetList(sheetListItems),setActiveKey(currentSubUnitId),tabMapRef.current.has(currentSubUnitId)){const element2=tabMapRef.current.get(currentSubUnitId);element2&&element2.scrollIntoView({behavior:"smooth",block:"nearest"})}tabMapRef.current.clear()},[workbook]);React.useEffect(()=>updateSheetItems(),[updateSheetItems]);const onTabClick=React.useCallback(sheetId=>{commandService.executeCommand(sheets.SetWorksheetActiveOperation.id,{unitId:workbook.getUnitId(),subUnitId:sheetId})},[commandService,workbook]);return React.useEffect(()=>{const disposable=commandService.onCommandExecuted(commandInfo=>{switch(commandInfo.id){case sheets.SetWorksheetHideMutation.id:case sheets.RemoveSheetMutation.id:case sheets.SetWorksheetNameMutation.id:case sheets.InsertSheetMutation.id:case sheets.SetWorksheetOrderMutation.id:case sheets.SetWorksheetActiveOperation.id:updateSheetItems();break}});return()=>disposable.dispose()},[commandService,updateSheetItems]),jsxRuntimeExports.jsx("div",{className:styles.mobileSheetBarContainer,children:jsxRuntimeExports.jsx("div",{className:styles.mobileSheetBarSlider,children:sheetList.map(sheet=>jsxRuntimeExports.jsx("div",{className:clsx(styles.mobileSheetBarItem,{[styles.mobileSheetBarItemActivated]:sheet.sheetId===activeKey}),onClick:__name(()=>onTabClick(sheet.sheetId),"onClick"),ref:__name(element2=>tabMapRef.current.set(sheet.sheetId,element2),"ref"),children:sheet.label},sheet.sheetId))})})}__name(MobileSheetBarImpl,"MobileSheetBarImpl");const menuSchema={[ui.ContextMenuPosition.MAIN_AREA]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.COL_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory}},[ui.ContextMenuGroup.LAYOUT]:{order:1},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.ROW_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory}},[ui.ContextMenuGroup.LAYOUT]:{order:1},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}}};var __defProp$3=Object.defineProperty,__getOwnPropDesc$3=Object.getOwnPropertyDescriptor,__decorateClass$3=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$3(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$3(target,key,result),result},"__decorateClass$3"),__decorateParam$3=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$3"),_a57;let SheetUIMobileController=(_a57=class extends core.Disposable{constructor(_injector,_componentManager,_layoutService,_commandService,_shortcutService,_menuManagerService,_uiPartsService){super(),this._injector=_injector,this._componentManager=_componentManager,this._layoutService=_layoutService,this._commandService=_commandService,this._shortcutService=_shortcutService,this._menuManagerService=_menuManagerService,this._uiPartsService=_uiPartsService,this._init()}_init(){this._initCustomComponents(),this._initCommands(),this._initMenus(),this._initShortcuts(),this._initWorkbenchParts(),this._initFocusHandler()}_initCustomComponents(){const componentManager=this._componentManager;this.disposeWithMe(componentManager.register(MENU_ITEM_INPUT_COMPONENT,MenuItemInput)),this.disposeWithMe(componentManager.register(BORDER_PANEL_COMPONENT,BorderPanel)),this.disposeWithMe(componentManager.register(COLOR_PICKER_COMPONENT,design.ColorPicker)),this.disposeWithMe(componentManager.register(FONT_FAMILY_COMPONENT,ui.FontFamily)),this.disposeWithMe(componentManager.register(FONT_FAMILY_ITEM_COMPONENT,ui.FontFamilyItem)),this.disposeWithMe(componentManager.register(FONT_SIZE_COMPONENT,ui.FontSize)),this.disposeWithMe(componentManager.register(DEFINED_NAME_CONTAINER,DefinedNameContainer))}_initCommands(){[AddWorksheetMergeAllCommand,AddWorksheetMergeCommand,AddWorksheetMergeHorizontalCommand,AddWorksheetMergeVerticalCommand,ChangeZoomRatioCommand,ExpandSelectionCommand,MoveSelectionCommand,MoveSelectionEnterAndTabCommand,RenameSheetOperation,RemoveSheetConfirmCommand,RemoveRowConfirmCommand,RemoveColConfirmCommand,HideRowConfirmCommand,HideColConfirmCommand,ScrollCommand,ScrollToCellCommand,SelectAllCommand,SetActivateCellEditOperation,sheets.SetBoldCommand,SetCellEditVisibleArrowOperation,SetCellEditVisibleOperation,SetCellEditVisibleWithF2Operation,SetRangeBoldCommand,SetRangeItalicCommand,SetRangeUnderlineCommand,SetRangeStrickThroughCommand,SetRangeSubscriptCommand,SetRangeSuperscriptCommand,SetRangeFontSizeCommand,SetRangeFontFamilyCommand,SetRangeTextColorCommand,sheets.SetItalicCommand,sheets.SetStrikeThroughCommand,sheets.SetFontFamilyCommand,sheets.SetFontSizeCommand,SetFormatPainterOperation,SetInfiniteFormatPainterCommand,SetOnceFormatPainterCommand,ApplyFormatPainterCommand,SetScrollOperation,SetScrollRelativeCommand,SetSelectionFrozenCommand,SetRowFrozenCommand,SetColumnFrozenCommand,CancelFrozenCommand,sheets.SetUnderlineCommand,SetZoomRatioCommand,SetZoomRatioOperation,ShowMenuListCommand,RefillCommand,InsertRangeMoveDownConfirmCommand,DeleteRangeMoveUpConfirmCommand,InsertRangeMoveRightConfirmCommand,DeleteRangeMoveLeftConfirmCommand,SidebarDefinedNameOperation,AutoFillCommand,AutoClearContentCommand,SheetPermissionOpenPanelOperation,SheetPermissionOpenDialogOperation,AddRangeProtectionFromToolbarCommand,AddRangeProtectionFromContextMenuCommand,ViewSheetPermissionFromContextMenuCommand,AddRangeProtectionFromSheetBarCommand,ViewSheetPermissionFromSheetBarCommand,ChangeSheetProtectionFromSheetBarCommand,DeleteRangeProtectionFromContextMenuCommand,SetRangeProtectionFromContextMenuCommand,AddWorksheetProtectionCommand,DeleteWorksheetProtectionCommand,SetWorksheetProtectionCommand,DeleteWorksheetProtectionFormSheetBarCommand,SetProtectionCommand].forEach(c=>{this.disposeWithMe(this._commandService.registerCommand(c))})}_initMenus(){this._menuManagerService.mergeMenu(menuSchema)}_initShortcuts(){[MoveSelectionDownShortcutItem,MoveSelectionUpShortcutItem,MoveSelectionLeftShortcutItem,MoveSelectionRightShortcutItem,MoveSelectionTabShortcutItem,MoveSelectionTabLeftShortcutItem,MoveSelectionEnterShortcutItem,MoveSelectionEnterUpShortcutItem,MoveSelectionEndDownShortcutItem,MoveSelectionEndUpShortcutItem,MoveSelectionEndLeftShortcutItem,MoveSelectionEndRightShortcutItem,ExpandSelectionDownShortcutItem,ExpandSelectionUpShortcutItem,ExpandSelectionLeftShortcutItem,ExpandSelectionRightShortcutItem,ExpandSelectionEndDownShortcutItem,ExpandSelectionEndUpShortcutItem,ExpandSelectionEndLeftShortcutItem,ExpandSelectionEndRightShortcutItem,SelectAllShortcutItem,ZoomInShortcutItem,ZoomOutShortcutItem,ResetZoomShortcutItem,PreventDefaultResetZoomShortcutItem,PreventDefaultZoomInShortcutItem,PreventDefaultZoomOutShortcutItem,SetBoldShortcutItem,SetItalicShortcutItem,SetUnderlineShortcutItem,SetStrikeThroughShortcutItem,ClearSelectionValueShortcutItem,...generateArrowSelectionShortCutItem(),EditorCursorEnterShortcut,StartEditWithF2Shortcut,EditorCursorTabShortcut,EditorBreakLineShortcut,EditorDeleteLeftShortcut,EditorDeleteLeftShortcutInActive,EditorCursorEscShortcut,SetRowHiddenShortcutItem,SetColHiddenShortcutItem].forEach(item=>{this.disposeWithMe(this._shortcutService.registerShortcut(item))})}_initWorkbenchParts(){this._uiPartsService.registerComponent(ui.BuiltInUIPart.HEADER,()=>core.connectInjector(MobileSheetBar,this._injector))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(core.UniverInstanceType.UNIVER_SHEET,_unitId=>{}))}},__name(_a57,"SheetUIMobileController"),_a57);SheetUIMobileController=__decorateClass$3([__decorateParam$3(0,core.Inject(core.Injector)),__decorateParam$3(1,core.Inject(ui.ComponentManager)),__decorateParam$3(2,ui.ILayoutService),__decorateParam$3(3,core.ICommandService),__decorateParam$3(4,ui.IShortcutService),__decorateParam$3(5,ui.IMenuManagerService),__decorateParam$3(6,ui.IUIPartsService)],SheetUIMobileController);var __defProp$2=Object.defineProperty,__getOwnPropDesc$2=Object.getOwnPropertyDescriptor,__decorateClass$2=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$2(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$2(target,key,result),result},"__decorateClass$2"),__decorateParam$2=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$2"),_a58;let SheetContextMenuMobileRenderController=(_a58=class extends core.Disposable{constructor(_context,_layoutService,_contextMenuService,_selectionManagerService,_selectionRenderService,_sheetSkeletonManagerService){super(),this._context=_context,this._layoutService=_layoutService,this._contextMenuService=_contextMenuService,this._selectionManagerService=_selectionManagerService,this._selectionRenderService=_selectionRenderService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._init()}_init(){let listenToSelectionChangeEvent=!1;this.disposeWithMe(this._selectionManagerService.selectionMoveStart$.subscribe(()=>listenToSelectionChangeEvent=!0)),this.disposeWithMe(this._selectionManagerService.selectionMoveEnd$.subscribe(selectionsList=>{if(!selectionsList||listenToSelectionChangeEvent===!1)return;listenToSelectionChangeEvent=!1;const selectionRangeWithStyle=selectionsList[0];if(!selectionRangeWithStyle.primary)return;const canvasRect=this._layoutService.getContentElement().getBoundingClientRect(),range=this._selectionRenderService.attachSelectionWithCoord(selectionRangeWithStyle),rangeType=selectionRangeWithStyle.range.rangeType,{scene}=this._context,viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),viewportScrollX=(viewMain==null?void 0:viewMain.viewportScrollX)||0,viewportScrollY=(viewMain==null?void 0:viewMain.viewportScrollY)||0;let clientX=0,clientY=0;const rowHeaderWidth=this._sheetSkeletonManagerService.getCurrent().skeleton.rowHeaderWidth;switch(rangeType){case core.RANGE_TYPE.NORMAL:clientX=range.rangeWithCoord.startX+canvasRect.left-viewportScrollX,clientY=range.rangeWithCoord.endY+canvasRect.top-viewportScrollY;break;case core.RANGE_TYPE.COLUMN:clientX=range.rangeWithCoord.startX+canvasRect.left-viewportScrollX,clientY=Math.min(canvasRect.height/2,range.rangeWithCoord.endY)+40;break;case core.RANGE_TYPE.ROW:clientX=(canvasRect.width-rowHeaderWidth)/2+20,clientY=range.rangeWithCoord.endY+canvasRect.top-viewportScrollY;break;case core.RANGE_TYPE.ALL:clientX=range.rangeWithCoord.startX+canvasRect.left,clientY=range.rangeWithCoord.startY+canvasRect.top;break;default:clientX=range.rangeWithCoord.startX+canvasRect.left-viewportScrollX,clientY=range.rangeWithCoord.endY+canvasRect.top-viewportScrollY;break}clientX=core.Tools.clamp(clientX,rowHeaderWidth,canvasRect.width),clientY=core.Tools.clamp(clientY,canvasRect.top,canvasRect.height),this._contextMenuService.triggerContextMenu({clientX,clientY,preventDefault:__name(()=>{},"preventDefault"),stopPropagation:__name(()=>{},"stopPropagation")},ui.ContextMenuPosition.MAIN_AREA)}))}},__name(_a58,"SheetContextMenuMobileRenderController"),_a58);SheetContextMenuMobileRenderController=__decorateClass$2([__decorateParam$2(1,ui.ILayoutService),__decorateParam$2(2,ui.IContextMenuService),__decorateParam$2(3,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$2(4,ISheetSelectionRenderService),__decorateParam$2(5,core.Inject(exports.SheetSkeletonManagerService))],SheetContextMenuMobileRenderController);const _MobileSelectionControl=class _MobileSelectionControl extends SelectionControl{constructor(_scene,_zIndex,_highlightHeader=!0,_themeService,_rangeType=core.RANGE_TYPE.NORMAL){super(_scene,_zIndex,_themeService,_highlightHeader);__publicField(this,"_fillControlTopLeft");__publicField(this,"_fillControlBottomRight");this._scene=_scene,this._zIndex=_zIndex,this._highlightHeader=_highlightHeader,this._themeService=_themeService,this._rangeType=_rangeType,this.initControlPoints()}initControlPoints(){const defaultStyle=this.defaultStyle,expandCornerSize=defaultStyle.expandCornerSize||0,expandCornerInnerSize=(defaultStyle.expandCornerSize||0)/4,AutofillStrokeWidth=defaultStyle.AutofillStrokeWidth||0,stroke=defaultStyle.stroke,AutofillStroke=defaultStyle.AutofillStroke,zIndex=this.zIndex;this._fillControlTopLeft=new engineRender.Rect(SELECTION_MANAGER_KEY.fillTopLeft+zIndex,{zIndex:zIndex+2,width:expandCornerSize,height:expandCornerSize,radius:expandCornerSize/2,visualWidth:expandCornerInnerSize,visualHeight:expandCornerInnerSize,strokeWidth:AutofillStrokeWidth}),this._fillControlBottomRight=new engineRender.Rect(SELECTION_MANAGER_KEY.fillBottomRight+zIndex,{zIndex:zIndex+2,width:expandCornerSize,height:expandCornerSize,radius:expandCornerSize/2,visualHeight:expandCornerInnerSize,visualWidth:expandCornerInnerSize,strokeWidth:AutofillStrokeWidth});const fillProps={fill:stroke,stroke:AutofillStroke,strokeScaleEnabled:!1};this._fillControlTopLeft.setProps({...fillProps}),this._fillControlBottomRight.setProps({...fillProps});const objs=[this._fillControlTopLeft,this._fillControlBottomRight];switch(this._rangeType){case core.RANGE_TYPE.ROW:this.rowHeaderGroup.addObjects(...objs);break;case core.RANGE_TYPE.COLUMN:this.columnHeaderGroup.addObjects(...objs);break;case core.RANGE_TYPE.NORMAL:this.selectionShapeGroup.addObjects(...objs)}this.getScene().addObjects(objs,SHEET_COMPONENT_SELECTION_LAYER_INDEX)}get fillControlTopLeft(){return this._fillControlTopLeft}set fillControlTopLeft(value){this._fillControlTopLeft=value}get fillControlBottomRight(){return this._fillControlBottomRight}set fillControlBottomRight(value){this._fillControlBottomRight=value}get rangeType(){return this._rangeType}set rangeType(value){this._rangeType=value}dispose(){var _a61,_b;(_a61=this._fillControlBottomRight)==null||_a61.dispose(),(_b=this._fillControlTopLeft)==null||_b.dispose(),super.dispose()}_setSizeAndStyleForSelectionControl(style){var _a61,_b;super._setSizeAndStyleForSelectionControl(style);const defaultStyle=this.defaultStyle;style==null&&(style=defaultStyle);const{widgets=defaultStyle.widgets,hasAutoFill:autoFillEnabled=defaultStyle.hasAutoFill}=style;if(this.currentStyle=style,autoFillEnabled===!0&&!super._hasWidgets(widgets)){const{viewportScrollX,viewportScrollY}=this.getViewportMainScrollInfo(),{endX,endY}=this.selectionModel;this.transformControlPoint(viewportScrollX,viewportScrollY,endX,endY),this.fillControlTopLeft.show(),this.fillControlBottomRight.show()}else(_a61=this.fillControlTopLeft)==null||_a61.hide(),(_b=this.fillControlBottomRight)==null||_b.hide()}getViewportMainScrollInfo(){const viewMain=this.getScene().getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);return{viewportScrollX:(viewMain==null?void 0:viewMain.viewportScrollX)||0,viewportScrollY:(viewMain==null?void 0:viewMain.viewportScrollY)||0,width:(viewMain==null?void 0:viewMain.width)||0,height:(viewMain==null?void 0:viewMain.height)||0}}transformControlPoint(viewportScrollX=0,viewportScrollY=0,sheetContentWidth=0,sheetContentHeight=0){const style=this.currentStyle,rangeType=this.selectionModel.rangeType,expandCornerSize=style.expandCornerSize,{startX,startY,endX,endY}=this.selectionModel,viewportSizeInfo=this.getViewportMainScrollInfo(),viewportW=viewportSizeInfo.width,viewportH=viewportSizeInfo.height;switch(rangeType){case core.RANGE_TYPE.NORMAL:this.fillControlTopLeft.transformByState({left:-expandCornerSize/2,top:-expandCornerSize/2}),this.fillControlBottomRight.transformByState({left:endX-startX-expandCornerSize/2,top:endY-startY-expandCornerSize/2});break;case core.RANGE_TYPE.ROW:{const left=Math.min(viewportW/2+viewportScrollX,sheetContentWidth),controlLeft=-expandCornerSize/2+left;this.fillControlTopLeft.transformByState({left:controlLeft,top:-expandCornerSize/2}),this.fillControlBottomRight.transformByState({left:controlLeft,top:-expandCornerSize/2+endY-startY})}break;case core.RANGE_TYPE.COLUMN:{const top=Math.min(+viewportH/2+viewportScrollY,sheetContentHeight),controlTop=-expandCornerSize/2+top;this.fillControlTopLeft.transformByState({left:-expandCornerSize/2,top:controlTop}),this.fillControlBottomRight.transformByState({left:-expandCornerSize/2+endX-startX,top:controlTop})}break;default:console.error("unknown range type")}}};__name(_MobileSelectionControl,"MobileSelectionControl");let MobileSelectionControl=_MobileSelectionControl;var __defProp$1=Object.defineProperty,__getOwnPropDesc$1=Object.getOwnPropertyDescriptor,__decorateClass$1=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$1(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$1(target,key,result),result},"__decorateClass$1"),__decorateParam$1=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$1"),_a59;let MobileSheetsSelectionRenderService=(_a59=class extends BaseSelectionRenderService{constructor(_context,injector,themeService,shortcutService,selectionManagerService,sheetSkeletonManagerService,_logService,_commandService,_contextService,_scrollManagerService){super(injector,themeService,shortcutService,sheetSkeletonManagerService);__publicField(this,"_workbookSelections");__publicField(this,"_renderDisposable",null);__publicField(this,"_expandingSelection",!1);__publicField(this,"_selectionControls",[]);__publicField(this,"expandingControlMode","bottom-right");this._context=_context,this._logService=_logService,this._commandService=_commandService,this._contextService=_contextService,this._scrollManagerService=_scrollManagerService,this._workbookSelections=selectionManagerService.getWorkbookSelections(this._context.unitId),this._init()}_init(){const sheetObject=this._getSheetObject();this._initEventListeners(sheetObject),this._initSelectionChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener(),this._updateControlPointWhenScrolling()}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{if(param==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const unitId=this._context.unitId,{sheetId,skeleton}=param,{scene}=this._context,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);this._changeRuntime(skeleton,scene,viewportMain),this._workbookSelections.getCurrentLastSelection()||this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,selections:[getTopLeftSelection(skeleton)]})}))}_initSelectionChangeListener(){this.disposeWithMe(this._workbookSelections.selectionMoveEnd$.subscribe(params=>{this._reset();for(const selectionWithStyle of params){const selectionData=attachSelectionWithCoord(selectionWithStyle,this._skeleton);this._addSelectionControlBySelectionData(selectionData)}}))}_initEventListeners(sheetObject){const{spreadsheetRowHeader,spreadsheetColumnHeader,spreadsheet,spreadsheetLeftTopPlaceholder}=sheetObject,{scene}=this._context;this._initSpreadsheetEvent(sheetObject),this.disposeWithMe(spreadsheetRowHeader==null?void 0:spreadsheetRowHeader.onPointerUp$.subscribeEvent((evt,_state)=>{if(this._normalSelectionDisabled())return;const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{row}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);isThisRowSelected(this._workbookSelections.getCurrentSelections(),row)||(this.createNewSelection(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.ROW,this._getActiveViewport(evt)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(spreadsheetColumnHeader==null?void 0:spreadsheetColumnHeader.onPointerUp$.subscribeEvent((evt,_state)=>{if(this._normalSelectionDisabled())return;const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);isThisColSelected(this._workbookSelections.getCurrentSelections(),column)||(this.createNewSelection(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.COLUMN,this._getActiveViewport(evt)),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()))})),this.disposeWithMe(spreadsheetLeftTopPlaceholder==null?void 0:spreadsheetLeftTopPlaceholder.onPointerUp$.subscribeEvent((_evt,state)=>{if(this._normalSelectionDisabled())return;this._reset();const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,selectionWithStyle=getAllSelection(skeleton),selectionData=attachSelectionWithCoord(selectionWithStyle,skeleton);this._addSelectionControlBySelectionData(selectionData),this.refreshSelectionMoveStart(),state.stopPropagation(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}))}_initSpreadsheetEvent(sheetObject){const{spreadsheet}=sheetObject;let longPressTimer;const longPressDuration=500,pointerDownPos={x:0,y:0},clearLongPressTimer=__name(()=>{clearTimeout(longPressTimer)},"clearLongPressTimer"),createNewSelection=__name((evt,showContextMenu)=>{this.createNewSelection(evt,spreadsheet.zIndex+1,core.RANGE_TYPE.NORMAL,this._getActiveViewport(evt)),showContextMenu&&this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())},"createNewSelection");spreadsheet==null||spreadsheet.onPointerMove$.subscribeEvent((evt,_state)=>{(Math.abs(evt.offsetX-pointerDownPos.x)>10||Math.abs(evt.offsetY-pointerDownPos.y)>10)&&clearLongPressTimer()});const spreadsheetPointerDownSub=spreadsheet==null?void 0:spreadsheet.onPointerDown$.subscribeEvent((evt,state)=>{pointerDownPos.x=evt.offsetX,pointerDownPos.y=evt.offsetY,longPressTimer=setTimeout(()=>{createNewSelection(evt,!0)},longPressDuration),state.stopPropagation()}),spreadsheetPointerUpSub=spreadsheet==null?void 0:spreadsheet.onPointerUp$.subscribeEvent((evt,state)=>{if(this._normalSelectionDisabled())return;clearTimeout(longPressTimer);const edge=10;Math.abs(evt.offsetX-pointerDownPos.x)>edge||Math.abs(evt.offsetY-pointerDownPos.y)>edge||(createNewSelection(evt,!1),state.stopPropagation())});this.disposeWithMe(core.toDisposable(spreadsheetPointerDownSub)),this.disposeWithMe(core.toDisposable(spreadsheetPointerUpSub))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(sheets.DISABLE_NORMAL_SELECTIONS).pipe(rxjs.startWith(!1),rxjs.distinctUntilChanged()).subscribe(disabled=>{var _a61;disabled?((_a61=this._renderDisposable)==null||_a61.dispose(),this._renderDisposable=null,this._reset()):this._renderDisposable=core.toDisposable(this.selectionMoveEnd$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVE_END)))}))}_updateSelections(selectionDataWithStyleList,type){const workbook=this._context.unit,unitId=workbook.getUnitId(),sheetId=workbook.getActiveSheet().getSheetId();selectionDataWithStyleList.length!==0&&this._commandService.executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,type,selections:selectionDataWithStyleList.map(selectionDataWithStyle=>sheets.convertSelectionDataToRange(selectionDataWithStyle))})}createNewSelection(evt,_zIndex=0,rangeType=core.RANGE_TYPE.NORMAL,viewport){this._shouldDetectMergedCells=rangeType===core.RANGE_TYPE.NORMAL;const skeleton=this._skeleton,scene=this._scene;if(!scene||!skeleton)return;viewport&&(this._activeViewport=viewport);const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY]));let{x:viewportPosX,y:viewportPosY}=relativeCoords;const scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords),{scaleX,scaleY}=scene.getAncestorScale(),cursorCellRangeInfo=this._getCellRangeByCursorPosition(viewportPosX,viewportPosY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return!1;const{rangeWithCoord:cursorCellRange,primaryWithCoord:primaryCursorCellRange}=cursorCellRangeInfo,cursorCellRangeWithRangeType={...cursorCellRange,rangeType};this._startRangeWhenPointerDown={...cursorCellRange,rangeType};let activeSelectionControl=this.getActiveSelectionControl();for(const control of this.getSelectionControls())if(control.model.isEqual(cursorCellRangeWithRangeType)){activeSelectionControl=control;break}(activeSelectionControl==null?void 0:activeSelectionControl.model.rangeType)!==rangeType&&(this._clearSelectionControls(),activeSelectionControl=this.newSelectionControl(scene,rangeType)),this._updateSelectionControlByRange(activeSelectionControl,cursorCellRangeWithRangeType,primaryCursorCellRange),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._expandingSelection=!1,(rangeType===core.RANGE_TYPE.ROW||rangeType===core.RANGE_TYPE.COLUMN)&&(rangeType===core.RANGE_TYPE.ROW?viewportPosX=0:rangeType===core.RANGE_TYPE.COLUMN&&(viewportPosY=0),this._movingHandler(viewportPosX,viewportPosY,activeSelectionControl,rangeType))}newSelectionControl(scene,rangeType){const selectionControls=this.getSelectionControls(),control=new MobileSelectionControl(scene,selectionControls.length,this._isHeaderHighlight,this._themeService,rangeType);this._selectionControls.push(control);const{expandingModeForTopLeft,expandingModeForBottomRight}=(()=>{switch(rangeType){case core.RANGE_TYPE.NORMAL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};case core.RANGE_TYPE.ROW:return{expandingModeForTopLeft:"top",expandingModeForBottomRight:"bottom"};case core.RANGE_TYPE.COLUMN:return{expandingModeForTopLeft:"left",expandingModeForBottomRight:"right"};case core.RANGE_TYPE.ALL:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"};default:return{expandingModeForTopLeft:"top-left",expandingModeForBottomRight:"bottom-right"}}})();return control.fillControlTopLeft.onPointerDown$.subscribeEvent(evt=>{this._expandingSelection=!0,this.expandingControlMode=expandingModeForTopLeft,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(evt,rangeType,this._activeViewport)}),control.fillControlBottomRight.onPointerDown$.subscribeEvent(evt=>{this._expandingSelection=!0,this.expandingControlMode=expandingModeForBottomRight,this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._fillControlPointerDownHandler(evt,rangeType,this._activeViewport)}),(rangeType===core.RANGE_TYPE.ROW||rangeType===core.RANGE_TYPE.COLUMN)&&!scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),control}_getActiveViewport(evt){const sheetObject=this._getSheetObject();return sheetObject==null?void 0:sheetObject.scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([evt.offsetX,evt.offsetY]))}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_normalSelectionDisabled(){return this._contextService.getContextValue(sheets.DISABLE_NORMAL_SELECTIONS)}getSelectionControls(){return this._selectionControls}_fillControlPointerDownHandler(evt,rangeType=core.RANGE_TYPE.NORMAL,viewport,scrollTimerType=engineRender.ScrollTimerType.ALL){var _a61,_b,_c;const skeleton=this._skeleton,scene=this._scene;if(!scene||!skeleton)return;viewport&&(this._activeViewport=viewport);const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),activeSelectionControl=this.getActiveSelectionControl();if(!activeSelectionControl)return;this._changeCurrCellWhenControlPointerDown(),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),this._clearUpdatingListeners(),this._addEndingListeners(),this._scrollTimer=engineRender.ScrollTimer.create(this._scene,scrollTimerType),this._scrollTimer.startScroll((_a61=viewportMain==null?void 0:viewportMain.left)!=null?_a61:0,(_b=viewportMain==null?void 0:viewportMain.top)!=null?_b:0,viewportMain),(_c=scene.getTransformer())==null||_c.clearSelectedObjects();const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evt.offsetX,evt.offsetY]));this._setupPointerMoveListener(viewportMain,activeSelectionControl,rangeType,scrollTimerType,relativeCoords.x,relativeCoords.y);const disposableShortcut=this._shortcutService.forceEscape();this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(_evt=>{this.endSelection(),this._expandingSelection=!1,this.expandingControlMode="bottom-right",this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),disposableShortcut.dispose()})}_changeCurrCellWhenControlPointerDown(){const activeSelectionControl=this.getActiveSelectionControl(),skeleton=this._skeleton;let currCellRange;const{startRow,startColumn,endRow,endColumn}=activeSelectionControl.model;switch(this.expandingControlMode){case"top-left":currCellRange=skeleton.getCellByIndex(endRow,endColumn);break;case"bottom-right":currCellRange=skeleton.getCellByIndex(startRow,startColumn);break;case"left":currCellRange=skeleton.getCellByIndex(startRow,endColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;case"right":currCellRange=skeleton.getCellByIndex(startRow,startColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;case"top":currCellRange=skeleton.getCellByIndex(endRow,startColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;case"bottom":currCellRange=skeleton.getCellByIndex(startRow,startColumn),currCellRange.isMerged=!1,currCellRange.isMergedMainCell=!1;break;default:currCellRange=skeleton.getCellByIndex(startRow,startColumn)}return activeSelectionControl.updateCurrCell(currCellRange),currCellRange}_movingHandler(offsetX,offsetY,activeSelectionControl,rangeType){var _a61,_b,_c,_d,_e,_f,_g,_h,_i,_j,_k,_l,_m;this._shouldDetectMergedCells=rangeType===core.RANGE_TYPE.NORMAL;const skeleton=this._skeleton,scene=this._scene,currSelectionRange={startRow:activeSelectionControl.model.startRow,endRow:activeSelectionControl.model.endRow,startColumn:activeSelectionControl.model.startColumn,endColumn:activeSelectionControl.model.endColumn},viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),targetViewport=(_a61=this._getViewportByCell(currSelectionRange.endRow,currSelectionRange.endColumn))!=null?_a61:viewportMain,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),targetViewport),{scaleX,scaleY}=scene.getAncestorScale();rangeType===core.RANGE_TYPE.ROW?offsetX=Number.POSITIVE_INFINITY:rangeType===core.RANGE_TYPE.COLUMN&&(offsetY=Number.POSITIVE_INFINITY);const cursorCellRangeInfo=this._getCellRangeByCursorPosition(offsetX,offsetY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return!1;const{rangeWithCoord:cursorCellRange}=cursorCellRangeInfo,currCellRange=activeSelectionControl.model.currentCell,startRowOfActiveCell=(_b=currCellRange==null?void 0:currCellRange.mergeInfo.startRow)!=null?_b:-1,endRowOfActiveCell=(_c=currCellRange==null?void 0:currCellRange.mergeInfo.endRow)!=null?_c:-1,startColumnOfActiveCell=(_d=currCellRange==null?void 0:currCellRange.mergeInfo.startColumn)!=null?_d:-1,endColOfActiveCell=(_e=currCellRange==null?void 0:currCellRange.mergeInfo.endColumn)!=null?_e:-1;let newSelectionRange={startRow:Math.min(cursorCellRange.startRow,startRowOfActiveCell),startColumn:Math.min(cursorCellRange.startColumn,startColumnOfActiveCell),endRow:Math.max(cursorCellRange.endRow,endRowOfActiveCell),endColumn:Math.max(cursorCellRange.endColumn,endColOfActiveCell)};if(rangeType===core.RANGE_TYPE.NORMAL?newSelectionRange=skeleton.getSelectionMergeBounding(newSelectionRange.startRow,newSelectionRange.startColumn,newSelectionRange.endRow,newSelectionRange.endColumn):rangeType===core.RANGE_TYPE.COLUMN?newSelectionRange={startRow:Math.min(cursorCellRange.startRow,(_f=currCellRange==null?void 0:currCellRange.actualRow)!=null?_f:-1),startColumn:Math.min(cursorCellRange.startColumn,(_g=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_g:-1),endRow:Math.max(cursorCellRange.endRow,(_h=currCellRange==null?void 0:currCellRange.actualRow)!=null?_h:-1),endColumn:Math.max(cursorCellRange.endColumn,(_i=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_i:-1)}:rangeType===core.RANGE_TYPE.ROW&&(newSelectionRange={startRow:Math.min(cursorCellRange.startRow,(_j=currCellRange==null?void 0:currCellRange.actualRow)!=null?_j:-1),startColumn:Math.min(cursorCellRange.startColumn,(_k=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_k:-1),endRow:Math.max(cursorCellRange.endRow,(_l=currCellRange==null?void 0:currCellRange.actualRow)!=null?_l:-1),endColumn:Math.max(cursorCellRange.endColumn,(_m=currCellRange==null?void 0:currCellRange.actualColumn)!=null?_m:-1)}),!newSelectionRange)return!1;const startCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.startRow,newSelectionRange.startColumn),endCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.endRow,newSelectionRange.endColumn),newSelectionRangeWithCoord={startColumn:newSelectionRange.startColumn,startRow:newSelectionRange.startRow,endColumn:newSelectionRange.endColumn,endRow:newSelectionRange.endRow,startY:(startCellXY==null?void 0:startCellXY.startY)||0,endY:(endCellXY==null?void 0:endCellXY.endY)||0,startX:(startCellXY==null?void 0:startCellXY.startX)||0,endX:(endCellXY==null?void 0:endCellXY.endX)||0};(currSelectionRange.startRow!==newSelectionRange.startRow||currSelectionRange.startColumn!==newSelectionRange.startColumn||currSelectionRange.endRow!==newSelectionRange.endRow||currSelectionRange.endColumn!==newSelectionRange.endColumn)&&activeSelectionControl&&(this._updateSelectionControlByRange(activeSelectionControl,newSelectionRangeWithCoord),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateControlPointWhenScrolling(){const{scene}=this._context;if(!scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN))return;const sub=this._scrollManagerService.validViewportScrollInfo$.subscribe(param=>{var _a61;if(param==null)return;const{viewportScrollX,viewportScrollY}=param,activeControl=this.getActiveSelectionControl();if(activeControl==null)return;const skeleton=(_a61=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a61.skeleton,sheetContentHeight=skeleton==null?void 0:skeleton.rowTotalHeight,sheetContentWidth=skeleton==null?void 0:skeleton.columnTotalWidth,rangeType=activeControl.rangeType;rangeType===core.RANGE_TYPE.COLUMN?activeControl.transformControlPoint(0,viewportScrollY,sheetContentWidth,sheetContentHeight):rangeType===core.RANGE_TYPE.ROW&&activeControl.transformControlPoint(viewportScrollX,0,sheetContentWidth,sheetContentHeight)});this.disposeWithMe(core.toDisposable(sub))}},__name(_a59,"MobileSheetsSelectionRenderService"),_a59);MobileSheetsSelectionRenderService=__decorateClass$1([__decorateParam$1(1,core.Inject(core.Injector)),__decorateParam$1(2,core.Inject(core.ThemeService)),__decorateParam$1(3,ui.IShortcutService),__decorateParam$1(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$1(5,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$1(6,core.ILogService),__decorateParam$1(7,core.ICommandService),__decorateParam$1(8,core.IContextService),__decorateParam$1(9,core.Inject(SheetScrollManagerService))],MobileSheetsSelectionRenderService);var __defProp2=Object.defineProperty,__getOwnPropDesc=Object.getOwnPropertyDescriptor,__defNormalProp2=__name((obj,key,value)=>key in obj?__defProp2(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value,"__defNormalProp"),__decorateClass=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp2(target,key,result),result},"__decorateClass"),__decorateParam=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam"),__publicField2=__name((obj,key,value)=>__defNormalProp2(obj,typeof key!="symbol"?key+"":key,value),"__publicField"),_a60;exports.UniverSheetsMobileUIPlugin=(_a60=class extends core.Plugin{constructor(_config=defaultPluginConfig,_injector,_renderManagerService,_univerInstanceService){super(),this._config=_config,this._injector=_injector,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService}onStarting(){[[ShortcutExperienceService],[ISheetClipboardService,{useClass:exports.SheetClipboardService}],[ISheetBarService,{useClass:SheetBarService}],[IFormatPainterService,{useClass:FormatPainterService}],[IAutoFillService,{useClass:exports.AutoFillService}],[SheetPrintInterceptorService],[ISheetSelectionRenderService,{useClass:MobileSheetsSelectionRenderService}],[IStatusBarService,{useClass:StatusBarService}],[IMarkSelectionService,{useClass:exports.MarkSelectionService}],[exports.HoverManagerService],[exports.DragManagerService],[exports.SheetCanvasPopManagerService],[exports.CellAlertManagerService],[SelectAllService],[ActiveWorksheetController],[exports.AutoHeightController],[SheetClipboardController],[exports.SheetsRenderService],[SheetUIMobileController],[exports.StatusBarController],[SheetPermissionPanelModel],[SheetPermissionUserManagerService],[WorksheetProtectionRenderController],[SheetPermissionInterceptorClipboardController],[exports.SheetPermissionInterceptorBaseController],[exports.SheetPermissionInitController],[SheetPermissionRenderManagerController]].forEach(d=>this._injector.add(d))}onReady(){this._markSheetAsFocused(),this._registerRenderBasics(),this._injector.get(SheetUIMobileController)}onRendered(){this._registerRenderModules()}_registerRenderBasics(){[[exports.SheetSkeletonManagerService],[exports.SheetRenderController],[ISheetSelectionRenderService,{useClass:MobileSheetsSelectionRenderService}],[SheetScrollManagerService]].forEach(renderDep=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,renderDep))})}_registerRenderModules(){[[exports.HeaderMoveRenderController],[exports.HeaderFreezeRenderController],[MobileSheetsScrollRenderController],[SheetsZoomRenderController],[FormatPainterRenderController],[CellAlertRenderController],[ForceStringAlertRenderController],[MarkSelectionRenderController],[exports.HoverRenderController],[exports.DragRenderController],[ForceStringRenderController],[exports.CellCustomRenderController],[SheetContextMenuMobileRenderController],[SheetPermissionInterceptorCanvasRenderController],[SheetPermissionInterceptorFormulaRenderController],[SheetPermissionRenderController]].forEach(renderModule=>{this.disposeWithMe(this._renderManagerService.registerRenderModule(core.UniverInstanceType.UNIVER_SHEET,renderModule))})}_markSheetAsFocused(){const univerInstanceService=this._univerInstanceService;this.disposeWithMe(univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.filter(v=>!!v)).subscribe(workbook=>{univerInstanceService.focusUnit(workbook.getUnitId())}))}},__name(_a60,"UniverSheetsMobileUIPlugin"),_a60);__publicField2(exports.UniverSheetsMobileUIPlugin,"pluginName","SHEET_UI_PLUGIN");__publicField2(exports.UniverSheetsMobileUIPlugin,"type",core.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsMobileUIPlugin=__decorateClass([core.DependentOn(sheets.UniverSheetsPlugin,ui.UniverMobileUIPlugin),__decorateParam(1,core.Inject(core.Injector)),__decorateParam(2,engineRender.IRenderManagerService),__decorateParam(3,core.IUniverInstanceService)],exports.UniverSheetsMobileUIPlugin);exports.AFFECT_LAYOUT_STYLES=AFFECT_LAYOUT_STYLES;exports.APPLY_TYPE=APPLY_TYPE;exports.AddRangeProtectionCommand=AddRangeProtectionCommand;exports.AddRangeProtectionFromContextMenuCommand=AddRangeProtectionFromContextMenuCommand;exports.AddRangeProtectionFromSheetBarCommand=AddRangeProtectionFromSheetBarCommand;exports.AddRangeProtectionFromToolbarCommand=AddRangeProtectionFromToolbarCommand;exports.AddWorksheetMergeAllCommand=AddWorksheetMergeAllCommand;exports.AddWorksheetMergeCommand=AddWorksheetMergeCommand;exports.AddWorksheetMergeHorizontalCommand=AddWorksheetMergeHorizontalCommand;exports.AddWorksheetMergeVerticalCommand=AddWorksheetMergeVerticalCommand;exports.AddWorksheetProtectionCommand=AddWorksheetProtectionCommand;exports.ApplyFormatPainterCommand=ApplyFormatPainterCommand;exports.AutoClearContentCommand=AutoClearContentCommand;exports.AutoFillCommand=AutoFillCommand;exports.BaseSelectionRenderService=BaseSelectionRenderService;exports.COPY_TYPE=COPY_TYPE;exports.CancelFrozenCommand=CancelFrozenCommand;exports.CellAlertType=CellAlertType;exports.CellEditorManagerService=CellEditorManagerService;exports.ChangeSheetProtectionFromSheetBarCommand=ChangeSheetProtectionFromSheetBarCommand;exports.ChangeZoomRatioCommand=ChangeZoomRatioCommand;exports.DATA_TYPE=DATA_TYPE;exports.DeleteRangeMoveLeftConfirmCommand=DeleteRangeMoveLeftConfirmCommand;exports.DeleteRangeMoveUpConfirmCommand=DeleteRangeMoveUpConfirmCommand;exports.DeleteRangeProtectionFromContextMenuCommand=DeleteRangeProtectionFromContextMenuCommand;exports.DeleteRangeSelectionCommand=DeleteRangeSelectionCommand;exports.DeleteWorksheetProtectionCommand=DeleteWorksheetProtectionCommand;exports.DeleteWorksheetProtectionFormSheetBarCommand=DeleteWorksheetProtectionFormSheetBarCommand;exports.ExpandSelectionCommand=ExpandSelectionCommand;exports.FONT_FAMILY_COMPONENT=FONT_FAMILY_COMPONENT;exports.FONT_FAMILY_ITEM_COMPONENT=FONT_FAMILY_ITEM_COMPONENT;exports.FONT_SIZE_COMPONENT=FONT_SIZE_COMPONENT;exports.FormatPainterStatus=FormatPainterStatus;exports.HideColConfirmCommand=HideColConfirmCommand;exports.HideRowConfirmCommand=HideRowConfirmCommand;exports.IAutoFillService=IAutoFillService;exports.ICellEditorManagerService=ICellEditorManagerService;exports.IEditorBridgeService=IEditorBridgeService;exports.IFormatPainterService=IFormatPainterService;exports.IFormulaEditorManagerService=IFormulaEditorManagerService;exports.IMarkSelectionService=IMarkSelectionService;exports.ISheetClipboardService=ISheetClipboardService;exports.ISheetSelectionRenderService=ISheetSelectionRenderService;exports.InsertRangeMoveDownConfirmCommand=InsertRangeMoveDownConfirmCommand;exports.InsertRangeMoveRightConfirmCommand=InsertRangeMoveRightConfirmCommand;exports.JumpOver=JumpOver;exports.MobileSheetBar=MobileSheetBar;exports.MoveSelectionCommand=MoveSelectionCommand;exports.MoveSelectionEnterAndTabCommand=MoveSelectionEnterAndTabCommand;exports.PASTE_SPECIAL_MENU_ID=PASTE_SPECIAL_MENU_ID;exports.PREDEFINED_HOOK_NAME=PREDEFINED_HOOK_NAME;exports.RANGE_SELECTOR_COMPONENT_KEY=RANGE_SELECTOR_COMPONENT_KEY;exports.RANGE_SELECTOR_SYMBOLS=RANGE_SELECTOR_SYMBOLS;exports.RefillCommand=RefillCommand;exports.RemoveColConfirmCommand=RemoveColConfirmCommand;exports.RemoveRowConfirmCommand=RemoveRowConfirmCommand;exports.RemoveSheetConfirmCommand=RemoveSheetConfirmCommand;exports.RenameSheetOperation=RenameSheetOperation;exports.RenderSheetContent=RenderSheetContent;exports.RenderSheetFooter=RenderSheetFooter;exports.RenderSheetHeader=RenderSheetHeader;exports.ResetScrollCommand=ResetScrollCommand;exports.SELECTION_SHAPE_DEPTH=SELECTION_SHAPE_DEPTH;exports.SHEET_UI_PLUGIN_NAME=SHEET_UI_PLUGIN_NAME;exports.SHEET_VIEW_KEY=SHEET_VIEW_KEY;exports.ScrollCommand=ScrollCommand;exports.ScrollToCellCommand=ScrollToCellCommand;exports.ScrollToRangeOperation=ScrollToRangeOperation;exports.SelectAllCommand=SelectAllCommand;exports.SelectionShape=SelectionControl;exports.SetActivateCellEditOperation=SetActivateCellEditOperation;exports.SetCellEditVisibleArrowOperation=SetCellEditVisibleArrowOperation;exports.SetCellEditVisibleOperation=SetCellEditVisibleOperation;exports.SetCellEditVisibleWithF2Operation=SetCellEditVisibleWithF2Operation;exports.SetColumnFrozenCommand=SetColumnFrozenCommand;exports.SetFormatPainterOperation=SetFormatPainterOperation;exports.SetInfiniteFormatPainterCommand=SetInfiniteFormatPainterCommand;exports.SetOnceFormatPainterCommand=SetOnceFormatPainterCommand;exports.SetProtectionCommand=SetProtectionCommand;exports.SetRangeBoldCommand=SetRangeBoldCommand;exports.SetRangeFontFamilyCommand=SetRangeFontFamilyCommand;exports.SetRangeFontSizeCommand=SetRangeFontSizeCommand;exports.SetRangeItalicCommand=SetRangeItalicCommand;exports.SetRangeProtectionCommand=SetRangeProtectionCommand;exports.SetRangeProtectionFromContextMenuCommand=SetRangeProtectionFromContextMenuCommand;exports.SetRangeStrickThroughCommand=SetRangeStrickThroughCommand;exports.SetRangeSubscriptCommand=SetRangeSubscriptCommand;exports.SetRangeSuperscriptCommand=SetRangeSuperscriptCommand;exports.SetRangeTextColorCommand=SetRangeTextColorCommand;exports.SetRangeUnderlineCommand=SetRangeUnderlineCommand;exports.SetRowFrozenCommand=SetRowFrozenCommand;exports.SetScrollOperation=SetScrollOperation;exports.SetScrollRelativeCommand=SetScrollRelativeCommand;exports.SetSelectionFrozenCommand=SetSelectionFrozenCommand;exports.SetWorksheetProtectionCommand=SetWorksheetProtectionCommand;exports.SetZoomRatioCommand=SetZoomRatioCommand;exports.SetZoomRatioOperation=SetZoomRatioOperation;exports.SheetBar=SheetBar;exports.SheetCopyCommand=SheetCopyCommand;exports.SheetCutCommand=SheetCutCommand;exports.SheetMenuPosition=SheetMenuPosition;exports.SheetPasteBesidesBorderCommand=SheetPasteBesidesBorderCommand;exports.SheetPasteColWidthCommand=SheetPasteColWidthCommand;exports.SheetPasteCommand=SheetPasteCommand;exports.SheetPasteFormatCommand=SheetPasteFormatCommand;exports.SheetPasteShortKeyCommand=SheetPasteShortKeyCommand;exports.SheetPasteValueCommand=SheetPasteValueCommand;exports.SheetPermissionOpenDialogOperation=SheetPermissionOpenDialogOperation;exports.SheetPermissionOpenPanelOperation=SheetPermissionOpenPanelOperation;exports.SheetPrintInterceptorService=SheetPrintInterceptorService;exports.SheetsUIPart=SheetsUIPart;exports.ShowMenuListCommand=ShowMenuListCommand;exports.SidebarDefinedNameOperation=SidebarDefinedNameOperation;exports.VIEWPORT_KEY=SHEET_VIEWPORT_KEY;exports.ViewSheetPermissionFromContextMenuCommand=ViewSheetPermissionFromContextMenuCommand;exports.ViewSheetPermissionFromSheetBarCommand=ViewSheetPermissionFromSheetBarCommand;exports.attachPrimaryWithCoord=attachPrimaryWithCoord;exports.attachRangeWithCoord=attachRangeWithCoord;exports.attachSelectionWithCoord=attachSelectionWithCoord;exports.calculateDocSkeletonRects=calculateDocSkeletonRects;exports.checkInHeaderRanges=matchedSelectionByRowColIndex;exports.deriveStateFromActiveSheet$=deriveStateFromActiveSheet$;exports.getAllSelection=getAllSelection;exports.getAutoFillRepeatRange=getAutoFillRepeatRange;exports.getCellRealRange=getCellRealRange;exports.getCoordByCell=getCoordByCell;exports.getCoordByOffset=getCoordByOffset;exports.getCurrentExclusiveRangeInterest$=getCurrentExclusiveRangeInterest$;exports.getCurrentRangeDisable$=getCurrentRangeDisable$;exports.getCustomRangePosition=getCustomRangePosition;exports.getEditingCustomRangePosition=getEditingCustomRangePosition;exports.getEditorObject=getEditorObject;exports.getObservableWithExclusiveRange$=getObservableWithExclusiveRange$;exports.getRepeatRange=getRepeatRange;exports.getSheetObject=getSheetObject;exports.getTopLeftSelection=getTopLeftSelection;exports.getTransformCoord=getTransformCoord;exports.isRangeSelector=isRangeSelector;exports.menuSchema=menuSchema$1;exports.mergeSetRangeValues=mergeSetRangeValues;exports.rangeToDiscreteRange=rangeToDiscreteRange;exports.useActiveWorkbook=useActiveWorkbook;exports.useActiveWorksheet=useActiveWorksheet;exports.useHighlightRange=useHighlightRange;exports.useWorkbooks=useWorkbooks;exports.virtualizeDiscreteRanges=virtualizeDiscreteRanges;exports.whenFormulaEditorActivated=whenFormulaEditorActivated;exports.whenSheetEditorFocused=whenSheetEditorFocused;