@univerjs/sheets-ui 0.2.8 → 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.
- package/lib/cjs/index.js +4 -4
- package/lib/es/index.js +782 -630
- package/lib/index.css +1 -1
- package/lib/types/{basics/const → consts}/ui-name.d.ts +2 -1
- package/lib/types/controllers/menu/menu.d.ts +2 -1
- package/lib/types/controllers/permission/sheet-permission-init.controller.d.ts +4 -2
- package/lib/types/controllers/render-controllers/zoom.render-controller.d.ts +4 -0
- package/lib/types/index.d.ts +2 -1
- package/lib/types/services/permission/sheet-permission-panel.model.d.ts +9 -0
- package/lib/types/services/permission/sheet-permission-user-list.service.d.ts +1 -0
- package/lib/types/services/selection/base-selection-render.service.d.ts +38 -38
- package/lib/types/services/selection/mobile-selection-render.service.d.ts +3 -4
- package/lib/types/services/selection/mobile-selection-shape.d.ts +1 -1
- package/lib/types/services/selection/selection-render-model.d.ts +7 -3
- package/lib/types/services/selection/selection-render.service.d.ts +3 -6
- package/lib/types/services/selection/selection-shape-extension.d.ts +13 -3
- package/lib/types/services/selection/selection-shape.d.ts +22 -17
- package/lib/types/views/permission/panel/index.d.ts +1 -1
- package/lib/umd/index.js +4 -4
- package/package.json +18 -18
- package/lib/types/basics/const/index.d.ts +0 -17
- package/lib/types/basics/index.d.ts +0 -16
- /package/lib/types/{basics/const → consts}/permission.d.ts +0 -0
- /package/lib/types/{basics/const → consts}/plugin-name.d.ts +0 -0
package/lib/es/index.js
CHANGED
|
@@ -5,16 +5,16 @@ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key != "sym
|
|
|
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
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, 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,
|
|
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";
|
|
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";
|
|
11
11
|
import React, { forwardRef, useRef, createElement, useState, useEffect, useCallback, useLayoutEffect, useMemo } from "react";
|
|
12
|
-
import { Dropdown, ColorPicker, Menu, MenuItem, InputNumber, Slider, Input, Tooltip, MessageType, RadioGroup, Radio, Select, Button, Confirm,
|
|
12
|
+
import { Dropdown, ColorPicker, Menu, MenuItem, InputNumber, Slider, Input, Tooltip, MessageType, RadioGroup, Radio, Select, Button, Confirm, Avatar, FormLayout, Switch } from "@univerjs/design";
|
|
13
13
|
import clsx from "clsx";
|
|
14
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";
|
|
15
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 || {});
|
|
16
17
|
const SHEET_UI_PLUGIN_NAME = "SheetUI";
|
|
17
|
-
var SheetsUIPart = /* @__PURE__ */ ((SheetsUIPart2) => (SheetsUIPart2.FILTER_PANEL_EMBED_POINT = "filter-panel-embed-point", SheetsUIPart2))(SheetsUIPart || {});
|
|
18
18
|
function getEditorObject(unitId, renderManagerService) {
|
|
19
19
|
if (unitId == null)
|
|
20
20
|
return;
|
|
@@ -1134,9 +1134,6 @@ let SheetsScrollRenderController = (_a4 = class extends Disposable {
|
|
|
1134
1134
|
const viewportMain = scene.getViewport(SHEET_VIEWPORT_KEY$1.VIEW_MAIN);
|
|
1135
1135
|
viewportMain && (this.disposeWithMe(
|
|
1136
1136
|
toDisposable(
|
|
1137
|
-
// wheel event --> set-scroll.command('sheet.operation.set-scroll') --> scroll.operation.ts -->
|
|
1138
|
-
// scrollManagerService.setScrollInfoAndEmitEvent ---> scrollManagerService.setScrollInfo(raw value, may be negative) &&
|
|
1139
|
-
// _notifyCurrentScrollInfo
|
|
1140
1137
|
this._scrollManagerService.rawScrollInfo$.subscribe((rawScrollInfo) => {
|
|
1141
1138
|
var _a59;
|
|
1142
1139
|
const skeleton = (_a59 = this._sheetSkeletonManagerService.getCurrent()) == null ? void 0 : _a59.skeleton;
|
|
@@ -1333,7 +1330,7 @@ SheetsScrollRenderController = __decorateClass$R([
|
|
|
1333
1330
|
__decorateParam$Q(5, IRenderManagerService),
|
|
1334
1331
|
__decorateParam$Q(6, Inject(SheetScrollManagerService))
|
|
1335
1332
|
], SheetsScrollRenderController);
|
|
1336
|
-
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.
|
|
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 || {});
|
|
1337
1334
|
function getActiveSheet$(univerInstanceService) {
|
|
1338
1335
|
return univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET).pipe(switchMap((workbook) => workbook ? workbook.activeSheet$.pipe(map((worksheet) => worksheet ? { workbook, worksheet } : null)) : of(null)));
|
|
1339
1336
|
}
|
|
@@ -1391,7 +1388,7 @@ function getBaseRangeMenuHidden$(accessor) {
|
|
|
1391
1388
|
for (let row = startRow; row <= endRow; row++)
|
|
1392
1389
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
1393
1390
|
const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
|
|
1394
|
-
if ((permission == null ? void 0 : permission[
|
|
1391
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
1395
1392
|
return !0;
|
|
1396
1393
|
}
|
|
1397
1394
|
return !1;
|
|
@@ -1417,7 +1414,7 @@ function getInsertAfterMenuHidden$(accessor, type) {
|
|
|
1417
1414
|
for (let row = startRow; row <= endRow; row++)
|
|
1418
1415
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
1419
1416
|
const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
|
|
1420
|
-
if ((permission == null ? void 0 : permission[
|
|
1417
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
1421
1418
|
return !0;
|
|
1422
1419
|
}
|
|
1423
1420
|
return !1;
|
|
@@ -1443,7 +1440,7 @@ function getInsertBeforeMenuHidden$(accessor, type) {
|
|
|
1443
1440
|
for (let row = startRow; row <= endRow; row++)
|
|
1444
1441
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
1445
1442
|
const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
|
|
1446
|
-
if ((permission == null ? void 0 : permission[
|
|
1443
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
1447
1444
|
return !0;
|
|
1448
1445
|
}
|
|
1449
1446
|
return !1;
|
|
@@ -1469,7 +1466,7 @@ function getDeleteMenuHidden$(accessor, type) {
|
|
|
1469
1466
|
for (let row = startRow; row <= endRow; row++)
|
|
1470
1467
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
1471
1468
|
const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
|
|
1472
|
-
if ((permission == null ? void 0 : permission[
|
|
1469
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
1473
1470
|
return !0;
|
|
1474
1471
|
}
|
|
1475
1472
|
return !1;
|
|
@@ -1495,7 +1492,7 @@ function getCellMenuHidden$(accessor, type) {
|
|
|
1495
1492
|
for (let row = startRow; row <= endRow; row++)
|
|
1496
1493
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
1497
1494
|
const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
|
|
1498
|
-
if ((permission == null ? void 0 : permission[
|
|
1495
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
1499
1496
|
return !0;
|
|
1500
1497
|
}
|
|
1501
1498
|
return !1;
|
|
@@ -2514,9 +2511,7 @@ const IAutoFillService = createIdentifier("univer.auto-fill-service"), AutoFillC
|
|
|
2514
2511
|
__publicField(this, "_endX", 0);
|
|
2515
2512
|
__publicField(this, "_endY", 0);
|
|
2516
2513
|
/**
|
|
2517
|
-
* highlight cell of selection
|
|
2518
|
-
* when there is no merge info
|
|
2519
|
-
* top left cell of current selection (or bottomLeft of current selection)
|
|
2514
|
+
* The highlight cell of a selection. aka: current cell
|
|
2520
2515
|
*/
|
|
2521
2516
|
__publicField(this, "_primary");
|
|
2522
2517
|
__publicField(this, "_rangeType", RANGE_TYPE.NORMAL);
|
|
@@ -2621,6 +2616,12 @@ const IAutoFillService = createIdentifier("univer.auto-fill-service"), AutoFillC
|
|
|
2621
2616
|
} = newSelectionRange;
|
|
2622
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);
|
|
2623
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
|
+
*/
|
|
2624
2625
|
setCurrentCell(currentCell) {
|
|
2625
2626
|
currentCell && (this._primary = currentCell);
|
|
2626
2627
|
}
|
|
@@ -2662,12 +2663,19 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2662
2663
|
__publicField(this, "_bottomRightWidget");
|
|
2663
2664
|
__publicField(this, "_dashRect");
|
|
2664
2665
|
__publicField(this, "_selectionModel");
|
|
2665
|
-
|
|
2666
|
+
// why three style prop? what's diff between _selectionStyle & _currentStyle?
|
|
2667
|
+
// protected _selectionStyle: Nullable<ISelectionStyle>;
|
|
2668
|
+
__publicField(this, "_defaultStyle");
|
|
2669
|
+
__publicField(this, "_currentStyle");
|
|
2666
2670
|
__publicField(this, "_rowHeaderWidth", 0);
|
|
2667
2671
|
__publicField(this, "_columnHeaderHeight", 0);
|
|
2668
2672
|
__publicField(this, "_widgetRects", []);
|
|
2669
2673
|
__publicField(this, "_dispose$", new BehaviorSubject(this));
|
|
2670
2674
|
__publicField(this, "dispose$", this._dispose$.asObservable());
|
|
2675
|
+
/**
|
|
2676
|
+
* eventSource: selectionShapeExtension selectionMoving$.next,
|
|
2677
|
+
* Observer: prompt.controller
|
|
2678
|
+
*/
|
|
2671
2679
|
__publicField(this, "selectionMoving$", new Subject());
|
|
2672
2680
|
__publicField(this, "selectionMoved$", new Subject());
|
|
2673
2681
|
__publicField(this, "selectionScaling$", new Subject());
|
|
@@ -2675,8 +2683,6 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2675
2683
|
__publicField(this, "selectionFilling$", new Subject());
|
|
2676
2684
|
__publicField(this, "_selectionFilled$", new Subject());
|
|
2677
2685
|
__publicField(this, "selectionFilled$", this._selectionFilled$.asObservable());
|
|
2678
|
-
__publicField(this, "_defaultStyle");
|
|
2679
|
-
__publicField(this, "_currentStyle");
|
|
2680
2686
|
__publicField(this, "_isHelperSelection", !0);
|
|
2681
2687
|
__publicField(this, "_antLineOffset", 0);
|
|
2682
2688
|
__publicField(this, "_antRequestNewFrame", -1);
|
|
@@ -2754,12 +2760,12 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2754
2760
|
get themeService() {
|
|
2755
2761
|
return this._themeService;
|
|
2756
2762
|
}
|
|
2757
|
-
get selectionStyle() {
|
|
2758
|
-
|
|
2759
|
-
}
|
|
2760
|
-
set selectionStyle(style) {
|
|
2761
|
-
|
|
2762
|
-
}
|
|
2763
|
+
// get selectionStyle() {
|
|
2764
|
+
// return this._selectionStyle;
|
|
2765
|
+
// }
|
|
2766
|
+
// set selectionStyle(style: Nullable<ISelectionStyle>) {
|
|
2767
|
+
// this._selectionStyle = style;
|
|
2768
|
+
// }
|
|
2763
2769
|
get selectionModel() {
|
|
2764
2770
|
return this._selectionModel;
|
|
2765
2771
|
}
|
|
@@ -2779,7 +2785,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2779
2785
|
return this._currentStyle;
|
|
2780
2786
|
}
|
|
2781
2787
|
set currentStyle(style) {
|
|
2782
|
-
this._currentStyle = style;
|
|
2788
|
+
style && (this._currentStyle = style);
|
|
2783
2789
|
}
|
|
2784
2790
|
get isHelperSelection() {
|
|
2785
2791
|
return this._isHelperSelection;
|
|
@@ -2802,109 +2808,25 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2802
2808
|
refreshSelectionFilled(val) {
|
|
2803
2809
|
this._selectionFilled$.next(val);
|
|
2804
2810
|
}
|
|
2805
|
-
updateStyle(style) {
|
|
2806
|
-
this._updateControl(style, this._rowHeaderWidth, this._columnHeaderHeight);
|
|
2807
|
-
}
|
|
2808
|
-
updateRange(range) {
|
|
2809
|
-
this._selectionModel.setValue(range), this._updateControl(null, this._rowHeaderWidth, this._columnHeaderHeight);
|
|
2810
|
-
}
|
|
2811
|
-
/**
|
|
2812
|
-
* update seleciton model(new range)
|
|
2813
|
-
* @param newSelectionRange update new selection range!!
|
|
2814
|
-
* @param rowHeaderWidth
|
|
2815
|
-
* @param columnHeaderHeight
|
|
2816
|
-
* @param style
|
|
2817
|
-
* @param highlight
|
|
2818
|
-
*/
|
|
2819
|
-
update(newSelectionRange, rowHeaderWidth = 0, columnHeaderHeight = 0, style, highlight) {
|
|
2820
|
-
this._selectionModel.setValue(newSelectionRange, highlight), style == null && (style = this._selectionStyle), this._updateControl(style, rowHeaderWidth, columnHeaderHeight);
|
|
2821
|
-
}
|
|
2822
|
-
updateCurrCell(highlight) {
|
|
2823
|
-
this._selectionModel.setCurrentCell(highlight);
|
|
2824
|
-
}
|
|
2825
|
-
clearHighlight() {
|
|
2826
|
-
this._selectionModel.clearCurrentCell(), this._updateControl(this._selectionStyle, this._rowHeaderWidth, this._columnHeaderHeight);
|
|
2827
|
-
}
|
|
2828
|
-
getScene() {
|
|
2829
|
-
return this._scene;
|
|
2830
|
-
}
|
|
2831
|
-
dispose() {
|
|
2832
|
-
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;
|
|
2833
|
-
(_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();
|
|
2834
|
-
}
|
|
2835
|
-
/**
|
|
2836
|
-
* Get the cell information of the current selection, considering the case of merging cells
|
|
2837
|
-
*/
|
|
2838
|
-
getCurrentCellInfo() {
|
|
2839
|
-
const currentCell = this.model.currentCell;
|
|
2840
|
-
if (currentCell) {
|
|
2841
|
-
let currentRangeData;
|
|
2842
|
-
if (currentCell.isMerged) {
|
|
2843
|
-
const mergeInfo = currentCell.mergeInfo;
|
|
2844
|
-
currentRangeData = {
|
|
2845
|
-
startRow: mergeInfo.startRow,
|
|
2846
|
-
endRow: mergeInfo.endRow,
|
|
2847
|
-
startColumn: mergeInfo.startColumn,
|
|
2848
|
-
endColumn: mergeInfo.endColumn,
|
|
2849
|
-
startX: mergeInfo.startX,
|
|
2850
|
-
endX: mergeInfo.endX,
|
|
2851
|
-
startY: mergeInfo.startY,
|
|
2852
|
-
endY: mergeInfo.endY
|
|
2853
|
-
};
|
|
2854
|
-
} else {
|
|
2855
|
-
const { actualRow, actualColumn, startX, endX, startY, endY } = currentCell;
|
|
2856
|
-
currentRangeData = {
|
|
2857
|
-
startRow: actualRow,
|
|
2858
|
-
endRow: actualRow,
|
|
2859
|
-
startColumn: actualColumn,
|
|
2860
|
-
endColumn: actualColumn,
|
|
2861
|
-
startX,
|
|
2862
|
-
endX,
|
|
2863
|
-
startY,
|
|
2864
|
-
endY
|
|
2865
|
-
};
|
|
2866
|
-
}
|
|
2867
|
-
return currentRangeData;
|
|
2868
|
-
}
|
|
2869
|
-
}
|
|
2870
|
-
getValue() {
|
|
2871
|
-
return {
|
|
2872
|
-
...this._selectionModel.getValue(),
|
|
2873
|
-
style: this._selectionStyle
|
|
2874
|
-
};
|
|
2875
|
-
}
|
|
2876
|
-
getRange() {
|
|
2877
|
-
return this._selectionModel.getValue().rangeWithCoord;
|
|
2878
|
-
}
|
|
2879
|
-
enableHelperSelection() {
|
|
2880
|
-
this._isHelperSelection = !0;
|
|
2881
|
-
}
|
|
2882
|
-
disableHelperSelection() {
|
|
2883
|
-
this._isHelperSelection = !1;
|
|
2884
|
-
}
|
|
2885
|
-
updateStyleId(id) {
|
|
2886
|
-
this._selectionStyle != null && (this._selectionStyle.id = id);
|
|
2887
|
-
}
|
|
2888
2811
|
/**
|
|
2889
|
-
* invoked when update selection style & range change
|
|
2812
|
+
* invoked when update selection style & range change, invoked by updateStyle, updateRange, update
|
|
2890
2813
|
*/
|
|
2891
2814
|
// eslint-disable-next-line max-lines-per-function
|
|
2892
|
-
|
|
2893
|
-
|
|
2894
|
-
|
|
2895
|
-
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, {
|
|
2896
2818
|
stroke = defaultStyle.stroke,
|
|
2897
2819
|
widgets = defaultStyle.widgets,
|
|
2898
2820
|
hasAutoFill = defaultStyle.hasAutoFill,
|
|
2899
2821
|
AutofillStroke = defaultStyle.AutofillStroke,
|
|
2900
2822
|
strokeDash,
|
|
2901
2823
|
isAnimationDash
|
|
2902
|
-
} =
|
|
2824
|
+
} = currentStyle;
|
|
2903
2825
|
let {
|
|
2904
2826
|
strokeWidth = defaultStyle.strokeWidth,
|
|
2905
2827
|
AutofillSize = defaultStyle.AutofillSize,
|
|
2906
2828
|
AutofillStrokeWidth = defaultStyle.AutofillStrokeWidth
|
|
2907
|
-
} =
|
|
2829
|
+
} = currentStyle;
|
|
2908
2830
|
const scale = this._getScale(), leftAdjustWidth = (strokeWidth + SELECTION_CONTROL_BORDER_BUFFER_WIDTH) / 2 / scale;
|
|
2909
2831
|
strokeWidth /= scale, AutofillSize /= scale, AutofillStrokeWidth /= scale < 1 ? 1 : scale;
|
|
2910
2832
|
const borderBuffer = SELECTION_CONTROL_BORDER_BUFFER_WIDTH / scale, fixOnePixelBlurOffset = FIX_ONE_PIXEL_BLUR_OFFSET / scale;
|
|
@@ -2947,7 +2869,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2947
2869
|
}), strokeDash == null)
|
|
2948
2870
|
this.dashRect.hide(), this._stopAntLineAnimation();
|
|
2949
2871
|
else {
|
|
2950
|
-
const dashRectBorderWidth =
|
|
2872
|
+
const dashRectBorderWidth = currentStyle.strokeWidth * 2 / scale;
|
|
2951
2873
|
this.dashRect.transformByState({
|
|
2952
2874
|
height: endY - startY,
|
|
2953
2875
|
width: endX - startX,
|
|
@@ -2973,11 +2895,103 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2973
2895
|
this.fillControl.setProps(fillProps), this.fillControl.transformByState(sizeState), this.fillControl.show();
|
|
2974
2896
|
} else
|
|
2975
2897
|
this.fillControl.hide();
|
|
2976
|
-
this._updateBackgroundControl(
|
|
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;
|
|
2977
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
|
+
// }
|
|
2978
2992
|
// eslint-disable-next-line max-lines-per-function
|
|
2979
2993
|
_initialize() {
|
|
2980
|
-
this._defaultStyle = getNormalSelectionStyle(this._themeService), this._selectionModel = new SelectionRenderModel();
|
|
2994
|
+
this._defaultStyle = getNormalSelectionStyle(this._themeService), this._currentStyle = getNormalSelectionStyle(this._themeService), this._selectionModel = new SelectionRenderModel();
|
|
2981
2995
|
const zIndex = this._zIndex;
|
|
2982
2996
|
this._leftControl = new Rect("__SpreadsheetSelectionShapeLeftControl__" + zIndex, {
|
|
2983
2997
|
zIndex
|
|
@@ -3023,7 +3037,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
3023
3037
|
scene.addObject(this._selectionShapeGroup, SHEET_COMPONENT_SELECTION_LAYER_INDEX), this.disposeWithMe(
|
|
3024
3038
|
toDisposable(
|
|
3025
3039
|
scene.onTransformChange$.subscribeEvent((state) => {
|
|
3026
|
-
state.type === TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale && this.
|
|
3040
|
+
state.type === TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale && this._updateControlStyleAndLayout(this._currentStyle, this._rowHeaderWidth, this._columnHeaderHeight);
|
|
3027
3041
|
})
|
|
3028
3042
|
)
|
|
3029
3043
|
), this._initialTitle();
|
|
@@ -3317,6 +3331,10 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3317
3331
|
endColumn
|
|
3318
3332
|
}, this._control.selectionMoving$.next(this._targetSelection);
|
|
3319
3333
|
}
|
|
3334
|
+
/**
|
|
3335
|
+
* Drag move whole selectionControl when cusor turns to crosshair. Not for dragging 8 control points.
|
|
3336
|
+
* @param evt
|
|
3337
|
+
*/
|
|
3320
3338
|
_controlEvent(evt) {
|
|
3321
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(
|
|
3322
3340
|
newEvtOffsetX,
|
|
@@ -3334,13 +3352,13 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3334
3352
|
} = this._control.model;
|
|
3335
3353
|
let fixRow = 0, fixColumn = 0;
|
|
3336
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;
|
|
3337
|
-
const style = this._control.
|
|
3355
|
+
const style = this._control.currentStyle, scale = this._getScale();
|
|
3338
3356
|
this.isHelperSelection && (this._helperSelection = new Rect(HELPER_SELECTION_TEMP_NAME, {
|
|
3339
3357
|
stroke: style.stroke,
|
|
3340
3358
|
strokeWidth: style.strokeWidth / scale
|
|
3341
3359
|
}), scene.addObject(this._helperSelection));
|
|
3342
3360
|
const viewMain = scene.getViewport(SHEET_VIEWPORT_KEY$1.VIEW_MAIN), scrollTimer = ScrollTimer.create(scene);
|
|
3343
|
-
scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY, viewMain),
|
|
3361
|
+
this._scrollTimer = scrollTimer, scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY, viewMain), scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
|
|
3344
3362
|
var _a59;
|
|
3345
3363
|
const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt;
|
|
3346
3364
|
if (((_a59 = this._injector.get(ISheetSelectionRenderService, Quantity.OPTIONAL)) == null ? void 0 : _a59.interceptor.fetchThroughInterceptors(RANGE_MOVE_PERMISSION_CHECK)(!1, null)) === !1)
|
|
@@ -3393,10 +3411,45 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3393
3411
|
}), control.onPointerLeave$.subscribeEvent(() => {
|
|
3394
3412
|
control.resetCursor();
|
|
3395
3413
|
}), control.onPointerDown$.subscribeEvent((evt) => {
|
|
3396
|
-
this.
|
|
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);
|
|
3397
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);
|
|
3398
3445
|
});
|
|
3399
3446
|
}
|
|
3447
|
+
/**
|
|
3448
|
+
* Pointer move Events for 8 control point.
|
|
3449
|
+
* @param moveOffsetX
|
|
3450
|
+
* @param moveOffsetY
|
|
3451
|
+
* @param cursor
|
|
3452
|
+
*/
|
|
3400
3453
|
_widgetMoving(moveOffsetX, moveOffsetY, cursor) {
|
|
3401
3454
|
const scene = this._scene, scrollXY = scene.getVpScrollXYInfoByPosToVp(Vector2.FromArray([this._startOffsetX, this._startOffsetY])), { scaleX, scaleY } = scene.getAncestorScale(), moveActualSelection = this._skeleton.getCellPositionByOffset(
|
|
3402
3455
|
moveOffsetX,
|
|
@@ -3422,36 +3475,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3422
3475
|
endRow,
|
|
3423
3476
|
startColumn,
|
|
3424
3477
|
endColumn
|
|
3425
|
-
}, this._control.update(this._targetSelection, rowHeaderWidth, columnHeaderHeight, this._control.
|
|
3426
|
-
}
|
|
3427
|
-
/**
|
|
3428
|
-
* Events for 8 control point
|
|
3429
|
-
* @param evt
|
|
3430
|
-
* @param cursor
|
|
3431
|
-
*/
|
|
3432
|
-
_widgetEvent(evt, cursor) {
|
|
3433
|
-
const { offsetX: evtOffsetX, offsetY: evtOffsetY } = evt, scene = this._scene, relativeCoords = scene.getRelativeToViewportCoord(Vector2.FromArray([evtOffsetX, evtOffsetY])), { x: newEvtOffsetX, y: newEvtOffsetY } = relativeCoords;
|
|
3434
|
-
this._startOffsetX = evtOffsetX, this._startOffsetY = evtOffsetY;
|
|
3435
|
-
const {
|
|
3436
|
-
startRow: originStartRow,
|
|
3437
|
-
startColumn: originStartColumn,
|
|
3438
|
-
endRow: originEndRow,
|
|
3439
|
-
endColumn: originEndColumn
|
|
3440
|
-
} = this._control.model;
|
|
3441
|
-
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);
|
|
3442
|
-
const scrollTimer = ScrollTimer.create(scene);
|
|
3443
|
-
scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY), this._scrollTimer = scrollTimer, scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
|
|
3444
|
-
const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt, { x: newMoveOffsetX, y: newMoveOffsetY } = scene.getRelativeToViewportCoord(
|
|
3445
|
-
Vector2.FromArray([moveOffsetX, moveOffsetY])
|
|
3446
|
-
);
|
|
3447
|
-
this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor), scene.setCursor(cursor), scrollTimer.scrolling(newMoveOffsetX, newMoveOffsetY, () => {
|
|
3448
|
-
this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor);
|
|
3449
|
-
});
|
|
3450
|
-
}), this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent(() => {
|
|
3451
|
-
var _a59, _b, _c;
|
|
3452
|
-
const scene2 = this._scene;
|
|
3453
|
-
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);
|
|
3454
|
-
});
|
|
3478
|
+
}, this._control.update(this._targetSelection, rowHeaderWidth, columnHeaderHeight, this._control.currentStyle), this._control.clearHighlight(), this._control.selectionScaling$.next(this._targetSelection);
|
|
3455
3479
|
}
|
|
3456
3480
|
_initialFill() {
|
|
3457
3481
|
const { fillControl } = this._control;
|
|
@@ -3461,6 +3485,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3461
3485
|
fillControl.resetCursor();
|
|
3462
3486
|
}), fillControl.onPointerDown$.subscribeEvent(this._fillEvent.bind(this));
|
|
3463
3487
|
}
|
|
3488
|
+
// eslint-disable-next-line complexity
|
|
3464
3489
|
_fillMoving(moveOffsetX, moveOffsetY) {
|
|
3465
3490
|
var _a59, _b, _c;
|
|
3466
3491
|
const scene = this._scene, scrollXY = scene.getViewportScrollXY(this._activeViewport), { scaleX, scaleY } = scene.getAncestorScale(), moveActualSelection = this._skeleton.getCellPositionByOffset(
|
|
@@ -3534,7 +3559,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3534
3559
|
endColumn: originEndColumn
|
|
3535
3560
|
} = this._control.model;
|
|
3536
3561
|
this._isInMergeState = this._hasMergeInRange(originStartRow, originStartColumn, originEndRow, originEndColumn), this._relativeSelectionPositionRow = originStartRow, this._relativeSelectionPositionColumn = originStartColumn, this._relativeSelectionRowLength = originEndRow - originStartRow, this._relativeSelectionColumnLength = originEndColumn - originStartColumn;
|
|
3537
|
-
const style = this._control.
|
|
3562
|
+
const style = this._control.currentStyle;
|
|
3538
3563
|
let stroke = style == null ? void 0 : style.stroke, strokeWidth = style == null ? void 0 : style.strokeWidth;
|
|
3539
3564
|
const defaultStyle = getNormalSelectionStyle(this._themeService);
|
|
3540
3565
|
stroke == null && (stroke = defaultStyle.stroke), strokeWidth == null && (strokeWidth = defaultStyle.strokeWidth);
|
|
@@ -3721,7 +3746,7 @@ function attachPrimaryWithCoord(primary, skeleton) {
|
|
|
3721
3746
|
}
|
|
3722
3747
|
__name(attachPrimaryWithCoord, "attachPrimaryWithCoord");
|
|
3723
3748
|
const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-render-service"), _BaseSelectionRenderService = class _BaseSelectionRenderService extends Disposable {
|
|
3724
|
-
constructor(_injector, _themeService, _shortcutService,
|
|
3749
|
+
constructor(_injector, _themeService, _shortcutService, _sheetSkeletonManagerService) {
|
|
3725
3750
|
super();
|
|
3726
3751
|
__publicField(this, "_downObserver");
|
|
3727
3752
|
__publicField(this, "_scenePointerMoveSub");
|
|
@@ -3767,11 +3792,6 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3767
3792
|
__publicField(this, "_singleSelectionEnabled", !1);
|
|
3768
3793
|
// #endregion
|
|
3769
3794
|
__publicField(this, "_selectionMoveEnd$", new BehaviorSubject([]));
|
|
3770
|
-
/**
|
|
3771
|
-
* trigger when selection move end(pointerup)
|
|
3772
|
-
* and then update selection model in selectionManagerService
|
|
3773
|
-
* selectionMoveEnd$ ---> _updateSelections --> selectionOperation@selectionManagerService.setSelections
|
|
3774
|
-
*/
|
|
3775
3795
|
__publicField(this, "selectionMoveEnd$", this._selectionMoveEnd$.asObservable());
|
|
3776
3796
|
__publicField(this, "_selectionMoving$", new Subject());
|
|
3777
3797
|
__publicField(this, "selectionMoving$", this._selectionMoving$.asObservable());
|
|
@@ -3780,7 +3800,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3780
3800
|
__publicField(this, "_selectionMoving", !1);
|
|
3781
3801
|
__publicField(this, "_activeViewport");
|
|
3782
3802
|
__publicField(this, "interceptor", new InterceptorManager({ RANGE_MOVE_PERMISSION_CHECK, RANGE_FILL_PERMISSION_CHECK }));
|
|
3783
|
-
this._injector = _injector, this._themeService = _themeService, this._shortcutService = _shortcutService, this.
|
|
3803
|
+
this._injector = _injector, this._themeService = _themeService, this._shortcutService = _shortcutService, this._sheetSkeletonManagerService = _sheetSkeletonManagerService, this._resetSelectionStyle(), this._initMoving();
|
|
3784
3804
|
}
|
|
3785
3805
|
get selectionMoving() {
|
|
3786
3806
|
return this._selectionMoving;
|
|
@@ -3792,11 +3812,14 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3792
3812
|
this._selectionMoving = !1;
|
|
3793
3813
|
}));
|
|
3794
3814
|
}
|
|
3795
|
-
|
|
3815
|
+
_setSelectionStyle(style) {
|
|
3796
3816
|
this._selectionStyle = style;
|
|
3797
3817
|
}
|
|
3798
|
-
|
|
3799
|
-
|
|
3818
|
+
/**
|
|
3819
|
+
* Reset this._selectionStyle to default normal selection style
|
|
3820
|
+
*/
|
|
3821
|
+
_resetSelectionStyle() {
|
|
3822
|
+
this._setSelectionStyle(getNormalSelectionStyle(this._themeService));
|
|
3800
3823
|
}
|
|
3801
3824
|
/** @deprecated This should not be provided by the selection render service. */
|
|
3802
3825
|
getViewPort() {
|
|
@@ -3806,37 +3829,15 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3806
3829
|
this._singleSelectionEnabled = enabled;
|
|
3807
3830
|
}
|
|
3808
3831
|
/**
|
|
3809
|
-
*
|
|
3810
|
-
*
|
|
3811
|
-
* in PC:init & pointerup would call this function.
|
|
3812
|
-
*
|
|
3813
|
-
* init
|
|
3814
|
-
* selectionController@_initSkeletonChangeListener --> selectionManagerService.add --> selectionManagerService._selectionMoveEnd$ --> this.addControlToCurrentByRangeData
|
|
3815
|
-
*
|
|
3816
|
-
* selectionMoveEnd$ --> this.addSelectionControlBySelectionData
|
|
3817
|
-
*
|
|
3818
|
-
*
|
|
3819
|
-
*
|
|
3820
|
-
* pointer
|
|
3821
|
-
* engine@_pointerDownEvent --> spreadsheet?.onPointerDownObserve --> eventTrigger --> scene@disableEvent() --> then scene.input-manager currentObject is always scene until scene@enableEvent.
|
|
3822
|
-
* engine@_pointerUpEvent --> scene.input-manager@_onPointerUp --> this._selectionMoveEnd$ --> _selectionManagerService.selectionMoveEnd$ --> this.addControlToCurrentByRangeData
|
|
3823
|
-
*
|
|
3824
|
-
* but in mobile, we do not call disableEvent() in eventTrigger,
|
|
3825
|
-
* so pointerup --> scene.input-manager currentObject is spreadsheet --> this.eventTrigger
|
|
3826
|
-
*
|
|
3827
|
-
*
|
|
3828
|
-
* columnHeader pointerup$ --> selectionMoveEnd$ --> selectionManagerService@setSelections -->
|
|
3829
|
-
* selectionManagerService@_emitOnEnd -->
|
|
3830
|
-
* _workbookSelections.selectionMoveEnd$ --> _addSelectionControlBySelectionData
|
|
3831
|
-
*
|
|
3832
|
-
* @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
|
|
3833
3834
|
*/
|
|
3834
3835
|
_addSelectionControlBySelectionData(selection) {
|
|
3835
3836
|
var _a59;
|
|
3836
|
-
const
|
|
3837
|
+
const skeleton = this._skeleton, style = (_a59 = selection.style) != null ? _a59 : getNormalSelectionStyle(this._themeService), scene = this._scene;
|
|
3837
3838
|
if (!scene || !skeleton)
|
|
3838
3839
|
return;
|
|
3839
|
-
const control = this.newSelectionControl(scene, rangeType || RANGE_TYPE.NORMAL);
|
|
3840
|
+
const { rangeWithCoord, primaryWithCoord } = selection, { rangeType } = rangeWithCoord, control = this.newSelectionControl(scene, rangeType || RANGE_TYPE.NORMAL);
|
|
3840
3841
|
new SelectionShapeExtension(control, skeleton, scene, this._themeService, this._injector, {
|
|
3841
3842
|
selectionMoveEnd: /* @__PURE__ */ __name(() => {
|
|
3842
3843
|
this._selectionMoveEnd$.next(this.getSelectionDataWithStyle());
|
|
@@ -3851,21 +3852,16 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3851
3852
|
}
|
|
3852
3853
|
/**
|
|
3853
3854
|
* Update the corresponding selectionControl based on selectionsData.
|
|
3854
|
-
* selectionData[i]
|
|
3855
|
+
* selectionData[i] syncs selectionControls[i]
|
|
3855
3856
|
* @param selections
|
|
3856
3857
|
*/
|
|
3857
3858
|
updateControlForCurrentByRangeData(selections) {
|
|
3858
3859
|
const selectionControls = this.getSelectionControls();
|
|
3859
|
-
if (!selectionControls)
|
|
3860
|
-
|
|
3861
|
-
|
|
3862
|
-
|
|
3863
|
-
|
|
3864
|
-
const { rowHeaderWidth, columnHeaderHeight } = skeleton;
|
|
3865
|
-
for (let i = 0, len = selections.length; i < len; i++) {
|
|
3866
|
-
const { rangeWithCoord, primaryWithCoord, style } = selections[i], control = selectionControls[i];
|
|
3867
|
-
control && control.update(rangeWithCoord, rowHeaderWidth, columnHeaderHeight, style, primaryWithCoord);
|
|
3868
|
-
}
|
|
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
|
+
}
|
|
3869
3865
|
}
|
|
3870
3866
|
refreshSelectionMoveStart() {
|
|
3871
3867
|
this._selectionMoveStart$.next(this.getSelectionDataWithStyle());
|
|
@@ -3876,6 +3872,10 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3876
3872
|
getSkeleton() {
|
|
3877
3873
|
return this._skeleton;
|
|
3878
3874
|
}
|
|
3875
|
+
/**
|
|
3876
|
+
* Generate selectionData from this._selectionControls.model .
|
|
3877
|
+
* @returns {ISelectionWithCoordAndStyle[]} {range, primary, style}[]
|
|
3878
|
+
*/
|
|
3879
3879
|
getSelectionDataWithStyle() {
|
|
3880
3880
|
const selectionControls = this._selectionControls, [unitId, sheetId] = this._skeleton.getLocation();
|
|
3881
3881
|
return selectionControls.map((control) => {
|
|
@@ -3893,8 +3893,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3893
3893
|
this._selectionControls.length = 0;
|
|
3894
3894
|
}
|
|
3895
3895
|
_getFreeze() {
|
|
3896
|
-
var _a59
|
|
3897
|
-
return (
|
|
3896
|
+
var _a59;
|
|
3897
|
+
return (_a59 = this._sheetSkeletonManagerService.getCurrent()) == null ? void 0 : _a59.skeleton.getWorksheetConfig().freeze;
|
|
3898
3898
|
}
|
|
3899
3899
|
_getViewportByCell(row, column) {
|
|
3900
3900
|
if (row === void 0 || column === void 0)
|
|
@@ -3967,7 +3967,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3967
3967
|
let { x: viewportPosX, y: viewportPosY } = relativeCoords;
|
|
3968
3968
|
this._startViewportPosX = viewportPosX, this._startViewportPosY = viewportPosY;
|
|
3969
3969
|
const scrollXY = scene.getVpScrollXYInfoByPosToVp(relativeCoords), { scaleX, scaleY } = scene.getAncestorScale(), cursorCellRangeInfo = this._getCellRangeByCursorPosition(viewportPosX, viewportPosY, scaleX, scaleY, scrollXY);
|
|
3970
|
-
if (!cursorCellRangeInfo) return
|
|
3970
|
+
if (!cursorCellRangeInfo) return;
|
|
3971
3971
|
const { rangeWithCoord: cursorCellRange, primaryWithCoord: primaryCursorCellRange } = cursorCellRangeInfo, cursorCellRangeWithRangeType = { ...cursorCellRange, rangeType };
|
|
3972
3972
|
this._startRangeWhenPointerDown = { ...cursorCellRange, rangeType };
|
|
3973
3973
|
let activeSelectionControl = this.getActiveSelectionControl();
|
|
@@ -3992,18 +3992,27 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3992
3992
|
rangeType,
|
|
3993
3993
|
activeSelectionControl
|
|
3994
3994
|
// Get updated in this method
|
|
3995
|
-
) : remainLastEnable && activeSelectionControl ? this.
|
|
3995
|
+
) : remainLastEnable && activeSelectionControl ? this._updateSelectionControlByRange(
|
|
3996
3996
|
activeSelectionControl,
|
|
3997
3997
|
cursorCellRangeWithRangeType,
|
|
3998
3998
|
primaryCursorCellRange
|
|
3999
|
-
) : (activeSelectionControl = this.newSelectionControl(scene, rangeType), this.
|
|
3999
|
+
) : (activeSelectionControl = this.newSelectionControl(scene, rangeType), this._updateSelectionControlByRange(
|
|
4000
4000
|
activeSelectionControl,
|
|
4001
4001
|
cursorCellRangeWithRangeType,
|
|
4002
4002
|
primaryCursorCellRange
|
|
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.
|
|
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(() => {
|
|
4004
4004
|
this._clearUpdatingListeners(), this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()), this._shortcutService.setDisable(!1);
|
|
4005
4005
|
});
|
|
4006
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
|
+
*/
|
|
4007
4016
|
// eslint-disable-next-line max-lines-per-function
|
|
4008
4017
|
_setupPointerMoveListener(viewportMain, activeSelectionControl, rangeType, scrollTimerType = ScrollTimerType.ALL, moveStartPosX, moveStartPosY) {
|
|
4009
4018
|
var _a59, _b;
|
|
@@ -4013,7 +4022,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4013
4022
|
this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
|
|
4014
4023
|
var _a60, _b2, _c, _d, _e, _f, _g, _h, _i;
|
|
4015
4024
|
const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt, { x: newMoveOffsetX, y: newMoveOffsetY } = scene.getRelativeToViewportCoord(Vector2.FromArray([moveOffsetX, moveOffsetY]));
|
|
4016
|
-
this.
|
|
4025
|
+
this._movingHandler(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
|
|
4017
4026
|
let scrollOffsetX = newMoveOffsetX, scrollOffsetY = newMoveOffsetY;
|
|
4018
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);
|
|
4019
4028
|
if (startViewport && endViewport && viewportMain) {
|
|
@@ -4047,7 +4056,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4047
4056
|
lastX = newMoveOffsetX, lastY = newMoveOffsetY;
|
|
4048
4057
|
}
|
|
4049
4058
|
this._scrollTimer.scrolling(scrollOffsetX, scrollOffsetY, () => {
|
|
4050
|
-
this.
|
|
4059
|
+
this._movingHandler(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
|
|
4051
4060
|
});
|
|
4052
4061
|
});
|
|
4053
4062
|
}
|
|
@@ -4072,8 +4081,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4072
4081
|
/**
|
|
4073
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
|
|
4074
4083
|
*/
|
|
4075
|
-
// eslint-disable-next-line max-lines-per-function
|
|
4076
|
-
|
|
4084
|
+
// eslint-disable-next-line max-lines-per-function, complexity
|
|
4085
|
+
_movingHandler(offsetX, offsetY, activeSelectionControl, rangeType) {
|
|
4077
4086
|
var _a59, _b, _c, _d, _e;
|
|
4078
4087
|
const skeleton = this._skeleton, scene = this._scene, [unitId, sheetId] = skeleton.getLocation(), currSelectionRange = {
|
|
4079
4088
|
startRow: (_a59 = activeSelectionControl == null ? void 0 : activeSelectionControl.model.startRow) != null ? _a59 : -1,
|
|
@@ -4111,11 +4120,16 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4111
4120
|
startX: (startCellXY == null ? void 0 : startCellXY.startX) || 0,
|
|
4112
4121
|
endX: (endCellXY == null ? void 0 : endCellXY.endX) || 0
|
|
4113
4122
|
}, rangeChanged = currSelectionRange.startRow !== newSelectionRange.startRow || currSelectionRange.startColumn !== newSelectionRange.startColumn || currSelectionRange.endRow !== newSelectionRange.endRow || currSelectionRange.endColumn !== newSelectionRange.endColumn;
|
|
4114
|
-
activeSelectionControl != null && rangeChanged && (this.
|
|
4123
|
+
activeSelectionControl != null && rangeChanged && (this._updateSelectionControlByRange(activeSelectionControl, newSelectionRangeWithCoord), this._selectionMoving$.next(this.getSelectionDataWithStyle()));
|
|
4115
4124
|
}
|
|
4116
|
-
|
|
4117
|
-
|
|
4118
|
-
|
|
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);
|
|
4119
4133
|
}
|
|
4120
4134
|
_clearUpdatingListeners() {
|
|
4121
4135
|
var _a59, _b, _c, _d, _e;
|
|
@@ -4196,8 +4210,12 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4196
4210
|
startX: activeCell.mergeInfo.startX || 0,
|
|
4197
4211
|
endX: activeCell.mergeInfo.endX || 0,
|
|
4198
4212
|
rangeType
|
|
4199
|
-
}, this.
|
|
4213
|
+
}, this._updateSelectionControlByRange(activeControl, newSelectionRange, currentCell);
|
|
4200
4214
|
}
|
|
4215
|
+
/**
|
|
4216
|
+
* Reset all this.selectionControls by selectionsData.
|
|
4217
|
+
* @param selectionsData
|
|
4218
|
+
*/
|
|
4201
4219
|
_refreshSelectionControl(selectionsData) {
|
|
4202
4220
|
const selections = selectionsData.map((selectionWithStyle) => {
|
|
4203
4221
|
const selectionData = attachSelectionWithCoord(selectionWithStyle, this._skeleton);
|
|
@@ -4509,6 +4527,10 @@ let SheetsZoomRenderController = (_a8 = class extends Disposable {
|
|
|
4509
4527
|
this._updateViewZoom(zoomRatio);
|
|
4510
4528
|
}));
|
|
4511
4529
|
}
|
|
4530
|
+
/**
|
|
4531
|
+
* Zoom scene, resize viewport and then setScrollInfo
|
|
4532
|
+
* @param zoomRatio
|
|
4533
|
+
*/
|
|
4512
4534
|
_updateViewZoom(zoomRatio) {
|
|
4513
4535
|
const sheetObject = this._getSheetObject();
|
|
4514
4536
|
sheetObject == null || sheetObject.scene.scale(zoomRatio, zoomRatio), sheetObject == null || sheetObject.spreadsheet.makeForceDirty();
|
|
@@ -9004,7 +9026,7 @@ const SHEET_CLIPBOARD_PRIORITY = 998, SheetCopyCommand = {
|
|
|
9004
9026
|
value: PREDEFINED_HOOK_NAME.SPECIAL_PASTE_BESIDES_BORDER
|
|
9005
9027
|
}), "handler")
|
|
9006
9028
|
};
|
|
9007
|
-
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 || {});
|
|
9008
9030
|
function FormatPainterMenuItemFactory(accessor) {
|
|
9009
9031
|
const formatPainterService = accessor.get(IFormatPainterService);
|
|
9010
9032
|
return {
|
|
@@ -11065,8 +11087,10 @@ const SINGLE_MODE_WIDTH = 800, ROW_COUNT_THRESHOLD = 3, StatusBar = /* @__PURE__
|
|
|
11065
11087
|
sheetContainer
|
|
11066
11088
|
};
|
|
11067
11089
|
function RenderSheetFooter() {
|
|
11068
|
-
|
|
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: [
|
|
11069
11092
|
/* @__PURE__ */ jsxRuntimeExports.jsx(SheetBar, {}),
|
|
11093
|
+
footerMenus.map((item) => /* @__PURE__ */ jsxRuntimeExports.jsx(ToolbarItem, { ...item }, item.id)),
|
|
11070
11094
|
/* @__PURE__ */ jsxRuntimeExports.jsx(StatusBar, {}),
|
|
11071
11095
|
/* @__PURE__ */ jsxRuntimeExports.jsx(CountBar, {})
|
|
11072
11096
|
] }) : null;
|
|
@@ -11085,7 +11109,11 @@ function RenderSheetContent() {
|
|
|
11085
11109
|
__name(RenderSheetContent, "RenderSheetContent");
|
|
11086
11110
|
function useHasWorkbook() {
|
|
11087
11111
|
const univerInstanceService = useDependency(IUniverInstanceService), workbook = useObservable(() => univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET), null, !1, []);
|
|
11088
|
-
return useMemo(
|
|
11112
|
+
return useMemo(
|
|
11113
|
+
() => univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).length > 0,
|
|
11114
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
11115
|
+
[univerInstanceService, workbook]
|
|
11116
|
+
);
|
|
11089
11117
|
}
|
|
11090
11118
|
__name(useHasWorkbook, "useHasWorkbook");
|
|
11091
11119
|
const widthStyle = {
|
|
@@ -11217,7 +11245,7 @@ const widthStyle = {
|
|
|
11217
11245
|
const unitId = workbook.getUnitId(), getDefinedNameMap = /* @__PURE__ */ __name(() => {
|
|
11218
11246
|
const definedNameMap = definedNamesService.getDefinedNameMap(unitId);
|
|
11219
11247
|
return definedNameMap ? Array.from(Object.values(definedNameMap)) : [];
|
|
11220
|
-
}, "getDefinedNameMap"), [
|
|
11248
|
+
}, "getDefinedNameMap"), [editState2, setEditState] = useState(!1), [definedNames, setDefinedNames] = useState(getDefinedNameMap()), [editorKey, setEditorKey] = useState(null), [deleteConformKey, setDeleteConformKey] = useState();
|
|
11221
11249
|
useEffect(() => {
|
|
11222
11250
|
const definedNamesSubscription = definedNamesService.update$.subscribe(() => {
|
|
11223
11251
|
setDefinedNames(getDefinedNameMap());
|
|
@@ -11280,11 +11308,11 @@ const widthStyle = {
|
|
|
11280
11308
|
}, "getSheetNameBySheetId");
|
|
11281
11309
|
return /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$h.definedNameContainer, children: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$h.definedNameContainerScroll, children: [
|
|
11282
11310
|
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
|
|
11283
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: openInsertCloseKeyEditor, className: styles$h.definedNameContainerAddButton, style: { display:
|
|
11311
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: openInsertCloseKeyEditor, className: styles$h.definedNameContainerAddButton, style: { display: editState2 ? "none" : "flex" }, children: [
|
|
11284
11312
|
/* @__PURE__ */ jsxRuntimeExports.jsx(IncreaseSingle, {}),
|
|
11285
11313
|
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$h.definedNameContainerAddButtonText, children: localeService.t("definedName.addButton") })
|
|
11286
11314
|
] }),
|
|
11287
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(DefinedNameInput, { confirm: insertConfirm, cancel: closeInput, state:
|
|
11315
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(DefinedNameInput, { confirm: insertConfirm, cancel: closeInput, state: editState2, inputId: "insertDefinedName", name: getInsertDefinedName(), formulaOrRefString: getInertFormulaOrRefString() })
|
|
11288
11316
|
] }, "insertDefinedName"),
|
|
11289
11317
|
definedNames.map((definedName2, index) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
|
|
11290
11318
|
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: /* @__PURE__ */ __name(() => {
|
|
@@ -11334,20 +11362,27 @@ const DEFAULT_RANGE_RULE = {
|
|
|
11334
11362
|
unitId: "",
|
|
11335
11363
|
subUnitId: "",
|
|
11336
11364
|
permissionId: "",
|
|
11337
|
-
unitType:
|
|
11365
|
+
unitType: M.Unkonwn,
|
|
11338
11366
|
id: "",
|
|
11339
11367
|
ranges: []
|
|
11340
11368
|
};
|
|
11341
|
-
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;
|
|
11342
11370
|
let SheetPermissionPanelModel = (_a14 = class {
|
|
11343
11371
|
constructor() {
|
|
11344
11372
|
__publicField(this, "_rule", DEFAULT_RANGE_RULE);
|
|
11345
11373
|
__publicField(this, "_rule$", new BehaviorSubject(this._rule));
|
|
11346
11374
|
__publicField(this, "_oldRule");
|
|
11347
11375
|
__publicField(this, "_rangeErrorMsg$", new BehaviorSubject(""));
|
|
11376
|
+
__publicField(this, "_visible", !1);
|
|
11348
11377
|
__publicField(this, "rangeErrorMsg$", this._rangeErrorMsg$.asObservable());
|
|
11349
11378
|
__publicField(this, "rule$", this._rule$.asObservable());
|
|
11350
11379
|
}
|
|
11380
|
+
setVisible(v) {
|
|
11381
|
+
this._visible = v;
|
|
11382
|
+
}
|
|
11383
|
+
getVisible() {
|
|
11384
|
+
return this._visible;
|
|
11385
|
+
}
|
|
11351
11386
|
setRangeErrorMsg(msg) {
|
|
11352
11387
|
this._rangeErrorMsg$.next(msg);
|
|
11353
11388
|
}
|
|
@@ -11360,6 +11395,9 @@ let SheetPermissionPanelModel = (_a14 = class {
|
|
|
11360
11395
|
resetRule() {
|
|
11361
11396
|
this._rule = DEFAULT_RANGE_RULE, this._rule$.next(this._rule);
|
|
11362
11397
|
}
|
|
11398
|
+
reset() {
|
|
11399
|
+
this.setVisible(!1), this.resetRule(), this.setRangeErrorMsg(""), this.setOldRule(null);
|
|
11400
|
+
}
|
|
11363
11401
|
get oldRule() {
|
|
11364
11402
|
return this._oldRule;
|
|
11365
11403
|
}
|
|
@@ -11391,6 +11429,9 @@ const _SheetPermissionUserManagerService = class _SheetPermissionUserManagerServ
|
|
|
11391
11429
|
setUserList(userList) {
|
|
11392
11430
|
this._userList = userList;
|
|
11393
11431
|
}
|
|
11432
|
+
reset() {
|
|
11433
|
+
this._userList = [], this._oldCollaboratorList = [], this._selectUserList = [], this._selectUserList$.next([]), this._allUserList = [];
|
|
11434
|
+
}
|
|
11394
11435
|
get oldCollaboratorList() {
|
|
11395
11436
|
return this._oldCollaboratorList;
|
|
11396
11437
|
}
|
|
@@ -11407,36 +11448,36 @@ const _SheetPermissionUserManagerService = class _SheetPermissionUserManagerServ
|
|
|
11407
11448
|
__name(_SheetPermissionUserManagerService, "SheetPermissionUserManagerService");
|
|
11408
11449
|
let SheetPermissionUserManagerService = _SheetPermissionUserManagerService;
|
|
11409
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 = {
|
|
11410
|
-
[
|
|
11411
|
-
[
|
|
11412
|
-
[
|
|
11413
|
-
[
|
|
11414
|
-
[
|
|
11415
|
-
[
|
|
11416
|
-
[
|
|
11417
|
-
[
|
|
11418
|
-
[
|
|
11419
|
-
[
|
|
11420
|
-
[
|
|
11421
|
-
[
|
|
11422
|
-
[
|
|
11423
|
-
[
|
|
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"
|
|
11424
11465
|
}, defaultWorksheetUnitActionList = [
|
|
11425
|
-
|
|
11426
|
-
|
|
11427
|
-
|
|
11428
|
-
|
|
11429
|
-
|
|
11430
|
-
|
|
11431
|
-
|
|
11432
|
-
|
|
11433
|
-
|
|
11434
|
-
|
|
11435
|
-
|
|
11436
|
-
|
|
11437
|
-
|
|
11438
|
-
|
|
11439
|
-
|
|
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
|
|
11440
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 = {
|
|
11441
11482
|
type: CommandType.OPERATION,
|
|
11442
11483
|
id: "sheet-permission.operation.openPanel",
|
|
@@ -11454,10 +11495,10 @@ const UNIVER_SHEET_PERMISSION_PANEL = "UNIVER_SHEET_PERMISSION_PANEL", UNIVER_SH
|
|
|
11454
11495
|
showDetail
|
|
11455
11496
|
},
|
|
11456
11497
|
onClose: /* @__PURE__ */ __name(() => {
|
|
11457
|
-
sheetPermissionPanelModel.
|
|
11498
|
+
sheetPermissionPanelModel.reset(), sheetPermissionUserManagerService.reset();
|
|
11458
11499
|
}, "onClose")
|
|
11459
11500
|
};
|
|
11460
|
-
return sidebarService.open(sidebarProps), !0;
|
|
11501
|
+
return sheetPermissionPanelModel.setVisible(!0), sidebarService.open(sidebarProps), !0;
|
|
11461
11502
|
}
|
|
11462
11503
|
}, SheetPermissionOpenDialogOperation = {
|
|
11463
11504
|
type: CommandType.OPERATION,
|
|
@@ -11749,7 +11790,7 @@ const UNIVER_SHEET_PERMISSION_PANEL = "UNIVER_SHEET_PERMISSION_PANEL", UNIVER_SH
|
|
|
11749
11790
|
if (!params)
|
|
11750
11791
|
return !1;
|
|
11751
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;
|
|
11752
|
-
return (oldRule == null ? void 0 : oldRule.unitType) === rule.unitType ? rule.unitType ===
|
|
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({
|
|
11753
11794
|
unitID: unitId,
|
|
11754
11795
|
undoMutations,
|
|
11755
11796
|
redoMutations
|
|
@@ -12818,9 +12859,10 @@ function getRemovePermissionDisable$(accessor) {
|
|
|
12818
12859
|
var _a59;
|
|
12819
12860
|
if (!worksheet)
|
|
12820
12861
|
return of(!0);
|
|
12821
|
-
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(
|
|
12822
12863
|
selectionProtectionRuleModel.ruleChange$,
|
|
12823
|
-
worksheetProtectionRuleModel.ruleChange
|
|
12864
|
+
worksheetProtectionRuleModel.ruleChange$,
|
|
12865
|
+
sheetSelectionsService.selectionMoveEnd$
|
|
12824
12866
|
).pipe(startWith(null));
|
|
12825
12867
|
return combineLatest([changes$, permission$]).pipe(
|
|
12826
12868
|
map(([_2, permission]) => {
|
|
@@ -13239,16 +13281,16 @@ var __defProp$F = Object.defineProperty, __getOwnPropDesc$F = Object.getOwnPrope
|
|
|
13239
13281
|
return kind && result && __defProp$F(target, key, result), result;
|
|
13240
13282
|
}, "__decorateClass$F"), __decorateParam$F = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$F"), _a16;
|
|
13241
13283
|
let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderService {
|
|
13242
|
-
constructor(_context, injector, themeService, shortcutService,
|
|
13284
|
+
constructor(_context, injector, themeService, shortcutService, selectionManagerService, sheetSkeletonManagerService, _logService, _commandService, _contextService) {
|
|
13243
13285
|
super(
|
|
13244
13286
|
injector,
|
|
13245
13287
|
themeService,
|
|
13246
13288
|
shortcutService,
|
|
13247
|
-
|
|
13289
|
+
sheetSkeletonManagerService
|
|
13248
13290
|
);
|
|
13249
13291
|
__publicField(this, "_workbookSelections");
|
|
13250
13292
|
__publicField(this, "_renderDisposable", null);
|
|
13251
|
-
this._context = _context, this.
|
|
13293
|
+
this._context = _context, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this._workbookSelections = selectionManagerService.getWorkbookSelections(this._context.unitId), this._init();
|
|
13252
13294
|
}
|
|
13253
13295
|
_init() {
|
|
13254
13296
|
const sheetObject = this._getSheetObject();
|
|
@@ -13277,9 +13319,9 @@ let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderServi
|
|
|
13277
13319
|
}
|
|
13278
13320
|
_initThemeChangeListener() {
|
|
13279
13321
|
this.disposeWithMe(this._themeService.currentTheme$.subscribe(() => {
|
|
13280
|
-
this.
|
|
13281
|
-
const
|
|
13282
|
-
|
|
13322
|
+
this._resetSelectionStyle();
|
|
13323
|
+
const selections = this._workbookSelections.getCurrentSelections();
|
|
13324
|
+
selections && this._refreshSelectionControl(selections);
|
|
13283
13325
|
}));
|
|
13284
13326
|
}
|
|
13285
13327
|
_normalSelectionDisabled() {
|
|
@@ -13303,8 +13345,7 @@ let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderServi
|
|
|
13303
13345
|
}));
|
|
13304
13346
|
}
|
|
13305
13347
|
/**
|
|
13306
|
-
*
|
|
13307
|
-
* selectionMoveEnd$ ---> _updateSelections --> selectionOperation@selectionManagerService.setSelections
|
|
13348
|
+
* Update selectionData to current sheet.
|
|
13308
13349
|
* @param selectionDataWithStyleList
|
|
13309
13350
|
* @param type
|
|
13310
13351
|
*/
|
|
@@ -13349,12 +13390,11 @@ SheetSelectionRenderService = __decorateClass$F([
|
|
|
13349
13390
|
__decorateParam$F(1, Inject(Injector)),
|
|
13350
13391
|
__decorateParam$F(2, Inject(ThemeService)),
|
|
13351
13392
|
__decorateParam$F(3, IShortcutService),
|
|
13352
|
-
__decorateParam$F(4,
|
|
13353
|
-
__decorateParam$F(5, Inject(
|
|
13393
|
+
__decorateParam$F(4, Inject(SheetsSelectionsService)),
|
|
13394
|
+
__decorateParam$F(5, Inject(SheetSkeletonManagerService)),
|
|
13354
13395
|
__decorateParam$F(6, ILogService),
|
|
13355
13396
|
__decorateParam$F(7, ICommandService),
|
|
13356
|
-
__decorateParam$F(8, IContextService)
|
|
13357
|
-
__decorateParam$F(9, Inject(SheetSkeletonManagerService))
|
|
13397
|
+
__decorateParam$F(8, IContextService)
|
|
13358
13398
|
], SheetSelectionRenderService);
|
|
13359
13399
|
var __defProp$E = Object.defineProperty, __getOwnPropDesc$E = Object.getOwnPropertyDescriptor, __decorateClass$E = /* @__PURE__ */ __name((decorators, target, key, kind) => {
|
|
13360
13400
|
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$E(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
|
|
@@ -15068,7 +15108,7 @@ let EditingRenderController = (_a21 = class extends Disposable {
|
|
|
15068
15108
|
worksheet.getCellRaw(row, column) || {},
|
|
15069
15109
|
documentLayoutObject,
|
|
15070
15110
|
this._lexerTreeBuilder,
|
|
15071
|
-
(model) => this._resourceLoaderService.
|
|
15111
|
+
(model) => this._resourceLoaderService.saveUnit(model.getUnitId()),
|
|
15072
15112
|
this._localService,
|
|
15073
15113
|
this._functionService
|
|
15074
15114
|
);
|
|
@@ -16508,8 +16548,10 @@ const HEADER_MENU_SHAPE_RECT_BACKGROUND_FILL = "rgba(120, 120, 120, 0.01)", HEAD
|
|
|
16508
16548
|
return this._color;
|
|
16509
16549
|
}
|
|
16510
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;
|
|
16511
16554
|
let { width, height } = this, left = 0, top = 0;
|
|
16512
|
-
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;
|
|
16513
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, {
|
|
16514
16556
|
width: this.width,
|
|
16515
16557
|
height: this.height,
|
|
@@ -17127,7 +17169,7 @@ let SheetRenderController = (_a30 = class extends RxDisposable {
|
|
|
17127
17169
|
if (!worksheet)
|
|
17128
17170
|
throw new Error("No active sheet found");
|
|
17129
17171
|
const sheetId = worksheet.getSheetId();
|
|
17130
|
-
this._sheetSkeletonManagerService.setCurrent({ sheetId }),
|
|
17172
|
+
this._sheetSkeletonManagerService.setCurrent({ sheetId }), engine.runRenderLoop(() => scene.render());
|
|
17131
17173
|
}
|
|
17132
17174
|
_addComponent(workbook) {
|
|
17133
17175
|
const { scene, components } = this._context, worksheet = workbook.getActiveSheet();
|
|
@@ -18440,7 +18482,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18440
18482
|
if (!target)
|
|
18441
18483
|
return !1;
|
|
18442
18484
|
const { worksheet, unitId, subUnitId } = target, selectionRange = (_a59 = this._selectionManagerService.getCurrentLastSelection()) == null ? void 0 : _a59.range;
|
|
18443
|
-
return !(!selectionRange || (direction === "top"
|
|
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))));
|
|
18444
18486
|
}
|
|
18445
18487
|
_permissionCheckByWorksheetCommand(types) {
|
|
18446
18488
|
var _a59, _b;
|
|
@@ -18542,7 +18584,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18542
18584
|
for (let row = range.startRow; row <= range.endRow; row++)
|
|
18543
18585
|
for (let col = range.startColumn; col <= range.endColumn; col++) {
|
|
18544
18586
|
const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
|
|
18545
|
-
if ((permission == null ? void 0 : permission[
|
|
18587
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
18546
18588
|
return !1;
|
|
18547
18589
|
}
|
|
18548
18590
|
}), !0);
|
|
@@ -18559,7 +18601,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18559
18601
|
for (let row = range.startRow; row <= range.endRow; row++)
|
|
18560
18602
|
for (let col = range.startColumn; col <= range.endColumn; col++) {
|
|
18561
18603
|
const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
|
|
18562
|
-
if ((permission == null ? void 0 : permission[
|
|
18604
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
18563
18605
|
return !0;
|
|
18564
18606
|
}
|
|
18565
18607
|
return !1;
|
|
@@ -18575,7 +18617,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18575
18617
|
for (let row = range.startRow; row <= range.endRow; row++)
|
|
18576
18618
|
for (let col = range.startColumn; col <= range.endColumn; col++) {
|
|
18577
18619
|
const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
|
|
18578
|
-
if ((permission == null ? void 0 : permission[
|
|
18620
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
18579
18621
|
return !1;
|
|
18580
18622
|
}
|
|
18581
18623
|
}), !0);
|
|
@@ -18600,12 +18642,12 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18600
18642
|
if (sequenceGrid.sheetName) {
|
|
18601
18643
|
const targetSheet = workbook.getSheetBySheetName(sequenceGrid.sheetName);
|
|
18602
18644
|
if (!targetSheet)
|
|
18603
|
-
return !
|
|
18645
|
+
return !0;
|
|
18604
18646
|
const { startRow, endRow, startColumn, endColumn } = sequenceGrid.range;
|
|
18605
18647
|
for (let i2 = startRow; i2 <= endRow; i2++)
|
|
18606
18648
|
for (let j = startColumn; j <= endColumn; j++) {
|
|
18607
18649
|
const permission = (_c = (_b = targetSheet.getCell(i2, j)) == null ? void 0 : _b.selectionProtection) == null ? void 0 : _c[0];
|
|
18608
|
-
if ((permission == null ? void 0 : permission[
|
|
18650
|
+
if ((permission == null ? void 0 : permission[L.View]) === !1)
|
|
18609
18651
|
return !1;
|
|
18610
18652
|
}
|
|
18611
18653
|
}
|
|
@@ -18617,7 +18659,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18617
18659
|
return !0;
|
|
18618
18660
|
for (let i = 0; i < sequenceNodes.length; i++) {
|
|
18619
18661
|
const node = sequenceNodes[i];
|
|
18620
|
-
if (typeof node == "string")
|
|
18662
|
+
if (typeof node == "string" || node.nodeType !== sequenceNodeType.REFERENCE)
|
|
18621
18663
|
continue;
|
|
18622
18664
|
const { token } = node, sequenceGrid = deserializeRangeWithSheet(token), workbook2 = sequenceGrid.unitId ? this._univerInstanceService.getUnit(sequenceGrid.unitId) : this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
|
|
18623
18665
|
if (!workbook2) return !0;
|
|
@@ -18635,10 +18677,11 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18635
18677
|
for (let i2 = startRow; i2 <= endRow; i2++)
|
|
18636
18678
|
for (let j = startColumn; j <= endColumn; j++) {
|
|
18637
18679
|
const permission = (_e = (_d = targetSheet.getCell(i2, j)) == null ? void 0 : _d.selectionProtection) == null ? void 0 : _e[0];
|
|
18638
|
-
if ((permission == null ? void 0 : permission[
|
|
18680
|
+
if ((permission == null ? void 0 : permission[L.View]) === !1)
|
|
18639
18681
|
return !1;
|
|
18640
18682
|
}
|
|
18641
18683
|
}
|
|
18684
|
+
return !0;
|
|
18642
18685
|
}
|
|
18643
18686
|
}
|
|
18644
18687
|
if (range) {
|
|
@@ -18702,7 +18745,7 @@ let SheetPermissionInterceptorClipboardController = (_a44 = class extends Dispos
|
|
|
18702
18745
|
for (let row = startRow; row <= endRow; row++)
|
|
18703
18746
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
18704
18747
|
const permission = (_c = (_b = worksheet.getCell(row, col)) == null ? void 0 : _b.selectionProtection) == null ? void 0 : _c[0];
|
|
18705
|
-
if ((permission == null ? void 0 : permission[
|
|
18748
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1) {
|
|
18706
18749
|
hasPermission = !1;
|
|
18707
18750
|
break;
|
|
18708
18751
|
}
|
|
@@ -18727,8 +18770,8 @@ var __defProp$c = Object.defineProperty, __getOwnPropDesc$c = Object.getOwnPrope
|
|
|
18727
18770
|
return kind && result && __defProp$c(target, key, result), result;
|
|
18728
18771
|
}, "__decorateClass$c"), __decorateParam$c = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$c"), _a45;
|
|
18729
18772
|
let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
18730
|
-
constructor(_univerInstanceService, _dialogService, _permissionService, _authzIoService, _rangeProtectionRuleModel, _worksheetProtectionRuleModel, _userManagerService, _worksheetProtectionPointRuleModel, _sheetInterceptorService, _selectionProtectionRenderModel) {
|
|
18731
|
-
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._initWorkbookPermissionFromSnapshot(), 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();
|
|
18732
18775
|
}
|
|
18733
18776
|
_initRangePermissionFromSnapshot() {
|
|
18734
18777
|
const initRangePermissionFunc = /* @__PURE__ */ __name((workbook) => {
|
|
@@ -18739,8 +18782,8 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18739
18782
|
permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
|
|
18740
18783
|
objectID: rule.permissionId,
|
|
18741
18784
|
unitID: unitId,
|
|
18742
|
-
objectType:
|
|
18743
|
-
actions: [
|
|
18785
|
+
objectType: M.SelectRange,
|
|
18786
|
+
actions: [L.View, L.Edit]
|
|
18744
18787
|
});
|
|
18745
18788
|
});
|
|
18746
18789
|
}), allAllowedParams.length && this._authzIoService.batchAllowed(allAllowedParams).then((permissionMap) => {
|
|
@@ -18763,8 +18806,8 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18763
18806
|
info.type !== "delete" ? this._authzIoService.allowed({
|
|
18764
18807
|
objectID: info.rule.permissionId,
|
|
18765
18808
|
unitID: info.unitId,
|
|
18766
|
-
objectType:
|
|
18767
|
-
actions: [
|
|
18809
|
+
objectType: M.SelectRange,
|
|
18810
|
+
actions: [L.Edit, L.View]
|
|
18768
18811
|
}).then((actionList) => {
|
|
18769
18812
|
getAllRangePermissionPoint().forEach((F) => {
|
|
18770
18813
|
if (info.type === "set") {
|
|
@@ -18787,7 +18830,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18787
18830
|
const unitId = _unitId || ((_a59 = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET)) == null ? void 0 : _a59.getUnitId());
|
|
18788
18831
|
unitId && this._authzIoService.allowed({
|
|
18789
18832
|
objectID: unitId,
|
|
18790
|
-
objectType:
|
|
18833
|
+
objectType: M.Workbook,
|
|
18791
18834
|
unitID: unitId,
|
|
18792
18835
|
actions: defaultWorkbookPermissionPoints
|
|
18793
18836
|
}).then((actionList) => {
|
|
@@ -18808,8 +18851,8 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18808
18851
|
info.type !== "delete" ? this._authzIoService.allowed({
|
|
18809
18852
|
objectID: info.rule.permissionId,
|
|
18810
18853
|
unitID: info.unitId,
|
|
18811
|
-
objectType:
|
|
18812
|
-
actions: [
|
|
18854
|
+
objectType: M.Worksheet,
|
|
18855
|
+
actions: [L.Edit, L.View]
|
|
18813
18856
|
}).then((actionList) => {
|
|
18814
18857
|
getAllWorksheetPermissionPoint().forEach((F) => {
|
|
18815
18858
|
const instance = new F(info.unitId, info.subUnitId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
|
|
@@ -18828,7 +18871,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18828
18871
|
this._authzIoService.allowed({
|
|
18829
18872
|
objectID: info.permissionId,
|
|
18830
18873
|
unitID: info.unitId,
|
|
18831
|
-
objectType:
|
|
18874
|
+
objectType: M.Worksheet,
|
|
18832
18875
|
actions: defaultWorksheetPermissionPoint
|
|
18833
18876
|
}).then((actionList) => {
|
|
18834
18877
|
getAllWorksheetPermissionPointByPointPanel().forEach((F) => {
|
|
@@ -18847,14 +18890,14 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18847
18890
|
rule && (permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
|
|
18848
18891
|
objectID: rule.permissionId,
|
|
18849
18892
|
unitID: unitId,
|
|
18850
|
-
objectType:
|
|
18851
|
-
actions: [
|
|
18893
|
+
objectType: M.Worksheet,
|
|
18894
|
+
actions: [L.Edit, L.View]
|
|
18852
18895
|
}));
|
|
18853
18896
|
const pointRule = this._worksheetProtectionPointRuleModel.getRule(unitId, subUnitId);
|
|
18854
18897
|
pointRule && (permissionIdWithRuleInstanceMap.set(pointRule.permissionId, pointRule), allAllowedParams.push({
|
|
18855
18898
|
objectID: pointRule.permissionId,
|
|
18856
18899
|
unitID: unitId,
|
|
18857
|
-
objectType:
|
|
18900
|
+
objectType: M.Worksheet,
|
|
18858
18901
|
actions: defaultWorksheetPermissionPoint
|
|
18859
18902
|
}));
|
|
18860
18903
|
}), allAllowedParams.length && this._authzIoService.batchAllowed(allAllowedParams).then((permissionMap) => {
|
|
@@ -18911,7 +18954,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18911
18954
|
};
|
|
18912
18955
|
}).filter((p2) => !!p2.ranges);
|
|
18913
18956
|
if (permissionList.length) {
|
|
18914
|
-
const isSkipRender = permissionList.some((p2) => !(p2 != null && p2[
|
|
18957
|
+
const isSkipRender = permissionList.some((p2) => !(p2 != null && p2[L.View])), _cellData = { ...cell, selectionProtection: permissionList };
|
|
18915
18958
|
return isSkipRender ? (delete _cellData.s, delete _cellData.v, delete _cellData.p, _cellData) : next(_cellData);
|
|
18916
18959
|
}
|
|
18917
18960
|
return next(cell);
|
|
@@ -18928,11 +18971,11 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18928
18971
|
handler: /* @__PURE__ */ __name((cell = {}, context, next) => {
|
|
18929
18972
|
var _a59, _b, _c, _d, _e;
|
|
18930
18973
|
const { unitId, subUnitId } = context, worksheetRule = this._worksheetProtectionRuleModel.getRule(unitId, subUnitId);
|
|
18931
|
-
if (worksheetRule != null && worksheetRule.permissionId
|
|
18974
|
+
if (worksheetRule != null && worksheetRule.permissionId) {
|
|
18932
18975
|
const selectionProtection = [{
|
|
18933
|
-
[
|
|
18934
|
-
[
|
|
18935
|
-
}], isSkipRender = !((_e = selectionProtection[0]) != null && _e[
|
|
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 };
|
|
18936
18979
|
return isSkipRender ? (delete _cellData.s, delete _cellData.v, delete _cellData.p, _cellData) : next(_cellData);
|
|
18937
18980
|
}
|
|
18938
18981
|
return next(cell);
|
|
@@ -18940,6 +18983,59 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18940
18983
|
}
|
|
18941
18984
|
));
|
|
18942
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
|
+
}
|
|
18943
19039
|
}, __name(_a45, "SheetPermissionInitController"), _a45);
|
|
18944
19040
|
SheetPermissionInitController = __decorateClass$c([
|
|
18945
19041
|
OnLifecycle(LifecycleStages.Rendered, SheetPermissionInitController),
|
|
@@ -18952,18 +19048,232 @@ SheetPermissionInitController = __decorateClass$c([
|
|
|
18952
19048
|
__decorateParam$c(6, Inject(UserManagerService)),
|
|
18953
19049
|
__decorateParam$c(7, Inject(WorksheetProtectionPointModel)),
|
|
18954
19050
|
__decorateParam$c(8, Inject(SheetInterceptorService)),
|
|
18955
|
-
__decorateParam$c(9, Inject(RangeProtectionRenderModel))
|
|
19051
|
+
__decorateParam$c(9, Inject(RangeProtectionRenderModel)),
|
|
19052
|
+
__decorateParam$c(10, Inject(IUndoRedoService))
|
|
18956
19053
|
], SheetPermissionInitController);
|
|
18957
|
-
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 = {
|
|
18958
19268
|
spinContainer,
|
|
18959
19269
|
spinOverlay,
|
|
18960
19270
|
spinner,
|
|
18961
19271
|
spin,
|
|
18962
19272
|
contentBlur
|
|
18963
|
-
}, Spin = /* @__PURE__ */ __name(({ loading, children }) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
18964
|
-
loading && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
18965
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: loading ? styles$
|
|
18966
|
-
] }), "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$
|
|
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 = {
|
|
18967
19277
|
permissionPanelDetailWrapper,
|
|
18968
19278
|
radioGroupVertical,
|
|
18969
19279
|
sheetPermissionDesignPersonPanel,
|
|
@@ -18983,8 +19293,8 @@ const UserEmptyBase64 = "
|
|
|
18983
19293
|
permissionRangeSelectorErrorText,
|
|
18984
19294
|
sheetPermissionPanelNameInputErrorText
|
|
18985
19295
|
}, SheetPermissionPanelDetail = /* @__PURE__ */ __name(({ fromSheetBar }) => {
|
|
18986
|
-
var _a59, _b
|
|
18987
|
-
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 ?
|
|
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 () => {
|
|
18988
19298
|
const userList = await authzIoService.listCollaborators({
|
|
18989
19299
|
objectID: unitId,
|
|
18990
19300
|
unitID: unitId
|
|
@@ -19028,7 +19338,7 @@ const UserEmptyBase64 = "
|
|
|
19028
19338
|
return useEffect(() => {
|
|
19029
19339
|
var _a60, _b2;
|
|
19030
19340
|
if (activeRule == null ? void 0 : activeRule.permissionId) {
|
|
19031
|
-
activeRule.unitType ===
|
|
19341
|
+
activeRule.unitType === M.Worksheet && sheetPermissionPanelModel.setRule({
|
|
19032
19342
|
ranges: [{
|
|
19033
19343
|
startRow: 0,
|
|
19034
19344
|
startColumn: 0,
|
|
@@ -19063,22 +19373,53 @@ const UserEmptyBase64 = "
|
|
|
19063
19373
|
name: fromSheetBar ? `${sheetName}` : `${sheetName}(${rangeStr})`,
|
|
19064
19374
|
unitId,
|
|
19065
19375
|
subUnitId,
|
|
19066
|
-
unitType: fromSheetBar ?
|
|
19376
|
+
unitType: fromSheetBar ? M.Worksheet : M.SelectRange
|
|
19067
19377
|
});
|
|
19068
19378
|
}, [activeRule == null ? void 0 : activeRule.permissionId, fromSheetBar, selectionManagerService, sheetPermissionPanelModel, subUnitId, unitId, worksheet]), useEffect(() => {
|
|
19069
19379
|
const getSelectUserList = /* @__PURE__ */ __name(async () => {
|
|
19070
|
-
const permissionId = activeRule == null ? void 0 : activeRule.permissionId
|
|
19071
|
-
setLoading(!0);
|
|
19072
|
-
const collaborators = await authzIoService.listCollaborators({
|
|
19380
|
+
const permissionId = activeRule == null ? void 0 : activeRule.permissionId, selectUserList2 = (await authzIoService.listCollaborators({
|
|
19073
19381
|
objectID: permissionId,
|
|
19074
19382
|
unitID: unitId
|
|
19075
|
-
})
|
|
19076
|
-
sheetPermissionUserManagerService.setSelectUserList(selectUserList2),
|
|
19077
|
-
const readerList = collaborators.filter((user) => user.role === M.Reader);
|
|
19078
|
-
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);
|
|
19079
19385
|
}, "getSelectUserList");
|
|
19080
|
-
activeRule != null && activeRule.permissionId ? getSelectUserList() : (sheetPermissionUserManagerService.setSelectUserList([]),
|
|
19386
|
+
activeRule != null && activeRule.permissionId ? getSelectUserList() : (sheetPermissionUserManagerService.setSelectUserList([]), sheetPermissionUserManagerService.setOldCollaboratorList([]));
|
|
19081
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(() => {
|
|
19082
19423
|
(/* @__PURE__ */ __name(async () => {
|
|
19083
19424
|
const userList = await authzIoService.listCollaborators({
|
|
19084
19425
|
objectID: unitId,
|
|
@@ -19086,13 +19427,9 @@ const UserEmptyBase64 = "
|
|
|
19086
19427
|
});
|
|
19087
19428
|
userList.forEach((user) => {
|
|
19088
19429
|
user != null && user.subject && userManagerService.addUser(user.subject);
|
|
19089
|
-
}), sheetPermissionUserManagerService.setUserList(userList.filter((user) => user.role ===
|
|
19430
|
+
}), sheetPermissionUserManagerService.setUserList(userList.filter((user) => user.role === P.Editor)), sheetPermissionUserManagerService.setAllUserList(userList.filter((user) => user.role === P.Editor || user.role === P.Reader));
|
|
19090
19431
|
}, "getListCollaborators"))();
|
|
19091
19432
|
}, []), useEffect(() => {
|
|
19092
|
-
sheetPermissionPanelModel.setRule({
|
|
19093
|
-
viewStatus: viewGroupValue
|
|
19094
|
-
});
|
|
19095
|
-
}, [sheetPermissionPanelModel, viewGroupValue]), useEffect(() => {
|
|
19096
19433
|
const workbook2 = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
|
|
19097
19434
|
if (!workbook2) return;
|
|
19098
19435
|
const activeSheetSubscribe = workbook2.activeSheet$.subscribe((sheet) => {
|
|
@@ -19101,14 +19438,14 @@ const UserEmptyBase64 = "
|
|
|
19101
19438
|
return () => {
|
|
19102
19439
|
activeSheetSubscribe.unsubscribe();
|
|
19103
19440
|
};
|
|
19104
|
-
}, [sidebarService, subUnitId, univerInstanceService]),
|
|
19105
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs(FormLayout, { className: styles$
|
|
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: [
|
|
19106
19443
|
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19107
19444
|
RangeSelector,
|
|
19108
19445
|
{
|
|
19109
|
-
className: clsx(styles$
|
|
19110
|
-
textEditorClassName: clsx({ [styles$
|
|
19111
|
-
value: (
|
|
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(","),
|
|
19112
19449
|
id: createInternalEditorID("sheet-permission-panel"),
|
|
19113
19450
|
openForSheetUnitId: unitId,
|
|
19114
19451
|
openForSheetSubUnitId: subUnitId,
|
|
@@ -19127,56 +19464,58 @@ const UserEmptyBase64 = "
|
|
|
19127
19464
|
ranges: transformedRange,
|
|
19128
19465
|
unitId: unitId2,
|
|
19129
19466
|
subUnitId: subUnitId2,
|
|
19130
|
-
unitType:
|
|
19467
|
+
unitType: M.SelectRange,
|
|
19131
19468
|
name: `${sheetName}(${rangeStr})`
|
|
19132
19469
|
};
|
|
19133
19470
|
if (rule.ranges.length === 1) {
|
|
19134
19471
|
const { startRow, endRow, startColumn, endColumn } = rule.ranges[0];
|
|
19135
|
-
startRow === 0 && endRow === worksheet2.getRowCount() - 1 && startColumn === 0 && worksheet2.getColumnCount() - 1 === endColumn && (rule.unitType =
|
|
19472
|
+
startRow === 0 && endRow === worksheet2.getRowCount() - 1 && startColumn === 0 && worksheet2.getColumnCount() - 1 === endColumn && (rule.unitType = M.Worksheet, rule.name = `${sheetName}`);
|
|
19136
19473
|
}
|
|
19137
19474
|
sheetPermissionPanelModel.setRule(rule);
|
|
19138
19475
|
}, "onChange")
|
|
19139
19476
|
}
|
|
19140
19477
|
),
|
|
19141
|
-
rangeErrorMsg && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
19478
|
+
rangeErrorMsg && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionPanelNameInputErrorText, children: rangeErrorMsg })
|
|
19142
19479
|
] }),
|
|
19143
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$
|
|
19480
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.permissionDirection"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19144
19481
|
Input,
|
|
19145
19482
|
{
|
|
19146
|
-
value: (
|
|
19483
|
+
value: (_b = activeRule == null ? void 0 : activeRule.description) != null ? _b : "",
|
|
19147
19484
|
onChange: /* @__PURE__ */ __name((v) => sheetPermissionPanelModel.setRule({ description: v }), "onChange"),
|
|
19148
19485
|
placeholder: localeService.t("permission.panel.permissionDirectionPlaceholder")
|
|
19149
19486
|
}
|
|
19150
19487
|
) }),
|
|
19151
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$
|
|
19488
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.editPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19152
19489
|
RadioGroup,
|
|
19153
19490
|
{
|
|
19154
19491
|
value: editorGroupValue,
|
|
19155
19492
|
onChange: /* @__PURE__ */ __name((v) => {
|
|
19156
|
-
setEditorGroupValue(v),
|
|
19493
|
+
setEditorGroupValue(v), sheetPermissionPanelModel.setRule({
|
|
19494
|
+
editStatus: v
|
|
19495
|
+
});
|
|
19157
19496
|
}, "onChange"),
|
|
19158
|
-
className: styles$
|
|
19497
|
+
className: styles$5.radioGroupVertical,
|
|
19159
19498
|
children: [
|
|
19160
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value:
|
|
19161
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value:
|
|
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") }) })
|
|
19162
19501
|
]
|
|
19163
19502
|
}
|
|
19164
19503
|
) }),
|
|
19165
|
-
editorGroupValue === "designedUserCanEdit" && /* @__PURE__ */ jsxRuntimeExports.
|
|
19166
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19504
|
+
editorGroupValue === "designedUserCanEdit" && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanel, children: [
|
|
19505
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanelHeader, children: [
|
|
19167
19506
|
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { children: localeService.t("permission.panel.designedPerson") }),
|
|
19168
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
19507
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionDesignPersonPanelHeaderAdd, onClick: handleAddPerson, children: localeService.t("permission.panel.addPerson") })
|
|
19169
19508
|
] }),
|
|
19170
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19171
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19172
|
-
var _a60, _b2,
|
|
19173
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
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: [
|
|
19174
19513
|
/* @__PURE__ */ jsxRuntimeExports.jsx(Avatar, { size: 24, src: (_a60 = item.subject) == null ? void 0 : _a60.avatar }),
|
|
19175
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
19514
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionDesignPersonPanelContentItemName, children: (_b2 = item.subject) == null ? void 0 : _b2.name }),
|
|
19176
19515
|
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19177
19516
|
Select,
|
|
19178
19517
|
{
|
|
19179
|
-
className: styles$
|
|
19518
|
+
className: styles$5.sheetPermissionDesignPersonPanelContentItemSelect,
|
|
19180
19519
|
value: "edit",
|
|
19181
19520
|
onChange: /* @__PURE__ */ __name((v) => {
|
|
19182
19521
|
v === "delete" && sheetPermissionUserManagerService.setSelectUserList(selectUserList.filter((i) => {
|
|
@@ -19190,234 +19529,38 @@ const UserEmptyBase64 = "
|
|
|
19190
19529
|
]
|
|
19191
19530
|
}
|
|
19192
19531
|
)
|
|
19193
|
-
] }, (
|
|
19194
|
-
}) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19532
|
+
] }, (_c = item.subject) == null ? void 0 : _c.userID);
|
|
19533
|
+
}) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionUserListEmpty, children: [
|
|
19195
19534
|
/* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: UserEmptyBase64, alt: "" }),
|
|
19196
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$
|
|
19535
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$5.sheetPermissionUserListEmptyText, children: localeService.t("permission.dialog.userEmpty") })
|
|
19197
19536
|
] }) })
|
|
19198
|
-
] })
|
|
19199
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$
|
|
19537
|
+
] }),
|
|
19538
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.viewPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19200
19539
|
RadioGroup,
|
|
19201
19540
|
{
|
|
19202
19541
|
value: viewGroupValue,
|
|
19203
|
-
onChange: /* @__PURE__ */ __name((v) =>
|
|
19204
|
-
|
|
19542
|
+
onChange: /* @__PURE__ */ __name((v) => {
|
|
19543
|
+
setViewGroupValue(v), sheetPermissionPanelModel.setRule({
|
|
19544
|
+
viewStatus: v
|
|
19545
|
+
});
|
|
19546
|
+
}, "onChange"),
|
|
19547
|
+
className: styles$5.radioGroupVertical,
|
|
19205
19548
|
children: [
|
|
19206
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.othersCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
19207
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.noOneElseCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
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") }) })
|
|
19208
19551
|
]
|
|
19209
19552
|
}
|
|
19210
19553
|
) })
|
|
19211
|
-
] });
|
|
19212
|
-
}, "SheetPermissionPanelDetail"),
|
|
19213
|
-
|
|
19214
|
-
|
|
19215
|
-
|
|
19216
|
-
|
|
19217
|
-
|
|
19218
|
-
|
|
19219
|
-
|
|
19220
|
-
|
|
19221
|
-
stroke: "#49B811",
|
|
19222
|
-
widgets: {}
|
|
19223
|
-
},
|
|
19224
|
-
primary: {
|
|
19225
|
-
startColumn: range.startColumn,
|
|
19226
|
-
endColumn: range.endColumn,
|
|
19227
|
-
startRow: range.startRow,
|
|
19228
|
-
endRow: range.endRow,
|
|
19229
|
-
actualRow: range.startRow,
|
|
19230
|
-
actualColumn: range.startColumn,
|
|
19231
|
-
isMerged: !1,
|
|
19232
|
-
isMergedMainCell: !1
|
|
19233
|
-
}
|
|
19234
|
-
}));
|
|
19235
|
-
return () => {
|
|
19236
|
-
ids.forEach((id) => {
|
|
19237
|
-
id && markSelectionService.removeShape(id);
|
|
19238
|
-
});
|
|
19239
|
-
};
|
|
19240
|
-
}, [ranges]);
|
|
19241
|
-
}, "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 = {
|
|
19242
|
-
sheetPermissionListPanelWrapper,
|
|
19243
|
-
sheetPermissionListPanelHeader,
|
|
19244
|
-
sheetPermissionListPanelHeaderType,
|
|
19245
|
-
sheetPermissionListPanelHeaderTypeBottom,
|
|
19246
|
-
sheetPermissionListPanelHeaderSelect,
|
|
19247
|
-
sheetPermissionListItemHeaderIcon,
|
|
19248
|
-
sheetPermissionListItem,
|
|
19249
|
-
sheetPermissionListItemHeader,
|
|
19250
|
-
sheetPermissionListItemHeaderName,
|
|
19251
|
-
sheetPermissionListItemHeaderOperator,
|
|
19252
|
-
sheetPermissionListItemSplit,
|
|
19253
|
-
sheetPermissionListItemContentEdit,
|
|
19254
|
-
sheetPermissionListItemContentView,
|
|
19255
|
-
sheetPermissionListItemContentDesc,
|
|
19256
|
-
sheetPermissionListEmpty,
|
|
19257
|
-
sheetPermissionListEmptyText,
|
|
19258
|
-
sheetPermissionListItemContentTitle,
|
|
19259
|
-
sheetPermissionListItemContentSub
|
|
19260
|
-
}, SheetPermissionPanelList = /* @__PURE__ */ __name(() => {
|
|
19261
|
-
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([]);
|
|
19262
|
-
useObservable(worksheetProtectionModel.ruleRefresh$), useObservable(rangeProtectionRuleModel.ruleRefresh$);
|
|
19263
|
-
const getRuleList = useCallback(async (isCurrentSheet2) => {
|
|
19264
|
-
var _a59;
|
|
19265
|
-
const worksheet = workbook.getActiveSheet(), unitId2 = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), allRangePermissionId = [], allSheetPermissionId = [];
|
|
19266
|
-
workbook.getSheets().forEach((sheet) => {
|
|
19267
|
-
const sheetId = sheet.getSheetId();
|
|
19268
|
-
rangeProtectionRuleModel.getSubunitRuleList(unitId2, sheetId).forEach((rule) => {
|
|
19269
|
-
rule.permissionId && rule.name && allRangePermissionId.push(rule.permissionId);
|
|
19270
|
-
});
|
|
19271
|
-
const worksheetPermissionRule = worksheetProtectionModel.getRule(unitId2, sheetId);
|
|
19272
|
-
worksheetPermissionRule != null && worksheetPermissionRule.permissionId && worksheetPermissionRule.name && allSheetPermissionId.push(worksheetPermissionRule.permissionId);
|
|
19273
|
-
});
|
|
19274
|
-
const allPermissionId = [...allRangePermissionId, ...allSheetPermissionId], allPermissionRule = await authzIoService.list({
|
|
19275
|
-
objectIDs: allPermissionId,
|
|
19276
|
-
unitID: unitId2,
|
|
19277
|
-
actions: [P.View, P.Edit]
|
|
19278
|
-
}), subUnitPermissionIds = rangeProtectionRuleModel.getSubunitRuleList(unitId2, subUnitId).map((item) => item.permissionId), sheetPermissionId = (_a59 = worksheetProtectionModel.getRule(unitId2, subUnitId)) == null ? void 0 : _a59.permissionId;
|
|
19279
|
-
sheetPermissionId && subUnitPermissionIds.push(sheetPermissionId);
|
|
19280
|
-
const subUnitRuleList = allPermissionRule.filter((item) => {
|
|
19281
|
-
var _a60;
|
|
19282
|
-
return subUnitPermissionIds.includes(item.objectID) || item.objectID === ((_a60 = worksheetProtectionModel.getRule(unitId2, subUnitId)) == null ? void 0 : _a60.permissionId);
|
|
19283
|
-
});
|
|
19284
|
-
return isCurrentSheet2 ? subUnitRuleList : allPermissionRule;
|
|
19285
|
-
}, []), [ruleList, setRuleList] = useState([]);
|
|
19286
|
-
useEffect(() => {
|
|
19287
|
-
const subscription = merge(
|
|
19288
|
-
rangeProtectionRuleModel.ruleChange$,
|
|
19289
|
-
worksheetProtectionModel.ruleChange$
|
|
19290
|
-
).subscribe(async () => {
|
|
19291
|
-
const ruleList2 = await getRuleList(isCurrentSheet);
|
|
19292
|
-
setRuleList(ruleList2);
|
|
19293
|
-
});
|
|
19294
|
-
return () => {
|
|
19295
|
-
subscription.unsubscribe();
|
|
19296
|
-
};
|
|
19297
|
-
}, [isCurrentSheet]), useEffect(() => {
|
|
19298
|
-
const subscribe = workbook.activeSheet$.subscribe(async () => {
|
|
19299
|
-
const ruleList2 = await getRuleList(!0);
|
|
19300
|
-
setRuleList(ruleList2);
|
|
19301
|
-
});
|
|
19302
|
-
return () => {
|
|
19303
|
-
subscribe.unsubscribe();
|
|
19304
|
-
};
|
|
19305
|
-
}, []);
|
|
19306
|
-
const handleDelete = /* @__PURE__ */ __name((rule) => {
|
|
19307
|
-
const { unitId: unitId2, subUnitId, unitType } = rule;
|
|
19308
|
-
let res;
|
|
19309
|
-
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([]));
|
|
19310
|
-
}, "handleDelete");
|
|
19311
|
-
useHighlightRange(currentRuleRanges);
|
|
19312
|
-
const allRuleMap = /* @__PURE__ */ new Map();
|
|
19313
|
-
workbook.getSheets().forEach((sheet) => {
|
|
19314
|
-
const sheetId = sheet.getSheetId();
|
|
19315
|
-
rangeProtectionRuleModel.getSubunitRuleList(unitId, sheetId).forEach((rule) => {
|
|
19316
|
-
allRuleMap.set(rule.permissionId, rule);
|
|
19317
|
-
});
|
|
19318
|
-
const sheetRule = worksheetProtectionModel.getRule(unitId, sheetId);
|
|
19319
|
-
sheetRule && allRuleMap.set(sheetRule == null ? void 0 : sheetRule.permissionId, sheetRule);
|
|
19320
|
-
});
|
|
19321
|
-
const handleEdit = /* @__PURE__ */ __name((rule) => {
|
|
19322
|
-
sheetPermissionPanelModel.setRule(rule), sheetPermissionPanelModel.setOldRule(rule), commandService.executeCommand(SetWorksheetActiveOperation.id, {
|
|
19323
|
-
unitId: rule.unitId,
|
|
19324
|
-
subUnitId: rule.subUnitId
|
|
19325
|
-
});
|
|
19326
|
-
const sidebarProps = {
|
|
19327
|
-
header: { title: "permission.panel.title" },
|
|
19328
|
-
children: {
|
|
19329
|
-
label: UNIVER_SHEET_PERMISSION_PANEL,
|
|
19330
|
-
showDetail: !0
|
|
19331
|
-
},
|
|
19332
|
-
width: 330,
|
|
19333
|
-
footer: {
|
|
19334
|
-
label: UNIVER_SHEET_PERMISSION_PANEL_FOOTER,
|
|
19335
|
-
showDetail: !0
|
|
19336
|
-
}
|
|
19337
|
-
};
|
|
19338
|
-
sidebarService.open(sidebarProps);
|
|
19339
|
-
}, "handleEdit"), handleChangeHeaderType = /* @__PURE__ */ __name(async (isCurrentSheet2) => {
|
|
19340
|
-
setIsCurrentSheet(isCurrentSheet2);
|
|
19341
|
-
const ruleList2 = await getRuleList(isCurrentSheet2);
|
|
19342
|
-
setRuleList(ruleList2);
|
|
19343
|
-
}, "handleChangeHeaderType");
|
|
19344
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelWrapper, children: [
|
|
19345
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelHeader, children: [
|
|
19346
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!0), "onClick"), children: [
|
|
19347
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$5.sheetPermissionListPanelHeaderSelect]: isCurrentSheet }), children: localeService.t("permission.panel.currentSheet") }),
|
|
19348
|
-
isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListPanelHeaderTypeBottom })
|
|
19349
|
-
] }),
|
|
19350
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!1), "onClick"), children: [
|
|
19351
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$5.sheetPermissionListPanelHeaderSelect]: !isCurrentSheet }), children: localeService.t("permission.panel.allSheet") }),
|
|
19352
|
-
!isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListPanelHeaderTypeBottom })
|
|
19353
|
-
] })
|
|
19354
|
-
] }),
|
|
19355
|
-
(ruleList == null ? void 0 : ruleList.length) > 0 ? /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListPanelContent, children: ruleList == null ? void 0 : ruleList.map((item) => {
|
|
19356
|
-
var _a59, _b, _c, _d, _e;
|
|
19357
|
-
const rule = allRuleMap.get(item.objectID);
|
|
19358
|
-
if (!rule)
|
|
19359
|
-
return null;
|
|
19360
|
-
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);
|
|
19361
|
-
let ruleName = "";
|
|
19362
|
-
const targetSheet = workbook.getSheetBySheetId(rule.subUnitId), targetName = targetSheet == null ? void 0 : targetSheet.getName();
|
|
19363
|
-
if (rule.unitType === l$1.SelectRange) {
|
|
19364
|
-
const ranges = rule.ranges, rangeStr = ranges != null && ranges.length ? ranges.map((range) => {
|
|
19365
|
-
const v = serializeRange(range);
|
|
19366
|
-
return v === "NaN" ? "" : v;
|
|
19367
|
-
}).filter((r) => !!r).join(",") : "";
|
|
19368
|
-
ruleName = `${targetName}(${rangeStr})`;
|
|
19369
|
-
} else rule.unitType === l$1.Worksheet && (ruleName = targetName || "");
|
|
19370
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19371
|
-
"div",
|
|
19372
|
-
{
|
|
19373
|
-
className: styles$5.sheetPermissionListItem,
|
|
19374
|
-
onMouseMove: /* @__PURE__ */ __name(() => {
|
|
19375
|
-
const { subUnitId, unitType } = rule, activeSheet = workbook.getActiveSheet();
|
|
19376
|
-
if (!activeSheet)
|
|
19377
|
-
return !1;
|
|
19378
|
-
const activeSubUnitId = activeSheet.getSheetId();
|
|
19379
|
-
if (subUnitId !== activeSubUnitId)
|
|
19380
|
-
return !1;
|
|
19381
|
-
if (unitType === l$1.SelectRange) {
|
|
19382
|
-
const ranges = rule.ranges || [];
|
|
19383
|
-
ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
|
|
19384
|
-
} else if (unitType === l$1.Worksheet) {
|
|
19385
|
-
const ranges = [{ startRow: 0, endRow: activeSheet.getRowCount() - 1, startColumn: 0, endColumn: activeSheet.getColumnCount() - 1 }];
|
|
19386
|
-
ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
|
|
19387
|
-
}
|
|
19388
|
-
}, "onMouseMove"),
|
|
19389
|
-
onMouseLeave: /* @__PURE__ */ __name(() => currentRuleRangesSet([]), "onMouseLeave"),
|
|
19390
|
-
children: [
|
|
19391
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemHeader, children: [
|
|
19392
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: ruleName, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemHeaderName, children: ruleName }) }),
|
|
19393
|
-
hasManagerPermission && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemHeaderOperator, children: [
|
|
19394
|
-
/* @__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, {}) }) }),
|
|
19395
|
-
/* @__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, {}) }) })
|
|
19396
|
-
] })
|
|
19397
|
-
] }),
|
|
19398
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemSplit }),
|
|
19399
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemContent, children: [
|
|
19400
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemContentEdit, children: [
|
|
19401
|
-
/* @__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 }) }) }),
|
|
19402
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.created") }),
|
|
19403
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentSub, children: editPermission ? `${localeService.t("permission.panel.iCanEdit")}` : `${localeService.t("permission.panel.iCanNotEdit")}` })
|
|
19404
|
-
] }),
|
|
19405
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListItemContentView, children: [
|
|
19406
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.viewPermission") }),
|
|
19407
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionListItemContentSub, children: viewPermission ? `${localeService.t("permission.panel.iCanView")}` : `${localeService.t("permission.panel.iCanNotView")}` })
|
|
19408
|
-
] }),
|
|
19409
|
-
rule.description && /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: rule.description, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionListItemContentDesc, children: rule.description }) })
|
|
19410
|
-
] })
|
|
19411
|
-
]
|
|
19412
|
-
},
|
|
19413
|
-
item.objectID
|
|
19414
|
-
);
|
|
19415
|
-
}) }) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionListEmpty, children: [
|
|
19416
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: panelListEmptyBase64, alt: "" }),
|
|
19417
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$5.sheetPermissionListEmptyText, children: localeService.t("permission.dialog.listEmpty") })
|
|
19418
|
-
] })
|
|
19419
|
-
] });
|
|
19420
|
-
}, "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 = {
|
|
19421
19564
|
sheetPermissionPanelFooter,
|
|
19422
19565
|
sheetPermissionPanelFooterCancel,
|
|
19423
19566
|
sheetPermissionPanelAddButton
|
|
@@ -19463,44 +19606,46 @@ const UserEmptyBase64 = "
|
|
|
19463
19606
|
type: "primary",
|
|
19464
19607
|
onClick: /* @__PURE__ */ __name(async () => {
|
|
19465
19608
|
if (!activeRule.name || rangeErrMsg) return;
|
|
19466
|
-
|
|
19467
|
-
activeRule.
|
|
19468
|
-
|
|
19469
|
-
|
|
19470
|
-
|
|
19471
|
-
|
|
19472
|
-
|
|
19473
|
-
|
|
19474
|
-
|
|
19475
|
-
|
|
19476
|
-
|
|
19477
|
-
if (activeRule.permissionId) {
|
|
19478
|
-
const oldRule = sheetPermissionPanelModel.oldRule;
|
|
19479
|
-
if (activeRule.unitType === (oldRule == null ? void 0 : oldRule.unitType) && activeRule.name === oldRule.name && activeRule.description === oldRule.description && activeRule.ranges === oldRule.ranges && !isSameCollaborators)
|
|
19480
|
-
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,
|
|
19481
19620
|
objectID: activeRule.permissionId,
|
|
19482
19621
|
unitID: activeRule.unitId,
|
|
19483
|
-
|
|
19622
|
+
share: void 0,
|
|
19623
|
+
name: "",
|
|
19624
|
+
strategies: [],
|
|
19625
|
+
scope: scopeObj,
|
|
19626
|
+
collaborators: {
|
|
19627
|
+
collaborators
|
|
19628
|
+
}
|
|
19484
19629
|
});
|
|
19485
19630
|
else {
|
|
19486
19631
|
let newPermissionId = activeRule.permissionId;
|
|
19487
|
-
|
|
19632
|
+
collaboratorsIsChange && (activeRule.unitType === M.Worksheet ? newPermissionId = await authzIoService.create({
|
|
19488
19633
|
worksheetObject: {
|
|
19489
19634
|
collaborators,
|
|
19490
19635
|
unitID: activeRule.unitId,
|
|
19491
19636
|
name: activeRule.name,
|
|
19492
|
-
strategies: [{ role:
|
|
19493
|
-
scope:
|
|
19637
|
+
strategies: [{ role: P.Editor, action: L.Edit }, { role: P.Reader, action: L.View }],
|
|
19638
|
+
scope: scopeObj
|
|
19494
19639
|
},
|
|
19495
|
-
objectType:
|
|
19640
|
+
objectType: M.Worksheet
|
|
19496
19641
|
}) : newPermissionId = await authzIoService.create({
|
|
19497
19642
|
selectRangeObject: {
|
|
19498
19643
|
collaborators,
|
|
19499
19644
|
unitID: activeRule.unitId,
|
|
19500
19645
|
name: activeRule.name,
|
|
19501
|
-
|
|
19646
|
+
scope: scopeObj
|
|
19502
19647
|
},
|
|
19503
|
-
objectType:
|
|
19648
|
+
objectType: M.SelectRange
|
|
19504
19649
|
})), commandService.executeCommand(SetProtectionCommand.id, {
|
|
19505
19650
|
rule: {
|
|
19506
19651
|
...activeRule,
|
|
@@ -19508,37 +19653,37 @@ const UserEmptyBase64 = "
|
|
|
19508
19653
|
}
|
|
19509
19654
|
});
|
|
19510
19655
|
}
|
|
19511
|
-
} else if (activeRule.unitType ===
|
|
19656
|
+
} else if (activeRule.unitType === M.Worksheet) {
|
|
19512
19657
|
const permissionId = await authzIoService.create({
|
|
19513
19658
|
worksheetObject: {
|
|
19514
19659
|
collaborators,
|
|
19515
19660
|
unitID: activeRule.unitId,
|
|
19516
19661
|
name: activeRule.name,
|
|
19517
|
-
strategies: [{ role:
|
|
19518
|
-
scope:
|
|
19662
|
+
strategies: [{ role: P.Editor, action: L.Edit }, { role: P.Reader, action: L.View }],
|
|
19663
|
+
scope: scopeObj
|
|
19519
19664
|
},
|
|
19520
|
-
objectType:
|
|
19665
|
+
objectType: M.Worksheet
|
|
19521
19666
|
}), { ranges: _range = [], ...sheetRule } = activeRule;
|
|
19522
19667
|
sheetRule.permissionId = permissionId, commandService.executeCommand(AddWorksheetProtectionCommand.id, {
|
|
19523
19668
|
rule: sheetRule,
|
|
19524
19669
|
unitId: activeRule.unitId
|
|
19525
19670
|
});
|
|
19526
|
-
} else if (activeRule.unitType ===
|
|
19671
|
+
} else if (activeRule.unitType === M.SelectRange) {
|
|
19527
19672
|
const permissionId = await authzIoService.create({
|
|
19528
19673
|
selectRangeObject: {
|
|
19529
19674
|
collaborators,
|
|
19530
19675
|
unitID: activeRule.unitId,
|
|
19531
19676
|
name: activeRule.name,
|
|
19532
|
-
|
|
19677
|
+
scope: scopeObj
|
|
19533
19678
|
},
|
|
19534
|
-
objectType:
|
|
19679
|
+
objectType: M.SelectRange
|
|
19535
19680
|
});
|
|
19536
19681
|
commandService.executeCommand(AddRangeProtectionCommand$1.id, {
|
|
19537
19682
|
rule: activeRule,
|
|
19538
19683
|
permissionId
|
|
19539
19684
|
});
|
|
19540
19685
|
}
|
|
19541
|
-
sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.
|
|
19686
|
+
sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.reset();
|
|
19542
19687
|
const sidebarProps = {
|
|
19543
19688
|
header: { title: `${localeService.t("permission.panel.title")}` },
|
|
19544
19689
|
children: {
|
|
@@ -19561,7 +19706,7 @@ const UserEmptyBase64 = "
|
|
|
19561
19706
|
{
|
|
19562
19707
|
className: styles$4.sheetPermissionPanelFooterCancel,
|
|
19563
19708
|
onClick: /* @__PURE__ */ __name(() => {
|
|
19564
|
-
sheetPermissionPanelModel.
|
|
19709
|
+
sheetPermissionPanelModel.reset(), sheetPermissionUserManagerService.reset(), sidebarService.close();
|
|
19565
19710
|
}, "onClick"),
|
|
19566
19711
|
children: localeService.t("permission.button.cancel")
|
|
19567
19712
|
}
|
|
@@ -19582,7 +19727,7 @@ const UserEmptyBase64 = "
|
|
|
19582
19727
|
}, SheetPermissionUserDialog = /* @__PURE__ */ __name(() => {
|
|
19583
19728
|
const [inputValue, setInputValue] = React.useState(""), localeService = useDependency(LocaleService), dialogService = useDependency(IDialogService), sheetPermissionUserManagerService = useDependency(SheetPermissionUserManagerService), searchUserList = sheetPermissionUserManagerService.userList.filter((item) => {
|
|
19584
19729
|
var _a59;
|
|
19585
|
-
return ((_a59 = item.subject) == null ? void 0 : _a59.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase())) && item.role ===
|
|
19730
|
+
return ((_a59 = item.subject) == null ? void 0 : _a59.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase())) && item.role === P.Editor;
|
|
19586
19731
|
}), [selectUserInfo, setSelectUserInfo] = useState(sheetPermissionUserManagerService.selectUserList), handleChangeUser = /* @__PURE__ */ __name((item) => {
|
|
19587
19732
|
if ((selectUserInfo == null ? void 0 : selectUserInfo.findIndex((v) => {
|
|
19588
19733
|
var _a59, _b;
|
|
@@ -19673,7 +19818,7 @@ const UserEmptyBase64 = "
|
|
|
19673
19818
|
actions: defaultWorksheetUnitActionList
|
|
19674
19819
|
}))[0].strategies.reduce((p2, c) => (subUnitPermissionTypeMap[c.action] && (p2[c.action] = {
|
|
19675
19820
|
text: localeService.t(`permission.panel.${subUnitPermissionTypeMap[c.action]}`),
|
|
19676
|
-
allowed: c.role !==
|
|
19821
|
+
allowed: c.role !== P.Owner
|
|
19677
19822
|
}), p2), {});
|
|
19678
19823
|
setPermissionMap(actions), setTimeout(() => {
|
|
19679
19824
|
setLoading(!1);
|
|
@@ -19686,29 +19831,37 @@ const UserEmptyBase64 = "
|
|
|
19686
19831
|
throw new Error("No active sheet found");
|
|
19687
19832
|
const unitId = workbook2.getUnitId(), subUnitId = worksheet2.getSheetId(), pointRule = worksheetProtectionPointRuleModel.getRule(unitId, subUnitId), actions = Object.keys(permissionMap).map((action) => ({
|
|
19688
19833
|
action: Number(action),
|
|
19689
|
-
role: permissionMap[action].allowed ?
|
|
19834
|
+
role: permissionMap[action].allowed ? P.Editor : P.Owner
|
|
19690
19835
|
}));
|
|
19691
19836
|
let permissionId = pointRule == null ? void 0 : pointRule.permissionId;
|
|
19692
19837
|
permissionId ? authzIoService.update({
|
|
19693
|
-
objectType:
|
|
19838
|
+
objectType: M.Worksheet,
|
|
19694
19839
|
objectID: permissionId,
|
|
19695
19840
|
unitID: unitId,
|
|
19696
19841
|
strategies: actions,
|
|
19697
19842
|
share: void 0,
|
|
19698
|
-
name: ""
|
|
19843
|
+
name: "",
|
|
19844
|
+
scope: {
|
|
19845
|
+
read: G.AllCollaborator,
|
|
19846
|
+
edit: G.AllCollaborator
|
|
19847
|
+
},
|
|
19848
|
+
collaborators: void 0
|
|
19699
19849
|
}).then(() => {
|
|
19700
19850
|
getAllWorksheetPermissionPoint().forEach((F) => {
|
|
19701
19851
|
const instance = new F(unitId, subUnitId), unitActionName = instance.subType, action = actions.find((item) => item.action === unitActionName);
|
|
19702
|
-
action && permissionService.updatePermissionPoint(instance.id, action.role ===
|
|
19852
|
+
action && permissionService.updatePermissionPoint(instance.id, action.role === P.Editor);
|
|
19703
19853
|
});
|
|
19704
19854
|
}) : (permissionId = await authzIoService.create({
|
|
19705
|
-
objectType:
|
|
19855
|
+
objectType: M.Worksheet,
|
|
19706
19856
|
worksheetObject: {
|
|
19707
19857
|
unitID: unitId,
|
|
19708
19858
|
collaborators,
|
|
19709
19859
|
name: "",
|
|
19710
19860
|
strategies: actions,
|
|
19711
|
-
scope:
|
|
19861
|
+
scope: {
|
|
19862
|
+
read: G.AllCollaborator,
|
|
19863
|
+
edit: G.AllCollaborator
|
|
19864
|
+
}
|
|
19712
19865
|
}
|
|
19713
19866
|
}), commandService.executeCommand(SetWorksheetPermissionPointsCommand.id, {
|
|
19714
19867
|
rule: {
|
|
@@ -19718,7 +19871,7 @@ const UserEmptyBase64 = "
|
|
|
19718
19871
|
}
|
|
19719
19872
|
}));
|
|
19720
19873
|
}, "handleChangeActionPermission");
|
|
19721
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsx(Spin, { loading, children: /* @__PURE__ */ jsxRuntimeExports.
|
|
19874
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsx(Spin, { loading, children: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$2.sheetPermissionDialogWrapper, children: [
|
|
19722
19875
|
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$2.sheetPermissionDialogSplit }),
|
|
19723
19876
|
Object.keys(permissionMap).map((action) => {
|
|
19724
19877
|
const actionItem = permissionMap[action], { text, allowed } = actionItem;
|
|
@@ -19765,7 +19918,7 @@ const UserEmptyBase64 = "
|
|
|
19765
19918
|
}
|
|
19766
19919
|
)
|
|
19767
19920
|
] })
|
|
19768
|
-
] }) })
|
|
19921
|
+
] }) });
|
|
19769
19922
|
}, "SheetPermissionDialog"), sheetPermissionAlertDialog = "univer-sheet-permission-alert-dialog", sheetPermissionAlertDialogTitle = "univer-sheet-permission-alert-dialog-title", sheetPermissionAlertDialogButton = "univer-sheet-permission-alert-dialog-button", styles$1 = {
|
|
19770
19923
|
sheetPermissionAlertDialog,
|
|
19771
19924
|
sheetPermissionAlertDialogTitle,
|
|
@@ -19825,7 +19978,7 @@ const _RangeProtectionCanViewRenderExtension = class _RangeProtectionCanViewRend
|
|
|
19825
19978
|
__publicField(this, "Z_INDEX", EXTENSION_CAN_VIEW_Z_INDEX$1);
|
|
19826
19979
|
}
|
|
19827
19980
|
shouldRender(config) {
|
|
19828
|
-
return (config == null ? void 0 : config[
|
|
19981
|
+
return (config == null ? void 0 : config[L.View]) !== !1;
|
|
19829
19982
|
}
|
|
19830
19983
|
};
|
|
19831
19984
|
__name(_RangeProtectionCanViewRenderExtension, "RangeProtectionCanViewRenderExtension");
|
|
@@ -19837,7 +19990,7 @@ const _RangeProtectionCanNotViewRenderExtension = class _RangeProtectionCanNotVi
|
|
|
19837
19990
|
__publicField(this, "Z_INDEX", EXTENSION_CAN_NOT_VIEW_Z_INDEX$1);
|
|
19838
19991
|
}
|
|
19839
19992
|
shouldRender(config) {
|
|
19840
|
-
return (config == null ? void 0 : config[
|
|
19993
|
+
return (config == null ? void 0 : config[L.View]) === !1;
|
|
19841
19994
|
}
|
|
19842
19995
|
};
|
|
19843
19996
|
__name(_RangeProtectionCanNotViewRenderExtension, "RangeProtectionCanNotViewRenderExtension");
|
|
@@ -19936,7 +20089,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
|
|
|
19936
20089
|
for (let row = startRow; row <= endRow; row++)
|
|
19937
20090
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
19938
20091
|
const permission = (_b = (_a59 = worksheet.getCell(row, col)) == null ? void 0 : _a59.selectionProtection) == null ? void 0 : _b[0];
|
|
19939
|
-
if ((permission == null ? void 0 : permission[
|
|
20092
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
19940
20093
|
return !0;
|
|
19941
20094
|
}
|
|
19942
20095
|
return !1;
|
|
@@ -19980,7 +20133,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
|
|
|
19980
20133
|
for (let row = startRow; row <= endRow; row++)
|
|
19981
20134
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
19982
20135
|
const permission = (_b2 = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b2[0];
|
|
19983
|
-
if ((permission == null ? void 0 : permission[
|
|
20136
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
19984
20137
|
return !0;
|
|
19985
20138
|
}
|
|
19986
20139
|
return !1;
|
|
@@ -20001,7 +20154,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
|
|
|
20001
20154
|
for (let row = startRow; row <= endRow; row++)
|
|
20002
20155
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
20003
20156
|
const permission = (_b2 = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b2[0];
|
|
20004
|
-
if ((permission == null ? void 0 : permission[
|
|
20157
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
20005
20158
|
return !0;
|
|
20006
20159
|
}
|
|
20007
20160
|
return !1;
|
|
@@ -20031,7 +20184,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
|
|
|
20031
20184
|
for (let row = startRow; row <= endRow; row++)
|
|
20032
20185
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
20033
20186
|
const permission = (_c = (_b = worksheet.getCell(row, col)) == null ? void 0 : _b.selectionProtection) == null ? void 0 : _c[0];
|
|
20034
|
-
if ((permission == null ? void 0 : permission[
|
|
20187
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1 || (permission == null ? void 0 : permission[L.View]) === !1)
|
|
20035
20188
|
return !1;
|
|
20036
20189
|
}
|
|
20037
20190
|
return !0;
|
|
@@ -20057,7 +20210,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
|
|
|
20057
20210
|
for (let row = startRow; row <= endRow; row++)
|
|
20058
20211
|
for (let col = startColumn; col <= endColumn; col++) {
|
|
20059
20212
|
const permission = (_b = (_a60 = worksheet.getCell(row, col)) == null ? void 0 : _a60.selectionProtection) == null ? void 0 : _b[0];
|
|
20060
|
-
if ((permission == null ? void 0 : permission[
|
|
20213
|
+
if ((permission == null ? void 0 : permission[L.Edit]) === !1)
|
|
20061
20214
|
return !0;
|
|
20062
20215
|
}
|
|
20063
20216
|
return !1;
|
|
@@ -20125,7 +20278,7 @@ let SheetPermissionInterceptorFormulaRenderController = (_a49 = class extends Rx
|
|
|
20125
20278
|
if (((_a60 = worksheet.getCellRaw(rowIndex + startRow, colIndex + startCol)) == null ? void 0 : _a60.v) === void 0)
|
|
20126
20279
|
return;
|
|
20127
20280
|
const permission = (_b = this._rangeProtectionRenderModel.getCellInfo(unitId, subUnitId, rowIndex + startRow, colIndex + startCol)) == null ? void 0 : _b[0];
|
|
20128
|
-
(permission == null ? void 0 : permission[
|
|
20281
|
+
(permission == null ? void 0 : permission[L.View]) === !1 && (itemValue[rowIndex][colIndex] = NullValueObject.create());
|
|
20129
20282
|
});
|
|
20130
20283
|
});
|
|
20131
20284
|
}), originValue;
|
|
@@ -20160,7 +20313,7 @@ const worksheetProtectionKey = "worksheet-protection", EXTENSION_CAN_VIEW_Z_INDE
|
|
|
20160
20313
|
if (this._pattern) {
|
|
20161
20314
|
if (selectionProtection.length > 0) {
|
|
20162
20315
|
const cellProtectionConfig = selectionProtection[0];
|
|
20163
|
-
(cellProtectionConfig == null ? void 0 : cellProtectionConfig[
|
|
20316
|
+
(cellProtectionConfig == null ? void 0 : cellProtectionConfig[L.View]) ? this.setZIndex(EXTENSION_CAN_VIEW_Z_INDEX) : this.setZIndex(EXTENSION_CAN_NOT_VIEW_Z_INDEX);
|
|
20164
20317
|
}
|
|
20165
20318
|
ctx.fillStyle = this._pattern, hasWorksheetRule && ctx.fillRect(start.startX, start.startY, end.endX - start.startX, end.endY - start.startY), ctx.restore();
|
|
20166
20319
|
}
|
|
@@ -21229,11 +21382,11 @@ const _MobileSelectionControl = class _MobileSelectionControl extends SelectionC
|
|
|
21229
21382
|
(_a59 = this._fillControlBottomRight) == null || _a59.dispose(), (_b = this._fillControlTopLeft) == null || _b.dispose(), super.dispose();
|
|
21230
21383
|
}
|
|
21231
21384
|
updateRange(range) {
|
|
21232
|
-
this._selectionModel.setValue(range), this.
|
|
21385
|
+
this._selectionModel.setValue(range), this._updateControlStyleAndLayout(null, this._rowHeaderWidth, this._columnHeaderHeight);
|
|
21233
21386
|
}
|
|
21234
|
-
|
|
21387
|
+
_updateControlStyleAndLayout(style, rowHeaderWidth, columnHeaderHeight) {
|
|
21235
21388
|
var _a59, _b, _c, _d;
|
|
21236
|
-
super.
|
|
21389
|
+
super._updateControlStyleAndLayout(style, rowHeaderWidth, columnHeaderHeight);
|
|
21237
21390
|
const defaultStyle = this.defaultStyle;
|
|
21238
21391
|
style == null && (style = defaultStyle);
|
|
21239
21392
|
const {
|
|
@@ -21330,12 +21483,12 @@ var __defProp$1 = Object.defineProperty, __getOwnPropDesc$1 = Object.getOwnPrope
|
|
|
21330
21483
|
return kind && result && __defProp$1(target, key, result), result;
|
|
21331
21484
|
}, "__decorateClass$1"), __decorateParam$1 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$1"), _a57;
|
|
21332
21485
|
let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRenderService {
|
|
21333
|
-
constructor(_context, injector, themeService, shortcutService,
|
|
21486
|
+
constructor(_context, injector, themeService, shortcutService, selectionManagerService, sheetSkeletonManagerService, _logService, _commandService, _contextService, _scrollManagerService) {
|
|
21334
21487
|
super(
|
|
21335
21488
|
injector,
|
|
21336
21489
|
themeService,
|
|
21337
21490
|
shortcutService,
|
|
21338
|
-
|
|
21491
|
+
sheetSkeletonManagerService
|
|
21339
21492
|
);
|
|
21340
21493
|
__publicField(this, "_workbookSelections");
|
|
21341
21494
|
__publicField(this, "_renderDisposable", null);
|
|
@@ -21343,7 +21496,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21343
21496
|
__publicField(this, "_selectionControls", []);
|
|
21344
21497
|
// sheetID:Controls
|
|
21345
21498
|
__publicField(this, "expandingControlMode", "bottom-right");
|
|
21346
|
-
this._context = _context, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this.
|
|
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();
|
|
21347
21500
|
}
|
|
21348
21501
|
_init() {
|
|
21349
21502
|
const sheetObject = this._getSheetObject();
|
|
@@ -21467,11 +21620,11 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21467
21620
|
activeSelectionControl = control;
|
|
21468
21621
|
break;
|
|
21469
21622
|
}
|
|
21470
|
-
(activeSelectionControl == null ? void 0 : activeSelectionControl.model.rangeType) !== rangeType && (this._clearSelectionControls(), activeSelectionControl = this.newSelectionControl(scene, rangeType)), this.
|
|
21623
|
+
(activeSelectionControl == null ? void 0 : activeSelectionControl.model.rangeType) !== rangeType && (this._clearSelectionControls(), activeSelectionControl = this.newSelectionControl(scene, rangeType)), this._updateSelectionControlByRange(
|
|
21471
21624
|
activeSelectionControl,
|
|
21472
21625
|
cursorCellRangeWithRangeType,
|
|
21473
21626
|
primaryCursorCellRange
|
|
21474
|
-
), 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.
|
|
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));
|
|
21475
21628
|
}
|
|
21476
21629
|
/**
|
|
21477
21630
|
* Not same as PC version,
|
|
@@ -21596,7 +21749,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21596
21749
|
*
|
|
21597
21750
|
* In Mobile version, new selection is determined by cursor cell and current of activeSelectionControl.model
|
|
21598
21751
|
*/
|
|
21599
|
-
|
|
21752
|
+
_movingHandler(offsetX, offsetY, activeSelectionControl, rangeType) {
|
|
21600
21753
|
var _a59, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m;
|
|
21601
21754
|
this._shouldDetectMergedCells = rangeType === RANGE_TYPE.NORMAL;
|
|
21602
21755
|
const skeleton = this._skeleton, scene = this._scene, currSelectionRange = {
|
|
@@ -21641,7 +21794,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21641
21794
|
startX: (startCellXY == null ? void 0 : startCellXY.startX) || 0,
|
|
21642
21795
|
endX: (endCellXY == null ? void 0 : endCellXY.endX) || 0
|
|
21643
21796
|
};
|
|
21644
|
-
(currSelectionRange.startRow !== newSelectionRange.startRow || currSelectionRange.startColumn !== newSelectionRange.startColumn || currSelectionRange.endRow !== newSelectionRange.endRow || currSelectionRange.endColumn !== newSelectionRange.endColumn) && activeSelectionControl && (this.
|
|
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()));
|
|
21645
21798
|
}
|
|
21646
21799
|
_updateControlPointWhenScrolling() {
|
|
21647
21800
|
const { scene } = this._context;
|
|
@@ -21663,13 +21816,12 @@ MobileSheetsSelectionRenderService = __decorateClass$1([
|
|
|
21663
21816
|
__decorateParam$1(1, Inject(Injector)),
|
|
21664
21817
|
__decorateParam$1(2, Inject(ThemeService)),
|
|
21665
21818
|
__decorateParam$1(3, IShortcutService),
|
|
21666
|
-
__decorateParam$1(4,
|
|
21667
|
-
__decorateParam$1(5, Inject(
|
|
21819
|
+
__decorateParam$1(4, Inject(SheetsSelectionsService)),
|
|
21820
|
+
__decorateParam$1(5, Inject(SheetSkeletonManagerService)),
|
|
21668
21821
|
__decorateParam$1(6, ILogService),
|
|
21669
21822
|
__decorateParam$1(7, ICommandService),
|
|
21670
21823
|
__decorateParam$1(8, IContextService),
|
|
21671
|
-
__decorateParam$1(9, Inject(
|
|
21672
|
-
__decorateParam$1(10, Inject(SheetScrollManagerService))
|
|
21824
|
+
__decorateParam$1(9, Inject(SheetScrollManagerService))
|
|
21673
21825
|
], MobileSheetsSelectionRenderService);
|
|
21674
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) => {
|
|
21675
21827
|
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
|