|
|
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 don’t (but can’t 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 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 */ 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":";;;;;;;;AAAA;;;;;;;;;;;;;;;;CAgBC,GAED;;;;;;;;;;CAUC,GAEsF;AACZ;AAC/B;AAE5C,sFAAsF;AACtF,uDAAuD;AACvD,uCAAuC;AAEvC;;;;CAIC,GACM,MAAMG,uBAAuB;IAClCC,OAAO;QACLC,OAAOC;QACPC,WAAWC;QACXC,aAAaD;QACbE,UAAUC;IACZ;IACAC,MAAM;QACJC,UAAUC;QACVT,OAAOU;QACPR,WAAWK;QACXH,aAAaG;QACbF,UAAUE;IACZ;AACF,EAAC;AAED;;;CAGC,GACD,SAASN,WAAWU,KAAK;IACvB,wDAAwD,GACxD,uCAAuC;IACvC,MAAMC,QAAQD,MAAME,MAAM;IAC1B,IAAI,CAACd,KAAK,CACR;QACEe,MAAM;QACNF,OAAOA,MAAMG,GAAG,CAAC,CAACC,IAAOA,MAAM,SAAS,OAAOA;QAC/CC,UAAU,EAAE;IACd,GACAN;IAEF,IAAI,CAACO,OAAO,CAAC,WAAW;AAC1B;AAEA;;;CAGC,GACD,SAASR,UAAUC,KAAK;IACtB,IAAI,CAACJ,IAAI,CAACI;IACV,IAAI,CAACO,OAAO,CAAC;AACf;AAEA;;;CAGC,GACD,SAASZ,SAASK,KAAK;IACrB,IAAI,CAACZ,KAAK,CAAC;QAACe,MAAM;QAAYG,UAAU,EAAE;IAAA,GAAGN;AAC/C;AAEA;;;CAGC,GACD,SAASJ,KAAKI,KAAK;IACjB,IAAI,CAACJ,IAAI,CAACI;AACZ;AAEA;;;CAGC,GACD,SAASR,UAAUQ,KAAK;IACtB,IAAI,CAACZ,KAAK,CAAC;QAACe,MAAM;QAAaG,UAAU,EAAE;IAAA,GAAGN;AAChD;AAEA,8EAA8E;AAC9E,sBAAsB;AACtB;;;CAGC,GACD,SAASF,aAAaE,KAAK;IACzB,IAAIQ,QAAQ,IAAI,CAACC,MAAM;IAEvB,IAAI,IAAI,CAACC,OAAO,CAAC,YAAY;QAC3BF,QAAQA,MAAMG,OAAO,CAAC,cAAcA;IACtC;IAEA,MAAMC,OAAO,uBAAuB,GAAI,IAAI,CAACC,KAAK,CAAC,IAAI,CAACA,KAAK,CAACC,MAAM,GAAG,EAAE;IACzEF,KAAKJ,KAAK,GAAGA;IACb,IAAI,CAACZ,IAAI,CAACI;AACZ;AAEA;;;;CAIC,GACD,SAASW,QAAQI,EAAE,EAAEC,EAAE;IACrB,0DAA0D;IAC1D,OAAOA,OAAO,MAAMA,KAAKD;AAC3B;AAEA;;;;;;;;CAQC,GACM,SAASE,mBAAmBC,OAAO;IACxC,MAAMC,WAAWD,WAAW,CAAC;IAC7B,MAAME,UAAUD,SAASE,gBAAgB;IACzC,MAAMC,kBAAkBH,SAASI,cAAc;IAC/C,MAAMC,eAAeL,SAASK,YAAY;IAC1C,MAAMC,SAASL,UAAU,MAAM;IAE/B,OAAO;QACLM,QAAQ;YACN;gBAACC,WAAW;gBAAMC,aAAa;YAAW;YAC1C;gBAACD,WAAW;gBAAMC,aAAa;YAAW;YAC1C,wEAAwE;YACxE,qDAAqD;YACrD;gBAACC,SAAS;gBAAMF,WAAW;gBAAKG,OAAO;YAAS;YAChD,oCAAoC;YACpC;gBAACH,WAAW;gBAAKC,aAAa;YAAW;YACzC,qEAAqE;YACrE,iBAAiB;YACjB;gBAACC,SAAS;gBAAMF,WAAW;gBAAKG,OAAO;YAAG;YAC1C,oEAAoE;YACpE,8BAA8B;YAC9B,yEAAyE;YACzE,+CAA+C;YAC/C,yFAAyF;YACzF;gBAACD,SAAS;gBAAMF,WAAW;gBAAKG,OAAO;YAAO;SAC/C;QACDC,UAAU;YACR1C,OAAO2C;YACPtC,UAAUuC;YACVC,WAAWC;YACXlD,YAAYmD;QACd;IACF;IAEA;;;GAGC,GACD,SAASJ,YAAYpB,IAAI,EAAEyB,CAAC,EAAEC,OAAO,EAAEC,WAAW;QAChD,OAAOC,cACLC,kBAAkB7B,MAAM0B,SAASC,cACjC3B,KAAKX,KAAK;IAEd;IAEA;;;;;;;GAOC,GACD,SAASgC,eAAerB,IAAI,EAAEyB,CAAC,EAAEC,OAAO,EAAEC,WAAW;QACnD,MAAMG,MAAMC,qBAAqB/B,MAAM0B,SAASC;QAChD,MAAM/B,QAAQgC,cAAc;YAACE;SAAI;QACjC,gDAAgD;QAChD,OAAOlC,MAAMoC,KAAK,CAAC,GAAGpC,MAAMqC,OAAO,CAAC;IACtC;IAEA;;;GAGC,GACD,SAASV,gBAAgBvB,IAAI,EAAEyB,CAAC,EAAEC,OAAO,EAAEC,WAAW;QACpD,MAAM3C,OAAO0C,QAAQlD,KAAK,CAAC;QAC3B,MAAM0D,UAAUR,QAAQlD,KAAK,CAAC;QAC9B,MAAMoB,QAAQxB,wGAAiBA,CAAC4B,MAAM0B,SAAS;YAC7C,GAAGC,WAAW;YACdQ,QAAQtB;YACRK,OAAOL;QACT;QACAqB;QACAlD;QACA,OAAOY;IACT;IAEA;;;GAGC,GACD,SAASgC,cAAcQ,MAAM,EAAE/C,KAAK;QAClC,OAAOf,6DAAaA,CAAC8D,QAAQ;YAC3B/C;YACA,kEAAkE;YAClEqB;YACA,kEAAkE;YAClEF;YACA,kEAAkE;YAClEI;QACF;IACF;IAEA;;;;GAIC,GACD,SAASiB,kBAAkB7B,IAAI,EAAE0B,OAAO,EAAEC,WAAW;QACnD,MAAMjC,WAAWM,KAAKN,QAAQ;QAC9B,IAAI2C,QAAQ,CAAC;QACb,iCAAiC,GACjC,MAAMC,SAAS,EAAE;QACjB,MAAMJ,UAAUR,QAAQlD,KAAK,CAAC;QAE9B,MAAO,EAAE6D,QAAQ3C,SAASQ,MAAM,CAAE;YAChCoC,MAAM,CAACD,MAAM,GAAGN,qBACdrC,QAAQ,CAAC2C,MAAM,EACfX,SACAC;QAEJ;QAEAO;QAEA,OAAOI;IACT;IAEA;;;;GAIC,GACD,SAASP,qBAAqB/B,IAAI,EAAE0B,OAAO,EAAEC,WAAW;QACtD,MAAMjC,WAAWM,KAAKN,QAAQ;QAC9B,IAAI2C,QAAQ,CAAC;QACb,0BAA0B,GAC1B,MAAMC,SAAS,EAAE;QACjB,MAAMJ,UAAUR,QAAQlD,KAAK,CAAC;QAE9B,MAAO,EAAE6D,QAAQ3C,SAASQ,MAAM,CAAE;YAChC,uDAAuD;YACvD,+DAA+D;YAC/D,qEAAqE;YACrEoC,MAAM,CAACD,MAAM,GAAGd,gBACd7B,QAAQ,CAAC2C,MAAM,EACfrC,MACA0B,SACAC;QAEJ;QAEAO;QAEA,OAAOI;IACT;IAEA;;;GAGC,GACD,SAASd,oBAAoBxB,IAAI,EAAEuC,MAAM,EAAEb,OAAO;QAChD,IAAI9B,QAAQvB,4FAAUA,CAAC2B,MAAMuC,QAAQb;QAErC,IAAIA,QAAQzB,KAAK,CAACuC,QAAQ,CAAC,cAAc;YACvC5C,QAAQA,MAAMG,OAAO,CAAC,OAAO;QAC/B;QAEA,OAAOH;IACT;AACF","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");
|