@univerjs/sheets-ui 0.2.7 → 0.2.9

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.
Files changed (216) hide show
  1. package/lib/cjs/index.js +6 -6
  2. package/lib/es/index.js +930 -750
  3. package/lib/index.css +1 -1
  4. package/lib/types/basics/editor/get-editor-object.d.ts +0 -1
  5. package/lib/types/commands/commands/__tests__/create-command-test-bed.d.ts +0 -1
  6. package/lib/types/commands/commands/__tests__/create-selection-command-test-bed.d.ts +0 -1
  7. package/lib/types/commands/commands/add-worksheet-merge.command.d.ts +0 -1
  8. package/lib/types/commands/commands/auto-fill.command.d.ts +0 -1
  9. package/lib/types/commands/commands/clipboard.command.d.ts +0 -1
  10. package/lib/types/commands/commands/delete-range-move-left-confirm.command.d.ts +0 -1
  11. package/lib/types/commands/commands/delete-range-move-up-confirm.command.d.ts +0 -1
  12. package/lib/types/commands/commands/hide-row-col-confirm.command.d.ts +0 -1
  13. package/lib/types/commands/commands/inline-format.command.d.ts +0 -1
  14. package/lib/types/commands/commands/insert-range-move-down-confirm.command.d.ts +0 -1
  15. package/lib/types/commands/commands/insert-range-move-right-confirm.command.d.ts +0 -1
  16. package/lib/types/commands/commands/range-protection.command.d.ts +0 -1
  17. package/lib/types/commands/commands/refill.command.d.ts +0 -1
  18. package/lib/types/commands/commands/remove-row-col-confirm.command.d.ts +0 -1
  19. package/lib/types/commands/commands/remove-sheet-confirm.command.d.ts +0 -1
  20. package/lib/types/commands/commands/set-format-painter.command.d.ts +0 -1
  21. package/lib/types/commands/commands/set-frozen.command.d.ts +0 -1
  22. package/lib/types/commands/commands/set-scroll.command.d.ts +0 -1
  23. package/lib/types/commands/commands/set-selection.command.d.ts +0 -1
  24. package/lib/types/commands/commands/set-zoom-ratio.command.d.ts +0 -1
  25. package/lib/types/commands/commands/unhide.command.d.ts +0 -1
  26. package/lib/types/commands/commands/utils/selection-utils.d.ts +0 -1
  27. package/lib/types/commands/commands/worksheet-protection.command.d.ts +0 -1
  28. package/lib/types/commands/operations/activate-cell-edit.operation.d.ts +0 -1
  29. package/lib/types/commands/operations/cell-edit.operation.d.ts +0 -1
  30. package/lib/types/commands/operations/rename-sheet.operation.d.ts +0 -1
  31. package/lib/types/commands/operations/scroll-to-range.operation.d.ts +0 -1
  32. package/lib/types/commands/operations/scroll.operation.d.ts +0 -1
  33. package/lib/types/commands/operations/set-format-painter.operation.d.ts +0 -1
  34. package/lib/types/commands/operations/set-zoom-ratio.operation.d.ts +0 -1
  35. package/lib/types/commands/operations/sheet-permission-open-dialog.operation.d.ts +0 -1
  36. package/lib/types/commands/operations/sheet-permission-open-panel.operation.d.ts +0 -1
  37. package/lib/types/commands/operations/sidebar-defined-name.operation.d.ts +0 -1
  38. package/lib/types/common/utils.d.ts +0 -1
  39. package/lib/types/components/border-panel/BorderPanel.d.ts +0 -1
  40. package/lib/types/components/border-panel/border-line/BorderLine.d.ts +0 -1
  41. package/lib/types/components/border-panel/border-line/icons/BorderDashDot.d.ts +0 -1
  42. package/lib/types/components/border-panel/border-line/icons/BorderDashDotDot.d.ts +0 -1
  43. package/lib/types/components/border-panel/border-line/icons/BorderDashed.d.ts +0 -1
  44. package/lib/types/components/border-panel/border-line/icons/BorderDotted.d.ts +0 -1
  45. package/lib/types/components/border-panel/border-line/icons/BorderHair.d.ts +0 -1
  46. package/lib/types/components/border-panel/border-line/icons/BorderMedium.d.ts +0 -1
  47. package/lib/types/components/border-panel/border-line/icons/BorderMediumDashDot.d.ts +0 -1
  48. package/lib/types/components/border-panel/border-line/icons/BorderMediumDashDotDot.d.ts +0 -1
  49. package/lib/types/components/border-panel/border-line/icons/BorderMediumDashed.d.ts +0 -1
  50. package/lib/types/components/border-panel/border-line/icons/BorderThick.d.ts +0 -1
  51. package/lib/types/components/border-panel/border-line/icons/BorderThin.d.ts +0 -1
  52. package/lib/types/components/border-panel/interface.d.ts +0 -1
  53. package/lib/types/components/hook.d.ts +0 -1
  54. package/lib/types/components/menu-item-input/MenuItemInput.d.ts +0 -1
  55. package/lib/types/components/menu-item-input/interface.d.ts +0 -1
  56. package/lib/types/{basics/const → consts}/permission.d.ts +0 -1
  57. package/lib/types/{basics/const → consts}/ui-name.d.ts +2 -1
  58. package/lib/types/controllers/active-worksheet/active-worksheet.controller.d.ts +0 -1
  59. package/lib/types/controllers/auto-fill.controller.d.ts +0 -1
  60. package/lib/types/controllers/auto-height.controller.d.ts +0 -1
  61. package/lib/types/controllers/cell-alert.controller.d.ts +0 -1
  62. package/lib/types/controllers/cell-custom-render.controller.d.ts +0 -1
  63. package/lib/types/controllers/clipboard/clipboard.controller.d.ts +0 -1
  64. package/lib/types/controllers/clipboard/utils.d.ts +0 -1
  65. package/lib/types/controllers/defined-name/defined-name.controller.d.ts +0 -1
  66. package/lib/types/controllers/drag-render.controller.d.ts +0 -1
  67. package/lib/types/controllers/editor/__tests__/create-test-bed.d.ts +0 -1
  68. package/lib/types/controllers/editor/__tests__/mock-function.service.d.ts +0 -1
  69. package/lib/types/controllers/editor/editing.render-controller.d.ts +0 -1
  70. package/lib/types/controllers/editor/formula-editor.controller.d.ts +0 -1
  71. package/lib/types/controllers/force-string-alert-render.controller.d.ts +0 -1
  72. package/lib/types/controllers/force-string-render.controller.d.ts +0 -1
  73. package/lib/types/controllers/format-painter/format-painter.controller.d.ts +0 -1
  74. package/lib/types/controllers/hover-render.controller.d.ts +0 -1
  75. package/lib/types/controllers/mark-selection.controller.d.ts +0 -1
  76. package/lib/types/controllers/menu/__tests__/create-menu-test-bed.d.ts +0 -1
  77. package/lib/types/controllers/menu/border.menu.d.ts +0 -1
  78. package/lib/types/controllers/menu/clear.menu.d.ts +0 -1
  79. package/lib/types/controllers/menu/delete.menu.d.ts +0 -1
  80. package/lib/types/controllers/menu/insert.menu.d.ts +0 -1
  81. package/lib/types/controllers/menu/menu-util.d.ts +0 -1
  82. package/lib/types/controllers/menu/menu.d.ts +2 -2
  83. package/lib/types/controllers/menu/merge.menu.d.ts +0 -1
  84. package/lib/types/controllers/menu/permission-menu-util.d.ts +0 -1
  85. package/lib/types/controllers/menu/permission.menu.d.ts +0 -1
  86. package/lib/types/controllers/menu/sheet.menu.d.ts +0 -1
  87. package/lib/types/controllers/mobile/mobile-sheet-ui.controller.d.ts +0 -1
  88. package/lib/types/controllers/move-range.controller.d.ts +0 -1
  89. package/lib/types/controllers/permission/sheet-permission-init.controller.d.ts +5 -3
  90. package/lib/types/controllers/permission/sheet-permission-interceptor-base.controller.d.ts +0 -1
  91. package/lib/types/controllers/permission/sheet-permission-interceptor-canvas-render.controller.d.ts +0 -1
  92. package/lib/types/controllers/permission/sheet-permission-interceptor-clipboard.controller.d.ts +0 -1
  93. package/lib/types/controllers/permission/sheet-permission-interceptor-formula-render.controller.d.ts +0 -1
  94. package/lib/types/controllers/permission/sheet-permission-render.controller.d.ts +0 -1
  95. package/lib/types/controllers/render-controllers/contextmenu.render-controller.d.ts +0 -1
  96. package/lib/types/controllers/render-controllers/editor-bridge.render-controller.d.ts +0 -1
  97. package/lib/types/controllers/render-controllers/format-painter.render-controller.d.ts +0 -1
  98. package/lib/types/controllers/render-controllers/freeze.render-controller.d.ts +0 -1
  99. package/lib/types/controllers/render-controllers/header-menu.render-controller.d.ts +0 -1
  100. package/lib/types/controllers/render-controllers/header-move.render-controller.d.ts +0 -1
  101. package/lib/types/controllers/render-controllers/header-resize.render-controller.d.ts +0 -1
  102. package/lib/types/controllers/render-controllers/header-unhide.render-controller.d.ts +0 -1
  103. package/lib/types/controllers/render-controllers/mobile/mobile-contextmenu.render-controller.d.ts +0 -1
  104. package/lib/types/controllers/render-controllers/mobile/mobile-scroll.render-controller.d.ts +0 -1
  105. package/lib/types/controllers/render-controllers/scroll.render-controller.d.ts +0 -1
  106. package/lib/types/controllers/render-controllers/sheet.render-controller.d.ts +1 -2
  107. package/lib/types/controllers/render-controllers/skeleton.render-controller.d.ts +0 -1
  108. package/lib/types/controllers/render-controllers/zoom.render-controller.d.ts +4 -1
  109. package/lib/types/controllers/sheet-ui.controller.d.ts +0 -1
  110. package/lib/types/controllers/shortcuts/editor.shortcut.d.ts +0 -1
  111. package/lib/types/controllers/shortcuts/operation.shortcut.d.ts +0 -1
  112. package/lib/types/controllers/shortcuts/selection.shortcut.d.ts +0 -1
  113. package/lib/types/controllers/shortcuts/style.shortcut.d.ts +0 -1
  114. package/lib/types/controllers/shortcuts/utils.d.ts +0 -1
  115. package/lib/types/controllers/shortcuts/value.shortcut.d.ts +0 -1
  116. package/lib/types/controllers/shortcuts/view.shortcut.d.ts +0 -1
  117. package/lib/types/controllers/status-bar.controller.d.ts +0 -1
  118. package/lib/types/controllers/utils/char-tools.d.ts +0 -1
  119. package/lib/types/controllers/utils/component-tools.d.ts +0 -1
  120. package/lib/types/controllers/utils/range-tools.d.ts +0 -1
  121. package/lib/types/controllers/utils/selections-tools.d.ts +0 -1
  122. package/lib/types/hooks/useHighlightRange.d.ts +0 -1
  123. package/lib/types/index.d.ts +2 -1
  124. package/lib/types/locale/en-US.d.ts +0 -1
  125. package/lib/types/locale/ru-RU.d.ts +0 -1
  126. package/lib/types/locale/vi-VN.d.ts +0 -1
  127. package/lib/types/locale/zh-TW.d.ts +0 -1
  128. package/lib/types/mobile-sheets-ui-plugin.d.ts +0 -1
  129. package/lib/types/services/auto-fill/auto-fill.service.d.ts +0 -1
  130. package/lib/types/services/auto-fill/rules.d.ts +0 -1
  131. package/lib/types/services/auto-fill/tools.d.ts +0 -1
  132. package/lib/types/services/auto-fill/type.d.ts +0 -1
  133. package/lib/types/services/canvas-pop-manager.service.d.ts +1 -2
  134. package/lib/types/services/cell-alert-manager.service.d.ts +0 -1
  135. package/lib/types/services/clipboard/__tests__/clipboard-test-bed.d.ts +0 -1
  136. package/lib/types/services/clipboard/clipboard.service.d.ts +0 -1
  137. package/lib/types/services/clipboard/copy-content-cache.d.ts +0 -1
  138. package/lib/types/services/clipboard/html-to-usm/converter.d.ts +0 -1
  139. package/lib/types/services/clipboard/html-to-usm/parse-node-style.d.ts +0 -1
  140. package/lib/types/services/clipboard/html-to-usm/paste-plugins/plugin-lark.d.ts +0 -1
  141. package/lib/types/services/clipboard/html-to-usm/paste-plugins/plugin-univer.d.ts +0 -1
  142. package/lib/types/services/clipboard/html-to-usm/paste-plugins/plugin-word.d.ts +0 -1
  143. package/lib/types/services/clipboard/html-to-usm/paste-plugins/type.d.ts +0 -1
  144. package/lib/types/services/clipboard/html-to-usm/utils.d.ts +0 -1
  145. package/lib/types/services/clipboard/type.d.ts +0 -1
  146. package/lib/types/services/clipboard/usm-to-html/convertor.d.ts +0 -1
  147. package/lib/types/services/clipboard/utils.d.ts +0 -1
  148. package/lib/types/services/drag-manager.service.d.ts +0 -1
  149. package/lib/types/services/editor/cell-editor-manager.service.d.ts +0 -1
  150. package/lib/types/services/editor/formula-editor-manager.service.d.ts +0 -1
  151. package/lib/types/services/editor-bridge.service.d.ts +0 -1
  152. package/lib/types/services/format-painter/format-painter.service.d.ts +0 -1
  153. package/lib/types/services/hover-manager.service.d.ts +0 -1
  154. package/lib/types/services/mark-selection/mark-selection.service.d.ts +0 -1
  155. package/lib/types/services/permission/sheet-permission-panel.model.d.ts +9 -1
  156. package/lib/types/services/permission/sheet-permission-user-list.service.d.ts +1 -1
  157. package/lib/types/services/permission/worksheet-permission-render.service.d.ts +0 -1
  158. package/lib/types/services/print-interceptor.service.d.ts +0 -1
  159. package/lib/types/services/scroll-manager.service.d.ts +0 -1
  160. package/lib/types/services/selection/base-selection-render.service.d.ts +38 -39
  161. package/lib/types/services/selection/const.d.ts +0 -1
  162. package/lib/types/services/selection/mobile-selection-render.service.d.ts +3 -5
  163. package/lib/types/services/selection/mobile-selection-shape.d.ts +1 -2
  164. package/lib/types/services/selection/selection-render-model.d.ts +7 -4
  165. package/lib/types/services/selection/selection-render.service.d.ts +3 -7
  166. package/lib/types/services/selection/selection-shape-extension.d.ts +13 -4
  167. package/lib/types/services/selection/selection-shape.d.ts +22 -18
  168. package/lib/types/services/selection/util.d.ts +0 -1
  169. package/lib/types/services/sheet-bar/sheet-bar.service.d.ts +0 -1
  170. package/lib/types/services/sheet-skeleton-manager.service.d.ts +0 -1
  171. package/lib/types/services/sheets-render.service.d.ts +0 -1
  172. package/lib/types/services/shortcut-experience.service.d.ts +0 -1
  173. package/lib/types/services/status-bar.service.d.ts +0 -1
  174. package/lib/types/services/utils/selection-util.d.ts +0 -1
  175. package/lib/types/sheets-ui-plugin.d.ts +1 -2
  176. package/lib/types/views/cell-alert/CellAlertPopup.d.ts +0 -1
  177. package/lib/types/views/count-bar/CountBar.d.ts +0 -1
  178. package/lib/types/views/count-bar/ZoomSlider.d.ts +0 -1
  179. package/lib/types/views/defined-name/DefinedName.d.ts +0 -1
  180. package/lib/types/views/defined-name/DefinedNameContainer.d.ts +0 -1
  181. package/lib/types/views/defined-name/DefinedNameInput.d.ts +0 -1
  182. package/lib/types/views/defined-name/DefinedNameOverlay.d.ts +0 -1
  183. package/lib/types/views/editor-container/EditorContainer.d.ts +0 -1
  184. package/lib/types/views/formula-bar/FormulaBar.d.ts +0 -1
  185. package/lib/types/views/header-menu-shape.d.ts +0 -1
  186. package/lib/types/views/header-resize-shape.d.ts +0 -1
  187. package/lib/types/views/header-unhide-shape.d.ts +0 -1
  188. package/lib/types/views/mobile/sheet-bar/MobileSheetBar.d.ts +0 -1
  189. package/lib/types/views/operate-container/AutoFillPopupMenu.d.ts +0 -1
  190. package/lib/types/views/operate-container/OperateContainer.d.ts +0 -1
  191. package/lib/types/views/permission/error-msg-dialog/index.d.ts +0 -1
  192. package/lib/types/views/permission/extensions/range-protection.render.d.ts +0 -1
  193. package/lib/types/views/permission/extensions/worksheet-permission.render.d.ts +0 -1
  194. package/lib/types/views/permission/footer/index.d.ts +0 -1
  195. package/lib/types/views/permission/footer/permission-detail-footer.d.ts +0 -1
  196. package/lib/types/views/permission/footer/permission-list-footer.d.ts +0 -1
  197. package/lib/types/views/permission/panel/index.d.ts +1 -2
  198. package/lib/types/views/permission/panel-detail/index.d.ts +0 -1
  199. package/lib/types/views/permission/panel-list/index.d.ts +0 -1
  200. package/lib/types/views/permission/permission-dialog/index.d.ts +0 -1
  201. package/lib/types/views/permission/spin/index.d.ts +0 -1
  202. package/lib/types/views/permission/user-dialog/index.d.ts +0 -1
  203. package/lib/types/views/sheet-bar/SheetBar.d.ts +0 -1
  204. package/lib/types/views/sheet-bar/sheet-bar-button/SheetBarButton.d.ts +0 -1
  205. package/lib/types/views/sheet-bar/sheet-bar-menu/SheetBarMenu.d.ts +0 -1
  206. package/lib/types/views/sheet-bar/sheet-bar-tabs/SheetBarItem.d.ts +0 -1
  207. package/lib/types/views/sheet-bar/sheet-bar-tabs/SheetBarTabs.d.ts +0 -1
  208. package/lib/types/views/sheet-bar/sheet-bar-tabs/utils/slide-tab-bar.d.ts +0 -1
  209. package/lib/types/views/sheet-container/SheetContainer.d.ts +0 -1
  210. package/lib/types/views/status-bar/CopyableStatisticItem.d.ts +0 -1
  211. package/lib/types/views/status-bar/StatusBar.d.ts +0 -1
  212. package/lib/umd/index.js +6 -6
  213. package/package.json +19 -21
  214. package/lib/types/basics/const/index.d.ts +0 -17
  215. package/lib/types/basics/index.d.ts +0 -16
  216. /package/lib/types/{basics/const → consts}/plugin-name.d.ts +0 -0
package/lib/es/index.js CHANGED
@@ -3,19 +3,18 @@ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { en
3
3
  var __name = (target, value) => __defProp(target, "name", { value, configurable: !0 });
4
4
  var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key != "symbol" ? key + "" : key, value);
5
5
  import { DOCS_VIEW_KEY, SetInlineFormatBoldCommand, SetInlineFormatItalicCommand, SetInlineFormatUnderlineCommand, SetInlineFormatStrikethroughCommand, SetInlineFormatSubscriptCommand, SetInlineFormatSuperscriptCommand, SetInlineFormatFontSizeCommand, SetInlineFormatFontFamilyCommand, SetInlineFormatTextColorCommand, SetTextSelectionsOperation, SetInlineFormatCommand, TextSelectionManagerService, BreakLineCommand, DeleteLeftCommand, CoverContentCommand, RichTextEditingMutation, DocSkeletonManagerService, VIEWPORT_KEY, DOCS_COMPONENT_MAIN_LAYER_INDEX, MoveSelectionOperation, MoveCursorOperation, IMEInputCommand, InsertCommand } from "@univerjs/docs";
6
- import { Disposable, Inject, Injector, CommandType, IUniverInstanceService, ICommandService, UniverInstanceType, LocaleService, Direction, Rectangle, getReverseDirection, RANGE_TYPE, Tools, Workbook, toDisposable, IContextService, UserManagerService, FOCUSING_COMMON_DRAWINGS, IPermissionService, RxDisposable, OnLifecycle, LifecycleStages, ObjectMatrix, isFormulaString, isFormulaId, CellValueType, createIdentifier, IUndoRedoService, createInterceptorKey, makeCellToSelection, ColorKit, Quantity, InterceptorManager, DOCS_NORMAL_EDITOR_UNIT_ID_KEY, EDITOR_ACTIVATED, FOCUSING_EDITOR_STANDALONE, FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE, ThemeService, FOCUSING_SHEET, DisposableCollection, getCellInfoInMergeData, sortRules, sequenceExecute, Dimension, ILogService, BorderStyleTypes, useDependency, DEFAULT_EMPTY_DOCUMENT_VALUE, DocumentFlavor, DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY, HorizontalAlign, VerticalAlign, WrapStrategy, BooleanNumber, FOCUSING_UNIVER_EDITOR, FOCUSING_EDITOR_INPUT_FORMULA, FOCUSING_FX_BAR_EDITOR, LRUMap, BaselineOffset, DataStreamTreeTokenType, skipParseTagNames, ErrorService, extractPureTextFromCell, FontWeight, FontItalic, DEFAULT_STYLES, nameCharacterCheck, debounce, createInternalEditorID, AbsoluteRefType, NilCommand, connectInjector, Range, cellToRange, convertBodyToHtml, handleStyleToString, DEFAULT_WORKSHEET_ROW_HEIGHT, DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY, DEFAULT_WORKSHEET_COLUMN_WIDTH, Optional, IConfigService, FOCUSING_EDITOR_BUT_HIDDEN, LocaleType, IResourceLoaderService, isRealNum, isICellData, IAuthzIoService, isValidRange, Plugin, mergeOverrideWithDependencies, DependentOn } from "@univerjs/core";
6
+ import { Disposable, Inject, Injector, CommandType, IUniverInstanceService, ICommandService, UniverInstanceType, LocaleService, Direction, Rectangle, getReverseDirection, RANGE_TYPE, Tools, Workbook, toDisposable, IContextService, UserManagerService, FOCUSING_COMMON_DRAWINGS, IPermissionService, RxDisposable, OnLifecycle, LifecycleStages, ObjectMatrix, isFormulaString, isFormulaId, CellValueType, numfmt, createIdentifier, IUndoRedoService, createInterceptorKey, makeCellToSelection, ColorKit, Quantity, InterceptorManager, DOCS_NORMAL_EDITOR_UNIT_ID_KEY, EDITOR_ACTIVATED, FOCUSING_EDITOR_STANDALONE, FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE, ThemeService, FOCUSING_SHEET, DisposableCollection, getCellInfoInMergeData, sortRules, sequenceExecute, Dimension, ILogService, BorderStyleTypes, useDependency, DEFAULT_EMPTY_DOCUMENT_VALUE, DocumentFlavor, DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY, HorizontalAlign, VerticalAlign, WrapStrategy, BooleanNumber, FOCUSING_UNIVER_EDITOR, FOCUSING_EDITOR_INPUT_FORMULA, FOCUSING_FX_BAR_EDITOR, LRUMap, BaselineOffset, DataStreamTreeTokenType, skipParseTagNames, ErrorService, extractPureTextFromCell, FontWeight, FontItalic, DEFAULT_STYLES, nameCharacterCheck, debounce, createInternalEditorID, AbsoluteRefType, NilCommand, connectInjector, Range, cellToRange, convertBodyToHtml, handleStyleToString, DEFAULT_WORKSHEET_ROW_HEIGHT, DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY, DEFAULT_WORKSHEET_COLUMN_WIDTH, Optional, IConfigService, FOCUSING_EDITOR_BUT_HIDDEN, LocaleType, IResourceLoaderService, isRealNum, isICellData, IAuthzIoService, isValidRange, Plugin, mergeOverrideWithDependencies, DependentOn } from "@univerjs/core";
7
7
  import { SpreadsheetSkeleton, IRenderManagerService, Vector2, SHEET_VIEWPORT_KEY as SHEET_VIEWPORT_KEY$1, RENDER_RAW_FORMULA_KEY, Spreadsheet, Rect, DashedRect, Group, TRANSFORM_CHANGE_OBSERVABLE_TYPE, cancelRequestFrame, requestNewFrame, FIX_ONE_PIXEL_BLUR_OFFSET, CURSOR_TYPE, ScrollTimer, ScrollTimerType, isRectIntersect, DeviceInputEventType, getCanvasOffsetByEngine, convertTextRotation, ptToPixel, hasCJKText, ITextSelectionRenderManager, DEFAULT_PADDING_DATA, ptToPx, ScrollBar, fixLineWidthByScale, Shape, RegularPolygon, Layer, SpreadsheetRowHeader, SpreadsheetColumnHeader, Viewport, PointerInput, RENDER_CLASS_TYPE, SheetExtension } from "@univerjs/engine-render";
8
- import { getSheetCommandTarget, alignToMergedCellsBorders, getSelectionsService, getCellAtRowCol, SetSelectionsOperation, expandToContinuousRange, ScrollToCellOperation, SheetsSelectionsService, RangeProtectionRuleModel, WorksheetProtectionRuleModel, WorkbookEditablePermission, WorkbookManageCollaboratorPermission, generateNullCellValue, SetRangeValuesUndoMutationFactory, SetRangeValuesMutation, SELECTION_CONTROL_BORDER_BUFFER_COLOR, getNormalSelectionStyle, SELECTION_CONTROL_BORDER_BUFFER_WIDTH, transformCellDataToSelectionData, IRefSelectionsService, SetRangeValuesCommand, SetWorksheetActiveOperation, MoveRangeMutation, RemoveRowMutation, RemoveColMutation, InsertRowMutation, InsertColMutation, MoveRowsMutation, MoveColsMutation, SetWorksheetColWidthMutation, SetWorksheetRowHeightMutation, RemoveSheetMutation, RemoveMergeUndoMutationFactory, RemoveWorksheetMergeMutation, AddWorksheetMergeMutation, getAddMergeMutationRangeByType, AddMergeUndoMutationFactory, AddMergeRedoSelectionsOperationFactory, AddMergeUndoSelectionsOperationFactory, DeleteRangeMoveLeftCommand, DeleteRangeMoveUpCommand, SetRowHiddenCommand, SetColHiddenCommand, SetBoldCommand, SetItalicCommand, SetUnderlineCommand, SetStrikeThroughCommand, SetFontSizeCommand, SetFontFamilyCommand, SetTextColorCommand, InsertRangeMoveDownCommand, InsertRangeMoveRightCommand, RemoveRowCommand, RemoveColCommand, RemoveSheetCommand, SetFrozenMutationFactory, SetFrozenMutation, BorderStyleManagerService, RangeProtectionPermissionEditPoint, WorksheetSetCellValuePermission, WorksheetEditPermission, SetWorksheetOrderMutation, InsertSheetMutation, SetWorksheetNameMutation, SetWorksheetHideMutation, SetWorksheetShowCommand, SetWorksheetActivateCommand, getPrimaryForRange, WorksheetCopyPermission, WorksheetSetCellStylePermission, ResetTextColorCommand, ResetBackgroundColorCommand, SetBackgroundColorCommand, SetHorizontalTextAlignCommand, SetVerticalTextAlignCommand, SetTextWrapCommand, SetTextRotationCommand, WorkbookCopyPermission, RangeProtectionPermissionViewPoint, WorksheetSetColumnStylePermission, WorksheetSetRowStylePermission, SetWorksheetRowIsAutoHeightCommand, SetRowHiddenMutation, SetRowVisibleMutation, SetSelectedRowsVisibleCommand, SetColHiddenMutation, SetColVisibleMutation, SetSelectedColsVisibleCommand, SetRowHeightCommand, SetWorksheetRowIsAutoHeightMutation, SetColWidthCommand, SetWorksheetNameCommand, SetWorksheetOrderCommand, WorkbookRenameSheetPermission, SetTabColorMutation, WorkbookCreateSheetPermission, InsertSheetCommand, InsertDefinedNameCommand, SetDefinedNameCommand, RemoveDefinedNameCommand, AddWorksheetProtectionMutation, DeleteWorksheetProtectionMutation, SetWorksheetProtectionMutation, AddRangeProtectionMutation, DeleteRangeProtectionMutation, SetRangeProtectionMutation, ClearSelectionContentCommand, ClearSelectionFormatCommand, ClearSelectionAllCommand, WorksheetDeleteColumnPermission, WorksheetDeleteRowPermission, WorksheetInsertColumnPermission, WorksheetInsertRowPermission, InsertRowBeforeCommand, InsertRowAfterCommand, InsertColBeforeCommand, InsertColAfterCommand, CopySheetCommand, SetTabColorCommand, SetWorksheetHideCommand, WorkbookDeleteSheetPermission, WorkbookHideSheetPermission, SetBorderBasicCommand, MergeCellController, MERGE_CELL_INTERCEPTOR_CHECK, RemoveWorksheetMergeCommand, DISABLE_NORMAL_SELECTIONS, SelectionMoveType, convertSelectionDataToRange, SetWorksheetRowAutoHeightMutationFactory, SetWorksheetRowAutoHeightMutation, SetStyleCommand, SheetInterceptorService, MoveRangeCommand, MAX_CELL_PER_SHEET_KEY, SetFrozenCommand, InsertRowCommand, InsertColCommand, MoveColsCommand, MoveRowsCommand, DeltaRowHeightCommand, DeltaColumnWidthCommand, SetSpecificRowsVisibleCommand, SetSpecificColsVisibleCommand, INumfmtService, COMMAND_LISTENER_SKELETON_CHANGE, COMMAND_LISTENER_VALUE_CHANGE, RefRangeService, INTERCEPTOR_POINT, WorkbookMoveSheetPermission, WorksheetViewPermission, getAllRangePermissionPoint, getAllWorksheetPermissionPointByPointPanel, defaultWorkbookPermissionPoints, getAllWorkbookPermissionPoint, getAllWorksheetPermissionPoint, defaultWorksheetPermissionPoint, WorksheetProtectionPointModel, RangeProtectionRenderModel, setEndForRange, DeleteRangeProtectionCommand, AddRangeProtectionCommand as AddRangeProtectionCommand$1, SetWorksheetPermissionPointsCommand, UniverSheetsPlugin } from "@univerjs/sheets";
8
+ import { getSheetCommandTarget, alignToMergedCellsBorders, getSelectionsService, getCellAtRowCol, SetSelectionsOperation, expandToContinuousRange, ScrollToCellOperation, SheetsSelectionsService, RangeProtectionRuleModel, WorksheetProtectionRuleModel, WorkbookEditablePermission, WorkbookManageCollaboratorPermission, generateNullCellValue, SetRangeValuesUndoMutationFactory, SetRangeValuesMutation, SELECTION_CONTROL_BORDER_BUFFER_COLOR, getNormalSelectionStyle, SELECTION_CONTROL_BORDER_BUFFER_WIDTH, transformCellDataToSelectionData, IRefSelectionsService, SetRangeValuesCommand, SetWorksheetActiveOperation, MoveRangeMutation, RemoveRowMutation, RemoveColMutation, InsertRowMutation, InsertColMutation, MoveRowsMutation, MoveColsMutation, SetWorksheetColWidthMutation, SetWorksheetRowHeightMutation, RemoveSheetMutation, AddMergeUndoMutationFactory, RemoveWorksheetMergeMutation, AddWorksheetMergeMutation, getAddMergeMutationRangeByType, RemoveMergeUndoMutationFactory, AddMergeRedoSelectionsOperationFactory, AddMergeUndoSelectionsOperationFactory, DeleteRangeMoveLeftCommand, DeleteRangeMoveUpCommand, SetRowHiddenCommand, SetColHiddenCommand, SetBoldCommand, SetItalicCommand, SetUnderlineCommand, SetStrikeThroughCommand, SetFontSizeCommand, SetFontFamilyCommand, SetTextColorCommand, InsertRangeMoveDownCommand, InsertRangeMoveRightCommand, RemoveRowCommand, RemoveColCommand, RemoveSheetCommand, SetFrozenMutationFactory, SetFrozenMutation, BorderStyleManagerService, RangeProtectionPermissionEditPoint, WorksheetSetCellValuePermission, WorksheetEditPermission, SetWorksheetOrderMutation, InsertSheetMutation, SetWorksheetNameMutation, SetWorksheetHideMutation, SetWorksheetShowCommand, SetWorksheetActivateCommand, getPrimaryForRange, WorksheetCopyPermission, WorksheetSetCellStylePermission, ResetTextColorCommand, ResetBackgroundColorCommand, SetBackgroundColorCommand, SetHorizontalTextAlignCommand, SetVerticalTextAlignCommand, SetTextWrapCommand, SetTextRotationCommand, WorkbookCopyPermission, RangeProtectionPermissionViewPoint, WorksheetSetColumnStylePermission, WorksheetSetRowStylePermission, SetWorksheetRowIsAutoHeightCommand, SetRowHiddenMutation, SetRowVisibleMutation, SetSelectedRowsVisibleCommand, SetColHiddenMutation, SetColVisibleMutation, SetSelectedColsVisibleCommand, SetRowHeightCommand, SetWorksheetRowIsAutoHeightMutation, SetColWidthCommand, SetWorksheetNameCommand, SetWorksheetOrderCommand, WorkbookRenameSheetPermission, SetTabColorMutation, WorkbookCreateSheetPermission, InsertSheetCommand, InsertDefinedNameCommand, SetDefinedNameCommand, RemoveDefinedNameCommand, AddWorksheetProtectionMutation, DeleteWorksheetProtectionMutation, SetWorksheetProtectionMutation, AddRangeProtectionMutation, DeleteRangeProtectionMutation, SetRangeProtectionMutation, ClearSelectionContentCommand, ClearSelectionFormatCommand, ClearSelectionAllCommand, WorksheetDeleteColumnPermission, WorksheetDeleteRowPermission, WorksheetInsertColumnPermission, WorksheetInsertRowPermission, InsertRowBeforeCommand, InsertRowAfterCommand, InsertColBeforeCommand, InsertColAfterCommand, CopySheetCommand, SetTabColorCommand, SetWorksheetHideCommand, WorkbookDeleteSheetPermission, WorkbookHideSheetPermission, SetBorderBasicCommand, MergeCellController, MERGE_CELL_INTERCEPTOR_CHECK, RemoveWorksheetMergeCommand, DISABLE_NORMAL_SELECTIONS, SelectionMoveType, convertSelectionDataToRange, SetWorksheetRowAutoHeightMutationFactory, SetWorksheetRowAutoHeightMutation, SetStyleCommand, SheetInterceptorService, MoveRangeCommand, MAX_CELL_PER_SHEET_KEY, SetFrozenCommand, InsertRowCommand, InsertColCommand, MoveColsCommand, MoveRowsCommand, DeltaRowHeightCommand, DeltaColumnWidthCommand, SetSpecificRowsVisibleCommand, SetSpecificColsVisibleCommand, INumfmtService, COMMAND_LISTENER_SKELETON_CHANGE, COMMAND_LISTENER_VALUE_CHANGE, RefRangeService, INTERCEPTOR_POINT, WorkbookMoveSheetPermission, WorksheetViewPermission, getAllRangePermissionPoint, getAllWorksheetPermissionPointByPointPanel, defaultWorkbookPermissionPoints, getAllWorkbookPermissionPoint, getAllWorksheetPermissionPoint, defaultWorksheetPermissionPoint, WorksheetProtectionPointModel, RangeProtectionRenderModel, DeleteRangeProtectionCommand, setEndForRange, AddRangeProtectionCommand as AddRangeProtectionCommand$1, SetWorksheetPermissionPointsCommand, UniverSheetsPlugin } from "@univerjs/sheets";
9
9
  import { BehaviorSubject, switchMap, of, combineLatest, startWith, map, takeUntil, distinctUntilChanged, Subject, merge, EMPTY, Observable, combineLatestWith, filter, Subscription, throttleTime } from "rxjs";
