@quoreadmin/ui 1.7.12 → 1.7.13

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 (210) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/index140.js +2 -2
  3. package/dist/index142.js +1 -1
  4. package/dist/index144.js +4 -4
  5. package/dist/index172.js +14 -14
  6. package/dist/index173.js +3 -3
  7. package/dist/index176.js +4 -4
  8. package/dist/index183.js +10 -10
  9. package/dist/index185.js +10 -10
  10. package/dist/index187.js +36 -1190
  11. package/dist/index188.js +46 -0
  12. package/dist/index189.js +1077 -5825
  13. package/dist/index191.js +5922 -19
  14. package/dist/index192.js +199 -10
  15. package/dist/index193.js +35 -36
  16. package/dist/index194.js +17 -43
  17. package/dist/index196.js +2 -2
  18. package/dist/index198.js +14 -14
  19. package/dist/index199.js +1 -1
  20. package/dist/index200.js +1 -1
  21. package/dist/index201.js +3 -3
  22. package/dist/index202.js +6 -6
  23. package/dist/index203.js +29 -123
  24. package/dist/index204.js +114 -36
  25. package/dist/index205.js +33 -404
  26. package/dist/index206.js +26 -80
  27. package/dist/index207.js +35 -19
  28. package/dist/index208.js +9 -88
  29. package/dist/index209.js +18 -19
  30. package/dist/index210.js +10 -20
  31. package/dist/index211.js +10 -20
  32. package/dist/index212.js +50 -19
  33. package/dist/index213.js +42 -21
  34. package/dist/index214.js +3 -21
  35. package/dist/index215.js +38 -19
  36. package/dist/index216.js +21 -836
  37. package/dist/index217.js +104 -645
  38. package/dist/index218.js +20 -176
  39. package/dist/index219.js +12 -14
  40. package/dist/index220.js +15 -13
  41. package/dist/index221.js +198 -19
  42. package/dist/index222.js +70 -3
  43. package/dist/index223.js +67 -166
  44. package/dist/index224.js +388 -114
  45. package/dist/index225.js +32 -159
  46. package/dist/index226.js +24 -1207
  47. package/dist/index227.js +22 -20
  48. package/dist/index228.js +160 -21
  49. package/dist/index229.js +228 -20
  50. package/dist/index230.js +36 -21
  51. package/dist/index231.js +10 -29
  52. package/dist/index232.js +126 -19
  53. package/dist/index233.js +34 -16
  54. package/dist/index234.js +80 -2
  55. package/dist/index235.js +20 -2
  56. package/dist/index236.js +19 -160
  57. package/dist/index237.js +20 -228
  58. package/dist/index238.js +19 -36
  59. package/dist/index239.js +3631 -9
  60. package/dist/index240.js +52 -19
  61. package/dist/index241.js +76 -32
  62. package/dist/index242.js +52 -116
  63. package/dist/index243.js +215 -36
  64. package/dist/index244.js +10 -26
  65. package/dist/index245.js +57 -36
  66. package/dist/index246.js +61 -9
  67. package/dist/index247.js +54 -19
  68. package/dist/index248.js +75 -10
  69. package/dist/index249.js +723 -10
  70. package/dist/index250.js +37 -49
  71. package/dist/index251.js +63 -42
  72. package/dist/index252.js +11 -4
  73. package/dist/index253.js +700 -34
  74. package/dist/index254.js +820 -21
  75. package/dist/index255.js +12 -12
  76. package/dist/index256.js +21 -198
  77. package/dist/index257.js +19 -69
  78. package/dist/index258.js +836 -34
  79. package/dist/index259.js +686 -24
  80. package/dist/index260.js +170 -3626
  81. package/dist/index261.js +22 -55
  82. package/dist/index262.js +20 -77
  83. package/dist/index263.js +20 -52
  84. package/dist/index264.js +3 -215
  85. package/dist/index265.js +187 -10
  86. package/dist/index266.js +128 -52
  87. package/dist/index267.js +1214 -52
  88. package/dist/index268.js +20 -54
  89. package/dist/index269.js +22 -75
  90. package/dist/index270.js +21 -722
  91. package/dist/index271.js +29 -39
  92. package/dist/index272.js +20 -64
  93. package/dist/index273.js +20 -11
  94. package/dist/index274.js +2 -705
  95. package/dist/index275.js +2 -820
  96. package/dist/index276.js +50 -249
  97. package/dist/index277.js +79 -2
  98. package/dist/index278.js +26 -138
  99. package/dist/index279.js +22 -83
  100. package/dist/index280.js +21 -78
  101. package/dist/index281.js +13 -5
  102. package/dist/index282.js +12 -74
  103. package/dist/index283.js +253 -22
  104. package/dist/index284.js +8 -935
  105. package/dist/index285.js +138 -22
  106. package/dist/index286.js +83 -20
  107. package/dist/index287.js +23 -20
  108. package/dist/index288.js +3 -69
  109. package/dist/index289.js +27 -19
  110. package/dist/index290.js +2 -19
  111. package/dist/index291.js +230 -49
  112. package/dist/index292.js +5 -21
  113. package/dist/index293.js +133 -21
  114. package/dist/index294.js +68 -63
  115. package/dist/index295.js +86 -25
  116. package/dist/index296.js +28 -21
  117. package/dist/index297.js +8 -21
  118. package/dist/index298.js +75 -16
  119. package/dist/index299.js +4 -17
  120. package/dist/index300.js +2 -23
  121. package/dist/index301.js +80 -1515
  122. package/dist/index302.js +53 -385
  123. package/dist/index303.js +4 -2729
  124. package/dist/index304.js +4 -85
  125. package/dist/index305.js +148 -3739
  126. package/dist/index306.js +60 -57
  127. package/dist/index307.js +74 -14
  128. package/dist/index308.js +1496 -62
  129. package/dist/index309.js +356 -172
  130. package/dist/index310.js +2695 -210
  131. package/dist/index311.js +86 -3
  132. package/dist/index312.js +3764 -21
  133. package/dist/index313.js +52 -227
  134. package/dist/index314.js +15 -6
  135. package/dist/index315.js +74 -124
  136. package/dist/index316.js +195 -61
  137. package/dist/index317.js +240 -81
  138. package/dist/index318.js +75 -25
  139. package/dist/index319.js +21 -8
  140. package/dist/index320.js +926 -66
  141. package/dist/index321.js +21 -3
  142. package/dist/index322.js +20 -2
  143. package/dist/index323.js +19 -82
  144. package/dist/index324.js +66 -51
  145. package/dist/index325.js +19 -6
  146. package/dist/index326.js +19 -5
  147. package/dist/index327.js +21 -178
  148. package/dist/index328.js +21 -62
  149. package/dist/index329.js +62 -74
  150. package/dist/index330.js +1 -1
  151. package/dist/index331.js +8 -19
  152. package/dist/index332.js +12 -19
  153. package/dist/index333.js +51 -60
  154. package/dist/index334.js +12 -37
  155. package/dist/index335.js +13 -8
  156. package/dist/index336.js +57 -12
  157. package/dist/index337.js +48 -51
  158. package/dist/index338.js +28 -9
  159. package/dist/index339.js +2 -14
  160. package/dist/index340.js +5 -58
  161. package/dist/index341.js +2 -52
  162. package/dist/index342.js +22 -30
  163. package/dist/index343.js +41 -2
  164. package/dist/index344.js +2 -5
  165. package/dist/index345.js +11 -2
  166. package/dist/index346.js +19 -22
  167. package/dist/index347.js +14 -38
  168. package/dist/index348.js +10 -2
  169. package/dist/index349.js +9 -10
  170. package/dist/index350.js +2 -20
  171. package/dist/index351.js +8 -16
  172. package/dist/index352.js +10 -10
  173. package/dist/index353.js +13 -9
  174. package/dist/index354.js +21 -2
  175. package/dist/index355.js +56 -9
  176. package/dist/index356.js +28 -9
  177. package/dist/index357.js +7 -14
  178. package/dist/index358.js +49 -18
  179. package/dist/index359.js +6 -56
  180. package/dist/index360.js +10 -27
  181. package/dist/index361.js +7 -7
  182. package/dist/index362.js +27 -51
  183. package/dist/index363.js +2 -6
  184. package/dist/index364.js +69 -11
  185. package/dist/index365.js +166 -6
  186. package/dist/index366.js +20 -28
  187. package/dist/index367.js +20 -2
  188. package/dist/index368.js +61 -67
  189. package/dist/index369.js +36 -166
  190. package/dist/index370.js +31 -17
  191. package/dist/index371.js +11 -98
  192. package/dist/index372.js +1 -98
  193. package/dist/index373.js +3 -90
  194. package/dist/index374.js +12 -30
  195. package/dist/index375.js +7 -11
  196. package/dist/index376.js +11 -3
  197. package/dist/index377.js +4 -3
  198. package/dist/index378.js +33 -13
  199. package/dist/index379.js +31 -7
  200. package/dist/index380.js +28 -12
  201. package/dist/index381.js +61 -5
  202. package/dist/index382.js +101 -33
  203. package/dist/index383.js +91 -31
  204. package/dist/index384.js +97 -27
  205. package/dist/index385.js +16 -60
  206. package/dist/index386.js +1 -1
  207. package/dist/index391.js +1 -1
  208. package/dist/index392.js +2 -2
  209. package/package.json +1 -1
  210. package/dist/index190.js +0 -209
