|
|
"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-find-and-replace";
|
|
|
exports.ids = ["vendor-chunks/mdast-util-find-and-replace"];
|
|
|
exports.modules = {
|
|
|
|
|
|
/***/ "(ssr)/./node_modules/mdast-util-find-and-replace/lib/index.js":
|
|
|
/*!***************************************************************!*\
|
|
|
!*** ./node_modules/mdast-util-find-and-replace/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 */ findAndReplace: () => (/* binding */ findAndReplace)\n/* harmony export */ });\n/* harmony import */ var escape_string_regexp__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! escape-string-regexp */ \"(ssr)/./node_modules/mdast-util-find-and-replace/node_modules/escape-string-regexp/index.js\");\n/* harmony import */ var unist_util_visit_parents__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! unist-util-visit-parents */ \"(ssr)/./node_modules/unist-util-visit-parents/lib/index.js\");\n/* harmony import */ var unist_util_is__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! unist-util-is */ \"(ssr)/./node_modules/unist-util-is/lib/index.js\");\n/**\n * @typedef {import('mdast').Parent} MdastParent\n * @typedef {import('mdast').Root} Root\n * @typedef {import('mdast').Content} Content\n * @typedef {import('mdast').PhrasingContent} PhrasingContent\n * @typedef {import('mdast').Text} Text\n * @typedef {import('unist-util-visit-parents').Test} Test\n * @typedef {import('unist-util-visit-parents').VisitorResult} VisitorResult\n */ /**\n * @typedef {Content | Root} Node\n * @typedef {Extract<Node, MdastParent>} Parent\n * @typedef {Exclude<Parent, Root>} ContentParent\n *\n * @typedef RegExpMatchObject\n * Info on the match.\n * @property {number} index\n * The index of the search at which the result was found.\n * @property {string} input\n * A copy of the search string in the text node.\n * @property {[Root, ...Array<ContentParent>, Text]} stack\n * All ancestors of the text node, where the last node is the text itself.\n *\n * @callback ReplaceFunction\n * Callback called when a search matches.\n * @param {...any} parameters\n * The parameters are the result of corresponding search expression:\n *\n * * `value` (`string`) — whole match\n * * `...capture` (`Array<string>`) — matches from regex capture groups\n * * `match` (`RegExpMatchObject`) — info on the match\n * @returns {Array<PhrasingContent> | PhrasingContent | string | false | undefined | null}\n * Thing to replace with.\n *\n * * when `null`, `undefined`, `''`, remove the match\n * * …or when `false`, do not replace at all\n * * …or when `string`, replace with a text node of that value\n * * …or when `Node` or `Array<Node>`, replace with those nodes\n *\n * @typedef {string | RegExp} Find\n * Pattern to find.\n *\n * Strings are escaped and then turned into global expressions.\n *\n * @typedef {Array<FindAndReplaceTuple>} FindAndReplaceList\n * Several find and replaces, in array form.\n * @typedef {Record<string, Replace>} FindAndReplaceSchema\n * Several find and replaces, in object form.\n * @typedef {[Find, Replace]} FindAndReplaceTuple\n * Find and replace in tuple form.\n * @typedef {string | ReplaceFunction} Replace\n * Thing to replace with.\n * @typedef {[RegExp, ReplaceFunction]} Pair\n * Normalized find and replace.\n * @typedef {Array<Pair>} Pairs\n * All find and replaced.\n *\n * @typedef Options\n * Configuration.\n * @property {Test | null | undefined} [ignore]\n * Test for which nodes to ignore.\n */ \n\n\nconst own = {}.hasOwnProperty;\n/**\n * Find patterns in a tree and replace them.\n *\n * The algorithm searches the tree in *preorder* for complete values in `Text`\n * nodes.\n * Partial matches are not supported.\n *\n * @param tree\n * Tree to change.\n * @param find\n * Patterns to find.\n * @param replace\n * Things to replace with (when `find` is `Find`) or configuration.\n * @param options\n * Configuration (when `find` is not `Find`).\n * @returns\n * Given, modified, tree.\n */ // To do: next major: remove `find` & `replace` combo, remove schema.\nconst findAndReplace = /**\n * @type {(\n * (<Tree extends Node>(tree: Tree, find: Find, replace?: Replace | null | undefined, options?: Options | null | undefined) => Tree) &\n * (<Tree extends Node>(tree: Tree, schema: FindAndReplaceSchema | FindAndReplaceList, options?: Options | null | undefined) => Tree)\n * )}\n **/ /**\n * @template {Node} Tree\n * @param {Tree} tree\n * @param {Find | FindAndReplaceSchema | FindAndReplaceList} find\n * @param {Replace | Options | null | undefined} [replace]\n * @param {Options | null | undefined} [options]\n * @returns {Tree}\n */ function(tree, find, replace, options) {\n /** @type {Options | null | undefined} */ let settings;\n /** @type {FindAndReplaceSchema|FindAndReplaceList} */ let schema;\n if (typeof find === \"string\" || find instanceof RegExp) {\n // @ts-expect-error don’t expect options twice.\n schema = [\n [\n find,\n replace\n ]\n ];\n settings = options;\n } else {\n schema = find;\n // @ts-expect-error don’t expect replace twice.\n settings = replace;\n }\n if (!settings) {\n settings = {};\n }\n const ignored = (0,unist_util_is__WEBPACK_IMPORTED_MODULE_1__.convert)(settings.ignore || []);\n const pairs = toPairs(schema);\n let pairIndex = -1;\n while(++pairIndex < pairs.length){\n (0,unist_util_visit_parents__WEBPACK_IMPORTED_MODULE_2__.visitParents)(tree, \"text\", visitor);\n }\n // To do next major: don’t return the given tree.\n return tree;\n /** @type {import('unist-util-visit-parents/complex-types.js').BuildVisitor<Root, 'text'>} */ function visitor(node, parents) {\n let index = -1;\n /** @type {Parent | undefined} */ let grandparent;\n while(++index < parents.length){\n const parent = parents[index];\n if (ignored(parent, // @ts-expect-error: TS doesn’t understand but it’s perfect.\n grandparent ? grandparent.children.indexOf(parent) : undefined, grandparent)) {\n return;\n }\n grandparent = parent;\n }\n if (grandparent) {\n return handler(node, parents);\n }\n }\n /**\n * Handle a text node which is not in an ignored parent.\n *\n * @param {Text} node\n * Text node.\n * @param {Array<Parent>} parents\n * Parents.\n * @returns {VisitorResult}\n * Result.\n */ function handler(node, parents) {\n const parent = parents[parents.length - 1];\n const find = pairs[pairIndex][0];\n const replace = pairs[pairIndex][1];\n let start = 0;\n // @ts-expect-error: TS is wrong, some of these children can be text.\n const index = parent.children.indexOf(node);\n let change = false;\n /** @type {Array<PhrasingContent>} */ let nodes = [];\n find.lastIndex = 0;\n let match = find.exec(node.value);\n while(match){\n const position = match.index;\n /** @type {RegExpMatchObject} */ const matchObject = {\n index: match.index,\n input: match.input,\n // @ts-expect-error: stack is fine.\n stack: [\n ...parents,\n node\n ]\n };\n let value = replace(...match, matchObject);\n if (typeof value === \"string\") {\n value = value.length > 0 ? {\n type: \"text\",\n value\n } : undefined;\n }\n // It wasn’t a match after all.\n if (value !== false) {\n if (start !== position) {\n nodes.push({\n type: \"text\",\n value: node.value.slice(start, position)\n });\n }\n if (Array.isArray(value)) {\n nodes.push(...value);\n } else if (value) {\n nodes.push(value);\n }\n start = position + match[0].length;\n change = true;\n }\n if (!find.global) {\n break;\n }\n match = find.exec(node.value);\n }\n if (change) {\n if (start < node.value.length) {\n nodes.push({\n type: \"text\",\n value: node.value.slice(start)\n });\n }\n parent.children.splice(index, 1, ...nodes);\n } else {\n nodes = [\n node\n ];\n }\n return index + nodes.length;\n }\n};\n/**\n * Turn a schema into pairs.\n *\n * @param {FindAndReplaceSchema | FindAndReplaceList} schema\n * Schema.\n * @returns {Pairs}\n * Clean pairs.\n */ function toPairs(schema) {\n /** @type {Pairs} */ const result = [];\n if (typeof schema !== \"object\") {\n throw new TypeError(\"Expected array or object as schema\");\n }\n if (Array.isArray(schema)) {\n let index = -1;\n while(++index < schema.length){\n result.push([\n toExpression(schema[index][0]),\n toFunction(schema[index][1])\n ]);\n }\n } else {\n /** @type {string} */ let key;\n for(key in schema){\n if (own.call(schema, key)) {\n result.push([\n toExpression(key),\n toFunction(schema[key])\n ]);\n }\n }\n }\n return result;\n}\n/**\n * Turn a find into an expression.\n *\n * @param {Find} find\n * Find.\n * @returns {RegExp}\n * Expression.\n */ function toExpression(find) {\n return typeof find === \"string\" ? new RegExp((0,escape_string_regexp__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(find), \"g\") : find;\n}\n/**\n * Turn a replace into a function.\n *\n * @param {Replace} replace\n * Replace.\n * @returns {ReplaceFunction}\n * Function.\n */ function toFunction(replace) {\n return typeof replace === \"function\" ? replace : ()=>replace;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/mdast-util-find-and-replace/lib/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/mdast-util-find-and-replace/lib/index.js?9423"],"sourcesContent":["/**\n * @typedef {import('mdast').Parent} MdastParent\n * @typedef {import('mdast').Root} Root\n * @typedef {import('mdast').Content} Content\n * @typedef {import('mdast').PhrasingContent} PhrasingContent\n * @typedef {import('mdast').Text} Text\n * @typedef {import('unist-util-visit-parents').Test} Test\n * @typedef {import('unist-util-visit-parents').VisitorResult} VisitorResult\n */\n\n/**\n * @typedef {Content | Root} Node\n * @typedef {Extract<Node, MdastParent>} Parent\n * @typedef {Exclude<Parent, Root>} ContentParent\n *\n * @typedef RegExpMatchObject\n *   Info on the match.\n * @property {number} index\n *   The index of the search at which the result was found.\n * @property {string} input\n *   A copy of the search string in the text node.\n * @property {[Root, ...Array<ContentParent>, Text]} stack\n *   All ancestors of the text node, where the last node is the text itself.\n *\n * @callback ReplaceFunction\n *   Callback called when a search matches.\n * @param {...any} parameters\n *   The parameters are the result of corresponding search expression:\n *\n *   * `value` (`string`) — whole match\n *   * `...capture` (`Array<string>`) — matches from regex capture groups\n *   * `match` (`RegExpMatchObject`) — info on the match\n * @returns {Array<PhrasingContent> | PhrasingContent | string | false | undefined | null}\n *   Thing to replace with.\n *\n *   * when `null`, `undefined`, `''`, remove the match\n *   * …or when `false`, do not replace at all\n *   * …or when `string`, replace with a text node of that value\n *   * …or when `Node` or `Array<Node>`, replace with those nodes\n *\n * @typedef {string | RegExp} Find\n *   Pattern to find.\n *\n *   Strings are escaped and then turned into global expressions.\n *\n * @typedef {Array<FindAndReplaceTuple>} FindAndReplaceList\n *   Several find and replaces, in array form.\n * @typedef {Record<string, Replace>} FindAndReplaceSchema\n *   Several find and replaces, in object form.\n * @typedef {[Find, Replace]} FindAndReplaceTuple\n *   Find and replace in tuple form.\n * @typedef {string | ReplaceFunction} Replace\n *   Thing to replace with.\n * @typedef {[RegExp, ReplaceFunction]} Pair\n *   Normalized find and replace.\n * @typedef {Array<Pair>} Pairs\n *   All find and replaced.\n *\n * @typedef Options\n *   Configuration.\n * @property {Test | null | undefined} [ignore]\n *   Test for which nodes to ignore.\n */\n\nimport escape from 'escape-string-regexp'\nimport {visitParents} from 'unist-util-visit-parents'\nimport {convert} from 'unist-util-is'\n\nconst own = {}.hasOwnProperty\n\n/**\n * Find patterns in a tree and replace them.\n *\n * The algorithm searches the tree in *preorder* for complete values in `Text`\n * nodes.\n * Partial matches are not supported.\n *\n * @param tree\n *   Tree to change.\n * @param find\n *   Patterns to find.\n * @param replace\n *   Things to replace with (when `find` is `Find`) or configuration.\n * @param options\n *   Configuration (when `find` is not `Find`).\n * @returns\n *   Given, modified, tree.\n */\n// To do: next major: remove `find` & `replace` combo, remove schema.\nexport const findAndReplace =\n  /**\n   * @type {(\n   *   (<Tree extends Node>(tree: Tree, find: Find, replace?: Replace | null | undefined, options?: Options | null | undefined) => Tree) &\n   *   (<Tree extends Node>(tree: Tree, schema: FindAndReplaceSchema | FindAndReplaceList, options?: Options | null | undefined) => Tree)\n   * )}\n   **/\n  (\n    /**\n     * @template {Node} Tree\n     * @param {Tree} tree\n     * @param {Find | FindAndReplaceSchema | FindAndReplaceList} find\n     * @param {Replace | Options | null | undefined} [replace]\n     * @param {Options | null | undefined} [options]\n     * @returns {Tree}\n     */\n    function (tree, find, replace, options) {\n      /** @type {Options | null | undefined} */\n      let settings\n      /** @type {FindAndReplaceSchema|FindAndReplaceList} */\n      let schema\n\n      if (typeof find === 'string' || find instanceof RegExp) {\n        // @ts-expect-error don’t expect options twice.\n        schema = [[find, replace]]\n        settings = options\n      } else {\n        schema = find\n        // @ts-expect-error don’t expect replace twice.\n        settings = replace\n      }\n\n      if (!settings) {\n        settings = {}\n      }\n\n      const ignored = convert(settings.ignore || [])\n      const pairs = toPairs(schema)\n      let pairIndex = -1\n\n      while (++pairIndex < pairs.length) {\n        visitParents(tree, 'text', visitor)\n      }\n\n      // To do next major: don’t return the given tree.\n      return tree\n\n      /** @type {import('unist-util-visit-parents/complex-types.js').BuildVisitor<Root, 'text'>} */\n      function visitor(node, parents) {\n        let index = -1\n        /** @type {Parent | undefined} */\n        let grandparent\n\n        while (++index < parents.length) {\n          const parent = parents[index]\n\n          if (\n            ignored(\n              parent,\n              // @ts-expect-error: TS doesn’t understand but it’s perfect.\n              grandparent ? grandparent.children.indexOf(parent) : undefined,\n              grandparent\n            )\n          ) {\n            return\n          }\n\n          grandparent = parent\n        }\n\n        if (grandparent) {\n          return handler(node, parents)\n        }\n      }\n\n      /**\n       * Handle a text node which is not in an ignored parent.\n       *\n       * @param {Text} node\n       *   Text node.\n       * @param {Array<Parent>} parents\n       *   Parents.\n       * @returns {VisitorResult}\n       *   Result.\n       */\n      function handler(node, parents) {\n        const parent = parents[parents.length - 1]\n        const find = pairs[pairIndex][0]\n        const replace = pairs[pairIndex][1]\n        let start = 0\n        // @ts-expect-error: TS is wrong, some of these children can be text.\n        const index = parent.children.indexOf(node)\n        let change = false\n        /** @type {Array<PhrasingContent>} */\n        let nodes = []\n\n        find.lastIndex = 0\n\n        let match = find.exec(node.value)\n\n        while (match) {\n          const position = match.index\n          /** @type {RegExpMatchObject} */\n          const matchObject = {\n            index: match.index,\n            input: match.input,\n            // @ts-expect-error: stack is fine.\n            stack: [...parents, node]\n          }\n          let value = replace(...match, matchObject)\n\n          if (typeof value === 'string') {\n            value = value.length > 0 ? {type: 'text', value} : undefined\n          }\n\n          // It wasn’t a match after all.\n          if (value !== false) {\n            if (start !== position) {\n              nodes.push({\n                type: 'text',\n                value: node.value.slice(start, position)\n              })\n            }\n\n            if (Array.isArray(value)) {\n              nodes.push(...value)\n            } else if (value) {\n              nodes.push(value)\n            }\n\n            start = position + match[0].length\n            change = true\n          }\n\n          if (!find.global) {\n            break\n          }\n\n          match = find.exec(node.value)\n        }\n\n        if (change) {\n          if (start < node.value.length) {\n            nodes.push({type: 'text', value: node.value.slice(start)})\n          }\n\n          parent.children.splice(index, 1, ...nodes)\n        } else {\n          nodes = [node]\n        }\n\n        return index + nodes.length\n      }\n    }\n  )\n\n/**\n * Turn a schema into pairs.\n *\n * @param {FindAndReplaceSchema | FindAndReplaceList} schema\n *   Schema.\n * @returns {Pairs}\n *   Clean pairs.\n */\nfunction toPairs(schema) {\n  /** @type {Pairs} */\n  const result = []\n\n  if (typeof schema !== 'object') {\n    throw new TypeError('Expected array or object as schema')\n  }\n\n  if (Array.isArray(schema)) {\n    let index = -1\n\n    while (++index < schema.length) {\n      result.push([\n        toExpression(schema[index][0]),\n        toFunction(schema[index][1])\n      ])\n    }\n  } else {\n    /** @type {string} */\n    let key\n\n    for (key in schema) {\n      if (own.call(schema, key)) {\n        result.push([toExpression(key), toFunction(schema[key])])\n      }\n    }\n  }\n\n  return result\n}\n\n/**\n * Turn a find into an expression.\n *\n * @param {Find} find\n *   Find.\n * @returns {RegExp}\n *   Expression.\n */\nfunction toExpression(find) {\n  return typeof find === 'string' ? new RegExp(escape(find), 'g') : find\n}\n\n/**\n * Turn a replace into a function.\n *\n * @param {Replace} replace\n *   Replace.\n * @returns {ReplaceFunction}\n *   Function.\n */\nfunction toFunction(replace) {\n  return typeof replace === 'function' ? replace : () => replace\n}\n"],"names":["escape","visitParents","convert","own","hasOwnProperty","findAndReplace","tree","find","replace","options","settings","schema","RegExp","ignored","ignore","pairs","toPairs","pairIndex","length","visitor","node","parents","index","grandparent","parent","children","indexOf","undefined","handler","start","change","nodes","lastIndex","match","exec","value","position","matchObject","input","stack","type","push","slice","Array","isArray","global","splice","result","TypeError","toExpression","toFunction","key","call"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/mdast-util-find-and-replace/lib/index.js\n");
|
|
|
|
|
|
/***/ }),
|
|
|
|
|
|
/***/ "(ssr)/./node_modules/mdast-util-find-and-replace/node_modules/escape-string-regexp/index.js":
|
|
|
/*!*********************************************************************************************!*\
|
|
|
!*** ./node_modules/mdast-util-find-and-replace/node_modules/escape-string-regexp/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 */ \"default\": () => (/* binding */ escapeStringRegexp)\n/* harmony export */ });\nfunction escapeStringRegexp(string) {\n if (typeof string !== \"string\") {\n throw new TypeError(\"Expected a string\");\n }\n // Escape characters with special meaning either inside or outside character sets.\n // Use a simple backslash escape when it’s always valid, and a `\\xnn` escape when the simpler form would be disallowed by Unicode patterns’ stricter grammar.\n return string.replace(/[|\\\\{}()[\\]^$+*?.]/g, \"\\\\$&\").replace(/-/g, \"\\\\x2d\");\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvbWRhc3QtdXRpbC1maW5kLWFuZC1yZXBsYWNlL25vZGVfbW9kdWxlcy9lc2NhcGUtc3RyaW5nLXJlZ2V4cC9pbmRleC5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBQWUsU0FBU0EsbUJBQW1CQyxNQUFNO0lBQ2hELElBQUksT0FBT0EsV0FBVyxVQUFVO1FBQy9CLE1BQU0sSUFBSUMsVUFBVTtJQUNyQjtJQUVBLGtGQUFrRjtJQUNsRiw2SkFBNko7SUFDN0osT0FBT0QsT0FDTEUsT0FBTyxDQUFDLHVCQUF1QixRQUMvQkEsT0FBTyxDQUFDLE1BQU07QUFDakIiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9uZXh0Y2hhdC8uL25vZGVfbW9kdWxlcy9tZGFzdC11dGlsLWZpbmQtYW5kLXJlcGxhY2Uvbm9kZV9tb2R1bGVzL2VzY2FwZS1zdHJpbmctcmVnZXhwL2luZGV4LmpzPzJlMjkiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gZXNjYXBlU3RyaW5nUmVnZXhwKHN0cmluZykge1xuXHRpZiAodHlwZW9mIHN0cmluZyAhPT0gJ3N0cmluZycpIHtcblx0XHR0aHJvdyBuZXcgVHlwZUVycm9yKCdFeHBlY3RlZCBhIHN0cmluZycpO1xuXHR9XG5cblx0Ly8gRXNjYXBlIGNoYXJhY3RlcnMgd2l0aCBzcGVjaWFsIG1lYW5pbmcgZWl0aGVyIGluc2lkZSBvciBvdXRzaWRlIGNoYXJhY3RlciBzZXRzLlxuXHQvLyBVc2UgYSBzaW1wbGUgYmFja3NsYXNoIGVzY2FwZSB3aGVuIGl04oCZcyBhbHdheXMgdmFsaWQsIGFuZCBhIGBcXHhubmAgZXNjYXBlIHdoZW4gdGhlIHNpbXBsZXIgZm9ybSB3b3VsZCBiZSBkaXNhbGxvd2VkIGJ5IFVuaWNvZGUgcGF0dGVybnPigJkgc3RyaWN0ZXIgZ3JhbW1hci5cblx0cmV0dXJuIHN0cmluZ1xuXHRcdC5yZXBsYWNlKC9bfFxcXFx7fSgpW1xcXV4kKyo/Ll0vZywgJ1xcXFwkJicpXG5cdFx0LnJlcGxhY2UoLy0vZywgJ1xcXFx4MmQnKTtcbn1cbiJdLCJuYW1lcyI6WyJlc2NhcGVTdHJpbmdSZWdleHAiLCJzdHJpbmciLCJUeXBlRXJyb3IiLCJyZXBsYWNlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/mdast-util-find-and-replace/node_modules/escape-string-regexp/index.js\n");
|
|
|
|
|
|
/***/ })
|
|
|
|
|
|
};
|
|
|
; |