@univerjs/docs-ui 0.2.6 → 0.2.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/lib/cjs/index.js +7 -4
  2. package/lib/es/index.js +1907 -640
  3. package/lib/index.css +1 -1
  4. package/lib/locale/en-US.json +38 -0
  5. package/lib/locale/ru-RU.json +39 -1
  6. package/lib/locale/vi-VN.json +39 -1
  7. package/lib/locale/zh-CN.json +40 -2
  8. package/lib/locale/zh-TW.json +39 -1
  9. package/lib/types/basics/interfaces/component-config/i-doc-ui-plugin-config.d.ts +2 -0
  10. package/lib/types/commands/commands/doc-paragraph-setting.command.d.ts +4 -0
  11. package/lib/types/commands/commands/doc-tab.command.d.ts +8 -0
  12. package/lib/types/commands/operations/doc-create-table.operation.d.ts +3 -0
  13. package/lib/types/commands/operations/doc-paragraph-setting-panel.operation.d.ts +3 -0
  14. package/lib/types/components/list-type-picker/index.d.ts +18 -0
  15. package/lib/types/components/list-type-picker/picker.d.ts +17 -0
  16. package/lib/types/controllers/doc-auto-format.controller.d.ts +11 -0
  17. package/lib/types/controllers/doc-header-footer.controller.d.ts +0 -1
  18. package/lib/types/controllers/doc-paragraph-setting.controller.d.ts +11 -0
  19. package/lib/types/controllers/doc-table.controller.d.ts +12 -0
  20. package/lib/types/controllers/doc-ui.controller.d.ts +12 -10
  21. package/lib/types/controllers/menu/context-menu.d.ts +11 -1
  22. package/lib/types/controllers/menu/menu.d.ts +9 -4
  23. package/lib/types/controllers/render-controllers/doc-checklist.render-controller.d.ts +15 -0
  24. package/lib/types/controllers/render-controllers/doc.render-controller.d.ts +3 -2
  25. package/lib/types/controllers/render-controllers/zoom.render-controller.d.ts +3 -3
  26. package/lib/types/docs-ui-plugin.d.ts +6 -3
  27. package/lib/types/index.d.ts +2 -0
  28. package/lib/types/locale/zh-CN.d.ts +38 -0
  29. package/lib/types/services/clipboard/clipboard.service.d.ts +2 -2
  30. package/lib/types/services/clipboard/copy-content-cache.d.ts +3 -3
  31. package/lib/types/services/clipboard/html-to-udm/converter.d.ts +5 -2
  32. package/lib/types/services/clipboard/html-to-udm/paste-plugins/type.d.ts +2 -2
  33. package/lib/types/services/clipboard/udm-to-html/convertor.d.ts +1 -1
  34. package/lib/types/services/doc-hover-manager.service.d.ts +3 -1
  35. package/lib/types/shortcuts/format.shortcut.d.ts +4 -0
  36. package/lib/types/views/paragraph-setting/Setting.d.ts +17 -0
  37. package/lib/types/views/paragraph-setting/hook/utils.d.ts +11 -0
  38. package/lib/types/views/paragraph-setting/index.d.ts +3 -0
  39. package/lib/types/views/table/create/TableCreate.d.ts +11 -0
  40. package/lib/types/views/table/create/component-name.d.ts +16 -0
  41. package/lib/umd/index.js +7 -4
  42. package/package.json +16 -13
  43. /package/lib/types/{controllers/shortcut → shortcuts}/toolbar.shortcut.d.ts +0 -0
package/lib/es/index.js CHANGED
@@ -2,13 +2,14 @@ var __defProp = Object.defineProperty;
2
2
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: !0, configurable: !0, writable: !0, value }) : obj[key] = value;
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
- import { FOCUSING_DOC, FOCUSING_UNIVER_EDITOR, FOCUSING_COMMON_DRAWINGS, FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE, Tools, LRUMap, BaselineOffset, BooleanNumber, ColorKit, DataStreamTreeTokenType, CustomRangeType, skipParseTagNames, createIdentifier, Inject, IUniverInstanceService, ILogService, ICommandService, Disposable, SliceBodyType, normalizeBody, UniverInstanceType, toDisposable, RxDisposable, Direction, EDITOR_ACTIVATED, LocaleService, Injector, Optional, useDependency, useObservable, CommandType, DocumentFlavor, JSONX, ThemeService, HorizontalAlign, connectInjector, OnLifecycle, LifecycleStages, IContextService, checkForSubstrings, IConfigService, isInternalEditorID, DisposableCollection, DEFAULT_EMPTY_DOCUMENT_VALUE, DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY, DOCS_NORMAL_EDITOR_UNIT_ID_KEY, DOCS_ZEN_EDITOR_UNIT_ID_KEY, fromEventSubject, Plugin, ObjectRelativeFromH, ObjectRelativeFromV } from "@univerjs/core";
6
- import { IClipboardInterfaceService, PLAIN_TEXT_CLIPBOARD_MIME_TYPE, HTML_CLIPBOARD_MIME_TYPE, IEditorService, KeyCode, MetaKeys, ILayoutService, ISidebarService, ComponentManager, MenuGroup, MenuItemType, MenuPosition, getMenuHiddenObservable, FONT_FAMILY_LIST, FONT_SIZE_LIST, getHeaderFooterMenuHiddenObservable, CopyCommand, CutCommand, PasteCommand, FontFamily, FontFamilyItem, FontSize, BuiltInUIPart, IMenuService, IUIPartsService, IShortcutService, SetEditorResizeOperation, ICanvasPopupService, IContextMenuService } from "@univerjs/ui";
7
- import { TextSelectionManagerService, DocCustomRangeService, CutContentCommand, InnerPasteCommand, getDeleteSelection, DocSkeletonManagerService, VIEWPORT_KEY, getDocObject, MoveCursorOperation, MoveSelectionOperation, SelectAllOperation, SetDocZoomRatioOperation, neoGetDocObject, RichTextEditingMutation, SetInlineFormatBoldCommand, SetTextSelectionsOperation, SetInlineFormatCommand, SetInlineFormatItalicCommand, SetInlineFormatUnderlineCommand, SetInlineFormatStrikethroughCommand, SetInlineFormatSubscriptCommand, SetInlineFormatSuperscriptCommand, SetInlineFormatFontFamilyCommand, SetInlineFormatFontSizeCommand, SetInlineFormatTextColorCommand, AlignLeftCommand, AlignOperationCommand, AlignCenterCommand, AlignRightCommand, AlignJustifyCommand, OrderListCommand, BulletListCommand, ResetInlineFormatTextBackgroundColorCommand, SetInlineFormatTextBackgroundColorCommand, DeleteLeftCommand, BreakLineCommand, DeleteRightCommand, CoverContentCommand, DOCS_COMPONENT_MAIN_LAYER_INDEX, DOCS_COMPONENT_HEADER_LAYER_INDEX, DOCS_VIEW_KEY, DOCS_COMPONENT_DEFAULT_Z_INDEX, DOCS_COMPONENT_BACKGROUND_LAYER_INDEX, SetDocZoomRatioCommand, DocInterceptorService } from "@univerjs/docs";
8
- import { pixelToPt, ptToPixel, NodePositionConvertToCursor, getAnchorBounding, IRenderManagerService, ITextSelectionRenderManager, Shape, DocumentEditArea, PageLayoutType, Vector2, Rect, Path, ScrollBar, Viewport, Layer, Documents, DocBackground, CURSOR_TYPE, pxToNum, getLineBounding, TRANSFORM_CHANGE_OBSERVABLE_TYPE } from "@univerjs/engine-render";
9
- import { takeUntil, Observable, combineLatest, fromEvent, BehaviorSubject, map, filter, throttleTime, debounceTime } from "rxjs";
10
- import require$$0, { useMemo, useCallback, useState, useEffect } from "react";
11
- import { Slider, Checkbox, InputNumber, Button, ColorPicker } from "@univerjs/design";
5
+ import { FOCUSING_DOC, FOCUSING_UNIVER_EDITOR, FOCUSING_COMMON_DRAWINGS, FOCUSING_UNIVER_EDITOR_STANDALONE_SINGLE_MODE, Tools, LRUMap, BaselineOffset, BooleanNumber, ColorKit, DataStreamTreeTokenType, CustomRangeType, skipParseTagNames, DataStreamTreeNodeType, createIdentifier, Inject, IUniverInstanceService, ILogService, ICommandService, Disposable, SliceBodyType, normalizeBody, UniverInstanceType, toDisposable, getBodySlice, RxDisposable, Direction, EDITOR_ACTIVATED, LocaleService, Injector, Optional, useDependency, DocumentFlavor, CommandType, JSONX, useObservable, PresetListType, ThemeService, HorizontalAlign, MemoryCursor, TextX, TextXActionType, UpdateDocsAttributeType, generateRandomId, OnLifecycle, LifecycleStages, connectInjector, IContextService, checkForSubstrings, IConfigService, isInternalEditorID, DisposableCollection, DEFAULT_EMPTY_DOCUMENT_VALUE, DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY, DOCS_NORMAL_EDITOR_UNIT_ID_KEY, DOCS_ZEN_EDITOR_UNIT_ID_KEY, fromEventSubject, QuickListTypeMap, Plugin, mergeOverrideWithDependencies, ObjectRelativeFromH, ObjectRelativeFromV } from "@univerjs/core";
6
+ import { IClipboardInterfaceService, PLAIN_TEXT_CLIPBOARD_MIME_TYPE, HTML_CLIPBOARD_MIME_TYPE, IEditorService, KeyCode, MetaKeys, ILayoutService, ComponentManager, ISidebarService, IConfirmService, MenuGroup, MenuItemType, MenuPosition, getMenuHiddenObservable, FONT_FAMILY_LIST, FONT_SIZE_LIST, getHeaderFooterMenuHiddenObservable, CopyCommand, CutCommand, PasteCommand, FontFamily, FontFamilyItem, FontSize, BuiltInUIPart, IMenuService, IUIPartsService, IShortcutService, SetEditorResizeOperation, ICanvasPopupService, IContextMenuService } from "@univerjs/ui";
7
+ import { getEmptyTableCell, getEmptyTableRow, genTableSource, getTableColumn, TextSelectionManagerService, DocCustomRangeService, getCursorWhenDelete, CutContentCommand, InnerPasteCommand, getDeleteSelection, DocSkeletonManagerService, VIEWPORT_KEY, getDocObject, MoveCursorOperation, MoveSelectionOperation, SelectAllOperation, neoGetDocObject, RichTextEditingMutation, SetDocZoomRatioOperation, SetInlineFormatBoldCommand, SetInlineFormatItalicCommand, SetInlineFormatUnderlineCommand, SetInlineFormatStrikethroughCommand, SetInlineFormatSubscriptCommand, SetInlineFormatSuperscriptCommand, AlignLeftCommand, AlignRightCommand, AlignCenterCommand, AlignJustifyCommand, OrderListCommand, BulletListCommand, TabCommand, CreateDocTableCommand, SetTextSelectionsOperation, SetInlineFormatCommand, SetInlineFormatFontFamilyCommand, SetInlineFormatFontSizeCommand, SetInlineFormatTextColorCommand, AlignOperationCommand, CheckListCommand, ResetInlineFormatTextBackgroundColorCommand, SetInlineFormatTextBackgroundColorCommand, getCommandSkeleton, getParagraphsInRange, getParagraphsInRanges, serializeDocRange, getRichTextEditPath, DeleteLeftCommand, DocTableInsertRowAboveCommand, DocTableInsertRowBellowCommand, DocTableInsertColumnLeftCommand, DocTableInsertColumnRightCommand, DocTableDeleteRowsCommand, DocTableDeleteColumnsCommand, DocTableDeleteTableCommand, EnterCommand, DeleteRightCommand, CoverContentCommand, DOCS_COMPONENT_MAIN_LAYER_INDEX, DOCS_COMPONENT_HEADER_LAYER_INDEX, DOCS_VIEW_KEY, DOCS_COMPONENT_DEFAULT_Z_INDEX, DOCS_COMPONENT_BACKGROUND_LAYER_INDEX, SetDocZoomRatioCommand, ChangeListNestingLevelCommand, ChangeListNestingLevelType, AfterSpaceCommand, QuickListCommand, ListOperationCommand, BreakLineCommand, DocAutoFormatService, ToggleCheckListCommand, DocTableTabCommand, DocTableShiftTabCommand, DocInterceptorService } from "@univerjs/docs";
8
+ import { pixelToPt, ptToPixel, parseDataStreamToTree, DOC_RANGE_TYPE, NodePositionConvertToCursor, getAnchorBounding, IRenderManagerService, ITextSelectionRenderManager, Shape, DocumentEditArea, PageLayoutType, Vector2, Rect, Path, getNumberUnitValue, ScrollBar, Viewport, Layer, Documents, DocBackground, CURSOR_TYPE, pxToNum, getLineBounding, TRANSFORM_CHANGE_OBSERVABLE_TYPE, getParagraphByGlyph, GlyphType, isInSameTableCell } from "@univerjs/engine-render";
9
+ import { takeUntil, Observable, combineLatest, map, fromEvent, BehaviorSubject, filter, throttleTime, Subject, debounceTime } from "rxjs";
10
+ import * as require$$0 from "react";
11
+ import require$$0__default, { forwardRef, useRef, createElement, useState, useEffect, useMemo, useCallback } from "react";
12
+ import { Checkbox, InputNumber, Button, Slider, Tooltip, ColorPicker } from "@univerjs/design";
12
13
  import clsx from "clsx";
