You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

25 lines
29 KiB
JavaScript

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

"use strict";
/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
exports.id = "vendor-chunks/mdast-util-gfm-table";
exports.ids = ["vendor-chunks/mdast-util-gfm-table"];
exports.modules = {
/***/ "(ssr)/./node_modules/mdast-util-gfm-table/lib/index.js":
/*!********************************************************!*\
!*** ./node_modules/mdast-util-gfm-table/lib/index.js ***!
\********************************************************/
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ gfmTableFromMarkdown: () => (/* binding */ gfmTableFromMarkdown),\n/* harmony export */ gfmTableToMarkdown: () => (/* binding */ gfmTableToMarkdown)\n/* harmony export */ });\n/* harmony import */ var mdast_util_to_markdown_lib_util_container_phrasing_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! mdast-util-to-markdown/lib/util/container-phrasing.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/util/container-phrasing.js\");\n/* harmony import */ var mdast_util_to_markdown_lib_handle_inline_code_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! mdast-util-to-markdown/lib/handle/inline-code.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/handle/inline-code.js\");\n/* harmony import */ var markdown_table__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! markdown-table */ \"(ssr)/./node_modules/markdown-table/index.js\");\n/**\n * @typedef {import('mdast').Table} Table\n * @typedef {import('mdast').TableRow} TableRow\n * @typedef {import('mdast').TableCell} TableCell\n * @typedef {import('mdast').InlineCode} InlineCode\n *\n * @typedef {import('markdown-table').MarkdownTableOptions} MarkdownTableOptions\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 *\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Context} ToMarkdownContext\n * @typedef {import('mdast-util-to-markdown').SafeOptions} SafeOptions\n */ /**\n * @typedef Options\n * Configuration.\n * @property {boolean | null | undefined} [tableCellPadding=true]\n * Whether to add a space of padding between delimiters and cells.\n * @property {boolean | null | undefined} [tablePipeAlign=true]\n * Whether to align the delimiters.\n * @property {MarkdownTableOptions['stringLength'] | null | undefined} [stringLength]\n * Function to detect the length of table cell content, used when aligning\n * the delimiters between cells\n */ \n\n\n// To do: next major: use `state` and `state` utilities from `mdast-util-to-markdown`.\n// To do: next major: use `defaultHandlers.inlineCode`.\n// To do: next major: expose functions.\n/**\n * Extension for `mdast-util-from-markdown` to enable GFM tables.\n *\n * @type {FromMarkdownExtension}\n */ const gfmTableFromMarkdown = {\n enter: {\n table: enterTable,\n tableData: enterCell,\n tableHeader: enterCell,\n tableRow: enterRow\n },\n exit: {\n codeText: exitCodeText,\n table: exitTable,\n tableData: exit,\n tableHeader: exit,\n tableRow: exit\n }\n};\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterTable(token) {\n /** @type {Array<'left' | 'right' | 'center' | 'none'>} */ // @ts-expect-error: `align` is custom.\n const align = token._align;\n this.enter({\n type: \"table\",\n align: align.map((d)=>d === \"none\" ? null : d),\n children: []\n }, token);\n this.setData(\"inTable\", true);\n}\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitTable(token) {\n this.exit(token);\n this.setData(\"inTable\");\n}\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterRow(token) {\n this.enter({\n type: \"tableRow\",\n children: []\n }, token);\n}\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exit(token) {\n this.exit(token);\n}\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterCell(token) {\n this.enter({\n type: \"tableCell\",\n children: []\n }, token);\n}\n// Overwrite the default code text data handler to unescape escaped pipes when\n// they are in tables.\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitCodeText(token) {\n let value = this.resume();\n if (this.getData(\"inTable\")) {\n value = value.replace(/\\\\([\\\\|])/g, replace);\n }\n const node = /** @type {InlineCode} */ this.stack[this.stack.length - 1];\n node.value = value;\n this.exit(token);\n}\n/**\n * @param {string} $0\n * @param {string} $1\n * @returns {string}\n */ function replace($0, $1) {\n // Pipes work, backslashes dont (but cant escape pipes).\n return $1 === \"|\" ? $1 : $0;\n}\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM tables in\n * markdown.\n *\n * @param {Options | null | undefined} [options]\n * Configuration.\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown` to enable GFM tables.\n */ function gfmTableToMarkdown(options) {\n const settings = options || {};\n const padding = settings.tableCellPadding;\n const alignDelimiters = settings.tablePipeAlign;\n const stringLength = settings.stringLength;\n const around = padding ? \" \" : \"|\";\n return {\n unsafe: [\n {\n character: \"\\r\",\n inConstruct: \"tableCell\"\n },\n {\n character: \"\\n\",\n inConstruct: \"tableCell\"\n },\n // A pipe, when followed by a tab or space (padding), or a dash or colon\n // (unpadded delimiter row), could result in a table.\n {\n atBreak: true,\n character: \"|\",\n after: \"[\t :-]\"\n },\n // A pipe in a cell must be encoded.\n {\n character: \"|\",\n inConstruct: \"tableCell\"\n },\n // A colon must be followed by a dash, in which case it could start a\n // delimiter row.\n {\n atBreak: true,\n character: \":\",\n after: \"-\"\n },\n // A delimiter row can also start with a dash, when followed by more\n // dashes, a colon, or a pipe.\n // This is a stricter version than the built in check for lists, thematic\n // breaks, and setex heading underlines though:\n // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/51a2038/lib/unsafe.js#L57>\n {\n atBreak: true,\n character: \"-\",\n after: \"[:|-]\"\n }\n ],\n handlers: {\n table: handleTable,\n tableRow: handleTableRow,\n tableCell: handleTableCell,\n inlineCode: inlineCodeWithTable\n }\n };\n /**\n * @type {ToMarkdownHandle}\n * @param {Table} node\n */ function handleTable(node, _, context, safeOptions) {\n return serializeData(handleTableAsData(node, context, safeOptions), node.align);\n }\n /**\n * This function isnt really used normally, because we handle rows at the\n * table level.\n * But, if someone passes in a table row, this ensures we make somewhat sense.\n *\n * @type {ToMarkdownHandle}\n * @param {TableRow} node\n */ function handleTableRow(node, _, context, safeOptions) {\n const row = handleTableRowAsData(node, context, safeOptions);\n const value = serializeData([\n row\n ]);\n // `markdown-table` will always add an align row\n return value.slice(0, value.indexOf(\"\\n\"));\n }\n /**\n * @type {ToMarkdownHandle}\n * @param {TableCell} node\n */ function handleTableCell(node, _, context, safeOptions) {\n const exit = context.enter(\"tableCell\");\n const subexit = context.enter(\"phrasing\");\n const value = (0,mdast_util_to_markdown_lib_util_container_phrasing_js__WEBPACK_IMPORTED_MODULE_0__.containerPhrasing)(node, context, {\n ...safeOptions,\n before: around,\n after: around\n });\n subexit();\n exit();\n return value;\n }\n /**\n * @param {Array<Array<string>>} matrix\n * @param {Array<string | null | undefined> | null | undefined} [align]\n */ function serializeData(matrix, align) {\n return (0,markdown_table__WEBPACK_IMPORTED_MODULE_1__.markdownTable)(matrix, {\n align,\n // @ts-expect-error: `markdown-table` types should support `null`.\n alignDelimiters,\n // @ts-expect-error: `markdown-table` types should support `null`.\n padding,\n // @ts-expect-error: `markdown-table` types should support `null`.\n stringLength\n });\n }\n /**\n * @param {Table} node\n * @param {ToMarkdownContext} context\n * @param {SafeOptions} safeOptions\n */ function handleTableAsData(node, context, safeOptions) {\n const children = node.children;\n let index = -1;\n /** @type {Array<Array<string>>} */ const result = [];\n const subexit = context.enter(\"table\");\n while(++index < children.length){\n result[index] = handleTableRowAsData(children[index], context, safeOptions);\n }\n subexit();\n return result;\n }\n /**\n * @param {TableRow} node\n * @param {ToMarkdownContext} context\n * @param {SafeOptions} safeOptions\n */ function handleTableRowAsData(node, context, safeOptions) {\n const children = node.children;\n let index = -1;\n /** @type {Array<string>} */ const result = [];\n const subexit = context.enter(\"tableRow\");\n while(++index < children.length){\n // Note: the positional info as used here is incorrect.\n // Making it correct would be impossible due to aligning cells?\n // And it would need copy/pasting `markdown-table` into this project.\n result[index] = handleTableCell(children[index], node, context, safeOptions);\n }\n subexit();\n return result;\n }\n /**\n * @type {ToMarkdownHandle}\n * @param {InlineCode} node\n */ function inlineCodeWithTable(node, parent, context) {\n let value = (0,mdast_util_to_markdown_lib_handle_inline_code_js__WEBPACK_IMPORTED_MODULE_2__.inlineCode)(node, parent, context);\n if (context.stack.includes(\"tableCell\")) {\n value = value.replace(/\\|/g, \"\\\\$&\");\n }\n return value;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/mdast-util-gfm-table/lib/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/mdast-util-gfm-table/lib/index.js?67be"],"sourcesContent":["/**\n * @typedef {import('mdast').Table} Table\n * @typedef {import('mdast').TableRow} TableRow\n * @typedef {import('mdast').TableCell} TableCell\n * @typedef {import('mdast').InlineCode} InlineCode\n *\n * @typedef {import('markdown-table').MarkdownTableOptions} MarkdownTableOptions\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 *\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Context} ToMarkdownContext\n * @typedef {import('mdast-util-to-markdown').SafeOptions} SafeOptions\n */\n\n/**\n * @typedef Options\n *   Configuration.\n * @property {boolean | null | undefined} [tableCellPadding=true]\n *   Whether to add a space of padding between delimiters and cells.\n * @property {boolean | null | undefined} [tablePipeAlign=true]\n *   Whether to align the delimiters.\n * @property {MarkdownTableOptions['stringLength'] | null | undefined} [stringLength]\n *   Function to detect the length of table cell content, used when aligning\n *   the delimiters between cells\n */\n\nimport {containerPhrasing} from 'mdast-util-to-markdown/lib/util/container-phrasing.js'\nimport {inlineCode} from 'mdast-util-to-markdown/lib/handle/inline-code.js'\nimport {markdownTable} from 'markdown-table'\n\n// To do: next major: use `state` and `state` utilities from `mdast-util-to-markdown`.\n// To do: next major: use `defaultHandlers.inlineCode`.\n// To do: next major: expose functions.\n\n/**\n * Extension for `mdast-util-from-markdown` to enable GFM tables.\n *\n * @type {FromMarkdownExtension}\n */\nexport const gfmTableFromMarkdown = {\n  enter: {\n    table: enterTable,\n    tableData: enterCell,\n    tableHeader: enterCell,\n    tableRow: enterRow\n  },\n  exit: {\n    codeText: exitCodeText,\n    table: exitTable,\n    tableData: exit,\n    tableHeader: exit,\n    tableRow: exit\n  }\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterTable(token) {\n  /** @type {Array<'left' | 'right' | 'center' | 'none'>} */\n  // @ts-expect-error: `align` is custom.\n  const align = token._align\n  this.enter(\n    {\n      type: 'table',\n      align: align.map((d) => (d === 'none' ? null : d)),\n      children: []\n    },\n    token\n  )\n  this.setData('inTable', true)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitTable(token) {\n  this.exit(token)\n  this.setData('inTable')\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterRow(token) {\n  this.enter({type: 'tableRow', children: []}, token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exit(token) {\n  this.exit(token)\n}\n\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction enterCell(token) {\n  this.enter({type: 'tableCell', children: []}, token)\n}\n\n// Overwrite the default code text data handler to unescape escaped pipes when\n// they are in tables.\n/**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */\nfunction exitCodeText(token) {\n  let value = this.resume()\n\n  if (this.getData('inTable')) {\n    value = value.replace(/\\\\([\\\\|])/g, replace)\n  }\n\n  const node = /** @type {InlineCode} */ (this.stack[this.stack.length - 1])\n  node.value = value\n  this.exit(token)\n}\n\n/**\n * @param {string} $0\n * @param {string} $1\n * @returns {string}\n */\nfunction replace($0, $1) {\n  // Pipes work, backslashes don’t (but can’t escape pipes).\n  return $1 === '|' ? $1 : $0\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown` to enable GFM tables in\n * markdown.\n *\n * @param {Options | null | undefined} [options]\n *   Configuration.\n * @returns {ToMarkdownExtension}\n *   Extension for `mdast-util-to-markdown` to enable GFM tables.\n */\nexport function gfmTableToMarkdown(options) {\n  const settings = options || {}\n  const padding = settings.tableCellPadding\n  const alignDelimiters = settings.tablePipeAlign\n  const stringLength = settings.stringLength\n  const around = padding ? ' ' : '|'\n\n  return {\n    unsafe: [\n      {character: '\\r', inConstruct: 'tableCell'},\n      {character: '\\n', inConstruct: 'tableCell'},\n      // A pipe, when followed by a tab or space (padding), or a dash or colon\n      // (unpadded delimiter row), could result in a table.\n      {atBreak: true, character: '|', after: '[\\t :-]'},\n      // A pipe in a cell must be encoded.\n      {character: '|', inConstruct: 'tableCell'},\n      // A colon must be followed by a dash, in which case it could start a\n      // delimiter row.\n      {atBreak: true, character: ':', after: '-'},\n      // A delimiter row can also start with a dash, when followed by more\n      // dashes, a colon, or a pipe.\n      // This is a stricter version than the built in check for lists, thematic\n      // breaks, and setex heading underlines though:\n      // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/51a2038/lib/unsafe.js#L57>\n      {atBreak: true, character: '-', after: '[:|-]'}\n    ],\n    handlers: {\n      table: handleTable,\n      tableRow: handleTableRow,\n      tableCell: handleTableCell,\n      inlineCode: inlineCodeWithTable\n    }\n  }\n\n  /**\n   * @type {ToMarkdownHandle}\n   * @param {Table} node\n   */\n  function handleTable(node, _, context, safeOptions) {\n    return serializeData(\n      handleTableAsData(node, context, safeOptions),\n      node.align\n    )\n  }\n\n  /**\n   * This function isn’t really used normally, because we handle rows at the\n   * table level.\n   * But, if someone passes in a table row, this ensures we make somewhat sense.\n   *\n   * @type {ToMarkdownHandle}\n   * @param {TableRow} node\n   */\n  function handleTableRow(node, _, context, safeOptions) {\n    const row = handleTableRowAsData(node, context, safeOptions)\n    const value = serializeData([row])\n    // `markdown-table` will always add an align row\n    return value.slice(0, value.indexOf('\\n'))\n  }\n\n  /**\n   * @type {ToMarkdownHandle}\n   * @param {TableCell} node\n   */\n  function handleTableCell(node, _, context, safeOptions) {\n    const exit = context.enter('tableCell')\n    const subexit = context.enter('phrasing')\n    const value = containerPhrasing(node, context, {\n      ...safeOptions,\n      before: around,\n      after: around\n    })\n    subexit()\n    exit()\n    return value\n  }\n\n  /**\n   * @param {Array<Array<string>>} matrix\n   * @param {Array<string | null | undefined> | null | undefined} [align]\n   */\n  function serializeData(matrix, align) {\n    return markdownTable(matrix, {\n      align,\n      // @ts-expect-error: `markdown-table` types should support `null`.\n      alignDelimiters,\n      // @ts-expect-error: `markdown-table` types should support `null`.\n      padding,\n      // @ts-expect-error: `markdown-table` types should support `null`.\n      stringLength\n    })\n  }\n\n  /**\n   * @param {Table} node\n   * @param {ToMarkdownContext} context\n   * @param {SafeOptions} safeOptions\n   */\n  function handleTableAsData(node, context, safeOptions) {\n    const children = node.children\n    let index = -1\n    /** @type {Array<Array<string>>} */\n    const result = []\n    const subexit = context.enter('table')\n\n    while (++index < children.length) {\n      result[index] = handleTableRowAsData(\n        children[index],\n        context,\n        safeOptions\n      )\n    }\n\n    subexit()\n\n    return result\n  }\n\n  /**\n   * @param {TableRow} node\n   * @param {ToMarkdownContext} context\n   * @param {SafeOptions} safeOptions\n   */\n  function handleTableRowAsData(node, context, safeOptions) {\n    const children = node.children\n    let index = -1\n    /** @type {Array<string>} */\n    const result = []\n    const subexit = context.enter('tableRow')\n\n    while (++index < children.length) {\n      // Note: the positional info as used here is incorrect.\n      // Making it correct would be impossible due to aligning cells?\n      // And it would need copy/pasting `markdown-table` into this project.\n      result[index] = handleTableCell(\n        children[index],\n        node,\n        context,\n        safeOptions\n      )\n    }\n\n    subexit()\n\n    return result\n  }\n\n  /**\n   * @type {ToMarkdownHandle}\n   * @param {InlineCode} node\n   */\n  function inlineCodeWithTable(node, parent, context) {\n    let value = inlineCode(node, parent, context)\n\n    if (context.stack.includes('tableCell')) {\n      value = value.replace(/\\|/g, '\\\\$&')\n    }\n\n    return value\n  }\n}\n"],"names":["containerPhrasing","inlineCode","markdownTable","gfmTableFromMarkdown","enter","table","enterTable","tableData","enterCell","tableHeader","tableRow","enterRow","exit","codeText","exitCodeText","exitTable","token","align","_align","type","map","d","children","setData","value","resume","getData","replace","node","stack","length","$0","$1","gfmTableToMarkdown","options","settings","padding","tableCellPadding","alignDelimiters","tablePipeAlign","stringLength","around","unsafe","character","inConstruct","atBreak","after","handlers","handleTable","handleTableRow","tableCell","handleTableCell","inlineCodeWithTable","_","context","safeOptions","serializeData","handleTableAsData","row","handleTableRowAsData","slice","indexOf","subexit","before","matrix","index","result","parent","includes"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/mdast-util-gfm-table/lib/index.js\n");
/***/ })
};
;