|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ mathFromMarkdown: () => (/* binding */ mathFromMarkdown),\n/* harmony export */ mathToMarkdown: () => (/* binding */ mathToMarkdown)\n/* harmony export */ });\n/* harmony import */ var longest_streak__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! longest-streak */ \"(ssr)/./node_modules/longest-streak/index.js\");\n/* harmony import */ var mdast_util_to_markdown_lib_util_safe_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! mdast-util-to-markdown/lib/util/safe.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/util/safe.js\");\n/* harmony import */ var mdast_util_to_markdown_lib_util_track_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! mdast-util-to-markdown/lib/util/track.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/util/track.js\");\n/* harmony import */ var mdast_util_to_markdown_lib_util_pattern_compile_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! mdast-util-to-markdown/lib/util/pattern-compile.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/util/pattern-compile.js\");\n/**\n * @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext\n * @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension\n * @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('../index.js').Math} Math\n * @typedef {import('../index.js').InlineMath} InlineMath\n *\n * @typedef ToOptions\n * Configuration.\n * @property {boolean | null | undefined} [singleDollarTextMath=true]\n * Whether to support math (text) with a single dollar.\n *\n * Single dollars work in Pandoc and many other places, but often interfere\n * with “normal” dollars in text.\n * If you turn this off, you can still use two or more dollars for text math.\n */ \n\n\n\n/**\n * Create an extension for `mdast-util-from-markdown`.\n *\n * @returns {FromMarkdownExtension}\n * Extension for `mdast-util-from-markdown`.\n */ function mathFromMarkdown() {\n return {\n enter: {\n mathFlow: enterMathFlow,\n mathFlowFenceMeta: enterMathFlowMeta,\n mathText: enterMathText\n },\n exit: {\n mathFlow: exitMathFlow,\n mathFlowFence: exitMathFlowFence,\n mathFlowFenceMeta: exitMathFlowMeta,\n mathFlowValue: exitMathData,\n mathText: exitMathText,\n mathTextData: exitMathData\n }\n };\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterMathFlow(token) {\n this.enter({\n type: \"math\",\n meta: null,\n value: \"\",\n data: {\n hName: \"div\",\n hProperties: {\n className: [\n \"math\",\n \"math-display\"\n ]\n },\n hChildren: [\n {\n type: \"text\",\n value: \"\"\n }\n ]\n }\n }, token);\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterMathFlowMeta() {\n this.buffer();\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathFlowMeta() {\n const data = this.resume();\n const node = /** @type {Math} */ this.stack[this.stack.length - 1];\n node.meta = data;\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathFlowFence() {\n // Exit if this is the closing fence.\n if (this.getData(\"mathFlowInside\")) return;\n this.buffer();\n this.setData(\"mathFlowInside\", true);\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathFlow(token) {\n const data = this.resume().replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, \"\");\n const node = /** @type {Math} */ this.exit(token);\n node.value = data;\n // @ts-expect-error: we defined it.\n node.data.hChildren[0].value = data;\n this.setData(\"mathFlowInside\");\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterMathText(token) {\n this.enter({\n type: \"inlineMath\",\n value: \"\",\n data: {\n hName: \"span\",\n hProperties: {\n className: [\n \"math\",\n \"math-inline\"\n ]\n },\n hChildren: [\n {\n type: \"text\",\n value: \"\"\n }\n ]\n }\n }, token);\n this.buffer();\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathText(token) {\n const data = this.resume();\n const node = /** @type {Math} */ this.exit(token);\n node.value = data;\n // @ts-expect-error: we defined it.\n node.data.hChildren[0].value = data;\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathData(token) {\n this.config.enter.data.call(this, token);\n this.config.exit.data.call(this, token);\n }\n}\n/**\n * Create an extension for `mdast-util-to-markdown`.\n *\n * @param {ToOptions | null | undefined} [options]\n * Configuration.\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown`.\n */ function mathToMarkdown(options) {\n let single = (options || {}).singleDollarTextMath;\n if (single === null || single === undefined) {\n single = true;\n }\n inlineMath.peek = inlineMathPeek;\n return {\n unsafe: [\n {\n character: \"\\r\",\n inConstruct: \"mathFlowMeta\"\n },\n {\n character: \"\\n\",\n inConstruct: \"mathFlowMeta\"\n },\n {\n character: \"$\",\n after: single ? undefined : \"\\\\$\",\n inConstruct: \"phrasing\"\n },\n {\n character: \"$\",\n inConstruct: \"mathFlowMeta\"\n },\n {\n atBreak: true,\n character: \"$\",\n after: \"\\\\$\"\n }\n ],\n handlers: {\n math,\n inlineMath\n }\n };\n /**\n * @type {ToMarkdownHandle}\n * @param {Math} node\n */ // To do: next major: rename `context` to state, `safeOptions` to info.\n // Note: fixing this code? Please also fix the similar code for code:\n // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/code.js>\n function math(node, _, context, safeOptions) {\n const raw = node.value || \"\";\n const tracker = (0,mdast_util_to_markdown_lib_util_track_js__WEBPACK_IMPORTED_MODULE_0__.track)(safeOptions);\n const sequence = \"$\".repeat(Math.max((0,longest_streak__WEBPACK_IMPORTED_MODULE_1__.longestStreak)(raw, \"$\") + 1, 2));\n const exit = context.enter(\"mathFlow\");\n let value = tracker.move(sequence);\n if (node.meta) {\n const subexit = context.enter(\"mathFlowMeta\");\n value += tracker.move((0,mdast_util_to_markdown_lib_util_safe_js__WEBPACK_IMPORTED_MODULE_2__.safe)(context, node.meta, {\n before: value,\n after: \"\\n\",\n encode: [\n \"$\"\n ],\n ...tracker.current()\n }));\n subexit();\n }\n value += tracker.move(\"\\n\");\n if (raw) {\n value += tracker.move(raw + \"\\n\");\n }\n value += tracker.move(sequence);\n exit();\n return value;\n }\n /**\n * @type {ToMarkdownHandle}\n * @param {InlineMath} node\n */ // Note: fixing this code? Please also fix the similar code for inline code:\n // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/inline-code.js>\n //\n // To do: next major: rename `context` to state.\n // To do: next major: use `state` (`safe`, `track`, `patternCompile`).\n function inlineMath(node, _, context) {\n let value = node.value || \"\";\n let size = 1;\n if (!single) size++;\n // If there is a single dollar sign on its own in the math, use a fence of\n // two.\n // If there are two in a row, use one.\n while(new RegExp(\"(^|[^$])\" + \"\\\\$\".repeat(size) + \"([^$]|$)\").test(value)){\n size++;\n }\n const sequence = \"$\".repeat(size);\n // If this is not just spaces or eols (tabs don’t count), and either the\n // first and last character are a space or eol, or the first or last\n // character are dollar signs, then pad with spaces.\n if (// Contains non-space.\n /[^ \\r\\n]/.test(value) && // Starts with space and ends with space.\n (/^[ \\r\\n]/.test(value) && /[ \\r\\n]$/.test(value) || // Starts or ends with dollar.\n /^\\$|\\$$/.test(value))) {\n value = \" \" + value + \" \";\n }\n let index = -1;\n // We have a potential problem: certain characters after eols could result in\n // blocks being seen.\n // For example, if someone injected the string `'\\n# b'`, then that would\n // result in an ATX heading.\n // We can’t escape characters in `inlineMath`, but because eols are\n // transformed to spaces when going from markdown to HTML anyway, we can swap\n // them out.\n while(++index < context.unsafe.length){\n const pattern = context.unsafe[index];\n const expression = (0,mdast_util_to_markdown_lib_util_pattern_compile_js__WEBPACK_IMPORTED_MODULE_3__.patternCompile)(pattern);\n /** @type {RegExpExecArray | null} */ let match;\n // Only look for `atBreak`s.\n // Btw: note that `atBreak` patterns will always start the regex at LF or\n // CR.\n if (!pattern.atBreak) continue;\n while(match = expression.exec(value)){\n let position = match.index;\n // Support CRLF (patterns only look for one of the characters).\n if (value.codePointAt(position) === 10 /* `\\n` */ && value.codePointAt(position - 1) === 13 /* `\\r` */ ) {\n position--;\n }\n value = value.slice(0, position) + \" \" + value.slice(match.index + 1);\n }\n }\n return sequence + value + sequence;\n }\n /**\n * @returns {string}\n */ function inlineMathPeek() {\n return \"$\";\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/mdast-util-math/lib/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/mdast-util-math/lib/index.js?0fa3"],"sourcesContent":["/**\n * @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext\n * @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension\n * @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('../index.js').Math} Math\n * @typedef {import('../index.js').InlineMath} InlineMath\n *\n * @typedef ToOptions\n *   Configuration.\n * @property {boolean | null | undefined} [singleDollarTextMath=true]\n *   Whether to support math (text) with a single dollar.\n *\n *   Single dollars work in Pandoc and many other places, but often interfere\n *   with “normal” dollars in text.\n *   If you turn this off, you can still use two or more dollars for text math.\n */\n\nimport {longestStreak} from 'longest-streak'\nimport {safe} from 'mdast-util-to-markdown/lib/util/safe.js'\nimport {track} from 'mdast-util-to-markdown/lib/util/track.js'\nimport {patternCompile} from 'mdast-util-to-markdown/lib/util/pattern-compile.js'\n\n/**\n * Create an extension for `mdast-util-from-markdown`.\n *\n * @returns {FromMarkdownExtension}\n *   Extension for `mdast-util-from-markdown`.\n */\nexport function mathFromMarkdown() {\n  return {\n    enter: {\n      mathFlow: enterMathFlow,\n      mathFlowFenceMeta: enterMathFlowMeta,\n      mathText: enterMathText\n    },\n    exit: {\n      mathFlow: exitMathFlow,\n      mathFlowFence: exitMathFlowFence,\n      mathFlowFenceMeta: exitMathFlowMeta,\n      mathFlowValue: exitMathData,\n      mathText: exitMathText,\n      mathTextData: exitMathData\n    }\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function enterMathFlow(token) {\n    this.enter(\n      {\n        type: 'math',\n        meta: null,\n        value: '',\n        data: {\n          hName: 'div',\n          hProperties: {className: ['math', 'math-display']},\n          hChildren: [{type: 'text', value: ''}]\n        }\n      },\n      token\n    )\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function enterMathFlowMeta() {\n    this.buffer()\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathFlowMeta() {\n    const data = this.resume()\n    const node = /** @type {Math} */ (this.stack[this.stack.length - 1])\n    node.meta = data\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathFlowFence() {\n    // Exit if this is the closing fence.\n    if (this.getData('mathFlowInside')) return\n    this.buffer()\n    this.setData('mathFlowInside', true)\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathFlow(token) {\n    const data = this.resume().replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, '')\n    const node = /** @type {Math} */ (this.exit(token))\n    node.value = data\n    // @ts-expect-error: we defined it.\n    node.data.hChildren[0].value = data\n    this.setData('mathFlowInside')\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function enterMathText(token) {\n    this.enter(\n      {\n        type: 'inlineMath',\n        value: '',\n        data: {\n          hName: 'span',\n          hProperties: {className: ['math', 'math-inline']},\n          hChildren: [{type: 'text', value: ''}]\n        }\n      },\n      token\n    )\n    this.buffer()\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathText(token) {\n    const data = this.resume()\n    const node = /** @type {Math} */ (this.exit(token))\n    node.value = data\n    // @ts-expect-error: we defined it.\n    node.data.hChildren[0].value = data\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathData(token) {\n    this.config.enter.data.call(this, token)\n    this.config.exit.data.call(this, token)\n  }\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown`.\n *\n * @param {ToOptions | null | undefined} [options]\n *   Configuration.\n * @returns {ToMarkdownExtension}\n *   Extension for `mdast-util-to-markdown`.\n */\nexport function mathToMarkdown(options) {\n  let single = (options || {}).singleDollarTextMath\n\n  if (single === null || single === undefined) {\n    single = true\n  }\n\n  inlineMath.peek = inlineMathPeek\n\n  return {\n    unsafe: [\n      {character: '\\r', inConstruct: 'mathFlowMeta'},\n      {character: '\\n', inConstruct: 'mathFlowMeta'},\n      {\n        character: '$',\n        after: single ? undefined : '\\\\$',\n        inConstruct: 'phrasing'\n      },\n      {character: '$', inConstruct: 'mathFlowMeta'},\n      {atBreak: true, character: '$', after: '\\\\$'}\n    ],\n    handlers: {math, inlineMath}\n  }\n\n  /**\n   * @type {ToMarkdownHandle}\n   * @param {Math} node\n   */\n  // To do: next major: rename `context` to state, `safeOptions` to info.\n  // Note: fixing this code? Please also fix the similar code for code:\n  // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/code.js>\n  function math(node, _, context, safeOptions) {\n    const raw = node.value || ''\n    const tracker = track(safeOptions)\n    const sequence = '$'.repeat(Math.max(longestStreak(raw, '$') + 1, 2))\n    const exit = context.enter('mathFlow')\n    let value = tracker.move(sequence)\n\n    if (node.meta) {\n      const subexit = context.enter('mathFlowMeta')\n      value += tracker.move(\n        safe(context, node.meta, {\n          before: value,\n          after: '\\n',\n          encode: ['$'],\n          ...tracker.current()\n        })\n      )\n      subexit()\n    }\n\n    value += tracker.move('\\n')\n\n    if (raw) {\n      value += tracker.move(raw + '\\n')\n    }\n\n    value += tracker.move(sequence)\n    exit()\n    return value\n  }\n\n  /**\n   * @type {ToMarkdownHandle}\n   * @param {InlineMath} node\n   */\n  // Note: fixing this code? Please also fix the similar code for inline code:\n  // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/inline-code.js>\n  //\n  // To do: next major: rename `context` to state.\n  // To do: next major: use `state` (`safe`, `track`, `patternCompile`).\n  function inlineMath(node, _, context) {\n    let value = node.value || ''\n    let size = 1\n\n    if (!single) size++\n\n    // If there is a single dollar sign on its own in the math, use a fence of\n    // two.\n    // If there are two in a row, use one.\n    while (\n      new RegExp('(^|[^$])' + '\\\\$'.repeat(size) + '([^$]|$)').test(value)\n    ) {\n      size++\n    }\n\n    const sequence = '$'.repeat(size)\n\n    // If this is not just spaces or eols (tabs don’t count), and either the\n    // first and last character are a space or eol, or the first or last\n    // character are dollar signs, then pad with spaces.\n    if (\n      // Contains non-space.\n      /[^ \\r\\n]/.test(value) &&\n      // Starts with space and ends with space.\n      ((/^[ \\r\\n]/.test(value) && /[ \\r\\n]$/.test(value)) ||\n        // Starts or ends with dollar.\n        /^\\$|\\$$/.test(value))\n    ) {\n      value = ' ' + value + ' '\n    }\n\n    let index = -1\n\n    // We have a potential problem: certain characters after eols could result in\n    // blocks being seen.\n    // For example, if someone injected the string `'\\n# b'`, then that would\n    // result in an ATX heading.\n    // We can’t escape characters in `inlineMath`, but because eols are\n    // transformed to spaces when going from markdown to HTML anyway, we can swap\n    // them out.\n    while (++index < context.unsafe.length) {\n      const pattern = context.unsafe[index]\n      const expression = patternCompile(pattern)\n      /** @type {RegExpExecArray | null} */\n      let match\n\n      // Only look for `atBreak`s.\n      // Btw: note that `atBreak` patterns will always start the regex at LF or\n      // CR.\n      if (!pattern.atBreak) continue\n\n      while ((match = expression.exec(value))) {\n        let position = match.index\n\n        // Support CRLF (patterns only look for one of the characters).\n        if (\n          value.codePointAt(position) === 10 /* `\\n` */ &&\n          value.codePointAt(position - 1) === 13 /* `\\r` */\n        ) {\n          position--\n        }\n\n        value = value.slice(0, position) + ' ' + value.slice(match.index + 1)\n      }\n    }\n\n    return sequence + value + sequence\n  }\n\n  /**\n   * @returns {string}\n   */\n  function inlineMathPeek() {\n    return '$'\n  }\n}\n"],"names":["longestStreak","safe","track","patternCompile","mathFromMarkdown","enter","mathFlow","enterMathFlow","mathFlowFenceMeta","enterMathFlowMeta","mathText","enterMathText","exit","exitMathFlow","mathFlowFence","exitMathFlowFence","exitMathFlowMeta","mathFlowValue","exitMathData","exitMathText","mathTextData","token","type","meta","value","data","hName","hProperties","className","hChildren","buffer","resume","node","stack","length","getData","setData","replace","config","call","mathToMarkdown","options","single","singleDollarTextMath","undefined","inlineMath","peek","inlineMathPeek","unsafe","character","inConstruct","after","atBreak","handlers","math","_","context","safeOptions","raw","tracker","sequence","repeat","Math","max","move","subexit","before","encode","current","size","RegExp","test","index","pattern","expression","match","exec","position","codePointAt","slice"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/mdast-util-math/lib/index.js\n");
|