10
- import { KeyCode, IEditorService, IConfirmService, ComponentManager, useObservable, DISABLE_AUTO_FOCUS_KEY, TextEditor, ISidebarService, ProgressBar, DEFAULT_BACKGROUND_COLOR_RGB, DEFAULT_BACKGROUND_COLOR_RGBA, handleStringToStyle, textTrim, PLAIN_TEXT_CLIPBOARD_MIME_TYPE, HTML_CLIPBOARD_MIME_TYPE, IClipboardInterfaceService, INotificationService, IPlatformService, CopyCommand, CutCommand, PasteCommand, MenuGroup, MenuItemType, MenuPosition, getMenuHiddenObservable, FONT_FAMILY_LIST, FONT_SIZE_LIST, Menu as Menu$1, IMessageService, RangeSelector, IDialogService, MetaKeys, FontFamily, FontFamilyItem, FontSize, BuiltInUIPart, ILayoutService, IShortcutService, IMenuService, IUIPartsService, SetEditorResizeOperation, IContextMenuService, ICanvasPopupService, IRangeSelectorService, UniverMobileUIPlugin } from "@univerjs/ui";
11
- import { numfmt } from "@univerjs/engine-numfmt";
10
+ import { KeyCode, IEditorService, IConfirmService, ComponentManager, useObservable, DISABLE_AUTO_FOCUS_KEY, TextEditor, ISidebarService, ProgressBar, DEFAULT_BACKGROUND_COLOR_RGB, DEFAULT_BACKGROUND_COLOR_RGBA, handleStringToStyle, textTrim, PLAIN_TEXT_CLIPBOARD_MIME_TYPE, HTML_CLIPBOARD_MIME_TYPE, IClipboardInterfaceService, INotificationService, IPlatformService, CopyCommand, CutCommand, PasteCommand, MenuGroup, MenuItemType, MenuPosition, getMenuHiddenObservable, FONT_FAMILY_LIST, FONT_SIZE_LIST, Menu as Menu$1, IMessageService, useSimpleToolbarGroups, ToolbarItem, RangeSelector, IDialogService, MetaKeys, FontFamily, FontFamilyItem, FontSize, BuiltInUIPart, ILayoutService, IShortcutService, IMenuService, IUIPartsService, SetEditorResizeOperation, IContextMenuService, ICanvasPopupService, IRangeSelectorService, UniverMobileUIPlugin } from "@univerjs/ui";
12
11
  import React, { forwardRef, useRef, createElement, useState, useEffect, useCallback, useLayoutEffect, useMemo } from "react";
13
- import { Dropdown, ColorPicker, Menu, MenuItem, InputNumber, Slider, Input, Tooltip, MessageType, RadioGroup, Radio, Select, Button, Confirm, FormLayout, Avatar, Switch } from "@univerjs/design";
12
+ import { Dropdown, ColorPicker, Menu, MenuItem, InputNumber, Slider, Input, Tooltip, MessageType, RadioGroup, Radio, Select, Button, Confirm, Avatar, FormLayout, Switch } from "@univerjs/design";
14
13
  import clsx from "clsx";
15
14
  import { IDefinedNamesService, FUNCTION_NAMES_STATISTICAL, FUNCTION_NAMES_MATH, FUNCTION_NAMES_TEXT, IFunctionService, LexerTreeBuilder, operatorToken, isReferenceStrings, isReferenceStringWithEffectiveColumn, serializeRangeToRefString, serializeRangeWithSheet, sequenceNodeType, matchToken, RangeReferenceObject, convertUnitDataToRuntime, FormulaDataModel, deserializeRangeWithSheet, serializeRange, NullValueObject } from "@univerjs/engine-formula";
16
15
  import { filter as filter$1 } from "rxjs/operators";
16
+ var SheetsUIPart = /* @__PURE__ */ ((SheetsUIPart2) => (SheetsUIPart2.FILTER_PANEL_EMBED_POINT = "filter-panel-embed-point", SheetsUIPart2.SHEETS_FOOTER = "sheets-footer", SheetsUIPart2))(SheetsUIPart || {});
17
17
  const SHEET_UI_PLUGIN_NAME = "SheetUI";
