@univerjs/docs-hyper-link-ui 0.6.7 → 0.6.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/index.js +769 -0
- package/lib/locale/en-US.js +26 -0
- package/lib/locale/fa-IR.js +26 -0
- package/lib/locale/fr-FR.js +26 -0
- package/lib/locale/ru-RU.js +26 -0
- package/lib/locale/vi-VN.js +26 -0
- package/lib/locale/zh-CN.js +26 -0
- package/lib/locale/zh-TW.js +26 -0
- package/package.json +11 -11
package/lib/index.js
ADDED
|
@@ -0,0 +1,769 @@
|
|
|
1
|
+
var Ue = Object.defineProperty;
|
|
2
|
+
var Te = (n, e, t) => e in n ? Ue(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t;
|
|
3
|
+
var O = (n, e, t) => Te(n, typeof e != "symbol" ? e + "" : e, t);
|
|
4
|
+
import { CommandType as R, ICommandService as k, generateRandomId as $e, CustomRangeType as E, IUniverInstanceService as L, UniverInstanceType as _, getBodySlice as Se, LocaleService as ye, Tools as He, BuildTextUtils as ve, Inject as I, Disposable as D, DOCS_ZEN_EDITOR_UNIT_ID_KEY as je, DOCS_NORMAL_EDITOR_UNIT_ID_KEY as Ke, DependentOn as Ae, Injector as Fe, IConfigService as Be, Plugin as Ve, merge as Ye } from "@univerjs/core";
|
|
5
|
+
import { UniverDocsHyperLinkPlugin as Ze } from "@univerjs/docs-hyper-link";
|
|
6
|
+
import { IRenderManagerService as ze } from "@univerjs/engine-render";
|
|
7
|
+
import { addCustomRangeBySelectionFactory as We, DocSelectionManagerService as w, replaceSelectionFactory as Ge, deleteCustomRangeFactory as qe, SetTextSelectionsOperation as Je, DocSkeletonManagerService as Qe, DocInterceptorService as Xe, DOC_INTERCEPTOR_POINT as en } from "@univerjs/docs";
|
|
8
|
+
import { DocCanvasPopManagerService as nn, DocEventManagerService as tn, DocRenderController as rn, whenDocAndEditorFocused as on } from "@univerjs/docs-ui";
|
|
9
|
+
import { BehaviorSubject as fe, distinctUntilChanged as sn, pairwise as cn, Observable as dn, debounceTime as an } from "rxjs";
|
|
10
|
+
import { jsxs as P, jsx as v } from "react/jsx-runtime";
|
|
11
|
+
import { FormLayout as he, Input as me, Button as Ie, Tooltip as K, MessageType as ln } from "@univerjs/design";
|
|
12
|
+
import { useDependency as S, useObservable as xe, KeyCode as X, IMessageService as un, MetaKeys as pn, getMenuHiddenObservable as gn, MenuItemType as vn, ContextMenuPosition as fn, ContextMenuGroup as hn, RibbonStartGroup as mn, ComponentManager as In, IMenuManagerService as _n, IShortcutService as Cn } from "@univerjs/ui";
|
|
13
|
+
import { useState as W, useEffect as Sn, forwardRef as N, useRef as yn, createElement as U } from "react";
|
|
14
|
+
const xn = "docs-hyper-link-ui.config", _e = {}, ke = {
|
|
15
|
+
type: R.COMMAND,
|
|
16
|
+
id: "docs.command.add-hyper-link",
|
|
17
|
+
async handler(n, e) {
|
|
18
|
+
if (!e)
|
|
19
|
+
return !1;
|
|
20
|
+
const { payload: t, unitId: i, selections: r } = e, o = n.get(k), s = $e(), c = We(
|
|
21
|
+
n,
|
|
22
|
+
{
|
|
23
|
+
rangeId: s,
|
|
24
|
+
rangeType: E.HYPERLINK,
|
|
25
|
+
properties: {
|
|
26
|
+
url: t
|
|
27
|
+
},
|
|
28
|
+
unitId: i,
|
|
29
|
+
selections: r
|
|
30
|
+
}
|
|
31
|
+
);
|
|
32
|
+
return c ? o.syncExecuteCommand(c.id, c.params) : !1;
|
|
33
|
+
}
|
|
34
|
+
}, Le = {
|
|
35
|
+
id: "docs.command.update-hyper-link",
|
|
36
|
+
type: R.COMMAND,
|
|
37
|
+
handler(n, e) {
|
|
38
|
+
var p;
|
|
39
|
+
if (!e)
|
|
40
|
+
return !1;
|
|
41
|
+
const { unitId: t, payload: i, segmentId: r, linkId: o } = e, s = n.get(k), c = n.get(L), u = n.get(w).getActiveTextRange(), f = c.getUnit(t, _.UNIVER_DOC);
|
|
42
|
+
if (!u || !f)
|
|
43
|
+
return !1;
|
|
44
|
+
const g = (p = Se(f.getSelfOrHeaderFooterModel(r).getBody(), u.startOffset, u.endOffset).textRuns) == null ? void 0 : p[0];
|
|
45
|
+
g && (g.ed = e.label.length + 1);
|
|
46
|
+
const d = Ge(n, {
|
|
47
|
+
unitId: t,
|
|
48
|
+
body: {
|
|
49
|
+
dataStream: `${e.label}`,
|
|
50
|
+
customRanges: [{
|
|
51
|
+
rangeId: o,
|
|
52
|
+
rangeType: E.HYPERLINK,
|
|
53
|
+
startIndex: 0,
|
|
54
|
+
endIndex: e.label.length + 1,
|
|
55
|
+
properties: {
|
|
56
|
+
url: i
|
|
57
|
+
}
|
|
58
|
+
}],
|
|
59
|
+
textRuns: g ? [g] : void 0
|
|
60
|
+
},
|
|
61
|
+
selection: {
|
|
62
|
+
startOffset: u.startOffset,
|
|
63
|
+
endOffset: u.endOffset,
|
|
64
|
+
collapsed: !1,
|
|
65
|
+
segmentId: r
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
return d ? s.syncExecuteCommand(d.id, d.params) : !1;
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
function kn(n) {
|
|
72
|
+
return /^[a-zA-Z]+:\/\//.test(n);
|
|
73
|
+
}
|
|
74
|
+
function Ln(n) {
|
|
75
|
+
return /^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$/.test(n);
|
|
76
|
+
}
|
|
77
|
+
function On(n) {
|
|
78
|
+
return kn(n) ? n : Ln(n) ? `mailto://${n}` : `https://${n}`;
|
|
79
|
+
}
|
|
80
|
+
const F = () => {
|
|
81
|
+
const n = S(y), e = S(ye), t = xe(n.editingLink$), i = S(k), r = S(L), o = S(w), [s, c] = W(""), [l, u] = W(""), [f, h] = W(!1), g = He.isLegalUrl(s), d = t ? r.getUnit(t.unitId, _.UNIVER_DOC) : r.getCurrentUnitForType(_.UNIVER_DOC);
|
|
82
|
+
Sn(() => {
|
|
83
|
+
var oe, se, ce, de, ae, le, ue, pe, ge;
|
|
84
|
+
const a = o.getActiveTextRange();
|
|
85
|
+
if (!a)
|
|
86
|
+
return;
|
|
87
|
+
if (t) {
|
|
88
|
+
const H = (oe = d == null ? void 0 : d.getSelfOrHeaderFooterModel(t.segmentId)) == null ? void 0 : oe.getBody(), j = (se = H == null ? void 0 : H.customRanges) == null ? void 0 : se.find((z) => (t == null ? void 0 : t.linkId) === z.rangeId && z.startIndex === t.startIndex && z.endIndex === t.endIndex);
|
|
89
|
+
d && j && (c((de = (ce = j.properties) == null ? void 0 : ce.url) != null ? de : ""), u(ve.transform.getPlainText(Se(H, j.startIndex, j.endIndex + 1).dataStream)));
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
const x = (ae = d == null ? void 0 : d.getSelfOrHeaderFooterModel(a.segmentId)) == null ? void 0 : ae.getBody(), re = x ? a : null, $ = re && ((ue = ve.customRange.getCustomRangesInterestsWithSelection(re, (le = x == null ? void 0 : x.customRanges) != null ? le : [])) == null ? void 0 : ue[0]);
|
|
93
|
+
d && $ && c((ge = (pe = $ == null ? void 0 : $.properties) == null ? void 0 : pe.url) != null ? ge : "");
|
|
94
|
+
}, [d, t, o, r]);
|
|
95
|
+
const p = () => {
|
|
96
|
+
n.hideEditPopup();
|
|
97
|
+
}, C = () => {
|
|
98
|
+
if (h(!0), !g || !d)
|
|
99
|
+
return;
|
|
100
|
+
const a = On(s);
|
|
101
|
+
if (!t)
|
|
102
|
+
i.executeCommand(ke.id, {
|
|
103
|
+
unitId: d.getUnitId(),
|
|
104
|
+
payload: a
|
|
105
|
+
});
|
|
106
|
+
else {
|
|
107
|
+
if (!l)
|
|
108
|
+
return;
|
|
109
|
+
i.executeCommand(Le.id, {
|
|
110
|
+
unitId: d.getUnitId(),
|
|
111
|
+
payload: a,
|
|
112
|
+
linkId: t.linkId,
|
|
113
|
+
label: l,
|
|
114
|
+
segmentId: t.segmentId
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
n.hideEditPopup();
|
|
118
|
+
};
|
|
119
|
+
if (d)
|
|
120
|
+
return /* @__PURE__ */ P(
|
|
121
|
+
"div",
|
|
122
|
+
{
|
|
123
|
+
className: `
|
|
124
|
+
univer-box-border univer-w-[328px] univer-rounded-xl univer-border univer-border-solid
|
|
125
|
+
univer-border-gray-200 univer-bg-white univer-px-6 univer-py-5 univer-shadow
|
|
126
|
+
`,
|
|
127
|
+
children: [
|
|
128
|
+
/* @__PURE__ */ P("div", { children: [
|
|
129
|
+
t ? /* @__PURE__ */ v(
|
|
130
|
+
he,
|
|
131
|
+
{
|
|
132
|
+
label: e.t("docLink.edit.label"),
|
|
133
|
+
error: f && !l ? e.t("docLink.edit.labelError") : "",
|
|
134
|
+
children: /* @__PURE__ */ v(
|
|
135
|
+
me,
|
|
136
|
+
{
|
|
137
|
+
value: l,
|
|
138
|
+
onChange: u,
|
|
139
|
+
autoFocus: !0,
|
|
140
|
+
onKeyDown: (a) => {
|
|
141
|
+
a.keyCode === X.ENTER && C();
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
)
|
|
145
|
+
}
|
|
146
|
+
) : null,
|
|
147
|
+
/* @__PURE__ */ v(
|
|
148
|
+
he,
|
|
149
|
+
{
|
|
150
|
+
label: e.t("docLink.edit.address"),
|
|
151
|
+
error: f && !g ? e.t("docLink.edit.addressError") : "",
|
|
152
|
+
children: /* @__PURE__ */ v(
|
|
153
|
+
me,
|
|
154
|
+
{
|
|
155
|
+
value: s,
|
|
156
|
+
onChange: c,
|
|
157
|
+
autoFocus: !0,
|
|
158
|
+
onKeyDown: (a) => {
|
|
159
|
+
a.keyCode === X.ENTER && C();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
)
|
|
163
|
+
}
|
|
164
|
+
)
|
|
165
|
+
] }),
|
|
166
|
+
/* @__PURE__ */ P("div", { className: "univer-flex univer-justify-end univer-gap-3", children: [
|
|
167
|
+
/* @__PURE__ */ v(Ie, { onClick: p, children: e.t("docLink.edit.cancel") }),
|
|
168
|
+
/* @__PURE__ */ v(
|
|
169
|
+
Ie,
|
|
170
|
+
{
|
|
171
|
+
type: "primary",
|
|
172
|
+
disabled: !s,
|
|
173
|
+
onClick: C,
|
|
174
|
+
children: e.t("docLink.edit.confirm")
|
|
175
|
+
}
|
|
176
|
+
)
|
|
177
|
+
] })
|
|
178
|
+
]
|
|
179
|
+
}
|
|
180
|
+
);
|
|
181
|
+
};
|
|
182
|
+
F.componentKey = "docs-hyper-link-edit";
|
|
183
|
+
var m = function() {
|
|
184
|
+
return m = Object.assign || function(n) {
|
|
185
|
+
for (var e, t = 1, i = arguments.length; t < i; t++) {
|
|
186
|
+
e = arguments[t];
|
|
187
|
+
for (var r in e) Object.prototype.hasOwnProperty.call(e, r) && (n[r] = e[r]);
|
|
188
|
+
}
|
|
189
|
+
return n;
|
|
190
|
+
}, m.apply(this, arguments);
|
|
191
|
+
}, Pn = function(n, e) {
|
|
192
|
+
var t = {};
|
|
193
|
+
for (var i in n) Object.prototype.hasOwnProperty.call(n, i) && e.indexOf(i) < 0 && (t[i] = n[i]);
|
|
194
|
+
if (n != null && typeof Object.getOwnPropertySymbols == "function")
|
|
195
|
+
for (var r = 0, i = Object.getOwnPropertySymbols(n); r < i.length; r++)
|
|
196
|
+
e.indexOf(i[r]) < 0 && Object.prototype.propertyIsEnumerable.call(n, i[r]) && (t[i[r]] = n[i[r]]);
|
|
197
|
+
return t;
|
|
198
|
+
}, T = N(function(n, e) {
|
|
199
|
+
var t = n.icon, i = n.id, r = n.className, o = n.extend, s = Pn(n, ["icon", "id", "className", "extend"]), c = "univerjs-icon univerjs-icon-".concat(i, " ").concat(r || "").trim(), l = yn("_".concat(wn()));
|
|
200
|
+
return Oe(t, "".concat(i), { defIds: t.defIds, idSuffix: l.current }, m({ ref: e, className: c }, s), o);
|
|
201
|
+
});
|
|
202
|
+
function Oe(n, e, t, i, r) {
|
|
203
|
+
return U(n.tag, m(m({ key: e }, bn(n, t, r)), i), (Rn(n, t).children || []).map(function(o, s) {
|
|
204
|
+
return Oe(o, "".concat(e, "-").concat(n.tag, "-").concat(s), t, void 0, r);
|
|
205
|
+
}));
|
|
206
|
+
}
|
|
207
|
+
function bn(n, e, t) {
|
|
208
|
+
var i = m({}, n.attrs);
|
|
209
|
+
t != null && t.colorChannel1 && i.fill === "colorChannel1" && (i.fill = t.colorChannel1), n.tag === "mask" && i.id && (i.id = i.id + e.idSuffix), Object.entries(i).forEach(function(o) {
|
|
210
|
+
var s = o[0], c = o[1];
|
|
211
|
+
s === "mask" && typeof c == "string" && (i[s] = c.replace(/url\(#(.*)\)/, "url(#$1".concat(e.idSuffix, ")")));
|
|
212
|
+
});
|
|
213
|
+
var r = e.defIds;
|
|
214
|
+
return !r || r.length === 0 || (n.tag === "use" && i["xlink:href"] && (i["xlink:href"] = i["xlink:href"] + e.idSuffix), Object.entries(i).forEach(function(o) {
|
|
215
|
+
var s = o[0], c = o[1];
|
|
216
|
+
typeof c == "string" && (i[s] = c.replace(/url\(#(.*)\)/, "url(#$1".concat(e.idSuffix, ")")));
|
|
217
|
+
})), i;
|
|
218
|
+
}
|
|
219
|
+
function Rn(n, e) {
|
|
220
|
+
var t, i = e.defIds;
|
|
221
|
+
return !i || i.length === 0 ? n : n.tag === "defs" && (!((t = n.children) === null || t === void 0) && t.length) ? m(m({}, n), { children: n.children.map(function(r) {
|
|
222
|
+
return typeof r.attrs.id == "string" && i && i.indexOf(r.attrs.id) > -1 ? m(m({}, r), { attrs: m(m({}, r.attrs), { id: r.attrs.id + e.idSuffix }) }) : r;
|
|
223
|
+
}) }) : n;
|
|
224
|
+
}
|
|
225
|
+
function wn() {
|
|
226
|
+
return Math.random().toString(36).substring(2, 8);
|
|
227
|
+
}
|
|
228
|
+
T.displayName = "UniverIcon";
|
|
229
|
+
var Mn = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M4.1302 12.4251C4.25802 13.7417 5.36779 14.7708 6.71792 14.7708H11.7179C13.1539 14.7708 14.3179 13.6067 14.3179 12.1708V6.1708C14.3179 4.78586 13.2351 3.65383 11.8698 3.57517C11.742 2.25858 10.6323 1.22949 9.28213 1.22949H4.28213C2.84619 1.22949 1.68213 2.39355 1.68213 3.82949V9.82949C1.68213 11.2144 2.76497 12.3465 4.1302 12.4251ZM10.6583 3.5708H6.71792C5.28198 3.5708 4.11792 4.73486 4.11792 6.1708V11.22C3.4221 11.1387 2.88213 10.5471 2.88213 9.82949V3.82949C2.88213 3.05629 3.50893 2.42949 4.28213 2.42949H9.28213C9.96695 2.42949 10.5369 2.92119 10.6583 3.5708ZM13.1179 6.1708C13.1179 5.3976 12.4911 4.7708 11.7179 4.7708H6.71792C5.94472 4.7708 5.31792 5.3976 5.31792 6.1708V12.1708C5.31792 12.944 5.94472 13.5708 6.71792 13.5708H11.7179C12.4911 13.5708 13.1179 12.944 13.1179 12.1708V6.1708Z", fillRule: "evenodd", clipRule: "evenodd" } }] }, Pe = N(function(n, e) {
|
|
230
|
+
return U(T, Object.assign({}, n, {
|
|
231
|
+
id: "copy-single",
|
|
232
|
+
ref: e,
|
|
233
|
+
icon: Mn
|
|
234
|
+
}));
|
|
235
|
+
});
|
|
236
|
+
Pe.displayName = "CopySingle";
|
|
237
|
+
var En = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M9.8816 1.97978C11.0177 0.843607 12.862 0.884962 14.0004 2.02342C15.1389 3.16188 15.1803 5.00612 14.0441 6.14228L11.399 8.78737C11.1608 9.02559 10.7746 9.02559 10.5363 8.78737C10.2981 8.54915 10.2981 8.16292 10.5363 7.9247L13.1814 5.2796C13.8195 4.64155 13.8217 3.57006 13.1378 2.8861C12.4538 2.20211 11.3823 2.20438 10.7443 2.84245L7.6976 5.88911L7.69317 5.89349C7.05959 6.53211 7.05894 7.60014 7.74132 8.28252C7.97954 8.52074 7.97954 8.90697 7.74132 9.14519C7.5031 9.38341 7.11687 9.38341 6.87865 9.14519C5.74016 8.00671 5.69884 6.16251 6.83497 5.02633L6.84021 5.02116L9.8816 1.97978Z" } }, { tag: "path", attrs: { fill: "currentColor", d: "M4.61426 7.2364C4.85248 6.99818 5.23871 6.99818 5.47693 7.2364C5.71515 7.47462 5.71515 7.86085 5.47693 8.09907L2.83183 10.7442C2.19375 11.3823 2.1915 12.4537 2.87547 13.1377C3.55945 13.8217 4.6309 13.8194 5.26899 13.1813L8.31566 10.1347C8.32262 10.1277 8.32971 10.121 8.33691 10.1144C8.34408 10.1064 8.3515 10.0986 8.35916 10.091C8.99721 9.45291 8.99949 8.38145 8.3155 7.69746C8.07728 7.45924 8.07728 7.07301 8.3155 6.83479C8.55372 6.59657 8.93995 6.59657 9.17817 6.83479C10.3166 7.97327 10.358 9.81748 9.22183 10.9536C9.21487 10.9606 9.20779 10.9673 9.20058 10.9739C9.19341 10.9819 9.18599 10.9897 9.17833 10.9973L6.13166 14.044C4.99548 15.1802 3.15127 15.1389 2.01279 14.0004C0.874362 12.8619 0.83297 11.0177 1.96916 9.8815L4.61426 7.2364Z" } }] }, ie = N(function(n, e) {
|
|
238
|
+
return U(T, Object.assign({}, n, {
|
|
239
|
+
id: "link-single",
|
|
240
|
+
ref: e,
|
|
241
|
+
icon: En
|
|
242
|
+
}));
|
|
243
|
+
});
|
|
244
|
+
ie.displayName = "LinkSingle";
|
|
245
|
+
var Dn = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 16 17", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M12.5935 3.47302C11.6354 2.51492 10.082 2.51492 9.12388 3.47302L7.83534 4.76157C7.60102 4.99588 7.22112 4.99588 6.98681 4.76157 6.75249 4.52725 6.75249 4.14735 6.98681 3.91304L8.27535 2.62449C9.70209 1.19776 12.0153 1.19776 13.442 2.62449 14.8688 4.05123 14.8688 6.36442 13.442 7.79116L12.1535 9.0797C11.9192 9.31402 11.5393 9.31402 11.3049 9.0797 11.0706 8.84539 11.0706 8.46549 11.3049 8.23117L12.5935 6.94263C13.5516 5.98452 13.5516 4.43113 12.5935 3.47302zM3.40637 12.6606C2.44827 11.7025 2.44827 10.1491 3.40637 9.19102L4.69492 7.90248C4.92923 7.66816 4.92923 7.28826 4.69492 7.05395 4.4606 6.81963 4.0807 6.81963 3.84639 7.05395L2.55784 8.34249C1.13111 9.76923 1.13111 12.0824 2.55784 13.5092 3.98458 14.9359 6.29777 14.9359 7.72451 13.5092L9.01305 12.2206C9.24737 11.9863 9.24737 11.6064 9.01305 11.3721 8.77874 11.1378 8.39884 11.1378 8.16452 11.3721L6.87598 12.6606C5.91787 13.6187 4.36448 13.6187 3.40637 12.6606zM3.5852 2.80332C3.35088 2.569 2.97098 2.569 2.73667 2.80332 2.50235 3.03763 2.50235 3.41753 2.73667 3.65185L12.4151 13.3302C12.6494 13.5646 13.0293 13.5646 13.2636 13.3302 13.4979 13.0959 13.4979 12.716 13.2636 12.4817L3.5852 2.80332z" } }] }, be = N(function(n, e) {
|
|
246
|
+
return U(T, Object.assign({}, n, {
|
|
247
|
+
id: "unlink-single",
|
|
248
|
+
ref: e,
|
|
249
|
+
icon: Dn
|
|
250
|
+
}));
|
|
251
|
+
});
|
|
252
|
+
be.displayName = "UnlinkSingle";
|
|
253
|
+
var Nn = { tag: "svg", attrs: { fill: "none", viewBox: "0 0 17 16", width: "1em", height: "1em" }, children: [{ tag: "path", attrs: { fill: "currentColor", d: "M12.6551 1.98906C11.7476 1.08113 10.2757 1.08149 9.3686 1.98987L4.82542 6.53955C4.75087 6.61421 4.69336 6.70411 4.65682 6.80309L3.2461 10.625C3.16506 10.8446 3.21909 11.0912 3.3845 11.2568C3.54991 11.4224 3.79651 11.4767 4.01616 11.3959L7.85031 9.98517C7.94979 9.94856 8.04014 9.89077 8.11508 9.81579L12.6552 5.27327C13.5618 4.36621 13.5618 2.89607 12.6551 1.98906ZM10.2177 2.83779C10.6562 2.39869 11.3677 2.39851 11.8064 2.8374C12.2447 3.27584 12.2447 3.9865 11.8065 4.42497L7.3392 8.89457L4.82213 9.82068L5.74706 7.31487L10.2177 2.83779Z", fillRule: "evenodd", clipRule: "evenodd" } }, { tag: "path", attrs: { fill: "currentColor", d: "M1.79238 13.2999C1.46101 13.2999 1.19238 13.5685 1.19238 13.8999C1.19238 14.2313 1.46101 14.4999 1.79238 14.4999H14.4924C14.8238 14.4999 15.0924 14.2313 15.0924 13.8999C15.0924 13.5685 14.8238 13.2999 14.4924 13.2999H1.79238Z" } }] }, Re = N(function(n, e) {
|
|
254
|
+
return U(T, Object.assign({}, n, {
|
|
255
|
+
id: "write-single",
|
|
256
|
+
ref: e,
|
|
257
|
+
icon: Nn
|
|
258
|
+
}));
|
|
259
|
+
});
|
|
260
|
+
Re.displayName = "WriteSingle";
|
|
261
|
+
const we = {
|
|
262
|
+
type: R.COMMAND,
|
|
263
|
+
id: "docs.command.delete-hyper-link",
|
|
264
|
+
async handler(n, e) {
|
|
265
|
+
if (!e)
|
|
266
|
+
return !1;
|
|
267
|
+
const { unitId: t, linkId: i, segmentId: r } = e, o = n.get(k), s = qe(n, { unitId: t, rangeId: i, segmentId: r });
|
|
268
|
+
return s ? await o.syncExecuteCommand(s.id, s.params) : !1;
|
|
269
|
+
}
|
|
270
|
+
}, Me = (n) => {
|
|
271
|
+
const e = n.get(w), t = n.get(L), i = e.getTextRanges();
|
|
272
|
+
if (!(i != null && i.length))
|
|
273
|
+
return !0;
|
|
274
|
+
const r = i[0];
|
|
275
|
+
return !!(!t.getCurrentUnitForType(_.UNIVER_DOC) || !r || r.collapsed);
|
|
276
|
+
}, b = {
|
|
277
|
+
type: R.OPERATION,
|
|
278
|
+
id: "doc.operation.show-hyper-link-edit-popup",
|
|
279
|
+
handler(n, e) {
|
|
280
|
+
var s;
|
|
281
|
+
const t = e == null ? void 0 : e.link, i = n.get(L);
|
|
282
|
+
if (Me(n) && !t)
|
|
283
|
+
return !1;
|
|
284
|
+
const r = n.get(y), o = (t == null ? void 0 : t.unitId) || ((s = i.getCurrentUnitForType(_.UNIVER_DOC)) == null ? void 0 : s.getUnitId());
|
|
285
|
+
return o ? (r.showEditPopup(o, t), !0) : !1;
|
|
286
|
+
}
|
|
287
|
+
}, ee = {
|
|
288
|
+
type: R.OPERATION,
|
|
289
|
+
id: "doc.operation.toggle-hyper-link-info-popup",
|
|
290
|
+
handler(n, e) {
|
|
291
|
+
const t = n.get(y);
|
|
292
|
+
return e ? (t.showInfoPopup(e), !0) : (t.hideInfoPopup(), !0);
|
|
293
|
+
}
|
|
294
|
+
}, Ee = {
|
|
295
|
+
type: R.OPERATION,
|
|
296
|
+
id: "doc.operation.click-hyper-link",
|
|
297
|
+
handler(n, e) {
|
|
298
|
+
var u, f, h;
|
|
299
|
+
if (!e)
|
|
300
|
+
return !1;
|
|
301
|
+
const { unitId: t, linkId: i, segmentId: r } = e, s = n.get(L).getUnit(t, _.UNIVER_DOC), c = s == null ? void 0 : s.getSelfOrHeaderFooterModel(r).getBody(), l = (h = (f = (u = c == null ? void 0 : c.customRanges) == null ? void 0 : u.find((g) => g.rangeId === i && g.rangeType === E.HYPERLINK)) == null ? void 0 : f.properties) == null ? void 0 : h.url;
|
|
302
|
+
return l && window.open(l, "_blank", "noopener noreferrer"), !0;
|
|
303
|
+
}
|
|
304
|
+
}, B = () => {
|
|
305
|
+
var C, a;
|
|
306
|
+
const n = S(y), e = S(k), t = S(un), i = S(ye), r = xe(n.showingLink$), o = S(L);
|
|
307
|
+
if (!r)
|
|
308
|
+
return null;
|
|
309
|
+
const { unitId: s, linkId: c, segmentId: l, startIndex: u, endIndex: f } = r, h = o.getUnit(s, _.UNIVER_DOC), g = h == null ? void 0 : h.getSelfOrHeaderFooterModel(l).getBody(), d = (C = g == null ? void 0 : g.customRanges) == null ? void 0 : C.find((x) => x.rangeId === c && x.rangeType === E.HYPERLINK && x.startIndex === u && x.endIndex === f);
|
|
310
|
+
if (!d)
|
|
311
|
+
return null;
|
|
312
|
+
const p = (a = d.properties) == null ? void 0 : a.url;
|
|
313
|
+
return /* @__PURE__ */ P(
|
|
314
|
+
"div",
|
|
315
|
+
{
|
|
316
|
+
className: `
|
|
317
|
+
univer-box-border univer-flex univer-max-w-[328px] univer-items-center univer-justify-between
|
|
318
|
+
univer-overflow-hidden univer-rounded-lg univer-border univer-border-solid univer-border-gray-200
|
|
319
|
+
univer-bg-white univer-p-3 univer-shadow
|
|
320
|
+
`,
|
|
321
|
+
onClick: () => {
|
|
322
|
+
n.hideInfoPopup();
|
|
323
|
+
},
|
|
324
|
+
children: [
|
|
325
|
+
/* @__PURE__ */ P(
|
|
326
|
+
"div",
|
|
327
|
+
{
|
|
328
|
+
className: `
|
|
329
|
+
univer-flex univer-h-6 univer-flex-1 univer-cursor-pointer univer-items-center univer-truncate
|
|
330
|
+
univer-text-[13px] univer-leading-5 univer-text-primary-500
|
|
331
|
+
`,
|
|
332
|
+
onClick: () => window.open(p, void 0, "noopener,noreferrer"),
|
|
333
|
+
children: [
|
|
334
|
+
/* @__PURE__ */ v(
|
|
335
|
+
"div",
|
|
336
|
+
{
|
|
337
|
+
className: `
|
|
338
|
+
univer-mr-2 univer-flex univer-size-5 univer-flex-[0_0_auto] univer-items-center
|
|
339
|
+
univer-justify-center univer-text-base univer-text-black
|
|
340
|
+
`,
|
|
341
|
+
children: /* @__PURE__ */ v(ie, {})
|
|
342
|
+
}
|
|
343
|
+
),
|
|
344
|
+
/* @__PURE__ */ v(K, { showIfEllipsis: !0, title: p, children: /* @__PURE__ */ v("span", { className: "univer-flex-1 univer-truncate", children: p }) })
|
|
345
|
+
]
|
|
346
|
+
}
|
|
347
|
+
),
|
|
348
|
+
/* @__PURE__ */ P("div", { className: "univer-flex univer-h-6 univer-flex-[0_0_auto] univer-items-center univer-justify-center", children: [
|
|
349
|
+
/* @__PURE__ */ v(
|
|
350
|
+
"div",
|
|
351
|
+
{
|
|
352
|
+
className: `
|
|
353
|
+
univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center
|
|
354
|
+
univer-justify-center univer-rounded univer-text-base
|
|
355
|
+
`,
|
|
356
|
+
onClick: () => {
|
|
357
|
+
navigator.clipboard.writeText(p), t.show({
|
|
358
|
+
content: i.t("docLink.info.coped"),
|
|
359
|
+
type: ln.Info
|
|
360
|
+
});
|
|
361
|
+
},
|
|
362
|
+
children: /* @__PURE__ */ v(K, { placement: "bottom", title: i.t("docLink.info.copy"), children: /* @__PURE__ */ v(Pe, {}) })
|
|
363
|
+
}
|
|
364
|
+
),
|
|
365
|
+
/* @__PURE__ */ v(
|
|
366
|
+
"div",
|
|
367
|
+
{
|
|
368
|
+
className: `
|
|
369
|
+
univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center
|
|
370
|
+
univer-justify-center univer-rounded univer-text-base
|
|
371
|
+
`,
|
|
372
|
+
onClick: () => {
|
|
373
|
+
e.executeCommand(b.id, {
|
|
374
|
+
link: r
|
|
375
|
+
});
|
|
376
|
+
},
|
|
377
|
+
children: /* @__PURE__ */ v(K, { placement: "bottom", title: i.t("docLink.info.edit"), children: /* @__PURE__ */ v(Re, {}) })
|
|
378
|
+
}
|
|
379
|
+
),
|
|
380
|
+
/* @__PURE__ */ v(
|
|
381
|
+
"div",
|
|
382
|
+
{
|
|
383
|
+
className: `
|
|
384
|
+
univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center
|
|
385
|
+
univer-justify-center univer-rounded univer-text-base
|
|
386
|
+
`,
|
|
387
|
+
onClick: () => {
|
|
388
|
+
e.executeCommand(we.id, {
|
|
389
|
+
unitId: s,
|
|
390
|
+
linkId: d.rangeId,
|
|
391
|
+
segmentId: l
|
|
392
|
+
});
|
|
393
|
+
},
|
|
394
|
+
children: /* @__PURE__ */ v(K, { placement: "bottom", title: i.t("docLink.info.cancel"), children: /* @__PURE__ */ v(be, {}) })
|
|
395
|
+
}
|
|
396
|
+
)
|
|
397
|
+
] })
|
|
398
|
+
]
|
|
399
|
+
}
|
|
400
|
+
);
|
|
401
|
+
};
|
|
402
|
+
B.componentKey = "univer.doc.link-info-popup";
|
|
403
|
+
var Un = Object.getOwnPropertyDescriptor, Tn = (n, e, t, i) => {
|
|
404
|
+
for (var r = i > 1 ? void 0 : i ? Un(e, t) : e, o = n.length - 1, s; o >= 0; o--)
|
|
405
|
+
(s = n[o]) && (r = s(r) || r);
|
|
406
|
+
return r;
|
|
407
|
+
}, G = (n, e) => (t, i) => e(t, i, n);
|
|
408
|
+
let y = class extends D {
|
|
409
|
+
constructor(e, t, i) {
|
|
410
|
+
super();
|
|
411
|
+
O(this, "_editingLink$", new fe(null));
|
|
412
|
+
O(this, "_showingLink$", new fe(null));
|
|
413
|
+
O(this, "editingLink$", this._editingLink$.asObservable());
|
|
414
|
+
O(this, "showingLink$", this._showingLink$.asObservable());
|
|
415
|
+
O(this, "_editPopup", null);
|
|
416
|
+
O(this, "_infoPopup", null);
|
|
417
|
+
this._docCanvasPopupManagerService = e, this._textSelectionManagerService = t, this._univerInstanceService = i, this.disposeWithMe(() => {
|
|
418
|
+
this._editingLink$.complete(), this._showingLink$.complete();
|
|
419
|
+
});
|
|
420
|
+
}
|
|
421
|
+
get editing() {
|
|
422
|
+
return this._editingLink$.value;
|
|
423
|
+
}
|
|
424
|
+
get showing() {
|
|
425
|
+
return this._showingLink$.value;
|
|
426
|
+
}
|
|
427
|
+
showEditPopup(e, t) {
|
|
428
|
+
this._editPopup && this._editPopup.dispose(), this._editingLink$.next(t);
|
|
429
|
+
const i = this._textSelectionManagerService.getTextRanges({ unitId: e, subUnitId: e });
|
|
430
|
+
let r = i == null ? void 0 : i[i.length - 1];
|
|
431
|
+
if (t) {
|
|
432
|
+
const { segmentId: o, segmentPage: s, startIndex: c, endIndex: l } = t;
|
|
433
|
+
r = {
|
|
434
|
+
collapsed: !1,
|
|
435
|
+
startOffset: c,
|
|
436
|
+
endOffset: l + 1,
|
|
437
|
+
segmentId: o,
|
|
438
|
+
segmentPage: s
|
|
439
|
+
}, this._textSelectionManagerService.replaceDocRanges([{
|
|
440
|
+
startOffset: c,
|
|
441
|
+
endOffset: l + 1
|
|
442
|
+
}]);
|
|
443
|
+
}
|
|
444
|
+
return r ? (this._editPopup = this._docCanvasPopupManagerService.attachPopupToRange(
|
|
445
|
+
r,
|
|
446
|
+
{
|
|
447
|
+
componentKey: F.componentKey,
|
|
448
|
+
direction: "bottom"
|
|
449
|
+
},
|
|
450
|
+
e
|
|
451
|
+
), this._editPopup) : null;
|
|
452
|
+
}
|
|
453
|
+
hideEditPopup() {
|
|
454
|
+
var e;
|
|
455
|
+
this._editingLink$.next(null), (e = this._editPopup) == null || e.dispose();
|
|
456
|
+
}
|
|
457
|
+
showInfoPopup(e) {
|
|
458
|
+
var u, f, h, g, d, p;
|
|
459
|
+
const { linkId: t, unitId: i, segmentId: r, segmentPage: o, startIndex: s, endIndex: c } = e;
|
|
460
|
+
if (!(((u = this.showing) == null ? void 0 : u.linkId) === t && ((f = this.showing) == null ? void 0 : f.unitId) === i && ((h = this.showing) == null ? void 0 : h.segmentId) === r && ((g = this.showing) == null ? void 0 : g.segmentPage) === o && ((d = this.showing) == null ? void 0 : d.startIndex) === s && ((p = this.showing) == null ? void 0 : p.endIndex) === c || (this._infoPopup && this._infoPopup.dispose(), !this._univerInstanceService.getUnit(i, _.UNIVER_DOC))))
|
|
461
|
+
return this._showingLink$.next({ unitId: i, linkId: t, segmentId: r, segmentPage: o, startIndex: s, endIndex: c }), this._infoPopup = this._docCanvasPopupManagerService.attachPopupToRange(
|
|
462
|
+
{
|
|
463
|
+
collapsed: !1,
|
|
464
|
+
startOffset: s,
|
|
465
|
+
endOffset: c + 1,
|
|
466
|
+
segmentId: r,
|
|
467
|
+
segmentPage: o
|
|
468
|
+
},
|
|
469
|
+
{
|
|
470
|
+
componentKey: B.componentKey,
|
|
471
|
+
direction: "top-center",
|
|
472
|
+
multipleDirection: "top",
|
|
473
|
+
onClickOutside: () => {
|
|
474
|
+
this.hideInfoPopup();
|
|
475
|
+
}
|
|
476
|
+
},
|
|
477
|
+
i
|
|
478
|
+
), this._infoPopup;
|
|
479
|
+
}
|
|
480
|
+
hideInfoPopup() {
|
|
481
|
+
var e;
|
|
482
|
+
this._showingLink$.next(null), (e = this._infoPopup) == null || e.dispose();
|
|
483
|
+
}
|
|
484
|
+
};
|
|
485
|
+
y = Tn([
|
|
486
|
+
G(0, I(nn)),
|
|
487
|
+
G(1, I(w)),
|
|
488
|
+
G(2, L)
|
|
489
|
+
], y);
|
|
490
|
+
var $n = Object.getOwnPropertyDescriptor, Hn = (n, e, t, i) => {
|
|
491
|
+
for (var r = i > 1 ? void 0 : i ? $n(e, t) : e, o = n.length - 1, s; o >= 0; o--)
|
|
492
|
+
(s = n[o]) && (r = s(r) || r);
|
|
493
|
+
return r;
|
|
494
|
+
}, q = (n, e) => (t, i) => e(t, i, n);
|
|
495
|
+
let V = class extends D {
|
|
496
|
+
constructor(n, e, t) {
|
|
497
|
+
super(), this._commandService = n, this._univerInstanceService = e, this._docHyperLinkService = t, this._initSelectionChange();
|
|
498
|
+
}
|
|
499
|
+
_initSelectionChange() {
|
|
500
|
+
this.disposeWithMe(
|
|
501
|
+
this._commandService.onCommandExecuted((n) => {
|
|
502
|
+
var e, t, i;
|
|
503
|
+
if (n.id === Je.id) {
|
|
504
|
+
const r = n.params, { unitId: o, ranges: s, segmentId: c } = r, l = this._univerInstanceService.getUnit(o, _.UNIVER_DOC), u = s[0];
|
|
505
|
+
if (u && l) {
|
|
506
|
+
const { startOffset: f, endOffset: h, collapsed: g, segmentPage: d } = u, p = (t = (e = l.getSelfOrHeaderFooterModel(c)) == null ? void 0 : e.getBody()) == null ? void 0 : t.customRanges;
|
|
507
|
+
if (g) {
|
|
508
|
+
const C = (i = p == null ? void 0 : p.findIndex((a) => a.startIndex < f && a.endIndex > h - 1)) != null ? i : -1;
|
|
509
|
+
if (C > -1) {
|
|
510
|
+
const a = p[C];
|
|
511
|
+
this._docHyperLinkService.showInfoPopup({ unitId: o, linkId: a.rangeId, segmentId: c, segmentPage: d, startIndex: a.startIndex, endIndex: a.endIndex });
|
|
512
|
+
return;
|
|
513
|
+
}
|
|
514
|
+
} else if (p == null ? void 0 : p.find((a) => a.startIndex <= f && a.endIndex >= h - 1))
|
|
515
|
+
return;
|
|
516
|
+
}
|
|
517
|
+
this._docHyperLinkService.hideInfoPopup(), this._docHyperLinkService.hideEditPopup();
|
|
518
|
+
}
|
|
519
|
+
})
|
|
520
|
+
);
|
|
521
|
+
}
|
|
522
|
+
};
|
|
523
|
+
V = Hn([
|
|
524
|
+
q(0, k),
|
|
525
|
+
q(1, L),
|
|
526
|
+
q(2, I(y))
|
|
527
|
+
], V);
|
|
528
|
+
var jn = Object.getOwnPropertyDescriptor, Kn = (n, e, t, i) => {
|
|
529
|
+
for (var r = i > 1 ? void 0 : i ? jn(e, t) : e, o = n.length - 1, s; o >= 0; o--)
|
|
530
|
+
(s = n[o]) && (r = s(r) || r);
|
|
531
|
+
return r;
|
|
532
|
+
}, M = (n, e) => (t, i) => e(t, i, n);
|
|
533
|
+
let ne = class extends D {
|
|
534
|
+
constructor(n, e, t, i, r, o) {
|
|
535
|
+
super(), this._context = n, this._docEventManagerService = e, this._commandService = t, this._hyperLinkPopupService = i, this._docSkeletonManagerService = r, this._docSelectionManagerService = o, !(this._context.unitId === je || this._context.unitId === Ke) && (this._initHover(), this._initClick());
|
|
536
|
+
}
|
|
537
|
+
get _skeleton() {
|
|
538
|
+
return this._docSkeletonManagerService.getSkeleton();
|
|
539
|
+
}
|
|
540
|
+
_hideInfoPopup() {
|
|
541
|
+
this._hyperLinkPopupService.showing && this._commandService.executeCommand(
|
|
542
|
+
ee.id
|
|
543
|
+
);
|
|
544
|
+
}
|
|
545
|
+
_initHover() {
|
|
546
|
+
this.disposeWithMe(
|
|
547
|
+
this._docEventManagerService.hoverCustomRanges$.subscribe((n) => {
|
|
548
|
+
var r;
|
|
549
|
+
const e = n.find((o) => o.range.rangeType === E.HYPERLINK), t = this._docSelectionManagerService.getTextRanges(), i = t == null ? void 0 : t[0].segmentId;
|
|
550
|
+
if (((r = e == null ? void 0 : e.segmentId) != null ? r : "") !== i) {
|
|
551
|
+
this._hideInfoPopup();
|
|
552
|
+
return;
|
|
553
|
+
}
|
|
554
|
+
e ? this._commandService.executeCommand(
|
|
555
|
+
ee.id,
|
|
556
|
+
{
|
|
557
|
+
unitId: this._context.unitId,
|
|
558
|
+
linkId: e.range.rangeId,
|
|
559
|
+
segmentId: e.segmentId,
|
|
560
|
+
segmentPage: e.segmentPageIndex,
|
|
561
|
+
rangeId: e.range.rangeId,
|
|
562
|
+
startIndex: e.range.startIndex,
|
|
563
|
+
endIndex: e.range.endIndex
|
|
564
|
+
}
|
|
565
|
+
) : this._hideInfoPopup();
|
|
566
|
+
})
|
|
567
|
+
);
|
|
568
|
+
}
|
|
569
|
+
_initClick() {
|
|
570
|
+
this.disposeWithMe(
|
|
571
|
+
this._docEventManagerService.clickCustomRanges$.subscribe((n) => {
|
|
572
|
+
const e = n.range;
|
|
573
|
+
e && this._commandService.executeCommand(
|
|
574
|
+
Ee.id,
|
|
575
|
+
{
|
|
576
|
+
unitId: this._context.unitId,
|
|
577
|
+
linkId: e.rangeId,
|
|
578
|
+
segmentId: n.segmentId
|
|
579
|
+
}
|
|
580
|
+
);
|
|
581
|
+
})
|
|
582
|
+
);
|
|
583
|
+
}
|
|
584
|
+
};
|
|
585
|
+
ne = Kn([
|
|
586
|
+
M(1, I(tn)),
|
|
587
|
+
M(2, k),
|
|
588
|
+
M(3, I(y)),
|
|
589
|
+
M(4, I(Qe)),
|
|
590
|
+
M(5, I(w))
|
|
591
|
+
], ne);
|
|
592
|
+
var An = Object.getOwnPropertyDescriptor, Fn = (n, e, t, i) => {
|
|
593
|
+
for (var r = i > 1 ? void 0 : i ? An(e, t) : e, o = n.length - 1, s; o >= 0; o--)
|
|
594
|
+
(s = n[o]) && (r = s(r) || r);
|
|
595
|
+
return r;
|
|
596
|
+
}, J = (n, e) => (t, i) => e(t, i, n);
|
|
597
|
+
let te = class extends D {
|
|
598
|
+
constructor(n, e, t, i) {
|
|
599
|
+
super(), this._context = n, this._docInterceptorService = e, this._hyperLinkService = t, this._docRenderController = i, this._init(), this._initReRender();
|
|
600
|
+
}
|
|
601
|
+
_init() {
|
|
602
|
+
this._docInterceptorService.intercept(en.CUSTOM_RANGE, {
|
|
603
|
+
handler: (n, e, t) => {
|
|
604
|
+
if (!n)
|
|
605
|
+
return t(n);
|
|
606
|
+
const { unitId: i, index: r } = e, o = this._hyperLinkService.showing;
|
|
607
|
+
if (!o)
|
|
608
|
+
return t({
|
|
609
|
+
...n,
|
|
610
|
+
active: !1
|
|
611
|
+
});
|
|
612
|
+
const { linkId: s, unitId: c, startIndex: l, endIndex: u } = o, f = c === i && n.rangeId === s && r >= l && r <= u;
|
|
613
|
+
return t({
|
|
614
|
+
...n,
|
|
615
|
+
active: f
|
|
616
|
+
});
|
|
617
|
+
}
|
|
618
|
+
});
|
|
619
|
+
}
|
|
620
|
+
_initReRender() {
|
|
621
|
+
this.disposeWithMe(this._hyperLinkService.showingLink$.pipe(
|
|
622
|
+
sn((n, e) => (n == null ? void 0 : n.linkId) === (e == null ? void 0 : e.linkId) && (n == null ? void 0 : n.unitId) === (e == null ? void 0 : e.unitId) && (n == null ? void 0 : n.startIndex) === (e == null ? void 0 : e.startIndex)),
|
|
623
|
+
cn()
|
|
624
|
+
).subscribe(([n, e]) => {
|
|
625
|
+
e ? e.unitId === this._context.unitId && this._docRenderController.reRender(e.unitId) : n && n.unitId === this._context.unitId && this._docRenderController.reRender(n.unitId);
|
|
626
|
+
}));
|
|
627
|
+
}
|
|
628
|
+
};
|
|
629
|
+
te = Fn([
|
|
630
|
+
J(1, I(Xe)),
|
|
631
|
+
J(2, I(y)),
|
|
632
|
+
J(3, I(rn))
|
|
633
|
+
], te);
|
|
634
|
+
const De = "doc-hyper-link-icon";
|
|
635
|
+
function Ce(n) {
|
|
636
|
+
return {
|
|
637
|
+
id: b.id,
|
|
638
|
+
type: vn.BUTTON,
|
|
639
|
+
icon: De,
|
|
640
|
+
title: "docLink.menu.tooltip",
|
|
641
|
+
tooltip: "docLink.menu.tooltip",
|
|
642
|
+
hidden$: gn(n, _.UNIVER_DOC),
|
|
643
|
+
disabled$: new dn(function(e) {
|
|
644
|
+
const i = n.get(w).textSelection$.pipe(an(16)).subscribe(() => {
|
|
645
|
+
e.next(Me(n));
|
|
646
|
+
});
|
|
647
|
+
return () => {
|
|
648
|
+
i.unsubscribe();
|
|
649
|
+
};
|
|
650
|
+
})
|
|
651
|
+
};
|
|
652
|
+
}
|
|
653
|
+
const Bn = {
|
|
654
|
+
id: b.id,
|
|
655
|
+
binding: pn.CTRL_COMMAND | X.K,
|
|
656
|
+
description: "docLink.menu.tooltip",
|
|
657
|
+
preconditions: on
|
|
658
|
+
}, Vn = {
|
|
659
|
+
[mn.OTHERS]: {
|
|
660
|
+
[b.id]: {
|
|
661
|
+
order: 0,
|
|
662
|
+
menuItemFactory: Ce
|
|
663
|
+
}
|
|
664
|
+
},
|
|
665
|
+
[fn.MAIN_AREA]: {
|
|
666
|
+
[hn.DATA]: {
|
|
667
|
+
[b.id]: {
|
|
668
|
+
order: 0,
|
|
669
|
+
menuItemFactory: Ce
|
|
670
|
+
}
|
|
671
|
+
}
|
|
672
|
+
}
|
|
673
|
+
};
|
|
674
|
+
var Yn = Object.getOwnPropertyDescriptor, Zn = (n, e, t, i) => {
|
|
675
|
+
for (var r = i > 1 ? void 0 : i ? Yn(e, t) : e, o = n.length - 1, s; o >= 0; o--)
|
|
676
|
+
(s = n[o]) && (r = s(r) || r);
|
|
677
|
+
return r;
|
|
678
|
+
}, A = (n, e) => (t, i) => e(t, i, n);
|
|
679
|
+
let Y = class extends D {
|
|
680
|
+
constructor(n, e, t, i) {
|
|
681
|
+
super(), this._componentManager = n, this._commandService = e, this._menuManagerService = t, this._shortcutService = i, this._initComponents(), this._initCommands(), this._initMenus(), this._initShortcut();
|
|
682
|
+
}
|
|
683
|
+
_initComponents() {
|
|
684
|
+
[
|
|
685
|
+
[F, F.componentKey],
|
|
686
|
+
[B, B.componentKey],
|
|
687
|
+
[ie, De]
|
|
688
|
+
].forEach(([n, e]) => {
|
|
689
|
+
this._componentManager.register(e, n);
|
|
690
|
+
});
|
|
691
|
+
}
|
|
692
|
+
_initCommands() {
|
|
693
|
+
[
|
|
694
|
+
ke,
|
|
695
|
+
Le,
|
|
696
|
+
we,
|
|
697
|
+
b,
|
|
698
|
+
ee,
|
|
699
|
+
Ee
|
|
700
|
+
].forEach((n) => {
|
|
701
|
+
this._commandService.registerCommand(n);
|
|
702
|
+
});
|
|
703
|
+
}
|
|
704
|
+
_initShortcut() {
|
|
705
|
+
[Bn].forEach((n) => {
|
|
706
|
+
this._shortcutService.registerShortcut(n);
|
|
707
|
+
});
|
|
708
|
+
}
|
|
709
|
+
_initMenus() {
|
|
710
|
+
this._menuManagerService.mergeMenu(Vn);
|
|
711
|
+
}
|
|
712
|
+
};
|
|
713
|
+
Y = Zn([
|
|
714
|
+
A(0, I(In)),
|
|
715
|
+
A(1, k),
|
|
716
|
+
A(2, _n),
|
|
717
|
+
A(3, Cn)
|
|
718
|
+
], Y);
|
|
719
|
+
const zn = "DOC_HYPER_LINK_UI_PLUGIN";
|
|
720
|
+
var Wn = Object.defineProperty, Gn = Object.getOwnPropertyDescriptor, qn = (n, e, t) => e in n ? Wn(n, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : n[e] = t, Jn = (n, e, t, i) => {
|
|
721
|
+
for (var r = i > 1 ? void 0 : i ? Gn(e, t) : e, o = n.length - 1, s; o >= 0; o--)
|
|
722
|
+
(s = n[o]) && (r = s(r) || r);
|
|
723
|
+
return r;
|
|
724
|
+
}, Q = (n, e) => (t, i) => e(t, i, n), Ne = (n, e, t) => qn(n, typeof e != "symbol" ? e + "" : e, t);
|
|
725
|
+
let Z = class extends Ve {
|
|
726
|
+
constructor(n = _e, e, t, i) {
|
|
727
|
+
super(), this._config = n, this._injector = e, this._renderManagerSrv = t, this._configService = i;
|
|
728
|
+
const { menu: r, ...o } = Ye(
|
|
729
|
+
{},
|
|
730
|
+
_e,
|
|
731
|
+
this._config
|
|
732
|
+
);
|
|
733
|
+
r && this._configService.setConfig("menu", r, { merge: !0 }), this._configService.setConfig(xn, o);
|
|
734
|
+
}
|
|
735
|
+
onStarting() {
|
|
736
|
+
[
|
|
737
|
+
[y],
|
|
738
|
+
[Y],
|
|
739
|
+
[V]
|
|
740
|
+
].forEach((e) => {
|
|
741
|
+
this._injector.add(e);
|
|
742
|
+
}), this._injector.get(Y);
|
|
743
|
+
}
|
|
744
|
+
onReady() {
|
|
745
|
+
this._injector.get(V);
|
|
746
|
+
}
|
|
747
|
+
onRendered() {
|
|
748
|
+
this._initRenderModule();
|
|
749
|
+
}
|
|
750
|
+
_initRenderModule() {
|
|
751
|
+
[
|
|
752
|
+
[te],
|
|
753
|
+
[ne]
|
|
754
|
+
].forEach((n) => {
|
|
755
|
+
this._renderManagerSrv.registerRenderModule(_.UNIVER_DOC, n);
|
|
756
|
+
});
|
|
757
|
+
}
|
|
758
|
+
};
|
|
759
|
+
Ne(Z, "pluginName", zn);
|
|
760
|
+
Ne(Z, "type", _.UNIVER_DOC);
|
|
761
|
+
Z = Jn([
|
|
762
|
+
Ae(Ze),
|
|
763
|
+
Q(1, I(Fe)),
|
|
764
|
+
Q(2, ze),
|
|
765
|
+
Q(3, Be)
|
|
766
|
+
], Z);
|
|
767
|
+
export {
|
|
768
|
+
Z as UniverDocsHyperLinkUIPlugin
|
|
769
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const l = {
|
|
2
|
+
docLink: {
|
|
3
|
+
edit: {
|
|
4
|
+
confirm: "Confirm",
|
|
5
|
+
cancel: "Cancel",
|
|
6
|
+
title: "Link",
|
|
7
|
+
address: "Link",
|
|
8
|
+
placeholder: "Please input a link url",
|
|
9
|
+
addressError: "Url is illegal!",
|
|
10
|
+
label: "Label",
|
|
11
|
+
labelError: "Please input label of link"
|
|
12
|
+
},
|
|
13
|
+
info: {
|
|
14
|
+
copy: "Copy",
|
|
15
|
+
edit: "Edit",
|
|
16
|
+
cancel: "Cancel link",
|
|
17
|
+
coped: "Link copied to clipboard"
|
|
18
|
+
},
|
|
19
|
+
menu: {
|
|
20
|
+
tooltip: "Add link"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
l as default
|
|
26
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const e = {
|
|
2
|
+
docLink: {
|
|
3
|
+
edit: {
|
|
4
|
+
confirm: "تایید",
|
|
5
|
+
cancel: "انصراف",
|
|
6
|
+
title: "لینک",
|
|
7
|
+
address: "لینک",
|
|
8
|
+
placeholder: "لطفا یک آدرس لینک وارد کنید",
|
|
9
|
+
addressError: "آدرس غیرمجاز است!",
|
|
10
|
+
label: "برچسب",
|
|
11
|
+
labelError: "لطفا برچسب لینک را وارد کنید"
|
|
12
|
+
},
|
|
13
|
+
info: {
|
|
14
|
+
copy: "کپی",
|
|
15
|
+
edit: "ویرایش",
|
|
16
|
+
cancel: "لینک را لغو کنید",
|
|
17
|
+
coped: "لینک به کلیپ بورد کپی شد"
|
|
18
|
+
},
|
|
19
|
+
menu: {
|
|
20
|
+
tooltip: "افزودن لینک"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
e as default
|
|
26
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const e = {
|
|
2
|
+
docLink: {
|
|
3
|
+
edit: {
|
|
4
|
+
confirm: "Confirmer",
|
|
5
|
+
cancel: "Annuler",
|
|
6
|
+
title: "Lien",
|
|
7
|
+
address: "Link",
|
|
8
|
+
placeholder: "Veuillez entrer un lien",
|
|
9
|
+
addressError: "L'url est illégal!",
|
|
10
|
+
label: "Label",
|
|
11
|
+
labelError: "Veuillez entrer le label du lien"
|
|
12
|
+
},
|
|
13
|
+
info: {
|
|
14
|
+
copy: "Copy",
|
|
15
|
+
edit: "Edit",
|
|
16
|
+
cancel: "Cancel link",
|
|
17
|
+
coped: "Link copied to clipboard"
|
|
18
|
+
},
|
|
19
|
+
menu: {
|
|
20
|
+
tooltip: "Add link"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
e as default
|
|
26
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const e = {
|
|
2
|
+
docLink: {
|
|
3
|
+
edit: {
|
|
4
|
+
confirm: "Подтвердить",
|
|
5
|
+
cancel: "Отменить",
|
|
6
|
+
title: "Ссылка",
|
|
7
|
+
address: "Cсылки",
|
|
8
|
+
label: "Текст",
|
|
9
|
+
labelError: "Введите текст ссылки",
|
|
10
|
+
placeholder: "Пожалуйста, введите URL ссылки",
|
|
11
|
+
addressError: "URL некорректен!"
|
|
12
|
+
},
|
|
13
|
+
info: {
|
|
14
|
+
copy: "Копировать",
|
|
15
|
+
edit: "Редактировать",
|
|
16
|
+
cancel: "Отменить ссылку",
|
|
17
|
+
coped: "Link copied to clipboard"
|
|
18
|
+
},
|
|
19
|
+
menu: {
|
|
20
|
+
tooltip: "Добавить ссылку"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
e as default
|
|
26
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const n = {
|
|
2
|
+
docLink: {
|
|
3
|
+
edit: {
|
|
4
|
+
confirm: "Xác nhận",
|
|
5
|
+
cancel: "Hủy",
|
|
6
|
+
title: "Liên kết",
|
|
7
|
+
address: "Liên kết",
|
|
8
|
+
label: "Nhãn",
|
|
9
|
+
labelError: "Vui lòng nhập nhãn liên kết",
|
|
10
|
+
placeholder: "Vui lòng nhập liên kết hợp lệ",
|
|
11
|
+
addressError: "Vui lòng nhập liên kết hợp lệ"
|
|
12
|
+
},
|
|
13
|
+
info: {
|
|
14
|
+
copy: "Sao chép",
|
|
15
|
+
edit: "Chỉnh sửa",
|
|
16
|
+
cancel: "Hủy liên kết",
|
|
17
|
+
coped: "Liên kết đã được sao chép vào clipboard"
|
|
18
|
+
},
|
|
19
|
+
menu: {
|
|
20
|
+
tooltip: "Thêm liên kết"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
n as default
|
|
26
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const e = {
|
|
2
|
+
docLink: {
|
|
3
|
+
edit: {
|
|
4
|
+
confirm: "确认",
|
|
5
|
+
cancel: "取消",
|
|
6
|
+
title: "链接",
|
|
7
|
+
address: "链接",
|
|
8
|
+
label: "文本",
|
|
9
|
+
labelError: "请输入链接文本",
|
|
10
|
+
placeholder: "请输入合法的链接",
|
|
11
|
+
addressError: "请输入合法的链接"
|
|
12
|
+
},
|
|
13
|
+
info: {
|
|
14
|
+
copy: "复制",
|
|
15
|
+
edit: "编辑",
|
|
16
|
+
cancel: "取消链接",
|
|
17
|
+
coped: "链接已被复制到剪贴板"
|
|
18
|
+
},
|
|
19
|
+
menu: {
|
|
20
|
+
tooltip: "添加链接"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
e as default
|
|
26
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const e = {
|
|
2
|
+
docLink: {
|
|
3
|
+
edit: {
|
|
4
|
+
confirm: "確認",
|
|
5
|
+
cancel: "取消",
|
|
6
|
+
title: "連結",
|
|
7
|
+
address: "連結",
|
|
8
|
+
label: "文本",
|
|
9
|
+
labelError: "请输入链接文本",
|
|
10
|
+
placeholder: "請輸入合法的連結",
|
|
11
|
+
addressError: "請輸入合法的連結"
|
|
12
|
+
},
|
|
13
|
+
info: {
|
|
14
|
+
copy: "複製",
|
|
15
|
+
edit: "編輯",
|
|
16
|
+
cancel: "取消連結",
|
|
17
|
+
coped: "連結已複製到剪貼板"
|
|
18
|
+
},
|
|
19
|
+
menu: {
|
|
20
|
+
tooltip: "新增連結"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
e as default
|
|
26
|
+
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@univerjs/docs-hyper-link-ui",
|
|
3
|
-
"version": "0.6.
|
|
3
|
+
"version": "0.6.9",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "Univer thread comment plugin",
|
|
6
6
|
"author": "DreamNum <developer@univer.ai>",
|
|
@@ -48,18 +48,18 @@
|
|
|
48
48
|
"lib"
|
|
49
49
|
],
|
|
50
50
|
"peerDependencies": {
|
|
51
|
-
"react": "
|
|
51
|
+
"react": "^16.9.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc",
|
|
52
52
|
"rxjs": ">=7.0.0"
|
|
53
53
|
},
|
|
54
54
|
"dependencies": {
|
|
55
|
-
"@univerjs/icons": "^0.2.
|
|
56
|
-
"@univerjs/core": "0.6.
|
|
57
|
-
"@univerjs/docs": "0.6.
|
|
58
|
-
"@univerjs/
|
|
59
|
-
"@univerjs/
|
|
60
|
-
"@univerjs/
|
|
61
|
-
"@univerjs/
|
|
62
|
-
"@univerjs/ui": "0.6.
|
|
55
|
+
"@univerjs/icons": "^0.2.31",
|
|
56
|
+
"@univerjs/core": "0.6.9",
|
|
57
|
+
"@univerjs/docs": "0.6.9",
|
|
58
|
+
"@univerjs/docs-ui": "0.6.9",
|
|
59
|
+
"@univerjs/design": "0.6.9",
|
|
60
|
+
"@univerjs/docs-hyper-link": "0.6.9",
|
|
61
|
+
"@univerjs/engine-render": "0.6.9",
|
|
62
|
+
"@univerjs/ui": "0.6.9"
|
|
63
63
|
},
|
|
64
64
|
"devDependencies": {
|
|
65
65
|
"postcss": "^8.5.3",
|
|
@@ -69,7 +69,7 @@
|
|
|
69
69
|
"typescript": "^5.8.2",
|
|
70
70
|
"vite": "^6.2.3",
|
|
71
71
|
"vitest": "^3.0.9",
|
|
72
|
-
"@univerjs-infra/shared": "0.6.
|
|
72
|
+
"@univerjs-infra/shared": "0.6.9"
|
|
73
73
|
},
|
|
74
74
|
"scripts": {
|
|
75
75
|
"test": "vitest run",
|