@quoreadmin/ui 1.10.13 → 1.10.15

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