18
- var SheetsUIPart = /* @__PURE__ */ ((SheetsUIPart2) => (SheetsUIPart2.FILTER_PANEL_EMBED_POINT = "filter-panel-embed-point", SheetsUIPart2))(SheetsUIPart || {});
19
18
  function getEditorObject(unitId, renderManagerService) {
20
19
  if (unitId == null)
21
20
  return;
@@ -153,7 +152,7 @@ SheetSkeletonManagerService = __decorateClass$U([
153
152
  __decorateParam$T(1, Inject(Injector))
154
153
  ], SheetSkeletonManagerService);
155
154
  function attachRangeWithCoord(skeleton, range) {
156
- const { startRow, startColumn, endRow, endColumn, rangeType } = range, startCell = skeleton.getNoMergeCellPositionByIndex(startRow, startColumn), endCell = skeleton.getNoMergeCellPositionByIndex(endRow, endColumn);
155
+ 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);
157
156
  return {
158
157
  startRow,
159
158
  startColumn,
@@ -1135,9 +1134,6 @@ let SheetsScrollRenderController = (_a4 = class extends Disposable {
1135
1134
  const viewportMain = scene.getViewport(SHEET_VIEWPORT_KEY$1.VIEW_MAIN);
1136
1135
  viewportMain && (this.disposeWithMe(
1137
1136
  toDisposable(
1138
- // wheel event --> set-scroll.command('sheet.operation.set-scroll') --> scroll.operation.ts -->
1139
- // scrollManagerService.setScrollInfoAndEmitEvent ---> scrollManagerService.setScrollInfo(raw value, may be negative) &&
1140
- // _notifyCurrentScrollInfo
1141
1137
  this._scrollManagerService.rawScrollInfo$.subscribe((rawScrollInfo) => {
1142
1138
  var _a59;
1143
1139
  const skeleton = (_a59 = this._sheetSkeletonManagerService.getCurrent()) == null ? void 0 : _a59.skeleton;
@@ -1334,7 +1330,7 @@ SheetsScrollRenderController = __decorateClass$R([
1334
1330
  __decorateParam$Q(5, IRenderManagerService),
1335
1331
  __decorateParam$Q(6, Inject(SheetScrollManagerService))
1336
1332
  ], SheetsScrollRenderController);
1337
- var I = /* @__PURE__ */ ((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.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(I || {}), L = /* @__PURE__ */ ((E) => (E[E.SomeCollaborator = 0] = "SomeCollaborator", E[E.AllCollaborator = 1] = "AllCollaborator", E[E.OneSelf = 2] = "OneSelf", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(L || {}), P = /* @__PURE__ */ ((E) => (E[E.View = 0] = "View", E[E.Edit = 1] = "Edit", E[E.ManageCollaborator = 2] = "ManageCollaborator", E[E.Print = 3] = "Print", E[E.Duplicate = 4] = "Duplicate", E[E.Comment = 5] = "Comment", E[E.Copy = 6] = "Copy", E[E.Share = 7] = "Share", E[E.Export = 8] = "Export", E[E.MoveWorksheet = 9] = "MoveWorksheet", E[E.DeleteWorksheet = 10] = "DeleteWorksheet", E[E.HideWorksheet = 11] = "HideWorksheet", E[E.RenameWorksheet = 12] = "RenameWorksheet", E[E.CreateWorksheet = 13] = "CreateWorksheet", E[E.SetWorksheetStyle = 14] = "SetWorksheetStyle", E[E.EditWorksheetCell = 15] = "EditWorksheetCell", E[E.InsertHyperlink = 16] = "InsertHyperlink", E[E.Sort = 17] = "Sort", E[E.Filter = 18] = "Filter", E[E.PivotTable = 19] = "PivotTable", E[E.FloatImg = 20] = "FloatImg", E[E.History = 21] = "History", E[E.RwHgtClWdt = 22] = "RwHgtClWdt", E[E.ViemRwHgtClWdt = 23] = "ViemRwHgtClWdt", E[E.ViewFilter = 24] = "ViewFilter", E[E.MoveSheet = 25] = "MoveSheet", E[E.DeleteSheet = 26] = "DeleteSheet", E[E.HideSheet = 27] = "HideSheet", E[E.CopySheet = 28] = "CopySheet", E[E.RenameSheet = 29] = "RenameSheet", E[E.CreateSheet = 30] = "CreateSheet", E[E.SelectProtectedCells = 31] = "SelectProtectedCells", E[E.SelectUnProtectedCells = 32] = "SelectUnProtectedCells", E[E.SetCellStyle = 33] = "SetCellStyle", E[E.SetCellValue = 34] = "SetCellValue", E[E.SetRowStyle = 35] = "SetRowStyle", E[E.SetColumnStyle = 36] = "SetColumnStyle", E[E.InsertRow = 37] = "InsertRow", E[E.InsertColumn = 38] = "InsertColumn", E[E.DeleteRow = 39] = "DeleteRow", E[E.DeleteColumn = 40] = "DeleteColumn", E[E.EditExtraObject = 41] = "EditExtraObject", E[E.Delete = 42] = "Delete", E[E.RecoverHistory = 43] = "RecoverHistory", E[E.ViewHistory = 44] = "ViewHistory", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(P || {}), M = /* @__PURE__ */ ((E) => (E[E.Reader = 0] = "Reader", E[E.Editor = 1] = "Editor", E[E.Owner = 2] = "Owner", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(M || {}), l$1 = /* @__PURE__ */ ((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))(l$1 || {});
1333
+ var I = /* @__PURE__ */ ((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 || {}), L = /* @__PURE__ */ ((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))(L || {}), P = /* @__PURE__ */ ((E) => (E[E.Reader = 0] = "Reader", E[E.Editor = 1] = "Editor", E[E.Owner = 2] = "Owner", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(P || {}), M = /* @__PURE__ */ ((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 || {}), G = /* @__PURE__ */ ((E) => (E[E.SomeCollaborator = 0] = "SomeCollaborator", E[E.AllCollaborator = 1] = "AllCollaborator", E[E.OneSelf = 2] = "OneSelf", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(G || {});
1338
1334
  function getActiveSheet$(univerInstanceService) {
1339
1335
  return univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET).pipe(switchMap((workbook) => workbook ? workbook.activeSheet$.pipe(map((worksheet) => worksheet ? { workbook, worksheet } : null)) : of(null)));
1340
1336
  }
@@ -1392,7 +1388,7 @@ function getBaseRangeMenuHidden$(accessor) {
1392
1388
  for (let row = startRow; row <= endRow; row++)
1393
1389
  for (let col = startColumn; col <= endColumn; col++) {
1394
1390
  const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
1395
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
1391
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
1396
1392
  return !0;
1397
1393
  }
1398
1394
  return !1;
@@ -1418,7 +1414,7 @@ function getInsertAfterMenuHidden$(accessor, type) {
1418
1414
  for (let row = startRow; row <= endRow; row++)
1419
1415
  for (let col = startColumn; col <= endColumn; col++) {
1420
1416
  const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
1421
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
1417
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
1422
1418
  return !0;
1423
1419
  }
1424
1420
  return !1;
@@ -1444,7 +1440,7 @@ function getInsertBeforeMenuHidden$(accessor, type) {
1444
1440
  for (let row = startRow; row <= endRow; row++)
1445
1441
  for (let col = startColumn; col <= endColumn; col++) {
1446
1442
  const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
1447
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
1443
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
1448
1444
  return !0;
1449
1445
  }
1450
1446
  return !1;
@@ -1470,7 +1466,7 @@ function getDeleteMenuHidden$(accessor, type) {
1470
1466
  for (let row = startRow; row <= endRow; row++)
1471
1467
  for (let col = startColumn; col <= endColumn; col++) {
1472
1468
  const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
1473
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
1469
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
1474
1470
  return !0;
1475
1471
  }
1476
1472
  return !1;
@@ -1496,7 +1492,7 @@ function getCellMenuHidden$(accessor, type) {
1496
1492
  for (let row = startRow; row <= endRow; row++)
1497
1493
  for (let col = startColumn; col <= endColumn; col++) {
1498
1494
  const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
1499
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
1495
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
1500
1496
  return !0;
1501
1497
  }
1502
1498
  return !1;
@@ -1557,7 +1553,9 @@ let SheetsRenderService = (_a5 = class extends RxDisposable {
1557
1553
  this._initWorkbookListener(), this._initContextListener();
1558
1554
  }
1559
1555
  _initWorkbookListener() {
1560
- this._instanceSrv.getTypeOfUnitAdded$(UniverInstanceType.UNIVER_SHEET).pipe(takeUntil(this.dispose$)).subscribe((workbook) => this._createRenderer(workbook)), this._instanceSrv.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).forEach((workbook) => this._createRenderer(workbook)), this._instanceSrv.getTypeOfUnitDisposed$(UniverInstanceType.UNIVER_SHEET).pipe(takeUntil(this.dispose$)).subscribe((workbook) => this._disposeRenderer(workbook));
1556
+ this._instanceSrv.getTypeOfUnitAdded$(UniverInstanceType.UNIVER_SHEET).pipe(takeUntil(this.dispose$)).subscribe((workbook) => {
1557
+ this._createRenderer(workbook);
1558
+ }), this._instanceSrv.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).forEach((workbook) => this._createRenderer(workbook)), this._instanceSrv.getTypeOfUnitDisposed$(UniverInstanceType.UNIVER_SHEET).pipe(takeUntil(this.dispose$)).subscribe((workbook) => this._disposeRenderer(workbook));
1561
1559
  }
1562
1560
  _createRenderer(workbook) {
1563
1561
  const unitId = workbook.getUnitId();
@@ -2513,9 +2511,7 @@ const IAutoFillService = createIdentifier("univer.auto-fill-service"), AutoFillC
2513
2511
  __publicField(this, "_endX", 0);
2514
2512
  __publicField(this, "_endY", 0);
2515
2513
  /**
2516
- * highlight cell of selection
2517
- * when there is no merge info
2518
- * top left cell of current selection (or bottomLeft of current selection)
2514
+ * The highlight cell of a selection. aka: current cell
2519
2515
  */
2520
2516
  __publicField(this, "_primary");
2521
2517
  __publicField(this, "_rangeType", RANGE_TYPE.NORMAL);
@@ -2620,6 +2616,12 @@ const IAutoFillService = createIdentifier("univer.auto-fill-service"), AutoFillC
2620
2616
  } = newSelectionRange;
2621
2617
  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 && (this._rangeType = rangeType), this.setCurrentCell(currentCell);
2622
2618
  }
2619
+ /**
2620
+ * Set primary cell.
2621
+ *
2622
+ * TODO @lumixraku there are 3 concepts for same thing, primary and current and highlight, primary is better cuz selectionModel is using primary.
2623
+ * @param currentCell
2624
+ */
2623
2625
  setCurrentCell(currentCell) {
2624
2626
  currentCell && (this._primary = currentCell);
2625
2627
  }
@@ -2661,12 +2663,19 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
2661
2663
  __publicField(this, "_bottomRightWidget");
2662
2664
  __publicField(this, "_dashRect");
2663
2665
  __publicField(this, "_selectionModel");
2664
- __publicField(this, "_selectionStyle");
2666
+ // why three style prop? what's diff between _selectionStyle & _currentStyle?
2667
+ // protected _selectionStyle: Nullable<ISelectionStyle>;
2668
+ __publicField(this, "_defaultStyle");
2669
+ __publicField(this, "_currentStyle");
2665
2670
  __publicField(this, "_rowHeaderWidth", 0);
2666
2671
  __publicField(this, "_columnHeaderHeight", 0);
2667
2672
  __publicField(this, "_widgetRects", []);
2668
2673
  __publicField(this, "_dispose$", new BehaviorSubject(this));
2669
2674
  __publicField(this, "dispose$", this._dispose$.asObservable());
2675
+ /**
2676
+ * eventSource: selectionShapeExtension selectionMoving$.next,
2677
+ * Observer: prompt.controller
2678
+ */
2670
2679
  __publicField(this, "selectionMoving$", new Subject());
2671
2680
  __publicField(this, "selectionMoved$", new Subject());
2672
2681
  __publicField(this, "selectionScaling$", new Subject());
@@ -2674,8 +2683,6 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
2674
2683
  __publicField(this, "selectionFilling$", new Subject());
2675
2684
  __publicField(this, "_selectionFilled$", new Subject());
2676
2685
  __publicField(this, "selectionFilled$", this._selectionFilled$.asObservable());
2677
- __publicField(this, "_defaultStyle");
2678
- __publicField(this, "_currentStyle");
2679
2686
  __publicField(this, "_isHelperSelection", !0);
2680
2687
  __publicField(this, "_antLineOffset", 0);
2681
2688
  __publicField(this, "_antRequestNewFrame", -1);
@@ -2753,12 +2760,12 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
2753
2760
  get themeService() {
2754
2761
  return this._themeService;
2755
2762
  }
2756
- get selectionStyle() {
2757
- return this._selectionStyle;
2758
- }
2759
- set selectionStyle(style) {
2760
- this._selectionStyle = style;
2761
- }
2763
+ // get selectionStyle() {
2764
+ // return this._selectionStyle;
2765
+ // }
2766
+ // set selectionStyle(style: Nullable<ISelectionStyle>) {
2767
+ // this._selectionStyle = style;
2768
+ // }
2762
2769
  get selectionModel() {
2763
2770
  return this._selectionModel;
2764
2771
  }
@@ -2778,7 +2785,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
2778
2785
  return this._currentStyle;
2779
2786
  }
2780
2787
  set currentStyle(style) {
2781
- this._currentStyle = style;
2788
+ style && (this._currentStyle = style);
2782
2789
  }
2783
2790
  get isHelperSelection() {
2784
2791
  return this._isHelperSelection;
@@ -2801,109 +2808,25 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
2801
2808
  refreshSelectionFilled(val) {
2802
2809
  this._selectionFilled$.next(val);
2803
2810
  }
2804
- updateStyle(style) {
2805
- this._updateControl(style, this._rowHeaderWidth, this._columnHeaderHeight);
2806
- }
2807
- updateRange(range) {
2808
- this._selectionModel.setValue(range), this._updateControl(null, this._rowHeaderWidth, this._columnHeaderHeight);
2809
- }
2810
- /**
2811
- * update seleciton model(new range)
2812
- * @param newSelectionRange update new selection range!!
2813
- * @param rowHeaderWidth
2814
- * @param columnHeaderHeight
2815
- * @param style
2816
- * @param highlight
2817
- */
2818
- update(newSelectionRange, rowHeaderWidth = 0, columnHeaderHeight = 0, style, highlight) {
2819
- this._selectionModel.setValue(newSelectionRange, highlight), style == null && (style = this._selectionStyle), this._updateControl(style, rowHeaderWidth, columnHeaderHeight);
2820
- }
2821
- updateCurrCell(highlight) {
2822
- this._selectionModel.setCurrentCell(highlight);
2823
- }
2824
- clearHighlight() {
2825
- this._selectionModel.clearCurrentCell(), this._updateControl(this._selectionStyle, this._rowHeaderWidth, this._columnHeaderHeight);
2826
- }
2827
- getScene() {
2828
- return this._scene;
2829
- }
2830
- dispose() {
2831
- var _a59, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x;
2832
- (_a59 = this._leftControl) == null || _a59.dispose(), (_b = this._rightControl) == null || _b.dispose(), (_c = this._topControl) == null || _c.dispose(), (_d = this._bottomControl) == 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();
2833
- }
2834
- /**
2835
- * Get the cell information of the current selection, considering the case of merging cells
2836
- */
2837
- getCurrentCellInfo() {
2838
- const currentCell = this.model.currentCell;
2839
- if (currentCell) {
2840
- let currentRangeData;
2841
- if (currentCell.isMerged) {
2842
- const mergeInfo = currentCell.mergeInfo;
2843
- currentRangeData = {
2844
- startRow: mergeInfo.startRow,
2845
- endRow: mergeInfo.endRow,
2846
- startColumn: mergeInfo.startColumn,
2847
- endColumn: mergeInfo.endColumn,
2848
- startX: mergeInfo.startX,
2849
- endX: mergeInfo.endX,
2850
- startY: mergeInfo.startY,
2851
- endY: mergeInfo.endY
2852
- };
2853
- } else {
2854
- const { actualRow, actualColumn, startX, endX, startY, endY } = currentCell;
2855
- currentRangeData = {
2856
- startRow: actualRow,
2857
- endRow: actualRow,
2858
- startColumn: actualColumn,
2859
- endColumn: actualColumn,
2860
- startX,
2861
- endX,
2862
- startY,
2863
- endY
2864
- };
2865
- }
2866
- return currentRangeData;
2867
- }
2868
- }
2869
- getValue() {
2870
- return {
2871
- ...this._selectionModel.getValue(),
2872
- style: this._selectionStyle
2873
- };
2874
- }
2875
- getRange() {
2876
- return this._selectionModel.getValue().rangeWithCoord;
2877
- }
2878
- enableHelperSelection() {
2879
- this._isHelperSelection = !0;
2880
- }
2881
- disableHelperSelection() {
2882
- this._isHelperSelection = !1;
2883
- }
2884
- updateStyleId(id) {
2885
- this._selectionStyle != null && (this._selectionStyle.id = id);
2886
- }
2887
2811
  /**
2888
- * invoked when update selection style & range change
2812
+ * invoked when update selection style & range change, invoked by updateStyle, updateRange, update
2889
2813
  */
2890
2814
  // eslint-disable-next-line max-lines-per-function
2891
- _updateControl(style, rowHeaderWidth, columnHeaderHeight) {
2892
- const { startX, startY, endX, endY } = this._selectionModel, defaultStyle = this._defaultStyle;
2893
- style == null && (style = defaultStyle), this._currentStyle = style;
2894
- const {
2815
+ _updateControlStyleAndLayout(selectionStyle, rowHeaderWidth, columnHeaderHeight) {
2816
+ this._rowHeaderWidth = rowHeaderWidth || 0, this._columnHeaderHeight = columnHeaderHeight || 0;
2817
+ const { startX, startY, endX, endY } = this._selectionModel, defaultStyle = this._defaultStyle, currentStyle = this.currentStyle = selectionStyle || this._currentStyle, {
2895
2818
  stroke = defaultStyle.stroke,
2896
2819
  widgets = defaultStyle.widgets,
2897
2820
  hasAutoFill = defaultStyle.hasAutoFill,
2898
2821
  AutofillStroke = defaultStyle.AutofillStroke,
2899
2822
  strokeDash,
2900
2823
  isAnimationDash
2901
- } = style;
2824
+ } = currentStyle;
2902
2825
  let {
2903
2826
  strokeWidth = defaultStyle.strokeWidth,
2904
2827
  AutofillSize = defaultStyle.AutofillSize,
2905
2828
  AutofillStrokeWidth = defaultStyle.AutofillStrokeWidth
2906
- } = style;
2829
+ } = currentStyle;
2907
2830
  const scale = this._getScale(), leftAdjustWidth = (strokeWidth + SELECTION_CONTROL_BORDER_BUFFER_WIDTH) / 2 / scale;
2908
2831
  strokeWidth /= scale, AutofillSize /= scale, AutofillStrokeWidth /= scale < 1 ? 1 : scale;
2909
2832
  const borderBuffer = SELECTION_CONTROL_BORDER_BUFFER_WIDTH / scale, fixOnePixelBlurOffset = FIX_ONE_PIXEL_BLUR_OFFSET / scale;
@@ -2946,7 +2869,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
2946
2869
  }), strokeDash == null)
2947
2870
  this.dashRect.hide(), this._stopAntLineAnimation();
2948
2871
  else {
2949
- const dashRectBorderWidth = style.strokeWidth * 2 / scale;
2872
+ const dashRectBorderWidth = currentStyle.strokeWidth * 2 / scale;
2950
2873
  this.dashRect.transformByState({
2951
2874
  height: endY - startY,
2952
2875
  width: endX - startX,
@@ -2972,11 +2895,103 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
2972
2895
  this.fillControl.setProps(fillProps), this.fillControl.transformByState(sizeState), this.fillControl.show();
2973
2896
  } else
2974
2897
  this.fillControl.hide();
2975
- this._updateBackgroundControl(style), this._updateBackgroundTitle(style, rowHeaderWidth, columnHeaderHeight), this._updateWidgets(style), this.selectionShape.show(), this.selectionShape.translate(startX, startY), this._selectionStyle = style, this._rowHeaderWidth = rowHeaderWidth || 0, this._columnHeaderHeight = columnHeaderHeight || 0, this.selectionShape.makeDirtyNoDebounce(!0);
2898
+ this._updateBackgroundControl(selectionStyle), this._updateBackgroundTitle(selectionStyle, rowHeaderWidth, columnHeaderHeight), this._updateWidgets(selectionStyle), this.selectionShape.show(), this.selectionShape.translate(startX, startY), this.selectionShape.makeDirtyNoDebounce(!0);
2899
+ }
2900
+ updateStyle(style) {
2901
+ this._updateControlStyleAndLayout(style, this._rowHeaderWidth, this._columnHeaderHeight);
2902
+ }
2903
+ updateRange(range, primaryCell) {
2904
+ this._selectionModel.setValue(range, primaryCell), this._updateControlStyleAndLayout(this._currentStyle, this._rowHeaderWidth, this._columnHeaderHeight);
2905
+ }
2906
+ /**
2907
+ * update selection model with new range & primary cell(aka: highlight/current), also update row/col selection size & style.
2908
+ *
2909
+ * @param newSelectionRange
2910
+ * @param rowHeaderWidth
2911
+ * @param columnHeaderHeight
2912
+ * @param style
2913
+ * @param primaryCell primary cell
2914
+ */
2915
+ update(newSelectionRange, rowHeaderWidth = 0, columnHeaderHeight = 0, style, primaryCell) {
2916
+ this._selectionModel.setValue(newSelectionRange, primaryCell), this._updateControlStyleAndLayout(style || this._currentStyle, rowHeaderWidth, columnHeaderHeight);
2917
+ }
2918
+ /**
2919
+ * update primary range
2920
+ * @param primaryCell model.current (aka: highlight)
2921
+ */
2922
+ updateCurrCell(primaryCell) {
2923
+ this._selectionModel.setCurrentCell(primaryCell);
2924
+ }
2925
+ clearHighlight() {
2926
+ this._selectionModel.clearCurrentCell(), this._updateControlStyleAndLayout(this._currentStyle, this._rowHeaderWidth, this._columnHeaderHeight);
2927
+ }
2928
+ getScene() {
2929
+ return this._scene;
2930
+ }
2931
+ // eslint-disable-next-line complexity
2932
+ dispose() {
2933
+ var _a59, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x;
2934
+ (_a59 = this._leftControl) == null || _a59.dispose(), (_b = this._rightControl) == null || _b.dispose(), (_c = this._topControl) == null || _c.dispose(), (_d = this._bottomControl) == 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();
2935
+ }
2936
+ /**
2937
+ * Get the cell information of the current selection, considering the case of merging cells
2938
+ */
2939
+ getCurrentCellInfo() {
2940
+ const currentCell = this.model.currentCell;
2941
+ if (currentCell) {
2942
+ let currentRangeData;
2943
+ if (currentCell.isMerged) {
2944
+ const mergeInfo = currentCell.mergeInfo;
2945
+ currentRangeData = {
2946
+ startRow: mergeInfo.startRow,
2947
+ endRow: mergeInfo.endRow,
2948
+ startColumn: mergeInfo.startColumn,
2949
+ endColumn: mergeInfo.endColumn,
2950
+ startX: mergeInfo.startX,
2951
+ endX: mergeInfo.endX,
2952
+ startY: mergeInfo.startY,
2953
+ endY: mergeInfo.endY
2954
+ };
2955
+ } else {
2956
+ const { actualRow, actualColumn, startX, endX, startY, endY } = currentCell;
2957
+ currentRangeData = {
2958
+ startRow: actualRow,
2959
+ endRow: actualRow,
2960
+ startColumn: actualColumn,
2961
+ endColumn: actualColumn,
2962
+ startX,
2963
+ endX,
2964
+ startY,
2965
+ endY
2966
+ };
2967
+ }
2968
+ return currentRangeData;
2969
+ }
2970
+ }
2971
+ getValue() {
2972
+ return {
2973
+ ...this._selectionModel.getValue(),
2974
+ style: this._currentStyle
2975
+ };
2976
+ }
2977
+ getRange() {
2978
+ return this._selectionModel.getValue().rangeWithCoord;
2979
+ }
2980
+ enableHelperSelection() {
2981
+ this._isHelperSelection = !0;
2976
2982
  }
2983
+ disableHelperSelection() {
2984
+ this._isHelperSelection = !1;
2985
+ }
2986
+ // updateStyleId(id: string) {
2987
+ // if (this._selectionStyle == null) {
2988
+ // return;
2989
+ // }
2990
+ // this._selectionStyle.id = id;
2991
+ // }
2977
2992
  // eslint-disable-next-line max-lines-per-function
2978
2993
  _initialize() {
2979
- this._defaultStyle = getNormalSelectionStyle(this._themeService), this._selectionModel = new SelectionRenderModel();
2994
+ this._defaultStyle = getNormalSelectionStyle(this._themeService), this._currentStyle = getNormalSelectionStyle(this._themeService), this._selectionModel = new SelectionRenderModel();
2980
2995
  const zIndex = this._zIndex;
2981
2996
  this._leftControl = new Rect("__SpreadsheetSelectionShapeLeftControl__" + zIndex, {
2982
2997
  zIndex
@@ -3022,7 +3037,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
3022
3037
  scene.addObject(this._selectionShapeGroup, SHEET_COMPONENT_SELECTION_LAYER_INDEX), this.disposeWithMe(
3023
3038
  toDisposable(
3024
3039
  scene.onTransformChange$.subscribeEvent((state) => {
3025
- state.type === TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale && this._updateControl(this._currentStyle, this._rowHeaderWidth, this._columnHeaderHeight);
3040
+ state.type === TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale && this._updateControlStyleAndLayout(this._currentStyle, this._rowHeaderWidth, this._columnHeaderHeight);
3026
3041
  })
3027
3042
  )
3028
3043
  ), this._initialTitle();
@@ -3316,6 +3331,10 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
3316
3331
  endColumn
3317
3332
  }, this._control.selectionMoving$.next(this._targetSelection);
3318
3333
  }
3334
+ /**
3335
+ * Drag move whole selectionControl when cusor turns to crosshair. Not for dragging 8 control points.
3336
+ * @param evt
3337
+ */
3319
3338
  _controlEvent(evt) {
3320
3339
  const { offsetX: evtOffsetX, offsetY: evtOffsetY } = evt, scene = this._scene, relativeCoords = scene.getRelativeToViewportCoord(Vector2.FromArray([evtOffsetX, evtOffsetY])), { x: newEvtOffsetX, y: newEvtOffsetY } = relativeCoords, scrollXY = scene.getVpScrollXYInfoByPosToVp(relativeCoords), { scaleX, scaleY } = scene.getAncestorScale(), actualSelection = this._skeleton.getCellPositionByOffset(
3321
3340
  newEvtOffsetX,
@@ -3333,13 +3352,13 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
3333
3352
  } = this._control.model;
3334
3353
  let fixRow = 0, fixColumn = 0;
3335
3354
  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;
3336
- const style = this._control.selectionStyle, scale = this._getScale();
3355
+ const style = this._control.currentStyle, scale = this._getScale();
3337
3356
  this.isHelperSelection && (this._helperSelection = new Rect(HELPER_SELECTION_TEMP_NAME, {
3338
3357
  stroke: style.stroke,
3339
3358
  strokeWidth: style.strokeWidth / scale
3340
3359
  }), scene.addObject(this._helperSelection));
3341
3360
  const viewMain = scene.getViewport(SHEET_VIEWPORT_KEY$1.VIEW_MAIN), scrollTimer = ScrollTimer.create(scene);
3342
- scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY, viewMain), this._scrollTimer = scrollTimer, scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
3361
+ this._scrollTimer = scrollTimer, scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY, viewMain), scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
3343
3362
  var _a59;
3344
3363
  const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt;
3345
3364
  if (((_a59 = this._injector.get(ISheetSelectionRenderService, Quantity.OPTIONAL)) == null ? void 0 : _a59.interceptor.fetchThroughInterceptors(RANGE_MOVE_PERMISSION_CHECK)(!1, null)) === !1)
@@ -3392,10 +3411,45 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
3392
3411
  }), control.onPointerLeave$.subscribeEvent(() => {
3393
3412
  control.resetCursor();
3394
3413
  }), control.onPointerDown$.subscribeEvent((evt) => {
3395
- this._widgetEvent(evt, cursors[index]);
3414
+ this._widgetPointerDownEvent(evt, cursors[index]);
3415
+ });
3416
+ });
3417
+ }
3418
+ /**
3419
+ * Pointer down Events for 8 control point.
3420
+ * @param evt
3421
+ * @param cursor
3422
+ */
3423
+ _widgetPointerDownEvent(evt, cursor) {
3424
+ const scene = this._scene, { offsetX: evtOffsetX, offsetY: evtOffsetY } = evt, relativeCoords = scene.getRelativeToViewportCoord(Vector2.FromArray([evtOffsetX, evtOffsetY])), { x: newEvtOffsetX, y: newEvtOffsetY } = relativeCoords;
3425
+ this._startOffsetX = evtOffsetX, this._startOffsetY = evtOffsetY;
3426
+ const {
3427
+ startRow: originStartRow,
3428
+ startColumn: originStartColumn,
3429
+ endRow: originEndRow,
3430
+ endColumn: originEndColumn
3431
+ } = this._control.model, startRow = Math.min(originStartRow, originEndRow), startColumn = Math.min(originStartColumn, originEndColumn), endRow = Math.max(originStartRow, originEndRow), endColumn = Math.max(originStartColumn, originEndColumn);
3432
+ this._relativeSelectionPositionRow = startRow, this._relativeSelectionPositionColumn = startColumn, this._relativeSelectionRowLength = endRow - startRow, this._relativeSelectionColumnLength = endColumn - startColumn, cursor === CURSOR_TYPE.NORTH_WEST_RESIZE ? (this._relativeSelectionPositionRow = endRow, this._relativeSelectionPositionColumn = endColumn) : cursor === CURSOR_TYPE.NORTH_RESIZE ? this._relativeSelectionPositionRow = endRow : cursor === CURSOR_TYPE.NORTH_EAST_RESIZE ? this._relativeSelectionPositionRow = endRow : cursor === CURSOR_TYPE.WEST_RESIZE ? this._relativeSelectionPositionColumn = endColumn : cursor === CURSOR_TYPE.SOUTH_WEST_RESIZE ? this._relativeSelectionPositionColumn = endColumn : cursor === CURSOR_TYPE.SOUTH_RESIZE && (this._relativeSelectionPositionRow = startRow);
3433
+ const scrollTimer = ScrollTimer.create(scene);
3434
+ scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY), this._scrollTimer = scrollTimer, scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
3435
+ const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt, { x: newMoveOffsetX, y: newMoveOffsetY } = scene.getRelativeToViewportCoord(
3436
+ Vector2.FromArray([moveOffsetX, moveOffsetY])
3437
+ );
3438
+ this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor), scene.setCursor(cursor), scrollTimer.scrolling(newMoveOffsetX, newMoveOffsetY, () => {
3439
+ this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor);
3396
3440
  });
3441
+ }), this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent(() => {
3442
+ var _a59, _b, _c;
3443
+ const scene2 = this._scene;
3444
+ scene2.resetCursor(), this._clearObserverEvent(), scene2.enableEvent(), (_a59 = this._scrollTimer) == null || _a59.dispose(), this._control.selectionScaled$.next(this._targetSelection), (_c = (_b = this._selectionHooks).selectionMoveEnd) == null || _c.call(_b);
3397
3445
  });
3398
3446
  }
3447
+ /**
3448
+ * Pointer move Events for 8 control point.
3449
+ * @param moveOffsetX
3450
+ * @param moveOffsetY
3451
+ * @param cursor
3452
+ */
3399
3453
  _widgetMoving(moveOffsetX, moveOffsetY, cursor) {
3400
3454
  const scene = this._scene, scrollXY = scene.getVpScrollXYInfoByPosToVp(Vector2.FromArray([this._startOffsetX, this._startOffsetY])), { scaleX, scaleY } = scene.getAncestorScale(), moveActualSelection = this._skeleton.getCellPositionByOffset(
3401
3455
  moveOffsetX,
@@ -3421,36 +3475,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
3421
3475
  endRow,
3422
3476
  startColumn,
3423
3477
  endColumn
3424
- }, this._control.update(this._targetSelection, rowHeaderWidth, columnHeaderHeight, this._control.selectionStyle), this._control.clearHighlight(), this._control.selectionScaling$.next(this._targetSelection);
3425
- }
3426
- /**
3427
- * Events for 8 control point
3428
- * @param evt
3429
- * @param cursor
3430
- */
3431
- _widgetEvent(evt, cursor) {
3432
- const { offsetX: evtOffsetX, offsetY: evtOffsetY } = evt, scene = this._scene, relativeCoords = scene.getRelativeToViewportCoord(Vector2.FromArray([evtOffsetX, evtOffsetY])), { x: newEvtOffsetX, y: newEvtOffsetY } = relativeCoords;
3433
- this._startOffsetX = evtOffsetX, this._startOffsetY = evtOffsetY;
3434
- const {
3435
- startRow: originStartRow,
3436
- startColumn: originStartColumn,
3437
- endRow: originEndRow,
3438
- endColumn: originEndColumn
3439
- } = this._control.model;
3440
- this._relativeSelectionPositionRow = originStartRow, this._relativeSelectionPositionColumn = originStartColumn, this._relativeSelectionRowLength = originEndRow - originStartRow, this._relativeSelectionColumnLength = originEndColumn - originStartColumn, cursor === CURSOR_TYPE.NORTH_WEST_RESIZE ? (this._relativeSelectionPositionRow = originEndRow, this._relativeSelectionPositionColumn = originEndColumn) : cursor === CURSOR_TYPE.NORTH_RESIZE ? this._relativeSelectionPositionRow = originEndRow : cursor === CURSOR_TYPE.NORTH_EAST_RESIZE ? this._relativeSelectionPositionRow = originEndRow : cursor === CURSOR_TYPE.WEST_RESIZE ? this._relativeSelectionPositionColumn = originEndColumn : cursor === CURSOR_TYPE.SOUTH_WEST_RESIZE && (this._relativeSelectionPositionColumn = originEndColumn);
3441
- const scrollTimer = ScrollTimer.create(scene);
3442
- scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY), this._scrollTimer = scrollTimer, scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
3443
- const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt, { x: newMoveOffsetX, y: newMoveOffsetY } = scene.getRelativeToViewportCoord(
3444
- Vector2.FromArray([moveOffsetX, moveOffsetY])
3445
- );
3446
- this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor), scene.setCursor(cursor), scrollTimer.scrolling(newMoveOffsetX, newMoveOffsetY, () => {
3447
- this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor);
3448
- });
3449
- }), this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent(() => {
3450
- var _a59, _b, _c;
3451
- const scene2 = this._scene;
3452
- scene2.resetCursor(), this._clearObserverEvent(), scene2.enableEvent(), (_a59 = this._scrollTimer) == null || _a59.dispose(), this._control.selectionScaled$.next(this._targetSelection), (_c = (_b = this._selectionHooks).selectionMoveEnd) == null || _c.call(_b);
3453
- });
3478
+ }, this._control.update(this._targetSelection, rowHeaderWidth, columnHeaderHeight, this._control.currentStyle), this._control.clearHighlight(), this._control.selectionScaling$.next(this._targetSelection);
3454
3479
  }
3455
3480
  _initialFill() {
3456
3481
  const { fillControl } = this._control;
@@ -3460,6 +3485,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
3460
3485
  fillControl.resetCursor();
3461
3486
  }), fillControl.onPointerDown$.subscribeEvent(this._fillEvent.bind(this));
3462
3487
  }
3488
+ // eslint-disable-next-line complexity
3463
3489
  _fillMoving(moveOffsetX, moveOffsetY) {
3464
3490
  var _a59, _b, _c;
3465
3491
  const scene = this._scene, scrollXY = scene.getViewportScrollXY(this._activeViewport), { scaleX, scaleY } = scene.getAncestorScale(), moveActualSelection = this._skeleton.getCellPositionByOffset(
@@ -3533,7 +3559,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
3533
3559
  endColumn: originEndColumn
3534
3560
  } = this._control.model;
3535
3561
  this._isInMergeState = this._hasMergeInRange(originStartRow, originStartColumn, originEndRow, originEndColumn), this._relativeSelectionPositionRow = originStartRow, this._relativeSelectionPositionColumn = originStartColumn, this._relativeSelectionRowLength = originEndRow - originStartRow, this._relativeSelectionColumnLength = originEndColumn - originStartColumn;
3536
- const style = this._control.selectionStyle;
3562
+ const style = this._control.currentStyle;
3537
3563
  let stroke = style == null ? void 0 : style.stroke, strokeWidth = style == null ? void 0 : style.strokeWidth;
3538
3564
  const defaultStyle = getNormalSelectionStyle(this._themeService);
3539
3565
  stroke == null && (stroke = defaultStyle.stroke), strokeWidth == null && (strokeWidth = defaultStyle.strokeWidth);
@@ -3720,7 +3746,7 @@ function attachPrimaryWithCoord(primary, skeleton) {
3720
3746
  }
3721
3747
  __name(attachPrimaryWithCoord, "attachPrimaryWithCoord");
3722
3748
  const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-render-service"), _BaseSelectionRenderService = class _BaseSelectionRenderService extends Disposable {
3723
- constructor(_injector, _themeService, _shortcutService, _renderManagerService) {
3749
+ constructor(_injector, _themeService, _shortcutService, _sheetSkeletonManagerService) {
3724
3750
  super();
3725
3751
  __publicField(this, "_downObserver");
3726
3752
  __publicField(this, "_scenePointerMoveSub");
@@ -3766,11 +3792,6 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3766
3792
  __publicField(this, "_singleSelectionEnabled", !1);
3767
3793
  // #endregion
3768
3794
  __publicField(this, "_selectionMoveEnd$", new BehaviorSubject([]));
3769
- /**
3770
- * trigger when selection move end(pointerup)
3771
- * and then update selection model in selectionManagerService
3772
- * selectionMoveEnd$ ---> _updateSelections --> selectionOperation@selectionManagerService.setSelections
3773
- */
3774
3795
  __publicField(this, "selectionMoveEnd$", this._selectionMoveEnd$.asObservable());
3775
3796
  __publicField(this, "_selectionMoving$", new Subject());
3776
3797
  __publicField(this, "selectionMoving$", this._selectionMoving$.asObservable());
@@ -3779,7 +3800,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3779
3800
  __publicField(this, "_selectionMoving", !1);
3780
3801
  __publicField(this, "_activeViewport");
3781
3802
  __publicField(this, "interceptor", new InterceptorManager({ RANGE_MOVE_PERMISSION_CHECK, RANGE_FILL_PERMISSION_CHECK }));
3782
- this._injector = _injector, this._themeService = _themeService, this._shortcutService = _shortcutService, this._renderManagerService = _renderManagerService, this._resetStyle(), this._initMoving();
3803
+ this._injector = _injector, this._themeService = _themeService, this._shortcutService = _shortcutService, this._sheetSkeletonManagerService = _sheetSkeletonManagerService, this._resetSelectionStyle(), this._initMoving();
3783
3804
  }
3784
3805
  get selectionMoving() {
3785
3806
  return this._selectionMoving;
@@ -3791,11 +3812,14 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3791
3812
  this._selectionMoving = !1;
3792
3813
  }));
3793
3814
  }
3794
- _setStyle(style) {
3815
+ _setSelectionStyle(style) {
3795
3816
  this._selectionStyle = style;
3796
3817
  }
3797
- _resetStyle() {
3798
- this._setStyle(getNormalSelectionStyle(this._themeService));
3818
+ /**
3819
+ * Reset this._selectionStyle to default normal selection style
3820
+ */
3821
+ _resetSelectionStyle() {
3822
+ this._setSelectionStyle(getNormalSelectionStyle(this._themeService));
3799
3823
  }
3800
3824
  /** @deprecated This should not be provided by the selection render service. */
3801
3825
  getViewPort() {
@@ -3805,37 +3829,15 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3805
3829
  this._singleSelectionEnabled = enabled;
3806
3830
  }
3807
3831
  /**
3808
- * add a selection
3809
- *
3810
- * in PC:init & pointerup would call this function.
3811
- *
3812
- * init
3813
- * selectionController@_initSkeletonChangeListener --> selectionManagerService.add --> selectionManagerService._selectionMoveEnd$ --> this.addControlToCurrentByRangeData
3814
- *
3815
- * selectionMoveEnd$ --> this.addSelectionControlBySelectionData
3816
- *
3817
- *
3818
- *
3819
- * pointer
3820
- * engine@_pointerDownEvent --> spreadsheet?.onPointerDownObserve --> eventTrigger --> scene@disableEvent() --> then scene.input-manager currentObject is always scene until scene@enableEvent.
3821
- * engine@_pointerUpEvent --> scene.input-manager@_onPointerUp --> this._selectionMoveEnd$ --> _selectionManagerService.selectionMoveEnd$ --> this.addControlToCurrentByRangeData
3822
- *
3823
- * but in mobile, we do not call disableEvent() in eventTrigger,
3824
- * so pointerup --> scene.input-manager currentObject is spreadsheet --> this.eventTrigger
3825
- *
3826
- *
3827
- * columnHeader pointerup$ --> selectionMoveEnd$ --> selectionManagerService@setSelections -->
3828
- * selectionManagerService@_emitOnEnd -->
3829
- * _workbookSelections.selectionMoveEnd$ --> _addSelectionControlBySelectionData
3830
- *
3831
- * @param selectionData
3832
+ * Add a selection in spreadsheet, create a new SelectionControl and then update this control by range derives from selection.
3833
+ * @param {ISelectionWithCoordAndStyle} selection
3832
3834
  */
3833
3835
  _addSelectionControlBySelectionData(selection) {
3834
3836
  var _a59;
3835
- const { rangeWithCoord, primaryWithCoord } = selection, { rangeType } = rangeWithCoord, skeleton = this._skeleton, style = (_a59 = selection.style) != null ? _a59 : getNormalSelectionStyle(this._themeService), scene = this._scene;
3837
+ const skeleton = this._skeleton, style = (_a59 = selection.style) != null ? _a59 : getNormalSelectionStyle(this._themeService), scene = this._scene;
3836
3838
  if (!scene || !skeleton)
3837
3839
  return;
3838
- const control = this.newSelectionControl(scene, rangeType || RANGE_TYPE.NORMAL);
3840
+ const { rangeWithCoord, primaryWithCoord } = selection, { rangeType } = rangeWithCoord, control = this.newSelectionControl(scene, rangeType || RANGE_TYPE.NORMAL);
3839
3841
  new SelectionShapeExtension(control, skeleton, scene, this._themeService, this._injector, {
3840
3842
  selectionMoveEnd: /* @__PURE__ */ __name(() => {
3841
3843
  this._selectionMoveEnd$.next(this.getSelectionDataWithStyle());
@@ -3850,21 +3852,16 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3850
3852
  }
3851
3853
  /**
3852
3854
  * Update the corresponding selectionControl based on selectionsData.
3853
- * selectionData[i] ---- selectionControls[i]
3855
+ * selectionData[i] syncs selectionControls[i]
3854
3856
  * @param selections
3855
3857
  */
3856
3858
  updateControlForCurrentByRangeData(selections) {
3857
3859
  const selectionControls = this.getSelectionControls();
3858
- if (!selectionControls)
3859
- return;
3860
- const skeleton = this._skeleton;
3861
- if (skeleton == null)
3862
- return;
3863
- const { rowHeaderWidth, columnHeaderHeight } = skeleton;
3864
- for (let i = 0, len = selections.length; i < len; i++) {
3865
- const { rangeWithCoord, primaryWithCoord, style } = selections[i], control = selectionControls[i];
3866
- control && control.update(rangeWithCoord, rowHeaderWidth, columnHeaderHeight, style, primaryWithCoord);
3867
- }
3860
+ if (!(!selectionControls || this._skeleton == null))
3861
+ for (let i = 0, len = selections.length; i < len; i++) {
3862
+ const { rangeWithCoord, primaryWithCoord } = selections[i], control = selectionControls[i];
3863
+ control && control.updateRange(rangeWithCoord, primaryWithCoord);
3864
+ }
3868
3865
  }
3869
3866
  refreshSelectionMoveStart() {
3870
3867
  this._selectionMoveStart$.next(this.getSelectionDataWithStyle());
@@ -3875,6 +3872,10 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3875
3872
  getSkeleton() {
3876
3873
  return this._skeleton;
3877
3874
  }
3875
+ /**
3876
+ * Generate selectionData from this._selectionControls.model .
3877
+ * @returns {ISelectionWithCoordAndStyle[]} {range, primary, style}[]
3878
+ */
3878
3879
  getSelectionDataWithStyle() {
3879
3880
  const selectionControls = this._selectionControls, [unitId, sheetId] = this._skeleton.getLocation();
3880
3881
  return selectionControls.map((control) => {
@@ -3892,8 +3893,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3892
3893
  this._selectionControls.length = 0;
3893
3894
  }
3894
3895
  _getFreeze() {
3895
- var _a59, _b;
3896
- return (_b = (_a59 = this._renderManagerService.withCurrentTypeOfUnit(UniverInstanceType.UNIVER_SHEET, SheetSkeletonManagerService)) == null ? void 0 : _a59.getCurrent()) == null ? void 0 : _b.skeleton.getWorksheetConfig().freeze;
3896
+ var _a59;
3897
+ return (_a59 = this._sheetSkeletonManagerService.getCurrent()) == null ? void 0 : _a59.skeleton.getWorksheetConfig().freeze;
3897
3898
  }
3898
3899
  _getViewportByCell(row, column) {
3899
3900
  if (row === void 0 || column === void 0)
@@ -3966,7 +3967,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3966
3967
  let { x: viewportPosX, y: viewportPosY } = relativeCoords;
3967
3968
  this._startViewportPosX = viewportPosX, this._startViewportPosY = viewportPosY;
3968
3969
  const scrollXY = scene.getVpScrollXYInfoByPosToVp(relativeCoords), { scaleX, scaleY } = scene.getAncestorScale(), cursorCellRangeInfo = this._getCellRangeByCursorPosition(viewportPosX, viewportPosY, scaleX, scaleY, scrollXY);
3969
- if (!cursorCellRangeInfo) return !1;
3970
+ if (!cursorCellRangeInfo) return;
3970
3971
  const { rangeWithCoord: cursorCellRange, primaryWithCoord: primaryCursorCellRange } = cursorCellRangeInfo, cursorCellRangeWithRangeType = { ...cursorCellRange, rangeType };
3971
3972
  this._startRangeWhenPointerDown = { ...cursorCellRange, rangeType };
3972
3973
  let activeSelectionControl = this.getActiveSelectionControl();
@@ -3991,18 +3992,27 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
3991
3992
  rangeType,
3992
3993
  activeSelectionControl
3993
3994
  // Get updated in this method
3994
- ) : remainLastEnable && activeSelectionControl ? this._updateSelectionControlRange(
3995
+ ) : remainLastEnable && activeSelectionControl ? this._updateSelectionControlByRange(
3995
3996
  activeSelectionControl,
3996
3997
  cursorCellRangeWithRangeType,
3997
3998
  primaryCursorCellRange
3998
- ) : (activeSelectionControl = this.newSelectionControl(scene, rangeType), this._updateSelectionControlRange(
3999
+ ) : (activeSelectionControl = this.newSelectionControl(scene, rangeType), this._updateSelectionControlByRange(
3999
4000
  activeSelectionControl,
4000
4001
  cursorCellRangeWithRangeType,
4001
4002
  primaryCursorCellRange
4002
- )), this._selectionMoveStart$.next(this.getSelectionDataWithStyle()), scene.disableEvent(), this._clearUpdatingListeners(), this._addEndingListeners(), (_a59 = scene.getTransformer()) == null || _a59.clearSelectedObjects(), (rangeType === RANGE_TYPE.ROW || rangeType === RANGE_TYPE.COLUMN) && (rangeType === RANGE_TYPE.ROW ? viewportPosX = 0 : rangeType === RANGE_TYPE.COLUMN && (viewportPosY = 0), this._moving(viewportPosX, viewportPosY, activeSelectionControl, rangeType)), this._setupPointerMoveListener(viewportMain, activeSelectionControl, rangeType, scrollTimerType, viewportPosX, viewportPosY), this._shortcutService.setDisable(!0), this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent(() => {
4003
+ )), this._selectionMoveStart$.next(this.getSelectionDataWithStyle()), scene.disableEvent(), this._clearUpdatingListeners(), this._addEndingListeners(), (_a59 = scene.getTransformer()) == null || _a59.clearSelectedObjects(), (rangeType === RANGE_TYPE.ROW || rangeType === RANGE_TYPE.COLUMN) && (rangeType === RANGE_TYPE.ROW ? viewportPosX = 0 : rangeType === RANGE_TYPE.COLUMN && (viewportPosY = 0), this._movingHandler(viewportPosX, viewportPosY, activeSelectionControl, rangeType)), this._setupPointerMoveListener(viewportMain, activeSelectionControl, rangeType, scrollTimerType, viewportPosX, viewportPosY), this._shortcutService.setDisable(!0), this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent(() => {
4003
4004
  this._clearUpdatingListeners(), this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()), this._shortcutService.setDisable(!1);
4004
4005
  });
4005
4006
  }
4007
+ /**
4008
+ * Init pointer move listener, bind in each pointer down, unbind in each pointer up
4009
+ * @param viewportMain
4010
+ * @param activeSelectionControl
4011
+ * @param rangeType
4012
+ * @param scrollTimerType
4013
+ * @param moveStartPosX
4014
+ * @param moveStartPosY
4015
+ */
4006
4016
  // eslint-disable-next-line max-lines-per-function
4007
4017
  _setupPointerMoveListener(viewportMain, activeSelectionControl, rangeType, scrollTimerType = ScrollTimerType.ALL, moveStartPosX, moveStartPosY) {
4008
4018
  var _a59, _b;
@@ -4012,7 +4022,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
4012
4022
  this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
4013
4023
  var _a60, _b2, _c, _d, _e, _f, _g, _h, _i;
4014
4024
  const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt, { x: newMoveOffsetX, y: newMoveOffsetY } = scene.getRelativeToViewportCoord(Vector2.FromArray([moveOffsetX, moveOffsetY]));
4015
- this._moving(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
4025
+ this._movingHandler(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
4016
4026
  let scrollOffsetX = newMoveOffsetX, scrollOffsetY = newMoveOffsetY;
4017
4027
  const currentSelection = this.getActiveSelectionControl(), freeze = this._getFreeze(), selection = currentSelection == null ? void 0 : currentSelection.model, endViewport = (_a60 = scene.getActiveViewportByCoord(Vector2.FromArray([moveOffsetX, moveOffsetY]))) != null ? _a60 : this._getViewportByCell(selection == null ? void 0 : selection.endRow, selection == null ? void 0 : selection.endColumn);
4018
4028
  if (startViewport && endViewport && viewportMain) {
@@ -4046,7 +4056,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
4046
4056
  lastX = newMoveOffsetX, lastY = newMoveOffsetY;
4047
4057
  }
4048
4058
  this._scrollTimer.scrolling(scrollOffsetX, scrollOffsetY, () => {
4049
- this._moving(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
4059
+ this._movingHandler(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
4050
4060
  });
4051
4061
  });
4052
4062
  }
@@ -4071,8 +4081,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
4071
4081
  /**
4072
4082
  * When mousedown and mouseup need to go to the coordination and undo stack, when mousemove does not need to go to the coordination and undo stack
4073
4083
  */
4074
- // eslint-disable-next-line max-lines-per-function
4075
- _moving(offsetX, offsetY, activeSelectionControl, rangeType) {
4084
+ // eslint-disable-next-line max-lines-per-function, complexity
4085
+ _movingHandler(offsetX, offsetY, activeSelectionControl, rangeType) {
4076
4086
  var _a59, _b, _c, _d, _e;
4077
4087
  const skeleton = this._skeleton, scene = this._scene, [unitId, sheetId] = skeleton.getLocation(), currSelectionRange = {
4078
4088
  startRow: (_a59 = activeSelectionControl == null ? void 0 : activeSelectionControl.model.startRow) != null ? _a59 : -1,
@@ -4110,11 +4120,16 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
4110
4120
  startX: (startCellXY == null ? void 0 : startCellXY.startX) || 0,
4111
4121
  endX: (endCellXY == null ? void 0 : endCellXY.endX) || 0
4112
4122
  }, rangeChanged = currSelectionRange.startRow !== newSelectionRange.startRow || currSelectionRange.startColumn !== newSelectionRange.startColumn || currSelectionRange.endRow !== newSelectionRange.endRow || currSelectionRange.endColumn !== newSelectionRange.endColumn;
4113
- activeSelectionControl != null && rangeChanged && (this._updateSelectionControlRange(activeSelectionControl, newSelectionRangeWithCoord), this._selectionMoving$.next(this.getSelectionDataWithStyle()));
4123
+ activeSelectionControl != null && rangeChanged && (this._updateSelectionControlByRange(activeSelectionControl, newSelectionRangeWithCoord), this._selectionMoving$.next(this.getSelectionDataWithStyle()));
4114
4124
  }
4115
- _updateSelectionControlRange(control, newSelectionRange, highlight) {
4116
- const skeleton = this._skeleton, { rowHeaderWidth, columnHeaderHeight } = skeleton;
4117
- control.update(newSelectionRange, rowHeaderWidth, columnHeaderHeight, this._selectionStyle, highlight || null);
4125
+ /**
4126
+ * Update the selection control by range.
4127
+ * @param control
4128
+ * @param newSelectionRange
4129
+ * @param highlight
4130
+ */
4131
+ _updateSelectionControlByRange(control, newSelectionRange, highlight) {
4132
+ control.updateRange(newSelectionRange, highlight);
4118
4133
  }
4119
4134
  _clearUpdatingListeners() {
4120
4135
  var _a59, _b, _c, _d, _e;
@@ -4195,8 +4210,12 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
4195
4210
  startX: activeCell.mergeInfo.startX || 0,
4196
4211
  endX: activeCell.mergeInfo.endX || 0,
4197
4212
  rangeType
4198
- }, this._updateSelectionControlRange(activeControl, newSelectionRange, currentCell);
4213
+ }, this._updateSelectionControlByRange(activeControl, newSelectionRange, currentCell);
4199
4214
  }
4215
+ /**
4216
+ * Reset all this.selectionControls by selectionsData.
4217
+ * @param selectionsData
4218
+ */
4200
4219
  _refreshSelectionControl(selectionsData) {
4201
4220
  const selections = selectionsData.map((selectionWithStyle) => {
4202
4221
  const selectionData = attachSelectionWithCoord(selectionWithStyle, this._skeleton);
@@ -4508,6 +4527,10 @@ let SheetsZoomRenderController = (_a8 = class extends Disposable {
4508
4527
  this._updateViewZoom(zoomRatio);
4509
4528
  }));
4510
4529
  }
4530
+ /**
4531
+ * Zoom scene, resize viewport and then setScrollInfo
4532
+ * @param zoomRatio
4533
+ */
4511
4534
  _updateViewZoom(zoomRatio) {
4512
4535
  const sheetObject = this._getSheetObject();
4513
4536
  sheetObject == null || sheetObject.scene.scale(zoomRatio, zoomRatio), sheetObject == null || sheetObject.spreadsheet.makeForceDirty();
@@ -4705,9 +4728,7 @@ let AutoFillController = (_a9 = class extends Disposable {
4705
4728
  const unitId = workbook.getUnitId(), subUnitId = (_a59 = workbook.getActiveSheet()) == null ? void 0 : _a59.getSheetId();
4706
4729
  if (!subUnitId) return;
4707
4730
  this._autoFillService.direction = direction;
4708
- const accessor = {
4709
- get: this._injector.get.bind(this._injector)
4710
- }, autoFillSource = rangeToDiscreteRange(source, accessor), autoFillTarget = rangeToDiscreteRange(target, accessor);
4731
+ const autoFillSource = this._injector.invoke((accessor) => rangeToDiscreteRange(source, accessor)), autoFillTarget = this._injector.invoke((accessor) => rangeToDiscreteRange(target, accessor));
4711
4732
  if (!autoFillSource || !autoFillTarget)
4712
4733
  return;
4713
4734
  this._autoFillService.autoFillLocation = {
@@ -4822,11 +4843,7 @@ let AutoFillController = (_a9 = class extends Disposable {
4822
4843
  throw new Error("No active sheet found");
4823
4844
  const currentCellDatas = worksheet.getCellMatrix(), rules = this._autoFillService.getRules(), copyData = [], isVertical = direction === Direction.DOWN || direction === Direction.UP;
4824
4845
  let aArray, bArray;
4825
- isVertical ? (aArray = source.cols, bArray = source.rows) : (aArray = source.rows, bArray = source.cols);
4826
- const accessor = {
4827
- get: this._injector.get.bind(this._injector)
4828
- };
4829
- return aArray.forEach((a) => {
4846
+ return isVertical ? (aArray = source.cols, bArray = source.rows) : (aArray = source.rows, bArray = source.cols), aArray.forEach((a) => {
4830
4847
  const copyDataPiece = this._getEmptyCopyDataPiece(), prevData = {
4831
4848
  type: void 0,
4832
4849
  cellData: void 0
@@ -4834,7 +4851,7 @@ let AutoFillController = (_a9 = class extends Disposable {
4834
4851
  bArray.forEach((b) => {
4835
4852
  let data;
4836
4853
  isVertical ? data = currentCellDatas.getValue(b, a) : data = currentCellDatas.getValue(a, b);
4837
- const { type, isContinue } = rules.find((r) => r.match(data, accessor)) || otherRule;
4854
+ const { type, isContinue } = rules.find((r) => r.match(data, this._injector)) || otherRule;
4838
4855
  if (isContinue(prevData, data)) {
4839
4856
  const typeInfo = copyDataPiece[type], last = typeInfo[typeInfo.length - 1];
4840
4857
  last.data.push(data), last.index.push(b - bArray[0]);
@@ -4988,9 +5005,7 @@ let AutoFillController = (_a9 = class extends Disposable {
4988
5005
  }
4989
5006
  });
4990
5007
  });
4991
- const accessor = {
4992
- get: this._injector.get.bind(this._injector)
4993
- }, deleteMergeRanges = [], mergeData = (_b = (_a59 = this._univerInstanceService.getUniverSheetInstance(unitId)) == null ? void 0 : _a59.getSheetBySheetId(subUnitId)) == null ? void 0 : _b.getMergeData();
5008
+ const deleteMergeRanges = [], mergeData = (_b = (_a59 = this._univerInstanceService.getUniverSheetInstance(unitId)) == null ? void 0 : _a59.getSheetBySheetId(subUnitId)) == null ? void 0 : _b.getMergeData();
4994
5009
  mergeData && mergeData.forEach((merge2) => {
4995
5010
  Rectangle.intersects(merge2, targetRange) && deleteMergeRanges.push(merge2);
4996
5011
  });
@@ -4998,8 +5013,8 @@ let AutoFillController = (_a9 = class extends Disposable {
4998
5013
  unitId,
4999
5014
  subUnitId,
5000
5015
  ranges: deleteMergeRanges
5001
- }, undoRemoveMergeMutationParams = RemoveMergeUndoMutationFactory(
5002
- accessor,
5016
+ }, undoRemoveMergeMutationParams = this._injector.invoke(
5017
+ AddMergeUndoMutationFactory,
5003
5018
  removeMergeMutationParams
5004
5019
  );
5005
5020
  deleteMergeRanges.length && (redos.push({ id: RemoveWorksheetMergeMutation.id, params: removeMergeMutationParams }), undos.push({ id: AddWorksheetMergeMutation.id, params: undoRemoveMergeMutationParams }));
@@ -5007,8 +5022,8 @@ let AutoFillController = (_a9 = class extends Disposable {
5007
5022
  subUnitId,
5008
5023
  unitId,
5009
5024
  cellValue: generateNullCellValueRowCol([target])
5010
- }, undoClearMutationParams = SetRangeValuesUndoMutationFactory(
5011
- accessor,
5025
+ }, undoClearMutationParams = this._injector.invoke(
5026
+ SetRangeValuesUndoMutationFactory,
5012
5027
  clearMutationParams
5013
5028
  );
5014
5029
  redos.push({ id: SetRangeValuesMutation.id, params: clearMutationParams }), undos.push({ id: SetRangeValuesMutation.id, params: undoClearMutationParams });
@@ -5022,8 +5037,8 @@ let AutoFillController = (_a9 = class extends Disposable {
5022
5037
  subUnitId,
5023
5038
  unitId,
5024
5039
  cellValue: cellValue.getMatrix()
5025
- }, undoSetRangeValuesMutationParams = SetRangeValuesUndoMutationFactory(
5026
- accessor,
5040
+ }, undoSetRangeValuesMutationParams = this._injector.invoke(
5041
+ SetRangeValuesUndoMutationFactory,
5027
5042
  setRangeValuesMutationParams
5028
5043
  );
5029
5044
  if (undos.push({ id: SetRangeValuesMutation.id, params: undoSetRangeValuesMutationParams }), redos.push({ id: SetRangeValuesMutation.id, params: setRangeValuesMutationParams }), applyMergeRanges != null && applyMergeRanges.length) {
@@ -5031,8 +5046,8 @@ let AutoFillController = (_a9 = class extends Disposable {
5031
5046
  unitId,
5032
5047
  subUnitId,
5033
5048
  ranges
5034
- }, undoRemoveMutationParams = AddMergeUndoMutationFactory(
5035
- accessor,
5049
+ }, undoRemoveMutationParams = this._injector.invoke(
5050
+ RemoveMergeUndoMutationFactory,
5036
5051
  addMergeMutationParams
5037
5052
  );
5038
5053
  undos.push({ id: RemoveWorksheetMergeMutation.id, params: undoRemoveMutationParams }), redos.push({ id: AddWorksheetMergeMutation.id, params: addMergeMutationParams });
@@ -8470,9 +8485,7 @@ let SheetClipboardService = (_a13 = class extends Disposable {
8470
8485
  const target = this._getPastingTarget();
8471
8486
  if (!target.subUnitId || !target.selection)
8472
8487
  return !1;
8473
- const accessor = {
8474
- get: this._injector.get.bind(this._injector)
8475
- }, range = rangeToDiscreteRange(target.selection.range, accessor, target.unitId, target.subUnitId);
8488
+ const range = this._injector.invoke((accessor) => rangeToDiscreteRange(target.selection.range, accessor, target.unitId, target.subUnitId));
8476
8489
  if (!range)
8477
8490
  return !1;
8478
8491
  const { unitId, subUnitId } = target, hooks = this._clipboardHooks, enabledHooks = [];
@@ -8749,9 +8762,7 @@ let SheetClipboardService = (_a13 = class extends Disposable {
8749
8762
  const target = this._getPastingTarget(), { selection, unitId, subUnitId } = target;
8750
8763
  if (!subUnitId || !selection)
8751
8764
  return null;
8752
- const accessor = {
8753
- get: this._injector.get.bind(this._injector)
8754
- }, discreteRange = rangeToDiscreteRange(selection.range, accessor, unitId, subUnitId);
8765
+ const discreteRange = this._injector.invoke((accessor) => rangeToDiscreteRange(selection.range, accessor, unitId, subUnitId));
8755
8766
  if (!discreteRange)
8756
8767
  return null;
8757
8768
  const { ranges: [vRange], mapFunc } = virtualizeDiscreteRanges([discreteRange]), { startRow, startColumn, endRow, endColumn } = vRange, destinationRows = endRow - startRow + 1, destinationColumns = endColumn - startColumn + 1, workbook = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), worksheet = workbook == null ? void 0 : workbook.getActiveSheet();
@@ -8816,9 +8827,7 @@ let SheetClipboardService = (_a13 = class extends Disposable {
8816
8827
  const target = this._getPastingTarget(), { selection, unitId, subUnitId } = target;
8817
8828
  if (!subUnitId || !selection)
8818
8829
  return null;
8819
- const accessor = {
8820
- get: this._injector.get.bind(this._injector)
8821
- }, discreteRange = rangeToDiscreteRange(selection.range, accessor, unitId, subUnitId);
8830
+ const discreteRange = this._injector.invoke((accessor) => rangeToDiscreteRange(selection.range, accessor, unitId, subUnitId));
8822
8831
  if (!discreteRange)
8823
8832
  return null;
8824
8833
  const { startColumn, endColumn, startRow, endRow } = cellMatrix.getDataRange(), rowCount = endRow - startRow + 1, colCount = endColumn - startColumn + 1;
@@ -9017,7 +9026,7 @@ const SHEET_CLIPBOARD_PRIORITY = 998, SheetCopyCommand = {
9017
9026
  value: PREDEFINED_HOOK_NAME.SPECIAL_PASTE_BESIDES_BORDER
9018
9027
  }), "handler")
9019
9028
  };
9020
- var SheetMenuPosition = /* @__PURE__ */ ((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))(SheetMenuPosition || {});
9029
+ var SheetMenuPosition = /* @__PURE__ */ ((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 || {});
9021
9030
  function FormatPainterMenuItemFactory(accessor) {
9022
9031
  const formatPainterService = accessor.get(IFormatPainterService);
9023
9032
  return {
@@ -11078,8 +11087,10 @@ const SINGLE_MODE_WIDTH = 800, ROW_COUNT_THRESHOLD = 3, StatusBar = /* @__PURE__
11078
11087
  sheetContainer
11079
11088
  };
11080
11089
  function RenderSheetFooter() {
11081
- return useActiveWorkbook() ? /* @__PURE__ */ jsxRuntimeExports.jsxs("section", { className: styles$9.sheetContainer, "data-range-selector": !0, children: [
11090
+ const workbook = useActiveWorkbook(), footerMenus = useSimpleToolbarGroups(SheetMenuPosition.SHEET_FOOTER);
11091
+ return workbook ? /* @__PURE__ */ jsxRuntimeExports.jsxs("section", { className: styles$9.sheetContainer, "data-range-selector": !0, children: [
11082
11092
  /* @__PURE__ */ jsxRuntimeExports.jsx(SheetBar, {}),
11093
+ footerMenus.map((item) => /* @__PURE__ */ jsxRuntimeExports.jsx(ToolbarItem, { ...item }, item.id)),
11083
11094
  /* @__PURE__ */ jsxRuntimeExports.jsx(StatusBar, {}),
11084
11095
  /* @__PURE__ */ jsxRuntimeExports.jsx(CountBar, {})
11085
11096
  ] }) : null;
@@ -11098,7 +11109,11 @@ function RenderSheetContent() {
11098
11109
  __name(RenderSheetContent, "RenderSheetContent");
11099
11110
  function useHasWorkbook() {
11100
11111
  const univerInstanceService = useDependency(IUniverInstanceService), workbook = useObservable(() => univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET), null, !1, []);
11101
- return useMemo(() => univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).length > 0, [univerInstanceService, workbook]);
11112
+ return useMemo(
11113
+ () => univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).length > 0,
11114
+ // eslint-disable-next-line react-hooks/exhaustive-deps
11115
+ [univerInstanceService, workbook]
11116
+ );
11102
11117
  }
11103
11118
  __name(useHasWorkbook, "useHasWorkbook");
11104
11119
  const widthStyle = {
@@ -11230,7 +11245,7 @@ const widthStyle = {
11230
11245
  const unitId = workbook.getUnitId(), getDefinedNameMap = /* @__PURE__ */ __name(() => {
11231
11246
  const definedNameMap = definedNamesService.getDefinedNameMap(unitId);
11232
11247
  return definedNameMap ? Array.from(Object.values(definedNameMap)) : [];
11233
- }, "getDefinedNameMap"), [editState, setEditState] = useState(!1), [definedNames, setDefinedNames] = useState(getDefinedNameMap()), [editorKey, setEditorKey] = useState(null), [deleteConformKey, setDeleteConformKey] = useState();
11248
+ }, "getDefinedNameMap"), [editState2, setEditState] = useState(!1), [definedNames, setDefinedNames] = useState(getDefinedNameMap()), [editorKey, setEditorKey] = useState(null), [deleteConformKey, setDeleteConformKey] = useState();
11234
11249
  useEffect(() => {
11235
11250
  const definedNamesSubscription = definedNamesService.update$.subscribe(() => {
11236
11251
  setDefinedNames(getDefinedNameMap());
@@ -11293,11 +11308,11 @@ const widthStyle = {
11293
11308
  }, "getSheetNameBySheetId");
11294
11309
  return /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$h.definedNameContainer, children: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$h.definedNameContainerScroll, children: [
11295
11310
  /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
11296
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: openInsertCloseKeyEditor, className: styles$h.definedNameContainerAddButton, style: { display: editState ? "none" : "flex" }, children: [
11311
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: openInsertCloseKeyEditor, className: styles$h.definedNameContainerAddButton, style: { display: editState2 ? "none" : "flex" }, children: [
11297
11312
  /* @__PURE__ */ jsxRuntimeExports.jsx(IncreaseSingle, {}),
11298
11313
  /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$h.definedNameContainerAddButtonText, children: localeService.t("definedName.addButton") })
11299
11314
  ] }),
11300
- /* @__PURE__ */ jsxRuntimeExports.jsx(DefinedNameInput, { confirm: insertConfirm, cancel: closeInput, state: editState, inputId: "insertDefinedName", name: getInsertDefinedName(), formulaOrRefString: getInertFormulaOrRefString() })
11315
+ /* @__PURE__ */ jsxRuntimeExports.jsx(DefinedNameInput, { confirm: insertConfirm, cancel: closeInput, state: editState2, inputId: "insertDefinedName", name: getInsertDefinedName(), formulaOrRefString: getInertFormulaOrRefString() })
11301
11316
  ] }, "insertDefinedName"),
11302
11317
  definedNames.map((definedName2, index) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
11303
11318
  /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: /* @__PURE__ */ __name(() => {
@@ -11347,20 +11362,27 @@ const DEFAULT_RANGE_RULE = {
11347
11362
  unitId: "",
11348
11363
  subUnitId: "",
11349
11364
  permissionId: "",
11350
- unitType: l$1.Unkonwn,
11365
+ unitType: M.Unkonwn,
11351
11366
  id: "",
11352
11367
  ranges: []
11353
11368
  };
11354
- var viewState = /* @__PURE__ */ ((viewState2) => (viewState2.othersCanView = "othersCanView", viewState2.noOneElseCanView = "noOneElseCanView", viewState2))(viewState || {}), _a14;
11369
+ var viewState = /* @__PURE__ */ ((viewState2) => (viewState2.othersCanView = "othersCanView", viewState2.noOneElseCanView = "noOneElseCanView", viewState2))(viewState || {}), editState = /* @__PURE__ */ ((editState2) => (editState2.designedUserCanEdit = "designedUserCanEdit", editState2.onlyMe = "onlyMe", editState2))(editState || {}), _a14;
11355
11370
  let SheetPermissionPanelModel = (_a14 = class {
11356
11371
  constructor() {
11357
11372
  __publicField(this, "_rule", DEFAULT_RANGE_RULE);
11358
11373
  __publicField(this, "_rule$", new BehaviorSubject(this._rule));
11359
11374
  __publicField(this, "_oldRule");
11360
11375
  __publicField(this, "_rangeErrorMsg$", new BehaviorSubject(""));
11376
+ __publicField(this, "_visible", !1);
11361
11377
  __publicField(this, "rangeErrorMsg$", this._rangeErrorMsg$.asObservable());
11362
11378
  __publicField(this, "rule$", this._rule$.asObservable());
11363
11379
  }
11380
+ setVisible(v) {
11381
+ this._visible = v;
11382
+ }
11383
+ getVisible() {
11384
+ return this._visible;
11385
+ }
11364
11386
  setRangeErrorMsg(msg) {
11365
11387
  this._rangeErrorMsg$.next(msg);
11366
11388
  }
@@ -11373,6 +11395,9 @@ let SheetPermissionPanelModel = (_a14 = class {
11373
11395
  resetRule() {
11374
11396
  this._rule = DEFAULT_RANGE_RULE, this._rule$.next(this._rule);
11375
11397
  }
11398
+ reset() {
11399
+ this.setVisible(!1), this.resetRule(), this.setRangeErrorMsg(""), this.setOldRule(null);
11400
+ }
11376
11401
  get oldRule() {
11377
11402
  return this._oldRule;
11378
11403
  }
@@ -11404,6 +11429,9 @@ const _SheetPermissionUserManagerService = class _SheetPermissionUserManagerServ
11404
11429
  setUserList(userList) {
11405
11430
  this._userList = userList;
11406
11431
  }
11432
+ reset() {
11433
+ this._userList = [], this._oldCollaboratorList = [], this._selectUserList = [], this._selectUserList$.next([]), this._allUserList = [];
11434
+ }
11407
11435
  get oldCollaboratorList() {
11408
11436
  return this._oldCollaboratorList;
11409
11437
  }
@@ -11420,36 +11448,36 @@ const _SheetPermissionUserManagerService = class _SheetPermissionUserManagerServ
11420
11448
  __name(_SheetPermissionUserManagerService, "SheetPermissionUserManagerService");
11421
11449
  let SheetPermissionUserManagerService = _SheetPermissionUserManagerService;
11422
11450
  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 = {
11423
- [P.Copy]: "Copy",
11424
- [P.SetCellStyle]: "SetCellStyle",
11425
- [P.SetCellValue]: "SetCellValue",
11426
- [P.SetRowStyle]: "SetRowStyle",
11427
- [P.SetColumnStyle]: "SetColumnStyle",
11428
- [P.InsertRow]: "InsertRow",
11429
- [P.InsertColumn]: "InsertColumn",
11430
- [P.InsertHyperlink]: "InsertHyperlink",
11431
- [P.DeleteRow]: "DeleteRow",
11432
- [P.DeleteColumn]: "DeleteColumn",
11433
- [P.Sort]: "Sort",
11434
- [P.Filter]: "Filter",
11435
- [P.PivotTable]: "PivotTable",
11436
- [P.EditExtraObject]: "EditExtraObject"
11451
+ [L.Copy]: "Copy",
11452
+ [L.SetCellStyle]: "SetCellStyle",
11453
+ [L.SetCellValue]: "SetCellValue",
11454
+ [L.SetRowStyle]: "SetRowStyle",
11455
+ [L.SetColumnStyle]: "SetColumnStyle",
11456
+ [L.InsertRow]: "InsertRow",
11457
+ [L.InsertColumn]: "InsertColumn",
11458
+ [L.InsertHyperlink]: "InsertHyperlink",
11459
+ [L.DeleteRow]: "DeleteRow",
11460
+ [L.DeleteColumn]: "DeleteColumn",
11461
+ [L.Sort]: "Sort",
11462
+ [L.Filter]: "Filter",
11463
+ [L.PivotTable]: "PivotTable",
11464
+ [L.EditExtraObject]: "EditExtraObject"
11437
11465
  }, defaultWorksheetUnitActionList = [
11438
- P.Copy,
11439
- P.SetCellStyle,
11440
- P.SetCellValue,
11441
- P.SetRowStyle,
11442
- P.SetColumnStyle,
11443
- P.InsertRow,
11444
- P.InsertColumn,
11445
- P.InsertHyperlink,
11446
- P.DeleteRow,
11447
- P.DeleteColumn,
11448
- P.Sort,
11449
- P.Filter,
11450
- P.PivotTable,
11451
- P.EditExtraObject,
11452
- P.View
11466
+ L.Copy,
11467
+ L.SetCellStyle,
11468
+ L.SetCellValue,
11469
+ L.SetRowStyle,
11470
+ L.SetColumnStyle,
11471
+ L.InsertRow,
11472
+ L.InsertColumn,
11473
+ L.InsertHyperlink,
11474
+ L.DeleteRow,
11475
+ L.DeleteColumn,
11476
+ L.Sort,
11477
+ L.Filter,
11478
+ L.PivotTable,
11479
+ L.EditExtraObject,
11480
+ L.View
11453
11481
  ], 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 = {
11454
11482
  type: CommandType.OPERATION,
11455
11483
  id: "sheet-permission.operation.openPanel",
@@ -11467,10 +11495,10 @@ const UNIVER_SHEET_PERMISSION_PANEL = "UNIVER_SHEET_PERMISSION_PANEL", UNIVER_SH
11467
11495
  showDetail
11468
11496
  },
11469
11497
  onClose: /* @__PURE__ */ __name(() => {
11470
- sheetPermissionPanelModel.setRangeErrorMsg(""), sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.setUserList([]), sheetPermissionUserManagerService.setSelectUserList([]), sheetPermissionUserManagerService.setOldCollaboratorList([]), sheetPermissionUserManagerService.setAllUserList([]);
11498
+ sheetPermissionPanelModel.reset(), sheetPermissionUserManagerService.reset();
11471
11499
  }, "onClose")
11472
11500
  };
11473
- return sidebarService.open(sidebarProps), !0;
11501
+ return sheetPermissionPanelModel.setVisible(!0), sidebarService.open(sidebarProps), !0;
11474
11502
  }
11475
11503
  }, SheetPermissionOpenDialogOperation = {
11476
11504
  type: CommandType.OPERATION,
@@ -11762,7 +11790,7 @@ const UNIVER_SHEET_PERMISSION_PANEL = "UNIVER_SHEET_PERMISSION_PANEL", UNIVER_SH
11762
11790
  if (!params)
11763
11791
  return !1;
11764
11792
  const commandService = accessor.get(ICommandService), undoRedoService = accessor.get(IUndoRedoService), sheetPermissionPanelModel = accessor.get(SheetPermissionPanelModel), rangeProtectionRuleModel = accessor.get(RangeProtectionRuleModel), { rule } = params, { unitId, subUnitId } = rule, redoMutations = [], undoMutations = [], oldRule = sheetPermissionPanelModel.oldRule;
11765
- return (oldRule == null ? void 0 : oldRule.unitType) === rule.unitType ? rule.unitType === l$1.Worksheet ? (redoMutations.push({ id: SetWorksheetProtectionMutation.id, params: { unitId, subUnitId, rule } }), undoMutations.push({ id: SetWorksheetProtectionMutation.id, params: { unitId, subUnitId, rule: oldRule } })) : (redoMutations.push({ id: SetRangeProtectionMutation.id, params: { unitId, subUnitId, rule, ruleId: rule.id } }), undoMutations.push({ id: SetRangeProtectionMutation.id, params: { unitId, subUnitId, ruleId: oldRule.id, rule: oldRule } })) : (oldRule && (oldRule.unitType === l$1.Worksheet ? (redoMutations.push({ id: DeleteWorksheetProtectionMutation.id, params: { unitId, subUnitId } }), undoMutations.push({ id: AddWorksheetProtectionMutation.id, params: { unitId, rule: oldRule, subUnitId: oldRule.subUnitId } })) : oldRule.unitType === l$1.SelectRange && (redoMutations.push({ id: DeleteRangeProtectionMutation.id, params: { unitId, subUnitId, ruleIds: [oldRule.id] } }), undoMutations.push({ id: AddRangeProtectionMutation.id, params: { unitId, subUnitId, rules: [oldRule] } }))), rule.unitType === l$1.Worksheet ? (redoMutations.push({ id: AddWorksheetProtectionMutation.id, params: { unitId, rule, subUnitId: rule.subUnitId } }), undoMutations.unshift({ id: DeleteWorksheetProtectionMutation.id, params: { unitId, subUnitId } })) : rule.unitType === l$1.SelectRange && (rule.id = rangeProtectionRuleModel.createRuleId(unitId, subUnitId), redoMutations.push({ id: AddRangeProtectionMutation.id, params: { unitId, subUnitId, rules: [rule] } }), undoMutations.unshift({ id: DeleteRangeProtectionMutation.id, params: { unitId, subUnitId, ruleIds: [rule.id] } }))), sequenceExecute(redoMutations, commandService) && undoRedoService.pushUndoRedo({
11793
+ return (oldRule == null ? void 0 : oldRule.unitType) === rule.unitType ? rule.unitType === M.Worksheet ? (redoMutations.push({ id: SetWorksheetProtectionMutation.id, params: { unitId, subUnitId, rule } }), undoMutations.push({ id: SetWorksheetProtectionMutation.id, params: { unitId, subUnitId, rule: oldRule } })) : (redoMutations.push({ id: SetRangeProtectionMutation.id, params: { unitId, subUnitId, rule, ruleId: rule.id } }), undoMutations.push({ id: SetRangeProtectionMutation.id, params: { unitId, subUnitId, ruleId: oldRule.id, rule: oldRule } })) : (oldRule && (oldRule.unitType === M.Worksheet ? (redoMutations.push({ id: DeleteWorksheetProtectionMutation.id, params: { unitId, subUnitId } }), undoMutations.push({ id: AddWorksheetProtectionMutation.id, params: { unitId, rule: oldRule, subUnitId: oldRule.subUnitId } })) : oldRule.unitType === M.SelectRange && (redoMutations.push({ id: DeleteRangeProtectionMutation.id, params: { unitId, subUnitId, ruleIds: [oldRule.id] } }), undoMutations.push({ id: AddRangeProtectionMutation.id, params: { unitId, subUnitId, rules: [oldRule] } }))), rule.unitType === M.Worksheet ? (redoMutations.push({ id: AddWorksheetProtectionMutation.id, params: { unitId, rule, subUnitId: rule.subUnitId } }), undoMutations.unshift({ id: DeleteWorksheetProtectionMutation.id, params: { unitId, subUnitId } })) : rule.unitType === M.SelectRange && (rule.id = rangeProtectionRuleModel.createRuleId(unitId, subUnitId), redoMutations.push({ id: AddRangeProtectionMutation.id, params: { unitId, subUnitId, rules: [rule] } }), undoMutations.unshift({ id: DeleteRangeProtectionMutation.id, params: { unitId, subUnitId, ruleIds: [rule.id] } }))), sequenceExecute(redoMutations, commandService) && undoRedoService.pushUndoRedo({
11766
11794
  unitID: unitId,
11767
11795
  undoMutations,
11768
11796
  redoMutations
@@ -12831,9 +12859,10 @@ function getRemovePermissionDisable$(accessor) {
12831
12859
  var _a59;
12832
12860
  if (!worksheet)
12833
12861
  return of(!0);
12834
- const unitId = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), selectionProtectionRuleModel = accessor.get(RangeProtectionRuleModel), worksheetProtectionRuleModel = accessor.get(WorksheetProtectionRuleModel), permission$ = (_a59 = permissionService.composePermission$([new WorkbookManageCollaboratorPermission(unitId).id, new WorkbookEditablePermission(unitId).id]).pipe(map((permissions) => permissions.every((permission) => permission.value)))) != null ? _a59 : of(!1), changes$ = merge(
12862
+ const unitId = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), sheetSelectionsService = accessor.get(SheetsSelectionsService), selectionProtectionRuleModel = accessor.get(RangeProtectionRuleModel), worksheetProtectionRuleModel = accessor.get(WorksheetProtectionRuleModel), permission$ = (_a59 = permissionService.composePermission$([new WorkbookManageCollaboratorPermission(unitId).id, new WorkbookEditablePermission(unitId).id]).pipe(map((permissions) => permissions.every((permission) => permission.value)))) != null ? _a59 : of(!1), changes$ = merge(
12835
12863
  selectionProtectionRuleModel.ruleChange$,
12836
- worksheetProtectionRuleModel.ruleChange$
12864
+ worksheetProtectionRuleModel.ruleChange$,
12865
+ sheetSelectionsService.selectionMoveEnd$
12837
12866
  ).pipe(startWith(null));
12838
12867
  return combineLatest([changes$, permission$]).pipe(
12839
12868
  map(([_2, permission]) => {
@@ -13252,16 +13281,16 @@ var __defProp$F = Object.defineProperty, __getOwnPropDesc$F = Object.getOwnPrope
13252
13281
  return kind && result && __defProp$F(target, key, result), result;
13253
13282
  }, "__decorateClass$F"), __decorateParam$F = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$F"), _a16;
13254
13283
  let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderService {
13255
- constructor(_context, injector, themeService, shortcutService, renderManagerService, _selectionManagerService, _logService, _commandService, _contextService, _sheetSkeletonManagerService) {
13284
+ constructor(_context, injector, themeService, shortcutService, selectionManagerService, sheetSkeletonManagerService, _logService, _commandService, _contextService) {
13256
13285
  super(
13257
13286
  injector,
13258
13287
  themeService,
13259
13288
  shortcutService,
13260
- renderManagerService
13289
+ sheetSkeletonManagerService
13261
13290
  );
13262
13291
  __publicField(this, "_workbookSelections");
13263
13292
  __publicField(this, "_renderDisposable", null);
13264
- this._context = _context, this._selectionManagerService = _selectionManagerService, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this._sheetSkeletonManagerService = _sheetSkeletonManagerService, this._workbookSelections = _selectionManagerService.getWorkbookSelections(this._context.unitId), this._init();
13293
+ this._context = _context, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this._workbookSelections = selectionManagerService.getWorkbookSelections(this._context.unitId), this._init();
13265
13294
  }
13266
13295
  _init() {
13267
13296
  const sheetObject = this._getSheetObject();
@@ -13290,9 +13319,9 @@ let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderServi
13290
13319
  }
13291
13320
  _initThemeChangeListener() {
13292
13321
  this.disposeWithMe(this._themeService.currentTheme$.subscribe(() => {
13293
- this._resetStyle();
13294
- const param = this._workbookSelections.getCurrentSelections();
13295
- param && this._refreshSelectionControl(param);
13322
+ this._resetSelectionStyle();
13323
+ const selections = this._workbookSelections.getCurrentSelections();
13324
+ selections && this._refreshSelectionControl(selections);
13296
13325
  }));
13297
13326
  }
13298
13327
  _normalSelectionDisabled() {
@@ -13316,8 +13345,7 @@ let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderServi
13316
13345
  }));
13317
13346
  }
13318
13347
  /**
13319
- * set new selection range in seletion model
13320
- * selectionMoveEnd$ ---> _updateSelections --> selectionOperation@selectionManagerService.setSelections
13348
+ * Update selectionData to current sheet.
13321
13349
  * @param selectionDataWithStyleList
13322
13350
  * @param type
13323
13351
  */
@@ -13362,12 +13390,11 @@ SheetSelectionRenderService = __decorateClass$F([
13362
13390
  __decorateParam$F(1, Inject(Injector)),
13363
13391
  __decorateParam$F(2, Inject(ThemeService)),
13364
13392
  __decorateParam$F(3, IShortcutService),
13365
- __decorateParam$F(4, IRenderManagerService),
13366
- __decorateParam$F(5, Inject(SheetsSelectionsService)),
13393
+ __decorateParam$F(4, Inject(SheetsSelectionsService)),
13394
+ __decorateParam$F(5, Inject(SheetSkeletonManagerService)),
13367
13395
  __decorateParam$F(6, ILogService),
13368
13396
  __decorateParam$F(7, ICommandService),
13369
- __decorateParam$F(8, IContextService),
13370
- __decorateParam$F(9, Inject(SheetSkeletonManagerService))
13397
+ __decorateParam$F(8, IContextService)
13371
13398
  ], SheetSelectionRenderService);
13372
13399
  var __defProp$E = Object.defineProperty, __getOwnPropDesc$E = Object.getOwnPropertyDescriptor, __decorateClass$E = /* @__PURE__ */ __name((decorators, target, key, kind) => {
13373
13400
  for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$E(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
@@ -13593,6 +13620,8 @@ function getMoveRangeMutations(from, to, accessor) {
13593
13620
  newToCellValue.setValue(range.startRow, range.startColumn, fromCellMatrix.getValue(row, col));
13594
13621
  });
13595
13622
  const doMoveRangeMutation = {
13623
+ fromRange,
13624
+ toRange,
13596
13625
  from: {
13597
13626
  value: newFromCellValue.getMatrix(),
13598
13627
  subUnitId: fromSubUnitId
@@ -13603,6 +13632,8 @@ function getMoveRangeMutations(from, to, accessor) {
13603
13632
  },
13604
13633
  unitId
13605
13634
  }, undoMoveRangeMutation = {
13635
+ fromRange: toRange,
13636
+ toRange: fromRange,
13606
13637
  from: {
13607
13638
  value: fromCellValue.getMatrix(),
13608
13639
  subUnitId: fromSubUnitId
@@ -13743,7 +13774,8 @@ function getSetCellStyleMutations(pasteTo, matrix, accessor, withRichFormat = !1
13743
13774
  s: Object.assign({}, {
13744
13775
  ...DEFAULT_STYLES,
13745
13776
  pd: DEFAULT_PADDING_DATA,
13746
- bg: null
13777
+ bg: null,
13778
+ cl: null
13747
13779
  }, value.s)
13748
13780
  };
13749
13781
  withRichFormat && ((_a59 = value.p) != null && _a59.body) && (newValue.p = value.p);
@@ -14171,44 +14203,39 @@ let SheetClipboardController = (_a19 = class extends RxDisposable {
14171
14203
  };
14172
14204
  }
14173
14205
  _onPasteCells(pasteFrom, pasteTo, data, payload) {
14174
- const accessor = {
14175
- get: this._injector.get.bind(this._injector)
14176
- };
14177
- return getDefaultOnPasteCellMutations(pasteFrom, pasteTo, data, payload, accessor);
14206
+ return this._injector.invoke((accessor) => getDefaultOnPasteCellMutations(pasteFrom, pasteTo, data, payload, accessor));
14178
14207
  }
14179
14208
  _initSpecialPasteHooks() {
14180
- const accessor = {
14181
- get: this._injector.get.bind(this._injector)
14182
- }, self = this, specialPasteValueHook = {
14209
+ const self = this, specialPasteValueHook = {
14183
14210
  id: PREDEFINED_HOOK_NAME.SPECIAL_PASTE_VALUE,
14184
14211
  specialPasteInfo: {
14185
14212
  label: "specialPaste.value"
14186
14213
  },
14187
- onPasteCells: /* @__PURE__ */ __name((pasteFrom, pasteTo, data) => getSetCellValueMutations(pasteTo, pasteFrom, data, accessor), "onPasteCells")
14214
+ onPasteCells: /* @__PURE__ */ __name((pasteFrom, pasteTo, data) => this._injector.invoke((accessor) => getSetCellValueMutations(pasteTo, pasteFrom, data, accessor)), "onPasteCells")
14188
14215
  }, specialPasteFormatHook = {
14189
14216
  id: PREDEFINED_HOOK_NAME.SPECIAL_PASTE_FORMAT,
14190
14217
  specialPasteInfo: {
14191
14218
  label: "specialPaste.format"
14192
14219
  },
14193
- onPasteCells(pasteFrom, pasteTo, matrix) {
14194
- const redoMutationsInfo = [], undoMutationsInfo = [], { undos: styleUndos, redos: styleRedos } = getClearCellStyleMutations(pasteTo, matrix, accessor);
14220
+ onPasteCells: /* @__PURE__ */ __name((pasteFrom, pasteTo, matrix) => {
14221
+ const redoMutationsInfo = [], undoMutationsInfo = [], { undos: styleUndos, redos: styleRedos } = this._injector.invoke((accessor) => getClearCellStyleMutations(pasteTo, matrix, accessor));
14195
14222
  redoMutationsInfo.push(...styleRedos), undoMutationsInfo.push(...styleUndos);
14196
- const { undos: mergeUndos, redos: mergeRedos } = getClearAndSetMergeMutations(
14223
+ const { undos: mergeUndos, redos: mergeRedos } = this._injector.invoke((accessor) => getClearAndSetMergeMutations(
14197
14224
  pasteTo,
14198
14225
  matrix,
14199
14226
  accessor
14200
- );
14227
+ ));
14201
14228
  redoMutationsInfo.push(...mergeRedos), undoMutationsInfo.push(...mergeUndos);
14202
- const { undos: setStyleUndos, redos: setStyleRedos } = getSetCellStyleMutations(
14229
+ const { undos: setStyleUndos, redos: setStyleRedos } = this._injector.invoke((accessor) => getSetCellStyleMutations(
14203
14230
  pasteTo,
14204
14231
  matrix,
14205
14232
  accessor
14206
- );
14233
+ ));
14207
14234
  return redoMutationsInfo.push(...setStyleRedos), undoMutationsInfo.push(...setStyleUndos), {
14208
14235
  undos: undoMutationsInfo,
14209
14236
  redos: redoMutationsInfo
14210
14237
  };
14211
- }
14238
+ }, "onPasteCells")
14212
14239
  }, specialPasteColWidthHook = {
14213
14240
  id: PREDEFINED_HOOK_NAME.SPECIAL_PASTE_COL_WIDTH,
14214
14241
  specialPasteInfo: {
@@ -14252,7 +14279,7 @@ let SheetClipboardController = (_a19 = class extends RxDisposable {
14252
14279
  specialPasteInfo: {
14253
14280
  label: "specialPaste.besidesBorder"
14254
14281
  },
14255
- onPasteCells(pasteFrom, pasteTo, matrix, payload) {
14282
+ onPasteCells: /* @__PURE__ */ __name((pasteFrom, pasteTo, matrix, payload) => {
14256
14283
  self._currentUniverSheet.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
14257
14284
  const redoMutationsInfo = [], undoMutationsInfo = [], { range, unitId, subUnitId } = pasteTo, valueMatrix = new ObjectMatrix();
14258
14285
  matrix.forValue((row, col, value) => {
@@ -14271,20 +14298,20 @@ let SheetClipboardController = (_a19 = class extends RxDisposable {
14271
14298
  id: SetRangeValuesMutation.id,
14272
14299
  params: setValuesMutation
14273
14300
  });
14274
- const undoSetValuesMutation = SetRangeValuesUndoMutationFactory(
14275
- accessor,
14301
+ const undoSetValuesMutation = this._injector.invoke(
14302
+ SetRangeValuesUndoMutationFactory,
14276
14303
  setValuesMutation
14277
14304
  );
14278
14305
  undoMutationsInfo.push({
14279
14306
  id: SetRangeValuesMutation.id,
14280
14307
  params: undoSetValuesMutation
14281
14308
  });
14282
- const { undos, redos } = getClearAndSetMergeMutations(pasteTo, matrix, accessor);
14309
+ const { undos, redos } = this._injector.invoke((accessor) => getClearAndSetMergeMutations(pasteTo, matrix, accessor));
14283
14310
  return undoMutationsInfo.push(...undos), redoMutationsInfo.push(...redos), {
14284
14311
  redos: redoMutationsInfo,
14285
14312
  undos: undoMutationsInfo
14286
14313
  };
14287
- }
14314
+ }, "onPasteCells")
14288
14315
  };
14289
14316
  return [specialPasteValueHook, specialPasteFormatHook, specialPasteColWidthHook, specialPasteBesidesBorder];
14290
14317
  }
@@ -14755,7 +14782,9 @@ let EditingRenderController = (_a21 = class extends Disposable {
14755
14782
  }
14756
14783
  _init() {
14757
14784
  const d = new DisposableCollection();
14758
- return this._subscribeToCurrentCell(d), this._initialKeyboardListener(d), this._initialCursorSync(d), this._listenEditorFocus(d), this._commandExecutedListener(d), this._cursorStateListener(d), d;
14785
+ return this._subscribeToCurrentCell(d), this._initialKeyboardListener(d), this._initialCursorSync(d), this._listenEditorFocus(d), this._commandExecutedListener(d), setTimeout(() => {
14786
+ this._cursorStateListener(d);
14787
+ }, 1e3), d;
14759
14788
  }
14760
14789
  _initEditorVisibilityListener() {
14761
14790
  this.disposeWithMe(this._editorBridgeService.visible$.pipe(distinctUntilChanged((prev, curr) => prev.visible === curr.visible)).subscribe((param) => {
@@ -15079,7 +15108,7 @@ let EditingRenderController = (_a21 = class extends Disposable {
15079
15108
  worksheet.getCellRaw(row, column) || {},
15080
15109
  documentLayoutObject,
15081
15110
  this._lexerTreeBuilder,
15082
- (model) => this._resourceLoaderService.saveDoc(model),
15111
+ (model) => this._resourceLoaderService.saveUnit(model.getUnitId()),
15083
15112
  this._localService,
15084
15113
  this._functionService
15085
15114
  );
@@ -16519,8 +16548,10 @@ const HEADER_MENU_SHAPE_RECT_BACKGROUND_FILL = "rgba(120, 120, 120, 0.01)", HEAD
16519
16548
  return this._color;
16520
16549
  }
16521
16550
  _draw(ctx) {
16551
+ const scene = this.getScene();
16552
+ if (!scene) return;
16553
+ const { scaleX, scaleY } = scene.getAncestorScale(), scale = Math.max(scaleX, scaleY), HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE = HEADER_MENU_SHAPE_SIZE / scale, HEADER_MENU_SHAPE_THUMB_SIZE_SCALE = HEADER_MENU_SHAPE_THUMB_SIZE / scale;
16522
16554
  let { width, height } = this, left = 0, top = 0;
16523
- const scene = this.getScene(), { scaleX, scaleY } = scene.getAncestorScale(), scale = Math.max(scaleX, scaleY), HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE = HEADER_MENU_SHAPE_SIZE / scale, HEADER_MENU_SHAPE_THUMB_SIZE_SCALE = HEADER_MENU_SHAPE_THUMB_SIZE / scale;
16524
16555
  this.mode === 0 ? (width = HEADER_MENU_SHAPE_THUMB_SIZE_SCALE, left = HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE - HEADER_MENU_SHAPE_THUMB_SIZE_SCALE) : (height = HEADER_MENU_SHAPE_THUMB_SIZE_SCALE, top = HEADER_MENU_SHAPE_WIDTH_HEIGHT_SCALE - HEADER_MENU_SHAPE_THUMB_SIZE_SCALE), Rect.drawWith(ctx, {
16525
16556
  width: this.width,
16526
16557
  height: this.height,
@@ -17049,17 +17080,17 @@ let StatusBarController = (_a29 = class extends Disposable {
17049
17080
  this._statusBarService.setState(null);
17050
17081
  }
17051
17082
  _calculateSelection(selections, primary) {
17052
- var _a59, _b;
17083
+ var _a59;
17053
17084
  const workbook = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
17054
17085
  if (!workbook)
17055
17086
  return this._clearResult();
17056
- const unitId = workbook.getUnitId(), sheetId = (_a59 = workbook.getActiveSheet()) == null ? void 0 : _a59.getSheetId();
17087
+ const unitId = workbook.getUnitId(), sheet = workbook.getActiveSheet(), sheetId = sheet == null ? void 0 : sheet.getSheetId();
17057
17088
  if (!sheetId)
17058
17089
  return this._clearResult();
17059
17090
  const sheetData = {}, arrayFormulaMatrixCell = this._formulaDataModel.getArrayFormulaCellData();
17060
- if (this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET).getSheets().forEach((sheet) => {
17061
- const sheetConfig = sheet.getConfig();
17062
- sheetData[sheet.getSheetId()] = {
17091
+ if (this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET).getSheets().forEach((sheet2) => {
17092
+ const sheetConfig = sheet2.getConfig();
17093
+ sheetData[sheet2.getSheetId()] = {
17063
17094
  cellData: new ObjectMatrix(sheetConfig.cellData),
17064
17095
  rowCount: sheetConfig.rowCount,
17065
17096
  columnCount: sheetConfig.columnCount,
@@ -17067,7 +17098,15 @@ let StatusBarController = (_a29 = class extends Disposable {
17067
17098
  columnData: sheetConfig.columnData
17068
17099
  };
17069
17100
  }), selections != null && selections.length) {
17070
- const refs = selections.map((s) => new RangeReferenceObject(s, sheetId, unitId));
17101
+ const realSelections = [];
17102
+ selections.forEach((selection) => {
17103
+ const { startRow: start, endRow: end } = selection;
17104
+ let prev = null;
17105
+ for (let r = start; r <= end; r++)
17106
+ sheet.getRowVisible(r) ? prev === null && (prev = r) : prev !== null && (realSelections.push({ ...selection, startRow: prev, endRow: r - 1 }), prev = null);
17107
+ prev !== null && realSelections.push({ ...selection, startRow: prev, endRow: end });
17108
+ });
17109
+ const refs = realSelections.map((s) => new RangeReferenceObject(s, sheetId, unitId));
17071
17110
  refs.forEach((ref) => {
17072
17111
  ref.setUnitData({
17073
17112
  [unitId]: sheetData
@@ -17093,7 +17132,7 @@ let StatusBarController = (_a29 = class extends Disposable {
17093
17132
  let pattern = null;
17094
17133
  if (primary) {
17095
17134
  const { actualRow, actualColumn } = primary;
17096
- pattern = (_b = this._numfmtService.getValue(unitId, sheetId, actualRow, actualColumn)) == null ? void 0 : _b.pattern;
17135
+ pattern = (_a59 = this._numfmtService.getValue(unitId, sheetId, actualRow, actualColumn)) == null ? void 0 : _a59.pattern;
17097
17136
  }
17098
17137
  const newState = {
17099
17138
  values: calcResult.filter((r) => r !== void 0),
@@ -17130,7 +17169,7 @@ let SheetRenderController = (_a30 = class extends RxDisposable {
17130
17169
  if (!worksheet)
17131
17170
  throw new Error("No active sheet found");
17132
17171
  const sheetId = worksheet.getSheetId();
17133
- this._sheetSkeletonManagerService.setCurrent({ sheetId }), workbook.getShouldRenderLoopImmediately() && engine.runRenderLoop(() => scene.render());
17172
+ this._sheetSkeletonManagerService.setCurrent({ sheetId }), engine.runRenderLoop(() => scene.render());
17134
17173
  }
17135
17174
  _addComponent(workbook) {
17136
17175
  const { scene, components } = this._context, worksheet = workbook.getActiveSheet();
@@ -17294,7 +17333,7 @@ let SheetRenderController = (_a30 = class extends RxDisposable {
17294
17333
  this._markViewportDirty(viewports, dirtyBounds), spreadsheet.setDirtyArea(dirtyBounds);
17295
17334
  }
17296
17335
  if (command.id === MoveRangeMutation.id && cmdParams.from && cmdParams.to) {
17297
- const fromRange = this._cellValueToRange(cmdParams.from.value), toRange = this._cellValueToRange(cmdParams.to.value), dirtyBounds = this._rangeToBounds([fromRange, toRange]);
17336
+ const fromRange = cmdParams.fromRange || this._cellValueToRange(cmdParams.from.value), toRange = cmdParams.toRange || this._cellValueToRange(cmdParams.to.value), dirtyBounds = this._rangeToBounds([fromRange, toRange]);
17298
17337
  this._markViewportDirty(viewports, dirtyBounds), spreadsheet.setDirtyArea(dirtyBounds);
17299
17338
  }
17300
17339
  }
@@ -17302,19 +17341,20 @@ let SheetRenderController = (_a30 = class extends RxDisposable {
17302
17341
  * cellValue data structure:
17303
17342
  * {[row]: { [col]: value}}
17304
17343
  * @param cellValue
17305
- * @returns
17344
+ * @returns IRange
17306
17345
  */
17307
17346
  _cellValueToRange(cellValue) {
17308
- const rows = Object.keys(cellValue).map(Number), columns = [];
17309
- for (const [_row, columnObj] of Object.entries(cellValue))
17347
+ let minCol = 0, maxCol = 0, minRow = 0, maxRow = 0;
17348
+ for (const [_row, columnObj] of Object.entries(cellValue)) {
17310
17349
  for (const column in columnObj)
17311
- columns.push(Number(column));
17312
- const startRow = Math.min(...rows), endRow = Math.max(...rows), startColumn = Math.min(...columns), endColumn = Math.max(...columns);
17350
+ minCol > Number(column) && (minCol = Number(column)), maxCol < Number(column) && (maxCol = Number(column));
17351
+ minRow > Number(_row) && (minRow = Number(_row)), maxRow < Number(_row) && (maxRow = Number(_row));
17352
+ }
17313
17353
  return {
17314
- startRow,
17315
- endRow,
17316
- startColumn,
17317
- endColumn
17354
+ startRow: minRow,
17355
+ endRow: maxRow,
17356
+ startColumn: minCol,
17357
+ endColumn: maxCol
17318
17358
  };
17319
17359
  }
17320
17360
  _rangeToBounds(ranges) {
@@ -17548,7 +17588,8 @@ let SheetCanvasPopManagerService = (_a33 = class extends Disposable {
17548
17588
  unitId,
17549
17589
  subUnitId,
17550
17590
  anchorRect: position,
17551
- anchorRect$: position$
17591
+ anchorRect$: position$,
17592
+ canvasElement: currentRender.engine.getCanvasElement()
17552
17593
  });
17553
17594
  return {
17554
17595
  dispose: /* @__PURE__ */ __name(() => {
@@ -17585,7 +17626,8 @@ let SheetCanvasPopManagerService = (_a33 = class extends Disposable {
17585
17626
  unitId,
17586
17627
  subUnitId,
17587
17628
  anchorRect: position,
17588
- anchorRect$: position$
17629
+ anchorRect$: position$,
17630
+ canvasElement: currentRender.engine.getCanvasElement()
17589
17631
  }), disposableCollection = new DisposableCollection();
17590
17632
  disposableCollection.add(positionObserverDisposable), disposableCollection.add(toDisposable(() => {
17591
17633
  this._globalPopupManagerService.removePopup(id), position$.complete();
@@ -18030,9 +18072,7 @@ let FormatPainterController = (_a40 = class extends Disposable {
18030
18072
  };
18031
18073
  }
18032
18074
  _getUndoRedoMutationInfo(unitId, subUnitId, range, format) {
18033
- const sheetInterceptorService = this._sheetInterceptorService, univerInstanceService = this._univerInstanceService, accessor = {
18034
- get: this._injector.get.bind(this._injector)
18035
- }, { merges, styles: stylesMatrix } = format;
18075
+ const sheetInterceptorService = this._sheetInterceptorService, univerInstanceService = this._univerInstanceService, { merges, styles: stylesMatrix } = format;
18036
18076
  if (!stylesMatrix) return { undos: [], redos: [] };
18037
18077
  const { startRow, startColumn, endRow, endColumn } = stylesMatrix.getDataRange(), styleRowsNum = endRow - startRow + 1, styleColsNum = endColumn - startColumn + 1, styleValues = Array.from(
18038
18078
  { length: range.endRow - range.startRow + 1 },
@@ -18079,8 +18119,8 @@ let FormatPainterController = (_a40 = class extends Disposable {
18079
18119
  subUnitId,
18080
18120
  unitId,
18081
18121
  cellValue: realCellValue != null ? realCellValue : cellValue.getMatrix()
18082
- }, undoSetRangeValuesMutationParams = SetRangeValuesUndoMutationFactory(
18083
- accessor,
18122
+ }, undoSetRangeValuesMutationParams = this._injector.invoke(
18123
+ SetRangeValuesUndoMutationFactory,
18084
18124
  setRangeValuesMutationParams
18085
18125
  ), { undos: interceptorUndos, redos: interceptorRedos } = sheetInterceptorService.onCommandExecute({
18086
18126
  id: SetRangeValuesCommand.id,
@@ -18095,9 +18135,15 @@ let FormatPainterController = (_a40 = class extends Disposable {
18095
18135
  ranges
18096
18136
  };
18097
18137
  mergeRedos.push({ id: RemoveWorksheetMergeMutation.id, params: removeMergeMutationParams }), mergeRedos.push({ id: AddWorksheetMergeMutation.id, params: addMergeMutationParams });
18098
- const undoRemoveMergeMutationParams = RemoveMergeUndoMutationFactory(accessor, removeMergeMutationParams), undoMutationParams = AddMergeUndoMutationFactory(accessor, addMergeMutationParams);
18138
+ const undoRemoveMergeMutationParams = this._injector.invoke(
18139
+ RemoveMergeUndoMutationFactory,
18140
+ removeMergeMutationParams
18141
+ ), undoMutationParams = this._injector.invoke(
18142
+ AddMergeUndoMutationFactory,
18143
+ addMergeMutationParams
18144
+ );
18099
18145
  if (mergeUndos.push({ id: RemoveWorksheetMergeMutation.id, params: undoMutationParams }), mergeUndos.push({ id: AddWorksheetMergeMutation.id, params: undoRemoveMergeMutationParams }), willRemoveSomeCell) {
18100
- const data = getClearContentMutationParamsForRanges(accessor, unitId, worksheet, ranges);
18146
+ const data = this._injector.invoke((accessor) => getClearContentMutationParamsForRanges(accessor, unitId, worksheet, ranges));
18101
18147
  mergeRedos.unshift(...data.redos), mergeUndos.push(...data.undos);
18102
18148
  }
18103
18149
  return {
@@ -18263,7 +18309,6 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18263
18309
  switch (id) {
18264
18310
  case InsertCommand.id:
18265
18311
  case IMEInputCommand.id:
18266
- case SetCellEditVisibleOperation.id:
18267
18312
  if (this._contextService.getContextValue(FOCUSING_EDITOR_STANDALONE) === !0)
18268
18313
  break;
18269
18314
  permission = this.permissionCheckWithoutRange({
@@ -18272,6 +18317,15 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18272
18317
  worksheetTypes: [WorksheetSetCellValuePermission, WorksheetEditPermission]
18273
18318
  }), errorMsg = this._localeService.t("permission.dialog.editErr");
18274
18319
  break;
18320
+ case SetCellEditVisibleOperation.id:
18321
+ if (params.visible === !1)
18322
+ break;
18323
+ permission = this.permissionCheckWithoutRange({
18324
+ workbookTypes: [WorkbookEditablePermission],
18325
+ rangeTypes: [RangeProtectionPermissionEditPoint],
18326
+ worksheetTypes: [WorksheetSetCellValuePermission, WorksheetEditPermission]
18327
+ }), errorMsg = this._localeService.t("permission.dialog.editErr");
18328
+ break;
18275
18329
  case SetRangeValuesCommand.id:
18276
18330
  isICellData(params.value) && params.value.f ? (permission = this._permissionCheckWithFormula(params), errorMsg = this._localeService.t("permission.dialog.formulaErr")) : permission = this._permissionCheckBySetRangeValue({
18277
18331
  workbookTypes: [WorkbookEditablePermission],
@@ -18428,7 +18482,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18428
18482
  if (!target)
18429
18483
  return !1;
18430
18484
  const { worksheet, unitId, subUnitId } = target, selectionRange = (_a59 = this._selectionManagerService.getCurrentLastSelection()) == null ? void 0 : _a59.range;
18431
- return !(!selectionRange || (direction === "top" ? selectionRange.startRow = 0 : direction === "left" ? selectionRange.startColumn = 0 : direction === "right" ? selectionRange.endColumn = worksheet.getColumnCount() - 1 : direction === "bottom" && (selectionRange.endRow = worksheet.getRowCount() - 1), this._rangeProtectionRuleModel.getSubunitRuleList(unitId, subUnitId).map((rule) => rule.ranges).flat().some((range) => Rectangle.getIntersects(selectionRange, range))));
18485
+ return !(!selectionRange || (direction === "top" || direction === "bottom" ? selectionRange.endRow = worksheet.getRowCount() - 1 : (direction === "left" || direction === "right") && (selectionRange.endColumn = worksheet.getColumnCount() - 1), this._rangeProtectionRuleModel.getSubunitRuleList(unitId, subUnitId).map((rule) => rule.ranges).flat().some((range) => Rectangle.getIntersects(selectionRange, range))));
18432
18486
  }
18433
18487
  _permissionCheckByWorksheetCommand(types) {
18434
18488
  var _a59, _b;
@@ -18530,7 +18584,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18530
18584
  for (let row = range.startRow; row <= range.endRow; row++)
18531
18585
  for (let col = range.startColumn; col <= range.endColumn; col++) {
18532
18586
  const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
18533
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
18587
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
18534
18588
  return !1;
18535
18589
  }
18536
18590
  }), !0);
@@ -18547,7 +18601,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18547
18601
  for (let row = range.startRow; row <= range.endRow; row++)
18548
18602
  for (let col = range.startColumn; col <= range.endColumn; col++) {
18549
18603
  const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
18550
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
18604
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
18551
18605
  return !0;
18552
18606
  }
18553
18607
  return !1;
@@ -18563,7 +18617,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18563
18617
  for (let row = range.startRow; row <= range.endRow; row++)
18564
18618
  for (let col = range.startColumn; col <= range.endColumn; col++) {
18565
18619
  const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
18566
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
18620
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
18567
18621
  return !1;
18568
18622
  }
18569
18623
  }), !0);
@@ -18588,12 +18642,12 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18588
18642
  if (sequenceGrid.sheetName) {
18589
18643
  const targetSheet = workbook.getSheetBySheetName(sequenceGrid.sheetName);
18590
18644
  if (!targetSheet)
18591
- return !1;
18645
+ return !0;
18592
18646
  const { startRow, endRow, startColumn, endColumn } = sequenceGrid.range;
18593
18647
  for (let i2 = startRow; i2 <= endRow; i2++)
18594
18648
  for (let j = startColumn; j <= endColumn; j++) {
18595
18649
  const permission = (_c = (_b = targetSheet.getCell(i2, j)) == null ? void 0 : _b.selectionProtection) == null ? void 0 : _c[0];
18596
- if ((permission == null ? void 0 : permission[P.View]) === !1)
18650
+ if ((permission == null ? void 0 : permission[L.View]) === !1)
18597
18651
  return !1;
18598
18652
  }
18599
18653
  }
@@ -18605,7 +18659,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18605
18659
  return !0;
18606
18660
  for (let i = 0; i < sequenceNodes.length; i++) {
18607
18661
  const node = sequenceNodes[i];
18608
- if (typeof node == "string")
18662
+ if (typeof node == "string" || node.nodeType !== sequenceNodeType.REFERENCE)
18609
18663
  continue;
18610
18664
  const { token } = node, sequenceGrid = deserializeRangeWithSheet(token), workbook2 = sequenceGrid.unitId ? this._univerInstanceService.getUnit(sequenceGrid.unitId) : this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
18611
18665
  if (!workbook2) return !0;
@@ -18623,10 +18677,11 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
18623
18677
  for (let i2 = startRow; i2 <= endRow; i2++)
18624
18678
  for (let j = startColumn; j <= endColumn; j++) {
18625
18679
  const permission = (_e = (_d = targetSheet.getCell(i2, j)) == null ? void 0 : _d.selectionProtection) == null ? void 0 : _e[0];
18626
- if ((permission == null ? void 0 : permission[P.View]) === !1)
18680
+ if ((permission == null ? void 0 : permission[L.View]) === !1)
18627
18681
  return !1;
18628
18682
  }
18629
18683
  }
18684
+ return !0;
18630
18685
  }
18631
18686
  }
18632
18687
  if (range) {
@@ -18690,7 +18745,7 @@ let SheetPermissionInterceptorClipboardController = (_a44 = class extends Dispos
18690
18745
  for (let row = startRow; row <= endRow; row++)
18691
18746
  for (let col = startColumn; col <= endColumn; col++) {
18692
18747
  const permission = (_c = (_b = worksheet.getCell(row, col)) == null ? void 0 : _b.selectionProtection) == null ? void 0 : _c[0];
18693
- if ((permission == null ? void 0 : permission[P.Edit]) === !1) {
18748
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1) {
18694
18749
  hasPermission = !1;
18695
18750
  break;
18696
18751
  }
@@ -18715,29 +18770,34 @@ var __defProp$c = Object.defineProperty, __getOwnPropDesc$c = Object.getOwnPrope
18715
18770
  return kind && result && __defProp$c(target, key, result), result;
18716
18771
  }, "__decorateClass$c"), __decorateParam$c = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$c"), _a45;
18717
18772
  let SheetPermissionInitController = (_a45 = class extends Disposable {
18718
- constructor(_univerInstanceService, _dialogService, _permissionService, _authzIoService, _rangeProtectionRuleModel, _worksheetProtectionRuleModel, _userManagerService, _worksheetProtectionPointRuleModel, _sheetInterceptorService, _selectionProtectionRenderModel) {
18719
- super(), this._univerInstanceService = _univerInstanceService, this._dialogService = _dialogService, this._permissionService = _permissionService, this._authzIoService = _authzIoService, this._rangeProtectionRuleModel = _rangeProtectionRuleModel, this._worksheetProtectionRuleModel = _worksheetProtectionRuleModel, this._userManagerService = _userManagerService, this._worksheetProtectionPointRuleModel = _worksheetProtectionPointRuleModel, this._sheetInterceptorService = _sheetInterceptorService, this._selectionProtectionRenderModel = _selectionProtectionRenderModel, this._initRangePermissionFromSnapshot(), this._initRangePermissionChange(), this._initWorksheetPermissionFromSnapshot(), this._initWorksheetPermissionChange(), this._initWorksheetPermissionPointsChange(), this.initWorkbookPermissionChange(), this._initUserChange(), this._initViewModelByRangeInterceptor(), this._initViewModelBySheetInterceptor();
18773
+ constructor(_univerInstanceService, _dialogService, _permissionService, _authzIoService, _rangeProtectionRuleModel, _worksheetProtectionRuleModel, _userManagerService, _worksheetProtectionPointRuleModel, _sheetInterceptorService, _selectionProtectionRenderModel, _undoRedoService) {
18774
+ super(), this._univerInstanceService = _univerInstanceService, this._dialogService = _dialogService, this._permissionService = _permissionService, this._authzIoService = _authzIoService, this._rangeProtectionRuleModel = _rangeProtectionRuleModel, this._worksheetProtectionRuleModel = _worksheetProtectionRuleModel, this._userManagerService = _userManagerService, this._worksheetProtectionPointRuleModel = _worksheetProtectionPointRuleModel, this._sheetInterceptorService = _sheetInterceptorService, this._selectionProtectionRenderModel = _selectionProtectionRenderModel, this._undoRedoService = _undoRedoService, this._initRangePermissionFromSnapshot(), this._initRangePermissionChange(), this._initWorksheetPermissionFromSnapshot(), this._initWorksheetPermissionChange(), this._initWorksheetPermissionPointsChange(), this._initWorkbookPermissionFromSnapshot(), this._initUserChange(), this._initViewModelByRangeInterceptor(), this._initViewModelBySheetInterceptor();
18720
18775
  }
18721
18776
  _initRangePermissionFromSnapshot() {
18722
- const allAllowedParams = [], workbook = this._univerInstanceService.getCurrentUnitForType(I.UNIVER_SHEET), unitId = workbook.getUnitId(), allSheets = workbook.getSheets(), permissionIdWithRuleInstanceMap = /* @__PURE__ */ new Map();
18723
- allSheets.forEach((sheet) => {
18724
- const subunitId = sheet.getSheetId();
18725
- this._rangeProtectionRuleModel.getSubunitRuleList(unitId, subunitId).forEach((rule) => {
18726
- permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
18727
- objectID: rule.permissionId,
18728
- unitID: unitId,
18729
- objectType: l$1.SelectRange,
18730
- actions: [P.View, P.Edit]
18777
+ const initRangePermissionFunc = /* @__PURE__ */ __name((workbook) => {
18778
+ const allAllowedParams = [], unitId = workbook.getUnitId(), allSheets = workbook.getSheets(), permissionIdWithRuleInstanceMap = /* @__PURE__ */ new Map();
18779
+ allSheets.forEach((sheet) => {
18780
+ const subunitId = sheet.getSheetId();
18781
+ this._rangeProtectionRuleModel.getSubunitRuleList(unitId, subunitId).forEach((rule) => {
18782
+ permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
18783
+ objectID: rule.permissionId,
18784
+ unitID: unitId,
18785
+ objectType: M.SelectRange,
18786
+ actions: [L.View, L.Edit]
18787
+ });
18731
18788
  });
18732
- });
18733
- }), allAllowedParams.length && this._authzIoService.batchAllowed(allAllowedParams).then((permissionMap) => {
18734
- permissionMap.forEach((item) => {
18735
- const rule = permissionIdWithRuleInstanceMap.get(item.objectID);
18736
- rule && getAllRangePermissionPoint().forEach((F) => {
18737
- const instance = new F(unitId, rule.subUnitId, item.objectID), unitActionName = instance.subType, result = item.actions.find((action) => action.action === unitActionName);
18738
- (result == null ? void 0 : result.allowed) !== void 0 && this._permissionService.updatePermissionPoint(instance.id, result.allowed);
18789
+ }), allAllowedParams.length && this._authzIoService.batchAllowed(allAllowedParams).then((permissionMap) => {
18790
+ permissionMap.forEach((item) => {
18791
+ const rule = permissionIdWithRuleInstanceMap.get(item.objectID);
18792
+ rule && getAllRangePermissionPoint().forEach((F) => {
18793
+ const instance = new F(unitId, rule.subUnitId, item.objectID), unitActionName = instance.subType, result = item.actions.find((action) => action.action === unitActionName);
18794
+ (result == null ? void 0 : result.allowed) !== void 0 && this._permissionService.updatePermissionPoint(instance.id, result.allowed);
18795
+ });
18739
18796
  });
18740
18797
  });
18798
+ }, "initRangePermissionFunc");
18799
+ this._univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).forEach((workbook) => {
18800
+ initRangePermissionFunc(workbook);
18741
18801
  });
18742
18802
  }
18743
18803
  _initRangePermissionChange() {
@@ -18746,8 +18806,8 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18746
18806
  info.type !== "delete" ? this._authzIoService.allowed({
18747
18807
  objectID: info.rule.permissionId,
18748
18808
  unitID: info.unitId,
18749
- objectType: l$1.SelectRange,
18750
- actions: [P.Edit, P.View]
18809
+ objectType: M.SelectRange,
18810
+ actions: [L.Edit, L.View]
18751
18811
  }).then((actionList) => {
18752
18812
  getAllRangePermissionPoint().forEach((F) => {
18753
18813
  if (info.type === "set") {
@@ -18766,10 +18826,11 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18766
18826
  );
18767
18827
  }
18768
18828
  initWorkbookPermissionChange(_unitId) {
18769
- const unitId = _unitId || this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET).getUnitId();
18770
- this._authzIoService.allowed({
18829
+ var _a59;
18830
+ const unitId = _unitId || ((_a59 = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET)) == null ? void 0 : _a59.getUnitId());
18831
+ unitId && this._authzIoService.allowed({
18771
18832
  objectID: unitId,
18772
- objectType: l$1.Workbook,
18833
+ objectType: M.Workbook,
18773
18834
  unitID: unitId,
18774
18835
  actions: defaultWorkbookPermissionPoints
18775
18836
  }).then((actionList) => {
@@ -18779,14 +18840,19 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18779
18840
  });
18780
18841
  });
18781
18842
  }
18843
+ _initWorkbookPermissionFromSnapshot() {
18844
+ this._univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).forEach((workbook) => {
18845
+ this.initWorkbookPermissionChange(workbook.getUnitId());
18846
+ });
18847
+ }
18782
18848
  _initWorksheetPermissionChange() {
18783
18849
  this.disposeWithMe(
18784
18850
  this._worksheetProtectionRuleModel.ruleChange$.subscribe((info) => {
18785
18851
  info.type !== "delete" ? this._authzIoService.allowed({
18786
18852
  objectID: info.rule.permissionId,
18787
18853
  unitID: info.unitId,
18788
- objectType: l$1.Worksheet,
18789
- actions: [P.Edit, P.View]
18854
+ objectType: M.Worksheet,
18855
+ actions: [L.Edit, L.View]
18790
18856
  }).then((actionList) => {
18791
18857
  getAllWorksheetPermissionPoint().forEach((F) => {
18792
18858
  const instance = new F(info.unitId, info.subUnitId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
@@ -18805,7 +18871,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18805
18871
  this._authzIoService.allowed({
18806
18872
  objectID: info.permissionId,
18807
18873
  unitID: info.unitId,
18808
- objectType: l$1.Worksheet,
18874
+ objectType: M.Worksheet,
18809
18875
  actions: defaultWorksheetPermissionPoint
18810
18876
  }).then((actionList) => {
18811
18877
  getAllWorksheetPermissionPointByPointPanel().forEach((F) => {
@@ -18817,30 +18883,35 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18817
18883
  );
18818
18884
  }
18819
18885
  _initWorksheetPermissionFromSnapshot() {
18820
- const allAllowedParams = [], workbook = this._univerInstanceService.getCurrentUnitForType(I.UNIVER_SHEET), unitId = workbook.getUnitId(), allSheets = workbook.getSheets(), permissionIdWithRuleInstanceMap = /* @__PURE__ */ new Map();
18821
- allSheets.forEach((sheet) => {
18822
- const subUnitId = sheet.getSheetId(), rule = this._worksheetProtectionRuleModel.getRule(unitId, subUnitId);
18823
- rule && (permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
18824
- objectID: rule.permissionId,
18825
- unitID: unitId,
18826
- objectType: l$1.Worksheet,
18827
- actions: [P.Edit, P.View]
18828
- }));
18829
- const pointRule = this._worksheetProtectionPointRuleModel.getRule(unitId, subUnitId);
18830
- pointRule && (permissionIdWithRuleInstanceMap.set(pointRule.permissionId, pointRule), allAllowedParams.push({
18831
- objectID: pointRule.permissionId,
18832
- unitID: unitId,
18833
- objectType: l$1.Worksheet,
18834
- actions: defaultWorksheetPermissionPoint
18835
- }));
18836
- }), allAllowedParams.length && this._authzIoService.batchAllowed(allAllowedParams).then((permissionMap) => {
18837
- permissionMap.forEach((item) => {
18838
- const rule = permissionIdWithRuleInstanceMap.get(item.objectID);
18839
- rule && [...getAllWorksheetPermissionPoint(), ...getAllWorksheetPermissionPointByPointPanel()].forEach((F) => {
18840
- const instance = new F(unitId, rule.subUnitId), unitActionName = instance.subType, result = item.actions.find((action) => action.action === unitActionName);
18841
- (result == null ? void 0 : result.allowed) !== void 0 && this._permissionService.updatePermissionPoint(instance.id, result.allowed);
18886
+ const initSheetPermissionFunc = /* @__PURE__ */ __name((workbook) => {
18887
+ const allAllowedParams = [], unitId = workbook.getUnitId(), allSheets = workbook.getSheets(), permissionIdWithRuleInstanceMap = /* @__PURE__ */ new Map();
18888
+ allSheets.forEach((sheet) => {
18889
+ const subUnitId = sheet.getSheetId(), rule = this._worksheetProtectionRuleModel.getRule(unitId, subUnitId);
18890
+ rule && (permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
18891
+ objectID: rule.permissionId,
18892
+ unitID: unitId,
18893
+ objectType: M.Worksheet,
18894
+ actions: [L.Edit, L.View]
18895
+ }));
18896
+ const pointRule = this._worksheetProtectionPointRuleModel.getRule(unitId, subUnitId);
18897
+ pointRule && (permissionIdWithRuleInstanceMap.set(pointRule.permissionId, pointRule), allAllowedParams.push({
18898
+ objectID: pointRule.permissionId,
18899
+ unitID: unitId,
18900
+ objectType: M.Worksheet,
18901
+ actions: defaultWorksheetPermissionPoint
18902
+ }));
18903
+ }), allAllowedParams.length && this._authzIoService.batchAllowed(allAllowedParams).then((permissionMap) => {
18904
+ permissionMap.forEach((item) => {
18905
+ const rule = permissionIdWithRuleInstanceMap.get(item.objectID);
18906
+ rule && [...getAllWorksheetPermissionPoint(), ...getAllWorksheetPermissionPointByPointPanel()].forEach((F) => {
18907
+ const instance = new F(unitId, rule.subUnitId), unitActionName = instance.subType, result = item.actions.find((action) => action.action === unitActionName);
18908
+ (result == null ? void 0 : result.allowed) !== void 0 && this._permissionService.updatePermissionPoint(instance.id, result.allowed);
18909
+ });
18842
18910
  });
18843
18911
  });
18912
+ }, "initSheetPermissionFunc");
18913
+ this._univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).forEach((workbook) => {
18914
+ initSheetPermissionFunc(workbook);
18844
18915
  });
18845
18916
  }
18846
18917
  _initUserChange() {
@@ -18863,7 +18934,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18863
18934
  _map.has(instance.id) && (instance = _map.get(instance.id)), this._permissionService.addPermissionPoint(instance);
18864
18935
  });
18865
18936
  });
18866
- }), this.initWorkbookPermissionChange(), this._initWorksheetPermissionFromSnapshot(), this._initRangePermissionFromSnapshot();
18937
+ }), this._initWorkbookPermissionFromSnapshot(), this._initWorksheetPermissionFromSnapshot(), this._initRangePermissionFromSnapshot();
18867
18938
  });
18868
18939
  })
18869
18940
  );
@@ -18883,7 +18954,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18883
18954
  };
18884
18955
  }).filter((p2) => !!p2.ranges);
18885
18956
  if (permissionList.length) {
18886
- const isSkipRender = permissionList.some((p2) => !(p2 != null && p2[P.View])), _cellData = { ...cell, selectionProtection: permissionList };
18957
+ const isSkipRender = permissionList.some((p2) => !(p2 != null && p2[L.View])), _cellData = { ...cell, selectionProtection: permissionList };
18887
18958
  return isSkipRender ? (delete _cellData.s, delete _cellData.v, delete _cellData.p, _cellData) : next(_cellData);
18888
18959
  }
18889
18960
  return next(cell);
@@ -18900,11 +18971,11 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18900
18971
  handler: /* @__PURE__ */ __name((cell = {}, context, next) => {
18901
18972
  var _a59, _b, _c, _d, _e;
18902
18973
  const { unitId, subUnitId } = context, worksheetRule = this._worksheetProtectionRuleModel.getRule(unitId, subUnitId);
18903
- if (worksheetRule != null && worksheetRule.permissionId && worksheetRule.name) {
18974
+ if (worksheetRule != null && worksheetRule.permissionId) {
18904
18975
  const selectionProtection = [{
18905
- [P.View]: (_b = (_a59 = this._permissionService.getPermissionPoint(new WorksheetViewPermission(unitId, subUnitId).id)) == null ? void 0 : _a59.value) != null ? _b : !1,
18906
- [P.Edit]: (_d = (_c = this._permissionService.getPermissionPoint(new WorksheetEditPermission(unitId, subUnitId).id)) == null ? void 0 : _c.value) != null ? _d : !1
18907
- }], isSkipRender = !((_e = selectionProtection[0]) != null && _e[P.View]), _cellData = { ...cell, hasWorksheetRule: !0, selectionProtection };
18976
+ [L.View]: (_b = (_a59 = this._permissionService.getPermissionPoint(new WorksheetViewPermission(unitId, subUnitId).id)) == null ? void 0 : _a59.value) != null ? _b : !1,
18977
+ [L.Edit]: (_d = (_c = this._permissionService.getPermissionPoint(new WorksheetEditPermission(unitId, subUnitId).id)) == null ? void 0 : _c.value) != null ? _d : !1
18978
+ }], isSkipRender = !((_e = selectionProtection[0]) != null && _e[L.View]), _cellData = { ...cell, hasWorksheetRule: !0, selectionProtection };
18908
18979
  return isSkipRender ? (delete _cellData.s, delete _cellData.v, delete _cellData.p, _cellData) : next(_cellData);
18909
18980
  }
18910
18981
  return next(cell);
@@ -18912,6 +18983,59 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
18912
18983
  }
18913
18984
  ));
18914
18985
  }
18986
+ refreshPermission(unitId, permissionId) {
18987
+ const sheetRuleItem = this._worksheetProtectionRuleModel.getTargetByPermissionId(unitId, permissionId);
18988
+ let needClearUndoRedo = !1;
18989
+ if (sheetRuleItem) {
18990
+ const [_, subUnitId] = sheetRuleItem;
18991
+ this._authzIoService.allowed({
18992
+ objectID: permissionId,
18993
+ unitID: unitId,
18994
+ objectType: M.Worksheet,
18995
+ actions: [L.Edit, L.View]
18996
+ }).then((actionList) => {
18997
+ let key = "";
18998
+ getAllWorksheetPermissionPoint().forEach((F) => {
18999
+ var _a59;
19000
+ const instance = new F(unitId, subUnitId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
19001
+ action && (((_a59 = this._permissionService.getPermissionPoint(instance.id)) == null ? void 0 : _a59.value) !== action.allowed && (needClearUndoRedo = !0), this._permissionService.updatePermissionPoint(instance.id, action.allowed), key += `${action.action}_${action.allowed}`);
19002
+ }), this._worksheetProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`), needClearUndoRedo && this._undoRedoService.clearUndoRedo(unitId);
19003
+ });
19004
+ }
19005
+ const sheetPointItem = this._worksheetProtectionPointRuleModel.getTargetByPermissionId(unitId, permissionId);
19006
+ if (sheetPointItem) {
19007
+ const [_, subUnitId] = sheetPointItem;
19008
+ this._authzIoService.allowed({
19009
+ objectID: permissionId,
19010
+ unitID: unitId,
19011
+ objectType: M.Worksheet,
19012
+ actions: defaultWorksheetPermissionPoint
19013
+ }).then((actionList) => {
19014
+ getAllWorksheetPermissionPointByPointPanel().forEach((F) => {
19015
+ var _a59;
19016
+ const instance = new F(unitId, subUnitId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
19017
+ action && (((_a59 = this._permissionService.getPermissionPoint(instance.id)) == null ? void 0 : _a59.value) !== action.allowed && (needClearUndoRedo = !0), this._permissionService.updatePermissionPoint(instance.id, action.allowed));
19018
+ }), needClearUndoRedo && this._undoRedoService.clearUndoRedo(unitId);
19019
+ });
19020
+ }
19021
+ const rangeRuleItem = this._rangeProtectionRuleModel.getTargetByPermissionId(unitId, permissionId);
19022
+ if (rangeRuleItem) {
19023
+ const [_, subUnitId] = rangeRuleItem;
19024
+ this._authzIoService.allowed({
19025
+ objectID: permissionId,
19026
+ unitID: unitId,
19027
+ objectType: M.SelectRange,
19028
+ actions: [L.Edit, L.View]
19029
+ }).then((actionList) => {
19030
+ let key = "";
19031
+ getAllRangePermissionPoint().forEach((F) => {
19032
+ var _a59;
19033
+ const instance = new F(unitId, subUnitId, permissionId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
19034
+ action && (((_a59 = this._permissionService.getPermissionPoint(instance.id)) == null ? void 0 : _a59.value) !== action.allowed && (needClearUndoRedo = !0), this._permissionService.updatePermissionPoint(instance.id, action.allowed), key += `${action.action}_${action.allowed}`);
19035
+ }), this._rangeProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`), needClearUndoRedo && this._undoRedoService.clearUndoRedo(unitId);
19036
+ });
19037
+ }
19038
+ }
18915
19039
  }, __name(_a45, "SheetPermissionInitController"), _a45);
18916
19040
  SheetPermissionInitController = __decorateClass$c([
18917
19041
  OnLifecycle(LifecycleStages.Rendered, SheetPermissionInitController),
@@ -18924,18 +19048,232 @@ SheetPermissionInitController = __decorateClass$c([
18924
19048
  __decorateParam$c(6, Inject(UserManagerService)),
18925
19049
  __decorateParam$c(7, Inject(WorksheetProtectionPointModel)),
18926
19050
  __decorateParam$c(8, Inject(SheetInterceptorService)),
18927
- __decorateParam$c(9, Inject(RangeProtectionRenderModel))
19051
+ __decorateParam$c(9, Inject(RangeProtectionRenderModel)),
19052
+ __decorateParam$c(10, Inject(IUndoRedoService))
18928
19053
  ], SheetPermissionInitController);
18929
- const UserEmptyBase64 = "", spinContainer = "univer-spin-container", spinOverlay = "univer-spin-overlay", spinner = "univer-spinner", spin = "univer-spin", contentBlur = "univer-content-blur", styles$7 = {
19054
+ const useHighlightRange = /* @__PURE__ */ __name((ranges = []) => {
19055
+ const markSelectionService = useDependency(IMarkSelectionService);
19056
+ useEffect(() => {
19057
+ const ids = ranges.map((range) => markSelectionService.addShape({
19058
+ range,
19059
+ style: {
19060
+ hasAutoFill: !1,
19061
+ fill: "rgba(73, 184, 17, 0.05)",
19062
+ strokeWidth: 1,
19063
+ stroke: "#49B811",
19064
+ widgets: {}
19065
+ },
19066
+ primary: {
19067
+ startColumn: range.startColumn,
19068
+ endColumn: range.endColumn,
19069
+ startRow: range.startRow,
19070
+ endRow: range.endRow,
19071
+ actualRow: range.startRow,
19072
+ actualColumn: range.startColumn,
19073
+ isMerged: !1,
19074
+ isMergedMainCell: !1
19075
+ }
19076
+ }));
19077
+ return () => {
19078
+ ids.forEach((id) => {
19079
+ id && markSelectionService.removeShape(id);
19080
+ });
19081
+ };
19082
+ }, [ranges]);
19083
+ }, "useHighlightRange"), panelListEmptyBase64 = "", sheetPermissionListPanelWrapper = "univer-sheet-permission-list-panel-wrapper", sheetPermissionListPanelHeader = "univer-sheet-permission-list-panel-header", sheetPermissionListPanelHeaderType = "univer-sheet-permission-list-panel-header-type", sheetPermissionListPanelHeaderTypeBottom = "univer-sheet-permission-list-panel-header-type-bottom", sheetPermissionListPanelHeaderSelect = "univer-sheet-permission-list-panel-header-select", sheetPermissionListItemHeaderIcon = "univer-sheet-permission-list-item-header-icon", sheetPermissionListItem = "univer-sheet-permission-list-item", sheetPermissionListItemHeader = "univer-sheet-permission-list-item-header", sheetPermissionListItemHeaderName = "univer-sheet-permission-list-item-header-name", sheetPermissionListItemHeaderOperator = "univer-sheet-permission-list-item-header-operator", sheetPermissionListItemSplit = "univer-sheet-permission-list-item-split", sheetPermissionListItemContentEdit = "univer-sheet-permission-list-item-content-edit", sheetPermissionListItemContentView = "univer-sheet-permission-list-item-content-view", sheetPermissionListItemContentDesc = "univer-sheet-permission-list-item-content-desc", sheetPermissionListEmpty = "univer-sheet-permission-list-empty", sheetPermissionListEmptyText = "univer-sheet-permission-list-empty-text", sheetPermissionListItemContentTitle = "univer-sheet-permission-list-item-content-title", sheetPermissionListItemContentSub = "univer-sheet-permission-list-item-content-sub", styles$7 = {
19084
+ sheetPermissionListPanelWrapper,
19085
+ sheetPermissionListPanelHeader,
19086
+ sheetPermissionListPanelHeaderType,
19087
+ sheetPermissionListPanelHeaderTypeBottom,
19088
+ sheetPermissionListPanelHeaderSelect,
19089
+ sheetPermissionListItemHeaderIcon,
19090
+ sheetPermissionListItem,
19091
+ sheetPermissionListItemHeader,
19092
+ sheetPermissionListItemHeaderName,
19093
+ sheetPermissionListItemHeaderOperator,
19094
+ sheetPermissionListItemSplit,
19095
+ sheetPermissionListItemContentEdit,
19096
+ sheetPermissionListItemContentView,
19097
+ sheetPermissionListItemContentDesc,
19098
+ sheetPermissionListEmpty,
19099
+ sheetPermissionListEmptyText,
19100
+ sheetPermissionListItemContentTitle,
19101
+ sheetPermissionListItemContentSub
19102
+ }, SheetPermissionPanelList = /* @__PURE__ */ __name(() => {
19103
+ const [isCurrentSheet, setIsCurrentSheet] = useState(!0), [forceUpdateFlag, setForceUpdateFlag] = useState(!1), sheetPermissionPanelModel = useDependency(SheetPermissionPanelModel), localeService = useDependency(LocaleService), rangeProtectionRuleModel = useDependency(RangeProtectionRuleModel), worksheetProtectionModel = useDependency(WorksheetProtectionRuleModel), workbook = useDependency(IUniverInstanceService).getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), unitId = workbook.getUnitId(), commandService = useDependency(ICommandService), sidebarService = useDependency(ISidebarService), authzIoService = useDependency(IAuthzIoService), permissionService = useDependency(IPermissionService), currentUser = useDependency(UserManagerService).getCurrentUser(), [currentRuleRanges, currentRuleRangesSet] = useState([]), _sheetRuleRefresh = useObservable(worksheetProtectionModel.ruleRefresh$, ""), _rangeRuleRefresh = useObservable(rangeProtectionRuleModel.ruleRefresh$, ""), getRuleList = useCallback(async (isCurrentSheet2) => {
19104
+ var _a59;
19105
+ const worksheet = workbook.getActiveSheet(), unitId2 = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), allRangePermissionId = [], allSheetPermissionId = [];
19106
+ workbook.getSheets().forEach((sheet) => {
19107
+ const sheetId = sheet.getSheetId();
19108
+ rangeProtectionRuleModel.getSubunitRuleList(unitId2, sheetId).forEach((rule) => {
19109
+ rule.permissionId && rule.name && allRangePermissionId.push(rule.permissionId);
19110
+ });
19111
+ const worksheetPermissionRule = worksheetProtectionModel.getRule(unitId2, sheetId);
19112
+ worksheetPermissionRule != null && worksheetPermissionRule.permissionId && worksheetPermissionRule.name && allSheetPermissionId.push(worksheetPermissionRule.permissionId);
19113
+ });
19114
+ const allPermissionId = [...allRangePermissionId, ...allSheetPermissionId], allPermissionRule = await authzIoService.list({
19115
+ objectIDs: allPermissionId,
19116
+ unitID: unitId2,
19117
+ actions: [L.View, L.Edit]
19118
+ }), subUnitPermissionIds = rangeProtectionRuleModel.getSubunitRuleList(unitId2, subUnitId).map((item) => item.permissionId), sheetPermissionId = (_a59 = worksheetProtectionModel.getRule(unitId2, subUnitId)) == null ? void 0 : _a59.permissionId;
19119
+ sheetPermissionId && subUnitPermissionIds.push(sheetPermissionId);
19120
+ const subUnitRuleList = allPermissionRule.filter((item) => {
19121
+ var _a60;
19122
+ return subUnitPermissionIds.includes(item.objectID) || item.objectID === ((_a60 = worksheetProtectionModel.getRule(unitId2, subUnitId)) == null ? void 0 : _a60.permissionId);
19123
+ });
19124
+ return isCurrentSheet2 ? subUnitRuleList : allPermissionRule;
19125
+ }, []), [ruleList, setRuleList] = useState([]);
19126
+ useEffect(() => {
19127
+ const subscription = merge(
19128
+ rangeProtectionRuleModel.ruleChange$,
19129
+ worksheetProtectionModel.ruleChange$
19130
+ ).subscribe(async () => {
19131
+ const ruleList2 = await getRuleList(isCurrentSheet);
19132
+ setRuleList(ruleList2);
19133
+ });
19134
+ return () => {
19135
+ subscription.unsubscribe();
19136
+ };
19137
+ }, [isCurrentSheet]), useEffect(() => {
19138
+ const subscribe = workbook.activeSheet$.subscribe(async () => {
19139
+ const ruleList2 = await getRuleList(!0);
19140
+ setRuleList(ruleList2);
19141
+ });
19142
+ return () => {
19143
+ subscribe.unsubscribe();
19144
+ };
19145
+ }, []), useEffect(() => {
19146
+ (/* @__PURE__ */ __name(async () => {
19147
+ if (_sheetRuleRefresh || _rangeRuleRefresh) {
19148
+ const ruleList2 = await getRuleList(!0);
19149
+ setRuleList(ruleList2);
19150
+ }
19151
+ }, "getRuleListByRefresh"))();
19152
+ }, [_sheetRuleRefresh, _rangeRuleRefresh]);
19153
+ const handleDelete = /* @__PURE__ */ __name((rule) => {
19154
+ const { unitId: unitId2, subUnitId, unitType } = rule;
19155
+ let res;
19156
+ unitType === M.Worksheet ? res = commandService.executeCommand(DeleteWorksheetProtectionCommand.id, { unitId: unitId2, subUnitId, rule }) : unitType === M.SelectRange && (res = commandService.executeCommand(DeleteRangeProtectionCommand.id, { unitId: unitId2, subUnitId, rule })), res && (setForceUpdateFlag(!forceUpdateFlag), rule.ranges === currentRuleRanges && currentRuleRangesSet([]));
19157
+ }, "handleDelete");
19158
+ useHighlightRange(currentRuleRanges);
19159
+ const allRuleMap = /* @__PURE__ */ new Map();
19160
+ workbook.getSheets().forEach((sheet) => {
19161
+ const sheetId = sheet.getSheetId();
19162
+ rangeProtectionRuleModel.getSubunitRuleList(unitId, sheetId).forEach((rule) => {
19163
+ allRuleMap.set(rule.permissionId, rule);
19164
+ });
19165
+ const sheetRule = worksheetProtectionModel.getRule(unitId, sheetId);
19166
+ sheetRule && allRuleMap.set(sheetRule == null ? void 0 : sheetRule.permissionId, sheetRule);
19167
+ });
19168
+ const handleEdit = /* @__PURE__ */ __name((rule) => {
19169
+ sheetPermissionPanelModel.setRule(rule), sheetPermissionPanelModel.setOldRule(rule), rule.subUnitId !== workbook.getActiveSheet().getSheetId() && commandService.executeCommand(SetWorksheetActiveOperation.id, {
19170
+ unitId: rule.unitId,
19171
+ subUnitId: rule.subUnitId
19172
+ });
19173
+ const sidebarProps = {
19174
+ header: { title: "permission.panel.title" },
19175
+ children: {
19176
+ label: UNIVER_SHEET_PERMISSION_PANEL,
19177
+ showDetail: !0
19178
+ },
19179
+ width: 330,
19180
+ footer: {
19181
+ label: UNIVER_SHEET_PERMISSION_PANEL_FOOTER,
19182
+ showDetail: !0
19183
+ }
19184
+ };
19185
+ sidebarService.open(sidebarProps);
19186
+ }, "handleEdit"), handleChangeHeaderType = /* @__PURE__ */ __name(async (isCurrentSheet2) => {
19187
+ setIsCurrentSheet(isCurrentSheet2);
19188
+ const ruleList2 = await getRuleList(isCurrentSheet2);
19189
+ setRuleList(ruleList2);
19190
+ }, "handleChangeHeaderType");
19191
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelWrapper, children: [
19192
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelHeader, children: [
19193
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!0), "onClick"), children: [
19194
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$7.sheetPermissionListPanelHeaderSelect]: isCurrentSheet }), children: localeService.t("permission.panel.currentSheet") }),
19195
+ isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListPanelHeaderTypeBottom })
19196
+ ] }),
19197
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!1), "onClick"), children: [
19198
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$7.sheetPermissionListPanelHeaderSelect]: !isCurrentSheet }), children: localeService.t("permission.panel.allSheet") }),
19199
+ !isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListPanelHeaderTypeBottom })
19200
+ ] })
19201
+ ] }),
19202
+ (ruleList == null ? void 0 : ruleList.length) > 0 ? /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListPanelContent, children: ruleList == null ? void 0 : ruleList.map((item) => {
19203
+ var _a59, _b, _c, _d, _e;
19204
+ const rule = allRuleMap.get(item.objectID);
19205
+ if (!rule)
19206
+ return null;
19207
+ const editAction = item.actions.find((action) => action.action === L.Edit), editPermission = editAction == null ? void 0 : editAction.allowed, viewAction = item.actions.find((action) => action.action === L.View), viewPermission = viewAction == null ? void 0 : viewAction.allowed, hasManagerPermission = ((_b = (_a59 = permissionService.getPermissionPoint(new WorkbookManageCollaboratorPermission(unitId).id)) == null ? void 0 : _a59.value) != null ? _b : !1) || currentUser.userID === ((_c = item.creator) == null ? void 0 : _c.userID);
19208
+ let ruleName = "";
19209
+ const targetSheet = workbook.getSheetBySheetId(rule.subUnitId), targetName = targetSheet == null ? void 0 : targetSheet.getName();
19210
+ if (rule.unitType === M.SelectRange) {
19211
+ const ranges = rule.ranges, rangeStr = ranges != null && ranges.length ? ranges.map((range) => {
19212
+ const v = serializeRange(range);
19213
+ return v === "NaN" ? "" : v;
19214
+ }).filter((r) => !!r).join(",") : "";
19215
+ ruleName = `${targetName}(${rangeStr})`;
19216
+ } else rule.unitType === M.Worksheet && (ruleName = targetName || "");
19217
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs(
19218
+ "div",
19219
+ {
19220
+ className: styles$7.sheetPermissionListItem,
19221
+ onMouseMove: /* @__PURE__ */ __name(() => {
19222
+ const { subUnitId, unitType } = rule, activeSheet = workbook.getActiveSheet();
19223
+ if (!activeSheet)
19224
+ return !1;
19225
+ const activeSubUnitId = activeSheet.getSheetId();
19226
+ if (subUnitId !== activeSubUnitId)
19227
+ return !1;
19228
+ if (unitType === M.SelectRange) {
19229
+ const ranges = rule.ranges || [];
19230
+ ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
19231
+ } else if (unitType === M.Worksheet) {
19232
+ const ranges = [{ startRow: 0, endRow: activeSheet.getRowCount() - 1, startColumn: 0, endColumn: activeSheet.getColumnCount() - 1 }];
19233
+ ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
19234
+ }
19235
+ }, "onMouseMove"),
19236
+ onMouseLeave: /* @__PURE__ */ __name(() => currentRuleRangesSet([]), "onMouseLeave"),
19237
+ children: [
19238
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemHeader, children: [
19239
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: ruleName, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemHeaderName, children: ruleName }) }),
19240
+ hasManagerPermission && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemHeaderOperator, children: [
19241
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: localeService.t("permission.panel.edit"), children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemHeaderIcon, onClick: /* @__PURE__ */ __name(() => handleEdit(rule), "onClick"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(WriteSingle, {}) }) }),
19242
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: localeService.t("permission.panel.delete"), children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemHeaderIcon, onClick: /* @__PURE__ */ __name(() => handleDelete(rule), "onClick"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(DeleteSingle, {}) }) })
19243
+ ] })
19244
+ ] }),
19245
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemSplit }),
19246
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemContent, children: [
19247
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemContentEdit, children: [
19248
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: (_d = item.creator) == null ? void 0 : _d.userID, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: /* @__PURE__ */ jsxRuntimeExports.jsx(Avatar, { src: (_e = item.creator) == null ? void 0 : _e.avatar, style: { marginRight: 6 }, size: 24 }) }) }),
19249
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.created") }),
19250
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentSub, children: editPermission ? `${localeService.t("permission.panel.iCanEdit")}` : `${localeService.t("permission.panel.iCanNotEdit")}` })
19251
+ ] }),
19252
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemContentView, children: [
19253
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.viewPermission") }),
19254
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentSub, children: viewPermission ? `${localeService.t("permission.panel.iCanView")}` : `${localeService.t("permission.panel.iCanNotView")}` })
19255
+ ] }),
19256
+ rule.description && /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: rule.description, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemContentDesc, children: rule.description }) })
19257
+ ] })
19258
+ ]
19259
+ },
19260
+ item.objectID
19261
+ );
19262
+ }) }) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListEmpty, children: [
19263
+ /* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: panelListEmptyBase64, alt: "" }),
19264
+ /* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$7.sheetPermissionListEmptyText, children: localeService.t("permission.dialog.listEmpty") })
19265
+ ] })
19266
+ ] });
19267
+ }, "SheetPermissionPanelList"), UserEmptyBase64 = "", spinContainer = "univer-spin-container", spinOverlay = "univer-spin-overlay", spinner = "univer-spinner", spin = "univer-spin", contentBlur = "univer-content-blur", styles$6 = {
18930
19268
  spinContainer,
18931
19269
  spinOverlay,
18932
19270
  spinner,
18933
19271
  spin,
18934
19272
  contentBlur
18935
- }, Spin = /* @__PURE__ */ __name(({ loading, children }) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.spinContainer, children: [
18936
- loading && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.spinOverlay, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.spinner }) }),
18937
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: loading ? styles$7.contentBlur : "", children })
18938
- ] }), "Spin"), permissionPanelDetailWrapper = "univer-permission-panel-detail-wrapper", radioGroupVertical = "univer-radio-group-vertical", sheetPermissionDesignPersonPanel = "univer-sheet-permission-design-person-panel", sheetPermissionDesignPersonPanelHeader = "univer-sheet-permission-design-person-panel-header", sheetPermissionDesignPersonPanelHeaderAdd = "univer-sheet-permission-design-person-panel-header-add", sheetPermissionDesignPersonPanelSplit = "univer-sheet-permission-design-person-panel-split", sheetPermissionDesignPersonPanelContentItem = "univer-sheet-permission-design-person-panel-content-item", sheetPermissionDesignPersonPanelContentItemName = "univer-sheet-permission-design-person-panel-content-item-name", sheetPermissionDesignPersonPanelContentItemSelect = "univer-sheet-permission-design-person-panel-content-item-select", sheetPermissionDesignPersonPanelContent = "univer-sheet-permission-design-person-panel-content", sheetPermissionUserListEmpty$1 = "univer-sheet-permission-user-list-empty", sheetPermissionUserListEmptyText$1 = "univer-sheet-permission-user-list-empty-text", sheetPermissionPanelTitle = "univer-sheet-permission-panel-title", permissionRangeSelector = "univer-permission-range-selector", permissionRangeSelectorError = "univer-permission-range-selector-error", sheetPermissionPanelNameInputError = "univer-sheet-permission-panel-name-input-error", permissionRangeSelectorErrorText = "univer-permission-range-selector-error-text", sheetPermissionPanelNameInputErrorText = "univer-sheet-permission-panel-name-input-error-text", styles$6 = {
19273
+ }, Spin = /* @__PURE__ */ __name(({ loading, children }) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.spinContainer, children: [
19274
+ loading && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.spinOverlay, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.spinner }) }),
19275
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: loading ? styles$6.contentBlur : "", children })
19276
+ ] }), "Spin"), permissionPanelDetailWrapper = "univer-permission-panel-detail-wrapper", radioGroupVertical = "univer-radio-group-vertical", sheetPermissionDesignPersonPanel = "univer-sheet-permission-design-person-panel", sheetPermissionDesignPersonPanelHeader = "univer-sheet-permission-design-person-panel-header", sheetPermissionDesignPersonPanelHeaderAdd = "univer-sheet-permission-design-person-panel-header-add", sheetPermissionDesignPersonPanelSplit = "univer-sheet-permission-design-person-panel-split", sheetPermissionDesignPersonPanelContentItem = "univer-sheet-permission-design-person-panel-content-item", sheetPermissionDesignPersonPanelContentItemName = "univer-sheet-permission-design-person-panel-content-item-name", sheetPermissionDesignPersonPanelContentItemSelect = "univer-sheet-permission-design-person-panel-content-item-select", sheetPermissionDesignPersonPanelContent = "univer-sheet-permission-design-person-panel-content", sheetPermissionUserListEmpty$1 = "univer-sheet-permission-user-list-empty", sheetPermissionUserListEmptyText$1 = "univer-sheet-permission-user-list-empty-text", sheetPermissionPanelTitle = "univer-sheet-permission-panel-title", permissionRangeSelector = "univer-permission-range-selector", permissionRangeSelectorError = "univer-permission-range-selector-error", sheetPermissionPanelNameInputError = "univer-sheet-permission-panel-name-input-error", permissionRangeSelectorErrorText = "univer-permission-range-selector-error-text", sheetPermissionPanelNameInputErrorText = "univer-sheet-permission-panel-name-input-error-text", styles$5 = {
18939
19277
  permissionPanelDetailWrapper,
18940
19278
  radioGroupVertical,
18941
19279
  sheetPermissionDesignPersonPanel,
@@ -18955,8 +19293,8 @@ const UserEmptyBase64 = "
18955
19293
  permissionRangeSelectorErrorText,
18956
19294
  sheetPermissionPanelNameInputErrorText
18957
19295
  }, SheetPermissionPanelDetail = /* @__PURE__ */ __name(({ fromSheetBar }) => {
18958
- var _a59, _b, _c;
18959
- const localeService = useDependency(LocaleService), dialogService = useDependency(IDialogService), univerInstanceService = useDependency(IUniverInstanceService), selectionManagerService = useDependency(SheetsSelectionsService), sheetPermissionPanelModel = useDependency(SheetPermissionPanelModel), activeRule = useObservable(sheetPermissionPanelModel.rule$, sheetPermissionPanelModel.rule), userManagerService = useDependency(UserManagerService), sheetPermissionUserManagerService = useDependency(SheetPermissionUserManagerService), authzIoService = useDependency(IAuthzIoService), sidebarService = useDependency(ISidebarService), rangeProtectionRuleModel = useDependency(RangeProtectionRuleModel), worksheetRuleModel = useDependency(WorksheetProtectionRuleModel), rangeErrorMsg = useObservable(sheetPermissionPanelModel.rangeErrorMsg$), workbook = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), worksheet = workbook.getActiveSheet(), unitId = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), selectUserList = useObservable(sheetPermissionUserManagerService.selectUserList$, sheetPermissionUserManagerService.selectUserList), [editorGroupValue, setEditorGroupValue] = React.useState(selectUserList.length ? "designedUserCanEdit" : "onlyMe"), [viewGroupValue, setViewGroupValue] = React.useState(viewState.othersCanView), [loading, setLoading] = useState(!1), handleAddPerson = /* @__PURE__ */ __name(async () => {
19296
+ var _a59, _b;
19297
+ const localeService = useDependency(LocaleService), dialogService = useDependency(IDialogService), univerInstanceService = useDependency(IUniverInstanceService), selectionManagerService = useDependency(SheetsSelectionsService), sheetPermissionPanelModel = useDependency(SheetPermissionPanelModel), activeRule = useObservable(sheetPermissionPanelModel.rule$, sheetPermissionPanelModel.rule), userManagerService = useDependency(UserManagerService), sheetPermissionUserManagerService = useDependency(SheetPermissionUserManagerService), authzIoService = useDependency(IAuthzIoService), sidebarService = useDependency(ISidebarService), rangeProtectionRuleModel = useDependency(RangeProtectionRuleModel), worksheetRuleModel = useDependency(WorksheetProtectionRuleModel), rangeErrorMsg = useObservable(sheetPermissionPanelModel.rangeErrorMsg$), workbook = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), worksheet = workbook.getActiveSheet(), unitId = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), selectUserList = useObservable(sheetPermissionUserManagerService.selectUserList$, sheetPermissionUserManagerService.selectUserList), [editorGroupValue, setEditorGroupValue] = React.useState(selectUserList.length ? editState.designedUserCanEdit : editState.onlyMe), [viewGroupValue, setViewGroupValue] = React.useState(viewState.othersCanView), [loading, setLoading] = useState(!!(activeRule != null && activeRule.permissionId)), handleAddPerson = /* @__PURE__ */ __name(async () => {
18960
19298
  const userList = await authzIoService.listCollaborators({
18961
19299
  objectID: unitId,
18962
19300
  unitID: unitId
@@ -19000,7 +19338,7 @@ const UserEmptyBase64 = "
19000
19338
  return useEffect(() => {
19001
19339
  var _a60, _b2;
19002
19340
  if (activeRule == null ? void 0 : activeRule.permissionId) {
19003
- activeRule.unitType === l$1.Worksheet && sheetPermissionPanelModel.setRule({
19341
+ activeRule.unitType === M.Worksheet && sheetPermissionPanelModel.setRule({
19004
19342
  ranges: [{
19005
19343
  startRow: 0,
19006
19344
  startColumn: 0,
@@ -19035,22 +19373,53 @@ const UserEmptyBase64 = "
19035
19373
  name: fromSheetBar ? `${sheetName}` : `${sheetName}(${rangeStr})`,
19036
19374
  unitId,
19037
19375
  subUnitId,
19038
- unitType: fromSheetBar ? l$1.Worksheet : l$1.SelectRange
19376
+ unitType: fromSheetBar ? M.Worksheet : M.SelectRange
19039
19377
  });
19040
19378
  }, [activeRule == null ? void 0 : activeRule.permissionId, fromSheetBar, selectionManagerService, sheetPermissionPanelModel, subUnitId, unitId, worksheet]), useEffect(() => {
19041
19379
  const getSelectUserList = /* @__PURE__ */ __name(async () => {
19042
- const permissionId = activeRule == null ? void 0 : activeRule.permissionId;
19043
- setLoading(!0);
19044
- const collaborators = await authzIoService.listCollaborators({
19380
+ const permissionId = activeRule == null ? void 0 : activeRule.permissionId, selectUserList2 = (await authzIoService.listCollaborators({
19045
19381
  objectID: permissionId,
19046
19382
  unitID: unitId
19047
- }), selectUserList2 = collaborators.filter((user) => user.role === M.Editor);
19048
- sheetPermissionUserManagerService.setSelectUserList(selectUserList2), setLoading(!1), (selectUserList2 == null ? void 0 : selectUserList2.length) > 0 && setEditorGroupValue("designedUserCanEdit");
19049
- const readerList = collaborators.filter((user) => user.role === M.Reader);
19050
- readerList.length === 0 && setViewGroupValue(viewState.noOneElseCanView), sheetPermissionUserManagerService.setOldCollaboratorList(selectUserList2.concat(readerList));
19383
+ })).filter((user) => user.role === P.Editor);
19384
+ sheetPermissionUserManagerService.setSelectUserList(selectUserList2), sheetPermissionUserManagerService.setOldCollaboratorList(selectUserList2);
19051
19385
  }, "getSelectUserList");
19052
- activeRule != null && activeRule.permissionId ? getSelectUserList() : (sheetPermissionUserManagerService.setSelectUserList([]), setEditorGroupValue("onlyMe"));
19386
+ activeRule != null && activeRule.permissionId ? getSelectUserList() : (sheetPermissionUserManagerService.setSelectUserList([]), sheetPermissionUserManagerService.setOldCollaboratorList([]));
19053
19387
  }, [activeRule == null ? void 0 : activeRule.permissionId]), useEffect(() => {
19388
+ if (!activeRule.permissionId) {
19389
+ sheetPermissionPanelModel.setRule({
19390
+ viewStatus: viewState.othersCanView
19391
+ });
19392
+ return;
19393
+ }
19394
+ (/* @__PURE__ */ __name(async () => {
19395
+ var _a60, _b2;
19396
+ try {
19397
+ const res = await authzIoService.list({
19398
+ unitID: unitId,
19399
+ objectIDs: [activeRule == null ? void 0 : activeRule.permissionId],
19400
+ actions: [L.View, L.Edit]
19401
+ });
19402
+ if (!res.length)
19403
+ setViewGroupValue(viewState.othersCanView), setEditorGroupValue(editState.onlyMe), sheetPermissionPanelModel.setRule({
19404
+ viewStatus: viewState.othersCanView,
19405
+ editStatus: editState.onlyMe
19406
+ });
19407
+ else {
19408
+ const isAllCanView = ((_a60 = res[0].scope) == null ? void 0 : _a60.read) === G.AllCollaborator, isSomeCanEdit = ((_b2 = res[0].scope) == null ? void 0 : _b2.edit) === G.SomeCollaborator, viewValue = isAllCanView ? viewState.othersCanView : viewState.noOneElseCanView, editValue = isSomeCanEdit ? editState.designedUserCanEdit : editState.onlyMe;
19409
+ setViewGroupValue(viewValue), setEditorGroupValue(editValue), sheetPermissionPanelModel.setRule({
19410
+ viewStatus: viewValue,
19411
+ editStatus: editValue
19412
+ });
19413
+ }
19414
+ } catch (error) {
19415
+ console.error(error);
19416
+ } finally {
19417
+ setTimeout(() => {
19418
+ setLoading(!1);
19419
+ }, 100);
19420
+ }
19421
+ }, "getCollaboratorInit"))();
19422
+ }, [activeRule.permissionId]), useEffect(() => {
19054
19423
  (/* @__PURE__ */ __name(async () => {
19055
19424
  const userList = await authzIoService.listCollaborators({
19056
19425
  objectID: unitId,
@@ -19058,13 +19427,9 @@ const UserEmptyBase64 = "
19058
19427
  });
19059
19428
  userList.forEach((user) => {
19060
19429
  user != null && user.subject && userManagerService.addUser(user.subject);
19061
- }), sheetPermissionUserManagerService.setUserList(userList.filter((user) => user.role === M.Editor)), sheetPermissionUserManagerService.setAllUserList(userList.filter((user) => user.role === M.Editor || user.role === M.Reader));
19430
+ }), sheetPermissionUserManagerService.setUserList(userList.filter((user) => user.role === P.Editor)), sheetPermissionUserManagerService.setAllUserList(userList.filter((user) => user.role === P.Editor || user.role === P.Reader));
19062
19431
  }, "getListCollaborators"))();
19063
19432
  }, []), useEffect(() => {
19064
- sheetPermissionPanelModel.setRule({
19065
- viewStatus: viewGroupValue
19066
- });
19067
- }, [sheetPermissionPanelModel, viewGroupValue]), useEffect(() => {
19068
19433
  const workbook2 = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
19069
19434
  if (!workbook2) return;
19070
19435
  const activeSheetSubscribe = workbook2.activeSheet$.subscribe((sheet) => {
@@ -19073,14 +19438,14 @@ const UserEmptyBase64 = "
19073
19438
  return () => {
19074
19439
  activeSheetSubscribe.unsubscribe();
19075
19440
  };
19076
- }, [sidebarService, subUnitId, univerInstanceService]), (_a59 = activeRule == null ? void 0 : activeRule.ranges) == null || _a59.map((i) => serializeRange(i)).join(","), /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.permissionPanelDetailWrapper, children: [
19077
- /* @__PURE__ */ jsxRuntimeExports.jsxs(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.protectedRange"), children: [
19441
+ }, [sidebarService, subUnitId, univerInstanceService]), /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.permissionPanelDetailWrapper, children: /* @__PURE__ */ jsxRuntimeExports.jsxs(Spin, { loading, children: [
19442
+ /* @__PURE__ */ jsxRuntimeExports.jsxs(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.protectedRange"), children: [
19078
19443
  /* @__PURE__ */ jsxRuntimeExports.jsx(
19079
19444
  RangeSelector,
19080
19445
  {
19081
- className: clsx(styles$6.permissionRangeSelector),
19082
- textEditorClassName: clsx({ [styles$6.permissionRangeSelectorError]: rangeErrorMsg }),
19083
- value: (_b = activeRule == null ? void 0 : activeRule.ranges) == null ? void 0 : _b.map((i) => serializeRange(i)).join(","),
19446
+ className: clsx(styles$5.permissionRangeSelector),
19447
+ textEditorClassName: clsx({ [styles$5.permissionRangeSelectorError]: rangeErrorMsg }),
19448
+ value: (_a59 = activeRule == null ? void 0 : activeRule.ranges) == null ? void 0 : _a59.map((i) => serializeRange(i)).join(","),
19084
19449
  id: createInternalEditorID("sheet-permission-panel"),
19085
19450
  openForSheetUnitId: unitId,
19086
19451
  openForSheetSubUnitId: subUnitId,
@@ -19099,56 +19464,58 @@ const UserEmptyBase64 = "
19099
19464
  ranges: transformedRange,
19100
19465
  unitId: unitId2,
19101
19466
  subUnitId: subUnitId2,
19102
- unitType: l$1.SelectRange,
19467
+ unitType: M.SelectRange,
19103
19468
  name: `${sheetName}(${rangeStr})`
19104
19469
  };
19105
19470
  if (rule.ranges.length === 1) {
19106
19471
  const { startRow, endRow, startColumn, endColumn } = rule.ranges[0];
19107
- startRow === 0 && endRow === worksheet2.getRowCount() - 1 && startColumn === 0 && worksheet2.getColumnCount() - 1 === endColumn && (rule.unitType = l$1.Worksheet, rule.name = `${sheetName}`);
19472
+ startRow === 0 && endRow === worksheet2.getRowCount() - 1 && startColumn === 0 && worksheet2.getColumnCount() - 1 === endColumn && (rule.unitType = M.Worksheet, rule.name = `${sheetName}`);
19108
19473
  }
19109
19474
  sheetPermissionPanelModel.setRule(rule);
19110
19475
  }, "onChange")
19111
19476
  }
19112
19477
  ),
19113
- rangeErrorMsg && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.sheetPermissionPanelNameInputErrorText, children: rangeErrorMsg })
19478
+ rangeErrorMsg && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionPanelNameInputErrorText, children: rangeErrorMsg })
19114
19479
  ] }),
19115
- /* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.permissionDirection"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(
19480
+ /* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.permissionDirection"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(
19116
19481
  Input,
19117
19482
  {
19118
- value: (_c = activeRule == null ? void 0 : activeRule.description) != null ? _c : "",
19483
+ value: (_b = activeRule == null ? void 0 : activeRule.description) != null ? _b : "",
19119
19484
  onChange: /* @__PURE__ */ __name((v) => sheetPermissionPanelModel.setRule({ description: v }), "onChange"),
19120
19485
  placeholder: localeService.t("permission.panel.permissionDirectionPlaceholder")
19121
19486
  }
19122
19487
  ) }),
19123
- /* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.editPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
19488
+ /* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.editPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
19124
19489
  RadioGroup,
19125
19490
  {
19126
19491
  value: editorGroupValue,
19127
19492
  onChange: /* @__PURE__ */ __name((v) => {
19128
- setEditorGroupValue(v), v === "onlyMe" && sheetPermissionUserManagerService.setSelectUserList([]);
19493
+ setEditorGroupValue(v), sheetPermissionPanelModel.setRule({
19494
+ editStatus: v
19495
+ });
19129
19496
  }, "onChange"),
19130
- className: styles$6.radioGroupVertical,
19497
+ className: styles$5.radioGroupVertical,
19131
19498
  children: [
19132
- /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: "onlyMe", children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.onlyICanEdit") }) }),
19133
- /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: "designedUserCanEdit", children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.designedUserCanEdit") }) })
19499
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: editState.onlyMe, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.onlyICanEdit") }) }),
19500
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: editState.designedUserCanEdit, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.designedUserCanEdit") }) })
19134
19501
  ]
19135
19502
  }
19136
19503
  ) }),
19137
- editorGroupValue === "designedUserCanEdit" && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.sheetPermissionDesignPersonPanel, children: /* @__PURE__ */ jsxRuntimeExports.jsxs(Spin, { loading, children: [
19138
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.sheetPermissionDesignPersonPanelHeader, children: [
19504
+ editorGroupValue === "designedUserCanEdit" && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanel, children: [
19505
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanelHeader, children: [
19139
19506
  /* @__PURE__ */ jsxRuntimeExports.jsx("span", { children: localeService.t("permission.panel.designedPerson") }),
19140
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.sheetPermissionDesignPersonPanelHeaderAdd, onClick: handleAddPerson, children: localeService.t("permission.panel.addPerson") })
19507
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionDesignPersonPanelHeaderAdd, onClick: handleAddPerson, children: localeService.t("permission.panel.addPerson") })
19141
19508
  ] }),
19142
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.sheetPermissionDesignPersonPanelSplit }),
19143
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.sheetPermissionDesignPersonPanelContent, children: (selectUserList == null ? void 0 : selectUserList.length) > 0 ? selectUserList.map((item) => {
19144
- var _a60, _b2, _c2;
19145
- return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.sheetPermissionDesignPersonPanelContentItem, children: [
19509
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionDesignPersonPanelSplit }),
19510
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionDesignPersonPanelContent, children: (selectUserList == null ? void 0 : selectUserList.length) > 0 ? selectUserList.map((item) => {
19511
+ var _a60, _b2, _c;
19512
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanelContentItem, children: [
19146
19513
  /* @__PURE__ */ jsxRuntimeExports.jsx(Avatar, { size: 24, src: (_a60 = item.subject) == null ? void 0 : _a60.avatar }),
19147
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.sheetPermissionDesignPersonPanelContentItemName, children: (_b2 = item.subject) == null ? void 0 : _b2.name }),
19514
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionDesignPersonPanelContentItemName, children: (_b2 = item.subject) == null ? void 0 : _b2.name }),
19148
19515
  /* @__PURE__ */ jsxRuntimeExports.jsx(
19149
19516
  Select,
19150
19517
  {
19151
- className: styles$6.sheetPermissionDesignPersonPanelContentItemSelect,
19518
+ className: styles$5.sheetPermissionDesignPersonPanelContentItemSelect,
19152
19519
  value: "edit",
19153
19520
  onChange: /* @__PURE__ */ __name((v) => {
19154
19521
  v === "delete" && sheetPermissionUserManagerService.setSelectUserList(selectUserList.filter((i) => {
@@ -19162,234 +19529,38 @@ const UserEmptyBase64 = "
19162
19529
  ]
19163
19530
  }
19164
19531
  )
19165
- ] }, (_c2 = item.subject) == null ? void 0 : _c2.userID);
19166
- }) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.sheetPermissionUserListEmpty, children: [
19532
+ ] }, (_c = item.subject) == null ? void 0 : _c.userID);
19533
+ }) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionUserListEmpty, children: [
19167
19534
  /* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: UserEmptyBase64, alt: "" }),
19168
- /* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$6.sheetPermissionUserListEmptyText, children: localeService.t("permission.dialog.userEmpty") })
19535
+ /* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$5.sheetPermissionUserListEmptyText, children: localeService.t("permission.dialog.userEmpty") })
19169
19536
  ] }) })
19170
- ] }) }),
19171
- /* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.viewPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
19537
+ ] }),
19538
+ /* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.viewPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
19172
19539
  RadioGroup,
19173
19540
  {
19174
19541
  value: viewGroupValue,
19175
- onChange: /* @__PURE__ */ __name((v) => setViewGroupValue(v), "onChange"),
19176
- className: styles$6.radioGroupVertical,
19542
+ onChange: /* @__PURE__ */ __name((v) => {
19543
+ setViewGroupValue(v), sheetPermissionPanelModel.setRule({
19544
+ viewStatus: v
19545
+ });
19546
+ }, "onChange"),
19547
+ className: styles$5.radioGroupVertical,
19177
19548
  children: [
19178
- /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.othersCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.othersCanView") }) }),
19179
- /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.noOneElseCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.noOneElseCanView") }) })
19549
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.othersCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.othersCanView") }) }),
19550
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.noOneElseCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.noOneElseCanView") }) })
19180
19551
  ]
19181
19552
  }
19182
19553
  ) })
19183
- ] });
19184
- }, "SheetPermissionPanelDetail"), useHighlightRange = /* @__PURE__ */ __name((ranges = []) => {
19185
- const markSelectionService = useDependency(IMarkSelectionService);
19186
- useEffect(() => {
19187
- const ids = ranges.map((range) => markSelectionService.addShape({
19188
- range,
19189
- style: {
19190
- hasAutoFill: !1,
19191
- fill: "rgba(73, 184, 17, 0.05)",
19192
- strokeWidth: 1,
19193
- stroke: "#49B811",
19194
- widgets: {}
19195
- },
19196
- primary: {
19197
- startColumn: range.startColumn,
19198
- endColumn: range.endColumn,
19199
- startRow: range.startRow,
19200
- endRow: range.endRow,
19201
- actualRow: range.startRow,
19202
- actualColumn: range.startColumn,
19203
- isMerged: !1,
19204
- isMergedMainCell: !1
19205
- }
19206
- }));
19207
- return () => {
19208
- ids.forEach((id) => {
19209
- id && markSelectionService.removeShape(id);
19210
- });
19211
- };
19212
- }, [ranges]);
19213
- }, "useHighlightRange"), panelListEmptyBase64 = "", sheetPermissionListPanelWrapper = "univer-sheet-permission-list-panel-wrapper", sheetPermissionListPanelHeader = "univer-sheet-permission-list-panel-header", sheetPermissionListPanelHeaderType = "univer-sheet-permission-list-panel-header-type", sheetPermissionListPanelHeaderTypeBottom = "univer-sheet-permission-list-panel-header-type-bottom", sheetPermissionListPanelHeaderSelect = "univer-sheet-permission-list-panel-header-select", sheetPermissionListItemHeaderIcon = "univer-sheet-permission-list-item-header-icon", sheetPermissionListItem = "univer-sheet-permission-list-item", sheetPermissionListItemHeader = "univer-sheet-permission-list-item-header", sheetPermissionListItemHeaderName = "univer-sheet-permission-list-item-header-name", sheetPermissionListItemHeaderOperator = "univer-sheet-permission-list-item-header-operator", sheetPermissionListItemSplit = "univer-sheet-permission-list-item-split", sheetPermissionListItemContentEdit = "univer-sheet-permission-list-item-content-edit", sheetPermissionListItemContentView = "univer-sheet-permission-list-item-content-view", sheetPermissionListItemContentDesc = "univer-sheet-permission-list-item-content-desc", sheetPermissionListEmpty = "univer-sheet-permission-list-empty", sheetPermissionListEmptyText = "univer-sheet-permission-list-empty-text", sheetPermissionListItemContentTitle = "univer-sheet-permission-list-item-content-title", sheetPermissionListItemContentSub = "univer-sheet-permission-list-item-content-sub", styles$5 = {
19214
- sheetPermissionListPanelWrapper,
19215
- sheetPermissionListPanelHeader,
19216
- sheetPermissionListPanelHeaderType,
19217
- sheetPermissionListPanelHeaderTypeBottom,
19218
- sheetPermissionListPanelHeaderSelect,
19219
- sheetPermissionListItemHeaderIcon,
19220
- sheetPermissionListItem,
19221
- sheetPermissionListItemHeader,
19222
- sheetPermissionListItemHeaderName,
19223
- sheetPermissionListItemHeaderOperator,
19224
- sheetPermissionListItemSplit,
19225
- sheetPermissionListItemContentEdit,
19226
- sheetPermissionListItemContentView,
19227
- sheetPermissionListItemContentDesc,
19228
- sheetPermissionListEmpty,
19229
- sheetPermissionListEmptyText,
19230
- sheetPermissionListItemContentTitle,
19231
- sheetPermissionListItemContentSub
19232
- }, SheetPermissionPanelList = /* @__PURE__ */ __name(() => {
19233
- const [isCurrentSheet, setIsCurrentSheet] = useState(!0), [forceUpdateFlag, setForceUpdateFlag] = useState(!1), sheetPermissionPanelModel = useDependency(SheetPermissionPanelModel), localeService = useDependency(LocaleService), rangeProtectionRuleModel = useDependency(RangeProtectionRuleModel), worksheetProtectionModel = useDependency(WorksheetProtectionRuleModel), workbook = useDependency(IUniverInstanceService).getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), unitId = workbook.getUnitId(), commandService = useDependency(ICommandService), sidebarService = useDependency(ISidebarService), authzIoService = useDependency(IAuthzIoService), permissionService = useDependency(IPermissionService), currentUser = useDependency(UserManagerService).getCurrentUser(), [currentRuleRanges, currentRuleRangesSet] = useState([]);
19234
- useObservable(worksheetProtectionModel.ruleRefresh$), useObservable(rangeProtectionRuleModel.ruleRefresh$);
19235
- const getRuleList = useCallback(async (isCurrentSheet2) => {
19236
- var _a59;
19237
- const worksheet = workbook.getActiveSheet(), unitId2 = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), allRangePermissionId = [], allSheetPermissionId = [];
19238
- workbook.getSheets().forEach((sheet) => {
19239
- const sheetId = sheet.getSheetId();
19240
- rangeProtectionRuleModel.getSubunitRuleList(unitId2, sheetId).forEach((rule) => {
19241
- rule.permissionId && rule.name && allRangePermissionId.push(rule.permissionId);
19242
- });
19243
- const worksheetPermissionRule = worksheetProtectionModel.getRule(unitId2, sheetId);
19244
- worksheetPermissionRule != null && worksheetPermissionRule.permissionId && worksheetPermissionRule.name && allSheetPermissionId.push(worksheetPermissionRule.permissionId);
19245
- });
19246
- const allPermissionId = [...allRangePermissionId, ...allSheetPermissionId], allPermissionRule = await authzIoService.list({
19247
- objectIDs: allPermissionId,
19248
- unitID: unitId2,
19249
- actions: [P.View, P.Edit]
19250
- }), subUnitPermissionIds = rangeProtectionRuleModel.getSubunitRuleList(unitId2, subUnitId).map((item) => item.permissionId), sheetPermissionId = (_a59 = worksheetProtectionModel.getRule(unitId2, subUnitId)) == null ? void 0 : _a59.permissionId;
19251
- sheetPermissionId && subUnitPermissionIds.push(sheetPermissionId);
19252
- const subUnitRuleList = allPermissionRule.filter((item) => {
19253
- var _a60;
19254
- return subUnitPermissionIds.includes(item.objectID) || item.objectID === ((_a60 = worksheetProtectionModel.getRule(unitId2, subUnitId)) == null ? void 0 : _a60.permissionId);
19255
- });
19256
- return isCurrentSheet2 ? subUnitRuleList : allPermissionRule;
19257
- }, []), [ruleList, setRuleList] = useState([]);
19258
- useEffect(() => {
19259
- const subscription = merge(
19260
- rangeProtectionRuleModel.ruleChange$,
19261
- worksheetProtectionModel.ruleChange$
19262
- ).subscribe(async () => {
19263
- const ruleList2 = await getRuleList(isCurrentSheet);
19264
- setRuleList(ruleList2);
19265
- });
19266
- return () => {
19267
- subscription.unsubscribe();
19268
- };
19269
- }, [isCurrentSheet]), useEffect(() => {
19270
- const subscribe = workbook.activeSheet$.subscribe(async () => {
19271
- const ruleList2 = await getRuleList(!0);
19272
- setRuleList(ruleList2);
19273
- });
19274
- return () => {
19275
- subscribe.unsubscribe();
19276
- };
19277
- }, []);
19278
- const handleDelete = /* @__PURE__ */ __name((rule) => {
19279
- const { unitId: unitId2, subUnitId, unitType } = rule;
19280
- let res;
19281
- unitType === l$1.Worksheet ? res = commandService.executeCommand(DeleteWorksheetProtectionCommand.id, { unitId: unitId2, subUnitId, rule }) : unitType === l$1.SelectRange && (res = commandService.executeCommand(DeleteRangeProtectionCommand.id, { unitId: unitId2, subUnitId, rule })), res && (setForceUpdateFlag(!forceUpdateFlag), rule.ranges === currentRuleRanges && currentRuleRangesSet([]));
19282
- }, "handleDelete");
19283
- useHighlightRange(currentRuleRanges);
19284
- const allRuleMap = /* @__PURE__ */ new Map();
19285
- workbook.getSheets().forEach((sheet) => {
19286
- const sheetId = sheet.getSheetId();
19287
- rangeProtectionRuleModel.getSubunitRuleList(unitId, sheetId).forEach((rule) => {
19288
- allRuleMap.set(rule.permissionId, rule);
19289
- });
19290
- const sheetRule = worksheetProtectionModel.getRule(unitId, sheetId);
19291
- sheetRule && allRuleMap.set(sheetRule == null ? void 0 : sheetRule.permissionId, sheetRule);
19292
- });
19293
- const handleEdit = /* @__PURE__ */ __name((rule) => {
19294
- sheetPermissionPanelModel.setRule(rule), sheetPermissionPanelModel.setOldRule(rule), commandService.executeCommand(SetWorksheetActiveOperation.id, {
19295
- unitId: rule.unitId,
19296
- subUnitId: rule.subUnitId
19297
- });
19298
- const sidebarProps = {
19299
- header: { title: "permission.panel.title" },
19300
- children: {
19301
- label: UNIVER_SHEET_PERMISSION_PANEL,
19302
- showDetail: !0
19303
- },
19304
- width: 330,
19305
- footer: {
19306
- label: UNIVER_SHEET_PERMISSION_PANEL_FOOTER,
19307
- showDetail: !0
19308
- }
19309
- };
19310
- sidebarService.open(sidebarProps);
19311
- }, "handleEdit"), handleChangeHeaderType = /* @__PURE__ */ __name(async (isCurrentSheet2) => {
19312
- setIsCurrentSheet(isCurrentSheet2);
19313
- const ruleList2 = await getRuleList(isCurrentSheet2);
19314
- setRuleList(ruleList2);
19315
- }, "handleChangeHeaderType");
19316
- return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelWrapper, children: [
19317
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelHeader, children: [
19318
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!0), "onClick"), children: [
19319
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$5.sheetPermissionListPanelHeaderSelect]: isCurrentSheet }), children: localeService.t("permission.panel.currentSheet") }),
19320
- isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListPanelHeaderTypeBottom })
19321
- ] }),
19322
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!1), "onClick"), children: [
19323
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$5.sheetPermissionListPanelHeaderSelect]: !isCurrentSheet }), children: localeService.t("permission.panel.allSheet") }),
19324
- !isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListPanelHeaderTypeBottom })
19325
- ] })
19326
- ] }),
19327
- (ruleList == null ? void 0 : ruleList.length) > 0 ? /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListPanelContent, children: ruleList == null ? void 0 : ruleList.map((item) => {
19328
- var _a59, _b, _c, _d, _e;
19329
- const rule = allRuleMap.get(item.objectID);
19330
- if (!rule)
19331
- return null;
19332
- const editAction = item.actions.find((action) => action.action === P.Edit), editPermission = editAction == null ? void 0 : editAction.allowed, viewAction = item.actions.find((action) => action.action === P.View), viewPermission = viewAction == null ? void 0 : viewAction.allowed, hasManagerPermission = ((_b = (_a59 = permissionService.getPermissionPoint(new WorkbookManageCollaboratorPermission(unitId).id)) == null ? void 0 : _a59.value) != null ? _b : !1) || currentUser.userID === ((_c = item.creator) == null ? void 0 : _c.userID);
19333
- let ruleName = "";
19334
- const targetSheet = workbook.getSheetBySheetId(rule.subUnitId), targetName = targetSheet == null ? void 0 : targetSheet.getName();
19335
- if (rule.unitType === l$1.SelectRange) {
19336
- const ranges = rule.ranges, rangeStr = ranges != null && ranges.length ? ranges.map((range) => {
19337
- const v = serializeRange(range);
19338
- return v === "NaN" ? "" : v;
19339
- }).filter((r) => !!r).join(",") : "";
19340
- ruleName = `${targetName}(${rangeStr})`;
19341
- } else rule.unitType === l$1.Worksheet && (ruleName = targetName || "");
19342
- return /* @__PURE__ */ jsxRuntimeExports.jsxs(
19343
- "div",
19344
- {
19345
- className: styles$5.sheetPermissionListItem,
19346
- onMouseMove: /* @__PURE__ */ __name(() => {
19347
- const { subUnitId, unitType } = rule, activeSheet = workbook.getActiveSheet();
19348
- if (!activeSheet)
19349
- return !1;
19350
- const activeSubUnitId = activeSheet.getSheetId();
19351
- if (subUnitId !== activeSubUnitId)
19352
- return !1;
19353
- if (unitType === l$1.SelectRange) {
19354
- const ranges = rule.ranges || [];
19355
- ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
19356
- } else if (unitType === l$1.Worksheet) {
19357
- const ranges = [{ startRow: 0, endRow: activeSheet.getRowCount() - 1, startColumn: 0, endColumn: activeSheet.getColumnCount() - 1 }];
19358
- ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
19359
- }
19360
- }, "onMouseMove"),
19361
- onMouseLeave: /* @__PURE__ */ __name(() => currentRuleRangesSet([]), "onMouseLeave"),
19362
- children: [
19363
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemHeader, children: [
19364
- /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: ruleName, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemHeaderName, children: ruleName }) }),
19365
- hasManagerPermission && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemHeaderOperator, children: [
19366
- /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: localeService.t("permission.panel.edit"), children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemHeaderIcon, onClick: /* @__PURE__ */ __name(() => handleEdit(rule), "onClick"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(WriteSingle, {}) }) }),
19367
- /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: localeService.t("permission.panel.delete"), children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemHeaderIcon, onClick: /* @__PURE__ */ __name(() => handleDelete(rule), "onClick"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(DeleteSingle, {}) }) })
19368
- ] })
19369
- ] }),
19370
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemSplit }),
19371
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemContent, children: [
19372
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemContentEdit, children: [
19373
- /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: (_d = item.creator) == null ? void 0 : _d.userID, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: /* @__PURE__ */ jsxRuntimeExports.jsx(Avatar, { src: (_e = item.creator) == null ? void 0 : _e.avatar, style: { marginRight: 6 }, size: 24 }) }) }),
19374
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.created") }),
19375
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentSub, children: editPermission ? `${localeService.t("permission.panel.iCanEdit")}` : `${localeService.t("permission.panel.iCanNotEdit")}` })
19376
- ] }),
19377
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemContentView, children: [
19378
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.viewPermission") }),
19379
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentSub, children: viewPermission ? `${localeService.t("permission.panel.iCanView")}` : `${localeService.t("permission.panel.iCanNotView")}` })
19380
- ] }),
19381
- rule.description && /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: rule.description, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemContentDesc, children: rule.description }) })
19382
- ] })
19383
- ]
19384
- },
19385
- item.objectID
19386
- );
19387
- }) }) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListEmpty, children: [
19388
- /* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: panelListEmptyBase64, alt: "" }),
19389
- /* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$5.sheetPermissionListEmptyText, children: localeService.t("permission.dialog.listEmpty") })
19390
- ] })
19391
- ] });
19392
- }, "SheetPermissionPanelList"), SheetPermissionPanel = /* @__PURE__ */ __name(({ showDetail, fromSheetBar }) => showDetail ? /* @__PURE__ */ jsxRuntimeExports.jsx(SheetPermissionPanelDetail, { fromSheetBar }) : /* @__PURE__ */ jsxRuntimeExports.jsx(SheetPermissionPanelList, {}), "SheetPermissionPanel"), sheetPermissionPanelFooter = "univer-sheet-permission-panel-footer", sheetPermissionPanelFooterCancel = "univer-sheet-permission-panel-footer-cancel", sheetPermissionPanelAddButton = "univer-sheet-permission-panel-add-button", styles$4 = {
19554
+ ] }) });
19555
+ }, "SheetPermissionPanelDetail"), SheetPermissionPanel = /* @__PURE__ */ __name(({ showDetail, fromSheetBar }) => {
19556
+ var _a59;
19557
+ const univerInstanceService = useDependency(IUniverInstanceService), sheetsSelectionsService = useDependency(SheetsSelectionsService);
19558
+ if (!useDependency(SheetPermissionPanelModel).getVisible()) return null;
19559
+ const target = getSheetCommandTarget(univerInstanceService);
19560
+ if (!target) return null;
19561
+ const { worksheet } = target, key = ((_a59 = sheetsSelectionsService.getCurrentSelections()) == null ? void 0 : _a59.map((selection) => selection.range)).reduce((acc, range) => acc + serializeRangeWithSheet(worksheet.getName(), range), "");
19562
+ return showDetail ? /* @__PURE__ */ jsxRuntimeExports.jsx(SheetPermissionPanelDetail, { fromSheetBar }, key) : /* @__PURE__ */ jsxRuntimeExports.jsx(SheetPermissionPanelList, {}, key);
19563
+ }, "SheetPermissionPanel"), sheetPermissionPanelFooter = "univer-sheet-permission-panel-footer", sheetPermissionPanelFooterCancel = "univer-sheet-permission-panel-footer-cancel", sheetPermissionPanelAddButton = "univer-sheet-permission-panel-add-button", styles$4 = {
19393
19564
  sheetPermissionPanelFooter,
19394
19565
  sheetPermissionPanelFooterCancel,
19395
19566
  sheetPermissionPanelAddButton
@@ -19435,44 +19606,46 @@ const UserEmptyBase64 = "
19435
19606
  type: "primary",
19436
19607
  onClick: /* @__PURE__ */ __name(async () => {
19437
19608
  if (!activeRule.name || rangeErrMsg) return;
19438
- const collaborators = sheetPermissionUserManagerService.selectUserList;
19439
- activeRule.viewStatus === viewState.othersCanView && sheetPermissionUserManagerService.allUserList.forEach((user) => {
19440
- if (!collaborators.some((collaborator) => collaborator.id === user.id)) {
19441
- const userCanRead = {
19442
- ...user,
19443
- role: M.Reader
19444
- };
19445
- collaborators.push(userCanRead);
19446
- }
19447
- });
19448
- const isSameCollaborators = getUserListEqual(collaborators, sheetPermissionUserManagerService.oldCollaboratorList);
19449
- if (activeRule.permissionId) {
19450
- const oldRule = sheetPermissionPanelModel.oldRule;
19451
- if (activeRule.unitType === (oldRule == null ? void 0 : oldRule.unitType) && activeRule.name === oldRule.name && activeRule.description === oldRule.description && activeRule.ranges === oldRule.ranges && !isSameCollaborators)
19452
- await authzIoService.putCollaborators({
19609
+ let collaborators = sheetPermissionUserManagerService.selectUserList;
19610
+ activeRule.editStatus === editState.onlyMe && (collaborators = [], sheetPermissionUserManagerService.setSelectUserList([]));
19611
+ const scopeObj = {
19612
+ read: activeRule.viewStatus === viewState.othersCanView ? G.AllCollaborator : G.SomeCollaborator,
19613
+ edit: activeRule.editStatus === editState.designedUserCanEdit ? G.SomeCollaborator : G.OneSelf
19614
+ };
19615
+ if (activeRule.editStatus === editState.designedUserCanEdit && collaborators.length === 0 && (collaborators = [], scopeObj.edit = G.OneSelf), activeRule.permissionId) {
19616
+ const oldRule = sheetPermissionPanelModel.oldRule, isSameCollaborators = getUserListEqual(collaborators.filter((user) => user.role === P.Editor), sheetPermissionUserManagerService.oldCollaboratorList.filter((user) => user.role === P.Editor)), isSameReadStatus = (oldRule == null ? void 0 : oldRule.viewStatus) === activeRule.viewStatus, isSameEditStatus = (oldRule == null ? void 0 : oldRule.editStatus) === activeRule.editStatus, ruleConfigIsOrigin = activeRule.unitType === (oldRule == null ? void 0 : oldRule.unitType) && activeRule.name === oldRule.name && activeRule.description === oldRule.description && activeRule.ranges === oldRule.ranges, collaboratorsIsChange = !isSameCollaborators || !isSameReadStatus || !isSameEditStatus;
19617
+ if (ruleConfigIsOrigin && collaboratorsIsChange)
19618
+ await authzIoService.update({
19619
+ objectType: activeRule.unitType,
19453
19620
  objectID: activeRule.permissionId,
19454
19621
  unitID: activeRule.unitId,
19455
- collaborators
19622
+ share: void 0,
19623
+ name: "",
19624
+ strategies: [],
19625
+ scope: scopeObj,
19626
+ collaborators: {
19627
+ collaborators
19628
+ }
19456
19629
  });
19457
19630
  else {
19458
19631
  let newPermissionId = activeRule.permissionId;
19459
- isSameCollaborators || (activeRule.unitType === l$1.Worksheet ? newPermissionId = await authzIoService.create({
19632
+ collaboratorsIsChange && (activeRule.unitType === M.Worksheet ? newPermissionId = await authzIoService.create({
19460
19633
  worksheetObject: {
19461
19634
  collaborators,
19462
19635
  unitID: activeRule.unitId,
19463
19636
  name: activeRule.name,
19464
- strategies: [{ role: M.Editor, action: P.Edit }, { role: M.Reader, action: P.View }],
19465
- scope: L.SomeCollaborator
19637
+ strategies: [{ role: P.Editor, action: L.Edit }, { role: P.Reader, action: L.View }],
19638
+ scope: scopeObj
19466
19639
  },
19467
- objectType: l$1.Worksheet
19640
+ objectType: M.Worksheet
19468
19641
  }) : newPermissionId = await authzIoService.create({
19469
19642
  selectRangeObject: {
19470
19643
  collaborators,
19471
19644
  unitID: activeRule.unitId,
19472
19645
  name: activeRule.name,
19473
- readScope: L.SomeCollaborator
19646
+ scope: scopeObj
19474
19647
  },
19475
- objectType: l$1.SelectRange
19648
+ objectType: M.SelectRange
19476
19649
  })), commandService.executeCommand(SetProtectionCommand.id, {
19477
19650
  rule: {
19478
19651
  ...activeRule,
@@ -19480,37 +19653,37 @@ const UserEmptyBase64 = "
19480
19653
  }
19481
19654
  });
19482
19655
  }
19483
- } else if (activeRule.unitType === l$1.Worksheet) {
19656
+ } else if (activeRule.unitType === M.Worksheet) {
19484
19657
  const permissionId = await authzIoService.create({
19485
19658
  worksheetObject: {
19486
19659
  collaborators,
19487
19660
  unitID: activeRule.unitId,
19488
19661
  name: activeRule.name,
19489
- strategies: [{ role: M.Editor, action: P.Edit }, { role: M.Reader, action: P.View }],
19490
- scope: L.SomeCollaborator
19662
+ strategies: [{ role: P.Editor, action: L.Edit }, { role: P.Reader, action: L.View }],
19663
+ scope: scopeObj
19491
19664
  },
19492
- objectType: l$1.Worksheet
19665
+ objectType: M.Worksheet
19493
19666
  }), { ranges: _range = [], ...sheetRule } = activeRule;
19494
19667
  sheetRule.permissionId = permissionId, commandService.executeCommand(AddWorksheetProtectionCommand.id, {
19495
19668
  rule: sheetRule,
19496
19669
  unitId: activeRule.unitId
19497
19670
  });
19498
- } else if (activeRule.unitType === l$1.SelectRange) {
19671
+ } else if (activeRule.unitType === M.SelectRange) {
19499
19672
  const permissionId = await authzIoService.create({
19500
19673
  selectRangeObject: {
19501
19674
  collaborators,
19502
19675
  unitID: activeRule.unitId,
19503
19676
  name: activeRule.name,
19504
- readScope: L.SomeCollaborator
19677
+ scope: scopeObj
19505
19678
  },
19506
- objectType: l$1.SelectRange
19679
+ objectType: M.SelectRange
19507
19680
  });
19508
19681
  commandService.executeCommand(AddRangeProtectionCommand$1.id, {
19509
19682
  rule: activeRule,
19510
19683
  permissionId
19511
19684
  });
19512
19685
  }
19513
- sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.setSelectUserList([]);
19686
+ sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.reset();
19514
19687
  const sidebarProps = {
19515
19688
  header: { title: `${localeService.t("permission.panel.title")}` },
19516
19689
  children: {
@@ -19533,7 +19706,7 @@ const UserEmptyBase64 = "
19533
19706
  {
19534
19707
  className: styles$4.sheetPermissionPanelFooterCancel,
19535
19708
  onClick: /* @__PURE__ */ __name(() => {
19536
- sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.setSelectUserList([]), sidebarService.close();
19709
+ sheetPermissionPanelModel.reset(), sheetPermissionUserManagerService.reset(), sidebarService.close();
19537
19710
  }, "onClick"),
19538
19711
  children: localeService.t("permission.button.cancel")
19539
19712
  }
@@ -19554,7 +19727,7 @@ const UserEmptyBase64 = "
19554
19727
  }, SheetPermissionUserDialog = /* @__PURE__ */ __name(() => {
19555
19728
  const [inputValue, setInputValue] = React.useState(""), localeService = useDependency(LocaleService), dialogService = useDependency(IDialogService), sheetPermissionUserManagerService = useDependency(SheetPermissionUserManagerService), searchUserList = sheetPermissionUserManagerService.userList.filter((item) => {
19556
19729
  var _a59;
19557
- return ((_a59 = item.subject) == null ? void 0 : _a59.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase())) && item.role === M.Editor;
19730
+ return ((_a59 = item.subject) == null ? void 0 : _a59.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase())) && item.role === P.Editor;
19558
19731
  }), [selectUserInfo, setSelectUserInfo] = useState(sheetPermissionUserManagerService.selectUserList), handleChangeUser = /* @__PURE__ */ __name((item) => {
19559
19732
  if ((selectUserInfo == null ? void 0 : selectUserInfo.findIndex((v) => {
19560
19733
  var _a59, _b;
@@ -19645,7 +19818,7 @@ const UserEmptyBase64 = "
19645
19818
  actions: defaultWorksheetUnitActionList
19646
19819
  }))[0].strategies.reduce((p2, c) => (subUnitPermissionTypeMap[c.action] && (p2[c.action] = {
19647
19820
  text: localeService.t(`permission.panel.${subUnitPermissionTypeMap[c.action]}`),
19648
- allowed: c.role !== M.Owner
19821
+ allowed: c.role !== P.Owner
19649
19822
  }), p2), {});
19650
19823
  setPermissionMap(actions), setTimeout(() => {
19651
19824
  setLoading(!1);
@@ -19658,29 +19831,37 @@ const UserEmptyBase64 = "
19658
19831
  throw new Error("No active sheet found");
19659
19832
  const unitId = workbook2.getUnitId(), subUnitId = worksheet2.getSheetId(), pointRule = worksheetProtectionPointRuleModel.getRule(unitId, subUnitId), actions = Object.keys(permissionMap).map((action) => ({
19660
19833
  action: Number(action),
19661
- role: permissionMap[action].allowed ? M.Editor : M.Owner
19834
+ role: permissionMap[action].allowed ? P.Editor : P.Owner
19662
19835
  }));
19663
19836
  let permissionId = pointRule == null ? void 0 : pointRule.permissionId;
19664
19837
  permissionId ? authzIoService.update({
19665
- objectType: l$1.Worksheet,
19838
+ objectType: M.Worksheet,
19666
19839
  objectID: permissionId,
19667
19840
  unitID: unitId,
19668
19841
  strategies: actions,
19669
19842
  share: void 0,
19670
- name: ""
19843
+ name: "",
19844
+ scope: {
19845
+ read: G.AllCollaborator,
19846
+ edit: G.AllCollaborator
19847
+ },
19848
+ collaborators: void 0
19671
19849
  }).then(() => {
19672
19850
  getAllWorksheetPermissionPoint().forEach((F) => {
19673
19851
  const instance = new F(unitId, subUnitId), unitActionName = instance.subType, action = actions.find((item) => item.action === unitActionName);
19674
- action && permissionService.updatePermissionPoint(instance.id, action.role === M.Editor);
19852
+ action && permissionService.updatePermissionPoint(instance.id, action.role === P.Editor);
19675
19853
  });
19676
19854
  }) : (permissionId = await authzIoService.create({
19677
- objectType: l$1.Worksheet,
19855
+ objectType: M.Worksheet,
19678
19856
  worksheetObject: {
19679
19857
  unitID: unitId,
19680
19858
  collaborators,
19681
19859
  name: "",
19682
19860
  strategies: actions,
19683
- scope: L.AllCollaborator
19861
+ scope: {
19862
+ read: G.AllCollaborator,
19863
+ edit: G.AllCollaborator
19864
+ }
19684
19865
  }
19685
19866
  }), commandService.executeCommand(SetWorksheetPermissionPointsCommand.id, {
19686
19867
  rule: {
@@ -19690,7 +19871,7 @@ const UserEmptyBase64 = "
19690
19871
  }
19691
19872
  }));
19692
19873
  }, "handleChangeActionPermission");
19693
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Spin, { loading, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$2.sheetPermissionDialogWrapper, children: /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
19874
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Spin, { loading, children: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$2.sheetPermissionDialogWrapper, children: [
19694
19875
  /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$2.sheetPermissionDialogSplit }),
19695
19876
  Object.keys(permissionMap).map((action) => {
19696
19877
  const actionItem = permissionMap[action], { text, allowed } = actionItem;
@@ -19737,7 +19918,7 @@ const UserEmptyBase64 = "
19737
19918
  }
19738
19919
  )
19739
19920
  ] })
19740
- ] }) }) });
19921
+ ] }) });
19741
19922
  }, "SheetPermissionDialog"), sheetPermissionAlertDialog = "univer-sheet-permission-alert-dialog", sheetPermissionAlertDialogTitle = "univer-sheet-permission-alert-dialog-title", sheetPermissionAlertDialogButton = "univer-sheet-permission-alert-dialog-button", styles$1 = {
19742
19923
  sheetPermissionAlertDialog,
19743
19924
  sheetPermissionAlertDialogTitle,
@@ -19797,7 +19978,7 @@ const _RangeProtectionCanViewRenderExtension = class _RangeProtectionCanViewRend
19797
19978
  __publicField(this, "Z_INDEX", EXTENSION_CAN_VIEW_Z_INDEX$1);
19798
19979
  }