13
14
  function whenDocAndEditorFocused(contextService) {
14
15
  return contextService.getContextValue(FOCUSING_DOC) && contextService.getContextValue(FOCUSING_UNIVER_EDITOR) && !contextService.getContextValue(FOCUSING_COMMON_DRAWINGS);
@@ -135,8 +136,9 @@ function matchFilter(node, filter2) {
135
136
  return typeof filter2 == "string" ? tagName === filter2 : Array.isArray(filter2) ? filter2.some((name) => name === tagName) : filter2(node);
136
137
  }
137
138
  __name(matchFilter, "matchFilter");
138
- const _HtmlToUDMService = class _HtmlToUDMService {
139
+ const DEFAULT_TABLE_WIDTH = 600, _HtmlToUDMService = class _HtmlToUDMService {
139
140
  constructor() {
141
+ __publicField(this, "_tableCache", []);
140
142
  __publicField(this, "_styleCache", /* @__PURE__ */ new Map());
141
143
  __publicField(this, "_styleRules", []);
142
144
  __publicField(this, "_afterProcessRules", []);
@@ -147,37 +149,41 @@ const _HtmlToUDMService = class _HtmlToUDMService {
147
149
  this._pluginList.push(plugin);
148
150
  }
149
151
  convert(html) {
150
- const pastePlugin = _HtmlToUDMService._pluginList.find((plugin) => plugin.checkPasteType(html)), dom = parseToDom(html), newDocBody = {
151
- dataStream: "",
152
- textRuns: []
152
+ const pastePlugin = _HtmlToUDMService._pluginList.find((plugin) => plugin.checkPasteType(html)), dom = parseToDom(html), docData = {
153
+ body: {
154
+ dataStream: "",
155
+ textRuns: []
156
+ },
157
+ tableSource: {}
153
158
  };
154
- return pastePlugin && (this._styleRules = [...pastePlugin.stylesRules], this._afterProcessRules = [...pastePlugin.afterProcessRules]), this._styleCache.clear(), this._process(null, dom == null ? void 0 : dom.childNodes, newDocBody), this._styleCache.clear(), this._styleRules = [], this._afterProcessRules = [], newDocBody;
159
+ return pastePlugin && (this._styleRules = [...pastePlugin.stylesRules], this._afterProcessRules = [...pastePlugin.afterProcessRules]), this._tableCache = [], this._styleCache.clear(), this._process(null, dom.childNodes, docData), this._styleCache.clear(), this._styleRules = [], this._afterProcessRules = [], docData;
155
160
  }
156
161
  _process(parent, nodes, doc) {
157
- var _a19, _b, _c;
162
+ var _a23, _b, _c;
163
+ const body = doc.body;
158
164
  for (const node of nodes)
159
165
  if (node.nodeType === Node.TEXT_NODE) {
160
- if (((_a19 = node.nodeValue) == null ? void 0 : _a19.trim()) === "")
166
+ if (((_a23 = node.nodeValue) == null ? void 0 : _a23.trim()) === "")
161
167
  continue;
162
168
  let text = (_b = node.nodeValue) == null ? void 0 : _b.replace(/[\r\n]/g, ""), style;
163
169
  if (parent && parent.nodeType === Node.ELEMENT_NODE && parent.tagName.toUpperCase() === "A") {
164
170
  const id = Tools.generateRandomId();
165
- text = `${DataStreamTreeTokenType.CUSTOM_RANGE_START}${text}${DataStreamTreeTokenType.CUSTOM_RANGE_END}`, doc.customRanges = [
166
- ...(_c = doc.customRanges) != null ? _c : [],
171
+ text = `${DataStreamTreeTokenType.CUSTOM_RANGE_START}${text}${DataStreamTreeTokenType.CUSTOM_RANGE_END}`, body.customRanges = [
172
+ ...(_c = body.customRanges) != null ? _c : [],
167
173
  {
168
- startIndex: doc.dataStream.length,
169
- endIndex: doc.dataStream.length + text.length - 1,
174
+ startIndex: body.dataStream.length,
175
+ endIndex: body.dataStream.length + text.length - 1,
170
176
  rangeId: id,
171
177
  rangeType: CustomRangeType.HYPERLINK
172
178
  }
173
- ], doc.payloads = {
174
- ...doc.payloads,
179
+ ], body.payloads = {
180
+ ...body.payloads,
175
181
  [id]: parent.href
176
182
  };
177
183
  }
178
- parent && this._styleCache.has(parent) && (style = this._styleCache.get(parent)), doc.dataStream += text, style && Object.getOwnPropertyNames(style).length && doc.textRuns.push({
179
- st: doc.dataStream.length - text.length,
180
- ed: doc.dataStream.length,
184
+ parent && this._styleCache.has(parent) && (style = this._styleCache.get(parent)), body.dataStream += text, style && Object.getOwnPropertyNames(style).length && body.textRuns.push({
185
+ st: body.dataStream.length - text.length,
186
+ ed: body.dataStream.length,
181
187
  ts: style
182
188
  });
183
189
  } else {
@@ -187,7 +193,7 @@ const _HtmlToUDMService = class _HtmlToUDMService {
187
193
  const parentStyles = parent ? this._styleCache.get(parent) : {}, styleRule = this._styleRules.find(({ filter: filter2 }) => matchFilter(node, filter2)), nodeStyles = styleRule ? styleRule.getStyle(node) : extractNodeStyle(node);
188
194
  this._styleCache.set(node, { ...parentStyles, ...nodeStyles });
189
195
  const { childNodes } = node;
190
- this._process(node, childNodes, doc);
196
+ this._processBeforeTable(node, doc), this._process(node, childNodes, doc), this._processAfterTable(node, doc);
191
197
  const afterProcessRule = this._afterProcessRules.find(
192
198
  ({ filter: filter2 }) => matchFilter(node, filter2)
193
199
  );
@@ -195,6 +201,61 @@ const _HtmlToUDMService = class _HtmlToUDMService {
195
201
  }
196
202
  }
197
203
  }
204
+ _processBeforeTable(node, doc) {
205
+ var _a23;
206
+ const tagName = node.tagName.toUpperCase(), body = doc.body;
207
+ switch (tagName) {
208
+ case "TABLE": {
209
+ body.dataStream[body.dataStream.length - 1] !== "\r" && (body.dataStream += "\r", (_a23 = body.paragraphs) == null || _a23.push({
210
+ startIndex: body.dataStream.length - 1
211
+ }));
212
+ const table = genTableSource(0, 0, DEFAULT_TABLE_WIDTH);
213
+ this._tableCache.push({
214
+ table,
215
+ startIndex: body.dataStream.length
216
+ }), body.dataStream += DataStreamTreeTokenType.TABLE_START;
217
+ break;
218
+ }
219
+ case "TR": {
220
+ const row = getEmptyTableRow(0);
221
+ this._tableCache[this._tableCache.length - 1].table.tableRows.push(row), body.dataStream += DataStreamTreeTokenType.TABLE_ROW_START;
222
+ break;
223
+ }
224
+ case "TD": {
225
+ const cell = getEmptyTableCell(), lastTable = this._tableCache[this._tableCache.length - 1].table;
226
+ lastTable.tableRows[lastTable.tableRows.length - 1].tableCells.push(cell), body.dataStream += DataStreamTreeTokenType.TABLE_CELL_START;
227
+ break;
228
+ }
229
+ }
230
+ }
231
+ _processAfterTable(node, doc) {
232
+ var _a23;
233
+ const tagName = node.tagName.toUpperCase(), body = doc.body;
234
+ doc.tableSource == null && (doc.tableSource = {}), body.tables == null && (body.tables = []), body.sectionBreaks == null && (body.sectionBreaks = []);
235
+ const { tableSource } = doc;
236
+ switch (tagName) {
237
+ case "TABLE": {
238
+ const tableCache = this._tableCache.pop(), { startIndex, table } = tableCache, colCount = table.tableRows[0].tableCells.length, tableColumn = getTableColumn(DEFAULT_TABLE_WIDTH / colCount), tableColumns = [...new Array(colCount).fill(null).map(() => Tools.deepClone(tableColumn))];
239
+ table.tableColumns = tableColumns, tableSource[table.tableId] = table, body.dataStream += DataStreamTreeTokenType.TABLE_END, body.tables.push({
240
+ startIndex,
241
+ endIndex: body.dataStream.length - 1,
242
+ tableId: table.tableId
243
+ });
244
+ break;
245
+ }
246
+ case "TR": {
247
+ body.dataStream += DataStreamTreeTokenType.TABLE_ROW_END;
248
+ break;
249
+ }
250
+ case "TD": {
251
+ (_a23 = body.sectionBreaks) == null || _a23.push({
252
+ startIndex: body.dataStream.length
253
+ }), body.dataStream += `
254
+ ${DataStreamTreeTokenType.TABLE_CELL_END}`;
255
+ break;
256
+ }
257
+ }
258
+ }
198
259
  };
199
260
  __name(_HtmlToUDMService, "HtmlToUDMService"), __publicField(_HtmlToUDMService, "_pluginList", []);
200
261
  let HtmlToUDMService = _HtmlToUDMService;
@@ -224,9 +285,10 @@ const wordPastePlugin$1 = {
224
285
  return el.tagName === "DIV" && /ace-line/i.test(el.className);
225
286
  },
226
287
  handler(doc) {
227
- doc.paragraphs == null && (doc.paragraphs = []), doc.paragraphs.push({
228
- startIndex: doc.dataStream.length
229
- }), doc.dataStream += "\r";
288
+ const body = doc.body;
289
+ body.paragraphs == null && (body.paragraphs = []), body.paragraphs.push({
290
+ startIndex: body.dataStream.length
291
+ }), body.dataStream += "\r";
230
292
  }
231
293
  }
232
294
  ]
@@ -247,8 +309,8 @@ function getParagraphStyle(el) {
247
309
  break;
248
310
  }
249
311
  case "line-height": {
250
- const lineHeightValue = Number.parseFloat(cssValue);
251
- paragraphStyle.lineSpacing = lineHeightValue;
312
+ let lineHeightValue = Number.parseFloat(cssValue);
313
+ cssValue.endsWith("%") && (lineHeightValue /= 100), paragraphStyle.lineSpacing = lineHeightValue;
252
314
  break;
253
315
  }
254
316
  }
@@ -276,11 +338,12 @@ const wordPastePlugin = {
276
338
  return el.tagName === "P";
277
339
  },
278
340
  handler(doc, el) {
279
- doc.paragraphs == null && (doc.paragraphs = []);
341
+ const body = doc.body;
342
+ body.paragraphs == null && (body.paragraphs = []);
280
343
  const paragraph = {
281
- startIndex: doc.dataStream.length
344
+ startIndex: body.dataStream.length
282
345
  }, paragraphStyle = getParagraphStyle(el);
283
- paragraphStyle && (paragraph.paragraphStyle = paragraphStyle), doc.paragraphs.push(paragraph), doc.dataStream += "\r";
346
+ paragraphStyle && (paragraph.paragraphStyle = paragraphStyle), body.paragraphs.push(paragraph), body.dataStream += "\r";
284
347
  }
285
348
  }
286
349
  ]
@@ -296,11 +359,12 @@ const wordPastePlugin = {
296
359
  return el.tagName === "P" && /UniverNormal/i.test(el.className);
297
360
  },
298
361
  handler(doc, el) {
299
- doc.paragraphs == null && (doc.paragraphs = []);
362
+ const body = doc.body;
363
+ body.paragraphs == null && (body.paragraphs = []);
300
364
  const paragraph = {
301
- startIndex: doc.dataStream.length
365
+ startIndex: body.dataStream.length
302
366
  }, paragraphStyle = getParagraphStyle(el);
303
- paragraphStyle && (paragraph.paragraphStyle = paragraphStyle), doc.paragraphs.push(paragraph), doc.dataStream += "\r";
367
+ paragraphStyle && (paragraph.paragraphStyle = paragraphStyle), body.paragraphs.push(paragraph), body.dataStream += "\r";
304
368
  }
305
369
  }
306
370
  ]
@@ -330,42 +394,102 @@ function getBodySliceHtml(body, startIndex, endIndex) {
330
394
  return cursorIndex !== endIndex && spanList.push(dataStream.slice(cursorIndex, endIndex)), spanList.join("");
331
395
  }
332
396
  __name(getBodySliceHtml, "getBodySliceHtml");
333
- function convertBodyToHtml(body, withParagraphInfo = !0) {
334
- var _a19;
335
- if (withParagraphInfo && ((_a19 = body.paragraphs) != null && _a19.length)) {
336
- const { dataStream, paragraphs = [] } = body;
337
- let result = "", cursorIndex = -1;
338
- for (const paragraph of paragraphs) {
339
- const { startIndex, paragraphStyle = {} } = paragraph, { spaceAbove, spaceBelow, lineSpacing } = paragraphStyle, style = [];
340
- spaceAbove != null && (typeof spaceAbove == "number" ? style.push(`margin-top: ${spaceAbove}px`) : style.push(`margin-top: ${spaceAbove.v}px`)), spaceBelow != null && (typeof spaceBelow == "number" ? style.push(`margin-bottom: ${spaceBelow}px`) : style.push(`margin-bottom: ${spaceBelow.v}px`)), lineSpacing != null && style.push(`line-height: ${lineSpacing}`), startIndex > cursorIndex + 1 ? result += `<p class="UniverNormal" ${style.length ? `style="${style.join("; ")};"` : ""}>${getBodySliceHtml(body, cursorIndex + 1, startIndex)}</p>` : result += `<p class="UniverNormal" ${style.length ? `style="${style.join("; ")};"` : ""}></p>`, cursorIndex = startIndex;
341
- }
342
- return cursorIndex !== dataStream.length && (result += getBodySliceHtml(body, cursorIndex, dataStream.length)), result;
343
- } else
344
- return getBodySliceHtml(body, 0, body.dataStream.length);
397
+ function convertBodyToHtml(body) {
398
+ const { paragraphs = [], sectionBreaks = [] } = body;
399
+ let { dataStream } = body;
400
+ dataStream.endsWith(`\r
401
+ `) || (dataStream += `\r
402
+ `, paragraphs.push({
403
+ startIndex: dataStream.length - 2
404
+ }), sectionBreaks.push({
405
+ startIndex: dataStream.length - 1
406
+ }), body.dataStream = dataStream, body.paragraphs = paragraphs, body.sectionBreaks = sectionBreaks);
407
+ const result = { html: "" }, nodeList = parseDataStreamToTree(dataStream);
408
+ for (const node of nodeList)
409
+ processNode(node, body, result);
410
+ return result.html;
345
411
  }
346
412
  __name(convertBodyToHtml, "convertBodyToHtml");
413
+ function processNode(node, body, result) {
414
+ var _a23;
415
+ switch (node.nodeType) {
416
+ case DataStreamTreeNodeType.SECTION_BREAK: {
417
+ for (const n2 of node.children)
418
+ processNode(n2, body, result);
419
+ break;
420
+ }
421
+ case DataStreamTreeNodeType.PARAGRAPH: {
422
+ const { children, startIndex, endIndex } = node, paragraph = (_a23 = body.paragraphs.find((p2) => p2.startIndex === endIndex)) != null ? _a23 : {}, { paragraphStyle = {} } = paragraph, { spaceAbove, spaceBelow, lineSpacing } = paragraphStyle, style = [];
423
+ if (spaceAbove != null && (typeof spaceAbove == "number" ? style.push(`margin-top: ${spaceAbove}px`) : style.push(`margin-top: ${spaceAbove.v}px`)), spaceBelow != null && (typeof spaceBelow == "number" ? style.push(`margin-bottom: ${spaceBelow}px`) : style.push(`margin-bottom: ${spaceBelow.v}px`)), lineSpacing != null && style.push(`line-height: ${lineSpacing}`), result.html += `<p class="UniverNormal" ${style.length ? `style="${style.join("; ")};"` : ""}>`, children.length)
424
+ for (const table of children)
425
+ processNode(table, body, result);
426
+ result.html += `${getBodySliceHtml(body, startIndex, endIndex)}</p>`;
427
+ break;
428
+ }
429
+ case DataStreamTreeNodeType.TABLE: {
430
+ const { children } = node;
431
+ result.html += '<table class="UniverTable" style="width: 100%; border-collapse: collapse;"><tbody>';
432
+ for (const row of children)
433
+ processNode(row, body, result);
434
+ result.html += "</tbody></table>";
435
+ break;
436
+ }
437
+ case DataStreamTreeNodeType.TABLE_ROW: {
438
+ const { children } = node;
439
+ result.html += '<tr class="UniverTableRow">';
440
+ for (const cell of children)
441
+ processNode(cell, body, result);
442
+ result.html += "</tr>";
443
+ break;
444
+ }
445
+ case DataStreamTreeNodeType.TABLE_CELL: {
446
+ const { children } = node;
447
+ result.html += '<td class="UniverTableCell">';
448
+ for (const n2 of children)
449
+ processNode(n2, body, result);
450
+ result.html += "</td>";
451
+ break;
452
+ }
453
+ default:
454
+ throw new Error(`Unknown node type: ${node.nodeType}`);
455
+ }
456
+ }
457
+ __name(processNode, "processNode");
347
458
  const _UDMToHtmlService = class _UDMToHtmlService {
348
459
  convert(bodyList) {
349
460
  if (bodyList.length === 0)
350
461
  throw new Error("The bodyList length at least to be 1");
351
- if (bodyList.length === 1)
352
- return convertBodyToHtml(bodyList[0]);
353
462
  let html = "";
354
- for (const body of bodyList)
355
- html += '<p className="UniverNormal">', html += convertBodyToHtml(body, !1), html += "</p>";
463
+ for (const body of Tools.deepClone(bodyList))
464
+ html += convertBodyToHtml(body);
356
465
  return html;
357
466
  }
358
467
  };
359
468
  __name(_UDMToHtmlService, "UDMToHtmlService");
360
469
  let UDMToHtmlService = _UDMToHtmlService;
361
- var __defProp$h = Object.defineProperty, __getOwnPropDesc$h = Object.getOwnPropertyDescriptor, __decorateClass$h = /* @__PURE__ */ __name((decorators, target, key, kind) => {
362
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$h(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
470
+ var __defProp$l = Object.defineProperty, __getOwnPropDesc$l = Object.getOwnPropertyDescriptor, __decorateClass$l = /* @__PURE__ */ __name((decorators, target, key, kind) => {
471
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$l(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
363
472
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
364
- return kind && result && __defProp$h(target, key, result), result;
365
- }, "__decorateClass$h"), __decorateParam$h = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$h");
473
+ return kind && result && __defProp$l(target, key, result), result;
474
+ }, "__decorateClass$l"), __decorateParam$l = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$l");
366
475
  HtmlToUDMService.use(PastePluginWord);
367
476
  HtmlToUDMService.use(PastePluginLark);
368
477
  HtmlToUDMService.use(PastePluginUniver);
478
+ function getTableSlice(body, start, end) {
479
+ var _a23, _b, _c;
480
+ const bodySlice = getBodySlice(body, start, end + 2), dataStream = DataStreamTreeTokenType.TABLE_START + DataStreamTreeTokenType.TABLE_ROW_START + DataStreamTreeTokenType.TABLE_CELL_START + bodySlice.dataStream + DataStreamTreeTokenType.TABLE_CELL_END + DataStreamTreeTokenType.TABLE_ROW_END + DataStreamTreeTokenType.TABLE_END;
481
+ return bodySlice.dataStream = dataStream, (_a23 = bodySlice.textRuns) == null || _a23.forEach((textRun) => {
482
+ const { st, ed } = textRun;
483
+ textRun.st = st + 3, textRun.ed = ed + 3;
484
+ }), (_b = bodySlice.tables) == null || _b.forEach((table) => {
485
+ const { startIndex, endIndex } = table;
486
+ table.startIndex = startIndex + 3, table.endIndex = endIndex + 3;
487
+ }), (_c = bodySlice.paragraphs) == null || _c.forEach((paragraph) => {
488
+ const { startIndex } = paragraph;
489
+ paragraph.startIndex = startIndex + 3;
490
+ }), bodySlice;
491
+ }
492
+ __name(getTableSlice, "getTableSlice");
369
493
  const IDocClipboardService = createIdentifier("doc.clipboard-service");
370
494
  var _a;
371
495
  let DocClipboardService = (_a = class extends Disposable {
@@ -377,12 +501,12 @@ let DocClipboardService = (_a = class extends Disposable {
377
501
  this._univerInstanceService = _univerInstanceService, this._logService = _logService, this._commandService = _commandService, this._clipboardInterfaceService = _clipboardInterfaceService, this._textSelectionManagerService = _textSelectionManagerService, this._docCustomRangeService = _docCustomRangeService;
378
502
  }
379
503
  async copy(sliceType = SliceBodyType.copy) {
380
- const documentBodyList = this._getDocumentBodyInRanges(sliceType);
381
- if (documentBodyList.length === 0)
504
+ const { bodyList, needCache } = this._getDocumentBodyInRanges(sliceType);
505
+ if (bodyList.length === 0)
382
506
  return !1;
383
507
  try {
384
- const activeRange = this._textSelectionManagerService.getActiveRange(), isCopyInHeaderFooter = !!(activeRange != null && activeRange.segmentId);
385
- this._setClipboardData(documentBodyList, !isCopyInHeaderFooter);
508
+ const activeRange = this._textSelectionManagerService.getActiveTextRangeWithStyle(), isCopyInHeaderFooter = !!(activeRange != null && activeRange.segmentId);
509
+ this._setClipboardData(bodyList, !isCopyInHeaderFooter && needCache);
386
510
  } catch (e) {
387
511
  return this._logService.error("[DocClipboardService] copy failed", e), !1;
388
512
  }
@@ -392,51 +516,57 @@ let DocClipboardService = (_a = class extends Disposable {
392
516
  return this._cut();
393
517
  }
394
518
  async paste(items) {
395
- const body = await this._generateBodyFromClipboardItems(items);
396
- return this._paste(body);
519
+ const partDocData = await this._genDocDataFromClipboardItems(items);
520
+ return this._paste(partDocData);
397
521
  }
398
522
  async legacyPaste(html, text) {
399
- const body = this._generateBodyFromHtmlAndText(html, text);
400
- return this._paste(body);
523
+ const partDocData = this._genDocDataFromHtmlAndText(html, text);
524
+ return this._paste(partDocData);
401
525
  }
402
526
  async _cut() {
403
- var _a19;
527
+ var _a23, _b, _c;
404
528
  const {
405
529
  segmentId,
406
530
  endOffset: activeEndOffset,
407
531
  style
408
- } = (_a19 = this._textSelectionManagerService.getActiveRange()) != null ? _a19 : {}, ranges = this._textSelectionManagerService.getCurrentSelections();
409
- if (segmentId == null && this._logService.error("[DocClipboardController] segmentId is not existed"), activeEndOffset == null || ranges == null)
532
+ } = (_a23 = this._textSelectionManagerService.getActiveTextRangeWithStyle()) != null ? _a23 : {}, textRanges = (_b = this._textSelectionManagerService.getCurrentTextRanges()) != null ? _b : [], rectRanges = (_c = this._textSelectionManagerService.getCurrentRectRanges()) != null ? _c : [];
533
+ if (segmentId == null && this._logService.error("[DocClipboardController] segmentId is not existed"), textRanges.length === 0 && rectRanges.length === 0)
410
534
  return !1;
411
535
  this.copy(SliceBodyType.cut);
412
536
  try {
413
- let cursor = activeEndOffset;
414
- for (const range of ranges) {
415
- const { startOffset, endOffset } = range;
416
- startOffset == null || endOffset == null || endOffset <= activeEndOffset && (cursor -= endOffset - startOffset);
417
- }
418
- const textRanges = [
537
+ let cursor = 0;
538
+ if (rectRanges.length > 0)
539
+ cursor = getCursorWhenDelete(textRanges, rectRanges);
540
+ else if (activeEndOffset != null)
541
+ for (const range of textRanges) {
542
+ const { startOffset, endOffset } = range;
543
+ startOffset == null || endOffset == null || endOffset <= activeEndOffset && (cursor -= endOffset - startOffset);
544
+ }
545
+ const newTextRanges = [
419
546
  {
420
547
  startOffset: cursor,
421
548
  endOffset: cursor,
422
549
  style
423
550
  }
424
551
  ];
425
- return this._commandService.executeCommand(CutContentCommand.id, { segmentId, textRanges });
552
+ return this._commandService.executeCommand(CutContentCommand.id, { segmentId, textRanges: newTextRanges });
426
553
  } catch {
427
554
  return this._logService.error("[DocClipboardController] cut content failed"), !1;
428
555
  }
429
556
  }
430
- async _paste(_body) {
431
- var _a19, _b;
557
+ async _paste(docData) {
558
+ var _a23, _b;
559
+ const { body: _body } = docData;
560
+ if (_body == null)
561
+ return !1;
432
562
  let body = normalizeBody(_body);
433
- const unitId = (_a19 = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_DOC)) == null ? void 0 : _a19.getUnitId();
563
+ const unitId = (_a23 = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_DOC)) == null ? void 0 : _a23.getUnitId();
434
564
  if (!unitId)
435
565
  return !1;
436
566
  this._clipboardHooks.forEach((hook) => {
437
567
  hook.onBeforePaste && (body = hook.onBeforePaste(body));
438
568
  }), body.customRanges = (_b = body.customRanges) == null ? void 0 : _b.map((range) => this._docCustomRangeService.copyCustomRange(unitId, range));
439
- const activeRange = this._textSelectionManagerService.getActiveRange(), { segmentId, endOffset: activeEndOffset, style } = activeRange || {}, ranges = this._textSelectionManagerService.getCurrentSelections();
569
+ const activeRange = this._textSelectionManagerService.getActiveTextRangeWithStyle(), { segmentId, endOffset: activeEndOffset, style } = activeRange || {}, ranges = this._textSelectionManagerService.getCurrentTextRanges();
440
570
  if (segmentId == null && this._logService.error("[DocClipboardController] segmentId does not exist!"), activeEndOffset == null || ranges == null)
441
571
  return !1;
442
572
  try {
@@ -452,7 +582,14 @@ let DocClipboardService = (_a = class extends Disposable {
452
582
  style
453
583
  }
454
584
  ];
455
- return this._commandService.executeCommand(InnerPasteCommand.id, { body, segmentId, textRanges });
585
+ return this._commandService.executeCommand(InnerPasteCommand.id, {
586
+ doc: {
587
+ ...docData,
588
+ body
589
+ },
590
+ segmentId,
591
+ textRanges
592
+ });
456
593
  } catch {
457
594
  return this._logService.error("[DocClipboardController]", "clipboard is empty."), !1;
458
595
  }
@@ -461,7 +598,7 @@ let DocClipboardService = (_a = class extends Disposable {
461
598
  const copyId = genId(), text = documentBodyList.length > 1 ? documentBodyList.map((body) => body.dataStream).join(`
462
599
  `) : documentBodyList[0].dataStream;
463
600
  let html = this._umdToHtml.convert(documentBodyList);
464
- return documentBodyList.length === 1 && needCache && (html = html.replace(/(<[a-z]+)/, (_p0, p1) => `${p1} data-copy-id="${copyId}"`), copyContentCache.set(copyId, documentBodyList[0])), this._clipboardInterfaceService.write(text, html);
601
+ return documentBodyList.length === 1 && needCache && (html = html.replace(/(<[a-z]+)/, (_p0, p1) => `${p1} data-copy-id="${copyId}"`), copyContentCache.set(copyId, { body: documentBodyList[0] })), this._clipboardInterfaceService.write(text, html);
465
602
  }
466
603
  addClipboardHook(hook) {
467
604
  return this._clipboardHooks.push(hook), toDisposable(() => {
@@ -469,15 +606,33 @@ let DocClipboardService = (_a = class extends Disposable {
469
606
  index > -1 && this._clipboardHooks.splice(index, 1);
470
607
  });
471
608
  }
609
+ // eslint-disable-next-line max-lines-per-function
472
610
  _getDocumentBodyInRanges(sliceType) {
473
- const ranges = this._textSelectionManagerService.getCurrentSelections(), activeRange = this._textSelectionManagerService.getActiveRange(), docDataModel = this._univerInstanceService.getCurrentUniverDocInstance(), results = [], body = docDataModel == null ? void 0 : docDataModel.getBody();
474
- if (ranges == null || docDataModel == null || body == null || activeRange == null)
475
- return results;
476
- const { segmentId } = activeRange;
477
- for (const range of ranges) {
478
- const { startOffset, endOffset, collapsed } = range;
611
+ var _a23;
612
+ const docDataModel = this._univerInstanceService.getCurrentUniverDocInstance(), allRanges = this._textSelectionManagerService.getDocRanges(), results = [];
613
+ let needCache = !0;
614
+ if (docDataModel == null || allRanges.length === 0)
615
+ return {
616
+ bodyList: results,
617
+ needCache
618
+ };
619
+ const segmentId = allRanges[0].segmentId, body = (_a23 = docDataModel == null ? void 0 : docDataModel.getSelfOrHeaderFooterModel(segmentId)) == null ? void 0 : _a23.getBody();
620
+ if (body == null)
621
+ return {
622
+ bodyList: results,
623
+ needCache
624
+ };
625
+ for (const range of allRanges) {
626
+ const { startOffset, endOffset, collapsed, rangeType } = range;
479
627
  if (collapsed || startOffset == null || endOffset == null)
480
628
  continue;
629
+ if (rangeType === DOC_RANGE_TYPE.RECT) {
630
+ needCache = !1;
631
+ const { spanEntireRow } = range;
632
+ let bodySlice;
633
+ bodySlice = getTableSlice(body, startOffset, endOffset), results.push(bodySlice);
634
+ continue;
635
+ }
481
636
  const deleteRange = getDeleteSelection({ startOffset, endOffset, collapsed }, body), docBody = docDataModel.getSelfOrHeaderFooterModel(segmentId).sliceBody(deleteRange.startOffset, deleteRange.endOffset, sliceType);
482
637
  if (docBody != null) {
483
638
  if (docBody.customRanges) {
@@ -493,15 +648,18 @@ let DocClipboardService = (_a = class extends Disposable {
493
648
  results.push(docBody);
494
649
  }
495
650
  }
496
- return results;
651
+ return {
652
+ bodyList: results,
653
+ needCache
654
+ };
497
655
  }
498
- async _generateBodyFromClipboardItems(items) {
656
+ async _genDocDataFromClipboardItems(items) {
499
657
  try {
500
658
  let html = "", text = "";
501
659
  for (const clipboardItem of items)
502
660
  for (const type of clipboardItem.types)
503
661
  type === PLAIN_TEXT_CLIPBOARD_MIME_TYPE ? text = await clipboardItem.getType(type).then((blob) => blob && blob.text()) : type === HTML_CLIPBOARD_MIME_TYPE && (html = await clipboardItem.getType(type).then((blob) => blob && blob.text()));
504
- return this._generateBodyFromHtmlAndText(html, text);
662
+ return this._genDocDataFromHtmlAndText(html, text);
505
663
  } catch (e) {
506
664
  return Promise.reject(e);
507
665
  }
@@ -532,10 +690,10 @@ let DocClipboardService = (_a = class extends Disposable {
532
690
  paragraphs
533
691
  };
534
692
  }
535
- _generateBodyFromHtmlAndText(html, text) {
693
+ _genDocDataFromHtmlAndText(html, text) {
536
694
  if (!html) {
537
695
  if (text)
538
- return this._generateBody(text);
696
+ return { body: this._generateBody(text) };
539
697
  throw new Error("[DocClipboardService] html and text cannot be both empty!");
540
698
  }
541
699
  const copyId = extractId(html);
@@ -547,19 +705,19 @@ let DocClipboardService = (_a = class extends Disposable {
547
705
  return this._htmlToUDM.convert(html);
548
706
  }
549
707
  }, __name(_a, "DocClipboardService"), _a);
550
- DocClipboardService = __decorateClass$h([
551
- __decorateParam$h(0, IUniverInstanceService),
552
- __decorateParam$h(1, ILogService),
553
- __decorateParam$h(2, ICommandService),
554
- __decorateParam$h(3, IClipboardInterfaceService),
555
- __decorateParam$h(4, Inject(TextSelectionManagerService)),
556
- __decorateParam$h(5, Inject(DocCustomRangeService))
708
+ DocClipboardService = __decorateClass$l([
709
+ __decorateParam$l(0, IUniverInstanceService),
710
+ __decorateParam$l(1, ILogService),
711
+ __decorateParam$l(2, ICommandService),
712
+ __decorateParam$l(3, IClipboardInterfaceService),
713
+ __decorateParam$l(4, Inject(TextSelectionManagerService)),
714
+ __decorateParam$l(5, Inject(DocCustomRangeService))
557
715
  ], DocClipboardService);
558
- var __defProp$g = Object.defineProperty, __getOwnPropDesc$g = Object.getOwnPropertyDescriptor, __decorateClass$g = /* @__PURE__ */ __name((decorators, target, key, kind) => {
559
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$g(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
716
+ var __defProp$k = Object.defineProperty, __getOwnPropDesc$k = Object.getOwnPropertyDescriptor, __decorateClass$k = /* @__PURE__ */ __name((decorators, target, key, kind) => {
717
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$k(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
560
718
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
561
- return kind && result && __defProp$g(target, key, result), result;
562
- }, "__decorateClass$g"), __decorateParam$g = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$g");
719
+ return kind && result && __defProp$k(target, key, result), result;
720
+ }, "__decorateClass$k"), __decorateParam$k = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$k");
563
721
  const ANCHOR_WIDTH = 1.5;
564
722
  var _a2;
565
723
  let DocBackScrollRenderController = (_a2 = class extends RxDisposable {
@@ -575,16 +733,16 @@ let DocBackScrollRenderController = (_a2 = class extends RxDisposable {
575
733
  });
576
734
  }
577
735
  scrollToRange(unitId, range) {
578
- var _a19;
579
- const docSkeletonManagerService = (_a19 = this._renderManagerService.getRenderById(unitId)) == null ? void 0 : _a19.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton();
736
+ var _a23;
737
+ const docSkeletonManagerService = (_a23 = this._renderManagerService.getRenderById(unitId)) == null ? void 0 : _a23.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton();
580
738
  if (!skeleton)
581
739
  return;
582
740
  const { startOffset } = range, anchorNodePosition = skeleton.findNodePositionByCharIndex(startOffset);
583
741
  this.scrollToNode(unitId, anchorNodePosition);
584
742
  }
585
743
  scrollToNode(unitId, startNodePosition) {
586
- var _a19;
587
- const docObject = this._getDocObject(), docSkeletonManagerService = (_a19 = this._renderManagerService.getRenderById(unitId)) == null ? void 0 : _a19.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton();
744
+ var _a23;
745
+ const docObject = this._getDocObject(), docSkeletonManagerService = (_a23 = this._renderManagerService.getRenderById(unitId)) == null ? void 0 : _a23.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton();
588
746
  if (docObject == null || skeleton == null)
589
747
  return;
590
748
  const documentOffsetConfig = docObject.document.getOffsetConfig(), { docsLeft, docsTop } = documentOffsetConfig, convertor = new NodePositionConvertToCursor(documentOffsetConfig, skeleton), { contentBoxPointGroup } = convertor.getRangePointData(startNodePosition, startNodePosition), { left: aLeft, top: aTop, height } = getAnchorBounding(contentBoxPointGroup), left = aLeft + docsLeft, top = aTop + docsTop, viewportMain = docObject.scene.getViewport(VIEWPORT_KEY.VIEW_MAIN), isEditor = !!this._editorService.getEditor(unitId);
@@ -604,7 +762,7 @@ let DocBackScrollRenderController = (_a2 = class extends RxDisposable {
604
762
  }
605
763
  // Let the selection show on the current screen.
606
764
  _scrollToSelection(unitId) {
607
- const activeTextRange = this._textSelectionManagerService.getActiveRange();
765
+ const activeTextRange = this._textSelectionManagerService.getActiveTextRangeWithStyle();
608
766
  if (activeTextRange == null)
609
767
  return;
610
768
  const { collapsed, startNodePosition } = activeTextRange;
@@ -614,11 +772,11 @@ let DocBackScrollRenderController = (_a2 = class extends RxDisposable {
614
772
  return getDocObject(this._univerInstanceService, this._renderManagerService);
615
773
  }
616
774
  }, __name(_a2, "DocBackScrollRenderController"), _a2);
617
- DocBackScrollRenderController = __decorateClass$g([
618
- __decorateParam$g(1, Inject(TextSelectionManagerService)),
619
- __decorateParam$g(2, IEditorService),
620
- __decorateParam$g(3, Inject(IUniverInstanceService)),
621
- __decorateParam$g(4, IRenderManagerService)
775
+ DocBackScrollRenderController = __decorateClass$k([
776
+ __decorateParam$k(1, Inject(TextSelectionManagerService)),
777
+ __decorateParam$k(2, IEditorService),
778
+ __decorateParam$k(3, Inject(IUniverInstanceService)),
779
+ __decorateParam$k(4, IRenderManagerService)
622
780
  ], DocBackScrollRenderController);
623
781
  const DefaultToolbarConfig = {
624
782
  undo: !0,
@@ -727,11 +885,11 @@ const DefaultToolbarConfig = {
727
885
  binding: KeyCode.A | MetaKeys.CTRL_COMMAND,
728
886
  preconditions: /* @__PURE__ */ __name((contextService) => contextService.getContextValue(FOCUSING_UNIVER_EDITOR) && (contextService.getContextValue(FOCUSING_DOC) || contextService.getContextValue(EDITOR_ACTIVATED)), "preconditions")
729
887
  };
730
- var __defProp$f = Object.defineProperty, __getOwnPropDesc$f = Object.getOwnPropertyDescriptor, __decorateClass$f = /* @__PURE__ */ __name((decorators, target, key, kind) => {
731
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$f(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
888
+ var __defProp$j = Object.defineProperty, __getOwnPropDesc$j = Object.getOwnPropertyDescriptor, __decorateClass$j = /* @__PURE__ */ __name((decorators, target, key, kind) => {
889
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$j(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
732
890
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
733
- return kind && result && __defProp$f(target, key, result), result;
734
- }, "__decorateClass$f"), __decorateParam$f = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$f"), _a3;
891
+ return kind && result && __defProp$j(target, key, result), result;
892
+ }, "__decorateClass$j"), __decorateParam$j = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$j"), _a3;
735
893
  let DocContainerUIController = (_a3 = class {
736
894
  constructor(_config, _localeService, _injector) {
737
895
  __publicField(this, "_docContainer");
@@ -771,15 +929,15 @@ let DocContainerUIController = (_a3 = class {
771
929
  return this._docContainer;
772
930
  }
773
931
  }, __name(_a3, "DocContainerUIController"), _a3);
774
- DocContainerUIController = __decorateClass$f([
775
- __decorateParam$f(1, Inject(LocaleService)),
776
- __decorateParam$f(2, Inject(Injector))
932
+ DocContainerUIController = __decorateClass$j([
933
+ __decorateParam$j(1, Inject(LocaleService)),
934
+ __decorateParam$j(2, Inject(Injector))
777
935
  ], DocContainerUIController);
778
- var __defProp$e = Object.defineProperty, __getOwnPropDesc$e = Object.getOwnPropertyDescriptor, __decorateClass$e = /* @__PURE__ */ __name((decorators, target, key, kind) => {
779
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$e(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
936
+ var __defProp$i = Object.defineProperty, __getOwnPropDesc$i = Object.getOwnPropertyDescriptor, __decorateClass$i = /* @__PURE__ */ __name((decorators, target, key, kind) => {
937
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$i(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
780
938
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
781
- return kind && result && __defProp$e(target, key, result), result;
782
- }, "__decorateClass$e"), __decorateParam$e = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$e"), _a4;
939
+ return kind && result && __defProp$i(target, key, result), result;
940
+ }, "__decorateClass$i"), __decorateParam$i = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$i"), _a4;
783
941
  let AppUIController = (_a4 = class extends RxDisposable {
784
942
  constructor(_config, _localeService, _injector, _textSelectionRenderManager, _layoutService) {
785
943
  super();
@@ -806,83 +964,100 @@ let AppUIController = (_a4 = class extends RxDisposable {
806
964
  return this._docContainerController;
807
965
  }
808
966
  }, __name(_a4, "AppUIController"), _a4);
809
- AppUIController = __decorateClass$e([
810
- __decorateParam$e(1, Inject(LocaleService)),
811
- __decorateParam$e(2, Inject(Injector)),
812
- __decorateParam$e(3, ITextSelectionRenderManager),
813
- __decorateParam$e(4, Optional(ILayoutService))
967
+ AppUIController = __decorateClass$i([
968
+ __decorateParam$i(1, Inject(LocaleService)),
969
+ __decorateParam$i(2, Inject(Injector)),
970
+ __decorateParam$i(3, ITextSelectionRenderManager),
971
+ __decorateParam$i(4, Optional(ILayoutService))
814
972
  ], AppUIController);
815
- const COMPONENT_PREFIX = "UI_PLUGIN_DOCS", COLOR_PICKER_COMPONENT = `${COMPONENT_PREFIX}_COLOR_PICKER_COMPONENT`, FONT_FAMILY_COMPONENT = `${COMPONENT_PREFIX}_FONT_FAMILY_COMPONENT`, FONT_FAMILY_ITEM_COMPONENT = `${COMPONENT_PREFIX}_FONT_FAMILY_ITEM_COMPONENT`, FONT_SIZE_COMPONENT = `${COMPONENT_PREFIX}_FONT_SIZE_COMPONENT`;
816
- var jsxRuntime = { exports: {} }, reactJsxRuntime_production_min = {};
817
- /**
818
- * @license React
819
- * react-jsx-runtime.production.min.js
820
- *
821
- * Copyright (c) Facebook, Inc. and its affiliates.
822
- *
823
- * This source code is licensed under the MIT license found in the
824
- * LICENSE file in the root directory of this source tree.
825
- */
826
- var f = require$$0, k = Symbol.for("react.element"), l = Symbol.for("react.fragment"), m = Object.prototype.hasOwnProperty, n = f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, p = { key: !0, ref: !0, __self: !0, __source: !0 };
827
- function q(c, a, g) {
828
- var b, d = {}, e = null, h = null;
829
- g !== void 0 && (e = "" + g), a.key !== void 0 && (e = "" + a.key), a.ref !== void 0 && (h = a.ref);
830
- for (b in a) m.call(a, b) && !p.hasOwnProperty(b) && (d[b] = a[b]);
831
- if (c && c.defaultProps) for (b in a = c.defaultProps, a) d[b] === void 0 && (d[b] = a[b]);
832
- return { $$typeof: k, type: c, key: e, ref: h, props: d, _owner: n.current };
833
- }
834
- __name(q, "q");
835
- reactJsxRuntime_production_min.Fragment = l;
836
- reactJsxRuntime_production_min.jsx = q;
837
- reactJsxRuntime_production_min.jsxs = q;
838
- jsxRuntime.exports = reactJsxRuntime_production_min;
839
- var jsxRuntimeExports = jsxRuntime.exports;
840
- const docCountBar = "univer-doc-count-bar", styles$2 = {
841
- docCountBar
842
- }, ZOOM_MAP = [50, 80, 100, 130, 150, 170, 200, 400], DOC_ZOOM_RANGE = [10, 400];
843
- function ZoomSlider() {
844
- const commandService = useDependency(ICommandService), univerInstanceService = useDependency(IUniverInstanceService), currentDoc$ = useMemo(() => univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_DOC), []), documentDataModel = useObservable(currentDoc$), getCurrentZoom = useCallback(() => {
845
- var _a19, _b;
846
- if (!documentDataModel) return 100;
847
- const currentZoom = ((_b = (_a19 = documentDataModel.getSettings()) == null ? void 0 : _a19.zoomRatio) != null ? _b : 1) * 100;
848
- return Math.round(currentZoom);
849
- }, [documentDataModel]), [zoom, setZoom] = useState(() => getCurrentZoom());
850
- useEffect(() => (setZoom(getCurrentZoom()), commandService.onCommandExecuted((commandInfo) => {
851
- if (commandInfo.id === SetDocZoomRatioOperation.id) {
852
- const currentZoom = getCurrentZoom();
853
- setZoom(currentZoom);
854
- }
855
- }).dispose), [commandService, getCurrentZoom]);
856
- function handleChange(value) {
857
- if (setZoom(value), documentDataModel == null)
858
- return;
859
- const zoomRatio = value / 100;
860
- commandService.executeCommand(SetDocZoomRatioOperation.id, {
861
- unitId: documentDataModel.getUnitId(),
862
- zoomRatio
863
- });
864
- }
865
- return __name(handleChange, "handleChange"), /* @__PURE__ */ jsxRuntimeExports.jsx(
866
- Slider,
867
- {
868
- min: DOC_ZOOM_RANGE[0],
869
- value: zoom,
870
- shortcuts: ZOOM_MAP,
871
- onChange: handleChange
973
+ var __assign = function() {
974
+ return __assign = Object.assign || function(t) {
975
+ for (var s, i = 1, n2 = arguments.length; i < n2; i++) {
976
+ s = arguments[i];
977
+ for (var p2 in s) Object.prototype.hasOwnProperty.call(s, p2) && (t[p2] = s[p2]);
872
978
  }
873
- );
979
+ return t;
980
+ }, __assign.apply(this, arguments);
981
+ }, __rest = function(s, e) {
982
+ var t = {};
983
+ for (var p2 in s) Object.prototype.hasOwnProperty.call(s, p2) && e.indexOf(p2) < 0 && (t[p2] = s[p2]);
984
+ if (s != null && typeof Object.getOwnPropertySymbols == "function")
985
+ for (var i = 0, p2 = Object.getOwnPropertySymbols(s); i < p2.length; i++)
986
+ e.indexOf(p2[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p2[i]) && (t[p2[i]] = s[p2[i]]);
987
+ return t;
988
+ }, IconBase = forwardRef(function(props, ref) {
989
+ var icon = props.icon, id = props.id, className = props.className, extend = props.extend, restProps = __rest(props, ["icon", "id", "className", "extend"]), cls = "univerjs-icon univerjs-icon-".concat(id, " ").concat(className || "").trim(), idSuffix = useRef("_".concat(generateShortUuid()));
990
+ return render(icon, "".concat(id), { defIds: icon.defIds, idSuffix: idSuffix.current }, __assign({ ref, className: cls }, restProps), extend);
991
+ });
992
+ function render(node, id, runtimeProps, rootProps, extend) {
993
+ return createElement(node.tag, __assign(__assign({ key: id }, replaceRuntimeIdsAndExtInAttrs(node, runtimeProps, extend)), rootProps), (replaceRuntimeIdsInDefs(node, runtimeProps).children || []).map(function(child, index) {
994
+ return render(child, "".concat(id, "-").concat(node.tag, "-").concat(index), runtimeProps, void 0, extend);
995
+ }));
874
996
  }
875
- __name(ZoomSlider, "ZoomSlider");
876
- function CountBar(props) {
877
- return /* @__PURE__ */ jsxRuntimeExports.jsx("section", { className: styles$2.docCountBar, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ZoomSlider, {}) });
997
+ __name(render, "render");
998
+ function replaceRuntimeIdsAndExtInAttrs(node, runtimeProps, extend) {
999
+ var attrs = __assign({}, node.attrs);
1000
+ extend != null && extend.colorChannel1 && attrs.fill === "colorChannel1" && (attrs.fill = extend.colorChannel1);
1001
+ var defIds = runtimeProps.defIds;
1002
+ return !defIds || defIds.length === 0 || (node.tag === "use" && attrs["xlink:href"] && (attrs["xlink:href"] = attrs["xlink:href"] + runtimeProps.idSuffix), Object.entries(attrs).forEach(function(_a23) {
1003
+ var key = _a23[0], value = _a23[1];
1004
+ typeof value == "string" && (attrs[key] = value.replace(/url\(#(.*)\)/, "url(#$1".concat(runtimeProps.idSuffix, ")")));
1005
+ })), attrs;
878
1006
  }
879
- __name(CountBar, "CountBar");
880
- const docFooterContainer = "univer-doc-footer-container", styles$1 = {
881
- docFooterContainer
882
- }, DocFooter = /* @__PURE__ */ __name(() => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.docFooterContainer, children: [
883
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", {}),
884
- /* @__PURE__ */ jsxRuntimeExports.jsx(CountBar, {})
885
- ] }), "DocFooter"), COLLAB_CURSOR_LABEL_HEIGHT = 18, COLLAB_CURSOR_LABEL_MAX_WIDTH = 200, COLLAB_CURSOR_LABEL_TEXT_PADDING_LR = 6, COLLAB_CURSOR_LABEL_TEXT_PADDING_TB = 4;
1007
+ __name(replaceRuntimeIdsAndExtInAttrs, "replaceRuntimeIdsAndExtInAttrs");
1008
+ function replaceRuntimeIdsInDefs(node, runtimeProps) {
1009
+ var _a23, defIds = runtimeProps.defIds;
1010
+ return !defIds || defIds.length === 0 ? node : node.tag === "defs" && (!((_a23 = node.children) === null || _a23 === void 0) && _a23.length) ? __assign(__assign({}, node), { children: node.children.map(function(child) {
1011
+ return typeof child.attrs.id == "string" && defIds && defIds.indexOf(child.attrs.id) > -1 ? __assign(__assign({}, child), { attrs: __assign(__assign({}, child.attrs), { id: child.attrs.id + runtimeProps.idSuffix }) }) : child;
1012
+ }) }) : node;
1013
+ }
1014
+ __name(replaceRuntimeIdsInDefs, "replaceRuntimeIdsInDefs");
1015
+ function generateShortUuid() {
1016
+ return Math.random().toString(36).substring(2, 8);
1017
+ }
1018
+ __name(generateShortUuid, "generateShortUuid");
1019
+ IconBase.displayName = "UniverIcon";
1020
+ var element$4 = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM1.9999 5.56641C1.66853 5.56641 1.3999 5.83504 1.3999 6.16641 1.3999 6.49778 1.66853 6.76641 1.9999 6.76641H13.9999C14.3313 6.76641 14.5999 6.49778 14.5999 6.16641 14.5999 5.83504 14.3313 5.56641 13.9999 5.56641H1.9999zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM1.9999 12.9004C1.66853 12.9004 1.3999 13.169 1.3999 13.5004 1.3999 13.8318 1.66853 14.1004 1.9999 14.1004H13.9999C14.3313 14.1004 14.5999 13.8318 14.5999 13.5004 14.5999 13.169 14.3313 12.9004 13.9999 12.9004H1.9999z" } }] }, AlignTextBothSingle = forwardRef(function(props, ref) {
1021
+ return createElement(IconBase, Object.assign({}, props, {
1022
+ id: "align-text-both-single",
1023
+ ref,
1024
+ icon: element$4
1025
+ }));
1026
+ });
1027
+ AlignTextBothSingle.displayName = "AlignTextBothSingle";
1028
+ var element$3 = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM3.33315 5.56641C3.00178 5.56641 2.73315 5.83504 2.73315 6.16641 2.73315 6.49778 3.00178 6.76641 3.33315 6.76641H12.6665C12.9979 6.76641 13.2665 6.49778 13.2665 6.16641 13.2665 5.83504 12.9979 5.56641 12.6665 5.56641H3.33315zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM3.33315 12.9004C3.00178 12.9004 2.73315 13.169 2.73315 13.5004 2.73315 13.8318 3.00178 14.1004 3.33315 14.1004H12.6665C12.9979 14.1004 13.2665 13.8318 13.2665 13.5004 13.2665 13.169 12.9979 12.9004 12.6665 12.9004H3.33315z" } }] }, HorizontallySingle = forwardRef(function(props, ref) {
1029
+ return createElement(IconBase, Object.assign({}, props, {
1030
+ id: "horizontally-single",
1031
+ ref,
1032
+ icon: element$3
1033
+ }));
1034
+ });
1035
+ HorizontallySingle.displayName = "HorizontallySingle";
1036
+ var element$2 = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM1.9999 5.56641C1.66853 5.56641 1.3999 5.83504 1.3999 6.16641 1.3999 6.49778 1.66853 6.76641 1.9999 6.76641H11.3332C11.6646 6.76641 11.9332 6.49778 11.9332 6.16641 11.9332 5.83504 11.6646 5.56641 11.3332 5.56641H1.9999zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM1.9999 12.9004C1.66853 12.9004 1.3999 13.169 1.3999 13.5004 1.3999 13.8318 1.66853 14.1004 1.9999 14.1004H11.3332C11.6646 14.1004 11.9332 13.8318 11.9332 13.5004 11.9332 13.169 11.6646 12.9004 11.3332 12.9004H1.9999z" } }] }, LeftJustifyingSingle = forwardRef(function(props, ref) {
1037
+ return createElement(IconBase, Object.assign({}, props, {
1038
+ id: "left-justifying-single",
1039
+ ref,
1040
+ icon: element$2
1041
+ }));
1042
+ });
1043
+ LeftJustifyingSingle.displayName = "LeftJustifyingSingle";
1044
+ var element$1 = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M1.9999 1.89941C1.66853 1.89941 1.3999 2.16804 1.3999 2.49941 1.3999 2.83078 1.66853 3.09941 1.9999 3.09941H13.9999C14.3313 3.09941 14.5999 2.83078 14.5999 2.49941 14.5999 2.16804 14.3313 1.89941 13.9999 1.89941H1.9999zM4.66665 5.56641C4.33528 5.56641 4.06665 5.83504 4.06665 6.16641 4.06665 6.49778 4.33528 6.76641 4.66665 6.76641H14C14.3314 6.76641 14.6 6.49778 14.6 6.16641 14.6 5.83504 14.3314 5.56641 14 5.56641H4.66665zM1.3999 9.8334C1.3999 9.50203 1.66853 9.2334 1.9999 9.2334H13.9999C14.3313 9.2334 14.5999 9.50203 14.5999 9.8334 14.5999 10.1648 14.3313 10.4334 13.9999 10.4334H1.9999C1.66853 10.4334 1.3999 10.1648 1.3999 9.8334zM4.66665 12.9004C4.33528 12.9004 4.06665 13.169 4.06665 13.5004 4.06665 13.8318 4.33528 14.1004 4.66665 14.1004H14C14.3314 14.1004 14.6 13.8318 14.6 13.5004 14.6 13.169 14.3314 12.9004 14 12.9004H4.66665z" } }] }, RightJustifyingSingle = forwardRef(function(props, ref) {
1045
+ return createElement(IconBase, Object.assign({}, props, {
1046
+ id: "right-justifying-single",
1047
+ ref,
1048
+ icon: element$1
1049
+ }));
1050
+ });
1051
+ RightJustifyingSingle.displayName = "RightJustifyingSingle";
1052
+ var element = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M4.96372 2.59116C5.19803 2.35684 5.19803 1.97695 4.96372 1.74263 4.7294 1.50832 4.3495 1.50832 4.11519 1.74263L2.53945 3.31837 1.96372 2.74263C1.7294 2.50832 1.3495 2.50832 1.11519 2.74263.880874 2.97695.880874 3.35684 1.11519 3.59116L2.11519 4.59116C2.3495 4.82547 2.7294 4.82547 2.96372 4.59116L4.96372 2.59116zM14.4605 2.56689H6.8981C6.56672 2.56689 6.2981 2.83552 6.2981 3.16689 6.2981 3.49827 6.56672 3.76689 6.8981 3.76689H14.4605C14.7918 3.76689 15.0605 3.49827 15.0605 3.16689 15.0605 2.83552 14.7918 2.56689 14.4605 2.56689zM6.8981 7.2334C6.56672 7.2334 6.2981 7.50203 6.2981 7.8334 6.2981 8.16477 6.56672 8.4334 6.8981 8.4334H14.4605C14.7918 8.4334 15.0605 8.16477 15.0605 7.8334 15.0605 7.50203 14.7918 7.2334 14.4605 7.2334H6.8981zM6.2981 12.4999C6.2981 12.1685 6.56672 11.8999 6.8981 11.8999H14.4605C14.7918 11.8999 15.0605 12.1685 15.0605 12.4999 15.0605 12.8313 14.7918 13.0999 14.4605 13.0999H6.8981C6.56672 13.0999 6.2981 12.8313 6.2981 12.4999z" } }, { tag: "path", attrs: { fill: "currentColor", d: "M2.87279 5.8999C1.80504 5.8999.939453 6.76549.939453 7.83324.939453 8.90099 1.80504 9.76657 2.87279 9.76657 3.94054 9.76657 4.80612 8.90099 4.80612 7.83324 4.80612 6.76549 3.94054 5.8999 2.87279 5.8999zM2.13945 7.83324C2.13945 7.42823 2.46778 7.0999 2.87279 7.0999 3.2778 7.0999 3.60612 7.42823 3.60612 7.83324 3.60612 8.23824 3.2778 8.56657 2.87279 8.56657 2.46778 8.56657 2.13945 8.23824 2.13945 7.83324zM.939453 12.5002C.939453 11.4325 1.80504 10.5669 2.87279 10.5669 3.94054 10.5669 4.80612 11.4325 4.80612 12.5002 4.80612 13.568 3.94054 14.4336 2.87279 14.4336 1.80504 14.4336.939453 13.568.939453 12.5002zM2.87279 11.7669C2.46778 11.7669 2.13945 12.0952 2.13945 12.5002 2.13945 12.9052 2.46778 13.2336 2.87279 13.2336 3.2778 13.2336 3.60612 12.9052 3.60612 12.5002 3.60612 12.0952 3.2778 11.7669 2.87279 11.7669z", fillRule: "evenodd", clipRule: "evenodd" } }] }, TodoList = forwardRef(function(props, ref) {
1053
+ return createElement(IconBase, Object.assign({}, props, {
1054
+ id: "todo-list",
1055
+ ref,
1056
+ icon: element
1057
+ }));
1058
+ });
1059
+ TodoList.displayName = "TodoList";
1060
+ const COMPONENT_PREFIX = "UI_PLUGIN_DOCS", COLOR_PICKER_COMPONENT = `${COMPONENT_PREFIX}_COLOR_PICKER_COMPONENT`, FONT_FAMILY_COMPONENT = `${COMPONENT_PREFIX}_FONT_FAMILY_COMPONENT`, FONT_FAMILY_ITEM_COMPONENT = `${COMPONENT_PREFIX}_FONT_FAMILY_ITEM_COMPONENT`, FONT_SIZE_COMPONENT = `${COMPONENT_PREFIX}_FONT_SIZE_COMPONENT`, COLLAB_CURSOR_LABEL_HEIGHT = 18, COLLAB_CURSOR_LABEL_MAX_WIDTH = 200, COLLAB_CURSOR_LABEL_TEXT_PADDING_LR = 6, COLLAB_CURSOR_LABEL_TEXT_PADDING_TB = 4;
886
1061
  function drawBubble(ctx, props) {
887
1062
  let { radius, width, height } = props;
888
1063
  radius = radius != null ? radius : 0, width = width != null ? width : 30, height = height != null ? height : 30;
@@ -914,10 +1089,10 @@ const _TextBubbleShape = class _TextBubbleShape extends Shape {
914
1089
  const offsetX = COLLAB_CURSOR_LABEL_TEXT_PADDING_LR, offsetY = COLLAB_CURSOR_LABEL_HEIGHT - COLLAB_CURSOR_LABEL_TEXT_PADDING_TB, maxTextWidth = COLLAB_CURSOR_LABEL_MAX_WIDTH - 2 * COLLAB_CURSOR_LABEL_TEXT_PADDING_LR;
915
1090
  if (textWidth > maxTextWidth) {
916
1091
  let truncatedText = "", currentWidth = 0;
917
- for (const element of text) {
918
- const charWidth = ctx.measureText(element).width;
1092
+ for (const element2 of text) {
1093
+ const charWidth = ctx.measureText(element2).width;
919
1094
  if (currentWidth + charWidth <= maxTextWidth - ctx.measureText("...").width)
920
- truncatedText += element, currentWidth += charWidth;
1095
+ truncatedText += element2, currentWidth += charWidth;
921
1096
  else {
922
1097
  truncatedText += "...";
923
1098
  break;
@@ -934,7 +1109,32 @@ const _TextBubbleShape = class _TextBubbleShape extends Shape {
934
1109
  };
935
1110
  __name(_TextBubbleShape, "TextBubbleShape");
936
1111
  let TextBubbleShape = _TextBubbleShape;
937
- const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", panel = "univer-panel", optionsSection = "univer-options-section", optionsFormItem = "univer-options-form-item", optionsInput = "univer-options-input", optionsMarginSetting = "univer-options-margin-setting", styles = {
1112
+ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL";
1113
+ var jsxRuntime = { exports: {} }, reactJsxRuntime_production_min = {};
1114
+ /**
1115
+ * @license React
1116
+ * react-jsx-runtime.production.min.js
1117
+ *
1118
+ * Copyright (c) Facebook, Inc. and its affiliates.
1119
+ *
1120
+ * This source code is licensed under the MIT license found in the
1121
+ * LICENSE file in the root directory of this source tree.
1122
+ */
1123
+ var f = require$$0__default, k = Symbol.for("react.element"), l = Symbol.for("react.fragment"), m = Object.prototype.hasOwnProperty, n = f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, p = { key: !0, ref: !0, __self: !0, __source: !0 };
1124
+ function q(c, a, g) {
1125
+ var b, d = {}, e = null, h = null;
1126
+ g !== void 0 && (e = "" + g), a.key !== void 0 && (e = "" + a.key), a.ref !== void 0 && (h = a.ref);
1127
+ for (b in a) m.call(a, b) && !p.hasOwnProperty(b) && (d[b] = a[b]);
1128
+ if (c && c.defaultProps) for (b in a = c.defaultProps, a) d[b] === void 0 && (d[b] = a[b]);
1129
+ return { $$typeof: k, type: c, key: e, ref: h, props: d, _owner: n.current };
1130
+ }
1131
+ __name(q, "q");
1132
+ reactJsxRuntime_production_min.Fragment = l;
1133
+ reactJsxRuntime_production_min.jsx = q;
1134
+ reactJsxRuntime_production_min.jsxs = q;
1135
+ jsxRuntime.exports = reactJsxRuntime_production_min;
1136
+ var jsxRuntimeExports = jsxRuntime.exports;
1137
+ const panel = "univer-panel", optionsSection = "univer-options-section", optionsFormItem = "univer-options-form-item", optionsInput = "univer-options-input", optionsMarginSetting = "univer-options-margin-setting", styles$5 = {
938
1138
  panel,
939
1139
  optionsSection,
940
1140
  optionsFormItem,
@@ -942,12 +1142,12 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
942
1142
  optionsMarginSetting
943
1143
  }, DocHeaderFooterOptions = /* @__PURE__ */ __name((props) => {
944
1144
  const localeService = useDependency(LocaleService), univerInstanceService = useDependency(IUniverInstanceService), renderManagerService = useDependency(IRenderManagerService), commandService = useDependency(ICommandService), textSelectionRenderService = useDependency(ITextSelectionRenderManager), textSelectionManagerService = useDependency(TextSelectionManagerService), { unitId } = props, [options, setOptions] = useState({}), handleCheckboxChange = /* @__PURE__ */ __name((val, type) => {
945
- var _a19;
1145
+ var _a23;
946
1146
  setOptions((prev) => ({
947
1147
  ...prev,
948
1148
  [type]: val ? BooleanNumber.TRUE : BooleanNumber.FALSE
949
1149
  }));
950
- const docDataModel = univerInstanceService.getUniverDocInstance(unitId), documentStyle = docDataModel == null ? void 0 : docDataModel.getSnapshot().documentStyle, docSkeletonManagerService = (_a19 = renderManagerService.getRenderById(unitId)) == null ? void 0 : _a19.with(DocSkeletonManagerService), viewModel = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getViewModel();
1150
+ const docDataModel = univerInstanceService.getUniverDocInstance(unitId), documentStyle = docDataModel == null ? void 0 : docDataModel.getSnapshot().documentStyle, docSkeletonManagerService = (_a23 = renderManagerService.getRenderById(unitId)) == null ? void 0 : _a23.with(DocSkeletonManagerService), viewModel = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getViewModel();
951
1151
  if (documentStyle == null || viewModel == null)
952
1152
  return;
953
1153
  const editArea = viewModel.getEditArea();
@@ -979,19 +1179,24 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
979
1179
  headerFooterProps: {
980
1180
  [type]: val
981
1181
  }
982
- }), textSelectionRenderService.removeAllTextRanges(), textSelectionRenderService.blur();
1182
+ }), textSelectionRenderService.removeAllRanges(), textSelectionRenderService.blur();
983
1183
  }, "handleMarginChange"), closeHeaderFooter = /* @__PURE__ */ __name(() => {
984
- var _a19;
1184
+ var _a23;
985
1185
  const renderObject = renderManagerService.getRenderById(unitId);
986
1186
  if (renderObject == null)
987
1187
  return;
988
- const { scene } = renderObject, transformer = scene.getTransformerByCreate(), docSkeletonManagerService = renderObject.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton(), viewModel = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getViewModel(), render = renderManagerService.getRenderById(unitId);
989
- render == null || viewModel == null || skeleton == null || (textSelectionManagerService.replaceTextRanges([]), transformer.clearSelectedObjects(), textSelectionRenderService.setSegment(""), textSelectionRenderService.setSegmentPage(-1), viewModel.setEditArea(DocumentEditArea.BODY), skeleton.calculate(), (_a19 = render.mainComponent) == null || _a19.makeDirty(!0));
1188
+ const { scene } = renderObject, transformer = scene.getTransformerByCreate(), docSkeletonManagerService = renderObject.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton(), viewModel = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getViewModel(), render2 = renderManagerService.getRenderById(unitId);
1189
+ render2 == null || viewModel == null || skeleton == null || (textSelectionManagerService.replaceTextRanges([]), transformer.clearSelectedObjects(), textSelectionRenderService.setSegment(""), textSelectionRenderService.setSegmentPage(-1), viewModel.setEditArea(DocumentEditArea.BODY), skeleton.calculate(), (_a23 = render2.mainComponent) == null || _a23.makeDirty(!0));
990
1190
  }, "closeHeaderFooter");
991
1191
  return useEffect(() => {
992
1192
  const docDataModel = univerInstanceService.getUniverDocInstance(unitId), documentStyle = docDataModel == null ? void 0 : docDataModel.getSnapshot().documentStyle;
993
1193
  if (documentStyle) {
994
- const { marginHeader, marginFooter, useFirstPageHeaderFooter, evenAndOddHeaders } = documentStyle;
1194
+ const {
1195
+ marginHeader = 0,
1196
+ marginFooter = 0,
1197
+ useFirstPageHeaderFooter = BooleanNumber.FALSE,
1198
+ evenAndOddHeaders = BooleanNumber.FALSE
1199
+ } = documentStyle;
995
1200
  setOptions({
996
1201
  marginHeader,
997
1202
  marginFooter,
@@ -999,9 +1204,9 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
999
1204
  evenAndOddHeaders
1000
1205
  });
1001
1206
  }
1002
- }, [unitId]), /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles.options, children: [
1003
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles.optionsSection, children: [
1004
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles.optionsFormItem, children: /* @__PURE__ */ jsxRuntimeExports.jsx(
1207
+ }, [unitId]), /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.options, children: [
1208
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.optionsSection, children: [
1209
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.optionsFormItem, children: /* @__PURE__ */ jsxRuntimeExports.jsx(
1005
1210
  Checkbox,
1006
1211
  {
1007
1212
  checked: options.useFirstPageHeaderFooter === BooleanNumber.TRUE,
@@ -1011,7 +1216,7 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
1011
1216
  children: localeService.t("headerFooter.firstPageCheckBox")
1012
1217
  }
1013
1218
  ) }),
1014
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles.optionsFormItem, children: /* @__PURE__ */ jsxRuntimeExports.jsx(
1219
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.optionsFormItem, children: /* @__PURE__ */ jsxRuntimeExports.jsx(
1015
1220
  Checkbox,
1016
1221
  {
1017
1222
  checked: options.evenAndOddHeaders === BooleanNumber.TRUE,
@@ -1022,8 +1227,8 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
1022
1227
  }
1023
1228
  ) })
1024
1229
  ] }),
1025
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: clsx(styles.optionsSection, styles.optionsMarginSetting), children: [
1026
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles.optionsMarginItem, children: [
1230
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: clsx(styles$5.optionsSection, styles$5.optionsMarginSetting), children: [
1231
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.optionsMarginItem, children: [
1027
1232
  /* @__PURE__ */ jsxRuntimeExports.jsx("span", { children: localeService.t("headerFooter.headerTopMargin") }),
1028
1233
  /* @__PURE__ */ jsxRuntimeExports.jsx(
1029
1234
  InputNumber,
@@ -1035,11 +1240,11 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
1035
1240
  onChange: /* @__PURE__ */ __name((val) => {
1036
1241
  handleMarginChange(val, "marginHeader");
1037
1242
  }, "onChange"),
1038
- className: styles.optionsInput
1243
+ className: styles$5.optionsInput
1039
1244
  }
1040
1245
  )
1041
1246
  ] }),
1042
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles.optionsMarginItem, children: [
1247
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$5.optionsMarginItem, children: [
1043
1248
  /* @__PURE__ */ jsxRuntimeExports.jsx("span", { children: localeService.t("headerFooter.footerBottomMargin") }),
1044
1249
  /* @__PURE__ */ jsxRuntimeExports.jsx(
1045
1250
  InputNumber,
@@ -1051,16 +1256,16 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
1051
1256
  onChange: /* @__PURE__ */ __name((val) => {
1052
1257
  handleMarginChange(val, "marginFooter");
1053
1258
  }, "onChange"),
1054
- className: styles.optionsInput
1259
+ className: styles$5.optionsInput
1055
1260
  }
1056
1261
  )
1057
1262
  ] })
1058
1263
  ] }),
1059
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles.optionsSection, children: /* @__PURE__ */ jsxRuntimeExports.jsx(Button, { onClick: closeHeaderFooter, children: localeService.t("headerFooter.closeHeaderFooter") }) })
1264
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.optionsSection, children: /* @__PURE__ */ jsxRuntimeExports.jsx(Button, { onClick: closeHeaderFooter, children: localeService.t("headerFooter.closeHeaderFooter") }) })
1060
1265
  ] });
1061
1266
  }, "DocHeaderFooterOptions"), DocHeaderFooterPanel = /* @__PURE__ */ __name(() => {
1062
- var _a19;
1063
- const localeService = useDependency(LocaleService), renderManagerService = useDependency(IRenderManagerService), unitId = useDependency(IUniverInstanceService).getCurrentUniverDocInstance().getUnitId(), viewModel = ((_a19 = renderManagerService.getRenderById(unitId)) == null ? void 0 : _a19.with(DocSkeletonManagerService)).getViewModel(), [isEditHeaderFooter, setIsEditHeaderFooter] = useState(!0);
1267
+ var _a23;
1268
+ const localeService = useDependency(LocaleService), renderManagerService = useDependency(IRenderManagerService), unitId = useDependency(IUniverInstanceService).getCurrentUniverDocInstance().getUnitId(), viewModel = ((_a23 = renderManagerService.getRenderById(unitId)) == null ? void 0 : _a23.with(DocSkeletonManagerService)).getViewModel(), [isEditHeaderFooter, setIsEditHeaderFooter] = useState(!0);
1064
1269
  return useEffect(() => {
1065
1270
  const editArea = viewModel.getEditArea();
1066
1271
  setIsEditHeaderFooter(editArea !== DocumentEditArea.BODY);
@@ -1070,35 +1275,13 @@ const COMPONENT_DOC_HEADER_FOOTER_PANEL = "COMPONENT_DOC_HEADER_FOOTER_PANEL", p
1070
1275
  return () => {
1071
1276
  subscription.unsubscribe();
1072
1277
  };
1073
- }, []), /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles.panel, children: isEditHeaderFooter ? /* @__PURE__ */ jsxRuntimeExports.jsx(DocHeaderFooterOptions, { unitId }) : /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles.panelDisableText, children: localeService.t("headerFooter.disableText") }) });
1074
- }, "DocHeaderFooterPanel"), SidebarDocHeaderFooterPanelOperation = {
1075
- id: "sidebar.operation.doc-header-footer-panel",
1076
- type: CommandType.COMMAND,
1077
- handler: /* @__PURE__ */ __name(async (accessor, params) => {
1078
- const sidebarService = accessor.get(ISidebarService), localeService = accessor.get(LocaleService);
1079
- switch (params.value) {
1080
- case "open":
1081
- sidebarService.open({
1082
- header: { title: localeService.t("headerFooter.panel") },
1083
- children: { label: COMPONENT_DOC_HEADER_FOOTER_PANEL },
1084
- onClose: /* @__PURE__ */ __name(() => {
1085
- }, "onClose"),
1086
- width: 400
1087
- });
1088
- break;
1089
- case "close":
1090
- default:
1091
- sidebarService.close();
1092
- break;
1093
- }
1094
- return !0;
1095
- }, "handler")
1096
- };
1097
- var __defProp$d = Object.defineProperty, __getOwnPropDesc$d = Object.getOwnPropertyDescriptor, __decorateClass$d = /* @__PURE__ */ __name((decorators, target, key, kind) => {
1098
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$d(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
1278
+ }, []), /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.panel, children: isEditHeaderFooter ? /* @__PURE__ */ jsxRuntimeExports.jsx(DocHeaderFooterOptions, { unitId }) : /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$5.panelDisableText, children: localeService.t("headerFooter.disableText") }) });
1279
+ }, "DocHeaderFooterPanel");
1280
+ var __defProp$h = Object.defineProperty, __getOwnPropDesc$h = Object.getOwnPropertyDescriptor, __decorateClass$h = /* @__PURE__ */ __name((decorators, target, key, kind) => {
1281
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$h(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
1099
1282
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
1100
- return kind && result && __defProp$d(target, key, result), result;
1101
- }, "__decorateClass$d"), __decorateParam$d = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$d");
1283
+ return kind && result && __defProp$h(target, key, result), result;
1284
+ }, "__decorateClass$h"), __decorateParam$h = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$h");
1102
1285
  const HEADER_FOOTER_STROKE_COLOR = "rgba(58, 96, 247, 1)", HEADER_FOOTER_FILL_COLOR = "rgba(58, 96, 247, 0.08)";
1103
1286
  var HeaderFooterType = /* @__PURE__ */ ((HeaderFooterType2) => (HeaderFooterType2[HeaderFooterType2.FIRST_PAGE_HEADER = 0] = "FIRST_PAGE_HEADER", HeaderFooterType2[HeaderFooterType2.FIRST_PAGE_FOOTER = 1] = "FIRST_PAGE_FOOTER", HeaderFooterType2[HeaderFooterType2.DEFAULT_HEADER = 2] = "DEFAULT_HEADER", HeaderFooterType2[HeaderFooterType2.DEFAULT_FOOTER = 3] = "DEFAULT_FOOTER", HeaderFooterType2[HeaderFooterType2.EVEN_PAGE_HEADER = 4] = "EVEN_PAGE_HEADER", HeaderFooterType2[HeaderFooterType2.EVEN_PAGE_FOOTER = 5] = "EVEN_PAGE_FOOTER", HeaderFooterType2))(HeaderFooterType || {});
1104
1287
  function checkCreateHeaderFooterType(viewModel, editArea, segmentPage) {
@@ -1159,14 +1342,7 @@ let DocHeaderFooterController = (_a5 = class extends Disposable {
1159
1342
  this._context = _context, this._commandService = _commandService, this._editorService = _editorService, this._instanceSrv = _instanceSrv, this._renderManagerService = _renderManagerService, this._docSkeletonManagerService = _docSkeletonManagerService, this._textSelectionRenderManager = _textSelectionRenderManager, this._localeService = _localeService, this._componentManager = _componentManager, this._initialize();
1160
1343
  }
1161
1344
  _initialize() {
1162
- this._context.unit.getSnapshot().documentStyle.documentFlavor === DocumentFlavor.TRADITIONAL && (this._init(), this._drawHeaderFooterLabel(), this._registerCommands(), this._initCustomComponents());
1163
- }
1164
- _registerCommands() {
1165
- [
1166
- CoreHeaderFooterCommand,
1167
- OpenHeaderFooterPanelCommand,
1168
- SidebarDocHeaderFooterPanelOperation
1169
- ].forEach((command) => this.disposeWithMe(this._commandService.registerCommand(command)));
1345
+ this._context.unit.getSnapshot().documentStyle.documentFlavor === DocumentFlavor.TRADITIONAL && (this._init(), this._drawHeaderFooterLabel(), this._initCustomComponents());
1170
1346
  }
1171
1347
  _initCustomComponents() {
1172
1348
  const componentManager = this._componentManager;
@@ -1296,16 +1472,39 @@ let DocHeaderFooterController = (_a5 = class extends Disposable {
1296
1472
  return this._context.unit;
1297
1473
  }
1298
1474
  }, __name(_a5, "DocHeaderFooterController"), _a5);
1299
- DocHeaderFooterController = __decorateClass$d([
1300
- __decorateParam$d(1, ICommandService),
1301
- __decorateParam$d(2, IEditorService),
1302
- __decorateParam$d(3, IUniverInstanceService),
1303
- __decorateParam$d(4, IRenderManagerService),
1304
- __decorateParam$d(5, Inject(DocSkeletonManagerService)),
1305
- __decorateParam$d(6, ITextSelectionRenderManager),
1306
- __decorateParam$d(7, Inject(LocaleService)),
1307
- __decorateParam$d(8, Inject(ComponentManager))
1475
+ DocHeaderFooterController = __decorateClass$h([
1476
+ __decorateParam$h(1, ICommandService),
1477
+ __decorateParam$h(2, IEditorService),
1478
+ __decorateParam$h(3, IUniverInstanceService),
1479
+ __decorateParam$h(4, IRenderManagerService),
1480
+ __decorateParam$h(5, Inject(DocSkeletonManagerService)),
1481
+ __decorateParam$h(6, ITextSelectionRenderManager),
1482
+ __decorateParam$h(7, Inject(LocaleService)),
1483
+ __decorateParam$h(8, Inject(ComponentManager))
1308
1484
  ], DocHeaderFooterController);
1485
+ const SidebarDocHeaderFooterPanelOperation = {
1486
+ id: "sidebar.operation.doc-header-footer-panel",
1487
+ type: CommandType.OPERATION,
1488
+ handler: /* @__PURE__ */ __name(async (accessor, params) => {
1489
+ const sidebarService = accessor.get(ISidebarService), localeService = accessor.get(LocaleService);
1490
+ switch (params.value) {
1491
+ case "open":
1492
+ sidebarService.open({
1493
+ header: { title: localeService.t("headerFooter.panel") },
1494
+ children: { label: COMPONENT_DOC_HEADER_FOOTER_PANEL },
1495
+ onClose: /* @__PURE__ */ __name(() => {
1496
+ }, "onClose"),
1497
+ width: 400
1498
+ });
1499
+ break;
1500
+ case "close":
1501
+ default:
1502
+ sidebarService.close();
1503
+ break;
1504
+ }
1505
+ return !0;
1506
+ }, "handler")
1507
+ };
1309
1508
  function getEmptyHeaderFooterBody() {
1310
1509
  return {
1311
1510
  dataStream: `\r
@@ -1387,8 +1586,8 @@ const CoreHeaderFooterCommandId = "doc.command.core-header-footer", CoreHeaderFo
1387
1586
  type: CommandType.COMMAND,
1388
1587
  // eslint-disable-next-line max-lines-per-function
1389
1588
  handler: /* @__PURE__ */ __name(async (accessor, params) => {
1390
- var _a19;
1391
- const commandService = accessor.get(ICommandService), univerInstanceService = accessor.get(IUniverInstanceService), renderManagerService = accessor.get(IRenderManagerService), { unitId, segmentId, createType, headerFooterProps } = params, docSkeletonManagerService = (_a19 = renderManagerService.getRenderById(unitId)) == null ? void 0 : _a19.with(DocSkeletonManagerService), docDataModel = univerInstanceService.getUniverDocInstance(unitId), docViewModel = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getViewModel();
1589
+ var _a23;
1590
+ const commandService = accessor.get(ICommandService), univerInstanceService = accessor.get(IUniverInstanceService), renderManagerService = accessor.get(IRenderManagerService), { unitId, segmentId, createType, headerFooterProps } = params, docSkeletonManagerService = (_a23 = renderManagerService.getRenderById(unitId)) == null ? void 0 : _a23.with(DocSkeletonManagerService), docDataModel = univerInstanceService.getUniverDocInstance(unitId), docViewModel = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getViewModel();
1392
1591
  if (docDataModel == null || docViewModel == null)
1393
1592
  return !1;
1394
1593
  const editArea = docViewModel.getEditArea(), { documentStyle } = docDataModel.getSnapshot(), isUpdateMargin = (headerFooterProps == null ? void 0 : headerFooterProps.marginFooter) != null || (headerFooterProps == null ? void 0 : headerFooterProps.marginHeader) != null, textRanges = [{
@@ -1424,55 +1623,334 @@ const CoreHeaderFooterCommandId = "doc.command.core-header-footer", CoreHeaderFo
1424
1623
  id: "doc.command.open-header-footer-panel",
1425
1624
  type: CommandType.COMMAND,
1426
1625
  handler: /* @__PURE__ */ __name(async (accessor, _params) => accessor.get(ICommandService).executeCommand(SidebarDocHeaderFooterPanelOperation.id, { value: "open" }), "handler")
1427
- };
1428
- function BoldMenuItemFactory(accessor) {
1429
- const commandService = accessor.get(ICommandService);
1430
- return {
1431
- id: SetInlineFormatBoldCommand.id,
1432
- group: MenuGroup.TOOLBAR_FORMAT,
1433
- type: MenuItemType.BUTTON,
1434
- icon: "BoldSingle",
1435
- title: "Set bold",
1436
- tooltip: "toolbar.bold",
1437
- positions: [MenuPosition.TOOLBAR_START],
1438
- activated$: new Observable((subscriber) => {
1439
- const disposable = commandService.onCommandExecuted((c) => {
1440
- var _a19;
1441
- const id = c.id;
1442
- if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1443
- const textRun = getFontStyleAtCursor(accessor);
1444
- if (textRun == null)
1445
- return;
1446
- const bl = (_a19 = textRun.ts) == null ? void 0 : _a19.bl;
1447
- subscriber.next(bl === BooleanNumber.TRUE);
1448
- }
1449
- });
1450
- return subscriber.next(!1), disposable.dispose;
1451
- }),
1452
- hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
1453
- };
1454
- }
1455
- __name(BoldMenuItemFactory, "BoldMenuItemFactory");
1456
- function ItalicMenuItemFactory(accessor) {
1457
- const commandService = accessor.get(ICommandService);
1458
- return {
1459
- id: SetInlineFormatItalicCommand.id,
1460
- group: MenuGroup.TOOLBAR_FORMAT,
1461
- type: MenuItemType.BUTTON,
1462
- icon: "ItalicSingle",
1463
- title: "Set italic",
1464
- tooltip: "toolbar.italic",
1465
- positions: [MenuPosition.TOOLBAR_START],
1466
- activated$: new Observable((subscriber) => {
1467
- const disposable = commandService.onCommandExecuted((c) => {
1468
- var _a19;
1469
- const id = c.id;
1470
- if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1471
- const textRun = getFontStyleAtCursor(accessor);
1472
- if (textRun == null)
1473
- return;
1474
- const it = (_a19 = textRun.ts) == null ? void 0 : _a19.it;
1475
- subscriber.next(it === BooleanNumber.TRUE);
1626
+ }, docCountBar = "univer-doc-count-bar", styles$4 = {
1627
+ docCountBar
1628
+ }, ZOOM_MAP = [50, 80, 100, 130, 150, 170, 200, 400], DOC_ZOOM_RANGE = [10, 400];
1629
+ function ZoomSlider() {
1630
+ const commandService = useDependency(ICommandService), univerInstanceService = useDependency(IUniverInstanceService), currentDoc$ = useMemo(() => univerInstanceService.getCurrentTypeOfUnit$(UniverInstanceType.UNIVER_DOC), []), documentDataModel = useObservable(currentDoc$), getCurrentZoom = useCallback(() => {
1631
+ var _a23, _b;
1632
+ if (!documentDataModel) return 100;
1633
+ const currentZoom = ((_b = (_a23 = documentDataModel.getSettings()) == null ? void 0 : _a23.zoomRatio) != null ? _b : 1) * 100;
1634
+ return Math.round(currentZoom);
1635
+ }, [documentDataModel]), [zoom, setZoom] = useState(() => getCurrentZoom());
1636
+ useEffect(() => (setZoom(getCurrentZoom()), commandService.onCommandExecuted((commandInfo) => {
1637
+ if (commandInfo.id === SetDocZoomRatioOperation.id) {
1638
+ const currentZoom = getCurrentZoom();
1639
+ setZoom(currentZoom);
1640
+ }
1641
+ }).dispose), [commandService, getCurrentZoom]);
1642
+ function handleChange(value) {
1643
+ if (setZoom(value), documentDataModel == null)
1644
+ return;
1645
+ const zoomRatio = value / 100;
1646
+ commandService.executeCommand(SetDocZoomRatioOperation.id, {
1647
+ unitId: documentDataModel.getUnitId(),
1648
+ zoomRatio
1649
+ });
1650
+ }
1651
+ return __name(handleChange, "handleChange"), /* @__PURE__ */ jsxRuntimeExports.jsx(
1652
+ Slider,
1653
+ {
1654
+ min: DOC_ZOOM_RANGE[0],
1655
+ value: zoom,
1656
+ shortcuts: ZOOM_MAP,
1657
+ onChange: handleChange
1658
+ }
1659
+ );
1660
+ }
1661
+ __name(ZoomSlider, "ZoomSlider");
1662
+ function CountBar(props) {
1663
+ return /* @__PURE__ */ jsxRuntimeExports.jsx("section", { className: styles$4.docCountBar, children: /* @__PURE__ */ jsxRuntimeExports.jsx(ZoomSlider, {}) });
1664
+ }
1665
+ __name(CountBar, "CountBar");
1666
+ const docFooterContainer = "univer-doc-footer-container", styles$3 = {
1667
+ docFooterContainer
1668
+ }, DocFooter = /* @__PURE__ */ __name(() => /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$3.docFooterContainer, children: [
1669
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", {}),
1670
+ /* @__PURE__ */ jsxRuntimeExports.jsx(CountBar, {})
1671
+ ] }), "DocFooter"), BoldShortCut = {
1672
+ id: SetInlineFormatBoldCommand.id,
1673
+ binding: KeyCode.B | MetaKeys.CTRL_COMMAND,
1674
+ preconditions: whenDocAndEditorFocused
1675
+ }, ItalicShortCut = {
1676
+ id: SetInlineFormatItalicCommand.id,
1677
+ binding: KeyCode.I | MetaKeys.CTRL_COMMAND,
1678
+ preconditions: whenDocAndEditorFocused
1679
+ }, UnderlineShortCut = {
1680
+ id: SetInlineFormatUnderlineCommand.id,
1681
+ binding: KeyCode.U | MetaKeys.CTRL_COMMAND,
1682
+ preconditions: whenDocAndEditorFocused
1683
+ }, StrikeThroughShortCut = {
1684
+ id: SetInlineFormatStrikethroughCommand.id,
1685
+ binding: KeyCode.X | MetaKeys.SHIFT | MetaKeys.CTRL_COMMAND,
1686
+ preconditions: whenDocAndEditorFocused
1687
+ }, SubscriptShortCut = {
1688
+ id: SetInlineFormatSubscriptCommand.id,
1689
+ binding: KeyCode.COMMA | MetaKeys.CTRL_COMMAND,
1690
+ preconditions: whenDocAndEditorFocused
1691
+ }, SuperscriptShortCut = {
1692
+ id: SetInlineFormatSuperscriptCommand.id,
1693
+ binding: KeyCode.PERIOD | MetaKeys.CTRL_COMMAND,
1694
+ preconditions: whenDocAndEditorFocused
1695
+ }, AlignLeftShortCut = {
1696
+ id: AlignLeftCommand.id,
1697
+ binding: KeyCode.L | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
1698
+ preconditions: whenDocAndEditorFocused
1699
+ }, AlignRightShortCut = {
1700
+ id: AlignRightCommand.id,
1701
+ binding: KeyCode.R | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
1702
+ preconditions: whenDocAndEditorFocused
1703
+ }, AlignCenterShortCut = {
1704
+ id: AlignCenterCommand.id,
1705
+ binding: KeyCode.E | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
1706
+ preconditions: whenDocAndEditorFocused
1707
+ }, AlignJustifyShortCut = {
1708
+ id: AlignJustifyCommand.id,
1709
+ binding: KeyCode.J | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
1710
+ preconditions: whenDocAndEditorFocused
1711
+ }, OrderListShortCut = {
1712
+ id: OrderListCommand.id,
1713
+ binding: KeyCode.Digit7 | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
1714
+ preconditions: whenDocAndEditorFocused
1715
+ }, BulletListShortCut = {
1716
+ id: BulletListCommand.id,
1717
+ binding: KeyCode.Digit8 | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
1718
+ preconditions: whenDocAndEditorFocused
1719
+ }, TabShortCut = {
1720
+ id: TabCommand.id,
1721
+ binding: KeyCode.TAB,
1722
+ preconditions: whenDocAndEditorFocused
1723
+ }, ShiftTabShortCut = {
1724
+ id: TabCommand.id,
1725
+ binding: KeyCode.TAB | MetaKeys.SHIFT,
1726
+ preconditions: whenDocAndEditorFocused,
1727
+ staticParameters: {
1728
+ shift: !0
1729
+ }
1730
+ }, docListTypePicker = "univer-doc-list-type-picker", docListTypePickerItem = "univer-doc-list-type-picker-item", docListTypePickerItemActive = "univer-doc-list-type-picker-item-active", styles$2 = {
1731
+ docListTypePicker,
1732
+ docListTypePickerItem,
1733
+ docListTypePickerItemActive
1734
+ }, ListTypePicker = /* @__PURE__ */ __name((props) => {
1735
+ const { value, onChange, options } = props;
1736
+ return /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$2.docListTypePicker, children: options.map((item) => /* @__PURE__ */ jsxRuntimeExports.jsx(
1737
+ "img",
1738
+ {
1739
+ className: styles$2.docListTypePickerItem + (value === item.value ? ` ${styles$2.docListTypePickerItemActive}` : ""),
1740
+ onClick: /* @__PURE__ */ __name(() => {
1741
+ onChange(item.value);
1742
+ }, "onClick"),
1743
+ src: item.img
1744
+ },
1745
+ item.value
1746
+ )) });
1747
+ }, "ListTypePicker"), orderListOptions = [
1748
+ {
1749
+ value: PresetListType.ORDER_LIST,
1750
+ img: ""
1751
+ },
1752
+ {
1753
+ value: PresetListType.ORDER_LIST_1,
1754
+ img: ""
1755
+ },
1756
+ {
1757
+ value: PresetListType.ORDER_LIST_2,
1758
+ img: ""
1759
+ },
1760
+ {
1761
+ value: PresetListType.ORDER_LIST_3,
1762
+ img: ""
1763
+ },
1764
+ {
1765
+ value: PresetListType.ORDER_LIST_4,
1766
+ img: ""
1767
+ },
1768
+ {
1769
+ value: PresetListType.ORDER_LIST_5,
1770
+ img: ""
1771
+ }
1772
+ ], OrderListTypePicker = /* @__PURE__ */ __name((props) => /* @__PURE__ */ jsxRuntimeExports.jsx(
1773
+ ListTypePicker,
1774
+ {
1775
+ ...props,
1776
+ options: orderListOptions
1777
+ }
1778
+ ), "OrderListTypePicker"), bulletOptions = [
1779
+ {
1780
+ value: PresetListType.BULLET_LIST,
1781
+ img: ""
1782
+ },
1783
+ {
1784
+ value: PresetListType.BULLET_LIST_1,
1785
+ img: ""
1786
+ },
1787
+ {
1788
+ value: PresetListType.BULLET_LIST_2,
1789
+ img: ""
1790
+ },
1791
+ {
1792
+ value: PresetListType.BULLET_LIST_3,
1793
+ img: ""
1794
+ },
1795
+ {
1796
+ value: PresetListType.BULLET_LIST_4,
1797
+ img: ""
1798
+ },
1799
+ {
1800
+ value: PresetListType.BULLET_LIST_5,
1801
+ img: ""
1802
+ }
1803
+ ], BulletListTypePicker = /* @__PURE__ */ __name((props) => /* @__PURE__ */ jsxRuntimeExports.jsx(
1804
+ ListTypePicker,
1805
+ {
1806
+ ...props,
1807
+ options: bulletOptions
1808
+ }
1809
+ ), "BulletListTypePicker"), ORDER_LIST_TYPE_COMPONENT = `${COMPONENT_PREFIX}_ORDER_LIST_TYPE_COMPONENT`, BULLET_LIST_TYPE_COMPONENT = `${COMPONENT_PREFIX}_BULLET_LIST_TYPE_COMPONENT`, COMPONENT_DOC_CREATE_TABLE_CONFIRM = "COMPONENT_DOC_CREATE_TABLE_CONFIRM", COMPONENT_DOC_CREATE_TABLE_CONFIRM_ID = "doc.component.create-table-confirm", DocCreateTableOperation = {
1810
+ id: "doc.operation.create-table",
1811
+ type: CommandType.COMMAND,
1812
+ handler: /* @__PURE__ */ __name(async (accessor) => {
1813
+ const localeService = accessor.get(LocaleService), confirmService = accessor.get(IConfirmService), commandService = accessor.get(ICommandService), tableCreateParams = {
1814
+ rowCount: 3,
1815
+ colCount: 5
1816
+ }, handleRowColChange = /* @__PURE__ */ __name((rowCount, colCount) => {
1817
+ tableCreateParams.rowCount = rowCount, tableCreateParams.colCount = colCount;
1818
+ }, "handleRowColChange");
1819
+ return await confirmService.open({
1820
+ id: COMPONENT_DOC_CREATE_TABLE_CONFIRM_ID,
1821
+ children: {
1822
+ label: {
1823
+ name: COMPONENT_DOC_CREATE_TABLE_CONFIRM,
1824
+ props: {
1825
+ handleRowColChange,
1826
+ tableCreateParams
1827
+ }
1828
+ }
1829
+ },
1830
+ width: 400,
1831
+ title: { title: localeService.t("toolbar.table.insert") },
1832
+ onConfirm: /* @__PURE__ */ __name(() => {
1833
+ commandService.executeCommand(CreateDocTableCommand.id, tableCreateParams), confirmService.close(COMPONENT_DOC_CREATE_TABLE_CONFIRM_ID);
1834
+ }, "onConfirm"),
1835
+ onClose: /* @__PURE__ */ __name(() => {
1836
+ confirmService.close(COMPONENT_DOC_CREATE_TABLE_CONFIRM_ID);
1837
+ }, "onClose")
1838
+ }), !0;
1839
+ }, "handler")
1840
+ };
1841
+ function getInsertTableHiddenObservable(accessor) {
1842
+ const univerInstanceService = accessor.get(IUniverInstanceService), renderManagerService = accessor.get(IRenderManagerService);
1843
+ return new Observable((subscriber) => {
1844
+ const subscription = univerInstanceService.focused$.subscribe((unitId) => {
1845
+ if (unitId == null || univerInstanceService.getUnitType(unitId) !== UniverInstanceType.UNIVER_DOC)
1846
+ return subscriber.next(!0);
1847
+ const currentRender2 = renderManagerService.getRenderById(unitId);
1848
+ if (currentRender2 == null)
1849
+ return subscriber.next(!0);
1850
+ currentRender2.with(DocSkeletonManagerService).getViewModel().editAreaChange$.subscribe((editArea) => {
1851
+ subscriber.next(editArea === DocumentEditArea.HEADER || editArea === DocumentEditArea.FOOTER);
1852
+ });
1853
+ }), currentRender = renderManagerService.getCurrentTypeOfRenderer(UniverInstanceType.UNIVER_DOC);
1854
+ if (currentRender == null)
1855
+ return subscriber.next(!0);
1856
+ const viewModel = currentRender.with(DocSkeletonManagerService).getViewModel();
1857
+ return subscriber.next(viewModel.getEditArea() !== DocumentEditArea.BODY), () => subscription.unsubscribe();
1858
+ });
1859
+ }
1860
+ __name(getInsertTableHiddenObservable, "getInsertTableHiddenObservable");
1861
+ function getTableDisabledObservable(accessor) {
1862
+ const textSelectionManagerService = accessor.get(TextSelectionManagerService), univerInstanceService = accessor.get(IUniverInstanceService);
1863
+ return new Observable((subscriber) => {
1864
+ const subscription = textSelectionManagerService.textSelection$.subscribe((selection) => {
1865
+ if (selection == null) {
1866
+ subscriber.next(!0);
1867
+ return;
1868
+ }
1869
+ const { textRanges } = selection;
1870
+ if (textRanges.length !== 1) {
1871
+ subscriber.next(!0);
1872
+ return;
1873
+ }
1874
+ const textRange = textRanges[0], { collapsed, anchorNodePosition, startOffset } = textRange;
1875
+ if (!collapsed || startOffset == null) {
1876
+ subscriber.next(!0);
1877
+ return;
1878
+ }
1879
+ const docDataModel = univerInstanceService.getCurrentUniverDocInstance();
1880
+ if (docDataModel == null) {
1881
+ subscriber.next(!0);
1882
+ return;
1883
+ }
1884
+ const docSkeletonManagerService = getCommandSkeleton(accessor, docDataModel.getUnitId());
1885
+ if (docSkeletonManagerService == null) {
1886
+ subscriber.next(!0);
1887
+ return;
1888
+ }
1889
+ if (docSkeletonManagerService.getViewModel().getCustomRangeRaw(startOffset)) {
1890
+ subscriber.next(!0);
1891
+ return;
1892
+ }
1893
+ if (anchorNodePosition != null) {
1894
+ const { path } = anchorNodePosition;
1895
+ if (path.indexOf("cells") !== -1) {
1896
+ subscriber.next(!0);
1897
+ return;
1898
+ }
1899
+ }
1900
+ subscriber.next(!1);
1901
+ });
1902
+ return () => subscription.unsubscribe();
1903
+ });
1904
+ }
1905
+ __name(getTableDisabledObservable, "getTableDisabledObservable");
1906
+ function BoldMenuItemFactory(accessor) {
1907
+ const commandService = accessor.get(ICommandService);
1908
+ return {
1909
+ id: SetInlineFormatBoldCommand.id,
1910
+ group: MenuGroup.TOOLBAR_FORMAT,
1911
+ type: MenuItemType.BUTTON,
1912
+ icon: "BoldSingle",
1913
+ title: "Set bold",
1914
+ tooltip: "toolbar.bold",
1915
+ positions: [MenuPosition.TOOLBAR_START],
1916
+ activated$: new Observable((subscriber) => {
1917
+ const disposable = commandService.onCommandExecuted((c) => {
1918
+ var _a23;
1919
+ const id = c.id;
1920
+ if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1921
+ const textRun = getFontStyleAtCursor(accessor);
1922
+ if (textRun == null)
1923
+ return;
1924
+ const bl = (_a23 = textRun.ts) == null ? void 0 : _a23.bl;
1925
+ subscriber.next(bl === BooleanNumber.TRUE);
1926
+ }
1927
+ });
1928
+ return subscriber.next(!1), disposable.dispose;
1929
+ }),
1930
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
1931
+ };
1932
+ }
1933
+ __name(BoldMenuItemFactory, "BoldMenuItemFactory");
1934
+ function ItalicMenuItemFactory(accessor) {
1935
+ const commandService = accessor.get(ICommandService);
1936
+ return {
1937
+ id: SetInlineFormatItalicCommand.id,
1938
+ group: MenuGroup.TOOLBAR_FORMAT,
1939
+ type: MenuItemType.BUTTON,
1940
+ icon: "ItalicSingle",
1941
+ title: "Set italic",
1942
+ tooltip: "toolbar.italic",
1943
+ positions: [MenuPosition.TOOLBAR_START],
1944
+ activated$: new Observable((subscriber) => {
1945
+ const disposable = commandService.onCommandExecuted((c) => {
1946
+ var _a23;
1947
+ const id = c.id;
1948
+ if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1949
+ const textRun = getFontStyleAtCursor(accessor);
1950
+ if (textRun == null)
1951
+ return;
1952
+ const it = (_a23 = textRun.ts) == null ? void 0 : _a23.it;
1953
+ subscriber.next(it === BooleanNumber.TRUE);
1476
1954
  }
1477
1955
  });
1478
1956
  return subscriber.next(!1), disposable.dispose;
@@ -1493,13 +1971,13 @@ function UnderlineMenuItemFactory(accessor) {
1493
1971
  positions: [MenuPosition.TOOLBAR_START],
1494
1972
  activated$: new Observable((subscriber) => {
1495
1973
  const disposable = commandService.onCommandExecuted((c) => {
1496
- var _a19;
1974
+ var _a23;
1497
1975
  const id = c.id;
1498
1976
  if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1499
1977
  const textRun = getFontStyleAtCursor(accessor);
1500
1978
  if (textRun == null)
1501
1979
  return;
1502
- const ul = (_a19 = textRun.ts) == null ? void 0 : _a19.ul;
1980
+ const ul = (_a23 = textRun.ts) == null ? void 0 : _a23.ul;
1503
1981
  subscriber.next((ul == null ? void 0 : ul.s) === BooleanNumber.TRUE);
1504
1982
  }
1505
1983
  });
@@ -1521,13 +1999,13 @@ function StrikeThroughMenuItemFactory(accessor) {
1521
1999
  positions: [MenuPosition.TOOLBAR_START],
1522
2000
  activated$: new Observable((subscriber) => {
1523
2001
  const disposable = commandService.onCommandExecuted((c) => {
1524
- var _a19;
2002
+ var _a23;
1525
2003
  const id = c.id;
1526
2004
  if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1527
2005
  const textRun = getFontStyleAtCursor(accessor);
1528
2006
  if (textRun == null)
1529
2007
  return;
1530
- const st = (_a19 = textRun.ts) == null ? void 0 : _a19.st;
2008
+ const st = (_a23 = textRun.ts) == null ? void 0 : _a23.st;
1531
2009
  subscriber.next((st == null ? void 0 : st.s) === BooleanNumber.TRUE);
1532
2010
  }
1533
2011
  });
@@ -1548,13 +2026,13 @@ function SubscriptMenuItemFactory(accessor) {
1548
2026
  positions: [MenuPosition.TOOLBAR_START],
1549
2027
  activated$: new Observable((subscriber) => {
1550
2028
  const disposable = commandService.onCommandExecuted((c) => {
1551
- var _a19;
2029
+ var _a23;
1552
2030
  const id = c.id;
1553
2031
  if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1554
2032
  const textRun = getFontStyleAtCursor(accessor);
1555
2033
  if (textRun == null)
1556
2034
  return;
1557
- const va = (_a19 = textRun.ts) == null ? void 0 : _a19.va;
2035
+ const va = (_a23 = textRun.ts) == null ? void 0 : _a23.va;
1558
2036
  subscriber.next(va === BaselineOffset.SUBSCRIPT);
1559
2037
  }
1560
2038
  });
@@ -1575,13 +2053,13 @@ function SuperscriptMenuItemFactory(accessor) {
1575
2053
  positions: [MenuPosition.TOOLBAR_START],
1576
2054
  activated$: new Observable((subscriber) => {
1577
2055
  const disposable = commandService.onCommandExecuted((c) => {
1578
- var _a19;
2056
+ var _a23;
1579
2057
  const id = c.id;
1580
2058
  if (id === SetTextSelectionsOperation.id || id === SetInlineFormatCommand.id) {
1581
2059
  const textRun = getFontStyleAtCursor(accessor);
1582
2060
  if (textRun == null)
1583
2061
  return;
1584
- const va = (_a19 = textRun.ts) == null ? void 0 : _a19.va;
2062
+ const va = (_a23 = textRun.ts) == null ? void 0 : _a23.va;
1585
2063
  subscriber.next(va === BaselineOffset.SUPERSCRIPT);
1586
2064
  }
1587
2065
  });
@@ -1610,13 +2088,13 @@ function FontFamilySelectorMenuItemFactory(accessor) {
1610
2088
  // disabled$: getCurrentSheetDisabled$(accessor),
1611
2089
  value$: new Observable((subscriber) => {
1612
2090
  const defaultValue = FONT_FAMILY_LIST[0].value, disposable = commandService.onCommandExecuted((c) => {
1613
- var _a19;
2091
+ var _a23;
1614
2092
  const id = c.id;
1615
2093
  if (id === SetTextSelectionsOperation.id || id === SetInlineFormatFontFamilyCommand.id) {
1616
2094
  const textRun = getFontStyleAtCursor(accessor);
1617
2095
  if (textRun == null)
1618
2096
  return;
1619
- const ff = (_a19 = textRun.ts) == null ? void 0 : _a19.ff;
2097
+ const ff = (_a23 = textRun.ts) == null ? void 0 : _a23.ff;
1620
2098
  subscriber.next(ff != null ? ff : defaultValue);
1621
2099
  }
1622
2100
  });
@@ -1646,13 +2124,13 @@ function FontSizeSelectorMenuItemFactory(accessor) {
1646
2124
  // disabled$,
1647
2125
  value$: new Observable((subscriber) => {
1648
2126
  const disposable = commandService.onCommandExecuted((c) => {
1649
- var _a19;
2127
+ var _a23;
1650
2128
  const id = c.id;
1651
2129
  if (id === SetTextSelectionsOperation.id || id === SetInlineFormatFontSizeCommand.id) {
1652
2130
  const textRun = getFontStyleAtCursor(accessor);
1653
2131
  if (textRun == null)
1654
2132
  return;
1655
- const fs = (_a19 = textRun.ts) == null ? void 0 : _a19.fs;
2133
+ const fs = (_a23 = textRun.ts) == null ? void 0 : _a23.fs;
1656
2134
  subscriber.next(fs != null ? fs : 14);
1657
2135
  }
1658
2136
  });
@@ -1705,6 +2183,31 @@ function HeaderFooterMenuItemFactory(accessor) {
1705
2183
  };
1706
2184
  }
1707
2185
  __name(HeaderFooterMenuItemFactory, "HeaderFooterMenuItemFactory");
2186
+ const TableIcon = "GridSingle", TABLE_MENU_ID = "doc.menu.table";
2187
+ function TableMenuFactory(accessor) {
2188
+ return {
2189
+ id: TABLE_MENU_ID,
2190
+ type: MenuItemType.SUBITEMS,
2191
+ positions: [MenuPosition.TOOLBAR_START],
2192
+ group: MenuGroup.TOOLBAR_LAYOUT,
2193
+ icon: TableIcon,
2194
+ tooltip: "toolbar.table.main",
2195
+ disabled$: getTableDisabledObservable(accessor),
2196
+ // Do not show header footer menu and insert table at zen mode.
2197
+ hidden$: combineLatest(getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC), getInsertTableHiddenObservable(accessor), getHeaderFooterMenuHiddenObservable(accessor), (one, two, three) => one || two || three)
2198
+ };
2199
+ }
2200
+ __name(TableMenuFactory, "TableMenuFactory");
2201
+ function InsertTableMenuFactory(_accessor) {
2202
+ return {
2203
+ id: DocCreateTableOperation.id,
2204
+ title: "toolbar.table.insert",
2205
+ type: MenuItemType.BUTTON,
2206
+ positions: [TABLE_MENU_ID],
2207
+ hidden$: getMenuHiddenObservable(_accessor, UniverInstanceType.UNIVER_DOC)
2208
+ };
2209
+ }
2210
+ __name(InsertTableMenuFactory, "InsertTableMenuFactory");
1708
2211
  function AlignLeftMenuItemFactory(accessor) {
1709
2212
  const commandService = accessor.get(ICommandService);
1710
2213
  return {
@@ -1716,13 +2219,13 @@ function AlignLeftMenuItemFactory(accessor) {
1716
2219
  positions: [MenuPosition.TOOLBAR_START],
1717
2220
  activated$: new Observable((subscriber) => {
1718
2221
  const disposable = commandService.onCommandExecuted((c) => {
1719
- var _a19;
2222
+ var _a23;
1720
2223
  const id = c.id;
1721
2224
  if (id === SetTextSelectionsOperation.id || id === AlignOperationCommand.id) {
1722
2225
  const paragraph = getParagraphStyleAtCursor(accessor);
1723
2226
  if (paragraph == null)
1724
2227
  return;
1725
- const alignType = (_a19 = paragraph.paragraphStyle) == null ? void 0 : _a19.horizontalAlign;
2228
+ const alignType = (_a23 = paragraph.paragraphStyle) == null ? void 0 : _a23.horizontalAlign;
1726
2229
  subscriber.next(alignType === HorizontalAlign.LEFT);
1727
2230
  }
1728
2231
  });
@@ -1743,13 +2246,13 @@ function AlignCenterMenuItemFactory(accessor) {
1743
2246
  positions: [MenuPosition.TOOLBAR_START],
1744
2247
  activated$: new Observable((subscriber) => {
1745
2248
  const disposable = commandService.onCommandExecuted((c) => {
1746
- var _a19;
2249
+ var _a23;
1747
2250
  const id = c.id;
1748
2251
  if (id === SetTextSelectionsOperation.id || id === AlignOperationCommand.id) {
1749
2252
  const paragraph = getParagraphStyleAtCursor(accessor);
1750
2253
  if (paragraph == null)
1751
2254
  return;
1752
- const alignType = (_a19 = paragraph.paragraphStyle) == null ? void 0 : _a19.horizontalAlign;
2255
+ const alignType = (_a23 = paragraph.paragraphStyle) == null ? void 0 : _a23.horizontalAlign;
1753
2256
  subscriber.next(alignType === HorizontalAlign.CENTER);
1754
2257
  }
1755
2258
  });
@@ -1770,13 +2273,13 @@ function AlignRightMenuItemFactory(accessor) {
1770
2273
  positions: [MenuPosition.TOOLBAR_START],
1771
2274
  activated$: new Observable((subscriber) => {
1772
2275
  const disposable = commandService.onCommandExecuted((c) => {
1773
- var _a19;
2276
+ var _a23;
1774
2277
  const id = c.id;
1775
2278
  if (id === SetTextSelectionsOperation.id || id === AlignOperationCommand.id) {
1776
2279
  const paragraph = getParagraphStyleAtCursor(accessor);
1777
2280
  if (paragraph == null)
1778
2281
  return;
1779
- const alignType = (_a19 = paragraph.paragraphStyle) == null ? void 0 : _a19.horizontalAlign;
2282
+ const alignType = (_a23 = paragraph.paragraphStyle) == null ? void 0 : _a23.horizontalAlign;
1780
2283
  subscriber.next(alignType === HorizontalAlign.RIGHT);
1781
2284
  }
1782
2285
  });
@@ -1797,13 +2300,13 @@ function AlignJustifyMenuItemFactory(accessor) {
1797
2300
  positions: [MenuPosition.TOOLBAR_START],
1798
2301
  activated$: new Observable((subscriber) => {
1799
2302
  const disposable = commandService.onCommandExecuted((c) => {
1800
- var _a19;
2303
+ var _a23;
1801
2304
  const id = c.id;
1802
2305
  if (id === SetTextSelectionsOperation.id || id === AlignOperationCommand.id) {
1803
2306
  const paragraph = getParagraphStyleAtCursor(accessor);
1804
2307
  if (paragraph == null)
1805
2308
  return;
1806
- const alignType = (_a19 = paragraph.paragraphStyle) == null ? void 0 : _a19.horizontalAlign;
2309
+ const alignType = (_a23 = paragraph.paragraphStyle) == null ? void 0 : _a23.horizontalAlign;
1807
2310
  subscriber.next(alignType === HorizontalAlign.JUSTIFIED);
1808
2311
  }
1809
2312
  });
@@ -1813,15 +2316,53 @@ function AlignJustifyMenuItemFactory(accessor) {
1813
2316
  };
1814
2317
  }
1815
2318
  __name(AlignJustifyMenuItemFactory, "AlignJustifyMenuItemFactory");
2319
+ const listValueFactory$ = /* @__PURE__ */ __name((accessor) => new Observable((subscriber) => {
2320
+ const univerInstanceService = accessor.get(IUniverInstanceService), textSelectionManagerService = accessor.get(TextSelectionManagerService);
2321
+ let textSubscription;
2322
+ const subscription = univerInstanceService.focused$.subscribe((unitId) => {
2323
+ if (textSubscription == null || textSubscription.unsubscribe(), unitId == null)
2324
+ return;
2325
+ const docDataModel = univerInstanceService.getUniverDocInstance(unitId);
2326
+ docDataModel != null && (textSubscription = textSelectionManagerService.textSelection$.subscribe(() => {
2327
+ var _a23, _b;
2328
+ const range = textSelectionManagerService.getActiveTextRangeWithStyle();
2329
+ if (range) {
2330
+ const doc = docDataModel.getSelfOrHeaderFooterModel(range == null ? void 0 : range.segmentId), paragraphs = getParagraphsInRange(range, (_b = (_a23 = doc.getBody()) == null ? void 0 : _a23.paragraphs) != null ? _b : []);
2331
+ let listType;
2332
+ if (paragraphs.every((p2) => {
2333
+ var _a24;
2334
+ return listType || (listType = (_a24 = p2.bullet) == null ? void 0 : _a24.listType), p2.bullet && p2.bullet.listType === listType;
2335
+ })) {
2336
+ subscriber.next(listType);
2337
+ return;
2338
+ }
2339
+ }
2340
+ subscriber.next(void 0);
2341
+ }));
2342
+ });
2343
+ return () => {
2344
+ subscription.unsubscribe(), textSubscription == null || textSubscription.unsubscribe();
2345
+ };
2346
+ }), "listValueFactory$");
1816
2347
  function OrderListMenuItemFactory(accessor) {
1817
2348
  return {
1818
2349
  id: OrderListCommand.id,
1819
2350
  group: MenuGroup.TOOLBAR_LAYOUT,
1820
- type: MenuItemType.BUTTON,
2351
+ type: MenuItemType.BUTTON_SELECTOR,
2352
+ selections: [
2353
+ {
2354
+ label: {
2355
+ name: ORDER_LIST_TYPE_COMPONENT,
2356
+ hoverable: !1
2357
+ },
2358
+ value$: listValueFactory$(accessor)
2359
+ }
2360
+ ],
1821
2361
  icon: "OrderSingle",
1822
2362
  tooltip: "toolbar.order",
1823
2363
  positions: [MenuPosition.TOOLBAR_START],
1824
- hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2364
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC),
2365
+ activated$: listValueFactory$(accessor).pipe(map((v) => v && v.indexOf("ORDER_LIST") === 0))
1825
2366
  };
1826
2367
  }
1827
2368
  __name(OrderListMenuItemFactory, "OrderListMenuItemFactory");
@@ -1829,14 +2370,37 @@ function BulletListMenuItemFactory(accessor) {
1829
2370
  return {
1830
2371
  id: BulletListCommand.id,
1831
2372
  group: MenuGroup.TOOLBAR_LAYOUT,
1832
- type: MenuItemType.BUTTON,
2373
+ type: MenuItemType.BUTTON_SELECTOR,
2374
+ selections: [
2375
+ {
2376
+ label: {
2377
+ name: BULLET_LIST_TYPE_COMPONENT,
2378
+ hoverable: !1
2379
+ },
2380
+ value$: listValueFactory$(accessor)
2381
+ }
2382
+ ],
1833
2383
  icon: "UnorderSingle",
1834
2384
  tooltip: "toolbar.unorder",
1835
2385
  positions: [MenuPosition.TOOLBAR_START],
1836
- hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2386
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC),
2387
+ activated$: listValueFactory$(accessor).pipe(map((v) => v && v.indexOf("BULLET_LIST") === 0))
1837
2388
  };
1838
2389
  }
1839
2390
  __name(BulletListMenuItemFactory, "BulletListMenuItemFactory");
2391
+ function CheckListMenuItemFactory(accessor) {
2392
+ return {
2393
+ id: CheckListCommand.id,
2394
+ group: MenuGroup.TOOLBAR_LAYOUT,
2395
+ type: MenuItemType.BUTTON,
2396
+ icon: "TodoList",
2397
+ tooltip: "toolbar.checklist",
2398
+ positions: [MenuPosition.TOOLBAR_START],
2399
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC),
2400
+ activated$: listValueFactory$(accessor).pipe(map((v) => v && v.indexOf("CHECK_LIST") === 0))
2401
+ };
2402
+ }
2403
+ __name(CheckListMenuItemFactory, "CheckListMenuItemFactory");
1840
2404
  function ResetBackgroundColorMenuItemFactory(accessor) {
1841
2405
  return {
1842
2406
  id: ResetInlineFormatTextBackgroundColorCommand.id,
@@ -1878,11 +2442,11 @@ function BackgroundColorSelectorMenuItemFactory(accessor) {
1878
2442
  }
1879
2443
  __name(BackgroundColorSelectorMenuItemFactory, "BackgroundColorSelectorMenuItemFactory");
1880
2444
  function getFontStyleAtCursor(accessor) {
1881
- var _a19;
1882
- const univerInstanceService = accessor.get(IUniverInstanceService), textSelectionService = accessor.get(TextSelectionManagerService), docDataModel = univerInstanceService.getCurrentUniverDocInstance(), activeTextRange = textSelectionService.getActiveRange();
2445
+ var _a23;
2446
+ const univerInstanceService = accessor.get(IUniverInstanceService), textSelectionService = accessor.get(TextSelectionManagerService), docDataModel = univerInstanceService.getCurrentUniverDocInstance(), activeTextRange = textSelectionService.getActiveTextRangeWithStyle();
1883
2447
  if (docDataModel == null || activeTextRange == null)
1884
2448
  return;
1885
- const { startOffset, segmentId } = activeTextRange, textRuns = (_a19 = docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody()) == null ? void 0 : _a19.textRuns;
2449
+ const { startOffset, segmentId } = activeTextRange, textRuns = (_a23 = docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody()) == null ? void 0 : _a23.textRuns;
1886
2450
  if (textRuns == null)
1887
2451
  return;
1888
2452
  let textRun;
@@ -1901,11 +2465,11 @@ function getFontStyleAtCursor(accessor) {
1901
2465
  }
1902
2466
  __name(getFontStyleAtCursor, "getFontStyleAtCursor");
1903
2467
  function getParagraphStyleAtCursor(accessor) {
1904
- var _a19;
1905
- const univerInstanceService = accessor.get(IUniverInstanceService), textSelectionService = accessor.get(TextSelectionManagerService), docDataModel = univerInstanceService.getCurrentUniverDocInstance(), activeTextRange = textSelectionService.getActiveRange();
2468
+ var _a23;
2469
+ const univerInstanceService = accessor.get(IUniverInstanceService), textSelectionService = accessor.get(TextSelectionManagerService), docDataModel = univerInstanceService.getCurrentUniverDocInstance(), activeTextRange = textSelectionService.getActiveTextRangeWithStyle();
1906
2470
  if (docDataModel == null || activeTextRange == null)
1907
2471
  return;
1908
- const { startOffset, segmentId } = activeTextRange, paragraphs = (_a19 = docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody()) == null ? void 0 : _a19.paragraphs;
2472
+ const { startOffset, segmentId } = activeTextRange, paragraphs = (_a23 = docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody()) == null ? void 0 : _a23.paragraphs;
1909
2473
  if (paragraphs == null)
1910
2474
  return;
1911
2475
  let prevIndex = -1;
@@ -1949,17 +2513,344 @@ const DOC_CLIPBOARD_PRIORITY = 999, DocCopyCommand = {
1949
2513
  const docClipboardService = accessor.get(IDocClipboardService), clipboardItems = await accessor.get(IClipboardInterfaceService).read();
1950
2514
  return clipboardItems.length === 0 ? !1 : docClipboardService.paste(clipboardItems);
1951
2515
  }, "handler")
2516
+ }, DocParagraphSettingCommand = {
2517
+ id: "doc-paragraph-setting.command",
2518
+ type: CommandType.COMMAND,
2519
+ handler: /* @__PURE__ */ __name(async (accessor, config) => {
2520
+ var _a23, _b, _c;
2521
+ const textSelectionManagerService = accessor.get(TextSelectionManagerService), univerInstanceService = accessor.get(IUniverInstanceService), commandService = accessor.get(ICommandService), docDataModel = univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_DOC), docRanges = textSelectionManagerService.getDocRanges();
2522
+ if (!docDataModel || docRanges.length === 0 || !config)
2523
+ return !1;
2524
+ const segmentId = docRanges[0].segmentId, unitId = docDataModel.getUnitId(), allParagraphs = (_b = (_a23 = docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody()) == null ? void 0 : _a23.paragraphs) != null ? _b : [], paragraphs = (_c = getParagraphsInRanges(docRanges, allParagraphs)) != null ? _c : [], serializedSelections = docRanges.map(serializeDocRange), doMutation = {
2525
+ id: RichTextEditingMutation.id,
2526
+ params: {
2527
+ unitId,
2528
+ actions: [],
2529
+ textRanges: serializedSelections
2530
+ }
2531
+ }, memoryCursor = new MemoryCursor();
2532
+ memoryCursor.reset();
2533
+ const textX = new TextX(), jsonX = JSONX.getInstance();
2534
+ for (const paragraph of paragraphs) {
2535
+ const { startIndex } = paragraph;
2536
+ textX.push({
2537
+ t: TextXActionType.RETAIN,
2538
+ len: startIndex - memoryCursor.cursor,
2539
+ segmentId
2540
+ });
2541
+ const paragraphStyle = {
2542
+ ...paragraph.paragraphStyle,
2543
+ ...config
2544
+ };
2545
+ textX.push({
2546
+ t: TextXActionType.RETAIN,
2547
+ len: 1,
2548
+ body: {
2549
+ dataStream: "",
2550
+ paragraphs: [
2551
+ {
2552
+ ...paragraph,
2553
+ paragraphStyle,
2554
+ startIndex: 0
2555
+ }
2556
+ ]
2557
+ },
2558
+ segmentId,
2559
+ coverType: UpdateDocsAttributeType.REPLACE
2560
+ }), memoryCursor.moveCursorTo(startIndex + 1);
2561
+ }
2562
+ const path = getRichTextEditPath(docDataModel, segmentId);
2563
+ return doMutation.params.actions = jsonX.editOp(textX.serialize(), path), !!commandService.syncExecuteCommand(doMutation.id, doMutation.params);
2564
+ }, "handler")
2565
+ }, useCurrentParagraph = /* @__PURE__ */ __name(() => {
2566
+ var _a23, _b, _c;
2567
+ const textSelectionManagerService = useDependency(TextSelectionManagerService), docDataModel = useDependency(IUniverInstanceService).getCurrentUnitForType(UniverInstanceType.UNIVER_DOC), docRanges = useMemo(() => textSelectionManagerService.getDocRanges(), []);
2568
+ if (!docDataModel || docRanges.length === 0)
2569
+ return [];
2570
+ const segmentId = docRanges[0].segmentId, paragraphs = (_b = (_a23 = docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody()) == null ? void 0 : _a23.paragraphs) != null ? _b : [];
2571
+ return (_c = getParagraphsInRanges(docRanges, paragraphs)) != null ? _c : [];
2572
+ }, "useCurrentParagraph"), useFirstParagraphHorizontalAlign = /* @__PURE__ */ __name((paragraph, defaultValue) => {
2573
+ const commandService = useDependency(ICommandService), [horizontalAlign, _horizontalAlignSet] = useState(() => {
2574
+ var _a23, _b;
2575
+ const firstParagraph = paragraph[0];
2576
+ return firstParagraph ? String((_b = (_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.horizontalAlign) != null ? _b : defaultValue) : defaultValue;
2577
+ });
2578
+ return [horizontalAlign, /* @__PURE__ */ __name((v) => (_horizontalAlignSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2579
+ horizontalAlign: Number(v)
2580
+ })), "horizontalAlignSet")];
2581
+ }, "useFirstParagraphHorizontalAlign"), useFirstParagraphIndentStart = /* @__PURE__ */ __name((paragraph) => {
2582
+ const commandService = useDependency(ICommandService), [indentStart, _indentStartSet] = useState(() => {
2583
+ var _a23;
2584
+ const firstParagraph = paragraph[0];
2585
+ return firstParagraph ? getNumberUnitValue((_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.indentStart, 0) : 0;
2586
+ });
2587
+ return [indentStart, /* @__PURE__ */ __name((v) => (_indentStartSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2588
+ indentStart: { v }
2589
+ })), "indentStartSet")];
2590
+ }, "useFirstParagraphIndentStart"), useFirstParagraphIndentEnd = /* @__PURE__ */ __name((paragraph) => {
2591
+ const commandService = useDependency(ICommandService), [indentEnd, _indentEndSet] = useState(() => {
2592
+ var _a23;
2593
+ const firstParagraph = paragraph[0];
2594
+ return firstParagraph ? getNumberUnitValue((_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.indentEnd, 0) : 0;
2595
+ });
2596
+ return [indentEnd, /* @__PURE__ */ __name((v) => (_indentEndSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2597
+ indentEnd: { v }
2598
+ })), "indentEndSet")];
2599
+ }, "useFirstParagraphIndentEnd"), useFirstParagraphIndentFirstLine = /* @__PURE__ */ __name((paragraph) => {
2600
+ const commandService = useDependency(ICommandService), [indentFirstLine, _indentFirstLineSet] = useState(() => {
2601
+ var _a23;
2602
+ const firstParagraph = paragraph[0];
2603
+ return firstParagraph ? getNumberUnitValue((_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.indentFirstLine, 0) : 0;
2604
+ });
2605
+ return [indentFirstLine, /* @__PURE__ */ __name((v) => (_indentFirstLineSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2606
+ indentFirstLine: { v }
2607
+ })), "indentFirstLineSet")];
2608
+ }, "useFirstParagraphIndentFirstLine"), useFirstParagraphIndentHanging = /* @__PURE__ */ __name((paragraph) => {
2609
+ const commandService = useDependency(ICommandService), [hanging, _hangingSet] = useState(() => {
2610
+ var _a23;
2611
+ const firstParagraph = paragraph[0];
2612
+ return firstParagraph ? getNumberUnitValue((_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.hanging, 0) : 0;
2613
+ });
2614
+ return [hanging, /* @__PURE__ */ __name((v) => (_hangingSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2615
+ hanging: { v }
2616
+ })), "hangingSet")];
2617
+ }, "useFirstParagraphIndentHanging"), useFirstParagraphIndentSpaceAbove = /* @__PURE__ */ __name((paragraph) => {
2618
+ const commandService = useDependency(ICommandService), [spaceAbove, _spaceAboveSet] = useState(() => {
2619
+ var _a23;
2620
+ const firstParagraph = paragraph[0];
2621
+ return firstParagraph ? getNumberUnitValue((_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.spaceAbove, 0) : 0;
2622
+ });
2623
+ return [spaceAbove, /* @__PURE__ */ __name((v) => (_spaceAboveSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2624
+ spaceAbove: { v }
2625
+ })), "spaceAboveSet")];
2626
+ }, "useFirstParagraphIndentSpaceAbove"), useFirstParagraphSpaceBelow = /* @__PURE__ */ __name((paragraph) => {
2627
+ const commandService = useDependency(ICommandService), [spaceBelow, _spaceBelowSet] = useState(() => {
2628
+ var _a23;
2629
+ const firstParagraph = paragraph[0];
2630
+ return firstParagraph ? getNumberUnitValue((_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.spaceBelow, 0) : 0;
2631
+ });
2632
+ return [spaceBelow, /* @__PURE__ */ __name((v) => (_spaceBelowSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2633
+ spaceBelow: { v }
2634
+ })), "spaceBelowSet")];
2635
+ }, "useFirstParagraphSpaceBelow"), useFirstParagraphLineSpacing = /* @__PURE__ */ __name((paragraph) => {
2636
+ const commandService = useDependency(ICommandService), [lineSpacing, _lineSpacingSet] = useState(() => {
2637
+ var _a23, _b;
2638
+ const firstParagraph = paragraph[0];
2639
+ return firstParagraph && (_b = (_a23 = firstParagraph.paragraphStyle) == null ? void 0 : _a23.lineSpacing) != null ? _b : 1;
2640
+ });
2641
+ return [lineSpacing, /* @__PURE__ */ __name((v) => (_lineSpacingSet(v), commandService.executeCommand(DocParagraphSettingCommand.id, {
2642
+ lineSpacing: v
2643
+ })), "lineSpacingSet")];
2644
+ }, "useFirstParagraphLineSpacing"), paragraphSettingIconList = "univer-paragraph-setting-icon-list", paragraphSettingIconListItem = "univer-paragraph-setting-icon-list-item", paragraphSettingIconListActive = "univer-paragraph-setting-icon-list-active", paragraphSettingTitle = "univer-paragraph-setting-title", paragraphSettingLabel = "univer-paragraph-setting-label", paragraphSettingMtBase = "univer-paragraph-setting-mt-base", paragraphSettingFlexCol = "univer-paragraph-setting-flex-col", styles$1 = {
2645
+ paragraphSettingIconList,
2646
+ paragraphSettingIconListItem,
2647
+ paragraphSettingIconListActive,
2648
+ paragraphSettingTitle,
2649
+ paragraphSettingLabel,
2650
+ paragraphSettingMtBase,
2651
+ paragraphSettingFlexCol
2652
+ }, AutoFocusInputNumber = /* @__PURE__ */ __name((props) => {
2653
+ const { value, onChange, className = "", min = 0, max = 100 } = props, ref = require$$0.useRef(null);
2654
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(
2655
+ InputNumber,
2656
+ {
2657
+ ref,
2658
+ min,
2659
+ max,
2660
+ value,
2661
+ onChange: /* @__PURE__ */ __name((v) => {
2662
+ onChange(v != null ? v : 0).finally(() => {
2663
+ setTimeout(() => {
2664
+ var _a23;
2665
+ (_a23 = ref.current) == null || _a23.focus();
2666
+ }, 2);
2667
+ });
2668
+ }, "onChange"),
2669
+ className
2670
+ }
2671
+ );
2672
+ }, "AutoFocusInputNumber");
2673
+ function ParagraphSetting() {
2674
+ const localeService = useDependency(LocaleService), alignmentOptions = useMemo(
2675
+ () => [
2676
+ { label: localeService.t("toolbar.alignLeft"), value: String(HorizontalAlign.LEFT), icon: /* @__PURE__ */ jsxRuntimeExports.jsx(LeftJustifyingSingle, {}) },
2677
+ { label: localeService.t("toolbar.alignCenter"), value: String(HorizontalAlign.CENTER), icon: /* @__PURE__ */ jsxRuntimeExports.jsx(HorizontallySingle, {}) },
2678
+ { label: localeService.t("toolbar.alignRight"), value: String(HorizontalAlign.RIGHT), icon: /* @__PURE__ */ jsxRuntimeExports.jsx(RightJustifyingSingle, {}) },
2679
+ { label: localeService.t("toolbar.alignJustify"), value: String(HorizontalAlign.JUSTIFIED), icon: /* @__PURE__ */ jsxRuntimeExports.jsx(AlignTextBothSingle, {}) }
2680
+ ],
2681
+ []
2682
+ ), currentParagraph = useCurrentParagraph(), [horizontalAlignValue, horizontalAlignSet] = useFirstParagraphHorizontalAlign(currentParagraph, alignmentOptions[0].value), [indentStart, indentStartSet] = useFirstParagraphIndentStart(currentParagraph), [indentEnd, indentEndSet] = useFirstParagraphIndentEnd(currentParagraph), [indentFirstLine, indentFirstLineSet] = useFirstParagraphIndentFirstLine(currentParagraph), [hanging, hangingSet] = useFirstParagraphIndentHanging(currentParagraph), [spaceAbove, spaceAboveSet] = useFirstParagraphIndentSpaceAbove(currentParagraph), [spaceBelow, spaceBelowSet] = useFirstParagraphSpaceBelow(currentParagraph), [lineSpacing, lineSpacingSet] = useFirstParagraphLineSpacing(currentParagraph);
2683
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSetting, children: [
2684
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$1.paragraphSettingTitle, children: localeService.t("doc.paragraphSetting.alignment") }),
2685
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: `${styles$1.paragraphSettingIconList} ${styles$1.paragraphSettingMtBase}`, children: alignmentOptions.map((item) => /* @__PURE__ */ jsxRuntimeExports.jsx(Tooltip, { title: item.label, placement: "bottom", children: /* @__PURE__ */ jsxRuntimeExports.jsx(
2686
+ "span",
2687
+ {
2688
+ className: clsx(
2689
+ styles$1.paragraphSettingIconListItem,
2690
+ { [styles$1.paragraphSettingIconListActive]: horizontalAlignValue === item.value }
2691
+ ),
2692
+ onClick: /* @__PURE__ */ __name(() => horizontalAlignSet(item.value), "onClick"),
2693
+ children: item.icon
2694
+ }
2695
+ ) }, item.value)) }),
2696
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$1.paragraphSettingTitle, children: localeService.t("doc.paragraphSetting.indentation") }),
2697
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
2698
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingFlexCol, children: [
2699
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingLabel, children: [
2700
+ localeService.t("doc.paragraphSetting.left"),
2701
+ "(px)"
2702
+ ] }),
2703
+ /* @__PURE__ */ jsxRuntimeExports.jsx(AutoFocusInputNumber, { className: styles$1.paragraphSettingMtBase, value: indentStart, onChange: /* @__PURE__ */ __name((v) => indentStartSet(v != null ? v : 0), "onChange") })
2704
+ ] }),
2705
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingFlexCol, children: [
2706
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingLabel, children: [
2707
+ localeService.t("doc.paragraphSetting.right"),
2708
+ "(px)"
2709
+ ] }),
2710
+ /* @__PURE__ */ jsxRuntimeExports.jsx(AutoFocusInputNumber, { className: styles$1.paragraphSettingMtBase, value: indentEnd, onChange: /* @__PURE__ */ __name((v) => indentEndSet(v != null ? v : 0), "onChange") })
2711
+ ] }),
2712
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingFlexCol, children: [
2713
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingLabel, children: [
2714
+ localeService.t("doc.paragraphSetting.firstLine"),
2715
+ "(px)"
2716
+ ] }),
2717
+ /* @__PURE__ */ jsxRuntimeExports.jsx(AutoFocusInputNumber, { className: styles$1.paragraphSettingMtBase, value: indentFirstLine, onChange: /* @__PURE__ */ __name((v) => indentFirstLineSet(v != null ? v : 0), "onChange") })
2718
+ ] }),
2719
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingFlexCol, children: [
2720
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingLabel, children: [
2721
+ localeService.t("doc.paragraphSetting.hanging"),
2722
+ "(px)"
2723
+ ] }),
2724
+ /* @__PURE__ */ jsxRuntimeExports.jsx(AutoFocusInputNumber, { className: styles$1.paragraphSettingMtBase, value: hanging, onChange: /* @__PURE__ */ __name((v) => hangingSet(v != null ? v : 0), "onChange") })
2725
+ ] })
2726
+ ] }),
2727
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$1.paragraphSettingTitle, children: localeService.t("doc.paragraphSetting.spacing") }),
2728
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
2729
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingFlexCol, children: [
2730
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingLabel, children: [
2731
+ localeService.t("doc.paragraphSetting.before"),
2732
+ "(px)"
2733
+ ] }),
2734
+ /* @__PURE__ */ jsxRuntimeExports.jsx(AutoFocusInputNumber, { className: styles$1.paragraphSettingMtBase, value: spaceAbove, onChange: /* @__PURE__ */ __name((v) => spaceAboveSet(v != null ? v : 0), "onChange") })
2735
+ ] }),
2736
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingFlexCol, children: [
2737
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingLabel, children: [
2738
+ localeService.t("doc.paragraphSetting.after"),
2739
+ "(px)"
2740
+ ] }),
2741
+ /* @__PURE__ */ jsxRuntimeExports.jsx(AutoFocusInputNumber, { className: styles$1.paragraphSettingMtBase, value: spaceBelow, onChange: /* @__PURE__ */ __name((v) => spaceBelowSet(v != null ? v : 0), "onChange") })
2742
+ ] }),
2743
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles$1.paragraphSettingFlexCol, children: [
2744
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: styles$1.paragraphSettingLabel, children: localeService.t("doc.paragraphSetting.lineSpace") }),
2745
+ /* @__PURE__ */ jsxRuntimeExports.jsx(AutoFocusInputNumber, { min: 1, max: 5, className: styles$1.paragraphSettingMtBase, value: lineSpacing, onChange: /* @__PURE__ */ __name((v) => lineSpacingSet(v != null ? v : 0), "onChange") })
2746
+ ] })
2747
+ ] })
2748
+ ] });
2749
+ }
2750
+ __name(ParagraphSetting, "ParagraphSetting");
2751
+ const isRangesEqual = /* @__PURE__ */ __name((oldRanges, ranges) => ranges.length === oldRanges.length && oldRanges.some((oldRange) => ranges.some((range) => range.startOffset === oldRange.startOffset && range.endOffset === oldRange.endOffset)), "isRangesEqual"), isRangesIntersection = /* @__PURE__ */ __name((oldRanges, ranges) => oldRanges.some((oldRange) => ranges.some((range) => {
2752
+ const { startOffset: activeStart, endOffset: activeEnd } = oldRange, { startOffset: compareStart, endOffset: compareEnd } = range;
2753
+ return activeStart == null || activeEnd == null || compareStart == null || compareEnd == null ? !1 : activeStart <= compareEnd && activeEnd >= compareStart;
2754
+ })), "isRangesIntersection");
2755
+ function ParagraphSettingIndex() {
2756
+ const commandService = useDependency(ICommandService), localeService = useDependency(LocaleService), currentLocale = useObservable(localeService.currentLocale$), [key, keySet] = useState(""), rangeRef = useRef([]);
2757
+ return useEffect(() => {
2758
+ const dispose = commandService.onCommandExecuted((info) => {
2759
+ var _a23;
2760
+ if (SetTextSelectionsOperation.id === info.id) {
2761
+ const ranges = info.params.ranges;
2762
+ isRangesEqual(ranges, rangeRef.current) || keySet(generateRandomId(4)), rangeRef.current = ranges;
2763
+ }
2764
+ if (RichTextEditingMutation.id === info.id) {
2765
+ const params = info.params, ranges = (_a23 = params.textRanges) != null ? _a23 : [];
2766
+ params.trigger !== DocParagraphSettingCommand.id && isRangesIntersection(ranges, rangeRef.current) && keySet(generateRandomId(4));
2767
+ }
2768
+ });
2769
+ return () => dispose.dispose();
2770
+ }, []), useEffect(() => {
2771
+ keySet(generateRandomId(4));
2772
+ }, [currentLocale]), /* @__PURE__ */ jsxRuntimeExports.jsx(ParagraphSetting, {}, key);
2773
+ }
2774
+ __name(ParagraphSettingIndex, "ParagraphSettingIndex");
2775
+ var __defProp$g = Object.defineProperty, __getOwnPropDesc$g = Object.getOwnPropertyDescriptor, __decorateClass$g = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2776
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$g(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2777
+ (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2778
+ return kind && result && __defProp$g(target, key, result), result;
2779
+ }, "__decorateClass$g"), __decorateParam$g = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$g");
2780
+ const paragraphSettingIndexKey = "doc_ui_paragraph-setting-panel";
2781
+ var _a6;
2782
+ let DocParagraphSettingController = (_a6 = class extends Disposable {
2783
+ constructor(_commandService, _componentManager, _sidebarService) {
2784
+ super(), this._commandService = _commandService, this._componentManager = _componentManager, this._sidebarService = _sidebarService, this._init();
2785
+ }
2786
+ _init() {
2787
+ this.disposeWithMe(this._componentManager.register(paragraphSettingIndexKey, ParagraphSettingIndex));
2788
+ }
2789
+ openPanel() {
2790
+ const props = {
2791
+ header: { title: "doc.slider.paragraphSetting" },
2792
+ children: {
2793
+ label: paragraphSettingIndexKey
2794
+ },
2795
+ width: 300
2796
+ };
2797
+ this._sidebarService.open(props);
2798
+ }
2799
+ }, __name(_a6, "DocParagraphSettingController"), _a6);
2800
+ DocParagraphSettingController = __decorateClass$g([
2801
+ OnLifecycle(LifecycleStages.Rendered, DocParagraphSettingController),
2802
+ __decorateParam$g(0, ICommandService),
2803
+ __decorateParam$g(1, Inject(ComponentManager)),
2804
+ __decorateParam$g(2, Inject(ISidebarService))
2805
+ ], DocParagraphSettingController);
2806
+ const DocParagraphSettingPanelOperation = {
2807
+ id: "sidebar.operation.doc-paragraph-setting-panel",
2808
+ type: CommandType.OPERATION,
2809
+ handler: /* @__PURE__ */ __name((accessor) => (accessor.get(DocParagraphSettingController).openPanel(), !0), "handler")
1952
2810
  }, getDisableOnCollapsedObservable = /* @__PURE__ */ __name((accessor) => {
1953
2811
  const textSelectionManagerService = accessor.get(TextSelectionManagerService);
1954
2812
  return new Observable((subscriber) => {
1955
- const observable = textSelectionManagerService.textSelection$.subscribe((selections) => {
1956
- const range = textSelectionManagerService.getActiveRange();
2813
+ const observable = textSelectionManagerService.textSelection$.subscribe(() => {
2814
+ const range = textSelectionManagerService.getActiveTextRangeWithStyle();
1957
2815
  range && !range.collapsed ? subscriber.next(!1) : subscriber.next(!0);
1958
2816
  });
1959
2817
  return () => observable.unsubscribe();
1960
2818
  });
1961
- }, "getDisableOnCollapsedObservable"), CopyMenuFactory = /* @__PURE__ */ __name((accessor) => ({
1962
- id: DocCopyCommand.id,
2819
+ }, "getDisableOnCollapsedObservable");
2820
+ function inSameTable(rectRanges) {
2821
+ if (rectRanges.length < 2)
2822
+ return !0;
2823
+ const tableIds = rectRanges.map((rectRange) => rectRange.tableId);
2824
+ return tableIds.every((tableId) => tableId === tableIds[0]);
2825
+ }
2826
+ __name(inSameTable, "inSameTable");
2827
+ const getDisableWhenSelectionNotInTableObservable = /* @__PURE__ */ __name((accessor) => {
2828
+ const textSelectionManagerService = accessor.get(TextSelectionManagerService), univerInstanceService = accessor.get(IUniverInstanceService);
2829
+ return new Observable((subscriber) => {
2830
+ const observable = textSelectionManagerService.textSelection$.subscribe(() => {
2831
+ var _a23;
2832
+ const rectRanges = textSelectionManagerService.getCurrentRectRanges(), activeRange = textSelectionManagerService.getActiveTextRangeWithStyle();
2833
+ if (rectRanges && rectRanges.length && inSameTable(rectRanges)) {
2834
+ subscriber.next(!1);
2835
+ return;
2836
+ }
2837
+ if (activeRange && (rectRanges == null || rectRanges.length === 0)) {
2838
+ const { segmentId, startOffset, endOffset } = activeRange, docDataModel = univerInstanceService.getCurrentUniverDocInstance(), tables = (_a23 = docDataModel == null ? void 0 : docDataModel.getSelfOrHeaderFooterModel(segmentId).getBody()) == null ? void 0 : _a23.tables;
2839
+ if (tables && tables.length && tables.some((table) => {
2840
+ const { startIndex, endIndex } = table;
2841
+ return startOffset > startIndex && startOffset < endIndex || endOffset > startIndex && endOffset < endIndex;
2842
+ })) {
2843
+ subscriber.next(!1);
2844
+ return;
2845
+ }
2846
+ }
2847
+ subscriber.next(!0);
2848
+ });
2849
+ return () => observable.unsubscribe();
2850
+ });
2851
+ }, "getDisableWhenSelectionNotInTableObservable"), CopyMenuFactory = /* @__PURE__ */ __name((accessor) => ({
2852
+ id: DocCopyCommand.name,
2853
+ commandId: DocCopyCommand.id,
1963
2854
  group: MenuGroup.CONTEXT_MENU_FORMAT,
1964
2855
  type: MenuItemType.BUTTON,
1965
2856
  icon: "Copy",
@@ -1967,7 +2858,14 @@ const DOC_CLIPBOARD_PRIORITY = 999, DocCopyCommand = {
1967
2858
  positions: [MenuPosition.CONTEXT_MENU],
1968
2859
  disabled$: getDisableOnCollapsedObservable(accessor),
1969
2860
  hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
1970
- }), "CopyMenuFactory"), CutMenuFactory = /* @__PURE__ */ __name((accessor) => ({
2861
+ }), "CopyMenuFactory"), ParagraphSettingMenuFactory = /* @__PURE__ */ __name((accessor) => ({
2862
+ id: DocParagraphSettingPanelOperation.id,
2863
+ type: MenuItemType.BUTTON,
2864
+ icon: "MenuSingle24",
2865
+ title: "doc.menu.paragraphSetting",
2866
+ positions: [MenuPosition.CONTEXT_MENU],
2867
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2868
+ }), "ParagraphSettingMenuFactory"), CutMenuFactory = /* @__PURE__ */ __name((accessor) => ({
1971
2869
  id: DocCutCommand.id,
1972
2870
  group: MenuGroup.CONTEXT_MENU_FORMAT,
1973
2871
  type: MenuItemType.BUTTON,
@@ -1980,85 +2878,146 @@ const DOC_CLIPBOARD_PRIORITY = 999, DocCopyCommand = {
1980
2878
  id: DocPasteCommand.id,
1981
2879
  group: MenuGroup.CONTEXT_MENU_FORMAT,
1982
2880
  type: MenuItemType.BUTTON,
1983
- icon: "PasteSpecial",
1984
- title: "rightClick.paste",
1985
- positions: [MenuPosition.CONTEXT_MENU],
1986
- hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
1987
- }), "PasteMenuFactory"), DeleteMenuFactory = /* @__PURE__ */ __name((accessor) => ({
1988
- id: DeleteLeftCommand.id,
1989
- group: MenuGroup.CONTEXT_MENU_FORMAT,
1990
- type: MenuItemType.BUTTON,
1991
- icon: "PasteSpecial",
1992
- title: "rightClick.delete",
1993
- positions: [MenuPosition.CONTEXT_MENU],
1994
- disabled$: getDisableOnCollapsedObservable(accessor),
1995
- hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
1996
- }), "DeleteMenuFactory"), BoldShortCut = {
1997
- id: SetInlineFormatBoldCommand.id,
1998
- binding: KeyCode.B | MetaKeys.CTRL_COMMAND,
1999
- preconditions: whenDocAndEditorFocused
2000
- }, ItalicShortCut = {
2001
- id: SetInlineFormatItalicCommand.id,
2002
- binding: KeyCode.I | MetaKeys.CTRL_COMMAND,
2003
- preconditions: whenDocAndEditorFocused
2004
- }, UnderlineShortCut = {
2005
- id: SetInlineFormatUnderlineCommand.id,
2006
- binding: KeyCode.U | MetaKeys.CTRL_COMMAND,
2007
- preconditions: whenDocAndEditorFocused
2008
- }, StrikeThroughShortCut = {
2009
- id: SetInlineFormatStrikethroughCommand.id,
2010
- binding: KeyCode.X | MetaKeys.SHIFT | MetaKeys.CTRL_COMMAND,
2011
- preconditions: whenDocAndEditorFocused
2012
- }, SubscriptShortCut = {
2013
- id: SetInlineFormatSubscriptCommand.id,
2014
- binding: KeyCode.COMMA | MetaKeys.CTRL_COMMAND,
2015
- preconditions: whenDocAndEditorFocused
2016
- }, SuperscriptShortCut = {
2017
- id: SetInlineFormatSuperscriptCommand.id,
2018
- binding: KeyCode.PERIOD | MetaKeys.CTRL_COMMAND,
2019
- preconditions: whenDocAndEditorFocused
2020
- }, AlignLeftShortCut = {
2021
- id: AlignLeftCommand.id,
2022
- binding: KeyCode.L | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
2023
- preconditions: whenDocAndEditorFocused
2024
- }, AlignRightShortCut = {
2025
- id: AlignRightCommand.id,
2026
- binding: KeyCode.R | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
2027
- preconditions: whenDocAndEditorFocused
2028
- }, AlignCenterShortCut = {
2029
- id: AlignCenterCommand.id,
2030
- binding: KeyCode.E | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
2031
- preconditions: whenDocAndEditorFocused
2032
- }, AlignJustifyShortCut = {
2033
- id: AlignJustifyCommand.id,
2034
- binding: KeyCode.J | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
2035
- preconditions: whenDocAndEditorFocused
2036
- }, OrderListShortCut = {
2037
- id: OrderListCommand.id,
2038
- binding: KeyCode.Digit7 | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
2039
- preconditions: whenDocAndEditorFocused
2040
- }, BulletListShortCut = {
2041
- id: BulletListCommand.id,
2042
- binding: KeyCode.Digit8 | MetaKeys.CTRL_COMMAND | MetaKeys.SHIFT,
2043
- preconditions: whenDocAndEditorFocused
2044
- };
2045
- var __defProp$c = Object.defineProperty, __getOwnPropDesc$c = Object.getOwnPropertyDescriptor, __decorateClass$c = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2046
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$c(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2881
+ icon: "PasteSpecial",
2882
+ title: "rightClick.paste",
2883
+ positions: [MenuPosition.CONTEXT_MENU],
2884
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2885
+ }), "PasteMenuFactory"), DeleteMenuFactory = /* @__PURE__ */ __name((accessor) => ({
2886
+ id: DeleteLeftCommand.id,
2887
+ group: MenuGroup.CONTEXT_MENU_FORMAT,
2888
+ type: MenuItemType.BUTTON,
2889
+ icon: "PasteSpecial",
2890
+ title: "rightClick.delete",
2891
+ positions: [MenuPosition.CONTEXT_MENU],
2892
+ disabled$: getDisableOnCollapsedObservable(accessor),
2893
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2894
+ }), "DeleteMenuFactory"), TABLE_INSERT_MENU_ID = "doc.menu.table-insert";
2895
+ function TableInsertMenuItemFactory(accessor) {
2896
+ return {
2897
+ id: TABLE_INSERT_MENU_ID,
2898
+ group: MenuGroup.CONTEXT_MENU_LAYOUT,
2899
+ type: MenuItemType.SUBITEMS,
2900
+ title: "table.insert",
2901
+ icon: "Insert",
2902
+ positions: [MenuPosition.CONTEXT_MENU],
2903
+ hidden$: combineLatest(getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC), getDisableWhenSelectionNotInTableObservable(accessor), (one, two) => one || two)
2904
+ };
2905
+ }
2906
+ __name(TableInsertMenuItemFactory, "TableInsertMenuItemFactory");
2907
+ function InsertRowBeforeMenuItemFactory(accessor) {
2908
+ return {
2909
+ id: DocTableInsertRowAboveCommand.id,
2910
+ type: MenuItemType.BUTTON,
2911
+ title: "table.insertRowAbove",
2912
+ icon: "InsertRowAbove",
2913
+ positions: [TABLE_INSERT_MENU_ID],
2914
+ disabled$: getDisableWhenSelectionNotInTableObservable(accessor),
2915
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2916
+ };
2917
+ }
2918
+ __name(InsertRowBeforeMenuItemFactory, "InsertRowBeforeMenuItemFactory");
2919
+ function InsertRowAfterMenuItemFactory(accessor) {
2920
+ return {
2921
+ id: DocTableInsertRowBellowCommand.id,
2922
+ type: MenuItemType.BUTTON,
2923
+ positions: [TABLE_INSERT_MENU_ID],
2924
+ title: "table.insertRowBelow",
2925
+ icon: "InsertRowBelow",
2926
+ disabled$: getDisableWhenSelectionNotInTableObservable(accessor),
2927
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2928
+ };
2929
+ }
2930
+ __name(InsertRowAfterMenuItemFactory, "InsertRowAfterMenuItemFactory");
2931
+ function InsertColumnLeftMenuItemFactory(accessor) {
2932
+ return {
2933
+ id: DocTableInsertColumnLeftCommand.id,
2934
+ type: MenuItemType.BUTTON,
2935
+ title: "table.insertColumnLeft",
2936
+ icon: "LeftInsertColumn",
2937
+ positions: [TABLE_INSERT_MENU_ID],
2938
+ disabled$: getDisableWhenSelectionNotInTableObservable(accessor),
2939
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2940
+ };
2941
+ }
2942
+ __name(InsertColumnLeftMenuItemFactory, "InsertColumnLeftMenuItemFactory");
2943
+ function InsertColumnRightMenuItemFactory(accessor) {
2944
+ return {
2945
+ id: DocTableInsertColumnRightCommand.id,
2946
+ type: MenuItemType.BUTTON,
2947
+ positions: [TABLE_INSERT_MENU_ID],
2948
+ title: "table.insertColumnRight",
2949
+ icon: "RightInsertColumn",
2950
+ disabled$: getDisableWhenSelectionNotInTableObservable(accessor),
2951
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2952
+ };
2953
+ }
2954
+ __name(InsertColumnRightMenuItemFactory, "InsertColumnRightMenuItemFactory");
2955
+ const TABLE_DELETE_MENU_ID = "doc.menu.table-delete";
2956
+ function TableDeleteMenuItemFactory(accessor) {
2957
+ return {
2958
+ id: TABLE_DELETE_MENU_ID,
2959
+ group: MenuGroup.CONTEXT_MENU_LAYOUT,
2960
+ type: MenuItemType.SUBITEMS,
2961
+ title: "table.delete",
2962
+ icon: "Reduce",
2963
+ positions: [MenuPosition.CONTEXT_MENU],
2964
+ hidden$: combineLatest(getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC), getDisableWhenSelectionNotInTableObservable(accessor), (one, two) => one || two)
2965
+ };
2966
+ }
2967
+ __name(TableDeleteMenuItemFactory, "TableDeleteMenuItemFactory");
2968
+ function DeleteRowsMenuItemFactory(accessor) {
2969
+ return {
2970
+ id: DocTableDeleteRowsCommand.id,
2971
+ type: MenuItemType.BUTTON,
2972
+ title: "table.deleteRows",
2973
+ icon: "DeleteRow",
2974
+ positions: [TABLE_DELETE_MENU_ID],
2975
+ disabled$: getDisableWhenSelectionNotInTableObservable(accessor),
2976
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2977
+ };
2978
+ }
2979
+ __name(DeleteRowsMenuItemFactory, "DeleteRowsMenuItemFactory");
2980
+ function DeleteColumnsMenuItemFactory(accessor) {
2981
+ return {
2982
+ id: DocTableDeleteColumnsCommand.id,
2983
+ type: MenuItemType.BUTTON,
2984
+ positions: [TABLE_DELETE_MENU_ID],
2985
+ title: "table.deleteColumns",
2986
+ icon: "DeleteColumn",
2987
+ disabled$: getDisableWhenSelectionNotInTableObservable(accessor),
2988
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
2989
+ };
2990
+ }
2991
+ __name(DeleteColumnsMenuItemFactory, "DeleteColumnsMenuItemFactory");
2992
+ function DeleteTableMenuItemFactory(accessor) {
2993
+ return {
2994
+ id: DocTableDeleteTableCommand.id,
2995
+ type: MenuItemType.BUTTON,
2996
+ positions: [TABLE_DELETE_MENU_ID],
2997
+ title: "table.deleteTable",
2998
+ icon: "GridSingle",
2999
+ disabled$: getDisableWhenSelectionNotInTableObservable(accessor),
3000
+ hidden$: getMenuHiddenObservable(accessor, UniverInstanceType.UNIVER_DOC)
3001
+ };
3002
+ }
3003
+ __name(DeleteTableMenuItemFactory, "DeleteTableMenuItemFactory");
3004
+ var __defProp$f = Object.defineProperty, __getOwnPropDesc$f = Object.getOwnPropertyDescriptor, __decorateClass$f = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3005
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$f(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2047
3006
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2048
- return kind && result && __defProp$c(target, key, result), result;
2049
- }, "__decorateClass$c"), __decorateParam$c = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$c"), _a6;
2050
- let DocUIController = (_a6 = class extends Disposable {
2051
- constructor(_config, _injector, _componentManager, _layoutService, _menuService, _uiPartsService, _univerInstanceService, _shortcutService) {
2052
- super(), this._config = _config, this._injector = _injector, this._componentManager = _componentManager, this._layoutService = _layoutService, this._menuService = _menuService, this._uiPartsService = _uiPartsService, this._univerInstanceService = _univerInstanceService, this._shortcutService = _shortcutService, this._init();
3007
+ return kind && result && __defProp$f(target, key, result), result;
3008
+ }, "__decorateClass$f"), __decorateParam$f = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$f"), _a7;
3009
+ let DocUIController = (_a7 = class extends Disposable {
3010
+ constructor(_config, _injector, _componentManager, _commandService, _layoutService, _menuService, _uiPartsService, _univerInstanceService, _shortcutService) {
3011
+ super(), this._config = _config, this._injector = _injector, this._componentManager = _componentManager, this._commandService = _commandService, this._layoutService = _layoutService, this._menuService = _menuService, this._uiPartsService = _uiPartsService, this._univerInstanceService = _univerInstanceService, this._shortcutService = _shortcutService, this._init();
2053
3012
  }
2054
3013
  _initCustomComponents() {
2055
3014
  const componentManager = this._componentManager;
2056
- this.disposeWithMe(componentManager.register(COLOR_PICKER_COMPONENT, ColorPicker)), this.disposeWithMe(componentManager.register(FONT_FAMILY_COMPONENT, FontFamily)), this.disposeWithMe(componentManager.register(FONT_FAMILY_ITEM_COMPONENT, FontFamilyItem)), this.disposeWithMe(componentManager.register(FONT_SIZE_COMPONENT, FontSize));
3015
+ this.disposeWithMe(componentManager.register(COLOR_PICKER_COMPONENT, ColorPicker)), this.disposeWithMe(componentManager.register(FONT_FAMILY_COMPONENT, FontFamily)), this.disposeWithMe(componentManager.register(FONT_FAMILY_ITEM_COMPONENT, FontFamilyItem)), this.disposeWithMe(componentManager.register(FONT_SIZE_COMPONENT, FontSize)), this.disposeWithMe(componentManager.register(BULLET_LIST_TYPE_COMPONENT, BulletListTypePicker)), this.disposeWithMe(componentManager.register(ORDER_LIST_TYPE_COMPONENT, OrderListTypePicker)), this.disposeWithMe(componentManager.register("TodoList", TodoList));
2057
3016
  }
2058
3017
  _initUiParts() {
2059
- var _a19, _b;
3018
+ var _a23, _b;
2060
3019
  const workbook = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
2061
- (_b = (_a19 = this._config.layout) == null ? void 0 : _a19.docContainerConfig) != null && _b.footer && !workbook && this.disposeWithMe(this._uiPartsService.registerComponent(BuiltInUIPart.FOOTER, () => connectInjector(DocFooter, this._injector)));
3020
+ (_b = (_a23 = this._config.layout) == null ? void 0 : _a23.docContainerConfig) != null && _b.footer && !workbook && this.disposeWithMe(this._uiPartsService.registerComponent(BuiltInUIPart.FOOTER, () => connectInjector(DocFooter, this._injector)));
2062
3021
  }
2063
3022
  _initMenus() {
2064
3023
  const { menu = {} } = this._config;
@@ -2073,12 +3032,15 @@ let DocUIController = (_a6 = class extends Disposable {
2073
3032
  FontFamilySelectorMenuItemFactory,
2074
3033
  TextColorSelectorMenuItemFactory,
2075
3034
  HeaderFooterMenuItemFactory,
3035
+ TableMenuFactory,
3036
+ InsertTableMenuFactory,
2076
3037
  AlignLeftMenuItemFactory,
2077
3038
  AlignCenterMenuItemFactory,
2078
3039
  AlignRightMenuItemFactory,
2079
3040
  AlignJustifyMenuItemFactory,
2080
3041
  OrderListMenuItemFactory,
2081
3042
  BulletListMenuItemFactory,
3043
+ CheckListMenuItemFactory,
2082
3044
  ResetBackgroundColorMenuItemFactory,
2083
3045
  BackgroundColorSelectorMenuItemFactory
2084
3046
  ].forEach((factory) => {
@@ -2087,7 +3049,17 @@ let DocUIController = (_a6 = class extends Disposable {
2087
3049
  CopyMenuFactory,
2088
3050
  CutMenuFactory,
2089
3051
  PasteMenuFactory,
2090
- DeleteMenuFactory
3052
+ DeleteMenuFactory,
3053
+ ParagraphSettingMenuFactory,
3054
+ TableInsertMenuItemFactory,
3055
+ InsertRowBeforeMenuItemFactory,
3056
+ InsertRowAfterMenuItemFactory,
3057
+ InsertColumnLeftMenuItemFactory,
3058
+ InsertColumnRightMenuItemFactory,
3059
+ TableDeleteMenuItemFactory,
3060
+ DeleteRowsMenuItemFactory,
3061
+ DeleteColumnsMenuItemFactory,
3062
+ DeleteTableMenuItemFactory
2091
3063
  ].forEach((factory) => {
2092
3064
  try {
2093
3065
  this.disposeWithMe(this._menuService.addMenuItem(this._injector.invoke(factory), menu));
@@ -2108,13 +3080,21 @@ let DocUIController = (_a6 = class extends Disposable {
2108
3080
  AlignRightShortCut,
2109
3081
  AlignLeftShortCut,
2110
3082
  OrderListShortCut,
2111
- BulletListShortCut
3083
+ BulletListShortCut,
3084
+ TabShortCut
2112
3085
  ].forEach((shortcut) => {
2113
3086
  this.disposeWithMe(this._shortcutService.registerShortcut(shortcut));
2114
3087
  });
2115
3088
  }
2116
3089
  _init() {
2117
- this._initCustomComponents(), this._initMenus(), this._initFocusHandler(), this._initUiParts(), this._initShortCut();
3090
+ this._initCustomComponents(), this._initMenus(), this._initFocusHandler(), this._initCommands(), this._initUiParts(), this._initShortCut();
3091
+ }
3092
+ _initCommands() {
3093
+ [
3094
+ CoreHeaderFooterCommand,
3095
+ OpenHeaderFooterPanelCommand,
3096
+ SidebarDocHeaderFooterPanelOperation
3097
+ ].forEach((command) => this.disposeWithMe(this._commandService.registerCommand(command)));
2118
3098
  }
2119
3099
  _initFocusHandler() {
2120
3100
  this.disposeWithMe(
@@ -2123,19 +3103,20 @@ let DocUIController = (_a6 = class extends Disposable {
2123
3103
  })
2124
3104
  );
2125
3105
  }
2126
- }, __name(_a6, "DocUIController"), _a6);
2127
- DocUIController = __decorateClass$c([
3106
+ }, __name(_a7, "DocUIController"), _a7);
3107
+ DocUIController = __decorateClass$f([
2128
3108
  OnLifecycle(LifecycleStages.Rendered, DocUIController),
2129
- __decorateParam$c(1, Inject(Injector)),
2130
- __decorateParam$c(2, Inject(ComponentManager)),
2131
- __decorateParam$c(3, ILayoutService),
2132
- __decorateParam$c(4, IMenuService),
2133
- __decorateParam$c(5, IUIPartsService),
2134
- __decorateParam$c(6, IUniverInstanceService),
2135
- __decorateParam$c(7, IShortcutService)
3109
+ __decorateParam$f(1, Inject(Injector)),
3110
+ __decorateParam$f(2, Inject(ComponentManager)),
3111
+ __decorateParam$f(3, ICommandService),
3112
+ __decorateParam$f(4, ILayoutService),
3113
+ __decorateParam$f(5, IMenuService),
3114
+ __decorateParam$f(6, IUIPartsService),
3115
+ __decorateParam$f(7, IUniverInstanceService),
3116
+ __decorateParam$f(8, IShortcutService)
2136
3117
  ], DocUIController);
2137
3118
  const BreakLineShortcut = {
2138
- id: BreakLineCommand.id,
3119
+ id: EnterCommand.id,
2139
3120
  preconditions: whenDocAndEditorFocusedWithBreakLine,
2140
3121
  binding: KeyCode.ENTER
2141
3122
  }, DeleteLeftShortcut = {
@@ -2147,12 +3128,12 @@ const BreakLineShortcut = {
2147
3128
  preconditions: whenDocAndEditorFocused,
2148
3129
  binding: KeyCode.DELETE
2149
3130
  };
2150
- var __defProp$b = Object.defineProperty, __getOwnPropDesc$b = Object.getOwnPropertyDescriptor, __decorateClass$b = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2151
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$b(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3131
+ var __defProp$e = Object.defineProperty, __getOwnPropDesc$e = Object.getOwnPropertyDescriptor, __decorateClass$e = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3132
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$e(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2152
3133
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2153
- return kind && result && __defProp$b(target, key, result), result;
2154
- }, "__decorateClass$b"), __decorateParam$b = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$b"), _a7;
2155
- let DocClipboardController = (_a7 = class extends RxDisposable {
3134
+ return kind && result && __defProp$e(target, key, result), result;
3135
+ }, "__decorateClass$e"), __decorateParam$e = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$e"), _a8;
3136
+ let DocClipboardController = (_a8 = class extends RxDisposable {
2156
3137
  constructor(_commandService, _clipboardInterfaceService, _docClipboardService, _textSelectionRenderManager, _contextService) {
2157
3138
  super(), this._commandService = _commandService, this._clipboardInterfaceService = _clipboardInterfaceService, this._docClipboardService = _docClipboardService, this._textSelectionRenderManager = _textSelectionRenderManager, this._contextService = _contextService, this._init();
2158
3139
  }
@@ -2160,31 +3141,31 @@ let DocClipboardController = (_a7 = class extends RxDisposable {
2160
3141
  [DocCopyCommand, DocCutCommand, DocPasteCommand].forEach((command) => this.disposeWithMe(this._commandService.registerMultipleCommand(command))), [InnerPasteCommand, CutContentCommand].forEach((command) => this.disposeWithMe(this._commandService.registerCommand(command))), this._initLegacyPasteCommand();
2161
3142
  }
2162
3143
  _initLegacyPasteCommand() {
2163
- var _a19;
2164
- (_a19 = this._textSelectionRenderManager) == null || _a19.onPaste$.pipe(takeUntil(this.dispose$)).subscribe((config) => {
2165
- var _a20, _b;
3144
+ var _a23;
3145
+ (_a23 = this._textSelectionRenderManager) == null || _a23.onPaste$.pipe(takeUntil(this.dispose$)).subscribe((config) => {
3146
+ var _a24, _b;
2166
3147
  if (!whenDocOrEditor(this._contextService))
2167
3148
  return;
2168
3149
  config.event.preventDefault();
2169
- const clipboardEvent = config.event, htmlContent = (_a20 = clipboardEvent.clipboardData) == null ? void 0 : _a20.getData("text/html"), textContent = (_b = clipboardEvent.clipboardData) == null ? void 0 : _b.getData("text/plain");
3150
+ const clipboardEvent = config.event, htmlContent = (_a24 = clipboardEvent.clipboardData) == null ? void 0 : _a24.getData("text/html"), textContent = (_b = clipboardEvent.clipboardData) == null ? void 0 : _b.getData("text/plain");
2170
3151
  this._docClipboardService.legacyPaste(htmlContent, textContent);
2171
3152
  });
2172
3153
  }
2173
- }, __name(_a7, "DocClipboardController"), _a7);
2174
- DocClipboardController = __decorateClass$b([
3154
+ }, __name(_a8, "DocClipboardController"), _a8);
3155
+ DocClipboardController = __decorateClass$e([
2175
3156
  OnLifecycle(LifecycleStages.Rendered, DocClipboardController),
2176
- __decorateParam$b(0, ICommandService),
2177
- __decorateParam$b(1, IClipboardInterfaceService),
2178
- __decorateParam$b(2, IDocClipboardService),
2179
- __decorateParam$b(3, ITextSelectionRenderManager),
2180
- __decorateParam$b(4, IContextService)
3157
+ __decorateParam$e(0, ICommandService),
3158
+ __decorateParam$e(1, IClipboardInterfaceService),
3159
+ __decorateParam$e(2, IDocClipboardService),
3160
+ __decorateParam$e(3, ITextSelectionRenderManager),
3161
+ __decorateParam$e(4, IContextService)
2181
3162
  ], DocClipboardController);
2182
- var __defProp$a = Object.defineProperty, __getOwnPropDesc$a = Object.getOwnPropertyDescriptor, __decorateClass$a = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2183
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$a(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3163
+ var __defProp$d = Object.defineProperty, __getOwnPropDesc$d = Object.getOwnPropertyDescriptor, __decorateClass$d = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3164
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$d(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2184
3165
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2185
- return kind && result && __defProp$a(target, key, result), result;
2186
- }, "__decorateClass$a"), __decorateParam$a = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$a"), _a8;
2187
- let DocEditorBridgeController = (_a8 = class extends Disposable {
3166
+ return kind && result && __defProp$d(target, key, result), result;
3167
+ }, "__decorateClass$d"), __decorateParam$d = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$d"), _a9;
3168
+ let DocEditorBridgeController = (_a9 = class extends Disposable {
2188
3169
  constructor(_univerInstanceService, _editorService, _commandService, _textSelectionRenderManager, _renderManagerService) {
2189
3170
  super();
2190
3171
  __publicField(this, "_initialEditors", /* @__PURE__ */ new Set());
@@ -2201,7 +3182,7 @@ let DocEditorBridgeController = (_a8 = class extends Disposable {
2201
3182
  }), this._commandExecutedListener(), this._initialSetValue(), this._initialBlur(), this._initialFocus(), this._initialValueChange();
2202
3183
  }
2203
3184
  _resize(unitId) {
2204
- var _a19, _b, _c;
3185
+ var _a23, _b, _c;
2205
3186
  if (unitId == null)
2206
3187
  return;
2207
3188
  const editor = this._editorService.getEditor(unitId);
@@ -2210,7 +3191,7 @@ let DocEditorBridgeController = (_a8 = class extends Disposable {
2210
3191
  const editorDataModel = this._univerInstanceService.getUniverDocInstance(unitId);
2211
3192
  if (!editorDataModel)
2212
3193
  return;
2213
- const skeleton = (_a19 = this._renderManagerService.getRenderById(editorDataModel.getUnitId())) == null ? void 0 : _a19.with(DocSkeletonManagerService).getSkeleton();
3194
+ const skeleton = (_a23 = this._renderManagerService.getRenderById(editorDataModel.getUnitId())) == null ? void 0 : _a23.with(DocSkeletonManagerService).getSkeleton();
2214
3195
  if (editor == null || editor.render == null || skeleton == null || editorDataModel == null)
2215
3196
  return;
2216
3197
  skeleton.calculate();
@@ -2239,12 +3220,12 @@ let DocEditorBridgeController = (_a8 = class extends Disposable {
2239
3220
  _initialBlur() {
2240
3221
  this.disposeWithMe(
2241
3222
  this._editorService.blur$.subscribe(() => {
2242
- this._textSelectionRenderManager.removeAllTextRanges(), this._textSelectionRenderManager.blur();
3223
+ this._textSelectionRenderManager.removeAllRanges(), this._textSelectionRenderManager.blur();
2243
3224
  })
2244
3225
  ), this.disposeWithMe(
2245
3226
  this._textSelectionRenderManager.onBlur$.subscribe(() => {
2246
- var _a19;
2247
- const unitId = (_a19 = this._univerInstanceService.getCurrentUniverDocInstance()) == null ? void 0 : _a19.getUnitId();
3227
+ var _a23;
3228
+ const unitId = (_a23 = this._univerInstanceService.getCurrentUniverDocInstance()) == null ? void 0 : _a23.getUnitId();
2248
3229
  if (unitId == null)
2249
3230
  return;
2250
3231
  const editor = this._editorService.getEditor(unitId), focusEditor = this._editorService.getFocusEditor();
@@ -2255,7 +3236,7 @@ let DocEditorBridgeController = (_a8 = class extends Disposable {
2255
3236
  _initialFocus() {
2256
3237
  this.disposeWithMe(
2257
3238
  this._editorService.focus$.subscribe((textRange) => {
2258
- this._textSelectionRenderManager.removeAllTextRanges(), this._textSelectionRenderManager.addTextRanges([textRange]);
3239
+ this._textSelectionRenderManager.removeAllRanges(), this._textSelectionRenderManager.addDocRanges([textRange]);
2259
3240
  })
2260
3241
  );
2261
3242
  const focusExcepts = [
@@ -2274,7 +3255,7 @@ let DocEditorBridgeController = (_a8 = class extends Disposable {
2274
3255
  this._editorService.changeSpreadsheetFocusState(!1);
2275
3256
  })
2276
3257
  ), this._univerInstanceService.getAllUnitsForType(UniverInstanceType.UNIVER_SHEET).forEach((unit) => {
2277
- const unitId = unit.getUnitId(), render = this._renderManagerService.getRenderById(unitId), canvasEle = render == null ? void 0 : render.engine.getCanvas().getCanvasEle();
3258
+ const unitId = unit.getUnitId(), render2 = this._renderManagerService.getRenderById(unitId), canvasEle = render2 == null ? void 0 : render2.engine.getCanvas().getCanvasEle();
2278
3259
  canvasEle != null && fromEvent(canvasEle, "mousedown").subscribe((evt) => {
2279
3260
  this._editorService.changeSpreadsheetFocusState(!0), evt.stopPropagation();
2280
3261
  });
@@ -2292,8 +3273,8 @@ let DocEditorBridgeController = (_a8 = class extends Disposable {
2292
3273
  );
2293
3274
  }
2294
3275
  _valueChange() {
2295
- var _a19;
2296
- const unitId = (_a19 = this._univerInstanceService.getCurrentUniverDocInstance()) == null ? void 0 : _a19.getUnitId();
3276
+ var _a23;
3277
+ const unitId = (_a23 = this._univerInstanceService.getCurrentUniverDocInstance()) == null ? void 0 : _a23.getUnitId();
2297
3278
  if (unitId == null)
2298
3279
  return;
2299
3280
  const editor = this._editorService.getEditor(unitId);
@@ -2315,27 +3296,27 @@ let DocEditorBridgeController = (_a8 = class extends Disposable {
2315
3296
  })
2316
3297
  );
2317
3298
  }
2318
- }, __name(_a8, "DocEditorBridgeController"), _a8);
2319
- DocEditorBridgeController = __decorateClass$a([
3299
+ }, __name(_a9, "DocEditorBridgeController"), _a9);
3300
+ DocEditorBridgeController = __decorateClass$d([
2320
3301
  OnLifecycle(LifecycleStages.Rendered, DocEditorBridgeController),
2321
- __decorateParam$a(0, IUniverInstanceService),
2322
- __decorateParam$a(1, IEditorService),
2323
- __decorateParam$a(2, ICommandService),
2324
- __decorateParam$a(3, ITextSelectionRenderManager),
2325
- __decorateParam$a(4, IRenderManagerService)
3302
+ __decorateParam$d(0, IUniverInstanceService),
3303
+ __decorateParam$d(1, IEditorService),
3304
+ __decorateParam$d(2, ICommandService),
3305
+ __decorateParam$d(3, ITextSelectionRenderManager),
3306
+ __decorateParam$d(4, IRenderManagerService)
2326
3307
  ], DocEditorBridgeController);
2327
- var __defProp$9 = Object.defineProperty, __getOwnPropDesc$9 = Object.getOwnPropertyDescriptor, __decorateClass$9 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2328
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$9(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3308
+ var __defProp$c = Object.defineProperty, __getOwnPropDesc$c = Object.getOwnPropertyDescriptor, __decorateClass$c = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3309
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$c(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2329
3310
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2330
- return kind && result && __defProp$9(target, key, result), result;
2331
- }, "__decorateClass$9"), __decorateParam$9 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$9"), _a9;
2332
- let DocRenderController = (_a9 = class extends RxDisposable {
2333
- constructor(_context, _commandService, _docSkeletonManagerService, _configService, _editorService, _renderManagerService) {
2334
- super(), this._context = _context, this._commandService = _commandService, this._docSkeletonManagerService = _docSkeletonManagerService, this._configService = _configService, this._editorService = _editorService, this._renderManagerService = _renderManagerService, this._addNewRender(), this._initRenderRefresh(), this._initCommandListener();
3311
+ return kind && result && __defProp$c(target, key, result), result;
3312
+ }, "__decorateClass$c"), __decorateParam$c = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$c"), _a10;
3313
+ let DocRenderController = (_a10 = class extends RxDisposable {
3314
+ constructor(_context, _contextService, _commandService, _docSkeletonManagerService, _configService, _editorService, _renderManagerService) {
3315
+ super(), this._context = _context, this._contextService = _contextService, this._commandService = _commandService, this._docSkeletonManagerService = _docSkeletonManagerService, this._configService = _configService, this._editorService = _editorService, this._renderManagerService = _renderManagerService, this._addNewRender(), this._initRenderRefresh(), this._initCommandListener();
2335
3316
  }
2336
3317
  reRender(unitId) {
2337
- var _a19, _b;
2338
- const docSkeletonManagerService = (_a19 = this._renderManagerService.getRenderById(unitId)) == null ? void 0 : _a19.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton();
3318
+ var _a23, _b;
3319
+ const docSkeletonManagerService = (_a23 = this._renderManagerService.getRenderById(unitId)) == null ? void 0 : _a23.with(DocSkeletonManagerService), skeleton = docSkeletonManagerService == null ? void 0 : docSkeletonManagerService.getSkeleton();
2339
3320
  if (!(!skeleton || skeleton.getViewModel().getDataModel().getSnapshot().disabled)) {
2340
3321
  if (skeleton.calculate(), this._editorService.isEditor(unitId)) {
2341
3322
  (_b = this._context.mainComponent) == null || _b.makeDirty();
@@ -2355,6 +3336,8 @@ let DocRenderController = (_a9 = class extends RxDisposable {
2355
3336
  isWheelPreventDefaultX: !0
2356
3337
  });
2357
3338
  scene.attachControl(), scene.onMouseWheel$.subscribeEvent((evt, state) => {
3339
+ if (!this._contextService.getContextValue(FOCUSING_DOC))
3340
+ return;
2358
3341
  const e = evt;
2359
3342
  if (e.ctrlKey) {
2360
3343
  const deltaFactor = Math.abs(e.deltaX);
@@ -2399,8 +3382,8 @@ let DocRenderController = (_a9 = class extends RxDisposable {
2399
3382
  }));
2400
3383
  }
2401
3384
  _recalculateSizeBySkeleton(skeleton) {
2402
- var _a19;
2403
- const { mainComponent, scene, unitId, components } = this._context, docsComponent = mainComponent, docBackground = components.get(DOCS_VIEW_KEY.BACKGROUND), pages = (_a19 = skeleton.getSkeletonData()) == null ? void 0 : _a19.pages;
3385
+ var _a23;
3386
+ const { mainComponent, scene, unitId, components } = this._context, docsComponent = mainComponent, docBackground = components.get(DOCS_VIEW_KEY.BACKGROUND), pages = (_a23 = skeleton.getSkeletonData()) == null ? void 0 : _a23.pages;
2404
3387
  if (pages == null)
2405
3388
  return;
2406
3389
  let width = 0, height = 0;
@@ -2410,21 +3393,22 @@ let DocRenderController = (_a9 = class extends RxDisposable {
2410
3393
  }
2411
3394
  docsComponent.resize(width, height), docBackground.resize(width, height), this._editorService.isEditor(unitId) || scene.resize(width, height);
2412
3395
  }
2413
- }, __name(_a9, "DocRenderController"), _a9);
2414
- DocRenderController = __decorateClass$9([
2415
- __decorateParam$9(1, ICommandService),
2416
- __decorateParam$9(2, Inject(DocSkeletonManagerService)),
2417
- __decorateParam$9(3, IConfigService),
2418
- __decorateParam$9(4, IEditorService),
2419
- __decorateParam$9(5, IRenderManagerService)
3396
+ }, __name(_a10, "DocRenderController"), _a10);
3397
+ DocRenderController = __decorateClass$c([
3398
+ __decorateParam$c(1, IContextService),
3399
+ __decorateParam$c(2, ICommandService),
3400
+ __decorateParam$c(3, Inject(DocSkeletonManagerService)),
3401
+ __decorateParam$c(4, IConfigService),
3402
+ __decorateParam$c(5, IEditorService),
3403
+ __decorateParam$c(6, IRenderManagerService)
2420
3404
  ], DocRenderController);
2421
3405
  const _DocPageLayoutService = class _DocPageLayoutService extends Disposable {
2422
3406
  constructor(_context) {
2423
3407
  super(), this._context = _context;
2424
3408
  }
2425
3409
  calculatePagePosition() {
2426
- var _a19, _b;
2427
- const docObject = neoGetDocObject(this._context), zoomRatio = (_b = (_a19 = this._context.unit.getSettings()) == null ? void 0 : _a19.zoomRatio) != null ? _b : 1, { document: docsComponent, scene, docBackground } = docObject, parent = scene == null ? void 0 : scene.getParent(), { width: docsWidth, height: docsHeight, pageMarginLeft, pageMarginTop } = docsComponent;
3410
+ var _a23, _b;
3411
+ const docObject = neoGetDocObject(this._context), zoomRatio = (_b = (_a23 = this._context.unit.getSettings()) == null ? void 0 : _a23.zoomRatio) != null ? _b : 1, { document: docsComponent, scene, docBackground } = docObject, parent = scene == null ? void 0 : scene.getParent(), { width: docsWidth, height: docsHeight, pageMarginLeft, pageMarginTop } = docsComponent;
2428
3412
  if (parent == null || docsWidth === Number.POSITIVE_INFINITY || docsHeight === Number.POSITIVE_INFINITY)
2429
3413
  return;
2430
3414
  const { width: engineWidth, height: engineHeight } = parent;
@@ -2438,17 +3422,14 @@ const _DocPageLayoutService = class _DocPageLayoutService extends Disposable {
2438
3422
  };
2439
3423
  __name(_DocPageLayoutService, "DocPageLayoutService");
2440
3424
  let DocPageLayoutService = _DocPageLayoutService;
2441
- var __defProp$8 = Object.defineProperty, __getOwnPropDesc$8 = Object.getOwnPropertyDescriptor, __decorateClass$8 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2442
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$8(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3425
+ var __defProp$b = Object.defineProperty, __getOwnPropDesc$b = Object.getOwnPropertyDescriptor, __decorateClass$b = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3426
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$b(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2443
3427
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2444
- return kind && result && __defProp$8(target, key, result), result;
2445
- }, "__decorateClass$8"), __decorateParam$8 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$8"), _a10;
2446
- let DocZoomRenderController = (_a10 = class extends Disposable {
2447
- constructor(_context, _docSkeletonManagerService, _univerInstanceService, _commandService, _textSelectionManagerService, _editorService, _docPageLayoutService) {
2448
- super(), this._context = _context, this._docSkeletonManagerService = _docSkeletonManagerService, this._univerInstanceService = _univerInstanceService, this._commandService = _commandService, this._textSelectionManagerService = _textSelectionManagerService, this._editorService = _editorService, this._docPageLayoutService = _docPageLayoutService, this._init();
2449
- }
2450
- _init() {
2451
- this._initSkeletonListener(), this._initCommandExecutedListener(), this._initRenderRefresher(), setTimeout(() => this.updateViewZoom(1, !0), 20);
3428
+ return kind && result && __defProp$b(target, key, result), result;
3429
+ }, "__decorateClass$b"), __decorateParam$b = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$b"), _a11;
3430
+ let DocZoomRenderController = (_a11 = class extends Disposable {
3431
+ constructor(_context, _contextService, _docSkeletonManagerService, _univerInstanceService, _commandService, _textSelectionManagerService, _editorService, _docPageLayoutService) {
3432
+ super(), this._context = _context, this._contextService = _contextService, this._docSkeletonManagerService = _docSkeletonManagerService, this._univerInstanceService = _univerInstanceService, this._commandService = _commandService, this._textSelectionManagerService = _textSelectionManagerService, this._editorService = _editorService, this._docPageLayoutService = _docPageLayoutService, this._initSkeletonListener(), this._initCommandExecutedListener(), this._initRenderRefresher(), setTimeout(() => this.updateViewZoom(1, !0), 20);
2452
3433
  }
2453
3434
  _initRenderRefresher() {
2454
3435
  this._docSkeletonManagerService.currentSkeleton$.subscribe((param) => {
@@ -2456,7 +3437,7 @@ let DocZoomRenderController = (_a10 = class extends Disposable {
2456
3437
  return;
2457
3438
  const { unitId, scene } = this._context;
2458
3439
  this._editorService.isEditor(unitId) || this.disposeWithMe(scene.onMouseWheel$.subscribeEvent((e) => {
2459
- if (!e.ctrlKey)
3440
+ if (!e.ctrlKey || !this._contextService.getContextValue(FOCUSING_DOC))
2460
3441
  return;
2461
3442
  const documentModel = this._univerInstanceService.getCurrentUniverDocInstance();
2462
3443
  if (!documentModel)
@@ -2486,37 +3467,33 @@ let DocZoomRenderController = (_a10 = class extends Disposable {
2486
3467
  _initCommandExecutedListener() {
2487
3468
  const updateCommandList = [SetDocZoomRatioOperation.id];
2488
3469
  this.disposeWithMe(this._commandService.onCommandExecuted((command) => {
2489
- if (updateCommandList.includes(command.id)) {
2490
- const documentModel = this._univerInstanceService.getCurrentUniverDocInstance();
2491
- if (!documentModel) return;
2492
- const params = command.params, { unitId } = params;
2493
- if (unitId !== documentModel.getUnitId())
2494
- return;
2495
- const zoomRatio = documentModel.zoomRatio || 1;
3470
+ if (updateCommandList.includes(command.id) && command.params.unitId === this._context.unitId) {
3471
+ const zoomRatio = this._context.unit.zoomRatio || 1;
2496
3472
  this.updateViewZoom(zoomRatio);
2497
3473
  }
2498
3474
  }));
2499
3475
  }
2500
3476
  updateViewZoom(zoomRatio, needRefreshSelection = !0) {
2501
- var _a19;
3477
+ var _a23;
2502
3478
  const docObject = neoGetDocObject(this._context);
2503
- docObject.scene.scale(zoomRatio, zoomRatio), this._docPageLayoutService.calculatePagePosition(), needRefreshSelection && !this._editorService.isEditor(this._context.unitId) && this._textSelectionManagerService.refreshSelection(), (_a19 = docObject.scene.getTransformer()) == null || _a19.clearSelectedObjects();
2504
- }
2505
- }, __name(_a10, "DocZoomRenderController"), _a10);
2506
- DocZoomRenderController = __decorateClass$8([
2507
- __decorateParam$8(1, Inject(DocSkeletonManagerService)),
2508
- __decorateParam$8(2, IUniverInstanceService),
2509
- __decorateParam$8(3, ICommandService),
2510
- __decorateParam$8(4, Inject(TextSelectionManagerService)),
2511
- __decorateParam$8(5, IEditorService),
2512
- __decorateParam$8(6, Inject(DocPageLayoutService))
3479
+ docObject.scene.scale(zoomRatio, zoomRatio), this._docPageLayoutService.calculatePagePosition(), needRefreshSelection && !this._editorService.isEditor(this._context.unitId) && this._textSelectionManagerService.refreshSelection(), (_a23 = docObject.scene.getTransformer()) == null || _a23.clearSelectedObjects();
3480
+ }
3481
+ }, __name(_a11, "DocZoomRenderController"), _a11);
3482
+ DocZoomRenderController = __decorateClass$b([
3483
+ __decorateParam$b(1, IContextService),
3484
+ __decorateParam$b(2, Inject(DocSkeletonManagerService)),
3485
+ __decorateParam$b(3, IUniverInstanceService),
3486
+ __decorateParam$b(4, ICommandService),
3487
+ __decorateParam$b(5, Inject(TextSelectionManagerService)),
3488
+ __decorateParam$b(6, IEditorService),
3489
+ __decorateParam$b(7, Inject(DocPageLayoutService))
2513
3490
  ], DocZoomRenderController);
2514
- var __defProp$7 = Object.defineProperty, __getOwnPropDesc$7 = Object.getOwnPropertyDescriptor, __decorateClass$7 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2515
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$7(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3491
+ var __defProp$a = Object.defineProperty, __getOwnPropDesc$a = Object.getOwnPropertyDescriptor, __decorateClass$a = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3492
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$a(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2516
3493
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2517
- return kind && result && __defProp$7(target, key, result), result;
2518
- }, "__decorateClass$7"), __decorateParam$7 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$7"), _a11;
2519
- let DocTextSelectionRenderController = (_a11 = class extends Disposable {
3494
+ return kind && result && __defProp$a(target, key, result), result;
3495
+ }, "__decorateClass$a"), __decorateParam$a = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$a"), _a12;
3496
+ let DocTextSelectionRenderController = (_a12 = class extends Disposable {
2520
3497
  constructor(_context, _commandService, _editorService, _instanceSrv, _textSelectionRenderManager, _docSkeletonManagerService, _textSelectionManagerService) {
2521
3498
  super();
2522
3499
  __publicField(this, "_loadedMap", /* @__PURE__ */ new WeakSet());
@@ -2555,7 +3532,7 @@ let DocTextSelectionRenderController = (_a11 = class extends Disposable {
2555
3532
  ), viewModel = this._docSkeletonManagerService.getViewModel(), preEditArea = viewModel.getEditArea();
2556
3533
  preEditArea !== DocumentEditArea.BODY && editArea !== DocumentEditArea.BODY && editArea !== preEditArea && viewModel.setEditArea(editArea);
2557
3534
  }
2558
- if (this._textSelectionRenderManager.eventTrigger(evt), this._editorService.getEditor(unitId)) {
3535
+ if (this._textSelectionRenderManager.onPointDown(evt), this._editorService.getEditor(unitId)) {
2559
3536
  this._setEditorFocus(unitId);
2560
3537
  const { offsetX: offsetX2, offsetY: offsetY2 } = evt;
2561
3538
  setTimeout(() => {
@@ -2587,9 +3564,9 @@ let DocTextSelectionRenderController = (_a11 = class extends Disposable {
2587
3564
  const updateCommandList = [SetDocZoomRatioOperation.id];
2588
3565
  this.disposeWithMe(
2589
3566
  this._commandService.onCommandExecuted((command) => {
2590
- var _a19;
3567
+ var _a23;
2591
3568
  if (updateCommandList.includes(command.id)) {
2592
- const params = command.params, { unitId: documentId } = params, unitId = (_a19 = this._textSelectionManagerService.getCurrentSelection()) == null ? void 0 : _a19.unitId;
3569
+ const params = command.params, { unitId: documentId } = params, unitId = (_a23 = this._textSelectionManagerService.getCurrentSelection()) == null ? void 0 : _a23.unitId;
2593
3570
  if (documentId !== unitId)
2594
3571
  return;
2595
3572
  this._textSelectionManagerService.refreshSelection();
@@ -2598,37 +3575,35 @@ let DocTextSelectionRenderController = (_a11 = class extends Disposable {
2598
3575
  );
2599
3576
  }
2600
3577
  _skeletonListener() {
2601
- this.disposeWithMe(
2602
- this._docSkeletonManagerService.currentSkeleton$.subscribe((skeleton) => {
2603
- if (skeleton == null)
2604
- return;
2605
- const { scene, mainComponent, unitId } = this._context;
2606
- this._textSelectionRenderManager.changeRuntime(skeleton, scene, mainComponent), this._textSelectionManagerService.setCurrentSelectionNotRefresh({
2607
- unitId,
2608
- subUnitId: ""
2609
- }), isInternalEditorID(unitId) || this._textSelectionManagerService.replaceTextRanges([
2610
- {
2611
- startOffset: 0,
2612
- endOffset: 0
2613
- }
2614
- ], !1);
2615
- })
2616
- );
3578
+ let init = !1;
3579
+ this.disposeWithMe(this._docSkeletonManagerService.currentSkeleton$.subscribe((skeleton) => {
3580
+ if (!skeleton) return;
3581
+ const { scene, mainComponent, unitId } = this._context, isInternalEditor = isInternalEditorID(unitId);
3582
+ (init || !isInternalEditorID(this._context.unitId)) && (this._textSelectionRenderManager.changeRuntime(skeleton, scene, mainComponent), this._textSelectionManagerService.setCurrentSelectionNotRefresh({
3583
+ unitId,
3584
+ subUnitId: ""
3585
+ }), isInternalEditor || this._textSelectionManagerService.replaceTextRanges([
3586
+ {
3587
+ startOffset: 0,
3588
+ endOffset: 0
3589
+ }
3590
+ ], !1)), init = !0;
3591
+ }));
2617
3592
  }
2618
- }, __name(_a11, "DocTextSelectionRenderController"), _a11);
2619
- DocTextSelectionRenderController = __decorateClass$7([
2620
- __decorateParam$7(1, ICommandService),
2621
- __decorateParam$7(2, IEditorService),
2622
- __decorateParam$7(3, IUniverInstanceService),
2623
- __decorateParam$7(4, ITextSelectionRenderManager),
2624
- __decorateParam$7(5, Inject(DocSkeletonManagerService)),
2625
- __decorateParam$7(6, Inject(TextSelectionManagerService))
3593
+ }, __name(_a12, "DocTextSelectionRenderController"), _a12);
3594
+ DocTextSelectionRenderController = __decorateClass$a([
3595
+ __decorateParam$a(1, ICommandService),
3596
+ __decorateParam$a(2, IEditorService),
3597
+ __decorateParam$a(3, IUniverInstanceService),
3598
+ __decorateParam$a(4, ITextSelectionRenderManager),
3599
+ __decorateParam$a(5, Inject(DocSkeletonManagerService)),
3600
+ __decorateParam$a(6, Inject(TextSelectionManagerService))
2626
3601
  ], DocTextSelectionRenderController);
2627
- var __defProp$6 = Object.defineProperty, __getOwnPropDesc$6 = Object.getOwnPropertyDescriptor, __decorateClass$6 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2628
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$6(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3602
+ var __defProp$9 = Object.defineProperty, __getOwnPropDesc$9 = Object.getOwnPropertyDescriptor, __decorateClass$9 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3603
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$9(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2629
3604
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2630
- return kind && result && __defProp$6(target, key, result), result;
2631
- }, "__decorateClass$6"), __decorateParam$6 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$6");
3605
+ return kind && result && __defProp$9(target, key, result), result;
3606
+ }, "__decorateClass$9"), __decorateParam$9 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$9");
2632
3607
  function transformBound2OffsetBound(originBound, scene) {
2633
3608
  const topLeft = transformPosition2Offset(originBound.left, originBound.top, scene), bottomRight = transformPosition2Offset(originBound.right, originBound.bottom, scene);
2634
3609
  return {
@@ -2653,8 +3628,8 @@ function transformPosition2Offset(x, y, scene) {
2653
3628
  };
2654
3629
  }
2655
3630
  __name(transformPosition2Offset, "transformPosition2Offset");
2656
- var _a12;
2657
- let DocCanvasPopManagerService = (_a12 = class extends Disposable {
3631
+ var _a13;
3632
+ let DocCanvasPopManagerService = (_a13 = class extends Disposable {
2658
3633
  constructor(_globalPopupManagerService, _renderManagerService, _univerInstanceService, _commandService) {
2659
3634
  super(), this._globalPopupManagerService = _globalPopupManagerService, this._renderManagerService = _renderManagerService, this._univerInstanceService = _univerInstanceService, this._commandService = _commandService;
2660
3635
  }
@@ -2687,19 +3662,19 @@ let DocCanvasPopManagerService = (_a12 = class extends Disposable {
2687
3662
  };
2688
3663
  }
2689
3664
  _createRangePositionObserver(range, currentRender) {
2690
- var _a19;
3665
+ var _a23;
2691
3666
  const calc = /* @__PURE__ */ __name(() => {
2692
3667
  const { scene, mainComponent, engine } = currentRender, skeleton = currentRender.with(DocSkeletonManagerService).getSkeleton(), startPosition = skeleton.findNodePositionByCharIndex(range.startOffset), endPosition = skeleton.findNodePositionByCharIndex(range.endOffset), document = mainComponent;
2693
3668
  if (!endPosition || !startPosition)
2694
3669
  return;
2695
- const documentOffsetConfig = document.getOffsetConfig(), { docsLeft, docsTop } = documentOffsetConfig, canvasElement = engine.getCanvasElement(), canvasClientRect = canvasElement.getBoundingClientRect(), widthOfCanvas = pxToNum(canvasElement.style.width), { top, left, width } = canvasClientRect, scaleAdjust = width / widthOfCanvas, { scaleX, scaleY } = scene.getAncestorScale(), convertor = new NodePositionConvertToCursor(documentOffsetConfig, skeleton), { borderBoxPointGroup } = convertor.getRangePointData(startPosition, endPosition);
2696
- return getLineBounding(borderBoxPointGroup).map((bound) => transformBound2OffsetBound(bound, scene)).map((i) => ({
3670
+ const documentOffsetConfig = document.getOffsetConfig(), { docsLeft, docsTop } = documentOffsetConfig, canvasElement = engine.getCanvasElement(), canvasClientRect = canvasElement.getBoundingClientRect(), widthOfCanvas = pxToNum(canvasElement.style.width), { top, left, width } = canvasClientRect, scaleAdjust = width / widthOfCanvas, { scaleX, scaleY } = scene.getAncestorScale(), convertor = new NodePositionConvertToCursor(documentOffsetConfig, skeleton), { contentBoxPointGroup } = convertor.getRangePointData(startPosition, endPosition);
3671
+ return getLineBounding(contentBoxPointGroup).map((bound) => transformBound2OffsetBound(bound, scene)).map((i) => ({
2697
3672
  left: (i.left + docsLeft * scaleX) * scaleAdjust + left,
2698
3673
  right: (i.right + docsLeft * scaleX) * scaleAdjust + left,
2699
3674
  top: (i.top + docsTop * scaleY) * scaleAdjust + top,
2700
3675
  bottom: (i.bottom + docsTop * scaleY) * scaleAdjust + top
2701
3676
  }));
2702
- }, "calc"), positions = (_a19 = calc()) != null ? _a19 : [], positions$ = new BehaviorSubject(positions), disposable = new DisposableCollection();
3677
+ }, "calc"), positions = (_a23 = calc()) != null ? _a23 : [], positions$ = new BehaviorSubject(positions), disposable = new DisposableCollection();
2703
3678
  disposable.add(this._commandService.onCommandExecuted((commandInfo) => {
2704
3679
  if (commandInfo.id === SetDocZoomRatioOperation.id) {
2705
3680
  const position = calc();
@@ -2765,24 +3740,24 @@ let DocCanvasPopManagerService = (_a12 = class extends Disposable {
2765
3740
  }, "dispose")
2766
3741
  };
2767
3742
  }
2768
- }, __name(_a12, "DocCanvasPopManagerService"), _a12);
2769
- DocCanvasPopManagerService = __decorateClass$6([
2770
- __decorateParam$6(0, Inject(ICanvasPopupService)),
2771
- __decorateParam$6(1, IRenderManagerService),
2772
- __decorateParam$6(2, IUniverInstanceService),
2773
- __decorateParam$6(3, ICommandService)
3743
+ }, __name(_a13, "DocCanvasPopManagerService"), _a13);
3744
+ DocCanvasPopManagerService = __decorateClass$9([
3745
+ __decorateParam$9(0, Inject(ICanvasPopupService)),
3746
+ __decorateParam$9(1, IRenderManagerService),
3747
+ __decorateParam$9(2, IUniverInstanceService),
3748
+ __decorateParam$9(3, ICommandService)
2774
3749
  ], DocCanvasPopManagerService);
2775
- var __defProp$5 = Object.defineProperty, __getOwnPropDesc$5 = Object.getOwnPropertyDescriptor, __decorateClass$5 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2776
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$5(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3750
+ var __defProp$8 = Object.defineProperty, __getOwnPropDesc$8 = Object.getOwnPropertyDescriptor, __decorateClass$8 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3751
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$8(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2777
3752
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2778
- return kind && result && __defProp$5(target, key, result), result;
2779
- }, "__decorateClass$5"), __decorateParam$5 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$5"), _a13;
2780
- let DocsRenderService = (_a13 = class extends RxDisposable {
3753
+ return kind && result && __defProp$8(target, key, result), result;
3754
+ }, "__decorateClass$8"), __decorateParam$8 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$8"), _a14;
3755
+ let DocsRenderService = (_a14 = class extends RxDisposable {
2781
3756
  constructor(_instanceSrv, _renderManagerService) {
2782
3757
  super(), this._instanceSrv = _instanceSrv, this._renderManagerService = _renderManagerService, this._init();
2783
3758
  }
2784
3759
  _init() {
2785
- this._renderManagerService.createRender$.pipe(takeUntil(this.dispose$)).subscribe((unitId) => this._createRenderWithId(unitId)), this._instanceSrv.getTypeOfUnitAdded$(UniverInstanceType.UNIVER_DOC).pipe(takeUntil(this.dispose$)).subscribe((doc) => this._createRenderer(doc)), this._instanceSrv.getAllUnitsForType(UniverInstanceType.UNIVER_DOC).forEach((documentModel) => this._createRenderer(documentModel)), this._instanceSrv.getTypeOfUnitDisposed$(UniverInstanceType.UNIVER_DOC).pipe(takeUntil(this.dispose$)).subscribe((doc) => this._disposeRenderer(doc));
3760
+ this._renderManagerService.createRender$.pipe(takeUntil(this.dispose$)).subscribe((unitId) => this._createRenderWithId(unitId)), this._instanceSrv.getAllUnitsForType(UniverInstanceType.UNIVER_DOC).forEach((documentModel) => this._createRenderer(documentModel)), this._instanceSrv.getTypeOfUnitAdded$(UniverInstanceType.UNIVER_DOC).pipe(takeUntil(this.dispose$)).subscribe((doc) => this._createRenderer(doc)), this._instanceSrv.getTypeOfUnitDisposed$(UniverInstanceType.UNIVER_DOC).pipe(takeUntil(this.dispose$)).subscribe((doc) => this._disposeRenderer(doc));
2786
3761
  }
2787
3762
  _createRenderer(doc) {
2788
3763
  const unitId = doc.getUnitId();
@@ -2795,31 +3770,31 @@ let DocsRenderService = (_a13 = class extends RxDisposable {
2795
3770
  const unitId = doc.getUnitId();
2796
3771
  this._renderManagerService.removeRender(unitId);
2797
3772
  }
2798
- }, __name(_a13, "DocsRenderService"), _a13);
2799
- DocsRenderService = __decorateClass$5([
3773
+ }, __name(_a14, "DocsRenderService"), _a14);
3774
+ DocsRenderService = __decorateClass$8([
2800
3775
  OnLifecycle(LifecycleStages.Ready, DocsRenderService),
2801
- __decorateParam$5(0, IUniverInstanceService),
2802
- __decorateParam$5(1, IRenderManagerService)
3776
+ __decorateParam$8(0, IUniverInstanceService),
3777
+ __decorateParam$8(1, IRenderManagerService)
2803
3778
  ], DocsRenderService);
2804
- var __defProp$4 = Object.defineProperty, __getOwnPropDesc$4 = Object.getOwnPropertyDescriptor, __decorateClass$4 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2805
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$4(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3779
+ var __defProp$7 = Object.defineProperty, __getOwnPropDesc$7 = Object.getOwnPropertyDescriptor, __decorateClass$7 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3780
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$7(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2806
3781
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2807
- return kind && result && __defProp$4(target, key, result), result;
2808
- }, "__decorateClass$4"), __decorateParam$4 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$4");
3782
+ return kind && result && __defProp$7(target, key, result), result;
3783
+ }, "__decorateClass$7"), __decorateParam$7 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$7");
2809
3784
  const SKIP_UNIT_IDS$1 = [
2810
3785
  DEFAULT_EMPTY_DOCUMENT_VALUE,
2811
3786
  DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,
2812
3787
  DOCS_NORMAL_EDITOR_UNIT_ID_KEY,
2813
3788
  DOCS_ZEN_EDITOR_UNIT_ID_KEY
2814
3789
  ];
2815
- var _a14;
2816
- let DocContextMenuRenderController = (_a14 = class extends Disposable {
3790
+ var _a15;
3791
+ let DocContextMenuRenderController = (_a15 = class extends Disposable {
2817
3792
  constructor(_context, _contextMenuService, _textSelectionManagerService, _commandService) {
2818
3793
  super(), this._context = _context, this._contextMenuService = _contextMenuService, this._textSelectionManagerService = _textSelectionManagerService, this._commandService = _commandService, SKIP_UNIT_IDS$1.includes(this._context.unitId) || (this._initPointerDown(), this._initEditChange());
2819
3794
  }
2820
3795
  _initPointerDown() {
2821
- var _a19, _b;
2822
- const documentsSubscription = ((_b = (_a19 = this._context) == null ? void 0 : _a19.mainComponent) == null ? void 0 : _b.onPointerDown$).subscribeEvent((event) => {
3796
+ var _a23, _b;
3797
+ const documentsSubscription = ((_b = (_a23 = this._context) == null ? void 0 : _a23.mainComponent) == null ? void 0 : _b.onPointerDown$).subscribeEvent((event) => {
2823
3798
  event.button === 2 && this._contextMenuService.triggerContextMenu(event, MenuPosition.CONTEXT_MENU);
2824
3799
  });
2825
3800
  this.disposeWithMe(documentsSubscription);
@@ -2831,24 +3806,24 @@ let DocContextMenuRenderController = (_a14 = class extends Disposable {
2831
3806
  })
2832
3807
  );
2833
3808
  }
2834
- }, __name(_a14, "DocContextMenuRenderController"), _a14);
2835
- DocContextMenuRenderController = __decorateClass$4([
2836
- __decorateParam$4(1, IContextMenuService),
2837
- __decorateParam$4(2, Inject(TextSelectionManagerService)),
2838
- __decorateParam$4(3, ICommandService)
3809
+ }, __name(_a15, "DocContextMenuRenderController"), _a15);
3810
+ DocContextMenuRenderController = __decorateClass$7([
3811
+ __decorateParam$7(1, IContextMenuService),
3812
+ __decorateParam$7(2, Inject(TextSelectionManagerService)),
3813
+ __decorateParam$7(3, ICommandService)
2839
3814
  ], DocContextMenuRenderController);
2840
- var __defProp$3 = Object.defineProperty, __getOwnPropDesc$3 = Object.getOwnPropertyDescriptor, __decorateClass$3 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2841
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$3(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3815
+ var __defProp$6 = Object.defineProperty, __getOwnPropDesc$6 = Object.getOwnPropertyDescriptor, __decorateClass$6 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3816
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$6(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2842
3817
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2843
- return kind && result && __defProp$3(target, key, result), result;
2844
- }, "__decorateClass$3"), __decorateParam$3 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$3");
3818
+ return kind && result && __defProp$6(target, key, result), result;
3819
+ }, "__decorateClass$6"), __decorateParam$6 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$6");
2845
3820
  const SKIP_UNIT_IDS = [
2846
3821
  DEFAULT_EMPTY_DOCUMENT_VALUE,
2847
3822
  DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY,
2848
3823
  DOCS_NORMAL_EDITOR_UNIT_ID_KEY
2849
3824
  ];
2850
- var _a15;
2851
- let DocResizeRenderController = (_a15 = class extends Disposable {
3825
+ var _a16;
3826
+ let DocResizeRenderController = (_a16 = class extends Disposable {
2852
3827
  constructor(_context, _docPageLayoutService, _textSelectionManagerService) {
2853
3828
  super(), this._context = _context, this._docPageLayoutService = _docPageLayoutService, this._textSelectionManagerService = _textSelectionManagerService, SKIP_UNIT_IDS.includes(this._context.unitId) || this._initResize();
2854
3829
  }
@@ -2862,23 +3837,25 @@ let DocResizeRenderController = (_a15 = class extends Disposable {
2862
3837
  })
2863
3838
  );
2864
3839
  }
2865
- }, __name(_a15, "DocResizeRenderController"), _a15);
2866
- DocResizeRenderController = __decorateClass$3([
2867
- __decorateParam$3(1, Inject(DocPageLayoutService)),
2868
- __decorateParam$3(2, Inject(TextSelectionManagerService))
3840
+ }, __name(_a16, "DocResizeRenderController"), _a16);
3841
+ DocResizeRenderController = __decorateClass$6([
3842
+ __decorateParam$6(1, Inject(DocPageLayoutService)),
3843
+ __decorateParam$6(2, Inject(TextSelectionManagerService))
2869
3844
  ], DocResizeRenderController);
2870
- var __defProp$2 = Object.defineProperty, __getOwnPropDesc$2 = Object.getOwnPropertyDescriptor, __decorateClass$2 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2871
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$2(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3845
+ var __defProp$5 = Object.defineProperty, __getOwnPropDesc$5 = Object.getOwnPropertyDescriptor, __decorateClass$5 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3846
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$5(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2872
3847
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2873
- return kind && result && __defProp$2(target, key, result), result;
2874
- }, "__decorateClass$2"), __decorateParam$2 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$2"), _a16;
2875
- let DocHoverManagerService = (_a16 = class extends Disposable {
3848
+ return kind && result && __defProp$5(target, key, result), result;
3849
+ }, "__decorateClass$5"), __decorateParam$5 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$5"), _a17;
3850
+ let DocHoverManagerService = (_a17 = class extends Disposable {
2876
3851
  constructor(_univerInstanceService, _renderManagerService) {
2877
3852
  super();
2878
- __publicField(this, "_activeCustomRanges$", new BehaviorSubject([]));
3853
+ __publicField(this, "_activeCustomRanges$", new Subject());
2879
3854
  __publicField(this, "activeCustomRanges$", this._activeCustomRanges$.asObservable());
2880
- __publicField(this, "_activeIndex$", new BehaviorSubject(null));
3855
+ __publicField(this, "_activeIndex$", new Subject());
2881
3856
  __publicField(this, "activeIndex$", this._activeIndex$.asObservable());
3857
+ __publicField(this, "_bullet$", new Subject());
3858
+ __publicField(this, "bullet$", this._bullet$.asObservable());
2882
3859
  __publicField(this, "_scrolling", !1);
2883
3860
  this._univerInstanceService = _univerInstanceService, this._renderManagerService = _renderManagerService, this.disposeWithMe(() => {
2884
3861
  this._activeCustomRanges$.complete(), this._activeIndex$.complete();
@@ -2890,7 +3867,7 @@ let DocHoverManagerService = (_a16 = class extends Disposable {
2890
3867
  return documentTransform.clone().invert().applyPoint(originCoord);
2891
3868
  }
2892
3869
  _calcActiveCustomRanges(offsetX, offsetY) {
2893
- var _a19, _b;
3870
+ var _a23, _b;
2894
3871
  const document = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_DOC);
2895
3872
  if (!document) {
2896
3873
  this._activeCustomRanges$.next([]);
@@ -2915,15 +3892,18 @@ let DocHoverManagerService = (_a16 = class extends Disposable {
2915
3892
  );
2916
3893
  if (node && node.node) {
2917
3894
  const left = node.node.left + pageMarginLeft, right = node.node.left + node.node.width + pageMarginLeft;
2918
- if (coord.x < left || coord.x > right) {
2919
- this._activeIndex$.next(null), this._activeCustomRanges$.next([]);
3895
+ let index = node.node.parent.st + node.node.parent.glyphGroup.indexOf(node.node);
3896
+ const paragraph = getParagraphByGlyph(node.node, document.getBody());
3897
+ if (paragraph && paragraph.bullet && index === paragraph.paragraphStart) {
3898
+ this._bullet$.next(paragraph), this._activeIndex$.next(null), this._activeCustomRanges$.next([]);
2920
3899
  return;
2921
3900
  }
2922
- const index = node.node.parent.st + node.node.parent.glyphGroup.indexOf(node.node);
2923
- index !== this._activeIndex$.value && this._activeIndex$.next(index);
2924
- const ranges = (_b = (_a19 = document.getCustomRanges()) == null ? void 0 : _a19.filter((range) => range.startIndex <= index && range.endIndex >= index)) != null ? _b : [], currentRanges = this._activeCustomRanges$.value;
2925
- if (currentRanges.length === ranges.length && currentRanges.every((range, i) => range.rangeId === ranges[i].rangeId))
3901
+ if (coord.x < left || coord.x > right) {
3902
+ this._activeIndex$.next(null), this._activeCustomRanges$.next([]), this._bullet$.next(null);
2926
3903
  return;
3904
+ }
3905
+ paragraph && paragraph.bullet && (index = index - 1), this._bullet$.next(null), this._activeIndex$.next(index);
3906
+ const ranges = (_b = (_a23 = document.getCustomRanges()) == null ? void 0 : _a23.filter((range) => range.startIndex <= index && range.endIndex >= index)) != null ? _b : [];
2927
3907
  this._activeCustomRanges$.next(ranges);
2928
3908
  }
2929
3909
  }
@@ -2939,23 +3919,23 @@ let DocHoverManagerService = (_a16 = class extends Disposable {
2939
3919
  endScroll() {
2940
3920
  this._scrolling = !1;
2941
3921
  }
2942
- }, __name(_a16, "DocHoverManagerService"), _a16);
2943
- DocHoverManagerService = __decorateClass$2([
2944
- __decorateParam$2(0, IUniverInstanceService),
2945
- __decorateParam$2(1, IRenderManagerService)
3922
+ }, __name(_a17, "DocHoverManagerService"), _a17);
3923
+ DocHoverManagerService = __decorateClass$5([
3924
+ __decorateParam$5(0, IUniverInstanceService),
3925
+ __decorateParam$5(1, IRenderManagerService)
2946
3926
  ], DocHoverManagerService);
2947
- var __defProp$1 = Object.defineProperty, __getOwnPropDesc$1 = Object.getOwnPropertyDescriptor, __decorateClass$1 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2948
- for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$1(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3927
+ var __defProp$4 = Object.defineProperty, __getOwnPropDesc$4 = Object.getOwnPropertyDescriptor, __decorateClass$4 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3928
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$4(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2949
3929
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2950
- return kind && result && __defProp$1(target, key, result), result;
2951
- }, "__decorateClass$1"), __decorateParam$1 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$1"), _a17;
2952
- let DocHoverRenderController = (_a17 = class extends Disposable {
3930
+ return kind && result && __defProp$4(target, key, result), result;
3931
+ }, "__decorateClass$4"), __decorateParam$4 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$4"), _a18;
3932
+ let DocHoverRenderController = (_a18 = class extends Disposable {
2953
3933
  constructor(_context, _docHoverManagerService) {
2954
3934
  super(), this._context = _context, this._docHoverManagerService = _docHoverManagerService, this._initPointerDown(), this._initScroll();
2955
3935
  }
2956
3936
  _initPointerDown() {
2957
3937
  this.disposeWithMe(
2958
- fromEventSubject(this._context.scene.onPointerMove$).pipe(debounceTime(200)).subscribe((evt) => {
3938
+ fromEventSubject(this._context.scene.onPointerMove$).pipe(debounceTime(100)).subscribe((evt) => {
2959
3939
  this._docHoverManagerService.onMouseMove(evt);
2960
3940
  })
2961
3941
  );
@@ -2968,18 +3948,284 @@ let DocHoverRenderController = (_a17 = class extends Disposable {
2968
3948
  this._docHoverManagerService.startScroll();
2969
3949
  })));
2970
3950
  }
2971
- }, __name(_a17, "DocHoverRenderController"), _a17);
2972
- DocHoverRenderController = __decorateClass$1([
2973
- __decorateParam$1(1, Inject(DocHoverManagerService))
3951
+ }, __name(_a18, "DocHoverRenderController"), _a18);
3952
+ DocHoverRenderController = __decorateClass$4([
3953
+ __decorateParam$4(1, Inject(DocHoverManagerService))
2974
3954
  ], DocHoverRenderController);
3955
+ var __defProp$3 = Object.defineProperty, __getOwnPropDesc$3 = Object.getOwnPropertyDescriptor, __decorateClass$3 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
3956
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$3(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
3957
+ (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
3958
+ return kind && result && __defProp$3(target, key, result), result;
3959
+ }, "__decorateClass$3"), __decorateParam$3 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$3"), _a19;
3960
+ let DocAutoFormatController = (_a19 = class extends Disposable {
3961
+ constructor(_docAutoFormatService) {
3962
+ super(), this._docAutoFormatService = _docAutoFormatService, this._initListTabAutoFormat(), this._initListSpaceAutoFormat(), this._initDefaultEnterFormat(), this._initExitListAutoFormat();
3963
+ }
3964
+ _initListTabAutoFormat() {
3965
+ this.disposeWithMe(
3966
+ this._docAutoFormatService.registerAutoFormat({
3967
+ id: TabCommand.id,
3968
+ match: /* @__PURE__ */ __name((context) => {
3969
+ var _a23;
3970
+ const { selection, paragraphs, unit } = context;
3971
+ if (paragraphs.length === 1 && selection.startOffset === paragraphs[0].paragraphStart && paragraphs[0].bullet) {
3972
+ const allParagraphs = (_a23 = unit.getBody()) == null ? void 0 : _a23.paragraphs, bulletParagraphs = allParagraphs == null ? void 0 : allParagraphs.filter((p2) => {
3973
+ var _a24;
3974
+ return ((_a24 = p2.bullet) == null ? void 0 : _a24.listId) === paragraphs[0].bullet.listId;
3975
+ });
3976
+ return (bulletParagraphs == null ? void 0 : bulletParagraphs.findIndex((p2) => p2.startIndex === paragraphs[0].startIndex)) !== 0;
3977
+ } else if (paragraphs.length > 1)
3978
+ return !0;
3979
+ return !1;
3980
+ }, "match"),
3981
+ // traverse all paragraphs, set paragraph
3982
+ getMutations(context) {
3983
+ const params = context.commandParams;
3984
+ return [{
3985
+ id: ChangeListNestingLevelCommand.id,
3986
+ params: {
3987
+ type: params != null && params.shift ? ChangeListNestingLevelType.decrease : ChangeListNestingLevelType.increase
3988
+ }
3989
+ }];
3990
+ }
3991
+ })
3992
+ );
3993
+ }
3994
+ _initListSpaceAutoFormat() {
3995
+ this.disposeWithMe(
3996
+ this._docAutoFormatService.registerAutoFormat({
3997
+ id: AfterSpaceCommand.id,
3998
+ match: /* @__PURE__ */ __name((context) => {
3999
+ var _a23;
4000
+ const { selection, paragraphs, unit } = context;
4001
+ if (!selection.collapsed || paragraphs.length !== 1)
4002
+ return !1;
4003
+ const text = (_a23 = unit.getBody()) == null ? void 0 : _a23.dataStream.slice(paragraphs[0].paragraphStart, paragraphs[0].paragraphEnd - 1);
4004
+ return !!(text && Object.keys(QuickListTypeMap).includes(text));
4005
+ }, "match"),
4006
+ getMutations(context) {
4007
+ var _a23;
4008
+ const { paragraphs, unit } = context, text = (_a23 = unit.getBody()) == null ? void 0 : _a23.dataStream.slice(paragraphs[0].paragraphStart, paragraphs[0].paragraphEnd - 1);
4009
+ if (text && Object.keys(QuickListTypeMap).includes(text)) {
4010
+ const type = QuickListTypeMap[text];
4011
+ return [{
4012
+ id: QuickListCommand.id,
4013
+ params: {
4014
+ listType: type,
4015
+ paragraph: paragraphs[0]
4016
+ }
4017
+ }];
4018
+ }
4019
+ return [];
4020
+ }
4021
+ })
4022
+ );
4023
+ }
4024
+ _initExitListAutoFormat() {
4025
+ this.disposeWithMe(
4026
+ this._docAutoFormatService.registerAutoFormat({
4027
+ id: EnterCommand.id,
4028
+ match: /* @__PURE__ */ __name((context) => {
4029
+ const { paragraphs } = context;
4030
+ return !!(paragraphs.length === 1 && paragraphs[0].bullet && paragraphs[0].paragraphStart === paragraphs[0].paragraphEnd);
4031
+ }, "match"),
4032
+ getMutations: /* @__PURE__ */ __name((context) => {
4033
+ const bullet = context.paragraphs[0].bullet;
4034
+ return bullet ? bullet.nestingLevel > 0 ? [{
4035
+ id: ChangeListNestingLevelCommand.id,
4036
+ params: {
4037
+ type: ChangeListNestingLevelType.decrease
4038
+ }
4039
+ }] : [{
4040
+ id: ListOperationCommand.id,
4041
+ params: {
4042
+ listType: context.paragraphs[0].bullet.listType
4043
+ }
4044
+ }] : [];
4045
+ }, "getMutations")
4046
+ })
4047
+ );
4048
+ }
4049
+ _initDefaultEnterFormat() {
4050
+ this.disposeWithMe(
4051
+ this._docAutoFormatService.registerAutoFormat({
4052
+ id: EnterCommand.id,
4053
+ match: /* @__PURE__ */ __name(() => !0, "match"),
4054
+ getMutations() {
4055
+ return [{
4056
+ id: BreakLineCommand.id
4057
+ }];
4058
+ },
4059
+ priority: -9999
4060
+ })
4061
+ );
4062
+ }
4063
+ }, __name(_a19, "DocAutoFormatController"), _a19);
4064
+ DocAutoFormatController = __decorateClass$3([
4065
+ OnLifecycle(LifecycleStages.Rendered, DocAutoFormatController),
4066
+ __decorateParam$3(0, Inject(DocAutoFormatService))
4067
+ ], DocAutoFormatController);
4068
+ var __defProp$2 = Object.defineProperty, __getOwnPropDesc$2 = Object.getOwnPropertyDescriptor, __decorateClass$2 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
4069
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$2(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
4070
+ (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
4071
+ return kind && result && __defProp$2(target, key, result), result;
4072
+ }, "__decorateClass$2"), __decorateParam$2 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$2"), _a20;
4073
+ let DocChecklistRenderController = (_a20 = class extends Disposable {
4074
+ constructor(_context, _docSkeletonManagerService, _commandService, _docHoverManagerService) {
4075
+ super(), this._context = _context, this._docSkeletonManagerService = _docSkeletonManagerService, this._commandService = _commandService, this._docHoverManagerService = _docHoverManagerService, this._initPointerDownObserver(), this._initHoverCursor();
4076
+ }
4077
+ _initPointerDownObserver() {
4078
+ this.disposeWithMe(
4079
+ this._context.mainComponent.onPointerDown$.subscribeEvent((evt) => {
4080
+ const { offsetX, offsetY } = evt, documentComponent = this._context.mainComponent, coord = this._getTransformCoordForDocumentOffset(
4081
+ documentComponent,
4082
+ this._context.scene.getViewport(VIEWPORT_KEY.VIEW_MAIN),
4083
+ offsetX,
4084
+ offsetY
4085
+ );
4086
+ if (!coord)
4087
+ return;
4088
+ const { pageLayoutType = PageLayoutType.VERTICAL, pageMarginLeft, pageMarginTop } = documentComponent.getOffsetConfig(), node = this._docSkeletonManagerService.getSkeleton().findNodeByCoord(
4089
+ coord,
4090
+ pageLayoutType,
4091
+ pageMarginLeft,
4092
+ pageMarginTop
4093
+ );
4094
+ if (!node)
4095
+ return;
4096
+ const paragraph = getParagraphByGlyph(node.node, this._context.unit.getBody());
4097
+ paragraph && paragraph.bullet && node.node.glyphType === GlyphType.LIST && (paragraph.bullet.listType === PresetListType.CHECK_LIST || paragraph.bullet.listType === PresetListType.CHECK_LIST_CHECKED) && this._commandService.executeCommand(ToggleCheckListCommand.id, {
4098
+ index: paragraph.startIndex
4099
+ });
4100
+ })
4101
+ );
4102
+ }
4103
+ _initHoverCursor() {
4104
+ this.disposeWithMe(
4105
+ this._docHoverManagerService.bullet$.subscribe((paragraph) => {
4106
+ paragraph ? this._context.mainComponent.setCursor(CURSOR_TYPE.POINTER) : this._context.mainComponent.setCursor(CURSOR_TYPE.TEXT);
4107
+ })
4108
+ );
4109
+ }
4110
+ _getTransformCoordForDocumentOffset(document, viewport, evtOffsetX, evtOffsetY) {
4111
+ const { documentTransform } = document.getOffsetConfig(), originCoord = viewport.transformVector2SceneCoord(Vector2.FromArray([evtOffsetX, evtOffsetY]));
4112
+ if (originCoord)
4113
+ return documentTransform.clone().invert().applyPoint(originCoord);
4114
+ }
4115
+ }, __name(_a20, "DocChecklistRenderController"), _a20);
4116
+ DocChecklistRenderController = __decorateClass$2([
4117
+ __decorateParam$2(1, Inject(DocSkeletonManagerService)),
4118
+ __decorateParam$2(2, ICommandService),
4119
+ __decorateParam$2(3, Inject(DocHoverManagerService))
4120
+ ], DocChecklistRenderController);
4121
+ const create = "univer-create", createItem = "univer-create-item", createLabel = "univer-create-label", createInput = "univer-create-input", styles = {
4122
+ create,
4123
+ createItem,
4124
+ createLabel,
4125
+ createInput
4126
+ }, DocCreateTableConfirm = /* @__PURE__ */ __name(({
4127
+ handleRowColChange,
4128
+ tableCreateParams
4129
+ }) => {
4130
+ const localeService = useDependency(LocaleService), [rowCount, setRowCount] = useState(3), [colCount, setColCount] = useState(5);
4131
+ function handleInputChange(rowCount2, colCount2) {
4132
+ setRowCount(rowCount2), setColCount(colCount2), handleRowColChange(rowCount2, colCount2);
4133
+ }
4134
+ return __name(handleInputChange, "handleInputChange"), useEffect(() => {
4135
+ setRowCount(tableCreateParams.rowCount), setColCount(tableCreateParams.colCount);
4136
+ }, [tableCreateParams]), /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles.create, children: [
4137
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles.createItem, children: [
4138
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles.createLabel, children: localeService.t("toolbar.table.rowCount") }),
4139
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
4140
+ InputNumber,
4141
+ {
4142
+ min: 1,
4143
+ max: 20,
4144
+ precision: 0,
4145
+ value: rowCount,
4146
+ onChange: /* @__PURE__ */ __name((val) => {
4147
+ handleInputChange(val, colCount);
4148
+ }, "onChange"),
4149
+ className: styles.createInput
4150
+ }
4151
+ )
4152
+ ] }),
4153
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: styles.createItem, children: [
4154
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: styles.createLabel, children: localeService.t("toolbar.table.colCount") }),
4155
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
4156
+ InputNumber,
4157
+ {
4158
+ min: 1,
4159
+ max: 20,
4160
+ precision: 0,
4161
+ value: colCount,
4162
+ onChange: /* @__PURE__ */ __name((val) => {
4163
+ handleInputChange(rowCount, val);
4164
+ }, "onChange"),
4165
+ className: styles.createInput
4166
+ }
4167
+ )
4168
+ ] })
4169
+ ] });
4170
+ }, "DocCreateTableConfirm");
4171
+ var __defProp$1 = Object.defineProperty, __getOwnPropDesc$1 = Object.getOwnPropertyDescriptor, __decorateClass$1 = /* @__PURE__ */ __name((decorators, target, key, kind) => {
4172
+ for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$1(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
4173
+ (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
4174
+ return kind && result && __defProp$1(target, key, result), result;
4175
+ }, "__decorateClass$1"), __decorateParam$1 = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam$1"), _a21;
4176
+ let DocTableController = (_a21 = class extends Disposable {
4177
+ constructor(_commandService, _componentManager) {
4178
+ super(), this._commandService = _commandService, this._componentManager = _componentManager, this._initialize();
4179
+ }
4180
+ _initialize() {
4181
+ this._init(), this._registerCommands(), this._initCustomComponents();
4182
+ }
4183
+ _registerCommands() {
4184
+ [
4185
+ DocCreateTableOperation
4186
+ ].forEach((command) => this.disposeWithMe(this._commandService.registerCommand(command)));
4187
+ }
4188
+ _initCustomComponents() {
4189
+ const componentManager = this._componentManager;
4190
+ this.disposeWithMe(componentManager.register(COMPONENT_DOC_CREATE_TABLE_CONFIRM, DocCreateTableConfirm));
4191
+ }
4192
+ _init() {
4193
+ }
4194
+ }, __name(_a21, "DocTableController"), _a21);
4195
+ DocTableController = __decorateClass$1([
4196
+ OnLifecycle(LifecycleStages.Rendered, DocTableController),
4197
+ __decorateParam$1(0, ICommandService),
4198
+ __decorateParam$1(1, Inject(ComponentManager))
4199
+ ], DocTableController);
4200
+ const DocTabCommand = {
4201
+ id: "doc.tab.tab-in-doc",
4202
+ type: CommandType.COMMAND,
4203
+ handler: /* @__PURE__ */ __name(async (accessor) => {
4204
+ const textSelectionManagerService = accessor.get(TextSelectionManagerService), commandService = accessor.get(ICommandService), activeTextRange = textSelectionManagerService.getActiveTextRangeWithStyle();
4205
+ if (activeTextRange == null)
4206
+ return !1;
4207
+ const { startNodePosition, endNodePosition } = activeTextRange;
4208
+ return startNodePosition && endNodePosition && isInSameTableCell(startNodePosition, endNodePosition) ? commandService.executeCommand(DocTableTabCommand.id) : !1;
4209
+ }, "handler")
4210
+ }, DocShiftTabCommand = {
4211
+ id: "doc.tab.shift-tab-in-doc",
4212
+ type: CommandType.COMMAND,
4213
+ handler: /* @__PURE__ */ __name(async (accessor) => {
4214
+ const textSelectionManagerService = accessor.get(TextSelectionManagerService), commandService = accessor.get(ICommandService), activeTextRange = textSelectionManagerService.getActiveTextRangeWithStyle();
4215
+ if (activeTextRange == null)
4216
+ return !1;
4217
+ const { startNodePosition, endNodePosition } = activeTextRange;
4218
+ return startNodePosition && endNodePosition && isInSameTableCell(startNodePosition, endNodePosition) ? commandService.executeCommand(DocTableShiftTabCommand.id) : !1;
4219
+ }, "handler")
4220
+ };
2975
4221
  var __defProp2 = Object.defineProperty, __getOwnPropDesc = Object.getOwnPropertyDescriptor, __decorateClass = /* @__PURE__ */ __name((decorators, target, key, kind) => {
2976
4222
  for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target, i = decorators.length - 1, decorator; i >= 0; i--)
2977
4223
  (decorator = decorators[i]) && (result = (kind ? decorator(target, key, result) : decorator(result)) || result);
2978
4224
  return kind && result && __defProp2(target, key, result), result;
2979
- }, "__decorateClass"), __decorateParam = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam"), _a18;
2980
- let UniverDocsUIPlugin = (_a18 = class extends Plugin {
2981
- constructor(_config, _injector, _renderManagerSrv, _logService) {
2982
- super(), this._config = _config, this._injector = _injector, this._renderManagerSrv = _renderManagerSrv, this._logService = _logService, this._config = Tools.deepMerge({}, DefaultDocUiConfig, this._config), this._initDependencies(_injector), this._initializeCommands();
4225
+ }, "__decorateClass"), __decorateParam = /* @__PURE__ */ __name((index, decorator) => (target, key) => decorator(target, key, index), "__decorateParam"), _a22;
4226
+ let UniverDocsUIPlugin = (_a22 = class extends Plugin {
4227
+ constructor(_config, _injector, _renderManagerSrv, _commandService, _logService) {
4228
+ super(), this._config = _config, this._injector = _injector, this._renderManagerSrv = _renderManagerSrv, this._commandService = _commandService, this._logService = _logService, this._config = Tools.deepMerge({}, DefaultDocUiConfig, this._config), this._initDependencies(_injector), this._initializeShortcut(), this._initCommand(), this._registerCommands();
2983
4229
  }
2984
4230
  onReady() {
2985
4231
  this._initRenderBasics(), this._markDocAsFocused();
@@ -2987,7 +4233,12 @@ let UniverDocsUIPlugin = (_a18 = class extends Plugin {
2987
4233
  onRendered() {
2988
4234
  this._initUI(), this._initRenderModules();
2989
4235
  }
2990
- _initializeCommands() {
4236
+ _initCommand() {
4237
+ [DocParagraphSettingCommand, DocParagraphSettingPanelOperation].forEach((e) => {
4238
+ this._commandService.registerCommand(e);
4239
+ });
4240
+ }
4241
+ _initializeShortcut() {
2991
4242
  [
2992
4243
  MoveCursorUpShortcut,
2993
4244
  MoveCursorDownShortcut,
@@ -3000,22 +4251,34 @@ let UniverDocsUIPlugin = (_a18 = class extends Plugin {
3000
4251
  SelectAllShortcut,
3001
4252
  DeleteLeftShortcut,
3002
4253
  DeleteRightShortcut,
3003
- BreakLineShortcut
4254
+ BreakLineShortcut,
4255
+ ShiftTabShortCut
4256
+ // TabShortcut,
4257
+ // ShiftTabShortcut,
3004
4258
  ].forEach((shortcut) => {
3005
4259
  this._injector.get(IShortcutService).registerShortcut(shortcut);
3006
4260
  });
3007
4261
  }
3008
- _initDependencies(injector) {
4262
+ _registerCommands() {
3009
4263
  [
4264
+ DocTabCommand,
4265
+ DocShiftTabCommand
4266
+ ].forEach((command) => this.disposeWithMe(this._commandService.registerCommand(command)));
4267
+ }
4268
+ _initDependencies(injector) {
4269
+ mergeOverrideWithDependencies([
3010
4270
  [DocUIController, { useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(DocUIController, this._config), "useFactory") }],
3011
4271
  [DocClipboardController],
3012
4272
  [DocEditorBridgeController],
4273
+ [DocAutoFormatController],
4274
+ [DocTableController],
3013
4275
  [DocsRenderService],
3014
4276
  [AppUIController, { useFactory: /* @__PURE__ */ __name(() => this._injector.createInstance(AppUIController, this._config), "useFactory") }],
3015
4277
  [IDocClipboardService, { useClass: DocClipboardService }],
3016
4278
  [DocCanvasPopManagerService],
3017
- [DocHoverManagerService]
3018
- ].forEach((d) => injector.add(d));
4279
+ [DocHoverManagerService],
4280
+ [DocParagraphSettingController]
4281
+ ], this._config.override).forEach((d) => injector.add(d));
3019
4282
  }
3020
4283
  _markDocAsFocused() {
3021
4284
  const currentService = this._injector.get(IUniverInstanceService), editorService = this._injector.get(IEditorService);
@@ -3049,16 +4312,18 @@ let UniverDocsUIPlugin = (_a18 = class extends Plugin {
3049
4312
  [DocHeaderFooterController],
3050
4313
  [DocResizeRenderController],
3051
4314
  [DocHoverRenderController],
3052
- [DocContextMenuRenderController]
4315
+ [DocContextMenuRenderController],
4316
+ [DocChecklistRenderController]
3053
4317
  ].forEach((m2) => {
3054
4318
  this._renderManagerSrv.registerRenderModule(UniverInstanceType.UNIVER_DOC, m2);
3055
4319
  });
3056
4320
  }
3057
- }, __name(_a18, "UniverDocsUIPlugin"), __publicField(_a18, "pluginName", DOC_UI_PLUGIN_NAME), __publicField(_a18, "type", UniverInstanceType.UNIVER_DOC), _a18);
4321
+ }, __name(_a22, "UniverDocsUIPlugin"), __publicField(_a22, "pluginName", DOC_UI_PLUGIN_NAME), __publicField(_a22, "type", UniverInstanceType.UNIVER_DOC), _a22);
3058
4322
  UniverDocsUIPlugin = __decorateClass([
3059
4323
  __decorateParam(1, Inject(Injector)),
3060
4324
  __decorateParam(2, IRenderManagerService),
3061
- __decorateParam(3, ILogService)
4325
+ __decorateParam(3, ICommandService),
4326
+ __decorateParam(4, ILogService)
3062
4327
  ], UniverDocsUIPlugin);
3063
4328
  function docDrawingPositionToTransform(position) {
3064
4329
  return {
@@ -3095,10 +4360,12 @@ export {
3095
4360
  DocBackScrollRenderController,
3096
4361
  DocCanvasPopManagerService,
3097
4362
  DocCopyCommand,
4363
+ DocCreateTableOperation,
3098
4364
  DocCutCommand,
3099
4365
  DocHoverManagerService,
3100
4366
  DocPasteCommand,
3101
4367
  DocRenderController,
4368
+ DocUIController,
3102
4369
  DocsRenderService,
3103
4370
  IDocClipboardService,
3104
4371
  PastePluginLark,