tiny-markdown-editor 0.1.33 → 0.2.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/README.md +88 -0
- package/dist/tiny-mde.js +3025 -3406
- package/dist/tiny-mde.min.js +1 -1
- package/dist/tiny-mde.tiny.js +1 -1
- package/lib/TinyMDE.d.ts +99 -0
- package/lib/TinyMDE.js +1452 -1714
- package/lib/TinyMDECommandBar.d.ts +35 -0
- package/lib/TinyMDECommandBar.js +311 -260
- package/lib/grammar.d.ts +77 -0
- package/lib/grammar.js +272 -367
- package/lib/index.d.ts +3 -0
- package/lib/index.js +9 -19
- package/lib/svg/svg.d.ts +2 -0
- package/lib/svg/svg.js +17 -21
- package/lib/tiny.d.ts +2 -0
- package/lib/tiny.js +7 -12
- package/package.json +12 -3
- package/globals.d.ts +0 -175
package/lib/grammar.js
CHANGED
|
@@ -1,406 +1,311 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
});
|
|
6
|
-
exports.htmlBlockGrammar = exports.commands = void 0;
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.commands = exports.inlineGrammar = exports.htmlBlockGrammar = exports.lineGrammar = exports.punctuationTrailing = exports.punctuationLeading = void 0;
|
|
4
|
+
exports.createMergedInlineGrammar = createMergedInlineGrammar;
|
|
7
5
|
exports.htmlescape = htmlescape;
|
|
8
|
-
exports.punctuationTrailing = exports.punctuationLeading = exports.lineGrammar = exports.inlineGrammar = void 0;
|
|
9
|
-
require("core-js/modules/es.regexp.flags.js");
|
|
10
|
-
// const replacements = {
|
|
11
|
-
// ASCIIPunctuation: '!"#$%&\'()*+,\\-./:;<=>?@\\[\\]^_`{|}~',
|
|
12
|
-
// TriggerChars: '`_\*\[\]\(\)',
|
|
13
|
-
// Scheme: `[A-Za-z][A-Za-z0-9\+\.\-]{1,31}`,
|
|
14
|
-
// Email: `[a-zA-Z0-9.!#$%&'*+/=?^_\`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*`, // From CommonMark spec
|
|
15
|
-
|
|
16
|
-
// }
|
|
17
6
|
const replacements = {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
KnownTag: /address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h1|h2|h3|h4|h5|h6|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|nav|noframes|ol|optgroup|option|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul/
|
|
7
|
+
ASCIIPunctuation: /[!"#$%&'()*+,\-./:;<=>?@[\]^_`{|}~\\]/,
|
|
8
|
+
NotTriggerChar: /[^`_*[\]()<>!~]/,
|
|
9
|
+
Scheme: /[A-Za-z][A-Za-z0-9+.-]{1,31}/,
|
|
10
|
+
Email: /[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*/, // From CommonMark spec
|
|
11
|
+
HTMLOpenTag: /<HTMLTagName(?:HTMLAttribute)*\s*\/?>/,
|
|
12
|
+
HTMLCloseTag: /<\/HTMLTagName\s*>/,
|
|
13
|
+
HTMLTagName: /[A-Za-z][A-Za-z0-9-]*/,
|
|
14
|
+
HTMLComment: /<!--(?:[^>-]|(?:[^>-](?:[^-]|-[^-])*[^-]))-->/,
|
|
15
|
+
HTMLPI: /<\?(?:|.|(?:[^?]|\?[^>])*)\?>/,
|
|
16
|
+
HTMLDeclaration: /<![A-Z]+\s[^>]*>/,
|
|
17
|
+
HTMLCDATA: /<!\[CDATA\[.*?\]\]>/,
|
|
18
|
+
HTMLAttribute: /\s+[A-Za-z_:][A-Za-z0-9_.:-]*(?:HTMLAttValue)?/,
|
|
19
|
+
HTMLAttValue: /\s*=\s*(?:(?:'[^']*')|(?:"[^"]*")|(?:[^\s"'=<>`]+))/,
|
|
20
|
+
KnownTag: /address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h1|h2|h3|h4|h5|h6|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|nav|noframes|ol|optgroup|option|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul/
|
|
33
21
|
};
|
|
34
|
-
|
|
35
22
|
// From CommonMark.js.
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
// export const inlineTriggerChars = new RegExp(`[${replacements.TriggerChars}]`);
|
|
40
|
-
|
|
23
|
+
exports.punctuationLeading = new RegExp(/^(?:[!"#$%&'()*+,\-./:;<=>?@[\]\\^_`{|}~\xA1\xA7\xAB\xB6\xB7\xBB\xBF\u037E\u0387\u055A-\u055F\u0589\u058A\u05BE\u05C0\u05C3\u05C6\u05F3\u05F4\u0609\u060A\u060C\u060D\u061B\u061E\u061F\u066A-\u066D\u06D4\u0700-\u070D\u07F7-\u07F9\u0830-\u083E\u085E\u0964\u0965\u0970\u0AF0\u0DF4\u0E4F\u0E5A\u0E5B\u0F04-\u0F12\u0F14\u0F3A-\u0F3D\u0F85\u0FD0-\u0FD4\u0FD9\u0FDA\u104A-\u104F\u10FB\u1360-\u1368\u1400\u166D\u166E\u169B\u169C\u16EB-\u16ED\u1735\u1736\u17D4-\u17D6\u17D8-\u17DA\u1800-\u180A\u1944\u1945\u1A1E\u1A1F\u1AA0-\u1AA6\u1AA8-\u1AAD\u1B5A-\u1B60\u1BFC-\u1BFF\u1C3B-\u1C3F\u1C7E\u1C7F\u1CC0-\u1CC7\u1CD3\u2010-\u2027\u2030-\u2043\u2045-\u2051\u2053-\u205E\u207D\u207E\u208D\u208E\u2308-\u230B\u2329\u232A\u2768-\u2775\u27C5\u27C6\u27E6-\u27EF\u2983-\u2998\u29D8-\u29DB\u29FC\u29FD\u2CF9-\u2CFC\u2CFE\u2CFF\u2D70\u2E00-\u2E2E\u2E30-\u2E42\u3001-\u3003\u3008-\u3011\u3014-\u301F\u3030\u303D\u30A0\u30FB\uA4FE\uA4FF\uA60D-\uA60F\uA673\uA67E\uA6F2-\uA6F7\uA874-\uA877\uA8CE\uA8CF\uA8F8-\uA8FA\uA8FC\uA92E\uA92F\uA95F\uA9C1-\uA9CD\uA9DE\uA9DF\uAA5C-\uAA5F\uAADE\uAADF\uAAF0\uAAF1\uABEB\uFD3E\uFD3F\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE61\uFE63\uFE68\uFE6A\uFE6B\uFF01-\uFF03\uFF05-\uFF0A\uFF0C-\uFF0F\uFF1A\uFF1B\uFF1F\uFF20\uFF3B-\uFF3D\uFF3F\uFF5B\uFF5D\uFF5F-\uFF65]|\uD800[\uDD00-\uDD02\uDF9F\uDFD0]|\uD801\uDD6F|\uD802[\uDC57\uDD1F\uDD3F\uDE50-\uDE58\uDE7F\uDEF0-\uDEF6\uDF39-\uDF3F\uDF99-\uDF9C]|\uD804[\uDC47-\uDC4D\uDCBB\uDCBC\uDCBE-\uDCC1\uDD40-\uDD43\uDD74\uDD75\uDDC5-\uDDC9\uDDCD\uDDDB\uDDDD-\uDDDF\uDE38-\uDE3D\uDEA9]|\uD805[\uDCC6\uDDC1-\uDDD7\uDE41-\uDE43\uDF3C-\uDF3E]|\uD809[\uDC70-\uDC74]|\uD81A[\uDE6E\uDE6F\uDEF5\uDF37-\uDF3B\uDF44]|\uD82F\uDC9F|\uD836[\uDE87-\uDE8B])/);
|
|
24
|
+
exports.punctuationTrailing = new RegExp(/(?:[!"#$%&'()*+,\-./:;<=>?@[\]\\^_`{|}~\xA1\xA7\xAB\xB6\xB7\xBB\xBF\u037E\u0387\u055A-\u055F\u0589\u058A\u05BE\u05C0\u05C3\u05C6\u05F3\u05F4\u0609\u060A\u060C\u060D\u061B\u061E\u061F\u066A-\u066D\u06D4\u0700-\u070D\u07F7-\u07F9\u0830-\u083E\u085E\u0964\u0965\u0970\u0AF0\u0DF4\u0E4F\u0E5A\u0E5B\u0F04-\u0F12\u0F14\u0F3A-\u0F3D\u0F85\u0FD0-\u0FD4\u0FD9\u0FDA\u104A-\u104F\u10FB\u1360-\u1368\u1400\u166D\u166E\u169B\u169C\u16EB-\u16ED\u1735\u1736\u17D4-\u17D6\u17D8-\u17DA\u1800-\u180A\u1944\u1945\u1A1E\u1A1F\u1AA0-\u1AA6\u1AA8-\u1AAD\u1B5A-\u1B60\u1BFC-\u1BFF\u1C3B-\u1C3F\u1C7E\u1C7F\u1CC0-\u1CC7\u1CD3\u2010-\u2027\u2030-\u2043\u2045-\u2051\u2053-\u205E\u207D\u207E\u208D\u208E\u2308-\u230B\u2329\u232A\u2768-\u2775\u27C5\u27C6\u27E6-\u27EF\u2983-\u2998\u29D8-\u29DB\u29FC\u29FD\u2CF9-\u2CFC\u2CFE\u2CFF\u2D70\u2E00-\u2E2E\u2E30-\u2E42\u3001-\u3003\u3008-\u3011\u3014-\u301F\u3030\u303D\u30A0\u30FB\uA4FE\uA4FF\uA60D-\uA60F\uA673\uA67E\uA6F2-\uA6F7\uA874-\uA877\uA8CE\uA8CF\uA8F8-\uA8FA\uA8FC\uA92E\uA92F\uA95F\uA9C1-\uA9CD\uA9DE\uA9DF\uAA5C-\uAA5F\uAADE\uAADF\uAAF0\uAAF1\uABEB\uFD3E\uFD3F\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE61\uFE63\uFE68\uFE6A\uFE6B\uFF01-\uFF03\uFF05-\uFF0A\uFF0C-\uFF0F\uFF1A\uFF1B\uFF1F\uFF20\uFF3B-\uFF3D\uFF3F\uFF5B\uFF5D\uFF5F-\uFF65]|\uD800[\uDD00-\uDD02\uDF9F\uDFD0]|\uD801\uDD6F|\uD802[\uDC57\uDD1F\uDD3F\uDE50-\uDE58\uDE7F\uDEF0-\uDEF6\uDF39-\uDF3F\uDF99-\uDF9C]|\uD804[\uDC47-\uDC4D\uDCBB\uDCBC\uDCBE-\uDCC1\uDD40-\uDD43\uDD74\uDD75\uDDC5-\uDDC9\uDDCD\uDDDB\uDDDD-\uDDDF\uDE38-\uDE3D\uDEA9]|\uD805[\uDCC6\uDDC1-\uDDD7\uDE41-\uDE43\uDF3C-\uDF3E]|\uD809[\uDC70-\uDC74]|\uD81A[\uDE6E\uDE6F\uDEF5\uDF37-\uDF3B\uDF44]|\uD82F\uDC9F|\uD836[\uDE87-\uDE8B])$/);
|
|
41
25
|
/**
|
|
42
|
-
* This is CommonMark's block grammar, but we're ignoring nested blocks here.
|
|
26
|
+
* This is CommonMark's block grammar, but we're ignoring nested blocks here.
|
|
43
27
|
*/
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
28
|
+
exports.lineGrammar = {
|
|
29
|
+
TMH1: {
|
|
30
|
+
regexp: /^( {0,3}#\s)(.*?)((?:\s+#+\s*)?)$/,
|
|
31
|
+
replacement: '<span class="TMMark TMMark_TMH1">$1</span>$$2<span class="TMMark TMMark_TMH1">$3</span>'
|
|
32
|
+
},
|
|
33
|
+
TMH2: {
|
|
34
|
+
regexp: /^( {0,3}##\s)(.*?)((?:\s+#+\s*)?)$/,
|
|
35
|
+
replacement: '<span class="TMMark TMMark_TMH2">$1</span>$$2<span class="TMMark TMMark_TMH2">$3</span>'
|
|
36
|
+
},
|
|
37
|
+
TMH3: {
|
|
38
|
+
regexp: /^( {0,3}###\s)(.*?)((?:\s+#+\s*)?)$/,
|
|
39
|
+
replacement: '<span class="TMMark TMMark_TMH3">$1</span>$$2<span class="TMMark TMMark_TMH3">$3</span>'
|
|
40
|
+
},
|
|
41
|
+
TMH4: {
|
|
42
|
+
regexp: /^( {0,3}####\s)(.*?)((?:\s+#+\s*)?)$/,
|
|
43
|
+
replacement: '<span class="TMMark TMMark_TMH4">$1</span>$$2<span class="TMMark TMMark_TMH4">$3</span>'
|
|
44
|
+
},
|
|
45
|
+
TMH5: {
|
|
46
|
+
regexp: /^( {0,3}#####\s)(.*?)((?:\s+#+\s*)?)$/,
|
|
47
|
+
replacement: '<span class="TMMark TMMark_TMH5">$1</span>$$2<span class="TMMark TMMark_TMH5">$3</span>'
|
|
48
|
+
},
|
|
49
|
+
TMH6: {
|
|
50
|
+
regexp: /^( {0,3}######\s)(.*?)((?:\s+#+\s*)?)$/,
|
|
51
|
+
replacement: '<span class="TMMark TMMark_TMH6">$1</span>$$2<span class="TMMark TMMark_TMH6">$3</span>'
|
|
52
|
+
},
|
|
53
|
+
TMBlockquote: {
|
|
54
|
+
regexp: /^( {0,3}>[ ]?)(.*)$/,
|
|
55
|
+
replacement: '<span class="TMMark TMMark_TMBlockquote">$1</span>$$2'
|
|
56
|
+
},
|
|
57
|
+
TMCodeFenceBacktickOpen: {
|
|
58
|
+
regexp: /^( {0,3}(?<seq>````*)\s*)([^`]*?)(\s*)$/,
|
|
59
|
+
replacement: '<span class="TMMark TMMark_TMCodeFenceBacktick">$1</span><span class="TMInfoString">$3</span>$4'
|
|
60
|
+
},
|
|
61
|
+
TMCodeFenceTildeOpen: {
|
|
62
|
+
regexp: /^( {0,3}(?<seq>~~~~*)\s*)(.*?)(\s*)$/,
|
|
63
|
+
replacement: '<span class="TMMark TMMark_TMCodeFenceTilde">$1</span><span class="TMInfoString">$3</span>$4'
|
|
64
|
+
},
|
|
65
|
+
TMCodeFenceBacktickClose: {
|
|
66
|
+
regexp: /^( {0,3}(?<seq>````*))(\s*)$/,
|
|
67
|
+
replacement: '<span class="TMMark TMMark_TMCodeFenceBacktick">$1</span>$3'
|
|
68
|
+
},
|
|
69
|
+
TMCodeFenceTildeClose: {
|
|
70
|
+
regexp: /^( {0,3}(?<seq>~~~~*))(\s*)$/,
|
|
71
|
+
replacement: '<span class="TMMark TMMark_TMCodeFenceTilde">$1</span>$3'
|
|
72
|
+
},
|
|
73
|
+
TMBlankLine: {
|
|
74
|
+
regexp: /^([ \t]*)$/,
|
|
75
|
+
replacement: '$0'
|
|
76
|
+
},
|
|
77
|
+
TMSetextH1Marker: {
|
|
78
|
+
regexp: /^ {0,3}=+\s*$/,
|
|
79
|
+
replacement: '<span class="TMMark TMMark_TMSetextH1Marker">$0</span>'
|
|
80
|
+
},
|
|
81
|
+
TMSetextH2Marker: {
|
|
82
|
+
regexp: /^ {0,3}-+\s*$/,
|
|
83
|
+
replacement: '<span class="TMMark TMMark_TMSetextH1Marker">$0</span>'
|
|
84
|
+
},
|
|
85
|
+
TMHR: {
|
|
86
|
+
regexp: /^( {0,3}(\*[ \t]*\*[ \t]*\*[ \t*]*)|(-[ \t]*-[ \t]*-[ \t-]*)|(_[ \t]*_[ \t]*_[ \t_]*))$/,
|
|
87
|
+
replacement: '<span class="TMMark TMMark_TMHR">$0</span>'
|
|
88
|
+
},
|
|
89
|
+
TMUL: {
|
|
90
|
+
regexp: /^( {0,3}[+*-] {1,4})(.*)$/,
|
|
91
|
+
replacement: '<span class="TMMark TMMark_TMUL">$1</span>$$2'
|
|
92
|
+
},
|
|
93
|
+
TMOL: {
|
|
94
|
+
regexp: /^( {0,3}\d{1,9}[.)] {1,4})(.*)$/,
|
|
95
|
+
replacement: '<span class="TMMark TMMark_TMOL">$1</span>$$2'
|
|
96
|
+
},
|
|
97
|
+
// TODO: This is currently preventing sublists (and any content within list items, really) from working
|
|
98
|
+
TMIndentedCode: {
|
|
99
|
+
regexp: /^( {4}|\t)(.*)$/,
|
|
100
|
+
replacement: '<span class="TMMark TMMark_TMIndentedCode">$1</span>$2'
|
|
101
|
+
},
|
|
102
|
+
TMLinkReferenceDefinition: {
|
|
103
|
+
// TODO: Link destination can't include unbalanced parantheses, but we just ignore that here
|
|
104
|
+
regexp: /^( {0,3}\[\s*)([^\s\]](?:[^\]]|\\\])*?)(\s*\]:\s*)((?:[^\s<>]+)|(?:<(?:[^<>\\]|\\.)*>))?(\s*)((?:\((?:[^()\\]|\\.)*\))|(?:"(?:[^"\\]|\\.)*")|(?:'(?:[^'\\]|\\.)*'))?(\s*)$/,
|
|
105
|
+
replacement: '<span class="TMMark TMMark_TMLinkReferenceDefinition">$1</span><span class="TMLinkLabel TMLinkLabel_Definition">$2</span><span class="TMMark TMMark_TMLinkReferenceDefinition">$3</span><span class="TMLinkDestination">$4</span>$5<span class="TMLinkTitle">$6</span>$7',
|
|
106
|
+
labelPlaceholder: 2, // this defines which placeholder in the above regex is the link "label"
|
|
107
|
+
},
|
|
124
108
|
};
|
|
125
|
-
|
|
126
109
|
/**
|
|
127
110
|
* HTML blocks have multiple different classes of opener and closer. This array defines all the cases
|
|
128
111
|
*/
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
},
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
start: /^ {0,3}<\?/,
|
|
139
|
-
end: /\?>/,
|
|
140
|
-
paraInterrupt: true
|
|
141
|
-
}, {
|
|
142
|
-
start: /^ {0,3}<![A-Z]/,
|
|
143
|
-
end: />/,
|
|
144
|
-
paraInterrupt: true
|
|
145
|
-
}, {
|
|
146
|
-
start: /^ {0,3}<!\[CDATA\[/,
|
|
147
|
-
end: /\]\]>/,
|
|
148
|
-
paraInterrupt: true
|
|
149
|
-
}, {
|
|
150
|
-
start: /^ {0,3}(?:<|<\/)(?:KnownTag)(?:\s|>|\/>|$)/i,
|
|
151
|
-
end: false,
|
|
152
|
-
paraInterrupt: true
|
|
153
|
-
}, {
|
|
154
|
-
start: /^ {0,3}(?:HTMLOpenTag|HTMLCloseTag)\s*$/,
|
|
155
|
-
end: false,
|
|
156
|
-
paraInterrupt: false
|
|
157
|
-
}];
|
|
158
|
-
|
|
112
|
+
exports.htmlBlockGrammar = [
|
|
113
|
+
{ start: /^ {0,3}<(?:script|pre|style)(?:\s|>|$)/i, end: /(?:<\/script>|<\/pre>|<\/style>)/i, paraInterrupt: true },
|
|
114
|
+
{ start: /^ {0,3}<!--/, end: /-->/, paraInterrupt: true },
|
|
115
|
+
{ start: /^ {0,3}<\?/, end: /\?>/, paraInterrupt: true },
|
|
116
|
+
{ start: /^ {0,3}<![A-Z]/, end: />/, paraInterrupt: true },
|
|
117
|
+
{ start: /^ {0,3}<!\[CDATA\[/, end: /\]\]>/, paraInterrupt: true },
|
|
118
|
+
{ start: /^ {0,3}(?:<|<\/)(?:KnownTag)(?:\s|>|\/>|$)/i, end: false, paraInterrupt: true },
|
|
119
|
+
{ start: /^ {0,3}(?:HTMLOpenTag|HTMLCloseTag)\s*$/, end: false, paraInterrupt: false },
|
|
120
|
+
];
|
|
159
121
|
/**
|
|
160
122
|
* Structure of the object:
|
|
161
123
|
* Top level entries are rules, each consisting of a regular expressions (in string format) as well as a replacement.
|
|
162
124
|
* In the regular expressions, replacements from the object 'replacements' will be processed before compiling into the property regexp.
|
|
163
125
|
*/
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
126
|
+
exports.inlineGrammar = {
|
|
127
|
+
escape: {
|
|
128
|
+
regexp: /^\\(ASCIIPunctuation)/,
|
|
129
|
+
replacement: '<span class="TMMark TMMark_TMEscape">\\</span>$1'
|
|
130
|
+
},
|
|
131
|
+
code: {
|
|
132
|
+
regexp: /^(`+)((?:[^`])|(?:[^`].*?[^`]))(\1)/,
|
|
133
|
+
replacement: '<span class="TMMark TMMark_TMCode">$1</span><code class="TMCode">$2</code><span class="TMMark TMMark_TMCode">$3</span>'
|
|
134
|
+
},
|
|
135
|
+
autolink: {
|
|
136
|
+
regexp: /^<((?:Scheme:[^\s<>]*)|(?:Email))>/,
|
|
137
|
+
replacement: '<span class="TMMark TMMark_TMAutolink"><</span><span class="TMAutolink">$1</span><span class="TMMark TMMark_TMAutolink">></span>'
|
|
138
|
+
},
|
|
139
|
+
html: {
|
|
140
|
+
regexp: /^((?:HTMLOpenTag)|(?:HTMLCloseTag)|(?:HTMLComment)|(?:HTMLPI)|(?:HTMLDeclaration)|(?:HTMLCDATA))/,
|
|
141
|
+
replacement: '<span class="TMHTML">$1</span>',
|
|
142
|
+
},
|
|
143
|
+
linkOpen: {
|
|
144
|
+
regexp: /^\[/,
|
|
145
|
+
replacement: ''
|
|
146
|
+
},
|
|
147
|
+
imageOpen: {
|
|
148
|
+
regexp: /^!\[/,
|
|
149
|
+
replacement: ''
|
|
150
|
+
},
|
|
151
|
+
linkLabel: {
|
|
152
|
+
regexp: /^(\[\s*)([^\]]*?)(\s*\])/,
|
|
153
|
+
replacement: '',
|
|
154
|
+
labelPlaceholder: 2
|
|
155
|
+
},
|
|
156
|
+
default: {
|
|
157
|
+
regexp: /^(.|(?:NotTriggerChar+))/,
|
|
158
|
+
replacement: '$1'
|
|
159
|
+
}
|
|
198
160
|
};
|
|
199
|
-
|
|
200
161
|
// Process replacements in regexps
|
|
201
162
|
const replacementRegexp = new RegExp(Object.keys(replacements).join('|'));
|
|
202
|
-
|
|
203
163
|
// Inline
|
|
204
|
-
const inlineRules = [...Object.keys(inlineGrammar)];
|
|
164
|
+
const inlineRules = [...Object.keys(exports.inlineGrammar)];
|
|
205
165
|
for (let rule of inlineRules) {
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
}
|
|
213
|
-
inlineGrammar[rule].regexp = new RegExp(re, inlineGrammar[rule].regexp.flags);
|
|
166
|
+
let re = exports.inlineGrammar[rule].regexp.source;
|
|
167
|
+
// Replace while there is something to replace. This means it also works over multiple levels (replacements containing replacements)
|
|
168
|
+
while (re.match(replacementRegexp)) {
|
|
169
|
+
re = re.replace(replacementRegexp, (string) => { return replacements[string].source; });
|
|
170
|
+
}
|
|
171
|
+
exports.inlineGrammar[rule].regexp = new RegExp(re, exports.inlineGrammar[rule].regexp.flags);
|
|
214
172
|
}
|
|
215
|
-
|
|
216
173
|
// HTML Block (only opening rule is processed currently)
|
|
217
|
-
for (let rule of htmlBlockGrammar) {
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
174
|
+
for (let rule of exports.htmlBlockGrammar) {
|
|
175
|
+
let re = rule.start.source;
|
|
176
|
+
// Replace while there is something to replace. This means it also works over multiple levels (replacements containing replacements)
|
|
177
|
+
while (re.match(replacementRegexp)) {
|
|
178
|
+
re = re.replace(replacementRegexp, (string) => { return replacements[string].source; });
|
|
179
|
+
}
|
|
180
|
+
rule.start = new RegExp(re, rule.start.flags);
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Creates a merged inline grammar by combining the default inline grammar with custom rules.
|
|
184
|
+
* Custom rules are processed and their regexp patterns are expanded with replacements.
|
|
185
|
+
* @param customRules - Object containing custom inline grammar rules
|
|
186
|
+
* @returns Merged inline grammar object
|
|
187
|
+
*/
|
|
188
|
+
function createMergedInlineGrammar(customRules = {}) {
|
|
189
|
+
const merged = { ...exports.inlineGrammar };
|
|
190
|
+
// Process custom rules
|
|
191
|
+
for (const [ruleName, rule] of Object.entries(customRules)) {
|
|
192
|
+
// Copy the rule to avoid modifying the original
|
|
193
|
+
const processedRule = { ...rule };
|
|
194
|
+
// Process replacements in the regexp
|
|
195
|
+
let regexpSource = rule.regexp.source;
|
|
196
|
+
const replacementRegexp = new RegExp(Object.keys(replacements).join('|'));
|
|
197
|
+
// Replace while there is something to replace
|
|
198
|
+
while (regexpSource.match(replacementRegexp)) {
|
|
199
|
+
regexpSource = regexpSource.replace(replacementRegexp, (match) => {
|
|
200
|
+
return replacements[match].source;
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
processedRule.regexp = new RegExp(regexpSource, rule.regexp.flags);
|
|
204
|
+
merged[ruleName] = processedRule;
|
|
205
|
+
}
|
|
206
|
+
return merged;
|
|
226
207
|
}
|
|
227
|
-
|
|
228
208
|
/**
|
|
229
209
|
* Escapes HTML special characters (<, >, and &) in the string.
|
|
230
210
|
* @param {string} string The raw string to be escaped
|
|
231
211
|
* @returns {string} The string, ready to be used in HTML
|
|
232
212
|
*/
|
|
233
213
|
function htmlescape(string) {
|
|
234
|
-
|
|
214
|
+
return (string ? string : '')
|
|
215
|
+
.replace(/&/g, '&')
|
|
216
|
+
.replace(/</g, '<')
|
|
217
|
+
.replace(/>/g, '>');
|
|
235
218
|
}
|
|
236
219
|
/**
|
|
237
220
|
* Contains the commands that can be sent to the editor. Contains objects with a name representing the name of the command.
|
|
238
221
|
* Each of the objects contains the following keys:
|
|
239
|
-
*
|
|
222
|
+
*
|
|
240
223
|
* - type: Can be either inline (for inline formatting) or line (for block / line formatting).
|
|
241
|
-
* - className: Used to determine whether the command is active at a given position.
|
|
224
|
+
* - className: Used to determine whether the command is active at a given position.
|
|
242
225
|
* For line formatting, this looks at the class of the line element. For inline elements, tries to find an enclosing element with that class.
|
|
243
|
-
* - set / unset: Contain instructions how to set and unset the command. For line type commands, both consist of a pattern and replacement that
|
|
226
|
+
* - set / unset: Contain instructions how to set and unset the command. For line type commands, both consist of a pattern and replacement that
|
|
244
227
|
* will be applied to each line (using String.replace). For inline type commands, the set object contains a pre and post string which will
|
|
245
|
-
* be inserted before and after the selection. The unset object contains a prePattern and a postPattern. Both should be regular expressions and
|
|
228
|
+
* be inserted before and after the selection. The unset object contains a prePattern and a postPattern. Both should be regular expressions and
|
|
246
229
|
* they will be applied to the portion of the line before and after the selection (using String.replace, with an empty replacement string).
|
|
247
230
|
*/
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
unset: {
|
|
330
|
-
pattern: /^( {0,3}###\s+)(.*?)((?:\s+#+\s*)?)$/,
|
|
331
|
-
replacement: '$2'
|
|
332
|
-
}
|
|
333
|
-
},
|
|
334
|
-
h4: {
|
|
335
|
-
type: 'line',
|
|
336
|
-
className: 'TMH4',
|
|
337
|
-
set: {
|
|
338
|
-
pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/,
|
|
339
|
-
replacement: '#### $2'
|
|
340
|
-
},
|
|
341
|
-
unset: {
|
|
342
|
-
pattern: /^( {0,3}####\s+)(.*?)((?:\s+#+\s*)?)$/,
|
|
343
|
-
replacement: '$2'
|
|
344
|
-
}
|
|
345
|
-
},
|
|
346
|
-
h5: {
|
|
347
|
-
type: 'line',
|
|
348
|
-
className: 'TMH5',
|
|
349
|
-
set: {
|
|
350
|
-
pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/,
|
|
351
|
-
replacement: '##### $2'
|
|
352
|
-
},
|
|
353
|
-
unset: {
|
|
354
|
-
pattern: /^( {0,3}#####\s+)(.*?)((?:\s+#+\s*)?)$/,
|
|
355
|
-
replacement: '$2'
|
|
356
|
-
}
|
|
357
|
-
},
|
|
358
|
-
h6: {
|
|
359
|
-
type: 'line',
|
|
360
|
-
className: 'TMH6',
|
|
361
|
-
set: {
|
|
362
|
-
pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/,
|
|
363
|
-
replacement: '###### $2'
|
|
364
|
-
},
|
|
365
|
-
unset: {
|
|
366
|
-
pattern: /^( {0,3}######\s+)(.*?)((?:\s+#+\s*)?)$/,
|
|
367
|
-
replacement: '$2'
|
|
368
|
-
}
|
|
369
|
-
},
|
|
370
|
-
ul: {
|
|
371
|
-
type: 'line',
|
|
372
|
-
className: 'TMUL',
|
|
373
|
-
set: {
|
|
374
|
-
pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/,
|
|
375
|
-
replacement: '- $2'
|
|
376
|
-
},
|
|
377
|
-
unset: {
|
|
378
|
-
pattern: /^( {0,3}[+*-] {1,4})(.*)$/,
|
|
379
|
-
replacement: '$2'
|
|
380
|
-
}
|
|
381
|
-
},
|
|
382
|
-
ol: {
|
|
383
|
-
type: 'line',
|
|
384
|
-
className: 'TMOL',
|
|
385
|
-
set: {
|
|
386
|
-
pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/,
|
|
387
|
-
replacement: '$#. $2'
|
|
388
|
-
},
|
|
389
|
-
unset: {
|
|
390
|
-
pattern: /^( {0,3}\d{1,9}[.)] {1,4})(.*)$/,
|
|
391
|
-
replacement: '$2'
|
|
392
|
-
}
|
|
393
|
-
},
|
|
394
|
-
blockquote: {
|
|
395
|
-
type: 'line',
|
|
396
|
-
className: 'TMBlockquote',
|
|
397
|
-
set: {
|
|
398
|
-
pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/,
|
|
399
|
-
replacement: '> $2'
|
|
400
|
-
},
|
|
401
|
-
unset: {
|
|
402
|
-
pattern: /^( {0,3}>[ ]?)(.*)$/,
|
|
403
|
-
replacement: '$2'
|
|
404
|
-
}
|
|
405
|
-
}
|
|
406
|
-
};
|
|
231
|
+
exports.commands = {
|
|
232
|
+
// Replacements for unset for inline commands are '' by default
|
|
233
|
+
bold: {
|
|
234
|
+
type: 'inline',
|
|
235
|
+
className: 'TMStrong',
|
|
236
|
+
set: { pre: '**', post: '**' },
|
|
237
|
+
unset: { prePattern: /(?:\*\*|__)$/, postPattern: /^(?:\*\*|__)/ }
|
|
238
|
+
},
|
|
239
|
+
italic: {
|
|
240
|
+
type: 'inline',
|
|
241
|
+
className: 'TMEm',
|
|
242
|
+
set: { pre: '*', post: '*' },
|
|
243
|
+
unset: { prePattern: /(?:\*|_)$/, postPattern: /^(?:\*|_)/ }
|
|
244
|
+
},
|
|
245
|
+
code: {
|
|
246
|
+
type: 'inline',
|
|
247
|
+
className: 'TMCode',
|
|
248
|
+
set: { pre: '`', post: '`' },
|
|
249
|
+
unset: { prePattern: /`+$/, postPattern: /^`+/ } // FIXME this doesn't ensure balanced backticks right now
|
|
250
|
+
},
|
|
251
|
+
strikethrough: {
|
|
252
|
+
type: 'inline',
|
|
253
|
+
className: 'TMStrikethrough',
|
|
254
|
+
set: { pre: '~~', post: '~~' },
|
|
255
|
+
unset: { prePattern: /~~$/, postPattern: /^~~/ }
|
|
256
|
+
},
|
|
257
|
+
h1: {
|
|
258
|
+
type: 'line',
|
|
259
|
+
className: 'TMH1',
|
|
260
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '# $2' },
|
|
261
|
+
unset: { pattern: /^( {0,3}#\s+)(.*?)((?:\s+#+\s*)?)$/, replacement: '$2' }
|
|
262
|
+
},
|
|
263
|
+
h2: {
|
|
264
|
+
type: 'line',
|
|
265
|
+
className: 'TMH2',
|
|
266
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '## $2' },
|
|
267
|
+
unset: { pattern: /^( {0,3}##\s+)(.*?)((?:\s+#+\s*)?)$/, replacement: '$2' }
|
|
268
|
+
},
|
|
269
|
+
h3: {
|
|
270
|
+
type: 'line',
|
|
271
|
+
className: 'TMH3',
|
|
272
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '### $2' },
|
|
273
|
+
unset: { pattern: /^( {0,3}###\s+)(.*?)((?:\s+#+\s*)?)$/, replacement: '$2' }
|
|
274
|
+
},
|
|
275
|
+
h4: {
|
|
276
|
+
type: 'line',
|
|
277
|
+
className: 'TMH4',
|
|
278
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '#### $2' },
|
|
279
|
+
unset: { pattern: /^( {0,3}####\s+)(.*?)((?:\s+#+\s*)?)$/, replacement: '$2' }
|
|
280
|
+
},
|
|
281
|
+
h5: {
|
|
282
|
+
type: 'line',
|
|
283
|
+
className: 'TMH5',
|
|
284
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '##### $2' },
|
|
285
|
+
unset: { pattern: /^( {0,3}#####\s+)(.*?)((?:\s+#+\s*)?)$/, replacement: '$2' }
|
|
286
|
+
},
|
|
287
|
+
h6: {
|
|
288
|
+
type: 'line',
|
|
289
|
+
className: 'TMH6',
|
|
290
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '###### $2' },
|
|
291
|
+
unset: { pattern: /^( {0,3}######\s+)(.*?)((?:\s+#+\s*)?)$/, replacement: '$2' }
|
|
292
|
+
},
|
|
293
|
+
ul: {
|
|
294
|
+
type: 'line',
|
|
295
|
+
className: 'TMUL',
|
|
296
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '- $2' },
|
|
297
|
+
unset: { pattern: /^( {0,3}[+*-] {1,4})(.*)$/, replacement: '$2' }
|
|
298
|
+
},
|
|
299
|
+
ol: {
|
|
300
|
+
type: 'line',
|
|
301
|
+
className: 'TMOL',
|
|
302
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '$#. $2' },
|
|
303
|
+
unset: { pattern: /^( {0,3}\d{1,9}[.)] {1,4})(.*)$/, replacement: '$2' }
|
|
304
|
+
},
|
|
305
|
+
blockquote: {
|
|
306
|
+
type: 'line',
|
|
307
|
+
className: 'TMBlockquote',
|
|
308
|
+
set: { pattern: /^( {0,3}(?:(?:#+|[0-9]{1,9}[).]|[>\-*+])\s+)?)(.*)$/, replacement: '> $2' },
|
|
309
|
+
unset: { pattern: /^( {0,3}>[ ]?)(.*)$/, replacement: '$2' }
|
|
310
|
+
},
|
|
311
|
+
};
|