package/dist/index240.js CHANGED
@@ -1,24 +1,57 @@
1
- import p from "./index278.js";
2
- var a = {
3
- root: function(e) {
4
- var t = e.props;
5
- return ["p-selectbutton p-button-group p-component", {
6
- "p-disabled": t.disabled,
7
- "p-invalid": t.invalid
8
- }];
1
+ import { Node as a, wrappingInputRule as c, mergeAttributes as d } from "./index239.js";
2
+ import { createElement as i } from "./index314.js";
3
+ var l = /^\s*>\s$/, g = a.create({
4
+ name: "blockquote",
5
+ addOptions() {
6
+ return {
7
+ HTMLAttributes: {}
8
+ };
9
9
  },
10
- button: function(e) {
11
- var t = e.instance, n = e.option;
12
- return ["p-button p-component", {
13
- "p-highlight": t.isSelected(n),
14
- "p-disabled": t.isOptionDisabled(n)
15
- }];
10
+ content: "block+",
11
+ group: "block",
12
+ defining: !0,
13
+ parseHTML() {
14
+ return [{ tag: "blockquote" }];
16
15
  },
17
- label: "p-button-label"
18
- }, l = p.extend({
19
- name: "selectbutton",
20
- classes: a
16
+ renderHTML({ HTMLAttributes: t }) {
17
+ return /* @__PURE__ */ i("blockquote", { ...d(this.options.HTMLAttributes, t), children: /* @__PURE__ */ i("slot", {}) });
18
+ },
19
+ parseMarkdown: (t, e) => e.createNode("blockquote", void 0, e.parseChildren(t.tokens || [])),
20
+ renderMarkdown: (t, e) => {
21
+ if (!t.content)
22
+ return "";
23
+ const r = ">", n = [];
24
+ return t.content.forEach((u) => {
25
+ const s = e.renderChildren([u]).split(`
26
+ `).map((o) => o.trim() === "" ? r : `${r} ${o}`);
27
+ n.push(s.join(`
28
+ `));
29
+ }), n.join(`
30
+ ${r}
31
+ `);
32
+ },
33
+ addCommands() {
34
+ return {
35
+ setBlockquote: () => ({ commands: t }) => t.wrapIn(this.name),
36
+ toggleBlockquote: () => ({ commands: t }) => t.toggleWrap(this.name),
37
+ unsetBlockquote: () => ({ commands: t }) => t.lift(this.name)
38
+ };
39
+ },
40
+ addKeyboardShortcuts() {
41
+ return {
42
+ "Mod-Shift-b": () => this.editor.commands.toggleBlockquote()
43
+ };
44
+ },
45
+ addInputRules() {
46
+ return [
47
+ c({
48
+ find: l,
49
+ type: this.type
50
+ })
51
+ ];
52
+ }
21
53
  });
22
54
  export {
23
- l as default
55
+ g as Blockquote,
56
+ l as inputRegex
24
57
  };
package/dist/index241.js CHANGED
@@ -1,35 +1,79 @@
1
- function u(t) {
2
- if (t === null || typeof t != "object")
3
- return !1;
4
- const n = Object.getPrototypeOf(t);
5
- return n !== null && n !== Object.prototype && Object.getPrototypeOf(n) !== null || Symbol.iterator in t ? !1 : Symbol.toStringTag in t ? Object.prototype.toString.call(t) === "[object Module]" : !0;
6
- }
7
- function c(t, n, e = ".", f) {
8
- if (!u(n))
9
- return c(t, {}, e, f);
10
- const r = Object.assign({}, n);
11
- for (const o in t) {
12
- if (o === "__proto__" || o === "constructor")
13
- continue;
14
- const i = t[o];
15
- i != null && (f && f(r, o, i, e) || (Array.isArray(i) && Array.isArray(r[o]) ? r[o] = [...i, ...r[o]] : u(i) && u(r[o]) ? r[o] = c(
16
- i,
17
- r[o],
18
- (e ? `${e}.` : "") + o.toString(),
19
- f
20
- ) : r[o] = i));
1
+ import { Mark as a, markPasteRule as r, markInputRule as s, mergeAttributes as o } from "./index239.js";
2
+ import { createElement as n } from "./index314.js";
3
+ var d = /(?:^|\s)(\*\*(?!\s+\*\*)((?:[^*]+))\*\*(?!\s+\*\*))$/, l = /(?:^|\s)(\*\*(?!\s+\*\*)((?:[^*]+))\*\*(?!\s+\*\*))/g, i = /(?:^|\s)(__(?!\s+__)((?:[^_]+))__(?!\s+__))$/, u = /(?:^|\s)(__(?!\s+__)((?:[^_]+))__(?!\s+__))/g, p = a.create({
4
+ name: "bold",
5
+ addOptions() {
6
+ return {
7
+ HTMLAttributes: {}
8
+ };
9
+ },
10
+ parseHTML() {
11
+ return [
12
+ {
13
+ tag: "strong"
14
+ },
15
+ {
16
+ tag: "b",
17
+ getAttrs: (t) => t.style.fontWeight !== "normal" && null
18
+ },
19
+ {
20
+ style: "font-weight=400",
21
+ clearMark: (t) => t.type.name === this.name
22
+ },
23
+ {
24
+ style: "font-weight",
25
+ getAttrs: (t) => /^(bold(er)?|[5-9]\d{2,})$/.test(t) && null
26
+ }
27
+ ];
28
+ },
29
+ renderHTML({ HTMLAttributes: t }) {
30
+ return /* @__PURE__ */ n("strong", { ...o(this.options.HTMLAttributes, t), children: /* @__PURE__ */ n("slot", {}) });
31
+ },
32
+ markdownTokenName: "strong",
33
+ parseMarkdown: (t, e) => e.applyMark("bold", e.parseInline(t.tokens || [])),
34
+ renderMarkdown: (t, e) => `**${e.renderChildren(t)}**`,
35
+ addCommands() {
36
+ return {
37
+ setBold: () => ({ commands: t }) => t.setMark(this.name),
38
+ toggleBold: () => ({ commands: t }) => t.toggleMark(this.name),
39
+ unsetBold: () => ({ commands: t }) => t.unsetMark(this.name)
40
+ };
41
+ },
42
+ addKeyboardShortcuts() {
43
+ return {
44
+ "Mod-b": () => this.editor.commands.toggleBold(),
45
+ "Mod-B": () => this.editor.commands.toggleBold()
46
+ };
47
+ },
48
+ addInputRules() {
49
+ return [
50
+ s({
51
+ find: d,
52
+ type: this.type
53
+ }),
54
+ s({
55
+ find: i,
56
+ type: this.type
57
+ })
58
+ ];
59
+ },
60
+ addPasteRules() {
61
+ return [
62
+ r({
63
+ find: l,
64
+ type: this.type
65
+ }),
66
+ r({
67
+ find: u,
68
+ type: this.type
69
+ })
70
+ ];
21
71
  }
22
- return r;
23
- }
24
- function l(t) {
25
- return (...n) => (
26
- // eslint-disable-next-line unicorn/no-array-reduce
27
- n.reduce((e, f) => c(e, f, "", t), {})
28
- );
29
- }
30
- const y = l();
72
+ });
31
73
  export {
32
- l as createDefu,
33
- y as default,
34
- y as defu
74
+ p as Bold,
75
+ d as starInputRegex,
76
+ l as starPasteRegex,
77
+ i as underscoreInputRegex,
78
+ u as underscorePasteRegex
35
79
  };
package/dist/index242.js CHANGED
@@ -1,118 +1,54 @@
1
- import { toArray as p, notNullish as x, noop as M, tryOnScopeDispose as g, watchImmediate as S, isClient as W, isObject as A } from "./index243.js";
2
- import { getLifeCycleTarget as q, tryOnUnmounted as z } from "./index243.js";
3
- import { toValue as a, computed as y, shallowRef as I, watch as T, getCurrentInstance as j, onMounted as w, unref as B } from "vue";
4
- const C = W ? window : void 0;
5
- function d(t) {
6
- var o;
7
- const l = a(t);
8
- return (o = l?.$el) != null ? o : l;
9
- }
10
- function U(...t) {
11
- const o = [], l = () => {
12
- o.forEach((e) => e()), o.length = 0;
13
- }, h = (e, n, u, r) => (e.addEventListener(n, u, r), () => e.removeEventListener(n, u, r)), c = y(() => {
14
- const e = p(a(t[0])).filter((n) => n != null);
15
- return e.every((n) => typeof n != "string") ? e : void 0;
16
- }), m = S(
17
- () => {
18
- var e, n;
19
- return [
20
- (n = (e = c.value) == null ? void 0 : e.map((u) => d(u))) != null ? n : [C].filter((u) => u != null),
21
- p(a(c.value ? t[1] : t[0])),
22
- p(B(c.value ? t[2] : t[1])),
23
- // @ts-expect-error - TypeScript gets the correct types, but somehow still complains
24
- a(c.value ? t[3] : t[2])
25
- ];
26
- },
27
- ([e, n, u, r]) => {
28
- if (l(), !e?.length || !n?.length || !u?.length)
29
- return;
30
- const s = A(r) ? { ...r } : r;
31
- o.push(
32
- ...e.flatMap(
33
- (b) => n.flatMap(
34
- (v) => u.map((i) => h(b, v, i, s))
35
- )
36
- )
37
- );
38
- },
39
- { flush: "post" }
40
- ), f = () => {
41
- m(), l();
42
- };
43
- return g(l), f;
44
- }
45
- // @__NO_SIDE_EFFECTS__
46
- function D() {
47
- const t = I(!1), o = j();
48
- return o && w(() => {
49
- t.value = !0;
50
- }, o), t;
51
- }
52
- // @__NO_SIDE_EFFECTS__
53
- function N(t) {
54
- const o = /* @__PURE__ */ D();
55
- return y(() => (o.value, !!t()));
56
- }
57
- function V(t, o, l = {}) {
58
- const {
59
- root: h,
60
- rootMargin: c = "0px",
61
- threshold: m = 0,
62
- window: f = C,
63
- immediate: e = !0
64
- } = l, n = /* @__PURE__ */ N(() => f && "IntersectionObserver" in f), u = y(() => {
65
- const i = a(t);
66
- return p(i).map(d).filter(x);
67
- });
68
- let r = M;
69
- const s = I(e), b = n.value ? T(
70
- () => [u.value, d(h), s.value],
71
- ([i, L]) => {
72
- if (r(), !s.value || !i.length)
73
- return;
74
- const E = new IntersectionObserver(
75
- o,
76
- {
77
- root: d(L),
78
- rootMargin: c,
79
- threshold: m
80
- }
81
- );
82
- i.forEach((O) => O && E.observe(O)), r = () => {
83
- E.disconnect(), r = M;
84
- };
85
- },
86
- { immediate: e, flush: "post" }
87
- ) : M, v = () => {
88
- r(), b(), s.value = !1;
89
- };
90
- return g(v), {
91
- isSupported: n,
92
- isActive: s,
93
- pause() {
94
- r(), s.value = !1;
95
- },
96
- resume() {
97
- s.value = !0;
98
- },
99
- stop: v
100
- };
101
- }
1
+ import { Mark as r, markPasteRule as n, markInputRule as a, mergeAttributes as d } from "./index239.js";
2
+ var o = /(^|[^`])`([^`]+)`(?!`)$/, u = /(^|[^`])`([^`]+)`(?!`)/g, i = r.create({
3
+ name: "code",
4
+ addOptions() {
5
+ return {
6
+ HTMLAttributes: {}
7
+ };
8
+ },
9
+ excludes: "_",
10
+ code: !0,
11
+ exitable: !0,
12
+ parseHTML() {
13
+ return [{ tag: "code" }];
14
+ },
15
+ renderHTML({ HTMLAttributes: e }) {
16
+ return ["code", d(this.options.HTMLAttributes, e), 0];
17
+ },
18
+ markdownTokenName: "codespan",
19
+ parseMarkdown: (e, t) => t.applyMark("code", [{ type: "text", text: e.text || "" }]),
20
+ renderMarkdown: (e, t) => e.content ? `\`${t.renderChildren(e.content)}\`` : "",
21
+ addCommands() {
22
+ return {
23
+ setCode: () => ({ commands: e }) => e.setMark(this.name),
24
+ toggleCode: () => ({ commands: e }) => e.toggleMark(this.name),
25
+ unsetCode: () => ({ commands: e }) => e.unsetMark(this.name)
26
+ };
27
+ },
28
+ addKeyboardShortcuts() {
29
+ return {
30
+ "Mod-e": () => this.editor.commands.toggleCode()
31
+ };
32
+ },
33
+ addInputRules() {
34
+ return [
35
+ a({
36
+ find: o,
37
+ type: this.type
38
+ })
39
+ ];
40
+ },
41
+ addPasteRules() {
42
+ return [
43
+ n({
44
+ find: u,
45
+ type: this.type
46
+ })
47
+ ];
48
+ }
49
+ });
102
50
  export {
103
- C as defaultWindow,
104
- q as getLifeCycleTarget,
105
- W as isClient,
106
- A as isObject,
107
- M as noop,
108
- x as notNullish,
109
- p as toArray,
110
- g as tryOnScopeDispose,
111
- z as tryOnUnmounted,
112
- d as unrefElement,
113
- U as useEventListener,
114
- V as useIntersectionObserver,
115
- D as useMounted,
116
- N as useSupported,
117
- S as watchImmediate
51
+ i as Code,
52
+ o as inputRegex,
53
+ u as pasteRegex
118
54
  };
package/dist/index243.js CHANGED
@@ -1,38 +1,217 @@
1
- import { onUnmounted as o, getCurrentInstance as r, getCurrentScope as c, onScopeDispose as i, watch as s } from "vue";
2
- function p(t) {
3
- return c() ? (i(t), !0) : !1;
4
- }
5
- const l = typeof window < "u" && typeof document < "u";
6
- typeof WorkerGlobalScope < "u" && globalThis instanceof WorkerGlobalScope;
7
- const d = (t) => t != null, u = Object.prototype.toString, y = (t) => u.call(t) === "[object Object]", m = () => {
8
- };
9
- function g(t) {
10
- return Array.isArray(t) ? t : [t];
11
- }
12
- function f(t) {
13
- return r();
14
- }
15
- function b(t, n) {
16
- f() && o(t, n);
17
- }
18
- function S(t, n, e) {
19
- return s(
20
- t,
21
- n,
22
- {
23
- ...e,
24
- immediate: !0
25
- }
26
- );
27
- }
1
+ import { Node as k, textblockTypeInputRule as S, mergeAttributes as C } from "./index239.js";
2
+ import { Plugin as w, PluginKey as B, TextSelection as T, Selection as L } from "./index254.js";
3
+ var y = 4, M = /^```([a-z]+)?[\s\n]$/, N = /^~~~([a-z]+)?[\s\n]$/, $ = k.create({
4
+ name: "codeBlock",
5
+ addOptions() {
6
+ return {
7
+ languageClassPrefix: "language-",
8
+ exitOnTripleEnter: !0,
9
+ exitOnArrowDown: !0,
10
+ defaultLanguage: null,
11
+ enableTabIndentation: !1,
12
+ tabSize: y,
13
+ HTMLAttributes: {}
14
+ };
15
+ },
16
+ content: "text*",
17
+ marks: "",
18
+ group: "block",
19
+ code: !0,
20
+ defining: !0,
21
+ addAttributes() {
22
+ return {
23
+ language: {
24
+ default: this.options.defaultLanguage,
25
+ parseHTML: (e) => {
26
+ var t;
27
+ const { languageClassPrefix: r } = this.options;
28
+ if (!r)
29
+ return null;
30
+ const o = [...((t = e.firstElementChild) == null ? void 0 : t.classList) || []].filter((s) => s.startsWith(r)).map((s) => s.replace(r, ""))[0];
31
+ return o || null;
32
+ },
33
+ rendered: !1
34
+ }
35
+ };
36
+ },
37
+ parseHTML() {
38
+ return [
39
+ {
40
+ tag: "pre",
41
+ preserveWhitespace: "full"
42
+ }
43
+ ];
44
+ },
45
+ renderHTML({ node: e, HTMLAttributes: t }) {
46
+ return [
47
+ "pre",
48
+ C(this.options.HTMLAttributes, t),
49
+ [
50
+ "code",
51
+ {
52
+ class: e.attrs.language ? this.options.languageClassPrefix + e.attrs.language : null
53
+ },
54
+ 0
55
+ ]
56
+ ];
57
+ },
58
+ markdownTokenName: "code",
59
+ parseMarkdown: (e, t) => {
60
+ var r;
61
+ return ((r = e.raw) == null ? void 0 : r.startsWith("```")) === !1 && e.codeBlockStyle !== "indented" ? [] : t.createNode(
62
+ "codeBlock",
63
+ { language: e.lang || null },
64
+ e.text ? [t.createTextNode(e.text)] : []
65
+ );
66
+ },
67
+ renderMarkdown: (e, t) => {
68
+ var r;
69
+ let n = "";
70
+ const a = ((r = e.attrs) == null ? void 0 : r.language) || "";
71
+ return e.content ? n = [`\`\`\`${a}`, t.renderChildren(e.content), "```"].join(`
72
+ `) : n = `\`\`\`${a}
73
+
74
+ \`\`\``, n;
75
+ },
76
+ addCommands() {
77
+ return {
78
+ setCodeBlock: (e) => ({ commands: t }) => t.setNode(this.name, e),
79
+ toggleCodeBlock: (e) => ({ commands: t }) => t.toggleNode(this.name, "paragraph", e)
80
+ };
81
+ },
82
+ addKeyboardShortcuts() {
83
+ return {
84
+ "Mod-Alt-c": () => this.editor.commands.toggleCodeBlock(),
85
+ // remove code block when at start of document or code block is empty
86
+ Backspace: () => {
87
+ const { empty: e, $anchor: t } = this.editor.state.selection, r = t.pos === 1;
88
+ return !e || t.parent.type.name !== this.name ? !1 : r || !t.parent.textContent.length ? this.editor.commands.clearNodes() : !1;
89
+ },
90
+ // handle tab indentation
91
+ Tab: ({ editor: e }) => {
92
+ var t;
93
+ if (!this.options.enableTabIndentation)
94
+ return !1;
95
+ const r = (t = this.options.tabSize) != null ? t : y, { state: n } = e, { selection: a } = n, { $from: o, empty: s } = a;
96
+ if (o.parent.type !== this.type)
97
+ return !1;
98
+ const i = " ".repeat(r);
99
+ return s ? e.commands.insertContent(i) : e.commands.command(({ tr: l }) => {
100
+ const { from: c, to: f } = a, u = n.doc.textBetween(c, f, `
101
+ `, `
102
+ `).split(`
103
+ `).map((p) => i + p).join(`
104
+ `);
105
+ return l.replaceWith(c, f, n.schema.text(u)), !0;
106
+ });
107
+ },
108
+ // handle shift+tab reverse indentation
109
+ "Shift-Tab": ({ editor: e }) => {
110
+ var t;
111
+ if (!this.options.enableTabIndentation)
112
+ return !1;
113
+ const r = (t = this.options.tabSize) != null ? t : y, { state: n } = e, { selection: a } = n, { $from: o, empty: s } = a;
114
+ return o.parent.type !== this.type ? !1 : s ? e.commands.command(({ tr: i }) => {
115
+ var l;
116
+ const { pos: c } = o, f = o.start(), h = o.end(), u = n.doc.textBetween(f, h, `
117
+ `, `
118
+ `).split(`
119
+ `);
120
+ let p = 0, g = 0;
121
+ const b = c - f;
122
+ for (let d = 0; d < u.length; d += 1) {
123
+ if (g + u[d].length >= b) {
124
+ p = d;
125
+ break;
126
+ }
127
+ g += u[d].length + 1;
128
+ }
129
+ const A = ((l = u[p].match(/^ */)) == null ? void 0 : l[0]) || "", v = Math.min(A.length, r);
130
+ if (v === 0)
131
+ return !0;
132
+ let m = f;
133
+ for (let d = 0; d < p; d += 1)
134
+ m += u[d].length + 1;
135
+ return i.delete(m, m + v), c - m <= v && i.setSelection(T.create(i.doc, m)), !0;
136
+ }) : e.commands.command(({ tr: i }) => {
137
+ const { from: l, to: c } = a, x = n.doc.textBetween(l, c, `
138
+ `, `
139
+ `).split(`
140
+ `).map((u) => {
141
+ var p;
142
+ const g = ((p = u.match(/^ */)) == null ? void 0 : p[0]) || "", b = Math.min(g.length, r);
143
+ return u.slice(b);
144
+ }).join(`
145
+ `);
146
+ return i.replaceWith(l, c, n.schema.text(x)), !0;
147
+ });
148
+ },
149
+ // exit node on triple enter
150
+ Enter: ({ editor: e }) => {
151
+ if (!this.options.exitOnTripleEnter)
152
+ return !1;
153
+ const { state: t } = e, { selection: r } = t, { $from: n, empty: a } = r;
154
+ if (!a || n.parent.type !== this.type)
155
+ return !1;
156
+ const o = n.parentOffset === n.parent.nodeSize - 2, s = n.parent.textContent.endsWith(`
157
+
158
+ `);
159
+ return !o || !s ? !1 : e.chain().command(({ tr: i }) => (i.delete(n.pos - 2, n.pos), !0)).exitCode().run();
160
+ },
161
+ // exit node on arrow down
162
+ ArrowDown: ({ editor: e }) => {
163
+ if (!this.options.exitOnArrowDown)
164
+ return !1;
165
+ const { state: t } = e, { selection: r, doc: n } = t, { $from: a, empty: o } = r;
166
+ if (!o || a.parent.type !== this.type || !(a.parentOffset === a.parent.nodeSize - 2))
167
+ return !1;
168
+ const i = a.after();
169
+ return i === void 0 ? !1 : n.nodeAt(i) ? e.commands.command(({ tr: c }) => (c.setSelection(L.near(n.resolve(i))), !0)) : e.commands.exitCode();
170
+ }
171
+ };
172
+ },
173
+ addInputRules() {
174
+ return [
175
+ S({
176
+ find: M,
177
+ type: this.type,
178
+ getAttributes: (e) => ({
179
+ language: e[1]
180
+ })
181
+ }),
182
+ S({
183
+ find: N,
184
+ type: this.type,
185
+ getAttributes: (e) => ({
186
+ language: e[1]
187
+ })
188
+ })
189
+ ];
190
+ },
191
+ addProseMirrorPlugins() {
192
+ return [
193
+ // this plugin creates a code block for pasted content from VS Code
194
+ // we can also detect the copied code language
195
+ new w({
196
+ key: new B("codeBlockVSCodeHandler"),
197
+ props: {
198
+ handlePaste: (e, t) => {
199
+ if (!t.clipboardData || this.editor.isActive(this.type.name))
200
+ return !1;
201
+ const r = t.clipboardData.getData("text/plain"), n = t.clipboardData.getData("vscode-editor-data"), a = n ? JSON.parse(n) : void 0, o = a?.mode;
202
+ if (!r || !o)
203
+ return !1;
204
+ const { tr: s, schema: i } = e.state, l = i.text(r.replace(/\r\n?/g, `
205
+ `));
206
+ return s.replaceSelectionWith(this.type.create({ language: o }, l)), s.selection.$from.parent.type !== this.type && s.setSelection(T.near(s.doc.resolve(Math.max(0, s.selection.from - 2)))), s.setMeta("paste", !0), e.dispatch(s), !0;
207
+ }
208
+ }
209
+ })
210
+ ];
211
+ }
212
+ });
28
213
  export {
29
- f as getLifeCycleTarget,
30
- l as isClient,
31
- y as isObject,
32
- m as noop,
33
- d as notNullish,
34
- g as toArray,
35
- p as tryOnScopeDispose,
36
- b as tryOnUnmounted,
37
- S as watchImmediate
214
+ $ as CodeBlock,
215
+ M as backtickInputRegex,
216
+ N as tildeInputRegex
38
217
  };
package/dist/index244.js CHANGED
@@ -1,28 +1,12 @@
1
- import { onNextFrame as p, defaultTimestep as i } from "./index311.js";
2
- import { createRenderStep as x } from "./index312.js";
3
- const h = 40;
4
- let o = !0, s = !1, c = !1;
5
- const r = {
6
- delta: 0,
7
- timestamp: 0
8
- }, a = [
9
- "read",
10
- "update",
11
- "preRender",
12
- "render",
13
- "postRender"
14
- ], n = a.reduce((e, t) => (e[t] = x(() => s = !0), e), {}), g = a.reduce((e, t) => {
15
- const l = n[t];
16
- return e[t] = (d, f = !1, m = !1) => (s || E(), l.schedule(d, f, m)), e;
17
- }, {}), D = a.reduce((e, t) => (e[t] = n[t].cancel, e), {});
18
- a.reduce((e, t) => (e[t] = () => n[t].process(r), e), {});
19
- const F = (e) => n[e].process(r), u = (e) => {
20
- s = !1, r.delta = o ? i : Math.max(Math.min(e - r.timestamp, h), 1), r.timestamp = e, c = !0, a.forEach(F), c = !1, s && (o = !1, p(u));
21
- }, E = () => {
22
- s = !0, o = !0, c || p(u);
23
- }, M = () => r;
1
+ import { Node as n } from "./index239.js";
2
+ var o = n.create({
3
+ name: "doc",
4
+ topNode: !0,
5
+ content: "block+",
6
+ renderMarkdown: (e, r) => e.content ? r.renderChildren(e.content, `
7
+
8
+ `) : ""
9
+ });
24
10
  export {
25
- D as cancelSync,
26
- g as default,
27
- M as getFrameData
11
+ o as Document
28
12
  };