@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.
- package/lib/cjs/index.js +7 -4
- package/lib/es/index.js +1907 -640
- package/lib/index.css +1 -1
- package/lib/locale/en-US.json +38 -0
- package/lib/locale/ru-RU.json +39 -1
- package/lib/locale/vi-VN.json +39 -1
- package/lib/locale/zh-CN.json +40 -2
- package/lib/locale/zh-TW.json +39 -1
- package/lib/types/basics/interfaces/component-config/i-doc-ui-plugin-config.d.ts +2 -0
- package/lib/types/commands/commands/doc-paragraph-setting.command.d.ts +4 -0
- package/lib/types/commands/commands/doc-tab.command.d.ts +8 -0
- package/lib/types/commands/operations/doc-create-table.operation.d.ts +3 -0
- package/lib/types/commands/operations/doc-paragraph-setting-panel.operation.d.ts +3 -0
- package/lib/types/components/list-type-picker/index.d.ts +18 -0
- package/lib/types/components/list-type-picker/picker.d.ts +17 -0
- package/lib/types/controllers/doc-auto-format.controller.d.ts +11 -0
- package/lib/types/controllers/doc-header-footer.controller.d.ts +0 -1
- package/lib/types/controllers/doc-paragraph-setting.controller.d.ts +11 -0
- package/lib/types/controllers/doc-table.controller.d.ts +12 -0
- package/lib/types/controllers/doc-ui.controller.d.ts +12 -10
- package/lib/types/controllers/menu/context-menu.d.ts +11 -1
- package/lib/types/controllers/menu/menu.d.ts +9 -4
- package/lib/types/controllers/render-controllers/doc-checklist.render-controller.d.ts +15 -0
- package/lib/types/controllers/render-controllers/doc.render-controller.d.ts +3 -2
- package/lib/types/controllers/render-controllers/zoom.render-controller.d.ts +3 -3
- package/lib/types/docs-ui-plugin.d.ts +6 -3
- package/lib/types/index.d.ts +2 -0
- package/lib/types/locale/zh-CN.d.ts +38 -0
- package/lib/types/services/clipboard/clipboard.service.d.ts +2 -2
- package/lib/types/services/clipboard/copy-content-cache.d.ts +3 -3
- package/lib/types/services/clipboard/html-to-udm/converter.d.ts +5 -2
- package/lib/types/services/clipboard/html-to-udm/paste-plugins/type.d.ts +2 -2
- package/lib/types/services/clipboard/udm-to-html/convertor.d.ts +1 -1
- package/lib/types/services/doc-hover-manager.service.d.ts +3 -1
- package/lib/types/shortcuts/format.shortcut.d.ts +4 -0
- package/lib/types/views/paragraph-setting/Setting.d.ts +17 -0
- package/lib/types/views/paragraph-setting/hook/utils.d.ts +11 -0
- package/lib/types/views/paragraph-setting/index.d.ts +3 -0
- package/lib/types/views/table/create/TableCreate.d.ts +11 -0
- package/lib/types/views/table/create/component-name.d.ts +16 -0
- package/lib/umd/index.js +7 -4
- package/package.json +16 -13
- /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,
|
|
6
|
-
import { IClipboardInterfaceService, PLAIN_TEXT_CLIPBOARD_MIME_TYPE, HTML_CLIPBOARD_MIME_TYPE, IEditorService, KeyCode, MetaKeys, ILayoutService, ISidebarService,
|
|
7
|
-
import { TextSelectionManagerService, DocCustomRangeService, CutContentCommand, InnerPasteCommand, getDeleteSelection, DocSkeletonManagerService, VIEWPORT_KEY, getDocObject, MoveCursorOperation, MoveSelectionOperation, SelectAllOperation,
|
|
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,
|
|
10
|
-
import require$$0
|
|
11
|
-
import {
|
|
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),
|
|
151
|
-
|
|
152
|
-
|
|
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
|
|
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
|
|
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 (((
|
|
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}`,
|
|
166
|
-
...(_c =
|
|
171
|
+
text = `${DataStreamTreeTokenType.CUSTOM_RANGE_START}${text}${DataStreamTreeTokenType.CUSTOM_RANGE_END}`, body.customRanges = [
|
|
172
|
+
...(_c = body.customRanges) != null ? _c : [],
|
|
167
173
|
{
|
|
168
|
-
startIndex:
|
|
169
|
-
endIndex:
|
|
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
|
-
],
|
|
174
|
-
...
|
|
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)),
|
|
179
|
-
st:
|
|
180
|
-
ed:
|
|
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
|
-
|
|
228
|
-
|
|
229
|
-
|
|
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
|
-
|
|
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
|
-
|
|
341
|
+
const body = doc.body;
|
|
342
|
+
body.paragraphs == null && (body.paragraphs = []);
|
|
280
343
|
const paragraph = {
|
|
281
|
-
startIndex:
|
|
344
|
+
startIndex: body.dataStream.length
|
|
282
345
|
}, paragraphStyle = getParagraphStyle(el);
|
|
283
|
-
paragraphStyle && (paragraph.paragraphStyle = paragraphStyle),
|
|
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
|
-
|
|
362
|
+
const body = doc.body;
|
|
363
|
+
body.paragraphs == null && (body.paragraphs = []);
|
|
300
364
|
const paragraph = {
|
|
301
|
-
startIndex:
|
|
365
|
+
startIndex: body.dataStream.length
|
|
302
366
|
}, paragraphStyle = getParagraphStyle(el);
|
|
303
|
-
paragraphStyle && (paragraph.paragraphStyle = paragraphStyle),
|
|
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
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
}
|
|
344
|
-
|
|
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 +=
|
|
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$
|
|
362
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
365
|
-
}, "__decorateClass$
|
|
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
|
|
381
|
-
if (
|
|
504
|
+
const { bodyList, needCache } = this._getDocumentBodyInRanges(sliceType);
|
|
505
|
+
if (bodyList.length === 0)
|
|
382
506
|
return !1;
|
|
383
507
|
try {
|
|
384
|
-
const activeRange = this._textSelectionManagerService.
|
|
385
|
-
this._setClipboardData(
|
|
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
|
|
396
|
-
return this._paste(
|
|
519
|
+
const partDocData = await this._genDocDataFromClipboardItems(items);
|
|
520
|
+
return this._paste(partDocData);
|
|
397
521
|
}
|
|
398
522
|
async legacyPaste(html, text) {
|
|
399
|
-
const
|
|
400
|
-
return this._paste(
|
|
523
|
+
const partDocData = this._genDocDataFromHtmlAndText(html, text);
|
|
524
|
+
return this._paste(partDocData);
|
|
401
525
|
}
|
|
402
526
|
async _cut() {
|
|
403
|
-
var
|
|
527
|
+
var _a23, _b, _c;
|
|
404
528
|
const {
|
|
405
529
|
segmentId,
|
|
406
530
|
endOffset: activeEndOffset,
|
|
407
531
|
style
|
|
408
|
-
} = (
|
|
409
|
-
if (segmentId == null && this._logService.error("[DocClipboardController] segmentId is not existed"),
|
|
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 =
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
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(
|
|
431
|
-
var
|
|
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 = (
|
|
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.
|
|
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, {
|
|
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
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
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
|
|
651
|
+
return {
|
|
652
|
+
bodyList: results,
|
|
653
|
+
needCache
|
|
654
|
+
};
|
|
497
655
|
}
|
|
498
|
-
async
|
|
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.
|
|
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
|
-
|
|
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$
|
|
551
|
-
__decorateParam$
|
|
552
|
-
__decorateParam$
|
|
553
|
-
__decorateParam$
|
|
554
|
-
__decorateParam$
|
|
555
|
-
__decorateParam$
|
|
556
|
-
__decorateParam$
|
|
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$
|
|
559
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
562
|
-
}, "__decorateClass$
|
|
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
|
|
579
|
-
const docSkeletonManagerService = (
|
|
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
|
|
587
|
-
const docObject = this._getDocObject(), docSkeletonManagerService = (
|
|
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.
|
|
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$
|
|
618
|
-
__decorateParam$
|
|
619
|
-
__decorateParam$
|
|
620
|
-
__decorateParam$
|
|
621
|
-
__decorateParam$
|
|
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$
|
|
731
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
734
|
-
}, "__decorateClass$
|
|
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$
|
|
775
|
-
__decorateParam$
|
|
776
|
-
__decorateParam$
|
|
932
|
+
DocContainerUIController = __decorateClass$j([
|
|
933
|
+
__decorateParam$j(1, Inject(LocaleService)),
|
|
934
|
+
__decorateParam$j(2, Inject(Injector))
|
|
777
935
|
], DocContainerUIController);
|
|
778
|
-
var __defProp$
|
|
779
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
782
|
-
}, "__decorateClass$
|
|
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$
|
|
810
|
-
__decorateParam$
|
|
811
|
-
__decorateParam$
|
|
812
|
-
__decorateParam$
|
|
813
|
-
__decorateParam$
|
|
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
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
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(
|
|
876
|
-
function
|
|
877
|
-
|
|
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(
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
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
|
|
918
|
-
const charWidth = ctx.measureText(
|
|
1092
|
+
for (const element2 of text) {
|
|
1093
|
+
const charWidth = ctx.measureText(element2).width;
|
|
919
1094
|
if (currentWidth + charWidth <= maxTextWidth - ctx.measureText("...").width)
|
|
920
|
-
truncatedText +=
|
|
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"
|
|
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
|
|
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 = (
|
|
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.
|
|
1182
|
+
}), textSelectionRenderService.removeAllRanges(), textSelectionRenderService.blur();
|
|
983
1183
|
}, "handleMarginChange"), closeHeaderFooter = /* @__PURE__ */ __name(() => {
|
|
984
|
-
var
|
|
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(),
|
|
989
|
-
|
|
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 {
|
|
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
|
|
1063
|
-
const localeService = useDependency(LocaleService), renderManagerService = useDependency(IRenderManagerService), unitId = useDependency(IUniverInstanceService).getCurrentUniverDocInstance().getUnitId(), viewModel = ((
|
|
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")
|
|
1075
|
-
|
|
1076
|
-
|
|
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$
|
|
1101
|
-
}, "__decorateClass$
|
|
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.
|
|
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$
|
|
1300
|
-
__decorateParam$
|
|
1301
|
-
__decorateParam$
|
|
1302
|
-
__decorateParam$
|
|
1303
|
-
__decorateParam$
|
|
1304
|
-
__decorateParam$
|
|
1305
|
-
__decorateParam$
|
|
1306
|
-
__decorateParam$
|
|
1307
|
-
__decorateParam$
|
|
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
|
|
1391
|
-
const commandService = accessor.get(ICommandService), univerInstanceService = accessor.get(IUniverInstanceService), renderManagerService = accessor.get(IRenderManagerService), { unitId, segmentId, createType, headerFooterProps } = params, docSkeletonManagerService = (
|
|
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
|
-
|
|
1429
|
-
|
|
1430
|
-
|
|
1431
|
-
|
|
1432
|
-
|
|
1433
|
-
|
|
1434
|
-
|
|
1435
|
-
|
|
1436
|
-
|
|
1437
|
-
|
|
1438
|
-
|
|
1439
|
-
const
|
|
1440
|
-
|
|
1441
|
-
|
|
1442
|
-
|
|
1443
|
-
|
|
1444
|
-
|
|
1445
|
-
|
|
1446
|
-
|
|
1447
|
-
|
|
1448
|
-
|
|
1449
|
-
|
|
1450
|
-
|
|
1451
|
-
|
|
1452
|
-
|
|
1453
|
-
|
|
1454
|
-
|
|
1455
|
-
|
|
1456
|
-
|
|
1457
|
-
|
|
1458
|
-
|
|
1459
|
-
|
|
1460
|
-
|
|
1461
|
-
|
|
1462
|
-
|
|
1463
|
-
|
|
1464
|
-
|
|
1465
|
-
|
|
1466
|
-
|
|
1467
|
-
|
|
1468
|
-
|
|
1469
|
-
|
|
1470
|
-
|
|
1471
|
-
|
|
1472
|
-
|
|
1473
|
-
|
|
1474
|
-
|
|
1475
|
-
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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
|
|
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 = (
|
|
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.
|
|
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.
|
|
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
|
|
1882
|
-
const univerInstanceService = accessor.get(IUniverInstanceService), textSelectionService = accessor.get(TextSelectionManagerService), docDataModel = univerInstanceService.getCurrentUniverDocInstance(), activeTextRange = textSelectionService.
|
|
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 = (
|
|
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
|
|
1905
|
-
const univerInstanceService = accessor.get(IUniverInstanceService), textSelectionService = accessor.get(TextSelectionManagerService), docDataModel = univerInstanceService.getCurrentUniverDocInstance(), activeTextRange = textSelectionService.
|
|
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 = (
|
|
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((
|
|
1956
|
-
const range = textSelectionManagerService.
|
|
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")
|
|
1962
|
-
|
|
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"),
|
|
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"),
|
|
1997
|
-
|
|
1998
|
-
|
|
1999
|
-
|
|
2000
|
-
|
|
2001
|
-
|
|
2002
|
-
|
|
2003
|
-
|
|
2004
|
-
|
|
2005
|
-
|
|
2006
|
-
|
|
2007
|
-
|
|
2008
|
-
|
|
2009
|
-
|
|
2010
|
-
|
|
2011
|
-
|
|
2012
|
-
|
|
2013
|
-
|
|
2014
|
-
|
|
2015
|
-
|
|
2016
|
-
|
|
2017
|
-
|
|
2018
|
-
|
|
2019
|
-
|
|
2020
|
-
|
|
2021
|
-
|
|
2022
|
-
|
|
2023
|
-
|
|
2024
|
-
|
|
2025
|
-
|
|
2026
|
-
|
|
2027
|
-
|
|
2028
|
-
|
|
2029
|
-
|
|
2030
|
-
|
|
2031
|
-
|
|
2032
|
-
|
|
2033
|
-
|
|
2034
|
-
|
|
2035
|
-
|
|
2036
|
-
|
|
2037
|
-
|
|
2038
|
-
|
|
2039
|
-
|
|
2040
|
-
|
|
2041
|
-
|
|
2042
|
-
|
|
2043
|
-
|
|
2044
|
-
|
|
2045
|
-
|
|
2046
|
-
|
|
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$
|
|
2049
|
-
}, "__decorateClass$
|
|
2050
|
-
let DocUIController = (
|
|
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
|
|
3018
|
+
var _a23, _b;
|
|
2060
3019
|
const workbook = this._univerInstanceService.getCurrentUnitForType(UniverInstanceType.UNIVER_SHEET);
|
|
2061
|
-
(_b = (
|
|
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(
|
|
2127
|
-
DocUIController = __decorateClass$
|
|
3106
|
+
}, __name(_a7, "DocUIController"), _a7);
|
|
3107
|
+
DocUIController = __decorateClass$f([
|
|
2128
3108
|
OnLifecycle(LifecycleStages.Rendered, DocUIController),
|
|
2129
|
-
__decorateParam$
|
|
2130
|
-
__decorateParam$
|
|
2131
|
-
__decorateParam$
|
|
2132
|
-
__decorateParam$
|
|
2133
|
-
__decorateParam$
|
|
2134
|
-
__decorateParam$
|
|
2135
|
-
__decorateParam$
|
|
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:
|
|
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$
|
|
2151
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2154
|
-
}, "__decorateClass$
|
|
2155
|
-
let DocClipboardController = (
|
|
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
|
|
2164
|
-
(
|
|
2165
|
-
var
|
|
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 = (
|
|
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(
|
|
2174
|
-
DocClipboardController = __decorateClass$
|
|
3154
|
+
}, __name(_a8, "DocClipboardController"), _a8);
|
|
3155
|
+
DocClipboardController = __decorateClass$e([
|
|
2175
3156
|
OnLifecycle(LifecycleStages.Rendered, DocClipboardController),
|
|
2176
|
-
__decorateParam$
|
|
2177
|
-
__decorateParam$
|
|
2178
|
-
__decorateParam$
|
|
2179
|
-
__decorateParam$
|
|
2180
|
-
__decorateParam$
|
|
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$
|
|
2183
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2186
|
-
}, "__decorateClass$
|
|
2187
|
-
let DocEditorBridgeController = (
|
|
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
|
|
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 = (
|
|
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.
|
|
3223
|
+
this._textSelectionRenderManager.removeAllRanges(), this._textSelectionRenderManager.blur();
|
|
2243
3224
|
})
|
|
2244
3225
|
), this.disposeWithMe(
|
|
2245
3226
|
this._textSelectionRenderManager.onBlur$.subscribe(() => {
|
|
2246
|
-
var
|
|
2247
|
-
const unitId = (
|
|
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.
|
|
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(),
|
|
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
|
|
2296
|
-
const unitId = (
|
|
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(
|
|
2319
|
-
DocEditorBridgeController = __decorateClass$
|
|
3299
|
+
}, __name(_a9, "DocEditorBridgeController"), _a9);
|
|
3300
|
+
DocEditorBridgeController = __decorateClass$d([
|
|
2320
3301
|
OnLifecycle(LifecycleStages.Rendered, DocEditorBridgeController),
|
|
2321
|
-
__decorateParam$
|
|
2322
|
-
__decorateParam$
|
|
2323
|
-
__decorateParam$
|
|
2324
|
-
__decorateParam$
|
|
2325
|
-
__decorateParam$
|
|
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$
|
|
2328
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2331
|
-
}, "__decorateClass$
|
|
2332
|
-
let DocRenderController = (
|
|
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
|
|
2338
|
-
const docSkeletonManagerService = (
|
|
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
|
|
2403
|
-
const { mainComponent, scene, unitId, components } = this._context, docsComponent = mainComponent, docBackground = components.get(DOCS_VIEW_KEY.BACKGROUND), 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(
|
|
2414
|
-
DocRenderController = __decorateClass$
|
|
2415
|
-
__decorateParam$
|
|
2416
|
-
__decorateParam$
|
|
2417
|
-
__decorateParam$
|
|
2418
|
-
__decorateParam$
|
|
2419
|
-
__decorateParam$
|
|
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
|
|
2427
|
-
const docObject = neoGetDocObject(this._context), zoomRatio = (_b = (
|
|
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$
|
|
2442
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2445
|
-
}, "__decorateClass$
|
|
2446
|
-
let DocZoomRenderController = (
|
|
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.
|
|
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
|
|
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
|
|
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(), (
|
|
2504
|
-
}
|
|
2505
|
-
}, __name(
|
|
2506
|
-
DocZoomRenderController = __decorateClass$
|
|
2507
|
-
__decorateParam$
|
|
2508
|
-
__decorateParam$
|
|
2509
|
-
__decorateParam$
|
|
2510
|
-
__decorateParam$
|
|
2511
|
-
__decorateParam$
|
|
2512
|
-
__decorateParam$
|
|
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$
|
|
2515
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2518
|
-
}, "__decorateClass$
|
|
2519
|
-
let DocTextSelectionRenderController = (
|
|
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.
|
|
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
|
|
3567
|
+
var _a23;
|
|
2591
3568
|
if (updateCommandList.includes(command.id)) {
|
|
2592
|
-
const params = command.params, { unitId: documentId } = params, 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
|
-
|
|
2602
|
-
|
|
2603
|
-
|
|
2604
|
-
|
|
2605
|
-
|
|
2606
|
-
|
|
2607
|
-
|
|
2608
|
-
|
|
2609
|
-
|
|
2610
|
-
|
|
2611
|
-
|
|
2612
|
-
|
|
2613
|
-
|
|
2614
|
-
|
|
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(
|
|
2619
|
-
DocTextSelectionRenderController = __decorateClass$
|
|
2620
|
-
__decorateParam$
|
|
2621
|
-
__decorateParam$
|
|
2622
|
-
__decorateParam$
|
|
2623
|
-
__decorateParam$
|
|
2624
|
-
__decorateParam$
|
|
2625
|
-
__decorateParam$
|
|
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$
|
|
2628
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2631
|
-
}, "__decorateClass$
|
|
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
|
|
2657
|
-
let DocCanvasPopManagerService = (
|
|
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
|
|
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), {
|
|
2696
|
-
return getLineBounding(
|
|
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 = (
|
|
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(
|
|
2769
|
-
DocCanvasPopManagerService = __decorateClass$
|
|
2770
|
-
__decorateParam$
|
|
2771
|
-
__decorateParam$
|
|
2772
|
-
__decorateParam$
|
|
2773
|
-
__decorateParam$
|
|
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$
|
|
2776
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2779
|
-
}, "__decorateClass$
|
|
2780
|
-
let DocsRenderService = (
|
|
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.
|
|
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(
|
|
2799
|
-
DocsRenderService = __decorateClass$
|
|
3773
|
+
}, __name(_a14, "DocsRenderService"), _a14);
|
|
3774
|
+
DocsRenderService = __decorateClass$8([
|
|
2800
3775
|
OnLifecycle(LifecycleStages.Ready, DocsRenderService),
|
|
2801
|
-
__decorateParam$
|
|
2802
|
-
__decorateParam$
|
|
3776
|
+
__decorateParam$8(0, IUniverInstanceService),
|
|
3777
|
+
__decorateParam$8(1, IRenderManagerService)
|
|
2803
3778
|
], DocsRenderService);
|
|
2804
|
-
var __defProp$
|
|
2805
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2808
|
-
}, "__decorateClass$
|
|
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
|
|
2816
|
-
let DocContextMenuRenderController = (
|
|
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
|
|
2822
|
-
const documentsSubscription = ((_b = (
|
|
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(
|
|
2835
|
-
DocContextMenuRenderController = __decorateClass$
|
|
2836
|
-
__decorateParam$
|
|
2837
|
-
__decorateParam$
|
|
2838
|
-
__decorateParam$
|
|
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$
|
|
2841
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2844
|
-
}, "__decorateClass$
|
|
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
|
|
2851
|
-
let DocResizeRenderController = (
|
|
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(
|
|
2866
|
-
DocResizeRenderController = __decorateClass$
|
|
2867
|
-
__decorateParam$
|
|
2868
|
-
__decorateParam$
|
|
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$
|
|
2871
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2874
|
-
}, "__decorateClass$
|
|
2875
|
-
let DocHoverManagerService = (
|
|
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
|
|
3853
|
+
__publicField(this, "_activeCustomRanges$", new Subject());
|
|
2879
3854
|
__publicField(this, "activeCustomRanges$", this._activeCustomRanges$.asObservable());
|
|
2880
|
-
__publicField(this, "_activeIndex$", new
|
|
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
|
|
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
|
-
|
|
2919
|
-
|
|
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
|
-
|
|
2923
|
-
|
|
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(
|
|
2943
|
-
DocHoverManagerService = __decorateClass$
|
|
2944
|
-
__decorateParam$
|
|
2945
|
-
__decorateParam$
|
|
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$
|
|
2948
|
-
for (var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$
|
|
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$
|
|
2951
|
-
}, "__decorateClass$
|
|
2952
|
-
let DocHoverRenderController = (
|
|
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(
|
|
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(
|
|
2972
|
-
DocHoverRenderController = __decorateClass$
|
|
2973
|
-
__decorateParam$
|
|
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"),
|
|
2980
|
-
let UniverDocsUIPlugin = (
|
|
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.
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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(
|
|
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,
|
|
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,
|