@quoreadmin/ui 1.10.0 → 1.10.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.css +1 -1
- package/dist/index105.js +2 -2
- package/dist/index111.js +1 -1
- package/dist/index115.js +2 -2
- package/dist/index119.js +3 -3
- package/dist/index131.js +2 -2
- package/dist/{index135.js → index136.js} +1 -1
- package/dist/{index137.js → index138.js} +2 -2
- package/dist/{index146.js → index147.js} +3 -3
- package/dist/{index148.js → index149.js} +1 -1
- package/dist/{index150.js → index151.js} +6 -6
- package/dist/{index161.js → index162.js} +1 -1
- package/dist/{index164.js → index165.js} +1 -1
- package/dist/{index168.js → index169.js} +9 -9
- package/dist/index172.js +111 -492
- package/dist/index173.js +471 -5498
- package/dist/index174.js +5511 -80
- package/dist/index175.js +86 -856
- package/dist/index176.js +844 -21
- package/dist/index177.js +23 -265
- package/dist/index178.js +256 -126
- package/dist/index179.js +146 -1195
- package/dist/index180.js +1139 -712
- package/dist/index181.js +704 -1240
- package/dist/index182.js +1280 -248
- package/dist/index183.js +266 -96
- package/dist/index184.js +106 -2
- package/dist/index185.js +2 -1376
- package/dist/index186.js +1378 -0
- package/dist/index188.js +12 -12
- package/dist/index189.js +10 -10
- package/dist/index190.js +12 -12
- package/dist/index191.js +14 -21
- package/dist/index192.js +23 -757
- package/dist/index193.js +759 -1144
- package/dist/index194.js +1144 -1234
- package/dist/index195.js +1205 -11248
- package/dist/index196.js +11277 -36
- package/dist/index197.js +36 -44
- package/dist/index198.js +42 -1226
- package/dist/index199.js +1230 -0
- package/dist/index201.js +5830 -99
- package/dist/index202.js +188 -16
- package/dist/index203.js +25 -8
- package/dist/index204.js +16 -76
- package/dist/index205.js +74 -249
- package/dist/index206.js +229 -13660
- package/dist/index207.js +13684 -27
- package/dist/index208.js +26 -62
- package/dist/index209.js +40 -215
- package/dist/index210.js +206 -279
- package/dist/index211.js +281 -265
- package/dist/index212.js +293 -31
- package/dist/index213.js +30 -113
- package/dist/index214.js +110 -30
- package/dist/index215.js +36 -26
- package/dist/index216.js +26 -36
- package/dist/index217.js +34 -49
- package/dist/index218.js +45 -37
- package/dist/index219.js +42 -3
- package/dist/index220.js +4 -9
- package/dist/index221.js +9 -19
- package/dist/index222.js +19 -10
- package/dist/index223.js +10 -10
- package/dist/index224.js +10 -39
- package/dist/index225.js +39 -21
- package/dist/index226.js +21 -88
- package/dist/index227.js +147 -393
- package/dist/index228.js +227 -21
- package/dist/index229.js +36 -160
- package/dist/index230.js +10 -20
- package/dist/index231.js +160 -19
- package/dist/index232.js +13 -15
- package/dist/index233.js +19 -198
- package/dist/index234.js +21 -69
- package/dist/index235.js +197 -32
- package/dist/index236.js +56 -26
- package/dist/index237.js +84 -157
- package/dist/index238.js +384 -205
- package/dist/index239.js +34 -37
- package/dist/index240.js +39 -9
- package/dist/index241.js +19 -124
- package/dist/index242.js +21 -37
- package/dist/index243.js +22 -80
- package/dist/index244.js +12 -12
- package/dist/index245.js +836 -20
- package/dist/index246.js +701 -19
- package/dist/index247.js +176 -20
- package/dist/index248.js +12 -14
- package/dist/index249.js +12 -14
- package/dist/index250.js +15 -13
- package/dist/index251.js +20 -836
- package/dist/index252.js +19 -701
- package/dist/index253.js +3 -176
- package/dist/index254.js +186 -21
- package/dist/index255.js +132 -19
- package/dist/index256.js +1223 -20
- package/dist/index257.js +127 -3
- package/dist/index258.js +18 -185
- package/dist/index259.js +21 -132
- package/dist/index260.js +22 -1223
- package/dist/index261.js +37 -19
- package/dist/index262.js +20 -13
- package/dist/index263.js +13 -15
- package/dist/index264.js +12 -21
- package/dist/index265.js +2 -20
- package/dist/index266.js +2 -20
- package/dist/index267.js +3636 -2
- package/dist/index268.js +55 -2
- package/dist/index269.js +55 -3614
- package/dist/index270.js +29 -32
- package/dist/index271.js +184 -46
- package/dist/index272.js +9 -51
- package/dist/index273.js +39 -197
- package/dist/index274.js +60 -9
- package/dist/index275.js +40 -43
- package/dist/index276.js +58 -44
- package/dist/index277.js +705 -33
- package/dist/index278.js +25 -58
- package/dist/index279.js +32 -694
- package/dist/index280.js +10 -41
- package/dist/index281.js +696 -55
- package/dist/index282.js +819 -10
- package/dist/index283.js +79 -704
- package/dist/index284.js +20 -820
- package/dist/index285.js +20 -253
- package/dist/index286.js +53 -7
- package/dist/index287.js +59 -118
- package/dist/index288.js +26 -83
- package/dist/index289.js +22 -3
- package/dist/index290.js +21 -26
- package/dist/index291.js +14 -52
- package/dist/index292.js +16 -78
- package/dist/index293.js +253 -26
- package/dist/index294.js +7 -21
- package/dist/index295.js +138 -22
- package/dist/index296.js +83 -16
- package/dist/index297.js +21 -15
- package/dist/index298.js +3 -23
- package/dist/index299.js +27 -2
- package/dist/index302.js +6 -6
- package/dist/index304.js +3 -3
- package/dist/index314.js +1 -1
- package/dist/index315.js +3 -3
- package/dist/index318.js +1 -1
- package/dist/index319.js +1 -1
- package/dist/index321.js +1 -1
- package/dist/index322.js +2 -2
- package/dist/index323.js +1 -1
- package/dist/index324.js +1 -1
- package/dist/index325.js +7 -7
- package/dist/index326.js +1 -1
- package/dist/index327.js +1 -1
- package/dist/index328.js +1 -1
- package/dist/index329.js +1 -1
- package/dist/index330.js +1 -1
- package/dist/index331.js +1 -1
- package/dist/index332.js +1 -1
- package/dist/index333.js +1 -1
- package/dist/index334.js +1 -1
- package/dist/index335.js +2 -15
- package/dist/index336.js +15 -84
- package/dist/index337.js +70 -188
- package/dist/index338.js +176 -220
- package/dist/index339.js +245 -8
- package/dist/index340.js +36 -12
- package/dist/index341.js +8 -54
- package/dist/index342.js +12 -11
- package/dist/index343.js +52 -11
- package/dist/index344.js +9 -55
- package/dist/index345.js +13 -51
- package/dist/index346.js +51 -24
- package/dist/index347.js +52 -2
- package/dist/index348.js +31 -5
- package/dist/index349.js +2 -2
- package/dist/index350.js +4 -22
- package/dist/index351.js +2 -41
- package/dist/index352.js +23 -2
- package/dist/index353.js +40 -10
- package/dist/index354.js +2 -20
- package/dist/index355.js +10 -9
- package/dist/index356.js +20 -10
- package/dist/index357.js +9 -16
- package/dist/index358.js +10 -2
- package/dist/index359.js +16 -8
- package/dist/index360.js +2 -10
- package/dist/index361.js +8 -13
- package/dist/index362.js +9 -36
- package/dist/index363.js +14 -19
- package/dist/index364.js +17 -55
- package/dist/index365.js +56 -28
- package/dist/index366.js +28 -6
- package/dist/index367.js +6 -51
- package/dist/index368.js +51 -6
- package/dist/index369.js +7 -12
- package/dist/index370.js +12 -7
- package/dist/index371.js +6 -27
- package/dist/index372.js +28 -2
- package/dist/index373.js +2 -70
- package/dist/index374.js +67 -164
- package/dist/index375.js +167 -20
- package/dist/index376.js +9 -9
- package/dist/index377.js +19 -63
- package/dist/index378.js +61 -34
- package/dist/index379.js +36 -12
- package/dist/index38.js +3 -2
- package/dist/index380.js +31 -7
- package/dist/index381.js +10 -30
- package/dist/index382.js +3 -10
- package/dist/index383.js +3 -3
- package/dist/index384.js +13 -4
- package/dist/index385.js +7 -12
- package/dist/index386.js +11 -4
- package/dist/index387.js +5 -33
- package/dist/index388.js +33 -31
- package/dist/index389.js +28 -25
- package/dist/index39.js +1 -1
- package/dist/index390.js +26 -59
- package/dist/index391.js +59 -99
- package/dist/index392.js +1 -1
- package/dist/index393.js +100 -90
- package/dist/index394.js +91 -98
- package/dist/index395.js +98 -3
- package/dist/index396.js +3 -2
- package/dist/index397.js +2 -2
- package/dist/index398.js +2 -17
- package/dist/index399.js +15 -11
- package/dist/index40.js +1 -1
- package/dist/index400.js +13 -6
- package/dist/index401.js +6 -32
- package/dist/index402.js +34 -0
- package/dist/index41.js +1 -1
- package/dist/index42.js +1 -1
- package/dist/index43.js +1 -1
- package/dist/index44.js +1 -1
- package/dist/index45.js +1 -1
- package/dist/index46.js +1 -1
- package/dist/index47.js +1 -1
- package/dist/index48.js +1 -1
- package/dist/index49.js +2 -2
- package/dist/index50.js +1 -1
- package/dist/index51.js +2 -2
- package/dist/index52.js +1 -1
- package/dist/index53.js +1 -1
- package/dist/index54.js +1 -1
- package/dist/index55.js +1 -1
- package/dist/index57.js +2 -2
- package/dist/index59.js +1 -1
- package/dist/index61.js +5 -5
- package/dist/index62.js +1 -1
- package/dist/index74.js +2 -2
- package/dist/index78.js +1 -1
- package/dist/index83.js +1 -1
- package/dist/index88.js +1 -1
- package/dist/index90.js +3 -3
- package/dist/index92.js +2 -2
- package/dist/index98.js +2 -2
- package/package.json +1 -1
- package/dist/index171.js +0 -116
- package/dist/index187.js +0 -20
- package/dist/index200.js +0 -5940
- /package/dist/{index133.js → index134.js} +0 -0
- /package/dist/{index140.js → index141.js} +0 -0
- /package/dist/{index142.js → index143.js} +0 -0
- /package/dist/{index144.js → index145.js} +0 -0
- /package/dist/{index152.js → index153.js} +0 -0
- /package/dist/{index154.js → index155.js} +0 -0
- /package/dist/{index156.js → index157.js} +0 -0
- /package/dist/{index159.js → index160.js} +0 -0
- /package/dist/{index166.js → index167.js} +0 -0
package/dist/index270.js
CHANGED
|
@@ -1,57 +1,54 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
name: "blockquote",
|
|
1
|
+
import { Mark as r, markPasteRule as n, markInputRule as a, mergeAttributes as d } from "./index267.js";
|
|
2
|
+
var o = /(^|[^`])`([^`]+)`(?!`)$/, u = /(^|[^`])`([^`]+)`(?!`)/g, i = r.create({
|
|
3
|
+
name: "code",
|
|
5
4
|
addOptions() {
|
|
6
5
|
return {
|
|
7
6
|
HTMLAttributes: {}
|
|
8
7
|
};
|
|
9
8
|
},
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
9
|
+
excludes: "_",
|
|
10
|
+
code: !0,
|
|
11
|
+
exitable: !0,
|
|
13
12
|
parseHTML() {
|
|
14
|
-
return [{ tag: "
|
|
13
|
+
return [{ tag: "code" }];
|
|
15
14
|
},
|
|
16
|
-
renderHTML({ HTMLAttributes:
|
|
17
|
-
return
|
|
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
|
-
`);
|
|
15
|
+
renderHTML({ HTMLAttributes: e }) {
|
|
16
|
+
return ["code", d(this.options.HTMLAttributes, e), 0];
|
|
32
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)}\`` : "",
|
|
33
21
|
addCommands() {
|
|
34
22
|
return {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
23
|
+
setCode: () => ({ commands: e }) => e.setMark(this.name),
|
|
24
|
+
toggleCode: () => ({ commands: e }) => e.toggleMark(this.name),
|
|
25
|
+
unsetCode: () => ({ commands: e }) => e.unsetMark(this.name)
|
|
38
26
|
};
|
|
39
27
|
},
|
|
40
28
|
addKeyboardShortcuts() {
|
|
41
29
|
return {
|
|
42
|
-
"Mod-
|
|
30
|
+
"Mod-e": () => this.editor.commands.toggleCode()
|
|
43
31
|
};
|
|
44
32
|
},
|
|
45
33
|
addInputRules() {
|
|
46
34
|
return [
|
|
47
|
-
|
|
48
|
-
find:
|
|
35
|
+
a({
|
|
36
|
+
find: o,
|
|
37
|
+
type: this.type
|
|
38
|
+
})
|
|
39
|
+
];
|
|
40
|
+
},
|
|
41
|
+
addPasteRules() {
|
|
42
|
+
return [
|
|
43
|
+
n({
|
|
44
|
+
find: u,
|
|
49
45
|
type: this.type
|
|
50
46
|
})
|
|
51
47
|
];
|
|
52
48
|
}
|
|
53
49
|
});
|
|
54
50
|
export {
|
|
55
|
-
|
|
56
|
-
|
|
51
|
+
i as Code,
|
|
52
|
+
o as inputRegex,
|
|
53
|
+
u as pasteRegex
|
|
57
54
|
};
|
package/dist/index271.js
CHANGED
|
@@ -1,79 +1,217 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
var
|
|
4
|
-
name: "
|
|
1
|
+
import { Node as k, textblockTypeInputRule as S, mergeAttributes as C } from "./index267.js";
|
|
2
|
+
import { Plugin as w, PluginKey as B, TextSelection as T, Selection as L } from "./index282.js";
|
|
3
|
+
var y = 4, M = /^```([a-z]+)?[\s\n]$/, N = /^~~~([a-z]+)?[\s\n]$/, $ = k.create({
|
|
4
|
+
name: "codeBlock",
|
|
5
5
|
addOptions() {
|
|
6
6
|
return {
|
|
7
|
+
languageClassPrefix: "language-",
|
|
8
|
+
exitOnTripleEnter: !0,
|
|
9
|
+
exitOnArrowDown: !0,
|
|
10
|
+
defaultLanguage: null,
|
|
11
|
+
enableTabIndentation: !1,
|
|
12
|
+
tabSize: y,
|
|
7
13
|
HTMLAttributes: {}
|
|
8
14
|
};
|
|
9
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
|
+
},
|
|
10
37
|
parseHTML() {
|
|
11
38
|
return [
|
|
12
39
|
{
|
|
13
|
-
tag: "
|
|
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
|
|
40
|
+
tag: "pre",
|
|
41
|
+
preserveWhitespace: "full"
|
|
26
42
|
}
|
|
27
43
|
];
|
|
28
44
|
},
|
|
29
|
-
renderHTML({ HTMLAttributes: t }) {
|
|
30
|
-
return
|
|
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;
|
|
31
75
|
},
|
|
32
|
-
markdownTokenName: "strong",
|
|
33
|
-
parseMarkdown: (t, e) => e.applyMark("bold", e.parseInline(t.tokens || [])),
|
|
34
|
-
renderMarkdown: (t, e) => `**${e.renderChildren(t)}**`,
|
|
35
76
|
addCommands() {
|
|
36
77
|
return {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
unsetBold: () => ({ commands: t }) => t.unsetMark(this.name)
|
|
78
|
+
setCodeBlock: (e) => ({ commands: t }) => t.setNode(this.name, e),
|
|
79
|
+
toggleCodeBlock: (e) => ({ commands: t }) => t.toggleNode(this.name, "paragraph", e)
|
|
40
80
|
};
|
|
41
81
|
},
|
|
42
82
|
addKeyboardShortcuts() {
|
|
43
83
|
return {
|
|
44
|
-
"Mod-
|
|
45
|
-
|
|
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
|
+
}
|
|
46
171
|
};
|
|
47
172
|
},
|
|
48
173
|
addInputRules() {
|
|
49
174
|
return [
|
|
50
|
-
|
|
51
|
-
find:
|
|
52
|
-
type: this.type
|
|
175
|
+
S({
|
|
176
|
+
find: M,
|
|
177
|
+
type: this.type,
|
|
178
|
+
getAttributes: (e) => ({
|
|
179
|
+
language: e[1]
|
|
180
|
+
})
|
|
53
181
|
}),
|
|
54
|
-
|
|
55
|
-
find:
|
|
56
|
-
type: this.type
|
|
182
|
+
S({
|
|
183
|
+
find: N,
|
|
184
|
+
type: this.type,
|
|
185
|
+
getAttributes: (e) => ({
|
|
186
|
+
language: e[1]
|
|
187
|
+
})
|
|
57
188
|
})
|
|
58
189
|
];
|
|
59
190
|
},
|
|
60
|
-
|
|
191
|
+
addProseMirrorPlugins() {
|
|
61
192
|
return [
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
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
|
+
}
|
|
69
209
|
})
|
|
70
210
|
];
|
|
71
211
|
}
|
|
72
212
|
});
|
|
73
213
|
export {
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
i as underscoreInputRegex,
|
|
78
|
-
u as underscorePasteRegex
|
|
214
|
+
$ as CodeBlock,
|
|
215
|
+
M as backtickInputRegex,
|
|
216
|
+
N as tildeInputRegex
|
|
79
217
|
};
|
package/dist/index272.js
CHANGED
|
@@ -1,54 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
var o =
|
|
3
|
-
name: "
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
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
|
-
}
|
|
1
|
+
import { Node as n } from "./index267.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
|
+
`) : ""
|
|
49
9
|
});
|
|
50
10
|
export {
|
|
51
|
-
|
|
52
|
-
o as inputRegex,
|
|
53
|
-
u as pasteRegex
|
|
11
|
+
o as Document
|
|
54
12
|
};
|
package/dist/index273.js
CHANGED
|
@@ -1,217 +1,59 @@
|
|
|
1
|
-
import { Node as
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { Node as l, mergeAttributes as c } from "./index267.js";
|
|
2
|
+
var f = l.create({
|
|
3
|
+
name: "hardBreak",
|
|
4
|
+
markdownTokenName: "br",
|
|
5
5
|
addOptions() {
|
|
6
6
|
return {
|
|
7
|
-
|
|
8
|
-
exitOnTripleEnter: !0,
|
|
9
|
-
exitOnArrowDown: !0,
|
|
10
|
-
defaultLanguage: null,
|
|
11
|
-
enableTabIndentation: !1,
|
|
12
|
-
tabSize: y,
|
|
7
|
+
keepMarks: !0,
|
|
13
8
|
HTMLAttributes: {}
|
|
14
9
|
};
|
|
15
10
|
},
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
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
|
-
},
|
|
11
|
+
inline: !0,
|
|
12
|
+
group: "inline",
|
|
13
|
+
selectable: !1,
|
|
14
|
+
linebreakReplacement: !0,
|
|
37
15
|
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
|
-
];
|
|
16
|
+
return [{ tag: "br" }];
|
|
57
17
|
},
|
|
58
|
-
|
|
59
|
-
|
|
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
|
-
);
|
|
18
|
+
renderHTML({ HTMLAttributes: e }) {
|
|
19
|
+
return ["br", c(this.options.HTMLAttributes, e)];
|
|
66
20
|
},
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
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;
|
|
21
|
+
renderText() {
|
|
22
|
+
return `
|
|
23
|
+
`;
|
|
75
24
|
},
|
|
25
|
+
renderMarkdown: () => `
|
|
26
|
+
`,
|
|
27
|
+
parseMarkdown: () => ({
|
|
28
|
+
type: "hardBreak"
|
|
29
|
+
}),
|
|
76
30
|
addCommands() {
|
|
77
31
|
return {
|
|
78
|
-
|
|
79
|
-
|
|
32
|
+
setHardBreak: () => ({ commands: e, chain: n, state: a, editor: s }) => e.first([
|
|
33
|
+
() => e.exitCode(),
|
|
34
|
+
() => e.command(() => {
|
|
35
|
+
const { selection: r, storedMarks: o } = a;
|
|
36
|
+
if (r.$from.parent.type.spec.isolating)
|
|
37
|
+
return !1;
|
|
38
|
+
const { keepMarks: i } = this.options, { splittableMarks: d } = s.extensionManager, t = o || r.$to.parentOffset && r.$from.marks();
|
|
39
|
+
return n().insertContent({ type: this.name }).command(({ tr: u, dispatch: k }) => {
|
|
40
|
+
if (k && t && i) {
|
|
41
|
+
const m = t.filter((p) => d.includes(p.type.name));
|
|
42
|
+
u.ensureMarks(m);
|
|
43
|
+
}
|
|
44
|
+
return !0;
|
|
45
|
+
}).run();
|
|
46
|
+
})
|
|
47
|
+
])
|
|
80
48
|
};
|
|
81
49
|
},
|
|
82
50
|
addKeyboardShortcuts() {
|
|
83
51
|
return {
|
|
84
|
-
"Mod-
|
|
85
|
-
|
|
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
|
-
}
|
|
52
|
+
"Mod-Enter": () => this.editor.commands.setHardBreak(),
|
|
53
|
+
"Shift-Enter": () => this.editor.commands.setHardBreak()
|
|
171
54
|
};
|
|
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
55
|
}
|
|
212
56
|
});
|
|
213
57
|
export {
|
|
214
|
-
|
|
215
|
-
M as backtickInputRegex,
|
|
216
|
-
N as tildeInputRegex
|
|
58
|
+
f as HardBreak
|
|
217
59
|
};
|