@inpageedit/core 0.7.0 → 0.8.1
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/dist/{IconQuickEdit-YVn1ANbm.js → IconQuickEdit-CAL1HXIb.js} +4 -4
- package/dist/IconQuickEdit-CAL1HXIb.js.map +1 -0
- package/dist/__test__/utils/constants.d.ts +2 -2
- package/dist/index-9M1QcjCN.js +354 -0
- package/dist/index-9M1QcjCN.js.map +1 -0
- package/dist/index-Ba7Wkale.js +127 -0
- package/dist/index-Ba7Wkale.js.map +1 -0
- package/dist/{index-1JtE4urY.js → index-C8dOYIIz.js} +63 -70
- package/dist/{index-1JtE4urY.js.map → index-C8dOYIIz.js.map} +1 -1
- package/dist/index-COlXHFRg.js +6326 -0
- package/dist/index-COlXHFRg.js.map +1 -0
- package/dist/{index-B3Bsg_nE.js → index-CeXR4lOu.js} +5 -5
- package/dist/{index-B3Bsg_nE.js.map → index-CeXR4lOu.js.map} +1 -1
- package/dist/index-DBV8FBjA.js +139 -0
- package/dist/index-DBV8FBjA.js.map +1 -0
- package/dist/{index-2AEdgbUL.js → index-DwyuBkCK.js} +3 -3
- package/dist/{index-2AEdgbUL.js.map → index-DwyuBkCK.js.map} +1 -1
- package/dist/{index-BCMwmSfQ.js → index-OBerV4GU.js} +76 -73
- package/dist/index-OBerV4GU.js.map +1 -0
- package/dist/{index-C0ci6Ll1.js → index-Tn22YSmW.js} +7 -7
- package/dist/index-Tn22YSmW.js.map +1 -0
- package/dist/index-kRdAN8h3.js +193 -0
- package/dist/index-kRdAN8h3.js.map +1 -0
- package/dist/{index-CrWxZ0yl.js → index-mntCdHRr.js} +3 -3
- package/dist/{index-CrWxZ0yl.js.map → index-mntCdHRr.js.map} +1 -1
- package/dist/index.js +1 -1
- package/dist/models/WikiPage/index.d.ts +42 -47
- package/dist/models/WikiTitle/index.d.ts +3 -2
- package/dist/plugins/in-article-links/index.d.ts +4 -34
- package/dist/plugins/quick-delete/index.d.ts +8 -6
- package/dist/plugins/quick-diff/PluginQuickDiffCore.d.ts +1 -1
- package/dist/plugins/quick-edit/index.d.ts +13 -11
- package/dist/plugins/quick-move/index.d.ts +3 -1
- package/dist/plugins/quick-preview/index.d.ts +13 -16
- package/dist/plugins/quick-redirect/index.d.ts +3 -1
- package/dist/plugins/toolbox/index.d.ts +7 -2
- package/dist/services/CurrentPageService.d.ts +27 -0
- package/dist/services/{ModalService/index.d.ts → ModalService.d.ts} +4 -4
- package/dist/services/{SiteMetadataService.d.ts → WikiMetadataService.d.ts} +36 -21
- package/dist/services/WikiPageService.d.ts +8 -7
- package/dist/services/WikiTitleService.d.ts +55 -3
- package/dist/style.css +1 -1
- package/dist/types/{SiteMetadata.d.ts → WikiMetadata.d.ts} +17 -17
- package/lib/index.umd.js +34 -35
- package/lib/index.umd.js.map +1 -1
- package/lib/style.css +1 -1
- package/package.json +8 -7
- package/dist/IconQuickEdit-YVn1ANbm.js.map +0 -1
- package/dist/index-2kN4SKmT.js +0 -116
- package/dist/index-2kN4SKmT.js.map +0 -1
- package/dist/index-BCMwmSfQ.js.map +0 -1
- package/dist/index-C0ci6Ll1.js.map +0 -1
- package/dist/index-CZnu6cRK.js +0 -319
- package/dist/index-CZnu6cRK.js.map +0 -1
- package/dist/index-CheNjwas.js +0 -128
- package/dist/index-CheNjwas.js.map +0 -1
- package/dist/index-DqfQ7hp6.js +0 -5626
- package/dist/index-DqfQ7hp6.js.map +0 -1
- package/dist/index-sfkutNHj.js +0 -201
- package/dist/index-sfkutNHj.js.map +0 -1
- package/dist/services/ModalService/IPEModal.d.ts +0 -235
package/dist/index-CZnu6cRK.js
DELETED
|
@@ -1,319 +0,0 @@
|
|
|
1
|
-
import { j as i, F as k, P as q } from "./index-CvhkVj_L.js";
|
|
2
|
-
import { B as M, W as u, I as A, S as h } from "./index-DqfQ7hp6.js";
|
|
3
|
-
import { m as T } from "./makeCallable-LDU0xZMJ.js";
|
|
4
|
-
import { R as F } from "./Preferences-Bg3J5Ur9.js";
|
|
5
|
-
import { M as _ } from "./index-lZkYoUca.js";
|
|
6
|
-
import { I as B } from "./InputBox-BV4m05Xs.js";
|
|
7
|
-
import { R as O } from "./RadioBox-nJqWsxW2.js";
|
|
8
|
-
import { C as S } from "./CheckBox-D3rHnX7I.js";
|
|
9
|
-
import { n as y } from "./noop-ClDc6zv4.js";
|
|
10
|
-
const j = (t = 0) => new Promise((e) => setTimeout(e, t));
|
|
11
|
-
var D = Object.create, x = Object.defineProperty, L = Object.getOwnPropertyDescriptor, P = (t, e) => (e = Symbol[t]) ? e : Symbol.for("Symbol." + t), E = (t) => {
|
|
12
|
-
throw TypeError(t);
|
|
13
|
-
}, R = (t, e, c) => e in t ? x(t, e, { enumerable: !0, configurable: !0, writable: !0, value: c }) : t[e] = c, W = (t, e) => x(t, "name", { value: e, configurable: !0 }), z = (t) => [, , , D(t?.[P("metadata")] ?? null)], Q = ["class", "method", "getter", "setter", "accessor", "field", "value", "get", "set"], I = (t) => t !== void 0 && typeof t != "function" ? E("Function expected") : t, U = (t, e, c, l, n) => ({ kind: Q[t], name: e, metadata: l, addInitializer: (d) => c._ ? E("Already initialized") : n.push(I(d || null)) }), Y = (t, e) => R(e, P("metadata"), t[3]), G = (t, e, c, l) => {
|
|
14
|
-
for (var n = 0, d = t[e >> 1], r = d && d.length; n < r; n++) d[n].call(c);
|
|
15
|
-
return l;
|
|
16
|
-
}, H = (t, e, c, l, n, d) => {
|
|
17
|
-
var r, o, s, m = e & 7, f = !1, p = 0, a = t[p] || (t[p] = []), g = m && (n = n.prototype, m < 5 && (m > 3 || !f) && L(n, c));
|
|
18
|
-
W(n, c);
|
|
19
|
-
for (var v = l.length - 1; v >= 0; v--)
|
|
20
|
-
s = U(m, c, o = {}, t[3], a), r = (0, l[v])(n, s), o._ = 1, I(r) && (n = r);
|
|
21
|
-
return Y(t, n), g && x(n, c, g), f ? m ^ 4 ? d : g : n;
|
|
22
|
-
}, C, b, N;
|
|
23
|
-
C = [A(["api", "wikiPage", "sitemeta", "modal", "preferences"]), F(
|
|
24
|
-
h.object({
|
|
25
|
-
editSummary: h.string().description("Default edit summary for quick edits").default("[IPE-NEXT] Quick edit"),
|
|
26
|
-
editMinor: h.boolean().description("Whether to mark the edit as minor").default(!1),
|
|
27
|
-
outSideClose: h.boolean().description("Whether to close the modal outside").default(!0),
|
|
28
|
-
watchList: h.union([
|
|
29
|
-
h.const(u.preferences).description("Follow my preferences"),
|
|
30
|
-
h.const(u.nochange).description("Keep the current watchlist status"),
|
|
31
|
-
h.const(u.watch).description("Add the page to watchlist"),
|
|
32
|
-
h.const(u.unwatch).description("Remove the page from watchlist")
|
|
33
|
-
]).description("Watchlist options").default(u.preferences)
|
|
34
|
-
}).description("Quick edit options").extra("category", "edit")
|
|
35
|
-
)];
|
|
36
|
-
class w extends (N = M) {
|
|
37
|
-
constructor(e) {
|
|
38
|
-
super(e, {}, "quick-edit"), this.ctx = e, this.DEFAULT_OPTIONS = {
|
|
39
|
-
title: "",
|
|
40
|
-
pageId: 0,
|
|
41
|
-
revision: 0,
|
|
42
|
-
section: void 0,
|
|
43
|
-
editMinor: !1,
|
|
44
|
-
editSummary: "",
|
|
45
|
-
createOnly: !1,
|
|
46
|
-
reloadAfterSave: !0
|
|
47
|
-
}, this.ctx.root.set("quickEdit", T(this, "showModal"));
|
|
48
|
-
}
|
|
49
|
-
start() {
|
|
50
|
-
this.ctx.inject(["toolbox"], (e) => {
|
|
51
|
-
this.injectToolbox(e), e.on("dispose", () => {
|
|
52
|
-
this.removeToolbox(e);
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
async showModal(e) {
|
|
57
|
-
typeof e > "u" ? e = {} : typeof e == "string" && (e = {
|
|
58
|
-
title: e
|
|
59
|
-
}), e?.page && (e.title = e.page, delete e.page), !e.title && !e.pageId && !e.revision && (this.logger.warn("None of the title, pageId or revision provided. Using defaults."), e = {
|
|
60
|
-
...e,
|
|
61
|
-
title: this.ctx.sitemeta.mwConfig.get("wgPageName"),
|
|
62
|
-
pageId: this.ctx.sitemeta.mwConfig.get("wgArticleId"),
|
|
63
|
-
revision: this.ctx.sitemeta.mwConfig.get("wgRevisionId")
|
|
64
|
-
});
|
|
65
|
-
const c = await this.ctx.preferences.get("outSideClose"), l = await this.ctx.preferences.get("watchList"), n = typeof e.editSummary == "string" ? e.editSummary : await this.ctx.preferences.get("editSummary"), d = typeof e.editMinor == "boolean" ? e.editMinor : await this.ctx.preferences.get("editMinor"), r = {
|
|
66
|
-
...this.DEFAULT_OPTIONS,
|
|
67
|
-
editSummary: n,
|
|
68
|
-
editMinor: d,
|
|
69
|
-
...e
|
|
70
|
-
};
|
|
71
|
-
r.editSummary || (r.editSummary = await this.ctx.preferences.get("editSummary") || ""), r || this.ctx.emit("quick-edit/init-options", { ctx: this.ctx, options: r });
|
|
72
|
-
const o = this.ctx.modal.createObject({
|
|
73
|
-
className: "ipe-quickEdit",
|
|
74
|
-
sizeClass: "large",
|
|
75
|
-
// backdrop: false,
|
|
76
|
-
// draggable: true,
|
|
77
|
-
center: !1,
|
|
78
|
-
outSideClose: c
|
|
79
|
-
}).init();
|
|
80
|
-
o.setTitle(
|
|
81
|
-
/* @__PURE__ */ i(k, { children: [
|
|
82
|
-
"Loading: ",
|
|
83
|
-
/* @__PURE__ */ i("u", { children: r.title })
|
|
84
|
-
] })
|
|
85
|
-
), o.setContent(
|
|
86
|
-
/* @__PURE__ */ i(
|
|
87
|
-
"section",
|
|
88
|
-
{
|
|
89
|
-
className: "ipe-quickEdit-loading",
|
|
90
|
-
style: {
|
|
91
|
-
height: "70vh",
|
|
92
|
-
display: "flex",
|
|
93
|
-
flexDirection: "column",
|
|
94
|
-
justifyContent: "center",
|
|
95
|
-
alignItems: "center"
|
|
96
|
-
},
|
|
97
|
-
children: /* @__PURE__ */ i(q, {})
|
|
98
|
-
}
|
|
99
|
-
)
|
|
100
|
-
), o.addButton({
|
|
101
|
-
side: "right",
|
|
102
|
-
type: "button",
|
|
103
|
-
className: "is-danger is-ghost",
|
|
104
|
-
label: "Cancel",
|
|
105
|
-
method() {
|
|
106
|
-
o.close();
|
|
107
|
-
}
|
|
108
|
-
}), o.show(), this.ctx.emit("quick-edit/show-modal", { ctx: this.ctx, modal: o, options: r });
|
|
109
|
-
let s;
|
|
110
|
-
try {
|
|
111
|
-
if (s = await this.getWikiPageFromPayload(r), s.pageInfo.special)
|
|
112
|
-
throw new Error("Special page is not editable");
|
|
113
|
-
} catch (a) {
|
|
114
|
-
o.off(o.Event.Close), o.close(), this.ctx.modal.notify("error", {
|
|
115
|
-
content: a instanceof Error ? a.message : String(a)
|
|
116
|
-
});
|
|
117
|
-
return;
|
|
118
|
-
}
|
|
119
|
-
o.setTitle(
|
|
120
|
-
/* @__PURE__ */ i(k, { children: [
|
|
121
|
-
"Quick ",
|
|
122
|
-
s.pageInfo.pageid === 0 ? "Create" : "Edit",
|
|
123
|
-
":",
|
|
124
|
-
" ",
|
|
125
|
-
/* @__PURE__ */ i("u", { children: s.pageInfo.title })
|
|
126
|
-
] })
|
|
127
|
-
);
|
|
128
|
-
const m = [];
|
|
129
|
-
s.pageInfo.pageid === 0 && m.push(
|
|
130
|
-
/* @__PURE__ */ i(_, { title: "Attention", type: "important", children: /* @__PURE__ */ i("p", { children: "This page does not exist." }) })
|
|
131
|
-
), s.pageInfo.pageid && s.pageInfo.lastrevid !== s.revisions[0]?.revid && m.push(
|
|
132
|
-
/* @__PURE__ */ i(_, { title: "Attention", type: "warning", children: /* @__PURE__ */ i("p", { children: [
|
|
133
|
-
"You are editing a ",
|
|
134
|
-
/* @__PURE__ */ i("em", { children: "historical version" }),
|
|
135
|
-
"; the content is not the latest!"
|
|
136
|
-
] }) })
|
|
137
|
-
), this.ctx.emit("quick-edit/edit-notice", {
|
|
138
|
-
ctx: this.ctx,
|
|
139
|
-
options: r,
|
|
140
|
-
modal: o,
|
|
141
|
-
wikiPage: s,
|
|
142
|
-
editNotices: m
|
|
143
|
-
});
|
|
144
|
-
const f = /* @__PURE__ */ i("form", { className: "ipe-quickEdit__form", children: [
|
|
145
|
-
/* @__PURE__ */ i("div", { className: "ipe-quickEdit__notices", children: m }),
|
|
146
|
-
/* @__PURE__ */ i("div", { className: "ipe-quickEdit__content", children: /* @__PURE__ */ i("textarea", { className: "ipe-quickEdit__textarea", name: "text", id: "wpTextbox1", children: s.revisions[0]?.content || "" }) }),
|
|
147
|
-
/* @__PURE__ */ i(
|
|
148
|
-
"div",
|
|
149
|
-
{
|
|
150
|
-
class: "ipe-quickEdit__options",
|
|
151
|
-
style: {
|
|
152
|
-
display: "flex",
|
|
153
|
-
flexDirection: "column",
|
|
154
|
-
gap: "1rem",
|
|
155
|
-
marginTop: "1rem"
|
|
156
|
-
},
|
|
157
|
-
children: [
|
|
158
|
-
/* @__PURE__ */ i(B, { label: "Summary", id: "summary", name: "summary", value: r.editSummary }),
|
|
159
|
-
/* @__PURE__ */ i("div", { className: "ipe-input-box", children: [
|
|
160
|
-
/* @__PURE__ */ i("label", { htmlFor: "watchlist", style: { display: "block" }, children: "Watchlist" }),
|
|
161
|
-
/* @__PURE__ */ i("div", { style: { display: "flex", gap: "1rem" }, children: [
|
|
162
|
-
u.preferences,
|
|
163
|
-
u.nochange,
|
|
164
|
-
u.watch,
|
|
165
|
-
u.unwatch
|
|
166
|
-
].map((a) => /* @__PURE__ */ i(
|
|
167
|
-
O,
|
|
168
|
-
{
|
|
169
|
-
name: "watchlist",
|
|
170
|
-
value: a,
|
|
171
|
-
inputProps: { checked: l === a },
|
|
172
|
-
children: a
|
|
173
|
-
},
|
|
174
|
-
a
|
|
175
|
-
)) })
|
|
176
|
-
] }),
|
|
177
|
-
/* @__PURE__ */ i("div", { style: { display: "flex", gap: "1rem" }, children: [
|
|
178
|
-
/* @__PURE__ */ i(S, { name: "minor", id: "minor", checked: r.editMinor, children: "Minor edit" }),
|
|
179
|
-
/* @__PURE__ */ i(S, { name: "reloadAfterSave", id: "reloadAfterSave", checked: r.reloadAfterSave, children: "Reload after save" })
|
|
180
|
-
] })
|
|
181
|
-
]
|
|
182
|
-
}
|
|
183
|
-
),
|
|
184
|
-
!1
|
|
185
|
-
] });
|
|
186
|
-
o.setContent(f), o.addButton(
|
|
187
|
-
{
|
|
188
|
-
side: "left",
|
|
189
|
-
className: "is-primary submit-btn",
|
|
190
|
-
label: "Submit",
|
|
191
|
-
method: () => {
|
|
192
|
-
const a = new FormData(f);
|
|
193
|
-
o.setLoadingState(!0), this.handleSubmit({
|
|
194
|
-
wikiPage: s,
|
|
195
|
-
text: a.get("text"),
|
|
196
|
-
summary: a.get("summary"),
|
|
197
|
-
minor: a.get("minor") === "on",
|
|
198
|
-
section: r.section,
|
|
199
|
-
createonly: s.pageid === 0,
|
|
200
|
-
watchlist: l
|
|
201
|
-
}).then(async () => {
|
|
202
|
-
o.setOptions({
|
|
203
|
-
beforeClose: y
|
|
204
|
-
}), o.close(), this.ctx.modal.notify("success", {
|
|
205
|
-
title: "Submission Successful",
|
|
206
|
-
content: "Your changes have been saved."
|
|
207
|
-
}), a.get("reloadAfterSave") && (await j(500), location.reload());
|
|
208
|
-
}).catch((g) => {
|
|
209
|
-
this.ctx.modal.notify("error", {
|
|
210
|
-
title: "Submission Error",
|
|
211
|
-
content: g instanceof Error ? g.message : String(g)
|
|
212
|
-
}), o.setLoadingState(!1);
|
|
213
|
-
});
|
|
214
|
-
}
|
|
215
|
-
},
|
|
216
|
-
0
|
|
217
|
-
), o.setOptions({
|
|
218
|
-
beforeClose: () => {
|
|
219
|
-
const a = s.revisions[0]?.content || "";
|
|
220
|
-
return (f.querySelector("textarea")?.value || "") === a ? !0 : (this.ctx.modal.confirm(
|
|
221
|
-
{
|
|
222
|
-
className: "is-primary",
|
|
223
|
-
title: "Unsaved Changes",
|
|
224
|
-
content: "All edit contents will be lost after closing the modal. Are you sure you want to close?",
|
|
225
|
-
center: !0,
|
|
226
|
-
okBtn: {
|
|
227
|
-
label: "Give Up",
|
|
228
|
-
className: "is-danger is-ghost"
|
|
229
|
-
},
|
|
230
|
-
cancelBtn: {
|
|
231
|
-
label: "Continue Editing",
|
|
232
|
-
className: "is-primary is-ghost"
|
|
233
|
-
}
|
|
234
|
-
},
|
|
235
|
-
(v) => (v && (o.setOptions({
|
|
236
|
-
beforeClose: y
|
|
237
|
-
}), o.close()), !0)
|
|
238
|
-
), !1);
|
|
239
|
-
}
|
|
240
|
-
}), this.ctx.emit("quick-edit/wiki-page", {
|
|
241
|
-
ctx: this.ctx,
|
|
242
|
-
options: r,
|
|
243
|
-
modal: o,
|
|
244
|
-
wikiPage: s
|
|
245
|
-
});
|
|
246
|
-
const p = (a) => f.querySelector("textarea")?.value === s.revisions[0]?.content ? !0 : (a.preventDefault(), "You have unsaved changes. Are you sure you want to leave?");
|
|
247
|
-
window.addEventListener("beforeunload", p), o.on(o.Event.Close, () => {
|
|
248
|
-
window.removeEventListener("beforeunload", p);
|
|
249
|
-
});
|
|
250
|
-
}
|
|
251
|
-
async handleSubmit(e) {
|
|
252
|
-
const c = e.wikiPage, l = e.summary || "", n = e.text || "", d = e.minor, r = e.createonly, o = e.watchlist, s = e.section;
|
|
253
|
-
return c.edit(
|
|
254
|
-
{
|
|
255
|
-
summary: l,
|
|
256
|
-
text: n,
|
|
257
|
-
watchlist: o,
|
|
258
|
-
section: s
|
|
259
|
-
},
|
|
260
|
-
{
|
|
261
|
-
minor: d,
|
|
262
|
-
createonly: r
|
|
263
|
-
}
|
|
264
|
-
);
|
|
265
|
-
}
|
|
266
|
-
async getWikiPageFromPayload(e) {
|
|
267
|
-
if (e.revision)
|
|
268
|
-
return this.ctx.wikiPage.newFromRevision(e.revision, e.section);
|
|
269
|
-
if (e.pageId)
|
|
270
|
-
return this.ctx.wikiPage.newFromPageId(e.pageId, e.section);
|
|
271
|
-
if (e.title)
|
|
272
|
-
return this.ctx.wikiPage.newFromTitle(e.title, !1, e.section);
|
|
273
|
-
throw new Error("Invalid payload");
|
|
274
|
-
}
|
|
275
|
-
injectToolbox(e) {
|
|
276
|
-
e.toolbox.addButton({
|
|
277
|
-
id: "quick-edit",
|
|
278
|
-
group: "group1",
|
|
279
|
-
index: 0,
|
|
280
|
-
icon: /* @__PURE__ */ i(
|
|
281
|
-
"svg",
|
|
282
|
-
{
|
|
283
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
284
|
-
width: "24",
|
|
285
|
-
height: "24",
|
|
286
|
-
viewBox: "0 0 24 24",
|
|
287
|
-
fill: "none",
|
|
288
|
-
stroke: "currentColor",
|
|
289
|
-
"stroke-width": "2",
|
|
290
|
-
"stroke-linecap": "round",
|
|
291
|
-
"stroke-linejoin": "round",
|
|
292
|
-
class: "icon icon-tabler icons-tabler-outline icon-tabler-edit",
|
|
293
|
-
children: [
|
|
294
|
-
/* @__PURE__ */ i("path", { stroke: "none", d: "M0 0h24v24H0z", fill: "none" }),
|
|
295
|
-
/* @__PURE__ */ i("path", { d: "M7 7h-1a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-1" }),
|
|
296
|
-
/* @__PURE__ */ i("path", { d: "M20.385 6.585a2.1 2.1 0 0 0 -2.97 -2.97l-8.415 8.385v3h3l8.385 -8.415z" }),
|
|
297
|
-
/* @__PURE__ */ i("path", { d: "M16 5l3 3" })
|
|
298
|
-
]
|
|
299
|
-
}
|
|
300
|
-
),
|
|
301
|
-
tooltip: "Edit this page quickly",
|
|
302
|
-
onClick: () => this.showModal({
|
|
303
|
-
title: this.ctx.sitemeta.mwConfig.get("wgPageName"),
|
|
304
|
-
pageId: this.ctx.sitemeta.mwConfig.get("wgArticleId"),
|
|
305
|
-
revision: this.ctx.sitemeta.mwConfig.get("wgRevisionId")
|
|
306
|
-
})
|
|
307
|
-
});
|
|
308
|
-
}
|
|
309
|
-
removeToolbox(e) {
|
|
310
|
-
e.toolbox.removeButton("quick-edit");
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
b = z(N);
|
|
314
|
-
w = H(b, 0, "PluginQuickEdit", C, w);
|
|
315
|
-
G(b, 1, w);
|
|
316
|
-
export {
|
|
317
|
-
w as PluginQuickEdit
|
|
318
|
-
};
|
|
319
|
-
//# sourceMappingURL=index-CZnu6cRK.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-CZnu6cRK.js","sources":["../src/utils/sleep.ts","../src/plugins/quick-edit/index.tsx"],"sourcesContent":["export const sleep = (ms: number = 0) =>\n new Promise((resolve) => setTimeout(resolve, ms))\n","import { Inject, InPageEdit, Schema } from '@/InPageEdit'\nimport { WikiPage } from '@/models/WikiPage'\nimport { WatchlistAction } from '@/models/WikiPage/types/WatchlistAction'\nimport { IPEModal } from '@/services/ModalService/IPEModal'\nimport { ReactNode } from 'jsx-dom'\nimport { makeCallable } from '@/utils/makeCallable.js'\n\ndeclare module '@/InPageEdit' {\n interface InPageEdit {\n quickEdit: PluginQuickEdit & {\n (...args: Parameters<PluginQuickEdit['showModal']>): ReturnType<PluginQuickEdit['showModal']>\n }\n }\n interface Events {\n 'quick-edit/init-options'(payload: Omit<QuickEditInitPayload, 'modal' | 'wikiPage'>): void\n 'quick-edit/show-modal'(payload: Omit<QuickEditInitPayload, 'wikiPage'>): void\n 'quick-edit/wiki-page'(payload: QuickEditInitPayload): void\n 'quick-edit/edit-notice'(payload: QuickEditInitPayload & { editNotices: ReactNode[] }): void\n }\n}\n\nexport interface QuickEditOptions {\n title: string\n pageId: number\n revision: number\n /**\n * - `undefined` for full article edit\n * - `0` for the first section\n * - `\"new\"` for a new section\n */\n section: number | 'new' | undefined\n editMinor: boolean\n editSummary: string\n createOnly: boolean\n reloadAfterSave: boolean\n}\n\nexport interface QuickEditInitPayload {\n ctx: InPageEdit\n options: QuickEditOptions\n modal: IPEModal\n wikiPage: WikiPage\n}\n\nexport interface QuickEditSubmitPayload {\n wikiPage: WikiPage\n text?: string\n summary?: string\n section?: number | 'new' | undefined\n minor?: boolean\n createonly?: boolean\n watchlist?: WatchlistAction\n}\n\n@Inject(['api', 'wikiPage', 'sitemeta', 'modal', 'preferences'])\n@RegisterPreferences(\n Schema.object({\n editSummary: Schema.string()\n .description('Default edit summary for quick edits')\n .default('[IPE-NEXT] Quick edit'),\n editMinor: Schema.boolean().description('Whether to mark the edit as minor').default(false),\n outSideClose: Schema.boolean().description('Whether to close the modal outside').default(true),\n watchList: Schema.union([\n Schema.const(WatchlistAction.preferences).description('Follow my preferences'),\n Schema.const(WatchlistAction.nochange).description('Keep the current watchlist status'),\n Schema.const(WatchlistAction.watch).description('Add the page to watchlist'),\n Schema.const(WatchlistAction.unwatch).description('Remove the page from watchlist'),\n ])\n .description('Watchlist options')\n .default(WatchlistAction.preferences),\n })\n .description('Quick edit options')\n .extra('category', 'edit')\n)\nexport class PluginQuickEdit extends BasePlugin {\n private readonly DEFAULT_OPTIONS: QuickEditOptions = {\n title: '',\n pageId: 0,\n revision: 0,\n section: undefined,\n editMinor: false,\n editSummary: '',\n createOnly: false,\n reloadAfterSave: true,\n }\n\n constructor(public ctx: InPageEdit) {\n super(ctx, {}, 'quick-edit')\n this.ctx.root.set('quickEdit', makeCallable(this, 'showModal'))\n }\n\n protected start(): Promise<void> | void {\n this.ctx.inject(['toolbox'], (ctx) => {\n this.injectToolbox(ctx)\n ctx.on('dispose', () => {\n this.removeToolbox(ctx)\n })\n })\n }\n\n async showModal(payload?: string | Partial<QuickEditOptions>) {\n if (typeof payload === 'undefined') {\n payload = {}\n } else if (typeof payload === 'string') {\n payload = {\n title: payload,\n } as Partial<QuickEditOptions>\n }\n\n // @ts-expect-error legacy `page` option\n if (payload?.page) {\n // @ts-expect-error\n payload.title = payload.page\n // @ts-expect-error\n delete payload.page\n }\n\n if (!payload.title && !payload.pageId && !payload.revision) {\n this.logger.warn('None of the title, pageId or revision provided. Using defaults.')\n payload = {\n ...payload,\n title: this.ctx.sitemeta.mwConfig.get('wgPageName'),\n pageId: this.ctx.sitemeta.mwConfig.get('wgArticleId'),\n revision: this.ctx.sitemeta.mwConfig.get('wgRevisionId'),\n }\n }\n\n const outSideClose = (await this.ctx.preferences.get<boolean>('outSideClose'))!\n const watchList = (await this.ctx.preferences.get<WatchlistAction>('watchList'))!\n const editSummary =\n typeof payload.editSummary === 'string'\n ? payload.editSummary\n : (await this.ctx.preferences.get<string>('editSummary'))!\n const editMinor =\n typeof payload.editMinor === 'boolean'\n ? payload.editMinor\n : (await this.ctx.preferences.get<boolean>('editMinor'))!\n\n const options: QuickEditOptions = {\n ...this.DEFAULT_OPTIONS,\n editSummary,\n editMinor,\n ...payload,\n }\n if (!options.editSummary) {\n options.editSummary = (await this.ctx.preferences.get<string>('editSummary')) || ''\n }\n if (!options) this.ctx.emit('quick-edit/init-options', { ctx: this.ctx, options })\n\n const modal = this.ctx.modal\n .createObject({\n className: 'ipe-quickEdit',\n sizeClass: 'large',\n // backdrop: false,\n // draggable: true,\n center: false,\n outSideClose,\n })\n .init()\n modal.setTitle(\n (\n <>\n Loading: <u>{options.title}</u>\n </>\n ) as HTMLElement\n )\n modal.setContent(\n (\n <section\n className=\"ipe-quickEdit-loading\"\n style={{\n height: '70vh',\n display: 'flex',\n flexDirection: 'column',\n justifyContent: 'center',\n alignItems: 'center',\n }}\n >\n <ProgressBar />\n </section>\n ) as HTMLElement\n )\n modal.addButton({\n side: 'right',\n type: 'button',\n className: 'is-danger is-ghost',\n label: 'Cancel',\n method() {\n modal.close()\n },\n })\n modal.show()\n this.ctx.emit('quick-edit/show-modal', { ctx: this.ctx, modal, options })\n\n let wikiPage: WikiPage\n try {\n wikiPage = await this.getWikiPageFromPayload(options)\n if (wikiPage.pageInfo.special) {\n throw new Error('Special page is not editable')\n }\n } catch (e) {\n modal.off(modal.Event.Close)\n modal.close()\n this.ctx.modal.notify('error', {\n content: e instanceof Error ? e.message : String(e),\n })\n return\n }\n modal.setTitle(\n (\n <>\n Quick {wikiPage.pageInfo.pageid === 0 ? 'Create' : 'Edit'}:{' '}\n <u>{wikiPage.pageInfo.title}</u>\n </>\n ) as HTMLElement\n )\n\n const editNotices = [] as ReactNode[]\n // Page not exists\n if (wikiPage.pageInfo.pageid === 0) {\n editNotices.push(\n <MBox title=\"Attention\" type=\"important\">\n <p>This page does not exist.</p>\n </MBox>\n )\n }\n // Edit based on old revision\n if (wikiPage.pageInfo.pageid && wikiPage.pageInfo.lastrevid !== wikiPage.revisions[0]?.revid) {\n editNotices.push(\n <MBox title=\"Attention\" type=\"warning\">\n <p>\n You are editing a <em>historical version</em>; the content is not the latest!\n </p>\n </MBox>\n )\n }\n this.ctx.emit('quick-edit/edit-notice', {\n ctx: this.ctx,\n options,\n modal,\n wikiPage,\n editNotices,\n })\n\n const editForm = (\n <form className=\"ipe-quickEdit__form\">\n <div className=\"ipe-quickEdit__notices\">{editNotices}</div>\n <div className=\"ipe-quickEdit__content\">\n <textarea className=\"ipe-quickEdit__textarea\" name=\"text\" id=\"wpTextbox1\">\n {wikiPage.revisions[0]?.content || ''}\n </textarea>\n </div>\n <div\n class=\"ipe-quickEdit__options\"\n style={{\n display: 'flex',\n flexDirection: 'column',\n gap: '1rem',\n marginTop: '1rem',\n }}\n >\n <InputBox label=\"Summary\" id=\"summary\" name=\"summary\" value={options.editSummary} />\n <div className=\"ipe-input-box\">\n <label htmlFor=\"watchlist\" style={{ display: 'block' }}>\n Watchlist\n </label>\n <div style={{ display: 'flex', gap: '1rem' }}>\n {[\n WatchlistAction.preferences,\n WatchlistAction.nochange,\n WatchlistAction.watch,\n WatchlistAction.unwatch,\n ].map((action) => (\n <RadioBox\n key={action}\n name=\"watchlist\"\n value={action}\n inputProps={{ checked: watchList === action }}\n >\n {action}\n </RadioBox>\n ))}\n </div>\n </div>\n <div style={{ display: 'flex', gap: '1rem' }}>\n <CheckBox name=\"minor\" id=\"minor\" checked={options.editMinor}>\n Minor edit\n </CheckBox>\n <CheckBox name=\"reloadAfterSave\" id=\"reloadAfterSave\" checked={options.reloadAfterSave}>\n Reload after save\n </CheckBox>\n </div>\n </div>\n {/* Debug Info */}\n {import.meta.env.DEV && (\n <div className=\"debug\" style={{ marginTop: '1rem' }}>\n <details>\n <pre>{JSON.stringify(wikiPage.pageInfo, null, 2)}</pre>\n </details>\n </div>\n )}\n </form>\n ) as HTMLFormElement\n modal.setContent(editForm)\n // shamefully fix: make sure the submit button is always the first\n modal.addButton(\n {\n side: 'left',\n className: 'is-primary submit-btn',\n label: 'Submit',\n method: () => {\n const formData = new FormData(editForm)\n console.info(wikiPage, editForm, {\n text: formData.get('text') as string,\n summary: formData.get('summary') as string,\n minor: formData.get('minor') === 'on',\n })\n modal.setLoadingState(true)\n this.handleSubmit({\n wikiPage,\n text: formData.get('text') as string,\n summary: formData.get('summary') as string,\n minor: formData.get('minor') === 'on',\n section: options.section,\n createonly: wikiPage.pageid === 0,\n watchlist: watchList,\n })\n .then(async () => {\n modal.setOptions({\n beforeClose: noop,\n })\n modal.close()\n this.ctx.modal.notify('success', {\n title: 'Submission Successful',\n content: 'Your changes have been saved.',\n })\n if (formData.get('reloadAfterSave')) {\n await sleep(500)\n location.reload()\n }\n })\n .catch((error) => {\n this.ctx.modal.notify('error', {\n title: 'Submission Error',\n content: error instanceof Error ? error.message : String(error),\n })\n modal.setLoadingState(false)\n })\n },\n },\n 0\n )\n modal.setOptions({\n beforeClose: () => {\n const oldStr = wikiPage.revisions[0]?.content || ''\n const newStr = editForm.querySelector('textarea')?.value || ''\n if (newStr === oldStr) {\n return true\n } else {\n this.ctx.modal.confirm(\n {\n className: 'is-primary',\n title: 'Unsaved Changes',\n content:\n 'All edit contents will be lost after closing the modal. Are you sure you want to close?',\n center: true,\n okBtn: {\n label: 'Give Up',\n className: 'is-danger is-ghost',\n },\n cancelBtn: {\n label: 'Continue Editing',\n className: 'is-primary is-ghost',\n },\n },\n (confirmed) => {\n if (confirmed) {\n modal.setOptions({\n beforeClose: noop,\n })\n modal.close()\n }\n return true\n }\n )\n return false\n }\n },\n })\n this.ctx.emit('quick-edit/wiki-page', {\n ctx: this.ctx,\n options,\n modal,\n wikiPage,\n })\n\n const beforeUnload = (e: BeforeUnloadEvent) => {\n if (editForm.querySelector('textarea')?.value === wikiPage.revisions[0]?.content) {\n return true\n }\n e.preventDefault()\n return 'You have unsaved changes. Are you sure you want to leave?'\n }\n window.addEventListener('beforeunload', beforeUnload)\n modal.on(modal.Event.Close, () => {\n window.removeEventListener('beforeunload', beforeUnload)\n })\n }\n\n async handleSubmit(payload: QuickEditSubmitPayload) {\n const wikiPage = payload.wikiPage\n const summary = payload.summary || ''\n const text = payload.text || ''\n const minor = payload.minor\n const createonly = payload.createonly\n const watchlist = payload.watchlist\n const section = payload.section\n\n return wikiPage.edit(\n {\n summary,\n text,\n watchlist,\n section,\n },\n {\n minor,\n createonly,\n }\n )\n }\n\n async getWikiPageFromPayload(payload: Partial<QuickEditOptions>) {\n if (payload.revision) {\n return this.ctx.wikiPage.newFromRevision(payload.revision, payload.section)\n } else if (payload.pageId) {\n return this.ctx.wikiPage.newFromPageId(payload.pageId, payload.section)\n } else if (payload.title) {\n return this.ctx.wikiPage.newFromTitle(payload.title, false, payload.section)\n }\n throw new Error('Invalid payload')\n }\n\n private injectToolbox(ctx: InPageEdit) {\n ctx.toolbox.addButton({\n id: 'quick-edit',\n group: 'group1',\n index: 0,\n icon: (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class=\"icon icon-tabler icons-tabler-outline icon-tabler-edit\"\n >\n <path stroke=\"none\" d=\"M0 0h24v24H0z\" fill=\"none\" />\n <path d=\"M7 7h-1a2 2 0 0 0 -2 2v9a2 2 0 0 0 2 2h9a2 2 0 0 0 2 -2v-1\" />\n <path d=\"M20.385 6.585a2.1 2.1 0 0 0 -2.97 -2.97l-8.415 8.385v3h3l8.385 -8.415z\" />\n <path d=\"M16 5l3 3\" />\n </svg>\n ) as HTMLElement,\n tooltip: 'Edit this page quickly',\n onClick: () =>\n this.showModal({\n title: this.ctx.sitemeta.mwConfig.get('wgPageName'),\n pageId: this.ctx.sitemeta.mwConfig.get('wgArticleId'),\n revision: this.ctx.sitemeta.mwConfig.get('wgRevisionId'),\n }),\n })\n }\n\n protected removeToolbox(ctx: InPageEdit) {\n ctx.toolbox.removeButton('quick-edit')\n }\n}\n"],"names":["sleep","ms","resolve","_PluginQuickEdit_decorators","_init","_a","Inject","RegisterPreferences","Schema","WatchlistAction","PluginQuickEdit","BasePlugin","ctx","makeCallable","payload","outSideClose","watchList","editSummary","editMinor","options","modal","jsxs","Fragment","jsx","ProgressBar","wikiPage","e","editNotices","MBox","editForm","InputBox","action","RadioBox","CheckBox","formData","noop","error","oldStr","confirmed","beforeUnload","summary","text","minor","createonly","watchlist","section","__decoratorStart","__decorateElement","__runInitializers"],"mappings":"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"}
|
package/dist/index-CheNjwas.js
DELETED
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import { j as l } from "./index-CvhkVj_L.js";
|
|
2
|
-
import { b as D, I as L, S as m } from "./index-DqfQ7hp6.js";
|
|
3
|
-
import { R as T } from "./Preferences-Bg3J5Ur9.js";
|
|
4
|
-
var C = Object.create, v = Object.defineProperty, E = Object.getOwnPropertyDescriptor, y = (e, t) => (t = Symbol[e]) ? t : Symbol.for("Symbol." + e), _ = (e) => {
|
|
5
|
-
throw TypeError(e);
|
|
6
|
-
}, q = (e, t, o) => t in e ? v(e, t, { enumerable: !0, configurable: !0, writable: !0, value: o }) : e[t] = o, I = (e, t) => v(e, "name", { value: t, configurable: !0 }), $ = (e) => [, , , C(e?.[y("metadata")] ?? null)], z = ["class", "method", "getter", "setter", "accessor", "field", "value", "get", "set"], w = (e) => e !== void 0 && typeof e != "function" ? _("Function expected") : e, j = (e, t, o, n, r) => ({ kind: z[e], name: t, metadata: n, addInitializer: (i) => o._ ? _("Already initialized") : r.push(w(i || null)) }), A = (e, t) => q(t, y("metadata"), e[3]), M = (e, t, o, n) => {
|
|
7
|
-
for (var r = 0, i = e[t >> 1], a = i && i.length; r < a; r++) i[r].call(o);
|
|
8
|
-
return n;
|
|
9
|
-
}, O = (e, t, o, n, r, i) => {
|
|
10
|
-
var a, p, d, u = t & 7, s = !1, c = 0, g = e[c] || (e[c] = []), h = u && (r = r.prototype, u < 5 && (u > 3 || !s) && E(r, o));
|
|
11
|
-
I(r, o);
|
|
12
|
-
for (var b = n.length - 1; b >= 0; b--)
|
|
13
|
-
d = j(u, o, p = {}, e[3], g), a = (0, n[b])(r, d), p._ = 1, w(a) && (r = a);
|
|
14
|
-
return A(e, r), h && v(r, o, h), s ? u ^ 4 ? i : h : r;
|
|
15
|
-
}, S, f, P;
|
|
16
|
-
S = [T(
|
|
17
|
-
m.object({
|
|
18
|
-
toolboxAlwaysShow: m.boolean().description("Make the toolbox opened by default").default(!1)
|
|
19
|
-
}).description("Toolbox preferences")
|
|
20
|
-
), L(["preferences"])];
|
|
21
|
-
class x extends (P = D) {
|
|
22
|
-
constructor(t) {
|
|
23
|
-
super(t, "toolbox", !1), this.ctx = t, this.container = void 0;
|
|
24
|
-
}
|
|
25
|
-
async start() {
|
|
26
|
-
this.container = this.createToolbox(), this.ctx.preferences.get("toolboxAlwaysShow").then((t) => {
|
|
27
|
-
t && this.container.classList.add("is-persistent");
|
|
28
|
-
}), this.setupHoverLogic(), document.body.appendChild(this.container), this.updateButtonDelays();
|
|
29
|
-
}
|
|
30
|
-
stop() {
|
|
31
|
-
this.container?.remove();
|
|
32
|
-
}
|
|
33
|
-
setupHoverLogic() {
|
|
34
|
-
let t = null;
|
|
35
|
-
const o = () => this.container.classList.contains("is-persistent");
|
|
36
|
-
this.container.addEventListener("mouseenter", () => {
|
|
37
|
-
t && (clearTimeout(t), t = null), o() || this.container.classList.add("is-hovered");
|
|
38
|
-
}), this.container.addEventListener("mouseleave", () => {
|
|
39
|
-
o() || (t = window.setTimeout(() => {
|
|
40
|
-
this.container.classList.remove("is-hovered");
|
|
41
|
-
}, 150));
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
/**
|
|
45
|
-
* 计算按钮动画延迟
|
|
46
|
-
* @param index 按钮索引(从0开始)
|
|
47
|
-
* @param totalCount 总按钮数量
|
|
48
|
-
* @returns 延迟时间(秒)
|
|
49
|
-
*/
|
|
50
|
-
calculateButtonDelay(t, o) {
|
|
51
|
-
if (o <= 1) return 0;
|
|
52
|
-
const n = 0.15, r = t / (o - 1), i = n * Math.sqrt(r);
|
|
53
|
-
return Math.round(i * 1e3) / 1e3;
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* 更新按钮组的动画延迟
|
|
57
|
-
*/
|
|
58
|
-
updateButtonDelays() {
|
|
59
|
-
this.container.querySelectorAll(".btn-group").forEach((o) => {
|
|
60
|
-
const n = o.querySelectorAll(".btn-tip-group"), r = n.length;
|
|
61
|
-
n.forEach((i, a) => {
|
|
62
|
-
const p = this.calculateButtonDelay(a, r);
|
|
63
|
-
i.style.setProperty("--transition-delay", `${p}s`), i.style.setProperty("--max-transition-delay", "0.15s");
|
|
64
|
-
});
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
createToolbox() {
|
|
68
|
-
return /* @__PURE__ */ l("div", { id: "ipe-edit-toolbox", children: [
|
|
69
|
-
/* @__PURE__ */ l("ul", { className: "btn-group group1", style: { display: "flex", flexDirection: "column" } }),
|
|
70
|
-
/* @__PURE__ */ l("ul", { className: "btn-group group2", style: { display: "flex", flexDirection: "row" } }),
|
|
71
|
-
/* @__PURE__ */ l(
|
|
72
|
-
"button",
|
|
73
|
-
{
|
|
74
|
-
className: "ipe-toolbox-btn",
|
|
75
|
-
id: "toolbox-toggler",
|
|
76
|
-
onClick: () => {
|
|
77
|
-
const r = !this.container.classList.contains("is-persistent");
|
|
78
|
-
this.container.classList.toggle("is-persistent", r), this.ctx.preferences.set("toolboxAlwaysShow", r);
|
|
79
|
-
},
|
|
80
|
-
children: /* @__PURE__ */ l("svg", { xmlns: "http://www.w3.org/2000/svg", width: "448", height: "512", viewBox: "0 0 448 512", children: [
|
|
81
|
-
/* @__PURE__ */ l("rect", { width: "448", height: "512", fill: "none" }),
|
|
82
|
-
/* @__PURE__ */ l(
|
|
83
|
-
"path",
|
|
84
|
-
{
|
|
85
|
-
fill: "currentColor",
|
|
86
|
-
d: "M416 208H272V64c0-17.67-14.33-32-32-32h-32c-17.67 0-32 14.33-32 32v144H32c-17.67 0-32 14.33-32 32v32c0 17.67 14.33 32 32 32h144v144c0 17.67 14.33 32 32 32h32c17.67 0 32-14.33 32-32V304h144c17.67 0 32-14.33 32-32v-32c0-17.67-14.33-32-32-32"
|
|
87
|
-
}
|
|
88
|
-
)
|
|
89
|
-
] })
|
|
90
|
-
}
|
|
91
|
-
)
|
|
92
|
-
] });
|
|
93
|
-
}
|
|
94
|
-
normalizeButtonId(t) {
|
|
95
|
-
return t || (t = Math.random().toString(36).substring(2, 8)), `ipe-toolbox__${t.trim()}`.replace(/\s\.#/g, "-");
|
|
96
|
-
}
|
|
97
|
-
addButton(t) {
|
|
98
|
-
let { id: o, group: n, icon: r, tooltip: i, buttonProps: a, onClick: p, index: d } = t;
|
|
99
|
-
o = this.normalizeButtonId(o);
|
|
100
|
-
const u = this.container.querySelector(`#${o}`);
|
|
101
|
-
u && (this.ctx.logger("toolbox").warn(`Button with id ${o} already exists, replacing it.`), u.remove());
|
|
102
|
-
let s = null;
|
|
103
|
-
if (typeof n > "u" || n === "auto") {
|
|
104
|
-
const g = this.container.querySelector(".btn-group.group1"), h = this.container.querySelector(".btn-group.group2"), b = g?.children.length || 0, B = h?.children.length || 0;
|
|
105
|
-
s = b <= B ? g : h;
|
|
106
|
-
} else
|
|
107
|
-
s = this.container.querySelector(`.btn-group.${n}`);
|
|
108
|
-
if (!s) throw new Error(`Button group ${n} not found`);
|
|
109
|
-
const c = /* @__PURE__ */ l("li", { class: "btn-tip-group", id: o, onClick: p, children: [
|
|
110
|
-
/* @__PURE__ */ l("div", { class: "btn-tip", children: i }),
|
|
111
|
-
/* @__PURE__ */ l("button", { id: `${o}-btn`, class: "ipe-toolbox-btn", ...a, children: r })
|
|
112
|
-
] });
|
|
113
|
-
return typeof d == "number" ? d <= 0 ? s.prepend(c) : d >= s.children.length ? s.appendChild(c) : s.children[d]?.before(c) : s.appendChild(c), this.ctx.emit("toolbox/button-added", {
|
|
114
|
-
ctx: this.ctx,
|
|
115
|
-
button: c
|
|
116
|
-
}), this.updateButtonDelays(), c;
|
|
117
|
-
}
|
|
118
|
-
removeButton(t) {
|
|
119
|
-
this.container.querySelector(`.ipe-toolbox-btn#${t}`)?.remove(), this.ctx.emit("toolbox/button-removed", { ctx: this.ctx, id: t }), this.updateButtonDelays();
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
f = $(P);
|
|
123
|
-
x = O(f, 0, "PluginToolbox", S, x);
|
|
124
|
-
M(f, 1, x);
|
|
125
|
-
export {
|
|
126
|
-
x as PluginToolbox
|
|
127
|
-
};
|
|
128
|
-
//# sourceMappingURL=index-CheNjwas.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-CheNjwas.js","sources":["../src/plugins/toolbox/index.tsx"],"sourcesContent":["import { Inject, InPageEdit, Schema, Service } from '@/InPageEdit'\nimport { ReactElement } from 'jsx-dom'\nimport './styles.scss'\n\ndeclare module '@/InPageEdit' {\n interface InPageEdit {\n toolbox: PluginToolbox\n }\n interface Events {\n 'toolbox/button-added'(payload: { ctx: InPageEdit; button: HTMLElement }): void\n 'toolbox/button-removed'(payload: { ctx: InPageEdit; id: string }): void\n }\n}\n\n@RegisterPreferences(\n Schema.object({\n toolboxAlwaysShow: Schema.boolean()\n .description('Make the toolbox opened by default')\n .default(false),\n }).description('Toolbox preferences')\n)\n@Inject(['preferences'])\nexport class PluginToolbox extends Service {\n container!: HTMLElement\n\n constructor(public ctx: InPageEdit) {\n super(ctx, 'toolbox', false)\n }\n\n protected async start(): Promise<void> {\n this.container = this.createToolbox()\n this.ctx.preferences.get('toolboxAlwaysShow').then((val) => {\n if (val) {\n this.container.classList.add('is-persistent')\n }\n })\n this.setupHoverLogic()\n document.body.appendChild(this.container)\n\n // 初始化时更新按钮延迟\n this.updateButtonDelays()\n }\n\n protected stop(): void | Promise<void> {\n this.container?.remove()\n }\n\n private setupHoverLogic() {\n let hoverTimeout: number | null = null\n\n // 检查是否处于持久化状态的辅助函数\n const isPersistent = () => {\n return this.container.classList.contains('is-persistent')\n }\n\n // 鼠标进入时暂时展开\n this.container.addEventListener('mouseenter', () => {\n if (hoverTimeout) {\n clearTimeout(hoverTimeout)\n hoverTimeout = null\n }\n\n // 如果不在持久化状态,则添加hover展开效果\n if (!isPersistent()) {\n this.container.classList.add('is-hovered')\n }\n })\n\n // 鼠标离开时收起(如果不是持久化状态)\n this.container.addEventListener('mouseleave', () => {\n if (!isPersistent()) {\n hoverTimeout = window.setTimeout(() => {\n this.container.classList.remove('is-hovered')\n }, 150) // 延迟150ms收起,避免快速移动鼠标时闪烁\n }\n })\n }\n\n /**\n * 计算按钮动画延迟\n * @param index 按钮索引(从0开始)\n * @param totalCount 总按钮数量\n * @returns 延迟时间(秒)\n */\n private calculateButtonDelay(index: number, totalCount: number): number {\n if (totalCount <= 1) return 0\n\n // 总动画时长150ms = 0.15s\n const totalDuration = 0.15\n // 使用平方根函数创建非线性延迟,差值逐渐缩小\n const normalizedIndex = index / (totalCount - 1)\n const delay = totalDuration * Math.sqrt(normalizedIndex)\n\n return Math.round(delay * 1000) / 1000 // 保留3位小数\n }\n\n /**\n * 更新按钮组的动画延迟\n */\n private updateButtonDelays() {\n const btnGroups = this.container.querySelectorAll('.btn-group')\n\n btnGroups.forEach((group) => {\n const buttons = group.querySelectorAll('.btn-tip-group')\n const totalCount = buttons.length\n\n buttons.forEach((button, index) => {\n const delay = this.calculateButtonDelay(index, totalCount)\n ;(button as HTMLElement).style.setProperty('--transition-delay', `${delay}s`)\n ;(button as HTMLElement).style.setProperty('--max-transition-delay', '0.15s')\n })\n })\n }\n\n private createToolbox() {\n const toggler = (\n <button\n className=\"ipe-toolbox-btn\"\n id=\"toolbox-toggler\"\n onClick={() => {\n const isPersistent = this.container.classList.contains('is-persistent')\n const newPersistent = !isPersistent\n this.container.classList.toggle('is-persistent', newPersistent)\n this.ctx.preferences.set('toolboxAlwaysShow', newPersistent)\n }}\n >\n {/* Font Awesome 5 Solid: Plus */}\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"448\" height=\"512\" viewBox=\"0 0 448 512\">\n <rect width=\"448\" height=\"512\" fill=\"none\" />\n <path\n fill=\"currentColor\"\n d=\"M416 208H272V64c0-17.67-14.33-32-32-32h-32c-17.67 0-32 14.33-32 32v144H32c-17.67 0-32 14.33-32 32v32c0 17.67 14.33 32 32 32h144v144c0 17.67 14.33 32 32 32h32c17.67 0 32-14.33 32-32V304h144c17.67 0 32-14.33 32-32v-32c0-17.67-14.33-32-32-32\"\n />\n </svg>\n </button>\n )\n const element = (\n <div id=\"ipe-edit-toolbox\">\n <ul className=\"btn-group group1\" style={{ display: 'flex', flexDirection: 'column' }}></ul>\n <ul className=\"btn-group group2\" style={{ display: 'flex', flexDirection: 'row' }}></ul>\n {toggler}\n </div>\n )\n\n return element as HTMLElement\n }\n\n private normalizeButtonId(id: string) {\n if (!id) {\n id = Math.random().toString(36).substring(2, 8)\n }\n return `ipe-toolbox__${id.trim()}`.replace(/\\s\\.#/g, '-')\n }\n\n addButton(payload: {\n id: string\n group?: 'auto' | 'group1' | 'group2'\n icon: string | HTMLElement | SVGElement | ReactElement\n tooltip?: string | HTMLElement\n buttonProps?: Record<string, any>\n onClick?: (event: MouseEvent) => void\n index?: number\n }) {\n let { id, group, icon, tooltip, buttonProps, onClick, index } = payload\n id = this.normalizeButtonId(id)\n\n const existingButton = this.container.querySelector(`#${id}`)\n if (existingButton) {\n this.ctx.logger('toolbox').warn(`Button with id ${id} already exists, replacing it.`)\n existingButton.remove()\n }\n\n let groupEl: HTMLElement | null = null\n if (typeof group === 'undefined' || group === 'auto') {\n // 选择按钮最少的那一组,一样多就选第一组\n const group1 = this.container.querySelector('.btn-group.group1') as HTMLElement\n const group2 = this.container.querySelector('.btn-group.group2') as HTMLElement\n const group1Count = group1?.children.length || 0\n const group2Count = group2?.children.length || 0\n groupEl = group1Count <= group2Count ? group1 : group2\n } else {\n groupEl = this.container.querySelector(`.btn-group.${group}`)\n }\n if (!groupEl) throw new Error(`Button group ${group} not found`)\n\n const button = (\n <li class=\"btn-tip-group\" id={id} onClick={onClick}>\n <div class=\"btn-tip\">{tooltip}</div>\n <button id={`${id}-btn`} class=\"ipe-toolbox-btn\" {...buttonProps}>\n {icon}\n </button>\n </li>\n )\n\n if (typeof index === 'number') {\n if (index <= 0) {\n groupEl.prepend(button)\n } else if (index >= groupEl.children.length) {\n groupEl.appendChild(button)\n } else {\n groupEl.children[index]?.before(button)\n }\n } else {\n groupEl.appendChild(button)\n }\n\n this.ctx.emit('toolbox/button-added', {\n ctx: this.ctx,\n button: button as HTMLElement,\n })\n\n // 更新按钮延迟\n this.updateButtonDelays()\n\n return button as HTMLElement\n }\n\n removeButton(id: string) {\n const button = this.container.querySelector(`.ipe-toolbox-btn#${id}`)\n button?.remove()\n this.ctx.emit('toolbox/button-removed', { ctx: this.ctx, id })\n\n // 更新按钮延迟\n this.updateButtonDelays()\n }\n}\n"],"names":["_PluginToolbox_decorators","_init","_a","RegisterPreferences","Schema","Inject","PluginToolbox","Service","ctx","val","hoverTimeout","isPersistent","index","totalCount","totalDuration","normalizedIndex","delay","group","buttons","button","jsxs","jsx","newPersistent","id","payload","icon","tooltip","buttonProps","onClick","existingButton","groupEl","group1","group2","group1Count","group2Count","__decoratorStart","__decorateElement","__runInitializers"],"mappings":"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"}
|