19799
19980
  shouldRender(config) {
19800
- return (config == null ? void 0 : config[P.View]) !== !1;
19981
+ return (config == null ? void 0 : config[L.View]) !== !1;
19801
19982
  }
19802
19983
  };
19803
19984
  __name(_RangeProtectionCanViewRenderExtension, "RangeProtectionCanViewRenderExtension");
@@ -19809,7 +19990,7 @@ const _RangeProtectionCanNotViewRenderExtension = class _RangeProtectionCanNotVi
19809
19990
  __publicField(this, "Z_INDEX", EXTENSION_CAN_NOT_VIEW_Z_INDEX$1);
19810
19991
  }
19811
19992
  shouldRender(config) {
19812
- return (config == null ? void 0 : config[P.View]) === !1;
19993
+ return (config == null ? void 0 : config[L.View]) === !1;
19813
19994
  }
19814
19995
  };
19815
19996
  __name(_RangeProtectionCanNotViewRenderExtension, "RangeProtectionCanNotViewRenderExtension");
@@ -19908,7 +20089,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
19908
20089
  for (let row = startRow; row <= endRow; row++)
19909
20090
  for (let col = startColumn; col <= endColumn; col++) {
19910
20091
  const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
19911
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
20092
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
19912
20093
  return !0;
19913
20094
  }
