var Fa = Object.defineProperty;
var Ha = (n, e, t) => e in n ? Fa(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t;
var x = (n, e, t) => Ha(n, typeof e != "symbol" ? e + "" : e, t);
import { Inject as z, Disposable as ue, toDisposable as Zn, UniverInstanceType as _, BuildTextUtils as Ce, IUniverInstanceService as Q, JSONX as k, ObjectRelativeFromH as $n, ObjectRelativeFromV as ot, useDependency as $, ICommandService as y, generateRandomId as pt, DisposableCollection as Dn, CommandType as N, debounce as fi, Tools as X, IUndoRedoService as eo, TextX as me, TextXActionType as W, DOC_RANGE_TYPE as Ge, RANGE_DIRECTION as xe, COLORS as tn, BooleanNumber as L, Rectangle as ka, RxDisposable as At, DataStreamTreeTokenType as U, ILogService as fs, isInternalEditorID as to, createIdentifier as ps, EDITOR_ACTIVATED as wn, FOCUSING_EDITOR_STANDALONE as lr, DEFAULT_EMPTY_DOCUMENT_VALUE as pi, VerticalAlign as Va, HorizontalAlign as _e, IContextService as ms, Direction as se, createInternalEditorID as ja, useObservable as Nn, LocaleService as Ze, DocumentFlavor as ye, PresetListType as Oe, sequenceExecuteAsync as Es, FOCUSING_DOC as hn, FOCUSING_UNIVER_EDITOR as Ss, FOCUSING_COMMON_DRAWINGS as mi, MemoryCursor as St, BaselineOffset as Ne, getBodySlice as Ei, PRESET_LIST_TYPE as Wa, GridType as za, sortRulesFactory as Ga, UpdateDocsAttributeType as no, TableRowHeightRule as Ya, TableSizeType as Si, TableAlignmentType as qa, TableTextWrapType as Ka, SHEET_EDITOR_UNITS as Is, PositionedObjectLayoutType as oo, LRUMap as Xa, ColorKit as dr, DrawingTypeEnum as Cs, skipParseTagNames as Ja, CustomRangeType as Ii, DataStreamTreeNodeType as qt, SliceBodyType as ur, DOCS_NORMAL_EDITOR_UNIT_ID_KEY as vs, normalizeBody as Za, SpacingRule as Bt, DEFAULT_STYLES as Ci, ThemeService as vi, DOCS_ZEN_EDITOR_UNIT_ID_KEY as $e, Injector as so, connectInjector as $a, IConfigService as Rs, QuickListTypeMap as bo, fromEventSubject as nn, DOCS_FORMULA_BAR_EDITOR_UNIT_ID_KEY as ec, checkForSubstrings as tc, UndoCommandId as hr, RedoCommandId as gr, DependentOn as nc, Plugin as oc, merge as sc, touchDependencies as fr, mergeOverrideWithDependencies as rc } from "@univerjs/core";
import { DocSelectionManagerService as G, RichTextEditingMutation as J, DocSkeletonManagerService as ie, SetTextSelectionsOperation as De, DocStateEmitService as ic, DocInterceptorService as ac } from "@univerjs/docs";
import { DeviceInputEventType as Ri, ScrollBar as Vo, IRenderManagerService as fe, Liquid as bi, GlyphType as xi, DocumentSkeletonPageType as Ie, getPageFromPath as jo, getTableIdAndSliceIndex as pr, NORMAL_TEXT_SELECTION_PLUGIN_STYLE as sn, getColor as on, RegularPolygon as Oi, Rect as yn, getOffsetRectForDom as cc, ScrollTimer as Ac, CURSOR_TYPE as mt, getSystemHighlightColor as lc, Vector2 as rn, PageLayoutType as an, DocumentEditArea as ge, Shape as dc, Path as mr, getCharSpaceApply as uc, getNumberUnitValue as ze, hasListGlyph as hc, isIndentByGlyph as gc, isFirstGlyph as fc, getParagraphByGlyph as pc, pixelToPt as mc, ptToPixel as Er, parseDataStreamToTree as Ec, Viewport as Sc, Layer as Sr, Documents as Ic, DocBackground as Cc, lineIterator as vc, getLastColumn as Rc, getLastLine as bc, pxToNum as Ti, TRANSFORM_CHANGE_OBSERVABLE_TYPE as yi, UniverRenderEnginePlugin as xc } from "@univerjs/engine-render";
import { IShortcutService as ro, KeyCode as j, ILayoutService as bs, MetaKeys as K, useEvent as xo, ComponentManager as io, ISidebarService as Bi, IClipboardInterfaceService as Mi, FILE_PNG_CLIPBOARD_MIME_TYPE as _i, FILE__WEBP_CLIPBOARD_MIME_TYPE as Pi, FILE__JPEG_CLIPBOARD_MIME_TYPE as Di, FILE__BMP_CLIPBOARD_MIME_TYPE as wi, HTML_CLIPBOARD_MIME_TYPE as Ni, PLAIN_TEXT_CLIPBOARD_MIME_TYPE as Qi, CopyCommand as Oc, CutCommand as Tc, PasteCommand as yc, IConfirmService as Bc, MenuItemType as Z, getMenuHiddenObservable as ee, FONT_FAMILY_LIST as Mc, FONT_SIZE_LIST as _c, RibbonStartGroup as Ir, ContextMenuPosition as Ui, ContextMenuGroup as Cr, FontFamily as Pc, FontFamilyItem as Dc, FontSize as wc, BuiltInUIPart as Nc, IMenuManagerService as Qc, IUIPartsService as Uc, ICanvasPopupService as Lc, IContextMenuService as Fc } from "@univerjs/ui";
import * as Hc from "react";
import Wo, { useMemo as Fe, useEffect as Re, useCallback as Li, useState as ve, useLayoutEffect as kc, useRef as cn, forwardRef as It, useImperativeHandle as Vc, createElement as Ft } from "react";
import { Subject as Ee, BehaviorSubject as Le, merge as Fi, filter as Qn, takeUntil as st, fromEvent as Ue, combineLatest as ao, Observable as pe, map as gn, distinctUntilChanged as vr, throttleTime as Hi, switchMap as jc, take as Wc, animationFrameScheduler as zc } from "rxjs";
import { filter as zo, bufferTime as Gc, map as Yc } from "rxjs/operators";
import { Checkbox as Rr, InputNumber as An, Button as qc, Slider as Kc, Tooltip as Xc, Select as Jc, ColorPicker as Zc } from "@univerjs/design";
import { ImageSourceType as xs } from "@univerjs/drawing";
var $c = Object.defineProperty, eA = Object.getOwnPropertyDescriptor, tA = (n, e, t, o) => {
for (var s = o > 1 ? void 0 : o ? eA(e, t) : e, r = n.length - 1, i; r >= 0; r--)
(i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
return o && s && $c(e, t, s), s;
}, br = (n, e) => (t, o) => e(t, o, n);
function nA(n, e) {
var i, a;
const { startOffset: t, endOffset: o } = n, s = [];
let r = -1;
for (let c = 0; c < e.length; c++) {
const A = e[c], l = e[c - 1], { startIndex: d } = A;
t > r && t <= d || o > r && o <= d ? s.push({
...A,
paragraphStart: ((i = l == null ? void 0 : l.startIndex) != null ? i : -1) + 1,
paragraphEnd: A.startIndex
}) : d >= t && d <= o && s.push({
...A,
paragraphStart: ((a = l == null ? void 0 : l.startIndex) != null ? a : -1) + 1,
paragraphEnd: A.startIndex
}), r = d;
}
return s;
}
let Et = class extends ue {
constructor(e, t) {
super();
x(this, "_matches", /* @__PURE__ */ new Map());
this._univerInstanceService = e, this._textSelectionManagerService = t;
}
registerAutoFormat(e) {
const t = this._matches.get(e.id);
return t ? (t.push(e), t.sort((o, s) => {
var r, i;
return ((r = s.priority) != null ? r : 0) - ((i = o.priority) != null ? i : 0);
})) : this._matches.set(e.id, [e]), Zn(() => {
const o = this._matches.get(e.id);
if (o) {
const s = o.findIndex((r) => r === e);
s >= 0 && o.splice(s, 1);
}
});
}
onAutoFormat(e, t) {
var a, c, A, l, d, h, u;
const o = (a = this._matches.get(e)) != null ? a : [], s = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC), r = this._textSelectionManagerService.getDocRanges(), i = (c = r.find((g) => g.isActive)) != null ? c : r[0];
if (s && i) {
const g = s.getSelfOrHeaderFooterModel(i.segmentId), f = {
unit: g,
selection: i,
isBody: !i.segmentId,
paragraphs: nA(i, (l = (A = g.getBody()) == null ? void 0 : A.paragraphs) != null ? l : []),
customRanges: Ce.customRange.getCustomRangesInterestsWithSelection(i, (h = (d = g.getBody()) == null ? void 0 : d.customRanges) != null ? h : []),
commandId: e,
commandParams: t
}, p = o.find((m) => m.match(f));
return (u = p == null ? void 0 : p.getMutations(f)) != null ? u : [];
}
return [];
}
};
Et = tA([
br(0, Q),
br(1, z(G))
], Et);
const oA = {
undo: !0,
redo: !0,
// Undo redo
font: !0,
// 'font'
fontSize: !0,
// 'Font size'
bold: !0,
// 'Bold (Ctrl+B)'
italic: !0,
// 'Italic (Ctrl+I)'
strikethrough: !0,
// 'Strikethrough (Alt+Shift+5)'
underline: !0,
// 'Underline (Alt+Shift+6)'
textColor: !0,
// 'Text color'
fillColor: !0,
// 'Cell color'
horizontalAlignMode: !0,
// 'Horizontal alignment'
verticalAlignMode: !0,
// 'Vertical alignment'
textWrapMode: !0,
// 'Wrap mode'
textRotateMode: !0
// 'Text Rotation Mode'
}, sA = {
outerLeft: !1,
outerRight: !1,
header: !0,
footer: !0,
innerLeft: !1,
innerRight: !1,
frozenHeaderLT: !1,
frozenHeaderRT: !1,
frozenHeaderLM: !1,
frozenContent: !1,
infoBar: !0,
toolbar: !0
}, rA = "DOC_UI_PLUGIN";
var We = /* @__PURE__ */ ((n) => (n.MAIN = "__Document_Render_Main__", n.BACKGROUND = "__Document_Render_Background__", n))(We || {}), Xe = /* @__PURE__ */ ((n) => (n.VIEW_MAIN = "viewMain", n.VIEW_TOP = "viewTop", n.VIEW_LEFT = "viewLeft", n.VIEW_LEFT_TOP = "viewLeftTop", n))(Xe || {});
const iA = 0, Oo = 2, aA = 4, xr = 10, ef = "normalTextSelectionPluginName";
function rt(n) {
const { mainComponent: e, scene: t, engine: o, components: s } = n, r = e, i = s.get(We.BACKGROUND);
return {
document: r,
docBackground: i,
scene: t,
engine: o
};
}
function cA(n, e) {
const t = n.getCurrentUnitForType(_.UNIVER_DOC);
if (!t)
return null;
const o = t.getUnitId(), s = e.getRenderById(o);
if (s == null)
return;
const { mainComponent: r, scene: i, engine: a, components: c } = s, A = r, l = c.get(We.BACKGROUND);
return {
document: A,
docBackground: l,
scene: i,
engine: a
};
}
function tf(n, e) {
const t = e.getRenderById(n);
if (t == null)
return;
const { mainComponent: o, scene: s, engine: r, components: i } = t, a = o, c = i.get(We.BACKGROUND);
return {
document: a,
docBackground: c,
scene: s,
engine: r
};
}
function AA(n) {
const { unitId: e, ranges: t, id: o, type: s, segmentId: r } = n, i = {
id: J.id,
params: {
unitId: e,
actions: [],
textRanges: void 0,
// noHistory: true,
segmentId: r
}
}, a = k.getInstance(), c = Ce.customDecoration.add({ ranges: t, id: o, type: s });
return i.params.actions = a.editOp(c.serialize()), i;
}
function nf(n, e) {
const { segmentId: t, id: o, type: s, unitId: r } = e, i = n.get(G), a = n.get(Q), c = r ? a.getUnit(r, _.UNIVER_DOC) : a.getCurrentUnitForType(_.UNIVER_DOC);
if (!c)
return !1;
const A = c.getUnitId(), l = i.getTextRanges({ unitId: A, subUnitId: A });
return !l || !c.getBody() ? !1 : AA(
{
unitId: A,
ranges: l,
id: o,
type: s,
segmentId: t
}
);
}
function of(n, e) {
const { unitId: t, id: o, segmentId: s } = e, i = n.get(Q).getUnit(t);
if (!i)
return !1;
const a = {
id: J.id,
params: {
unitId: t,
actions: [],
textRanges: void 0,
// noHistory: true,
segmentId: s
}
}, c = Ce.customDecoration.delete({ id: o, segmentId: s, documentDataModel: i });
if (!c)
return !1;
const A = k.getInstance();
return a.params.actions = A.editOp(c.serialize()), a;
}
function sf(n, e) {
return e.some((t) => n.startIndex > t.startIndex && n.startIndex < t.endIndex);
}
function co(n, e, t, o) {
const s = {
st: 0,
ed: 0,
ts: t
};
for (let r = n.length - 1; r >= 0; r--) {
const i = n[r], { st: a, ed: c } = i;
e > a && e <= c && (s.st = a, s.ed = c, s.ts = {
...s.ts,
...i.ts
});
}
if (e === 0) {
const r = n == null ? void 0 : n[0];
r && r.st === 0 && (s.ts = {
...s.ts,
...r.ts
});
}
return o && (s.ts = {
...s.ts,
...o
}), s;
}
function Os(n, e, t) {
if (t) {
const s = n.find((r) => e >= r.startIndex && e <= r.endIndex + 1);
return s != null && s.wholeEntity ? null : s;
}
const o = n.find((s) => e > s.startIndex && e <= s.endIndex);
return o != null && o.wholeEntity ? null : o;
}
function Ts(n, e) {
return n.filter((t) => e > t.startIndex && e <= t.endIndex);
}
function rf(n) {
return {
left: n.positionH.posOffset,
top: n.positionV.posOffset,
width: n.size.width,
height: n.size.height
};
}
function af(n, e = 0, t = 0) {
return {
size: {
width: n.width,
height: n.height
},
positionH: {
relativeFrom: $n.MARGIN,
posOffset: (n.left || 0) - e
},
positionV: {
relativeFrom: ot.PAGE,
posOffset: (n.top || 0) - t
},
angle: n.angle || 0
};
}
function lA(n, e, t) {
const o = $(y), s = $(ro), r = Fe(() => pt(4), []);
Re(() => {
if (!t || !n || !e)
return;
const a = `sheet.operation.editor-${t.getEditorId()}-keyboard-${r}`, c = new Dn();
return c.add(o.registerCommand({
id: a,
type: N.OPERATION,
handler(A, l) {
const { keyCode: d, metaKey: h } = l;
e.handler(d, h);
}
})), e.keyCodes.map((A) => ({
id: a,
binding: A.metaKey ? A.keyCode | A.metaKey : A.keyCode,
preconditions: () => !0,
priority: 901,
staticParameters: {
eventType: Ri.Keyboard,
keyCode: A.keyCode,
metaKey: A.metaKey
}
})).forEach((A) => {
c.add(s.registerShortcut(A));
}), () => {
c.dispose();
};
}, [o, e, t, n, r, s]);
}
const dA = (n, e = !0, t, o) => {
const s = Li(() => {
if (n) {
const { scene: i, mainComponent: a } = n.render, c = n.render.with(ie), { width: A, height: l } = n.getBoundingClientRect();
c.getViewModel().getDataModel().updateDocumentDataPageSize(e ? 1 / 0 : A, 1 / 0), i.transformByState({
width: A,
height: l
}), a == null || a.resize(A, l);
}
}, [n, e]), r = Fe(() => fi(() => {
var E, I;
if (!t || !n || !t)
return;
const a = n.render.with(ie).getSkeleton(), { scene: c, mainComponent: A } = n.render, l = c.getViewport(Xe.VIEW_MAIN), { actualWidth: d, actualHeight: h } = a.getActualSize(), { width: u, height: g } = n.getBoundingClientRect();
let f = l == null ? void 0 : l.getScrollBar();
const p = Math.max(d, u), m = Math.max(h, g);
c.transformByState({
width: p,
height: m
}), A == null || A.resize(p, m), e ? d > u ? (f == null ? l && new Vo(l, {
barSize: 8,
enableVertical: !1,
enableHorizontal: !0,
minThumbSizeV: 8
}) : l == null || l.resetCanvasSizeAndUpdateScroll(), o && (l == null || l.scrollToBarPos({ x: 1 / 0, y: 0 }))) : (f = null, l == null || l.scrollToBarPos({ x: 0, y: 0 }), (I = l == null ? void 0 : l.getScrollBar()) == null || I.dispose()) : h > g ? (f == null ? l && (f = new Vo(l, {
enableHorizontal: !1,
enableVertical: !0,
barSize: 8,
minThumbSizeV: 8
})) : l == null || l.resetCanvasSizeAndUpdateScroll(), o && (l == null || l.scrollToBarPos({ x: 0, y: 1 / 0 }))) : (f = null, l == null || l.scrollToBarPos({ x: 0, y: 0 }), (E = l == null ? void 0 : l.getScrollBar()) == null || E.dispose());
}, 30), [n, t, e, o]);
return Re(() => {
if (t && n) {
const i = setTimeout(() => {
s(), r();
}, 500);
return () => {
clearTimeout(i);
};
}
}, [n, t, s, r]), Re(() => {
if (t && n) {
const i = n.input$.subscribe(() => {
r();
});
return () => {
i.unsubscribe();
};
}
}, [n, t, r]), { resize: s, checkScrollBar: r };
};
var To = { exports: {} }, Kt = {};
/**
* @license React
* react-jsx-runtime.production.min.js
*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
var Or;
function uA() {
if (Or) return Kt;
Or = 1;
var n = Wo, e = Symbol.for("react.element"), t = Symbol.for("react.fragment"), o = Object.prototype.hasOwnProperty, s = n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, r = { key: !0, ref: !0, __self: !0, __source: !0 };
function i(a, c, A) {
var l, d = {}, h = null, u = null;
A !== void 0 && (h = "" + A), c.key !== void 0 && (h = "" + c.key), c.ref !== void 0 && (u = c.ref);
for (l in c) o.call(c, l) && !r.hasOwnProperty(l) && (d[l] = c[l]);
if (a && a.defaultProps) for (l in c = a.defaultProps, c) d[l] === void 0 && (d[l] = c[l]);
return { $$typeof: e, type: a, key: h, ref: u, props: d, _owner: s.current };
}
return Kt.Fragment = t, Kt.jsx = i, Kt.jsxs = i, Kt;
}
var Tr;
function hA() {
return Tr || (Tr = 1, To.exports = uA()), To.exports;
}
var w = hA();
function ki(n) {
var e, t, o = "";
if (typeof n == "string" || typeof n == "number") o += n;
else if (typeof n == "object") if (Array.isArray(n)) {
var s = n.length;
for (e = 0; e < s; e++) n[e] && (t = ki(n[e])) && (o && (o += " "), o += t);
} else for (t in n) n[t] && (o && (o += " "), o += t);
return o;
}
function Un() {
for (var n, e, t = 0, o = "", s = arguments.length; t < s; t++) (n = arguments[t]) && (e = ki(n)) && (o && (o += " "), o += e);
return o;
}
function ke(n, e) {
var o;
return (o = n.get(fe).getRenderById(e)) == null ? void 0 : o.with(ie);
}
function le(n, e = "") {
if (!e)
return ["body"];
const { headers: t, footers: o } = n.getSnapshot();
if (t == null && o == null)
throw new Error("Document data model must have headers or footers when update by segment id");
if ((t == null ? void 0 : t[e]) != null)
return ["headers", e, "body"];
if ((o == null ? void 0 : o[e]) != null)
return ["footers", e, "body"];
throw new Error("Segment id not found in headers or footers");
}
const Vi = {
id: "doc.command-replace-snapshot",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function, complexity
handler: (n, e) => {
const { unitId: t, snapshot: o, textRanges: s, segmentId: r = "", options: i } = e, a = n.get(Q), c = n.get(y), A = n.get(G), l = a.getUnit(t, _.UNIVER_DOC), d = l == null ? void 0 : l.getSelfOrHeaderFooterModel(r).getSnapshot();
if (l == null || d == null)
return !1;
const { body: h, tableSource: u, footers: g, headers: f, lists: p, drawings: m, drawingsOrder: E, documentStyle: I } = X.deepClone(o), {
body: v,
tableSource: R,
footers: S,
headers: C,
lists: T,
drawings: O,
drawingsOrder: P,
documentStyle: b
} = d;
if (h == null || v == null)
return !1;
if (X.diffValue(h, v) && s)
return A.replaceDocRanges(s, {
unitId: t,
subUnitId: t
}, !1), !0;
const B = {
id: J.id,
params: {
unitId: t,
actions: [],
textRanges: s
}
};
i && (B.params.options = i);
const M = [], H = k.getInstance();
if (!X.diffValue(b, I)) {
const D = H.replaceOp(["documentStyle"], b, I);
D != null && M.push(D);
}
if (!X.diffValue(h, v)) {
const D = H.replaceOp(["body"], v, h);
D != null && M.push(D);
}
if (!X.diffValue(u, R)) {
const D = H.replaceOp(["tableSource"], R, u);
D != null && M.push(D);
}
if (!X.diffValue(g, S)) {
const D = H.replaceOp(["footers"], S, g);
D != null && M.push(D);
}
if (!X.diffValue(f, C)) {
const D = H.replaceOp(["headers"], C, f);
D != null && M.push(D);
}
if (!X.diffValue(p, T)) {
const D = H.replaceOp(["lists"], T, p);
D != null && M.push(D);
}
if (!X.diffValue(m, O)) {
const D = H.replaceOp(["drawings"], O, m);
D != null && M.push(D);
}
if (!X.diffValue(E, P)) {
const D = H.replaceOp(["drawingsOrder"], P, E);
D != null && M.push(D);
}
return B.params.actions = M.reduce((D, te) => k.compose(D, te), null), !!c.syncExecuteCommand(B.id, B.params);
}
}, gA = {
id: "doc.command-replace-content",
type: N.COMMAND,
handler: async (n, e) => {
const { unitId: t, body: o, textRanges: s, segmentId: r = "", options: i } = e, a = n.get(Q), c = n.get(y), A = n.get(G), l = a.getUnit(t, _.UNIVER_DOC), d = l == null ? void 0 : l.getSelfOrHeaderFooterModel(r).getSnapshot().body;
if (l == null || d == null)
return !1;
const h = ji(t, r, l, d, o);
return h.params.textRanges = s, i && (h.params.options = i), h.params.actions == null && s ? (A.replaceDocRanges(s, {
unitId: t,
subUnitId: t
}, !1), !0) : !!c.syncExecuteCommand(h.id, h.params);
}
}, fA = {
id: "doc.command-cover-content",
type: N.COMMAND,
handler: async (n, e) => {
const { unitId: t, body: o, segmentId: s = "" } = e, r = n.get(Q), i = n.get(y), a = n.get(eo), c = r.getUniverDocInstance(t), A = c == null ? void 0 : c.getSnapshot().body;
if (c == null || A == null)
return !1;
const l = ji(t, s, c, A, o);
return l.params.noNeedSetTextRange = !0, l.params.noHistory = !0, i.syncExecuteCommand(
l.id,
l.params
), a.clearUndoRedo(t), !0;
}
};
function pA(n, e, t, o) {
const s = new me(), r = k.getInstance(), i = (t == null ? void 0 : t.dataStream.length) - 2;
i > 0 && s.push({
t: W.DELETE,
len: i
}), o.dataStream.length > 0 && s.push({
t: W.INSERT,
body: o,
len: o.dataStream.length
});
const a = le(e, n);
return r.editOp(s.serialize(), a);
}
function ji(n, e, t, o, s) {
const r = {
id: J.id,
params: {
unitId: n,
actions: [],
textRanges: []
}
}, i = pA(e, t, o, s);
return r.params.actions = i, r;
}
N.COMMAND;
const mA = {
id: "doc.command.replace-text-runs",
type: N.COMMAND,
handler: (n, e) => {
const { unitId: t, body: o, textRanges: s, segmentId: r = "", options: i } = e, a = n.get(Q), c = n.get(y), A = a.getUnit(t, _.UNIVER_DOC), l = A == null ? void 0 : A.getSelfOrHeaderFooterModel(r).getSnapshot().body;
if (A == null || l == null)
return !1;
const d = Ce.selection.replaceTextRuns({
doc: A,
body: o,
selection: {
startOffset: 0,
endOffset: l.dataStream.length - 2,
collapsed: !1
}
});
if (!d)
return !1;
const h = {
id: J.id,
params: {
unitId: t,
actions: [],
textRanges: s,
noHistory: !0
}
}, u = k.getInstance(), g = le(A, r);
return h.params.actions = u.editOp(d.serialize(), g), h.params.textRanges = s, i && (h.params.options = i), !!c.syncExecuteCommand(h.id, h.params);
}
};
var Bn = /* @__PURE__ */ ((n) => (n[n.page = 0] = "page", n[n.section = 1] = "section", n[n.column = 2] = "column", n[n.line = 3] = "line", n[n.divide = 4] = "divide", n[n.glyph = 5] = "glyph", n))(Bn || {});
const Tt = {
page: 0,
section: 1,
column: 2,
line: 3,
divide: 4,
glyph: 5
};
function ys(n, e) {
return n.page > e.page ? !1 : n.page < e.page ? !0 : n.section > e.section ? !1 : n.section < e.section ? !0 : n.column > e.column ? !1 : n.column < e.column ? !0 : n.line > e.line ? !1 : n.line < e.line ? !0 : n.divide > e.divide ? !1 : n.divide < e.divide ? !0 : n.glyph > e.glyph ? !1 : (n.glyph < e.glyph, !0);
}
function Go(n, e) {
return ys(n, e) ? {
start: n,
end: e
} : {
start: e,
end: n
};
}
function yr(n) {
const e = n.length;
if (e === 0)
return;
const t = n[0], o = n[e - 1], s = n.length === 1 && t.collapsed;
return {
startOffset: t.startOffset,
endOffset: o.endOffset,
collapsed: s
};
}
function EA(n, e, t, o) {
let s = o, r = o;
for (let i = 0; i < n.length; i++) {
const c = n[i].count;
i < e && (s += c), i < t && (r += c);
}
return {
startOffset: s,
endOffset: r
};
}
function Yo(n) {
const { startX: e, startY: t, endX: o, endY: s } = n, r = [];
return r.push({
x: e,
y: t
}), r.push({
x: o,
y: t
}), r.push({
x: o,
y: s
}), r.push({
x: e,
y: s
}), r.push({
x: e,
y: t
}), r;
}
class it {
constructor(e, t) {
x(this, "_liquid", new bi());
x(this, "_currentStartState", {
page: 0,
section: 0,
column: 0,
line: 0,
divide: 0,
glyph: 0
/* NORMAL */
});
x(this, "_currentEndState", {
page: 0,
section: 0,
column: 0,
line: 0,
divide: 0,
glyph: 0
/* NORMAL */
});
this._documentOffsetConfig = e, this._docSkeleton = t;
}
// eslint-disable-next-line max-lines-per-function
getRangePointData(e, t) {
const o = [], s = [], r = [];
if (e == null || t == null)
return {
borderBoxPointGroup: o,
contentBoxPointGroup: s,
cursorList: r
};
if (!this._isValidPosition(e, t))
throw new Error(
`
Invalid positions in NodePositionConvertToCursor,
they are not in the same segment page when in header or footer.`
);
const { start: a, end: c } = Go(e, t);
return this._selectionIterator(a, c, (A, l, d, h, u, g) => {
const { lineHeight: f, asc: p, paddingTop: m, marginTop: E, marginBottom: I } = g, { glyphGroup: v, st: R } = u;
if (v.length === 0)
return;
const { x: S, y: C } = this._liquid;
let T, O;
const P = v[A], b = v[l], B = v[A - 1], M = (P == null ? void 0 : P.left) || 0, H = (P == null ? void 0 : P.width) || 0, F = (b == null ? void 0 : b.left) || 0, D = (b == null ? void 0 : b.width) || 0, te = (P == null ? void 0 : P.glyphType) === xi.LIST, { startOffset: q, endOffset: V } = EA(v, A, l, R), Y = a.glyph === A && d ? a.isBack : !0, oe = c.glyph === l && h ? c.isBack : !1, ce = a === c, he = Y && B != null ? B : P;
if (A === 0 && l === v.length - 1)
T = {
startX: S + M + (te ? H : 0),
startY: C,
endX: S + F + (oe ? 0 : D),
endY: C + f - E - I
}, O = {
startX: S + M + (te ? H : 0),
startY: C + m + p - he.bBox.ba,
endX: S + F + (oe ? 0 : D),
endY: C + m + p + he.bBox.bd
};
else {
const Ae = Y && !te;
T = {
startX: S + M + (Ae ? 0 : H),
startY: C,
endX: S + F + (oe ? 0 : D),
endY: C + f - E - I
}, O = {
startX: S + M + (Ae ? 0 : H),
startY: C + m + p - he.bBox.ba,
endX: S + F + (oe ? 0 : D),
endY: C + m + p + he.bBox.bd
};
}
o.push(Yo(T)), s.push(Yo(O)), r.push({
startOffset: Y ? q : q + P.count,
endOffset: oe ? V : V + b.count,
collapsed: ce
});
}), {
borderBoxPointGroup: o,
contentBoxPointGroup: s,
cursorList: r
};
}
_isValidPosition(e, t) {
const { segmentPage: o, pageType: s } = e, { segmentPage: r, pageType: i } = t;
return s !== i ? !1 : s === Ie.HEADER || s === Ie.FOOTER ? o === r : !0;
}
_resetCurrentNodePositionState() {
this._currentStartState = {
page: 0,
section: 0,
column: 0,
line: 0,
divide: 0,
glyph: 0
/* NORMAL */
}, this._currentEndState = {
page: 0,
section: 0,
column: 0,
line: 0,
divide: 0,
glyph: 0
/* NORMAL */
};
}
_setNodePositionState(e = 0, t, o, s) {
s === t ? this._currentStartState[e] = 1 : this._currentStartState[e] = 0, s === o ? this._currentEndState[e] = 2 : this._currentEndState[e] = 0;
}
_checkPreviousNodePositionState(e, t = !0) {
let o = e, s;
for (; o >= 0; ) {
const r = Bn[o];
let i;
if (t ? i = this._currentStartState[r] : i = this._currentEndState[r], i === void 0)
return;
if (s === void 0 && (s = i), i !== s)
return 0;
o--;
}
return s;
}
_getSelectionRuler(e, t, o, s, r) {
let i = 0, a = s;
const c = Bn[e], A = Bn[e + 1];
if (A === null || c === null)
return {
start_next: i,
end_next: a
};
const l = t[c], d = o[c];
this._setNodePositionState(c, l, d, r);
const h = this._checkPreviousNodePositionState(e), u = this._checkPreviousNodePositionState(e, !1);
return h === 1 && (i = t[A]), u === 2 && (a = o[A]), {
start_next: i,
end_next: a
};
}
// eslint-disable-next-line max-lines-per-function, complexity
_selectionIterator(e, t, o) {
var v, R;
const s = this._docSkeleton;
if (!s)
return [];
const { pageType: r, path: i } = e;
this._liquid.reset();
const a = s.getSkeletonData();
if (a == null)
return [];
const { pages: c, skeHeaders: A, skeFooters: l } = a, { page: d, segmentPage: h } = e, { page: u, segmentPage: g } = t;
if (this._resetCurrentNodePositionState(), this._documentOffsetConfig == null)
return [];
const { pageLayoutType: f, pageMarginLeft: p, pageMarginTop: m } = this._documentOffsetConfig, E = r === Ie.BODY || r === Ie.CELL ? d : h;
for (let S = 0; S < E; S++) {
const C = c[S];
this._liquid.translatePage(C, f, p, m);
}
const I = r === Ie.BODY || r === Ie.CELL ? u : g;
for (let S = E; S <= I; S++) {
const C = c[S], { headerId: T, footerId: O, pageWidth: P } = C;
let b = C;
if (r === Ie.HEADER ? b = (v = A.get(T)) == null ? void 0 : v.get(P) : r === Ie.FOOTER ? b = (R = l.get(O)) == null ? void 0 : R.get(P) : r === Ie.CELL && (b = jo(a, i)), b == null) {
this._liquid.translatePage(C, f, p, m);
continue;
}
const B = b.sections, { start_next: M, end_next: H } = this._getSelectionRuler(
Tt.page,
e,
t,
B.length - 1,
r === Ie.BODY || r === Ie.CELL ? S : 0
);
switch (this._liquid.translateSave(), r) {
case Ie.HEADER:
this._liquid.translatePagePadding({
...b,
marginLeft: C.marginLeft
// Because header or footer margin Left is 0.
});
break;
case Ie.FOOTER: {
const F = C.pageHeight - b.height - b.marginBottom;
this._liquid.translate(C.marginLeft, F);
break;
}
case Ie.CELL: {
this._liquid.translatePagePadding(C);
const F = b.parent, D = F.parent, { left: te } = b, { top: q, left: V } = D, { top: Y } = F;
this._liquid.translate(V + te, q + Y), this._liquid.translatePagePadding(b);
break;
}
default:
this._liquid.translatePagePadding(C);
break;
}
for (let F = M; F <= H; F++) {
const D = B[F], te = D.columns, { start_next: q, end_next: V } = this._getSelectionRuler(
Tt.section,
e,
t,
te.length - 1,
F
);
this._liquid.translateSection(D);
for (let Y = q; Y <= V; Y++) {
const oe = te[Y], ce = oe.lines, { start_next: he, end_next: Ae } = this._getSelectionRuler(
Tt.column,
e,
t,
ce.length - 1,
Y
);
this._liquid.translateColumn(oe);
for (let ne = he; ne <= Ae; ne++) {
const ae = ce[ne], { divides: Te } = ae, { start_next: je, end_next: ut } = this._getSelectionRuler(
Tt.line,
e,
t,
Te.length - 1,
ne
);
this._liquid.translateSave(), this._liquid.translateLine(ae, !0, !1);
for (let we = je; we <= ut; we++) {
const Yt = Te[we];
this._liquid.translateSave(), this._liquid.translateDivide(Yt);
const { glyphGroup: Qa } = Yt, { start_next: Ua, end_next: La } = this._getSelectionRuler(
Tt.divide,
e,
t,
Qa.length - 1,
we
);
let cr = !1, Ar = !1;
S === E && F === M && Y === q && ne === he && we === je && (cr = !0), S === I && F === H && Y === V && ne === Ae && we === ut && (Ar = !0), o && o(Ua, La, cr, Ar, Yt, ae, oe, D, b), this._liquid.translateRestore();
}
this._liquid.translateRestore();
}
}
}
this._liquid.translateRestore(), this._liquid.translatePage(C, f, p, m);
}
}
}
function SA(n, e) {
const { path: t } = n, { path: o } = e;
if (t.length !== o.length || t.indexOf("cells") === -1)
return !1;
const s = t.indexOf("skeTables") + 1, r = t.indexOf("rows") + 1, i = t.indexOf("cells") + 1, { tableId: a, sliceIndex: c } = pr(t[s]), { tableId: A, sliceIndex: l } = pr(o[s]);
if (a !== A)
return !1;
const d = t[r], h = o[r], u = t[i], g = o[i];
return !(d === h && u === g && c === l);
}
function Wi(n, e) {
const { path: t } = n, { path: o } = e;
return t.indexOf("cells") === -1 || o.indexOf("cells") === -1 || t.length !== o.length ? !1 : X.diffValue(t, o);
}
function zi(n, e, t) {
var u, g, f, p, m, E, I, v;
const { path: o } = e, { path: s } = t;
if (o.indexOf("cells") === -1 || s.indexOf("cells") === -1)
return !1;
const r = n.findGlyphByPosition(e), i = n.findGlyphByPosition(t), a = (p = (f = (g = (u = r == null ? void 0 : r.parent) == null ? void 0 : u.parent) == null ? void 0 : g.parent) == null ? void 0 : f.parent) == null ? void 0 : p.parent, c = (v = (I = (E = (m = i == null ? void 0 : i.parent) == null ? void 0 : m.parent) == null ? void 0 : E.parent) == null ? void 0 : I.parent) == null ? void 0 : v.parent;
if (a == null || c == null)
return !1;
const A = a.parent, l = c.parent, d = A.cells.indexOf(a), h = l.cells.indexOf(c);
return d === h && A.index === l.index;
}
function yo(n, e) {
if (Wi(n, e))
return ys(n, e);
const { path: t } = n, { path: o } = e, s = t[t.length - 5], r = o[o.length - 5];
if (s !== r && typeof s == "string" && typeof r == "string") {
const l = s.split("#-#")[1], d = r.split("#-#")[1];
return +l < +d;
}
const i = t[t.length - 3], a = o[o.length - 3], c = t[t.length - 1], A = o[o.length - 1];
return i < a ? !0 : i > a ? !1 : c <= A;
}
function vt(n) {
return n.sections[0].columns[0].lines.length === 0;
}
function IA(n, e, t) {
let o = e, s = t, r = n[o], i = n[s];
for (; o < s && (vt(r) || vt(i)); )
vt(r) ? (o++, r = n[o]) : vt(i) && (s--, i = n[s]);
if (!vt(r) && !vt(i))
return [r, i];
}
class Gi {
constructor(e, t) {
x(this, "_liquid", new bi());
this._documentOffsetConfig = e, this._docSkeleton = t;
}
// eslint-disable-next-line max-lines-per-function
getRangePointData(e, t) {
const o = [], r = this._docSkeleton.getSkeletonData();
if (r == null)
return;
const { pages: i } = r, { segmentPage: a, page: c, pageType: A } = e, l = this._getTableRectRangeInfo(e, t);
if (l == null)
return;
const {
tableId: d,
startRowIndex: h,
startColumnIndex: u,
endRowIndex: g,
endColumnIndex: f
} = l;
this._liquid.reset();
const { pageLayoutType: p, pageMarginLeft: m, pageMarginTop: E } = this._documentOffsetConfig, I = A === Ie.BODY || A === Ie.CELL ? c : a;
for (let v = 0; v < I; v++) {
const R = i[v];
this._liquid.translatePage(R, p, m, E);
}
for (let v = I; v < i.length; v++) {
const R = i[v];
this._liquid.translatePagePadding(R);
const { skeTables: S } = R;
let C = null;
for (const [b, B] of S.entries())
b.startsWith(d) && (C = B);
if (C == null) {
this._liquid.restorePagePadding(R), this._liquid.translatePage(R, p, m, E);
continue;
}
this._liquid.translateSave(), this._liquid.translate(0, C.top);
const { x: T, y: O } = this._liquid, { left: P } = C;
for (const b of C.rows)
if (b.index >= h && b.index <= g) {
const B = IA(b.cells, u, f);
if (B == null)
continue;
const [M, H] = B, F = {
startX: T + M.left + P,
startY: O + b.top,
endX: T + H.left + H.pageWidth + P,
endY: O + b.top + b.height
};
o.push(Yo(F));
}
this._liquid.translateRestore(), this._liquid.restorePagePadding(R), this._liquid.translatePage(R, p, m, E);
}
return {
pointGroup: o,
startRow: h,
startColumn: u,
endRow: g,
endColumn: f,
tableId: d
};
}
getNodePositionGroup(e, t) {
const o = [], s = this._docSkeleton.findCharIndexByPosition(e), r = this._docSkeleton.findCharIndexByPosition(t);
if (s == null || r == null)
return;
const i = s < r, a = this._getTableRectRangeInfo(e, t);
if (a == null)
return;
const { tableId: c, startRowIndex: A, startColumnIndex: l, endRowIndex: d, endColumnIndex: h } = a, u = this._docSkeleton.getViewModel().findTableNodeById(c);
if (u == null)
return;
const g = u.children[0].children.length;
if (l === 0 && h === g - 1) {
const p = u.children[A].children[l], m = this._docSkeleton.findNodePositionByCharIndex(p.startIndex + 1), E = u.children[d].children[h], I = this._docSkeleton.findNodePositionByCharIndex(E.endIndex - 2);
if (m == null || I == null)
return;
o.push({
anchor: i ? m : I,
focus: i ? I : m
});
} else
for (let p = A; p <= d; p++) {
const m = u.children[p], E = m.children[l], I = m.children[h], v = this._docSkeleton.findNodePositionByCharIndex(E.startIndex + 1), R = this._docSkeleton.findNodePositionByCharIndex(I.endIndex - 2);
if (v == null || R == null)
return;
o.push({
anchor: i ? v : R,
focus: i ? R : v
});
}
return o;
}
_getTableRectRangeInfo(e, t) {
const s = this._docSkeleton.getSkeletonData();
if (s == null)
return;
const { pages: r } = s, { path: i } = e, { path: a } = t, c = jo(s, i), A = jo(s, a);
if (c == null || A == null)
return;
const l = c.segmentId, d = c.parent.index, h = c.parent.cells.indexOf(c), u = (A == null ? void 0 : A.parent).index, g = (A == null ? void 0 : A.parent).cells.indexOf(A), f = Math.min(d, u), p = Math.max(d, u), m = Math.min(h, g), E = Math.max(h, g);
return {
pages: r,
tableId: l,
startRowIndex: f,
startColumnIndex: m,
endRowIndex: p,
endColumnIndex: E
};
}
}
const CA = "__TestSelectionRange__", vA = "__TestSelectionAnchor__", Br = 6, Bo = 500, RA = 500, qo = 3;
function Mn(n) {
const e = n[0], t = e[0], o = e[2], { x: s, y: r } = t, { x: i, y: a } = o;
return {
left: s,
top: r,
width: i - s,
height: a - r
};
}
function Bs(n) {
return n.map((e) => {
let t = 1 / 0, o = -1 / 0, s = 1 / 0, r = -1 / 0;
return e.forEach((i) => {
t = Math.min(i.x, t), o = Math.max(i.x, o), r = Math.max(i.y, r), s = Math.min(i.y, s);
}), {
left: t,
right: o,
top: s,
bottom: r
};
});
}
class Mt {
constructor(e, t, o, s, r, i = sn, a = "", c = -1) {
x(this, "rangeType", Ge.TEXT);
// Identifies whether the range is the current one, most of which is the last range.
x(this, "_current", !1);
// The rendered range graphic when collapsed is false
x(this, "_rangeShape");
// The rendered range graphic when collapsed is true
x(this, "_anchorShape");
x(this, "_cursorList", []);
x(this, "_anchorBlinkTimer", null);
this._scene = e, this._document = t, this._docSkeleton = o, this.anchorNodePosition = s, this.focusNodePosition = r, this.style = i, this._segmentId = a, this._segmentPage = c, this._anchorBlink(), this.refresh();
}
_anchorBlink() {
setTimeout(() => {
this._anchorShape && this._anchorShape.visible && this.deactivateStatic();
}, Bo), this._anchorBlinkTimer = setInterval(() => {
this._anchorShape && this._anchorShape.visible && (this.activeStatic(), setTimeout(() => {
this.deactivateStatic();
}, Bo));
}, RA + Bo);
}
// The start position of the range
get startOffset() {
var s;
const { startOffset: e } = (s = yr(this._cursorList)) != null ? s : {}, t = this._docSkeleton.getViewModel().getDataModel().getSelfOrHeaderFooterModel(this._segmentId).getBody();
if (e == null || t == null)
return e;
const o = t.dataStream.length - 2;
return Math.min(o, e);
}
// The end position of the range
get endOffset() {
var s;
const { endOffset: e } = (s = yr(this._cursorList)) != null ? s : {}, t = this._docSkeleton.getViewModel().getDataModel().getSelfOrHeaderFooterModel(this._segmentId).getBody();
if (e == null || t == null)
return e;
const o = t.dataStream.length - 2;
return Math.min(e, o);
}
get collapsed() {
const { startOffset: e, endOffset: t } = this;
return e != null && e === t;
}
get startNodePosition() {
if (this.anchorNodePosition == null)
return null;
if (this.focusNodePosition == null)
return this.anchorNodePosition;
const { start: e } = Go(this.anchorNodePosition, this.focusNodePosition);
return e;
}
get endNodePosition() {
if (this.anchorNodePosition == null)
return this.focusNodePosition;
if (this.focusNodePosition == null)
return null;
const { end: e } = Go(this.anchorNodePosition, this.focusNodePosition);
return e;
}
get direction() {
const { collapsed: e, anchorNodePosition: t, focusNodePosition: o } = this;
return e || t == null || o == null ? xe.NONE : ys(t, o) ? xe.FORWARD : xe.BACKWARD;
}
get segmentId() {
return this._segmentId;
}
get segmentPage() {
return this._segmentPage;
}
getAbsolutePosition() {
const e = this.anchorNodePosition, t = this.focusNodePosition;
if (this._isEmpty())
return;
const o = this._document.getOffsetConfig(), { docsLeft: s, docsTop: r } = o, i = new it(o, this._docSkeleton);
if (this._isCollapsed()) {
const { contentBoxPointGroup: l, cursorList: d } = i.getRangePointData(e, e);
if (this._setCursorList(d), l.length === 0)
return;
const h = Mn(l);
return {
...h,
left: h.left + s,
top: h.top + r
};
}
const { borderBoxPointGroup: a, cursorList: c } = i.getRangePointData(e, t);
if (this._setCursorList(c), a.length === 0)
return;
const A = Mn(a);
return {
...A,
left: A.left + s,
top: A.top + r
};
}
getAnchor() {
return this._anchorShape;
}
activeStatic() {
var e, t;
(t = this._anchorShape) == null || t.setProps({
stroke: ((e = this.style) == null ? void 0 : e.strokeActive) || on(tn.black, 1)
});
}
deactivateStatic() {
var e, t;
(t = this._anchorShape) == null || t.setProps({
stroke: ((e = this.style) == null ? void 0 : e.stroke) || on(tn.black, 0)
});
}
isActive() {
return this._current === !0;
}
activate() {
this._current = !0;
}
deactivate() {
this._current = !1;
}
dispose() {
var e, t;
(e = this._rangeShape) == null || e.dispose(), this._rangeShape = null, (t = this._anchorShape) == null || t.dispose(), this._anchorShape = null, this._anchorBlinkTimer && (clearInterval(this._anchorBlinkTimer), this._anchorBlinkTimer = null);
}
isIntersection(e) {
const { startOffset: t, endOffset: o } = this, { startOffset: s, endOffset: r } = e;
return t == null || o == null || s == null || r == null ? !1 : t <= r && o >= s;
}
// render cursor and selection.
refresh() {
var d, h;
const { _document: e, _docSkeleton: t } = this, o = this.anchorNodePosition, s = this.focusNodePosition;
if ((d = this._anchorShape) == null || d.hide(), (h = this._rangeShape) == null || h.hide(), this._isEmpty())
return;
const r = e.getOffsetConfig(), { docsLeft: i, docsTop: a } = r, c = new it(r, t);
if (this._isCollapsed()) {
const { contentBoxPointGroup: u, cursorList: g } = c.getRangePointData(o, o);
if (this._setCursorList(g), u.length > 0) {
const f = t.findGlyphByPosition(o);
this._createOrUpdateAnchor(u, i, a, f);
}
return;
}
const { borderBoxPointGroup: A, cursorList: l } = c.getRangePointData(o, s);
this._setCursorList(l), A.length > 0 && this._createOrUpdateRange(A, i, a);
}
_isEmpty() {
return this.anchorNodePosition == null && this.focusNodePosition == null;
}
_isCollapsed() {
const e = this.anchorNodePosition, t = this.focusNodePosition;
if (e != null && t == null)
return !0;
if (e == null || t == null)
return !1;
const o = Object.keys(Tt);
for (const s of o) {
const r = e[s], i = t[s];
if (r !== i)
return !1;
}
return e.isBack === t.isBack;
}
_createOrUpdateRange(e, t, o) {
var i;
if (this._rangeShape) {
this._rangeShape.translate(t, o), this._rangeShape.updatePointGroup(e), this._rangeShape.show();
return;
}
const s = 0.3, r = new Oi(CA + X.generateRandomId(Br), {
pointsGroup: e,
fill: ((i = this.style) == null ? void 0 : i.fill) || on(tn.black, s),
left: t,
top: o,
evented: !1,
debounceParentDirty: !1
});
this._rangeShape = r, this._scene.addObject(r, qo);
}
_createOrUpdateAnchor(e, t, o, s) {
var f, p, m;
const r = Mn(e), { left: i } = r;
let { top: a, height: c } = r;
const A = 14;
c < A && (a -= A - c, c = A);
const l = 12;
let d = i + t;
const h = a + o, u = ((f = s == null ? void 0 : s.ts) == null ? void 0 : f.it) === L.TRUE;
if (u && (d += c * Math.tan(l * Math.PI / 180) / 2), this._anchorShape) {
this._anchorShape.transformByState({ left: d, top: h, height: c }), this._anchorShape.show(), u ? this._anchorShape.skew(-12, 0) : this._anchorShape.skew(0, 0);
return;
}
const g = new yn(vA + X.generateRandomId(Br), {
left: d,
top: h,
height: c,
strokeWidth: ((p = this.style) == null ? void 0 : p.strokeWidth) || 1.5,
stroke: ((m = this.style) == null ? void 0 : m.strokeActive) || on(tn.black, 1),
evented: !1
});
u && g.skew(-12, 0), this._anchorShape = g, this._scene.addObject(g, qo), this.activeStatic();
}
_setCursorList(e) {
e.length !== 0 && (this._cursorList = e);
}
}
const bA = "__DocTableRectRange__", xA = 6;
function Mo(n, e, t, o, s, r = sn, i = "", a = -1) {
const c = e.getOffsetConfig(), l = new Gi(c, t).getNodePositionGroup(o, s);
return (l != null ? l : []).map((d) => new Yi(
n,
e,
t,
d.anchor,
d.focus,
r,
i,
a
));
}
class Yi {
constructor(e, t, o, s, r, i = sn, a = "", c = -1) {
x(this, "rangeType", Ge.RECT);
// The rendered rect range
x(this, "_rangeShape");
// Identifies whether the range is the current one, most of which is the last range.
x(this, "_current", !1);
// Rect Range start row.
x(this, "_startRow");
// Rect Range start column.
x(this, "_startCol");
// Rect Range end row.
x(this, "_endRow");
// Rect Range end column.
x(this, "_endCol");
// table id in view model.
x(this, "_tableId");
this._scene = e, this._document = t, this._docSkeleton = o, this.anchorNodePosition = s, this.focusNodePosition = r, this.style = i, this._segmentId = a, this._segmentPage = c, this.refresh();
}
get startOffset() {
const { startNodePosition: e } = this;
return this._docSkeleton.findCharIndexByPosition(e);
}
get endOffset() {
const { endNodePosition: e } = this;
return this._docSkeleton.findCharIndexByPosition(e);
}
get collapsed() {
return !1;
}
get startRow() {
return this._startRow;
}
get startColumn() {
return this._startCol;
}
get endRow() {
return this._endRow;
}
get endColumn() {
return this._endCol;
}
get tableId() {
return this._tableId;
}
get segmentId() {
return this._segmentId;
}
get segmentPage() {
return this._segmentPage;
}
get spanEntireRow() {
var i;
const t = (i = this._docSkeleton.getViewModel().getSnapshot().tableSource) == null ? void 0 : i[this._tableId], { _startCol: o, _endCol: s } = this;
if (t == null)
throw new Error("Table is not found.");
const { tableColumns: r } = t;
return o === 0 && s === r.length - 1;
}
get spanEntireColumn() {
var i;
const t = (i = this._docSkeleton.getViewModel().getSnapshot().tableSource) == null ? void 0 : i[this._tableId], { _startRow: o, _endRow: s } = this;
if (t == null)
throw new Error("Table is not found.");
const { tableRows: r } = t;
return o === 0 && s === r.length - 1;
}
get spanEntireTable() {
return this.spanEntireRow && this.spanEntireColumn;
}
get startNodePosition() {
const { anchorNodePosition: e, focusNodePosition: t } = this;
return yo(e, t) ? e : t;
}
get endNodePosition() {
const { anchorNodePosition: e, focusNodePosition: t } = this;
return yo(e, t) ? t : e;
}
get direction() {
const { anchorNodePosition: e, focusNodePosition: t } = this;
return yo(e, t) ? xe.FORWARD : xe.BACKWARD;
}
isActive() {
return this._current === !0;
}
activate() {
this._current = !0;
}
deactivate() {
this._current = !1;
}
dispose() {
var e;
(e = this._rangeShape) == null || e.dispose(), this._rangeShape = null;
}
isIntersection(e) {
const { startRow: t, startColumn: o, endRow: s, endColumn: r } = this, { startRow: i, startColumn: a, endRow: c, endColumn: A } = e, l = {
left: o,
top: t,
right: r,
bottom: s
}, d = {
left: a,
top: i,
right: A,
bottom: c
};
return ka.hasIntersectionBetweenTwoRect(l, d);
}
refresh() {
var p;
(p = this._rangeShape) == null || p.hide();
const { startNodePosition: e, endNodePosition: t, _document: o, _docSkeleton: s } = this, r = o.getOffsetConfig(), { docsLeft: i, docsTop: a } = r, A = new Gi(r, s).getRangePointData(e, t);
if (A == null)
return;
const { pointGroup: l = [], startRow: d, endRow: h, startColumn: u, endColumn: g, tableId: f } = A;
(l == null ? void 0 : l.length) > 0 && this._createOrUpdateRange(l, i, a), this._updateTableInfo(d, h, u, g, f);
}
_updateTableInfo(e, t, o, s, r) {
this._startRow = e, this._endRow = t, this._startCol = o, this._endCol = s, this._tableId = r;
}
_createOrUpdateRange(e, t, o) {
var i;
if (this._rangeShape) {
this._rangeShape.translate(t, o), this._rangeShape.updatePointGroup(e), this._rangeShape.show();
return;
}
const s = 0.3, r = new Oi(bA + X.generateRandomId(xA), {
pointsGroup: e,
fill: ((i = this.style) == null ? void 0 : i.fill) || on(tn.black, s),
left: t,
top: o,
evented: !1,
debounceParentDirty: !1
});
this._rangeShape = r, this._scene.addObject(r, qo);
}
}
function Mr(n, e, t, o, s, r, i, a, c = !0, A = !0) {
const l = s.findNodePositionByCharIndex(n, c, i, a), d = s.findNodePositionByCharIndex(e, A, i, a);
if (!(l == null || d == null))
return new Mt(t, o, s, l, d, r, i, a);
}
function OA(n, e, t, o, s, r, i, a) {
const c = s.findNodePositionByCharIndex(n, !0, i, a), A = s.findNodePositionByCharIndex(e, !0, i, a);
if (!(c == null || A == null))
return new Yi(t, o, s, c, A, r, i, a);
}
function TA(n, e, t, o, s, r, i, a) {
const c = s.findNodePositionByCharIndex(n, !0, i, a), A = s.findNodePositionByCharIndex(e, !0, i, a);
if (!(c == null || A == null))
return Ko(
c,
A,
t,
o,
s,
r,
i,
a
);
}
function Ko(n, e, t, o, s, r, i, a) {
const c = [], A = [], l = [t, o, s, n, e, r, i, a];
if (zi(s, n, e)) {
if (Wi(n, e))
return c.push(new Mt(...l)), {
textRanges: c,
rectRanges: A
};
{
const I = Mo(
...l
);
return A.push(...I), {
textRanges: c,
rectRanges: A
};
}
}
if (SA(n, e)) {
const I = Mo(
...l
);
return A.push(...I), {
textRanges: c,
rectRanges: A
};
}
const d = s.getViewModel().getSelfOrHeaderFooterViewModel(i), h = s.findCharIndexByPosition(n), u = s.findCharIndexByPosition(e);
if (h == null || u == null)
return;
const g = h <= u ? xe.FORWARD : xe.BACKWARD, f = Math.min(h, u), p = Math.max(h, u);
let m = f, E = p;
for (const I of d.getChildren())
for (const v of I.children) {
const { startIndex: R, endIndex: S, children: C } = v, T = I.children.indexOf(v), O = I.children[T + 1], P = C[0];
let b = !1;
if (P) {
const { startIndex: B, endIndex: M, children: H } = P;
let F = null, D = null;
const te = H.find((V) => V.startIndex <= f && V.endIndex >= f), q = H.find((V) => V.startIndex <= p && V.endIndex >= p);
if (f > B && f < M)
F = s.findNodePositionByCharIndex(te.startIndex + 2, !0, i, a), D = s.findNodePositionByCharIndex(M - 4, !0, i, a), m = M + 1;
else if (p > B && p < M)
F = s.findNodePositionByCharIndex(B + 3, !0, i, a), D = s.findNodePositionByCharIndex(q.endIndex - 3, !0, i, a), E = B - 1, b = !0;
else if (B > f && M < p) {
if (F = s.findNodePositionByCharIndex(B + 3, !0, i, a), D = s.findNodePositionByCharIndex(M - 4, !0, i, a), m <= B - 1) {
const V = s.findNodePositionByCharIndex(m, !0, i, a), Y = s.findNodePositionByCharIndex(B - 1, !1, i, a), oe = g === xe.FORWARD ? V : Y, ce = g === xe.FORWARD ? Y : V;
c.push(new Mt(t, o, s, oe, ce, r, i, a));
}
m = M + 1;
}
if (F && D) {
const V = g === xe.FORWARD ? F : D, Y = g === xe.FORWARD ? D : F;
A.push(...Mo(
t,
o,
s,
V,
Y,
r,
i,
a
));
}
}
if (E === S + 1 && !b && O && O.children.length && (E = S, b = !0), E >= R && E <= S || b) {
const B = s.findNodePositionByCharIndex(m, !0, i, a), M = s.findNodePositionByCharIndex(E, !b, i, a), H = g === xe.FORWARD ? B : M, F = g === xe.FORWARD ? M : B;
if (A.length && X.diffValue(H, F))
continue;
c.push(new Mt(t, o, s, H, F, r, i, a));
}
}
return {
textRanges: c,
rectRanges: A
};
}
function yA(n) {
const e = n == null ? void 0 : n.getCanvasElement();
if (!e)
return {
left: 0,
top: 0
};
const { top: t, left: o } = cc(e);
return {
left: o,
top: t
};
}
function _r(n) {
var c;
const e = (c = n.parent) == null ? void 0 : c.parent, t = e == null ? void 0 : e.parent;
if (e == null || t == null)
return;
const { paragraphIndex: o } = e, s = t.lines.filter((A) => A.paragraphIndex === o);
let r = -1, i = "", a = !1;
for (const A of s)
for (const l of A.divides)
for (const d of l.glyphGroup)
a || (r += d.count), d === n && (a = !0), i += d.count > 0 ? d.content : "";
return {
st: s[0].st,
ed: o,
content: i,
nodeIndex: r
};
}
function Xo(n) {
const { startOffset: e, endOffset: t, collapsed: o, rangeType: s, startNodePosition: r, endNodePosition: i, direction: a, segmentId: c, segmentPage: A } = n;
return {
startOffset: e,
endOffset: t,
collapsed: o,
rangeType: s,
startNodePosition: r,
endNodePosition: i,
direction: a,
segmentId: c,
segmentPage: A,
isActive: n.isActive()
};
}
function BA(n) {
const e = Xo(n), {
startRow: t,
startColumn: o,
endRow: s,
endColumn: r,
tableId: i,
spanEntireRow: a,
spanEntireColumn: c,
spanEntireTable: A
} = n;
return {
...e,
startRow: t,
startColumn: o,
endRow: s,
endColumn: r,
tableId: i,
spanEntireRow: a,
spanEntireColumn: c,
spanEntireTable: A
};
}
var MA = Object.defineProperty, _A = Object.getOwnPropertyDescriptor, PA = (n, e, t, o) => {
for (var s = o > 1 ? void 0 : o ? _A(e, t) : e, r = n.length - 1, i; r >= 0; r--)
(i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
return o && s && MA(e, t, s), s;
}, Cn = (n, e) => (t, o) => e(t, o, n);
let Se = class extends At {
constructor(e, t, o, s, r) {
super();
x(this, "_onInputBefore$", new Ee());
x(this, "onInputBefore$", this._onInputBefore$.asObservable());
x(this, "_onKeydown$", new Ee());
x(this, "onKeydown$", this._onKeydown$.asObservable());
x(this, "_onInput$", new Ee());
x(this, "onInput$", this._onInput$.asObservable());
x(this, "_onCompositionstart$", new Le(null));
x(this, "onCompositionstart$", this._onCompositionstart$.asObservable());
x(this, "_onCompositionupdate$", new Le(null));
x(this, "onCompositionupdate$", this._onCompositionupdate$.asObservable());
x(this, "_onCompositionend$", new Le(null));
x(this, "onCompositionend$", this._onCompositionend$.asObservable());
x(this, "_onSelectionStart$", new Le(null));
x(this, "onSelectionStart$", this._onSelectionStart$.asObservable());
x(this, "onChangeByEvent$", Fi(
this._onInput$,
this._onKeydown$.pipe(Qn((e) => e.event.keyCode === j.BACKSPACE)),
this._onCompositionend$
));
x(this, "_onPaste$", new Ee());
x(this, "onPaste$", this._onPaste$.asObservable());
x(this, "_textSelectionInner$", new Le(null));
x(this, "textSelectionInner$", this._textSelectionInner$.asObservable());
x(this, "_onFocus$", new Ee());
x(this, "onFocus$", this._onFocus$.asObservable());
x(this, "_onBlur$", new Ee());
x(this, "onBlur$", this._onBlur$.asObservable());
x(this, "_onPointerDown$", new Ee());
x(this, "onPointerDown$", this._onPointerDown$.asObservable());
x(this, "_container");
x(this, "_inputParent");
x(this, "_input");
x(this, "_scrollTimers", []);
x(this, "_rangeList", []);
// Use to cache range list in moving.
x(this, "_rangeListCache", []);
// Rect range list.
x(this, "_rectRangeList", []);
// Use to cache rect range list in moving.
x(this, "_rectRangeListCache", []);
x(this, "_anchorNodePosition", null);
x(this, "_focusNodePosition", null);
x(this, "_currentSegmentId", "");
x(this, "_currentSegmentPage", -1);
x(this, "_selectionStyle", sn);
x(this, "_onPointerEvent", !1);
x(this, "_viewPortObserverMap", /* @__PURE__ */ new Map());
x(this, "_isIMEInputApply", !1);
x(this, "_scenePointerMoveSubs", []);
x(this, "_scenePointerUpSubs", []);
// When the user switches editors, whether to clear the doc ranges.
x(this, "_reserveRanges", !1);
this._context = e, this._layoutService = t, this._logService = o, this._univerInstanceService = s, this._docSkeletonManagerService = r, this._initDOM(), this._registerContainer(), this._setSystemHighlightColorToStyle(), this._listenCurrentUnitChange();
}
get isOnPointerEvent() {
return this._onPointerEvent;
}
get isFocusing() {
return this._input === document.activeElement;
}
get canFocusing() {
return this.isFocusing || document.activeElement === document.body || document.activeElement === null;
}
_listenCurrentUnitChange() {
this._univerInstanceService.getCurrentTypeOfUnit$(_.UNIVER_DOC).pipe(st(this.dispose$)).subscribe((e) => {
if (e == null)
return;
e.getUnitId() !== this._context.unitId && !this._reserveRanges && this.removeAllRanges();
});
}
get activeViewPort() {
return this._context.scene.getViewports()[0];
}
setSegment(e) {
this._currentSegmentId = e;
}
getSegment() {
return this._currentSegmentId;
}
setSegmentPage(e) {
this._currentSegmentPage = e;
}
getSegmentPage() {
return this._currentSegmentPage;
}
setReserveRangesStatus(e) {
this._reserveRanges = e;
}
_setRangeStyle(e = sn) {
this._selectionStyle = e;
}
// eslint-disable-next-line max-lines-per-function
addDocRanges(e, t = !0, o) {
const {
_currentSegmentId: s,
_currentSegmentPage: r,
_selectionStyle: i
} = this, { scene: a, mainComponent: c } = this._context, A = c, l = this._docSkeletonManagerService.getSkeleton(), d = (h, u) => {
const g = TA(
h,
u,
a,
A,
l,
i,
s,
r
);
if (g == null)
return;
const { textRanges: f, rectRanges: p } = g;
for (const m of f)
this._addTextRange(m);
this._addRectRanges(p);
};
for (const h of e) {
const { startOffset: u, endOffset: g, rangeType: f, startNodePosition: p, endNodePosition: m } = h;
if (f === Ge.RECT) {
const E = OA(
u,
g,
a,
A,
l,
i,
s,
r
);
E && this._addRectRanges([E]);
} else if (f === Ge.TEXT)
try {
let E = null;
p && m ? E = Mr(
p.isBack ? u : u - 1,
m.isBack ? g : g - 1,
a,
A,
l,
i,
s,
r,
p.isBack,
m.isBack
) : E = Mr(
u,
g,
a,
A,
l,
i,
s,
r
), E && this._addTextRange(E);
} catch {
d(u, g);
}
else
d(u, g);
}
this._textSelectionInner$.next({
textRanges: this._getAllTextRanges(),
rectRanges: this._getAllRectRanges(),
segmentId: s,
segmentPage: r,
style: i,
isEditing: t,
options: o
}), this._updateInputPosition(o == null ? void 0 : o.forceFocus);
}
setCursorManually(e, t) {
const o = this._findNodeByCoord(e, t, {
strict: !0,
segmentId: this._currentSegmentId,
segmentPage: this._currentSegmentPage
}), s = this._getNodePosition(o);
if (s == null) {
this._removeAllRanges();
return;
}
(o == null ? void 0 : o.node.streamType) === U.PARAGRAPH && (s.isBack = !0), this._createTextRangeByAnchorPosition(s), this._textSelectionInner$.next({
textRanges: this._getAllTextRanges(),
rectRanges: this._getAllRectRanges(),
segmentId: this._currentSegmentId,
segmentPage: this._currentSegmentPage,
style: this._selectionStyle,
isEditing: !1
});
}
// Sync canvas selection to dom selection.
sync() {
this._updateInputPosition();
}
/**
* @deprecated
*/
activate(e, t, o = !1) {
this._container.style.left = `${e}px`, this._container.style.top = `${t}px`, this._container.style.zIndex = "1000", (this.canFocusing || o) && this.focus();
}
hasFocus() {
return document.activeElement === this._input;
}
focus() {
this._input.focus();
}
blur() {
this._input.blur();
}
// FIXME: for editor cell editor we don't need to blur the input element
/**
* @deprecated
*/
deactivate() {
this._container.style.left = "0px", this._container.style.top = "0px";
}
// Handler double click.
__handleDblClick(e) {
const { offsetX: t, offsetY: o } = e, s = this._findNodeByCoord(t, o, {
strict: !1,
segmentId: this._currentSegmentId,
segmentPage: this._currentSegmentPage
});
if (s == null || s.node == null)
return;
const r = _r(s.node);
if (r == null)
return;
const { content: i, st: a, nodeIndex: c } = r;
if (c === -1 || Intl.Segmenter == null)
return;
const l = new Intl.Segmenter(void 0, { granularity: "word" }).segment(i);
let d = Number.NEGATIVE_INFINITY, h = Number.NEGATIVE_INFINITY;
for (const { segment: u, index: g, isWordLike: f } of l)
if (g <= c && c < g + u.length && f) {
d = g + a, h = g + a + u.length;
break;
}
if (Number.isFinite(d) && Number.isFinite(h)) {
this.removeAllRanges();
const u = [
{
startOffset: d,
endOffset: h
}
];
this.addDocRanges(u, !1, { forceFocus: !0 });
}
}
__handleTripleClick(e) {
const { offsetX: t, offsetY: o } = e, s = this._findNodeByCoord(t, o, {
strict: !1,
segmentId: this._currentSegmentId,
segmentPage: this._currentSegmentPage
});
if (s == null || s.node == null)
return;
const r = _r(s.node);
if (r == null)
return;
this.removeAllRanges();
const { st: i, ed: a } = r, c = [
{
startOffset: i,
endOffset: a
}
];
this.addDocRanges(c, !1, { forceFocus: !0 });
}
// Handle pointer down.
// eslint-disable-next-line max-lines-per-function, complexity
__onPointDown(e) {
var f, p;
const { scene: t, mainComponent: o } = this._context, s = this._docSkeletonManagerService.getSkeleton(), { offsetX: r, offsetY: i } = e, a = this._findNodeByCoord(r, i, {
strict: !1,
segmentId: this._currentSegmentId,
segmentPage: this._currentSegmentPage
}), c = this._getNodePosition(a);
if (c == null || a == null) {
this._removeAllRanges();
return;
}
(a == null ? void 0 : a.node.streamType) === U.PARAGRAPH && (c.isBack = !0);
const A = this._textSelectionInner$.value;
if (a && e.button === 2 && A) {
const m = s.findCharIndexByPosition(c);
if (typeof m == "number" && A.textRanges.some((E) => E.startOffset <= m && E.endOffset > m) || typeof m == "number" && A.rectRanges.some((E) => E.startOffset <= m && E.endOffset >= m))
return;
}
const { segmentId: l, segmentPage: d } = a;
l && this._currentSegmentId && l !== this._currentSegmentId && this.setSegment(l), l && d !== this._currentSegmentPage && this.setSegmentPage(d), this._anchorNodePosition = c, e.shiftKey && this._getActiveRangeInstance() ? this._updateActiveRangePosition(c) : e.ctrlKey ? this._removeAllCollapsedTextRanges() : this._isEmpty() || this._removeAllRanges(), t.disableObjectsEvent();
const h = Ac.create(t);
this._scrollTimers.push(h), h.startScroll(r, i), this._onSelectionStart$.next((f = this._getActiveRangeInstance()) == null ? void 0 : f.startNodePosition), (p = t.getTransformer()) == null || p.clearSelectedObjects();
let u = r, g = i;
this._onPointerEvent = !0, this._scenePointerMoveSubs.push(t.onPointerMove$.subscribeEvent((m) => {
const { offsetX: E, offsetY: I } = m;
t.setCursor(mt.TEXT), !(Math.sqrt((E - u) ** 2 + (I - g) ** 2) < 3) && (this._moving(E, I), h.scrolling(E, I, () => {
this._moving(E, I);
}), u = E, g = I);
})), this._scenePointerUpSubs.push(t.onPointerUp$.subscribeEvent(() => {
if ([...this._scenePointerMoveSubs, ...this._scenePointerUpSubs].forEach((E) => {
E.unsubscribe();
}), this._onPointerEvent = !1, t.enableObjectsEvent(), this._anchorNodePosition && !this._focusNodePosition) {
if (e.ctrlKey) {
this._disposeScrollTimers();
return;
}
const E = new Mt(t, o, s, this._anchorNodePosition, void 0, this._selectionStyle, this._currentSegmentId, this._currentSegmentPage);
this._addTextRange(E);
} else if (this._anchorNodePosition && this._focusNodePosition) {
for (const E of this._rangeListCache)
e.ctrlKey ? E.collapsed ? E.dispose() : this._addTextRange(E) : this._addTextRange(E);
this._addRectRanges(this._rectRangeListCache), this._rangeListCache = [], this._rectRangeListCache = [];
}
this._anchorNodePosition = null, this._focusNodePosition = null;
const m = {
textRanges: this._getAllTextRanges(),
rectRanges: this._getAllRectRanges(),
segmentId: this._currentSegmentId,
segmentPage: this._currentSegmentPage,
style: this._selectionStyle,
isEditing: !1
};
this._textSelectionInner$.next(m), this._disposeScrollTimers(), this._updateInputPosition(!0);
}));
}
removeAllRanges() {
this._removeAllRanges(), this.deactivate();
}
getActiveTextRange() {
return this._getActiveRangeInstance();
}
_disposeScrollTimers() {
this._scrollTimers.forEach((e) => {
e == null || e.dispose();
}), this._scrollTimers = [];
}
_setSystemHighlightColorToStyle() {
const { r: e, g: t, b: o, a: s } = lc(), r = {
strokeWidth: 1.5,
stroke: "rgba(0, 0, 0, 0)",
strokeActive: "rgba(0, 0, 0, 1)",
fill: `rgba(${e}, ${t}, ${o}, ${s != null ? s : 0.3})`
};
this._setRangeStyle(r);
}
_getAllTextRanges() {
return this._rangeList.map(Xo);
}
_getAllRectRanges() {
return this._rectRangeList.map(BA);
}
getAllTextRanges() {
return this._getAllTextRanges();
}
getAllRectRanges() {
return this._getAllRectRanges();
}
_getActiveRange() {
const e = this._rangeList.find((s) => s.isActive());
if (e == null)
return null;
const { startOffset: t, endOffset: o } = e;
return t == null || o == null ? null : Xo(e);
}
_getActiveRangeInstance() {
return this._rangeList.find((e) => e.isActive());
}
dispose() {
super.dispose(), this._detachEvent(), this._removeAllRanges(), this._container.remove();
}
_initDOM() {
const { unitId: e } = this._context, t = document.createElement("div");
t.style.position = "fixed", t.style.left = "0px", t.style.top = "0px", t.id = `univer-doc-selection-container-${e}`;
const o = document.createElement("div"), s = document.createElement("div");
o.appendChild(s), t.appendChild(o), this._container = t, this._inputParent = o, this._input = s, this._initInput(), this._initInputEvents(), document.body.appendChild(t);
}
_registerContainer() {
this.disposeWithMe(
// the content editable div should be regarded as part of the applications container
this._layoutService.registerContainerElement(this._container)
);
}
_initInput() {
this._inputParent.style.cssText = `
position:absolute;
height:1px;
width:1px;
overflow: hidden;
`, this._input.contentEditable = "true", this._input.classList.add("univer-editor"), this._input.id = `__editor_${this._context.unitId}`, this._input.style.cssText = `
position: absolute;
overflow: hidden;
opacity: 1;
background: #000;
color: transparent;
outline: none;
z-index: -2;
caret-color: transparent;
white-space: pre-wrap;
user-select: text;
`;
}
_getNodePosition(e) {
if (e == null)
return;
const { node: t, ratioX: o, segmentPage: s } = e, i = this._docSkeletonManagerService.getSkeleton().findPositionByGlyph(t, s);
if (i == null)
return;
let c = o < 0.5;
return t.glyphType === xi.LIST && (c = !0), {
...i,
isBack: c
};
}
_interactTextRanges(e) {
const t = [];
for (const o of this._rangeList) {
if (e.some((s) => s.isIntersection(o))) {
o.dispose();
continue;
}
t.push(o);
}
this._rangeList = t;
}
_interactRectRanges(e) {
const t = [];
for (const o of this._rectRangeList) {
if (e.some((s) => s.isIntersection(o))) {
o.dispose();
continue;
}
t.push(o);
}
this._rectRangeList = t;
}
_removeAllRanges() {
this._removeAllTextRanges(), this._removeAllRectRanges();
}
_removeAllCacheRanges() {
this._rangeListCache.forEach((e) => {
e.dispose();
}), this._rectRangeListCache.forEach((e) => {
e.dispose();
}), this._rangeListCache = [], this._rectRangeListCache = [];
}
_removeAllTextRanges() {
this._rangeList.forEach((e) => {
e.dispose();
}), this._rangeList = [];
}
_removeAllRectRanges() {
this._rectRangeList.forEach((e) => {
e.dispose();
}), this._rectRangeList = [];
}
_removeAllCollapsedTextRanges() {
for (const e of this._rangeList)
e.collapsed && e.dispose();
}
_deactivateAllTextRanges() {
this._rangeList.forEach((e) => {
e.deactivate();
});
}
_deactivateAllRectRanges() {
this._rectRangeList.forEach((e) => {
e.deactivate();
});
}
_addTextRangesToCache(e) {
this._rangeListCache.push(...e);
}
_addTextRange(e) {
this._deactivateAllTextRanges(), e.activate(), this._rangeList.push(e);
}
_addRectRangesToCache(e) {
this._rectRangeListCache.push(...e);
}
_addRectRanges(e) {
e.length !== 0 && (this._deactivateAllRectRanges(), e[e.length - 1].activate(), this._rectRangeList.push(...e));
}
_createTextRangeByAnchorPosition(e) {
this._removeAllRanges();
const { scene: t, mainComponent: o } = this._context, s = this._docSkeletonManagerService.getSkeleton(), r = new Mt(t, o, s, e, void 0, this._selectionStyle, this._currentSegmentId, this._currentSegmentPage);
this._addTextRange(r);
}
_updateActiveRangePosition(e) {
const t = this._getActiveRangeInstance();
if (t == null || t.anchorNodePosition == null) {
this._logService.error(
"[DocSelectionRenderService] _updateActiveRangeFocusPosition: active range has no anchor"
);
return;
}
this._removeAllRanges(), this._anchorNodePosition = t.anchorNodePosition, this._focusNodePosition = e;
const { scene: o, mainComponent: s } = this._context, r = this._docSkeletonManagerService.getSkeleton(), { _anchorNodePosition: i, _focusNodePosition: a, _selectionStyle: c, _currentSegmentId: A, _currentSegmentPage: l } = this;
if (i == null || a == null || s == null)
return;
const d = Ko(
i,
a,
o,
s,
r,
c,
A,
l
);
if (d == null)
return;
const { textRanges: h, rectRanges: u } = d;
this._addTextRangesToCache(h), this._addRectRangesToCache(u), this.deactivate();
}
_isEmpty() {
return this._rangeList.length === 0 && this._rectRangeList.length === 0;
}
_getCanvasOffset() {
var t;
const e = (t = this._context.scene) == null ? void 0 : t.getEngine();
return yA(e);
}
_updateInputPosition(e = !1) {
const t = this._getActiveRangeInstance(), o = t == null ? void 0 : t.getAnchor();
if (!o || o && !o.visible || this.activeViewPort == null) {
this.focus();
return;
}
const { left: s, top: r } = o, i = this.activeViewPort.getAbsoluteVector(rn.FromArray([s, r])), { x: a, y: c } = i;
let { left: A, top: l } = this._getCanvasOffset();
A += a, l += c, this.activate(A, l, e);
}
_moving(e, t) {
var m, E;
const { _currentSegmentId: o, _currentSegmentPage: s } = this, r = this._findNodeByCoord(e, t, {
strict: !0,
segmentId: o,
segmentPage: s
}), i = this._getNodePosition(r);
if (i == null || r == null)
return;
const a = r == null ? void 0 : r.node.parent, c = a == null ? void 0 : a.glyphGroup[a.glyphGroup.indexOf(r.node) + 1];
(r == null ? void 0 : r.node.streamType) === U.PARAGRAPH && (c == null ? void 0 : c.streamType) === U.SECTION_BREAK && (i.isBack = !0), this._focusNodePosition = i, this._removeAllCacheRanges();
const { _anchorNodePosition: A, _selectionStyle: l } = this, { scene: d, mainComponent: h } = this._context, u = this._docSkeletonManagerService.getSkeleton();
if (A == null || h == null)
return;
const g = Ko(
A,
i,
d,
h,
u,
l,
o,
s
);
if (g == null)
return;
const { textRanges: f, rectRanges: p } = g;
this._rangeList.length > 0 && f.length > 0 && this._interactTextRanges(f), this._rectRangeList.length > 0 && p.length > 0 && this._interactRectRanges(p), this._addTextRangesToCache(f), this._addRectRangesToCache(p), this.deactivate(), (E = (m = this._context.scene) == null ? void 0 : m.getEngine()) == null || E.setCapture();
}
__attachScrollEvent() {
const e = this.activeViewPort;
if (!e)
return;
const { unitId: t } = this._context;
if (this._viewPortObserverMap.has(t))
return;
const o = e.onScrollAfter$.subscribeEvent((r) => {
if (!r.viewport)
return;
const a = this._getActiveRangeInstance();
a == null || a.activeStatic();
}), s = e.onScrollEnd$.subscribeEvent((r) => {
const i = r.viewport;
if (!i)
return;
const a = i.getBounding(), c = this._getActiveRangeInstance(), A = c == null ? void 0 : c.getAnchor();
if (!(!A || A && !A.visible)) {
if (a) {
const { left: l, top: d, right: h, bottom: u } = a.viewBound;
if (A.left < l || A.left > h || A.top < d || A.top > u) {
c == null || c.deactivateStatic();
return;
}
}
this._updateInputPosition();
}
});
this._viewPortObserverMap.set(t, {
scrollBefore: o,
scrollStop: s
});
}
// FIXME: listeners here are not correctly disposed
// eslint-disable-next-line max-lines-per-function
_initInputEvents() {
this.disposeWithMe(
Ue(this._input, "keydown").subscribe((e) => {
this._isIMEInputApply || this._eventHandle(e, (t) => {
this._onKeydown$.next(t);
});
})
), this.disposeWithMe(
Ue(this._input, "input").subscribe((e) => {
if (!(e.inputType === "historyUndo" || e.inputType === "historyRedo")) {
if (this._rectRangeList.length > 0)
return e.stopPropagation(), e.preventDefault();
this._isIMEInputApply || this._eventHandle(e, (t) => {
this._onInputBefore$.next(t), this._onInput$.next(t);
});
}
})
), this.disposeWithMe(
Ue(this._input, "compositionstart").subscribe((e) => {
if (this._rectRangeList.length > 0)
return e.stopPropagation(), e.preventDefault();
this._isIMEInputApply = !0, this._eventHandle(e, (t) => {
this._onCompositionstart$.next(t);
});
})
), this.disposeWithMe(
Ue(this._input, "compositionend").subscribe((e) => {
this._isIMEInputApply = !1, this._eventHandle(e, (t) => {
this._onCompositionend$.next(t);
});
})
), this.disposeWithMe(
Ue(this._input, "compositionupdate").subscribe((e) => {
this._eventHandle(e, (t) => {
this._onInputBefore$.next(t), this._onCompositionupdate$.next(t);
});
})
), this.disposeWithMe(
Ue(this._input, "paste").subscribe((e) => {
this._eventHandle(e, (t) => {
this._onPaste$.next(t);
});
})
), this.disposeWithMe(
Ue(this._input, "focus").subscribe((e) => {
this._eventHandle(e, (t) => {
this._onFocus$.next(t);
});
})
), this.disposeWithMe(
Ue(this._input, "blur").subscribe((e) => {
this._eventHandle(e, (t) => {
this._onBlur$.next(t);
});
})
);
}
_eventHandle(e, t) {
const o = this._input.textContent || "";
this._input.innerHTML = "";
const s = this._getActiveRange(), r = this._getAllTextRanges();
t({
event: e,
content: o,
activeRange: s,
rangeList: r
});
}
_getTransformCoordForDocumentOffset(e, t) {
const o = this._context.mainComponent, { documentTransform: s } = o.getOffsetConfig();
if (this.activeViewPort == null || s == null)
return;
const r = this.activeViewPort.transformVector2SceneCoord(rn.FromArray([e, t]));
if (r)
return s.clone().invert().applyPoint(r);
}
_findNodeByCoord(e, t, o) {
const s = this._getTransformCoordForDocumentOffset(e, t);
if (s == null)
return;
const r = this._context.mainComponent, i = this._docSkeletonManagerService.getSkeleton(), {
pageLayoutType: a = an.VERTICAL,
pageMarginLeft: c,
pageMarginTop: A
} = r.getOffsetConfig();
return i.findNodeByCoord(
s,
a,
c,
A,
o
);
}
_detachEvent() {
this._onInputBefore$.complete(), this._onKeydown$.complete(), this._onInput$.complete(), this._onCompositionstart$.complete(), this._onCompositionupdate$.complete(), this._onCompositionend$.complete(), this._onSelectionStart$.complete(), this._textSelectionInner$.complete(), this._onPaste$.complete(), this._onFocus$.complete(), this._onBlur$.complete(), this._onPointerDown$.complete();
}
};
Se = PA([
Cn(1, bs),
Cn(2, fs),
Cn(3, Q),
Cn(4, z(ie))
], Se);
class DA extends ue {
constructor(t, o, s, r, i) {
super();
// Emit change event when editor lose focus.
x(this, "_change$", new Ee());
x(this, "change$", this._change$.asObservable());
// The input event fires when the value of a editor has been changed as a direct result of a user action.
x(this, "_input$", new Ee());
x(this, "input$", this._input$.asObservable());
// paste event.
x(this, "_paste$", new Ee());
x(this, "paste$", this._paste$.asObservable());
// Editor get focus.
x(this, "_focus$", new Ee());
x(this, "focus$", this._focus$.asObservable());
// Editor lose focus.
x(this, "_blur$", new Ee());
x(this, "blur$", this._blur$.asObservable());
// Emit when doc selection changed.
x(this, "_selectionChange$", new Ee());
x(this, "selectionChange$", this._selectionChange$.asObservable());
this._param = t, this._univerInstanceService = o, this._docSelectionManagerService = s, this._commandService = r, this._undoRedoService = i, this._listenSelection();
}
get docSelectionRenderService() {
return this._param.render.with(Se);
}
_listenSelection() {
const t = this._param.render.with(Se);
this.disposeWithMe(
t.onBlur$.subscribe((o) => {
this._blur$.next(o);
const s = this.getDocumentData();
this._change$.next({
target: this,
data: s
});
})
), this.disposeWithMe(
t.onFocus$.subscribe((o) => {
this._focus$.next(o);
})
), this.disposeWithMe(
t.onPaste$.subscribe((o) => {
this._paste$.next(o);
})
), this.disposeWithMe(
Fi(
t.onInput$,
t.onKeydown$.pipe(zo((o) => {
const s = o.event;
return s.ctrlKey || s.metaKey ? [j.X, j.V].includes(s.keyCode) : [j.BACKSPACE].includes(s.keyCode);
})),
t.onCompositionupdate$,
t.onCompositionend$,
t.onPaste$
).subscribe((o) => {
if (o == null)
return;
const { content: s = "" } = o, r = this.getDocumentData();
this._input$.next({
target: this,
content: s,
data: r,
isComposing: o.event.type === "compositionupdate"
});
})
), this.disposeWithMe(
this._docSelectionManagerService.textSelection$.subscribe((o) => {
if (o == null)
return;
const { unitId: s, subUnitId: r, ...i } = o, a = this.getEditorId();
s === a && this._selectionChange$.next(i);
})
);
}
isFocus() {
const t = this._param.render.with(Se);
return t.isFocusing && !!t.getActiveTextRange();
}
/**
* @deprecated use `IEditorService.focus` as instead. this is for internal usage.
*/
focus() {
const t = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC), o = this.getEditorId();
(t == null || t.getUnitId() !== o) && this._univerInstanceService.setCurrentUnitForType(o), this._param.render.with(Se).focus();
}
/**
* @deprecated use `IEditorService.blur` as instead. this is for internal usage.
*/
blur() {
this._param.render.with(Se).blur();
}
// Selects the entire content of the editor.
// Calling editor.select() will not necessarily focus the editor, so it is often used with Editor.focus
select() {
const t = this.getDocumentData();
return this.setSelectionRanges([{
startOffset: 0,
endOffset: t.body ? t.body.dataStream.length - 2 : 0
}]);
}
// Selects the specified range of characters within editor.
setSelectionRanges(t) {
const o = this.getEditorId(), s = {
unitId: o,
subUnitId: o
};
return this._docSelectionManagerService.replaceDocRanges(t, s, !1);
}
// Get current doc ranges. include text range and rect range.
getSelectionRanges() {
const t = this.getEditorId(), o = {
unitId: t,
subUnitId: t
};
return this._docSelectionManagerService.getDocRanges(o);
}
getCursorPosition() {
var o, s;
return (s = (o = this.getSelectionRanges().find((r) => r.collapsed)) == null ? void 0 : o.startOffset) != null ? s : -1;
}
// get editor id.
getEditorId() {
return this._getEditorId();
}
// get document data.
getDocumentData() {
return this._getDocDataModel().getSnapshot();
}
getDocumentDataModel() {
return this._getDocDataModel();
}
// Set the new document data.
setDocumentData(t, o) {
const { id: s } = t;
this._commandService.syncExecuteCommand(Vi.id, {
unitId: s,
snapshot: t,
textRanges: o
});
}
replaceText(t, o = !0) {
const s = this.getDocumentData();
this.setDocumentData(
{
...s,
body: {
dataStream: `${t}\r
`,
paragraphs: [{
startIndex: 0
}],
customRanges: [],
sectionBreaks: [],
tables: [],
textRuns: []
}
},
o ? [{
startOffset: t.length,
endOffset: t.length,
collapsed: !0
}] : null
);
}
// Clear the undo redo history of this editor.
clearUndoRedoHistory() {
const t = this.getEditorId();
return this._undoRedoService.clearUndoRedo(t);
}
dispose() {
this._getDocDataModel().dispose();
}
/**
* @deprecated use getEditorId.
*/
get editorUnitId() {
return this._param.editorUnitId;
}
/**
* @deprecated @TODO: @JOCS remove this in the future.
*/
get params() {
return this._param;
}
get cancelDefaultResizeListener() {
return this._param.cancelDefaultResizeListener;
}
get render() {
return this._param.render;
}
isReadOnly() {
return this._param.readonly === !0;
}
getBoundingClientRect() {
return this._param.editorDom.getBoundingClientRect();
}
get editorDOM() {
return this._param.editorDom;
}
isVisible() {
return this._param.visible;
}
isSheetEditor() {
return to(this._getEditorId());
}
/**
* @deprecated use getDocumentData.
*/
getValue() {
var s;
return (((s = this._getDocDataModel().getBody()) == null ? void 0 : s.dataStream) || "").replace(/\r\n/g, "").replace(/\n/g, "").replace(/\n/g, "");
}
/**
* @deprecated use getDocumentData.
*/
getBody() {
return this._getDocDataModel().getBody();
}
/**
* @deprecated.
*/
update(t) {
this._param = {
...this._param,
...t
};
}
/**
* @deprecated.
*/
updateCanvasStyle() {
var s;
const t = this._getDocDataModel();
if (t == null)
return;
const o = {};
(s = this._param.canvasStyle) != null && s.fontSize && (o.textStyle == null && (o.textStyle = {}), o.textStyle.fs = this._param.canvasStyle.fontSize), t.updateDocumentStyle(o);
}
_getDocDataModel() {
const t = this._getEditorId();
return this._univerInstanceService.getUnit(t, _.UNIVER_DOC);
}
_getEditorId() {
var t;
return ((t = this._param.initialSnapshot) == null ? void 0 : t.id) || this._param.editorUnitId || "";
}
}
var wA = Object.defineProperty, NA = Object.getOwnPropertyDescriptor, QA = (n, e, t, o) => {
for (var s = o > 1 ? void 0 : o ? NA(e, t) : e, r = n.length - 1, i; r >= 0; r--)
(i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
return o && s && wA(e, t, s), s;
}, Rt = (n, e) => (t, o) => e(t, o, n);
const UA = [
"univer-editor",
"univer-range-selector",
"univer-range-selector-editor",
"univer-render-canvas",
"univer-text-editor-container-placeholder"
];
let Jo = class extends ue {
constructor(e, t, o, s, r, i) {
super();
x(this, "_editors", /* @__PURE__ */ new Map());
x(this, "_focusEditorUnitId");
x(this, "_blur$", new Ee());
x(this, "blur$", this._blur$.asObservable());
x(this, "_focus$", new Ee());
x(this, "focus$", this._focus$.asObservable());
this._univerInstanceService = e, this._renderManagerService = t, this._docSelectionManagerService = o, this._contextService = s, this._commandService = r, this._undoRedoService = i, this._initUniverFocusListener();
}
// REFACTOR: @Gggpound The specific business processing should not be placed here,
// I moved from the layout service. https://github.com/dream-num/univer-pro/issues/1708
_initUniverFocusListener() {
this.disposeWithMe(
Ue(window, "focusin").subscribe((e) => {
const t = e.target;
this._blurSheetEditor(t);
})
);
}
_blurSheetEditor(e) {
if (UA.some((o) => e.classList.contains(o)))
return;
const t = this.getFocusEditor();
t && t.isSheetEditor() !== !0 && this.blur();
}
_setFocusId(e) {
this._focusEditorUnitId = e;
}
getFocusId() {
return this._focusEditorUnitId;
}
getFocusEditor() {
if (this._focusEditorUnitId)
return this.getEditor(this._focusEditorUnitId);
}
isEditor(e) {
return this._editors.has(e);
}
isSheetEditor(e) {
const t = this._editors.get(e);
return !!(t && t.isSheetEditor());
}
blur() {
this._setFocusId(null), this._contextService.setContextValue(wn, !1), this._contextService.setContextValue(lr, !1);
const e = this.getFocusEditor();
e == null || e.blur(), this._blur$.next(null);
}
focus(e) {
if (this._focusEditorUnitId && this.blur(), e == null)
return;
const t = this.getEditor(e);
if (t == null)
return;
this._univerInstanceService.setCurrentUnitForType(e);
const o = t.getValue().length;
this._contextService.setContextValue(wn, !0), to(e) || this._contextService.setContextValue(lr, !0), t.focus(), this._setFocusId(e), this._focus$.next({
startOffset: o,
endOffset: o
});
}
dispose() {
this._editors.clear(), super.dispose();
}
getEditor(e = this._getCurrentEditorUnitId()) {
return this._editors.get(e);
}
getAllEditor() {
return this._editors;
}
register(e, t) {
var c, A, l, d;
const { initialSnapshot: o, canvasStyle: s = {} } = e, r = o.id;
this._univerInstanceService.getUnit(r, _.UNIVER_DOC) == null && this._univerInstanceService.createUnit(
_.UNIVER_DOC,
o || this._getBlank(r),
{ makeCurrent: !1 }
);
let a = this._renderManagerService.getRenderById(r);
if (a == null && (this._renderManagerService.create(r), a = this._renderManagerService.getRenderById(r)), a) {
a.engine.setContainer(t);
const h = new DA(
{ ...e, render: a, editorDom: t, canvasStyle: s },
this._univerInstanceService,
this._docSelectionManagerService,
this._commandService,
this._undoRedoService
);
this._editors.set(r, h), e.scrollBar || (d = (l = (A = (c = a.mainComponent) == null ? void 0 : c.getScene()) == null ? void 0 : A.getViewports()) == null ? void 0 : l[0].getScrollBar()) == null || d.dispose();
}
return Zn(() => {
this._unRegister(r);
});
}
_unRegister(e) {
const t = this._editors.get(e);
t != null && (this._renderManagerService.removeRender(e), t.dispose(), this._editors.delete(e), this._univerInstanceService.disposeUnit(e));
}
_getCurrentEditorUnitId() {
return this._univerInstanceService.getCurrentUniverDocInstance().getUnitId();
}
_getBlank(e) {
return {
id: e,
body: {
dataStream: `${pi}`,
textRuns: [],
paragraphs: [
{
startIndex: 0
}
]
},
documentStyle: {
renderConfig: {
verticalAlign: Va.TOP,
horizontalAlign: _e.LEFT
},
marginLeft: 3,
marginTop: 0,
marginRight: 3
}
};
}
};
Jo = QA([
Rt(0, Q),
Rt(1, fe),
Rt(2, z(G)),
Rt(3, ms),
Rt(4, y),
Rt(5, eo)
], Jo);
const He = ps("univer.editor.service");
function LA(n) {
const { editorId: e, initialValue: t, container: o, autoFocus: s, isSingle: r } = n, i = Fe(() => s != null ? s : !1, []), [a, c] = ve(), A = $(He);
return kc(() => {
var l, d;
if (o.current) {
const h = {
body: {
dataStream: `\r
`,
textRuns: [],
customBlocks: [],
customDecorations: [],
customRanges: [],
paragraphs: [{
startIndex: 0
}]
},
...t,
documentStyle: {
...t == null ? void 0 : t.documentStyle,
pageSize: {
width: r ? 1 / 0 : o.current.clientWidth,
height: 1 / 0
}
},
id: e
}, u = A.register(
{
autofocus: !0,
editorUnitId: e,
initialSnapshot: h
},
o.current
), g = A.getEditor(e);
if (c(g), i) {
g.focus();
const f = ((d = (l = h.body) == null ? void 0 : l.dataStream.length) != null ? d : 2) - 2;
g.setSelectionRanges([{ startOffset: f, endOffset: f }]);
}
return () => {
u == null || u.dispose();
};
}
}, []), a;
}
const at = {
id: "doc.operation.move-cursor",
type: N.OPERATION,
handler: (n, e) => !!e
}, ct = {
id: "doc.operation.move-selection",
type: N.OPERATION,
handler: (n, e) => !!e
}, FA = (n, e, t, o) => {
const s = $(y), r = $(ro), i = cn(e);
i.current = e;
const a = cn(o);
a.current = o, Re(() => {
if (!t || !n)
return;
const A = `sheet.formula-embedding-editor.${t.getEditorId()}`, l = new Dn(), d = (u, g) => {
if (a.current) {
a.current(u, g);
return;
}
let f = se.LEFT;
u === j.ARROW_DOWN ? f = se.DOWN : u === j.ARROW_UP ? f = se.UP : u === j.ARROW_RIGHT && (f = se.RIGHT), g === K.SHIFT ? s.executeCommand(ct.id, {
direction: f
}) : s.executeCommand(at.id, {
direction: f
});
};
return l.add(s.registerCommand({
id: A,
type: N.OPERATION,
handler(u, g) {
const { keyCode: f } = g;
d(f);
}
})), [
{ keyCode: j.ARROW_DOWN },
{ keyCode: j.ARROW_LEFT },
{ keyCode: j.ARROW_RIGHT },
{ keyCode: j.ARROW_UP },
{ keyCode: j.ARROW_DOWN, metaKey: K.SHIFT },
{ keyCode: j.ARROW_LEFT, metaKey: K.SHIFT },
{ keyCode: j.ARROW_RIGHT, metaKey: K.SHIFT },
{ keyCode: j.ARROW_UP, metaKey: K.SHIFT },
{ keyCode: j.ARROW_DOWN, metaKey: K.CTRL_COMMAND },
{ keyCode: j.ARROW_LEFT, metaKey: K.CTRL_COMMAND },
{ keyCode: j.ARROW_RIGHT, metaKey: K.CTRL_COMMAND },
{ keyCode: j.ARROW_UP, metaKey: K.CTRL_COMMAND },
{ keyCode: j.ARROW_DOWN, metaKey: K.CTRL_COMMAND | K.SHIFT },
{ keyCode: j.ARROW_LEFT, metaKey: K.CTRL_COMMAND | K.SHIFT },
{ keyCode: j.ARROW_RIGHT, metaKey: K.CTRL_COMMAND | K.SHIFT },
{ keyCode: j.ARROW_UP, metaKey: K.CTRL_COMMAND | K.SHIFT }
].map(({ keyCode: u, metaKey: g }) => ({
id: A,
binding: g ? u | g : u,
preconditions: () => !0,
priority: 900,
staticParameters: {
eventType: Ri.Keyboard,
keyCode: u
}
})).forEach((u) => {
l.add(r.registerShortcut(u));
}), () => {
l.dispose();
};
}, [s, t, n, r]);
};
function HA(n, e) {
const t = $(y);
Re(() => {
if (!n) return;
const o = t.onCommandExecuted((s) => {
if (s.id === J.id) {
if (s.params.unitId !== n.getEditorId()) return;
e(n.getDocumentData());
}
});
return () => {
o.dispose();
};
}, [n, e, t]);
}
const kA = "univer-rich-text-editor-active", VA = "univer-rich-text-editor-wrap", jA = "univer-rich-text-editor-text", WA = "univer-rich-text-editor-error-wrap", zA = "univer-rich-text-editor-placeholder", Xt = {
richTextEditorActive: kA,
richTextEditorWrap: VA,
richTextEditorText: jA,
richTextEditorErrorWrap: WA,
richTextEditorPlaceholder: zA
}, cf = It((n, e) => {
var te;
const {
className: t,
autoFocus: o,
onFocusChange: s,
initialValue: r,
onClickOutside: i,
keyboardEventConfig: a,
moveCursor: c = !0,
style: A,
isSingle: l,
editorId: d,
onHeightChange: h,
onChange: u,
defaultHeight: g = 32,
maxHeight: f = 32
} = n, p = $(He), m = xo(s), E = xo(i), [I, v] = ve(g), R = Wo.useRef(null), S = Fe(() => d != null ? d : ja(`RICH_TEXT_EDITOR-${pt(4)}`), [d]), C = LA({
editorId: S,
initialValue: r,
container: R,
autoFocus: o,
isSingle: l
}), O = $(fe).getRenderById(S), P = O == null ? void 0 : O.with(Se), b = (te = P == null ? void 0 : P.isFocusing) != null ? te : !1, B = Wo.useRef(null), [M, H] = ve(() => {
var q, V;
return !Ce.transform.getPlainText((V = (q = C == null ? void 0 : C.getDocumentData().body) == null ? void 0 : q.dataStream) != null ? V : "");
}), { checkScrollBar: F } = dA(C, l, !0, !0), D = xo((q) => {
const V = O == null ? void 0 : O.with(ie), Y = V == null ? void 0 : V.getSkeleton().getActualSize();
Y && (h == null || h(Y.actualHeight), v(Math.max(g, Math.min(Y.actualHeight + 10, f)))), u == null || u(q), F();
});
return Re(() => {
var V, Y;
H(!Ce.transform.getPlainText((Y = (V = C == null ? void 0 : C.getDocumentData().body) == null ? void 0 : V.dataStream) != null ? Y : ""));
const q = C == null ? void 0 : C.selectionChange$.subscribe(() => {
var oe, ce;
H(!Ce.transform.getPlainText((ce = (oe = C == null ? void 0 : C.getDocumentData().body) == null ? void 0 : oe.dataStream) != null ? ce : ""));
});
return () => q == null ? void 0 : q.unsubscribe();
}, [C]), Nn(C == null ? void 0 : C.blur$), Nn(C == null ? void 0 : C.focus$), Re(() => {
m == null || m(b);
}, [b, m]), Re(() => {
const q = (V) => {
var oe, ce;
p.getFocusId() !== S || ((ce = (oe = V.target) == null ? void 0 : oe.dataset) == null ? void 0 : ce.editorid) === S || B.current && !B.current.contains(V.target) && (E == null || E());
};
return setTimeout(() => {
document.addEventListener("click", q);
}, 100), () => {
document.removeEventListener("click", q);
};
}, [C, S, p, E]), FA(b && c, !1, C), lA(b, a, C), Vc(e, () => C, [C]), HA(C, D), /* @__PURE__ */ w.jsx("div", { className: Un(Xt.richTextEditor, t), style: A, children: /* @__PURE__ */ w.jsxs(
"div",
{
className: Un(Xt.richTextEditorWrap, {
[Xt.richTextEditorActive]: b
}),
style: { height: I },
ref: B,
children: [
/* @__PURE__ */ w.jsx(
"div",
{
className: Xt.richTextEditorText,
ref: R,
onMouseUp: () => C == null ? void 0 : C.focus()
}
),
M ? /* @__PURE__ */ w.jsx("div", { className: Xt.richTextEditorPlaceholder, children: n.placeholder }) : null
]
}
) });
});
var Qe = function() {
return Qe = Object.assign || function(n) {
for (var e, t = 1, o = arguments.length; t < o; t++) {
e = arguments[t];
for (var s in e) Object.prototype.hasOwnProperty.call(e, s) && (n[s] = e[s]);
}
return n;
}, Qe.apply(this, arguments);
}, GA = function(n, e) {
var t = {};
for (var o in n) Object.prototype.hasOwnProperty.call(n, o) && e.indexOf(o) < 0 && (t[o] = n[o]);
if (n != null && typeof Object.getOwnPropertySymbols == "function")
for (var s = 0, o = Object.getOwnPropertySymbols(n); s < o.length; s++)
e.indexOf(o[s]) < 0 && Object.prototype.propertyIsEnumerable.call(n, o[s]) && (t[o[s]] = n[o[s]]);
return t;
}, Ht = It(function(n, e) {
var t = n.icon, o = n.id, s = n.className, r = n.extend, i = GA(n, ["icon", "id", "className", "extend"]), a = "univerjs-icon univerjs-icon-".concat(o, " ").concat(s || "").trim(), c = cn("_".concat(KA()));
return qi(t, "".concat(o), { defIds: t.defIds, idSuffix: c.current }, Qe({ ref: e, className: a }, i), r);
});
function qi(n, e, t, o, s) {
return Ft(n.tag, Qe(Qe({ key: e }, YA(n, t, s)), o), (qA(n, t).children || []).map(function(r, i) {
return qi(r, "".concat(e, "-").concat(n.tag, "-").concat(i), t, void 0, s);
}));
}
function YA(n, e, t) {
var o = Qe({}, n.attrs);
t != null && t.colorChannel1 && o.fill === "colorChannel1" && (o.fill = t.colorChannel1);
var s = e.defIds;
return !s || s.length === 0 || (n.tag === "use" && o["xlink:href"] && (o["xlink:href"] = o["xlink:href"] + e.idSuffix), Object.entries(o).forEach(function(r) {
var i = r[0], a = r[1];
typeof a == "string" && (o[i] = a.replace(/url\(#(.*)\)/, "url(#$1".concat(e.idSuffix, ")")));
})), o;
}
function qA(n, e) {
var t, o = e.defIds;
return !o || o.length === 0 ? n : n.tag === "defs" && (!((t = n.children) === null || t === void 0) && t.length) ? Qe(Qe({}, n), { children: n.children.map(function(s) {
return typeof s.attrs.id == "string" && o && o.indexOf(s.attrs.id) > -1 ? Qe(Qe({}, s), { attrs: Qe(Qe({}, s.attrs), { id: s.attrs.id + e.idSuffix }) }) : s;
}) }) : n;
}
function KA() {
return Math.random().toString(36).substring(2, 8);
}
Ht.displayName = "UniverIcon";
var XA = { 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" } }] }, Ki = It(function(n, e) {
return Ft(Ht, Object.assign({}, n, {
id: "align-text-both-single",
ref: e,
icon: XA
}));
});
Ki.displayName = "AlignTextBothSingle";
var JA = { 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" } }] }, Xi = It(function(n, e) {
return Ft(Ht, Object.assign({}, n, {
id: "horizontally-single",
ref: e,
icon: JA
}));
});
Xi.displayName = "HorizontallySingle";
var ZA = { 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" } }] }, Ji = It(function(n, e) {
return Ft(Ht, Object.assign({}, n, {
id: "left-justifying-single",
ref: e,
icon: ZA
}));
});
Ji.displayName = "LeftJustifyingSingle";
var $A = { 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" } }] }, Zi = It(function(n, e) {
return Ft(Ht, Object.assign({}, n, {
id: "right-justifying-single",
ref: e,
icon: $A
}));
});
Zi.displayName = "RightJustifyingSingle";
var el = { 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" } }] }, $i = It(function(n, e) {
return Ft(Ht, Object.assign({}, n, {
id: "todo-list",
ref: e,
icon: el
}));
});
$i.displayName = "TodoList";
function ea(n) {
var o;
const { dataStream: e } = (o = n.body) != null ? o : {}, t = [
U.TABLE_START,
U.TABLE_CELL_END,
U.TABLE_CELL_START,
U.TABLE_END,
U.TABLE_ROW_END,
U.TABLE_ROW_START,
U.COLUMN_BREAK,
U.PAGE_BREAK,
U.TAB,
U.DOCS_END,
U.CUSTOM_BLOCK
];
if (typeof e == "string")
for (let s = 0; s < e.length; s++) {
const r = e[s];
if (!t.includes(r))
return s;
}
return 0;
}
const ta = "COMPONENT_DOC_HEADER_FOOTER_PANEL", tl = "univer-panel", nl = "univer-options-section", ol = "univer-options-form-item", sl = "univer-options-input", rl = "univer-options-margin-setting", Pe = {
panel: tl,
optionsSection: nl,
optionsFormItem: ol,
optionsInput: sl,
optionsMarginSetting: rl
};
function il(n, e, t) {
const { useFirstPageHeaderFooter: o, evenAndOddHeaders: s, defaultHeaderId: r, defaultFooterId: i, firstPageHeaderId: a, firstPageFooterId: c, evenPageHeaderId: A, evenPageFooterId: l } = n;
return e === ge.HEADER ? o === L.TRUE ? t === 0 ? a : s === L.TRUE && t % 2 === 1 ? A : r : s === L.TRUE && t % 2 === 1 ? A : r : o === L.TRUE ? t === 0 ? c : s === L.TRUE && t % 2 === 1 ? l : i : s === L.TRUE && t % 2 === 1 ? l : i;
}
const al = (n) => {
const e = $(Ze), t = $(Q), o = $(fe), s = $(y), r = $(bs), { unitId: i } = n, a = o.getRenderById(i).with(Se), [c, A] = ve({}), l = (u, g) => {
var C;
A((T) => ({
...T,
[g]: u ? L.TRUE : L.FALSE
}));
const f = t.getUniverDocInstance(i), p = f == null ? void 0 : f.getSnapshot().documentStyle, m = (C = o.getRenderById(i)) == null ? void 0 : C.with(ie), E = m == null ? void 0 : m.getViewModel();
if (p == null || E == null)
return;
const I = E.getEditArea();
let v = !1;
const R = a.getSegmentPage();
let S = !1;
if (g === "useFirstPageHeaderFooter" && u === !0 && ((I === ge.HEADER && !p.firstPageHeaderId || I === ge.FOOTER && !p.firstPageFooterId) && (v = !0), v && R === 0 && (S = !0)), g === "evenAndOddHeaders" && u === !0 && ((I === ge.HEADER && !p.evenPageHeaderId || I === ge.FOOTER && !p.evenPageFooterId) && (v = !0), v && R % 2 === 1 && (S = !0)), v) {
const O = X.generateRandomId(6);
S && a.setSegment(O), s.executeCommand(_n, {
unitId: i,
segmentId: O,
headerFooterProps: {
[g]: u ? L.TRUE : L.FALSE
}
});
} else {
const T = a.getSegmentPage(), O = a.getSegment(), P = il(
{
...p,
[g]: u ? L.TRUE : L.FALSE
},
I,
T
);
P && P !== O && a.setSegment(P), s.executeCommand(_n, {
unitId: i,
headerFooterProps: {
[g]: u ? L.TRUE : L.FALSE
}
});
}
r.focus();
}, d = async (u, g) => {
A((f) => ({
...f,
[g]: u
})), await s.executeCommand(_n, {
unitId: i,
headerFooterProps: {
[g]: u
}
}), a.removeAllRanges(), a.blur();
}, h = () => {
s.executeCommand(Ps.id, {
unitId: i
});
};
return Re(() => {
const u = t.getUniverDocInstance(i), g = u == null ? void 0 : u.getSnapshot().documentStyle;
if (g) {
const {
marginHeader: f = 0,
marginFooter: p = 0,
useFirstPageHeaderFooter: m = L.FALSE,
evenAndOddHeaders: E = L.FALSE
} = g;
A({
marginHeader: f,
marginFooter: p,
useFirstPageHeaderFooter: m,
evenAndOddHeaders: E
});
}
}, [i]), /* @__PURE__ */ w.jsxs("div", { className: Pe.options, children: [
/* @__PURE__ */ w.jsxs("div", { className: Pe.optionsSection, children: [
/* @__PURE__ */ w.jsx("div", { className: Pe.optionsFormItem, children: /* @__PURE__ */ w.jsx(
Rr,
{
checked: c.useFirstPageHeaderFooter === L.TRUE,
onChange: (u) => {
l(u, "useFirstPageHeaderFooter");
},
children: e.t("headerFooter.firstPageCheckBox")
}
) }),
/* @__PURE__ */ w.jsx("div", { className: Pe.optionsFormItem, children: /* @__PURE__ */ w.jsx(
Rr,
{
checked: c.evenAndOddHeaders === L.TRUE,
onChange: (u) => {
l(u, "evenAndOddHeaders");
},
children: e.t("headerFooter.oddEvenCheckBox")
}
) })
] }),
/* @__PURE__ */ w.jsxs("div", { className: Un(Pe.optionsSection, Pe.optionsMarginSetting), children: [
/* @__PURE__ */ w.jsxs("div", { className: Pe.optionsMarginItem, children: [
/* @__PURE__ */ w.jsx("span", { children: e.t("headerFooter.headerTopMargin") }),
/* @__PURE__ */ w.jsx(
An,
{
min: 0,
max: 200,
precision: 1,
value: c.marginHeader,
onChange: (u) => {
d(u, "marginHeader");
},
className: Pe.optionsInput
}
)
] }),
/* @__PURE__ */ w.jsxs("div", { className: Pe.optionsMarginItem, children: [
/* @__PURE__ */ w.jsx("span", { children: e.t("headerFooter.footerBottomMargin") }),
/* @__PURE__ */ w.jsx(
An,
{
min: 0,
max: 200,
precision: 1,
value: c.marginFooter,
onChange: (u) => {
d(u, "marginFooter");
},
className: Pe.optionsInput
}
)
] })
] }),
/* @__PURE__ */ w.jsx("div", { className: Pe.optionsSection, children: /* @__PURE__ */ w.jsx(qc, { onClick: h, children: e.t("headerFooter.closeHeaderFooter") }) })
] });
}, cl = () => {
var A;
const n = $(Ze), e = $(fe), s = $(Q).getCurrentUniverDocInstance().getUnitId(), i = ((A = e.getRenderById(s)) == null ? void 0 : A.with(ie)).getViewModel(), [a, c] = ve(!0);
return Re(() => {
const l = i.getEditArea();
c(l !== ge.BODY);
const d = i.editAreaChange$.subscribe((h) => {
h != null && c(h !== ge.BODY);
});
return () => {
d.unsubscribe();
};
}, []), /* @__PURE__ */ w.jsx("div", { className: Pe.panel, children: a ? /* @__PURE__ */ w.jsx(al, { unitId: s }) : /* @__PURE__ */ w.jsx("div", { className: Pe.panelDisableText, children: n.t("headerFooter.disableText") }) });
}, Pr = 18, Dr = 200, _o = 6, Al = 4;
function ll(n, e) {
let { radius: t, width: o, height: s } = e;
t = t != null ? t : 0, o = o != null ? o : 30, s = s != null ? s : 30;
let r = 0;
r = Math.min(t, o / 2, s / 2), n.beginPath(), n.moveTo(0, 0), n.lineTo(o, 0), n.lineTo(o, s - r), n.arc(o - r, s - r, r, 0, Math.PI / 2, !1), n.lineTo(0, s), n.lineTo(0, 0), n.closePath(), e.fill && (n.save(), n.fillStyle = e.fill, e.fillRule === "evenodd" ? n.fill("evenodd") : n.fill(), n.restore());
}
class Ln extends dc {
constructor(t, o) {
super(t, o);
x(this, "color");
x(this, "text");
this.color = o == null ? void 0 : o.color, this.text = o == null ? void 0 : o.text;
}
static drawWith(t, o) {
const { text: s, color: r } = o;
t.save(), t.font = "13px Source Han Sans CN";
const i = t.measureText(s).width, a = Math.min(
i + 2 * _o,
Dr
);
ll(t, {
height: Pr,
width: a,
radius: 4,
fill: r,
evented: !1
}), t.fillStyle = "rgba(58, 96, 247, 1)";
const c = _o, A = Pr - Al, l = Dr - 2 * _o;
if (i > l) {
let d = "", h = 0;
for (const u of s) {
const g = t.measureText(u).width;
if (h + g <= l - t.measureText("...").width)
d += u, h += g;
else {
d += "...";
break;
}
}
t.fillText(d, c, A);
} else
t.fillText(s, c, A);
t.restore();
}
_draw(t) {
Ln.drawWith(t, this);
}
}
var dl = Object.defineProperty, ul = Object.getOwnPropertyDescriptor, hl = (n, e, t, o) => {
for (var s = o > 1 ? void 0 : o ? ul(e, t) : e, r = n.length - 1, i; r >= 0; r--)
(i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
return o && s && dl(e, t, s), s;
}, nt = (n, e) => (t, o) => e(t, o, n);
const wr = "rgba(58, 96, 247, 1)", Nr = "rgba(58, 96, 247, 0.08)";
var Me = /* @__PURE__ */ ((n) => (n[n.FIRST_PAGE_HEADER = 0] = "FIRST_PAGE_HEADER", n[n.FIRST_PAGE_FOOTER = 1] = "FIRST_PAGE_FOOTER", n[n.DEFAULT_HEADER = 2] = "DEFAULT_HEADER", n[n.DEFAULT_FOOTER = 3] = "DEFAULT_FOOTER", n[n.EVEN_PAGE_HEADER = 4] = "EVEN_PAGE_HEADER", n[n.EVEN_PAGE_FOOTER = 5] = "EVEN_PAGE_FOOTER", n))(Me || {});
function gl(n, e, t) {
const { documentStyle: o } = n.getDataModel().getSnapshot(), {
defaultHeaderId: s,
defaultFooterId: r,
evenPageHeaderId: i,
evenPageFooterId: a,
firstPageHeaderId: c,
firstPageFooterId: A,
evenAndOddHeaders: l,
useFirstPageHeaderFooter: d
} = o;
switch (e) {
case ge.BODY:
return {
createType: null,
headerFooterId: null
};
case ge.HEADER:
return d === L.TRUE && !c ? {
createType: 0,
headerFooterId: null
} : l === L.TRUE && t % 2 === 0 && !i ? {
createType: 4,
headerFooterId: null
} : s ? {
createType: null,
headerFooterId: s
} : {
createType: 2,
headerFooterId: null
};
case ge.FOOTER:
return d === L.TRUE && !A ? {
createType: 1,
headerFooterId: null
} : l === L.TRUE && t % 2 === 0 && !a ? {
createType: 5,
headerFooterId: null
} : r ? {
createType: null,
headerFooterId: r
} : {
createType: 3,
headerFooterId: null
};
default:
throw new Error(`Invalid editArea: ${e}`);
}
}
let Zo = class extends ue {
constructor(e, t, o, s, r, i, a, c, A) {
super();
x(this, "_loadedMap", /* @__PURE__ */ new WeakSet());
this._context = e, this._commandService = t, this._editorService = o, this._instanceSrv = s, this._renderManagerService = r, this._docSkeletonManagerService = i, this._docSelectionRenderService = a, this._localeService = c, this._componentManager = A, this._initialize();
}
_initialize() {
this._init(), this._drawHeaderFooterLabel(), this._initCustomComponents(), this._listenSwitchMode();
}
// Close header footer panel when switch mode.
_listenSwitchMode() {
this.disposeWithMe(
this._commandService.onCommandExecuted((e) => {
if (J.id === e.id) {
const t = this._context.unit, s = this._docSkeletonManagerService.getViewModel().getEditArea(), r = t.getSnapshot().documentStyle.documentFlavor;
s !== ge.BODY && r === ye.MODERN && this._commandService.executeCommand(Ps.id, {
unitId: this._context.unitId
});
}
})
);
}
_initCustomComponents() {
const e = this._componentManager;
this.disposeWithMe(e.register(ta, cl));
}
_init() {
const { unitId: e } = this._context, t = rt(this._context);
t == null || t.document == null || this._loadedMap.has(t.document) || (this._initialMain(e), this._loadedMap.add(t.document));
}
_initialMain(e) {
const t = rt(this._context), { document: o } = t;
this.disposeWithMe(o.onDblclick$.subscribeEvent(async (s) => {
if (this._isEditorReadOnly(e) || !this._isTraditionalMode())
return;
const { offsetX: r, offsetY: i } = s, {
pageLayoutType: a = an.VERTICAL,
pageMarginLeft: c,
pageMarginTop: A
} = o.getOffsetConfig(), l = this._getTransformCoordForDocumentOffset(r, i);
if (l == null)
return;
const d = this._docSkeletonManagerService.getViewModel(), h = this._docSkeletonManagerService.getSkeleton(), u = d.getEditArea(), { editArea: g, pageNumber: f } = h.findEditAreaByCoord(
l,
a,
c,
A
);
if (u === g)
return;
d.setEditArea(g);
const { createType: p, headerFooterId: m } = gl(d, g, f);
if (g === ge.BODY)
this._docSelectionRenderService.setSegment(""), this._docSelectionRenderService.setSegmentPage(-1), this._docSelectionRenderService.setCursorManually(r, i);
else if (p != null) {
const I = X.generateRandomId(6);
this._docSelectionRenderService.setSegment(I), this._docSelectionRenderService.setSegmentPage(f), await this._commandService.executeCommand(na.id, {
unitId: e,
createType: p,
segmentId: I
});
} else m != null && (this._docSelectionRenderService.setSegment(m), this._docSelectionRenderService.setSegmentPage(f), this._docSelectionRenderService.setCursorManually(r, i));
}));
}
_getTransformCoordForDocumentOffset(e, t) {
const o = rt(this._context), { document: s, scene: r } = o, { documentTransform: i } = s.getOffsetConfig(), a = r.getViewports()[0];
if (a == null)
return;
const c = a.transformVector2SceneCoord(rn.FromArray([e, t]));
return i.clone().invert().applyPoint(c);
}
// eslint-disable-next-line max-lines-per-function
_drawHeaderFooterLabel() {
const e = this._localeService;
this._renderManagerService.currentRender$.subscribe((t) => {
if (t == null)
return;
const o = this._renderManagerService.getRenderById(t);
if (this._editorService.isEditor(t) || this._instanceSrv.getUniverDocInstance(t) == null || o == null)
return;
const { mainComponent: s } = o, r = s;
this.disposeWithMe(
Zn(
// eslint-disable-next-line max-lines-per-function
r.pageRender$.subscribe((i) => {
if (this._editorService.isEditor(t) || !this._isTraditionalMode())
return;
const A = this._docSkeletonManagerService.getViewModel().getEditArea() === ge.BODY, { page: l, pageLeft: d, pageTop: h, ctx: u } = i, { pageWidth: g, pageHeight: f, marginTop: p, marginBottom: m } = l;
if (u.save(), u.translate(d - 0.5, h - 0.5), A ? (yn.drawWith(u, {
left: 0,
top: 0,
width: g,
height: p,
fill: "rgba(255, 255, 255, 0.5)"
}), u.save(), u.translate(0, f - m), yn.drawWith(u, {
left: 0,
top: 0,
width: g,
height: m,
fill: "rgba(255, 255, 255, 0.5)"
}), u.restore()) : (u.save(), u.translate(0, p), yn.drawWith(u, {
left: 0,
top: p,
width: g,
height: f - p - m,
fill: "rgba(255, 255, 255, 0.5)"
}), u.restore()), !A) {
const E = {
dataArray: [{
command: "M",
points: [0, p]
}, {
command: "L",
points: [g, p]
}],
strokeWidth: 1,
stroke: wr
}, I = {
dataArray: [{
command: "M",
points: [0, f - m]
}, {
command: "L",
points: [g, f - m]
}],
strokeWidth: 1,
stroke: wr
};
mr.drawWith(u, E), mr.drawWith(u, I), u.translate(0, p + 1), Ln.drawWith(u, {
text: e.t("headerFooter.header"),
color: Nr
}), u.translate(0, f - p - m), Ln.drawWith(u, {
text: e.t("headerFooter.footer"),
color: Nr
});
}
u.restore();
})
)
);
});
}
_isEditorReadOnly(e) {
const t = this._editorService.getEditor(e);
return t ? t.isReadOnly() : !1;
}
_isTraditionalMode() {
return this._context.unit.getSnapshot().documentStyle.documentFlavor === ye.TRADITIONAL;
}
};
Zo = hl([
nt(1, y),
nt(2, He),
nt(3, Q),
nt(4, fe),
nt(5, z(ie)),
nt(6, z(Se)),
nt(7, z(Ze)),
nt(8, z(io))
], Zo);
const Ms = {
id: "sidebar.operation.doc-header-footer-panel",
type: N.OPERATION,
handler: async (n, e) => {
const t = n.get(Bi), o = n.get(Ze);
switch (e.value) {
case "open":
t.open({
header: { title: o.t("headerFooter.panel") },
children: { label: ta },
onClose: () => {
},
width: 400
});
break;
case "close":
default:
t.close();
break;
}
return !0;
}
};
function Qr() {
return {
dataStream: `\r
`,
textRuns: [{
st: 0,
ed: 0,
ts: {
fs: 9
// The default header footer text size.
}
}],
customBlocks: [],
paragraphs: [
{
startIndex: 0,
paragraphStyle: {
spaceAbove: { v: 0 },
lineSpacing: 1.5,
spaceBelow: { v: 0 }
}
}
],
sectionBreaks: [
{
startIndex: 1
}
]
};
}
function Po(n, e, t, o) {
const s = k.getInstance(), r = 6, i = n != null ? n : X.generateRandomId(r), a = e === Me.DEFAULT_HEADER || e === Me.FIRST_PAGE_HEADER || e === Me.EVEN_PAGE_HEADER, c = s.insertOp([a ? "headers" : "footers", i], {
[a ? "headerId" : "footerId"]: i,
body: Qr()
});
o.push(c);
const A = X.generateRandomId(r), l = s.insertOp([a ? "footers" : "headers", A], {
[a ? "footerId" : "headerId"]: A,
body: Qr()
});
o.push(l);
let d = "defaultHeaderId", h = "defaultFooterId";
switch (e) {
case Me.DEFAULT_HEADER:
d = "defaultHeaderId", h = "defaultFooterId";
break;
case Me.DEFAULT_FOOTER:
d = "defaultFooterId", h = "defaultHeaderId";
break;
case Me.FIRST_PAGE_HEADER:
d = "firstPageHeaderId", h = "firstPageFooterId";
break;
case Me.FIRST_PAGE_FOOTER:
d = "firstPageFooterId", h = "firstPageHeaderId";
break;
case Me.EVEN_PAGE_HEADER:
d = "evenPageHeaderId", h = "evenPageFooterId";
break;
case Me.EVEN_PAGE_FOOTER:
d = "evenPageFooterId", h = "evenPageHeaderId";
break;
default:
throw new Error(`Unknown header footer type: ${e}`);
}
for (const [u, g] of [[d, i], [h, A]])
if (t[u] != null) {
const f = s.replaceOp(["documentStyle", u], t[u], g);
o.push(f);
} else {
const f = s.insertOp(["documentStyle", u], g);
o.push(f);
}
return o;
}
const _n = "doc.command.core-header-footer", na = {
id: _n,
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function
handler: async (n, e) => {
var v;
const t = n.get(y), o = n.get(Q), s = n.get(fe), { unitId: r, segmentId: i, createType: a, headerFooterProps: c } = e, A = (v = s.getRenderById(r)) == null ? void 0 : v.with(ie), l = o.getUniverDocInstance(r), d = A == null ? void 0 : A.getViewModel();
if (l == null || d == null)
return !1;
const h = d.getEditArea(), { documentStyle: u } = l.getSnapshot(), g = (c == null ? void 0 : c.marginFooter) != null || (c == null ? void 0 : c.marginHeader) != null, f = [{
startOffset: 0,
endOffset: 0,
collapsed: !0
}], p = {
id: J.id,
params: {
unitId: r,
actions: [],
textRanges: f,
debounce: !0
}
};
g && (p.params.noNeedSetTextRange = !0);
const m = k.getInstance(), E = [];
return a != null && Po(i, a, u, E), c != null && Object.keys(c).forEach((R) => {
const S = c[R], C = u[R];
if (S === C)
return;
let T;
if (C === void 0 ? T = m.insertOp(["documentStyle", R], S) : T = m.replaceOp(["documentStyle", R], C, S), E.push(T), R === "useFirstPageHeaderFooter" && S === L.TRUE && !u.firstPageHeaderId) {
const O = h === ge.HEADER ? Me.FIRST_PAGE_HEADER : Me.FIRST_PAGE_FOOTER;
Po(i, O, u, E);
} else if (R === "evenAndOddHeaders" && S === L.TRUE && !u.evenPageHeaderId) {
const O = h === ge.HEADER ? Me.EVEN_PAGE_HEADER : Me.EVEN_PAGE_FOOTER;
Po(i, O, u, E);
}
}), E.length === 0 ? !1 : (p.params.actions = E.reduce((R, S) => k.compose(R, S), null), !!t.syncExecuteCommand(p.id, p.params));
}
}, _s = {
id: "doc.command.open-header-footer-panel",
type: N.COMMAND,
handler: async (n, e) => n.get(y).executeCommand(Ms.id, { value: "open" })
}, Ps = {
id: "doc.command.close-header-footer",
type: N.COMMAND,
handler: async (n, e) => {
var g;
const t = n.get(y), o = n.get(fe), s = n.get(G), r = n.get(Q), { unitId: i } = e, a = o.getRenderById(i);
if (a == null)
return !1;
const { scene: c } = a, A = c.getTransformerByCreate(), l = a.with(ie), d = a.with(Se), h = l == null ? void 0 : l.getSkeleton(), u = l == null ? void 0 : l.getViewModel();
return u == null || h == null ? !1 : (s.replaceDocRanges([]), A.clearSelectedObjects(), d.setSegment(""), d.setSegmentPage(-1), u.setEditArea(ge.BODY), h.calculate(), (g = a.mainComponent) == null || g.makeDirty(!0), queueMicrotask(() => {
const f = r.getUnit(i), p = f == null ? void 0 : f.getSnapshot();
if (p == null)
return;
const m = ea(p);
s.replaceDocRanges([
{
startOffset: m,
endOffset: m
}
]);
}), t.executeCommand(Ms.id, { value: "close" }), !0);
}
}, kt = "UI_PLUGIN_DOCS", Ds = `${kt}_COLOR_PICKER_COMPONENT`, oa = `${kt}_FONT_FAMILY_COMPONENT`, sa = `${kt}_FONT_FAMILY_ITEM_COMPONENT`, ra = `${kt}_FONT_SIZE_COMPONENT`, fl = "univer-doc-list-type-picker", pl = "univer-doc-list-type-picker-item", ml = "univer-doc-list-type-picker-item-active", Do = {
docListTypePicker: fl,
docListTypePickerItem: pl,
docListTypePickerItemActive: ml
}, ia = (n) => {
const { value: e, onChange: t, options: o } = n;
return /* @__PURE__ */ w.jsx("div", { className: Do.docListTypePicker, children: o.map((s) => /* @__PURE__ */ w.jsx(
"img",
{
className: Do.docListTypePickerItem + (e === s.value ? `
${Do.docListTypePickerItemActive}
` : ""),
onClick: () => {
t(s.value);
},
src: s.img
},
s.value
)) });
}, El = [
{
value: Oe.ORDER_LIST,
img: ""
},
{
value: Oe.ORDER_LIST_1,
img: ""
},
{
value: Oe.ORDER_LIST_2,
img: ""
},
{
value: Oe.ORDER_LIST_3,
img: ""
},
{
value: Oe.ORDER_LIST_4,
img: ""
},
{
value: Oe.ORDER_LIST_5,
img: ""
}
], Sl = (n) => /* @__PURE__ */ w.jsx(
ia,
{
...n,
options: El
}
), Il = [
{
value: Oe.BULLET_LIST,
img: ""
},
{
value: Oe.BULLET_LIST_1,
img: ""
},
{
value: Oe.BULLET_LIST_2,
img: ""
},
{
value: Oe.BULLET_LIST_3,
img: ""
},
{
value: Oe.BULLET_LIST_4,
img: ""
},
{
value: Oe.BULLET_LIST_5,
img: ""
}
], Cl = (n) => /* @__PURE__ */ w.jsx(
ia,
{
...n,
options: Il
}
), aa = `${kt}_ORDER_LIST_TYPE_COMPONENT`, ca = `${kt}_BULLET_LIST_TYPE_COMPONENT`, vl = "doc.command.tab", _t = {
id: vl,
type: N.COMMAND,
async handler(n, e) {
const o = n.get(Et).onAutoFormat(_t.id, e);
return (await Es(o, n.get(y))).result;
}
}, Rl = "doc.command.after-space", Ao = {
id: Rl,
type: N.COMMAND,
async handler(n) {
const t = n.get(Et).onAutoFormat(Ao.id);
return (await Es(t, n.get(y))).result;
}
}, ln = {
id: "doc.command.enter",
type: N.COMMAND,
async handler(n) {
const t = n.get(Et).onAutoFormat(ln.id);
return (await Es(t, n.get(y))).result;
}
};
function de(n) {
return n.getContextValue(hn) && n.getContextValue(Ss) && !n.getContextValue(mi);
}
function bl(n) {
return n.getContextValue(hn) && n.getContextValue(Ss) && !n.getContextValue(mi);
}
const xl = {
id: _t.id,
binding: j.TAB,
preconditions: de
}, Ol = {
id: _t.id,
binding: j.TAB | K.SHIFT,
preconditions: de,
staticParameters: {
shift: !0
}
};
var Tl = Object.defineProperty, yl = Object.getOwnPropertyDescriptor, Bl = (n, e, t, o) => {
for (var s = o > 1 ? void 0 : o ? yl(e, t) : e, r = n.length - 1, i; r >= 0; r--)
(i = n[r]) && (s = (o ? i(e, t, s) : i(s)) || s);
return o && s && Tl(e, t, s), s;
}, wo = (n, e) => (t, o) => e(t, o, n);
const Ml = 11, _l = 9, vn = {
/**
* fontFamily
*/
ff: "Arial",
/**
* fontSize
*/
fs: Ml
};
let Je = class extends ue {
constructor(e, t, o) {
super();
x(this, "_cacheStyle", null);
this._textSelectionManagerService = e, this._univerInstanceService = t, this._renderManagerService = o, this._init();
}
_init() {
this._listenDocRangeChange();
}
_listenDocRangeChange() {
this.disposeWithMe(
this._textSelectionManagerService.textSelection$.subscribe(() => {
this._clearStyleCache();
})
);
}
getStyleCache() {
return this._cacheStyle;
}
getDefaultStyle() {
var i;
const e = this._univerInstanceService.getCurrentUnitForType(_.UNIVER_DOC);
if (e == null)
return {
...vn
};
const t = e == null ? void 0 : e.getUnitId(), o = (i = this._renderManagerService.getRenderById(t)) == null ? void 0 : i.with(ie), s = o == null ? void 0 : o.getViewModel();
return s == null ? {
...vn
} : s.getEditArea() === ge.BODY ? {
...vn
} : {
...vn,
fs: _l
};
}
setStyleCache(e) {
this._cacheStyle = {
...this._cacheStyle,
...e
};
}
_clearStyleCache() {
this._cacheStyle = null;
}
};
Je = Bl([
wo(0, z(G)),
wo(1, Q),
wo(2, fe)
], Je);
function Ve(n, e, t) {
return t.executeCommand(lt.id, {
preCommandId: n,
...e != null ? e : {}
});
}
const Ur = "doc.command.set-inline-format-bold", Vt = {
id: Ur,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Ur,
e,
t
);
}
}, Lr = "doc.command.set-inline-format-italic", jt = {
id: Lr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Lr,
e,
t
);
}
}, Fr = "doc.command.set-inline-format-underline", Wt = {
id: Fr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Fr,
e,
t
);
}
}, Hr = "doc.command.set-inline-format-strikethrough", zt = {
id: Hr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Hr,
e,
t
);
}
}, kr = "doc.command.set-inline-format-subscript", Ct = {
id: kr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
kr,
e,
t
);
}
}, Vr = "doc.command.set-inline-format-superscript", Gt = {
id: Vr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Vr,
e,
t
);
}
}, jr = "doc.command.set-inline-format-fontsize", Pt = {
id: jr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
jr,
e,
t
);
}
}, Wr = "doc.command.set-inline-format-font-family", Dt = {
id: Wr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Wr,
e,
t
);
}
}, zr = "doc.command.set-inline-format-text-color", wt = {
id: zr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
zr,
e,
t
);
}
}, Gr = "doc.command.set-inline-format-text-background-color", Nt = {
id: Gr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Gr,
e,
t
);
}
}, Yr = "doc.command.reset-inline-format-text-background-color", fn = {
id: Yr,
type: N.COMMAND,
handler: async (n, e) => {
const t = n.get(y);
return Ve(
Yr,
e,
t
);
}
}, $o = {
[Vt.id]: "bl",
[jt.id]: "it",
[Wt.id]: "ul",
[zt.id]: "st",
[Pt.id]: "fs",
[Dt.id]: "ff",
[wt.id]: "cl",
[Nt.id]: "bg",
[fn.id]: "bg",
[Ct.id]: "va",
[Gt.id]: "va"
}, lt = {
id: "doc.command.set-inline-format",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function, complexity
handler: async (n, e) => {
var R;
const { value: t, preCommandId: o } = e, s = n.get(y), r = n.get(G), i = n.get(Q), a = n.get(Je), c = r.getDocRanges(), A = (R = c.find((S) => S.isActive)) != null ? R : c[0];
if (c.length === 0)
return !1;
const { segmentId: l } = c[0], d = i.getCurrentUnitForType(_.UNIVER_DOC);
if (d == null)
return !1;
const h = d.getSelfOrHeaderFooterModel(l).getBody();
if (h == null)
return !1;
const u = d.getUnitId();
let g;
switch (o) {
case Vt.id:
// fallthrough
case jt.id:
// fallthrough
case Wt.id:
// fallthrough
case zt.id:
// fallthrough
case Ct.id:
// fallthrough
case Gt.id: {
const S = a.getDefaultStyle(), C = la(
h,
A,
S
);
g = Dl(
C,
o
);
break;
}
case Pt.id:
case Dt.id: {
g = t;
break;
}
case wt.id:
case Nt.id: {
g = {
rgb: t
};
break;
}
case fn.id: {
g = {
rgb: null
};
break;
}
default:
throw new Error(`Unknown command: ${o} in handleInlineFormat`);
}
const f = {
id: J.id,
params: {
unitId: u,
actions: [],
textRanges: c
}
}, p = new me(), m = k.getInstance(), E = new St();
E.reset();
for (const S of c) {
let { startOffset: C, endOffset: T, rangeType: O } = S;
if (C == null || T == null)
continue;
if (O === Ge.RECT && (C = C - 1), C === T) {
const B = a.getStyleCache(), M = $o[o];
a.setStyleCache(
{
[M]: (B == null ? void 0 : B[M]) !== void 0 ? Aa(
B,
M,
o
) : g
}
);
continue;
}
const P = {
dataStream: "",
textRuns: [
{
st: 0,
ed: T - C,
ts: {
[$o[o]]: g
}
}
]
}, b = C - E.cursor;
b !== 0 && p.push({
t: W.RETAIN,
len: b
}), p.push({
t: W.RETAIN,
body: P,
len: T - C
}), E.reset(), E.moveCursor(T);
}
const I = le(d, l);
return f.params.actions = m.editOp(p.serialize(), I), !!s.syncExecuteCommand(f.id, f.params);
}
};
function Pl(n) {
return n !== null && typeof n == "object";
}
function Aa(n, e, t) {
if (/bl|it/.test(e))
return (n == null ? void 0 : n[e]) === L.TRUE ? L.FALSE : L.TRUE;
if (/ul|st/.test(e))
return Pl(n == null ? void 0 : n[e]) && (n == null ? void 0 : n[e]).s === L.TRUE ? {
s: L.FALSE
} : {
s: L.TRUE
};
if (/va/.test(e))
return t === Ct.id ? (n == null ? void 0 : n[e]) === Ne.SUBSCRIPT ? Ne.NORMAL : Ne.SUBSCRIPT : (n == null ? void 0 : n[e]) === Ne.SUPERSCRIPT ? Ne.NORMAL : Ne.SUPERSCRIPT;
}
function la(n, e, t) {
var A, l, d, h, u, g, f, p, m, E, I, v, R, S;
const { startOffset: o, endOffset: s, collapsed: r } = e;
if (r) {
const C = (A = n.textRuns) != null ? A : [];
let T = null;
for (let O = C.length - 1; O >= 0; O--) {
const P = C[O];
if (P.st < o && o <= P.ed) {
T = P;
break;
}
}
return T != null && T.ts ? { ...t, ...T.ts } : t;
}
const { textRuns: i = [] } = Ei(n, o, s), a = X.deepClone(t);
a.fs = Math.max(a.fs, ...i.map((C) => {
var T, O;
return (O = (T = C == null ? void 0 : C.ts) == null ? void 0 : T.fs) != null ? O : a.fs;
})), a.ff = (h = (d = (l = i.find((C) => {
var T;
return ((T = C.ts) == null ? void 0 : T.ff) != null;
})) == null ? void 0 : l.ts) == null ? void 0 : d.ff) != null ? h : a.ff, a.it = i.length && i.every((C) => {
var T;
return ((T = C.ts) == null ? void 0 : T.it) === L.TRUE;
}) ? L.TRUE : L.FALSE, a.bl = i.length && i.every((C) => {
var T;
return ((T = C.ts) == null ? void 0 : T.bl) === L.TRUE;
}) ? L.TRUE : L.FALSE, a.ul = i.length && i.every((C) => {
var T, O;
return ((O = (T = C.ts) == null ? void 0 : T.ul) == null ? void 0 : O.s) === L.TRUE;
}) ? (u = i[0].ts) == null ? void 0 : u.ul : a.ul, a.st = i.length && i.every((C) => {
var T, O;
return ((O = (T = C.ts) == null ? void 0 : T.st) == null ? void 0 : O.s) === L.TRUE;
}) ? (g = i[0].ts) == null ? void 0 : g.st : a.st, a.bg = (m = (p = (f = i.find((C) => {
var T;
return ((T = C.ts) == null ? void 0 : T.bg) != null;
})) == null ? void 0 : f.ts) == null ? void 0 : p.bg) != null ? m : a.bg, a.cl = (v = (I = (E = i.find((C) => {
var T;
return ((T = C.ts) == null ? void 0 : T.cl) != null;
})) == null ? void 0 : E.ts) == null ? void 0 : I.cl) != null ? v : a.cl;
const c = i.filter((C) => {
var T;
return ((T = C == null ? void 0 : C.ts) == null ? void 0 : T.va) != null;
});
if (c.length > 0 && c.length === i.length) {
const C = (R = c[0].ts) == null ? void 0 : R.va;
let T = !0;
for (let O = 1; O < c.length; O++)
if (((S = c[O].ts) == null ? void 0 : S.va) !== C) {
T = !1;
break;
}
T && (a.va = C);
}
return a;
}
function Dl(n, e) {
const t = $o[e];
return Aa(n, t, e);
}
const pn = {
id: "doc.command.list-operation",
type: N.COMMAND,
handler: (n, e) => {
var E, I;
const t = n.get(G), o = n.get(Q), s = n.get(y), r = e.listType, i = o.getCurrentUnitForType(_.UNIVER_DOC), a = (E = t.getDocRanges()) != null ? E : [];
if (i == null || a.length === 0)
return !1;
const c = a[0].segmentId, A = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
if (A == null)
return !1;
const l = mn(a, A), d = i.getUnitId(), h = {
id: J.id,
params: {
unitId: d,
actions: [],
textRanges: a,
isEditing: !1
}
};
new St().reset();
const g = Ce.paragraph.bullet.switch({
paragraphs: l,
listType: r,
document: i,
segmentId: c
}), f = k.getInstance(), p = le(i, c);
return h.params.actions = f.editOp(g.serialize(), p), !!s.syncExecuteCommand(h.id, h.params);
}
}, lo = {
id: "doc.command.change-list-type",
type: N.COMMAND,
handler: (n, e) => {
var E, I;
const t = n.get(G), o = n.get(Q), s = n.get(y), { listType: r } = e, i = o.getCurrentUnitForType(_.UNIVER_DOC), a = t.getDocRanges();
if (i == null || a == null || !a.length)
return !1;
const { segmentId: c } = a[0], A = (E = t.getDocRanges()) != null ? E : [], l = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
if (l == null)
return !1;
const d = mn(A, l), h = i.getUnitId(), u = Ce.paragraph.bullet.set({
paragraphs: d,
listType: r,
segmentId: c,
document: i
});
if (!u)
return !1;
const g = k.getInstance(), f = {
id: J.id,
params: {
unitId: h,
actions: [],
textRanges: A,
isEditing: !1
}
}, p = le(i, c);
return f.params.actions = g.editOp(u.serialize(), p), !!s.syncExecuteCommand(f.id, f.params);
}
};
var Pn = /* @__PURE__ */ ((n) => (n[n.increase = 1] = "increase", n[n.decrease = -1] = "decrease", n))(Pn || {});
const es = {
id: "doc.command.change-list-nesting-level",
type: N.COMMAND,
handler: (n, e) => {
var E, I;
if (!e)
return !1;
const { type: t } = e, o = n.get(G), s = n.get(Q), r = n.get(y), i = s.getCurrentUnitForType(_.UNIVER_DOC), a = o.getActiveTextRange();
if (i == null || a == null)
return !1;
const { segmentId: c } = a, A = (E = o.getDocRanges()) != null ? E : [], l = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
if (l == null)
return !1;
const d = Qs(a, l), h = i.getUnitId(), u = k.getInstance(), g = Ce.paragraph.bullet.changeNestLevel({
paragraphs: d,
type: t,
segmentId: c,
document: i
}), f = {
id: J.id,
params: {
unitId: h,
actions: [],
textRanges: A,
isEditing: !1
}
}, p = le(i, c);
return f.params.actions = u.editOp(g.serialize(), p), !!r.syncExecuteCommand(f.id, f.params);
}
}, uo = {
id: "doc.command.bullet-list",
type: N.COMMAND,
handler: (n, e) => {
const t = n.get(y);
return e != null && e.value ? t.syncExecuteCommand(lo.id, {
listType: e.value
}) : t.syncExecuteCommand(pn.id, {
listType: Oe.BULLET_LIST
});
}
}, ws = {
id: "doc.command.check-list",
type: N.COMMAND,
handler: (n, e) => {
const t = n.get(y);
return e != null && e.value ? t.syncExecuteCommand(lo.id, {
listType: e.value
}) : t.syncExecuteCommand(pn.id, {
listType: Oe.CHECK_LIST
});
}
}, Ns = {
id: "doc.command.toggle-check-list",
type: N.COMMAND,
handler: (n, e) => {
var f;
if (!e)
return !1;
const t = n.get(Q), o = n.get(y), { index: s, segmentId: r, textRanges: i } = e, a = t.getCurrentUnitForType(_.UNIVER_DOC);
if (a == null || ((f = a.getSelfOrHeaderFooterModel(r).getBody()) == null ? void 0 : f.paragraphs) == null)
return !1;
const A = a.getUnitId(), l = {
id: J.id,
params: {
unitId: A,
actions: [],
textRanges: i != null ? i : [],
segmentId: r,
isEditing: !1
}
}, d = Ce.paragraph.bullet.toggleChecklist({
document: a,
paragraphIndex: s,
segmentId: r
});
if (!d)
return !1;
const h = k.getInstance(), u = le(a, r);
return l.params.actions = h.editOp(d.serialize(), u), !!o.syncExecuteCommand(l.id, l.params);
}
}, ho = {
id: "doc.command.order-list",
type: N.COMMAND,
handler: (n, e) => {
const t = n.get(y);
return e != null && e.value ? t.syncExecuteCommand(lo.id, {
listType: e.value
}) : t.syncExecuteCommand(pn.id, {
listType: Oe.ORDER_LIST
});
}
}, da = {
id: "doc.command.quick-list",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function
handler(n, e) {
var oe, ce, he, Ae, ne;
if (!e)
return !1;
const t = n.get(G), o = n.get(Q), s = n.get(y), r = o.getCurrentUnitForType(_.UNIVER_DOC), i = t.getActiveTextRange();
if (r == null || i == null)
return !1;
const { segmentId: a } = i, { listType: c, paragraph: A } = e, { paragraphStart: l, paragraphEnd: d } = A, h = new me(), u = k.getInstance(), { defaultTabStop: g = 36 } = r.getSnapshot().documentStyle, f = (ce = (oe = r.getSelfOrHeaderFooterModel(a).getBody()) == null ? void 0 : oe.sectionBreaks) != null ? ce : [], { startIndex: p, paragraphStyle: m = {} } = A, { indentFirstLine: E, snapToGrid: I, indentStart: v } = m, R = Wa[c].nestingLevel[0].paragraphProperties || {}, { hanging: S, indentStart: C } = R, T = R.textStyle, { charSpace: O, gridType: P } = wl(p, f) || { charSpace: 0, gridType: za.LINES }, b = uc(O, g, P, I);
let M = X.generateRandomId(6);
const H = (Ae = (he = r.getBody()) == null ? void 0 : he.paragraphs) != null ? Ae : [], F = H.findIndex((ae) => ae.startIndex === A.startIndex), D = H[F - 1], te = H[F + 1];
D && D.bullet && D.bullet.listType.indexOf(c) === 0 ? M = D.bullet.listId : te && te.bullet && te.bullet.listType.indexOf(c) === 0 && (M = te.bullet.listId);
const q = {
id: J.id,
params: {
unitId: r.getUnitId(),
actions: [],
textRanges: [{
startOffset: l,
endOffset: l,
collapsed: !0
}],
isEditing: !1
}
};
h.push({
t: W.RETAIN,
len: l
}), h.push({
t: W.DELETE,
len: d - l
}), h.push({
t: W.RETAIN,
len: 1,
body: {
dataStream: "",
paragraphs: [
{
startIndex: 0,
paragraphStyle: {
...m,
textStyle: {
...m.textStyle,
...T
},
indentFirstLine: void 0,
hanging: S,
indentStart: { v: ze(C, b) - ze(S, b) + ze(E, b) + ze(v, b) }
},
bullet: {
...(ne = A.bullet) != null ? ne : {
nestingLevel: 0,
textStyle: {
fs: 20
}
},
listType: c,
listId: M
}
}
]
}
});
const V = le(r, a);
return q.params.actions = u.editOp(h.serialize(), V), !!s.syncExecuteCommand(q.id, q.params);
}
};
function Qs(n, e) {
const { startOffset: t, endOffset: o } = n, s = [];
let r = -1;
for (const i of e) {
const { startIndex: a } = i;
(t > r && t <= a || o > r && o <= a || a >= t && a <= o) && s.push(i), r = a;
}
return s;
}
function mn(n, e) {
const t = [];
for (const o of n) {
const s = Qs(o, e);
t.push(...s);
}
return t;
}
function wl(n, e) {
const t = e.sort(Ga("startIndex"));
for (let o = 0; o < t.length; o++) {
const s = e[o];
if (s.startIndex >= n)
return s;
}
}
const et = {
id: "doc.command.align-action",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function
handler: (n, e) => {
var I;
const t = n.get(G), o = n.get(Q), s = n.get(y), { alignType: r } = e, i = o.getCurrentUniverDocInstance();
if (i == null)
return !1;
const a = t.getDocRanges();
if (a.length === 0)
return !1;
const c = a[0].segmentId, A = (I = i.getSelfOrHeaderFooterModel(c).getBody()) == null ? void 0 : I.paragraphs;
if (A == null)
return !1;
const l = mn(a, A), d = i.getUnitId(), h = l.every((v) => {
var R;
return ((R = v.paragraphStyle) == null ? void 0 : R.horizontalAlign) === r;
}), u = {
id: J.id,
params: {
unitId: d,
actions: [],
textRanges: a
}
}, g = new St();
g.reset();
const f = new me(), p = k.getInstance();
for (const v of l) {
const { startIndex: R } = v;
f.push({
t: W.RETAIN,
len: R - g.cursor
});
const S = {
...v.paragraphStyle,
horizontalAlign: h ? _e.UNSPECIFIED : r
};
f.push({
t: W.RETAIN,
len: 1,
body: {
dataStream: "",
paragraphs: [
{
...v,
paragraphStyle: S,
startIndex: 0
}
]
},
coverType: no.REPLACE
}), g.moveCursorTo(R + 1);
}
const m = le(i, c);
return u.params.actions = p.editOp(f.serialize(), m), !!s.syncExecuteCommand(u.id, u.params);
}
}, go = {
id: "doc.command.align-left",
type: N.COMMAND,
handler: (n) => n.get(y).syncExecuteCommand(et.id, {
alignType: _e.LEFT
})
}, fo = {
id: "doc.command.align-center",
type: N.COMMAND,
handler: (n) => n.get(y).syncExecuteCommand(et.id, {
alignType: _e.CENTER
})
}, po = {
id: "doc.command.align-right",
type: N.COMMAND,
handler: (n) => n.get(y).syncExecuteCommand(et.id, {
alignType: _e.RIGHT
})
}, mo = {
id: "doc.command.align-justify",
type: N.COMMAND,
handler: (n) => n.get(y).syncExecuteCommand(et.id, {
alignType: _e.JUSTIFIED
})
}, Nl = {
id: Vt.id,
binding: j.B | K.CTRL_COMMAND,
preconditions: de
}, Ql = {
id: jt.id,
binding: j.I | K.CTRL_COMMAND,
preconditions: de
}, Ul = {
id: Wt.id,
binding: j.U | K.CTRL_COMMAND,
preconditions: de
}, Ll = {
id: zt.id,
binding: j.X | K.SHIFT | K.CTRL_COMMAND,
preconditions: de
}, Fl = {
id: Ct.id,
binding: j.COMMA | K.CTRL_COMMAND,
preconditions: de
}, Hl = {
id: Gt.id,
binding: j.PERIOD | K.CTRL_COMMAND,
preconditions: de
}, kl = {
id: go.id,
binding: j.L | K.CTRL_COMMAND | K.SHIFT,
preconditions: de
}, Vl = {
id: po.id,
binding: j.R | K.CTRL_COMMAND | K.SHIFT,
preconditions: de
}, jl = {
id: fo.id,
binding: j.E | K.CTRL_COMMAND | K.SHIFT,
preconditions: de
}, Wl = {
id: mo.id,
binding: j.J | K.CTRL_COMMAND | K.SHIFT,
preconditions: de
}, zl = {
id: ho.id,
binding: j.Digit7 | K.CTRL_COMMAND | K.SHIFT,
preconditions: de
}, Gl = {
id: uo.id,
binding: j.Digit8 | K.CTRL_COMMAND | K.SHIFT,
preconditions: de
}, Yl = "univer-doc-count-bar", ql = {
docCountBar: Yl
}, Kl = (n, e) => {
const t = n.get(Q).getUniverDocInstance(e.unitId), o = (t == null ? void 0 : t.zoomRatio) || 1;
return {
...X.deepClone(e),
zoomRatio: o
};
}, Ye = {
id: "doc.operation.set-zoom-ratio",
type: N.OPERATION,
handler: (n, e) => {
const t = n.get(Q).getUniverDocInstance(e.unitId);
if (!t)
return !1;
const o = t.getSnapshot();
return o.settings == null ? o.settings = {
zoomRatio: e.zoomRatio
} : o.settings.zoomRatio = e.zoomRatio, !0;
}
}, Xl = [50, 80, 100, 130, 150, 170, 200, 400], Jl = [10, 400];
function Zl() {
const n = $(y), e = $(Q), t = Fe(() => e.getCurrentTypeOfUnit$(_.UNIVER_DOC), []), o = Nn(t), s = Li(() => {
var A, l;
if (!o) return 100;
const c = ((l = (A = o.getSettings()) == null ? void 0 : A.zoomRatio) != null ? l : 1) * 100;
return Math.round(c);
}, [o]), [r, i] = ve(() => s());
Re(() => (i(s()), n.onCommandExecuted((A) => {
if (A.id === Ye.id) {
const l = s();
i(l);
}
}).dispose), [n, s]);
function a(c) {
if (i(c), o == null)
return;
const A = c / 100;
n.executeCommand(Ye.id, {
unitId: o.getUnitId(),
zoomRatio: A
});
}
return /* @__PURE__ */ w.jsx(
Kc,
{
min: Jl[0],
value: r,
shortcuts: Xl,
onChange: a
}
);
}
function $l(n) {
return /* @__PURE__ */ w.jsx("section", { className: ql.docCountBar, children: /* @__PURE__ */ w.jsx(Zl, {}) });
}
const ed = "univer-doc-footer-container", td = {
docFooterContainer: ed
}, nd = () => /* @__PURE__ */ w.jsxs("div", { className: td.docFooterContainer, children: [
/* @__PURE__ */ w.jsx("div", {}),
/* @__PURE__ */ w.jsx($l, {})
] }), Us = "docs-ui.config", qr = {
layout: {
docContainerConfig: sA,
toolbarConfig: oA
}
};
var Eo = /* @__PURE__ */ ((n) => (n[n.ABOVE = 0] = "ABOVE", n[n.BELLOW = 1] = "BELLOW", n))(Eo || {}), Ls = /* @__PURE__ */ ((n) => (n[n.LEFT = 0] = "LEFT", n[n.RIGHT = 1] = "RIGHT", n))(Ls || {});
function od(n, e) {
let t = U.TABLE_START;
const o = [], s = [];
for (let r = 0; r < n; r++) {
t += U.TABLE_ROW_START;
for (let i = 0; i < e; i++)
t += `${U.TABLE_CELL_START}\r
${U.TABLE_CELL_END}`, o.push({
startIndex: t.length - 3,
paragraphStyle: {
spaceAbove: { v: 3 },
lineSpacing: 2,
spaceBelow: { v: 0 }
}
}), s.push({
startIndex: t.length - 2
});
t += U.TABLE_ROW_END;
}
return t += U.TABLE_END, {
dataStream: t,
paragraphs: o,
sectionBreaks: s
};
}
function Fs() {
return {
margin: {
start: {
v: 10
},
end: {
v: 10
},
top: {
v: 5
},
bottom: {
v: 5
}
}
};
}
function Hs(n) {
const e = Fs();
return {
tableCells: [...new Array(n).fill(null).map(() => X.deepClone(e))],
trHeight: {
val: { v: 30 },
hRule: Ya.AUTO
}
};
}
function ks(n) {
return {
size: {
type: Si.SPECIFIED,
width: {
v: n
}
}
};
}
function ua(n, e, t) {
const o = ks(t / e), s = Hs(e), r = [...new Array(n).fill(null).map(() => X.deepClone(s))], i = [...new Array(e).fill(null).map(() => X.deepClone(o))], a = pt(6);
return {
tableRows: r,
tableColumns: i,
tableId: a,
align: qa.START,
indent: {
v: 0
},
textWrap: Ka.NONE,
position: {
positionH: {
relativeFrom: $n.PAGE,
posOffset: 0
},
positionV: {
relativeFrom: ot.PAGE,
posOffset: 0
}
},
dist: {
distB: 0,
distL: 0,
distR: 0,
distT: 0
},
cellMargin: {
start: {
v: 10
},
end: {
v: 10
},
top: {
v: 5
},
bottom: {
v: 5
}
},
size: {
type: Si.UNSPECIFIED,
width: {
v: t
}
}
};
}
function En(n, e) {
if (!n && !e)
return null;
if (e && e.length > 0) {
let t = Number.POSITIVE_INFINITY, o = Number.NEGATIVE_INFINITY;
const s = "";
for (const r of e) {
const { startOffset: i, endOffset: a, segmentId: c } = r;
i == null || a == null || c == null || (t = Math.min(t, i), o = Math.max(o, a));
}
if (Number.isFinite(t) && Number.isFinite(o))
return {
startOffset: t,
endOffset: o,
segmentId: s
};
} else if (n) {
const { startOffset: t, endOffset: o, segmentId: s } = n;
return t == null || o == null || s == null ? null : {
startOffset: t,
endOffset: o,
segmentId: s
};
}
}
function sd(n) {
let e = U.TABLE_ROW_START;
const t = [], o = [];
for (let s = 0; s < n; s++)
e += `${U.TABLE_CELL_START}\r
${U.TABLE_CELL_END}`, t.push({
startIndex: e.length - 3,
paragraphStyle: {
spaceAbove: { v: 3 },
lineSpacing: 2,
spaceBelow: { v: 0 }
}
}), o.push({
startIndex: e.length - 2
});
return e += U.TABLE_ROW_END, {
dataStream: e,
paragraphs: t,
sectionBreaks: o
};
}
function rd() {
const n = `${U.TABLE_CELL_START}\r
${U.TABLE_CELL_END}`, e = [], t = [];
return e.push({
startIndex: 1,
paragraphStyle: {
spaceAbove: { v: 3 },
lineSpacing: 2,
spaceBelow: { v: 0 }
}
}), t.push({
startIndex: 2
}), {
dataStream: n,
paragraphs: e,
sectionBreaks: t
};
}
function id(n, e, t) {
var d, h, u;
const { startOffset: o, endOffset: s, segmentId: r } = n, i = t.getSelfOrHeaderFooterViewModel(r), a = e === 0 ? o : s;
let c = null;
const A = (u = (h = (d = t.getBody()) == null ? void 0 : d.tables) == null ? void 0 : h.find((g) => a >= g.startIndex && a <= g.endIndex)) == null ? void 0 : u.tableId;
let l = 0;
for (const g of i.getChildren()) {
for (const f of g.children) {
const { children: p } = f, m = p[0];
if (m) {
for (const E of m.children)
if (E.startIndex <= a && a <= E.endIndex) {
l = m.children.indexOf(E), c = E;
break;
}
}
if (c)
break;
}
if (c)
break;
}
return c == null || A == null ? null : {
offset: e === 0 ? c.startIndex : c.endIndex + 1,
colCount: c.children.length,
tableId: A,
insertRowIndex: e === 0 ? l : l + 1
};
}
function ad(n, e, t) {
var u, g, f;
const { startOffset: o, endOffset: s, segmentId: r } = n, i = t.getSelfOrHeaderFooterViewModel(r), a = e === 0 ? o : s, c = (f = (g = (u = t.getBody()) == null ? void 0 : u.tables) == null ? void 0 : g.find((p) => a >= p.startIndex && a <= p.endIndex)) == null ? void 0 : f.tableId, A = [];
let l = null, d = -1;
for (const p of i.getChildren()) {
for (const m of p.children) {
const { children: E } = m, I = E[0];
if (I) {
if (a < I.startIndex || a > I.endIndex)
continue;
l = I;
for (const v of I.children) {
for (const R of v.children) {
const S = v.children.indexOf(R);
if (a >= R.startIndex && a <= R.endIndex) {
d = S;
break;
}
}
if (d !== -1)
break;
}
}
if (l)
break;
}
if (l)
break;
}
if (l == null || c == null || d === -1)
return null;
let h = 0;
for (const p of l.children) {
const m = p.children[d], E = e === 0 ? m.startIndex : m.endIndex + 1;
A.push(E - h), h = E;
}
return {
offsets: A,
tableId: c,
columnIndex: d,
rowCount: l.children.length
};
}
function cd(n, e, t) {
const o = [];
let s = e[t].size.width.v, r = 0;
for (let i = 0; i < e.length; i++)
r += e[i].size.width.v;
r += s;
for (let i = 0; i < e.length; i++)
o.push(e[i].size.width.v / r * n);
return s = s / r * n, {
widths: o,
newColWidth: s
};
}
function ha(n, e) {
var h, u, g;
const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (g = (u = (h = e.getBody()) == null ? void 0 : h.tables) == null ? void 0 : u.find((f) => t >= f.startIndex && o <= f.endIndex)) == null ? void 0 : g.tableId, a = [];
let c = -1, A = 0, l = -1, d = !1;
for (const f of r.getChildren()) {
for (const p of f.children) {
const { children: m } = p, E = m[0];
if (E) {
if (t < E.startIndex || o > E.endIndex)
continue;
l = E.startIndex + 3;
for (const I of E.children) {
const v = E.children.indexOf(I), { startIndex: R, endIndex: S } = I;
t >= R && t <= S ? (c = R, a.push(v), A += S - R + 1) : (R > t && S < o || o >= R && o <= S) && (a.push(v), A += S - R + 1), a.length === E.children.length && (d = !0);
}
}
if (a.length)
break;
}
if (a.length)
break;
}
return i == null || a.length === 0 ? null : {
tableId: i,
rowIndexes: a,
offset: c,
len: A,
cursor: l,
selectWholeTable: d
};
}
function Ad(n, e) {
var g, f, p;
const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (p = (f = (g = e.getBody()) == null ? void 0 : g.tables) == null ? void 0 : f.find((m) => t >= m.startIndex && o <= m.endIndex)) == null ? void 0 : p.tableId, a = [];
let c = null;
const A = [];
let l = -1, d = -1, h = -1;
for (const m of r.getChildren()) {
for (const E of m.children) {
const { children: I } = E, v = I[0];
if (v) {
if (t < v.startIndex || o > v.endIndex)
continue;
c = v;
for (const R of v.children)
for (const S of R.children) {
const C = R.children.indexOf(S);
t >= S.startIndex && t <= S.endIndex && (d = C), o >= S.startIndex && o <= S.endIndex && (h = C);
}
}
if (c)
break;
}
if (c)
break;
}
if (c == null || i == null)
return null;
for (let m = d; m <= h; m++)
A.push(m);
let u = 0;
for (const m of c.children) {
const E = m.children[d], I = m.children[h];
a.push({
retain: E.startIndex - u,
delete: I.endIndex - E.startIndex + 1
}), u = I.endIndex + 1;
}
return l = c.startIndex + 3, {
offsets: a,
tableId: i,
columnIndexes: A,
cursor: l,
selectWholeTable: A.length === c.children[0].children.length,
rowCount: c.children.length
};
}
function ga(n, e) {
var l, d, h;
const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (h = (d = (l = e.getBody()) == null ? void 0 : l.tables) == null ? void 0 : d.find((u) => t >= u.startIndex && o <= u.endIndex)) == null ? void 0 : h.tableId;
let a = -1, c = 0, A = -1;
for (const u of r.getChildren()) {
for (const g of u.children) {
const { children: f } = g, p = f[0];
if (p) {
if (t < p.startIndex || o > p.endIndex)
continue;
a = p.startIndex, c = p.endIndex - p.startIndex + 1, A = p.startIndex;
}
if (p)
break;
}
if (c > 0)
break;
}
return i == null ? null : {
tableId: i,
offset: a,
len: c,
cursor: A
};
}
function ld(n, e) {
var g, f, p;
const { startOffset: t, endOffset: o, segmentId: s } = n, r = e.getSelfOrHeaderFooterViewModel(s), i = (p = (f = (g = e.getBody()) == null ? void 0 : g.tables) == null ? void 0 : f.find((m) => t >= m.startIndex && o <= m.endIndex)) == null ? void 0 : p.tableId, a = [];
let c = null, A = -1, l = -1, d = -1, h = -1;
for (const m of r.getChildren()) {
for (const E of m.children) {
const { children: I } = E, v = I[0];
if (v) {
if (t < v.startIndex || o > v.endIndex)
continue;
c = v;
for (const R of v.children) {
const S = v.children.indexOf(R);
for (const C of R.children) {
const T = R.children.indexOf(C);
t >= C.startIndex && t <= C.endIndex && (l = S, d = T), o >= C.startIndex && o <= C.endIndex && (h = T);
}
}
}
if (c)
break;
}
if (c)
break;
}
if (c == null || i == null || l === -1)
return null;
const u = c.children[l];
for (let m = d; m <= h; m++) {
const E = u.children[m];
a.push({
retain: E.startIndex + 1,
delete: E.endIndex - E.startIndex - 3
});
}
return A = c.startIndex + 3, {
offsets: a,
tableId: i,
cursor: A,
rowCount: c.children.length
};
}
var ts = /* @__PURE__ */ ((n) => (n[n.NEXT = 0] = "NEXT", n[n.PREV = 1] = "PREV", n))(ts || {});
function Kr(n, e, t) {
const { startOffset: o } = e;
let s = null;
for (const A of n.getChildren()) {
for (const l of A.children) {
const d = l.children[0];
if (d && o > d.startIndex && o < d.endIndex) {
s = d;
break;
}
}
if (s)
break;
}
if (s == null)
return null;
let r = -1, i = -1, a = null;
for (const A of s.children) {
for (const l of A.children)
if (o > l.startIndex && o < l.endIndex) {
r = A.children.indexOf(l), i = s.children.indexOf(A), a = A;
break;
}
if (r > -1)
break;
}
if (r === -1 || i === -1 || a == null)
return null;
let c = null;
if (t === 0) {
if (c = a.children[r + 1], !c) {
const A = s.children[i + 1];
A && (c = A.children[0]);
}
} else if (c = a.children[r - 1], !c) {
const A = s.children[i - 1];
A && (c = A.children[A.children.length - 1]);
}
if (c) {
const { startIndex: A, endIndex: l } = c;
return {
startOffset: A + 1,
endOffset: l - 2
};
}
}
function dd(n, e) {
const t = [], { customBlocks: o = [] } = n;
for (const s of e) {
const { startOffset: r, endOffset: i } = s;
if (!(r == null || i == null))
for (const a of o) {
const { startIndex: c } = a;
c >= r && c < i && t.push(a.blockId);
}
}
return t;
}
function ud(n) {
return n.some((e) => {
const { startNodePosition: t } = e;
return t ? (t == null ? void 0 : t.path.indexOf("cells")) > -1 : !1;
});
}
const hd = Is, fa = {
id: "doc.command.inner-paste",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function, complexity
handler: async (n, e) => {
var O, P, b, B, M, H;
const { segmentId: t, textRanges: o, doc: s } = e, r = n.get(y), i = n.get(G), a = n.get(Q), c = i.getTextRanges(), A = i.getRectRanges(), { body: l, tableSource: d, drawings: h } = s;
if (!Array.isArray(c) || c.length === 0 || l == null)
return !1;
const u = a.getCurrentUniverDocInstance(), g = u == null ? void 0 : u.getSelfOrHeaderFooterModel(t).getBody();
if (u == null || g == null)
return !1;
const f = u.getUnitId(), p = {
id: J.id,
params: {
unitId: f,
actions: [],
textRanges: o,
segmentId: t
}
}, m = new St();
m.reset();
const E = new me(), I = k.getInstance(), v = [], R = !!((O = l.tables) != null && O.length), S = !!((P = l.customBlocks) != null && P.length);
if (R && t || R && ud(c) || c.length && (A != null && A.length))
return !1;
for (let F = 0; F < c.length; F++) {
const D = c[F], { startOffset: te, endOffset: q, collapsed: V } = D, Y = te - m.cursor, oe = X.deepClone(l);
if (R)
for (const Ae of oe.tables) {
const { tableId: ne } = Ae, ae = X.generateRandomId(6);
Ae.tableId = ae;
const Te = X.deepClone(d[ne]);
Te.tableId = ae;
const je = I.insertOp(["tableSource", ae], Te);
v.push(je);
}
if (S && h) {
const Ae = (B = (b = u.getSnapshot().drawingsOrder) == null ? void 0 : b.length) != null ? B : 0;
for (const ne of oe.customBlocks) {
const { blockId: ae } = ne, Te = X.generateRandomId(6);
ne.blockId = Te;
const je = X.deepClone(h[ae]);
je.drawingId = Te;
const ut = I.insertOp(["drawings", Te], je), we = I.insertOp(["drawingsOrder", Ae], Te);
v.push(ut), v.push(we);
}
}
const ce = Os((M = g.customRanges) != null ? M : [], q, hd.includes(f)), he = Ts((H = g.customDecorations) != null ? H : [], q);
if (ce && (oe.customRanges = [{
...ce,
startIndex: 0,
endIndex: l.dataStream.length - 1
}]), he.length && (oe.customDecorations = he.map((Ae) => ({
...Ae,
startIndex: 0,
endIndex: l.dataStream.length - 1
}))), V)
E.push({
t: W.RETAIN,
len: Y
}), E.push({
t: W.INSERT,
body: oe,
len: l.dataStream.length
});
else {
const Ae = Ce.selection.delete([D], l, m.cursor, oe, c.length === 1);
E.push(...Ae);
}
m.reset(), m.moveCursor(q);
}
const C = le(u, t);
return v.push(I.editOp(E.serialize(), C)), p.params.actions = v.reduce((F, D) => k.compose(F, D), null), !!r.syncExecuteCommand(p.id, p.params);
}
};
function gd(n, e) {
const { startOffset: t, endOffset: o } = n, s = e.some((i) => i.startIndex === o), r = Math.max(t, s ? o - 1 : o);
return {
...n,
endOffset: r,
collapsed: t === r
};
}
function fd(n, e, t) {
var g, f;
const o = e.getSelfOrHeaderFooterModel(t).getBody(), s = new me(), r = k.getInstance(), i = [];
if (o == null)
return i;
const { tables: a = [] } = o, c = new St();
c.reset();
for (let p = 0; p < n.length; p++) {
const m = gd(n[p], a), { startOffset: E, endOffset: I, collapsed: v } = m, R = E - c.cursor;
v ? s.push({
t: W.RETAIN,
len: R
}) : s.push(...Ce.selection.delete([m], o, c.cursor, null, !1)), c.reset(), c.moveCursor(I);
}
const A = le(e, t);
i.push(r.editOp(s.serialize(), A));
const l = dd(o, n), d = (g = e.getDrawings()) != null ? g : {}, h = (f = e.getDrawingsOrder()) != null ? f : [], u = l.sort((p, m) => h.indexOf(p) > h.indexOf(m) ? -1 : h.indexOf(p) < h.indexOf(m) ? 1 : 0);
if (u.length > 0)
for (const p of u) {
const m = d[p], E = h.indexOf(p);
if (m == null || E < 0)
continue;
const I = r.removeOp(["drawings", p], m), v = r.removeOp(["drawingsOrder", E], p);
i.push(I), i.push(v);
}
return i.reduce((p, m) => k.compose(p, m), null);
}
function pd(n, e, t, o) {
const s = [];
if (e.getSelfOrHeaderFooterModel(o).getBody() == null)
return s;
const i = new me(), a = k.getInstance(), c = new St();
c.reset();
for (const l of n) {
const { startOffset: d, endOffset: h, spanEntireRow: u, spanEntireTable: g } = l;
if (!(d == null || h == null))
if (g) {
const f = ga({ startOffset: d, endOffset: h, segmentId: o }, t);
if (f == null)
continue;
const { offset: p, len: m, tableId: E } = f;
p - c.cursor > 0 && i.push({
t: W.RETAIN,
len: p - c.cursor
}), i.push({
t: W.DELETE,
len: m
});
const I = a.removeOp(["tableSource", E]);
s.push(I), c.moveCursorTo(p + m);
} else if (u) {
const f = ha({ startOffset: d, endOffset: h, segmentId: o }, t);
if (f == null)
continue;
const { offset: p, rowIndexes: m, len: E, tableId: I } = f;
p - c.cursor > 0 && i.push({
t: W.RETAIN,
len: p - c.cursor
}), i.push({
t: W.DELETE,
len: E
});
for (const v of m.reverse()) {
const R = a.removeOp(["tableSource", I, "tableRows", v]);
s.push(R);
}
c.moveCursorTo(p + E);
} else {
const f = ld({ startOffset: d, endOffset: h, segmentId: o }, t);
if (f == null)
continue;
const { offsets: p } = f;
for (const m of p) {
const { retain: E, delete: I } = m;
E - c.cursor > 0 && i.push({
t: W.RETAIN,
len: E - c.cursor
}), i.push({
t: W.DELETE,
len: I
}), c.moveCursorTo(E + I);
}
}
}
const A = le(e, o);
return s.push(a.editOp(i.serialize(), A)), s.reduce((l, d) => k.compose(l, d), null);
}
function md(n, e, t, o, s) {
let r = [];
if (Array.isArray(n) && (n == null ? void 0 : n.length) !== 0 && (r = fd(n, t, s)), Array.isArray(e) && (e == null ? void 0 : e.length) !== 0) {
const i = pd(e, t, o, s);
r == null || r.length === 0 ? r = i : r = k.compose(
r,
k.transform(i, r, "right")
);
}
return r;
}
const Qt = {
id: "doc.command.inner-cut",
type: N.COMMAND,
handler: async (n, e) => {
var f, p;
const { segmentId: t, textRanges: o } = e, s = n.get(y), r = n.get(G), i = n.get(Q), a = (f = e.selections) != null ? f : r.getTextRanges(), c = r.getRectRanges();
if ((!Array.isArray(a) || a.length === 0) && (!Array.isArray(c) || c.length === 0))
return !1;
const A = (p = i.getCurrentUniverDocInstance()) == null ? void 0 : p.getUnitId();
if (!A)
return !1;
const l = i.getUniverDocInstance(A);
if (l == null)
return !1;
const d = ke(n, A);
if (d == null)
return !1;
const h = d.getViewModel(), u = {
id: J.id,
params: {
unitId: A,
actions: [],
textRanges: o
}
};
return u.params.actions = md(a, c, l, h, t), !!s.syncExecuteCommand(u.id, u.params);
}
};
var Be = /* @__PURE__ */ ((n) => (n[n.LEFT = 0] = "LEFT", n[n.RIGHT = 1] = "RIGHT", n))(Be || {});
const Ed = "doc.command.insert-text", Vs = {
id: Ed,
type: N.COMMAND,
handler: async (n, e) => {
var S;
const t = n.get(y), { range: o, segmentId: s, body: r, unitId: i, cursorOffset: a } = e, c = n.get(G), l = n.get(Q).getUnit(i, _.UNIVER_DOC);
if (l == null)
return !1;
const d = c.getActiveTextRange(), h = l.getSelfOrHeaderFooterModel((S = d == null ? void 0 : d.segmentId) != null ? S : "").getBody();
if (h == null)
return !1;
const { startOffset: u, collapsed: g } = o, f = a != null ? a : r.dataStream.length, p = [
{
startOffset: u + f,
endOffset: u + f,
style: d == null ? void 0 : d.style,
collapsed: g
}
], m = {
id: J.id,
params: {
unitId: i,
actions: [],
textRanges: p,
debounce: !0
}
}, E = new me(), I = k.getInstance();
if (g)
u > 0 && E.push({
t: W.RETAIN,
len: u
}), E.push({
t: W.INSERT,
body: r,
len: r.dataStream.length
});
else {
const C = Ce.selection.delete([o], h, 0, r);
E.push(...C);
}
m.params.textRanges = [{
startOffset: u + f,
endOffset: u + f,
collapsed: g
}];
const v = le(l, s);
return m.params.actions = I.editOp(E.serialize(), v), !!t.syncExecuteCommand(m.id, m.params);
}
}, dn = {
id: "doc.command.delete-text",
type: N.COMMAND,
handler: async (n, e) => {
var R;
const t = n.get(y), o = n.get(Q), { range: s, segmentId: r, unitId: i, direction: a, len: c = 1 } = e, A = o.getUnit(i, _.UNIVER_DOC), l = A == null ? void 0 : A.getSelfOrHeaderFooterModel(r).getBody();
if (A == null || l == null)
return !1;
const { startOffset: d } = s;
let h = a === Be.LEFT ? d - c : d, u = a === Be.LEFT ? d - 1 : d + c - 1;
const g = (R = l.customRanges) == null ? void 0 : R.find((S) => S.startIndex <= h && S.endIndex >= u);
g != null && g.wholeEntity && (h = g.startIndex, u = Math.max(u, g.endIndex));
const f = {
id: J.id,
params: {
unitId: i,
actions: [],
textRanges: [{
startOffset: h,
endOffset: h,
collapsed: !0
}],
debounce: !0
}
}, p = new me(), m = k.getInstance();
p.push({
t: W.RETAIN,
len: h - 0
}), p.push({
t: W.DELETE,
len: u - h + 1
});
const I = le(A, r);
return f.params.actions = m.editOp(p.serialize(), I), !!t.syncExecuteCommand(f.id, f.params);
}
}, pa = {
id: "doc.command.update-text",
type: N.COMMAND,
handler: async (n, e) => {
const { range: t, segmentId: o, updateBody: s, coverType: r, unitId: i, textRanges: a } = e, c = n.get(y), l = n.get(Q).getCurrentUniverDocInstance();
if (l == null)
return !1;
const d = {
id: J.id,
params: {
unitId: i,
actions: [],
textRanges: a
}
}, h = new me(), u = k.getInstance(), { startOffset: g, endOffset: f } = t;
h.push({
t: W.RETAIN,
len: g
}), h.push({
t: W.RETAIN,
body: s,
len: f - g,
coverType: r
});
const p = le(l, o);
return d.params.actions = u.editOp(h.serialize(), p), !!c.syncExecuteCommand(d.id, d.params);
}
}, js = {
id: "doc.command.delete-custom-block",
type: N.COMMAND,
handler: async (n, e) => {
var b;
const t = n.get(G), o = n.get(Q), s = n.get(y), r = t.getActiveTextRange(), i = o.getCurrentUniverDocInstance();
if (r == null || i == null)
return !1;
const { direction: a, range: c, unitId: A, drawingId: l } = e, { startOffset: d, segmentId: h, style: u } = r, g = a === Be.LEFT ? d - 1 : d, f = [
{
startOffset: g,
endOffset: g,
style: u
}
], p = {
id: J.id,
params: {
unitId: A,
actions: [],
textRanges: f,
prevTextRanges: [c]
}
}, m = new me(), E = k.getInstance(), I = [];
d > 0 && m.push({
t: W.RETAIN,
len: a === Be.LEFT ? d - 1 : d
}), m.push({
t: W.DELETE,
len: 1
});
const v = le(i, h);
I.push(E.editOp(m.serialize(), v));
const R = ((b = i.getDrawings()) != null ? b : {})[l], C = i.getDrawingsOrder().indexOf(l), T = E.removeOp(["drawings", l], R), O = E.removeOp(["drawingsOrder", C], l);
return I.push(T), I.push(O), p.params.actions = I.reduce((B, M) => k.compose(B, M), null), !!s.syncExecuteCommand(p.id, p.params);
}
}, Ws = {
id: "doc.command.merge-two-paragraph",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function
handler: async (n, e) => {
const t = n.get(G), o = n.get(Q), s = n.get(y), { direction: r, range: i } = e, a = t.getActiveTextRange(), c = t.getTextRanges();
if (a == null || c == null)
return !1;
const { segmentId: A, style: l } = a, d = o.getCurrentUnitForType(_.UNIVER_DOC), h = d == null ? void 0 : d.getSelfOrHeaderFooterModel(A).getBody();
if (d == null || h == null)
return !1;
const u = a, g = d.getUnitId(), { startOffset: f, collapsed: p } = u;
if (!p)
return !1;
const m = r === Be.LEFT ? f : f + 1;
let E, I;
for (const b of h.paragraphs) {
if (b.startIndex >= m) {
I = b;
break;
}
E = b;
}
if (E == null || I == null)
return !1;
const v = r === Be.LEFT ? f - 1 : f, R = [
{
startOffset: v,
endOffset: v,
style: l
}
], S = {
id: J.id,
params: {
unitId: g,
actions: [],
textRanges: R,
prevTextRanges: [i]
}
}, C = new me(), T = k.getInstance();
E.startIndex > 0 && C.push({
t: W.RETAIN,
len: E.startIndex
}), C.push({
t: W.DELETE,
len: 1
}), I.startIndex > E.startIndex + 1 && C.push({
t: W.RETAIN,
len: I.startIndex - E.startIndex - 1
}), C.push({
t: W.RETAIN,
len: 1,
coverType: no.REPLACE,
body: {
dataStream: "",
paragraphs: [
{
...X.deepClone(E),
startIndex: 0
}
]
}
});
const O = le(d, A);
return S.params.actions = T.editOp(C.serialize(), O), !!s.syncExecuteCommand(S.id, S.params);
}
};
function zs(n, e) {
let t = 0;
if (n == null || n.length === 0) {
if (typeof e[0].startOffset == "number") {
const o = e[0], { spanEntireRow: s, spanEntireTable: r } = o;
r ? t = o.startOffset - 3 : s ? o.startRow > 0 ? t = o.startOffset - 6 : t = o.startOffset : t = e[0].startOffset;
}
} else if (n.length > 0 && e.length > 0) {
const o = n[0], s = e[0];
if (o.startOffset != null && s.startOffset != null) {
if (o.startOffset < s.startOffset)
t = o.startOffset;
else if (o.startOffset >= s.startOffset) {
const { spanEntireRow: r, spanEntireTable: i } = s;
i ? t = s.startOffset - 3 : r && (t = s.startOffset - 6);
}
}
}
return t;
}
const So = {
id: "doc.command.delete-left",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function, complexity
handler: async (n) => {
var O, P;
const e = n.get(G), t = n.get(Q), o = n.get(y);
let s = !0;
const r = t.getCurrentUniverDocInstance();
if (r == null)
return !1;
const i = r.getUnitId(), a = ke(n, i), c = e.getActiveTextRange(), A = e.getRectRanges(), l = e.getTextRanges(), d = a == null ? void 0 : a.getSkeleton();
if (d == null)
return !1;
if (A != null && A.length) {
const b = zs(l, A), B = A[0].segmentId, M = [
{
startOffset: b,
endOffset: b
}
];
return o.executeCommand(Qt.id, {
segmentId: B,
textRanges: M
});
}
if (c == null || l == null)
return !1;
const { segmentId: h, style: u, segmentPage: g } = c, f = r.getSelfOrHeaderFooterModel(h).getBody();
if (f == null)
return !1;
const p = c, { startOffset: m, collapsed: E } = p, I = d.findNodeByCharIndex(m, h, g), v = hc(I), R = gc(I, f);
let S = m;
const C = d.findNodeByCharIndex(m - 1, h, g);
if (fc(I) && C !== I && (v === !0 || R === !0) && E) {
const b = pc(I, f);
if (b == null)
return !1;
const B = b == null ? void 0 : b.startIndex, M = { startIndex: 0 }, H = b.paragraphStyle;
if (v === !0) {
const D = b.paragraphStyle;
if (D) {
M.paragraphStyle = D;
const { hanging: te } = D;
te && (M.paragraphStyle.indentStart = te, M.paragraphStyle.hanging = void 0);
}
} else if (R === !0) {
const D = b.bullet;
D && (M.bullet = D), H != null && (M.paragraphStyle = { ...H }, delete M.paragraphStyle.hanging, delete M.paragraphStyle.indentStart);
}
const F = [
{
startOffset: S,
endOffset: S,
style: u
}
];
s = await o.executeCommand(pa.id, {
unitId: r.getUnitId(),
updateBody: {
dataStream: "",
paragraphs: [{ ...M }]
},
range: {
startOffset: B,
endOffset: B + 1
},
textRanges: F,
coverType: no.REPLACE,
segmentId: h
});
} else if (E === !0) {
if (C == null)
return !0;
if (C.content === "\r")
s = await o.executeCommand(Ws.id, {
direction: Be.LEFT,
range: p
});
else if (C.streamType === "\b") {
const b = (P = r.getSnapshot().drawings) == null ? void 0 : P[(O = C.drawingId) != null ? O : ""];
if (b == null)
return !0;
if (b.layoutType === oo.INLINE) {
const M = r.getUnitId();
s = await o.executeCommand(js.id, {
direction: Be.LEFT,
range: c,
unitId: M,
drawingId: C.drawingId
});
} else {
const M = d.findNodeByCharIndex(m - 2);
if (M == null)
return !0;
S -= C.count, S -= M.count;
const H = [
{
startOffset: S,
endOffset: S,
style: u
}
];
s = await o.executeCommand(dn.id, {
unitId: r.getUnitId(),
range: {
...c,
startOffset: c.startOffset - 1,
endOffset: c.endOffset - 1
},
segmentId: h,
direction: Be.LEFT,
len: M.count,
textRanges: H
});
}
} else
S -= C.count, s = await o.executeCommand(dn.id, {
unitId: r.getUnitId(),
range: p,
segmentId: h,
direction: Be.LEFT,
len: C.count
});
} else {
const b = Ea(p, [p]);
s = await o.executeCommand(Qt.id, {
segmentId: h,
textRanges: b,
selections: [p]
});
}
return s;
}
}, ma = {
id: "doc.command.delete-right",
type: N.COMMAND,
// eslint-disable-next-line max-lines-per-function, complexity
handler: async (n) => {
var I, v;
const e = n.get(G), o = n.get(Q).getCurrentUniverDocInstance();
if (!o)
return !1;
const s = ke(n, o.getUnitId()), r = n.get(y), i = e.getActiveTextRange(), a = e.getRectRanges(), c = e.getTextRanges(), A = s == null ? void 0 : s.getSkeleton();
if (a != null && a.length) {
const R = zs(c, a), S = a[0].segmentId, C = [
{
startOffset: R,
endOffset: R
}
];
return r.executeCommand(Qt.id, {
segmentId: S,
textRanges: C
});
}
if (i == null || A == null || c == null)
return !1;
const { segmentId: l, style: d, segmentPage: h } = i, u = o == null ? void 0 : o.getSelfOrHeaderFooterModel(l).getBody();
if (!o || !u)
return !1;
const g = i, { startOffset: f, endOffset: p, collapsed: m } = g;
if (f === u.dataStream.length - 2 && m)
return !0;
let E = !1;
if (m === !0) {
const R = A.findNodeByCharIndex(f, l, h), S = A.findNodeByCharIndex(f + 1);
if (R.streamType === U.PARAGRAPH && (S == null ? void 0 : S.streamType) === U.SECTION_BREAK)
return !1;
if (R.content === "\r")
E = await r.executeCommand(Ws.id, {
direction: Be.RIGHT,
range: i
});
else if (R.streamType === "\b") {
const C = (v = o.getSnapshot().drawings) == null ? void 0 : v[(I = R.drawingId) != null ? I : ""];
if (C == null)
return !0;
if (C.layoutType === oo.INLINE) {
const O = o.getUnitId();
E = await r.executeCommand(js.id, {
direction: Be.RIGHT,
range: i,
unitId: O,
drawingId: R.drawingId
});
} else {
if (S == null)
return !0;
const O = [
{
startOffset: f + 1,
endOffset: f + 1,
style: d
}
];
E = await r.executeCommand(dn.id, {
unitId: o.getUnitId(),
range: {
...i,
startOffset: f + 1,
endOffset: p + 1
},
segmentId: l,
direction: Be.RIGHT,
textRanges: O,
len: S.count
});
}
} else {
const C = [
{
startOffset: f,
endOffset: f,
style: d
}
];
E = await r.executeCommand(dn.id, {
unitId: o.getUnitId(),
range: g,
segmentId: l,
direction: Be.RIGHT,
textRanges: C,
len: R.count
});
}
} else {
const R = Ea(g, [g]);
E = await r.executeCommand(Qt.id, {
segmentId: l,
textRanges: R,
selections: [g]
});
}
return E;
}
};
function Ea(n, e) {
let t = n.endOffset;
for (const s of e) {
const { startOffset: r, endOffset: i } = s;
r == null || i == null || i <= n.endOffset && (t -= i - r);
}
return [
{
startOffset: t,
endOffset: t,
style: n.style
}
];
}
const Sd = 10, Id = 6;
function Cd() {
return X.generateRandomId(Id);
}
function vd(n) {
const e = n.match(/data-copy-id="([^\s]+)"/);
return e && e[1] ? e[1] : null;
}
class Rd {
constructor() {
x(this, "_cache", new Xa(Sd));
}
set(e, t) {
this._cache.set(e, t);
}
get(e) {
return this._cache.get(e);
}
clear() {
this._cache.clear();
}
}
const No = new Rd();
function Gs(n) {
const e = n.style, t = {}, o = n.tagName.toLowerCase();
switch (o) {
case "b":
case "em":
case "strong": {
t.bl = L.TRUE;
break;
}
case "s": {
t.st = {
s: L.TRUE
};
break;
}
case "u": {
t.ul = {
s: L.TRUE
};
break;
}
case "i": {
t.it = L.TRUE;
break;
}
case "sub":
case "sup": {
t.va = o === "sup" ? Ne.SUPERSCRIPT : Ne.SUBSCRIPT;
break;
}
}
for (let s = 0; s < e.length; s++) {
const r = e[s], i = e.getPropertyValue(r);
switch (r) {
case "font-family": {
t.ff = i.replace(/^"/g, "").replace(/"$/g, "");
break;
}
case "font-size": {
const a = Number.parseInt(i);
Number.isNaN(a) || (i.endsWith("pt") ? t.fs = a : i.endsWith("px") && (t.fs = mc(a)));
break;
}
case "font-style": {
i === "italic" && (t.it = L.TRUE);
break;
}
case "font-weight": {
(Number(i) > 400 || String(i) === "bold") && (t.bl = L.TRUE);
break;
}
case "text-decoration": {
/underline/.test(i) ? t.ul = {
s: L.TRUE
} : /overline/.test(i) ? t.ol = {
s: L.TRUE
} : /line-through/.test(i) && (t.st = {
s: L.TRUE
});
break;
}
case "color": {
try {
const a = new dr(i);
a.isValid && (t.cl = {
rgb: a.toRgbString()
});
} catch {
}
break;
}
case "background-color": {
const a = new dr(i);
a.isValid && (t.bg = {
rgb: a.toRgbString()
});
break;
}
}
}
return t;
}
function bd(n) {
const e = new DOMParser(), t = ``;
}
function Zr(n, e) {
const { st: t, ed: o, ts: s = {} } = e, { ff: r, fs: i, it: a, bl: c, ul: A, st: l, ol: d, bg: h, cl: u, va: g } = s;
let f = n.slice(t, o);
const p = [];
return a === L.TRUE && (f = `${f}`), g === Ne.SUPERSCRIPT ? f = `${f}` : g === Ne.SUBSCRIPT && (f = `${f}`), (A == null ? void 0 : A.s) === L.TRUE && (f = `${f}`), (l == null ? void 0 : l.s) === L.TRUE && (f = `
${f}`), c === L.TRUE && (f = `${f}`), r && p.push(`font-family: ${r}`), u && p.push(`color: ${u.rgb}`), i && p.push(`font-size: ${i}pt`), d && p.push("text-decoration: overline"), h && p.push(`background: ${h.rgb}`), p.length ? `${f}` : f;
}
function Qo(n, e, t) {
const { dataStream: o, textRuns: s = [] } = n;
if (e === t)
return "";
let r = e;
const i = [];
for (const a of s) {
const { st: c, ed: A } = a;
X.hasIntersectionBetweenTwoRanges(e, t, c, A) && (c > r ? (i.push(o.slice(r, c)), i.push(Zr(o, {
...a,
ed: Math.min(A, t)
}))) : i.push(Zr(o, {
...a,
st: r,
ed: Math.min(A, t)
}))), r = Math.max(e, Math.min(A, t));
}
return r !== t && i.push(o.slice(r, t)), i.join("");
}
function Bd(n, e, t) {
const o = n.body, s = n.drawings || {}, { customRanges: r = [], customBlocks: i = [] } = o || {}, a = [...i], c = r.filter((u) => u.startIndex >= e && u.endIndex <= t);
let A = e, l = "";
const d = (u, g) => {
let f = "", p = 0, m = u, E = a.findIndex((I) => u <= I.startIndex && g >= I.startIndex);
if (E === -1)
return f = Qo(o, u, g), { sliceHtml: f, customBlockLength: p };
for (; E !== -1; ) {
const I = a[E];
a.splice(E, 1), f += Qo(o, m, I.startIndex);
const v = s[I.blockId];
if (v)
switch (v.drawingType) {
case Cs.DRAWING_IMAGE: {
f += yd(v), p++;
break;
}
}
m = I.startIndex + 1, E = a.findIndex((R) => m <= R.startIndex && g >= R.startIndex);
}
return f = f + Qo(o, m, g + 1), { sliceHtml: f, customBlockLength: p };
};
c.forEach((u) => {
var v, R;
const { startIndex: g, endIndex: f, rangeType: p, rangeId: m } = u, E = d(A, g);
l += E.sliceHtml;
const I = d(g, f + 1);
switch (p) {
case Ii.HYPERLINK: {
l += `${I.sliceHtml}`;
break;
}
default: {
l += I.sliceHtml;
break;
}
}
A = f + 1 + (E.customBlockLength + I.customBlockLength);
});
const h = d(A, t);
return l += h.sliceHtml, l;
}
function Md(n) {
const e = n.body || {}, { paragraphs: t = [], sectionBreaks: o = [] } = e;
let { dataStream: s = "" } = e;
s.endsWith(`\r
`) || (s += `\r
`, t.push({
startIndex: s.length - 2
}), o.push({
startIndex: s.length - 1
}), e.dataStream = s, e.paragraphs = t, e.sectionBreaks = o);
const r = { html: "" }, i = Ec(s).sectionList;
for (const a of i)
yt(a, n, r);
return r.html;
}
function yt(n, e, t) {
var o, s;
switch (n.nodeType) {
case qt.SECTION_BREAK: {
for (const r of n.children)
yt(r, e, t);
break;
}
case qt.PARAGRAPH: {
const { children: r, startIndex: i, endIndex: a } = n, c = (s = (o = e.body) == null ? void 0 : o.paragraphs.find((g) => g.startIndex === a)) != null ? s : {}, { paragraphStyle: A = {} } = c, { spaceAbove: l, spaceBelow: d, lineSpacing: h } = A, u = [];
if (l != null && (typeof l == "number" ? u.push(`margin-top: ${l}px`) : u.push(`margin-top: ${l.v}px`)), d != null && (typeof d == "number" ? u.push(`margin-bottom: ${d}px`) : u.push(`margin-bottom: ${d.v}px`)), h != null && u.push(`line-height: ${h}`), t.html += `
`, r.length) for (const g of r) yt(g, e, t); t.html += `${Bd(e, i, a)}
`; break; } case qt.TABLE: { const { children: r } = n; t.html += '