@khanacademy/pure-markdown 0.1.4 → 0.2.0

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/.eslintrc.js CHANGED
@@ -1,3 +1,4 @@
1
+ /* eslint-disable @typescript-eslint/no-var-requires */
1
2
  /* eslint-disable import/no-commonjs */
2
3
  const path = require("path");
3
4
 
package/CHANGELOG.md CHANGED
@@ -1,5 +1,24 @@
1
1
  # @khanacademy/pure-markdown
2
2
 
3
+ ## 0.2.0
4
+
5
+ ### Minor Changes
6
+
7
+ - 53fd3768: Migrate source code to TypeScript
8
+
9
+ ### Patch Changes
10
+
11
+ - Updated dependencies [53fd3768]
12
+ - @khanacademy/perseus-error@0.2.0
13
+ - @khanacademy/simple-markdown@0.9.0
14
+
15
+ ## 0.1.5
16
+
17
+ ### Patch Changes
18
+
19
+ - Updated dependencies [a1b4ab3c]
20
+ - @khanacademy/perseus-error@0.1.5
21
+
3
22
  ## 0.1.4
4
23
 
5
24
  ### Patch Changes
package/dist/es/index.js CHANGED
@@ -2,17 +2,14 @@ import SimpleMarkdown from '@khanacademy/simple-markdown';
2
2
 
3
3
  function ownKeys(object, enumerableOnly) {
4
4
  var keys = Object.keys(object);
5
-
6
5
  if (Object.getOwnPropertySymbols) {
7
6
  var symbols = Object.getOwnPropertySymbols(object);
8
7
  enumerableOnly && (symbols = symbols.filter(function (sym) {
9
8
  return Object.getOwnPropertyDescriptor(object, sym).enumerable;
10
9
  })), keys.push.apply(keys, symbols);
11
10
  }
12
-
13
11
  return keys;
14
12
  }
15
-
16
13
  function _objectSpread2(target) {
17
14
  for (var i = 1; i < arguments.length; i++) {
18
15
  var source = null != arguments[i] ? arguments[i] : {};
@@ -22,11 +19,10 @@ function _objectSpread2(target) {
22
19
  Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
23
20
  });
24
21
  }
25
-
26
22
  return target;
27
23
  }