19914
20095
  return !1;
@@ -19952,7 +20133,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
19952
20133
  for (let row = startRow; row <= endRow; row++)
19953
20134
  for (let col = startColumn; col <= endColumn; col++) {
19954
20135
  const permission = (_b2 = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b2[0];
19955
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
20136
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
19956
20137
  return !0;
19957
20138
  }
19958
20139
  return !1;
@@ -19973,7 +20154,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
19973
20154
  for (let row = startRow; row <= endRow; row++)
19974
20155
  for (let col = startColumn; col <= endColumn; col++) {
19975
20156
  const permission = (_b2 = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b2[0];
19976
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
20157
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
19977
20158
  return !0;
19978
20159
  }
19979
20160
  return !1;
@@ -20003,7 +20184,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
20003
20184
  for (let row = startRow; row <= endRow; row++)
20004
20185
  for (let col = startColumn; col <= endColumn; col++) {
20005
20186
  const permission = (_c = (_b = worksheet.getCell(row, col)) == null ? void 0 : _b.selectionProtection) == null ? void 0 : _c[0];
20006
- if ((permission == null ? void 0 : permission[P.Edit]) === !1 || (permission == null ? void 0 : permission[P.View]) === !1)
20187
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1 || (permission == null ? void 0 : permission[L.View]) === !1)
20007
20188
  return !1;
20008
20189
  }
20009
20190
  return !0;
@@ -20029,7 +20210,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
20029
20210
  for (let row = startRow; row <= endRow; row++)
20030
20211
  for (let col = startColumn; col <= endColumn; col++) {
20031
20212
  const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
20032
- if ((permission == null ? void 0 : permission[P.Edit]) === !1)
20213
+ if ((permission == null ? void 0 : permission[L.Edit]) === !1)
20033
20214
  return !0;
20034
20215
  }
20035
20216
  return !1;
@@ -20097,7 +20278,7 @@ let SheetPermissionInterceptorFormulaRenderController = (_a49 = class extends Rx
20097
20278
  if (((_a60 = worksheet.getCellRaw(rowIndex + startRow, colIndex + startCol)) == null ? void 0 : _a60.v) === void 0)
20098
20279
  return;
20099
20280
  const permission = (_b = this._rangeProtectionRenderModel.getCellInfo(unitId, subUnitId, rowIndex + startRow, colIndex + startCol)) == null ? void 0 : _b[0];
20100
- (permission == null ? void 0 : permission[P.View]) === !1 && (itemValue[rowIndex][colIndex] = NullValueObject.create());
20281
+ (permission == null ? void 0 : permission[L.View]) === !1 && (itemValue[rowIndex][colIndex] = NullValueObject.create());
20101
20282
  });
