@univerjs/sheets-ui 0.2.8 → 0.2.10
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 +10 -9
- package/lib/es/index.js +1082 -853
- package/lib/index.css +1 -1
- package/lib/types/{basics/const → consts}/ui-name.d.ts +2 -1
- package/lib/types/controllers/editor/editing.render-controller.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/permission/sheet-permission-render.controller.d.ts +3 -7
- package/lib/types/controllers/render-controllers/zoom.render-controller.d.ts +4 -0
- package/lib/types/controllers/sheet-ui.controller.d.ts +1 -0
- package/lib/types/index.d.ts +5 -1
- package/lib/types/services/canvas-pop-manager.service.d.ts +1 -1
- package/lib/types/services/format-painter/format-painter.service.d.ts +11 -2
- package/lib/types/services/mark-selection/mark-selection.service.d.ts +3 -0
- 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/select-all/select-all.service.d.ts +5 -0
- package/lib/types/services/selection/base-selection-render.service.d.ts +44 -43
- package/lib/types/services/selection/const.d.ts +4 -0
- package/lib/types/services/selection/mobile-selection-render.service.d.ts +3 -4
- package/lib/types/services/selection/mobile-selection-shape.d.ts +3 -3
- 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 +48 -42
- package/lib/types/sheets-ui-plugin.d.ts +1 -0
- package/lib/types/views/permission/panel/index.d.ts +1 -1
- package/lib/types/views/status-bar/CopyableStatisticItem.d.ts +1 -1
- package/lib/umd/index.js +10 -9
- package/package.json +20 -20
- 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
|
@@ -3,18 +3,18 @@ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { en
|
|
|
3
3
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: !0 });
|
|
4
4
|
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key != "symbol" ? key + "" : key, value);
|
|
5
5
|
import { DOCS_VIEW_KEY, SetInlineFormatBoldCommand, SetInlineFormatItalicCommand, SetInlineFormatUnderlineCommand, SetInlineFormatStrikethroughCommand, SetInlineFormatSubscriptCommand, SetInlineFormatSuperscriptCommand, SetInlineFormatFontSizeCommand, SetInlineFormatFontFamilyCommand, SetInlineFormatTextColorCommand, SetTextSelectionsOperation, SetInlineFormatCommand, TextSelectionManagerService, BreakLineCommand, DeleteLeftCommand, CoverContentCommand, RichTextEditingMutation, DocSkeletonManagerService, VIEWPORT_KEY, DOCS_COMPONENT_MAIN_LAYER_INDEX, MoveSelectionOperation, MoveCursorOperation, IMEInputCommand, InsertCommand } from "@univerjs/docs";
|
|
6
|
-
import { Disposable, Inject, Injector, CommandType, IUniverInstanceService, ICommandService, UniverInstanceType, LocaleService, Direction, Rectangle, getReverseDirection, RANGE_TYPE, Tools, Workbook, toDisposable, IContextService, UserManagerService, FOCUSING_COMMON_DRAWINGS, IPermissionService, RxDisposable, OnLifecycle, LifecycleStages, ObjectMatrix, isFormulaString, isFormulaId, CellValueType, 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
|
-
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,
|
|
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,
|
|
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, UNIVER_INTERNAL, IResourceLoaderService, isRealNum, isICellData, IAuthzIoService, isValidRange, Plugin, mergeOverrideWithDependencies, DependentOn } from "@univerjs/core";
|
|
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, 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, 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;
|
|
@@ -434,6 +434,15 @@ ShortcutExperienceService = __decorateClass$S([
|
|
|
434
434
|
__decorateParam$R(0, IUniverInstanceService),
|
|
435
435
|
__decorateParam$R(1, Inject(LocaleService))
|
|
436
436
|
], ShortcutExperienceService);
|
|
437
|
+
const _SelectAllService = class _SelectAllService extends Disposable {
|
|
438
|
+
constructor() {
|
|
439
|
+
super(...arguments);
|
|
440
|
+
__publicField(this, "rangesStack", []);
|
|
441
|
+
__publicField(this, "selectedRangeWorksheet", "");
|
|
442
|
+
}
|
|
443
|
+
};
|
|
444
|
+
__name(_SelectAllService, "SelectAllService");
|
|
445
|
+
let SelectAllService = _SelectAllService;
|
|
437
446
|
var MergeType = /* @__PURE__ */ ((MergeType2) => (MergeType2.MergeAll = "mergeAll", MergeType2.MergeVertical = "mergeVertical", MergeType2.MergeHorizontal = "mergeHorizontal", MergeType2))(MergeType || {});
|
|
438
447
|
function findNextRange(startRange, direction, worksheet, boundary, isFindNext = !0, nextStep = 1, isGoBack = !0) {
|
|
439
448
|
let destRange = { ...startRange };
|
|
@@ -977,34 +986,28 @@ const MoveSelectionCommand = {
|
|
|
977
986
|
]
|
|
978
987
|
});
|
|
979
988
|
}, "handler")
|
|
980
|
-
}
|
|
981
|
-
let RANGES_STACK = [], SELECTED_RANGE_WORKSHEET = "";
|
|
982
|
-
const SelectAllCommand = {
|
|
989
|
+
}, SelectAllCommand = {
|
|
983
990
|
id: "sheet.command.select-all",
|
|
984
991
|
type: CommandType.COMMAND,
|
|
985
|
-
onDispose() {
|
|
986
|
-
RANGES_STACK = [], SELECTED_RANGE_WORKSHEET = "";
|
|
987
|
-
},
|
|
988
992
|
handler: /* @__PURE__ */ __name(async (accessor, params = { expandToGapFirst: !0, loop: !1 }) => {
|
|
989
|
-
const
|
|
993
|
+
const target = getSheetCommandTarget(accessor.get(IUniverInstanceService));
|
|
990
994
|
if (!target) return !1;
|
|
991
|
-
const
|
|
992
|
-
if (!selection
|
|
993
|
-
|
|
994
|
-
|
|
995
|
-
id !== SELECTED_RANGE_WORKSHEET && (RANGES_STACK = [], SELECTED_RANGE_WORKSHEET = id);
|
|
995
|
+
const selection = getSelectionsService(accessor).getCurrentLastSelection();
|
|
996
|
+
if (!selection) return !1;
|
|
997
|
+
const selectAllService = accessor.get(SelectAllService), { worksheet, unitId, subUnitId } = target, id = `${unitId}|${subUnitId}`;
|
|
998
|
+
id !== selectAllService.selectedRangeWorksheet && (selectAllService.rangesStack = [], selectAllService.selectedRangeWorksheet = id);
|
|
996
999
|
const maxRow = worksheet.getMaxRows(), maxCol = worksheet.getMaxColumns(), { expandToGapFirst, loop } = params, { range, primary } = selection, isWholeSheetSelected = range.endColumn === maxCol - 1 && range.endRow === maxRow - 1 && range.startRow === 0 && range.startColumn === 0;
|
|
997
|
-
|
|
1000
|
+
selectAllService.rangesStack.some((s) => Rectangle.equals(s, range)) || (selectAllService.rangesStack = [], selectAllService.rangesStack.push(range));
|
|
998
1001
|
let destRange;
|
|
999
1002
|
if (isWholeSheetSelected)
|
|
1000
1003
|
if (loop) {
|
|
1001
|
-
if (
|
|
1004
|
+
if (selectAllService.rangesStack.findIndex((s) => Rectangle.equals(s, range)) !== selectAllService.rangesStack.length - 1)
|
|
1002
1005
|
return !1;
|
|
1003
|
-
destRange =
|
|
1006
|
+
destRange = selectAllService.rangesStack[0];
|
|
1004
1007
|
} else
|
|
1005
1008
|
return !1;
|
|
1006
1009
|
else expandToGapFirst ? (destRange = expandToContinuousRange(range, { left: !0, right: !0, up: !0, down: !0 }, worksheet), Rectangle.equals(destRange, range) && (destRange = expandToWholeSheet(worksheet))) : destRange = expandToWholeSheet(worksheet);
|
|
1007
|
-
return
|
|
1010
|
+
return selectAllService.rangesStack.some((s) => Rectangle.equals(s, destRange)) || selectAllService.rangesStack.push(destRange), accessor.get(ICommandService).executeCommand(SetSelectionsOperation.id, {
|
|
1008
1011
|
unitId,
|
|
1009
1012
|
subUnitId,
|
|
1010
1013
|
selections: [
|
|
@@ -1134,9 +1137,6 @@ let SheetsScrollRenderController = (_a4 = class extends Disposable {
|
|
|
1134
1137
|
const viewportMain = scene.getViewport(SHEET_VIEWPORT_KEY$1.VIEW_MAIN);
|
|
1135
1138
|
viewportMain && (this.disposeWithMe(
|
|
1136
1139
|
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
1140
|
this._scrollManagerService.rawScrollInfo$.subscribe((rawScrollInfo) => {
|
|
1141
1141
|
var _a59;
|
|
1142
1142
|
const skeleton = (_a59 = this._sheetSkeletonManagerService.getCurrent()) == null ? void 0 : _a59.skeleton;
|
|
@@ -1333,7 +1333,7 @@ SheetsScrollRenderController = __decorateClass$R([
|
|
|
1333
1333
|
__decorateParam$Q(5, IRenderManagerService),
|
|
1334
1334
|
__decorateParam$Q(6, Inject(SheetScrollManagerService))
|
|
1335
1335
|
], 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 || {}),
|
|
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 || {}), P = /* @__PURE__ */ ((E) => (E[E.View = 0] = "View", E[E.Edit = 1] = "Edit", E[E.ManageCollaborator = 2] = "ManageCollaborator", E[E.Print = 3] = "Print", E[E.Duplicate = 4] = "Duplicate", E[E.Comment = 5] = "Comment", E[E.Copy = 6] = "Copy", E[E.Share = 7] = "Share", E[E.Export = 8] = "Export", E[E.MoveWorksheet = 9] = "MoveWorksheet", E[E.DeleteWorksheet = 10] = "DeleteWorksheet", E[E.HideWorksheet = 11] = "HideWorksheet", E[E.RenameWorksheet = 12] = "RenameWorksheet", E[E.CreateWorksheet = 13] = "CreateWorksheet", E[E.SetWorksheetStyle = 14] = "SetWorksheetStyle", E[E.EditWorksheetCell = 15] = "EditWorksheetCell", E[E.InsertHyperlink = 16] = "InsertHyperlink", E[E.Sort = 17] = "Sort", E[E.Filter = 18] = "Filter", E[E.PivotTable = 19] = "PivotTable", E[E.FloatImg = 20] = "FloatImg", E[E.History = 21] = "History", E[E.RwHgtClWdt = 22] = "RwHgtClWdt", E[E.ViemRwHgtClWdt = 23] = "ViemRwHgtClWdt", E[E.ViewFilter = 24] = "ViewFilter", E[E.MoveSheet = 25] = "MoveSheet", E[E.DeleteSheet = 26] = "DeleteSheet", E[E.HideSheet = 27] = "HideSheet", E[E.CopySheet = 28] = "CopySheet", E[E.RenameSheet = 29] = "RenameSheet", E[E.CreateSheet = 30] = "CreateSheet", E[E.SelectProtectedCells = 31] = "SelectProtectedCells", E[E.SelectUnProtectedCells = 32] = "SelectUnProtectedCells", E[E.SetCellStyle = 33] = "SetCellStyle", E[E.SetCellValue = 34] = "SetCellValue", E[E.SetRowStyle = 35] = "SetRowStyle", E[E.SetColumnStyle = 36] = "SetColumnStyle", E[E.InsertRow = 37] = "InsertRow", E[E.InsertColumn = 38] = "InsertColumn", E[E.DeleteRow = 39] = "DeleteRow", E[E.DeleteColumn = 40] = "DeleteColumn", E[E.EditExtraObject = 41] = "EditExtraObject", E[E.Delete = 42] = "Delete", E[E.RecoverHistory = 43] = "RecoverHistory", E[E.ViewHistory = 44] = "ViewHistory", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(P || {}), G = /* @__PURE__ */ ((E) => (E[E.Reader = 0] = "Reader", E[E.Editor = 1] = "Editor", E[E.Owner = 2] = "Owner", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(G || {}), 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 || {}), H = /* @__PURE__ */ ((E) => (E[E.SomeCollaborator = 0] = "SomeCollaborator", E[E.AllCollaborator = 1] = "AllCollaborator", E[E.OneSelf = 2] = "OneSelf", E[E.UNRECOGNIZED = -1] = "UNRECOGNIZED", E))(H || {});
|
|
1337
1337
|
function getActiveSheet$(univerInstanceService) {
|
|
1338
1338
|
return univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET).pipe(switchMap((workbook) => workbook ? workbook.activeSheet$.pipe(map((worksheet) => worksheet ? { workbook, worksheet } : null)) : of(null)));
|
|
1339
1339
|
}
|
|
@@ -2503,7 +2503,9 @@ const IAutoFillService = createIdentifier("univer.auto-fill-service"), AutoFillC
|
|
|
2503
2503
|
redoMutations: [{ id: SetRangeValuesMutation.id, params: clearMutationParams }]
|
|
2504
2504
|
}), !0) : !1;
|
|
2505
2505
|
}, "handler")
|
|
2506
|
-
}, RANGE_MOVE_PERMISSION_CHECK = createInterceptorKey("rangeMovePermissionCheck"), RANGE_FILL_PERMISSION_CHECK = createInterceptorKey("rangeFillPermissionCheck")
|
|
2506
|
+
}, RANGE_MOVE_PERMISSION_CHECK = createInterceptorKey("rangeMovePermissionCheck"), RANGE_FILL_PERMISSION_CHECK = createInterceptorKey("rangeFillPermissionCheck");
|
|
2507
|
+
var SELECTION_SHAPE_DEPTH = /* @__PURE__ */ ((SELECTION_SHAPE_DEPTH2) => (SELECTION_SHAPE_DEPTH2[SELECTION_SHAPE_DEPTH2.FORMULA_EDITOR_SHOW = 100] = "FORMULA_EDITOR_SHOW", SELECTION_SHAPE_DEPTH2[SELECTION_SHAPE_DEPTH2.MARK_SELECTION = 1e4] = "MARK_SELECTION", SELECTION_SHAPE_DEPTH2))(SELECTION_SHAPE_DEPTH || {});
|
|
2508
|
+
const _SelectionRenderModel = class _SelectionRenderModel {
|
|
2507
2509
|
constructor() {
|
|
2508
2510
|
__publicField(this, "_startColumn", -1);
|
|
2509
2511
|
__publicField(this, "_startRow", -1);
|
|
@@ -2514,9 +2516,7 @@ const IAutoFillService = createIdentifier("univer.auto-fill-service"), AutoFillC
|
|
|
2514
2516
|
__publicField(this, "_endX", 0);
|
|
2515
2517
|
__publicField(this, "_endY", 0);
|
|
2516
2518
|
/**
|
|
2517
|
-
* highlight cell of selection
|
|
2518
|
-
* when there is no merge info
|
|
2519
|
-
* top left cell of current selection (or bottomLeft of current selection)
|
|
2519
|
+
* The highlight cell of a selection. aka: current cell
|
|
2520
2520
|
*/
|
|
2521
2521
|
__publicField(this, "_primary");
|
|
2522
2522
|
__publicField(this, "_rangeType", RANGE_TYPE.NORMAL);
|
|
@@ -2621,6 +2621,12 @@ const IAutoFillService = createIdentifier("univer.auto-fill-service"), AutoFillC
|
|
|
2621
2621
|
} = newSelectionRange;
|
|
2622
2622
|
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
2623
|
}
|
|
2624
|
+
/**
|
|
2625
|
+
* Set primary cell.
|
|
2626
|
+
*
|
|
2627
|
+
* TODO @lumixraku there are 3 concepts for same thing, primary and current and highlight, primary is better cuz selectionModel is using primary.
|
|
2628
|
+
* @param currentCell
|
|
2629
|
+
*/
|
|
2624
2630
|
setCurrentCell(currentCell) {
|
|
2625
2631
|
currentCell && (this._primary = currentCell);
|
|
2626
2632
|
}
|
|
@@ -2632,7 +2638,7 @@ __name(_SelectionRenderModel, "SelectionRenderModel");
|
|
|
2632
2638
|
let SelectionRenderModel = _SelectionRenderModel;
|
|
2633
2639
|
var SELECTION_MANAGER_KEY = /* @__PURE__ */ ((SELECTION_MANAGER_KEY2) => (SELECTION_MANAGER_KEY2.Selection = "__SpreadsheetSelectionShape__", SELECTION_MANAGER_KEY2.top = "__SpreadsheetSelectionTopControl__", SELECTION_MANAGER_KEY2.bottom = "__SpreadsheetSelectionBottomControl__", SELECTION_MANAGER_KEY2.left = "__SpreadsheetSelectionShapeLeftControl__", SELECTION_MANAGER_KEY2.right = "__SpreadsheetSelectionShapeRightControl__", SELECTION_MANAGER_KEY2.backgroundTop = "__SpreadsheetSelectionBackgroundControlTop__", SELECTION_MANAGER_KEY2.backgroundMiddleLeft = "__SpreadsheetSelectionBackgroundControlMiddleLeft__", SELECTION_MANAGER_KEY2.backgroundMiddleRight = "__SpreadsheetSelectionBackgroundControlMiddleRight__", SELECTION_MANAGER_KEY2.backgroundBottom = "__SpreadsheetSelectionBackgroundControlBottom__", SELECTION_MANAGER_KEY2.fill = "__SpreadsheetSelectionFillControl__", SELECTION_MANAGER_KEY2.fillTopLeft = "__SpreadsheetSelectionFillControlTopLeft__", SELECTION_MANAGER_KEY2.fillBottomRight = "__SpreadsheetSelectionFillControlBottomRight__", SELECTION_MANAGER_KEY2.fillTopLeftInner = "__SpreadsheetSelectionFillControlTopLeftInner__", SELECTION_MANAGER_KEY2.fillBottomRightInner = "__SpreadsheetSelectionFillControlBottomRightInner__", SELECTION_MANAGER_KEY2.lineMain = "__SpreadsheetDragLineMainControl__", SELECTION_MANAGER_KEY2.lineContent = "__SpreadsheetDragLineContentControl__", SELECTION_MANAGER_KEY2.line = "__SpreadsheetDragLineControl__", SELECTION_MANAGER_KEY2.dash = "__SpreadsheetDragDashControl__", SELECTION_MANAGER_KEY2.rowHeaderBackground = "__SpreadSheetSelectionRowHeaderBackground__", SELECTION_MANAGER_KEY2.rowHeaderBorder = "__SpreadSheetSelectionRowHeaderBorder__", SELECTION_MANAGER_KEY2.rowHeaderGroup = "__SpreadSheetSelectionRowHeaderGroup__", SELECTION_MANAGER_KEY2.columnHeaderBackground = "__SpreadSheetSelectionColumnHeaderBackground__", SELECTION_MANAGER_KEY2.columnHeaderBorder = "__SpreadSheetSelectionColumnHeaderBorder__", SELECTION_MANAGER_KEY2.columnHeaderGroup = "__SpreadSheetSelectionColumnHeaderGroup__", SELECTION_MANAGER_KEY2.topLeftWidget = "__SpreadSheetSelectionTopLeftWidget__", SELECTION_MANAGER_KEY2.topCenterWidget = "__SpreadSheetSelectionTopCenterWidget__", SELECTION_MANAGER_KEY2.topRightWidget = "__SpreadSheetSelectionTopRightWidget__", SELECTION_MANAGER_KEY2.middleLeftWidget = "__SpreadSheetSelectionMiddleLeftWidget__", SELECTION_MANAGER_KEY2.middleRightWidget = "__SpreadSheetSelectionMiddleRightWidget__", SELECTION_MANAGER_KEY2.bottomLeftWidget = "__SpreadSheetSelectionBottomLeftWidget__", SELECTION_MANAGER_KEY2.bottomCenterWidget = "__SpreadSheetSelectionBottomCenterWidget__", SELECTION_MANAGER_KEY2.bottomRightWidget = "__SpreadSheetSelectionBottomRightWidget__", SELECTION_MANAGER_KEY2))(SELECTION_MANAGER_KEY || {});
|
|
2634
2640
|
const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _SelectionControl extends Disposable {
|
|
2635
|
-
constructor(_scene, _zIndex,
|
|
2641
|
+
constructor(_scene, _zIndex, _themeService, _highlightHeader = !0, options) {
|
|
2636
2642
|
super();
|
|
2637
2643
|
__publicField(this, "_leftControl");
|
|
2638
2644
|
__publicField(this, "_rightControl");
|
|
@@ -2647,11 +2653,11 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2647
2653
|
__publicField(this, "_rowHeaderBackground");
|
|
2648
2654
|
__publicField(this, "_rowHeaderBorder");
|
|
2649
2655
|
__publicField(this, "_rowHeaderGroup");
|
|
2650
|
-
|
|
2656
|
+
// private _rowHeaderHighlight!: Rect;
|
|
2651
2657
|
__publicField(this, "_columnHeaderBackground");
|
|
2652
2658
|
__publicField(this, "_columnHeaderBorder");
|
|
2653
2659
|
__publicField(this, "_columnHeaderGroup");
|
|
2654
|
-
|
|
2660
|
+
// private _columnHeaderHighlight!: Rect;
|
|
2655
2661
|
__publicField(this, "_topLeftWidget");
|
|
2656
2662
|
__publicField(this, "_topCenterWidget");
|
|
2657
2663
|
__publicField(this, "_topRightWidget");
|
|
@@ -2662,12 +2668,19 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2662
2668
|
__publicField(this, "_bottomRightWidget");
|
|
2663
2669
|
__publicField(this, "_dashRect");
|
|
2664
2670
|
__publicField(this, "_selectionModel");
|
|
2665
|
-
|
|
2671
|
+
// why three style prop? what's diff between _selectionStyle & _currentStyle?
|
|
2672
|
+
// protected _selectionStyle: Nullable<ISelectionStyle>;
|
|
2673
|
+
__publicField(this, "_defaultStyle");
|
|
2674
|
+
__publicField(this, "_currentStyle");
|
|
2666
2675
|
__publicField(this, "_rowHeaderWidth", 0);
|
|
2667
2676
|
__publicField(this, "_columnHeaderHeight", 0);
|
|
2668
2677
|
__publicField(this, "_widgetRects", []);
|
|
2669
2678
|
__publicField(this, "_dispose$", new BehaviorSubject(this));
|
|
2670
2679
|
__publicField(this, "dispose$", this._dispose$.asObservable());
|
|
2680
|
+
/**
|
|
2681
|
+
* eventSource: selectionShapeExtension selectionMoving$.next,
|
|
2682
|
+
* Observer: prompt.controller
|
|
2683
|
+
*/
|
|
2671
2684
|
__publicField(this, "selectionMoving$", new Subject());
|
|
2672
2685
|
__publicField(this, "selectionMoved$", new Subject());
|
|
2673
2686
|
__publicField(this, "selectionScaling$", new Subject());
|
|
@@ -2675,12 +2688,10 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2675
2688
|
__publicField(this, "selectionFilling$", new Subject());
|
|
2676
2689
|
__publicField(this, "_selectionFilled$", new Subject());
|
|
2677
2690
|
__publicField(this, "selectionFilled$", this._selectionFilled$.asObservable());
|
|
2678
|
-
__publicField(this, "_defaultStyle");
|
|
2679
|
-
__publicField(this, "_currentStyle");
|
|
2680
2691
|
__publicField(this, "_isHelperSelection", !0);
|
|
2681
2692
|
__publicField(this, "_antLineOffset", 0);
|
|
2682
2693
|
__publicField(this, "_antRequestNewFrame", -1);
|
|
2683
|
-
this._scene = _scene, this._zIndex = _zIndex, this.
|
|
2694
|
+
this._scene = _scene, this._zIndex = _zIndex, this._themeService = _themeService, this._highlightHeader = _highlightHeader, this._rowHeaderWidth = (options == null ? void 0 : options.rowHeaderWidth) || 0, this._columnHeaderHeight = (options == null ? void 0 : options.columnHeaderHeight) || 0, this._initialize();
|
|
2684
2695
|
}
|
|
2685
2696
|
get zIndex() {
|
|
2686
2697
|
return this._zIndex;
|
|
@@ -2754,12 +2765,12 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2754
2765
|
get themeService() {
|
|
2755
2766
|
return this._themeService;
|
|
2756
2767
|
}
|
|
2757
|
-
get selectionStyle() {
|
|
2758
|
-
|
|
2759
|
-
}
|
|
2760
|
-
set selectionStyle(style) {
|
|
2761
|
-
|
|
2762
|
-
}
|
|
2768
|
+
// get selectionStyle() {
|
|
2769
|
+
// return this._selectionStyle;
|
|
2770
|
+
// }
|
|
2771
|
+
// set selectionStyle(style: Nullable<ISelectionStyle>) {
|
|
2772
|
+
// this._selectionStyle = style;
|
|
2773
|
+
// }
|
|
2763
2774
|
get selectionModel() {
|
|
2764
2775
|
return this._selectionModel;
|
|
2765
2776
|
}
|
|
@@ -2779,7 +2790,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2779
2790
|
return this._currentStyle;
|
|
2780
2791
|
}
|
|
2781
2792
|
set currentStyle(style) {
|
|
2782
|
-
this._currentStyle = style;
|
|
2793
|
+
style && (this._currentStyle = style);
|
|
2783
2794
|
}
|
|
2784
2795
|
get isHelperSelection() {
|
|
2785
2796
|
return this._isHelperSelection;
|
|
@@ -2802,109 +2813,24 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2802
2813
|
refreshSelectionFilled(val) {
|
|
2803
2814
|
this._selectionFilled$.next(val);
|
|
2804
2815
|
}
|
|
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
2816
|
/**
|
|
2889
|
-
* invoked when update selection style & range change
|
|
2817
|
+
* invoked when update selection style & range change, invoked by updateStyle, updateRange, update
|
|
2890
2818
|
*/
|
|
2891
2819
|
// eslint-disable-next-line max-lines-per-function
|
|
2892
|
-
|
|
2893
|
-
const { startX, startY, endX, endY } = this._selectionModel, defaultStyle = this._defaultStyle
|
|
2894
|
-
style == null && (style = defaultStyle), this._currentStyle = style;
|
|
2895
|
-
const {
|
|
2820
|
+
_updateControlStyleAndLayout(selectionStyle) {
|
|
2821
|
+
const { startX, startY, endX, endY } = this._selectionModel, defaultStyle = this._defaultStyle, currentStyle = this.currentStyle = selectionStyle || this._currentStyle, {
|
|
2896
2822
|
stroke = defaultStyle.stroke,
|
|
2897
2823
|
widgets = defaultStyle.widgets,
|
|
2898
2824
|
hasAutoFill = defaultStyle.hasAutoFill,
|
|
2899
2825
|
AutofillStroke = defaultStyle.AutofillStroke,
|
|
2900
2826
|
strokeDash,
|
|
2901
2827
|
isAnimationDash
|
|
2902
|
-
} =
|
|
2828
|
+
} = currentStyle;
|
|
2903
2829
|
let {
|
|
2904
2830
|
strokeWidth = defaultStyle.strokeWidth,
|
|
2905
2831
|
AutofillSize = defaultStyle.AutofillSize,
|
|
2906
2832
|
AutofillStrokeWidth = defaultStyle.AutofillStrokeWidth
|
|
2907
|
-
} =
|
|
2833
|
+
} = currentStyle;
|
|
2908
2834
|
const scale = this._getScale(), leftAdjustWidth = (strokeWidth + SELECTION_CONTROL_BORDER_BUFFER_WIDTH) / 2 / scale;
|
|
2909
2835
|
strokeWidth /= scale, AutofillSize /= scale, AutofillStrokeWidth /= scale < 1 ? 1 : scale;
|
|
2910
2836
|
const borderBuffer = SELECTION_CONTROL_BORDER_BUFFER_WIDTH / scale, fixOnePixelBlurOffset = FIX_ONE_PIXEL_BLUR_OFFSET / scale;
|
|
@@ -2947,7 +2873,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2947
2873
|
}), strokeDash == null)
|
|
2948
2874
|
this.dashRect.hide(), this._stopAntLineAnimation();
|
|
2949
2875
|
else {
|
|
2950
|
-
const dashRectBorderWidth =
|
|
2876
|
+
const dashRectBorderWidth = currentStyle.strokeWidth * 2 / scale;
|
|
2951
2877
|
this.dashRect.transformByState({
|
|
2952
2878
|
height: endY - startY,
|
|
2953
2879
|
width: endX - startX,
|
|
@@ -2973,11 +2899,103 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
2973
2899
|
this.fillControl.setProps(fillProps), this.fillControl.transformByState(sizeState), this.fillControl.show();
|
|
2974
2900
|
} else
|
|
2975
2901
|
this.fillControl.hide();
|
|
2976
|
-
this._updateBackgroundControl(
|
|
2902
|
+
this._updateBackgroundControl(selectionStyle), this._updateHeaderBackground(selectionStyle), this._updateWidgets(selectionStyle), this.selectionShape.show(), this.selectionShape.translate(startX, startY), this.selectionShape.makeDirtyNoDebounce(!0);
|
|
2903
|
+
}
|
|
2904
|
+
updateStyle(style) {
|
|
2905
|
+
this._updateControlStyleAndLayout(style);
|
|
2906
|
+
}
|
|
2907
|
+
updateRange(range, primaryCell) {
|
|
2908
|
+
this._selectionModel.setValue(range, primaryCell), this._updateControlStyleAndLayout(this._currentStyle);
|
|
2909
|
+
}
|
|
2910
|
+
/**
|
|
2911
|
+
* update selection model with new range & primary cell(aka: highlight/current), also update row/col selection size & style.
|
|
2912
|
+
*
|
|
2913
|
+
* @param newSelectionRange
|
|
2914
|
+
* @param rowHeaderWidth
|
|
2915
|
+
* @param columnHeaderHeight
|
|
2916
|
+
* @param style
|
|
2917
|
+
* @param primaryCell primary cell
|
|
2918
|
+
*/
|
|
2919
|
+
update(newSelectionRange, rowHeaderWidth = 0, columnHeaderHeight = 0, style, primaryCell) {
|
|
2920
|
+
this._selectionModel.setValue(newSelectionRange, primaryCell), this._rowHeaderWidth = rowHeaderWidth, this._columnHeaderHeight = columnHeaderHeight, this._updateControlStyleAndLayout(style || this._currentStyle);
|
|
2921
|
+
}
|
|
2922
|
+
/**
|
|
2923
|
+
* update primary range
|
|
2924
|
+
* @param primaryCell model.current (aka: highlight)
|
|
2925
|
+
*/
|
|
2926
|
+
updateCurrCell(primaryCell) {
|
|
2927
|
+
this._selectionModel.setCurrentCell(primaryCell);
|
|
2928
|
+
}
|
|
2929
|
+
clearHighlight() {
|
|
2930
|
+
this._selectionModel.clearCurrentCell(), this._updateControlStyleAndLayout(this._currentStyle);
|
|
2931
|
+
}
|
|
2932
|
+
getScene() {
|
|
2933
|
+
return this._scene;
|
|
2934
|
+
}
|
|
2935
|
+
// eslint-disable-next-line complexity
|
|
2936
|
+
dispose() {
|
|
2937
|
+
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;
|
|
2938
|
+
(_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();
|
|
2939
|
+
}
|
|
2940
|
+
/**
|
|
2941
|
+
* Get the cell information of the current selection, considering the case of merging cells
|
|
2942
|
+
*/
|
|
2943
|
+
getCurrentCellInfo() {
|
|
2944
|
+
const currentCell = this.model.currentCell;
|
|
2945
|
+
if (currentCell) {
|
|
2946
|
+
let currentRangeData;
|
|
2947
|
+
if (currentCell.isMerged) {
|
|
2948
|
+
const mergeInfo = currentCell.mergeInfo;
|
|
2949
|
+
currentRangeData = {
|
|
2950
|
+
startRow: mergeInfo.startRow,
|
|
2951
|
+
endRow: mergeInfo.endRow,
|
|
2952
|
+
startColumn: mergeInfo.startColumn,
|
|
2953
|
+
endColumn: mergeInfo.endColumn,
|
|
2954
|
+
startX: mergeInfo.startX,
|
|
2955
|
+
endX: mergeInfo.endX,
|
|
2956
|
+
startY: mergeInfo.startY,
|
|
2957
|
+
endY: mergeInfo.endY
|
|
2958
|
+
};
|
|
2959
|
+
} else {
|
|
2960
|
+
const { actualRow, actualColumn, startX, endX, startY, endY } = currentCell;
|
|
2961
|
+
currentRangeData = {
|
|
2962
|
+
startRow: actualRow,
|
|
2963
|
+
endRow: actualRow,
|
|
2964
|
+
startColumn: actualColumn,
|
|
2965
|
+
endColumn: actualColumn,
|
|
2966
|
+
startX,
|
|
2967
|
+
endX,
|
|
2968
|
+
startY,
|
|
2969
|
+
endY
|
|
2970
|
+
};
|
|
2971
|
+
}
|
|
2972
|
+
return currentRangeData;
|
|
2973
|
+
}
|
|
2974
|
+
}
|
|
2975
|
+
getValue() {
|
|
2976
|
+
return {
|
|
2977
|
+
...this._selectionModel.getValue(),
|
|
2978
|
+
style: this._currentStyle
|
|
2979
|
+
};
|
|
2980
|
+
}
|
|
2981
|
+
getRange() {
|
|
2982
|
+
return this._selectionModel.getValue().rangeWithCoord;
|
|
2983
|
+
}
|
|
2984
|
+
enableHelperSelection() {
|
|
2985
|
+
this._isHelperSelection = !0;
|
|
2986
|
+
}
|
|
2987
|
+
disableHelperSelection() {
|
|
2988
|
+
this._isHelperSelection = !1;
|
|
2977
2989
|
}
|
|
2990
|
+
// updateStyleId(id: string) {
|
|
2991
|
+
// if (this._selectionStyle == null) {
|
|
2992
|
+
// return;
|
|
2993
|
+
// }
|
|
2994
|
+
// this._selectionStyle.id = id;
|
|
2995
|
+
// }
|
|
2978
2996
|
// eslint-disable-next-line max-lines-per-function
|
|
2979
2997
|
_initialize() {
|
|
2980
|
-
this._defaultStyle = getNormalSelectionStyle(this._themeService), this._selectionModel = new SelectionRenderModel();
|
|
2998
|
+
this._defaultStyle = getNormalSelectionStyle(this._themeService), this._currentStyle = getNormalSelectionStyle(this._themeService), this._selectionModel = new SelectionRenderModel();
|
|
2981
2999
|
const zIndex = this._zIndex;
|
|
2982
3000
|
this._leftControl = new Rect("__SpreadsheetSelectionShapeLeftControl__" + zIndex, {
|
|
2983
3001
|
zIndex
|
|
@@ -3023,12 +3041,12 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
3023
3041
|
scene.addObject(this._selectionShapeGroup, SHEET_COMPONENT_SELECTION_LAYER_INDEX), this.disposeWithMe(
|
|
3024
3042
|
toDisposable(
|
|
3025
3043
|
scene.onTransformChange$.subscribeEvent((state) => {
|
|
3026
|
-
state.type === TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale && this.
|
|
3044
|
+
state.type === TRANSFORM_CHANGE_OBSERVABLE_TYPE.scale && this._updateControlStyleAndLayout(this._currentStyle);
|
|
3027
3045
|
})
|
|
3028
3046
|
)
|
|
3029
|
-
), this.
|
|
3047
|
+
), this._initialHeader();
|
|
3030
3048
|
}
|
|
3031
|
-
|
|
3049
|
+
_initialHeader() {
|
|
3032
3050
|
const zIndex = this._zIndex;
|
|
3033
3051
|
this._rowHeaderBackground = new Rect("__SpreadSheetSelectionRowHeaderBackground__" + zIndex, {
|
|
3034
3052
|
zIndex: zIndex - 1,
|
|
@@ -3081,7 +3099,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
3081
3099
|
this._bottomRightWidget
|
|
3082
3100
|
];
|
|
3083
3101
|
}
|
|
3084
|
-
|
|
3102
|
+
_updateHeaderBackground(style) {
|
|
3085
3103
|
const { startX, startY, endX, endY, rangeType } = this._selectionModel, defaultStyle = this._defaultStyle;
|
|
3086
3104
|
style == null && (style = defaultStyle);
|
|
3087
3105
|
const scale = this._getScale(), {
|
|
@@ -3097,9 +3115,11 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
3097
3115
|
rowHeaderStrokeWidth = defaultStyle.rowHeaderStrokeWidth,
|
|
3098
3116
|
columnHeaderStrokeWidth = defaultStyle.columnHeaderStrokeWidth
|
|
3099
3117
|
} = style;
|
|
3100
|
-
|
|
3118
|
+
rowHeaderStrokeWidth /= scale, columnHeaderStrokeWidth /= scale;
|
|
3119
|
+
const rowHeaderWidth = this._rowHeaderWidth, columnHeaderHeight = this._columnHeaderHeight;
|
|
3120
|
+
if (hasColumnHeader === !0) {
|
|
3101
3121
|
let highlightTitleColor = columnHeaderFill;
|
|
3102
|
-
this.
|
|
3122
|
+
this._highlightHeader && rangeType === RANGE_TYPE.COLUMN && (highlightTitleColor = new ColorKit(stroke).setAlpha(SELECTION_TITLE_HIGHLIGHT_ALPHA).toString()), this._columnHeaderBackground.setProps({
|
|
3103
3123
|
fill: highlightTitleColor
|
|
3104
3124
|
}), this._columnHeaderBackground.resize(endX - startX, columnHeaderHeight), this._columnHeaderBorder.setProps({
|
|
3105
3125
|
fill: columnHeaderStroke
|
|
@@ -3112,7 +3132,7 @@ const SELECTION_TITLE_HIGHLIGHT_ALPHA = 0.3, _SelectionControl = class _Selectio
|
|
|
3112
3132
|
this._columnHeaderGroup.hide();
|
|
3113
3133
|
if (this._columnHeaderGroup.makeDirty(!0), hasRowHeader === !0) {
|
|
3114
3134
|
let highlightTitleColor = rowHeaderFill;
|
|
3115
|
-
this.
|
|
3135
|
+
this._highlightHeader && rangeType === RANGE_TYPE.ROW && (highlightTitleColor = new ColorKit(stroke).setAlpha(SELECTION_TITLE_HIGHLIGHT_ALPHA).toString()), this._rowHeaderBackground.setProps({
|
|
3116
3136
|
fill: highlightTitleColor
|
|
3117
3137
|
}), this._rowHeaderBackground.resize(rowHeaderWidth, endY - startY), this._rowHeaderBorder.setProps({
|
|
3118
3138
|
fill: rowHeaderStroke
|
|
@@ -3317,6 +3337,10 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3317
3337
|
endColumn
|
|
3318
3338
|
}, this._control.selectionMoving$.next(this._targetSelection);
|
|
3319
3339
|
}
|
|
3340
|
+
/**
|
|
3341
|
+
* Drag move whole selectionControl when cusor turns to crosshair. Not for dragging 8 control points.
|
|
3342
|
+
* @param evt
|
|
3343
|
+
*/
|
|
3320
3344
|
_controlEvent(evt) {
|
|
3321
3345
|
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
3346
|
newEvtOffsetX,
|
|
@@ -3334,13 +3358,13 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3334
3358
|
} = this._control.model;
|
|
3335
3359
|
let fixRow = 0, fixColumn = 0;
|
|
3336
3360
|
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.
|
|
3361
|
+
const style = this._control.currentStyle, scale = this._getScale();
|
|
3338
3362
|
this.isHelperSelection && (this._helperSelection = new Rect(HELPER_SELECTION_TEMP_NAME, {
|
|
3339
3363
|
stroke: style.stroke,
|
|
3340
3364
|
strokeWidth: style.strokeWidth / scale
|
|
3341
3365
|
}), scene.addObject(this._helperSelection));
|
|
3342
3366
|
const viewMain = scene.getViewport(SHEET_VIEWPORT_KEY$1.VIEW_MAIN), scrollTimer = ScrollTimer.create(scene);
|
|
3343
|
-
scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY, viewMain),
|
|
3367
|
+
this._scrollTimer = scrollTimer, scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY, viewMain), scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
|
|
3344
3368
|
var _a59;
|
|
3345
3369
|
const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt;
|
|
3346
3370
|
if (((_a59 = this._injector.get(ISheetSelectionRenderService, Quantity.OPTIONAL)) == null ? void 0 : _a59.interceptor.fetchThroughInterceptors(RANGE_MOVE_PERMISSION_CHECK)(!1, null)) === !1)
|
|
@@ -3393,10 +3417,45 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3393
3417
|
}), control.onPointerLeave$.subscribeEvent(() => {
|
|
3394
3418
|
control.resetCursor();
|
|
3395
3419
|
}), control.onPointerDown$.subscribeEvent((evt) => {
|
|
3396
|
-
this.
|
|
3420
|
+
this._widgetPointerDownEvent(evt, cursors[index]);
|
|
3421
|
+
});
|
|
3422
|
+
});
|
|
3423
|
+
}
|
|
3424
|
+
/**
|
|
3425
|
+
* Pointer down Events for 8 control point.
|
|
3426
|
+
* @param evt
|
|
3427
|
+
* @param cursor
|
|
3428
|
+
*/
|
|
3429
|
+
_widgetPointerDownEvent(evt, cursor) {
|
|
3430
|
+
const scene = this._scene, { offsetX: evtOffsetX, offsetY: evtOffsetY } = evt, relativeCoords = scene.getRelativeToViewportCoord(Vector2.FromArray([evtOffsetX, evtOffsetY])), { x: newEvtOffsetX, y: newEvtOffsetY } = relativeCoords;
|
|
3431
|
+
this._startOffsetX = evtOffsetX, this._startOffsetY = evtOffsetY;
|
|
3432
|
+
const {
|
|
3433
|
+
startRow: originStartRow,
|
|
3434
|
+
startColumn: originStartColumn,
|
|
3435
|
+
endRow: originEndRow,
|
|
3436
|
+
endColumn: originEndColumn
|
|
3437
|
+
} = this._control.model, startRow = Math.min(originStartRow, originEndRow), startColumn = Math.min(originStartColumn, originEndColumn), endRow = Math.max(originStartRow, originEndRow), endColumn = Math.max(originStartColumn, originEndColumn);
|
|
3438
|
+
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);
|
|
3439
|
+
const scrollTimer = ScrollTimer.create(scene);
|
|
3440
|
+
scrollTimer.startScroll(newEvtOffsetX, newEvtOffsetY), this._scrollTimer = scrollTimer, scene.disableEvent(), this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
|
|
3441
|
+
const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt, { x: newMoveOffsetX, y: newMoveOffsetY } = scene.getRelativeToViewportCoord(
|
|
3442
|
+
Vector2.FromArray([moveOffsetX, moveOffsetY])
|
|
3443
|
+
);
|
|
3444
|
+
this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor), scene.setCursor(cursor), scrollTimer.scrolling(newMoveOffsetX, newMoveOffsetY, () => {
|
|
3445
|
+
this._widgetMoving(newMoveOffsetX, newMoveOffsetY, cursor);
|
|
3397
3446
|
});
|
|
3447
|
+
}), this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent(() => {
|
|
3448
|
+
var _a59, _b, _c;
|
|
3449
|
+
const scene2 = this._scene;
|
|
3450
|
+
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
3451
|
});
|
|
3399
3452
|
}
|
|
3453
|
+
/**
|
|
3454
|
+
* Pointer move Events for 8 control point.
|
|
3455
|
+
* @param moveOffsetX
|
|
3456
|
+
* @param moveOffsetY
|
|
3457
|
+
* @param cursor
|
|
3458
|
+
*/
|
|
3400
3459
|
_widgetMoving(moveOffsetX, moveOffsetY, cursor) {
|
|
3401
3460
|
const scene = this._scene, scrollXY = scene.getVpScrollXYInfoByPosToVp(Vector2.FromArray([this._startOffsetX, this._startOffsetY])), { scaleX, scaleY } = scene.getAncestorScale(), moveActualSelection = this._skeleton.getCellPositionByOffset(
|
|
3402
3461
|
moveOffsetX,
|
|
@@ -3422,36 +3481,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3422
3481
|
endRow,
|
|
3423
3482
|
startColumn,
|
|
3424
3483
|
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
|
-
});
|
|
3484
|
+
}, this._control.update(this._targetSelection, rowHeaderWidth, columnHeaderHeight, this._control.currentStyle), this._control.clearHighlight(), this._control.selectionScaling$.next(this._targetSelection);
|
|
3455
3485
|
}
|
|
3456
3486
|
_initialFill() {
|
|
3457
3487
|
const { fillControl } = this._control;
|
|
@@ -3461,6 +3491,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3461
3491
|
fillControl.resetCursor();
|
|
3462
3492
|
}), fillControl.onPointerDown$.subscribeEvent(this._fillEvent.bind(this));
|
|
3463
3493
|
}
|
|
3494
|
+
// eslint-disable-next-line complexity
|
|
3464
3495
|
_fillMoving(moveOffsetX, moveOffsetY) {
|
|
3465
3496
|
var _a59, _b, _c;
|
|
3466
3497
|
const scene = this._scene, scrollXY = scene.getViewportScrollXY(this._activeViewport), { scaleX, scaleY } = scene.getAncestorScale(), moveActualSelection = this._skeleton.getCellPositionByOffset(
|
|
@@ -3534,7 +3565,7 @@ const HELPER_SELECTION_TEMP_NAME = "__SpreadsheetHelperSelectionTempRect", SELEC
|
|
|
3534
3565
|
endColumn: originEndColumn
|
|
3535
3566
|
} = this._control.model;
|
|
3536
3567
|
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.
|
|
3568
|
+
const style = this._control.currentStyle;
|
|
3538
3569
|
let stroke = style == null ? void 0 : style.stroke, strokeWidth = style == null ? void 0 : style.strokeWidth;
|
|
3539
3570
|
const defaultStyle = getNormalSelectionStyle(this._themeService);
|
|
3540
3571
|
stroke == null && (stroke = defaultStyle.stroke), strokeWidth == null && (strokeWidth = defaultStyle.strokeWidth);
|
|
@@ -3721,7 +3752,7 @@ function attachPrimaryWithCoord(primary, skeleton) {
|
|
|
3721
3752
|
}
|
|
3722
3753
|
__name(attachPrimaryWithCoord, "attachPrimaryWithCoord");
|
|
3723
3754
|
const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-render-service"), _BaseSelectionRenderService = class _BaseSelectionRenderService extends Disposable {
|
|
3724
|
-
constructor(_injector, _themeService, _shortcutService,
|
|
3755
|
+
constructor(_injector, _themeService, _shortcutService, _sheetSkeletonManagerService) {
|
|
3725
3756
|
super();
|
|
3726
3757
|
__publicField(this, "_downObserver");
|
|
3727
3758
|
__publicField(this, "_scenePointerMoveSub");
|
|
@@ -3767,11 +3798,6 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3767
3798
|
__publicField(this, "_singleSelectionEnabled", !1);
|
|
3768
3799
|
// #endregion
|
|
3769
3800
|
__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
3801
|
__publicField(this, "selectionMoveEnd$", this._selectionMoveEnd$.asObservable());
|
|
3776
3802
|
__publicField(this, "_selectionMoving$", new Subject());
|
|
3777
3803
|
__publicField(this, "selectionMoving$", this._selectionMoving$.asObservable());
|
|
@@ -3780,7 +3806,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3780
3806
|
__publicField(this, "_selectionMoving", !1);
|
|
3781
3807
|
__publicField(this, "_activeViewport");
|
|
3782
3808
|
__publicField(this, "interceptor", new InterceptorManager({ RANGE_MOVE_PERMISSION_CHECK, RANGE_FILL_PERMISSION_CHECK }));
|
|
3783
|
-
this
|
|
3809
|
+
__publicField(this, "_escapeShortcutDisposable", null);
|
|
3810
|
+
this._injector = _injector, this._themeService = _themeService, this._shortcutService = _shortcutService, this._sheetSkeletonManagerService = _sheetSkeletonManagerService, this._resetSelectionStyle(), this._initMoving();
|
|
3784
3811
|
}
|
|
3785
3812
|
get selectionMoving() {
|
|
3786
3813
|
return this._selectionMoving;
|
|
@@ -3792,11 +3819,14 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3792
3819
|
this._selectionMoving = !1;
|
|
3793
3820
|
}));
|
|
3794
3821
|
}
|
|
3795
|
-
|
|
3822
|
+
_setSelectionStyle(style) {
|
|
3796
3823
|
this._selectionStyle = style;
|
|
3797
3824
|
}
|
|
3798
|
-
|
|
3799
|
-
|
|
3825
|
+
/**
|
|
3826
|
+
* Reset this._selectionStyle to default normal selection style
|
|
3827
|
+
*/
|
|
3828
|
+
_resetSelectionStyle() {
|
|
3829
|
+
this._setSelectionStyle(getNormalSelectionStyle(this._themeService));
|
|
3800
3830
|
}
|
|
3801
3831
|
/** @deprecated This should not be provided by the selection render service. */
|
|
3802
3832
|
getViewPort() {
|
|
@@ -3806,37 +3836,15 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3806
3836
|
this._singleSelectionEnabled = enabled;
|
|
3807
3837
|
}
|
|
3808
3838
|
/**
|
|
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
|
|
3839
|
+
* Add a selection in spreadsheet, create a new SelectionControl and then update this control by range derives from selection.
|
|
3840
|
+
* @param {ISelectionWithCoordAndStyle} selection
|
|
3833
3841
|
*/
|
|
3834
3842
|
_addSelectionControlBySelectionData(selection) {
|
|
3835
3843
|
var _a59;
|
|
3836
|
-
const
|
|
3844
|
+
const skeleton = this._skeleton, style = (_a59 = selection.style) != null ? _a59 : getNormalSelectionStyle(this._themeService), scene = this._scene;
|
|
3837
3845
|
if (!scene || !skeleton)
|
|
3838
3846
|
return;
|
|
3839
|
-
const control = this.newSelectionControl(scene, rangeType || RANGE_TYPE.NORMAL);
|
|
3847
|
+
const { rangeWithCoord, primaryWithCoord } = selection, { rangeType } = rangeWithCoord, control = this.newSelectionControl(scene, rangeType || RANGE_TYPE.NORMAL, skeleton);
|
|
3840
3848
|
new SelectionShapeExtension(control, skeleton, scene, this._themeService, this._injector, {
|
|
3841
3849
|
selectionMoveEnd: /* @__PURE__ */ __name(() => {
|
|
3842
3850
|
this._selectionMoveEnd$.next(this.getSelectionDataWithStyle());
|
|
@@ -3845,27 +3853,25 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3845
3853
|
const { rowHeaderWidth, columnHeaderHeight } = skeleton;
|
|
3846
3854
|
control.update(rangeWithCoord, rowHeaderWidth, columnHeaderHeight, style, primaryWithCoord);
|
|
3847
3855
|
}
|
|
3848
|
-
newSelectionControl(scene, _rangeType) {
|
|
3849
|
-
const
|
|
3856
|
+
newSelectionControl(scene, _rangeType, skeleton) {
|
|
3857
|
+
const zIndex = this.getSelectionControls().length, { rowHeaderWidth, columnHeaderHeight } = skeleton, control = new SelectionControl(scene, zIndex, this._themeService, this._isHeaderHighlight, {
|
|
3858
|
+
rowHeaderWidth,
|
|
3859
|
+
columnHeaderHeight
|
|
3860
|
+
});
|
|
3850
3861
|
return this._selectionControls.push(control), control;
|
|
3851
3862
|
}
|
|
3852
3863
|
/**
|
|
3853
3864
|
* Update the corresponding selectionControl based on selectionsData.
|
|
3854
|
-
* selectionData[i]
|
|
3865
|
+
* selectionData[i] syncs selectionControls[i]
|
|
3855
3866
|
* @param selections
|
|
3856
3867
|
*/
|
|
3857
3868
|
updateControlForCurrentByRangeData(selections) {
|
|
3858
3869
|
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
|
-
}
|
|
3870
|
+
if (!(!selectionControls || this._skeleton == null))
|
|
3871
|
+
for (let i = 0, len = selections.length; i < len; i++) {
|
|
3872
|
+
const { rangeWithCoord, primaryWithCoord } = selections[i], control = selectionControls[i];
|
|
3873
|
+
control && control.updateRange(rangeWithCoord, primaryWithCoord);
|
|
3874
|
+
}
|
|
3869
3875
|
}
|
|
3870
3876
|
refreshSelectionMoveStart() {
|
|
3871
3877
|
this._selectionMoveStart$.next(this.getSelectionDataWithStyle());
|
|
@@ -3876,6 +3882,10 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3876
3882
|
getSkeleton() {
|
|
3877
3883
|
return this._skeleton;
|
|
3878
3884
|
}
|
|
3885
|
+
/**
|
|
3886
|
+
* Generate selectionData from this._selectionControls.model .
|
|
3887
|
+
* @returns {ISelectionWithCoordAndStyle[]} {range, primary, style}[]
|
|
3888
|
+
*/
|
|
3879
3889
|
getSelectionDataWithStyle() {
|
|
3880
3890
|
const selectionControls = this._selectionControls, [unitId, sheetId] = this._skeleton.getLocation();
|
|
3881
3891
|
return selectionControls.map((control) => {
|
|
@@ -3893,8 +3903,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3893
3903
|
this._selectionControls.length = 0;
|
|
3894
3904
|
}
|
|
3895
3905
|
_getFreeze() {
|
|
3896
|
-
var _a59
|
|
3897
|
-
return (
|
|
3906
|
+
var _a59;
|
|
3907
|
+
return (_a59 = this._sheetSkeletonManagerService.getCurrent()) == null ? void 0 : _a59.skeleton.getWorksheetConfig().freeze;
|
|
3898
3908
|
}
|
|
3899
3909
|
_getViewportByCell(row, column) {
|
|
3900
3910
|
if (row === void 0 || column === void 0)
|
|
@@ -3933,7 +3943,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3933
3943
|
return controls[controls.length - 1];
|
|
3934
3944
|
}
|
|
3935
3945
|
endSelection() {
|
|
3936
|
-
|
|
3946
|
+
var _a59;
|
|
3947
|
+
this._clearUpdatingListeners(), this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()), (_a59 = this._escapeShortcutDisposable) == null || _a59.dispose(), this._escapeShortcutDisposable = null;
|
|
3937
3948
|
}
|
|
3938
3949
|
/**
|
|
3939
3950
|
* Clear existed selections.
|
|
@@ -3967,7 +3978,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3967
3978
|
let { x: viewportPosX, y: viewportPosY } = relativeCoords;
|
|
3968
3979
|
this._startViewportPosX = viewportPosX, this._startViewportPosY = viewportPosY;
|
|
3969
3980
|
const scrollXY = scene.getVpScrollXYInfoByPosToVp(relativeCoords), { scaleX, scaleY } = scene.getAncestorScale(), cursorCellRangeInfo = this._getCellRangeByCursorPosition(viewportPosX, viewportPosY, scaleX, scaleY, scrollXY);
|
|
3970
|
-
if (!cursorCellRangeInfo) return
|
|
3981
|
+
if (!cursorCellRangeInfo) return;
|
|
3971
3982
|
const { rangeWithCoord: cursorCellRange, primaryWithCoord: primaryCursorCellRange } = cursorCellRangeInfo, cursorCellRangeWithRangeType = { ...cursorCellRange, rangeType };
|
|
3972
3983
|
this._startRangeWhenPointerDown = { ...cursorCellRange, rangeType };
|
|
3973
3984
|
let activeSelectionControl = this.getActiveSelectionControl();
|
|
@@ -3992,18 +4003,28 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
3992
4003
|
rangeType,
|
|
3993
4004
|
activeSelectionControl
|
|
3994
4005
|
// Get updated in this method
|
|
3995
|
-
) : remainLastEnable && activeSelectionControl ? this.
|
|
4006
|
+
) : remainLastEnable && activeSelectionControl ? this._updateSelectionControlByRange(
|
|
3996
4007
|
activeSelectionControl,
|
|
3997
4008
|
cursorCellRangeWithRangeType,
|
|
3998
4009
|
primaryCursorCellRange
|
|
3999
|
-
) : (activeSelectionControl = this.newSelectionControl(scene, rangeType), this.
|
|
4010
|
+
) : (activeSelectionControl = this.newSelectionControl(scene, rangeType, skeleton), this._updateSelectionControlByRange(
|
|
4000
4011
|
activeSelectionControl,
|
|
4001
4012
|
cursorCellRangeWithRangeType,
|
|
4002
4013
|
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.
|
|
4004
|
-
|
|
4014
|
+
)), 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._escapeShortcutDisposable = this._shortcutService.forceEscape(), this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent(() => {
|
|
4015
|
+
var _a60;
|
|
4016
|
+
this._clearUpdatingListeners(), this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()), (_a60 = this._escapeShortcutDisposable) == null || _a60.dispose(), this._escapeShortcutDisposable = null;
|
|
4005
4017
|
});
|
|
4006
4018
|
}
|
|
4019
|
+
/**
|
|
4020
|
+
* Init pointer move listener, bind in each pointer down, unbind in each pointer up
|
|
4021
|
+
* @param viewportMain
|
|
4022
|
+
* @param activeSelectionControl
|
|
4023
|
+
* @param rangeType
|
|
4024
|
+
* @param scrollTimerType
|
|
4025
|
+
* @param moveStartPosX
|
|
4026
|
+
* @param moveStartPosY
|
|
4027
|
+
*/
|
|
4007
4028
|
// eslint-disable-next-line max-lines-per-function
|
|
4008
4029
|
_setupPointerMoveListener(viewportMain, activeSelectionControl, rangeType, scrollTimerType = ScrollTimerType.ALL, moveStartPosX, moveStartPosY) {
|
|
4009
4030
|
var _a59, _b;
|
|
@@ -4013,7 +4034,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4013
4034
|
this._scenePointerMoveSub = scene.onPointerMove$.subscribeEvent((moveEvt) => {
|
|
4014
4035
|
var _a60, _b2, _c, _d, _e, _f, _g, _h, _i;
|
|
4015
4036
|
const { offsetX: moveOffsetX, offsetY: moveOffsetY } = moveEvt, { x: newMoveOffsetX, y: newMoveOffsetY } = scene.getRelativeToViewportCoord(Vector2.FromArray([moveOffsetX, moveOffsetY]));
|
|
4016
|
-
this.
|
|
4037
|
+
this._movingHandler(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
|
|
4017
4038
|
let scrollOffsetX = newMoveOffsetX, scrollOffsetY = newMoveOffsetY;
|
|
4018
4039
|
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
4040
|
if (startViewport && endViewport && viewportMain) {
|
|
@@ -4047,7 +4068,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4047
4068
|
lastX = newMoveOffsetX, lastY = newMoveOffsetY;
|
|
4048
4069
|
}
|
|
4049
4070
|
this._scrollTimer.scrolling(scrollOffsetX, scrollOffsetY, () => {
|
|
4050
|
-
this.
|
|
4071
|
+
this._movingHandler(newMoveOffsetX, newMoveOffsetY, activeSelectionControl, rangeType);
|
|
4051
4072
|
});
|
|
4052
4073
|
});
|
|
4053
4074
|
}
|
|
@@ -4072,8 +4093,8 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4072
4093
|
/**
|
|
4073
4094
|
* 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
4095
|
*/
|
|
4075
|
-
// eslint-disable-next-line max-lines-per-function
|
|
4076
|
-
|
|
4096
|
+
// eslint-disable-next-line max-lines-per-function, complexity
|
|
4097
|
+
_movingHandler(offsetX, offsetY, activeSelectionControl, rangeType) {
|
|
4077
4098
|
var _a59, _b, _c, _d, _e;
|
|
4078
4099
|
const skeleton = this._skeleton, scene = this._scene, [unitId, sheetId] = skeleton.getLocation(), currSelectionRange = {
|
|
4079
4100
|
startRow: (_a59 = activeSelectionControl == null ? void 0 : activeSelectionControl.model.startRow) != null ? _a59 : -1,
|
|
@@ -4089,7 +4110,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4089
4110
|
rangeType === RANGE_TYPE.ROW ? offsetX = Number.POSITIVE_INFINITY : rangeType === RANGE_TYPE.COLUMN && (offsetY = Number.POSITIVE_INFINITY);
|
|
4090
4111
|
const cursorCellRangeInfo = this._getCellRangeByCursorPosition(offsetX, offsetY, scaleX, scaleY, scrollXY);
|
|
4091
4112
|
if (!cursorCellRangeInfo)
|
|
4092
|
-
return
|
|
4113
|
+
return;
|
|
4093
4114
|
const { rangeWithCoord: cursorCellRange } = cursorCellRangeInfo, activeCellRange = this._startRangeWhenPointerDown;
|
|
4094
4115
|
let newSelectionRange = {
|
|
4095
4116
|
startRow: Math.min(cursorCellRange.startRow, activeCellRange.startRow),
|
|
@@ -4098,7 +4119,7 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4098
4119
|
endColumn: Math.max(cursorCellRange.endColumn, activeCellRange.endColumn)
|
|
4099
4120
|
};
|
|
4100
4121
|
if (this._shouldDetectMergedCells && (newSelectionRange = skeleton.getSelectionMergeBounding(newSelectionRange.startRow, newSelectionRange.startColumn, newSelectionRange.endRow, newSelectionRange.endColumn)), !newSelectionRange)
|
|
4101
|
-
return
|
|
4122
|
+
return;
|
|
4102
4123
|
const startCellXY = skeleton.getNoMergeCellPositionByIndex(newSelectionRange.startRow, newSelectionRange.startColumn), endCellXY = skeleton.getNoMergeCellPositionByIndex(newSelectionRange.endRow, newSelectionRange.endColumn), newSelectionRangeWithCoord = {
|
|
4103
4124
|
startRow: newSelectionRange.startRow,
|
|
4104
4125
|
startColumn: newSelectionRange.startColumn,
|
|
@@ -4111,11 +4132,16 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4111
4132
|
startX: (startCellXY == null ? void 0 : startCellXY.startX) || 0,
|
|
4112
4133
|
endX: (endCellXY == null ? void 0 : endCellXY.endX) || 0
|
|
4113
4134
|
}, rangeChanged = currSelectionRange.startRow !== newSelectionRange.startRow || currSelectionRange.startColumn !== newSelectionRange.startColumn || currSelectionRange.endRow !== newSelectionRange.endRow || currSelectionRange.endColumn !== newSelectionRange.endColumn;
|
|
4114
|
-
activeSelectionControl != null && rangeChanged && (this.
|
|
4135
|
+
activeSelectionControl != null && rangeChanged && (this._updateSelectionControlByRange(activeSelectionControl, newSelectionRangeWithCoord), this._selectionMoving$.next(this.getSelectionDataWithStyle()));
|
|
4115
4136
|
}
|
|
4116
|
-
|
|
4117
|
-
|
|
4118
|
-
|
|
4137
|
+
/**
|
|
4138
|
+
* Update the selection control by range.
|
|
4139
|
+
* @param control
|
|
4140
|
+
* @param newSelectionRange
|
|
4141
|
+
* @param highlight
|
|
4142
|
+
*/
|
|
4143
|
+
_updateSelectionControlByRange(control, newSelectionRange, highlight) {
|
|
4144
|
+
control.updateRange(newSelectionRange, highlight);
|
|
4119
4145
|
}
|
|
4120
4146
|
_clearUpdatingListeners() {
|
|
4121
4147
|
var _a59, _b, _c, _d, _e;
|
|
@@ -4196,8 +4222,12 @@ const ISheetSelectionRenderService = createIdentifier("univer.sheet.selection-re
|
|
|
4196
4222
|
startX: activeCell.mergeInfo.startX || 0,
|
|
4197
4223
|
endX: activeCell.mergeInfo.endX || 0,
|
|
4198
4224
|
rangeType
|
|
4199
|
-
}, this.
|
|
4225
|
+
}, this._updateSelectionControlByRange(activeControl, newSelectionRange, currentCell);
|
|
4200
4226
|
}
|
|
4227
|
+
/**
|
|
4228
|
+
* Reset all this.selectionControls by selectionsData.
|
|
4229
|
+
* @param selectionsData
|
|
4230
|
+
*/
|
|
4201
4231
|
_refreshSelectionControl(selectionsData) {
|
|
4202
4232
|
const selections = selectionsData.map((selectionWithStyle) => {
|
|
4203
4233
|
const selectionData = attachSelectionWithCoord(selectionWithStyle, this._skeleton);
|
|
@@ -4354,7 +4384,7 @@ let EditorBridgeService = (_a7 = class extends Disposable {
|
|
|
4354
4384
|
}
|
|
4355
4385
|
documentLayoutObject = blankModel;
|
|
4356
4386
|
}
|
|
4357
|
-
if ((_b = documentLayoutObject.documentModel) == null || _b.setZoomRatio(Math.max(scaleX, scaleY)), (cell == null ? void 0 : cell.isInArrayFormulaRange) === !0) {
|
|
4387
|
+
if (documentLayoutObject.fill = documentLayoutObject.fill || "#fff", (_b = documentLayoutObject.documentModel) == null || _b.setZoomRatio(Math.max(scaleX, scaleY)), (cell == null ? void 0 : cell.isInArrayFormulaRange) === !0) {
|
|
4358
4388
|
const body = (_c = documentLayoutObject.documentModel) == null ? void 0 : _c.getBody();
|
|
4359
4389
|
body && (body.textRuns = [
|
|
4360
4390
|
{
|
|
@@ -4509,6 +4539,10 @@ let SheetsZoomRenderController = (_a8 = class extends Disposable {
|
|
|
4509
4539
|
this._updateViewZoom(zoomRatio);
|
|
4510
4540
|
}));
|
|
4511
4541
|
}
|
|
4542
|
+
/**
|
|
4543
|
+
* Zoom scene, resize viewport and then setScrollInfo
|
|
4544
|
+
* @param zoomRatio
|
|
4545
|
+
*/
|
|
4512
4546
|
_updateViewZoom(zoomRatio) {
|
|
4513
4547
|
const sheetObject = this._getSheetObject();
|
|
4514
4548
|
sheetObject == null || sheetObject.scene.scale(zoomRatio, zoomRatio), sheetObject == null || sheetObject.spreadsheet.makeForceDirty();
|
|
@@ -5721,7 +5755,7 @@ var __defProp$K = Object.defineProperty, __getOwnPropDesc$K = Object.getOwnPrope
|
|
|
5721
5755
|
(decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
|
|
5722
5756
|
return kind && result && __defProp$K(target, key, result), result;
|
|
5723
5757
|
}, "__decorateClass$K"), __decorateParam$J = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$J");
|
|
5724
|
-
const DEFAULT_Z_INDEX =
|
|
5758
|
+
const DEFAULT_Z_INDEX = SELECTION_SHAPE_DEPTH.MARK_SELECTION, IMarkSelectionService = createIdentifier("univer.mark-selection-service");
|
|
5725
5759
|
var _a11;
|
|
5726
5760
|
let MarkSelectionService = (_a11 = class extends Disposable {
|
|
5727
5761
|
constructor(_currentService, _renderManagerService, _themeService) {
|
|
@@ -5751,14 +5785,16 @@ let MarkSelectionService = (_a11 = class extends Disposable {
|
|
|
5751
5785
|
this._shapeMap.forEach((shape) => {
|
|
5752
5786
|
var _a60;
|
|
5753
5787
|
const { unitId, subUnitId, selection, control: oldControl, zIndex } = shape;
|
|
5754
|
-
if (oldControl
|
|
5788
|
+
if (oldControl == null || oldControl.dispose(), unitId !== currentUnitId || subUnitId !== currentSubUnitId)
|
|
5755
5789
|
return;
|
|
5756
|
-
const
|
|
5790
|
+
const renderUnit = this._renderManagerService.getRenderById(unitId);
|
|
5757
5791
|
if (!renderUnit) return;
|
|
5758
5792
|
const skeleton = (_a60 = this._renderManagerService.withCurrentTypeOfUnit(UniverInstanceType.UNIVER_SHEET, SheetSkeletonManagerService)) == null ? void 0 : _a60.getCurrentSkeleton();
|
|
5759
5793
|
if (!skeleton) return;
|
|
5760
|
-
const { scene } = renderUnit, { rowHeaderWidth, columnHeaderHeight } = skeleton, control = new SelectionControl(scene, zIndex, !1,
|
|
5761
|
-
control.
|
|
5794
|
+
const { scene } = renderUnit, { rowHeaderWidth, columnHeaderHeight } = skeleton, control = new SelectionControl(scene, zIndex, this._themeService, !1, { rowHeaderWidth, columnHeaderHeight }), { rangeWithCoord, primaryWithCoord } = renderUnit.with(ISheetSelectionRenderService).attachSelectionWithCoord(selection);
|
|
5795
|
+
control.updateRange(rangeWithCoord, primaryWithCoord);
|
|
5796
|
+
const { style } = selection;
|
|
5797
|
+
style && control.updateStyle(style), shape.control = control;
|
|
5762
5798
|
});
|
|
5763
5799
|
}
|
|
5764
5800
|
getShapeMap() {
|
|
@@ -5768,12 +5804,12 @@ let MarkSelectionService = (_a11 = class extends Disposable {
|
|
|
5768
5804
|
const shapeInfo = this._shapeMap.get(id);
|
|
5769
5805
|
if (!shapeInfo) return;
|
|
5770
5806
|
const { control } = shapeInfo;
|
|
5771
|
-
control
|
|
5807
|
+
control == null || control.dispose(), this._shapeMap.delete(id);
|
|
5772
5808
|
}
|
|
5773
5809
|
removeAllShapes() {
|
|
5774
5810
|
for (const shape of this._shapeMap.values()) {
|
|
5775
5811
|
const { control } = shape;
|
|
5776
|
-
control
|
|
5812
|
+
control == null || control.dispose();
|
|
5777
5813
|
}
|
|
5778
5814
|
this._shapeMap.clear();
|
|
5779
5815
|
}
|
|
@@ -5824,7 +5860,7 @@ let FormatPainterService = (_a12 = class extends Disposable {
|
|
|
5824
5860
|
}
|
|
5825
5861
|
setStatus(status) {
|
|
5826
5862
|
this._updateRangeMark(status), this._status$.next(status), this.getHooks().forEach((hook) => {
|
|
5827
|
-
hook.onStatusChange(status);
|
|
5863
|
+
hook.onStatusChange !== void 0 && hook.onStatusChange(status);
|
|
5828
5864
|
});
|
|
5829
5865
|
}
|
|
5830
5866
|
getStatus() {
|
|
@@ -5839,14 +5875,27 @@ let FormatPainterService = (_a12 = class extends Disposable {
|
|
|
5839
5875
|
applyFormatPainter(unitId, subUnitId, range) {
|
|
5840
5876
|
const hooks = this.getHooks(), redoMutationsInfo = [], undoMutationsInfo = [];
|
|
5841
5877
|
hooks.forEach((h) => {
|
|
5842
|
-
|
|
5878
|
+
if (h.onApply !== void 0) {
|
|
5879
|
+
const applyReturn = h.onApply(
|
|
5880
|
+
unitId,
|
|
5881
|
+
subUnitId,
|
|
5882
|
+
range,
|
|
5883
|
+
this._selectionFormat
|
|
5884
|
+
);
|
|
5885
|
+
applyReturn && (redoMutationsInfo.push(...applyReturn.redos), undoMutationsInfo.push(...applyReturn.undos));
|
|
5886
|
+
}
|
|
5887
|
+
});
|
|
5888
|
+
for (const beforeHook of hooks)
|
|
5889
|
+
if (beforeHook.onBeforeApply !== void 0 && !beforeHook.onBeforeApply({
|
|
5843
5890
|
unitId,
|
|
5844
5891
|
subUnitId,
|
|
5845
5892
|
range,
|
|
5846
|
-
|
|
5847
|
-
|
|
5848
|
-
|
|
5849
|
-
|
|
5893
|
+
redoMutationsInfo,
|
|
5894
|
+
format: this._selectionFormat,
|
|
5895
|
+
undoMutationsInfo
|
|
5896
|
+
}))
|
|
5897
|
+
return !1;
|
|
5898
|
+
this._logService.log("[FormatPainterService]", "apply mutations", {
|
|
5850
5899
|
undoMutationsInfo,
|
|
5851
5900
|
redoMutationsInfo
|
|
5852
5901
|
});
|
|
@@ -6836,13 +6885,20 @@ const ICellEditorManagerService = createIdentifier(
|
|
|
6836
6885
|
id: DOCS_NORMAL_EDITOR_UNIT_ID_KEY,
|
|
6837
6886
|
body: {
|
|
6838
6887
|
dataStream: `${DEFAULT_EMPTY_DOCUMENT_VALUE}`,
|
|
6888
|
+
tables: [],
|
|
6839
6889
|
textRuns: [],
|
|
6840
6890
|
paragraphs: [
|
|
6841
6891
|
{
|
|
6842
6892
|
startIndex: 0
|
|
6843
6893
|
}
|
|
6894
|
+
],
|
|
6895
|
+
sectionBreaks: [
|
|
6896
|
+
{
|
|
6897
|
+
startIndex: 1
|
|
6898
|
+
}
|
|
6844
6899
|
]
|
|
6845
6900
|
},
|
|
6901
|
+
tableSource: {},
|
|
6846
6902
|
documentStyle: {
|
|
6847
6903
|
documentFlavor: DocumentFlavor.MODERN
|
|
6848
6904
|
}
|
|
@@ -7099,12 +7155,17 @@ function FormulaBar() {
|
|
|
7099
7155
|
body: {
|
|
7100
7156
|
dataStream: `${DEFAULT_EMPTY_DOCUMENT_VALUE}`,
|
|
7101
7157
|
textRuns: [],
|
|
7158
|
+
tables: [],
|
|
7102
7159
|
paragraphs: [
|
|
7103
7160
|
{
|
|
7104
7161
|
startIndex: 0
|
|
7105
7162
|
}
|
|
7106
|
-
]
|
|
7163
|
+
],
|
|
7164
|
+
sectionBreaks: [{
|
|
7165
|
+
startIndex: 1
|
|
7166
|
+
}]
|
|
7107
7167
|
},
|
|
7168
|
+
tableSource: {},
|
|
7108
7169
|
documentStyle: {
|
|
7109
7170
|
pageSize: {
|
|
7110
7171
|
width: Number.POSITIVE_INFINITY,
|
|
@@ -7570,8 +7631,13 @@ function handleStyle(cssRule, cssValue, docStyles) {
|
|
|
7570
7631
|
break;
|
|
7571
7632
|
}
|
|
7572
7633
|
case "color": {
|
|
7573
|
-
|
|
7574
|
-
|
|
7634
|
+
try {
|
|
7635
|
+
const color = new ColorKit(cssValue);
|
|
7636
|
+
color.isValid && (docStyles.cl = {
|
|
7637
|
+
rgb: color.toRgbString()
|
|
7638
|
+
});
|
|
7639
|
+
} catch {
|
|
7640
|
+
}
|
|
7575
7641
|
break;
|
|
7576
7642
|
}
|
|
7577
7643
|
case "background-color": {
|
|
@@ -8010,7 +8076,19 @@ __name(parseProperties, "parseProperties");
|
|
|
8010
8076
|
function parseColGroup(raw) {
|
|
8011
8077
|
const COLGROUP_TAG_REGEX = /<colgroup([\s\S]*?)>(.*?)<\/colgroup>/, colgroupMatch = raw.match(COLGROUP_TAG_REGEX), COL_TAG_REGEX = /<col([\s\S]*?)>/g;
|
|
8012
8078
|
let colMatches;
|
|
8013
|
-
|
|
8079
|
+
if (colgroupMatch != null && colgroupMatch[2] ? colMatches = colgroupMatch[2].matchAll(COL_TAG_REGEX) : colMatches = raw.matchAll(COL_TAG_REGEX), !colMatches)
|
|
8080
|
+
return null;
|
|
8081
|
+
const colPropertiesWithSpan = Array.from(colMatches).map((colMatch) => parseProperties(colMatch[1])), colProperties = [];
|
|
8082
|
+
return colPropertiesWithSpan.forEach((propertiesWithSpan) => {
|
|
8083
|
+
const span = Number(propertiesWithSpan.span);
|
|
8084
|
+
if (span)
|
|
8085
|
+
for (let i = 0; i < span; i++) {
|
|
8086
|
+
const propertiesWithoutSpan = { ...propertiesWithSpan };
|
|
8087
|
+
delete propertiesWithoutSpan.span, colProperties.push(propertiesWithoutSpan);
|
|
8088
|
+
}
|
|
8089
|
+
else
|
|
8090
|
+
colProperties.push(propertiesWithSpan);
|
|
8091
|
+
}), colProperties;
|
|
8014
8092
|
}
|
|
8015
8093
|
__name(parseColGroup, "parseColGroup");
|
|
8016
8094
|
function decodeHTMLEntities(input) {
|
|
@@ -8527,6 +8605,7 @@ let SheetClipboardService = (_a13 = class extends Disposable {
|
|
|
8527
8605
|
pasteType
|
|
8528
8606
|
);
|
|
8529
8607
|
}
|
|
8608
|
+
// eslint-disable-next-line max-lines-per-function
|
|
8530
8609
|
async _pasteInternal(copyId, pasteType) {
|
|
8531
8610
|
var _a59, _b;
|
|
8532
8611
|
const cachedData = Tools.deepClone(this._copyContentCache.get(copyId)), { range, matrix: cellMatrix, unitId: copyUnitId, subUnitId: copySubUnitId } = cachedData || {};
|
|
@@ -8548,13 +8627,17 @@ let SheetClipboardService = (_a13 = class extends Disposable {
|
|
|
8548
8627
|
});
|
|
8549
8628
|
const pasteTarget = this._getPastedRange(cellMatrix);
|
|
8550
8629
|
if (!pasteTarget) return !1;
|
|
8551
|
-
const
|
|
8552
|
-
if (!
|
|
8630
|
+
const pasteToWorksheet = (_b = this._univerInstanceService.getUniverSheetInstance(pasteTarget.unitId)) == null ? void 0 : _b.getSheetBySheetId(pasteTarget.subUnitId);
|
|
8631
|
+
if (!pasteToWorksheet)
|
|
8553
8632
|
return !1;
|
|
8554
|
-
const mergeData =
|
|
8633
|
+
const mergeData = pasteToWorksheet == null ? void 0 : pasteToWorksheet.getMergeData();
|
|
8555
8634
|
if (mergeData && mergeData.some((m2) => rangeIntersectWithDiscreteRange(m2, pasteTarget.pastedRange) && !discreteRangeContainsRange(pasteTarget.pastedRange, m2)))
|
|
8556
8635
|
return this._errorService.emit(this._localeService.t("clipboard.paste.overlappingMergedCells")), !1;
|
|
8557
|
-
const
|
|
8636
|
+
const pasteFromWorkbook = this._univerInstanceService.getUnit(copyUnitId);
|
|
8637
|
+
if (!pasteFromWorkbook) return !1;
|
|
8638
|
+
const pasteFromWorksheet = pasteFromWorkbook.getSheetBySheetId(copySubUnitId);
|
|
8639
|
+
if (!pasteFromWorksheet) return !1;
|
|
8640
|
+
const colManager = pasteFromWorksheet.getColumnManager(), rowManager = pasteFromWorksheet.getRowManager(), defaultColumnWidth = pasteFromWorksheet.getConfig().defaultColumnWidth, defaultRowHeight = pasteFromWorksheet.getConfig().defaultRowHeight, colProperties = [], rowProperties = [];
|
|
8558
8641
|
if (range.cols.forEach((i) => {
|
|
8559
8642
|
const column = colManager.getColumnOrCreate(i);
|
|
8560
8643
|
colProperties.push({ width: `${column.w || defaultColumnWidth}` });
|
|
@@ -8736,6 +8819,7 @@ let SheetClipboardService = (_a13 = class extends Disposable {
|
|
|
8736
8819
|
* @param cellMatrix
|
|
8737
8820
|
* @param range
|
|
8738
8821
|
*/
|
|
8822
|
+
// eslint-disable-next-line max-lines-per-function, complexity
|
|
8739
8823
|
_transformPastedData(rowCount, colCount, cellMatrix) {
|
|
8740
8824
|
const target = this._getPastingTarget(), { selection, unitId, subUnitId } = target;
|
|
8741
8825
|
if (!subUnitId || !selection)
|
|
@@ -9004,7 +9088,7 @@ const SHEET_CLIPBOARD_PRIORITY = 998, SheetCopyCommand = {
|
|
|
9004
9088
|
value: PREDEFINED_HOOK_NAME.SPECIAL_PASTE_BESIDES_BORDER
|
|
9005
9089
|
}), "handler")
|
|
9006
9090
|
};
|
|
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 || {});
|
|
9091
|
+
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
9092
|
function FormatPainterMenuItemFactory(accessor) {
|
|
9009
9093
|
const formatPainterService = accessor.get(IFormatPainterService);
|
|
9010
9094
|
return {
|
|
@@ -9789,7 +9873,7 @@ function FrozenMenuItemFactory(accessor) {
|
|
|
9789
9873
|
positions: [SHEET_FROZEN_MENU_ID, SHEET_FROZEN_HEADER_MENU_ID],
|
|
9790
9874
|
title: "rightClick.freeze",
|
|
9791
9875
|
icon: "FreezeToSelectedSingle",
|
|
9792
|
-
disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9876
|
+
// disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9793
9877
|
hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_SHEET)
|
|
9794
9878
|
};
|
|
9795
9879
|
}
|
|
@@ -9801,7 +9885,7 @@ function FrozenRowMenuItemFactory(accessor) {
|
|
|
9801
9885
|
positions: [SHEET_FROZEN_MENU_ID],
|
|
9802
9886
|
title: "rightClick.freezeRow",
|
|
9803
9887
|
icon: "FreezeRowSingle",
|
|
9804
|
-
disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9888
|
+
// disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9805
9889
|
hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_SHEET)
|
|
9806
9890
|
};
|
|
9807
9891
|
}
|
|
@@ -9813,7 +9897,7 @@ function FrozenColMenuItemFactory(accessor) {
|
|
|
9813
9897
|
positions: [SHEET_FROZEN_MENU_ID],
|
|
9814
9898
|
title: "rightClick.freezeCol",
|
|
9815
9899
|
icon: "FreezeColumnSingle",
|
|
9816
|
-
disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9900
|
+
// disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9817
9901
|
hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_SHEET)
|
|
9818
9902
|
};
|
|
9819
9903
|
}
|
|
@@ -9825,7 +9909,7 @@ function CancelFrozenMenuItemFactory(accessor) {
|
|
|
9825
9909
|
positions: [SHEET_FROZEN_MENU_ID, SHEET_FROZEN_HEADER_MENU_ID],
|
|
9826
9910
|
title: "rightClick.cancelFreeze",
|
|
9827
9911
|
icon: "CancelFreezeSingle",
|
|
9828
|
-
disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9912
|
+
// disabled$: getCurrentRangeDisable$(accessor, { workbookTypes: [WorkbookEditablePermission], worksheetTypes: [WorksheetEditPermission], rangeTypes: [RangeProtectionPermissionEditPoint] }),
|
|
9829
9913
|
hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_SHEET)
|
|
9830
9914
|
};
|
|
9831
9915
|
}
|
|
@@ -11065,8 +11149,10 @@ const SINGLE_MODE_WIDTH = 800, ROW_COUNT_THRESHOLD = 3, StatusBar = /* @__PURE__
|
|
|
11065
11149
|
sheetContainer
|
|
11066
11150
|
};
|
|
11067
11151
|
function RenderSheetFooter() {
|
|
11068
|
-
|
|
11152
|
+
const workbook = useActiveWorkbook(), footerMenus = useSimpleToolbarGroups(SheetMenuPosition.SHEET_FOOTER);
|
|
11153
|
+
return workbook ? /* @__PURE__ */ jsxRuntimeExports.jsxs("section", { className: styles$9.sheetContainer, "data-range-selector": !0, children: [
|
|
11069
11154
|
/* @__PURE__ */ jsxRuntimeExports.jsx(SheetBar, {}),
|
|
11155
|
+
footerMenus.map((item) => /* @__PURE__ */ jsxRuntimeExports.jsx(ToolbarItem, { ...item }, item.id)),
|
|
11070
11156
|
/* @__PURE__ */ jsxRuntimeExports.jsx(StatusBar, {}),
|
|
11071
11157
|
/* @__PURE__ */ jsxRuntimeExports.jsx(CountBar, {})
|
|
11072
11158
|
] }) : null;
|
|
@@ -11085,7 +11171,11 @@ function RenderSheetContent() {
|
|
|
11085
11171
|
__name(RenderSheetContent, "RenderSheetContent");
|
|
11086
11172
|
function useHasWorkbook() {
|
|
11087
11173
|
const univerInstanceService = useDependency(IUniverInstanceService), workbook = useObservable(() => univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET), null, !1, []);
|
|
11088
|
-
return useMemo(
|
|
11174
|
+
return useMemo(
|
|
11175
|
+
() => univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).length > 0,
|
|
11176
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
11177
|
+
[univerInstanceService, workbook]
|
|
11178
|
+
);
|
|
11089
11179
|
}
|
|
11090
11180
|
__name(useHasWorkbook, "useHasWorkbook");
|
|
11091
11181
|
const widthStyle = {
|
|
@@ -11217,7 +11307,7 @@ const widthStyle = {
|
|
|
11217
11307
|
const unitId = workbook.getUnitId(), getDefinedNameMap = /* @__PURE__ */ __name(() => {
|
|
11218
11308
|
const definedNameMap = definedNamesService.getDefinedNameMap(unitId);
|
|
11219
11309
|
return definedNameMap ? Array.from(Object.values(definedNameMap)) : [];
|
|
11220
|
-
}, "getDefinedNameMap"), [
|
|
11310
|
+
}, "getDefinedNameMap"), [editState2, setEditState] = useState(!1), [definedNames, setDefinedNames] = useState(getDefinedNameMap()), [editorKey, setEditorKey] = useState(null), [deleteConformKey, setDeleteConformKey] = useState();
|
|
11221
11311
|
useEffect(() => {
|
|
11222
11312
|
const definedNamesSubscription = definedNamesService.update$.subscribe(() => {
|
|
11223
11313
|
setDefinedNames(getDefinedNameMap());
|
|
@@ -11280,11 +11370,11 @@ const widthStyle = {
|
|
|
11280
11370
|
}, "getSheetNameBySheetId");
|
|
11281
11371
|
return /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$h.definedNameContainer, children: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$h.definedNameContainerScroll, children: [
|
|
11282
11372
|
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
|
|
11283
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: openInsertCloseKeyEditor, className: styles$h.definedNameContainerAddButton, style: { display:
|
|
11373
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: openInsertCloseKeyEditor, className: styles$h.definedNameContainerAddButton, style: { display: editState2 ? "none" : "flex" }, children: [
|
|
11284
11374
|
/* @__PURE__ */ jsxRuntimeExports.jsx(IncreaseSingle, {}),
|
|
11285
11375
|
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$h.definedNameContainerAddButtonText, children: localeService.t("definedName.addButton") })
|
|
11286
11376
|
] }),
|
|
11287
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(DefinedNameInput, { confirm: insertConfirm, cancel: closeInput, state:
|
|
11377
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(DefinedNameInput, { confirm: insertConfirm, cancel: closeInput, state: editState2, inputId: "insertDefinedName", name: getInsertDefinedName(), formulaOrRefString: getInertFormulaOrRefString() })
|
|
11288
11378
|
] }, "insertDefinedName"),
|
|
11289
11379
|
definedNames.map((definedName2, index) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
|
|
11290
11380
|
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { onClick: /* @__PURE__ */ __name(() => {
|
|
@@ -11334,20 +11424,27 @@ const DEFAULT_RANGE_RULE = {
|
|
|
11334
11424
|
unitId: "",
|
|
11335
11425
|
subUnitId: "",
|
|
11336
11426
|
permissionId: "",
|
|
11337
|
-
unitType:
|
|
11427
|
+
unitType: M.Unkonwn,
|
|
11338
11428
|
id: "",
|
|
11339
11429
|
ranges: []
|
|
11340
11430
|
};
|
|
11341
|
-
var viewState = /* @__PURE__ */ ((viewState2) => (viewState2.othersCanView = "othersCanView", viewState2.noOneElseCanView = "noOneElseCanView", viewState2))(viewState || {}), _a14;
|
|
11431
|
+
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
11432
|
let SheetPermissionPanelModel = (_a14 = class {
|
|
11343
11433
|
constructor() {
|
|
11344
11434
|
__publicField(this, "_rule", DEFAULT_RANGE_RULE);
|
|
11345
11435
|
__publicField(this, "_rule$", new BehaviorSubject(this._rule));
|
|
11346
11436
|
__publicField(this, "_oldRule");
|
|
11347
11437
|
__publicField(this, "_rangeErrorMsg$", new BehaviorSubject(""));
|
|
11438
|
+
__publicField(this, "_visible", !1);
|
|
11348
11439
|
__publicField(this, "rangeErrorMsg$", this._rangeErrorMsg$.asObservable());
|
|
11349
11440
|
__publicField(this, "rule$", this._rule$.asObservable());
|
|
11350
11441
|
}
|
|
11442
|
+
setVisible(v) {
|
|
11443
|
+
this._visible = v;
|
|
11444
|
+
}
|
|
11445
|
+
getVisible() {
|
|
11446
|
+
return this._visible;
|
|
11447
|
+
}
|
|
11351
11448
|
setRangeErrorMsg(msg) {
|
|
11352
11449
|
this._rangeErrorMsg$.next(msg);
|
|
11353
11450
|
}
|
|
@@ -11360,6 +11457,9 @@ let SheetPermissionPanelModel = (_a14 = class {
|
|
|
11360
11457
|
resetRule() {
|
|
11361
11458
|
this._rule = DEFAULT_RANGE_RULE, this._rule$.next(this._rule);
|
|
11362
11459
|
}
|
|
11460
|
+
reset() {
|
|
11461
|
+
this.setVisible(!1), this.resetRule(), this.setRangeErrorMsg(""), this.setOldRule(null);
|
|
11462
|
+
}
|
|
11363
11463
|
get oldRule() {
|
|
11364
11464
|
return this._oldRule;
|
|
11365
11465
|
}
|
|
@@ -11391,6 +11491,9 @@ const _SheetPermissionUserManagerService = class _SheetPermissionUserManagerServ
|
|
|
11391
11491
|
setUserList(userList) {
|
|
11392
11492
|
this._userList = userList;
|
|
11393
11493
|
}
|
|
11494
|
+
reset() {
|
|
11495
|
+
this._userList = [], this._oldCollaboratorList = [], this._selectUserList = [], this._selectUserList$.next([]), this._allUserList = [];
|
|
11496
|
+
}
|
|
11394
11497
|
get oldCollaboratorList() {
|
|
11395
11498
|
return this._oldCollaboratorList;
|
|
11396
11499
|
}
|
|
@@ -11454,10 +11557,10 @@ const UNIVER_SHEET_PERMISSION_PANEL = "UNIVER_SHEET_PERMISSION_PANEL", UNIVER_SH
|
|
|
11454
11557
|
showDetail
|
|
11455
11558
|
},
|
|
11456
11559
|
onClose: /* @__PURE__ */ __name(() => {
|
|
11457
|
-
sheetPermissionPanelModel.
|
|
11560
|
+
sheetPermissionPanelModel.reset(), sheetPermissionUserManagerService.reset();
|
|
11458
11561
|
}, "onClose")
|
|
11459
11562
|
};
|
|
11460
|
-
return sidebarService.open(sidebarProps), !0;
|
|
11563
|
+
return sheetPermissionPanelModel.setVisible(!0), sidebarService.open(sidebarProps), !0;
|
|
11461
11564
|
}
|
|
11462
11565
|
}, SheetPermissionOpenDialogOperation = {
|
|
11463
11566
|
type: CommandType.OPERATION,
|
|
@@ -11749,7 +11852,7 @@ const UNIVER_SHEET_PERMISSION_PANEL = "UNIVER_SHEET_PERMISSION_PANEL", UNIVER_SH
|
|
|
11749
11852
|
if (!params)
|
|
11750
11853
|
return !1;
|
|
11751
11854
|
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 ===
|
|
11855
|
+
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
11856
|
unitID: unitId,
|
|
11754
11857
|
undoMutations,
|
|
11755
11858
|
redoMutations
|
|
@@ -12818,9 +12921,10 @@ function getRemovePermissionDisable$(accessor) {
|
|
|
12818
12921
|
var _a59;
|
|
12819
12922
|
if (!worksheet)
|
|
12820
12923
|
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(
|
|
12924
|
+
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
12925
|
selectionProtectionRuleModel.ruleChange$,
|
|
12823
|
-
worksheetProtectionRuleModel.ruleChange
|
|
12926
|
+
worksheetProtectionRuleModel.ruleChange$,
|
|
12927
|
+
sheetSelectionsService.selectionMoveEnd$
|
|
12824
12928
|
).pipe(startWith(null));
|
|
12825
12929
|
return combineLatest([changes$, permission$]).pipe(
|
|
12826
12930
|
map(([_2, permission]) => {
|
|
@@ -13239,16 +13343,16 @@ var __defProp$F = Object.defineProperty, __getOwnPropDesc$F = Object.getOwnPrope
|
|
|
13239
13343
|
return kind && result && __defProp$F(target, key, result), result;
|
|
13240
13344
|
}, "__decorateClass$F"), __decorateParam$F = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$F"), _a16;
|
|
13241
13345
|
let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderService {
|
|
13242
|
-
constructor(_context, injector, themeService, shortcutService,
|
|
13346
|
+
constructor(_context, injector, themeService, shortcutService, selectionManagerService, sheetSkeletonManagerService, _logService, _commandService, _contextService) {
|
|
13243
13347
|
super(
|
|
13244
13348
|
injector,
|
|
13245
13349
|
themeService,
|
|
13246
13350
|
shortcutService,
|
|
13247
|
-
|
|
13351
|
+
sheetSkeletonManagerService
|
|
13248
13352
|
);
|
|
13249
13353
|
__publicField(this, "_workbookSelections");
|
|
13250
13354
|
__publicField(this, "_renderDisposable", null);
|
|
13251
|
-
this._context = _context, this.
|
|
13355
|
+
this._context = _context, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this._workbookSelections = selectionManagerService.getWorkbookSelections(this._context.unitId), this._init();
|
|
13252
13356
|
}
|
|
13253
13357
|
_init() {
|
|
13254
13358
|
const sheetObject = this._getSheetObject();
|
|
@@ -13277,9 +13381,9 @@ let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderServi
|
|
|
13277
13381
|
}
|
|
13278
13382
|
_initThemeChangeListener() {
|
|
13279
13383
|
this.disposeWithMe(this._themeService.currentTheme$.subscribe(() => {
|
|
13280
|
-
this.
|
|
13281
|
-
const
|
|
13282
|
-
|
|
13384
|
+
this._resetSelectionStyle();
|
|
13385
|
+
const selections = this._workbookSelections.getCurrentSelections();
|
|
13386
|
+
selections && this._refreshSelectionControl(selections);
|
|
13283
13387
|
}));
|
|
13284
13388
|
}
|
|
13285
13389
|
_normalSelectionDisabled() {
|
|
@@ -13303,8 +13407,7 @@ let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderServi
|
|
|
13303
13407
|
}));
|
|
13304
13408
|
}
|
|
13305
13409
|
/**
|
|
13306
|
-
*
|
|
13307
|
-
* selectionMoveEnd$ ---> _updateSelections --> selectionOperation@selectionManagerService.setSelections
|
|
13410
|
+
* Update selectionData to current sheet.
|
|
13308
13411
|
* @param selectionDataWithStyleList
|
|
13309
13412
|
* @param type
|
|
13310
13413
|
*/
|
|
@@ -13328,11 +13431,14 @@ let SheetSelectionRenderService = (_a16 = class extends BaseSelectionRenderServi
|
|
|
13328
13431
|
}
|
|
13329
13432
|
const unitId = this._context.unitId, { sheetId, skeleton } = param, { scene } = this._context, viewportMain = scene.getViewport(SHEET_VIEWPORT_KEY$1.VIEW_MAIN), prevSheetId = (_b = (_a59 = this._skeleton) == null ? void 0 : _a59.worksheet) == null ? void 0 : _b.getSheetId();
|
|
13330
13433
|
if (this._changeRuntime(skeleton, scene, viewportMain), this._normalSelectionDisabled()) return;
|
|
13331
|
-
prevSheetId !== skeleton.worksheet.getSheetId()
|
|
13332
|
-
|
|
13333
|
-
|
|
13334
|
-
|
|
13335
|
-
|
|
13434
|
+
if (prevSheetId !== skeleton.worksheet.getSheetId()) {
|
|
13435
|
+
const selections = this._workbookSelections.getCurrentSelections();
|
|
13436
|
+
this._commandService.syncExecuteCommand(SetSelectionsOperation.id, {
|
|
13437
|
+
unitId,
|
|
13438
|
+
subUnitId: sheetId,
|
|
13439
|
+
selections: selections.length !== 0 ? selections : [getTopLeftSelection(skeleton)]
|
|
13440
|
+
});
|
|
13441
|
+
}
|
|
13336
13442
|
const currentSelections = this._workbookSelections.getCurrentSelections();
|
|
13337
13443
|
currentSelections != null && this._refreshSelectionControl(currentSelections);
|
|
13338
13444
|
}));
|
|
@@ -13349,12 +13455,11 @@ SheetSelectionRenderService = __decorateClass$F([
|
|
|
13349
13455
|
__decorateParam$F(1, Inject(Injector)),
|
|
13350
13456
|
__decorateParam$F(2, Inject(ThemeService)),
|
|
13351
13457
|
__decorateParam$F(3, IShortcutService),
|
|
13352
|
-
__decorateParam$F(4,
|
|
13353
|
-
__decorateParam$F(5, Inject(
|
|
13458
|
+
__decorateParam$F(4, Inject(SheetsSelectionsService)),
|
|
13459
|
+
__decorateParam$F(5, Inject(SheetSkeletonManagerService)),
|
|
13354
13460
|
__decorateParam$F(6, ILogService),
|
|
13355
13461
|
__decorateParam$F(7, ICommandService),
|
|
13356
|
-
__decorateParam$F(8, IContextService)
|
|
13357
|
-
__decorateParam$F(9, Inject(SheetSkeletonManagerService))
|
|
13462
|
+
__decorateParam$F(8, IContextService)
|
|
13358
13463
|
], SheetSelectionRenderService);
|
|
13359
13464
|
var __defProp$E = Object.defineProperty, __getOwnPropDesc$E = Object.getOwnPropertyDescriptor, __decorateClass$E = /* @__PURE__ */ __name((decorators, target, key, kind) => {
|
|
13360
13465
|
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$E(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
|
|
@@ -13698,11 +13803,11 @@ function getSetCellValueMutations(pasteTo, pasteFrom, matrix, accessor) {
|
|
|
13698
13803
|
var _a59;
|
|
13699
13804
|
let originNumberValue;
|
|
13700
13805
|
if (!value.p && value.v && !pasteFrom) {
|
|
13701
|
-
const content = String(value.v), numfmtValue = numfmt.
|
|
13702
|
-
numfmtValue
|
|
13806
|
+
const content = String(value.v), numfmtValue = numfmt.parseValue(content);
|
|
13807
|
+
(numfmtValue == null ? void 0 : numfmtValue.v) !== void 0 && typeof numfmtValue.v == "number" && (originNumberValue = numfmtValue.v);
|
|
13703
13808
|
}
|
|
13704
13809
|
const { row: realRow, col: realCol } = mapFunc(row, col);
|
|
13705
|
-
(_a59 = value.p) != null && _a59.body ? valueMatrix.setValue(realRow, realCol, Tools.deepClone({ p: value.p, v: originNumberValue != null ? originNumberValue : value.v })) : valueMatrix.setValue(realRow, realCol, Tools.deepClone({ v: originNumberValue != null ? originNumberValue : value.v }));
|
|
13810
|
+
(_a59 = value.p) != null && _a59.body ? valueMatrix.setValue(realRow, realCol, Tools.deepClone({ p: value.p, v: originNumberValue != null ? originNumberValue : value.v })) : valueMatrix.setValue(realRow, realCol, Tools.deepClone({ v: originNumberValue != null ? originNumberValue : value.v, t: value.t }));
|
|
13706
13811
|
});
|
|
13707
13812
|
const setValuesMutation = {
|
|
13708
13813
|
unitId,
|
|
@@ -13739,7 +13844,7 @@ function getSetCellStyleMutations(pasteTo, matrix, accessor, withRichFormat = !1
|
|
|
13739
13844
|
}, value.s)
|
|
13740
13845
|
};
|
|
13741
13846
|
withRichFormat && ((_a59 = value.p) != null && _a59.body) && (newValue.p = value.p);
|
|
13742
|
-
const content = String(value.v), numfmtValue = numfmt.
|
|
13847
|
+
const content = String(value.v), numfmtValue = numfmt.parseValue(content);
|
|
13743
13848
|
numfmtValue != null && numfmtValue.z && (newValue.s || (newValue.s = {}), typeof newValue.s == "object" && ((_b = newValue.s) != null && _b.n ? newValue.s.n.pattern = numfmtValue.z : newValue.s.n = { pattern: numfmtValue.z }));
|
|
13744
13849
|
const { row: actualRow, col: actualCol } = mapFunc(row, col);
|
|
13745
13850
|
valueMatrix.setValue(actualRow, actualCol, newValue);
|
|
@@ -13972,56 +14077,44 @@ let SheetClipboardController = (_a19 = class extends RxDisposable {
|
|
|
13972
14077
|
}), !1) : !0;
|
|
13973
14078
|
},
|
|
13974
14079
|
onPasteRows(pasteTo, rowProperties) {
|
|
13975
|
-
const { range } = pasteTo, redoMutations = [], undoMutations = [], maxRow = currentSheet.getMaxRows(), addingRowsCount = range.rows[range.rows.length - 1] -
|
|
14080
|
+
const { range } = pasteTo, redoMutations = [], undoMutations = [], maxRow = currentSheet.getMaxRows(), rowCount = maxRow - 1, addingRowsCount = range.rows[range.rows.length - 1] - rowCount, existingRowsCount = rowProperties.length - addingRowsCount, rowManager = currentSheet.getRowManager();
|
|
13976
14081
|
if (addingRowsCount > 0) {
|
|
13977
14082
|
const rowInfo = {};
|
|
13978
14083
|
rowProperties.slice(existingRowsCount).forEach((property, index) => {
|
|
13979
|
-
const {
|
|
13980
|
-
|
|
13981
|
-
const cssTextArray = style.split(";");
|
|
13982
|
-
let height = DEFAULT_WORKSHEET_ROW_HEIGHT;
|
|
13983
|
-
cssTextArray.find((css) => {
|
|
13984
|
-
css = css.toLowerCase();
|
|
13985
|
-
const key = textTrim(css.substr(0, css.indexOf(":"))), value = textTrim(css.substr(css.indexOf(":") + 1));
|
|
13986
|
-
return key === "height" ? (value.endsWith("pt") ? height = ptToPx(Number.parseFloat(value)) : height = Number.parseFloat(value), !0) : !1;
|
|
13987
|
-
}), rowInfo[index] = {
|
|
13988
|
-
h: height,
|
|
13989
|
-
hd: BooleanNumber.FALSE
|
|
13990
|
-
};
|
|
13991
|
-
} else PropertyHeight && (rowInfo[index] = {
|
|
14084
|
+
const { height: PropertyHeight } = property || {};
|
|
14085
|
+
PropertyHeight && (rowInfo[index] = {
|
|
13992
14086
|
h: Number.parseFloat(PropertyHeight),
|
|
13993
14087
|
hd: BooleanNumber.FALSE
|
|
13994
14088
|
});
|
|
13995
14089
|
});
|
|
13996
|
-
const
|
|
14090
|
+
const addRowRange = {
|
|
14091
|
+
startColumn: range.cols[0],
|
|
14092
|
+
endColumn: range.cols[range.cols.length - 1],
|
|
14093
|
+
endRow: range.rows[range.rows.length - 1],
|
|
14094
|
+
startRow: maxRow
|
|
14095
|
+
}, addRowMutation = {
|
|
13997
14096
|
unitId,
|
|
13998
14097
|
subUnitId,
|
|
13999
|
-
range:
|
|
14000
|
-
startColumn: range.cols[0],
|
|
14001
|
-
endColumn: range.cols[range.cols.length - 1],
|
|
14002
|
-
endRow: range.rows[range.rows.length - 1],
|
|
14003
|
-
startRow: maxRow
|
|
14004
|
-
},
|
|
14098
|
+
range: addRowRange,
|
|
14005
14099
|
rowInfo
|
|
14006
14100
|
};
|
|
14007
14101
|
redoMutations.push({
|
|
14008
14102
|
id: InsertRowMutation.id,
|
|
14009
14103
|
params: addRowMutation
|
|
14104
|
+
}), undoMutations.push({
|
|
14105
|
+
id: RemoveRowMutation.id,
|
|
14106
|
+
params: {
|
|
14107
|
+
unitId,
|
|
14108
|
+
subUnitId,
|
|
14109
|
+
range: addRowRange
|
|
14110
|
+
}
|
|
14010
14111
|
});
|
|
14011
14112
|
}
|
|
14012
14113
|
const rowHeight = {}, originRowHeight = {};
|
|
14013
|
-
rowProperties.slice(0, existingRowsCount).forEach((property, index) => {
|
|
14114
|
+
if (rowProperties.slice(0, existingRowsCount).forEach((property, index) => {
|
|
14014
14115
|
var _a59, _b;
|
|
14015
|
-
const {
|
|
14016
|
-
if (
|
|
14017
|
-
const cssTextArray = style.split(";");
|
|
14018
|
-
let height = DEFAULT_WORKSHEET_ROW_HEIGHT;
|
|
14019
|
-
cssTextArray.find((css) => {
|
|
14020
|
-
css = css.toLowerCase();
|
|
14021
|
-
const key = textTrim(css.substr(0, css.indexOf(":"))), value = textTrim(css.substr(css.indexOf(":") + 1));
|
|
14022
|
-
return key === "height" ? (value.endsWith("pt") ? height = ptToPx(Number.parseFloat(value)) : height = Number.parseFloat(value), !0) : !1;
|
|
14023
|
-
}), rowHeight[index + range.rows[0]] = height;
|
|
14024
|
-
} else if (propertyHeight) {
|
|
14116
|
+
const { height: propertyHeight } = property;
|
|
14117
|
+
if (propertyHeight) {
|
|
14025
14118
|
const rowConfigBeforePaste = rowManager.getRow(range.rows[0] + index), willSetHeight = Number.parseFloat(propertyHeight);
|
|
14026
14119
|
if (rowConfigBeforePaste) {
|
|
14027
14120
|
const { h = DEFAULT_WORKSHEET_ROW_HEIGHT, ah = 0 } = rowConfigBeforePaste, nowRowHeight = Math.max(h, ah);
|
|
@@ -14029,56 +14122,65 @@ let SheetClipboardController = (_a19 = class extends RxDisposable {
|
|
|
14029
14122
|
} else
|
|
14030
14123
|
rowHeight[index + range.rows[0]] = willSetHeight, originRowHeight[index + range.rows[0]] = (_b = (_a59 = rowManager.getRow(range.rows[0] + index)) == null ? void 0 : _a59.h) != null ? _b : DEFAULT_WORKSHEET_ROW_HEIGHT;
|
|
14031
14124
|
}
|
|
14032
|
-
})
|
|
14033
|
-
|
|
14034
|
-
|
|
14035
|
-
|
|
14036
|
-
|
|
14037
|
-
|
|
14038
|
-
|
|
14039
|
-
|
|
14040
|
-
|
|
14041
|
-
|
|
14042
|
-
|
|
14043
|
-
|
|
14044
|
-
|
|
14045
|
-
|
|
14046
|
-
|
|
14047
|
-
|
|
14048
|
-
|
|
14049
|
-
|
|
14050
|
-
|
|
14051
|
-
|
|
14052
|
-
|
|
14053
|
-
|
|
14125
|
+
}), Object.keys(rowHeight).length) {
|
|
14126
|
+
const setRowPropertyMutation = {
|
|
14127
|
+
unitId,
|
|
14128
|
+
subUnitId,
|
|
14129
|
+
ranges: [{
|
|
14130
|
+
startRow: range.rows[0],
|
|
14131
|
+
endRow: Math.min(range.rows[range.rows.length - 1], maxRow),
|
|
14132
|
+
startColumn: range.cols[0],
|
|
14133
|
+
endColumn: range.cols[range.cols.length - 1]
|
|
14134
|
+
}],
|
|
14135
|
+
rowHeight
|
|
14136
|
+
};
|
|
14137
|
+
redoMutations.push({
|
|
14138
|
+
id: SetWorksheetRowHeightMutation.id,
|
|
14139
|
+
params: setRowPropertyMutation
|
|
14140
|
+
}), undoMutations.push({
|
|
14141
|
+
id: SetWorksheetRowHeightMutation.id,
|
|
14142
|
+
params: {
|
|
14143
|
+
...setRowPropertyMutation,
|
|
14144
|
+
rowHeight: originRowHeight
|
|
14145
|
+
}
|
|
14146
|
+
});
|
|
14147
|
+
}
|
|
14148
|
+
return {
|
|
14054
14149
|
redos: redoMutations,
|
|
14055
14150
|
undos: undoMutations
|
|
14056
14151
|
};
|
|
14057
14152
|
},
|
|
14058
14153
|
onPasteColumns(pasteTo, colProperties, pasteType) {
|
|
14059
14154
|
var _a59;
|
|
14060
|
-
const { range } = pasteTo, redoMutations = [], maxColumn = currentSheet.getMaxColumns(), addingColsCount = range.cols[range.cols.length - 1] -
|
|
14155
|
+
const { range } = pasteTo, redoMutations = [], undoMutations = [], maxColumn = currentSheet.getMaxColumns(), colCount = maxColumn - 1, addingColsCount = range.cols[range.cols.length - 1] - colCount, existingColsCount = colProperties.length - addingColsCount, defaultColumnWidth = (_a59 = self._configService.getConfig(DEFAULT_WORKSHEET_COLUMN_WIDTH_KEY)) != null ? _a59 : DEFAULT_WORKSHEET_COLUMN_WIDTH, pasteToCols = range.cols;
|
|
14061
14156
|
if (addingColsCount > 0) {
|
|
14062
|
-
const
|
|
14157
|
+
const addColRange = {
|
|
14158
|
+
startRow: range.rows[0],
|
|
14159
|
+
endRow: range.rows[range.rows.length - 1],
|
|
14160
|
+
endColumn: range.cols[range.cols.length - 1],
|
|
14161
|
+
startColumn: maxColumn
|
|
14162
|
+
}, addColMutation = {
|
|
14063
14163
|
unitId,
|
|
14064
14164
|
subUnitId,
|
|
14065
|
-
range:
|
|
14066
|
-
|
|
14067
|
-
|
|
14068
|
-
endColumn: range.cols[range.cols.length - 1],
|
|
14069
|
-
startColumn: maxColumn
|
|
14070
|
-
},
|
|
14071
|
-
colInfo: colProperties.slice(existingColsCount).map((property) => ({
|
|
14072
|
-
w: property.width ? +property.width : defaultColumnWidth,
|
|
14165
|
+
range: addColRange,
|
|
14166
|
+
colInfo: colProperties.slice(existingColsCount).map((property, index) => ({
|
|
14167
|
+
w: property.width ? Math.max(+property.width, currentSheet.getColumnWidth(pasteToCols[index])) : defaultColumnWidth,
|
|
14073
14168
|
hd: BooleanNumber.FALSE
|
|
14074
14169
|
}))
|
|
14075
14170
|
};
|
|
14076
14171
|
redoMutations.push({
|
|
14077
14172
|
id: InsertColMutation.id,
|
|
14078
14173
|
params: addColMutation
|
|
14174
|
+
}), undoMutations.push({
|
|
14175
|
+
id: RemoveColMutation.id,
|
|
14176
|
+
params: {
|
|
14177
|
+
unitId,
|
|
14178
|
+
subUnitId,
|
|
14179
|
+
range: addColRange
|
|
14180
|
+
}
|
|
14079
14181
|
});
|
|
14080
14182
|
}
|
|
14081
|
-
const
|
|
14183
|
+
const targetSetColPropertyParams = {
|
|
14082
14184
|
unitId,
|
|
14083
14185
|
subUnitId,
|
|
14084
14186
|
ranges: [{
|
|
@@ -14086,15 +14188,30 @@ let SheetClipboardController = (_a19 = class extends RxDisposable {
|
|
|
14086
14188
|
endRow: range.rows[range.rows.length - 1],
|
|
14087
14189
|
startColumn: range.cols[0],
|
|
14088
14190
|
endColumn: Math.min(range.cols[range.cols.length - 1], maxColumn)
|
|
14089
|
-
}]
|
|
14090
|
-
colWidth: colProperties.slice(0, existingColsCount).map((property) => property.width ? +property.width : defaultColumnWidth)
|
|
14191
|
+
}]
|
|
14091
14192
|
};
|
|
14092
|
-
|
|
14093
|
-
|
|
14094
|
-
|
|
14095
|
-
|
|
14193
|
+
if (colProperties.length > 0) {
|
|
14194
|
+
const setColPropertyMutation = {
|
|
14195
|
+
...targetSetColPropertyParams,
|
|
14196
|
+
colWidth: colProperties.slice(0, existingColsCount).map((property, index) => property.width ? Math.max(+property.width, currentSheet.getColumnWidth(pasteToCols[index])) : defaultColumnWidth)
|
|
14197
|
+
}, undoSetColPropertyParams = {
|
|
14198
|
+
...targetSetColPropertyParams,
|
|
14199
|
+
colWidth: colProperties.slice(0, existingColsCount).map((_property, index) => {
|
|
14200
|
+
var _a60;
|
|
14201
|
+
return (_a60 = currentSheet.getColumnWidth(pasteToCols[index])) != null ? _a60 : defaultColumnWidth;
|
|
14202
|
+
})
|
|
14203
|
+
};
|
|
14204
|
+
redoMutations.push({
|
|
14205
|
+
id: SetWorksheetColWidthMutation.id,
|
|
14206
|
+
params: setColPropertyMutation
|
|
14207
|
+
}), undoMutations.push({
|
|
14208
|
+
id: SetWorksheetColWidthMutation.id,
|
|
14209
|
+
params: undoSetColPropertyParams
|
|
14210
|
+
});
|
|
14211
|
+
}
|
|
14212
|
+
return {
|
|
14096
14213
|
redos: redoMutations,
|
|
14097
|
-
undos:
|
|
14214
|
+
undos: undoMutations
|
|
14098
14215
|
};
|
|
14099
14216
|
},
|
|
14100
14217
|
onPastePlainText(pasteTo, text, payload) {
|
|
@@ -14286,7 +14403,7 @@ let SheetClipboardController = (_a19 = class extends RxDisposable {
|
|
|
14286
14403
|
}
|
|
14287
14404
|
}, __name(_a19, "SheetClipboardController"), _a19);
|
|
14288
14405
|
SheetClipboardController = __decorateClass$C([
|
|
14289
|
-
OnLifecycle(LifecycleStages.
|
|
14406
|
+
OnLifecycle(LifecycleStages.Rendered, SheetClipboardController),
|
|
14290
14407
|
__decorateParam$C(0, Inject(Injector)),
|
|
14291
14408
|
__decorateParam$C(1, IUniverInstanceService),
|
|
14292
14409
|
__decorateParam$C(2, IRenderManagerService),
|
|
@@ -15011,6 +15128,8 @@ let EditingRenderController = (_a21 = class extends Disposable {
|
|
|
15011
15128
|
}
|
|
15012
15129
|
})), d.add(this._commandService.onCommandExecuted((command) => {
|
|
15013
15130
|
command.id === ClearSelectionFormatCommand.id && this._editorBridgeService.refreshEditCellState();
|
|
15131
|
+
})), d.add(this._commandService.onCommandExecuted((command) => {
|
|
15132
|
+
command.id === SetRangeValuesMutation.id && this._editorBridgeService.refreshEditCellState();
|
|
15014
15133
|
}));
|
|
15015
15134
|
const closeEditorOperation = [SetCellEditVisibleArrowOperation.id];
|
|
15016
15135
|
d.add(this._commandService.onCommandExecuted((command) => {
|
|
@@ -15034,6 +15153,7 @@ let EditingRenderController = (_a21 = class extends Disposable {
|
|
|
15034
15153
|
return getEditorObject(this._editorBridgeService.getCurrentEditorId(), this._renderManagerService);
|
|
15035
15154
|
}
|
|
15036
15155
|
async _handleEditorInvisible(param) {
|
|
15156
|
+
var _a59, _b;
|
|
15037
15157
|
const { keycode } = param;
|
|
15038
15158
|
this._setOpenForCurrent(null, null), this._cursorChange = 0, this._exitInput(param);
|
|
15039
15159
|
const editCellState = this._editorBridgeService.getEditCellState();
|
|
@@ -15052,11 +15172,7 @@ let EditingRenderController = (_a21 = class extends Disposable {
|
|
|
15052
15172
|
selections && this._commandService.syncExecuteCommand(SetSelectionsOperation.id, {
|
|
15053
15173
|
unitId: this._context.unit.getUnitId(),
|
|
15054
15174
|
subUnitId: worksheetId,
|
|
15055
|
-
|
|
15056
|
-
// in selection-manager.service.ts@setSelections
|
|
15057
|
-
// this._ensureWorkbookSelection(unitIdOrSelections).setSelections
|
|
15058
|
-
// would clear selection Data on selecitonManagerInstance.
|
|
15059
|
-
selections: [...selections]
|
|
15175
|
+
selections
|
|
15060
15176
|
});
|
|
15061
15177
|
return;
|
|
15062
15178
|
}
|
|
@@ -15068,7 +15184,7 @@ let EditingRenderController = (_a21 = class extends Disposable {
|
|
|
15068
15184
|
worksheet.getCellRaw(row, column) || {},
|
|
15069
15185
|
documentLayoutObject,
|
|
15070
15186
|
this._lexerTreeBuilder,
|
|
15071
|
-
(model) => this._resourceLoaderService.
|
|
15187
|
+
(model) => this._resourceLoaderService.saveUnit(model.getUnitId()),
|
|
15072
15188
|
this._localService,
|
|
15073
15189
|
this._functionService
|
|
15074
15190
|
);
|
|
@@ -15088,7 +15204,7 @@ let EditingRenderController = (_a21 = class extends Disposable {
|
|
|
15088
15204
|
)(cellData, context), finalCell = await this._editorBridgeService.interceptor.fetchThroughInterceptors(
|
|
15089
15205
|
this._editorBridgeService.interceptor.getInterceptPoints().AFTER_CELL_EDIT_ASYNC
|
|
15090
15206
|
)(Promise.resolve(cell), context);
|
|
15091
|
-
this._commandService.executeCommand(SetRangeValuesCommand.id, {
|
|
15207
|
+
(_b = (_a59 = finalCell == null ? void 0 : finalCell.custom) == null ? void 0 : _a59[UNIVER_INTERNAL]) != null && _b.origin && (finalCell.custom[UNIVER_INTERNAL] = null), this._commandService.executeCommand(SetRangeValuesCommand.id, {
|
|
15092
15208
|
subUnitId: sheetId,
|
|
15093
15209
|
unitId,
|
|
15094
15210
|
range: {
|
|
@@ -15204,23 +15320,47 @@ function getCellDataByInput(cellData, documentLayoutObject, lexerTreeBuilder, ge
|
|
|
15204
15320
|
} else if (isForceString(newDataStream)) {
|
|
15205
15321
|
const v = extractStringFromForceString(newDataStream);
|
|
15206
15322
|
cellData.v = v, cellData.f = null, cellData.si = null, cellData.p = null, cellData.t = CellValueType.FORCE_STRING;
|
|
15207
|
-
} else if (
|
|
15323
|
+
} else if (numfmt.parseDate(newDataStream) || numfmt.parseNumber(newDataStream) || numfmt.parseTime(newDataStream))
|
|
15324
|
+
cellData.v = newDataStream, cellData.f = null, cellData.si = null, cellData.p = null, cellData.t = CellValueType.NUMBER;
|
|
15325
|
+
else if (isRichText(body))
|
|
15208
15326
|
body.dataStream === `\r
|
|
15209
15327
|
` ? (cellData.v = "", cellData.f = null, cellData.si = null, cellData.p = null) : (cellData.p = snapshot, cellData.v = null, cellData.f = null, cellData.si = null);
|
|
15210
15328
|
else {
|
|
15211
15329
|
if ((newDataStream === cellData.v || newDataStream === "" && cellData.v == null) && cellData.p == null)
|
|
15212
15330
|
return null;
|
|
15213
15331
|
cellData.v = newDataStream, cellData.f = null, cellData.si = null, cellData.p = null;
|
|
15332
|
+
const style = getCellStyleBySnapshot(snapshot);
|
|
15333
|
+
style && (cellData.s = style);
|
|
15214
15334
|
}
|
|
15215
|
-
return cellData
|
|
15335
|
+
return cellData.custom = {
|
|
15336
|
+
[UNIVER_INTERNAL]: {
|
|
15337
|
+
origin: { ...cellData }
|
|
15338
|
+
}
|
|
15339
|
+
}, cellData;
|
|
15216
15340
|
}
|
|
15217
15341
|
__name(getCellDataByInput, "getCellDataByInput");
|
|
15218
15342
|
function isRichText(body) {
|
|
15219
15343
|
const { textRuns = [], paragraphs = [], customRanges, customBlocks = [] } = body, bodyNoLineBreak = body.dataStream.replace(`\r
|
|
15220
|
-
`, "");
|
|
15221
|
-
return textRuns.some((textRun) =>
|
|
15344
|
+
`, ""), richTextStyle = ["va"];
|
|
15345
|
+
return textRuns.some((textRun) => {
|
|
15346
|
+
var _a59;
|
|
15347
|
+
return !!(textRun.ts && Object.keys(textRun.ts).some((property) => richTextStyle.includes(property))) || Object.keys((_a59 = textRun.ts) != null ? _a59 : {}).length && textRun.ed - textRun.st < bodyNoLineBreak.length;
|
|
15348
|
+
}) || paragraphs.some((paragraph) => paragraph.bullet) || paragraphs.length >= 2 || !!(customRanges != null && customRanges.length) || customBlocks.length > 0;
|
|
15222
15349
|
}
|
|
15223
15350
|
__name(isRichText, "isRichText");
|
|
15351
|
+
function getCellStyleBySnapshot(snapshot) {
|
|
15352
|
+
const { body } = snapshot;
|
|
15353
|
+
if (!body) return null;
|
|
15354
|
+
const { textRuns = [] } = body;
|
|
15355
|
+
let style = {};
|
|
15356
|
+
const bodyNoLineBreak = body.dataStream.replace(`\r
|
|
15357
|
+
`, "");
|
|
15358
|
+
return textRuns.forEach((textRun) => {
|
|
15359
|
+
const { st, ed, ts } = textRun;
|
|
15360
|
+
ed - st >= bodyNoLineBreak.length && (style = { ...style, ...ts });
|
|
15361
|
+
}), Object.keys(style).length ? style : null;
|
|
15362
|
+
}
|
|
15363
|
+
__name(getCellStyleBySnapshot, "getCellStyleBySnapshot");
|
|
15224
15364
|
var __defProp$z = Object.defineProperty, __getOwnPropDesc$z = Object.getOwnPropertyDescriptor, __decorateClass$z = /* @__PURE__ */ __name((decorators, target, key, kind) => {
|
|
15225
15365
|
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$z(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
|
|
15226
15366
|
(decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
|
|
@@ -15347,7 +15487,7 @@ let HeaderFreezeRenderController = (_a23 = class extends Disposable {
|
|
|
15347
15487
|
const { scene } = sheetObject;
|
|
15348
15488
|
if (this._freezePointerEnterSubs = new Subscription(), this._freezePointerLeaveSubs = new Subscription(), this._freezeDownSubs = new Subscription(), freezeObjectMainRect) {
|
|
15349
15489
|
const _freezeObjectMainRectEnterSub = freezeObjectMainRect.onPointerEnter$.subscribeEvent(() => {
|
|
15350
|
-
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(
|
|
15490
|
+
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0, null))
|
|
15351
15491
|
return !1;
|
|
15352
15492
|
freezeObjectHeaderRect == null || freezeObjectHeaderRect.setProps({
|
|
15353
15493
|
fill: this._freezeHoverColor,
|
|
@@ -15365,7 +15505,7 @@ let HeaderFreezeRenderController = (_a23 = class extends Disposable {
|
|
|
15365
15505
|
}
|
|
15366
15506
|
if (freezeObjectHeaderRect) {
|
|
15367
15507
|
const _freezeObjHeaderPointerEnterSub = freezeObjectHeaderRect.onPointerEnter$.subscribeEvent(() => {
|
|
15368
|
-
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(
|
|
15508
|
+
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0, null))
|
|
15369
15509
|
return !1;
|
|
15370
15510
|
freezeObjectHeaderRect == null || freezeObjectHeaderRect.setProps({
|
|
15371
15511
|
fill: this._freezeHoverColor,
|
|
@@ -15430,7 +15570,7 @@ let HeaderFreezeRenderController = (_a23 = class extends Disposable {
|
|
|
15430
15570
|
const sheetObject = this._getSheetObject();
|
|
15431
15571
|
if (sheetObject == null)
|
|
15432
15572
|
return;
|
|
15433
|
-
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(
|
|
15573
|
+
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0, null))
|
|
15434
15574
|
return !1;
|
|
15435
15575
|
const { scene } = sheetObject;
|
|
15436
15576
|
scene.setCursor(CURSOR_TYPE.GRABBING), scene.disableEvent();
|
|
@@ -15447,7 +15587,7 @@ let HeaderFreezeRenderController = (_a23 = class extends Disposable {
|
|
|
15447
15587
|
activeViewport || void 0,
|
|
15448
15588
|
!0
|
|
15449
15589
|
);
|
|
15450
|
-
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(
|
|
15590
|
+
if (!this.interceptor.fetchThroughInterceptors(FREEZE_PERMISSION_CHECK)(!0, null))
|
|
15451
15591
|
return !1;
|
|
15452
15592
|
scene.setCursor(CURSOR_TYPE.GRABBING);
|
|
15453
15593
|
const FREEZE_SIZE = FREEZE_SIZE_NORMAL / Math.max(scene.scaleX, scene.scaleY);
|
|
@@ -16508,8 +16648,10 @@ const HEADER_MENU_SHAPE_RECT_BACKGROUND_FILL = "rgba(120, 120, 120, 0.01)", HEAD
|
|
|
16508
16648
|
return this._color;
|
|
16509
16649
|
}
|
|
16510
16650
|
_draw(ctx) {
|
|
16651
|
+
const scene = this.getScene();
|
|
16652
|
+
if (!scene) return;
|
|
16653
|
+
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
16654
|
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
16655
|
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
16656
|
width: this.width,
|
|
16515
16657
|
height: this.height,
|
|
@@ -16727,13 +16869,13 @@ let HeaderResizeRenderController = (_a26 = class extends Disposable {
|
|
|
16727
16869
|
), this.disposeWithMe(
|
|
16728
16870
|
toDisposable(
|
|
16729
16871
|
eventBindingObject.onDblclick$.subscribeEvent(() => {
|
|
16730
|
-
var _a59;
|
|
16872
|
+
var _a59, _b;
|
|
16731
16873
|
initialType === 0 && (this._context.scene.resetCursor(), this._commandService.executeCommand(
|
|
16732
16874
|
SetWorksheetRowIsAutoHeightCommand.id,
|
|
16733
16875
|
{
|
|
16734
|
-
|
|
16876
|
+
ranges: [{ startRow: this._currentRow, endRow: this._currentRow, startColumn: 0, endColumn: ((_a59 = this._sheetSkeletonManagerService.getCurrent()) == null ? void 0 : _a59.skeleton.worksheet.getColumnCount()) || 0 }]
|
|
16735
16877
|
}
|
|
16736
|
-
), (
|
|
16878
|
+
), (_b = this._rowResizeRect) == null || _b.hide());
|
|
16737
16879
|
})
|
|
16738
16880
|
)
|
|
16739
16881
|
));
|
|
@@ -17127,7 +17269,7 @@ let SheetRenderController = (_a30 = class extends RxDisposable {
|
|
|
17127
17269
|
if (!worksheet)
|
|
17128
17270
|
throw new Error("No active sheet found");
|
|
17129
17271
|
const sheetId = worksheet.getSheetId();
|
|
17130
|
-
this._sheetSkeletonManagerService.setCurrent({ sheetId }),
|
|
17272
|
+
this._sheetSkeletonManagerService.setCurrent({ sheetId }), engine.runRenderLoop(() => scene.render());
|
|
17131
17273
|
}
|
|
17132
17274
|
_addComponent(workbook) {
|
|
17133
17275
|
const { scene, components } = this._context, worksheet = workbook.getActiveSheet();
|
|
@@ -17263,7 +17405,7 @@ let SheetRenderController = (_a30 = class extends RxDisposable {
|
|
|
17263
17405
|
}));
|
|
17264
17406
|
}
|
|
17265
17407
|
_initCommandListener() {
|
|
17266
|
-
this.disposeWithMe(this._commandService.onCommandExecuted((command) => {
|
|
17408
|
+
this.disposeWithMe(this._commandService.onCommandExecuted((command, options) => {
|
|
17267
17409
|
const { unit: workbook, unitId: workbookId } = this._context, { id: commandId } = command;
|
|
17268
17410
|
if (COMMAND_LISTENER_SKELETON_CHANGE.includes(commandId) || this._sheetRenderService.checkMutationShouldTriggerRerender(commandId)) {
|
|
17269
17411
|
const worksheet = workbook.getActiveSheet();
|
|
@@ -17279,7 +17421,7 @@ let SheetRenderController = (_a30 = class extends RxDisposable {
|
|
|
17279
17421
|
commandId
|
|
17280
17422
|
});
|
|
17281
17423
|
} else COMMAND_LISTENER_VALUE_CHANGE.includes(commandId) && this._sheetSkeletonManagerService.reCalculate();
|
|
17282
|
-
command.type === CommandType.MUTATION && this._markUnitDirty(workbookId, command);
|
|
17424
|
+
command.type === CommandType.MUTATION && (options == null ? void 0 : options.onlyLocal) !== !0 && this._markUnitDirty(workbookId, command);
|
|
17283
17425
|
}));
|
|
17284
17426
|
}
|
|
17285
17427
|
_markUnitDirty(unitId, command) {
|
|
@@ -17565,11 +17707,14 @@ let SheetCanvasPopManagerService = (_a33 = class extends Disposable {
|
|
|
17565
17707
|
* @param viewport target viewport
|
|
17566
17708
|
* @returns disposable
|
|
17567
17709
|
*/
|
|
17568
|
-
attachPopupToCell(row, col, popup, viewport, showOnSelectionMoving = !1) {
|
|
17710
|
+
attachPopupToCell(row, col, popup, _unitId, _subUnitId, viewport, showOnSelectionMoving = !1) {
|
|
17569
17711
|
const workbook = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), worksheet = workbook.getActiveSheet();
|
|
17570
17712
|
if (!worksheet)
|
|
17571
17713
|
return null;
|
|
17572
|
-
const unitId = workbook.getUnitId(), subUnitId = worksheet.getSheetId()
|
|
17714
|
+
const unitId = workbook.getUnitId(), subUnitId = worksheet.getSheetId();
|
|
17715
|
+
if (_unitId && unitId !== _unitId || _subUnitId && subUnitId !== _subUnitId)
|
|
17716
|
+
return null;
|
|
17717
|
+
const currentRender = this._renderManagerService.getRenderById(unitId), skeleton = currentRender == null ? void 0 : currentRender.with(SheetSkeletonManagerService).getOrCreateSkeleton({
|
|
17573
17718
|
sheetId: subUnitId
|
|
17574
17719
|
}), sheetSelectionRenderService = currentRender == null ? void 0 : currentRender.with(ISheetSelectionRenderService);
|
|
17575
17720
|
if (!currentRender || !skeleton || !sheetSelectionRenderService)
|
|
@@ -18439,8 +18584,8 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18439
18584
|
const target = getSheetCommandTarget(this._univerInstanceService);
|
|
18440
18585
|
if (!target)
|
|
18441
18586
|
return !1;
|
|
18442
|
-
const { worksheet, unitId, subUnitId } = target, selectionRange = (_a59 = this._selectionManagerService.getCurrentLastSelection()) == null ? void 0 : _a59.range;
|
|
18443
|
-
return !(!selectionRange || (direction === "top"
|
|
18587
|
+
const { worksheet, unitId, subUnitId } = target, selectionRange = Tools.deepClone((_a59 = this._selectionManagerService.getCurrentLastSelection()) == null ? void 0 : _a59.range);
|
|
18588
|
+
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
18589
|
}
|
|
18445
18590
|
_permissionCheckByWorksheetCommand(types) {
|
|
18446
18591
|
var _a59, _b;
|
|
@@ -18600,7 +18745,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18600
18745
|
if (sequenceGrid.sheetName) {
|
|
18601
18746
|
const targetSheet = workbook.getSheetBySheetName(sequenceGrid.sheetName);
|
|
18602
18747
|
if (!targetSheet)
|
|
18603
|
-
return !
|
|
18748
|
+
return !0;
|
|
18604
18749
|
const { startRow, endRow, startColumn, endColumn } = sequenceGrid.range;
|
|
18605
18750
|
for (let i2 = startRow; i2 <= endRow; i2++)
|
|
18606
18751
|
for (let j = startColumn; j <= endColumn; j++) {
|
|
@@ -18617,7 +18762,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18617
18762
|
return !0;
|
|
18618
18763
|
for (let i = 0; i < sequenceNodes.length; i++) {
|
|
18619
18764
|
const node = sequenceNodes[i];
|
|
18620
|
-
if (typeof node == "string")
|
|
18765
|
+
if (typeof node == "string" || node.nodeType !== sequenceNodeType.REFERENCE)
|
|
18621
18766
|
continue;
|
|
18622
18767
|
const { token } = node, sequenceGrid = deserializeRangeWithSheet(token), workbook2 = sequenceGrid.unitId ? this._univerInstanceService.getUnit(sequenceGrid.unitId) : this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
|
|
18623
18768
|
if (!workbook2) return !0;
|
|
@@ -18639,6 +18784,7 @@ let SheetPermissionInterceptorBaseController = (_a43 = class extends Disposable
|
|
|
18639
18784
|
return !1;
|
|
18640
18785
|
}
|
|
18641
18786
|
}
|
|
18787
|
+
return !0;
|
|
18642
18788
|
}
|
|
18643
18789
|
}
|
|
18644
18790
|
if (range) {
|
|
@@ -18727,8 +18873,8 @@ var __defProp$c = Object.defineProperty, __getOwnPropDesc$c = Object.getOwnPrope
|
|
|
18727
18873
|
return kind && result && __defProp$c(target, key, result), result;
|
|
18728
18874
|
}, "__decorateClass$c"), __decorateParam$c = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$c"), _a45;
|
|
18729
18875
|
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();
|
|
18876
|
+
constructor(_univerInstanceService, _dialogService, _permissionService, _authzIoService, _rangeProtectionRuleModel, _worksheetProtectionRuleModel, _userManagerService, _worksheetProtectionPointRuleModel, _sheetInterceptorService, _selectionProtectionRenderModel, _undoRedoService) {
|
|
18877
|
+
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
18878
|
}
|
|
18733
18879
|
_initRangePermissionFromSnapshot() {
|
|
18734
18880
|
const initRangePermissionFunc = /* @__PURE__ */ __name((workbook) => {
|
|
@@ -18739,7 +18885,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18739
18885
|
permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
|
|
18740
18886
|
objectID: rule.permissionId,
|
|
18741
18887
|
unitID: unitId,
|
|
18742
|
-
objectType:
|
|
18888
|
+
objectType: M.SelectRange,
|
|
18743
18889
|
actions: [P.View, P.Edit]
|
|
18744
18890
|
});
|
|
18745
18891
|
});
|
|
@@ -18763,7 +18909,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18763
18909
|
info.type !== "delete" ? this._authzIoService.allowed({
|
|
18764
18910
|
objectID: info.rule.permissionId,
|
|
18765
18911
|
unitID: info.unitId,
|
|
18766
|
-
objectType:
|
|
18912
|
+
objectType: M.SelectRange,
|
|
18767
18913
|
actions: [P.Edit, P.View]
|
|
18768
18914
|
}).then((actionList) => {
|
|
18769
18915
|
getAllRangePermissionPoint().forEach((F) => {
|
|
@@ -18787,7 +18933,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18787
18933
|
const unitId = _unitId || ((_a59 = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET)) == null ? void 0 : _a59.getUnitId());
|
|
18788
18934
|
unitId && this._authzIoService.allowed({
|
|
18789
18935
|
objectID: unitId,
|
|
18790
|
-
objectType:
|
|
18936
|
+
objectType: M.Workbook,
|
|
18791
18937
|
unitID: unitId,
|
|
18792
18938
|
actions: defaultWorkbookPermissionPoints
|
|
18793
18939
|
}).then((actionList) => {
|
|
@@ -18808,7 +18954,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18808
18954
|
info.type !== "delete" ? this._authzIoService.allowed({
|
|
18809
18955
|
objectID: info.rule.permissionId,
|
|
18810
18956
|
unitID: info.unitId,
|
|
18811
|
-
objectType:
|
|
18957
|
+
objectType: M.Worksheet,
|
|
18812
18958
|
actions: [P.Edit, P.View]
|
|
18813
18959
|
}).then((actionList) => {
|
|
18814
18960
|
getAllWorksheetPermissionPoint().forEach((F) => {
|
|
@@ -18828,7 +18974,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18828
18974
|
this._authzIoService.allowed({
|
|
18829
18975
|
objectID: info.permissionId,
|
|
18830
18976
|
unitID: info.unitId,
|
|
18831
|
-
objectType:
|
|
18977
|
+
objectType: M.Worksheet,
|
|
18832
18978
|
actions: defaultWorksheetPermissionPoint
|
|
18833
18979
|
}).then((actionList) => {
|
|
18834
18980
|
getAllWorksheetPermissionPointByPointPanel().forEach((F) => {
|
|
@@ -18847,14 +18993,14 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18847
18993
|
rule && (permissionIdWithRuleInstanceMap.set(rule.permissionId, rule), allAllowedParams.push({
|
|
18848
18994
|
objectID: rule.permissionId,
|
|
18849
18995
|
unitID: unitId,
|
|
18850
|
-
objectType:
|
|
18996
|
+
objectType: M.Worksheet,
|
|
18851
18997
|
actions: [P.Edit, P.View]
|
|
18852
18998
|
}));
|
|
18853
18999
|
const pointRule = this._worksheetProtectionPointRuleModel.getRule(unitId, subUnitId);
|
|
18854
19000
|
pointRule && (permissionIdWithRuleInstanceMap.set(pointRule.permissionId, pointRule), allAllowedParams.push({
|
|
18855
19001
|
objectID: pointRule.permissionId,
|
|
18856
19002
|
unitID: unitId,
|
|
18857
|
-
objectType:
|
|
19003
|
+
objectType: M.Worksheet,
|
|
18858
19004
|
actions: defaultWorksheetPermissionPoint
|
|
18859
19005
|
}));
|
|
18860
19006
|
}), allAllowedParams.length && this._authzIoService.batchAllowed(allAllowedParams).then((permissionMap) => {
|
|
@@ -18928,7 +19074,7 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18928
19074
|
handler: /* @__PURE__ */ __name((cell = {}, context, next) => {
|
|
18929
19075
|
var _a59, _b, _c, _d, _e;
|
|
18930
19076
|
const { unitId, subUnitId } = context, worksheetRule = this._worksheetProtectionRuleModel.getRule(unitId, subUnitId);
|
|
18931
|
-
if (worksheetRule != null && worksheetRule.permissionId
|
|
19077
|
+
if (worksheetRule != null && worksheetRule.permissionId) {
|
|
18932
19078
|
const selectionProtection = [{
|
|
18933
19079
|
[P.View]: (_b = (_a59 = this._permissionService.getPermissionPoint(new WorksheetViewPermission(unitId, subUnitId).id)) == null ? void 0 : _a59.value) != null ? _b : !1,
|
|
18934
19080
|
[P.Edit]: (_d = (_c = this._permissionService.getPermissionPoint(new WorksheetEditPermission(unitId, subUnitId).id)) == null ? void 0 : _c.value) != null ? _d : !1
|
|
@@ -18940,6 +19086,59 @@ let SheetPermissionInitController = (_a45 = class extends Disposable {
|
|
|
18940
19086
|
}
|
|
18941
19087
|
));
|
|
18942
19088
|
}
|
|
19089
|
+
refreshPermission(unitId, permissionId) {
|
|
19090
|
+
const sheetRuleItem = this._worksheetProtectionRuleModel.getTargetByPermissionId(unitId, permissionId);
|
|
19091
|
+
let needClearUndoRedo = !1;
|
|
19092
|
+
if (sheetRuleItem) {
|
|
19093
|
+
const [_, subUnitId] = sheetRuleItem;
|
|
19094
|
+
this._authzIoService.allowed({
|
|
19095
|
+
objectID: permissionId,
|
|
19096
|
+
unitID: unitId,
|
|
19097
|
+
objectType: M.Worksheet,
|
|
19098
|
+
actions: [P.Edit, P.View]
|
|
19099
|
+
}).then((actionList) => {
|
|
19100
|
+
let key = "";
|
|
19101
|
+
getAllWorksheetPermissionPoint().forEach((F) => {
|
|
19102
|
+
var _a59;
|
|
19103
|
+
const instance = new F(unitId, subUnitId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
|
|
19104
|
+
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}`);
|
|
19105
|
+
}), this._worksheetProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`), needClearUndoRedo && this._undoRedoService.clearUndoRedo(unitId);
|
|
19106
|
+
});
|
|
19107
|
+
}
|
|
19108
|
+
const sheetPointItem = this._worksheetProtectionPointRuleModel.getTargetByPermissionId(unitId, permissionId);
|
|
19109
|
+
if (sheetPointItem) {
|
|
19110
|
+
const [_, subUnitId] = sheetPointItem;
|
|
19111
|
+
this._authzIoService.allowed({
|
|
19112
|
+
objectID: permissionId,
|
|
19113
|
+
unitID: unitId,
|
|
19114
|
+
objectType: M.Worksheet,
|
|
19115
|
+
actions: defaultWorksheetPermissionPoint
|
|
19116
|
+
}).then((actionList) => {
|
|
19117
|
+
getAllWorksheetPermissionPointByPointPanel().forEach((F) => {
|
|
19118
|
+
var _a59;
|
|
19119
|
+
const instance = new F(unitId, subUnitId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
|
|
19120
|
+
action && (((_a59 = this._permissionService.getPermissionPoint(instance.id)) == null ? void 0 : _a59.value) !== action.allowed && (needClearUndoRedo = !0), this._permissionService.updatePermissionPoint(instance.id, action.allowed));
|
|
19121
|
+
}), needClearUndoRedo && this._undoRedoService.clearUndoRedo(unitId);
|
|
19122
|
+
});
|
|
19123
|
+
}
|
|
19124
|
+
const rangeRuleItem = this._rangeProtectionRuleModel.getTargetByPermissionId(unitId, permissionId);
|
|
19125
|
+
if (rangeRuleItem) {
|
|
19126
|
+
const [_, subUnitId] = rangeRuleItem;
|
|
19127
|
+
this._authzIoService.allowed({
|
|
19128
|
+
objectID: permissionId,
|
|
19129
|
+
unitID: unitId,
|
|
19130
|
+
objectType: M.SelectRange,
|
|
19131
|
+
actions: [P.Edit, P.View]
|
|
19132
|
+
}).then((actionList) => {
|
|
19133
|
+
let key = "";
|
|
19134
|
+
getAllRangePermissionPoint().forEach((F) => {
|
|
19135
|
+
var _a59;
|
|
19136
|
+
const instance = new F(unitId, subUnitId, permissionId), unitActionName = instance.subType, action = actionList.find((item) => item.action === unitActionName);
|
|
19137
|
+
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}`);
|
|
19138
|
+
}), this._rangeProtectionRuleModel.ruleRefresh(`${permissionId}_${key}`), needClearUndoRedo && this._undoRedoService.clearUndoRedo(unitId);
|
|
19139
|
+
});
|
|
19140
|
+
}
|
|
19141
|
+
}
|
|
18943
19142
|
}, __name(_a45, "SheetPermissionInitController"), _a45);
|
|
18944
19143
|
SheetPermissionInitController = __decorateClass$c([
|
|
18945
19144
|
OnLifecycle(LifecycleStages.Rendered, SheetPermissionInitController),
|
|
@@ -18952,293 +19151,39 @@ SheetPermissionInitController = __decorateClass$c([
|
|
|
18952
19151
|
__decorateParam$c(6, Inject(UserManagerService)),
|
|
18953
19152
|
__decorateParam$c(7, Inject(WorksheetProtectionPointModel)),
|
|
18954
19153
|
__decorateParam$c(8, Inject(SheetInterceptorService)),
|
|
18955
|
-
__decorateParam$c(9, Inject(RangeProtectionRenderModel))
|
|
19154
|
+
__decorateParam$c(9, Inject(RangeProtectionRenderModel)),
|
|
19155
|
+
__decorateParam$c(10, Inject(IUndoRedoService))
|
|
18956
19156
|
], SheetPermissionInitController);
|
|
18957
|
-
const UserEmptyBase64 = "", spinContainer = "univer-spin-container", spinOverlay = "univer-spin-overlay", spinner = "univer-spinner", spin = "univer-spin", contentBlur = "univer-content-blur", styles$7 = {
|
|
18958
|
-
|
|
18959
|
-
|
|
18960
|
-
|
|
18961
|
-
|
|
18962
|
-
|
|
18963
|
-
|
|
18964
|
-
|
|
18965
|
-
|
|
18966
|
-
|
|
18967
|
-
|
|
18968
|
-
|
|
18969
|
-
|
|
18970
|
-
|
|
18971
|
-
|
|
18972
|
-
|
|
18973
|
-
|
|
18974
|
-
|
|
18975
|
-
|
|
18976
|
-
|
|
18977
|
-
|
|
18978
|
-
sheetPermissionUserListEmptyText: sheetPermissionUserListEmptyText$1,
|
|
18979
|
-
sheetPermissionPanelTitle,
|
|
18980
|
-
permissionRangeSelector,
|
|
18981
|
-
permissionRangeSelectorError,
|
|
18982
|
-
sheetPermissionPanelNameInputError,
|
|
18983
|
-
permissionRangeSelectorErrorText,
|
|
18984
|
-
sheetPermissionPanelNameInputErrorText
|
|
18985
|
-
}, SheetPermissionPanelDetail = /* @__PURE__ */ __name(({ fromSheetBar }) => {
|
|
18986
|
-
var _a59, _b, _c;
|
|
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 ? "designedUserCanEdit" : "onlyMe"), [viewGroupValue, setViewGroupValue] = React.useState(viewState.othersCanView), [loading, setLoading] = useState(!1), handleAddPerson = /* @__PURE__ */ __name(async () => {
|
|
18988
|
-
const userList = await authzIoService.listCollaborators({
|
|
18989
|
-
objectID: unitId,
|
|
18990
|
-
unitID: unitId
|
|
18991
|
-
});
|
|
18992
|
-
userList.forEach((user) => {
|
|
18993
|
-
user != null && user.subject && userManagerService.addUser(user.subject);
|
|
18994
|
-
}), sheetPermissionUserManagerService.setUserList(userList), dialogService.open({
|
|
18995
|
-
id: UNIVER_SHEET_PERMISSION_USER_DIALOG_ID,
|
|
18996
|
-
title: { title: "" },
|
|
18997
|
-
children: { label: UNIVER_SHEET_PERMISSION_USER_DIALOG },
|
|
18998
|
-
width: 280,
|
|
18999
|
-
destroyOnClose: !0,
|
|
19000
|
-
onClose: /* @__PURE__ */ __name(() => dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID), "onClose"),
|
|
19001
|
-
className: "sheet-permission-user-dialog"
|
|
19002
|
-
});
|
|
19003
|
-
}, "handleAddPerson"), checkRangeValid = /* @__PURE__ */ __name((permissionRanges) => {
|
|
19004
|
-
let rangeErrorString = "";
|
|
19005
|
-
if (permissionRanges.length === 0)
|
|
19006
|
-
rangeErrorString = localeService.t("permission.panel.emptyRangeError");
|
|
19007
|
-
else if (permissionRanges.length > 1) {
|
|
19008
|
-
let hasLap = !1;
|
|
19009
|
-
for (let i = 0; i < permissionRanges.length; i++) {
|
|
19010
|
-
for (let j = i + 1; j < permissionRanges.length; j++)
|
|
19011
|
-
if (Rectangle.intersects(permissionRanges[i], permissionRanges[j])) {
|
|
19012
|
-
hasLap = !0;
|
|
19013
|
-
break;
|
|
19014
|
-
}
|
|
19015
|
-
if (hasLap)
|
|
19016
|
-
break;
|
|
19157
|
+
const useHighlightRange = /* @__PURE__ */ __name((ranges = []) => {
|
|
19158
|
+
const markSelectionService = useDependency(IMarkSelectionService);
|
|
19159
|
+
useEffect(() => {
|
|
19160
|
+
const ids = ranges.map((range) => markSelectionService.addShape({
|
|
19161
|
+
range,
|
|
19162
|
+
style: {
|
|
19163
|
+
hasAutoFill: !1,
|
|
19164
|
+
fill: "rgba(73, 184, 17, 0.05)",
|
|
19165
|
+
strokeWidth: 1,
|
|
19166
|
+
stroke: "#49B811",
|
|
19167
|
+
widgets: {}
|
|
19168
|
+
},
|
|
19169
|
+
primary: {
|
|
19170
|
+
startColumn: range.startColumn,
|
|
19171
|
+
endColumn: range.endColumn,
|
|
19172
|
+
startRow: range.startRow,
|
|
19173
|
+
endRow: range.endRow,
|
|
19174
|
+
actualRow: range.startRow,
|
|
19175
|
+
actualColumn: range.startColumn,
|
|
19176
|
+
isMerged: !1,
|
|
19177
|
+
isMergedMainCell: !1
|
|
19017
19178
|
}
|
|
19018
|
-
|
|
19019
|
-
|
|
19020
|
-
|
|
19021
|
-
|
|
19022
|
-
return rangeErrorString = localeService.t("permission.panel.rangeOverlapOverPermissionError"), rangeErrorString;
|
|
19023
|
-
const lapRule = rangeProtectionRuleModel.getSubunitRuleList(unitId, subUnitId).filter((rule) => rule.permissionId !== (activeRule == null ? void 0 : activeRule.permissionId)).find((rule) => rule.ranges.some((ruleRange) => permissionRanges.some((r) => Rectangle.intersects(ruleRange, r))));
|
|
19024
|
-
(lapRule == null ? void 0 : lapRule.ranges.find((range) => permissionRanges.some((r) => Rectangle.intersects(range, r)))) && (rangeErrorString = localeService.t("permission.panel.rangeOverlapOverPermissionError"));
|
|
19025
|
-
}
|
|
19026
|
-
return rangeErrorString;
|
|
19027
|
-
}, "checkRangeValid");
|
|
19028
|
-
return useEffect(() => {
|
|
19029
|
-
var _a60, _b2;
|
|
19030
|
-
if (activeRule == null ? void 0 : activeRule.permissionId) {
|
|
19031
|
-
activeRule.unitType === l$1.Worksheet && sheetPermissionPanelModel.setRule({
|
|
19032
|
-
ranges: [{
|
|
19033
|
-
startRow: 0,
|
|
19034
|
-
startColumn: 0,
|
|
19035
|
-
endRow: worksheet.getRowCount() - 1,
|
|
19036
|
-
endColumn: worksheet.getColumnCount() - 1,
|
|
19037
|
-
rangeType: RANGE_TYPE.ALL
|
|
19038
|
-
}]
|
|
19039
|
-
});
|
|
19040
|
-
return;
|
|
19041
|
-
}
|
|
19042
|
-
fromSheetBar && (selectionManagerService.clearCurrentSelections(), selectionManagerService.addSelections([
|
|
19043
|
-
{
|
|
19044
|
-
primary: null,
|
|
19045
|
-
style: null,
|
|
19046
|
-
range: {
|
|
19047
|
-
startRow: 0,
|
|
19048
|
-
startColumn: 0,
|
|
19049
|
-
endRow: worksheet.getRowCount() - 1,
|
|
19050
|
-
endColumn: worksheet.getColumnCount() - 1,
|
|
19051
|
-
rangeType: RANGE_TYPE.ALL
|
|
19052
|
-
}
|
|
19053
|
-
}
|
|
19054
|
-
]));
|
|
19055
|
-
const ranges = (_b2 = (_a60 = selectionManagerService.getCurrentSelections()) == null ? void 0 : _a60.map((s) => s.range)) != null ? _b2 : [], rangeErrorString = checkRangeValid(ranges);
|
|
19056
|
-
sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString);
|
|
19057
|
-
const rangeStr = ranges != null && ranges.length ? ranges.map((range) => {
|
|
19058
|
-
const v = serializeRange(range);
|
|
19059
|
-
return v === "NaN" ? "" : v;
|
|
19060
|
-
}).filter((r) => !!r).join(",") : "", sheetName = worksheet.getName();
|
|
19061
|
-
sheetPermissionPanelModel.setRule({
|
|
19062
|
-
ranges,
|
|
19063
|
-
name: fromSheetBar ? `${sheetName}` : `${sheetName}(${rangeStr})`,
|
|
19064
|
-
unitId,
|
|
19065
|
-
subUnitId,
|
|
19066
|
-
unitType: fromSheetBar ? l$1.Worksheet : l$1.SelectRange
|
|
19067
|
-
});
|
|
19068
|
-
}, [activeRule == null ? void 0 : activeRule.permissionId, fromSheetBar, selectionManagerService, sheetPermissionPanelModel, subUnitId, unitId, worksheet]), useEffect(() => {
|
|
19069
|
-
const getSelectUserList = /* @__PURE__ */ __name(async () => {
|
|
19070
|
-
const permissionId = activeRule == null ? void 0 : activeRule.permissionId;
|
|
19071
|
-
setLoading(!0);
|
|
19072
|
-
const collaborators = await authzIoService.listCollaborators({
|
|
19073
|
-
objectID: permissionId,
|
|
19074
|
-
unitID: unitId
|
|
19075
|
-
}), selectUserList2 = collaborators.filter((user) => user.role === M.Editor);
|
|
19076
|
-
sheetPermissionUserManagerService.setSelectUserList(selectUserList2), setLoading(!1), (selectUserList2 == null ? void 0 : selectUserList2.length) > 0 && setEditorGroupValue("designedUserCanEdit");
|
|
19077
|
-
const readerList = collaborators.filter((user) => user.role === M.Reader);
|
|
19078
|
-
readerList.length === 0 && setViewGroupValue(viewState.noOneElseCanView), sheetPermissionUserManagerService.setOldCollaboratorList(selectUserList2.concat(readerList));
|
|
19079
|
-
}, "getSelectUserList");
|
|
19080
|
-
activeRule != null && activeRule.permissionId ? getSelectUserList() : (sheetPermissionUserManagerService.setSelectUserList([]), setEditorGroupValue("onlyMe"));
|
|
19081
|
-
}, [activeRule == null ? void 0 : activeRule.permissionId]), useEffect(() => {
|
|
19082
|
-
(/* @__PURE__ */ __name(async () => {
|
|
19083
|
-
const userList = await authzIoService.listCollaborators({
|
|
19084
|
-
objectID: unitId,
|
|
19085
|
-
unitID: unitId
|
|
19086
|
-
});
|
|
19087
|
-
userList.forEach((user) => {
|
|
19088
|
-
user != null && user.subject && userManagerService.addUser(user.subject);
|
|
19089
|
-
}), sheetPermissionUserManagerService.setUserList(userList.filter((user) => user.role === M.Editor)), sheetPermissionUserManagerService.setAllUserList(userList.filter((user) => user.role === M.Editor || user.role === M.Reader));
|
|
19090
|
-
}, "getListCollaborators"))();
|
|
19091
|
-
}, []), useEffect(() => {
|
|
19092
|
-
sheetPermissionPanelModel.setRule({
|
|
19093
|
-
viewStatus: viewGroupValue
|
|
19094
|
-
});
|
|
19095
|
-
}, [sheetPermissionPanelModel, viewGroupValue]), useEffect(() => {
|
|
19096
|
-
const workbook2 = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
|
|
19097
|
-
if (!workbook2) return;
|
|
19098
|
-
const activeSheetSubscribe = workbook2.activeSheet$.subscribe((sheet) => {
|
|
19099
|
-
(sheet == null ? void 0 : sheet.getSheetId()) !== subUnitId && sidebarService.close();
|
|
19100
|
-
});
|
|
19101
|
-
return () => {
|
|
19102
|
-
activeSheetSubscribe.unsubscribe();
|
|
19103
|
-
};
|
|
19104
|
-
}, [sidebarService, subUnitId, univerInstanceService]), (_a59 = activeRule == null ? void 0 : activeRule.ranges) == null || _a59.map((i) => serializeRange(i)).join(","), /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.permissionPanelDetailWrapper, children: [
|
|
19105
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.protectedRange"), children: [
|
|
19106
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19107
|
-
RangeSelector,
|
|
19108
|
-
{
|
|
19109
|
-
className: clsx(styles$6.permissionRangeSelector),
|
|
19110
|
-
textEditorClassName: clsx({ [styles$6.permissionRangeSelectorError]: rangeErrorMsg }),
|
|
19111
|
-
value: (_b = activeRule == null ? void 0 : activeRule.ranges) == null ? void 0 : _b.map((i) => serializeRange(i)).join(","),
|
|
19112
|
-
id: createInternalEditorID("sheet-permission-panel"),
|
|
19113
|
-
openForSheetUnitId: unitId,
|
|
19114
|
-
openForSheetSubUnitId: subUnitId,
|
|
19115
|
-
onChange: /* @__PURE__ */ __name((newRange) => {
|
|
19116
|
-
if (newRange.some((i) => !isValidRange(i.range) || i.range.endColumn < i.range.startColumn || i.range.endRow < i.range.startRow))
|
|
19117
|
-
return;
|
|
19118
|
-
const workbook2 = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), worksheet2 = workbook2.getActiveSheet(), unitId2 = workbook2.getUnitId(), subUnitId2 = worksheet2.getSheetId(), transformedRange = newRange.map((i) => {
|
|
19119
|
-
const range = { ...i.range }, rowCount = worksheet2.getRowCount(), colCount = worksheet2.getColumnCount();
|
|
19120
|
-
return setEndForRange(range, rowCount, colCount), range;
|
|
19121
|
-
}), rangeErrorString = checkRangeValid(transformedRange);
|
|
19122
|
-
if (sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString), rangeErrorString) return;
|
|
19123
|
-
const sheetName = worksheet2.getName(), rangeStr = transformedRange.map((range) => {
|
|
19124
|
-
const v = serializeRange(range);
|
|
19125
|
-
return v === "NaN" ? "" : v;
|
|
19126
|
-
}).filter((r) => !!r).join(","), rule = {
|
|
19127
|
-
ranges: transformedRange,
|
|
19128
|
-
unitId: unitId2,
|
|
19129
|
-
subUnitId: subUnitId2,
|
|
19130
|
-
unitType: l$1.SelectRange,
|
|
19131
|
-
name: `${sheetName}(${rangeStr})`
|
|
19132
|
-
};
|
|
19133
|
-
if (rule.ranges.length === 1) {
|
|
19134
|
-
const { startRow, endRow, startColumn, endColumn } = rule.ranges[0];
|
|
19135
|
-
startRow === 0 && endRow === worksheet2.getRowCount() - 1 && startColumn === 0 && worksheet2.getColumnCount() - 1 === endColumn && (rule.unitType = l$1.Worksheet, rule.name = `${sheetName}`);
|
|
19136
|
-
}
|
|
19137
|
-
sheetPermissionPanelModel.setRule(rule);
|
|
19138
|
-
}, "onChange")
|
|
19139
|
-
}
|
|
19140
|
-
),
|
|
19141
|
-
rangeErrorMsg && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.sheetPermissionPanelNameInputErrorText, children: rangeErrorMsg })
|
|
19142
|
-
] }),
|
|
19143
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.permissionDirection"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19144
|
-
Input,
|
|
19145
|
-
{
|
|
19146
|
-
value: (_c = activeRule == null ? void 0 : activeRule.description) != null ? _c : "",
|
|
19147
|
-
onChange: /* @__PURE__ */ __name((v) => sheetPermissionPanelModel.setRule({ description: v }), "onChange"),
|
|
19148
|
-
placeholder: localeService.t("permission.panel.permissionDirectionPlaceholder")
|
|
19149
|
-
}
|
|
19150
|
-
) }),
|
|
19151
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.editPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19152
|
-
RadioGroup,
|
|
19153
|
-
{
|
|
19154
|
-
value: editorGroupValue,
|
|
19155
|
-
onChange: /* @__PURE__ */ __name((v) => {
|
|
19156
|
-
setEditorGroupValue(v), v === "onlyMe" && sheetPermissionUserManagerService.setSelectUserList([]);
|
|
19157
|
-
}, "onChange"),
|
|
19158
|
-
className: styles$6.radioGroupVertical,
|
|
19159
|
-
children: [
|
|
19160
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: "onlyMe", children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.onlyICanEdit") }) }),
|
|
19161
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: "designedUserCanEdit", children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.designedUserCanEdit") }) })
|
|
19162
|
-
]
|
|
19163
|
-
}
|
|
19164
|
-
) }),
|
|
19165
|
-
editorGroupValue === "designedUserCanEdit" && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.sheetPermissionDesignPersonPanel, children: /* @__PURE__ */ jsxRuntimeExports.jsxs(Spin, { loading, children: [
|
|
19166
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.sheetPermissionDesignPersonPanelHeader, children: [
|
|
19167
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { children: localeService.t("permission.panel.designedPerson") }),
|
|
19168
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.sheetPermissionDesignPersonPanelHeaderAdd, onClick: handleAddPerson, children: localeService.t("permission.panel.addPerson") })
|
|
19169
|
-
] }),
|
|
19170
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.sheetPermissionDesignPersonPanelSplit }),
|
|
19171
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.sheetPermissionDesignPersonPanelContent, children: (selectUserList == null ? void 0 : selectUserList.length) > 0 ? selectUserList.map((item) => {
|
|
19172
|
-
var _a60, _b2, _c2;
|
|
19173
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.sheetPermissionDesignPersonPanelContentItem, children: [
|
|
19174
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Avatar, { size: 24, src: (_a60 = item.subject) == null ? void 0 : _a60.avatar }),
|
|
19175
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.sheetPermissionDesignPersonPanelContentItemName, children: (_b2 = item.subject) == null ? void 0 : _b2.name }),
|
|
19176
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19177
|
-
Select,
|
|
19178
|
-
{
|
|
19179
|
-
className: styles$6.sheetPermissionDesignPersonPanelContentItemSelect,
|
|
19180
|
-
value: "edit",
|
|
19181
|
-
onChange: /* @__PURE__ */ __name((v) => {
|
|
19182
|
-
v === "delete" && sheetPermissionUserManagerService.setSelectUserList(selectUserList.filter((i) => {
|
|
19183
|
-
var _a61, _b3;
|
|
19184
|
-
return ((_a61 = i.subject) == null ? void 0 : _a61.userID) !== ((_b3 = item.subject) == null ? void 0 : _b3.userID);
|
|
19185
|
-
}));
|
|
19186
|
-
}, "onChange"),
|
|
19187
|
-
options: [
|
|
19188
|
-
{ label: `${localeService.t("permission.panel.canEdit")}`, value: "edit" },
|
|
19189
|
-
{ label: `${localeService.t("permission.panel.delete")}`, value: "delete" }
|
|
19190
|
-
]
|
|
19191
|
-
}
|
|
19192
|
-
)
|
|
19193
|
-
] }, (_c2 = item.subject) == null ? void 0 : _c2.userID);
|
|
19194
|
-
}) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.sheetPermissionUserListEmpty, children: [
|
|
19195
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: UserEmptyBase64, alt: "" }),
|
|
19196
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$6.sheetPermissionUserListEmptyText, children: localeService.t("permission.dialog.userEmpty") })
|
|
19197
|
-
] }) })
|
|
19198
|
-
] }) }),
|
|
19199
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$6.sheetPermissionPanelTitle, label: localeService.t("permission.panel.viewPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19200
|
-
RadioGroup,
|
|
19201
|
-
{
|
|
19202
|
-
value: viewGroupValue,
|
|
19203
|
-
onChange: /* @__PURE__ */ __name((v) => setViewGroupValue(v), "onChange"),
|
|
19204
|
-
className: styles$6.radioGroupVertical,
|
|
19205
|
-
children: [
|
|
19206
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.othersCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.othersCanView") }) }),
|
|
19207
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.noOneElseCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$6.text, children: localeService.t("permission.panel.noOneElseCanView") }) })
|
|
19208
|
-
]
|
|
19209
|
-
}
|
|
19210
|
-
) })
|
|
19211
|
-
] });
|
|
19212
|
-
}, "SheetPermissionPanelDetail"), useHighlightRange = /* @__PURE__ */ __name((ranges = []) => {
|
|
19213
|
-
const markSelectionService = useDependency(IMarkSelectionService);
|
|
19214
|
-
useEffect(() => {
|
|
19215
|
-
const ids = ranges.map((range) => markSelectionService.addShape({
|
|
19216
|
-
range,
|
|
19217
|
-
style: {
|
|
19218
|
-
hasAutoFill: !1,
|
|
19219
|
-
fill: "rgba(73, 184, 17, 0.05)",
|
|
19220
|
-
strokeWidth: 1,
|
|
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);
|
|
19179
|
+
}));
|
|
19180
|
+
return () => {
|
|
19181
|
+
ids.forEach((id) => {
|
|
19182
|
+
id && markSelectionService.removeShape(id);
|
|
19238
19183
|
});
|
|
19239
19184
|
};
|
|
19240
19185
|
}, [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 = {
|
|
19186
|
+
}, "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 = {
|
|
19242
19187
|
sheetPermissionListPanelWrapper,
|
|
19243
19188
|
sheetPermissionListPanelHeader,
|
|
19244
19189
|
sheetPermissionListPanelHeaderType,
|
|
@@ -19258,9 +19203,7 @@ const UserEmptyBase64 = "
|
|
|
19258
19203
|
sheetPermissionListItemContentTitle,
|
|
19259
19204
|
sheetPermissionListItemContentSub
|
|
19260
19205
|
}, 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) => {
|
|
19206
|
+
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) => {
|
|
19264
19207
|
var _a59;
|
|
19265
19208
|
const worksheet = workbook.getActiveSheet(), unitId2 = workbook.getUnitId(), subUnitId = worksheet.getSheetId(), allRangePermissionId = [], allSheetPermissionId = [];
|
|
19266
19209
|
workbook.getSheets().forEach((sheet) => {
|
|
@@ -19302,11 +19245,18 @@ const UserEmptyBase64 = "
|
|
|
19302
19245
|
return () => {
|
|
19303
19246
|
subscribe.unsubscribe();
|
|
19304
19247
|
};
|
|
19305
|
-
}, [])
|
|
19248
|
+
}, []), useEffect(() => {
|
|
19249
|
+
(/* @__PURE__ */ __name(async () => {
|
|
19250
|
+
if (_sheetRuleRefresh || _rangeRuleRefresh) {
|
|
19251
|
+
const ruleList2 = await getRuleList(!0);
|
|
19252
|
+
setRuleList(ruleList2);
|
|
19253
|
+
}
|
|
19254
|
+
}, "getRuleListByRefresh"))();
|
|
19255
|
+
}, [_sheetRuleRefresh, _rangeRuleRefresh]);
|
|
19306
19256
|
const handleDelete = /* @__PURE__ */ __name((rule) => {
|
|
19307
19257
|
const { unitId: unitId2, subUnitId, unitType } = rule;
|
|
19308
19258
|
let res;
|
|
19309
|
-
unitType ===
|
|
19259
|
+
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([]));
|
|
19310
19260
|
}, "handleDelete");
|
|
19311
19261
|
useHighlightRange(currentRuleRanges);
|
|
19312
19262
|
const allRuleMap = /* @__PURE__ */ new Map();
|
|
@@ -19319,7 +19269,7 @@ const UserEmptyBase64 = "
|
|
|
19319
19269
|
sheetRule && allRuleMap.set(sheetRule == null ? void 0 : sheetRule.permissionId, sheetRule);
|
|
19320
19270
|
});
|
|
19321
19271
|
const handleEdit = /* @__PURE__ */ __name((rule) => {
|
|
19322
|
-
sheetPermissionPanelModel.setRule(rule), sheetPermissionPanelModel.setOldRule(rule), commandService.executeCommand(SetWorksheetActiveOperation.id, {
|
|
19272
|
+
sheetPermissionPanelModel.setRule(rule), sheetPermissionPanelModel.setOldRule(rule), rule.subUnitId !== workbook.getActiveSheet().getSheetId() && commandService.executeCommand(SetWorksheetActiveOperation.id, {
|
|
19323
19273
|
unitId: rule.unitId,
|
|
19324
19274
|
subUnitId: rule.subUnitId
|
|
19325
19275
|
});
|
|
@@ -19341,18 +19291,18 @@ const UserEmptyBase64 = "
|
|
|
19341
19291
|
const ruleList2 = await getRuleList(isCurrentSheet2);
|
|
19342
19292
|
setRuleList(ruleList2);
|
|
19343
19293
|
}, "handleChangeHeaderType");
|
|
19344
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19345
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19346
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19347
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$
|
|
19348
|
-
isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19294
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelWrapper, children: [
|
|
19295
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelHeader, children: [
|
|
19296
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!0), "onClick"), children: [
|
|
19297
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$7.sheetPermissionListPanelHeaderSelect]: isCurrentSheet }), children: localeService.t("permission.panel.currentSheet") }),
|
|
19298
|
+
isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListPanelHeaderTypeBottom })
|
|
19349
19299
|
] }),
|
|
19350
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19351
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$
|
|
19352
|
-
!isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19300
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListPanelHeaderType, onClick: /* @__PURE__ */ __name(() => handleChangeHeaderType(!1), "onClick"), children: [
|
|
19301
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: clsx({ [styles$7.sheetPermissionListPanelHeaderSelect]: !isCurrentSheet }), children: localeService.t("permission.panel.allSheet") }),
|
|
19302
|
+
!isCurrentSheet && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListPanelHeaderTypeBottom })
|
|
19353
19303
|
] })
|
|
19354
19304
|
] }),
|
|
19355
|
-
(ruleList == null ? void 0 : ruleList.length) > 0 ? /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19305
|
+
(ruleList == null ? void 0 : ruleList.length) > 0 ? /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListPanelContent, children: ruleList == null ? void 0 : ruleList.map((item) => {
|
|
19356
19306
|
var _a59, _b, _c, _d, _e;
|
|
19357
19307
|
const rule = allRuleMap.get(item.objectID);
|
|
19358
19308
|
if (!rule)
|
|
@@ -19360,17 +19310,17 @@ const UserEmptyBase64 = "
|
|
|
19360
19310
|
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
19311
|
let ruleName = "";
|
|
19362
19312
|
const targetSheet = workbook.getSheetBySheetId(rule.subUnitId), targetName = targetSheet == null ? void 0 : targetSheet.getName();
|
|
19363
|
-
if (rule.unitType ===
|
|
19313
|
+
if (rule.unitType === M.SelectRange) {
|
|
19364
19314
|
const ranges = rule.ranges, rangeStr = ranges != null && ranges.length ? ranges.map((range) => {
|
|
19365
19315
|
const v = serializeRange(range);
|
|
19366
19316
|
return v === "NaN" ? "" : v;
|
|
19367
19317
|
}).filter((r) => !!r).join(",") : "";
|
|
19368
19318
|
ruleName = `${targetName}(${rangeStr})`;
|
|
19369
|
-
} else rule.unitType ===
|
|
19319
|
+
} else rule.unitType === M.Worksheet && (ruleName = targetName || "");
|
|
19370
19320
|
return /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19371
19321
|
"div",
|
|
19372
19322
|
{
|
|
19373
|
-
className: styles$
|
|
19323
|
+
className: styles$7.sheetPermissionListItem,
|
|
19374
19324
|
onMouseMove: /* @__PURE__ */ __name(() => {
|
|
19375
19325
|
const { subUnitId, unitType } = rule, activeSheet = workbook.getActiveSheet();
|
|
19376
19326
|
if (!activeSheet)
|
|
@@ -19378,46 +19328,342 @@ const UserEmptyBase64 = "
|
|
|
19378
19328
|
const activeSubUnitId = activeSheet.getSheetId();
|
|
19379
19329
|
if (subUnitId !== activeSubUnitId)
|
|
19380
19330
|
return !1;
|
|
19381
|
-
if (unitType ===
|
|
19331
|
+
if (unitType === M.SelectRange) {
|
|
19382
19332
|
const ranges = rule.ranges || [];
|
|
19383
19333
|
ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
|
|
19384
|
-
} else if (unitType ===
|
|
19334
|
+
} else if (unitType === M.Worksheet) {
|
|
19385
19335
|
const ranges = [{ startRow: 0, endRow: activeSheet.getRowCount() - 1, startColumn: 0, endColumn: activeSheet.getColumnCount() - 1 }];
|
|
19386
19336
|
ranges !== currentRuleRanges && currentRuleRangesSet(ranges);
|
|
19387
19337
|
}
|
|
19388
19338
|
}, "onMouseMove"),
|
|
19389
19339
|
onMouseLeave: /* @__PURE__ */ __name(() => currentRuleRangesSet([]), "onMouseLeave"),
|
|
19390
19340
|
children: [
|
|
19391
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19392
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: ruleName, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19393
|
-
hasManagerPermission && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19394
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: localeService.t("permission.panel.edit"), children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19395
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: localeService.t("permission.panel.delete"), children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19341
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemHeader, children: [
|
|
19342
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: ruleName, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemHeaderName, children: ruleName }) }),
|
|
19343
|
+
hasManagerPermission && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemHeaderOperator, children: [
|
|
19344
|
+
/* @__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, {}) }) }),
|
|
19345
|
+
/* @__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, {}) }) })
|
|
19396
19346
|
] })
|
|
19397
19347
|
] }),
|
|
19398
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19399
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19400
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19348
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemSplit }),
|
|
19349
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemContent, children: [
|
|
19350
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemContentEdit, children: [
|
|
19401
19351
|
/* @__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$
|
|
19403
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
19352
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.created") }),
|
|
19353
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentSub, children: editPermission ? `${localeService.t("permission.panel.iCanEdit")}` : `${localeService.t("permission.panel.iCanNotEdit")}` })
|
|
19404
19354
|
] }),
|
|
19405
|
-
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19406
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
19407
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$
|
|
19355
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListItemContentView, children: [
|
|
19356
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentTitle, children: localeService.t("permission.panel.viewPermission") }),
|
|
19357
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$7.sheetPermissionListItemContentSub, children: viewPermission ? `${localeService.t("permission.panel.iCanView")}` : `${localeService.t("permission.panel.iCanNotView")}` })
|
|
19408
19358
|
] }),
|
|
19409
|
-
rule.description && /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: rule.description, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$
|
|
19359
|
+
rule.description && /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: rule.description, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$7.sheetPermissionListItemContentDesc, children: rule.description }) })
|
|
19410
19360
|
] })
|
|
19411
19361
|
]
|
|
19412
19362
|
},
|
|
19413
19363
|
item.objectID
|
|
19414
19364
|
);
|
|
19415
|
-
}) }) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$
|
|
19365
|
+
}) }) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$7.sheetPermissionListEmpty, children: [
|
|
19416
19366
|
/* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: panelListEmptyBase64, alt: "" }),
|
|
19417
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$
|
|
19367
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$7.sheetPermissionListEmptyText, children: localeService.t("permission.dialog.listEmpty") })
|
|
19418
19368
|
] })
|
|
19419
19369
|
] });
|
|
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 = {
|
|
19370
|
+
}, "SheetPermissionPanelList"), UserEmptyBase64 = "", spinContainer = "univer-spin-container", spinOverlay = "univer-spin-overlay", spinner = "univer-spinner", spin = "univer-spin", contentBlur = "univer-content-blur", styles$6 = {
|
|
19371
|
+
spinContainer,
|
|
19372
|
+
spinOverlay,
|
|
19373
|
+
spinner,
|
|
19374
|
+
spin,
|
|
19375
|
+
contentBlur
|
|
19376
|
+
}, Spin = /* @__PURE__ */ __name(({ loading, children }) => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$6.spinContainer, children: [
|
|
19377
|
+
loading && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.spinOverlay, children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$6.spinner }) }),
|
|
19378
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: loading ? styles$6.contentBlur : "", children })
|
|
19379
|
+
] }), "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 = {
|
|
19380
|
+
permissionPanelDetailWrapper,
|
|
19381
|
+
radioGroupVertical,
|
|
19382
|
+
sheetPermissionDesignPersonPanel,
|
|
19383
|
+
sheetPermissionDesignPersonPanelHeader,
|
|
19384
|
+
sheetPermissionDesignPersonPanelHeaderAdd,
|
|
19385
|
+
sheetPermissionDesignPersonPanelSplit,
|
|
19386
|
+
sheetPermissionDesignPersonPanelContentItem,
|
|
19387
|
+
sheetPermissionDesignPersonPanelContentItemName,
|
|
19388
|
+
sheetPermissionDesignPersonPanelContentItemSelect,
|
|
19389
|
+
sheetPermissionDesignPersonPanelContent,
|
|
19390
|
+
sheetPermissionUserListEmpty: sheetPermissionUserListEmpty$1,
|
|
19391
|
+
sheetPermissionUserListEmptyText: sheetPermissionUserListEmptyText$1,
|
|
19392
|
+
sheetPermissionPanelTitle,
|
|
19393
|
+
permissionRangeSelector,
|
|
19394
|
+
permissionRangeSelectorError,
|
|
19395
|
+
sheetPermissionPanelNameInputError,
|
|
19396
|
+
permissionRangeSelectorErrorText,
|
|
19397
|
+
sheetPermissionPanelNameInputErrorText
|
|
19398
|
+
}, SheetPermissionPanelDetail = /* @__PURE__ */ __name(({ fromSheetBar }) => {
|
|
19399
|
+
var _a59, _b;
|
|
19400
|
+
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 () => {
|
|
19401
|
+
const userList = await authzIoService.listCollaborators({
|
|
19402
|
+
objectID: unitId,
|
|
19403
|
+
unitID: unitId
|
|
19404
|
+
});
|
|
19405
|
+
userList.forEach((user) => {
|
|
19406
|
+
user != null && user.subject && userManagerService.addUser(user.subject);
|
|
19407
|
+
}), sheetPermissionUserManagerService.setUserList(userList), dialogService.open({
|
|
19408
|
+
id: UNIVER_SHEET_PERMISSION_USER_DIALOG_ID,
|
|
19409
|
+
title: { title: "" },
|
|
19410
|
+
children: { label: UNIVER_SHEET_PERMISSION_USER_DIALOG },
|
|
19411
|
+
width: 280,
|
|
19412
|
+
destroyOnClose: !0,
|
|
19413
|
+
onClose: /* @__PURE__ */ __name(() => dialogService.close(UNIVER_SHEET_PERMISSION_USER_DIALOG_ID), "onClose"),
|
|
19414
|
+
className: "sheet-permission-user-dialog"
|
|
19415
|
+
});
|
|
19416
|
+
}, "handleAddPerson"), checkRangeValid = /* @__PURE__ */ __name((permissionRanges) => {
|
|
19417
|
+
let rangeErrorString = "";
|
|
19418
|
+
if (permissionRanges.length === 0)
|
|
19419
|
+
rangeErrorString = localeService.t("permission.panel.emptyRangeError");
|
|
19420
|
+
else if (permissionRanges.length > 1) {
|
|
19421
|
+
let hasLap = !1;
|
|
19422
|
+
for (let i = 0; i < permissionRanges.length; i++) {
|
|
19423
|
+
for (let j = i + 1; j < permissionRanges.length; j++)
|
|
19424
|
+
if (Rectangle.intersects(permissionRanges[i], permissionRanges[j])) {
|
|
19425
|
+
hasLap = !0;
|
|
19426
|
+
break;
|
|
19427
|
+
}
|
|
19428
|
+
if (hasLap)
|
|
19429
|
+
break;
|
|
19430
|
+
}
|
|
19431
|
+
hasLap && (rangeErrorString = localeService.t("permission.panel.rangeOverlapError"));
|
|
19432
|
+
}
|
|
19433
|
+
if (!rangeErrorString) {
|
|
19434
|
+
if (worksheetRuleModel.getRule(unitId, subUnitId) && !(activeRule != null && activeRule.permissionId))
|
|
19435
|
+
return rangeErrorString = localeService.t("permission.panel.rangeOverlapOverPermissionError"), rangeErrorString;
|
|
19436
|
+
const lapRule = rangeProtectionRuleModel.getSubunitRuleList(unitId, subUnitId).filter((rule) => rule.permissionId !== (activeRule == null ? void 0 : activeRule.permissionId)).find((rule) => rule.ranges.some((ruleRange) => permissionRanges.some((r) => Rectangle.intersects(ruleRange, r))));
|
|
19437
|
+
(lapRule == null ? void 0 : lapRule.ranges.find((range) => permissionRanges.some((r) => Rectangle.intersects(range, r)))) && (rangeErrorString = localeService.t("permission.panel.rangeOverlapOverPermissionError"));
|
|
19438
|
+
}
|
|
19439
|
+
return rangeErrorString;
|
|
19440
|
+
}, "checkRangeValid");
|
|
19441
|
+
return useEffect(() => {
|
|
19442
|
+
var _a60, _b2;
|
|
19443
|
+
if (activeRule == null ? void 0 : activeRule.permissionId) {
|
|
19444
|
+
activeRule.unitType === M.Worksheet && sheetPermissionPanelModel.setRule({
|
|
19445
|
+
ranges: [{
|
|
19446
|
+
startRow: 0,
|
|
19447
|
+
startColumn: 0,
|
|
19448
|
+
endRow: worksheet.getRowCount() - 1,
|
|
19449
|
+
endColumn: worksheet.getColumnCount() - 1,
|
|
19450
|
+
rangeType: RANGE_TYPE.ALL
|
|
19451
|
+
}]
|
|
19452
|
+
});
|
|
19453
|
+
return;
|
|
19454
|
+
}
|
|
19455
|
+
fromSheetBar && (selectionManagerService.clearCurrentSelections(), selectionManagerService.addSelections([
|
|
19456
|
+
{
|
|
19457
|
+
primary: null,
|
|
19458
|
+
style: null,
|
|
19459
|
+
range: {
|
|
19460
|
+
startRow: 0,
|
|
19461
|
+
startColumn: 0,
|
|
19462
|
+
endRow: worksheet.getRowCount() - 1,
|
|
19463
|
+
endColumn: worksheet.getColumnCount() - 1,
|
|
19464
|
+
rangeType: RANGE_TYPE.ALL
|
|
19465
|
+
}
|
|
19466
|
+
}
|
|
19467
|
+
]));
|
|
19468
|
+
const ranges = (_b2 = (_a60 = selectionManagerService.getCurrentSelections()) == null ? void 0 : _a60.map((s) => s.range)) != null ? _b2 : [], rangeErrorString = checkRangeValid(ranges);
|
|
19469
|
+
sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString);
|
|
19470
|
+
const rangeStr = ranges != null && ranges.length ? ranges.map((range) => {
|
|
19471
|
+
const v = serializeRange(range);
|
|
19472
|
+
return v === "NaN" ? "" : v;
|
|
19473
|
+
}).filter((r) => !!r).join(",") : "", sheetName = worksheet.getName();
|
|
19474
|
+
sheetPermissionPanelModel.setRule({
|
|
19475
|
+
ranges,
|
|
19476
|
+
name: fromSheetBar ? `${sheetName}` : `${sheetName}(${rangeStr})`,
|
|
19477
|
+
unitId,
|
|
19478
|
+
subUnitId,
|
|
19479
|
+
unitType: fromSheetBar ? M.Worksheet : M.SelectRange
|
|
19480
|
+
});
|
|
19481
|
+
}, [activeRule == null ? void 0 : activeRule.permissionId, fromSheetBar, selectionManagerService, sheetPermissionPanelModel, subUnitId, unitId, worksheet]), useEffect(() => {
|
|
19482
|
+
const getSelectUserList = /* @__PURE__ */ __name(async () => {
|
|
19483
|
+
const permissionId = activeRule == null ? void 0 : activeRule.permissionId, selectUserList2 = (await authzIoService.listCollaborators({
|
|
19484
|
+
objectID: permissionId,
|
|
19485
|
+
unitID: unitId
|
|
19486
|
+
})).filter((user) => user.role === G.Editor);
|
|
19487
|
+
sheetPermissionUserManagerService.setSelectUserList(selectUserList2), sheetPermissionUserManagerService.setOldCollaboratorList(selectUserList2);
|
|
19488
|
+
}, "getSelectUserList");
|
|
19489
|
+
activeRule != null && activeRule.permissionId ? getSelectUserList() : (sheetPermissionUserManagerService.setSelectUserList([]), sheetPermissionUserManagerService.setOldCollaboratorList([]));
|
|
19490
|
+
}, [activeRule == null ? void 0 : activeRule.permissionId]), useEffect(() => {
|
|
19491
|
+
if (!activeRule.permissionId) {
|
|
19492
|
+
sheetPermissionPanelModel.setRule({
|
|
19493
|
+
viewStatus: viewState.othersCanView
|
|
19494
|
+
});
|
|
19495
|
+
return;
|
|
19496
|
+
}
|
|
19497
|
+
(/* @__PURE__ */ __name(async () => {
|
|
19498
|
+
var _a60, _b2;
|
|
19499
|
+
try {
|
|
19500
|
+
const res = await authzIoService.list({
|
|
19501
|
+
unitID: unitId,
|
|
19502
|
+
objectIDs: [activeRule == null ? void 0 : activeRule.permissionId],
|
|
19503
|
+
actions: [P.View, P.Edit]
|
|
19504
|
+
});
|
|
19505
|
+
if (!res.length)
|
|
19506
|
+
setViewGroupValue(viewState.othersCanView), setEditorGroupValue(editState.onlyMe), sheetPermissionPanelModel.setRule({
|
|
19507
|
+
viewStatus: viewState.othersCanView,
|
|
19508
|
+
editStatus: editState.onlyMe
|
|
19509
|
+
});
|
|
19510
|
+
else {
|
|
19511
|
+
const isAllCanView = ((_a60 = res[0].scope) == null ? void 0 : _a60.read) === H.AllCollaborator, isSomeCanEdit = ((_b2 = res[0].scope) == null ? void 0 : _b2.edit) === H.SomeCollaborator, viewValue = isAllCanView ? viewState.othersCanView : viewState.noOneElseCanView, editValue = isSomeCanEdit ? editState.designedUserCanEdit : editState.onlyMe;
|
|
19512
|
+
setViewGroupValue(viewValue), setEditorGroupValue(editValue), sheetPermissionPanelModel.setRule({
|
|
19513
|
+
viewStatus: viewValue,
|
|
19514
|
+
editStatus: editValue
|
|
19515
|
+
});
|
|
19516
|
+
}
|
|
19517
|
+
} catch (error) {
|
|
19518
|
+
console.error(error);
|
|
19519
|
+
} finally {
|
|
19520
|
+
setTimeout(() => {
|
|
19521
|
+
setLoading(!1);
|
|
19522
|
+
}, 100);
|
|
19523
|
+
}
|
|
19524
|
+
}, "getCollaboratorInit"))();
|
|
19525
|
+
}, [activeRule.permissionId]), useEffect(() => {
|
|
19526
|
+
(/* @__PURE__ */ __name(async () => {
|
|
19527
|
+
const userList = await authzIoService.listCollaborators({
|
|
19528
|
+
objectID: unitId,
|
|
19529
|
+
unitID: unitId
|
|
19530
|
+
});
|
|
19531
|
+
userList.forEach((user) => {
|
|
19532
|
+
user != null && user.subject && userManagerService.addUser(user.subject);
|
|
19533
|
+
}), sheetPermissionUserManagerService.setUserList(userList.filter((user) => user.role === G.Editor)), sheetPermissionUserManagerService.setAllUserList(userList.filter((user) => user.role === G.Editor || user.role === G.Reader));
|
|
19534
|
+
}, "getListCollaborators"))();
|
|
19535
|
+
}, []), useEffect(() => {
|
|
19536
|
+
const workbook2 = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
|
|
19537
|
+
if (!workbook2) return;
|
|
19538
|
+
const activeSheetSubscribe = workbook2.activeSheet$.subscribe((sheet) => {
|
|
19539
|
+
(sheet == null ? void 0 : sheet.getSheetId()) !== subUnitId && sidebarService.close();
|
|
19540
|
+
});
|
|
19541
|
+
return () => {
|
|
19542
|
+
activeSheetSubscribe.unsubscribe();
|
|
19543
|
+
};
|
|
19544
|
+
}, [sidebarService, subUnitId, univerInstanceService]), /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.permissionPanelDetailWrapper, children: /* @__PURE__ */ jsxRuntimeExports.jsxs(Spin, { loading, children: [
|
|
19545
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.protectedRange"), children: [
|
|
19546
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19547
|
+
RangeSelector,
|
|
19548
|
+
{
|
|
19549
|
+
className: clsx(styles$5.permissionRangeSelector),
|
|
19550
|
+
textEditorClassName: clsx({ [styles$5.permissionRangeSelectorError]: rangeErrorMsg }),
|
|
19551
|
+
value: (_a59 = activeRule == null ? void 0 : activeRule.ranges) == null ? void 0 : _a59.map((i) => serializeRange(i)).join(","),
|
|
19552
|
+
id: createInternalEditorID("sheet-permission-panel"),
|
|
19553
|
+
openForSheetUnitId: unitId,
|
|
19554
|
+
openForSheetSubUnitId: subUnitId,
|
|
19555
|
+
onChange: /* @__PURE__ */ __name((newRange) => {
|
|
19556
|
+
if (newRange.some((i) => !isValidRange(i.range) || i.range.endColumn < i.range.startColumn || i.range.endRow < i.range.startRow))
|
|
19557
|
+
return;
|
|
19558
|
+
const workbook2 = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET), worksheet2 = workbook2.getActiveSheet(), unitId2 = workbook2.getUnitId(), subUnitId2 = worksheet2.getSheetId(), transformedRange = newRange.map((i) => {
|
|
19559
|
+
const range = { ...i.range }, rowCount = worksheet2.getRowCount(), colCount = worksheet2.getColumnCount();
|
|
19560
|
+
return setEndForRange(range, rowCount, colCount), range;
|
|
19561
|
+
}), rangeErrorString = checkRangeValid(transformedRange);
|
|
19562
|
+
if (sheetPermissionPanelModel.setRangeErrorMsg(rangeErrorString), rangeErrorString) return;
|
|
19563
|
+
const sheetName = worksheet2.getName(), rangeStr = transformedRange.map((range) => {
|
|
19564
|
+
const v = serializeRange(range);
|
|
19565
|
+
return v === "NaN" ? "" : v;
|
|
19566
|
+
}).filter((r) => !!r).join(","), rule = {
|
|
19567
|
+
ranges: transformedRange,
|
|
19568
|
+
unitId: unitId2,
|
|
19569
|
+
subUnitId: subUnitId2,
|
|
19570
|
+
unitType: M.SelectRange,
|
|
19571
|
+
name: `${sheetName}(${rangeStr})`
|
|
19572
|
+
};
|
|
19573
|
+
if (rule.ranges.length === 1) {
|
|
19574
|
+
const { startRow, endRow, startColumn, endColumn } = rule.ranges[0];
|
|
19575
|
+
startRow === 0 && endRow === worksheet2.getRowCount() - 1 && startColumn === 0 && worksheet2.getColumnCount() - 1 === endColumn && (rule.unitType = M.Worksheet, rule.name = `${sheetName}`);
|
|
19576
|
+
}
|
|
19577
|
+
sheetPermissionPanelModel.setRule(rule);
|
|
19578
|
+
}, "onChange")
|
|
19579
|
+
}
|
|
19580
|
+
),
|
|
19581
|
+
rangeErrorMsg && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionPanelNameInputErrorText, children: rangeErrorMsg })
|
|
19582
|
+
] }),
|
|
19583
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.permissionDirection"), children: /* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19584
|
+
Input,
|
|
19585
|
+
{
|
|
19586
|
+
value: (_b = activeRule == null ? void 0 : activeRule.description) != null ? _b : "",
|
|
19587
|
+
onChange: /* @__PURE__ */ __name((v) => sheetPermissionPanelModel.setRule({ description: v }), "onChange"),
|
|
19588
|
+
placeholder: localeService.t("permission.panel.permissionDirectionPlaceholder")
|
|
19589
|
+
}
|
|
19590
|
+
) }),
|
|
19591
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.editPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19592
|
+
RadioGroup,
|
|
19593
|
+
{
|
|
19594
|
+
value: editorGroupValue,
|
|
19595
|
+
onChange: /* @__PURE__ */ __name((v) => {
|
|
19596
|
+
setEditorGroupValue(v), sheetPermissionPanelModel.setRule({
|
|
19597
|
+
editStatus: v
|
|
19598
|
+
});
|
|
19599
|
+
}, "onChange"),
|
|
19600
|
+
className: styles$5.radioGroupVertical,
|
|
19601
|
+
children: [
|
|
19602
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: editState.onlyMe, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.onlyICanEdit") }) }),
|
|
19603
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: editState.designedUserCanEdit, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.designedUserCanEdit") }) })
|
|
19604
|
+
]
|
|
19605
|
+
}
|
|
19606
|
+
) }),
|
|
19607
|
+
editorGroupValue === "designedUserCanEdit" && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanel, children: [
|
|
19608
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanelHeader, children: [
|
|
19609
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { children: localeService.t("permission.panel.designedPerson") }),
|
|
19610
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionDesignPersonPanelHeaderAdd, onClick: handleAddPerson, children: localeService.t("permission.panel.addPerson") })
|
|
19611
|
+
] }),
|
|
19612
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionDesignPersonPanelSplit }),
|
|
19613
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.sheetPermissionDesignPersonPanelContent, children: (selectUserList == null ? void 0 : selectUserList.length) > 0 ? selectUserList.map((item) => {
|
|
19614
|
+
var _a60, _b2, _c;
|
|
19615
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionDesignPersonPanelContentItem, children: [
|
|
19616
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Avatar, { size: 24, src: (_a60 = item.subject) == null ? void 0 : _a60.avatar }),
|
|
19617
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.sheetPermissionDesignPersonPanelContentItemName, children: (_b2 = item.subject) == null ? void 0 : _b2.name }),
|
|
19618
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
19619
|
+
Select,
|
|
19620
|
+
{
|
|
19621
|
+
className: styles$5.sheetPermissionDesignPersonPanelContentItemSelect,
|
|
19622
|
+
value: "edit",
|
|
19623
|
+
onChange: /* @__PURE__ */ __name((v) => {
|
|
19624
|
+
v === "delete" && sheetPermissionUserManagerService.setSelectUserList(selectUserList.filter((i) => {
|
|
19625
|
+
var _a61, _b3;
|
|
19626
|
+
return ((_a61 = i.subject) == null ? void 0 : _a61.userID) !== ((_b3 = item.subject) == null ? void 0 : _b3.userID);
|
|
19627
|
+
}));
|
|
19628
|
+
}, "onChange"),
|
|
19629
|
+
options: [
|
|
19630
|
+
{ label: `${localeService.t("permission.panel.canEdit")}`, value: "edit" },
|
|
19631
|
+
{ label: `${localeService.t("permission.panel.delete")}`, value: "delete" }
|
|
19632
|
+
]
|
|
19633
|
+
}
|
|
19634
|
+
)
|
|
19635
|
+
] }, (_c = item.subject) == null ? void 0 : _c.userID);
|
|
19636
|
+
}) : /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.sheetPermissionUserListEmpty, children: [
|
|
19637
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("img", { width: 240, height: 120, src: UserEmptyBase64, alt: "" }),
|
|
19638
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: styles$5.sheetPermissionUserListEmptyText, children: localeService.t("permission.dialog.userEmpty") })
|
|
19639
|
+
] }) })
|
|
19640
|
+
] }),
|
|
19641
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(FormLayout, { className: styles$5.sheetPermissionPanelTitle, label: localeService.t("permission.panel.viewPermission"), children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
|
19642
|
+
RadioGroup,
|
|
19643
|
+
{
|
|
19644
|
+
value: viewGroupValue,
|
|
19645
|
+
onChange: /* @__PURE__ */ __name((v) => {
|
|
19646
|
+
setViewGroupValue(v), sheetPermissionPanelModel.setRule({
|
|
19647
|
+
viewStatus: v
|
|
19648
|
+
});
|
|
19649
|
+
}, "onChange"),
|
|
19650
|
+
className: styles$5.radioGroupVertical,
|
|
19651
|
+
children: [
|
|
19652
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.othersCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.othersCanView") }) }),
|
|
19653
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Radio, { value: viewState.noOneElseCanView, children: /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles$5.text, children: localeService.t("permission.panel.noOneElseCanView") }) })
|
|
19654
|
+
]
|
|
19655
|
+
}
|
|
19656
|
+
) })
|
|
19657
|
+
] }) });
|
|
19658
|
+
}, "SheetPermissionPanelDetail"), SheetPermissionPanel = /* @__PURE__ */ __name(({ showDetail, fromSheetBar }) => {
|
|
19659
|
+
var _a59;
|
|
19660
|
+
const univerInstanceService = useDependency(IUniverInstanceService), sheetsSelectionsService = useDependency(SheetsSelectionsService);
|
|
19661
|
+
if (!useDependency(SheetPermissionPanelModel).getVisible()) return null;
|
|
19662
|
+
const target = getSheetCommandTarget(univerInstanceService);
|
|
19663
|
+
if (!target) return null;
|
|
19664
|
+
const { worksheet } = target, key = ((_a59 = sheetsSelectionsService.getCurrentSelections()) == null ? void 0 : _a59.map((selection) => selection.range)).reduce((acc, range) => acc + serializeRangeWithSheet(worksheet.getName(), range), "");
|
|
19665
|
+
return showDetail ? /* @__PURE__ */ jsxRuntimeExports.jsx(SheetPermissionPanelDetail, { fromSheetBar }, key) : /* @__PURE__ */ jsxRuntimeExports.jsx(SheetPermissionPanelList, {}, key);
|
|
19666
|
+
}, "SheetPermissionPanel"), sheetPermissionPanelFooter = "univer-sheet-permission-panel-footer", sheetPermissionPanelFooterCancel = "univer-sheet-permission-panel-footer-cancel", sheetPermissionPanelAddButton = "univer-sheet-permission-panel-add-button", styles$4 = {
|
|
19421
19667
|
sheetPermissionPanelFooter,
|
|
19422
19668
|
sheetPermissionPanelFooterCancel,
|
|
19423
19669
|
sheetPermissionPanelAddButton
|
|
@@ -19463,44 +19709,46 @@ const UserEmptyBase64 = "
|
|
|
19463
19709
|
type: "primary",
|
|
19464
19710
|
onClick: /* @__PURE__ */ __name(async () => {
|
|
19465
19711
|
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({
|
|
19712
|
+
let collaborators = sheetPermissionUserManagerService.selectUserList;
|
|
19713
|
+
activeRule.editStatus === editState.onlyMe && (collaborators = [], sheetPermissionUserManagerService.setSelectUserList([]));
|
|
19714
|
+
const scopeObj = {
|
|
19715
|
+
read: activeRule.viewStatus === viewState.othersCanView ? H.AllCollaborator : H.SomeCollaborator,
|
|
19716
|
+
edit: activeRule.editStatus === editState.designedUserCanEdit ? H.SomeCollaborator : H.OneSelf
|
|
19717
|
+
};
|
|
19718
|
+
if (activeRule.editStatus === editState.designedUserCanEdit && collaborators.length === 0 && (collaborators = [], scopeObj.edit = H.OneSelf), activeRule.permissionId) {
|
|
19719
|
+
const oldRule = sheetPermissionPanelModel.oldRule, isSameCollaborators = getUserListEqual(collaborators.filter((user) => user.role === G.Editor), sheetPermissionUserManagerService.oldCollaboratorList.filter((user) => user.role === G.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;
|
|
19720
|
+
if (ruleConfigIsOrigin && collaboratorsIsChange)
|
|
19721
|
+
await authzIoService.update({
|
|
19722
|
+
objectType: activeRule.unitType,
|
|
19481
19723
|
objectID: activeRule.permissionId,
|
|
19482
19724
|
unitID: activeRule.unitId,
|
|
19483
|
-
|
|
19725
|
+
share: void 0,
|
|
19726
|
+
name: "",
|
|
19727
|
+
strategies: [],
|
|
19728
|
+
scope: scopeObj,
|
|
19729
|
+
collaborators: {
|
|
19730
|
+
collaborators
|
|
19731
|
+
}
|
|
19484
19732
|
});
|
|
19485
19733
|
else {
|
|
19486
19734
|
let newPermissionId = activeRule.permissionId;
|
|
19487
|
-
|
|
19735
|
+
collaboratorsIsChange && (activeRule.unitType === M.Worksheet ? newPermissionId = await authzIoService.create({
|
|
19488
19736
|
worksheetObject: {
|
|
19489
19737
|
collaborators,
|
|
19490
19738
|
unitID: activeRule.unitId,
|
|
19491
19739
|
name: activeRule.name,
|
|
19492
|
-
strategies: [{ role:
|
|
19493
|
-
scope:
|
|
19740
|
+
strategies: [{ role: G.Editor, action: P.Edit }, { role: G.Reader, action: P.View }],
|
|
19741
|
+
scope: scopeObj
|
|
19494
19742
|
},
|
|
19495
|
-
objectType:
|
|
19743
|
+
objectType: M.Worksheet
|
|
19496
19744
|
}) : newPermissionId = await authzIoService.create({
|
|
19497
19745
|
selectRangeObject: {
|
|
19498
19746
|
collaborators,
|
|
19499
19747
|
unitID: activeRule.unitId,
|
|
19500
19748
|
name: activeRule.name,
|
|
19501
|
-
|
|
19749
|
+
scope: scopeObj
|
|
19502
19750
|
},
|
|
19503
|
-
objectType:
|
|
19751
|
+
objectType: M.SelectRange
|
|
19504
19752
|
})), commandService.executeCommand(SetProtectionCommand.id, {
|
|
19505
19753
|
rule: {
|
|
19506
19754
|
...activeRule,
|
|
@@ -19508,37 +19756,37 @@ const UserEmptyBase64 = "
|
|
|
19508
19756
|
}
|
|
19509
19757
|
});
|
|
19510
19758
|
}
|
|
19511
|
-
} else if (activeRule.unitType ===
|
|
19759
|
+
} else if (activeRule.unitType === M.Worksheet) {
|
|
19512
19760
|
const permissionId = await authzIoService.create({
|
|
19513
19761
|
worksheetObject: {
|
|
19514
19762
|
collaborators,
|
|
19515
19763
|
unitID: activeRule.unitId,
|
|
19516
19764
|
name: activeRule.name,
|
|
19517
|
-
strategies: [{ role:
|
|
19518
|
-
scope:
|
|
19765
|
+
strategies: [{ role: G.Editor, action: P.Edit }, { role: G.Reader, action: P.View }],
|
|
19766
|
+
scope: scopeObj
|
|
19519
19767
|
},
|
|
19520
|
-
objectType:
|
|
19768
|
+
objectType: M.Worksheet
|
|
19521
19769
|
}), { ranges: _range = [], ...sheetRule } = activeRule;
|
|
19522
19770
|
sheetRule.permissionId = permissionId, commandService.executeCommand(AddWorksheetProtectionCommand.id, {
|
|
19523
19771
|
rule: sheetRule,
|
|
19524
19772
|
unitId: activeRule.unitId
|
|
19525
19773
|
});
|
|
19526
|
-
} else if (activeRule.unitType ===
|
|
19774
|
+
} else if (activeRule.unitType === M.SelectRange) {
|
|
19527
19775
|
const permissionId = await authzIoService.create({
|
|
19528
19776
|
selectRangeObject: {
|
|
19529
19777
|
collaborators,
|
|
19530
19778
|
unitID: activeRule.unitId,
|
|
19531
19779
|
name: activeRule.name,
|
|
19532
|
-
|
|
19780
|
+
scope: scopeObj
|
|
19533
19781
|
},
|
|
19534
|
-
objectType:
|
|
19782
|
+
objectType: M.SelectRange
|
|
19535
19783
|
});
|
|
19536
19784
|
commandService.executeCommand(AddRangeProtectionCommand$1.id, {
|
|
19537
19785
|
rule: activeRule,
|
|
19538
19786
|
permissionId
|
|
19539
19787
|
});
|
|
19540
19788
|
}
|
|
19541
|
-
sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.
|
|
19789
|
+
sheetPermissionPanelModel.resetRule(), sheetPermissionUserManagerService.reset();
|
|
19542
19790
|
const sidebarProps = {
|
|
19543
19791
|
header: { title: `${localeService.t("permission.panel.title")}` },
|
|
19544
19792
|
children: {
|
|
@@ -19561,7 +19809,7 @@ const UserEmptyBase64 = "
|
|
|
19561
19809
|
{
|
|
19562
19810
|
className: styles$4.sheetPermissionPanelFooterCancel,
|
|
19563
19811
|
onClick: /* @__PURE__ */ __name(() => {
|
|
19564
|
-
sheetPermissionPanelModel.
|
|
19812
|
+
sheetPermissionPanelModel.reset(), sheetPermissionUserManagerService.reset(), sidebarService.close();
|
|
19565
19813
|
}, "onClick"),
|
|
19566
19814
|
children: localeService.t("permission.button.cancel")
|
|
19567
19815
|
}
|
|
@@ -19582,7 +19830,7 @@ const UserEmptyBase64 = "
|
|
|
19582
19830
|
}, SheetPermissionUserDialog = /* @__PURE__ */ __name(() => {
|
|
19583
19831
|
const [inputValue, setInputValue] = React.useState(""), localeService = useDependency(LocaleService), dialogService = useDependency(IDialogService), sheetPermissionUserManagerService = useDependency(SheetPermissionUserManagerService), searchUserList = sheetPermissionUserManagerService.userList.filter((item) => {
|
|
19584
19832
|
var _a59;
|
|
19585
|
-
return ((_a59 = item.subject) == null ? void 0 : _a59.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase())) && item.role ===
|
|
19833
|
+
return ((_a59 = item.subject) == null ? void 0 : _a59.name.toLocaleLowerCase().includes(inputValue.toLocaleLowerCase())) && item.role === G.Editor;
|
|
19586
19834
|
}), [selectUserInfo, setSelectUserInfo] = useState(sheetPermissionUserManagerService.selectUserList), handleChangeUser = /* @__PURE__ */ __name((item) => {
|
|
19587
19835
|
if ((selectUserInfo == null ? void 0 : selectUserInfo.findIndex((v) => {
|
|
19588
19836
|
var _a59, _b;
|
|
@@ -19673,7 +19921,7 @@ const UserEmptyBase64 = "
|
|
|
19673
19921
|
actions: defaultWorksheetUnitActionList
|
|
19674
19922
|
}))[0].strategies.reduce((p2, c) => (subUnitPermissionTypeMap[c.action] && (p2[c.action] = {
|
|
19675
19923
|
text: localeService.t(`permission.panel.${subUnitPermissionTypeMap[c.action]}`),
|
|
19676
|
-
allowed: c.role !==
|
|
19924
|
+
allowed: c.role !== G.Owner
|
|
19677
19925
|
}), p2), {});
|
|
19678
19926
|
setPermissionMap(actions), setTimeout(() => {
|
|
19679
19927
|
setLoading(!1);
|
|
@@ -19686,29 +19934,37 @@ const UserEmptyBase64 = "
|
|
|
19686
19934
|
throw new Error("No active sheet found");
|
|
19687
19935
|
const unitId = workbook2.getUnitId(), subUnitId = worksheet2.getSheetId(), pointRule = worksheetProtectionPointRuleModel.getRule(unitId, subUnitId), actions = Object.keys(permissionMap).map((action) => ({
|
|
19688
19936
|
action: Number(action),
|
|
19689
|
-
role: permissionMap[action].allowed ?
|
|
19937
|
+
role: permissionMap[action].allowed ? G.Editor : G.Owner
|
|
19690
19938
|
}));
|
|
19691
19939
|
let permissionId = pointRule == null ? void 0 : pointRule.permissionId;
|
|
19692
19940
|
permissionId ? authzIoService.update({
|
|
19693
|
-
objectType:
|
|
19941
|
+
objectType: M.Worksheet,
|
|
19694
19942
|
objectID: permissionId,
|
|
19695
19943
|
unitID: unitId,
|
|
19696
19944
|
strategies: actions,
|
|
19697
19945
|
share: void 0,
|
|
19698
|
-
name: ""
|
|
19946
|
+
name: "",
|
|
19947
|
+
scope: {
|
|
19948
|
+
read: H.AllCollaborator,
|
|
19949
|
+
edit: H.AllCollaborator
|
|
19950
|
+
},
|
|
19951
|
+
collaborators: void 0
|
|
19699
19952
|
}).then(() => {
|
|
19700
19953
|
getAllWorksheetPermissionPoint().forEach((F) => {
|
|
19701
19954
|
const instance = new F(unitId, subUnitId), unitActionName = instance.subType, action = actions.find((item) => item.action === unitActionName);
|
|
19702
|
-
action && permissionService.updatePermissionPoint(instance.id, action.role ===
|
|
19955
|
+
action && permissionService.updatePermissionPoint(instance.id, action.role === G.Editor);
|
|
19703
19956
|
});
|
|
19704
19957
|
}) : (permissionId = await authzIoService.create({
|
|
19705
|
-
objectType:
|
|
19958
|
+
objectType: M.Worksheet,
|
|
19706
19959
|
worksheetObject: {
|
|
19707
19960
|
unitID: unitId,
|
|
19708
19961
|
collaborators,
|
|
19709
19962
|
name: "",
|
|
19710
19963
|
strategies: actions,
|
|
19711
|
-
scope:
|
|
19964
|
+
scope: {
|
|
19965
|
+
read: H.AllCollaborator,
|
|
19966
|
+
edit: H.AllCollaborator
|
|
19967
|
+
}
|
|
19712
19968
|
}
|
|
19713
19969
|
}), commandService.executeCommand(SetWorksheetPermissionPointsCommand.id, {
|
|
19714
19970
|
rule: {
|
|
@@ -19718,7 +19974,7 @@ const UserEmptyBase64 = "
|
|
|
19718
19974
|
}
|
|
19719
19975
|
}));
|
|
19720
19976
|
}, "handleChangeActionPermission");
|
|
19721
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsx(Spin, { loading, children: /* @__PURE__ */ jsxRuntimeExports.
|
|
19977
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsx(Spin, { loading, children: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$2.sheetPermissionDialogWrapper, children: [
|
|
19722
19978
|
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$2.sheetPermissionDialogSplit }),
|
|
19723
19979
|
Object.keys(permissionMap).map((action) => {
|
|
19724
19980
|
const actionItem = permissionMap[action], { text, allowed } = actionItem;
|
|
@@ -19765,7 +20021,7 @@ const UserEmptyBase64 = "
|
|
|
19765
20021
|
}
|
|
19766
20022
|
)
|
|
19767
20023
|
] })
|
|
19768
|
-
] }) })
|
|
20024
|
+
] }) });
|
|
19769
20025
|
}, "SheetPermissionDialog"), sheetPermissionAlertDialog = "univer-sheet-permission-alert-dialog", sheetPermissionAlertDialogTitle = "univer-sheet-permission-alert-dialog-title", sheetPermissionAlertDialogButton = "univer-sheet-permission-alert-dialog-button", styles$1 = {
|
|
19770
20026
|
sheetPermissionAlertDialog,
|
|
19771
20027
|
sheetPermissionAlertDialogTitle,
|
|
@@ -19848,8 +20104,8 @@ var __defProp$b = Object.defineProperty, __getOwnPropDesc$b = Object.getOwnPrope
|
|
|
19848
20104
|
return kind && result && __defProp$b(target, key, result), result;
|
|
19849
20105
|
}, "__decorateClass$b"), __decorateParam$b = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$b"), _a46;
|
|
19850
20106
|
let SheetPermissionRenderManagerController = (_a46 = class extends Disposable {
|
|
19851
|
-
constructor(
|
|
19852
|
-
super(), this.
|
|
20107
|
+
constructor(_componentManager) {
|
|
20108
|
+
super(), this._componentManager = _componentManager, this._init();
|
|
19853
20109
|
}
|
|
19854
20110
|
_init() {
|
|
19855
20111
|
this._initComponents();
|
|
@@ -19875,10 +20131,7 @@ let SheetPermissionRenderManagerController = (_a46 = class extends Disposable {
|
|
|
19875
20131
|
}
|
|
19876
20132
|
}, __name(_a46, "SheetPermissionRenderManagerController"), _a46);
|
|
19877
20133
|
SheetPermissionRenderManagerController = __decorateClass$b([
|
|
19878
|
-
|
|
19879
|
-
__decorateParam$b(1, IMenuService),
|
|
19880
|
-
__decorateParam$b(2, Inject(ComponentManager)),
|
|
19881
|
-
__decorateParam$b(3, Inject(Injector))
|
|
20134
|
+
__decorateParam$b(0, Inject(ComponentManager))
|
|
19882
20135
|
], SheetPermissionRenderManagerController);
|
|
19883
20136
|
var _a47;
|
|
19884
20137
|
let SheetPermissionRenderController = (_a47 = class extends Disposable {
|
|
@@ -19920,7 +20173,7 @@ let SheetPermissionInterceptorCanvasRenderController = (_a48 = class extends RxD
|
|
|
19920
20173
|
constructor(_context, _univerInstanceService, _permissionService, _selectionManagerService, _rangeProtectionRuleModel, _headerMoveRenderController, _selectionRenderService, _headerFreezeRenderController, _headerResizeRenderController) {
|
|
19921
20174
|
super();
|
|
19922
20175
|
__publicField(this, "disposableCollection", new DisposableCollection());
|
|
19923
|
-
this._context = _context, this._univerInstanceService = _univerInstanceService, this._permissionService = _permissionService, this._selectionManagerService = _selectionManagerService, this._rangeProtectionRuleModel = _rangeProtectionRuleModel, this._headerMoveRenderController = _headerMoveRenderController, this._selectionRenderService = _selectionRenderService, this._headerFreezeRenderController = _headerFreezeRenderController, this._headerResizeRenderController = _headerResizeRenderController, this._initHeaderMovePermissionInterceptor(), this._initHeaderResizePermissionInterceptor(), this._initRangeFillPermissionInterceptor(), this._initRangeMovePermissionInterceptor()
|
|
20176
|
+
this._context = _context, this._univerInstanceService = _univerInstanceService, this._permissionService = _permissionService, this._selectionManagerService = _selectionManagerService, this._rangeProtectionRuleModel = _rangeProtectionRuleModel, this._headerMoveRenderController = _headerMoveRenderController, this._selectionRenderService = _selectionRenderService, this._headerFreezeRenderController = _headerFreezeRenderController, this._headerResizeRenderController = _headerResizeRenderController, this._initHeaderMovePermissionInterceptor(), this._initHeaderResizePermissionInterceptor(), this._initRangeFillPermissionInterceptor(), this._initRangeMovePermissionInterceptor();
|
|
19924
20177
|
}
|
|
19925
20178
|
_initHeaderMovePermissionInterceptor() {
|
|
19926
20179
|
this.disposeWithMe(
|
|
@@ -20357,12 +20610,12 @@ var __defProp$5 = Object.defineProperty, __getOwnPropDesc$5 = Object.getOwnPrope
|
|
|
20357
20610
|
return kind && result && __defProp$5(target, key, result), result;
|
|
20358
20611
|
}, "__decorateClass$5"), __decorateParam$5 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$5"), __publicField$1 = /* @__PURE__ */ __name((obj, key, value) => __defNormalProp$1(obj, typeof key != "symbol" ? key + "" : key, value), "__publicField$1"), _a53;
|
|
20359
20612
|
let UniverSheetsUIPlugin = (_a53 = class extends Plugin {
|
|
20613
|
+
/** @ignore */
|
|
20360
20614
|
constructor(_config = {}, _injector, _renderManagerService, _univerInstanceService) {
|
|
20361
20615
|
super(), this._config = _config, this._injector = _injector, this._renderManagerService = _renderManagerService, this._univerInstanceService = _univerInstanceService, this._config = Tools.deepMerge({}, DefaultSheetUiConfig, this._config);
|
|
20362
20616
|
}
|
|
20363
20617
|
onStarting() {
|
|
20364
20618
|
mergeOverrideWithDependencies([
|
|
20365
|
-
// services
|
|
20366
20619
|
[ShortcutExperienceService],
|
|
20367
20620
|
[IEditorBridgeService, { useClass: EditorBridgeService }],
|
|
20368
20621
|
[ISheetClipboardService, { useClass: SheetClipboardService }],
|
|
@@ -20372,26 +20625,22 @@ let UniverSheetsUIPlugin = (_a53 = class extends Plugin {
|
|
|
20372
20625
|
[IFormulaEditorManagerService, { useClass: FormulaEditorManagerService }],
|
|
20373
20626
|
[IAutoFillService, { useClass: AutoFillService }],
|
|
20374
20627
|
[SheetPrintInterceptorService],
|
|
20375
|
-
// This would be removed from global injector and moved into RenderUnit provider.
|
|
20376
|
-
// [SheetSkeletonManagerService],
|
|
20377
20628
|
[IStatusBarService, { useClass: StatusBarService }],
|
|
20378
20629
|
[IMarkSelectionService, { useClass: MarkSelectionService }],
|
|
20379
20630
|
[HoverManagerService],
|
|
20380
20631
|
[DragManagerService],
|
|
20381
20632
|
[SheetCanvasPopManagerService],
|
|
20382
20633
|
[CellAlertManagerService],
|
|
20634
|
+
[SelectAllService],
|
|
20383
20635
|
// controllers
|
|
20384
20636
|
[ActiveWorksheetController],
|
|
20385
20637
|
[AutoHeightController],
|
|
20386
20638
|
[FormulaEditorController],
|
|
20387
20639
|
[SheetClipboardController],
|
|
20388
20640
|
[SheetsRenderService],
|
|
20389
|
-
[
|
|
20390
|
-
SheetUIController,
|
|
20391
|
-
|
|
20392
|
-
useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(SheetUIController, this._config), "useFactory")
|
|
20393
|
-
}
|
|
20394
|
-
],
|
|
20641
|
+
[SheetUIController, {
|
|
20642
|
+
useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(SheetUIController, this._config), "useFactory")
|
|
20643
|
+
}],
|
|
20395
20644
|
[StatusBarController],
|
|
20396
20645
|
[AutoFillController],
|
|
20397
20646
|
[FormatPainterController],
|
|
@@ -20402,22 +20651,15 @@ let UniverSheetsUIPlugin = (_a53 = class extends Plugin {
|
|
|
20402
20651
|
[WorksheetProtectionRenderService],
|
|
20403
20652
|
[SheetPermissionInterceptorClipboardController],
|
|
20404
20653
|
[SheetPermissionInterceptorBaseController],
|
|
20405
|
-
[SheetPermissionInitController]
|
|
20406
|
-
|
|
20407
|
-
], this._config.override).forEach((d) => this._injector.add(d))
|
|
20408
|
-
[
|
|
20409
|
-
SheetPermissionRenderManagerController,
|
|
20410
|
-
{
|
|
20411
|
-
useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(SheetPermissionRenderManagerController, this._config), "useFactory")
|
|
20412
|
-
}
|
|
20413
|
-
]
|
|
20414
|
-
);
|
|
20654
|
+
[SheetPermissionInitController],
|
|
20655
|
+
[SheetPermissionRenderManagerController]
|
|
20656
|
+
], this._config.override).forEach((d) => this._injector.add(d));
|
|
20415
20657
|
}
|
|
20416
20658
|
onReady() {
|
|
20417
|
-
this._markSheetAsFocused(), this._registerRenderBasics();
|
|
20659
|
+
this._config.disableAutoFocus || this._markSheetAsFocused(), this._registerRenderBasics();
|
|
20418
20660
|
}
|
|
20419
20661
|
onRendered() {
|
|
20420
|
-
this._registerRenderModules();
|
|
20662
|
+
this._registerRenderModules(), this._injector.get(SheetPermissionRenderManagerController);
|
|
20421
20663
|
}
|
|
20422
20664
|
_registerRenderBasics() {
|
|
20423
20665
|
[
|
|
@@ -20435,8 +20677,7 @@ let UniverSheetsUIPlugin = (_a53 = class extends Plugin {
|
|
|
20435
20677
|
[HeaderMoveRenderController],
|
|
20436
20678
|
[HeaderUnhideRenderController],
|
|
20437
20679
|
[HeaderResizeRenderController],
|
|
20438
|
-
// Caution: ScrollRenderController should placed before ZoomRenderController
|
|
20439
|
-
// because ZoomRenderController ---> viewport.resize --> setScrollInfo, but ScrollRenderController needs scrollInfo
|
|
20680
|
+
// Caution: ScrollRenderController should placed before ZoomRenderController.
|
|
20440
20681
|
[SheetScrollManagerService],
|
|
20441
20682
|
[SheetsScrollRenderController],
|
|
20442
20683
|
[HeaderFreezeRenderController],
|
|
@@ -20465,7 +20706,7 @@ let UniverSheetsUIPlugin = (_a53 = class extends Plugin {
|
|
|
20465
20706
|
}
|
|
20466
20707
|
_markSheetAsFocused() {
|
|
20467
20708
|
const univerInstanceService = this._univerInstanceService;
|
|
20468
|
-
univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET).pipe(filter$1((v) => !!v)).subscribe((workbook) => univerInstanceService.focusUnit(workbook.getUnitId()));
|
|
20709
|
+
this.disposeWithMe(univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET).pipe(filter$1((v) => !!v)).subscribe((workbook) => univerInstanceService.focusUnit(workbook.getUnitId())));
|
|
20469
20710
|
}
|
|
20470
20711
|
}, __name(_a53, "UniverSheetsUIPlugin"), _a53);
|
|
20471
20712
|
__publicField$1(UniverSheetsUIPlugin, "pluginName", "SHEET_UI_PLUGIN");
|
|
@@ -21140,8 +21381,8 @@ SheetContextMenuMobileRenderController = __decorateClass$2([
|
|
|
21140
21381
|
__decorateParam$2(5, Inject(SheetSkeletonManagerService))
|
|
21141
21382
|
], SheetContextMenuMobileRenderController);
|
|
21142
21383
|
const _MobileSelectionControl = class _MobileSelectionControl extends SelectionControl {
|
|
21143
|
-
constructor(_scene, _zIndex,
|
|
21144
|
-
super(_scene, _zIndex,
|
|
21384
|
+
constructor(_scene, _zIndex, _highlightHeader = !0, _themeService, _rangeType = RANGE_TYPE.NORMAL) {
|
|
21385
|
+
super(_scene, _zIndex, _themeService, _highlightHeader);
|
|
21145
21386
|
/**
|
|
21146
21387
|
* topLeft controlPointer, it is not visible, just transparent, for handling event.
|
|
21147
21388
|
*/
|
|
@@ -21158,7 +21399,7 @@ const _MobileSelectionControl = class _MobileSelectionControl extends SelectionC
|
|
|
21158
21399
|
* a very small visible point, placed in control pointer
|
|
21159
21400
|
*/
|
|
21160
21401
|
__publicField(this, "_fillControlBottomRightInner");
|
|
21161
|
-
this._scene = _scene, this._zIndex = _zIndex, this.
|
|
21402
|
+
this._scene = _scene, this._zIndex = _zIndex, this._highlightHeader = _highlightHeader, this._themeService = _themeService, this._rangeType = _rangeType, this.initControlPoints();
|
|
21162
21403
|
}
|
|
21163
21404
|
initControlPoints() {
|
|
21164
21405
|
const defaultStyle = this.defaultStyle, expandCornerSize = defaultStyle.expandCornerSize || 0, expandCornerInnerSize = (defaultStyle.expandCornerSize || 0) / 4, AutofillStrokeWidth = defaultStyle.AutofillStrokeWidth || 0, stroke = defaultStyle.stroke, AutofillStroke = defaultStyle.AutofillStroke, zIndex = this.zIndex, RectCtor = Rect;
|
|
@@ -21229,11 +21470,11 @@ const _MobileSelectionControl = class _MobileSelectionControl extends SelectionC
|
|
|
21229
21470
|
(_a59 = this._fillControlBottomRight) == null || _a59.dispose(), (_b = this._fillControlTopLeft) == null || _b.dispose(), super.dispose();
|
|
21230
21471
|
}
|
|
21231
21472
|
updateRange(range) {
|
|
21232
|
-
this._selectionModel.setValue(range)
|
|
21473
|
+
this._selectionModel.setValue(range);
|
|
21233
21474
|
}
|
|
21234
|
-
|
|
21475
|
+
_updateControlStyleAndLayout(style) {
|
|
21235
21476
|
var _a59, _b, _c, _d;
|
|
21236
|
-
super.
|
|
21477
|
+
super._updateControlStyleAndLayout(style);
|
|
21237
21478
|
const defaultStyle = this.defaultStyle;
|
|
21238
21479
|
style == null && (style = defaultStyle);
|
|
21239
21480
|
const {
|
|
@@ -21330,12 +21571,12 @@ var __defProp$1 = Object.defineProperty, __getOwnPropDesc$1 = Object.getOwnPrope
|
|
|
21330
21571
|
return kind && result && __defProp$1(target, key, result), result;
|
|
21331
21572
|
}, "__decorateClass$1"), __decorateParam$1 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$1"), _a57;
|
|
21332
21573
|
let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRenderService {
|
|
21333
|
-
constructor(_context, injector, themeService, shortcutService,
|
|
21574
|
+
constructor(_context, injector, themeService, shortcutService, selectionManagerService, sheetSkeletonManagerService, _logService, _commandService, _contextService, _scrollManagerService) {
|
|
21334
21575
|
super(
|
|
21335
21576
|
injector,
|
|
21336
21577
|
themeService,
|
|
21337
21578
|
shortcutService,
|
|
21338
|
-
|
|
21579
|
+
sheetSkeletonManagerService
|
|
21339
21580
|
);
|
|
21340
21581
|
__publicField(this, "_workbookSelections");
|
|
21341
21582
|
__publicField(this, "_renderDisposable", null);
|
|
@@ -21343,7 +21584,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21343
21584
|
__publicField(this, "_selectionControls", []);
|
|
21344
21585
|
// sheetID:Controls
|
|
21345
21586
|
__publicField(this, "expandingControlMode", "bottom-right");
|
|
21346
|
-
this._context = _context, this._logService = _logService, this._commandService = _commandService, this._contextService = _contextService, this.
|
|
21587
|
+
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
21588
|
}
|
|
21348
21589
|
_init() {
|
|
21349
21590
|
const sheetObject = this._getSheetObject();
|
|
@@ -21467,11 +21708,11 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21467
21708
|
activeSelectionControl = control;
|
|
21468
21709
|
break;
|
|
21469
21710
|
}
|
|
21470
|
-
(activeSelectionControl == null ? void 0 : activeSelectionControl.model.rangeType) !== rangeType && (this._clearSelectionControls(), activeSelectionControl = this.newSelectionControl(scene, rangeType)), this.
|
|
21711
|
+
(activeSelectionControl == null ? void 0 : activeSelectionControl.model.rangeType) !== rangeType && (this._clearSelectionControls(), activeSelectionControl = this.newSelectionControl(scene, rangeType)), this._updateSelectionControlByRange(
|
|
21471
21712
|
activeSelectionControl,
|
|
21472
21713
|
cursorCellRangeWithRangeType,
|
|
21473
21714
|
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.
|
|
21715
|
+
), 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
21716
|
}
|
|
21476
21717
|
/**
|
|
21477
21718
|
* Not same as PC version,
|
|
@@ -21557,9 +21798,11 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21557
21798
|
if (!activeSelectionControl) return;
|
|
21558
21799
|
this._changeCurrCellWhenControlPointerDown(), this._selectionMoveStart$.next(this.getSelectionDataWithStyle()), this._clearUpdatingListeners(), this._addEndingListeners(), this._scrollTimer = ScrollTimer.create(this._scene, scrollTimerType), this._scrollTimer.startScroll((_a59 = viewportMain == null ? void 0 : viewportMain.left) != null ? _a59 : 0, (_b = viewportMain == null ? void 0 : viewportMain.top) != null ? _b : 0, viewportMain), (_c = scene.getTransformer()) == null || _c.clearSelectedObjects();
|
|
21559
21800
|
const relativeCoords = scene.getRelativeToViewportCoord(Vector2.FromArray([evt.offsetX, evt.offsetY]));
|
|
21560
|
-
this._setupPointerMoveListener(viewportMain, activeSelectionControl, rangeType, scrollTimerType, relativeCoords.x, relativeCoords.y)
|
|
21561
|
-
|
|
21562
|
-
|
|
21801
|
+
this._setupPointerMoveListener(viewportMain, activeSelectionControl, rangeType, scrollTimerType, relativeCoords.x, relativeCoords.y);
|
|
21802
|
+
const disposableShortcut = this._shortcutService.forceEscape();
|
|
21803
|
+
this._scenePointerUpSub = scene.onPointerUp$.subscribeEvent((_evt) => {
|
|
21804
|
+
this.endSelection(), this._expandingSelection = !1, this.expandingControlMode = "bottom-right", this._selectionMoveEnd$.next(this.getSelectionDataWithStyle()), disposableShortcut.dispose();
|
|
21805
|
+
});
|
|
21563
21806
|
}
|
|
21564
21807
|
_changeCurrCellWhenControlPointerDown() {
|
|
21565
21808
|
const activeSelectionControl = this.getActiveSelectionControl(), skeleton = this._skeleton;
|
|
@@ -21596,7 +21839,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21596
21839
|
*
|
|
21597
21840
|
* In Mobile version, new selection is determined by cursor cell and current of activeSelectionControl.model
|
|
21598
21841
|
*/
|
|
21599
|
-
|
|
21842
|
+
_movingHandler(offsetX, offsetY, activeSelectionControl, rangeType) {
|
|
21600
21843
|
var _a59, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m;
|
|
21601
21844
|
this._shouldDetectMergedCells = rangeType === RANGE_TYPE.NORMAL;
|
|
21602
21845
|
const skeleton = this._skeleton, scene = this._scene, currSelectionRange = {
|
|
@@ -21641,7 +21884,7 @@ let MobileSheetsSelectionRenderService = (_a57 = class extends BaseSelectionRend
|
|
|
21641
21884
|
startX: (startCellXY == null ? void 0 : startCellXY.startX) || 0,
|
|
21642
21885
|
endX: (endCellXY == null ? void 0 : endCellXY.endX) || 0
|
|
21643
21886
|
};
|
|
21644
|
-
(currSelectionRange.startRow !== newSelectionRange.startRow || currSelectionRange.startColumn !== newSelectionRange.startColumn || currSelectionRange.endRow !== newSelectionRange.endRow || currSelectionRange.endColumn !== newSelectionRange.endColumn) && activeSelectionControl && (this.
|
|
21887
|
+
(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
21888
|
}
|
|
21646
21889
|
_updateControlPointWhenScrolling() {
|
|
21647
21890
|
const { scene } = this._context;
|
|
@@ -21663,13 +21906,12 @@ MobileSheetsSelectionRenderService = __decorateClass$1([
|
|
|
21663
21906
|
__decorateParam$1(1, Inject(Injector)),
|
|
21664
21907
|
__decorateParam$1(2, Inject(ThemeService)),
|
|
21665
21908
|
__decorateParam$1(3, IShortcutService),
|
|
21666
|
-
__decorateParam$1(4,
|
|
21667
|
-
__decorateParam$1(5, Inject(
|
|
21909
|
+
__decorateParam$1(4, Inject(SheetsSelectionsService)),
|
|
21910
|
+
__decorateParam$1(5, Inject(SheetSkeletonManagerService)),
|
|
21668
21911
|
__decorateParam$1(6, ILogService),
|
|
21669
21912
|
__decorateParam$1(7, ICommandService),
|
|
21670
21913
|
__decorateParam$1(8, IContextService),
|
|
21671
|
-
__decorateParam$1(9, Inject(
|
|
21672
|
-
__decorateParam$1(10, Inject(SheetScrollManagerService))
|
|
21914
|
+
__decorateParam$1(9, Inject(SheetScrollManagerService))
|
|
21673
21915
|
], MobileSheetsSelectionRenderService);
|
|
21674
21916
|
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
21917
|
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
|
|
@@ -21682,15 +21924,12 @@ let UniverSheetsMobileUIPlugin = (_a58 = class extends Plugin {
|
|
|
21682
21924
|
}
|
|
21683
21925
|
onStarting() {
|
|
21684
21926
|
[
|
|
21685
|
-
// services
|
|
21686
21927
|
[ShortcutExperienceService],
|
|
21687
21928
|
[ISheetClipboardService, { useClass: SheetClipboardService }],
|
|
21688
21929
|
[ISheetBarService, { useClass: SheetBarService }],
|
|
21689
21930
|
[IFormatPainterService, { useClass: FormatPainterService }],
|
|
21690
21931
|
[IAutoFillService, { useClass: AutoFillService }],
|
|
21691
21932
|
[SheetPrintInterceptorService],
|
|
21692
|
-
// This would be removed from global injector and moved into RenderUnit provider.
|
|
21693
|
-
// [SheetSkeletonManagerService],
|
|
21694
21933
|
[ISheetSelectionRenderService, { useClass: MobileSheetsSelectionRenderService }],
|
|
21695
21934
|
[IStatusBarService, { useClass: StatusBarService }],
|
|
21696
21935
|
[IMarkSelectionService, { useClass: MarkSelectionService }],
|
|
@@ -21698,35 +21937,24 @@ let UniverSheetsMobileUIPlugin = (_a58 = class extends Plugin {
|
|
|
21698
21937
|
[DragManagerService],
|
|
21699
21938
|
[SheetCanvasPopManagerService],
|
|
21700
21939
|
[CellAlertManagerService],
|
|
21701
|
-
|
|
21940
|
+
[SelectAllService],
|
|
21702
21941
|
[ActiveWorksheetController],
|
|
21703
21942
|
[AutoHeightController],
|
|
21704
21943
|
[SheetClipboardController],
|
|
21705
21944
|
[SheetsRenderService],
|
|
21706
|
-
[
|
|
21707
|
-
SheetUIMobileController,
|
|
21708
|
-
|
|
21709
|
-
useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(SheetUIMobileController, this._config), "useFactory")
|
|
21710
|
-
}
|
|
21711
|
-
],
|
|
21945
|
+
[SheetUIMobileController, {
|
|
21946
|
+
useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(SheetUIMobileController, this._config), "useFactory")
|
|
21947
|
+
}],
|
|
21712
21948
|
[StatusBarController],
|
|
21713
|
-
// [AutoFillController],
|
|
21714
|
-
// [FormatPainterController],
|
|
21715
21949
|
// permission
|
|
21716
21950
|
[SheetPermissionPanelModel],
|
|
21717
21951
|
[SheetPermissionUserManagerService],
|
|
21718
21952
|
[WorksheetProtectionRenderService],
|
|
21719
21953
|
[SheetPermissionInterceptorClipboardController],
|
|
21720
21954
|
[SheetPermissionInterceptorBaseController],
|
|
21721
|
-
[SheetPermissionInitController]
|
|
21722
|
-
|
|
21723
|
-
|
|
21724
|
-
SheetPermissionRenderManagerController,
|
|
21725
|
-
{
|
|
21726
|
-
useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(SheetPermissionRenderManagerController, this._config), "useFactory")
|
|
21727
|
-
}
|
|
21728
|
-
]
|
|
21729
|
-
);
|
|
21955
|
+
[SheetPermissionInitController],
|
|
21956
|
+
[SheetPermissionRenderManagerController]
|
|
21957
|
+
].forEach((d) => this._injector.add(d));
|
|
21730
21958
|
}
|
|
21731
21959
|
onReady() {
|
|
21732
21960
|
this._markSheetAsFocused(), this._registerRenderBasics();
|
|
@@ -21755,8 +21983,7 @@ let UniverSheetsMobileUIPlugin = (_a58 = class extends Plugin {
|
|
|
21755
21983
|
[HeaderMoveRenderController],
|
|
21756
21984
|
[HeaderFreezeRenderController],
|
|
21757
21985
|
// Caution: ScrollRenderController should placed before ZoomRenderController
|
|
21758
|
-
// because ZoomRenderController would change scrollInfo in currentSkeletonBefore
|
|
21759
|
-
// currentSkeletonBefore$ --> ZoomRenderController ---> viewport.resize --> setScrollInfo, but ScrollRenderController needs scrollInfo
|
|
21986
|
+
// because ZoomRenderController would change scrollInfo in currentSkeletonBefore$.
|
|
21760
21987
|
[MobileSheetsScrollRenderController],
|
|
21761
21988
|
[SheetsZoomRenderController],
|
|
21762
21989
|
[FormatPainterRenderController],
|
|
@@ -21777,9 +22004,9 @@ let UniverSheetsMobileUIPlugin = (_a58 = class extends Plugin {
|
|
|
21777
22004
|
}
|
|
21778
22005
|
_markSheetAsFocused() {
|
|
21779
22006
|
const univerInstanceService = this._univerInstanceService;
|
|
21780
|
-
univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET).pipe(filter$1((v) => !!v)).subscribe((workbook) => {
|
|
22007
|
+
this.disposeWithMe(univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_SHEET).pipe(filter$1((v) => !!v)).subscribe((workbook) => {
|
|
21781
22008
|
univerInstanceService.focusUnit(workbook.getUnitId());
|
|
21782
|
-
});
|
|
22009
|
+
}));
|
|
21783
22010
|
}
|
|
21784
22011
|
}, __name(_a58, "UniverSheetsMobileUIPlugin"), _a58);
|
|
21785
22012
|
__publicField2(UniverSheetsMobileUIPlugin, "pluginName", "SHEET_UI_PLUGIN");
|
|
@@ -21841,6 +22068,7 @@ export {
|
|
|
21841
22068
|
IAutoFillService,
|
|
21842
22069
|
ICellEditorManagerService,
|
|
21843
22070
|
IEditorBridgeService,
|
|
22071
|
+
IFormatPainterService,
|
|
21844
22072
|
IFormulaEditorManagerService,
|
|
21845
22073
|
IMarkSelectionService,
|
|
21846
22074
|
ISheetClipboardService,
|
|
@@ -21863,6 +22091,7 @@ export {
|
|
|
21863
22091
|
RenderSheetFooter,
|
|
21864
22092
|
RenderSheetHeader,
|
|
21865
22093
|
ResetScrollCommand,
|
|
22094
|
+
SELECTION_SHAPE_DEPTH,
|
|
21866
22095
|
SHEET_UI_PLUGIN_NAME,
|
|
21867
22096
|
SHEET_VIEW_KEY,
|
|
21868
22097
|
ScrollCommand,
|