@quoreadmin/ui 1.10.27 → 1.10.29

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 (197) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/index103.js +11 -6
  3. package/dist/index147.js +2 -2
  4. package/dist/index149.js +1 -1
  5. package/dist/index151.js +4 -4
  6. package/dist/index157.js +160 -160
  7. package/dist/index165.js +1 -1
  8. package/dist/index169.js +7 -7
  9. package/dist/index197.js +1228 -36
  10. package/dist/index199.js +5816 -1106
  11. package/dist/index200.js +209 -0
  12. package/dist/index201.js +19 -5922
  13. package/dist/index202.js +10 -199
  14. package/dist/index203.js +76 -33
  15. package/dist/index204.js +249 -14
  16. package/dist/index205.js +13678 -72
  17. package/dist/index206.js +27 -253
  18. package/dist/index207.js +48 -13669
  19. package/dist/index208.js +236 -25
  20. package/dist/index209.js +293 -45
  21. package/dist/index210.js +238 -179
  22. package/dist/index211.js +36 -311
  23. package/dist/index212.js +43 -296
  24. package/dist/index216.js +2 -2
  25. package/dist/index217.js +1 -1
  26. package/dist/index219.js +4 -4
  27. package/dist/index221.js +1 -1
  28. package/dist/index222.js +1 -1
  29. package/dist/index223.js +1 -1
  30. package/dist/index224.js +4 -4
  31. package/dist/index226.js +1 -1
  32. package/dist/index227.js +2 -2
  33. package/dist/index228.js +2 -2
  34. package/dist/index229.js +1 -1
  35. package/dist/index23.js +47 -27
  36. package/dist/index230.js +1 -1
  37. package/dist/index231.js +1 -1
  38. package/dist/index232.js +1 -1
  39. package/dist/index233.js +1 -1
  40. package/dist/index234.js +4 -4
  41. package/dist/index235.js +1 -1
  42. package/dist/index236.js +1 -1
  43. package/dist/index237.js +1 -1
  44. package/dist/index238.js +1 -1
  45. package/dist/index240.js +1 -1
  46. package/dist/index241.js +1 -1
  47. package/dist/index242.js +1 -1
  48. package/dist/index243.js +1 -1
  49. package/dist/index244.js +1 -1
  50. package/dist/index249.js +1 -1
  51. package/dist/index250.js +1 -1
  52. package/dist/index251.js +1 -1
  53. package/dist/index252.js +6 -6
  54. package/dist/index253.js +1 -1
  55. package/dist/index254.js +1 -1
  56. package/dist/index255.js +1 -1
  57. package/dist/index256.js +1 -1
  58. package/dist/index257.js +1 -1
  59. package/dist/index259.js +1 -1
  60. package/dist/index260.js +1 -1
  61. package/dist/index261.js +3 -3
  62. package/dist/index262.js +1 -1
  63. package/dist/index263.js +1 -1
  64. package/dist/index264.js +1 -1
  65. package/dist/index265.js +1 -1
  66. package/dist/index266.js +1 -1
  67. package/dist/index267.js +1 -1
  68. package/dist/index270.js +3673 -217
  69. package/dist/index271.js +59 -7
  70. package/dist/index272.js +78 -133
  71. package/dist/index273.js +51 -82
  72. package/dist/index274.js +213 -52
  73. package/dist/index275.js +10 -79
  74. package/dist/index276.js +57 -26
  75. package/dist/index277.js +61 -22
  76. package/dist/index278.js +54 -22
  77. package/dist/index279.js +79 -14
  78. package/dist/index280.js +727 -16
  79. package/dist/index281.js +45 -21
  80. package/dist/index282.js +64 -3
  81. package/dist/index283.js +11 -27
  82. package/dist/index284.js +637 -3641
  83. package/dist/index285.js +819 -59
  84. package/dist/index286.js +242 -72
  85. package/dist/index287.js +7 -51
  86. package/dist/index288.js +132 -209
  87. package/dist/index289.js +83 -10
  88. package/dist/index290.js +51 -54
  89. package/dist/index291.js +77 -59
  90. package/dist/index292.js +26 -54
  91. package/dist/index293.js +22 -81
  92. package/dist/index294.js +21 -727
  93. package/dist/index295.js +14 -45
  94. package/dist/index296.js +15 -62
  95. package/dist/index297.js +22 -10
  96. package/dist/index298.js +3 -705
  97. package/dist/index299.js +21 -814
  98. package/dist/index301.js +1534 -79
  99. package/dist/index302.js +386 -22
  100. package/dist/index303.js +2698 -902
  101. package/dist/index304.js +85 -21
  102. package/dist/index305.js +3798 -20
  103. package/dist/index306.js +59 -19
  104. package/dist/index307.js +77 -67
  105. package/dist/index308.js +21 -18
  106. package/dist/index309.js +934 -18
  107. package/dist/index310.js +16 -16
  108. package/dist/index311.js +11 -13
  109. package/dist/index312.js +19 -62
  110. package/dist/index313.js +67 -263
  111. package/dist/index314.js +19 -6
  112. package/dist/index315.js +18 -149
  113. package/dist/index316.js +21 -68
  114. package/dist/index317.js +20 -89
  115. package/dist/index318.js +63 -29
  116. package/dist/index319.js +15 -16
  117. package/dist/index320.js +74 -65
  118. package/dist/index321.js +201 -3
  119. package/dist/index322.js +246 -2
  120. package/dist/index323.js +227 -76
  121. package/dist/index324.js +5 -57
  122. package/dist/index325.js +133 -5
  123. package/dist/index326.js +67 -4
  124. package/dist/index327.js +79 -178
  125. package/dist/index328.js +26 -60
  126. package/dist/index329.js +8 -74
  127. package/dist/index330.js +73 -35
  128. package/dist/index331.js +3 -8
  129. package/dist/index332.js +2 -13
  130. package/dist/index333.js +78 -50
  131. package/dist/index334.js +53 -11
  132. package/dist/index335.js +4 -12
  133. package/dist/index336.js +4 -57
  134. package/dist/index337.js +175 -48
  135. package/dist/index338.js +60 -28
  136. package/dist/index339.js +75 -2
  137. package/dist/index340.js +37 -5
  138. package/dist/index341.js +9 -2
  139. package/dist/index342.js +13 -23
  140. package/dist/index343.js +52 -38
  141. package/dist/index344.js +12 -2
  142. package/dist/index345.js +14 -11
  143. package/dist/index346.js +54 -16
  144. package/dist/index347.js +52 -10
  145. package/dist/index348.js +31 -10
  146. package/dist/index349.js +2 -17
  147. package/dist/index350.js +5 -2
  148. package/dist/index351.js +2 -9
  149. package/dist/index352.js +23 -10
  150. package/dist/index353.js +39 -12
  151. package/dist/index354.js +2 -1534
  152. package/dist/index355.js +9 -384
  153. package/dist/index356.js +16 -2727
  154. package/dist/index357.js +10 -86
  155. package/dist/index358.js +9 -3797
  156. package/dist/index359.js +15 -58
  157. package/dist/index360.js +2 -15
  158. package/dist/index361.js +9 -84
  159. package/dist/index362.js +9 -201
  160. package/dist/index363.js +13 -245
  161. package/dist/index364.js +1 -1
  162. package/dist/index365.js +1 -1
  163. package/dist/index367.js +1 -1
  164. package/dist/index368.js +14 -12
  165. package/dist/index369.js +1 -2
  166. package/dist/index370.js +22 -18
  167. package/dist/index371.js +2 -2
  168. package/dist/index372.js +3 -6
  169. package/dist/index373.js +3 -4
  170. package/dist/index374.js +2 -2
  171. package/dist/index375.js +2 -2
  172. package/dist/index376.js +1 -1
  173. package/dist/index378.js +20 -32
  174. package/dist/index379.js +45 -58
  175. package/dist/index380.js +1 -1
  176. package/dist/index381.js +98 -28
  177. package/dist/index382.js +90 -10
  178. package/dist/index383.js +98 -4
  179. package/dist/index384.js +30 -3
  180. package/dist/index385.js +11 -13
  181. package/dist/index386.js +4 -7
  182. package/dist/index387.js +3 -13
  183. package/dist/index388.js +13 -5
  184. package/dist/index389.js +7 -36
  185. package/dist/index390.js +11 -36
  186. package/dist/index391.js +5 -30
  187. package/dist/index392.js +33 -64
  188. package/dist/index393.js +29 -99
  189. package/dist/index394.js +28 -91
  190. package/dist/index395.js +59 -96
  191. package/dist/index396.js +1 -1
  192. package/dist/index402.js +1 -1
  193. package/dist/index50.js +1 -1
  194. package/dist/src/components/event/event.d.ts +12 -0
  195. package/dist/src/components/event/event.stories.d.ts +2 -0
  196. package/package.json +2 -2
  197. package/dist/index198.js +0 -46