20102
20283
  });
20103
20284
  }), originValue;
@@ -20132,7 +20313,7 @@ const worksheetProtectionKey = "worksheet-protection", EXTENSION_CAN_VIEW_Z_INDE
20132
20313
  if (this._pattern) {
20133
20314
  if (selectionProtection.length > 0) {
20134
20315
  const cellProtectionConfig = selectionProtection[0];
20135
- (cellProtectionConfig == null ? void 0 : cellProtectionConfig[P.View]) ? this.setZIndex(EXTENSION_CAN_VIEW_Z_INDEX) : this.setZIndex(EXTENSION_CAN_NOT_VIEW_Z_INDEX);
20316
+ (cellProtectionConfig == null ? void 0 : cellProtectionConfig[L.View]) ? this.setZIndex(EXTENSION_CAN_VIEW_Z_INDEX) : this.setZIndex(EXTENSION_CAN_NOT_VIEW_Z_INDEX);
20136
20317
  }
20137
20318
  ctx.fillStyle = this._pattern, hasWorksheetRule && ctx.fillRect(start.startX, start.startY, end.endX - start.startX, end.endY - start.startY), ctx.restore();
20138
20319
  }
@@ -20332,7 +20513,7 @@ let UniverSheetsUIPlugin = (_a53 = class extends Plugin {
20332
20513
  constructor(_config = {}, _injector, _renderManagerService, _univerInstanceService) {
20333
20514
  super(), this._config = _config, this._injector = _injector, this._renderManagerService = _renderManagerService, this._univerInstanceService = _univerInstanceService, this._config = Tools.deepMerge({}, DefaultSheetUiConfig, this._config);
20334
20515
  }
20335
- onStarting(injector) {
20516
+ onStarting() {
20336
20517
  mergeOverrideWithDependencies([
20337
20518
  // services
20338
20519
  [ShortcutExperienceService],
@@ -20376,7 +20557,7 @@ let UniverSheetsUIPlugin = (_a53 = class extends Plugin {
20376
20557
  [SheetPermissionInterceptorBaseController],
20377
20558
  [SheetPermissionInitController]
20378
20559
  // [MoveRangeController],
20379
- ], this._config.override).forEach((d) => injector.add(d)), this._injector.add(
20560
+ ], this._config.override).forEach((d) => this._injector.add(d)), this._injector.add(
20380
20561
  [
20381
20562
  SheetPermissionRenderManagerController,
20382
20563
  {
@@ -21201,11 +21382,11 @@ const _MobileSelectionControl = class _MobileSelectionControl extends SelectionC
21201
21382
  (_a59 = this._fillControlBottomRight) == null || _a59.dispose(), (_b = this._fillControlTopLeft) == null || _b.dispose(), super.dispose();
21202
21383
  }
21203
21384
  updateRange(range) {
21204
- this._selectionModel.setValue(range), this._updateControl(null, this._rowHeaderWidth, this._columnHeaderHeight);
21385
+ this._selectionModel.setValue(range), this._updateControlStyleAndLayout(null, this._rowHeaderWidth, this._columnHeaderHeight);
21205
21386
  }
21206
- _updateControl(style, rowHeaderWidth, columnHeaderHeight) {
21387
+ _updateControlStyleAndLayout(style, rowHeaderWidth, columnHeaderHeight) {
21207
21388
  var _a59, _b, _c, _d;
21208
- super._updateControl(style, rowHeaderWidth, columnHeaderHeight);
21389
+ super._updateControlStyleAndLayout(style, rowHeaderWidth, columnHeaderHeight);
21209
21390
  const defaultStyle = this.defaultStyle;
21210
21391
  style == null && (style = defaultStyle);
21211
21392
  const {
@@ -21302,12 +21483,12 @@ var __defProp$1 = Object.defineProperty, __getOwnPropDesc$1 = Object.getOwnPrope
21302
21483
  return kind && result && __defProp$1(target, key, result), result;
21303
21484
  }, "__decorateClass$1"), __decorateParam$1 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$1"), _a57;
21304
21485
  let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRenderService {
21305
- constructor(_context, injector, themeService, shortcutService, renderManagerService, selectionManagerService, _logService, _commandService, _contextService, _sheetSkeletonManagerService, _scrollManagerService) {
21486
+ constructor(_context, injector, themeService, shortcutService, selectionManagerService, sheetSkeletonManagerService, _logService, _commandService, _contextService, _scrollManagerService) {
21306
21487
  super(
21307
21488
  injector,
21308
21489
  themeService,
21309
21490
  shortcutService,
21310
- renderManagerService
21491
+ sheetSkeletonManagerService
21311
21492
  );
21312
21493
  __publicField(this, "_workbookSelections");
21313
21494
  __publicField(this, "_renderDisposable", null);
@@ -21315,7 +21496,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
21315
21496
  __publicField(this, "_selectionControls", []);
21316
21497
  // sheetID:Controls
21317
21498
  __publicField(this, "expandingControlMode", "bottom-right");
21318
- this._context = _context, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this._sheetSkeletonManagerService = _sheetSkeletonManagerService, this._scrollManagerService = _scrollManagerService, this._workbookSelections = selectionManagerService.getWorkbookSelections(this._context.unitId), this._init();
21499
+ this._context = _context, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this._scrollManagerService = _scrollManagerService, this._workbookSelections = selectionManagerService.getWorkbookSelections(this._context.unitId), this._init();
21319
21500
  }
21320
21501
  _init() {
21321
21502
  const sheetObject = this._getSheetObject();
@@ -21439,11 +21620,11 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
21439
21620
  activeSelectionControl = control;
21440
21621
  break;
21441
21622
  }
21442
- (activeSelectionControl == null ? void 0 : activeSelectionControl.model.rangeType) !== rangeType && (this._clearSelectionControls(), activeSelectionControl = this.newSelectionControl(scene, rangeType)), this._updateSelectionControlRange(
21623
+ (activeSelectionControl == null ? void 0 : activeSelectionControl.model.rangeType) !== rangeType && (this._clearSelectionControls(), activeSelectionControl = this.newSelectionControl(scene, rangeType)), this._updateSelectionControlByRange(
21443
21624
  activeSelectionControl,
21444
21625
  cursorCellRangeWithRangeType,
21445
21626
  primaryCursorCellRange
21446
- ), this._selectionMoveStart$.next(this.getSelectionDataWithStyle()), this._clearUpdatingListeners(), this._expandingSelection = !1, (rangeType === RANGE_TYPE.ROW || rangeType === RANGE_TYPE.COLUMN) && (rangeType === RANGE_TYPE.ROW ? viewportPosX = 0 : rangeType === RANGE_TYPE.COLUMN && (viewportPosY = 0), this._moving(viewportPosX, viewportPosY, activeSelectionControl, rangeType));
21627
+ ), this._selectionMoveStart$.next(this.getSelectionDataWithStyle()), this._clearUpdatingListeners(), this._expandingSelection = !1, (rangeType === RANGE_TYPE.ROW || rangeType === RANGE_TYPE.COLUMN) && (rangeType === RANGE_TYPE.ROW ? viewportPosX = 0 : rangeType === RANGE_TYPE.COLUMN && (viewportPosY = 0), this._movingHandler(viewportPosX, viewportPosY, activeSelectionControl, rangeType));
21447
21628
  }
21448
21629
  /**
21449
21630
  * Not same as PC version,
@@ -21568,7 +21749,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
21568
21749
  *
21569
21750
  * In Mobile version, new selection is determined by cursor cell and current of activeSelectionControl.model
21570
21751
  */
21571
- _moving(offsetX, offsetY, activeSelectionControl, rangeType) {
21752
+ _movingHandler(offsetX, offsetY, activeSelectionControl, rangeType) {
21572
21753
  var _a59, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m;
21573
21754
  this._shouldDetectMergedCells = rangeType === RANGE_TYPE.NORMAL;
21574
21755
  const skeleton = this._skeleton, scene = this._scene, currSelectionRange = {
@@ -21613,7 +21794,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
21613
21794
  startX: (startCellXY == null ? void 0 : startCellXY.startX) || 0,
21614
21795
  endX: (endCellXY == null ? void 0 : endCellXY.endX) || 0
21615
21796
  };
21616
- (currSelectionRange.startRow !== newSelectionRange.startRow || currSelectionRange.startColumn !== newSelectionRange.startColumn || currSelectionRange.endRow !== newSelectionRange.endRow || currSelectionRange.endColumn !== newSelectionRange.endColumn) && activeSelectionControl && (this._updateSelectionControlRange(activeSelectionControl, newSelectionRangeWithCoord), this._selectionMoving$.next(this.getSelectionDataWithStyle()));
21797
+ (currSelectionRange.startRow !== newSelectionRange.startRow || currSelectionRange.startColumn !== newSelectionRange.startColumn || currSelectionRange.endRow !== newSelectionRange.endRow || currSelectionRange.endColumn !== newSelectionRange.endColumn) && activeSelectionControl && (this._updateSelectionControlByRange(activeSelectionControl, newSelectionRangeWithCoord), this._selectionMoving$.next(this.getSelectionDataWithStyle()));
21617
21798
  }
21618
21799
  _updateControlPointWhenScrolling() {
21619
21800
  const { scene } = this._context;
@@ -21635,13 +21816,12 @@ MobileSheetsSelectionRenderService = __decorateClass$1([
21635
21816
  __decorateParam$1(1, Inject(Injector)),
21636
21817
  __decorateParam$1(2, Inject(ThemeService)),
21637
21818
  __decorateParam$1(3, IShortcutService),
21638
- __decorateParam$1(4, IRenderManagerService),
21639
- __decorateParam$1(5, Inject(SheetsSelectionsService)),
21819
+ __decorateParam$1(4, Inject(SheetsSelectionsService)),
21820
+ __decorateParam$1(5, Inject(SheetSkeletonManagerService)),
21640
21821
  __decorateParam$1(6, ILogService),
21641
21822
  __decorateParam$1(7, ICommandService),
21642
21823
  __decorateParam$1(8, IContextService),
21643
- __decorateParam$1(9, Inject(SheetSkeletonManagerService)),
21644
- __decorateParam$1(10, Inject(SheetScrollManagerService))
21824
+ __decorateParam$1(9, Inject(SheetScrollManagerService))
21645
21825
  ], MobileSheetsSelectionRenderService);
21646
21826
  var __defProp2 = Object.defineProperty, __getOwnPropDesc = Object.getOwnPropertyDescriptor, __defNormalProp2 = /* @__PURE__ */ __name((obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: !0, configurable: !0, writable: !0, value }) : obj[key] = value, "__defNormalProp"), __decorateClass = /* @__PURE__ */ __name((decorators, target, key, kind) => {
21647
21827
  for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)