@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.
Files changed (61) hide show
  1. package/dist/{IconQuickEdit-YVn1ANbm.js → IconQuickEdit-CAL1HXIb.js} +4 -4
  2. package/dist/IconQuickEdit-CAL1HXIb.js.map +1 -0
  3. package/dist/__test__/utils/constants.d.ts +2 -2
  4. package/dist/index-9M1QcjCN.js +354 -0
  5. package/dist/index-9M1QcjCN.js.map +1 -0
  6. package/dist/index-Ba7Wkale.js +127 -0
  7. package/dist/index-Ba7Wkale.js.map +1 -0
  8. package/dist/{index-1JtE4urY.js → index-C8dOYIIz.js} +63 -70
  9. package/dist/{index-1JtE4urY.js.map → index-C8dOYIIz.js.map} +1 -1
  10. package/dist/index-COlXHFRg.js +6326 -0
  11. package/dist/index-COlXHFRg.js.map +1 -0
  12. package/dist/{index-B3Bsg_nE.js → index-CeXR4lOu.js} +5 -5
  13. package/dist/{index-B3Bsg_nE.js.map → index-CeXR4lOu.js.map} +1 -1
  14. package/dist/index-DBV8FBjA.js +139 -0
  15. package/dist/index-DBV8FBjA.js.map +1 -0
  16. package/dist/{index-2AEdgbUL.js → index-DwyuBkCK.js} +3 -3
  17. package/dist/{index-2AEdgbUL.js.map → index-DwyuBkCK.js.map} +1 -1
  18. package/dist/{index-BCMwmSfQ.js → index-OBerV4GU.js} +76 -73
  19. package/dist/index-OBerV4GU.js.map +1 -0
  20. package/dist/{index-C0ci6Ll1.js → index-Tn22YSmW.js} +7 -7
  21. package/dist/index-Tn22YSmW.js.map +1 -0
  22. package/dist/index-kRdAN8h3.js +193 -0
  23. package/dist/index-kRdAN8h3.js.map +1 -0
  24. package/dist/{index-CrWxZ0yl.js → index-mntCdHRr.js} +3 -3
  25. package/dist/{index-CrWxZ0yl.js.map → index-mntCdHRr.js.map} +1 -1
  26. package/dist/index.js +1 -1
  27. package/dist/models/WikiPage/index.d.ts +42 -47
  28. package/dist/models/WikiTitle/index.d.ts +3 -2
  29. package/dist/plugins/in-article-links/index.d.ts +4 -34
  30. package/dist/plugins/quick-delete/index.d.ts +8 -6
  31. package/dist/plugins/quick-diff/PluginQuickDiffCore.d.ts +1 -1
  32. package/dist/plugins/quick-edit/index.d.ts +13 -11
  33. package/dist/plugins/quick-move/index.d.ts +3 -1
  34. package/dist/plugins/quick-preview/index.d.ts +13 -16
  35. package/dist/plugins/quick-redirect/index.d.ts +3 -1
  36. package/dist/plugins/toolbox/index.d.ts +7 -2
  37. package/dist/services/CurrentPageService.d.ts +27 -0
  38. package/dist/services/{ModalService/index.d.ts → ModalService.d.ts} +4 -4
  39. package/dist/services/{SiteMetadataService.d.ts → WikiMetadataService.d.ts} +36 -21
  40. package/dist/services/WikiPageService.d.ts +8 -7
  41. package/dist/services/WikiTitleService.d.ts +55 -3
  42. package/dist/style.css +1 -1
  43. package/dist/types/{SiteMetadata.d.ts → WikiMetadata.d.ts} +17 -17
  44. package/lib/index.umd.js +34 -35
  45. package/lib/index.umd.js.map +1 -1
  46. package/lib/style.css +1 -1
  47. package/package.json +8 -7
  48. package/dist/IconQuickEdit-YVn1ANbm.js.map +0 -1
  49. package/dist/index-2kN4SKmT.js +0 -116
  50. package/dist/index-2kN4SKmT.js.map +0 -1
  51. package/dist/index-BCMwmSfQ.js.map +0 -1
  52. package/dist/index-C0ci6Ll1.js.map +0 -1
  53. package/dist/index-CZnu6cRK.js +0 -319
  54. package/dist/index-CZnu6cRK.js.map +0 -1
  55. package/dist/index-CheNjwas.js +0 -128
  56. package/dist/index-CheNjwas.js.map +0 -1
  57. package/dist/index-DqfQ7hp6.js +0 -5626
  58. package/dist/index-DqfQ7hp6.js.map +0 -1
  59. package/dist/index-sfkutNHj.js +0 -201
  60. package/dist/index-sfkutNHj.js.map +0 -1
  61. package/dist/services/ModalService/IPEModal.d.ts +0 -235
@@ -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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"}
@@ -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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"}