28
-
29
24
  function _defineProperty(obj, key, value) {
25
+ key = _toPropertyKey(key);
30
26
  if (key in obj) {
31
27
  Object.defineProperty(obj, key, {
32
28
  value: value,
@@ -37,9 +33,22 @@ function _defineProperty(obj, key, value) {
37
33
  } else {
38
34
  obj[key] = value;
39
35
  }
40
-
41
36
  return obj;
42
37
  }
38
+ function _toPrimitive(input, hint) {
39
+ if (typeof input !== "object" || input === null) return input;
40
+ var prim = input[Symbol.toPrimitive];
41
+ if (prim !== undefined) {
42
+ var res = prim.call(input, hint || "default");
43
+ if (typeof res !== "object") return res;
44
+ throw new TypeError("@@toPrimitive must return a primitive value.");
45
+ }
46
+ return (hint === "string" ? String : Number)(input);
47
+ }
48
+ function _toPropertyKey(arg) {
49
+ var key = _toPrimitive(arg, "string");
50
+ return typeof key === "symbol" ? key : String(key);
51
+ }
43
52
 
44
53
  /**
45
54
  * This match function matches math in `$`s, such as:
@@ -65,35 +74,33 @@ function _defineProperty(obj, key, value) {
65
74
  */
66
75
 
67
76
  var rWidgetRule = /^\[\[\u2603 (([a-z-]+) ([0-9]+))\]\]/;
68
-
69
77
  var mathMatcher = (source, state, isBlock) => {
70
78
  var length = source.length;
71
- var index = 0; // When looking for blocks, skip over leading spaces
79
+ var index = 0;
72
80
 
81
+ // When looking for blocks, skip over leading spaces
73
82
  if (isBlock) {
74
83
  if (state.inline) {
75
84
  return null;
76
85
  }
77
-
78
86
  while (index < length && source[index] === " ") {
79
87
  index++;
80
88
  }
81
- } // Our source must start with a "$"
82
-
89
+ }
83
90
 
91
+ // Our source must start with a "$"
84
92
  if (!(index < length && source[index] === "$")) {
85
93
  return null;
86
94
  }
87
-
88
95
  index++;
89
96
  var startIndex = index;
90
- var braceLevel = 0; // Loop through the source, looking for a closing '$'
97
+ var braceLevel = 0;
98
+
99
+ // Loop through the source, looking for a closing '$'
91
100
  // closing '$'s only count if they are not escaped with
92
101
  // a `\`, and we are not in nested `{}` braces.
93
-
94
102
  while (index < length) {
95
103
  var character = source[index];
96
-
97
104
  if (character === "\\") {
98
105
  // Consume both the `\` and the escaped char as a single
99
106
  // token.
@@ -106,23 +113,22 @@ var mathMatcher = (source, state, isBlock) => {
106
113
  index++;
107
114
  } else if (braceLevel <= 0 && character === "$") {
108
115
  var endIndex = index + 1;
109
-
110
116
  if (isBlock) {
111
117
  // Look for two trailing newlines after the closing `$`
112
118
  var match = /^(?: *\n){2,}/.exec(source.slice(endIndex));
119
+ // @ts-expect-error [FEI-5003] - TS2322 - Type 'number | null' is not assignable to type 'number'.
113
120
  endIndex = match ? endIndex + match[0].length : null;
114
- } // Return an array that looks like the results of a
121
+ }
122
+
123
+ // Return an array that looks like the results of a
115
124
  // regex's .exec function:
116
125
  // capture[0] is the whole string
117
126
  // capture[1] is the first "paren" match, which is the
118
127
  // content of the math here, as if we wrote the regex
119
128
  // /\$([^\$]*)\$/
120
-
121
-
122
129
  if (endIndex) {
123
130
  return [source.substring(0, endIndex), source.substring(startIndex, index)];
124
131
  }
125
-
126
132
  return null;
127
133
  } else if (character === "{") {
128
134
  braceLevel++;
@@ -136,21 +142,19 @@ var mathMatcher = (source, state, isBlock) => {
136
142
  // in paragraphs...
137
143
  return null;
138
144
  }
139
-
140
145
  index++;
141
- } // we didn't find a closing `$`
142
-
146
+ }
143
147
 
148
+ // we didn't find a closing `$`
144
149
  return null;
145
150
  };
146
-
147
151
  var mathMatch = (source, state) => mathMatcher(source, state, false);
148
-
149
152
  var blockMathMatch = (source, state) => mathMatcher(source, state, true);
150
-
151
- var TITLED_TABLE_REGEX = new RegExp("^\\|\\| +(.*) +\\|\\| *\\n" + "(" + // The simple-markdown nptable regex, without
153
+ var TITLED_TABLE_REGEX = new RegExp("^\\|\\| +(.*) +\\|\\| *\\n" + "(" +
154
+ // The simple-markdown nptable regex, without
152
155
  // the leading `^`
153
156
  // $FlowFixMe[incompatible-use]
157
+ // @ts-expect-error [FEI-5003] - TS2532 - Object is possibly 'undefined'.
154
158
  SimpleMarkdown.defaultRules.nptable.match.regex.source.substring(1) + ")");
155
159
  var crowdinJiptMatcher = SimpleMarkdown.blockRegex(/^(crwdns.*)\n\s*\n/);
156
160
  var pureMarkdownRules = _objectSpread2(_objectSpread2({}, SimpleMarkdown.defaultRules), {}, {
@@ -172,7 +176,6 @@ var pureMarkdownRules = _objectSpread2(_objectSpread2({}, SimpleMarkdown.default
172
176
  if (state.isJipt) {
173
177
  return crowdinJiptMatcher(source, state, prevCapture);
174
178
  }
175
-
176
179
  return null;
177
180
  },
178
181
  parse: (capture, _parse2, state) => ({
@@ -190,9 +193,10 @@ var pureMarkdownRules = _objectSpread2(_objectSpread2({}, SimpleMarkdown.default
190
193
  order: SimpleMarkdown.defaultRules.nptable.order - 0.5,
191
194
  match: SimpleMarkdown.blockRegex(TITLED_TABLE_REGEX),
192
195
  parse: (capture, _parse3, state) => {
193
- var title = SimpleMarkdown.parseInline(_parse3, capture[1], state); // Remove our [0] and [1] captures, and pass the rest to
194
- // the nptable parser
196
+ var title = SimpleMarkdown.parseInline(_parse3, capture[1], state);
195
197
 
198
+ // Remove our [0] and [1] captures, and pass the rest to
199
+ // the nptable parser
196
200
  var tableCapture = capture.slice(2);
197
201
  var table = SimpleMarkdown.defaultRules.nptable.parse(tableCapture, _parse3, state);
198
202
  return {
@@ -238,8 +242,9 @@ var pureMarkdownRules = _objectSpread2(_objectSpread2({}, SimpleMarkdown.default
238
242
  },
239
243
  fence: _objectSpread2(_objectSpread2({}, SimpleMarkdown.defaultRules.fence), {}, {
240
244
  parse: (capture, _parse8, state) => {
241
- var node = SimpleMarkdown.defaultRules.fence.parse(capture, _parse8, state); // support screenreader-only text with ```alt
245
+ var node = SimpleMarkdown.defaultRules.fence.parse(capture, _parse8, state);
242
246
 
247
+ // support screenreader-only text with ```alt
243
248
  if (node.lang === "alt") {
244
249
  return {
245
250
  type: "codeBlock",
@@ -253,7 +258,6 @@ var pureMarkdownRules = _objectSpread2(_objectSpread2({}, SimpleMarkdown.default
253
258
  content: _parse8(node.content + "\n\n", state)
254
259
  };
255
260
  }
256
-
257
261
  return node;
258
262
  }
259
263
  }),
@@ -295,7 +299,6 @@ var pureMarkdownRules = _objectSpread2(_objectSpread2({}, SimpleMarkdown.default
295
299
  if (state.isJipt) {
296
300
  return null;
297
301
  }
298
-
299
302
  return SimpleMarkdown.defaultRules.list.match(source, state, prevCapture);
300
303
  }
301
304
  }),
@@ -308,8 +311,9 @@ var pureMarkdownRules = _objectSpread2(_objectSpread2({}, SimpleMarkdown.default
308
311
  match: s => null,
309
312
  parse: (capture, _parse9, state) => ({})
310
313
  }
311
- }); // $FlowFixMe[incompatible-call]
314
+ });
312
315
 
316
+ // @ts-expect-error [FEI-5003] - TS2345 - Argument of type '{ readonly columns: { readonly order: -2; readonly match: any; readonly parse: (capture: any, parse: any, state: any) => any; }; readonly crowdinId: { readonly order: -1; readonly match: (source: any, state: any, prevCapture: any) => any; readonly parse: (capture: any, parse: any, state: any) => any; }; ... 34 more ...' is not assignable to parameter of type 'ParserRules'.
313
317
  var builtParser = SimpleMarkdown.parserFor(pureMarkdownRules);
314
318
  var parse = (source, state) => {
315
319
  var paragraphedSource = source + "\n\n";
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/index.js"],"sourcesContent":["// @flow\n\n/**\n * Contains markdown related functions in pure javascript,\n * extracted from perseus-markdown.jsx\n * Note that this file may be used in stand alone nodejs, thus\n * do not import anything from Perseus\n */\nimport SimpleMarkdown from \"@khanacademy/simple-markdown\";\n\n/**\n * This match function matches math in `$`s, such as:\n *\n * $y = x + 1$\n *\n * It functions roughly like the following regex:\n * /\\$([^\\$]*)\\$/\n *\n * Unfortunately, math may have other `$`s inside it, as\n * long as they are inside `{` braces `}`, mostly for\n * `\\text{ $math$ }`.\n *\n * To parse this, we can't use a regex, since we\n * should support arbitrary nesting (even though\n * MathJax actually only supports two levels of nesting\n * here, which we *could* parse with a regex).\n *\n * Non-regex matchers like this are now a first-class\n * concept in simple-markdown. Yay!\n *\n * This can also match block-math, which is math alone in a paragraph.\n */\n\nconst rWidgetRule: RegExp = /^\\[\\[\\u2603 (([a-z-]+) ([0-9]+))\\]\\]/;\n\nconst mathMatcher = (source, state, isBlock) => {\n const length = source.length;\n let index = 0;\n\n // When looking for blocks, skip over leading spaces\n if (isBlock) {\n if (state.inline) {\n return null;\n }\n while (index < length && source[index] === \" \") {\n index++;\n }\n }\n\n // Our source must start with a \"$\"\n if (!(index < length && source[index] === \"$\")) {\n return null;\n }\n\n index++;\n const startIndex = index;\n let braceLevel = 0;\n\n // Loop through the source, looking for a closing '$'\n // closing '$'s only count if they are not escaped with\n // a `\\`, and we are not in nested `{}` braces.\n while (index < length) {\n const character = source[index];\n\n if (character === \"\\\\\") {\n // Consume both the `\\` and the escaped char as a single\n // token.\n // This is so that the second `$` in `$\\\\$` closes\n // the math expression, since the first `\\` is escaping\n // the second `\\`, but the second `\\` is not escaping\n // the second `$`.\n // This also handles the case of escaping `$`s or\n // braces `\\{`\n index++;\n } else if (braceLevel <= 0 && character === \"$\") {\n let endIndex = index + 1;\n if (isBlock) {\n // Look for two trailing newlines after the closing `$`\n const match = /^(?: *\\n){2,}/.exec(source.slice(endIndex));\n endIndex = match ? endIndex + match[0].length : null;\n }\n\n // Return an array that looks like the results of a\n // regex's .exec function:\n // capture[0] is the whole string\n // capture[1] is the first \"paren\" match, which is the\n // content of the math here, as if we wrote the regex\n // /\\$([^\\$]*)\\$/\n if (endIndex) {\n return [\n source.substring(0, endIndex),\n source.substring(startIndex, index),\n ];\n }\n return null;\n } else if (character === \"{\") {\n braceLevel++;\n } else if (character === \"}\") {\n braceLevel--;\n } else if (character === \"\\n\" && source[index - 1] === \"\\n\") {\n // This is a weird case we supported in the old\n // math implementation--double newlines break\n // math. I'm preserving it for now because content\n // creators might have questions with single '$'s\n // in paragraphs...\n return null;\n }\n\n index++;\n }\n\n // we didn't find a closing `$`\n return null;\n};\nconst mathMatch = (source: any, state: any): any =>\n mathMatcher(source, state, false);\nconst blockMathMatch = (source: any, state: any): any =>\n mathMatcher(source, state, true);\n\nconst TITLED_TABLE_REGEX = new RegExp(\n \"^\\\\|\\\\| +(.*) +\\\\|\\\\| *\\\\n\" +\n \"(\" +\n // The simple-markdown nptable regex, without\n // the leading `^`\n // $FlowFixMe[incompatible-use]\n SimpleMarkdown.defaultRules.nptable.match.regex.source.substring(1) +\n \")\",\n);\n\nconst crowdinJiptMatcher = SimpleMarkdown.blockRegex(/^(crwdns.*)\\n\\s*\\n/);\n\nexport const pureMarkdownRules = {\n ...SimpleMarkdown.defaultRules,\n\n // NOTE: basically ignored by JIPT. wraps everything at the outer layer\n columns: {\n order: -2,\n match: (SimpleMarkdown.blockRegex(\n /^([\\s\\S]*\\n\\n)={5,}\\n\\n([\\s\\S]*)/,\n ): any),\n parse: (capture: any, parse: any, state: any): any => {\n return {\n col1: parse(capture[1], state),\n col2: parse(capture[2], state),\n };\n },\n },\n crowdinId: {\n order: -1,\n match: (source: any, state: any, prevCapture: any): any => {\n // Only match on the just-in-place translation site\n if (state.isJipt) {\n return crowdinJiptMatcher(source, state, prevCapture);\n }\n return null;\n },\n parse: (capture: any, parse: any, state: any): any => ({\n id: capture[1],\n }),\n },\n // This is pretty much horrible, but we have a regex here to capture an\n // entire table + a title. capture[1] is the title. capture[2] of the\n // regex is a copy of the simple-markdown nptable regex. Then we turn\n // our capture[2] into tableCapture[0], and any further captures in\n // our table regex into tableCapture[1..], and we pass tableCapture to\n // our nptable regex\n titledTable: {\n // process immediately before nptables\n order: SimpleMarkdown.defaultRules.nptable.order - 0.5,\n match: (SimpleMarkdown.blockRegex(TITLED_TABLE_REGEX): any),\n parse: (capture: any, parse: any, state: any): any => {\n const title = SimpleMarkdown.parseInline(parse, capture[1], state);\n\n // Remove our [0] and [1] captures, and pass the rest to\n // the nptable parser\n const tableCapture = capture.slice(2);\n const table = SimpleMarkdown.defaultRules.nptable.parse(\n tableCapture,\n parse,\n state,\n );\n return {\n title: title,\n table: table,\n };\n },\n },\n widget: {\n order: SimpleMarkdown.defaultRules.link.order - 0.75,\n match: (SimpleMarkdown.inlineRegex(rWidgetRule): any),\n parse: (capture: any, parse: any, state: any): any => {\n return {\n id: capture[1],\n widgetType: capture[2],\n };\n },\n },\n blockMath: {\n order: (SimpleMarkdown.defaultRules.codeBlock.order + 0.5: any),\n match: blockMathMatch,\n parse: (capture: any, parse: any, state: any): any => {\n return {\n content: capture[1],\n };\n },\n },\n math: {\n order: SimpleMarkdown.defaultRules.link.order - 0.25,\n match: mathMatch,\n parse: (capture: any, parse: any, state: any): any => {\n return {\n content: capture[1],\n };\n },\n },\n unescapedDollar: {\n order: SimpleMarkdown.defaultRules.link.order - 0.24,\n match: (SimpleMarkdown.inlineRegex(/^(?!\\\\)\\$/): any),\n parse: (capture: any, parse: any, state: any): any => {\n return {};\n },\n },\n fence: {\n ...SimpleMarkdown.defaultRules.fence,\n parse: (capture: any, parse: any, state: any): any => {\n const node = SimpleMarkdown.defaultRules.fence.parse(\n capture,\n parse,\n state,\n );\n\n // support screenreader-only text with ```alt\n if (node.lang === \"alt\") {\n return {\n type: \"codeBlock\",\n lang: \"alt\",\n // default codeBlock parsing doesn't parse the contents.\n // We need to parse the contents for things like table\n // support :).\n // The \\n\\n is because the inside of the codeblock might\n // not end in double newlines for block rules, because\n // ordinarily we don't parse this :).\n content: parse(node.content + \"\\n\\n\", state),\n };\n }\n return node;\n },\n },\n blockQuote: {\n ...SimpleMarkdown.defaultRules.blockQuote,\n // Replace the less restrictive blockquote regex from SimpleMarkdown\n // with a more restrictive one. The only difference should be that\n //\n // > A blockquote\n //\n // > Another blockquote\n //\n // will now match as two different blockQuotes instead of a single\n // blockquote with some paragraph breaks in it.\n //\n // The main motivation for doing this is to provide better support for\n // translators translating blockquotes with multiple paragraphs in\n // them. When translating articles, we split up paragraphs, translate\n // them separately, and then recombine them. We do this so that\n // translators don't have to translate an entire article at a time,\n // they can instead translate paragraph-by-paragraph.That system\n // doesn't understand blockquotes, so it will split up blockquotes into\n // more than one paragraph. A way to solve this would be to make that\n // system understand blockquotes, but then translators would have to\n // translate an entire, multi-paragraph blockquote at a time. Instead,\n // we choose to modify our blockquote matching to split up\n // multi-paragraph blockquotes into multiple blockquotes.\n //\n // There is also precedence for doing this splitting up in other\n // libraries, for instance CommonMark also splits up blockquotes with\n // empty lines into multiple blockquotes:\n // https://spec.commonmark.org/0.28/#example-205\n match: (SimpleMarkdown.blockRegex(\n /^ *>[^\\n]+(\\n( *>)?[^\\n]+)*\\n{2,}/,\n ): any),\n },\n list: {\n ...SimpleMarkdown.defaultRules.list,\n match: (source: any, state: any, prevCapture: any): any => {\n // Since lists can contain double newlines and we have special\n // handling of double newlines while parsing jipt content, just\n // disable the list parser.\n if (state.isJipt) {\n return null;\n }\n return SimpleMarkdown.defaultRules.list.match(\n source,\n state,\n prevCapture,\n );\n },\n },\n // The lint rule never actually matches anything.\n // We check for lint after parsing, and, if we find any, we\n // transform the tree to add lint nodes. This rule is here\n // just for the react() function\n lint: {\n order: 1000,\n match: (s: any): any => null,\n parse: (capture: any, parse: any, state: any): any => ({}),\n },\n};\n\n// $FlowFixMe[incompatible-call]\nconst builtParser = SimpleMarkdown.parserFor(pureMarkdownRules);\n\nexport const parse = (source: string, state: $FlowFixMe): $FlowFixMe => {\n const paragraphedSource = source + \"\\n\\n\";\n\n return builtParser(paragraphedSource, {\n ...state,\n inline: false,\n });\n};\n"],"names":["rWidgetRule","mathMatcher","source","state","isBlock","length","index","inline","startIndex","braceLevel","character","endIndex","match","exec","slice","substring","mathMatch","blockMathMatch","TITLED_TABLE_REGEX","RegExp","SimpleMarkdown","defaultRules","nptable","regex","crowdinJiptMatcher","blockRegex","pureMarkdownRules","columns","order","parse","capture","col1","col2","crowdinId","prevCapture","isJipt","id","titledTable","title","parseInline","tableCapture","table","widget","link","inlineRegex","widgetType","blockMath","codeBlock","content","math","unescapedDollar","fence","node","lang","type","blockQuote","list","lint","s","builtParser","parserFor","paragraphedSource","_objectSpread"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/index.ts"],"sourcesContent":["/**\n * Contains markdown related functions in pure javascript,\n * extracted from perseus-markdown.jsx\n * Note that this file may be used in stand alone nodejs, thus\n * do not import anything from Perseus\n */\nimport SimpleMarkdown from \"@khanacademy/simple-markdown\";\n\n/**\n * This match function matches math in `$`s, such as:\n *\n * $y = x + 1$\n *\n * It functions roughly like the following regex:\n * /\\$([^\\$]*)\\$/\n *\n * Unfortunately, math may have other `$`s inside it, as\n * long as they are inside `{` braces `}`, mostly for\n * `\\text{ $math$ }`.\n *\n * To parse this, we can't use a regex, since we\n * should support arbitrary nesting (even though\n * MathJax actually only supports two levels of nesting\n * here, which we *could* parse with a regex).\n *\n * Non-regex matchers like this are now a first-class\n * concept in simple-markdown. Yay!\n *\n * This can also match block-math, which is math alone in a paragraph.\n */\n\nconst rWidgetRule = /^\\[\\[\\u2603 (([a-z-]+) ([0-9]+))\\]\\]/;\n\nconst mathMatcher = (source: any, state: any, isBlock: boolean) => {\n const length = source.length;\n let index = 0;\n\n // When looking for blocks, skip over leading spaces\n if (isBlock) {\n if (state.inline) {\n return null;\n }\n while (index < length && source[index] === \" \") {\n index++;\n }\n }\n\n // Our source must start with a \"$\"\n if (!(index < length && source[index] === \"$\")) {\n return null;\n }\n\n index++;\n const startIndex = index;\n let braceLevel = 0;\n\n // Loop through the source, looking for a closing '$'\n // closing '$'s only count if they are not escaped with\n // a `\\`, and we are not in nested `{}` braces.\n while (index < length) {\n const character = source[index];\n\n if (character === \"\\\\\") {\n // Consume both the `\\` and the escaped char as a single\n // token.\n // This is so that the second `$` in `$\\\\$` closes\n // the math expression, since the first `\\` is escaping\n // the second `\\`, but the second `\\` is not escaping\n // the second `$`.\n // This also handles the case of escaping `$`s or\n // braces `\\{`\n index++;\n } else if (braceLevel <= 0 && character === \"$\") {\n let endIndex = index + 1;\n if (isBlock) {\n // Look for two trailing newlines after the closing `$`\n const match = /^(?: *\\n){2,}/.exec(source.slice(endIndex));\n // @ts-expect-error [FEI-5003] - TS2322 - Type 'number | null' is not assignable to type 'number'.\n endIndex = match ? endIndex + match[0].length : null;\n }\n\n // Return an array that looks like the results of a\n // regex's .exec function:\n // capture[0] is the whole string\n // capture[1] is the first \"paren\" match, which is the\n // content of the math here, as if we wrote the regex\n // /\\$([^\\$]*)\\$/\n if (endIndex) {\n return [\n source.substring(0, endIndex),\n source.substring(startIndex, index),\n ];\n }\n return null;\n } else if (character === \"{\") {\n braceLevel++;\n } else if (character === \"}\") {\n braceLevel--;\n } else if (character === \"\\n\" && source[index - 1] === \"\\n\") {\n // This is a weird case we supported in the old\n // math implementation--double newlines break\n // math. I'm preserving it for now because content\n // creators might have questions with single '$'s\n // in paragraphs...\n return null;\n }\n\n index++;\n }\n\n // we didn't find a closing `$`\n return null;\n};\nconst mathMatch = (source: any, state: any): any =>\n mathMatcher(source, state, false);\nconst blockMathMatch = (source: any, state: any): any =>\n mathMatcher(source, state, true);\n\nconst TITLED_TABLE_REGEX = new RegExp(\n \"^\\\\|\\\\| +(.*) +\\\\|\\\\| *\\\\n\" +\n \"(\" +\n // The simple-markdown nptable regex, without\n // the leading `^`\n // $FlowFixMe[incompatible-use]\n // @ts-expect-error [FEI-5003] - TS2532 - Object is possibly 'undefined'.\n SimpleMarkdown.defaultRules.nptable.match.regex.source.substring(1) +\n \")\",\n);\n\nconst crowdinJiptMatcher = SimpleMarkdown.blockRegex(/^(crwdns.*)\\n\\s*\\n/);\n\nexport const pureMarkdownRules = {\n ...SimpleMarkdown.defaultRules,\n\n // NOTE: basically ignored by JIPT. wraps everything at the outer layer\n columns: {\n order: -2,\n match: SimpleMarkdown.blockRegex(\n /^([\\s\\S]*\\n\\n)={5,}\\n\\n([\\s\\S]*)/,\n ) as any,\n parse: (capture: any, parse: any, state: any): any => {\n return {\n col1: parse(capture[1], state),\n col2: parse(capture[2], state),\n };\n },\n },\n crowdinId: {\n order: -1,\n match: (source: any, state: any, prevCapture: any): any => {\n // Only match on the just-in-place translation site\n if (state.isJipt) {\n return crowdinJiptMatcher(source, state, prevCapture);\n }\n return null;\n },\n parse: (capture: any, parse: any, state: any): any => ({\n id: capture[1],\n }),\n },\n // This is pretty much horrible, but we have a regex here to capture an\n // entire table + a title. capture[1] is the title. capture[2] of the\n // regex is a copy of the simple-markdown nptable regex. Then we turn\n // our capture[2] into tableCapture[0], and any further captures in\n // our table regex into tableCapture[1..], and we pass tableCapture to\n // our nptable regex\n titledTable: {\n // process immediately before nptables\n order: SimpleMarkdown.defaultRules.nptable.order - 0.5,\n match: SimpleMarkdown.blockRegex(TITLED_TABLE_REGEX) as any,\n parse: (capture: any, parse: any, state: any): any => {\n const title = SimpleMarkdown.parseInline(parse, capture[1], state);\n\n // Remove our [0] and [1] captures, and pass the rest to\n // the nptable parser\n const tableCapture = capture.slice(2);\n const table = SimpleMarkdown.defaultRules.nptable.parse(\n tableCapture,\n parse,\n state,\n );\n return {\n title: title,\n table: table,\n };\n },\n },\n widget: {\n order: SimpleMarkdown.defaultRules.link.order - 0.75,\n match: SimpleMarkdown.inlineRegex(rWidgetRule) as any,\n parse: (capture: any, parse: any, state: any): any => {\n return {\n id: capture[1],\n widgetType: capture[2],\n };\n },\n },\n blockMath: {\n order: (SimpleMarkdown.defaultRules.codeBlock.order + 0.5) as any,\n match: blockMathMatch,\n parse: (capture: any, parse: any, state: any): any => {\n return {\n content: capture[1],\n };\n },\n },\n math: {\n order: SimpleMarkdown.defaultRules.link.order - 0.25,\n match: mathMatch,\n parse: (capture: any, parse: any, state: any): any => {\n return {\n content: capture[1],\n };\n },\n },\n unescapedDollar: {\n order: SimpleMarkdown.defaultRules.link.order - 0.24,\n match: SimpleMarkdown.inlineRegex(/^(?!\\\\)\\$/) as any,\n parse: (capture: any, parse: any, state: any): any => {\n return {};\n },\n },\n fence: {\n ...SimpleMarkdown.defaultRules.fence,\n parse: (capture: any, parse: any, state: any): any => {\n const node = SimpleMarkdown.defaultRules.fence.parse(\n capture,\n parse,\n state,\n );\n\n // support screenreader-only text with ```alt\n if (node.lang === \"alt\") {\n return {\n type: \"codeBlock\",\n lang: \"alt\",\n // default codeBlock parsing doesn't parse the contents.\n // We need to parse the contents for things like table\n // support :).\n // The \\n\\n is because the inside of the codeblock might\n // not end in double newlines for block rules, because\n // ordinarily we don't parse this :).\n content: parse(node.content + \"\\n\\n\", state),\n };\n }\n return node;\n },\n },\n blockQuote: {\n ...SimpleMarkdown.defaultRules.blockQuote,\n // Replace the less restrictive blockquote regex from SimpleMarkdown\n // with a more restrictive one. The only difference should be that\n //\n // > A blockquote\n //\n // > Another blockquote\n //\n // will now match as two different blockQuotes instead of a single\n // blockquote with some paragraph breaks in it.\n //\n // The main motivation for doing this is to provide better support for\n // translators translating blockquotes with multiple paragraphs in\n // them. When translating articles, we split up paragraphs, translate\n // them separately, and then recombine them. We do this so that\n // translators don't have to translate an entire article at a time,\n // they can instead translate paragraph-by-paragraph.That system\n // doesn't understand blockquotes, so it will split up blockquotes into\n // more than one paragraph. A way to solve this would be to make that\n // system understand blockquotes, but then translators would have to\n // translate an entire, multi-paragraph blockquote at a time. Instead,\n // we choose to modify our blockquote matching to split up\n // multi-paragraph blockquotes into multiple blockquotes.\n //\n // There is also precedence for doing this splitting up in other\n // libraries, for instance CommonMark also splits up blockquotes with\n // empty lines into multiple blockquotes:\n // https://spec.commonmark.org/0.28/#example-205\n match: SimpleMarkdown.blockRegex(\n /^ *>[^\\n]+(\\n( *>)?[^\\n]+)*\\n{2,}/,\n ) as any,\n },\n list: {\n ...SimpleMarkdown.defaultRules.list,\n match: (source: any, state: any, prevCapture: any): any => {\n // Since lists can contain double newlines and we have special\n // handling of double newlines while parsing jipt content, just\n // disable the list parser.\n if (state.isJipt) {\n return null;\n }\n return SimpleMarkdown.defaultRules.list.match(\n source,\n state,\n prevCapture,\n );\n },\n },\n // The lint rule never actually matches anything.\n // We check for lint after parsing, and, if we find any, we\n // transform the tree to add lint nodes. This rule is here\n // just for the react() function\n lint: {\n order: 1000,\n match: (s: any): any => null,\n parse: (capture: any, parse: any, state: any): any => ({}),\n },\n} as const;\n\n// @ts-expect-error [FEI-5003] - TS2345 - Argument of type '{ readonly columns: { readonly order: -2; readonly match: any; readonly parse: (capture: any, parse: any, state: any) => any; }; readonly crowdinId: { readonly order: -1; readonly match: (source: any, state: any, prevCapture: any) => any; readonly parse: (capture: any, parse: any, state: any) => any; }; ... 34 more ...' is not assignable to parameter of type 'ParserRules'.\nconst builtParser = SimpleMarkdown.parserFor(pureMarkdownRules);\n\nexport const parse = (source: string, state?: any): any => {\n const paragraphedSource = source + \"\\n\\n\";\n\n return builtParser(paragraphedSource, {\n ...state,\n inline: false,\n });\n};\n"],"names":["rWidgetRule","mathMatcher","source","state","isBlock","length","index","inline","startIndex","braceLevel","character","endIndex","match","exec","slice","substring","mathMatch","blockMathMatch","TITLED_TABLE_REGEX","RegExp","SimpleMarkdown","defaultRules","nptable","regex","crowdinJiptMatcher","blockRegex","pureMarkdownRules","_objectSpread","columns","order","parse","capture","col1","col2","crowdinId","prevCapture","isJipt","id","titledTable","title","parseInline","tableCapture","table","widget","link","inlineRegex","widgetType","blockMath","codeBlock","content","math","unescapedDollar","fence","node","lang","type","blockQuote","list","lint","s","builtParser","parserFor","paragraphedSource"],"mappings":"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"}