package/dist/index210.js CHANGED
@@ -1,240 +1,299 @@
1
- import { Mark as y, mergeAttributes as p, Extension as l } from "./index284.js";
2
- var d = 20, u = (t, e = 0) => {
3
- const r = [];
4
- return !t.children.length || e > d || Array.from(t.children).forEach((o) => {
5
- o.tagName === "SPAN" ? r.push(o) : o.children.length && r.push(...u(o, e + 1));
6
- }), r;
7
- }, f = (t) => {
8
- if (!t.children.length)
9
- return;
10
- const e = u(t);
11
- e && e.forEach((r) => {
12
- var o, n;
13
- const s = r.getAttribute("style"), i = (n = (o = r.parentElement) == null ? void 0 : o.closest("span")) == null ? void 0 : n.getAttribute("style");
14
- r.setAttribute("style", `${i};${s}`);
15
- });
16
- }, c = y.create({
17
- name: "textStyle",
18
- priority: 101,
1
+ import { Extension as l, isNodeEmpty as v, callOrReturn as P, getExtensionField as S, isNodeSelection as z } from "./index270.js";
2
+ import { Plugin as p, PluginKey as m } from "./index285.js";
3
+ import { dropCursor as E } from "./index320.js";
4
+ import { Decoration as y, DecorationSet as f } from "./index305.js";
5
+ import { gapCursor as N } from "./index321.js";
6
+ import { history as A, redo as M, undo as T } from "./index322.js";
7
+ l.create({
8
+ name: "characterCount",
19
9
  addOptions() {
20
10
  return {
21
- HTMLAttributes: {},
22
- mergeNestedSpanStyles: !0
11
+ limit: null,
12
+ mode: "textSize",
13
+ textCounter: (e) => e.length,
14
+ wordCounter: (e) => e.split(" ").filter((t) => t !== "").length
23
15
  };
24
16
  },
25
- parseHTML() {
26
- return [
27
- {
28
- tag: "span",
29
- consuming: !1,
30
- getAttrs: (t) => t.hasAttribute("style") ? (this.options.mergeNestedSpanStyles && f(t), {}) : !1
31
- }
32
- ];
33
- },
34
- renderHTML({ HTMLAttributes: t }) {
35
- return ["span", p(this.options.HTMLAttributes, t), 0];
36
- },
37
- addCommands() {
17
+ addStorage() {
38
18
  return {
39
- toggleTextStyle: (t) => ({ commands: e }) => e.toggleMark(this.name, t),
40
- removeEmptyTextStyle: () => ({ tr: t }) => {
41
- const { selection: e } = t;
42
- return t.doc.nodesBetween(e.from, e.to, (r, o) => {
43
- if (r.isTextblock)
44
- return !0;
45
- r.marks.filter((n) => n.type === this.type).some((n) => Object.values(n.attrs).some((s) => !!s)) || t.removeMark(o, o + r.nodeSize, this.type);
46
- }), !0;
47
- }
19
+ characters: () => 0,
20
+ words: () => 0
48
21
  };
49
- }
50
- }), m = l.create({
51
- name: "backgroundColor",
52
- addOptions() {
53
- return {
54
- types: ["textStyle"]
22
+ },
23
+ onBeforeCreate() {
24
+ this.storage.characters = (e) => {
25
+ const t = e?.node || this.editor.state.doc;
26
+ if ((e?.mode || this.options.mode) === "textSize") {
27
+ const r = t.textBetween(0, t.content.size, void 0, " ");
28
+ return this.options.textCounter(r);
29
+ }
30
+ return t.nodeSize;
31
+ }, this.storage.words = (e) => {
32
+ const t = e?.node || this.editor.state.doc, s = t.textBetween(0, t.content.size, " ", " ");
33
+ return this.options.wordCounter(s);
55
34
  };
56
35
  },
57
- addGlobalAttributes() {
36
+ addProseMirrorPlugins() {
37
+ let e = !1;
58
38
  return [
59
- {
60
- types: this.options.types,
61
- attributes: {
62
- backgroundColor: {
63
- default: null,
64
- parseHTML: (t) => {
65
- var e;
66
- const r = t.getAttribute("style");
67
- if (r) {
68
- const o = r.split(";").map((n) => n.trim()).filter(Boolean);
69
- for (let n = o.length - 1; n >= 0; n -= 1) {
70
- const s = o[n].split(":");
71
- if (s.length >= 2) {
72
- const i = s[0].trim().toLowerCase(), a = s.slice(1).join(":").trim();
73
- if (i === "background-color")
74
- return a.replace(/['"]+/g, "");
75
- }
76
- }
77
- }
78
- return (e = t.style.backgroundColor) == null ? void 0 : e.replace(/['"]+/g, "");
79
- },
80
- renderHTML: (t) => t.backgroundColor ? {
81
- style: `background-color: ${t.backgroundColor}`
82
- } : {}
39
+ new p({
40
+ key: new m("characterCount"),
41
+ appendTransaction: (t, s, r) => {
42
+ if (e)
43
+ return;
44
+ const o = this.options.limit;
45
+ if (o == null || o === 0) {
46
+ e = !0;
47
+ return;
83
48
  }
49
+ const n = this.storage.characters({ node: r.doc });
50
+ if (n > o) {
51
+ const c = n - o, a = 0, i = c;
52
+ console.warn(
53
+ `[CharacterCount] Initial content exceeded limit of ${o} characters. Content was automatically trimmed.`
54
+ );
55
+ const d = r.tr.deleteRange(a, i);
56
+ return e = !0, d;
57
+ }
58
+ e = !0;
59
+ },
60
+ filterTransaction: (t, s) => {
61
+ const r = this.options.limit;
62
+ if (!t.docChanged || r === 0 || r === null || r === void 0)
63
+ return !0;
64
+ const o = this.storage.characters({ node: s.doc }), n = this.storage.characters({ node: t.doc });
65
+ if (n <= r || o > r && n > r && n <= o)
66
+ return !0;
67
+ if (o > r && n > r && n > o || !t.getMeta("paste"))
68
+ return !1;
69
+ const a = t.selection.$head.pos, i = n - r, d = a - i, u = a;
70
+ return t.deleteRange(d, u), !(this.storage.characters({ node: t.doc }) > r);
84
71
  }
85
- }
72
+ })
86
73
  ];
87
- },
88
- addCommands() {
74
+ }
75
+ });
76
+ var R = l.create({
77
+ name: "dropCursor",
78
+ addOptions() {
89
79
  return {
90
- setBackgroundColor: (t) => ({ chain: e }) => e().setMark("textStyle", { backgroundColor: t }).run(),
91
- unsetBackgroundColor: () => ({ chain: t }) => t().setMark("textStyle", { backgroundColor: null }).removeEmptyTextStyle().run()
80
+ color: "currentColor",
81
+ width: 1,
82
+ class: void 0
92
83
  };
84
+ },
85
+ addProseMirrorPlugins() {
86
+ return [E(this.options)];
93
87
  }
94
- }), g = l.create({
95
- name: "color",
88
+ });
89
+ l.create({
90
+ name: "focus",
96
91
  addOptions() {
97
92
  return {
98
- types: ["textStyle"]
93
+ className: "has-focus",
94
+ mode: "all"
99
95
  };
100
96
  },
101
- addGlobalAttributes() {
97
+ addProseMirrorPlugins() {
102
98
  return [
103
- {
104
- types: this.options.types,
105
- attributes: {
106
- color: {
107
- default: null,
108
- parseHTML: (t) => {
109
- var e;
110
- const r = t.getAttribute("style");
111
- if (r) {
112
- const o = r.split(";").map((n) => n.trim()).filter(Boolean);
113
- for (let n = o.length - 1; n >= 0; n -= 1) {
114
- const s = o[n].split(":");
115
- if (s.length >= 2) {
116
- const i = s[0].trim().toLowerCase(), a = s.slice(1).join(":").trim();
117
- if (i === "color")
118
- return a.replace(/['"]+/g, "");
119
- }
120
- }
121
- }
122
- return (e = t.style.color) == null ? void 0 : e.replace(/['"]+/g, "");
123
- },
124
- renderHTML: (t) => t.color ? {
125
- style: `color: ${t.color}`
126
- } : {}
99
+ new p({
100
+ key: new m("focus"),
101
+ props: {
102
+ decorations: ({ doc: e, selection: t }) => {
103
+ const { isEditable: s, isFocused: r } = this.editor, { anchor: o } = t, n = [];
104
+ if (!s || !r)
105
+ return f.create(e, []);
106
+ let c = 0;
107
+ this.options.mode === "deepest" && e.descendants((i, d) => {
108
+ if (i.isText)
109
+ return;
110
+ if (!(o >= d && o <= d + i.nodeSize - 1))
111
+ return !1;
112
+ c += 1;
113
+ });
114
+ let a = 0;
115
+ return e.descendants((i, d) => {
116
+ if (i.isText || !(o >= d && o <= d + i.nodeSize - 1))
117
+ return !1;
118
+ if (a += 1, this.options.mode === "deepest" && c - a > 0 || this.options.mode === "shallowest" && a > 1)
119
+ return this.options.mode === "deepest";
120
+ n.push(
121
+ y.node(d, d + i.nodeSize, {
122
+ class: this.options.className
123
+ })
124
+ );
125
+ }), f.create(e, n);
127
126
  }
128
127
  }
129
- }
128
+ })
130
129
  ];
130
+ }
131
+ });
132
+ var L = l.create({
133
+ name: "gapCursor",
134
+ addProseMirrorPlugins() {
135
+ return [N()];
131
136
  },
132
- addCommands() {
137
+ extendNodeSchema(e) {
138
+ var t;
139
+ const s = {
140
+ name: e.name,
141
+ options: e.options,
142
+ storage: e.storage
143
+ };
133
144
  return {
134
- setColor: (t) => ({ chain: e }) => e().setMark("textStyle", { color: t }).run(),
135
- unsetColor: () => ({ chain: t }) => t().setMark("textStyle", { color: null }).removeEmptyTextStyle().run()
145
+ allowGapCursor: (t = P(S(e, "allowGapCursor", s))) != null ? t : null
136
146
  };
137
147
  }
138
- }), h = l.create({
139
- name: "fontFamily",
148
+ }), C = "placeholder";
149
+ function x(e) {
150
+ return e.replace(/\s+/g, "-").replace(/[^a-zA-Z0-9-]/g, "").replace(/^[0-9-]+/, "").replace(/^-+/, "").toLowerCase();
151
+ }
152
+ var B = l.create({
153
+ name: "placeholder",
140
154
  addOptions() {
141
155
  return {
142
- types: ["textStyle"]
156
+ emptyEditorClass: "is-editor-empty",
157
+ emptyNodeClass: "is-empty",
158
+ dataAttribute: C,
159
+ placeholder: "Write something …",
160
+ showOnlyWhenEditable: !0,
161
+ showOnlyCurrent: !0,
162
+ includeChildren: !1
143
163
  };
144
164
  },
145
- addGlobalAttributes() {
165
+ addProseMirrorPlugins() {
166
+ const e = this.options.dataAttribute ? `data-${x(this.options.dataAttribute)}` : `data-${C}`;
146
167
  return [
147
- {
148
- types: this.options.types,
149
- attributes: {
150
- fontFamily: {
151
- default: null,
152
- parseHTML: (t) => t.style.fontFamily,
153
- renderHTML: (t) => t.fontFamily ? {
154
- style: `font-family: ${t.fontFamily}`
155
- } : {}
168
+ new p({
169
+ key: new m("placeholder"),
170
+ props: {
171
+ decorations: ({ doc: t, selection: s }) => {
172
+ const r = this.editor.isEditable || !this.options.showOnlyWhenEditable, { anchor: o } = s, n = [];
173
+ if (!r)
174
+ return null;
175
+ const c = this.editor.isEmpty;
176
+ return t.descendants((a, i) => {
177
+ const d = o >= i && o <= i + a.nodeSize, u = !a.isLeaf && v(a);
178
+ if (!a.type.isTextblock)
179
+ return this.options.includeChildren;
180
+ if ((d || !this.options.showOnlyCurrent) && u) {
181
+ const h = [this.options.emptyNodeClass];
182
+ c && h.push(this.options.emptyEditorClass);
183
+ const g = y.node(i, i + a.nodeSize, {
184
+ class: h.join(" "),
185
+ [e]: typeof this.options.placeholder == "function" ? this.options.placeholder({
186
+ editor: this.editor,
187
+ node: a,
188
+ pos: i,
189
+ hasAnchor: d
190
+ }) : this.options.placeholder
191
+ });
192
+ n.push(g);
193
+ }
194
+ return this.options.includeChildren;
195
+ }), f.create(t, n);
156
196
  }
157
197
  }
158
- }
198
+ })
159
199
  ];
160
- },
161
- addCommands() {
162
- return {
163
- setFontFamily: (t) => ({ chain: e }) => e().setMark("textStyle", { fontFamily: t }).run(),
164
- unsetFontFamily: () => ({ chain: t }) => t().setMark("textStyle", { fontFamily: null }).removeEmptyTextStyle().run()
165
- };
166
200
  }
167
- }), S = l.create({
168
- name: "fontSize",
201
+ });
202
+ l.create({
203
+ name: "selection",
169
204
  addOptions() {
170
205
  return {
171
- types: ["textStyle"]
206
+ className: "selection"
172
207
  };
173
208
  },
174
- addGlobalAttributes() {
209
+ addProseMirrorPlugins() {
210
+ const { editor: e, options: t } = this;
175
211
  return [
176
- {
177
- types: this.options.types,
178
- attributes: {
179
- fontSize: {
180
- default: null,
181
- parseHTML: (t) => t.style.fontSize,
182
- renderHTML: (t) => t.fontSize ? {
183
- style: `font-size: ${t.fontSize}`
184
- } : {}
212
+ new p({
213
+ key: new m("selection"),
214
+ props: {
215
+ decorations(s) {
216
+ return s.selection.empty || e.isFocused || !e.isEditable || z(s.selection) || e.view.dragging ? null : f.create(s.doc, [
217
+ y.inline(s.selection.from, s.selection.to, {
218
+ class: t.className
219
+ })
220
+ ]);
185
221
  }
186
222
  }
187
- }
223
+ })
188
224
  ];
189
- },
190
- addCommands() {
191
- return {
192
- setFontSize: (t) => ({ chain: e }) => e().setMark("textStyle", { fontSize: t }).run(),
193
- unsetFontSize: () => ({ chain: t }) => t().setMark("textStyle", { fontSize: null }).removeEmptyTextStyle().run()
194
- };
195
225
  }
196
- }), b = l.create({
197
- name: "lineHeight",
226
+ });
227
+ function w({ types: e, node: t }) {
228
+ return t && Array.isArray(e) && e.includes(t.type) || t?.type === e;
229
+ }
230
+ var G = l.create({
231
+ name: "trailingNode",
198
232
  addOptions() {
199
233
  return {
200
- types: ["textStyle"]
234
+ node: void 0,
235
+ notAfter: []
201
236
  };
202
237
  },
203
- addGlobalAttributes() {
238
+ addProseMirrorPlugins() {
239
+ var e;
240
+ const t = new m(this.name), s = this.options.node || ((e = this.editor.schema.topNodeType.contentMatch.defaultType) == null ? void 0 : e.name) || "paragraph", r = Object.entries(this.editor.schema.nodes).map(([, o]) => o).filter((o) => (this.options.notAfter || []).concat(s).includes(o.name));
204
241
  return [
205
- {
206
- types: this.options.types,
207
- attributes: {
208
- lineHeight: {
209
- default: null,
210
- parseHTML: (t) => t.style.lineHeight,
211
- renderHTML: (t) => t.lineHeight ? {
212
- style: `line-height: ${t.lineHeight}`
213
- } : {}
242
+ new p({
243
+ key: t,
244
+ appendTransaction: (o, n, c) => {
245
+ const { doc: a, tr: i, schema: d } = c, u = t.getState(c), h = a.content.size, g = d.nodes[s];
246
+ if (u)
247
+ return i.insert(h, g.create());
248
+ },
249
+ state: {
250
+ init: (o, n) => {
251
+ const c = n.tr.doc.lastChild;
252
+ return !w({ node: c, types: r });
253
+ },
254
+ apply: (o, n) => {
255
+ if (!o.docChanged || o.getMeta("__uniqueIDTransaction"))
256
+ return n;
257
+ const c = o.doc.lastChild;
258
+ return !w({ node: c, types: r });
214
259
  }
215
260
  }
216
- }
261
+ })
217
262
  ];
263
+ }
264
+ }), I = l.create({
265
+ name: "undoRedo",
266
+ addOptions() {
267
+ return {
268
+ depth: 100,
269
+ newGroupDelay: 500
270
+ };
218
271
  },
219
272
  addCommands() {
220
273
  return {
221
- setLineHeight: (t) => ({ chain: e }) => e().setMark("textStyle", { lineHeight: t }).run(),
222
- unsetLineHeight: () => ({ chain: t }) => t().setMark("textStyle", { lineHeight: null }).removeEmptyTextStyle().run()
274
+ undo: () => ({ state: e, dispatch: t }) => T(e, t),
275
+ redo: () => ({ state: e, dispatch: t }) => M(e, t)
276
+ };
277
+ },
278
+ addProseMirrorPlugins() {
279
+ return [A(this.options)];
280
+ },
281
+ addKeyboardShortcuts() {
282
+ return {
283
+ "Mod-z": () => this.editor.commands.undo(),
284
+ "Shift-Mod-z": () => this.editor.commands.redo(),
285
+ "Mod-y": () => this.editor.commands.redo(),
286
+ // Russian keyboard layouts
287
+ "Mod-я": () => this.editor.commands.undo(),
288
+ "Shift-Mod-я": () => this.editor.commands.redo()
223
289
  };
224
- }
225
- });
226
- l.create({
227
- name: "textStyleKit",
228
- addExtensions() {
229
- const t = [];
230
- return this.options.backgroundColor !== !1 && t.push(m.configure(this.options.backgroundColor)), this.options.color !== !1 && t.push(g.configure(this.options.color)), this.options.fontFamily !== !1 && t.push(h.configure(this.options.fontFamily)), this.options.fontSize !== !1 && t.push(S.configure(this.options.fontSize)), this.options.lineHeight !== !1 && t.push(b.configure(this.options.lineHeight)), this.options.textStyle !== !1 && t.push(c.configure(this.options.textStyle)), t;
231
290
  }
232
291
  });
233
292
  export {
234
- m as BackgroundColor,
235
- g as Color,
236
- h as FontFamily,
237
- S as FontSize,
238
- b as LineHeight,
239
- c as TextStyle
293
+ R as Dropcursor,
294
+ L as Gapcursor,
295
+ B as Placeholder,
296
+ G as TrailingNode,
297
+ I as UndoRedo,
298
+ x as preparePlaceholderAttribute
240
299
  };