@univerjs/sheets 0.2.15 → 0.3.0-alpha.0
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 +3 -3
- package/lib/es/index.js +1549 -1300
- package/lib/types/basics/rangeMerge.d.ts +1 -1
- package/lib/types/commands/commands/__tests__/add-merge-command.spec.d.ts +16 -0
- package/lib/types/commands/commands/set-border-command.d.ts +8 -8
- package/lib/types/commands/commands/utils/selection-utils.d.ts +1 -1
- package/lib/types/commands/commands/utils/target-util.d.ts +1 -2
- package/lib/types/index.d.ts +65 -63
- package/lib/types/model/range-protection-rule.model.d.ts +9 -7
- package/lib/types/model/range-protection.cache.d.ts +30 -0
- package/lib/types/services/border-style-manager.service.d.ts +1 -1
- package/lib/types/services/permission/permission-point/index.d.ts +32 -32
- package/lib/types/services/permission/range-permission/range-protection.ref-range.d.ts +9 -6
- package/lib/types/services/permission/range-permission/range-protection.service.d.ts +3 -1
- package/lib/types/services/permission/worksheet-permission/index.d.ts +1 -1
- package/lib/types/services/permission/worksheet-permission/utils.d.ts +2 -2
- package/lib/types/services/ref-range/util.d.ts +5 -5
- package/lib/types/services/sheet-interceptor/interceptor-const.d.ts +4 -2
- package/lib/types/services/sheet-interceptor/sheet-interceptor.service.d.ts +2 -2
- package/lib/types/sheets-plugin.d.ts +2 -2
- package/lib/umd/index.js +2 -2
- package/package.json +13 -13
package/lib/cjs/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";var __defProp=Object.defineProperty;var __defNormalProp=(obj,key,value)=>key in obj?__defProp(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value;var __name=(target,value)=>__defProp(target,"name",{value,configurable:!0});var __publicField=(obj,key,value)=>__defNormalProp(obj,typeof key!="symbol"?key+"":key,value);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const core=require("@univerjs/core"),engineFormula=require("@univerjs/engine-formula"),rpc=require("@univerjs/rpc"),rxjs=require("rxjs"),engineNumfmt=require("@univerjs/engine-numfmt"),operators=require("rxjs/operators"),sheets=require("@univerjs/sheets");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$f=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$f"),SelectionMoveType=(SelectionMoveType2=>(SelectionMoveType2[SelectionMoveType2.MOVE_START=0]="MOVE_START",SelectionMoveType2[SelectionMoveType2.MOVING=1]="MOVING",SelectionMoveType2[SelectionMoveType2.MOVE_END=2]="MOVE_END",SelectionMoveType2))(SelectionMoveType||{}),_a;exports.SheetsSelectionsService=(_a=class extends core.RxDisposable{constructor(_instanceSrv){super();__publicField(this,"selectionMoveStart$");__publicField(this,"selectionMoving$");__publicField(this,"selectionMoveEnd$");__publicField(this,"_workbookSelections",new Map);this._instanceSrv=_instanceSrv,this._init()}get _currentSelectionPos(){const workbook=this._instanceSrv.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const worksheet=workbook.getActiveSheet();return{unitId:workbook.getUnitId(),sheetId:worksheet.getSheetId()}}get currentSelectionParam(){return this._currentSelectionPos}_init(){const c$=this._instanceSrv.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.shareReplay(1),rxjs.takeUntil(this.dispose$));this.selectionMoveStart$=c$.pipe(rxjs.switchMap(workbook=>workbook?this._ensureWorkbookSelection(workbook.getUnitId()).selectionMoveStart$:rxjs.of())),this.selectionMoving$=c$.pipe(rxjs.switchMap(workbook=>workbook?this._ensureWorkbookSelection(workbook.getUnitId()).selectionMoving$:rxjs.of())),this.selectionMoveEnd$=c$.pipe(rxjs.switchMap(workbook=>workbook?this._ensureWorkbookSelection(workbook.getUnitId()).selectionMoveEnd$:rxjs.of([]))),this._instanceSrv.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.takeUntil(this.dispose$)).subscribe(workbook=>{this._removeWorkbookSelection(workbook.getUnitId())})}clear(){this._workbookSelections.forEach(wbSelection=>wbSelection.clear())}getCurrentSelections(){return this._getCurrentSelections()}getCurrentLastSelection(){const selectionData=this._getCurrentSelections();return selectionData==null?void 0:selectionData[selectionData.length-1]}addSelections(unitIdOrSelections,worksheetId,selectionDatas){if(typeof unitIdOrSelections=="string"){this._ensureWorkbookSelection(unitIdOrSelections).addSelections(worksheetId,selectionDatas);return}const current=this._currentSelectionPos;if(!current)throw new Error("[SheetsSelectionsService]: cannot find current selection position!");const{unitId,sheetId}=current;this._ensureWorkbookSelection(unitId).addSelections(sheetId,unitIdOrSelections)}setSelections(unitIdOrSelections,worksheetIdOrType,selectionDatas,type){if(typeof unitIdOrSelections=="string"){this._ensureWorkbookSelection(unitIdOrSelections).setSelections(worksheetIdOrType,selectionDatas,type!=null?type:2);return}const current=this._currentSelectionPos;if(!current)throw new Error("[SheetsSelectionsService]: cannot find current selection position!");const{unitId,sheetId}=current;this._ensureWorkbookSelection(unitId).setSelections(sheetId,unitIdOrSelections!=null?unitIdOrSelections:selectionDatas,worksheetIdOrType!=null?worksheetIdOrType:2)}clearCurrentSelections(){this._getCurrentSelections().splice(0)}isOverlapping(){const selectionDataList=this.getCurrentSelections();return selectionDataList==null?!1:selectionDataList.some(({range},index)=>selectionDataList.some(({range:range2},index2)=>index===index2?!1:range.startRow<=range2.endRow&&range.endRow>=range2.startRow&&range.startColumn<=range2.endColumn&&range.endColumn>=range2.startColumn))}_getCurrentSelections(){const current=this._currentSelectionPos;if(!current)return[];const{unitId,sheetId}=current;return this._ensureWorkbookSelection(unitId).getSelectionOfWorksheet(sheetId)}getWorkbookSelections(unitId){return this._ensureWorkbookSelection(unitId)}_ensureWorkbookSelection(unitId){let wbSelection=this._workbookSelections.get(unitId);if(!wbSelection){const workbook=this._instanceSrv.getUnit(unitId);if(!workbook)throw new Error(`[SheetsSelectionsService]: cannot resolve unit with id "${unitId}"!`);wbSelection=new WorkbookSelections(workbook),this._workbookSelections.set(unitId,wbSelection)}return wbSelection}_removeWorkbookSelection(unitId){this._workbookSelections.delete(unitId)}},__name(_a,"SheetsSelectionsService"),_a);exports.SheetsSelectionsService=__decorateClass$i([__decorateParam$f(0,core.IUniverInstanceService)],exports.SheetsSelectionsService);const _WorkbookSelections=class _WorkbookSelections extends core.Disposable{constructor(_workbook){super();__publicField(this,"_selectionMoveStart$",new rxjs.Subject);__publicField(this,"selectionMoveStart$",this._selectionMoveStart$.asObservable());__publicField(this,"_selectionMoving$",new rxjs.Subject);__publicField(this,"selectionMoving$",this._selectionMoving$.asObservable());__publicField(this,"_selectionMoveEnd$",new rxjs.BehaviorSubject([]));__publicField(this,"selectionMoveEnd$",this._selectionMoveEnd$.asObservable());__publicField(this,"_beforeSelectionMoveEnd$",new rxjs.BehaviorSubject([]));__publicField(this,"beforeSelectionMoveEnd$",this._beforeSelectionMoveEnd$.asObservable());__publicField(this,"_worksheetSelections",new Map);this._workbook=_workbook}dispose(){super.dispose(),this._beforeSelectionMoveEnd$.complete(),this._selectionMoveEnd$.complete(),this._selectionMoving$.complete(),this._selectionMoveStart$.complete()}clear(){this._worksheetSelections.clear(),this._emitOnEnd([])}addSelections(sheetId,selectionDatas){const selections=this._ensureSheetSelection(sheetId);selections.push(...selectionDatas),this._emitOnEnd(selections)}setSelections(sheetId,selectionDatas=[],type){switch(this._ensureSheetSelection(sheetId).length=0,this._ensureSheetSelection(sheetId).push(...selectionDatas),type){case 0:this._selectionMoveStart$.next(selectionDatas);break;case 1:this._selectionMoving$.next(selectionDatas);break;case 2:this._emitOnEnd(selectionDatas);break;default:this._emitOnEnd(selectionDatas);break}}getCurrentSelections(){return this._getCurrentSelections()}getSelectionOfWorksheet(sheetId){return this._worksheetSelections.has(sheetId)?this._worksheetSelections.get(sheetId):[]}_getCurrentSelections(){return this.getSelectionOfWorksheet(this._workbook.getActiveSheet().getSheetId())}getCurrentLastSelection(){const selectionData=this._getCurrentSelections();return selectionData[selectionData.length-1]}_ensureSheetSelection(sheetId){let worksheetSelection=this._worksheetSelections.get(sheetId);return worksheetSelection||(worksheetSelection=[],this._worksheetSelections.set(sheetId,worksheetSelection)),worksheetSelection}_emitOnEnd(selections){this._beforeSelectionMoveEnd$.next(selections),this._selectionMoveEnd$.next(selections)}};__name(_WorkbookSelections,"WorkbookSelections");let WorkbookSelections=_WorkbookSelections;const DISABLE_NORMAL_SELECTIONS="DISABLE_NORMAL_SELECTIONS",CELL_CONTENT=core.createInterceptorKey("CELL_CONTENT"),ROW_FILTERED=core.createInterceptorKey("ROW_FILTERED"),INTERCEPTOR_POINT={CELL_CONTENT,ROW_FILTERED};var InterceptCellContentPriority=(InterceptCellContentPriority2=>(InterceptCellContentPriority2[InterceptCellContentPriority2.DATA_VALIDATION=9]="DATA_VALIDATION",InterceptCellContentPriority2[InterceptCellContentPriority2.NUMFMT=10]="NUMFMT",InterceptCellContentPriority2))(InterceptCellContentPriority||{}),__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$e=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$e"),_a2;exports.SheetInterceptorService=(_a2=class extends core.Disposable{constructor(_univerInstanceService){super();__publicField(this,"_interceptorsByName",new Map);__publicField(this,"_commandInterceptors",[]);__publicField(this,"_rangeInterceptors",[]);__publicField(this,"_beforeCommandInterceptor",[]);__publicField(this,"_workbookDisposables",new Map);__publicField(this,"_worksheetDisposables",new Map);this._univerInstanceService=_univerInstanceService,this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{this._interceptWorkbook(workbook)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>this._disposeWorkbookInterceptor(workbook))),this.intercept(INTERCEPTOR_POINT.CELL_CONTENT,{priority:-1,handler(value,context){const rawData=context.worksheet.getCellRaw(context.row,context.col);return value?{...rawData,...value}:rawData}})}dispose(){super.dispose(),this._workbookDisposables.forEach(disposable=>disposable.dispose()),this._workbookDisposables.clear(),this._worksheetDisposables.clear()}interceptCommand(interceptor){if(this._commandInterceptors.includes(interceptor))throw new Error("[SheetInterceptorService]: Interceptor already exists!");return this._commandInterceptors.push(interceptor),this._commandInterceptors.sort((a,b)=>{var _a20,_b;return((_a20=b.priority)!=null?_a20:0)-((_b=a.priority)!=null?_b:0)}),this.disposeWithMe(core.toDisposable(()=>core.remove(this._commandInterceptors,interceptor)))}interceptBeforeCommand(interceptor){if(this._beforeCommandInterceptor.includes(interceptor))throw new Error("[SheetInterceptorService]: Interceptor already exists!");return this._beforeCommandInterceptor.push(interceptor),this._beforeCommandInterceptor.sort((a,b)=>{var _a20,_b;return((_a20=b.priority)!=null?_a20:0)-((_b=a.priority)!=null?_b:0)}),this.disposeWithMe(core.toDisposable(()=>core.remove(this._beforeCommandInterceptor,interceptor)))}async beforeCommandExecute(info){return(await Promise.all(this._beforeCommandInterceptor.map(i=>i.performCheck(info)))).every(perform=>perform)}interceptRanges(interceptor){if(this._rangeInterceptors.includes(interceptor))throw new Error("[SheetInterceptorService]: Interceptor already exists!");return this._rangeInterceptors.push(interceptor),this._rangeInterceptors.sort((a,b)=>{var _a20,_b;return((_a20=b.priority)!=null?_a20:0)-((_b=a.priority)!=null?_b:0)}),this.disposeWithMe(core.toDisposable(()=>core.remove(this._rangeInterceptors,interceptor)))}onCommandExecute(info){const infos=this._commandInterceptors.map(i=>i.getMutations(info));return{preUndos:infos.map(i=>{var _a20;return(_a20=i.preUndos)!=null?_a20:[]}).flat(),undos:infos.map(i=>i.undos).flat(),preRedos:infos.map(i=>{var _a20;return(_a20=i.preRedos)!=null?_a20:[]}).flat(),redos:infos.map(i=>i.redos).flat()}}generateMutationsByRanges(info){const infos=this._rangeInterceptors.map(i=>i.getMutations(info));return{preUndos:infos.map(i=>{var _a20;return(_a20=i.preUndos)!=null?_a20:[]}).flat(),undos:infos.map(i=>i.undos).flat(),preRedos:infos.map(i=>{var _a20;return(_a20=i.preRedos)!=null?_a20:[]}).flat(),redos:infos.map(i=>i.redos).flat()}}intercept(name,interceptor){const key=name;this._interceptorsByName.has(key)||this._interceptorsByName.set(key,[]);const interceptors=this._interceptorsByName.get(key);return interceptors.push(interceptor),this._interceptorsByName.set(key,interceptors.sort((a,b)=>{var _a20,_b;return((_a20=b.priority)!=null?_a20:0)-((_b=a.priority)!=null?_b:0)})),this.disposeWithMe(core.toDisposable(()=>core.remove(this._interceptorsByName.get(key),interceptor)))}fetchThroughInterceptors(name){const key=name,interceptors=this._interceptorsByName.get(key);return core.composeInterceptors(interceptors||[])}_interceptWorkbook(workbook){const disposables=new core.DisposableCollection,unitId=workbook.getUnitId(),sheetInterceptorService=this,interceptViewModel=__name(worksheet=>{const subUnitId=worksheet.getSheetId();worksheet.__interceptViewModel(viewModel=>{const sheetDisposables=new core.DisposableCollection;sheetInterceptorService._worksheetDisposables.set(getWorksheetDisposableID(unitId,worksheet),sheetDisposables),sheetDisposables.add(viewModel.registerCellContentInterceptor({getCell(row,col){return sheetInterceptorService.fetchThroughInterceptors(INTERCEPTOR_POINT.CELL_CONTENT)(worksheet.getCellRaw(row,col),{unitId,subUnitId,row,col,worksheet,workbook})}})),sheetDisposables.add(viewModel.registerRowFilteredInterceptor({getRowFiltered(row){return!!sheetInterceptorService.fetchThroughInterceptors(INTERCEPTOR_POINT.ROW_FILTERED)(!1,{unitId,subUnitId,row,workbook,worksheet})}}))})},"interceptViewModel");workbook.getSheets().forEach(worksheet=>interceptViewModel(worksheet)),disposables.add(workbook.sheetCreated$.subscribe(worksheet=>interceptViewModel(worksheet))),disposables.add(core.toDisposable(()=>workbook.getSheets().forEach(worksheet=>this._disposeSheetInterceptor(unitId,worksheet)))),disposables.add(workbook.sheetDisposed$.subscribe(worksheet=>this._disposeSheetInterceptor(unitId,worksheet))),this._workbookDisposables.set(unitId,disposables)}_disposeWorkbookInterceptor(workbook){const unitId=workbook.getUnitId(),disposable=this._workbookDisposables.get(unitId);disposable&&(disposable.dispose(),this._workbookDisposables.delete(unitId))}_disposeSheetInterceptor(unitId,worksheet){const disposableId=getWorksheetDisposableID(unitId,worksheet),disposable=this._worksheetDisposables.get(disposableId);disposable&&(disposable.dispose(),this._worksheetDisposables.delete(disposableId))}},__name(_a2,"SheetInterceptorService"),_a2);exports.SheetInterceptorService=__decorateClass$h([__decorateParam$e(0,core.IUniverInstanceService)],exports.SheetInterceptorService);function getWorksheetDisposableID(unitId,worksheet){return`${unitId}|${worksheet.getSheetId()}`}__name(getWorksheetDisposableID,"getWorksheetDisposableID");function handleStyle(styles,oldVal,newVal){var _a20;const oldStyle=styles.getStyleByCell(oldVal);oldStyle==null&&delete oldVal.s,typeof newVal.s=="string"&&(newVal.s=styles.get(newVal.s));const merge=mergeStyle(oldStyle,newVal.s?newVal.s:null);merge&&core.Tools.removeNull(merge),core.Tools.isEmptyObject(merge)?delete oldVal.s:oldVal.s=styles.setValue(merge);const newValueStream=newVal.v?`${newVal.v}\r
|
|
2
|
-
`:"";!newVal.p&&oldVal.p&&(newValueStream&&newValueStream!==((
|
|
3
|
-
`)?p.body.dataStream.length-2:p.body.dataStream.length;if(index<endIndex){const tr={st:index,ed:endIndex},merge=mergeStyle({},newStyle,!0);merge&&core.Tools.removeNull(merge),core.Tools.isEmptyObject(merge)||(tr.ts=merge),newTextRuns.push(tr)}p.body.textRuns=core.normalizeTextRuns(newTextRuns)}__name(mergeRichTextStyle,"mergeRichTextStyle");function getCellType(styles,newVal,oldVal){if(newVal.t)return newVal.t;if(newVal.v===null)return null;const newStyle=styles.getStyleByCell(newVal),oldStyle=styles.getStyleByCell(oldVal);if(oldVal.t===core.CellValueType.FORCE_STRING){if(!isTextFormat(oldStyle)&&newVal.v!==void 0){if(core.isRealNum(newVal.v))return core.CellValueType.NUMBER;if(core.isBooleanString(`${newVal.v}`))return core.CellValueType.BOOLEAN}return core.CellValueType.FORCE_STRING}return hasNumberFormat(newStyle)?isTextFormat(newStyle)?core.CellValueType.STRING:checkCellValueTypeByValue(newVal,oldVal):isTextFormat(oldStyle)?core.CellValueType.STRING:checkCellValueTypeByValue(newVal,oldVal)}__name(getCellType,"getCellType");function checkCellValueTypeByValue(newVal,oldVal){return newVal.v!==void 0?checkCellValueType(newVal.v,newVal.t):checkCellValueType(oldVal.v,oldVal.t)}__name(checkCellValueTypeByValue,"checkCellValueTypeByValue");function hasNumberFormat(style){var _a20;return!!((_a20=style==null?void 0:style.n)!=null&&_a20.pattern)}__name(hasNumberFormat,"hasNumberFormat");function isTextFormat(style){var _a20;return((_a20=style==null?void 0:style.n)==null?void 0:_a20.pattern)===engineNumfmt.DEFAULT_TEXT_FORMAT}__name(isTextFormat,"isTextFormat");function checkCellValueType(v,type){return v===null?null:typeof v=="string"?core.isRealNum(v)?(+v==0||+v==1)&&type===core.CellValueType.BOOLEAN?core.CellValueType.BOOLEAN:core.CellValueType.NUMBER:core.isBooleanString(v)?core.CellValueType.BOOLEAN:core.CellValueType.STRING:typeof v=="number"?(v===0||v===1)&&type===core.CellValueType.BOOLEAN?core.CellValueType.BOOLEAN:core.CellValueType.NUMBER:typeof v=="boolean"?core.CellValueType.BOOLEAN:core.CellValueType.FORCE_STRING}__name(checkCellValueType,"checkCellValueType");function getCellTypeByPattern(cell,pattern){return cell.t===core.CellValueType.FORCE_STRING?core.CellValueType.FORCE_STRING:pattern===engineNumfmt.DEFAULT_TEXT_FORMAT?core.CellValueType.STRING:checkCellValueType(cell.v,cell.t)}__name(getCellTypeByPattern,"getCellTypeByPattern");function getCellValue(type,cell){return type===core.CellValueType.NUMBER?Number(cell.v):type===core.CellValueType.BOOLEAN?extractBooleanValue(cell.v)?1:0:type===core.CellValueType.STRING||type===core.CellValueType.FORCE_STRING?`${cell.v}`:cell.v}__name(getCellValue,"getCellValue");function extractBooleanValue(value){if(typeof value=="string"){if(value.toUpperCase()==="TRUE")return!0;if(value.toUpperCase()==="FALSE")return!1;if(core.isSafeNumeric(value)){if(Number(value)===0)return!1;if(Number(value)===1)return!0}}if(typeof value=="number"){if(value===0)return!1;if(value===1)return!0}return typeof value=="boolean"?value:null}__name(extractBooleanValue,"extractBooleanValue");function setNull(value){return value==null?null:(value.f===void 0&&(value.f=null),value.si===void 0&&(value.si=null),value.p===void 0&&(value.p=null),value.v===void 0&&(value.v=null),value.t===void 0&&(value.t=null),value.s===void 0&&(value.s=null),value.custom===void 0&&(value.custom=null),value)}__name(setNull,"setNull");const SetRangeValuesUndoMutationFactory=__name((accessor,params)=>{const{unitId,subUnitId,cellValue}=params,workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(workbook==null)throw new Error("workbook is null error!");const worksheet=workbook.getSheetBySheetId(subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const cellMatrix=worksheet.getCellMatrix(),styles=workbook.getStyles(),undoData=new core.ObjectMatrix;return new core.ObjectMatrix(cellValue).forValue((row,col,newVal)=>{const cell=core.Tools.deepClone(cellMatrix==null?void 0:cellMatrix.getValue(row,col))||{},oldStyle=styles.getStyleByCell(cell),newStyle=styles.getStyleByCell(newVal);cell.s=transformStyle(oldStyle,newStyle),undoData.setValue(row,col,setNull(cell))}),{...params,options:{},cellValue:undoData.getMatrix()}},"SetRangeValuesUndoMutationFactory"),SetRangeValuesMutation={id:"sheet.mutation.set-range-values",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{cellValue,subUnitId,unitId}=params,workbook=accessor.get(core.IUniverInstanceService).getUnit(unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet)return!1;const cellMatrix=worksheet.getCellMatrix(),styles=workbook.getStyles();return new core.ObjectMatrix(cellValue).forValue((row,col,newVal)=>{if(!newVal)cellMatrix==null||cellMatrix.setValue(row,col,{});else{const oldVal=cellMatrix.getValue(row,col)||{},type=getCellType(styles,newVal,oldVal);newVal.f!==void 0&&(oldVal.f=newVal.f),newVal.si!==void 0&&(oldVal.si=newVal.si),newVal.p!==void 0&&(oldVal.p=newVal.p),newVal.v!==void 0&&(oldVal.v=getCellValue(type,newVal)),oldVal.v!==void 0&&(oldVal.t=type,oldVal.v=getCellValue(type,oldVal)),newVal.s!==void 0&&handleStyle(styles,oldVal,newVal),newVal.custom!==void 0&&(oldVal.custom=newVal.custom),cellMatrix.setValue(row,col,core.Tools.removeNull(oldVal))}}),!0},"handler")},groupByKey=__name((arr,key,blankKey="")=>arr.reduce((result,current)=>{const value=current&¤t[key];return typeof value!="string"?(console.warn(current,`${key} is not string`),result):(value?(result[value]||(result[value]=[]),result[value].push(current)):result[blankKey].push(current),result)},{}),"groupByKey"),createUniqueKey=__name((initValue=0)=>{let _initValue=initValue;return __name(function(){return _initValue++},"getKey")},"createUniqueKey");function generateNullCell(range){const cellValue=new core.ObjectMatrix;return range.forEach(range2=>{const{startRow,startColumn,endRow,endColumn}=range2;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellValue.setValue(i,j,null)}),cellValue.clone()}__name(generateNullCell,"generateNullCell");function generateNullCellValue(range){const cellValue=new core.ObjectMatrix;return range.forEach(range2=>{const{startRow,startColumn,endRow,endColumn}=range2;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellValue.setValue(i,j,{v:null,p:null,f:null,si:null,custom:null})}),cellValue.clone()}__name(generateNullCellValue,"generateNullCellValue");function generateNullCellStyle(ranges){const cellValue=new core.ObjectMatrix;return ranges.forEach(range=>{const{startRow,startColumn,endRow,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellValue.setValue(i,j,{s:null})}),cellValue.clone()}__name(generateNullCellStyle,"generateNullCellStyle");const ClearSelectionAllCommand={id:"sheet.command.clear-selection-all",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a20;const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),selections=(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const sequenceExecuteList=[],sequenceExecuteUndoList=[],clearMutationParams={subUnitId,unitId,cellValue:generateNullCell(selections)},undoClearMutationParams=SetRangeValuesUndoMutationFactory(accessor,clearMutationParams);sequenceExecuteList.push({id:SetRangeValuesMutation.id,params:clearMutationParams}),sequenceExecuteUndoList.push({id:SetRangeValuesMutation.id,params:undoClearMutationParams});const intercepted=sheetInterceptorService.onCommandExecute({id:ClearSelectionAllCommand.id});return sequenceExecuteList.push(...intercepted.redos),sequenceExecuteUndoList.unshift(...intercepted.undos),core.sequenceExecute(sequenceExecuteList,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:sequenceExecuteUndoList,redoMutations:sequenceExecuteList}),!0):!1},"handler")},ClearSelectionContentCommand={id:"sheet.command.clear-selection-content",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a20;const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),selections=(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const clearMutationParams={subUnitId,unitId,cellValue:generateNullCellValue(selections)},undoClearMutationParams=SetRangeValuesUndoMutationFactory(accessor,clearMutationParams),intercepted=sheetInterceptorService.onCommandExecute({id:ClearSelectionContentCommand.id}),redos=[{id:SetRangeValuesMutation.id,params:clearMutationParams},...intercepted.redos],undos=[...intercepted.undos,{id:SetRangeValuesMutation.id,params:undoClearMutationParams}];return core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},ClearSelectionFormatCommand={id:"sheet.command.clear-selection-format",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a20;const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),selections=(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const sequenceExecuteList=[],sequenceExecuteUndoList=[],clearMutationParams={subUnitId,unitId,cellValue:generateNullCellStyle(selections)},undoClearMutationParams=SetRangeValuesUndoMutationFactory(accessor,clearMutationParams);sequenceExecuteList.push({id:SetRangeValuesMutation.id,params:clearMutationParams}),sequenceExecuteUndoList.push({id:SetRangeValuesMutation.id,params:undoClearMutationParams});const intercepted=sheetInterceptorService.onCommandExecute({id:ClearSelectionFormatCommand.id});return sequenceExecuteList.push(...intercepted.redos),sequenceExecuteUndoList.unshift(...intercepted.undos),core.sequenceExecute(sequenceExecuteList,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:sequenceExecuteUndoList,redoMutations:sequenceExecuteList}),!0):!1},"handler")},InsertSheetUndoMutationFactory=__name((_accessor,params)=>({subUnitId:params.sheet.id,unitId:params.unitId,subUnitName:params.sheet.name}),"InsertSheetUndoMutationFactory"),InsertSheetMutation={id:"sheet.mutation.insert-sheet",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),{sheet,index,unitId}=params,workbook=univerInstanceService.getUniverSheetInstance(unitId);return workbook?workbook.addWorksheet(sheet.id,index,sheet):!1},"handler")};function getSheetCommandTargetWorkbook(univerInstanceService,params){const{unitId}=params,workbook=unitId?univerInstanceService.getUniverSheetInstance(unitId):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);return workbook?{workbook,unitId:workbook.getUnitId()}:null}__name(getSheetCommandTargetWorkbook,"getSheetCommandTargetWorkbook");function getSheetCommandTarget(univerInstanceService,params={}){const{unitId,subUnitId}=params,workbook=unitId?univerInstanceService.getUniverSheetInstance(unitId):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const worksheet=subUnitId?workbook.getSheetBySheetId(subUnitId):workbook.getActiveSheet(!0);return worksheet?{worksheet,workbook,unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId()}:null}__name(getSheetCommandTarget,"getSheetCommandTarget");function getSheetMutationTarget(univerInstanceService,params){const{unitId,subUnitId}=params,workbook=univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return null;const worksheet=workbook.getSheetBySheetId(subUnitId);return worksheet?{worksheet,workbook}:null}__name(getSheetMutationTarget,"getSheetMutationTarget");const RemoveSheetUndoMutationFactory=__name((accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),{subUnitId,unitId}=params,target=getSheetMutationTarget(univerInstanceService,params);if(!target)throw new Error("[RemoveSheetUndoMutationFactory]: Worksheet is null error!");const{workbook,worksheet}=target,sheet=worksheet.getConfig();return{index:workbook.getConfig().sheetOrder.findIndex(id=>id===subUnitId),sheet,unitId}},"RemoveSheetUndoMutationFactory"),RemoveSheetMutation={id:"sheet.mutation.remove-sheet",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),{subUnitId,unitId}=params,workbook=univerInstanceService.getUniverSheetInstance(unitId);return workbook?workbook.removeSheet(subUnitId):!1},"handler")},CopySheetCommand={type:core.CommandType.COMMAND,id:"sheet.command.copy-sheet",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),localeService=accessor.get(core.LocaleService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{workbook,worksheet,unitId}=target,config=core.Tools.deepClone(worksheet.getConfig());config.name=getCopyUniqueSheetName(workbook,localeService,config.name),config.id=core.Tools.generateRandomId();const insertSheetMutationParams={index:workbook.getSheetIndex(worksheet)+1,sheet:config,unitId},removeSheetMutationParams=InsertSheetUndoMutationFactory(accessor,insertSheetMutationParams);return commandService.syncExecuteCommand(InsertSheetMutation.id,insertSheetMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:RemoveSheetMutation.id,params:removeSheetMutationParams}],redoMutations:[{id:InsertSheetMutation.id,params:insertSheetMutationParams}]}),!0):!1},"handler")};function getCopyUniqueSheetName(workbook,localeService,name){let output=name+localeService.t("sheets.tabs.sheetCopy",""),count=2;for(;workbook.checkSheetName(output);)output=name+localeService.t("sheets.tabs.sheetCopy",`${count}`),count++;return output}__name(getCopyUniqueSheetName,"getCopyUniqueSheetName");const MoveRangeMutation={id:"sheet.mutation.move-range",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{from,to}=params;if(!from||!to)return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const fromWorksheet=workbook.getSheetBySheetId(params.from.subUnitId),toWorksheet=workbook.getSheetBySheetId(params.to.subUnitId);if(!fromWorksheet||!toWorksheet)return!1;const fromCellMatrix=fromWorksheet.getCellMatrix(),toCellMatrix=toWorksheet.getCellMatrix();return new core.ObjectMatrix(from.value).forValue((row,col,newVal)=>{fromCellMatrix.setValue(row,col,newVal)}),new core.ObjectMatrix(to.value).forValue((row,col,newVal)=>{toCellMatrix.setValue(row,col,newVal)}),!0},"handler")};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$d=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$d");const IRefSelectionsService=core.createIdentifier("sheets-formula.ref-selections.service");var _a3;exports.RefSelectionsService=(_a3=class extends exports.SheetsSelectionsService{constructor(_instanceSrv){super(_instanceSrv)}_init(){const $=this._getAliveWorkbooks$().pipe(rxjs.takeUntil(this.dispose$));this.selectionMoveStart$=$.pipe(rxjs.switchMap(ss=>rxjs.merge(...ss.map(s=>s.selectionMoveStart$)))),this.selectionMoving$=$.pipe(rxjs.switchMap(ss=>rxjs.merge(...ss.map(s=>s.selectionMoving$)))),this.selectionMoveEnd$=$.pipe(rxjs.switchMap(ss=>rxjs.merge(...ss.map(s=>s.selectionMoveEnd$))))}_getAliveWorkbooks$(){const aliveWorkbooks=this._instanceSrv.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET);aliveWorkbooks.forEach(workbook=>this._ensureWorkbookSelection(workbook.getUnitId()));const workbooks$=new rxjs.BehaviorSubject(aliveWorkbooks);return this.disposeWithMe(this._instanceSrv.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{this._ensureWorkbookSelection(workbook.getUnitId()),workbooks$.next([...workbooks$.getValue(),workbook])})),this.disposeWithMe(this._instanceSrv.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{this._removeWorkbookSelection(workbook.getUnitId()),workbooks$.next(workbooks$.getValue().filter(unit=>unit!==workbook))})),workbooks$.pipe(rxjs.map(workbooks=>workbooks.map(w=>this._ensureWorkbookSelection(w.getUnitId()))))}},__name(_a3,"RefSelectionsService"),_a3);exports.RefSelectionsService=__decorateClass$g([__decorateParam$d(0,core.IUniverInstanceService)],exports.RefSelectionsService);function getSelectionsService(accessor){const disabledNormalSelections=accessor.get(core.IContextService).getContextValue(DISABLE_NORMAL_SELECTIONS);return accessor.get(disabledNormalSelections?IRefSelectionsService:exports.SheetsSelectionsService)}__name(getSelectionsService,"getSelectionsService");const SetSelectionsOperation={id:"sheet.operation.set-selections",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{if(!params)return!1;const{selections,type,unitId,subUnitId}=params;return getSelectionsService(accessor).setSelections(unitId,subUnitId,[...selections],type),!0},"handler")};function alignToMergedCellsBorders(startRange,worksheet,shouldRecursive=!0){const coveredMergedCells=worksheet.getMatrixWithMergedCells(...core.selectionToArray(startRange)),exceededMergedCells=[];if(coveredMergedCells.forValue((row,col,value)=>{if(value.colSpan!==void 0&&value.rowSpan!==void 0){const mergedCellRange={startRow:row,startColumn:col,endRow:row+value.rowSpan-1,endColumn:col+value.colSpan-1};core.Rectangle.contains(startRange,mergedCellRange)||exceededMergedCells.push(mergedCellRange)}}),exceededMergedCells.length===0)return startRange;const union=core.Rectangle.union(startRange,...exceededMergedCells);return shouldRecursive?alignToMergedCellsBorders(union,worksheet,shouldRecursive):union}__name(alignToMergedCellsBorders,"alignToMergedCellsBorders");function getCellAtRowCol(row,col,worksheet){let destRange=null;return worksheet.getMatrixWithMergedCells(row,col,row,col).forValue((row2,col2,value)=>(destRange={actualRow:row2,actualColumn:col2,startRow:row2,startColumn:col2,isMerged:value.rowSpan!==void 0||value.colSpan!==void 0,isMergedMainCell:value.rowSpan!==void 0&&value.colSpan!==void 0,endRow:row2+(value.rowSpan!==void 0?value.rowSpan-1:0),endColumn:col2+(value.colSpan!==void 0?value.colSpan-1:0),rangeType:core.RANGE_TYPE.NORMAL},!1)),destRange||{actualColumn:col,actualRow:row,startRow:row,startColumn:col,endRow:row,endColumn:col,isMerged:!1,isMergedMainCell:!1,rangeType:core.RANGE_TYPE.NORMAL}}__name(getCellAtRowCol,"getCellAtRowCol");function setEndForRange(range,rowCount,columnCount){const{startRow,startColumn,endRow,endColumn}=range;return Number.isNaN(startRow)&&(range.startRow=0),Number.isNaN(endRow)&&(range.endRow=rowCount-1),Number.isNaN(startColumn)&&(range.startColumn=0),Number.isNaN(endColumn)&&(range.endColumn=columnCount-1),range}__name(setEndForRange,"setEndForRange");function getPrimaryForRange(range,worksheet){const startRow=Number.isNaN(range.startRow)?0:range.startRow,startColumn=Number.isNaN(range.startColumn)?0:range.startColumn,mergedRange=worksheet.getMergedCell(startRow,startColumn);return mergedRange?{...mergedRange,actualRow:startRow,actualColumn:startColumn,rangeType:core.RANGE_TYPE.NORMAL,isMerged:!0,isMergedMainCell:!0}:{startRow,startColumn,endRow:range.startRow,endColumn:range.startColumn,actualRow:startRow,actualColumn:startColumn,rangeType:core.RANGE_TYPE.NORMAL,isMerged:!1,isMergedMainCell:!1}}__name(getPrimaryForRange,"getPrimaryForRange");const followSelectionOperation=__name((range,workbook,worksheet)=>({id:SetSelectionsOperation.id,params:{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),selections:[{range,primary:getPrimaryForRange(range,worksheet)}]}}),"followSelectionOperation");function isSingleCellSelection(selection){if(!selection)return!1;const{range,primary}=selection;return core.Rectangle.equals(range,primary)}__name(isSingleCellSelection,"isSingleCellSelection");function createRangeIteratorWithSkipFilteredRows(sheet){function forOperableEach(ranges,operator){function iterate(range){for(let r=range.startRow;r<=range.endRow;r++)if(!sheet.getRowFiltered(r))for(let c=range.startColumn;c<=range.endColumn;c++)operator(r,c,range)}__name(iterate,"iterate"),iterate(ranges)}return __name(forOperableEach,"forOperableEach"),{forOperableEach}}__name(createRangeIteratorWithSkipFilteredRows,"createRangeIteratorWithSkipFilteredRows");function copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,isRow,styleRowOrColumn){const cellValue={};for(let row=startRow;row<=endRow;row++)for(let column=startColumn;column<=endColumn;column++){const cell=isRow?worksheet.getCell(styleRowOrColumn,column):worksheet.getCell(row,styleRowOrColumn);!cell||!cell.s||(cellValue[row]||(cellValue[row]={}),cellValue[row][column]={s:cell.s})}return cellValue}__name(copyRangeStyles,"copyRangeStyles");const MoveRangeCommandId="sheet.command.move-range",MoveRangeCommand={type:core.CommandType.COMMAND,id:MoveRangeCommandId,handler:__name(async(accessor,params)=>{var _a20,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService);if(!target||!await sheetInterceptorService.beforeCommandExecute({id:MoveRangeCommand.id,params}))return!1;const{worksheet,subUnitId,unitId}=target,moveRangeMutations=getMoveRangeUndoRedoMutations(accessor,{unitId,subUnitId,range:params.fromRange},{unitId,subUnitId,range:params.toRange});if(moveRangeMutations===null)return errorService.emit(localeService.t("sheets.info.acrossMergedCell")),!1;const interceptorCommands=sheetInterceptorService.onCommandExecute({id:MoveRangeCommand.id,params:{...params}}),redos=[...(_a20=interceptorCommands.preRedos)!=null?_a20:[],...moveRangeMutations.redos,...interceptorCommands.redos,{id:SetSelectionsOperation.id,params:{unitId,subUnitId,selections:[{range:params.toRange,primary:getPrimaryForRange(params.toRange,worksheet)}]}}],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],...moveRangeMutations.undos,...interceptorCommands.undos,{id:SetSelectionsOperation.id,params:{unitId,subUnitId,selections:[{range:params.fromRange,primary:getPrimaryForRange(params.fromRange,worksheet)}]}}];return core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")};function getMoveRangeUndoRedoMutations(accessor,from,to,ignoreMerge=!1){const redos=[],undos=[],{range:fromRange,subUnitId:fromSubUnitId,unitId}=from,{range:toRange,subUnitId:toSubUnitId}=to,workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId),toWorksheet=workbook==null?void 0:workbook.getSheetBySheetId(toSubUnitId),fromWorksheet=workbook==null?void 0:workbook.getSheetBySheetId(fromSubUnitId),toCellMatrix=toWorksheet==null?void 0:toWorksheet.getCellMatrix(),fromCellMatrix=fromWorksheet==null?void 0:fromWorksheet.getCellMatrix();if(toWorksheet&&fromWorksheet&&toCellMatrix&&fromCellMatrix){const alignedRangeWithToRange=alignToMergedCellsBorders(toRange,toWorksheet,!1);if(!core.Rectangle.equals(toRange,alignedRangeWithToRange)&&!ignoreMerge)return null;const fromCellValue=new core.ObjectMatrix,newFromCellValue=new core.ObjectMatrix;core.Range.foreach(fromRange,(row,col)=>{fromCellValue.setValue(row,col,core.Tools.deepClone(fromCellMatrix.getValue(row,col))),newFromCellValue.setValue(row,col,null)});const toCellValue=new core.ObjectMatrix,newToCellValue=new core.ObjectMatrix;core.Range.foreach(toRange,(row,col)=>{toCellValue.setValue(row,col,core.Tools.deepClone(toCellMatrix.getValue(row,col)))}),core.Range.foreach(fromRange,(row,col)=>{const cellRange=core.cellToRange(row,col),relativeRange=core.Rectangle.getRelativeRange(cellRange,fromRange),range=core.Rectangle.getPositionRange(relativeRange,toRange);newToCellValue.setValue(range.startRow,range.startColumn,core.Tools.deepClone(fromCellMatrix.getValue(row,col)))});const doMoveRangeMutation={fromRange:from.range,toRange:to.range,from:{value:newFromCellValue.getMatrix(),subUnitId:fromSubUnitId},to:{value:newToCellValue.getMatrix(),subUnitId:toSubUnitId},unitId},undoMoveRangeMutation={fromRange:to.range,toRange:from.range,from:{value:fromCellValue.getMatrix(),subUnitId:fromSubUnitId},to:{value:toCellValue.getMatrix(),subUnitId:toSubUnitId},unitId};redos.push({id:MoveRangeMutation.id,params:doMoveRangeMutation}),undos.push({id:MoveRangeMutation.id,params:undoMoveRangeMutation})}return{redos,undos}}__name(getMoveRangeUndoRedoMutations,"getMoveRangeUndoRedoMutations");var I=(E=>(E[E.UNIVER_UNKNOWN=0]="UNIVER_UNKNOWN",E[E.UNIVER_DOC=1]="UNIVER_DOC",E[E.UNIVER_SHEET=2]="UNIVER_SHEET",E[E.UNIVER_SLIDE=3]="UNIVER_SLIDE",E[E.UNIVER_PROJECT=4]="UNIVER_PROJECT",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(I||{}),P=(E=>(E[E.View=0]="View",E[E.Edit=1]="Edit",E[E.ManageCollaborator=2]="ManageCollaborator",E[E.Print=3]="Print",E[E.Duplicate=4]="Duplicate",E[E.Comment=5]="Comment",E[E.Copy=6]="Copy",E[E.Share=7]="Share",E[E.Export=8]="Export",E[E.MoveWorksheet=9]="MoveWorksheet",E[E.DeleteWorksheet=10]="DeleteWorksheet",E[E.HideWorksheet=11]="HideWorksheet",E[E.RenameWorksheet=12]="RenameWorksheet",E[E.CreateWorksheet=13]="CreateWorksheet",E[E.SetWorksheetStyle=14]="SetWorksheetStyle",E[E.EditWorksheetCell=15]="EditWorksheetCell",E[E.InsertHyperlink=16]="InsertHyperlink",E[E.Sort=17]="Sort",E[E.Filter=18]="Filter",E[E.PivotTable=19]="PivotTable",E[E.FloatImg=20]="FloatImg",E[E.History=21]="History",E[E.RwHgtClWdt=22]="RwHgtClWdt",E[E.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",E[E.ViewFilter=24]="ViewFilter",E[E.MoveSheet=25]="MoveSheet",E[E.DeleteSheet=26]="DeleteSheet",E[E.HideSheet=27]="HideSheet",E[E.CopySheet=28]="CopySheet",E[E.RenameSheet=29]="RenameSheet",E[E.CreateSheet=30]="CreateSheet",E[E.SelectProtectedCells=31]="SelectProtectedCells",E[E.SelectUnProtectedCells=32]="SelectUnProtectedCells",E[E.SetCellStyle=33]="SetCellStyle",E[E.SetCellValue=34]="SetCellValue",E[E.SetRowStyle=35]="SetRowStyle",E[E.SetColumnStyle=36]="SetColumnStyle",E[E.InsertRow=37]="InsertRow",E[E.InsertColumn=38]="InsertColumn",E[E.DeleteRow=39]="DeleteRow",E[E.DeleteColumn=40]="DeleteColumn",E[E.EditExtraObject=41]="EditExtraObject",E[E.Delete=42]="Delete",E[E.RecoverHistory=43]="RecoverHistory",E[E.ViewHistory=44]="ViewHistory",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(P||{}),M=(E=>(E[E.Unkonwn=0]="Unkonwn",E[E.Workbook=1]="Workbook",E[E.Worksheet=2]="Worksheet",E[E.SelectRange=3]="SelectRange",E[E.Document=4]="Document",E[E.Slide=5]="Slide",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(M||{});const _WorksheetCopyPermission=class _WorksheetCopyPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Copy);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Copy}_${unitId}_${subUnitId}`}};__name(_WorksheetCopyPermission,"WorksheetCopyPermission");let WorksheetCopyPermission=_WorksheetCopyPermission;const _WorksheetSelectProtectedCellsPermission=class _WorksheetSelectProtectedCellsPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SelectProtectedCells);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SelectProtectedCells}_${unitId}_${subUnitId}`}};__name(_WorksheetSelectProtectedCellsPermission,"WorksheetSelectProtectedCellsPermission");let WorksheetSelectProtectedCellsPermission=_WorksheetSelectProtectedCellsPermission;const _WorksheetSelectUnProtectedCellsPermission=class _WorksheetSelectUnProtectedCellsPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SelectUnProtectedCells);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SelectUnProtectedCells}_${unitId}_${subUnitId}`}};__name(_WorksheetSelectUnProtectedCellsPermission,"WorksheetSelectUnProtectedCellsPermission");let WorksheetSelectUnProtectedCellsPermission=_WorksheetSelectUnProtectedCellsPermission;const _WorksheetSetCellStylePermission=class _WorksheetSetCellStylePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetCellStyle);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetCellStyle}_${unitId}_${subUnitId}`}};__name(_WorksheetSetCellStylePermission,"WorksheetSetCellStylePermission");let WorksheetSetCellStylePermission=_WorksheetSetCellStylePermission;const _WorksheetSetCellValuePermission=class _WorksheetSetCellValuePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetCellValue);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetCellValue}_${unitId}_${subUnitId}`}};__name(_WorksheetSetCellValuePermission,"WorksheetSetCellValuePermission");let WorksheetSetCellValuePermission=_WorksheetSetCellValuePermission;const _WorksheetViewPermission=class _WorksheetViewPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.View);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.View}_${unitId}_${subUnitId}`}};__name(_WorksheetViewPermission,"WorksheetViewPermission");let WorksheetViewPermission=_WorksheetViewPermission;const _WorksheetSetRowStylePermission=class _WorksheetSetRowStylePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetRowStyle);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetRowStyle}_${unitId}_${subUnitId}`}};__name(_WorksheetSetRowStylePermission,"WorksheetSetRowStylePermission");let WorksheetSetRowStylePermission=_WorksheetSetRowStylePermission;const _WorksheetSetColumnStylePermission=class _WorksheetSetColumnStylePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetColumnStyle);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetColumnStyle}_${unitId}_${subUnitId}`}};__name(_WorksheetSetColumnStylePermission,"WorksheetSetColumnStylePermission");let WorksheetSetColumnStylePermission=_WorksheetSetColumnStylePermission;const _WorksheetInsertRowPermission=class _WorksheetInsertRowPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.InsertRow);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.InsertRow}_${unitId}_${subUnitId}`}};__name(_WorksheetInsertRowPermission,"WorksheetInsertRowPermission");let WorksheetInsertRowPermission=_WorksheetInsertRowPermission;const _WorksheetInsertColumnPermission=class _WorksheetInsertColumnPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.InsertColumn);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.InsertColumn}_${unitId}_${subUnitId}`}};__name(_WorksheetInsertColumnPermission,"WorksheetInsertColumnPermission");let WorksheetInsertColumnPermission=_WorksheetInsertColumnPermission;const _WorksheetInsertHyperlinkPermission=class _WorksheetInsertHyperlinkPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.InsertHyperlink);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.InsertHyperlink}_${unitId}_${subUnitId}`}};__name(_WorksheetInsertHyperlinkPermission,"WorksheetInsertHyperlinkPermission");let WorksheetInsertHyperlinkPermission=_WorksheetInsertHyperlinkPermission;const _WorksheetDeleteRowPermission=class _WorksheetDeleteRowPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.DeleteRow);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.DeleteRow}_${unitId}_${subUnitId}`}};__name(_WorksheetDeleteRowPermission,"WorksheetDeleteRowPermission");let WorksheetDeleteRowPermission=_WorksheetDeleteRowPermission;const _WorksheetDeleteColumnPermission=class _WorksheetDeleteColumnPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.DeleteColumn);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.DeleteColumn}_${unitId}_${subUnitId}`}};__name(_WorksheetDeleteColumnPermission,"WorksheetDeleteColumnPermission");let WorksheetDeleteColumnPermission=_WorksheetDeleteColumnPermission;const _WorksheetSortPermission=class _WorksheetSortPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Sort);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Sort}_${unitId}_${subUnitId}`}};__name(_WorksheetSortPermission,"WorksheetSortPermission");let WorksheetSortPermission=_WorksheetSortPermission;const _WorksheetFilterPermission=class _WorksheetFilterPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Filter);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Filter}_${unitId}_${subUnitId}`}};__name(_WorksheetFilterPermission,"WorksheetFilterPermission");let WorksheetFilterPermission=_WorksheetFilterPermission;const _WorksheetPivotTablePermission=class _WorksheetPivotTablePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.PivotTable);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.PivotTable}_${unitId}_${subUnitId}`}};__name(_WorksheetPivotTablePermission,"WorksheetPivotTablePermission");let WorksheetPivotTablePermission=_WorksheetPivotTablePermission;const _WorksheetEditExtraObjectPermission=class _WorksheetEditExtraObjectPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.EditExtraObject);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.EditExtraObject}_${unitId}_${subUnitId}`}};__name(_WorksheetEditExtraObjectPermission,"WorksheetEditExtraObjectPermission");let WorksheetEditExtraObjectPermission=_WorksheetEditExtraObjectPermission;const _WorksheetManageCollaboratorPermission=class _WorksheetManageCollaboratorPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.ManageCollaborator);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.ManageCollaborator}_${unitId}_${subUnitId}`}};__name(_WorksheetManageCollaboratorPermission,"WorksheetManageCollaboratorPermission");let WorksheetManageCollaboratorPermission=_WorksheetManageCollaboratorPermission;const _WorksheetEditPermission=class _WorksheetEditPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Edit);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Edit}_${unitId}_${subUnitId}`}};__name(_WorksheetEditPermission,"WorksheetEditPermission");let WorksheetEditPermission=_WorksheetEditPermission;const _WorkbookCommentPermission=class _WorkbookCommentPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Comment);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Comment}_${unitId}`}};__name(_WorkbookCommentPermission,"WorkbookCommentPermission");let WorkbookCommentPermission=_WorkbookCommentPermission;const _WorkbookEditablePermission=class _WorkbookEditablePermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Edit);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Edit}_${unitId}`}};__name(_WorkbookEditablePermission,"WorkbookEditablePermission");let WorkbookEditablePermission=_WorkbookEditablePermission;const _WorkbookDuplicatePermission=class _WorkbookDuplicatePermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Duplicate);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Duplicate}_${unitId}`}};__name(_WorkbookDuplicatePermission,"WorkbookDuplicatePermission");let WorkbookDuplicatePermission=_WorkbookDuplicatePermission;const _WorkbookPrintPermission=class _WorkbookPrintPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Print);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Print}_${unitId}`}};__name(_WorkbookPrintPermission,"WorkbookPrintPermission");let WorkbookPrintPermission=_WorkbookPrintPermission;const _WorkbookExportPermission=class _WorkbookExportPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Export);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Export}_${unitId}`}};__name(_WorkbookExportPermission,"WorkbookExportPermission");let WorkbookExportPermission=_WorkbookExportPermission;const _WorkbookMoveSheetPermission=class _WorkbookMoveSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.MoveSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.MoveSheet}_${unitId}`}};__name(_WorkbookMoveSheetPermission,"WorkbookMoveSheetPermission");let WorkbookMoveSheetPermission=_WorkbookMoveSheetPermission;const _WorkbookDeleteSheetPermission=class _WorkbookDeleteSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.DeleteSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.DeleteSheet}_${unitId}`}};__name(_WorkbookDeleteSheetPermission,"WorkbookDeleteSheetPermission");let WorkbookDeleteSheetPermission=_WorkbookDeleteSheetPermission;const _WorkbookHideSheetPermission=class _WorkbookHideSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.HideSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.HideSheet}_${unitId}`}};__name(_WorkbookHideSheetPermission,"WorkbookHideSheetPermission");let WorkbookHideSheetPermission=_WorkbookHideSheetPermission;const _WorkbookRenameSheetPermission=class _WorkbookRenameSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.RenameSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.RenameSheet}_${unitId}`}};__name(_WorkbookRenameSheetPermission,"WorkbookRenameSheetPermission");let WorkbookRenameSheetPermission=_WorkbookRenameSheetPermission;const _WorkbookCreateSheetPermission=class _WorkbookCreateSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.CreateSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.CreateSheet}_${unitId}`}};__name(_WorkbookCreateSheetPermission,"WorkbookCreateSheetPermission");let WorkbookCreateSheetPermission=_WorkbookCreateSheetPermission;const _WorkbookHistoryPermission=class _WorkbookHistoryPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.History);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.History}_${unitId}`}};__name(_WorkbookHistoryPermission,"WorkbookHistoryPermission");let WorkbookHistoryPermission=_WorkbookHistoryPermission;const _WorkbookViewPermission=class _WorkbookViewPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.View);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.View}_${unitId}`}};__name(_WorkbookViewPermission,"WorkbookViewPermission");let WorkbookViewPermission=_WorkbookViewPermission;const _WorkbookSharePermission=class _WorkbookSharePermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Share);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Share}_${unitId}`}};__name(_WorkbookSharePermission,"WorkbookSharePermission");let WorkbookSharePermission=_WorkbookSharePermission;const _WorkbookCopyPermission=class _WorkbookCopyPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Copy);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Copy}_${unitId}`}};__name(_WorkbookCopyPermission,"WorkbookCopyPermission");let WorkbookCopyPermission=_WorkbookCopyPermission;const _WorkbookCopySheetPermission=class _WorkbookCopySheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"subType",P.CopySheet);__publicField(this,"status",core.PermissionStatus.INIT);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.CopySheet}_${unitId}`}};__name(_WorkbookCopySheetPermission,"WorkbookCopySheetPermission");let WorkbookCopySheetPermission=_WorkbookCopySheetPermission;const _WorkbookManageCollaboratorPermission=class _WorkbookManageCollaboratorPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.ManageCollaborator);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.ManageCollaborator}_${unitId}`}};__name(_WorkbookManageCollaboratorPermission,"WorkbookManageCollaboratorPermission");let WorkbookManageCollaboratorPermission=_WorkbookManageCollaboratorPermission;const _WorkbookViewHistoryPermission=class _WorkbookViewHistoryPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.ViewHistory);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.ViewHistory}_${unitId}`}};__name(_WorkbookViewHistoryPermission,"WorkbookViewHistoryPermission");let WorkbookViewHistoryPermission=_WorkbookViewHistoryPermission;const _WorkbookRecoverHistoryPermission=class _WorkbookRecoverHistoryPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.RecoverHistory);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.RecoverHistory}_${unitId}`}};__name(_WorkbookRecoverHistoryPermission,"WorkbookRecoverHistoryPermission");let WorkbookRecoverHistoryPermission=_WorkbookRecoverHistoryPermission;const _RangeProtectionPermissionEditPoint=class _RangeProtectionPermissionEditPoint{constructor(unitId,subUnitId,permissionId){__publicField(this,"type",M.SelectRange);__publicField(this,"subType",P.Edit);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"value",!0);__publicField(this,"id");__publicField(this,"unitId");__publicField(this,"subUnitId");__publicField(this,"permissionId");this.unitId=unitId,this.subUnitId=subUnitId,this.permissionId=permissionId,this.id=`${M.SelectRange}.${P.Edit}.${permissionId}`}};__name(_RangeProtectionPermissionEditPoint,"RangeProtectionPermissionEditPoint");let RangeProtectionPermissionEditPoint=_RangeProtectionPermissionEditPoint;const _RangeProtectionPermissionViewPoint=class _RangeProtectionPermissionViewPoint{constructor(unitId,subUnitId,permissionId){__publicField(this,"type",M.SelectRange);__publicField(this,"subType",P.View);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"value",!0);__publicField(this,"id");__publicField(this,"unitId");__publicField(this,"subUnitId");__publicField(this,"permissionId");this.unitId=unitId,this.subUnitId=subUnitId,this.permissionId=permissionId,this.id=`${M.SelectRange}.${P.View}.${permissionId}`}};__name(_RangeProtectionPermissionViewPoint,"RangeProtectionPermissionViewPoint");let RangeProtectionPermissionViewPoint=_RangeProtectionPermissionViewPoint;const SetRangeValuesCommand={id:"sheet.command.set-range-values",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a20;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),permissionService=accessor.get(core.IPermissionService),target=getSheetCommandTarget(univerInstanceService,{subUnitId:params.subUnitId,unitId:params.unitId});if(!target)return!1;const{subUnitId,unitId}=target,{value,range}=params,currentSelections=range?[range]:(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!currentSelections||!currentSelections.length||!permissionService.getPermissionPoint(new WorksheetEditPermission(unitId,subUnitId).id))return!1;const cellValue=new core.ObjectMatrix;let realCellValue;if(core.Tools.isArray(value))for(let i=0;i<currentSelections.length;i++){const{startRow,startColumn,endRow,endColumn}=currentSelections[i];for(let r=0;r<=endRow-startRow;r++)for(let c=0;c<=endColumn-startColumn;c++)cellValue.setValue(r+startRow,c+startColumn,value[r][c])}else if(core.isICellData(value))for(let i=0;i<currentSelections.length;i++){const{startRow,startColumn,endRow,endColumn}=currentSelections[i];for(let r=startRow;r<=endRow;r++)for(let c=startColumn;c<=endColumn;c++)cellValue.setValue(r,c,value)}else realCellValue=value;const setRangeValuesMutationParams={subUnitId,unitId,cellValue:realCellValue!=null?realCellValue:cellValue.getMatrix()},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams),setValueMutationResult=commandService.syncExecuteCommand(SetRangeValuesMutation.id,setRangeValuesMutationParams),{undos,redos}=sheetInterceptorService.onCommandExecute({id:SetRangeValuesCommand.id,params:{...setRangeValuesMutationParams,range:currentSelections}}),result=core.sequenceExecute([...redos],commandService);return setValueMutationResult&&result.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams},...undos],redoMutations:[{id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...redos]}),!0):!1},"handler")};function getInsertRangeMutations(accessor,params){const redo=[],undo=[],{unitId,subUnitId,range,shiftDimension,cellValue={}}=params,instanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=instanceService.getUniverSheetInstance(unitId),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(worksheet){const cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange();if(range.startColumn<=dataRange.endColumn||range.startRow<=dataRange.endRow){let moveFromRange,moveToRange;if(shiftDimension===core.Dimension.COLUMNS){const endRow=Math.min(range.endRow,dataRange.endRow);let endColumn=0;for(let row=range.startRow;row<=endRow;row++){const rowData=cellMatrix.getRow(row),rowLength=rowData?core.getArrayLength(rowData)-1:0;endColumn=Math.max(endColumn,rowLength)}moveFromRange={startRow:range.startRow,startColumn:range.startColumn,endRow,endColumn};const shift=range.endColumn-range.startColumn+1;moveToRange={startRow:range.startRow,startColumn:moveFromRange.startColumn+shift,endRow,endColumn:moveFromRange.endColumn+shift}}else{const endColumn=Math.min(range.endColumn,dataRange.endColumn),endRow=dataRange.endRow;moveFromRange={startRow:range.startRow,startColumn:range.startColumn,endRow,endColumn};const shift=range.endRow-range.startRow+1;moveToRange={startRow:moveFromRange.startRow+shift,startColumn:range.startColumn,endRow:moveFromRange.endRow+shift,endColumn}}const moveRangeMutations=getMoveRangeUndoRedoMutations(accessor,{unitId,subUnitId,range:moveFromRange},{unitId,subUnitId,range:moveToRange},!0);moveRangeMutations&&(redo.push(...moveRangeMutations.redos),undo.push(...moveRangeMutations.undos))}if(Object.entries(cellValue).length===0)for(let row=range.startRow;row<=range.endRow;row++){cellValue[row]||(cellValue[row]={});for(let column=range.startColumn;column<=range.endColumn;column++)cellValue[row][column]=null}const setRangeValuesMutationParams={subUnitId,unitId,cellValue},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams),{undos:interceptorUndos,redos:interceptorRedos}=sheetInterceptorService.onCommandExecute({id:SetRangeValuesCommand.id,params:{...setRangeValuesMutationParams,range}});redo.push({id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...interceptorRedos),undo.push({id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams},...interceptorUndos)}return{redo,undo}}__name(getInsertRangeMutations,"getInsertRangeMutations");function getRemoveRangeMutations(accessor,params){const redo=[],undo=[],{unitId,subUnitId,range,shiftDimension}=params,instanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=instanceService.getUniverSheetInstance(unitId),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(worksheet){const cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange(),setRangeValuesMutationParams={subUnitId,unitId,cellValue:generateNullCell([range])},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams),intercepted=sheetInterceptorService.onCommandExecute({id:SetRangeValuesCommand.id,params:setRangeValuesMutationParams});if(redo.push({id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...intercepted.redos),undo.push(...intercepted.undos,{id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams}),range.startColumn<=dataRange.endColumn||range.startRow<=dataRange.endRow){let moveFromRange=null,moveToRange=null;if(shiftDimension===core.Dimension.COLUMNS&&range.endColumn<dataRange.endColumn){const endRow=Math.min(range.endRow,dataRange.endRow);let endColumn=0;for(let row=range.startRow;row<=endRow;row++){const rowData=cellMatrix.getRow(row),rowLength=rowData?core.getArrayLength(rowData)-1:0;endColumn=Math.max(endColumn,rowLength)}moveFromRange={startRow:range.startRow,startColumn:range.endColumn+1,endRow,endColumn};const shift=range.endColumn-range.startColumn+1;moveToRange={startRow:range.startRow,startColumn:moveFromRange.startColumn-shift,endRow,endColumn:moveFromRange.endColumn-shift}}if(shiftDimension===core.Dimension.ROWS&&range.endRow<dataRange.endRow){const endColumn=Math.min(range.endColumn,dataRange.endColumn),endRow=dataRange.endRow;moveFromRange={startRow:range.endRow+1,startColumn:range.startColumn,endRow,endColumn};const shift=range.endRow-range.startRow+1;moveToRange={startRow:moveFromRange.startRow-shift,startColumn:range.startColumn,endRow:moveFromRange.endRow-shift,endColumn}}if(moveFromRange&&moveToRange){const moveRangeMutations=getMoveRangeUndoRedoMutations(accessor,{unitId,subUnitId,range:moveFromRange},{unitId,subUnitId,range:moveToRange},!0);moveRangeMutations&&(redo.push(...moveRangeMutations.redos),undo.push(...moveRangeMutations.undos))}}}return{redo,undo}}__name(getRemoveRangeMutations,"getRemoveRangeMutations");function handleInsertRangeMutation(cellMatrix,range,lastEndRow,lastEndColumn,shiftDimension,cellValue){const{startRow,endRow,startColumn,endColumn}=range;if(shiftDimension===core.Dimension.ROWS){const rows=endRow-startRow+1;for(let r=lastEndRow;r>=startRow;r--)for(let c=startColumn;c<=endColumn;c++){const value=cellMatrix.getValue(r,c);value==null?cellMatrix.realDeleteValue(r+rows,c):cellMatrix.setValue(r+rows,c,value)}for(let r=endRow;r>=startRow;r--)for(let c=startColumn;c<=endColumn;c++)cellValue&&cellValue[r]&&cellValue[r][c]?cellMatrix.setValue(r,c,cellValue[r][c]):cellMatrix.realDeleteValue(r,c)}else if(shiftDimension===core.Dimension.COLUMNS){const columns=endColumn-startColumn+1;for(let r=startRow;r<=endRow;r++)for(let c=lastEndColumn;c>=startColumn;c--){const value=cellMatrix.getValue(r,c);value==null?cellMatrix.realDeleteValue(r,c+columns):cellMatrix.setValue(r,c+columns,value)}for(let r=startRow;r<=endRow;r++)for(let c=endColumn;c>=startColumn;c--)cellValue&&cellValue[r]&&cellValue[r][c]?cellMatrix.setValue(r,c,cellValue[r][c]):cellMatrix.realDeleteValue(r,c)}}__name(handleInsertRangeMutation,"handleInsertRangeMutation");function handleDeleteRangeMutation(cellMatrix,range,lastEndRow,lastEndColumn,shiftDimension){const{startRow,endRow,startColumn,endColumn}=range,rows=endRow-startRow+1,columns=endColumn-startColumn+1;if(shiftDimension===core.Dimension.ROWS)for(let r=startRow;r<=lastEndRow;r++)for(let c=startColumn;c<=endColumn;c++){const value=cellMatrix.getValue(r+rows,c);value==null?cellMatrix.realDeleteValue(r,c):cellMatrix.setValue(r,c,value)}else if(shiftDimension===core.Dimension.COLUMNS)for(let r=startRow;r<=endRow;r++)for(let c=startColumn;c<=lastEndColumn;c++){const value=cellMatrix.getValue(r,c+columns);value==null?cellMatrix.realDeleteValue(r,c):cellMatrix.setValue(r,c,value)}}__name(handleDeleteRangeMutation,"handleDeleteRangeMutation");const DeleteRangeMoveLeftCommandId="sheet.command.delete-range-move-left",DeleteRangeMoveLeftCommand={type:core.CommandType.COMMAND,id:DeleteRangeMoveLeftCommandId,handler:__name(async(accessor,params)=>{var _a20,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,workbook,subUnitId,unitId}=target;let range=params==null?void 0:params.range;if(range||(range=(_a20=selectionManagerService.getCurrentLastSelection())==null?void 0:_a20.range),!range)return!1;const deleteRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.COLUMNS},sheetInterceptor=sheetInterceptorService.onCommandExecute({id:DeleteRangeMoveLeftCommand.id,params:{range}}),{redo:removeRangeRedo,undo:removeRangeUndo}=getRemoveRangeMutations(accessor,deleteRangeMutationParams),redos=[...(_b=sheetInterceptor.preRedos)!=null?_b:[],...removeRangeRedo],undos=[...sheetInterceptor.undos,...removeRangeUndo];return redos.push(...sheetInterceptor.redos),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.push(...(_c=sheetInterceptor.preUndos)!=null?_c:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos.reverse(),redoMutations:redos}),!0):!1},"handler")},DeleteRangeMoveUpCommandId="sheet.command.delete-range-move-up",DeleteRangeMoveUpCommand={type:core.CommandType.COMMAND,id:DeleteRangeMoveUpCommandId,handler:__name(async(accessor,params)=>{var _a20,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,workbook,worksheet}=target;let range=params==null?void 0:params.range;if(range||(range=(_a20=selectionManagerService.getCurrentLastSelection())==null?void 0:_a20.range),!range)return!1;const deleteRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.ROWS},sheetInterceptor=sheetInterceptorService.onCommandExecute({id:DeleteRangeMoveUpCommand.id,params:{range}}),{redo:removeRangeRedo,undo:removeRangeUndo}=getRemoveRangeMutations(accessor,deleteRangeMutationParams),redos=[...(_b=sheetInterceptor.preRedos)!=null?_b:[],...removeRangeRedo],undos=[...sheetInterceptor.undos,...removeRangeUndo];return redos.push(...sheetInterceptor.redos),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.push(...(_c=sheetInterceptor.preUndos)!=null?_c:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos.reverse(),redoMutations:redos}),!0):!1},"handler")},InsertRowMutationUndoFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range}},"InsertRowMutationUndoFactory"),InsertRowMutation={id:"sheet.mutation.insert-row",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a20;const{unitId,subUnitId,range,rowInfo}=params,universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const rowWrapper=worksheet.getRowManager().getRowData(),defaultRowInfo={h:worksheet.getConfig().defaultRowHeight,hd:0},rowIndex=range.startRow,rowCount=range.endRow-range.startRow+1;for(let j=rowIndex;j<rowIndex+rowCount;j++)rowInfo?core.insertMatrixArray(j,(_a20=rowInfo[j-range.startRow])!=null?_a20:defaultRowInfo,rowWrapper):core.insertMatrixArray(j,defaultRowInfo,rowWrapper);return worksheet.setRowCount(worksheet.getRowCount()+range.endRow-range.startRow+1),worksheet.getCellMatrix().insertRows(range.startRow,rowCount),!0},"handler")},InsertColMutationUndoFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range}},"InsertColMutationUndoFactory"),InsertColMutation={id:"sheet.mutation.insert-col",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a20;const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const manager=worksheet.getColumnManager(),{range,colInfo}=params,columnWrapper=manager.getColumnData(),colIndex=range.startColumn,colCount=range.endColumn-range.startColumn+1,defaultColWidth=worksheet.getConfig().defaultColumnWidth;for(let j=colIndex;j<colIndex+colCount;j++){const defaultColInfo={w:defaultColWidth,hd:0};colInfo?core.insertMatrixArray(j,(_a20=colInfo[j-range.startColumn])!=null?_a20:defaultColInfo,columnWrapper):core.insertMatrixArray(j,defaultColInfo,columnWrapper)}return worksheet.setColumnCount(worksheet.getColumnCount()+range.endColumn-range.startColumn+1),worksheet.getCellMatrix().insertColumns(range.startColumn,colCount),!0},"handler")},RemoveRowsUndoMutationFactory=__name((params,worksheet)=>{const rowWrapper=worksheet.getRowManager().getRowData(),rowInfo={},range=params.range,slice=core.sliceMatrixArray(range.startRow,range.endRow,rowWrapper),_rowInfo=core.concatMatrixArray(rowInfo,slice);return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,rowInfo:_rowInfo}},"RemoveRowsUndoMutationFactory"),RemoveRowMutation={id:"sheet.mutation.remove-rows",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const range=params.range,rowPrimitive=worksheet.getRowManager().getRowData();for(let i=range.startRow;i<=range.endRow;i++)worksheet.getRowFiltered(i);const rowCount=range.endRow-range.startRow+1;return core.spliceArray(range.startRow,rowCount,rowPrimitive),worksheet.getCellMatrix().removeRows(range.startRow,rowCount),worksheet.setRowCount(worksheet.getRowCount()-rowCount),!0},"handler")},RemoveColMutationFactory=__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const columnWrapper=worksheet.getColumnManager().getColumnData(),colInfo={},range=params.range,slice=core.sliceMatrixArray(range.startColumn,range.endColumn,columnWrapper),_colInfo=core.concatMatrixArray(colInfo,slice);return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,colInfo:_colInfo}},"RemoveColMutationFactory"),RemoveColMutation={id:"sheet.mutation.remove-col",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const range=params.range,colPrimitive=worksheet.getColumnManager().getColumnData(),colCount=range.endColumn-range.startColumn+1;return core.spliceArray(range.startColumn,colCount,colPrimitive),worksheet.setColumnCount(worksheet.getColumnCount()-colCount),worksheet.getCellMatrix().removeColumns(range.startColumn,colCount),!0},"handler")},InsertRangeMoveDownCommandId="sheet.command.insert-range-move-down",InsertRangeMoveDownCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-range-move-down",handler:__name(async(accessor,params)=>{var _a20,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService);if(selectionManagerService.isOverlapping())return errorService.emit(localeService.t("sheets.info.overlappingSelections")),!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,worksheet,workbook}=target;let range=params==null?void 0:params.range;if(range||(range=(_a20=selectionManagerService.getCurrentLastSelection())==null?void 0:_a20.range),!range)return!1;const redoMutations=[],undoMutations=[],cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange(),sliceMaxRow=cellMatrix.getSlice(dataRange.startRow,dataRange.endRow,range.startColumn,range.endColumn).getDataRange().endRow,insertRowCount=Math.max(sliceMaxRow+(range.endRow-range.startRow+1)-dataRange.endRow,0);if(insertRowCount>0){const anchorRow=range.startRow-1,height=worksheet.getRowHeight(anchorRow),insertRowParams={unitId,subUnitId,range:{startRow:dataRange.endRow+1,endRow:dataRange.endRow+insertRowCount,startColumn:dataRange.startColumn,endColumn:dataRange.endColumn},rowInfo:new Array(insertRowCount).fill(void 0).map(()=>({h:height,hd:core.BooleanNumber.FALSE}))};redoMutations.push({id:InsertRowMutation.id,params:insertRowParams});const undoRowInsertionParams=InsertRowMutationUndoFactory(accessor,insertRowParams);undoMutations.push({id:RemoveRowMutation.id,params:undoRowInsertionParams})}const cellValue={};core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCell(row,col);cell&&(cellValue[row]||(cellValue[row]={}),cellValue[row][col]={s:cell.s})});const insertRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.ROWS,cellValue},{redo:insertRangeRedo,undo:insertRangeUndo}=getInsertRangeMutations(accessor,insertRangeMutationParams);redoMutations.push(...insertRangeRedo),undoMutations.push(...insertRangeUndo);const sheetInterceptor=sheetInterceptorService.onCommandExecute({id:InsertRangeMoveDownCommand.id,params:{range}});return redoMutations.push(...sheetInterceptor.redos),redoMutations.push(followSelectionOperation(range,workbook,worksheet)),undoMutations.push(...(_b=sheetInterceptor.preUndos)!=null?_b:[]),redoMutations.unshift(...(_c=sheetInterceptor.preRedos)!=null?_c:[]),undoMutations.unshift(...sheetInterceptor.undos),core.sequenceExecute(redoMutations,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undoMutations.reverse(),redoMutations}),!0):!1},"handler")},InsertRangeMoveRightCommandId="sheet.command.insert-range-move-right",InsertRangeMoveRightCommand={type:core.CommandType.COMMAND,id:InsertRangeMoveRightCommandId,handler:__name(async(accessor,params)=>{var _a20,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService);if(selectionManagerService.isOverlapping())return errorService.emit(localeService.t("sheets.info.overlappingSelections")),!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,unitId,subUnitId}=target;let range=params==null?void 0:params.range;if(range||(range=(_a20=selectionManagerService.getCurrentLastSelection())==null?void 0:_a20.range),!range)return!1;const redoMutations=[],undoMutations=[],cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange(),sliceMaxCol=cellMatrix.getSlice(range.startRow,range.endRow,dataRange.startColumn,dataRange.endColumn).getDataRange().endColumn,insertColCount=Math.max(sliceMaxCol+(range.endColumn-range.startColumn+1)-dataRange.endColumn,0);if(insertColCount>0){const anchorCol=range.startColumn-1,width=worksheet.getColumnWidth(anchorCol),insertColParams={unitId,subUnitId,range:{startRow:dataRange.startRow+1,endRow:dataRange.endRow,startColumn:dataRange.endColumn+1,endColumn:dataRange.endColumn+insertColCount},colInfo:new Array(insertColCount).fill(void 0).map(()=>({w:width,hd:core.BooleanNumber.FALSE}))};redoMutations.push({id:InsertColMutation.id,params:insertColParams});const undoColInsertionParams=InsertColMutationUndoFactory(accessor,insertColParams);undoMutations.push({id:RemoveColMutation.id,params:undoColInsertionParams})}const cellValue={};core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCell(row,col);!cell||!cell.s||(cellValue[row]||(cellValue[row]={}),cellValue[row][col]={s:cell.s})});const insertRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.COLUMNS,cellValue},{redo:insertRangeRedo,undo:insertRangeUndo}=getInsertRangeMutations(accessor,insertRangeMutationParams);redoMutations.push(...insertRangeRedo),undoMutations.push(...insertRangeUndo);const sheetInterceptor=sheetInterceptorService.onCommandExecute({id:InsertRangeMoveRightCommand.id,params:{range}});return redoMutations.push(...sheetInterceptor.redos),redoMutations.push(followSelectionOperation(range,workbook,worksheet)),undoMutations.push(...(_b=sheetInterceptor.preUndos)!=null?_b:[]),redoMutations.unshift(...(_c=sheetInterceptor.preRedos)!=null?_c:[]),undoMutations.unshift(...sheetInterceptor.undos),core.sequenceExecute(redoMutations,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undoMutations.reverse(),redoMutations}),!0):!1},"handler")},InsertRowCommandId="sheet.command.insert-row",InsertRowCommand={type:core.CommandType.COMMAND,id:InsertRowCommandId,handler:__name(async(accessor,params)=>{var _a20,_b,_c,_d;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=univerInstanceService.getUniverSheetInstance(params.unitId),worksheet=workbook.getSheetBySheetId(params.subUnitId),{range,direction,unitId,subUnitId,cellValue}=params,{startRow,endRow}=range,anchorRow=direction===core.Direction.UP?startRow:startRow-1,height=worksheet.getRowHeight(anchorRow),insertRowParams={unitId,subUnitId,range,rowInfo:new Array(endRow-startRow+1).fill(void 0).map(()=>({h:height,hd:core.BooleanNumber.FALSE}))},undoRowInsertionParams=InsertRowMutationUndoFactory(accessor,insertRowParams);if(!await sheetInterceptorService.beforeCommandExecute({id:InsertRowCommand.id,params:insertRowParams}))return!1;const redos=[{id:InsertRowMutation.id,params:insertRowParams}],undos=[{id:RemoveRowMutation.id,params:undoRowInsertionParams}];cellValue&&redos.push({id:SetRangeValuesMutation.id,params:{unitId,subUnitId,cellValue}});const intercepted=sheetInterceptorService.onCommandExecute({id:InsertRowCommand.id,params});return redos.unshift(...(_a20=intercepted.preRedos)!=null?_a20:[]),redos.push(...(_b=intercepted.redos)!=null?_b:[]),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.unshift(...(_c=intercepted.preUndos)!=null?_c:[]),undos.push(...(_d=intercepted.undos)!=null?_d:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},InsertRowBeforeCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-row-before",handler:__name(async accessor=>{var _a20;const selections=(_a20=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a20.map(s=>s.range);let range;if((selections==null?void 0:selections.length)===1)range=selections[0];else return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),{startRow,endRow}=range,startColumn=0,endColumn=worksheet.getColumnCount()-1,cellValue=copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!0,startRow-1),insertRowParams={unitId,subUnitId,direction:core.Direction.UP,range:{startRow,endRow,startColumn,endColumn},cellValue};return accessor.get(core.ICommandService).executeCommand(InsertRowCommand.id,insertRowParams)},"handler")},InsertRowAfterCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-row-after",handler:__name(async accessor=>{var _a20;const selections=(_a20=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a20.map(s=>s.range);let range;if((selections==null?void 0:selections.length)===1)range=selections[0];else return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),count=range.endRow-range.startRow+1,startRow=range.endRow+1,endRow=range.endRow+count,startColumn=0,endColumn=worksheet.getColumnCount()-1,cellValue=copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!0,range.endRow),insertRowParams={unitId,subUnitId,direction:core.Direction.DOWN,range:{startRow,endRow,startColumn,endColumn,rangeType:core.RANGE_TYPE.ROW},cellValue};return accessor.get(core.ICommandService).executeCommand(InsertRowCommand.id,insertRowParams)},"handler")},InsertColCommandId="sheet.command.insert-col",InsertColCommand={type:core.CommandType.COMMAND,id:InsertColCommandId,handler:__name(async(accessor,params)=>{var _a20,_b,_c,_d;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),{range,direction,subUnitId,unitId,cellValue}=params,{startColumn,endColumn}=params.range,workbook=univerInstanceService.getUniverSheetInstance(params.unitId),worksheet=workbook.getSheetBySheetId(params.subUnitId),anchorCol=direction===core.Direction.LEFT?startColumn:startColumn-1,width=worksheet.getColumnWidth(anchorCol),insertColParams={unitId,subUnitId,range,colInfo:new Array(endColumn-startColumn+1).fill(void 0).map(()=>({w:width,hd:core.BooleanNumber.FALSE}))},undoColInsertionParams=InsertColMutationUndoFactory(accessor,insertColParams);if(!await sheetInterceptorService.beforeCommandExecute({id:InsertColCommand.id,params:insertColParams}))return!1;const redos=[{id:InsertColMutation.id,params:insertColParams}],undos=[{id:RemoveColMutation.id,params:undoColInsertionParams}];cellValue&&redos.push({id:SetRangeValuesMutation.id,params:{unitId,subUnitId,cellValue}});const intercepted=sheetInterceptorService.onCommandExecute({id:InsertColCommand.id,params});return redos.unshift(...(_a20=intercepted.preRedos)!=null?_a20:[]),redos.push(...(_b=intercepted.redos)!=null?_b:[]),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.unshift(...(_c=intercepted.preUndos)!=null?_c:[]),undos.push(...(_d=intercepted.undos)!=null?_d:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:undos.filter(Boolean),redoMutations:redos.filter(Boolean)}),!0):!1},"handler")},InsertColBeforeCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-col-before",handler:__name(async accessor=>{const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections();let range;if((selections==null?void 0:selections.length)===1)range=selections[0].range;else return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),{startColumn,endColumn}=range,startRow=0,endRow=worksheet.getRowCount()-1,cellValue=copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!1,startColumn-1),insertColParams={unitId,subUnitId,direction:core.Direction.LEFT,range:{startColumn,endColumn,startRow,endRow,rangeType:core.RANGE_TYPE.COLUMN},cellValue};return accessor.get(core.ICommandService).executeCommand(InsertColCommand.id,insertColParams)},"handler")},InsertColAfterCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-col-after",handler:__name(async accessor=>{const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections();let range;if((selections==null?void 0:selections.length)===1)range=selections[0].range;else return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),count=range.endColumn-range.startColumn+1,startColumn=range.endColumn+1,endColumn=range.endColumn+count,startRow=0,endRow=worksheet.getRowCount()-1,cellValue=copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!1,range.endColumn),insertColParams={unitId,subUnitId,direction:core.Direction.RIGHT,range:{startColumn,endColumn,startRow,endRow},cellValue};return accessor.get(core.ICommandService).executeCommand(InsertColCommand.id,insertColParams)},"handler")},InsertSheetCommand={id:"sheet.command.insert-sheet",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a20;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),localeService=accessor.get(core.LocaleService),target=getSheetCommandTargetWorkbook(univerInstanceService,{unitId:params==null?void 0:params.unitId});if(!target)return!1;const{unitId,workbook}=target;let index=workbook.getSheets().length;const sheet=params==null?void 0:params.sheet,sheetId=sheet==null?void 0:sheet.id,sheetConfig=core.mergeWorksheetSnapshotWithDefault(sheet||{});params?(index=(_a20=params.index)!=null?_a20:index,sheetConfig.id=sheetId||core.Tools.generateRandomId(),sheetConfig.name=(sheet==null?void 0:sheet.name)||workbook.generateNewSheetName(`${localeService.t("sheets.tabs.sheet")}`)):(sheetConfig.id=core.Tools.generateRandomId(),sheetConfig.name=workbook.generateNewSheetName(`${localeService.t("sheets.tabs.sheet")}`));const insertSheetMutationParams={index,sheet:sheetConfig,unitId},removeSheetMutationParams=InsertSheetUndoMutationFactory(accessor,insertSheetMutationParams);return commandService.syncExecuteCommand(InsertSheetMutation.id,insertSheetMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:RemoveSheetMutation.id,params:removeSheetMutationParams}],redoMutations:[{id:InsertSheetMutation.id,params:insertSheetMutationParams}]}),!0):!1},"handler")};function MoveRowsMutationUndoFactory(_accessor,params){const{unitId,subUnitId,sourceRange,targetRange}=params,movingBackward=sourceRange.startRow>targetRange.startRow,count=sourceRange.endRow-sourceRange.startRow+1;return movingBackward?{unitId,subUnitId,sourceRange:core.Rectangle.clone(targetRange),targetRange:{...sourceRange,endRow:sourceRange.endRow+count,startRow:sourceRange.startRow+count}}:{unitId,subUnitId,targetRange:core.Rectangle.clone(sourceRange),sourceRange:{...targetRange,endRow:targetRange.endRow-count,startRow:targetRange.startRow-count}}}__name(MoveRowsMutationUndoFactory,"MoveRowsMutationUndoFactory");const MoveRowsMutation={id:"sheet.mutation.move-rows",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,sourceRange,targetRange}=params,univerSheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(!univerSheet)throw new Error("[MoveRowMutation] univerSheet is null!");const worksheet=univerSheet.getSheetBySheetId(subUnitId);if(!worksheet)throw new Error("[MoveRowMutation] worksheet is null!");const fromRow=sourceRange.startRow,count=sourceRange.endRow-sourceRange.startRow+1,toRow=targetRange.startRow,rowWrapper=worksheet.getRowManager().getRowData();return core.moveMatrixArray(fromRow,count,toRow,rowWrapper),worksheet.getCellMatrix().moveRows(fromRow,count,toRow),!0},"handler")};function MoveColsMutationUndoFactory(_accessor,params){const{unitId,subUnitId,sourceRange,targetRange}=params,movingBackward=sourceRange.startColumn>targetRange.startColumn,count=sourceRange.endColumn-sourceRange.startColumn+1;return movingBackward?{unitId,subUnitId,sourceRange:core.Rectangle.clone(targetRange),targetRange:{...sourceRange,endColumn:sourceRange.endColumn+count,startColumn:sourceRange.startColumn+count}}:{unitId,subUnitId,targetRange:core.Rectangle.clone(sourceRange),sourceRange:{...targetRange,startColumn:targetRange.startColumn-count,endColumn:targetRange.endColumn-count}}}__name(MoveColsMutationUndoFactory,"MoveColsMutationUndoFactory");const MoveColsMutation={id:"sheet.mutation.move-columns",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,sourceRange,targetRange}=params,univerSheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(!univerSheet)throw new Error("[MoveColumnMutation] univerSheet is null!");const worksheet=univerSheet.getSheetBySheetId(subUnitId);if(!worksheet)throw new Error("[MoveColumnMutation] worksheet is null!");const fromCol=sourceRange.startColumn,count=sourceRange.endColumn-sourceRange.startColumn+1,toCol=targetRange.startColumn,columnWrapper=worksheet.getColumnManager().getColumnData();return core.moveMatrixArray(fromCol,count,toCol,columnWrapper),worksheet.getCellMatrix().moveColumns(fromCol,count,toCol),!0},"handler")};function rowAcrossMergedCell(row,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startRow<row&&row<=mergedCell.endRow)}__name(rowAcrossMergedCell,"rowAcrossMergedCell");function columnAcrossMergedCell(col,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startColumn<col&&col<=mergedCell.endColumn)}__name(columnAcrossMergedCell,"columnAcrossMergedCell");const MoveRowsCommandId="sheet.command.move-rows",MoveRowsCommand={id:MoveRowsCommandId,type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a20,_b;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),{fromRange:{startRow:fromRow},toRange:{startRow:toRow},range}=params,selections=range?[covertRangeToSelection(range)]:selectionManagerService.getCurrentSelections(),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?void 0:filteredSelections.length)!==1)return!1;const sheetInterceptorService=accessor.get(exports.SheetInterceptorService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{workbook,worksheet}=target,unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),rangeToMove=filteredSelections[0].range,beforePrimary=filteredSelections[0].primary,alignedRange=alignToMergedCellsBorders(rangeToMove,worksheet,!1);if(!core.Rectangle.equals(rangeToMove,alignedRange))return errorService.emit(localeService.t("sheets.info.partOfCell")),!1;if(rowAcrossMergedCell(toRow,worksheet))return errorService.emit(localeService.t("sheets.info.acrossMergedCell")),!1;const destinationRange={...rangeToMove,startRow:toRow,endRow:toRow+rangeToMove.endRow-rangeToMove.startRow},moveRowsParams={unitId,subUnitId,sourceRange:rangeToMove,targetRange:destinationRange},undoMoveRowsParams=MoveRowsMutationUndoFactory(accessor,moveRowsParams),commandService=accessor.get(core.ICommandService),interceptorCommands=sheetInterceptorService.onCommandExecute({id:MoveRowsCommand.id,params}),redos=[...(_a20=interceptorCommands.preRedos)!=null?_a20:[],{id:MoveRowsMutation.id,params:moveRowsParams}],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],{id:MoveRowsMutation.id,params:undoMoveRowsParams}];if(beforePrimary){const moveBackward=toRow-fromRow<0,count=rangeToMove.endRow-rangeToMove.startRow+1,destSelection=moveBackward?destinationRange:{...destinationRange,startRow:destinationRange.startRow-count,endRow:destinationRange.endRow-count},setSelectionsParam={unitId,subUnitId,selections:[{range:destSelection,primary:getPrimaryForRange(destSelection,worksheet),style:null}]},undoSetSelectionsParam={unitId,subUnitId,selections:[{range:rangeToMove,primary:beforePrimary,style:null}]};redos.push({id:SetSelectionsOperation.id,params:setSelectionsParam}),undos.push({id:SetSelectionsOperation.id,params:undoSetSelectionsParam})}return redos.push(...interceptorCommands.redos),undos.push(...interceptorCommands.undos),core.sequenceExecute(redos,commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},MoveColsCommandId="sheet.command.move-cols",MoveColsCommand={id:MoveColsCommandId,type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a20,_b;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),{fromRange:{startColumn:fromCol},toRange:{startColumn:toCol},range}=params,selections=range?[covertRangeToSelection(range)]:selectionManagerService.getCurrentSelections(),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?void 0:filteredSelections.length)!==1)return!1;const sheetInterceptorService=accessor.get(exports.SheetInterceptorService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{workbook,worksheet}=target,unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),rangeToMove=filteredSelections[0].range,beforePrimary=filteredSelections[0].primary,alignedRange=alignToMergedCellsBorders(rangeToMove,worksheet,!1);if(!core.Rectangle.equals(rangeToMove,alignedRange))return errorService.emit(localeService.t("sheets.info.partOfCell")),!1;if(columnAcrossMergedCell(toCol,worksheet))return errorService.emit(localeService.t("sheets.info.acrossMergedCell")),!1;const destinationRange={...rangeToMove,startColumn:toCol,endColumn:toCol+rangeToMove.endColumn-rangeToMove.startColumn},moveColsParams={unitId,subUnitId,sourceRange:rangeToMove,targetRange:destinationRange},undoMoveColsParams=MoveColsMutationUndoFactory(accessor,moveColsParams),commandService=accessor.get(core.ICommandService),interceptorCommands=sheetInterceptorService.onCommandExecute({id:MoveColsCommand.id,params}),redos=[...(_a20=interceptorCommands.preRedos)!=null?_a20:[],{id:MoveColsMutation.id,params:moveColsParams}],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],{id:MoveColsMutation.id,params:undoMoveColsParams}];if(beforePrimary){const count=rangeToMove.endColumn-rangeToMove.startColumn+1,destSelection=toCol-fromCol<0?destinationRange:{...destinationRange,startColumn:destinationRange.startColumn-count,endColumn:destinationRange.endColumn-count},setSelectionsParam={unitId,subUnitId,selections:[{range:destSelection,primary:getPrimaryForRange(destSelection,worksheet),style:null}]},undoSetSelectionsParam={unitId,subUnitId,selections:[{range:rangeToMove,primary:beforePrimary,style:null}]};redos.push({id:SetSelectionsOperation.id,params:setSelectionsParam}),undos.push({id:SetSelectionsOperation.id,params:undoSetSelectionsParam})}return redos.push(...interceptorCommands.redos),undos.push(...interceptorCommands.undos),core.sequenceExecute(redos,commandService).result&&accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0},"handler")};function covertRangeToSelection(range){return{range,primary:null,style:null}}__name(covertRangeToSelection,"covertRangeToSelection");const RemoveRowCommandId="sheet.command.remove-row",RemoveRowCommand={type:core.CommandType.COMMAND,id:RemoveRowCommandId,handler:__name(async(accessor,params)=>{var _a20,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);let totalRange=params==null?void 0:params.range;if(totalRange||(totalRange=(_a20=selectionManagerService.getCurrentLastSelection())==null?void 0:_a20.range),!totalRange)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,subUnitId,unitId}=target;totalRange={...totalRange,startColumn:0,endColumn:Math.max(worksheet.getMaxColumns()-1,0)};const filterOutRowsInRemove=[];for(let i=totalRange.startRow;i<=totalRange.endRow;i++)worksheet.getRowFiltered(i)&&filterOutRowsInRemove.push(i);const ranges=[];if(filterOutRowsInRemove.length){const starts=[totalRange.startRow,...filterOutRowsInRemove.map(r=>r+1)],ends=[...filterOutRowsInRemove.map(r=>r-1),totalRange.endRow];for(let i=starts.length-1;i>=0;i--)starts[i]<=ends[i]&&ranges.push({startRow:starts[i],endRow:ends[i],startColumn:totalRange.startColumn,endColumn:totalRange.endColumn})}else ranges.push(totalRange);if(!await sheetInterceptorService.beforeCommandExecute({id:RemoveRowCommand.id,params:{range:totalRange,ranges}}))return!1;const redos=[],undos=[];ranges.forEach(range=>{const removeRowsParams={unitId,subUnitId,range},removedRows=worksheet.getCellMatrix().getSlice(range.startRow,range.endRow,0,worksheet.getColumnCount()-1),undoSetRangeValuesParams={unitId,subUnitId,cellValue:removedRows.getMatrix()},undoRemoveRowsParams=RemoveRowsUndoMutationFactory(removeRowsParams,worksheet);redos.push({id:RemoveRowMutation.id,params:removeRowsParams}),undos.unshift({id:InsertRowMutation.id,params:undoRemoveRowsParams},{id:SetRangeValuesMutation.id,params:undoSetRangeValuesParams})});const intercepted=sheetInterceptorService.onCommandExecute({id:RemoveRowCommand.id,params:{range:totalRange,ranges}}),commandService=accessor.get(core.ICommandService);return core.sequenceExecute([...(_b=intercepted.preRedos)!=null?_b:[],...redos,...intercepted.redos,followSelectionOperation(totalRange,workbook,worksheet)],commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preUndos)!=null?_c:[],...undos,...intercepted.undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],...redos,...intercepted.redos]}),!0):!1},"handler")},RemoveColCommandId="sheet.command.remove-col",RemoveColCommand={type:core.CommandType.COMMAND,id:RemoveColCommandId,handler:__name(async(accessor,params)=>{var _a20,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);let range=params==null?void 0:params.range;if(range||(range=(_a20=selectionManagerService.getCurrentLastSelection())==null?void 0:_a20.range),!range)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,subUnitId,unitId}=target;range={...range,startRow:0,endRow:Math.max(worksheet.getMaxRows()-1,0)};const removeColParams={unitId,subUnitId,range},undoRemoveColParams=RemoveColMutationFactory(accessor,removeColParams),removedCols=worksheet.getCellMatrix().getSlice(0,worksheet.getRowCount()-1,range.startColumn,range.endColumn),undoSetRangeValuesParams={unitId,subUnitId,cellValue:removedCols.getMatrix()};if(!await sheetInterceptorService.beforeCommandExecute({id:RemoveColCommand.id,params:{range}}))return!1;const intercepted=sheetInterceptorService.onCommandExecute({id:RemoveColCommand.id,params:{range}}),commandService=accessor.get(core.ICommandService);return core.sequenceExecute([...(_b=intercepted.preRedos)!=null?_b:[],{id:RemoveColMutation.id,params:removeColParams},...intercepted.redos,followSelectionOperation(range,workbook,worksheet)],commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preUndos)!=null?_c:[],{id:InsertColMutation.id,params:undoRemoveColParams},{id:SetRangeValuesMutation.id,params:undoSetRangeValuesParams},...intercepted.undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:RemoveColMutation.id,params:removeColParams},...intercepted.redos]}),!0):!1},"handler")},RemoveSheetCommand={id:"sheet.command.remove-sheet",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a20,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{unitId,subUnitId,workbook,worksheet}=target;if(workbook.getSheets().length<=1)return!1;const RemoveSheetMutationParams={subUnitId,unitId,subUnitName:worksheet.getName()},InsertSheetMutationParams=RemoveSheetUndoMutationFactory(accessor,RemoveSheetMutationParams),intercepted=sheetInterceptorService.onCommandExecute({id:RemoveSheetCommand.id,params:{unitId,subUnitId}}),redos=[...(_a20=intercepted.preRedos)!=null?_a20:[],{id:RemoveSheetMutation.id,params:RemoveSheetMutationParams},...intercepted.redos],undos=[...(_b=intercepted.preUndos)!=null?_b:[],{id:InsertSheetMutation.id,params:InsertSheetMutationParams},...intercepted.undos];return core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},AddMergeUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"AddMergeUndoMutationFactory"),AddWorksheetMergeMutation={id:"sheet.mutation.add-worksheet-merge",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const mergeConfigData=worksheet.getConfig().mergeData,mergeAppendData=params.ranges;for(let i=0;i<mergeAppendData.length;i++)mergeConfigData.push(mergeAppendData[i]);return worksheet.getSpanModel().rebuild(mergeConfigData),!0},"handler")},RemoveMergeUndoMutationFactory=__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const mergeConfigData=worksheet.getConfig().mergeData,mergeRemoveData=params.ranges,ranges=[];for(let j=0;j<mergeRemoveData.length;j++)for(let i=mergeConfigData.length-1;i>=0;i--){const configMerge=mergeConfigData[i],removeMerge=mergeRemoveData[j];core.Rectangle.intersects(configMerge,removeMerge)&&ranges.push(mergeConfigData[i])}return{unitId:params.unitId,subUnitId:params.subUnitId,ranges}},"RemoveMergeUndoMutationFactory"),RemoveWorksheetMergeMutation={id:"sheet.mutation.remove-worksheet-merge",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const mergeConfigData=worksheet.getConfig().mergeData,mergeRemoveData=params.ranges;for(let j=0;j<mergeRemoveData.length;j++)for(let i=mergeConfigData.length-1;i>=0;i--){const configMerge=mergeConfigData[i],removeMerge=mergeRemoveData[j];core.Rectangle.intersects(configMerge,removeMerge)&&mergeConfigData.splice(i,1)}return worksheet.getSpanModel().rebuild(mergeConfigData),!0},"handler")},RemoveWorksheetMergeCommand={type:core.CommandType.COMMAND,id:"sheet.command.remove-worksheet-merge",handler:__name(async(accessor,params)=>{var _a20;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selections=(params==null?void 0:params.ranges)||((_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range));if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{subUnitId,unitId,worksheet}=target,removeMergeMutationParams={unitId,subUnitId,ranges:selections},intersectsMerges=worksheet.getConfig().mergeData.filter(merge=>selections.some(selection=>core.Rectangle.intersects(selection,merge)));if(!intersectsMerges.length)return!1;const undoredoMutationParams=RemoveMergeUndoMutationFactory(accessor,removeMergeMutationParams),nowSelections=selectionManagerService.getCurrentSelections();if(!(nowSelections!=null&&nowSelections.length))return!1;const undoSelections=core.Tools.deepClone(nowSelections),redoSelections=core.Tools.deepClone(nowSelections),redoLastSelection=redoSelections[redoSelections.length-1],{startRow,startColumn}=redoLastSelection.range;redoLastSelection.primary={startRow,startColumn,endRow:startRow,endColumn:startColumn,actualRow:startRow,actualColumn:startColumn,isMerged:!1,isMergedMainCell:!1};const getSetRangeValuesParams=getSetRangeStyleParamsForRemoveMerge(worksheet,intersectsMerges),redoSetRangeValueParams={unitId,subUnitId,cellValue:getSetRangeValuesParams.redoParams.getMatrix()},undoSetRangeValueParams={unitId,subUnitId,cellValue:getSetRangeValuesParams.undoParams.getMatrix()},redoMutations=[{id:RemoveWorksheetMergeMutation.id,params:undoredoMutationParams},{id:SetRangeValuesMutation.id,params:redoSetRangeValueParams},{id:SetSelectionsOperation.id,params:{selections:redoSelections}}],undoMutations=[{id:AddWorksheetMergeMutation.id,params:undoredoMutationParams},{id:SetRangeValuesMutation.id,params:undoSetRangeValueParams},{id:SetSelectionsOperation.id,params:{selections:undoSelections}}];return core.sequenceExecute(redoMutations,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations,redoMutations}),!0):!1},"handler")};function getSetRangeStyleParamsForRemoveMerge(worksheet,ranges){const styleRedoMatrix=new core.ObjectMatrix,styleUndoMatrix=new core.ObjectMatrix;return ranges.forEach(range=>{const{startRow,startColumn,endColumn,endRow}=range,cellValue=worksheet.getCellMatrix().getValue(startRow,startColumn);if(cellValue!=null&&cellValue.s)for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)(i!==startRow||j!==startColumn)&&(styleRedoMatrix.setValue(i,j,{s:cellValue.s}),styleUndoMatrix.setValue(i,j,null))}),{redoParams:styleRedoMatrix,undoParams:styleUndoMatrix}}__name(getSetRangeStyleParamsForRemoveMerge,"getSetRangeStyleParamsForRemoveMerge");const _BorderStyleManagerService=class _BorderStyleManagerService{constructor(){__publicField(this,"_borderInfo",{type:core.BorderType.ALL,color:"#000000",style:core.BorderStyleTypes.THIN,activeBorderType:!1});__publicField(this,"_borderInfo$",new rxjs.BehaviorSubject(this._borderInfo));__publicField(this,"borderInfo$",this._borderInfo$.asObservable())}dispose(){this._borderInfo$.complete()}setType(type){this._borderInfo.type=type,this.setActiveBorderType(!0),this.refresh()}setColor(color){this._borderInfo.color=color,this.refresh()}setStyle(style){this._borderInfo.style=style,this.refresh()}setActiveBorderType(status){this._borderInfo.activeBorderType=status}getBorderInfo(){return this._borderInfo}refresh(){this._borderInfo$.next(this._borderInfo)}};__name(_BorderStyleManagerService,"BorderStyleManagerService");let BorderStyleManagerService=_BorderStyleManagerService;function forEach(range,action){const{startRow,startColumn,endRow,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)action(i,j)}__name(forEach,"forEach");const SetBorderBasicCommand={id:"sheet.command.set-border-basic",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const{unitId,subUnitId,value}=params,{type,color,style}=value,commandService=accessor.get(core.ICommandService),borderManager=accessor.get(BorderStyleManagerService);return borderManager.setType(type),borderManager.setColor(color),borderManager.setStyle(style),commandService.executeCommand(SetBorderCommand.id,{unitId,subUnitId})},"handler")},SetBorderPositionCommand={id:"sheet.command.set-border-position",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params.value)return!1;const commandService=accessor.get(core.ICommandService);return accessor.get(BorderStyleManagerService).setType(params.value),commandService.executeCommand(SetBorderCommand.id)},"handler")},SetBorderStyleCommand={id:"sheet.command.set-border-style",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(BorderStyleManagerService).setStyle(params.value),commandService.executeCommand(SetBorderCommand.id)},"handler")},SetBorderColorCommand={id:"sheet.command.set-border-color",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(BorderStyleManagerService).setColor(params.value),commandService.executeCommand(SetBorderCommand.id)},"handler")},SetBorderCommand={id:"sheet.command.set-border",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a20;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),borderStyleManagerService=accessor.get(BorderStyleManagerService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,selections=(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const{style,color,type,activeBorderType}=borderStyleManagerService.getBorderInfo();if(!activeBorderType)return!1;const top=type===core.BorderType.TOP||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,left=type===core.BorderType.LEFT||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,bottom=type===core.BorderType.BOTTOM||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,right=type===core.BorderType.RIGHT||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,vertical=type===core.BorderType.VERTICAL||type===core.BorderType.ALL||type===core.BorderType.INSIDE,horizontal=type===core.BorderType.HORIZONTAL||type===core.BorderType.ALL||type===core.BorderType.INSIDE,tl_br=type.indexOf("tlbr")>-1,tl_bc=type.indexOf("tlbc")>-1,tl_mr=type.indexOf("tlmr")>-1,bl_tr=type.indexOf("bltr")>-1,ml_tr=type.indexOf("mltr")>-1,bc_tr=type.indexOf("bctr")>-1,range=selections[0],topRangeOut={startRow:range.startRow-1,startColumn:range.startColumn,endRow:range.startRow-1,endColumn:range.endColumn},leftRangeOut={startRow:range.startRow,startColumn:range.startColumn-1,endRow:range.endRow,endColumn:range.startColumn-1},bottomRangeOut={startRow:range.endRow+1,startColumn:range.startColumn,endRow:range.endRow+1,endColumn:range.endColumn},rightRangeOut={startRow:range.startRow,startColumn:range.endColumn+1,endRow:range.endRow,endColumn:range.endColumn+1},topRange={startRow:range.startRow,startColumn:range.startColumn,endRow:range.startRow,endColumn:range.endColumn},leftRange={startRow:range.startRow,startColumn:range.startColumn,endRow:range.endRow,endColumn:range.startColumn},bottomRange={startRow:range.endRow,startColumn:range.startColumn,endRow:range.endRow,endColumn:range.endColumn},rightRange={startRow:range.startRow,startColumn:range.endColumn,endRow:range.endRow,endColumn:range.endColumn},mr=new core.ObjectMatrix,border={s:style,cl:{rgb:color}};function setBorderStyle(range2,defaultStyle,reserve){range2.startRow<0||range2.startColumn<0||forEach(range2,(row,column)=>{var _a21,_b;const rectangle=worksheet.getMergedCell(row,column);let bdStyle=defaultStyle;if(rectangle&&(defaultStyle.bc_tr||defaultStyle.ml_tr||defaultStyle.bl_tr||defaultStyle.tl_mr||defaultStyle.tl_bc||defaultStyle.tl_br)){if(reserve){const style2=core.Tools.deepClone((_a21=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_a21.s);bdStyle=style2!=null&&style2.bd?Object.assign(style2.bd,defaultStyle):defaultStyle}mr.setValue(rectangle.startRow,rectangle.startColumn,{s:{bd:bdStyle}})}else{if(reserve){const style2=core.Tools.deepClone((_b=mr.getValue(row,column))==null?void 0:_b.s);bdStyle=style2!=null&&style2.bd?Object.assign(style2.bd,defaultStyle):defaultStyle}mr.setValue(row,column,{s:{bd:bdStyle}})}})}__name(setBorderStyle,"setBorderStyle"),top&&(setBorderStyle(topRangeOut,{b:null}),setBorderStyle(topRange,{t:core.Tools.deepClone(border)},!0)),bottom&&(setBorderStyle(bottomRangeOut,{t:null}),setBorderStyle(bottomRange,{b:core.Tools.deepClone(border)},!0)),left&&(setBorderStyle(leftRangeOut,{r:null}),setBorderStyle(leftRange,{l:core.Tools.deepClone(border)},!0)),right&&(setBorderStyle(rightRangeOut,{l:null}),setBorderStyle(rightRange,{r:core.Tools.deepClone(border)},!0)),tl_br&&setBorderStyle(range,{tl_br:core.Tools.deepClone(border)},!0),tl_bc&&setBorderStyle(range,{tl_bc:core.Tools.deepClone(border)},!0),tl_mr&&setBorderStyle(range,{tl_mr:core.Tools.deepClone(border)},!0),bl_tr&&setBorderStyle(range,{bl_tr:core.Tools.deepClone(border)},!0),ml_tr&&setBorderStyle(range,{ml_tr:core.Tools.deepClone(border)},!0),bc_tr&&setBorderStyle(range,{bc_tr:core.Tools.deepClone(border)},!0),vertical&&forEach(range,(row,column)=>{var _a21,_b,_c,_d;const rectangle=worksheet.getMergedCell(row,column);if(rectangle){if(rectangle.endColumn!==range.endColumn){const style2=(_a21=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_a21.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{r:core.Tools.deepClone(border)}):{r:core.Tools.deepClone(border)}}})}if(rectangle.startColumn!==range.startColumn){const style2=(_b=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_b.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{l:core.Tools.deepClone(border)}):{l:core.Tools.deepClone(border)}}})}}else{if(column!==range.endColumn){const style2=(_c=mr.getValue(row,column))==null?void 0:_c.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{r:core.Tools.deepClone(border)}):{r:core.Tools.deepClone(border)}}})}if(column!==range.startColumn){const style2=(_d=mr.getValue(row,column))==null?void 0:_d.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{l:core.Tools.deepClone(border)}):{l:core.Tools.deepClone(border)}}})}}}),horizontal&&forEach(range,(row,column)=>{var _a21,_b,_c,_d;const rectangle=worksheet.getMergedCell(row,column);if(rectangle){if(rectangle.endRow!==range.endRow){const style2=(_a21=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_a21.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{b:core.Tools.deepClone(border)}):{b:core.Tools.deepClone(border)}}})}if(rectangle.startRow!==range.startRow){const style2=(_b=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_b.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{t:core.Tools.deepClone(border)}):{t:core.Tools.deepClone(border)}}})}}else{if(row!==range.endRow){const style2=(_c=mr.getValue(row,column))==null?void 0:_c.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{b:core.Tools.deepClone(border)}):{b:core.Tools.deepClone(border)}}})}if(row!==range.startRow){const style2=(_d=mr.getValue(row,column))==null?void 0:_d.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{t:core.Tools.deepClone(border)}):{t:core.Tools.deepClone(border)}}})}}}),!top&&!bottom&&!left&&!right&&!vertical&&!horizontal&&!tl_br&&!tl_bc&&!tl_mr&&!bl_tr&&!ml_tr&&!bc_tr&&(setBorderStyle(topRangeOut,{b:null}),setBorderStyle(topRange,{t:null},!0),setBorderStyle(bottomRangeOut,{t:null}),setBorderStyle(bottomRange,{b:null},!0),setBorderStyle(leftRangeOut,{r:null}),setBorderStyle(leftRange,{l:null},!0),setBorderStyle(rightRangeOut,{l:null}),setBorderStyle(rightRange,{r:null},!0),setBorderStyle(range,{tl_br:null},!0),setBorderStyle(range,{tl_bc:null},!0),setBorderStyle(range,{tl_mr:null},!0),setBorderStyle(range,{bl_tr:null},!0),setBorderStyle(range,{ml_tr:null},!0),setBorderStyle(range,{bc_tr:null},!0),forEach(range,(row,column)=>{var _a21,_b,_c,_d,_e,_f,_g,_h;const rectangle=worksheet.getMergedCell(row,column);if(rectangle){if(rectangle.endColumn!==range.endColumn){const style2=(_a21=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_a21.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{r:null}):{r:null}}})}if(rectangle.startColumn!==range.startColumn){const style2=(_b=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_b.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{l:null}):{l:null}}})}if(rectangle.endRow!==range.endRow){const style2=(_c=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_c.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{b:null}):{b:null}}})}if(rectangle.startRow!==range.startRow){const style2=(_d=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_d.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{t:null}):{t:null}}})}}else{if(column!==range.endColumn){const style2=(_e=mr.getValue(row,column))==null?void 0:_e.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{r:null}):{r:null}}})}if(column!==range.startColumn){const style2=(_f=mr.getValue(row,column))==null?void 0:_f.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{l:null}):{l:null}}})}if(row!==range.endRow){const style2=(_g=mr.getValue(row,column))==null?void 0:_g.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{b:null}):{b:null}}})}if(row!==range.startRow){const style2=(_h=mr.getValue(row,column))==null?void 0:_h.s;mr.setValue(row,column,{s:{bd:style2!=null&&style2.bd?Object.assign(style2.bd,{t:null}):{t:null}}})}}}));const setRangeValuesMutationParams={unitId,subUnitId,cellValue:mr.getData()},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams);return commandService.syncExecuteCommand(SetRangeValuesMutation.id,setRangeValuesMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams}],redoMutations:[{id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams}]}),!0):!1},"handler")},SetColHiddenUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetColHiddenUndoMutationFactory"),SetColHiddenMutation={id:"sheet.mutation.set-col-hidden",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!universheet)return!1;const manager=universheet.getSheetBySheetId(params.subUnitId).getColumnManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);column!=null&&(column.hd=core.BooleanNumber.TRUE)}}return!0},"handler")},SetColVisibleUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetColVisibleUndoMutationFactory"),SetColVisibleMutation={id:"sheet.mutation.set-col-visible",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!universheet)return!1;const manager=universheet.getSheetBySheetId(params.subUnitId).getColumnManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);column!=null&&(column.hd=core.BooleanNumber.FALSE)}}return!0},"handler")},SetSpecificColsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-col-visible-on-cols",handler:__name(async(accessor,params)=>{var _a20,_b;const{unitId,subUnitId,ranges}=params,sheetInterceptorService=accessor.get(exports.SheetInterceptorService),commandService=accessor.get(core.ICommandService),instanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(instanceService,{unitId,subUnitId});if(!target)return!1;const{worksheet}=target,redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(r=>({range:r,primary:getPrimaryForRange(r,worksheet),style:null}))},undoMutationParams=SetColVisibleUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding$1(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},result=core.sequenceExecute([{id:SetColVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetSpecificColsVisibleCommand.id,params}),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result&&accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[{id:SetColHiddenMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_a20=intercepted.undos)!=null?_a20:[]],redoMutations:[...(_b=intercepted.preRedos)!=null?_b:[],{id:SetColVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0},"handler")},SetSelectedColsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-selected-cols-visible",handler:__name(async accessor=>{var _a20;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),ranges=(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.COLUMN);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,unitId,subUnitId}=target,hiddenRanges=ranges.map(r=>worksheet.getHiddenCols(r.startColumn,r.endColumn)).flat();return commandService.executeCommand(SetSpecificColsVisibleCommand.id,{unitId,subUnitId,ranges:hiddenRanges})},"handler")},SetColHiddenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-col-hidden",handler:__name(async(accessor,params)=>{var _a20,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService);let ranges=(_a20=params==null?void 0:params.ranges)!=null&&_a20.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.COLUMN);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;ranges=divideRangesByHiddenCols(target.worksheet,ranges);const redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding$1(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},undoMutationParams=SetColHiddenUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},result=core.sequenceExecute([{id:SetColHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetColHiddenCommand.id,params:redoMutationParams}),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[{id:SetColVisibleMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_c=intercepted.undos)!=null?_c:[]],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:SetColHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0):!1},"handler")};function divideRangesByHiddenCols(worksheet,ranges){const endRow=worksheet.getRowCount()-1,hiddenCols=worksheet.getHiddenCols(),divided=[];return ranges.forEach(range=>{const hiddenColsInSelection=hiddenCols.filter(c=>c.startColumn>=range.startColumn&&c.endColumn<=range.endColumn);if(hiddenColsInSelection.length){let startColumn=range.startColumn;hiddenColsInSelection.forEach(hiddenRange=>{hiddenRange.startColumn>startColumn&&(divided.push({startColumn,endColumn:hiddenRange.startColumn-1,startRow:0,endRow}),startColumn=hiddenRange.endColumn+1)}),startColumn<=range.endColumn&÷d.push({startColumn,endColumn:range.endColumn,startRow:0,endRow})}else divided.push(range)}),divided}__name(divideRangesByHiddenCols,"divideRangesByHiddenCols");function getSelectionsAfterHiding$1(ranges){return mergeSelections$1(ranges).map(range=>{const column=range.startColumn===0?range.endColumn+1:range.startColumn-1;return{...range,startColumn:column,endColumn:column}})}__name(getSelectionsAfterHiding$1,"getSelectionsAfterHiding$1");function mergeSelections$1(ranges){const merged=[];let current;return ranges.sort((a,b)=>a.startColumn-b.startColumn).forEach(range=>{if(!current){current=range;return}current.endColumn===range.startColumn-1?current.endColumn=range.endColumn:(merged.push(current),current=range)}),merged.push(current),merged}__name(mergeSelections$1,"mergeSelections$1");const SetFrozenMutationFactory=__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const freeze=worksheet.getConfig().freeze;return{unitId:params.unitId,subUnitId:params.subUnitId,...freeze}},"SetFrozenMutationFactory"),SetFrozenMutation={id:"sheet.mutation.set-frozen",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const config=worksheet.getConfig(),{startRow,startColumn,ySplit,xSplit}=params;return config.freeze={startRow,startColumn,ySplit,xSplit},!0},"handler")},SetFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-frozen",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,{startColumn,startRow,xSplit,ySplit}=params;if(startRow>=worksheet.getRowCount()||startColumn>=worksheet.getColumnCount()||xSplit>=worksheet.getColumnCount()||ySplit>=worksheet.getRowCount())return!1;const redoMutationParams={unitId,subUnitId,...params},undoMutationParams=SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(SetFrozenMutation.id,redoMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:SetFrozenMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},SetFrozenCancelCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-frozen-cancel",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target,redoMutationParams={unitId,subUnitId,startRow:-1,startColumn:-1,ySplit:0,xSplit:0},undoMutationParams=SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(SetFrozenMutation.id,redoMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:SetFrozenMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},SetRowVisibleUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetRowVisibleUndoMutationFactory"),SetRowVisibleMutation={id:"sheet.mutation.set-row-visible",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const manager=universheet.getSheetBySheetId(params.subUnitId).getRowManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startRow;j<range.endRow+1;j++){const row=manager.getRowOrCreate(j);row!=null&&(row.hd=0)}}return!0},"handler")},SetRowHiddenUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetRowHiddenUndoMutationFactory"),SetRowHiddenMutation={id:"sheet.mutation.set-row-hidden",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const manager=universheet.getSheetBySheetId(params.subUnitId).getRowManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startRow;j<range.endRow+1;j++){const row=manager.getRowOrCreate(j);row!=null&&(row.hd=1)}}return!0},"handler")},SetSpecificRowsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-specific-rows-visible",handler:__name(async(accessor,params)=>{var _a20,_b,_c;const{unitId,subUnitId,ranges}=params,commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),{unitId,subUnitId});if(!target)return!1;const{worksheet}=target,redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},undoMutationParams=SetRowVisibleUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},result=core.sequenceExecute([{id:SetRowVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetSpecificRowsVisibleCommand.id,params}),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_a20=intercepted.preUndos)!=null?_a20:[],{id:SetRowHiddenMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_b=intercepted.undos)!=null?_b:[]],redoMutations:[...(_c=intercepted.preRedos)!=null?_c:[],{id:SetRowVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0},"handler")},SetSelectedRowsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-selected-rows-visible",handler:__name(async accessor=>{var _a20;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),ranges=(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.ROW);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,hiddenRanges=ranges.map(r=>worksheet.getHiddenRows(r.startRow,r.endRow)).flat();return commandService.executeCommand(SetSpecificRowsVisibleCommand.id,{unitId,subUnitId,ranges:hiddenRanges})},"handler")},SetRowHiddenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-rows-hidden",handler:__name(async(accessor,params)=>{var _a20,_b,_c,_d,_e,_f;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);let ranges=(_a20=params==null?void 0:params.ranges)!=null&&_a20.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.ROW);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;ranges=divideRangesByHiddenRows(target.worksheet,ranges);const{unitId,subUnitId,worksheet}=target,redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},undoMutationParams=SetRowHiddenUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},intercepted=sheetInterceptorService.onCommandExecute({id:SetRowHiddenCommand.id,params:redoMutationParams});return core.sequenceExecute([...(_c=intercepted.preRedos)!=null?_c:[],{id:SetRowHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos],commandService).result&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_d=intercepted.preUndos)!=null?_d:[],{id:SetRowVisibleMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_e=intercepted.undos)!=null?_e:[]],redoMutations:[...(_f=intercepted.preRedos)!=null?_f:[],{id:SetRowHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0},"handler")};function divideRangesByHiddenRows(worksheet,ranges){const endCol=worksheet.getMaxColumns()-1,hiddenRows=worksheet.getHiddenRows(),divided=[];return ranges.forEach(range=>{const hiddenRowsInThisRange=hiddenRows.filter(r=>r.startRow>=range.startRow&&r.endRow<=range.endRow);if(hiddenRowsInThisRange.length){let startRow=range.startRow;hiddenRowsInThisRange.forEach(hiddenRange=>{hiddenRange.startRow>startRow&&(divided.push({startRow,endRow:hiddenRange.startRow-1,startColumn:0,endColumn:endCol}),startRow=hiddenRange.endRow+1)}),startRow<=range.endRow&÷d.push({startRow,endRow:range.endRow,startColumn:0,endColumn:endCol})}else divided.push(range)}),divided}__name(divideRangesByHiddenRows,"divideRangesByHiddenRows");function getSelectionsAfterHiding(ranges){return mergeSelections(ranges).map(range=>{const row=range.startRow===0?range.endRow+1:range.startRow-1;return{...range,startRow:row,endRow:row}})}__name(getSelectionsAfterHiding,"getSelectionsAfterHiding");function mergeSelections(ranges){const merged=[];let current;return ranges.sort((a,b)=>a.startRow-b.startRow).forEach(range=>{if(!current){current=range;return}range.startRow===current.endRow+1?current.endRow=range.endRow:(merged.push(current),current=range)}),merged.push(current),merged}__name(mergeSelections,"mergeSelections");const SetStyleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-style",handler:__name(async(accessor,params)=>{var _a20;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,{range,style}=params,commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),ranges=range?[range]:(_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const cellValue=new core.ObjectMatrix,iterator=createRangeIteratorWithSkipFilteredRows(worksheet);if(core.Tools.isArray(style.value))for(let i=0;i<ranges.length;i++)iterator.forOperableEach(ranges[i],(r,c,range2)=>{cellValue.setValue(r,c,{s:{[style.type]:style.value[r-range2.startRow][c-range2.startColumn]}})});else for(let i=0;i<ranges.length;i++){const styleObj={s:{[style.type]:style.value}};iterator.forOperableEach(ranges[i],(r,c)=>cellValue.setValue(r,c,styleObj))}const setRangeValuesMutationParams={subUnitId,unitId,cellValue:cellValue.getMatrix()},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams),setRangeValuesResult=commandService.syncExecuteCommand(SetRangeValuesMutation.id,setRangeValuesMutationParams),{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetStyleCommand.id,params}),result=core.sequenceExecute([...redos],commandService);return setRangeValuesResult&&result.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams},...undos],redoMutations:[{id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...redos]}),!0):!1},"handler")},SetBoldCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-bold",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target,{actualRow,actualColumn}=selection.primary,setStyleParams={style:{type:"bl",value:worksheet.getRange(actualRow,actualColumn).getFontWeight()===core.FontWeight.BOLD?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetItalicCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-italic",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyItalic=!0;if(selection.primary){const{startRow,startColumn}=selection.primary;currentlyItalic=worksheet.getRange(startRow,startColumn).getFontStyle()===core.FontItalic.ITALIC}const setStyleParams={style:{type:"it",value:currentlyItalic?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetUnderlineCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-underline",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyUnderline=!0;selection.primary&&(currentlyUnderline=!!worksheet.getRange(selection.primary.startRow,selection.primary.startColumn).getUnderline().s);const setStyleParams={style:{type:"ul",value:{s:currentlyUnderline?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetStrikeThroughCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-stroke",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyStrokeThrough=!0;selection.primary&&(currentlyStrokeThrough=!!worksheet.getRange(selection.primary.actualRow,selection.primary.actualColumn).getStrikeThrough().s);const setStyleParams={style:{type:"st",value:{s:currentlyStrokeThrough?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetOverlineCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-overline",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyOverline=!0;selection.primary&&(currentlyOverline=!!worksheet.getRange(selection.primary.startRow,selection.primary.startColumn).getOverline().s);const setStyleParams={style:{type:"ol",value:{s:currentlyOverline?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetFontFamilyCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-font-family",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"ff",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetFontSizeCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-font-size",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"fs",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTextColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-text-color",handler:__name(async(accessor,params)=>{if(!params||!params.value)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"cl",value:{rgb:params.value}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},ResetTextColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.reset-text-color",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"cl",value:{rgb:null}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetBackgroundColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-background-color",handler:__name(async(accessor,params)=>{if(!params||!params.value)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"bg",value:{rgb:params.value}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},ResetBackgroundColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.reset-background-color",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"bg",value:{rgb:null}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetVerticalTextAlignCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-vertical-text-align",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,style:{type:"vt",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetHorizontalTextAlignCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-horizontal-text-align",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,style:{type:"ht",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTextWrapCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-text-wrap",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,style:{type:"tb",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTextRotationCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-text-rotation",handler:__name(async(accessor,params)=>{if(!params)return!1;const value=typeof params.value=="number"?{a:params.value}:{a:0,v:core.BooleanNumber.TRUE},commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"tr",value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTabColorUndoMutationFactory=__name((accessor,params)=>{const oldTabColor=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId).getSheetBySheetId(params.subUnitId).getConfig().tabColor;return{...core.Tools.deepClone(params),color:oldTabColor}},"SetTabColorUndoMutationFactory"),SetTabColorMutation={id:"sheet.mutation.set-tab-color",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(params.subUnitId);return worksheet?(worksheet.getConfig().tabColor=params.color,!0):!1},"handler")},SetTabColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-tab-color",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{unitId,subUnitId}=target,setTabColorMutationParams={color:params.value,unitId,subUnitId},undoMutationParams=SetTabColorUndoMutationFactory(accessor,setTabColorMutationParams);return commandService.syncExecuteCommand(SetTabColorMutation.id,setTabColorMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetTabColorMutation.id,params:undoMutationParams}],redoMutations:[{id:SetTabColorMutation.id,params:setTabColorMutationParams}]}),!0):!1},"handler")},SetWorksheetActiveOperation={id:"sheet.operation.set-worksheet-active",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheets=workbook.getWorksheets();for(const[,worksheet]of worksheets)if(worksheet.getSheetId()===params.subUnitId)return workbook.setActiveSheet(worksheet),!0;return!1},"handler")},SET_WORKSHEET_ACTIVE_DELAY=4,SetWorksheetActivateCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-activate",handler:__name((accessor,params,options)=>{const commandService=accessor.get(core.ICommandService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{unitId,subUnitId}=target;return new Promise(resolve=>{setTimeout(()=>{const result=commandService.syncExecuteCommand(SetWorksheetActiveOperation.id,{unitId,subUnitId},options);resolve(result)},SET_WORKSHEET_ACTIVE_DELAY)})},"handler")},SetWorksheetColWidthMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,ranges}=params,colWidth={},manager=worksheet.getColumnManager();for(let i=0;i<ranges.length;i++){const range=ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);colWidth[j]=column.w}}return{unitId,subUnitId,ranges,colWidth}},"SetWorksheetColWidthMutationFactory"),SetWorksheetColWidthMutation={id:"sheet.mutation.set-worksheet-col-width",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a20;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{worksheet}=target,defaultColumnWidth=worksheet.getConfig().defaultColumnWidth,manager=worksheet.getColumnManager(),ranges=params.ranges;for(let i=0;i<ranges.length;i++){const range=ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);typeof params.colWidth=="number"?column.w=params.colWidth:column.w=(_a20=params.colWidth[j])!=null?_a20:defaultColumnWidth}}return!0},"handler")},DeltaColumnWidthCommand={type:core.CommandType.COMMAND,id:"sheet.command.delta-column-width",handler:__name(async(accessor,params)=>{const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections();if(!(selections!=null&&selections.length))return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,unitId,subUnitId}=target,{anchorCol,deltaX}=params,destColumnWidth=worksheet.getColumnWidth(anchorCol)+deltaX,isAllSheetRange=selections.length===1&&selections[0].range.rangeType===core.RANGE_TYPE.ALL,colSelections=selections.filter(s=>s.range.rangeType===core.RANGE_TYPE.COLUMN),rangeType=isAllSheetRange?core.RANGE_TYPE.ALL:colSelections.some(({range})=>{const{startColumn,endColumn}=range;return startColumn<=anchorCol&&anchorCol<=endColumn})?core.RANGE_TYPE.COLUMN:core.RANGE_TYPE.NORMAL;let redoMutationParams;if(rangeType===core.RANGE_TYPE.ALL){const rowCount=worksheet.getRowCount(),allColRanges=new Array(worksheet.getColumnCount()).fill(void 0).map((_,index)=>({startRow:0,endRow:rowCount-1,startColumn:index,endColumn:index}));redoMutationParams={subUnitId,unitId,colWidth:destColumnWidth,ranges:allColRanges}}else rangeType===core.RANGE_TYPE.COLUMN?redoMutationParams={subUnitId,unitId,ranges:colSelections.map(s=>core.Rectangle.clone(s.range)),colWidth:destColumnWidth}:redoMutationParams={subUnitId,unitId,colWidth:destColumnWidth,ranges:[{startRow:0,endRow:worksheet.getMaxRows()-1,startColumn:anchorCol,endColumn:anchorCol}]};const{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:DeltaColumnWidthCommand.id,params:redoMutationParams}),undoMutationParams=SetWorksheetColWidthMutationFactory(redoMutationParams,worksheet),setColWidthResult=commandService.syncExecuteCommand(SetWorksheetColWidthMutation.id,redoMutationParams),result=core.sequenceExecute([...redos],commandService);return setColWidthResult&&result.result&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetColWidthMutation.id,params:undoMutationParams},...undos],redoMutations:[{id:SetWorksheetColWidthMutation.id,params:redoMutationParams},...redos]}),!0},"handler")},SetColWidthCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-col-width",handler:__name(async(accessor,params)=>{var _a20,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),selections=(_a20=params==null?void 0:params.ranges)!=null&&_a20.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{subUnitId,unitId,worksheet}=target,redoMutationParams={subUnitId,unitId,ranges:selections,colWidth:params.value},undoMutationParams=SetWorksheetColWidthMutationFactory(redoMutationParams,worksheet),setColWidthResult=commandService.syncExecuteCommand(SetWorksheetColWidthMutation.id,redoMutationParams),{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetColWidthCommand.id,params:redoMutationParams}),intercepted=sheetInterceptorService.onCommandExecute({id:SetColWidthCommand.id,params:redoMutationParams}),result=core.sequenceExecute([...redos,...intercepted.redos],commandService);return setColWidthResult&&result.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preUndos)!=null?_c:[],{id:SetWorksheetColWidthMutation.id,params:undoMutationParams},...undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:SetWorksheetColWidthMutation.id,params:redoMutationParams},...redos]}),!0):!1},"handler")},SetWorksheetHideMutationFactory=__name((accessor,params)=>{const target=getSheetMutationTarget(accessor.get(core.IUniverInstanceService),params);if(!target)throw new Error("[SetWorksheetHideMutationFactory]: worksheet is null error!");const{worksheet}=target;return{hidden:worksheet.isSheetHidden(),unitId:params.unitId,subUnitId:worksheet.getSheetId()}},"SetWorksheetHideMutationFactory"),SetWorksheetHideMutation={id:"sheet.mutation.set-worksheet-hidden",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)return!1;const worksheet=universheet.getSheetBySheetId(params.subUnitId);return worksheet?(worksheet.getConfig().hidden=params.hidden,!0):!1},"handler")},SetWorksheetHideCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-hidden",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{workbook,worksheet,unitId,subUnitId}=target;if(worksheet.getConfig().hidden===core.BooleanNumber.TRUE)return!1;const redoMutationParams={unitId,subUnitId,hidden:core.BooleanNumber.TRUE},undoMutationParams=SetWorksheetHideMutationFactory(accessor,redoMutationParams);return workbook.getSheets().filter(sheet=>sheet.getConfig().hidden===core.BooleanNumber.FALSE).length===1?(errorService.emit(localeService.t("sheets.info.hideSheet")),!1):commandService.syncExecuteCommand(SetWorksheetHideMutation.id,redoMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetHideMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetHideMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},SetWorksheetNameMutationFactory=__name((accessor,params)=>{const target=getSheetMutationTarget(accessor.get(core.IUniverInstanceService),params);if(!target)throw new Error("[SetWorksheetNameMutationFactory]: worksheet is null error!");const{worksheet}=target;return{unitId:params.unitId,name:worksheet.getName(),subUnitId:worksheet.getSheetId()}},"SetWorksheetNameMutationFactory"),SetWorksheetNameMutation={id:"sheet.mutation.set-worksheet-name",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)return!1;const worksheet=universheet.getSheetBySheetId(params.subUnitId);return worksheet?(worksheet.getConfig().name=params.name,!0):!1},"handler")},SetWorksheetNameCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-name",handler:__name(async(accessor,params)=>{var _a20,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{unitId,subUnitId}=target,redoMutationParams={subUnitId,name:params.name,unitId},undoMutationParams=SetWorksheetNameMutationFactory(accessor,redoMutationParams),interceptorCommands=sheetInterceptorService.onCommandExecute({id:SetWorksheetNameCommand.id,params}),redos=[...(_a20=interceptorCommands.preRedos)!=null?_a20:[],{id:SetWorksheetNameMutation.id,params:redoMutationParams},...interceptorCommands.redos],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],{id:SetWorksheetNameMutation.id,params:undoMutationParams},...interceptorCommands.undos];return await core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},SetWorksheetOrderUndoMutationFactory=__name((accessor,params)=>({...core.Tools.deepClone(params),toOrder:params.fromOrder,fromOrder:params.toOrder}),"SetWorksheetOrderUndoMutationFactory"),SetWorksheetOrderMutation={id:"sheet.mutation.set-worksheet-order",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const config=workbook.getConfig();return config.sheetOrder.splice(params.fromOrder,1),config.sheetOrder.splice(params.toOrder,0,params.subUnitId),!0},"handler")},SetWorksheetOrderCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-order",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{workbook,unitId,subUnitId}=target,setWorksheetOrderMutationParams={fromOrder:workbook.getConfig().sheetOrder.indexOf(subUnitId),toOrder:params.order,unitId,subUnitId},undoMutationParams=SetWorksheetOrderUndoMutationFactory(accessor,setWorksheetOrderMutationParams);return commandService.syncExecuteCommand(SetWorksheetOrderMutation.id,setWorksheetOrderMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetOrderMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetOrderMutation.id,params:setWorksheetOrderMutationParams}]}),!0):!1},"handler")},MAXIMUM_ROW_HEIGHT=2e3,SetWorksheetRowHeightMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,ranges}=params,rowHeight={},manager=worksheet.getRowManager();for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<endRow+1;rowIndex++){const row=manager.getRowOrCreate(rowIndex);rowHeight[rowIndex]=row.h}return{unitId,subUnitId,ranges,rowHeight}},"SetWorksheetRowHeightMutationFactory"),SetWorksheetRowIsAutoHeightMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,ranges}=params,autoHeightHash={},manager=worksheet.getRowManager();for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<=endRow;rowIndex++){const row=manager.getRowOrCreate(rowIndex);autoHeightHash[rowIndex]=row.ia}return{unitId,subUnitId,ranges,autoHeightInfo:autoHeightHash}},"SetWorksheetRowIsAutoHeightMutationFactory"),SetWorksheetRowAutoHeightMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,rowsAutoHeightInfo}=params,results=[],manager=worksheet.getRowManager();for(const rowInfo of rowsAutoHeightInfo){const{row}=rowInfo,{ah}=manager.getRowOrCreate(row);results.push({row,autoHeight:ah})}return{unitId,subUnitId,rowsAutoHeightInfo:results}},"SetWorksheetRowAutoHeightMutationFactory"),SetWorksheetRowHeightMutation={id:"sheet.mutation.set-worksheet-row-height",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a20;const{ranges,rowHeight}=params,univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{worksheet}=target,manager=worksheet.getRowManager(),defaultRowHeight=worksheet.getConfig().defaultRowHeight;for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<=endRow;rowIndex++){const row=manager.getRowOrCreate(rowIndex);typeof rowHeight=="number"?row.h=rowHeight:row.h=(_a20=rowHeight[rowIndex])!=null?_a20:defaultRowHeight,row.h=Math.min(MAXIMUM_ROW_HEIGHT,row.h)}return!0},"handler")},SetWorksheetRowIsAutoHeightMutation={id:"sheet.mutation.set-worksheet-row-is-auto-height",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a20;const{ranges,autoHeightInfo}=params,univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const manager=target.worksheet.getRowManager();for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<=endRow;rowIndex++){const row=manager.getRowOrCreate(rowIndex);typeof autoHeightInfo=="number"?row.ia=autoHeightInfo:row.ia=(_a20=autoHeightInfo[rowIndex])!=null?_a20:void 0}return!0},"handler")},SetWorksheetRowAutoHeightMutation={id:"sheet.mutation.set-worksheet-row-auto-height",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{rowsAutoHeightInfo}=params,univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const rowManager=target.worksheet.getRowManager();for(const{row,autoHeight}of rowsAutoHeightInfo){const curRow=rowManager.getRowOrCreate(row);curRow.ah=autoHeight}return!0},"handler")},DeltaRowHeightCommand={type:core.CommandType.COMMAND,id:"sheet.command.delta-row-height",handler:__name(async(accessor,params)=>{var _a20,_b;const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections(),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,subUnitId,unitId}=target,{anchorRow,deltaY}=params,destRowHeight=worksheet.getRowHeight(anchorRow)+deltaY,isAllSheetRange=selections.length===1&&selections[0].range.rangeType===core.RANGE_TYPE.ALL,rowSelections=selections.filter(s=>s.range.rangeType===core.RANGE_TYPE.ROW),rangeType=isAllSheetRange?core.RANGE_TYPE.ALL:rowSelections.some(({range})=>{const{startRow,endRow}=range;return startRow<=anchorRow&&anchorRow<=endRow})?core.RANGE_TYPE.ROW:core.RANGE_TYPE.NORMAL;let redoMutationParams;if(rangeType===core.RANGE_TYPE.ALL){const colCount=worksheet.getRowCount(),allRowRanges=new Array(worksheet.getColumnCount()).fill(void 0).map((_,index)=>({startRow:index,endRow:index,startColumn:0,endColumn:colCount-1}));redoMutationParams={subUnitId,unitId,rowHeight:destRowHeight,ranges:allRowRanges}}else rangeType===core.RANGE_TYPE.ROW?redoMutationParams={subUnitId,unitId,ranges:rowSelections.map(s=>core.Rectangle.clone(s.range)),rowHeight:destRowHeight}:redoMutationParams={subUnitId,unitId,rowHeight:destRowHeight,ranges:[{startRow:anchorRow,endRow:anchorRow,startColumn:0,endColumn:worksheet.getMaxColumns()-1}]};const undoMutationParams=SetWorksheetRowHeightMutationFactory(redoMutationParams,worksheet),redoSetIsAutoHeightParams={unitId,subUnitId,ranges:redoMutationParams.ranges,autoHeightInfo:core.BooleanNumber.FALSE},undoSetIsAutoHeightParams=SetWorksheetRowIsAutoHeightMutationFactory(redoSetIsAutoHeightParams,worksheet),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),intercepted=sheetInterceptorService.onCommandExecute({id:DeltaRowHeightCommand.id,params:redoMutationParams}),result=core.sequenceExecute([{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams}],commandService),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_a20=intercepted.preUndos)!=null?_a20:[],{id:SetWorksheetRowHeightMutation.id,params:undoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:undoSetIsAutoHeightParams},...intercepted.undos],redoMutations:[...(_b=intercepted.preRedos)!=null?_b:[],{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams},...intercepted.redos]}),!0):!1},"handler")},SetRowHeightCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-row-height",handler:__name((accessor,params)=>{var _a20,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),selections=(_a20=params==null?void 0:params.ranges)!=null&&_a20.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,redoMutationParams={subUnitId,unitId,ranges:selections,rowHeight:params.value},undoMutationParams=SetWorksheetRowHeightMutationFactory(redoMutationParams,worksheet),redoSetIsAutoHeightParams={unitId,subUnitId,ranges:redoMutationParams.ranges,autoHeightInfo:core.BooleanNumber.FALSE},undoSetIsAutoHeightParams=SetWorksheetRowIsAutoHeightMutationFactory(redoSetIsAutoHeightParams,worksheet),result=core.sequenceExecute([{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetRowHeightCommand.id,params:redoMutationParams}),sheetInterceptorResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&sheetInterceptorResult.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preRedos)!=null?_c:[],{id:SetWorksheetRowHeightMutation.id,params:undoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:undoSetIsAutoHeightParams},...intercepted.undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams},...intercepted.redos]}),!0):!1},"handler")},SetWorksheetRowIsAutoHeightCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-row-is-auto-height",handler:__name(async(accessor,params)=>{var _a20,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,ranges=(_a20=params==null?void 0:params.ranges)!=null&&_a20.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const redoMutationParams={unitId,subUnitId,ranges,autoHeightInfo:core.BooleanNumber.TRUE},undoMutationParams=SetWorksheetRowIsAutoHeightMutationFactory(redoMutationParams,worksheet),setIsAutoHeightResult=commandService.syncExecuteCommand(SetWorksheetRowIsAutoHeightMutation.id,redoMutationParams),{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetWorksheetRowIsAutoHeightCommand.id,params:redoMutationParams}),result=core.sequenceExecute([...redos],commandService);return setIsAutoHeightResult&&result.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetRowIsAutoHeightMutation.id,params:undoMutationParams},...undos],redoMutations:[{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoMutationParams},...redos]}),!0):!1},"handler")},SetWorksheetShowCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-show",handler:__name(async(accessor,params)=>{const{unitId,subUnitId}=params,commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService);if(!getSheetCommandTarget(accessor.get(core.IUniverInstanceService)))return!1;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet||worksheet.getConfig().hidden===core.BooleanNumber.FALSE)return!1;const redoMutationParams={unitId,subUnitId,hidden:core.BooleanNumber.FALSE},undoMutationParams=SetWorksheetHideMutationFactory(accessor,redoMutationParams),result=commandService.syncExecuteCommand(SetWorksheetHideMutation.id,redoMutationParams),activeSheetMutationParams={unitId,subUnitId},activeResult=commandService.syncExecuteCommand(SetWorksheetActiveOperation.id,activeSheetMutationParams);return result&&activeResult?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetHideMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetHideMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},createTopMatrixFromRanges=__name(ranges=>{const matrix=new core.ObjectMatrix;return ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{matrix.setValue(row,col,1)})}),matrix.forValue((row,col)=>{const theLastRowValue=matrix.getValue(row-1,col);theLastRowValue&&matrix.setValue(row,col,theLastRowValue+1)}),matrix},"createTopMatrixFromRanges"),createTopMatrixFromMatrix=__name(matrix=>{const _matrix=matrix;return _matrix.forValue((row,col)=>{const theLastRowValue=matrix.getValue(row-1,col);theLastRowValue&&_matrix.setValue(row,col,theLastRowValue+1)}),_matrix},"createTopMatrixFromMatrix"),findMaximalRectangle=__name(topMatrix=>{const res={area:0},checkArea=__name((area,range)=>res.area<area?(res.area=area,res.range=range,!0):!1,"checkArea");return topMatrix.forValue((row,col,lineArea)=>{let cols=1,rows=lineArea;checkArea(cols*rows,{startRow:row-rows+1,endRow:row,startColumn:col,endColumn:col});const _range={startRow:row-rows+1,endRow:row,startColumn:0,endColumn:col};for(let k=col-1;k>=0&&topMatrix.getValue(row,k);k--){rows=Math.min(topMatrix.getValue(row,k)||0,rows),cols++;const area=rows*cols;_range.startColumn=k,_range.startRow=row-rows+1,checkArea(area,_range)}}),res},"findMaximalRectangle"),filterLeftMatrix=__name((topMatrix,range)=>{core.Range.foreach(range,(row,col)=>{topMatrix.realDeleteValue(row,col)});for(let col=range.startColumn;col<=range.endColumn;col++){const row=range.endRow+1;if(topMatrix.getValue(row,col)>0){topMatrix.setValue(row,col,1);let nextRow=row+1;for(;topMatrix.getValue(nextRow,col)>0;)topMatrix.setValue(nextRow,col,topMatrix.getValue(nextRow-1,col)+1),nextRow++}}return topMatrix},"filterLeftMatrix"),findAllRectangle=__name(topMatrix=>{const resultList=[];let result=findMaximalRectangle(topMatrix);for(;result.area>0;)result.range&&(resultList.push(result.range),filterLeftMatrix(topMatrix,result.range)),result=findMaximalRectangle(topMatrix);return resultList},"findAllRectangle"),rangeMerge=__name(ranges=>{const topMatrix=createTopMatrixFromRanges(ranges);return findAllRectangle(topMatrix)},"rangeMerge"),_RangeMergeUtil=class _RangeMergeUtil{constructor(){__publicField(this,"_matrix",new core.ObjectMatrix)}add(...ranges){return ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this._matrix.setValue(row,col,1)})}),this}subtract(...ranges){return ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this._matrix.realDeleteValue(row,col)})}),this}merge(){const topMatrix=createTopMatrixFromMatrix(this._matrix);return findAllRectangle(topMatrix)}};__name(_RangeMergeUtil,"RangeMergeUtil");let RangeMergeUtil=_RangeMergeUtil;const INumfmtService=core.createIdentifier("INumfmtService");core.runOnLifecycle(core.LifecycleStages.Ready,INumfmtService);const factorySetNumfmtUndoMutation=__name((accessor,option)=>{const numfmtService=accessor.get(INumfmtService),{values,unitId,subUnitId}=option,cells=[],removeCells=[];Object.keys(values).forEach(id=>{values[id].ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const oldNumfmt=numfmtService.getValue(unitId,subUnitId,row,col);oldNumfmt?cells.push({pattern:oldNumfmt.pattern,row,col}):removeCells.push({startColumn:col,endColumn:col,startRow:row,endRow:row})})})});const result=[];if(cells.length){const params=transformCellsToRange(unitId,subUnitId,cells);Object.keys(params.values).forEach(key=>{const v=params.values[key];v.ranges=rangeMerge(v.ranges)}),result.push({id:SetNumfmtMutation.id,params:transformCellsToRange(unitId,subUnitId,cells)})}return removeCells.length&&result.push({id:RemoveNumfmtMutation.id,params:{unitId,subUnitId,ranges:removeCells}}),result},"factorySetNumfmtUndoMutation"),SetNumfmtMutation={id:"sheet.mutation.set.numfmt",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{if(!params)return!1;const{values,refMap}=params,numfmtService=accessor.get(INumfmtService),unitId=params.unitId,sheetId=params.subUnitId,setValues=Object.keys(values).reduce((result,id)=>{const value=refMap[id],ranges=values[id].ranges;return value&&result.push({...value,ranges}),result},[]);return numfmtService.setValues(unitId,sheetId,setValues),!0},"handler")},RemoveNumfmtMutation={id:"sheet.mutation.remove.numfmt",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{if(!params)return!1;const{unitId,subUnitId,ranges}=params;return accessor.get(INumfmtService).deleteValues(unitId,subUnitId,ranges),!0},"handler")},factoryRemoveNumfmtUndoMutation=__name((accessor,option)=>{const numfmtService=accessor.get(INumfmtService),{ranges,unitId,subUnitId}=option,cells=[];if(ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const oldNumfmt=numfmtService.getValue(unitId,subUnitId,row,col);oldNumfmt&&cells.push({pattern:oldNumfmt.pattern,row,col})})}),!cells.length)return[];const params=transformCellsToRange(unitId,subUnitId,cells);return Object.keys(params.values).forEach(key=>{const v=params.values[key];v.ranges=rangeMerge(v.ranges)}),[{id:SetNumfmtMutation.id,params}]},"factoryRemoveNumfmtUndoMutation"),transformCellsToRange=__name((unitId,subUnitId,cells)=>{const group=groupByKey(cells,"pattern"),refMap={},values={},getKey=createUniqueKey();return Object.keys(group).forEach(pattern=>{const groupItem=group[pattern],key=getKey();refMap[key]={pattern},groupItem.forEach(item=>{values[key]||(values[key]={ranges:[]}),values[key].ranges.push(core.cellToRange(item.row,item.col))})}),{unitId,subUnitId,refMap,values}},"transformCellsToRange"),EmptyMutation={id:"sheet.mutation.empty",type:core.CommandType.MUTATION,handler:__name(()=>!0,"handler")},InsertDefinedNameCommand={id:"sheet.command.insert-defined-name",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService);if(!params)return!1;const insertSheetMutationParams={...params};return commandService.syncExecuteCommand(engineFormula.SetDefinedNameMutation.id,insertSheetMutationParams)?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:[{id:engineFormula.RemoveDefinedNameMutation.id,params:insertSheetMutationParams}],redoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:insertSheetMutationParams}]}),!0):!1},"handler")},RemoveDefinedNameCommand={id:"sheet.command.remove-defined-name",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService);if(!params)return!1;const removeSheetMutationParams={...params};return commandService.syncExecuteCommand(engineFormula.RemoveDefinedNameMutation.id,removeSheetMutationParams)?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:removeSheetMutationParams}],redoMutations:[{id:engineFormula.RemoveDefinedNameMutation.id,params:removeSheetMutationParams}]}),!0):!1},"handler")},SetDefinedNameCommand={id:"sheet.command.set-defined-name",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService);return params&&commandService.syncExecuteCommand(engineFormula.SetDefinedNameMutation.id,params.newDefinedName)?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:params.oldDefinedName}],redoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:params.newDefinedName}]}),!0):!1},"handler")},ScrollToCellOperation={id:"sheet.operation.scroll-to-cell",type:core.CommandType.OPERATION,handler:__name(()=>!0,"handler")},SetWorkbookNameMutation={id:"sheet.mutation.set-workbook-name",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUnit(params.unitId,core.UniverInstanceType.UNIVER_SHEET);return workbook?(workbook.setName(params.name),!0):!1},"handler")},SetWorkbookNameCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-workbook-name",handler:__name(async(accessor,params)=>{var _a20;if(!accessor.get(core.IUniverInstanceService).getUnit(params.unitId,core.UniverInstanceType.UNIVER_SHEET))return!1;const interceptedCommands=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetWorkbookNameCommand.id,params}),redoMutationParams={name:params.name,unitId:params.unitId},redos=[...(_a20=interceptedCommands.preRedos)!=null?_a20:[],{id:SetWorkbookNameMutation.id,params:redoMutationParams},...interceptedCommands.redos],commandService=accessor.get(core.ICommandService);return core.sequenceExecute(redos,commandService).result},"handler")};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"),_a4;exports.WorksheetProtectionRuleModel=(_a4=class{constructor(){__publicField(this,"_model",new Map);__publicField(this,"_ruleChange",new rxjs.Subject);__publicField(this,"_ruleRefresh",new rxjs.Subject);__publicField(this,"_resetOrder",new rxjs.Subject);__publicField(this,"ruleChange$",this._ruleChange.asObservable());__publicField(this,"ruleRefresh$",this._ruleRefresh.asObservable());__publicField(this,"resetOrder$",this._resetOrder.asObservable());__publicField(this,"_worksheetRuleInitStateChange",new rxjs.BehaviorSubject(!1));__publicField(this,"worksheetRuleInitStateChange$",this._worksheetRuleInitStateChange.asObservable())}changeRuleInitState(state){this._worksheetRuleInitStateChange.next(state)}getSheetRuleInitState(){return this._worksheetRuleInitStateChange.value}addRule(unitId,rule){this._ensureSubUnitMap(unitId).set(rule.subUnitId,rule),this._ruleChange.next({unitId,rule,type:"add",subUnitId:rule.subUnitId})}deleteRule(unitId,subUnitId){var _a20,_b,_c;const rule=(_b=(_a20=this._model)==null?void 0:_a20.get(unitId))==null?void 0:_b.get(subUnitId);rule&&((_c=this._model.get(unitId))==null||_c.delete(subUnitId),this._ruleChange.next({unitId,rule,type:"delete",subUnitId}))}setRule(unitId,subUnitId,rule){var _a20,_b;const oldRule=this.getRule(unitId,subUnitId);oldRule&&((_b=(_a20=this._model)==null?void 0:_a20.get(unitId))==null||_b.set(subUnitId,rule),this._ruleChange.next({unitId,oldRule,rule,type:"set",subUnitId}))}getRule(unitId,subUnitId){var _a20,_b;return(_b=(_a20=this._model)==null?void 0:_a20.get(unitId))==null?void 0:_b.get(subUnitId)}toObject(){const result={};return[...this._model.keys()].forEach(unitId=>{const subUnitMap=this._model.get(unitId);subUnitMap!=null&&subUnitMap.size&&(result[unitId]=[],[...subUnitMap.keys()].forEach(subUnitId=>{const rule=subUnitMap.get(subUnitId);rule&&result[unitId].push(rule)}))}),result}fromObject(obj){const result=new Map;Object.keys(obj).forEach(unitId=>{const subUnitList=obj[unitId];if(subUnitList!=null&&subUnitList.length){const subUnitMap=new Map;subUnitList.forEach(rule=>{subUnitMap.set(rule.subUnitId,rule)}),result.set(unitId,subUnitMap)}}),this._model=result}deleteUnitModel(unitId){this._model.delete(unitId)}_ensureSubUnitMap(unitId){let subUnitMap=this._model.get(unitId);return subUnitMap||(subUnitMap=new Map,this._model.set(unitId,subUnitMap)),subUnitMap}ruleRefresh(permissionId){this._ruleRefresh.next(permissionId)}resetOrder(){this._resetOrder.next(Math.random())}getTargetByPermissionId(unitId,permissionId){const subUnitMap=this._model.get(unitId);if(!subUnitMap)return null;for(const[subUnitId,rule]of subUnitMap)if(rule.permissionId===permissionId)return[unitId,subUnitId]}},__name(_a4,"WorksheetProtectionRuleModel"),_a4);exports.WorksheetProtectionRuleModel=__decorateClass$f([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorksheetProtectionRuleModel)],exports.WorksheetProtectionRuleModel);const AddWorksheetProtectionMutation={id:"sheet.mutation.add-worksheet-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,rule}=params;return accessor.get(exports.WorksheetProtectionRuleModel).addRule(unitId,rule),!0},"handler")},SetWorksheetProtectionMutation={id:"sheet.mutation.set-worksheet-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,rule}=params;return accessor.get(exports.WorksheetProtectionRuleModel).setRule(unitId,subUnitId,rule),!0},"handler")},DeleteWorksheetProtectionMutation={id:"sheet.mutation.delete-worksheet-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId}=params;return accessor.get(exports.WorksheetProtectionRuleModel).deleteRule(unitId,subUnitId),!0},"handler")};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"),_a5;exports.RangeProtectionRuleModel=(_a5=class{constructor(){__publicField(this,"_model",new Map);__publicField(this,"_ruleChange",new rxjs.Subject);__publicField(this,"ruleChange$",this._ruleChange.asObservable());__publicField(this,"_ruleRefresh",new rxjs.Subject);__publicField(this,"ruleRefresh$",this._ruleRefresh.asObservable());__publicField(this,"_rangeRuleInitStateChange",new rxjs.BehaviorSubject(!1));__publicField(this,"rangeRuleInitStateChange$",this._rangeRuleInitStateChange.asObservable())}ruleRefresh(id){this._ruleRefresh.next(id)}getRangeRuleInitState(){return this._rangeRuleInitStateChange.value}changeRuleInitState(state){this._rangeRuleInitStateChange.next(state)}addRule(unitId,subUnitId,rule){this._ensureRuleMap(unitId,subUnitId).set(rule.id,rule),this._ruleChange.next({unitId,subUnitId,rule,type:"add"})}deleteRule(unitId,subUnitId,id){var _a20,_b,_c,_d;const rule=(_b=(_a20=this._model.get(unitId))==null?void 0:_a20.get(subUnitId))==null?void 0:_b.get(id);rule&&((_d=(_c=this._model.get(unitId))==null?void 0:_c.get(subUnitId))==null||_d.delete(id),this._ruleChange.next({unitId,subUnitId,rule,type:"delete"}))}setRule(unitId,subUnitId,id,rule){var _a20,_b;const oldRule=this.getRule(unitId,subUnitId,id);oldRule&&((_b=(_a20=this._model.get(unitId))==null?void 0:_a20.get(subUnitId))==null||_b.set(id,rule),this._ruleChange.next({unitId,subUnitId,oldRule,rule,type:"set"}))}getRule(unitId,subUnitId,id){var _a20,_b;return(_b=(_a20=this._model.get(unitId))==null?void 0:_a20.get(subUnitId))==null?void 0:_b.get(id)}getSubunitRuleList(unitId,subUnitId){var _a20;return[...(((_a20=this._model.get(unitId))==null?void 0:_a20.get(subUnitId))||new Map).values()]}_ensureRuleMap(unitId,subUnitId){let subUnitMap=this._model.get(unitId);subUnitMap||(subUnitMap=new Map,this._model.set(unitId,subUnitMap));let ruleMap=subUnitMap.get(subUnitId);return ruleMap||(ruleMap=new Map,subUnitMap.set(subUnitId,ruleMap)),ruleMap}toObject(){const result={};return[...this._model.keys()].forEach(unitId=>{const submitMap=this._model.get(unitId),subUnitKeys=[...submitMap.keys()];result[unitId]={},subUnitKeys.forEach(subunitId=>{const ruleMap=submitMap.get(subunitId);result[unitId][subunitId]=[...ruleMap.values()]})}),result}fromObject(obj){const result=new Map;Object.keys(obj).forEach(unitId=>{const subUnitObj=obj[unitId],map=new Map;Object.keys(subUnitObj).forEach(subunitId=>{const ruleMap=subUnitObj[subunitId].reduce((result2,cur)=>(result2.set(cur.id,cur),result2),new Map);map.set(subunitId,ruleMap)}),result.set(unitId,map)}),this._model=result}deleteUnitModel(unitId){this._model.delete(unitId)}createRuleId(unitId,subUnitId){let id=core.Tools.generateRandomId(4);const ruleMap=this._ensureRuleMap(unitId,subUnitId);for(;ruleMap.has(id);)id=core.Tools.generateRandomId(4);return id}getTargetByPermissionId(unitId,permissionId){const subUnitMap=this._model.get(unitId);if(!subUnitMap)return null;for(const[subUnitId,ruleMap]of subUnitMap)for(const rule of ruleMap.values())if(rule.permissionId===permissionId)return[unitId,subUnitId];return null}},__name(_a5,"RangeProtectionRuleModel"),_a5);exports.RangeProtectionRuleModel=__decorateClass$e([core.OnLifecycle(core.LifecycleStages.Starting,exports.RangeProtectionRuleModel)],exports.RangeProtectionRuleModel);const getAllWorksheetPermissionPoint=__name(()=>[WorksheetEditPermission,WorksheetViewPermission],"getAllWorksheetPermissionPoint"),getAllWorksheetPermissionPointByPointPanel=__name(()=>[WorksheetCopyPermission,WorksheetDeleteColumnPermission,WorksheetDeleteRowPermission,WorksheetEditExtraObjectPermission,WorksheetFilterPermission,WorksheetInsertColumnPermission,WorksheetInsertRowPermission,WorksheetInsertHyperlinkPermission,WorksheetPivotTablePermission,WorksheetSetCellStylePermission,WorksheetSetCellValuePermission,WorksheetSetColumnStylePermission,WorksheetSetRowStylePermission,WorksheetSortPermission],"getAllWorksheetPermissionPointByPointPanel"),defaultWorksheetPermissionPoint=[P.Copy,P.DeleteColumn,P.DeleteRow,P.EditExtraObject,P.Filter,P.InsertColumn,P.InsertRow,P.InsertHyperlink,P.PivotTable,P.SetCellStyle,P.SetCellValue,P.SetColumnStyle,P.SetRowStyle,P.Sort];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"),_a6;exports.WorksheetProtectionPointModel=(_a6=class{constructor(){__publicField(this,"_model",new Map);__publicField(this,"_pointChange",new rxjs.Subject);__publicField(this,"pointChange$",this._pointChange.asObservable())}addRule(rule){this._ensureSubUnitMap(rule.unitId).set(rule.subUnitId,rule),this._pointChange.next(rule)}deleteRule(unitId,subUnitId){var _a20,_b,_c;const rule=(_a20=this._model.get(unitId))==null?void 0:_a20.get(subUnitId);rule&&((_c=(_b=this._model)==null?void 0:_b.get(unitId))==null||_c.delete(subUnitId),this._pointChange.next(rule))}getRule(unitId,subUnitId){var _a20,_b;return(_b=(_a20=this._model)==null?void 0:_a20.get(unitId))==null?void 0:_b.get(subUnitId)}toObject(){const result={};return[...this._model.keys()].forEach(unitId=>{const subUnitMap=this._model.get(unitId);subUnitMap!=null&&subUnitMap.size&&(result[unitId]=[],[...subUnitMap.keys()].forEach(subUnitId=>{const rule=subUnitMap.get(subUnitId);rule&&result[unitId].push(rule)}))}),result}fromObject(obj){const result=new Map;Object.keys(obj).forEach(unitId=>{const subUnitList=obj[unitId];if(subUnitList!=null&&subUnitList.length){const subUnitMap=new Map;subUnitList.forEach(rule=>{subUnitMap.set(rule.subUnitId,rule)}),result.set(unitId,subUnitMap)}}),this._model=result}deleteUnitModel(unitId){this._model.delete(unitId)}_ensureSubUnitMap(unitId){let subUnitMap=this._model.get(unitId);return subUnitMap||(subUnitMap=new Map,this._model.set(unitId,subUnitMap)),subUnitMap}getTargetByPermissionId(unitId,permissionId){const subUnitMap=this._model.get(unitId);if(!subUnitMap)return null;for(const[subUnitId,rule]of subUnitMap)if(rule.permissionId===permissionId)return[unitId,subUnitId]}},__name(_a6,"WorksheetProtectionPointModel"),_a6);exports.WorksheetProtectionPointModel=__decorateClass$d([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorksheetProtectionPointModel)],exports.WorksheetProtectionPointModel);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");const RULE_MODEL_PLUGIN_NAME="SHEET_WORKSHEET_PROTECTION_PLUGIN",POINT_MODEL_PLUGIN_NAME="SHEET_WORKSHEET_PROTECTION_POINT_PLUGIN";var _a7;exports.WorksheetPermissionService=(_a7=class extends core.RxDisposable{constructor(_permissionService,_univerInstanceService,_injector,_worksheetProtectionRuleModel,_worksheetProtectionPointRuleModel,_resourceManagerService,_rangeProtectionRuleModel){super(),this._permissionService=_permissionService,this._univerInstanceService=_univerInstanceService,this._injector=_injector,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._worksheetProtectionPointRuleModel=_worksheetProtectionPointRuleModel,this._resourceManagerService=_resourceManagerService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._init(),this._initRuleChange(),this._initRuleSnapshot(),this._initPointSnapshot()}_init(){const handleWorkbook=__name(workbook=>{const unitId=workbook.getUnitId(),handleWorksheet=__name(worksheet=>{const subUnitId=worksheet.getSheetId();[...getAllWorksheetPermissionPoint(),...getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.addPermissionPoint(instance)})},"handleWorksheet");workbook.getSheets().forEach(worksheet=>{handleWorksheet(worksheet)}),workbook.sheetCreated$.subscribe(worksheet=>{handleWorksheet(worksheet)}),workbook.sheetDisposed$.subscribe(worksheet=>{const subUnitId=worksheet.getSheetId();this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{[RangeProtectionPermissionEditPoint,RangeProtectionPermissionViewPoint].forEach(F=>{const instance=new F(unitId,subUnitId,rule.permissionId);this._permissionService.deletePermissionPoint(instance.id)})}),[...getAllWorksheetPermissionPoint(),...getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.deletePermissionPoint(instance.id)})})},"handleWorkbook");this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>{handleWorkbook(workbook)}),this._univerInstanceService.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.takeUntil(this.dispose$)).subscribe(handleWorkbook),this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.takeUntil(this.dispose$)).subscribe(workbook=>{workbook.getSheets().forEach(worksheet=>{const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId();getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.deletePermissionPoint(instance.id)})})})}_initRuleChange(){this.disposeWithMe(this._worksheetProtectionRuleModel.ruleChange$.subscribe(info=>{switch(info.type){case"add":break;case"delete":{getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,!0)});break}case"set":{getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,info.rule)});break}}}))}_initRuleSnapshot(){const toJson=__name(()=>{const object=this._worksheetProtectionRuleModel.toObject();return JSON.stringify(object)},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({toJson,parseJson,pluginName:RULE_MODEL_PLUGIN_NAME,businesses:[I.UNIVER_SHEET],onLoad:__name((unitId,resources)=>{this._worksheetProtectionRuleModel.fromObject(resources),Object.keys(resources).forEach(subUnitId=>{getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(unitId,subUnitId);instance.value=!1,this._permissionService.addPermissionPoint(instance)})}),this._worksheetProtectionRuleModel.changeRuleInitState(!0)},"onLoad"),onUnLoad:__name(unitId=>{this._worksheetProtectionRuleModel.deleteUnitModel(unitId)},"onUnLoad")}))}_initPointSnapshot(){const toJson=__name(()=>{const object=this._worksheetProtectionPointRuleModel.toObject();return JSON.stringify(object)},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({toJson,parseJson,pluginName:POINT_MODEL_PLUGIN_NAME,businesses:[I.UNIVER_SHEET],onLoad:__name((unitId,resources)=>{this._worksheetProtectionPointRuleModel.fromObject(resources),Object.keys(resources).forEach(subUnitId=>{getAllWorksheetPermissionPointByPointPanel().forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.addPermissionPoint(instance)})})},"onLoad"),onUnLoad:__name(unitId=>{this._worksheetProtectionPointRuleModel.deleteUnitModel(unitId)},"onUnLoad")}))}},__name(_a7,"WorksheetPermissionService"),_a7);exports.WorksheetPermissionService=__decorateClass$c([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorksheetPermissionService),__decorateParam$c(0,core.Inject(core.IPermissionService)),__decorateParam$c(1,core.Inject(core.IUniverInstanceService)),__decorateParam$c(2,core.Inject(core.Injector)),__decorateParam$c(3,core.Inject(exports.WorksheetProtectionRuleModel)),__decorateParam$c(4,core.Inject(exports.WorksheetProtectionPointModel)),__decorateParam$c(5,core.Inject(core.IResourceManagerService)),__decorateParam$c(6,core.Inject(exports.RangeProtectionRuleModel))],exports.WorksheetPermissionService);const SetWorksheetPermissionPointsMutation={id:"sheet.mutation.set-worksheet-permission-points",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{rule}=params;return accessor.get(exports.WorksheetProtectionPointModel).addRule(rule),!0},"handler")},SetWorksheetPermissionPointsCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-permission-points",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),{rule}=params;return commandService.executeCommand(SetWorksheetPermissionPointsMutation.id,{rule,unitId:rule.unitId,subUnitId:rule.subUnitId}),!0}},FactoryDeleteRangeProtectionMutation=__name((accessor,param)=>{const selectionProtectionRuleModel=accessor.get(exports.RangeProtectionRuleModel),rules=param.ruleIds.map(id=>selectionProtectionRuleModel.getRule(param.unitId,param.subUnitId,id)).filter(rule=>!!rule);return{id:AddRangeProtectionMutation.id,params:{subUnitId:param.subUnitId,unitId:param.unitId,rules}}},"FactoryDeleteRangeProtectionMutation"),DeleteRangeProtectionMutation={id:"sheet.mutation.delete-range-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,ruleIds}=params,selectionProtectionRuleModel=accessor.get(exports.RangeProtectionRuleModel);return ruleIds.forEach(id=>{selectionProtectionRuleModel.deleteRule(unitId,subUnitId,id)}),!0},"handler")},FactoryAddRangeProtectionMutation=__name(param=>{const deleteParams={...param,ruleIds:param.rules.map(rule=>rule.id)};return{id:DeleteRangeProtectionMutation.id,params:deleteParams}},"FactoryAddRangeProtectionMutation"),AddRangeProtectionMutation={id:"sheet.mutation.add-range-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,rules}=params,selectionProtectionRuleModel=accessor.get(exports.RangeProtectionRuleModel);return rules.forEach(rule=>{selectionProtectionRuleModel.addRule(unitId,subUnitId,rule)}),!0},"handler")},AddRangeProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),selectionProtectionModel=accessor.get(exports.RangeProtectionRuleModel),{rule,permissionId}=params,{unitId,subUnitId,ranges,name,description}=rule,rules=[{ranges,permissionId,id:selectionProtectionModel.createRuleId(unitId,subUnitId),name,description,unitType:rule.unitType,unitId,subUnitId}];if(await commandService.executeCommand(AddRangeProtectionMutation.id,{unitId,subUnitId,rules})){const redoMutations=[{id:AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules}}],undoMutations=[{id:DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:rules.map(rule2=>rule2.id)}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteRangeProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),{unitId,subUnitId,rule}=params,redoMutationParam={unitId,subUnitId,ruleIds:[rule.id]};return await commandService.executeCommand(DeleteRangeProtectionMutation.id,redoMutationParam)&&undoRedoService.pushUndoRedo({unitID:unitId,redoMutations:[{id:DeleteRangeProtectionMutation.id,params:redoMutationParam}],undoMutations:[{id:AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}]}),!0}},SetRangeProtectionMutation={id:"sheet.mutation.set-range-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,rule,ruleId}=params;return accessor.get(exports.RangeProtectionRuleModel).setRule(unitId,subUnitId,ruleId,rule),!0},"handler")},FactorySetRangeProtectionMutation=__name((accessor,param)=>{const{unitId,subUnitId,ruleId}=param,oldRule=accessor.get(exports.RangeProtectionRuleModel).getRule(unitId,subUnitId,ruleId);return oldRule?{id:SetRangeProtectionMutation.id,params:{...param,rule:oldRule}}:null},"FactorySetRangeProtectionMutation"),SetRangeProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),selectionProtectionModel=accessor.get(exports.RangeProtectionRuleModel),undoRedoService=accessor.get(core.IUndoRedoService),{rule,permissionId,oldRule}=params,{unitId,subUnitId,ranges,name,description}=rule;if(rule.id){const redoMutationParam={unitId,subUnitId,ruleId:rule.id,rule:{ranges,permissionId,id:selectionProtectionModel.createRuleId(unitId,subUnitId),name,description}};if(await commandService.executeCommand(SetRangeProtectionMutation.id,redoMutationParam)){const redoMutations=[{id:SetRangeProtectionMutation.id,params:redoMutationParam}],undoMutations=[{id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,ruleId:rule.id,rule:oldRule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}}return!0}},ReorderRangeUndoMutationFactory=__name(params=>{const{order}=params,newOrder={};return Object.keys(order).forEach(key=>{newOrder[order[Number(key)]]=Number(key)}),{...params,order:newOrder}},"ReorderRangeUndoMutationFactory"),ReorderRangeMutation={id:"sheet.mutation.reorder-range",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{subUnitId,unitId,range,order}=params,worksheet=accessor.get(core.IUniverInstanceService).getUnit(unitId).getSheetBySheetId(subUnitId);if(!worksheet)return!1;const cellDataMatrix=new core.ObjectMatrix;core.Range.foreach(range,(row,col)=>{if(order.hasOwnProperty(row)){const targetRow=order[row],cloneCell=core.Tools.deepClone(worksheet.getCellRaw(targetRow,col));cellDataMatrix.setValue(row,col,cloneCell)}});const worksheetCellDataMatrix=worksheet.getCellMatrix();return cellDataMatrix.forValue((row,col,cellData)=>{worksheetCellDataMatrix.setValue(row,col,cellData)}),!0},"handler")},ReorderRangeCommandId="sheet.command.reorder-range",ReorderRangeCommand={id:ReorderRangeCommandId,type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a20,_b;const{subUnitId,unitId,range,order}=params,commandService=accessor.get(core.ICommandService),reorderMutation={id:ReorderRangeMutation.id,params:{unitId,subUnitId,order,range}},undoReorderMutation={id:ReorderRangeMutation.id,params:ReorderRangeUndoMutationFactory(reorderMutation.params)},interceptorCommands=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:ReorderRangeCommand.id,params}),redos=[...(_a20=interceptorCommands.preRedos)!=null?_a20:[],reorderMutation,...interceptorCommands.redos],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],undoReorderMutation,...interceptorCommands.undos];return core.sequenceExecute(redos,commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},MAX_CELL_PER_SHEET_KEY="maxCellsPerSheet",MAX_CELL_PER_SHEET_DEFAULT=3e6,ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY="ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY";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"),_a8;let BasicWorksheetController=(_a8=class extends core.Disposable{constructor(_commandService,_configService,_dataSyncPrimaryController){var _a20;super(),this._commandService=_commandService,this._configService=_configService,this._dataSyncPrimaryController=_dataSyncPrimaryController,[SetRangeValuesMutation,InsertColMutation,InsertRowMutation,InsertSheetMutation,MoveRangeMutation,MoveRowsMutation,MoveColsMutation,RemoveColMutation,RemoveRowMutation,RemoveSheetMutation,RemoveWorksheetMergeMutation,RemoveNumfmtMutation,AddWorksheetMergeMutation,SetWorkbookNameMutation,SetWorksheetNameMutation,SetNumfmtMutation,ReorderRangeMutation,EmptyMutation,SetWorksheetColWidthMutation].forEach(mutation=>{var _a21;this._commandService.registerCommand(mutation),(_a21=this._dataSyncPrimaryController)==null||_a21.registerSyncingMutations(mutation)}),((_a20=this._configService.getConfig(ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY))!=null?_a20:!1)||[ClearSelectionAllCommand,ClearSelectionContentCommand,ClearSelectionFormatCommand,CopySheetCommand,DeleteRangeMoveLeftCommand,DeleteRangeMoveUpCommand,DeltaColumnWidthCommand,DeltaRowHeightCommand,InsertColAfterCommand,InsertColBeforeCommand,InsertColCommand,InsertRangeMoveDownCommand,InsertRangeMoveRightCommand,InsertRowAfterCommand,InsertRowBeforeCommand,InsertRowCommand,InsertSheetCommand,MoveColsCommand,MoveRangeCommand,MoveRowsCommand,RemoveColCommand,RemoveRowCommand,RemoveSheetCommand,ReorderRangeCommand,RemoveWorksheetMergeCommand,ResetBackgroundColorCommand,ResetTextColorCommand,SetBackgroundColorCommand,SetBorderBasicCommand,SetBorderColorCommand,SetBorderCommand,SetBorderPositionCommand,SetBorderStyleCommand,SetColHiddenCommand,SetColHiddenMutation,SetColVisibleMutation,SetColWidthCommand,SetFrozenCancelCommand,SetFrozenCommand,SetFrozenMutation,SetHorizontalTextAlignCommand,SetRangeValuesCommand,SetRowHeightCommand,SetRowHiddenCommand,SetRowHiddenMutation,SetRowVisibleMutation,SetSelectedColsVisibleCommand,SetSelectedRowsVisibleCommand,SetSpecificColsVisibleCommand,SetSpecificRowsVisibleCommand,SetStyleCommand,SetTabColorCommand,SetTabColorMutation,SetTextColorCommand,SetTextRotationCommand,SetTextWrapCommand,SetVerticalTextAlignCommand,SetWorkbookNameCommand,SetWorksheetActivateCommand,SetWorksheetActiveOperation,SetWorksheetHideCommand,SetWorksheetHideMutation,SetWorksheetNameCommand,SetWorksheetOrderCommand,SetWorksheetOrderMutation,SetWorksheetRowAutoHeightMutation,SetWorksheetRowHeightMutation,SetWorksheetRowIsAutoHeightCommand,SetWorksheetRowIsAutoHeightMutation,SetSelectionsOperation,ScrollToCellOperation,InsertDefinedNameCommand,RemoveDefinedNameCommand,SetDefinedNameCommand,SetWorksheetShowCommand,SetWorksheetPermissionPointsCommand,AddWorksheetProtectionMutation,SetWorksheetProtectionMutation,DeleteWorksheetProtectionMutation,SetWorksheetPermissionPointsMutation,AddRangeProtectionCommand,DeleteRangeProtectionCommand,SetRangeProtectionCommand,AddRangeProtectionMutation,DeleteRangeProtectionMutation,SetRangeProtectionMutation].forEach(command=>this.disposeWithMe(this._commandService.registerCommand(command))),this._configService.setConfig(MAX_CELL_PER_SHEET_KEY,MAX_CELL_PER_SHEET_DEFAULT)}},__name(_a8,"BasicWorksheetController"),_a8);BasicWorksheetController=__decorateClass$b([core.OnLifecycle(core.LifecycleStages.Starting,BasicWorksheetController),__decorateParam$b(0,core.ICommandService),__decorateParam$b(1,core.IConfigService),__decorateParam$b(2,core.Optional(rpc.DataSyncPrimaryController))],BasicWorksheetController);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"),_a9;let CalculateResultApplyController=(_a9=class extends core.Disposable{constructor(_univerInstanceService,_commandService){super(),this._univerInstanceService=_univerInstanceService,this._commandService=_commandService,this._initialize()}_initialize(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id!==engineFormula.SetFormulaCalculationResultMutation.id)return;const params=command.params,{unitData}=params,unitIds=Object.keys(unitData),redoMutationsInfo=[];return unitIds.forEach(unitId=>{const sheetData=unitData[unitId];if(sheetData==null)return!0;Object.keys(sheetData).forEach(sheetId=>{const cellData=sheetData[sheetId];if(cellData==null)return!0;const cellValue=this._getMergedCellData(unitId,sheetId,cellData),setRangeValuesMutation={subUnitId:sheetId,unitId,cellValue};redoMutationsInfo.push({id:SetRangeValuesMutation.id,params:setRangeValuesMutation})})}),redoMutationsInfo.every(m=>this._commandService.executeCommand(m.id,m.params,{onlyLocal:!0}))}))}_getMergedCellData(unitId,sheetId,cellData){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId),styles=workbook==null?void 0:workbook.getStyles(),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(sheetId),oldCellDataMatrix=worksheet==null?void 0:worksheet.getCellMatrix(),cellDataMatrix=new core.ObjectMatrix(cellData);return cellDataMatrix.forValue((row,col,cell)=>{const oldCell=oldCellDataMatrix==null?void 0:oldCellDataMatrix.getValue(row,col),newCell=engineFormula.handleNumfmtInCell(oldCell,cell,styles);cellDataMatrix.setValue(row,col,newCell)}),cellDataMatrix.clone()}},__name(_a9,"CalculateResultApplyController"),_a9);CalculateResultApplyController=__decorateClass$a([core.OnLifecycle(core.LifecycleStages.Ready,CalculateResultApplyController),__decorateParam$a(0,core.Inject(core.IUniverInstanceService)),__decorateParam$a(1,core.ICommandService)],CalculateResultApplyController);const EffectRefRangId={MoveRangeCommandId,InsertRowCommandId,InsertColCommandId,RemoveColCommandId,RemoveRowCommandId,DeleteRangeMoveLeftCommandId,DeleteRangeMoveUpCommandId,InsertRangeMoveDownCommandId,InsertRangeMoveRightCommandId,MoveColsCommandId,MoveRowsCommandId,ReorderRangeCommandId};var OperatorType=(OperatorType2=>(OperatorType2[OperatorType2.Set=0]="Set",OperatorType2[OperatorType2.Delete=1]="Delete",OperatorType2[OperatorType2.HorizontalMove=2]="HorizontalMove",OperatorType2[OperatorType2.VerticalMove=3]="VerticalMove",OperatorType2[OperatorType2.Unknown=4]="Unknown",OperatorType2))(OperatorType||{});const MAX_SAFE_INTEGER=Number.MAX_SAFE_INTEGER,handleRangeTypeInput=__name(range=>{const _range={...range},isColumn=Number.isNaN(_range.startRow)&&Number.isNaN(_range.endRow)&&!Number.isNaN(_range.startColumn)&&!Number.isNaN(_range.endColumn),isRow=Number.isNaN(_range.startColumn)&&Number.isNaN(_range.endColumn)&&!Number.isNaN(_range.startRow)&&!Number.isNaN(_range.endRow);return(_range.rangeType===core.RANGE_TYPE.COLUMN||isColumn)&&(_range.startRow=0,_range.endRow=MAX_SAFE_INTEGER),(_range.rangeType===core.RANGE_TYPE.ROW||isRow)&&(_range.startColumn=0,_range.endColumn=MAX_SAFE_INTEGER),_range.rangeType===core.RANGE_TYPE.ALL&&(_range.startColumn=0,_range.endColumn=MAX_SAFE_INTEGER,_range.startRow=0,_range.endRow=MAX_SAFE_INTEGER),_range},"handleRangeTypeInput"),rotateRange=__name(range=>{let rangeType=range.rangeType;return range.rangeType===core.RANGE_TYPE.COLUMN?rangeType=core.RANGE_TYPE.ROW:range.rangeType===core.RANGE_TYPE.ROW&&(rangeType=core.RANGE_TYPE.COLUMN),{startRow:range.startColumn,endRow:range.endColumn,startColumn:range.startRow,endColumn:range.endRow,rangeType}},"rotateRange"),handleBaseMoveRowsCols=__name((fromRange,toRange,effectRange)=>{const _effectRange={...effectRange},_toRange={...toRange},getIntersects=__name((line1,line2)=>{const start=Math.max(line1.start,line2.start),end=Math.min(line1.end,line2.end);return end<start?null:{start,end}},"getIntersects"),getLength=__name(line=>line.end-line.start+1,"getLength"),getRelative=__name((line,origin)=>({start:line.start-origin.start,end:line.start-origin.start+line.end-line.start}),"getRelative"),getAbsolute=__name((line,origin)=>({start:origin.start+line.start,end:origin.start+line.start+line.end-line.start}),"getAbsolute"),isToLargeFrom=toRange.start>fromRange.start;if(isToLargeFrom){const step=Math.min(fromRange.end,toRange.start)-fromRange.start+1;_toRange.start-=step,_toRange.end-=step}const fromRangeStep=getLength(fromRange),toRangeStep=fromRangeStep,fromRangeIntersectsEffectRange=getIntersects(fromRange,_effectRange),isFromRangeContainEffectRange=fromRangeIntersectsEffectRange&&getLength(fromRangeIntersectsEffectRange)>=getLength(_effectRange);if(fromRange.end<_effectRange.start)_effectRange.start-=fromRangeStep,_effectRange.end-=fromRangeStep;else if(fromRangeIntersectsEffectRange){const fromRangeIntersectsEffectRangeStep=getLength(fromRangeIntersectsEffectRange);if(isFromRangeContainEffectRange){const relative=getRelative(_effectRange,fromRange),newLine=getAbsolute(relative,_toRange);_effectRange.start=newLine.start,_effectRange.end=newLine.end}else fromRangeIntersectsEffectRange.start>fromRange.start?isToLargeFrom?(_effectRange.end-=fromRangeIntersectsEffectRangeStep+fromRangeStep,_effectRange.start-=fromRangeStep):_effectRange.end-=fromRangeIntersectsEffectRangeStep:isToLargeFrom?_effectRange.end-=fromRangeIntersectsEffectRangeStep:_effectRange.start>fromRange.start&&_effectRange.end>fromRange.end?(_effectRange.start-=fromRangeStep,_effectRange.end-=fromRangeStep+fromRangeIntersectsEffectRangeStep):_effectRange.end-=fromRangeIntersectsEffectRangeStep}const toRangeIntersectsEffectRange=getIntersects(_toRange,_effectRange);return isFromRangeContainEffectRange||(_toRange.start<=_effectRange.start?(_effectRange.start+=toRangeStep,_effectRange.end+=toRangeStep):toRangeIntersectsEffectRange&&(isToLargeFrom?_toRange.end<=_effectRange.start||_toRange.start<=_effectRange.start&&_toRange.end>=_effectRange.start?(_effectRange.start+=toRangeStep,_effectRange.end+=toRangeStep):_toRange.start>=_effectRange.start&&_toRange.start<=_effectRange.end&&(_effectRange.end+=toRangeStep):_effectRange.start<_toRange.start&&_effectRange.end>_toRange.start?_effectRange.end+=toRangeStep:(_effectRange.start>=_toRange.end||_effectRange.start>=_toRange.start&&_effectRange.start<=_toRange.end)&&(_effectRange.end+=toRangeStep,_effectRange.start+=toRangeStep))),{step:_effectRange.start-effectRange.start,length:getLength(_effectRange)-getLength(effectRange)}},"handleBaseMoveRowsCols"),handleMoveRows=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!toRange||!fromRange)return[];const _fromRange=handleRangeTypeInput(fromRange),_toRange=handleRangeTypeInput(toRange),_targetRange=handleRangeTypeInput(targetRange),result=handleBaseMoveRowsCols({start:_fromRange.startRow,end:_fromRange.endRow},{start:_toRange.startRow,end:_toRange.endRow},{start:_targetRange.startRow,end:_targetRange.endRow});return result===null?[{type:OperatorType.Delete}]:[{type:OperatorType.VerticalMove,step:result.step||0,length:result.length||0}]},"handleMoveRows"),handleMoveRowsCommon=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!fromRange||!toRange)return[targetRange];const fromRow=fromRange.startRow,count=fromRange.endRow-fromRange.startRow+1,toRow=toRange.startRow,matrix=new core.ObjectMatrix;return core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)}),matrix.moveRows(fromRow,count,toRow),core.queryObjectMatrix(matrix,value=>value===1)},"handleMoveRowsCommon"),handleReorderRangeCommon=__name((param,targetRange)=>{const{range,order}=param.params||{};if(!range||!order)return[targetRange];const matrix=new core.ObjectMatrix;core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)});const cacheMatrix=new core.ObjectMatrix;return core.Range.foreach(range,(row,col)=>{var _a20;if(order.hasOwnProperty(row)){const targetRow=order[row],cloneCell=(_a20=matrix.getValue(targetRow,col))!=null?_a20:0;cacheMatrix.setValue(row,col,cloneCell)}}),cacheMatrix.forValue((row,col,cellData)=>{matrix.setValue(row,col,cellData)}),core.queryObjectMatrix(matrix,value=>value===1)},"handleReorderRangeCommon"),handleMoveCols=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!toRange||!fromRange)return[];const _fromRange=handleRangeTypeInput(fromRange),_toRange=handleRangeTypeInput(toRange),_targetRange=handleRangeTypeInput(targetRange),result=handleBaseMoveRowsCols({start:_fromRange.startColumn,end:_fromRange.endColumn},{start:_toRange.startColumn,end:_toRange.endColumn},{start:_targetRange.startColumn,end:_targetRange.endColumn});return result===null?[{type:OperatorType.Delete}]:[{type:OperatorType.HorizontalMove,step:result.step||0,length:result.length||0}]},"handleMoveCols"),handleMoveColsCommon=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!fromRange||!toRange)return[targetRange];const fromCol=fromRange.startColumn,count=fromRange.endColumn-fromRange.startColumn+1,toCol=toRange.startColumn,matrix=new core.ObjectMatrix;return core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)}),matrix.moveColumns(fromCol,count,toCol),core.queryObjectMatrix(matrix,value=>value===1)},"handleMoveColsCommon"),handleMoveRange=__name((param,targetRange)=>{var _a20,_b;const toRange=(_a20=param.params)==null?void 0:_a20.toRange,fromRange=(_b=param.params)==null?void 0:_b.fromRange;if(!toRange||!fromRange)return[];const operators2=[];if(core.Rectangle.contains(toRange,targetRange)&&operators2.push({type:OperatorType.Delete}),core.Rectangle.contains(fromRange,targetRange)){operators2.push({type:OperatorType.Delete});const relativeRange=core.Rectangle.getRelativeRange(targetRange,fromRange),positionRange=core.Rectangle.getPositionRange(relativeRange,toRange);return[{type:OperatorType.Set,range:positionRange}]}return operators2},"handleMoveRange"),handleMoveRangeCommon=__name((param,targetRange)=>{var _a20,_b;const toRange=(_a20=param.params)==null?void 0:_a20.toRange,fromRange=(_b=param.params)==null?void 0:_b.fromRange;if(!toRange||!fromRange)return[targetRange];if(!core.Rectangle.intersects(fromRange,targetRange)&&!core.Rectangle.intersects(toRange,targetRange))return[targetRange];if(core.Rectangle.contains(fromRange,targetRange)){const relativeRange=core.Rectangle.getRelativeRange(targetRange,fromRange);return[core.Rectangle.getPositionRange(relativeRange,toRange)]}const matrix=new core.ObjectMatrix;core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)});const fromMatrix=new core.ObjectMatrix,loopFromRange=core.Rectangle.getIntersects(fromRange,targetRange);loopFromRange&&core.Range.foreach(loopFromRange,(row,col)=>{matrix.getValue(row,col)&&(matrix.setValue(row,col,void 0),fromMatrix.setValue(row,col,1))});const columnOffset=toRange.startColumn-fromRange.startColumn,rowOffset=toRange.startRow-fromRange.startRow,loopToRange={startColumn:toRange.startColumn-columnOffset,endColumn:toRange.endColumn-columnOffset,startRow:toRange.startRow-rowOffset,endRow:toRange.endRow-rowOffset};return loopToRange&&core.Range.foreach(loopToRange,(row,col)=>{var _a21;const targetRow=row+rowOffset,targetCol=col+columnOffset;matrix.setValue(targetRow,targetCol,(_a21=fromMatrix.getValue(row,col))!=null?_a21:0)}),core.queryObjectMatrix(matrix,value=>value===1)},"handleMoveRangeCommon"),handleBaseRemoveRange=__name((_removeRange,_targetRange)=>{const removeRange=handleRangeTypeInput(_removeRange),targetRange=handleRangeTypeInput(_targetRange),getLength=__name(range=>range.endColumn-range.startColumn+1,"getLength"),getRowLength=__name(range=>range.endRow-range.startRow+1,"getRowLength");if(removeRange.startRow<=targetRange.startRow&&removeRange.endRow>=targetRange.endRow){if(targetRange.startColumn<removeRange.startColumn&&targetRange.endColumn>=removeRange.startColumn&&targetRange.endColumn<=removeRange.endColumn||targetRange.startColumn<removeRange.startColumn&&targetRange.endColumn>=removeRange.endColumn){const intersectedRange=core.Rectangle.getIntersects(targetRange,removeRange);if(intersectedRange)return{step:0,length:-getLength(intersectedRange)}}if(targetRange.startColumn>=removeRange.startColumn&&targetRange.endColumn<=removeRange.endColumn&&getRowLength(removeRange)>=getRowLength(targetRange))return null;if(targetRange.startColumn>=removeRange.startColumn&&targetRange.startColumn<=removeRange.endColumn&&targetRange.endColumn>removeRange.endColumn){const intersectedRange=core.Rectangle.getIntersects(targetRange,removeRange);if(intersectedRange){const length=-getLength(intersectedRange);return{step:-(getLength(removeRange)-getLength(intersectedRange)),length}}}if(targetRange.startColumn>removeRange.endColumn)return{step:-getLength(removeRange),length:0}}return{step:0,length:0}},"handleBaseRemoveRange"),handleIRemoveCol=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(range,targetRange);if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.HorizontalMove,step,length})}return operators2},"handleIRemoveCol"),handleIRemoveRow=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(rotateRange(range),rotateRange(targetRange));if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.VerticalMove,step,length})}return operators2},"handleIRemoveRow"),handleReorderRange=__name((param,targetRange)=>{const{range,order}=param.params||{};if(!range||!order)return[];if(core.Rectangle.contains(range,targetRange)&&targetRange.endRow===targetRange.startRow){const operators2=[],targetRow=targetRange.startRow;for(const k in order)if(order[k]===targetRow){const toRow=Number(k);return operators2.push({type:OperatorType.VerticalMove,step:toRow-targetRow,length:0}),operators2}return[]}return[]},"handleReorderRange"),handleBaseInsertRange=__name((_insertRange,_targetRange)=>{const insertRange=handleRangeTypeInput(_insertRange),targetRange=handleRangeTypeInput(_targetRange),getLength=__name(range=>range.endColumn-range.startColumn+1,"getLength");if(insertRange.startRow<=targetRange.startRow&&insertRange.endRow>=targetRange.endRow){if(targetRange.startColumn<insertRange.startColumn&&targetRange.endColumn>=insertRange.startColumn&&targetRange.endColumn<=insertRange.endColumn||targetRange.startColumn<insertRange.startColumn&&targetRange.endColumn>=insertRange.endColumn)return{step:0,length:getLength(insertRange)};if(targetRange.startColumn>=insertRange.startColumn&&targetRange.endColumn<=insertRange.endColumn||targetRange.startColumn>insertRange.startColumn&&targetRange.startColumn<=insertRange.endColumn&&targetRange.endColumn>insertRange.endColumn||targetRange.startColumn>=insertRange.endColumn)return{step:getLength(insertRange),length:0}}return{step:0,length:0}},"handleBaseInsertRange");function handleBaseMoveRange(fromRange,toRange,targetRange){const operators2=[];if(core.Rectangle.contains(toRange,targetRange)&&operators2.push({type:OperatorType.Delete}),core.Rectangle.contains(fromRange,targetRange)){operators2.push({type:OperatorType.Delete});const relativeRange=core.Rectangle.getRelativeRange(targetRange,fromRange),positionRange=core.Rectangle.getPositionRange(relativeRange,toRange);return[{type:OperatorType.Set,range:positionRange}]}return operators2}__name(handleBaseMoveRange,"handleBaseMoveRange");const handleInsertRow=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(rotateRange(range),rotateRange(targetRange)),{step,length}=result;return operators2.push({type:OperatorType.VerticalMove,step,length}),operators2},"handleInsertRow"),handleInsertCol=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(range,targetRange),{step,length}=result;return operators2.push({type:OperatorType.HorizontalMove,step,length}),operators2},"handleInsertCol"),handleInsertRangeMoveDown=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(rotateRange(range),rotateRange(targetRange)),{step,length}=result;return operators2.push({type:OperatorType.VerticalMove,step,length}),operators2},"handleInsertRangeMoveDown"),handleInsertRangeMoveDownCommon=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[targetRange];const moveCount=range.endRow-range.startRow+1,bottomRange={...range,startRow:range.startRow,endRow:Number.POSITIVE_INFINITY},noMoveRanges=core.Rectangle.subtract(targetRange,bottomRange),targetMoveRange=core.Rectangle.getIntersects(bottomRange,targetRange);if(!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row+moveCount,col,1)}),core.queryObjectMatrix(matrix,v=>v===1)},"handleInsertRangeMoveDownCommon"),handleInsertRangeMoveRight=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(range,targetRange),{step,length}=result;return operators2.push({type:OperatorType.HorizontalMove,step,length}),operators2},"handleInsertRangeMoveRight"),handleInsertRangeMoveRightCommon=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[targetRange];const moveCount=range.endColumn-range.startColumn+1,bottomRange={...range,startColumn:range.startColumn,endColumn:Number.POSITIVE_INFINITY},noMoveRanges=core.Rectangle.subtract(targetRange,bottomRange),targetMoveRange=core.Rectangle.getIntersects(bottomRange,targetRange);if(!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row,col+moveCount,1)}),core.queryObjectMatrix(matrix,v=>v===1)},"handleInsertRangeMoveRightCommon"),handleDeleteRangeMoveLeft=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(range,targetRange);if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.HorizontalMove,step,length})}return operators2},"handleDeleteRangeMoveLeft"),handleDeleteRangeMoveLeftCommon=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[targetRange];const rightRange={startRow:range.startRow,endRow:range.endRow,startColumn:range.startColumn,endColumn:Number.POSITIVE_INFINITY},moveCount=range.endColumn-range.startColumn+1,targetDeleteRange=core.Rectangle.getIntersects(range,targetRange),noMoveRanges=core.Rectangle.subtract(targetRange,rightRange),targetMoveRange=core.Rectangle.getIntersects(rightRange,targetRange);if(!targetDeleteRange&&!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row,col-moveCount,1)}),targetDeleteRange&&core.Range.foreach(targetDeleteRange,(row,col)=>{matrix.setValue(row,col-moveCount,0)}),noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),core.queryObjectMatrix(matrix,v=>v===1)},"handleDeleteRangeMoveLeftCommon"),handleDeleteRangeMoveUp=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(rotateRange(range),rotateRange(targetRange));if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.VerticalMove,step,length})}return operators2},"handleDeleteRangeMoveUp"),handleDeleteRangeMoveUpCommon=__name((param,targetRange)=>{var _a20;const range=(_a20=param.params)==null?void 0:_a20.range;if(!range)return[targetRange];const bottomRange={...range,startRow:range.startRow,endRow:Number.POSITIVE_INFINITY},moveCount=range.endRow-range.startRow+1,targetDeleteRange=core.Rectangle.getIntersects(range,targetRange),noMoveRanges=core.Rectangle.subtract(targetRange,bottomRange),targetMoveRange=core.Rectangle.getIntersects(bottomRange,targetRange);if(!targetDeleteRange&&!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row-moveCount,col,1)}),targetDeleteRange&&core.Range.foreach(targetDeleteRange,(row,col)=>{matrix.setValue(row-moveCount,col,0)}),noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),core.queryObjectMatrix(matrix,v=>v===1)},"handleDeleteRangeMoveUpCommon"),handleRemoveRowCommon=__name((param,targetRange)=>{var _a20;const ranges=(_a20=param.ranges)!=null?_a20:[param.range],matrix=new core.ObjectMatrix;return core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)}),ranges.forEach(range=>{const startRow=range.startRow,count=range.endRow-startRow+1;matrix.removeRows(startRow,count)}),core.queryObjectMatrix(matrix,value=>value===1)},"handleRemoveRowCommon"),runRefRangeMutations=__name((operators2,range)=>{let result={...range};return operators2.forEach(operator=>{switch(operator.type){case OperatorType.Delete:{result=null;break}case OperatorType.HorizontalMove:{if(!result)return;result.startColumn+=operator.step,result.endColumn+=operator.step+(operator.length||0);break}case OperatorType.VerticalMove:{if(!result)return;result.startRow+=operator.step,result.endRow+=operator.step+(operator.length||0);break}case OperatorType.Set:{result=operator.range;break}}}),result&&(result.endColumn<result.startColumn||result.endRow<result.startRow)?null:result},"runRefRangeMutations"),handleDefaultRangeChangeWithEffectRefCommands=__name((range,commandInfo)=>{let operator=[];switch(commandInfo.id){case EffectRefRangId.DeleteRangeMoveLeftCommandId:{operator=handleDeleteRangeMoveLeft(commandInfo,range);break}case EffectRefRangId.DeleteRangeMoveUpCommandId:{operator=handleDeleteRangeMoveUp(commandInfo,range);break}case EffectRefRangId.InsertColCommandId:{operator=handleInsertCol(commandInfo,range);break}case EffectRefRangId.InsertRangeMoveDownCommandId:{operator=handleInsertRangeMoveDown(commandInfo,range);break}case EffectRefRangId.InsertRangeMoveRightCommandId:{operator=handleInsertRangeMoveRight(commandInfo,range);break}case EffectRefRangId.InsertRowCommandId:{operator=handleInsertRow(commandInfo,range);break}case EffectRefRangId.MoveColsCommandId:{operator=handleMoveCols(commandInfo,range);break}case EffectRefRangId.MoveRangeCommandId:{operator=handleMoveRange(commandInfo,range);break}case EffectRefRangId.MoveRowsCommandId:{operator=handleMoveRows(commandInfo,range);break}case EffectRefRangId.RemoveColCommandId:{operator=handleIRemoveCol(commandInfo,range);break}case EffectRefRangId.RemoveRowCommandId:{operator=handleIRemoveRow(commandInfo,range);break}case EffectRefRangId.ReorderRangeCommandId:{operator=handleReorderRange(commandInfo,range);break}}return runRefRangeMutations(operator,range)},"handleDefaultRangeChangeWithEffectRefCommands"),handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests=__name((range,commandInfo,deps)=>[DeleteRangeMoveLeftCommand.id,DeleteRangeMoveUpCommand.id].includes(commandInfo.id)||getEffectedRangesOnCommand(commandInfo,deps).some(effectRange=>core.Rectangle.intersects(effectRange,range))?handleDefaultRangeChangeWithEffectRefCommands(range,commandInfo):range,"handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests"),handleCommonDefaultRangeChangeWithEffectRefCommands=__name((range,commandInfo)=>{let operator=[];switch(commandInfo.id){case EffectRefRangId.DeleteRangeMoveLeftCommandId:return handleDeleteRangeMoveLeftCommon(commandInfo,range);case EffectRefRangId.DeleteRangeMoveUpCommandId:return handleDeleteRangeMoveUpCommon(commandInfo,range);case EffectRefRangId.InsertRangeMoveDownCommandId:return handleInsertRangeMoveDownCommon(commandInfo,range);case EffectRefRangId.InsertRangeMoveRightCommandId:return handleInsertRangeMoveRightCommon(commandInfo,range);case EffectRefRangId.InsertColCommandId:{operator=handleInsertCol(commandInfo,range);break}case EffectRefRangId.InsertRowCommandId:{operator=handleInsertRow(commandInfo,range);break}case EffectRefRangId.MoveColsCommandId:return handleMoveColsCommon(commandInfo,range);case EffectRefRangId.MoveRangeCommandId:return handleMoveRangeCommon(commandInfo,range);case EffectRefRangId.MoveRowsCommandId:return handleMoveRowsCommon(commandInfo,range);case EffectRefRangId.ReorderRangeCommandId:return handleReorderRangeCommon(commandInfo,range);case EffectRefRangId.RemoveColCommandId:{operator=handleIRemoveCol(commandInfo,range);break}case EffectRefRangId.RemoveRowCommandId:return handleRemoveRowCommon(commandInfo.params,range)}return runRefRangeMutations(operator,range)},"handleCommonDefaultRangeChangeWithEffectRefCommands"),handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests=__name((range,commandInfo,deps)=>[DeleteRangeMoveLeftCommand.id,DeleteRangeMoveUpCommand.id,InsertRangeMoveDownCommand.id,InsertRangeMoveRightCommandId].includes(commandInfo.id)||getEffectedRangesOnCommand(commandInfo,deps).some(effectRange=>core.Rectangle.intersects(effectRange,range))?handleCommonDefaultRangeChangeWithEffectRefCommands(range,commandInfo):range,"handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests");function adjustRangeOnMutation(range,mutation){const{id,params}=mutation;let baseRangeOperator={length:0,step:0,type:OperatorType.Unknown};switch(id){case RemoveSheetMutation.id:baseRangeOperator.type=OperatorType.Delete;break;case MoveRowsMutation.id:baseRangeOperator=handleBaseMoveRowsCols({start:params.sourceRange.startRow,end:params.sourceRange.endRow},{start:params.targetRange.startRow,end:params.targetRange.endRow},{start:range.startRow,end:range.endRow}),baseRangeOperator.type=OperatorType.VerticalMove;break;case MoveColsMutation.id:baseRangeOperator=handleBaseMoveRowsCols({start:params.sourceRange.startColumn,end:params.sourceRange.endColumn},{start:params.targetRange.startColumn,end:params.targetRange.endColumn},{start:range.startColumn,end:range.endColumn}),baseRangeOperator.type=OperatorType.HorizontalMove;break;case RemoveColMutation.id:baseRangeOperator=handleBaseRemoveRange(params.range,range),baseRangeOperator?baseRangeOperator.type=OperatorType.HorizontalMove:baseRangeOperator={step:0,length:0,type:OperatorType.Delete};break;case RemoveRowMutation.id:baseRangeOperator=handleBaseRemoveRange(rotateRange(params.range),rotateRange(range)),baseRangeOperator?baseRangeOperator.type=OperatorType.VerticalMove:baseRangeOperator={step:0,length:0,type:OperatorType.Delete};break;case InsertRowMutation.id:baseRangeOperator=handleBaseInsertRange(rotateRange(params.range),rotateRange(range)),baseRangeOperator.type=OperatorType.VerticalMove;break;case InsertColMutation.id:baseRangeOperator=handleBaseInsertRange(params.range,range),baseRangeOperator.type=OperatorType.HorizontalMove;break;case MoveRangeMutation.id:{const fromRange=params.fromRange||new core.ObjectMatrix(params.from).getRange(),toRange=params.toRange||new core.ObjectMatrix(params.to).getRange();baseRangeOperator=handleBaseMoveRange(fromRange,toRange,range)}break}return baseRangeOperator?Array.isArray(baseRangeOperator)?runRefRangeMutations(baseRangeOperator,range):runRefRangeMutations([baseRangeOperator],range):range}__name(adjustRangeOnMutation,"adjustRangeOnMutation");function getEffectedRangesOnCommand(command,deps){var _a20,_b,_c,_d,_e,_f;const{selectionManagerService}=deps;switch(command.id){case EffectRefRangId.MoveColsCommandId:{const params=command.params;return[params.fromRange,{...params.toRange,startColumn:params.toRange.startColumn-.5,endColumn:params.toRange.endColumn-.5}]}case EffectRefRangId.MoveRowsCommandId:{const params=command.params;return[params.fromRange,{...params.toRange,startRow:params.toRange.startRow-.5,endRow:params.toRange.startRow-.5}]}case EffectRefRangId.MoveRangeCommandId:{const params=command;return[params.params.fromRange,params.params.toRange]}case EffectRefRangId.InsertRowCommandId:{const range=command.params.range;return[{...range,startRow:range.startRow-.5,endRow:range.endRow-.5}]}case EffectRefRangId.InsertColCommandId:{const range=command.params.range;return[{...range,startColumn:range.startColumn-.5,endColumn:range.endColumn-.5}]}case EffectRefRangId.RemoveRowCommandId:return[command.params.range];case EffectRefRangId.RemoveColCommandId:return[command.params.range];case EffectRefRangId.DeleteRangeMoveUpCommandId:case EffectRefRangId.InsertRangeMoveDownCommandId:{const range=((_a20=command.params)==null?void 0:_a20.range)||((_c=(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range))==null?void 0:_c[0]);return range?[range]:[]}case EffectRefRangId.DeleteRangeMoveLeftCommandId:case EffectRefRangId.InsertRangeMoveRightCommandId:{const range=((_d=command.params)==null?void 0:_d.range)||((_f=(_e=selectionManagerService.getCurrentSelections())==null?void 0:_e.map(s=>s.range))==null?void 0:_f[0]);return range?[range]:[]}case EffectRefRangId.ReorderRangeCommandId:{const params=command,{range,order}=params.params,effectRanges=[];for(let row=range.startRow;row<=range.endRow;row++)row in order&&effectRanges.push({startRow:row,endRow:row,startColumn:range.startColumn,endColumn:range.endColumn});return effectRanges}}}__name(getEffectedRangesOnCommand,"getEffectedRangesOnCommand");function getEffectedRangesOnMutation(mutation){switch(mutation.id){case MoveColsMutation.id:{const params=mutation.params;return[params.sourceRange,{...params.targetRange,startColumn:params.targetRange.startColumn-.5,endColumn:params.targetRange.startColumn-.5}]}case MoveRowsMutation.id:{const params=mutation.params;return[params.sourceRange,{...params.targetRange,startRow:params.targetRange.startRow-.5,endRow:params.targetRange.startRow-.5}]}case MoveRangeMutation.id:{const params=mutation.params;return[new core.ObjectMatrix(params.from.value).getRange(),new core.ObjectMatrix(params.to.value).getRange()]}case InsertColMutation.id:{const range=mutation.params.range;return[{...range,startColumn:range.startColumn-.5,endColumn:range.startColumn-.5}]}case InsertRowMutation.id:{const range=mutation.params.range;return[{...range,startRow:range.startRow-.5,endRow:range.startRow-.5}]}case RemoveColMutation.id:return[mutation.params.range];case RemoveRowMutation.id:return[mutation.params.range]}}__name(getEffectedRangesOnMutation,"getEffectedRangesOnMutation");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");const MERGE_REDO=core.createInterceptorKey("MERGE_REDO"),MERGE_UNDO=core.createInterceptorKey("MERGE_UNDO"),MAX_ROW_COL=Math.floor(Number.MAX_SAFE_INTEGER/10),_WatchRange=class _WatchRange extends core.Disposable{constructor(_unitId,_subUnitId,_range,_callback,_skipIntersects=!1){super(),this._unitId=_unitId,this._subUnitId=_subUnitId,this._range=_range,this._callback=_callback,this._skipIntersects=_skipIntersects}onMutation(mutation){var _a20,_b;if(((_a20=mutation.params)==null?void 0:_a20.unitId)!==this._unitId)return;if(mutation.id===MoveRangeMutation.id){const params=mutation.params;if(params.from.subUnitId!==this._subUnitId||params.to.subUnitId!==this._subUnitId)return}else if(((_b=mutation.params)==null?void 0:_b.subUnitId)!==this._subUnitId)return;if(!this._range)return;if(this._skipIntersects){if(mutation.id===RemoveSheetMutation.id)return;const effectRanges=getEffectedRangesOnMutation(mutation);if(effectRanges!=null&&effectRanges.some(effectRange=>core.Rectangle.intersects(effectRange,this._range)))return}const afterRange=adjustRangeOnMutation(this._range,mutation);if(afterRange&&core.Rectangle.equals(afterRange,this._range))return!1;const beforeChange=this._range;this._range=afterRange,this._callback(beforeChange,afterRange)}};__name(_WatchRange,"WatchRange");let WatchRange=_WatchRange;var _a10;exports.RefRangeService=(_a10=class extends core.Disposable{constructor(_commandService,_sheetInterceptorService,_univerInstanceService,_selectionManagerService){super();__publicField(this,"interceptor",new core.InterceptorManager({MERGE_REDO,MERGE_UNDO}));__publicField(this,"_watchRanges",new Set);__publicField(this,"_refRangeManagerMap",new Map);__publicField(this,"_serializer",createRangeSerializer());__publicField(this,"_onRefRangeChange",__name(()=>{this._sheetInterceptorService.interceptCommand({getMutations:__name(command=>{const worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet(),unitId=getUnitId(this._univerInstanceService),subUnitId=getSubUnitId(this._univerInstanceService);if(!worksheet||!unitId||!subUnitId)return{redos:[],undos:[],preRedos:[],preUndos:[]};const result=(__name(()=>{switch(command.id){case EffectRefRangId.MoveColsCommandId:{const params=command.params,startColumn=Math.min(params.fromRange.startColumn,params.toRange.startColumn);return this._checkRange([{...params.fromRange,startColumn,endColumn:worksheet.getColumnCount()-1}],unitId,subUnitId)}case EffectRefRangId.MoveRowsCommandId:{const params=command.params,startRow=Math.min(params.fromRange.startRow,params.toRange.startRow);return this._checkRange([{...params.fromRange,startRow,endRow:worksheet.getRowCount()-1}],unitId,subUnitId)}case EffectRefRangId.MoveRangeCommandId:{const params=command;return this._checkRange([params.params.fromRange,params.params.toRange],unitId,subUnitId)}case EffectRefRangId.InsertRowCommandId:{const range={startRow:command.params.range.startRow,endRow:worksheet.getRowCount()-1,startColumn:0,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ROW};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.InsertColCommandId:{const colStart=command.params.range.startColumn,range={startRow:0,endRow:worksheet.getRowCount()-1,startColumn:colStart,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.COLUMN};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.RemoveRowCommandId:{const range={startRow:command.params.range.startRow,endRow:worksheet.getRowCount()-1,startColumn:0,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ROW};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.RemoveColCommandId:{const colStart=command.params.range.startColumn,range={startRow:0,endRow:worksheet.getRowCount()-1,startColumn:colStart,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.COLUMN};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.DeleteRangeMoveUpCommandId:case EffectRefRangId.InsertRangeMoveDownCommandId:{const range=command.params.range||getSelectionRanges(this._selectionManagerService)[0],effectRange={startRow:range.startRow,startColumn:range.startColumn,endColumn:range.endColumn,endRow:MAX_ROW_COL};return this._checkRange([effectRange],unitId,subUnitId)}case EffectRefRangId.DeleteRangeMoveLeftCommandId:case EffectRefRangId.InsertRangeMoveRightCommandId:{const range=command.params.range||getSelectionRanges(this._selectionManagerService)[0],effectRange={startRow:range.startRow,startColumn:range.startColumn,endColumn:MAX_ROW_COL,endRow:range.endRow};return this._checkRange([effectRange],unitId,subUnitId)}case EffectRefRangId.ReorderRangeCommandId:{const params=command,{range,order}=params.params,effectRanges=[];for(let row=range.startRow;row<=range.endRow;row++)row in order&&effectRanges.push({startRow:row,endRow:row,startColumn:range.startColumn,endColumn:range.endColumn});return this._checkRange(effectRanges,unitId,subUnitId)}}},"getEffectsCbList")()||[]).reduce((result2,currentFn)=>{const v=currentFn(command);return result2.push(v),result2},[]).reduce((result2,currentValue)=>{var _a20,_b;return result2.redos.push(...currentValue.redos),result2.undos.push(...currentValue.undos),result2.preRedos.push(...(_a20=currentValue.preRedos)!=null?_a20:[]),result2.preUndos.push(...(_b=currentValue.preUndos)!=null?_b:[]),result2},{redos:[],undos:[],preUndos:[],preRedos:[]}),preRedos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_REDO)(result.preRedos,null)||[],redos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_REDO)(result.redos,null)||[],preUndos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_UNDO)(result.preUndos,null)||[],undos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_UNDO)(result.undos,null)||[];return{redos,undos,preRedos,preUndos}},"getMutations")})},"_onRefRangeChange"));__publicField(this,"_checkRange",__name((effectRanges,unitId,subUnitId)=>{const managerId=getRefRangId(unitId,subUnitId),manager=this._refRangeManagerMap.get(managerId);if(manager){const callbackSet=new Set;return[...manager.keys()].forEach(key=>{const cbList=manager.get(key),range=this._serializer.deserialize(key),realRange={...range,startRow:+range.startRow,endRow:+range.endRow,startColumn:+range.startColumn,endColumn:+range.endColumn,rangeType:range.rangeType&&+range.rangeType};effectRanges.some(item=>core.Rectangle.intersects(item,realRange))&&cbList&&cbList.forEach(callback=>{callbackSet.add(callback)})}),[...callbackSet]}return[]},"_checkRange"));__publicField(this,"registerRefRange",__name((range,callback,_unitId,_subUnitId)=>{const unitId=_unitId||getUnitId(this._univerInstanceService),subUnitId=_subUnitId||getSubUnitId(this._univerInstanceService);if(!unitId||!subUnitId)return core.toDisposable(()=>{});const refRangeManagerId=getRefRangId(unitId,subUnitId),rangeString=this._serializer.serialize(range);let manager=this._refRangeManagerMap.get(refRangeManagerId);manager||(manager=new Map,this._refRangeManagerMap.set(refRangeManagerId,manager));const refRangeCallbackList=manager.get(rangeString);return refRangeCallbackList?refRangeCallbackList.add(callback):manager.set(rangeString,new Set([callback])),core.toDisposable(()=>{const refRangeCallbackList2=manager.get(rangeString);refRangeCallbackList2&&(refRangeCallbackList2.delete(callback),refRangeCallbackList2.size||(manager.delete(rangeString),manager.size||this._refRangeManagerMap.delete(refRangeManagerId)))})},"registerRefRange"));this._commandService=_commandService,this._sheetInterceptorService=_sheetInterceptorService,this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._onRefRangeChange(),this.interceptor.intercept(this.interceptor.getInterceptPoints().MERGE_REDO,{priority:-1,handler:__name(list=>list,"handler")}),this.interceptor.intercept(this.interceptor.getInterceptPoints().MERGE_UNDO,{priority:-1,handler:__name(list=>list,"handler")})}watchRange(unitId,subUnitId,range,callback,skipIntersects){let watchRangesListener;this._watchRanges.size===0&&(watchRangesListener=this._commandService.onCommandExecuted(command=>{if(command.type!==core.CommandType.MUTATION)return!1;for(const watchRange2 of this._watchRanges)watchRange2.onMutation(command)}));const watchRange=new WatchRange(unitId,subUnitId,range,callback,skipIntersects);this._watchRanges.add(watchRange);const teardownWatching=core.toDisposable(()=>{this._watchRanges.delete(watchRange),this._watchRanges.size===0&&(watchRangesListener==null||watchRangesListener.dispose(),watchRangesListener=null)}),registerToService=this.disposeWithMe(teardownWatching);return core.toDisposable(()=>{registerToService.dispose(),teardownWatching.dispose()})}},__name(_a10,"RefRangeService"),_a10);exports.RefRangeService=__decorateClass$9([core.OnLifecycle(core.LifecycleStages.Ready,exports.RefRangeService),__decorateParam$9(0,core.ICommandService),__decorateParam$9(1,core.Inject(exports.SheetInterceptorService)),__decorateParam$9(2,core.Inject(core.IUniverInstanceService)),__decorateParam$9(3,core.Inject(exports.SheetsSelectionsService))],exports.RefRangeService);function getUnitId(univerInstanceService){return univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()}__name(getUnitId,"getUnitId");function getSubUnitId(univerInstanceService){var _a20;return(_a20=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet())==null?void 0:_a20.getSheetId()}__name(getSubUnitId,"getSubUnitId");function getSelectionRanges(selectionManagerService){var _a20;return((_a20=selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range))||[]}__name(getSelectionRanges,"getSelectionRanges");function getRefRangId(unitId,subUnitId){return`${unitId}_${subUnitId}`}__name(getRefRangId,"getRefRangId");function createRangeSerializer(){const keyList=["startRow","startColumn","endRow","endColumn","rangeType"],SPLIT_CODE="_";return{deserialize:__name(rangeString=>{const map=keyList.reduce((preValue,currentValue,index)=>(preValue[String(index)]=currentValue,preValue),{});return rangeString.split(SPLIT_CODE).reduce((preValue,currentValue,_index)=>{const index=String(_index);return currentValue&&map[index]&&(preValue[map[index]]=currentValue),preValue},{})},"deserialize"),serialize:__name(range=>keyList.reduce((preValue,currentValue,index)=>{const value=range[currentValue];return value!==void 0?`${preValue}${index>0?SPLIT_CODE:""}${value}`:`${preValue}`},""),"serialize")}}__name(createRangeSerializer,"createRangeSerializer");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 mutationIdByRowCol$1=[InsertColMutation.id,InsertRowMutation.id,RemoveColMutation.id,RemoveRowMutation.id],mutationIdArrByMove$1=[MoveRowsMutation.id,MoveColsMutation.id];function getAddMergeMutationRangeByType(selection,type){let ranges=selection;if(type!==void 0){const rectangles=[];for(let i=0;i<ranges.length;i++){const{startRow,endRow,startColumn,endColumn}=ranges[i];if(type===core.Dimension.ROWS)for(let r=startRow;r<=endRow;r++){const data={startRow:r,endRow:r,startColumn,endColumn};rectangles.push(data)}else if(type===core.Dimension.COLUMNS)for(let c=startColumn;c<=endColumn;c++){const data={startRow,endRow,startColumn:c,endColumn:c};rectangles.push(data)}}ranges=rectangles}return ranges}__name(getAddMergeMutationRangeByType,"getAddMergeMutationRangeByType");const MERGE_CELL_INTERCEPTOR_CHECK=core.createInterceptorKey("mergeCellPermissionCheck");var _a11;exports.MergeCellController=(_a11=class extends core.Disposable{constructor(_commandService,_refRangeService,_univerInstanceService,_injector,_sheetInterceptorService,_selectionManagerService){super();__publicField(this,"disposableCollection",new core.DisposableCollection);__publicField(this,"interceptor",new core.InterceptorManager({MERGE_CELL_INTERCEPTOR_CHECK}));this._commandService=_commandService,this._refRangeService=_refRangeService,this._univerInstanceService=_univerInstanceService,this._injector=_injector,this._sheetInterceptorService=_sheetInterceptorService,this._selectionManagerService=_selectionManagerService,this._onRefRangeChange(),this._initCommandInterceptor(),this._commandExecutedListener()}_initCommandInterceptor(){const self=this;this._sheetInterceptorService.interceptCommand({getMutations(commandInfo){var _a20;switch(commandInfo.id){case ClearSelectionAllCommand.id:case ClearSelectionFormatCommand.id:{const workbook=self._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return{redos:[],undos:[]};const subUnitId=worksheet.getSheetId(),mergeData=worksheet.getConfig().mergeData,selections=(_a20=self._selectionManagerService.getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(selections&&selections.length>0&&selections.some(range=>mergeData.some(item=>core.Rectangle.intersects(item,range)))){const removeMergeParams={unitId,subUnitId,ranges:selections},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(self._injector,removeMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos}}}}return{redos:[],undos:[]}}}),this._sheetInterceptorService.interceptRanges({getMutations:__name(({unitId,subUnitId,ranges})=>{const redos=[],undos=[],emptyInterceptorArr={redos,undos};if(!ranges||!ranges.length)return emptyInterceptorArr;const target=getSheetCommandTarget(this._univerInstanceService,{unitId,subUnitId});if(!target)return emptyInterceptorArr;const{worksheet}=target,overlapRanges=worksheet.getMergeData().filter(item=>ranges.some(range=>core.Rectangle.intersects(item,range)));return overlapRanges.length?(redos.push({id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:overlapRanges}}),undos.push({id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:overlapRanges}}),{undos,redos}):emptyInterceptorArr},"getMutations")})}refRangeHandle(config,unitId,subUnitId){switch(config.id){case EffectRefRangId.MoveColsCommandId:{const params=config.params;return this._handleMoveColsCommand(params,unitId,subUnitId)}case EffectRefRangId.MoveRowsCommandId:{const params=config.params;return this._handleMoveRowsCommand(params,unitId,subUnitId)}case InsertRowCommand.id:{const params=config.params,_unitId=params.unitId||unitId,_subUnitId=params.subUnitId||subUnitId;return this._handleInsertRowCommand(params,_unitId,_subUnitId)}case InsertColCommand.id:{const params=config.params,_unitId=params.unitId||unitId,_subUnitId=params.subUnitId||subUnitId;return this._handleInsertColCommand(params,_unitId,_subUnitId)}case RemoveColCommand.id:{const params=config.params;return this._handleRemoveColCommand(params,unitId,subUnitId)}case RemoveRowCommand.id:{const params=config.params;return this._handleRemoveRowCommand(params,unitId,subUnitId)}case MoveRangeCommand.id:{const params=config.params;return this._handleMoveRangeCommand(params,unitId,subUnitId)}case InsertRangeMoveRightCommand.id:{const params=config.params;return this._handleInsertRangeMoveRightCommand(params,unitId,subUnitId)}case InsertRangeMoveDownCommand.id:{const params=config.params;return this._handleInsertRangeMoveDownCommand(params,unitId,subUnitId)}case DeleteRangeMoveUpCommand.id:{const params=config.params;return this._handleDeleteRangeMoveUpCommand(params,unitId,subUnitId)}case DeleteRangeMoveLeftCommand.id:{const params=config.params;return this._handleDeleteRangeMoveLeftCommand(params,unitId,subUnitId)}}return{redos:[],undos:[]}}_onRefRangeChange(){const registerRefRange=__name((unitId,subUnitId)=>{const workbook2=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook2)return;const workSheet=workbook2==null?void 0:workbook2.getSheetBySheetId(subUnitId);if(!workSheet)return;this.disposableCollection.dispose();const mergeData=workSheet.getMergeData(),handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");mergeData.forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))})},"registerRefRange");this.disposeWithMe(this._commandService.onCommandExecuted(commandInfo=>{if(commandInfo.id===SetWorksheetActivateCommand.id){const params=commandInfo.params,sheetId=params.subUnitId,unitId=params.unitId;if(!sheetId||!unitId)return;registerRefRange(unitId,sheetId)}if(commandInfo.id===AddWorksheetMergeMutation.id){const params=commandInfo.params,sheetId=params.subUnitId,unitId=params.unitId;if(!sheetId||!unitId)return;registerRefRange(params.unitId,params.subUnitId)}}));const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(workbook){const sheet=workbook.getActiveSheet();if(!sheet)return;registerRefRange(workbook.getUnitId(),sheet.getSheetId())}}_handleMoveRowsCommand(params,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const mergeData=[...worksheet.getMergeData()],removeParams={unitId,subUnitId,ranges:[]},addParams={unitId,subUnitId,ranges:[]},{fromRange}=params,{startRow:sourceStart,endRow:sourceEnd}=fromRange;if(mergeData.forEach(range=>{if(sourceStart<=range.startRow&&sourceEnd>=range.endRow){removeParams.ranges.push(range);const operation=handleMoveRows({id:EffectRefRangId.MoveRowsCommandId,params},range),result=runRefRangeMutations(operation,range);result&&addParams.ranges.push(result)}}),removeParams.ranges.length===0)return this._handleNull();const removeUndo=RemoveMergeUndoMutationFactory(this._injector,removeParams),addUndo=AddMergeUndoMutationFactory(this._injector,addParams);return{redos:[{id:RemoveWorksheetMergeMutation.id,params:removeParams},{id:AddWorksheetMergeMutation.id,params:addParams}],undos:[{id:RemoveWorksheetMergeMutation.id,params:addUndo},{id:AddWorksheetMergeMutation.id,params:removeUndo}]}}_handleMoveColsCommand(params,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const mergeData=[...worksheet.getMergeData()],removeParams={unitId,subUnitId,ranges:[]},addParams={unitId,subUnitId,ranges:[]},{fromRange}=params,{startColumn:sourceStart,endColumn:sourceEnd}=fromRange;if(mergeData.forEach(range=>{if(sourceStart<=range.startColumn&&sourceEnd>=range.endColumn){removeParams.ranges.push(range);const operation=handleMoveCols({id:EffectRefRangId.MoveColsCommandId,params},range),result=runRefRangeMutations(operation,range);result&&addParams.ranges.push(result)}}),removeParams.ranges.length===0)return this._handleNull();const removeUndo=RemoveMergeUndoMutationFactory(this._injector,removeParams),addUndo=AddMergeUndoMutationFactory(this._injector,addParams);return{redos:[{id:RemoveWorksheetMergeMutation.id,params:removeParams},{id:AddWorksheetMergeMutation.id,params:addParams}],undos:[{id:RemoveWorksheetMergeMutation.id,params:addUndo},{id:AddWorksheetMergeMutation.id,params:removeUndo}]}}_handleMoveRangeCommand(params,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const mergeData=worksheet.getMergeData(),fromMergeRanges=mergeData.filter(item=>core.Rectangle.intersects(item,params.fromRange)),toMergeRanges=mergeData.filter(item=>core.Rectangle.intersects(item,params.toRange)),willMoveToMergeRanges=fromMergeRanges.map(mergeRange=>core.Rectangle.getRelativeRange(mergeRange,params.fromRange)).map(relativeRange=>core.Rectangle.getPositionRange(relativeRange,params.toRange)),addMergeCellRanges=getAddMergeMutationRangeByType(willMoveToMergeRanges).filter(range=>!mergeData.some(mergeRange=>core.Rectangle.equals(range,mergeRange))),redos=[{id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:fromMergeRanges}},{id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:toMergeRanges}},{id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:addMergeCellRanges}}],undos=[{id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:addMergeCellRanges}},{id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:toMergeRanges}},{id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:fromMergeRanges}}];return{redos,undos}}_handleInsertRowCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{range}=config,{startRow,endRow}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(startRow>cell.startRow&&startRow<=cell.endRow&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(startRow>cell.startRow&&startRow<=cell.endRow){const count=endRow-startRow+1;cell.endRow+=count,this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams},{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos}}_handleInsertColCommand(config,unitId,subUnitId){const{range}=config,workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{startColumn,endColumn}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(startColumn>cell.startColumn&&startColumn<=cell.endColumn&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(startColumn>cell.startColumn&&startColumn<=cell.endColumn){const count=endColumn-startColumn+1;cell.endColumn+=count,this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams},{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos}}_handleRemoveColCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{range}=config,{startColumn,endColumn}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(core.Rectangle.intersects(range,cell)&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(core.Rectangle.intersects(range,cell)){if(startColumn<=cell.startColumn&&endColumn>=cell.endColumn)return mergeCellsHasLapping;startColumn>=cell.startColumn&&endColumn<=cell.endColumn?cell.endColumn-=endColumn-startColumn+1:startColumn<cell.startColumn?(cell.startColumn=startColumn,cell.endColumn-=endColumn-startColumn+1):endColumn>cell.endColumn&&(cell.endColumn=startColumn-1),this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeMutationParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeMutationParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeMutationParams),addMergeMutationParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeMutationParams),preRedos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}],redos=[{id:AddWorksheetMergeMutation.id,params:addMergeMutationParams}],preUndos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}];return{preUndos,undos,preRedos,redos}}_handleRemoveRowCommand(config,unitId,subUnitId){const{range}=config,workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{startRow,endRow}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(core.Rectangle.intersects(range,cell)&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(core.Rectangle.intersects(range,cell)){if(startRow<=cell.startRow&&endRow>=cell.endRow)return mergeCellsHasLapping;startRow>=cell.startRow&&endRow<=cell.endRow?cell.endRow-=endRow-startRow+1:startRow<cell.startRow?(cell.startRow=startRow,cell.endRow-=endRow-startRow+1):endRow>cell.endRow&&(cell.endRow=startRow-1),this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeMutationParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeMutationParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeMutationParams),addMergeMutationParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeMutationParams),preRedos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}],redos=[{id:AddWorksheetMergeMutation.id,params:addMergeMutationParams}],preUndos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}];return{preUndos,undos,preRedos,redos}}_handleInsertRangeMoveRightCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxCol=worksheet.getMaxColumns()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,endRow,startColumn,endColumn}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow,endColumn:maxCol},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow,endColumn:maxCol},rect))){const currentColumnsCount=endColumn-startColumn+1;addMergeData.push({startRow:rect.startRow,startColumn:rect.startColumn+currentColumnsCount,endRow:rect.endRow,endColumn:rect.endColumn+currentColumnsCount})}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams);return{redos:[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos:[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams},{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}]}}_handleInsertRangeMoveDownCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxRow=worksheet.getMaxRows()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,startColumn,endColumn,endRow}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow:maxRow,endColumn},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow:maxRow,endColumn},rect))){const rowCount=endRow-startRow+1;addMergeData.push({startRow:rect.startRow+rowCount,startColumn:rect.startColumn,endRow:rect.endRow+rowCount,endColumn:rect.endColumn})}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams},{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}];return{redos,undos}}_handleDeleteRangeMoveUpCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxRow=worksheet.getMaxRows()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,startColumn,endColumn,endRow}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow:maxRow,endColumn},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow:maxRow,endColumn},rect))){const rowCount=endRow-startRow+1,range2=core.Rectangle.moveVertical(rect,-rowCount);addMergeData.push(range2)}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams},{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}];return{redos,undos}}_handleDeleteRangeMoveLeftCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxCol=worksheet.getMaxColumns()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,endRow,startColumn,endColumn}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow,endColumn:maxCol},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow,endColumn:maxCol},rect))){const currentColumnsCount=endColumn-startColumn+1;addMergeData.push({startRow:rect.startRow,startColumn:rect.startColumn-currentColumnsCount,endRow:rect.endRow,endColumn:rect.endColumn-currentColumnsCount})}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams);return{redos:[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos:[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams},{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}]}}_checkIsMergeCell(cell){return!(cell.startRow===cell.endRow&&cell.startColumn===cell.endColumn)}_handleNull(){return{redos:[],undos:[]}}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(mutationIdArrByMove$1.includes(command.id)){if(!command.params)return;const workbook=this._univerInstanceService.getUniverSheetInstance(command.params.unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const{sourceRange,targetRange}=command.params,isRowMove=sourceRange.startColumn===targetRange.startColumn&&sourceRange.endColumn===targetRange.endColumn,moveLength=isRowMove?sourceRange.endRow-sourceRange.startRow+1:sourceRange.endColumn-sourceRange.startColumn+1,sourceStart=isRowMove?sourceRange.startRow:sourceRange.startColumn,targetStart=isRowMove?targetRange.startRow:targetRange.startColumn,mergeData=worksheet.getConfig().mergeData,adjustedMergedCells=[];mergeData.forEach(merge=>{let{startRow,endRow,startColumn,endColumn,rangeType}=merge;core.Rectangle.intersects(merge,sourceRange)||(isRowMove?sourceStart<startRow&&targetStart>endRow?(startRow-=moveLength,endRow-=moveLength):sourceStart>endRow&&targetStart<=startRow&&(startRow+=moveLength,endRow+=moveLength):sourceStart<startColumn&&targetStart>endColumn?(startColumn-=moveLength,endColumn-=moveLength):sourceStart>endColumn&&targetStart<=startColumn&&(startColumn+=moveLength,endColumn+=moveLength)),merge.startRow===merge.endRow&&merge.startColumn===merge.endColumn||adjustedMergedCells.push({startRow,endRow,startColumn,endColumn,rangeType})}),worksheet.setMergeData(adjustedMergedCells),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");adjustedMergedCells.forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))})}if(mutationIdByRowCol$1.includes(command.id)){const workbook=this._univerInstanceService.getUniverSheetInstance(command.params.unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const mergeData=worksheet.getConfig().mergeData,params=command.params;if(!params)return;const{range}=params,isRowOperation=command.id.includes("row"),isAddOperation=command.id.includes("insert"),operationStart=isRowOperation?range.startRow:range.startColumn,operationEnd=isRowOperation?range.endRow:range.endColumn,operationCount=operationEnd-operationStart+1,adjustedMergedCells=[];mergeData.forEach(merge=>{let{startRow,endRow,startColumn,endColumn,rangeType}=merge;isAddOperation?isRowOperation?operationStart<=startRow&&(startRow+=operationCount,endRow+=operationCount):operationStart<=startColumn&&(startColumn+=operationCount,endColumn+=operationCount):isRowOperation?operationEnd<startRow&&(startRow-=operationCount,endRow-=operationCount):operationEnd<startColumn&&(startColumn-=operationCount,endColumn-=operationCount),merge.startRow===merge.endRow&&merge.startColumn===merge.endColumn||adjustedMergedCells.push({startRow,endRow,startColumn,endColumn,rangeType})}),worksheet.setMergeData(adjustedMergedCells),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");adjustedMergedCells.forEach(range2=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range2,handler,unitId,subUnitId))})}}))}},__name(_a11,"MergeCellController"),_a11);exports.MergeCellController=__decorateClass$8([core.OnLifecycle(core.LifecycleStages.Steady,exports.MergeCellController),__decorateParam$8(0,core.Inject(core.ICommandService)),__decorateParam$8(1,core.Inject(exports.RefRangeService)),__decorateParam$8(2,core.Inject(core.IUniverInstanceService)),__decorateParam$8(3,core.Inject(core.Injector)),__decorateParam$8(4,core.Inject(exports.SheetInterceptorService)),__decorateParam$8(5,core.Inject(exports.SheetsSelectionsService))],exports.MergeCellController);function getWorkbook(univerInstanceService,unitId){return unitId?univerInstanceService.getUniverSheetInstance(unitId):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET)}__name(getWorkbook,"getWorkbook");function getWorksheet(workbook,subUnitId){return subUnitId?workbook.getSheetBySheetId(subUnitId):workbook.getActiveSheet()}__name(getWorksheet,"getWorksheet");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"),_a12;exports.NumfmtService=(_a12=class extends core.Disposable{constructor(_resourceManagerService,_univerInstanceService,_logService){super(),this._resourceManagerService=_resourceManagerService,this._univerInstanceService=_univerInstanceService,this._logService=_logService}getValue(unitId,subUnitId,row,col){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!worksheet)return;const styles=workbook.getStyles(),cell=worksheet.getCellRaw(row,col);if(cell!=null&&cell.s){const style=styles.get(cell.s);if(style!=null&&style.n)return style.n}return null}deleteValues(unitId,subUnitId,values){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!worksheet)return;const styles=workbook.getStyles();values.forEach(range=>{core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCellRaw(row,col);if(!cell)return;const oldStyleId=cell==null?void 0:cell.s,newStyle={...oldStyleId&&styles.get(oldStyleId)||{}};delete newStyle.n;const newStyleId=styles.setValue(newStyle);cell.s=newStyleId})})}setValues(unitId,subUnitId,values){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!worksheet)return;const styles=workbook.getStyles(),matrix=worksheet.getCellMatrix();values.forEach(value=>{value.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCellRaw(row,col);if(cell){const newStyle={...styles.getStyleByCell(cell)||{},n:{pattern:value.pattern}},styleId=styles.setValue(newStyle);cell.s=styleId;const type=getCellTypeByPattern(cell,value.pattern);cell.v!==void 0&&(cell.t=type,cell.v=getCellValue(type,cell))}else{const style={n:{pattern:value.pattern}},styleId=styles.setValue(style);styleId&&matrix.setValue(row,col,{s:styleId})}})})})}},__name(_a12,"NumfmtService"),_a12);exports.NumfmtService=__decorateClass$7([__decorateParam$7(0,core.IResourceManagerService),__decorateParam$7(1,core.IUniverInstanceService),__decorateParam$7(2,core.ILogService)],exports.NumfmtService);const getAllWorkbookPermissionPoint=__name(()=>[WorkbookEditablePermission,WorkbookPrintPermission,WorkbookCommentPermission,WorkbookViewPermission,WorkbookCopyPermission,WorkbookExportPermission,WorkbookManageCollaboratorPermission,WorkbookCreateSheetPermission,WorkbookDeleteSheetPermission,WorkbookRenameSheetPermission,WorkbookHideSheetPermission,WorkbookDuplicatePermission,WorkbookSharePermission,WorkbookMoveSheetPermission,WorkbookCopySheetPermission,WorkbookViewHistoryPermission,WorkbookRecoverHistoryPermission],"getAllWorkbookPermissionPoint"),defaultWorkbookPermissionPoints=[P.Edit,P.Print,P.Comment,P.View,P.Copy,P.Export,P.ManageCollaborator,P.CreateSheet,P.DeleteSheet,P.RenameSheet,P.HideSheet,P.Duplicate,P.Share,P.MoveSheet,P.CopySheet,P.RecoverHistory,P.ViewHistory];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"),_a13;exports.WorkbookPermissionService=(_a13=class extends core.Disposable{constructor(_permissionService,_univerInstanceService,_rangeProtectionRuleModel){super(),this._permissionService=_permissionService,this._univerInstanceService=_univerInstanceService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._init()}_init(){const handleWorkbook=__name(workbook=>{const unitId=workbook.getUnitId();getAllWorkbookPermissionPoint().forEach(F=>{const instance=new F(unitId);this._permissionService.addPermissionPoint(instance)})},"handleWorkbook");this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>{handleWorkbook(workbook)}),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{handleWorkbook(workbook)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{const unitId=workbook.getUnitId();workbook.getSheets().forEach(worksheet=>{const subUnitId=worksheet.getSheetId();this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{[RangeProtectionPermissionEditPoint,RangeProtectionPermissionViewPoint].forEach(F=>{const instance=new F(unitId,subUnitId,rule.permissionId);this._permissionService.deletePermissionPoint(instance.id)})}),[...getAllWorksheetPermissionPoint(),...getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.deletePermissionPoint(instance.id)})}),getAllWorkbookPermissionPoint().forEach(F=>{const instance=new F(unitId);this._permissionService.deletePermissionPoint(instance.id)})}))}},__name(_a13,"WorkbookPermissionService"),_a13);exports.WorkbookPermissionService=__decorateClass$6([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorkbookPermissionService),__decorateParam$6(0,core.Inject(core.IPermissionService)),__decorateParam$6(1,core.Inject(core.IUniverInstanceService)),__decorateParam$6(2,core.Inject(exports.RangeProtectionRuleModel))],exports.WorkbookPermissionService);var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__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");const SHEET_DEFINED_NAME_PLUGIN="SHEET_DEFINED_NAME_PLUGIN";var _a14;exports.DefinedNameDataController=(_a14=class extends core.Disposable{constructor(_definedNamesService,_resourceManagerService){super(),this._definedNamesService=_definedNamesService,this._resourceManagerService=_resourceManagerService,this._initialize()}_initialize(){this._initSnapshot()}_initSnapshot(){const toJson=__name(unitId=>{const map=this._definedNamesService.getDefinedNameMap(unitId);return map?JSON.stringify(map):""},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({pluginName:SHEET_DEFINED_NAME_PLUGIN,businesses:[core.UniverInstanceType.UNIVER_SHEET],toJson:__name(unitId=>toJson(unitId),"toJson"),parseJson:__name(json=>parseJson(json),"parseJson"),onUnLoad:__name(unitId=>{this._definedNamesService.removeUnitDefinedName(unitId)},"onUnLoad"),onLoad:__name((unitId,value)=>{this._definedNamesService.registerDefinedNames(unitId,value)},"onLoad")}))}},__name(_a14,"DefinedNameDataController"),_a14);exports.DefinedNameDataController=__decorateClass$5([core.OnLifecycle(core.LifecycleStages.Ready,exports.DefinedNameDataController),__decorateParam$5(0,engineFormula.IDefinedNamesService),__decorateParam$5(1,core.IResourceManagerService)],exports.DefinedNameDataController);const getAllRangePermissionPoint=__name(()=>[RangeProtectionPermissionViewPoint,RangeProtectionPermissionEditPoint],"getAllRangePermissionPoint"),getDefaultRangePermission=__name((unitId="unitId",subUnitId="subUnitId",permissionId="permissionId")=>getAllRangePermissionPoint().reduce((r,F)=>{const i=new F(unitId,subUnitId,permissionId);return r[i.subType]=i.value,r},{}),"getDefaultRangePermission");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"),_a15;exports.RangeProtectionRenderModel=(_a15=class{constructor(_selectionProtectionRuleModel,_permissionService){__publicField(this,"_cache",new core.LRUMap(1e4));this._selectionProtectionRuleModel=_selectionProtectionRuleModel,this._permissionService=_permissionService,this._init()}_init(){this._permissionService.permissionPointUpdate$.pipe(operators.filter(permission=>permission.type===M.SelectRange),operators.filter(permission=>getAllRangePermissionPoint().some(F=>permission instanceof F)),operators.map(permission=>permission)).subscribe(permission=>{const ruleMap=this._selectionProtectionRuleModel.getSubunitRuleList(permission.unitId,permission.subUnitId);for(const rule of ruleMap)rule.permissionId===permission.permissionId&&rule.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const key=this._createKey(permission.unitId,permission.subUnitId,row,col);this._cache.delete(key)})})}),this._selectionProtectionRuleModel.ruleChange$.subscribe(info=>{var _a20;info.rule.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const key=this._createKey(info.unitId,info.subUnitId,row,col);this._cache.delete(key)})}),info.type==="set"&&((_a20=info.oldRule)==null||_a20.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const key=this._createKey(info.unitId,info.subUnitId,row,col);this._cache.delete(key)})}))})}_createKey(unitId,subUnitId,row,col){return`${unitId}_${subUnitId}_${row}_${col}`}getCellInfo(unitId,subUnitId,row,col){const key=this._createKey(unitId,subUnitId,row,col),cacheValue=this._cache.get(key);if(cacheValue)return cacheValue;const ruleMap=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId),defaultV=[];if(!ruleMap||!ruleMap.length)return defaultV;const result=[];for(const rule of ruleMap)if(rule.ranges.some(range=>range.startRow<=row&&range.endRow>=row&&range.startColumn<=col&&range.endColumn>=col)){const permissionMap=getAllRangePermissionPoint().reduce((result2,F)=>{var _a20;const instance=new F(unitId,subUnitId,rule.permissionId),permission=this._permissionService.getPermissionPoint(instance.id);return result2[instance.subType]=(_a20=permission==null?void 0:permission.value)!=null?_a20:instance.value,result2},{});result.push({...permissionMap,ruleId:rule.id,ranges:rule.ranges})}return this._cache.set(key,result),result}clear(){this._cache.clear()}},__name(_a15,"RangeProtectionRenderModel"),_a15);exports.RangeProtectionRenderModel=__decorateClass$4([core.OnLifecycle(core.LifecycleStages.Ready,exports.RangeProtectionRenderModel),__decorateParam$4(0,core.Inject(exports.RangeProtectionRuleModel)),__decorateParam$4(1,core.Inject(core.IPermissionService))],exports.RangeProtectionRenderModel);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");const mutationIdByRowCol=[InsertColMutation.id,InsertRowMutation.id,RemoveColMutation.id,RemoveRowMutation.id],mutationIdArrByMove=[MoveRowsMutation.id,MoveColsMutation.id];var _a16;exports.RangeProtectionRefRangeService=(_a16=class extends core.Disposable{constructor(_selectionProtectionRuleModel,_univerInstanceService,_commandService,_refRangeService,_selectionProtectionRenderModel){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._selectionProtectionRuleModel=_selectionProtectionRuleModel,this._univerInstanceService=_univerInstanceService,this._commandService=_commandService,this._refRangeService=_refRangeService,this._selectionProtectionRenderModel=_selectionProtectionRenderModel,this._onRefRangeChange(),this._correctPermissionRange()}_onRefRangeChange(){const registerRefRange=__name((unitId,subUnitId)=>{const workbook2=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook2||!(workbook2==null?void 0:workbook2.getSheetBySheetId(subUnitId)))return;this.disposableCollection.dispose();const handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p,c)=>[...p,...c.ranges],[]).forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))})},"registerRefRange");this.disposeWithMe(this._commandService.onCommandExecuted(commandInfo=>{if(commandInfo.id===SetWorksheetActivateCommand.id){const params=commandInfo.params,sheetId=params.subUnitId,unitId=params.unitId;if(!sheetId||!unitId)return;registerRefRange(unitId,sheetId)}if(commandInfo.id===SetRangeProtectionMutation.id||commandInfo.id===AddRangeProtectionMutation.id){const params=commandInfo.params,subUnitId=params.subUnitId,unitId=params.unitId;if(!subUnitId||!unitId)return;registerRefRange(unitId,subUnitId)}}));const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(workbook){const sheet=workbook.getActiveSheet();if(!sheet)return;registerRefRange(workbook.getUnitId(),sheet.getSheetId())}}refRangeHandle(config,unitId,subUnitId){switch(config.id){case MoveRowsCommand.id:return this._getRefRangeMutationsByMoveRows(config.params,unitId,subUnitId);case MoveColsCommand.id:return this._getRefRangeMutationsByMoveCols(config.params,unitId,subUnitId);case InsertRowCommand.id:return this._getRefRangeMutationsByInsertRows(config.params,unitId,subUnitId);case InsertColCommand.id:return this._getRefRangeMutationsByInsertCols(config.params,unitId,subUnitId);case RemoveColCommand.id:return this._getRefRangeMutationsByDeleteCols(config.params,unitId,subUnitId);case RemoveRowCommand.id:return this._getRefRangeMutationsByDeleteRows(config.params,unitId,subUnitId)}return{redos:[],undos:[]}}_getRefRangeMutationsByDeleteCols(params,unitId,subUnitId){const permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>core.Rectangle.intersects(range,params.range))),removeRange=params.range;if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),rangesByRemove=cloneRule.ranges.reduce((p,c)=>{if(core.Rectangle.intersects(c,removeRange)){const cloneRange=core.Tools.deepClone(c),{startColumn,endColumn}=removeRange;if(startColumn<=cloneRange.startColumn&&endColumn>=cloneRange.endColumn)return p;startColumn>=cloneRange.startColumn&&endColumn<=cloneRange.endColumn?cloneRange.endColumn-=endColumn-startColumn+1:startColumn<cloneRange.startColumn?(cloneRange.startColumn=startColumn,cloneRange.endColumn-=endColumn-startColumn+1):endColumn>cloneRange.endColumn&&(cloneRange.endColumn=startColumn-1),this._checkIsRightRange(cloneRange)&&p.push(cloneRange)}return p},[]);cloneRule.ranges=rangesByRemove,cloneRule.ranges.length?(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}})):(redoMutations.push({id:DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:[rule.id]}}),undoMutations.push({id:AddRangeProtectionMutation.id,params:{unitId,subUnitId,name:"",rules:[rule]}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByDeleteRows(params,unitId,subUnitId){const permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>core.Rectangle.intersects(range,params.range))),removeRange=params.range;if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),rangesByRemove=cloneRule.ranges.reduce((p,c)=>{if(core.Rectangle.intersects(c,removeRange)){const cloneRange=core.Tools.deepClone(c),{startRow,endRow}=removeRange;if(startRow<=cloneRange.startRow&&endRow>=cloneRange.endRow)return p;startRow>=cloneRange.startRow&&endRow<=cloneRange.endRow?cloneRange.endRow-=endRow-startRow+1:startRow<cloneRange.startRow?(cloneRange.startRow=startRow,cloneRange.endRow-=endRow-startRow+1):endRow>cloneRange.endRow&&(cloneRange.endRow=startRow-1),this._checkIsRightRange(cloneRange)&&p.push(cloneRange)}return p},[]);cloneRule.ranges=rangesByRemove,redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}})}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByInsertCols(params,unitId,subUnitId){const insertStart=params.range.startColumn,insertLength=params.range.endColumn-params.range.startColumn+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>insertStart>range.startColumn&&insertStart<=range.endColumn));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule);let hasLap=!1;cloneRule.ranges.forEach(range=>{insertStart>range.startColumn&&insertStart<=range.endColumn&&(range.endColumn+=insertLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByInsertRows(params,unitId,subUnitId){const insertStart=params.range.startRow,insertLength=params.range.endRow-params.range.startRow+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>insertStart>range.startRow&&insertStart<=range.endRow));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule);let hasLap=!1;cloneRule.ranges.forEach(range=>{insertStart>range.startRow&&insertStart<=range.endRow&&(range.endRow+=insertLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByMoveRows(params,unitId,subUnitId){const toRange=params.toRange,moveToStartRow=toRange.startRow,moveLength=toRange.endRow-toRange.startRow+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>moveToStartRow>range.startRow&&moveToStartRow<=range.endRow));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),moveFromStartRow=params.fromRange.startRow;let hasLap=!1;cloneRule.ranges.forEach(range=>{moveToStartRow>range.startRow&&moveToStartRow<=range.endRow&&(moveFromStartRow<range.startRow&&(range.startRow=range.startRow-moveLength,range.endRow=range.endRow-moveLength),range.endRow+=moveLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByMoveCols(params,unitId,subUnitId){const toRange=params.toRange,moveToStartCol=toRange.startColumn,moveLength=toRange.endColumn-toRange.startColumn+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>moveToStartCol>range.startColumn&&moveToStartCol<=range.endColumn));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),moveFromStartCol=params.fromRange.startColumn;let hasLap=!1;cloneRule.ranges.forEach(range=>{moveToStartCol>range.startColumn&&moveToStartCol<=range.endColumn&&(moveFromStartCol<range.startColumn&&(range.startColumn=range.startColumn-moveLength,range.endColumn=range.endColumn-moveLength),range.endColumn+=moveLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_correctPermissionRange(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(mutationIdArrByMove.includes(command.id)){if(!command.params)return;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const{sourceRange,targetRange}=command.params,isRowMove=sourceRange.startColumn===targetRange.startColumn&&sourceRange.endColumn===targetRange.endColumn,moveLength=isRowMove?sourceRange.endRow-sourceRange.startRow+1:sourceRange.endColumn-sourceRange.startColumn+1,sourceStart=isRowMove?sourceRange.startRow:sourceRange.startColumn,targetStart=isRowMove?targetRange.startRow:targetRange.startColumn;this._selectionProtectionRuleModel.getSubunitRuleList(workbook.getUnitId(),worksheet.getSheetId()).forEach(rule=>{rule.ranges.forEach(range=>{let{startRow,endRow,startColumn,endColumn}=range;core.Rectangle.intersects(range,sourceRange)||(isRowMove?sourceStart<startRow&&targetStart>endRow?(startRow-=moveLength,endRow-=moveLength):sourceStart>endRow&&targetStart<=startRow&&(startRow+=moveLength,endRow+=moveLength):sourceStart<startColumn&&targetStart>endColumn?(startColumn-=moveLength,endColumn-=moveLength):sourceStart>endColumn&&targetStart<=startColumn&&(startColumn+=moveLength,endColumn+=moveLength)),this._checkIsRightRange({startRow,endRow,startColumn,endColumn})&&(range.startColumn=startColumn,range.endColumn=endColumn,range.startRow=startRow,range.endRow=endRow)})}),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p,c)=>[...p,...c.ranges],[]).forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))}),this._selectionProtectionRenderModel.clear()}if(mutationIdByRowCol.includes(command.id)){const workbook=this._univerInstanceService.getUniverSheetInstance(command.params.unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const params=command.params;if(!params)return;const{range}=params,isRowOperation=command.id.includes("row"),isAddOperation=command.id.includes("insert"),operationStart=isRowOperation?range.startRow:range.startColumn,operationEnd=isRowOperation?range.endRow:range.endColumn,operationCount=operationEnd-operationStart+1;this._selectionProtectionRuleModel.getSubunitRuleList(workbook.getUnitId(),worksheet.getSheetId()).forEach(rule=>{rule.ranges.forEach(range2=>{let{startRow,endRow,startColumn,endColumn}=range2;isAddOperation?isRowOperation?operationStart<=startRow&&(startRow+=operationCount,endRow+=operationCount):operationStart<=startColumn&&(startColumn+=operationCount,endColumn+=operationCount):isRowOperation?operationEnd<startRow&&(startRow-=operationCount,endRow-=operationCount):operationEnd<startColumn&&(startColumn-=operationCount,endColumn-=operationCount),this._checkIsRightRange({startRow,endRow,startColumn,endColumn})&&(range2.startColumn=startColumn,range2.endColumn=endColumn,range2.startRow=startRow,range2.endRow=endRow)})}),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p,c)=>[...p,...c.ranges],[]).forEach(range2=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range2,handler,unitId,subUnitId))}),this._selectionProtectionRenderModel.clear()}}))}_checkIsRightRange(range){return range.startRow<=range.endRow&&range.startColumn<=range.endColumn}},__name(_a16,"RangeProtectionRefRangeService"),_a16);exports.RangeProtectionRefRangeService=__decorateClass$3([core.OnLifecycle(core.LifecycleStages.Ready,exports.RangeProtectionRefRangeService),__decorateParam$3(0,core.Inject(exports.RangeProtectionRuleModel)),__decorateParam$3(1,core.Inject(core.IUniverInstanceService)),__decorateParam$3(2,core.ICommandService),__decorateParam$3(3,core.Inject(exports.RefRangeService)),__decorateParam$3(4,core.Inject(exports.RangeProtectionRenderModel))],exports.RangeProtectionRefRangeService);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");const PLUGIN_NAME$1="SHEET_RANGE_PROTECTION_PLUGIN";var _a17;exports.RangeProtectionService=(_a17=class extends core.Disposable{constructor(_selectionProtectionRuleModel,_permissionService,_resourceManagerService){super(),this._selectionProtectionRuleModel=_selectionProtectionRuleModel,this._permissionService=_permissionService,this._resourceManagerService=_resourceManagerService,this._initSnapshot(),this._initRuleChange()}_initRuleChange(){this.disposeWithMe(this._selectionProtectionRuleModel.ruleChange$.subscribe(info=>{switch(info.type){case"add":{getAllRangePermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId,info.rule.permissionId);this._permissionService.addPermissionPoint(instance)});break}case"delete":{getAllRangePermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId,info.rule.permissionId);this._permissionService.deletePermissionPoint(instance.id)});break}case"set":{info.oldRule.permissionId!==info.rule.permissionId&&getAllRangePermissionPoint().forEach(F=>{const oldPermissionPoint=new F(info.unitId,info.subUnitId,info.oldRule.permissionId);this._permissionService.deletePermissionPoint(oldPermissionPoint.id);const newPermissionPoint=new F(info.unitId,info.subUnitId,info.rule.permissionId);this._permissionService.addPermissionPoint(newPermissionPoint)});break}}}))}_initSnapshot(){const toJson=__name(unitID=>{const v=this._selectionProtectionRuleModel.toObject()[unitID];return v?JSON.stringify(v):""},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({toJson,parseJson,pluginName:PLUGIN_NAME$1,businesses:[I.UNIVER_SHEET],onLoad:__name((unitId,resources)=>{const result=this._selectionProtectionRuleModel.toObject();result[unitId]=resources,this._selectionProtectionRuleModel.fromObject(result);const allAllowedParams=[];Object.keys(resources).forEach(subUnitId=>{const list=resources[subUnitId];this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{allAllowedParams.push({objectID:rule.permissionId,unitID:unitId,objectType:M.SelectRange,actions:[P.View,P.Edit]})}),list.forEach(rule=>{getAllRangePermissionPoint().forEach(Factor=>{const instance=new Factor(unitId,subUnitId,rule.permissionId);instance.value=!1,this._permissionService.addPermissionPoint(instance)})})})},"onLoad"),onUnLoad:__name(unitId=>{this._selectionProtectionRuleModel.deleteUnitModel(unitId)},"onUnLoad")}))}},__name(_a17,"RangeProtectionService"),_a17);exports.RangeProtectionService=__decorateClass$2([__decorateParam$2(0,core.Inject(exports.RangeProtectionRuleModel)),__decorateParam$2(1,core.Inject(core.IPermissionService)),__decorateParam$2(2,core.Inject(core.IResourceManagerService))],exports.RangeProtectionService);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"),_a18;let NumberCellDisplayController=(_a18=class extends core.Disposable{constructor(_sheetInterceptorService){super(),this._sheetInterceptorService=_sheetInterceptorService,this._initialize()}_initialize(){this._initInterceptorCellContent()}_initInterceptorCellContent(){this.disposeWithMe(this._sheetInterceptorService.intercept(INTERCEPTOR_POINT.CELL_CONTENT,{priority:11,handler:__name((cell,location,next)=>{var _a20;const style=location.workbook.getStyles().getStyleByCell(cell);return(_a20=style==null?void 0:style.n)!=null&&_a20.pattern?next({...cell}):(cell==null?void 0:cell.t)===core.CellValueType.NUMBER&&typeof(cell==null?void 0:cell.v)=="number"?next({...cell,v:engineFormula.stripErrorMargin(cell.v)}):next({...cell})},"handler")}))}},__name(_a18,"NumberCellDisplayController"),_a18);NumberCellDisplayController=__decorateClass$1([core.OnLifecycle(core.LifecycleStages.Ready,NumberCellDisplayController),__decorateParam$1(0,core.Inject(exports.SheetInterceptorService))],NumberCellDisplayController);const IExclusiveRangeService=core.createIdentifier("univer.exclusive-range-service"),_ExclusiveRangeService=class _ExclusiveRangeService extends core.Disposable{constructor(){super(...arguments);__publicField(this,"_exclusiveRanges",new Map)}_ensureUnitMap(unitId){return this._exclusiveRanges.has(unitId)||this._exclusiveRanges.set(unitId,new Map),this._exclusiveRanges.get(unitId)}_ensureSubunitMap(unitId,sheetId){const unitMap=this._ensureUnitMap(unitId);return unitMap.has(sheetId)||unitMap.set(sheetId,new Map),unitMap.get(sheetId)}_ensureFeature(unitId,sheetId,feature){const subunitMap=this._ensureSubunitMap(unitId,sheetId);return subunitMap.has(feature)||subunitMap.set(feature,[]),subunitMap.get(feature)}addExclusiveRange(unitId,sheetId,feature,ranges){this._ensureFeature(unitId,sheetId,feature).push(...ranges)}getExclusiveRanges(unitId,sheetId,feature){var _a20,_b;return(_b=(_a20=this._exclusiveRanges.get(unitId))==null?void 0:_a20.get(sheetId))==null?void 0:_b.get(feature)}clearExclusiveRanges(unitId,sheetId,feature){this._ensureFeature(unitId,sheetId,feature),this._exclusiveRanges.get(unitId).get(sheetId).set(feature,[])}clearExclusiveRangesByGroupId(unitId,sheetId,feature,groupId){const featureMap=this.getExclusiveRanges(unitId,sheetId,feature);if(featureMap){const newFeatureMap=featureMap.filter(item=>item.groupId!==groupId);this._exclusiveRanges.get(unitId).get(sheetId).set(feature,newFeatureMap)}}getInterestGroupId(selections){const interestGroupId=[];return selections.forEach(selection=>{var _a20;const range=selection.range,{unitId,sheetId}=range;if(!unitId||!sheetId)return;const featureMap=(_a20=this._exclusiveRanges.get(unitId))==null?void 0:_a20.get(sheetId);if(featureMap)for(const feature of featureMap.keys()){const featureMapRanges=featureMap.get(feature);if(featureMapRanges){for(const featureMapRange of featureMapRanges)if(core.Rectangle.intersects(range,featureMapRange.range)){interestGroupId.push(feature);break}}}}),interestGroupId}};__name(_ExclusiveRangeService,"ExclusiveRangeService");let ExclusiveRangeService=_ExclusiveRangeService;const PLUGIN_CONFIG_KEY="sheets.config",defaultPluginConfig={};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");const PLUGIN_NAME="SHEET_PLUGIN";var _a19;exports.UniverSheetsPlugin=(_a19=class extends core.Plugin{constructor(_config=defaultPluginConfig,_injector,_configService){super(),this._config=_config,this._injector=_injector,this._configService=_configService;const{...rest}=this._config;this._configService.setConfig(PLUGIN_CONFIG_KEY,rest),this._initConfig(),this._initDependencies(_injector)}onRendered(){}_initConfig(){var _a20;(_a20=this._config)!=null&&_a20.onlyRegisterFormulaRelatedMutations&&this._configService.setConfig(ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY,!0)}_initDependencies(sheetInjector){var _a20,_b;const dependencies=[[BorderStyleManagerService],[exports.SheetsSelectionsService],[exports.RefRangeService],[exports.WorkbookPermissionService],[INumfmtService,{useClass:exports.NumfmtService}],[exports.SheetInterceptorService],[BasicWorksheetController],[exports.MergeCellController],[NumberCellDisplayController],[exports.DefinedNameDataController],[exports.WorksheetPermissionService],[exports.WorksheetProtectionRuleModel],[exports.WorksheetProtectionPointModel],[exports.RangeProtectionRenderModel],[exports.RangeProtectionRuleModel],[exports.RangeProtectionRefRangeService],[exports.RangeProtectionService],[IExclusiveRangeService,{useClass:ExclusiveRangeService,deps:[exports.SheetsSelectionsService]}]];(_a20=this._config)!=null&&_a20.notExecuteFormula||dependencies.push([CalculateResultApplyController]),core.mergeOverrideWithDependencies(dependencies,(_b=this._config)==null?void 0:_b.override).forEach(d=>{sheetInjector.add(d)}),this._injector.get(exports.SheetInterceptorService),this._injector.get(exports.RangeProtectionService),this._injector.get(IExclusiveRangeService)}},__name(_a19,"UniverSheetsPlugin"),_a19);__publicField2(exports.UniverSheetsPlugin,"pluginName",PLUGIN_NAME);__publicField2(exports.UniverSheetsPlugin,"type",core.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsPlugin=__decorateClass([core.DependentOn(engineFormula.UniverFormulaEnginePlugin),__decorateParam(1,core.Inject(core.Injector)),__decorateParam(2,core.IConfigService)],exports.UniverSheetsPlugin);const COMMAND_LISTENER_SKELETON_CHANGE=[SetWorksheetRowHeightMutation.id,SetWorksheetRowIsAutoHeightMutation.id,SetWorksheetRowAutoHeightMutation.id,SetWorksheetColWidthMutation.id,SetWorksheetActiveOperation.id,MoveRowsMutation.id,MoveColsMutation.id,SetColHiddenMutation.id,SetColVisibleMutation.id,SetRowHiddenMutation.id,SetRowVisibleMutation.id,InsertColMutation.id,InsertRowMutation.id,RemoveColMutation.id,RemoveRowMutation.id],COMMAND_LISTENER_VALUE_CHANGE=[SetRangeValuesMutation.id,MoveRangeMutation.id,RemoveWorksheetMergeMutation.id,AddWorksheetMergeMutation.id,ReorderRangeMutation.id],SELECTION_CONTROL_BORDER_BUFFER_WIDTH=1.5,SELECTION_CONTROL_BORDER_BUFFER_COLOR="rgba(255, 255, 255, 0.01)";function getNormalSelectionStyle(themeService){const styleSheet=themeService.getCurrentTheme(),fill=new core.ColorKit(styleSheet.primaryColor).setAlpha(.07).toRgbString();return{strokeWidth:1,stroke:styleSheet.primaryColor,fill,widgets:{},widgetSize:6,widgetStrokeWidth:1,widgetStroke:styleSheet.colorWhite,hasAutoFill:!0,AutofillSize:6,AutofillStrokeWidth:1,AutofillStroke:styleSheet.colorWhite,hasRowHeader:!0,rowHeaderFill:fill,rowHeaderStroke:styleSheet.primaryColor,rowHeaderStrokeWidth:1,hasColumnHeader:!0,columnHeaderFill:fill,columnHeaderStroke:styleSheet.primaryColor,columnHeaderStrokeWidth:1,expandCornerSize:40}}__name(getNormalSelectionStyle,"getNormalSelectionStyle");function convertSelectionDataToRange(selectionWithCoordAndStyle){const{rangeWithCoord,primaryWithCoord,style}=selectionWithCoordAndStyle,result={range:{startRow:rangeWithCoord.startRow,startColumn:rangeWithCoord.startColumn,endRow:rangeWithCoord.endRow,endColumn:rangeWithCoord.endColumn,rangeType:rangeWithCoord.rangeType,unitId:rangeWithCoord.unitId,sheetId:rangeWithCoord.sheetId},primary:null,style};return primaryWithCoord!=null&&(result.primary=convertPrimaryWithCoordToPrimary(primaryWithCoord)),result}__name(convertSelectionDataToRange,"convertSelectionDataToRange");function convertPrimaryWithCoordToPrimary(primaryWithCoord){const{actualRow,actualColumn,isMerged,isMergedMainCell}=primaryWithCoord,{startRow,startColumn,endRow,endColumn}=primaryWithCoord.mergeInfo;return{actualRow,actualColumn,isMerged,isMergedMainCell,startRow,startColumn,endRow,endColumn}}__name(convertPrimaryWithCoordToPrimary,"convertPrimaryWithCoordToPrimary");function transformCellDataToSelectionData(row,column,mergeData){const newCellRange=core.getCellInfoInMergeData(row,column,mergeData),newSelectionData=core.makeCellRangeToRangeData(newCellRange);if(newSelectionData)return{range:newSelectionData,primary:newCellRange,style:null}}__name(transformCellDataToSelectionData,"transformCellDataToSelectionData");const AddMergeRedoSelectionsOperationFactory=__name((accessor,params,ranges)=>{const selectionsBeforeMutation=accessor.get(exports.SheetsSelectionsService).getCurrentSelections(),{value,selections,unitId,subUnitId}=params;if(selectionsBeforeMutation){const primaryBeforeMutation=selectionsBeforeMutation[(selectionsBeforeMutation==null?void 0:selectionsBeforeMutation.length)-1].primary;if(primaryBeforeMutation){const{actualColumn,actualRow}=primaryBeforeMutation;let{startRow,startColumn,endRow,endColumn}=selections[selections.length-1];if(value===core.Dimension.COLUMNS){const rangeByColumn=ranges.find(item=>item.startColumn===actualColumn&&item.endColumn===actualColumn&&actualRow===item.startRow);rangeByColumn&&(endColumn=rangeByColumn.endColumn,startRow=rangeByColumn.startRow,endRow=rangeByColumn.endRow)}else if(value===core.Dimension.ROWS){const rangeByRow=ranges.find(item=>item.startRow===actualRow&&item.endRow===actualRow&&actualColumn===item.startColumn);rangeByRow&&(endRow=rangeByRow.endRow,startColumn=rangeByRow.startColumn,endColumn=rangeByRow.endColumn)}const primary={startRow,startColumn,endRow,endColumn,actualRow,actualColumn,isMerged:!0,isMergedMainCell:startRow===actualRow&&startColumn===actualColumn},selectionsByRedo=selectionsBeforeMutation.map((selection,index,selections2)=>({range:selection.range,style:null,primary:index===selections2.length-1?primary:null})),setSelectionsParamByRedo={unitId,subUnitId,selections:selectionsByRedo};return{id:SetSelectionsOperation.id,params:setSelectionsParamByRedo}}return null}return null},"AddMergeRedoSelectionsOperationFactory"),AddMergeUndoSelectionsOperationFactory=__name((accessor,params)=>{const selectionsBeforeMutation=accessor.get(exports.SheetsSelectionsService).getCurrentSelections(),{unitId,subUnitId}=params;if(selectionsBeforeMutation&&selectionsBeforeMutation[(selectionsBeforeMutation==null?void 0:selectionsBeforeMutation.length)-1].primary){const setSelectionsParamByUndo={unitId,subUnitId,selections:[...selectionsBeforeMutation]};return{id:SetSelectionsOperation.id,params:setSelectionsParamByUndo}}return null},"AddMergeUndoSelectionsOperationFactory");function cellHasValue(cell){return cell==null?!1:cell.v!==void 0&&cell.v!==null&&cell.v!==""||cell.p!==void 0}__name(cellHasValue,"cellHasValue");function hasValueFromMatrixWithSpanInfo(cell,matrix){return cell&&cell.spanAnchor?cellHasValue(matrix.getValue(cell.spanAnchor.startRow,cell.spanAnchor.startColumn)):cellHasValue(cell)}__name(hasValueFromMatrixWithSpanInfo,"hasValueFromMatrixWithSpanInfo");function getMatrixWithSpanInfo(worksheet,startRow,startColumn,endRow,endColumn){const matrix=worksheet.getCellMatrix(),mergedCellsInRange=worksheet.getSpanModel().getMergedCellRange(startRow,startColumn,endRow,endColumn),returnCellMatrix=new core.ObjectMatrix;return matrix.forValue((row,col)=>{const v=matrix.getValue(row,col);v&&returnCellMatrix.setValue(row,col,v)}),mergedCellsInRange.forEach(mergedCell=>{const{startColumn:startColumn2,startRow:startRow2,endColumn:endColumn2,endRow:endRow2}=mergedCell;core.createRowColIter(startRow2,endRow2,startColumn2,endColumn2).forEach((row,col)=>{row===startRow2&&col===startColumn2&&returnCellMatrix.setValue(row,col,{...matrix.getValue(row,col),spanAnchor:{startRow:startRow2,endRow:endRow2,startColumn:startColumn2,endColumn:endColumn2}}),(row!==startRow2||col!==startColumn2)&&(returnCellMatrix.realDeleteValue(row,col),returnCellMatrix.setValue(row,col,{spanAnchor:{startRow:startRow2,endRow:endRow2,startColumn:startColumn2,endColumn:endColumn2}}))})}),returnCellMatrix}__name(getMatrixWithSpanInfo,"getMatrixWithSpanInfo");function getExpandedRangeLeft(range,allMatrixWithSpan,leftOffset,isWorksheetHasSpan){const{startRow,startColumn,endRow}=range;let spanAnchor=null,hasValue=!1;for(let i=startRow;i<=endRow;i++){const cell=allMatrixWithSpan.getValue(i,startColumn-leftOffset);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.startColumn=range.startColumn-leftOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeLeft,"getExpandedRangeLeft");function getExpandedRangeRight(range,allMatrixWithSpan,rightOffset,isWorksheetHasSpan){const{startRow,endColumn,endRow}=range;let spanAnchor=null,hasValue=!1;for(let i=startRow;i<=endRow;i++){const cell=allMatrixWithSpan.getValue(i,endColumn+rightOffset);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.endColumn=range.endColumn+rightOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeRight,"getExpandedRangeRight");function getExpandedRangeUp(range,allMatrixWithSpan,upOffset,isWorksheetHasSpan){const{startRow,startColumn,endColumn}=range;let spanAnchor=null,hasValue=!1;for(let i=startColumn;i<=endColumn;i++){const cell=allMatrixWithSpan.getValue(startRow-upOffset,i);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.startRow=range.startRow-upOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeUp,"getExpandedRangeUp");function getExpandedRangeDown(range,allMatrixWithSpan,downOffset,isWorksheetHasSpan){const{startColumn,endColumn,endRow}=range;let spanAnchor=null,hasValue=!1;for(let i=startColumn;i<=endColumn;i++){const cell=allMatrixWithSpan.getValue(endRow+downOffset,i);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.endRow=range.endRow+downOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeDown,"getExpandedRangeDown");function expandToContinuousRange(startRange,directions,worksheet){const maxRow=worksheet.getMaxRows(),maxColumn=worksheet.getMaxColumns(),allMatrixWithSpan=getMatrixWithSpanInfo(worksheet,0,0,maxRow-1,maxColumn-1),worksheetHasSpan=worksheet.getSnapshot().mergeData.length>0,{left,right,up,down}=directions;let changed=!0,destRange={...startRange};const spanAnchors=[];for(;changed;){if(changed=!1,up&&destRange.startRow!==0){const{hasValue,range,spanAnchor}=getExpandedRangeUp(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}if(down&&destRange.endRow!==maxRow-1){const{hasValue,range,spanAnchor}=getExpandedRangeDown(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}if(left&&destRange.startColumn!==0){const{hasValue,range,spanAnchor}=getExpandedRangeLeft(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}if(right&&destRange.endColumn!==maxColumn-1){const{hasValue,range,spanAnchor}=getExpandedRangeRight(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}}return spanAnchors.length>0&&(destRange=core.Rectangle.union(destRange,...spanAnchors)),destRange}__name(expandToContinuousRange,"expandToContinuousRange");const checkRangesEditablePermission=__name((accessor,unitId,subUnitId,ranges)=>{const permissionService=accessor.get(core.IPermissionService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),workbookEditablePermission=permissionService.getPermissionPoint(new sheets.WorkbookEditablePermission(unitId).id);if(!(workbookEditablePermission!=null&&workbookEditablePermission.value))return!1;const worksheetEditPermission=permissionService.getPermissionPoint(new sheets.WorksheetEditPermission(unitId,subUnitId).id);if(!(worksheetEditPermission!=null&&worksheetEditPermission.value))return!1;const ruleList=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>ranges.some(range=>core.Rectangle.intersects(ruleRange,range))));return ruleList.length?ruleList.every(rule=>{const permissionId=rule.permissionId,permissionPoint=permissionService.getPermissionPoint(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,permissionId).id);return!!(permissionPoint!=null&&permissionPoint.value)}):!0},"checkRangesEditablePermission");function checkCellContentInRanges(worksheet,ranges){return ranges.some(range=>checkCellContentInRange(worksheet,range))}__name(checkCellContentInRanges,"checkCellContentInRanges");function checkCellContentInRange(worksheet,range){const{startRow,startColumn,endColumn,endRow}=range,cellMatrix=worksheet.getMatrixWithMergedCells(startRow,startColumn,endRow,endColumn);let someCellGoingToBeRemoved=!1;return cellMatrix.forValue((row,col,cellData)=>{if(cellData&&(row!==startRow||col!==startColumn)&&worksheet.cellHasValue(cellData))return someCellGoingToBeRemoved=!0,!1}),someCellGoingToBeRemoved}__name(checkCellContentInRange,"checkCellContentInRange");function getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges){const undos=[],redos=[],subUnitId=worksheet.getSheetId();return ranges.forEach(range=>{const redoMatrix=getClearContentMutationParamForRange(worksheet,range),redoMutationParams={unitId,subUnitId,cellValue:redoMatrix.getData()},undoMutationParams=SetRangeValuesUndoMutationFactory(accessor,redoMutationParams);undos.push({id:SetRangeValuesMutation.id,params:undoMutationParams}),redos.push({id:SetRangeValuesMutation.id,params:redoMutationParams})}),{undos,redos}}__name(getClearContentMutationParamsForRanges,"getClearContentMutationParamsForRanges");function getClearContentMutationParamForRange(worksheet,range){const{startRow,startColumn,endColumn,endRow}=range,cellMatrix=worksheet.getMatrixWithMergedCells(startRow,startColumn,endRow,endColumn,!0),redoMatrix=new core.ObjectMatrix;return cellMatrix.forValue((row,col,cellData)=>{cellData&&(row!==startRow||col!==startColumn)&&redoMatrix.setValue(row,col,null)}),redoMatrix}__name(getClearContentMutationParamForRange,"getClearContentMutationParamForRange");const AddWorksheetMergeCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),unitId=params.unitId,subUnitId=params.subUnitId,selections=params.selections,ranges=getAddMergeMutationRangeByType(selections,params.value),worksheet=univerInstanceService.getUniverSheetInstance(unitId).getSheetBySheetId(subUnitId),redoMutations=[],undoMutations=[],willRemoveSomeCell=checkCellContentInRanges(worksheet,ranges),removeMergeMutationParams={unitId,subUnitId,ranges},addMergeMutationParams={unitId,subUnitId,ranges};redoMutations.push({id:RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}),redoMutations.push({id:AddWorksheetMergeMutation.id,params:addMergeMutationParams});const undoRemoveMergeMutationParams=RemoveMergeUndoMutationFactory(accessor,removeMergeMutationParams),undoMutationParams=AddMergeUndoMutationFactory(accessor,addMergeMutationParams);if(undoMutations.push({id:RemoveWorksheetMergeMutation.id,params:undoMutationParams}),undoMutations.push({id:AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),willRemoveSomeCell){const data=getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges);redoMutations.unshift(...data.redos),undoMutations.push(...data.undos)}return core.sequenceExecute(redoMutations,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations,redoMutations}),!0):!1},"handler")},AddWorksheetMergeAllCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-all",handler:__name(async accessor=>{var _a20;const commandService=accessor.get(core.ICommandService),selections=(_a20=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const workSheet=workbook.getActiveSheet();if(!workSheet)return!1;const unitId=workbook.getUnitId(),subUnitId=workSheet.getSheetId();return commandService.executeCommand(AddWorksheetMergeCommand.id,{selections,unitId,subUnitId})},"handler")},AddWorksheetMergeVerticalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-vertical",handler:__name(async accessor=>{var _a20;const commandService=accessor.get(core.ICommandService),selections=(_a20=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const workSheet=workbook.getActiveSheet();if(!workSheet)return!1;const unitId=workbook.getUnitId(),subUnitId=workSheet.getSheetId();return commandService.executeCommand(AddWorksheetMergeCommand.id,{value:core.Dimension.COLUMNS,selections,unitId,subUnitId})},"handler")},AddWorksheetMergeHorizontalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-horizontal",handler:__name(async accessor=>{var _a20;const commandService=accessor.get(core.ICommandService),selections=(_a20=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a20.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const workSheet=workbook.getActiveSheet();if(!workSheet)return!1;const unitId=workbook.getUnitId(),subUnitId=workSheet.getSheetId();return commandService.executeCommand(AddWorksheetMergeCommand.id,{value:core.Dimension.ROWS,selections,unitId,subUnitId})},"handler")};async function addMergeCellsUtil(injector,unitId,subUnitId,ranges){const univerInstanceService=injector.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,{unitId,subUnitId});if(!target)return;const{worksheet}=target;if(worksheet.getMergeData().some(mergeRange=>ranges.some(range=>core.Rectangle.intersects(range,mergeRange))))throw new Error("The ranges to be merged overlap with the existing merged cells");await injector.get(core.ICommandService).executeCommand(AddWorksheetMergeCommand.id,{unitId,subUnitId,selections:ranges})}__name(addMergeCellsUtil,"addMergeCellsUtil");const SetHideGridlinesUndoMutationFactory=__name((accessor,params)=>{const oldStatus=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId).getSheetBySheetId(params.subUnitId).getConfig().showGridlines;return{...core.Tools.deepClone(params),hideGridlines:oldStatus}},"SetHideGridlinesUndoMutationFactory"),SetHideGridlinesMutation={id:"sheet.mutation.set-hide-gridlines",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const config=worksheet.getConfig();return config.showGridlines=params.hideGridlines,!0},"handler")},SetHideGridlinesCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-hide-gridlines",handler:__name(async(accessor,params)=>{var _a20;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target;let hideGridlines=core.BooleanNumber.FALSE;params&&(hideGridlines=(_a20=params.hideGridlines)!=null?_a20:core.BooleanNumber.FALSE);const workbook=univerInstanceService.getUniverSheetInstance(unitId);if(!workbook||!workbook.getSheetBySheetId(subUnitId))return!1;const setHideGridlinesMutationParams={hideGridlines,unitId,subUnitId},undoMutationParams=SetHideGridlinesUndoMutationFactory(accessor,setHideGridlinesMutationParams);return commandService.syncExecuteCommand(SetHideGridlinesMutation.id,setHideGridlinesMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetHideGridlinesMutation.id,params:undoMutationParams}],redoMutations:[{id:SetHideGridlinesMutation.id,params:setHideGridlinesMutationParams}]}),!0):!1},"handler")},SetWorksheetRightToLeftUndoMutationFactory=__name((accessor,params)=>{const oldState=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId).getSheetBySheetId(params.subUnitId).getConfig().rightToLeft;return{...core.Tools.deepClone(params),rightToLeft:oldState}},"SetWorksheetRightToLeftUndoMutationFactory"),SetWorksheetRightToLeftMutation={id:"sheet.mutation.set-worksheet-right-to-left",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const config=worksheet.getConfig();return config.rightToLeft=params.rightToLeft,!0},"handler")},SetWorksheetRightToLeftCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-right-to-left",handler:__name(async(accessor,params)=>{var _a20;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{unitId,subUnitId}=target;let rightToLeft=core.BooleanNumber.FALSE;params&&(rightToLeft=(_a20=params.rightToLeft)!=null?_a20:core.BooleanNumber.FALSE);const setWorksheetRightToLeftMutationParams={rightToLeft,unitId,subUnitId},undoMutationParams=SetWorksheetRightToLeftUndoMutationFactory(accessor,setWorksheetRightToLeftMutationParams);return commandService.syncExecuteCommand(SetWorksheetRightToLeftMutation.id,setWorksheetRightToLeftMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetRightToLeftMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetRightToLeftMutation.id,params:setWorksheetRightToLeftMutationParams}]}),!0):!1},"handler")};exports.AddMergeRedoSelectionsOperationFactory=AddMergeRedoSelectionsOperationFactory;exports.AddMergeUndoMutationFactory=AddMergeUndoMutationFactory;exports.AddMergeUndoSelectionsOperationFactory=AddMergeUndoSelectionsOperationFactory;exports.AddRangeProtectionCommand=AddRangeProtectionCommand;exports.AddRangeProtectionMutation=AddRangeProtectionMutation;exports.AddWorksheetMergeAllCommand=AddWorksheetMergeAllCommand;exports.AddWorksheetMergeCommand=AddWorksheetMergeCommand;exports.AddWorksheetMergeHorizontalCommand=AddWorksheetMergeHorizontalCommand;exports.AddWorksheetMergeMutation=AddWorksheetMergeMutation;exports.AddWorksheetMergeVerticalCommand=AddWorksheetMergeVerticalCommand;exports.AddWorksheetProtectionMutation=AddWorksheetProtectionMutation;exports.BorderStyleManagerService=BorderStyleManagerService;exports.COMMAND_LISTENER_SKELETON_CHANGE=COMMAND_LISTENER_SKELETON_CHANGE;exports.COMMAND_LISTENER_VALUE_CHANGE=COMMAND_LISTENER_VALUE_CHANGE;exports.ClearSelectionAllCommand=ClearSelectionAllCommand;exports.ClearSelectionContentCommand=ClearSelectionContentCommand;exports.ClearSelectionFormatCommand=ClearSelectionFormatCommand;exports.CopySheetCommand=CopySheetCommand;exports.DISABLE_NORMAL_SELECTIONS=DISABLE_NORMAL_SELECTIONS;exports.DeleteRangeMoveLeftCommand=DeleteRangeMoveLeftCommand;exports.DeleteRangeMoveUpCommand=DeleteRangeMoveUpCommand;exports.DeleteRangeProtectionCommand=DeleteRangeProtectionCommand;exports.DeleteRangeProtectionMutation=DeleteRangeProtectionMutation;exports.DeleteWorksheetProtectionMutation=DeleteWorksheetProtectionMutation;exports.DeltaColumnWidthCommand=DeltaColumnWidthCommand;exports.DeltaRowHeightCommand=DeltaRowHeightCommand;exports.EffectRefRangId=EffectRefRangId;exports.EmptyMutation=EmptyMutation;exports.ExclusiveRangeService=ExclusiveRangeService;exports.FactoryAddRangeProtectionMutation=FactoryAddRangeProtectionMutation;exports.FactoryDeleteRangeProtectionMutation=FactoryDeleteRangeProtectionMutation;exports.FactorySetRangeProtectionMutation=FactorySetRangeProtectionMutation;exports.IExclusiveRangeService=IExclusiveRangeService;exports.INTERCEPTOR_POINT=INTERCEPTOR_POINT;exports.INumfmtService=INumfmtService;exports.IRefSelectionsService=IRefSelectionsService;exports.InsertColAfterCommand=InsertColAfterCommand;exports.InsertColBeforeCommand=InsertColBeforeCommand;exports.InsertColCommand=InsertColCommand;exports.InsertColMutation=InsertColMutation;exports.InsertColMutationUndoFactory=InsertColMutationUndoFactory;exports.InsertDefinedNameCommand=InsertDefinedNameCommand;exports.InsertRangeMoveDownCommand=InsertRangeMoveDownCommand;exports.InsertRangeMoveRightCommand=InsertRangeMoveRightCommand;exports.InsertRowAfterCommand=InsertRowAfterCommand;exports.InsertRowBeforeCommand=InsertRowBeforeCommand;exports.InsertRowCommand=InsertRowCommand;exports.InsertRowMutation=InsertRowMutation;exports.InsertRowMutationUndoFactory=InsertRowMutationUndoFactory;exports.InsertSheetCommand=InsertSheetCommand;exports.InsertSheetMutation=InsertSheetMutation;exports.InsertSheetUndoMutationFactory=InsertSheetUndoMutationFactory;exports.InterceptCellContentPriority=InterceptCellContentPriority;exports.MAX_CELL_PER_SHEET_KEY=MAX_CELL_PER_SHEET_KEY;exports.MERGE_CELL_INTERCEPTOR_CHECK=MERGE_CELL_INTERCEPTOR_CHECK;exports.MoveColsCommand=MoveColsCommand;exports.MoveColsMutation=MoveColsMutation;exports.MoveColsMutationUndoFactory=MoveColsMutationUndoFactory;exports.MoveRangeCommand=MoveRangeCommand;exports.MoveRangeMutation=MoveRangeMutation;exports.MoveRowsCommand=MoveRowsCommand;exports.MoveRowsMutation=MoveRowsMutation;exports.MoveRowsMutationUndoFactory=MoveRowsMutationUndoFactory;exports.OperatorType=OperatorType;exports.RangeMergeUtil=RangeMergeUtil;exports.RangeProtectionPermissionEditPoint=RangeProtectionPermissionEditPoint;exports.RangeProtectionPermissionViewPoint=RangeProtectionPermissionViewPoint;exports.RemoveColCommand=RemoveColCommand;exports.RemoveColMutation=RemoveColMutation;exports.RemoveDefinedNameCommand=RemoveDefinedNameCommand;exports.RemoveMergeUndoMutationFactory=RemoveMergeUndoMutationFactory;exports.RemoveNumfmtMutation=RemoveNumfmtMutation;exports.RemoveRowCommand=RemoveRowCommand;exports.RemoveRowMutation=RemoveRowMutation;exports.RemoveSheetCommand=RemoveSheetCommand;exports.RemoveSheetMutation=RemoveSheetMutation;exports.RemoveSheetUndoMutationFactory=RemoveSheetUndoMutationFactory;exports.RemoveWorksheetMergeCommand=RemoveWorksheetMergeCommand;exports.RemoveWorksheetMergeMutation=RemoveWorksheetMergeMutation;exports.ReorderRangeCommand=ReorderRangeCommand;exports.ReorderRangeMutation=ReorderRangeMutation;exports.ReorderRangeUndoMutationFactory=ReorderRangeUndoMutationFactory;exports.ResetBackgroundColorCommand=ResetBackgroundColorCommand;exports.ResetTextColorCommand=ResetTextColorCommand;exports.SELECTION_CONTROL_BORDER_BUFFER_COLOR=SELECTION_CONTROL_BORDER_BUFFER_COLOR;exports.SELECTION_CONTROL_BORDER_BUFFER_WIDTH=SELECTION_CONTROL_BORDER_BUFFER_WIDTH;exports.ScrollToCellOperation=ScrollToCellOperation;exports.SelectionMoveType=SelectionMoveType;exports.SetBackgroundColorCommand=SetBackgroundColorCommand;exports.SetBoldCommand=SetBoldCommand;exports.SetBorderBasicCommand=SetBorderBasicCommand;exports.SetBorderColorCommand=SetBorderColorCommand;exports.SetBorderCommand=SetBorderCommand;exports.SetBorderPositionCommand=SetBorderPositionCommand;exports.SetBorderStyleCommand=SetBorderStyleCommand;exports.SetColHiddenCommand=SetColHiddenCommand;exports.SetColHiddenMutation=SetColHiddenMutation;exports.SetColVisibleMutation=SetColVisibleMutation;exports.SetColWidthCommand=SetColWidthCommand;exports.SetDefinedNameCommand=SetDefinedNameCommand;exports.SetFontFamilyCommand=SetFontFamilyCommand;exports.SetFontSizeCommand=SetFontSizeCommand;exports.SetFrozenCancelCommand=SetFrozenCancelCommand;exports.SetFrozenCommand=SetFrozenCommand;exports.SetFrozenMutation=SetFrozenMutation;exports.SetFrozenMutationFactory=SetFrozenMutationFactory;exports.SetHideGridlinesCommand=SetHideGridlinesCommand;exports.SetHideGridlinesMutation=SetHideGridlinesMutation;exports.SetHorizontalTextAlignCommand=SetHorizontalTextAlignCommand;exports.SetItalicCommand=SetItalicCommand;exports.SetNumfmtMutation=SetNumfmtMutation;exports.SetOverlineCommand=SetOverlineCommand;exports.SetRangeProtectionCommand=SetRangeProtectionCommand;exports.SetRangeProtectionMutation=SetRangeProtectionMutation;exports.SetRangeValuesCommand=SetRangeValuesCommand;exports.SetRangeValuesMutation=SetRangeValuesMutation;exports.SetRangeValuesUndoMutationFactory=SetRangeValuesUndoMutationFactory;exports.SetRowHeightCommand=SetRowHeightCommand;exports.SetRowHiddenCommand=SetRowHiddenCommand;exports.SetRowHiddenMutation=SetRowHiddenMutation;exports.SetRowVisibleMutation=SetRowVisibleMutation;exports.SetSelectedColsVisibleCommand=SetSelectedColsVisibleCommand;exports.SetSelectedRowsVisibleCommand=SetSelectedRowsVisibleCommand;exports.SetSelectionsOperation=SetSelectionsOperation;exports.SetSpecificColsVisibleCommand=SetSpecificColsVisibleCommand;exports.SetSpecificRowsVisibleCommand=SetSpecificRowsVisibleCommand;exports.SetStrikeThroughCommand=SetStrikeThroughCommand;exports.SetStyleCommand=SetStyleCommand;exports.SetTabColorCommand=SetTabColorCommand;exports.SetTabColorMutation=SetTabColorMutation;exports.SetTextColorCommand=SetTextColorCommand;exports.SetTextRotationCommand=SetTextRotationCommand;exports.SetTextWrapCommand=SetTextWrapCommand;exports.SetUnderlineCommand=SetUnderlineCommand;exports.SetVerticalTextAlignCommand=SetVerticalTextAlignCommand;exports.SetWorkbookNameCommand=SetWorkbookNameCommand;exports.SetWorkbookNameMutation=SetWorkbookNameMutation;exports.SetWorksheetActivateCommand=SetWorksheetActivateCommand;exports.SetWorksheetActiveOperation=SetWorksheetActiveOperation;exports.SetWorksheetColWidthMutation=SetWorksheetColWidthMutation;exports.SetWorksheetColWidthMutationFactory=SetWorksheetColWidthMutationFactory;exports.SetWorksheetHideCommand=SetWorksheetHideCommand;exports.SetWorksheetHideMutation=SetWorksheetHideMutation;exports.SetWorksheetNameCommand=SetWorksheetNameCommand;exports.SetWorksheetNameMutation=SetWorksheetNameMutation;exports.SetWorksheetOrderCommand=SetWorksheetOrderCommand;exports.SetWorksheetOrderMutation=SetWorksheetOrderMutation;exports.SetWorksheetPermissionPointsCommand=SetWorksheetPermissionPointsCommand;exports.SetWorksheetPermissionPointsMutation=SetWorksheetPermissionPointsMutation;exports.SetWorksheetProtectionMutation=SetWorksheetProtectionMutation;exports.SetWorksheetRightToLeftCommand=SetWorksheetRightToLeftCommand;exports.SetWorksheetRightToLeftMutation=SetWorksheetRightToLeftMutation;exports.SetWorksheetRowAutoHeightMutation=SetWorksheetRowAutoHeightMutation;exports.SetWorksheetRowAutoHeightMutationFactory=SetWorksheetRowAutoHeightMutationFactory;exports.SetWorksheetRowHeightMutation=SetWorksheetRowHeightMutation;exports.SetWorksheetRowIsAutoHeightCommand=SetWorksheetRowIsAutoHeightCommand;exports.SetWorksheetRowIsAutoHeightMutation=SetWorksheetRowIsAutoHeightMutation;exports.SetWorksheetShowCommand=SetWorksheetShowCommand;exports.UnitObject=M;exports.WorkbookCommentPermission=WorkbookCommentPermission;exports.WorkbookCopyPermission=WorkbookCopyPermission;exports.WorkbookCopySheetPermission=WorkbookCopySheetPermission;exports.WorkbookCreateSheetPermission=WorkbookCreateSheetPermission;exports.WorkbookDeleteSheetPermission=WorkbookDeleteSheetPermission;exports.WorkbookDuplicatePermission=WorkbookDuplicatePermission;exports.WorkbookEditablePermission=WorkbookEditablePermission;exports.WorkbookExportPermission=WorkbookExportPermission;exports.WorkbookHideSheetPermission=WorkbookHideSheetPermission;exports.WorkbookHistoryPermission=WorkbookHistoryPermission;exports.WorkbookManageCollaboratorPermission=WorkbookManageCollaboratorPermission;exports.WorkbookMoveSheetPermission=WorkbookMoveSheetPermission;exports.WorkbookPrintPermission=WorkbookPrintPermission;exports.WorkbookRecoverHistoryPermission=WorkbookRecoverHistoryPermission;exports.WorkbookRenameSheetPermission=WorkbookRenameSheetPermission;exports.WorkbookSelections=WorkbookSelections;exports.WorkbookSharePermission=WorkbookSharePermission;exports.WorkbookViewHistoryPermission=WorkbookViewHistoryPermission;exports.WorkbookViewPermission=WorkbookViewPermission;exports.WorksheetCopyPermission=WorksheetCopyPermission;exports.WorksheetDeleteColumnPermission=WorksheetDeleteColumnPermission;exports.WorksheetDeleteRowPermission=WorksheetDeleteRowPermission;exports.WorksheetEditExtraObjectPermission=WorksheetEditExtraObjectPermission;exports.WorksheetEditPermission=WorksheetEditPermission;exports.WorksheetFilterPermission=WorksheetFilterPermission;exports.WorksheetInsertColumnPermission=WorksheetInsertColumnPermission;exports.WorksheetInsertHyperlinkPermission=WorksheetInsertHyperlinkPermission;exports.WorksheetInsertRowPermission=WorksheetInsertRowPermission;exports.WorksheetManageCollaboratorPermission=WorksheetManageCollaboratorPermission;exports.WorksheetPivotTablePermission=WorksheetPivotTablePermission;exports.WorksheetSelectProtectedCellsPermission=WorksheetSelectProtectedCellsPermission;exports.WorksheetSelectUnProtectedCellsPermission=WorksheetSelectUnProtectedCellsPermission;exports.WorksheetSetCellStylePermission=WorksheetSetCellStylePermission;exports.WorksheetSetCellValuePermission=WorksheetSetCellValuePermission;exports.WorksheetSetColumnStylePermission=WorksheetSetColumnStylePermission;exports.WorksheetSetRowStylePermission=WorksheetSetRowStylePermission;exports.WorksheetSortPermission=WorksheetSortPermission;exports.WorksheetViewPermission=WorksheetViewPermission;exports.addMergeCellsUtil=addMergeCellsUtil;exports.alignToMergedCellsBorders=alignToMergedCellsBorders;exports.checkRangesEditablePermission=checkRangesEditablePermission;exports.convertPrimaryWithCoordToPrimary=convertPrimaryWithCoordToPrimary;exports.convertSelectionDataToRange=convertSelectionDataToRange;exports.copyRangeStyles=copyRangeStyles;exports.createTopMatrixFromMatrix=createTopMatrixFromMatrix;exports.createTopMatrixFromRanges=createTopMatrixFromRanges;exports.defaultWorkbookPermissionPoints=defaultWorkbookPermissionPoints;exports.defaultWorksheetPermissionPoint=defaultWorksheetPermissionPoint;exports.expandToContinuousRange=expandToContinuousRange;exports.factoryRemoveNumfmtUndoMutation=factoryRemoveNumfmtUndoMutation;exports.factorySetNumfmtUndoMutation=factorySetNumfmtUndoMutation;exports.findAllRectangle=findAllRectangle;exports.followSelectionOperation=followSelectionOperation;exports.generateNullCell=generateNullCell;exports.generateNullCellValue=generateNullCellValue;exports.getAddMergeMutationRangeByType=getAddMergeMutationRangeByType;exports.getAllRangePermissionPoint=getAllRangePermissionPoint;exports.getAllWorkbookPermissionPoint=getAllWorkbookPermissionPoint;exports.getAllWorksheetPermissionPoint=getAllWorksheetPermissionPoint;exports.getAllWorksheetPermissionPointByPointPanel=getAllWorksheetPermissionPointByPointPanel;exports.getCellAtRowCol=getCellAtRowCol;exports.getDefaultRangePermission=getDefaultRangePermission;exports.getInsertRangeMutations=getInsertRangeMutations;exports.getMoveRangeUndoRedoMutations=getMoveRangeUndoRedoMutations;exports.getNormalSelectionStyle=getNormalSelectionStyle;exports.getPrimaryForRange=getPrimaryForRange;exports.getRemoveRangeMutations=getRemoveRangeMutations;exports.getSelectionsService=getSelectionsService;exports.getSheetCommandTarget=getSheetCommandTarget;exports.getSheetCommandTargetWorkbook=getSheetCommandTargetWorkbook;exports.getSheetMutationTarget=getSheetMutationTarget;exports.handleBaseInsertRange=handleBaseInsertRange;exports.handleBaseMoveRowsCols=handleBaseMoveRowsCols;exports.handleBaseRemoveRange=handleBaseRemoveRange;exports.handleCommonDefaultRangeChangeWithEffectRefCommands=handleCommonDefaultRangeChangeWithEffectRefCommands;exports.handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests=handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests;exports.handleDefaultRangeChangeWithEffectRefCommands=handleDefaultRangeChangeWithEffectRefCommands;exports.handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests=handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests;exports.handleDeleteRangeMoveLeft=handleDeleteRangeMoveLeft;exports.handleDeleteRangeMoveUp=handleDeleteRangeMoveUp;exports.handleDeleteRangeMutation=handleDeleteRangeMutation;exports.handleIRemoveCol=handleIRemoveCol;exports.handleIRemoveRow=handleIRemoveRow;exports.handleInsertCol=handleInsertCol;exports.handleInsertRangeMoveDown=handleInsertRangeMoveDown;exports.handleInsertRangeMoveRight=handleInsertRangeMoveRight;exports.handleInsertRangeMutation=handleInsertRangeMutation;exports.handleInsertRow=handleInsertRow;exports.handleMoveCols=handleMoveCols;exports.handleMoveRange=handleMoveRange;exports.handleMoveRows=handleMoveRows;exports.isSingleCellSelection=isSingleCellSelection;exports.rangeMerge=rangeMerge;exports.rotateRange=rotateRange;exports.runRefRangeMutations=runRefRangeMutations;exports.setEndForRange=setEndForRange;exports.transformCellDataToSelectionData=transformCellDataToSelectionData;exports.transformCellsToRange=transformCellsToRange;
|
|
1
|
+
"use strict";var __defProp=Object.defineProperty;var __defNormalProp=(obj,key,value)=>key in obj?__defProp(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value;var __name=(target,value)=>__defProp(target,"name",{value,configurable:!0});var __publicField=(obj,key,value)=>__defNormalProp(obj,typeof key!="symbol"?key+"":key,value);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const core=require("@univerjs/core"),engineFormula=require("@univerjs/engine-formula"),rpc=require("@univerjs/rpc"),rxjs=require("rxjs"),engineNumfmt=require("@univerjs/engine-numfmt"),operators=require("rxjs/operators"),sheets=require("@univerjs/sheets");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$g=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$g"),SelectionMoveType=(SelectionMoveType2=>(SelectionMoveType2[SelectionMoveType2.MOVE_START=0]="MOVE_START",SelectionMoveType2[SelectionMoveType2.MOVING=1]="MOVING",SelectionMoveType2[SelectionMoveType2.MOVE_END=2]="MOVE_END",SelectionMoveType2))(SelectionMoveType||{}),_a;exports.SheetsSelectionsService=(_a=class extends core.RxDisposable{constructor(_instanceSrv){super();__publicField(this,"selectionMoveStart$");__publicField(this,"selectionMoving$");__publicField(this,"selectionMoveEnd$");__publicField(this,"_workbookSelections",new Map);this._instanceSrv=_instanceSrv,this._init()}get _currentSelectionPos(){const workbook=this._instanceSrv.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const worksheet=workbook.getActiveSheet();return{unitId:workbook.getUnitId(),sheetId:worksheet.getSheetId()}}get currentSelectionParam(){return this._currentSelectionPos}_init(){const c$=this._instanceSrv.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.shareReplay(1),rxjs.takeUntil(this.dispose$));this.selectionMoveStart$=c$.pipe(rxjs.switchMap(workbook=>workbook?this._ensureWorkbookSelection(workbook.getUnitId()).selectionMoveStart$:rxjs.of())),this.selectionMoving$=c$.pipe(rxjs.switchMap(workbook=>workbook?this._ensureWorkbookSelection(workbook.getUnitId()).selectionMoving$:rxjs.of())),this.selectionMoveEnd$=c$.pipe(rxjs.switchMap(workbook=>workbook?this._ensureWorkbookSelection(workbook.getUnitId()).selectionMoveEnd$:rxjs.of([]))),this._instanceSrv.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.takeUntil(this.dispose$)).subscribe(workbook=>{this._removeWorkbookSelection(workbook.getUnitId())})}clear(){this._workbookSelections.forEach(wbSelection=>wbSelection.clear())}getCurrentSelections(){return this._getCurrentSelections()}getCurrentLastSelection(){const selectionData=this._getCurrentSelections();return selectionData==null?void 0:selectionData[selectionData.length-1]}addSelections(unitIdOrSelections,worksheetId,selectionDatas){if(typeof unitIdOrSelections=="string"){this._ensureWorkbookSelection(unitIdOrSelections).addSelections(worksheetId,selectionDatas);return}const current=this._currentSelectionPos;if(!current)throw new Error("[SheetsSelectionsService]: cannot find current selection position!");const{unitId,sheetId}=current;this._ensureWorkbookSelection(unitId).addSelections(sheetId,unitIdOrSelections)}setSelections(unitIdOrSelections,worksheetIdOrType,selectionDatas,type){if(typeof unitIdOrSelections=="string"){this._ensureWorkbookSelection(unitIdOrSelections).setSelections(worksheetIdOrType,selectionDatas,type!=null?type:2);return}const current=this._currentSelectionPos;if(!current)throw new Error("[SheetsSelectionsService]: cannot find current selection position!");const{unitId,sheetId}=current;this._ensureWorkbookSelection(unitId).setSelections(sheetId,unitIdOrSelections!=null?unitIdOrSelections:selectionDatas,worksheetIdOrType!=null?worksheetIdOrType:2)}clearCurrentSelections(){this._getCurrentSelections().splice(0)}isOverlapping(){const selectionDataList=this.getCurrentSelections();return selectionDataList==null?!1:selectionDataList.some(({range},index)=>selectionDataList.some(({range:range2},index2)=>index===index2?!1:range.startRow<=range2.endRow&&range.endRow>=range2.startRow&&range.startColumn<=range2.endColumn&&range.endColumn>=range2.startColumn))}_getCurrentSelections(){const current=this._currentSelectionPos;if(!current)return[];const{unitId,sheetId}=current;return this._ensureWorkbookSelection(unitId).getSelectionOfWorksheet(sheetId)}getWorkbookSelections(unitId){return this._ensureWorkbookSelection(unitId)}_ensureWorkbookSelection(unitId){let wbSelection=this._workbookSelections.get(unitId);if(!wbSelection){const workbook=this._instanceSrv.getUnit(unitId);if(!workbook)throw new Error(`[SheetsSelectionsService]: cannot resolve unit with id "${unitId}"!`);wbSelection=new WorkbookSelections(workbook),this._workbookSelections.set(unitId,wbSelection)}return wbSelection}_removeWorkbookSelection(unitId){this._workbookSelections.delete(unitId)}},__name(_a,"SheetsSelectionsService"),_a);exports.SheetsSelectionsService=__decorateClass$j([__decorateParam$g(0,core.IUniverInstanceService)],exports.SheetsSelectionsService);const _WorkbookSelections=class _WorkbookSelections extends core.Disposable{constructor(_workbook){super();__publicField(this,"_selectionMoveStart$",new rxjs.Subject);__publicField(this,"selectionMoveStart$",this._selectionMoveStart$.asObservable());__publicField(this,"_selectionMoving$",new rxjs.Subject);__publicField(this,"selectionMoving$",this._selectionMoving$.asObservable());__publicField(this,"_selectionMoveEnd$",new rxjs.BehaviorSubject([]));__publicField(this,"selectionMoveEnd$",this._selectionMoveEnd$.asObservable());__publicField(this,"_beforeSelectionMoveEnd$",new rxjs.BehaviorSubject([]));__publicField(this,"beforeSelectionMoveEnd$",this._beforeSelectionMoveEnd$.asObservable());__publicField(this,"_worksheetSelections",new Map);this._workbook=_workbook}dispose(){super.dispose(),this._beforeSelectionMoveEnd$.complete(),this._selectionMoveEnd$.complete(),this._selectionMoving$.complete(),this._selectionMoveStart$.complete()}clear(){this._worksheetSelections.clear(),this._emitOnEnd([])}addSelections(sheetId,selectionDatas){const selections=this._ensureSheetSelection(sheetId);selections.push(...selectionDatas),this._emitOnEnd(selections)}setSelections(sheetId,selectionDatas=[],type){switch(this._ensureSheetSelection(sheetId).length=0,this._ensureSheetSelection(sheetId).push(...selectionDatas),type){case 0:this._selectionMoveStart$.next(selectionDatas);break;case 1:this._selectionMoving$.next(selectionDatas);break;case 2:this._emitOnEnd(selectionDatas);break;default:this._emitOnEnd(selectionDatas);break}}getCurrentSelections(){return this._getCurrentSelections()}getSelectionOfWorksheet(sheetId){return this._worksheetSelections.has(sheetId)?this._worksheetSelections.get(sheetId):[]}_getCurrentSelections(){return this.getSelectionOfWorksheet(this._workbook.getActiveSheet().getSheetId())}getCurrentLastSelection(){const selectionData=this._getCurrentSelections();return selectionData[selectionData.length-1]}_ensureSheetSelection(sheetId){let worksheetSelection=this._worksheetSelections.get(sheetId);return worksheetSelection||(worksheetSelection=[],this._worksheetSelections.set(sheetId,worksheetSelection)),worksheetSelection}_emitOnEnd(selections){this._beforeSelectionMoveEnd$.next(selections),this._selectionMoveEnd$.next(selections)}};__name(_WorkbookSelections,"WorkbookSelections");let WorkbookSelections=_WorkbookSelections;const DISABLE_NORMAL_SELECTIONS="DISABLE_NORMAL_SELECTIONS",CELL_CONTENT=core.createInterceptorKey("CELL_CONTENT"),ROW_FILTERED=core.createInterceptorKey("ROW_FILTERED"),INTERCEPTOR_POINT={CELL_CONTENT,ROW_FILTERED};var InterceptCellContentPriority=(InterceptCellContentPriority2=>(InterceptCellContentPriority2[InterceptCellContentPriority2.DATA_VALIDATION=9]="DATA_VALIDATION",InterceptCellContentPriority2[InterceptCellContentPriority2.NUMFMT=10]="NUMFMT",InterceptCellContentPriority2))(InterceptCellContentPriority||{}),__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$f=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$f"),_a2;exports.SheetInterceptorService=(_a2=class extends core.Disposable{constructor(_univerInstanceService){super();__publicField(this,"_interceptorsByName",new Map);__publicField(this,"_commandInterceptors",[]);__publicField(this,"_rangeInterceptors",[]);__publicField(this,"_beforeCommandInterceptor",[]);__publicField(this,"_workbookDisposables",new Map);__publicField(this,"_worksheetDisposables",new Map);this._univerInstanceService=_univerInstanceService,this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{this._interceptWorkbook(workbook)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>this._disposeWorkbookInterceptor(workbook))),this.intercept(INTERCEPTOR_POINT.CELL_CONTENT,{priority:-1,effect:core.InterceptorEffectEnum.Style|core.InterceptorEffectEnum.Value,handler(value,context){const rawData=context.worksheet.getCellRaw(context.row,context.col);return value?{...rawData,...value}:rawData}})}dispose(){super.dispose(),this._workbookDisposables.forEach(disposable=>disposable.dispose()),this._workbookDisposables.clear(),this._worksheetDisposables.clear()}interceptCommand(interceptor){if(this._commandInterceptors.includes(interceptor))throw new Error("[SheetInterceptorService]: Interceptor already exists!");return this._commandInterceptors.push(interceptor),this._commandInterceptors.sort((a,b)=>{var _a21,_b;return((_a21=b.priority)!=null?_a21:0)-((_b=a.priority)!=null?_b:0)}),this.disposeWithMe(core.toDisposable(()=>core.remove(this._commandInterceptors,interceptor)))}interceptBeforeCommand(interceptor){if(this._beforeCommandInterceptor.includes(interceptor))throw new Error("[SheetInterceptorService]: Interceptor already exists!");return this._beforeCommandInterceptor.push(interceptor),this._beforeCommandInterceptor.sort((a,b)=>{var _a21,_b;return((_a21=b.priority)!=null?_a21:0)-((_b=a.priority)!=null?_b:0)}),this.disposeWithMe(core.toDisposable(()=>core.remove(this._beforeCommandInterceptor,interceptor)))}async beforeCommandExecute(info){return(await Promise.all(this._beforeCommandInterceptor.map(i=>i.performCheck(info)))).every(perform=>perform)}interceptRanges(interceptor){if(this._rangeInterceptors.includes(interceptor))throw new Error("[SheetInterceptorService]: Interceptor already exists!");return this._rangeInterceptors.push(interceptor),this._rangeInterceptors.sort((a,b)=>{var _a21,_b;return((_a21=b.priority)!=null?_a21:0)-((_b=a.priority)!=null?_b:0)}),this.disposeWithMe(core.toDisposable(()=>core.remove(this._rangeInterceptors,interceptor)))}onCommandExecute(info){const infos=this._commandInterceptors.map(i=>i.getMutations(info));return{preUndos:infos.map(i=>{var _a21;return(_a21=i.preUndos)!=null?_a21:[]}).flat(),undos:infos.map(i=>i.undos).flat(),preRedos:infos.map(i=>{var _a21;return(_a21=i.preRedos)!=null?_a21:[]}).flat(),redos:infos.map(i=>i.redos).flat()}}generateMutationsByRanges(info){const infos=this._rangeInterceptors.map(i=>i.getMutations(info));return{preUndos:infos.map(i=>{var _a21;return(_a21=i.preUndos)!=null?_a21:[]}).flat(),undos:infos.map(i=>i.undos).flat(),preRedos:infos.map(i=>{var _a21;return(_a21=i.preRedos)!=null?_a21:[]}).flat(),redos:infos.map(i=>i.redos).flat()}}intercept(name,interceptor){const key=name;this._interceptorsByName.has(key)||this._interceptorsByName.set(key,[]);const interceptors=this._interceptorsByName.get(key);interceptors.push(interceptor);const sortedInterceptors=interceptors.sort((a,b)=>{var _a21,_b;return((_a21=b.priority)!=null?_a21:0)-((_b=a.priority)!=null?_b:0)});return key===INTERCEPTOR_POINT.CELL_CONTENT?(this._interceptorsByName.set(`${key}-${core.InterceptorEffectEnum.Style|core.InterceptorEffectEnum.Value}`,sortedInterceptors),this._interceptorsByName.set(`${key}-${core.InterceptorEffectEnum.Style}`,sortedInterceptors.filter(i=>((i.effect||3)&core.InterceptorEffectEnum.Style)>0)),this._interceptorsByName.set(`${key}-${core.InterceptorEffectEnum.Value}`,sortedInterceptors.filter(i=>((i.effect||3)&core.InterceptorEffectEnum.Value)>0))):this._interceptorsByName.set(key,sortedInterceptors),this.disposeWithMe(core.toDisposable(()=>core.remove(this._interceptorsByName.get(key),interceptor)))}fetchThroughInterceptors(name,effect){const key=effect===void 0?name:`${name}-${effect}`,interceptors=this._interceptorsByName.get(key);return core.composeInterceptors(interceptors||[])}_interceptWorkbook(workbook){const disposables=new core.DisposableCollection,unitId=workbook.getUnitId(),sheetInterceptorService=this,interceptViewModel=__name(worksheet=>{const subUnitId=worksheet.getSheetId();worksheet.__interceptViewModel(viewModel=>{const sheetDisposables=new core.DisposableCollection;sheetInterceptorService._worksheetDisposables.set(getWorksheetDisposableID(unitId,worksheet),sheetDisposables),sheetDisposables.add(viewModel.registerCellContentInterceptor({getCell(row,col,effect){const rawData=worksheet.getCellRaw(row,col);return sheetInterceptorService.fetchThroughInterceptors(INTERCEPTOR_POINT.CELL_CONTENT,effect)(rawData,{unitId,subUnitId,row,col,worksheet,workbook,rawData})}})),sheetDisposables.add(viewModel.registerRowFilteredInterceptor({getRowFiltered(row){return!!sheetInterceptorService.fetchThroughInterceptors(INTERCEPTOR_POINT.ROW_FILTERED)(!1,{unitId,subUnitId,row,workbook,worksheet})}}))})},"interceptViewModel");workbook.getSheets().forEach(worksheet=>interceptViewModel(worksheet)),disposables.add(workbook.sheetCreated$.subscribe(worksheet=>interceptViewModel(worksheet))),disposables.add(core.toDisposable(()=>workbook.getSheets().forEach(worksheet=>this._disposeSheetInterceptor(unitId,worksheet)))),disposables.add(workbook.sheetDisposed$.subscribe(worksheet=>this._disposeSheetInterceptor(unitId,worksheet))),this._workbookDisposables.set(unitId,disposables)}_disposeWorkbookInterceptor(workbook){const unitId=workbook.getUnitId(),disposable=this._workbookDisposables.get(unitId);disposable&&(disposable.dispose(),this._workbookDisposables.delete(unitId))}_disposeSheetInterceptor(unitId,worksheet){const disposableId=getWorksheetDisposableID(unitId,worksheet),disposable=this._worksheetDisposables.get(disposableId);disposable&&(disposable.dispose(),this._worksheetDisposables.delete(disposableId))}},__name(_a2,"SheetInterceptorService"),_a2);exports.SheetInterceptorService=__decorateClass$i([__decorateParam$f(0,core.IUniverInstanceService)],exports.SheetInterceptorService);function getWorksheetDisposableID(unitId,worksheet){return`${unitId}|${worksheet.getSheetId()}`}__name(getWorksheetDisposableID,"getWorksheetDisposableID");function handleStyle(styles,oldVal,newVal){var _a21;const oldStyle=styles.getStyleByCell(oldVal);oldStyle==null&&delete oldVal.s,typeof newVal.s=="string"&&(newVal.s=styles.get(newVal.s));const merge=mergeStyle(oldStyle,newVal.s?newVal.s:null);merge&&core.Tools.removeNull(merge),core.Tools.isEmptyObject(merge)?delete oldVal.s:oldVal.s=styles.setValue(merge);const newValueStream=newVal.v?`${newVal.v}\r
|
|
2
|
+
`:"";!newVal.p&&oldVal.p&&(newValueStream&&newValueStream!==((_a21=oldVal.p.body)==null?void 0:_a21.dataStream)?delete oldVal.p:mergeRichTextStyle(oldVal.p,newVal.s?newVal.s:null))}__name(handleStyle,"handleStyle");function transformStyle(oldStyle,newStyle){if(!newStyle||!Object.keys(newStyle).length)return oldStyle;const backupStyle=oldStyle||{};for(const k in newStyle)k==="bd"?backupStyle[k]=transformBorders(backupStyle[k]||{},newStyle[k]):k in backupStyle||(backupStyle[k]=null);return backupStyle}__name(transformStyle,"transformStyle");function transformBorders(oldBorders,newBorders){if(!newBorders||!Object.keys(newBorders).length)return oldBorders;for(const k in newBorders)k in oldBorders||(oldBorders[k]=null);return oldBorders}__name(transformBorders,"transformBorders");function mergeStyle(oldStyle,newStyle,isRichText=!1){if(newStyle===null)return newStyle;if(newStyle===void 0)return oldStyle;const backupStyle=core.Tools.deepClone(oldStyle)||{};for(const k in newStyle)isRichText&&["bd","tr","td","ht","vt","tb","pd","bg"].includes(k)||(k in backupStyle&&k==="bd"?backupStyle[k]=Object.assign(backupStyle[k],newStyle[k]):backupStyle[k]=newStyle[k]);return"cl"in backupStyle&&("ul"in backupStyle&&backupStyle.ul&&(backupStyle.ul.cl=backupStyle.cl),"ol"in backupStyle&&backupStyle.ol&&(backupStyle.ol.cl=backupStyle.cl),"st"in backupStyle&&backupStyle.st&&(backupStyle.st.cl=backupStyle.cl)),backupStyle}__name(mergeStyle,"mergeStyle");function skipParagraphs(paragraphs,offset){return paragraphs.some(p=>p.startIndex===offset)?skipParagraphs(paragraphs,offset+1):offset}__name(skipParagraphs,"skipParagraphs");function mergeRichTextStyle(p,newStyle){var _a21;if(p.body==null)return;Array.isArray(p.body.textRuns)||(p.body.textRuns=[]);let index=0;const newTextRuns=[],paragraphs=((_a21=p.body)==null?void 0:_a21.paragraphs)||[];for(const textRun of p.body.textRuns){const{st,ed,ts={}}=textRun;if(index<st){const tr={st:index,ed:st},merge2=mergeStyle({},newStyle,!0);merge2&&core.Tools.removeNull(merge2),core.Tools.isEmptyObject(merge2)||(tr.ts=merge2),newTextRuns.push(tr)}const merge=mergeStyle(ts,newStyle,!0);merge&&core.Tools.removeNull(merge),core.Tools.isEmptyObject(merge)?delete textRun.ts:textRun.ts=merge,newTextRuns.push(textRun),index=skipParagraphs(paragraphs,ed)}const endIndex=p.body.dataStream.endsWith(`\r
|
|
3
|
+
`)?p.body.dataStream.length-2:p.body.dataStream.length;if(index<endIndex){const tr={st:index,ed:endIndex},merge=mergeStyle({},newStyle,!0);merge&&core.Tools.removeNull(merge),core.Tools.isEmptyObject(merge)||(tr.ts=merge),newTextRuns.push(tr)}p.body.textRuns=core.normalizeTextRuns(newTextRuns)}__name(mergeRichTextStyle,"mergeRichTextStyle");function getCellType(styles,newVal,oldVal){if(newVal.t)return newVal.t;if(newVal.v===null)return null;const newStyle=styles.getStyleByCell(newVal),oldStyle=styles.getStyleByCell(oldVal);if(oldVal.t===core.CellValueType.FORCE_STRING){if(!isTextFormat(oldStyle)&&newVal.v!==void 0){if(core.isRealNum(newVal.v))return core.CellValueType.NUMBER;if(core.isBooleanString(`${newVal.v}`))return core.CellValueType.BOOLEAN}return core.CellValueType.FORCE_STRING}return hasNumberFormat(newStyle)?isTextFormat(newStyle)?core.CellValueType.STRING:checkCellValueTypeByValue(newVal,oldVal):isTextFormat(oldStyle)?core.CellValueType.STRING:checkCellValueTypeByValue(newVal,oldVal)}__name(getCellType,"getCellType");function checkCellValueTypeByValue(newVal,oldVal){return newVal.v!==void 0?checkCellValueType(newVal.v,newVal.t):checkCellValueType(oldVal.v,oldVal.t)}__name(checkCellValueTypeByValue,"checkCellValueTypeByValue");function hasNumberFormat(style){var _a21;return!!((_a21=style==null?void 0:style.n)!=null&&_a21.pattern)}__name(hasNumberFormat,"hasNumberFormat");function isTextFormat(style){var _a21;return((_a21=style==null?void 0:style.n)==null?void 0:_a21.pattern)===engineNumfmt.DEFAULT_TEXT_FORMAT}__name(isTextFormat,"isTextFormat");function checkCellValueType(v,type){return v===null?null:typeof v=="string"?core.isRealNum(v)?(+v==0||+v==1)&&type===core.CellValueType.BOOLEAN?core.CellValueType.BOOLEAN:core.CellValueType.NUMBER:core.isBooleanString(v)?core.CellValueType.BOOLEAN:core.CellValueType.STRING:typeof v=="number"?(v===0||v===1)&&type===core.CellValueType.BOOLEAN?core.CellValueType.BOOLEAN:core.CellValueType.NUMBER:typeof v=="boolean"?core.CellValueType.BOOLEAN:core.CellValueType.FORCE_STRING}__name(checkCellValueType,"checkCellValueType");function getCellTypeByPattern(cell,pattern){return cell.t===core.CellValueType.FORCE_STRING?core.CellValueType.FORCE_STRING:pattern===engineNumfmt.DEFAULT_TEXT_FORMAT?core.CellValueType.STRING:checkCellValueType(cell.v,cell.t)}__name(getCellTypeByPattern,"getCellTypeByPattern");function getCellValue(type,cell){return type===core.CellValueType.NUMBER?Number(cell.v):type===core.CellValueType.BOOLEAN?extractBooleanValue(cell.v)?1:0:type===core.CellValueType.STRING||type===core.CellValueType.FORCE_STRING?`${cell.v}`:cell.v}__name(getCellValue,"getCellValue");function extractBooleanValue(value){if(typeof value=="string"){if(value.toUpperCase()==="TRUE")return!0;if(value.toUpperCase()==="FALSE")return!1;if(core.isSafeNumeric(value)){if(Number(value)===0)return!1;if(Number(value)===1)return!0}}if(typeof value=="number"){if(value===0)return!1;if(value===1)return!0}return typeof value=="boolean"?value:null}__name(extractBooleanValue,"extractBooleanValue");function setNull(value){return value==null?null:(value.f===void 0&&(value.f=null),value.si===void 0&&(value.si=null),value.p===void 0&&(value.p=null),value.v===void 0&&(value.v=null),value.t===void 0&&(value.t=null),value.s===void 0&&(value.s=null),value.custom===void 0&&(value.custom=null),value)}__name(setNull,"setNull");const SetRangeValuesUndoMutationFactory=__name((accessor,params)=>{const{unitId,subUnitId,cellValue}=params,workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(workbook==null)throw new Error("workbook is null error!");const worksheet=workbook.getSheetBySheetId(subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const cellMatrix=worksheet.getCellMatrix(),styles=workbook.getStyles(),undoData=new core.ObjectMatrix;return new core.ObjectMatrix(cellValue).forValue((row,col,newVal)=>{const cell=core.Tools.deepClone(cellMatrix==null?void 0:cellMatrix.getValue(row,col))||{},oldStyle=styles.getStyleByCell(cell),newStyle=styles.getStyleByCell(newVal);cell.s=transformStyle(oldStyle,newStyle),undoData.setValue(row,col,setNull(cell))}),{...params,options:{},cellValue:undoData.getMatrix()}},"SetRangeValuesUndoMutationFactory"),SetRangeValuesMutation={id:"sheet.mutation.set-range-values",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{cellValue,subUnitId,unitId}=params,workbook=accessor.get(core.IUniverInstanceService).getUnit(unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet)return!1;const cellMatrix=worksheet.getCellMatrix(),styles=workbook.getStyles();return new core.ObjectMatrix(cellValue).forValue((row,col,newVal)=>{if(!newVal)cellMatrix==null||cellMatrix.setValue(row,col,{});else{const oldVal=cellMatrix.getValue(row,col)||{},type=getCellType(styles,newVal,oldVal);newVal.f!==void 0&&(oldVal.f=newVal.f),newVal.si!==void 0&&(oldVal.si=newVal.si),newVal.p!==void 0&&(oldVal.p=newVal.p),newVal.v!==void 0&&(oldVal.v=getCellValue(type,newVal)),oldVal.v!==void 0&&(oldVal.t=type,oldVal.v=getCellValue(type,oldVal)),newVal.s!==void 0&&handleStyle(styles,oldVal,newVal),newVal.custom!==void 0&&(oldVal.custom=newVal.custom),cellMatrix.setValue(row,col,core.Tools.removeNull(oldVal))}}),!0},"handler")},groupByKey=__name((arr,key,blankKey="")=>arr.reduce((result,current)=>{const value=current&¤t[key];return typeof value!="string"?(console.warn(current,`${key} is not string`),result):(value?(result[value]||(result[value]=[]),result[value].push(current)):result[blankKey].push(current),result)},{}),"groupByKey"),createUniqueKey=__name((initValue=0)=>{let _initValue=initValue;return __name(function(){return _initValue++},"getKey")},"createUniqueKey");function generateNullCell(range){const cellValue=new core.ObjectMatrix;return range.forEach(range2=>{const{startRow,startColumn,endRow,endColumn}=range2;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellValue.setValue(i,j,null)}),cellValue.clone()}__name(generateNullCell,"generateNullCell");function generateNullCellValue(range){const cellValue=new core.ObjectMatrix;return range.forEach(range2=>{const{startRow,startColumn,endRow,endColumn}=range2;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellValue.setValue(i,j,{v:null,p:null,f:null,si:null,custom:null})}),cellValue.clone()}__name(generateNullCellValue,"generateNullCellValue");function generateNullCellStyle(ranges){const cellValue=new core.ObjectMatrix;return ranges.forEach(range=>{const{startRow,startColumn,endRow,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellValue.setValue(i,j,{s:null})}),cellValue.clone()}__name(generateNullCellStyle,"generateNullCellStyle");const ClearSelectionAllCommand={id:"sheet.command.clear-selection-all",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a21;const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),selections=(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const sequenceExecuteList=[],sequenceExecuteUndoList=[],clearMutationParams={subUnitId,unitId,cellValue:generateNullCell(selections)},undoClearMutationParams=SetRangeValuesUndoMutationFactory(accessor,clearMutationParams);sequenceExecuteList.push({id:SetRangeValuesMutation.id,params:clearMutationParams}),sequenceExecuteUndoList.push({id:SetRangeValuesMutation.id,params:undoClearMutationParams});const intercepted=sheetInterceptorService.onCommandExecute({id:ClearSelectionAllCommand.id});return sequenceExecuteList.push(...intercepted.redos),sequenceExecuteUndoList.unshift(...intercepted.undos),core.sequenceExecute(sequenceExecuteList,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:sequenceExecuteUndoList,redoMutations:sequenceExecuteList}),!0):!1},"handler")},ClearSelectionContentCommand={id:"sheet.command.clear-selection-content",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a21;const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),selections=(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const clearMutationParams={subUnitId,unitId,cellValue:generateNullCellValue(selections)},undoClearMutationParams=SetRangeValuesUndoMutationFactory(accessor,clearMutationParams),intercepted=sheetInterceptorService.onCommandExecute({id:ClearSelectionContentCommand.id}),redos=[{id:SetRangeValuesMutation.id,params:clearMutationParams},...intercepted.redos],undos=[...intercepted.undos,{id:SetRangeValuesMutation.id,params:undoClearMutationParams}];return core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},ClearSelectionFormatCommand={id:"sheet.command.clear-selection-format",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a21;const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const unitId=workbook.getUnitId(),worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),selections=(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const sequenceExecuteList=[],sequenceExecuteUndoList=[],clearMutationParams={subUnitId,unitId,cellValue:generateNullCellStyle(selections)},undoClearMutationParams=SetRangeValuesUndoMutationFactory(accessor,clearMutationParams);sequenceExecuteList.push({id:SetRangeValuesMutation.id,params:clearMutationParams}),sequenceExecuteUndoList.push({id:SetRangeValuesMutation.id,params:undoClearMutationParams});const intercepted=sheetInterceptorService.onCommandExecute({id:ClearSelectionFormatCommand.id});return sequenceExecuteList.push(...intercepted.redos),sequenceExecuteUndoList.unshift(...intercepted.undos),core.sequenceExecute(sequenceExecuteList,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:sequenceExecuteUndoList,redoMutations:sequenceExecuteList}),!0):!1},"handler")},InsertSheetUndoMutationFactory=__name((_accessor,params)=>({subUnitId:params.sheet.id,unitId:params.unitId,subUnitName:params.sheet.name}),"InsertSheetUndoMutationFactory"),InsertSheetMutation={id:"sheet.mutation.insert-sheet",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),{sheet,index,unitId}=params,workbook=univerInstanceService.getUniverSheetInstance(unitId);return workbook?workbook.addWorksheet(sheet.id,index,sheet):!1},"handler")};function getSheetCommandTargetWorkbook(univerInstanceService,params){const{unitId}=params,workbook=unitId?univerInstanceService.getUniverSheetInstance(unitId):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);return workbook?{workbook,unitId:workbook.getUnitId()}:null}__name(getSheetCommandTargetWorkbook,"getSheetCommandTargetWorkbook");function getSheetCommandTarget(univerInstanceService,params={}){const{unitId,subUnitId}=params,workbook=unitId?univerInstanceService.getUniverSheetInstance(unitId):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const worksheet=subUnitId?workbook.getSheetBySheetId(subUnitId):workbook.getActiveSheet(!0);return worksheet?{worksheet,workbook,unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId()}:null}__name(getSheetCommandTarget,"getSheetCommandTarget");function getSheetMutationTarget(univerInstanceService,params){const{unitId,subUnitId}=params,workbook=univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return null;const worksheet=workbook.getSheetBySheetId(subUnitId);return worksheet?{worksheet,workbook}:null}__name(getSheetMutationTarget,"getSheetMutationTarget");const RemoveSheetUndoMutationFactory=__name((accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),{subUnitId,unitId}=params,target=getSheetMutationTarget(univerInstanceService,params);if(!target)throw new Error("[RemoveSheetUndoMutationFactory]: Worksheet is null error!");const{workbook,worksheet}=target,sheet=worksheet.getConfig();return{index:workbook.getConfig().sheetOrder.findIndex(id=>id===subUnitId),sheet,unitId}},"RemoveSheetUndoMutationFactory"),RemoveSheetMutation={id:"sheet.mutation.remove-sheet",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),{subUnitId,unitId}=params,workbook=univerInstanceService.getUniverSheetInstance(unitId);return workbook?workbook.removeSheet(subUnitId):!1},"handler")},CopySheetCommand={type:core.CommandType.COMMAND,id:"sheet.command.copy-sheet",handler:__name(async(accessor,params)=>{var _a21,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),localeService=accessor.get(core.LocaleService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{workbook,worksheet,unitId,subUnitId}=target,config=core.Tools.deepClone(worksheet.getConfig());config.name=getCopyUniqueSheetName(workbook,localeService,config.name),config.id=core.Tools.generateRandomId();const insertSheetMutationParams={index:workbook.getSheetIndex(worksheet)+1,sheet:config,unitId},removeSheetMutationParams=InsertSheetUndoMutationFactory(accessor,insertSheetMutationParams),intercepted=sheetInterceptorService.onCommandExecute({id:CopySheetCommand.id,params:{unitId,subUnitId,targetSubUnitId:config.id}}),redos=[...(_a21=intercepted.preRedos)!=null?_a21:[],{id:InsertSheetMutation.id,params:insertSheetMutationParams},...intercepted.redos],undos=[...(_b=intercepted.preUndos)!=null?_b:[],{id:RemoveSheetMutation.id,params:removeSheetMutationParams},...intercepted.undos];return core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")};function getCopyUniqueSheetName(workbook,localeService,name){let output=name+localeService.t("sheets.tabs.sheetCopy",""),count=2;for(;workbook.checkSheetName(output);)output=name+localeService.t("sheets.tabs.sheetCopy",`${count}`),count++;return output}__name(getCopyUniqueSheetName,"getCopyUniqueSheetName");const MoveRangeMutation={id:"sheet.mutation.move-range",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{from,to}=params;if(!from||!to)return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const fromWorksheet=workbook.getSheetBySheetId(params.from.subUnitId),toWorksheet=workbook.getSheetBySheetId(params.to.subUnitId);if(!fromWorksheet||!toWorksheet)return!1;const fromCellMatrix=fromWorksheet.getCellMatrix(),toCellMatrix=toWorksheet.getCellMatrix();return new core.ObjectMatrix(from.value).forValue((row,col,newVal)=>{fromCellMatrix.setValue(row,col,newVal)}),new core.ObjectMatrix(to.value).forValue((row,col,newVal)=>{toCellMatrix.setValue(row,col,newVal)}),!0},"handler")};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$e=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$e");const IRefSelectionsService=core.createIdentifier("sheets-formula.ref-selections.service");var _a3;exports.RefSelectionsService=(_a3=class extends exports.SheetsSelectionsService{constructor(_instanceSrv){super(_instanceSrv)}_init(){const $=this._getAliveWorkbooks$().pipe(rxjs.takeUntil(this.dispose$));this.selectionMoveStart$=$.pipe(rxjs.switchMap(ss=>rxjs.merge(...ss.map(s=>s.selectionMoveStart$)))),this.selectionMoving$=$.pipe(rxjs.switchMap(ss=>rxjs.merge(...ss.map(s=>s.selectionMoving$)))),this.selectionMoveEnd$=$.pipe(rxjs.switchMap(ss=>rxjs.merge(...ss.map(s=>s.selectionMoveEnd$))))}_getAliveWorkbooks$(){const aliveWorkbooks=this._instanceSrv.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET);aliveWorkbooks.forEach(workbook=>this._ensureWorkbookSelection(workbook.getUnitId()));const workbooks$=new rxjs.BehaviorSubject(aliveWorkbooks);return this.disposeWithMe(this._instanceSrv.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{this._ensureWorkbookSelection(workbook.getUnitId()),workbooks$.next([...workbooks$.getValue(),workbook])})),this.disposeWithMe(this._instanceSrv.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{this._removeWorkbookSelection(workbook.getUnitId()),workbooks$.next(workbooks$.getValue().filter(unit=>unit!==workbook))})),workbooks$.pipe(rxjs.map(workbooks=>workbooks.map(w=>this._ensureWorkbookSelection(w.getUnitId()))))}},__name(_a3,"RefSelectionsService"),_a3);exports.RefSelectionsService=__decorateClass$h([__decorateParam$e(0,core.IUniverInstanceService)],exports.RefSelectionsService);function getSelectionsService(accessor){const disabledNormalSelections=accessor.get(core.IContextService).getContextValue(DISABLE_NORMAL_SELECTIONS);return accessor.get(disabledNormalSelections?IRefSelectionsService:exports.SheetsSelectionsService)}__name(getSelectionsService,"getSelectionsService");const SetSelectionsOperation={id:"sheet.operation.set-selections",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{if(!params)return!1;const{selections,type,unitId,subUnitId}=params;return getSelectionsService(accessor).setSelections(unitId,subUnitId,[...selections],type),!0},"handler")};function alignToMergedCellsBorders(startRange,worksheet,shouldRecursive=!0){const coveredMergedCells=worksheet.getMatrixWithMergedCells(...core.selectionToArray(startRange)),exceededMergedCells=[];if(coveredMergedCells.forValue((row,col,value)=>{if(value.colSpan!==void 0&&value.rowSpan!==void 0){const mergedCellRange={startRow:row,startColumn:col,endRow:row+value.rowSpan-1,endColumn:col+value.colSpan-1};core.Rectangle.contains(startRange,mergedCellRange)||exceededMergedCells.push(mergedCellRange)}}),exceededMergedCells.length===0)return startRange;const union=core.Rectangle.union(startRange,...exceededMergedCells);return shouldRecursive?alignToMergedCellsBorders(union,worksheet,shouldRecursive):union}__name(alignToMergedCellsBorders,"alignToMergedCellsBorders");function getCellAtRowCol(row,col,worksheet){let destRange=null;return worksheet.getMatrixWithMergedCells(row,col,row,col).forValue((row2,col2,value)=>(destRange={actualRow:row2,actualColumn:col2,startRow:row2,startColumn:col2,isMerged:value.rowSpan!==void 0||value.colSpan!==void 0,isMergedMainCell:value.rowSpan!==void 0&&value.colSpan!==void 0,endRow:row2+(value.rowSpan!==void 0?value.rowSpan-1:0),endColumn:col2+(value.colSpan!==void 0?value.colSpan-1:0),rangeType:core.RANGE_TYPE.NORMAL},!1)),destRange||{actualColumn:col,actualRow:row,startRow:row,startColumn:col,endRow:row,endColumn:col,isMerged:!1,isMergedMainCell:!1,rangeType:core.RANGE_TYPE.NORMAL}}__name(getCellAtRowCol,"getCellAtRowCol");function setEndForRange(range,rowCount,columnCount){const{startRow,startColumn,endRow,endColumn}=range;return Number.isNaN(startRow)&&(range.startRow=0),Number.isNaN(endRow)&&(range.endRow=rowCount-1),Number.isNaN(startColumn)&&(range.startColumn=0),Number.isNaN(endColumn)&&(range.endColumn=columnCount-1),range}__name(setEndForRange,"setEndForRange");function getPrimaryForRange(range,worksheet){const startRow=Number.isNaN(range.startRow)?0:range.startRow,startColumn=Number.isNaN(range.startColumn)?0:range.startColumn,mergedRange=worksheet.getMergedCell(startRow,startColumn);return mergedRange?{...mergedRange,actualRow:startRow,actualColumn:startColumn,rangeType:core.RANGE_TYPE.NORMAL,isMerged:!0,isMergedMainCell:!0}:{startRow,startColumn,endRow:range.startRow,endColumn:range.startColumn,actualRow:startRow,actualColumn:startColumn,rangeType:core.RANGE_TYPE.NORMAL,isMerged:!1,isMergedMainCell:!1}}__name(getPrimaryForRange,"getPrimaryForRange");const followSelectionOperation=__name((range,workbook,worksheet)=>({id:SetSelectionsOperation.id,params:{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),reveal:!0,selections:[{range,primary:getPrimaryForRange(range,worksheet)}]}}),"followSelectionOperation");function isSingleCellSelection(selection){if(!selection)return!1;const{range,primary}=selection;return core.Rectangle.equals(range,primary)}__name(isSingleCellSelection,"isSingleCellSelection");function createRangeIteratorWithSkipFilteredRows(sheet){function forOperableEach(ranges,operator){function iterate(range){for(let r=range.startRow;r<=range.endRow;r++)if(!sheet.getRowFiltered(r))for(let c=range.startColumn;c<=range.endColumn;c++)operator(r,c,range)}__name(iterate,"iterate"),iterate(ranges)}return __name(forOperableEach,"forOperableEach"),{forOperableEach}}__name(createRangeIteratorWithSkipFilteredRows,"createRangeIteratorWithSkipFilteredRows");function copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,isRow,styleRowOrColumn){const cellValue={};for(let row=startRow;row<=endRow;row++)for(let column=startColumn;column<=endColumn;column++){const cell=isRow?worksheet.getCell(styleRowOrColumn,column):worksheet.getCell(row,styleRowOrColumn);!cell||!cell.s||(cellValue[row]||(cellValue[row]={}),cellValue[row][column]={s:cell.s})}return cellValue}__name(copyRangeStyles,"copyRangeStyles");const MoveRangeCommandId="sheet.command.move-range",MoveRangeCommand={type:core.CommandType.COMMAND,id:MoveRangeCommandId,handler:__name(async(accessor,params)=>{var _a21,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService);if(!target||!await sheetInterceptorService.beforeCommandExecute({id:MoveRangeCommand.id,params}))return!1;const{worksheet,subUnitId,unitId}=target,moveRangeMutations=getMoveRangeUndoRedoMutations(accessor,{unitId,subUnitId,range:params.fromRange},{unitId,subUnitId,range:params.toRange});if(moveRangeMutations===null)return errorService.emit(localeService.t("sheets.info.acrossMergedCell")),!1;const interceptorCommands=sheetInterceptorService.onCommandExecute({id:MoveRangeCommand.id,params:{...params}}),redos=[...(_a21=interceptorCommands.preRedos)!=null?_a21:[],...moveRangeMutations.redos,...interceptorCommands.redos,{id:SetSelectionsOperation.id,params:{unitId,subUnitId,selections:[{range:params.toRange,primary:getPrimaryForRange(params.toRange,worksheet)}]}}],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],...moveRangeMutations.undos,...interceptorCommands.undos,{id:SetSelectionsOperation.id,params:{unitId,subUnitId,selections:[{range:params.fromRange,primary:getPrimaryForRange(params.fromRange,worksheet)}]}}];return core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")};function getMoveRangeUndoRedoMutations(accessor,from,to,ignoreMerge=!1){const redos=[],undos=[],{range:fromRange,subUnitId:fromSubUnitId,unitId}=from,{range:toRange,subUnitId:toSubUnitId}=to,workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId),toWorksheet=workbook==null?void 0:workbook.getSheetBySheetId(toSubUnitId),fromWorksheet=workbook==null?void 0:workbook.getSheetBySheetId(fromSubUnitId),toCellMatrix=toWorksheet==null?void 0:toWorksheet.getCellMatrix(),fromCellMatrix=fromWorksheet==null?void 0:fromWorksheet.getCellMatrix();if(toWorksheet&&fromWorksheet&&toCellMatrix&&fromCellMatrix){const alignedRangeWithToRange=alignToMergedCellsBorders(toRange,toWorksheet,!1);if(!core.Rectangle.equals(toRange,alignedRangeWithToRange)&&!ignoreMerge)return null;const fromCellValue=new core.ObjectMatrix,newFromCellValue=new core.ObjectMatrix;core.Range.foreach(fromRange,(row,col)=>{fromCellValue.setValue(row,col,core.Tools.deepClone(fromCellMatrix.getValue(row,col))),newFromCellValue.setValue(row,col,null)});const toCellValue=new core.ObjectMatrix,newToCellValue=new core.ObjectMatrix;core.Range.foreach(toRange,(row,col)=>{toCellValue.setValue(row,col,core.Tools.deepClone(toCellMatrix.getValue(row,col)))}),core.Range.foreach(fromRange,(row,col)=>{const cellRange=core.cellToRange(row,col),relativeRange=core.Rectangle.getRelativeRange(cellRange,fromRange),range=core.Rectangle.getPositionRange(relativeRange,toRange);newToCellValue.setValue(range.startRow,range.startColumn,core.Tools.deepClone(fromCellMatrix.getValue(row,col)))});const doMoveRangeMutation={fromRange:from.range,toRange:to.range,from:{value:newFromCellValue.getMatrix(),subUnitId:fromSubUnitId},to:{value:newToCellValue.getMatrix(),subUnitId:toSubUnitId},unitId},undoMoveRangeMutation={fromRange:to.range,toRange:from.range,from:{value:fromCellValue.getMatrix(),subUnitId:fromSubUnitId},to:{value:toCellValue.getMatrix(),subUnitId:toSubUnitId},unitId};redos.push({id:MoveRangeMutation.id,params:doMoveRangeMutation}),undos.push({id:MoveRangeMutation.id,params:undoMoveRangeMutation})}return{redos,undos}}__name(getMoveRangeUndoRedoMutations,"getMoveRangeUndoRedoMutations");var I=(E=>(E[E.UNIVER_UNKNOWN=0]="UNIVER_UNKNOWN",E[E.UNIVER_DOC=1]="UNIVER_DOC",E[E.UNIVER_SHEET=2]="UNIVER_SHEET",E[E.UNIVER_SLIDE=3]="UNIVER_SLIDE",E[E.UNIVER_PROJECT=4]="UNIVER_PROJECT",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(I||{}),P=(E=>(E[E.View=0]="View",E[E.Edit=1]="Edit",E[E.ManageCollaborator=2]="ManageCollaborator",E[E.Print=3]="Print",E[E.Duplicate=4]="Duplicate",E[E.Comment=5]="Comment",E[E.Copy=6]="Copy",E[E.Share=7]="Share",E[E.Export=8]="Export",E[E.MoveWorksheet=9]="MoveWorksheet",E[E.DeleteWorksheet=10]="DeleteWorksheet",E[E.HideWorksheet=11]="HideWorksheet",E[E.RenameWorksheet=12]="RenameWorksheet",E[E.CreateWorksheet=13]="CreateWorksheet",E[E.SetWorksheetStyle=14]="SetWorksheetStyle",E[E.EditWorksheetCell=15]="EditWorksheetCell",E[E.InsertHyperlink=16]="InsertHyperlink",E[E.Sort=17]="Sort",E[E.Filter=18]="Filter",E[E.PivotTable=19]="PivotTable",E[E.FloatImg=20]="FloatImg",E[E.History=21]="History",E[E.RwHgtClWdt=22]="RwHgtClWdt",E[E.ViemRwHgtClWdt=23]="ViemRwHgtClWdt",E[E.ViewFilter=24]="ViewFilter",E[E.MoveSheet=25]="MoveSheet",E[E.DeleteSheet=26]="DeleteSheet",E[E.HideSheet=27]="HideSheet",E[E.CopySheet=28]="CopySheet",E[E.RenameSheet=29]="RenameSheet",E[E.CreateSheet=30]="CreateSheet",E[E.SelectProtectedCells=31]="SelectProtectedCells",E[E.SelectUnProtectedCells=32]="SelectUnProtectedCells",E[E.SetCellStyle=33]="SetCellStyle",E[E.SetCellValue=34]="SetCellValue",E[E.SetRowStyle=35]="SetRowStyle",E[E.SetColumnStyle=36]="SetColumnStyle",E[E.InsertRow=37]="InsertRow",E[E.InsertColumn=38]="InsertColumn",E[E.DeleteRow=39]="DeleteRow",E[E.DeleteColumn=40]="DeleteColumn",E[E.EditExtraObject=41]="EditExtraObject",E[E.Delete=42]="Delete",E[E.RecoverHistory=43]="RecoverHistory",E[E.ViewHistory=44]="ViewHistory",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(P||{}),M=(E=>(E[E.Unkonwn=0]="Unkonwn",E[E.Workbook=1]="Workbook",E[E.Worksheet=2]="Worksheet",E[E.SelectRange=3]="SelectRange",E[E.Document=4]="Document",E[E.Slide=5]="Slide",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(M||{});const _RangeProtectionPermissionEditPoint=class _RangeProtectionPermissionEditPoint{constructor(unitId,subUnitId,permissionId){__publicField(this,"type",M.SelectRange);__publicField(this,"subType",P.Edit);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"value",!0);__publicField(this,"id");__publicField(this,"unitId");__publicField(this,"subUnitId");__publicField(this,"permissionId");this.unitId=unitId,this.subUnitId=subUnitId,this.permissionId=permissionId,this.id=`${M.SelectRange}.${P.Edit}.${permissionId}`}};__name(_RangeProtectionPermissionEditPoint,"RangeProtectionPermissionEditPoint");let RangeProtectionPermissionEditPoint=_RangeProtectionPermissionEditPoint;const _RangeProtectionPermissionViewPoint=class _RangeProtectionPermissionViewPoint{constructor(unitId,subUnitId,permissionId){__publicField(this,"type",M.SelectRange);__publicField(this,"subType",P.View);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"value",!0);__publicField(this,"id");__publicField(this,"unitId");__publicField(this,"subUnitId");__publicField(this,"permissionId");this.unitId=unitId,this.subUnitId=subUnitId,this.permissionId=permissionId,this.id=`${M.SelectRange}.${P.View}.${permissionId}`}};__name(_RangeProtectionPermissionViewPoint,"RangeProtectionPermissionViewPoint");let RangeProtectionPermissionViewPoint=_RangeProtectionPermissionViewPoint;const _WorkbookCommentPermission=class _WorkbookCommentPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Comment);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Comment}_${unitId}`}};__name(_WorkbookCommentPermission,"WorkbookCommentPermission");let WorkbookCommentPermission=_WorkbookCommentPermission;const _WorkbookCopyPermission=class _WorkbookCopyPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Copy);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Copy}_${unitId}`}};__name(_WorkbookCopyPermission,"WorkbookCopyPermission");let WorkbookCopyPermission=_WorkbookCopyPermission;const _WorkbookCopySheetPermission=class _WorkbookCopySheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"subType",P.CopySheet);__publicField(this,"status",core.PermissionStatus.INIT);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.CopySheet}_${unitId}`}};__name(_WorkbookCopySheetPermission,"WorkbookCopySheetPermission");let WorkbookCopySheetPermission=_WorkbookCopySheetPermission;const _WorkbookCreateSheetPermission=class _WorkbookCreateSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.CreateSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.CreateSheet}_${unitId}`}};__name(_WorkbookCreateSheetPermission,"WorkbookCreateSheetPermission");let WorkbookCreateSheetPermission=_WorkbookCreateSheetPermission;const _WorkbookDeleteSheetPermission=class _WorkbookDeleteSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.DeleteSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.DeleteSheet}_${unitId}`}};__name(_WorkbookDeleteSheetPermission,"WorkbookDeleteSheetPermission");let WorkbookDeleteSheetPermission=_WorkbookDeleteSheetPermission;const _WorkbookDuplicatePermission=class _WorkbookDuplicatePermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Duplicate);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Duplicate}_${unitId}`}};__name(_WorkbookDuplicatePermission,"WorkbookDuplicatePermission");let WorkbookDuplicatePermission=_WorkbookDuplicatePermission;const _WorkbookEditablePermission=class _WorkbookEditablePermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Edit);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Edit}_${unitId}`}};__name(_WorkbookEditablePermission,"WorkbookEditablePermission");let WorkbookEditablePermission=_WorkbookEditablePermission;const _WorkbookExportPermission=class _WorkbookExportPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Export);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Export}_${unitId}`}};__name(_WorkbookExportPermission,"WorkbookExportPermission");let WorkbookExportPermission=_WorkbookExportPermission;const _WorkbookHideSheetPermission=class _WorkbookHideSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.HideSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.HideSheet}_${unitId}`}};__name(_WorkbookHideSheetPermission,"WorkbookHideSheetPermission");let WorkbookHideSheetPermission=_WorkbookHideSheetPermission;const _WorkbookHistoryPermission=class _WorkbookHistoryPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.History);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.History}_${unitId}`}};__name(_WorkbookHistoryPermission,"WorkbookHistoryPermission");let WorkbookHistoryPermission=_WorkbookHistoryPermission;const _WorkbookManageCollaboratorPermission=class _WorkbookManageCollaboratorPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.ManageCollaborator);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.ManageCollaborator}_${unitId}`}};__name(_WorkbookManageCollaboratorPermission,"WorkbookManageCollaboratorPermission");let WorkbookManageCollaboratorPermission=_WorkbookManageCollaboratorPermission;const _WorkbookMoveSheetPermission=class _WorkbookMoveSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.MoveSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.MoveSheet}_${unitId}`}};__name(_WorkbookMoveSheetPermission,"WorkbookMoveSheetPermission");let WorkbookMoveSheetPermission=_WorkbookMoveSheetPermission;const _WorkbookPrintPermission=class _WorkbookPrintPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Print);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Print}_${unitId}`}};__name(_WorkbookPrintPermission,"WorkbookPrintPermission");let WorkbookPrintPermission=_WorkbookPrintPermission;const _WorkbookRecoverHistoryPermission=class _WorkbookRecoverHistoryPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.RecoverHistory);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.RecoverHistory}_${unitId}`}};__name(_WorkbookRecoverHistoryPermission,"WorkbookRecoverHistoryPermission");let WorkbookRecoverHistoryPermission=_WorkbookRecoverHistoryPermission;const _WorkbookRenameSheetPermission=class _WorkbookRenameSheetPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.RenameSheet);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.RenameSheet}_${unitId}`}};__name(_WorkbookRenameSheetPermission,"WorkbookRenameSheetPermission");let WorkbookRenameSheetPermission=_WorkbookRenameSheetPermission;const _WorkbookSharePermission=class _WorkbookSharePermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.Share);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.Share}_${unitId}`}};__name(_WorkbookSharePermission,"WorkbookSharePermission");let WorkbookSharePermission=_WorkbookSharePermission;const _WorkbookViewPermission=class _WorkbookViewPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.View);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.View}_${unitId}`}};__name(_WorkbookViewPermission,"WorkbookViewPermission");let WorkbookViewPermission=_WorkbookViewPermission;const _WorkbookViewHistoryPermission=class _WorkbookViewHistoryPermission{constructor(unitId){__publicField(this,"id");__publicField(this,"value",!0);__publicField(this,"type",M.Workbook);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"subType",P.ViewHistory);this.unitId=unitId,this.unitId=unitId,this.id=`${this.type}.${P.ViewHistory}_${unitId}`}};__name(_WorkbookViewHistoryPermission,"WorkbookViewHistoryPermission");let WorkbookViewHistoryPermission=_WorkbookViewHistoryPermission;const _WorksheetCopyPermission=class _WorksheetCopyPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Copy);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Copy}_${unitId}_${subUnitId}`}};__name(_WorksheetCopyPermission,"WorksheetCopyPermission");let WorksheetCopyPermission=_WorksheetCopyPermission;const _WorksheetDeleteColumnPermission=class _WorksheetDeleteColumnPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.DeleteColumn);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.DeleteColumn}_${unitId}_${subUnitId}`}};__name(_WorksheetDeleteColumnPermission,"WorksheetDeleteColumnPermission");let WorksheetDeleteColumnPermission=_WorksheetDeleteColumnPermission;const _WorksheetDeleteRowPermission=class _WorksheetDeleteRowPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.DeleteRow);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.DeleteRow}_${unitId}_${subUnitId}`}};__name(_WorksheetDeleteRowPermission,"WorksheetDeleteRowPermission");let WorksheetDeleteRowPermission=_WorksheetDeleteRowPermission;const _WorksheetEditPermission=class _WorksheetEditPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Edit);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Edit}_${unitId}_${subUnitId}`}};__name(_WorksheetEditPermission,"WorksheetEditPermission");let WorksheetEditPermission=_WorksheetEditPermission;const _WorksheetEditExtraObjectPermission=class _WorksheetEditExtraObjectPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.EditExtraObject);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.EditExtraObject}_${unitId}_${subUnitId}`}};__name(_WorksheetEditExtraObjectPermission,"WorksheetEditExtraObjectPermission");let WorksheetEditExtraObjectPermission=_WorksheetEditExtraObjectPermission;const _WorksheetFilterPermission=class _WorksheetFilterPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Filter);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Filter}_${unitId}_${subUnitId}`}};__name(_WorksheetFilterPermission,"WorksheetFilterPermission");let WorksheetFilterPermission=_WorksheetFilterPermission;const _WorksheetInsertColumnPermission=class _WorksheetInsertColumnPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.InsertColumn);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.InsertColumn}_${unitId}_${subUnitId}`}};__name(_WorksheetInsertColumnPermission,"WorksheetInsertColumnPermission");let WorksheetInsertColumnPermission=_WorksheetInsertColumnPermission;const _WorksheetInsertHyperlinkPermission=class _WorksheetInsertHyperlinkPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.InsertHyperlink);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.InsertHyperlink}_${unitId}_${subUnitId}`}};__name(_WorksheetInsertHyperlinkPermission,"WorksheetInsertHyperlinkPermission");let WorksheetInsertHyperlinkPermission=_WorksheetInsertHyperlinkPermission;const _WorksheetInsertRowPermission=class _WorksheetInsertRowPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.InsertRow);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.InsertRow}_${unitId}_${subUnitId}`}};__name(_WorksheetInsertRowPermission,"WorksheetInsertRowPermission");let WorksheetInsertRowPermission=_WorksheetInsertRowPermission;const _WorksheetManageCollaboratorPermission=class _WorksheetManageCollaboratorPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.ManageCollaborator);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.ManageCollaborator}_${unitId}_${subUnitId}`}};__name(_WorksheetManageCollaboratorPermission,"WorksheetManageCollaboratorPermission");let WorksheetManageCollaboratorPermission=_WorksheetManageCollaboratorPermission;const _WorksheetPivotTablePermission=class _WorksheetPivotTablePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.PivotTable);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.PivotTable}_${unitId}_${subUnitId}`}};__name(_WorksheetPivotTablePermission,"WorksheetPivotTablePermission");let WorksheetPivotTablePermission=_WorksheetPivotTablePermission;const _WorksheetSelectProtectedCellsPermission=class _WorksheetSelectProtectedCellsPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SelectProtectedCells);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SelectProtectedCells}_${unitId}_${subUnitId}`}};__name(_WorksheetSelectProtectedCellsPermission,"WorksheetSelectProtectedCellsPermission");let WorksheetSelectProtectedCellsPermission=_WorksheetSelectProtectedCellsPermission;const _WorksheetSelectUnProtectedCellsPermission=class _WorksheetSelectUnProtectedCellsPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SelectUnProtectedCells);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SelectUnProtectedCells}_${unitId}_${subUnitId}`}};__name(_WorksheetSelectUnProtectedCellsPermission,"WorksheetSelectUnProtectedCellsPermission");let WorksheetSelectUnProtectedCellsPermission=_WorksheetSelectUnProtectedCellsPermission;const _WorksheetSetCellStylePermission=class _WorksheetSetCellStylePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetCellStyle);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetCellStyle}_${unitId}_${subUnitId}`}};__name(_WorksheetSetCellStylePermission,"WorksheetSetCellStylePermission");let WorksheetSetCellStylePermission=_WorksheetSetCellStylePermission;const _WorksheetSetCellValuePermission=class _WorksheetSetCellValuePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetCellValue);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetCellValue}_${unitId}_${subUnitId}`}};__name(_WorksheetSetCellValuePermission,"WorksheetSetCellValuePermission");let WorksheetSetCellValuePermission=_WorksheetSetCellValuePermission;const _WorksheetSetColumnStylePermission=class _WorksheetSetColumnStylePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetColumnStyle);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetColumnStyle}_${unitId}_${subUnitId}`}};__name(_WorksheetSetColumnStylePermission,"WorksheetSetColumnStylePermission");let WorksheetSetColumnStylePermission=_WorksheetSetColumnStylePermission;const _WorksheetSetRowStylePermission=class _WorksheetSetRowStylePermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.SetRowStyle);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.SetRowStyle}_${unitId}_${subUnitId}`}};__name(_WorksheetSetRowStylePermission,"WorksheetSetRowStylePermission");let WorksheetSetRowStylePermission=_WorksheetSetRowStylePermission;const _WorksheetSortPermission=class _WorksheetSortPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.Sort);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.Sort}_${unitId}_${subUnitId}`}};__name(_WorksheetSortPermission,"WorksheetSortPermission");let WorksheetSortPermission=_WorksheetSortPermission;const _WorksheetViewPermission=class _WorksheetViewPermission{constructor(unitId,subUnitId){__publicField(this,"value",!0);__publicField(this,"type",M.Worksheet);__publicField(this,"status",core.PermissionStatus.INIT);__publicField(this,"id");__publicField(this,"subType",P.View);this.unitId=unitId,this.subUnitId=subUnitId,this.id=`${this.type}.${P.View}_${unitId}_${subUnitId}`}};__name(_WorksheetViewPermission,"WorksheetViewPermission");let WorksheetViewPermission=_WorksheetViewPermission;const SetRangeValuesCommand={id:"sheet.command.set-range-values",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a21;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),permissionService=accessor.get(core.IPermissionService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{subUnitId,unitId,workbook,worksheet}=target,{value,range}=params,currentSelections=range?[range]:(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!currentSelections||!currentSelections.length||!permissionService.getPermissionPoint(new WorksheetEditPermission(unitId,subUnitId).id))return!1;const cellValue=new core.ObjectMatrix;let realCellValue;if(core.Tools.isArray(value))for(let i=0;i<currentSelections.length;i++){const{startRow,startColumn,endRow,endColumn}=currentSelections[i];for(let r=0;r<=endRow-startRow;r++)for(let c=0;c<=endColumn-startColumn;c++)cellValue.setValue(r+startRow,c+startColumn,value[r][c])}else if(core.isICellData(value))for(let i=0;i<currentSelections.length;i++){const{startRow,startColumn,endRow,endColumn}=currentSelections[i];for(let r=startRow;r<=endRow;r++)for(let c=startColumn;c<=endColumn;c++)cellValue.setValue(r,c,value)}else realCellValue=value;const setRangeValuesMutationParams={subUnitId,unitId,cellValue:realCellValue!=null?realCellValue:cellValue.getMatrix()},redoParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams);if(!commandService.syncExecuteCommand(SetRangeValuesMutation.id,setRangeValuesMutationParams))return!1;const{undos,redos}=sheetInterceptorService.onCommandExecute({id:SetRangeValuesCommand.id,params:{...setRangeValuesMutationParams,range:currentSelections}});if(core.sequenceExecute([...redos],commandService).result){const selectionOperation=followSelectionOperation(range!=null?range:cellValue.getRange(),workbook,worksheet);return undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetRangeValuesMutation.id,params:redoParams},...undos,selectionOperation],redoMutations:[{id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...redos,core.Tools.deepClone(selectionOperation)]}),!0}return!1},"handler")};function getInsertRangeMutations(accessor,params){const redo=[],undo=[],{unitId,subUnitId,range,shiftDimension,cellValue={}}=params,instanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=instanceService.getUniverSheetInstance(unitId),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(worksheet){const cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange();if(range.startColumn<=dataRange.endColumn||range.startRow<=dataRange.endRow){let moveFromRange,moveToRange;if(shiftDimension===core.Dimension.COLUMNS){const endRow=Math.min(range.endRow,dataRange.endRow);let endColumn=0;for(let row=range.startRow;row<=endRow;row++){const rowData=cellMatrix.getRow(row),rowLength=rowData?core.getArrayLength(rowData)-1:0;endColumn=Math.max(endColumn,rowLength)}moveFromRange={startRow:range.startRow,startColumn:range.startColumn,endRow,endColumn};const shift=range.endColumn-range.startColumn+1;moveToRange={startRow:range.startRow,startColumn:moveFromRange.startColumn+shift,endRow,endColumn:moveFromRange.endColumn+shift}}else{const endColumn=Math.min(range.endColumn,dataRange.endColumn),endRow=dataRange.endRow;moveFromRange={startRow:range.startRow,startColumn:range.startColumn,endRow,endColumn};const shift=range.endRow-range.startRow+1;moveToRange={startRow:moveFromRange.startRow+shift,startColumn:range.startColumn,endRow:moveFromRange.endRow+shift,endColumn}}const moveRangeMutations=getMoveRangeUndoRedoMutations(accessor,{unitId,subUnitId,range:moveFromRange},{unitId,subUnitId,range:moveToRange},!0);moveRangeMutations&&(redo.push(...moveRangeMutations.redos),undo.push(...moveRangeMutations.undos))}if(Object.entries(cellValue).length===0)for(let row=range.startRow;row<=range.endRow;row++){cellValue[row]||(cellValue[row]={});for(let column=range.startColumn;column<=range.endColumn;column++)cellValue[row][column]=null}const setRangeValuesMutationParams={subUnitId,unitId,cellValue},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams),{undos:interceptorUndos,redos:interceptorRedos}=sheetInterceptorService.onCommandExecute({id:SetRangeValuesCommand.id,params:{...setRangeValuesMutationParams,range}});redo.push({id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...interceptorRedos),undo.push({id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams},...interceptorUndos)}return{redo,undo}}__name(getInsertRangeMutations,"getInsertRangeMutations");function getRemoveRangeMutations(accessor,params){const redo=[],undo=[],{unitId,subUnitId,range,shiftDimension}=params,instanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),workbook=instanceService.getUniverSheetInstance(unitId),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(worksheet){const cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange(),setRangeValuesMutationParams={subUnitId,unitId,cellValue:generateNullCell([range])},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams),intercepted=sheetInterceptorService.onCommandExecute({id:SetRangeValuesCommand.id,params:setRangeValuesMutationParams});if(redo.push({id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...intercepted.redos),undo.push(...intercepted.undos,{id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams}),range.startColumn<=dataRange.endColumn||range.startRow<=dataRange.endRow){let moveFromRange=null,moveToRange=null;if(shiftDimension===core.Dimension.COLUMNS&&range.endColumn<dataRange.endColumn){const endRow=Math.min(range.endRow,dataRange.endRow);let endColumn=0;for(let row=range.startRow;row<=endRow;row++){const rowData=cellMatrix.getRow(row),rowLength=rowData?core.getArrayLength(rowData)-1:0;endColumn=Math.max(endColumn,rowLength)}moveFromRange={startRow:range.startRow,startColumn:range.endColumn+1,endRow,endColumn};const shift=range.endColumn-range.startColumn+1;moveToRange={startRow:range.startRow,startColumn:moveFromRange.startColumn-shift,endRow,endColumn:moveFromRange.endColumn-shift}}if(shiftDimension===core.Dimension.ROWS&&range.endRow<dataRange.endRow){const endColumn=Math.min(range.endColumn,dataRange.endColumn),endRow=dataRange.endRow;moveFromRange={startRow:range.endRow+1,startColumn:range.startColumn,endRow,endColumn};const shift=range.endRow-range.startRow+1;moveToRange={startRow:moveFromRange.startRow-shift,startColumn:range.startColumn,endRow:moveFromRange.endRow-shift,endColumn}}if(moveFromRange&&moveToRange){const moveRangeMutations=getMoveRangeUndoRedoMutations(accessor,{unitId,subUnitId,range:moveFromRange},{unitId,subUnitId,range:moveToRange},!0);moveRangeMutations&&(redo.push(...moveRangeMutations.redos),undo.push(...moveRangeMutations.undos))}}}return{redo,undo}}__name(getRemoveRangeMutations,"getRemoveRangeMutations");function handleInsertRangeMutation(cellMatrix,range,lastEndRow,lastEndColumn,shiftDimension,cellValue){const{startRow,endRow,startColumn,endColumn}=range;if(shiftDimension===core.Dimension.ROWS){const rows=endRow-startRow+1;for(let r=lastEndRow;r>=startRow;r--)for(let c=startColumn;c<=endColumn;c++){const value=cellMatrix.getValue(r,c);value==null?cellMatrix.realDeleteValue(r+rows,c):cellMatrix.setValue(r+rows,c,value)}for(let r=endRow;r>=startRow;r--)for(let c=startColumn;c<=endColumn;c++)cellValue&&cellValue[r]&&cellValue[r][c]?cellMatrix.setValue(r,c,cellValue[r][c]):cellMatrix.realDeleteValue(r,c)}else if(shiftDimension===core.Dimension.COLUMNS){const columns=endColumn-startColumn+1;for(let r=startRow;r<=endRow;r++)for(let c=lastEndColumn;c>=startColumn;c--){const value=cellMatrix.getValue(r,c);value==null?cellMatrix.realDeleteValue(r,c+columns):cellMatrix.setValue(r,c+columns,value)}for(let r=startRow;r<=endRow;r++)for(let c=endColumn;c>=startColumn;c--)cellValue&&cellValue[r]&&cellValue[r][c]?cellMatrix.setValue(r,c,cellValue[r][c]):cellMatrix.realDeleteValue(r,c)}}__name(handleInsertRangeMutation,"handleInsertRangeMutation");function handleDeleteRangeMutation(cellMatrix,range,lastEndRow,lastEndColumn,shiftDimension){const{startRow,endRow,startColumn,endColumn}=range,rows=endRow-startRow+1,columns=endColumn-startColumn+1;if(shiftDimension===core.Dimension.ROWS)for(let r=startRow;r<=lastEndRow;r++)for(let c=startColumn;c<=endColumn;c++){const value=cellMatrix.getValue(r+rows,c);value==null?cellMatrix.realDeleteValue(r,c):cellMatrix.setValue(r,c,value)}else if(shiftDimension===core.Dimension.COLUMNS)for(let r=startRow;r<=endRow;r++)for(let c=startColumn;c<=lastEndColumn;c++){const value=cellMatrix.getValue(r,c+columns);value==null?cellMatrix.realDeleteValue(r,c):cellMatrix.setValue(r,c,value)}}__name(handleDeleteRangeMutation,"handleDeleteRangeMutation");const DeleteRangeMoveLeftCommandId="sheet.command.delete-range-move-left",DeleteRangeMoveLeftCommand={type:core.CommandType.COMMAND,id:DeleteRangeMoveLeftCommandId,handler:__name(async(accessor,params)=>{var _a21,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,workbook,subUnitId,unitId}=target;let range=params==null?void 0:params.range;if(range||(range=(_a21=selectionManagerService.getCurrentLastSelection())==null?void 0:_a21.range),!range)return!1;const deleteRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.COLUMNS},sheetInterceptor=sheetInterceptorService.onCommandExecute({id:DeleteRangeMoveLeftCommand.id,params:{range}}),{redo:removeRangeRedo,undo:removeRangeUndo}=getRemoveRangeMutations(accessor,deleteRangeMutationParams),redos=[...(_b=sheetInterceptor.preRedos)!=null?_b:[],...removeRangeRedo],undos=[...sheetInterceptor.undos,...removeRangeUndo];return redos.push(...sheetInterceptor.redos),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.push(...(_c=sheetInterceptor.preUndos)!=null?_c:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos.reverse(),redoMutations:redos}),!0):!1},"handler")},DeleteRangeMoveUpCommandId="sheet.command.delete-range-move-up",DeleteRangeMoveUpCommand={type:core.CommandType.COMMAND,id:DeleteRangeMoveUpCommandId,handler:__name(async(accessor,params)=>{var _a21,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,workbook,worksheet}=target;let range=params==null?void 0:params.range;if(range||(range=(_a21=selectionManagerService.getCurrentLastSelection())==null?void 0:_a21.range),!range)return!1;const deleteRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.ROWS},sheetInterceptor=sheetInterceptorService.onCommandExecute({id:DeleteRangeMoveUpCommand.id,params:{range}}),{redo:removeRangeRedo,undo:removeRangeUndo}=getRemoveRangeMutations(accessor,deleteRangeMutationParams),redos=[...(_b=sheetInterceptor.preRedos)!=null?_b:[],...removeRangeRedo],undos=[...sheetInterceptor.undos,...removeRangeUndo];return redos.push(...sheetInterceptor.redos),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.push(...(_c=sheetInterceptor.preUndos)!=null?_c:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos.reverse(),redoMutations:redos}),!0):!1},"handler")},InsertRowMutationUndoFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range}},"InsertRowMutationUndoFactory"),InsertRowMutation={id:"sheet.mutation.insert-row",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a21;const{unitId,subUnitId,range,rowInfo}=params,universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const rowWrapper=worksheet.getRowManager().getRowData(),defaultRowInfo={h:worksheet.getConfig().defaultRowHeight,hd:0},rowIndex=range.startRow,rowCount=range.endRow-range.startRow+1;for(let j=rowIndex;j<rowIndex+rowCount;j++)rowInfo?core.insertMatrixArray(j,(_a21=rowInfo[j-range.startRow])!=null?_a21:defaultRowInfo,rowWrapper):core.insertMatrixArray(j,defaultRowInfo,rowWrapper);return worksheet.setRowCount(worksheet.getRowCount()+range.endRow-range.startRow+1),worksheet.getCellMatrix().insertRows(range.startRow,rowCount),!0},"handler")},InsertColMutationUndoFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range}},"InsertColMutationUndoFactory"),InsertColMutation={id:"sheet.mutation.insert-col",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a21;const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const manager=worksheet.getColumnManager(),{range,colInfo}=params,columnWrapper=manager.getColumnData(),colIndex=range.startColumn,colCount=range.endColumn-range.startColumn+1,defaultColWidth=worksheet.getConfig().defaultColumnWidth;for(let j=colIndex;j<colIndex+colCount;j++){const defaultColInfo={w:defaultColWidth,hd:0};colInfo?core.insertMatrixArray(j,(_a21=colInfo[j-range.startColumn])!=null?_a21:defaultColInfo,columnWrapper):core.insertMatrixArray(j,defaultColInfo,columnWrapper)}return worksheet.setColumnCount(worksheet.getColumnCount()+range.endColumn-range.startColumn+1),worksheet.getCellMatrix().insertColumns(range.startColumn,colCount),!0},"handler")},RemoveRowsUndoMutationFactory=__name((params,worksheet)=>{const rowWrapper=worksheet.getRowManager().getRowData(),rowInfo={},range=params.range,slice=core.sliceMatrixArray(range.startRow,range.endRow,rowWrapper),_rowInfo=core.concatMatrixArray(rowInfo,slice);return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,rowInfo:_rowInfo}},"RemoveRowsUndoMutationFactory"),RemoveRowMutation={id:"sheet.mutation.remove-rows",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const range=params.range,rowPrimitive=worksheet.getRowManager().getRowData();for(let i=range.startRow;i<=range.endRow;i++)worksheet.getRowFiltered(i);const rowCount=range.endRow-range.startRow+1;return core.spliceArray(range.startRow,rowCount,rowPrimitive),worksheet.getCellMatrix().removeRows(range.startRow,rowCount),worksheet.setRowCount(worksheet.getRowCount()-rowCount),!0},"handler")},RemoveColMutationFactory=__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const columnWrapper=worksheet.getColumnManager().getColumnData(),colInfo={},range=params.range,slice=core.sliceMatrixArray(range.startColumn,range.endColumn,columnWrapper),_colInfo=core.concatMatrixArray(colInfo,slice);return{unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,colInfo:_colInfo}},"RemoveColMutationFactory"),RemoveColMutation={id:"sheet.mutation.remove-col",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const range=params.range,colPrimitive=worksheet.getColumnManager().getColumnData(),colCount=range.endColumn-range.startColumn+1;return core.spliceArray(range.startColumn,colCount,colPrimitive),worksheet.setColumnCount(worksheet.getColumnCount()-colCount),worksheet.getCellMatrix().removeColumns(range.startColumn,colCount),!0},"handler")},InsertRangeMoveDownCommandId="sheet.command.insert-range-move-down",InsertRangeMoveDownCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-range-move-down",handler:__name(async(accessor,params)=>{var _a21,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService);if(selectionManagerService.isOverlapping())return errorService.emit(localeService.t("sheets.info.overlappingSelections")),!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,worksheet,workbook}=target;let range=params==null?void 0:params.range;if(range||(range=(_a21=selectionManagerService.getCurrentLastSelection())==null?void 0:_a21.range),!range)return!1;const redoMutations=[],undoMutations=[],cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange(),sliceMaxRow=cellMatrix.getSlice(dataRange.startRow,dataRange.endRow,range.startColumn,range.endColumn).getDataRange().endRow,insertRowCount=Math.max(sliceMaxRow+(range.endRow-range.startRow+1)-dataRange.endRow,0);if(insertRowCount>0){const anchorRow=range.startRow-1,height=worksheet.getRowHeight(anchorRow),insertRowParams={unitId,subUnitId,range:{startRow:dataRange.endRow+1,endRow:dataRange.endRow+insertRowCount,startColumn:dataRange.startColumn,endColumn:dataRange.endColumn},rowInfo:new Array(insertRowCount).fill(void 0).map(()=>({h:height,hd:core.BooleanNumber.FALSE}))};redoMutations.push({id:InsertRowMutation.id,params:insertRowParams});const undoRowInsertionParams=InsertRowMutationUndoFactory(accessor,insertRowParams);undoMutations.push({id:RemoveRowMutation.id,params:undoRowInsertionParams})}const cellValue={};core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCell(row,col);cell&&(cellValue[row]||(cellValue[row]={}),cellValue[row][col]={s:cell.s})});const insertRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.ROWS,cellValue},{redo:insertRangeRedo,undo:insertRangeUndo}=getInsertRangeMutations(accessor,insertRangeMutationParams);redoMutations.push(...insertRangeRedo),undoMutations.push(...insertRangeUndo);const sheetInterceptor=sheetInterceptorService.onCommandExecute({id:InsertRangeMoveDownCommand.id,params:{range}});return redoMutations.push(...sheetInterceptor.redos),redoMutations.push(followSelectionOperation(range,workbook,worksheet)),undoMutations.push(...(_b=sheetInterceptor.preUndos)!=null?_b:[]),redoMutations.unshift(...(_c=sheetInterceptor.preRedos)!=null?_c:[]),undoMutations.unshift(...sheetInterceptor.undos),core.sequenceExecute(redoMutations,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undoMutations.reverse(),redoMutations}),!0):!1},"handler")},InsertRangeMoveRightCommandId="sheet.command.insert-range-move-right",InsertRangeMoveRightCommand={type:core.CommandType.COMMAND,id:InsertRangeMoveRightCommandId,handler:__name(async(accessor,params)=>{var _a21,_b,_c;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService);if(selectionManagerService.isOverlapping())return errorService.emit(localeService.t("sheets.info.overlappingSelections")),!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,unitId,subUnitId}=target;let range=params==null?void 0:params.range;if(range||(range=(_a21=selectionManagerService.getCurrentLastSelection())==null?void 0:_a21.range),!range)return!1;const redoMutations=[],undoMutations=[],cellMatrix=worksheet.getCellMatrix(),dataRange=cellMatrix.getDataRange(),sliceMaxCol=cellMatrix.getSlice(range.startRow,range.endRow,dataRange.startColumn,dataRange.endColumn).getDataRange().endColumn,insertColCount=Math.max(sliceMaxCol+(range.endColumn-range.startColumn+1)-dataRange.endColumn,0);if(insertColCount>0){const anchorCol=range.startColumn-1,width=worksheet.getColumnWidth(anchorCol),insertColParams={unitId,subUnitId,range:{startRow:dataRange.startRow+1,endRow:dataRange.endRow,startColumn:dataRange.endColumn+1,endColumn:dataRange.endColumn+insertColCount},colInfo:new Array(insertColCount).fill(void 0).map(()=>({w:width,hd:core.BooleanNumber.FALSE}))};redoMutations.push({id:InsertColMutation.id,params:insertColParams});const undoColInsertionParams=InsertColMutationUndoFactory(accessor,insertColParams);undoMutations.push({id:RemoveColMutation.id,params:undoColInsertionParams})}const cellValue={};core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCell(row,col);!cell||!cell.s||(cellValue[row]||(cellValue[row]={}),cellValue[row][col]={s:cell.s})});const insertRangeMutationParams={range,subUnitId,unitId,shiftDimension:core.Dimension.COLUMNS,cellValue},{redo:insertRangeRedo,undo:insertRangeUndo}=getInsertRangeMutations(accessor,insertRangeMutationParams);redoMutations.push(...insertRangeRedo),undoMutations.push(...insertRangeUndo);const sheetInterceptor=sheetInterceptorService.onCommandExecute({id:InsertRangeMoveRightCommand.id,params:{range}});return redoMutations.push(...sheetInterceptor.redos),redoMutations.push(followSelectionOperation(range,workbook,worksheet)),undoMutations.push(...(_b=sheetInterceptor.preUndos)!=null?_b:[]),redoMutations.unshift(...(_c=sheetInterceptor.preRedos)!=null?_c:[]),undoMutations.unshift(...sheetInterceptor.undos),core.sequenceExecute(redoMutations,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undoMutations.reverse(),redoMutations}),!0):!1},"handler")},InsertRowCommandId="sheet.command.insert-row",InsertRowCommand={type:core.CommandType.COMMAND,id:InsertRowCommandId,handler:__name(async(accessor,params)=>{var _a21,_b,_c,_d;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{workbook,worksheet}=target,{range,direction,unitId,subUnitId,cellValue}=params,{startRow,endRow}=range;range.rangeType=core.RANGE_TYPE.ROW;const anchorRow=direction===core.Direction.UP?startRow:startRow-1,height=worksheet.getRowHeight(anchorRow),insertRowParams={unitId,subUnitId,range,rowInfo:new Array(endRow-startRow+1).fill(void 0).map(()=>({h:height,hd:core.BooleanNumber.FALSE}))},undoRowInsertionParams=InsertRowMutationUndoFactory(accessor,insertRowParams);if(!await sheetInterceptorService.beforeCommandExecute({id:InsertRowCommand.id,params:insertRowParams}))return!1;const redos=[{id:InsertRowMutation.id,params:insertRowParams}],undos=[{id:RemoveRowMutation.id,params:undoRowInsertionParams}];cellValue&&redos.push({id:SetRangeValuesMutation.id,params:{unitId,subUnitId,cellValue}});const intercepted=sheetInterceptorService.onCommandExecute({id:InsertRowCommand.id,params});return redos.unshift(...(_a21=intercepted.preRedos)!=null?_a21:[]),redos.push(...(_b=intercepted.redos)!=null?_b:[]),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.unshift(...(_c=intercepted.preUndos)!=null?_c:[]),undos.push(...(_d=intercepted.undos)!=null?_d:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},InsertRowBeforeCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-row-before",handler:__name(async accessor=>{var _a21;const selections=(_a21=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a21.map(s=>s.range);let range;if((selections==null?void 0:selections.length)===1)range=selections[0];else return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,subUnitId,unitId}=target,{startRow,endRow}=range,startColumn=0,endColumn=worksheet.getColumnCount()-1,insertRowParams={unitId,subUnitId,direction:core.Direction.UP,range:{startRow,endRow,startColumn,endColumn},cellValue:copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!0,startRow-1)};return accessor.get(core.ICommandService).executeCommand(InsertRowCommand.id,insertRowParams)},"handler")},InsertRowAfterCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-row-after",handler:__name(async accessor=>{var _a21;const selections=(_a21=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a21.map(s=>s.range);let range;if((selections==null?void 0:selections.length)===1)range=selections[0];else return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,count=range.endRow-range.startRow+1,startRow=range.endRow+1,endRow=range.endRow+count,startColumn=0,endColumn=worksheet.getColumnCount()-1,insertRowParams={unitId,subUnitId,direction:core.Direction.DOWN,range:{startRow,endRow,startColumn,endColumn,rangeType:core.RANGE_TYPE.ROW},cellValue:copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!0,range.endRow)};return accessor.get(core.ICommandService).executeCommand(InsertRowCommand.id,insertRowParams)},"handler")},InsertColCommandId="sheet.command.insert-col",InsertColCommand={type:core.CommandType.COMMAND,id:InsertColCommandId,handler:__name(async(accessor,params)=>{var _a21,_b,_c,_d;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),{range,direction,subUnitId,unitId,cellValue}=params,{startColumn,endColumn}=params.range;range.rangeType=core.RANGE_TYPE.COLUMN;const workbook=univerInstanceService.getUniverSheetInstance(params.unitId),worksheet=workbook.getSheetBySheetId(params.subUnitId),anchorCol=direction===core.Direction.LEFT?startColumn:startColumn-1,width=worksheet.getColumnWidth(anchorCol),insertColParams={unitId,subUnitId,range,colInfo:new Array(endColumn-startColumn+1).fill(void 0).map(()=>({w:width,hd:core.BooleanNumber.FALSE}))},undoColInsertionParams=InsertColMutationUndoFactory(accessor,insertColParams);if(!await sheetInterceptorService.beforeCommandExecute({id:InsertColCommand.id,params:insertColParams}))return!1;const redos=[{id:InsertColMutation.id,params:insertColParams}],undos=[{id:RemoveColMutation.id,params:undoColInsertionParams}];cellValue&&redos.push({id:SetRangeValuesMutation.id,params:{unitId,subUnitId,cellValue}});const intercepted=sheetInterceptorService.onCommandExecute({id:InsertColCommand.id,params});return redos.unshift(...(_a21=intercepted.preRedos)!=null?_a21:[]),redos.push(...(_b=intercepted.redos)!=null?_b:[]),redos.push(followSelectionOperation(range,workbook,worksheet)),undos.unshift(...(_c=intercepted.preUndos)!=null?_c:[]),undos.push(...(_d=intercepted.undos)!=null?_d:[]),core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:undos.filter(Boolean),redoMutations:redos.filter(Boolean)}),!0):!1},"handler")},InsertColBeforeCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-col-before",handler:__name(async accessor=>{const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections();let range;if((selections==null?void 0:selections.length)===1)range=selections[0].range;else return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,{startColumn,endColumn}=range,startRow=0,endRow=worksheet.getRowCount()-1,insertColParams={unitId,subUnitId,direction:core.Direction.LEFT,range:{startColumn,endColumn,startRow,endRow,rangeType:core.RANGE_TYPE.COLUMN},cellValue:copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!1,startColumn-1)};return accessor.get(core.ICommandService).executeCommand(InsertColCommand.id,insertColParams)},"handler")},InsertColAfterCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-col-after",handler:__name(async accessor=>{const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections();let range;if((selections==null?void 0:selections.length)===1)range=selections[0].range;else return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,count=range.endColumn-range.startColumn+1,startColumn=range.endColumn+1,endColumn=range.endColumn+count,startRow=0,endRow=worksheet.getRowCount()-1,insertColParams={unitId,subUnitId,direction:core.Direction.RIGHT,range:{startColumn,endColumn,startRow,endRow},cellValue:copyRangeStyles(worksheet,startRow,endRow,startColumn,endColumn,!1,range.endColumn)};return accessor.get(core.ICommandService).executeCommand(InsertColCommand.id,insertColParams)},"handler")},InsertSheetCommand={id:"sheet.command.insert-sheet",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a21;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),localeService=accessor.get(core.LocaleService),target=getSheetCommandTargetWorkbook(univerInstanceService,{unitId:params==null?void 0:params.unitId});if(!target)return!1;const{unitId,workbook}=target;let index=workbook.getSheets().length;const sheet=params==null?void 0:params.sheet,sheetId=sheet==null?void 0:sheet.id,sheetConfig=core.mergeWorksheetSnapshotWithDefault(sheet||{});params?(index=(_a21=params.index)!=null?_a21:index,sheetConfig.id=sheetId||core.Tools.generateRandomId(),sheetConfig.name=(sheet==null?void 0:sheet.name)||workbook.generateNewSheetName(`${localeService.t("sheets.tabs.sheet")}`)):(sheetConfig.id=core.Tools.generateRandomId(),sheetConfig.name=workbook.generateNewSheetName(`${localeService.t("sheets.tabs.sheet")}`));const insertSheetMutationParams={index,sheet:sheetConfig,unitId},removeSheetMutationParams=InsertSheetUndoMutationFactory(accessor,insertSheetMutationParams);return commandService.syncExecuteCommand(InsertSheetMutation.id,insertSheetMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:RemoveSheetMutation.id,params:removeSheetMutationParams}],redoMutations:[{id:InsertSheetMutation.id,params:insertSheetMutationParams}]}),!0):!1},"handler")};function MoveRowsMutationUndoFactory(_accessor,params){const{unitId,subUnitId,sourceRange,targetRange}=params,movingBackward=sourceRange.startRow>targetRange.startRow,count=sourceRange.endRow-sourceRange.startRow+1;return movingBackward?{unitId,subUnitId,sourceRange:core.Rectangle.clone(targetRange),targetRange:{...sourceRange,endRow:sourceRange.endRow+count,startRow:sourceRange.startRow+count}}:{unitId,subUnitId,targetRange:core.Rectangle.clone(sourceRange),sourceRange:{...targetRange,endRow:targetRange.endRow-count,startRow:targetRange.startRow-count}}}__name(MoveRowsMutationUndoFactory,"MoveRowsMutationUndoFactory");const MoveRowsMutation={id:"sheet.mutation.move-rows",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,sourceRange,targetRange}=params,univerSheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(!univerSheet)throw new Error("[MoveRowMutation] univerSheet is null!");const worksheet=univerSheet.getSheetBySheetId(subUnitId);if(!worksheet)throw new Error("[MoveRowMutation] worksheet is null!");const fromRow=sourceRange.startRow,count=sourceRange.endRow-sourceRange.startRow+1,toRow=targetRange.startRow,rowWrapper=worksheet.getRowManager().getRowData();return core.moveMatrixArray(fromRow,count,toRow,rowWrapper),worksheet.getCellMatrix().moveRows(fromRow,count,toRow),!0},"handler")};function MoveColsMutationUndoFactory(_accessor,params){const{unitId,subUnitId,sourceRange,targetRange}=params,movingBackward=sourceRange.startColumn>targetRange.startColumn,count=sourceRange.endColumn-sourceRange.startColumn+1;return movingBackward?{unitId,subUnitId,sourceRange:core.Rectangle.clone(targetRange),targetRange:{...sourceRange,endColumn:sourceRange.endColumn+count,startColumn:sourceRange.startColumn+count}}:{unitId,subUnitId,targetRange:core.Rectangle.clone(sourceRange),sourceRange:{...targetRange,startColumn:targetRange.startColumn-count,endColumn:targetRange.endColumn-count}}}__name(MoveColsMutationUndoFactory,"MoveColsMutationUndoFactory");const MoveColsMutation={id:"sheet.mutation.move-columns",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,sourceRange,targetRange}=params,univerSheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId);if(!univerSheet)throw new Error("[MoveColumnMutation] univerSheet is null!");const worksheet=univerSheet.getSheetBySheetId(subUnitId);if(!worksheet)throw new Error("[MoveColumnMutation] worksheet is null!");const fromCol=sourceRange.startColumn,count=sourceRange.endColumn-sourceRange.startColumn+1,toCol=targetRange.startColumn,columnWrapper=worksheet.getColumnManager().getColumnData();return core.moveMatrixArray(fromCol,count,toCol,columnWrapper),worksheet.getCellMatrix().moveColumns(fromCol,count,toCol),!0},"handler")};function rowAcrossMergedCell(row,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startRow<row&&row<=mergedCell.endRow)}__name(rowAcrossMergedCell,"rowAcrossMergedCell");function columnAcrossMergedCell(col,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startColumn<col&&col<=mergedCell.endColumn)}__name(columnAcrossMergedCell,"columnAcrossMergedCell");const MoveRowsCommandId="sheet.command.move-rows",MoveRowsCommand={id:MoveRowsCommandId,type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a21,_b;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),{fromRange:{startRow:fromRow},toRange:{startRow:toRow},range}=params,selections=range?[covertRangeToSelection(range)]:selectionManagerService.getCurrentSelections(),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?void 0:filteredSelections.length)!==1)return!1;const sheetInterceptorService=accessor.get(exports.SheetInterceptorService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{workbook,worksheet}=target,unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),rangeToMove=filteredSelections[0].range,beforePrimary=filteredSelections[0].primary,alignedRange=alignToMergedCellsBorders(rangeToMove,worksheet,!1);if(!core.Rectangle.equals(rangeToMove,alignedRange))return errorService.emit(localeService.t("sheets.info.partOfCell")),!1;if(rowAcrossMergedCell(toRow,worksheet))return errorService.emit(localeService.t("sheets.info.acrossMergedCell")),!1;const destinationRange={...rangeToMove,startRow:toRow,endRow:toRow+rangeToMove.endRow-rangeToMove.startRow},moveRowsParams={unitId,subUnitId,sourceRange:rangeToMove,targetRange:destinationRange},undoMoveRowsParams=MoveRowsMutationUndoFactory(accessor,moveRowsParams),commandService=accessor.get(core.ICommandService),interceptorCommands=sheetInterceptorService.onCommandExecute({id:MoveRowsCommand.id,params}),redos=[...(_a21=interceptorCommands.preRedos)!=null?_a21:[],{id:MoveRowsMutation.id,params:moveRowsParams}],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],{id:MoveRowsMutation.id,params:undoMoveRowsParams}];if(beforePrimary){const moveBackward=toRow-fromRow<0,count=rangeToMove.endRow-rangeToMove.startRow+1,destSelection=moveBackward?destinationRange:{...destinationRange,startRow:destinationRange.startRow-count,endRow:destinationRange.endRow-count},setSelectionsParam={unitId,subUnitId,selections:[{range:destSelection,primary:getPrimaryForRange(destSelection,worksheet),style:null}]},undoSetSelectionsParam={unitId,subUnitId,selections:[{range:rangeToMove,primary:beforePrimary,style:null}]};redos.push({id:SetSelectionsOperation.id,params:setSelectionsParam}),undos.push({id:SetSelectionsOperation.id,params:undoSetSelectionsParam})}return redos.push(...interceptorCommands.redos),undos.push(...interceptorCommands.undos),core.sequenceExecute(redos,commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},MoveColsCommandId="sheet.command.move-cols",MoveColsCommand={id:MoveColsCommandId,type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a21,_b;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),{fromRange:{startColumn:fromCol},toRange:{startColumn:toCol},range}=params,selections=range?[covertRangeToSelection(range)]:selectionManagerService.getCurrentSelections(),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?void 0:filteredSelections.length)!==1)return!1;const sheetInterceptorService=accessor.get(exports.SheetInterceptorService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{workbook,worksheet}=target,unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),rangeToMove=filteredSelections[0].range,beforePrimary=filteredSelections[0].primary,alignedRange=alignToMergedCellsBorders(rangeToMove,worksheet,!1);if(!core.Rectangle.equals(rangeToMove,alignedRange))return errorService.emit(localeService.t("sheets.info.partOfCell")),!1;if(columnAcrossMergedCell(toCol,worksheet))return errorService.emit(localeService.t("sheets.info.acrossMergedCell")),!1;const destinationRange={...rangeToMove,startColumn:toCol,endColumn:toCol+rangeToMove.endColumn-rangeToMove.startColumn},moveColsParams={unitId,subUnitId,sourceRange:rangeToMove,targetRange:destinationRange},undoMoveColsParams=MoveColsMutationUndoFactory(accessor,moveColsParams),commandService=accessor.get(core.ICommandService),interceptorCommands=sheetInterceptorService.onCommandExecute({id:MoveColsCommand.id,params}),redos=[...(_a21=interceptorCommands.preRedos)!=null?_a21:[],{id:MoveColsMutation.id,params:moveColsParams}],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],{id:MoveColsMutation.id,params:undoMoveColsParams}];if(beforePrimary){const count=rangeToMove.endColumn-rangeToMove.startColumn+1,destSelection=toCol-fromCol<0?destinationRange:{...destinationRange,startColumn:destinationRange.startColumn-count,endColumn:destinationRange.endColumn-count},setSelectionsParam={unitId,subUnitId,selections:[{range:destSelection,primary:getPrimaryForRange(destSelection,worksheet),style:null}]},undoSetSelectionsParam={unitId,subUnitId,selections:[{range:rangeToMove,primary:beforePrimary,style:null}]};redos.push({id:SetSelectionsOperation.id,params:setSelectionsParam}),undos.push({id:SetSelectionsOperation.id,params:undoSetSelectionsParam})}return redos.push(...interceptorCommands.redos),undos.push(...interceptorCommands.undos),core.sequenceExecute(redos,commandService).result&&accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0},"handler")};function covertRangeToSelection(range){return{range,primary:null,style:null}}__name(covertRangeToSelection,"covertRangeToSelection");const RemoveRowCommandId="sheet.command.remove-row",RemoveRowCommand={type:core.CommandType.COMMAND,id:RemoveRowCommandId,handler:__name(async(accessor,params)=>{var _a21,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);let totalRange=params==null?void 0:params.range;if(totalRange||(totalRange=(_a21=selectionManagerService.getCurrentLastSelection())==null?void 0:_a21.range),!totalRange)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,subUnitId,unitId}=target;totalRange={...totalRange,startColumn:0,endColumn:Math.max(worksheet.getMaxColumns()-1,0)};const filterOutRowsInRemove=[];for(let i=totalRange.startRow;i<=totalRange.endRow;i++)worksheet.getRowFiltered(i)&&filterOutRowsInRemove.push(i);const ranges=[];if(filterOutRowsInRemove.length){const starts=[totalRange.startRow,...filterOutRowsInRemove.map(r=>r+1)],ends=[...filterOutRowsInRemove.map(r=>r-1),totalRange.endRow];for(let i=starts.length-1;i>=0;i--)starts[i]<=ends[i]&&ranges.push({startRow:starts[i],endRow:ends[i],startColumn:totalRange.startColumn,endColumn:totalRange.endColumn})}else ranges.push(totalRange);if(!await sheetInterceptorService.beforeCommandExecute({id:RemoveRowCommand.id,params:{range:totalRange,ranges}}))return!1;const redos=[],undos=[];ranges.forEach(range=>{const removeRowsParams={unitId,subUnitId,range},removedRows=worksheet.getCellMatrix().getSlice(range.startRow,range.endRow,0,worksheet.getColumnCount()-1),undoSetRangeValuesParams={unitId,subUnitId,cellValue:removedRows.getMatrix()},undoRemoveRowsParams=RemoveRowsUndoMutationFactory(removeRowsParams,worksheet);redos.push({id:RemoveRowMutation.id,params:removeRowsParams}),undos.unshift({id:InsertRowMutation.id,params:undoRemoveRowsParams},{id:SetRangeValuesMutation.id,params:undoSetRangeValuesParams})});const intercepted=sheetInterceptorService.onCommandExecute({id:RemoveRowCommand.id,params:{range:totalRange,ranges}}),commandService=accessor.get(core.ICommandService);return core.sequenceExecute([...(_b=intercepted.preRedos)!=null?_b:[],...redos,...intercepted.redos,followSelectionOperation(totalRange,workbook,worksheet)],commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preUndos)!=null?_c:[],...undos,...intercepted.undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],...redos,...intercepted.redos]}),!0):!1},"handler")},RemoveColCommandId="sheet.command.remove-col",RemoveColCommand={type:core.CommandType.COMMAND,id:RemoveColCommandId,handler:__name(async(accessor,params)=>{var _a21,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);let range=params==null?void 0:params.range;if(range||(range=(_a21=selectionManagerService.getCurrentLastSelection())==null?void 0:_a21.range),!range)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,subUnitId,unitId}=target;range={...range,startRow:0,endRow:Math.max(worksheet.getMaxRows()-1,0)};const removeColParams={unitId,subUnitId,range},undoRemoveColParams=RemoveColMutationFactory(accessor,removeColParams),removedCols=worksheet.getCellMatrix().getSlice(0,worksheet.getRowCount()-1,range.startColumn,range.endColumn),undoSetRangeValuesParams={unitId,subUnitId,cellValue:removedCols.getMatrix()};if(!await sheetInterceptorService.beforeCommandExecute({id:RemoveColCommand.id,params:{range}}))return!1;const intercepted=sheetInterceptorService.onCommandExecute({id:RemoveColCommand.id,params:{range}}),commandService=accessor.get(core.ICommandService);return core.sequenceExecute([...(_b=intercepted.preRedos)!=null?_b:[],{id:RemoveColMutation.id,params:removeColParams},...intercepted.redos,followSelectionOperation(range,workbook,worksheet)],commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preUndos)!=null?_c:[],{id:InsertColMutation.id,params:undoRemoveColParams},{id:SetRangeValuesMutation.id,params:undoSetRangeValuesParams},...intercepted.undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:RemoveColMutation.id,params:removeColParams},...intercepted.redos]}),!0):!1},"handler")},RemoveSheetCommand={id:"sheet.command.remove-sheet",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a21,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{unitId,subUnitId,workbook,worksheet}=target;if(workbook.getSheets().length<=1)return!1;const RemoveSheetMutationParams={subUnitId,unitId,subUnitName:worksheet.getName()},InsertSheetMutationParams=RemoveSheetUndoMutationFactory(accessor,RemoveSheetMutationParams),intercepted=sheetInterceptorService.onCommandExecute({id:RemoveSheetCommand.id,params:{unitId,subUnitId}}),redos=[...(_a21=intercepted.preRedos)!=null?_a21:[],{id:RemoveSheetMutation.id,params:RemoveSheetMutationParams},...intercepted.redos],undos=[...(_b=intercepted.preUndos)!=null?_b:[],{id:InsertSheetMutation.id,params:InsertSheetMutationParams},...intercepted.undos];return core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},AddMergeUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:core.Tools.deepClone(params.ranges)}},"AddMergeUndoMutationFactory"),AddWorksheetMergeMutation={id:"sheet.mutation.add-worksheet-merge",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const mergeConfigData=worksheet.getConfig().mergeData,mergeAppendData=params.ranges;for(let i=0;i<mergeAppendData.length;i++)mergeConfigData.push(mergeAppendData[i]);return worksheet.getSpanModel().rebuild(mergeConfigData),!0},"handler")},RemoveMergeUndoMutationFactory=__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const mergeConfigData=worksheet.getConfig().mergeData,mergeRemoveData=params.ranges,ranges=[];for(let j=0;j<mergeRemoveData.length;j++)for(let i=mergeConfigData.length-1;i>=0;i--){const configMerge=mergeConfigData[i],removeMerge=mergeRemoveData[j];core.Rectangle.intersects(configMerge,removeMerge)&&ranges.push(mergeConfigData[i])}return{unitId:params.unitId,subUnitId:params.subUnitId,ranges}},"RemoveMergeUndoMutationFactory"),RemoveWorksheetMergeMutation={id:"sheet.mutation.remove-worksheet-merge",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const mergeConfigData=worksheet.getConfig().mergeData,mergeRemoveData=params.ranges;for(let j=0;j<mergeRemoveData.length;j++)for(let i=mergeConfigData.length-1;i>=0;i--){const configMerge=mergeConfigData[i],removeMerge=mergeRemoveData[j];core.Rectangle.intersects(configMerge,removeMerge)&&mergeConfigData.splice(i,1)}return worksheet.getSpanModel().rebuild(mergeConfigData),!0},"handler")},RemoveWorksheetMergeCommand={type:core.CommandType.COMMAND,id:"sheet.command.remove-worksheet-merge",handler:__name(async(accessor,params)=>{var _a21;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selections=(params==null?void 0:params.ranges)||((_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range));if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{subUnitId,unitId,worksheet}=target,removeMergeMutationParams={unitId,subUnitId,ranges:selections},intersectsMerges=worksheet.getConfig().mergeData.filter(merge=>selections.some(selection=>core.Rectangle.intersects(selection,merge)));if(!intersectsMerges.length)return!1;const undoredoMutationParams=RemoveMergeUndoMutationFactory(accessor,removeMergeMutationParams),nowSelections=selectionManagerService.getCurrentSelections();if(!(nowSelections!=null&&nowSelections.length))return!1;const undoSelections=core.Tools.deepClone(nowSelections),redoSelections=core.Tools.deepClone(nowSelections),redoLastSelection=redoSelections[redoSelections.length-1],{startRow,startColumn}=redoLastSelection.range;redoLastSelection.primary={startRow,startColumn,endRow:startRow,endColumn:startColumn,actualRow:startRow,actualColumn:startColumn,isMerged:!1,isMergedMainCell:!1};const getSetRangeValuesParams=getSetRangeStyleParamsForRemoveMerge(worksheet,intersectsMerges),redoSetRangeValueParams={unitId,subUnitId,cellValue:getSetRangeValuesParams.redoParams.getMatrix()},undoSetRangeValueParams={unitId,subUnitId,cellValue:getSetRangeValuesParams.undoParams.getMatrix()},redoMutations=[{id:RemoveWorksheetMergeMutation.id,params:undoredoMutationParams},{id:SetRangeValuesMutation.id,params:redoSetRangeValueParams},{id:SetSelectionsOperation.id,params:{selections:redoSelections}}],undoMutations=[{id:AddWorksheetMergeMutation.id,params:undoredoMutationParams},{id:SetRangeValuesMutation.id,params:undoSetRangeValueParams},{id:SetSelectionsOperation.id,params:{selections:undoSelections}}];return core.sequenceExecute(redoMutations,commandService)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations,redoMutations}),!0):!1},"handler")};function getSetRangeStyleParamsForRemoveMerge(worksheet,ranges){const styleRedoMatrix=new core.ObjectMatrix,styleUndoMatrix=new core.ObjectMatrix;return ranges.forEach(range=>{const{startRow,startColumn,endColumn,endRow}=range,cellValue=worksheet.getCellMatrix().getValue(startRow,startColumn);if(cellValue!=null&&cellValue.s)for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)(i!==startRow||j!==startColumn)&&(styleRedoMatrix.setValue(i,j,{s:cellValue.s}),styleUndoMatrix.setValue(i,j,null))}),{redoParams:styleRedoMatrix,undoParams:styleUndoMatrix}}__name(getSetRangeStyleParamsForRemoveMerge,"getSetRangeStyleParamsForRemoveMerge");const _BorderStyleManagerService=class _BorderStyleManagerService{constructor(){__publicField(this,"_borderInfo",{type:core.BorderType.ALL,color:"#000000",style:core.BorderStyleTypes.THIN,activeBorderType:!1});__publicField(this,"_borderInfo$",new rxjs.BehaviorSubject(this._borderInfo));__publicField(this,"borderInfo$",this._borderInfo$.asObservable())}dispose(){this._borderInfo$.complete()}setType(type){this._borderInfo.type=type,this.setActiveBorderType(!0),this.refresh()}setColor(color){this._borderInfo.color=color,this.refresh()}setStyle(style){this._borderInfo.style=style,this.refresh()}setActiveBorderType(status){this._borderInfo.activeBorderType=status}getBorderInfo(){return this._borderInfo}refresh(){this._borderInfo$.next(this._borderInfo)}};__name(_BorderStyleManagerService,"BorderStyleManagerService");let BorderStyleManagerService=_BorderStyleManagerService;function forEach(range,action){const{startRow,startColumn,endRow,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)action(i,j)}__name(forEach,"forEach");const setBorderStyleForRange=__name((borderContext,range,defaultStyle,reserve)=>{const{mr,worksheet}=borderContext;range.startRow<0||range.startColumn<0||forEach(range,(row,column)=>{var _a21,_b;const rectangle=worksheet.getMergedCell(row,column);let bdStyle=defaultStyle;if(rectangle&&(defaultStyle.bc_tr||defaultStyle.ml_tr||defaultStyle.bl_tr||defaultStyle.tl_mr||defaultStyle.tl_bc||defaultStyle.tl_br)){if(reserve){const style=core.Tools.deepClone((_a21=mr.getValue(rectangle.startRow,rectangle.startColumn))==null?void 0:_a21.s);bdStyle=style!=null&&style.bd?Object.assign(style.bd,defaultStyle):defaultStyle}mr.setValue(rectangle.startRow,rectangle.startColumn,{s:{bd:bdStyle}})}else{if(reserve){const style=core.Tools.deepClone((_b=mr.getValue(row,column))==null?void 0:_b.s);bdStyle=style!=null&&style.bd?Object.assign(style.bd,defaultStyle):defaultStyle}mr.setValue(row,column,{s:{bd:bdStyle}})}})},"setBorderStyleForRange"),prepareEdgeRange=__name(range=>{const topRangeOut={startRow:range.startRow-1,startColumn:range.startColumn,endRow:range.startRow-1,endColumn:range.endColumn},leftRangeOut={startRow:range.startRow,startColumn:range.startColumn-1,endRow:range.endRow,endColumn:range.startColumn-1},bottomRangeOut={startRow:range.endRow+1,startColumn:range.startColumn,endRow:range.endRow+1,endColumn:range.endColumn},rightRangeOut={startRow:range.startRow,startColumn:range.endColumn+1,endRow:range.endRow,endColumn:range.endColumn+1},topRange={startRow:range.startRow,startColumn:range.startColumn,endRow:range.startRow,endColumn:range.endColumn},leftRange={startRow:range.startRow,startColumn:range.startColumn,endRow:range.endRow,endColumn:range.startColumn},bottomRange={startRow:range.endRow,startColumn:range.startColumn,endRow:range.endRow,endColumn:range.endColumn},rightRange={startRow:range.startRow,startColumn:range.endColumn,endRow:range.endRow,endColumn:range.endColumn};return{topRangeOut,leftRangeOut,bottomRangeOut,rightRangeOut,topRange,leftRange,bottomRange,rightRange}},"prepareEdgeRange");function getBorderContext(borderStyleManagerService,target,selections){const{style,color,type}=borderStyleManagerService.getBorderInfo(),top=type===core.BorderType.TOP||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,left=type===core.BorderType.LEFT||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,bottom=type===core.BorderType.BOTTOM||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,right=type===core.BorderType.RIGHT||type===core.BorderType.ALL||type===core.BorderType.OUTSIDE,vertical=type===core.BorderType.VERTICAL||type===core.BorderType.ALL||type===core.BorderType.INSIDE,horizontal=type===core.BorderType.HORIZONTAL||type===core.BorderType.ALL||type===core.BorderType.INSIDE,tl_br=type.indexOf("tlbr")>-1,tl_bc=type.indexOf("tlbc")>-1,tl_mr=type.indexOf("tlmr")>-1,bl_tr=type.indexOf("bltr")>-1,ml_tr=type.indexOf("mltr")>-1,bc_tr=type.indexOf("bctr")>-1,range=selections[0],{topRangeOut,leftRangeOut,bottomRangeOut,rightRangeOut,topRange,leftRange,bottomRange,rightRange}=prepareEdgeRange(range),mr=new core.ObjectMatrix,{worksheet,unitId,subUnitId}=target;return{worksheet,unitId,subUnitId,style,color,type,top,left,right,bottom,vertical,horizontal,tl_br,tl_bc,tl_mr,bl_tr,ml_tr,bc_tr,topRangeOut,leftRangeOut,bottomRangeOut,rightRangeOut,topRange,leftRange,bottomRange,rightRange,range,mr,borderStyle:{s:style,cl:{rgb:color}}}}__name(getBorderContext,"getBorderContext");const innerBorder=__name(borderContext=>{const{range,mr,borderStyle,vertical,horizontal,worksheet}=borderContext;vertical&&forEach(range,(row,column)=>{var _a21,_b,_c;const mergedRange=worksheet.getMergedCell(row,column);if(mergedRange){const topLeftStyle=(_a21=mr.getValue(mergedRange.startRow,mergedRange.startColumn))==null?void 0:_a21.s;mergedRange.startColumn!==range.startColumn&&mr.setValue(row,column,{s:{bd:topLeftStyle!=null&&topLeftStyle.bd?Object.assign(topLeftStyle.bd,{l:core.Tools.deepClone(borderStyle)}):{l:core.Tools.deepClone(borderStyle)}}})}else{if(column!==range.endColumn){const style=(_b=mr.getValue(row,column))==null?void 0:_b.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{r:core.Tools.deepClone(borderStyle)}):{r:core.Tools.deepClone(borderStyle)}}})}if(column!==range.startColumn){const style=(_c=mr.getValue(row,column))==null?void 0:_c.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{l:core.Tools.deepClone(borderStyle)}):{l:core.Tools.deepClone(borderStyle)}}})}}}),horizontal&&forEach(range,(row,column)=>{var _a21,_b,_c;const mergedRange=worksheet.getMergedCell(row,column);if(mergedRange){const topLeftStyle=(_a21=mr.getValue(mergedRange.startRow,mergedRange.startColumn))==null?void 0:_a21.s;mergedRange.startRow!==range.startRow&&mr.setValue(row,column,{s:{bd:topLeftStyle!=null&&topLeftStyle.bd?Object.assign(topLeftStyle.bd,{t:core.Tools.deepClone(borderStyle)}):{t:core.Tools.deepClone(borderStyle)}}})}else{if(row!==range.endRow){const style=(_b=mr.getValue(row,column))==null?void 0:_b.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{b:core.Tools.deepClone(borderStyle)}):{b:core.Tools.deepClone(borderStyle)}}})}if(row!==range.startRow){const style=(_c=mr.getValue(row,column))==null?void 0:_c.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{t:core.Tools.deepClone(borderStyle)}):{t:core.Tools.deepClone(borderStyle)}}})}}})},"innerBorder");function otherBorders(borderContext){const{borderStyle,tl_br,tl_bc,tl_mr,bl_tr,ml_tr,bc_tr}=borderContext,setBorderStyle=__name((range,defaultStyle,reserve)=>{setBorderStyleForRange(borderContext,range,defaultStyle,reserve)},"setBorderStyle");tl_br&&setBorderStyle(borderContext.range,{tl_br:core.Tools.deepClone(borderStyle)},!0),tl_bc&&setBorderStyle(borderContext.range,{tl_bc:core.Tools.deepClone(borderStyle)},!0),tl_mr&&setBorderStyle(borderContext.range,{tl_mr:core.Tools.deepClone(borderStyle)},!0),bl_tr&&setBorderStyle(borderContext.range,{bl_tr:core.Tools.deepClone(borderStyle)},!0),ml_tr&&setBorderStyle(borderContext.range,{ml_tr:core.Tools.deepClone(borderStyle)},!0),bc_tr&&setBorderStyle(borderContext.range,{bc_tr:core.Tools.deepClone(borderStyle)},!0)}__name(otherBorders,"otherBorders");const outlineBorder=__name(borderContext=>{const{top,left,right,bottom,borderStyle,bottomRange,topRange,leftRange,rightRange,bottomRangeOut,topRangeOut,leftRangeOut,rightRangeOut}=borderContext,setBorderStyle=__name((range,defaultStyle,reserve)=>{setBorderStyleForRange(borderContext,range,defaultStyle,reserve)},"setBorderStyle");top&&(setBorderStyle(topRangeOut,{b:null}),setBorderStyle(topRange,{t:core.Tools.deepClone(borderStyle)},!0)),bottom&&(setBorderStyle(bottomRangeOut,{t:null}),setBorderStyle(bottomRange,{b:core.Tools.deepClone(borderStyle)},!0)),left&&(setBorderStyle(leftRangeOut,{r:null}),setBorderStyle(leftRange,{l:core.Tools.deepClone(borderStyle)},!0)),right&&(setBorderStyle(rightRangeOut,{l:null}),setBorderStyle(rightRange,{r:core.Tools.deepClone(borderStyle)},!0))},"outlineBorder"),clearBorder=__name(borderContext=>{const{range,worksheet,mr,top,bottom,left,right,vertical,horizontal,tl_br,tl_bc,tl_mr,bl_tr,ml_tr,bc_tr,topRange,bottomRange,leftRange,rightRange,topRangeOut,bottomRangeOut,leftRangeOut,rightRangeOut}=borderContext,setBorderStyle=__name((range2,defaultStyle,reserve)=>{setBorderStyleForRange(borderContext,range2,defaultStyle,reserve)},"setBorderStyle");!top&&!bottom&&!left&&!right&&!vertical&&!horizontal&&!tl_br&&!tl_bc&&!tl_mr&&!bl_tr&&!ml_tr&&!bc_tr&&(forEach(range,(row,column)=>{var _a21,_b,_c,_d,_e,_f,_g,_h;const mergedRange=worksheet.getMergedCell(row,column);if(mergedRange){if(mergedRange.endColumn!==range.endColumn){const style=(_a21=mr.getValue(mergedRange.startRow,mergedRange.startColumn))==null?void 0:_a21.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{r:null}):{r:null}}})}if(mergedRange.startColumn!==range.startColumn){const style=(_b=mr.getValue(mergedRange.startRow,mergedRange.startColumn))==null?void 0:_b.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{l:null}):{l:null}}})}if(mergedRange.endRow!==range.endRow){const style=(_c=mr.getValue(mergedRange.startRow,mergedRange.startColumn))==null?void 0:_c.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{b:null}):{b:null}}})}if(mergedRange.startRow!==range.startRow){const style=(_d=mr.getValue(mergedRange.startRow,mergedRange.startColumn))==null?void 0:_d.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{t:null}):{t:null}}})}}else{if(column!==range.endColumn){const style=(_e=mr.getValue(row,column))==null?void 0:_e.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{r:null}):{r:null}}})}if(column!==range.startColumn){const style=(_f=mr.getValue(row,column))==null?void 0:_f.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{l:null}):{l:null}}})}if(row!==range.endRow){const style=(_g=mr.getValue(row,column))==null?void 0:_g.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{b:null}):{b:null}}})}if(row!==range.startRow){const style=(_h=mr.getValue(row,column))==null?void 0:_h.s;mr.setValue(row,column,{s:{bd:style!=null&&style.bd?Object.assign(style.bd,{t:null}):{t:null}}})}}}),setBorderStyle(topRangeOut,{b:null}),setBorderStyle(topRange,{t:null},!0),setBorderStyle(bottomRangeOut,{t:null}),setBorderStyle(bottomRange,{b:null},!0),setBorderStyle(leftRangeOut,{r:null}),setBorderStyle(leftRange,{l:null},!0),setBorderStyle(rightRangeOut,{l:null}),setBorderStyle(rightRange,{r:null},!0),setBorderStyle(range,{tl_br:null},!0),setBorderStyle(range,{tl_bc:null},!0),setBorderStyle(range,{tl_mr:null},!0),setBorderStyle(range,{bl_tr:null},!0),setBorderStyle(range,{ml_tr:null},!0),setBorderStyle(range,{bc_tr:null},!0))},"clearBorder"),SetBorderCommand={id:"sheet.command.set-border",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a21;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),borderStyleManagerService=accessor.get(BorderStyleManagerService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const selections=(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const{activeBorderType}=borderStyleManagerService.getBorderInfo();if(!activeBorderType)return!1;const borderContext=getBorderContext(borderStyleManagerService,target,selections);innerBorder(borderContext),outlineBorder(borderContext),otherBorders(borderContext),clearBorder(borderContext);const{unitId,subUnitId,mr}=borderContext,setRangeValuesMutationParams={unitId,subUnitId,cellValue:mr.getData()},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams);return commandService.syncExecuteCommand(SetRangeValuesMutation.id,setRangeValuesMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams}],redoMutations:[{id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams}]}),!0):!1},"handler")},SetBorderPositionCommand={id:"sheet.command.set-border-position",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params.value)return!1;const commandService=accessor.get(core.ICommandService);return accessor.get(BorderStyleManagerService).setType(params.value),commandService.executeCommand(SetBorderCommand.id)},"handler")},SetBorderStyleCommand={id:"sheet.command.set-border-style",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(BorderStyleManagerService).setStyle(params.value),commandService.executeCommand(SetBorderCommand.id)},"handler")},SetBorderColorCommand={id:"sheet.command.set-border-color",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(BorderStyleManagerService).setColor(params.value),commandService.executeCommand(SetBorderCommand.id)},"handler")},SetBorderBasicCommand={id:"sheet.command.set-border-basic",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const{unitId,subUnitId,value}=params,{type,color,style}=value,commandService=accessor.get(core.ICommandService),borderManager=accessor.get(BorderStyleManagerService);return borderManager.setType(type),color&&borderManager.setColor(color),borderManager.setStyle(style),commandService.executeCommand(SetBorderCommand.id,{unitId,subUnitId})},"handler")},SetColHiddenUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetColHiddenUndoMutationFactory"),SetColHiddenMutation={id:"sheet.mutation.set-col-hidden",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!universheet)return!1;const manager=universheet.getSheetBySheetId(params.subUnitId).getColumnManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);column!=null&&(column.hd=core.BooleanNumber.TRUE)}}return!0},"handler")},SetColVisibleUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetColVisibleUndoMutationFactory"),SetColVisibleMutation={id:"sheet.mutation.set-col-visible",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!universheet)return!1;const manager=universheet.getSheetBySheetId(params.subUnitId).getColumnManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);column!=null&&(column.hd=core.BooleanNumber.FALSE)}}return!0},"handler")},SetSpecificColsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-col-visible-on-cols",handler:__name(async(accessor,params)=>{var _a21,_b;const{unitId,subUnitId,ranges}=params,sheetInterceptorService=accessor.get(exports.SheetInterceptorService),commandService=accessor.get(core.ICommandService),instanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(instanceService,{unitId,subUnitId});if(!target)return!1;const{worksheet}=target,redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(r=>({range:r,primary:getPrimaryForRange(r,worksheet),style:null}))},undoMutationParams=SetColVisibleUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding$1(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},result=core.sequenceExecute([{id:SetColVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetSpecificColsVisibleCommand.id,params}),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result&&accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[{id:SetColHiddenMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_a21=intercepted.undos)!=null?_a21:[]],redoMutations:[...(_b=intercepted.preRedos)!=null?_b:[],{id:SetColVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0},"handler")},SetSelectedColsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-selected-cols-visible",handler:__name(async accessor=>{var _a21;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),ranges=(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.COLUMN);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,unitId,subUnitId}=target,hiddenRanges=ranges.map(r=>worksheet.getHiddenCols(r.startColumn,r.endColumn)).flat();return commandService.executeCommand(SetSpecificColsVisibleCommand.id,{unitId,subUnitId,ranges:hiddenRanges})},"handler")},SetColHiddenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-col-hidden",handler:__name(async(accessor,params)=>{var _a21,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService);let ranges=(_a21=params==null?void 0:params.ranges)!=null&&_a21.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.COLUMN);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{worksheet,unitId,subUnitId}=target;ranges=divideRangesByHiddenCols(target.worksheet,ranges);const redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding$1(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},undoMutationParams=SetColHiddenUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},result=core.sequenceExecute([{id:SetColHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetColHiddenCommand.id,params:redoMutationParams}),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:[{id:SetColVisibleMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_c=intercepted.undos)!=null?_c:[]],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:SetColHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0):!1},"handler")};function divideRangesByHiddenCols(worksheet,ranges){const endRow=worksheet.getRowCount()-1,hiddenCols=worksheet.getHiddenCols(),divided=[];return ranges.forEach(range=>{const hiddenColsInSelection=hiddenCols.filter(c=>c.startColumn>=range.startColumn&&c.endColumn<=range.endColumn);if(hiddenColsInSelection.length){let startColumn=range.startColumn;hiddenColsInSelection.forEach(hiddenRange=>{hiddenRange.startColumn>startColumn&&(divided.push({startColumn,endColumn:hiddenRange.startColumn-1,startRow:0,endRow}),startColumn=hiddenRange.endColumn+1)}),startColumn<=range.endColumn&÷d.push({startColumn,endColumn:range.endColumn,startRow:0,endRow})}else divided.push(range)}),divided}__name(divideRangesByHiddenCols,"divideRangesByHiddenCols");function getSelectionsAfterHiding$1(ranges){return mergeSelections$1(ranges).map(range=>{const column=range.startColumn===0?range.endColumn+1:range.startColumn-1;return{...range,startColumn:column,endColumn:column}})}__name(getSelectionsAfterHiding$1,"getSelectionsAfterHiding$1");function mergeSelections$1(ranges){const merged=[];let current;return ranges.sort((a,b)=>a.startColumn-b.startColumn).forEach(range=>{if(!current){current=range;return}current.endColumn===range.startColumn-1?current.endColumn=range.endColumn:(merged.push(current),current=range)}),merged.push(current),merged}__name(mergeSelections$1,"mergeSelections$1");const SetFrozenMutationFactory=__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(worksheet==null)throw new Error("worksheet is null error!");const freeze=worksheet.getConfig().freeze;return{unitId:params.unitId,subUnitId:params.subUnitId,...freeze}},"SetFrozenMutationFactory"),SetFrozenMutation={id:"sheet.mutation.set-frozen",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const worksheet=universheet.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const config=worksheet.getConfig(),{startRow,startColumn,ySplit,xSplit}=params;return config.freeze={startRow,startColumn,ySplit,xSplit},!0},"handler")},SetFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-frozen",handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,{unitId:params.unitId,subUnitId:params.subUnitId});if(!target)return!1;const{unitId,subUnitId,worksheet}=target,{startColumn,startRow,xSplit,ySplit}=params;if(startRow>=worksheet.getRowCount()||startColumn>=worksheet.getColumnCount()||xSplit>=worksheet.getColumnCount()||ySplit>=worksheet.getRowCount())return!1;const redoMutationParams={unitId,subUnitId,...params},undoMutationParams=SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(SetFrozenMutation.id,redoMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:SetFrozenMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},SetFrozenCancelCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-frozen-cancel",handler:__name(accessor=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target,redoMutationParams={unitId,subUnitId,startRow:-1,startColumn:-1,ySplit:0,xSplit:0},undoMutationParams=SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(SetFrozenMutation.id,redoMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:SetFrozenMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},SetRowVisibleUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetRowVisibleUndoMutationFactory"),SetRowVisibleMutation={id:"sheet.mutation.set-row-visible",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const manager=universheet.getSheetBySheetId(params.subUnitId).getRowManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startRow;j<range.endRow+1;j++){const row=manager.getRowOrCreate(j);row!=null&&(row.hd=0)}}return!0},"handler")},SetRowHiddenUndoMutationFactory=__name((accessor,params)=>{if(accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId)==null)throw new Error("universheet is null error!");return{unitId:params.unitId,subUnitId:params.subUnitId,ranges:params.ranges}},"SetRowHiddenUndoMutationFactory"),SetRowHiddenMutation={id:"sheet.mutation.set-row-hidden",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)throw new Error("universheet is null error!");const manager=universheet.getSheetBySheetId(params.subUnitId).getRowManager();for(let i=0;i<params.ranges.length;i++){const range=params.ranges[i];for(let j=range.startRow;j<range.endRow+1;j++){const row=manager.getRowOrCreate(j);row!=null&&(row.hd=1)}}return!0},"handler")},SetSpecificRowsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-specific-rows-visible",handler:__name(async(accessor,params)=>{var _a21,_b,_c;const{unitId,subUnitId,ranges}=params,commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),{unitId,subUnitId});if(!target)return!1;const{worksheet}=target,redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},undoMutationParams=SetRowVisibleUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},result=core.sequenceExecute([{id:SetRowVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetSpecificRowsVisibleCommand.id,params}),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_a21=intercepted.preUndos)!=null?_a21:[],{id:SetRowHiddenMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_b=intercepted.undos)!=null?_b:[]],redoMutations:[...(_c=intercepted.preRedos)!=null?_c:[],{id:SetRowVisibleMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0},"handler")},SetSelectedRowsVisibleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-selected-rows-visible",handler:__name(async accessor=>{var _a21;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),ranges=(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.ROW);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,unitId,subUnitId}=target,hiddenRanges=ranges.map(r=>worksheet.getHiddenRows(r.startRow,r.endRow)).flat();return commandService.executeCommand(SetSpecificRowsVisibleCommand.id,{unitId,subUnitId,ranges:hiddenRanges})},"handler")},SetRowHiddenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-rows-hidden",handler:__name(async(accessor,params)=>{var _a21,_b,_c,_d,_e,_f;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);let ranges=(_a21=params==null?void 0:params.ranges)!=null&&_a21.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range).filter(r=>r.rangeType===core.RANGE_TYPE.ROW);if(!(ranges!=null&&ranges.length))return!1;const target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;ranges=divideRangesByHiddenRows(target.worksheet,ranges);const{unitId,subUnitId,worksheet}=target,redoMutationParams={unitId,subUnitId,ranges},setSelectionOperationParams={unitId,subUnitId,selections:getSelectionsAfterHiding(ranges).map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},undoMutationParams=SetRowHiddenUndoMutationFactory(accessor,redoMutationParams),undoSetSelectionsOperationParams={unitId,subUnitId,reveal:!0,selections:ranges.map(range=>({range,primary:getPrimaryForRange(range,worksheet),style:null}))},intercepted=sheetInterceptorService.onCommandExecute({id:SetRowHiddenCommand.id,params:redoMutationParams});return core.sequenceExecute([...(_c=intercepted.preRedos)!=null?_c:[],{id:SetRowHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos],commandService).result&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_d=intercepted.preUndos)!=null?_d:[],{id:SetRowVisibleMutation.id,params:undoMutationParams},{id:SetSelectionsOperation.id,params:undoSetSelectionsOperationParams},...(_e=intercepted.undos)!=null?_e:[]],redoMutations:[...(_f=intercepted.preRedos)!=null?_f:[],{id:SetRowHiddenMutation.id,params:redoMutationParams},{id:SetSelectionsOperation.id,params:setSelectionOperationParams},...intercepted.redos]}),!0},"handler")};function divideRangesByHiddenRows(worksheet,ranges){const endCol=worksheet.getMaxColumns()-1,hiddenRows=worksheet.getHiddenRows(),divided=[];return ranges.forEach(range=>{const hiddenRowsInThisRange=hiddenRows.filter(r=>r.startRow>=range.startRow&&r.endRow<=range.endRow);if(hiddenRowsInThisRange.length){let startRow=range.startRow;hiddenRowsInThisRange.forEach(hiddenRange=>{hiddenRange.startRow>startRow&&(divided.push({startRow,endRow:hiddenRange.startRow-1,startColumn:0,endColumn:endCol}),startRow=hiddenRange.endRow+1)}),startRow<=range.endRow&÷d.push({startRow,endRow:range.endRow,startColumn:0,endColumn:endCol})}else divided.push(range)}),divided}__name(divideRangesByHiddenRows,"divideRangesByHiddenRows");function getSelectionsAfterHiding(ranges){return mergeSelections(ranges).map(range=>{const row=range.startRow===0?range.endRow+1:range.startRow-1;return{...range,startRow:row,endRow:row}})}__name(getSelectionsAfterHiding,"getSelectionsAfterHiding");function mergeSelections(ranges){const merged=[];let current;return ranges.sort((a,b)=>a.startRow-b.startRow).forEach(range=>{if(!current){current=range;return}range.startRow===current.endRow+1?current.endRow=range.endRow:(merged.push(current),current=range)}),merged.push(current),merged}__name(mergeSelections,"mergeSelections");const SetStyleCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-style",handler:__name(async(accessor,params)=>{var _a21;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,{range,style}=params,commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),ranges=range?[range]:(_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const cellValue=new core.ObjectMatrix,iterator=createRangeIteratorWithSkipFilteredRows(worksheet);if(core.Tools.isArray(style.value))for(let i=0;i<ranges.length;i++)iterator.forOperableEach(ranges[i],(r,c,range2)=>{cellValue.setValue(r,c,{s:{[style.type]:style.value[r-range2.startRow][c-range2.startColumn]}})});else for(let i=0;i<ranges.length;i++){const styleObj={s:{[style.type]:style.value}};iterator.forOperableEach(ranges[i],(r,c)=>cellValue.setValue(r,c,styleObj))}const setRangeValuesMutationParams={subUnitId,unitId,cellValue:cellValue.getMatrix()},undoSetRangeValuesMutationParams=SetRangeValuesUndoMutationFactory(accessor,setRangeValuesMutationParams),setRangeValuesResult=commandService.syncExecuteCommand(SetRangeValuesMutation.id,setRangeValuesMutationParams),{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetStyleCommand.id,params}),result=core.sequenceExecute([...redos],commandService);return setRangeValuesResult&&result.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams},...undos],redoMutations:[{id:SetRangeValuesMutation.id,params:setRangeValuesMutationParams},...redos]}),!0):!1},"handler")},SetBoldCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-bold",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target,{actualRow,actualColumn}=selection.primary,setStyleParams={style:{type:"bl",value:worksheet.getRange(actualRow,actualColumn).getFontWeight()===core.FontWeight.BOLD?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetItalicCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-italic",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyItalic=!0;if(selection.primary){const{startRow,startColumn}=selection.primary;currentlyItalic=worksheet.getRange(startRow,startColumn).getFontStyle()===core.FontItalic.ITALIC}const setStyleParams={style:{type:"it",value:currentlyItalic?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetUnderlineCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-underline",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyUnderline=!0;selection.primary&&(currentlyUnderline=!!worksheet.getRange(selection.primary.startRow,selection.primary.startColumn).getUnderline().s);const setStyleParams={style:{type:"ul",value:{s:currentlyUnderline?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetStrikeThroughCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-stroke",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyStrokeThrough=!0;selection.primary&&(currentlyStrokeThrough=!!worksheet.getRange(selection.primary.actualRow,selection.primary.actualColumn).getStrikeThrough().s);const setStyleParams={style:{type:"st",value:{s:currentlyStrokeThrough?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetOverlineCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-overline",handler:__name(async accessor=>{const selection=accessor.get(exports.SheetsSelectionsService).getCurrentLastSelection();if(!selection)return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet}=target;let currentlyOverline=!0;selection.primary&&(currentlyOverline=!!worksheet.getRange(selection.primary.startRow,selection.primary.startColumn).getOverline().s);const setStyleParams={style:{type:"ol",value:{s:currentlyOverline?core.BooleanNumber.FALSE:core.BooleanNumber.TRUE}}};return accessor.get(core.ICommandService).executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetFontFamilyCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-font-family",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"ff",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetFontSizeCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-font-size",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"fs",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTextColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-text-color",handler:__name(async(accessor,params)=>{if(!params||!params.value)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"cl",value:{rgb:params.value}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},ResetTextColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.reset-text-color",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"cl",value:{rgb:null}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetBackgroundColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-background-color",handler:__name(async(accessor,params)=>{if(!params||!params.value)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"bg",value:{rgb:params.value}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},ResetBackgroundColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.reset-background-color",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"bg",value:{rgb:null}}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetVerticalTextAlignCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-vertical-text-align",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,style:{type:"vt",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetHorizontalTextAlignCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-horizontal-text-align",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,style:{type:"ht",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTextWrapCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-text-wrap",handler:__name(async(accessor,params)=>{if(!params)return!1;const commandService=accessor.get(core.ICommandService),setStyleParams={unitId:params.unitId,subUnitId:params.subUnitId,range:params.range,style:{type:"tb",value:params.value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTextRotationCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-text-rotation",handler:__name(async(accessor,params)=>{if(!params)return!1;const value=typeof params.value=="number"?{a:params.value}:{a:0,v:core.BooleanNumber.TRUE},commandService=accessor.get(core.ICommandService),setStyleParams={style:{type:"tr",value}};return commandService.executeCommand(SetStyleCommand.id,setStyleParams)},"handler")},SetTabColorUndoMutationFactory=__name((accessor,params)=>{const oldTabColor=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId).getSheetBySheetId(params.subUnitId).getConfig().tabColor;return{...core.Tools.deepClone(params),color:oldTabColor}},"SetTabColorUndoMutationFactory"),SetTabColorMutation={id:"sheet.mutation.set-tab-color",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(params.subUnitId);return worksheet?(worksheet.getConfig().tabColor=params.color,!0):!1},"handler")},SetTabColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-tab-color",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{unitId,subUnitId}=target,setTabColorMutationParams={color:params.value,unitId,subUnitId},undoMutationParams=SetTabColorUndoMutationFactory(accessor,setTabColorMutationParams);return commandService.syncExecuteCommand(SetTabColorMutation.id,setTabColorMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetTabColorMutation.id,params:undoMutationParams}],redoMutations:[{id:SetTabColorMutation.id,params:setTabColorMutationParams}]}),!0):!1},"handler")},SetWorksheetActiveOperation={id:"sheet.operation.set-worksheet-active",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheets=workbook.getWorksheets();for(const[,worksheet]of worksheets)if(worksheet.getSheetId()===params.subUnitId)return workbook.setActiveSheet(worksheet),!0;return!1},"handler")},SET_WORKSHEET_ACTIVE_DELAY=4,SetWorksheetActivateCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-activate",handler:__name((accessor,params,options)=>{const commandService=accessor.get(core.ICommandService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{unitId,subUnitId}=target;return new Promise(resolve=>{setTimeout(()=>{const result=commandService.syncExecuteCommand(SetWorksheetActiveOperation.id,{unitId,subUnitId},options);resolve(result)},SET_WORKSHEET_ACTIVE_DELAY)})},"handler")},SetWorksheetColWidthMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,ranges}=params,colWidth={},manager=worksheet.getColumnManager();for(let i=0;i<ranges.length;i++){const range=ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);colWidth[j]=column.w}}return{unitId,subUnitId,ranges,colWidth}},"SetWorksheetColWidthMutationFactory"),SetWorksheetColWidthMutation={id:"sheet.mutation.set-worksheet-col-width",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a21;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{worksheet}=target,defaultColumnWidth=worksheet.getConfig().defaultColumnWidth,manager=worksheet.getColumnManager(),ranges=params.ranges;for(let i=0;i<ranges.length;i++){const range=ranges[i];for(let j=range.startColumn;j<range.endColumn+1;j++){const column=manager.getColumnOrCreate(j);typeof params.colWidth=="number"?column.w=params.colWidth:column.w=(_a21=params.colWidth[j])!=null?_a21:defaultColumnWidth}}return!0},"handler")},DeltaColumnWidthCommand={type:core.CommandType.COMMAND,id:"sheet.command.delta-column-width",handler:__name(async(accessor,params)=>{const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections();if(!(selections!=null&&selections.length))return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,unitId,subUnitId}=target,{anchorCol,deltaX}=params,destColumnWidth=worksheet.getColumnWidth(anchorCol)+deltaX,isAllSheetRange=selections.length===1&&selections[0].range.rangeType===core.RANGE_TYPE.ALL,colSelections=selections.filter(s=>s.range.rangeType===core.RANGE_TYPE.COLUMN),rangeType=isAllSheetRange?core.RANGE_TYPE.ALL:colSelections.some(({range})=>{const{startColumn,endColumn}=range;return startColumn<=anchorCol&&anchorCol<=endColumn})?core.RANGE_TYPE.COLUMN:core.RANGE_TYPE.NORMAL;let redoMutationParams;if(rangeType===core.RANGE_TYPE.ALL){const rowCount=worksheet.getRowCount(),allColRanges=new Array(worksheet.getColumnCount()).fill(void 0).map((_,index)=>({startRow:0,endRow:rowCount-1,startColumn:index,endColumn:index}));redoMutationParams={subUnitId,unitId,colWidth:destColumnWidth,ranges:allColRanges}}else rangeType===core.RANGE_TYPE.COLUMN?redoMutationParams={subUnitId,unitId,ranges:colSelections.map(s=>core.Rectangle.clone(s.range)),colWidth:destColumnWidth}:redoMutationParams={subUnitId,unitId,colWidth:destColumnWidth,ranges:[{startRow:0,endRow:worksheet.getMaxRows()-1,startColumn:anchorCol,endColumn:anchorCol}]};const{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:DeltaColumnWidthCommand.id,params:redoMutationParams}),undoMutationParams=SetWorksheetColWidthMutationFactory(redoMutationParams,worksheet),setColWidthResult=commandService.syncExecuteCommand(SetWorksheetColWidthMutation.id,redoMutationParams),result=core.sequenceExecute([...redos],commandService);return setColWidthResult&&result.result&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetColWidthMutation.id,params:undoMutationParams},...undos],redoMutations:[{id:SetWorksheetColWidthMutation.id,params:redoMutationParams},...redos]}),!0},"handler")},SetColWidthCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-col-width",handler:__name(async(accessor,params)=>{var _a21,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),selections=(_a21=params==null?void 0:params.ranges)!=null&&_a21.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{subUnitId,unitId,worksheet}=target,redoMutationParams={subUnitId,unitId,ranges:selections,colWidth:params.value},undoMutationParams=SetWorksheetColWidthMutationFactory(redoMutationParams,worksheet),setColWidthResult=commandService.syncExecuteCommand(SetWorksheetColWidthMutation.id,redoMutationParams),{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetColWidthCommand.id,params:redoMutationParams}),intercepted=sheetInterceptorService.onCommandExecute({id:SetColWidthCommand.id,params:redoMutationParams}),result=core.sequenceExecute([...redos,...intercepted.redos],commandService);return setColWidthResult&&result.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preUndos)!=null?_c:[],{id:SetWorksheetColWidthMutation.id,params:undoMutationParams},...undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:SetWorksheetColWidthMutation.id,params:redoMutationParams},...redos]}),!0):!1},"handler")},SetWorksheetHideMutationFactory=__name((accessor,params)=>{const target=getSheetMutationTarget(accessor.get(core.IUniverInstanceService),params);if(!target)throw new Error("[SetWorksheetHideMutationFactory]: worksheet is null error!");const{worksheet}=target;return{hidden:worksheet.isSheetHidden(),unitId:params.unitId,subUnitId:worksheet.getSheetId()}},"SetWorksheetHideMutationFactory"),SetWorksheetHideMutation={id:"sheet.mutation.set-worksheet-hidden",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)return!1;const worksheet=universheet.getSheetBySheetId(params.subUnitId);return worksheet?(worksheet.getConfig().hidden=params.hidden,!0):!1},"handler")},SetWorksheetHideCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-hidden",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),errorService=accessor.get(core.ErrorService),localeService=accessor.get(core.LocaleService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{workbook,worksheet,unitId,subUnitId}=target;if(worksheet.getConfig().hidden===core.BooleanNumber.TRUE)return!1;const redoMutationParams={unitId,subUnitId,hidden:core.BooleanNumber.TRUE},undoMutationParams=SetWorksheetHideMutationFactory(accessor,redoMutationParams);return workbook.getSheets().filter(sheet=>sheet.getConfig().hidden===core.BooleanNumber.FALSE).length===1?(errorService.emit(localeService.t("sheets.info.hideSheet")),!1):commandService.syncExecuteCommand(SetWorksheetHideMutation.id,redoMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetHideMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetHideMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},SetWorksheetNameMutationFactory=__name((accessor,params)=>{const target=getSheetMutationTarget(accessor.get(core.IUniverInstanceService),params);if(!target)throw new Error("[SetWorksheetNameMutationFactory]: worksheet is null error!");const{worksheet}=target;return{unitId:params.unitId,name:worksheet.getName(),subUnitId:worksheet.getSheetId()}},"SetWorksheetNameMutationFactory"),SetWorksheetNameMutation={id:"sheet.mutation.set-worksheet-name",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const universheet=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(universheet==null)return!1;const worksheet=universheet.getSheetBySheetId(params.subUnitId);return worksheet?(worksheet.getConfig().name=params.name,!0):!1},"handler")},SetWorksheetNameCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-name",handler:__name(async(accessor,params)=>{var _a21,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{unitId,subUnitId}=target,redoMutationParams={subUnitId,name:params.name,unitId},undoMutationParams=SetWorksheetNameMutationFactory(accessor,redoMutationParams),interceptorCommands=sheetInterceptorService.onCommandExecute({id:SetWorksheetNameCommand.id,params}),redos=[...(_a21=interceptorCommands.preRedos)!=null?_a21:[],{id:SetWorksheetNameMutation.id,params:redoMutationParams},...interceptorCommands.redos],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],{id:SetWorksheetNameMutation.id,params:undoMutationParams},...interceptorCommands.undos];return await core.sequenceExecute(redos,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},SetWorksheetOrderUndoMutationFactory=__name((accessor,params)=>({...core.Tools.deepClone(params),toOrder:params.fromOrder,fromOrder:params.toOrder}),"SetWorksheetOrderUndoMutationFactory"),SetWorksheetOrderMutation={id:"sheet.mutation.set-worksheet-order",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const config=workbook.getConfig();return config.sheetOrder.splice(params.fromOrder,1),config.sheetOrder.splice(params.toOrder,0,params.subUnitId),!0},"handler")},SetWorksheetOrderCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-order",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{workbook,unitId,subUnitId}=target,setWorksheetOrderMutationParams={fromOrder:workbook.getConfig().sheetOrder.indexOf(subUnitId),toOrder:params.order,unitId,subUnitId},undoMutationParams=SetWorksheetOrderUndoMutationFactory(accessor,setWorksheetOrderMutationParams);return commandService.syncExecuteCommand(SetWorksheetOrderMutation.id,setWorksheetOrderMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetOrderMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetOrderMutation.id,params:setWorksheetOrderMutationParams}]}),!0):!1},"handler")},MAXIMUM_ROW_HEIGHT=2e3,SetWorksheetRowHeightMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,ranges}=params,rowHeight={},manager=worksheet.getRowManager();for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<endRow+1;rowIndex++){const row=manager.getRowOrCreate(rowIndex);rowHeight[rowIndex]=row.h}return{unitId,subUnitId,ranges,rowHeight}},"SetWorksheetRowHeightMutationFactory"),SetWorksheetRowIsAutoHeightMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,ranges}=params,autoHeightHash={},manager=worksheet.getRowManager();for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<=endRow;rowIndex++){const row=manager.getRowOrCreate(rowIndex);autoHeightHash[rowIndex]=row.ia}return{unitId,subUnitId,ranges,autoHeightInfo:autoHeightHash}},"SetWorksheetRowIsAutoHeightMutationFactory"),SetWorksheetRowAutoHeightMutationFactory=__name((params,worksheet)=>{const{unitId,subUnitId,rowsAutoHeightInfo}=params,results=[],manager=worksheet.getRowManager();for(const rowInfo of rowsAutoHeightInfo){const{row}=rowInfo,{ah}=manager.getRowOrCreate(row);results.push({row,autoHeight:ah})}return{unitId,subUnitId,rowsAutoHeightInfo:results}},"SetWorksheetRowAutoHeightMutationFactory"),SetWorksheetRowHeightMutation={id:"sheet.mutation.set-worksheet-row-height",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a21;const{ranges,rowHeight}=params,univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{worksheet}=target,manager=worksheet.getRowManager(),defaultRowHeight=worksheet.getConfig().defaultRowHeight;for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<=endRow;rowIndex++){const row=manager.getRowOrCreate(rowIndex);typeof rowHeight=="number"?row.h=rowHeight:row.h=(_a21=rowHeight[rowIndex])!=null?_a21:defaultRowHeight,row.h=Math.min(MAXIMUM_ROW_HEIGHT,row.h)}return!0},"handler")},SetWorksheetRowIsAutoHeightMutation={id:"sheet.mutation.set-worksheet-row-is-auto-height",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{var _a21;const{ranges,autoHeightInfo}=params,univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const manager=target.worksheet.getRowManager();for(const{startRow,endRow}of ranges)for(let rowIndex=startRow;rowIndex<=endRow;rowIndex++){const row=manager.getRowOrCreate(rowIndex);typeof autoHeightInfo=="number"?row.ia=autoHeightInfo:row.ia=(_a21=autoHeightInfo[rowIndex])!=null?_a21:void 0}return!0},"handler")},SetWorksheetRowAutoHeightMutation={id:"sheet.mutation.set-worksheet-row-auto-height",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{rowsAutoHeightInfo}=params,univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const rowManager=target.worksheet.getRowManager();for(const{row,autoHeight}of rowsAutoHeightInfo){const curRow=rowManager.getRowOrCreate(row);curRow.ah=autoHeight}return!0},"handler")},DeltaRowHeightCommand={type:core.CommandType.COMMAND,id:"sheet.command.delta-row-height",handler:__name(async(accessor,params)=>{var _a21,_b;const selections=accessor.get(exports.SheetsSelectionsService).getCurrentSelections(),sheetInterceptorService=accessor.get(exports.SheetInterceptorService);if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,subUnitId,unitId}=target,{anchorRow,deltaY}=params,destRowHeight=worksheet.getRowHeight(anchorRow)+deltaY,isAllSheetRange=selections.length===1&&selections[0].range.rangeType===core.RANGE_TYPE.ALL,rowSelections=selections.filter(s=>s.range.rangeType===core.RANGE_TYPE.ROW),rangeType=isAllSheetRange?core.RANGE_TYPE.ALL:rowSelections.some(({range})=>{const{startRow,endRow}=range;return startRow<=anchorRow&&anchorRow<=endRow})?core.RANGE_TYPE.ROW:core.RANGE_TYPE.NORMAL;let redoMutationParams;if(rangeType===core.RANGE_TYPE.ALL){const colCount=worksheet.getRowCount(),allRowRanges=new Array(worksheet.getColumnCount()).fill(void 0).map((_,index)=>({startRow:index,endRow:index,startColumn:0,endColumn:colCount-1}));redoMutationParams={subUnitId,unitId,rowHeight:destRowHeight,ranges:allRowRanges}}else rangeType===core.RANGE_TYPE.ROW?redoMutationParams={subUnitId,unitId,ranges:rowSelections.map(s=>core.Rectangle.clone(s.range)),rowHeight:destRowHeight}:redoMutationParams={subUnitId,unitId,rowHeight:destRowHeight,ranges:[{startRow:anchorRow,endRow:anchorRow,startColumn:0,endColumn:worksheet.getMaxColumns()-1}]};const undoMutationParams=SetWorksheetRowHeightMutationFactory(redoMutationParams,worksheet),redoSetIsAutoHeightParams={unitId,subUnitId,ranges:redoMutationParams.ranges,autoHeightInfo:core.BooleanNumber.FALSE},undoSetIsAutoHeightParams=SetWorksheetRowIsAutoHeightMutationFactory(redoSetIsAutoHeightParams,worksheet),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),intercepted=sheetInterceptorService.onCommandExecute({id:DeltaRowHeightCommand.id,params:redoMutationParams}),result=core.sequenceExecute([{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams}],commandService),interceptedResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&interceptedResult.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_a21=intercepted.preUndos)!=null?_a21:[],{id:SetWorksheetRowHeightMutation.id,params:undoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:undoSetIsAutoHeightParams},...intercepted.undos],redoMutations:[...(_b=intercepted.preRedos)!=null?_b:[],{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams},...intercepted.redos]}),!0):!1},"handler")},SetRowHeightCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-row-height",handler:__name((accessor,params)=>{var _a21,_b,_c,_d;const selectionManagerService=accessor.get(exports.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(exports.SheetInterceptorService),selections=(_a21=params==null?void 0:params.ranges)!=null&&_a21.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,redoMutationParams={subUnitId,unitId,ranges:selections,rowHeight:params.value},undoMutationParams=SetWorksheetRowHeightMutationFactory(redoMutationParams,worksheet),redoSetIsAutoHeightParams={unitId,subUnitId,ranges:redoMutationParams.ranges,autoHeightInfo:core.BooleanNumber.FALSE},undoSetIsAutoHeightParams=SetWorksheetRowIsAutoHeightMutationFactory(redoSetIsAutoHeightParams,worksheet),result=core.sequenceExecute([{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams}],commandService),intercepted=sheetInterceptorService.onCommandExecute({id:SetRowHeightCommand.id,params:redoMutationParams}),sheetInterceptorResult=core.sequenceExecute([...intercepted.redos],commandService);return result.result&&sheetInterceptorResult.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[...(_c=intercepted.preRedos)!=null?_c:[],{id:SetWorksheetRowHeightMutation.id,params:undoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:undoSetIsAutoHeightParams},...intercepted.undos],redoMutations:[...(_d=intercepted.preRedos)!=null?_d:[],{id:SetWorksheetRowHeightMutation.id,params:redoMutationParams},{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoSetIsAutoHeightParams},...intercepted.redos]}),!0):!1},"handler")},SetWorksheetRowIsAutoHeightCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-row-is-auto-height",handler:__name(async(accessor,params)=>{var _a21,_b;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),selectionManagerService=accessor.get(exports.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,params);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,ranges=(_a21=params==null?void 0:params.ranges)!=null&&_a21.length?params.ranges:(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const redoMutationParams={unitId,subUnitId,ranges,autoHeightInfo:core.BooleanNumber.TRUE},undoMutationParams=SetWorksheetRowIsAutoHeightMutationFactory(redoMutationParams,worksheet),setIsAutoHeightResult=commandService.syncExecuteCommand(SetWorksheetRowIsAutoHeightMutation.id,redoMutationParams),{undos,redos}=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetWorksheetRowIsAutoHeightCommand.id,params:redoMutationParams}),result=core.sequenceExecute([...redos],commandService);return setIsAutoHeightResult&&result.result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetRowIsAutoHeightMutation.id,params:undoMutationParams},...undos],redoMutations:[{id:SetWorksheetRowIsAutoHeightMutation.id,params:redoMutationParams},...redos]}),!0):!1},"handler")},SetWorksheetShowCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-show",handler:__name(async(accessor,params)=>{const{unitId,subUnitId}=params,commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService);if(!getSheetCommandTarget(accessor.get(core.IUniverInstanceService)))return!1;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet||worksheet.getConfig().hidden===core.BooleanNumber.FALSE)return!1;const redoMutationParams={unitId,subUnitId,hidden:core.BooleanNumber.FALSE},undoMutationParams=SetWorksheetHideMutationFactory(accessor,redoMutationParams),result=commandService.syncExecuteCommand(SetWorksheetHideMutation.id,redoMutationParams),activeSheetMutationParams={unitId,subUnitId},activeResult=commandService.syncExecuteCommand(SetWorksheetActiveOperation.id,activeSheetMutationParams);return result&&activeResult?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetHideMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetHideMutation.id,params:redoMutationParams}]}),!0):!1},"handler")},createTopMatrixFromRanges=__name(ranges=>{const matrix=new core.ObjectMatrix;return ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{matrix.setValue(row,col,1)})}),matrix.forValue((row,col)=>{const theLastRowValue=matrix.getValue(row-1,col);theLastRowValue&&matrix.setValue(row,col,theLastRowValue+1)}),matrix},"createTopMatrixFromRanges"),createTopMatrixFromMatrix=__name(matrix=>{const _matrix=matrix;return _matrix.forValue((row,col)=>{const theLastRowValue=matrix.getValue(row-1,col);theLastRowValue&&_matrix.setValue(row,col,theLastRowValue+1)}),_matrix},"createTopMatrixFromMatrix"),findMaximalRectangle=__name(topMatrix=>{const res={area:0},checkArea=__name((area,range)=>res.area<area?(res.area=area,res.range=range,!0):!1,"checkArea");return topMatrix.forValue((row,col,lineArea)=>{let cols=1,rows=lineArea;checkArea(cols*rows,{startRow:row-rows+1,endRow:row,startColumn:col,endColumn:col});const _range={startRow:row-rows+1,endRow:row,startColumn:0,endColumn:col};for(let k=col-1;k>=0&&topMatrix.getValue(row,k);k--){rows=Math.min(topMatrix.getValue(row,k)||0,rows),cols++;const area=rows*cols;_range.startColumn=k,_range.startRow=row-rows+1,checkArea(area,_range)}}),res},"findMaximalRectangle"),filterLeftMatrix=__name((topMatrix,range)=>{core.Range.foreach(range,(row,col)=>{topMatrix.realDeleteValue(row,col)});for(let col=range.startColumn;col<=range.endColumn;col++){const row=range.endRow+1;if(topMatrix.getValue(row,col)>0){topMatrix.setValue(row,col,1);let nextRow=row+1;for(;topMatrix.getValue(nextRow,col)>0;)topMatrix.setValue(nextRow,col,topMatrix.getValue(nextRow-1,col)+1),nextRow++}}return topMatrix},"filterLeftMatrix"),findAllRectangle=__name(topMatrix=>{const resultList=[];let result=findMaximalRectangle(topMatrix);for(;result.area>0;)result.range&&(resultList.push(result.range),filterLeftMatrix(topMatrix,result.range)),result=findMaximalRectangle(topMatrix);return resultList},"findAllRectangle"),rangeMerge=__name(ranges=>{const topMatrix=createTopMatrixFromRanges(ranges);return findAllRectangle(topMatrix)},"rangeMerge"),_RangeMergeUtil=class _RangeMergeUtil{constructor(){__publicField(this,"_matrix",new core.ObjectMatrix)}add(...ranges){return ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this._matrix.setValue(row,col,1)})}),this}subtract(...ranges){return ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this._matrix.realDeleteValue(row,col)})}),this}merge(){const topMatrix=createTopMatrixFromMatrix(this._matrix);return findAllRectangle(topMatrix)}};__name(_RangeMergeUtil,"RangeMergeUtil");let RangeMergeUtil=_RangeMergeUtil;const INumfmtService=core.createIdentifier("INumfmtService");core.runOnLifecycle(core.LifecycleStages.Ready,INumfmtService);const factorySetNumfmtUndoMutation=__name((accessor,option)=>{const numfmtService=accessor.get(INumfmtService),{values,unitId,subUnitId}=option,cells=[],removeCells=[];Object.keys(values).forEach(id=>{values[id].ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const oldNumfmt=numfmtService.getValue(unitId,subUnitId,row,col);oldNumfmt?cells.push({pattern:oldNumfmt.pattern,row,col}):removeCells.push({startColumn:col,endColumn:col,startRow:row,endRow:row})})})});const result=[];if(cells.length){const params=transformCellsToRange(unitId,subUnitId,cells);Object.keys(params.values).forEach(key=>{const v=params.values[key];v.ranges=rangeMerge(v.ranges)}),result.push({id:SetNumfmtMutation.id,params:transformCellsToRange(unitId,subUnitId,cells)})}return removeCells.length&&result.push({id:RemoveNumfmtMutation.id,params:{unitId,subUnitId,ranges:removeCells}}),result},"factorySetNumfmtUndoMutation"),SetNumfmtMutation={id:"sheet.mutation.set.numfmt",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{if(!params)return!1;const{values,refMap}=params,numfmtService=accessor.get(INumfmtService),unitId=params.unitId,sheetId=params.subUnitId,setValues=Object.keys(values).reduce((result,id)=>{const value=refMap[id],ranges=values[id].ranges;return value&&result.push({...value,ranges}),result},[]);return numfmtService.setValues(unitId,sheetId,setValues),!0},"handler")},RemoveNumfmtMutation={id:"sheet.mutation.remove.numfmt",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{if(!params)return!1;const{unitId,subUnitId,ranges}=params;return accessor.get(INumfmtService).deleteValues(unitId,subUnitId,ranges),!0},"handler")},factoryRemoveNumfmtUndoMutation=__name((accessor,option)=>{const numfmtService=accessor.get(INumfmtService),{ranges,unitId,subUnitId}=option,cells=[];if(ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const oldNumfmt=numfmtService.getValue(unitId,subUnitId,row,col);oldNumfmt&&cells.push({pattern:oldNumfmt.pattern,row,col})})}),!cells.length)return[];const params=transformCellsToRange(unitId,subUnitId,cells);return Object.keys(params.values).forEach(key=>{const v=params.values[key];v.ranges=rangeMerge(v.ranges)}),[{id:SetNumfmtMutation.id,params}]},"factoryRemoveNumfmtUndoMutation"),transformCellsToRange=__name((unitId,subUnitId,cells)=>{const group=groupByKey(cells,"pattern"),refMap={},values={},getKey=createUniqueKey();return Object.keys(group).forEach(pattern=>{const groupItem=group[pattern],key=getKey();refMap[key]={pattern},groupItem.forEach(item=>{values[key]||(values[key]={ranges:[]}),values[key].ranges.push(core.cellToRange(item.row,item.col))})}),{unitId,subUnitId,refMap,values}},"transformCellsToRange"),EmptyMutation={id:"sheet.mutation.empty",type:core.CommandType.MUTATION,handler:__name(()=>!0,"handler")},InsertDefinedNameCommand={id:"sheet.command.insert-defined-name",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService);if(!params)return!1;const insertSheetMutationParams={...params};return commandService.syncExecuteCommand(engineFormula.SetDefinedNameMutation.id,insertSheetMutationParams)?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:[{id:engineFormula.RemoveDefinedNameMutation.id,params:insertSheetMutationParams}],redoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:insertSheetMutationParams}]}),!0):!1},"handler")},RemoveDefinedNameCommand={id:"sheet.command.remove-defined-name",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService);if(!params)return!1;const removeSheetMutationParams={...params};return commandService.syncExecuteCommand(engineFormula.RemoveDefinedNameMutation.id,removeSheetMutationParams)?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:removeSheetMutationParams}],redoMutations:[{id:engineFormula.RemoveDefinedNameMutation.id,params:removeSheetMutationParams}]}),!0):!1},"handler")},SetDefinedNameCommand={id:"sheet.command.set-defined-name",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService);return params&&commandService.syncExecuteCommand(engineFormula.SetDefinedNameMutation.id,params.newDefinedName)?(undoRedoService.pushUndoRedo({unitID:params.unitId,undoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:params.oldDefinedName}],redoMutations:[{id:engineFormula.SetDefinedNameMutation.id,params:params.newDefinedName}]}),!0):!1},"handler")},ScrollToCellOperation={id:"sheet.operation.scroll-to-cell",type:core.CommandType.OPERATION,handler:__name(()=>!0,"handler")},SetWorkbookNameMutation={id:"sheet.mutation.set-workbook-name",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUnit(params.unitId,core.UniverInstanceType.UNIVER_SHEET);return workbook?(workbook.setName(params.name),!0):!1},"handler")},SetWorkbookNameCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-workbook-name",handler:__name(async(accessor,params)=>{var _a21;if(!accessor.get(core.IUniverInstanceService).getUnit(params.unitId,core.UniverInstanceType.UNIVER_SHEET))return!1;const interceptedCommands=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:SetWorkbookNameCommand.id,params}),redoMutationParams={name:params.name,unitId:params.unitId},redos=[...(_a21=interceptedCommands.preRedos)!=null?_a21:[],{id:SetWorkbookNameMutation.id,params:redoMutationParams},...interceptedCommands.redos],commandService=accessor.get(core.ICommandService);return core.sequenceExecute(redos,commandService).result},"handler")};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"),_a4;exports.WorksheetProtectionRuleModel=(_a4=class{constructor(){__publicField(this,"_model",new Map);__publicField(this,"_ruleChange",new rxjs.Subject);__publicField(this,"_ruleRefresh",new rxjs.Subject);__publicField(this,"_resetOrder",new rxjs.Subject);__publicField(this,"ruleChange$",this._ruleChange.asObservable());__publicField(this,"ruleRefresh$",this._ruleRefresh.asObservable());__publicField(this,"resetOrder$",this._resetOrder.asObservable());__publicField(this,"_worksheetRuleInitStateChange",new rxjs.BehaviorSubject(!1));__publicField(this,"worksheetRuleInitStateChange$",this._worksheetRuleInitStateChange.asObservable())}changeRuleInitState(state){this._worksheetRuleInitStateChange.next(state)}getSheetRuleInitState(){return this._worksheetRuleInitStateChange.value}addRule(unitId,rule){this._ensureSubUnitMap(unitId).set(rule.subUnitId,rule),this._ruleChange.next({unitId,rule,type:"add",subUnitId:rule.subUnitId})}deleteRule(unitId,subUnitId){var _a21,_b,_c;const rule=(_b=(_a21=this._model)==null?void 0:_a21.get(unitId))==null?void 0:_b.get(subUnitId);rule&&((_c=this._model.get(unitId))==null||_c.delete(subUnitId),this._ruleChange.next({unitId,rule,type:"delete",subUnitId}))}setRule(unitId,subUnitId,rule){var _a21,_b;const oldRule=this.getRule(unitId,subUnitId);oldRule&&((_b=(_a21=this._model)==null?void 0:_a21.get(unitId))==null||_b.set(subUnitId,rule),this._ruleChange.next({unitId,oldRule,rule,type:"set",subUnitId}))}getRule(unitId,subUnitId){var _a21,_b;return(_b=(_a21=this._model)==null?void 0:_a21.get(unitId))==null?void 0:_b.get(subUnitId)}toObject(){const result={};return[...this._model.keys()].forEach(unitId=>{const subUnitMap=this._model.get(unitId);subUnitMap!=null&&subUnitMap.size&&(result[unitId]=[],[...subUnitMap.keys()].forEach(subUnitId=>{const rule=subUnitMap.get(subUnitId);rule&&result[unitId].push(rule)}))}),result}fromObject(obj){const result=new Map;Object.keys(obj).forEach(unitId=>{const subUnitList=obj[unitId];if(subUnitList!=null&&subUnitList.length){const subUnitMap=new Map;subUnitList.forEach(rule=>{subUnitMap.set(rule.subUnitId,rule)}),result.set(unitId,subUnitMap)}}),this._model=result}deleteUnitModel(unitId){this._model.delete(unitId)}_ensureSubUnitMap(unitId){let subUnitMap=this._model.get(unitId);return subUnitMap||(subUnitMap=new Map,this._model.set(unitId,subUnitMap)),subUnitMap}ruleRefresh(permissionId){this._ruleRefresh.next(permissionId)}resetOrder(){this._resetOrder.next(Math.random())}getTargetByPermissionId(unitId,permissionId){const subUnitMap=this._model.get(unitId);if(!subUnitMap)return null;for(const[subUnitId,rule]of subUnitMap)if(rule.permissionId===permissionId)return[unitId,subUnitId]}},__name(_a4,"WorksheetProtectionRuleModel"),_a4);exports.WorksheetProtectionRuleModel=__decorateClass$g([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorksheetProtectionRuleModel)],exports.WorksheetProtectionRuleModel);const AddWorksheetProtectionMutation={id:"sheet.mutation.add-worksheet-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,rule}=params;return accessor.get(exports.WorksheetProtectionRuleModel).addRule(unitId,rule),!0},"handler")},SetWorksheetProtectionMutation={id:"sheet.mutation.set-worksheet-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,rule}=params;return accessor.get(exports.WorksheetProtectionRuleModel).setRule(unitId,subUnitId,rule),!0},"handler")},DeleteWorksheetProtectionMutation={id:"sheet.mutation.delete-worksheet-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId}=params;return accessor.get(exports.WorksheetProtectionRuleModel).deleteRule(unitId,subUnitId),!0},"handler")};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"),_a5;exports.RangeProtectionRuleModel=(_a5=class{constructor(){__publicField(this,"_model",new Map);__publicField(this,"_ruleChange",new rxjs.Subject);__publicField(this,"ruleChange$",this._ruleChange.asObservable());__publicField(this,"_ruleRefresh",new rxjs.Subject);__publicField(this,"ruleRefresh$",this._ruleRefresh.asObservable());__publicField(this,"_rangeRuleInitStateChange",new rxjs.BehaviorSubject(!1));__publicField(this,"rangeRuleInitStateChange$",this._rangeRuleInitStateChange.asObservable())}ruleRefresh(id){this._ruleRefresh.next(id)}getRangeRuleInitState(){return this._rangeRuleInitStateChange.value}changeRuleInitState(state){this._rangeRuleInitStateChange.next(state)}addRule(unitId,subUnitId,rule){this._ensureRuleMap(unitId,subUnitId).set(rule.id,rule),this._ruleChange.next({unitId,subUnitId,rule,type:"add"})}deleteRule(unitId,subUnitId,id){var _a21,_b,_c,_d;const rule=(_b=(_a21=this._model.get(unitId))==null?void 0:_a21.get(subUnitId))==null?void 0:_b.get(id);rule&&((_d=(_c=this._model.get(unitId))==null?void 0:_c.get(subUnitId))==null||_d.delete(id),this._ruleChange.next({unitId,subUnitId,rule,type:"delete"}))}setRule(unitId,subUnitId,id,rule){var _a21,_b;const oldRule=this.getRule(unitId,subUnitId,id);oldRule&&((_b=(_a21=this._model.get(unitId))==null?void 0:_a21.get(subUnitId))==null||_b.set(id,rule),this._ruleChange.next({unitId,subUnitId,oldRule,rule,type:"set"}))}getRule(unitId,subUnitId,id){var _a21,_b;return(_b=(_a21=this._model.get(unitId))==null?void 0:_a21.get(subUnitId))==null?void 0:_b.get(id)}getSubunitRuleList(unitId,subUnitId){var _a21;return[...(((_a21=this._model.get(unitId))==null?void 0:_a21.get(subUnitId))||new Map).values()]}getSubunitRuleListLength(unitId,subUnitId){var _a21;const map=(_a21=this._model.get(unitId))==null?void 0:_a21.get(subUnitId);return map?map.size:0}_ensureRuleMap(unitId,subUnitId){let subUnitMap=this._model.get(unitId);subUnitMap||(subUnitMap=new Map,this._model.set(unitId,subUnitMap));let ruleMap=subUnitMap.get(subUnitId);return ruleMap||(ruleMap=new Map,subUnitMap.set(subUnitId,ruleMap)),ruleMap}toObject(){const result={};return[...this._model.keys()].forEach(unitId=>{const submitMap=this._model.get(unitId),subUnitKeys=[...submitMap.keys()];result[unitId]={},subUnitKeys.forEach(subunitId=>{const ruleMap=submitMap.get(subunitId);result[unitId][subunitId]=[...ruleMap.values()]})}),result}fromObject(obj){const result=new Map;Object.keys(obj).forEach(unitId=>{const subUnitObj=obj[unitId],map=new Map;Object.keys(subUnitObj).forEach(subunitId=>{const ruleMap=subUnitObj[subunitId].reduce((result2,cur)=>(result2.set(cur.id,cur),result2),new Map);map.set(subunitId,ruleMap)}),result.set(unitId,map)}),this._model=result}deleteUnitModel(unitId){this._model.delete(unitId)}createRuleId(unitId,subUnitId){let id=core.Tools.generateRandomId(4);const ruleMap=this._ensureRuleMap(unitId,subUnitId);for(;ruleMap.has(id);)id=core.Tools.generateRandomId(4);return id}getTargetByPermissionId(unitId,permissionId){const subUnitMap=this._model.get(unitId);if(!subUnitMap)return null;for(const[subUnitId,ruleMap]of subUnitMap)for(const rule of ruleMap.values())if(rule.permissionId===permissionId)return[unitId,subUnitId];return null}},__name(_a5,"RangeProtectionRuleModel"),_a5);exports.RangeProtectionRuleModel=__decorateClass$f([core.OnLifecycle(core.LifecycleStages.Starting,exports.RangeProtectionRuleModel)],exports.RangeProtectionRuleModel);const getAllWorksheetPermissionPoint=__name(()=>[WorksheetEditPermission,WorksheetViewPermission],"getAllWorksheetPermissionPoint"),getAllWorksheetPermissionPointByPointPanel=__name(()=>[WorksheetCopyPermission,WorksheetDeleteColumnPermission,WorksheetDeleteRowPermission,WorksheetEditExtraObjectPermission,WorksheetFilterPermission,WorksheetInsertColumnPermission,WorksheetInsertRowPermission,WorksheetInsertHyperlinkPermission,WorksheetPivotTablePermission,WorksheetSetCellStylePermission,WorksheetSetCellValuePermission,WorksheetSetColumnStylePermission,WorksheetSetRowStylePermission,WorksheetSortPermission],"getAllWorksheetPermissionPointByPointPanel"),defaultWorksheetPermissionPoint=[P.Copy,P.DeleteColumn,P.DeleteRow,P.EditExtraObject,P.Filter,P.InsertColumn,P.InsertRow,P.InsertHyperlink,P.PivotTable,P.SetCellStyle,P.SetCellValue,P.SetColumnStyle,P.SetRowStyle,P.Sort];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"),_a6;exports.WorksheetProtectionPointModel=(_a6=class{constructor(){__publicField(this,"_model",new Map);__publicField(this,"_pointChange",new rxjs.Subject);__publicField(this,"pointChange$",this._pointChange.asObservable())}addRule(rule){this._ensureSubUnitMap(rule.unitId).set(rule.subUnitId,rule),this._pointChange.next(rule)}deleteRule(unitId,subUnitId){var _a21,_b,_c;const rule=(_a21=this._model.get(unitId))==null?void 0:_a21.get(subUnitId);rule&&((_c=(_b=this._model)==null?void 0:_b.get(unitId))==null||_c.delete(subUnitId),this._pointChange.next(rule))}getRule(unitId,subUnitId){var _a21,_b;return(_b=(_a21=this._model)==null?void 0:_a21.get(unitId))==null?void 0:_b.get(subUnitId)}toObject(){const result={};return[...this._model.keys()].forEach(unitId=>{const subUnitMap=this._model.get(unitId);subUnitMap!=null&&subUnitMap.size&&(result[unitId]=[],[...subUnitMap.keys()].forEach(subUnitId=>{const rule=subUnitMap.get(subUnitId);rule&&result[unitId].push(rule)}))}),result}fromObject(obj){const result=new Map;Object.keys(obj).forEach(unitId=>{const subUnitList=obj[unitId];if(subUnitList!=null&&subUnitList.length){const subUnitMap=new Map;subUnitList.forEach(rule=>{subUnitMap.set(rule.subUnitId,rule)}),result.set(unitId,subUnitMap)}}),this._model=result}deleteUnitModel(unitId){this._model.delete(unitId)}_ensureSubUnitMap(unitId){let subUnitMap=this._model.get(unitId);return subUnitMap||(subUnitMap=new Map,this._model.set(unitId,subUnitMap)),subUnitMap}getTargetByPermissionId(unitId,permissionId){const subUnitMap=this._model.get(unitId);if(!subUnitMap)return null;for(const[subUnitId,rule]of subUnitMap)if(rule.permissionId===permissionId)return[unitId,subUnitId]}},__name(_a6,"WorksheetProtectionPointModel"),_a6);exports.WorksheetProtectionPointModel=__decorateClass$e([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorksheetProtectionPointModel)],exports.WorksheetProtectionPointModel);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");const RULE_MODEL_PLUGIN_NAME="SHEET_WORKSHEET_PROTECTION_PLUGIN",POINT_MODEL_PLUGIN_NAME="SHEET_WORKSHEET_PROTECTION_POINT_PLUGIN";var _a7;exports.WorksheetPermissionService=(_a7=class extends core.RxDisposable{constructor(_permissionService,_univerInstanceService,_injector,_worksheetProtectionRuleModel,_worksheetProtectionPointRuleModel,_resourceManagerService,_rangeProtectionRuleModel){super(),this._permissionService=_permissionService,this._univerInstanceService=_univerInstanceService,this._injector=_injector,this._worksheetProtectionRuleModel=_worksheetProtectionRuleModel,this._worksheetProtectionPointRuleModel=_worksheetProtectionPointRuleModel,this._resourceManagerService=_resourceManagerService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._init(),this._initRuleChange(),this._initRuleSnapshot(),this._initPointSnapshot()}_init(){const handleWorkbook=__name(workbook=>{const unitId=workbook.getUnitId(),handleWorksheet=__name(worksheet=>{const subUnitId=worksheet.getSheetId();[...getAllWorksheetPermissionPoint(),...getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.addPermissionPoint(instance)})},"handleWorksheet");workbook.getSheets().forEach(worksheet=>{handleWorksheet(worksheet)}),workbook.sheetCreated$.subscribe(worksheet=>{handleWorksheet(worksheet)}),workbook.sheetDisposed$.subscribe(worksheet=>{const subUnitId=worksheet.getSheetId();this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{[RangeProtectionPermissionEditPoint,RangeProtectionPermissionViewPoint].forEach(F=>{const instance=new F(unitId,subUnitId,rule.permissionId);this._permissionService.deletePermissionPoint(instance.id)})}),[...getAllWorksheetPermissionPoint(),...getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.deletePermissionPoint(instance.id)})})},"handleWorkbook");this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>{handleWorkbook(workbook)}),this._univerInstanceService.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.takeUntil(this.dispose$)).subscribe(handleWorkbook),this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).pipe(operators.takeUntil(this.dispose$)).subscribe(workbook=>{workbook.getSheets().forEach(worksheet=>{const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId();getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.deletePermissionPoint(instance.id)})})})}_initRuleChange(){this.disposeWithMe(this._worksheetProtectionRuleModel.ruleChange$.subscribe(info=>{switch(info.type){case"add":break;case"delete":{getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,!0)});break}case"set":{getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId);this._permissionService.updatePermissionPoint(instance.id,info.rule)});break}}}))}_initRuleSnapshot(){const toJson=__name(()=>{const object=this._worksheetProtectionRuleModel.toObject();return JSON.stringify(object)},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({toJson,parseJson,pluginName:RULE_MODEL_PLUGIN_NAME,businesses:[I.UNIVER_SHEET],onLoad:__name((unitId,resources)=>{this._worksheetProtectionRuleModel.fromObject(resources),Object.keys(resources).forEach(subUnitId=>{getAllWorksheetPermissionPoint().forEach(F=>{const instance=new F(unitId,subUnitId);instance.value=!1,this._permissionService.addPermissionPoint(instance)})}),this._worksheetProtectionRuleModel.changeRuleInitState(!0)},"onLoad"),onUnLoad:__name(unitId=>{this._worksheetProtectionRuleModel.deleteUnitModel(unitId)},"onUnLoad")}))}_initPointSnapshot(){const toJson=__name(()=>{const object=this._worksheetProtectionPointRuleModel.toObject();return JSON.stringify(object)},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({toJson,parseJson,pluginName:POINT_MODEL_PLUGIN_NAME,businesses:[I.UNIVER_SHEET],onLoad:__name((unitId,resources)=>{this._worksheetProtectionPointRuleModel.fromObject(resources),Object.keys(resources).forEach(subUnitId=>{getAllWorksheetPermissionPointByPointPanel().forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.addPermissionPoint(instance)})})},"onLoad"),onUnLoad:__name(unitId=>{this._worksheetProtectionPointRuleModel.deleteUnitModel(unitId)},"onUnLoad")}))}},__name(_a7,"WorksheetPermissionService"),_a7);exports.WorksheetPermissionService=__decorateClass$d([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorksheetPermissionService),__decorateParam$d(0,core.Inject(core.IPermissionService)),__decorateParam$d(1,core.Inject(core.IUniverInstanceService)),__decorateParam$d(2,core.Inject(core.Injector)),__decorateParam$d(3,core.Inject(exports.WorksheetProtectionRuleModel)),__decorateParam$d(4,core.Inject(exports.WorksheetProtectionPointModel)),__decorateParam$d(5,core.Inject(core.IResourceManagerService)),__decorateParam$d(6,core.Inject(exports.RangeProtectionRuleModel))],exports.WorksheetPermissionService);const SetWorksheetPermissionPointsMutation={id:"sheet.mutation.set-worksheet-permission-points",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{rule}=params;return accessor.get(exports.WorksheetProtectionPointModel).addRule(rule),!0},"handler")},SetWorksheetPermissionPointsCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-permission-points",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),{rule}=params;return commandService.executeCommand(SetWorksheetPermissionPointsMutation.id,{rule,unitId:rule.unitId,subUnitId:rule.subUnitId}),!0}},FactoryDeleteRangeProtectionMutation=__name((accessor,param)=>{const selectionProtectionRuleModel=accessor.get(exports.RangeProtectionRuleModel),rules=param.ruleIds.map(id=>selectionProtectionRuleModel.getRule(param.unitId,param.subUnitId,id)).filter(rule=>!!rule);return{id:AddRangeProtectionMutation.id,params:{subUnitId:param.subUnitId,unitId:param.unitId,rules}}},"FactoryDeleteRangeProtectionMutation"),DeleteRangeProtectionMutation={id:"sheet.mutation.delete-range-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,ruleIds}=params,selectionProtectionRuleModel=accessor.get(exports.RangeProtectionRuleModel);return ruleIds.forEach(id=>{selectionProtectionRuleModel.deleteRule(unitId,subUnitId,id)}),!0},"handler")},FactoryAddRangeProtectionMutation=__name(param=>{const deleteParams={...param,ruleIds:param.rules.map(rule=>rule.id)};return{id:DeleteRangeProtectionMutation.id,params:deleteParams}},"FactoryAddRangeProtectionMutation"),AddRangeProtectionMutation={id:"sheet.mutation.add-range-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,rules}=params,selectionProtectionRuleModel=accessor.get(exports.RangeProtectionRuleModel);return rules.forEach(rule=>{selectionProtectionRuleModel.addRule(unitId,subUnitId,rule)}),!0},"handler")},AddRangeProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),selectionProtectionModel=accessor.get(exports.RangeProtectionRuleModel),{rule,permissionId}=params,{unitId,subUnitId,ranges,name,description}=rule,rules=[{ranges,permissionId,id:selectionProtectionModel.createRuleId(unitId,subUnitId),name,description,unitType:rule.unitType,unitId,subUnitId}];if(await commandService.executeCommand(AddRangeProtectionMutation.id,{unitId,subUnitId,rules})){const redoMutations=[{id:AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules}}],undoMutations=[{id:DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:rules.map(rule2=>rule2.id)}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteRangeProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),{unitId,subUnitId,rule}=params,redoMutationParam={unitId,subUnitId,ruleIds:[rule.id]};return await commandService.executeCommand(DeleteRangeProtectionMutation.id,redoMutationParam)&&undoRedoService.pushUndoRedo({unitID:unitId,redoMutations:[{id:DeleteRangeProtectionMutation.id,params:redoMutationParam}],undoMutations:[{id:AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}]}),!0}},SetRangeProtectionMutation={id:"sheet.mutation.set-range-protection",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{unitId,subUnitId,rule,ruleId}=params;return accessor.get(exports.RangeProtectionRuleModel).setRule(unitId,subUnitId,ruleId,rule),!0},"handler")},FactorySetRangeProtectionMutation=__name((accessor,param)=>{const{unitId,subUnitId,ruleId}=param,oldRule=accessor.get(exports.RangeProtectionRuleModel).getRule(unitId,subUnitId,ruleId);return oldRule?{id:SetRangeProtectionMutation.id,params:{...param,rule:oldRule}}:null},"FactorySetRangeProtectionMutation"),SetRangeProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),selectionProtectionModel=accessor.get(exports.RangeProtectionRuleModel),undoRedoService=accessor.get(core.IUndoRedoService),{rule,permissionId,oldRule}=params,{unitId,subUnitId,ranges,name,description}=rule;if(rule.id){const redoMutationParam={unitId,subUnitId,ruleId:rule.id,rule:{ranges,permissionId,id:selectionProtectionModel.createRuleId(unitId,subUnitId),name,description}};if(await commandService.executeCommand(SetRangeProtectionMutation.id,redoMutationParam)){const redoMutations=[{id:SetRangeProtectionMutation.id,params:redoMutationParam}],undoMutations=[{id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,ruleId:rule.id,rule:oldRule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}}return!0}},ReorderRangeUndoMutationFactory=__name(params=>{const{order}=params,newOrder={};return Object.keys(order).forEach(key=>{newOrder[order[Number(key)]]=Number(key)}),{...params,order:newOrder}},"ReorderRangeUndoMutationFactory"),ReorderRangeMutation={id:"sheet.mutation.reorder-range",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const{subUnitId,unitId,range,order}=params,worksheet=accessor.get(core.IUniverInstanceService).getUnit(unitId).getSheetBySheetId(subUnitId);if(!worksheet)return!1;const cellDataMatrix=new core.ObjectMatrix;core.Range.foreach(range,(row,col)=>{if(order.hasOwnProperty(row)){const targetRow=order[row],cloneCell=core.Tools.deepClone(worksheet.getCellRaw(targetRow,col));cellDataMatrix.setValue(row,col,cloneCell)}});const worksheetCellDataMatrix=worksheet.getCellMatrix();return cellDataMatrix.forValue((row,col,cellData)=>{worksheetCellDataMatrix.setValue(row,col,cellData)}),!0},"handler")},ReorderRangeCommandId="sheet.command.reorder-range",ReorderRangeCommand={id:ReorderRangeCommandId,type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{var _a21,_b;const{subUnitId,unitId,range,order}=params,commandService=accessor.get(core.ICommandService),reorderMutation={id:ReorderRangeMutation.id,params:{unitId,subUnitId,order,range}},undoReorderMutation={id:ReorderRangeMutation.id,params:ReorderRangeUndoMutationFactory(reorderMutation.params)},interceptorCommands=accessor.get(exports.SheetInterceptorService).onCommandExecute({id:ReorderRangeCommand.id,params}),redos=[...(_a21=interceptorCommands.preRedos)!=null?_a21:[],reorderMutation,...interceptorCommands.redos],undos=[...(_b=interceptorCommands.preUndos)!=null?_b:[],undoReorderMutation,...interceptorCommands.undos];return core.sequenceExecute(redos,commandService).result?(accessor.get(core.IUndoRedoService).pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos}),!0):!1},"handler")},MAX_CELL_PER_SHEET_KEY="maxCellsPerSheet",MAX_CELL_PER_SHEET_DEFAULT=3e6,ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY="ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY";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"),_a8;let BasicWorksheetController=(_a8=class extends core.Disposable{constructor(_commandService,_configService,_dataSyncPrimaryController){var _a21;super(),this._commandService=_commandService,this._configService=_configService,this._dataSyncPrimaryController=_dataSyncPrimaryController,[SetRangeValuesMutation,InsertColMutation,InsertRowMutation,InsertSheetMutation,MoveRangeMutation,MoveRowsMutation,MoveColsMutation,RemoveColMutation,RemoveRowMutation,RemoveSheetMutation,RemoveWorksheetMergeMutation,RemoveNumfmtMutation,AddWorksheetMergeMutation,SetWorkbookNameMutation,SetWorksheetNameMutation,SetNumfmtMutation,ReorderRangeMutation,EmptyMutation,SetWorksheetColWidthMutation].forEach(mutation=>{var _a22;this._commandService.registerCommand(mutation),(_a22=this._dataSyncPrimaryController)==null||_a22.registerSyncingMutations(mutation)}),((_a21=this._configService.getConfig(ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY))!=null?_a21:!1)||[ClearSelectionAllCommand,ClearSelectionContentCommand,ClearSelectionFormatCommand,CopySheetCommand,DeleteRangeMoveLeftCommand,DeleteRangeMoveUpCommand,DeltaColumnWidthCommand,DeltaRowHeightCommand,InsertColAfterCommand,InsertColBeforeCommand,InsertColCommand,InsertRangeMoveDownCommand,InsertRangeMoveRightCommand,InsertRowAfterCommand,InsertRowBeforeCommand,InsertRowCommand,InsertSheetCommand,MoveColsCommand,MoveRangeCommand,MoveRowsCommand,RemoveColCommand,RemoveRowCommand,RemoveSheetCommand,ReorderRangeCommand,RemoveWorksheetMergeCommand,ResetBackgroundColorCommand,ResetTextColorCommand,SetBackgroundColorCommand,SetBorderBasicCommand,SetBorderColorCommand,SetBorderCommand,SetBorderPositionCommand,SetBorderStyleCommand,SetColHiddenCommand,SetColHiddenMutation,SetColVisibleMutation,SetColWidthCommand,SetFrozenCancelCommand,SetFrozenCommand,SetFrozenMutation,SetHorizontalTextAlignCommand,SetRangeValuesCommand,SetRowHeightCommand,SetRowHiddenCommand,SetRowHiddenMutation,SetRowVisibleMutation,SetSelectedColsVisibleCommand,SetSelectedRowsVisibleCommand,SetSpecificColsVisibleCommand,SetSpecificRowsVisibleCommand,SetStyleCommand,SetTabColorCommand,SetTabColorMutation,SetTextColorCommand,SetTextRotationCommand,SetTextWrapCommand,SetVerticalTextAlignCommand,SetWorkbookNameCommand,SetWorksheetActivateCommand,SetWorksheetActiveOperation,SetWorksheetHideCommand,SetWorksheetHideMutation,SetWorksheetNameCommand,SetWorksheetOrderCommand,SetWorksheetOrderMutation,SetWorksheetRowAutoHeightMutation,SetWorksheetRowHeightMutation,SetWorksheetRowIsAutoHeightCommand,SetWorksheetRowIsAutoHeightMutation,SetSelectionsOperation,ScrollToCellOperation,InsertDefinedNameCommand,RemoveDefinedNameCommand,SetDefinedNameCommand,SetWorksheetShowCommand,SetWorksheetPermissionPointsCommand,AddWorksheetProtectionMutation,SetWorksheetProtectionMutation,DeleteWorksheetProtectionMutation,SetWorksheetPermissionPointsMutation,AddRangeProtectionCommand,DeleteRangeProtectionCommand,SetRangeProtectionCommand,AddRangeProtectionMutation,DeleteRangeProtectionMutation,SetRangeProtectionMutation].forEach(command=>this.disposeWithMe(this._commandService.registerCommand(command))),this._configService.setConfig(MAX_CELL_PER_SHEET_KEY,MAX_CELL_PER_SHEET_DEFAULT)}},__name(_a8,"BasicWorksheetController"),_a8);BasicWorksheetController=__decorateClass$c([core.OnLifecycle(core.LifecycleStages.Starting,BasicWorksheetController),__decorateParam$c(0,core.ICommandService),__decorateParam$c(1,core.IConfigService),__decorateParam$c(2,core.Optional(rpc.DataSyncPrimaryController))],BasicWorksheetController);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"),_a9;let CalculateResultApplyController=(_a9=class extends core.Disposable{constructor(_univerInstanceService,_commandService){super(),this._univerInstanceService=_univerInstanceService,this._commandService=_commandService,this._initialize()}_initialize(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(command.id!==engineFormula.SetFormulaCalculationResultMutation.id)return;const params=command.params,{unitData}=params,unitIds=Object.keys(unitData),redoMutationsInfo=[];return unitIds.forEach(unitId=>{const sheetData=unitData[unitId];if(sheetData==null)return!0;Object.keys(sheetData).forEach(sheetId=>{const cellData=sheetData[sheetId];if(cellData==null)return!0;const cellValue=this._getMergedCellData(unitId,sheetId,cellData),setRangeValuesMutation={subUnitId:sheetId,unitId,cellValue};redoMutationsInfo.push({id:SetRangeValuesMutation.id,params:setRangeValuesMutation})})}),redoMutationsInfo.every(m=>this._commandService.executeCommand(m.id,m.params,{onlyLocal:!0}))}))}_getMergedCellData(unitId,sheetId,cellData){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId),styles=workbook==null?void 0:workbook.getStyles(),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(sheetId),oldCellDataMatrix=worksheet==null?void 0:worksheet.getCellMatrix(),cellDataMatrix=new core.ObjectMatrix(cellData);return cellDataMatrix.forValue((row,col,cell)=>{const oldCell=oldCellDataMatrix==null?void 0:oldCellDataMatrix.getValue(row,col),newCell=engineFormula.handleNumfmtInCell(oldCell,cell,styles);cellDataMatrix.setValue(row,col,newCell)}),cellDataMatrix.clone()}},__name(_a9,"CalculateResultApplyController"),_a9);CalculateResultApplyController=__decorateClass$b([core.OnLifecycle(core.LifecycleStages.Ready,CalculateResultApplyController),__decorateParam$b(0,core.Inject(core.IUniverInstanceService)),__decorateParam$b(1,core.ICommandService)],CalculateResultApplyController);const PLUGIN_CONFIG_KEY="sheets.config",defaultPluginConfig={};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");const SHEET_DEFINED_NAME_PLUGIN="SHEET_DEFINED_NAME_PLUGIN";var _a10;exports.DefinedNameDataController=(_a10=class extends core.Disposable{constructor(_definedNamesService,_resourceManagerService){super(),this._definedNamesService=_definedNamesService,this._resourceManagerService=_resourceManagerService,this._initialize()}_initialize(){this._initSnapshot()}_initSnapshot(){const toJson=__name(unitId=>{const map=this._definedNamesService.getDefinedNameMap(unitId);return map?JSON.stringify(map):""},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({pluginName:SHEET_DEFINED_NAME_PLUGIN,businesses:[core.UniverInstanceType.UNIVER_SHEET],toJson:__name(unitId=>toJson(unitId),"toJson"),parseJson:__name(json=>parseJson(json),"parseJson"),onUnLoad:__name(unitId=>{this._definedNamesService.removeUnitDefinedName(unitId)},"onUnLoad"),onLoad:__name((unitId,value)=>{this._definedNamesService.registerDefinedNames(unitId,value)},"onLoad")}))}},__name(_a10,"DefinedNameDataController"),_a10);exports.DefinedNameDataController=__decorateClass$a([core.OnLifecycle(core.LifecycleStages.Ready,exports.DefinedNameDataController),__decorateParam$a(0,engineFormula.IDefinedNamesService),__decorateParam$a(1,core.IResourceManagerService)],exports.DefinedNameDataController);const EffectRefRangId={MoveRangeCommandId,InsertRowCommandId,InsertColCommandId,RemoveColCommandId,RemoveRowCommandId,DeleteRangeMoveLeftCommandId,DeleteRangeMoveUpCommandId,InsertRangeMoveDownCommandId,InsertRangeMoveRightCommandId,MoveColsCommandId,MoveRowsCommandId,ReorderRangeCommandId};var OperatorType=(OperatorType2=>(OperatorType2[OperatorType2.Set=0]="Set",OperatorType2[OperatorType2.Delete=1]="Delete",OperatorType2[OperatorType2.HorizontalMove=2]="HorizontalMove",OperatorType2[OperatorType2.VerticalMove=3]="VerticalMove",OperatorType2[OperatorType2.Unknown=4]="Unknown",OperatorType2))(OperatorType||{});const MAX_SAFE_INTEGER=Number.MAX_SAFE_INTEGER,handleRangeTypeInput=__name(range=>{const _range={...range},isColumn=Number.isNaN(_range.startRow)&&Number.isNaN(_range.endRow)&&!Number.isNaN(_range.startColumn)&&!Number.isNaN(_range.endColumn),isRow=Number.isNaN(_range.startColumn)&&Number.isNaN(_range.endColumn)&&!Number.isNaN(_range.startRow)&&!Number.isNaN(_range.endRow);return(_range.rangeType===core.RANGE_TYPE.COLUMN||isColumn)&&(_range.startRow=0,_range.endRow=MAX_SAFE_INTEGER),(_range.rangeType===core.RANGE_TYPE.ROW||isRow)&&(_range.startColumn=0,_range.endColumn=MAX_SAFE_INTEGER),_range.rangeType===core.RANGE_TYPE.ALL&&(_range.startColumn=0,_range.endColumn=MAX_SAFE_INTEGER,_range.startRow=0,_range.endRow=MAX_SAFE_INTEGER),_range},"handleRangeTypeInput"),rotateRange=__name(range=>{let rangeType=range.rangeType;return range.rangeType===core.RANGE_TYPE.COLUMN?rangeType=core.RANGE_TYPE.ROW:range.rangeType===core.RANGE_TYPE.ROW&&(rangeType=core.RANGE_TYPE.COLUMN),{startRow:range.startColumn,endRow:range.endColumn,startColumn:range.startRow,endColumn:range.endRow,rangeType}},"rotateRange"),handleBaseMoveRowsCols=__name((fromRange,toRange,effectRange)=>{const _effectRange={...effectRange},_toRange={...toRange},getIntersects=__name((line1,line2)=>{const start=Math.max(line1.start,line2.start),end=Math.min(line1.end,line2.end);return end<start?null:{start,end}},"getIntersects"),getLength=__name(line=>line.end-line.start+1,"getLength"),getRelative=__name((line,origin)=>({start:line.start-origin.start,end:line.start-origin.start+line.end-line.start}),"getRelative"),getAbsolute=__name((line,origin)=>({start:origin.start+line.start,end:origin.start+line.start+line.end-line.start}),"getAbsolute"),isToLargeFrom=toRange.start>fromRange.start;if(isToLargeFrom){const step=Math.min(fromRange.end,toRange.start)-fromRange.start+1;_toRange.start-=step,_toRange.end-=step}const fromRangeStep=getLength(fromRange),toRangeStep=fromRangeStep,fromRangeIntersectsEffectRange=getIntersects(fromRange,_effectRange),isFromRangeContainEffectRange=fromRangeIntersectsEffectRange&&getLength(fromRangeIntersectsEffectRange)>=getLength(_effectRange);if(fromRange.end<_effectRange.start)_effectRange.start-=fromRangeStep,_effectRange.end-=fromRangeStep;else if(fromRangeIntersectsEffectRange){const fromRangeIntersectsEffectRangeStep=getLength(fromRangeIntersectsEffectRange);if(isFromRangeContainEffectRange){const relative=getRelative(_effectRange,fromRange),newLine=getAbsolute(relative,_toRange);_effectRange.start=newLine.start,_effectRange.end=newLine.end}else fromRangeIntersectsEffectRange.start>fromRange.start?isToLargeFrom?(_effectRange.end-=fromRangeIntersectsEffectRangeStep+fromRangeStep,_effectRange.start-=fromRangeStep):_effectRange.end-=fromRangeIntersectsEffectRangeStep:isToLargeFrom?_effectRange.end-=fromRangeIntersectsEffectRangeStep:_effectRange.start>fromRange.start&&_effectRange.end>fromRange.end?(_effectRange.start-=fromRangeStep,_effectRange.end-=fromRangeStep+fromRangeIntersectsEffectRangeStep):_effectRange.end-=fromRangeIntersectsEffectRangeStep}const toRangeIntersectsEffectRange=getIntersects(_toRange,_effectRange);return isFromRangeContainEffectRange||(_toRange.start<=_effectRange.start?(_effectRange.start+=toRangeStep,_effectRange.end+=toRangeStep):toRangeIntersectsEffectRange&&(isToLargeFrom?_toRange.end<=_effectRange.start||_toRange.start<=_effectRange.start&&_toRange.end>=_effectRange.start?(_effectRange.start+=toRangeStep,_effectRange.end+=toRangeStep):_toRange.start>=_effectRange.start&&_toRange.start<=_effectRange.end&&(_effectRange.end+=toRangeStep):_effectRange.start<_toRange.start&&_effectRange.end>_toRange.start?_effectRange.end+=toRangeStep:(_effectRange.start>=_toRange.end||_effectRange.start>=_toRange.start&&_effectRange.start<=_toRange.end)&&(_effectRange.end+=toRangeStep,_effectRange.start+=toRangeStep))),{step:_effectRange.start-effectRange.start,length:getLength(_effectRange)-getLength(effectRange)}},"handleBaseMoveRowsCols"),handleMoveRows=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!toRange||!fromRange)return[];const _fromRange=handleRangeTypeInput(fromRange),_toRange=handleRangeTypeInput(toRange),_targetRange=handleRangeTypeInput(targetRange),result=handleBaseMoveRowsCols({start:_fromRange.startRow,end:_fromRange.endRow},{start:_toRange.startRow,end:_toRange.endRow},{start:_targetRange.startRow,end:_targetRange.endRow});return result===null?[{type:OperatorType.Delete}]:[{type:OperatorType.VerticalMove,step:result.step||0,length:result.length||0}]},"handleMoveRows"),handleMoveRowsCommon=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!fromRange||!toRange)return[targetRange];const fromRow=fromRange.startRow,count=fromRange.endRow-fromRange.startRow+1,toRow=toRange.startRow,matrix=new core.ObjectMatrix;return core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)}),matrix.moveRows(fromRow,count,toRow),core.queryObjectMatrix(matrix,value=>value===1)},"handleMoveRowsCommon"),handleReorderRangeCommon=__name((param,targetRange)=>{const{range,order}=param.params||{};if(!range||!order)return[targetRange];const matrix=new core.ObjectMatrix;core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)});const cacheMatrix=new core.ObjectMatrix;return core.Range.foreach(range,(row,col)=>{var _a21;if(order.hasOwnProperty(row)){const targetRow=order[row],cloneCell=(_a21=matrix.getValue(targetRow,col))!=null?_a21:0;cacheMatrix.setValue(row,col,cloneCell)}}),cacheMatrix.forValue((row,col,cellData)=>{matrix.setValue(row,col,cellData)}),core.queryObjectMatrix(matrix,value=>value===1)},"handleReorderRangeCommon"),handleMoveCols=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!toRange||!fromRange)return[];const _fromRange=handleRangeTypeInput(fromRange),_toRange=handleRangeTypeInput(toRange),_targetRange=handleRangeTypeInput(targetRange),result=handleBaseMoveRowsCols({start:_fromRange.startColumn,end:_fromRange.endColumn},{start:_toRange.startColumn,end:_toRange.endColumn},{start:_targetRange.startColumn,end:_targetRange.endColumn});return result===null?[{type:OperatorType.Delete}]:[{type:OperatorType.HorizontalMove,step:result.step||0,length:result.length||0}]},"handleMoveCols"),handleMoveColsCommon=__name((params,targetRange)=>{const{fromRange,toRange}=params.params||{};if(!fromRange||!toRange)return[targetRange];const fromCol=fromRange.startColumn,count=fromRange.endColumn-fromRange.startColumn+1,toCol=toRange.startColumn,matrix=new core.ObjectMatrix;return core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)}),matrix.moveColumns(fromCol,count,toCol),core.queryObjectMatrix(matrix,value=>value===1)},"handleMoveColsCommon"),handleMoveRange=__name((param,targetRange)=>{var _a21,_b;const toRange=(_a21=param.params)==null?void 0:_a21.toRange,fromRange=(_b=param.params)==null?void 0:_b.fromRange;if(!toRange||!fromRange)return[];const operators2=[];if(core.Rectangle.contains(toRange,targetRange)&&operators2.push({type:OperatorType.Delete}),core.Rectangle.contains(fromRange,targetRange)){operators2.push({type:OperatorType.Delete});const relativeRange=core.Rectangle.getRelativeRange(targetRange,fromRange),positionRange=core.Rectangle.getPositionRange(relativeRange,toRange);return[{type:OperatorType.Set,range:positionRange}]}return operators2},"handleMoveRange"),handleMoveRangeCommon=__name((param,targetRange)=>{var _a21,_b;const toRange=(_a21=param.params)==null?void 0:_a21.toRange,fromRange=(_b=param.params)==null?void 0:_b.fromRange;if(!toRange||!fromRange)return[targetRange];if(!core.Rectangle.intersects(fromRange,targetRange)&&!core.Rectangle.intersects(toRange,targetRange))return[targetRange];if(core.Rectangle.contains(fromRange,targetRange)){const relativeRange=core.Rectangle.getRelativeRange(targetRange,fromRange);return[core.Rectangle.getPositionRange(relativeRange,toRange)]}const matrix=new core.ObjectMatrix;core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)});const fromMatrix=new core.ObjectMatrix,loopFromRange=core.Rectangle.getIntersects(fromRange,targetRange);loopFromRange&&core.Range.foreach(loopFromRange,(row,col)=>{matrix.getValue(row,col)&&(matrix.setValue(row,col,void 0),fromMatrix.setValue(row,col,1))});const columnOffset=toRange.startColumn-fromRange.startColumn,rowOffset=toRange.startRow-fromRange.startRow,loopToRange={startColumn:toRange.startColumn-columnOffset,endColumn:toRange.endColumn-columnOffset,startRow:toRange.startRow-rowOffset,endRow:toRange.endRow-rowOffset};return loopToRange&&core.Range.foreach(loopToRange,(row,col)=>{var _a22;const targetRow=row+rowOffset,targetCol=col+columnOffset;matrix.setValue(targetRow,targetCol,(_a22=fromMatrix.getValue(row,col))!=null?_a22:0)}),core.queryObjectMatrix(matrix,value=>value===1)},"handleMoveRangeCommon"),handleBaseRemoveRange=__name((_removeRange,_targetRange)=>{const removeRange=handleRangeTypeInput(_removeRange),targetRange=handleRangeTypeInput(_targetRange),getLength=__name(range=>range.endColumn-range.startColumn+1,"getLength"),getRowLength=__name(range=>range.endRow-range.startRow+1,"getRowLength");if(removeRange.startRow<=targetRange.startRow&&removeRange.endRow>=targetRange.endRow){if(targetRange.startColumn<removeRange.startColumn&&targetRange.endColumn>=removeRange.startColumn&&targetRange.endColumn<=removeRange.endColumn||targetRange.startColumn<removeRange.startColumn&&targetRange.endColumn>=removeRange.endColumn){const intersectedRange=core.Rectangle.getIntersects(targetRange,removeRange);if(intersectedRange)return{step:0,length:-getLength(intersectedRange)}}if(targetRange.startColumn>=removeRange.startColumn&&targetRange.endColumn<=removeRange.endColumn&&getRowLength(removeRange)>=getRowLength(targetRange))return null;if(targetRange.startColumn>=removeRange.startColumn&&targetRange.startColumn<=removeRange.endColumn&&targetRange.endColumn>removeRange.endColumn){const intersectedRange=core.Rectangle.getIntersects(targetRange,removeRange);if(intersectedRange){const length=-getLength(intersectedRange);return{step:-(getLength(removeRange)-getLength(intersectedRange)),length}}}if(targetRange.startColumn>removeRange.endColumn)return{step:-getLength(removeRange),length:0}}return{step:0,length:0}},"handleBaseRemoveRange"),handleIRemoveCol=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(range,targetRange);if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.HorizontalMove,step,length})}return operators2},"handleIRemoveCol"),handleIRemoveRow=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(rotateRange(range),rotateRange(targetRange));if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.VerticalMove,step,length})}return operators2},"handleIRemoveRow"),handleReorderRange=__name((param,targetRange)=>{const{range,order}=param.params||{};if(!range||!order)return[];if(core.Rectangle.contains(range,targetRange)&&targetRange.endRow===targetRange.startRow){const operators2=[],targetRow=targetRange.startRow;for(const k in order)if(order[k]===targetRow){const toRow=Number(k);return operators2.push({type:OperatorType.VerticalMove,step:toRow-targetRow,length:0}),operators2}return[]}return[]},"handleReorderRange"),handleBaseInsertRange=__name((_insertRange,_targetRange)=>{const insertRange=handleRangeTypeInput(_insertRange),targetRange=handleRangeTypeInput(_targetRange),getLength=__name(range=>range.endColumn-range.startColumn+1,"getLength");if(insertRange.startRow<=targetRange.startRow&&insertRange.endRow>=targetRange.endRow){if(targetRange.startColumn<insertRange.startColumn&&targetRange.endColumn>=insertRange.startColumn&&targetRange.endColumn<=insertRange.endColumn||targetRange.startColumn<insertRange.startColumn&&targetRange.endColumn>=insertRange.endColumn)return{step:0,length:getLength(insertRange)};if(targetRange.startColumn>=insertRange.startColumn&&targetRange.endColumn<=insertRange.endColumn||targetRange.startColumn>insertRange.startColumn&&targetRange.startColumn<=insertRange.endColumn&&targetRange.endColumn>insertRange.endColumn||targetRange.startColumn>=insertRange.endColumn)return{step:getLength(insertRange),length:0}}return{step:0,length:0}},"handleBaseInsertRange");function handleBaseMoveRange(fromRange,toRange,targetRange){const operators2=[];if(core.Rectangle.contains(toRange,targetRange)&&operators2.push({type:OperatorType.Delete}),core.Rectangle.contains(fromRange,targetRange)){operators2.push({type:OperatorType.Delete});const relativeRange=core.Rectangle.getRelativeRange(targetRange,fromRange),positionRange=core.Rectangle.getPositionRange(relativeRange,toRange);return[{type:OperatorType.Set,range:positionRange}]}return operators2}__name(handleBaseMoveRange,"handleBaseMoveRange");const handleInsertRow=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(rotateRange(range),rotateRange(targetRange)),{step,length}=result;return operators2.push({type:OperatorType.VerticalMove,step,length}),operators2},"handleInsertRow"),handleInsertCol=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(range,targetRange),{step,length}=result;return operators2.push({type:OperatorType.HorizontalMove,step,length}),operators2},"handleInsertCol"),handleInsertRangeMoveDown=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(rotateRange(range),rotateRange(targetRange)),{step,length}=result;return operators2.push({type:OperatorType.VerticalMove,step,length}),operators2},"handleInsertRangeMoveDown"),handleInsertRangeMoveDownCommon=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[targetRange];const moveCount=range.endRow-range.startRow+1,bottomRange={...range,startRow:range.startRow,endRow:Number.POSITIVE_INFINITY},noMoveRanges=core.Rectangle.subtract(targetRange,bottomRange),targetMoveRange=core.Rectangle.getIntersects(bottomRange,targetRange);if(!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row+moveCount,col,1)}),core.queryObjectMatrix(matrix,v=>v===1)},"handleInsertRangeMoveDownCommon"),handleInsertRangeMoveRight=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseInsertRange(range,targetRange),{step,length}=result;return operators2.push({type:OperatorType.HorizontalMove,step,length}),operators2},"handleInsertRangeMoveRight"),handleInsertRangeMoveRightCommon=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[targetRange];const moveCount=range.endColumn-range.startColumn+1,bottomRange={...range,startColumn:range.startColumn,endColumn:Number.POSITIVE_INFINITY},noMoveRanges=core.Rectangle.subtract(targetRange,bottomRange),targetMoveRange=core.Rectangle.getIntersects(bottomRange,targetRange);if(!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row,col+moveCount,1)}),core.queryObjectMatrix(matrix,v=>v===1)},"handleInsertRangeMoveRightCommon"),handleDeleteRangeMoveLeft=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(range,targetRange);if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.HorizontalMove,step,length})}return operators2},"handleDeleteRangeMoveLeft"),handleDeleteRangeMoveLeftCommon=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[targetRange];const rightRange={startRow:range.startRow,endRow:range.endRow,startColumn:range.startColumn,endColumn:Number.POSITIVE_INFINITY},moveCount=range.endColumn-range.startColumn+1,targetDeleteRange=core.Rectangle.getIntersects(range,targetRange),noMoveRanges=core.Rectangle.subtract(targetRange,rightRange),targetMoveRange=core.Rectangle.getIntersects(rightRange,targetRange);if(!targetDeleteRange&&!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row,col-moveCount,1)}),targetDeleteRange&&core.Range.foreach(targetDeleteRange,(row,col)=>{matrix.setValue(row,col-moveCount,0)}),noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),core.queryObjectMatrix(matrix,v=>v===1)},"handleDeleteRangeMoveLeftCommon"),handleDeleteRangeMoveUp=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[];const operators2=[],result=handleBaseRemoveRange(rotateRange(range),rotateRange(targetRange));if(!result)operators2.push({type:OperatorType.Delete});else{const{step,length}=result;operators2.push({type:OperatorType.VerticalMove,step,length})}return operators2},"handleDeleteRangeMoveUp"),handleDeleteRangeMoveUpCommon=__name((param,targetRange)=>{var _a21;const range=(_a21=param.params)==null?void 0:_a21.range;if(!range)return[targetRange];const bottomRange={...range,startRow:range.startRow,endRow:Number.POSITIVE_INFINITY},moveCount=range.endRow-range.startRow+1,targetDeleteRange=core.Rectangle.getIntersects(range,targetRange),noMoveRanges=core.Rectangle.subtract(targetRange,bottomRange),targetMoveRange=core.Rectangle.getIntersects(bottomRange,targetRange);if(!targetDeleteRange&&!targetMoveRange)return[targetRange];const matrix=new core.ObjectMatrix;return targetMoveRange&&core.Range.foreach(targetMoveRange,(row,col)=>{matrix.setValue(row-moveCount,col,1)}),targetDeleteRange&&core.Range.foreach(targetDeleteRange,(row,col)=>{matrix.setValue(row-moveCount,col,0)}),noMoveRanges.forEach(noMoveRange=>{core.Range.foreach(noMoveRange,(row,col)=>{matrix.setValue(row,col,1)})}),core.queryObjectMatrix(matrix,v=>v===1)},"handleDeleteRangeMoveUpCommon"),handleRemoveRowCommon=__name((param,targetRange)=>{var _a21;const ranges=(_a21=param.ranges)!=null?_a21:[param.range],matrix=new core.ObjectMatrix;return core.Range.foreach(targetRange,(row,col)=>{matrix.setValue(row,col,1)}),ranges.forEach(range=>{const startRow=range.startRow,count=range.endRow-startRow+1;matrix.removeRows(startRow,count)}),core.queryObjectMatrix(matrix,value=>value===1)},"handleRemoveRowCommon"),runRefRangeMutations=__name((operators2,range)=>{let result={...range};return operators2.forEach(operator=>{switch(operator.type){case OperatorType.Delete:{result=null;break}case OperatorType.HorizontalMove:{if(!result)return;result.startColumn+=operator.step,result.endColumn+=operator.step+(operator.length||0);break}case OperatorType.VerticalMove:{if(!result)return;result.startRow+=operator.step,result.endRow+=operator.step+(operator.length||0);break}case OperatorType.Set:{result=operator.range;break}}}),result&&(result.endColumn<result.startColumn||result.endRow<result.startRow)?null:result},"runRefRangeMutations"),handleDefaultRangeChangeWithEffectRefCommands=__name((range,commandInfo)=>{let operator=[];switch(commandInfo.id){case EffectRefRangId.DeleteRangeMoveLeftCommandId:{operator=handleDeleteRangeMoveLeft(commandInfo,range);break}case EffectRefRangId.DeleteRangeMoveUpCommandId:{operator=handleDeleteRangeMoveUp(commandInfo,range);break}case EffectRefRangId.InsertColCommandId:{operator=handleInsertCol(commandInfo,range);break}case EffectRefRangId.InsertRangeMoveDownCommandId:{operator=handleInsertRangeMoveDown(commandInfo,range);break}case EffectRefRangId.InsertRangeMoveRightCommandId:{operator=handleInsertRangeMoveRight(commandInfo,range);break}case EffectRefRangId.InsertRowCommandId:{operator=handleInsertRow(commandInfo,range);break}case EffectRefRangId.MoveColsCommandId:{operator=handleMoveCols(commandInfo,range);break}case EffectRefRangId.MoveRangeCommandId:{operator=handleMoveRange(commandInfo,range);break}case EffectRefRangId.MoveRowsCommandId:{operator=handleMoveRows(commandInfo,range);break}case EffectRefRangId.RemoveColCommandId:{operator=handleIRemoveCol(commandInfo,range);break}case EffectRefRangId.RemoveRowCommandId:{operator=handleIRemoveRow(commandInfo,range);break}case EffectRefRangId.ReorderRangeCommandId:{operator=handleReorderRange(commandInfo,range);break}}return runRefRangeMutations(operator,range)},"handleDefaultRangeChangeWithEffectRefCommands"),handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests=__name((range,commandInfo,deps)=>[DeleteRangeMoveLeftCommand.id,DeleteRangeMoveUpCommand.id].includes(commandInfo.id)||getEffectedRangesOnCommand(commandInfo,deps).some(effectRange=>core.Rectangle.intersects(effectRange,range))?handleDefaultRangeChangeWithEffectRefCommands(range,commandInfo):range,"handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests"),handleCommonDefaultRangeChangeWithEffectRefCommands=__name((range,commandInfo)=>{let operator=[];switch(commandInfo.id){case EffectRefRangId.DeleteRangeMoveLeftCommandId:return handleDeleteRangeMoveLeftCommon(commandInfo,range);case EffectRefRangId.DeleteRangeMoveUpCommandId:return handleDeleteRangeMoveUpCommon(commandInfo,range);case EffectRefRangId.InsertRangeMoveDownCommandId:return handleInsertRangeMoveDownCommon(commandInfo,range);case EffectRefRangId.InsertRangeMoveRightCommandId:return handleInsertRangeMoveRightCommon(commandInfo,range);case EffectRefRangId.InsertColCommandId:{operator=handleInsertCol(commandInfo,range);break}case EffectRefRangId.InsertRowCommandId:{operator=handleInsertRow(commandInfo,range);break}case EffectRefRangId.MoveColsCommandId:return handleMoveColsCommon(commandInfo,range);case EffectRefRangId.MoveRangeCommandId:return handleMoveRangeCommon(commandInfo,range);case EffectRefRangId.MoveRowsCommandId:return handleMoveRowsCommon(commandInfo,range);case EffectRefRangId.ReorderRangeCommandId:return handleReorderRangeCommon(commandInfo,range);case EffectRefRangId.RemoveColCommandId:{operator=handleIRemoveCol(commandInfo,range);break}case EffectRefRangId.RemoveRowCommandId:return handleRemoveRowCommon(commandInfo.params,range)}const resultRange=runRefRangeMutations(operator,range);return resultRange?[resultRange]:[]},"handleCommonDefaultRangeChangeWithEffectRefCommands"),handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests=__name((range,commandInfo,deps)=>[DeleteRangeMoveLeftCommand.id,DeleteRangeMoveUpCommand.id,InsertRangeMoveDownCommand.id,InsertRangeMoveRightCommandId].includes(commandInfo.id)||getEffectedRangesOnCommand(commandInfo,deps).some(effectRange=>core.Rectangle.intersects(effectRange,range))?handleCommonDefaultRangeChangeWithEffectRefCommands(range,commandInfo):range,"handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests");function adjustRangeOnMutation(range,mutation){const{id,params}=mutation;let baseRangeOperator={length:0,step:0,type:OperatorType.Unknown};switch(id){case RemoveSheetMutation.id:baseRangeOperator.type=OperatorType.Delete;break;case MoveRowsMutation.id:baseRangeOperator=handleBaseMoveRowsCols({start:params.sourceRange.startRow,end:params.sourceRange.endRow},{start:params.targetRange.startRow,end:params.targetRange.endRow},{start:range.startRow,end:range.endRow}),baseRangeOperator.type=OperatorType.VerticalMove;break;case MoveColsMutation.id:baseRangeOperator=handleBaseMoveRowsCols({start:params.sourceRange.startColumn,end:params.sourceRange.endColumn},{start:params.targetRange.startColumn,end:params.targetRange.endColumn},{start:range.startColumn,end:range.endColumn}),baseRangeOperator.type=OperatorType.HorizontalMove;break;case RemoveColMutation.id:baseRangeOperator=handleBaseRemoveRange(params.range,range),baseRangeOperator?baseRangeOperator.type=OperatorType.HorizontalMove:baseRangeOperator={step:0,length:0,type:OperatorType.Delete};break;case RemoveRowMutation.id:baseRangeOperator=handleBaseRemoveRange(rotateRange(params.range),rotateRange(range)),baseRangeOperator?baseRangeOperator.type=OperatorType.VerticalMove:baseRangeOperator={step:0,length:0,type:OperatorType.Delete};break;case InsertRowMutation.id:baseRangeOperator=handleBaseInsertRange(rotateRange(params.range),rotateRange(range)),baseRangeOperator.type=OperatorType.VerticalMove;break;case InsertColMutation.id:baseRangeOperator=handleBaseInsertRange(params.range,range),baseRangeOperator.type=OperatorType.HorizontalMove;break;case MoveRangeMutation.id:{const fromRange=params.fromRange||new core.ObjectMatrix(params.from).getRange(),toRange=params.toRange||new core.ObjectMatrix(params.to).getRange();baseRangeOperator=handleBaseMoveRange(fromRange,toRange,range)}break}return baseRangeOperator?Array.isArray(baseRangeOperator)?runRefRangeMutations(baseRangeOperator,range):runRefRangeMutations([baseRangeOperator],range):range}__name(adjustRangeOnMutation,"adjustRangeOnMutation");function getEffectedRangesOnCommand(command,deps){var _a21,_b,_c,_d,_e,_f;const{selectionManagerService}=deps;switch(command.id){case EffectRefRangId.MoveColsCommandId:{const params=command.params;return[params.fromRange,{...params.toRange,startColumn:params.toRange.startColumn-.5,endColumn:params.toRange.endColumn-.5}]}case EffectRefRangId.MoveRowsCommandId:{const params=command.params;return[params.fromRange,{...params.toRange,startRow:params.toRange.startRow-.5,endRow:params.toRange.startRow-.5}]}case EffectRefRangId.MoveRangeCommandId:{const params=command;return[params.params.fromRange,params.params.toRange]}case EffectRefRangId.InsertRowCommandId:{const range=command.params.range;return[{...range,startRow:range.startRow-.5,endRow:range.endRow-.5}]}case EffectRefRangId.InsertColCommandId:{const range=command.params.range;return[{...range,startColumn:range.startColumn-.5,endColumn:range.endColumn-.5}]}case EffectRefRangId.RemoveRowCommandId:return[command.params.range];case EffectRefRangId.RemoveColCommandId:return[command.params.range];case EffectRefRangId.DeleteRangeMoveUpCommandId:case EffectRefRangId.InsertRangeMoveDownCommandId:{const range=((_a21=command.params)==null?void 0:_a21.range)||((_c=(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range))==null?void 0:_c[0]);return range?[range]:[]}case EffectRefRangId.DeleteRangeMoveLeftCommandId:case EffectRefRangId.InsertRangeMoveRightCommandId:{const range=((_d=command.params)==null?void 0:_d.range)||((_f=(_e=selectionManagerService.getCurrentSelections())==null?void 0:_e.map(s=>s.range))==null?void 0:_f[0]);return range?[range]:[]}case EffectRefRangId.ReorderRangeCommandId:{const params=command,{range,order}=params.params,effectRanges=[];for(let row=range.startRow;row<=range.endRow;row++)row in order&&effectRanges.push({startRow:row,endRow:row,startColumn:range.startColumn,endColumn:range.endColumn});return effectRanges}}}__name(getEffectedRangesOnCommand,"getEffectedRangesOnCommand");function getEffectedRangesOnMutation(mutation){switch(mutation.id){case MoveColsMutation.id:{const params=mutation.params;return[params.sourceRange,{...params.targetRange,startColumn:params.targetRange.startColumn-.5,endColumn:params.targetRange.startColumn-.5}]}case MoveRowsMutation.id:{const params=mutation.params;return[params.sourceRange,{...params.targetRange,startRow:params.targetRange.startRow-.5,endRow:params.targetRange.startRow-.5}]}case MoveRangeMutation.id:{const params=mutation.params;return[new core.ObjectMatrix(params.from.value).getRange(),new core.ObjectMatrix(params.to.value).getRange()]}case InsertColMutation.id:{const range=mutation.params.range;return[{...range,startColumn:range.startColumn-.5,endColumn:range.startColumn-.5}]}case InsertRowMutation.id:{const range=mutation.params.range;return[{...range,startRow:range.startRow-.5,endRow:range.startRow-.5}]}case RemoveColMutation.id:return[mutation.params.range];case RemoveRowMutation.id:return[mutation.params.range]}}__name(getEffectedRangesOnMutation,"getEffectedRangesOnMutation");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");const MERGE_REDO=core.createInterceptorKey("MERGE_REDO"),MERGE_UNDO=core.createInterceptorKey("MERGE_UNDO"),MAX_ROW_COL=Math.floor(Number.MAX_SAFE_INTEGER/10),_WatchRange=class _WatchRange extends core.Disposable{constructor(_unitId,_subUnitId,_range,_callback,_skipIntersects=!1){super(),this._unitId=_unitId,this._subUnitId=_subUnitId,this._range=_range,this._callback=_callback,this._skipIntersects=_skipIntersects}onMutation(mutation){var _a21,_b;if(((_a21=mutation.params)==null?void 0:_a21.unitId)!==this._unitId)return;if(mutation.id===MoveRangeMutation.id){const params=mutation.params;if(params.from.subUnitId!==this._subUnitId||params.to.subUnitId!==this._subUnitId)return}else if(((_b=mutation.params)==null?void 0:_b.subUnitId)!==this._subUnitId)return;if(!this._range)return;if(this._skipIntersects){if(mutation.id===RemoveSheetMutation.id)return;const effectRanges=getEffectedRangesOnMutation(mutation);if(effectRanges!=null&&effectRanges.some(effectRange=>core.Rectangle.intersects(effectRange,this._range)))return}const afterRange=adjustRangeOnMutation(this._range,mutation);if(afterRange&&core.Rectangle.equals(afterRange,this._range))return!1;const beforeChange=this._range;this._range=afterRange,this._callback(beforeChange,afterRange)}};__name(_WatchRange,"WatchRange");let WatchRange=_WatchRange;var _a11;exports.RefRangeService=(_a11=class extends core.Disposable{constructor(_commandService,_sheetInterceptorService,_univerInstanceService,_selectionManagerService){super();__publicField(this,"interceptor",new core.InterceptorManager({MERGE_REDO,MERGE_UNDO}));__publicField(this,"_watchRanges",new Set);__publicField(this,"_refRangeManagerMap",new Map);__publicField(this,"_serializer",createRangeSerializer());__publicField(this,"_onRefRangeChange",__name(()=>{this._sheetInterceptorService.interceptCommand({getMutations:__name(command=>{const worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet(),unitId=getUnitId(this._univerInstanceService),subUnitId=getSubUnitId(this._univerInstanceService);if(!worksheet||!unitId||!subUnitId)return{redos:[],undos:[],preRedos:[],preUndos:[]};const result=(__name(()=>{switch(command.id){case EffectRefRangId.MoveColsCommandId:{const params=command.params,startColumn=Math.min(params.fromRange.startColumn,params.toRange.startColumn);return this._checkRange([{...params.fromRange,startColumn,endColumn:worksheet.getColumnCount()-1}],unitId,subUnitId)}case EffectRefRangId.MoveRowsCommandId:{const params=command.params,startRow=Math.min(params.fromRange.startRow,params.toRange.startRow);return this._checkRange([{...params.fromRange,startRow,endRow:worksheet.getRowCount()-1}],unitId,subUnitId)}case EffectRefRangId.MoveRangeCommandId:{const params=command;return this._checkRange([params.params.fromRange,params.params.toRange],unitId,subUnitId)}case EffectRefRangId.InsertRowCommandId:{const range={startRow:command.params.range.startRow,endRow:worksheet.getRowCount()-1,startColumn:0,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ROW};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.InsertColCommandId:{const colStart=command.params.range.startColumn,range={startRow:0,endRow:worksheet.getRowCount()-1,startColumn:colStart,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.COLUMN};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.RemoveRowCommandId:{const range={startRow:command.params.range.startRow,endRow:worksheet.getRowCount()-1,startColumn:0,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ROW};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.RemoveColCommandId:{const colStart=command.params.range.startColumn,range={startRow:0,endRow:worksheet.getRowCount()-1,startColumn:colStart,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.COLUMN};return this._checkRange([range],unitId,subUnitId)}case EffectRefRangId.DeleteRangeMoveUpCommandId:case EffectRefRangId.InsertRangeMoveDownCommandId:{const range=command.params.range||getSelectionRanges(this._selectionManagerService)[0],effectRange={startRow:range.startRow,startColumn:range.startColumn,endColumn:range.endColumn,endRow:MAX_ROW_COL};return this._checkRange([effectRange],unitId,subUnitId)}case EffectRefRangId.DeleteRangeMoveLeftCommandId:case EffectRefRangId.InsertRangeMoveRightCommandId:{const range=command.params.range||getSelectionRanges(this._selectionManagerService)[0],effectRange={startRow:range.startRow,startColumn:range.startColumn,endColumn:MAX_ROW_COL,endRow:range.endRow};return this._checkRange([effectRange],unitId,subUnitId)}case EffectRefRangId.ReorderRangeCommandId:{const params=command,{range,order}=params.params,effectRanges=[];for(let row=range.startRow;row<=range.endRow;row++)row in order&&effectRanges.push({startRow:row,endRow:row,startColumn:range.startColumn,endColumn:range.endColumn});return this._checkRange(effectRanges,unitId,subUnitId)}}},"getEffectsCbList")()||[]).reduce((result2,currentFn)=>{const v=currentFn(command);return result2.push(v),result2},[]).reduce((result2,currentValue)=>{var _a21,_b;return result2.redos.push(...currentValue.redos),result2.undos.push(...currentValue.undos),result2.preRedos.push(...(_a21=currentValue.preRedos)!=null?_a21:[]),result2.preUndos.push(...(_b=currentValue.preUndos)!=null?_b:[]),result2},{redos:[],undos:[],preUndos:[],preRedos:[]}),preRedos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_REDO)(result.preRedos,null)||[],redos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_REDO)(result.redos,null)||[],preUndos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_UNDO)(result.preUndos,null)||[],undos=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().MERGE_UNDO)(result.undos,null)||[];return{redos,undos,preRedos,preUndos}},"getMutations")})},"_onRefRangeChange"));__publicField(this,"_checkRange",__name((effectRanges,unitId,subUnitId)=>{const managerId=getRefRangId(unitId,subUnitId),manager=this._refRangeManagerMap.get(managerId);if(manager){const callbackSet=new Set;return[...manager.keys()].forEach(key=>{const cbList=manager.get(key),range=this._serializer.deserialize(key),realRange={...range,startRow:+range.startRow,endRow:+range.endRow,startColumn:+range.startColumn,endColumn:+range.endColumn,rangeType:range.rangeType&&+range.rangeType};effectRanges.some(item=>core.Rectangle.intersects(item,realRange))&&cbList&&cbList.forEach(callback=>{callbackSet.add(callback)})}),[...callbackSet]}return[]},"_checkRange"));__publicField(this,"registerRefRange",__name((range,callback,_unitId,_subUnitId)=>{const unitId=_unitId||getUnitId(this._univerInstanceService),subUnitId=_subUnitId||getSubUnitId(this._univerInstanceService);if(!unitId||!subUnitId)return core.toDisposable(()=>{});const refRangeManagerId=getRefRangId(unitId,subUnitId),rangeString=this._serializer.serialize(range);let manager=this._refRangeManagerMap.get(refRangeManagerId);manager||(manager=new Map,this._refRangeManagerMap.set(refRangeManagerId,manager));const refRangeCallbackList=manager.get(rangeString);return refRangeCallbackList?refRangeCallbackList.add(callback):manager.set(rangeString,new Set([callback])),core.toDisposable(()=>{const refRangeCallbackList2=manager.get(rangeString);refRangeCallbackList2&&(refRangeCallbackList2.delete(callback),refRangeCallbackList2.size||(manager.delete(rangeString),manager.size||this._refRangeManagerMap.delete(refRangeManagerId)))})},"registerRefRange"));this._commandService=_commandService,this._sheetInterceptorService=_sheetInterceptorService,this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._onRefRangeChange(),this.interceptor.intercept(this.interceptor.getInterceptPoints().MERGE_REDO,{priority:-1,handler:__name(list=>list,"handler")}),this.interceptor.intercept(this.interceptor.getInterceptPoints().MERGE_UNDO,{priority:-1,handler:__name(list=>list,"handler")})}watchRange(unitId,subUnitId,range,callback,skipIntersects){let watchRangesListener;this._watchRanges.size===0&&(watchRangesListener=this._commandService.onCommandExecuted(command=>{if(command.type!==core.CommandType.MUTATION)return!1;for(const watchRange2 of this._watchRanges)watchRange2.onMutation(command)}));const watchRange=new WatchRange(unitId,subUnitId,range,callback,skipIntersects);this._watchRanges.add(watchRange);const teardownWatching=core.toDisposable(()=>{this._watchRanges.delete(watchRange),this._watchRanges.size===0&&(watchRangesListener==null||watchRangesListener.dispose(),watchRangesListener=null)}),registerToService=this.disposeWithMe(teardownWatching);return core.toDisposable(()=>{registerToService.dispose(),teardownWatching.dispose()})}},__name(_a11,"RefRangeService"),_a11);exports.RefRangeService=__decorateClass$9([core.OnLifecycle(core.LifecycleStages.Ready,exports.RefRangeService),__decorateParam$9(0,core.ICommandService),__decorateParam$9(1,core.Inject(exports.SheetInterceptorService)),__decorateParam$9(2,core.Inject(core.IUniverInstanceService)),__decorateParam$9(3,core.Inject(exports.SheetsSelectionsService))],exports.RefRangeService);function getUnitId(univerInstanceService){return univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()}__name(getUnitId,"getUnitId");function getSubUnitId(univerInstanceService){var _a21;return(_a21=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet())==null?void 0:_a21.getSheetId()}__name(getSubUnitId,"getSubUnitId");function getSelectionRanges(selectionManagerService){var _a21;return((_a21=selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range))||[]}__name(getSelectionRanges,"getSelectionRanges");function getRefRangId(unitId,subUnitId){return`${unitId}_${subUnitId}`}__name(getRefRangId,"getRefRangId");function createRangeSerializer(){const keyList=["startRow","startColumn","endRow","endColumn","rangeType"],SPLIT_CODE="_";return{deserialize:__name(rangeString=>{const map=keyList.reduce((preValue,currentValue,index)=>(preValue[String(index)]=currentValue,preValue),{});return rangeString.split(SPLIT_CODE).reduce((preValue,currentValue,_index)=>{const index=String(_index);return currentValue&&map[index]&&(preValue[map[index]]=currentValue),preValue},{})},"deserialize"),serialize:__name(range=>keyList.reduce((preValue,currentValue,index)=>{const value=range[currentValue];return value!==void 0?`${preValue}${index>0?SPLIT_CODE:""}${value}`:`${preValue}`},""),"serialize")}}__name(createRangeSerializer,"createRangeSerializer");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 mutationIdByRowCol$1=[InsertColMutation.id,InsertRowMutation.id,RemoveColMutation.id,RemoveRowMutation.id],mutationIdArrByMove$1=[MoveRowsMutation.id,MoveColsMutation.id];function getAddMergeMutationRangeByType(selection,type){let ranges=selection;if(type!==void 0){const rectangles=[];for(let i=0;i<ranges.length;i++){const{startRow,endRow,startColumn,endColumn}=ranges[i];if(type===core.Dimension.ROWS)for(let r=startRow;r<=endRow;r++){const data={startRow:r,endRow:r,startColumn,endColumn};rectangles.push(data)}else if(type===core.Dimension.COLUMNS)for(let c=startColumn;c<=endColumn;c++){const data={startRow,endRow,startColumn:c,endColumn:c};rectangles.push(data)}}ranges=rectangles}return ranges}__name(getAddMergeMutationRangeByType,"getAddMergeMutationRangeByType");const MERGE_CELL_INTERCEPTOR_CHECK=core.createInterceptorKey("mergeCellPermissionCheck");var _a12;exports.MergeCellController=(_a12=class extends core.Disposable{constructor(_commandService,_refRangeService,_univerInstanceService,_injector,_sheetInterceptorService,_selectionManagerService){super();__publicField(this,"disposableCollection",new core.DisposableCollection);__publicField(this,"interceptor",new core.InterceptorManager({MERGE_CELL_INTERCEPTOR_CHECK}));this._commandService=_commandService,this._refRangeService=_refRangeService,this._univerInstanceService=_univerInstanceService,this._injector=_injector,this._sheetInterceptorService=_sheetInterceptorService,this._selectionManagerService=_selectionManagerService,this._onRefRangeChange(),this._initCommandInterceptor(),this._commandExecutedListener()}_initCommandInterceptor(){const self=this;this._sheetInterceptorService.interceptCommand({getMutations(commandInfo){var _a21;switch(commandInfo.id){case ClearSelectionAllCommand.id:case ClearSelectionFormatCommand.id:{const workbook=self._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),unitId=workbook.getUnitId(),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!worksheet)return{redos:[],undos:[]};const subUnitId=worksheet.getSheetId(),mergeData=worksheet.getConfig().mergeData,selections=(_a21=self._selectionManagerService.getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(selections&&selections.length>0&&selections.some(range=>mergeData.some(item=>core.Rectangle.intersects(item,range)))){const removeMergeParams={unitId,subUnitId,ranges:selections},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(self._injector,removeMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos}}}}return{redos:[],undos:[]}}}),this._sheetInterceptorService.interceptRanges({getMutations:__name(({unitId,subUnitId,ranges})=>{const redos=[],undos=[],emptyInterceptorArr={redos,undos};if(!ranges||!ranges.length)return emptyInterceptorArr;const target=getSheetCommandTarget(this._univerInstanceService,{unitId,subUnitId});if(!target)return emptyInterceptorArr;const{worksheet}=target,overlapRanges=worksheet.getMergeData().filter(item=>ranges.some(range=>core.Rectangle.intersects(item,range)));return overlapRanges.length?(redos.push({id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:overlapRanges}}),undos.push({id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:overlapRanges}}),{undos,redos}):emptyInterceptorArr},"getMutations")})}refRangeHandle(config,unitId,subUnitId){switch(config.id){case EffectRefRangId.MoveColsCommandId:{const params=config.params;return this._handleMoveColsCommand(params,unitId,subUnitId)}case EffectRefRangId.MoveRowsCommandId:{const params=config.params;return this._handleMoveRowsCommand(params,unitId,subUnitId)}case InsertRowCommand.id:{const params=config.params,_unitId=params.unitId||unitId,_subUnitId=params.subUnitId||subUnitId;return this._handleInsertRowCommand(params,_unitId,_subUnitId)}case InsertColCommand.id:{const params=config.params,_unitId=params.unitId||unitId,_subUnitId=params.subUnitId||subUnitId;return this._handleInsertColCommand(params,_unitId,_subUnitId)}case RemoveColCommand.id:{const params=config.params;return this._handleRemoveColCommand(params,unitId,subUnitId)}case RemoveRowCommand.id:{const params=config.params;return this._handleRemoveRowCommand(params,unitId,subUnitId)}case MoveRangeCommand.id:{const params=config.params;return this._handleMoveRangeCommand(params,unitId,subUnitId)}case InsertRangeMoveRightCommand.id:{const params=config.params;return this._handleInsertRangeMoveRightCommand(params,unitId,subUnitId)}case InsertRangeMoveDownCommand.id:{const params=config.params;return this._handleInsertRangeMoveDownCommand(params,unitId,subUnitId)}case DeleteRangeMoveUpCommand.id:{const params=config.params;return this._handleDeleteRangeMoveUpCommand(params,unitId,subUnitId)}case DeleteRangeMoveLeftCommand.id:{const params=config.params;return this._handleDeleteRangeMoveLeftCommand(params,unitId,subUnitId)}}return{redos:[],undos:[]}}_onRefRangeChange(){const registerRefRange=__name((unitId,subUnitId)=>{const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const workSheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!workSheet)return;this.disposableCollection.dispose();const mergeData=workSheet.getMergeData(),handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");mergeData.forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))})},"registerRefRange");this.disposeWithMe(this._commandService.onCommandExecuted(commandInfo=>{if(commandInfo.id===SetWorksheetActiveOperation.id){const params=commandInfo.params,sheetId=params.subUnitId,unitId=params.unitId;if(!sheetId||!unitId)return;registerRefRange(unitId,sheetId)}if(commandInfo.id===AddWorksheetMergeMutation.id){const params=commandInfo.params,sheetId=params.subUnitId,unitId=params.unitId;if(!sheetId||!unitId)return;registerRefRange(params.unitId,params.subUnitId)}})),this._univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.first(workbook=>!!workbook)).subscribe(workbook=>{const sheet=workbook.getActiveSheet();sheet&®isterRefRange(workbook.getUnitId(),sheet.getSheetId())})}_handleMoveRowsCommand(params,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const mergeData=[...worksheet.getMergeData()],removeParams={unitId,subUnitId,ranges:[]},addParams={unitId,subUnitId,ranges:[]},{fromRange}=params,{startRow:sourceStart,endRow:sourceEnd}=fromRange;if(mergeData.forEach(range=>{if(sourceStart<=range.startRow&&sourceEnd>=range.endRow){removeParams.ranges.push(range);const operation=handleMoveRows({id:EffectRefRangId.MoveRowsCommandId,params},range),result=runRefRangeMutations(operation,range);result&&addParams.ranges.push(result)}}),removeParams.ranges.length===0)return this._handleNull();const removeUndo=RemoveMergeUndoMutationFactory(this._injector,removeParams),addUndo=AddMergeUndoMutationFactory(this._injector,addParams);return{redos:[{id:RemoveWorksheetMergeMutation.id,params:removeParams},{id:AddWorksheetMergeMutation.id,params:addParams}],undos:[{id:RemoveWorksheetMergeMutation.id,params:addUndo},{id:AddWorksheetMergeMutation.id,params:removeUndo}]}}_handleMoveColsCommand(params,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const mergeData=[...worksheet.getMergeData()],removeParams={unitId,subUnitId,ranges:[]},addParams={unitId,subUnitId,ranges:[]},{fromRange}=params,{startColumn:sourceStart,endColumn:sourceEnd}=fromRange;if(mergeData.forEach(range=>{if(sourceStart<=range.startColumn&&sourceEnd>=range.endColumn){removeParams.ranges.push(range);const operation=handleMoveCols({id:EffectRefRangId.MoveColsCommandId,params},range),result=runRefRangeMutations(operation,range);result&&addParams.ranges.push(result)}}),removeParams.ranges.length===0)return this._handleNull();const removeUndo=RemoveMergeUndoMutationFactory(this._injector,removeParams),addUndo=AddMergeUndoMutationFactory(this._injector,addParams);return{redos:[{id:RemoveWorksheetMergeMutation.id,params:removeParams},{id:AddWorksheetMergeMutation.id,params:addParams}],undos:[{id:RemoveWorksheetMergeMutation.id,params:addUndo},{id:AddWorksheetMergeMutation.id,params:removeUndo}]}}_handleMoveRangeCommand(params,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const mergeData=worksheet.getMergeData(),fromMergeRanges=mergeData.filter(item=>core.Rectangle.intersects(item,params.fromRange)),toMergeRanges=mergeData.filter(item=>core.Rectangle.intersects(item,params.toRange)),willMoveToMergeRanges=fromMergeRanges.map(mergeRange=>core.Rectangle.getRelativeRange(mergeRange,params.fromRange)).map(relativeRange=>core.Rectangle.getPositionRange(relativeRange,params.toRange)),addMergeCellRanges=getAddMergeMutationRangeByType(willMoveToMergeRanges).filter(range=>!mergeData.some(mergeRange=>core.Rectangle.equals(range,mergeRange))),redos=[{id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:fromMergeRanges}},{id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:toMergeRanges}},{id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:addMergeCellRanges}}],undos=[{id:RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:addMergeCellRanges}},{id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:toMergeRanges}},{id:AddWorksheetMergeMutation.id,params:{unitId,subUnitId,ranges:fromMergeRanges}}];return{redos,undos}}_handleInsertRowCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{range}=config,{startRow,endRow}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(startRow>cell.startRow&&startRow<=cell.endRow&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(startRow>cell.startRow&&startRow<=cell.endRow){const count=endRow-startRow+1;cell.endRow+=count,this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams},{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos}}_handleInsertColCommand(config,unitId,subUnitId){const{range}=config,workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{startColumn,endColumn}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(startColumn>cell.startColumn&&startColumn<=cell.endColumn&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(startColumn>cell.startColumn&&startColumn<=cell.endColumn){const count=endColumn-startColumn+1;cell.endColumn+=count,this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),redos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams},{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams},{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos}}_handleRemoveColCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{range}=config,{startColumn,endColumn}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(core.Rectangle.intersects(range,cell)&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(core.Rectangle.intersects(range,cell)){if(startColumn<=cell.startColumn&&endColumn>=cell.endColumn)return mergeCellsHasLapping;startColumn>=cell.startColumn&&endColumn<=cell.endColumn?cell.endColumn-=endColumn-startColumn+1:startColumn<cell.startColumn?(cell.startColumn=startColumn,cell.endColumn-=endColumn-startColumn+1):endColumn>cell.endColumn&&(cell.endColumn=startColumn-1),this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeMutationParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeMutationParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeMutationParams),addMergeMutationParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeMutationParams),preRedos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}],redos=[{id:AddWorksheetMergeMutation.id,params:addMergeMutationParams}],preUndos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}];return{preUndos,undos,preRedos,redos}}_handleRemoveRowCommand(config,unitId,subUnitId){const{range}=config,workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const{startRow,endRow}=range,oldMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>(core.Rectangle.intersects(range,cell)&&mergeCellsHasLapping.push(cell),mergeCellsHasLapping),[]);if(oldMergeCells.length===0)return this._handleNull();const newMergeCells=core.Tools.deepClone(worksheet.getMergeData()).reduce((mergeCellsHasLapping,cell)=>{if(core.Rectangle.intersects(range,cell)){if(startRow<=cell.startRow&&endRow>=cell.endRow)return mergeCellsHasLapping;startRow>=cell.startRow&&endRow<=cell.endRow?cell.endRow-=endRow-startRow+1:startRow<cell.startRow?(cell.startRow=startRow,cell.endRow-=endRow-startRow+1):endRow>cell.endRow&&(cell.endRow=startRow-1),this._checkIsMergeCell(cell)&&mergeCellsHasLapping.push(cell)}return mergeCellsHasLapping},[]),removeMergeMutationParams={unitId,subUnitId,ranges:oldMergeCells},undoRemoveMergeMutationParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeMutationParams),addMergeMutationParams={unitId,subUnitId,ranges:newMergeCells},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeMutationParams),preRedos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}],redos=[{id:AddWorksheetMergeMutation.id,params:addMergeMutationParams}],preUndos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}];return{preUndos,undos,preRedos,redos}}_handleInsertRangeMoveRightCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxCol=worksheet.getMaxColumns()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,endRow,startColumn,endColumn}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow,endColumn:maxCol},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow,endColumn:maxCol},rect))){const currentColumnsCount=endColumn-startColumn+1;addMergeData.push({startRow:rect.startRow,startColumn:rect.startColumn+currentColumnsCount,endRow:rect.endRow,endColumn:rect.endColumn+currentColumnsCount})}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams);return{preRedos:[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams}],redos:[{id:AddWorksheetMergeMutation.id,params:addMergeParams}],preUndos:[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}],undos:[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}]}}_handleInsertRangeMoveDownCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxRow=worksheet.getMaxRows()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,startColumn,endColumn,endRow}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow:maxRow,endColumn},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow:maxRow,endColumn},rect))){const rowCount=endRow-startRow+1;addMergeData.push({startRow:rect.startRow+rowCount,startColumn:rect.startColumn,endRow:rect.endRow+rowCount,endColumn:rect.endColumn})}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),preRedos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams}],redos=[{id:AddWorksheetMergeMutation.id,params:addMergeParams}],preUndos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos,preRedos,preUndos}}_handleDeleteRangeMoveUpCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxRow=worksheet.getMaxRows()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,startColumn,endColumn,endRow}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow:maxRow,endColumn},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow:maxRow,endColumn},rect))){const rowCount=endRow-startRow+1,range2=core.Rectangle.moveVertical(rect,-rowCount);addMergeData.push(range2)}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams),preRedos=[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams}],redos=[{id:AddWorksheetMergeMutation.id,params:addMergeParams}],preUndos=[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}],undos=[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}];return{redos,undos,preRedos,preUndos}}_handleDeleteRangeMoveLeftCommand(config,unitId,subUnitId){const workbook=getWorkbook(this._univerInstanceService,unitId);if(!workbook)return this._handleNull();const worksheet=getWorksheet(workbook,subUnitId);if(!worksheet)return this._handleNull();const range=config.range,maxCol=worksheet.getMaxColumns()-1,mergeData=worksheet.getMergeData(),removeMergeData=[],addMergeData=[];mergeData.forEach(rect=>{const{startRow,endRow,startColumn,endColumn}=range;if(core.Rectangle.intersects({startRow,startColumn,endRow,endColumn:maxCol},rect)&&(removeMergeData.push(rect),core.Rectangle.contains({startRow,startColumn,endRow,endColumn:maxCol},rect))){const currentColumnsCount=endColumn-startColumn+1;addMergeData.push({startRow:rect.startRow,startColumn:rect.startColumn-currentColumnsCount,endRow:rect.endRow,endColumn:rect.endColumn-currentColumnsCount})}});const removeMergeParams={unitId,subUnitId,ranges:removeMergeData},undoRemoveMergeParams=RemoveMergeUndoMutationFactory(this._injector,removeMergeParams),addMergeParams={unitId,subUnitId,ranges:addMergeData},undoAddMergeParams=AddMergeUndoMutationFactory(this._injector,addMergeParams);return{preRedos:[{id:RemoveWorksheetMergeMutation.id,params:removeMergeParams}],redos:[{id:AddWorksheetMergeMutation.id,params:addMergeParams}],undos:[{id:AddWorksheetMergeMutation.id,params:undoRemoveMergeParams}],preUndos:[{id:RemoveWorksheetMergeMutation.id,params:undoAddMergeParams}]}}_checkIsMergeCell(cell){return!(cell.startRow===cell.endRow&&cell.startColumn===cell.endColumn)}_handleNull(){return{redos:[],undos:[]}}_commandExecutedListener(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(mutationIdArrByMove$1.includes(command.id)){if(!command.params)return;const workbook=this._univerInstanceService.getUniverSheetInstance(command.params.unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const{sourceRange,targetRange}=command.params,isRowMove=sourceRange.startColumn===targetRange.startColumn&&sourceRange.endColumn===targetRange.endColumn,moveLength=isRowMove?sourceRange.endRow-sourceRange.startRow+1:sourceRange.endColumn-sourceRange.startColumn+1,sourceStart=isRowMove?sourceRange.startRow:sourceRange.startColumn,targetStart=isRowMove?targetRange.startRow:targetRange.startColumn,mergeData=worksheet.getConfig().mergeData,adjustedMergedCells=[];mergeData.forEach(merge=>{let{startRow,endRow,startColumn,endColumn,rangeType}=merge;core.Rectangle.intersects(merge,sourceRange)||(isRowMove?sourceStart<startRow&&targetStart>endRow?(startRow-=moveLength,endRow-=moveLength):sourceStart>endRow&&targetStart<=startRow&&(startRow+=moveLength,endRow+=moveLength):sourceStart<startColumn&&targetStart>endColumn?(startColumn-=moveLength,endColumn-=moveLength):sourceStart>endColumn&&targetStart<=startColumn&&(startColumn+=moveLength,endColumn+=moveLength)),merge.startRow===merge.endRow&&merge.startColumn===merge.endColumn||adjustedMergedCells.push({startRow,endRow,startColumn,endColumn,rangeType})}),worksheet.setMergeData(adjustedMergedCells),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");adjustedMergedCells.forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))})}if(mutationIdByRowCol$1.includes(command.id)){const workbook=this._univerInstanceService.getUniverSheetInstance(command.params.unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const mergeData=worksheet.getConfig().mergeData,params=command.params;if(!params)return;const{range}=params,isRowOperation=command.id.includes("row"),isAddOperation=command.id.includes("insert"),operationStart=isRowOperation?range.startRow:range.startColumn,operationEnd=isRowOperation?range.endRow:range.endColumn,operationCount=operationEnd-operationStart+1,adjustedMergedCells=[];mergeData.forEach(merge=>{let{startRow,endRow,startColumn,endColumn,rangeType}=merge;isAddOperation?isRowOperation?operationStart<=startRow&&(startRow+=operationCount,endRow+=operationCount):operationStart<=startColumn&&(startColumn+=operationCount,endColumn+=operationCount):isRowOperation?operationEnd<startRow&&(startRow-=operationCount,endRow-=operationCount):operationEnd<startColumn&&(startColumn-=operationCount,endColumn-=operationCount),merge.startRow===merge.endRow&&merge.startColumn===merge.endColumn||adjustedMergedCells.push({startRow,endRow,startColumn,endColumn,rangeType})}),worksheet.setMergeData(adjustedMergedCells),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");adjustedMergedCells.forEach(range2=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range2,handler,unitId,subUnitId))})}}))}},__name(_a12,"MergeCellController"),_a12);exports.MergeCellController=__decorateClass$8([__decorateParam$8(0,core.Inject(core.ICommandService)),__decorateParam$8(1,core.Inject(exports.RefRangeService)),__decorateParam$8(2,core.Inject(core.IUniverInstanceService)),__decorateParam$8(3,core.Inject(core.Injector)),__decorateParam$8(4,core.Inject(exports.SheetInterceptorService)),__decorateParam$8(5,core.Inject(exports.SheetsSelectionsService))],exports.MergeCellController);function getWorkbook(univerInstanceService,unitId){return unitId?univerInstanceService.getUniverSheetInstance(unitId):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET)}__name(getWorkbook,"getWorkbook");function getWorksheet(workbook,subUnitId){return subUnitId?workbook.getSheetBySheetId(subUnitId):workbook.getActiveSheet()}__name(getWorksheet,"getWorksheet");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"),_a13;let NumberCellDisplayController=(_a13=class extends core.Disposable{constructor(_sheetInterceptorService){super(),this._sheetInterceptorService=_sheetInterceptorService,this._initialize()}_initialize(){this._initInterceptorCellContent()}_initInterceptorCellContent(){this.disposeWithMe(this._sheetInterceptorService.intercept(INTERCEPTOR_POINT.CELL_CONTENT,{priority:11,effect:core.InterceptorEffectEnum.Value|core.InterceptorEffectEnum.Style,handler:__name((cell,location,next)=>{var _a21;const style=location.workbook.getStyles().getStyleByCell(cell);return(_a21=style==null?void 0:style.n)!=null&&_a21.pattern?next({...cell}):(cell==null?void 0:cell.t)===core.CellValueType.NUMBER&&typeof(cell==null?void 0:cell.v)=="number"?next({...cell,v:engineFormula.stripErrorMargin(cell.v)}):next({...cell})},"handler")}))}},__name(_a13,"NumberCellDisplayController"),_a13);NumberCellDisplayController=__decorateClass$7([core.OnLifecycle(core.LifecycleStages.Ready,NumberCellDisplayController),__decorateParam$7(0,core.Inject(exports.SheetInterceptorService))],NumberCellDisplayController);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"),_a14;exports.RangeProtectionCache=(_a14=class extends core.Disposable{constructor(_ruleModel,_permissionService,_univerInstanceService){super();__publicField(this,"_cellRuleCache",new Map);__publicField(this,"_permissionIdCache",new Map);__publicField(this,"_cellInfoCache",new Map);this._ruleModel=_ruleModel,this._permissionService=_permissionService,this._univerInstanceService=_univerInstanceService,this._initUpdateCellRuleCache(),this._initUpdateCellInfoCache(),this._initCache()}_initCache(){this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>{workbook.getSheets().forEach(sheet=>{const unitId=workbook.getUnitId(),subUnitId=sheet.getSheetId();this.reBuildCache(unitId,subUnitId)})})}_initUpdateCellInfoCache(){this._permissionService.permissionPointUpdate$.pipe(rxjs.filter(permission=>permission.type===M.SelectRange),rxjs.map(permission=>permission)).subscribe(permission=>{const{subUnitId,unitId,permissionId}=permission,ruleId=this._permissionIdCache.get(permissionId);if(!ruleId)return;const ruleInstance=this._ruleModel.getRule(unitId,subUnitId,ruleId);if(!ruleInstance)return;const cellInfoMap=this._ensureCellInfoMap(unitId,subUnitId);ruleInstance.ranges.forEach(range=>{const{startRow,endRow,startColumn,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellInfoMap.delete(`${i}-${j}`)})}),this._ruleModel.ruleChange$.subscribe(info=>{var _a21;const{unitId,subUnitId}=info,cellInfoMap=this._ensureCellInfoMap(unitId,subUnitId);info.rule.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{cellInfoMap.delete(`${row}-${col}`)})}),info.type==="set"&&((_a21=info.oldRule)==null||_a21.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{this._cellInfoCache.delete(`${row}-${col}`)})}))})}_initUpdateCellRuleCache(){this._ruleModel.ruleChange$.subscribe(ruleChange=>{const{type}=ruleChange;type==="add"?this._addCellRuleCache(ruleChange):type==="delete"?this._deleteCellRuleCache(ruleChange):(this._deleteCellRuleCache({...ruleChange,rule:ruleChange.oldRule}),this._addCellRuleCache(ruleChange))})}_ensureRuleMap(unitId,subUnitId){let subUnitMap=this._cellRuleCache.get(unitId);subUnitMap||(subUnitMap=new Map,this._cellRuleCache.set(unitId,subUnitMap));let cellMap=subUnitMap.get(subUnitId);return cellMap||(cellMap=new Map,subUnitMap.set(subUnitId,cellMap)),cellMap}_ensureCellInfoMap(unitId,subUnitId){let subUnitMap=this._cellInfoCache.get(unitId);subUnitMap||(subUnitMap=new Map,this._cellInfoCache.set(unitId,subUnitMap));let cellMap=subUnitMap.get(subUnitId);return cellMap||(cellMap=new Map,subUnitMap.set(subUnitId,cellMap)),cellMap}_addCellRuleCache(ruleChange){const{subUnitId,unitId,rule}=ruleChange,cellMap=this._ensureRuleMap(unitId,subUnitId);rule.ranges.forEach(range=>{const{startRow,endRow,startColumn,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellMap.set(`${i}-${j}`,rule.id)}),this._permissionIdCache.set(rule.permissionId,rule.id)}_deleteCellRuleCache(ruleChange){const{subUnitId,unitId,rule}=ruleChange,cellMap=this._ensureRuleMap(unitId,subUnitId),cellInfoMap=this._ensureCellInfoMap(unitId,subUnitId);rule.ranges.forEach(range=>{const{startRow,endRow,startColumn,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellMap.delete(`${i}-${j}`),cellInfoMap.delete(`${i}-${j}`)}),this._permissionIdCache.delete(rule.permissionId)}reBuildCache(unitId,subUnitId){const cellRuleMap=this._ensureRuleMap(unitId,subUnitId),cellInfoMap=this._ensureCellInfoMap(unitId,subUnitId);cellRuleMap.clear(),cellInfoMap.clear(),this._ruleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{var _a21,_b,_c,_d,_e,_f;const edit=(_c=(_b=this._permissionService.getPermissionPoint((_a21=new RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId))==null?void 0:_a21.id))==null?void 0:_b.value)!=null?_c:!0,view=(_f=(_e=this._permissionService.getPermissionPoint((_d=new RangeProtectionPermissionViewPoint(unitId,subUnitId,rule.permissionId))==null?void 0:_d.id))==null?void 0:_e.value)!=null?_f:!0,selectionProtection={[P.Edit]:edit,[P.View]:view,ruleId:rule.id,ranges:rule.ranges};rule.ranges.forEach(range=>{const{startRow,endRow,startColumn,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)cellRuleMap.set(`${i}-${j}`,rule.id),cellInfoMap.set(`${i}-${j}`,selectionProtection)}),this._permissionIdCache.set(rule.permissionId,rule.id)})}getCellInfo(unitId,subUnitId,row,col){var _a21,_b,_c,_d,_e,_f,_g,_h;const cellMap=this._ensureCellInfoMap(unitId,subUnitId),cacheValue=cellMap.get(`${row}-${col}`);if(cacheValue)return cacheValue;let view=!0,edit=!0;const ruleId=(_b=(_a21=this._cellRuleCache.get(unitId))==null?void 0:_a21.get(subUnitId))==null?void 0:_b.get(`${row}-${col}`);if(!ruleId)return;const rule=this._ruleModel.getRule(unitId,subUnitId,ruleId);if(rule){view=(_e=(_d=this._permissionService.getPermissionPoint((_c=new RangeProtectionPermissionViewPoint(unitId,subUnitId,rule.permissionId))==null?void 0:_c.id))==null?void 0:_d.value)!=null?_e:!0,edit=(_h=(_g=this._permissionService.getPermissionPoint((_f=new RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId))==null?void 0:_f.id))==null?void 0:_g.value)!=null?_h:!0;const selectionProtection={[P.Edit]:edit,[P.View]:view,ruleId,ranges:rule.ranges};return cellMap.set(`${row}-${col}`,selectionProtection),selectionProtection}}deleteUnit(unitId){this._cellRuleCache.delete(unitId),this._cellInfoCache.delete(unitId);const workbook=this._univerInstanceService.getUnit(unitId);workbook==null||workbook.getSheets().forEach(sheet=>{const subUnitId=sheet.getSheetId();this._ruleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{this._permissionIdCache.delete(rule.permissionId)})})}},__name(_a14,"RangeProtectionCache"),_a14);exports.RangeProtectionCache=__decorateClass$6([__decorateParam$6(0,core.Inject(exports.RangeProtectionRuleModel)),__decorateParam$6(1,core.Inject(core.IPermissionService)),__decorateParam$6(2,core.Inject(core.IUniverInstanceService))],exports.RangeProtectionCache);const getAllRangePermissionPoint=__name(()=>[RangeProtectionPermissionViewPoint,RangeProtectionPermissionEditPoint],"getAllRangePermissionPoint"),getDefaultRangePermission=__name((unitId="unitId",subUnitId="subUnitId",permissionId="permissionId")=>getAllRangePermissionPoint().reduce((r,F)=>{const i=new F(unitId,subUnitId,permissionId);return r[i.subType]=i.value,r},{}),"getDefaultRangePermission");var __defProp$5=Object.defineProperty,__getOwnPropDesc$5=Object.getOwnPropertyDescriptor,__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"),_a15;exports.RangeProtectionRenderModel=(_a15=class{constructor(_selectionProtectionRuleModel,_permissionService){__publicField(this,"_cache",new core.LRUMap(1e4));this._selectionProtectionRuleModel=_selectionProtectionRuleModel,this._permissionService=_permissionService,this._init()}_init(){this._permissionService.permissionPointUpdate$.pipe(operators.filter(permission=>permission.type===M.SelectRange),operators.filter(permission=>getAllRangePermissionPoint().some(F=>permission instanceof F)),operators.map(permission=>permission)).subscribe(permission=>{const ruleMap=this._selectionProtectionRuleModel.getSubunitRuleList(permission.unitId,permission.subUnitId);for(const rule of ruleMap)rule.permissionId===permission.permissionId&&rule.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const key=this._createKey(permission.unitId,permission.subUnitId,row,col);this._cache.delete(key)})})}),this._selectionProtectionRuleModel.ruleChange$.subscribe(info=>{var _a21;info.rule.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const key=this._createKey(info.unitId,info.subUnitId,row,col);this._cache.delete(key)})}),info.type==="set"&&((_a21=info.oldRule)==null||_a21.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const key=this._createKey(info.unitId,info.subUnitId,row,col);this._cache.delete(key)})}))})}_createKey(unitId,subUnitId,row,col){return`${unitId}_${subUnitId}_${row}_${col}`}getCellInfo(unitId,subUnitId,row,col){const ruleMap=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId),defaultV=[];if(!ruleMap||!ruleMap.length)return defaultV;const key=this._createKey(unitId,subUnitId,row,col),cacheValue=this._cache.get(key);if(cacheValue)return cacheValue;const result=[];for(const rule of ruleMap)if(rule.ranges.some(range=>range.startRow<=row&&range.endRow>=row&&range.startColumn<=col&&range.endColumn>=col)){const permissionMap=getAllRangePermissionPoint().reduce((result2,F)=>{var _a21;const instance=new F(unitId,subUnitId,rule.permissionId),permission=this._permissionService.getPermissionPoint(instance.id);return result2[instance.subType]=(_a21=permission==null?void 0:permission.value)!=null?_a21:instance.value,result2},{});result.push({...permissionMap,ruleId:rule.id,ranges:rule.ranges})}return this._cache.set(key,result),result}clear(){this._cache.clear()}},__name(_a15,"RangeProtectionRenderModel"),_a15);exports.RangeProtectionRenderModel=__decorateClass$5([core.OnLifecycle(core.LifecycleStages.Ready,exports.RangeProtectionRenderModel),__decorateParam$5(0,core.Inject(exports.RangeProtectionRuleModel)),__decorateParam$5(1,core.Inject(core.IPermissionService))],exports.RangeProtectionRenderModel);const IExclusiveRangeService=core.createIdentifier("univer.exclusive-range-service"),_ExclusiveRangeService=class _ExclusiveRangeService extends core.Disposable{constructor(){super(...arguments);__publicField(this,"_exclusiveRanges",new Map)}_ensureUnitMap(unitId){return this._exclusiveRanges.has(unitId)||this._exclusiveRanges.set(unitId,new Map),this._exclusiveRanges.get(unitId)}_ensureSubunitMap(unitId,sheetId){const unitMap=this._ensureUnitMap(unitId);return unitMap.has(sheetId)||unitMap.set(sheetId,new Map),unitMap.get(sheetId)}_ensureFeature(unitId,sheetId,feature){const subunitMap=this._ensureSubunitMap(unitId,sheetId);return subunitMap.has(feature)||subunitMap.set(feature,[]),subunitMap.get(feature)}addExclusiveRange(unitId,sheetId,feature,ranges){this._ensureFeature(unitId,sheetId,feature).push(...ranges)}getExclusiveRanges(unitId,sheetId,feature){var _a21,_b;return(_b=(_a21=this._exclusiveRanges.get(unitId))==null?void 0:_a21.get(sheetId))==null?void 0:_b.get(feature)}clearExclusiveRanges(unitId,sheetId,feature){this._ensureFeature(unitId,sheetId,feature),this._exclusiveRanges.get(unitId).get(sheetId).set(feature,[])}clearExclusiveRangesByGroupId(unitId,sheetId,feature,groupId){const featureMap=this.getExclusiveRanges(unitId,sheetId,feature);if(featureMap){const newFeatureMap=featureMap.filter(item=>item.groupId!==groupId);this._exclusiveRanges.get(unitId).get(sheetId).set(feature,newFeatureMap)}}getInterestGroupId(selections){const interestGroupId=[];return selections.forEach(selection=>{var _a21;const range=selection.range,{unitId,sheetId}=range;if(!unitId||!sheetId)return;const featureMap=(_a21=this._exclusiveRanges.get(unitId))==null?void 0:_a21.get(sheetId);if(featureMap)for(const feature of featureMap.keys()){const featureMapRanges=featureMap.get(feature);if(featureMapRanges){for(const featureMapRange of featureMapRanges)if(core.Rectangle.intersects(range,featureMapRange.range)){interestGroupId.push(feature);break}}}}),interestGroupId}};__name(_ExclusiveRangeService,"ExclusiveRangeService");let ExclusiveRangeService=_ExclusiveRangeService;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"),_a16;exports.NumfmtService=(_a16=class extends core.Disposable{constructor(_resourceManagerService,_univerInstanceService,_logService){super(),this._resourceManagerService=_resourceManagerService,this._univerInstanceService=_univerInstanceService,this._logService=_logService}getValue(unitId,subUnitId,row,col){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!worksheet)return;const styles=workbook.getStyles(),cell=worksheet.getCellRaw(row,col);if(cell!=null&&cell.s){const style=styles.get(cell.s);if(style!=null&&style.n)return style.n}return null}deleteValues(unitId,subUnitId,values){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!worksheet)return;const styles=workbook.getStyles();values.forEach(range=>{core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCellRaw(row,col);if(!cell)return;const oldStyleId=cell==null?void 0:cell.s,newStyle={...oldStyleId&&styles.get(oldStyleId)||{}};delete newStyle.n;const newStyleId=styles.setValue(newStyle);cell.s=newStyleId})})}setValues(unitId,subUnitId,values){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!worksheet)return;const styles=workbook.getStyles(),matrix=worksheet.getCellMatrix();values.forEach(value=>{value.ranges.forEach(range=>{core.Range.foreach(range,(row,col)=>{const cell=worksheet.getCellRaw(row,col);if(cell){const newStyle={...styles.getStyleByCell(cell)||{},n:{pattern:value.pattern}},styleId=styles.setValue(newStyle);cell.s=styleId;const type=getCellTypeByPattern(cell,value.pattern);cell.v!==void 0&&(cell.t=type,cell.v=getCellValue(type,cell))}else{const style={n:{pattern:value.pattern}},styleId=styles.setValue(style);styleId&&matrix.setValue(row,col,{s:styleId})}})})})}},__name(_a16,"NumfmtService"),_a16);exports.NumfmtService=__decorateClass$4([__decorateParam$4(0,core.IResourceManagerService),__decorateParam$4(1,core.IUniverInstanceService),__decorateParam$4(2,core.ILogService)],exports.NumfmtService);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");const mutationIdByRowCol=[InsertColMutation.id,InsertRowMutation.id,RemoveColMutation.id,RemoveRowMutation.id],mutationIdArrByMove=[MoveRowsMutation.id,MoveColsMutation.id];var _a17;exports.RangeProtectionRefRangeService=(_a17=class extends core.Disposable{constructor(_selectionProtectionRuleModel,_univerInstanceService,_commandService,_refRangeService,_selectionProtectionRenderModel,_rangeProtectionCache){super();__publicField(this,"disposableCollection",new core.DisposableCollection);this._selectionProtectionRuleModel=_selectionProtectionRuleModel,this._univerInstanceService=_univerInstanceService,this._commandService=_commandService,this._refRangeService=_refRangeService,this._selectionProtectionRenderModel=_selectionProtectionRenderModel,this._rangeProtectionCache=_rangeProtectionCache,this._onRefRangeChange(),this._correctPermissionRange(),this._initReBuildCache()}_onRefRangeChange(){const registerRefRange=__name((unitId,subUnitId)=>{const workbook2=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook2||!(workbook2==null?void 0:workbook2.getSheetBySheetId(subUnitId)))return;this.disposableCollection.dispose();const handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p,c)=>[...p,...c.ranges],[]).forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))})},"registerRefRange");this.disposeWithMe(this._commandService.onCommandExecuted(commandInfo=>{if(commandInfo.id===SetWorksheetActivateCommand.id){const params=commandInfo.params,sheetId=params.subUnitId,unitId=params.unitId;if(!sheetId||!unitId)return;registerRefRange(unitId,sheetId)}if(commandInfo.id===SetRangeProtectionMutation.id||commandInfo.id===AddRangeProtectionMutation.id){const params=commandInfo.params,subUnitId=params.subUnitId,unitId=params.unitId;if(!subUnitId||!unitId)return;registerRefRange(unitId,subUnitId)}}));const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(workbook){const sheet=workbook.getActiveSheet();if(!sheet)return;registerRefRange(workbook.getUnitId(),sheet.getSheetId())}}refRangeHandle(config,unitId,subUnitId){switch(config.id){case MoveRowsCommand.id:return this._getRefRangeMutationsByMoveRows(config.params,unitId,subUnitId);case MoveColsCommand.id:return this._getRefRangeMutationsByMoveCols(config.params,unitId,subUnitId);case InsertRowCommand.id:return this._getRefRangeMutationsByInsertRows(config.params,unitId,subUnitId);case InsertColCommand.id:return this._getRefRangeMutationsByInsertCols(config.params,unitId,subUnitId);case RemoveColCommand.id:return this._getRefRangeMutationsByDeleteCols(config.params,unitId,subUnitId);case RemoveRowCommand.id:return this._getRefRangeMutationsByDeleteRows(config.params,unitId,subUnitId)}return{redos:[],undos:[]}}_getRefRangeMutationsByDeleteCols(params,unitId,subUnitId){const permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>core.Rectangle.intersects(range,params.range))),removeRange=params.range;if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),rangesByRemove=cloneRule.ranges.reduce((p,c)=>{if(core.Rectangle.intersects(c,removeRange)){const cloneRange=core.Tools.deepClone(c),{startColumn,endColumn}=removeRange;if(startColumn<=cloneRange.startColumn&&endColumn>=cloneRange.endColumn)return p;startColumn>=cloneRange.startColumn&&endColumn<=cloneRange.endColumn?cloneRange.endColumn-=endColumn-startColumn+1:startColumn<cloneRange.startColumn?(cloneRange.startColumn=startColumn,cloneRange.endColumn-=endColumn-startColumn+1):endColumn>cloneRange.endColumn&&(cloneRange.endColumn=startColumn-1),this._checkIsRightRange(cloneRange)&&p.push(cloneRange)}return p},[]);cloneRule.ranges=rangesByRemove,cloneRule.ranges.length?(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}})):(redoMutations.push({id:DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:[rule.id]}}),undoMutations.push({id:AddRangeProtectionMutation.id,params:{unitId,subUnitId,name:"",rules:[rule]}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByDeleteRows(params,unitId,subUnitId){const permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>core.Rectangle.intersects(range,params.range))),removeRange=params.range;if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),rangesByRemove=cloneRule.ranges.reduce((p,c)=>{if(core.Rectangle.intersects(c,removeRange)){const cloneRange=core.Tools.deepClone(c),{startRow,endRow}=removeRange;if(startRow<=cloneRange.startRow&&endRow>=cloneRange.endRow)return p;startRow>=cloneRange.startRow&&endRow<=cloneRange.endRow?cloneRange.endRow-=endRow-startRow+1:startRow<cloneRange.startRow?(cloneRange.startRow=startRow,cloneRange.endRow-=endRow-startRow+1):endRow>cloneRange.endRow&&(cloneRange.endRow=startRow-1),this._checkIsRightRange(cloneRange)&&p.push(cloneRange)}return p},[]);cloneRule.ranges=rangesByRemove,redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}})}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByInsertCols(params,unitId,subUnitId){const insertStart=params.range.startColumn,insertLength=params.range.endColumn-params.range.startColumn+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>insertStart>range.startColumn&&insertStart<=range.endColumn));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule);let hasLap=!1;cloneRule.ranges.forEach(range=>{insertStart>range.startColumn&&insertStart<=range.endColumn&&(range.endColumn+=insertLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByInsertRows(params,unitId,subUnitId){const insertStart=params.range.startRow,insertLength=params.range.endRow-params.range.startRow+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>insertStart>range.startRow&&insertStart<=range.endRow));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule);let hasLap=!1;cloneRule.ranges.forEach(range=>{insertStart>range.startRow&&insertStart<=range.endRow&&(range.endRow+=insertLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByMoveRows(params,unitId,subUnitId){const toRange=params.toRange,moveToStartRow=toRange.startRow,moveLength=toRange.endRow-toRange.startRow+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>moveToStartRow>range.startRow&&moveToStartRow<=range.endRow));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),moveFromStartRow=params.fromRange.startRow;let hasLap=!1;cloneRule.ranges.forEach(range=>{moveToStartRow>range.startRow&&moveToStartRow<=range.endRow&&(moveFromStartRow<range.startRow&&(range.startRow=range.startRow-moveLength,range.endRow=range.endRow-moveLength),range.endRow+=moveLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_getRefRangeMutationsByMoveCols(params,unitId,subUnitId){const toRange=params.toRange,moveToStartCol=toRange.startColumn,moveLength=toRange.endColumn-toRange.startColumn+1,permissionRangeLapRules=this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(range=>moveToStartCol>range.startColumn&&moveToStartCol<=range.endColumn));if(permissionRangeLapRules.length){const redoMutations=[],undoMutations=[];return permissionRangeLapRules.forEach(rule=>{const cloneRule=core.Tools.deepClone(rule),moveFromStartCol=params.fromRange.startColumn;let hasLap=!1;cloneRule.ranges.forEach(range=>{moveToStartCol>range.startColumn&&moveToStartCol<=range.endColumn&&(moveFromStartCol<range.startColumn&&(range.startColumn=range.startColumn-moveLength,range.endColumn=range.endColumn-moveLength),range.endColumn+=moveLength,hasLap=!0)}),hasLap&&(redoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule:cloneRule,ruleId:rule.id}}),undoMutations.push({id:SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}))}),{redos:redoMutations,undos:undoMutations}}return{undos:[],redos:[]}}_correctPermissionRange(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(mutationIdArrByMove.includes(command.id)){if(!command.params)return;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const{sourceRange,targetRange}=command.params,isRowMove=sourceRange.startColumn===targetRange.startColumn&&sourceRange.endColumn===targetRange.endColumn,moveLength=isRowMove?sourceRange.endRow-sourceRange.startRow+1:sourceRange.endColumn-sourceRange.startColumn+1,sourceStart=isRowMove?sourceRange.startRow:sourceRange.startColumn,targetStart=isRowMove?targetRange.startRow:targetRange.startColumn;this._selectionProtectionRuleModel.getSubunitRuleList(workbook.getUnitId(),worksheet.getSheetId()).forEach(rule=>{rule.ranges.forEach(range=>{let{startRow,endRow,startColumn,endColumn}=range;core.Rectangle.intersects(range,sourceRange)||(isRowMove?sourceStart<startRow&&targetStart>endRow?(startRow-=moveLength,endRow-=moveLength):sourceStart>endRow&&targetStart<=startRow&&(startRow+=moveLength,endRow+=moveLength):sourceStart<startColumn&&targetStart>endColumn?(startColumn-=moveLength,endColumn-=moveLength):sourceStart>endColumn&&targetStart<=startColumn&&(startColumn+=moveLength,endColumn+=moveLength)),this._checkIsRightRange({startRow,endRow,startColumn,endColumn})&&(range.startColumn=startColumn,range.endColumn=endColumn,range.startRow=startRow,range.endRow=endRow)})}),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p,c)=>[...p,...c.ranges],[]).forEach(range=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range,handler,unitId,subUnitId))}),this._selectionProtectionRenderModel.clear()}if(mutationIdByRowCol.includes(command.id)){const workbook=this._univerInstanceService.getUniverSheetInstance(command.params.unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(command.params.subUnitId);if(!worksheet)return;const params=command.params;if(!params)return;const{range}=params,isRowOperation=command.id.includes("row"),isAddOperation=command.id.includes("insert"),operationStart=isRowOperation?range.startRow:range.startColumn,operationEnd=isRowOperation?range.endRow:range.endColumn,operationCount=operationEnd-operationStart+1;this._selectionProtectionRuleModel.getSubunitRuleList(workbook.getUnitId(),worksheet.getSheetId()).forEach(rule=>{rule.ranges.forEach(range2=>{let{startRow,endRow,startColumn,endColumn}=range2;isAddOperation?isRowOperation?operationStart<=startRow&&(startRow+=operationCount,endRow+=operationCount):operationStart<=startColumn&&(startColumn+=operationCount,endColumn+=operationCount):isRowOperation?operationEnd<startRow&&(startRow-=operationCount,endRow-=operationCount):operationEnd<startColumn&&(startColumn-=operationCount,endColumn-=operationCount),this._checkIsRightRange({startRow,endRow,startColumn,endColumn})&&(range2.startColumn=startColumn,range2.endColumn=endColumn,range2.startRow=startRow,range2.endRow=endRow)})}),this.disposableCollection.dispose();const{unitId,subUnitId}=command.params,handler=__name(config=>this.refRangeHandle(config,unitId,subUnitId),"handler");this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).reduce((p,c)=>[...p,...c.ranges],[]).forEach(range2=>{this.disposableCollection.add(this._refRangeService.registerRefRange(range2,handler,unitId,subUnitId))}),this._selectionProtectionRenderModel.clear()}}))}_checkIsRightRange(range){return range.startRow<=range.endRow&&range.startColumn<=range.endColumn}_initReBuildCache(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(mutationIdByRowCol.includes(command.id)||mutationIdArrByMove.includes(command.id)){const{unitId,subUnitId}=command.params;this._rangeProtectionCache.reBuildCache(unitId,subUnitId)}}))}},__name(_a17,"RangeProtectionRefRangeService"),_a17);exports.RangeProtectionRefRangeService=__decorateClass$3([core.OnLifecycle(core.LifecycleStages.Ready,exports.RangeProtectionRefRangeService),__decorateParam$3(0,core.Inject(exports.RangeProtectionRuleModel)),__decorateParam$3(1,core.Inject(core.IUniverInstanceService)),__decorateParam$3(2,core.ICommandService),__decorateParam$3(3,core.Inject(exports.RefRangeService)),__decorateParam$3(4,core.Inject(exports.RangeProtectionRenderModel)),__decorateParam$3(5,core.Inject(exports.RangeProtectionCache))],exports.RangeProtectionRefRangeService);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");const PLUGIN_NAME$1="SHEET_RANGE_PROTECTION_PLUGIN";var _a18;exports.RangeProtectionService=(_a18=class extends core.Disposable{constructor(_selectionProtectionRuleModel,_permissionService,_resourceManagerService,_selectionProtectionCache){super(),this._selectionProtectionRuleModel=_selectionProtectionRuleModel,this._permissionService=_permissionService,this._resourceManagerService=_resourceManagerService,this._selectionProtectionCache=_selectionProtectionCache,this._initSnapshot(),this._initRuleChange()}_initRuleChange(){this.disposeWithMe(this._selectionProtectionRuleModel.ruleChange$.subscribe(info=>{switch(info.type){case"add":{getAllRangePermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId,info.rule.permissionId);this._permissionService.addPermissionPoint(instance)});break}case"delete":{getAllRangePermissionPoint().forEach(F=>{const instance=new F(info.unitId,info.subUnitId,info.rule.permissionId);this._permissionService.deletePermissionPoint(instance.id)});break}case"set":{info.oldRule.permissionId!==info.rule.permissionId&&getAllRangePermissionPoint().forEach(F=>{const oldPermissionPoint=new F(info.unitId,info.subUnitId,info.oldRule.permissionId);this._permissionService.deletePermissionPoint(oldPermissionPoint.id);const newPermissionPoint=new F(info.unitId,info.subUnitId,info.rule.permissionId);this._permissionService.addPermissionPoint(newPermissionPoint)});break}}}))}_initSnapshot(){const toJson=__name(unitID=>{const v=this._selectionProtectionRuleModel.toObject()[unitID];return v?JSON.stringify(v):""},"toJson"),parseJson=__name(json=>{if(!json)return{};try{return JSON.parse(json)}catch{return{}}},"parseJson");this.disposeWithMe(this._resourceManagerService.registerPluginResource({toJson,parseJson,pluginName:PLUGIN_NAME$1,businesses:[I.UNIVER_SHEET],onLoad:__name((unitId,resources)=>{const result=this._selectionProtectionRuleModel.toObject();result[unitId]=resources,this._selectionProtectionRuleModel.fromObject(result);const allAllowedParams=[];Object.keys(resources).forEach(subUnitId=>{const list=resources[subUnitId];this._selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{allAllowedParams.push({objectID:rule.permissionId,unitID:unitId,objectType:M.SelectRange,actions:[P.View,P.Edit]})}),list.forEach(rule=>{getAllRangePermissionPoint().forEach(Factor=>{const instance=new Factor(unitId,subUnitId,rule.permissionId);instance.value=!1,this._permissionService.addPermissionPoint(instance)})})})},"onLoad"),onUnLoad:__name(unitId=>{this._selectionProtectionRuleModel.deleteUnitModel(unitId),this._selectionProtectionCache.deleteUnit(unitId)},"onUnLoad")}))}},__name(_a18,"RangeProtectionService"),_a18);exports.RangeProtectionService=__decorateClass$2([__decorateParam$2(0,core.Inject(exports.RangeProtectionRuleModel)),__decorateParam$2(1,core.Inject(core.IPermissionService)),__decorateParam$2(2,core.Inject(core.IResourceManagerService)),__decorateParam$2(3,core.Inject(exports.RangeProtectionCache))],exports.RangeProtectionService);const getAllWorkbookPermissionPoint=__name(()=>[WorkbookEditablePermission,WorkbookPrintPermission,WorkbookCommentPermission,WorkbookViewPermission,WorkbookCopyPermission,WorkbookExportPermission,WorkbookManageCollaboratorPermission,WorkbookCreateSheetPermission,WorkbookDeleteSheetPermission,WorkbookRenameSheetPermission,WorkbookHideSheetPermission,WorkbookDuplicatePermission,WorkbookSharePermission,WorkbookMoveSheetPermission,WorkbookCopySheetPermission,WorkbookViewHistoryPermission,WorkbookRecoverHistoryPermission],"getAllWorkbookPermissionPoint"),defaultWorkbookPermissionPoints=[P.Edit,P.Print,P.Comment,P.View,P.Copy,P.Export,P.ManageCollaborator,P.CreateSheet,P.DeleteSheet,P.RenameSheet,P.HideSheet,P.Duplicate,P.Share,P.MoveSheet,P.CopySheet,P.RecoverHistory,P.ViewHistory];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"),_a19;exports.WorkbookPermissionService=(_a19=class extends core.Disposable{constructor(_permissionService,_univerInstanceService,_rangeProtectionRuleModel){super(),this._permissionService=_permissionService,this._univerInstanceService=_univerInstanceService,this._rangeProtectionRuleModel=_rangeProtectionRuleModel,this._init()}_init(){const handleWorkbook=__name(workbook=>{const unitId=workbook.getUnitId();getAllWorkbookPermissionPoint().forEach(F=>{const instance=new F(unitId);this._permissionService.addPermissionPoint(instance)})},"handleWorkbook");this._univerInstanceService.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>{handleWorkbook(workbook)}),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{handleWorkbook(workbook)})),this.disposeWithMe(this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{const unitId=workbook.getUnitId();workbook.getSheets().forEach(worksheet=>{const subUnitId=worksheet.getSheetId();this._rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).forEach(rule=>{[RangeProtectionPermissionEditPoint,RangeProtectionPermissionViewPoint].forEach(F=>{const instance=new F(unitId,subUnitId,rule.permissionId);this._permissionService.deletePermissionPoint(instance.id)})}),[...getAllWorksheetPermissionPoint(),...getAllWorksheetPermissionPointByPointPanel()].forEach(F=>{const instance=new F(unitId,subUnitId);this._permissionService.deletePermissionPoint(instance.id)})}),getAllWorkbookPermissionPoint().forEach(F=>{const instance=new F(unitId);this._permissionService.deletePermissionPoint(instance.id)})}))}},__name(_a19,"WorkbookPermissionService"),_a19);exports.WorkbookPermissionService=__decorateClass$1([core.OnLifecycle(core.LifecycleStages.Starting,exports.WorkbookPermissionService),__decorateParam$1(0,core.Inject(core.IPermissionService)),__decorateParam$1(1,core.Inject(core.IUniverInstanceService)),__decorateParam$1(2,core.Inject(exports.RangeProtectionRuleModel))],exports.WorkbookPermissionService);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");const PLUGIN_NAME="SHEET_PLUGIN";var _a20;exports.UniverSheetsPlugin=(_a20=class extends core.Plugin{constructor(_config=defaultPluginConfig,_injector,_configService){super(),this._config=_config,this._injector=_injector,this._configService=_configService;const{...rest}=this._config;this._configService.setConfig(PLUGIN_CONFIG_KEY,rest),this._initConfig(),this._initDependencies()}_initConfig(){var _a21;(_a21=this._config)!=null&&_a21.onlyRegisterFormulaRelatedMutations&&this._configService.setConfig(ONLY_REGISTER_FORMULA_RELATED_MUTATIONS_KEY,!0)}_initDependencies(){var _a21,_b;const dependencies=[[BorderStyleManagerService],[exports.SheetsSelectionsService],[exports.RefRangeService],[exports.WorkbookPermissionService],[INumfmtService,{useClass:exports.NumfmtService}],[exports.SheetInterceptorService],[BasicWorksheetController],[exports.MergeCellController],[NumberCellDisplayController],[exports.DefinedNameDataController],[exports.WorksheetPermissionService],[exports.WorksheetProtectionRuleModel],[exports.WorksheetProtectionPointModel],[exports.RangeProtectionRenderModel],[exports.RangeProtectionRuleModel],[exports.RangeProtectionCache],[exports.RangeProtectionRefRangeService],[exports.RangeProtectionService],[IExclusiveRangeService,{useClass:ExclusiveRangeService,deps:[exports.SheetsSelectionsService]}]];(_a21=this._config)!=null&&_a21.notExecuteFormula||dependencies.push([CalculateResultApplyController]),core.mergeOverrideWithDependencies(dependencies,(_b=this._config)==null?void 0:_b.override).forEach(d=>{this._injector.add(d)}),this._injector.get(exports.SheetInterceptorService),this._injector.get(exports.RangeProtectionService),this._injector.get(IExclusiveRangeService)}onStarting(_injector){this._injector.get(exports.MergeCellController)}},__name(_a20,"UniverSheetsPlugin"),_a20);__publicField2(exports.UniverSheetsPlugin,"pluginName",PLUGIN_NAME);__publicField2(exports.UniverSheetsPlugin,"type",core.UniverInstanceType.UNIVER_SHEET);exports.UniverSheetsPlugin=__decorateClass([core.DependentOn(engineFormula.UniverFormulaEnginePlugin),__decorateParam(1,core.Inject(core.Injector)),__decorateParam(2,core.IConfigService)],exports.UniverSheetsPlugin);const COMMAND_LISTENER_SKELETON_CHANGE=[SetWorksheetRowHeightMutation.id,SetWorksheetRowIsAutoHeightMutation.id,SetWorksheetRowAutoHeightMutation.id,SetWorksheetColWidthMutation.id,SetWorksheetActiveOperation.id,MoveRowsMutation.id,MoveColsMutation.id,SetColHiddenMutation.id,SetColVisibleMutation.id,SetRowHiddenMutation.id,SetRowVisibleMutation.id,InsertColMutation.id,InsertRowMutation.id,RemoveColMutation.id,RemoveRowMutation.id],COMMAND_LISTENER_VALUE_CHANGE=[SetRangeValuesMutation.id,MoveRangeMutation.id,RemoveWorksheetMergeMutation.id,AddWorksheetMergeMutation.id,ReorderRangeMutation.id],SELECTION_CONTROL_BORDER_BUFFER_WIDTH=1.5,SELECTION_CONTROL_BORDER_BUFFER_COLOR="rgba(255, 255, 255, 0.01)";function getNormalSelectionStyle(themeService){const styleSheet=themeService.getCurrentTheme(),fill=new core.ColorKit(styleSheet.primaryColor).setAlpha(.07).toRgbString();return{strokeWidth:1,stroke:styleSheet.primaryColor,fill,widgets:{},widgetSize:6,widgetStrokeWidth:1,widgetStroke:styleSheet.colorWhite,hasAutoFill:!0,AutofillSize:6,AutofillStrokeWidth:1,AutofillStroke:styleSheet.colorWhite,hasRowHeader:!0,rowHeaderFill:fill,rowHeaderStroke:styleSheet.primaryColor,rowHeaderStrokeWidth:1,hasColumnHeader:!0,columnHeaderFill:fill,columnHeaderStroke:styleSheet.primaryColor,columnHeaderStrokeWidth:1,expandCornerSize:40}}__name(getNormalSelectionStyle,"getNormalSelectionStyle");function convertSelectionDataToRange(selectionWithCoordAndStyle){const{rangeWithCoord,primaryWithCoord,style}=selectionWithCoordAndStyle,result={range:{startRow:rangeWithCoord.startRow,startColumn:rangeWithCoord.startColumn,endRow:rangeWithCoord.endRow,endColumn:rangeWithCoord.endColumn,rangeType:rangeWithCoord.rangeType,unitId:rangeWithCoord.unitId,sheetId:rangeWithCoord.sheetId},primary:null,style};return primaryWithCoord!=null&&(result.primary=convertPrimaryWithCoordToPrimary(primaryWithCoord)),result}__name(convertSelectionDataToRange,"convertSelectionDataToRange");function convertPrimaryWithCoordToPrimary(primaryWithCoord){const{actualRow,actualColumn,isMerged,isMergedMainCell}=primaryWithCoord,{startRow,startColumn,endRow,endColumn}=primaryWithCoord.mergeInfo;return{actualRow,actualColumn,isMerged,isMergedMainCell,startRow,startColumn,endRow,endColumn}}__name(convertPrimaryWithCoordToPrimary,"convertPrimaryWithCoordToPrimary");function transformCellDataToSelectionData(row,column,mergeData){const newCellRange=core.getCellInfoInMergeData(row,column,mergeData),newSelectionData=core.makeCellRangeToRangeData(newCellRange);if(newSelectionData)return{range:newSelectionData,primary:newCellRange,style:null}}__name(transformCellDataToSelectionData,"transformCellDataToSelectionData");const AddMergeRedoSelectionsOperationFactory=__name((accessor,params,ranges)=>{const selectionsBeforeMutation=accessor.get(exports.SheetsSelectionsService).getCurrentSelections(),{value,selections,unitId,subUnitId}=params;if(selectionsBeforeMutation){const primaryBeforeMutation=selectionsBeforeMutation[(selectionsBeforeMutation==null?void 0:selectionsBeforeMutation.length)-1].primary;if(primaryBeforeMutation){const{actualColumn,actualRow}=primaryBeforeMutation;let{startRow,startColumn,endRow,endColumn}=selections[selections.length-1];if(value===core.Dimension.COLUMNS){const rangeByColumn=ranges.find(item=>item.startColumn===actualColumn&&item.endColumn===actualColumn&&actualRow===item.startRow);rangeByColumn&&(endColumn=rangeByColumn.endColumn,startRow=rangeByColumn.startRow,endRow=rangeByColumn.endRow)}else if(value===core.Dimension.ROWS){const rangeByRow=ranges.find(item=>item.startRow===actualRow&&item.endRow===actualRow&&actualColumn===item.startColumn);rangeByRow&&(endRow=rangeByRow.endRow,startColumn=rangeByRow.startColumn,endColumn=rangeByRow.endColumn)}const primary={startRow,startColumn,endRow,endColumn,actualRow,actualColumn,isMerged:!0,isMergedMainCell:startRow===actualRow&&startColumn===actualColumn},selectionsByRedo=selectionsBeforeMutation.map((selection,index,selections2)=>({range:selection.range,style:null,primary:index===selections2.length-1?primary:null})),setSelectionsParamByRedo={unitId,subUnitId,selections:selectionsByRedo};return{id:SetSelectionsOperation.id,params:setSelectionsParamByRedo}}return null}return null},"AddMergeRedoSelectionsOperationFactory"),AddMergeUndoSelectionsOperationFactory=__name((accessor,params)=>{const selectionsBeforeMutation=accessor.get(exports.SheetsSelectionsService).getCurrentSelections(),{unitId,subUnitId}=params;if(selectionsBeforeMutation&&selectionsBeforeMutation[(selectionsBeforeMutation==null?void 0:selectionsBeforeMutation.length)-1].primary){const setSelectionsParamByUndo={unitId,subUnitId,selections:[...selectionsBeforeMutation]};return{id:SetSelectionsOperation.id,params:setSelectionsParamByUndo}}return null},"AddMergeUndoSelectionsOperationFactory");function cellHasValue(cell){return cell==null?!1:cell.v!==void 0&&cell.v!==null&&cell.v!==""||cell.p!==void 0}__name(cellHasValue,"cellHasValue");function hasValueFromMatrixWithSpanInfo(cell,matrix){return cell&&cell.spanAnchor?cellHasValue(matrix.getValue(cell.spanAnchor.startRow,cell.spanAnchor.startColumn)):cellHasValue(cell)}__name(hasValueFromMatrixWithSpanInfo,"hasValueFromMatrixWithSpanInfo");function getMatrixWithSpanInfo(worksheet,startRow,startColumn,endRow,endColumn){const matrix=worksheet.getCellMatrix(),mergedCellsInRange=worksheet.getSpanModel().getMergedCellRange(startRow,startColumn,endRow,endColumn),returnCellMatrix=new core.ObjectMatrix;return matrix.forValue((row,col)=>{const v=matrix.getValue(row,col);v&&returnCellMatrix.setValue(row,col,v)}),mergedCellsInRange.forEach(mergedCell=>{const{startColumn:startColumn2,startRow:startRow2,endColumn:endColumn2,endRow:endRow2}=mergedCell;core.createRowColIter(startRow2,endRow2,startColumn2,endColumn2).forEach((row,col)=>{row===startRow2&&col===startColumn2&&returnCellMatrix.setValue(row,col,{...matrix.getValue(row,col),spanAnchor:{startRow:startRow2,endRow:endRow2,startColumn:startColumn2,endColumn:endColumn2}}),(row!==startRow2||col!==startColumn2)&&(returnCellMatrix.realDeleteValue(row,col),returnCellMatrix.setValue(row,col,{spanAnchor:{startRow:startRow2,endRow:endRow2,startColumn:startColumn2,endColumn:endColumn2}}))})}),returnCellMatrix}__name(getMatrixWithSpanInfo,"getMatrixWithSpanInfo");function getExpandedRangeLeft(range,allMatrixWithSpan,leftOffset,isWorksheetHasSpan){const{startRow,startColumn,endRow}=range;let spanAnchor=null,hasValue=!1;for(let i=startRow;i<=endRow;i++){const cell=allMatrixWithSpan.getValue(i,startColumn-leftOffset);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.startColumn=range.startColumn-leftOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeLeft,"getExpandedRangeLeft");function getExpandedRangeRight(range,allMatrixWithSpan,rightOffset,isWorksheetHasSpan){const{startRow,endColumn,endRow}=range;let spanAnchor=null,hasValue=!1;for(let i=startRow;i<=endRow;i++){const cell=allMatrixWithSpan.getValue(i,endColumn+rightOffset);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.endColumn=range.endColumn+rightOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeRight,"getExpandedRangeRight");function getExpandedRangeUp(range,allMatrixWithSpan,upOffset,isWorksheetHasSpan){const{startRow,startColumn,endColumn}=range;let spanAnchor=null,hasValue=!1;for(let i=startColumn;i<=endColumn;i++){const cell=allMatrixWithSpan.getValue(startRow-upOffset,i);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.startRow=range.startRow-upOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeUp,"getExpandedRangeUp");function getExpandedRangeDown(range,allMatrixWithSpan,downOffset,isWorksheetHasSpan){const{startColumn,endColumn,endRow}=range;let spanAnchor=null,hasValue=!1;for(let i=startColumn;i<=endColumn;i++){const cell=allMatrixWithSpan.getValue(endRow+downOffset,i);if(hasValue=hasValue||hasValueFromMatrixWithSpanInfo(cell,allMatrixWithSpan),!isWorksheetHasSpan&&hasValue)break;cell&&cell.spanAnchor&&(spanAnchor?spanAnchor={startRow:Math.min(cell.spanAnchor.startRow,spanAnchor.startRow),startColumn:Math.min(cell.spanAnchor.startColumn,spanAnchor.startColumn),endRow:Math.max(cell.spanAnchor.endRow,spanAnchor.endRow),endColumn:Math.max(cell.spanAnchor.endColumn,spanAnchor.endColumn)}:spanAnchor={startRow:cell.spanAnchor.startRow,startColumn:cell.spanAnchor.startColumn,endRow:cell.spanAnchor.endRow,endColumn:cell.spanAnchor.endColumn})}return hasValue?(range.endRow=range.endRow+downOffset,{spanAnchor,hasValue:!0,range}):{spanAnchor:null,hasValue:!1,range}}__name(getExpandedRangeDown,"getExpandedRangeDown");function expandToContinuousRange(startRange,directions,worksheet){const maxRow=worksheet.getMaxRows(),maxColumn=worksheet.getMaxColumns(),allMatrixWithSpan=getMatrixWithSpanInfo(worksheet,0,0,maxRow-1,maxColumn-1),worksheetHasSpan=worksheet.getSnapshot().mergeData.length>0,{left,right,up,down}=directions;let changed=!0,destRange={...startRange};const spanAnchors=[];for(;changed;){if(changed=!1,up&&destRange.startRow!==0){const{hasValue,range,spanAnchor}=getExpandedRangeUp(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}if(down&&destRange.endRow!==maxRow-1){const{hasValue,range,spanAnchor}=getExpandedRangeDown(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}if(left&&destRange.startColumn!==0){const{hasValue,range,spanAnchor}=getExpandedRangeLeft(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}if(right&&destRange.endColumn!==maxColumn-1){const{hasValue,range,spanAnchor}=getExpandedRangeRight(destRange,allMatrixWithSpan,1,worksheetHasSpan);if(spanAnchor&&spanAnchors.push(spanAnchor),hasValue){destRange=range,changed=!0;continue}}}return spanAnchors.length>0&&(destRange=core.Rectangle.union(destRange,...spanAnchors)),destRange}__name(expandToContinuousRange,"expandToContinuousRange");const checkRangesEditablePermission=__name((accessor,unitId,subUnitId,ranges)=>{const permissionService=accessor.get(core.IPermissionService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),workbookEditablePermission=permissionService.getPermissionPoint(new sheets.WorkbookEditablePermission(unitId).id);if(!(workbookEditablePermission!=null&&workbookEditablePermission.value))return!1;const worksheetEditPermission=permissionService.getPermissionPoint(new sheets.WorksheetEditPermission(unitId,subUnitId).id);if(!(worksheetEditPermission!=null&&worksheetEditPermission.value))return!1;const ruleList=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>ranges.some(range=>core.Rectangle.intersects(ruleRange,range))));return ruleList.length?ruleList.every(rule=>{const permissionId=rule.permissionId,permissionPoint=permissionService.getPermissionPoint(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,permissionId).id);return!!(permissionPoint!=null&&permissionPoint.value)}):!0},"checkRangesEditablePermission");function checkCellContentInRanges(worksheet,ranges){return ranges.some(range=>checkCellContentInRange(worksheet,range))}__name(checkCellContentInRanges,"checkCellContentInRanges");function checkCellContentInRange(worksheet,range){const{startRow,startColumn,endColumn,endRow}=range,cellMatrix=worksheet.getMatrixWithMergedCells(startRow,startColumn,endRow,endColumn);let someCellGoingToBeRemoved=!1;return cellMatrix.forValue((row,col,cellData)=>{if(cellData&&(row!==startRow||col!==startColumn)&&worksheet.cellHasValue(cellData))return someCellGoingToBeRemoved=!0,!1}),someCellGoingToBeRemoved}__name(checkCellContentInRange,"checkCellContentInRange");function getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges){const undos=[],redos=[],subUnitId=worksheet.getSheetId();return ranges.forEach(range=>{const redoMatrix=getClearContentMutationParamForRange(worksheet,range),redoMutationParams={unitId,subUnitId,cellValue:redoMatrix.getData()},undoMutationParams=SetRangeValuesUndoMutationFactory(accessor,redoMutationParams);undos.push({id:SetRangeValuesMutation.id,params:undoMutationParams}),redos.push({id:SetRangeValuesMutation.id,params:redoMutationParams})}),{undos,redos}}__name(getClearContentMutationParamsForRanges,"getClearContentMutationParamsForRanges");function getClearContentMutationParamForRange(worksheet,range){const{startRow,startColumn,endColumn,endRow}=range,cellMatrix=worksheet.getMatrixWithMergedCells(startRow,startColumn,endRow,endColumn,!0),redoMatrix=new core.ObjectMatrix;return cellMatrix.forValue((row,col,cellData)=>{cellData&&(row!==startRow||col!==startColumn)&&redoMatrix.setValue(row,col,null)}),redoMatrix}__name(getClearContentMutationParamForRange,"getClearContentMutationParamForRange");const AddWorksheetMergeCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),unitId=params.unitId,subUnitId=params.subUnitId,selections=params.selections,ranges=getAddMergeMutationRangeByType(selections,params.value),worksheet=univerInstanceService.getUniverSheetInstance(unitId).getSheetBySheetId(subUnitId),redoMutations=[],undoMutations=[],willRemoveSomeCell=checkCellContentInRanges(worksheet,ranges),removeMergeMutationParams={unitId,subUnitId,ranges},addMergeMutationParams={unitId,subUnitId,ranges};redoMutations.push({id:RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}),redoMutations.push({id:AddWorksheetMergeMutation.id,params:addMergeMutationParams});const undoRemoveMergeMutationParams=RemoveMergeUndoMutationFactory(accessor,removeMergeMutationParams),undoMutationParams=AddMergeUndoMutationFactory(accessor,addMergeMutationParams);if(undoMutations.push({id:RemoveWorksheetMergeMutation.id,params:undoMutationParams}),undoMutations.push({id:AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),willRemoveSomeCell){const data=getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges);redoMutations.unshift(...data.redos),undoMutations.push(...data.undos)}return core.sequenceExecute(redoMutations,commandService).result?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations,redoMutations}),!0):!1},"handler")},AddWorksheetMergeAllCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-all",handler:__name(async accessor=>{var _a21;const commandService=accessor.get(core.ICommandService),selections=(_a21=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const workSheet=workbook.getActiveSheet();if(!workSheet)return!1;const unitId=workbook.getUnitId(),subUnitId=workSheet.getSheetId();return commandService.executeCommand(AddWorksheetMergeCommand.id,{selections,unitId,subUnitId})},"handler")},AddWorksheetMergeVerticalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-vertical",handler:__name(async accessor=>{var _a21;const commandService=accessor.get(core.ICommandService),selections=(_a21=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const workSheet=workbook.getActiveSheet();if(!workSheet)return!1;const unitId=workbook.getUnitId(),subUnitId=workSheet.getSheetId();return commandService.executeCommand(AddWorksheetMergeCommand.id,{value:core.Dimension.COLUMNS,selections,unitId,subUnitId})},"handler")},AddWorksheetMergeHorizontalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-horizontal",handler:__name(async accessor=>{var _a21;const commandService=accessor.get(core.ICommandService),selections=(_a21=accessor.get(exports.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a21.map(s=>s.range);if(!(selections!=null&&selections.length))return!1;const workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return!1;const workSheet=workbook.getActiveSheet();if(!workSheet)return!1;const unitId=workbook.getUnitId(),subUnitId=workSheet.getSheetId();return commandService.executeCommand(AddWorksheetMergeCommand.id,{value:core.Dimension.ROWS,selections,unitId,subUnitId})},"handler")};async function addMergeCellsUtil(injector,unitId,subUnitId,ranges){const univerInstanceService=injector.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService,{unitId,subUnitId});if(!target)return;const{worksheet}=target;if(worksheet.getMergeData().some(mergeRange=>ranges.some(range=>core.Rectangle.intersects(range,mergeRange))))throw new Error("The ranges to be merged overlap with the existing merged cells");await injector.get(core.ICommandService).executeCommand(AddWorksheetMergeCommand.id,{unitId,subUnitId,selections:ranges})}__name(addMergeCellsUtil,"addMergeCellsUtil");const SetHideGridlinesUndoMutationFactory=__name((accessor,params)=>{const oldStatus=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId).getSheetBySheetId(params.subUnitId).getConfig().showGridlines;return{...core.Tools.deepClone(params),hideGridlines:oldStatus}},"SetHideGridlinesUndoMutationFactory"),SetHideGridlinesMutation={id:"sheet.mutation.set-hide-gridlines",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const config=worksheet.getConfig();return config.showGridlines=params.hideGridlines,!0},"handler")},SetHideGridlinesCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-hide-gridlines",handler:__name(async(accessor,params)=>{var _a21;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target;let hideGridlines=core.BooleanNumber.FALSE;params&&(hideGridlines=(_a21=params.hideGridlines)!=null?_a21:core.BooleanNumber.FALSE);const workbook=univerInstanceService.getUniverSheetInstance(unitId);if(!workbook||!workbook.getSheetBySheetId(subUnitId))return!1;const setHideGridlinesMutationParams={hideGridlines,unitId,subUnitId},undoMutationParams=SetHideGridlinesUndoMutationFactory(accessor,setHideGridlinesMutationParams);return commandService.syncExecuteCommand(SetHideGridlinesMutation.id,setHideGridlinesMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetHideGridlinesMutation.id,params:undoMutationParams}],redoMutations:[{id:SetHideGridlinesMutation.id,params:setHideGridlinesMutationParams}]}),!0):!1},"handler")},SetWorksheetRightToLeftUndoMutationFactory=__name((accessor,params)=>{const oldState=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId).getSheetBySheetId(params.subUnitId).getConfig().rightToLeft;return{...core.Tools.deepClone(params),rightToLeft:oldState}},"SetWorksheetRightToLeftUndoMutationFactory"),SetWorksheetRightToLeftMutation={id:"sheet.mutation.set-worksheet-right-to-left",type:core.CommandType.MUTATION,handler:__name((accessor,params)=>{const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(params.unitId);if(!workbook)return!1;const worksheet=workbook.getSheetBySheetId(params.subUnitId);if(!worksheet)return!1;const config=worksheet.getConfig();return config.rightToLeft=params.rightToLeft,!0},"handler")},SetWorksheetRightToLeftCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-right-to-left",handler:__name(async(accessor,params)=>{var _a21;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=getSheetCommandTarget(accessor.get(core.IUniverInstanceService),params);if(!target)return!1;const{unitId,subUnitId}=target;let rightToLeft=core.BooleanNumber.FALSE;params&&(rightToLeft=(_a21=params.rightToLeft)!=null?_a21:core.BooleanNumber.FALSE);const setWorksheetRightToLeftMutationParams={rightToLeft,unitId,subUnitId},undoMutationParams=SetWorksheetRightToLeftUndoMutationFactory(accessor,setWorksheetRightToLeftMutationParams);return commandService.syncExecuteCommand(SetWorksheetRightToLeftMutation.id,setWorksheetRightToLeftMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:SetWorksheetRightToLeftMutation.id,params:undoMutationParams}],redoMutations:[{id:SetWorksheetRightToLeftMutation.id,params:setWorksheetRightToLeftMutationParams}]}),!0):!1},"handler")};exports.AddMergeRedoSelectionsOperationFactory=AddMergeRedoSelectionsOperationFactory;exports.AddMergeUndoMutationFactory=AddMergeUndoMutationFactory;exports.AddMergeUndoSelectionsOperationFactory=AddMergeUndoSelectionsOperationFactory;exports.AddRangeProtectionCommand=AddRangeProtectionCommand;exports.AddRangeProtectionMutation=AddRangeProtectionMutation;exports.AddWorksheetMergeAllCommand=AddWorksheetMergeAllCommand;exports.AddWorksheetMergeCommand=AddWorksheetMergeCommand;exports.AddWorksheetMergeHorizontalCommand=AddWorksheetMergeHorizontalCommand;exports.AddWorksheetMergeMutation=AddWorksheetMergeMutation;exports.AddWorksheetMergeVerticalCommand=AddWorksheetMergeVerticalCommand;exports.AddWorksheetProtectionMutation=AddWorksheetProtectionMutation;exports.BorderStyleManagerService=BorderStyleManagerService;exports.COMMAND_LISTENER_SKELETON_CHANGE=COMMAND_LISTENER_SKELETON_CHANGE;exports.COMMAND_LISTENER_VALUE_CHANGE=COMMAND_LISTENER_VALUE_CHANGE;exports.ClearSelectionAllCommand=ClearSelectionAllCommand;exports.ClearSelectionContentCommand=ClearSelectionContentCommand;exports.ClearSelectionFormatCommand=ClearSelectionFormatCommand;exports.CopySheetCommand=CopySheetCommand;exports.DISABLE_NORMAL_SELECTIONS=DISABLE_NORMAL_SELECTIONS;exports.DeleteRangeMoveLeftCommand=DeleteRangeMoveLeftCommand;exports.DeleteRangeMoveUpCommand=DeleteRangeMoveUpCommand;exports.DeleteRangeProtectionCommand=DeleteRangeProtectionCommand;exports.DeleteRangeProtectionMutation=DeleteRangeProtectionMutation;exports.DeleteWorksheetProtectionMutation=DeleteWorksheetProtectionMutation;exports.DeltaColumnWidthCommand=DeltaColumnWidthCommand;exports.DeltaRowHeightCommand=DeltaRowHeightCommand;exports.EffectRefRangId=EffectRefRangId;exports.EmptyMutation=EmptyMutation;exports.ExclusiveRangeService=ExclusiveRangeService;exports.FactoryAddRangeProtectionMutation=FactoryAddRangeProtectionMutation;exports.FactoryDeleteRangeProtectionMutation=FactoryDeleteRangeProtectionMutation;exports.FactorySetRangeProtectionMutation=FactorySetRangeProtectionMutation;exports.IExclusiveRangeService=IExclusiveRangeService;exports.INTERCEPTOR_POINT=INTERCEPTOR_POINT;exports.INumfmtService=INumfmtService;exports.IRefSelectionsService=IRefSelectionsService;exports.InsertColAfterCommand=InsertColAfterCommand;exports.InsertColBeforeCommand=InsertColBeforeCommand;exports.InsertColCommand=InsertColCommand;exports.InsertColMutation=InsertColMutation;exports.InsertColMutationUndoFactory=InsertColMutationUndoFactory;exports.InsertDefinedNameCommand=InsertDefinedNameCommand;exports.InsertRangeMoveDownCommand=InsertRangeMoveDownCommand;exports.InsertRangeMoveRightCommand=InsertRangeMoveRightCommand;exports.InsertRowAfterCommand=InsertRowAfterCommand;exports.InsertRowBeforeCommand=InsertRowBeforeCommand;exports.InsertRowCommand=InsertRowCommand;exports.InsertRowMutation=InsertRowMutation;exports.InsertRowMutationUndoFactory=InsertRowMutationUndoFactory;exports.InsertSheetCommand=InsertSheetCommand;exports.InsertSheetMutation=InsertSheetMutation;exports.InsertSheetUndoMutationFactory=InsertSheetUndoMutationFactory;exports.InterceptCellContentPriority=InterceptCellContentPriority;exports.MAX_CELL_PER_SHEET_KEY=MAX_CELL_PER_SHEET_KEY;exports.MERGE_CELL_INTERCEPTOR_CHECK=MERGE_CELL_INTERCEPTOR_CHECK;exports.MoveColsCommand=MoveColsCommand;exports.MoveColsMutation=MoveColsMutation;exports.MoveColsMutationUndoFactory=MoveColsMutationUndoFactory;exports.MoveRangeCommand=MoveRangeCommand;exports.MoveRangeMutation=MoveRangeMutation;exports.MoveRowsCommand=MoveRowsCommand;exports.MoveRowsMutation=MoveRowsMutation;exports.MoveRowsMutationUndoFactory=MoveRowsMutationUndoFactory;exports.OperatorType=OperatorType;exports.RangeMergeUtil=RangeMergeUtil;exports.RangeProtectionPermissionEditPoint=RangeProtectionPermissionEditPoint;exports.RangeProtectionPermissionViewPoint=RangeProtectionPermissionViewPoint;exports.RemoveColCommand=RemoveColCommand;exports.RemoveColMutation=RemoveColMutation;exports.RemoveDefinedNameCommand=RemoveDefinedNameCommand;exports.RemoveMergeUndoMutationFactory=RemoveMergeUndoMutationFactory;exports.RemoveNumfmtMutation=RemoveNumfmtMutation;exports.RemoveRowCommand=RemoveRowCommand;exports.RemoveRowMutation=RemoveRowMutation;exports.RemoveSheetCommand=RemoveSheetCommand;exports.RemoveSheetMutation=RemoveSheetMutation;exports.RemoveSheetUndoMutationFactory=RemoveSheetUndoMutationFactory;exports.RemoveWorksheetMergeCommand=RemoveWorksheetMergeCommand;exports.RemoveWorksheetMergeMutation=RemoveWorksheetMergeMutation;exports.ReorderRangeCommand=ReorderRangeCommand;exports.ReorderRangeMutation=ReorderRangeMutation;exports.ReorderRangeUndoMutationFactory=ReorderRangeUndoMutationFactory;exports.ResetBackgroundColorCommand=ResetBackgroundColorCommand;exports.ResetTextColorCommand=ResetTextColorCommand;exports.SELECTION_CONTROL_BORDER_BUFFER_COLOR=SELECTION_CONTROL_BORDER_BUFFER_COLOR;exports.SELECTION_CONTROL_BORDER_BUFFER_WIDTH=SELECTION_CONTROL_BORDER_BUFFER_WIDTH;exports.ScrollToCellOperation=ScrollToCellOperation;exports.SelectionMoveType=SelectionMoveType;exports.SetBackgroundColorCommand=SetBackgroundColorCommand;exports.SetBoldCommand=SetBoldCommand;exports.SetBorderBasicCommand=SetBorderBasicCommand;exports.SetBorderColorCommand=SetBorderColorCommand;exports.SetBorderCommand=SetBorderCommand;exports.SetBorderPositionCommand=SetBorderPositionCommand;exports.SetBorderStyleCommand=SetBorderStyleCommand;exports.SetColHiddenCommand=SetColHiddenCommand;exports.SetColHiddenMutation=SetColHiddenMutation;exports.SetColVisibleMutation=SetColVisibleMutation;exports.SetColWidthCommand=SetColWidthCommand;exports.SetDefinedNameCommand=SetDefinedNameCommand;exports.SetFontFamilyCommand=SetFontFamilyCommand;exports.SetFontSizeCommand=SetFontSizeCommand;exports.SetFrozenCancelCommand=SetFrozenCancelCommand;exports.SetFrozenCommand=SetFrozenCommand;exports.SetFrozenMutation=SetFrozenMutation;exports.SetFrozenMutationFactory=SetFrozenMutationFactory;exports.SetHideGridlinesCommand=SetHideGridlinesCommand;exports.SetHideGridlinesMutation=SetHideGridlinesMutation;exports.SetHorizontalTextAlignCommand=SetHorizontalTextAlignCommand;exports.SetItalicCommand=SetItalicCommand;exports.SetNumfmtMutation=SetNumfmtMutation;exports.SetOverlineCommand=SetOverlineCommand;exports.SetRangeProtectionCommand=SetRangeProtectionCommand;exports.SetRangeProtectionMutation=SetRangeProtectionMutation;exports.SetRangeValuesCommand=SetRangeValuesCommand;exports.SetRangeValuesMutation=SetRangeValuesMutation;exports.SetRangeValuesUndoMutationFactory=SetRangeValuesUndoMutationFactory;exports.SetRowHeightCommand=SetRowHeightCommand;exports.SetRowHiddenCommand=SetRowHiddenCommand;exports.SetRowHiddenMutation=SetRowHiddenMutation;exports.SetRowVisibleMutation=SetRowVisibleMutation;exports.SetSelectedColsVisibleCommand=SetSelectedColsVisibleCommand;exports.SetSelectedRowsVisibleCommand=SetSelectedRowsVisibleCommand;exports.SetSelectionsOperation=SetSelectionsOperation;exports.SetSpecificColsVisibleCommand=SetSpecificColsVisibleCommand;exports.SetSpecificRowsVisibleCommand=SetSpecificRowsVisibleCommand;exports.SetStrikeThroughCommand=SetStrikeThroughCommand;exports.SetStyleCommand=SetStyleCommand;exports.SetTabColorCommand=SetTabColorCommand;exports.SetTabColorMutation=SetTabColorMutation;exports.SetTextColorCommand=SetTextColorCommand;exports.SetTextRotationCommand=SetTextRotationCommand;exports.SetTextWrapCommand=SetTextWrapCommand;exports.SetUnderlineCommand=SetUnderlineCommand;exports.SetVerticalTextAlignCommand=SetVerticalTextAlignCommand;exports.SetWorkbookNameCommand=SetWorkbookNameCommand;exports.SetWorkbookNameMutation=SetWorkbookNameMutation;exports.SetWorksheetActivateCommand=SetWorksheetActivateCommand;exports.SetWorksheetActiveOperation=SetWorksheetActiveOperation;exports.SetWorksheetColWidthMutation=SetWorksheetColWidthMutation;exports.SetWorksheetColWidthMutationFactory=SetWorksheetColWidthMutationFactory;exports.SetWorksheetHideCommand=SetWorksheetHideCommand;exports.SetWorksheetHideMutation=SetWorksheetHideMutation;exports.SetWorksheetNameCommand=SetWorksheetNameCommand;exports.SetWorksheetNameMutation=SetWorksheetNameMutation;exports.SetWorksheetOrderCommand=SetWorksheetOrderCommand;exports.SetWorksheetOrderMutation=SetWorksheetOrderMutation;exports.SetWorksheetPermissionPointsCommand=SetWorksheetPermissionPointsCommand;exports.SetWorksheetPermissionPointsMutation=SetWorksheetPermissionPointsMutation;exports.SetWorksheetProtectionMutation=SetWorksheetProtectionMutation;exports.SetWorksheetRightToLeftCommand=SetWorksheetRightToLeftCommand;exports.SetWorksheetRightToLeftMutation=SetWorksheetRightToLeftMutation;exports.SetWorksheetRowAutoHeightMutation=SetWorksheetRowAutoHeightMutation;exports.SetWorksheetRowAutoHeightMutationFactory=SetWorksheetRowAutoHeightMutationFactory;exports.SetWorksheetRowHeightMutation=SetWorksheetRowHeightMutation;exports.SetWorksheetRowIsAutoHeightCommand=SetWorksheetRowIsAutoHeightCommand;exports.SetWorksheetRowIsAutoHeightMutation=SetWorksheetRowIsAutoHeightMutation;exports.SetWorksheetShowCommand=SetWorksheetShowCommand;exports.UnitAction=P;exports.UnitObject=M;exports.WorkbookCommentPermission=WorkbookCommentPermission;exports.WorkbookCopyPermission=WorkbookCopyPermission;exports.WorkbookCopySheetPermission=WorkbookCopySheetPermission;exports.WorkbookCreateSheetPermission=WorkbookCreateSheetPermission;exports.WorkbookDeleteSheetPermission=WorkbookDeleteSheetPermission;exports.WorkbookDuplicatePermission=WorkbookDuplicatePermission;exports.WorkbookEditablePermission=WorkbookEditablePermission;exports.WorkbookExportPermission=WorkbookExportPermission;exports.WorkbookHideSheetPermission=WorkbookHideSheetPermission;exports.WorkbookHistoryPermission=WorkbookHistoryPermission;exports.WorkbookManageCollaboratorPermission=WorkbookManageCollaboratorPermission;exports.WorkbookMoveSheetPermission=WorkbookMoveSheetPermission;exports.WorkbookPrintPermission=WorkbookPrintPermission;exports.WorkbookRecoverHistoryPermission=WorkbookRecoverHistoryPermission;exports.WorkbookRenameSheetPermission=WorkbookRenameSheetPermission;exports.WorkbookSelections=WorkbookSelections;exports.WorkbookSharePermission=WorkbookSharePermission;exports.WorkbookViewHistoryPermission=WorkbookViewHistoryPermission;exports.WorkbookViewPermission=WorkbookViewPermission;exports.WorksheetCopyPermission=WorksheetCopyPermission;exports.WorksheetDeleteColumnPermission=WorksheetDeleteColumnPermission;exports.WorksheetDeleteRowPermission=WorksheetDeleteRowPermission;exports.WorksheetEditExtraObjectPermission=WorksheetEditExtraObjectPermission;exports.WorksheetEditPermission=WorksheetEditPermission;exports.WorksheetFilterPermission=WorksheetFilterPermission;exports.WorksheetInsertColumnPermission=WorksheetInsertColumnPermission;exports.WorksheetInsertHyperlinkPermission=WorksheetInsertHyperlinkPermission;exports.WorksheetInsertRowPermission=WorksheetInsertRowPermission;exports.WorksheetManageCollaboratorPermission=WorksheetManageCollaboratorPermission;exports.WorksheetPivotTablePermission=WorksheetPivotTablePermission;exports.WorksheetSelectProtectedCellsPermission=WorksheetSelectProtectedCellsPermission;exports.WorksheetSelectUnProtectedCellsPermission=WorksheetSelectUnProtectedCellsPermission;exports.WorksheetSetCellStylePermission=WorksheetSetCellStylePermission;exports.WorksheetSetCellValuePermission=WorksheetSetCellValuePermission;exports.WorksheetSetColumnStylePermission=WorksheetSetColumnStylePermission;exports.WorksheetSetRowStylePermission=WorksheetSetRowStylePermission;exports.WorksheetSortPermission=WorksheetSortPermission;exports.WorksheetViewPermission=WorksheetViewPermission;exports.addMergeCellsUtil=addMergeCellsUtil;exports.alignToMergedCellsBorders=alignToMergedCellsBorders;exports.checkRangesEditablePermission=checkRangesEditablePermission;exports.convertPrimaryWithCoordToPrimary=convertPrimaryWithCoordToPrimary;exports.convertSelectionDataToRange=convertSelectionDataToRange;exports.copyRangeStyles=copyRangeStyles;exports.createTopMatrixFromMatrix=createTopMatrixFromMatrix;exports.createTopMatrixFromRanges=createTopMatrixFromRanges;exports.defaultWorkbookPermissionPoints=defaultWorkbookPermissionPoints;exports.defaultWorksheetPermissionPoint=defaultWorksheetPermissionPoint;exports.expandToContinuousRange=expandToContinuousRange;exports.factoryRemoveNumfmtUndoMutation=factoryRemoveNumfmtUndoMutation;exports.factorySetNumfmtUndoMutation=factorySetNumfmtUndoMutation;exports.findAllRectangle=findAllRectangle;exports.followSelectionOperation=followSelectionOperation;exports.generateNullCell=generateNullCell;exports.generateNullCellValue=generateNullCellValue;exports.getAddMergeMutationRangeByType=getAddMergeMutationRangeByType;exports.getAllRangePermissionPoint=getAllRangePermissionPoint;exports.getAllWorkbookPermissionPoint=getAllWorkbookPermissionPoint;exports.getAllWorksheetPermissionPoint=getAllWorksheetPermissionPoint;exports.getAllWorksheetPermissionPointByPointPanel=getAllWorksheetPermissionPointByPointPanel;exports.getCellAtRowCol=getCellAtRowCol;exports.getDefaultRangePermission=getDefaultRangePermission;exports.getInsertRangeMutations=getInsertRangeMutations;exports.getMoveRangeUndoRedoMutations=getMoveRangeUndoRedoMutations;exports.getNormalSelectionStyle=getNormalSelectionStyle;exports.getPrimaryForRange=getPrimaryForRange;exports.getRemoveRangeMutations=getRemoveRangeMutations;exports.getSelectionsService=getSelectionsService;exports.getSheetCommandTarget=getSheetCommandTarget;exports.getSheetCommandTargetWorkbook=getSheetCommandTargetWorkbook;exports.getSheetMutationTarget=getSheetMutationTarget;exports.handleBaseInsertRange=handleBaseInsertRange;exports.handleBaseMoveRowsCols=handleBaseMoveRowsCols;exports.handleBaseRemoveRange=handleBaseRemoveRange;exports.handleCommonDefaultRangeChangeWithEffectRefCommands=handleCommonDefaultRangeChangeWithEffectRefCommands;exports.handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests=handleCommonRangeChangeWithEffectRefCommandsSkipNoInterests;exports.handleDefaultRangeChangeWithEffectRefCommands=handleDefaultRangeChangeWithEffectRefCommands;exports.handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests=handleDefaultRangeChangeWithEffectRefCommandsSkipNoInterests;exports.handleDeleteRangeMoveLeft=handleDeleteRangeMoveLeft;exports.handleDeleteRangeMoveUp=handleDeleteRangeMoveUp;exports.handleDeleteRangeMutation=handleDeleteRangeMutation;exports.handleIRemoveCol=handleIRemoveCol;exports.handleIRemoveRow=handleIRemoveRow;exports.handleInsertCol=handleInsertCol;exports.handleInsertRangeMoveDown=handleInsertRangeMoveDown;exports.handleInsertRangeMoveRight=handleInsertRangeMoveRight;exports.handleInsertRangeMutation=handleInsertRangeMutation;exports.handleInsertRow=handleInsertRow;exports.handleMoveCols=handleMoveCols;exports.handleMoveRange=handleMoveRange;exports.handleMoveRows=handleMoveRows;exports.isSingleCellSelection=isSingleCellSelection;exports.rangeMerge=rangeMerge;exports.rotateRange=rotateRange;exports.runRefRangeMutations=runRefRangeMutations;exports.setEndForRange=setEndForRange;exports.transformCellDataToSelectionData=transformCellDataToSelectionData;exports.transformCellsToRange=transformCellsToRange;
|