mirror of
https://github.com/logos-messaging/lab.waku.org.git
synced 2026-01-08 00:33:11 +00:00
25 lines
34 KiB
JavaScript
25 lines
34 KiB
JavaScript
"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/react-markdown";
|
||
exports.ids = ["vendor-chunks/react-markdown"];
|
||
exports.modules = {
|
||
|
||
/***/ "(ssr)/./node_modules/react-markdown/lib/index.js":
|
||
/*!**************************************************!*\
|
||
!*** ./node_modules/react-markdown/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 */ Markdown: () => (/* binding */ Markdown),\n/* harmony export */ defaultUrlTransform: () => (/* binding */ defaultUrlTransform)\n/* harmony export */ });\n/* harmony import */ var devlop__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! devlop */ \"(ssr)/./node_modules/devlop/lib/development.js\");\n/* harmony import */ var hast_util_to_jsx_runtime__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! hast-util-to-jsx-runtime */ \"(ssr)/./node_modules/hast-util-to-jsx-runtime/lib/index.js\");\n/* harmony import */ var html_url_attributes__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! html-url-attributes */ \"(ssr)/./node_modules/html-url-attributes/lib/index.js\");\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-runtime */ \"(ssr)/./node_modules/next/dist/server/future/route-modules/app-page/vendored/ssr/react-jsx-runtime.js\");\n/* harmony import */ var remark_parse__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! remark-parse */ \"(ssr)/./node_modules/remark-parse/lib/index.js\");\n/* harmony import */ var remark_rehype__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! remark-rehype */ \"(ssr)/./node_modules/remark-rehype/lib/index.js\");\n/* harmony import */ var unified__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! unified */ \"(ssr)/./node_modules/unified/lib/index.js\");\n/* harmony import */ var unist_util_visit__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! unist-util-visit */ \"(ssr)/./node_modules/unist-util-visit/lib/index.js\");\n/* harmony import */ var vfile__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! vfile */ \"(ssr)/./node_modules/vfile/lib/index.js\");\n// Register `Raw` in tree:\n/// <reference types=\"mdast-util-to-hast\" />\n/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Nodes} Nodes\n * @typedef {import('hast').Parents} Parents\n * @typedef {import('hast').Root} Root\n * @typedef {import('hast-util-to-jsx-runtime').Components} JsxRuntimeComponents\n * @typedef {import('remark-rehype').Options} RemarkRehypeOptions\n * @typedef {import('unist-util-visit').BuildVisitor<Root>} Visitor\n * @typedef {import('unified').PluggableList} PluggableList\n */ /**\n * @callback AllowElement\n * Filter elements.\n * @param {Readonly<Element>} element\n * Element to check.\n * @param {number} index\n * Index of `element` in `parent`.\n * @param {Readonly<Parents> | undefined} parent\n * Parent of `element`.\n * @returns {boolean | null | undefined}\n * Whether to allow `element` (default: `false`).\n *\n * @typedef {Partial<JsxRuntimeComponents>} Components\n * Map tag names to components.\n *\n * @typedef Deprecation\n * Deprecation.\n * @property {string} from\n * Old field.\n * @property {string} id\n * ID in readme.\n * @property {keyof Options} [to]\n * New field.\n *\n * @typedef Options\n * Configuration.\n * @property {AllowElement | null | undefined} [allowElement]\n * Filter elements (optional);\n * `allowedElements` / `disallowedElements` is used first.\n * @property {ReadonlyArray<string> | null | undefined} [allowedElements]\n * Tag names to allow (default: all tag names);\n * cannot combine w/ `disallowedElements`.\n * @property {string | null | undefined} [children]\n * Markdown.\n * @property {string | null | undefined} [className]\n * Wrap in a `div` with this class name.\n * @property {Components | null | undefined} [components]\n * Map tag names to components.\n * @property {ReadonlyArray<string> | null | undefined} [disallowedElements]\n * Tag names to disallow (default: `[]`);\n * cannot combine w/ `allowedElements`.\n * @property {PluggableList | null | undefined} [rehypePlugins]\n * List of rehype plugins to use.\n * @property {PluggableList | null | undefined} [remarkPlugins]\n * List of remark plugins to use.\n * @property {Readonly<RemarkRehypeOptions> | null | undefined} [remarkRehypeOptions]\n * Options to pass through to `remark-rehype`.\n * @property {boolean | null | undefined} [skipHtml=false]\n * Ignore HTML in markdown completely (default: `false`).\n * @property {boolean | null | undefined} [unwrapDisallowed=false]\n * Extract (unwrap) what’s in disallowed elements (default: `false`);\n * normally when say `strong` is not allowed, it and it’s children are dropped,\n * with `unwrapDisallowed` the element itself is replaced by its children.\n * @property {UrlTransform | null | undefined} [urlTransform]\n * Change URLs (default: `defaultUrlTransform`)\n *\n * @callback UrlTransform\n * Transform all URLs.\n * @param {string} url\n * URL.\n * @param {string} key\n * Property name (example: `'href'`).\n * @param {Readonly<Element>} node\n * Node.\n * @returns {string | null | undefined}\n * Transformed URL (optional).\n */ \n\n\n// @ts-expect-error: untyped.\n\n\n\n\n\n\nconst changelog = \"https://github.com/remarkjs/react-markdown/blob/main/changelog.md\";\n/** @type {PluggableList} */ const emptyPlugins = [];\n/** @type {Readonly<RemarkRehypeOptions>} */ const emptyRemarkRehypeOptions = {\n allowDangerousHtml: true\n};\nconst safeProtocol = /^(https?|ircs?|mailto|xmpp)$/i;\n// Mutable because we `delete` any time it’s used and a message is sent.\n/** @type {ReadonlyArray<Readonly<Deprecation>>} */ const deprecations = [\n {\n from: \"astPlugins\",\n id: \"remove-buggy-html-in-markdown-parser\"\n },\n {\n from: \"allowDangerousHtml\",\n id: \"remove-buggy-html-in-markdown-parser\"\n },\n {\n from: \"allowNode\",\n id: \"replace-allownode-allowedtypes-and-disallowedtypes\",\n to: \"allowElement\"\n },\n {\n from: \"allowedTypes\",\n id: \"replace-allownode-allowedtypes-and-disallowedtypes\",\n to: \"allowedElements\"\n },\n {\n from: \"disallowedTypes\",\n id: \"replace-allownode-allowedtypes-and-disallowedtypes\",\n to: \"disallowedElements\"\n },\n {\n from: \"escapeHtml\",\n id: \"remove-buggy-html-in-markdown-parser\"\n },\n {\n from: \"includeElementIndex\",\n id: \"#remove-includeelementindex\"\n },\n {\n from: \"includeNodeIndex\",\n id: \"change-includenodeindex-to-includeelementindex\"\n },\n {\n from: \"linkTarget\",\n id: \"remove-linktarget\"\n },\n {\n from: \"plugins\",\n id: \"change-plugins-to-remarkplugins\",\n to: \"remarkPlugins\"\n },\n {\n from: \"rawSourcePos\",\n id: \"#remove-rawsourcepos\"\n },\n {\n from: \"renderers\",\n id: \"change-renderers-to-components\",\n to: \"components\"\n },\n {\n from: \"source\",\n id: \"change-source-to-children\",\n to: \"children\"\n },\n {\n from: \"sourcePos\",\n id: \"#remove-sourcepos\"\n },\n {\n from: \"transformImageUri\",\n id: \"#add-urltransform\",\n to: \"urlTransform\"\n },\n {\n from: \"transformLinkUri\",\n id: \"#add-urltransform\",\n to: \"urlTransform\"\n }\n];\n/**\n * Component to render markdown.\n *\n * @param {Readonly<Options>} options\n * Props.\n * @returns {JSX.Element}\n * React element.\n */ function Markdown(options) {\n const allowedElements = options.allowedElements;\n const allowElement = options.allowElement;\n const children = options.children || \"\";\n const className = options.className;\n const components = options.components;\n const disallowedElements = options.disallowedElements;\n const rehypePlugins = options.rehypePlugins || emptyPlugins;\n const remarkPlugins = options.remarkPlugins || emptyPlugins;\n const remarkRehypeOptions = options.remarkRehypeOptions ? {\n ...options.remarkRehypeOptions,\n ...emptyRemarkRehypeOptions\n } : emptyRemarkRehypeOptions;\n const skipHtml = options.skipHtml;\n const unwrapDisallowed = options.unwrapDisallowed;\n const urlTransform = options.urlTransform || defaultUrlTransform;\n const processor = (0,unified__WEBPACK_IMPORTED_MODULE_1__.unified)().use(remark_parse__WEBPACK_IMPORTED_MODULE_2__[\"default\"]).use(remarkPlugins).use(remark_rehype__WEBPACK_IMPORTED_MODULE_3__[\"default\"], remarkRehypeOptions).use(rehypePlugins);\n const file = new vfile__WEBPACK_IMPORTED_MODULE_4__.VFile();\n if (typeof children === \"string\") {\n file.value = children;\n } else {\n (0,devlop__WEBPACK_IMPORTED_MODULE_5__.unreachable)(\"Unexpected value `\" + children + \"` for `children` prop, expected `string`\");\n }\n if (allowedElements && disallowedElements) {\n (0,devlop__WEBPACK_IMPORTED_MODULE_5__.unreachable)(\"Unexpected combined `allowedElements` and `disallowedElements`, expected one or the other\");\n }\n for (const deprecation of deprecations){\n if (Object.hasOwn(options, deprecation.from)) {\n (0,devlop__WEBPACK_IMPORTED_MODULE_5__.unreachable)(\"Unexpected `\" + deprecation.from + \"` prop, \" + (deprecation.to ? \"use `\" + deprecation.to + \"` instead\" : \"remove it\") + \" (see <\" + changelog + \"#\" + deprecation.id + \"> for more info)\");\n }\n }\n const mdastTree = processor.parse(file);\n /** @type {Nodes} */ let hastTree = processor.runSync(mdastTree, file);\n // Wrap in `div` if there’s a class name.\n if (className) {\n hastTree = {\n type: \"element\",\n tagName: \"div\",\n properties: {\n className\n },\n // Assume no doctypes.\n children: /** @type {Array<ElementContent>} */ hastTree.type === \"root\" ? hastTree.children : [\n hastTree\n ]\n };\n }\n (0,unist_util_visit__WEBPACK_IMPORTED_MODULE_6__.visit)(hastTree, transform);\n return (0,hast_util_to_jsx_runtime__WEBPACK_IMPORTED_MODULE_7__.toJsxRuntime)(hastTree, {\n Fragment: react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.Fragment,\n components,\n ignoreInvalidStyle: true,\n jsx: react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx,\n jsxs: react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs,\n passKeys: true,\n passNode: true\n });\n /** @type {Visitor} */ function transform(node, index, parent) {\n if (node.type === \"raw\" && parent && typeof index === \"number\") {\n if (skipHtml) {\n parent.children.splice(index, 1);\n } else {\n parent.children[index] = {\n type: \"text\",\n value: node.value\n };\n }\n return index;\n }\n if (node.type === \"element\") {\n /** @type {string} */ let key;\n for(key in html_url_attributes__WEBPACK_IMPORTED_MODULE_8__.urlAttributes){\n if (Object.hasOwn(html_url_attributes__WEBPACK_IMPORTED_MODULE_8__.urlAttributes, key) && Object.hasOwn(node.properties, key)) {\n const value = node.properties[key];\n const test = html_url_attributes__WEBPACK_IMPORTED_MODULE_8__.urlAttributes[key];\n if (test === null || test.includes(node.tagName)) {\n node.properties[key] = urlTransform(String(value || \"\"), key, node);\n }\n }\n }\n }\n if (node.type === \"element\") {\n let remove = allowedElements ? !allowedElements.includes(node.tagName) : disallowedElements ? disallowedElements.includes(node.tagName) : false;\n if (!remove && allowElement && typeof index === \"number\") {\n remove = !allowElement(node, index, parent);\n }\n if (remove && parent && typeof index === \"number\") {\n if (unwrapDisallowed && node.children) {\n parent.children.splice(index, 1, ...node.children);\n } else {\n parent.children.splice(index, 1);\n }\n return index;\n }\n }\n }\n}\n/**\n * Make a URL safe.\n *\n * @satisfies {UrlTransform}\n * @param {string} value\n * URL.\n * @returns {string}\n * Safe URL.\n */ function defaultUrlTransform(value) {\n // Same as:\n // <https://github.com/micromark/micromark/blob/929275e/packages/micromark-util-sanitize-uri/dev/index.js#L34>\n // But without the `encode` part.\n const colon = value.indexOf(\":\");\n const questionMark = value.indexOf(\"?\");\n const numberSign = value.indexOf(\"#\");\n const slash = value.indexOf(\"/\");\n if (// If there is no protocol, it’s relative.\n colon < 0 || // If the first colon is after a `?`, `#`, or `/`, it’s not a protocol.\n slash > -1 && colon > slash || questionMark > -1 && colon > questionMark || numberSign > -1 && colon > numberSign || // It is a protocol, it should be allowed.\n safeProtocol.test(value.slice(0, colon))) {\n return value;\n }\n return \"\";\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/react-markdown/lib/index.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/react-markdown/lib/index.js?223c"],"sourcesContent":["// Register `Raw` in tree:\n/// <reference types=\"mdast-util-to-hast\" />\n\n/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Nodes} Nodes\n * @typedef {import('hast').Parents} Parents\n * @typedef {import('hast').Root} Root\n * @typedef {import('hast-util-to-jsx-runtime').Components} JsxRuntimeComponents\n * @typedef {import('remark-rehype').Options} RemarkRehypeOptions\n * @typedef {import('unist-util-visit').BuildVisitor<Root>} Visitor\n * @typedef {import('unified').PluggableList} PluggableList\n */\n\n/**\n * @callback AllowElement\n *   Filter elements.\n * @param {Readonly<Element>} element\n *   Element to check.\n * @param {number} index\n *   Index of `element` in `parent`.\n * @param {Readonly<Parents> | undefined} parent\n *   Parent of `element`.\n * @returns {boolean | null | undefined}\n *   Whether to allow `element` (default: `false`).\n *\n * @typedef {Partial<JsxRuntimeComponents>} Components\n *   Map tag names to components.\n *\n * @typedef Deprecation\n *   Deprecation.\n * @property {string} from\n *   Old field.\n * @property {string} id\n *   ID in readme.\n * @property {keyof Options} [to]\n *   New field.\n *\n * @typedef Options\n *   Configuration.\n * @property {AllowElement | null | undefined} [allowElement]\n *   Filter elements (optional);\n *   `allowedElements` / `disallowedElements` is used first.\n * @property {ReadonlyArray<string> | null | undefined} [allowedElements]\n *   Tag names to allow (default: all tag names);\n *   cannot combine w/ `disallowedElements`.\n * @property {string | null | undefined} [children]\n *   Markdown.\n * @property {string | null | undefined} [className]\n *   Wrap in a `div` with this class name.\n * @property {Components | null | undefined} [components]\n *   Map tag names to components.\n * @property {ReadonlyArray<string> | null | undefined} [disallowedElements]\n *   Tag names to disallow (default: `[]`);\n *   cannot combine w/ `allowedElements`.\n * @property {PluggableList | null | undefined} [rehypePlugins]\n *   List of rehype plugins to use.\n * @property {PluggableList | null | undefined} [remarkPlugins]\n *   List of remark plugins to use.\n * @property {Readonly<RemarkRehypeOptions> | null | undefined} [remarkRehypeOptions]\n *   Options to pass through to `remark-rehype`.\n * @property {boolean | null | undefined} [skipHtml=false]\n *   Ignore HTML in markdown completely (default: `false`).\n * @property {boolean | null | undefined} [unwrapDisallowed=false]\n *   Extract (unwrap) what’s in disallowed elements (default: `false`);\n *   normally when say `strong` is not allowed, it and it’s children are dropped,\n *   with `unwrapDisallowed` the element itself is replaced by its children.\n * @property {UrlTransform | null | undefined} [urlTransform]\n *   Change URLs (default: `defaultUrlTransform`)\n *\n * @callback UrlTransform\n *   Transform all URLs.\n * @param {string} url\n *   URL.\n * @param {string} key\n *   Property name (example: `'href'`).\n * @param {Readonly<Element>} node\n *   Node.\n * @returns {string | null | undefined}\n *   Transformed URL (optional).\n */\n\nimport {unreachable} from 'devlop'\nimport {toJsxRuntime} from 'hast-util-to-jsx-runtime'\nimport {urlAttributes} from 'html-url-attributes'\n// @ts-expect-error: untyped.\nimport {Fragment, jsx, jsxs} from 'react/jsx-runtime'\nimport remarkParse from 'remark-parse'\nimport remarkRehype from 'remark-rehype'\nimport {unified} from 'unified'\nimport {visit} from 'unist-util-visit'\nimport {VFile} from 'vfile'\n\nconst changelog =\n  'https://github.com/remarkjs/react-markdown/blob/main/changelog.md'\n\n/** @type {PluggableList} */\nconst emptyPlugins = []\n/** @type {Readonly<RemarkRehypeOptions>} */\nconst emptyRemarkRehypeOptions = {allowDangerousHtml: true}\nconst safeProtocol = /^(https?|ircs?|mailto|xmpp)$/i\n\n// Mutable because we `delete` any time it’s used and a message is sent.\n/** @type {ReadonlyArray<Readonly<Deprecation>>} */\nconst deprecations = [\n  {from: 'astPlugins', id: 'remove-buggy-html-in-markdown-parser'},\n  {from: 'allowDangerousHtml', id: 'remove-buggy-html-in-markdown-parser'},\n  {\n    from: 'allowNode',\n    id: 'replace-allownode-allowedtypes-and-disallowedtypes',\n    to: 'allowElement'\n  },\n  {\n    from: 'allowedTypes',\n    id: 'replace-allownode-allowedtypes-and-disallowedtypes',\n    to: 'allowedElements'\n  },\n  {\n    from: 'disallowedTypes',\n    id: 'replace-allownode-allowedtypes-and-disallowedtypes',\n    to: 'disallowedElements'\n  },\n  {from: 'escapeHtml', id: 'remove-buggy-html-in-markdown-parser'},\n  {from: 'includeElementIndex', id: '#remove-includeelementindex'},\n  {\n    from: 'includeNodeIndex',\n    id: 'change-includenodeindex-to-includeelementindex'\n  },\n  {from: 'linkTarget', id: 'remove-linktarget'},\n  {from: 'plugins', id: 'change-plugins-to-remarkplugins', to: 'remarkPlugins'},\n  {from: 'rawSourcePos', id: '#remove-rawsourcepos'},\n  {from: 'renderers', id: 'change-renderers-to-components', to: 'components'},\n  {from: 'source', id: 'change-source-to-children', to: 'children'},\n  {from: 'sourcePos', id: '#remove-sourcepos'},\n  {from: 'transformImageUri', id: '#add-urltransform', to: 'urlTransform'},\n  {from: 'transformLinkUri', id: '#add-urltransform', to: 'urlTransform'}\n]\n\n/**\n * Component to render markdown.\n *\n * @param {Readonly<Options>} options\n *   Props.\n * @returns {JSX.Element}\n *   React element.\n */\nexport function Markdown(options) {\n  const allowedElements = options.allowedElements\n  const allowElement = options.allowElement\n  const children = options.children || ''\n  const className = options.className\n  const components = options.components\n  const disallowedElements = options.disallowedElements\n  const rehypePlugins = options.rehypePlugins || emptyPlugins\n  const remarkPlugins = options.remarkPlugins || emptyPlugins\n  const remarkRehypeOptions = options.remarkRehypeOptions\n    ? {...options.remarkRehypeOptions, ...emptyRemarkRehypeOptions}\n    : emptyRemarkRehypeOptions\n  const skipHtml = options.skipHtml\n  const unwrapDisallowed = options.unwrapDisallowed\n  const urlTransform = options.urlTransform || defaultUrlTransform\n\n  const processor = unified()\n    .use(remarkParse)\n    .use(remarkPlugins)\n    .use(remarkRehype, remarkRehypeOptions)\n    .use(rehypePlugins)\n\n  const file = new VFile()\n\n  if (typeof children === 'string') {\n    file.value = children\n  } else {\n    unreachable(\n      'Unexpected value `' +\n        children +\n        '` for `children` prop, expected `string`'\n    )\n  }\n\n  if (allowedElements && disallowedElements) {\n    unreachable(\n      'Unexpected combined `allowedElements` and `disallowedElements`, expected one or the other'\n    )\n  }\n\n  for (const deprecation of deprecations) {\n    if (Object.hasOwn(options, deprecation.from)) {\n      unreachable(\n        'Unexpected `' +\n          deprecation.from +\n          '` prop, ' +\n          (deprecation.to\n            ? 'use `' + deprecation.to + '` instead'\n            : 'remove it') +\n          ' (see <' +\n          changelog +\n          '#' +\n          deprecation.id +\n          '> for more info)'\n      )\n    }\n  }\n\n  const mdastTree = processor.parse(file)\n  /** @type {Nodes} */\n  let hastTree = processor.runSync(mdastTree, file)\n\n  // Wrap in `div` if there’s a class name.\n  if (className) {\n    hastTree = {\n      type: 'element',\n      tagName: 'div',\n      properties: {className},\n      // Assume no doctypes.\n      children: /** @type {Array<ElementContent>} */ (\n        hastTree.type === 'root' ? hastTree.children : [hastTree]\n      )\n    }\n  }\n\n  visit(hastTree, transform)\n\n  return toJsxRuntime(hastTree, {\n    Fragment,\n    components,\n    ignoreInvalidStyle: true,\n    jsx,\n    jsxs,\n    passKeys: true,\n    passNode: true\n  })\n\n  /** @type {Visitor} */\n  function transform(node, index, parent) {\n    if (node.type === 'raw' && parent && typeof index === 'number') {\n      if (skipHtml) {\n        parent.children.splice(index, 1)\n      } else {\n        parent.children[index] = {type: 'text', value: node.value}\n      }\n\n      return index\n    }\n\n    if (node.type === 'element') {\n      /** @type {string} */\n      let key\n\n      for (key in urlAttributes) {\n        if (\n          Object.hasOwn(urlAttributes, key) &&\n          Object.hasOwn(node.properties, key)\n        ) {\n          const value = node.properties[key]\n          const test = urlAttributes[key]\n          if (test === null || test.includes(node.tagName)) {\n            node.properties[key] = urlTransform(String(value || ''), key, node)\n          }\n        }\n      }\n    }\n\n    if (node.type === 'element') {\n      let remove = allowedElements\n        ? !allowedElements.includes(node.tagName)\n        : disallowedElements\n        ? disallowedElements.includes(node.tagName)\n        : false\n\n      if (!remove && allowElement && typeof index === 'number') {\n        remove = !allowElement(node, index, parent)\n      }\n\n      if (remove && parent && typeof index === 'number') {\n        if (unwrapDisallowed && node.children) {\n          parent.children.splice(index, 1, ...node.children)\n        } else {\n          parent.children.splice(index, 1)\n        }\n\n        return index\n      }\n    }\n  }\n}\n\n/**\n * Make a URL safe.\n *\n * @satisfies {UrlTransform}\n * @param {string} value\n *   URL.\n * @returns {string}\n *   Safe URL.\n */\nexport function defaultUrlTransform(value) {\n  // Same as:\n  // <https://github.com/micromark/micromark/blob/929275e/packages/micromark-util-sanitize-uri/dev/index.js#L34>\n  // But without the `encode` part.\n  const colon = value.indexOf(':')\n  const questionMark = value.indexOf('?')\n  const numberSign = value.indexOf('#')\n  const slash = value.indexOf('/')\n\n  if (\n    // If there is no protocol, it’s relative.\n    colon < 0 ||\n    // If the first colon is after a `?`, `#`, or `/`, it’s not a protocol.\n    (slash > -1 && colon > slash) ||\n    (questionMark > -1 && colon > questionMark) ||\n    (numberSign > -1 && colon > numberSign) ||\n    // It is a protocol, it should be allowed.\n    safeProtocol.test(value.slice(0, colon))\n  ) {\n    return value\n  }\n\n  return ''\n}\n"],"names":["unreachable","toJsxRuntime","urlAttributes","Fragment","jsx","jsxs","remarkParse","remarkRehype","unified","visit","VFile","changelog","emptyPlugins","emptyRemarkRehypeOptions","allowDangerousHtml","safeProtocol","deprecations","from","id","to","Markdown","options","allowedElements","allowElement","children","className","components","disallowedElements","rehypePlugins","remarkPlugins","remarkRehypeOptions","skipHtml","unwrapDisallowed","urlTransform","defaultUrlTransform","processor","use","file","value","deprecation","Object","hasOwn","mdastTree","parse","hastTree","runSync","type","tagName","properties","transform","ignoreInvalidStyle","passKeys","passNode","node","index","parent","splice","key","test","includes","String","remove","colon","indexOf","questionMark","numberSign","slash","slice"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/react-markdown/lib/index.js\n");
|
||
|
||
/***/ })
|
||
|
||
};
|
||
; |