@univerjs/sheets-ui 0.4.0-alpha.1 → 0.4.0-nightly.202410131605

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/cjs/index.js CHANGED
@@ -1,4 +1,4 @@
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 docsUi=require("@univerjs/docs-ui"),core=require("@univerjs/core"),engineRender=require("@univerjs/engine-render"),sheets=require("@univerjs/sheets"),rxjs=require("rxjs"),ui=require("@univerjs/ui"),docs=require("@univerjs/docs"),React=require("react"),design=require("@univerjs/design"),engineFormula=require("@univerjs/engine-formula"),operators=require("rxjs/operators"),telemetry=require("@univerjs/telemetry");var SheetsUIPart=(SheetsUIPart2=>(SheetsUIPart2.FILTER_PANEL_EMBED_POINT="filter-panel-embed-point",SheetsUIPart2.SHEETS_FOOTER="sheets-footer",SheetsUIPart2))(SheetsUIPart||{});const SHEET_UI_PLUGIN_NAME="SheetUI";function getEditorObject(unitId,renderManagerService){if(unitId==null)return;const currentRender=renderManagerService.getRenderById(unitId);if(currentRender==null)return;const{mainComponent,scene,engine,components}=currentRender,document2=mainComponent,docBackground=components.get(docsUi.DOCS_VIEW_KEY.BACKGROUND);return{document:document2,docBackground,scene,engine}}__name(getEditorObject,"getEditorObject");var __defProp$S=Object.defineProperty,__getOwnPropDesc$S=Object.getOwnPropertyDescriptor,__decorateClass$S=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$S(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$S(target,key,result),result},"__decorateClass$S"),__decorateParam$S=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$S"),_a;exports.SheetSkeletonManagerService=(_a=class extends core.Disposable{constructor(_context,_injector){super();__publicField(this,"_currentSkeletonSearchParam",{sheetId:""});__publicField(this,"_sheetSkeletonParam",[]);__publicField(this,"_currentSkeleton$",new rxjs.BehaviorSubject(null));__publicField(this,"currentSkeleton$",this._currentSkeleton$.asObservable());__publicField(this,"_currentSkeletonBefore$",new rxjs.BehaviorSubject(null));__publicField(this,"currentSkeletonBefore$",this._currentSkeletonBefore$.asObservable());this._context=_context,this._injector=_injector,this.disposeWithMe(()=>{this._currentSkeletonBefore$.complete(),this._currentSkeleton$.complete(),this._sheetSkeletonParam=[]}),this._initRemoveSheet()}_initRemoveSheet(){this.disposeWithMe(this._context.unit.sheetDisposed$.subscribe(sheet=>{this.disposeSkeleton({sheetId:sheet.getSheetId()})}))}getCurrentSkeleton(){var _a58;return(_a58=this.getCurrent())==null?void 0:_a58.skeleton}getCurrent(){return this._getSkeleton(this._currentSkeletonSearchParam)}getWorksheetSkeleton(sheetId){return this._getSkeleton({sheetId})}getUnitSkeleton(unitId,sheetId){const param=this._getSkeleton({sheetId});return param!=null&&(param.unitId=unitId),param}setCurrent(searchParam){this._setCurrent(searchParam)}_setCurrent(searchParam){const param=this._getSkeleton(searchParam),unitId=this._context.unitId;if(param!=null)this._reCalculate(param);else{const{sheetId:sheetId2}=searchParam,worksheet=this._context.unit.getSheetBySheetId(searchParam.sheetId);if(worksheet==null)return;const skeleton=this._buildSkeleton(worksheet);this._sheetSkeletonParam.push({unitId,sheetId:sheetId2,skeleton,dirty:!1})}this._currentSkeletonSearchParam=searchParam;const sheetId=this._currentSkeletonSearchParam.sheetId,sheetSkeletonManagerParam=this.getUnitSkeleton(unitId,sheetId);this._currentSkeletonBefore$.next(sheetSkeletonManagerParam),this._currentSkeleton$.next(sheetSkeletonManagerParam)}reCalculate(){const param=this.getCurrent();param!=null&&this._reCalculate(param)}_reCalculate(param){param.dirty&&(param.skeleton.makeDirty(!0),param.dirty=!1),param.skeleton.calculate()}makeDirty(searchParm,state=!0){const param=this._getSkeleton(searchParm);param!=null&&(param.dirty=state)}getOrCreateSkeleton(searchParam){const skeleton=this._getSkeleton(searchParam);if(skeleton)return skeleton.skeleton;const worksheet=this._context.unit.getSheetBySheetId(searchParam.sheetId);if(!worksheet)return;const newSkeleton=this._buildSkeleton(worksheet);return this._sheetSkeletonParam.push({unitId:this._context.unitId,sheetId:searchParam.sheetId,skeleton:newSkeleton,dirty:!1}),newSkeleton}disposeSkeleton(searchParm){const index=this._sheetSkeletonParam.findIndex(param=>param.sheetId===searchParm.sheetId);index>-1&&(this._sheetSkeletonParam[index].skeleton.dispose(),this._sheetSkeletonParam.splice(index,1))}attachRangeWithCoord(range){const skeleton=this.getCurrentSkeleton();return skeleton?attachRangeWithCoord(skeleton,range):null}_getSkeleton(searchParm){const item=this._sheetSkeletonParam.find(param=>param.sheetId===searchParm.sheetId);return item!=null&&(item.commandId=searchParm.commandId),item}_buildSkeleton(worksheet){const config=worksheet.getConfig();return this._injector.createInstance(engineRender.SpreadsheetSkeleton,worksheet,config,worksheet.getCellMatrix(),this._context.unit.getStyles())}},__name(_a,"SheetSkeletonManagerService"),_a);exports.SheetSkeletonManagerService=__decorateClass$S([__decorateParam$S(1,core.Inject(core.Injector))],exports.SheetSkeletonManagerService);function attachRangeWithCoord(skeleton,range){const{startRow,startColumn,endRow,endColumn,rangeType}=range,_startRow=endRow<startRow?endRow:startRow,_endRow=endRow<startRow?startRow:endRow,_startColumn=endColumn<startColumn?endColumn:startColumn,_endColumn=endColumn<startColumn?startColumn:endColumn,startCell=skeleton.getNoMergeCellPositionByIndex(_startRow,_startColumn),endCell=skeleton.getNoMergeCellPositionByIndex(_endRow,_endColumn);return{startRow,startColumn,endRow,endColumn,rangeType,startY:(startCell==null?void 0:startCell.startY)||0,endY:(endCell==null?void 0:endCell.endY)||0,startX:(startCell==null?void 0:startCell.startX)||0,endX:(endCell==null?void 0:endCell.endX)||0}}__name(attachRangeWithCoord,"attachRangeWithCoord");var __defProp$R=Object.defineProperty,__getOwnPropDesc$R=Object.getOwnPropertyDescriptor,__decorateClass$R=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$R(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$R(target,key,result),result},"__decorateClass$R"),__decorateParam$R=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$R"),_a2;let SheetScrollManagerService=(_a2=class{constructor(_context,_sheetSkeletonManagerService){__publicField(this,"_scrollStateMap",new Map);__publicField(this,"_rawscrollInfo$",new rxjs.BehaviorSubject(null));__publicField(this,"rawScrollInfo$",this._rawscrollInfo$.asObservable());__publicField(this,"validViewportScrollInfo$",new rxjs.BehaviorSubject(null));__publicField(this,"_searchParamForScroll",null);this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService}dispose(){this._rawscrollInfo$.complete()}setSearchParam(param){this._searchParamForScroll=param}setSearchParamAndRefresh(param){this._searchParamForScroll=param,this._scrollStateNext(param)}getScrollStateByParam(param){return this._getCurrentScroll(param)}getCurrentScrollState(){return this._getCurrentScroll(this._searchParamForScroll)}setScrollInfoAndEmitEvent(param){this._setScrollState(param),this._scrollStateNext(param)}setScrollStateToCurrSheetAndEmitEvent(scrollInfo){this._searchParamForScroll!=null&&(this._setScrollState({...this._searchParamForScroll,...scrollInfo}),this._scrollStateNext(this._searchParamForScroll))}setScrollStateToCurrSheet(scroll){this._searchParamForScroll!=null&&this._setScrollState({...this._searchParamForScroll,...scroll})}clear(){this._searchParamForScroll!=null&&this._clearByParamAndNotify(this._searchParamForScroll)}calcViewportScrollFromRowColOffset(scrollInfo){if(!scrollInfo)return{viewportScrollX:0,viewportScrollY:0};let{sheetViewStartColumn,sheetViewStartRow,offsetX,offsetY}=scrollInfo;sheetViewStartRow=sheetViewStartRow||0,offsetY=offsetY||0;const skeleton=this._sheetSkeletonManagerService.getCurrentSkeleton(),rowAcc=(skeleton==null?void 0:skeleton.rowHeightAccumulation[sheetViewStartRow-1])||0,viewportScrollX=((skeleton==null?void 0:skeleton.columnWidthAccumulation[sheetViewStartColumn-1])||0)+offsetX,viewportScrollY=rowAcc+offsetY;return{viewportScrollX,viewportScrollY}}_setScrollState(scrollInfo){const{unitId,sheetId,sheetViewStartColumn,sheetViewStartRow,offsetX,offsetY}=scrollInfo;this._scrollStateMap.has(unitId)||this._scrollStateMap.set(unitId,new Map);const worksheetScrollInfoMap=this._scrollStateMap.get(unitId),newScrollInfo={sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY};worksheetScrollInfoMap.set(sheetId,newScrollInfo)}_clearByParamAndNotify(param){this._setScrollState({...param,sheetViewStartRow:0,sheetViewStartColumn:0,offsetX:0,offsetY:0}),this._scrollStateNext(param)}_getCurrentScroll(param){var _a58;if(param==null)return;const{unitId,sheetId}=param;return(_a58=this._scrollStateMap.get(unitId))==null?void 0:_a58.get(sheetId)}_scrollStateNext(param){const scrollInfo=this._getCurrentScroll(param);this._rawscrollInfo$.next(scrollInfo)}},__name(_a2,"SheetScrollManagerService"),_a2);SheetScrollManagerService=__decorateClass$R([__decorateParam$R(1,core.Inject(exports.SheetSkeletonManagerService))],SheetScrollManagerService);const SetScrollOperation={id:"sheet.operation.set-scroll",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{if(!params)return!1;const{unitId,sheetId,offsetX,offsetY,sheetViewStartColumn,sheetViewStartRow}=params,currentService=accessor.get(core.IUniverInstanceService),renderManagerService=accessor.get(engineRender.IRenderManagerService),worksheet=currentService.getUniverSheetInstance(unitId).getSheetBySheetId(sheetId),scrollManagerService=renderManagerService.getRenderById(unitId).with(SheetScrollManagerService),{xSplit,ySplit}=worksheet.getConfig().freeze;return scrollManagerService.setScrollInfoAndEmitEvent({unitId,sheetId,offsetX,offsetY,sheetViewStartRow:sheetViewStartRow-ySplit,sheetViewStartColumn:sheetViewStartColumn-xSplit}),!0},"handler")},SetScrollRelativeCommand={id:"sheet.command.set-scroll-relative",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),renderManagerSrv=accessor.get(engineRender.IRenderManagerService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,{xSplit,ySplit}=worksheet.getConfig().freeze,currentScroll=renderManagerSrv.getRenderById(unitId).with(SheetScrollManagerService).getCurrentScrollState(),{offsetX=0,offsetY=0}=params||{},{sheetViewStartRow=0,sheetViewStartColumn=0,offsetX:currentOffsetX=0,offsetY:currentOffsetY=0}=currentScroll||{};return commandService.executeCommand(SetScrollOperation.id,{unitId,sheetId:subUnitId,sheetViewStartRow:sheetViewStartRow+ySplit,sheetViewStartColumn:sheetViewStartColumn+xSplit,offsetX:currentOffsetX+offsetX,offsetY:currentOffsetY+offsetY})},"handler")},ScrollCommand={id:"sheet.command.scroll-view",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{if(!params)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),renderManagerSrv=accessor.get(engineRender.IRenderManagerService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,unitId}=target,currentScroll=renderManagerSrv.getRenderById(unitId).with(SheetScrollManagerService).getCurrentScrollState();if(!worksheet)return!1;const{sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY}=params,{sheetViewStartColumn:currentColumn,sheetViewStartRow:currentRow,offsetX:currentOffsetX,offsetY:currentOffsetY}=currentScroll||{},{xSplit,ySplit}=worksheet.getConfig().freeze;return accessor.get(core.ICommandService).syncExecuteCommand(SetScrollOperation.id,{unitId:workbook.getUnitId(),sheetId:worksheet.getSheetId(),sheetViewStartRow:sheetViewStartRow!=null?sheetViewStartRow:(currentRow!=null?currentRow:0)+ySplit,sheetViewStartColumn:sheetViewStartColumn!=null?sheetViewStartColumn:(currentColumn!=null?currentColumn:0)+xSplit,offsetX:offsetX!=null?offsetX:currentOffsetX,offsetY:offsetY!=null?offsetY:currentOffsetY})},"handler")},ScrollToCellCommand={id:"sheet.command.scroll-to-cell",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const instanceService=accessor.get(core.IUniverInstanceService);return accessor.get(engineRender.IRenderManagerService).getRenderById(instanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).with(exports.SheetsScrollRenderController).scrollToRange(params.range)},"handler")},ResetScrollCommand={id:"sheet.command.scroll-view-reset",type:core.CommandType.COMMAND,handler:__name(async accessor=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{subUnitId,unitId}=target;return accessor.get(core.ICommandService).executeCommand(SetScrollOperation.id,{unitId,sheetId:subUnitId,sheetViewStartRow:0,sheetViewStartColumn:0})},"handler")};var __defProp$Q=Object.defineProperty,__getOwnPropDesc$Q=Object.getOwnPropertyDescriptor,__decorateClass$Q=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$Q(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$Q(target,key,result),result},"__decorateClass$Q"),__decorateParam$Q=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$Q"),_a3;let ShortcutExperienceService=(_a3=class{constructor(_univerInstanceService,_localeService){__publicField(this,"_current",null);__publicField(this,"_shortcutParam",[]);this._univerInstanceService=_univerInstanceService,this._localeService=_localeService}dispose(){this._shortcutParam=[]}getCurrentBySearch(searchParm){return this._getCurrentBySearch(searchParm)}getCurrent(){return this._getCurrentBySearch(this._current)}addOrUpdate(insertParam){const param=this._getCurrentBySearch({unitId:insertParam.unitId,sheetId:insertParam.sheetId,keycode:insertParam.keycode});if(param!=null){const index=this._shortcutParam.indexOf(param);this._shortcutParam.splice(index,1)}return this._shortcutParam.push(insertParam),param}remove(searchParm){if(searchParm==null)return;const param=this._getCurrentBySearch(searchParm);if(param==null)return;const index=this._shortcutParam.indexOf(param);return this._shortcutParam.splice(index,1)[0]}_getCurrentBySearch(searchParm){return searchParm==null?void 0:this._shortcutParam.find(param=>param.unitId===searchParm.unitId&&param.sheetId===searchParm.sheetId&&param.keycode===searchParm.keycode)}},__name(_a3,"ShortcutExperienceService"),_a3);ShortcutExperienceService=__decorateClass$Q([__decorateParam$Q(0,core.IUniverInstanceService),__decorateParam$Q(1,core.Inject(core.LocaleService))],ShortcutExperienceService);const _SelectAllService=class _SelectAllService extends core.Disposable{constructor(){super(...arguments);__publicField(this,"rangesStack",[]);__publicField(this,"selectedRangeWorksheet","")}};__name(_SelectAllService,"SelectAllService");let SelectAllService=_SelectAllService;var MergeType=(MergeType2=>(MergeType2.MergeAll="mergeAll",MergeType2.MergeVertical="mergeVertical",MergeType2.MergeHorizontal="mergeHorizontal",MergeType2))(MergeType||{});function findNextRange(startRange,direction,worksheet,boundary,isFindNext=!0,nextStep=1,isGoBack=!0){let destRange={...startRange};boundary==null&&(boundary={startRow:0,endRow:worksheet.getRowCount()-1,startColumn:0,endColumn:worksheet.getColumnCount()-1});let next;switch(direction){case core.Direction.UP:for(next=startRange.startRow-nextStep;next>-1&&!worksheet.getRowVisible(next);)next-=1;next>=boundary.startRow?(destRange.startRow=next,destRange.endRow=next):isGoBack&&(destRange.startRow=boundary.endRow,destRange.endRow=boundary.endRow,isFindNext&&(destRange=findNextRange(destRange,core.Direction.LEFT,worksheet,boundary,!1)));break;case core.Direction.DOWN:for(next=startRange.endRow+nextStep;next<worksheet.getRowCount()&&!worksheet.getRowVisible(next);)next+=1;next<=boundary.endRow?(destRange.startRow=next,destRange.endRow=next):isGoBack&&(destRange.startRow=boundary.startRow,destRange.endRow=boundary.startRow,isFindNext&&(destRange=findNextRange(destRange,core.Direction.RIGHT,worksheet,boundary,!1)));break;case core.Direction.LEFT:for(next=startRange.startColumn-nextStep;next>-1&&!worksheet.getColVisible(next);)next-=1;next>=boundary.startColumn?(destRange.startColumn=next,destRange.endColumn=next):isGoBack&&(destRange.startColumn=boundary.endColumn,destRange.endColumn=boundary.endColumn,isFindNext&&(destRange=findNextRange(destRange,core.Direction.UP,worksheet,boundary,!1)));break;case core.Direction.RIGHT:for(next=startRange.endColumn+nextStep;next<worksheet.getColumnCount()&&!worksheet.getColVisible(next);)next+=1;next<=boundary.endColumn?(destRange.startColumn=next,destRange.endColumn=next):isGoBack&&(destRange.startColumn=boundary.startColumn,destRange.endColumn=boundary.startColumn,isFindNext&&(destRange=findNextRange(destRange,core.Direction.DOWN,worksheet,boundary,!1)));break}return destRange}__name(findNextRange,"findNextRange");function findNextGapRange(startRange,direction,worksheet){const destRange={...startRange},{startRow,startColumn,endRow,endColumn}=getEdgeOfRange(startRange,direction,worksheet);let currentPositionHasValue=rangeHasValue(worksheet,startRow,startColumn,endRow,endColumn).hasValue,firstMove=!0,shouldContinue=!0;for(;shouldContinue;){if(core.Direction.UP===direction){let next=destRange.startRow-1;for(;next>-1&&!worksheet.getRowVisible(next);)next-=1;if(next===-1){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,next,destRange.startColumn,next,destRange.endColumn);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let min=next;matrix.forValue(row=>{min=Math.min(row,min)}),destRange.startRow=min}else destRange.startRow=next;if(destRange.endRow=destRange.startRow,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}if(core.Direction.DOWN===direction){let next=destRange.endRow+1;for(;next<worksheet.getRowCount()&&!worksheet.getRowVisible(next);)next+=1;if(next===worksheet.getRowCount()){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,next,destRange.startColumn,next,destRange.endColumn);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let max=next;matrix.forValue((row,_,value)=>{max=Math.max(row+(value.rowSpan||1)-1,max)}),destRange.endRow=max}else destRange.endRow=next;if(destRange.startRow=destRange.endRow,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}if(core.Direction.LEFT===direction){let next=destRange.startColumn-1;for(;next>-1&&!worksheet.getColVisible(next);)next-=1;if(next===-1){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,destRange.startRow,next,destRange.endRow,next);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let min=next;matrix.forValue((_,col)=>{min=Math.min(col,min)}),destRange.startColumn=min}else destRange.startColumn=next;if(destRange.endColumn=destRange.startColumn,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}if(core.Direction.RIGHT===direction){let next=destRange.endColumn+1;for(;next<worksheet.getColumnCount()&&!worksheet.getColVisible(next);)next+=1;if(next===worksheet.getColumnCount()){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,destRange.startRow,next,destRange.endRow,next);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let max=next;matrix.forValue((_,col,value)=>{max=Math.max(col+(value.colSpan||1)-1,max)}),destRange.endColumn=max}else destRange.endColumn=next;if(destRange.startColumn=destRange.endColumn,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}}return sheets.alignToMergedCellsBorders(destRange,worksheet,!0)}__name(findNextGapRange,"findNextGapRange");function findNextRangeExpand(startRange,direction,worksheet){return findNextRange(startRange,direction,worksheet,void 0,!1,1,!1)}__name(findNextRangeExpand,"findNextRangeExpand");function expandToNextGapRange(startRange,direction,worksheet){const next=findNextGapRange(startRange,direction,worksheet);return sheets.alignToMergedCellsBorders(core.Rectangle.union(next,startRange),worksheet,!0)}__name(expandToNextGapRange,"expandToNextGapRange");function expandToNextCell(startRange,direction,worksheet){const next=findNextRangeExpand(startRange,direction,worksheet),destRange={startRow:Math.min(startRange.startRow,next.startRow),startColumn:Math.min(startRange.startColumn,next.startColumn),endRow:Math.max(startRange.endRow,next.endRow),endColumn:Math.max(startRange.endColumn,next.endColumn)};return sheets.alignToMergedCellsBorders(core.Rectangle.union(startRange,destRange),worksheet)}__name(expandToNextCell,"expandToNextCell");function shrinkToNextGapRange(startRange,anchorRange,direction,worksheet){const reversedDirection=core.getReverseDirection(direction),nextGap=findNextGapRange(getEdgeOfRange(startRange,reversedDirection,worksheet),direction,worksheet);return direction===core.Direction.UP&&nextGap.startRow<=startRange.startRow?sheets.alignToMergedCellsBorders({...anchorRange,startColumn:startRange.startColumn,endColumn:startRange.endColumn},worksheet,!0):direction===core.Direction.DOWN&&nextGap.endRow>=startRange.endRow?sheets.alignToMergedCellsBorders({...anchorRange,startColumn:startRange.startColumn,endColumn:startRange.endColumn},worksheet,!0):direction===core.Direction.LEFT&&nextGap.startColumn<=startRange.startColumn?sheets.alignToMergedCellsBorders({...anchorRange,startRow:startRange.startRow,endRow:startRange.endRow},worksheet,!0):direction===core.Direction.RIGHT&&nextGap.endColumn>=startRange.endColumn?sheets.alignToMergedCellsBorders({...anchorRange,startRow:startRange.startRow,endRow:startRange.endRow},worksheet,!0):core.Rectangle.union(core.Rectangle.clone(anchorRange),nextGap)}__name(shrinkToNextGapRange,"shrinkToNextGapRange");function shrinkToNextCell(startRange,direction,worksheet){const reversedDirection=core.getReverseDirection(direction),shrinkFromEdge=getEdgeOfRange(startRange,reversedDirection,worksheet),otherEdge=getEdgeOfRange(startRange,direction,worksheet),next=findNextRangeExpand(shrinkFromEdge,direction,worksheet);return sheets.alignToMergedCellsBorders(core.Rectangle.union(otherEdge,next),worksheet,!1)}__name(shrinkToNextCell,"shrinkToNextCell");function expandToWholeSheet(worksheet){return{startRow:0,startColumn:0,endRow:worksheet.getRowCount()-1,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL}}__name(expandToWholeSheet,"expandToWholeSheet");function getEdgeOfRange(startRange,direction,worksheet){let destRange;switch(direction){case core.Direction.UP:destRange={startRow:startRange.startRow,startColumn:startRange.startColumn,endRow:startRange.startRow,endColumn:startRange.endColumn,rangeType:core.RANGE_TYPE.NORMAL};break;case core.Direction.DOWN:destRange={startRow:startRange.endRow,startColumn:startRange.startColumn,endRow:startRange.endRow,endColumn:startRange.endColumn,rangeType:core.RANGE_TYPE.NORMAL};break;case core.Direction.LEFT:destRange={startRow:startRange.startRow,startColumn:startRange.startColumn,endRow:startRange.endRow,endColumn:startRange.startColumn,rangeType:core.RANGE_TYPE.NORMAL};break;case core.Direction.RIGHT:destRange={startRow:startRange.startRow,startColumn:startRange.endColumn,endRow:startRange.endRow,endColumn:startRange.endColumn,rangeType:core.RANGE_TYPE.NORMAL};break;default:throw new Error("Invalid direction")}return sheets.alignToMergedCellsBorders(destRange,worksheet,!1)}__name(getEdgeOfRange,"getEdgeOfRange");function rangeHasValue(worksheet,row,col,rowEnd,colEnd){let hasValue=!1;const matrix=worksheet.getMatrixWithMergedCells(row,col,rowEnd,colEnd).forValue((_,__,value)=>{if(cellHasValue(value))return hasValue=!0,!1});return{hasValue,matrix}}__name(rangeHasValue,"rangeHasValue");function getStartRange(range,primary,direction){const ret=core.Rectangle.clone(range);if(primary==null)return ret;switch(direction){case core.Direction.UP:case core.Direction.DOWN:ret.startColumn=ret.endColumn=primary.actualColumn;break;case core.Direction.LEFT:case core.Direction.RIGHT:ret.startRow=ret.endRow=primary.actualRow;break}return ret}__name(getStartRange,"getStartRange");function checkIfShrink(selection,direction,worksheet){const{primary,range}=selection,startRange=core.Rectangle.clone(range);switch(direction){case core.Direction.UP:case core.Direction.DOWN:startRange.startRow=primary.startRow,startRange.endRow=primary.endRow;break;case core.Direction.LEFT:case core.Direction.RIGHT:startRange.startColumn=primary.startColumn,startRange.endColumn=primary.endColumn;break}const anchorRange=getEdgeOfRange(startRange,direction,worksheet);switch(direction){case core.Direction.DOWN:return range.startRow<anchorRange.startRow;case core.Direction.UP:return range.endRow>anchorRange.endRow;case core.Direction.LEFT:return anchorRange.endColumn<range.endColumn;case core.Direction.RIGHT:return anchorRange.startColumn>range.startColumn}}__name(checkIfShrink,"checkIfShrink");function isAllRowsCovered(allRowRanges,ranges){let start=allRowRanges[0].startRow,end=allRowRanges[0].endRow;allRowRanges.forEach(range=>{const{startRow,endRow}=range;start=Math.min(start,startRow),end=Math.max(end,endRow)});const covered=new Array(end-start+1).fill(!1);return ranges.forEach(range=>{const{startRow,endRow}=range;for(let i=Math.max(startRow,start);i<=Math.min(endRow,end);i++)covered[i-start]=!0}),allRowRanges.every(range=>{const{startRow,endRow}=range;for(let i=startRow;i<=endRow;i++)if(!covered[i-start])return!1;return!0})}__name(isAllRowsCovered,"isAllRowsCovered");function isAllColumnsCovered(allColumnRanges,ranges){let start=allColumnRanges[0].startColumn,end=allColumnRanges[0].endColumn;allColumnRanges.forEach(range=>{const{startColumn,endColumn}=range;start=Math.min(start,startColumn),end=Math.max(end,endColumn)});const covered=new Array(end-start+1).fill(!1);return ranges.forEach(range=>{const{startColumn,endColumn}=range;for(let i=Math.max(startColumn,start);i<=Math.min(endColumn,end);i++)covered[i-start]=!0}),allColumnRanges.every(range=>{const{startColumn,endColumn}=range;for(let i=startColumn;i<=endColumn;i++)if(!covered[i-start])return!1;return!0})}__name(isAllColumnsCovered,"isAllColumnsCovered");function getMergeableSelectionsByType(type,selections){return selections?type==="mergeAll"?selections.filter(selection=>!(selection.startRow===selection.endRow&&selection.startColumn===selection.endColumn)):type==="mergeVertical"?selections.filter(selection=>selection.startRow!==selection.endRow):type==="mergeHorizontal"?selections.filter(selection=>selection.startColumn!==selection.endColumn):selections:null}__name(getMergeableSelectionsByType,"getMergeableSelectionsByType");function cellHasValue(cell){return cell.v!==void 0&&cell.v!==null&&cell.v!==""||cell.p!==void 0}__name(cellHasValue,"cellHasValue");var JumpOver=(JumpOver2=>(JumpOver2[JumpOver2.moveStopeOne=0]="moveStopeOne",JumpOver2[JumpOver2.moveGap=1]="moveGap",JumpOver2[JumpOver2.moveStepPage=2]="moveStepPage",JumpOver2[JumpOver2.moveStepEnd=3]="moveStepEnd",JumpOver2))(JumpOver||{});const MoveSelectionCommand={id:"sheet.command.move-selection",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{workbook,worksheet}=target,selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const{direction,jumpOver}=params,{range,primary}=selection,startRange=getStartRange(range,primary,direction),next=jumpOver===1?findNextGapRange(startRange,direction,worksheet):findNextRange(startRange,direction,worksheet),destRange=sheets.getCellAtRowCol(next.startRow,next.startColumn,worksheet);return core.Rectangle.equals(destRange,startRange)?!1:(accessor.get(ShortcutExperienceService).remove({unitId:workbook.getUnitId(),sheetId:worksheet.getSheetId(),keycode:ui.KeyCode.TAB}),accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),selections:[{range:core.Rectangle.clone(destRange),primary:{startRow:destRange.startRow,startColumn:destRange.startColumn,endRow:destRange.endRow,endColumn:destRange.endColumn,actualRow:next.startRow,actualColumn:next.startColumn,isMerged:destRange.isMerged,isMergedMainCell:destRange.startRow===next.startRow&&destRange.startColumn===next.startColumn}}]}))},"handler")},MoveSelectionEnterAndTabCommand={id:"sheet.command.move-selection-enter-tab",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{workbook,worksheet}=target,selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const unitId=workbook.getUnitId(),sheetId=worksheet.getSheetId();if(!selection)return!1;const{direction,keycode}=params,{range,primary}=selection;let startRange=getStartRange(range,primary,direction);const shortcutExperienceService=accessor.get(ShortcutExperienceService),shortcutExperienceParam=shortcutExperienceService.getCurrentBySearch({unitId,sheetId,keycode:ui.KeyCode.TAB});let resultRange;const{startRow,endRow,startColumn,endColumn}=range;if(core.Rectangle.equals(range,primary)){if(keycode===ui.KeyCode.TAB)shortcutExperienceParam==null&&shortcutExperienceService.addOrUpdate({unitId,sheetId,keycode:ui.KeyCode.TAB,selection});else{const selectionRemain=shortcutExperienceParam==null?void 0:shortcutExperienceParam.selection;if(selectionRemain!=null){const{range:range2,primary:primary2}=selectionRemain;startRange=getStartRange(range2,primary2,direction)}shortcutExperienceService.remove({unitId,sheetId,keycode:ui.KeyCode.TAB})}const next=findNextRange(startRange,direction,worksheet),destRange=sheets.getCellAtRowCol(next.startRow,next.startColumn,worksheet);if(core.Rectangle.equals(destRange,startRange))return!1;resultRange={range:core.Rectangle.clone(destRange),primary:{startRow:destRange.startRow,startColumn:destRange.startColumn,endRow:destRange.endRow,endColumn:destRange.endColumn,actualRow:next.startRow,actualColumn:next.startColumn,isMerged:destRange.isMerged,isMergedMainCell:destRange.startRow===next.startRow&&destRange.startColumn===next.startColumn}}}else{shortcutExperienceService.remove({unitId,sheetId,keycode:ui.KeyCode.TAB});const newPrimary=core.Tools.deepClone(primary),next=findNextRange({startRow:newPrimary.startRow,startColumn:newPrimary.startColumn,endRow:newPrimary.endRow,endColumn:newPrimary.endColumn},direction,worksheet,{startRow,endRow,startColumn,endColumn}),destRange=sheets.getCellAtRowCol(next.startRow,next.startColumn,worksheet);resultRange={range:core.Rectangle.clone(range),primary:{startRow:destRange.startRow,startColumn:destRange.startColumn,endRow:destRange.endRow,endColumn:destRange.endColumn,actualRow:next.startRow,actualColumn:next.startColumn,isMerged:destRange.isMerged,isMergedMainCell:destRange.startRow===next.startRow&&destRange.startColumn===next.startColumn}}}return accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,selections:[resultRange]})},"handler")},ExpandSelectionCommand={id:"sheet.command.expand-selection",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,unitId,subUnitId}=target,selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const{range:startRange,primary}=selection,{jumpOver,direction}=params,destRange=checkIfShrink(selection,direction,worksheet)?jumpOver===1?shrinkToNextGapRange(startRange,{...core.Rectangle.clone(primary),rangeType:core.RANGE_TYPE.NORMAL},direction,worksheet):shrinkToNextCell(startRange,direction,worksheet):jumpOver===1?expandToNextGapRange(startRange,direction,worksheet):expandToNextCell(startRange,direction,worksheet);return core.Rectangle.equals(destRange,startRange)?!1:accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId,selections:[{range:destRange,primary}]})},"handler")},SelectAllCommand={id:"sheet.command.select-all",type:core.CommandType.COMMAND,handler:__name(async(accessor,params={expandToGapFirst:!0,loop:!1})=>{const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const selectAllService=accessor.get(SelectAllService),{worksheet,unitId,subUnitId}=target,id=`${unitId}|${subUnitId}`;id!==selectAllService.selectedRangeWorksheet&&(selectAllService.rangesStack=[],selectAllService.selectedRangeWorksheet=id);const maxRow=worksheet.getMaxRows(),maxCol=worksheet.getMaxColumns(),{expandToGapFirst,loop}=params,{range,primary}=selection,isWholeSheetSelected=range.endColumn===maxCol-1&&range.endRow===maxRow-1&&range.startRow===0&&range.startColumn===0;selectAllService.rangesStack.some(s=>core.Rectangle.equals(s,range))||(selectAllService.rangesStack=[],selectAllService.rangesStack.push(range));let destRange;if(isWholeSheetSelected)if(loop){if(selectAllService.rangesStack.findIndex(s=>core.Rectangle.equals(s,range))!==selectAllService.rangesStack.length-1)return!1;destRange=selectAllService.rangesStack[0]}else return!1;else expandToGapFirst?(destRange=sheets.expandToContinuousRange(range,{left:!0,right:!0,up:!0,down:!0},worksheet),core.Rectangle.equals(destRange,range)&&(destRange=expandToWholeSheet(worksheet))):destRange=expandToWholeSheet(worksheet);return selectAllService.rangesStack.some(s=>core.Rectangle.equals(s,destRange))||selectAllService.rangesStack.push(destRange),accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId,selections:[{range:destRange,primary}]})},"handler")},SHEET_ZOOM_RANGE=[10,400];var SHEET_VIEW_KEY=(SHEET_VIEW_KEY2=>(SHEET_VIEW_KEY2.MAIN="__SpreadsheetRender__",SHEET_VIEW_KEY2.ROW="__SpreadsheetRowHeader__",SHEET_VIEW_KEY2.COLUMN="__SpreadsheetColumnHeader__",SHEET_VIEW_KEY2.LEFT_TOP="__SpreadsheetLeftTopPlaceholder__",SHEET_VIEW_KEY2))(SHEET_VIEW_KEY||{}),SHEET_VIEWPORT_KEY=(SHEET_VIEWPORT_KEY2=>(SHEET_VIEWPORT_KEY2.VIEW_MAIN="viewMain",SHEET_VIEWPORT_KEY2.VIEW_MAIN_LEFT_TOP="viewMainLeftTop",SHEET_VIEWPORT_KEY2.VIEW_MAIN_TOP="viewMainTop",SHEET_VIEWPORT_KEY2.VIEW_MAIN_LEFT="viewMainLeft",SHEET_VIEWPORT_KEY2.VIEW_ROW_TOP="viewRowTop",SHEET_VIEWPORT_KEY2.VIEW_ROW_BOTTOM="viewRowBottom",SHEET_VIEWPORT_KEY2.VIEW_COLUMN_LEFT="viewColumnLeft",SHEET_VIEWPORT_KEY2.VIEW_COLUMN_RIGHT="viewColumnRight",SHEET_VIEWPORT_KEY2.VIEW_LEFT_TOP="viewLeftTop",SHEET_VIEWPORT_KEY2))(SHEET_VIEWPORT_KEY||{});const SHEET_COMPONENT_MAIN_LAYER_INDEX=0,SHEET_COMPONENT_SELECTION_LAYER_INDEX=1,SHEET_COMPONENT_HEADER_LAYER_INDEX=10,SHEET_COMPONENT_HEADER_SELECTION_LAYER_INDEX=11,SHEET_COMPONENT_UNHIDE_LAYER_INDEX=12;function isRenderManagerService(renderManagerService){return typeof renderManagerService.isMainScene>"u"}__name(isRenderManagerService,"isRenderManagerService");function getSheetObject(univerInstanceService,renderManagerService){const workbook=univerInstanceService instanceof core.Workbook?univerInstanceService:univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const unitId=workbook.getUnitId();let components,mainComponent,scene,engine;if(isRenderManagerService(renderManagerService)){const currentRender=renderManagerService.getRenderById(unitId);if(currentRender==null)return null;components=currentRender.components,components=currentRender.components,mainComponent=currentRender.mainComponent,scene=currentRender.scene,engine=currentRender.engine}else components=renderManagerService.components,mainComponent=renderManagerService.mainComponent,scene=renderManagerService.scene,engine=renderManagerService.engine;if(!components||!mainComponent)return null;const spreadsheet=mainComponent,spreadsheetRowHeader=components.get(SHEET_VIEW_KEY.ROW),spreadsheetColumnHeader=components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetLeftTopPlaceholder=components.get(SHEET_VIEW_KEY.LEFT_TOP);return{spreadsheet,spreadsheetRowHeader,spreadsheetColumnHeader,spreadsheetLeftTopPlaceholder,scene,engine}}__name(getSheetObject,"getSheetObject");function getCoordByCell(row,col,scene,skeleton){const{startX,startY,endX,endY}=skeleton.getCellByIndex(row,col);return{startX,startY,endX,endY}}__name(getCoordByCell,"getCoordByCell");function getCoordByOffset(evtOffsetX,evtOffsetY,scene,skeleton,viewport,closeFirst){const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords,scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords,viewport),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=skeleton.getCellPositionByOffset(newEvtOffsetX,newEvtOffsetY,scaleX,scaleY,scrollXY,closeFirst),{row,column}=moveActualSelection,startCell=skeleton.getNoMergeCellPositionByIndex(row,column),{startX,startY,endX,endY}=startCell;return{startX,startY,endX,endY,row,column}}__name(getCoordByOffset,"getCoordByOffset");function getTransformCoord(evtOffsetX,evtOffsetY,scene,skeleton){const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords,viewMain),{scaleX,scaleY}=scene.getAncestorScale(),{x:scrollX,y:scrollY}=scrollXY,offsetX=evtOffsetX/scaleX+scrollX,offsetY=evtOffsetY/scaleY+scrollY;return{x:offsetX,y:offsetY}}__name(getTransformCoord,"getTransformCoord");var __defProp$P=Object.defineProperty,__getOwnPropDesc$P=Object.getOwnPropertyDescriptor,__decorateClass$P=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$P(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$P(target,key,result),result},"__decorateClass$P"),__decorateParam$P=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$P");const SHEET_NAVIGATION_COMMANDS$1=[MoveSelectionCommand.id,MoveSelectionEnterAndTabCommand.id];var _a4;exports.SheetsScrollRenderController=(_a4=class extends core.Disposable{constructor(_context,_injector,_sheetSkeletonManagerService,_contextService,_commandService,_renderManagerService,_scrollManagerService){super(),this._context=_context,this._injector=_injector,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._contextService=_contextService,this._commandService=_commandService,this._renderManagerService=_renderManagerService,this._scrollManagerService=_scrollManagerService,this._initCommandListener(),this._wheelEventListener(),this._scrollBarEventListener(),this._initSkeletonListener()}scrollToRange(range){let{endRow,endColumn,startColumn,startRow}=range;const bounding=this._getViewportBounding();if(range.rangeType===core.RANGE_TYPE.ROW?(startColumn=0,endColumn=0):range.rangeType===core.RANGE_TYPE.COLUMN&&(startRow=0,endRow=0),bounding){const row=bounding.startRow>endRow?startRow:endRow,col=bounding.startColumn>endColumn?startColumn:endColumn;return this._scrollToCell(row,col)}else return this._scrollToCell(startRow,startColumn)}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(SHEET_NAVIGATION_COMMANDS$1.includes(command.id))this._scrollToSelection();else if(command.id===sheets.ScrollToCellOperation.id){const param=command.params;this.scrollToRange(param)}else if(command.id===ExpandSelectionCommand.id){const param=command.params;this._scrollToSelectionForExpand(param)}else command.id===sheets.SetSelectionsOperation.id&&command.params.reveal&&this._scrollToSelection()}))}_scrollToSelectionForExpand(param){setTimeout(()=>{const selection=this._getSelectionsService().getCurrentLastSelection();if(selection==null)return;const{startRow,startColumn,endRow,endColumn}=selection.range,bounds=this._getViewportBounding();if(bounds==null)return;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;startRow>viewportStartRow?row=endRow:endRow<viewportEndRow?row=startRow:row=viewportStartRow,startColumn>viewportStartColumn?column=endColumn:endColumn<viewportEndColumn?column=startColumn:column=viewportStartColumn,param.direction===core.Direction.DOWN?row=endRow:param.direction===core.Direction.UP?row=startRow:param.direction===core.Direction.RIGHT?column=endColumn:param.direction===core.Direction.LEFT&&(column=startColumn),this._scrollToCell(row,column)},0)}_getFreeze(){var _a58;const snapshot=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton.getWorksheetConfig();if(snapshot!=null)return snapshot.freeze}_wheelEventListener(){const{scene}=this._context;if(!scene)return;const viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);viewMain&&this.disposeWithMe(scene.onMouseWheel$.subscribeEvent((evt,state)=>{if(evt.ctrlKey||!this._contextService.getContextValue(core.FOCUSING_SHEET))return;let offsetX=0,offsetY=0;const isLimitedStore=viewMain.limitedScroll();if(evt.inputIndex===engineRender.PointerInput.MouseWheelX){const scrollNum=Math.abs(evt.deltaX);offsetX=evt.deltaX>0?scrollNum:-scrollNum,this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetX}),scene.getParent().classType===engineRender.RENDER_CLASS_TYPE.SCENE_VIEWER?isLimitedStore!=null&&isLimitedStore.isLimitedX||state.stopPropagation():viewMain.isWheelPreventDefaultX?evt.preventDefault():isLimitedStore!=null&&isLimitedStore.isLimitedX||evt.preventDefault()}if(evt.inputIndex===engineRender.PointerInput.MouseWheelY){let scrollNum=Math.abs(evt.deltaY);evt.shiftKey?(scrollNum*=3,evt.deltaY>0?offsetX=scrollNum:offsetX=-scrollNum,this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetX}),scene.getParent().classType===engineRender.RENDER_CLASS_TYPE.SCENE_VIEWER?isLimitedStore!=null&&isLimitedStore.isLimitedX||state.stopPropagation():viewMain.isWheelPreventDefaultX?evt.preventDefault():isLimitedStore!=null&&isLimitedStore.isLimitedX||evt.preventDefault()):(offsetY=evt.deltaY>0?scrollNum:-scrollNum,this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetY}),scene.getParent().classType===engineRender.RENDER_CLASS_TYPE.SCENE_VIEWER?isLimitedStore!=null&&isLimitedStore.isLimitedY||state.stopPropagation():viewMain.isWheelPreventDefaultY?evt.preventDefault():isLimitedStore!=null&&isLimitedStore.isLimitedY||evt.preventDefault())}this._context.scene.makeDirty(!0)}))}_scrollBarEventListener(){const{scene}=this._context;if(scene==null)return;const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);viewportMain&&(this.disposeWithMe(core.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(rawScrollInfo=>{var _a58;const skeleton=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton;if(!skeleton)return;if(rawScrollInfo==null){viewportMain.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const{sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY}=rawScrollInfo,{startX,startY}=skeleton.getCellByIndexWithNoHeader(sheetViewStartRow,sheetViewStartColumn),viewportScrollX=startX+offsetX,viewportScrollY=startY+offsetY;viewportMain.scrollToViewportPos({viewportScrollX,viewportScrollY})}))),this.disposeWithMe(viewportMain.onScrollAfter$.subscribeEvent(scrollAfterParam=>{var _a58;const skeleton=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton;if(skeleton==null||scrollAfterParam.isTrigger===!1)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX,viewportScrollY,scrollX,scrollY}=scrollAfterParam,{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY),scrollInfo={sheetViewStartRow:row,sheetViewStartColumn:column,offsetX:columnOffset,offsetY:rowOffset};this._scrollManagerService.setScrollStateToCurrSheet(scrollInfo),this._scrollManagerService.validViewportScrollInfo$.next({...scrollInfo,viewportScrollX,viewportScrollY,scrollX,scrollY})})),this.disposeWithMe(viewportMain.onScrollByBar$.subscribeEvent(param=>{var _a58;const skeleton=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton;if(skeleton==null||param.isTrigger===!1)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX=0,viewportScrollY=0}=param,freeze=this._getFreeze(),{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY);this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartRow:row+((freeze==null?void 0:freeze.ySplit)||0),sheetViewStartColumn:column+((freeze==null?void 0:freeze.xSplit)||0),offsetX:columnOffset,offsetY:rowOffset})})))}_initSkeletonListener(){this.disposeWithMe(core.toDisposable(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(param=>{if(param==null)return;const scrollParam={unitId:param.unitId,sheetId:param.sheetId};this._scrollManagerService.setSearchParam(scrollParam);const sheetObject=this._getSheetObject();if(!sheetObject)return;const viewportMain=sheetObject.scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),currScrollInfo=this._scrollManagerService.getScrollStateByParam(scrollParam),{viewportScrollX,viewportScrollY}=this._scrollManagerService.calcViewportScrollFromRowColOffset(currScrollInfo);viewportMain&&(currScrollInfo?(viewportMain.viewportScrollX=viewportScrollX,viewportMain.viewportScrollY=viewportScrollY):(viewportMain.viewportScrollX=0,viewportMain.viewportScrollY=0),this._updateSceneSize(param))})))}_updateSceneSize(param){var _a58;if(param==null)return;const{unitId}=this._context,{skeleton}=param,scene=(_a58=this._renderManagerService.getRenderById(unitId))==null?void 0:_a58.scene;if(skeleton==null||scene==null)return;const{rowTotalHeight,columnTotalWidth,rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const zoomRatio=worksheet.getZoomRatio()||1;scene==null||scene.setScaleValue(zoomRatio,zoomRatio),scene==null||scene.transformByState({width:rowHeaderWidthAndMarginLeft+columnTotalWidth,height:columnHeaderHeightAndMarginTop+rowTotalHeight})}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_scrollToSelectionByDirection(range){const bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;const{startRow,startColumn,endRow,endColumn}=range;startRow>=viewportStartRow&&(row=endRow),endRow<=viewportEndRow&&(row=startRow),startColumn>=viewportStartColumn&&(column=endColumn),endColumn<=viewportEndColumn&&(column=startColumn),this._scrollToCell(row,column)}_scrollToSelection(targetIsActualRowAndColumn=!0){const selection=this._getSelectionsService().getCurrentLastSelection();if(!selection)return;const{startRow,startColumn,actualRow,actualColumn}=selection.primary,selectionStartRow=targetIsActualRowAndColumn?actualRow:startRow,selectionStartColumn=targetIsActualRowAndColumn?actualColumn:startColumn;this._scrollToCell(selectionStartRow,selectionStartColumn)}_getSelectionsService(){return sheets.getSelectionsService(this._injector)}_getViewportBounding(){var _a58,_b;const scene=(_a58=this._getSheetObject())==null?void 0:_a58.scene;if(scene==null)return;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null)return;const skeleton=(_b=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_b.skeleton;if(skeleton==null)return;const bounds=viewport.getBounding();return skeleton.getRowColumnSegmentByViewBound(bounds.viewBound)}_scrollToCell(row,column){var _a58,_b,_c,_d;const{rowHeightAccumulation,columnWidthAccumulation}=(_b=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton)!=null?_b:{};if(rowHeightAccumulation==null||columnWidthAccumulation==null)return!1;const scene=(_c=this._getSheetObject())==null?void 0:_c.scene;if(scene==null)return!1;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null||((_d=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_d.skeleton)==null)return!1;const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return!1;const{startColumn:freezeStartColumn,startRow:freezeStartRow,ySplit:freezeYSplit,xSplit:freezeXSplit}=worksheet.getFreeze(),bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let startSheetViewRow,startSheetViewColumn;if(row>=freezeStartRow&&column>=freezeStartColumn-freezeXSplit&&(row<=viewportStartRow&&(startSheetViewRow=row),row>=viewportEndRow)){const minRowAccumulation=rowHeightAccumulation[row]-viewport.height;for(let r2=viewportStartRow;r2<=row;r2++)if(rowHeightAccumulation[r2]>=minRowAccumulation){startSheetViewRow=r2+1;break}}if(column>=freezeStartColumn&&row>=freezeStartRow-freezeYSplit&&(column<=viewportStartColumn&&(startSheetViewColumn=column),column>=viewportEndColumn)){const minColumnAccumulation=columnWidthAccumulation[column]-viewport.width;for(let c=viewportStartColumn;c<=column;c++)if(columnWidthAccumulation[c]>=minColumnAccumulation){startSheetViewColumn=c+1;break}}if(startSheetViewRow===void 0&&startSheetViewColumn===void 0)return!1;const{offsetX,offsetY}=this._scrollManagerService.getCurrentScrollState()||{};return startSheetViewRow=startSheetViewRow&&Math.min(startSheetViewRow,row),startSheetViewColumn=startSheetViewColumn&&Math.min(startSheetViewColumn,column),this._commandService.syncExecuteCommand(ScrollCommand.id,{sheetViewStartRow:startSheetViewRow,sheetViewStartColumn:startSheetViewColumn,offsetX:startSheetViewColumn===void 0?offsetX:0,offsetY:startSheetViewRow===void 0?offsetY:0})}},__name(_a4,"SheetsScrollRenderController"),_a4);exports.SheetsScrollRenderController=__decorateClass$P([__decorateParam$P(1,core.Inject(core.Injector)),__decorateParam$P(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$P(3,core.IContextService),__decorateParam$P(4,core.ICommandService),__decorateParam$P(5,engineRender.IRenderManagerService),__decorateParam$P(6,core.Inject(SheetScrollManagerService))],exports.SheetsScrollRenderController);function getActiveSheet$(univerInstanceService){return univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.switchMap(workbook=>workbook?workbook.activeSheet$.pipe(rxjs.map(worksheet=>worksheet?{workbook,worksheet}:null)):rxjs.of(null)))}__name(getActiveSheet$,"getActiveSheet$");function deriveStateFromActiveSheet$(univerInstanceService,defaultValue,callback){return getActiveSheet$(univerInstanceService).pipe(rxjs.switchMap(active=>active?callback(active):rxjs.of(defaultValue)))}__name(deriveStateFromActiveSheet$,"deriveStateFromActiveSheet$");function getCurrentExclusiveRangeInterest$(accessor,disableGroupSet){const univerInstanceService=accessor.get(core.IUniverInstanceService),exclusiveRangeService=accessor.get(sheets.IExclusiveRangeService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.switchMap(workbook=>workbook?rxjs.combineLatest([selectionManagerService.selectionMoveEnd$,workbook.activeSheet$]).pipe(rxjs.switchMap(([selections,worksheet])=>{if(!worksheet||selections.length===0)return rxjs.of(!1);const interestGroupIds=exclusiveRangeService.getInterestGroupId(selections);if(disableGroupSet){const disableGroup=interestGroupIds.filter(groupId=>disableGroupSet.has(groupId));return rxjs.of(disableGroup.length>0)}else return rxjs.of(interestGroupIds.length>0)})):rxjs.of(!1)))}__name(getCurrentExclusiveRangeInterest$,"getCurrentExclusiveRangeInterest$");function getObservableWithExclusiveRange$(accessor,observable$,disableGroupSet){return rxjs.combineLatest([observable$,getCurrentExclusiveRangeInterest$(accessor,disableGroupSet)]).pipe(rxjs.map(([observable,exclusiveRangeDisable])=>observable||exclusiveRangeDisable))}__name(getObservableWithExclusiveRange$,"getObservableWithExclusiveRange$");function getCurrentRangeDisable$(accessor,permissionTypes={}){const workbook$=accessor.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([userManagerService.currentUser$,workbook$]).pipe(rxjs.switchMap(([_,workbook])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{if(!worksheet)return rxjs.of(!0);const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),focusedOnDrawing$=accessor.get(core.IContextService).subscribeContextValue$(core.FOCUSING_COMMON_DRAWINGS).pipe(rxjs.startWith(!1));return rxjs.combineLatest([selectionManagerService.selectionMoveEnd$,focusedOnDrawing$]).pipe(rxjs.switchMap(([selection,focusOnDrawings])=>{if(focusOnDrawings)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionService=accessor.get(core.IPermissionService),{workbookTypes=[sheets.WorkbookEditablePermission],worksheetTypes,rangeTypes}=permissionTypes,permissionIds=[];if(workbookTypes==null||workbookTypes.forEach(F=>{permissionIds.push(new F(unitId).id)}),worksheetTypes==null||worksheetTypes.forEach(F=>{permissionIds.push(new F(unitId,subUnitId).id)}),worksheetRuleModel.getRule(unitId,subUnitId))return permissionService.composePermission$(permissionIds).pipe(rxjs.map(list=>list.some(item=>item.value===!1)));const selectionRanges=selection==null?void 0:selection.map(selection2=>selection2.range),rules=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>selectionRanges==null?void 0:selectionRanges.some(range=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(range,ruleRange))));return rangeTypes==null||rangeTypes.forEach(F=>{rules.forEach(rule=>{permissionIds.push(new F(unitId,subUnitId,rule.permissionId).id)})}),permissionService.composePermission$(permissionIds).pipe(rxjs.map(list=>list.some(item=>item.value===!1)))}))})):rxjs.of(!0)))}__name(getCurrentRangeDisable$,"getCurrentRangeDisable$");function getBaseRangeMenuHidden$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id];return rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(range,ruleRange))).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getBaseRangeMenuHidden$,"getBaseRangeMenuHidden$");function getInsertAfterMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id];return rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>type==="row"?rule.ranges.some(ruleRange=>range.endRow>ruleRange.startRow&&range.endRow<=ruleRange.endRow):rule.ranges.some(ruleRange=>range.endColumn>ruleRange.startColumn&&range.endColumn<=ruleRange.endColumn)).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getInsertAfterMenuHidden$,"getInsertAfterMenuHidden$");function getInsertBeforeMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id];return rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>type==="row"?rule.ranges.some(ruleRange=>range.startRow>ruleRange.startRow&&range.startRow<=ruleRange.endRow):rule.ranges.some(ruleRange=>range.startColumn>ruleRange.startColumn&&range.startColumn<=ruleRange.endColumn)).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getInsertBeforeMenuHidden$,"getInsertBeforeMenuHidden$");function getDeleteMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id],rowColRangeExpand=core.Tools.deepClone(range);return type==="row"?(rowColRangeExpand.startColumn=0,rowColRangeExpand.endColumn=worksheet.getColumnCount()-1):(rowColRangeExpand.startRow=0,rowColRangeExpand.endRow=worksheet.getRowCount()-1),rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(rowColRangeExpand,ruleRange))).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getDeleteMenuHidden$,"getDeleteMenuHidden$");function getCellMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id],rowColRangeExpand=core.Tools.deepClone(range);return type==="row"?rowColRangeExpand.endRow=worksheet.getRowCount()-1:rowColRangeExpand.endColumn=worksheet.getColumnCount()-1,rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(rowColRangeExpand,ruleRange))).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getCellMenuHidden$,"getCellMenuHidden$");function getWorkbookPermissionDisable$(accessor,workbookPermissionTypes){const workbook$=accessor.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([userManagerService.currentUser$,workbook$]).pipe(rxjs.switchMap(([_user,workbook])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(activeSheet=>{var _a58,_b;if(!activeSheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),workbookPermissionIds=[];workbookPermissionTypes.forEach(F=>workbookPermissionIds.push(new F(unitId).id));const workbookPermission$=permissionService.composePermission$(workbookPermissionIds).pipe(rxjs.map(list=>list.every(item=>item.value===!0))),workbookManageCollaboratorPermission$=(_b=(_a58=permissionService.getPermissionPoint$(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_a58.pipe(rxjs.map(permission=>permission.value)))!=null?_b:rxjs.of(!1);return rxjs.combineLatest([workbookPermission$,workbookManageCollaboratorPermission$]).pipe(rxjs.map(([basePermission,manageable])=>{if(!basePermission)return!0;const subUnitId=activeSheet.getSheetId(),worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId),worksheetRuleList=selectionRuleModel.getSubunitRuleList(unitId,subUnitId);return worksheetRule||worksheetRuleList.length?!manageable:!1}))})):rxjs.of(!0)))}__name(getWorkbookPermissionDisable$,"getWorkbookPermissionDisable$");var __defProp$O=Object.defineProperty,__getOwnPropDesc$O=Object.getOwnPropertyDescriptor,__decorateClass$O=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$O(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$O(target,key,result),result},"__decorateClass$O"),__decorateParam$O=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$O"),_a5;exports.SheetsRenderService=(_a5=class extends core.RxDisposable{constructor(_contextService,_instanceSrv,_renderManagerService){super();__publicField(this,"_skeletonChangeMutations",new Set);this._contextService=_contextService,this._instanceSrv=_instanceSrv,this._renderManagerService=_renderManagerService,Promise.resolve().then(()=>this._init())}registerSkeletonChangingMutations(mutationId){return this._skeletonChangeMutations.has(mutationId)?core.toDisposable(()=>{}):(this._skeletonChangeMutations.add(mutationId),core.toDisposable(()=>this._skeletonChangeMutations.delete(mutationId)))}checkMutationShouldTriggerRerender(id){return this._skeletonChangeMutations.has(id)}_init(){this._initWorkbookListener(),this._initContextListener()}_initWorkbookListener(){this._instanceSrv.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.takeUntil(this.dispose$)).subscribe(workbook=>{this._createRenderer(workbook)}),this._instanceSrv.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>this._createRenderer(workbook)),this._instanceSrv.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.takeUntil(this.dispose$)).subscribe(workbook=>this._disposeRenderer(workbook))}_createRenderer(workbook){const unitId=workbook.getUnitId();this._renderManagerService.createRender(unitId),this._renderManagerService.setCurrent(unitId)}_disposeRenderer(workbook){const unitId=workbook.getUnitId();this._renderManagerService.removeRender(unitId)}_initContextListener(){this._contextService.subscribeContextValue$(engineRender.RENDER_RAW_FORMULA_KEY).pipe(rxjs.distinctUntilChanged(),rxjs.takeUntil(this.dispose$)).subscribe(()=>{this._renderManagerService.getRenderAll().forEach(renderer=>{renderer.mainComponent instanceof engineRender.Spreadsheet&&renderer.mainComponent.makeForceDirty(!0)})})}},__name(_a5,"SheetsRenderService"),_a5);exports.SheetsRenderService=__decorateClass$O([__decorateParam$O(0,core.IContextService),__decorateParam$O(1,core.IUniverInstanceService),__decorateParam$O(2,engineRender.IRenderManagerService)],exports.SheetsRenderService);const RANGE_MOVE_PERMISSION_CHECK=core.createInterceptorKey("rangeMovePermissionCheck"),RANGE_FILL_PERMISSION_CHECK=core.createInterceptorKey("rangeFillPermissionCheck");var SELECTION_SHAPE_DEPTH=(SELECTION_SHAPE_DEPTH2=>(SELECTION_SHAPE_DEPTH2[SELECTION_SHAPE_DEPTH2.FORMULA_EDITOR_SHOW=100]="FORMULA_EDITOR_SHOW",SELECTION_SHAPE_DEPTH2[SELECTION_SHAPE_DEPTH2.MARK_SELECTION=1e4]="MARK_SELECTION",SELECTION_SHAPE_DEPTH2))(SELECTION_SHAPE_DEPTH||{});const _SelectionRenderModel=class _SelectionRenderModel{constructor(){__publicField(this,"_startColumn",-1);__publicField(this,"_startRow",-1);__publicField(this,"_endColumn",-1);__publicField(this,"_endRow",-1);__publicField(this,"_startX",0);__publicField(this,"_startY",0);__publicField(this,"_endX",0);__publicField(this,"_endY",0);__publicField(this,"_primary");__publicField(this,"_rangeType",core.RANGE_TYPE.NORMAL)}get startColumn(){return this._startColumn}get startRow(){return this._startRow}get endColumn(){return this._endColumn}get endRow(){return this._endRow}get startX(){return this._startX}get startY(){return this._startY}get endX(){return this._endX}get endY(){return this._endY}get currentCell(){return this._primary}get rangeType(){return this._rangeType}isEqual(rangeWithCoord){const{startColumn,startRow,endColumn,endRow}=this,{startColumn:newStartColumn,startRow:newStartRow,endColumn:newEndColumn,endRow:newEndRow}=rangeWithCoord;return startColumn===newStartColumn&&startRow===newStartRow&&endColumn===newEndColumn&&endRow===newEndRow}isInclude(rangeWithCoord){const{startColumn,startRow,endColumn,endRow}=this,{startColumn:newStartColumn,startRow:newStartRow,endColumn:newEndColumn,endRow:newEndRow}=rangeWithCoord;return!(newEndColumn<startColumn||newStartColumn>endColumn||newStartRow>endRow||newEndRow<startRow)}highlightToSelection(){if(this._primary)return core.makeCellToSelection(this._primary)}getRange(){return{startColumn:this._startColumn,startRow:this._startRow,endColumn:this._endColumn,endRow:this._endRow,startX:this._startX,startY:this._startY,endX:this._endX,endY:this._endY,rangeType:this.rangeType}}getCell(){return this._primary}getRangeType(){return this._rangeType}setRangeType(rangeType){this._rangeType=rangeType}getValue(){return{rangeWithCoord:this.getRange(),primaryWithCoord:this._primary}}setValue(newSelectionRange,currentCell){const{startColumn,startRow,endColumn,endRow,startX,startY,endX,endY,rangeType}=newSelectionRange;this._startColumn=startColumn,this._startRow=startRow,this._endColumn=endColumn,this._endRow=endRow,this._startX=startX,this._startY=startY,this._endX=endX,this._endY=endY,rangeType!==void 0&&(this._rangeType=rangeType),this.setCurrentCell(currentCell)}setCurrentCell(currentCell){currentCell&&(this._primary=currentCell)}clearCurrentCell(){this._primary=null}};__name(_SelectionRenderModel,"SelectionRenderModel");let SelectionRenderModel=_SelectionRenderModel;var SELECTION_MANAGER_KEY=(SELECTION_MANAGER_KEY2=>(SELECTION_MANAGER_KEY2.Selection="__SpreadsheetSelectionShape__",SELECTION_MANAGER_KEY2.top="__SpreadsheetSelectionTopControl__",SELECTION_MANAGER_KEY2.bottom="__SpreadsheetSelectionBottomControl__",SELECTION_MANAGER_KEY2.left="__SpreadsheetSelectionShapeLeftControl__",SELECTION_MANAGER_KEY2.right="__SpreadsheetSelectionShapeRightControl__",SELECTION_MANAGER_KEY2.backgroundTop="__SpreadsheetSelectionBackgroundControlTop__",SELECTION_MANAGER_KEY2.backgroundMiddleLeft="__SpreadsheetSelectionBackgroundControlMiddleLeft__",SELECTION_MANAGER_KEY2.backgroundMiddleRight="__SpreadsheetSelectionBackgroundControlMiddleRight__",SELECTION_MANAGER_KEY2.backgroundBottom="__SpreadsheetSelectionBackgroundControlBottom__",SELECTION_MANAGER_KEY2.fill="__SpreadsheetSelectionFillControl__",SELECTION_MANAGER_KEY2.fillTopLeft="__SpreadsheetSelectionFillControlTopLeft__",SELECTION_MANAGER_KEY2.fillBottomRight="__SpreadsheetSelectionFillControlBottomRight__",SELECTION_MANAGER_KEY2.fillTopLeftInner="__SpreadsheetSelectionFillControlTopLeftInner__",SELECTION_MANAGER_KEY2.fillBottomRightInner="__SpreadsheetSelectionFillControlBottomRightInner__",SELECTION_MANAGER_KEY2.lineMain="__SpreadsheetDragLineMainControl__",SELECTION_MANAGER_KEY2.lineContent="__SpreadsheetDragLineContentControl__",SELECTION_MANAGER_KEY2.line="__SpreadsheetDragLineControl__",SELECTION_MANAGER_KEY2.dash="__SpreadsheetDragDashControl__",SELECTION_MANAGER_KEY2.rowHeaderBackground="__SpreadSheetSelectionRowHeaderBackground__",SELECTION_MANAGER_KEY2.rowHeaderBorder="__SpreadSheetSelectionRowHeaderBorder__",SELECTION_MANAGER_KEY2.rowHeaderGroup="__SpreadSheetSelectionRowHeaderGroup__",SELECTION_MANAGER_KEY2.columnHeaderBackground="__SpreadSheetSelectionColumnHeaderBackground__",SELECTION_MANAGER_KEY2.columnHeaderBorder="__SpreadSheetSelectionColumnHeaderBorder__",SELECTION_MANAGER_KEY2.columnHeaderGroup="__SpreadSheetSelectionColumnHeaderGroup__",SELECTION_MANAGER_KEY2.topLeftWidget="__SpreadSheetSelectionTopLeftWidget__",SELECTION_MANAGER_KEY2.topCenterWidget="__SpreadSheetSelectionTopCenterWidget__",SELECTION_MANAGER_KEY2.topRightWidget="__SpreadSheetSelectionTopRightWidget__",SELECTION_MANAGER_KEY2.middleLeftWidget="__SpreadSheetSelectionMiddleLeftWidget__",SELECTION_MANAGER_KEY2.middleRightWidget="__SpreadSheetSelectionMiddleRightWidget__",SELECTION_MANAGER_KEY2.bottomLeftWidget="__SpreadSheetSelectionBottomLeftWidget__",SELECTION_MANAGER_KEY2.bottomCenterWidget="__SpreadSheetSelectionBottomCenterWidget__",SELECTION_MANAGER_KEY2.bottomRightWidget="__SpreadSheetSelectionBottomRightWidget__",SELECTION_MANAGER_KEY2))(SELECTION_MANAGER_KEY||{});const SELECTION_TITLE_HIGHLIGHT_ALPHA=.3,_SelectionControl=class _SelectionControl extends core.Disposable{constructor(_scene,_zIndex,_themeService,_highlightHeader=!0,options){super();__publicField(this,"_leftBorder");__publicField(this,"_rightBorder");__publicField(this,"_topBorder");__publicField(this,"_bottomBorder");__publicField(this,"_backgroundControlTop");__publicField(this,"_backgroundControlBottom");__publicField(this,"_backgroundControlMiddleLeft");__publicField(this,"_backgroundControlMiddleRight");__publicField(this,"_fillControl");__publicField(this,"_selectionShapeGroup");__publicField(this,"_rowHeaderBackground");__publicField(this,"_rowHeaderBorder");__publicField(this,"_rowHeaderGroup");__publicField(this,"_columnHeaderBackground");__publicField(this,"_columnHeaderBorder");__publicField(this,"_columnHeaderGroup");__publicField(this,"_topLeftWidget");__publicField(this,"_topCenterWidget");__publicField(this,"_topRightWidget");__publicField(this,"_middleLeftWidget");__publicField(this,"_middleRightWidget");__publicField(this,"_bottomLeftWidget");__publicField(this,"_bottomCenterWidget");__publicField(this,"_bottomRightWidget");__publicField(this,"_dashedRect");__publicField(this,"_selectionModel");__publicField(this,"_defaultStyle");__publicField(this,"_currentStyle");__publicField(this,"_rowHeaderWidth",0);__publicField(this,"_columnHeaderHeight",0);__publicField(this,"_widgetRects",[]);__publicField(this,"_dispose$",new rxjs.BehaviorSubject(this));__publicField(this,"dispose$",this._dispose$.asObservable());__publicField(this,"selectionMoving$",new rxjs.Subject);__publicField(this,"selectionMoved$",new rxjs.Subject);__publicField(this,"selectionScaling$",new rxjs.Subject);__publicField(this,"selectionScaled$",new rxjs.Subject);__publicField(this,"selectionFilling$",new rxjs.Subject);__publicField(this,"_selectionFilled$",new rxjs.Subject);__publicField(this,"selectionFilled$",this._selectionFilled$.asObservable());__publicField(this,"_isHelperSelection",!0);__publicField(this,"_antLineOffset",0);__publicField(this,"_antRequestNewFrame",-1);this._scene=_scene,this._zIndex=_zIndex,this._themeService=_themeService,this._highlightHeader=_highlightHeader,this._rowHeaderWidth=(options==null?void 0:options.rowHeaderWidth)||0,this._columnHeaderHeight=(options==null?void 0:options.columnHeaderHeight)||0,this._initialize()}get zIndex(){return this._zIndex}get leftControl(){return this._leftBorder}get rightControl(){return this._rightBorder}get topControl(){return this._topBorder}get bottomControl(){return this._bottomBorder}get fillControl(){return this._fillControl}get backgroundControlTop(){return this._backgroundControlTop}get backgroundControlBottom(){return this._backgroundControlBottom}get backgroundControlMiddleLeft(){return this._backgroundControlMiddleLeft}get backgroundControlMiddleRight(){return this._backgroundControlMiddleRight}get selectionShape(){return this._selectionShapeGroup}get columnHeaderGroup(){return this._columnHeaderGroup}get rowHeaderGroup(){return this._rowHeaderGroup}get selectionShapeGroup(){return this._selectionShapeGroup}get model(){return this._selectionModel}get topLeftWidget(){return this._topLeftWidget}get topCenterWidget(){return this._topCenterWidget}get topRightWidget(){return this._topRightWidget}get middleLeftWidget(){return this._middleLeftWidget}get middleRightWidget(){return this._middleRightWidget}get bottomLeftWidget(){return this._bottomLeftWidget}get bottomCenterWidget(){return this._bottomCenterWidget}get bottomRightWidget(){return this._bottomRightWidget}get themeService(){return this._themeService}get selectionModel(){return this._selectionModel}set selectionModel(model){this._selectionModel=model}get defaultStyle(){return this._defaultStyle}set defaultStyle(style){this._defaultStyle=style}get dashedRect(){return this._dashedRect}get currentStyle(){return this._currentStyle}set currentStyle(style){style&&(this._currentStyle=style)}get isHelperSelection(){return this._isHelperSelection}get rowHeaderWidth(){return this._rowHeaderWidth}set rowHeaderWidth(width){this._rowHeaderWidth=width}get columnHeaderHeight(){return this._columnHeaderHeight}set columnHeaderHeight(height){this._columnHeaderHeight=height}setEvent(state){this.leftControl.evented=state,this.rightControl.evented=state,this.topControl.evented=state,this.bottomControl.evented=state}refreshSelectionFilled(val){this._selectionFilled$.next(val)}_setSizeAndStyleForSelectionControl(selectionStyle){this.currentStyle=selectionStyle;const defaultStyle=this._defaultStyle,currentStyle=this.currentStyle,{stroke=defaultStyle.stroke,widgets=defaultStyle.widgets,hasAutoFill=defaultStyle.hasAutoFill,AutofillStroke=defaultStyle.AutofillStroke,strokeDash,isAnimationDash}=currentStyle;let{strokeWidth=defaultStyle.strokeWidth,AutofillSize=defaultStyle.AutofillSize,AutofillStrokeWidth=defaultStyle.AutofillStrokeWidth}=currentStyle;const scale=this._getScale(),leftAdjustWidth=(strokeWidth+sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH)/2/scale;strokeWidth/=scale,AutofillSize/=scale,AutofillStrokeWidth/=scale<1?1:scale;const borderBuffer=sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH/scale,fixOnePixelBlurOffset=engineRender.FIX_ONE_PIXEL_BLUR_OFFSET/scale,{startX,startY,endX,endY}=this._selectionModel;if(this.leftControl.transformByState({height:endY-startY,left:-leftAdjustWidth+fixOnePixelBlurOffset,width:strokeWidth,strokeWidth:borderBuffer,top:-borderBuffer/2+fixOnePixelBlurOffset}),this.leftControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),this.rightControl.transformByState({height:endY-startY,left:endX-startX-leftAdjustWidth+fixOnePixelBlurOffset,width:strokeWidth,strokeWidth:borderBuffer,top:-borderBuffer/2+fixOnePixelBlurOffset}),this.rightControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),this.topControl.transformByState({width:endX-startX+strokeWidth,top:-leftAdjustWidth+fixOnePixelBlurOffset,left:-leftAdjustWidth+fixOnePixelBlurOffset,height:strokeWidth,strokeWidth:borderBuffer}),this.topControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),this.bottomControl.transformByState({width:endX-startX+strokeWidth,top:endY-startY-leftAdjustWidth+fixOnePixelBlurOffset,height:strokeWidth,left:-leftAdjustWidth+fixOnePixelBlurOffset,strokeWidth:borderBuffer}),this.bottomControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),strokeDash==null)this.dashedRect.hide(),this._stopAntLineAnimation();else{const dashRectBorderWidth=currentStyle.strokeWidth*2/scale;this.dashedRect.transformByState({height:endY-startY,width:endX-startX,strokeWidth:dashRectBorderWidth,left:-dashRectBorderWidth/2+fixOnePixelBlurOffset,top:-dashRectBorderWidth/2+fixOnePixelBlurOffset}),this.dashedRect.setProps({strokeDashArray:[0,strokeDash/scale]}),this._stopAntLineAnimation(),isAnimationDash!==!1&&this._startAntLineAnimation(),this.dashedRect.show()}if(hasAutoFill===!0&&!this._hasWidgets(widgets)){const fillProps={fill:stroke,stroke:AutofillStroke,strokeScaleEnabled:!1},sizeState={width:AutofillSize-AutofillStrokeWidth,height:AutofillSize-AutofillStrokeWidth,left:endX-startX-AutofillSize/2+AutofillStrokeWidth/2-fixOnePixelBlurOffset,top:endY-startY-AutofillSize/2+AutofillStrokeWidth/2-fixOnePixelBlurOffset,strokeWidth:AutofillStrokeWidth};this.fillControl.setProps(fillProps),this.fillControl.transformByState(sizeState),this.fillControl.show()}else this.fillControl.hide();this._updateBackgroundControl(selectionStyle),this._updateHeaderBackground(selectionStyle),this._updateWidgets(selectionStyle)}_refreshControlPosition(){const{startX,startY}=this._selectionModel;this.selectionShapeGroup.show(),this.selectionShapeGroup.translate(startX,startY),this.selectionShapeGroup.makeDirtyNoDebounce(!0)}updateStyle(style){this._setSizeAndStyleForSelectionControl(style),this._refreshControlPosition()}updateRange(range,primaryCell){this._selectionModel.setValue(range,primaryCell),this._setSizeAndStyleForSelectionControl(this._currentStyle),this._refreshControlPosition()}update(newSelectionRange,rowHeaderWidth=0,columnHeaderHeight=0,style,primaryCell){this._selectionModel.setValue(newSelectionRange,primaryCell),this._rowHeaderWidth=rowHeaderWidth,this._columnHeaderHeight=columnHeaderHeight,this._setSizeAndStyleForSelectionControl(style||this._currentStyle),this._refreshControlPosition()}updateCurrCell(primaryCell){this._selectionModel.setCurrentCell(primaryCell)}clearHighlight(){this._selectionModel.clearCurrentCell(),this._setSizeAndStyleForSelectionControl(this._currentStyle)}getScene(){return this._scene}dispose(){var _a58,_b,_c,_d,_e,_f,_g,_h,_i,_j,_k,_l,_m,_n,_o,_p,_q,_r,_s,_t,_u,_v,_w,_x;(_a58=this._leftBorder)==null||_a58.dispose(),(_b=this._rightBorder)==null||_b.dispose(),(_c=this._topBorder)==null||_c.dispose(),(_d=this._bottomBorder)==null||_d.dispose(),(_e=this._backgroundControlTop)==null||_e.dispose(),(_f=this._backgroundControlMiddleLeft)==null||_f.dispose(),(_g=this._backgroundControlMiddleRight)==null||_g.dispose(),(_h=this._backgroundControlBottom)==null||_h.dispose(),this._fillControl.dispose(),(_i=this._selectionShapeGroup)==null||_i.dispose(),(_j=this._rowHeaderBackground)==null||_j.dispose(),(_k=this._rowHeaderBorder)==null||_k.dispose(),(_l=this._rowHeaderGroup)==null||_l.dispose(),(_m=this._rowHeaderBackground)==null||_m.dispose(),(_n=this._columnHeaderBackground)==null||_n.dispose(),(_o=this._columnHeaderBorder)==null||_o.dispose(),(_p=this._columnHeaderGroup)==null||_p.dispose(),(_q=this._topLeftWidget)==null||_q.dispose(),(_r=this._topCenterWidget)==null||_r.dispose(),(_s=this._topRightWidget)==null||_s.dispose(),(_t=this._middleLeftWidget)==null||_t.dispose(),(_u=this._middleRightWidget)==null||_u.dispose(),(_v=this._bottomLeftWidget)==null||_v.dispose(),(_w=this._bottomCenterWidget)==null||_w.dispose(),(_x=this._bottomRightWidget)==null||_x.dispose(),super.dispose(),this._dispose$.next(this),this._dispose$.complete()}getCurrentCellInfo(){const currentCell=this.model.currentCell;if(currentCell){let currentRangeData;if(currentCell.isMerged){const mergeInfo=currentCell.mergeInfo;currentRangeData={startRow:mergeInfo.startRow,endRow:mergeInfo.endRow,startColumn:mergeInfo.startColumn,endColumn:mergeInfo.endColumn,startX:mergeInfo.startX,endX:mergeInfo.endX,startY:mergeInfo.startY,endY:mergeInfo.endY}}else{const{actualRow,actualColumn,startX,endX,startY,endY}=currentCell;currentRangeData={startRow:actualRow,endRow:actualRow,startColumn:actualColumn,endColumn:actualColumn,startX,endX,startY,endY}}return currentRangeData}}getValue(){return{...this._selectionModel.getValue(),style:this._currentStyle}}getRange(){return this._selectionModel.getValue().rangeWithCoord}enableHelperSelection(){this._isHelperSelection=!0}disableHelperSelection(){this._isHelperSelection=!1}_initialize(){this._defaultStyle=sheets.getNormalSelectionStyle(this._themeService),this._currentStyle=sheets.getNormalSelectionStyle(this._themeService),this._selectionModel=new SelectionRenderModel;const zIndex=this._zIndex;this._leftBorder=new engineRender.Rect("__SpreadsheetSelectionShapeLeftControl__"+zIndex,{zIndex}),this._rightBorder=new engineRender.Rect("__SpreadsheetSelectionShapeRightControl__"+zIndex,{zIndex}),this._topBorder=new engineRender.Rect("__SpreadsheetSelectionTopControl__"+zIndex,{zIndex}),this._bottomBorder=new engineRender.Rect("__SpreadsheetSelectionBottomControl__"+zIndex,{zIndex}),this._backgroundControlTop=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlTop__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._backgroundControlBottom=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlBottom__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._backgroundControlMiddleLeft=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlMiddleLeft__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._backgroundControlMiddleRight=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlMiddleRight__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._fillControl=new engineRender.Rect("__SpreadsheetSelectionFillControl__"+zIndex,{zIndex:zIndex+1}),this._dashedRect=new engineRender.DashedRect("__SpreadsheetDragDashControl__"+zIndex,{zIndex:zIndex+2,evented:!1,stroke:"#fff"});const shapes=[this._fillControl,this._leftBorder,this._rightBorder,this._topBorder,this._bottomBorder,this._backgroundControlTop,this._backgroundControlMiddleLeft,this._backgroundControlMiddleRight,this._backgroundControlBottom,this._dashedRect];this._widgetRects=this._initialWidget(),this._selectionShapeGroup=new engineRender.Group("__SpreadsheetSelectionShape__"+zIndex,...shapes,...this._widgetRects),this._selectionShapeGroup.hide(),this._selectionShapeGroup.evented=!1,this._selectionShapeGroup.zIndex=zIndex;const scene=this.getScene();scene.addObject(this._selectionShapeGroup,SHEET_COMPONENT_SELECTION_LAYER_INDEX),this.disposeWithMe(core.toDisposable(scene.onTransformChange$.subscribeEvent(state=>{state.type===engineRender.TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale&&(this._setSizeAndStyleForSelectionControl(this._currentStyle),this._refreshControlPosition())}))),this._initialHeader()}_initialHeader(){const zIndex=this._zIndex;this._rowHeaderBackground=new engineRender.Rect("__SpreadSheetSelectionRowHeaderBackground__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._rowHeaderBorder=new engineRender.Rect("__SpreadSheetSelectionRowHeaderBorder__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._rowHeaderGroup=new engineRender.Group("__SpreadSheetSelectionRowHeaderGroup__"+zIndex,this._rowHeaderBackground,this._rowHeaderBorder),this._rowHeaderGroup.hide(),this._rowHeaderGroup.evented=!1,this._rowHeaderGroup.zIndex=zIndex,this._columnHeaderBackground=new engineRender.Rect("__SpreadSheetSelectionColumnHeaderBackground__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._columnHeaderBorder=new engineRender.Rect("__SpreadSheetSelectionColumnHeaderBorder__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._columnHeaderGroup=new engineRender.Group("__SpreadSheetSelectionColumnHeaderGroup__"+zIndex,this._columnHeaderBackground,this._columnHeaderBorder),this._columnHeaderGroup.hide(),this._columnHeaderGroup.evented=!1,this._columnHeaderGroup.zIndex=zIndex,this.getScene().addObjects([this._rowHeaderGroup,this._columnHeaderGroup],SHEET_COMPONENT_HEADER_SELECTION_LAYER_INDEX)}_initialWidget(){const zIndex=this._zIndex;return this._topLeftWidget=new engineRender.Rect("__SpreadSheetSelectionTopLeftWidget__"+zIndex,{zIndex:zIndex+1}),this._topCenterWidget=new engineRender.Rect("__SpreadSheetSelectionTopCenterWidget__"+zIndex,{zIndex:zIndex+1}),this._topRightWidget=new engineRender.Rect("__SpreadSheetSelectionTopRightWidget__"+zIndex,{zIndex:zIndex+1}),this._middleLeftWidget=new engineRender.Rect("__SpreadSheetSelectionMiddleLeftWidget__"+zIndex,{zIndex:zIndex+1}),this._middleRightWidget=new engineRender.Rect("__SpreadSheetSelectionMiddleRightWidget__"+zIndex,{zIndex:zIndex+1}),this._bottomLeftWidget=new engineRender.Rect("__SpreadSheetSelectionBottomLeftWidget__"+zIndex,{zIndex:zIndex+1}),this._bottomCenterWidget=new engineRender.Rect("__SpreadSheetSelectionBottomCenterWidget__"+zIndex,{zIndex:zIndex+1}),this._bottomRightWidget=new engineRender.Rect("__SpreadSheetSelectionBottomRightWidget__"+zIndex,{zIndex:zIndex+1}),[this._topLeftWidget,this._topCenterWidget,this._topRightWidget,this._middleLeftWidget,this._middleRightWidget,this._bottomLeftWidget,this._bottomCenterWidget,this._bottomRightWidget]}_updateHeaderBackground(style){const{startX,startY,endX,endY,rangeType}=this._selectionModel,defaultStyle=this._defaultStyle;style==null&&(style=defaultStyle);const scale=this._getScale(),{stroke,hasRowHeader,rowHeaderFill=defaultStyle.rowHeaderFill,rowHeaderStroke=defaultStyle.rowHeaderStroke,hasColumnHeader,columnHeaderFill=defaultStyle.columnHeaderFill,columnHeaderStroke=defaultStyle.columnHeaderStroke}=style;let{rowHeaderStrokeWidth=defaultStyle.rowHeaderStrokeWidth,columnHeaderStrokeWidth=defaultStyle.columnHeaderStrokeWidth}=style;rowHeaderStrokeWidth/=scale,columnHeaderStrokeWidth/=scale;const rowHeaderWidth=this._rowHeaderWidth,columnHeaderHeight=this._columnHeaderHeight;if(hasColumnHeader===!0){let highlightTitleColor=columnHeaderFill;this._highlightHeader&&rangeType===core.RANGE_TYPE.COLUMN&&(highlightTitleColor=new core.ColorKit(stroke).setAlpha(SELECTION_TITLE_HIGHLIGHT_ALPHA).toString()),this._columnHeaderBackground.setProps({fill:highlightTitleColor}),this._columnHeaderBackground.resize(endX-startX,columnHeaderHeight),this._columnHeaderBorder.setProps({fill:columnHeaderStroke}),this._columnHeaderBorder.transformByState({width:endX-startX,height:columnHeaderStrokeWidth,top:columnHeaderHeight-columnHeaderStrokeWidth+1/scale}),this._columnHeaderGroup.show(),this._columnHeaderGroup.translate(startX,0)}else this._columnHeaderGroup.hide();if(this._columnHeaderGroup.makeDirty(!0),hasRowHeader===!0){let highlightTitleColor=rowHeaderFill;this._highlightHeader&&rangeType===core.RANGE_TYPE.ROW&&(highlightTitleColor=new core.ColorKit(stroke).setAlpha(SELECTION_TITLE_HIGHLIGHT_ALPHA).toString()),this._rowHeaderBackground.setProps({fill:highlightTitleColor}),this._rowHeaderBackground.resize(rowHeaderWidth,endY-startY),this._rowHeaderBorder.setProps({fill:rowHeaderStroke}),this._rowHeaderBorder.transformByState({width:rowHeaderStrokeWidth,height:endY-startY,left:rowHeaderWidth-rowHeaderStrokeWidth+1/scale}),this._rowHeaderGroup.show(),this._rowHeaderGroup.translate(0,startY)}else this._rowHeaderGroup.hide();this._rowHeaderGroup.makeDirty(!0)}_updateBackgroundControl(style){const{startX,startY,endX,endY}=this._selectionModel,defaultStyle=this._defaultStyle;style==null&&(style=defaultStyle);const scale=this._getScale(),{fill=defaultStyle.fill}=style;let{strokeWidth=defaultStyle.strokeWidth}=style;strokeWidth/=scale;const highlightSelection=this._selectionModel.highlightToSelection();if(!highlightSelection){this._backgroundControlTop.resize(endX-startX,endY-startY),this._backgroundControlTop.setProps({fill}),this._backgroundControlBottom.resize(0,0),this._backgroundControlMiddleLeft.resize(0,0),this._backgroundControlMiddleRight.resize(0,0);return}const{startX:h_startX,startY:h_startY,endX:h_endX,endY:h_endY}=highlightSelection,strokeOffset=strokeWidth/2,topConfig={left:-strokeOffset,top:-strokeOffset,width:endX-startX+strokeOffset*2,height:h_startY-startY+strokeOffset};topConfig.height<0&&(topConfig.width=0,topConfig.height=0),this._backgroundControlTop.transformByState(topConfig);const middleLeftConfig={left:-strokeOffset,top:h_startY-startY,width:h_startX-startX+strokeOffset,height:h_endY-h_startY};middleLeftConfig.width<0&&(middleLeftConfig.width=0,middleLeftConfig.height=0),this._backgroundControlMiddleLeft.transformByState(middleLeftConfig);const middleRightConfig={left:h_endX-startX-strokeOffset,top:h_startY-startY,width:endX-h_endX+strokeOffset*2,height:h_endY-h_startY};middleRightConfig.width<0&&(middleRightConfig.width=0,middleRightConfig.height=0),this._backgroundControlMiddleRight.transformByState(middleRightConfig);const middleBottomConfig={left:-strokeOffset,top:h_endY-startY,width:endX-startX+strokeOffset*2,height:endY-h_endY+strokeOffset};middleBottomConfig.height<0&&(middleBottomConfig.width=0,middleBottomConfig.height=0),this._backgroundControlBottom.transformByState(middleBottomConfig),this._backgroundControlTop.setProps({fill}),this._backgroundControlMiddleLeft.setProps({fill}),this._backgroundControlMiddleRight.setProps({fill}),this._backgroundControlBottom.setProps({fill})}_updateWidgets(style){const{startX,startY,endX,endY}=this._selectionModel,defaultStyle=this._defaultStyle;style==null&&(style=defaultStyle);const{stroke=defaultStyle.stroke,widgets=defaultStyle.widgets,widgetStroke=defaultStyle.widgetStroke}=style,scale=this._getScale();let{widgetSize=defaultStyle.widgetSize,widgetStrokeWidth=defaultStyle.widgetStrokeWidth}=style;widgetSize/=scale,widgetStrokeWidth/=scale;const position={left:-widgetSize/2+widgetStrokeWidth/2,center:(endX-startX)/2-widgetSize/2+widgetStrokeWidth/2,right:endX-startX-widgetSize/2+widgetStrokeWidth/2,top:-widgetSize/2,middle:(endY-startY)/2-widgetSize/2,bottom:endY-startY-widgetSize/2+widgetStrokeWidth/2},size=widgetSize-widgetStrokeWidth;this._widgetRects.forEach(widget=>{widget.setProps({fill:stroke,stroke:widgetStroke})}),widgets.tl===!0?(this._topLeftWidget.transformByState({height:size,width:size,left:position.left,top:position.top,strokeWidth:widgetStrokeWidth}),this._topLeftWidget.show()):this._topLeftWidget.hide(),widgets.tc===!0?(this._topCenterWidget.transformByState({height:size,width:size,left:position.center,top:position.top,strokeWidth:widgetStrokeWidth}),this._topCenterWidget.show()):this._topCenterWidget.hide(),widgets.tr===!0?(this._topRightWidget.transformByState({height:size,width:size,left:position.right,top:position.top,strokeWidth:widgetStrokeWidth}),this._topRightWidget.show()):this._topRightWidget.hide(),widgets.ml===!0?(this._middleLeftWidget.transformByState({height:size,width:size,left:position.left,top:position.middle,strokeWidth:widgetStrokeWidth}),this._middleLeftWidget.show()):this._middleLeftWidget.hide(),widgets.mr===!0?(this._middleRightWidget.transformByState({height:size,width:size,left:position.right,top:position.middle,strokeWidth:widgetStrokeWidth}),this._middleRightWidget.show()):this._middleRightWidget.hide(),widgets.bl===!0?(this._bottomLeftWidget.transformByState({height:size,width:size,left:position.left,top:position.bottom,strokeWidth:widgetStrokeWidth}),this._bottomLeftWidget.show()):this._bottomLeftWidget.hide(),widgets.bc===!0?(this._bottomCenterWidget.transformByState({height:size,width:size,left:position.center,top:position.bottom,strokeWidth:widgetStrokeWidth}),this._bottomCenterWidget.show()):this._bottomCenterWidget.hide(),widgets.br===!0?(this._bottomRightWidget.transformByState({height:size,width:size,left:position.right,top:position.bottom,strokeWidth:widgetStrokeWidth}),this._bottomRightWidget.show()):this._bottomRightWidget.hide()}_hasWidgets(widgets){if(widgets==null)return!1;const keys=Object.keys(widgets);if(keys.length===0)return!1;for(const key of keys)if(widgets[key]===!0)return!0;return!0}_getScale(){const{scaleX,scaleY}=this._scene.getAncestorScale();return Math.max(scaleX,scaleY)}_stopAntLineAnimation(){this._antLineOffset=0,engineRender.cancelRequestFrame(this._antRequestNewFrame)}_startAntLineAnimation(){const scale=this._getScale();this._antLineOffset+=.6/scale,this._antLineOffset>160/scale&&(this._antLineOffset=0),this.dashedRect.setProps({strokeDashOffset:-this._antLineOffset}),this._antRequestNewFrame=engineRender.requestNewFrame(()=>{this._startAntLineAnimation()})}};__name(_SelectionControl,"SelectionControl");let SelectionControl=_SelectionControl;const _SelectionLayer=class _SelectionLayer extends engineRender.Layer{render(ctx,isMaxLayer=!1){const startTime=core.Tools.now();return super.render(ctx,isMaxLayer),this._afterRender(startTime),this}_afterRender(startTime){this.scene.getEngine().renderFrameTimeMetric$.next(["selectionLayer",core.Tools.now()-startTime])}};__name(_SelectionLayer,"SelectionLayer");let SelectionLayer=_SelectionLayer;const HELPER_SELECTION_TEMP_NAME="__SpreadsheetHelperSelectionTempRect",SELECTION_CONTROL_DELETING_LIGHTEN=35,_SelectionShapeExtension=class _SelectionShapeExtension{constructor(_control,_skeleton,_scene,_themeService,_injector,_selectionHooks){__publicField(this,"_startOffsetX",0);__publicField(this,"_startOffsetY",0);__publicField(this,"_relativeSelectionPositionRow",0);__publicField(this,"_relativeSelectionPositionColumn",0);__publicField(this,"_relativeSelectionRowLength",0);__publicField(this,"_relativeSelectionColumnLength",0);__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_helperSelection");__publicField(this,"_scrollTimer");__publicField(this,"_activeViewport");__publicField(this,"_targetSelection",{startY:0,endY:0,startX:0,endX:0,startRow:-1,endRow:-1,startColumn:-1,endColumn:-1});__publicField(this,"_isInMergeState",!1);__publicField(this,"_fillControlColors",[]);this._control=_control,this._skeleton=_skeleton,this._scene=_scene,this._themeService=_themeService,this._injector=_injector,this._selectionHooks=_selectionHooks,this._initialControl(),this._initialWidget(),this._initialFill(),this._control.dispose$.subscribe(()=>{this.dispose()})}get isHelperSelection(){return this._control.isHelperSelection}dispose(){var _a58,_b;(_a58=this._scrollTimer)==null||_a58.dispose(),this._fillControlColors=[],this._clearObserverEvent(),(_b=this._helperSelection)==null||_b.dispose()}_getFreeze(){var _a58,_b;return(_b=(_a58=this._injector.get(engineRender.IRenderManagerService).withCurrentTypeOfUnit(core.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService))==null?void 0:_a58.getCurrent())==null?void 0:_b.skeleton.getWorksheetConfig().freeze}_isSelectionInViewport(selection,viewport){const freeze=this._getFreeze()||{startRow:-1,startColumn:-1,xSplit:0,ySplit:0};switch(viewport.viewportKey){case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN:return selection.endRow>=freeze.startRow&&selection.endColumn>=freeze.startColumn;case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP:case engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT:return selection.endColumn>=freeze.startColumn&&selection.startRow<freeze.startRow;case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT:case engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM:return selection.endRow>=freeze.startRow&&selection.startColumn<freeze.startColumn;case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP:case engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT:case engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP:case engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP:return selection.startRow<freeze.startRow&&selection.startColumn<freeze.startColumn}}_clearObserverEvent(){var _a58,_b;(_a58=this._scenePointerMoveSub)==null||_a58.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null}_initialControl(){const{leftControl,rightControl,topControl,bottomControl}=this._control;[leftControl,rightControl,topControl,bottomControl].forEach(control=>{control.onPointerEnter$.subscribeEvent(()=>{var _a58;((_a58=this._injector.get(ISheetSelectionRenderService,core.Quantity.OPTIONAL))==null?void 0:_a58.interceptor.fetchThroughInterceptors(RANGE_MOVE_PERMISSION_CHECK)(!1,null))!==!1&&control.setCursor(engineRender.CURSOR_TYPE.MOVE)}),control.onPointerLeave$.subscribeEvent(()=>{control.resetCursor()}),control.onPointerDown$.subscribeEvent(this._controlEvent.bind(this))})}_controlMoving(moveOffsetX,moveOffsetY){var _a58;const scene=this._scene,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY])),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=this._skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,maxRow=this._skeleton.getRowCount()-1,maxColumn=this._skeleton.getColumnCount()-1;let startRow=row+this._relativeSelectionPositionRow;startRow<0&&(startRow=0);let endRow=startRow+this._relativeSelectionRowLength;endRow>maxRow&&(endRow=maxRow,endRow-startRow<this._relativeSelectionRowLength&&(startRow=endRow-this._relativeSelectionRowLength));let startColumn=column+this._relativeSelectionPositionColumn;startColumn<0&&(startColumn=0);let endColumn=startColumn+this._relativeSelectionColumnLength;endColumn>maxColumn&&(endColumn=maxColumn,endColumn-startColumn<this._relativeSelectionColumnLength&&(startColumn=endColumn-this._relativeSelectionColumnLength));const startCell=this._skeleton.getNoMergeCellPositionByIndex(startRow,startColumn),endCell=this._skeleton.getNoMergeCellPositionByIndex(endRow,endColumn),startY=(startCell==null?void 0:startCell.startY)||0,endY=(endCell==null?void 0:endCell.endY)||0,startX=(startCell==null?void 0:startCell.startX)||0,endX=(endCell==null?void 0:endCell.endX)||0;(_a58=this._helperSelection)==null||_a58.transformByState({left:startX,top:startY,width:endX-startX,height:endY-startY}),this._targetSelection={startY,endY,startX,endX,startRow,endRow,startColumn,endColumn},this._control.selectionMoving$.next(this._targetSelection)}_controlEvent(evt){const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,scene=this._scene,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords,scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords),{scaleX,scaleY}=scene.getAncestorScale(),actualSelection=this._skeleton.getCellPositionByOffset(newEvtOffsetX,newEvtOffsetY,scaleX,scaleY,scrollXY);this._startOffsetX=newEvtOffsetX,this._startOffsetY=newEvtOffsetY;const{row,column}=actualSelection,{startRow:originStartRow,startColumn:originStartColumn,endRow:originEndRow,endColumn:originEndColumn}=this._control.model;let fixRow=0,fixColumn=0;row<originStartRow?fixRow-=1:row>originEndRow&&(fixRow+=1),column<originStartColumn?fixColumn-=1:column>originEndColumn&&(fixColumn+=1),this._relativeSelectionPositionRow=originStartRow-row+fixRow,this._relativeSelectionPositionColumn=originStartColumn-column+fixColumn,this._relativeSelectionRowLength=originEndRow-originStartRow,this._relativeSelectionColumnLength=originEndColumn-originStartColumn;const style=this._control.currentStyle,scale=this._getScale();this.isHelperSelection&&(this._helperSelection=new engineRender.Rect(HELPER_SELECTION_TEMP_NAME,{stroke:style.stroke,strokeWidth:style.strokeWidth/scale}),scene.addObject(this._helperSelection));const viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollTimer=engineRender.ScrollTimer.create(scene);this._scrollTimer=scrollTimer,scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY,viewMain),scene.disableObjectsEvent(),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a58;const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt;if(((_a58=this._injector.get(ISheetSelectionRenderService,core.Quantity.OPTIONAL))==null?void 0:_a58.interceptor.fetchThroughInterceptors(RANGE_MOVE_PERMISSION_CHECK)(!1,null))===!1)return;const{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._controlMoving(newMoveOffsetX,newMoveOffsetY),scene.setCursor(engineRender.CURSOR_TYPE.MOVE),scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._controlMoving(newMoveOffsetX,newMoveOffsetY)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a58,_b,_c,_d;(_a58=this._helperSelection)==null||_a58.dispose();const scene2=this._scene;scene2.resetCursor(),this._clearObserverEvent(),scene2.enableObjectsEvent(),(_b=this._scrollTimer)==null||_b.dispose(),this._control.selectionMoved$.next(this._targetSelection),(_d=(_c=this._selectionHooks).selectionMoveEnd)==null||_d.call(_c)})}_initialWidget(){const{topLeftWidget,topCenterWidget,topRightWidget,middleLeftWidget,middleRightWidget,bottomLeftWidget,bottomCenterWidget,bottomRightWidget}=this._control,cursors=[engineRender.CURSOR_TYPE.NORTH_WEST_RESIZE,engineRender.CURSOR_TYPE.NORTH_RESIZE,engineRender.CURSOR_TYPE.NORTH_EAST_RESIZE,engineRender.CURSOR_TYPE.WEST_RESIZE,engineRender.CURSOR_TYPE.EAST_RESIZE,engineRender.CURSOR_TYPE.SOUTH_WEST_RESIZE,engineRender.CURSOR_TYPE.SOUTH_RESIZE,engineRender.CURSOR_TYPE.SOUTH_EAST_RESIZE];[topLeftWidget,topCenterWidget,topRightWidget,middleLeftWidget,middleRightWidget,bottomLeftWidget,bottomCenterWidget,bottomRightWidget].forEach((control,index)=>{control.onPointerEnter$.subscribeEvent(()=>{control.setCursor(cursors[index])}),control.onPointerLeave$.subscribeEvent(()=>{control.resetCursor()}),control.onPointerDown$.subscribeEvent(evt=>{this._widgetPointerDownEvent(evt,cursors[index])})})}_widgetPointerDownEvent(evt,cursor){const scene=this._scene,{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords;this._startOffsetX=evtOffsetX,this._startOffsetY=evtOffsetY;const{startRow:originStartRow,startColumn:originStartColumn,endRow:originEndRow,endColumn:originEndColumn}=this._control.model,startRow=Math.min(originStartRow,originEndRow),startColumn=Math.min(originStartColumn,originEndColumn),endRow=Math.max(originStartRow,originEndRow),endColumn=Math.max(originStartColumn,originEndColumn);this._relativeSelectionPositionRow=startRow,this._relativeSelectionPositionColumn=startColumn,this._relativeSelectionRowLength=endRow-startRow,this._relativeSelectionColumnLength=endColumn-startColumn,cursor===engineRender.CURSOR_TYPE.NORTH_WEST_RESIZE?(this._relativeSelectionPositionRow=endRow,this._relativeSelectionPositionColumn=endColumn):cursor===engineRender.CURSOR_TYPE.NORTH_RESIZE?this._relativeSelectionPositionRow=endRow:cursor===engineRender.CURSOR_TYPE.NORTH_EAST_RESIZE?this._relativeSelectionPositionRow=endRow:cursor===engineRender.CURSOR_TYPE.WEST_RESIZE?this._relativeSelectionPositionColumn=endColumn:cursor===engineRender.CURSOR_TYPE.SOUTH_WEST_RESIZE?this._relativeSelectionPositionColumn=endColumn:cursor===engineRender.CURSOR_TYPE.SOUTH_RESIZE&&(this._relativeSelectionPositionRow=startRow);const scrollTimer=engineRender.ScrollTimer.create(scene);scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY),this._scrollTimer=scrollTimer,scene.disableObjectsEvent(),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._widgetMoving(newMoveOffsetX,newMoveOffsetY,cursor),scene.setCursor(cursor),scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._widgetMoving(newMoveOffsetX,newMoveOffsetY,cursor)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a58,_b,_c;const scene2=this._scene;scene2.resetCursor(),this._clearObserverEvent(),scene2.enableObjectsEvent(),(_a58=this._scrollTimer)==null||_a58.dispose(),this._control.selectionScaled$.next(this._targetSelection),(_c=(_b=this._selectionHooks).selectionMoveEnd)==null||_c.call(_b)})}_widgetMoving(moveOffsetX,moveOffsetY,cursor){const scene=this._scene,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startOffsetX,this._startOffsetY])),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=this._skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,{rowHeaderWidth,columnHeaderHeight}=this._skeleton;let startRow=this._relativeSelectionPositionRow,startColumn=this._relativeSelectionPositionColumn,endRow=row,endColumn=column;cursor===engineRender.CURSOR_TYPE.NORTH_WEST_RESIZE?(startRow=row,startColumn=column,endRow=this._relativeSelectionPositionRow,endColumn=this._relativeSelectionPositionColumn):cursor===engineRender.CURSOR_TYPE.NORTH_RESIZE?(startRow=row,startColumn=this._relativeSelectionPositionColumn,endRow=this._relativeSelectionPositionRow,endColumn=this._relativeSelectionPositionColumn+this._relativeSelectionColumnLength):cursor===engineRender.CURSOR_TYPE.NORTH_EAST_RESIZE?(startRow=row,startColumn=this._relativeSelectionPositionColumn,endRow=this._relativeSelectionPositionRow,endColumn=column):cursor===engineRender.CURSOR_TYPE.WEST_RESIZE?(startRow=this._relativeSelectionPositionRow,startColumn=column,endRow=this._relativeSelectionPositionRow+this._relativeSelectionRowLength,endColumn=this._relativeSelectionPositionColumn):cursor===engineRender.CURSOR_TYPE.EAST_RESIZE?endRow=this._relativeSelectionPositionRow+this._relativeSelectionRowLength:cursor===engineRender.CURSOR_TYPE.SOUTH_WEST_RESIZE?(startRow=this._relativeSelectionPositionRow,startColumn=column,endRow=row,endColumn=this._relativeSelectionPositionColumn):cursor===engineRender.CURSOR_TYPE.SOUTH_RESIZE&&(startRow=this._relativeSelectionPositionRow,startColumn=this._relativeSelectionPositionColumn,endRow=row,endColumn=this._relativeSelectionPositionColumn+this._relativeSelectionColumnLength);const{startRow:finalStartRow,startColumn:finalStartColumn,endRow:finalEndRow,endColumn:finalEndColumn}=this._swapPositions(startRow,startColumn,endRow,endColumn),startCell=this._skeleton.getNoMergeCellPositionByIndex(finalStartRow,finalStartColumn),endCell=this._skeleton.getNoMergeCellPositionByIndex(finalEndRow,finalEndColumn),startY=(startCell==null?void 0:startCell.startY)||0,endY=(endCell==null?void 0:endCell.endY)||0,startX=(startCell==null?void 0:startCell.startX)||0,endX=(endCell==null?void 0:endCell.endX)||0;this._targetSelection={startY,endY,startX,endX,startRow,endRow,startColumn,endColumn},this._control.update(this._targetSelection,rowHeaderWidth,columnHeaderHeight,this._control.currentStyle),this._control.clearHighlight(),this._control.selectionScaling$.next(this._targetSelection)}_initialFill(){const{fillControl}=this._control;fillControl.onPointerEnter$.subscribeEvent(evt=>{this._injector.get(ISheetSelectionRenderService).interceptor.fetchThroughInterceptors(RANGE_FILL_PERMISSION_CHECK)(!1,{x:evt.offsetX,y:evt.offsetY,skeleton:this._skeleton,scene:this._scene})&&fillControl.setCursor(engineRender.CURSOR_TYPE.CROSSHAIR)}),fillControl.onPointerLeave$.subscribeEvent(()=>{fillControl.resetCursor()}),fillControl.onPointerDown$.subscribeEvent(this._fillEvent.bind(this))}_fillMoving(moveOffsetX,moveOffsetY){var _a58,_b,_c;const scene=this._scene,scrollXY=scene.getViewportScrollXY(this._activeViewport),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=this._skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,moveRelativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY])),maxRow=this._skeleton.getRowCount()-1,maxColumn=this._skeleton.getColumnCount()-1;let startRow=this._relativeSelectionPositionRow,startColumn=this._relativeSelectionPositionColumn,endRow=this._relativeSelectionPositionRow+this._relativeSelectionRowLength,endColumn=this._relativeSelectionPositionColumn+this._relativeSelectionColumnLength,isLighten=!1,isRowDropping=!0;if((column<startColumn||column>endColumn)&&row>=startRow&&row<=endRow){const rulerValue=this._fillRuler(column,startColumn,endColumn,this._relativeSelectionColumnLength,maxColumn);startColumn=rulerValue.startRowOrColumn,endColumn=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten,isRowDropping=!1}else if((row<startRow||row>endRow)&&column>=startColumn&&column<=endColumn){const rulerValue=this._fillRuler(row,startRow,endRow,this._relativeSelectionRowLength,maxRow);startRow=rulerValue.startRowOrColumn,endRow=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten}else if(Math.abs(this._startOffsetX-moveRelativeCoords.x-scrollXY.x)/2>Math.abs(this._startOffsetY-moveRelativeCoords.y-scrollXY.y)){const rulerValue=this._fillRuler(column,startColumn,endColumn,this._relativeSelectionColumnLength,maxColumn);startColumn=rulerValue.startRowOrColumn,endColumn=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten,isRowDropping=!1}else{const rulerValue=this._fillRuler(row,startRow,endRow,this._relativeSelectionRowLength,maxRow);startRow=rulerValue.startRowOrColumn,endRow=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten}const startCell=this._skeleton.getNoMergeCellPositionByIndex(startRow,startColumn),endCell=this._skeleton.getNoMergeCellPositionByIndex(endRow,endColumn),startY=(startCell==null?void 0:startCell.startY)||0,endY=(endCell==null?void 0:endCell.endY)||0,startX=(startCell==null?void 0:startCell.startX)||0,endX=(endCell==null?void 0:endCell.endX)||0;isLighten?this._controlHandler((o,index)=>{const newColor=new core.ColorKit(this._fillControlColors[index]).lighten(SELECTION_CONTROL_DELETING_LIGHTEN).toRgbString();o.setProps({fill:newColor})}):this._controlHandler((o,index)=>{o.setProps({fill:this._fillControlColors[index]})});const SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE=sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH/this._getScale();startRow===endRow&&isRowDropping===!0||startColumn===endColumn&&isRowDropping===!1?(_a58=this._helperSelection)==null||_a58.hide():((_b=this._helperSelection)==null||_b.transformByState({left:startX-SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE/2,top:startY-SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE/2,width:endX-startX,height:endY-startY}),(_c=this._helperSelection)==null||_c.show()),this._targetSelection={startY,endY,startX,endX,startRow,endRow,startColumn,endColumn},this._control.selectionFilling$.next(this._targetSelection)}_fillEvent(evt){const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,scene=this._scene,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords;this._startOffsetX=newEvtOffsetX,this._startOffsetY=newEvtOffsetY;const{startRow:originStartRow,startColumn:originStartColumn,endRow:originEndRow,endColumn:originEndColumn}=this._control.model;this._isInMergeState=this._hasMergeInRange(originStartRow,originStartColumn,originEndRow,originEndColumn),this._relativeSelectionPositionRow=originStartRow,this._relativeSelectionPositionColumn=originStartColumn,this._relativeSelectionRowLength=originEndRow-originStartRow,this._relativeSelectionColumnLength=originEndColumn-originStartColumn;const style=this._control.currentStyle;let stroke=style==null?void 0:style.stroke,strokeWidth=style==null?void 0:style.strokeWidth;const defaultStyle=sheets.getNormalSelectionStyle(this._themeService);stroke==null&&(stroke=defaultStyle.stroke),strokeWidth==null&&(strokeWidth=defaultStyle.strokeWidth);const scale=this._getScale();strokeWidth/=scale;const SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE=sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH/scale,darkenColor=new core.ColorKit(stroke).darken(2).toRgbString();this.isHelperSelection&&(this._helperSelection=new engineRender.Rect(HELPER_SELECTION_TEMP_NAME,{stroke:darkenColor,strokeWidth:strokeWidth+SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE/2}),scene.addObject(this._helperSelection)),this._activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY]));const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollTimer=engineRender.ScrollTimer.create(scene,this._activeViewport.viewportKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN?engineRender.ScrollTimerType.ALL:engineRender.ScrollTimerType.NONE);scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY,viewportMain),this._scrollTimer=scrollTimer,scene.disableObjectsEvent(),this._controlHandler(o=>{this._fillControlColors.push(o.fill)}),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a58;const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,currentViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));if(!this._injector.get(ISheetSelectionRenderService).interceptor.fetchThroughInterceptors(RANGE_FILL_PERMISSION_CHECK)(!1,{x:evt.offsetX,y:evt.offsetY,skeleton:this._skeleton,scene:this._scene}))return;const{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._fillMoving(newMoveOffsetX,newMoveOffsetY),scene.setCursor(engineRender.CURSOR_TYPE.CROSSHAIR);const newSelection=this._targetSelection;if(viewportMain&&currentViewport&&((_a58=this._activeViewport)==null?void 0:_a58.viewportKey)!==(currentViewport==null?void 0:currentViewport.viewportKey)){let movingRange;newSelection.startRow!==originStartRow?(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.Y,movingRange={...newSelection,endRow:newSelection.startRow}):newSelection.endRow!==originEndRow?(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.Y,movingRange={...newSelection,startRow:newSelection.endRow}):newSelection.startColumn!==originStartColumn?(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.X,movingRange={...newSelection,endColumn:newSelection.startColumn}):(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.X,movingRange={...newSelection,startColumn:newSelection.endColumn}),this._isSelectionInViewport(movingRange,currentViewport)&&(viewportMain.scrollToBarPos({x:scrollTimer.scrollTimerType===engineRender.ScrollTimerType.X?0:void 0,y:scrollTimer.scrollTimerType===engineRender.ScrollTimerType.Y?0:void 0}),this._activeViewport=currentViewport)}scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._fillMoving(newMoveOffsetX,newMoveOffsetY)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a58,_b;(_a58=this._helperSelection)==null||_a58.dispose();const scene2=this._scene;scene2.resetCursor(),this._clearObserverEvent(),scene2.enableObjectsEvent(),(_b=this._scrollTimer)==null||_b.dispose(),this._control.refreshSelectionFilled(this._targetSelection),this._isInMergeState=!1,this._controlHandler((o,index)=>{o.setProps({fill:this._fillControlColors[index]})}),this._fillControlColors=[]})}_hasMergeInRange(startRow,startColumn,endRow,endColumn){return this._skeleton.worksheet.getMergedCellRange(startRow,startColumn,endRow,endColumn).length>0}_swapPositions(startRow,startColumn,endRow,endColumn){const finalStartRow=Math.min(startRow,endRow),finalStartColumn=Math.min(startColumn,endColumn),finalEndRow=Math.max(startRow,endRow),finalEndColumn=Math.max(startColumn,endColumn);return{startRow:finalStartRow,startColumn:finalStartColumn,endRow:finalEndRow,endColumn:finalEndColumn}}_controlHandler(func){const{leftControl,rightControl,topControl,bottomControl,backgroundControlTop,backgroundControlMiddleLeft,backgroundControlMiddleRight,backgroundControlBottom,fillControl}=this._control,objects=[leftControl,rightControl,topControl,bottomControl,backgroundControlTop,backgroundControlMiddleLeft,backgroundControlMiddleRight,backgroundControlBottom,fillControl];for(let i=0,len=objects.length;i<len;i++){const object=objects[i];func(object,i)}}_fillRuler(rowOrColumn,startRowOrColumn,endRowOrColumn,rowOrColumnLength,maxRowOrColumn){let isLighten=!1;if(rowOrColumn<startRowOrColumn)if(this._isInMergeState&&rowOrColumn<startRowOrColumn){const current=startRowOrColumn-rowOrColumn,rangeRowCount=rowOrColumnLength+1,step=Math.ceil(current/rangeRowCount);let newStartRow=startRowOrColumn-step*rangeRowCount;newStartRow<0&&(newStartRow=startRowOrColumn-(step-1)*rangeRowCount),startRowOrColumn=newStartRow}else startRowOrColumn=rowOrColumn;else if(rowOrColumn>=startRowOrColumn&&rowOrColumn<=endRowOrColumn)isLighten=!0,this._isInMergeState||(endRowOrColumn=rowOrColumn);else if(this._isInMergeState&&rowOrColumn>endRowOrColumn){const current=rowOrColumn-endRowOrColumn,rangeRowCount=rowOrColumnLength+1,step=Math.ceil(current/rangeRowCount);let newEndRow=endRowOrColumn+step*rangeRowCount;newEndRow>maxRowOrColumn&&(newEndRow=endRowOrColumn+(step-1)*rangeRowCount),endRowOrColumn=newEndRow}else endRowOrColumn=rowOrColumn;return{rowOrColumn,startRowOrColumn,endRowOrColumn,isLighten}}_getScale(){const{scaleX,scaleY}=this._scene.getAncestorScale();return Math.max(scaleX,scaleY)}};__name(_SelectionShapeExtension,"SelectionShapeExtension");let SelectionShapeExtension=_SelectionShapeExtension;function attachSelectionWithCoord(selection,skeleton){const{range,primary,style}=selection;return{rangeWithCoord:attachRangeWithCoord(skeleton,range),primaryWithCoord:primary?attachPrimaryWithCoord(primary,skeleton):null,style}}__name(attachSelectionWithCoord,"attachSelectionWithCoord");function attachPrimaryWithCoord(primary,skeleton){const{actualRow,actualColumn,isMerged,isMergedMainCell,startRow,startColumn,endRow,endColumn}=primary,cellPosition=skeleton.getNoMergeCellPositionByIndex(actualRow,actualColumn),startCell=skeleton.getNoMergeCellPositionByIndex(startRow,startColumn),endCell=skeleton.getNoMergeCellPositionByIndex(endRow,endColumn);return{actualRow,actualColumn,isMerged,isMergedMainCell,startX:cellPosition.startX,startY:cellPosition.startY,endX:cellPosition.endX,endY:cellPosition.endY,mergeInfo:{startRow,startColumn,endRow,endColumn,startY:(startCell==null?void 0:startCell.startY)||0,endY:(endCell==null?void 0:endCell.endY)||0,startX:(startCell==null?void 0:startCell.startX)||0,endX:(endCell==null?void 0:endCell.endX)||0}}}__name(attachPrimaryWithCoord,"attachPrimaryWithCoord");const ISheetSelectionRenderService=core.createIdentifier("univer.sheet.selection-render-service"),_BaseSelectionRenderService=class _BaseSelectionRenderService extends core.Disposable{constructor(_injector,_themeService,_shortcutService,_sheetSkeletonManagerService){super();__publicField(this,"_downObserver");__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_controlFillConfig$",new rxjs.BehaviorSubject(null));__publicField(this,"controlFillConfig$",this._controlFillConfig$.asObservable());__publicField(this,"_selectionControls",[]);__publicField(this,"_startRangeWhenPointerDown",{startY:0,endY:0,startX:0,endX:0,startRow:-1,endRow:-1,startColumn:-1,endColumn:-1});__publicField(this,"_startViewportPosX",0);__publicField(this,"_startViewportPosY",0);__publicField(this,"_scrollTimer");__publicField(this,"_cancelDownSubscription");__publicField(this,"_cancelUpSubscription");__publicField(this,"_skeleton");__publicField(this,"_scene");__publicField(this,"_isHeaderHighlight",!0);__publicField(this,"_shouldDetectMergedCells",!0);__publicField(this,"_selectionStyle");__publicField(this,"_remainLastEnabled",!1);__publicField(this,"_skipLastEnabled",!1);__publicField(this,"_singleSelectionEnabled",!1);__publicField(this,"_selectionMoveEnd$",new rxjs.BehaviorSubject([]));__publicField(this,"selectionMoveEnd$",this._selectionMoveEnd$.asObservable());__publicField(this,"_selectionMoving$",new rxjs.Subject);__publicField(this,"selectionMoving$",this._selectionMoving$.asObservable());__publicField(this,"_selectionMoveStart$",new rxjs.Subject);__publicField(this,"selectionMoveStart$",this._selectionMoveStart$.asObservable());__publicField(this,"_selectionMoving",!1);__publicField(this,"_activeViewport");__publicField(this,"interceptor",new core.InterceptorManager({RANGE_MOVE_PERMISSION_CHECK,RANGE_FILL_PERMISSION_CHECK}));__publicField(this,"_escapeShortcutDisposable",null);this._injector=_injector,this._themeService=_themeService,this._shortcutService=_shortcutService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._resetSelectionStyle(),this._initMoving()}get selectionMoving(){return this._selectionMoving}_initMoving(){this.disposeWithMe(this._selectionMoving$.subscribe(()=>{this._selectionMoving=!0})),this.disposeWithMe(this._selectionMoveEnd$.subscribe(()=>{this._selectionMoving=!1}))}_setSelectionStyle(style){this._selectionStyle=style}_resetSelectionStyle(){this._setSelectionStyle(sheets.getNormalSelectionStyle(this._themeService))}getViewPort(){return this._activeViewport}setSingleSelectionEnabled(enabled=!1){this._singleSelectionEnabled=enabled}_addSelectionControlBySelectionData(selection){var _a58;const skeleton=this._skeleton,style=(_a58=selection.style)!=null?_a58:sheets.getNormalSelectionStyle(this._themeService),scene=this._scene;if(!scene||!skeleton)return;const{rangeWithCoord,primaryWithCoord}=selection,{rangeType}=rangeWithCoord,control=this.newSelectionControl(scene,rangeType||core.RANGE_TYPE.NORMAL,skeleton);new SelectionShapeExtension(control,skeleton,scene,this._themeService,this._injector,{selectionMoveEnd:__name(()=>{this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())},"selectionMoveEnd")});const{rowHeaderWidth,columnHeaderHeight}=skeleton;control.update(rangeWithCoord,rowHeaderWidth,columnHeaderHeight,style,primaryWithCoord)}newSelectionControl(scene,_rangeType,skeleton){const zIndex=this.getSelectionControls().length,{rowHeaderWidth,columnHeaderHeight}=skeleton,control=new SelectionControl(scene,zIndex,this._themeService,this._isHeaderHighlight,{rowHeaderWidth,columnHeaderHeight});return this._selectionControls.push(control),control}updateControlForCurrentByRangeData(selections){const selectionControls=this.getSelectionControls();if(!(!selectionControls||this._skeleton==null))for(let i=0,len=selections.length;i<len;i++){const{rangeWithCoord,primaryWithCoord}=selections[i],control=selectionControls[i];control&&control.updateRange(rangeWithCoord,primaryWithCoord)}}refreshSelectionMoveStart(){this._selectionMoveStart$.next(this.getSelectionDataWithStyle())}refreshSelectionMoveEnd(){this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}_changeRuntime(skeleton,scene,viewport){this._skeleton=skeleton,this._scene=scene,this._activeViewport=viewport||(scene==null?void 0:scene.getViewports()[0]),scene.findLayerByZIndex(SHEET_COMPONENT_SELECTION_LAYER_INDEX)||scene.addLayer(new SelectionLayer(scene,[],SHEET_COMPONENT_SELECTION_LAYER_INDEX))}getSkeleton(){return this._skeleton}getSelectionDataWithStyle(){const selectionControls=this._selectionControls,[unitId,sheetId]=this._skeleton.getLocation();return selectionControls.map(control=>{const v=control.getValue();return v.rangeWithCoord.sheetId=sheetId,v.rangeWithCoord.unitId=unitId,v})}getSelectionControls(){return this._selectionControls}_clearSelectionControls(){const allSelectionControls=this._selectionControls;for(const control of allSelectionControls)control.dispose();this._selectionControls.length=0}_getFreeze(){var _a58;return(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton.getWorksheetConfig().freeze}_getViewportByCell(row,column){if(row===void 0||column===void 0)return null;const freeze=this._getFreeze();if(!freeze||freeze.startRow<=0&&freeze.startColumn<=0)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(row>freeze.startRow&&column>freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(row<=freeze.startRow&&column<=freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP);if(row<=freeze.startRow&&column>freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP);if(row>freeze.startRow&&column<=freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT)}getActiveRange(){const controls=this.getSelectionControls(),model=controls&&controls[controls.length-1].model;return model&&{startRow:model.startRow,startColumn:model.startColumn,endRow:model.endRow,endColumn:model.endColumn}}getActiveSelectionControl(){const controls=this.getSelectionControls();if(controls)return controls[controls.length-1]}endSelection(){var _a58;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(_a58=this._escapeShortcutDisposable)==null||_a58.dispose(),this._escapeShortcutDisposable=null}_reset(){var _a58;this._clearSelectionControls(),(_a58=this._downObserver)==null||_a58.unsubscribe(),this._downObserver=null}resetAndEndSelection(){this.endSelection(),this._reset()}_onPointerDown(evt,_zIndex=0,rangeType=core.RANGE_TYPE.NORMAL,viewport,scrollTimerType=engineRender.ScrollTimerType.ALL){var _a58;this._shouldDetectMergedCells=rangeType===core.RANGE_TYPE.NORMAL;const skeleton=this._skeleton,scene=this._scene;if(!scene||!skeleton)return;viewport&&(this._activeViewport=viewport);const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!viewportMain)return;const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY]));let{x:viewportPosX,y:viewportPosY}=relativeCoords;this._startViewportPosX=viewportPosX,this._startViewportPosY=viewportPosY;const scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords),{scaleX,scaleY}=scene.getAncestorScale(),cursorCellRangeInfo=this._getCellRangeByCursorPosition(viewportPosX,viewportPosY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return;const{rangeWithCoord:cursorCellRange,primaryWithCoord:primaryCursorCellRange}=cursorCellRangeInfo,cursorCellRangeWithRangeType={...cursorCellRange,rangeType};this._startRangeWhenPointerDown={...cursorCellRange,rangeType};let activeSelectionControl=this.getActiveSelectionControl();const curControls=this.getSelectionControls();for(const control of curControls){if(evt.button===2&&control.model.isInclude(cursorCellRangeWithRangeType)){activeSelectionControl=control;return}if(control.model.isEqual(cursorCellRangeWithRangeType)){activeSelectionControl=control;break}evt.shiftKey||control.clearHighlight()}this._checkClearPreviousControls(evt);const currentCell=activeSelectionControl==null?void 0:activeSelectionControl.model.currentCell,expandByShiftKey=evt.shiftKey&&currentCell,remainLastEnable=this._remainLastEnabled&&!evt.ctrlKey&&!evt.shiftKey&&!this._skipLastEnabled&&!this._singleSelectionEnabled;expandByShiftKey&&currentCell?this._performSelectionByTwoCells(currentCell,cursorCellRangeWithRangeType,skeleton,rangeType,activeSelectionControl):remainLastEnable&&activeSelectionControl?this._updateSelectionControlByRange(activeSelectionControl,cursorCellRangeWithRangeType,primaryCursorCellRange):(activeSelectionControl=this.newSelectionControl(scene,rangeType,skeleton),this._updateSelectionControlByRange(activeSelectionControl,cursorCellRangeWithRangeType,primaryCursorCellRange)),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),scene.disableObjectsEvent(),this._clearUpdatingListeners(),this._addEndingListeners(),(_a58=scene.getTransformer())==null||_a58.clearSelectedObjects(),(rangeType===core.RANGE_TYPE.ROW||rangeType===core.RANGE_TYPE.COLUMN)&&(rangeType===core.RANGE_TYPE.ROW?viewportPosX=0:rangeType===core.RANGE_TYPE.COLUMN&&(viewportPosY=0),this._movingHandler(viewportPosX,viewportPosY,activeSelectionControl,rangeType)),this._setupPointerMoveListener(viewportMain,activeSelectionControl,rangeType,scrollTimerType,viewportPosX,viewportPosY),this._escapeShortcutDisposable=this._shortcutService.forceEscape(),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a59;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(_a59=this._escapeShortcutDisposable)==null||_a59.dispose(),this._escapeShortcutDisposable=null})}_setupPointerMoveListener(viewportMain,activeSelectionControl,rangeType,scrollTimerType=engineRender.ScrollTimerType.ALL,moveStartPosX,moveStartPosY){var _a58,_b;let xCrossTime=0,yCrossTime=0,lastX=moveStartPosX,lastY=moveStartPosY;this._scrollTimer=engineRender.ScrollTimer.create(this._scene,scrollTimerType),this._scrollTimer.startScroll((_a58=viewportMain==null?void 0:viewportMain.left)!=null?_a58:0,(_b=viewportMain==null?void 0:viewportMain.top)!=null?_b:0,viewportMain);const scene=this._scene,startViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([moveStartPosX,moveStartPosY]));this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a59,_b2,_c,_d,_e,_f,_g,_h,_i;const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._movingHandler(newMoveOffsetX,newMoveOffsetY,activeSelectionControl,rangeType);let scrollOffsetX=newMoveOffsetX,scrollOffsetY=newMoveOffsetY;const currentSelection=this.getActiveSelectionControl(),freeze=this._getFreeze(),selection=currentSelection==null?void 0:currentSelection.model,endViewport=(_a59=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY])))!=null?_a59:this._getViewportByCell(selection==null?void 0:selection.endRow,selection==null?void 0:selection.endColumn);if(__name(()=>{if(!startViewport||!endViewport||!viewportMain)return!1;const crossableViewports=[engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN,engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP,engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP,engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT];return crossableViewports.includes(startViewport.viewportKey)&&crossableViewports.includes(endViewport.viewportKey)},"isCrossableViewports")()){if(!startViewport||!endViewport||!viewportMain)return!1;const isCrossingX=lastX<viewportMain.left&&newMoveOffsetX>viewportMain.left||lastX>viewportMain.left&&newMoveOffsetX<viewportMain.left,isCrossingY=lastY<viewportMain.top&&newMoveOffsetY>viewportMain.top||lastY>viewportMain.top&&newMoveOffsetY<viewportMain.top;isCrossingX&&(xCrossTime+=1),isCrossingY&&(yCrossTime+=1);const startKey=startViewport.viewportKey,endKey=endViewport.viewportKey;if(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP)moveOffsetY<viewportMain.top&&((_b2=selection==null?void 0:selection.endRow)!=null?_b2:0)<((_c=freeze==null?void 0:freeze.startRow)!=null?_c:0)?scrollOffsetY=viewportMain.top:isCrossingY&&yCrossTime%2===1&&viewportMain.scrollToViewportPos({viewportScrollY:0});else if(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT)moveOffsetX<viewportMain.left&&((_d=selection==null?void 0:selection.endColumn)!=null?_d:0)<((_e=freeze==null?void 0:freeze.startColumn)!=null?_e:0)?scrollOffsetX=viewportMain.left:isCrossingX&&xCrossTime%2===1&&viewportMain.scrollToViewportPos({viewportScrollX:0});else if(startKey===endKey){let disableX=!1,disableY=!1;startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP?(disableX=!0,disableY=!0):startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP?disableY=!0:startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT&&(disableX=!0),((_f=selection==null?void 0:selection.endRow)!=null?_f:0)>((_g=freeze==null?void 0:freeze.startRow)!=null?_g:0)&&(disableY=!1),((_h=selection==null?void 0:selection.endColumn)!=null?_h:0)>((_i=freeze==null?void 0:freeze.startColumn)!=null?_i:0)&&(disableX=!1),disableX&&(scrollOffsetX=viewportMain.left),disableY&&(scrollOffsetY=viewportMain.top)}else{const startXY={x:startViewport.scrollX,y:startViewport.scrollY},endXY={x:endViewport.scrollX,y:endViewport.scrollY},shouldResetX=startXY.x!==endXY.x&&isCrossingX&&xCrossTime%2===1,shouldResetY=startXY.y!==endXY.y&&isCrossingY&&yCrossTime%2===1;(shouldResetX||shouldResetY)&&(viewportMain.scrollToBarPos({x:shouldResetX?startXY.x:void 0,y:shouldResetY?startXY.y:void 0}),shouldResetX||(scrollOffsetX=viewportMain.left),shouldResetY||(scrollOffsetY=viewportMain.top)),(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT||endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT)&&(scrollOffsetX=viewportMain.left),(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP||endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP)&&(scrollOffsetY=viewportMain.top)}lastX=newMoveOffsetX,lastY=newMoveOffsetY}this._scrollTimer.scrolling(scrollOffsetX,scrollOffsetY,()=>{this._movingHandler(newMoveOffsetX,newMoveOffsetY,activeSelectionControl,rangeType)})})}attachSelectionWithCoord(selectionWithStyle){return attachSelectionWithCoord(selectionWithStyle,this._skeleton)}attachPrimaryWithCoord(primary){return attachPrimaryWithCoord(primary,this._skeleton)}getSelectionCellByPosition(x,y){const scene=this._scene,skeleton=this._skeleton,scrollXY=scene.getViewportScrollXY(scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN)),{scaleX,scaleY}=scene.getAncestorScale();return skeleton.calculateCellIndexByPosition(x,y,scaleX,scaleY,scrollXY)}_movingHandler(offsetX,offsetY,activeSelectionControl,rangeType){var _a58,_b,_c,_d,_e;const skeleton=this._skeleton,scene=this._scene,[unitId,sheetId]=skeleton.getLocation(),currSelectionRange={startRow:(_a58=activeSelectionControl==null?void 0:activeSelectionControl.model.startRow)!=null?_a58:-1,endRow:(_b=activeSelectionControl==null?void 0:activeSelectionControl.model.endRow)!=null?_b:-1,startColumn:(_c=activeSelectionControl==null?void 0:activeSelectionControl.model.startColumn)!=null?_c:-1,endColumn:(_d=activeSelectionControl==null?void 0:activeSelectionControl.model.endColumn)!=null?_d:-1,unitId,sheetId},viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),targetViewport=(_e=this._getViewportByCell(currSelectionRange.endRow,currSelectionRange.endColumn))!=null?_e:viewportMain,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),targetViewport),{scaleX,scaleY}=scene.getAncestorScale();rangeType===core.RANGE_TYPE.ROW?offsetX=Number.POSITIVE_INFINITY:rangeType===core.RANGE_TYPE.COLUMN&&(offsetY=Number.POSITIVE_INFINITY);const cursorCellRangeInfo=this._getCellRangeByCursorPosition(offsetX,offsetY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return;const{rangeWithCoord:cursorCellRange}=cursorCellRangeInfo,activeCellRange=this._startRangeWhenPointerDown;let newSelectionRange={startRow:Math.min(cursorCellRange.startRow,activeCellRange.startRow),startColumn:Math.min(cursorCellRange.startColumn,activeCellRange.startColumn),endRow:Math.max(cursorCellRange.endRow,activeCellRange.endRow),endColumn:Math.max(cursorCellRange.endColumn,activeCellRange.endColumn)};if(this._shouldDetectMergedCells&&(newSelectionRange=skeleton.getSelectionMergeBounding(newSelectionRange.startRow,newSelectionRange.startColumn,newSelectionRange.endRow,newSelectionRange.endColumn)),!newSelectionRange)return;const startCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.startRow,newSelectionRange.startColumn),endCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.endRow,newSelectionRange.endColumn),newSelectionRangeWithCoord={startRow:newSelectionRange.startRow,startColumn:newSelectionRange.startColumn,endRow:newSelectionRange.endRow,endColumn:newSelectionRange.endColumn,unitId,sheetId,startY:(startCellXY==null?void 0:startCellXY.startY)||0,endY:(endCellXY==null?void 0:endCellXY.endY)||0,startX:(startCellXY==null?void 0:startCellXY.startX)||0,endX:(endCellXY==null?void 0:endCellXY.endX)||0},rangeChanged=currSelectionRange.startRow!==newSelectionRange.startRow||currSelectionRange.startColumn!==newSelectionRange.startColumn||currSelectionRange.endRow!==newSelectionRange.endRow||currSelectionRange.endColumn!==newSelectionRange.endColumn;activeSelectionControl!=null&&rangeChanged&&(this._updateSelectionControlByRange(activeSelectionControl,newSelectionRangeWithCoord),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateSelectionControlByRange(control,newSelectionRange,highlight){control.updateRange(newSelectionRange,highlight)}_clearUpdatingListeners(){var _a58,_b,_c,_d,_e;this._scene.enableObjectsEvent(),(_a58=this._scenePointerMoveSub)==null||_a58.unsubscribe(),this._scenePointerMoveSub=null,(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerUpSub=null,(_c=this._cancelDownSubscription)==null||_c.unsubscribe(),this._cancelDownSubscription=null,(_d=this._cancelUpSubscription)==null||_d.unsubscribe(),this._cancelUpSubscription=null,(_e=this._scrollTimer)==null||_e.dispose()}_addEndingListeners(){var _a58,_b,_c;const scene=this._scene,mainScene=(_a58=scene.getEngine())==null?void 0:_a58.activeScene;!mainScene||mainScene===scene||((_b=this._cancelDownSubscription)==null||_b.unsubscribe(),this._cancelDownSubscription=null,(_c=this._cancelUpSubscription)==null||_c.unsubscribe(),this._cancelUpSubscription=null,this._cancelDownSubscription=mainScene.onPointerDown$.subscribeEvent(()=>this._clearUpdatingListeners()),this._cancelUpSubscription=mainScene.onPointerUp$.subscribeEvent(()=>this._clearUpdatingListeners()))}_getCellRangeByCursorPosition(offsetX,offsetY,scaleX,scaleY,scrollXY){var _a58;if(this._shouldDetectMergedCells){const primaryWithCoord2=(_a58=this._skeleton)==null?void 0:_a58.calculateCellIndexByPosition(offsetX,offsetY,scaleX,scaleY,scrollXY);if(!primaryWithCoord2)return;const rangeWithCoord2=core.makeCellToSelection(primaryWithCoord2);return{primaryWithCoord:primaryWithCoord2,rangeWithCoord:rangeWithCoord2}}const skeleton=this._skeleton;if(skeleton==null)return;const moveActualSelection=skeleton.getCellPositionByOffset(offsetX,offsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,startCell=skeleton.getNoMergeCellPositionByIndex(row,column),{startX,startY,endX,endY}=startCell,rangeWithCoord={startY,endY,startX,endX,startRow:row,endRow:row,startColumn:column,endColumn:column};return{primaryWithCoord:{actualRow:row,actualColumn:column,isMerged:!1,isMergedMainCell:!1,startY,endY,startX,endX,mergeInfo:rangeWithCoord},rangeWithCoord}}_checkClearPreviousControls(evt){this.getSelectionControls().length!==0&&(!evt.ctrlKey&&!evt.shiftKey&&!this._remainLastEnabled||this._singleSelectionEnabled&&!evt.shiftKey)&&this._clearSelectionControls()}_performSelectionByTwoCells(currentCell,startSelectionRange,skeleton,rangeType,activeControl){const{actualRow,actualColumn,mergeInfo:actualMergeInfo}=currentCell,newStartRow=Math.min(actualRow,startSelectionRange.startRow,actualMergeInfo.startRow),newEndRow=Math.max(actualRow,startSelectionRange.endRow,actualMergeInfo.endRow),newStartColumn=Math.min(actualColumn,startSelectionRange.startColumn,actualMergeInfo.startColumn),newEndColumn=Math.max(actualColumn,startSelectionRange.endColumn,actualMergeInfo.endColumn),bounding=skeleton.getMergeBounding(newStartRow,newStartColumn,newEndRow,newEndColumn),startCell=skeleton.getNoMergeCellPositionByIndex(bounding.startRow,bounding.startColumn),endCell=skeleton.getNoMergeCellPositionByIndex(bounding.endRow,bounding.endColumn),newSelectionRange={startColumn:bounding.startColumn,startRow:bounding.startRow,endColumn:bounding.endColumn,endRow:bounding.endRow,startY:startCell.startY,endY:endCell.endY,startX:startCell.startX,endX:endCell.endX,rangeType},activeCell=skeleton.getCellByIndex(actualRow,actualColumn);this._startRangeWhenPointerDown={startColumn:activeCell.mergeInfo.startColumn,startRow:activeCell.mergeInfo.startRow,endColumn:activeCell.mergeInfo.endColumn,endRow:activeCell.mergeInfo.endRow,startY:activeCell.mergeInfo.startY||0,endY:activeCell.mergeInfo.endY||0,startX:activeCell.mergeInfo.startX||0,endX:activeCell.mergeInfo.endX||0,rangeType},this._updateSelectionControlByRange(activeControl,newSelectionRange,currentCell)}_refreshSelectionControl(selectionsData){const selections=selectionsData.map(selectionWithStyle=>{const selectionData=attachSelectionWithCoord(selectionWithStyle,this._skeleton);return selectionData.style=sheets.getNormalSelectionStyle(this._themeService),selectionData});this.updateControlForCurrentByRangeData(selections)}};__name(_BaseSelectionRenderService,"BaseSelectionRenderService");let BaseSelectionRenderService=_BaseSelectionRenderService;function getAllSelection(skeleton){return{range:{startRow:0,startColumn:0,endRow:skeleton.getRowCount()-1,endColumn:skeleton.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL},primary:getTopLeftSelection(skeleton).primary,style:null}}__name(getAllSelection,"getAllSelection");function getTopLeftSelection(skeleton){const mergeData=skeleton.mergeData;return sheets.transformCellDataToSelectionData(0,0,mergeData)||{range:{startRow:0,startColumn:0,endRow:0,endColumn:0},primary:{actualRow:0,actualColumn:0,startRow:0,startColumn:0,endRow:0,endColumn:0,isMerged:!1,isMergedMainCell:!1},style:null}}__name(getTopLeftSelection,"getTopLeftSelection");var __defProp$N=Object.defineProperty,__getOwnPropDesc$N=Object.getOwnPropertyDescriptor,__decorateClass$N=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$N(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$N(target,key,result),result},"__decorateClass$N"),__decorateParam$N=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$N");const BEFORE_CELL_EDIT=core.createInterceptorKey("BEFORE_CELL_EDIT"),AFTER_CELL_EDIT=core.createInterceptorKey("AFTER_CELL_EDIT"),AFTER_CELL_EDIT_ASYNC=core.createInterceptorKey("AFTER_CELL_EDIT_ASYNC");var _a6;exports.EditorBridgeService=(_a6=class extends core.Disposable{constructor(_renderManagerService,_themeService,_univerInstanceService,_editorService,_refSelectionsService,_contextService){super();__publicField(this,"_editorUnitId",core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY);__publicField(this,"_isForceKeepVisible",!1);__publicField(this,"_editorIsDirty",!1);__publicField(this,"_visible",{visible:!1,eventType:engineRender.DeviceInputEventType.Dblclick,unitId:""});__publicField(this,"_currentEditCell",null);__publicField(this,"_currentEditCellState",null);__publicField(this,"_currentEditCellState$",new rxjs.BehaviorSubject(null));__publicField(this,"currentEditCellState$",this._currentEditCellState$.asObservable());__publicField(this,"_visible$",new rxjs.BehaviorSubject(this._visible));__publicField(this,"visible$",this._visible$.asObservable());__publicField(this,"_afterVisible$",new rxjs.BehaviorSubject(this._visible));__publicField(this,"afterVisible$",this._afterVisible$.asObservable());__publicField(this,"interceptor",new core.InterceptorManager({BEFORE_CELL_EDIT,AFTER_CELL_EDIT,AFTER_CELL_EDIT_ASYNC}));this._renderManagerService=_renderManagerService,this._themeService=_themeService,this._univerInstanceService=_univerInstanceService,this._editorService=_editorService,this._refSelectionsService=_refSelectionsService,this._contextService=_contextService,this.disposeWithMe(core.toDisposable(()=>{this._currentEditCellState$.complete(),this._currentEditCell=null})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().AFTER_CELL_EDIT,{priority:-1,handler:__name(_value=>_value,"handler")})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().BEFORE_CELL_EDIT,{priority:-1,handler:__name(_value=>_value,"handler")})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{priority:-1,handler:__name(_value=>_value,"handler")})),this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(unit=>{var _a58;unit.getUnitId()===((_a58=this._currentEditCellState)==null?void 0:_a58.unitId)&&this._clearCurrentEditCellState()})}refreshEditCellState(){const editCellState=this.getLatestEditCellState();this._currentEditCellState=editCellState,this._currentEditCellState$.next(editCellState)}refreshEditCellPosition(resetSizeOnly){var _a58,_b;const currentEditCell=this._currentEditCell;if(currentEditCell==null)return;const ru=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET);if(!ru)return;const skeleton=(_a58=ru.with(exports.SheetSkeletonManagerService).getWorksheetSkeleton(currentEditCell.sheetId))==null?void 0:_a58.skeleton,selectionRenderService=ru.with(ISheetSelectionRenderService);if(!skeleton||!this._currentEditCellState)return;const{primary,unitId,sheetId,scene,engine}=currentEditCell,{startRow,startColumn}=primary,primaryWithCoord=attachPrimaryWithCoord(primary,skeleton);if(primaryWithCoord==null)return;const actualRangeWithCoord=core.makeCellToSelection(primaryWithCoord),canvasOffset=docsUi.getCanvasOffsetByEngine(engine);let{startX,startY,endX,endY}=actualRangeWithCoord;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY=scene.getViewportScrollXY(selectionRenderService.getViewPort());startX=skeleton.convertTransformToOffsetX(startX,scaleX,scrollXY),startY=skeleton.convertTransformToOffsetY(startY,scaleY,scrollXY),endX=skeleton.convertTransformToOffsetX(endX,scaleX,scrollXY),endY=skeleton.convertTransformToOffsetY(endY,scaleY,scrollXY),resetSizeOnly&&this._currentEditCellState&&(endX=endX-startX+this._currentEditCellState.position.startX,endY=endY-startY+this._currentEditCellState.position.startY,startX=this._currentEditCellState.position.startX,startY=this._currentEditCellState.position.startY),this._editorService.setOperationSheetUnitId(unitId),this._editorService.setOperationSheetSubUnitId(sheetId);const editCellState={position:{startX,startY,endX,endY},scaleX,scaleY,canvasOffset,row:startRow,column:startColumn,unitId,sheetId,documentLayoutObject:this._currentEditCellState.documentLayoutObject,editorUnitId:this._editorUnitId,isInArrayFormulaRange:(_b=this._currentEditCellState)==null?void 0:_b.isInArrayFormulaRange};this._currentEditCellState=editCellState,this._currentEditCellState$.next(editCellState)}setEditCell(param){this._currentEditCell=param,this._editorService.getFocusEditor()||(this._editorService.focus(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),this._contextService.setContextValue(core.EDITOR_ACTIVATED,!1),this._contextService.setContextValue(core.FOCUSING_EDITOR_STANDALONE,!1),this._contextService.setContextValue(core.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE,!1));const editCellState=this.getLatestEditCellState();this._currentEditCellState=editCellState,this._currentEditCellState$.next(editCellState)}_clearCurrentEditCellState(){this._currentEditCellState=null,this._currentEditCellState$.next(null)}getEditCellState(){return this._currentEditCellState}getLatestEditCellState(){var _a58,_b,_c;const currentEditCell=this._currentEditCell;if(currentEditCell==null)return;const ru=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET);if(!ru)return;const skeleton=ru.with(exports.SheetSkeletonManagerService).getCurrentSkeleton(),selectionRenderService=ru.with(ISheetSelectionRenderService);if(!skeleton)return;const{primary,unitId,sheetId,scene,engine}=currentEditCell,{startRow,startColumn}=primary,primaryWithCoord=attachPrimaryWithCoord(primary,skeleton);if(primaryWithCoord==null)return;const actualRangeWithCoord=core.makeCellToSelection(primaryWithCoord),canvasOffset=docsUi.getCanvasOffsetByEngine(engine);let{startX,startY,endX,endY}=actualRangeWithCoord;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY=scene.getViewportScrollXY(selectionRenderService.getViewPort());startX=skeleton.convertTransformToOffsetX(startX,scaleX,scrollXY),startY=skeleton.convertTransformToOffsetY(startY,scaleY,scrollXY),endX=skeleton.convertTransformToOffsetX(endX,scaleX,scrollXY),endY=skeleton.convertTransformToOffsetY(endY,scaleY,scrollXY);const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)return;const location={workbook,worksheet,unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),row:startRow,col:startColumn,origin:worksheet.getCellRaw(startRow,startColumn)},cell=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().BEFORE_CELL_EDIT)(worksheet.getCell(startRow,startColumn),location);let documentLayoutObject=cell&&skeleton.getCellDocumentModelWithFormula(cell);const renderConfig=(_a58=documentLayoutObject==null?void 0:documentLayoutObject.documentModel)==null?void 0:_a58.documentStyle.renderConfig;if(renderConfig!=null&&(renderConfig.cellValueType=core.CellValueType.STRING),!documentLayoutObject||documentLayoutObject.documentModel==null){const blankModel=skeleton.getBlankCellDocumentModel(cell);if(documentLayoutObject!=null){const{verticalAlign,horizontalAlign,wrapStrategy,textRotation,fill}=documentLayoutObject,{centerAngle,vertexAngle}=engineRender.convertTextRotation(textRotation);blankModel.documentModel.documentStyle.renderConfig={verticalAlign,horizontalAlign,wrapStrategy,background:{rgb:fill},centerAngle,vertexAngle}}documentLayoutObject=blankModel}if(documentLayoutObject.fill=documentLayoutObject.fill||"#fff",(_b=documentLayoutObject.documentModel)==null||_b.setZoomRatio(Math.max(scaleX,scaleY)),(cell==null?void 0:cell.isInArrayFormulaRange)===!0){const body=(_c=documentLayoutObject.documentModel)==null?void 0:_c.getBody();body&&(body.textRuns=[{st:0,ed:body.dataStream.length-2,ts:{cl:{rgb:this._themeService.getCurrentTheme().textColorSecondary}}}])}return this._editorService.setOperationSheetUnitId(unitId),this._editorService.setOperationSheetSubUnitId(sheetId),{position:{startX,startY,endX,endY},scaleX,scaleY,canvasOffset,row:startRow,column:startColumn,unitId,sheetId,documentLayoutObject,editorUnitId:this._editorUnitId,isInArrayFormulaRange:cell==null?void 0:cell.isInArrayFormulaRange}}getCurrentEditorId(){return this._editorUnitId}changeVisible(param){const editor=this._editorService.getFocusEditor();this._refSelectionsService.getCurrentSelections().length>0&&editor&&!editor.isSheetEditor()||(this._visible=param,param.visible&&(this._editorIsDirty=!1),this._visible$.next(this._visible),this._afterVisible$.next(this._visible))}isVisible(){return this._visible}enableForceKeepVisible(){this._isForceKeepVisible=!0}disableForceKeepVisible(){this._isForceKeepVisible=!1}isForceKeepVisible(){return this._isForceKeepVisible}changeEditorDirty(dirtyStatus){this._editorIsDirty=dirtyStatus}getEditorDirty(){return this._editorIsDirty}},__name(_a6,"EditorBridgeService"),_a6);exports.EditorBridgeService=__decorateClass$N([__decorateParam$N(0,engineRender.IRenderManagerService),__decorateParam$N(1,core.Inject(core.ThemeService)),__decorateParam$N(2,core.IUniverInstanceService),__decorateParam$N(3,docsUi.IEditorService),__decorateParam$N(4,sheets.IRefSelectionsService),__decorateParam$N(5,core.IContextService)],exports.EditorBridgeService);const IEditorBridgeService=core.createIdentifier("univer.sheet-editor-bridge.service"),calcDocRangePositions=__name((range,skeleton)=>{var _a58,_b,_c,_d,_e;const startPosition=skeleton.findNodePositionByCharIndex(range.startOffset,!1,range.segmentId,-1),skeletonData=skeleton.getSkeletonData();let end=range.endOffset;if(range.segmentId){const root=(_e=Array.from((_b=(_a58=skeletonData==null?void 0:skeletonData.skeFooters.get(range.segmentId))==null?void 0:_a58.values())!=null?_b:[])[0])!=null?_e:Array.from((_d=(_c=skeletonData==null?void 0:skeletonData.skeHeaders.get(range.segmentId))==null?void 0:_c.values())!=null?_d:[])[0];root&&(end=Math.min(root.ed,end))}const endPosition=skeleton.findNodePositionByCharIndex(end,!1,range.segmentId,-1);if(!endPosition||!startPosition)return;const documentOffsetConfig={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},convertor=new docsUi.NodePositionConvertToCursor(documentOffsetConfig,skeleton),{borderBoxPointGroup}=convertor.getRangePointData(startPosition,endPosition);return docsUi.getLineBounding(borderBoxPointGroup).map(rect=>({top:rect.top,bottom:rect.bottom,left:rect.left,right:rect.right}))},"calcDocRangePositions"),calcDocGlyphPosition=__name((glyph,skeleton,pageIndex=-1)=>{const start=skeleton.findPositionByGlyph(glyph,pageIndex);if(!start)return;const startPosition={...start,isBack:!0},documentOffsetConfig={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},convertor=new docsUi.NodePositionConvertToCursor(documentOffsetConfig,skeleton),{borderBoxPointGroup}=convertor.getRangePointData(startPosition,startPosition),rect=docsUi.getLineBounding(borderBoxPointGroup)[0];return{top:rect.top,bottom:rect.bottom,left:rect.left,right:rect.left}},"calcDocGlyphPosition"),calcLinkPosition=__name((skeleton,range,paddingLeft=0,paddingTop=0)=>{const rects=calcDocRangePositions({startOffset:range.startIndex,endOffset:range.endIndex+1,collapsed:!1},skeleton);if(rects)return{rects:rects.map(rect=>({top:rect.top+paddingTop,bottom:rect.bottom+paddingTop,left:rect.left+paddingLeft,right:rect.right+paddingLeft})),range}},"calcLinkPosition"),calcBulletPosition=__name((skeleton,paragraph,paddingLeft=0,paddingTop=0)=>{var _a58,_b,_c;const node=skeleton.findNodeByCharIndex(paragraph.startIndex),divide=node==null?void 0:node.parent,line=divide==null?void 0:divide.parent,column=line==null?void 0:line.parent,targetLine=column==null?void 0:column.lines.find(l2=>l2.paragraphStart&&l2.paragraphIndex===paragraph.startIndex),bulletNode=(_c=(_b=(_a58=targetLine==null?void 0:targetLine.divides)==null?void 0:_a58[0])==null?void 0:_b.glyphGroup)==null?void 0:_c[0];if(!bulletNode||!bulletNode)return;const rect=calcDocGlyphPosition(bulletNode,skeleton);if(rect)return{rect:{top:rect.top+paddingTop,bottom:rect.bottom+paddingTop,left:rect.left+paddingLeft,right:rect.right+paddingLeft},segmentId:void 0,segmentPageIndex:-1,paragraph}},"calcBulletPosition"),calculateDocSkeletonRects=__name((docSkeleton,paddingLeft=0,paddingTop=0)=>{var _a58,_b,_c,_d,_e,_f;const docModel=docSkeleton.getViewModel().getDataModel(),hyperLinks=(_c=(_b=(_a58=docModel.getBody())==null?void 0:_a58.customRanges)==null?void 0:_b.filter(range=>range.rangeType===core.CustomRangeType.HYPERLINK))!=null?_c:[],checkLists=(_f=(_e=(_d=docModel.getBody())==null?void 0:_d.paragraphs)==null?void 0:_e.filter(p2=>{var _a59;return((_a59=p2.bullet)==null?void 0:_a59.listType.indexOf(core.PresetListType.CHECK_LIST))===0}))!=null?_f:[];return{links:hyperLinks.map(link=>calcLinkPosition(docSkeleton,link,paddingLeft,paddingTop)).filter(Boolean),checkLists:checkLists.map(list=>calcBulletPosition(docSkeleton,list,paddingLeft,paddingTop)).filter(Boolean)}},"calculateDocSkeletonRects");function calcPadding(cell,font){var _a58,_b,_c,_d;const height=(_b=(_a58=font.documentSkeleton.getSkeletonData())==null?void 0:_a58.pages[0].height)!=null?_b:0,width=(_d=(_c=font.documentSkeleton.getSkeletonData())==null?void 0:_c.pages[0].width)!=null?_d:0,vt=font.verticalAlign,ht=font.horizontalAlign;let paddingTop=0;switch(vt){case core.VerticalAlign.UNSPECIFIED:case core.VerticalAlign.BOTTOM:paddingTop=cell.mergeInfo.endY-cell.mergeInfo.startY-height;break;case core.VerticalAlign.MIDDLE:paddingTop=(cell.mergeInfo.endY-cell.mergeInfo.startY-height)/2;break}let paddingLeft=0;switch(ht){case core.HorizontalAlign.RIGHT:paddingLeft=cell.mergeInfo.endX-cell.mergeInfo.startX-width;break;case core.HorizontalAlign.CENTER:paddingLeft=(cell.mergeInfo.endX-cell.mergeInfo.startX-width)/2;break}return{paddingLeft,paddingTop}}__name(calcPadding,"calcPadding");const getCustomRangePosition=__name((injector,unitId,subUnitId,row,col,rangeId)=>{var _a58,_b,_c;const univerInstanceService=injector.get(core.IUniverInstanceService),renderManagerService=injector.get(engineRender.IRenderManagerService),workbook=univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet)return null;const currentRender=renderManagerService.getRenderById(workbook.getUnitId()),skeletonParam=currentRender==null?void 0:currentRender.with(exports.SheetSkeletonManagerService).getWorksheetSkeleton(worksheet.getSheetId()),skeleton=skeletonParam==null?void 0:skeletonParam.skeleton;if(!skeleton||!currentRender)return;const font=skeleton.getFont(row,col),docSkeleton=font==null?void 0:font.documentSkeleton;if(!docSkeleton)return null;const customRange=(_b=(_a58=docSkeleton.getViewModel().getBody())==null?void 0:_a58.customRanges)==null?void 0:_b.find(range=>range.rangeId===rangeId);if(!customRange)return null;const PADDING=docsUi.DOC_VERTICAL_PADDING,cellIndex=skeleton.getCellByIndex(row,col);let{actualColumn,actualRow}=cellIndex;skeleton.overflowCache.forValue((r2,c,range)=>{range.startRow<=actualRow&&range.endRow>=actualRow&&range.startColumn<=actualColumn&&range.endColumn>=actualColumn&&(actualColumn=c,actualRow=r2)});const actualCell=skeleton.getCellByIndex(actualRow,actualColumn),cellData=worksheet.getCell(actualCell.actualRow,actualCell.actualColumn),{topOffset=0,leftOffset=0}=(_c=cellData==null?void 0:cellData.fontRenderExtension)!=null?_c:{},{paddingLeft,paddingTop}=calcPadding(actualCell,font),rects=calcDocRangePositions({startOffset:customRange.startIndex,endOffset:customRange.endIndex,collapsed:!1},docSkeleton);return{rects:rects==null?void 0:rects.map(rect=>({top:rect.top+actualCell.mergeInfo.startY+paddingTop+topOffset+PADDING,bottom:rect.bottom+actualCell.mergeInfo.startY+paddingTop+topOffset+PADDING,left:rect.left+actualCell.mergeInfo.startX+paddingLeft+leftOffset,right:rect.right+actualCell.mergeInfo.startX+paddingLeft+leftOffset})),customRange,label:docSkeleton.getViewModel().getBody().dataStream.slice(customRange.startIndex+1,customRange.endIndex)}},"getCustomRangePosition"),getEditingCustomRangePosition=__name((injector,unitId,subUnitId,row,col,rangeId)=>{var _a58,_b,_c;const editorBridgeService=injector.get(IEditorBridgeService),state=editorBridgeService.getEditCellState();if(!state||!editorBridgeService.isVisible().visible)return null;const{editorUnitId,unitId:editingUnitId,sheetId,row:editRow,column:editCol}=state;if(unitId!==editingUnitId||subUnitId!==sheetId||editRow!==row||editCol!==col)return null;const renderManagerService=injector.get(engineRender.IRenderManagerService),renderer=renderManagerService.getRenderById(editorUnitId),sheetRenderer=renderManagerService.getRenderById(unitId);if(!renderer||!sheetRenderer)return null;const docSkeleton=renderer.with(docs.DocSkeletonManagerService).getSkeleton(),sheetSkeleton=(_a58=sheetRenderer.with(exports.SheetSkeletonManagerService).getWorksheetSkeleton(sheetId))==null?void 0:_a58.skeleton;if(!docSkeleton||!sheetSkeleton)return null;const customRange=(_c=(_b=docSkeleton.getViewModel().getBody())==null?void 0:_b.customRanges)==null?void 0:_c.find(range=>range.rangeId===rangeId);if(!customRange)return null;const PADDING=4,rects=calcDocRangePositions({startOffset:customRange.startIndex,endOffset:customRange.endIndex,collapsed:!1},docSkeleton),canvasClientRect=renderer.engine.getCanvasElement().getBoundingClientRect();return{rects:rects==null?void 0:rects.map(rect=>({top:rect.top+canvasClientRect.top-PADDING,bottom:rect.bottom+canvasClientRect.top+PADDING,left:rect.left+canvasClientRect.left,right:rect.right+canvasClientRect.left})),customRange,label:docSkeleton.getViewModel().getBody().dataStream.slice(customRange.startIndex+1,customRange.endIndex)}},"getEditingCustomRangePosition");var __defProp$M=Object.defineProperty,__getOwnPropDesc$M=Object.getOwnPropertyDescriptor,__decorateClass$M=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$M(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$M(target,key,result),result},"__decorateClass$M"),__decorateParam$M=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$M");const AFFECT_LAYOUT_STYLES=["ff","fs","tr","tb"];var _a7;exports.AutoHeightController=(_a7=class extends core.Disposable{constructor(_renderManagerService,_sheetInterceptorService,_selectionManagerService,_univerInstanceService){super(),this._renderManagerService=_renderManagerService,this._sheetInterceptorService=_sheetInterceptorService,this._selectionManagerService=_selectionManagerService,this._univerInstanceService=_univerInstanceService,this._initialize()}getUndoRedoParamsOfAutoHeight(ranges){const{_univerInstanceService:univerInstanceService}=this,workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),sheetSkeletonService=this._renderManagerService.getRenderById(unitId).with(exports.SheetSkeletonManagerService);if(!subUnitId||!sheetSkeletonService.getCurrent())return{redos:[],undos:[]};const{skeleton}=sheetSkeletonService.getCurrent(),rowsAutoHeightInfo=skeleton.calculateAutoHeightInRange(ranges),redoParams={subUnitId,unitId,rowsAutoHeightInfo},undoParams=sheets.SetWorksheetRowAutoHeightMutationFactory(redoParams,worksheet);return{undos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:undoParams}],redos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:redoParams}]}}_initialize(){const{_sheetInterceptorService:sheetInterceptorService,_selectionManagerService:selectionManagerService}=this;this.disposeWithMe(sheetInterceptorService.interceptCommand({getMutations:__name(command=>command.id!==sheets.SetRangeValuesCommand.id?{redos:[],undos:[]}:this.getUndoRedoParamsOfAutoHeight(command.params.range),"getMutations")})),this.disposeWithMe(sheetInterceptorService.interceptCommand({getMutations:__name(command=>command.id!==sheets.SetWorksheetRowIsAutoHeightCommand.id?{redos:[],undos:[]}:this.getUndoRedoParamsOfAutoHeight(command.params.ranges),"getMutations")})),this.disposeWithMe(sheetInterceptorService.interceptCommand({getMutations:__name(command=>{var _a58,_b;if(command.id!==sheets.SetStyleCommand.id)return{redos:[],undos:[]};if(!AFFECT_LAYOUT_STYLES.includes((_a58=command.params)==null?void 0:_a58.style.type))return{redos:[],undos:[]};const selections=(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);return selections!=null&&selections.length?this.getUndoRedoParamsOfAutoHeight(selections):{redos:[],undos:[]}},"getMutations")}))}},__name(_a7,"AutoHeightController"),_a7);exports.AutoHeightController=__decorateClass$M([__decorateParam$M(0,engineRender.IRenderManagerService),__decorateParam$M(1,core.Inject(sheets.SheetInterceptorService)),__decorateParam$M(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$M(3,core.Inject(core.IUniverInstanceService))],exports.AutoHeightController);function rangeToDiscreteRange(range,accessor,unitId,subUnitId){const univerInstanceService=accessor.get(core.IUniverInstanceService),workbook=unitId?univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_SHEET):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=subUnitId?workbook==null?void 0:workbook.getSheetBySheetId(subUnitId):workbook==null?void 0:workbook.getActiveSheet();if(!worksheet)return null;const{startRow,endRow,startColumn,endColumn}=range,rows=[],cols=[];for(let r2=startRow;r2<=endRow;r2++)worksheet.getRowFiltered(r2)||rows.push(r2);for(let c=startColumn;c<=endColumn;c++)cols.push(c);return{rows,cols}}__name(rangeToDiscreteRange,"rangeToDiscreteRange");function discreteRangeToRange(discreteRange){const{rows,cols}=discreteRange;return{startRow:rows[0],endRow:rows[rows.length-1],startColumn:cols[0],endColumn:cols[cols.length-1]}}__name(discreteRangeToRange,"discreteRangeToRange");function virtualizeDiscreteRanges(ranges){let totalRows=[],totalCols=[];const totalRanges=[];return ranges.forEach(r2=>{totalRows.push(...r2.rows),totalCols.push(...r2.cols)}),totalRows=Array.from(new Set(totalRows)).sort((a,b)=>a-b),totalCols=Array.from(new Set(totalCols)).sort((a,b)=>a-b),ranges.forEach(r2=>{totalRanges.push({startRow:totalRows.findIndex(row=>row===r2.rows[0]),endRow:totalRows.findIndex(row=>row===r2.rows[r2.rows.length-1]),startColumn:totalCols.findIndex(col=>col===r2.cols[0]),endColumn:totalCols.findIndex(col=>col===r2.cols[r2.cols.length-1])})}),{ranges:totalRanges,mapFunc:__name((row,col)=>({row:totalRows[row],col:totalCols[col]}),"mapFunc")}}__name(virtualizeDiscreteRanges,"virtualizeDiscreteRanges");function generateNullCellValueRowCol(range){const cellValue=new core.ObjectMatrix;return range.forEach(r2=>{const{rows,cols}=r2;rows.forEach(i=>{cols.forEach(j=>{cellValue.setValue(i,j,{v:null,p:null,f:null,si:null,custom:null})})})}),cellValue.getData()}__name(generateNullCellValueRowCol,"generateNullCellValueRowCol");const chnNumChar={零:0,一:1,二:2,三:3,四:4,五:5,六:6,七:7,八:8,九:9},chnNumChar2=["零","一","二","三","四","五","六","七","八","九"],chnUnitSection=["","万","亿","万亿","亿亿"],chnUnitChar=["","十","百","千"],chnNameValue={十:{value:10,secUnit:!1},百:{value:100,secUnit:!1},千:{value:1e3,secUnit:!1},万:{value:1e4,secUnit:!0},亿:{value:1e8,secUnit:!0}};function chineseToNumber(chnStr){if(!chnStr)return 0;let rtn=0,section=0,number=0,secUnit=!1;const str=chnStr.split("");for(let i=0;i<str.length;i++){const num=chnNumChar[str[i]];if(typeof num<"u")number=num,i===str.length-1&&(section+=number);else{const obj=chnNameValue[str[i]],unit=obj.value;secUnit=obj.secUnit,secUnit?(section=(section+number)*unit,rtn+=section,section=0):section+=number*unit,number=0}}return rtn+section}__name(chineseToNumber,"chineseToNumber");function sectionToChinese(section){let strIns="",chnStr="",unitPos=0,zero=!0;for(;section>0;){const v=section%10;v===0?zero||(zero=!0,chnStr=chnNumChar2[v]+chnStr):(zero=!1,strIns=chnNumChar2[v],strIns+=chnUnitChar[unitPos],chnStr=strIns+chnStr),unitPos++,section=Math.floor(section/10)}return chnStr}__name(sectionToChinese,"sectionToChinese");function numberToChinese(num){let unitPos=0,strIns="",chnStr="",needZero=!1;if(num===0)return chnNumChar2[0];for(;num>0;){const section=num%1e4;needZero&&(chnStr=chnNumChar2[0]+chnStr),strIns=sectionToChinese(section),strIns+=section!==0?chnUnitSection[unitPos]:chnUnitSection[0],chnStr=strIns+chnStr,needZero=section<1e3&&section>0,num=Math.floor(num/1e4),unitPos++}return chnStr}__name(numberToChinese,"numberToChinese");function isChnNumber(txt){if(!txt)return!1;let isChnNumber2=!0;if(txt)if(txt.length===1)txt==="日"||txt in chnNumChar?isChnNumber2=!0:isChnNumber2=!1;else{const str=txt.split("");for(let i=0;i<str.length;i++)if(!(str[i]in chnNumChar||str[i]in chnNameValue)){isChnNumber2=!1;break}}return isChnNumber2}__name(isChnNumber,"isChnNumber");function matchExtendNumber(txt){if(!txt)return{isExtendNumber:!1};const reg=/0|([1-9]+[0-9]*)/g,isExtendNumber=reg.test(txt);if(isExtendNumber){const match=txt.match(reg);if(match&&match.length>0){const matchTxt=match[match.length-1],matchIndex=txt.lastIndexOf(matchTxt),beforeTxt=txt.substr(0,matchIndex),afterTxt=txt.substr(matchIndex+matchTxt.length);return{isExtendNumber:!0,matchTxt:Number(matchTxt),beforeTxt,afterTxt}}return{isExtendNumber:!1}}return{isExtendNumber}}__name(matchExtendNumber,"matchExtendNumber");function isChnWeek2(txt){let isChnWeek22;return txt.length===2&&(txt==="周一"||txt==="周二"||txt==="周三"||txt==="周四"||txt==="周五"||txt==="周六"||txt==="周日")?isChnWeek22=!0:isChnWeek22=!1,isChnWeek22}__name(isChnWeek2,"isChnWeek2");function isChnWeek3(txt){let isChnWeek32;return txt.length===3&&(txt==="星期一"||txt==="星期二"||txt==="星期三"||txt==="星期四"||txt==="星期五"||txt==="星期六"||txt==="星期日")?isChnWeek32=!0:isChnWeek32=!1,isChnWeek32}__name(isChnWeek3,"isChnWeek3");function getLenS(indexArr,rsd){let s=0;for(let j=0;j<indexArr.length&&indexArr[j]<rsd;j++)s++;return s}__name(getLenS,"getLenS");function isEqualDiff(arr){let diff=!0;const step=arr[1]-arr[0];for(let i=1;i<arr.length;i++)if(arr[i]-arr[i-1]!==step){diff=!1;break}return diff}__name(isEqualDiff,"isEqualDiff");function getDataIndex(csLen,asLen,indexArr){const obj=[],num=Math.floor(asLen/csLen),rsd=asLen%csLen;let sum=0;if(num>0){for(let i=0;i<num;i++)for(let j=0;j<indexArr.length;j++)obj[indexArr[j]+i*csLen]=sum,sum++;for(let a=0;a<indexArr.length&&indexArr[a]<rsd;a++)obj[indexArr[a]+csLen*num]=sum,sum++}else for(let a=0;a<indexArr.length&&indexArr[a]<rsd;a++)obj[indexArr[a]]=sum,sum++;return obj}__name(getDataIndex,"getDataIndex");function fillCopy(data,len){const applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]);applyData.push({v:null,s:null,p:null,f:null,si:null,t:null,...d})}return applyData}__name(fillCopy,"fillCopy");function fillCopyStyles(data,len){var _a58;const applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d={s:(_a58=data[index])==null?void 0:_a58.s};applyData.push(d)}return applyData}__name(fillCopyStyles,"fillCopyStyles");function isEqualRatio(arr){let ratio=!0;const step=arr[1]/arr[0];for(let i=1;i<arr.length;i++)if(arr[i]/arr[i-1]!==step){ratio=!1;break}return ratio}__name(isEqualRatio,"isEqualRatio");function getXArr(len){const xArr=[];for(let i=1;i<=len;i++)xArr.push(i);return xArr}__name(getXArr,"getXArr");function fillSeries(data,len,direction){var _a58,_b,_c,_d;const applyData=[],dataNumArr=[];for(let j=0;j<data.length;j++)dataNumArr.push(Number((_a58=data[j])==null?void 0:_a58.v));if(data.length>2&&isEqualRatio(dataNumArr))for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),num=Number((_b=data[data.length-1])==null?void 0:_b.v)*(Number((_c=data[1])==null?void 0:_c.v)/Number((_d=data[0])==null?void 0:_d.v))**i;d&&(needsUpdateCellValue(d)&&(d.v=num),applyData.push(d))}else{const xArr=getXArr(data.length);for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),forward=direction===core.Direction.DOWN||direction===core.Direction.RIGHT,y=forecast(data.length+i,dataNumArr,xArr,forward);d&&(needsUpdateCellValue(d)&&(d.v=y),applyData.push(d))}}return applyData}__name(fillSeries,"fillSeries");function forecast(x,yArr,xArr,forward=!0){function getAverage(arr){let sum=0;for(let i=0;i<arr.length;i++)sum+=arr[i];return sum/arr.length}__name(getAverage,"getAverage");const ax=getAverage(xArr),ay=getAverage(yArr);let sum_d=0,sum_n=0;for(let j=0;j<xArr.length;j++)sum_d+=(xArr[j]-ax)*(yArr[j]-ay),sum_n+=(xArr[j]-ax)*(xArr[j]-ax);let b;sum_n===0?b=forward?1:-1:b=sum_d/sum_n;const a=ay-b*ax;return Math.round((a+b*x)*1e5)/1e5}__name(forecast,"forecast");function fillExtendNumber(data,len,step){var _a58;const applyData=[],reg=/0|([1-9]+[0-9]*)/g;for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),last=`${(_a58=data[data.length-1])==null?void 0:_a58.v}`,match=last==null?void 0:last.match(reg),lastTxt=match==null?void 0:match[match.length-1],num=Math.abs(Number(lastTxt)+step*i);if(!last||!lastTxt)continue;const lastIndex=last.lastIndexOf(lastTxt),valueTxt=last.substr(0,lastIndex)+num.toString()+last.substr(lastIndex+lastTxt.length);d&&(d.v=valueTxt,applyData.push(d))}return applyData}__name(fillExtendNumber,"fillExtendNumber");function fillChnWeek(data,len,step,weekType=0){var _a58,_b;const keywordMap=[["日","一","二","三","四","五","六"],["周日","周一","周二","周三","周四","周五","周六"],["星期日","星期一","星期二","星期三","星期四","星期五","星期六"]];if(weekType>=keywordMap.length)return[];const keyword=keywordMap[weekType],applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]);let num=0;if(((_a58=data[data.length-1])==null?void 0:_a58.v)===keyword[0])num=7+step*i;else{const last=`${(_b=data[data.length-1])==null?void 0:_b.v}`;if(last){const txt=last.substr(last.length-1,1);num=chineseToNumber(txt)+step*i}}num<0&&(num=Math.ceil(Math.abs(num)/7)*7+num);const rsd=num%7;d&&(d.v=keyword[rsd],applyData.push(d))}return applyData}__name(fillChnWeek,"fillChnWeek");function fillChnNumber(data,len,step){var _a58;const applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),formattedValue=`${(_a58=data[data.length-1])==null?void 0:_a58.v}`,num=chineseToNumber(formattedValue)+step*i;let txt;num<=0?txt="零":txt=numberToChinese(num),d&&(d.v=txt,applyData.push(d))}return applyData}__name(fillChnNumber,"fillChnNumber");const LOOP_SERIES={enWeek1:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],enWeek2:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],enMonth1:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],enMonth2:["January","February","March","April","May","June","July","August","September","October","November","December"],chnMonth1:["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],chnMonth2:["正月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","腊月"],chHour1:["子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥"],chHour2:["子时","丑时","寅时","卯时","辰时","巳时","午时","未时","申时","酉时","戌时","亥时"],chYear1:["甲","乙","丙","丁","戊","己","庚","辛","壬","癸"],chSeason1:["春","夏","秋","冬"],chSeason2:["春季","夏季","秋季","冬季"]};function isLoopSeries(txt){let isLoopSeries2=!1;return Object.keys(LOOP_SERIES).forEach(key=>{LOOP_SERIES[key].includes(txt)&&(isLoopSeries2=!0)}),isLoopSeries2}__name(isLoopSeries,"isLoopSeries");function getLoopSeriesInfo(txt){let name="";const series=[];return Object.keys(LOOP_SERIES).forEach(key=>{LOOP_SERIES[key].includes(txt)&&(name=key,series.push(...LOOP_SERIES[key]))}),{name,series}}__name(getLoopSeriesInfo,"getLoopSeriesInfo");function fillLoopSeries(data,len,step,series){var _a58;const seriesLen=series.length,applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),last=`${(_a58=data[data.length-1])==null?void 0:_a58.v}`;let num=series.indexOf(last)+step*i;num<0&&(num+=Math.abs(step)*seriesLen);const rsd=num%seriesLen;d&&(d.v=series[rsd],applyData.push(d))}return applyData}__name(fillLoopSeries,"fillLoopSeries");function getAutoFillRepeatRange(sourceRange,targetRange){const repeats=[];let direction;if(targetRange.startRow<sourceRange.startRow)direction=core.Direction.UP;else if(targetRange.endRow>sourceRange.endRow)direction=core.Direction.DOWN;else if(targetRange.startColumn<sourceRange.startColumn)direction=core.Direction.LEFT;else if(targetRange.endColumn>sourceRange.endColumn)direction=core.Direction.RIGHT;else return[];if(direction===core.Direction.DOWN||direction===core.Direction.UP){const sourceLength=sourceRange.endRow-sourceRange.startRow+1,targetLength=targetRange.endRow-targetRange.startRow+1,mod=Math.floor(targetLength/sourceLength),rest=targetLength%sourceLength,relativeRange={startRow:0,startColumn:0,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:sourceRange.endColumn-sourceRange.startColumn};if(direction===core.Direction.DOWN){for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow+(i+1)*sourceLength,col:sourceRange.startColumn},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow+(mod+1)*sourceLength,col:sourceRange.startColumn},relativeRange:{startRow:0,startColumn:0,endRow:rest-1,endColumn:sourceRange.endColumn-sourceRange.startColumn}})}else{for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow-(i+1)*sourceLength,col:sourceRange.startColumn},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow-(mod+1)*sourceLength,col:sourceRange.startColumn},relativeRange:{startRow:sourceLength-rest,endRow:sourceLength-1,startColumn:0,endColumn:sourceRange.endColumn-sourceRange.startColumn}})}}if(direction===core.Direction.RIGHT||direction===core.Direction.LEFT){const sourceLength=sourceRange.endColumn-sourceRange.startColumn+1,targetLength=targetRange.endColumn-targetRange.startColumn+1,mod=Math.floor(targetLength/sourceLength),rest=targetLength%sourceLength,relativeRange={startRow:0,startColumn:0,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:sourceRange.endColumn-sourceRange.startColumn};if(direction===core.Direction.RIGHT){for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn+(i+1)*sourceLength},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn+(mod+1)*sourceLength},relativeRange:{startRow:0,startColumn:0,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:rest-1}})}else{for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn-(i+1)*sourceLength},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn-(mod+1)*sourceLength},relativeRange:{startRow:0,startColumn:sourceLength-rest,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:sourceLength-1}})}}return repeats}__name(getAutoFillRepeatRange,"getAutoFillRepeatRange");function needsUpdateCellValue(cell){return!(core.isFormulaString(cell.f)||core.isFormulaId(cell.si)||cell.t===core.CellValueType.BOOLEAN)}__name(needsUpdateCellValue,"needsUpdateCellValue");var AutoFillHookType=(AutoFillHookType2=>(AutoFillHookType2.Append="APPEND",AutoFillHookType2.Default="DEFAULT",AutoFillHookType2.Only="ONLY",AutoFillHookType2))(AutoFillHookType||{}),DATA_TYPE=(DATA_TYPE2=>(DATA_TYPE2.NUMBER="number",DATA_TYPE2.DATE="date",DATA_TYPE2.EXTEND_NUMBER="extendNumber",DATA_TYPE2.CHN_NUMBER="chnNumber",DATA_TYPE2.CHN_WEEK2="chnWeek2",DATA_TYPE2.CHN_WEEK3="chnWeek3",DATA_TYPE2.LOOP_SERIES="loopSeries",DATA_TYPE2.FORMULA="formula",DATA_TYPE2.OTHER="other",DATA_TYPE2))(DATA_TYPE||{}),APPLY_TYPE=(APPLY_TYPE2=>(APPLY_TYPE2.COPY="COPY",APPLY_TYPE2.SERIES="SERIES",APPLY_TYPE2.ONLY_FORMAT="ONLY_FORMAT",APPLY_TYPE2.NO_FORMAT="NO_FORMAT",APPLY_TYPE2))(APPLY_TYPE||{});const dateRule={type:DATA_TYPE.DATE,priority:1100,match:__name((cellData,accessor)=>{var _a58;if(cellData!=null&&cellData.f||cellData!=null&&cellData.si)return!1;if((typeof(cellData==null?void 0:cellData.v)=="number"||(cellData==null?void 0:cellData.t)===core.CellValueType.NUMBER)&&cellData.s){if(typeof cellData.s=="string"){const style=accessor.get(core.IUniverInstanceService).getFocusedUnit().getStyles().get(cellData.s),pattern=(_a58=style==null?void 0:style.n)==null?void 0:_a58.pattern;if(pattern)return core.numfmt.getInfo(pattern).isDate}else if(cellData.s.n&&core.numfmt.getInfo(cellData.s.n.pattern).isDate)return!0}return!1},"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.DATE,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{const{data}=dataWithIndex;return direction===core.Direction.LEFT||direction===core.Direction.UP?(data.reverse(),fillSeries(data,len,direction).reverse()):fillSeries(data,len,direction)}}},numberRule={type:DATA_TYPE.NUMBER,priority:1e3,match:__name(cellData=>typeof(cellData==null?void 0:cellData.v)=="number"||(cellData==null?void 0:cellData.t)===core.CellValueType.NUMBER,"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.NUMBER,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{const{data}=dataWithIndex;return direction===core.Direction.LEFT||direction===core.Direction.UP?(data.reverse(),fillSeries(data,len,direction).reverse()):fillSeries(data,len,direction)}}},otherRule={type:DATA_TYPE.OTHER,priority:0,match:__name(()=>!0,"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.OTHER,"isContinue")},extendNumberRule={type:DATA_TYPE.EXTEND_NUMBER,priority:900,match:__name(cellData=>matchExtendNumber(`${cellData==null?void 0:cellData.v}`||"").isExtendNumber,"match"),isContinue:__name((prev,cur)=>{var _a58;if(prev.type===DATA_TYPE.EXTEND_NUMBER){const{beforeTxt,afterTxt}=matchExtendNumber(`${(_a58=prev.cellData)==null?void 0:_a58.v}`||""),{beforeTxt:curBeforeTxt,afterTxt:curAfterTxt}=matchExtendNumber(`${cur==null?void 0:cur.v}`||"");if(beforeTxt===curBeforeTxt&&afterTxt===curAfterTxt)return!0}return!1},"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58;const{data}=dataWithIndex,isReverse=direction===core.Direction.UP||direction===core.Direction.LEFT;let step;if(data.length===1)return step=isReverse?-1:1,reverseIfNeed(fillExtendNumber(data,len,step),isReverse);const dataNumArr=[];for(let i=0;i<data.length;i++){const txt=`${(_a58=data[i])==null?void 0:_a58.v}`;txt&&dataNumArr.push(Number(matchExtendNumber(txt).matchTxt))}return isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)?(step=dataNumArr[1]-dataNumArr[0],reverseIfNeed(fillExtendNumber(data,len,step),isReverse)):fillCopy(data,len)}}},chnNumberRule={type:DATA_TYPE.CHN_NUMBER,priority:830,match:__name(cellData=>!!isChnNumber(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.CHN_NUMBER,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58,_b,_c;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP;if(data.length===1){const formattedValue=`${(_a58=data[0])==null?void 0:_a58.v}`;let step;return isReverse?step=-1:step=1,formattedValue&&(formattedValue==="日"||chineseToNumber(formattedValue)<7)?reverseIfNeed(fillChnWeek(data,len,step),isReverse):reverseIfNeed(fillChnNumber(data,len,step),isReverse)}let hasWeek=!1;for(let i=0;i<data.length;i++)if(((_b=data[i])==null?void 0:_b.v)==="日"){hasWeek=!0;break}const dataNumArr=[];let weekIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_c=data[i])==null?void 0:_c.v}`;formattedValue==="日"?i===0?dataNumArr.push(0):(weekIndex++,dataNumArr.push(weekIndex*7)):hasWeek&&chineseToNumber(formattedValue)>0&&chineseToNumber(formattedValue)<7?dataNumArr.push(chineseToNumber(formattedValue)+weekIndex*7):dataNumArr.push(chineseToNumber(formattedValue))}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){if(hasWeek||dataNumArr[dataNumArr.length-1]<6&&dataNumArr[0]>0||dataNumArr[0]<6&&dataNumArr[dataNumArr.length-1]>0){const step2=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnWeek(data,len,step2),isReverse)}const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnNumber(data,len,step),isReverse)}return fillCopy(data,len)}}},chnWeek2Rule={type:DATA_TYPE.CHN_WEEK2,priority:820,match:__name(cellData=>!!isChnWeek2(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.CHN_WEEK2,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP;if(data.length===1){let step;return isReverse?step=-1:step=1,reverseIfNeed(fillChnWeek(data,len,step,1),isReverse)}const dataNumArr=[];let weekIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_a58=data[i])==null?void 0:_a58.v}`,lastTxt=formattedValue==null?void 0:formattedValue.substr(formattedValue.length-1,1);formattedValue==="周日"?i===0?dataNumArr.push(0):(weekIndex++,dataNumArr.push(weekIndex*7)):dataNumArr.push(chineseToNumber(lastTxt)+weekIndex*7)}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnWeek(data,len,step,1),isReverse)}return fillCopy(data,len)}}},chnWeek3Rule={type:DATA_TYPE.CHN_WEEK3,priority:810,match:__name(cellData=>isChnWeek3(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.CHN_WEEK3,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP;if(data.length===1){let step;return isReverse?step=-1:step=1,reverseIfNeed(fillChnWeek(data,len,step,2),isReverse)}const dataNumArr=[];let weekIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_a58=data[i])==null?void 0:_a58.v}`;if(formattedValue){const lastTxt=formattedValue.substr(formattedValue.length-1,1);formattedValue==="星期日"?i===0?dataNumArr.push(0):(weekIndex++,dataNumArr.push(weekIndex*7)):dataNumArr.push(chineseToNumber(lastTxt)+weekIndex*7)}}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnWeek(data,len,step,2),isReverse)}return fillCopy(data,len)}}},loopSeriesRule={type:DATA_TYPE.LOOP_SERIES,priority:800,match:__name(cellData=>isLoopSeries(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>{var _a58;return prev.type===DATA_TYPE.LOOP_SERIES?getLoopSeriesInfo(`${(_a58=prev.cellData)==null?void 0:_a58.v}`||"").name===getLoopSeriesInfo(`${cur==null?void 0:cur.v}`||"").name:!1},"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58,_b;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP,{series}=getLoopSeriesInfo(`${(_a58=data[0])==null?void 0:_a58.v}`||"");if(data.length===1){let step;return isReverse?step=-1:step=1,reverseIfNeed(fillLoopSeries(data,len,step,series),isReverse)}const dataNumArr=[];let cycleIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_b=data[i])==null?void 0:_b.v}`;formattedValue&&(formattedValue===series[0]?i===0?dataNumArr.push(0):(cycleIndex++,dataNumArr.push(cycleIndex*series.length)):dataNumArr.push(series.indexOf(formattedValue)+cycleIndex*7))}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillLoopSeries(data,len,step,series),isReverse)}return fillCopy(data,len)}}};function reverseIfNeed(data,reverse){return reverse?data.reverse():data}__name(reverseIfNeed,"reverseIfNeed");var __defProp$L=Object.defineProperty,__getOwnPropDesc$L=Object.getOwnPropertyDescriptor,__decorateClass$L=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$L(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$L(target,key,result),result},"__decorateClass$L"),__decorateParam$L=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$L"),_a8;exports.AutoFillService=(_a8=class extends core.Disposable{constructor(_commandService,_undoRedoService,_renderManagerService,_univerInstanceService,_selectionManagerService,_injector){super();__publicField(this,"_rules",[]);__publicField(this,"_hooks",[]);__publicField(this,"_applyType$",new rxjs.BehaviorSubject(APPLY_TYPE.SERIES));__publicField(this,"_isFillingStyle",!0);__publicField(this,"_prevUndos",[]);__publicField(this,"_autoFillLocation$",new rxjs.BehaviorSubject(null));__publicField(this,"autoFillLocation$",this._autoFillLocation$.asObservable());__publicField(this,"_showMenu$",new rxjs.BehaviorSubject(!1));__publicField(this,"showMenu$",this._showMenu$.asObservable());__publicField(this,"_direction",core.Direction.DOWN);__publicField(this,"applyType$",this._applyType$.asObservable());__publicField(this,"_menu$",new rxjs.BehaviorSubject([{label:"autoFill.copy",value:APPLY_TYPE.COPY,disable:!1},{label:"autoFill.series",value:APPLY_TYPE.SERIES,disable:!1},{label:"autoFill.formatOnly",value:APPLY_TYPE.ONLY_FORMAT,disable:!1},{label:"autoFill.noFormat",value:APPLY_TYPE.NO_FORMAT,disable:!1}]));__publicField(this,"menu$",this._menu$.asObservable());this._commandService=_commandService,this._undoRedoService=_undoRedoService,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._injector=_injector,this._init()}_init(){this._rules=[dateRule,numberRule,extendNumberRule,chnNumberRule,chnWeek2Rule,chnWeek3Rule,loopSeriesRule,otherRule].sort((a,b)=>b.priority-a.priority),this._isFillingStyle=!0}_getOneByPriority(items){return items.length<=0?[]:[items.reduce((maxItem,currentItem)=>(currentItem.priority||0)>(maxItem.priority||0)?currentItem:maxItem,items[0])]}initPrevUndo(){this._prevUndos=[]}addHook(hook){if(this._hooks.find(h=>h.id===hook.id))throw new Error(`Add hook failed, hook id '${hook.id}' already exist!`);return hook.priority===void 0&&(hook.priority=0),hook.type===void 0&&(hook.type=AutoFillHookType.Append),this._hooks.push(hook),core.toDisposable(()=>{const index=this._hooks.findIndex(item=>item===hook);index>-1&&this._hooks.splice(index,1)})}registerRule(rule){if(this._rules.find(r2=>r2.type===rule.type))throw new Error(`Registry rule failed, type '${rule.type}' already exist!`);const index=this._rules.findIndex(r2=>r2.priority<rule.priority);this._rules.splice(index===-1?this._rules.length:index,0,rule)}getRules(){return this._rules}getAllHooks(){return this._hooks}getActiveHooks(){const{source,target,unitId,subUnitId}=this.autoFillLocation||{};if(!source||!target||!unitId||!subUnitId)return[];const enabledHooks=this._hooks.filter(h=>{var _a58;return!((_a58=h.disable)!=null&&_a58.call(h,{source,target,unitId,subUnitId},this._direction,this.applyType))}),onlyHooks=enabledHooks.filter(h=>h.type===AutoFillHookType.Only);if(onlyHooks.length>0)return this._getOneByPriority(onlyHooks);const defaultHooks=this._getOneByPriority(enabledHooks.filter(h=>h.type===AutoFillHookType.Default)),appendHooks=enabledHooks.filter(h=>h.type===AutoFillHookType.Append)||[];return[...defaultHooks,...appendHooks]}get applyType(){return this._applyType$.getValue()}set applyType(type){this._applyType$.next(type)}get menu(){return this._menu$.getValue()}get direction(){return this._direction}set direction(direction){this._direction=direction}isFillingStyle(){return this._isFillingStyle}setFillingStyle(isFillingStyle){this._isFillingStyle=isFillingStyle}get autoFillLocation(){return this._autoFillLocation$.getValue()}set autoFillLocation(location){this._autoFillLocation$.next(location)}setDisableApplyType(type,disable){this._menu$.next(this._menu$.getValue().map(item=>item.value===type?{...item,disable}:item))}setShowMenu(show){this._showMenu$.next(show)}fillData(triggerUnitId,triggerSubUnitId){var _a58,_b,_c;const{source,target,unitId=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId(),subUnitId=(_a58=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet())==null?void 0:_a58.getSheetId()}=this.autoFillLocation||{},direction=this.direction;if(!source||!source.cols.length||!source.rows.length||!target||!target.cols.length||!target.rows.length||unitId!==triggerUnitId||subUnitId!==triggerSubUnitId)return!1;this._prevUndos.length>0&&this._prevUndos.forEach(undo=>{this._commandService.syncExecuteCommand(undo.id,undo.params)}),this._prevUndos=[];const selection=core.Rectangle.union(discreteRangeToRange(source),discreteRangeToRange(target)),applyType=this.applyType,activeHooks=this.getActiveHooks();this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,{selections:[{primary:{...(_c=(_b=this._selectionManagerService.getCurrentLastSelection())==null?void 0:_b.primary)!=null?_c:selection},range:{...selection,rangeType:core.RANGE_TYPE.NORMAL}}],unitId,subUnitId});const undos=[],redos=[];activeHooks.forEach(hook=>{var _a59;const{undos:hookUndos,redos:hookRedos}=((_a59=hook.onFillData)==null?void 0:_a59.call(hook,{source,target,unitId,subUnitId},direction,applyType))||{};hookUndos&&undos.push(...hookUndos),hookRedos&&redos.push(...hookRedos)});const result=redos.every(m2=>this._commandService.syncExecuteCommand(m2.id,m2.params)),autoHeightRanges=[];applyType!==APPLY_TYPE.NO_FORMAT&&redos.forEach(m2=>{if(m2.id===sheets.SetRangeValuesMutation.id){const{cellValue}=m2.params;new core.ObjectMatrix(cellValue).forValue((row,col,value)=>{const style=Object.keys((value==null?void 0:value.s)||{});style.length&&AFFECT_LAYOUT_STYLES.some(s=>style.includes(s))&&autoHeightRanges.push({startRow:row,endRow:row,startColumn:col,endColumn:col})})}});const autoHeightUndoRedos=this._getAutoHeightUndoRedos(triggerUnitId,triggerSubUnitId,autoHeightRanges);return autoHeightUndoRedos.redos.every(m2=>this._commandService.syncExecuteCommand(m2.id,m2.params))&&(undos.push(...autoHeightUndoRedos.undos),redos.push(...autoHeightUndoRedos.redos)),result&&(this._prevUndos=undos,this._undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos})),activeHooks.forEach(hook=>{var _a59;(_a59=hook.onAfterFillData)==null||_a59.call(hook,{source,target,unitId,subUnitId},direction,applyType)}),this.setShowMenu(!0),!0}_getAutoHeightUndoRedos(unitId,subUnitId,ranges){var _a58,_b;const sheetSkeletonService=(_a58=this._renderManagerService.getRenderById(unitId))==null?void 0:_a58.with(exports.SheetSkeletonManagerService),skeleton=(_b=sheetSkeletonService==null?void 0:sheetSkeletonService.getCurrent())==null?void 0:_b.skeleton;if(!skeleton)return{redos:[],undos:[]};const rowsAutoHeightInfo=skeleton.calculateAutoHeightInRange(ranges),redoParams={subUnitId,unitId,rowsAutoHeightInfo},worksheet=skeleton.worksheet,undoParams=sheets.SetWorksheetRowAutoHeightMutationFactory(redoParams,worksheet);return{undos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:undoParams}],redos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:redoParams}]}}},__name(_a8,"AutoFillService"),_a8);exports.AutoFillService=__decorateClass$L([__decorateParam$L(0,core.ICommandService),__decorateParam$L(1,core.IUndoRedoService),__decorateParam$L(2,engineRender.IRenderManagerService),__decorateParam$L(3,core.Inject(core.IUniverInstanceService)),__decorateParam$L(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$L(5,core.Inject(core.Injector))],exports.AutoFillService);const IAutoFillService=core.createIdentifier("univer.auto-fill-service"),AutoFillCommand={type:core.CommandType.COMMAND,id:"sheet.command.auto-fill",handler:__name(async(accessor,params)=>accessor.get(IAutoFillService).fillData(params.unitId,params.subUnitId),"handler")},AutoClearContentCommand={id:"sheet.command.auto-clear-content",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target,{clearRange,selectionRange}=params,clearMutationParams={subUnitId,unitId,cellValue:sheets.generateNullCellValue([clearRange])},undoClearMutationParams=sheets.SetRangeValuesUndoMutationFactory(accessor,clearMutationParams),{startColumn,startRow}=selectionRange;return commandService.executeCommand(sheets.SetSelectionsOperation.id,{selections:[{primary:{startColumn,startRow,endColumn:startColumn,endRow:startRow,actualRow:startRow,actualColumn:startColumn,isMerge:!1,isMergedMainCell:!1},range:{...selectionRange}}],unitId,subUnitId}),commandService.syncExecuteCommand(sheets.SetRangeValuesMutation.id,clearMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:sheets.SetRangeValuesMutation.id,params:undoClearMutationParams}],redoMutations:[{id:sheets.SetRangeValuesMutation.id,params:clearMutationParams}]}),!0):!1},"handler")},SetCellEditVisibleOperation={id:"sheet.operation.set-cell-edit-visible",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>params?(accessor.get(IEditorBridgeService).changeVisible(params),!0):!1,"handler")},SetCellEditVisibleWithF2Operation={id:"sheet.operation.set-cell-edit-visible-f2",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>(accessor.get(core.ICommandService).syncExecuteCommand(SetCellEditVisibleOperation.id,params),!0),"handler")},SetCellEditVisibleArrowOperation={id:"sheet.operation.set-cell-edit-visible-arrow",type:core.CommandType.OPERATION,handler:__name(()=>!0,"handler")},ChangeZoomRatioCommand={id:"sheet.command.change-zoom-ratio",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,subUnitId,unitId}=target,{delta,reset}=params;let zoom=reset?100:Math.round((worksheet.getConfig().zoomRatio+delta)*100);zoom=Math.max(SHEET_ZOOM_RANGE[0],zoom),zoom=Math.min(SHEET_ZOOM_RANGE[1],zoom);const zoomRatio=zoom/100,state=accessor.get(IEditorBridgeService).isVisible();return(state.unitId===unitId||state.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)&&state.visible?!1:accessor.get(core.ICommandService).executeCommand(SetZoomRatioOperation.id,{unitId,subUnitId,zoomRatio})},"handler")},SetZoomRatioCommand={id:"sheet.command.set-zoom-ratio",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const{unitId,subUnitId,zoomRatio}=params,state=accessor.get(IEditorBridgeService).isVisible();return(state.unitId===unitId||state.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)&&state.visible?!1:accessor.get(core.ICommandService).executeCommand(SetZoomRatioOperation.id,{unitId,subUnitId,zoomRatio})},"handler")};var __defProp$K=Object.defineProperty,__getOwnPropDesc$K=Object.getOwnPropertyDescriptor,__decorateClass$K=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$K(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$K(target,key,result),result},"__decorateClass$K"),__decorateParam$K=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$K"),_a9;let SheetsZoomRenderController=(_a9=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService,_contextService,_editorBridgeService){super(),this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._contextService=_contextService,this._editorBridgeService=_editorBridgeService,this._initSkeletonListener(),this._initZoomEventListener()}updateZoom(worksheetId,zoomRatio){const worksheet=this._context.unit.getSheetBySheetId(worksheetId);return worksheet?(worksheet.getConfig().zoomRatio=zoomRatio,worksheet===this._context.unit.getActiveSheet()&&this._updateViewZoom(zoomRatio),!0):!1}_initZoomEventListener(){const scene=this._getSheetObject().scene;this.disposeWithMe(scene.onMouseWheel$.subscribeEvent(e=>{if(!e.ctrlKey||!this._contextService.getContextValue(core.FOCUSING_SHEET))return;if(this._editorBridgeService){const state=this._editorBridgeService.isVisible();if((state.unitId===this._context.unitId||state.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)&&state.visible)return}const deltaFactor=Math.abs(e.deltaX);let ratioDelta=deltaFactor<40?.2:deltaFactor<80?.4:.2;ratioDelta*=e.deltaY>0?-1:1,scene.scaleX<1&&(ratioDelta/=2);const workbook=this._context.unit,sheet=workbook.getActiveSheet();if(!sheet)return;const currentRatio=sheet.getZoomRatio();let nextRatio=+Number.parseFloat(`${currentRatio+ratioDelta}`).toFixed(1);nextRatio=nextRatio>=4?4:nextRatio<=.1?.1:nextRatio,this._commandService.executeCommand(SetZoomRatioCommand.id,{zoomRatio:Math.round(nextRatio*10)/10,unitId:workbook.getUnitId(),subUnitId:sheet.getSheetId()}),e.preventDefault()}))}_initSkeletonListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(param=>{if(param==null)return;const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const zoomRatio=worksheet.getZoomRatio()||1;this._updateViewZoom(zoomRatio)}))}_updateViewZoom(zoomRatio){const sheetObject=this._getSheetObject();sheetObject==null||sheetObject.scene.scale(zoomRatio,zoomRatio),sheetObject==null||sheetObject.spreadsheet.makeForceDirty()}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}},__name(_a9,"SheetsZoomRenderController"),_a9);SheetsZoomRenderController=__decorateClass$K([__decorateParam$K(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$K(2,core.ICommandService),__decorateParam$K(3,core.IContextService),__decorateParam$K(4,core.Optional(IEditorBridgeService))],SheetsZoomRenderController);const SetZoomRatioOperation={id:"sheet.operation.set-zoom-ratio",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{const renderUnit=accessor.get(engineRender.IRenderManagerService).getRenderById(params.unitId);return renderUnit?renderUnit.with(SheetsZoomRenderController).updateZoom(params.subUnitId,params.zoomRatio):!1},"handler")};var __defProp$J=Object.defineProperty,__getOwnPropDesc$J=Object.getOwnPropertyDescriptor,__decorateClass$J=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$J(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$J(target,key,result),result},"__decorateClass$J"),__decorateParam$J=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$J"),_a10;exports.AutoFillController=(_a10=class extends core.Disposable{constructor(_univerInstanceService,_commandService,_autoFillService,_editorBridgeService,_renderManagerService,_injector,_sheetsRenderService){super();__publicField(this,"_beforeApplyData",[]);__publicField(this,"_currentLocation",null);__publicField(this,"_copyData",[]);__publicField(this,"_defaultHook");this._univerInstanceService=_univerInstanceService,this._commandService=_commandService,this._autoFillService=_autoFillService,this._editorBridgeService=_editorBridgeService,this._renderManagerService=_renderManagerService,this._injector=_injector,this._sheetsRenderService=_sheetsRenderService,this._defaultHook={id:"default",type:AutoFillHookType.Default,priority:0,onBeforeFillData:__name((location,direction)=>this._presetAndCacheData(location,direction),"onBeforeFillData"),onFillData:__name((location,direction,applyType)=>this._fillData(location,direction,applyType),"onFillData")},this._init()}_init(){this._initDefaultHook(),this._onSelectionControlFillChanged(),this._onApplyTypeChanged(),this._initQuitListener(),this._initSkeletonChange()}_initSkeletonChange(){this.disposeWithMe(this._sheetsRenderService.registerSkeletonChangingMutations(AutoFillCommand.id))}_initDefaultHook(){this.disposeWithMe(this._autoFillService.addHook(this._defaultHook))}_initQuitListener(){const quitCommands=[SetCellEditVisibleOperation.id,AutoClearContentCommand.id,sheets.SetRangeValuesCommand.id,SetZoomRatioOperation.id,sheets.SetWorksheetActiveOperation.id,sheets.MoveRangeMutation.id,sheets.RemoveRowMutation.id,sheets.RemoveColMutation.id,sheets.InsertRowMutation.id,sheets.InsertColMutation.id,sheets.MoveRowsMutation.id,sheets.MoveColsMutation.id,sheets.SetWorksheetColWidthMutation.id,sheets.SetWorksheetRowHeightMutation.id,sheets.SetRangeValuesMutation.id];this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{var _a58,_b;const fromCollab=options==null?void 0:options.fromCollab,fromSync=options==null?void 0:options.fromSync,fromFormula=options==null?void 0:options.fromFormula;quitCommands.includes(command.id)&&!fromCollab&&!fromSync&&!fromFormula&&command.params.trigger!==AutoFillCommand.id&&this._quit(),command.id===sheets.RemoveSheetMutation.id&&command.params.unitId===((_a58=this._currentLocation)==null?void 0:_a58.unitId)&&command.params.subUnitId===((_b=this._currentLocation)==null?void 0:_b.subUnitId)&&this._quit()})),this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(unit=>{var _a58;unit.getUnitId()===((_a58=this._currentLocation)==null?void 0:_a58.unitId)&&this._quit()}))}_quit(){this._currentLocation=null,this._beforeApplyData=[],this._copyData=[],this._autoFillService.setShowMenu(!1)}_onSelectionControlFillChanged(){const disposableCollection=new core.DisposableCollection,addListener=__name(disposableCollection2=>{disposableCollection2.dispose();const currentRenderer=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET);if(!currentRenderer)return;currentRenderer.with(ISheetSelectionRenderService).getSelectionControls().forEach(controlSelection=>{disposableCollection2.add(core.toDisposable(controlSelection.selectionFilled$.subscribe(filled=>{if(filled==null||filled.startColumn===-1||filled.startRow===-1||filled.endColumn===-1||filled.endRow===-1)return;const source={startColumn:controlSelection.model.startColumn,endColumn:controlSelection.model.endColumn,startRow:controlSelection.model.startRow,endRow:controlSelection.model.endRow},selection={startColumn:filled.startColumn,endColumn:filled.endColumn,startRow:filled.startRow,endRow:filled.endRow};this._triggerAutoFill(source,selection)}))),disposableCollection2.add(core.toDisposable(controlSelection.fillControl.onDblclick$.subscribeEvent(()=>{const source={startColumn:controlSelection.model.startColumn,endColumn:controlSelection.model.endColumn,startRow:controlSelection.model.startRow,endRow:controlSelection.model.endRow};this._handleDbClickFill(source)}))),disposableCollection2.add(core.toDisposable(controlSelection.fillControl.onPointerDown$.subscribeEvent(()=>{this._editorBridgeService.isVisible().visible&&this._editorBridgeService.changeVisible({visible:!1,eventType:engineRender.DeviceInputEventType.PointerDown,unitId:currentRenderer.unitId})})))})},"addListener");addListener(disposableCollection),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{command.id===sheets.SetSelectionsOperation.id&&addListener(disposableCollection)}))}_onApplyTypeChanged(){this.disposeWithMe(core.toDisposable(this._autoFillService.applyType$.subscribe(()=>{this._handleFillData()})))}_triggerAutoFill(source,selection){var _a58,_b;if(source.startColumn===selection.startColumn&&source.startRow===selection.startRow&&source.endColumn===selection.endColumn&&source.endRow===selection.endRow)return;if(selection.endColumn<source.endColumn&&selection.endColumn>source.startColumn){this._commandService.executeCommand(AutoClearContentCommand.id,{clearRange:{startRow:selection.startRow,endRow:selection.endRow,startColumn:selection.endColumn+1,endColumn:source.endColumn},selectionRange:selection});return}if(selection.endRow<source.endRow&&selection.endRow>source.startRow){this._commandService.executeCommand(AutoClearContentCommand.id,{clearRange:{startRow:selection.endRow+1,endRow:source.endRow,startColumn:selection.startColumn,endColumn:selection.endColumn},selectionRange:selection});return}const target={startRow:selection.startRow,endRow:selection.endRow,startColumn:selection.startColumn,endColumn:selection.endColumn};let direction=null;if(selection.startRow<source.startRow)direction=core.Direction.UP,target.endRow=source.startRow-1;else if(selection.endRow>source.endRow)direction=core.Direction.DOWN,target.startRow=source.endRow+1;else if(selection.startColumn<source.startColumn)direction=core.Direction.LEFT,target.endColumn=source.startColumn-1;else if(selection.endColumn>source.endColumn)direction=core.Direction.RIGHT,target.startColumn=source.endColumn+1;else return;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return;const unitId=workbook.getUnitId(),subUnitId=(_a58=workbook.getActiveSheet())==null?void 0:_a58.getSheetId();if(!subUnitId)return;this._autoFillService.direction=direction;const autoFillSource=this._injector.invoke(accessor=>rangeToDiscreteRange(source,accessor)),autoFillTarget=this._injector.invoke(accessor=>rangeToDiscreteRange(target,accessor));if(!autoFillSource||!autoFillTarget)return;this._autoFillService.autoFillLocation={source:autoFillSource,target:autoFillTarget,unitId,subUnitId};const preferTypes=[];this._autoFillService.getActiveHooks().forEach(hook=>{var _a59;const type=(_a59=hook==null?void 0:hook.onBeforeFillData)==null?void 0:_a59.call(hook,{source:autoFillSource,target:autoFillTarget,unitId,subUnitId},direction);type&&preferTypes.unshift(type)}),this._autoFillService.initPrevUndo();for(let i=0;i<preferTypes.length;i++){const menuItem=this._autoFillService.menu.find(m2=>m2.value===preferTypes[i]);if(menuItem&&!menuItem.disable){this._autoFillService.applyType=preferTypes[i];return}}const first=(_b=this._autoFillService.menu.find(m2=>m2.disable===!1))==null?void 0:_b.value;first&&(this._autoFillService.applyType=first)}_handleDbClickFill(source){const selection=this._detectFillRange(source);selection.endRow<=source.endRow||this._triggerAutoFill(source,selection)}_detectFillRange(source){var _a58,_b,_c,_d,_e,_f;const{startRow,endRow,startColumn,endColumn}=source,worksheet=(_a58=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_a58.getActiveSheet();if(!worksheet)return source;const matrix=worksheet.getCellMatrix(),maxRow=worksheet.getMaxRows()-1,maxColumn=worksheet.getMaxColumns()-1;let detectEndRow=endRow;if(startColumn>0&&((_b=matrix.getValue(startRow,startColumn-1))==null?void 0:_b.v)!=null){let cur=startRow;for(;((_c=matrix.getValue(cur,startColumn-1))==null?void 0:_c.v)!=null&&cur<maxRow;)cur+=1;detectEndRow=cur-1}else if(endColumn<maxColumn&&((_d=matrix.getValue(endRow,endColumn+1))==null?void 0:_d.v)!=null){let cur=startRow;for(;((_e=matrix.getValue(cur,endColumn+1))==null?void 0:_e.v)!=null&&cur<maxRow;)cur+=1;detectEndRow=cur-1}for(let i=endRow+1;i<=detectEndRow;i++)for(let j=startColumn;j<=endColumn;j++)if(((_f=matrix.getValue(i,j))==null?void 0:_f.v)!=null){detectEndRow=i-1;break}return{startColumn,endColumn,startRow,endRow:detectEndRow}}_handleFillData(){var _a58,_b;this._currentLocation&&this._commandService.executeCommand(AutoFillCommand.id,{unitId:(_a58=this._currentLocation)==null?void 0:_a58.unitId,subUnitId:(_b=this._currentLocation)==null?void 0:_b.subUnitId})}_getApplyData(copyDataPiece,csLen,asLen,direction,applyType,hasStyle=!0){const applyData=[],num=Math.floor(asLen/csLen),rsd=asLen%csLen,rules=this._autoFillService.getRules();if(!hasStyle&&applyType===APPLY_TYPE.ONLY_FORMAT)return console.error("ERROR: only format can not be applied when hasStyle is false"),[];const applyDataInTypes={};rules.forEach(r2=>{applyDataInTypes[r2.type]=[]}),rules.forEach(r2=>{const{type,applyFunctions:customApplyFunctions={}}=r2,copyDataInType=copyDataPiece[type];copyDataInType&&copyDataInType.forEach(copySquad=>{const s=getLenS(copySquad.index,rsd),len=copySquad.index.length*num+s,arrData=this._applyFunctions(copySquad,len,direction,applyType,customApplyFunctions,copyDataPiece),arrIndex=getDataIndex(csLen,asLen,copySquad.index);applyDataInTypes[type].push({data:arrData,index:arrIndex})})});for(let x=0;x<asLen;x++)rules.forEach(r2=>{const{type}=r2,applyDataInType=applyDataInTypes[type];for(let y=0;y<applyDataInType.length;y++)x in applyDataInType[y].index&&applyData.push(applyDataInType[y].data[applyDataInType[y].index[x]])});return applyData}_applyFunctions(copySquad,len,direction,applyType,customApplyFunctions,copyDataPiece){const{data}=copySquad,isReverse=direction===core.Direction.UP||direction===core.Direction.LEFT;if(applyType===APPLY_TYPE.COPY){const custom=customApplyFunctions==null?void 0:customApplyFunctions[APPLY_TYPE.COPY];return custom?custom(copySquad,len,direction,copyDataPiece):(isReverse&&data.reverse(),fillCopy(data,len))}if(applyType===APPLY_TYPE.SERIES){const custom=customApplyFunctions==null?void 0:customApplyFunctions[APPLY_TYPE.SERIES];return custom?custom(copySquad,len,direction,copyDataPiece):(isReverse&&data.reverse(),customApplyFunctions!=null&&customApplyFunctions[APPLY_TYPE.COPY]?customApplyFunctions[APPLY_TYPE.COPY](copySquad,len,direction,copyDataPiece):fillCopy(data,len))}if(applyType===APPLY_TYPE.ONLY_FORMAT){const custom=customApplyFunctions==null?void 0:customApplyFunctions[APPLY_TYPE.ONLY_FORMAT];return custom?custom(copySquad,len,direction,copyDataPiece):fillCopyStyles(data,len)}}_getCopyData(source,direction){const worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const currentCellDatas=worksheet.getCellMatrix(),rules=this._autoFillService.getRules(),copyData=[],isVertical=direction===core.Direction.DOWN||direction===core.Direction.UP;let aArray,bArray;return isVertical?(aArray=source.cols,bArray=source.rows):(aArray=source.rows,bArray=source.cols),aArray.forEach(a=>{const copyDataPiece=this._getEmptyCopyDataPiece(),prevData={type:void 0,cellData:void 0};bArray.forEach(b=>{let data;isVertical?data=currentCellDatas.getValue(b,a):data=currentCellDatas.getValue(a,b);const{type,isContinue}=rules.find(r2=>r2.match(data,this._injector))||otherRule;if(isContinue(prevData,data)){const typeInfo=copyDataPiece[type],last=typeInfo[typeInfo.length-1];last.data.push(data),last.index.push(b-bArray[0])}else{const typeInfo=copyDataPiece[type];typeInfo?typeInfo.push({data:[data],index:[b-bArray[0]]}):copyDataPiece[type]=[{data:[data],index:[b-bArray[0]]}]}prevData.type=type,prevData.cellData=data}),copyData.push(copyDataPiece)}),copyData}_getEmptyCopyDataPiece(){const copyDataPiece={};return this._autoFillService.getRules().forEach(r2=>{copyDataPiece[r2.type]=[]}),copyDataPiece}_getMergeApplyData(source,target,direction,csLen){const worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const applyMergeRanges=[];for(let i=source.startRow;i<=source.endRow;i++)for(let j=source.startColumn;j<=source.endColumn;j++){const{isMergedMainCell,startRow,startColumn,endRow,endColumn}=worksheet.getCellInfoInMergeData(i,j);if(isMergedMainCell){if(direction===core.Direction.DOWN){let windowStartRow=startRow+csLen,windowEndRow=endRow+csLen;for(;windowEndRow<=target.endRow;)applyMergeRanges.push({startRow:windowStartRow,startColumn,endRow:windowEndRow,endColumn}),windowStartRow+=csLen,windowEndRow+=csLen}else if(direction===core.Direction.UP){let windowStartRow=startRow-csLen,windowEndRow=endRow-csLen;for(;windowStartRow>=target.startRow;)applyMergeRanges.push({startRow:windowStartRow,startColumn,endRow:windowEndRow,endColumn}),windowStartRow-=csLen,windowEndRow-=csLen}else if(direction===core.Direction.RIGHT){let windowStartColumn=startColumn+csLen,windowEndColumn=endColumn+csLen;for(;windowEndColumn<=target.endColumn;)applyMergeRanges.push({startRow,startColumn:windowStartColumn,endRow,endColumn:windowEndColumn}),windowStartColumn+=csLen,windowEndColumn+=csLen}else if(direction===core.Direction.LEFT){let windowStartColumn=startColumn-csLen,windowEndColumn=endColumn-csLen;for(;windowStartColumn>=target.startColumn;)applyMergeRanges.push({startRow,startColumn:windowStartColumn,endRow,endColumn:windowEndColumn}),windowStartColumn-=csLen,windowEndColumn-=csLen}}}return applyMergeRanges}_presetAndCacheData(location,direction){const{source,target}=location,worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const currentCellDatas=worksheet.getCellMatrix(),applyData=[];return target.rows.forEach(i=>{const row=[];target.cols.forEach(j=>{row.push(core.Tools.deepClone(currentCellDatas.getValue(i,j)))}),applyData.push(row)}),this._beforeApplyData=applyData,this._copyData=this._getCopyData(source,direction),this._currentLocation=location,this._shouldDisableSeries(this._copyData)?(this._autoFillService.setDisableApplyType(APPLY_TYPE.SERIES,!0),APPLY_TYPE.COPY):(this._autoFillService.setDisableApplyType(APPLY_TYPE.SERIES,!1),this._getPreferredApplyType(this._copyData))}_fillData(location,direction,applyType){var _a58,_b;const undos=[],redos=[];let hasStyle=!0;applyType===APPLY_TYPE.NO_FORMAT&&(hasStyle=!1,applyType=APPLY_TYPE.SERIES);const{source,target,unitId,subUnitId}=location;if(!source||!target||direction==null)return{undos,redos};const sourceRange=discreteRangeToRange(source),targetRange=discreteRangeToRange(target),{cols:targetCols,rows:targetRows}=target,{cols:sourceCols,rows:sourceRows}=source,copyData=this._copyData;let csLen;direction===core.Direction.DOWN||direction===core.Direction.UP?csLen=sourceRows.length:csLen=sourceCols.length;const applyDatas=[];if(direction===core.Direction.DOWN||direction===core.Direction.UP){const asLen=targetRows.length,untransformedApplyDatas=[];targetCols.forEach((_,i)=>{const copyD=copyData[i],applyData=this._getApplyData(copyD,csLen,asLen,direction,applyType,hasStyle);untransformedApplyDatas.push(applyData)});for(let i=0;i<untransformedApplyDatas[0].length;i++){const row=[];for(let j=0;j<untransformedApplyDatas.length;j++)row.push({s:null,...untransformedApplyDatas[j][i]});applyDatas.push(row)}}else{const asLen=targetCols.length;targetRows.forEach((_,i)=>{const copyD=copyData[i],applyData=this._getApplyData(copyD,csLen,asLen,direction,applyType,hasStyle),row=[];for(let j=0;j<applyData.length;j++)row.push({s:null,...applyData[j]});applyDatas.push(row)})}let applyMergeRanges=[];const style=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getStyles();if(hasStyle?(applyMergeRanges=this._getMergeApplyData(sourceRange,targetRange,direction,csLen),applyDatas.forEach(row=>{row.forEach(cellData=>{cellData&&style&&style&&(cellData.s=style.getStyleByCell(cellData))})})):applyDatas.forEach((row,rowIndex)=>{row.forEach((cellData,colIndex)=>{cellData&&style&&(cellData.s=style.getStyleByCell(this._beforeApplyData[rowIndex][colIndex])||null)})}),applyType===APPLY_TYPE.ONLY_FORMAT&&applyDatas.forEach((row,rowIndex)=>{row.forEach((cellData,colIndex)=>{if(cellData){const old=this._beforeApplyData[rowIndex][colIndex]||{};cellData.f=old.f,cellData.si=old.si,cellData.t=old.t,cellData.v=old.v}})}),hasStyle){const deleteMergeRanges=[],mergeData=(_b=(_a58=this._univerInstanceService.getUniverSheetInstance(unitId))==null?void 0:_a58.getSheetBySheetId(subUnitId))==null?void 0:_b.getMergeData();mergeData&&mergeData.forEach(merge=>{core.Rectangle.intersects(merge,targetRange)&&deleteMergeRanges.push(merge)});const removeMergeMutationParams={unitId,subUnitId,ranges:deleteMergeRanges},undoRemoveMergeMutationParams=this._injector.invoke(sheets.RemoveMergeUndoMutationFactory,removeMergeMutationParams);deleteMergeRanges.length&&(redos.push({id:sheets.RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}),undos.unshift({id:sheets.AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}))}const clearMutationParams={subUnitId,unitId,cellValue:generateNullCellValueRowCol([target])},undoClearMutationParams=this._injector.invoke(sheets.SetRangeValuesUndoMutationFactory,clearMutationParams);redos.push({id:sheets.SetRangeValuesMutation.id,params:clearMutationParams}),undos.unshift({id:sheets.SetRangeValuesMutation.id,params:undoClearMutationParams});const cellValue=new core.ObjectMatrix;targetRows.forEach((row,rowIndex)=>{targetCols.forEach((col,colIndex)=>{applyDatas[rowIndex][colIndex]&&cellValue.setValue(row,col,applyDatas[rowIndex][colIndex])})});const setRangeValuesMutationParams={subUnitId,unitId,cellValue:cellValue.getMatrix()},undoSetRangeValuesMutationParams=this._injector.invoke(sheets.SetRangeValuesUndoMutationFactory,setRangeValuesMutationParams);if(undos.unshift({id:sheets.SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams}),redos.push({id:sheets.SetRangeValuesMutation.id,params:setRangeValuesMutationParams}),applyMergeRanges!=null&&applyMergeRanges.length){const ranges=sheets.getAddMergeMutationRangeByType(applyMergeRanges),addMergeMutationParams={unitId,subUnitId,ranges},undoAddMergeMutationParams=this._injector.invoke(sheets.AddMergeUndoMutationFactory,addMergeMutationParams);undos.unshift({id:sheets.RemoveWorksheetMergeMutation.id,params:undoAddMergeMutationParams}),redos.push({id:sheets.AddWorksheetMergeMutation.id,params:addMergeMutationParams})}return{undos,redos}}_shouldDisableSeries(copyData){return copyData.every(copyDataPiece=>Object.keys(copyDataPiece).every(type=>{var _a58;return((_a58=copyDataPiece[type])==null?void 0:_a58.length)===0||[DATA_TYPE.OTHER,DATA_TYPE.FORMULA].includes(type)}))}_getPreferredApplyType(copyData){return copyData.every(copyDataPiece=>Object.keys(copyDataPiece).every(type=>{var _a58,_b;return((_a58=copyDataPiece[type])==null?void 0:_a58.length)===0||((_b=copyDataPiece[type])==null?void 0:_b.length)===1&&copyDataPiece[type][0].data.length===1&&DATA_TYPE.NUMBER===type}))?APPLY_TYPE.COPY:APPLY_TYPE.SERIES}},__name(_a10,"AutoFillController"),_a10);exports.AutoFillController=__decorateClass$J([__decorateParam$J(0,core.IUniverInstanceService),__decorateParam$J(1,core.ICommandService),__decorateParam$J(2,IAutoFillService),__decorateParam$J(3,IEditorBridgeService),__decorateParam$J(4,engineRender.IRenderManagerService),__decorateParam$J(5,core.Inject(core.Injector)),__decorateParam$J(6,core.Inject(exports.SheetsRenderService))],exports.AutoFillController);var __defProp$I=Object.defineProperty,__getOwnPropDesc$I=Object.getOwnPropertyDescriptor,__decorateClass$I=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$I(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$I(target,key,result),result},"__decorateClass$I"),__decorateParam$I=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$I"),_a11;exports.CellCustomRenderController=(_a11=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_renderManagerService,_permissionService){super();__publicField(this,"_enterActiveRender");this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._renderManagerService=_renderManagerService,this._permissionService=_permissionService,this._initEventBinding()}_initEventBinding(){const disposableCollection=new core.DisposableCollection,workbook=this._context.unit,handleSkeletonChange=__name(skeletonParam=>{if(disposableCollection.dispose(),!skeletonParam)return;const unitId=this._context.unitId,{skeleton}=skeletonParam,currentRender=this._renderManagerService.getRenderById(unitId);if(currentRender&&currentRender.mainComponent){const spreadsheet=currentRender.mainComponent,getActiveRender=__name(evt=>{const{offsetX,offsetY}=evt,scene=currentRender.scene,worksheet=workbook.getActiveSheet();if(!worksheet)return;const activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([offsetX,offsetY]));if(!activeViewport)return;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY={x:activeViewport.viewportScrollX,y:activeViewport.viewportScrollY},cellPos=skeleton.getCellPositionByOffset(offsetX,offsetY,scaleX,scaleY,scrollXY),mergeCell=skeleton.worksheet.getMergedCell(cellPos.row,cellPos.column),cellIndex={actualRow:mergeCell?mergeCell.startRow:cellPos.row,actualCol:mergeCell?mergeCell.startColumn:cellPos.column,mergeCell,row:cellPos.row,col:cellPos.column};if(!cellIndex||!skeleton)return;const cellData=worksheet.getCell(cellIndex.actualRow,cellIndex.actualCol);if(!cellData)return;const renders=cellData.customRender;if(!(renders!=null&&renders.length))return;const row=cellIndex.actualRow,col=cellIndex.actualCol,sortedRenders=renders.sort(core.sortRules),subUnitId=worksheet.getSheetId(),info={data:cellData,style:skeleton.getsStyles().getStyleByCell(cellData),primaryWithCoord:skeleton.getCellByIndex(cellIndex.actualRow,cellIndex.actualCol),unitId,subUnitId,row,col,workbook,worksheet},position={x:scrollXY.x+offsetX/scaleX,y:scrollXY.y+offsetY/scaleY},activeRender=sortedRenders.find(render2=>{var _a58;return(_a58=render2.isHit)==null?void 0:_a58.call(render2,position,info)});if(activeRender)return[activeRender,info]},"getActiveRender"),disposable=spreadsheet.onPointerDown$.subscribeEvent(evt=>{var _a58,_b,_c,_d;const activeRenderInfo=getActiveRender(evt);if(activeRenderInfo){const[activeRender,cellContext]=activeRenderInfo,{row,col,worksheet,unitId:unitId2,subUnitId}=cellContext;if(!((_a58=this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId2).id,new sheets.WorksheetEditPermission(unitId2,subUnitId).id]))==null?void 0:_a58.every(permission2=>permission2.value)))return!1;const permission=(_c=(_b=worksheet.getCell(row,col))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[sheets.UnitAction.Edit])===!1)return!1;(_d=activeRender.onPointerDown)==null||_d.call(activeRender,cellContext,evt)}}),moveDisposable=spreadsheet.onPointerMove$.subscribeEvent(evt=>{var _a58,_b,_c,_d;const activeRenderInfo=getActiveRender(evt);if(activeRenderInfo){const[activeRender,cellContext]=activeRenderInfo;this._enterActiveRender?this._enterActiveRender.render!==activeRender&&((_b=(_a58=this._enterActiveRender.render).onPointerLeave)==null||_b.call(_a58,this._enterActiveRender.cellContext,evt),this._enterActiveRender={render:activeRender,cellContext},(_c=activeRender.onPointerEnter)==null||_c.call(activeRender,cellContext,evt)):(this._enterActiveRender={render:activeRender,cellContext},(_d=activeRender.onPointerEnter)==null||_d.call(activeRender,cellContext,evt))}});disposable&&disposableCollection.add(disposable),moveDisposable&&disposableCollection.add(moveDisposable)}},"handleSkeletonChange");this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(handleSkeletonChange)),handleSkeletonChange(this._sheetSkeletonManagerService.getCurrent()),this.disposeWithMe(disposableCollection)}},__name(_a11,"CellCustomRenderController"),_a11);exports.CellCustomRenderController=__decorateClass$I([__decorateParam$I(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$I(2,engineRender.IRenderManagerService),__decorateParam$I(3,core.IPermissionService)],exports.CellCustomRenderController);function getUserListEqual(userList1,userList2){if(userList1.length!==userList2.length)return!1;const sorted1=userList1.sort((a,b)=>a.id.localeCompare(b.id)),sorted2=userList2.sort((a,b)=>a.id.localeCompare(b.id));return sorted1.every((user,index)=>{var _a58,_b;return((_a58=user.subject)==null?void 0:_a58.userID)===((_b=sorted2[index].subject)==null?void 0:_b.userID)&&user.role===sorted2[index].role})}__name(getUserListEqual,"getUserListEqual");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=sheets.SetRangeValuesUndoMutationFactory(accessor,redoMutationParams);undos.push({id:sheets.SetRangeValuesMutation.id,params:undoMutationParams}),redos.push({id:sheets.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;let leftTopCellValue=null;return cellMatrix.forValue((row,col,cellData)=>{cellData&&row>=startRow&&col>=startColumn&&(!leftTopCellValue&&worksheet.cellHasValue(cellData)&&(leftTopCellValue=cellData),redoMatrix.setValue(row,col,null))}),redoMatrix.setValue(startRow,startColumn,leftTopCellValue),redoMatrix}__name(getClearContentMutationParamForRange,"getClearContentMutationParamForRange");function getCellIndexByOffsetWithMerge(offsetX,offsetY,scene,skeleton){const activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([offsetX,offsetY]));if(!activeViewport)return;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY={x:activeViewport.viewportScrollX,y:activeViewport.viewportScrollY},cellPos=skeleton.getCellPositionByOffset(offsetX,offsetY,scaleX,scaleY,scrollXY),mergeCell=skeleton.worksheet.getMergedCell(cellPos.row,cellPos.column);return{actualRow:mergeCell?mergeCell.startRow:cellPos.row,actualCol:mergeCell?mergeCell.startColumn:cellPos.column,mergeCell,row:cellPos.row,col:cellPos.column}}__name(getCellIndexByOffsetWithMerge,"getCellIndexByOffsetWithMerge");function getViewportByCell(row,column,scene,worksheet){const freeze=worksheet.getFreeze();if(!freeze||freeze.startRow<=0&&freeze.startColumn<=0||row>freeze.startRow&&column>freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(row<=freeze.startRow&&column<=freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP);if(row<=freeze.startRow&&column>freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP);if(row>freeze.startRow&&column<=freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT)}__name(getViewportByCell,"getViewportByCell");function transformBound2OffsetBound(originBound,scene,skeleton,worksheet){const topLeft=transformPosition2Offset(originBound.left,originBound.top,scene,skeleton,worksheet),bottomRight=transformPosition2Offset(originBound.right,originBound.bottom,scene,skeleton,worksheet);return{left:topLeft.x,top:topLeft.y,right:bottomRight.x,bottom:bottomRight.y}}__name(transformBound2OffsetBound,"transformBound2OffsetBound");function transformPosition2Offset(x,y,scene,skeleton,worksheet){const{scaleX,scaleY}=scene.getAncestorScale(),viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!viewMain)return{x,y};const freeze=worksheet.getFreeze(),{startColumn,startRow,xSplit,ySplit}=freeze,startSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(startRow-ySplit,startColumn-xSplit),endSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(startRow,startColumn),{rowHeaderWidth,columnHeaderHeight}=skeleton,freezeWidth=endSheetView.startX-startSheetView.startX,freezeHeight=endSheetView.startY-startSheetView.startY,{top,left,viewportScrollX,viewportScrollY}=viewMain;let offsetX;x>left?offsetX=(x-viewportScrollX)*scaleX:offsetX=(freezeWidth+rowHeaderWidth-(left-x))*scaleX;let offsetY;return y>top?offsetY=(y-viewportScrollY)*scaleY:offsetY=(freezeHeight+columnHeaderHeight-(top-y))*scaleX,{x:offsetX,y:offsetY}}__name(transformPosition2Offset,"transformPosition2Offset");function getCellRealRange(workbook,worksheet,skeleton,row,col){let actualRow=row,actualCol=col;skeleton.overflowCache.forValue((r2,c,range)=>{range.startRow<=actualRow&&range.endRow>=actualRow&&range.startColumn<=actualCol&&range.endColumn>=actualCol&&(actualCol=c,actualRow=r2)});const actualCell=skeleton.getCellByIndex(actualRow,actualCol);return{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),workbook,worksheet,row:actualCell.actualRow,col:actualCell.actualColumn}}__name(getCellRealRange,"getCellRealRange");function getHoverCellPosition(currentRender,workbook,worksheet,skeletonParam,offsetX,offsetY){const{scene}=currentRender,unitId=workbook.getUnitId(),{skeleton,sheetId}=skeletonParam,cellIndex=getCellIndexByOffsetWithMerge(offsetX,offsetY,scene,skeleton);if(!cellIndex)return null;let{actualCol,actualRow}=cellIndex;skeleton.overflowCache.forValue((r2,c,range)=>{range.startRow<=actualRow&&range.endRow>=actualRow&&range.startColumn<=actualCol&&range.endColumn>=actualCol&&(actualCol=c,actualRow=r2)});const actualCell=skeleton.getCellByIndex(actualRow,actualCol),originCell=skeleton.getCellByIndex(cellIndex.row,cellIndex.col),originLocation={unitId,subUnitId:sheetId,workbook,worksheet,row:originCell.actualRow,col:originCell.actualColumn},location=getCellRealRange(workbook,worksheet,skeleton,actualRow,actualCol);let anchorCell;actualCell.mergeInfo?anchorCell=actualCell.mergeInfo:anchorCell={startRow:location.row,endRow:location.row,startColumn:location.col,endColumn:location.col};const activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([offsetX,offsetY]));if(!activeViewport)return;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY={x:activeViewport.viewportScrollX,y:activeViewport.viewportScrollY};return{position:{startX:(skeleton.getOffsetByPositionX(anchorCell.startColumn-1)-scrollXY.x)*scaleX,endX:(skeleton.getOffsetByPositionX(anchorCell.endColumn)-scrollXY.x)*scaleX,startY:(skeleton.getOffsetByPositionY(anchorCell.startRow-1)-scrollXY.y)*scaleY,endY:(skeleton.getOffsetByPositionY(anchorCell.endRow)-scrollXY.y)*scaleY},location:originLocation,overflowLocation:location}}__name(getHoverCellPosition,"getHoverCellPosition");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),confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService),unitId=params.unitId,subUnitId=params.subUnitId,selections=params.selections,ranges=sheets.getAddMergeMutationRangeByType(selections,params.value),worksheet=univerInstanceService.getUniverSheetInstance(unitId).getSheetBySheetId(subUnitId),redoMutations=[],undoMutations=[],willClearSomeCell=checkCellContentInRanges(worksheet,ranges);if(willClearSomeCell&&!await confirmService.confirm({id:"merge.confirm.add-worksheet-merge",title:{title:"merge.confirm.title"},cancelText:localeService.t("merge.confirm.cancel"),confirmText:localeService.t("merge.confirm.confirm")}))return!1;const removeMergeMutationParams={unitId,subUnitId,ranges:core.Tools.deepClone(ranges)},addMergeMutationParams={unitId,subUnitId,ranges:core.Tools.deepClone(ranges)},undoRemoveMergeMutationParams=sheets.RemoveMergeUndoMutationFactory(accessor,removeMergeMutationParams),undoMutationParams=sheets.AddMergeUndoMutationFactory(accessor,addMergeMutationParams);if(undoRemoveMergeMutationParams.ranges.length>0&&redoMutations.push({id:sheets.RemoveWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),redoMutations.push({id:sheets.AddWorksheetMergeMutation.id,params:addMergeMutationParams}),undoMutations.push({id:sheets.RemoveWorksheetMergeMutation.id,params:undoMutationParams}),undoRemoveMergeMutationParams.ranges.length>0&&undoMutations.push({id:sheets.AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),willClearSomeCell){const data=getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges);redoMutations.unshift(...data.redos),undoMutations.push(...data.undos)}const addMergeRedoSelectionsMutation=sheets.AddMergeRedoSelectionsOperationFactory(accessor,params,ranges);addMergeRedoSelectionsMutation&&redoMutations.push(addMergeRedoSelectionsMutation);const addMergeUndoSelectionsMutation=sheets.AddMergeUndoSelectionsOperationFactory(accessor,params);return addMergeUndoSelectionsMutation&&undoMutations.push(addMergeUndoSelectionsMutation),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 _a58;const commandService=accessor.get(core.ICommandService),selections=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range),mergeableSelections=getMergeableSelectionsByType(MergeType.MergeAll,selections);if(!(mergeableSelections!=null&&mergeableSelections.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:mergeableSelections,unitId,subUnitId})},"handler")},AddWorksheetMergeVerticalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-vertical",handler:__name(async accessor=>{var _a58;const commandService=accessor.get(core.ICommandService),selections=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range),mergeableSelections=getMergeableSelectionsByType(MergeType.MergeVertical,selections);if(!(mergeableSelections!=null&&mergeableSelections.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:mergeableSelections,unitId,subUnitId})},"handler")},AddWorksheetMergeHorizontalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-horizontal",handler:__name(async accessor=>{var _a58;const commandService=accessor.get(core.ICommandService),selections=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range),mergeableSelections=getMergeableSelectionsByType(MergeType.MergeHorizontal,selections);if(!(mergeableSelections!=null&&mergeableSelections.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:mergeableSelections,unitId,subUnitId})},"handler")},DeleteRangeMoveLeftConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-move-left-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endColumn:worksheet.getColumnCount()-1};const getRowLength=__name(range2=>range2.endRow-range2.startRow,"getRowLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getRowLength(mergeRange)>getRowLength(interSectedRange):!1})||await confirmService.confirm({id:DeleteRangeMoveLeftConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.DeleteRangeMoveLeftCommand.id):!0},"handler")},DeleteRangeMoveUpConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-move-up-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endRow:worksheet.getRowCount()-1};for(let i=range.startRow;i<=range.endRow;i++)if(worksheet.getRowFiltered(i)&&await confirmService.confirm({id:DeleteRangeMoveUpConfirmCommand.id,title:{title:localeService.t("filter.confirm.error")},children:{title:localeService.t("filter.confirm.notAllowedToInsertRange")},confirmText:localeService.t("button.confirm")}))return!1;const getColLength=__name(range2=>range2.endColumn-range2.startColumn,"getColLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getColLength(mergeRange)>getColLength(interSectedRange):!1})||await confirmService.confirm({id:DeleteRangeMoveUpConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.DeleteRangeMoveUpCommand.id):!0},"handler")},HideRowConfirmCommand={id:"sheet.command.hide-row-confirm",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a58;const ranges=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allRowRanges=worksheet.getVisibleRows();if(isAllRowsCovered(allRowRanges,ranges)){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.hide-row",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.hideAllRowsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.SetRowHiddenCommand.id),!0},"handler")},HideColConfirmCommand={id:"sheet.command.hide-col-confirm",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a58;const ranges=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allColumnRanges=worksheet.getVisibleCols();if(isAllColumnsCovered(allColumnRanges,ranges)){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.hide-col",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.hideAllColumnsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.SetColHiddenCommand.id),!0},"handler")},SetRangeBoldCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-bold",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatBoldCommand.id):commandService.executeCommand(sheets.SetBoldCommand.id)},"handler")},SetRangeItalicCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-italic",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatItalicCommand.id):commandService.executeCommand(sheets.SetItalicCommand.id)},"handler")},SetRangeUnderlineCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-underline",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatUnderlineCommand.id):commandService.executeCommand(sheets.SetUnderlineCommand.id)},"handler")},SetRangeStrickThroughCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-stroke",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatStrikethroughCommand.id):commandService.executeCommand(sheets.SetStrikeThroughCommand.id)},"handler")},SetRangeSubscriptCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-subscript",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatSubscriptCommand.id):!1},"handler")},SetRangeSuperscriptCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-superscript",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatSuperscriptCommand.id):!1},"handler")},SetRangeFontSizeCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-fontsize",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatFontSizeCommand.id,params):commandService.executeCommand(sheets.SetFontSizeCommand.id,params)},"handler")},SetRangeFontFamilyCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-font-family",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatFontFamilyCommand.id,params):commandService.executeCommand(sheets.SetFontFamilyCommand.id,params)},"handler")},SetRangeTextColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-text-color",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatTextColorCommand.id,params):commandService.executeCommand(sheets.SetTextColorCommand.id,params)},"handler")},InsertRangeMoveDownConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-range-move-down-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endRow:worksheet.getRowCount()-1};for(let i=range.startRow;i<=range.endRow;i++)if(worksheet.getRowFiltered(i)&&await confirmService.confirm({id:InsertRangeMoveDownConfirmCommand.id,title:{title:localeService.t("filter.confirm.error")},children:{title:localeService.t("filter.confirm.notAllowedToInsertRange")},confirmText:localeService.t("button.confirm")}))return!1;const getColLength=__name(range2=>range2.endColumn-range2.startColumn,"getColLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getColLength(mergeRange)>getColLength(interSectedRange):!1})||await confirmService.confirm({id:InsertRangeMoveDownConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.InsertRangeMoveDownCommand.id):!0},"handler")},InsertRangeMoveRightConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-range-move-right-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endColumn:worksheet.getColumnCount()-1};const getRowLength=__name(range2=>range2.endRow-range2.startRow,"getRowLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getRowLength(mergeRange)>getRowLength(interSectedRange):!1})||await confirmService.confirm({id:InsertRangeMoveRightConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.InsertRangeMoveRightCommand.id):!0},"handler")};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||{}),G=(E=>(E[E.Reader=0]="Reader",E[E.Editor=1]="Editor",E[E.Owner=2]="Owner",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(G||{}),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||{}),H=(E=>(E[E.SomeCollaborator=0]="SomeCollaborator",E[E.AllCollaborator=1]="AllCollaborator",E[E.OneSelf=2]="OneSelf",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(H||{});const DEFAULT_RANGE_RULE={name:"",unitId:"",subUnitId:"",permissionId:"",unitType:M.Unkonwn,id:"",ranges:[]};var viewState=(viewState2=>(viewState2.othersCanView="othersCanView",viewState2.noOneElseCanView="noOneElseCanView",viewState2))(viewState||{}),editState=(editState2=>(editState2.designedUserCanEdit="designedUserCanEdit",editState2.onlyMe="onlyMe",editState2))(editState||{});const _SheetPermissionPanelModel=class _SheetPermissionPanelModel{constructor(){__publicField(this,"_rule",DEFAULT_RANGE_RULE);__publicField(this,"_rule$",new rxjs.BehaviorSubject(this._rule));__publicField(this,"_oldRule");__publicField(this,"_rangeErrorMsg$",new rxjs.BehaviorSubject(""));__publicField(this,"_visible",!1);__publicField(this,"rangeErrorMsg$",this._rangeErrorMsg$.asObservable());__publicField(this,"rule$",this._rule$.asObservable())}setVisible(v){this._visible=v}getVisible(){return this._visible}setRangeErrorMsg(msg){this._rangeErrorMsg$.next(msg)}get rule(){return this._rule}setRule(ruleObj){this._rule={...this._rule,...ruleObj},this._rule$.next(this._rule)}resetRule(){this._rule=DEFAULT_RANGE_RULE,this._rule$.next(this._rule)}reset(){this.setVisible(!1),this.resetRule(),this.setRangeErrorMsg(""),this.setOldRule(null)}get oldRule(){return this._oldRule}setOldRule(ruleObj){this._oldRule=ruleObj}};__name(_SheetPermissionPanelModel,"SheetPermissionPanelModel");let SheetPermissionPanelModel=_SheetPermissionPanelModel;const _SheetPermissionUserManagerService=class _SheetPermissionUserManagerService{constructor(){__publicField(this,"_userList",[]);__publicField(this,"_oldCollaboratorList",[]);__publicField(this,"_selectUserList",[]);__publicField(this,"_allUserList",[]);__publicField(this,"_selectUserList$",new rxjs.BehaviorSubject(this._selectUserList));__publicField(this,"selectUserList$",this._selectUserList$.asObservable())}get userList(){return this._userList}get allUserList(){return this._allUserList}setAllUserList(userList){this._allUserList=userList}setUserList(userList){this._userList=userList}reset(){this._userList=[],this._oldCollaboratorList=[],this._selectUserList=[],this._selectUserList$.next([]),this._allUserList=[]}get oldCollaboratorList(){return this._oldCollaboratorList}setOldCollaboratorList(userList){this._oldCollaboratorList=userList}get selectUserList(){return this._selectUserList}setSelectUserList(userList){this._selectUserList=userList,this._selectUserList$.next(userList)}};__name(_SheetPermissionUserManagerService,"SheetPermissionUserManagerService");let SheetPermissionUserManagerService=_SheetPermissionUserManagerService;const UNIVER_SHEET_PERMISSION_PANEL="UNIVER_SHEET_PERMISSION_PANEL",UNIVER_SHEET_PERMISSION_PANEL_FOOTER="UNIVER_SHEET_PERMISSION_PANEL_FOOTER",UNIVER_SHEET_PERMISSION_USER_DIALOG="UNIVER_SHEET_PERMISSION_USER_DIALOG",UNIVER_SHEET_PERMISSION_DIALOG="UNIVER_SHEET_PERMISSION_DIALOG",UNIVER_SHEET_PERMISSION_USER_DIALOG_ID="UNIVER_SHEET_PERMISSION_USER_DIALOG_ID",UNIVER_SHEET_PERMISSION_DIALOG_ID="UNIVER_SHEET_PERMISSION_DIALOG_ID",subUnitPermissionTypeMap={[P.Copy]:"Copy",[P.SetCellStyle]:"SetCellStyle",[P.SetCellValue]:"SetCellValue",[P.SetRowStyle]:"SetRowStyle",[P.SetColumnStyle]:"SetColumnStyle",[P.InsertRow]:"InsertRow",[P.InsertColumn]:"InsertColumn",[P.InsertHyperlink]:"InsertHyperlink",[P.DeleteRow]:"DeleteRow",[P.DeleteColumn]:"DeleteColumn",[P.Sort]:"Sort",[P.Filter]:"Filter",[P.PivotTable]:"PivotTable",[P.EditExtraObject]:"EditExtraObject"},defaultWorksheetUnitActionList=[P.Copy,P.SetCellStyle,P.SetCellValue,P.SetRowStyle,P.SetColumnStyle,P.InsertRow,P.InsertColumn,P.InsertHyperlink,P.DeleteRow,P.DeleteColumn,P.Sort,P.Filter,P.PivotTable,P.EditExtraObject,P.View],permissionMenuIconKey="sheet-permission-menu-icon",permissionDeleteIconKey="sheet-permission-delete-icon",permissionEditIconKey="sheet-permission-edit-icon",permissionCheckIconKey="sheet-permission-check-icon",permissionLockIconKey="sheet-permission-lock-icon",SheetPermissionOpenPanelOperation={type:core.CommandType.OPERATION,id:"sheet-permission.operation.openPanel",async handler(accessor,_params={}){const sidebarService=accessor.get(ui.ISidebarService),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),sheetPermissionUserManagerService=accessor.get(SheetPermissionUserManagerService),{showDetail=!0,fromSheetBar=!1}=_params,sidebarProps={header:{title:"permission.panel.title"},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail,fromSheetBar},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail},onClose:__name(()=>{sheetPermissionPanelModel.reset(),sheetPermissionUserManagerService.reset()},"onClose")};return sheetPermissionPanelModel.setVisible(!0),sidebarService.open(sidebarProps),!0}},AddWorksheetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),{rule,unitId}=params,subUnitId=rule.subUnitId;if(await commandService.executeCommand(sheets.AddWorksheetProtectionMutation.id,{unitId,rule,subUnitId:rule.subUnitId})){const redoMutations=[{id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule,subUnitId:rule.subUnitId}}],undoMutations=[{id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteWorksheetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-worksheet-protection",handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),{rule,unitId,subUnitId}=params;commandService.executeCommand(sheets.DeleteWorksheetProtectionMutation.id,{unitId,subUnitId});const redoMutations=[{id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}}],undoMutations=[{id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule,subUnitId}}];return undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations}),!0}},SetWorksheetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),undoRedoService=accessor.get(core.IUndoRedoService),{rule,permissionId}=params,{unitId,subUnitId}=rule,newRule={...rule,permissionId},oldRule=sheetPermissionPanelModel.oldRule;if(await commandService.executeCommand(sheets.SetWorksheetProtectionMutation.id,{unitId,subUnitId,newRule})){const redoMutations=[{id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,newRule}}],undoMutations=[{id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,rule:oldRule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteWorksheetProtectionFormSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-worksheet-protection-from-sheet-bar",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(I.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet(),unitId=workbook.getUnitId();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),rule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);if(await commandService.executeCommand(DeleteWorksheetProtectionCommand.id,{unitId,subUnitId})){const redoMutations=[{id:DeleteWorksheetProtectionCommand.id,params:{unitId,subUnitId}}],undoMutations=[{id:AddWorksheetProtectionCommand.id,params:{unitId,rule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},ChangeSheetProtectionFromSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.change-sheet-protection-from-sheet-bar",async handler(accessor){return await accessor.get(core.ICommandService).executeCommand("sheet-permission.operation.openDialog"),!0}},AddRangeProtectionFromToolbarCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection-from-toolbar",async handler(accessor){const commandService=accessor.get(core.ICommandService);return accessor.get(SheetPermissionPanelModel).resetRule(),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}},AddRangeProtectionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection-from-context-menu",async handler(accessor){const commandService=accessor.get(core.ICommandService);return accessor.get(SheetPermissionPanelModel).resetRule(),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}},ViewSheetPermissionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.view-sheet-permission-from-context-menu",async handler(accessor){return await accessor.get(core.ICommandService).executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!1}),!0}},AddRangeProtectionFromSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection-from-sheet-bar",async handler(accessor){const commandService=accessor.get(core.ICommandService);return accessor.get(SheetPermissionPanelModel).resetRule(),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{fromSheetBar:!0,showDetail:!0}),!0}},ViewSheetPermissionFromSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.view-sheet-permission-from-sheet-bar",async handler(accessor){return await accessor.get(core.ICommandService).executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!1}),!0}},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(sheets.RangeProtectionRuleModel),{rule,permissionId}=params,{unitId,subUnitId,ranges,name,description}=rule,rules=[{ranges,permissionId,id:selectionProtectionModel.createRuleId(unitId,subUnitId),name,description}];if(await commandService.executeCommand(sheets.AddRangeProtectionMutation.id,{unitId,subUnitId,rules})){const redoMutations=[{id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules}}],undoMutations=[{id:sheets.DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:rules.map(rule2=>rule2.id)}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteRangeSelectionCommand={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(sheets.DeleteRangeProtectionMutation.id,redoMutationParam)&&undoRedoService.pushUndoRedo({unitID:unitId,redoMutations:[{id:sheets.DeleteRangeProtectionMutation.id,params:redoMutationParam}],undoMutations:[{id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}]}),!0}},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(sheets.RangeProtectionRuleModel),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),undoRedoService=accessor.get(core.IUndoRedoService),{rule,permissionId}=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(sheets.SetRangeProtectionMutation.id,redoMutationParam)){const redoMutations=[{id:sheets.SetRangeProtectionMutation.id,params:redoMutationParam}],undoMutations=[{id:sheets.SetRangeProtectionMutation.id,params:{unitId,subUnitId,ruleId:rule.id,rule:sheetPermissionPanelModel.oldRule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}}return!0}},DeleteRangeProtectionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-protection-from-context-menu",async handler(accessor){var _a58;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),undoRedoService=accessor.get(core.IUndoRedoService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId);if(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name))return commandService.executeCommand(DeleteWorksheetProtectionCommand.id,{unitId,subUnitId,rule:worksheetRule});{const selectRange=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!selectRange)return!1;const rule=accessor.get(sheets.RangeProtectionRuleModel).getSubunitRuleList(unitId,subUnitId).find(item=>item.ranges.some(range=>core.Rectangle.intersects(range,selectRange)));if(rule){const redoMutationParam={unitId,subUnitId,ruleIds:[rule.id]};return await commandService.executeCommand(sheets.DeleteRangeProtectionMutation.id,redoMutationParam)&&undoRedoService.pushUndoRedo({unitID:unitId,redoMutations:[{id:sheets.DeleteRangeProtectionMutation.id,params:redoMutationParam}],undoMutations:[{id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}]}),!0}else return!1}}},SetRangeProtectionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-protection-from-context-menu",async handler(accessor){var _a58;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel);if(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)){const oldRule={...worksheetRule,unitId,subUnitId,ranges:[]};return sheetPermissionPanelModel.setRule(oldRule),sheetPermissionPanelModel.setOldRule(oldRule),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}else{const selectRange=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!selectRange)return!1;const rule=accessor.get(sheets.RangeProtectionRuleModel).getSubunitRuleList(unitId,subUnitId).find(item=>{var _a59;return(_a59=item==null?void 0:item.ranges)==null?void 0:_a59.some(range=>core.Rectangle.intersects(range,selectRange))});if(rule){const oldRule={...rule,unitId,subUnitId};return sheetPermissionPanelModel.setRule(oldRule),sheetPermissionPanelModel.setOldRule(oldRule),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}else return!1}}},SetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),{rule}=params,{unitId,subUnitId}=rule,redoMutations=[],undoMutations=[],oldRule=sheetPermissionPanelModel.oldRule;return(oldRule==null?void 0:oldRule.unitType)===rule.unitType?rule.unitType===M.Worksheet?(redoMutations.push({id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,rule}}),undoMutations.push({id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,rule:oldRule}})):(redoMutations.push({id:sheets.SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}),undoMutations.push({id:sheets.SetRangeProtectionMutation.id,params:{unitId,subUnitId,ruleId:oldRule.id,rule:oldRule}})):(oldRule&&(oldRule.unitType===M.Worksheet?(redoMutations.push({id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}}),undoMutations.push({id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule:oldRule,subUnitId:oldRule.subUnitId}})):oldRule.unitType===M.SelectRange&&(redoMutations.push({id:sheets.DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:[oldRule.id]}}),undoMutations.push({id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[oldRule]}}))),rule.unitType===M.Worksheet?(redoMutations.push({id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule,subUnitId:rule.subUnitId}}),undoMutations.unshift({id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}})):rule.unitType===M.SelectRange&&(rule.id=rangeProtectionRuleModel.createRuleId(unitId,subUnitId),redoMutations.push({id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}),undoMutations.unshift({id:sheets.DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:[rule.id]}}))),core.sequenceExecute(redoMutations,commandService)&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations,redoMutations}),!0}},RefillCommand={id:"sheet.command.refill",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const autoFillService=accessor.get(IAutoFillService);return autoFillService.applyType=params.type,!0},"handler")},RemoveRowConfirmCommand={id:"sheet.command.remove-row-confirm",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a58;const selectionManagerService=accessor.get(sheets.SheetsSelectionsService);let range=params==null?void 0:params.range;if(range||(range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range),!range)return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allRowRanges=worksheet.getVisibleRows();if(isAllRowsCovered(allRowRanges,[range])){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.remove-row",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.deleteAllRowsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.RemoveRowCommand.id,{range}),!0},"handler")},RemoveColConfirmCommand={id:"sheet.command.remove-col-confirm",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a58;const selectionManagerService=accessor.get(sheets.SheetsSelectionsService);let range=params==null?void 0:params.range;if(range||(range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range),!range)return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allColumnRanges=worksheet.getVisibleCols();if(isAllColumnsCovered(allColumnRanges,[range])){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.remove-col",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.deleteAllColumnsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.RemoveColCommand.id,{range}),!0},"handler")},RemoveSheetConfirmCommand={id:"sheet.command.remove-sheet-confirm",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const{subUnitId}=params,confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.remove-sheet",title:{title:localeService.t("sheetConfig.deleteSheet")},children:{title:localeService.t("sheetConfig.deleteSheetContent")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?(await commandService.executeCommand(sheets.RemoveSheetCommand.id,{subUnitId}),!0):!1},"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$H=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$H");const DEFAULT_Z_INDEX=SELECTION_SHAPE_DEPTH.MARK_SELECTION,IMarkSelectionService=core.createIdentifier("univer.mark-selection-service");var _a12;exports.MarkSelectionService=(_a12=class extends core.Disposable{constructor(_currentService,_renderManagerService,_themeService){super();__publicField(this,"_shapeMap",new Map);this._currentService=_currentService,this._renderManagerService=_renderManagerService,this._themeService=_themeService}addShape(selection,exits=[],zIndex=DEFAULT_Z_INDEX){var _a58;const workbook=this._currentService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),subUnitId=(_a58=workbook.getActiveSheet())==null?void 0:_a58.getSheetId();if(!subUnitId)return null;const id=core.Tools.generateRandomId();return this._shapeMap.set(id,{selection,subUnitId,unitId:workbook.getUnitId(),zIndex,control:null,exits}),this.refreshShapes(),id}refreshShapes(){var _a58;const currentSheet=this._currentService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!currentSheet)return;const currentUnitId=currentSheet.getUnitId(),currentSubUnitId=(_a58=currentSheet.getActiveSheet())==null?void 0:_a58.getSheetId();this._shapeMap.forEach(shape=>{var _a59;const{unitId,subUnitId,selection,control:oldControl,zIndex}=shape;if(oldControl==null||oldControl.dispose(),unitId!==currentUnitId||subUnitId!==currentSubUnitId)return;const renderUnit=this._renderManagerService.getRenderById(unitId);if(!renderUnit)return;const skeleton=(_a59=this._renderManagerService.withCurrentTypeOfUnit(core.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService))==null?void 0:_a59.getCurrentSkeleton();if(!skeleton)return;const{scene}=renderUnit,{rowHeaderWidth,columnHeaderHeight}=skeleton,control=new SelectionControl(scene,zIndex,this._themeService,!1,{rowHeaderWidth,columnHeaderHeight}),{rangeWithCoord,primaryWithCoord}=renderUnit.with(ISheetSelectionRenderService).attachSelectionWithCoord(selection);control.updateRange(rangeWithCoord,primaryWithCoord);const{style}=selection;style&&control.updateStyle(style),shape.control=control})}getShapeMap(){return this._shapeMap}removeShape(id){const shapeInfo=this._shapeMap.get(id);if(!shapeInfo)return;const{control}=shapeInfo;control==null||control.dispose(),this._shapeMap.delete(id)}removeAllShapes(){for(const shape of this._shapeMap.values()){const{control}=shape;control==null||control.dispose()}this._shapeMap.clear()}},__name(_a12,"MarkSelectionService"),_a12);exports.MarkSelectionService=__decorateClass$H([__decorateParam$H(0,core.IUniverInstanceService),__decorateParam$H(1,engineRender.IRenderManagerService),__decorateParam$H(2,core.Inject(core.ThemeService))],exports.MarkSelectionService);function createCopyPasteSelectionStyle(themeService){return{strokeWidth:1.5,stroke:themeService.getCurrentTheme().primaryColor,fill:"rgba(178, 178, 178, 0.10)",widgets:{},hasAutoFill:!1,strokeDash:8}}__name(createCopyPasteSelectionStyle,"createCopyPasteSelectionStyle");var __defProp$G=Object.defineProperty,__getOwnPropDesc$G=Object.getOwnPropertyDescriptor,__decorateClass$G=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$G(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$G(target,key,result),result},"__decorateClass$G"),__decorateParam$G=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$G"),FormatPainterStatus=(FormatPainterStatus2=>(FormatPainterStatus2[FormatPainterStatus2.OFF=0]="OFF",FormatPainterStatus2[FormatPainterStatus2.ONCE=1]="ONCE",FormatPainterStatus2[FormatPainterStatus2.INFINITE=2]="INFINITE",FormatPainterStatus2))(FormatPainterStatus||{});const IFormatPainterService=core.createIdentifier("univer.format-painter-service");var _a13;let FormatPainterService=(_a13=class extends core.Disposable{constructor(_selectionManagerService,_themeService,_markSelectionService,_logService,_commandService,_undoRedoService){super();__publicField(this,"status$");__publicField(this,"_selectionFormat");__publicField(this,"_markId",null);__publicField(this,"_status$");__publicField(this,"_defaultHook",null);__publicField(this,"_extendHooks",[]);this._selectionManagerService=_selectionManagerService,this._themeService=_themeService,this._markSelectionService=_markSelectionService,this._logService=_logService,this._commandService=_commandService,this._undoRedoService=_undoRedoService,this._status$=new rxjs.BehaviorSubject(0),this.status$=this._status$.asObservable(),this._selectionFormat={styles:new core.ObjectMatrix,merges:[]}}addHook(hook){var _a58,_b,_c;hook.isDefaultHook&&((_a58=hook.priority)!=null?_a58:0)>((_c=(_b=this._defaultHook)==null?void 0:_b.priority)!=null?_c:-1)?this._defaultHook=hook:(this._extendHooks.push(hook),this._extendHooks.sort((a,b)=>(a.priority||0)-(b.priority||0)))}getHooks(){return this._defaultHook?[this._defaultHook,...this._extendHooks]:this._extendHooks}setStatus(status){this._updateRangeMark(status),this._status$.next(status),this.getHooks().forEach(hook=>{hook.onStatusChange!==void 0&&hook.onStatusChange(status)})}getStatus(){return this._status$.getValue()}setSelectionFormat(format){this._selectionFormat=format}getSelectionFormat(){return this._selectionFormat}applyFormatPainter(unitId,subUnitId,range){const hooks=this.getHooks(),redoMutationsInfo=[],undoMutationsInfo=[];hooks.forEach(h=>{if(h.onApply!==void 0){const applyReturn=h.onApply(unitId,subUnitId,range,this._selectionFormat);applyReturn&&(redoMutationsInfo.push(...applyReturn.redos),undoMutationsInfo.push(...applyReturn.undos))}});for(const beforeHook of hooks)if(beforeHook.onBeforeApply!==void 0&&!beforeHook.onBeforeApply({unitId,subUnitId,range,redoMutationsInfo,format:this._selectionFormat,undoMutationsInfo}))return!1;this._logService.log("[FormatPainterService]","apply mutations",{undoMutationsInfo,redoMutationsInfo});const result=redoMutationsInfo.every(m2=>this._commandService.executeCommand(m2.id,m2.params));return result&&this._undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undoMutationsInfo,redoMutations:redoMutationsInfo}),result}_updateRangeMark(status){if(this._markSelectionService.removeAllShapes(),status!==0){const selection=this._selectionManagerService.getCurrentLastSelection();if(selection){const style=createCopyPasteSelectionStyle(this._themeService);status===2?this._markId=this._markSelectionService.addShape({...selection,style}):this._markId=this._markSelectionService.addShape({...selection,style},[sheets.SetRangeValuesMutation.id])}}}},__name(_a13,"FormatPainterService"),_a13);FormatPainterService=__decorateClass$G([__decorateParam$G(0,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$G(1,core.Inject(core.ThemeService)),__decorateParam$G(2,IMarkSelectionService),__decorateParam$G(3,core.ILogService),__decorateParam$G(4,core.ICommandService),__decorateParam$G(5,core.IUndoRedoService)],FormatPainterService);const SetFormatPainterOperation={id:"sheet.operation.set-format-painter",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>params?(accessor.get(IFormatPainterService).setStatus(params.status),!0):!1,"handler")},SetInfiniteFormatPainterCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-infinite-format-painter",handler:__name(async accessor=>{const status=accessor.get(IFormatPainterService).getStatus();let newStatus;return status!==FormatPainterStatus.OFF?newStatus=FormatPainterStatus.OFF:newStatus=FormatPainterStatus.INFINITE,accessor.get(core.ICommandService).executeCommand(SetFormatPainterOperation.id,{status:newStatus})},"handler")},SetOnceFormatPainterCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-once-format-painter",handler:__name(async accessor=>{const status=accessor.get(IFormatPainterService).getStatus();let newStatus;return status!==FormatPainterStatus.OFF?newStatus=FormatPainterStatus.OFF:newStatus=FormatPainterStatus.ONCE,accessor.get(core.ICommandService).executeCommand(SetFormatPainterOperation.id,{status:newStatus})},"handler")},ApplyFormatPainterCommand={type:core.CommandType.COMMAND,id:"sheet.command.apply-format-painter",handler:__name(async(accessor,params)=>accessor.get(IFormatPainterService).applyFormatPainter(params.unitId,params.subUnitId,params.range),"handler")},SetSelectionFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-selection-frozen",handler:__name(async(accessor,params)=>{const{type}=params||{},univerInstanceService=accessor.get(core.IUniverInstanceService),undoRedoService=accessor.get(core.IUndoRedoService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target,commandService=accessor.get(core.ICommandService),selections=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections();if(!selections)return!1;const currentSelection=selections[(selections==null?void 0:selections.length)-1],{range}=currentSelection,scrollManagerService=accessor.get(engineRender.IRenderManagerService).getRenderById(unitId).with(SheetScrollManagerService),{sheetViewStartRow=0,sheetViewStartColumn=0}=scrollManagerService.getCurrentScrollState()||{};let startRow,startColumn,ySplit,xSplit;const{startRow:selectRow,startColumn:selectColumn,rangeType}=range;if(rangeType===core.RANGE_TYPE.ROW||type===1)startRow=selectRow,ySplit=selectRow-sheetViewStartRow,startColumn=-1,xSplit=0;else if(rangeType===core.RANGE_TYPE.COLUMN||type===2)startRow=-1,ySplit=0,startColumn=selectColumn,xSplit=selectColumn-sheetViewStartColumn;else if(rangeType===core.RANGE_TYPE.NORMAL)startRow=selectRow,ySplit=selectRow-sheetViewStartRow,startColumn=selectColumn,xSplit=selectColumn-sheetViewStartColumn;else return!1;const redoMutationParams={unitId,subUnitId,startRow,startColumn,xSplit:startColumn>0?Math.max(1,xSplit):xSplit,ySplit:startRow>0?Math.max(1,ySplit):ySplit},undoMutationParams=sheets.SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(sheets.SetFrozenMutation.id,redoMutationParams)&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:sheets.SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:sheets.SetFrozenMutation.id,params:redoMutationParams}]}),!0},"handler")},SetRowFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-row-frozen",handler:__name(async accessor=>(accessor.get(core.ICommandService).executeCommand(SetSelectionFrozenCommand.id,{type:1}),!0),"handler")},SetColumnFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-col-frozen",handler:__name(async accessor=>(accessor.get(core.ICommandService).executeCommand(SetSelectionFrozenCommand.id,{type:2}),!0),"handler")},CancelFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.cancel-frozen",handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),undoRedoService=accessor.get(core.IUndoRedoService),target=sheets.getSheetCommandTarget(univerInstanceService,{unitId:params==null?void 0:params.unitId,subUnitId:params==null?void 0:params.subUnitId});if(!target)return!1;const{unitId,subUnitId}=target,redoMutationParams={unitId,subUnitId,startRow:-1,startColumn:-1,xSplit:0,ySplit:0},undoMutationParams=sheets.SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(sheets.SetFrozenMutation.id,redoMutationParams)&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:sheets.SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:sheets.SetFrozenMutation.id,params:redoMutationParams}]}),!0},"handler")},ISheetBarService=core.createIdentifier("univer.sheetbar-service"),_SheetBarService=class _SheetBarService extends core.Disposable{constructor(){super();__publicField(this,"renameId$");__publicField(this,"removeId$");__publicField(this,"scroll$");__publicField(this,"scrollX$");__publicField(this,"addSheet$");__publicField(this,"_renameId$");__publicField(this,"_removeId$");__publicField(this,"_scroll$");__publicField(this,"_scrollX$");__publicField(this,"_addSheet$");__publicField(this,"_currentHandler",null);this._renameId$=new rxjs.Subject,this.renameId$=this._renameId$.asObservable(),this._removeId$=new rxjs.Subject,this.removeId$=this._removeId$.asObservable(),this._scroll$=new rxjs.Subject,this.scroll$=this._scroll$.asObservable(),this._scrollX$=new rxjs.Subject,this.scrollX$=this._scrollX$.asObservable(),this._addSheet$=new rxjs.Subject,this.addSheet$=this._addSheet$.asObservable()}setRenameId(renameId){this._renameId$.next(renameId)}setRemoveId(removeId){this._removeId$.next(removeId)}setScroll(state){this._scroll$.next(state)}setScrollX(x){this._scrollX$.next(x)}setAddSheet(index){this._addSheet$.next(index)}triggerSheetBarMenu(){var _a58;(_a58=this._currentHandler)==null||_a58.handleSheetBarMenu()}registerSheetBarMenuHandler(handler){if(this._currentHandler)throw new Error("There is already a context menu handler!");return this._currentHandler=handler,core.toDisposable(()=>{this._currentHandler=null})}};__name(_SheetBarService,"SheetBarService");let SheetBarService=_SheetBarService;const ShowMenuListCommand={id:"ui-sheet.command.show-menu-list",type:core.CommandType.OPERATION,handler:__name(async accessor=>(accessor.get(ISheetBarService).triggerSheetBarMenu(),!0),"handler")},SetActivateCellEditOperation={id:"sheet.operation.set-activate-cell-edit",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>(accessor.get(IEditorBridgeService).setEditCell(params),!0),"handler")},RenameSheetOperation={id:"sheet.operation.rename-sheet",type:core.CommandType.OPERATION,handler:__name(async(accessor,params)=>{const sheetBarService=accessor.get(ISheetBarService);return params&&sheetBarService.setRenameId(params.subUnitId),!0},"handler")},ScrollToRangeOperation={id:"sheet.operation.scroll-to-range",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{if(!params)return!1;const instanceService=accessor.get(core.IUniverInstanceService);return accessor.get(engineRender.IRenderManagerService).getRenderById(instanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).with(exports.SheetsScrollRenderController).scrollToRange(params.range)},"handler")},SheetPermissionOpenDialogOperation={type:core.CommandType.OPERATION,id:"sheet-permission.operation.openDialog",async handler(accessor,_params){const dialogService=accessor.get(ui.IDialogService);return dialogService.close("DESKTOP_FIND_REPLACE_DIALOG"),dialogService.open({id:UNIVER_SHEET_PERMISSION_DIALOG_ID,title:{title:"permission.dialog.allowedPermissionType"},children:{label:UNIVER_SHEET_PERMISSION_DIALOG},width:393,destroyOnClose:!0,onClose:__name(()=>dialogService.close(UNIVER_SHEET_PERMISSION_DIALOG_ID),"onClose")}),!0}},DEFINED_NAME_CONTAINER="DefinedNameContainer",SCOPE_WORKBOOK_VALUE="AllDefaultWorkbook",SidebarDefinedNameOperation={id:"sidebar.operation.defined-name",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const sidebarService=accessor.get(ui.ISidebarService),editorService=accessor.get(docsUi.IEditorService),localeService=accessor.get(core.LocaleService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId}=target;switch(params.value){case"open":editorService.setOperationSheetUnitId(unitId),sidebarService.open({header:{title:localeService.t("definedName.featureTitle")},children:{label:DEFINED_NAME_CONTAINER},onClose:__name(()=>{editorService.closeRangePrompt()},"onClose"),width:333});break;case"close":default:sidebarService.close();break}return!0},"handler")};var jsxRuntime={exports:{}},reactJsxRuntime_production_min={};/**
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 docsUi=require("@univerjs/docs-ui"),core=require("@univerjs/core"),engineRender=require("@univerjs/engine-render"),sheets=require("@univerjs/sheets"),rxjs=require("rxjs"),ui=require("@univerjs/ui"),docs=require("@univerjs/docs"),React=require("react"),design=require("@univerjs/design"),engineFormula=require("@univerjs/engine-formula"),operators=require("rxjs/operators"),telemetry=require("@univerjs/telemetry");var SheetsUIPart=(SheetsUIPart2=>(SheetsUIPart2.FILTER_PANEL_EMBED_POINT="filter-panel-embed-point",SheetsUIPart2.SHEETS_FOOTER="sheets-footer",SheetsUIPart2))(SheetsUIPart||{});const SHEET_UI_PLUGIN_NAME="SheetUI";function getEditorObject(unitId,renderManagerService){if(unitId==null)return;const currentRender=renderManagerService.getRenderById(unitId);if(currentRender==null)return;const{mainComponent,scene,engine,components}=currentRender,document2=mainComponent,docBackground=components.get(docsUi.DOCS_VIEW_KEY.BACKGROUND);return{document:document2,docBackground,scene,engine}}__name(getEditorObject,"getEditorObject");var __defProp$S=Object.defineProperty,__getOwnPropDesc$S=Object.getOwnPropertyDescriptor,__decorateClass$S=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$S(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$S(target,key,result),result},"__decorateClass$S"),__decorateParam$S=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$S"),_a;exports.SheetSkeletonManagerService=(_a=class extends core.Disposable{constructor(_context,_injector){super();__publicField(this,"_currentSkeletonSearchParam",{sheetId:""});__publicField(this,"_sheetSkeletonParam",[]);__publicField(this,"_currentSkeleton$",new rxjs.BehaviorSubject(null));__publicField(this,"currentSkeleton$",this._currentSkeleton$.asObservable());__publicField(this,"_currentSkeletonBefore$",new rxjs.BehaviorSubject(null));__publicField(this,"currentSkeletonBefore$",this._currentSkeletonBefore$.asObservable());this._context=_context,this._injector=_injector,this.disposeWithMe(()=>{this._currentSkeletonBefore$.complete(),this._currentSkeleton$.complete(),this._sheetSkeletonParam=[]}),this._initRemoveSheet()}_initRemoveSheet(){this.disposeWithMe(this._context.unit.sheetDisposed$.subscribe(sheet=>{this.disposeSkeleton({sheetId:sheet.getSheetId()})}))}getCurrentSkeleton(){var _a58;return(_a58=this.getCurrent())==null?void 0:_a58.skeleton}getCurrent(){return this._getSkeleton(this._currentSkeletonSearchParam)}getWorksheetSkeleton(sheetId){return this._getSkeleton({sheetId})}getUnitSkeleton(unitId,sheetId){const param=this._getSkeleton({sheetId});return param!=null&&(param.unitId=unitId),param}setCurrent(searchParam){this._setCurrent(searchParam)}_setCurrent(searchParam){const param=this._getSkeleton(searchParam),unitId=this._context.unitId;if(param!=null)this._reCalculate(param);else{const{sheetId:sheetId2}=searchParam,worksheet=this._context.unit.getSheetBySheetId(searchParam.sheetId);if(worksheet==null)return;const skeleton=this._buildSkeleton(worksheet);this._sheetSkeletonParam.push({unitId,sheetId:sheetId2,skeleton,dirty:!1})}this._currentSkeletonSearchParam=searchParam;const sheetId=this._currentSkeletonSearchParam.sheetId,sheetSkeletonManagerParam=this.getUnitSkeleton(unitId,sheetId);this._currentSkeletonBefore$.next(sheetSkeletonManagerParam),this._currentSkeleton$.next(sheetSkeletonManagerParam)}reCalculate(){const param=this.getCurrent();param!=null&&this._reCalculate(param)}_reCalculate(param){param.dirty&&(param.skeleton.makeDirty(!0),param.dirty=!1),param.skeleton.calculate()}makeDirty(searchParm,state=!0){const param=this._getSkeleton(searchParm);param!=null&&(param.dirty=state)}getOrCreateSkeleton(searchParam){const skeleton=this._getSkeleton(searchParam);if(skeleton)return skeleton.skeleton;const worksheet=this._context.unit.getSheetBySheetId(searchParam.sheetId);if(!worksheet)return;const newSkeleton=this._buildSkeleton(worksheet);return this._sheetSkeletonParam.push({unitId:this._context.unitId,sheetId:searchParam.sheetId,skeleton:newSkeleton,dirty:!1}),newSkeleton}disposeSkeleton(searchParm){const index=this._sheetSkeletonParam.findIndex(param=>param.sheetId===searchParm.sheetId);index>-1&&(this._sheetSkeletonParam[index].skeleton.dispose(),this._sheetSkeletonParam.splice(index,1))}attachRangeWithCoord(range){const skeleton=this.getCurrentSkeleton();return skeleton?attachRangeWithCoord(skeleton,range):null}_getSkeleton(searchParm){const item=this._sheetSkeletonParam.find(param=>param.sheetId===searchParm.sheetId);return item!=null&&(item.commandId=searchParm.commandId),item}_buildSkeleton(worksheet){const config=worksheet.getConfig();return this._injector.createInstance(engineRender.SpreadsheetSkeleton,worksheet,config,worksheet.getCellMatrix(),this._context.unit.getStyles())}},__name(_a,"SheetSkeletonManagerService"),_a);exports.SheetSkeletonManagerService=__decorateClass$S([__decorateParam$S(1,core.Inject(core.Injector))],exports.SheetSkeletonManagerService);function attachRangeWithCoord(skeleton,range){const{startRow,startColumn,endRow,endColumn,rangeType}=range,_startRow=endRow<startRow?endRow:startRow,_endRow=endRow<startRow?startRow:endRow,_startColumn=endColumn<startColumn?endColumn:startColumn,_endColumn=endColumn<startColumn?startColumn:endColumn,startCell=skeleton.getNoMergeCellPositionByIndex(_startRow,_startColumn),endCell=skeleton.getNoMergeCellPositionByIndex(_endRow,_endColumn);return{startRow,startColumn,endRow,endColumn,rangeType,startY:(startCell==null?void 0:startCell.startY)||0,endY:(endCell==null?void 0:endCell.endY)||0,startX:(startCell==null?void 0:startCell.startX)||0,endX:(endCell==null?void 0:endCell.endX)||0}}__name(attachRangeWithCoord,"attachRangeWithCoord");var __defProp$R=Object.defineProperty,__getOwnPropDesc$R=Object.getOwnPropertyDescriptor,__decorateClass$R=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$R(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$R(target,key,result),result},"__decorateClass$R"),__decorateParam$R=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$R"),_a2;let SheetScrollManagerService=(_a2=class{constructor(_context,_sheetSkeletonManagerService){__publicField(this,"_scrollStateMap",new Map);__publicField(this,"_rawscrollInfo$",new rxjs.BehaviorSubject(null));__publicField(this,"rawScrollInfo$",this._rawscrollInfo$.asObservable());__publicField(this,"validViewportScrollInfo$",new rxjs.BehaviorSubject(null));__publicField(this,"_searchParamForScroll",null);this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService}dispose(){this._rawscrollInfo$.complete()}setSearchParam(param){this._searchParamForScroll=param}setSearchParamAndRefresh(param){this._searchParamForScroll=param,this._scrollStateNext(param)}getScrollStateByParam(param){return this._getCurrentScroll(param)}getCurrentScrollState(){return this._getCurrentScroll(this._searchParamForScroll)}setScrollInfoAndEmitEvent(param){this._setScrollState(param),this._scrollStateNext(param)}setScrollStateToCurrSheetAndEmitEvent(scrollInfo){this._searchParamForScroll!=null&&(this._setScrollState({...this._searchParamForScroll,...scrollInfo}),this._scrollStateNext(this._searchParamForScroll))}setScrollStateToCurrSheet(scroll){this._searchParamForScroll!=null&&this._setScrollState({...this._searchParamForScroll,...scroll})}clear(){this._searchParamForScroll!=null&&this._clearByParamAndNotify(this._searchParamForScroll)}calcViewportScrollFromRowColOffset(scrollInfo){if(!scrollInfo)return{viewportScrollX:0,viewportScrollY:0};let{sheetViewStartColumn,sheetViewStartRow,offsetX,offsetY}=scrollInfo;sheetViewStartRow=sheetViewStartRow||0,offsetY=offsetY||0;const skeleton=this._sheetSkeletonManagerService.getCurrentSkeleton(),rowAcc=(skeleton==null?void 0:skeleton.rowHeightAccumulation[sheetViewStartRow-1])||0,viewportScrollX=((skeleton==null?void 0:skeleton.columnWidthAccumulation[sheetViewStartColumn-1])||0)+offsetX,viewportScrollY=rowAcc+offsetY;return{viewportScrollX,viewportScrollY}}_setScrollState(scrollInfo){const{unitId,sheetId,sheetViewStartColumn,sheetViewStartRow,offsetX,offsetY}=scrollInfo;this._scrollStateMap.has(unitId)||this._scrollStateMap.set(unitId,new Map);const worksheetScrollInfoMap=this._scrollStateMap.get(unitId),newScrollInfo={sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY};worksheetScrollInfoMap.set(sheetId,newScrollInfo)}_clearByParamAndNotify(param){this._setScrollState({...param,sheetViewStartRow:0,sheetViewStartColumn:0,offsetX:0,offsetY:0}),this._scrollStateNext(param)}_getCurrentScroll(param){var _a58;if(param==null)return;const{unitId,sheetId}=param;return(_a58=this._scrollStateMap.get(unitId))==null?void 0:_a58.get(sheetId)}_scrollStateNext(param){const scrollInfo=this._getCurrentScroll(param);this._rawscrollInfo$.next(scrollInfo)}},__name(_a2,"SheetScrollManagerService"),_a2);SheetScrollManagerService=__decorateClass$R([__decorateParam$R(1,core.Inject(exports.SheetSkeletonManagerService))],SheetScrollManagerService);const SetScrollOperation={id:"sheet.operation.set-scroll",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{if(!params)return!1;const{unitId,sheetId,offsetX,offsetY,sheetViewStartColumn,sheetViewStartRow}=params,currentService=accessor.get(core.IUniverInstanceService),renderManagerService=accessor.get(engineRender.IRenderManagerService),worksheet=currentService.getUniverSheetInstance(unitId).getSheetBySheetId(sheetId),scrollManagerService=renderManagerService.getRenderById(unitId).with(SheetScrollManagerService),{xSplit,ySplit}=worksheet.getConfig().freeze;return scrollManagerService.setScrollInfoAndEmitEvent({unitId,sheetId,offsetX,offsetY,sheetViewStartRow:sheetViewStartRow-ySplit,sheetViewStartColumn:sheetViewStartColumn-xSplit}),!0},"handler")},SetScrollRelativeCommand={id:"sheet.command.set-scroll-relative",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),renderManagerSrv=accessor.get(engineRender.IRenderManagerService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId,worksheet}=target,{xSplit,ySplit}=worksheet.getConfig().freeze,currentScroll=renderManagerSrv.getRenderById(unitId).with(SheetScrollManagerService).getCurrentScrollState(),{offsetX=0,offsetY=0}=params||{},{sheetViewStartRow=0,sheetViewStartColumn=0,offsetX:currentOffsetX=0,offsetY:currentOffsetY=0}=currentScroll||{};return commandService.executeCommand(SetScrollOperation.id,{unitId,sheetId:subUnitId,sheetViewStartRow:sheetViewStartRow+ySplit,sheetViewStartColumn:sheetViewStartColumn+xSplit,offsetX:currentOffsetX+offsetX,offsetY:currentOffsetY+offsetY})},"handler")},ScrollCommand={id:"sheet.command.scroll-view",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{if(!params)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),renderManagerSrv=accessor.get(engineRender.IRenderManagerService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{workbook,worksheet,unitId}=target,currentScroll=renderManagerSrv.getRenderById(unitId).with(SheetScrollManagerService).getCurrentScrollState();if(!worksheet)return!1;const{sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY}=params,{sheetViewStartColumn:currentColumn,sheetViewStartRow:currentRow,offsetX:currentOffsetX,offsetY:currentOffsetY}=currentScroll||{},{xSplit,ySplit}=worksheet.getConfig().freeze;return accessor.get(core.ICommandService).syncExecuteCommand(SetScrollOperation.id,{unitId:workbook.getUnitId(),sheetId:worksheet.getSheetId(),sheetViewStartRow:sheetViewStartRow!=null?sheetViewStartRow:(currentRow!=null?currentRow:0)+ySplit,sheetViewStartColumn:sheetViewStartColumn!=null?sheetViewStartColumn:(currentColumn!=null?currentColumn:0)+xSplit,offsetX:offsetX!=null?offsetX:currentOffsetX,offsetY:offsetY!=null?offsetY:currentOffsetY})},"handler")},ScrollToCellCommand={id:"sheet.command.scroll-to-cell",type:core.CommandType.COMMAND,handler:__name((accessor,params)=>{const instanceService=accessor.get(core.IUniverInstanceService);return accessor.get(engineRender.IRenderManagerService).getRenderById(instanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).with(exports.SheetsScrollRenderController).scrollToRange(params.range)},"handler")},ResetScrollCommand={id:"sheet.command.scroll-view-reset",type:core.CommandType.COMMAND,handler:__name(async accessor=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{subUnitId,unitId}=target;return accessor.get(core.ICommandService).executeCommand(SetScrollOperation.id,{unitId,sheetId:subUnitId,sheetViewStartRow:0,sheetViewStartColumn:0})},"handler")};var __defProp$Q=Object.defineProperty,__getOwnPropDesc$Q=Object.getOwnPropertyDescriptor,__decorateClass$Q=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$Q(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$Q(target,key,result),result},"__decorateClass$Q"),__decorateParam$Q=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$Q"),_a3;let ShortcutExperienceService=(_a3=class{constructor(_univerInstanceService,_localeService){__publicField(this,"_current",null);__publicField(this,"_shortcutParam",[]);this._univerInstanceService=_univerInstanceService,this._localeService=_localeService}dispose(){this._shortcutParam=[]}getCurrentBySearch(searchParm){return this._getCurrentBySearch(searchParm)}getCurrent(){return this._getCurrentBySearch(this._current)}addOrUpdate(insertParam){const param=this._getCurrentBySearch({unitId:insertParam.unitId,sheetId:insertParam.sheetId,keycode:insertParam.keycode});if(param!=null){const index=this._shortcutParam.indexOf(param);this._shortcutParam.splice(index,1)}return this._shortcutParam.push(insertParam),param}remove(searchParm){if(searchParm==null)return;const param=this._getCurrentBySearch(searchParm);if(param==null)return;const index=this._shortcutParam.indexOf(param);return this._shortcutParam.splice(index,1)[0]}_getCurrentBySearch(searchParm){return searchParm==null?void 0:this._shortcutParam.find(param=>param.unitId===searchParm.unitId&&param.sheetId===searchParm.sheetId&&param.keycode===searchParm.keycode)}},__name(_a3,"ShortcutExperienceService"),_a3);ShortcutExperienceService=__decorateClass$Q([__decorateParam$Q(0,core.IUniverInstanceService),__decorateParam$Q(1,core.Inject(core.LocaleService))],ShortcutExperienceService);const _SelectAllService=class _SelectAllService extends core.Disposable{constructor(){super(...arguments);__publicField(this,"rangesStack",[]);__publicField(this,"selectedRangeWorksheet","")}};__name(_SelectAllService,"SelectAllService");let SelectAllService=_SelectAllService;var MergeType=(MergeType2=>(MergeType2.MergeAll="mergeAll",MergeType2.MergeVertical="mergeVertical",MergeType2.MergeHorizontal="mergeHorizontal",MergeType2))(MergeType||{});function findNextRange(startRange,direction,worksheet,boundary,isFindNext=!0,nextStep=1,isGoBack=!0){let destRange={...startRange};boundary==null&&(boundary={startRow:0,endRow:worksheet.getRowCount()-1,startColumn:0,endColumn:worksheet.getColumnCount()-1});let next;switch(direction){case core.Direction.UP:for(next=startRange.startRow-nextStep;next>-1&&!worksheet.getRowVisible(next);)next-=1;next>=boundary.startRow?(destRange.startRow=next,destRange.endRow=next):isGoBack&&(destRange.startRow=boundary.endRow,destRange.endRow=boundary.endRow,isFindNext&&(destRange=findNextRange(destRange,core.Direction.LEFT,worksheet,boundary,!1)));break;case core.Direction.DOWN:for(next=startRange.endRow+nextStep;next<worksheet.getRowCount()&&!worksheet.getRowVisible(next);)next+=1;next<=boundary.endRow?(destRange.startRow=next,destRange.endRow=next):isGoBack&&(destRange.startRow=boundary.startRow,destRange.endRow=boundary.startRow,isFindNext&&(destRange=findNextRange(destRange,core.Direction.RIGHT,worksheet,boundary,!1)));break;case core.Direction.LEFT:for(next=startRange.startColumn-nextStep;next>-1&&!worksheet.getColVisible(next);)next-=1;next>=boundary.startColumn?(destRange.startColumn=next,destRange.endColumn=next):isGoBack&&(destRange.startColumn=boundary.endColumn,destRange.endColumn=boundary.endColumn,isFindNext&&(destRange=findNextRange(destRange,core.Direction.UP,worksheet,boundary,!1)));break;case core.Direction.RIGHT:for(next=startRange.endColumn+nextStep;next<worksheet.getColumnCount()&&!worksheet.getColVisible(next);)next+=1;next<=boundary.endColumn?(destRange.startColumn=next,destRange.endColumn=next):isGoBack&&(destRange.startColumn=boundary.startColumn,destRange.endColumn=boundary.startColumn,isFindNext&&(destRange=findNextRange(destRange,core.Direction.DOWN,worksheet,boundary,!1)));break}return destRange}__name(findNextRange,"findNextRange");function findNextGapRange(startRange,direction,worksheet){const destRange={...startRange},{startRow,startColumn,endRow,endColumn}=getEdgeOfRange(startRange,direction,worksheet);let currentPositionHasValue=rangeHasValue(worksheet,startRow,startColumn,endRow,endColumn).hasValue,firstMove=!0,shouldContinue=!0;for(;shouldContinue;){if(core.Direction.UP===direction){let next=destRange.startRow-1;for(;next>-1&&!worksheet.getRowVisible(next);)next-=1;if(next===-1){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,next,destRange.startColumn,next,destRange.endColumn);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let min=next;matrix.forValue(row=>{min=Math.min(row,min)}),destRange.startRow=min}else destRange.startRow=next;if(destRange.endRow=destRange.startRow,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}if(core.Direction.DOWN===direction){let next=destRange.endRow+1;for(;next<worksheet.getRowCount()&&!worksheet.getRowVisible(next);)next+=1;if(next===worksheet.getRowCount()){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,next,destRange.startColumn,next,destRange.endColumn);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let max=next;matrix.forValue((row,_,value)=>{max=Math.max(row+(value.rowSpan||1)-1,max)}),destRange.endRow=max}else destRange.endRow=next;if(destRange.startRow=destRange.endRow,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}if(core.Direction.LEFT===direction){let next=destRange.startColumn-1;for(;next>-1&&!worksheet.getColVisible(next);)next-=1;if(next===-1){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,destRange.startRow,next,destRange.endRow,next);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let min=next;matrix.forValue((_,col)=>{min=Math.min(col,min)}),destRange.startColumn=min}else destRange.startColumn=next;if(destRange.endColumn=destRange.startColumn,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}if(core.Direction.RIGHT===direction){let next=destRange.endColumn+1;for(;next<worksheet.getColumnCount()&&!worksheet.getColVisible(next);)next+=1;if(next===worksheet.getColumnCount()){shouldContinue=!1;break}const{hasValue:nextRangeHasValue,matrix}=rangeHasValue(worksheet,destRange.startRow,next,destRange.endRow,next);if(currentPositionHasValue&&!nextRangeHasValue&&!firstMove){shouldContinue=!1;break}else{if(matrix.getLength()!==0){let max=next;matrix.forValue((_,col,value)=>{max=Math.max(col+(value.colSpan||1)-1,max)}),destRange.endColumn=max}else destRange.endColumn=next;if(destRange.startColumn=destRange.endColumn,!currentPositionHasValue&&nextRangeHasValue){shouldContinue=!1;break}currentPositionHasValue=nextRangeHasValue,firstMove=!1}}}return sheets.alignToMergedCellsBorders(destRange,worksheet,!0)}__name(findNextGapRange,"findNextGapRange");function findNextRangeExpand(startRange,direction,worksheet){return findNextRange(startRange,direction,worksheet,void 0,!1,1,!1)}__name(findNextRangeExpand,"findNextRangeExpand");function expandToNextGapRange(startRange,direction,worksheet){const next=findNextGapRange(startRange,direction,worksheet);return sheets.alignToMergedCellsBorders(core.Rectangle.union(next,startRange),worksheet,!0)}__name(expandToNextGapRange,"expandToNextGapRange");function expandToNextCell(startRange,direction,worksheet){const next=findNextRangeExpand(startRange,direction,worksheet),destRange={startRow:Math.min(startRange.startRow,next.startRow),startColumn:Math.min(startRange.startColumn,next.startColumn),endRow:Math.max(startRange.endRow,next.endRow),endColumn:Math.max(startRange.endColumn,next.endColumn)};return sheets.alignToMergedCellsBorders(core.Rectangle.union(startRange,destRange),worksheet)}__name(expandToNextCell,"expandToNextCell");function shrinkToNextGapRange(startRange,anchorRange,direction,worksheet){const reversedDirection=core.getReverseDirection(direction),nextGap=findNextGapRange(getEdgeOfRange(startRange,reversedDirection,worksheet),direction,worksheet);return direction===core.Direction.UP&&nextGap.startRow<=startRange.startRow?sheets.alignToMergedCellsBorders({...anchorRange,startColumn:startRange.startColumn,endColumn:startRange.endColumn},worksheet,!0):direction===core.Direction.DOWN&&nextGap.endRow>=startRange.endRow?sheets.alignToMergedCellsBorders({...anchorRange,startColumn:startRange.startColumn,endColumn:startRange.endColumn},worksheet,!0):direction===core.Direction.LEFT&&nextGap.startColumn<=startRange.startColumn?sheets.alignToMergedCellsBorders({...anchorRange,startRow:startRange.startRow,endRow:startRange.endRow},worksheet,!0):direction===core.Direction.RIGHT&&nextGap.endColumn>=startRange.endColumn?sheets.alignToMergedCellsBorders({...anchorRange,startRow:startRange.startRow,endRow:startRange.endRow},worksheet,!0):core.Rectangle.union(core.Rectangle.clone(anchorRange),nextGap)}__name(shrinkToNextGapRange,"shrinkToNextGapRange");function shrinkToNextCell(startRange,direction,worksheet){const reversedDirection=core.getReverseDirection(direction),shrinkFromEdge=getEdgeOfRange(startRange,reversedDirection,worksheet),otherEdge=getEdgeOfRange(startRange,direction,worksheet),next=findNextRangeExpand(shrinkFromEdge,direction,worksheet);return sheets.alignToMergedCellsBorders(core.Rectangle.union(otherEdge,next),worksheet,!1)}__name(shrinkToNextCell,"shrinkToNextCell");function expandToWholeSheet(worksheet){return{startRow:0,startColumn:0,endRow:worksheet.getRowCount()-1,endColumn:worksheet.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL}}__name(expandToWholeSheet,"expandToWholeSheet");function getEdgeOfRange(startRange,direction,worksheet){let destRange;switch(direction){case core.Direction.UP:destRange={startRow:startRange.startRow,startColumn:startRange.startColumn,endRow:startRange.startRow,endColumn:startRange.endColumn,rangeType:core.RANGE_TYPE.NORMAL};break;case core.Direction.DOWN:destRange={startRow:startRange.endRow,startColumn:startRange.startColumn,endRow:startRange.endRow,endColumn:startRange.endColumn,rangeType:core.RANGE_TYPE.NORMAL};break;case core.Direction.LEFT:destRange={startRow:startRange.startRow,startColumn:startRange.startColumn,endRow:startRange.endRow,endColumn:startRange.startColumn,rangeType:core.RANGE_TYPE.NORMAL};break;case core.Direction.RIGHT:destRange={startRow:startRange.startRow,startColumn:startRange.endColumn,endRow:startRange.endRow,endColumn:startRange.endColumn,rangeType:core.RANGE_TYPE.NORMAL};break;default:throw new Error("Invalid direction")}return sheets.alignToMergedCellsBorders(destRange,worksheet,!1)}__name(getEdgeOfRange,"getEdgeOfRange");function rangeHasValue(worksheet,row,col,rowEnd,colEnd){let hasValue=!1;const matrix=worksheet.getMatrixWithMergedCells(row,col,rowEnd,colEnd).forValue((_,__,value)=>{if(cellHasValue(value))return hasValue=!0,!1});return{hasValue,matrix}}__name(rangeHasValue,"rangeHasValue");function getStartRange(range,primary,direction){const ret=core.Rectangle.clone(range);if(primary==null)return ret;switch(direction){case core.Direction.UP:case core.Direction.DOWN:ret.startColumn=ret.endColumn=primary.actualColumn;break;case core.Direction.LEFT:case core.Direction.RIGHT:ret.startRow=ret.endRow=primary.actualRow;break}return ret}__name(getStartRange,"getStartRange");function checkIfShrink(selection,direction,worksheet){const{primary,range}=selection,startRange=core.Rectangle.clone(range);switch(direction){case core.Direction.UP:case core.Direction.DOWN:startRange.startRow=primary.startRow,startRange.endRow=primary.endRow;break;case core.Direction.LEFT:case core.Direction.RIGHT:startRange.startColumn=primary.startColumn,startRange.endColumn=primary.endColumn;break}const anchorRange=getEdgeOfRange(startRange,direction,worksheet);switch(direction){case core.Direction.DOWN:return range.startRow<anchorRange.startRow;case core.Direction.UP:return range.endRow>anchorRange.endRow;case core.Direction.LEFT:return anchorRange.endColumn<range.endColumn;case core.Direction.RIGHT:return anchorRange.startColumn>range.startColumn}}__name(checkIfShrink,"checkIfShrink");function isAllRowsCovered(allRowRanges,ranges){let start=allRowRanges[0].startRow,end=allRowRanges[0].endRow;allRowRanges.forEach(range=>{const{startRow,endRow}=range;start=Math.min(start,startRow),end=Math.max(end,endRow)});const covered=new Array(end-start+1).fill(!1);return ranges.forEach(range=>{const{startRow,endRow}=range;for(let i=Math.max(startRow,start);i<=Math.min(endRow,end);i++)covered[i-start]=!0}),allRowRanges.every(range=>{const{startRow,endRow}=range;for(let i=startRow;i<=endRow;i++)if(!covered[i-start])return!1;return!0})}__name(isAllRowsCovered,"isAllRowsCovered");function isAllColumnsCovered(allColumnRanges,ranges){let start=allColumnRanges[0].startColumn,end=allColumnRanges[0].endColumn;allColumnRanges.forEach(range=>{const{startColumn,endColumn}=range;start=Math.min(start,startColumn),end=Math.max(end,endColumn)});const covered=new Array(end-start+1).fill(!1);return ranges.forEach(range=>{const{startColumn,endColumn}=range;for(let i=Math.max(startColumn,start);i<=Math.min(endColumn,end);i++)covered[i-start]=!0}),allColumnRanges.every(range=>{const{startColumn,endColumn}=range;for(let i=startColumn;i<=endColumn;i++)if(!covered[i-start])return!1;return!0})}__name(isAllColumnsCovered,"isAllColumnsCovered");function getMergeableSelectionsByType(type,selections){return selections?type==="mergeAll"?selections.filter(selection=>!(selection.startRow===selection.endRow&&selection.startColumn===selection.endColumn)):type==="mergeVertical"?selections.filter(selection=>selection.startRow!==selection.endRow):type==="mergeHorizontal"?selections.filter(selection=>selection.startColumn!==selection.endColumn):selections:null}__name(getMergeableSelectionsByType,"getMergeableSelectionsByType");function cellHasValue(cell){return cell.v!==void 0&&cell.v!==null&&cell.v!==""||cell.p!==void 0}__name(cellHasValue,"cellHasValue");var JumpOver=(JumpOver2=>(JumpOver2[JumpOver2.moveStopeOne=0]="moveStopeOne",JumpOver2[JumpOver2.moveGap=1]="moveGap",JumpOver2[JumpOver2.moveStepPage=2]="moveStepPage",JumpOver2[JumpOver2.moveStepEnd=3]="moveStepEnd",JumpOver2))(JumpOver||{});const MoveSelectionCommand={id:"sheet.command.move-selection",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{workbook,worksheet}=target,selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const{direction,jumpOver}=params,{range,primary}=selection,startRange=getStartRange(range,primary,direction),next=jumpOver===1?findNextGapRange(startRange,direction,worksheet):findNextRange(startRange,direction,worksheet),destRange=sheets.getCellAtRowCol(next.startRow,next.startColumn,worksheet);return core.Rectangle.equals(destRange,startRange)?!1:(accessor.get(ShortcutExperienceService).remove({unitId:workbook.getUnitId(),sheetId:worksheet.getSheetId(),keycode:ui.KeyCode.TAB}),accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),selections:[{range:core.Rectangle.clone(destRange),primary:{startRow:destRange.startRow,startColumn:destRange.startColumn,endRow:destRange.endRow,endColumn:destRange.endColumn,actualRow:next.startRow,actualColumn:next.startColumn,isMerged:destRange.isMerged,isMergedMainCell:destRange.startRow===next.startRow&&destRange.startColumn===next.startColumn}}]}))},"handler")},MoveSelectionEnterAndTabCommand={id:"sheet.command.move-selection-enter-tab",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{workbook,worksheet}=target,selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const unitId=workbook.getUnitId(),sheetId=worksheet.getSheetId();if(!selection)return!1;const{direction,keycode}=params,{range,primary}=selection;let startRange=getStartRange(range,primary,direction);const shortcutExperienceService=accessor.get(ShortcutExperienceService),shortcutExperienceParam=shortcutExperienceService.getCurrentBySearch({unitId,sheetId,keycode:ui.KeyCode.TAB});let resultRange;const{startRow,endRow,startColumn,endColumn}=range;if(core.Rectangle.equals(range,primary)){if(keycode===ui.KeyCode.TAB)shortcutExperienceParam==null&&shortcutExperienceService.addOrUpdate({unitId,sheetId,keycode:ui.KeyCode.TAB,selection});else{const selectionRemain=shortcutExperienceParam==null?void 0:shortcutExperienceParam.selection;if(selectionRemain!=null){const{range:range2,primary:primary2}=selectionRemain;startRange=getStartRange(range2,primary2,direction)}shortcutExperienceService.remove({unitId,sheetId,keycode:ui.KeyCode.TAB})}const next=findNextRange(startRange,direction,worksheet),destRange=sheets.getCellAtRowCol(next.startRow,next.startColumn,worksheet);if(core.Rectangle.equals(destRange,startRange))return!1;resultRange={range:core.Rectangle.clone(destRange),primary:{startRow:destRange.startRow,startColumn:destRange.startColumn,endRow:destRange.endRow,endColumn:destRange.endColumn,actualRow:next.startRow,actualColumn:next.startColumn,isMerged:destRange.isMerged,isMergedMainCell:destRange.startRow===next.startRow&&destRange.startColumn===next.startColumn}}}else{shortcutExperienceService.remove({unitId,sheetId,keycode:ui.KeyCode.TAB});const newPrimary=core.Tools.deepClone(primary),next=findNextRange({startRow:newPrimary.startRow,startColumn:newPrimary.startColumn,endRow:newPrimary.endRow,endColumn:newPrimary.endColumn},direction,worksheet,{startRow,endRow,startColumn,endColumn}),destRange=sheets.getCellAtRowCol(next.startRow,next.startColumn,worksheet);resultRange={range:core.Rectangle.clone(range),primary:{startRow:destRange.startRow,startColumn:destRange.startColumn,endRow:destRange.endRow,endColumn:destRange.endColumn,actualRow:next.startRow,actualColumn:next.startColumn,isMerged:destRange.isMerged,isMergedMainCell:destRange.startRow===next.startRow&&destRange.startColumn===next.startColumn}}}return accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,selections:[resultRange]})},"handler")},ExpandSelectionCommand={id:"sheet.command.expand-selection",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const{worksheet,unitId,subUnitId}=target,selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const{range:startRange,primary}=selection,{jumpOver,direction}=params,destRange=checkIfShrink(selection,direction,worksheet)?jumpOver===1?shrinkToNextGapRange(startRange,{...core.Rectangle.clone(primary),rangeType:core.RANGE_TYPE.NORMAL},direction,worksheet):shrinkToNextCell(startRange,direction,worksheet):jumpOver===1?expandToNextGapRange(startRange,direction,worksheet):expandToNextCell(startRange,direction,worksheet);return core.Rectangle.equals(destRange,startRange)?!1:accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId,selections:[{range:destRange,primary}]})},"handler")},SelectAllCommand={id:"sheet.command.select-all",type:core.CommandType.COMMAND,handler:__name(async(accessor,params={expandToGapFirst:!0,loop:!1})=>{const target=sheets.getSheetCommandTarget(accessor.get(core.IUniverInstanceService));if(!target)return!1;const selection=sheets.getSelectionsService(accessor).getCurrentLastSelection();if(!selection)return!1;const selectAllService=accessor.get(SelectAllService),{worksheet,unitId,subUnitId}=target,id=`${unitId}|${subUnitId}`;id!==selectAllService.selectedRangeWorksheet&&(selectAllService.rangesStack=[],selectAllService.selectedRangeWorksheet=id);const maxRow=worksheet.getMaxRows(),maxCol=worksheet.getMaxColumns(),{expandToGapFirst,loop}=params,{range,primary}=selection,isWholeSheetSelected=range.endColumn===maxCol-1&&range.endRow===maxRow-1&&range.startRow===0&&range.startColumn===0;selectAllService.rangesStack.some(s=>core.Rectangle.equals(s,range))||(selectAllService.rangesStack=[],selectAllService.rangesStack.push(range));let destRange;if(isWholeSheetSelected)if(loop){if(selectAllService.rangesStack.findIndex(s=>core.Rectangle.equals(s,range))!==selectAllService.rangesStack.length-1)return!1;destRange=selectAllService.rangesStack[0]}else return!1;else expandToGapFirst?(destRange=sheets.expandToContinuousRange(range,{left:!0,right:!0,up:!0,down:!0},worksheet),core.Rectangle.equals(destRange,range)&&(destRange=expandToWholeSheet(worksheet))):destRange=expandToWholeSheet(worksheet);return selectAllService.rangesStack.some(s=>core.Rectangle.equals(s,destRange))||selectAllService.rangesStack.push(destRange),accessor.get(core.ICommandService).executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId,selections:[{range:destRange,primary}]})},"handler")},SHEET_ZOOM_RANGE=[10,400];var SHEET_VIEW_KEY=(SHEET_VIEW_KEY2=>(SHEET_VIEW_KEY2.MAIN="__SpreadsheetRender__",SHEET_VIEW_KEY2.ROW="__SpreadsheetRowHeader__",SHEET_VIEW_KEY2.COLUMN="__SpreadsheetColumnHeader__",SHEET_VIEW_KEY2.LEFT_TOP="__SpreadsheetLeftTopPlaceholder__",SHEET_VIEW_KEY2))(SHEET_VIEW_KEY||{}),SHEET_VIEWPORT_KEY=(SHEET_VIEWPORT_KEY2=>(SHEET_VIEWPORT_KEY2.VIEW_MAIN="viewMain",SHEET_VIEWPORT_KEY2.VIEW_MAIN_LEFT_TOP="viewMainLeftTop",SHEET_VIEWPORT_KEY2.VIEW_MAIN_TOP="viewMainTop",SHEET_VIEWPORT_KEY2.VIEW_MAIN_LEFT="viewMainLeft",SHEET_VIEWPORT_KEY2.VIEW_ROW_TOP="viewRowTop",SHEET_VIEWPORT_KEY2.VIEW_ROW_BOTTOM="viewRowBottom",SHEET_VIEWPORT_KEY2.VIEW_COLUMN_LEFT="viewColumnLeft",SHEET_VIEWPORT_KEY2.VIEW_COLUMN_RIGHT="viewColumnRight",SHEET_VIEWPORT_KEY2.VIEW_LEFT_TOP="viewLeftTop",SHEET_VIEWPORT_KEY2))(SHEET_VIEWPORT_KEY||{});const SHEET_COMPONENT_MAIN_LAYER_INDEX=0,SHEET_COMPONENT_SELECTION_LAYER_INDEX=1,SHEET_COMPONENT_HEADER_LAYER_INDEX=10,SHEET_COMPONENT_HEADER_SELECTION_LAYER_INDEX=11,SHEET_COMPONENT_UNHIDE_LAYER_INDEX=12;function isRenderManagerService(renderManagerService){return typeof renderManagerService.isMainScene>"u"}__name(isRenderManagerService,"isRenderManagerService");function getSheetObject(univerInstanceService,renderManagerService){const workbook=univerInstanceService instanceof core.Workbook?univerInstanceService:univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const unitId=workbook.getUnitId();let components,mainComponent,scene,engine;if(isRenderManagerService(renderManagerService)){const currentRender=renderManagerService.getRenderById(unitId);if(currentRender==null)return null;components=currentRender.components,components=currentRender.components,mainComponent=currentRender.mainComponent,scene=currentRender.scene,engine=currentRender.engine}else components=renderManagerService.components,mainComponent=renderManagerService.mainComponent,scene=renderManagerService.scene,engine=renderManagerService.engine;if(!components||!mainComponent)return null;const spreadsheet=mainComponent,spreadsheetRowHeader=components.get(SHEET_VIEW_KEY.ROW),spreadsheetColumnHeader=components.get(SHEET_VIEW_KEY.COLUMN),spreadsheetLeftTopPlaceholder=components.get(SHEET_VIEW_KEY.LEFT_TOP);return{spreadsheet,spreadsheetRowHeader,spreadsheetColumnHeader,spreadsheetLeftTopPlaceholder,scene,engine}}__name(getSheetObject,"getSheetObject");function getCoordByCell(row,col,scene,skeleton){const{startX,startY,endX,endY}=skeleton.getCellByIndex(row,col);return{startX,startY,endX,endY}}__name(getCoordByCell,"getCoordByCell");function getCoordByOffset(evtOffsetX,evtOffsetY,scene,skeleton,viewport,closeFirst){const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords,scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords,viewport),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=skeleton.getCellPositionByOffset(newEvtOffsetX,newEvtOffsetY,scaleX,scaleY,scrollXY,closeFirst),{row,column}=moveActualSelection,startCell=skeleton.getNoMergeCellPositionByIndex(row,column),{startX,startY,endX,endY}=startCell;return{startX,startY,endX,endY,row,column}}__name(getCoordByOffset,"getCoordByOffset");function getTransformCoord(evtOffsetX,evtOffsetY,scene,skeleton){const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords,viewMain),{scaleX,scaleY}=scene.getAncestorScale(),{x:scrollX,y:scrollY}=scrollXY,offsetX=evtOffsetX/scaleX+scrollX,offsetY=evtOffsetY/scaleY+scrollY;return{x:offsetX,y:offsetY}}__name(getTransformCoord,"getTransformCoord");var __defProp$P=Object.defineProperty,__getOwnPropDesc$P=Object.getOwnPropertyDescriptor,__decorateClass$P=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$P(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$P(target,key,result),result},"__decorateClass$P"),__decorateParam$P=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$P");const SHEET_NAVIGATION_COMMANDS$1=[MoveSelectionCommand.id,MoveSelectionEnterAndTabCommand.id];var _a4;exports.SheetsScrollRenderController=(_a4=class extends core.Disposable{constructor(_context,_injector,_sheetSkeletonManagerService,_contextService,_commandService,_renderManagerService,_scrollManagerService){super(),this._context=_context,this._injector=_injector,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._contextService=_contextService,this._commandService=_commandService,this._renderManagerService=_renderManagerService,this._scrollManagerService=_scrollManagerService,this._initCommandListener(),this._wheelEventListener(),this._scrollBarEventListener(),this._initSkeletonListener()}scrollToRange(range){let{endRow,endColumn,startColumn,startRow}=range;const bounding=this._getViewportBounding();if(range.rangeType===core.RANGE_TYPE.ROW?(startColumn=0,endColumn=0):range.rangeType===core.RANGE_TYPE.COLUMN&&(startRow=0,endRow=0),bounding){const row=bounding.startRow>endRow?startRow:endRow,col=bounding.startColumn>endColumn?startColumn:endColumn;return this._scrollToCell(row,col)}else return this._scrollToCell(startRow,startColumn)}_initCommandListener(){this.disposeWithMe(this._commandService.onCommandExecuted(command=>{if(SHEET_NAVIGATION_COMMANDS$1.includes(command.id))this._scrollToSelection();else if(command.id===sheets.ScrollToCellOperation.id){const param=command.params;this.scrollToRange(param)}else if(command.id===ExpandSelectionCommand.id){const param=command.params;this._scrollToSelectionForExpand(param)}else command.id===sheets.SetSelectionsOperation.id&&command.params.reveal&&this._scrollToSelection()}))}_scrollToSelectionForExpand(param){setTimeout(()=>{const selection=this._getSelectionsService().getCurrentLastSelection();if(selection==null)return;const{startRow,startColumn,endRow,endColumn}=selection.range,bounds=this._getViewportBounding();if(bounds==null)return;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;startRow>viewportStartRow?row=endRow:endRow<viewportEndRow?row=startRow:row=viewportStartRow,startColumn>viewportStartColumn?column=endColumn:endColumn<viewportEndColumn?column=startColumn:column=viewportStartColumn,param.direction===core.Direction.DOWN?row=endRow:param.direction===core.Direction.UP?row=startRow:param.direction===core.Direction.RIGHT?column=endColumn:param.direction===core.Direction.LEFT&&(column=startColumn),this._scrollToCell(row,column)},0)}_getFreeze(){var _a58;const snapshot=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton.getWorksheetConfig();if(snapshot!=null)return snapshot.freeze}_wheelEventListener(){const{scene}=this._context;if(!scene)return;const viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);viewMain&&this.disposeWithMe(scene.onMouseWheel$.subscribeEvent((evt,state)=>{if(evt.ctrlKey||!this._contextService.getContextValue(core.FOCUSING_SHEET))return;let offsetX=0,offsetY=0;const isLimitedStore=viewMain.limitedScroll();if(evt.inputIndex===engineRender.PointerInput.MouseWheelX){const scrollNum=Math.abs(evt.deltaX);offsetX=evt.deltaX>0?scrollNum:-scrollNum,this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetX}),scene.getParent().classType===engineRender.RENDER_CLASS_TYPE.SCENE_VIEWER?isLimitedStore!=null&&isLimitedStore.isLimitedX||state.stopPropagation():viewMain.isWheelPreventDefaultX?evt.preventDefault():isLimitedStore!=null&&isLimitedStore.isLimitedX||evt.preventDefault()}if(evt.inputIndex===engineRender.PointerInput.MouseWheelY){let scrollNum=Math.abs(evt.deltaY);evt.shiftKey?(scrollNum*=3,evt.deltaY>0?offsetX=scrollNum:offsetX=-scrollNum,this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetX}),scene.getParent().classType===engineRender.RENDER_CLASS_TYPE.SCENE_VIEWER?isLimitedStore!=null&&isLimitedStore.isLimitedX||state.stopPropagation():viewMain.isWheelPreventDefaultX?evt.preventDefault():isLimitedStore!=null&&isLimitedStore.isLimitedX||evt.preventDefault()):(offsetY=evt.deltaY>0?scrollNum:-scrollNum,this._commandService.executeCommand(SetScrollRelativeCommand.id,{offsetY}),scene.getParent().classType===engineRender.RENDER_CLASS_TYPE.SCENE_VIEWER?isLimitedStore!=null&&isLimitedStore.isLimitedY||state.stopPropagation():viewMain.isWheelPreventDefaultY?evt.preventDefault():isLimitedStore!=null&&isLimitedStore.isLimitedY||evt.preventDefault())}this._context.scene.makeDirty(!0)}))}_scrollBarEventListener(){const{scene}=this._context;if(scene==null)return;const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);viewportMain&&(this.disposeWithMe(core.toDisposable(this._scrollManagerService.rawScrollInfo$.subscribe(rawScrollInfo=>{var _a58;const skeleton=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton;if(!skeleton)return;if(rawScrollInfo==null){viewportMain.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});return}const{sheetViewStartRow,sheetViewStartColumn,offsetX,offsetY}=rawScrollInfo,{startX,startY}=skeleton.getCellByIndexWithNoHeader(sheetViewStartRow,sheetViewStartColumn),viewportScrollX=startX+offsetX,viewportScrollY=startY+offsetY;viewportMain.scrollToViewportPos({viewportScrollX,viewportScrollY})}))),this.disposeWithMe(viewportMain.onScrollAfter$.subscribeEvent(scrollAfterParam=>{var _a58;const skeleton=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton;if(skeleton==null||scrollAfterParam.isTrigger===!1)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX,viewportScrollY,scrollX,scrollY}=scrollAfterParam,{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY),scrollInfo={sheetViewStartRow:row,sheetViewStartColumn:column,offsetX:columnOffset,offsetY:rowOffset};this._scrollManagerService.setScrollStateToCurrSheet(scrollInfo),this._scrollManagerService.validViewportScrollInfo$.next({...scrollInfo,viewportScrollX,viewportScrollY,scrollX,scrollY})})),this.disposeWithMe(viewportMain.onScrollByBar$.subscribeEvent(param=>{var _a58;const skeleton=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton;if(skeleton==null||param.isTrigger===!1)return;const sheetObject=this._getSheetObject();if(skeleton==null||sheetObject==null)return;const{viewportScrollX=0,viewportScrollY=0}=param,freeze=this._getFreeze(),{row,column,rowOffset,columnOffset}=skeleton.getDecomposedOffset(viewportScrollX,viewportScrollY);this._commandService.executeCommand(ScrollCommand.id,{sheetViewStartRow:row+((freeze==null?void 0:freeze.ySplit)||0),sheetViewStartColumn:column+((freeze==null?void 0:freeze.xSplit)||0),offsetX:columnOffset,offsetY:rowOffset})})))}_initSkeletonListener(){this.disposeWithMe(core.toDisposable(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(param=>{if(param==null)return;const scrollParam={unitId:param.unitId,sheetId:param.sheetId};this._scrollManagerService.setSearchParam(scrollParam);const sheetObject=this._getSheetObject();if(!sheetObject)return;const viewportMain=sheetObject.scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),currScrollInfo=this._scrollManagerService.getScrollStateByParam(scrollParam),{viewportScrollX,viewportScrollY}=this._scrollManagerService.calcViewportScrollFromRowColOffset(currScrollInfo);viewportMain&&(currScrollInfo?(viewportMain.viewportScrollX=viewportScrollX,viewportMain.viewportScrollY=viewportScrollY):(viewportMain.viewportScrollX=0,viewportMain.viewportScrollY=0),this._updateSceneSize(param))})))}_updateSceneSize(param){var _a58;if(param==null)return;const{unitId}=this._context,{skeleton}=param,scene=(_a58=this._renderManagerService.getRenderById(unitId))==null?void 0:_a58.scene;if(skeleton==null||scene==null)return;const{rowTotalHeight,columnTotalWidth,rowHeaderWidthAndMarginLeft,columnHeaderHeightAndMarginTop}=skeleton,worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const zoomRatio=worksheet.getZoomRatio()||1;scene==null||scene.setScaleValue(zoomRatio,zoomRatio),scene==null||scene.transformByState({width:rowHeaderWidthAndMarginLeft+columnTotalWidth,height:columnHeaderHeightAndMarginTop+rowTotalHeight})}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}_scrollToSelectionByDirection(range){const bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let row=0,column=0;const{startRow,startColumn,endRow,endColumn}=range;startRow>=viewportStartRow&&(row=endRow),endRow<=viewportEndRow&&(row=startRow),startColumn>=viewportStartColumn&&(column=endColumn),endColumn<=viewportEndColumn&&(column=startColumn),this._scrollToCell(row,column)}_scrollToSelection(targetIsActualRowAndColumn=!0){const selection=this._getSelectionsService().getCurrentLastSelection();if(!selection)return;const{startRow,startColumn,actualRow,actualColumn}=selection.primary,selectionStartRow=targetIsActualRowAndColumn?actualRow:startRow,selectionStartColumn=targetIsActualRowAndColumn?actualColumn:startColumn;this._scrollToCell(selectionStartRow,selectionStartColumn)}_getSelectionsService(){return sheets.getSelectionsService(this._injector)}_getViewportBounding(){var _a58,_b;const scene=(_a58=this._getSheetObject())==null?void 0:_a58.scene;if(scene==null)return;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null)return;const skeleton=(_b=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_b.skeleton;if(skeleton==null)return;const bounds=viewport.getBounding();return skeleton.getRowColumnSegmentByViewBound(bounds.viewBound)}_scrollToCell(row,column){var _a58,_b,_c,_d;const{rowHeightAccumulation,columnWidthAccumulation}=(_b=(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton)!=null?_b:{};if(rowHeightAccumulation==null||columnWidthAccumulation==null)return!1;const scene=(_c=this._getSheetObject())==null?void 0:_c.scene;if(scene==null)return!1;const viewport=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(viewport==null||((_d=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_d.skeleton)==null)return!1;const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return!1;const{startColumn:freezeStartColumn,startRow:freezeStartRow,ySplit:freezeYSplit,xSplit:freezeXSplit}=worksheet.getFreeze(),bounds=this._getViewportBounding();if(bounds==null)return!1;const{startRow:viewportStartRow,startColumn:viewportStartColumn,endRow:viewportEndRow,endColumn:viewportEndColumn}=bounds;let startSheetViewRow,startSheetViewColumn;if(row>=freezeStartRow&&column>=freezeStartColumn-freezeXSplit&&(row<=viewportStartRow&&(startSheetViewRow=row),row>=viewportEndRow)){const minRowAccumulation=rowHeightAccumulation[row]-viewport.height;for(let r2=viewportStartRow;r2<=row;r2++)if(rowHeightAccumulation[r2]>=minRowAccumulation){startSheetViewRow=r2+1;break}}if(column>=freezeStartColumn&&row>=freezeStartRow-freezeYSplit&&(column<=viewportStartColumn&&(startSheetViewColumn=column),column>=viewportEndColumn)){const minColumnAccumulation=columnWidthAccumulation[column]-viewport.width;for(let c=viewportStartColumn;c<=column;c++)if(columnWidthAccumulation[c]>=minColumnAccumulation){startSheetViewColumn=c+1;break}}if(startSheetViewRow===void 0&&startSheetViewColumn===void 0)return!1;const{offsetX,offsetY}=this._scrollManagerService.getCurrentScrollState()||{};return startSheetViewRow=startSheetViewRow&&Math.min(startSheetViewRow,row),startSheetViewColumn=startSheetViewColumn&&Math.min(startSheetViewColumn,column),this._commandService.syncExecuteCommand(ScrollCommand.id,{sheetViewStartRow:startSheetViewRow,sheetViewStartColumn:startSheetViewColumn,offsetX:startSheetViewColumn===void 0?offsetX:0,offsetY:startSheetViewRow===void 0?offsetY:0})}},__name(_a4,"SheetsScrollRenderController"),_a4);exports.SheetsScrollRenderController=__decorateClass$P([__decorateParam$P(1,core.Inject(core.Injector)),__decorateParam$P(2,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$P(3,core.IContextService),__decorateParam$P(4,core.ICommandService),__decorateParam$P(5,engineRender.IRenderManagerService),__decorateParam$P(6,core.Inject(SheetScrollManagerService))],exports.SheetsScrollRenderController);function getActiveSheet$(univerInstanceService){return univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.switchMap(workbook=>workbook?workbook.activeSheet$.pipe(rxjs.map(worksheet=>worksheet?{workbook,worksheet}:null)):rxjs.of(null)))}__name(getActiveSheet$,"getActiveSheet$");function deriveStateFromActiveSheet$(univerInstanceService,defaultValue,callback){return getActiveSheet$(univerInstanceService).pipe(rxjs.switchMap(active=>active?callback(active):rxjs.of(defaultValue)))}__name(deriveStateFromActiveSheet$,"deriveStateFromActiveSheet$");function getCurrentExclusiveRangeInterest$(accessor,disableGroupSet){const univerInstanceService=accessor.get(core.IUniverInstanceService),exclusiveRangeService=accessor.get(sheets.IExclusiveRangeService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.switchMap(workbook=>workbook?rxjs.combineLatest([selectionManagerService.selectionMoveEnd$,workbook.activeSheet$]).pipe(rxjs.switchMap(([selections,worksheet])=>{if(!worksheet||selections.length===0)return rxjs.of(!1);const interestGroupIds=exclusiveRangeService.getInterestGroupId(selections);if(disableGroupSet){const disableGroup=interestGroupIds.filter(groupId=>disableGroupSet.has(groupId));return rxjs.of(disableGroup.length>0)}else return rxjs.of(interestGroupIds.length>0)})):rxjs.of(!1)))}__name(getCurrentExclusiveRangeInterest$,"getCurrentExclusiveRangeInterest$");function getObservableWithExclusiveRange$(accessor,observable$,disableGroupSet){return rxjs.combineLatest([observable$,getCurrentExclusiveRangeInterest$(accessor,disableGroupSet)]).pipe(rxjs.map(([observable,exclusiveRangeDisable])=>observable||exclusiveRangeDisable))}__name(getObservableWithExclusiveRange$,"getObservableWithExclusiveRange$");function getCurrentRangeDisable$(accessor,permissionTypes={}){const workbook$=accessor.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([userManagerService.currentUser$,workbook$]).pipe(rxjs.switchMap(([_,workbook])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{if(!worksheet)return rxjs.of(!0);const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),focusedOnDrawing$=accessor.get(core.IContextService).subscribeContextValue$(core.FOCUSING_COMMON_DRAWINGS).pipe(rxjs.startWith(!1));return rxjs.combineLatest([selectionManagerService.selectionMoveEnd$,focusedOnDrawing$]).pipe(rxjs.switchMap(([selection,focusOnDrawings])=>{if(focusOnDrawings)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionService=accessor.get(core.IPermissionService),{workbookTypes=[sheets.WorkbookEditablePermission],worksheetTypes,rangeTypes}=permissionTypes,permissionIds=[];if(workbookTypes==null||workbookTypes.forEach(F=>{permissionIds.push(new F(unitId).id)}),worksheetTypes==null||worksheetTypes.forEach(F=>{permissionIds.push(new F(unitId,subUnitId).id)}),worksheetRuleModel.getRule(unitId,subUnitId))return permissionService.composePermission$(permissionIds).pipe(rxjs.map(list=>list.some(item=>item.value===!1)));const selectionRanges=selection==null?void 0:selection.map(selection2=>selection2.range),rules=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>selectionRanges==null?void 0:selectionRanges.some(range=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(range,ruleRange))));return rangeTypes==null||rangeTypes.forEach(F=>{rules.forEach(rule=>{permissionIds.push(new F(unitId,subUnitId,rule.permissionId).id)})}),permissionService.composePermission$(permissionIds).pipe(rxjs.map(list=>list.some(item=>item.value===!1)))}))})):rxjs.of(!0)))}__name(getCurrentRangeDisable$,"getCurrentRangeDisable$");function getBaseRangeMenuHidden$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id];return rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(range,ruleRange))).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getBaseRangeMenuHidden$,"getBaseRangeMenuHidden$");function getInsertAfterMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id];return rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>type==="row"?rule.ranges.some(ruleRange=>range.endRow>ruleRange.startRow&&range.endRow<=ruleRange.endRow):rule.ranges.some(ruleRange=>range.endColumn>ruleRange.startColumn&&range.endColumn<=ruleRange.endColumn)).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getInsertAfterMenuHidden$,"getInsertAfterMenuHidden$");function getInsertBeforeMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id];return rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>type==="row"?rule.ranges.some(ruleRange=>range.startRow>ruleRange.startRow&&range.startRow<=ruleRange.endRow):rule.ranges.some(ruleRange=>range.startColumn>ruleRange.startColumn&&range.startColumn<=ruleRange.endColumn)).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getInsertBeforeMenuHidden$,"getInsertBeforeMenuHidden$");function getDeleteMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id],rowColRangeExpand=core.Tools.deepClone(range);return type==="row"?(rowColRangeExpand.startColumn=0,rowColRangeExpand.endColumn=worksheet.getColumnCount()-1):(rowColRangeExpand.startRow=0,rowColRangeExpand.endRow=worksheet.getRowCount()-1),rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(rowColRangeExpand,ruleRange))).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getDeleteMenuHidden$,"getDeleteMenuHidden$");function getCellMenuHidden$(accessor,type){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,permissionService.permissionPointUpdate$.pipe(rxjs.debounceTime(100))).pipe(rxjs.map(()=>{var _a58;const range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!range)return!0;const workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!workbook||!worksheet)return!0;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),permissionIds=[new sheets.WorkbookEditablePermission(unitId).id,new sheets.WorksheetEditPermission(unitId,subUnitId).id],rowColRangeExpand=core.Tools.deepClone(range);return type==="row"?rowColRangeExpand.endRow=worksheet.getRowCount()-1:rowColRangeExpand.endColumn=worksheet.getColumnCount()-1,rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).filter(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(rowColRangeExpand,ruleRange))).forEach(rule=>{permissionIds.push(new sheets.RangeProtectionPermissionEditPoint(unitId,subUnitId,rule.permissionId).id)}),permissionService.composePermission(permissionIds).some(item=>item.value===!1)}))}__name(getCellMenuHidden$,"getCellMenuHidden$");function getWorkbookPermissionDisable$(accessor,workbookPermissionTypes){const workbook$=accessor.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),permissionService=accessor.get(core.IPermissionService),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([userManagerService.currentUser$,workbook$]).pipe(rxjs.switchMap(([_user,workbook])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(activeSheet=>{var _a58,_b;if(!activeSheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),workbookPermissionIds=[];workbookPermissionTypes.forEach(F=>workbookPermissionIds.push(new F(unitId).id));const workbookPermission$=permissionService.composePermission$(workbookPermissionIds).pipe(rxjs.map(list=>list.every(item=>item.value===!0))),workbookManageCollaboratorPermission$=(_b=(_a58=permissionService.getPermissionPoint$(new sheets.WorkbookManageCollaboratorPermission(unitId).id))==null?void 0:_a58.pipe(rxjs.map(permission=>permission.value)))!=null?_b:rxjs.of(!1);return rxjs.combineLatest([workbookPermission$,workbookManageCollaboratorPermission$]).pipe(rxjs.map(([basePermission,manageable])=>{if(!basePermission)return!0;const subUnitId=activeSheet.getSheetId(),worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId),worksheetRuleList=selectionRuleModel.getSubunitRuleList(unitId,subUnitId);return worksheetRule||worksheetRuleList.length?!manageable:!1}))})):rxjs.of(!0)))}__name(getWorkbookPermissionDisable$,"getWorkbookPermissionDisable$");var __defProp$O=Object.defineProperty,__getOwnPropDesc$O=Object.getOwnPropertyDescriptor,__decorateClass$O=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$O(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$O(target,key,result),result},"__decorateClass$O"),__decorateParam$O=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$O");const SHEET_MAIN_CANVAS_ID="univer-sheet-main-canvas";var _a5;exports.SheetsRenderService=(_a5=class extends core.RxDisposable{constructor(_contextService,_instanceSrv,_renderManagerService){super();__publicField(this,"_skeletonChangeMutations",new Set);this._contextService=_contextService,this._instanceSrv=_instanceSrv,this._renderManagerService=_renderManagerService,Promise.resolve().then(()=>this._init())}registerSkeletonChangingMutations(mutationId){return this._skeletonChangeMutations.has(mutationId)?core.toDisposable(()=>{}):(this._skeletonChangeMutations.add(mutationId),core.toDisposable(()=>this._skeletonChangeMutations.delete(mutationId)))}checkMutationShouldTriggerRerender(id){return this._skeletonChangeMutations.has(id)}_init(){this._initWorkbookListener(),this._initContextListener()}_initWorkbookListener(){this._instanceSrv.getTypeOfUnitAdded$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.takeUntil(this.dispose$)).subscribe(workbook=>{this._createRenderer(workbook)}),this._instanceSrv.getAllUnitsForType(core.UniverInstanceType.UNIVER_SHEET).forEach(workbook=>this._createRenderer(workbook)),this._instanceSrv.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).pipe(rxjs.takeUntil(this.dispose$)).subscribe(workbook=>this._disposeRenderer(workbook))}_createRenderer(workbook){const unitId=workbook.getUnitId();this._renderManagerService.created$.subscribe(renderer=>{renderer.unitId===unitId&&renderer.engine.getCanvas().setId(SHEET_MAIN_CANVAS_ID)}),this._renderManagerService.createRender(unitId),this._renderManagerService.setCurrent(unitId)}_disposeRenderer(workbook){const unitId=workbook.getUnitId();this._renderManagerService.removeRender(unitId)}_initContextListener(){this._contextService.subscribeContextValue$(engineRender.RENDER_RAW_FORMULA_KEY).pipe(rxjs.distinctUntilChanged(),rxjs.takeUntil(this.dispose$)).subscribe(()=>{this._renderManagerService.getRenderAll().forEach(renderer=>{renderer.mainComponent instanceof engineRender.Spreadsheet&&renderer.mainComponent.makeForceDirty(!0)})})}},__name(_a5,"SheetsRenderService"),_a5);exports.SheetsRenderService=__decorateClass$O([__decorateParam$O(0,core.IContextService),__decorateParam$O(1,core.IUniverInstanceService),__decorateParam$O(2,engineRender.IRenderManagerService)],exports.SheetsRenderService);const RANGE_MOVE_PERMISSION_CHECK=core.createInterceptorKey("rangeMovePermissionCheck"),RANGE_FILL_PERMISSION_CHECK=core.createInterceptorKey("rangeFillPermissionCheck");var SELECTION_SHAPE_DEPTH=(SELECTION_SHAPE_DEPTH2=>(SELECTION_SHAPE_DEPTH2[SELECTION_SHAPE_DEPTH2.FORMULA_EDITOR_SHOW=100]="FORMULA_EDITOR_SHOW",SELECTION_SHAPE_DEPTH2[SELECTION_SHAPE_DEPTH2.MARK_SELECTION=1e4]="MARK_SELECTION",SELECTION_SHAPE_DEPTH2))(SELECTION_SHAPE_DEPTH||{});const _SelectionRenderModel=class _SelectionRenderModel{constructor(){__publicField(this,"_startColumn",-1);__publicField(this,"_startRow",-1);__publicField(this,"_endColumn",-1);__publicField(this,"_endRow",-1);__publicField(this,"_startX",0);__publicField(this,"_startY",0);__publicField(this,"_endX",0);__publicField(this,"_endY",0);__publicField(this,"_primary");__publicField(this,"_rangeType",core.RANGE_TYPE.NORMAL)}get startColumn(){return this._startColumn}get startRow(){return this._startRow}get endColumn(){return this._endColumn}get endRow(){return this._endRow}get startX(){return this._startX}get startY(){return this._startY}get endX(){return this._endX}get endY(){return this._endY}get currentCell(){return this._primary}get rangeType(){return this._rangeType}isEqual(rangeWithCoord){const{startColumn,startRow,endColumn,endRow}=this,{startColumn:newStartColumn,startRow:newStartRow,endColumn:newEndColumn,endRow:newEndRow}=rangeWithCoord;return startColumn===newStartColumn&&startRow===newStartRow&&endColumn===newEndColumn&&endRow===newEndRow}isInclude(rangeWithCoord){const{startColumn,startRow,endColumn,endRow}=this,{startColumn:newStartColumn,startRow:newStartRow,endColumn:newEndColumn,endRow:newEndRow}=rangeWithCoord;return!(newEndColumn<startColumn||newStartColumn>endColumn||newStartRow>endRow||newEndRow<startRow)}highlightToSelection(){if(this._primary)return core.makeCellToSelection(this._primary)}getRange(){return{startColumn:this._startColumn,startRow:this._startRow,endColumn:this._endColumn,endRow:this._endRow,startX:this._startX,startY:this._startY,endX:this._endX,endY:this._endY,rangeType:this.rangeType}}getCell(){return this._primary}getRangeType(){return this._rangeType}setRangeType(rangeType){this._rangeType=rangeType}getValue(){return{rangeWithCoord:this.getRange(),primaryWithCoord:this._primary}}setValue(newSelectionRange,currentCell){const{startColumn,startRow,endColumn,endRow,startX,startY,endX,endY,rangeType}=newSelectionRange;this._startColumn=startColumn,this._startRow=startRow,this._endColumn=endColumn,this._endRow=endRow,this._startX=startX,this._startY=startY,this._endX=endX,this._endY=endY,rangeType!==void 0&&(this._rangeType=rangeType),this.setCurrentCell(currentCell)}setCurrentCell(currentCell){currentCell&&(this._primary=currentCell)}clearCurrentCell(){this._primary=null}};__name(_SelectionRenderModel,"SelectionRenderModel");let SelectionRenderModel=_SelectionRenderModel;var SELECTION_MANAGER_KEY=(SELECTION_MANAGER_KEY2=>(SELECTION_MANAGER_KEY2.Selection="__SpreadsheetSelectionShape__",SELECTION_MANAGER_KEY2.top="__SpreadsheetSelectionTopControl__",SELECTION_MANAGER_KEY2.bottom="__SpreadsheetSelectionBottomControl__",SELECTION_MANAGER_KEY2.left="__SpreadsheetSelectionShapeLeftControl__",SELECTION_MANAGER_KEY2.right="__SpreadsheetSelectionShapeRightControl__",SELECTION_MANAGER_KEY2.backgroundTop="__SpreadsheetSelectionBackgroundControlTop__",SELECTION_MANAGER_KEY2.backgroundMiddleLeft="__SpreadsheetSelectionBackgroundControlMiddleLeft__",SELECTION_MANAGER_KEY2.backgroundMiddleRight="__SpreadsheetSelectionBackgroundControlMiddleRight__",SELECTION_MANAGER_KEY2.backgroundBottom="__SpreadsheetSelectionBackgroundControlBottom__",SELECTION_MANAGER_KEY2.fill="__SpreadsheetSelectionFillControl__",SELECTION_MANAGER_KEY2.fillTopLeft="__SpreadsheetSelectionFillControlTopLeft__",SELECTION_MANAGER_KEY2.fillBottomRight="__SpreadsheetSelectionFillControlBottomRight__",SELECTION_MANAGER_KEY2.fillTopLeftInner="__SpreadsheetSelectionFillControlTopLeftInner__",SELECTION_MANAGER_KEY2.fillBottomRightInner="__SpreadsheetSelectionFillControlBottomRightInner__",SELECTION_MANAGER_KEY2.lineMain="__SpreadsheetDragLineMainControl__",SELECTION_MANAGER_KEY2.lineContent="__SpreadsheetDragLineContentControl__",SELECTION_MANAGER_KEY2.line="__SpreadsheetDragLineControl__",SELECTION_MANAGER_KEY2.dash="__SpreadsheetDragDashControl__",SELECTION_MANAGER_KEY2.rowHeaderBackground="__SpreadSheetSelectionRowHeaderBackground__",SELECTION_MANAGER_KEY2.rowHeaderBorder="__SpreadSheetSelectionRowHeaderBorder__",SELECTION_MANAGER_KEY2.rowHeaderGroup="__SpreadSheetSelectionRowHeaderGroup__",SELECTION_MANAGER_KEY2.columnHeaderBackground="__SpreadSheetSelectionColumnHeaderBackground__",SELECTION_MANAGER_KEY2.columnHeaderBorder="__SpreadSheetSelectionColumnHeaderBorder__",SELECTION_MANAGER_KEY2.columnHeaderGroup="__SpreadSheetSelectionColumnHeaderGroup__",SELECTION_MANAGER_KEY2.topLeftWidget="__SpreadSheetSelectionTopLeftWidget__",SELECTION_MANAGER_KEY2.topCenterWidget="__SpreadSheetSelectionTopCenterWidget__",SELECTION_MANAGER_KEY2.topRightWidget="__SpreadSheetSelectionTopRightWidget__",SELECTION_MANAGER_KEY2.middleLeftWidget="__SpreadSheetSelectionMiddleLeftWidget__",SELECTION_MANAGER_KEY2.middleRightWidget="__SpreadSheetSelectionMiddleRightWidget__",SELECTION_MANAGER_KEY2.bottomLeftWidget="__SpreadSheetSelectionBottomLeftWidget__",SELECTION_MANAGER_KEY2.bottomCenterWidget="__SpreadSheetSelectionBottomCenterWidget__",SELECTION_MANAGER_KEY2.bottomRightWidget="__SpreadSheetSelectionBottomRightWidget__",SELECTION_MANAGER_KEY2))(SELECTION_MANAGER_KEY||{});const SELECTION_TITLE_HIGHLIGHT_ALPHA=.3,_SelectionControl=class _SelectionControl extends core.Disposable{constructor(_scene,_zIndex,_themeService,_highlightHeader=!0,options){super();__publicField(this,"_leftBorder");__publicField(this,"_rightBorder");__publicField(this,"_topBorder");__publicField(this,"_bottomBorder");__publicField(this,"_backgroundControlTop");__publicField(this,"_backgroundControlBottom");__publicField(this,"_backgroundControlMiddleLeft");__publicField(this,"_backgroundControlMiddleRight");__publicField(this,"_fillControl");__publicField(this,"_selectionShapeGroup");__publicField(this,"_rowHeaderBackground");__publicField(this,"_rowHeaderBorder");__publicField(this,"_rowHeaderGroup");__publicField(this,"_columnHeaderBackground");__publicField(this,"_columnHeaderBorder");__publicField(this,"_columnHeaderGroup");__publicField(this,"_topLeftWidget");__publicField(this,"_topCenterWidget");__publicField(this,"_topRightWidget");__publicField(this,"_middleLeftWidget");__publicField(this,"_middleRightWidget");__publicField(this,"_bottomLeftWidget");__publicField(this,"_bottomCenterWidget");__publicField(this,"_bottomRightWidget");__publicField(this,"_dashedRect");__publicField(this,"_selectionModel");__publicField(this,"_defaultStyle");__publicField(this,"_currentStyle");__publicField(this,"_rowHeaderWidth",0);__publicField(this,"_columnHeaderHeight",0);__publicField(this,"_widgetRects",[]);__publicField(this,"_dispose$",new rxjs.BehaviorSubject(this));__publicField(this,"dispose$",this._dispose$.asObservable());__publicField(this,"selectionMoving$",new rxjs.Subject);__publicField(this,"selectionMoved$",new rxjs.Subject);__publicField(this,"selectionScaling$",new rxjs.Subject);__publicField(this,"selectionScaled$",new rxjs.Subject);__publicField(this,"selectionFilling$",new rxjs.Subject);__publicField(this,"_selectionFilled$",new rxjs.Subject);__publicField(this,"selectionFilled$",this._selectionFilled$.asObservable());__publicField(this,"_isHelperSelection",!0);__publicField(this,"_antLineOffset",0);__publicField(this,"_antRequestNewFrame",-1);this._scene=_scene,this._zIndex=_zIndex,this._themeService=_themeService,this._highlightHeader=_highlightHeader,this._rowHeaderWidth=(options==null?void 0:options.rowHeaderWidth)||0,this._columnHeaderHeight=(options==null?void 0:options.columnHeaderHeight)||0,this._initialize()}get zIndex(){return this._zIndex}get leftControl(){return this._leftBorder}get rightControl(){return this._rightBorder}get topControl(){return this._topBorder}get bottomControl(){return this._bottomBorder}get fillControl(){return this._fillControl}get backgroundControlTop(){return this._backgroundControlTop}get backgroundControlBottom(){return this._backgroundControlBottom}get backgroundControlMiddleLeft(){return this._backgroundControlMiddleLeft}get backgroundControlMiddleRight(){return this._backgroundControlMiddleRight}get selectionShape(){return this._selectionShapeGroup}get columnHeaderGroup(){return this._columnHeaderGroup}get rowHeaderGroup(){return this._rowHeaderGroup}get selectionShapeGroup(){return this._selectionShapeGroup}get model(){return this._selectionModel}get topLeftWidget(){return this._topLeftWidget}get topCenterWidget(){return this._topCenterWidget}get topRightWidget(){return this._topRightWidget}get middleLeftWidget(){return this._middleLeftWidget}get middleRightWidget(){return this._middleRightWidget}get bottomLeftWidget(){return this._bottomLeftWidget}get bottomCenterWidget(){return this._bottomCenterWidget}get bottomRightWidget(){return this._bottomRightWidget}get themeService(){return this._themeService}get selectionModel(){return this._selectionModel}set selectionModel(model){this._selectionModel=model}get defaultStyle(){return this._defaultStyle}set defaultStyle(style){this._defaultStyle=style}get dashedRect(){return this._dashedRect}get currentStyle(){return this._currentStyle}set currentStyle(style){style&&(this._currentStyle=style)}get isHelperSelection(){return this._isHelperSelection}get rowHeaderWidth(){return this._rowHeaderWidth}set rowHeaderWidth(width){this._rowHeaderWidth=width}get columnHeaderHeight(){return this._columnHeaderHeight}set columnHeaderHeight(height){this._columnHeaderHeight=height}setEvent(state){this.leftControl.evented=state,this.rightControl.evented=state,this.topControl.evented=state,this.bottomControl.evented=state}refreshSelectionFilled(val){this._selectionFilled$.next(val)}_setSizeAndStyleForSelectionControl(selectionStyle){this.currentStyle=selectionStyle;const defaultStyle=this._defaultStyle,currentStyle=this.currentStyle,{stroke=defaultStyle.stroke,widgets=defaultStyle.widgets,hasAutoFill=defaultStyle.hasAutoFill,AutofillStroke=defaultStyle.AutofillStroke,strokeDash,isAnimationDash}=currentStyle;let{strokeWidth=defaultStyle.strokeWidth,AutofillSize=defaultStyle.AutofillSize,AutofillStrokeWidth=defaultStyle.AutofillStrokeWidth}=currentStyle;const scale=this._getScale(),leftAdjustWidth=(strokeWidth+sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH)/2/scale;strokeWidth/=scale,AutofillSize/=scale,AutofillStrokeWidth/=scale<1?1:scale;const borderBuffer=sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH/scale,fixOnePixelBlurOffset=engineRender.FIX_ONE_PIXEL_BLUR_OFFSET/scale,{startX,startY,endX,endY}=this._selectionModel;if(this.leftControl.transformByState({height:endY-startY,left:-leftAdjustWidth+fixOnePixelBlurOffset,width:strokeWidth,strokeWidth:borderBuffer,top:-borderBuffer/2+fixOnePixelBlurOffset}),this.leftControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),this.rightControl.transformByState({height:endY-startY,left:endX-startX-leftAdjustWidth+fixOnePixelBlurOffset,width:strokeWidth,strokeWidth:borderBuffer,top:-borderBuffer/2+fixOnePixelBlurOffset}),this.rightControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),this.topControl.transformByState({width:endX-startX+strokeWidth,top:-leftAdjustWidth+fixOnePixelBlurOffset,left:-leftAdjustWidth+fixOnePixelBlurOffset,height:strokeWidth,strokeWidth:borderBuffer}),this.topControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),this.bottomControl.transformByState({width:endX-startX+strokeWidth,top:endY-startY-leftAdjustWidth+fixOnePixelBlurOffset,height:strokeWidth,left:-leftAdjustWidth+fixOnePixelBlurOffset,strokeWidth:borderBuffer}),this.bottomControl.setProps({fill:stroke,stroke:sheets.SELECTION_CONTROL_BORDER_BUFFER_COLOR}),strokeDash==null)this.dashedRect.hide(),this._stopAntLineAnimation();else{const dashRectBorderWidth=currentStyle.strokeWidth*2/scale;this.dashedRect.transformByState({height:endY-startY,width:endX-startX,strokeWidth:dashRectBorderWidth,left:-dashRectBorderWidth/2+fixOnePixelBlurOffset,top:-dashRectBorderWidth/2+fixOnePixelBlurOffset}),this.dashedRect.setProps({strokeDashArray:[0,strokeDash/scale]}),this._stopAntLineAnimation(),isAnimationDash!==!1&&this._startAntLineAnimation(),this.dashedRect.show()}if(hasAutoFill===!0&&!this._hasWidgets(widgets)){const fillProps={fill:stroke,stroke:AutofillStroke,strokeScaleEnabled:!1},sizeState={width:AutofillSize-AutofillStrokeWidth,height:AutofillSize-AutofillStrokeWidth,left:endX-startX-AutofillSize/2+AutofillStrokeWidth/2-fixOnePixelBlurOffset,top:endY-startY-AutofillSize/2+AutofillStrokeWidth/2-fixOnePixelBlurOffset,strokeWidth:AutofillStrokeWidth};this.fillControl.setProps(fillProps),this.fillControl.transformByState(sizeState),this.fillControl.show()}else this.fillControl.hide();this._updateBackgroundControl(selectionStyle),this._updateHeaderBackground(selectionStyle),this._updateWidgets(selectionStyle)}_refreshControlPosition(){const{startX,startY}=this._selectionModel;this.selectionShapeGroup.show(),this.selectionShapeGroup.translate(startX,startY),this.selectionShapeGroup.makeDirtyNoDebounce(!0)}updateStyle(style){this._setSizeAndStyleForSelectionControl(style),this._refreshControlPosition()}updateRange(range,primaryCell){this._selectionModel.setValue(range,primaryCell),this._setSizeAndStyleForSelectionControl(this._currentStyle),this._refreshControlPosition()}update(newSelectionRange,rowHeaderWidth=0,columnHeaderHeight=0,style,primaryCell){this._selectionModel.setValue(newSelectionRange,primaryCell),this._rowHeaderWidth=rowHeaderWidth,this._columnHeaderHeight=columnHeaderHeight,this._setSizeAndStyleForSelectionControl(style||this._currentStyle),this._refreshControlPosition()}updateCurrCell(primaryCell){this._selectionModel.setCurrentCell(primaryCell)}clearHighlight(){this._selectionModel.clearCurrentCell(),this._setSizeAndStyleForSelectionControl(this._currentStyle)}getScene(){return this._scene}dispose(){var _a58,_b,_c,_d,_e,_f,_g,_h,_i,_j,_k,_l,_m,_n,_o,_p,_q,_r,_s,_t,_u,_v,_w,_x;(_a58=this._leftBorder)==null||_a58.dispose(),(_b=this._rightBorder)==null||_b.dispose(),(_c=this._topBorder)==null||_c.dispose(),(_d=this._bottomBorder)==null||_d.dispose(),(_e=this._backgroundControlTop)==null||_e.dispose(),(_f=this._backgroundControlMiddleLeft)==null||_f.dispose(),(_g=this._backgroundControlMiddleRight)==null||_g.dispose(),(_h=this._backgroundControlBottom)==null||_h.dispose(),this._fillControl.dispose(),(_i=this._selectionShapeGroup)==null||_i.dispose(),(_j=this._rowHeaderBackground)==null||_j.dispose(),(_k=this._rowHeaderBorder)==null||_k.dispose(),(_l=this._rowHeaderGroup)==null||_l.dispose(),(_m=this._rowHeaderBackground)==null||_m.dispose(),(_n=this._columnHeaderBackground)==null||_n.dispose(),(_o=this._columnHeaderBorder)==null||_o.dispose(),(_p=this._columnHeaderGroup)==null||_p.dispose(),(_q=this._topLeftWidget)==null||_q.dispose(),(_r=this._topCenterWidget)==null||_r.dispose(),(_s=this._topRightWidget)==null||_s.dispose(),(_t=this._middleLeftWidget)==null||_t.dispose(),(_u=this._middleRightWidget)==null||_u.dispose(),(_v=this._bottomLeftWidget)==null||_v.dispose(),(_w=this._bottomCenterWidget)==null||_w.dispose(),(_x=this._bottomRightWidget)==null||_x.dispose(),super.dispose(),this._dispose$.next(this),this._dispose$.complete()}getCurrentCellInfo(){const currentCell=this.model.currentCell;if(currentCell){let currentRangeData;if(currentCell.isMerged){const mergeInfo=currentCell.mergeInfo;currentRangeData={startRow:mergeInfo.startRow,endRow:mergeInfo.endRow,startColumn:mergeInfo.startColumn,endColumn:mergeInfo.endColumn,startX:mergeInfo.startX,endX:mergeInfo.endX,startY:mergeInfo.startY,endY:mergeInfo.endY}}else{const{actualRow,actualColumn,startX,endX,startY,endY}=currentCell;currentRangeData={startRow:actualRow,endRow:actualRow,startColumn:actualColumn,endColumn:actualColumn,startX,endX,startY,endY}}return currentRangeData}}getValue(){return{...this._selectionModel.getValue(),style:this._currentStyle}}getRange(){return this._selectionModel.getValue().rangeWithCoord}enableHelperSelection(){this._isHelperSelection=!0}disableHelperSelection(){this._isHelperSelection=!1}_initialize(){this._defaultStyle=sheets.getNormalSelectionStyle(this._themeService),this._currentStyle=sheets.getNormalSelectionStyle(this._themeService),this._selectionModel=new SelectionRenderModel;const zIndex=this._zIndex;this._leftBorder=new engineRender.Rect("__SpreadsheetSelectionShapeLeftControl__"+zIndex,{zIndex}),this._rightBorder=new engineRender.Rect("__SpreadsheetSelectionShapeRightControl__"+zIndex,{zIndex}),this._topBorder=new engineRender.Rect("__SpreadsheetSelectionTopControl__"+zIndex,{zIndex}),this._bottomBorder=new engineRender.Rect("__SpreadsheetSelectionBottomControl__"+zIndex,{zIndex}),this._backgroundControlTop=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlTop__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._backgroundControlBottom=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlBottom__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._backgroundControlMiddleLeft=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlMiddleLeft__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._backgroundControlMiddleRight=new engineRender.Rect("__SpreadsheetSelectionBackgroundControlMiddleRight__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._fillControl=new engineRender.Rect("__SpreadsheetSelectionFillControl__"+zIndex,{zIndex:zIndex+1}),this._dashedRect=new engineRender.DashedRect("__SpreadsheetDragDashControl__"+zIndex,{zIndex:zIndex+2,evented:!1,stroke:"#fff"});const shapes=[this._fillControl,this._leftBorder,this._rightBorder,this._topBorder,this._bottomBorder,this._backgroundControlTop,this._backgroundControlMiddleLeft,this._backgroundControlMiddleRight,this._backgroundControlBottom,this._dashedRect];this._widgetRects=this._initialWidget(),this._selectionShapeGroup=new engineRender.Group("__SpreadsheetSelectionShape__"+zIndex,...shapes,...this._widgetRects),this._selectionShapeGroup.hide(),this._selectionShapeGroup.evented=!1,this._selectionShapeGroup.zIndex=zIndex;const scene=this.getScene();scene.addObject(this._selectionShapeGroup,SHEET_COMPONENT_SELECTION_LAYER_INDEX),this.disposeWithMe(core.toDisposable(scene.onTransformChange$.subscribeEvent(state=>{state.type===engineRender.TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale&&(this._setSizeAndStyleForSelectionControl(this._currentStyle),this._refreshControlPosition())}))),this._initialHeader()}_initialHeader(){const zIndex=this._zIndex;this._rowHeaderBackground=new engineRender.Rect("__SpreadSheetSelectionRowHeaderBackground__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._rowHeaderBorder=new engineRender.Rect("__SpreadSheetSelectionRowHeaderBorder__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._rowHeaderGroup=new engineRender.Group("__SpreadSheetSelectionRowHeaderGroup__"+zIndex,this._rowHeaderBackground,this._rowHeaderBorder),this._rowHeaderGroup.hide(),this._rowHeaderGroup.evented=!1,this._rowHeaderGroup.zIndex=zIndex,this._columnHeaderBackground=new engineRender.Rect("__SpreadSheetSelectionColumnHeaderBackground__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._columnHeaderBorder=new engineRender.Rect("__SpreadSheetSelectionColumnHeaderBorder__"+zIndex,{zIndex:zIndex-1,evented:!1}),this._columnHeaderGroup=new engineRender.Group("__SpreadSheetSelectionColumnHeaderGroup__"+zIndex,this._columnHeaderBackground,this._columnHeaderBorder),this._columnHeaderGroup.hide(),this._columnHeaderGroup.evented=!1,this._columnHeaderGroup.zIndex=zIndex,this.getScene().addObjects([this._rowHeaderGroup,this._columnHeaderGroup],SHEET_COMPONENT_HEADER_SELECTION_LAYER_INDEX)}_initialWidget(){const zIndex=this._zIndex;return this._topLeftWidget=new engineRender.Rect("__SpreadSheetSelectionTopLeftWidget__"+zIndex,{zIndex:zIndex+1}),this._topCenterWidget=new engineRender.Rect("__SpreadSheetSelectionTopCenterWidget__"+zIndex,{zIndex:zIndex+1}),this._topRightWidget=new engineRender.Rect("__SpreadSheetSelectionTopRightWidget__"+zIndex,{zIndex:zIndex+1}),this._middleLeftWidget=new engineRender.Rect("__SpreadSheetSelectionMiddleLeftWidget__"+zIndex,{zIndex:zIndex+1}),this._middleRightWidget=new engineRender.Rect("__SpreadSheetSelectionMiddleRightWidget__"+zIndex,{zIndex:zIndex+1}),this._bottomLeftWidget=new engineRender.Rect("__SpreadSheetSelectionBottomLeftWidget__"+zIndex,{zIndex:zIndex+1}),this._bottomCenterWidget=new engineRender.Rect("__SpreadSheetSelectionBottomCenterWidget__"+zIndex,{zIndex:zIndex+1}),this._bottomRightWidget=new engineRender.Rect("__SpreadSheetSelectionBottomRightWidget__"+zIndex,{zIndex:zIndex+1}),[this._topLeftWidget,this._topCenterWidget,this._topRightWidget,this._middleLeftWidget,this._middleRightWidget,this._bottomLeftWidget,this._bottomCenterWidget,this._bottomRightWidget]}_updateHeaderBackground(style){const{startX,startY,endX,endY,rangeType}=this._selectionModel,defaultStyle=this._defaultStyle;style==null&&(style=defaultStyle);const scale=this._getScale(),{stroke,hasRowHeader,rowHeaderFill=defaultStyle.rowHeaderFill,rowHeaderStroke=defaultStyle.rowHeaderStroke,hasColumnHeader,columnHeaderFill=defaultStyle.columnHeaderFill,columnHeaderStroke=defaultStyle.columnHeaderStroke}=style;let{rowHeaderStrokeWidth=defaultStyle.rowHeaderStrokeWidth,columnHeaderStrokeWidth=defaultStyle.columnHeaderStrokeWidth}=style;rowHeaderStrokeWidth/=scale,columnHeaderStrokeWidth/=scale;const rowHeaderWidth=this._rowHeaderWidth,columnHeaderHeight=this._columnHeaderHeight;if(hasColumnHeader===!0){let highlightTitleColor=columnHeaderFill;this._highlightHeader&&rangeType===core.RANGE_TYPE.COLUMN&&(highlightTitleColor=new core.ColorKit(stroke).setAlpha(SELECTION_TITLE_HIGHLIGHT_ALPHA).toString()),this._columnHeaderBackground.setProps({fill:highlightTitleColor}),this._columnHeaderBackground.resize(endX-startX,columnHeaderHeight),this._columnHeaderBorder.setProps({fill:columnHeaderStroke}),this._columnHeaderBorder.transformByState({width:endX-startX,height:columnHeaderStrokeWidth,top:columnHeaderHeight-columnHeaderStrokeWidth+1/scale}),this._columnHeaderGroup.show(),this._columnHeaderGroup.translate(startX,0)}else this._columnHeaderGroup.hide();if(this._columnHeaderGroup.makeDirty(!0),hasRowHeader===!0){let highlightTitleColor=rowHeaderFill;this._highlightHeader&&rangeType===core.RANGE_TYPE.ROW&&(highlightTitleColor=new core.ColorKit(stroke).setAlpha(SELECTION_TITLE_HIGHLIGHT_ALPHA).toString()),this._rowHeaderBackground.setProps({fill:highlightTitleColor}),this._rowHeaderBackground.resize(rowHeaderWidth,endY-startY),this._rowHeaderBorder.setProps({fill:rowHeaderStroke}),this._rowHeaderBorder.transformByState({width:rowHeaderStrokeWidth,height:endY-startY,left:rowHeaderWidth-rowHeaderStrokeWidth+1/scale}),this._rowHeaderGroup.show(),this._rowHeaderGroup.translate(0,startY)}else this._rowHeaderGroup.hide();this._rowHeaderGroup.makeDirty(!0)}_updateBackgroundControl(style){const{startX,startY,endX,endY}=this._selectionModel,defaultStyle=this._defaultStyle;style==null&&(style=defaultStyle);const scale=this._getScale(),{fill=defaultStyle.fill}=style;let{strokeWidth=defaultStyle.strokeWidth}=style;strokeWidth/=scale;const highlightSelection=this._selectionModel.highlightToSelection();if(!highlightSelection){this._backgroundControlTop.resize(endX-startX,endY-startY),this._backgroundControlTop.setProps({fill}),this._backgroundControlBottom.resize(0,0),this._backgroundControlMiddleLeft.resize(0,0),this._backgroundControlMiddleRight.resize(0,0);return}const{startX:h_startX,startY:h_startY,endX:h_endX,endY:h_endY}=highlightSelection,strokeOffset=strokeWidth/2,topConfig={left:-strokeOffset,top:-strokeOffset,width:endX-startX+strokeOffset*2,height:h_startY-startY+strokeOffset};topConfig.height<0&&(topConfig.width=0,topConfig.height=0),this._backgroundControlTop.transformByState(topConfig);const middleLeftConfig={left:-strokeOffset,top:h_startY-startY,width:h_startX-startX+strokeOffset,height:h_endY-h_startY};middleLeftConfig.width<0&&(middleLeftConfig.width=0,middleLeftConfig.height=0),this._backgroundControlMiddleLeft.transformByState(middleLeftConfig);const middleRightConfig={left:h_endX-startX-strokeOffset,top:h_startY-startY,width:endX-h_endX+strokeOffset*2,height:h_endY-h_startY};middleRightConfig.width<0&&(middleRightConfig.width=0,middleRightConfig.height=0),this._backgroundControlMiddleRight.transformByState(middleRightConfig);const middleBottomConfig={left:-strokeOffset,top:h_endY-startY,width:endX-startX+strokeOffset*2,height:endY-h_endY+strokeOffset};middleBottomConfig.height<0&&(middleBottomConfig.width=0,middleBottomConfig.height=0),this._backgroundControlBottom.transformByState(middleBottomConfig),this._backgroundControlTop.setProps({fill}),this._backgroundControlMiddleLeft.setProps({fill}),this._backgroundControlMiddleRight.setProps({fill}),this._backgroundControlBottom.setProps({fill})}_updateWidgets(style){const{startX,startY,endX,endY}=this._selectionModel,defaultStyle=this._defaultStyle;style==null&&(style=defaultStyle);const{stroke=defaultStyle.stroke,widgets=defaultStyle.widgets,widgetStroke=defaultStyle.widgetStroke}=style,scale=this._getScale();let{widgetSize=defaultStyle.widgetSize,widgetStrokeWidth=defaultStyle.widgetStrokeWidth}=style;widgetSize/=scale,widgetStrokeWidth/=scale;const position={left:-widgetSize/2+widgetStrokeWidth/2,center:(endX-startX)/2-widgetSize/2+widgetStrokeWidth/2,right:endX-startX-widgetSize/2+widgetStrokeWidth/2,top:-widgetSize/2,middle:(endY-startY)/2-widgetSize/2,bottom:endY-startY-widgetSize/2+widgetStrokeWidth/2},size=widgetSize-widgetStrokeWidth;this._widgetRects.forEach(widget=>{widget.setProps({fill:stroke,stroke:widgetStroke})}),widgets.tl===!0?(this._topLeftWidget.transformByState({height:size,width:size,left:position.left,top:position.top,strokeWidth:widgetStrokeWidth}),this._topLeftWidget.show()):this._topLeftWidget.hide(),widgets.tc===!0?(this._topCenterWidget.transformByState({height:size,width:size,left:position.center,top:position.top,strokeWidth:widgetStrokeWidth}),this._topCenterWidget.show()):this._topCenterWidget.hide(),widgets.tr===!0?(this._topRightWidget.transformByState({height:size,width:size,left:position.right,top:position.top,strokeWidth:widgetStrokeWidth}),this._topRightWidget.show()):this._topRightWidget.hide(),widgets.ml===!0?(this._middleLeftWidget.transformByState({height:size,width:size,left:position.left,top:position.middle,strokeWidth:widgetStrokeWidth}),this._middleLeftWidget.show()):this._middleLeftWidget.hide(),widgets.mr===!0?(this._middleRightWidget.transformByState({height:size,width:size,left:position.right,top:position.middle,strokeWidth:widgetStrokeWidth}),this._middleRightWidget.show()):this._middleRightWidget.hide(),widgets.bl===!0?(this._bottomLeftWidget.transformByState({height:size,width:size,left:position.left,top:position.bottom,strokeWidth:widgetStrokeWidth}),this._bottomLeftWidget.show()):this._bottomLeftWidget.hide(),widgets.bc===!0?(this._bottomCenterWidget.transformByState({height:size,width:size,left:position.center,top:position.bottom,strokeWidth:widgetStrokeWidth}),this._bottomCenterWidget.show()):this._bottomCenterWidget.hide(),widgets.br===!0?(this._bottomRightWidget.transformByState({height:size,width:size,left:position.right,top:position.bottom,strokeWidth:widgetStrokeWidth}),this._bottomRightWidget.show()):this._bottomRightWidget.hide()}_hasWidgets(widgets){if(widgets==null)return!1;const keys=Object.keys(widgets);if(keys.length===0)return!1;for(const key of keys)if(widgets[key]===!0)return!0;return!0}_getScale(){const{scaleX,scaleY}=this._scene.getAncestorScale();return Math.max(scaleX,scaleY)}_stopAntLineAnimation(){this._antLineOffset=0,engineRender.cancelRequestFrame(this._antRequestNewFrame)}_startAntLineAnimation(){const scale=this._getScale();this._antLineOffset+=.6/scale,this._antLineOffset>160/scale&&(this._antLineOffset=0),this.dashedRect.setProps({strokeDashOffset:-this._antLineOffset}),this._antRequestNewFrame=engineRender.requestNewFrame(()=>{this._startAntLineAnimation()})}};__name(_SelectionControl,"SelectionControl");let SelectionControl=_SelectionControl;const _SelectionLayer=class _SelectionLayer extends engineRender.Layer{render(ctx,isMaxLayer=!1){const startTime=core.Tools.now();return super.render(ctx,isMaxLayer),this._afterRender(startTime),this}_afterRender(startTime){this.scene.getEngine().renderFrameTimeMetric$.next(["selectionLayer",core.Tools.now()-startTime])}};__name(_SelectionLayer,"SelectionLayer");let SelectionLayer=_SelectionLayer;const HELPER_SELECTION_TEMP_NAME="__SpreadsheetHelperSelectionTempRect",SELECTION_CONTROL_DELETING_LIGHTEN=35,_SelectionShapeExtension=class _SelectionShapeExtension{constructor(_control,_skeleton,_scene,_themeService,_injector,_selectionHooks){__publicField(this,"_startOffsetX",0);__publicField(this,"_startOffsetY",0);__publicField(this,"_relativeSelectionPositionRow",0);__publicField(this,"_relativeSelectionPositionColumn",0);__publicField(this,"_relativeSelectionRowLength",0);__publicField(this,"_relativeSelectionColumnLength",0);__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_helperSelection");__publicField(this,"_scrollTimer");__publicField(this,"_activeViewport");__publicField(this,"_targetSelection",{startY:0,endY:0,startX:0,endX:0,startRow:-1,endRow:-1,startColumn:-1,endColumn:-1});__publicField(this,"_isInMergeState",!1);__publicField(this,"_fillControlColors",[]);this._control=_control,this._skeleton=_skeleton,this._scene=_scene,this._themeService=_themeService,this._injector=_injector,this._selectionHooks=_selectionHooks,this._initialControl(),this._initialWidget(),this._initialFill(),this._control.dispose$.subscribe(()=>{this.dispose()})}get isHelperSelection(){return this._control.isHelperSelection}dispose(){var _a58,_b;(_a58=this._scrollTimer)==null||_a58.dispose(),this._fillControlColors=[],this._clearObserverEvent(),(_b=this._helperSelection)==null||_b.dispose()}_getFreeze(){var _a58,_b;return(_b=(_a58=this._injector.get(engineRender.IRenderManagerService).withCurrentTypeOfUnit(core.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService))==null?void 0:_a58.getCurrent())==null?void 0:_b.skeleton.getWorksheetConfig().freeze}_isSelectionInViewport(selection,viewport){const freeze=this._getFreeze()||{startRow:-1,startColumn:-1,xSplit:0,ySplit:0};switch(viewport.viewportKey){case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN:return selection.endRow>=freeze.startRow&&selection.endColumn>=freeze.startColumn;case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP:case engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_RIGHT:return selection.endColumn>=freeze.startColumn&&selection.startRow<freeze.startRow;case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT:case engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_BOTTOM:return selection.endRow>=freeze.startRow&&selection.startColumn<freeze.startColumn;case engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP:case engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT:case engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP:case engineRender.SHEET_VIEWPORT_KEY.VIEW_LEFT_TOP:return selection.startRow<freeze.startRow&&selection.startColumn<freeze.startColumn}}_clearObserverEvent(){var _a58,_b;(_a58=this._scenePointerMoveSub)==null||_a58.unsubscribe(),(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerMoveSub=null,this._scenePointerUpSub=null}_initialControl(){const{leftControl,rightControl,topControl,bottomControl}=this._control;[leftControl,rightControl,topControl,bottomControl].forEach(control=>{control.onPointerEnter$.subscribeEvent(()=>{var _a58;((_a58=this._injector.get(ISheetSelectionRenderService,core.Quantity.OPTIONAL))==null?void 0:_a58.interceptor.fetchThroughInterceptors(RANGE_MOVE_PERMISSION_CHECK)(!1,null))!==!1&&control.setCursor(engineRender.CURSOR_TYPE.MOVE)}),control.onPointerLeave$.subscribeEvent(()=>{control.resetCursor()}),control.onPointerDown$.subscribeEvent(this._controlEvent.bind(this))})}_controlMoving(moveOffsetX,moveOffsetY){var _a58;const scene=this._scene,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY])),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=this._skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,maxRow=this._skeleton.getRowCount()-1,maxColumn=this._skeleton.getColumnCount()-1;let startRow=row+this._relativeSelectionPositionRow;startRow<0&&(startRow=0);let endRow=startRow+this._relativeSelectionRowLength;endRow>maxRow&&(endRow=maxRow,endRow-startRow<this._relativeSelectionRowLength&&(startRow=endRow-this._relativeSelectionRowLength));let startColumn=column+this._relativeSelectionPositionColumn;startColumn<0&&(startColumn=0);let endColumn=startColumn+this._relativeSelectionColumnLength;endColumn>maxColumn&&(endColumn=maxColumn,endColumn-startColumn<this._relativeSelectionColumnLength&&(startColumn=endColumn-this._relativeSelectionColumnLength));const startCell=this._skeleton.getNoMergeCellPositionByIndex(startRow,startColumn),endCell=this._skeleton.getNoMergeCellPositionByIndex(endRow,endColumn),startY=(startCell==null?void 0:startCell.startY)||0,endY=(endCell==null?void 0:endCell.endY)||0,startX=(startCell==null?void 0:startCell.startX)||0,endX=(endCell==null?void 0:endCell.endX)||0;(_a58=this._helperSelection)==null||_a58.transformByState({left:startX,top:startY,width:endX-startX,height:endY-startY}),this._targetSelection={startY,endY,startX,endX,startRow,endRow,startColumn,endColumn},this._control.selectionMoving$.next(this._targetSelection)}_controlEvent(evt){const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,scene=this._scene,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords,scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords),{scaleX,scaleY}=scene.getAncestorScale(),actualSelection=this._skeleton.getCellPositionByOffset(newEvtOffsetX,newEvtOffsetY,scaleX,scaleY,scrollXY);this._startOffsetX=newEvtOffsetX,this._startOffsetY=newEvtOffsetY;const{row,column}=actualSelection,{startRow:originStartRow,startColumn:originStartColumn,endRow:originEndRow,endColumn:originEndColumn}=this._control.model;let fixRow=0,fixColumn=0;row<originStartRow?fixRow-=1:row>originEndRow&&(fixRow+=1),column<originStartColumn?fixColumn-=1:column>originEndColumn&&(fixColumn+=1),this._relativeSelectionPositionRow=originStartRow-row+fixRow,this._relativeSelectionPositionColumn=originStartColumn-column+fixColumn,this._relativeSelectionRowLength=originEndRow-originStartRow,this._relativeSelectionColumnLength=originEndColumn-originStartColumn;const style=this._control.currentStyle,scale=this._getScale();this.isHelperSelection&&(this._helperSelection=new engineRender.Rect(HELPER_SELECTION_TEMP_NAME,{stroke:style.stroke,strokeWidth:style.strokeWidth/scale}),scene.addObject(this._helperSelection));const viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollTimer=engineRender.ScrollTimer.create(scene);this._scrollTimer=scrollTimer,scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY,viewMain),scene.disableObjectsEvent(),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a58;const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt;if(((_a58=this._injector.get(ISheetSelectionRenderService,core.Quantity.OPTIONAL))==null?void 0:_a58.interceptor.fetchThroughInterceptors(RANGE_MOVE_PERMISSION_CHECK)(!1,null))===!1)return;const{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._controlMoving(newMoveOffsetX,newMoveOffsetY),scene.setCursor(engineRender.CURSOR_TYPE.MOVE),scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._controlMoving(newMoveOffsetX,newMoveOffsetY)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a58,_b,_c,_d;(_a58=this._helperSelection)==null||_a58.dispose();const scene2=this._scene;scene2.resetCursor(),this._clearObserverEvent(),scene2.enableObjectsEvent(),(_b=this._scrollTimer)==null||_b.dispose(),this._control.selectionMoved$.next(this._targetSelection),(_d=(_c=this._selectionHooks).selectionMoveEnd)==null||_d.call(_c)})}_initialWidget(){const{topLeftWidget,topCenterWidget,topRightWidget,middleLeftWidget,middleRightWidget,bottomLeftWidget,bottomCenterWidget,bottomRightWidget}=this._control,cursors=[engineRender.CURSOR_TYPE.NORTH_WEST_RESIZE,engineRender.CURSOR_TYPE.NORTH_RESIZE,engineRender.CURSOR_TYPE.NORTH_EAST_RESIZE,engineRender.CURSOR_TYPE.WEST_RESIZE,engineRender.CURSOR_TYPE.EAST_RESIZE,engineRender.CURSOR_TYPE.SOUTH_WEST_RESIZE,engineRender.CURSOR_TYPE.SOUTH_RESIZE,engineRender.CURSOR_TYPE.SOUTH_EAST_RESIZE];[topLeftWidget,topCenterWidget,topRightWidget,middleLeftWidget,middleRightWidget,bottomLeftWidget,bottomCenterWidget,bottomRightWidget].forEach((control,index)=>{control.onPointerEnter$.subscribeEvent(()=>{control.setCursor(cursors[index])}),control.onPointerLeave$.subscribeEvent(()=>{control.resetCursor()}),control.onPointerDown$.subscribeEvent(evt=>{this._widgetPointerDownEvent(evt,cursors[index])})})}_widgetPointerDownEvent(evt,cursor){const scene=this._scene,{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords;this._startOffsetX=evtOffsetX,this._startOffsetY=evtOffsetY;const{startRow:originStartRow,startColumn:originStartColumn,endRow:originEndRow,endColumn:originEndColumn}=this._control.model,startRow=Math.min(originStartRow,originEndRow),startColumn=Math.min(originStartColumn,originEndColumn),endRow=Math.max(originStartRow,originEndRow),endColumn=Math.max(originStartColumn,originEndColumn);this._relativeSelectionPositionRow=startRow,this._relativeSelectionPositionColumn=startColumn,this._relativeSelectionRowLength=endRow-startRow,this._relativeSelectionColumnLength=endColumn-startColumn,cursor===engineRender.CURSOR_TYPE.NORTH_WEST_RESIZE?(this._relativeSelectionPositionRow=endRow,this._relativeSelectionPositionColumn=endColumn):cursor===engineRender.CURSOR_TYPE.NORTH_RESIZE?this._relativeSelectionPositionRow=endRow:cursor===engineRender.CURSOR_TYPE.NORTH_EAST_RESIZE?this._relativeSelectionPositionRow=endRow:cursor===engineRender.CURSOR_TYPE.WEST_RESIZE?this._relativeSelectionPositionColumn=endColumn:cursor===engineRender.CURSOR_TYPE.SOUTH_WEST_RESIZE?this._relativeSelectionPositionColumn=endColumn:cursor===engineRender.CURSOR_TYPE.SOUTH_RESIZE&&(this._relativeSelectionPositionRow=startRow);const scrollTimer=engineRender.ScrollTimer.create(scene);scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY),this._scrollTimer=scrollTimer,scene.disableObjectsEvent(),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._widgetMoving(newMoveOffsetX,newMoveOffsetY,cursor),scene.setCursor(cursor),scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._widgetMoving(newMoveOffsetX,newMoveOffsetY,cursor)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a58,_b,_c;const scene2=this._scene;scene2.resetCursor(),this._clearObserverEvent(),scene2.enableObjectsEvent(),(_a58=this._scrollTimer)==null||_a58.dispose(),this._control.selectionScaled$.next(this._targetSelection),(_c=(_b=this._selectionHooks).selectionMoveEnd)==null||_c.call(_b)})}_widgetMoving(moveOffsetX,moveOffsetY,cursor){const scene=this._scene,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startOffsetX,this._startOffsetY])),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=this._skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,{rowHeaderWidth,columnHeaderHeight}=this._skeleton;let startRow=this._relativeSelectionPositionRow,startColumn=this._relativeSelectionPositionColumn,endRow=row,endColumn=column;cursor===engineRender.CURSOR_TYPE.NORTH_WEST_RESIZE?(startRow=row,startColumn=column,endRow=this._relativeSelectionPositionRow,endColumn=this._relativeSelectionPositionColumn):cursor===engineRender.CURSOR_TYPE.NORTH_RESIZE?(startRow=row,startColumn=this._relativeSelectionPositionColumn,endRow=this._relativeSelectionPositionRow,endColumn=this._relativeSelectionPositionColumn+this._relativeSelectionColumnLength):cursor===engineRender.CURSOR_TYPE.NORTH_EAST_RESIZE?(startRow=row,startColumn=this._relativeSelectionPositionColumn,endRow=this._relativeSelectionPositionRow,endColumn=column):cursor===engineRender.CURSOR_TYPE.WEST_RESIZE?(startRow=this._relativeSelectionPositionRow,startColumn=column,endRow=this._relativeSelectionPositionRow+this._relativeSelectionRowLength,endColumn=this._relativeSelectionPositionColumn):cursor===engineRender.CURSOR_TYPE.EAST_RESIZE?endRow=this._relativeSelectionPositionRow+this._relativeSelectionRowLength:cursor===engineRender.CURSOR_TYPE.SOUTH_WEST_RESIZE?(startRow=this._relativeSelectionPositionRow,startColumn=column,endRow=row,endColumn=this._relativeSelectionPositionColumn):cursor===engineRender.CURSOR_TYPE.SOUTH_RESIZE&&(startRow=this._relativeSelectionPositionRow,startColumn=this._relativeSelectionPositionColumn,endRow=row,endColumn=this._relativeSelectionPositionColumn+this._relativeSelectionColumnLength);const{startRow:finalStartRow,startColumn:finalStartColumn,endRow:finalEndRow,endColumn:finalEndColumn}=this._swapPositions(startRow,startColumn,endRow,endColumn),startCell=this._skeleton.getNoMergeCellPositionByIndex(finalStartRow,finalStartColumn),endCell=this._skeleton.getNoMergeCellPositionByIndex(finalEndRow,finalEndColumn),startY=(startCell==null?void 0:startCell.startY)||0,endY=(endCell==null?void 0:endCell.endY)||0,startX=(startCell==null?void 0:startCell.startX)||0,endX=(endCell==null?void 0:endCell.endX)||0;this._targetSelection={startY,endY,startX,endX,startRow,endRow,startColumn,endColumn},this._control.update(this._targetSelection,rowHeaderWidth,columnHeaderHeight,this._control.currentStyle),this._control.clearHighlight(),this._control.selectionScaling$.next(this._targetSelection)}_initialFill(){const{fillControl}=this._control;fillControl.onPointerEnter$.subscribeEvent(evt=>{this._injector.get(ISheetSelectionRenderService).interceptor.fetchThroughInterceptors(RANGE_FILL_PERMISSION_CHECK)(!1,{x:evt.offsetX,y:evt.offsetY,skeleton:this._skeleton,scene:this._scene})&&fillControl.setCursor(engineRender.CURSOR_TYPE.CROSSHAIR)}),fillControl.onPointerLeave$.subscribeEvent(()=>{fillControl.resetCursor()}),fillControl.onPointerDown$.subscribeEvent(this._fillEvent.bind(this))}_fillMoving(moveOffsetX,moveOffsetY){var _a58,_b,_c;const scene=this._scene,scrollXY=scene.getViewportScrollXY(this._activeViewport),{scaleX,scaleY}=scene.getAncestorScale(),moveActualSelection=this._skeleton.getCellPositionByOffset(moveOffsetX,moveOffsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,moveRelativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY])),maxRow=this._skeleton.getRowCount()-1,maxColumn=this._skeleton.getColumnCount()-1;let startRow=this._relativeSelectionPositionRow,startColumn=this._relativeSelectionPositionColumn,endRow=this._relativeSelectionPositionRow+this._relativeSelectionRowLength,endColumn=this._relativeSelectionPositionColumn+this._relativeSelectionColumnLength,isLighten=!1,isRowDropping=!0;if((column<startColumn||column>endColumn)&&row>=startRow&&row<=endRow){const rulerValue=this._fillRuler(column,startColumn,endColumn,this._relativeSelectionColumnLength,maxColumn);startColumn=rulerValue.startRowOrColumn,endColumn=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten,isRowDropping=!1}else if((row<startRow||row>endRow)&&column>=startColumn&&column<=endColumn){const rulerValue=this._fillRuler(row,startRow,endRow,this._relativeSelectionRowLength,maxRow);startRow=rulerValue.startRowOrColumn,endRow=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten}else if(Math.abs(this._startOffsetX-moveRelativeCoords.x-scrollXY.x)/2>Math.abs(this._startOffsetY-moveRelativeCoords.y-scrollXY.y)){const rulerValue=this._fillRuler(column,startColumn,endColumn,this._relativeSelectionColumnLength,maxColumn);startColumn=rulerValue.startRowOrColumn,endColumn=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten,isRowDropping=!1}else{const rulerValue=this._fillRuler(row,startRow,endRow,this._relativeSelectionRowLength,maxRow);startRow=rulerValue.startRowOrColumn,endRow=rulerValue.endRowOrColumn,isLighten=rulerValue.isLighten}const startCell=this._skeleton.getNoMergeCellPositionByIndex(startRow,startColumn),endCell=this._skeleton.getNoMergeCellPositionByIndex(endRow,endColumn),startY=(startCell==null?void 0:startCell.startY)||0,endY=(endCell==null?void 0:endCell.endY)||0,startX=(startCell==null?void 0:startCell.startX)||0,endX=(endCell==null?void 0:endCell.endX)||0;isLighten?this._controlHandler((o,index)=>{const newColor=new core.ColorKit(this._fillControlColors[index]).lighten(SELECTION_CONTROL_DELETING_LIGHTEN).toRgbString();o.setProps({fill:newColor})}):this._controlHandler((o,index)=>{o.setProps({fill:this._fillControlColors[index]})});const SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE=sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH/this._getScale();startRow===endRow&&isRowDropping===!0||startColumn===endColumn&&isRowDropping===!1?(_a58=this._helperSelection)==null||_a58.hide():((_b=this._helperSelection)==null||_b.transformByState({left:startX-SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE/2,top:startY-SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE/2,width:endX-startX,height:endY-startY}),(_c=this._helperSelection)==null||_c.show()),this._targetSelection={startY,endY,startX,endX,startRow,endRow,startColumn,endColumn},this._control.selectionFilling$.next(this._targetSelection)}_fillEvent(evt){const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,scene=this._scene,relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY])),{x:newEvtOffsetX,y:newEvtOffsetY}=relativeCoords;this._startOffsetX=newEvtOffsetX,this._startOffsetY=newEvtOffsetY;const{startRow:originStartRow,startColumn:originStartColumn,endRow:originEndRow,endColumn:originEndColumn}=this._control.model;this._isInMergeState=this._hasMergeInRange(originStartRow,originStartColumn,originEndRow,originEndColumn),this._relativeSelectionPositionRow=originStartRow,this._relativeSelectionPositionColumn=originStartColumn,this._relativeSelectionRowLength=originEndRow-originStartRow,this._relativeSelectionColumnLength=originEndColumn-originStartColumn;const style=this._control.currentStyle;let stroke=style==null?void 0:style.stroke,strokeWidth=style==null?void 0:style.strokeWidth;const defaultStyle=sheets.getNormalSelectionStyle(this._themeService);stroke==null&&(stroke=defaultStyle.stroke),strokeWidth==null&&(strokeWidth=defaultStyle.strokeWidth);const scale=this._getScale();strokeWidth/=scale;const SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE=sheets.SELECTION_CONTROL_BORDER_BUFFER_WIDTH/scale,darkenColor=new core.ColorKit(stroke).darken(2).toRgbString();this.isHelperSelection&&(this._helperSelection=new engineRender.Rect(HELPER_SELECTION_TEMP_NAME,{stroke:darkenColor,strokeWidth:strokeWidth+SELECTION_CONTROL_BORDER_BUFFER_WIDTH_SCALE/2}),scene.addObject(this._helperSelection)),this._activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY]));const viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),scrollTimer=engineRender.ScrollTimer.create(scene,this._activeViewport.viewportKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN?engineRender.ScrollTimerType.ALL:engineRender.ScrollTimerType.NONE);scrollTimer.startScroll(newEvtOffsetX,newEvtOffsetY,viewportMain),this._scrollTimer=scrollTimer,scene.disableObjectsEvent(),this._controlHandler(o=>{this._fillControlColors.push(o.fill)}),this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a58;const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,currentViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));if(!this._injector.get(ISheetSelectionRenderService).interceptor.fetchThroughInterceptors(RANGE_FILL_PERMISSION_CHECK)(!1,{x:evt.offsetX,y:evt.offsetY,skeleton:this._skeleton,scene:this._scene}))return;const{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._fillMoving(newMoveOffsetX,newMoveOffsetY),scene.setCursor(engineRender.CURSOR_TYPE.CROSSHAIR);const newSelection=this._targetSelection;if(viewportMain&&currentViewport&&((_a58=this._activeViewport)==null?void 0:_a58.viewportKey)!==(currentViewport==null?void 0:currentViewport.viewportKey)){let movingRange;newSelection.startRow!==originStartRow?(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.Y,movingRange={...newSelection,endRow:newSelection.startRow}):newSelection.endRow!==originEndRow?(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.Y,movingRange={...newSelection,startRow:newSelection.endRow}):newSelection.startColumn!==originStartColumn?(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.X,movingRange={...newSelection,endColumn:newSelection.startColumn}):(scrollTimer.scrollTimerType=engineRender.ScrollTimerType.X,movingRange={...newSelection,startColumn:newSelection.endColumn}),this._isSelectionInViewport(movingRange,currentViewport)&&(viewportMain.scrollToBarPos({x:scrollTimer.scrollTimerType===engineRender.ScrollTimerType.X?0:void 0,y:scrollTimer.scrollTimerType===engineRender.ScrollTimerType.Y?0:void 0}),this._activeViewport=currentViewport)}scrollTimer.scrolling(newMoveOffsetX,newMoveOffsetY,()=>{this._fillMoving(newMoveOffsetX,newMoveOffsetY)})}),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a58,_b;(_a58=this._helperSelection)==null||_a58.dispose();const scene2=this._scene;scene2.resetCursor(),this._clearObserverEvent(),scene2.enableObjectsEvent(),(_b=this._scrollTimer)==null||_b.dispose(),this._control.refreshSelectionFilled(this._targetSelection),this._isInMergeState=!1,this._controlHandler((o,index)=>{o.setProps({fill:this._fillControlColors[index]})}),this._fillControlColors=[]})}_hasMergeInRange(startRow,startColumn,endRow,endColumn){return this._skeleton.worksheet.getMergedCellRange(startRow,startColumn,endRow,endColumn).length>0}_swapPositions(startRow,startColumn,endRow,endColumn){const finalStartRow=Math.min(startRow,endRow),finalStartColumn=Math.min(startColumn,endColumn),finalEndRow=Math.max(startRow,endRow),finalEndColumn=Math.max(startColumn,endColumn);return{startRow:finalStartRow,startColumn:finalStartColumn,endRow:finalEndRow,endColumn:finalEndColumn}}_controlHandler(func){const{leftControl,rightControl,topControl,bottomControl,backgroundControlTop,backgroundControlMiddleLeft,backgroundControlMiddleRight,backgroundControlBottom,fillControl}=this._control,objects=[leftControl,rightControl,topControl,bottomControl,backgroundControlTop,backgroundControlMiddleLeft,backgroundControlMiddleRight,backgroundControlBottom,fillControl];for(let i=0,len=objects.length;i<len;i++){const object=objects[i];func(object,i)}}_fillRuler(rowOrColumn,startRowOrColumn,endRowOrColumn,rowOrColumnLength,maxRowOrColumn){let isLighten=!1;if(rowOrColumn<startRowOrColumn)if(this._isInMergeState&&rowOrColumn<startRowOrColumn){const current=startRowOrColumn-rowOrColumn,rangeRowCount=rowOrColumnLength+1,step=Math.ceil(current/rangeRowCount);let newStartRow=startRowOrColumn-step*rangeRowCount;newStartRow<0&&(newStartRow=startRowOrColumn-(step-1)*rangeRowCount),startRowOrColumn=newStartRow}else startRowOrColumn=rowOrColumn;else if(rowOrColumn>=startRowOrColumn&&rowOrColumn<=endRowOrColumn)isLighten=!0,this._isInMergeState||(endRowOrColumn=rowOrColumn);else if(this._isInMergeState&&rowOrColumn>endRowOrColumn){const current=rowOrColumn-endRowOrColumn,rangeRowCount=rowOrColumnLength+1,step=Math.ceil(current/rangeRowCount);let newEndRow=endRowOrColumn+step*rangeRowCount;newEndRow>maxRowOrColumn&&(newEndRow=endRowOrColumn+(step-1)*rangeRowCount),endRowOrColumn=newEndRow}else endRowOrColumn=rowOrColumn;return{rowOrColumn,startRowOrColumn,endRowOrColumn,isLighten}}_getScale(){const{scaleX,scaleY}=this._scene.getAncestorScale();return Math.max(scaleX,scaleY)}};__name(_SelectionShapeExtension,"SelectionShapeExtension");let SelectionShapeExtension=_SelectionShapeExtension;function attachSelectionWithCoord(selection,skeleton){const{range,primary,style}=selection;return{rangeWithCoord:attachRangeWithCoord(skeleton,range),primaryWithCoord:primary?attachPrimaryWithCoord(primary,skeleton):null,style}}__name(attachSelectionWithCoord,"attachSelectionWithCoord");function attachPrimaryWithCoord(primary,skeleton){const{actualRow,actualColumn,isMerged,isMergedMainCell,startRow,startColumn,endRow,endColumn}=primary,cellPosition=skeleton.getNoMergeCellPositionByIndex(actualRow,actualColumn),startCell=skeleton.getNoMergeCellPositionByIndex(startRow,startColumn),endCell=skeleton.getNoMergeCellPositionByIndex(endRow,endColumn);return{actualRow,actualColumn,isMerged,isMergedMainCell,startX:cellPosition.startX,startY:cellPosition.startY,endX:cellPosition.endX,endY:cellPosition.endY,mergeInfo:{startRow,startColumn,endRow,endColumn,startY:(startCell==null?void 0:startCell.startY)||0,endY:(endCell==null?void 0:endCell.endY)||0,startX:(startCell==null?void 0:startCell.startX)||0,endX:(endCell==null?void 0:endCell.endX)||0}}}__name(attachPrimaryWithCoord,"attachPrimaryWithCoord");const ISheetSelectionRenderService=core.createIdentifier("univer.sheet.selection-render-service"),_BaseSelectionRenderService=class _BaseSelectionRenderService extends core.Disposable{constructor(_injector,_themeService,_shortcutService,_sheetSkeletonManagerService){super();__publicField(this,"_downObserver");__publicField(this,"_scenePointerMoveSub");__publicField(this,"_scenePointerUpSub");__publicField(this,"_controlFillConfig$",new rxjs.BehaviorSubject(null));__publicField(this,"controlFillConfig$",this._controlFillConfig$.asObservable());__publicField(this,"_selectionControls",[]);__publicField(this,"_startRangeWhenPointerDown",{startY:0,endY:0,startX:0,endX:0,startRow:-1,endRow:-1,startColumn:-1,endColumn:-1});__publicField(this,"_startViewportPosX",0);__publicField(this,"_startViewportPosY",0);__publicField(this,"_scrollTimer");__publicField(this,"_cancelDownSubscription");__publicField(this,"_cancelUpSubscription");__publicField(this,"_skeleton");__publicField(this,"_scene");__publicField(this,"_isHeaderHighlight",!0);__publicField(this,"_shouldDetectMergedCells",!0);__publicField(this,"_selectionStyle");__publicField(this,"_remainLastEnabled",!1);__publicField(this,"_skipLastEnabled",!1);__publicField(this,"_singleSelectionEnabled",!1);__publicField(this,"_selectionMoveEnd$",new rxjs.BehaviorSubject([]));__publicField(this,"selectionMoveEnd$",this._selectionMoveEnd$.asObservable());__publicField(this,"_selectionMoving$",new rxjs.Subject);__publicField(this,"selectionMoving$",this._selectionMoving$.asObservable());__publicField(this,"_selectionMoveStart$",new rxjs.Subject);__publicField(this,"selectionMoveStart$",this._selectionMoveStart$.asObservable());__publicField(this,"_selectionMoving",!1);__publicField(this,"_activeViewport");__publicField(this,"interceptor",new core.InterceptorManager({RANGE_MOVE_PERMISSION_CHECK,RANGE_FILL_PERMISSION_CHECK}));__publicField(this,"_escapeShortcutDisposable",null);this._injector=_injector,this._themeService=_themeService,this._shortcutService=_shortcutService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._resetSelectionStyle(),this._initMoving()}get selectionMoving(){return this._selectionMoving}_initMoving(){this.disposeWithMe(this._selectionMoving$.subscribe(()=>{this._selectionMoving=!0})),this.disposeWithMe(this._selectionMoveEnd$.subscribe(()=>{this._selectionMoving=!1}))}_setSelectionStyle(style){this._selectionStyle=style}_resetSelectionStyle(){this._setSelectionStyle(sheets.getNormalSelectionStyle(this._themeService))}getViewPort(){return this._activeViewport}setSingleSelectionEnabled(enabled=!1){this._singleSelectionEnabled=enabled}_addSelectionControlBySelectionData(selection){var _a58;const skeleton=this._skeleton,style=(_a58=selection.style)!=null?_a58:sheets.getNormalSelectionStyle(this._themeService),scene=this._scene;if(!scene||!skeleton)return;const{rangeWithCoord,primaryWithCoord}=selection,{rangeType}=rangeWithCoord,control=this.newSelectionControl(scene,rangeType||core.RANGE_TYPE.NORMAL,skeleton);new SelectionShapeExtension(control,skeleton,scene,this._themeService,this._injector,{selectionMoveEnd:__name(()=>{this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())},"selectionMoveEnd")});const{rowHeaderWidth,columnHeaderHeight}=skeleton;control.update(rangeWithCoord,rowHeaderWidth,columnHeaderHeight,style,primaryWithCoord)}newSelectionControl(scene,_rangeType,skeleton){const zIndex=this.getSelectionControls().length,{rowHeaderWidth,columnHeaderHeight}=skeleton,control=new SelectionControl(scene,zIndex,this._themeService,this._isHeaderHighlight,{rowHeaderWidth,columnHeaderHeight});return this._selectionControls.push(control),control}updateControlForCurrentByRangeData(selections){const selectionControls=this.getSelectionControls();if(!(!selectionControls||this._skeleton==null))for(let i=0,len=selections.length;i<len;i++){const{rangeWithCoord,primaryWithCoord}=selections[i],control=selectionControls[i];control&&control.updateRange(rangeWithCoord,primaryWithCoord)}}refreshSelectionMoveStart(){this._selectionMoveStart$.next(this.getSelectionDataWithStyle())}refreshSelectionMoveEnd(){this._selectionMoveEnd$.next(this.getSelectionDataWithStyle())}_changeRuntime(skeleton,scene,viewport){this._skeleton=skeleton,this._scene=scene,this._activeViewport=viewport||(scene==null?void 0:scene.getViewports()[0]),scene.findLayerByZIndex(SHEET_COMPONENT_SELECTION_LAYER_INDEX)||scene.addLayer(new SelectionLayer(scene,[],SHEET_COMPONENT_SELECTION_LAYER_INDEX))}getSkeleton(){return this._skeleton}getSelectionDataWithStyle(){const selectionControls=this._selectionControls,[unitId,sheetId]=this._skeleton.getLocation();return selectionControls.map(control=>{const v=control.getValue();return v.rangeWithCoord.sheetId=sheetId,v.rangeWithCoord.unitId=unitId,v})}getSelectionControls(){return this._selectionControls}_clearSelectionControls(){const allSelectionControls=this._selectionControls;for(const control of allSelectionControls)control.dispose();this._selectionControls.length=0}_getFreeze(){var _a58;return(_a58=this._sheetSkeletonManagerService.getCurrent())==null?void 0:_a58.skeleton.getWorksheetConfig().freeze}_getViewportByCell(row,column){if(row===void 0||column===void 0)return null;const freeze=this._getFreeze();if(!freeze||freeze.startRow<=0&&freeze.startColumn<=0)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(row>freeze.startRow&&column>freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(row<=freeze.startRow&&column<=freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP);if(row<=freeze.startRow&&column>freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP);if(row>freeze.startRow&&column<=freeze.startColumn)return this._scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT)}getActiveRange(){const controls=this.getSelectionControls(),model=controls&&controls[controls.length-1].model;return model&&{startRow:model.startRow,startColumn:model.startColumn,endRow:model.endRow,endColumn:model.endColumn}}getActiveSelectionControl(){const controls=this.getSelectionControls();if(controls)return controls[controls.length-1]}endSelection(){var _a58;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(_a58=this._escapeShortcutDisposable)==null||_a58.dispose(),this._escapeShortcutDisposable=null}_reset(){var _a58;this._clearSelectionControls(),(_a58=this._downObserver)==null||_a58.unsubscribe(),this._downObserver=null}resetAndEndSelection(){this.endSelection(),this._reset()}_onPointerDown(evt,_zIndex=0,rangeType=core.RANGE_TYPE.NORMAL,viewport,scrollTimerType=engineRender.ScrollTimerType.ALL){var _a58;this._shouldDetectMergedCells=rangeType===core.RANGE_TYPE.NORMAL;const skeleton=this._skeleton,scene=this._scene;if(!scene||!skeleton)return;viewport&&(this._activeViewport=viewport);const{offsetX:evtOffsetX,offsetY:evtOffsetY}=evt,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!viewportMain)return;const relativeCoords=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([evtOffsetX,evtOffsetY]));let{x:viewportPosX,y:viewportPosY}=relativeCoords;this._startViewportPosX=viewportPosX,this._startViewportPosY=viewportPosY;const scrollXY=scene.getVpScrollXYInfoByPosToVp(relativeCoords),{scaleX,scaleY}=scene.getAncestorScale(),cursorCellRangeInfo=this._getCellRangeByCursorPosition(viewportPosX,viewportPosY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return;const{rangeWithCoord:cursorCellRange,primaryWithCoord:primaryCursorCellRange}=cursorCellRangeInfo,cursorCellRangeWithRangeType={...cursorCellRange,rangeType};this._startRangeWhenPointerDown={...cursorCellRange,rangeType};let activeSelectionControl=this.getActiveSelectionControl();const curControls=this.getSelectionControls();for(const control of curControls){if(evt.button===2&&control.model.isInclude(cursorCellRangeWithRangeType)){activeSelectionControl=control;return}if(control.model.isEqual(cursorCellRangeWithRangeType)){activeSelectionControl=control;break}evt.shiftKey||control.clearHighlight()}this._checkClearPreviousControls(evt);const currentCell=activeSelectionControl==null?void 0:activeSelectionControl.model.currentCell,expandByShiftKey=evt.shiftKey&&currentCell,remainLastEnable=this._remainLastEnabled&&!evt.ctrlKey&&!evt.shiftKey&&!this._skipLastEnabled&&!this._singleSelectionEnabled;expandByShiftKey&&currentCell?this._performSelectionByTwoCells(currentCell,cursorCellRangeWithRangeType,skeleton,rangeType,activeSelectionControl):remainLastEnable&&activeSelectionControl?this._updateSelectionControlByRange(activeSelectionControl,cursorCellRangeWithRangeType,primaryCursorCellRange):(activeSelectionControl=this.newSelectionControl(scene,rangeType,skeleton),this._updateSelectionControlByRange(activeSelectionControl,cursorCellRangeWithRangeType,primaryCursorCellRange)),this._selectionMoveStart$.next(this.getSelectionDataWithStyle()),scene.disableObjectsEvent(),this._clearUpdatingListeners(),this._addEndingListeners(),(_a58=scene.getTransformer())==null||_a58.clearSelectedObjects(),(rangeType===core.RANGE_TYPE.ROW||rangeType===core.RANGE_TYPE.COLUMN)&&(rangeType===core.RANGE_TYPE.ROW?viewportPosX=0:rangeType===core.RANGE_TYPE.COLUMN&&(viewportPosY=0),this._movingHandler(viewportPosX,viewportPosY,activeSelectionControl,rangeType)),this._setupPointerMoveListener(viewportMain,activeSelectionControl,rangeType,scrollTimerType,viewportPosX,viewportPosY),this._escapeShortcutDisposable=this._shortcutService.forceEscape(),this._scenePointerUpSub=scene.onPointerUp$.subscribeEvent(()=>{var _a59;this._clearUpdatingListeners(),this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()),(_a59=this._escapeShortcutDisposable)==null||_a59.dispose(),this._escapeShortcutDisposable=null})}_setupPointerMoveListener(viewportMain,activeSelectionControl,rangeType,scrollTimerType=engineRender.ScrollTimerType.ALL,moveStartPosX,moveStartPosY){var _a58,_b;let xCrossTime=0,yCrossTime=0,lastX=moveStartPosX,lastY=moveStartPosY;this._scrollTimer=engineRender.ScrollTimer.create(this._scene,scrollTimerType),this._scrollTimer.startScroll((_a58=viewportMain==null?void 0:viewportMain.left)!=null?_a58:0,(_b=viewportMain==null?void 0:viewportMain.top)!=null?_b:0,viewportMain);const scene=this._scene,startViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([moveStartPosX,moveStartPosY]));this._scenePointerMoveSub=scene.onPointerMove$.subscribeEvent(moveEvt=>{var _a59,_b2,_c,_d,_e,_f,_g,_h,_i;const{offsetX:moveOffsetX,offsetY:moveOffsetY}=moveEvt,{x:newMoveOffsetX,y:newMoveOffsetY}=scene.getRelativeToViewportCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY]));this._movingHandler(newMoveOffsetX,newMoveOffsetY,activeSelectionControl,rangeType);let scrollOffsetX=newMoveOffsetX,scrollOffsetY=newMoveOffsetY;const currentSelection=this.getActiveSelectionControl(),freeze=this._getFreeze(),selection=currentSelection==null?void 0:currentSelection.model,endViewport=(_a59=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([moveOffsetX,moveOffsetY])))!=null?_a59:this._getViewportByCell(selection==null?void 0:selection.endRow,selection==null?void 0:selection.endColumn);if(__name(()=>{if(!startViewport||!endViewport||!viewportMain)return!1;const crossableViewports=[engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN,engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP,engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP,engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT];return crossableViewports.includes(startViewport.viewportKey)&&crossableViewports.includes(endViewport.viewportKey)},"isCrossableViewports")()){if(!startViewport||!endViewport||!viewportMain)return!1;const isCrossingX=lastX<viewportMain.left&&newMoveOffsetX>viewportMain.left||lastX>viewportMain.left&&newMoveOffsetX<viewportMain.left,isCrossingY=lastY<viewportMain.top&&newMoveOffsetY>viewportMain.top||lastY>viewportMain.top&&newMoveOffsetY<viewportMain.top;isCrossingX&&(xCrossTime+=1),isCrossingY&&(yCrossTime+=1);const startKey=startViewport.viewportKey,endKey=endViewport.viewportKey;if(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_ROW_TOP)moveOffsetY<viewportMain.top&&((_b2=selection==null?void 0:selection.endRow)!=null?_b2:0)<((_c=freeze==null?void 0:freeze.startRow)!=null?_c:0)?scrollOffsetY=viewportMain.top:isCrossingY&&yCrossTime%2===1&&viewportMain.scrollToViewportPos({viewportScrollY:0});else if(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_COLUMN_LEFT)moveOffsetX<viewportMain.left&&((_d=selection==null?void 0:selection.endColumn)!=null?_d:0)<((_e=freeze==null?void 0:freeze.startColumn)!=null?_e:0)?scrollOffsetX=viewportMain.left:isCrossingX&&xCrossTime%2===1&&viewportMain.scrollToViewportPos({viewportScrollX:0});else if(startKey===endKey){let disableX=!1,disableY=!1;startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP?(disableX=!0,disableY=!0):startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP?disableY=!0:startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT&&(disableX=!0),((_f=selection==null?void 0:selection.endRow)!=null?_f:0)>((_g=freeze==null?void 0:freeze.startRow)!=null?_g:0)&&(disableY=!1),((_h=selection==null?void 0:selection.endColumn)!=null?_h:0)>((_i=freeze==null?void 0:freeze.startColumn)!=null?_i:0)&&(disableX=!1),disableX&&(scrollOffsetX=viewportMain.left),disableY&&(scrollOffsetY=viewportMain.top)}else{const startXY={x:startViewport.scrollX,y:startViewport.scrollY},endXY={x:endViewport.scrollX,y:endViewport.scrollY},shouldResetX=startXY.x!==endXY.x&&isCrossingX&&xCrossTime%2===1,shouldResetY=startXY.y!==endXY.y&&isCrossingY&&yCrossTime%2===1;(shouldResetX||shouldResetY)&&(viewportMain.scrollToBarPos({x:shouldResetX?startXY.x:void 0,y:shouldResetY?startXY.y:void 0}),shouldResetX||(scrollOffsetX=viewportMain.left),shouldResetY||(scrollOffsetY=viewportMain.top)),(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT||endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT)&&(scrollOffsetX=viewportMain.left),(startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP||endKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP&&startKey===engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP)&&(scrollOffsetY=viewportMain.top)}lastX=newMoveOffsetX,lastY=newMoveOffsetY}this._scrollTimer.scrolling(scrollOffsetX,scrollOffsetY,()=>{this._movingHandler(newMoveOffsetX,newMoveOffsetY,activeSelectionControl,rangeType)})})}attachSelectionWithCoord(selectionWithStyle){return attachSelectionWithCoord(selectionWithStyle,this._skeleton)}attachPrimaryWithCoord(primary){return attachPrimaryWithCoord(primary,this._skeleton)}getSelectionCellByPosition(x,y){const scene=this._scene,skeleton=this._skeleton,scrollXY=scene.getViewportScrollXY(scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN)),{scaleX,scaleY}=scene.getAncestorScale();return skeleton.calculateCellIndexByPosition(x,y,scaleX,scaleY,scrollXY)}_movingHandler(offsetX,offsetY,activeSelectionControl,rangeType){var _a58,_b,_c,_d,_e;const skeleton=this._skeleton,scene=this._scene,[unitId,sheetId]=skeleton.getLocation(),currSelectionRange={startRow:(_a58=activeSelectionControl==null?void 0:activeSelectionControl.model.startRow)!=null?_a58:-1,endRow:(_b=activeSelectionControl==null?void 0:activeSelectionControl.model.endRow)!=null?_b:-1,startColumn:(_c=activeSelectionControl==null?void 0:activeSelectionControl.model.startColumn)!=null?_c:-1,endColumn:(_d=activeSelectionControl==null?void 0:activeSelectionControl.model.endColumn)!=null?_d:-1,unitId,sheetId},viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),targetViewport=(_e=this._getViewportByCell(currSelectionRange.endRow,currSelectionRange.endColumn))!=null?_e:viewportMain,scrollXY=scene.getVpScrollXYInfoByPosToVp(engineRender.Vector2.FromArray([this._startViewportPosX,this._startViewportPosY]),targetViewport),{scaleX,scaleY}=scene.getAncestorScale();rangeType===core.RANGE_TYPE.ROW?offsetX=Number.POSITIVE_INFINITY:rangeType===core.RANGE_TYPE.COLUMN&&(offsetY=Number.POSITIVE_INFINITY);const cursorCellRangeInfo=this._getCellRangeByCursorPosition(offsetX,offsetY,scaleX,scaleY,scrollXY);if(!cursorCellRangeInfo)return;const{rangeWithCoord:cursorCellRange}=cursorCellRangeInfo,activeCellRange=this._startRangeWhenPointerDown;let newSelectionRange={startRow:Math.min(cursorCellRange.startRow,activeCellRange.startRow),startColumn:Math.min(cursorCellRange.startColumn,activeCellRange.startColumn),endRow:Math.max(cursorCellRange.endRow,activeCellRange.endRow),endColumn:Math.max(cursorCellRange.endColumn,activeCellRange.endColumn)};if(this._shouldDetectMergedCells&&(newSelectionRange=skeleton.getSelectionMergeBounding(newSelectionRange.startRow,newSelectionRange.startColumn,newSelectionRange.endRow,newSelectionRange.endColumn)),!newSelectionRange)return;const startCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.startRow,newSelectionRange.startColumn),endCellXY=skeleton.getNoMergeCellPositionByIndex(newSelectionRange.endRow,newSelectionRange.endColumn),newSelectionRangeWithCoord={startRow:newSelectionRange.startRow,startColumn:newSelectionRange.startColumn,endRow:newSelectionRange.endRow,endColumn:newSelectionRange.endColumn,unitId,sheetId,startY:(startCellXY==null?void 0:startCellXY.startY)||0,endY:(endCellXY==null?void 0:endCellXY.endY)||0,startX:(startCellXY==null?void 0:startCellXY.startX)||0,endX:(endCellXY==null?void 0:endCellXY.endX)||0},rangeChanged=currSelectionRange.startRow!==newSelectionRange.startRow||currSelectionRange.startColumn!==newSelectionRange.startColumn||currSelectionRange.endRow!==newSelectionRange.endRow||currSelectionRange.endColumn!==newSelectionRange.endColumn;activeSelectionControl!=null&&rangeChanged&&(this._updateSelectionControlByRange(activeSelectionControl,newSelectionRangeWithCoord),this._selectionMoving$.next(this.getSelectionDataWithStyle()))}_updateSelectionControlByRange(control,newSelectionRange,highlight){control.updateRange(newSelectionRange,highlight)}_clearUpdatingListeners(){var _a58,_b,_c,_d,_e;this._scene.enableObjectsEvent(),(_a58=this._scenePointerMoveSub)==null||_a58.unsubscribe(),this._scenePointerMoveSub=null,(_b=this._scenePointerUpSub)==null||_b.unsubscribe(),this._scenePointerUpSub=null,(_c=this._cancelDownSubscription)==null||_c.unsubscribe(),this._cancelDownSubscription=null,(_d=this._cancelUpSubscription)==null||_d.unsubscribe(),this._cancelUpSubscription=null,(_e=this._scrollTimer)==null||_e.dispose()}_addEndingListeners(){var _a58,_b,_c;const scene=this._scene,mainScene=(_a58=scene.getEngine())==null?void 0:_a58.activeScene;!mainScene||mainScene===scene||((_b=this._cancelDownSubscription)==null||_b.unsubscribe(),this._cancelDownSubscription=null,(_c=this._cancelUpSubscription)==null||_c.unsubscribe(),this._cancelUpSubscription=null,this._cancelDownSubscription=mainScene.onPointerDown$.subscribeEvent(()=>this._clearUpdatingListeners()),this._cancelUpSubscription=mainScene.onPointerUp$.subscribeEvent(()=>this._clearUpdatingListeners()))}_getCellRangeByCursorPosition(offsetX,offsetY,scaleX,scaleY,scrollXY){var _a58;if(this._shouldDetectMergedCells){const primaryWithCoord2=(_a58=this._skeleton)==null?void 0:_a58.calculateCellIndexByPosition(offsetX,offsetY,scaleX,scaleY,scrollXY);if(!primaryWithCoord2)return;const rangeWithCoord2=core.makeCellToSelection(primaryWithCoord2);return{primaryWithCoord:primaryWithCoord2,rangeWithCoord:rangeWithCoord2}}const skeleton=this._skeleton;if(skeleton==null)return;const moveActualSelection=skeleton.getCellPositionByOffset(offsetX,offsetY,scaleX,scaleY,scrollXY),{row,column}=moveActualSelection,startCell=skeleton.getNoMergeCellPositionByIndex(row,column),{startX,startY,endX,endY}=startCell,rangeWithCoord={startY,endY,startX,endX,startRow:row,endRow:row,startColumn:column,endColumn:column};return{primaryWithCoord:{actualRow:row,actualColumn:column,isMerged:!1,isMergedMainCell:!1,startY,endY,startX,endX,mergeInfo:rangeWithCoord},rangeWithCoord}}_checkClearPreviousControls(evt){this.getSelectionControls().length!==0&&(!evt.ctrlKey&&!evt.shiftKey&&!this._remainLastEnabled||this._singleSelectionEnabled&&!evt.shiftKey)&&this._clearSelectionControls()}_performSelectionByTwoCells(currentCell,startSelectionRange,skeleton,rangeType,activeControl){const{actualRow,actualColumn,mergeInfo:actualMergeInfo}=currentCell,newStartRow=Math.min(actualRow,startSelectionRange.startRow,actualMergeInfo.startRow),newEndRow=Math.max(actualRow,startSelectionRange.endRow,actualMergeInfo.endRow),newStartColumn=Math.min(actualColumn,startSelectionRange.startColumn,actualMergeInfo.startColumn),newEndColumn=Math.max(actualColumn,startSelectionRange.endColumn,actualMergeInfo.endColumn),bounding=skeleton.getMergeBounding(newStartRow,newStartColumn,newEndRow,newEndColumn),startCell=skeleton.getNoMergeCellPositionByIndex(bounding.startRow,bounding.startColumn),endCell=skeleton.getNoMergeCellPositionByIndex(bounding.endRow,bounding.endColumn),newSelectionRange={startColumn:bounding.startColumn,startRow:bounding.startRow,endColumn:bounding.endColumn,endRow:bounding.endRow,startY:startCell.startY,endY:endCell.endY,startX:startCell.startX,endX:endCell.endX,rangeType},activeCell=skeleton.getCellByIndex(actualRow,actualColumn);this._startRangeWhenPointerDown={startColumn:activeCell.mergeInfo.startColumn,startRow:activeCell.mergeInfo.startRow,endColumn:activeCell.mergeInfo.endColumn,endRow:activeCell.mergeInfo.endRow,startY:activeCell.mergeInfo.startY||0,endY:activeCell.mergeInfo.endY||0,startX:activeCell.mergeInfo.startX||0,endX:activeCell.mergeInfo.endX||0,rangeType},this._updateSelectionControlByRange(activeControl,newSelectionRange,currentCell)}_refreshSelectionControl(selectionsData){const selections=selectionsData.map(selectionWithStyle=>{const selectionData=attachSelectionWithCoord(selectionWithStyle,this._skeleton);return selectionData.style=sheets.getNormalSelectionStyle(this._themeService),selectionData});this.updateControlForCurrentByRangeData(selections)}};__name(_BaseSelectionRenderService,"BaseSelectionRenderService");let BaseSelectionRenderService=_BaseSelectionRenderService;function getAllSelection(skeleton){return{range:{startRow:0,startColumn:0,endRow:skeleton.getRowCount()-1,endColumn:skeleton.getColumnCount()-1,rangeType:core.RANGE_TYPE.ALL},primary:getTopLeftSelection(skeleton).primary,style:null}}__name(getAllSelection,"getAllSelection");function getTopLeftSelection(skeleton){const mergeData=skeleton.mergeData;return sheets.transformCellDataToSelectionData(0,0,mergeData)||{range:{startRow:0,startColumn:0,endRow:0,endColumn:0},primary:{actualRow:0,actualColumn:0,startRow:0,startColumn:0,endRow:0,endColumn:0,isMerged:!1,isMergedMainCell:!1},style:null}}__name(getTopLeftSelection,"getTopLeftSelection");var __defProp$N=Object.defineProperty,__getOwnPropDesc$N=Object.getOwnPropertyDescriptor,__decorateClass$N=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$N(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$N(target,key,result),result},"__decorateClass$N"),__decorateParam$N=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$N");const BEFORE_CELL_EDIT=core.createInterceptorKey("BEFORE_CELL_EDIT"),AFTER_CELL_EDIT=core.createInterceptorKey("AFTER_CELL_EDIT"),AFTER_CELL_EDIT_ASYNC=core.createInterceptorKey("AFTER_CELL_EDIT_ASYNC");var _a6;exports.EditorBridgeService=(_a6=class extends core.Disposable{constructor(_renderManagerService,_themeService,_univerInstanceService,_editorService,_refSelectionsService,_contextService){super();__publicField(this,"_editorUnitId",core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY);__publicField(this,"_isForceKeepVisible",!1);__publicField(this,"_editorIsDirty",!1);__publicField(this,"_visible",{visible:!1,eventType:engineRender.DeviceInputEventType.Dblclick,unitId:""});__publicField(this,"_currentEditCell",null);__publicField(this,"_currentEditCellState",null);__publicField(this,"_currentEditCellState$",new rxjs.BehaviorSubject(null));__publicField(this,"currentEditCellState$",this._currentEditCellState$.asObservable());__publicField(this,"_visible$",new rxjs.BehaviorSubject(this._visible));__publicField(this,"visible$",this._visible$.asObservable());__publicField(this,"_afterVisible$",new rxjs.BehaviorSubject(this._visible));__publicField(this,"afterVisible$",this._afterVisible$.asObservable());__publicField(this,"interceptor",new core.InterceptorManager({BEFORE_CELL_EDIT,AFTER_CELL_EDIT,AFTER_CELL_EDIT_ASYNC}));this._renderManagerService=_renderManagerService,this._themeService=_themeService,this._univerInstanceService=_univerInstanceService,this._editorService=_editorService,this._refSelectionsService=_refSelectionsService,this._contextService=_contextService,this.disposeWithMe(core.toDisposable(()=>{this._currentEditCellState$.complete(),this._currentEditCell=null})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().AFTER_CELL_EDIT,{priority:-1,handler:__name(_value=>_value,"handler")})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().BEFORE_CELL_EDIT,{priority:-1,handler:__name(_value=>_value,"handler")})),this.disposeWithMe(this.interceptor.intercept(this.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC,{priority:-1,handler:__name(_value=>_value,"handler")})),this._univerInstanceService.getTypeOfUnitDisposed$(core.UniverInstanceType.UNIVER_SHEET).subscribe(unit=>{var _a58;unit.getUnitId()===((_a58=this._currentEditCellState)==null?void 0:_a58.unitId)&&this._clearCurrentEditCellState()})}refreshEditCellState(){const editCellState=this.getLatestEditCellState();this._currentEditCellState=editCellState,this._currentEditCellState$.next(editCellState)}refreshEditCellPosition(resetSizeOnly){var _a58,_b;const currentEditCell=this._currentEditCell;if(currentEditCell==null)return;const ru=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET);if(!ru)return;const skeleton=(_a58=ru.with(exports.SheetSkeletonManagerService).getWorksheetSkeleton(currentEditCell.sheetId))==null?void 0:_a58.skeleton,selectionRenderService=ru.with(ISheetSelectionRenderService);if(!skeleton||!this._currentEditCellState)return;const{primary,unitId,sheetId,scene,engine}=currentEditCell,{startRow,startColumn}=primary,primaryWithCoord=attachPrimaryWithCoord(primary,skeleton);if(primaryWithCoord==null)return;const actualRangeWithCoord=core.makeCellToSelection(primaryWithCoord),canvasOffset=docsUi.getCanvasOffsetByEngine(engine);let{startX,startY,endX,endY}=actualRangeWithCoord;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY=scene.getViewportScrollXY(selectionRenderService.getViewPort());startX=skeleton.convertTransformToOffsetX(startX,scaleX,scrollXY),startY=skeleton.convertTransformToOffsetY(startY,scaleY,scrollXY),endX=skeleton.convertTransformToOffsetX(endX,scaleX,scrollXY),endY=skeleton.convertTransformToOffsetY(endY,scaleY,scrollXY),resetSizeOnly&&this._currentEditCellState&&(endX=endX-startX+this._currentEditCellState.position.startX,endY=endY-startY+this._currentEditCellState.position.startY,startX=this._currentEditCellState.position.startX,startY=this._currentEditCellState.position.startY),this._editorService.setOperationSheetUnitId(unitId),this._editorService.setOperationSheetSubUnitId(sheetId);const editCellState={position:{startX,startY,endX,endY},scaleX,scaleY,canvasOffset,row:startRow,column:startColumn,unitId,sheetId,documentLayoutObject:this._currentEditCellState.documentLayoutObject,editorUnitId:this._editorUnitId,isInArrayFormulaRange:(_b=this._currentEditCellState)==null?void 0:_b.isInArrayFormulaRange};this._currentEditCellState=editCellState,this._currentEditCellState$.next(editCellState)}setEditCell(param){this._currentEditCell=param,this._editorService.getFocusEditor()||(this._editorService.focus(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),this._contextService.setContextValue(core.EDITOR_ACTIVATED,!1),this._contextService.setContextValue(core.FOCUSING_EDITOR_STANDALONE,!1),this._contextService.setContextValue(core.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE,!1));const editCellState=this.getLatestEditCellState();this._currentEditCellState=editCellState,this._currentEditCellState$.next(editCellState)}_clearCurrentEditCellState(){this._currentEditCellState=null,this._currentEditCellState$.next(null)}getEditCellState(){return this._currentEditCellState}getLatestEditCellState(){var _a58,_b,_c;const currentEditCell=this._currentEditCell;if(currentEditCell==null)return;const ru=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET);if(!ru)return;const skeleton=ru.with(exports.SheetSkeletonManagerService).getCurrentSkeleton(),selectionRenderService=ru.with(ISheetSelectionRenderService);if(!skeleton)return;const{primary,unitId,sheetId,scene,engine}=currentEditCell,{startRow,startColumn}=primary,primaryWithCoord=attachPrimaryWithCoord(primary,skeleton);if(primaryWithCoord==null)return;const actualRangeWithCoord=core.makeCellToSelection(primaryWithCoord),canvasOffset=docsUi.getCanvasOffsetByEngine(engine);let{startX,startY,endX,endY}=actualRangeWithCoord;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY=scene.getViewportScrollXY(selectionRenderService.getViewPort());startX=skeleton.convertTransformToOffsetX(startX,scaleX,scrollXY),startY=skeleton.convertTransformToOffsetY(startY,scaleY,scrollXY),endX=skeleton.convertTransformToOffsetX(endX,scaleX,scrollXY),endY=skeleton.convertTransformToOffsetY(endY,scaleY,scrollXY);const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)return;const location={workbook,worksheet,unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),row:startRow,col:startColumn,origin:worksheet.getCellRaw(startRow,startColumn)},cell=this.interceptor.fetchThroughInterceptors(this.interceptor.getInterceptPoints().BEFORE_CELL_EDIT)(worksheet.getCell(startRow,startColumn),location);let documentLayoutObject=cell&&skeleton.getCellDocumentModelWithFormula(cell);const renderConfig=(_a58=documentLayoutObject==null?void 0:documentLayoutObject.documentModel)==null?void 0:_a58.documentStyle.renderConfig;if(renderConfig!=null&&(renderConfig.cellValueType=core.CellValueType.STRING),!documentLayoutObject||documentLayoutObject.documentModel==null){const blankModel=skeleton.getBlankCellDocumentModel(cell);if(documentLayoutObject!=null){const{verticalAlign,horizontalAlign,wrapStrategy,textRotation,fill}=documentLayoutObject,{centerAngle,vertexAngle}=engineRender.convertTextRotation(textRotation);blankModel.documentModel.documentStyle.renderConfig={verticalAlign,horizontalAlign,wrapStrategy,background:{rgb:fill},centerAngle,vertexAngle}}documentLayoutObject=blankModel}if(documentLayoutObject.fill=documentLayoutObject.fill||"#fff",(_b=documentLayoutObject.documentModel)==null||_b.setZoomRatio(Math.max(scaleX,scaleY)),(cell==null?void 0:cell.isInArrayFormulaRange)===!0){const body=(_c=documentLayoutObject.documentModel)==null?void 0:_c.getBody();body&&(body.textRuns=[{st:0,ed:body.dataStream.length-2,ts:{cl:{rgb:this._themeService.getCurrentTheme().textColorSecondary}}}])}return this._editorService.setOperationSheetUnitId(unitId),this._editorService.setOperationSheetSubUnitId(sheetId),{position:{startX,startY,endX,endY},scaleX,scaleY,canvasOffset,row:startRow,column:startColumn,unitId,sheetId,documentLayoutObject,editorUnitId:this._editorUnitId,isInArrayFormulaRange:cell==null?void 0:cell.isInArrayFormulaRange}}getCurrentEditorId(){return this._editorUnitId}changeVisible(param){const editor=this._editorService.getFocusEditor();this._refSelectionsService.getCurrentSelections().length>0&&editor&&!editor.isSheetEditor()||(this._visible=param,param.visible&&(this._editorIsDirty=!1),this._visible$.next(this._visible),this._afterVisible$.next(this._visible))}isVisible(){return this._visible}enableForceKeepVisible(){this._isForceKeepVisible=!0}disableForceKeepVisible(){this._isForceKeepVisible=!1}isForceKeepVisible(){return this._isForceKeepVisible}changeEditorDirty(dirtyStatus){this._editorIsDirty=dirtyStatus}getEditorDirty(){return this._editorIsDirty}},__name(_a6,"EditorBridgeService"),_a6);exports.EditorBridgeService=__decorateClass$N([__decorateParam$N(0,engineRender.IRenderManagerService),__decorateParam$N(1,core.Inject(core.ThemeService)),__decorateParam$N(2,core.IUniverInstanceService),__decorateParam$N(3,docsUi.IEditorService),__decorateParam$N(4,sheets.IRefSelectionsService),__decorateParam$N(5,core.IContextService)],exports.EditorBridgeService);const IEditorBridgeService=core.createIdentifier("univer.sheet-editor-bridge.service"),calcDocRangePositions=__name((range,skeleton)=>{var _a58,_b,_c,_d,_e;const startPosition=skeleton.findNodePositionByCharIndex(range.startOffset,!1,range.segmentId,-1),skeletonData=skeleton.getSkeletonData();let end=range.endOffset;if(range.segmentId){const root=(_e=Array.from((_b=(_a58=skeletonData==null?void 0:skeletonData.skeFooters.get(range.segmentId))==null?void 0:_a58.values())!=null?_b:[])[0])!=null?_e:Array.from((_d=(_c=skeletonData==null?void 0:skeletonData.skeHeaders.get(range.segmentId))==null?void 0:_c.values())!=null?_d:[])[0];root&&(end=Math.min(root.ed,end))}const endPosition=skeleton.findNodePositionByCharIndex(end,!1,range.segmentId,-1);if(!endPosition||!startPosition)return;const documentOffsetConfig={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},convertor=new docsUi.NodePositionConvertToCursor(documentOffsetConfig,skeleton),{borderBoxPointGroup}=convertor.getRangePointData(startPosition,endPosition);return docsUi.getLineBounding(borderBoxPointGroup).map(rect=>({top:rect.top,bottom:rect.bottom,left:rect.left,right:rect.right}))},"calcDocRangePositions"),calcDocGlyphPosition=__name((glyph,skeleton,pageIndex=-1)=>{const start=skeleton.findPositionByGlyph(glyph,pageIndex);if(!start)return;const startPosition={...start,isBack:!0},documentOffsetConfig={docsLeft:0,docsTop:0,pageMarginLeft:0,pageMarginTop:0},convertor=new docsUi.NodePositionConvertToCursor(documentOffsetConfig,skeleton),{borderBoxPointGroup}=convertor.getRangePointData(startPosition,startPosition),rect=docsUi.getLineBounding(borderBoxPointGroup)[0];return{top:rect.top,bottom:rect.bottom,left:rect.left,right:rect.left}},"calcDocGlyphPosition"),calcLinkPosition=__name((skeleton,range,paddingLeft=0,paddingTop=0)=>{const rects=calcDocRangePositions({startOffset:range.startIndex,endOffset:range.endIndex+1,collapsed:!1},skeleton);if(rects)return{rects:rects.map(rect=>({top:rect.top+paddingTop,bottom:rect.bottom+paddingTop,left:rect.left+paddingLeft,right:rect.right+paddingLeft})),range}},"calcLinkPosition"),calcBulletPosition=__name((skeleton,paragraph,paddingLeft=0,paddingTop=0)=>{var _a58,_b,_c;const node=skeleton.findNodeByCharIndex(paragraph.startIndex),divide=node==null?void 0:node.parent,line=divide==null?void 0:divide.parent,column=line==null?void 0:line.parent,targetLine=column==null?void 0:column.lines.find(l2=>l2.paragraphStart&&l2.paragraphIndex===paragraph.startIndex),bulletNode=(_c=(_b=(_a58=targetLine==null?void 0:targetLine.divides)==null?void 0:_a58[0])==null?void 0:_b.glyphGroup)==null?void 0:_c[0];if(!bulletNode||!bulletNode)return;const rect=calcDocGlyphPosition(bulletNode,skeleton);if(rect)return{rect:{top:rect.top+paddingTop,bottom:rect.bottom+paddingTop,left:rect.left+paddingLeft,right:rect.right+paddingLeft},segmentId:void 0,segmentPageIndex:-1,paragraph}},"calcBulletPosition"),calculateDocSkeletonRects=__name((docSkeleton,paddingLeft=0,paddingTop=0)=>{var _a58,_b,_c,_d,_e,_f;const docModel=docSkeleton.getViewModel().getDataModel(),hyperLinks=(_c=(_b=(_a58=docModel.getBody())==null?void 0:_a58.customRanges)==null?void 0:_b.filter(range=>range.rangeType===core.CustomRangeType.HYPERLINK))!=null?_c:[],checkLists=(_f=(_e=(_d=docModel.getBody())==null?void 0:_d.paragraphs)==null?void 0:_e.filter(p2=>{var _a59;return((_a59=p2.bullet)==null?void 0:_a59.listType.indexOf(core.PresetListType.CHECK_LIST))===0}))!=null?_f:[];return{links:hyperLinks.map(link=>calcLinkPosition(docSkeleton,link,paddingLeft,paddingTop)).filter(Boolean),checkLists:checkLists.map(list=>calcBulletPosition(docSkeleton,list,paddingLeft,paddingTop)).filter(Boolean)}},"calculateDocSkeletonRects");function calcPadding(cell,font){var _a58,_b,_c,_d;const height=(_b=(_a58=font.documentSkeleton.getSkeletonData())==null?void 0:_a58.pages[0].height)!=null?_b:0,width=(_d=(_c=font.documentSkeleton.getSkeletonData())==null?void 0:_c.pages[0].width)!=null?_d:0,vt=font.verticalAlign,ht=font.horizontalAlign;let paddingTop=0;switch(vt){case core.VerticalAlign.UNSPECIFIED:case core.VerticalAlign.BOTTOM:paddingTop=cell.mergeInfo.endY-cell.mergeInfo.startY-height;break;case core.VerticalAlign.MIDDLE:paddingTop=(cell.mergeInfo.endY-cell.mergeInfo.startY-height)/2;break}let paddingLeft=0;switch(ht){case core.HorizontalAlign.RIGHT:paddingLeft=cell.mergeInfo.endX-cell.mergeInfo.startX-width;break;case core.HorizontalAlign.CENTER:paddingLeft=(cell.mergeInfo.endX-cell.mergeInfo.startX-width)/2;break}return{paddingLeft,paddingTop}}__name(calcPadding,"calcPadding");const getCustomRangePosition=__name((injector,unitId,subUnitId,row,col,rangeId)=>{var _a58,_b,_c;const univerInstanceService=injector.get(core.IUniverInstanceService),renderManagerService=injector.get(engineRender.IRenderManagerService),workbook=univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return null;const worksheet=workbook.getSheetBySheetId(subUnitId);if(!worksheet)return null;const currentRender=renderManagerService.getRenderById(workbook.getUnitId()),skeletonParam=currentRender==null?void 0:currentRender.with(exports.SheetSkeletonManagerService).getWorksheetSkeleton(worksheet.getSheetId()),skeleton=skeletonParam==null?void 0:skeletonParam.skeleton;if(!skeleton||!currentRender)return;const font=skeleton.getFont(row,col),docSkeleton=font==null?void 0:font.documentSkeleton;if(!docSkeleton)return null;const customRange=(_b=(_a58=docSkeleton.getViewModel().getBody())==null?void 0:_a58.customRanges)==null?void 0:_b.find(range=>range.rangeId===rangeId);if(!customRange)return null;const PADDING=docsUi.DOC_VERTICAL_PADDING,cellIndex=skeleton.getCellByIndex(row,col);let{actualColumn,actualRow}=cellIndex;skeleton.overflowCache.forValue((r2,c,range)=>{range.startRow<=actualRow&&range.endRow>=actualRow&&range.startColumn<=actualColumn&&range.endColumn>=actualColumn&&(actualColumn=c,actualRow=r2)});const actualCell=skeleton.getCellByIndex(actualRow,actualColumn),cellData=worksheet.getCell(actualCell.actualRow,actualCell.actualColumn),{topOffset=0,leftOffset=0}=(_c=cellData==null?void 0:cellData.fontRenderExtension)!=null?_c:{},{paddingLeft,paddingTop}=calcPadding(actualCell,font),rects=calcDocRangePositions({startOffset:customRange.startIndex,endOffset:customRange.endIndex,collapsed:!1},docSkeleton);return{rects:rects==null?void 0:rects.map(rect=>({top:rect.top+actualCell.mergeInfo.startY+paddingTop+topOffset+PADDING,bottom:rect.bottom+actualCell.mergeInfo.startY+paddingTop+topOffset+PADDING,left:rect.left+actualCell.mergeInfo.startX+paddingLeft+leftOffset,right:rect.right+actualCell.mergeInfo.startX+paddingLeft+leftOffset})),customRange,label:docSkeleton.getViewModel().getBody().dataStream.slice(customRange.startIndex+1,customRange.endIndex)}},"getCustomRangePosition"),getEditingCustomRangePosition=__name((injector,unitId,subUnitId,row,col,rangeId)=>{var _a58,_b,_c;const editorBridgeService=injector.get(IEditorBridgeService),state=editorBridgeService.getEditCellState();if(!state||!editorBridgeService.isVisible().visible)return null;const{editorUnitId,unitId:editingUnitId,sheetId,row:editRow,column:editCol}=state;if(unitId!==editingUnitId||subUnitId!==sheetId||editRow!==row||editCol!==col)return null;const renderManagerService=injector.get(engineRender.IRenderManagerService),renderer=renderManagerService.getRenderById(editorUnitId),sheetRenderer=renderManagerService.getRenderById(unitId);if(!renderer||!sheetRenderer)return null;const docSkeleton=renderer.with(docs.DocSkeletonManagerService).getSkeleton(),sheetSkeleton=(_a58=sheetRenderer.with(exports.SheetSkeletonManagerService).getWorksheetSkeleton(sheetId))==null?void 0:_a58.skeleton;if(!docSkeleton||!sheetSkeleton)return null;const customRange=(_c=(_b=docSkeleton.getViewModel().getBody())==null?void 0:_b.customRanges)==null?void 0:_c.find(range=>range.rangeId===rangeId);if(!customRange)return null;const PADDING=4,rects=calcDocRangePositions({startOffset:customRange.startIndex,endOffset:customRange.endIndex,collapsed:!1},docSkeleton),canvasClientRect=renderer.engine.getCanvasElement().getBoundingClientRect();return{rects:rects==null?void 0:rects.map(rect=>({top:rect.top+canvasClientRect.top-PADDING,bottom:rect.bottom+canvasClientRect.top+PADDING,left:rect.left+canvasClientRect.left,right:rect.right+canvasClientRect.left})),customRange,label:docSkeleton.getViewModel().getBody().dataStream.slice(customRange.startIndex+1,customRange.endIndex)}},"getEditingCustomRangePosition");var __defProp$M=Object.defineProperty,__getOwnPropDesc$M=Object.getOwnPropertyDescriptor,__decorateClass$M=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$M(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$M(target,key,result),result},"__decorateClass$M"),__decorateParam$M=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$M");const AFFECT_LAYOUT_STYLES=["ff","fs","tr","tb"];var _a7;exports.AutoHeightController=(_a7=class extends core.Disposable{constructor(_renderManagerService,_sheetInterceptorService,_selectionManagerService,_univerInstanceService){super(),this._renderManagerService=_renderManagerService,this._sheetInterceptorService=_sheetInterceptorService,this._selectionManagerService=_selectionManagerService,this._univerInstanceService=_univerInstanceService,this._initialize()}getUndoRedoParamsOfAutoHeight(ranges){const{_univerInstanceService:univerInstanceService}=this,workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),sheetSkeletonService=this._renderManagerService.getRenderById(unitId).with(exports.SheetSkeletonManagerService);if(!subUnitId||!sheetSkeletonService.getCurrent())return{redos:[],undos:[]};const{skeleton}=sheetSkeletonService.getCurrent(),rowsAutoHeightInfo=skeleton.calculateAutoHeightInRange(ranges),redoParams={subUnitId,unitId,rowsAutoHeightInfo},undoParams=sheets.SetWorksheetRowAutoHeightMutationFactory(redoParams,worksheet);return{undos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:undoParams}],redos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:redoParams}]}}_initialize(){const{_sheetInterceptorService:sheetInterceptorService,_selectionManagerService:selectionManagerService}=this;this.disposeWithMe(sheetInterceptorService.interceptCommand({getMutations:__name(command=>command.id!==sheets.SetRangeValuesCommand.id?{redos:[],undos:[]}:this.getUndoRedoParamsOfAutoHeight(command.params.range),"getMutations")})),this.disposeWithMe(sheetInterceptorService.interceptCommand({getMutations:__name(command=>command.id!==sheets.SetWorksheetRowIsAutoHeightCommand.id?{redos:[],undos:[]}:this.getUndoRedoParamsOfAutoHeight(command.params.ranges),"getMutations")})),this.disposeWithMe(sheetInterceptorService.interceptCommand({getMutations:__name(command=>{var _a58,_b;if(command.id!==sheets.SetStyleCommand.id)return{redos:[],undos:[]};if(!AFFECT_LAYOUT_STYLES.includes((_a58=command.params)==null?void 0:_a58.style.type))return{redos:[],undos:[]};const selections=(_b=selectionManagerService.getCurrentSelections())==null?void 0:_b.map(s=>s.range);return selections!=null&&selections.length?this.getUndoRedoParamsOfAutoHeight(selections):{redos:[],undos:[]}},"getMutations")}))}},__name(_a7,"AutoHeightController"),_a7);exports.AutoHeightController=__decorateClass$M([__decorateParam$M(0,engineRender.IRenderManagerService),__decorateParam$M(1,core.Inject(sheets.SheetInterceptorService)),__decorateParam$M(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$M(3,core.Inject(core.IUniverInstanceService))],exports.AutoHeightController);function rangeToDiscreteRange(range,accessor,unitId,subUnitId){const univerInstanceService=accessor.get(core.IUniverInstanceService),workbook=unitId?univerInstanceService.getUnit(unitId,core.UniverInstanceType.UNIVER_SHEET):univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=subUnitId?workbook==null?void 0:workbook.getSheetBySheetId(subUnitId):workbook==null?void 0:workbook.getActiveSheet();if(!worksheet)return null;const{startRow,endRow,startColumn,endColumn}=range,rows=[],cols=[];for(let r2=startRow;r2<=endRow;r2++)worksheet.getRowFiltered(r2)||rows.push(r2);for(let c=startColumn;c<=endColumn;c++)cols.push(c);return{rows,cols}}__name(rangeToDiscreteRange,"rangeToDiscreteRange");function discreteRangeToRange(discreteRange){const{rows,cols}=discreteRange;return{startRow:rows[0],endRow:rows[rows.length-1],startColumn:cols[0],endColumn:cols[cols.length-1]}}__name(discreteRangeToRange,"discreteRangeToRange");function virtualizeDiscreteRanges(ranges){let totalRows=[],totalCols=[];const totalRanges=[];return ranges.forEach(r2=>{totalRows.push(...r2.rows),totalCols.push(...r2.cols)}),totalRows=Array.from(new Set(totalRows)).sort((a,b)=>a-b),totalCols=Array.from(new Set(totalCols)).sort((a,b)=>a-b),ranges.forEach(r2=>{totalRanges.push({startRow:totalRows.findIndex(row=>row===r2.rows[0]),endRow:totalRows.findIndex(row=>row===r2.rows[r2.rows.length-1]),startColumn:totalCols.findIndex(col=>col===r2.cols[0]),endColumn:totalCols.findIndex(col=>col===r2.cols[r2.cols.length-1])})}),{ranges:totalRanges,mapFunc:__name((row,col)=>({row:totalRows[row],col:totalCols[col]}),"mapFunc")}}__name(virtualizeDiscreteRanges,"virtualizeDiscreteRanges");function generateNullCellValueRowCol(range){const cellValue=new core.ObjectMatrix;return range.forEach(r2=>{const{rows,cols}=r2;rows.forEach(i=>{cols.forEach(j=>{cellValue.setValue(i,j,{v:null,p:null,f:null,si:null,custom:null})})})}),cellValue.getData()}__name(generateNullCellValueRowCol,"generateNullCellValueRowCol");const chnNumChar={零:0,一:1,二:2,三:3,四:4,五:5,六:6,七:7,八:8,九:9},chnNumChar2=["零","一","二","三","四","五","六","七","八","九"],chnUnitSection=["","万","亿","万亿","亿亿"],chnUnitChar=["","十","百","千"],chnNameValue={十:{value:10,secUnit:!1},百:{value:100,secUnit:!1},千:{value:1e3,secUnit:!1},万:{value:1e4,secUnit:!0},亿:{value:1e8,secUnit:!0}};function chineseToNumber(chnStr){if(!chnStr)return 0;let rtn=0,section=0,number=0,secUnit=!1;const str=chnStr.split("");for(let i=0;i<str.length;i++){const num=chnNumChar[str[i]];if(typeof num<"u")number=num,i===str.length-1&&(section+=number);else{const obj=chnNameValue[str[i]],unit=obj.value;secUnit=obj.secUnit,secUnit?(section=(section+number)*unit,rtn+=section,section=0):section+=number*unit,number=0}}return rtn+section}__name(chineseToNumber,"chineseToNumber");function sectionToChinese(section){let strIns="",chnStr="",unitPos=0,zero=!0;for(;section>0;){const v=section%10;v===0?zero||(zero=!0,chnStr=chnNumChar2[v]+chnStr):(zero=!1,strIns=chnNumChar2[v],strIns+=chnUnitChar[unitPos],chnStr=strIns+chnStr),unitPos++,section=Math.floor(section/10)}return chnStr}__name(sectionToChinese,"sectionToChinese");function numberToChinese(num){let unitPos=0,strIns="",chnStr="",needZero=!1;if(num===0)return chnNumChar2[0];for(;num>0;){const section=num%1e4;needZero&&(chnStr=chnNumChar2[0]+chnStr),strIns=sectionToChinese(section),strIns+=section!==0?chnUnitSection[unitPos]:chnUnitSection[0],chnStr=strIns+chnStr,needZero=section<1e3&&section>0,num=Math.floor(num/1e4),unitPos++}return chnStr}__name(numberToChinese,"numberToChinese");function isChnNumber(txt){if(!txt)return!1;let isChnNumber2=!0;if(txt)if(txt.length===1)txt==="日"||txt in chnNumChar?isChnNumber2=!0:isChnNumber2=!1;else{const str=txt.split("");for(let i=0;i<str.length;i++)if(!(str[i]in chnNumChar||str[i]in chnNameValue)){isChnNumber2=!1;break}}return isChnNumber2}__name(isChnNumber,"isChnNumber");function matchExtendNumber(txt){if(!txt)return{isExtendNumber:!1};const reg=/0|([1-9]+[0-9]*)/g,isExtendNumber=reg.test(txt);if(isExtendNumber){const match=txt.match(reg);if(match&&match.length>0){const matchTxt=match[match.length-1],matchIndex=txt.lastIndexOf(matchTxt),beforeTxt=txt.substr(0,matchIndex),afterTxt=txt.substr(matchIndex+matchTxt.length);return{isExtendNumber:!0,matchTxt:Number(matchTxt),beforeTxt,afterTxt}}return{isExtendNumber:!1}}return{isExtendNumber}}__name(matchExtendNumber,"matchExtendNumber");function isChnWeek2(txt){let isChnWeek22;return txt.length===2&&(txt==="周一"||txt==="周二"||txt==="周三"||txt==="周四"||txt==="周五"||txt==="周六"||txt==="周日")?isChnWeek22=!0:isChnWeek22=!1,isChnWeek22}__name(isChnWeek2,"isChnWeek2");function isChnWeek3(txt){let isChnWeek32;return txt.length===3&&(txt==="星期一"||txt==="星期二"||txt==="星期三"||txt==="星期四"||txt==="星期五"||txt==="星期六"||txt==="星期日")?isChnWeek32=!0:isChnWeek32=!1,isChnWeek32}__name(isChnWeek3,"isChnWeek3");function getLenS(indexArr,rsd){let s=0;for(let j=0;j<indexArr.length&&indexArr[j]<rsd;j++)s++;return s}__name(getLenS,"getLenS");function isEqualDiff(arr){let diff=!0;const step=arr[1]-arr[0];for(let i=1;i<arr.length;i++)if(arr[i]-arr[i-1]!==step){diff=!1;break}return diff}__name(isEqualDiff,"isEqualDiff");function getDataIndex(csLen,asLen,indexArr){const obj=[],num=Math.floor(asLen/csLen),rsd=asLen%csLen;let sum=0;if(num>0){for(let i=0;i<num;i++)for(let j=0;j<indexArr.length;j++)obj[indexArr[j]+i*csLen]=sum,sum++;for(let a=0;a<indexArr.length&&indexArr[a]<rsd;a++)obj[indexArr[a]+csLen*num]=sum,sum++}else for(let a=0;a<indexArr.length&&indexArr[a]<rsd;a++)obj[indexArr[a]]=sum,sum++;return obj}__name(getDataIndex,"getDataIndex");function fillCopy(data,len){const applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]);applyData.push({v:null,s:null,p:null,f:null,si:null,t:null,...d})}return applyData}__name(fillCopy,"fillCopy");function fillCopyStyles(data,len){var _a58;const applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d={s:(_a58=data[index])==null?void 0:_a58.s};applyData.push(d)}return applyData}__name(fillCopyStyles,"fillCopyStyles");function isEqualRatio(arr){let ratio=!0;const step=arr[1]/arr[0];for(let i=1;i<arr.length;i++)if(arr[i]/arr[i-1]!==step){ratio=!1;break}return ratio}__name(isEqualRatio,"isEqualRatio");function getXArr(len){const xArr=[];for(let i=1;i<=len;i++)xArr.push(i);return xArr}__name(getXArr,"getXArr");function fillSeries(data,len,direction){var _a58,_b,_c,_d;const applyData=[],dataNumArr=[];for(let j=0;j<data.length;j++)dataNumArr.push(Number((_a58=data[j])==null?void 0:_a58.v));if(data.length>2&&isEqualRatio(dataNumArr))for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),num=Number((_b=data[data.length-1])==null?void 0:_b.v)*(Number((_c=data[1])==null?void 0:_c.v)/Number((_d=data[0])==null?void 0:_d.v))**i;d&&(needsUpdateCellValue(d)&&(d.v=num),applyData.push(d))}else{const xArr=getXArr(data.length);for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),forward=direction===core.Direction.DOWN||direction===core.Direction.RIGHT,y=forecast(data.length+i,dataNumArr,xArr,forward);d&&(needsUpdateCellValue(d)&&(d.v=y),applyData.push(d))}}return applyData}__name(fillSeries,"fillSeries");function forecast(x,yArr,xArr,forward=!0){function getAverage(arr){let sum=0;for(let i=0;i<arr.length;i++)sum+=arr[i];return sum/arr.length}__name(getAverage,"getAverage");const ax=getAverage(xArr),ay=getAverage(yArr);let sum_d=0,sum_n=0;for(let j=0;j<xArr.length;j++)sum_d+=(xArr[j]-ax)*(yArr[j]-ay),sum_n+=(xArr[j]-ax)*(xArr[j]-ax);let b;sum_n===0?b=forward?1:-1:b=sum_d/sum_n;const a=ay-b*ax;return Math.round((a+b*x)*1e5)/1e5}__name(forecast,"forecast");function fillExtendNumber(data,len,step){var _a58;const applyData=[],reg=/0|([1-9]+[0-9]*)/g;for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),last=`${(_a58=data[data.length-1])==null?void 0:_a58.v}`,match=last==null?void 0:last.match(reg),lastTxt=match==null?void 0:match[match.length-1],num=Math.abs(Number(lastTxt)+step*i);if(!last||!lastTxt)continue;const lastIndex=last.lastIndexOf(lastTxt),valueTxt=last.substr(0,lastIndex)+num.toString()+last.substr(lastIndex+lastTxt.length);d&&(d.v=valueTxt,applyData.push(d))}return applyData}__name(fillExtendNumber,"fillExtendNumber");function fillChnWeek(data,len,step,weekType=0){var _a58,_b;const keywordMap=[["日","一","二","三","四","五","六"],["周日","周一","周二","周三","周四","周五","周六"],["星期日","星期一","星期二","星期三","星期四","星期五","星期六"]];if(weekType>=keywordMap.length)return[];const keyword=keywordMap[weekType],applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]);let num=0;if(((_a58=data[data.length-1])==null?void 0:_a58.v)===keyword[0])num=7+step*i;else{const last=`${(_b=data[data.length-1])==null?void 0:_b.v}`;if(last){const txt=last.substr(last.length-1,1);num=chineseToNumber(txt)+step*i}}num<0&&(num=Math.ceil(Math.abs(num)/7)*7+num);const rsd=num%7;d&&(d.v=keyword[rsd],applyData.push(d))}return applyData}__name(fillChnWeek,"fillChnWeek");function fillChnNumber(data,len,step){var _a58;const applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),formattedValue=`${(_a58=data[data.length-1])==null?void 0:_a58.v}`,num=chineseToNumber(formattedValue)+step*i;let txt;num<=0?txt="零":txt=numberToChinese(num),d&&(d.v=txt,applyData.push(d))}return applyData}__name(fillChnNumber,"fillChnNumber");const LOOP_SERIES={enWeek1:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],enWeek2:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],enMonth1:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],enMonth2:["January","February","March","April","May","June","July","August","September","October","November","December"],chnMonth1:["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],chnMonth2:["正月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","腊月"],chHour1:["子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥"],chHour2:["子时","丑时","寅时","卯时","辰时","巳时","午时","未时","申时","酉时","戌时","亥时"],chYear1:["甲","乙","丙","丁","戊","己","庚","辛","壬","癸"],chSeason1:["春","夏","秋","冬"],chSeason2:["春季","夏季","秋季","冬季"]};function isLoopSeries(txt){let isLoopSeries2=!1;return Object.keys(LOOP_SERIES).forEach(key=>{LOOP_SERIES[key].includes(txt)&&(isLoopSeries2=!0)}),isLoopSeries2}__name(isLoopSeries,"isLoopSeries");function getLoopSeriesInfo(txt){let name="";const series=[];return Object.keys(LOOP_SERIES).forEach(key=>{LOOP_SERIES[key].includes(txt)&&(name=key,series.push(...LOOP_SERIES[key]))}),{name,series}}__name(getLoopSeriesInfo,"getLoopSeriesInfo");function fillLoopSeries(data,len,step,series){var _a58;const seriesLen=series.length,applyData=[];for(let i=1;i<=len;i++){const index=(i-1)%data.length,d=core.Tools.deepClone(data[index]),last=`${(_a58=data[data.length-1])==null?void 0:_a58.v}`;let num=series.indexOf(last)+step*i;num<0&&(num+=Math.abs(step)*seriesLen);const rsd=num%seriesLen;d&&(d.v=series[rsd],applyData.push(d))}return applyData}__name(fillLoopSeries,"fillLoopSeries");function getAutoFillRepeatRange(sourceRange,targetRange){const repeats=[];let direction;if(targetRange.startRow<sourceRange.startRow)direction=core.Direction.UP;else if(targetRange.endRow>sourceRange.endRow)direction=core.Direction.DOWN;else if(targetRange.startColumn<sourceRange.startColumn)direction=core.Direction.LEFT;else if(targetRange.endColumn>sourceRange.endColumn)direction=core.Direction.RIGHT;else return[];if(direction===core.Direction.DOWN||direction===core.Direction.UP){const sourceLength=sourceRange.endRow-sourceRange.startRow+1,targetLength=targetRange.endRow-targetRange.startRow+1,mod=Math.floor(targetLength/sourceLength),rest=targetLength%sourceLength,relativeRange={startRow:0,startColumn:0,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:sourceRange.endColumn-sourceRange.startColumn};if(direction===core.Direction.DOWN){for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow+(i+1)*sourceLength,col:sourceRange.startColumn},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow+(mod+1)*sourceLength,col:sourceRange.startColumn},relativeRange:{startRow:0,startColumn:0,endRow:rest-1,endColumn:sourceRange.endColumn-sourceRange.startColumn}})}else{for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow-(i+1)*sourceLength,col:sourceRange.startColumn},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow-(mod+1)*sourceLength,col:sourceRange.startColumn},relativeRange:{startRow:sourceLength-rest,endRow:sourceLength-1,startColumn:0,endColumn:sourceRange.endColumn-sourceRange.startColumn}})}}if(direction===core.Direction.RIGHT||direction===core.Direction.LEFT){const sourceLength=sourceRange.endColumn-sourceRange.startColumn+1,targetLength=targetRange.endColumn-targetRange.startColumn+1,mod=Math.floor(targetLength/sourceLength),rest=targetLength%sourceLength,relativeRange={startRow:0,startColumn:0,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:sourceRange.endColumn-sourceRange.startColumn};if(direction===core.Direction.RIGHT){for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn+(i+1)*sourceLength},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn+(mod+1)*sourceLength},relativeRange:{startRow:0,startColumn:0,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:rest-1}})}else{for(let i=0;i<mod;i++)repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn-(i+1)*sourceLength},relativeRange});rest>0&&repeats.push({repeatStartCell:{row:sourceRange.startRow,col:sourceRange.startColumn-(mod+1)*sourceLength},relativeRange:{startRow:0,startColumn:sourceLength-rest,endRow:sourceRange.endRow-sourceRange.startRow,endColumn:sourceLength-1}})}}return repeats}__name(getAutoFillRepeatRange,"getAutoFillRepeatRange");function needsUpdateCellValue(cell){return!(core.isFormulaString(cell.f)||core.isFormulaId(cell.si)||cell.t===core.CellValueType.BOOLEAN)}__name(needsUpdateCellValue,"needsUpdateCellValue");var AutoFillHookType=(AutoFillHookType2=>(AutoFillHookType2.Append="APPEND",AutoFillHookType2.Default="DEFAULT",AutoFillHookType2.Only="ONLY",AutoFillHookType2))(AutoFillHookType||{}),DATA_TYPE=(DATA_TYPE2=>(DATA_TYPE2.NUMBER="number",DATA_TYPE2.DATE="date",DATA_TYPE2.EXTEND_NUMBER="extendNumber",DATA_TYPE2.CHN_NUMBER="chnNumber",DATA_TYPE2.CHN_WEEK2="chnWeek2",DATA_TYPE2.CHN_WEEK3="chnWeek3",DATA_TYPE2.LOOP_SERIES="loopSeries",DATA_TYPE2.FORMULA="formula",DATA_TYPE2.OTHER="other",DATA_TYPE2))(DATA_TYPE||{}),APPLY_TYPE=(APPLY_TYPE2=>(APPLY_TYPE2.COPY="COPY",APPLY_TYPE2.SERIES="SERIES",APPLY_TYPE2.ONLY_FORMAT="ONLY_FORMAT",APPLY_TYPE2.NO_FORMAT="NO_FORMAT",APPLY_TYPE2))(APPLY_TYPE||{});const dateRule={type:DATA_TYPE.DATE,priority:1100,match:__name((cellData,accessor)=>{var _a58;if(cellData!=null&&cellData.f||cellData!=null&&cellData.si)return!1;if((typeof(cellData==null?void 0:cellData.v)=="number"||(cellData==null?void 0:cellData.t)===core.CellValueType.NUMBER)&&cellData.s){if(typeof cellData.s=="string"){const style=accessor.get(core.IUniverInstanceService).getFocusedUnit().getStyles().get(cellData.s),pattern=(_a58=style==null?void 0:style.n)==null?void 0:_a58.pattern;if(pattern)return core.numfmt.getInfo(pattern).isDate}else if(cellData.s.n&&core.numfmt.getInfo(cellData.s.n.pattern).isDate)return!0}return!1},"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.DATE,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{const{data}=dataWithIndex;return direction===core.Direction.LEFT||direction===core.Direction.UP?(data.reverse(),fillSeries(data,len,direction).reverse()):fillSeries(data,len,direction)}}},numberRule={type:DATA_TYPE.NUMBER,priority:1e3,match:__name(cellData=>typeof(cellData==null?void 0:cellData.v)=="number"||(cellData==null?void 0:cellData.t)===core.CellValueType.NUMBER,"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.NUMBER,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{const{data}=dataWithIndex;return direction===core.Direction.LEFT||direction===core.Direction.UP?(data.reverse(),fillSeries(data,len,direction).reverse()):fillSeries(data,len,direction)}}},otherRule={type:DATA_TYPE.OTHER,priority:0,match:__name(()=>!0,"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.OTHER,"isContinue")},extendNumberRule={type:DATA_TYPE.EXTEND_NUMBER,priority:900,match:__name(cellData=>matchExtendNumber(`${cellData==null?void 0:cellData.v}`||"").isExtendNumber,"match"),isContinue:__name((prev,cur)=>{var _a58;if(prev.type===DATA_TYPE.EXTEND_NUMBER){const{beforeTxt,afterTxt}=matchExtendNumber(`${(_a58=prev.cellData)==null?void 0:_a58.v}`||""),{beforeTxt:curBeforeTxt,afterTxt:curAfterTxt}=matchExtendNumber(`${cur==null?void 0:cur.v}`||"");if(beforeTxt===curBeforeTxt&&afterTxt===curAfterTxt)return!0}return!1},"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58;const{data}=dataWithIndex,isReverse=direction===core.Direction.UP||direction===core.Direction.LEFT;let step;if(data.length===1)return step=isReverse?-1:1,reverseIfNeed(fillExtendNumber(data,len,step),isReverse);const dataNumArr=[];for(let i=0;i<data.length;i++){const txt=`${(_a58=data[i])==null?void 0:_a58.v}`;txt&&dataNumArr.push(Number(matchExtendNumber(txt).matchTxt))}return isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)?(step=dataNumArr[1]-dataNumArr[0],reverseIfNeed(fillExtendNumber(data,len,step),isReverse)):fillCopy(data,len)}}},chnNumberRule={type:DATA_TYPE.CHN_NUMBER,priority:830,match:__name(cellData=>!!isChnNumber(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.CHN_NUMBER,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58,_b,_c;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP;if(data.length===1){const formattedValue=`${(_a58=data[0])==null?void 0:_a58.v}`;let step;return isReverse?step=-1:step=1,formattedValue&&(formattedValue==="日"||chineseToNumber(formattedValue)<7)?reverseIfNeed(fillChnWeek(data,len,step),isReverse):reverseIfNeed(fillChnNumber(data,len,step),isReverse)}let hasWeek=!1;for(let i=0;i<data.length;i++)if(((_b=data[i])==null?void 0:_b.v)==="日"){hasWeek=!0;break}const dataNumArr=[];let weekIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_c=data[i])==null?void 0:_c.v}`;formattedValue==="日"?i===0?dataNumArr.push(0):(weekIndex++,dataNumArr.push(weekIndex*7)):hasWeek&&chineseToNumber(formattedValue)>0&&chineseToNumber(formattedValue)<7?dataNumArr.push(chineseToNumber(formattedValue)+weekIndex*7):dataNumArr.push(chineseToNumber(formattedValue))}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){if(hasWeek||dataNumArr[dataNumArr.length-1]<6&&dataNumArr[0]>0||dataNumArr[0]<6&&dataNumArr[dataNumArr.length-1]>0){const step2=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnWeek(data,len,step2),isReverse)}const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnNumber(data,len,step),isReverse)}return fillCopy(data,len)}}},chnWeek2Rule={type:DATA_TYPE.CHN_WEEK2,priority:820,match:__name(cellData=>!!isChnWeek2(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.CHN_WEEK2,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP;if(data.length===1){let step;return isReverse?step=-1:step=1,reverseIfNeed(fillChnWeek(data,len,step,1),isReverse)}const dataNumArr=[];let weekIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_a58=data[i])==null?void 0:_a58.v}`,lastTxt=formattedValue==null?void 0:formattedValue.substr(formattedValue.length-1,1);formattedValue==="周日"?i===0?dataNumArr.push(0):(weekIndex++,dataNumArr.push(weekIndex*7)):dataNumArr.push(chineseToNumber(lastTxt)+weekIndex*7)}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnWeek(data,len,step,1),isReverse)}return fillCopy(data,len)}}},chnWeek3Rule={type:DATA_TYPE.CHN_WEEK3,priority:810,match:__name(cellData=>isChnWeek3(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>prev.type===DATA_TYPE.CHN_WEEK3,"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP;if(data.length===1){let step;return isReverse?step=-1:step=1,reverseIfNeed(fillChnWeek(data,len,step,2),isReverse)}const dataNumArr=[];let weekIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_a58=data[i])==null?void 0:_a58.v}`;if(formattedValue){const lastTxt=formattedValue.substr(formattedValue.length-1,1);formattedValue==="星期日"?i===0?dataNumArr.push(0):(weekIndex++,dataNumArr.push(weekIndex*7)):dataNumArr.push(chineseToNumber(lastTxt)+weekIndex*7)}}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillChnWeek(data,len,step,2),isReverse)}return fillCopy(data,len)}}},loopSeriesRule={type:DATA_TYPE.LOOP_SERIES,priority:800,match:__name(cellData=>isLoopSeries(`${cellData==null?void 0:cellData.v}`||""),"match"),isContinue:__name((prev,cur)=>{var _a58;return prev.type===DATA_TYPE.LOOP_SERIES?getLoopSeriesInfo(`${(_a58=prev.cellData)==null?void 0:_a58.v}`||"").name===getLoopSeriesInfo(`${cur==null?void 0:cur.v}`||"").name:!1},"isContinue"),applyFunctions:{[APPLY_TYPE.SERIES]:(dataWithIndex,len,direction)=>{var _a58,_b;const{data}=dataWithIndex,isReverse=direction===core.Direction.LEFT||direction===core.Direction.UP,{series}=getLoopSeriesInfo(`${(_a58=data[0])==null?void 0:_a58.v}`||"");if(data.length===1){let step;return isReverse?step=-1:step=1,reverseIfNeed(fillLoopSeries(data,len,step,series),isReverse)}const dataNumArr=[];let cycleIndex=0;for(let i=0;i<data.length;i++){const formattedValue=`${(_b=data[i])==null?void 0:_b.v}`;formattedValue&&(formattedValue===series[0]?i===0?dataNumArr.push(0):(cycleIndex++,dataNumArr.push(cycleIndex*series.length)):dataNumArr.push(series.indexOf(formattedValue)+cycleIndex*7))}if(isReverse&&(data.reverse(),dataNumArr.reverse()),isEqualDiff(dataNumArr)){const step=dataNumArr[1]-dataNumArr[0];return reverseIfNeed(fillLoopSeries(data,len,step,series),isReverse)}return fillCopy(data,len)}}};function reverseIfNeed(data,reverse){return reverse?data.reverse():data}__name(reverseIfNeed,"reverseIfNeed");var __defProp$L=Object.defineProperty,__getOwnPropDesc$L=Object.getOwnPropertyDescriptor,__decorateClass$L=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$L(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$L(target,key,result),result},"__decorateClass$L"),__decorateParam$L=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$L"),_a8;exports.AutoFillService=(_a8=class extends core.Disposable{constructor(_commandService,_undoRedoService,_renderManagerService,_univerInstanceService,_selectionManagerService,_injector){super();__publicField(this,"_rules",[]);__publicField(this,"_hooks",[]);__publicField(this,"_applyType$",new rxjs.BehaviorSubject(APPLY_TYPE.SERIES));__publicField(this,"_isFillingStyle",!0);__publicField(this,"_prevUndos",[]);__publicField(this,"_autoFillLocation$",new rxjs.BehaviorSubject(null));__publicField(this,"autoFillLocation$",this._autoFillLocation$.asObservable());__publicField(this,"_showMenu$",new rxjs.BehaviorSubject(!1));__publicField(this,"showMenu$",this._showMenu$.asObservable());__publicField(this,"_direction",core.Direction.DOWN);__publicField(this,"applyType$",this._applyType$.asObservable());__publicField(this,"_menu$",new rxjs.BehaviorSubject([{label:"autoFill.copy",value:APPLY_TYPE.COPY,disable:!1},{label:"autoFill.series",value:APPLY_TYPE.SERIES,disable:!1},{label:"autoFill.formatOnly",value:APPLY_TYPE.ONLY_FORMAT,disable:!1},{label:"autoFill.noFormat",value:APPLY_TYPE.NO_FORMAT,disable:!1}]));__publicField(this,"menu$",this._menu$.asObservable());this._commandService=_commandService,this._undoRedoService=_undoRedoService,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._injector=_injector,this._init()}_init(){this._rules=[dateRule,numberRule,extendNumberRule,chnNumberRule,chnWeek2Rule,chnWeek3Rule,loopSeriesRule,otherRule].sort((a,b)=>b.priority-a.priority),this._isFillingStyle=!0}_getOneByPriority(items){return items.length<=0?[]:[items.reduce((maxItem,currentItem)=>(currentItem.priority||0)>(maxItem.priority||0)?currentItem:maxItem,items[0])]}initPrevUndo(){this._prevUndos=[]}addHook(hook){if(this._hooks.find(h=>h.id===hook.id))throw new Error(`Add hook failed, hook id '${hook.id}' already exist!`);return hook.priority===void 0&&(hook.priority=0),hook.type===void 0&&(hook.type=AutoFillHookType.Append),this._hooks.push(hook),core.toDisposable(()=>{const index=this._hooks.findIndex(item=>item===hook);index>-1&&this._hooks.splice(index,1)})}registerRule(rule){if(this._rules.find(r2=>r2.type===rule.type))throw new Error(`Registry rule failed, type '${rule.type}' already exist!`);const index=this._rules.findIndex(r2=>r2.priority<rule.priority);this._rules.splice(index===-1?this._rules.length:index,0,rule)}getRules(){return this._rules}getAllHooks(){return this._hooks}getActiveHooks(){const{source,target,unitId,subUnitId}=this.autoFillLocation||{};if(!source||!target||!unitId||!subUnitId)return[];const enabledHooks=this._hooks.filter(h=>{var _a58;return!((_a58=h.disable)!=null&&_a58.call(h,{source,target,unitId,subUnitId},this._direction,this.applyType))}),onlyHooks=enabledHooks.filter(h=>h.type===AutoFillHookType.Only);if(onlyHooks.length>0)return this._getOneByPriority(onlyHooks);const defaultHooks=this._getOneByPriority(enabledHooks.filter(h=>h.type===AutoFillHookType.Default)),appendHooks=enabledHooks.filter(h=>h.type===AutoFillHookType.Append)||[];return[...defaultHooks,...appendHooks]}get applyType(){return this._applyType$.getValue()}set applyType(type){this._applyType$.next(type)}get menu(){return this._menu$.getValue()}get direction(){return this._direction}set direction(direction){this._direction=direction}isFillingStyle(){return this._isFillingStyle}setFillingStyle(isFillingStyle){this._isFillingStyle=isFillingStyle}get autoFillLocation(){return this._autoFillLocation$.getValue()}set autoFillLocation(location){this._autoFillLocation$.next(location)}setDisableApplyType(type,disable){this._menu$.next(this._menu$.getValue().map(item=>item.value===type?{...item,disable}:item))}setShowMenu(show){this._showMenu$.next(show)}fillData(triggerUnitId,triggerSubUnitId){var _a58,_b,_c;const{source,target,unitId=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId(),subUnitId=(_a58=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet())==null?void 0:_a58.getSheetId()}=this.autoFillLocation||{},direction=this.direction;if(!source||!source.cols.length||!source.rows.length||!target||!target.cols.length||!target.rows.length||unitId!==triggerUnitId||subUnitId!==triggerSubUnitId)return!1;this._prevUndos.length>0&&this._prevUndos.forEach(undo=>{this._commandService.syncExecuteCommand(undo.id,undo.params)}),this._prevUndos=[];const selection=core.Rectangle.union(discreteRangeToRange(source),discreteRangeToRange(target)),applyType=this.applyType,activeHooks=this.getActiveHooks();this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,{selections:[{primary:{...(_c=(_b=this._selectionManagerService.getCurrentLastSelection())==null?void 0:_b.primary)!=null?_c:selection},range:{...selection,rangeType:core.RANGE_TYPE.NORMAL}}],unitId,subUnitId});const undos=[],redos=[];activeHooks.forEach(hook=>{var _a59;const{undos:hookUndos,redos:hookRedos}=((_a59=hook.onFillData)==null?void 0:_a59.call(hook,{source,target,unitId,subUnitId},direction,applyType))||{};hookUndos&&undos.push(...hookUndos),hookRedos&&redos.push(...hookRedos)});const result=redos.every(m2=>this._commandService.syncExecuteCommand(m2.id,m2.params)),autoHeightRanges=[];applyType!==APPLY_TYPE.NO_FORMAT&&redos.forEach(m2=>{if(m2.id===sheets.SetRangeValuesMutation.id){const{cellValue}=m2.params;new core.ObjectMatrix(cellValue).forValue((row,col,value)=>{const style=Object.keys((value==null?void 0:value.s)||{});style.length&&AFFECT_LAYOUT_STYLES.some(s=>style.includes(s))&&autoHeightRanges.push({startRow:row,endRow:row,startColumn:col,endColumn:col})})}});const autoHeightUndoRedos=this._getAutoHeightUndoRedos(triggerUnitId,triggerSubUnitId,autoHeightRanges);return autoHeightUndoRedos.redos.every(m2=>this._commandService.syncExecuteCommand(m2.id,m2.params))&&(undos.push(...autoHeightUndoRedos.undos),redos.push(...autoHeightUndoRedos.redos)),result&&(this._prevUndos=undos,this._undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undos,redoMutations:redos})),activeHooks.forEach(hook=>{var _a59;(_a59=hook.onAfterFillData)==null||_a59.call(hook,{source,target,unitId,subUnitId},direction,applyType)}),this.setShowMenu(!0),!0}_getAutoHeightUndoRedos(unitId,subUnitId,ranges){var _a58,_b;const sheetSkeletonService=(_a58=this._renderManagerService.getRenderById(unitId))==null?void 0:_a58.with(exports.SheetSkeletonManagerService),skeleton=(_b=sheetSkeletonService==null?void 0:sheetSkeletonService.getCurrent())==null?void 0:_b.skeleton;if(!skeleton)return{redos:[],undos:[]};const rowsAutoHeightInfo=skeleton.calculateAutoHeightInRange(ranges),redoParams={subUnitId,unitId,rowsAutoHeightInfo},worksheet=skeleton.worksheet,undoParams=sheets.SetWorksheetRowAutoHeightMutationFactory(redoParams,worksheet);return{undos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:undoParams}],redos:[{id:sheets.SetWorksheetRowAutoHeightMutation.id,params:redoParams}]}}},__name(_a8,"AutoFillService"),_a8);exports.AutoFillService=__decorateClass$L([__decorateParam$L(0,core.ICommandService),__decorateParam$L(1,core.IUndoRedoService),__decorateParam$L(2,engineRender.IRenderManagerService),__decorateParam$L(3,core.Inject(core.IUniverInstanceService)),__decorateParam$L(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$L(5,core.Inject(core.Injector))],exports.AutoFillService);const IAutoFillService=core.createIdentifier("univer.auto-fill-service"),AutoFillCommand={type:core.CommandType.COMMAND,id:"sheet.command.auto-fill",handler:__name(async(accessor,params)=>accessor.get(IAutoFillService).fillData(params.unitId,params.subUnitId),"handler")},AutoClearContentCommand={id:"sheet.command.auto-clear-content",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target,{clearRange,selectionRange}=params,clearMutationParams={subUnitId,unitId,cellValue:sheets.generateNullCellValue([clearRange])},undoClearMutationParams=sheets.SetRangeValuesUndoMutationFactory(accessor,clearMutationParams),{startColumn,startRow}=selectionRange;return commandService.executeCommand(sheets.SetSelectionsOperation.id,{selections:[{primary:{startColumn,startRow,endColumn:startColumn,endRow:startRow,actualRow:startRow,actualColumn:startColumn,isMerge:!1,isMergedMainCell:!1},range:{...selectionRange}}],unitId,subUnitId}),commandService.syncExecuteCommand(sheets.SetRangeValuesMutation.id,clearMutationParams)?(undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:sheets.SetRangeValuesMutation.id,params:undoClearMutationParams}],redoMutations:[{id:sheets.SetRangeValuesMutation.id,params:clearMutationParams}]}),!0):!1},"handler")},SetCellEditVisibleOperation={id:"sheet.operation.set-cell-edit-visible",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>params?(accessor.get(IEditorBridgeService).changeVisible(params),!0):!1,"handler")},SetCellEditVisibleWithF2Operation={id:"sheet.operation.set-cell-edit-visible-f2",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>(accessor.get(core.ICommandService).syncExecuteCommand(SetCellEditVisibleOperation.id,params),!0),"handler")},SetCellEditVisibleArrowOperation={id:"sheet.operation.set-cell-edit-visible-arrow",type:core.CommandType.OPERATION,handler:__name(()=>!0,"handler")},ChangeZoomRatioCommand={id:"sheet.command.change-zoom-ratio",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet,subUnitId,unitId}=target,{delta,reset}=params;let zoom=reset?100:Math.round((worksheet.getConfig().zoomRatio+delta)*100);zoom=Math.max(SHEET_ZOOM_RANGE[0],zoom),zoom=Math.min(SHEET_ZOOM_RANGE[1],zoom);const zoomRatio=zoom/100,state=accessor.get(IEditorBridgeService).isVisible();return(state.unitId===unitId||state.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)&&state.visible?!1:accessor.get(core.ICommandService).executeCommand(SetZoomRatioOperation.id,{unitId,subUnitId,zoomRatio})},"handler")},SetZoomRatioCommand={id:"sheet.command.set-zoom-ratio",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{if(!params)return!1;const{unitId,subUnitId,zoomRatio}=params,state=accessor.get(IEditorBridgeService).isVisible();return(state.unitId===unitId||state.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)&&state.visible?!1:accessor.get(core.ICommandService).executeCommand(SetZoomRatioOperation.id,{unitId,subUnitId,zoomRatio})},"handler")};var __defProp$K=Object.defineProperty,__getOwnPropDesc$K=Object.getOwnPropertyDescriptor,__decorateClass$K=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$K(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$K(target,key,result),result},"__decorateClass$K"),__decorateParam$K=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$K"),_a9;let SheetsZoomRenderController=(_a9=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_commandService,_contextService,_editorBridgeService){super(),this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._commandService=_commandService,this._contextService=_contextService,this._editorBridgeService=_editorBridgeService,this._initSkeletonListener(),this._initZoomEventListener()}updateZoom(worksheetId,zoomRatio){const worksheet=this._context.unit.getSheetBySheetId(worksheetId);return worksheet?(worksheet.getConfig().zoomRatio=zoomRatio,worksheet===this._context.unit.getActiveSheet()&&this._updateViewZoom(zoomRatio),!0):!1}_initZoomEventListener(){const scene=this._getSheetObject().scene;this.disposeWithMe(scene.onMouseWheel$.subscribeEvent(e=>{if(!e.ctrlKey||!this._contextService.getContextValue(core.FOCUSING_SHEET))return;if(this._editorBridgeService){const state=this._editorBridgeService.isVisible();if((state.unitId===this._context.unitId||state.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY)&&state.visible)return}const deltaFactor=Math.abs(e.deltaX);let ratioDelta=deltaFactor<40?.2:deltaFactor<80?.4:.2;ratioDelta*=e.deltaY>0?-1:1,scene.scaleX<1&&(ratioDelta/=2);const workbook=this._context.unit,sheet=workbook.getActiveSheet();if(!sheet)return;const currentRatio=sheet.getZoomRatio();let nextRatio=+Number.parseFloat(`${currentRatio+ratioDelta}`).toFixed(1);nextRatio=nextRatio>=4?4:nextRatio<=.1?.1:nextRatio,this._commandService.executeCommand(SetZoomRatioCommand.id,{zoomRatio:Math.round(nextRatio*10)/10,unitId:workbook.getUnitId(),subUnitId:sheet.getSheetId()}),e.preventDefault()}))}_initSkeletonListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeletonBefore$.subscribe(param=>{if(param==null)return;const worksheet=this._context.unit.getActiveSheet();if(!worksheet)return;const zoomRatio=worksheet.getZoomRatio()||1;this._updateViewZoom(zoomRatio)}))}_updateViewZoom(zoomRatio){const sheetObject=this._getSheetObject();sheetObject==null||sheetObject.scene.scale(zoomRatio,zoomRatio),sheetObject==null||sheetObject.spreadsheet.makeForceDirty()}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}},__name(_a9,"SheetsZoomRenderController"),_a9);SheetsZoomRenderController=__decorateClass$K([__decorateParam$K(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$K(2,core.ICommandService),__decorateParam$K(3,core.IContextService),__decorateParam$K(4,core.Optional(IEditorBridgeService))],SheetsZoomRenderController);const SetZoomRatioOperation={id:"sheet.operation.set-zoom-ratio",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{const renderUnit=accessor.get(engineRender.IRenderManagerService).getRenderById(params.unitId);return renderUnit?renderUnit.with(SheetsZoomRenderController).updateZoom(params.subUnitId,params.zoomRatio):!1},"handler")};var __defProp$J=Object.defineProperty,__getOwnPropDesc$J=Object.getOwnPropertyDescriptor,__decorateClass$J=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$J(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$J(target,key,result),result},"__decorateClass$J"),__decorateParam$J=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$J"),_a10;exports.AutoFillController=(_a10=class extends core.Disposable{constructor(_univerInstanceService,_commandService,_autoFillService,_editorBridgeService,_renderManagerService,_injector,_sheetsRenderService){super();__publicField(this,"_beforeApplyData",[]);__publicField(this,"_currentLocation",null);__publicField(this,"_copyData",[]);__publicField(this,"_defaultHook");this._univerInstanceService=_univerInstanceService,this._commandService=_commandService,this._autoFillService=_autoFillService,this._editorBridgeService=_editorBridgeService,this._renderManagerService=_renderManagerService,this._injector=_injector,this._sheetsRenderService=_sheetsRenderService,this._defaultHook={id:"default",type:AutoFillHookType.Default,priority:0,onBeforeFillData:__name((location,direction)=>this._presetAndCacheData(location,direction),"onBeforeFillData"),onFillData:__name((location,direction,applyType)=>this._fillData(location,direction,applyType),"onFillData")},this._init()}_init(){this._initDefaultHook(),this._onSelectionControlFillChanged(),this._onApplyTypeChanged(),this._initQuitListener(),this._initSkeletonChange()}_initSkeletonChange(){this.disposeWithMe(this._sheetsRenderService.registerSkeletonChangingMutations(AutoFillCommand.id))}_initDefaultHook(){this.disposeWithMe(this._autoFillService.addHook(this._defaultHook))}_initQuitListener(){const quitCommands=[SetCellEditVisibleOperation.id,AutoClearContentCommand.id,sheets.SetRangeValuesCommand.id,SetZoomRatioOperation.id,sheets.SetWorksheetActiveOperation.id,sheets.MoveRangeMutation.id,sheets.RemoveRowMutation.id,sheets.RemoveColMutation.id,sheets.InsertRowMutation.id,sheets.InsertColMutation.id,sheets.MoveRowsMutation.id,sheets.MoveColsMutation.id,sheets.SetWorksheetColWidthMutation.id,sheets.SetWorksheetRowHeightMutation.id,sheets.SetRangeValuesMutation.id];this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{var _a58,_b;const fromCollab=options==null?void 0:options.fromCollab,fromSync=options==null?void 0:options.fromSync,fromFormula=options==null?void 0:options.fromFormula;quitCommands.includes(command.id)&&!fromCollab&&!fromSync&&!fromFormula&&command.params.trigger!==AutoFillCommand.id&&this._quit(),command.id===sheets.RemoveSheetMutation.id&&command.params.unitId===((_a58=this._currentLocation)==null?void 0:_a58.unitId)&&command.params.subUnitId===((_b=this._currentLocation)==null?void 0:_b.subUnitId)&&this._quit()})),this.disposeWithMe(this._univerInstanceService.unitDisposed$.subscribe(unit=>{var _a58;unit.getUnitId()===((_a58=this._currentLocation)==null?void 0:_a58.unitId)&&this._quit()}))}_quit(){this._currentLocation=null,this._beforeApplyData=[],this._copyData=[],this._autoFillService.setShowMenu(!1)}_onSelectionControlFillChanged(){const disposableCollection=new core.DisposableCollection,addListener=__name(disposableCollection2=>{disposableCollection2.dispose();const currentRenderer=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_SHEET);if(!currentRenderer)return;currentRenderer.with(ISheetSelectionRenderService).getSelectionControls().forEach(controlSelection=>{disposableCollection2.add(core.toDisposable(controlSelection.selectionFilled$.subscribe(filled=>{if(filled==null||filled.startColumn===-1||filled.startRow===-1||filled.endColumn===-1||filled.endRow===-1)return;const source={startColumn:controlSelection.model.startColumn,endColumn:controlSelection.model.endColumn,startRow:controlSelection.model.startRow,endRow:controlSelection.model.endRow},selection={startColumn:filled.startColumn,endColumn:filled.endColumn,startRow:filled.startRow,endRow:filled.endRow};this._triggerAutoFill(source,selection)}))),disposableCollection2.add(core.toDisposable(controlSelection.fillControl.onDblclick$.subscribeEvent(()=>{const source={startColumn:controlSelection.model.startColumn,endColumn:controlSelection.model.endColumn,startRow:controlSelection.model.startRow,endRow:controlSelection.model.endRow};this._handleDbClickFill(source)}))),disposableCollection2.add(core.toDisposable(controlSelection.fillControl.onPointerDown$.subscribeEvent(()=>{this._editorBridgeService.isVisible().visible&&this._editorBridgeService.changeVisible({visible:!1,eventType:engineRender.DeviceInputEventType.PointerDown,unitId:currentRenderer.unitId})})))})},"addListener");addListener(disposableCollection),this.disposeWithMe(this._commandService.onCommandExecuted(command=>{command.id===sheets.SetSelectionsOperation.id&&addListener(disposableCollection)}))}_onApplyTypeChanged(){this.disposeWithMe(core.toDisposable(this._autoFillService.applyType$.subscribe(()=>{this._handleFillData()})))}_triggerAutoFill(source,selection){var _a58,_b;if(source.startColumn===selection.startColumn&&source.startRow===selection.startRow&&source.endColumn===selection.endColumn&&source.endRow===selection.endRow)return;if(selection.endColumn<source.endColumn&&selection.endColumn>source.startColumn){this._commandService.executeCommand(AutoClearContentCommand.id,{clearRange:{startRow:selection.startRow,endRow:selection.endRow,startColumn:selection.endColumn+1,endColumn:source.endColumn},selectionRange:selection});return}if(selection.endRow<source.endRow&&selection.endRow>source.startRow){this._commandService.executeCommand(AutoClearContentCommand.id,{clearRange:{startRow:selection.endRow+1,endRow:source.endRow,startColumn:selection.startColumn,endColumn:selection.endColumn},selectionRange:selection});return}const target={startRow:selection.startRow,endRow:selection.endRow,startColumn:selection.startColumn,endColumn:selection.endColumn};let direction=null;if(selection.startRow<source.startRow)direction=core.Direction.UP,target.endRow=source.startRow-1;else if(selection.endRow>source.endRow)direction=core.Direction.DOWN,target.startRow=source.endRow+1;else if(selection.startColumn<source.startColumn)direction=core.Direction.LEFT,target.endColumn=source.startColumn-1;else if(selection.endColumn>source.endColumn)direction=core.Direction.RIGHT,target.startColumn=source.endColumn+1;else return;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!workbook)return;const unitId=workbook.getUnitId(),subUnitId=(_a58=workbook.getActiveSheet())==null?void 0:_a58.getSheetId();if(!subUnitId)return;this._autoFillService.direction=direction;const autoFillSource=this._injector.invoke(accessor=>rangeToDiscreteRange(source,accessor)),autoFillTarget=this._injector.invoke(accessor=>rangeToDiscreteRange(target,accessor));if(!autoFillSource||!autoFillTarget)return;this._autoFillService.autoFillLocation={source:autoFillSource,target:autoFillTarget,unitId,subUnitId};const preferTypes=[];this._autoFillService.getActiveHooks().forEach(hook=>{var _a59;const type=(_a59=hook==null?void 0:hook.onBeforeFillData)==null?void 0:_a59.call(hook,{source:autoFillSource,target:autoFillTarget,unitId,subUnitId},direction);type&&preferTypes.unshift(type)}),this._autoFillService.initPrevUndo();for(let i=0;i<preferTypes.length;i++){const menuItem=this._autoFillService.menu.find(m2=>m2.value===preferTypes[i]);if(menuItem&&!menuItem.disable){this._autoFillService.applyType=preferTypes[i];return}}const first=(_b=this._autoFillService.menu.find(m2=>m2.disable===!1))==null?void 0:_b.value;first&&(this._autoFillService.applyType=first)}_handleDbClickFill(source){const selection=this._detectFillRange(source);selection.endRow<=source.endRow||this._triggerAutoFill(source,selection)}_detectFillRange(source){var _a58,_b,_c,_d,_e,_f;const{startRow,endRow,startColumn,endColumn}=source,worksheet=(_a58=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET))==null?void 0:_a58.getActiveSheet();if(!worksheet)return source;const matrix=worksheet.getCellMatrix(),maxRow=worksheet.getMaxRows()-1,maxColumn=worksheet.getMaxColumns()-1;let detectEndRow=endRow;if(startColumn>0&&((_b=matrix.getValue(startRow,startColumn-1))==null?void 0:_b.v)!=null){let cur=startRow;for(;((_c=matrix.getValue(cur,startColumn-1))==null?void 0:_c.v)!=null&&cur<maxRow;)cur+=1;detectEndRow=cur-1}else if(endColumn<maxColumn&&((_d=matrix.getValue(endRow,endColumn+1))==null?void 0:_d.v)!=null){let cur=startRow;for(;((_e=matrix.getValue(cur,endColumn+1))==null?void 0:_e.v)!=null&&cur<maxRow;)cur+=1;detectEndRow=cur-1}for(let i=endRow+1;i<=detectEndRow;i++)for(let j=startColumn;j<=endColumn;j++)if(((_f=matrix.getValue(i,j))==null?void 0:_f.v)!=null){detectEndRow=i-1;break}return{startColumn,endColumn,startRow,endRow:detectEndRow}}_handleFillData(){var _a58,_b;this._currentLocation&&this._commandService.executeCommand(AutoFillCommand.id,{unitId:(_a58=this._currentLocation)==null?void 0:_a58.unitId,subUnitId:(_b=this._currentLocation)==null?void 0:_b.subUnitId})}_getApplyData(copyDataPiece,csLen,asLen,direction,applyType,hasStyle=!0){const applyData=[],num=Math.floor(asLen/csLen),rsd=asLen%csLen,rules=this._autoFillService.getRules();if(!hasStyle&&applyType===APPLY_TYPE.ONLY_FORMAT)return console.error("ERROR: only format can not be applied when hasStyle is false"),[];const applyDataInTypes={};rules.forEach(r2=>{applyDataInTypes[r2.type]=[]}),rules.forEach(r2=>{const{type,applyFunctions:customApplyFunctions={}}=r2,copyDataInType=copyDataPiece[type];copyDataInType&&copyDataInType.forEach(copySquad=>{const s=getLenS(copySquad.index,rsd),len=copySquad.index.length*num+s,arrData=this._applyFunctions(copySquad,len,direction,applyType,customApplyFunctions,copyDataPiece),arrIndex=getDataIndex(csLen,asLen,copySquad.index);applyDataInTypes[type].push({data:arrData,index:arrIndex})})});for(let x=0;x<asLen;x++)rules.forEach(r2=>{const{type}=r2,applyDataInType=applyDataInTypes[type];for(let y=0;y<applyDataInType.length;y++)x in applyDataInType[y].index&&applyData.push(applyDataInType[y].data[applyDataInType[y].index[x]])});return applyData}_applyFunctions(copySquad,len,direction,applyType,customApplyFunctions,copyDataPiece){const{data}=copySquad,isReverse=direction===core.Direction.UP||direction===core.Direction.LEFT;if(applyType===APPLY_TYPE.COPY){const custom=customApplyFunctions==null?void 0:customApplyFunctions[APPLY_TYPE.COPY];return custom?custom(copySquad,len,direction,copyDataPiece):(isReverse&&data.reverse(),fillCopy(data,len))}if(applyType===APPLY_TYPE.SERIES){const custom=customApplyFunctions==null?void 0:customApplyFunctions[APPLY_TYPE.SERIES];return custom?custom(copySquad,len,direction,copyDataPiece):(isReverse&&data.reverse(),customApplyFunctions!=null&&customApplyFunctions[APPLY_TYPE.COPY]?customApplyFunctions[APPLY_TYPE.COPY](copySquad,len,direction,copyDataPiece):fillCopy(data,len))}if(applyType===APPLY_TYPE.ONLY_FORMAT){const custom=customApplyFunctions==null?void 0:customApplyFunctions[APPLY_TYPE.ONLY_FORMAT];return custom?custom(copySquad,len,direction,copyDataPiece):fillCopyStyles(data,len)}}_getCopyData(source,direction){const worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const currentCellDatas=worksheet.getCellMatrix(),rules=this._autoFillService.getRules(),copyData=[],isVertical=direction===core.Direction.DOWN||direction===core.Direction.UP;let aArray,bArray;return isVertical?(aArray=source.cols,bArray=source.rows):(aArray=source.rows,bArray=source.cols),aArray.forEach(a=>{const copyDataPiece=this._getEmptyCopyDataPiece(),prevData={type:void 0,cellData:void 0};bArray.forEach(b=>{let data;isVertical?data=currentCellDatas.getValue(b,a):data=currentCellDatas.getValue(a,b);const{type,isContinue}=rules.find(r2=>r2.match(data,this._injector))||otherRule;if(isContinue(prevData,data)){const typeInfo=copyDataPiece[type],last=typeInfo[typeInfo.length-1];last.data.push(data),last.index.push(b-bArray[0])}else{const typeInfo=copyDataPiece[type];typeInfo?typeInfo.push({data:[data],index:[b-bArray[0]]}):copyDataPiece[type]=[{data:[data],index:[b-bArray[0]]}]}prevData.type=type,prevData.cellData=data}),copyData.push(copyDataPiece)}),copyData}_getEmptyCopyDataPiece(){const copyDataPiece={};return this._autoFillService.getRules().forEach(r2=>{copyDataPiece[r2.type]=[]}),copyDataPiece}_getMergeApplyData(source,target,direction,csLen){const worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const applyMergeRanges=[];for(let i=source.startRow;i<=source.endRow;i++)for(let j=source.startColumn;j<=source.endColumn;j++){const{isMergedMainCell,startRow,startColumn,endRow,endColumn}=worksheet.getCellInfoInMergeData(i,j);if(isMergedMainCell){if(direction===core.Direction.DOWN){let windowStartRow=startRow+csLen,windowEndRow=endRow+csLen;for(;windowEndRow<=target.endRow;)applyMergeRanges.push({startRow:windowStartRow,startColumn,endRow:windowEndRow,endColumn}),windowStartRow+=csLen,windowEndRow+=csLen}else if(direction===core.Direction.UP){let windowStartRow=startRow-csLen,windowEndRow=endRow-csLen;for(;windowStartRow>=target.startRow;)applyMergeRanges.push({startRow:windowStartRow,startColumn,endRow:windowEndRow,endColumn}),windowStartRow-=csLen,windowEndRow-=csLen}else if(direction===core.Direction.RIGHT){let windowStartColumn=startColumn+csLen,windowEndColumn=endColumn+csLen;for(;windowEndColumn<=target.endColumn;)applyMergeRanges.push({startRow,startColumn:windowStartColumn,endRow,endColumn:windowEndColumn}),windowStartColumn+=csLen,windowEndColumn+=csLen}else if(direction===core.Direction.LEFT){let windowStartColumn=startColumn-csLen,windowEndColumn=endColumn-csLen;for(;windowStartColumn>=target.startColumn;)applyMergeRanges.push({startRow,startColumn:windowStartColumn,endRow,endColumn:windowEndColumn}),windowStartColumn-=csLen,windowEndColumn-=csLen}}}return applyMergeRanges}_presetAndCacheData(location,direction){const{source,target}=location,worksheet=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getActiveSheet();if(!worksheet)throw new Error("No active sheet found");const currentCellDatas=worksheet.getCellMatrix(),applyData=[];return target.rows.forEach(i=>{const row=[];target.cols.forEach(j=>{row.push(core.Tools.deepClone(currentCellDatas.getValue(i,j)))}),applyData.push(row)}),this._beforeApplyData=applyData,this._copyData=this._getCopyData(source,direction),this._currentLocation=location,this._shouldDisableSeries(this._copyData)?(this._autoFillService.setDisableApplyType(APPLY_TYPE.SERIES,!0),APPLY_TYPE.COPY):(this._autoFillService.setDisableApplyType(APPLY_TYPE.SERIES,!1),this._getPreferredApplyType(this._copyData))}_fillData(location,direction,applyType){var _a58,_b;const undos=[],redos=[];let hasStyle=!0;applyType===APPLY_TYPE.NO_FORMAT&&(hasStyle=!1,applyType=APPLY_TYPE.SERIES);const{source,target,unitId,subUnitId}=location;if(!source||!target||direction==null)return{undos,redos};const sourceRange=discreteRangeToRange(source),targetRange=discreteRangeToRange(target),{cols:targetCols,rows:targetRows}=target,{cols:sourceCols,rows:sourceRows}=source,copyData=this._copyData;let csLen;direction===core.Direction.DOWN||direction===core.Direction.UP?csLen=sourceRows.length:csLen=sourceCols.length;const applyDatas=[];if(direction===core.Direction.DOWN||direction===core.Direction.UP){const asLen=targetRows.length,untransformedApplyDatas=[];targetCols.forEach((_,i)=>{const copyD=copyData[i],applyData=this._getApplyData(copyD,csLen,asLen,direction,applyType,hasStyle);untransformedApplyDatas.push(applyData)});for(let i=0;i<untransformedApplyDatas[0].length;i++){const row=[];for(let j=0;j<untransformedApplyDatas.length;j++)row.push({s:null,...untransformedApplyDatas[j][i]});applyDatas.push(row)}}else{const asLen=targetCols.length;targetRows.forEach((_,i)=>{const copyD=copyData[i],applyData=this._getApplyData(copyD,csLen,asLen,direction,applyType,hasStyle),row=[];for(let j=0;j<applyData.length;j++)row.push({s:null,...applyData[j]});applyDatas.push(row)})}let applyMergeRanges=[];const style=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getStyles();if(hasStyle?(applyMergeRanges=this._getMergeApplyData(sourceRange,targetRange,direction,csLen),applyDatas.forEach(row=>{row.forEach(cellData=>{cellData&&style&&style&&(cellData.s=style.getStyleByCell(cellData))})})):applyDatas.forEach((row,rowIndex)=>{row.forEach((cellData,colIndex)=>{cellData&&style&&(cellData.s=style.getStyleByCell(this._beforeApplyData[rowIndex][colIndex])||null)})}),applyType===APPLY_TYPE.ONLY_FORMAT&&applyDatas.forEach((row,rowIndex)=>{row.forEach((cellData,colIndex)=>{if(cellData){const old=this._beforeApplyData[rowIndex][colIndex]||{};cellData.f=old.f,cellData.si=old.si,cellData.t=old.t,cellData.v=old.v}})}),hasStyle){const deleteMergeRanges=[],mergeData=(_b=(_a58=this._univerInstanceService.getUniverSheetInstance(unitId))==null?void 0:_a58.getSheetBySheetId(subUnitId))==null?void 0:_b.getMergeData();mergeData&&mergeData.forEach(merge=>{core.Rectangle.intersects(merge,targetRange)&&deleteMergeRanges.push(merge)});const removeMergeMutationParams={unitId,subUnitId,ranges:deleteMergeRanges},undoRemoveMergeMutationParams=this._injector.invoke(sheets.RemoveMergeUndoMutationFactory,removeMergeMutationParams);deleteMergeRanges.length&&(redos.push({id:sheets.RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams}),undos.unshift({id:sheets.AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}))}const clearMutationParams={subUnitId,unitId,cellValue:generateNullCellValueRowCol([target])},undoClearMutationParams=this._injector.invoke(sheets.SetRangeValuesUndoMutationFactory,clearMutationParams);redos.push({id:sheets.SetRangeValuesMutation.id,params:clearMutationParams}),undos.unshift({id:sheets.SetRangeValuesMutation.id,params:undoClearMutationParams});const cellValue=new core.ObjectMatrix;targetRows.forEach((row,rowIndex)=>{targetCols.forEach((col,colIndex)=>{applyDatas[rowIndex][colIndex]&&cellValue.setValue(row,col,applyDatas[rowIndex][colIndex])})});const setRangeValuesMutationParams={subUnitId,unitId,cellValue:cellValue.getMatrix()},undoSetRangeValuesMutationParams=this._injector.invoke(sheets.SetRangeValuesUndoMutationFactory,setRangeValuesMutationParams);if(undos.unshift({id:sheets.SetRangeValuesMutation.id,params:undoSetRangeValuesMutationParams}),redos.push({id:sheets.SetRangeValuesMutation.id,params:setRangeValuesMutationParams}),applyMergeRanges!=null&&applyMergeRanges.length){const ranges=sheets.getAddMergeMutationRangeByType(applyMergeRanges),addMergeMutationParams={unitId,subUnitId,ranges},undoAddMergeMutationParams=this._injector.invoke(sheets.AddMergeUndoMutationFactory,addMergeMutationParams);undos.unshift({id:sheets.RemoveWorksheetMergeMutation.id,params:undoAddMergeMutationParams}),redos.push({id:sheets.AddWorksheetMergeMutation.id,params:addMergeMutationParams})}return{undos,redos}}_shouldDisableSeries(copyData){return copyData.every(copyDataPiece=>Object.keys(copyDataPiece).every(type=>{var _a58;return((_a58=copyDataPiece[type])==null?void 0:_a58.length)===0||[DATA_TYPE.OTHER,DATA_TYPE.FORMULA].includes(type)}))}_getPreferredApplyType(copyData){return copyData.every(copyDataPiece=>Object.keys(copyDataPiece).every(type=>{var _a58,_b;return((_a58=copyDataPiece[type])==null?void 0:_a58.length)===0||((_b=copyDataPiece[type])==null?void 0:_b.length)===1&&copyDataPiece[type][0].data.length===1&&DATA_TYPE.NUMBER===type}))?APPLY_TYPE.COPY:APPLY_TYPE.SERIES}},__name(_a10,"AutoFillController"),_a10);exports.AutoFillController=__decorateClass$J([__decorateParam$J(0,core.IUniverInstanceService),__decorateParam$J(1,core.ICommandService),__decorateParam$J(2,IAutoFillService),__decorateParam$J(3,IEditorBridgeService),__decorateParam$J(4,engineRender.IRenderManagerService),__decorateParam$J(5,core.Inject(core.Injector)),__decorateParam$J(6,core.Inject(exports.SheetsRenderService))],exports.AutoFillController);var __defProp$I=Object.defineProperty,__getOwnPropDesc$I=Object.getOwnPropertyDescriptor,__decorateClass$I=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$I(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$I(target,key,result),result},"__decorateClass$I"),__decorateParam$I=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$I"),_a11;exports.CellCustomRenderController=(_a11=class extends core.Disposable{constructor(_context,_sheetSkeletonManagerService,_renderManagerService,_permissionService){super();__publicField(this,"_enterActiveRender");this._context=_context,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._renderManagerService=_renderManagerService,this._permissionService=_permissionService,this._initEventBinding()}_initEventBinding(){const disposableCollection=new core.DisposableCollection,workbook=this._context.unit,handleSkeletonChange=__name(skeletonParam=>{if(disposableCollection.dispose(),!skeletonParam)return;const unitId=this._context.unitId,{skeleton}=skeletonParam,currentRender=this._renderManagerService.getRenderById(unitId);if(currentRender&&currentRender.mainComponent){const spreadsheet=currentRender.mainComponent,getActiveRender=__name(evt=>{const{offsetX,offsetY}=evt,scene=currentRender.scene,worksheet=workbook.getActiveSheet();if(!worksheet)return;const activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([offsetX,offsetY]));if(!activeViewport)return;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY={x:activeViewport.viewportScrollX,y:activeViewport.viewportScrollY},cellPos=skeleton.getCellPositionByOffset(offsetX,offsetY,scaleX,scaleY,scrollXY),mergeCell=skeleton.worksheet.getMergedCell(cellPos.row,cellPos.column),cellIndex={actualRow:mergeCell?mergeCell.startRow:cellPos.row,actualCol:mergeCell?mergeCell.startColumn:cellPos.column,mergeCell,row:cellPos.row,col:cellPos.column};if(!cellIndex||!skeleton)return;const cellData=worksheet.getCell(cellIndex.actualRow,cellIndex.actualCol);if(!cellData)return;const renders=cellData.customRender;if(!(renders!=null&&renders.length))return;const row=cellIndex.actualRow,col=cellIndex.actualCol,sortedRenders=renders.sort(core.sortRules),subUnitId=worksheet.getSheetId(),info={data:cellData,style:skeleton.getsStyles().getStyleByCell(cellData),primaryWithCoord:skeleton.getCellByIndex(cellIndex.actualRow,cellIndex.actualCol),unitId,subUnitId,row,col,workbook,worksheet},position={x:scrollXY.x+offsetX/scaleX,y:scrollXY.y+offsetY/scaleY},activeRender=sortedRenders.find(render2=>{var _a58;return(_a58=render2.isHit)==null?void 0:_a58.call(render2,position,info)});if(activeRender)return[activeRender,info]},"getActiveRender"),disposable=spreadsheet.onPointerDown$.subscribeEvent(evt=>{var _a58,_b,_c,_d;const activeRenderInfo=getActiveRender(evt);if(activeRenderInfo){const[activeRender,cellContext]=activeRenderInfo,{row,col,worksheet,unitId:unitId2,subUnitId}=cellContext;if(!((_a58=this._permissionService.composePermission([new sheets.WorkbookEditablePermission(unitId2).id,new sheets.WorksheetEditPermission(unitId2,subUnitId).id]))==null?void 0:_a58.every(permission2=>permission2.value)))return!1;const permission=(_c=(_b=worksheet.getCell(row,col))==null?void 0:_b.selectionProtection)==null?void 0:_c[0];if((permission==null?void 0:permission[sheets.UnitAction.Edit])===!1)return!1;(_d=activeRender.onPointerDown)==null||_d.call(activeRender,cellContext,evt)}}),moveDisposable=spreadsheet.onPointerMove$.subscribeEvent(evt=>{var _a58,_b,_c,_d;const activeRenderInfo=getActiveRender(evt);if(activeRenderInfo){const[activeRender,cellContext]=activeRenderInfo;this._enterActiveRender?this._enterActiveRender.render!==activeRender&&((_b=(_a58=this._enterActiveRender.render).onPointerLeave)==null||_b.call(_a58,this._enterActiveRender.cellContext,evt),this._enterActiveRender={render:activeRender,cellContext},(_c=activeRender.onPointerEnter)==null||_c.call(activeRender,cellContext,evt)):(this._enterActiveRender={render:activeRender,cellContext},(_d=activeRender.onPointerEnter)==null||_d.call(activeRender,cellContext,evt))}});disposable&&disposableCollection.add(disposable),moveDisposable&&disposableCollection.add(moveDisposable)}},"handleSkeletonChange");this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(handleSkeletonChange)),handleSkeletonChange(this._sheetSkeletonManagerService.getCurrent()),this.disposeWithMe(disposableCollection)}},__name(_a11,"CellCustomRenderController"),_a11);exports.CellCustomRenderController=__decorateClass$I([__decorateParam$I(1,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$I(2,engineRender.IRenderManagerService),__decorateParam$I(3,core.IPermissionService)],exports.CellCustomRenderController);function getUserListEqual(userList1,userList2){if(userList1.length!==userList2.length)return!1;const sorted1=userList1.sort((a,b)=>a.id.localeCompare(b.id)),sorted2=userList2.sort((a,b)=>a.id.localeCompare(b.id));return sorted1.every((user,index)=>{var _a58,_b;return((_a58=user.subject)==null?void 0:_a58.userID)===((_b=sorted2[index].subject)==null?void 0:_b.userID)&&user.role===sorted2[index].role})}__name(getUserListEqual,"getUserListEqual");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=sheets.SetRangeValuesUndoMutationFactory(accessor,redoMutationParams);undos.push({id:sheets.SetRangeValuesMutation.id,params:undoMutationParams}),redos.push({id:sheets.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;let leftTopCellValue=null;return cellMatrix.forValue((row,col,cellData)=>{cellData&&row>=startRow&&col>=startColumn&&(!leftTopCellValue&&worksheet.cellHasValue(cellData)&&(leftTopCellValue=cellData),redoMatrix.setValue(row,col,null))}),redoMatrix.setValue(startRow,startColumn,leftTopCellValue),redoMatrix}__name(getClearContentMutationParamForRange,"getClearContentMutationParamForRange");function getCellIndexByOffsetWithMerge(offsetX,offsetY,scene,skeleton){const activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([offsetX,offsetY]));if(!activeViewport)return;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY={x:activeViewport.viewportScrollX,y:activeViewport.viewportScrollY},cellPos=skeleton.getCellPositionByOffset(offsetX,offsetY,scaleX,scaleY,scrollXY),mergeCell=skeleton.worksheet.getMergedCell(cellPos.row,cellPos.column);return{actualRow:mergeCell?mergeCell.startRow:cellPos.row,actualCol:mergeCell?mergeCell.startColumn:cellPos.column,mergeCell,row:cellPos.row,col:cellPos.column}}__name(getCellIndexByOffsetWithMerge,"getCellIndexByOffsetWithMerge");function getViewportByCell(row,column,scene,worksheet){const freeze=worksheet.getFreeze();if(!freeze||freeze.startRow<=0&&freeze.startColumn<=0||row>freeze.startRow&&column>freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(row<=freeze.startRow&&column<=freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT_TOP);if(row<=freeze.startRow&&column>freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_TOP);if(row>freeze.startRow&&column<=freeze.startColumn)return scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN_LEFT)}__name(getViewportByCell,"getViewportByCell");function transformBound2OffsetBound(originBound,scene,skeleton,worksheet){const topLeft=transformPosition2Offset(originBound.left,originBound.top,scene,skeleton,worksheet),bottomRight=transformPosition2Offset(originBound.right,originBound.bottom,scene,skeleton,worksheet);return{left:topLeft.x,top:topLeft.y,right:bottomRight.x,bottom:bottomRight.y}}__name(transformBound2OffsetBound,"transformBound2OffsetBound");function transformPosition2Offset(x,y,scene,skeleton,worksheet){const{scaleX,scaleY}=scene.getAncestorScale(),viewMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN);if(!viewMain)return{x,y};const freeze=worksheet.getFreeze(),{startColumn,startRow,xSplit,ySplit}=freeze,startSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(startRow-ySplit,startColumn-xSplit),endSheetView=skeleton.getNoMergeCellPositionByIndexWithNoHeader(startRow,startColumn),{rowHeaderWidth,columnHeaderHeight}=skeleton,freezeWidth=endSheetView.startX-startSheetView.startX,freezeHeight=endSheetView.startY-startSheetView.startY,{top,left,viewportScrollX,viewportScrollY}=viewMain;let offsetX;x>left?offsetX=(x-viewportScrollX)*scaleX:offsetX=(freezeWidth+rowHeaderWidth-(left-x))*scaleX;let offsetY;return y>top?offsetY=(y-viewportScrollY)*scaleY:offsetY=(freezeHeight+columnHeaderHeight-(top-y))*scaleX,{x:offsetX,y:offsetY}}__name(transformPosition2Offset,"transformPosition2Offset");function getCellRealRange(workbook,worksheet,skeleton,row,col){let actualRow=row,actualCol=col;skeleton.overflowCache.forValue((r2,c,range)=>{range.startRow<=actualRow&&range.endRow>=actualRow&&range.startColumn<=actualCol&&range.endColumn>=actualCol&&(actualCol=c,actualRow=r2)});const actualCell=skeleton.getCellByIndex(actualRow,actualCol);return{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),workbook,worksheet,row:actualCell.actualRow,col:actualCell.actualColumn}}__name(getCellRealRange,"getCellRealRange");function getHoverCellPosition(currentRender,workbook,worksheet,skeletonParam,offsetX,offsetY){const{scene}=currentRender,unitId=workbook.getUnitId(),{skeleton,sheetId}=skeletonParam,cellIndex=getCellIndexByOffsetWithMerge(offsetX,offsetY,scene,skeleton);if(!cellIndex)return null;let{actualCol,actualRow}=cellIndex;skeleton.overflowCache.forValue((r2,c,range)=>{range.startRow<=actualRow&&range.endRow>=actualRow&&range.startColumn<=actualCol&&range.endColumn>=actualCol&&(actualCol=c,actualRow=r2)});const actualCell=skeleton.getCellByIndex(actualRow,actualCol),originCell=skeleton.getCellByIndex(cellIndex.row,cellIndex.col),originLocation={unitId,subUnitId:sheetId,workbook,worksheet,row:originCell.actualRow,col:originCell.actualColumn},location=getCellRealRange(workbook,worksheet,skeleton,actualRow,actualCol);let anchorCell;actualCell.mergeInfo?anchorCell=actualCell.mergeInfo:anchorCell={startRow:location.row,endRow:location.row,startColumn:location.col,endColumn:location.col};const activeViewport=scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([offsetX,offsetY]));if(!activeViewport)return;const{scaleX,scaleY}=scene.getAncestorScale(),scrollXY={x:activeViewport.viewportScrollX,y:activeViewport.viewportScrollY};return{position:{startX:(skeleton.getOffsetByPositionX(anchorCell.startColumn-1)-scrollXY.x)*scaleX,endX:(skeleton.getOffsetByPositionX(anchorCell.endColumn)-scrollXY.x)*scaleX,startY:(skeleton.getOffsetByPositionY(anchorCell.startRow-1)-scrollXY.y)*scaleY,endY:(skeleton.getOffsetByPositionY(anchorCell.endRow)-scrollXY.y)*scaleY},location:originLocation,overflowLocation:location}}__name(getHoverCellPosition,"getHoverCellPosition");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),confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService),unitId=params.unitId,subUnitId=params.subUnitId,selections=params.selections,ranges=sheets.getAddMergeMutationRangeByType(selections,params.value),worksheet=univerInstanceService.getUniverSheetInstance(unitId).getSheetBySheetId(subUnitId),redoMutations=[],undoMutations=[],willClearSomeCell=checkCellContentInRanges(worksheet,ranges);if(willClearSomeCell&&!await confirmService.confirm({id:"merge.confirm.add-worksheet-merge",title:{title:"merge.confirm.title"},cancelText:localeService.t("merge.confirm.cancel"),confirmText:localeService.t("merge.confirm.confirm")}))return!1;const removeMergeMutationParams={unitId,subUnitId,ranges:core.Tools.deepClone(ranges)},addMergeMutationParams={unitId,subUnitId,ranges:core.Tools.deepClone(ranges)},undoRemoveMergeMutationParams=sheets.RemoveMergeUndoMutationFactory(accessor,removeMergeMutationParams),undoMutationParams=sheets.AddMergeUndoMutationFactory(accessor,addMergeMutationParams);if(undoRemoveMergeMutationParams.ranges.length>0&&redoMutations.push({id:sheets.RemoveWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),redoMutations.push({id:sheets.AddWorksheetMergeMutation.id,params:addMergeMutationParams}),undoMutations.push({id:sheets.RemoveWorksheetMergeMutation.id,params:undoMutationParams}),undoRemoveMergeMutationParams.ranges.length>0&&undoMutations.push({id:sheets.AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams}),willClearSomeCell){const data=getClearContentMutationParamsForRanges(accessor,unitId,worksheet,ranges);redoMutations.unshift(...data.redos),undoMutations.push(...data.undos)}const addMergeRedoSelectionsMutation=sheets.AddMergeRedoSelectionsOperationFactory(accessor,params,ranges);addMergeRedoSelectionsMutation&&redoMutations.push(addMergeRedoSelectionsMutation);const addMergeUndoSelectionsMutation=sheets.AddMergeUndoSelectionsOperationFactory(accessor,params);return addMergeUndoSelectionsMutation&&undoMutations.push(addMergeUndoSelectionsMutation),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 _a58;const commandService=accessor.get(core.ICommandService),selections=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range),mergeableSelections=getMergeableSelectionsByType(MergeType.MergeAll,selections);if(!(mergeableSelections!=null&&mergeableSelections.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:mergeableSelections,unitId,subUnitId})},"handler")},AddWorksheetMergeVerticalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-vertical",handler:__name(async accessor=>{var _a58;const commandService=accessor.get(core.ICommandService),selections=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range),mergeableSelections=getMergeableSelectionsByType(MergeType.MergeVertical,selections);if(!(mergeableSelections!=null&&mergeableSelections.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:mergeableSelections,unitId,subUnitId})},"handler")},AddWorksheetMergeHorizontalCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-merge-horizontal",handler:__name(async accessor=>{var _a58;const commandService=accessor.get(core.ICommandService),selections=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range),mergeableSelections=getMergeableSelectionsByType(MergeType.MergeHorizontal,selections);if(!(mergeableSelections!=null&&mergeableSelections.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:mergeableSelections,unitId,subUnitId})},"handler")},DeleteRangeMoveLeftConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-move-left-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endColumn:worksheet.getColumnCount()-1};const getRowLength=__name(range2=>range2.endRow-range2.startRow,"getRowLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getRowLength(mergeRange)>getRowLength(interSectedRange):!1})||await confirmService.confirm({id:DeleteRangeMoveLeftConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.DeleteRangeMoveLeftCommand.id):!0},"handler")},DeleteRangeMoveUpConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-move-up-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endRow:worksheet.getRowCount()-1};for(let i=range.startRow;i<=range.endRow;i++)if(worksheet.getRowFiltered(i)&&await confirmService.confirm({id:DeleteRangeMoveUpConfirmCommand.id,title:{title:localeService.t("filter.confirm.error")},children:{title:localeService.t("filter.confirm.notAllowedToInsertRange")},confirmText:localeService.t("button.confirm")}))return!1;const getColLength=__name(range2=>range2.endColumn-range2.startColumn,"getColLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getColLength(mergeRange)>getColLength(interSectedRange):!1})||await confirmService.confirm({id:DeleteRangeMoveUpConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.DeleteRangeMoveUpCommand.id):!0},"handler")},HideRowConfirmCommand={id:"sheet.command.hide-row-confirm",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a58;const ranges=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allRowRanges=worksheet.getVisibleRows();if(isAllRowsCovered(allRowRanges,ranges)){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.hide-row",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.hideAllRowsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.SetRowHiddenCommand.id),!0},"handler")},HideColConfirmCommand={id:"sheet.command.hide-col-confirm",type:core.CommandType.COMMAND,handler:__name(async accessor=>{var _a58;const ranges=(_a58=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections())==null?void 0:_a58.map(s=>s.range);if(!(ranges!=null&&ranges.length))return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allColumnRanges=worksheet.getVisibleCols();if(isAllColumnsCovered(allColumnRanges,ranges)){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.hide-col",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.hideAllColumnsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.SetColHiddenCommand.id),!0},"handler")},SetRangeBoldCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-bold",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatBoldCommand.id):commandService.executeCommand(sheets.SetBoldCommand.id)},"handler")},SetRangeItalicCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-italic",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatItalicCommand.id):commandService.executeCommand(sheets.SetItalicCommand.id)},"handler")},SetRangeUnderlineCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-underline",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatUnderlineCommand.id):commandService.executeCommand(sheets.SetUnderlineCommand.id)},"handler")},SetRangeStrickThroughCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-stroke",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatStrikethroughCommand.id):commandService.executeCommand(sheets.SetStrikeThroughCommand.id)},"handler")},SetRangeSubscriptCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-subscript",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatSubscriptCommand.id):!1},"handler")},SetRangeSuperscriptCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-superscript",handler:__name(async accessor=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatSuperscriptCommand.id):!1},"handler")},SetRangeFontSizeCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-fontsize",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatFontSizeCommand.id,params):commandService.executeCommand(sheets.SetFontSizeCommand.id,params)},"handler")},SetRangeFontFamilyCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-font-family",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatFontFamilyCommand.id,params):commandService.executeCommand(sheets.SetFontFamilyCommand.id,params)},"handler")},SetRangeTextColorCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-text-color",handler:__name(async(accessor,params)=>{const commandService=accessor.get(core.ICommandService);return accessor.get(core.IContextService).getContextValue(core.EDITOR_ACTIVATED)?commandService.executeCommand(docsUi.SetInlineFormatTextColorCommand.id,params):commandService.executeCommand(sheets.SetTextColorCommand.id,params)},"handler")},InsertRangeMoveDownConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-range-move-down-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endRow:worksheet.getRowCount()-1};for(let i=range.startRow;i<=range.endRow;i++)if(worksheet.getRowFiltered(i)&&await confirmService.confirm({id:InsertRangeMoveDownConfirmCommand.id,title:{title:localeService.t("filter.confirm.error")},children:{title:localeService.t("filter.confirm.notAllowedToInsertRange")},confirmText:localeService.t("button.confirm")}))return!1;const getColLength=__name(range2=>range2.endColumn-range2.startColumn,"getColLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getColLength(mergeRange)>getColLength(interSectedRange):!1})||await confirmService.confirm({id:InsertRangeMoveDownConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.InsertRangeMoveDownCommand.id):!0},"handler")},InsertRangeMoveRightConfirmCommand={type:core.CommandType.COMMAND,id:"sheet.command.insert-range-move-right-confirm",handler:__name(async accessor=>{const confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),selection=selectionManagerService.getCurrentSelections();if(!selection)return!1;const target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target;let range=selection[0].range;if(!range)return!1;range={...range,endColumn:worksheet.getColumnCount()-1};const getRowLength=__name(range2=>range2.endRow-range2.startRow,"getRowLength");return!worksheet.getMergeData().find(mergeRange=>{const interSectedRange=core.Rectangle.getIntersects(mergeRange,range);return interSectedRange?getRowLength(mergeRange)>getRowLength(interSectedRange):!1})||await confirmService.confirm({id:InsertRangeMoveRightConfirmCommand.id,title:{title:localeService.t("merge.confirm.waring")},children:{title:localeService.t("merge.confirm.dismantleMergeCellWaring")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?commandService.executeCommand(sheets.InsertRangeMoveRightCommand.id):!0},"handler")};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||{}),G=(E=>(E[E.Reader=0]="Reader",E[E.Editor=1]="Editor",E[E.Owner=2]="Owner",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(G||{}),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||{}),H=(E=>(E[E.SomeCollaborator=0]="SomeCollaborator",E[E.AllCollaborator=1]="AllCollaborator",E[E.OneSelf=2]="OneSelf",E[E.UNRECOGNIZED=-1]="UNRECOGNIZED",E))(H||{});const DEFAULT_RANGE_RULE={name:"",unitId:"",subUnitId:"",permissionId:"",unitType:M.Unkonwn,id:"",ranges:[]};var viewState=(viewState2=>(viewState2.othersCanView="othersCanView",viewState2.noOneElseCanView="noOneElseCanView",viewState2))(viewState||{}),editState=(editState2=>(editState2.designedUserCanEdit="designedUserCanEdit",editState2.onlyMe="onlyMe",editState2))(editState||{});const _SheetPermissionPanelModel=class _SheetPermissionPanelModel{constructor(){__publicField(this,"_rule",DEFAULT_RANGE_RULE);__publicField(this,"_rule$",new rxjs.BehaviorSubject(this._rule));__publicField(this,"_oldRule");__publicField(this,"_rangeErrorMsg$",new rxjs.BehaviorSubject(""));__publicField(this,"_visible",!1);__publicField(this,"rangeErrorMsg$",this._rangeErrorMsg$.asObservable());__publicField(this,"rule$",this._rule$.asObservable())}setVisible(v){this._visible=v}getVisible(){return this._visible}setRangeErrorMsg(msg){this._rangeErrorMsg$.next(msg)}get rule(){return this._rule}setRule(ruleObj){this._rule={...this._rule,...ruleObj},this._rule$.next(this._rule)}resetRule(){this._rule=DEFAULT_RANGE_RULE,this._rule$.next(this._rule)}reset(){this.setVisible(!1),this.resetRule(),this.setRangeErrorMsg(""),this.setOldRule(null)}get oldRule(){return this._oldRule}setOldRule(ruleObj){this._oldRule=ruleObj}};__name(_SheetPermissionPanelModel,"SheetPermissionPanelModel");let SheetPermissionPanelModel=_SheetPermissionPanelModel;const _SheetPermissionUserManagerService=class _SheetPermissionUserManagerService{constructor(){__publicField(this,"_userList",[]);__publicField(this,"_oldCollaboratorList",[]);__publicField(this,"_selectUserList",[]);__publicField(this,"_allUserList",[]);__publicField(this,"_selectUserList$",new rxjs.BehaviorSubject(this._selectUserList));__publicField(this,"selectUserList$",this._selectUserList$.asObservable())}get userList(){return this._userList}get allUserList(){return this._allUserList}setAllUserList(userList){this._allUserList=userList}setUserList(userList){this._userList=userList}reset(){this._userList=[],this._oldCollaboratorList=[],this._selectUserList=[],this._selectUserList$.next([]),this._allUserList=[]}get oldCollaboratorList(){return this._oldCollaboratorList}setOldCollaboratorList(userList){this._oldCollaboratorList=userList}get selectUserList(){return this._selectUserList}setSelectUserList(userList){this._selectUserList=userList,this._selectUserList$.next(userList)}};__name(_SheetPermissionUserManagerService,"SheetPermissionUserManagerService");let SheetPermissionUserManagerService=_SheetPermissionUserManagerService;const UNIVER_SHEET_PERMISSION_PANEL="UNIVER_SHEET_PERMISSION_PANEL",UNIVER_SHEET_PERMISSION_PANEL_FOOTER="UNIVER_SHEET_PERMISSION_PANEL_FOOTER",UNIVER_SHEET_PERMISSION_USER_DIALOG="UNIVER_SHEET_PERMISSION_USER_DIALOG",UNIVER_SHEET_PERMISSION_DIALOG="UNIVER_SHEET_PERMISSION_DIALOG",UNIVER_SHEET_PERMISSION_USER_DIALOG_ID="UNIVER_SHEET_PERMISSION_USER_DIALOG_ID",UNIVER_SHEET_PERMISSION_DIALOG_ID="UNIVER_SHEET_PERMISSION_DIALOG_ID",subUnitPermissionTypeMap={[P.Copy]:"Copy",[P.SetCellStyle]:"SetCellStyle",[P.SetCellValue]:"SetCellValue",[P.SetRowStyle]:"SetRowStyle",[P.SetColumnStyle]:"SetColumnStyle",[P.InsertRow]:"InsertRow",[P.InsertColumn]:"InsertColumn",[P.InsertHyperlink]:"InsertHyperlink",[P.DeleteRow]:"DeleteRow",[P.DeleteColumn]:"DeleteColumn",[P.Sort]:"Sort",[P.Filter]:"Filter",[P.PivotTable]:"PivotTable",[P.EditExtraObject]:"EditExtraObject"},defaultWorksheetUnitActionList=[P.Copy,P.SetCellStyle,P.SetCellValue,P.SetRowStyle,P.SetColumnStyle,P.InsertRow,P.InsertColumn,P.InsertHyperlink,P.DeleteRow,P.DeleteColumn,P.Sort,P.Filter,P.PivotTable,P.EditExtraObject,P.View],permissionMenuIconKey="sheet-permission-menu-icon",permissionDeleteIconKey="sheet-permission-delete-icon",permissionEditIconKey="sheet-permission-edit-icon",permissionCheckIconKey="sheet-permission-check-icon",permissionLockIconKey="sheet-permission-lock-icon",SheetPermissionOpenPanelOperation={type:core.CommandType.OPERATION,id:"sheet-permission.operation.openPanel",async handler(accessor,_params={}){const sidebarService=accessor.get(ui.ISidebarService),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),sheetPermissionUserManagerService=accessor.get(SheetPermissionUserManagerService),{showDetail=!0,fromSheetBar=!1}=_params,sidebarProps={header:{title:"permission.panel.title"},children:{label:UNIVER_SHEET_PERMISSION_PANEL,showDetail,fromSheetBar},width:330,footer:{label:UNIVER_SHEET_PERMISSION_PANEL_FOOTER,showDetail},onClose:__name(()=>{sheetPermissionPanelModel.reset(),sheetPermissionUserManagerService.reset()},"onClose")};return sheetPermissionPanelModel.setVisible(!0),sidebarService.open(sidebarProps),!0}},AddWorksheetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-worksheet-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),{rule,unitId}=params,subUnitId=rule.subUnitId;if(await commandService.executeCommand(sheets.AddWorksheetProtectionMutation.id,{unitId,rule,subUnitId:rule.subUnitId})){const redoMutations=[{id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule,subUnitId:rule.subUnitId}}],undoMutations=[{id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteWorksheetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-worksheet-protection",handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),{rule,unitId,subUnitId}=params;commandService.executeCommand(sheets.DeleteWorksheetProtectionMutation.id,{unitId,subUnitId});const redoMutations=[{id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}}],undoMutations=[{id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule,subUnitId}}];return undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations}),!0}},SetWorksheetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-worksheet-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),undoRedoService=accessor.get(core.IUndoRedoService),{rule,permissionId}=params,{unitId,subUnitId}=rule,newRule={...rule,permissionId},oldRule=sheetPermissionPanelModel.oldRule;if(await commandService.executeCommand(sheets.SetWorksheetProtectionMutation.id,{unitId,subUnitId,newRule})){const redoMutations=[{id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,newRule}}],undoMutations=[{id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,rule:oldRule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteWorksheetProtectionFormSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-worksheet-protection-from-sheet-bar",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),workbook=accessor.get(core.IUniverInstanceService).getCurrentUnitForType(I.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet(),unitId=workbook.getUnitId();if(!worksheet)return!1;const subUnitId=worksheet.getSheetId(),rule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);if(await commandService.executeCommand(DeleteWorksheetProtectionCommand.id,{unitId,subUnitId})){const redoMutations=[{id:DeleteWorksheetProtectionCommand.id,params:{unitId,subUnitId}}],undoMutations=[{id:AddWorksheetProtectionCommand.id,params:{unitId,rule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},ChangeSheetProtectionFromSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.change-sheet-protection-from-sheet-bar",async handler(accessor){return await accessor.get(core.ICommandService).executeCommand("sheet-permission.operation.openDialog"),!0}},AddRangeProtectionFromToolbarCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection-from-toolbar",async handler(accessor){const commandService=accessor.get(core.ICommandService);return accessor.get(SheetPermissionPanelModel).resetRule(),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}},AddRangeProtectionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection-from-context-menu",async handler(accessor){const commandService=accessor.get(core.ICommandService);return accessor.get(SheetPermissionPanelModel).resetRule(),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}},ViewSheetPermissionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.view-sheet-permission-from-context-menu",async handler(accessor){return await accessor.get(core.ICommandService).executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!1}),!0}},AddRangeProtectionFromSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.add-range-protection-from-sheet-bar",async handler(accessor){const commandService=accessor.get(core.ICommandService);return accessor.get(SheetPermissionPanelModel).resetRule(),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{fromSheetBar:!0,showDetail:!0}),!0}},ViewSheetPermissionFromSheetBarCommand={type:core.CommandType.COMMAND,id:"sheet.command.view-sheet-permission-from-sheet-bar",async handler(accessor){return await accessor.get(core.ICommandService).executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!1}),!0}},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(sheets.RangeProtectionRuleModel),{rule,permissionId}=params,{unitId,subUnitId,ranges,name,description}=rule,rules=[{ranges,permissionId,id:selectionProtectionModel.createRuleId(unitId,subUnitId),name,description}];if(await commandService.executeCommand(sheets.AddRangeProtectionMutation.id,{unitId,subUnitId,rules})){const redoMutations=[{id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules}}],undoMutations=[{id:sheets.DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:rules.map(rule2=>rule2.id)}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}return!0}},DeleteRangeSelectionCommand={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(sheets.DeleteRangeProtectionMutation.id,redoMutationParam)&&undoRedoService.pushUndoRedo({unitID:unitId,redoMutations:[{id:sheets.DeleteRangeProtectionMutation.id,params:redoMutationParam}],undoMutations:[{id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}]}),!0}},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(sheets.RangeProtectionRuleModel),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),undoRedoService=accessor.get(core.IUndoRedoService),{rule,permissionId}=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(sheets.SetRangeProtectionMutation.id,redoMutationParam)){const redoMutations=[{id:sheets.SetRangeProtectionMutation.id,params:redoMutationParam}],undoMutations=[{id:sheets.SetRangeProtectionMutation.id,params:{unitId,subUnitId,ruleId:rule.id,rule:sheetPermissionPanelModel.oldRule}}];undoRedoService.pushUndoRedo({unitID:unitId,redoMutations,undoMutations})}}return!0}},DeleteRangeProtectionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.delete-range-protection-from-context-menu",async handler(accessor){var _a58;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),undoRedoService=accessor.get(core.IUndoRedoService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId);if(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name))return commandService.executeCommand(DeleteWorksheetProtectionCommand.id,{unitId,subUnitId,rule:worksheetRule});{const selectRange=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!selectRange)return!1;const rule=accessor.get(sheets.RangeProtectionRuleModel).getSubunitRuleList(unitId,subUnitId).find(item=>item.ranges.some(range=>core.Rectangle.intersects(range,selectRange)));if(rule){const redoMutationParam={unitId,subUnitId,ruleIds:[rule.id]};return await commandService.executeCommand(sheets.DeleteRangeProtectionMutation.id,redoMutationParam)&&undoRedoService.pushUndoRedo({unitID:unitId,redoMutations:[{id:sheets.DeleteRangeProtectionMutation.id,params:redoMutationParam}],undoMutations:[{id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}]}),!0}else return!1}}},SetRangeProtectionFromContextMenuCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-range-protection-from-context-menu",async handler(accessor){var _a58;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),workbook=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel);if(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)){const oldRule={...worksheetRule,unitId,subUnitId,ranges:[]};return sheetPermissionPanelModel.setRule(oldRule),sheetPermissionPanelModel.setOldRule(oldRule),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}else{const selectRange=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range;if(!selectRange)return!1;const rule=accessor.get(sheets.RangeProtectionRuleModel).getSubunitRuleList(unitId,subUnitId).find(item=>{var _a59;return(_a59=item==null?void 0:item.ranges)==null?void 0:_a59.some(range=>core.Rectangle.intersects(range,selectRange))});if(rule){const oldRule={...rule,unitId,subUnitId};return sheetPermissionPanelModel.setRule(oldRule),sheetPermissionPanelModel.setOldRule(oldRule),await commandService.executeCommand(SheetPermissionOpenPanelOperation.id,{showDetail:!0}),!0}else return!1}}},SetProtectionCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-protection",async handler(accessor,params){if(!params)return!1;const commandService=accessor.get(core.ICommandService),undoRedoService=accessor.get(core.IUndoRedoService),sheetPermissionPanelModel=accessor.get(SheetPermissionPanelModel),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),{rule}=params,{unitId,subUnitId}=rule,redoMutations=[],undoMutations=[],oldRule=sheetPermissionPanelModel.oldRule;return(oldRule==null?void 0:oldRule.unitType)===rule.unitType?rule.unitType===M.Worksheet?(redoMutations.push({id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,rule}}),undoMutations.push({id:sheets.SetWorksheetProtectionMutation.id,params:{unitId,subUnitId,rule:oldRule}})):(redoMutations.push({id:sheets.SetRangeProtectionMutation.id,params:{unitId,subUnitId,rule,ruleId:rule.id}}),undoMutations.push({id:sheets.SetRangeProtectionMutation.id,params:{unitId,subUnitId,ruleId:oldRule.id,rule:oldRule}})):(oldRule&&(oldRule.unitType===M.Worksheet?(redoMutations.push({id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}}),undoMutations.push({id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule:oldRule,subUnitId:oldRule.subUnitId}})):oldRule.unitType===M.SelectRange&&(redoMutations.push({id:sheets.DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:[oldRule.id]}}),undoMutations.push({id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[oldRule]}}))),rule.unitType===M.Worksheet?(redoMutations.push({id:sheets.AddWorksheetProtectionMutation.id,params:{unitId,rule,subUnitId:rule.subUnitId}}),undoMutations.unshift({id:sheets.DeleteWorksheetProtectionMutation.id,params:{unitId,subUnitId}})):rule.unitType===M.SelectRange&&(rule.id=rangeProtectionRuleModel.createRuleId(unitId,subUnitId),redoMutations.push({id:sheets.AddRangeProtectionMutation.id,params:{unitId,subUnitId,rules:[rule]}}),undoMutations.unshift({id:sheets.DeleteRangeProtectionMutation.id,params:{unitId,subUnitId,ruleIds:[rule.id]}}))),core.sequenceExecute(redoMutations,commandService)&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations,redoMutations}),!0}},RefillCommand={id:"sheet.command.refill",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const autoFillService=accessor.get(IAutoFillService);return autoFillService.applyType=params.type,!0},"handler")},RemoveRowConfirmCommand={id:"sheet.command.remove-row-confirm",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a58;const selectionManagerService=accessor.get(sheets.SheetsSelectionsService);let range=params==null?void 0:params.range;if(range||(range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range),!range)return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allRowRanges=worksheet.getVisibleRows();if(isAllRowsCovered(allRowRanges,[range])){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.remove-row",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.deleteAllRowsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.RemoveRowCommand.id,{range}),!0},"handler")},RemoveColConfirmCommand={id:"sheet.command.remove-col-confirm",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{var _a58;const selectionManagerService=accessor.get(sheets.SheetsSelectionsService);let range=params==null?void 0:params.range;if(range||(range=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.range),!range)return!1;const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{worksheet}=target,allColumnRanges=worksheet.getVisibleCols();if(isAllColumnsCovered(allColumnRanges,[range])){const confirmService=accessor.get(ui.IConfirmService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.remove-col",title:{title:localeService.t("info.problem")},children:{title:localeService.t("rightClick.deleteAllColumnsAlert")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")}),!1}return await commandService.executeCommand(sheets.RemoveColCommand.id,{range}),!0},"handler")},RemoveSheetConfirmCommand={id:"sheet.command.remove-sheet-confirm",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const{subUnitId}=params,confirmService=accessor.get(ui.IConfirmService),commandService=accessor.get(core.ICommandService),localeService=accessor.get(core.LocaleService);return await confirmService.confirm({id:"sheet.confirm.remove-sheet",title:{title:localeService.t("sheetConfig.deleteSheet")},children:{title:localeService.t("sheetConfig.deleteSheetContent")},cancelText:localeService.t("button.cancel"),confirmText:localeService.t("button.confirm")})?(await commandService.executeCommand(sheets.RemoveSheetCommand.id,{subUnitId}),!0):!1},"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$H=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$H");const DEFAULT_Z_INDEX=SELECTION_SHAPE_DEPTH.MARK_SELECTION,IMarkSelectionService=core.createIdentifier("univer.mark-selection-service");var _a12;exports.MarkSelectionService=(_a12=class extends core.Disposable{constructor(_currentService,_renderManagerService,_themeService){super();__publicField(this,"_shapeMap",new Map);this._currentService=_currentService,this._renderManagerService=_renderManagerService,this._themeService=_themeService}addShape(selection,exits=[],zIndex=DEFAULT_Z_INDEX){var _a58;const workbook=this._currentService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),subUnitId=(_a58=workbook.getActiveSheet())==null?void 0:_a58.getSheetId();if(!subUnitId)return null;const id=core.Tools.generateRandomId();return this._shapeMap.set(id,{selection,subUnitId,unitId:workbook.getUnitId(),zIndex,control:null,exits}),this.refreshShapes(),id}refreshShapes(){var _a58;const currentSheet=this._currentService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET);if(!currentSheet)return;const currentUnitId=currentSheet.getUnitId(),currentSubUnitId=(_a58=currentSheet.getActiveSheet())==null?void 0:_a58.getSheetId();this._shapeMap.forEach(shape=>{var _a59;const{unitId,subUnitId,selection,control:oldControl,zIndex}=shape;if(oldControl==null||oldControl.dispose(),unitId!==currentUnitId||subUnitId!==currentSubUnitId)return;const renderUnit=this._renderManagerService.getRenderById(unitId);if(!renderUnit)return;const skeleton=(_a59=this._renderManagerService.withCurrentTypeOfUnit(core.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService))==null?void 0:_a59.getCurrentSkeleton();if(!skeleton)return;const{scene}=renderUnit,{rowHeaderWidth,columnHeaderHeight}=skeleton,control=new SelectionControl(scene,zIndex,this._themeService,!1,{rowHeaderWidth,columnHeaderHeight}),{rangeWithCoord,primaryWithCoord}=renderUnit.with(ISheetSelectionRenderService).attachSelectionWithCoord(selection);control.updateRange(rangeWithCoord,primaryWithCoord);const{style}=selection;style&&control.updateStyle(style),shape.control=control})}getShapeMap(){return this._shapeMap}removeShape(id){const shapeInfo=this._shapeMap.get(id);if(!shapeInfo)return;const{control}=shapeInfo;control==null||control.dispose(),this._shapeMap.delete(id)}removeAllShapes(){for(const shape of this._shapeMap.values()){const{control}=shape;control==null||control.dispose()}this._shapeMap.clear()}},__name(_a12,"MarkSelectionService"),_a12);exports.MarkSelectionService=__decorateClass$H([__decorateParam$H(0,core.IUniverInstanceService),__decorateParam$H(1,engineRender.IRenderManagerService),__decorateParam$H(2,core.Inject(core.ThemeService))],exports.MarkSelectionService);function createCopyPasteSelectionStyle(themeService){return{strokeWidth:1.5,stroke:themeService.getCurrentTheme().primaryColor,fill:"rgba(178, 178, 178, 0.10)",widgets:{},hasAutoFill:!1,strokeDash:8}}__name(createCopyPasteSelectionStyle,"createCopyPasteSelectionStyle");var __defProp$G=Object.defineProperty,__getOwnPropDesc$G=Object.getOwnPropertyDescriptor,__decorateClass$G=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$G(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$G(target,key,result),result},"__decorateClass$G"),__decorateParam$G=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$G"),FormatPainterStatus=(FormatPainterStatus2=>(FormatPainterStatus2[FormatPainterStatus2.OFF=0]="OFF",FormatPainterStatus2[FormatPainterStatus2.ONCE=1]="ONCE",FormatPainterStatus2[FormatPainterStatus2.INFINITE=2]="INFINITE",FormatPainterStatus2))(FormatPainterStatus||{});const IFormatPainterService=core.createIdentifier("univer.format-painter-service");var _a13;let FormatPainterService=(_a13=class extends core.Disposable{constructor(_selectionManagerService,_themeService,_markSelectionService,_logService,_commandService,_undoRedoService){super();__publicField(this,"status$");__publicField(this,"_selectionFormat");__publicField(this,"_markId",null);__publicField(this,"_status$");__publicField(this,"_defaultHook",null);__publicField(this,"_extendHooks",[]);this._selectionManagerService=_selectionManagerService,this._themeService=_themeService,this._markSelectionService=_markSelectionService,this._logService=_logService,this._commandService=_commandService,this._undoRedoService=_undoRedoService,this._status$=new rxjs.BehaviorSubject(0),this.status$=this._status$.asObservable(),this._selectionFormat={styles:new core.ObjectMatrix,merges:[]}}addHook(hook){var _a58,_b,_c;hook.isDefaultHook&&((_a58=hook.priority)!=null?_a58:0)>((_c=(_b=this._defaultHook)==null?void 0:_b.priority)!=null?_c:-1)?this._defaultHook=hook:(this._extendHooks.push(hook),this._extendHooks.sort((a,b)=>(a.priority||0)-(b.priority||0)))}getHooks(){return this._defaultHook?[this._defaultHook,...this._extendHooks]:this._extendHooks}setStatus(status){this._updateRangeMark(status),this._status$.next(status),this.getHooks().forEach(hook=>{hook.onStatusChange!==void 0&&hook.onStatusChange(status)})}getStatus(){return this._status$.getValue()}setSelectionFormat(format){this._selectionFormat=format}getSelectionFormat(){return this._selectionFormat}applyFormatPainter(unitId,subUnitId,range){const hooks=this.getHooks(),redoMutationsInfo=[],undoMutationsInfo=[];hooks.forEach(h=>{if(h.onApply!==void 0){const applyReturn=h.onApply(unitId,subUnitId,range,this._selectionFormat);applyReturn&&(redoMutationsInfo.push(...applyReturn.redos),undoMutationsInfo.push(...applyReturn.undos))}});for(const beforeHook of hooks)if(beforeHook.onBeforeApply!==void 0&&!beforeHook.onBeforeApply({unitId,subUnitId,range,redoMutationsInfo,format:this._selectionFormat,undoMutationsInfo}))return!1;this._logService.log("[FormatPainterService]","apply mutations",{undoMutationsInfo,redoMutationsInfo});const result=redoMutationsInfo.every(m2=>this._commandService.executeCommand(m2.id,m2.params));return result&&this._undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undoMutationsInfo,redoMutations:redoMutationsInfo}),result}_updateRangeMark(status){if(this._markSelectionService.removeAllShapes(),status!==0){const selection=this._selectionManagerService.getCurrentLastSelection();if(selection){const style=createCopyPasteSelectionStyle(this._themeService);status===2?this._markId=this._markSelectionService.addShape({...selection,style}):this._markId=this._markSelectionService.addShape({...selection,style},[sheets.SetRangeValuesMutation.id])}}}},__name(_a13,"FormatPainterService"),_a13);FormatPainterService=__decorateClass$G([__decorateParam$G(0,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$G(1,core.Inject(core.ThemeService)),__decorateParam$G(2,IMarkSelectionService),__decorateParam$G(3,core.ILogService),__decorateParam$G(4,core.ICommandService),__decorateParam$G(5,core.IUndoRedoService)],FormatPainterService);const SetFormatPainterOperation={id:"sheet.operation.set-format-painter",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>params?(accessor.get(IFormatPainterService).setStatus(params.status),!0):!1,"handler")},SetInfiniteFormatPainterCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-infinite-format-painter",handler:__name(async accessor=>{const status=accessor.get(IFormatPainterService).getStatus();let newStatus;return status!==FormatPainterStatus.OFF?newStatus=FormatPainterStatus.OFF:newStatus=FormatPainterStatus.INFINITE,accessor.get(core.ICommandService).executeCommand(SetFormatPainterOperation.id,{status:newStatus})},"handler")},SetOnceFormatPainterCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-once-format-painter",handler:__name(async accessor=>{const status=accessor.get(IFormatPainterService).getStatus();let newStatus;return status!==FormatPainterStatus.OFF?newStatus=FormatPainterStatus.OFF:newStatus=FormatPainterStatus.ONCE,accessor.get(core.ICommandService).executeCommand(SetFormatPainterOperation.id,{status:newStatus})},"handler")},ApplyFormatPainterCommand={type:core.CommandType.COMMAND,id:"sheet.command.apply-format-painter",handler:__name(async(accessor,params)=>accessor.get(IFormatPainterService).applyFormatPainter(params.unitId,params.subUnitId,params.range),"handler")},SetSelectionFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-selection-frozen",handler:__name(async(accessor,params)=>{const{type}=params||{},univerInstanceService=accessor.get(core.IUniverInstanceService),undoRedoService=accessor.get(core.IUndoRedoService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId,subUnitId}=target,commandService=accessor.get(core.ICommandService),selections=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections();if(!selections)return!1;const currentSelection=selections[(selections==null?void 0:selections.length)-1],{range}=currentSelection,scrollManagerService=accessor.get(engineRender.IRenderManagerService).getRenderById(unitId).with(SheetScrollManagerService),{sheetViewStartRow=0,sheetViewStartColumn=0}=scrollManagerService.getCurrentScrollState()||{};let startRow,startColumn,ySplit,xSplit;const{startRow:selectRow,startColumn:selectColumn,rangeType}=range;if(rangeType===core.RANGE_TYPE.ROW||type===1)startRow=selectRow,ySplit=selectRow-sheetViewStartRow,startColumn=-1,xSplit=0;else if(rangeType===core.RANGE_TYPE.COLUMN||type===2)startRow=-1,ySplit=0,startColumn=selectColumn,xSplit=selectColumn-sheetViewStartColumn;else if(rangeType===core.RANGE_TYPE.NORMAL)startRow=selectRow,ySplit=selectRow-sheetViewStartRow,startColumn=selectColumn,xSplit=selectColumn-sheetViewStartColumn;else return!1;const redoMutationParams={unitId,subUnitId,startRow,startColumn,xSplit:startColumn>0?Math.max(1,xSplit):xSplit,ySplit:startRow>0?Math.max(1,ySplit):ySplit},undoMutationParams=sheets.SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(sheets.SetFrozenMutation.id,redoMutationParams)&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:sheets.SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:sheets.SetFrozenMutation.id,params:redoMutationParams}]}),!0},"handler")},SetRowFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-row-frozen",handler:__name(async accessor=>(accessor.get(core.ICommandService).executeCommand(SetSelectionFrozenCommand.id,{type:1}),!0),"handler")},SetColumnFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.set-col-frozen",handler:__name(async accessor=>(accessor.get(core.ICommandService).executeCommand(SetSelectionFrozenCommand.id,{type:2}),!0),"handler")},CancelFrozenCommand={type:core.CommandType.COMMAND,id:"sheet.command.cancel-frozen",handler:__name((accessor,params)=>{const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),undoRedoService=accessor.get(core.IUndoRedoService),target=sheets.getSheetCommandTarget(univerInstanceService,{unitId:params==null?void 0:params.unitId,subUnitId:params==null?void 0:params.subUnitId});if(!target)return!1;const{unitId,subUnitId}=target,redoMutationParams={unitId,subUnitId,startRow:-1,startColumn:-1,xSplit:0,ySplit:0},undoMutationParams=sheets.SetFrozenMutationFactory(accessor,redoMutationParams);return commandService.syncExecuteCommand(sheets.SetFrozenMutation.id,redoMutationParams)&&undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:[{id:sheets.SetFrozenMutation.id,params:undoMutationParams}],redoMutations:[{id:sheets.SetFrozenMutation.id,params:redoMutationParams}]}),!0},"handler")},ISheetBarService=core.createIdentifier("univer.sheetbar-service"),_SheetBarService=class _SheetBarService extends core.Disposable{constructor(){super();__publicField(this,"renameId$");__publicField(this,"removeId$");__publicField(this,"scroll$");__publicField(this,"scrollX$");__publicField(this,"addSheet$");__publicField(this,"_renameId$");__publicField(this,"_removeId$");__publicField(this,"_scroll$");__publicField(this,"_scrollX$");__publicField(this,"_addSheet$");__publicField(this,"_currentHandler",null);this._renameId$=new rxjs.Subject,this.renameId$=this._renameId$.asObservable(),this._removeId$=new rxjs.Subject,this.removeId$=this._removeId$.asObservable(),this._scroll$=new rxjs.Subject,this.scroll$=this._scroll$.asObservable(),this._scrollX$=new rxjs.Subject,this.scrollX$=this._scrollX$.asObservable(),this._addSheet$=new rxjs.Subject,this.addSheet$=this._addSheet$.asObservable()}setRenameId(renameId){this._renameId$.next(renameId)}setRemoveId(removeId){this._removeId$.next(removeId)}setScroll(state){this._scroll$.next(state)}setScrollX(x){this._scrollX$.next(x)}setAddSheet(index){this._addSheet$.next(index)}triggerSheetBarMenu(){var _a58;(_a58=this._currentHandler)==null||_a58.handleSheetBarMenu()}registerSheetBarMenuHandler(handler){if(this._currentHandler)throw new Error("There is already a context menu handler!");return this._currentHandler=handler,core.toDisposable(()=>{this._currentHandler=null})}};__name(_SheetBarService,"SheetBarService");let SheetBarService=_SheetBarService;const ShowMenuListCommand={id:"ui-sheet.command.show-menu-list",type:core.CommandType.OPERATION,handler:__name(async accessor=>(accessor.get(ISheetBarService).triggerSheetBarMenu(),!0),"handler")},SetActivateCellEditOperation={id:"sheet.operation.set-activate-cell-edit",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>(accessor.get(IEditorBridgeService).setEditCell(params),!0),"handler")},RenameSheetOperation={id:"sheet.operation.rename-sheet",type:core.CommandType.OPERATION,handler:__name(async(accessor,params)=>{const sheetBarService=accessor.get(ISheetBarService);return params&&sheetBarService.setRenameId(params.subUnitId),!0},"handler")},ScrollToRangeOperation={id:"sheet.operation.scroll-to-range",type:core.CommandType.OPERATION,handler:__name((accessor,params)=>{if(!params)return!1;const instanceService=accessor.get(core.IUniverInstanceService);return accessor.get(engineRender.IRenderManagerService).getRenderById(instanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId()).with(exports.SheetsScrollRenderController).scrollToRange(params.range)},"handler")},SheetPermissionOpenDialogOperation={type:core.CommandType.OPERATION,id:"sheet-permission.operation.openDialog",async handler(accessor,_params){const dialogService=accessor.get(ui.IDialogService);return dialogService.close("DESKTOP_FIND_REPLACE_DIALOG"),dialogService.open({id:UNIVER_SHEET_PERMISSION_DIALOG_ID,title:{title:"permission.dialog.allowedPermissionType"},children:{label:UNIVER_SHEET_PERMISSION_DIALOG},width:393,destroyOnClose:!0,onClose:__name(()=>dialogService.close(UNIVER_SHEET_PERMISSION_DIALOG_ID),"onClose")}),!0}},DEFINED_NAME_CONTAINER="DefinedNameContainer",SCOPE_WORKBOOK_VALUE="AllDefaultWorkbook",SidebarDefinedNameOperation={id:"sidebar.operation.defined-name",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const sidebarService=accessor.get(ui.ISidebarService),editorService=accessor.get(docsUi.IEditorService),localeService=accessor.get(core.LocaleService),univerInstanceService=accessor.get(core.IUniverInstanceService),target=sheets.getSheetCommandTarget(univerInstanceService);if(!target)return!1;const{unitId}=target;switch(params.value){case"open":editorService.setOperationSheetUnitId(unitId),sidebarService.open({header:{title:localeService.t("definedName.featureTitle")},children:{label:DEFINED_NAME_CONTAINER},onClose:__name(()=>{editorService.closeRangePrompt()},"onClose"),width:333});break;case"close":default:sidebarService.close();break}return!0},"handler")};var jsxRuntime={exports:{}},reactJsxRuntime_production_min={};/**
2
2
  * @license React
3
3
  * react-jsx-runtime.production.min.js
4
4
  *
@@ -14,7 +14,7 @@
14
14
  `,documentData={...p2,body:{dataStream:singleDataStream,textRuns:newDocBody.textRuns,paragraphs:generateParagraphs(singleDataStream)}};documentModel==null||documentModel.reset(documentData),cellRichStyle=documentModel==null?void 0:documentModel.getSnapshot(),cellText=newDocBody.dataStream}else cellText=decodeHTMLEntities(cell.innerHTML.replace(/[\r\n]/g,""));return{cellText,cellRichStyle}}_generateDocumentDataModelSnapshot(snapshot){var _a58;const currentSkeleton=this._getCurrentSkeleton();if(currentSkeleton==null)return null;const{skeleton}=currentSkeleton,documentModel=(_a58=skeleton.getBlankCellDocumentModel())==null?void 0:_a58.documentModel,documentData={...documentModel==null?void 0:documentModel.getSnapshot(),...snapshot};return documentModel==null||documentModel.reset(documentData),documentModel==null?void 0:documentModel.getSnapshot()}process(parent,nodes,doc,tables){var _a58,_b,_c;for(const node of nodes)if(node.nodeName.toLowerCase()==="table")tables.push({index:((_a58=doc==null?void 0:doc.paragraphs)==null?void 0:_a58.length)||0});else if(node.nodeType===Node.TEXT_NODE){if(((_b=node.nodeValue)==null?void 0:_b.trim())==="")continue;const text=(_c=node.nodeValue)==null?void 0:_c.replace(/[\r\n]/g,"");let style;parent&&this._styleCache.has(parent)&&(style=this._styleCache.get(parent));const newDoc={dataStream:"",textRuns:[]};doc.dataStream+=text,newDoc.dataStream+=text,style&&Object.getOwnPropertyNames(style).length&&(doc.textRuns.push({st:doc.dataStream.length-text.length,ed:doc.dataStream.length,ts:style}),newDoc.textRuns.push({st:doc.dataStream.length-text.length,ed:doc.dataStream.length,ts:style}))}else{if(core.skipParseTagNames.includes(node.nodeName.toLowerCase()))continue;if(node.nodeType===Node.ELEMENT_NODE){if(node.nodeName==="STYLE")continue;const element2=node,linkStart=this._processBeforeLink(element2,{body:doc}),parentStyles=parent?this._styleCache.get(parent):{},styleRule=this._styleRules.find(({filter})=>matchFilter(node,filter)),nodeStyles=styleRule?styleRule.getStyle(node):extractNodeStyle(node);this._styleCache.set(node,{...parentStyles,...nodeStyles});const{childNodes}=node;this.process(node,childNodes,doc,tables);const afterProcessRule=this._afterProcessRules.find(({filter})=>matchFilter(node,filter));afterProcessRule&&afterProcessRule.handler(doc,node),this._processAfterLink(element2,{body:doc},linkStart)}}}_processBeforeLink(node,doc){const body=doc.body,element2=node,start=body.dataStream.length;return element2.tagName.toUpperCase()==="A"&&(body.dataStream+=core.DataStreamTreeTokenType.CUSTOM_RANGE_START),start}_processAfterLink(node,doc,start){var _a58,_b;const body=doc.body,element2=node;element2.tagName.toUpperCase()==="A"&&(body.dataStream+=core.DataStreamTreeTokenType.CUSTOM_RANGE_END,body.customRanges=(_a58=body.customRanges)!=null?_a58:[],body.customRanges.push({startIndex:start,endIndex:body.dataStream.length-1,rangeId:(_b=element2.dataset.rangeid)!=null?_b:core.generateRandomId(),rangeType:core.CustomRangeType.HYPERLINK,properties:{url:element2.href}}))}dispose(){this._dom=null,this._styleCache.clear(),this._styleMap.clear()}};__name(_HtmlToUSMService,"HtmlToUSMService"),__publicField(_HtmlToUSMService,"_pluginList",[]);let HtmlToUSMService=_HtmlToUSMService;function parseTableRows(html){const ROWS_REGEX=/<tr([\s\S]*?)>([\s\S]*?)<\/tr>/gi,rowMatches=html.matchAll(ROWS_REGEX);if(!rowMatches)return{rowProperties:[],rowCount:0};const rowProperties=Array.from(rowMatches).map(rowMatch=>parseProperties(rowMatch[1])).map(properties=>{if(!properties.height){const style=properties.style,match=style&&style.match(/height\s*:\s*(\d+(\.\d+)?)px/);properties.height=`${match?Number.parseInt(match[1],10):core.DEFAULT_WORKSHEET_ROW_HEIGHT}`}return properties});return{rowProperties,rowCount:rowProperties.length}}__name(parseTableRows,"parseTableRows");function turnToStyleObject(styleStr){const styleObj={};return styleStr.split(";").forEach(style=>{const[key,value]=style.split(":");styleObj[key]=value}),styleObj}__name(turnToStyleObject,"turnToStyleObject");function parseProperties(propertyStr){if(!propertyStr)return{};const property={},PROPERTY_REGEX=/([\w-]+)\s*=\s*(?:(['"])([^'"]*)\2|(\S+))/g;let match;for(;(match=PROPERTY_REGEX.exec(propertyStr))!==null;){const[,attributeName,,attributeValue1,attributeValue2]=match,attributeValue=attributeValue1!==void 0?attributeValue1:attributeValue2;property[attributeName]=attributeValue}return property}__name(parseProperties,"parseProperties");function parseColGroup(raw){const COLGROUP_TAG_REGEX=/<colgroup([\s\S]*?)>(.*?)<\/colgroup>/,colgroupMatch=raw.match(COLGROUP_TAG_REGEX),COL_TAG_REGEX=/<col([\s\S]*?)>/g;let colMatches;if(colgroupMatch!=null&&colgroupMatch[2]?colMatches=colgroupMatch[2].matchAll(COL_TAG_REGEX):colMatches=raw.matchAll(COL_TAG_REGEX),!colMatches)return null;const colPropertiesWithSpan=Array.from(colMatches).map(colMatch=>parseProperties(colMatch[1])),colProperties=[];return colPropertiesWithSpan.forEach(propertiesWithSpan=>{const span=Number(propertiesWithSpan.span);if(span)for(let i=0;i<span;i++){const propertiesWithoutSpan={...propertiesWithSpan};delete propertiesWithoutSpan.span,colProperties.push(propertiesWithoutSpan)}else colProperties.push(propertiesWithSpan)}),colProperties}__name(parseColGroup,"parseColGroup");function decodeHTMLEntities(input){const entities={"&lt;":"<","&gt;":">","&amp;":"&","&quot;":'"',"&#39;":"'","&nbsp;":" "};return input.replace(/&lt;|&gt;|&amp;|&quot;|&#39;|&nbsp;|<br>/g,match=>entities[match])}__name(decodeHTMLEntities,"decodeHTMLEntities");function extractStyleProperty(styleString,propertyName){if(!styleString||!propertyName)return null;const regex=new RegExp(`(${propertyName}\\s*:\\s*[^;]+);`,"i"),match=styleString.match(regex);return match?match[1]:null}__name(extractStyleProperty,"extractStyleProperty");function setMergedCellStyle(cellMatrix,cellStyle,cellValue,indexParams){const{rowSpan,colSpan,rowIndex,colSetValueIndex}=indexParams;for(let i=rowIndex;i<rowIndex+rowSpan;i++)for(let j=colSetValueIndex;j<colSetValueIndex+colSpan;j++)i===rowIndex&&j===colSetValueIndex?cellMatrix.setValue(i,j,{...cellValue,style:cellStyle}):cellMatrix.setValue(i,j,{style:cellStyle})}__name(setMergedCellStyle,"setMergedCellStyle");const LarkPastePlugin={name:"univer-doc-paste-plugin-lark",checkPasteType(html){return/lark-record-clipboard/i.test(html)},stylesRules:[{filter:["s"],getStyle(node){const inlineStyle=extractNodeStyle(node);return{st:{s:core.BooleanNumber.TRUE},...inlineStyle}}}],afterProcessRules:[{filter(el){return el.tagName==="DIV"&&/ace-line/i.test(el.className)},handler(doc){doc.paragraphs==null&&(doc.paragraphs=[]),doc.paragraphs.push({startIndex:doc.dataStream.length}),doc.dataStream+="\r"}}]},UniverPastePlugin={name:"univer-doc-paste-plugin-univer",checkPasteType(html){return/UniverNormal/i.test(html)},stylesRules:[],afterProcessRules:[{filter(el){return el.tagName==="P"&&/UniverNormal/i.test(el.className)},handler(doc,el){doc.paragraphs==null&&(doc.paragraphs=[]);const paragraph={startIndex:doc.dataStream.length},paragraphStyle=getParagraphStyle(el);paragraphStyle&&(paragraph.paragraphStyle=paragraphStyle),doc.paragraphs.push(paragraph),doc.dataStream+="\r"}}]},WordPastePlugin={name:"univer-doc-paste-plugin-word",checkPasteType(html){return/word|mso/i.test(html)},stylesRules:[{filter:["b"],getStyle(node){const inlineStyle=extractNodeStyle(node);return{bl:core.BooleanNumber.TRUE,...inlineStyle}}}],afterProcessRules:[{filter(el){return el.tagName==="P"&&/mso/i.test(el.className)},handler(doc,el){doc.paragraphs==null&&(doc.paragraphs=[]);const paragraph={startIndex:doc.dataStream.length},paragraphStyle=getParagraphStyle(el);paragraphStyle&&(paragraph.paragraphStyle=paragraphStyle),doc.paragraphs.push(paragraph),doc.dataStream+="\r"}}]};var COPY_TYPE=(COPY_TYPE2=>(COPY_TYPE2.COPY="COPY",COPY_TYPE2.CUT="CUT",COPY_TYPE2))(COPY_TYPE||{});function getRowContent(row,cols,hooks,matrix,mergeSet){const properties=hooks.map(hook=>{var _a58;return(_a58=hook.onCopyRow)==null?void 0:_a58.call(hook,row)}).filter(v=>!!v),mergedProperties=mergeProperties(properties),str=zipClipboardPropertyItemToString(mergedProperties),tds=cols.map(col=>{if(!mergeSet.has(`${row}-${col}`)){const v=matrix.getValue(row,col);if(v!=null&&v.rowSpan&&(v!=null&&v.colSpan))for(let i=row;i<row+v.rowSpan;i++)for(let j=col;j<col+v.colSpan;j++)mergeSet.add(`${i}-${j}`);return getTDContent(row,col,hooks,matrix)}return null}).filter(v=>!!v).join("");return`<tr${str}>${tds}</tr>`}__name(getRowContent,"getRowContent");function getTDContent(row,col,hooks,matrix){const v=matrix.getValue(row,col),properties=hooks.map(hook=>{var _a58;return(_a58=hook.onCopyCellStyle)==null?void 0:_a58.call(hook,row,col,v==null?void 0:v.rowSpan,v==null?void 0:v.colSpan)}).filter(v2=>!!v2),mergedProperties=mergeProperties(properties),str=zipClipboardPropertyItemToString(mergedProperties),content=hooks.reduce((acc,hook)=>{var _a58;return acc||((_a58=hook.onCopyCellContent)==null?void 0:_a58.call(hook,row,col))||""},"");return`<td${str}>${content}</td>`}__name(getTDContent,"getTDContent");function getColStyle(cols,hooks){return`<colgroup>${cols.map(col=>{const properties=hooks.map(hook=>{var _a58;return(_a58=hook.onCopyColumn)==null?void 0:_a58.call(hook,col)}).filter(v=>!!v),mergedProperties=mergeProperties(properties);return`<col ${zipClipboardPropertyItemToString(mergedProperties)}>`}).join("")}</colgroup>`}__name(getColStyle,"getColStyle");function mergeProperties(properties){return properties.reduce((acc,cur)=>(Object.keys(cur).forEach(key=>{acc[key]?acc[key]+=`;${cur[key]}`:acc[key]=cur[key]}),acc),{})}__name(mergeProperties,"mergeProperties");function zipClipboardPropertyItemToString(item){return Object.keys(item).reduce((acc,cur)=>(acc+=` ${cur}="${item[cur]}"`,acc),"")}__name(zipClipboardPropertyItemToString,"zipClipboardPropertyItemToString");const _USMToHtmlService=class _USMToHtmlService{convert(matrix,range,hooks){const{cols,rows}=range;if(!cols.length)return"";const colStyles=getColStyle(cols,hooks),rowContents=[],mergeSet=new Set;return rows.forEach(row=>{rowContents.push(getRowContent(row,cols,hooks,matrix,mergeSet))}),`<google-sheets-html-origin><table xmlns="http://www.w3.org/1999/xhtml" cellspacing="0" cellpadding="0" dir="ltr" style="table-layout:fixed;font-size:10pt;font-family:Arial;width:0px;border-collapse:collapse;border:none">${colStyles}
15
15
  <tbody>${rowContents.join("")}</tbody></table>`}};__name(_USMToHtmlService,"USMToHtmlService");let USMToHtmlService=_USMToHtmlService;const getRepeatRange=__name((sourceRange,targetRange,isStrictMode=!1)=>{const getRowLength=__name(range=>range.endRow-range.startRow+1,"getRowLength"),getColLength=__name(range=>range.endColumn-range.startColumn+1,"getColLength"),rowMod=getRowLength(targetRange)%getRowLength(sourceRange),colMod=getColLength(targetRange)%getColLength(sourceRange),repeatRelativeRange={startRow:0,endRow:getRowLength(sourceRange)-1,startColumn:0,endColumn:getColLength(sourceRange)-1},repeatRow=Math.floor(getRowLength(targetRange)/getRowLength(sourceRange)),repeatCol=Math.floor(getColLength(targetRange)/getColLength(sourceRange)),repeatList=[];if(!rowMod&&!colMod)for(let countRow=1;countRow<=repeatRow;countRow++)for(let countCol=1;countCol<=repeatCol;countCol++){const row=getRowLength(sourceRange)*(countRow-1),col=getColLength(sourceRange)*(countCol-1),startRange={startRow:row+targetRange.startRow,endRow:row+targetRange.startRow,startColumn:col+targetRange.startColumn,endColumn:col+targetRange.startColumn};repeatList.push({repeatRelativeRange,startRange})}else if(!rowMod&&colMod&&!isStrictMode)for(let countRow=1;countRow<=repeatRow;countRow++){const row=getRowLength(sourceRange)*(countRow-1),col=0,startRange={startRow:row+targetRange.startRow,endRow:row+targetRange.startRow,startColumn:col+targetRange.startColumn,endColumn:col+targetRange.startColumn};repeatList.push({repeatRelativeRange,startRange})}else if(rowMod&&!colMod&&!isStrictMode)for(let countCol=1;countCol<=repeatCol;countCol++){const col=getColLength(sourceRange)*(countCol-1),startRange={startRow:0+targetRange.startRow,endRow:0+targetRange.startRow,startColumn:col+targetRange.startColumn,endColumn:col+targetRange.startColumn};repeatList.push({repeatRelativeRange,startRange})}else{const startRange={startRow:targetRange.startRow,endRow:targetRange.startRow,startColumn:targetRange.startColumn,endColumn:targetRange.startColumn};repeatList.push({startRange,repeatRelativeRange})}return repeatList},"getRepeatRange");async function clipboardItemIsFromExcel(html){return html?/<td[^>]*class=".*?xl.*?"[^>]*>.*?<\/td>/.test(html):!1}__name(clipboardItemIsFromExcel,"clipboardItemIsFromExcel");function mergeCellValues(...cellValues){if(cellValues.length===1)return cellValues[0];const newMatrix=new core.ObjectMatrix;return cellValues.forEach(cellValue=>{cellValue&&new core.ObjectMatrix(cellValue).forValue((row,col,value)=>{newMatrix.setValue(row,col,{...newMatrix.getValue(row,col),...value})})}),newMatrix.getMatrix()}__name(mergeCellValues,"mergeCellValues");function getRangeValuesMergeable(m1,m2){return m1.id===m2.id&&m1.params.unitId===m2.params.unitId&&m1.params.subUnitId===m2.params.subUnitId}__name(getRangeValuesMergeable,"getRangeValuesMergeable");function mergeSetRangeValues(mutations){const newMutations=[];for(let i=0;i<mutations.length;){let cursor=1;if(mutations[i].id===sheets.SetRangeValuesMutation.id){const current=mutations[i],toMerge=[current];for(;i+cursor<mutations.length&&getRangeValuesMergeable(current,mutations[i+cursor]);)toMerge.push(mutations[i+cursor]),cursor+=1;const merged=mergeCellValues(...toMerge.map(m2=>m2.params.cellValue||{}));newMutations.push({...current,params:{...current.params,cellValue:merged}})}else newMutations.push(mutations[i]);i+=cursor}return newMutations}__name(mergeSetRangeValues,"mergeSetRangeValues");function rangeIntersectWithDiscreteRange(range,discrete){const{startRow,endRow,startColumn,endColumn}=range;for(let i=startRow;i<=endRow;i++)for(let j=startColumn;j<=endColumn;j++)if(discrete.rows.includes(i)&&discrete.cols.includes(j))return!0}__name(rangeIntersectWithDiscreteRange,"rangeIntersectWithDiscreteRange");function discreteRangeContainsRange(discrete,range){const{startRow,endRow,startColumn,endColumn}=range;for(let i=startRow;i<=endRow;i++)if(!discrete.rows.includes(i))return!1;for(let j=startColumn;j<=endColumn;j++)if(!discrete.cols.includes(j))return!1;return!0}__name(discreteRangeContainsRange,"discreteRangeContainsRange");function convertTextToTable(text){const rows=text.trim().split(`
16
16
  `);let html="<table>";return rows.forEach(row=>{const columns=row.split(" ");html+="<tr>",columns.forEach(column=>{html+=`<td>${column}</td>`}),html+="</tr>"}),html+="</table>",html}__name(convertTextToTable,"convertTextToTable");var __defProp$F=Object.defineProperty,__getOwnPropDesc$F=Object.getOwnPropertyDescriptor,__decorateClass$F=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$F(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$F(target,key,result),result},"__decorateClass$F"),__decorateParam$F=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$F");const PREDEFINED_HOOK_NAME={DEFAULT_COPY:"default-copy",DEFAULT_PASTE:"default-paste",SPECIAL_PASTE_VALUE:"special-paste-value",SPECIAL_PASTE_FORMAT:"special-paste-format",SPECIAL_PASTE_COL_WIDTH:"special-paste-col-width",SPECIAL_PASTE_BESIDES_BORDER:"special-paste-besides-border",SPECIAL_PASTE_FORMULA:"special-paste-formula"};HtmlToUSMService.use(WordPastePlugin);HtmlToUSMService.use(LarkPastePlugin);HtmlToUSMService.use(UniverPastePlugin);const ISheetClipboardService=core.createIdentifier("sheet.clipboard-service");var _a14;exports.SheetClipboardService=(_a14=class extends core.Disposable{constructor(_logService,_univerInstanceService,_selectionManagerService,_clipboardInterfaceService,_undoRedoService,_commandService,_markSelectionService,_notificationService,_platformService,_renderManagerService,_themeService,_localeService,_errorService,_injector){super();__publicField(this,"_clipboardHooks",[]);__publicField(this,"_clipboardHooks$",new rxjs.BehaviorSubject([]));__publicField(this,"clipboardHooks$",this._clipboardHooks$.asObservable());__publicField(this,"_htmlToUSM");__publicField(this,"_usmToHtml");__publicField(this,"_copyContentCache");__publicField(this,"_copyMarkId",null);this._logService=_logService,this._univerInstanceService=_univerInstanceService,this._selectionManagerService=_selectionManagerService,this._clipboardInterfaceService=_clipboardInterfaceService,this._undoRedoService=_undoRedoService,this._commandService=_commandService,this._markSelectionService=_markSelectionService,this._notificationService=_notificationService,this._platformService=_platformService,this._renderManagerService=_renderManagerService,this._themeService=_themeService,this._localeService=_localeService,this._errorService=_errorService,this._injector=_injector,this._htmlToUSM=new HtmlToUSMService({getCurrentSkeleton:__name(()=>{var _a58;return(_a58=this._renderManagerService.withCurrentTypeOfUnit(core.UniverInstanceType.UNIVER_SHEET,exports.SheetSkeletonManagerService))==null?void 0:_a58.getCurrent()},"getCurrentSkeleton")}),this._usmToHtml=new USMToHtmlService,this._copyContentCache=new CopyContentCache,this.disposeWithMe(this._htmlToUSM)}copyContentCache(){return this._copyContentCache}generateCopyContent(workbookId,worksheetId,range){const hooks=this._clipboardHooks;hooks.forEach(h=>{var _a58;return(_a58=h.onBeforeCopy)==null?void 0:_a58.call(h,workbookId,worksheetId,range)});const copyContent=this._generateCopyContent(workbookId,worksheetId,range,hooks);return hooks.forEach(h=>{var _a58;return(_a58=h.onAfterCopy)==null?void 0:_a58.call(h)}),copyContent}async copy(copyType=COPY_TYPE.COPY){const selection=this._selectionManagerService.getCurrentLastSelection();if(!selection)return!1;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)return!1;const copyContent=this.generateCopyContent(workbook.getUnitId(),worksheet.getSheetId(),selection.range);if(!copyContent)return!1;const{html,plain,matrixFragment,copyId,discreteRange}=copyContent;this._copyContentCache.set(copyId,{unitId:workbook.getUnitId(),subUnitId:worksheet.getSheetId(),range:discreteRange,matrix:matrixFragment,copyType}),await this._clipboardInterfaceService.write(plain,html),this._markSelectionService.removeAllShapes();const style=createCopyPasteSelectionStyle(this._themeService);return this._copyMarkId=this._markSelectionService.addShape({...selection,style}),!0}async cut(){return this.copy(COPY_TYPE.CUT)}async paste(item,pasteType=PREDEFINED_HOOK_NAME.DEFAULT_PASTE){const types=item.types,text=types.indexOf(ui.PLAIN_TEXT_CLIPBOARD_MIME_TYPE)!==-1?await item.getType(ui.PLAIN_TEXT_CLIPBOARD_MIME_TYPE).then(blob=>blob&&blob.text()):"",html=types.indexOf(ui.HTML_CLIPBOARD_MIME_TYPE)!==-1?await item.getType(ui.HTML_CLIPBOARD_MIME_TYPE).then(blob=>blob&&blob.text()):"";return html?this._platformService.isWindows&&await clipboardItemIsFromExcel(html)?(this._notificationService.show({type:"warning",title:this._localeService.t("clipboard.shortCutNotify.title"),content:this._localeService.t("clipboard.shortCutNotify.useShortCutInstead")}),!1):this._pasteHTML(html,pasteType):text?this._pastePlainText(text,pasteType):(this._logService.error("[SheetClipboardService]","No valid data on clipboard"),!1)}legacyPaste(html,text){return html?this._pasteHTML(html,PREDEFINED_HOOK_NAME.DEFAULT_PASTE):text?/[\n\t]/.test(text)?this._pasteHTML(convertTextToTable(text),PREDEFINED_HOOK_NAME.DEFAULT_PASTE):this._pastePlainText(text,PREDEFINED_HOOK_NAME.DEFAULT_PASTE):Promise.resolve(!1)}addClipboardHook(hook){if(this._clipboardHooks.findIndex(h=>h.id===hook.id)!==-1)return this._logService.error("[SheetClipboardService]","hook already exists",hook.id),{dispose:__name(()=>{},"dispose")};const insertIndex=this._clipboardHooks.findIndex(existingHook=>{const existingHookPriority=existingHook.priority||0;return(hook.priority||0)<existingHookPriority});return this._clipboardHooks.splice(insertIndex!==-1?insertIndex:this._clipboardHooks.length,0,hook),this._notifyClipboardHook(),core.toDisposable(()=>{const index=this._clipboardHooks.indexOf(hook);index>-1&&(this._clipboardHooks.splice(index,1),this._notifyClipboardHook())})}getClipboardHooks(){return this._clipboardHooks}_generateCopyContent(unitId,subUnitId,range,hooks){const workbook=this._univerInstanceService.getUniverSheetInstance(unitId),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(!workbook||!worksheet)return null;const filteredRows=hooks.reduce((acc,cur)=>{var _a58;const rows=(_a58=cur.getFilteredOutRows)==null?void 0:_a58.call(cur,range);return rows==null||rows.forEach(r2=>acc.add(r2)),acc},new Set),{startColumn,startRow,endColumn,endRow}=range,matrix=worksheet.getMatrixWithMergedCells(startRow,startColumn,endRow,endColumn,!0),matrixFragment=new core.ObjectMatrix;let rowIndex=startRow;const discreteRange={rows:[],cols:[]};for(let r2=startRow;r2<=endRow;r2++)if(!filteredRows.has(r2)){discreteRange.rows.push(r2);for(let c=startColumn;c<=endColumn;c++){const cellData=matrix.getValue(r2,c);cellData?matrixFragment.setValue(rowIndex-startRow,c-startColumn,{...getEmptyCell(),...core.Tools.deepClone(cellData)}):(matrixFragment.setValue(rowIndex-startRow,c-startColumn,getEmptyCell()),matrix.setValue(r2,c,getEmptyCell()))}rowIndex+=1}for(let c=startColumn;c<=endColumn;c++)discreteRange.cols.push(c);let html=this._usmToHtml.convert(matrix,discreteRange,hooks);const plain=getMatrixPlainText(matrixFragment),copyId=genId();return html=html.replace(/(<[a-z]+)/,(_p0,p1)=>`${p1} data-copy-id="${copyId}"`),{copyId,plain,html,matrixFragment,discreteRange}}_notifyClipboardHook(){this._clipboardHooks$.next(this._clipboardHooks)}async _pastePlainText(text,pasteType){const target=this._getPastingTarget();if(!target.subUnitId||!target.selection)return!1;const range=this._injector.invoke(accessor=>rangeToDiscreteRange(target.selection.range,accessor,target.unitId,target.subUnitId));if(!range)return!1;const{unitId,subUnitId}=target,hooks=this._clipboardHooks,enabledHooks=[];if(hooks.some(h=>{var _a58;return enabledHooks.push(h)&&((_a58=h.onBeforePaste)==null?void 0:_a58.call(h,{unitId,subUnitId,range}))===!1}))return enabledHooks.forEach(h=>{var _a58;return(_a58=h.onAfterPaste)==null?void 0:_a58.call(h,!1)}),!1;const redoMutationsInfo=[],undoMutationsInfo=[];enabledHooks.forEach(h=>{var _a58;const contentReturn=(_a58=h.onPastePlainText)==null?void 0:_a58.call(h,{unitId,subUnitId,range},text,{pasteType});contentReturn&&(redoMutationsInfo.push(...contentReturn.redos),undoMutationsInfo.push(...contentReturn.undos))});const result=redoMutationsInfo.every(m2=>this._commandService.executeCommand(m2.id,m2.params));return result&&this._undoRedoService.pushUndoRedo({unitID:this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getUnitId(),undoMutations:undoMutationsInfo,redoMutations:redoMutationsInfo}),result}async _pasteHTML(html,pasteType){const copyId=extractId(html);return copyId&&this._copyContentCache.get(copyId)?this._pasteInternal(copyId,pasteType):this._pasteExternal(html,pasteType)}async _pasteExternal(html,pasteType){var _a58;const{rowProperties,colProperties,cellMatrix}=this._htmlToUSM.convert(html);if(!cellMatrix)return!1;const pasteTarget=this._getPastedRange(cellMatrix);if(!pasteTarget)return!1;const worksheet=(_a58=this._univerInstanceService.getUniverSheetInstance(pasteTarget.unitId))==null?void 0:_a58.getSheetBySheetId(pasteTarget.subUnitId);if(!worksheet)return!1;const mergeData=worksheet==null?void 0:worksheet.getMergeData();return mergeData.length&&mergeData.some(m2=>rangeIntersectWithDiscreteRange(m2,pasteTarget.pastedRange)&&!discreteRangeContainsRange(pasteTarget.pastedRange,m2))?(this._errorService.emit(this._localeService.t("clipboard.paste.overlappingMergedCells")),!1):this._pasteUSM({rowProperties,colProperties,cellMatrix},pasteTarget,pasteType)}async _pasteInternal(copyId,pasteType){var _a58,_b;const cachedData=core.Tools.deepClone(this._copyContentCache.get(copyId)),{range,matrix:cellMatrix,unitId:copyUnitId,subUnitId:copySubUnitId}=cachedData||{};if(!cellMatrix||!cachedData||!range||!copyUnitId||!copySubUnitId||!cellMatrix||!cachedData)return!1;const styles2=(_a58=this._univerInstanceService.getUniverSheetInstance(copyUnitId))==null?void 0:_a58.getStyles();cellMatrix.forValue((row,col,value)=>{if(typeof value.s=="string"){const newValue=core.Tools.deepClone(value);newValue.s=styles2==null?void 0:styles2.getStyleByCell(value),cellMatrix.setValue(row,col,newValue)}if(value.colSpan||value.rowSpan)for(let rStart=0;rStart<value.rowSpan;rStart++)for(let cStart=0;cStart<value.colSpan;cStart++){if(rStart===0&&cStart===0)continue;const r2=row+rStart,c=col+cStart;cellMatrix.setValue(r2,c,{s:styles2==null?void 0:styles2.getStyleByCell(value)})}});const pasteTarget=this._getPastedRange(cellMatrix);if(!pasteTarget)return!1;const pasteToWorksheet=(_b=this._univerInstanceService.getUniverSheetInstance(pasteTarget.unitId))==null?void 0:_b.getSheetBySheetId(pasteTarget.subUnitId);if(!pasteToWorksheet)return!1;const mergeData=pasteToWorksheet==null?void 0:pasteToWorksheet.getMergeData();if(mergeData&&mergeData.some(m2=>rangeIntersectWithDiscreteRange(m2,pasteTarget.pastedRange)&&!discreteRangeContainsRange(pasteTarget.pastedRange,m2)))return this._errorService.emit(this._localeService.t("clipboard.paste.overlappingMergedCells")),!1;const pasteFromWorkbook=this._univerInstanceService.getUnit(copyUnitId);if(!pasteFromWorkbook)return!1;const pasteFromWorksheet=pasteFromWorkbook.getSheetBySheetId(copySubUnitId);if(!pasteFromWorksheet)return!1;const colManager=pasteFromWorksheet.getColumnManager(),rowManager=pasteFromWorksheet.getRowManager(),defaultColumnWidth=pasteFromWorksheet.getConfig().defaultColumnWidth,defaultRowHeight=pasteFromWorksheet.getConfig().defaultRowHeight,colProperties=[],rowProperties=[];if(range.cols.forEach(i=>{const column=colManager.getColumnOrCreate(i);colProperties.push({width:`${column.w||defaultColumnWidth}`})}),range.rows.forEach(j=>{const row=rowManager.getRowOrCreate(j),{ah=defaultRowHeight,h=defaultRowHeight}=row,height=Math.max(ah,h);rowProperties.push({height:`${height}`})}),cachedData.copyType===COPY_TYPE.CUT){const start=pasteTarget.pastedRange.rows[0],end=range.rows[range.rows.length-1]-range.rows[0]+start;pasteTarget.pastedRange.rows=Array.from(new Array(end+1).keys()).slice(start)}const pasteRes=this._pasteUSM({cellMatrix,colProperties,rowProperties},pasteTarget,pasteType,{range,unitId:cachedData.unitId,subUnitId:cachedData.subUnitId,copyType:cachedData.copyType,copyId});return cachedData.copyType===COPY_TYPE.CUT&&(this._copyContentCache.set(copyId,{...cachedData,matrix:null}),this._copyMarkId&&this._markSelectionService.removeShape(this._copyMarkId),this._copyMarkId=null),pasteRes}_pasteUSM(data,target,pasteType,source){const{rowProperties,colProperties,cellMatrix}=data,{unitId,subUnitId,pastedRange}=target,colCount=pastedRange.cols.length,hooks=this._clipboardHooks,enabledHooks=[];if(hooks.some(h=>{var _a58;return enabledHooks.push(h)&&((_a58=h.onBeforePaste)==null?void 0:_a58.call(h,{unitId,subUnitId,range:pastedRange}))===!1}))return enabledHooks.forEach(h=>{var _a58;return(_a58=h.onAfterPaste)==null?void 0:_a58.call(h,!1)}),!1;if(!cellMatrix)return!1;const pasteFrom=source?{unitId:source.unitId,subUnitId:source.subUnitId,range:source.range}:null,payload={copyType:(source==null?void 0:source.copyType)||COPY_TYPE.COPY,copyId:source==null?void 0:source.copyId,pasteType};let redoMutationsInfo=[],undoMutationsInfo=[];enabledHooks.filter(h=>!h.specialPasteInfo&&h.id!==PREDEFINED_HOOK_NAME.DEFAULT_PASTE||pasteType===h.id).forEach(h=>{var _a58,_b,_c;if(rowProperties){const rowReturn=(_a58=h.onPasteRows)==null?void 0:_a58.call(h,{range:pastedRange,unitId,subUnitId},rowProperties,{pasteType});rowReturn&&(redoMutationsInfo.push(...rowReturn.redos),undoMutationsInfo.push(...rowReturn.undos))}const colReturn=(_b=h.onPasteColumns)==null?void 0:_b.call(h,{range:pastedRange,unitId,subUnitId},colProperties||new Array(colCount).map(()=>({})),{pasteType});colReturn&&(redoMutationsInfo.push(...colReturn.redos),undoMutationsInfo.push(...colReturn.undos));const contentReturn=(_c=h.onPasteCells)==null?void 0:_c.call(h,pasteFrom,{range:pastedRange,unitId,subUnitId},cellMatrix,payload);contentReturn&&(redoMutationsInfo.push(...contentReturn.redos),undoMutationsInfo.push(...contentReturn.undos))});const setSelectionOperation=this._getSetSelectionOperation(unitId,subUnitId,pastedRange,cellMatrix);setSelectionOperation&&redoMutationsInfo.push(setSelectionOperation),redoMutationsInfo=mergeSetRangeValues(redoMutationsInfo),undoMutationsInfo=mergeSetRangeValues(undoMutationsInfo),this._logService.log("[SheetClipboardService]","pasting mutations",{undoMutationsInfo,redoMutationsInfo});const result=redoMutationsInfo.every(m2=>this._commandService.syncExecuteCommand(m2.id,m2.params));return result&&this._undoRedoService.pushUndoRedo({unitID:unitId,undoMutations:undoMutationsInfo,redoMutations:redoMutationsInfo}),result}_getSetSelectionOperation(unitId,subUnitId,range,cellMatrix){var _a58;const worksheet=(_a58=this._univerInstanceService.getUniverSheetInstance(unitId))==null?void 0:_a58.getSheetBySheetId(subUnitId);if(!worksheet)return null;const{rows,cols}=range,startRow=rows[0],startColumn=cols[0],endRow=rows[rows.length-1],endColumn=cols[cols.length-1],primaryCell={startRow,endRow:startRow,startColumn,endColumn:startColumn},primary=sheets.getPrimaryForRange(primaryCell,worksheet),mainCell=cellMatrix.getValue(0,0),rowSpan=(mainCell==null?void 0:mainCell.rowSpan)||1,colSpan=(mainCell==null?void 0:mainCell.colSpan)||1;if(rowSpan>1||colSpan>1){const mergeRange={startRow,endRow:startRow+rowSpan-1,startColumn,endColumn:startColumn+colSpan-1};primary.startRow=mergeRange.startRow,primary.endRow=mergeRange.endRow,primary.startColumn=mergeRange.startColumn,primary.endColumn=mergeRange.endColumn,primary.isMerged=!0,primary.isMergedMainCell=!0}const setSelectionsParam={unitId,subUnitId,selections:[{range:{startRow,endRow,startColumn,endColumn},primary,style:null}]};return{id:sheets.SetSelectionsOperation.id,params:setSelectionsParam}}_getPastingTarget(){const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet(),selection=this._selectionManagerService.getCurrentLastSelection();return{unitId:workbook.getUnitId(),subUnitId:worksheet==null?void 0:worksheet.getSheetId(),selection}}_transformPastedData(rowCount,colCount,cellMatrix){const target=this._getPastingTarget(),{selection,unitId,subUnitId}=target;if(!subUnitId||!selection)return null;const discreteRange=this._injector.invoke(accessor=>rangeToDiscreteRange(selection.range,accessor,unitId,subUnitId));if(!discreteRange)return null;const{ranges:[vRange],mapFunc}=virtualizeDiscreteRanges([discreteRange]),{startRow,startColumn,endRow,endColumn}=vRange,destinationRows=endRow-startRow+1,destinationColumns=endColumn-startColumn+1,workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!worksheet)return null;const mergedCellsInRange=worksheet.getMergeData().filter(rect=>discreteRange.rows.includes(rect.startRow)&&discreteRange.cols.includes(rect.startColumn)),mergedRange=mergedCellsInRange[0];let mergedRangeStartRow=0,mergedRangeStartColumn=0,mergedRangeEndRow=0,mergedRangeEndColumn=0;if(mergedRange&&(mergedRangeStartRow=mergedRange.startRow,mergedRangeStartColumn=mergedRange.startColumn,mergedRangeEndRow=mergedRange.endRow,mergedRangeEndColumn=mergedRange.endColumn),destinationRows%rowCount===0&&destinationColumns%colCount===0)if(mergedCellsInRange.length>0&&(destinationRows!==rowCount||destinationColumns!==colCount))if(mergedRangeStartRow===discreteRange.rows[0]&&mergedRangeStartColumn===discreteRange.cols[0]&&mergedRangeEndRow===discreteRange.rows[destinationRows-1]&&mergedRangeEndColumn===discreteRange.cols[destinationColumns-1])if(isMultipleCells(cellMatrix))for(let r2=0;r2<destinationRows;r2++)for(let c=0;c<destinationColumns;c++){const cell=cellMatrix.getValue(r2%rowCount,c%colCount);cell&&cellMatrix.setValue(r2,c,cell)}else cellMatrix.forValue((row,col,cell)=>{cell.s=null,delete cell.colSpan,delete cell.rowSpan});else for(let r2=0;r2<destinationRows;r2++)for(let c=0;c<destinationColumns;c++){const cell=cellMatrix.getValue(r2%rowCount,c%colCount);cell&&cellMatrix.setValue(r2,c,cell)}else for(let r2=0;r2<destinationRows;r2++)for(let c=0;c<destinationColumns;c++){const cell=cellMatrix.getValue(r2%rowCount,c%colCount);cell&&cellMatrix.setValue(r2,c,cell)}else if(mergedCellsInRange.length>0){const{row:topRow,col:leftCol}=mapFunc(startRow,startColumn);if(this._topLeftCellsMatch(rowCount,colCount,{topRow,leftCol})){const newDiscreteRange=this._expandOrShrinkRowsCols(unitId,subUnitId,discreteRange,colCount,rowCount);discreteRange.rows=newDiscreteRange.rows,discreteRange.cols=newDiscreteRange.cols}else{if(endRow>mergedRange.endRow||endColumn>mergedRange.endColumn)return null;cellMatrix.forValue((row,col,cell)=>{cell.s=null,delete cell.colSpan,delete cell.rowSpan})}}else{const newDiscreteRange=this._expandOrShrinkRowsCols(unitId,subUnitId,discreteRange,colCount,rowCount);discreteRange.rows=newDiscreteRange.rows,discreteRange.cols=newDiscreteRange.cols}return{pastedRange:discreteRange,unitId,subUnitId}}_getPastedRange(cellMatrix){var _a58;const target=this._getPastingTarget(),{selection,unitId,subUnitId}=target;if(!subUnitId||!selection)return null;const discreteRange=this._injector.invoke(accessor=>rangeToDiscreteRange(selection.range,accessor,unitId,subUnitId));if(!discreteRange)return null;const{startColumn,endColumn,startRow,endRow}=cellMatrix.getDataRange(),rowCount=endRow-startRow+1,colCount=endColumn-startColumn+1;if(rowCount<=0||colCount<=0)return null;const pasteSelectionRangeRowLen=discreteRange.rows.length,pasteSelectionRangeColLen=discreteRange.cols.length,worksheet=(_a58=this._univerInstanceService.getUniverSheetInstance(unitId))==null?void 0:_a58.getSheetBySheetId(subUnitId);if(!worksheet)return null;const mergeData=worksheet==null?void 0:worksheet.getMergeData();if(pasteSelectionRangeRowLen%rowCount===0&&pasteSelectionRangeColLen%colCount===0&&!(mergeData==null?void 0:mergeData.some(merge=>rangeIntersectWithDiscreteRange(merge,discreteRange)))){for(let r2=0;r2<pasteSelectionRangeRowLen;r2++)for(let c=0;c<pasteSelectionRangeColLen;c++){const cell=cellMatrix.getValue(r2%rowCount,c%colCount);cell&&cellMatrix.setValue(r2,c,cell)}return{pastedRange:discreteRange,unitId,subUnitId}}const newDiscreteRange=this._expandOrShrinkRowsCols(unitId,subUnitId,discreteRange,colCount,rowCount);return discreteRange.rows=newDiscreteRange.rows,discreteRange.cols=newDiscreteRange.cols,{pastedRange:discreteRange,unitId,subUnitId}}_expandOrShrinkRowsCols(unitId,subUnitId,range,colCount,rowCount){const{rows,cols}=range,workbook=this._univerInstanceService.getUniverSheetInstance(unitId),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);let newRows,newCols;if(rows.length>=rowCount)newRows=rows.slice(0,rowCount);else{newRows=rows.slice(0);let rowIndex=rows[rows.length-1]+1;for(;newRows.length<rowCount;)worksheet.getRowFiltered(rowIndex)||newRows.push(rowIndex),rowIndex++}if(cols.length>=colCount)newCols=cols.slice(0,colCount);else{newCols=cols.slice(0);let colIndex=cols[cols.length-1]+1;for(;newCols.length<colCount;)newCols.push(colIndex),colIndex++}return{rows:newRows,cols:newCols}}_topLeftCellsMatch(rowCount,colCount,range){const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook==null?void 0:workbook.getActiveSheet();if(!worksheet)return!1;const{topRow,leftCol}=range,isRowAcross=rowAcrossMergedCell(topRow+rowCount-1,leftCol,leftCol+colCount-1,worksheet),isColAcross=columnAcrossMergedCell(leftCol+colCount-1,topRow,topRow+rowCount-1,worksheet);return!isRowAcross&&!isColAcross}removeMarkSelection(){this._copyMarkId&&(this._markSelectionService.removeShape(this._copyMarkId),this._copyMarkId=null)}},__name(_a14,"SheetClipboardService"),_a14);exports.SheetClipboardService=__decorateClass$F([__decorateParam$F(0,core.ILogService),__decorateParam$F(1,core.IUniverInstanceService),__decorateParam$F(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$F(3,ui.IClipboardInterfaceService),__decorateParam$F(4,core.IUndoRedoService),__decorateParam$F(5,core.ICommandService),__decorateParam$F(6,IMarkSelectionService),__decorateParam$F(7,ui.INotificationService),__decorateParam$F(8,ui.IPlatformService),__decorateParam$F(9,engineRender.IRenderManagerService),__decorateParam$F(10,core.Inject(core.ThemeService)),__decorateParam$F(11,core.Inject(core.LocaleService)),__decorateParam$F(12,core.Inject(core.ErrorService)),__decorateParam$F(13,core.Inject(core.Injector))],exports.SheetClipboardService);function getMatrixPlainText(matrix){let plain="";const matrixLength=matrix.getLength();return matrix.forRow((row,cols)=>{const arr=[];cols.forEach(col=>{const cell=matrix.getValue(row,col);if(cell){const cellText=getCellTextForClipboard(cell);arr.push(cellText)}}),plain+=arr.join(" "),row!==matrixLength-1&&(plain+=`
17
- `)}),plain}__name(getMatrixPlainText,"getMatrixPlainText");function getCellTextForClipboard(cell){return core.extractPureTextFromCell(cell)}__name(getCellTextForClipboard,"getCellTextForClipboard");function rowAcrossMergedCell(row,startColumn,endColumn,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startRow<=row&&row<mergedCell.endRow&&startColumn<=mergedCell.startColumn&&mergedCell.startColumn<=endColumn)}__name(rowAcrossMergedCell,"rowAcrossMergedCell");function columnAcrossMergedCell(col,startRow,endRow,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startColumn<=col&&col<mergedCell.endColumn&&startRow<=mergedCell.startRow&&mergedCell.startRow<=endRow)}__name(columnAcrossMergedCell,"columnAcrossMergedCell");function isMultipleCells(cellMatrix){let count=0;return cellMatrix.forValue((row,col,cell)=>{if(cell&&count++,count>1)return!1}),count>1}__name(isMultipleCells,"isMultipleCells");function getEmptyCell(){return{p:null,v:null,s:null,f:null,si:null,t:null}}__name(getEmptyCell,"getEmptyCell");const SHEET_CLIPBOARD_PRIORITY=998,SheetCopyCommand={id:ui.CopyCommand.id,name:"sheet.command.copy",type:core.CommandType.COMMAND,multi:!0,priority:SHEET_CLIPBOARD_PRIORITY,preconditions:whenSheetFocused,handler:__name(async accessor=>accessor.get(ISheetClipboardService).copy(),"handler")},SheetCutCommand={id:ui.CutCommand.id,name:"sheet.command.cut",type:core.CommandType.COMMAND,multi:!0,priority:SHEET_CLIPBOARD_PRIORITY,preconditions:whenSheetFocused,handler:__name(async accessor=>accessor.get(ISheetClipboardService).cut(),"handler")},SheetPasteCommand={id:ui.PasteCommand.id,type:core.CommandType.COMMAND,multi:!0,name:"sheet.command.paste",priority:SHEET_CLIPBOARD_PRIORITY,preconditions:whenSheetFocused,handler:__name(async(accessor,params)=>{const clipboardItems=await accessor.get(ui.IClipboardInterfaceService).read(),sheetClipboardService=accessor.get(ISheetClipboardService);return clipboardItems.length!==0?sheetClipboardService.paste(clipboardItems[0],params==null?void 0:params.value):!1},"handler")},SheetPasteShortKeyCommand={id:"sheet.command.paste-bu-short-key",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const clipboardService=accessor.get(ISheetClipboardService),{htmlContent,textContent}=params;return clipboardService.legacyPaste(htmlContent,textContent),!0},"handler")},SheetPasteValueCommand={id:"sheet.command.paste-value",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE}),"handler")},SheetPasteFormatCommand={id:"sheet.command.paste-format",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT}),"handler")},SheetPasteColWidthCommand={id:"sheet.command.paste-col-width",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH}),"handler")},SheetPasteBesidesBorderCommand={id:"sheet.command.paste-besides-border",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_BESIDES_BORDER}),"handler")};function CellBorderSelectorMenuItemFactory(accessor){const borderStyleManagerService=accessor.get(sheets.BorderStyleManagerService),disabled$=getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]});return{id:sheets.SetBorderBasicCommand.id,icon:new rxjs.Observable(subscriber=>{const defaultIcon="AllBorderSingle",borderManager=accessor.get(sheets.BorderStyleManagerService),disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a58;if(c.id!==sheets.SetBorderBasicCommand.id)return;const{type}=borderManager.getBorderInfo(),item=BORDER_LINE_CHILDREN.find(item2=>item2.value===type),icon=(_a58=item==null?void 0:item.icon)!=null?_a58:defaultIcon;subscriber.next(icon)});return subscriber.next(defaultIcon),disposable.dispose}),tooltip:"toolbar.border.main",type:ui.MenuItemType.BUTTON_SELECTOR,selections:[{label:{name:BORDER_PANEL_COMPONENT,hoverable:!1},value$:borderStyleManagerService.borderInfo$}],value$:borderStyleManagerService.borderInfo$,hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$}}__name(CellBorderSelectorMenuItemFactory,"CellBorderSelectorMenuItemFactory");const CLEAR_SELECTION_MENU_ID="sheet.menu.clear-selection";function ClearSelectionMenuItemFactory(accessor){return{id:CLEAR_SELECTION_MENU_ID,type:ui.MenuItemType.SUBITEMS,icon:"ClearFormat",title:"rightClick.clearSelection",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionMenuItemFactory,"ClearSelectionMenuItemFactory");function ClearSelectionContentMenuItemFactory(accessor){return{id:sheets.ClearSelectionContentCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.clearContent",disabled$:getObservableWithExclusiveRange$(accessor,getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionContentMenuItemFactory,"ClearSelectionContentMenuItemFactory");function ClearSelectionFormatMenuItemFactory(accessor){return{id:sheets.ClearSelectionFormatCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.clearFormat",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionFormatMenuItemFactory,"ClearSelectionFormatMenuItemFactory");function ClearSelectionAllMenuItemFactory(accessor){return{id:sheets.ClearSelectionAllCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.clearAll",disabled$:getObservableWithExclusiveRange$(accessor,getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionAllMenuItemFactory,"ClearSelectionAllMenuItemFactory");const DELETE_RANGE_MENU_ID="sheet.menu.delete";function DeleteRangeMenuItemFactory(accessor){return{id:DELETE_RANGE_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.delete",icon:"Reduce",hidden$:getObservableWithExclusiveRange$(accessor,getBaseRangeMenuHidden$(accessor)),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission]})}}__name(DeleteRangeMenuItemFactory,"DeleteRangeMenuItemFactory");function RemoveColMenuItemFactory(accessor){return{id:RemoveColConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"DeleteColumn",title:"rightClick.deleteSelectedColumn",hidden$:getDeleteMenuHidden$(accessor,"col"),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetDeleteColumnPermission]})}}__name(RemoveColMenuItemFactory,"RemoveColMenuItemFactory");function RemoveRowMenuItemFactory(accessor){return{id:RemoveRowConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"DeleteRow",title:"rightClick.deleteSelectedRow",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetDeleteRowPermission]}),hidden$:getDeleteMenuHidden$(accessor,"row")}}__name(RemoveRowMenuItemFactory,"RemoveRowMenuItemFactory");function DeleteRangeMoveLeftMenuItemFactory(accessor){return{id:DeleteRangeMoveLeftConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveLeft",icon:"DeleteCellShiftLeft",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"col")}}__name(DeleteRangeMoveLeftMenuItemFactory,"DeleteRangeMoveLeftMenuItemFactory");function DeleteRangeMoveUpMenuItemFactory(accessor){return{id:DeleteRangeMoveUpConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveUp",icon:"DeleteCellShiftUp",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"row")}}__name(DeleteRangeMoveUpMenuItemFactory,"DeleteRangeMoveUpMenuItemFactory");const COL_INSERT_MENU_ID="sheet.menu.col-insert";function ColInsertMenuItemFactory(accessor){return{id:COL_INSERT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.insert",icon:"Insert",hidden$:getBaseRangeMenuHidden$(accessor),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetInsertColumnPermission]})}}__name(ColInsertMenuItemFactory,"ColInsertMenuItemFactory");const ROW_INSERT_MENU_ID="sheet.menu.row-insert";function RowInsertMenuItemFactory(accessor){return{id:ROW_INSERT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.insert",icon:"Insert",hidden$:getBaseRangeMenuHidden$(accessor),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertRowPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(RowInsertMenuItemFactory,"RowInsertMenuItemFactory");const CELL_INSERT_MENU_ID="sheet.menu.cell-insert";function CellInsertMenuItemFactory(accessor){return{id:CELL_INSERT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.insert",icon:"Insert",hidden$:getObservableWithExclusiveRange$(accessor,getBaseRangeMenuHidden$(accessor)),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertColumnPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(CellInsertMenuItemFactory,"CellInsertMenuItemFactory");function InsertRowBeforeMenuItemFactory(accessor){return{id:sheets.InsertRowBeforeCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertRowBefore",icon:"InsertRowAbove",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertRowPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertBeforeMenuHidden$(accessor,"row")}}__name(InsertRowBeforeMenuItemFactory,"InsertRowBeforeMenuItemFactory");function InsertRowAfterMenuItemFactory(accessor){return{id:sheets.InsertRowAfterCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertRow",icon:"InsertRowBelow",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertRowPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertAfterMenuHidden$(accessor,"row")}}__name(InsertRowAfterMenuItemFactory,"InsertRowAfterMenuItemFactory");function InsertColBeforeMenuItemFactory(accessor){return{id:sheets.InsertColBeforeCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertColumnBefore",icon:"LeftInsertColumn",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertColumnPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertBeforeMenuHidden$(accessor,"col")}}__name(InsertColBeforeMenuItemFactory,"InsertColBeforeMenuItemFactory");function InsertColAfterMenuItemFactory(accessor){return{id:sheets.InsertColAfterCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertColumn",icon:"RightInsertColumn",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertColumnPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertAfterMenuHidden$(accessor,"col")}}__name(InsertColAfterMenuItemFactory,"InsertColAfterMenuItemFactory");function InsertRangeMoveRightMenuItemFactory(accessor){return{id:InsertRangeMoveRightConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveRight",icon:"InsertCellShiftRight",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"col")}}__name(InsertRangeMoveRightMenuItemFactory,"InsertRangeMoveRightMenuItemFactory");function InsertRangeMoveDownMenuItemFactory(accessor){return{id:InsertRangeMoveDownConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveDown",icon:"InsertCellDown",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"row")}}__name(InsertRangeMoveDownMenuItemFactory,"InsertRangeMoveDownMenuItemFactory");var SheetMenuPosition=(SheetMenuPosition2=>(SheetMenuPosition2.ROW_HEADER_CONTEXT_MENU="ROW_HEADER_CONTEXT_MENU",SheetMenuPosition2.COL_HEADER_CONTEXT_MENU="COL_HEADER_CONTEXT_MENU",SheetMenuPosition2.SHEET_BAR="SHEET_BAR",SheetMenuPosition2.SHEET_FOOTER="SHEET_FOOTER",SheetMenuPosition2))(SheetMenuPosition||{});function FormatPainterMenuItemFactory(accessor){const formatPainterService=accessor.get(IFormatPainterService);return{id:SetOnceFormatPainterCommand.id,subId:SetInfiniteFormatPainterCommand.id,type:ui.MenuItemType.BUTTON,icon:"BrushSingle",title:"Format Painter",tooltip:"toolbar.formatPainter",activated$:new rxjs.Observable(subscriber=>{let active=!1;const status$=formatPainterService.status$.subscribe(s=>{active=s!==FormatPainterStatus.OFF,subscriber.next(active)});return subscriber.next(active),()=>{status$.unsubscribe()}}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetCopyPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(FormatPainterMenuItemFactory,"FormatPainterMenuItemFactory");function BoldMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),contextService=accessor.get(core.IContextService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return{id:SetRangeBoldCommand.id,type:ui.MenuItemType.BUTTON,icon:"BoldSingle",title:"Set bold",tooltip:"toolbar.bold",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let isBold2=core.FontWeight.NORMAL;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);isBold2=range==null?void 0:range.getFontWeight()}subscriber.next(isBold2===core.FontWeight.BOLD)}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const bl=(_b=textRun.ts)==null?void 0:_b.bl;subscriber.next(bl===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;if(!worksheet){subscriber.next(!1);return}let isBold=core.FontWeight.NORMAL;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);isBold=range==null?void 0:range.getFontWeight()}return subscriber.next(isBold===core.FontWeight.BOLD),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(BoldMenuItemFactory,"BoldMenuItemFactory");function ItalicMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService);return{id:SetRangeItalicCommand.id,type:ui.MenuItemType.BUTTON,icon:"ItalicSingle",title:"Set italic",tooltip:"toolbar.italic",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let isItalic2=core.FontItalic.NORMAL;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);isItalic2=range==null?void 0:range.getFontStyle()}subscriber.next(isItalic2===core.FontItalic.ITALIC)}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const it=(_b=textRun.ts)==null?void 0:_b.it;subscriber.next(it===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let isItalic=core.FontItalic.NORMAL;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);isItalic=range==null?void 0:range.getFontStyle()}return subscriber.next(isItalic===core.FontItalic.ITALIC),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ItalicMenuItemFactory,"ItalicMenuItemFactory");function UnderlineMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService);return{id:SetRangeUnderlineCommand.id,type:ui.MenuItemType.BUTTON,icon:"UnderlineSingle",title:"Set underline",tooltip:"toolbar.underline",activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let isUnderline2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);isUnderline2=range==null?void 0:range.getUnderline()}subscriber.next(!!(isUnderline2&&isUnderline2.s))}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const ul=(_b=textRun.ts)==null?void 0:_b.ul;subscriber.next((ul==null?void 0:ul.s)===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let isUnderline;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);isUnderline=range==null?void 0:range.getUnderline()}return subscriber.next(!!(isUnderline&&isUnderline.s)),disposable.dispose})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(UnderlineMenuItemFactory,"UnderlineMenuItemFactory");function StrikeThroughMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService);return{id:SetRangeStrickThroughCommand.id,type:ui.MenuItemType.BUTTON,icon:"StrikethroughSingle",title:"Set strike through",tooltip:"toolbar.strikethrough",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let st2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);st2=range==null?void 0:range.getStrikeThrough()}subscriber.next(!!(st2&&st2.s))}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const st2=(_b=textRun.ts)==null?void 0:_b.st;subscriber.next((st2==null?void 0:st2.s)===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let st;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);st=range==null?void 0:range.getStrikeThrough()}return subscriber.next(!!(st&&st.s)),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(StrikeThroughMenuItemFactory,"StrikeThroughMenuItemFactory");function FontFamilySelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=core.DEFAULT_STYLES.ff;return{id:SetRangeFontFamilyCommand.id,tooltip:"toolbar.font",type:ui.MenuItemType.SELECTOR,label:FONT_FAMILY_COMPONENT,selections:ui.FONT_FAMILY_LIST.map(item=>({label:{name:FONT_FAMILY_ITEM_COMPONENT,hoverable:!0},value:item.value})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetRangeValuesMutation.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let ff2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);ff2=range==null?void 0:range.getFontFamily()}subscriber.next(ff2!=null?ff2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let ff;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);ff=range==null?void 0:range.getFontFamily()}return subscriber.next(ff!=null?ff:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FontFamilySelectorMenuItemFactory,"FontFamilySelectorMenuItemFactory");function FontSizeSelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService),defaultValue=core.DEFAULT_STYLES.fs,disabled$=getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]});return{id:SetRangeFontSizeCommand.id,type:ui.MenuItemType.SELECTOR,tooltip:"toolbar.fontSize",label:{name:FONT_SIZE_COMPONENT,props:{min:1,max:400,disabled$}},selections:ui.FONT_SIZE_LIST,disabled$,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let fs2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);fs2=range==null?void 0:range.getFontSize()}subscriber.next(fs2!=null?fs2:defaultValue)}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const fs2=(_b=textRun.ts)==null?void 0:_b.fs;subscriber.next(fs2!=null?fs2:defaultValue)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let fs;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);fs=range==null?void 0:range.getFontSize()}return subscriber.next(fs!=null?fs:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FontSizeSelectorMenuItemFactory,"FontSizeSelectorMenuItemFactory");function ResetTextColorMenuItemFactory(accessor){return{id:sheets.ResetTextColorCommand.id,type:ui.MenuItemType.BUTTON,title:"toolbar.resetColor",icon:"NoColor",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ResetTextColorMenuItemFactory,"ResetTextColorMenuItemFactory");function TextColorSelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),themeService=accessor.get(core.ThemeService);return{id:SetRangeTextColorCommand.id,icon:"FontColor",tooltip:"toolbar.textColor.main",type:ui.MenuItemType.BUTTON_SELECTOR,selections:[{label:{name:COLOR_PICKER_COMPONENT,hoverable:!1}}],value$:new rxjs.Observable(subscriber=>{const defaultValue=themeService.getCurrentTheme().textColor,disposable=commandService.onCommandExecuted(c=>{if(c.id===SetRangeTextColorCommand.id){const color=c.params.value;subscriber.next(color!=null?color:defaultValue)}});return subscriber.next(defaultValue),disposable.dispose}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(TextColorSelectorMenuItemFactory,"TextColorSelectorMenuItemFactory");function ResetBackgroundColorMenuItemFactory(accessor){return{id:sheets.ResetBackgroundColorCommand.id,type:ui.MenuItemType.BUTTON,title:"toolbar.resetColor",icon:"NoColor",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(ResetBackgroundColorMenuItemFactory,"ResetBackgroundColorMenuItemFactory");function BackgroundColorSelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),themeService=accessor.get(core.ThemeService);return{id:sheets.SetBackgroundColorCommand.id,tooltip:"toolbar.fillColor.main",type:ui.MenuItemType.BUTTON_SELECTOR,icon:"PaintBucket",selections:[{label:{name:COLOR_PICKER_COMPONENT,hoverable:!1}}],value$:new rxjs.Observable(subscriber=>{const defaultValue=themeService.getCurrentTheme().primaryColor,disposable=commandService.onCommandExecuted(c=>{if(c.id===sheets.SetBackgroundColorCommand.id){const color=c.params.value;subscriber.next(color!=null?color:defaultValue)}});return subscriber.next(defaultValue),disposable.dispose}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(BackgroundColorSelectorMenuItemFactory,"BackgroundColorSelectorMenuItemFactory");const HORIZONTAL_ALIGN_CHILDREN=[{label:"align.left",icon:"LeftJustifyingSingle",value:core.HorizontalAlign.LEFT},{label:"align.center",icon:"HorizontallySingle",value:core.HorizontalAlign.CENTER},{label:"align.right",icon:"RightJustifyingSingle",value:core.HorizontalAlign.RIGHT}];function HorizontalAlignMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=core.HorizontalAlign.LEFT;return{id:sheets.SetHorizontalTextAlignCommand.id,icon:HORIZONTAL_ALIGN_CHILDREN[0].icon,tooltip:"toolbar.horizontalAlignMode.main",type:ui.MenuItemType.SELECTOR,selections:HORIZONTAL_ALIGN_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetHorizontalTextAlignCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let ha2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);ha2=range==null?void 0:range.getHorizontalAlignment()}subscriber.next(ha2!=null?ha2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let ha;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);ha=range==null?void 0:range.getHorizontalAlignment()}return subscriber.next(ha!=null?ha:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(HorizontalAlignMenuItemFactory,"HorizontalAlignMenuItemFactory");const VERTICAL_ALIGN_CHILDREN=[{label:"align.top",icon:"AlignTopSingle",value:core.VerticalAlign.TOP},{label:"align.middle",icon:"VerticalCenterSingle",value:core.VerticalAlign.MIDDLE},{label:"align.bottom",icon:"AlignBottomSingle",value:core.VerticalAlign.BOTTOM}];function VerticalAlignMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=core.VerticalAlign.BOTTOM;return{id:sheets.SetVerticalTextAlignCommand.id,icon:VERTICAL_ALIGN_CHILDREN[2].icon,tooltip:"toolbar.verticalAlignMode.main",type:ui.MenuItemType.SELECTOR,selections:VERTICAL_ALIGN_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetVerticalTextAlignCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let va2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);va2=range==null?void 0:range.getVerticalAlignment()}subscriber.next(va2!=null?va2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let va;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);va=range==null?void 0:range.getVerticalAlignment()}return subscriber.next(va!=null?va:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(VerticalAlignMenuItemFactory,"VerticalAlignMenuItemFactory");const TEXT_WRAP_CHILDREN=[{label:"textWrap.overflow",icon:"OverflowSingle",value:core.WrapStrategy.OVERFLOW},{label:"textWrap.wrap",icon:"AutowrapSingle",value:core.WrapStrategy.WRAP},{label:"textWrap.clip",icon:"TruncationSingle",value:core.WrapStrategy.CLIP}];function WrapTextMenuItemFactory(accessor){const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),defaultValue=core.WrapStrategy.OVERFLOW;return{id:sheets.SetTextWrapCommand.id,tooltip:"toolbar.textWrapMode.main",icon:TEXT_WRAP_CHILDREN[0].icon,type:ui.MenuItemType.SELECTOR,selections:TEXT_WRAP_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetTextWrapCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let ws2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);ws2=range==null?void 0:range.getWrapStrategy()}subscriber.next(ws2!=null?ws2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let ws;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);ws=range==null?void 0:range.getWrapStrategy()}return subscriber.next(ws!=null?ws:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(WrapTextMenuItemFactory,"WrapTextMenuItemFactory");const TEXT_ROTATE_CHILDREN=[{label:"textRotate.none",icon:"NoRotationSingle",value:0},{label:"textRotate.angleUp",icon:"LeftRotationFortyFiveDegreesSingle",value:-45},{label:"textRotate.angleDown",icon:"RightRotationFortyFiveDegreesSingle",value:45},{label:"textRotate.vertical",icon:"VerticalTextSingle",value:"v"},{label:"textRotate.rotationUp",icon:"LeftRotationNinetyDegreesSingle",value:-90},{label:"textRotate.rotationDown",icon:"RightRotationNinetyDegreesSingle",value:90}];function TextRotateMenuItemFactory(accessor){const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),defaultValue=0;return{id:sheets.SetTextRotationCommand.id,tooltip:"toolbar.textRotateMode.main",icon:TEXT_ROTATE_CHILDREN[0].icon,type:ui.MenuItemType.SELECTOR,selections:TEXT_ROTATE_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58,_b;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59,_b2;const id=c.id;if(id!==sheets.SetTextRotationCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let tr2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);tr2=range==null?void 0:range.getTextRotation()}(tr2==null?void 0:tr2.v)===core.BooleanNumber.TRUE?subscriber.next("v"):subscriber.next((_b2=tr2&&tr2.a)!=null?_b2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let tr;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);tr=range==null?void 0:range.getTextRotation()}return(tr==null?void 0:tr.v)===core.BooleanNumber.TRUE?subscriber.next("v"):subscriber.next((_b=tr&&tr.a)!=null?_b:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(TextRotateMenuItemFactory,"TextRotateMenuItemFactory");function menuClipboardDisabledObservable(injector){return new rxjs.Observable(subscriber=>subscriber.next(!injector.get(ui.IClipboardInterfaceService).supportClipboard))}__name(menuClipboardDisabledObservable,"menuClipboardDisabledObservable");function CopyMenuItemFactory(accessor){return{id:SheetCopyCommand.name,commandId:SheetCopyCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.copy",icon:"Copy",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookCopyPermission],worksheetTypes:[sheets.WorksheetCopyPermission],rangeTypes:[sheets.RangeProtectionPermissionViewPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CopyMenuItemFactory,"CopyMenuItemFactory");function PasteMenuItemFactory(accessor){return{id:SheetPasteCommand.name,commandId:SheetPasteCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.paste",icon:"PasteSpecial",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission,sheets.WorksheetSetCellValuePermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteMenuItemFactory,"PasteMenuItemFactory");const PASTE_SPECIAL_MENU_ID="sheet.menu.paste-special";function PasteSpacialMenuItemFactory(accessor){return{id:PASTE_SPECIAL_MENU_ID,type:ui.MenuItemType.SUBITEMS,icon:"PasteSpecial",title:"rightClick.pasteSpecial",hidden$:getObservableWithExclusiveRange$(accessor,ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET))}}__name(PasteSpacialMenuItemFactory,"PasteSpacialMenuItemFactory");function PasteValueMenuItemFactory(accessor){return{id:SheetPasteValueCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteValue",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteValueMenuItemFactory,"PasteValueMenuItemFactory");function PasteFormatMenuItemFactory(accessor){return{id:SheetPasteFormatCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteFormat",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteFormatMenuItemFactory,"PasteFormatMenuItemFactory");function PasteColWidthMenuItemFactory(accessor){return{id:SheetPasteColWidthCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteColWidth",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetColumnStylePermission,sheets.WorksheetEditPermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2))}}__name(PasteColWidthMenuItemFactory,"PasteColWidthMenuItemFactory");function PasteBesidesBorderMenuItemFactory(accessor){return{id:SheetPasteBesidesBorderCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteBesidesBorder",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetRowStylePermission,sheets.WorksheetSetColumnStylePermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteBesidesBorderMenuItemFactory,"PasteBesidesBorderMenuItemFactory");function FitContentMenuItemFactory(accessor){return{id:sheets.SetWorksheetRowIsAutoHeightCommand.id,type:ui.MenuItemType.BUTTON,icon:"AutoHeight",title:"rightClick.fitContent",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetSetRowStylePermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FitContentMenuItemFactory,"FitContentMenuItemFactory");const SHEET_FROZEN_MENU_ID="sheet.menu.sheet-frozen";function SheetFrozenMenuItemFactory(accessor){return{id:SHEET_FROZEN_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.freeze",icon:"FreezeToSelectedSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(SheetFrozenMenuItemFactory,"SheetFrozenMenuItemFactory");const SHEET_FROZEN_HEADER_MENU_ID="sheet.header-menu.sheet-frozen";function SheetFrozenHeaderMenuItemFactory(accessor){return{id:SHEET_FROZEN_HEADER_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.freeze",icon:"FreezeToSelectedSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(SheetFrozenHeaderMenuItemFactory,"SheetFrozenHeaderMenuItemFactory");function FrozenMenuItemFactory(accessor){return{id:SetSelectionFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.freeze",icon:"FreezeToSelectedSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FrozenMenuItemFactory,"FrozenMenuItemFactory");function FrozenRowMenuItemFactory(accessor){return{id:SetRowFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.freezeRow",icon:"FreezeRowSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FrozenRowMenuItemFactory,"FrozenRowMenuItemFactory");function FrozenColMenuItemFactory(accessor){return{id:SetColumnFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.freezeCol",icon:"FreezeColumnSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FrozenColMenuItemFactory,"FrozenColMenuItemFactory");function CancelFrozenMenuItemFactory(accessor){return{id:CancelFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.cancelFreeze",icon:"CancelFreezeSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CancelFrozenMenuItemFactory,"CancelFrozenMenuItemFactory");function HideRowMenuItemFactory(accessor){return{id:HideRowConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"Hide",title:"rightClick.hideSelectedRow",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetSetRowStylePermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(HideRowMenuItemFactory,"HideRowMenuItemFactory");function HideColMenuItemFactory(accessor){return{id:HideColConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"Hide",title:"rightClick.hideSelectedColumn",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(HideColMenuItemFactory,"HideColMenuItemFactory");function ShowRowMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),affectedCommands=[sheets.SetSelectionsOperation,sheets.SetRowHiddenMutation,sheets.SetRowVisibleMutation].map(c=>c.id);return{id:sheets.SetSelectedRowsVisibleCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.showHideRow",hidden$:deriveStateFromActiveSheet$(univerInstanceService,!0,({worksheet})=>new rxjs.Observable(subscriber=>{function hasHiddenRowsInSelections(){var _a58;const rowRanges=(_a58=selectionManagerService.getCurrentSelections())==null?void 0:_a58.map(s=>s.range).filter(r2=>r2.rangeType===core.RANGE_TYPE.ROW);return!!(rowRanges!=null&&rowRanges.some(range=>{for(let r2=range.startRow;r2<=range.endRow;r2++)if(!worksheet.getRowRawVisible(r2))return!0;return!1}))}__name(hasHiddenRowsInSelections,"hasHiddenRowsInSelections");const disposable=commandService.onCommandExecuted(command=>{affectedCommands.findIndex(c=>c===command.id)!==-1&&subscriber.next(!hasHiddenRowsInSelections())});return subscriber.next(!hasHiddenRowsInSelections()),()=>disposable.dispose()})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(ShowRowMenuItemFactory,"ShowRowMenuItemFactory");function ShowColMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),affectedCommands=[sheets.SetSelectionsOperation,sheets.SetColHiddenMutation,sheets.SetColVisibleMutation].map(c=>c.id);return{id:sheets.SetSelectedColsVisibleCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.showHideColumn",hidden$:deriveStateFromActiveSheet$(univerInstanceService,!0,({worksheet})=>new rxjs.Observable(subscriber=>{function hasHiddenColsInSelections(){var _a58;const colRanges=(_a58=selectionManagerService.getCurrentSelections())==null?void 0:_a58.map(s=>s.range).filter(r2=>r2.rangeType===core.RANGE_TYPE.COLUMN);return!colRanges||colRanges.length===0?!1:!!colRanges.some(range=>{for(let r2=range.startColumn;r2<=range.endColumn;r2++)if(!worksheet.getColVisible(r2))return!0;return!1})}__name(hasHiddenColsInSelections,"hasHiddenColsInSelections");const disposable=commandService.onCommandExecuted(commandInfo=>{affectedCommands.findIndex(c=>c===commandInfo.id)!==-1&&subscriber.next(!hasHiddenColsInSelections())});return subscriber.next(!hasHiddenColsInSelections()),()=>disposable.dispose()})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetSetColumnStylePermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(ShowColMenuItemFactory,"ShowColMenuItemFactory");function SetRowHeightMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=0;return{id:sheets.SetRowHeightCommand.id,type:ui.MenuItemType.BUTTON,icon:"AdjustHeight",label:{name:MENU_ITEM_INPUT_COMPONENT,props:{prefix:"rightClick.rowHeight",suffix:"px",min:2,max:1e3}},value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{function update(){var _a58;const primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary,rowHeight=primary?worksheet.getRowHeight(primary.startRow):defaultValue;subscriber.next(rowHeight)}__name(update,"update");const disposable=commandService.onCommandExecuted(c=>{const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetRowIsAutoHeightMutation.id)return update()});return update(),disposable.dispose})),hidden$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(SetRowHeightMenuItemFactory,"SetRowHeightMenuItemFactory");function SetColWidthMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=0;return{id:sheets.SetColWidthCommand.id,type:ui.MenuItemType.BUTTON,icon:"AdjustWidth",label:{name:MENU_ITEM_INPUT_COMPONENT,props:{prefix:"rightClick.columnWidth",suffix:"px",min:2,max:1e3}},value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{function update(){var _a58;const primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let colWidth=defaultValue;primary!=null&&(colWidth=worksheet.getColumnWidth(primary.startColumn)),subscriber.next(colWidth)}__name(update,"update");const disposable=commandService.onCommandExecuted(c=>{const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetColWidthMutation.id)return update()});return update(),disposable.dispose})),hidden$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(SetColWidthMenuItemFactory,"SetColWidthMenuItemFactory");function getFontStyleAtCursor(accessor){var _a58;const univerInstanceService=accessor.get(core.IUniverInstanceService),textSelectionService=accessor.get(docs.DocSelectionManagerService),editorDataModel=univerInstanceService.getUniverDocInstance(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),activeTextRange=textSelectionService.getActiveTextRange();if(editorDataModel==null||activeTextRange==null)return null;const textRuns=(_a58=editorDataModel.getBody())==null?void 0:_a58.textRuns;if(textRuns==null)return;const{startOffset}=activeTextRange;return textRuns.find(({st,ed})=>startOffset>=st&&startOffset<=ed)}__name(getFontStyleAtCursor,"getFontStyleAtCursor");function getSheetSelectionsDisabled$(accessor){const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),univerInstanceService=accessor.get(core.IUniverInstanceService),mergeCellController=accessor.get(sheets.MergeCellController),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET);return rxjs.combineLatest([selectionManagerService.selectionMoveEnd$,workbook$.pipe(rxjs.map(workbook=>{var _a58;return(_a58=workbook==null?void 0:workbook.getUnitId())!=null?_a58:""})),workbook$.pipe(rxjs.switchMap(workbook=>{var _a58;return(_a58=workbook==null?void 0:workbook.activeSheet$)!=null?_a58:rxjs.of(null)}))]).pipe(rxjs.map(([selection,unitId,sheet])=>{if(!sheet||!selection||selection.length===0)return!1;const subUnitId=sheet.getSheetId(),selectionRanges=selection.map(sel=>sel.range);if(mergeCellController.interceptor.fetchThroughInterceptors(sheets.MERGE_CELL_INTERCEPTOR_CHECK)(!1,selectionRanges))return!0;const subUnitRuleRange=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).map(rule=>rule.ranges).flat();if(selection.length<2){const range=selection[0].range;return subUnitRuleRange.some(ruleRange=>core.Rectangle.intersects(ruleRange,range)&&!core.Rectangle.contains(ruleRange,range))}for(let i=0;i<selection.length;i++)for(let j=i+1;j<selection.length;j++)if(core.Rectangle.intersects(selection[i].range,selection[j].range))return!0;return!1}))}__name(getSheetSelectionsDisabled$,"getSheetSelectionsDisabled$");function isThisRowSelected(selections,rowIndex){return!!matchedSelectionByRowColIndex(selections,rowIndex,core.RANGE_TYPE.ROW)}__name(isThisRowSelected,"isThisRowSelected");function isThisColSelected(selections,colIndex){return!!matchedSelectionByRowColIndex(selections,colIndex,core.RANGE_TYPE.COLUMN)}__name(isThisColSelected,"isThisColSelected");function matchedSelectionByRowColIndex(selections,indexOfRowCol,rowOrCol){return selections.find(sel=>{const range=sel.range,{startRow:startRowOfCurrSel,endRow:endRowOfCurrSel,startColumn:startColumnOfCurrSel,endColumn:endColumnOfCurrSel,rangeType:rangeTypeOfCurrSelection}=range;return rangeTypeOfCurrSelection===core.RANGE_TYPE.ALL||rangeTypeOfCurrSelection===core.RANGE_TYPE.NORMAL?!1:rangeTypeOfCurrSelection===rowOrCol&&(rowOrCol===core.RANGE_TYPE.COLUMN&&startColumnOfCurrSel<=indexOfRowCol&&indexOfRowCol<=endColumnOfCurrSel||rowOrCol===core.RANGE_TYPE.ROW&&startRowOfCurrSel<=indexOfRowCol&&indexOfRowCol<=endRowOfCurrSel)})}__name(matchedSelectionByRowColIndex,"matchedSelectionByRowColIndex");function CellMergeMenuItemFactory(accessor){const editDisabled$=getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),selectionsHasCross$=getSheetSelectionsDisabled$(accessor);return{id:AddWorksheetMergeCommand.id,icon:"MergeAllSingle",tooltip:"toolbar.mergeCell.main",type:ui.MenuItemType.SUBITEMS,hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:editDisabled$.pipe(rxjs.combineLatestWith(selectionsHasCross$),rxjs.map(([disable,hasCross])=>disable||hasCross))}}__name(CellMergeMenuItemFactory,"CellMergeMenuItemFactory");function CellMergeAllMenuItemFactory(accessor){return{id:AddWorksheetMergeAllCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.all",icon:"MergeAllSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeAllMenuItemFactory,"CellMergeAllMenuItemFactory");function CellMergeVerticalMenuItemFactory(accessor){return{id:AddWorksheetMergeVerticalCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.vertical",icon:"VerticalIntegrationSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeVerticalMenuItemFactory,"CellMergeVerticalMenuItemFactory");function CellMergeHorizontalMenuItemFactory(accessor){return{id:AddWorksheetMergeHorizontalCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.horizontal",icon:"HorizontalMergeSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeHorizontalMenuItemFactory,"CellMergeHorizontalMenuItemFactory");function CellMergeCancelMenuItemFactory(accessor){return{id:sheets.RemoveWorksheetMergeCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.cancel",icon:"CancelMergeSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeCancelMenuItemFactory,"CellMergeCancelMenuItemFactory");function getAddPermissionHidden$(accessor){const workbook$=accessor.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{if(!worksheet)return rxjs.of(!0);const rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,rangeProtectionRuleModel.ruleChange$,worksheetRuleModel.ruleChange$).pipe(rxjs.map(()=>{const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),subUnitRuleList=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId),selections=selectionManagerService.getCurrentSelections(),selectionsRanges=selections==null?void 0:selections.map(selection=>selection.range),ruleRanges=subUnitRuleList.map(rule=>rule.ranges).flat();if(!selectionsRanges)return!1;const worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId);return worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)?!0:selectionsRanges==null?void 0:selectionsRanges.some(selectionRange=>ruleRanges.some(ruleRange=>core.Rectangle.intersects(selectionRange,ruleRange)))}))})):rxjs.of(!0)))}__name(getAddPermissionHidden$,"getAddPermissionHidden$");function getEditPermissionHidden$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),rangeRuleModel=accessor.get(sheets.RangeProtectionRuleModel),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{if(!worksheet)return rxjs.of(!0);const rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,rangeProtectionRuleModel.ruleChange$,worksheetRuleModel.ruleChange$).pipe(rxjs.map(()=>{var _a58;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),subUnitRuleList=rangeRuleModel.getSubunitRuleList(unitId,subUnitId),selectionRanges=(_a58=selectionManagerService.getCurrentSelections())==null?void 0:_a58.map(selection=>selection.range),ruleRanges=subUnitRuleList.map(rule=>rule.ranges).flat();if(!(selectionRanges!=null&&selectionRanges.length)||selectionRanges.length>1)return!0;const selectedRange=selectionRanges[0],worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId);return worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)?!1:ruleRanges.filter(ruleRange=>core.Rectangle.intersects(ruleRange,selectedRange)).length!==1}))})):rxjs.of(!0)))}__name(getEditPermissionHidden$,"getEditPermissionHidden$");function getPermissionDisableBase$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),ruleChange$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$).pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,ruleChange$,selectionManagerService.selectionMoveEnd$]).pipe(rxjs.map(([permission,_2,__])=>{if(!permission)return!0;const selections=selectionManagerService.getCurrentSelections(),selectionRanges=selections==null?void 0:selections.map(selection=>selection.range);return selectionRanges!=null&&selectionRanges.length?selectionRanges.length>1:!1}))})):rxjs.of(!0)))}__name(getPermissionDisableBase$,"getPermissionDisableBase$");function getAddPermissionDisableBase$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const focusingDrawing$=accessor.get(core.IContextService).subscribeContextValue$(core.FOCUSING_COMMON_DRAWINGS).pipe(rxjs.startWith(!1)),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),ruleChange$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$).pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,ruleChange$,selectionManagerService.selectionMoveEnd$,focusingDrawing$]).pipe(rxjs.map(([permission,_2,__,focus])=>{if(!permission||focus)return!0;const selections=selectionManagerService.getCurrentSelections(),selectionRanges=selections==null?void 0:selections.map(selection=>selection.range);if(!(selectionRanges!=null&&selectionRanges.length))return!0;const worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);if(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name))return!0;const subunitRuleList=selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId);return selectionRanges==null?void 0:selectionRanges.some(selectionRange=>subunitRuleList.some(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(selectionRange,ruleRange))))}))})):rxjs.of(!0)))}__name(getAddPermissionDisableBase$,"getAddPermissionDisableBase$");function getAddPermissionFromSheetBarDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),ruleChange$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$).pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,ruleChange$]).pipe(rxjs.map(([permission,_2])=>{var _a59;if(!permission)return!0;const worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)?!0:((_a59=selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId))==null?void 0:_a59.filter(item=>(item==null?void 0:item.permissionId)&&(item==null?void 0:item.name))).length>0}))})):rxjs.of(!0)))}__name(getAddPermissionFromSheetBarDisable$,"getAddPermissionFromSheetBarDisable$");function getRemovePermissionFromSheetBarDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1);return rxjs.combineLatest([permission$,worksheetProtectionRuleModel.ruleChange$.pipe(rxjs.startWith(null))]).pipe(rxjs.map(([permission,_2])=>{if(!permission)return!0;const worksheetPermissionRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return!(worksheetPermissionRule!=null&&worksheetPermissionRule.permissionId&&(worksheetPermissionRule!=null&&worksheetPermissionRule.name))}))})):rxjs.of(!0)))}__name(getRemovePermissionFromSheetBarDisable$,"getRemovePermissionFromSheetBarDisable$");function getSetPermissionFromSheetBarDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),worksheetRuleChange$=worksheetProtectionRuleModel.ruleChange$.pipe(rxjs.startWith(null)),selectionRuleChange$=selectionProtectionRuleModel.ruleChange$.pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,worksheetRuleChange$,selectionRuleChange$]).pipe(rxjs.map(([permission,_2,__])=>{if(!permission)return!0;const subUnitId=worksheet.getSheetId(),worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId),selectionRuleList=selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId);return!(worksheetRule||selectionRuleList.length)}))})):rxjs.of(!0)))}__name(getSetPermissionFromSheetBarDisable$,"getSetPermissionFromSheetBarDisable$");function getRemovePermissionDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),sheetSelectionsService=accessor.get(sheets.SheetsSelectionsService),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),changes$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$,sheetSelectionsService.selectionMoveEnd$).pipe(rxjs.startWith(null));return rxjs.combineLatest([changes$,permission$]).pipe(rxjs.map(([_2,permission])=>{if(!permission)return!0;const selections=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections(),selectionRanges=selections==null?void 0:selections.map(selection=>selection.range);if(!(selectionRanges!=null&&selectionRanges.length)||selectionRanges.length>1)return!0;const selectionRange=selectionRanges[0],worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return!(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)||selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).map(rule=>rule.ranges).flat().some(ruleRange=>core.Rectangle.intersects(selectionRange,ruleRange)))}))})):rxjs.of(!0)))}__name(getRemovePermissionDisable$,"getRemovePermissionDisable$");function getViewPermissionDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58,_b;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId();return((_b=(_a58=permissionService.getPermissionPoint$(new sheets.WorkbookEditablePermission(unitId).id))==null?void 0:_a58.pipe(rxjs.map(e=>!!e.value)))!=null?_b:rxjs.of(!1)).pipe(rxjs.map(permission=>!permission))})):rxjs.of(!0)))}__name(getViewPermissionDisable$,"getViewPermissionDisable$");const SHEET_PERMISSION_CONTEXT_MENU_ID="sheet.contextMenu.permission";function sheetPermissionToolbarMenuFactory(accessor){return{id:AddRangeProtectionFromToolbarCommand.id,type:ui.MenuItemType.BUTTON,icon:permissionMenuIconKey,tooltip:"permission.toolbarMenu",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getAddPermissionDisableBase$(accessor)}}__name(sheetPermissionToolbarMenuFactory,"sheetPermissionToolbarMenuFactory");function sheetPermissionContextMenuFactory(accessor){return{id:SHEET_PERMISSION_CONTEXT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.protectRange",icon:permissionLockIconKey,hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionContextMenuFactory,"sheetPermissionContextMenuFactory");function sheetPermissionAddProtectContextMenuFactory(accessor){return{id:AddRangeProtectionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.turnOnProtectRange",hidden$:getAddPermissionHidden$(accessor),disabled$:getAddPermissionDisableBase$(accessor)}}__name(sheetPermissionAddProtectContextMenuFactory,"sheetPermissionAddProtectContextMenuFactory");function sheetPermissionEditProtectContextMenuFactory(accessor){return{id:SetRangeProtectionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.editProtectRange",hidden$:getEditPermissionHidden$(accessor),disabled$:getPermissionDisableBase$(accessor)}}__name(sheetPermissionEditProtectContextMenuFactory,"sheetPermissionEditProtectContextMenuFactory");function sheetPermissionRemoveProtectContextMenuFactory(accessor){return{id:DeleteRangeProtectionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.removeProtectRange",disabled$:getRemovePermissionDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionRemoveProtectContextMenuFactory,"sheetPermissionRemoveProtectContextMenuFactory");function sheetPermissionViewAllProtectRuleContextMenuFactory(accessor){return{id:ViewSheetPermissionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.viewAllProtectArea",disabled$:getViewPermissionDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionViewAllProtectRuleContextMenuFactory,"sheetPermissionViewAllProtectRuleContextMenuFactory");function sheetPermissionProtectSheetInSheetBarMenuFactory(accessor){return{id:AddRangeProtectionFromSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.addProtectSheet",disabled$:getAddPermissionFromSheetBarDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionProtectSheetInSheetBarMenuFactory,"sheetPermissionProtectSheetInSheetBarMenuFactory");function sheetPermissionRemoveProtectionSheetBarMenuFactory(accessor){return{id:DeleteWorksheetProtectionFormSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.removeProtectSheet",disabled$:getRemovePermissionFromSheetBarDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionRemoveProtectionSheetBarMenuFactory,"sheetPermissionRemoveProtectionSheetBarMenuFactory");function sheetPermissionChangeSheetPermissionSheetBarMenuFactory(accessor){return{id:ChangeSheetProtectionFromSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.changeSheetPermission",disabled$:getSetPermissionFromSheetBarDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionChangeSheetPermissionSheetBarMenuFactory,"sheetPermissionChangeSheetPermissionSheetBarMenuFactory");function sheetPermissionViewAllProtectRuleSheetBarMenuFactory(accessor){return{id:ViewSheetPermissionFromSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.viewAllProtectArea",disabled$:getViewPermissionDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionViewAllProtectRuleSheetBarMenuFactory,"sheetPermissionViewAllProtectRuleSheetBarMenuFactory");function DeleteSheetMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),defaultDisable$=new rxjs.Observable(subscriber=>{const disposable=commandService.onCommandExecuted(c=>{const id=c.id;(id===sheets.RemoveSheetMutation.id||id===sheets.InsertSheetMutation.id||id===sheets.SetWorksheetHideMutation.id)&&disableFunction(univerInstanceService,subscriber)});return disableFunction(univerInstanceService,subscriber),disposable.dispose}),permissionDisable$=getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookDeleteSheetPermission]);return{id:RemoveSheetConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.delete",disabled$:rxjs.combineLatest([defaultDisable$,permissionDisable$]).pipe(rxjs.map(([defaultDisabled,permissionDisabled])=>defaultDisabled||permissionDisabled)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(DeleteSheetMenuItemFactory,"DeleteSheetMenuItemFactory");function CopySheetMenuItemFactory(accessor){return{id:sheets.CopySheetCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.copy",disabled$:getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookCreateSheetPermission]),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CopySheetMenuItemFactory,"CopySheetMenuItemFactory");function RenameSheetMenuItemFactory(accessor){return{id:RenameSheetOperation.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.rename",disabled$:getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookRenameSheetPermission]),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(RenameSheetMenuItemFactory,"RenameSheetMenuItemFactory");function ChangeColorSheetMenuItemFactory(accessor){return{id:sheets.SetTabColorCommand.id,title:"sheetConfig.changeColor",type:ui.MenuItemType.SELECTOR,selections:[{label:{name:COLOR_PICKER_COMPONENT,hoverable:!1}}],hidden$:getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission])}}__name(ChangeColorSheetMenuItemFactory,"ChangeColorSheetMenuItemFactory");function HideSheetMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService);return{id:sheets.SetWorksheetHideCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.hide",disabled$:new rxjs.Observable(subscriber=>{const disposable=commandService.onCommandExecuted(c=>{const id=c.id;(id===sheets.RemoveSheetMutation.id||id===sheets.InsertSheetMutation.id||id===sheets.SetWorksheetHideMutation.id)&&disableFunction(univerInstanceService,subscriber)});return disableFunction(univerInstanceService,subscriber),disposable.dispose}).pipe(rxjs.combineLatestWith(getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookHideSheetPermission])),rxjs.map(([defaultDisabled,permissionDisabled])=>defaultDisabled||permissionDisabled)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(HideSheetMenuItemFactory,"HideSheetMenuItemFactory");function ShowMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService);return{id:ShowMenuListCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.unhide",disabled$:new rxjs.Observable(subscriber=>{function disableFunction2(){const worksheets=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getWorksheets(),visibleSheets=Array.from(worksheets.values());subscriber.next(visibleSheets.length===1)}__name(disableFunction2,"disableFunction2");const disposable=commandService.onCommandExecuted(c=>{const id=c.id;(id===sheets.RemoveSheetMutation.id||id===sheets.InsertSheetMutation.id||id===sheets.SetWorksheetHideMutation.id)&&disableFunction2()});return disableFunction2(),disposable.dispose}).pipe(rxjs.combineLatestWith(getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookHideSheetPermission])),rxjs.map(([defaultDisabled,permissionDisabled])=>defaultDisabled||permissionDisabled)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ShowMenuItemFactory,"ShowMenuItemFactory");function disableFunction(univerInstanceService,subscriber){const worksheets=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getWorksheets(),visibleSheets=Array.from(worksheets.values()).filter(sheet=>sheet.getConfig().hidden===core.BooleanNumber.FALSE);subscriber.next(visibleSheets.length===1)}__name(disableFunction,"disableFunction");const menuSchema$1={[ui.RibbonStartGroup.FORMAT]:{[SetOnceFormatPainterCommand.id]:{order:0,menuItemFactory:FormatPainterMenuItemFactory},[SetRangeBoldCommand.id]:{order:1,menuItemFactory:BoldMenuItemFactory},[SetRangeItalicCommand.id]:{order:2,menuItemFactory:ItalicMenuItemFactory},[SetRangeUnderlineCommand.id]:{order:3,menuItemFactory:UnderlineMenuItemFactory},[SetRangeStrickThroughCommand.id]:{order:4,menuItemFactory:StrikeThroughMenuItemFactory},[SetRangeFontFamilyCommand.id]:{order:5,menuItemFactory:FontFamilySelectorMenuItemFactory},[SetRangeFontSizeCommand.id]:{order:6,menuItemFactory:FontSizeSelectorMenuItemFactory},[SetRangeTextColorCommand.id]:{order:7,menuItemFactory:TextColorSelectorMenuItemFactory,[sheets.ResetTextColorCommand.id]:{order:0,menuItemFactory:ResetTextColorMenuItemFactory}},[sheets.SetBackgroundColorCommand.id]:{order:9,menuItemFactory:BackgroundColorSelectorMenuItemFactory,[sheets.ResetBackgroundColorCommand.id]:{order:0,menuItemFactory:ResetBackgroundColorMenuItemFactory}},[sheets.SetBorderBasicCommand.id]:{order:10,menuItemFactory:CellBorderSelectorMenuItemFactory}},[ui.RibbonStartGroup.LAYOUT]:{[sheets.AddWorksheetMergeCommand.id]:{order:0,menuItemFactory:CellMergeMenuItemFactory,[sheets.AddWorksheetMergeAllCommand.id]:{order:0,menuItemFactory:CellMergeAllMenuItemFactory},[sheets.AddWorksheetMergeVerticalCommand.id]:{order:1,menuItemFactory:CellMergeVerticalMenuItemFactory},[sheets.AddWorksheetMergeHorizontalCommand.id]:{order:2,menuItemFactory:CellMergeHorizontalMenuItemFactory},[sheets.RemoveWorksheetMergeCommand.id]:{order:3,menuItemFactory:CellMergeCancelMenuItemFactory}},[sheets.SetHorizontalTextAlignCommand.id]:{order:1,menuItemFactory:HorizontalAlignMenuItemFactory},[sheets.SetVerticalTextAlignCommand.id]:{order:1,menuItemFactory:VerticalAlignMenuItemFactory},[sheets.SetTextWrapCommand.id]:{order:2,menuItemFactory:WrapTextMenuItemFactory},[sheets.SetTextRotationCommand.id]:{order:3,menuItemFactory:TextRotateMenuItemFactory}},[ui.RibbonStartGroup.OTHERS]:{[AddRangeProtectionFromToolbarCommand.id]:{order:0,menuItemFactory:sheetPermissionToolbarMenuFactory}},[ui.ContextMenuPosition.MAIN_AREA]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory},[SheetPasteCommand.name]:{order:2,menuItemFactory:PasteMenuItemFactory},[PASTE_SPECIAL_MENU_ID]:{order:3,menuItemFactory:PasteSpacialMenuItemFactory,[SheetPasteValueCommand.id]:{order:0,menuItemFactory:PasteValueMenuItemFactory},[SheetPasteFormatCommand.id]:{order:1,menuItemFactory:PasteFormatMenuItemFactory},[SheetPasteColWidthCommand.id]:{order:2,menuItemFactory:PasteColWidthMenuItemFactory},[SheetPasteBesidesBorderCommand.id]:{order:3,menuItemFactory:PasteBesidesBorderMenuItemFactory}},[CLEAR_SELECTION_MENU_ID]:{order:4,menuItemFactory:ClearSelectionMenuItemFactory,[sheets.ClearSelectionContentCommand.id]:{order:0,menuItemFactory:ClearSelectionContentMenuItemFactory},[sheets.ClearSelectionFormatCommand.id]:{order:1,menuItemFactory:ClearSelectionFormatMenuItemFactory},[sheets.ClearSelectionAllCommand.id]:{order:2,menuItemFactory:ClearSelectionAllMenuItemFactory}}},[ui.ContextMenuGroup.LAYOUT]:{order:1,[CELL_INSERT_MENU_ID]:{order:0,menuItemFactory:CellInsertMenuItemFactory,[sheets.InsertRowBeforeCommand.id]:{order:0,menuItemFactory:InsertRowBeforeMenuItemFactory},[sheets.InsertColBeforeCommand.id]:{order:1,menuItemFactory:InsertColBeforeMenuItemFactory},[InsertRangeMoveRightConfirmCommand.id]:{order:2,menuItemFactory:InsertRangeMoveRightMenuItemFactory},[InsertRangeMoveDownConfirmCommand.id]:{order:3,menuItemFactory:InsertRangeMoveDownMenuItemFactory}},[DELETE_RANGE_MENU_ID]:{order:0,menuItemFactory:DeleteRangeMenuItemFactory,[RemoveColConfirmCommand.id]:{order:0,menuItemFactory:RemoveColMenuItemFactory},[RemoveRowConfirmCommand.id]:{order:1,menuItemFactory:RemoveRowMenuItemFactory},[DeleteRangeMoveLeftConfirmCommand.id]:{order:2,menuItemFactory:DeleteRangeMoveLeftMenuItemFactory},[DeleteRangeMoveUpConfirmCommand.id]:{order:3,menuItemFactory:DeleteRangeMoveUpMenuItemFactory}},[SHEET_FROZEN_MENU_ID]:{order:2,menuItemFactory:SheetFrozenMenuItemFactory,[SetSelectionFrozenCommand.id]:{order:0,menuItemFactory:FrozenMenuItemFactory},[SetRowFrozenCommand.id]:{order:1,menuItemFactory:FrozenRowMenuItemFactory},[SetColumnFrozenCommand.id]:{order:2,menuItemFactory:FrozenColMenuItemFactory},[CancelFrozenCommand.id]:{order:3,menuItemFactory:CancelFrozenMenuItemFactory}},[SHEET_PERMISSION_CONTEXT_MENU_ID]:{order:3,menuItemFactory:sheetPermissionContextMenuFactory,[AddRangeProtectionFromContextMenuCommand.id]:{order:0,menuItemFactory:sheetPermissionAddProtectContextMenuFactory},[SetRangeProtectionFromContextMenuCommand.id]:{order:1,menuItemFactory:sheetPermissionEditProtectContextMenuFactory},[DeleteRangeProtectionFromContextMenuCommand.id]:{order:2,menuItemFactory:sheetPermissionRemoveProtectContextMenuFactory},[ViewSheetPermissionFromContextMenuCommand.id]:{order:3,menuItemFactory:sheetPermissionViewAllProtectRuleContextMenuFactory}}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.COL_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory},[SheetPasteCommand.name]:{order:2,menuItemFactory:PasteMenuItemFactory},[PASTE_SPECIAL_MENU_ID]:{order:3,menuItemFactory:PasteSpacialMenuItemFactory,[SheetPasteValueCommand.id]:{order:0,menuItemFactory:PasteValueMenuItemFactory},[SheetPasteFormatCommand.id]:{order:1,menuItemFactory:PasteFormatMenuItemFactory},[SheetPasteColWidthCommand.id]:{order:2,menuItemFactory:PasteColWidthMenuItemFactory},[SheetPasteBesidesBorderCommand.id]:{order:3,menuItemFactory:PasteBesidesBorderMenuItemFactory}},[CLEAR_SELECTION_MENU_ID]:{order:4,menuItemFactory:ClearSelectionMenuItemFactory,[sheets.ClearSelectionContentCommand.id]:{order:0,menuItemFactory:ClearSelectionContentMenuItemFactory},[sheets.ClearSelectionFormatCommand.id]:{order:1,menuItemFactory:ClearSelectionFormatMenuItemFactory},[sheets.ClearSelectionAllCommand.id]:{order:2,menuItemFactory:ClearSelectionAllMenuItemFactory}}},[ui.ContextMenuGroup.LAYOUT]:{order:1,[COL_INSERT_MENU_ID]:{order:0,menuItemFactory:ColInsertMenuItemFactory,[sheets.InsertColBeforeCommand.id]:{order:0,menuItemFactory:InsertColBeforeMenuItemFactory},[sheets.InsertColAfterCommand.id]:{order:1,menuItemFactory:InsertColAfterMenuItemFactory}},[HideColConfirmCommand.id]:{order:1,menuItemFactory:HideColMenuItemFactory},[sheets.SetSelectedColsVisibleCommand.id]:{order:2,menuItemFactory:ShowColMenuItemFactory},[RemoveColConfirmCommand.id]:{order:2,menuItemFactory:RemoveColMenuItemFactory},[sheets.SetColWidthCommand.id]:{order:3,menuItemFactory:SetColWidthMenuItemFactory},[SHEET_FROZEN_HEADER_MENU_ID]:{order:4,menuItemFactory:SheetFrozenHeaderMenuItemFactory,[SetSelectionFrozenCommand.id]:{order:0,menuItemFactory:FrozenMenuItemFactory},[CancelFrozenCommand.id]:{order:3,menuItemFactory:CancelFrozenMenuItemFactory}},[SHEET_PERMISSION_CONTEXT_MENU_ID]:{order:5,menuItemFactory:sheetPermissionContextMenuFactory,[AddRangeProtectionFromContextMenuCommand.id]:{order:0,menuItemFactory:sheetPermissionAddProtectContextMenuFactory},[SetRangeProtectionFromContextMenuCommand.id]:{order:1,menuItemFactory:sheetPermissionEditProtectContextMenuFactory},[DeleteRangeProtectionFromContextMenuCommand.id]:{order:2,menuItemFactory:sheetPermissionRemoveProtectContextMenuFactory},[ViewSheetPermissionFromContextMenuCommand.id]:{order:3,menuItemFactory:sheetPermissionViewAllProtectRuleContextMenuFactory}}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.ROW_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory},[SheetPasteCommand.name]:{order:2,menuItemFactory:PasteMenuItemFactory},[PASTE_SPECIAL_MENU_ID]:{order:3,menuItemFactory:PasteSpacialMenuItemFactory,[SheetPasteValueCommand.id]:{order:0,menuItemFactory:PasteValueMenuItemFactory},[SheetPasteFormatCommand.id]:{order:1,menuItemFactory:PasteFormatMenuItemFactory},[SheetPasteColWidthCommand.id]:{order:2,menuItemFactory:PasteColWidthMenuItemFactory},[SheetPasteBesidesBorderCommand.id]:{order:3,menuItemFactory:PasteBesidesBorderMenuItemFactory}},[CLEAR_SELECTION_MENU_ID]:{order:4,menuItemFactory:ClearSelectionMenuItemFactory,[sheets.ClearSelectionContentCommand.id]:{order:0,menuItemFactory:ClearSelectionContentMenuItemFactory},[sheets.ClearSelectionFormatCommand.id]:{order:1,menuItemFactory:ClearSelectionFormatMenuItemFactory},[sheets.ClearSelectionAllCommand.id]:{order:2,menuItemFactory:ClearSelectionAllMenuItemFactory}}},[ui.ContextMenuGroup.LAYOUT]:{order:1,[ROW_INSERT_MENU_ID]:{order:0,menuItemFactory:RowInsertMenuItemFactory,[sheets.InsertRowBeforeCommand.id]:{order:0,menuItemFactory:InsertRowBeforeMenuItemFactory},[sheets.InsertRowAfterCommand.id]:{order:1,menuItemFactory:InsertRowAfterMenuItemFactory}},[RemoveRowConfirmCommand.id]:{order:1,menuItemFactory:RemoveRowMenuItemFactory},[HideRowConfirmCommand.id]:{order:2,menuItemFactory:HideRowMenuItemFactory},[sheets.SetSelectedRowsVisibleCommand.id]:{order:2,menuItemFactory:ShowRowMenuItemFactory},[sheets.SetRowHeightCommand.id]:{order:3,menuItemFactory:SetRowHeightMenuItemFactory},[sheets.SetWorksheetRowIsAutoHeightCommand.id]:{order:4,menuItemFactory:FitContentMenuItemFactory},[SHEET_FROZEN_HEADER_MENU_ID]:{order:5,menuItemFactory:SheetFrozenHeaderMenuItemFactory,[SetSelectionFrozenCommand.id]:{order:0,menuItemFactory:FrozenMenuItemFactory},[CancelFrozenCommand.id]:{order:3,menuItemFactory:CancelFrozenMenuItemFactory}},[SHEET_PERMISSION_CONTEXT_MENU_ID]:{order:6,menuItemFactory:sheetPermissionContextMenuFactory,[AddRangeProtectionFromContextMenuCommand.id]:{order:0,menuItemFactory:sheetPermissionAddProtectContextMenuFactory},[SetRangeProtectionFromContextMenuCommand.id]:{order:1,menuItemFactory:sheetPermissionEditProtectContextMenuFactory},[DeleteRangeProtectionFromContextMenuCommand.id]:{order:2,menuItemFactory:sheetPermissionRemoveProtectContextMenuFactory},[ViewSheetPermissionFromContextMenuCommand.id]:{order:3,menuItemFactory:sheetPermissionViewAllProtectRuleContextMenuFactory}}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.FOOTER_TABS]:{[ui.ContextMenuGroup.OTHERS]:{order:0,[RemoveSheetConfirmCommand.id]:{order:0,menuItemFactory:DeleteSheetMenuItemFactory},[sheets.CopySheetCommand.id]:{order:1,menuItemFactory:CopySheetMenuItemFactory},[RenameSheetOperation.id]:{order:2,menuItemFactory:RenameSheetMenuItemFactory},[sheets.SetTabColorCommand.id]:{order:3,menuItemFactory:ChangeColorSheetMenuItemFactory},[sheets.SetWorksheetHideCommand.id]:{order:4,menuItemFactory:HideSheetMenuItemFactory},[ShowMenuListCommand.id]:{order:6,menuItemFactory:ShowMenuItemFactory},[AddRangeProtectionFromSheetBarCommand.id]:{order:7,menuItemFactory:sheetPermissionProtectSheetInSheetBarMenuFactory},[DeleteWorksheetProtectionFormSheetBarCommand.id]:{order:8,menuItemFactory:sheetPermissionRemoveProtectionSheetBarMenuFactory},[ChangeSheetProtectionFromSheetBarCommand.id]:{order:9,menuItemFactory:sheetPermissionChangeSheetPermissionSheetBarMenuFactory},[ViewSheetPermissionFromSheetBarCommand.id]:{order:10,menuItemFactory:sheetPermissionViewAllProtectRuleSheetBarMenuFactory}}}},ARROW_SELECTION_KEYCODE_LIST=[ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP,ui.KeyCode.ARROW_LEFT,ui.KeyCode.ARROW_RIGHT],MOVE_SELECTION_KEYCODE_LIST=[ui.KeyCode.ENTER,ui.KeyCode.TAB,...ARROW_SELECTION_KEYCODE_LIST];function generateArrowSelectionShortCutItem(){const shortcutList=[];for(const keycode of ARROW_SELECTION_KEYCODE_LIST)shortcutList.push({id:SetCellEditVisibleArrowOperation.id,binding:keycode,preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,isShift:!1}}),shortcutList.push({id:SetCellEditVisibleArrowOperation.id,binding:keycode|ui.MetaKeys.SHIFT,preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,isShift:!0}});return shortcutList}__name(generateArrowSelectionShortCutItem,"generateArrowSelectionShortCutItem");const StartEditWithF2Shortcut={id:SetCellEditVisibleWithF2Operation.id,binding:ui.KeyCode.F2,description:"shortcut.sheet.start-editing",group:"4_sheet-edit",preconditions:whenSheetEditorFocused,staticParameters:{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.F2}},EditorCursorEnterShortcut={id:SetCellEditVisibleOperation.id,binding:ui.KeyCode.ENTER,description:"shortcut.sheet.toggle-editing",group:"4_sheet-edit",preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.ENTER}},EditorCursorTabShortcut={id:SetCellEditVisibleOperation.id,binding:ui.KeyCode.TAB,preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.TAB}},EditorCursorEscShortcut={id:SetCellEditVisibleOperation.id,binding:ui.KeyCode.ESC,description:"shortcut.sheet.abort-editing",group:"4_sheet-edit",preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.ESC}},EditorBreakLineShortcut={id:docsUi.BreakLineCommand.id,description:"shortcut.sheet.break-line",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorActivated(contextService),"preconditions"),binding:ui.KeyCode.ENTER|ui.MetaKeys.ALT},EditorDeleteLeftShortcut={id:docsUi.DeleteLeftCommand.id,preconditions:__name(contextService=>whenEditorActivated(contextService)||whenFormulaEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.BACKSPACE},EditorDeleteLeftShortcutInActive={id:SetCellEditVisibleOperation.id,description:"shortcut.sheet.delete-and-start-editing",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService)&&!whenFormulaEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.BACKSPACE,staticParameters:{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.BACKSPACE}},SetRowHiddenShortcutItem={id:sheets.SetRowHiddenCommand.id,preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.Digit9|ui.MetaKeys.CTRL_COMMAND},SetColHiddenShortcutItem={id:sheets.SetColHiddenCommand.id,preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.Digit0|ui.MetaKeys.CTRL_COMMAND|ui.MetaKeys.SHIFT},MoveSelectionDownShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-below-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN}},MoveSelectionUpShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-up-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP}},MoveSelectionLeftShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-left-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT,priority:100,preconditions:whenSheetEditorFocusedAndFxNotFocused,staticParameters:{direction:core.Direction.LEFT}},MoveSelectionRightShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-right-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT,priority:100,preconditions:whenSheetEditorFocusedAndFxNotFocused,staticParameters:{direction:core.Direction.RIGHT}},MoveSelectionTabShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-next-cell",group:"3_sheet-view",binding:ui.KeyCode.TAB,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT,keycode:ui.KeyCode.TAB}},MoveSelectionTabLeftShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-previous-cell",group:"3_sheet-view",binding:ui.KeyCode.TAB|ui.MetaKeys.SHIFT,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT,keycode:ui.KeyCode.TAB}},MoveSelectionEnterShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-below-cell",group:"3_sheet-view",binding:ui.KeyCode.ENTER,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN,keycode:ui.KeyCode.ENTER}},MoveSelectionEnterUpShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-up-cell",group:"3_sheet-view",binding:ui.KeyCode.ENTER|ui.MetaKeys.SHIFT,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP,keycode:ui.KeyCode.ENTER}},MoveSelectionEndDownShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-below-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN,jumpOver:JumpOver.moveGap}},MoveSelectionEndUpShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-up-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP,jumpOver:JumpOver.moveGap}},MoveSelectionEndLeftShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-left-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT,jumpOver:JumpOver.moveGap}},MoveSelectionEndRightShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-right-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT,jumpOver:JumpOver.moveGap}},ExpandSelectionDownShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-down",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN}},ExpandSelectionUpShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-up",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP}},ExpandSelectionLeftShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-left",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT}},ExpandSelectionRightShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-right",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT}},ExpandSelectionEndDownShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-below-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN,jumpOver:JumpOver.moveGap}},ExpandSelectionEndUpShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-up-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP,jumpOver:JumpOver.moveGap}},ExpandSelectionEndLeftShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-left-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT,jumpOver:JumpOver.moveGap}},ExpandSelectionEndRightShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-right-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT,jumpOver:JumpOver.moveGap}},SelectAllShortcutItem={id:SelectAllCommand.id,description:"shortcut.sheet.select-all",group:"3_sheet-view",binding:ui.KeyCode.A|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{expandToGapFirst:!0,loop:!0}},SetBoldShortcutItem={id:SetRangeBoldCommand.id,description:"shortcut.sheet.set-bold",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.B|ui.MetaKeys.CTRL_COMMAND},SetItalicShortcutItem={id:SetRangeItalicCommand.id,description:"shortcut.sheet.set-italic",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.I|ui.MetaKeys.CTRL_COMMAND},SetUnderlineShortcutItem={id:SetRangeUnderlineCommand.id,description:"shortcut.sheet.set-underline",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.U|ui.MetaKeys.CTRL_COMMAND},SetStrikeThroughShortcutItem={id:SetRangeStrickThroughCommand.id,description:"shortcut.sheet.set-strike-through",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.X|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND},ClearSelectionValueShortcutItem={id:sheets.ClearSelectionContentCommand.id,preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.DELETE,mac:ui.KeyCode.BACKSPACE},ZoomInShortcutItem={id:ChangeZoomRatioCommand.id,description:"shortcut.sheet.zoom-in",binding:ui.KeyCode.EQUAL|ui.MetaKeys.CTRL_COMMAND,group:"3_sheet-view",preconditions:whenSheetEditorFocused,priority:1,staticParameters:{delta:.2}},PreventDefaultZoomInShortcutItem={id:core.NilCommand.id,binding:ui.KeyCode.EQUAL|ui.MetaKeys.CTRL_COMMAND},ZoomOutShortcutItem={id:ChangeZoomRatioCommand.id,description:"shortcut.sheet.zoom-out",binding:ui.KeyCode.MINUS|ui.MetaKeys.CTRL_COMMAND,group:"3_sheet-view",preconditions:whenSheetEditorFocused,priority:1,staticParameters:{delta:-.2}},PreventDefaultZoomOutShortcutItem={id:core.NilCommand.id,binding:ui.KeyCode.MINUS|ui.MetaKeys.CTRL_COMMAND},ResetZoomShortcutItem={id:ChangeZoomRatioCommand.id,description:"shortcut.sheet.reset-zoom",binding:ui.KeyCode.Digit0|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,group:"3_sheet-view",priority:1,staticParameters:{reset:!0}},PreventDefaultResetZoomShortcutItem={id:core.NilCommand.id,binding:ui.KeyCode.Digit0|ui.MetaKeys.CTRL_COMMAND};var __defProp$E=Object.defineProperty,__getOwnPropDesc$E=Object.getOwnPropertyDescriptor,__decorateClass$E=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$E(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$E(target,key,result),result},"__decorateClass$E"),__decorateParam$E=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$E"),_a15;exports.SheetUIController=(_a15=class extends core.Disposable{constructor(_injector,_componentManager,_layoutService,_commandService,_shortcutService,_menuManagerService,_uiPartsService,_configService){super(),this._injector=_injector,this._componentManager=_componentManager,this._layoutService=_layoutService,this._commandService=_commandService,this._shortcutService=_shortcutService,this._menuManagerService=_menuManagerService,this._uiPartsService=_uiPartsService,this._configService=_configService,this._init()}_init(){this._initCustomComponents(),this._initCommands(),this._initMenus(),this._initShortcuts(),this._initWorkbenchParts(),this._initFocusHandler()}_initCustomComponents(){const componentManager=this._componentManager;this.disposeWithMe(componentManager.register(MENU_ITEM_INPUT_COMPONENT,MenuItemInput)),this.disposeWithMe(componentManager.register(BORDER_PANEL_COMPONENT,BorderPanel)),this.disposeWithMe(componentManager.register(COLOR_PICKER_COMPONENT,design.ColorPicker)),this.disposeWithMe(componentManager.register(FONT_FAMILY_COMPONENT,ui.FontFamily)),this.disposeWithMe(componentManager.register(FONT_FAMILY_ITEM_COMPONENT,ui.FontFamilyItem)),this.disposeWithMe(componentManager.register(FONT_SIZE_COMPONENT,ui.FontSize)),this.disposeWithMe(componentManager.register(DEFINED_NAME_CONTAINER,DefinedNameContainer))}_initCommands(){[AddWorksheetMergeAllCommand,AddWorksheetMergeCommand,AddWorksheetMergeHorizontalCommand,AddWorksheetMergeVerticalCommand,ChangeZoomRatioCommand,ExpandSelectionCommand,MoveSelectionCommand,MoveSelectionEnterAndTabCommand,RenameSheetOperation,RemoveSheetConfirmCommand,RemoveRowConfirmCommand,RemoveColConfirmCommand,HideRowConfirmCommand,HideColConfirmCommand,ScrollCommand,ScrollToCellCommand,SelectAllCommand,SetActivateCellEditOperation,sheets.SetBoldCommand,SetCellEditVisibleArrowOperation,SetCellEditVisibleOperation,SetCellEditVisibleWithF2Operation,SetRangeBoldCommand,SetRangeItalicCommand,SetRangeUnderlineCommand,SetRangeStrickThroughCommand,SetRangeSubscriptCommand,SetRangeSuperscriptCommand,SetRangeFontSizeCommand,SetRangeFontFamilyCommand,SetRangeTextColorCommand,sheets.SetItalicCommand,sheets.SetStrikeThroughCommand,sheets.SetFontFamilyCommand,sheets.SetFontSizeCommand,SetFormatPainterOperation,SetInfiniteFormatPainterCommand,SetOnceFormatPainterCommand,ApplyFormatPainterCommand,SetScrollOperation,SetScrollRelativeCommand,SetSelectionFrozenCommand,SetRowFrozenCommand,SetColumnFrozenCommand,ScrollToRangeOperation,CancelFrozenCommand,sheets.SetUnderlineCommand,SetZoomRatioCommand,SetZoomRatioOperation,ShowMenuListCommand,RefillCommand,InsertRangeMoveDownConfirmCommand,DeleteRangeMoveUpConfirmCommand,InsertRangeMoveRightConfirmCommand,DeleteRangeMoveLeftConfirmCommand,SidebarDefinedNameOperation,AutoFillCommand,AutoClearContentCommand,SheetPermissionOpenPanelOperation,SheetPermissionOpenDialogOperation,AddRangeProtectionFromToolbarCommand,AddRangeProtectionFromContextMenuCommand,ViewSheetPermissionFromContextMenuCommand,AddRangeProtectionFromSheetBarCommand,ViewSheetPermissionFromSheetBarCommand,ChangeSheetProtectionFromSheetBarCommand,DeleteRangeProtectionFromContextMenuCommand,SetRangeProtectionFromContextMenuCommand,AddWorksheetProtectionCommand,DeleteWorksheetProtectionCommand,SetWorksheetProtectionCommand,DeleteWorksheetProtectionFormSheetBarCommand,SetProtectionCommand].forEach(c=>{this.disposeWithMe(this._commandService.registerCommand(c))})}_initMenus(){this._menuManagerService.mergeMenu(menuSchema$1)}_initShortcuts(){[MoveSelectionDownShortcutItem,MoveSelectionUpShortcutItem,MoveSelectionLeftShortcutItem,MoveSelectionRightShortcutItem,MoveSelectionTabShortcutItem,MoveSelectionTabLeftShortcutItem,MoveSelectionEnterShortcutItem,MoveSelectionEnterUpShortcutItem,MoveSelectionEndDownShortcutItem,MoveSelectionEndUpShortcutItem,MoveSelectionEndLeftShortcutItem,MoveSelectionEndRightShortcutItem,ExpandSelectionDownShortcutItem,ExpandSelectionUpShortcutItem,ExpandSelectionLeftShortcutItem,ExpandSelectionRightShortcutItem,ExpandSelectionEndDownShortcutItem,ExpandSelectionEndUpShortcutItem,ExpandSelectionEndLeftShortcutItem,ExpandSelectionEndRightShortcutItem,SelectAllShortcutItem,ZoomInShortcutItem,ZoomOutShortcutItem,ResetZoomShortcutItem,PreventDefaultResetZoomShortcutItem,PreventDefaultZoomInShortcutItem,PreventDefaultZoomOutShortcutItem,SetBoldShortcutItem,SetItalicShortcutItem,SetUnderlineShortcutItem,SetStrikeThroughShortcutItem,ClearSelectionValueShortcutItem,...generateArrowSelectionShortCutItem(),EditorCursorEnterShortcut,StartEditWithF2Shortcut,EditorCursorTabShortcut,EditorBreakLineShortcut,EditorDeleteLeftShortcut,EditorDeleteLeftShortcutInActive,EditorCursorEscShortcut,SetRowHiddenShortcutItem,SetColHiddenShortcutItem].forEach(item=>{this.disposeWithMe(this._shortcutService.registerShortcut(item))})}_initWorkbenchParts(){const uiController=this._uiPartsService,injector=this._injector,config=this._configService.getConfig(PLUGIN_CONFIG_KEY);(config==null?void 0:config.formulaBar)!==!1&&this.disposeWithMe(uiController.registerComponent(ui.BuiltInUIPart.HEADER,()=>core.connectInjector(RenderSheetHeader,injector))),this.disposeWithMe(uiController.registerComponent(ui.BuiltInUIPart.FOOTER,()=>core.connectInjector(RenderSheetFooter,injector))),this.disposeWithMe(uiController.registerComponent(ui.BuiltInUIPart.CONTENT,()=>core.connectInjector(RenderSheetContent,injector)))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(core.UniverInstanceType.UNIVER_SHEET,_unitId=>{const currentEditorRender=this._injector.get(engineRender.IRenderManagerService).getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC),docSelectionRenderService=currentEditorRender==null?void 0:currentEditorRender.with(docsUi.DocSelectionRenderService);docSelectionRenderService==null||docSelectionRenderService.focus()}))}},__name(_a15,"SheetUIController"),_a15);exports.SheetUIController=__decorateClass$E([__decorateParam$E(0,core.Inject(core.Injector)),__decorateParam$E(1,core.Inject(ui.ComponentManager)),__decorateParam$E(2,ui.ILayoutService),__decorateParam$E(3,core.ICommandService),__decorateParam$E(4,ui.IShortcutService),__decorateParam$E(5,ui.IMenuManagerService),__decorateParam$E(6,ui.IUIPartsService),__decorateParam$E(7,core.IConfigService)],exports.SheetUIController);function isForceString(str){return str.startsWith("'")}__name(isForceString,"isForceString");function extractStringFromForceString(str){return str.slice(1)}__name(extractStringFromForceString,"extractStringFromForceString");const fullWidthToHalfWidthMap={"0":"0","1":"1","2":"2","3":"3","4":"4","5":"5","6":"6","7":"7","8":"8","9":"9",A:"A",B:"B",C:"C",D:"D",E:"E",F:"F",G:"G",H:"H",I:"I",J:"J",K:"K",L:"L",M:"M",N:"N",O:"O",P:"P",Q:"Q",R:"R",S:"S",T:"T",U:"U",V:"V",W:"W",X:"X",Y:"Y",Z:"Z",a:"a",b:"b",c:"c",d:"d",e:"e",f:"f",g:"g",h:"h",i:"i",j:"j",k:"k",l:"l",m:"m",n:"n",o:"o",p:"p",q:"q",r:"r",s:"s",t:"t",u:"u",v:"v",w:"w",x:"x",y:"y",z:"z","%":"%","-":"-",".":".",":":":","/":"/","+":"+","@":"@","&":"&","*":"*","#":"#","=":"=",">":">","<":"<","$":"$",""":'"',"'":"'","(":"(",")":")"," ":" ",",":",","!":"!","?":"?",";":";","[":"[","]":"]","{":"{","}":"}"},booleanMap={true:"TRUE",false:"FALSE"};function isCJKLocale(locale){return[core.LocaleType.ZH_CN,core.LocaleType.ZH_TW].includes(locale)}__name(isCJKLocale,"isCJKLocale");function normalizeString(str,lexerTreeBuilder,currentLocale,functionService){let normalStr=str;if(isCJKLocale(currentLocale)){if(str.startsWith("'")||str.startsWith("'"))return`'${str.slice(1)}`;normalStr=str.split("").map(toHalfWidth).join("")}if(normalStr.startsWith("="))return normalizeFormulaString(str,normalStr,lexerTreeBuilder,functionService);const lowerCaseStr=normalStr.toLowerCase();return booleanMap[lowerCaseStr]?booleanMap[lowerCaseStr]:core.numfmt.parseValue(normalStr)==null?str:normalStr}__name(normalizeString,"normalizeString");function normalizeFormulaString(str,normalStr,lexerTreeBuilder,functionService){const nodes=lexerTreeBuilder.sequenceNodesBuilder(normalStr);if(!nodes)return str;let _normalStr=normalStr;return nodes.forEach((node,index)=>{if(typeof node=="object"){const token=node.token;if(booleanMap[token.toLowerCase()]){const startIndex=node.startIndex+1,endIndex=node.endIndex+2;_normalStr=replaceString(token.toLocaleUpperCase(),_normalStr,startIndex,endIndex)}else if(node.nodeType===engineFormula.sequenceNodeType.FUNCTION&&hasFunctionName(token,functionService,nodes,index)||node.nodeType===engineFormula.sequenceNodeType.REFERENCE){const sheetNameIndex=token.indexOf("!");if(sheetNameIndex>-1){const refBody=token.substring(sheetNameIndex+1),startIndex=node.startIndex+(sheetNameIndex+1)+1,endIndex=node.endIndex+2;_normalStr=replaceString(refBody.toLocaleUpperCase(),_normalStr,startIndex,endIndex)}else{const startIndex=node.startIndex+1,endIndex=node.endIndex+2;_normalStr=replaceString(token.toLocaleUpperCase(),_normalStr,startIndex,endIndex)}}else if(token.startsWith('"')&&token.endsWith('"')||token.startsWith("'")&&token.endsWith("'")){const startIndex=node.startIndex+2,endIndex=node.endIndex+1;_normalStr=replaceString(str.slice(startIndex,endIndex),_normalStr,startIndex,endIndex)}else if(node.nodeType!==engineFormula.sequenceNodeType.ARRAY&&core.numfmt.parseValue(token)==null){const startIndex=node.startIndex+1,endIndex=node.endIndex+2;_normalStr=replaceString(str.slice(startIndex,endIndex),_normalStr,startIndex,endIndex)}}}),_normalStr}__name(normalizeFormulaString,"normalizeFormulaString");function hasFunctionName(name,functionService,nodes,index){const functionList=functionService.getDescriptions();return nodes[index+1]!==engineFormula.matchToken.OPEN_BRACKET?!1:functionList.get(removeLeadingAtSymbols(name).toLocaleUpperCase())!==void 0}__name(hasFunctionName,"hasFunctionName");function removeLeadingAtSymbols(str){const regex=/^@+/;return str.replace(regex,"")}__name(removeLeadingAtSymbols,"removeLeadingAtSymbols");function toHalfWidth(char){return fullWidthToHalfWidthMap[char]||char}__name(toHalfWidth,"toHalfWidth");function replaceString(replacedString,normalStr,startIndex,endIndex){return normalStr.substring(0,startIndex)+replacedString+normalStr.substring(endIndex)}__name(replaceString,"replaceString");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 HIDDEN_EDITOR_POSITION=-1e3,EDITOR_INPUT_SELF_EXTEND_GAP=5,EDITOR_BORDER_SIZE=2;var _a16;exports.EditingRenderController=(_a16=class extends core.Disposable{constructor(_context,_layoutService,selectionManagerService,_undoRedoService,_contextService,_instanceSrv,_renderManagerService,_editorBridgeService,_cellEditorManagerService,_lexerTreeBuilder,_functionService,_textSelectionManagerService,_commandService,_localService,_editorService,_sheetSkeletonManagerService){super();__publicField(this,"_cursorChange",0);__publicField(this,"_isUnitEditing",!1);__publicField(this,"_workbookSelections");__publicField(this,"_d");__publicField(this,"_cursorTimeout");this._context=_context,this._layoutService=_layoutService,this._undoRedoService=_undoRedoService,this._contextService=_contextService,this._instanceSrv=_instanceSrv,this._renderManagerService=_renderManagerService,this._editorBridgeService=_editorBridgeService,this._cellEditorManagerService=_cellEditorManagerService,this._lexerTreeBuilder=_lexerTreeBuilder,this._functionService=_functionService,this._textSelectionManagerService=_textSelectionManagerService,this._commandService=_commandService,this._localService=_localService,this._editorService=_editorService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._workbookSelections=selectionManagerService.getWorkbookSelections(this._context.unitId),this.disposeWithMe(this._instanceSrv.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{(workbook==null?void 0:workbook.getUnitId())===this._context.unitId?this._d=this._init():(this._disposeCurrent(),this._isUnitEditing&&(this._handleEditorInvisible({visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.ESC,unitId:this._context.unitId}),this._isUnitEditing=!1))})),this._initEditorVisibilityListener()}dispose(){super.dispose(),this._disposeCurrent()}_disposeCurrent(){var _a58;(_a58=this._d)==null||_a58.dispose(),this._d=null}_init(){const d=new core.DisposableCollection;return this._subscribeToCurrentCell(d),this._initialKeyboardListener(d),this._initialCursorSync(d),this._listenEditorFocus(d),this._commandExecutedListener(d),this._initSkeletonListener(d),this.disposeWithMe(this._instanceSrv.unitDisposed$.subscribe(_unit=>{clearTimeout(this._cursorTimeout)})),this._cursorTimeout=setTimeout(()=>{this._cursorStateListener(d)},1e3),d}_initEditorVisibilityListener(){this.disposeWithMe(this._editorBridgeService.visible$.pipe(rxjs.distinctUntilChanged((prev,curr)=>prev.visible===curr.visible)).subscribe(param=>{(param.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY||param.unitId===this._context.unitId)&&param.visible?(this._isUnitEditing=!0,this._handleEditorVisible(param)):this._isUnitEditing&&(this._handleEditorInvisible(param),this._isUnitEditing=!1)}))}_listenEditorFocus(d){const renderConfig=this._getEditorObject();renderConfig&&d.add(renderConfig.document.onPointerDown$.subscribeEvent(()=>{if(this._isUnitEditing&&this._editorBridgeService.isVisible()){const param=this._editorBridgeService.getEditCellState(),editorId=this._editorBridgeService.getCurrentEditorId();if(!param||!editorId||!this._editorService.isSheetEditor(editorId))return;const skeleton=this._getEditorSkeleton(editorId);if(!skeleton)return;const{position,documentLayoutObject,canvasOffset,scaleX,scaleY}=param;this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY)}}))}_getEditorSkeleton(editorId){var _a58;return(_a58=this._renderManagerService.getRenderById(editorId))==null?void 0:_a58.with(docs.DocSkeletonManagerService).getSkeleton()}_getEditorViewModel(editorId){var _a58;return(_a58=this._renderManagerService.getRenderById(editorId))==null?void 0:_a58.with(docs.DocSkeletonManagerService).getViewModel()}_initialCursorSync(d){d.add(this._cellEditorManagerService.focus$.pipe(rxjs.filter(f2=>!!f2)).subscribe(()=>{var _a58;const docSelectionRenderManager=(_a58=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a58.with(docsUi.DocSelectionRenderService);docSelectionRenderManager&&docSelectionRenderManager.sync()}))}_initSkeletonListener(d){const commandList=new Set(sheets.COMMAND_LISTENER_SKELETON_CHANGE);commandList.delete(sheets.SetWorksheetActiveOperation.id),d.add(this._commandService.onCommandExecuted(commandInfo=>{commandList.has(commandInfo.id)&&this.resizeCellEditor()}))}resizeCellEditor(){var _a58;const state=this._cellEditorManagerService.getState();if(!state||!this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellPosition(!0);const editCellState=this._editorBridgeService.getEditCellState();if(!editCellState)return;const skeleton=(_a58=this._sheetSkeletonManagerService.getWorksheetSkeleton(editCellState.sheetId))==null?void 0:_a58.skeleton;if(!skeleton)return;const{row,column,scaleX,scaleY,position,canvasOffset,documentLayoutObject}=editCellState,maxSize=this._getEditorMaxSize(position,canvasOffset);if(!maxSize)return;const{height:clientHeight,width:clientWidth,scaleAdjust}=maxSize,cell=skeleton.getCellByIndex(row,column),height=Math.min((cell.mergeInfo.endY-cell.mergeInfo.startY)*scaleY,clientHeight)*scaleAdjust,width=Math.min((cell.mergeInfo.endX-cell.mergeInfo.startX)*scaleX,clientWidth)*scaleAdjust,currentHeight=state.endY-state.startY,currentWidth=state.endX-state.startX;if(currentHeight!==height||currentWidth!==width){this._editorBridgeService.refreshEditCellPosition(!0);const docSkeleton=this._getEditorSkeleton(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY);if(!docSkeleton)return;this._fitTextSize(position,canvasOffset,docSkeleton,documentLayoutObject,scaleX,scaleY,()=>{this._textSelectionManagerService.refreshSelection({unitId:core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,subUnitId:core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY})})}}_subscribeToCurrentCell(d){d.add(this._editorBridgeService.currentEditCellState$.subscribe(editCellState=>{var _a58;if(editCellState==null||this._editorBridgeService.isForceKeepVisible())return;const{position,documentLayoutObject,scaleX,editorUnitId}=editCellState;if(this._contextService.getContextValue(core.FOCUSING_EDITOR_STANDALONE)||this._contextService.getContextValue(core.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE)||this._instanceSrv.getUnit(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY)===documentLayoutObject.documentModel)return;const{startX,endX}=position,{textRotation,wrapStrategy,documentModel}=documentLayoutObject,{vertexAngle:angle}=engineRender.convertTextRotation(textRotation);documentModel.updateDocumentId(editorUnitId),wrapStrategy===core.WrapStrategy.WRAP&&angle===0&&documentModel.updateDocumentDataPageSize((endX-startX)/scaleX),this._instanceSrv.changeDoc(editorUnitId,documentModel),this._contextService.setContextValue(core.FOCUSING_EDITOR_BUT_HIDDEN,!0),this._textSelectionManagerService.replaceTextRanges([{startOffset:0,endOffset:0}]);const docSelectionRenderManager=(_a58=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a58.with(docsUi.DocSelectionRenderService);docSelectionRenderManager&&docSelectionRenderManager.activate(HIDDEN_EDITOR_POSITION,HIDDEN_EDITOR_POSITION,!document.activeElement||document.activeElement.classList.contains("univer-editor"))}))}_fitTextSize(actualRangeWithCoord,canvasOffset,documentSkeleton,documentLayoutObject,scaleX=1,scaleY=1,callback){const{startX,startY,endX,endY}=actualRangeWithCoord,documentDataModel=documentLayoutObject.documentModel;if(documentDataModel==null)return;const{actualWidth,actualHeight}=this._predictingSize(actualRangeWithCoord,canvasOffset,documentSkeleton,documentLayoutObject,scaleX,scaleY),{verticalAlign,paddingData,fill}=documentLayoutObject;let editorWidth=endX-startX,editorHeight=endY-startY;if(editorWidth<actualWidth&&(editorWidth=actualWidth),editorHeight<actualHeight)editorHeight=actualHeight,documentDataModel.updateDocumentDataMargin(paddingData);else{let offsetTop=0;verticalAlign===core.VerticalAlign.MIDDLE?offsetTop=(editorHeight-actualHeight)/2/scaleY:verticalAlign===core.VerticalAlign.TOP?offsetTop=paddingData.t||0:offsetTop=(editorHeight-actualHeight)/scaleY-(paddingData.b||0),offsetTop=offsetTop<(paddingData.t||0)?paddingData.t||0:offsetTop,documentDataModel.updateDocumentDataMargin({t:offsetTop})}documentSkeleton.calculate(),this._editAreaProcessing(editorWidth,editorHeight,actualRangeWithCoord,canvasOffset,fill,scaleX,scaleY,callback)}_predictingSize(actualRangeWithCoord,canvasOffset,documentSkeleton,documentLayoutObject,scaleX=1,scaleY=1){const{startX,endX}=actualRangeWithCoord,{textRotation,wrapStrategy}=documentLayoutObject,documentDataModel=documentLayoutObject.documentModel,{vertexAngle:angle}=engineRender.convertTextRotation(textRotation),clientWidth=document.body.clientWidth;if(wrapStrategy===core.WrapStrategy.WRAP&&angle===0){const{actualWidth,actualHeight}=documentSkeleton.getActualSize();return{actualWidth:actualWidth*scaleX,actualHeight:actualHeight*scaleY}}documentDataModel==null||documentDataModel.updateDocumentDataPageSize((clientWidth-startX-canvasOffset.left)/scaleX),documentSkeleton.calculate();const size=documentSkeleton.getActualSize();let editorWidth=endX-startX;return editorWidth<size.actualWidth*scaleX+EDITOR_INPUT_SELF_EXTEND_GAP*scaleX&&(editorWidth=size.actualWidth*scaleX+EDITOR_INPUT_SELF_EXTEND_GAP*scaleX),documentDataModel==null||documentDataModel.updateDocumentDataPageSize(editorWidth/scaleX),documentDataModel==null||documentDataModel.updateDocumentRenderConfig({horizontalAlign:core.HorizontalAlign.UNSPECIFIED,cellValueType:void 0}),{actualWidth:editorWidth,actualHeight:size.actualHeight*scaleY}}_getEditorMaxSize(position,canvasOffset){if(this._getEditorObject()==null)return;function pxToNum2(width2){return Number.parseInt(width2.replace("px",""))}__name(pxToNum2,"pxToNum");const canvasElement=this._context.engine.getCanvasElement(),canvasClientRect=canvasElement.getBoundingClientRect(),widthOfCanvas=pxToNum2(canvasElement.style.width),{width}=canvasClientRect,scaleAdjust=width/widthOfCanvas,{startX,startY}=position,clientHeight=document.body.clientHeight-startY-Number.parseFloat(styles$9.sheetFooterBarHeight)-canvasOffset.top-EDITOR_BORDER_SIZE*2,clientWidth=document.body.clientWidth-startX-canvasOffset.left;return{height:clientHeight,width:clientWidth,scaleAdjust}}_editAreaProcessing(editorWidth,editorHeight,actualRangeWithCoord,canvasOffset,fill,scaleX=1,scaleY=1,callback){var _a58;const editorObject=this._getEditorObject();if(editorObject==null)return;const canvasElement=this._context.engine.getCanvasElement();let{startX,startY}=actualRangeWithCoord;const{document:documentComponent,scene:editorScene,engine:docEngine}=editorObject,viewportMain=editorScene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN),info=this._getEditorMaxSize(actualRangeWithCoord,canvasOffset);if(!info)return;const{height:clientHeight,width:clientWidth,scaleAdjust}=info;let physicHeight=editorHeight,scrollBar=viewportMain==null?void 0:viewportMain.getScrollBar();physicHeight>clientHeight?(physicHeight=clientHeight,scrollBar==null?viewportMain&&new engineRender.ScrollBar(viewportMain,{enableHorizontal:!1,barSize:8}):viewportMain==null||viewportMain.resetCanvasSizeAndUpdateScroll()):(scrollBar=null,(_a58=viewportMain==null?void 0:viewportMain.getScrollBar())==null||_a58.dispose()),editorWidth+=(scrollBar==null?void 0:scrollBar.barSize)||0,editorWidth>clientWidth&&(editorWidth=clientWidth),startX-=engineRender.FIX_ONE_PIXEL_BLUR_OFFSET,startY-=engineRender.FIX_ONE_PIXEL_BLUR_OFFSET,this._addBackground(editorScene,editorWidth/scaleX,editorHeight/scaleY,fill);const{scaleX:precisionScaleX,scaleY:precisionScaleY}=editorScene.getPrecisionScale();editorScene.transformByState({width:editorWidth*scaleAdjust/scaleX,height:editorHeight*scaleAdjust/scaleY,scaleX:scaleX*scaleAdjust,scaleY:scaleY*scaleAdjust}),documentComponent.resize(editorWidth*scaleAdjust/scaleX,editorHeight*scaleAdjust/scaleY),setTimeout(()=>{docEngine.resizeBySize(engineRender.fixLineWidthByScale(editorWidth,precisionScaleX),engineRender.fixLineWidthByScale(physicHeight,precisionScaleY)),callback==null||callback()},0);const contentBoundingRect=this._layoutService.getContentElement().getBoundingClientRect(),canvasBoundingRect=canvasElement.getBoundingClientRect();startX=startX*scaleAdjust+(canvasBoundingRect.left-contentBoundingRect.left),startY=startY*scaleAdjust+(canvasBoundingRect.top-contentBoundingRect.top),this._cellEditorManagerService.setState({startX,startY,endX:editorWidth*scaleAdjust+startX,endY:physicHeight*scaleAdjust+startY,show:!0})}_addBackground(scene,editorWidth,editorHeight,fill){const fillRectKey="_backgroundRectHelperColor_",rect=scene.getObject(fillRectKey);rect==null&&fill==null||(rect==null?scene.addObjects([new engineRender.Rect(fillRectKey,{width:editorWidth,height:editorHeight,fill,evented:!1})],docsUi.DOCS_COMPONENT_MAIN_LAYER_INDEX):fill==null?rect.dispose():(rect.setProps({fill}),rect.transformByState({width:editorWidth,height:editorHeight})))}_handleEditorVisible(param){var _a58;const{eventType,keycode}=param;this._cursorChange=eventType===engineRender.DeviceInputEventType.PointerDown||eventType===engineRender.DeviceInputEventType.Dblclick?2:1;let editCellState=this._editorBridgeService.getEditCellState();if(editCellState==null||(this._commandService.syncExecuteCommand(ScrollToRangeOperation.id,{range:{startRow:editCellState.row,startColumn:editCellState.column,endRow:editCellState.row,endColumn:editCellState.column}}),this._editorBridgeService.refreshEditCellPosition(!1),editCellState=this._editorBridgeService.getEditCellState(),editCellState==null))return;const{position,documentLayoutObject,canvasOffset,scaleX,scaleY,editorUnitId,unitId,sheetId,isInArrayFormulaRange=!1}=editCellState,editorObject=this._getEditorObject();if(editorObject==null)return;this._setOpenForCurrent(unitId,sheetId);const{document:document2,scene}=editorObject;this._contextService.setContextValue(core.EDITOR_ACTIVATED,!0);const{documentModel:documentDataModel}=documentLayoutObject,skeleton=this._getEditorSkeleton(editorUnitId);if(!skeleton||!documentDataModel)return;if(this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY),eventType===engineRender.DeviceInputEventType.Keyboard||eventType===engineRender.DeviceInputEventType.Dblclick&&isInArrayFormulaRange){const snapshot=core.Tools.deepClone(documentDataModel.getSnapshot()),documentViewModel=this._getEditorViewModel(editorUnitId);if(documentViewModel==null)return;this._resetBodyStyle(snapshot.body,!!isInArrayFormulaRange),documentDataModel.reset(snapshot),documentViewModel.reset(documentDataModel),document2.makeDirty(),(keycode===ui.KeyCode.BACKSPACE||eventType===engineRender.DeviceInputEventType.Dblclick)&&(skeleton.calculate(),this._editorBridgeService.changeEditorDirty(!0)),this._textSelectionManagerService.replaceTextRanges([{startOffset:0,endOffset:0}])}else if(eventType===engineRender.DeviceInputEventType.Dblclick){const cursor=documentDataModel.getBody().dataStream.length-2||0;this._textSelectionManagerService.replaceTextRanges([{startOffset:cursor,endOffset:cursor}])}const viewMain=scene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN);setTimeout(()=>{viewMain==null||viewMain.scrollToViewportPos({viewportScrollX:Number.POSITIVE_INFINITY,viewportScrollY:Number.POSITIVE_INFINITY})},10),(_a58=this._renderManagerService.getRenderById(unitId))==null||_a58.scene.resetCursor()}_resetBodyStyle(body,removeStyle=!1){body.dataStream=core.DEFAULT_EMPTY_DOCUMENT_VALUE,body.textRuns!=null&&(body.textRuns.length===1&&!removeStyle?(body.textRuns[0].st=0,body.textRuns[0].ed=1):body.textRuns=void 0),body.paragraphs!=null&&(body.paragraphs.length===1?body.paragraphs[0].startIndex=0:body.paragraphs=[{startIndex:0}]),body.sectionBreaks!=null&&(body.sectionBreaks=void 0),body.tables!=null&&(body.tables=void 0),body.customRanges!=null&&(body.customRanges=void 0),body.customBlocks!=null&&(body.customBlocks=void 0)}_initialKeyboardListener(d){var _a58;const docSelectionRenderService=(_a58=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a58.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&d.add(docSelectionRenderService.onInputBefore$.subscribe(config=>{var _a59;if(!this._isCurrentSheetFocused())return;const isFocusFormulaEditor=this._contextService.getContextValue(core.FOCUSING_FX_BAR_EDITOR),isFocusSheets=this._contextService.getContextValue(core.FOCUSING_SHEET),unitId=(_a59=this._instanceSrv.getCurrentUniverDocInstance())==null?void 0:_a59.getUnitId();unitId&&isFocusSheets&&!isFocusFormulaEditor&&this._editorService.isSheetEditor(unitId)&&this._showEditorByKeyboard(config)}))}_showEditorByKeyboard(config){if(config==null)return;const event=config.event;this._commandService.executeCommand(SetCellEditVisibleOperation.id,{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:event.which,unitId:this._context.unitId})}_commandExecutedListener(d){const updateCommandList=[docs.RichTextEditingMutation.id,ui.SetEditorResizeOperation.id];d.add(this._commandService.onCommandExecuted(command=>{if(updateCommandList.includes(command.id)){const params=command.params,{unitId:commandUnitId}=params;if(!this._isCurrentSheetFocused()||!this._editorService.isSheetEditor(commandUnitId))return;const editorId=this._editorBridgeService.getCurrentEditorId();if(editorId==null)return;const skeleton=this._getEditorSkeleton(editorId);if(skeleton==null)return;this._editorBridgeService.changeEditorDirty(!0);const param=this._editorBridgeService.getEditCellState();if(param==null)return;const{position,documentLayoutObject,canvasOffset,scaleX,scaleY}=param;if(!this._editorBridgeService.isVisible().visible)return;commandUnitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY?setTimeout(()=>{this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY)},0):this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY)}})),d.add(this._commandService.onCommandExecuted(command=>{if(command.id===sheets.ClearSelectionFormatCommand.id){if(this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellState()}})),d.add(this._commandService.onCommandExecuted(command=>{if(command.id===sheets.SetRangeValuesMutation.id){if(this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellState()}}));const closeEditorOperation=[SetCellEditVisibleArrowOperation.id];d.add(this._commandService.onCommandExecuted(command=>{if(closeEditorOperation.includes(command.id)){const params=command.params,{keycode,isShift}=params;if(keycode!=null&&(this._cursorChange===2||this._contextService.getContextValue(core.FOCUSING_FX_BAR_EDITOR))){this._moveInEditor(keycode,isShift);return}this._editorBridgeService.changeVisible(params)}command.id===SetCellEditVisibleWithF2Operation.id&&(this._cursorChange=2)}))}_setOpenForCurrent(unitId,sheetId){const sheetEditors=this._editorService.getAllEditor();for(const[_,sheetEditor]of sheetEditors)sheetEditor.isSheetEditor()&&(sheetEditor.setOpenForSheetUnitId(unitId),sheetEditor.setOpenForSheetSubUnitId(sheetId))}_getEditorObject(){return getEditorObject(this._editorBridgeService.getCurrentEditorId(),this._renderManagerService)}async _handleEditorInvisible(param){const editCellState=this._editorBridgeService.getEditCellState();let{keycode}=param;if(this._setOpenForCurrent(null,null),this._cursorChange=0,this._exitInput(param),editCellState==null)return;this._editorBridgeService.getEditorDirty()===!1&&(keycode=ui.KeyCode.ESC);const worksheet=this._context.unit.getActiveSheet(),workbookId=this._context.unitId,worksheetId=worksheet.getSheetId();if(keycode===ui.KeyCode.ESC){const selections=this._workbookSelections.getCurrentSelections();selections&&this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,{unitId:this._context.unit.getUnitId(),subUnitId:worksheetId,selections});return}const{unitId,sheetId}=editCellState;workbookId===unitId&&sheetId!==worksheetId&&this._editorBridgeService.isForceKeepVisible()&&await this._commandService.executeCommand(sheets.SetWorksheetActivateCommand.id,{subUnitId:sheetId,unitId});const documentDataModel=editCellState.documentLayoutObject.documentModel;documentDataModel&&await this._submitCellData(documentDataModel),this._moveCursor(keycode)}submitCellData(documentDataModel){return this._submitCellData(documentDataModel)}async _submitCellData(documentDataModel){const editCellState=this._editorBridgeService.getEditCellState();if(editCellState==null)return;const{unitId,sheetId,row,column}=editCellState,workbook=this._context.unit;let worksheet=workbook.getActiveSheet();if(!workbook.getSheetBySheetId(sheetId))return;worksheet=workbook.getActiveSheet();const cellData=getCellDataByInput(worksheet.getCellRaw(row,column)||{},documentDataModel,this._lexerTreeBuilder,model=>model.getSnapshot(),this._localService,this._functionService);if(!cellData)return;const context={subUnitId:sheetId,unitId,workbook,worksheet,row,col:column,origin:core.Tools.deepClone(cellData)},cell=this._editorBridgeService.interceptor.fetchThroughInterceptors(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT)(cellData,context),finalCell=await this._editorBridgeService.interceptor.fetchThroughInterceptors(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC)(Promise.resolve(cell),context);this._commandService.executeCommand(sheets.SetRangeValuesCommand.id,{subUnitId:sheetId,unitId,range:{startRow:row,startColumn:column,endRow:row,endColumn:column},value:finalCell})}_exitInput(param){var _a58;this._contextService.setContextValue(core.FOCUSING_EDITOR_INPUT_FORMULA,!1),this._contextService.setContextValue(core.EDITOR_ACTIVATED,!1),this._contextService.setContextValue(core.FOCUSING_EDITOR_BUT_HIDDEN,!1),this._contextService.setContextValue(core.FOCUSING_FX_BAR_EDITOR,!1),this._cellEditorManagerService.setState({show:param.visible});const editorObject=this._getEditorObject();(_a58=editorObject==null?void 0:editorObject.scene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN))==null||_a58.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});const editorUnitId=this._editorBridgeService.getCurrentEditorId();editorUnitId==null||!this._editorService.isSheetEditor(editorUnitId)||(this._undoRedoService.clearUndoRedo(editorUnitId),this._undoRedoService.clearUndoRedo(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY))}_moveCursor(keycode){if(keycode==null||!MOVE_SELECTION_KEYCODE_LIST.includes(keycode))return;let direction=core.Direction.LEFT;switch(keycode){case ui.KeyCode.ENTER:direction=core.Direction.DOWN;break;case ui.KeyCode.TAB:direction=core.Direction.RIGHT;break;case ui.KeyCode.ARROW_DOWN:direction=core.Direction.DOWN;break;case ui.KeyCode.ARROW_UP:direction=core.Direction.UP;break;case ui.KeyCode.ARROW_LEFT:direction=core.Direction.LEFT;break;case ui.KeyCode.ARROW_RIGHT:direction=core.Direction.RIGHT;break}keycode===ui.KeyCode.ENTER||keycode===ui.KeyCode.TAB?this._commandService.executeCommand(MoveSelectionEnterAndTabCommand.id,{keycode,direction}):this._commandService.executeCommand(MoveSelectionCommand.id,{direction})}_cursorStateListener(d){const editorObject=this._getEditorObject();if(!editorObject.document)return;const{document:documentComponent}=editorObject;d.add(core.toDisposable(documentComponent.onPointerDown$.subscribeEvent(()=>{this._cursorChange===1&&(this._cursorChange=2)})))}_moveInEditor(keycode,isShift){let direction=core.Direction.LEFT;keycode===ui.KeyCode.ARROW_DOWN?direction=core.Direction.DOWN:keycode===ui.KeyCode.ARROW_UP?direction=core.Direction.UP:keycode===ui.KeyCode.ARROW_RIGHT&&(direction=core.Direction.RIGHT),isShift?this._commandService.executeCommand(docsUi.MoveSelectionOperation.id,{direction}):this._commandService.executeCommand(docsUi.MoveCursorOperation.id,{direction})}_isCurrentSheetFocused(){var _a58;return((_a58=this._instanceSrv.getFocusedUnit())==null?void 0:_a58.getUnitId())===this._context.unitId}},__name(_a16,"EditingRenderController"),_a16);exports.EditingRenderController=__decorateClass$D([__decorateParam$D(1,ui.ILayoutService),__decorateParam$D(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$D(3,core.IUndoRedoService),__decorateParam$D(4,core.IContextService),__decorateParam$D(5,core.IUniverInstanceService),__decorateParam$D(6,engineRender.IRenderManagerService),__decorateParam$D(7,IEditorBridgeService),__decorateParam$D(8,ICellEditorManagerService),__decorateParam$D(9,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$D(10,engineFormula.IFunctionService),__decorateParam$D(11,core.Inject(docs.DocSelectionManagerService)),__decorateParam$D(12,core.ICommandService),__decorateParam$D(13,core.Inject(core.LocaleService)),__decorateParam$D(14,docsUi.IEditorService),__decorateParam$D(15,core.Inject(exports.SheetSkeletonManagerService))],exports.EditingRenderController);function getCellDataByInput(cellData,documentDataModel,lexerTreeBuilder,getSnapshot,localeService,functionService){if(cellData=core.Tools.deepClone(cellData),documentDataModel==null)return null;const snapshot=getSnapshot(documentDataModel),{body}=snapshot;if(body==null)return null;cellData.t=void 0;const data=body.dataStream;let newDataStream=data.substring(data.length-2,data.length)===core.DEFAULT_EMPTY_DOCUMENT_VALUE?data.substring(0,data.length-2):data;const currentLocale=localeService.getCurrentLocale();if(newDataStream=normalizeString(newDataStream,lexerTreeBuilder,currentLocale,functionService),core.isFormulaString(newDataStream)){if(cellData.f===newDataStream)return null;const bracketCount=lexerTreeBuilder.checkIfAddBracket(newDataStream);for(let i=0;i<bracketCount;i++)newDataStream+=engineFormula.matchToken.CLOSE_BRACKET;cellData.f=newDataStream,cellData.si=null,cellData.v=null,cellData.p=null}else if(isForceString(newDataStream)){const v=extractStringFromForceString(newDataStream);cellData.v=v,cellData.f=null,cellData.si=null,cellData.p=null,cellData.t=core.CellValueType.FORCE_STRING}else if(isRichText(body))body.dataStream===`\r
17
+ `)}),plain}__name(getMatrixPlainText,"getMatrixPlainText");function getCellTextForClipboard(cell){return core.extractPureTextFromCell(cell)}__name(getCellTextForClipboard,"getCellTextForClipboard");function rowAcrossMergedCell(row,startColumn,endColumn,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startRow<=row&&row<mergedCell.endRow&&startColumn<=mergedCell.startColumn&&mergedCell.startColumn<=endColumn)}__name(rowAcrossMergedCell,"rowAcrossMergedCell");function columnAcrossMergedCell(col,startRow,endRow,worksheet){return worksheet.getMergeData().some(mergedCell=>mergedCell.startColumn<=col&&col<mergedCell.endColumn&&startRow<=mergedCell.startRow&&mergedCell.startRow<=endRow)}__name(columnAcrossMergedCell,"columnAcrossMergedCell");function isMultipleCells(cellMatrix){let count=0;return cellMatrix.forValue((row,col,cell)=>{if(cell&&count++,count>1)return!1}),count>1}__name(isMultipleCells,"isMultipleCells");function getEmptyCell(){return{p:null,v:null,s:null,f:null,si:null,t:null}}__name(getEmptyCell,"getEmptyCell");const SHEET_CLIPBOARD_PRIORITY=998,SheetCopyCommand={id:ui.CopyCommand.id,name:"sheet.command.copy",type:core.CommandType.COMMAND,multi:!0,priority:SHEET_CLIPBOARD_PRIORITY,preconditions:whenSheetFocused,handler:__name(async accessor=>accessor.get(ISheetClipboardService).copy(),"handler")},SheetCutCommand={id:ui.CutCommand.id,name:"sheet.command.cut",type:core.CommandType.COMMAND,multi:!0,priority:SHEET_CLIPBOARD_PRIORITY,preconditions:whenSheetFocused,handler:__name(async accessor=>accessor.get(ISheetClipboardService).cut(),"handler")},SheetPasteCommand={id:ui.PasteCommand.id,type:core.CommandType.COMMAND,multi:!0,name:"sheet.command.paste",priority:SHEET_CLIPBOARD_PRIORITY,preconditions:whenSheetFocused,handler:__name(async(accessor,params)=>{const clipboardItems=await accessor.get(ui.IClipboardInterfaceService).read(),sheetClipboardService=accessor.get(ISheetClipboardService);return clipboardItems.length!==0?sheetClipboardService.paste(clipboardItems[0],params==null?void 0:params.value):!1},"handler")},SheetPasteShortKeyCommand={id:"sheet.command.paste-bu-short-key",type:core.CommandType.COMMAND,handler:__name(async(accessor,params)=>{const clipboardService=accessor.get(ISheetClipboardService),{htmlContent,textContent}=params;return clipboardService.legacyPaste(htmlContent,textContent),!0},"handler")},SheetPasteValueCommand={id:"sheet.command.paste-value",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE}),"handler")},SheetPasteFormatCommand={id:"sheet.command.paste-format",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT}),"handler")},SheetPasteColWidthCommand={id:"sheet.command.paste-col-width",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH}),"handler")},SheetPasteBesidesBorderCommand={id:"sheet.command.paste-besides-border",type:core.CommandType.COMMAND,handler:__name(async accessor=>accessor.get(core.ICommandService).executeCommand(SheetPasteCommand.id,{value:PREDEFINED_HOOK_NAME.SPECIAL_PASTE_BESIDES_BORDER}),"handler")};function CellBorderSelectorMenuItemFactory(accessor){const borderStyleManagerService=accessor.get(sheets.BorderStyleManagerService),disabled$=getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]});return{id:sheets.SetBorderBasicCommand.id,icon:new rxjs.Observable(subscriber=>{const defaultIcon="AllBorderSingle",borderManager=accessor.get(sheets.BorderStyleManagerService),disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a58;if(c.id!==sheets.SetBorderBasicCommand.id)return;const{type}=borderManager.getBorderInfo(),item=BORDER_LINE_CHILDREN.find(item2=>item2.value===type),icon=(_a58=item==null?void 0:item.icon)!=null?_a58:defaultIcon;subscriber.next(icon)});return subscriber.next(defaultIcon),disposable.dispose}),tooltip:"toolbar.border.main",type:ui.MenuItemType.BUTTON_SELECTOR,selections:[{label:{name:BORDER_PANEL_COMPONENT,hoverable:!1},value$:borderStyleManagerService.borderInfo$}],value$:borderStyleManagerService.borderInfo$,hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$}}__name(CellBorderSelectorMenuItemFactory,"CellBorderSelectorMenuItemFactory");const CLEAR_SELECTION_MENU_ID="sheet.menu.clear-selection";function ClearSelectionMenuItemFactory(accessor){return{id:CLEAR_SELECTION_MENU_ID,type:ui.MenuItemType.SUBITEMS,icon:"ClearFormat",title:"rightClick.clearSelection",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionMenuItemFactory,"ClearSelectionMenuItemFactory");function ClearSelectionContentMenuItemFactory(accessor){return{id:sheets.ClearSelectionContentCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.clearContent",disabled$:getObservableWithExclusiveRange$(accessor,getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionContentMenuItemFactory,"ClearSelectionContentMenuItemFactory");function ClearSelectionFormatMenuItemFactory(accessor){return{id:sheets.ClearSelectionFormatCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.clearFormat",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionFormatMenuItemFactory,"ClearSelectionFormatMenuItemFactory");function ClearSelectionAllMenuItemFactory(accessor){return{id:sheets.ClearSelectionAllCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.clearAll",disabled$:getObservableWithExclusiveRange$(accessor,getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ClearSelectionAllMenuItemFactory,"ClearSelectionAllMenuItemFactory");const DELETE_RANGE_MENU_ID="sheet.menu.delete";function DeleteRangeMenuItemFactory(accessor){return{id:DELETE_RANGE_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.delete",icon:"Reduce",hidden$:getObservableWithExclusiveRange$(accessor,getBaseRangeMenuHidden$(accessor)),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission]})}}__name(DeleteRangeMenuItemFactory,"DeleteRangeMenuItemFactory");function RemoveColMenuItemFactory(accessor){return{id:RemoveColConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"DeleteColumn",title:"rightClick.deleteSelectedColumn",hidden$:getObservableWithExclusiveRange$(accessor,getDeleteMenuHidden$(accessor,"col")),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetDeleteColumnPermission]})}}__name(RemoveColMenuItemFactory,"RemoveColMenuItemFactory");function RemoveRowMenuItemFactory(accessor){return{id:RemoveRowConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"DeleteRow",title:"rightClick.deleteSelectedRow",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetDeleteRowPermission]}),hidden$:getDeleteMenuHidden$(accessor,"row")}}__name(RemoveRowMenuItemFactory,"RemoveRowMenuItemFactory");function DeleteRangeMoveLeftMenuItemFactory(accessor){return{id:DeleteRangeMoveLeftConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveLeft",icon:"DeleteCellShiftLeft",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"col")}}__name(DeleteRangeMoveLeftMenuItemFactory,"DeleteRangeMoveLeftMenuItemFactory");function DeleteRangeMoveUpMenuItemFactory(accessor){return{id:DeleteRangeMoveUpConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveUp",icon:"DeleteCellShiftUp",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"row")}}__name(DeleteRangeMoveUpMenuItemFactory,"DeleteRangeMoveUpMenuItemFactory");const COL_INSERT_MENU_ID="sheet.menu.col-insert";function ColInsertMenuItemFactory(accessor){return{id:COL_INSERT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.insert",icon:"Insert",hidden$:getBaseRangeMenuHidden$(accessor),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetInsertColumnPermission]})}}__name(ColInsertMenuItemFactory,"ColInsertMenuItemFactory");const ROW_INSERT_MENU_ID="sheet.menu.row-insert";function RowInsertMenuItemFactory(accessor){return{id:ROW_INSERT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.insert",icon:"Insert",hidden$:getBaseRangeMenuHidden$(accessor),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertRowPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(RowInsertMenuItemFactory,"RowInsertMenuItemFactory");const CELL_INSERT_MENU_ID="sheet.menu.cell-insert";function CellInsertMenuItemFactory(accessor){return{id:CELL_INSERT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.insert",icon:"Insert",hidden$:getObservableWithExclusiveRange$(accessor,getBaseRangeMenuHidden$(accessor)),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertColumnPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(CellInsertMenuItemFactory,"CellInsertMenuItemFactory");function InsertRowBeforeMenuItemFactory(accessor){return{id:sheets.InsertRowBeforeCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertRowBefore",icon:"InsertRowAbove",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertRowPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertBeforeMenuHidden$(accessor,"row")}}__name(InsertRowBeforeMenuItemFactory,"InsertRowBeforeMenuItemFactory");function InsertRowAfterMenuItemFactory(accessor){return{id:sheets.InsertRowAfterCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertRow",icon:"InsertRowBelow",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertRowPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertAfterMenuHidden$(accessor,"row")}}__name(InsertRowAfterMenuItemFactory,"InsertRowAfterMenuItemFactory");function InsertColBeforeMenuItemFactory(accessor){return{id:sheets.InsertColBeforeCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertColumnBefore",icon:"LeftInsertColumn",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertColumnPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertBeforeMenuHidden$(accessor,"col")}}__name(InsertColBeforeMenuItemFactory,"InsertColBeforeMenuItemFactory");function InsertColAfterMenuItemFactory(accessor){return{id:sheets.InsertColAfterCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.insertColumn",icon:"RightInsertColumn",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetInsertColumnPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getInsertAfterMenuHidden$(accessor,"col")}}__name(InsertColAfterMenuItemFactory,"InsertColAfterMenuItemFactory");function InsertRangeMoveRightMenuItemFactory(accessor){return{id:InsertRangeMoveRightConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveRight",icon:"InsertCellShiftRight",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"col")}}__name(InsertRangeMoveRightMenuItemFactory,"InsertRangeMoveRightMenuItemFactory");function InsertRangeMoveDownMenuItemFactory(accessor){return{id:InsertRangeMoveDownConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.moveDown",icon:"InsertCellDown",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:getCellMenuHidden$(accessor,"row")}}__name(InsertRangeMoveDownMenuItemFactory,"InsertRangeMoveDownMenuItemFactory");var SheetMenuPosition=(SheetMenuPosition2=>(SheetMenuPosition2.ROW_HEADER_CONTEXT_MENU="ROW_HEADER_CONTEXT_MENU",SheetMenuPosition2.COL_HEADER_CONTEXT_MENU="COL_HEADER_CONTEXT_MENU",SheetMenuPosition2.SHEET_BAR="SHEET_BAR",SheetMenuPosition2.SHEET_FOOTER="SHEET_FOOTER",SheetMenuPosition2))(SheetMenuPosition||{});function FormatPainterMenuItemFactory(accessor){const formatPainterService=accessor.get(IFormatPainterService);return{id:SetOnceFormatPainterCommand.id,subId:SetInfiniteFormatPainterCommand.id,type:ui.MenuItemType.BUTTON,icon:"BrushSingle",title:"Format Painter",tooltip:"toolbar.formatPainter",activated$:new rxjs.Observable(subscriber=>{let active=!1;const status$=formatPainterService.status$.subscribe(s=>{active=s!==FormatPainterStatus.OFF,subscriber.next(active)});return subscriber.next(active),()=>{status$.unsubscribe()}}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetCopyPermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(FormatPainterMenuItemFactory,"FormatPainterMenuItemFactory");function BoldMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),contextService=accessor.get(core.IContextService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return{id:SetRangeBoldCommand.id,type:ui.MenuItemType.BUTTON,icon:"BoldSingle",title:"Set bold",tooltip:"toolbar.bold",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let isBold2=core.FontWeight.NORMAL;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);isBold2=range==null?void 0:range.getFontWeight()}subscriber.next(isBold2===core.FontWeight.BOLD)}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const bl=(_b=textRun.ts)==null?void 0:_b.bl;subscriber.next(bl===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;if(!worksheet){subscriber.next(!1);return}let isBold=core.FontWeight.NORMAL;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);isBold=range==null?void 0:range.getFontWeight()}return subscriber.next(isBold===core.FontWeight.BOLD),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(BoldMenuItemFactory,"BoldMenuItemFactory");function ItalicMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService);return{id:SetRangeItalicCommand.id,type:ui.MenuItemType.BUTTON,icon:"ItalicSingle",title:"Set italic",tooltip:"toolbar.italic",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let isItalic2=core.FontItalic.NORMAL;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);isItalic2=range==null?void 0:range.getFontStyle()}subscriber.next(isItalic2===core.FontItalic.ITALIC)}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const it=(_b=textRun.ts)==null?void 0:_b.it;subscriber.next(it===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let isItalic=core.FontItalic.NORMAL;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);isItalic=range==null?void 0:range.getFontStyle()}return subscriber.next(isItalic===core.FontItalic.ITALIC),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ItalicMenuItemFactory,"ItalicMenuItemFactory");function UnderlineMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService);return{id:SetRangeUnderlineCommand.id,type:ui.MenuItemType.BUTTON,icon:"UnderlineSingle",title:"Set underline",tooltip:"toolbar.underline",activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let isUnderline2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);isUnderline2=range==null?void 0:range.getUnderline()}subscriber.next(!!(isUnderline2&&isUnderline2.s))}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const ul=(_b=textRun.ts)==null?void 0:_b.ul;subscriber.next((ul==null?void 0:ul.s)===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let isUnderline;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);isUnderline=range==null?void 0:range.getUnderline()}return subscriber.next(!!(isUnderline&&isUnderline.s)),disposable.dispose})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(UnderlineMenuItemFactory,"UnderlineMenuItemFactory");function StrikeThroughMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService);return{id:SetRangeStrickThroughCommand.id,type:ui.MenuItemType.BUTTON,icon:"StrikethroughSingle",title:"Set strike through",tooltip:"toolbar.strikethrough",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),activated$:deriveStateFromActiveSheet$(univerInstanceService,!1,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let st2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);st2=range==null?void 0:range.getStrikeThrough()}subscriber.next(!!(st2&&st2.s))}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const st2=(_b=textRun.ts)==null?void 0:_b.st;subscriber.next((st2==null?void 0:st2.s)===core.BooleanNumber.TRUE)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let st;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);st=range==null?void 0:range.getStrikeThrough()}return subscriber.next(!!(st&&st.s)),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(StrikeThroughMenuItemFactory,"StrikeThroughMenuItemFactory");function FontFamilySelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=core.DEFAULT_STYLES.ff;return{id:SetRangeFontFamilyCommand.id,tooltip:"toolbar.font",type:ui.MenuItemType.SELECTOR,label:FONT_FAMILY_COMPONENT,selections:ui.FONT_FAMILY_LIST.map(item=>({label:{name:FONT_FAMILY_ITEM_COMPONENT,hoverable:!0},value:item.value})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetRangeValuesMutation.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let ff2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);ff2=range==null?void 0:range.getFontFamily()}subscriber.next(ff2!=null?ff2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let ff;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);ff=range==null?void 0:range.getFontFamily()}return subscriber.next(ff!=null?ff:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FontFamilySelectorMenuItemFactory,"FontFamilySelectorMenuItemFactory");function FontSizeSelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),contextService=accessor.get(core.IContextService),defaultValue=core.DEFAULT_STYLES.fs,disabled$=getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]});return{id:SetRangeFontSizeCommand.id,type:ui.MenuItemType.SELECTOR,tooltip:"toolbar.fontSize",label:{name:FONT_SIZE_COMPONENT,props:{min:1,max:400,disabled$}},selections:ui.FONT_SIZE_LIST,disabled$,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=commandService.onCommandExecuted(c=>{var _a59,_b;const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetActiveOperation.id){const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let fs2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);fs2=range==null?void 0:range.getFontSize()}subscriber.next(fs2!=null?fs2:defaultValue)}if((id===docs.SetTextSelectionsOperation.id||id===docsUi.SetInlineFormatCommand.id)&&contextService.getContextValue(core.EDITOR_ACTIVATED)&&contextService.getContextValue(core.FOCUSING_SHEET)){const textRun=getFontStyleAtCursor(accessor);if(textRun==null)return;const fs2=(_b=textRun.ts)==null?void 0:_b.fs;subscriber.next(fs2!=null?fs2:defaultValue)}}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let fs;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);fs=range==null?void 0:range.getFontSize()}return subscriber.next(fs!=null?fs:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FontSizeSelectorMenuItemFactory,"FontSizeSelectorMenuItemFactory");function ResetTextColorMenuItemFactory(accessor){return{id:sheets.ResetTextColorCommand.id,type:ui.MenuItemType.BUTTON,title:"toolbar.resetColor",icon:"NoColor",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ResetTextColorMenuItemFactory,"ResetTextColorMenuItemFactory");function TextColorSelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),themeService=accessor.get(core.ThemeService);return{id:SetRangeTextColorCommand.id,icon:"FontColor",tooltip:"toolbar.textColor.main",type:ui.MenuItemType.BUTTON_SELECTOR,selections:[{label:{name:COLOR_PICKER_COMPONENT,hoverable:!1}}],value$:new rxjs.Observable(subscriber=>{const defaultValue=themeService.getCurrentTheme().textColor,disposable=commandService.onCommandExecuted(c=>{if(c.id===SetRangeTextColorCommand.id){const color=c.params.value;subscriber.next(color!=null?color:defaultValue)}});return subscriber.next(defaultValue),disposable.dispose}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(TextColorSelectorMenuItemFactory,"TextColorSelectorMenuItemFactory");function ResetBackgroundColorMenuItemFactory(accessor){return{id:sheets.ResetBackgroundColorCommand.id,type:ui.MenuItemType.BUTTON,title:"toolbar.resetColor",icon:"NoColor",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(ResetBackgroundColorMenuItemFactory,"ResetBackgroundColorMenuItemFactory");function BackgroundColorSelectorMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),themeService=accessor.get(core.ThemeService);return{id:sheets.SetBackgroundColorCommand.id,tooltip:"toolbar.fillColor.main",type:ui.MenuItemType.BUTTON_SELECTOR,icon:"PaintBucket",selections:[{label:{name:COLOR_PICKER_COMPONENT,hoverable:!1}}],value$:new rxjs.Observable(subscriber=>{const defaultValue=themeService.getCurrentTheme().primaryColor,disposable=commandService.onCommandExecuted(c=>{if(c.id===sheets.SetBackgroundColorCommand.id){const color=c.params.value;subscriber.next(color!=null?color:defaultValue)}});return subscriber.next(defaultValue),disposable.dispose}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(BackgroundColorSelectorMenuItemFactory,"BackgroundColorSelectorMenuItemFactory");const HORIZONTAL_ALIGN_CHILDREN=[{label:"align.left",icon:"LeftJustifyingSingle",value:core.HorizontalAlign.LEFT},{label:"align.center",icon:"HorizontallySingle",value:core.HorizontalAlign.CENTER},{label:"align.right",icon:"RightJustifyingSingle",value:core.HorizontalAlign.RIGHT}];function HorizontalAlignMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=core.HorizontalAlign.LEFT;return{id:sheets.SetHorizontalTextAlignCommand.id,icon:HORIZONTAL_ALIGN_CHILDREN[0].icon,tooltip:"toolbar.horizontalAlignMode.main",type:ui.MenuItemType.SELECTOR,selections:HORIZONTAL_ALIGN_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetHorizontalTextAlignCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let ha2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);ha2=range==null?void 0:range.getHorizontalAlignment()}subscriber.next(ha2!=null?ha2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let ha;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);ha=range==null?void 0:range.getHorizontalAlignment()}return subscriber.next(ha!=null?ha:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(HorizontalAlignMenuItemFactory,"HorizontalAlignMenuItemFactory");const VERTICAL_ALIGN_CHILDREN=[{label:"align.top",icon:"AlignTopSingle",value:core.VerticalAlign.TOP},{label:"align.middle",icon:"VerticalCenterSingle",value:core.VerticalAlign.MIDDLE},{label:"align.bottom",icon:"AlignBottomSingle",value:core.VerticalAlign.BOTTOM}];function VerticalAlignMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=core.VerticalAlign.BOTTOM;return{id:sheets.SetVerticalTextAlignCommand.id,icon:VERTICAL_ALIGN_CHILDREN[2].icon,tooltip:"toolbar.verticalAlignMode.main",type:ui.MenuItemType.SELECTOR,selections:VERTICAL_ALIGN_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetVerticalTextAlignCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let va2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);va2=range==null?void 0:range.getVerticalAlignment()}subscriber.next(va2!=null?va2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let va;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);va=range==null?void 0:range.getVerticalAlignment()}return subscriber.next(va!=null?va:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(VerticalAlignMenuItemFactory,"VerticalAlignMenuItemFactory");const TEXT_WRAP_CHILDREN=[{label:"textWrap.overflow",icon:"OverflowSingle",value:core.WrapStrategy.OVERFLOW},{label:"textWrap.wrap",icon:"AutowrapSingle",value:core.WrapStrategy.WRAP},{label:"textWrap.clip",icon:"TruncationSingle",value:core.WrapStrategy.CLIP}];function WrapTextMenuItemFactory(accessor){const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),defaultValue=core.WrapStrategy.OVERFLOW;return{id:sheets.SetTextWrapCommand.id,tooltip:"toolbar.textWrapMode.main",icon:TEXT_WRAP_CHILDREN[0].icon,type:ui.MenuItemType.SELECTOR,selections:TEXT_WRAP_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59;const id=c.id;if(id!==sheets.SetTextWrapCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let ws2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);ws2=range==null?void 0:range.getWrapStrategy()}subscriber.next(ws2!=null?ws2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let ws;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);ws=range==null?void 0:range.getWrapStrategy()}return subscriber.next(ws!=null?ws:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(WrapTextMenuItemFactory,"WrapTextMenuItemFactory");const TEXT_ROTATE_CHILDREN=[{label:"textRotate.none",icon:"NoRotationSingle",value:0},{label:"textRotate.angleUp",icon:"LeftRotationFortyFiveDegreesSingle",value:-45},{label:"textRotate.angleDown",icon:"RightRotationFortyFiveDegreesSingle",value:45},{label:"textRotate.vertical",icon:"VerticalTextSingle",value:"v"},{label:"textRotate.rotationUp",icon:"LeftRotationNinetyDegreesSingle",value:-90},{label:"textRotate.rotationDown",icon:"RightRotationNinetyDegreesSingle",value:90}];function TextRotateMenuItemFactory(accessor){const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),univerInstanceService=accessor.get(core.IUniverInstanceService),defaultValue=0;return{id:sheets.SetTextRotationCommand.id,tooltip:"toolbar.textRotateMode.main",icon:TEXT_ROTATE_CHILDREN[0].icon,type:ui.MenuItemType.SELECTOR,selections:TEXT_ROTATE_CHILDREN,value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{var _a58,_b;const disposable=accessor.get(core.ICommandService).onCommandExecuted(c=>{var _a59,_b2;const id=c.id;if(id!==sheets.SetTextRotationCommand.id&&id!==sheets.SetSelectionsOperation.id&&id!==sheets.SetWorksheetActiveOperation.id)return;const primary2=(_a59=selectionManagerService.getCurrentLastSelection())==null?void 0:_a59.primary;let tr2;if(primary2!=null){const range=worksheet.getRange(primary2.startRow,primary2.startColumn);tr2=range==null?void 0:range.getTextRotation()}(tr2==null?void 0:tr2.v)===core.BooleanNumber.TRUE?subscriber.next("v"):subscriber.next((_b2=tr2&&tr2.a)!=null?_b2:defaultValue)}),primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let tr;if(primary!=null){const range=worksheet.getRange(primary.startRow,primary.startColumn);tr=range==null?void 0:range.getTextRotation()}return(tr==null?void 0:tr.v)===core.BooleanNumber.TRUE?subscriber.next("v"):subscriber.next((_b=tr&&tr.a)!=null?_b:defaultValue),disposable.dispose})),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(TextRotateMenuItemFactory,"TextRotateMenuItemFactory");function menuClipboardDisabledObservable(injector){return new rxjs.Observable(subscriber=>subscriber.next(!injector.get(ui.IClipboardInterfaceService).supportClipboard))}__name(menuClipboardDisabledObservable,"menuClipboardDisabledObservable");function CopyMenuItemFactory(accessor){return{id:SheetCopyCommand.name,commandId:SheetCopyCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.copy",icon:"Copy",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookCopyPermission],worksheetTypes:[sheets.WorksheetCopyPermission],rangeTypes:[sheets.RangeProtectionPermissionViewPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CopyMenuItemFactory,"CopyMenuItemFactory");function PasteMenuItemFactory(accessor){return{id:SheetPasteCommand.name,commandId:SheetPasteCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.paste",icon:"PasteSpecial",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission,sheets.WorksheetSetCellValuePermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteMenuItemFactory,"PasteMenuItemFactory");const PASTE_SPECIAL_MENU_ID="sheet.menu.paste-special";function PasteSpacialMenuItemFactory(accessor){return{id:PASTE_SPECIAL_MENU_ID,type:ui.MenuItemType.SUBITEMS,icon:"PasteSpecial",title:"rightClick.pasteSpecial",hidden$:getObservableWithExclusiveRange$(accessor,ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET))}}__name(PasteSpacialMenuItemFactory,"PasteSpacialMenuItemFactory");function PasteValueMenuItemFactory(accessor){return{id:SheetPasteValueCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteValue",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellValuePermission,sheets.WorksheetEditPermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteValueMenuItemFactory,"PasteValueMenuItemFactory");function PasteFormatMenuItemFactory(accessor){return{id:SheetPasteFormatCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteFormat",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetCellStylePermission,sheets.WorksheetEditPermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteFormatMenuItemFactory,"PasteFormatMenuItemFactory");function PasteColWidthMenuItemFactory(accessor){return{id:SheetPasteColWidthCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteColWidth",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetSetColumnStylePermission,sheets.WorksheetEditPermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2))}}__name(PasteColWidthMenuItemFactory,"PasteColWidthMenuItemFactory");function PasteBesidesBorderMenuItemFactory(accessor){return{id:SheetPasteBesidesBorderCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.pasteBesidesBorder",disabled$:menuClipboardDisabledObservable(accessor).pipe(rxjs.combineLatestWith(getCurrentRangeDisable$(accessor,{rangeTypes:[sheets.RangeProtectionPermissionEditPoint],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellStylePermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetRowStylePermission,sheets.WorksheetSetColumnStylePermission],workbookTypes:[sheets.WorkbookEditablePermission]})),rxjs.map(([d1,d2])=>d1||d2)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(PasteBesidesBorderMenuItemFactory,"PasteBesidesBorderMenuItemFactory");function FitContentMenuItemFactory(accessor){return{id:sheets.SetWorksheetRowIsAutoHeightCommand.id,type:ui.MenuItemType.BUTTON,icon:"AutoHeight",title:"rightClick.fitContent",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetSetRowStylePermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FitContentMenuItemFactory,"FitContentMenuItemFactory");const SHEET_FROZEN_MENU_ID="sheet.menu.sheet-frozen";function SheetFrozenMenuItemFactory(accessor){return{id:SHEET_FROZEN_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.freeze",icon:"FreezeToSelectedSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(SheetFrozenMenuItemFactory,"SheetFrozenMenuItemFactory");const SHEET_FROZEN_HEADER_MENU_ID="sheet.header-menu.sheet-frozen";function SheetFrozenHeaderMenuItemFactory(accessor){return{id:SHEET_FROZEN_HEADER_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.freeze",icon:"FreezeToSelectedSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(SheetFrozenHeaderMenuItemFactory,"SheetFrozenHeaderMenuItemFactory");function FrozenMenuItemFactory(accessor){return{id:SetSelectionFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.freeze",icon:"FreezeToSelectedSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FrozenMenuItemFactory,"FrozenMenuItemFactory");function FrozenRowMenuItemFactory(accessor){return{id:SetRowFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.freezeRow",icon:"FreezeRowSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FrozenRowMenuItemFactory,"FrozenRowMenuItemFactory");function FrozenColMenuItemFactory(accessor){return{id:SetColumnFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.freezeCol",icon:"FreezeColumnSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(FrozenColMenuItemFactory,"FrozenColMenuItemFactory");function CancelFrozenMenuItemFactory(accessor){return{id:CancelFrozenCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.cancelFreeze",icon:"CancelFreezeSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CancelFrozenMenuItemFactory,"CancelFrozenMenuItemFactory");function HideRowMenuItemFactory(accessor){return{id:HideRowConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"Hide",title:"rightClick.hideSelectedRow",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetSetRowStylePermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(HideRowMenuItemFactory,"HideRowMenuItemFactory");function HideColMenuItemFactory(accessor){return{id:HideColConfirmCommand.id,type:ui.MenuItemType.BUTTON,icon:"Hide",title:"rightClick.hideSelectedColumn",disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(HideColMenuItemFactory,"HideColMenuItemFactory");function ShowRowMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),affectedCommands=[sheets.SetSelectionsOperation,sheets.SetRowHiddenMutation,sheets.SetRowVisibleMutation].map(c=>c.id);return{id:sheets.SetSelectedRowsVisibleCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.showHideRow",hidden$:deriveStateFromActiveSheet$(univerInstanceService,!0,({worksheet})=>new rxjs.Observable(subscriber=>{function hasHiddenRowsInSelections(){var _a58;const rowRanges=(_a58=selectionManagerService.getCurrentSelections())==null?void 0:_a58.map(s=>s.range).filter(r2=>r2.rangeType===core.RANGE_TYPE.ROW);return!!(rowRanges!=null&&rowRanges.some(range=>{for(let r2=range.startRow;r2<=range.endRow;r2++)if(!worksheet.getRowRawVisible(r2))return!0;return!1}))}__name(hasHiddenRowsInSelections,"hasHiddenRowsInSelections");const disposable=commandService.onCommandExecuted(command=>{affectedCommands.findIndex(c=>c===command.id)!==-1&&subscriber.next(!hasHiddenRowsInSelections())});return subscriber.next(!hasHiddenRowsInSelections()),()=>disposable.dispose()})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(ShowRowMenuItemFactory,"ShowRowMenuItemFactory");function ShowColMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),commandService=accessor.get(core.ICommandService),affectedCommands=[sheets.SetSelectionsOperation,sheets.SetColHiddenMutation,sheets.SetColVisibleMutation].map(c=>c.id);return{id:sheets.SetSelectedColsVisibleCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.showHideColumn",hidden$:deriveStateFromActiveSheet$(univerInstanceService,!0,({worksheet})=>new rxjs.Observable(subscriber=>{function hasHiddenColsInSelections(){var _a58;const colRanges=(_a58=selectionManagerService.getCurrentSelections())==null?void 0:_a58.map(s=>s.range).filter(r2=>r2.rangeType===core.RANGE_TYPE.COLUMN);return!colRanges||colRanges.length===0?!1:!!colRanges.some(range=>{for(let r2=range.startColumn;r2<=range.endColumn;r2++)if(!worksheet.getColVisible(r2))return!0;return!1})}__name(hasHiddenColsInSelections,"hasHiddenColsInSelections");const disposable=commandService.onCommandExecuted(commandInfo=>{affectedCommands.findIndex(c=>c===commandInfo.id)!==-1&&subscriber.next(!hasHiddenColsInSelections())});return subscriber.next(!hasHiddenColsInSelections()),()=>disposable.dispose()})),disabled$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetSetColumnStylePermission,sheets.WorksheetEditPermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(ShowColMenuItemFactory,"ShowColMenuItemFactory");function SetRowHeightMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=0;return{id:sheets.SetRowHeightCommand.id,type:ui.MenuItemType.BUTTON,icon:"AdjustHeight",label:{name:MENU_ITEM_INPUT_COMPONENT,props:{prefix:"rightClick.rowHeight",suffix:"px",min:2,max:1e3}},value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{function update(){var _a58;const primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary,rowHeight=primary?worksheet.getRowHeight(primary.startRow):defaultValue;subscriber.next(rowHeight)}__name(update,"update");const disposable=commandService.onCommandExecuted(c=>{const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetRowIsAutoHeightMutation.id)return update()});return update(),disposable.dispose})),hidden$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetRowStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(SetRowHeightMenuItemFactory,"SetRowHeightMenuItemFactory");function SetColWidthMenuItemFactory(accessor){const commandService=accessor.get(core.ICommandService),univerInstanceService=accessor.get(core.IUniverInstanceService),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),defaultValue=0;return{id:sheets.SetColWidthCommand.id,type:ui.MenuItemType.BUTTON,icon:"AdjustWidth",label:{name:MENU_ITEM_INPUT_COMPONENT,props:{prefix:"rightClick.columnWidth",suffix:"px",min:2,max:1e3}},value$:deriveStateFromActiveSheet$(univerInstanceService,defaultValue,({worksheet})=>new rxjs.Observable(subscriber=>{function update(){var _a58;const primary=(_a58=selectionManagerService.getCurrentLastSelection())==null?void 0:_a58.primary;let colWidth=defaultValue;primary!=null&&(colWidth=worksheet.getColumnWidth(primary.startColumn)),subscriber.next(colWidth)}__name(update,"update");const disposable=commandService.onCommandExecuted(c=>{const id=c.id;if(id===sheets.SetRangeValuesMutation.id||id===sheets.SetSelectionsOperation.id||id===sheets.SetWorksheetColWidthMutation.id)return update()});return update(),disposable.dispose})),hidden$:getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetColumnStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]})}}__name(SetColWidthMenuItemFactory,"SetColWidthMenuItemFactory");function getFontStyleAtCursor(accessor){var _a58;const univerInstanceService=accessor.get(core.IUniverInstanceService),textSelectionService=accessor.get(docs.DocSelectionManagerService),editorDataModel=univerInstanceService.getUniverDocInstance(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY),activeTextRange=textSelectionService.getActiveTextRange();if(editorDataModel==null||activeTextRange==null)return null;const textRuns=(_a58=editorDataModel.getBody())==null?void 0:_a58.textRuns;if(textRuns==null)return;const{startOffset}=activeTextRange;return textRuns.find(({st,ed})=>startOffset>=st&&startOffset<=ed)}__name(getFontStyleAtCursor,"getFontStyleAtCursor");function getSheetSelectionsDisabled$(accessor){const selectionManagerService=accessor.get(sheets.SheetsSelectionsService),rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),univerInstanceService=accessor.get(core.IUniverInstanceService),mergeCellController=accessor.get(sheets.MergeCellController),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET);return rxjs.combineLatest([selectionManagerService.selectionMoveEnd$,workbook$.pipe(rxjs.map(workbook=>{var _a58;return(_a58=workbook==null?void 0:workbook.getUnitId())!=null?_a58:""})),workbook$.pipe(rxjs.switchMap(workbook=>{var _a58;return(_a58=workbook==null?void 0:workbook.activeSheet$)!=null?_a58:rxjs.of(null)}))]).pipe(rxjs.map(([selection,unitId,sheet])=>{if(!sheet||!selection||selection.length===0)return!1;const subUnitId=sheet.getSheetId(),selectionRanges=selection.map(sel=>sel.range);if(mergeCellController.interceptor.fetchThroughInterceptors(sheets.MERGE_CELL_INTERCEPTOR_CHECK)(!1,selectionRanges))return!0;const subUnitRuleRange=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).map(rule=>rule.ranges).flat();if(selection.length<2){const range=selection[0].range;return subUnitRuleRange.some(ruleRange=>core.Rectangle.intersects(ruleRange,range)&&!core.Rectangle.contains(ruleRange,range))}for(let i=0;i<selection.length;i++)for(let j=i+1;j<selection.length;j++)if(core.Rectangle.intersects(selection[i].range,selection[j].range))return!0;return!1}))}__name(getSheetSelectionsDisabled$,"getSheetSelectionsDisabled$");function isThisRowSelected(selections,rowIndex){return!!matchedSelectionByRowColIndex(selections,rowIndex,core.RANGE_TYPE.ROW)}__name(isThisRowSelected,"isThisRowSelected");function isThisColSelected(selections,colIndex){return!!matchedSelectionByRowColIndex(selections,colIndex,core.RANGE_TYPE.COLUMN)}__name(isThisColSelected,"isThisColSelected");function matchedSelectionByRowColIndex(selections,indexOfRowCol,rowOrCol){return selections.find(sel=>{const range=sel.range,{startRow:startRowOfCurrSel,endRow:endRowOfCurrSel,startColumn:startColumnOfCurrSel,endColumn:endColumnOfCurrSel,rangeType:rangeTypeOfCurrSelection}=range;return rangeTypeOfCurrSelection===core.RANGE_TYPE.ALL||rangeTypeOfCurrSelection===core.RANGE_TYPE.NORMAL?!1:rangeTypeOfCurrSelection===rowOrCol&&(rowOrCol===core.RANGE_TYPE.COLUMN&&startColumnOfCurrSel<=indexOfRowCol&&indexOfRowCol<=endColumnOfCurrSel||rowOrCol===core.RANGE_TYPE.ROW&&startRowOfCurrSel<=indexOfRowCol&&indexOfRowCol<=endRowOfCurrSel)})}__name(matchedSelectionByRowColIndex,"matchedSelectionByRowColIndex");function CellMergeMenuItemFactory(accessor){const editDisabled$=getCurrentRangeDisable$(accessor,{workbookTypes:[sheets.WorkbookEditablePermission],worksheetTypes:[sheets.WorksheetEditPermission,sheets.WorksheetSetCellValuePermission,sheets.WorksheetSetCellStylePermission],rangeTypes:[sheets.RangeProtectionPermissionEditPoint]}),selectionsHasCross$=getSheetSelectionsDisabled$(accessor);return{id:AddWorksheetMergeCommand.id,icon:"MergeAllSingle",tooltip:"toolbar.mergeCell.main",type:ui.MenuItemType.SUBITEMS,hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:editDisabled$.pipe(rxjs.combineLatestWith(selectionsHasCross$),rxjs.map(([disable,hasCross])=>disable||hasCross))}}__name(CellMergeMenuItemFactory,"CellMergeMenuItemFactory");function CellMergeAllMenuItemFactory(accessor){return{id:AddWorksheetMergeAllCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.all",icon:"MergeAllSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeAllMenuItemFactory,"CellMergeAllMenuItemFactory");function CellMergeVerticalMenuItemFactory(accessor){return{id:AddWorksheetMergeVerticalCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.vertical",icon:"VerticalIntegrationSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeVerticalMenuItemFactory,"CellMergeVerticalMenuItemFactory");function CellMergeHorizontalMenuItemFactory(accessor){return{id:AddWorksheetMergeHorizontalCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.horizontal",icon:"HorizontalMergeSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeHorizontalMenuItemFactory,"CellMergeHorizontalMenuItemFactory");function CellMergeCancelMenuItemFactory(accessor){return{id:sheets.RemoveWorksheetMergeCommand.id,type:ui.MenuItemType.BUTTON,title:"merge.cancel",icon:"CancelMergeSingle",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CellMergeCancelMenuItemFactory,"CellMergeCancelMenuItemFactory");function getAddPermissionHidden$(accessor){const workbook$=accessor.get(core.IUniverInstanceService).getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{if(!worksheet)return rxjs.of(!0);const rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,rangeProtectionRuleModel.ruleChange$,worksheetRuleModel.ruleChange$).pipe(rxjs.map(()=>{const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),subUnitRuleList=rangeProtectionRuleModel.getSubunitRuleList(unitId,subUnitId),selections=selectionManagerService.getCurrentSelections(),selectionsRanges=selections==null?void 0:selections.map(selection=>selection.range),ruleRanges=subUnitRuleList.map(rule=>rule.ranges).flat();if(!selectionsRanges)return!1;const worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId);return worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)?!0:selectionsRanges==null?void 0:selectionsRanges.some(selectionRange=>ruleRanges.some(ruleRange=>core.Rectangle.intersects(selectionRange,ruleRange)))}))})):rxjs.of(!0)))}__name(getAddPermissionHidden$,"getAddPermissionHidden$");function getEditPermissionHidden$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),rangeRuleModel=accessor.get(sheets.RangeProtectionRuleModel),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{if(!worksheet)return rxjs.of(!0);const rangeProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionManagerService=accessor.get(sheets.SheetsSelectionsService);return rxjs.merge(selectionManagerService.selectionMoveEnd$,rangeProtectionRuleModel.ruleChange$,worksheetRuleModel.ruleChange$).pipe(rxjs.map(()=>{var _a58;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),subUnitRuleList=rangeRuleModel.getSubunitRuleList(unitId,subUnitId),selectionRanges=(_a58=selectionManagerService.getCurrentSelections())==null?void 0:_a58.map(selection=>selection.range),ruleRanges=subUnitRuleList.map(rule=>rule.ranges).flat();if(!(selectionRanges!=null&&selectionRanges.length)||selectionRanges.length>1)return!0;const selectedRange=selectionRanges[0],worksheetRule=worksheetRuleModel.getRule(unitId,subUnitId);return worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)?!1:ruleRanges.filter(ruleRange=>core.Rectangle.intersects(ruleRange,selectedRange)).length!==1}))})):rxjs.of(!0)))}__name(getEditPermissionHidden$,"getEditPermissionHidden$");function getPermissionDisableBase$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),ruleChange$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$).pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,ruleChange$,selectionManagerService.selectionMoveEnd$]).pipe(rxjs.map(([permission,_2,__])=>{if(!permission)return!0;const selections=selectionManagerService.getCurrentSelections(),selectionRanges=selections==null?void 0:selections.map(selection=>selection.range);return selectionRanges!=null&&selectionRanges.length?selectionRanges.length>1:!1}))})):rxjs.of(!0)))}__name(getPermissionDisableBase$,"getPermissionDisableBase$");function getAddPermissionDisableBase$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const focusingDrawing$=accessor.get(core.IContextService).subscribeContextValue$(core.FOCUSING_COMMON_DRAWINGS).pipe(rxjs.startWith(!1)),unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),selectionManagerService=accessor.get(sheets.SheetsSelectionsService),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),ruleChange$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$).pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,ruleChange$,selectionManagerService.selectionMoveEnd$,focusingDrawing$]).pipe(rxjs.map(([permission,_2,__,focus])=>{if(!permission||focus)return!0;const selections=selectionManagerService.getCurrentSelections(),selectionRanges=selections==null?void 0:selections.map(selection=>selection.range);if(!(selectionRanges!=null&&selectionRanges.length))return!0;const worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);if(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name))return!0;const subunitRuleList=selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId);return selectionRanges==null?void 0:selectionRanges.some(selectionRange=>subunitRuleList.some(rule=>rule.ranges.some(ruleRange=>core.Rectangle.intersects(selectionRange,ruleRange))))}))})):rxjs.of(!0)))}__name(getAddPermissionDisableBase$,"getAddPermissionDisableBase$");function getAddPermissionFromSheetBarDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),ruleChange$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$).pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,ruleChange$]).pipe(rxjs.map(([permission,_2])=>{var _a59;if(!permission)return!0;const worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)?!0:((_a59=selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId))==null?void 0:_a59.filter(item=>(item==null?void 0:item.permissionId)&&(item==null?void 0:item.name))).length>0}))})):rxjs.of(!0)))}__name(getAddPermissionFromSheetBarDisable$,"getAddPermissionFromSheetBarDisable$");function getRemovePermissionFromSheetBarDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1);return rxjs.combineLatest([permission$,worksheetProtectionRuleModel.ruleChange$.pipe(rxjs.startWith(null))]).pipe(rxjs.map(([permission,_2])=>{if(!permission)return!0;const worksheetPermissionRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return!(worksheetPermissionRule!=null&&worksheetPermissionRule.permissionId&&(worksheetPermissionRule!=null&&worksheetPermissionRule.name))}))})):rxjs.of(!0)))}__name(getRemovePermissionFromSheetBarDisable$,"getRemovePermissionFromSheetBarDisable$");function getSetPermissionFromSheetBarDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),worksheetRuleChange$=worksheetProtectionRuleModel.ruleChange$.pipe(rxjs.startWith(null)),selectionRuleChange$=selectionProtectionRuleModel.ruleChange$.pipe(rxjs.startWith(null));return rxjs.combineLatest([permission$,worksheetRuleChange$,selectionRuleChange$]).pipe(rxjs.map(([permission,_2,__])=>{if(!permission)return!0;const subUnitId=worksheet.getSheetId(),worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId),selectionRuleList=selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId);return!(worksheetRule||selectionRuleList.length)}))})):rxjs.of(!0)))}__name(getSetPermissionFromSheetBarDisable$,"getSetPermissionFromSheetBarDisable$");function getRemovePermissionDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),sheetSelectionsService=accessor.get(sheets.SheetsSelectionsService),selectionProtectionRuleModel=accessor.get(sheets.RangeProtectionRuleModel),worksheetProtectionRuleModel=accessor.get(sheets.WorksheetProtectionRuleModel),permission$=(_a58=permissionService.composePermission$([new sheets.WorkbookManageCollaboratorPermission(unitId).id,new sheets.WorkbookEditablePermission(unitId).id]).pipe(rxjs.map(permissions=>permissions.every(permission=>permission.value))))!=null?_a58:rxjs.of(!1),changes$=rxjs.merge(selectionProtectionRuleModel.ruleChange$,worksheetProtectionRuleModel.ruleChange$,sheetSelectionsService.selectionMoveEnd$).pipe(rxjs.startWith(null));return rxjs.combineLatest([changes$,permission$]).pipe(rxjs.map(([_2,permission])=>{if(!permission)return!0;const selections=accessor.get(sheets.SheetsSelectionsService).getCurrentSelections(),selectionRanges=selections==null?void 0:selections.map(selection=>selection.range);if(!(selectionRanges!=null&&selectionRanges.length)||selectionRanges.length>1)return!0;const selectionRange=selectionRanges[0],worksheetRule=worksheetProtectionRuleModel.getRule(unitId,subUnitId);return!(worksheetRule!=null&&worksheetRule.permissionId&&(worksheetRule!=null&&worksheetRule.name)||selectionProtectionRuleModel.getSubunitRuleList(unitId,subUnitId).map(rule=>rule.ranges).flat().some(ruleRange=>core.Rectangle.intersects(selectionRange,ruleRange)))}))})):rxjs.of(!0)))}__name(getRemovePermissionDisable$,"getRemovePermissionDisable$");function getViewPermissionDisable$(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),permissionService=accessor.get(core.IPermissionService),workbook$=univerInstanceService.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET),userManagerService=accessor.get(core.UserManagerService);return rxjs.combineLatest([workbook$,userManagerService.currentUser$]).pipe(rxjs.switchMap(([workbook,_])=>workbook?workbook.activeSheet$.pipe(rxjs.switchMap(worksheet=>{var _a58,_b;if(!worksheet)return rxjs.of(!0);const unitId=workbook.getUnitId();return((_b=(_a58=permissionService.getPermissionPoint$(new sheets.WorkbookEditablePermission(unitId).id))==null?void 0:_a58.pipe(rxjs.map(e=>!!e.value)))!=null?_b:rxjs.of(!1)).pipe(rxjs.map(permission=>!permission))})):rxjs.of(!0)))}__name(getViewPermissionDisable$,"getViewPermissionDisable$");const SHEET_PERMISSION_CONTEXT_MENU_ID="sheet.contextMenu.permission";function sheetPermissionToolbarMenuFactory(accessor){return{id:AddRangeProtectionFromToolbarCommand.id,type:ui.MenuItemType.BUTTON,icon:permissionMenuIconKey,tooltip:"permission.toolbarMenu",hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET),disabled$:getAddPermissionDisableBase$(accessor)}}__name(sheetPermissionToolbarMenuFactory,"sheetPermissionToolbarMenuFactory");function sheetPermissionContextMenuFactory(accessor){return{id:SHEET_PERMISSION_CONTEXT_MENU_ID,type:ui.MenuItemType.SUBITEMS,title:"rightClick.protectRange",icon:permissionLockIconKey,hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionContextMenuFactory,"sheetPermissionContextMenuFactory");function sheetPermissionAddProtectContextMenuFactory(accessor){return{id:AddRangeProtectionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.turnOnProtectRange",hidden$:getAddPermissionHidden$(accessor),disabled$:getAddPermissionDisableBase$(accessor)}}__name(sheetPermissionAddProtectContextMenuFactory,"sheetPermissionAddProtectContextMenuFactory");function sheetPermissionEditProtectContextMenuFactory(accessor){return{id:SetRangeProtectionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.editProtectRange",hidden$:getEditPermissionHidden$(accessor),disabled$:getPermissionDisableBase$(accessor)}}__name(sheetPermissionEditProtectContextMenuFactory,"sheetPermissionEditProtectContextMenuFactory");function sheetPermissionRemoveProtectContextMenuFactory(accessor){return{id:DeleteRangeProtectionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.removeProtectRange",disabled$:getRemovePermissionDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionRemoveProtectContextMenuFactory,"sheetPermissionRemoveProtectContextMenuFactory");function sheetPermissionViewAllProtectRuleContextMenuFactory(accessor){return{id:ViewSheetPermissionFromContextMenuCommand.id,type:ui.MenuItemType.BUTTON,title:"rightClick.viewAllProtectArea",disabled$:getViewPermissionDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionViewAllProtectRuleContextMenuFactory,"sheetPermissionViewAllProtectRuleContextMenuFactory");function sheetPermissionProtectSheetInSheetBarMenuFactory(accessor){return{id:AddRangeProtectionFromSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.addProtectSheet",disabled$:getAddPermissionFromSheetBarDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionProtectSheetInSheetBarMenuFactory,"sheetPermissionProtectSheetInSheetBarMenuFactory");function sheetPermissionRemoveProtectionSheetBarMenuFactory(accessor){return{id:DeleteWorksheetProtectionFormSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.removeProtectSheet",disabled$:getRemovePermissionFromSheetBarDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionRemoveProtectionSheetBarMenuFactory,"sheetPermissionRemoveProtectionSheetBarMenuFactory");function sheetPermissionChangeSheetPermissionSheetBarMenuFactory(accessor){return{id:ChangeSheetProtectionFromSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.changeSheetPermission",disabled$:getSetPermissionFromSheetBarDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionChangeSheetPermissionSheetBarMenuFactory,"sheetPermissionChangeSheetPermissionSheetBarMenuFactory");function sheetPermissionViewAllProtectRuleSheetBarMenuFactory(accessor){return{id:ViewSheetPermissionFromSheetBarCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.viewAllProtectArea",disabled$:getViewPermissionDisable$(accessor),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(sheetPermissionViewAllProtectRuleSheetBarMenuFactory,"sheetPermissionViewAllProtectRuleSheetBarMenuFactory");function DeleteSheetMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService),defaultDisable$=new rxjs.Observable(subscriber=>{const disposable=commandService.onCommandExecuted(c=>{const id=c.id;(id===sheets.RemoveSheetMutation.id||id===sheets.InsertSheetMutation.id||id===sheets.SetWorksheetHideMutation.id)&&disableFunction(univerInstanceService,subscriber)});return disableFunction(univerInstanceService,subscriber),disposable.dispose}),permissionDisable$=getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookDeleteSheetPermission]);return{id:RemoveSheetConfirmCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.delete",disabled$:rxjs.combineLatest([defaultDisable$,permissionDisable$]).pipe(rxjs.map(([defaultDisabled,permissionDisabled])=>defaultDisabled||permissionDisabled)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(DeleteSheetMenuItemFactory,"DeleteSheetMenuItemFactory");function CopySheetMenuItemFactory(accessor){return{id:sheets.CopySheetCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.copy",disabled$:getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookCreateSheetPermission]),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(CopySheetMenuItemFactory,"CopySheetMenuItemFactory");function RenameSheetMenuItemFactory(accessor){return{id:RenameSheetOperation.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.rename",disabled$:getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookRenameSheetPermission]),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(RenameSheetMenuItemFactory,"RenameSheetMenuItemFactory");function ChangeColorSheetMenuItemFactory(accessor){return{id:sheets.SetTabColorCommand.id,title:"sheetConfig.changeColor",type:ui.MenuItemType.SELECTOR,selections:[{label:{name:COLOR_PICKER_COMPONENT,hoverable:!1}}],hidden$:getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission])}}__name(ChangeColorSheetMenuItemFactory,"ChangeColorSheetMenuItemFactory");function HideSheetMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService);return{id:sheets.SetWorksheetHideCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.hide",disabled$:new rxjs.Observable(subscriber=>{const disposable=commandService.onCommandExecuted(c=>{const id=c.id;(id===sheets.RemoveSheetMutation.id||id===sheets.InsertSheetMutation.id||id===sheets.SetWorksheetHideMutation.id)&&disableFunction(univerInstanceService,subscriber)});return disableFunction(univerInstanceService,subscriber),disposable.dispose}).pipe(rxjs.combineLatestWith(getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookHideSheetPermission])),rxjs.map(([defaultDisabled,permissionDisabled])=>defaultDisabled||permissionDisabled)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(HideSheetMenuItemFactory,"HideSheetMenuItemFactory");function ShowMenuItemFactory(accessor){const univerInstanceService=accessor.get(core.IUniverInstanceService),commandService=accessor.get(core.ICommandService);return{id:ShowMenuListCommand.id,type:ui.MenuItemType.BUTTON,title:"sheetConfig.unhide",disabled$:new rxjs.Observable(subscriber=>{function disableFunction2(){const worksheets=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getWorksheets(),visibleSheets=Array.from(worksheets.values());subscriber.next(visibleSheets.length===1)}__name(disableFunction2,"disableFunction2");const disposable=commandService.onCommandExecuted(c=>{const id=c.id;(id===sheets.RemoveSheetMutation.id||id===sheets.InsertSheetMutation.id||id===sheets.SetWorksheetHideMutation.id)&&disableFunction2()});return disableFunction2(),disposable.dispose}).pipe(rxjs.combineLatestWith(getWorkbookPermissionDisable$(accessor,[sheets.WorkbookEditablePermission,sheets.WorkbookHideSheetPermission])),rxjs.map(([defaultDisabled,permissionDisabled])=>defaultDisabled||permissionDisabled)),hidden$:ui.getMenuHiddenObservable(accessor,core.UniverInstanceType.UNIVER_SHEET)}}__name(ShowMenuItemFactory,"ShowMenuItemFactory");function disableFunction(univerInstanceService,subscriber){const worksheets=univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET).getWorksheets(),visibleSheets=Array.from(worksheets.values()).filter(sheet=>sheet.getConfig().hidden===core.BooleanNumber.FALSE);subscriber.next(visibleSheets.length===1)}__name(disableFunction,"disableFunction");const menuSchema$1={[ui.RibbonStartGroup.FORMAT]:{[SetOnceFormatPainterCommand.id]:{order:0,menuItemFactory:FormatPainterMenuItemFactory},[SetRangeBoldCommand.id]:{order:1,menuItemFactory:BoldMenuItemFactory},[SetRangeItalicCommand.id]:{order:2,menuItemFactory:ItalicMenuItemFactory},[SetRangeUnderlineCommand.id]:{order:3,menuItemFactory:UnderlineMenuItemFactory},[SetRangeStrickThroughCommand.id]:{order:4,menuItemFactory:StrikeThroughMenuItemFactory},[SetRangeFontFamilyCommand.id]:{order:5,menuItemFactory:FontFamilySelectorMenuItemFactory},[SetRangeFontSizeCommand.id]:{order:6,menuItemFactory:FontSizeSelectorMenuItemFactory},[SetRangeTextColorCommand.id]:{order:7,menuItemFactory:TextColorSelectorMenuItemFactory,[sheets.ResetTextColorCommand.id]:{order:0,menuItemFactory:ResetTextColorMenuItemFactory}},[sheets.SetBackgroundColorCommand.id]:{order:9,menuItemFactory:BackgroundColorSelectorMenuItemFactory,[sheets.ResetBackgroundColorCommand.id]:{order:0,menuItemFactory:ResetBackgroundColorMenuItemFactory}},[sheets.SetBorderBasicCommand.id]:{order:10,menuItemFactory:CellBorderSelectorMenuItemFactory}},[ui.RibbonStartGroup.LAYOUT]:{[sheets.AddWorksheetMergeCommand.id]:{order:0,menuItemFactory:CellMergeMenuItemFactory,[sheets.AddWorksheetMergeAllCommand.id]:{order:0,menuItemFactory:CellMergeAllMenuItemFactory},[sheets.AddWorksheetMergeVerticalCommand.id]:{order:1,menuItemFactory:CellMergeVerticalMenuItemFactory},[sheets.AddWorksheetMergeHorizontalCommand.id]:{order:2,menuItemFactory:CellMergeHorizontalMenuItemFactory},[sheets.RemoveWorksheetMergeCommand.id]:{order:3,menuItemFactory:CellMergeCancelMenuItemFactory}},[sheets.SetHorizontalTextAlignCommand.id]:{order:1,menuItemFactory:HorizontalAlignMenuItemFactory},[sheets.SetVerticalTextAlignCommand.id]:{order:1,menuItemFactory:VerticalAlignMenuItemFactory},[sheets.SetTextWrapCommand.id]:{order:2,menuItemFactory:WrapTextMenuItemFactory},[sheets.SetTextRotationCommand.id]:{order:3,menuItemFactory:TextRotateMenuItemFactory}},[ui.RibbonStartGroup.OTHERS]:{[AddRangeProtectionFromToolbarCommand.id]:{order:0,menuItemFactory:sheetPermissionToolbarMenuFactory}},[ui.ContextMenuPosition.MAIN_AREA]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory},[SheetPasteCommand.name]:{order:2,menuItemFactory:PasteMenuItemFactory},[PASTE_SPECIAL_MENU_ID]:{order:3,menuItemFactory:PasteSpacialMenuItemFactory,[SheetPasteValueCommand.id]:{order:0,menuItemFactory:PasteValueMenuItemFactory},[SheetPasteFormatCommand.id]:{order:1,menuItemFactory:PasteFormatMenuItemFactory},[SheetPasteColWidthCommand.id]:{order:2,menuItemFactory:PasteColWidthMenuItemFactory},[SheetPasteBesidesBorderCommand.id]:{order:3,menuItemFactory:PasteBesidesBorderMenuItemFactory}},[CLEAR_SELECTION_MENU_ID]:{order:4,menuItemFactory:ClearSelectionMenuItemFactory,[sheets.ClearSelectionContentCommand.id]:{order:0,menuItemFactory:ClearSelectionContentMenuItemFactory},[sheets.ClearSelectionFormatCommand.id]:{order:1,menuItemFactory:ClearSelectionFormatMenuItemFactory},[sheets.ClearSelectionAllCommand.id]:{order:2,menuItemFactory:ClearSelectionAllMenuItemFactory}}},[ui.ContextMenuGroup.LAYOUT]:{order:1,[CELL_INSERT_MENU_ID]:{order:0,menuItemFactory:CellInsertMenuItemFactory,[sheets.InsertRowBeforeCommand.id]:{order:0,menuItemFactory:InsertRowBeforeMenuItemFactory},[sheets.InsertColBeforeCommand.id]:{order:1,menuItemFactory:InsertColBeforeMenuItemFactory},[InsertRangeMoveRightConfirmCommand.id]:{order:2,menuItemFactory:InsertRangeMoveRightMenuItemFactory},[InsertRangeMoveDownConfirmCommand.id]:{order:3,menuItemFactory:InsertRangeMoveDownMenuItemFactory}},[DELETE_RANGE_MENU_ID]:{order:0,menuItemFactory:DeleteRangeMenuItemFactory,[RemoveColConfirmCommand.id]:{order:0,menuItemFactory:RemoveColMenuItemFactory},[RemoveRowConfirmCommand.id]:{order:1,menuItemFactory:RemoveRowMenuItemFactory},[DeleteRangeMoveLeftConfirmCommand.id]:{order:2,menuItemFactory:DeleteRangeMoveLeftMenuItemFactory},[DeleteRangeMoveUpConfirmCommand.id]:{order:3,menuItemFactory:DeleteRangeMoveUpMenuItemFactory}},[SHEET_FROZEN_MENU_ID]:{order:2,menuItemFactory:SheetFrozenMenuItemFactory,[SetSelectionFrozenCommand.id]:{order:0,menuItemFactory:FrozenMenuItemFactory},[SetRowFrozenCommand.id]:{order:1,menuItemFactory:FrozenRowMenuItemFactory},[SetColumnFrozenCommand.id]:{order:2,menuItemFactory:FrozenColMenuItemFactory},[CancelFrozenCommand.id]:{order:3,menuItemFactory:CancelFrozenMenuItemFactory}},[SHEET_PERMISSION_CONTEXT_MENU_ID]:{order:3,menuItemFactory:sheetPermissionContextMenuFactory,[AddRangeProtectionFromContextMenuCommand.id]:{order:0,menuItemFactory:sheetPermissionAddProtectContextMenuFactory},[SetRangeProtectionFromContextMenuCommand.id]:{order:1,menuItemFactory:sheetPermissionEditProtectContextMenuFactory},[DeleteRangeProtectionFromContextMenuCommand.id]:{order:2,menuItemFactory:sheetPermissionRemoveProtectContextMenuFactory},[ViewSheetPermissionFromContextMenuCommand.id]:{order:3,menuItemFactory:sheetPermissionViewAllProtectRuleContextMenuFactory}}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.COL_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory},[SheetPasteCommand.name]:{order:2,menuItemFactory:PasteMenuItemFactory},[PASTE_SPECIAL_MENU_ID]:{order:3,menuItemFactory:PasteSpacialMenuItemFactory,[SheetPasteValueCommand.id]:{order:0,menuItemFactory:PasteValueMenuItemFactory},[SheetPasteFormatCommand.id]:{order:1,menuItemFactory:PasteFormatMenuItemFactory},[SheetPasteColWidthCommand.id]:{order:2,menuItemFactory:PasteColWidthMenuItemFactory},[SheetPasteBesidesBorderCommand.id]:{order:3,menuItemFactory:PasteBesidesBorderMenuItemFactory}},[CLEAR_SELECTION_MENU_ID]:{order:4,menuItemFactory:ClearSelectionMenuItemFactory,[sheets.ClearSelectionContentCommand.id]:{order:0,menuItemFactory:ClearSelectionContentMenuItemFactory},[sheets.ClearSelectionFormatCommand.id]:{order:1,menuItemFactory:ClearSelectionFormatMenuItemFactory},[sheets.ClearSelectionAllCommand.id]:{order:2,menuItemFactory:ClearSelectionAllMenuItemFactory}}},[ui.ContextMenuGroup.LAYOUT]:{order:1,[COL_INSERT_MENU_ID]:{order:0,menuItemFactory:ColInsertMenuItemFactory,[sheets.InsertColBeforeCommand.id]:{order:0,menuItemFactory:InsertColBeforeMenuItemFactory},[sheets.InsertColAfterCommand.id]:{order:1,menuItemFactory:InsertColAfterMenuItemFactory}},[HideColConfirmCommand.id]:{order:1,menuItemFactory:HideColMenuItemFactory},[sheets.SetSelectedColsVisibleCommand.id]:{order:2,menuItemFactory:ShowColMenuItemFactory},[RemoveColConfirmCommand.id]:{order:2,menuItemFactory:RemoveColMenuItemFactory},[sheets.SetColWidthCommand.id]:{order:3,menuItemFactory:SetColWidthMenuItemFactory},[SHEET_FROZEN_HEADER_MENU_ID]:{order:4,menuItemFactory:SheetFrozenHeaderMenuItemFactory,[SetSelectionFrozenCommand.id]:{order:0,menuItemFactory:FrozenMenuItemFactory},[CancelFrozenCommand.id]:{order:3,menuItemFactory:CancelFrozenMenuItemFactory}},[SHEET_PERMISSION_CONTEXT_MENU_ID]:{order:5,menuItemFactory:sheetPermissionContextMenuFactory,[AddRangeProtectionFromContextMenuCommand.id]:{order:0,menuItemFactory:sheetPermissionAddProtectContextMenuFactory},[SetRangeProtectionFromContextMenuCommand.id]:{order:1,menuItemFactory:sheetPermissionEditProtectContextMenuFactory},[DeleteRangeProtectionFromContextMenuCommand.id]:{order:2,menuItemFactory:sheetPermissionRemoveProtectContextMenuFactory},[ViewSheetPermissionFromContextMenuCommand.id]:{order:3,menuItemFactory:sheetPermissionViewAllProtectRuleContextMenuFactory}}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.ROW_HEADER]:{[ui.ContextMenuGroup.FORMAT]:{[SheetCopyCommand.name]:{order:0,menuItemFactory:CopyMenuItemFactory},[SheetPasteCommand.name]:{order:2,menuItemFactory:PasteMenuItemFactory},[PASTE_SPECIAL_MENU_ID]:{order:3,menuItemFactory:PasteSpacialMenuItemFactory,[SheetPasteValueCommand.id]:{order:0,menuItemFactory:PasteValueMenuItemFactory},[SheetPasteFormatCommand.id]:{order:1,menuItemFactory:PasteFormatMenuItemFactory},[SheetPasteColWidthCommand.id]:{order:2,menuItemFactory:PasteColWidthMenuItemFactory},[SheetPasteBesidesBorderCommand.id]:{order:3,menuItemFactory:PasteBesidesBorderMenuItemFactory}},[CLEAR_SELECTION_MENU_ID]:{order:4,menuItemFactory:ClearSelectionMenuItemFactory,[sheets.ClearSelectionContentCommand.id]:{order:0,menuItemFactory:ClearSelectionContentMenuItemFactory},[sheets.ClearSelectionFormatCommand.id]:{order:1,menuItemFactory:ClearSelectionFormatMenuItemFactory},[sheets.ClearSelectionAllCommand.id]:{order:2,menuItemFactory:ClearSelectionAllMenuItemFactory}}},[ui.ContextMenuGroup.LAYOUT]:{order:1,[ROW_INSERT_MENU_ID]:{order:0,menuItemFactory:RowInsertMenuItemFactory,[sheets.InsertRowBeforeCommand.id]:{order:0,menuItemFactory:InsertRowBeforeMenuItemFactory},[sheets.InsertRowAfterCommand.id]:{order:1,menuItemFactory:InsertRowAfterMenuItemFactory}},[RemoveRowConfirmCommand.id]:{order:1,menuItemFactory:RemoveRowMenuItemFactory},[HideRowConfirmCommand.id]:{order:2,menuItemFactory:HideRowMenuItemFactory},[sheets.SetSelectedRowsVisibleCommand.id]:{order:2,menuItemFactory:ShowRowMenuItemFactory},[sheets.SetRowHeightCommand.id]:{order:3,menuItemFactory:SetRowHeightMenuItemFactory},[sheets.SetWorksheetRowIsAutoHeightCommand.id]:{order:4,menuItemFactory:FitContentMenuItemFactory},[SHEET_FROZEN_HEADER_MENU_ID]:{order:5,menuItemFactory:SheetFrozenHeaderMenuItemFactory,[SetSelectionFrozenCommand.id]:{order:0,menuItemFactory:FrozenMenuItemFactory},[CancelFrozenCommand.id]:{order:3,menuItemFactory:CancelFrozenMenuItemFactory}},[SHEET_PERMISSION_CONTEXT_MENU_ID]:{order:6,menuItemFactory:sheetPermissionContextMenuFactory,[AddRangeProtectionFromContextMenuCommand.id]:{order:0,menuItemFactory:sheetPermissionAddProtectContextMenuFactory},[SetRangeProtectionFromContextMenuCommand.id]:{order:1,menuItemFactory:sheetPermissionEditProtectContextMenuFactory},[DeleteRangeProtectionFromContextMenuCommand.id]:{order:2,menuItemFactory:sheetPermissionRemoveProtectContextMenuFactory},[ViewSheetPermissionFromContextMenuCommand.id]:{order:3,menuItemFactory:sheetPermissionViewAllProtectRuleContextMenuFactory}}},[ui.ContextMenuGroup.DATA]:{order:2},[ui.ContextMenuGroup.OTHERS]:{order:3}},[ui.ContextMenuPosition.FOOTER_TABS]:{[ui.ContextMenuGroup.OTHERS]:{order:0,[RemoveSheetConfirmCommand.id]:{order:0,menuItemFactory:DeleteSheetMenuItemFactory},[sheets.CopySheetCommand.id]:{order:1,menuItemFactory:CopySheetMenuItemFactory},[RenameSheetOperation.id]:{order:2,menuItemFactory:RenameSheetMenuItemFactory},[sheets.SetTabColorCommand.id]:{order:3,menuItemFactory:ChangeColorSheetMenuItemFactory},[sheets.SetWorksheetHideCommand.id]:{order:4,menuItemFactory:HideSheetMenuItemFactory},[ShowMenuListCommand.id]:{order:6,menuItemFactory:ShowMenuItemFactory},[AddRangeProtectionFromSheetBarCommand.id]:{order:7,menuItemFactory:sheetPermissionProtectSheetInSheetBarMenuFactory},[DeleteWorksheetProtectionFormSheetBarCommand.id]:{order:8,menuItemFactory:sheetPermissionRemoveProtectionSheetBarMenuFactory},[ChangeSheetProtectionFromSheetBarCommand.id]:{order:9,menuItemFactory:sheetPermissionChangeSheetPermissionSheetBarMenuFactory},[ViewSheetPermissionFromSheetBarCommand.id]:{order:10,menuItemFactory:sheetPermissionViewAllProtectRuleSheetBarMenuFactory}}}},ARROW_SELECTION_KEYCODE_LIST=[ui.KeyCode.ARROW_DOWN,ui.KeyCode.ARROW_UP,ui.KeyCode.ARROW_LEFT,ui.KeyCode.ARROW_RIGHT],MOVE_SELECTION_KEYCODE_LIST=[ui.KeyCode.ENTER,ui.KeyCode.TAB,...ARROW_SELECTION_KEYCODE_LIST];function generateArrowSelectionShortCutItem(){const shortcutList=[];for(const keycode of ARROW_SELECTION_KEYCODE_LIST)shortcutList.push({id:SetCellEditVisibleArrowOperation.id,binding:keycode,preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,isShift:!1}}),shortcutList.push({id:SetCellEditVisibleArrowOperation.id,binding:keycode|ui.MetaKeys.SHIFT,preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode,isShift:!0}});return shortcutList}__name(generateArrowSelectionShortCutItem,"generateArrowSelectionShortCutItem");const StartEditWithF2Shortcut={id:SetCellEditVisibleWithF2Operation.id,binding:ui.KeyCode.F2,description:"shortcut.sheet.start-editing",group:"4_sheet-edit",preconditions:whenSheetEditorFocused,staticParameters:{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.F2}},EditorCursorEnterShortcut={id:SetCellEditVisibleOperation.id,binding:ui.KeyCode.ENTER,description:"shortcut.sheet.toggle-editing",group:"4_sheet-edit",preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.ENTER}},EditorCursorTabShortcut={id:SetCellEditVisibleOperation.id,binding:ui.KeyCode.TAB,preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.TAB}},EditorCursorEscShortcut={id:SetCellEditVisibleOperation.id,binding:ui.KeyCode.ESC,description:"shortcut.sheet.abort-editing",group:"4_sheet-edit",preconditions:__name(contextService=>whenEditorDidNotInputFormulaActivated(contextService),"preconditions"),staticParameters:{visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.ESC}},EditorBreakLineShortcut={id:docsUi.BreakLineCommand.id,description:"shortcut.sheet.break-line",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorActivated(contextService),"preconditions"),binding:ui.KeyCode.ENTER|ui.MetaKeys.ALT},EditorDeleteLeftShortcut={id:docsUi.DeleteLeftCommand.id,preconditions:__name(contextService=>whenEditorActivated(contextService)||whenFormulaEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.BACKSPACE},EditorDeleteLeftShortcutInActive={id:SetCellEditVisibleOperation.id,description:"shortcut.sheet.delete-and-start-editing",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService)&&!whenFormulaEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.BACKSPACE,staticParameters:{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.BACKSPACE}},SetRowHiddenShortcutItem={id:sheets.SetRowHiddenCommand.id,preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.Digit9|ui.MetaKeys.CTRL_COMMAND},SetColHiddenShortcutItem={id:sheets.SetColHiddenCommand.id,preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.Digit0|ui.MetaKeys.CTRL_COMMAND|ui.MetaKeys.SHIFT},MoveSelectionDownShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-below-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN}},MoveSelectionUpShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-up-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP}},MoveSelectionLeftShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-left-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT,priority:100,preconditions:whenSheetEditorFocusedAndFxNotFocused,staticParameters:{direction:core.Direction.LEFT}},MoveSelectionRightShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-right-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT,priority:100,preconditions:whenSheetEditorFocusedAndFxNotFocused,staticParameters:{direction:core.Direction.RIGHT}},MoveSelectionTabShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-next-cell",group:"3_sheet-view",binding:ui.KeyCode.TAB,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT,keycode:ui.KeyCode.TAB}},MoveSelectionTabLeftShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-previous-cell",group:"3_sheet-view",binding:ui.KeyCode.TAB|ui.MetaKeys.SHIFT,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT,keycode:ui.KeyCode.TAB}},MoveSelectionEnterShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-below-cell",group:"3_sheet-view",binding:ui.KeyCode.ENTER,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN,keycode:ui.KeyCode.ENTER}},MoveSelectionEnterUpShortcutItem={id:MoveSelectionEnterAndTabCommand.id,description:"shortcut.sheet.select-up-cell",group:"3_sheet-view",binding:ui.KeyCode.ENTER|ui.MetaKeys.SHIFT,priority:100,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP,keycode:ui.KeyCode.ENTER}},MoveSelectionEndDownShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-below-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN,jumpOver:JumpOver.moveGap}},MoveSelectionEndUpShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-up-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP,jumpOver:JumpOver.moveGap}},MoveSelectionEndLeftShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-left-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT,jumpOver:JumpOver.moveGap}},MoveSelectionEndRightShortcutItem={id:MoveSelectionCommand.id,description:"shortcut.sheet.select-right-value-cell",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT,jumpOver:JumpOver.moveGap}},ExpandSelectionDownShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-down",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN}},ExpandSelectionUpShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-up",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP}},ExpandSelectionLeftShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-left",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT}},ExpandSelectionRightShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-right",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT|ui.MetaKeys.SHIFT,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT}},ExpandSelectionEndDownShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-below-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_DOWN|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.DOWN,jumpOver:JumpOver.moveGap}},ExpandSelectionEndUpShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-up-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_UP|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.UP,jumpOver:JumpOver.moveGap}},ExpandSelectionEndLeftShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-left-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_LEFT|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.LEFT,jumpOver:JumpOver.moveGap}},ExpandSelectionEndRightShortcutItem={id:ExpandSelectionCommand.id,description:"shortcut.sheet.expand-selection-to-right-gap",group:"3_sheet-view",binding:ui.KeyCode.ARROW_RIGHT|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{direction:core.Direction.RIGHT,jumpOver:JumpOver.moveGap}},SelectAllShortcutItem={id:SelectAllCommand.id,description:"shortcut.sheet.select-all",group:"3_sheet-view",binding:ui.KeyCode.A|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,staticParameters:{expandToGapFirst:!0,loop:!0}},SetBoldShortcutItem={id:SetRangeBoldCommand.id,description:"shortcut.sheet.set-bold",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.B|ui.MetaKeys.CTRL_COMMAND},SetItalicShortcutItem={id:SetRangeItalicCommand.id,description:"shortcut.sheet.set-italic",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.I|ui.MetaKeys.CTRL_COMMAND},SetUnderlineShortcutItem={id:SetRangeUnderlineCommand.id,description:"shortcut.sheet.set-underline",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.U|ui.MetaKeys.CTRL_COMMAND},SetStrikeThroughShortcutItem={id:SetRangeStrickThroughCommand.id,description:"shortcut.sheet.set-strike-through",group:"4_sheet-edit",preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.X|ui.MetaKeys.SHIFT|ui.MetaKeys.CTRL_COMMAND},ClearSelectionValueShortcutItem={id:sheets.ClearSelectionContentCommand.id,preconditions:__name(contextService=>whenSheetEditorFocused(contextService),"preconditions"),binding:ui.KeyCode.DELETE,mac:ui.KeyCode.BACKSPACE},ZoomInShortcutItem={id:ChangeZoomRatioCommand.id,description:"shortcut.sheet.zoom-in",binding:ui.KeyCode.EQUAL|ui.MetaKeys.CTRL_COMMAND,group:"3_sheet-view",preconditions:whenSheetEditorFocused,priority:1,staticParameters:{delta:.2}},PreventDefaultZoomInShortcutItem={id:core.NilCommand.id,binding:ui.KeyCode.EQUAL|ui.MetaKeys.CTRL_COMMAND},ZoomOutShortcutItem={id:ChangeZoomRatioCommand.id,description:"shortcut.sheet.zoom-out",binding:ui.KeyCode.MINUS|ui.MetaKeys.CTRL_COMMAND,group:"3_sheet-view",preconditions:whenSheetEditorFocused,priority:1,staticParameters:{delta:-.2}},PreventDefaultZoomOutShortcutItem={id:core.NilCommand.id,binding:ui.KeyCode.MINUS|ui.MetaKeys.CTRL_COMMAND},ResetZoomShortcutItem={id:ChangeZoomRatioCommand.id,description:"shortcut.sheet.reset-zoom",binding:ui.KeyCode.Digit0|ui.MetaKeys.CTRL_COMMAND,preconditions:whenSheetEditorFocused,group:"3_sheet-view",priority:1,staticParameters:{reset:!0}},PreventDefaultResetZoomShortcutItem={id:core.NilCommand.id,binding:ui.KeyCode.Digit0|ui.MetaKeys.CTRL_COMMAND};var __defProp$E=Object.defineProperty,__getOwnPropDesc$E=Object.getOwnPropertyDescriptor,__decorateClass$E=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$E(target,key):target,i=decorators.length-1,decorator;i>=0;i--)(decorator=decorators[i])&&(result=(kind?decorator(target,key,result):decorator(result))||result);return kind&&result&&__defProp$E(target,key,result),result},"__decorateClass$E"),__decorateParam$E=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$E"),_a15;exports.SheetUIController=(_a15=class extends core.Disposable{constructor(_injector,_componentManager,_layoutService,_commandService,_shortcutService,_menuManagerService,_uiPartsService,_configService){super(),this._injector=_injector,this._componentManager=_componentManager,this._layoutService=_layoutService,this._commandService=_commandService,this._shortcutService=_shortcutService,this._menuManagerService=_menuManagerService,this._uiPartsService=_uiPartsService,this._configService=_configService,this._init()}_init(){this._initCustomComponents(),this._initCommands(),this._initMenus(),this._initShortcuts(),this._initWorkbenchParts(),this._initFocusHandler()}_initCustomComponents(){const componentManager=this._componentManager;this.disposeWithMe(componentManager.register(MENU_ITEM_INPUT_COMPONENT,MenuItemInput)),this.disposeWithMe(componentManager.register(BORDER_PANEL_COMPONENT,BorderPanel)),this.disposeWithMe(componentManager.register(COLOR_PICKER_COMPONENT,design.ColorPicker)),this.disposeWithMe(componentManager.register(FONT_FAMILY_COMPONENT,ui.FontFamily)),this.disposeWithMe(componentManager.register(FONT_FAMILY_ITEM_COMPONENT,ui.FontFamilyItem)),this.disposeWithMe(componentManager.register(FONT_SIZE_COMPONENT,ui.FontSize)),this.disposeWithMe(componentManager.register(DEFINED_NAME_CONTAINER,DefinedNameContainer))}_initCommands(){[AddWorksheetMergeAllCommand,AddWorksheetMergeCommand,AddWorksheetMergeHorizontalCommand,AddWorksheetMergeVerticalCommand,ChangeZoomRatioCommand,ExpandSelectionCommand,MoveSelectionCommand,MoveSelectionEnterAndTabCommand,RenameSheetOperation,RemoveSheetConfirmCommand,RemoveRowConfirmCommand,RemoveColConfirmCommand,HideRowConfirmCommand,HideColConfirmCommand,ScrollCommand,ScrollToCellCommand,SelectAllCommand,SetActivateCellEditOperation,sheets.SetBoldCommand,SetCellEditVisibleArrowOperation,SetCellEditVisibleOperation,SetCellEditVisibleWithF2Operation,SetRangeBoldCommand,SetRangeItalicCommand,SetRangeUnderlineCommand,SetRangeStrickThroughCommand,SetRangeSubscriptCommand,SetRangeSuperscriptCommand,SetRangeFontSizeCommand,SetRangeFontFamilyCommand,SetRangeTextColorCommand,sheets.SetItalicCommand,sheets.SetStrikeThroughCommand,sheets.SetFontFamilyCommand,sheets.SetFontSizeCommand,SetFormatPainterOperation,SetInfiniteFormatPainterCommand,SetOnceFormatPainterCommand,ApplyFormatPainterCommand,SetScrollOperation,SetScrollRelativeCommand,SetSelectionFrozenCommand,SetRowFrozenCommand,SetColumnFrozenCommand,ScrollToRangeOperation,CancelFrozenCommand,sheets.SetUnderlineCommand,SetZoomRatioCommand,SetZoomRatioOperation,ShowMenuListCommand,RefillCommand,InsertRangeMoveDownConfirmCommand,DeleteRangeMoveUpConfirmCommand,InsertRangeMoveRightConfirmCommand,DeleteRangeMoveLeftConfirmCommand,SidebarDefinedNameOperation,AutoFillCommand,AutoClearContentCommand,SheetPermissionOpenPanelOperation,SheetPermissionOpenDialogOperation,AddRangeProtectionFromToolbarCommand,AddRangeProtectionFromContextMenuCommand,ViewSheetPermissionFromContextMenuCommand,AddRangeProtectionFromSheetBarCommand,ViewSheetPermissionFromSheetBarCommand,ChangeSheetProtectionFromSheetBarCommand,DeleteRangeProtectionFromContextMenuCommand,SetRangeProtectionFromContextMenuCommand,AddWorksheetProtectionCommand,DeleteWorksheetProtectionCommand,SetWorksheetProtectionCommand,DeleteWorksheetProtectionFormSheetBarCommand,SetProtectionCommand].forEach(c=>{this.disposeWithMe(this._commandService.registerCommand(c))})}_initMenus(){this._menuManagerService.mergeMenu(menuSchema$1)}_initShortcuts(){[MoveSelectionDownShortcutItem,MoveSelectionUpShortcutItem,MoveSelectionLeftShortcutItem,MoveSelectionRightShortcutItem,MoveSelectionTabShortcutItem,MoveSelectionTabLeftShortcutItem,MoveSelectionEnterShortcutItem,MoveSelectionEnterUpShortcutItem,MoveSelectionEndDownShortcutItem,MoveSelectionEndUpShortcutItem,MoveSelectionEndLeftShortcutItem,MoveSelectionEndRightShortcutItem,ExpandSelectionDownShortcutItem,ExpandSelectionUpShortcutItem,ExpandSelectionLeftShortcutItem,ExpandSelectionRightShortcutItem,ExpandSelectionEndDownShortcutItem,ExpandSelectionEndUpShortcutItem,ExpandSelectionEndLeftShortcutItem,ExpandSelectionEndRightShortcutItem,SelectAllShortcutItem,ZoomInShortcutItem,ZoomOutShortcutItem,ResetZoomShortcutItem,PreventDefaultResetZoomShortcutItem,PreventDefaultZoomInShortcutItem,PreventDefaultZoomOutShortcutItem,SetBoldShortcutItem,SetItalicShortcutItem,SetUnderlineShortcutItem,SetStrikeThroughShortcutItem,ClearSelectionValueShortcutItem,...generateArrowSelectionShortCutItem(),EditorCursorEnterShortcut,StartEditWithF2Shortcut,EditorCursorTabShortcut,EditorBreakLineShortcut,EditorDeleteLeftShortcut,EditorDeleteLeftShortcutInActive,EditorCursorEscShortcut,SetRowHiddenShortcutItem,SetColHiddenShortcutItem].forEach(item=>{this.disposeWithMe(this._shortcutService.registerShortcut(item))})}_initWorkbenchParts(){const uiController=this._uiPartsService,injector=this._injector,config=this._configService.getConfig(PLUGIN_CONFIG_KEY);(config==null?void 0:config.formulaBar)!==!1&&this.disposeWithMe(uiController.registerComponent(ui.BuiltInUIPart.HEADER,()=>core.connectInjector(RenderSheetHeader,injector))),this.disposeWithMe(uiController.registerComponent(ui.BuiltInUIPart.FOOTER,()=>core.connectInjector(RenderSheetFooter,injector))),this.disposeWithMe(uiController.registerComponent(ui.BuiltInUIPart.CONTENT,()=>core.connectInjector(RenderSheetContent,injector)))}_initFocusHandler(){this.disposeWithMe(this._layoutService.registerFocusHandler(core.UniverInstanceType.UNIVER_SHEET,_unitId=>{const currentEditorRender=this._injector.get(engineRender.IRenderManagerService).getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC),docSelectionRenderService=currentEditorRender==null?void 0:currentEditorRender.with(docsUi.DocSelectionRenderService);docSelectionRenderService==null||docSelectionRenderService.focus()}))}},__name(_a15,"SheetUIController"),_a15);exports.SheetUIController=__decorateClass$E([__decorateParam$E(0,core.Inject(core.Injector)),__decorateParam$E(1,core.Inject(ui.ComponentManager)),__decorateParam$E(2,ui.ILayoutService),__decorateParam$E(3,core.ICommandService),__decorateParam$E(4,ui.IShortcutService),__decorateParam$E(5,ui.IMenuManagerService),__decorateParam$E(6,ui.IUIPartsService),__decorateParam$E(7,core.IConfigService)],exports.SheetUIController);function isForceString(str){return str.startsWith("'")}__name(isForceString,"isForceString");function extractStringFromForceString(str){return str.slice(1)}__name(extractStringFromForceString,"extractStringFromForceString");const fullWidthToHalfWidthMap={"0":"0","1":"1","2":"2","3":"3","4":"4","5":"5","6":"6","7":"7","8":"8","9":"9",A:"A",B:"B",C:"C",D:"D",E:"E",F:"F",G:"G",H:"H",I:"I",J:"J",K:"K",L:"L",M:"M",N:"N",O:"O",P:"P",Q:"Q",R:"R",S:"S",T:"T",U:"U",V:"V",W:"W",X:"X",Y:"Y",Z:"Z",a:"a",b:"b",c:"c",d:"d",e:"e",f:"f",g:"g",h:"h",i:"i",j:"j",k:"k",l:"l",m:"m",n:"n",o:"o",p:"p",q:"q",r:"r",s:"s",t:"t",u:"u",v:"v",w:"w",x:"x",y:"y",z:"z","%":"%","-":"-",".":".",":":":","/":"/","+":"+","@":"@","&":"&","*":"*","#":"#","=":"=",">":">","<":"<","$":"$",""":'"',"'":"'","(":"(",")":")"," ":" ",",":",","!":"!","?":"?",";":";","[":"[","]":"]","{":"{","}":"}"},booleanMap={true:"TRUE",false:"FALSE"};function isCJKLocale(locale){return[core.LocaleType.ZH_CN,core.LocaleType.ZH_TW].includes(locale)}__name(isCJKLocale,"isCJKLocale");function normalizeString(str,lexerTreeBuilder,currentLocale,functionService){let normalStr=str;if(isCJKLocale(currentLocale)){if(str.startsWith("'")||str.startsWith("'"))return`'${str.slice(1)}`;normalStr=str.split("").map(toHalfWidth).join("")}if(normalStr.startsWith("="))return normalizeFormulaString(str,normalStr,lexerTreeBuilder,functionService);const lowerCaseStr=normalStr.toLowerCase();return booleanMap[lowerCaseStr]?booleanMap[lowerCaseStr]:core.numfmt.parseValue(normalStr)==null?str:normalStr}__name(normalizeString,"normalizeString");function normalizeFormulaString(str,normalStr,lexerTreeBuilder,functionService){const nodes=lexerTreeBuilder.sequenceNodesBuilder(normalStr);if(!nodes)return str;let _normalStr=normalStr;return nodes.forEach((node,index)=>{if(typeof node=="object"){const token=node.token;if(booleanMap[token.toLowerCase()]){const startIndex=node.startIndex+1,endIndex=node.endIndex+2;_normalStr=replaceString(token.toLocaleUpperCase(),_normalStr,startIndex,endIndex)}else if(node.nodeType===engineFormula.sequenceNodeType.FUNCTION&&hasFunctionName(token,functionService,nodes,index)||node.nodeType===engineFormula.sequenceNodeType.REFERENCE){const sheetNameIndex=token.indexOf("!");if(sheetNameIndex>-1){const refBody=token.substring(sheetNameIndex+1),startIndex=node.startIndex+(sheetNameIndex+1)+1,endIndex=node.endIndex+2;_normalStr=replaceString(refBody.toLocaleUpperCase(),_normalStr,startIndex,endIndex)}else{const startIndex=node.startIndex+1,endIndex=node.endIndex+2;_normalStr=replaceString(token.toLocaleUpperCase(),_normalStr,startIndex,endIndex)}}else if(token.startsWith('"')&&token.endsWith('"')||token.startsWith("'")&&token.endsWith("'")){const startIndex=node.startIndex+2,endIndex=node.endIndex+1;_normalStr=replaceString(str.slice(startIndex,endIndex),_normalStr,startIndex,endIndex)}else if(node.nodeType!==engineFormula.sequenceNodeType.ARRAY&&core.numfmt.parseValue(token)==null){const startIndex=node.startIndex+1,endIndex=node.endIndex+2;_normalStr=replaceString(str.slice(startIndex,endIndex),_normalStr,startIndex,endIndex)}}}),_normalStr}__name(normalizeFormulaString,"normalizeFormulaString");function hasFunctionName(name,functionService,nodes,index){const functionList=functionService.getDescriptions();return nodes[index+1]!==engineFormula.matchToken.OPEN_BRACKET?!1:functionList.get(removeLeadingAtSymbols(name).toLocaleUpperCase())!==void 0}__name(hasFunctionName,"hasFunctionName");function removeLeadingAtSymbols(str){const regex=/^@+/;return str.replace(regex,"")}__name(removeLeadingAtSymbols,"removeLeadingAtSymbols");function toHalfWidth(char){return fullWidthToHalfWidthMap[char]||char}__name(toHalfWidth,"toHalfWidth");function replaceString(replacedString,normalStr,startIndex,endIndex){return normalStr.substring(0,startIndex)+replacedString+normalStr.substring(endIndex)}__name(replaceString,"replaceString");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 HIDDEN_EDITOR_POSITION=-1e3,EDITOR_INPUT_SELF_EXTEND_GAP=5,EDITOR_BORDER_SIZE=2;var _a16;exports.EditingRenderController=(_a16=class extends core.Disposable{constructor(_context,_layoutService,selectionManagerService,_undoRedoService,_contextService,_instanceSrv,_renderManagerService,_editorBridgeService,_cellEditorManagerService,_lexerTreeBuilder,_functionService,_textSelectionManagerService,_commandService,_localService,_editorService,_sheetSkeletonManagerService){super();__publicField(this,"_cursorChange",0);__publicField(this,"_isUnitEditing",!1);__publicField(this,"_workbookSelections");__publicField(this,"_d");__publicField(this,"_cursorTimeout");this._context=_context,this._layoutService=_layoutService,this._undoRedoService=_undoRedoService,this._contextService=_contextService,this._instanceSrv=_instanceSrv,this._renderManagerService=_renderManagerService,this._editorBridgeService=_editorBridgeService,this._cellEditorManagerService=_cellEditorManagerService,this._lexerTreeBuilder=_lexerTreeBuilder,this._functionService=_functionService,this._textSelectionManagerService=_textSelectionManagerService,this._commandService=_commandService,this._localService=_localService,this._editorService=_editorService,this._sheetSkeletonManagerService=_sheetSkeletonManagerService,this._workbookSelections=selectionManagerService.getWorkbookSelections(this._context.unitId),this.disposeWithMe(this._instanceSrv.getCurrentTypeOfUnit$(core.UniverInstanceType.UNIVER_SHEET).subscribe(workbook=>{(workbook==null?void 0:workbook.getUnitId())===this._context.unitId?this._d=this._init():(this._disposeCurrent(),this._isUnitEditing&&(this._handleEditorInvisible({visible:!1,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:ui.KeyCode.ESC,unitId:this._context.unitId}),this._isUnitEditing=!1))})),this._initEditorVisibilityListener()}dispose(){super.dispose(),this._disposeCurrent()}_disposeCurrent(){var _a58;(_a58=this._d)==null||_a58.dispose(),this._d=null}_init(){const d=new core.DisposableCollection;return this._subscribeToCurrentCell(d),this._initialKeyboardListener(d),this._initialCursorSync(d),this._listenEditorFocus(d),this._commandExecutedListener(d),this._initSkeletonListener(d),this.disposeWithMe(this._instanceSrv.unitDisposed$.subscribe(_unit=>{clearTimeout(this._cursorTimeout)})),this._cursorTimeout=setTimeout(()=>{this._cursorStateListener(d)},1e3),d}_initEditorVisibilityListener(){this.disposeWithMe(this._editorBridgeService.visible$.pipe(rxjs.distinctUntilChanged((prev,curr)=>prev.visible===curr.visible)).subscribe(param=>{(param.unitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY||param.unitId===this._context.unitId)&&param.visible?(this._isUnitEditing=!0,this._handleEditorVisible(param)):this._isUnitEditing&&(this._handleEditorInvisible(param),this._isUnitEditing=!1)}))}_listenEditorFocus(d){const renderConfig=this._getEditorObject();renderConfig&&d.add(renderConfig.document.onPointerDown$.subscribeEvent(()=>{if(this._isUnitEditing&&this._editorBridgeService.isVisible()){const param=this._editorBridgeService.getEditCellState(),editorId=this._editorBridgeService.getCurrentEditorId();if(!param||!editorId||!this._editorService.isSheetEditor(editorId))return;const skeleton=this._getEditorSkeleton(editorId);if(!skeleton)return;const{position,documentLayoutObject,canvasOffset,scaleX,scaleY}=param;this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY)}}))}_getEditorSkeleton(editorId){var _a58;return(_a58=this._renderManagerService.getRenderById(editorId))==null?void 0:_a58.with(docs.DocSkeletonManagerService).getSkeleton()}_getEditorViewModel(editorId){var _a58;return(_a58=this._renderManagerService.getRenderById(editorId))==null?void 0:_a58.with(docs.DocSkeletonManagerService).getViewModel()}_initialCursorSync(d){d.add(this._cellEditorManagerService.focus$.pipe(rxjs.filter(f2=>!!f2)).subscribe(()=>{var _a58;const docSelectionRenderManager=(_a58=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a58.with(docsUi.DocSelectionRenderService);docSelectionRenderManager&&docSelectionRenderManager.sync()}))}_initSkeletonListener(d){const commandList=new Set(sheets.COMMAND_LISTENER_SKELETON_CHANGE);commandList.delete(sheets.SetWorksheetActiveOperation.id),d.add(this._commandService.onCommandExecuted(commandInfo=>{commandList.has(commandInfo.id)&&this.resizeCellEditor()}))}resizeCellEditor(){var _a58;const state=this._cellEditorManagerService.getState();if(!state||!this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellPosition(!0);const editCellState=this._editorBridgeService.getEditCellState();if(!editCellState)return;const skeleton=(_a58=this._sheetSkeletonManagerService.getWorksheetSkeleton(editCellState.sheetId))==null?void 0:_a58.skeleton;if(!skeleton)return;const{row,column,scaleX,scaleY,position,canvasOffset,documentLayoutObject}=editCellState,maxSize=this._getEditorMaxSize(position,canvasOffset);if(!maxSize)return;const{height:clientHeight,width:clientWidth,scaleAdjust}=maxSize,cell=skeleton.getCellByIndex(row,column),height=Math.min((cell.mergeInfo.endY-cell.mergeInfo.startY)*scaleY,clientHeight)*scaleAdjust,width=Math.min((cell.mergeInfo.endX-cell.mergeInfo.startX)*scaleX,clientWidth)*scaleAdjust,currentHeight=state.endY-state.startY,currentWidth=state.endX-state.startX;if(currentHeight!==height||currentWidth!==width){this._editorBridgeService.refreshEditCellPosition(!0);const docSkeleton=this._getEditorSkeleton(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY);if(!docSkeleton)return;this._fitTextSize(position,canvasOffset,docSkeleton,documentLayoutObject,scaleX,scaleY,()=>{this._textSelectionManagerService.refreshSelection({unitId:core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY,subUnitId:core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY})})}}_subscribeToCurrentCell(d){d.add(this._editorBridgeService.currentEditCellState$.subscribe(editCellState=>{var _a58;if(editCellState==null||this._editorBridgeService.isForceKeepVisible())return;const{position,documentLayoutObject,scaleX,editorUnitId}=editCellState;if(this._contextService.getContextValue(core.FOCUSING_EDITOR_STANDALONE)||this._contextService.getContextValue(core.FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE)||this._instanceSrv.getUnit(core.DOCS_NORMAL_EDITOR_UNIT_ID_KEY)===documentLayoutObject.documentModel)return;const{startX,endX}=position,{textRotation,wrapStrategy,documentModel}=documentLayoutObject,{vertexAngle:angle}=engineRender.convertTextRotation(textRotation);documentModel.updateDocumentId(editorUnitId),wrapStrategy===core.WrapStrategy.WRAP&&angle===0&&documentModel.updateDocumentDataPageSize((endX-startX)/scaleX),this._instanceSrv.changeDoc(editorUnitId,documentModel),this._contextService.setContextValue(core.FOCUSING_EDITOR_BUT_HIDDEN,!0),this._textSelectionManagerService.replaceTextRanges([{startOffset:0,endOffset:0}]);const docSelectionRenderManager=(_a58=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a58.with(docsUi.DocSelectionRenderService);docSelectionRenderManager&&docSelectionRenderManager.activate(HIDDEN_EDITOR_POSITION,HIDDEN_EDITOR_POSITION,!document.activeElement||document.activeElement.classList.contains("univer-editor"))}))}_fitTextSize(actualRangeWithCoord,canvasOffset,documentSkeleton,documentLayoutObject,scaleX=1,scaleY=1,callback){const{startX,startY,endX,endY}=actualRangeWithCoord,documentDataModel=documentLayoutObject.documentModel;if(documentDataModel==null)return;const{actualWidth,actualHeight}=this._predictingSize(actualRangeWithCoord,canvasOffset,documentSkeleton,documentLayoutObject,scaleX,scaleY),{verticalAlign,paddingData,fill}=documentLayoutObject;let editorWidth=endX-startX,editorHeight=endY-startY;if(editorWidth<actualWidth&&(editorWidth=actualWidth),editorHeight<actualHeight)editorHeight=actualHeight,documentDataModel.updateDocumentDataMargin(paddingData);else{let offsetTop=0;verticalAlign===core.VerticalAlign.MIDDLE?offsetTop=(editorHeight-actualHeight)/2/scaleY:verticalAlign===core.VerticalAlign.TOP?offsetTop=paddingData.t||0:offsetTop=(editorHeight-actualHeight)/scaleY-(paddingData.b||0),offsetTop=offsetTop<(paddingData.t||0)?paddingData.t||0:offsetTop,documentDataModel.updateDocumentDataMargin({t:offsetTop})}documentSkeleton.calculate(),this._editAreaProcessing(editorWidth,editorHeight,actualRangeWithCoord,canvasOffset,fill,scaleX,scaleY,callback)}_predictingSize(actualRangeWithCoord,canvasOffset,documentSkeleton,documentLayoutObject,scaleX=1,scaleY=1){const{startX,endX}=actualRangeWithCoord,{textRotation,wrapStrategy}=documentLayoutObject,documentDataModel=documentLayoutObject.documentModel,{vertexAngle:angle}=engineRender.convertTextRotation(textRotation),clientWidth=document.body.clientWidth;if(wrapStrategy===core.WrapStrategy.WRAP&&angle===0){const{actualWidth,actualHeight}=documentSkeleton.getActualSize();return{actualWidth:actualWidth*scaleX,actualHeight:actualHeight*scaleY}}documentDataModel==null||documentDataModel.updateDocumentDataPageSize((clientWidth-startX-canvasOffset.left)/scaleX),documentSkeleton.calculate();const size=documentSkeleton.getActualSize();let editorWidth=endX-startX;return editorWidth<size.actualWidth*scaleX+EDITOR_INPUT_SELF_EXTEND_GAP*scaleX&&(editorWidth=size.actualWidth*scaleX+EDITOR_INPUT_SELF_EXTEND_GAP*scaleX),documentDataModel==null||documentDataModel.updateDocumentDataPageSize(editorWidth/scaleX),documentDataModel==null||documentDataModel.updateDocumentRenderConfig({horizontalAlign:core.HorizontalAlign.UNSPECIFIED,cellValueType:void 0}),{actualWidth:editorWidth,actualHeight:size.actualHeight*scaleY}}_getEditorMaxSize(position,canvasOffset){if(this._getEditorObject()==null)return;function pxToNum2(width2){return Number.parseInt(width2.replace("px",""))}__name(pxToNum2,"pxToNum");const canvasElement=this._context.engine.getCanvasElement(),canvasClientRect=canvasElement.getBoundingClientRect(),widthOfCanvas=pxToNum2(canvasElement.style.width),{width}=canvasClientRect,scaleAdjust=width/widthOfCanvas,{startX,startY}=position,clientHeight=document.body.clientHeight-startY-Number.parseFloat(styles$9.sheetFooterBarHeight)-canvasOffset.top-EDITOR_BORDER_SIZE*2,clientWidth=document.body.clientWidth-startX-canvasOffset.left;return{height:clientHeight,width:clientWidth,scaleAdjust}}_editAreaProcessing(editorWidth,editorHeight,actualRangeWithCoord,canvasOffset,fill,scaleX=1,scaleY=1,callback){var _a58;const editorObject=this._getEditorObject();if(editorObject==null)return;const canvasElement=this._context.engine.getCanvasElement();let{startX,startY}=actualRangeWithCoord;const{document:documentComponent,scene:editorScene,engine:docEngine}=editorObject,viewportMain=editorScene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN),info=this._getEditorMaxSize(actualRangeWithCoord,canvasOffset);if(!info)return;const{height:clientHeight,width:clientWidth,scaleAdjust}=info;let physicHeight=editorHeight,scrollBar=viewportMain==null?void 0:viewportMain.getScrollBar();physicHeight>clientHeight?(physicHeight=clientHeight,scrollBar==null?viewportMain&&new engineRender.ScrollBar(viewportMain,{enableHorizontal:!1,barSize:8}):viewportMain==null||viewportMain.resetCanvasSizeAndUpdateScroll()):(scrollBar=null,(_a58=viewportMain==null?void 0:viewportMain.getScrollBar())==null||_a58.dispose()),editorWidth+=(scrollBar==null?void 0:scrollBar.barSize)||0,editorWidth>clientWidth&&(editorWidth=clientWidth),startX-=engineRender.FIX_ONE_PIXEL_BLUR_OFFSET,startY-=engineRender.FIX_ONE_PIXEL_BLUR_OFFSET,this._addBackground(editorScene,editorWidth/scaleX,editorHeight/scaleY,fill);const{scaleX:precisionScaleX,scaleY:precisionScaleY}=editorScene.getPrecisionScale();editorScene.transformByState({width:editorWidth*scaleAdjust/scaleX,height:editorHeight*scaleAdjust/scaleY,scaleX:scaleX*scaleAdjust,scaleY:scaleY*scaleAdjust}),documentComponent.resize(editorWidth*scaleAdjust/scaleX,editorHeight*scaleAdjust/scaleY),setTimeout(()=>{docEngine.resizeBySize(engineRender.fixLineWidthByScale(editorWidth,precisionScaleX),engineRender.fixLineWidthByScale(physicHeight,precisionScaleY)),callback==null||callback()},0);const contentBoundingRect=this._layoutService.getContentElement().getBoundingClientRect(),canvasBoundingRect=canvasElement.getBoundingClientRect();startX=startX*scaleAdjust+(canvasBoundingRect.left-contentBoundingRect.left),startY=startY*scaleAdjust+(canvasBoundingRect.top-contentBoundingRect.top),this._cellEditorManagerService.setState({startX,startY,endX:editorWidth*scaleAdjust+startX,endY:physicHeight*scaleAdjust+startY,show:!0})}_addBackground(scene,editorWidth,editorHeight,fill){const fillRectKey="_backgroundRectHelperColor_",rect=scene.getObject(fillRectKey);rect==null&&fill==null||(rect==null?scene.addObjects([new engineRender.Rect(fillRectKey,{width:editorWidth,height:editorHeight,fill,evented:!1})],docsUi.DOCS_COMPONENT_MAIN_LAYER_INDEX):fill==null?rect.dispose():(rect.setProps({fill}),rect.transformByState({width:editorWidth,height:editorHeight})))}_handleEditorVisible(param){var _a58;const{eventType,keycode}=param;this._cursorChange=eventType===engineRender.DeviceInputEventType.PointerDown||eventType===engineRender.DeviceInputEventType.Dblclick?2:1;let editCellState=this._editorBridgeService.getEditCellState();if(editCellState==null||(this._commandService.syncExecuteCommand(ScrollToRangeOperation.id,{range:{startRow:editCellState.row,startColumn:editCellState.column,endRow:editCellState.row,endColumn:editCellState.column}}),this._editorBridgeService.refreshEditCellPosition(!1),editCellState=this._editorBridgeService.getEditCellState(),editCellState==null))return;const{position,documentLayoutObject,canvasOffset,scaleX,scaleY,editorUnitId,unitId,sheetId,isInArrayFormulaRange=!1}=editCellState,editorObject=this._getEditorObject();if(editorObject==null)return;this._setOpenForCurrent(unitId,sheetId);const{document:document2,scene}=editorObject;this._contextService.setContextValue(core.EDITOR_ACTIVATED,!0);const{documentModel:documentDataModel}=documentLayoutObject,skeleton=this._getEditorSkeleton(editorUnitId);if(!skeleton||!documentDataModel)return;if(this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY),eventType===engineRender.DeviceInputEventType.Keyboard||eventType===engineRender.DeviceInputEventType.Dblclick&&isInArrayFormulaRange){const snapshot=core.Tools.deepClone(documentDataModel.getSnapshot()),documentViewModel=this._getEditorViewModel(editorUnitId);if(documentViewModel==null)return;this._resetBodyStyle(snapshot.body,!!isInArrayFormulaRange),documentDataModel.reset(snapshot),documentViewModel.reset(documentDataModel),document2.makeDirty(),(keycode===ui.KeyCode.BACKSPACE||eventType===engineRender.DeviceInputEventType.Dblclick)&&(skeleton.calculate(),this._editorBridgeService.changeEditorDirty(!0)),this._textSelectionManagerService.replaceTextRanges([{startOffset:0,endOffset:0}])}else if(eventType===engineRender.DeviceInputEventType.Dblclick){const cursor=documentDataModel.getBody().dataStream.length-2||0;this._textSelectionManagerService.replaceTextRanges([{startOffset:cursor,endOffset:cursor}])}const viewMain=scene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN);setTimeout(()=>{viewMain==null||viewMain.scrollToViewportPos({viewportScrollX:Number.POSITIVE_INFINITY,viewportScrollY:Number.POSITIVE_INFINITY})},10),(_a58=this._renderManagerService.getRenderById(unitId))==null||_a58.scene.resetCursor()}_resetBodyStyle(body,removeStyle=!1){body.dataStream=core.DEFAULT_EMPTY_DOCUMENT_VALUE,body.textRuns!=null&&(body.textRuns.length===1&&!removeStyle?(body.textRuns[0].st=0,body.textRuns[0].ed=1):body.textRuns=void 0),body.paragraphs!=null&&(body.paragraphs.length===1?body.paragraphs[0].startIndex=0:body.paragraphs=[{startIndex:0}]),body.sectionBreaks!=null&&(body.sectionBreaks=void 0),body.tables!=null&&(body.tables=void 0),body.customRanges!=null&&(body.customRanges=void 0),body.customBlocks!=null&&(body.customBlocks=void 0)}_initialKeyboardListener(d){var _a58;const docSelectionRenderService=(_a58=this._renderManagerService.getCurrentTypeOfRenderer(core.UniverInstanceType.UNIVER_DOC))==null?void 0:_a58.with(docsUi.DocSelectionRenderService);docSelectionRenderService&&d.add(docSelectionRenderService.onInputBefore$.subscribe(config=>{var _a59;if(!this._isCurrentSheetFocused())return;const isFocusFormulaEditor=this._contextService.getContextValue(core.FOCUSING_FX_BAR_EDITOR),isFocusSheets=this._contextService.getContextValue(core.FOCUSING_SHEET),unitId=(_a59=this._instanceSrv.getCurrentUniverDocInstance())==null?void 0:_a59.getUnitId();unitId&&isFocusSheets&&!isFocusFormulaEditor&&this._editorService.isSheetEditor(unitId)&&this._showEditorByKeyboard(config)}))}_showEditorByKeyboard(config){if(config==null)return;const event=config.event;this._commandService.executeCommand(SetCellEditVisibleOperation.id,{visible:!0,eventType:engineRender.DeviceInputEventType.Keyboard,keycode:event.which,unitId:this._context.unitId})}_commandExecutedListener(d){const updateCommandList=[docs.RichTextEditingMutation.id,ui.SetEditorResizeOperation.id];d.add(this._commandService.onCommandExecuted(command=>{if(updateCommandList.includes(command.id)){const params=command.params,{unitId:commandUnitId}=params;if(!this._isCurrentSheetFocused()||!this._editorService.isSheetEditor(commandUnitId))return;const editorId=this._editorBridgeService.getCurrentEditorId();if(editorId==null)return;const skeleton=this._getEditorSkeleton(editorId);if(skeleton==null)return;this._editorBridgeService.changeEditorDirty(!0);const param=this._editorBridgeService.getEditCellState();if(param==null)return;const{position,documentLayoutObject,canvasOffset,scaleX,scaleY}=param;if(!this._editorBridgeService.isVisible().visible)return;commandUnitId===core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY?setTimeout(()=>{this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY)},0):this._fitTextSize(position,canvasOffset,skeleton,documentLayoutObject,scaleX,scaleY)}})),d.add(this._commandService.onCommandExecuted(command=>{if(command.id===sheets.ClearSelectionFormatCommand.id){if(this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellState()}})),d.add(this._commandService.onCommandExecuted(command=>{if(command.id===sheets.SetRangeValuesMutation.id){if(this._editorBridgeService.isVisible().visible)return;this._editorBridgeService.refreshEditCellState()}}));const closeEditorOperation=[SetCellEditVisibleArrowOperation.id];d.add(this._commandService.onCommandExecuted(command=>{if(closeEditorOperation.includes(command.id)){const params=command.params,{keycode,isShift}=params;if(keycode!=null&&(this._cursorChange===2||this._contextService.getContextValue(core.FOCUSING_FX_BAR_EDITOR))){this._moveInEditor(keycode,isShift);return}this._editorBridgeService.changeVisible(params)}command.id===SetCellEditVisibleWithF2Operation.id&&(this._cursorChange=2)}))}_setOpenForCurrent(unitId,sheetId){const sheetEditors=this._editorService.getAllEditor();for(const[_,sheetEditor]of sheetEditors)sheetEditor.isSheetEditor()&&(sheetEditor.setOpenForSheetUnitId(unitId),sheetEditor.setOpenForSheetSubUnitId(sheetId))}_getEditorObject(){return getEditorObject(this._editorBridgeService.getCurrentEditorId(),this._renderManagerService)}async _handleEditorInvisible(param){const editCellState=this._editorBridgeService.getEditCellState();let{keycode}=param;if(this._setOpenForCurrent(null,null),this._cursorChange=0,this._exitInput(param),editCellState==null)return;this._editorBridgeService.getEditorDirty()===!1&&(keycode=ui.KeyCode.ESC);const worksheet=this._context.unit.getActiveSheet(),workbookId=this._context.unitId,worksheetId=worksheet.getSheetId();if(keycode===ui.KeyCode.ESC){const selections=this._workbookSelections.getCurrentSelections();selections&&this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,{unitId:this._context.unit.getUnitId(),subUnitId:worksheetId,selections});return}const{unitId,sheetId}=editCellState;workbookId===unitId&&sheetId!==worksheetId&&this._editorBridgeService.isForceKeepVisible()&&await this._commandService.executeCommand(sheets.SetWorksheetActivateCommand.id,{subUnitId:sheetId,unitId});const documentDataModel=editCellState.documentLayoutObject.documentModel;documentDataModel&&await this._submitCellData(documentDataModel),this._moveCursor(keycode)}submitCellData(documentDataModel){return this._submitCellData(documentDataModel)}async _submitCellData(documentDataModel){const editCellState=this._editorBridgeService.getEditCellState();if(editCellState==null)return;const{unitId,sheetId,row,column}=editCellState,workbook=this._context.unit;let worksheet=workbook.getActiveSheet();if(!workbook.getSheetBySheetId(sheetId))return;worksheet=workbook.getActiveSheet();const cellData=getCellDataByInput(worksheet.getCellRaw(row,column)||{},documentDataModel,this._lexerTreeBuilder,model=>model.getSnapshot(),this._localService,this._functionService);if(!cellData)return;const context={subUnitId:sheetId,unitId,workbook,worksheet,row,col:column,origin:core.Tools.deepClone(cellData)},cell=this._editorBridgeService.interceptor.fetchThroughInterceptors(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT)(cellData,context),finalCell=await this._editorBridgeService.interceptor.fetchThroughInterceptors(this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC)(Promise.resolve(cell),context);this._commandService.executeCommand(sheets.SetRangeValuesCommand.id,{subUnitId:sheetId,unitId,range:{startRow:row,startColumn:column,endRow:row,endColumn:column},value:finalCell})}_exitInput(param){var _a58;this._contextService.setContextValue(core.FOCUSING_EDITOR_INPUT_FORMULA,!1),this._contextService.setContextValue(core.EDITOR_ACTIVATED,!1),this._contextService.setContextValue(core.FOCUSING_EDITOR_BUT_HIDDEN,!1),this._contextService.setContextValue(core.FOCUSING_FX_BAR_EDITOR,!1),this._cellEditorManagerService.setState({show:param.visible});const editorObject=this._getEditorObject();(_a58=editorObject==null?void 0:editorObject.scene.getViewport(docsUi.VIEWPORT_KEY.VIEW_MAIN))==null||_a58.scrollToViewportPos({viewportScrollX:0,viewportScrollY:0});const editorUnitId=this._editorBridgeService.getCurrentEditorId();editorUnitId==null||!this._editorService.isSheetEditor(editorUnitId)||(this._undoRedoService.clearUndoRedo(editorUnitId),this._undoRedoService.clearUndoRedo(core.DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY))}_moveCursor(keycode){if(keycode==null||!MOVE_SELECTION_KEYCODE_LIST.includes(keycode))return;let direction=core.Direction.LEFT;switch(keycode){case ui.KeyCode.ENTER:direction=core.Direction.DOWN;break;case ui.KeyCode.TAB:direction=core.Direction.RIGHT;break;case ui.KeyCode.ARROW_DOWN:direction=core.Direction.DOWN;break;case ui.KeyCode.ARROW_UP:direction=core.Direction.UP;break;case ui.KeyCode.ARROW_LEFT:direction=core.Direction.LEFT;break;case ui.KeyCode.ARROW_RIGHT:direction=core.Direction.RIGHT;break}keycode===ui.KeyCode.ENTER||keycode===ui.KeyCode.TAB?this._commandService.executeCommand(MoveSelectionEnterAndTabCommand.id,{keycode,direction}):this._commandService.executeCommand(MoveSelectionCommand.id,{direction})}_cursorStateListener(d){const editorObject=this._getEditorObject();if(!editorObject.document)return;const{document:documentComponent}=editorObject;d.add(core.toDisposable(documentComponent.onPointerDown$.subscribeEvent(()=>{this._cursorChange===1&&(this._cursorChange=2)})))}_moveInEditor(keycode,isShift){let direction=core.Direction.LEFT;keycode===ui.KeyCode.ARROW_DOWN?direction=core.Direction.DOWN:keycode===ui.KeyCode.ARROW_UP?direction=core.Direction.UP:keycode===ui.KeyCode.ARROW_RIGHT&&(direction=core.Direction.RIGHT),isShift?this._commandService.executeCommand(docsUi.MoveSelectionOperation.id,{direction}):this._commandService.executeCommand(docsUi.MoveCursorOperation.id,{direction})}_isCurrentSheetFocused(){var _a58;return((_a58=this._instanceSrv.getFocusedUnit())==null?void 0:_a58.getUnitId())===this._context.unitId}},__name(_a16,"EditingRenderController"),_a16);exports.EditingRenderController=__decorateClass$D([__decorateParam$D(1,ui.ILayoutService),__decorateParam$D(2,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$D(3,core.IUndoRedoService),__decorateParam$D(4,core.IContextService),__decorateParam$D(5,core.IUniverInstanceService),__decorateParam$D(6,engineRender.IRenderManagerService),__decorateParam$D(7,IEditorBridgeService),__decorateParam$D(8,ICellEditorManagerService),__decorateParam$D(9,core.Inject(engineFormula.LexerTreeBuilder)),__decorateParam$D(10,engineFormula.IFunctionService),__decorateParam$D(11,core.Inject(docs.DocSelectionManagerService)),__decorateParam$D(12,core.ICommandService),__decorateParam$D(13,core.Inject(core.LocaleService)),__decorateParam$D(14,docsUi.IEditorService),__decorateParam$D(15,core.Inject(exports.SheetSkeletonManagerService))],exports.EditingRenderController);function getCellDataByInput(cellData,documentDataModel,lexerTreeBuilder,getSnapshot,localeService,functionService){if(cellData=core.Tools.deepClone(cellData),documentDataModel==null)return null;const snapshot=getSnapshot(documentDataModel),{body}=snapshot;if(body==null)return null;cellData.t=void 0;const data=body.dataStream;let newDataStream=data.substring(data.length-2,data.length)===core.DEFAULT_EMPTY_DOCUMENT_VALUE?data.substring(0,data.length-2):data;const currentLocale=localeService.getCurrentLocale();if(newDataStream=normalizeString(newDataStream,lexerTreeBuilder,currentLocale,functionService),core.isFormulaString(newDataStream)){if(cellData.f===newDataStream)return null;const bracketCount=lexerTreeBuilder.checkIfAddBracket(newDataStream);for(let i=0;i<bracketCount;i++)newDataStream+=engineFormula.matchToken.CLOSE_BRACKET;cellData.f=newDataStream,cellData.si=null,cellData.v=null,cellData.p=null}else if(isForceString(newDataStream)){const v=extractStringFromForceString(newDataStream);cellData.v=v,cellData.f=null,cellData.si=null,cellData.p=null,cellData.t=core.CellValueType.FORCE_STRING}else if(isRichText(body))body.dataStream===`\r
18
18
  `?(cellData.v="",cellData.f=null,cellData.si=null,cellData.p=null):(cellData.p=snapshot,cellData.v=null,cellData.f=null,cellData.si=null);else if(core.numfmt.parseDate(newDataStream)||core.numfmt.parseNumber(newDataStream)||core.numfmt.parseTime(newDataStream))cellData.v=newDataStream,cellData.f=null,cellData.si=null,cellData.p=null,cellData.t=core.CellValueType.NUMBER;else{if((newDataStream===cellData.v||newDataStream===""&&cellData.v==null)&&cellData.p==null)return null;cellData.v=newDataStream,cellData.f=null,cellData.si=null,cellData.p=null;const style=getCellStyleBySnapshot(snapshot);style&&(cellData.s=style)}return cellData}__name(getCellDataByInput,"getCellDataByInput");function isRichText(body){const{textRuns=[],paragraphs=[],customRanges,customBlocks=[]}=body,bodyNoLineBreak=body.dataStream.replace(`\r
19
19
  `,""),richTextStyle=["va"];return textRuns.some(textRun=>{var _a58;return!!(textRun.ts&&Object.keys(textRun.ts).some(property=>richTextStyle.includes(property)))||Object.keys((_a58=textRun.ts)!=null?_a58:{}).length&&textRun.ed-textRun.st<bodyNoLineBreak.length})||paragraphs.some(paragraph=>paragraph.bullet)||paragraphs.length>=2||!!(customRanges!=null&&customRanges.length)||customBlocks.length>0}__name(isRichText,"isRichText");function getCellStyleBySnapshot(snapshot){const{body}=snapshot;if(!body)return null;const{textRuns=[]}=body;let style={};const bodyNoLineBreak=body.dataStream.replace(`\r
20
20
  `,"");return textRuns.forEach(textRun=>{const{st,ed,ts}=textRun;ed-st>=bodyNoLineBreak.length&&(style={...style,...ts})}),Object.keys(style).length?style:null}__name(getCellStyleBySnapshot,"getCellStyleBySnapshot");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"),_a17;exports.SheetSelectionRenderService=(_a17=class extends BaseSelectionRenderService{constructor(_context,injector,themeService,shortcutService,selectionManagerService,sheetSkeletonManagerService,_logService,_commandService,_contextService){super(injector,themeService,shortcutService,sheetSkeletonManagerService);__publicField(this,"_workbookSelections");__publicField(this,"_renderDisposable",null);this._context=_context,this._logService=_logService,this._commandService=_commandService,this._contextService=_contextService,this._workbookSelections=selectionManagerService.getWorkbookSelections(this._context.unitId),this._init()}_init(){const sheetObject=this._getSheetObject();this._initEventListeners(sheetObject),this._initSelectionChangeListener(),this._initThemeChangeListener(),this._initSkeletonChangeListener(),this._initUserActionSyncListener()}_initEventListeners(sheetObject){const{spreadsheetRowHeader,spreadsheetColumnHeader,spreadsheet,spreadsheetLeftTopPlaceholder}=sheetObject,{scene}=this._context;this.disposeWithMe(spreadsheet==null?void 0:spreadsheet.onPointerDown$.subscribeEvent((evt,state)=>{this._normalSelectionDisabled()||(this._onPointerDown(evt,spreadsheet.zIndex+1,core.RANGE_TYPE.NORMAL,this._getActiveViewport(evt)),evt.button!==2&&state.stopPropagation())})),this.disposeWithMe(spreadsheetRowHeader==null?void 0:spreadsheetRowHeader.onPointerDown$.subscribeEvent((evt,state)=>{if(this._normalSelectionDisabled())return;const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{row}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);isThisRowSelected(this._workbookSelections.getCurrentSelections(),row)||(this._onPointerDown(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.ROW,this._getActiveViewport(evt),engineRender.ScrollTimerType.Y),evt.button!==2&&state.stopPropagation())})),this.disposeWithMe(spreadsheetColumnHeader==null?void 0:spreadsheetColumnHeader.onPointerDown$.subscribeEvent((evt,state)=>{if(this._normalSelectionDisabled())return;const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,{column}=getCoordByOffset(evt.offsetX,evt.offsetY,scene,skeleton);isThisColSelected(this._workbookSelections.getCurrentSelections(),column)||(this._onPointerDown(evt,(spreadsheet.zIndex||1)+1,core.RANGE_TYPE.COLUMN,this._getActiveViewport(evt),engineRender.ScrollTimerType.X),evt.button!==2&&state.stopPropagation())})),this.disposeWithMe(spreadsheetLeftTopPlaceholder==null?void 0:spreadsheetLeftTopPlaceholder.onPointerDown$.subscribeEvent((evt,state)=>{if(this._normalSelectionDisabled())return;this._reset();const skeleton=this._sheetSkeletonManagerService.getCurrent().skeleton,selectionWithStyle=getAllSelection(skeleton),selectionData=attachSelectionWithCoord(selectionWithStyle,skeleton);this._addSelectionControlBySelectionData(selectionData),this.refreshSelectionMoveEnd(),evt.button!==2&&state.stopPropagation()}))}_initThemeChangeListener(){this.disposeWithMe(this._themeService.currentTheme$.subscribe(()=>{this._resetSelectionStyle();const selections=this._workbookSelections.getCurrentSelections();selections&&this._refreshSelectionControl(selections)}))}_normalSelectionDisabled(){return this._contextService.getContextValue(sheets.DISABLE_NORMAL_SELECTIONS)}_initSelectionChangeListener(){this.disposeWithMe(this._workbookSelections.selectionMoveEnd$.subscribe(params=>{this._reset();for(const selectionWithStyle of params){const selectionData=attachSelectionWithCoord(selectionWithStyle,this._skeleton);this._addSelectionControlBySelectionData(selectionData)}}))}_initUserActionSyncListener(){this.disposeWithMe(this.selectionMoveStart$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVE_START))),this.disposeWithMe(this.selectionMoving$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVING))),this.disposeWithMe(this._contextService.subscribeContextValue$(sheets.DISABLE_NORMAL_SELECTIONS).pipe(rxjs.startWith(!1),rxjs.distinctUntilChanged()).subscribe(disabled=>{var _a58;disabled?((_a58=this._renderDisposable)==null||_a58.dispose(),this._renderDisposable=null,this._reset()):this._renderDisposable=core.toDisposable(this.selectionMoveEnd$.subscribe(params=>this._updateSelections(params,sheets.SelectionMoveType.MOVE_END)))}))}_updateSelections(selectionDataWithStyleList,type){const workbook=this._context.unit,unitId=workbook.getUnitId(),sheetId=workbook.getActiveSheet().getSheetId();selectionDataWithStyleList.length!==0&&this._commandService.executeCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,type,selections:selectionDataWithStyleList.map(selectionDataWithStyle=>sheets.convertSelectionDataToRange(selectionDataWithStyle))})}_initSkeletonChangeListener(){this.disposeWithMe(this._sheetSkeletonManagerService.currentSkeleton$.subscribe(param=>{var _a58,_b;if(param==null){this._logService.error("[SelectionRenderService]: should not receive null!");return}const unitId=this._context.unitId,{sheetId,skeleton}=param,{scene}=this._context,viewportMain=scene.getViewport(engineRender.SHEET_VIEWPORT_KEY.VIEW_MAIN),prevSheetId=(_b=(_a58=this._skeleton)==null?void 0:_a58.worksheet)==null?void 0:_b.getSheetId();if(this._changeRuntime(skeleton,scene,viewportMain),this._normalSelectionDisabled())return;if(prevSheetId!==skeleton.worksheet.getSheetId()){const selections=this._workbookSelections.getCurrentSelections();this._commandService.syncExecuteCommand(sheets.SetSelectionsOperation.id,{unitId,subUnitId:sheetId,selections:selections.length!==0?selections:[getTopLeftSelection(skeleton)]})}const currentSelections=this._workbookSelections.getCurrentSelections();currentSelections!=null&&this._refreshSelectionControl(currentSelections)}))}_getActiveViewport(evt){const sheetObject=this._getSheetObject();return sheetObject==null?void 0:sheetObject.scene.getActiveViewportByCoord(engineRender.Vector2.FromArray([evt.offsetX,evt.offsetY]))}_getSheetObject(){return getSheetObject(this._context.unit,this._context)}},__name(_a17,"SheetSelectionRenderService"),_a17);exports.SheetSelectionRenderService=__decorateClass$C([__decorateParam$C(1,core.Inject(core.Injector)),__decorateParam$C(2,core.Inject(core.ThemeService)),__decorateParam$C(3,ui.IShortcutService),__decorateParam$C(4,core.Inject(sheets.SheetsSelectionsService)),__decorateParam$C(5,core.Inject(exports.SheetSkeletonManagerService)),__decorateParam$C(6,core.ILogService),__decorateParam$C(7,core.ICommandService),__decorateParam$C(8,core.IContextService)],exports.SheetSelectionRenderService);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"),_a18;let ActiveWorksheetController=(_a18=class extends core.Disposable{constructor(_commandService,_univerInstanceService){super();__publicField(this,"_previousSheetIndex",-1);this._commandService=_commandService,this._univerInstanceService=_univerInstanceService,this.disposeWithMe(this._commandService.beforeCommandExecuted(command=>{if(command.id===sheets.RemoveSheetMutation.id)return this._beforeAdjustActiveSheetOnRemoveSheet(command)})),this.disposeWithMe(this._commandService.onCommandExecuted((command,options)=>{if(command.id===sheets.RemoveSheetMutation.id)return this._adjustActiveSheetOnRemoveSheet(command);if(command.id===sheets.SetWorksheetHideMutation.id&&command.params.hidden)return this._adjustActiveSheetOnHideSheet(command);if(options!=null&&options.fromCollab)return!1;if(command.id===sheets.InsertSheetMutation.id)return this._adjustActiveSheetOnInsertSheet(command);if(command.id===sheets.SetWorksheetHideMutation.id&&!command.params.hidden)return this._adjustActiveSheetOnShowSheet(command);if(command.id===sheets.SetSelectionsOperation.id)return this._adjustActiveSheetOnSelection(command)}))}_adjustActiveSheetOnHideSheet(mutation){var _a58;const{unitId,subUnitId}=mutation.params,workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook||((_a58=workbook.getActiveSheet())==null?void 0:_a58.getSheetId())!==subUnitId)return;const activeIndex=workbook.getActiveSheetIndex(),nextId=findTheNextUnhiddenSheet(workbook,activeIndex);this._switchToNextSheet(unitId,nextId)}_beforeAdjustActiveSheetOnRemoveSheet(mutation){const{unitId,subUnitId}=mutation.params,workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;const worksheet=workbook.getSheetBySheetId(subUnitId);worksheet&&(this._previousSheetIndex=workbook.getSheetIndex(worksheet))}_adjustActiveSheetOnRemoveSheet(mutation){if(this._previousSheetIndex===-1)return;const{unitId}=mutation.params,workbook=this._univerInstanceService.getUniverSheetInstance(unitId);if(!workbook)return;if(workbook.getActiveSheet().getSheetId()===mutation.params.subUnitId){const previousIndex=this._previousSheetIndex,nextIndex=previousIndex>=1?previousIndex-1:0,nextId=findTheNextUnhiddenSheet(workbook,nextIndex);this._switchToNextSheet(unitId,nextId)}}_adjustActiveSheetOnInsertSheet(mutation){const{unitId,sheet}=mutation.params;this._switchToNextSheet(unitId,sheet.id)}_adjustActiveSheetOnShowSheet(mutation){const{unitId,subUnitId}=mutation.params;this._switchToNextSheet(unitId,subUnitId)}_adjustActiveSheetOnSelection(operation){var _a58;const{unitId,subUnitId}=operation.params;subUnitId!==((_a58=this._univerInstanceService.getUnit(unitId))==null?void 0:_a58.getActiveSheet().getSheetId())&&this._switchToNextSheet(unitId,subUnitId)}_switchToNextSheet(unitId,subUnitId){this._commandService.executeCommand(sheets.SetWorksheetActiveOperation.id,{unitId,subUnitId})}},__name(_a18,"ActiveWorksheetController"),_a18);ActiveWorksheetController=__decorateClass$B([__decorateParam$B(0,core.ICommandService),__decorateParam$B(1,core.IUniverInstanceService)],ActiveWorksheetController);function findTheNextUnhiddenSheet(workbook,startIndex){const countOfSheets=workbook.getSheetSize();for(let i=startIndex;i>-1;i--){const sheet=workbook.getSheetByIndex(i);if(!sheet.getConfig().hidden)return sheet.getSheetId()}for(let i=startIndex;i<countOfSheets;i++){const sheet=workbook.getSheetByIndex(i);if(!sheet.getConfig().hidden)return sheet.getSheetId()}throw new Error("[ActiveWorksheetController]: could not find the next unhidden sheet! Collaboration error perhaps.")}__name(findTheNextUnhiddenSheet,"findTheNextUnhiddenSheet");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"),_a19;exports.SheetCanvasPopManagerService=(_a19=class extends core.Disposable{constructor(_globalPopupManagerService,_renderManagerService,_univerInstanceService,_refRangeService,_commandService){super(),this._globalPopupManagerService=_globalPopupManagerService,this._renderManagerService=_renderManagerService,this._univerInstanceService=_univerInstanceService,this._refRangeService=_refRangeService,this._commandService=_commandService}_createPositionObserver(bound,currentRender,skeleton,worksheet){const calc=__name(()=>{const{scene}=currentRender,offsetBound=transformBound2OffsetBound(bound,scene,skeleton,worksheet),canvasElement=currentRender.engine.getCanvasElement(),canvasClientRect=canvasElement.getBoundingClientRect(),widthOfCanvas=pxToNum(canvasElement.style.width),scaleAdjust=canvasClientRect.width/widthOfCanvas;return{left:offsetBound.left*scaleAdjust+canvasClientRect.left,right:offsetBound.right*scaleAdjust+canvasClientRect.left,top:offsetBound.top*scaleAdjust+canvasClientRect.top,bottom:offsetBound.bottom*scaleAdjust+canvasClientRect.top}},"calc"),position=calc(),position$=new rxjs.BehaviorSubject(position),disposable=new core.DisposableCollection;return disposable.add(this._commandService.onCommandExecuted(commandInfo=>{(commandInfo.id===SetScrollOperation.id||commandInfo.id===SetZoomRatioOperation.id)&&position$.next(calc())})),{position,position$,disposable}}attachPopupToObject(targetObject,popup){var _a58;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)return{dispose:__name(()=>{},"dispose"),canDispose:__name(()=>!0,"canDispose")};const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId(),skeleton=(_a58=this._renderManagerService.getRenderById(unitId))==null?void 0:_a58.with(exports.SheetSkeletonManagerService).getOrCreateSkeleton({sheetId:subUnitId}),currentRender=this._renderManagerService.getRenderById(unitId);if(!currentRender||!skeleton)return{dispose:__name(()=>{},"dispose"),canDispose:__name(()=>!0,"canDispose")};const{left,top,width,height}=targetObject,bound={left,right:left+width,top,bottom:top+height},{position,position$,disposable}=this._createPositionObserver(bound,currentRender,skeleton,worksheet),id=this._globalPopupManagerService.addPopup({...popup,unitId,subUnitId,anchorRect:position,anchorRect$:position$,canvasElement:currentRender.engine.getCanvasElement()});return{dispose:__name(()=>{this._globalPopupManagerService.removePopup(id),position$.complete(),disposable.dispose()},"dispose"),canDispose:__name(()=>this._globalPopupManagerService.activePopupId!==id,"canDispose")}}attachPopupByPosition(bound,popup,_unitId,_subUnitId){var _a58;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)return null;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId();if(_unitId&&unitId!==_unitId||_subUnitId&&_subUnitId!==subUnitId)return null;const skeleton=(_a58=this._renderManagerService.getRenderById(unitId))==null?void 0:_a58.with(exports.SheetSkeletonManagerService).getOrCreateSkeleton({sheetId:subUnitId}),currentRender=this._renderManagerService.getRenderById(unitId);if(!currentRender||!skeleton)return null;const{position,position$,disposable}=this._createPositionObserver(bound,currentRender,skeleton,worksheet),id=this._globalPopupManagerService.addPopup({...popup,unitId,subUnitId,anchorRect:position,anchorRect$:position$,canvasElement:currentRender.engine.getCanvasElement()});return{dispose:__name(()=>{this._globalPopupManagerService.removePopup(id),position$.complete(),disposable.dispose()},"dispose"),canDispose:__name(()=>this._globalPopupManagerService.activePopupId!==id,"canDispose")}}attachPopupToAbsolutePosition(bound,popup,_unitId,_subUnitId){var _a58;const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)return null;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId();if(_unitId&&unitId!==_unitId||_subUnitId&&_subUnitId!==subUnitId)return null;const skeleton=(_a58=this._renderManagerService.getRenderById(unitId))==null?void 0:_a58.with(exports.SheetSkeletonManagerService).getOrCreateSkeleton({sheetId:subUnitId}),currentRender=this._renderManagerService.getRenderById(unitId);if(!currentRender||!skeleton)return null;const position$=new rxjs.BehaviorSubject(bound),id=this._globalPopupManagerService.addPopup({...popup,unitId,subUnitId,anchorRect:bound,anchorRect$:position$.asObservable(),canvasElement:currentRender.engine.getCanvasElement()});return{dispose:__name(()=>{this._globalPopupManagerService.removePopup(id),position$.complete()},"dispose"),canDispose:__name(()=>this._globalPopupManagerService.activePopupId!==id,"canDispose")}}attachPopupToCell(row,col,popup,_unitId,_subUnitId,viewport,showOnSelectionMoving=!1){const workbook=this._univerInstanceService.getCurrentUnitForType(core.UniverInstanceType.UNIVER_SHEET),worksheet=workbook.getActiveSheet();if(!worksheet)return null;const unitId=workbook.getUnitId(),subUnitId=worksheet.getSheetId();if(_unitId&&unitId!==_unitId||_subUnitId&&subUnitId!==_subUnitId)return null;const currentRender=this._renderManagerService.getRenderById(unitId),skeleton=currentRender==null?void 0:currentRender.with(exports.SheetSkeletonManagerService).getOrCreateSkeleton({sheetId:subUnitId}),sheetSelectionRenderService=currentRender==null?void 0:currentRender.with(ISheetSelectionRenderService);if(!currentRender||!skeleton||!sheetSelectionRenderService)return null;if(sheetSelectionRenderService.selectionMoving&&!showOnSelectionMoving)return;const activeViewport=viewport!=null?viewport:getViewportByCell(row,col,currentRender.scene,worksheet);if(!activeViewport)return null;const{position,position$,disposable:positionObserverDisposable,updateRowCol}=this._createCellPositionObserver(row,col,currentRender,skeleton,activeViewport),id=this._globalPopupManagerService.addPopup({...popup,unitId,subUnitId,anchorRect:position,anchorRect$:position$,canvasElement:currentRender.engine.getCanvasElement()}),disposableCollection=new core.DisposableCollection;disposableCollection.add(positionObserverDisposable),disposableCollection.add(core.toDisposable(()=>{this._globalPopupManagerService.removePopup(id),position$.complete()}));const watchedRange={startRow:row,endRow:row,startColumn:col,endColumn:col};return disposableCollection.add(this._refRangeService.watchRange(unitId,subUnitId,watchedRange,(_,after)=>{after?updateRowCol(after.startRow,after.startColumn):disposableCollection.dispose()})),{dispose(){disposableCollection.dispose()},canDispose:__name(()=>this._globalPopupManagerService.activePopupId!==id,"canDispose")}}_createCellPositionObserver(initialRow,initialCol,currentRender,skeleton,activeViewport){let row=initialRow,col=initialCol;const position=this._calcCellPositionByCell(row,col,currentRender,skeleton,activeViewport),position$=new rxjs.BehaviorSubject(position),updatePosition=__name(()=>position$.next(this._calcCellPositionByCell(row,col,currentRender,skeleton,activeViewport)),"updatePosition"),disposable=new core.DisposableCollection;return disposable.add(currentRender.engine.clientRect$.subscribe(()=>updatePosition())),disposable.add(this._commandService.onCommandExecuted(commandInfo=>{if(commandInfo.id===sheets.SetWorksheetRowAutoHeightMutation.id&&commandInfo.params.rowsAutoHeightInfo.findIndex(item=>item.row===row)>-1){updatePosition();return}(sheets.COMMAND_LISTENER_SKELETON_CHANGE.indexOf(commandInfo.id)>-1||commandInfo.id===SetScrollOperation.id||commandInfo.id===SetZoomRatioOperation.id)&&updatePosition()})),{position$,disposable,position,updateRowCol:__name((newRow,newCol)=>{row=newRow,col=newCol,updatePosition()},"updateRowCol")}}_calcCellPositionByCell(row,col,currentRender,skeleton,activeViewport){const{scene,engine}=currentRender,primaryWithCoord=skeleton.getCellByIndex(row,col),cellInfo=primaryWithCoord.isMergedMainCell?primaryWithCoord.mergeInfo:primaryWithCoord,{scaleX,scaleY}=scene.getAncestorScale(),scrollXY={x:activeViewport.viewportScrollX,y:activeViewport.viewportScrollY},canvasElement=engine.getCanvasElement(),canvasClientRect=canvasElement.getBoundingClientRect(),widthOfCanvas=pxToNum(canvasElement.style.width),{top,left,width}=canvasClientRect,scaleAdjust=width/widthOfCanvas;return{left:(cellInfo.startX-scrollXY.x)*scaleAdjust*scaleX+left,right:(cellInfo.endX-scrollXY.x)*scaleAdjust*scaleX+left,top:(cellInfo.startY-scrollXY.y)*scaleAdjust*scaleY+top,bottom:(cellInfo.endY-scrollXY.y)*scaleAdjust*scaleY+top}}},__name(_a19,"SheetCanvasPopManagerService"),_a19);exports.SheetCanvasPopManagerService=__decorateClass$A([__decorateParam$A(0,core.Inject(ui.ICanvasPopupService)),__decorateParam$A(1,engineRender.IRenderManagerService),__decorateParam$A(2,core.IUniverInstanceService),__decorateParam$A(3,core.Inject(sheets.RefRangeService)),__decorateParam$A(4,core.ICommandService)],exports.SheetCanvasPopManagerService);function pxToNum(width){return Number.parseInt(width.replace("px",""))}__name(pxToNum,"pxToNum");var __defProp$z=Object.defineProperty,__getOwnPropDesc$z=Object.getOwnPropertyDescriptor,__decorateClass$z=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$z(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$z(target,key,result),result},"__decorateClass$z"),__decorateParam$z=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$z"),CellAlertType=(CellAlertType2=>(CellAlertType2[CellAlertType2.INFO=0]="INFO",CellAlertType2[CellAlertType2.WARNING=1]="WARNING",CellAlertType2[CellAlertType2.ERROR=2]="ERROR",CellAlertType2))(CellAlertType||{}),_a20;exports.CellAlertManagerService=(_a20=class extends core.Disposable{constructor(_renderManagerService,_canvasPopManagerService){super();__publicField(this,"_currentAlert$",new rxjs.Subject);__publicField(this,"_currentAlert",new Map);__publicField(this,"currentAlert$",this._currentAlert$.asObservable());this._renderManagerService=_renderManagerService,this._canvasPopManagerService=_canvasPopManagerService,this.disposeWithMe(()=>{this._currentAlert$.complete()})}get currentAlert(){return this._currentAlert}showAlert(alert){let lastPopup=this._currentAlert.get(alert.key);lastPopup&&lastPopup.dispose.dispose(),lastPopup?lastPopup.dispose.dispose():(lastPopup={alert,dispose:{dispose(){}}},this._currentAlert.set(alert.key,lastPopup));const{location}=alert,{row,col,unitId}=location;if(!this._renderManagerService.getRenderById(unitId))return;const disposable=this._canvasPopManagerService.attachPopupToCell(row,col,{componentKey:CELL_ALERT_KEY,direction:"horizontal",offset:[2,0],extraProps:{alert}});disposable&&(lastPopup.dispose=disposable),this._currentAlert$.next(Array.from(this._currentAlert.entries()))}removeAlert(key){const lastPopup=this._currentAlert.get(key);lastPopup&&(this._currentAlert.delete(key),lastPopup==null||lastPopup.dispose.dispose(),this._currentAlert$.next(Array.from(this._currentAlert.entries())))}clearAlert(){this._currentAlert.forEach(alert=>{alert.dispose.dispose()}),this._currentAlert.clear(),this._currentAlert$.next(Array.from(this._currentAlert.entries()))}},__name(_a20,"CellAlertManagerService"),_a20);exports.CellAlertManagerService=__decorateClass$z([__decorateParam$z(0,engineRender.IRenderManagerService),__decorateParam$z(1,core.Inject(exports.SheetCanvasPopManagerService))],exports.CellAlertManagerService);const cellAlert="univer-cell-alert",cellAlertTitle="univer-cell-alert-title",cellAlertIcon="univer-cell-alert-icon",cellAlertIconError="univer-cell-alert-icon-error",cellAlertIconInfo="univer-cell-alert-icon-info",cellAlertIconWarning="univer-cell-alert-icon-warning",cellAlertContent="univer-cell-alert-content",styles$8={cellAlert,cellAlertTitle,cellAlertIcon,cellAlertIconError,cellAlertIconInfo,cellAlertIconWarning,cellAlertContent};function CellAlert({popup}){var _a58;const alert=(_a58=popup.extraProps)==null?void 0:_a58.alert;if(!alert)return null;const{type,title,message}=alert,iconMap={[CellAlertType.ERROR]:jsxRuntimeExports.jsx(ErrorSingle,{className:clsx(styles$8.cellAlertIcon,styles$8.cellAlertIconError)}),[CellAlertType.INFO]:jsxRuntimeExports.jsx(WarningSingle,{className:clsx(styles$8.cellAlertIcon,styles$8.cellAlertIconInfo)}),[CellAlertType.WARNING]:jsxRuntimeExports.jsx(WarningSingle,{className:clsx(styles$8.cellAlertIcon,styles$8.cellAlertIconWarning)})};return jsxRuntimeExports.jsxs("div",{className:styles$8.cellAlert,children:[jsxRuntimeExports.jsxs("div",{className:styles$8.cellAlertTitle,children:[type?iconMap[type]:null,title]}),jsxRuntimeExports.jsx("div",{className:styles$8.cellAlertContent,children:message})]})}__name(CellAlert,"CellAlert");const CELL_ALERT_KEY="univer.sheet.cell-alert";var __defProp$y=Object.defineProperty,__getOwnPropDesc$y=Object.getOwnPropertyDescriptor,__decorateClass$y=__name((decorators,target,key,kind)=>{for(var result=kind>1?void 0:kind?__getOwnPropDesc$y(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$y(target,key,result),result},"__decorateClass$y"),__decorateParam$y=__name((index,decorator)=>(target,key)=>decorator(target,key,index),"__decorateParam$y"),_a21;let CellAlertRenderController=(_a21=class extends core.Disposable{constructor(_context,_componentManager){super(),this._context=_context,this._componentManager=_componentManager,this._initComponent()}_initComponent(){this._componentManager.register(CELL_ALERT_KEY,CellAlert)}},__name(_a21,"CellAlertRenderController"),_a21);CellAlertRenderController=__decorateClass$y([__decorateParam$y(1,core.Inject(ui.ComponentManager))],CellAlertRenderController);function getDefaultOnPasteCellMutations(pasteFrom,pasteTo,data,payload,accessor){const redoMutationsInfo=[],undoMutationsInfo=[];if(payload.copyType===COPY_TYPE.CUT){const{undos,redos}=getMoveRangeMutations(pasteFrom,pasteTo,accessor);redoMutationsInfo.push(...redos),undoMutationsInfo.push(...undos)}else{const{undos:clearStyleUndos,redos:clearStyleRedos}=getClearCellStyleMutations(pasteTo,data,accessor);redoMutationsInfo.push(...clearStyleRedos),undoMutationsInfo.push(...clearStyleUndos);const{undos:setValuesUndos,redos:setValuesRedos}=getSetCellValueMutations(pasteTo,pasteFrom,data,accessor);redoMutationsInfo.push(...setValuesRedos),undoMutationsInfo.push(...setValuesUndos);const{undos:setStyleUndos,redos:setStyleRedos}=getSetCellStyleMutations(pasteTo,data,accessor,!0);redoMutationsInfo.push(...setStyleRedos),undoMutationsInfo.push(...setStyleUndos);const{undos:setCustomUndos,redos:setCustomRedos}=getSetCellCustomMutations(pasteTo,pasteFrom,data,accessor);redoMutationsInfo.push(...setCustomRedos),undoMutationsInfo.push(...setCustomUndos);const{undos:clearMergeUndos,redos:clearMergeRedos}=getClearAndSetMergeMutations(pasteTo,data,accessor);redoMutationsInfo.push(...clearMergeRedos),undoMutationsInfo.push(...clearMergeUndos)}return{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getDefaultOnPasteCellMutations,"getDefaultOnPasteCellMutations");function getMoveRangeMutations(from,to,accessor){let redos=[],undos=[];const{range:fromDiscreteRange,subUnitId:fromSubUnitId,unitId}=from,{range:toDiscreteRange,subUnitId:toSubUnitId}=to,toRange=toDiscreteRange?discreteRangeToRange(toDiscreteRange):null,fromRange=fromDiscreteRange?discreteRangeToRange(fromDiscreteRange):null;if(fromRange&&toRange){const univerInstanceService=accessor.get(core.IUniverInstanceService),sheetInterceptorService=accessor.get(sheets.SheetInterceptorService),workbook=univerInstanceService.getUniverSheetInstance(unitId),fromWorksheet=workbook==null?void 0:workbook.getSheetBySheetId(fromSubUnitId),toWorksheet=workbook==null?void 0:workbook.getSheetBySheetId(toSubUnitId);if(fromWorksheet&&toWorksheet){const fromCellValue=new core.ObjectMatrix,newFromCellValue=new core.ObjectMatrix,fromCellMatrix=fromWorksheet.getCellMatrix(),toCellMatrix=toWorksheet.getCellMatrix();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;core.Range.foreach(toRange,(row,col)=>{toCellValue.setValue(row,col,core.Tools.deepClone(toCellMatrix.getValue(row,col)))});const newToCellValue=new core.ObjectMatrix;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,fromCellMatrix.getValue(row,col))});const doMoveRangeMutation={fromRange,toRange,from:{value:newFromCellValue.getMatrix(),subUnitId:fromSubUnitId},to:{value:newToCellValue.getMatrix(),subUnitId:toSubUnitId},unitId},undoMoveRangeMutation={fromRange:toRange,toRange:fromRange,from:{value:fromCellValue.getMatrix(),subUnitId:fromSubUnitId},to:{value:toCellValue.getMatrix(),subUnitId:toSubUnitId},unitId},interceptorCommands=sheetInterceptorService.onCommandExecute({id:sheets.MoveRangeCommand.id,params:{toRange,fromRange}}),fromMergeData=fromWorksheet.getMergeData(),toMergeData=toWorksheet.getMergeData(),fromMergeRanges=fromMergeData.filter(item=>core.Rectangle.intersects(item,fromRange)),toMergeRanges=toMergeData.filter(item=>core.Rectangle.intersects(item,toRange)),willMoveToMergeRanges=fromMergeRanges.map(mergeRange=>core.Rectangle.getRelativeRange(mergeRange,fromRange)).map(relativeRange=>core.Rectangle.getPositionRange(relativeRange,toRange)),addMergeCellRanges=sheets.getAddMergeMutationRangeByType(willMoveToMergeRanges).filter(range=>!toMergeData.some(mergeRange=>core.Rectangle.equals(range,mergeRange))),mergeRedos=[{id:sheets.RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId:fromSubUnitId,ranges:fromMergeRanges}},{id:sheets.RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId:fromSubUnitId,ranges:toMergeRanges}},{id:sheets.AddWorksheetMergeMutation.id,params:{unitId,subUnitId:toSubUnitId,ranges:addMergeCellRanges}}],mergeUndos=[{id:sheets.RemoveWorksheetMergeMutation.id,params:{unitId,subUnitId:toSubUnitId,ranges:addMergeCellRanges}},{id:sheets.AddWorksheetMergeMutation.id,params:{unitId,subUnitId:toSubUnitId,ranges:toMergeRanges}},{id:sheets.AddWorksheetMergeMutation.id,params:{unitId,subUnitId:fromSubUnitId,ranges:fromMergeRanges}}];redos=[{id:sheets.MoveRangeMutation.id,params:doMoveRangeMutation},...interceptorCommands.redos,...mergeRedos,{id:sheets.SetSelectionsOperation.id,params:{unitId,subUnitId:toSubUnitId,selections:[{range:toRange}]}}],undos=[{id:sheets.MoveRangeMutation.id,params:undoMoveRangeMutation},...interceptorCommands.undos,...mergeUndos,{id:sheets.SetSelectionsOperation.id,params:{unitId,sheetId:fromSubUnitId,selections:[{range:fromRange}]}}]}}return{undos,redos}}__name(getMoveRangeMutations,"getMoveRangeMutations");function getSetCellValueMutations(pasteTo,pasteFrom,matrix,accessor){const{unitId,subUnitId,range}=pasteTo,redoMutationsInfo=[],undoMutationsInfo=[],{mapFunc}=virtualizeDiscreteRanges([range]),valueMatrix=new core.ObjectMatrix;matrix.forValue((row,col,value)=>{var _a58;let originNumberValue;if(!value.p&&value.v&&!pasteFrom){const content=String(value.v),numfmtValue=core.numfmt.parseValue(content);(numfmtValue==null?void 0:numfmtValue.v)!==void 0&&typeof numfmtValue.v=="number"&&(originNumberValue=numfmtValue.v)}const{row:realRow,col:realCol}=mapFunc(row,col);(_a58=value.p)!=null&&_a58.body?valueMatrix.setValue(realRow,realCol,core.Tools.deepClone({p:value.p,v:originNumberValue!=null?originNumberValue:value.v})):valueMatrix.setValue(realRow,realCol,core.Tools.deepClone({v:originNumberValue!=null?originNumberValue:value.v,t:value.t}))});const setValuesMutation={unitId,subUnitId,cellValue:core.Tools.deepClone(valueMatrix.getMatrix())};redoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:setValuesMutation});const undoSetValuesMutation=sheets.SetRangeValuesUndoMutationFactory(accessor,setValuesMutation);return undoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:undoSetValuesMutation}),{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getSetCellValueMutations,"getSetCellValueMutations");function getSetCellCustomMutations(pasteTo,pasteFrom,matrix,accessor){const{unitId,subUnitId,range}=pasteTo,redoMutationsInfo=[],undoMutationsInfo=[],{mapFunc}=virtualizeDiscreteRanges([range]),valueMatrix=new core.ObjectMatrix;matrix.forValue((row,col,value)=>{const{row:realRow,col:realCol}=mapFunc(row,col);value.custom&&valueMatrix.setValue(realRow,realCol,core.Tools.deepClone({custom:value.custom}))});const setCustomMutation={unitId,subUnitId,cellValue:core.Tools.deepClone(valueMatrix.getMatrix())};redoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:setCustomMutation});const undoSetValuesMutation=sheets.SetRangeValuesUndoMutationFactory(accessor,setCustomMutation);return undoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:undoSetValuesMutation}),{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getSetCellCustomMutations,"getSetCellCustomMutations");function getSetCellStyleMutations(pasteTo,matrix,accessor,withRichFormat=!1){const redoMutationsInfo=[],undoMutationsInfo=[],{unitId,subUnitId,range}=pasteTo,valueMatrix=new core.ObjectMatrix,{mapFunc}=virtualizeDiscreteRanges([range]);matrix.forValue((row,col,value)=>{var _a58,_b;const newValue={s:Object.assign({},{...core.DEFAULT_STYLES,pd:engineRender.DEFAULT_PADDING_DATA,bg:null,cl:null},value.s)};withRichFormat&&((_a58=value.p)!=null&&_a58.body)&&(newValue.p=value.p);const content=String(value.v),numfmtValue=core.numfmt.parseValue(content);numfmtValue!=null&&numfmtValue.z&&(newValue.s||(newValue.s={}),typeof newValue.s=="object"&&((_b=newValue.s)!=null&&_b.n?newValue.s.n.pattern=numfmtValue.z:newValue.s.n={pattern:numfmtValue.z}));const{row:actualRow,col:actualCol}=mapFunc(row,col);valueMatrix.setValue(actualRow,actualCol,newValue)});const setValuesMutation={unitId,subUnitId,cellValue:core.Tools.deepClone(valueMatrix.getMatrix())};redoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:setValuesMutation});const undoSetValuesMutation=sheets.SetRangeValuesUndoMutationFactory(accessor,setValuesMutation);return undoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:undoSetValuesMutation}),{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getSetCellStyleMutations,"getSetCellStyleMutations");function getClearCellStyleMutations(pasteTo,matrix,accessor){const redoMutationsInfo=[],undoMutationsInfo=[],clearStyleMatrix=new core.ObjectMatrix,{unitId,subUnitId,range}=pasteTo,{mapFunc}=virtualizeDiscreteRanges([range]);if(matrix.forValue((row,col,value)=>{if(value.s){const{row:actualRow,col:actualCol}=mapFunc(row,col);clearStyleMatrix.setValue(actualRow,actualCol,{s:null})}}),clearStyleMatrix.getLength()>0){const clearMutation={subUnitId,unitId,cellValue:core.Tools.deepClone(clearStyleMatrix.getMatrix())};redoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:clearMutation});const undoClearMutation=sheets.SetRangeValuesUndoMutationFactory(accessor,clearMutation);undoMutationsInfo.push({id:sheets.SetRangeValuesMutation.id,params:undoClearMutation})}return{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getClearCellStyleMutations,"getClearCellStyleMutations");function getClearAndSetMergeMutations(pasteTo,matrix,accessor){const redoMutationsInfo=[],undoMutationsInfo=[],{unitId,subUnitId,range}=pasteTo,{startColumn,startRow,endColumn,endRow}=discreteRangeToRange(range),mergeRangeData=[];matrix.forValue((row,col,value)=>{if(value.rowSpan&&value.rowSpan>1){const colSpan=value.colSpan||1,mergeRange={startRow:startRow+row,endRow:startRow+row+value.rowSpan-1,startColumn:startColumn+col,endColumn:startColumn+col+colSpan-1};mergeRangeData.push(mergeRange)}else if(value.colSpan&&value.colSpan>1){const rowSpan=value.rowSpan||1,mergeRange={startRow:startRow+row,endRow:startRow+row+rowSpan-1,startColumn:startColumn+col,endColumn:startColumn+col+value.colSpan-1};mergeRangeData.push(mergeRange)}});const workbook=accessor.get(core.IUniverInstanceService).getUniverSheetInstance(unitId),worksheet=workbook==null?void 0:workbook.getSheetBySheetId(subUnitId);if(workbook&&worksheet){const mergedCellsInRange=worksheet.getMergeData().filter(rect=>core.Rectangle.intersects({startRow,startColumn,endRow,endColumn},rect)),removeMergeMutationParams={unitId,subUnitId,ranges:mergedCellsInRange};redoMutationsInfo.push({id:sheets.RemoveWorksheetMergeMutation.id,params:removeMergeMutationParams});const undoRemoveMergeMutationParams=sheets.RemoveMergeUndoMutationFactory(accessor,removeMergeMutationParams);undoMutationsInfo.push({id:sheets.AddWorksheetMergeMutation.id,params:undoRemoveMergeMutationParams})}const addMergeMutationParams={unitId,subUnitId,ranges:mergeRangeData};mergeRangeData.length>0&&redoMutationsInfo.push({id:sheets.AddWorksheetMergeMutation.id,params:addMergeMutationParams});const undoAddMergeMutation=sheets.AddMergeUndoMutationFactory(accessor,addMergeMutationParams);return mergeRangeData.length>0&&undoMutationsInfo.push({id:sheets.RemoveWorksheetMergeMutation.id,params:undoAddMergeMutation}),{undos:undoMutationsInfo,redos:redoMutationsInfo}}__name(getClearAndSetMergeMutations,"getClearAndSetMergeMutations");function generateBody(text){if(!text.includes("\r")&&core.Tools.isLegalUrl(text)){const id=core.generateRandomId(),urlText=`${core.DataStreamTreeTokenType.CUSTOM_RANGE_START}${text}${core.DataStreamTreeTokenType.CUSTOM_RANGE_END}`,range={startIndex:0,endIndex:urlText.length-1,rangeId:id,rangeType:core.CustomRangeType.HYPERLINK,properties:{url:text}};return{dataStream:`${urlText}\r