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.

35 lines
31 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-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 dont expect options twice.\n schema = [\n [\n find,\n replace\n ]\n ];\n settings = options;\n } else {\n schema = find;\n // @ts-expect-error dont 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: dont 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 doesnt understand but its 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 wasnt 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvbWRhc3QtdXRpbC1maW5kLWFuZC1yZXBsYWNlL2xpYi9pbmRleC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7Ozs7O0NBUUMsR0FFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQW9EQyxHQUV3QztBQUNZO0FBQ2hCO0FBRXJDLE1BQU1HLE1BQU0sQ0FBQyxFQUFFQyxjQUFjO0FBRTdCOzs7Ozs7Ozs7Ozs7Ozs7OztDQWlCQyxHQUNELHFFQUFxRTtBQUM5RCxNQUFNQyxpQkFDWDs7Ozs7SUFLRSxHQUVBOzs7Ozs7O0tBT0MsR0FDRCxTQUFVQyxJQUFJLEVBQUVDLElBQUksRUFBRUMsT0FBTyxFQUFFQyxPQUFPO0lBQ3BDLHVDQUF1QyxHQUN2QyxJQUFJQztJQUNKLG9EQUFvRCxHQUNwRCxJQUFJQztJQUVKLElBQUksT0FBT0osU0FBUyxZQUFZQSxnQkFBZ0JLLFFBQVE7UUFDdEQsK0NBQStDO1FBQy9DRCxTQUFTO1lBQUM7Z0JBQUNKO2dCQUFNQzthQUFRO1NBQUM7UUFDMUJFLFdBQVdEO0lBQ2IsT0FBTztRQUNMRSxTQUFTSjtRQUNULCtDQUErQztRQUMvQ0csV0FBV0Y7SUFDYjtJQUVBLElBQUksQ0FBQ0UsVUFBVTtRQUNiQSxXQUFXLENBQUM7SUFDZDtJQUVBLE1BQU1HLFVBQVVYLHNEQUFPQSxDQUFDUSxTQUFTSSxNQUFNLElBQUksRUFBRTtJQUM3QyxNQUFNQyxRQUFRQyxRQUFRTDtJQUN0QixJQUFJTSxZQUFZLENBQUM7SUFFakIsTUFBTyxFQUFFQSxZQUFZRixNQUFNRyxNQUFNLENBQUU7UUFDakNqQixzRUFBWUEsQ0FBQ0ssTUFBTSxRQUFRYTtJQUM3QjtJQUVBLGlEQUFpRDtJQUNqRCxPQUFPYjtJQUVQLDJGQUEyRixHQUMzRixTQUFTYSxRQUFRQyxJQUFJLEVBQUVDLE9BQU87UUFDNUIsSUFBSUMsUUFBUSxDQUFDO1FBQ2IsK0JBQStCLEdBQy9CLElB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LENBQUNqQyxTQUFTO1FBQ3pCLElBQUlXLFFBQVEsQ0FBQztRQUViLE1BQU8sRUFBRUEsUUFBUVgsT0FBT08sTUFBTSxDQUFFO1lBQzlCNkIsT0FBT04sSUFBSSxDQUFDO2dCQUNWUSxhQUFhdEMsTUFBTSxDQUFDVyxNQUFNLENBQUMsRUFBRTtnQkFDN0I0QixXQUFXdkMsTUFBTSxDQUFDVyxNQUFNLENBQUMsRUFBRTthQUM1QjtRQUNIO0lBQ0YsT0FBTztRQUNMLG1CQUFtQixHQUNuQixJQUFJNkI7UUFFSixJQUFLQSxPQUFPeEMsT0FBUTtZQUNsQixJQUFJUixJQUFJaUQsSUFBSSxDQUFDekMsUUFBUXdDLE1BQU07Z0JBQ3pCSixPQUFPTixJQUFJLENBQUM7b0JBQUNRLGFBQWFFO29CQUFNRCxXQUFXdkMsTUFBTSxDQUFDd0MsSUFBSTtpQkFBRTtZQUMxRDtRQUNGO0lBQ0Y7SUFFQSxPQUFPSjtBQUNUO0FBRUE7Ozs7Ozs7Q0FPQyxHQUNELFNBQVNFLGFBQWExQyxJQUFJO0lBQ3hCLE9BQU8sT0FBT0EsU0FBUyxXQUFXLElBQUlLLE9BQU9aLGdFQUFNQSxDQUFDTyxPQUFPLE9BQU9BO0FBQ3BFO0FBRUE7Ozs7Ozs7Q0FPQyxHQUNELFNBQVMyQyxXQUFXMUMsT0FBTztJQUN6QixPQUFPLE9BQU9BLFlBQVksYUFBYUEsVUFBVSxJQUFNQTtBQUN6RCIsInNvdXJjZXMiOlsid2VicGFjazovL25leHRjaGF0Ly4vbm9kZV9tb2R1bGVzL21kYXN0LXV0aWwtZmluZC1hbmQtcmVwbGFjZS9saWIvaW5kZXguanM/OTQyMyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJ21kYXN0JykuUGFyZW50fSBNZGFzdFBhcmVudFxuICogQHR5cGVkZWYge2ltcG9ydCgnbWRhc3QnKS5Sb290fSBSb290XG4gKiBAdHlwZWRlZiB7aW1wb3J0KCdtZGFzdCcpLkNvbnRlbnR9IENvbnRlbnRcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJ21kYXN0JykuUGhyYXNpbmdDb250ZW50fSBQaHJhc2luZ0NvbnRlbnRcbiAqIEB0eXBlZGVmIHtpbXBvcnQoJ21kYXN0JykuVGV4dH0gVGV4dFxuICogQHR5cGVkZWYge2ltcG9ydCgndW5pc3QtdXRpbC12aXNpdC1wYXJlbnRzJykuVGVzdH0gVGVzdFxuICogQHR5cGVkZWYge2ltcG9ydCgndW5pc3QtdXRpbC12aXNpdC1wYXJlbnRzJykuVmlzaXRvclJlc3VsdH0gVmlzaXRvclJlc3VsdFxuICovXG5cbi8qKlxuICogQHR5cGVkZWYge0NvbnRlbnQgfCBSb290fSBOb2RlXG4gKiBAdHlwZWRlZiB7RXh0cmFjdDxOb2RlLCBNZGFzdFBhcmVudD59IFBhcmVudFxuICogQHR5cGVkZWYge0V4Y2x1ZGU8UGFyZW50LCBSb290Pn0gQ29udGVudFBhcmVudFxuICpcbiAqIEB0eXBlZGVmIFJlZ0V4cE1hdGNoT2JqZWN0XG4gKiAgIEluZm8gb24gdGhlIG1hdGNoLlxuICogQHByb3BlcnR5IHtudW1iZXJ9IGluZGV4XG4gKiAgIFRoZSBpbmRleCBvZiB0aGUgc2VhcmNoIGF0IHdoaWNoIHRoZSByZXN1bHQgd2FzIGZvdW5kLlxuICogQHByb3BlcnR5IHtzdHJpbmd9IGlucHV0XG4gKiAgIEEgY29weSBvZiB0aGUgc2VhcmNoIHN0cmluZyBpbiB0aGUgdGV4dCBub2RlLlxuICogQHByb3BlcnR5IHtbUm9vdCwgLi4uQXJyYXk8Q29udGVudFBhcmVudD4sIFRleHRdfSBzdGFja1xuICogICBBbGwgYW5jZXN0b3JzIG9mIHRoZSB0ZXh0IG5vZGUsIHdoZXJlIHRoZSBsYXN0IG5vZGUgaXMgdGhlIHRleHQgaXRzZWxmLlxuICpcbiAqIEBjYWxsYmFjayBSZXBsYWNlRnVuY3Rpb25cbiAqICAgQ2FsbGJhY2sgY2FsbGVkIHdoZW4gYSBzZWFyY2ggbWF0Y2hlcy5cbiAqIEBwYXJhbSB7Li4uYW55fSBwYXJhbWV0ZXJzXG4gKiAgIFRoZSBwYXJhbWV0ZXJzIGFyZSB0aGUgcmVzdWx0IG9mIGNvcnJlc3BvbmRpbmcgc2VhcmNoIGV4cHJlc3Npb246XG4gKlxuICogICAqIGB2YWx1ZWAgKGBzdHJpbmdgKSDigJQgd2hvbGUgbWF0Y2hcbiAqICAgKiBgLi4uY2FwdHVyZWAgKGBBcnJheTxzdHJpbmc+YCkg4oCUIG1hdGNoZXMgZnJvbSByZWdleCBjYXB0dXJlIGdyb3Vwc1xuICogICAqIGBtYXRjaGAgKGBSZWdFeHBNYXRjaE9iamVjdGApIOKAlCBpbmZvIG9uIHRoZSBtYXRjaFxuICogQHJldHVybnMge0FycmF5PFBocmFzaW5nQ29udGVudD4gfCBQaHJhc2luZ0NvbnRlbnQgfCBzdHJpbmcgfCBmYWxzZSB8IHVuZGVmaW5lZCB8IG51bGx9XG4gKiAgIFRoaW5nIHRvIHJlcGxhY2Ugd2l0aC5cbiAqXG4gKiAgICogd2hlbiBgbnVsbGAsIGB1bmRlZmluZWRgLCBgJydgLCByZW1vdmUgdGhlIG1hdGNoXG4gKiAgICog4oCmb3Igd2hlbiBgZmFsc2VgLCBkbyBub3QgcmVwbGFjZSBhdCBhbGxcbiAqICAgKiDigKZvciB3aGVuIGBzdHJpbmdgLCByZXBsYWNlIHdpdGggYSB0ZXh0IG5vZGUgb2YgdGhhdCB2YWx1ZVxuICogICAqIOKApm9yIHdoZW4gYE5vZGVgIG9yIGBBcnJheTxOb2RlPmAsIHJlcGxhY2Ugd2l0aCB0aG9zZSBub2Rlc1xuICpcbiAqIEB0eXBlZGVmIHtzdHJpbmcgfCBSZWdFeHB9IEZpbmRcbiAqICAgUGF0dGVybiB0byBmaW5kLlxuICpcbiAqICAgU3RyaW5ncyBhcmUgZXNjYXBlZCBhbmQgdGhlbiB0dXJuZWQgaW50byBnbG9iYWwgZXhwcmVzc2lvbnMuXG4gKlxuICogQHR5cGVkZWYge0FycmF5PEZpbmRBbmRSZXBsYWNlVHVwbGU+fSBGaW5kQW5kUmVwbGFjZUxpc3RcbiAqICAgU2V2ZXJhbCBmaW5kIGFuZCByZXBsYWNlcywgaW4gYXJyYXkgZm9ybS5cbiAqIEB0eXBlZGVmIHtSZWNvcmQ8c3RyaW5nLCBSZXBsYWNlPn0gRmluZEFuZFJlcGxhY2VTY2hlbWFcbiAqICAgU2V2ZXJhbCBmaW5kIGFuZCByZXBsYWNlcywgaW4gb2JqZWN0IGZvcm0uXG4gKiBAdHlwZWRlZiB7W0ZpbmQsIFJlcGxhY2VdfSBGaW5kQW5kUmVwbGFjZVR1cGxlXG4gKiAgIEZpbmQgYW5kIHJlcGxhY2UgaW4gdHVwbGUgZm9ybS5cbiAqIEB0eXBlZGVmIHtzdHJpbmcgfCBSZXBsYWNlRnVuY3Rpb259IFJlcGxhY2VcbiAqICAgVGhpbmcgdG8gcmVwbGFjZSB3aXRoLlxuICogQHR5cGVkZWYge1tSZWdFeHAsIFJlcGxhY2VGdW5jdGlvbl19IFBhaXJcbiAqICAgTm9ybWFsaXplZCBmaW5kIGFuZCByZXBsYWNlLlxuICogQHR5cGVkZWYge0FycmF5PFBhaXI+fSBQYWlyc1xuICogICBBbGwgZmluZCBhbmQgcmVwbGFjZWQuXG4gKlxuICogQHR5cGVkZWYgT3B0aW9uc1xuICogICBDb25maWd1cmF0aW9uLlxuICogQHByb3BlcnR5IHtUZXN0IHwgbnVsbCB8IHVuZGVmaW5lZH0gW2lnbm9yZV1cbiAqICAgVGVzdCBmb3Igd2hpY2ggbm9kZXMgdG8gaWdub3JlLlxuICovXG5cbmltcG9ydCBlc2NhcGUgZnJvbSAnZXNjYXBlLXN0cmluZy1yZWdleHAnXG5pbXBvcnQge3Zpc2l0UGFyZW50c30gZnJvbSAndW5pc3QtdXRpbC12aXNpdC1wYXJlbnRzJ1xuaW1wb3J0IHtjb252ZXJ0fSBmcm9tICd1bmlzdC11dGlsLWlzJ1xuXG5jb25zdCBvd24gPSB7fS5oYXNPd25Qcm9wZXJ0eVxuXG4vKipcbiAqIEZpbmQgcGF0dGVybnMgaW4gYSB0cmVlIGFuZCByZXBsYWNlIHRoZW0uXG4gKlxuICogVGhlIGFsZ29yaXRobSBzZWFyY2hlcyB0aGUgdHJlZSBpbiAqcHJlb3JkZXIqIGZvciBjb21wbGV0ZSB2YWx1ZXMgaW4gYFRleHRgXG4gKiBub2Rlcy5cbiAqIFBhcnRpYWwgbWF0Y2hlcyBhcmUgbm90IHN1cHBvcnRlZC5cbiAqXG4gKiBAcGFyYW0gdHJlZVxuICogICBUcmVlIHRvIGNoYW5nZS5cbiAqIEBwYXJhbSBmaW5kXG4gKiAgIFBhdHRlcm5zIHRvIGZpbmQuXG4gKiBAcGFyYW0gcmVwbGFjZVxuICogICBUaGluZ3MgdG8gcmVwbGFjZSB3aXRoICh3aGVuIGBmaW5kYCBpcyBgRmluZGApIG9yIGNvbmZpZ3VyYXRpb24uXG4gKiBAcGFyYW0gb3B0aW9uc1xuICogICBDb25maWd1cmF0aW9uICh3aGVuIGBmaW5kYCBpcyBub3QgYEZpbmRgKS5cbiAqIEByZXR1cm5zXG4gKiAgIEdpdmVuLCBtb2RpZmllZCwgdHJlZS5cbiAqL1xuLy8gVG8gZG86IG5leHQgbWFqb3I6IHJlbW92ZSBgZmluZGAgJiBgcmVwbGFjZWAgY29tYm8sIHJlbW92ZSBzY2hlbWEuXG5leHBvcnQgY29uc3QgZmluZEFuZFJlcGxhY2UgPVxuICAvKipcbiAgICogQHR5cGUgeyhcbiAgICogICAoPFRyZWUgZXh0ZW5kcyBOb2RlPih0cmVlOiBUcmVlLCBmaW5kOiBGaW5kLCByZXBsYWNlPzogUmVwbGFjZSB8IG51bGwgfCB1bmRlZmluZWQsIG9wdGlvbnM/OiBPcHRpb25zIHwgbnVsbCB8IHVuZGVmaW5lZCkgPT4gVHJlZSkgJlxuICAgKiAgICg8VHJlZSBleHRlbmRzIE5vZGU+KHRyZWU6IFRyZWUsIHNjaGVtYTogRmluZEFuZFJlcGxhY2VTY2hlbWEgfCBGaW5kQW5kUmVwbGFjZUxpc3QsIG9wdGlvbnM/OiBPcHRpb25zIHwgbnVsbCB8IHVuZGVmaW5lZCkgPT4gVHJlZSlcbiAgICogKX1cbiAgICoqL1xuICAoXG4gICAgLyoqXG4gICAgICogQHRlbXBsYXRlIHtOb2RlfSBUcmVlXG4gICAgICogQHBhcmFtIHtUcmVlfSB0cmVlXG4gICAgICogQHBhcmFtIHtGaW5kIHwgRmluZEFuZFJlcGxhY2VTY2hlbWEgfCBGaW5kQW5kUmVwbGFjZUxpc3R9IGZpbmRcbiAgICAgKiBAcGFyYW0ge1JlcGxhY2UgfCBPcHRpb25zIHwgbnVsbCB8IHVuZGVmaW5lZH0gW3JlcGxhY2VdXG4gICAgICogQHBhcmFtIHtPcHRpb25zIHwgbnVsbCB8IHVuZGVmaW5lZH0gW29wdGlvbnNdXG4gICAgICogQHJldHVybnMge1RyZWV9XG4gICAgICovXG4gICAgZnVuY3Rpb24gKHRyZWUsIGZpbmQsIHJlcGxhY2UsIG9wdGlvbnMpIHtcbiAgICAgIC8qKiBAdHlwZSB7T3B0aW9ucyB8IG51bGwgfCB1bmRlZmluZWR9ICovXG4gICAgICBsZXQgc2V0dGluZ3NcbiAgICAgIC8qKiBAdHlwZSB7RmluZEFuZFJlcGxhY2VTY2hlbWF8RmluZEFuZFJlcGxhY2VMaXN0fSAqL1xuICAgICAgbGV0IHNjaGVtYVxuXG4gICAgICBpZiAodHlwZW9mIGZpbmQgPT09ICdzdHJpbmcnIHx8IGZpbmQgaW5zdGFuY2VvZiBSZWdFeHApIHtcbiAgICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBkb27igJl0IGV4cGVjdCBvcHRpb25zIHR3aWNlLlxuICAgICAgICBzY2hlbWEgPSBbW2ZpbmQsIHJlcGxhY2VdXVxuICAgICAgICBzZXR0aW5ncyA9IG9wdGlvbnNcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHNjaGVtYSA9IGZpbmRcbiAgICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBkb27igJl0IGV4cGVjdCByZXBsYWNlIHR3aWNlLlxuICAgICAgICBzZXR0aW5ncyA9IHJlcGxhY2VcbiAgICAgIH1cblxuICAgICAgaWYgKCFzZXR0aW5ncykge1xuICAgICAgICBzZXR0aW5ncyA9IHt9XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGlnbm9yZWQgPSBjb252ZXJ0KHNldHRpbmdzLmlnbm9yZSB8fCBbXSlcbiAgICAgIGNvbnN0IHBhaXJzID0gdG9QYWlycyhzY2hlbWEpXG4gICAgICBsZXQgcGFpckluZGV4ID0gLTFcblxuICAgICAgd2hpbGUgKCsrcGFpckluZGV4IDwgcGFpcnMubGVuZ3RoKSB7XG4gICAgICAgIHZpc2l0UGFyZW50cyh0cmVlLCAndGV4dCcsIHZpc2l0b3IpXG4gICAgICB9XG5cbiAgICAgIC8vIFRvIGRvIG5leHQgbWFqb3I6IGRvbuKAmXQgcmV0dXJuIHRoZSBnaXZlbiB0cmVlLlxuICAgICAgcmV0dXJuIHRyZWVcblxuICAgICAgLyoqIEB0eXBlIHtpbXBvcnQoJ3VuaXN0LXV0aWwtdmlzaXQtcGFyZW50cy9jb21wbGV4LXR5cGVzLmpzJykuQnVpbGRWaXNpdG9yPFJvb3QsICd0ZXh0Jz59ICovXG4gICAgICBmdW5jdGlvbiB2aXNpdG9yKG5vZGUsIHBhcmVudHMpIHtcbiAgICAgICAgbGV0IGluZGV4ID0gLTFcbiAgICAgICAgLyoqIEB0eXBlIHtQYXJlbnQgfCB1bmRlZmluZWR9ICovXG4gICAgICAgIGxldCBncmFuZHBhcmVudFxuXG4gICAgICAgIHdoaWxlICgrK2luZGV4IDwgcGFyZW50cy5sZW5ndGgpIHtcbiAgICAgICAgICBjb25zdCBwYXJlbnQgPSBwYXJlbnRzW2luZGV4XVxuXG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgaWdub3JlZChcbiAgICAgICAgICAgICAgcGFyZW50LFxuICAgICAgICAgICAgICAvLyBAdHMtZXhwZWN0LWVycm9yOiBUUyBkb2VzbuKAmXQgdW5kZXJzdGFuZCBidXQgaXTigJlzIHBlcmZlY3QuXG4gICAgICAgICAgICAgIGdyYW5kcGFyZW50ID8gZ3JhbmRwYXJlbnQuY2hpbGRyZW4uaW5kZXhPZihwYXJlbnQpIDogdW5kZWZpbmVkLFxuICAgICAgICAgICAgICBncmFuZHBhcmVudFxuICAgICAgICAgICAgKVxuICAgICAgICAgICkge1xuICAgICAgICAgICAgcmV0dXJuXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgZ3JhbmRwYXJlbnQgPSBwYXJlbnRcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChncmFuZHBhcmVudCkge1xuICAgICAgICAgIHJldHVybiBoYW5kbGVyKG5vZGUsIHBhcmVudHMpXG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgLyoqXG4gICAgICAgKiBIYW5kbGUgYSB0ZXh0IG5vZGUgd2hpY2ggaXMgbm90IGluIGFuIGlnbm9yZWQgcGFyZW50LlxuICAgICAgICpcbiAgICAgICAqIEBwYXJhbSB7VGV4dH0gbm9kZVxuICAgICAgICogICBUZXh0IG5vZGUuXG4gICAgICAgKiBAcGFyYW0ge0FycmF5PFBhcmVudD59IHBhcmVudHNcbiAgICAgICAqICAgUGFyZW50cy5cbiAgICAgICAqIEByZXR1cm5zIHtWaXNpdG9yUmVzdWx0fVxuICAgICAgICogICBSZXN1bHQuXG4gICAgICAgKi9cbiAgICAgIGZ1bmN0aW9uIGhhbmRsZXIobm9kZSwgcGFyZW50cykge1xuICAgICAgICBjb25zdCBwYXJlbnQgPSBwYXJlbnRzW3BhcmVudHMubGVuZ3RoIC0gMV1cbiAgICAgICAgY29uc3QgZmluZCA9IHBhaXJzW3BhaXJJbmRleF1bMF1cbiAgICAgICAgY29uc3QgcmVwbGFjZSA9IHBhaXJzW3BhaXJJbmRleF1bMV1cbiAgICAgICAgbGV0IHN0YXJ0ID0gMFxuICAgICAgICAvLyBAdHMtZXhwZWN0LWVycm9yOiBUUyBpcyB3cm9uZywgc29tZSBvZiB0aGVzZSBjaGlsZHJlbiBjYW4gYmUgdGV4dC5cbiAgICAgICAgY29uc3QgaW5kZXggPSBwYXJlbnQuY2hpbGRyZW4uaW5kZXhPZihub2RlKVxuICAgICAgICBsZXQgY2hhbmdlID0gZmFsc2VcbiAgICAgICAgLyoqIEB0eXBlIHtBcnJheTxQaHJhc2luZ0NvbnRlbnQ+fSAqL1xuICAgICAgICBsZXQgbm9kZXMgPSBbXVxuXG4gICAgICAgIGZpbmQubGFzdEluZGV4ID0gMFxuXG4gICAgICAgIGxldCBtYXRjaCA9IGZpbmQuZXhlYyhub2RlLnZhbHVlKVxuXG4gICAgICAgIHdoaWxlIChtYXRjaCkge1xuICAgICAgICAgIGNvbnN0IHBvc2l0aW9uID0gbWF0Y2guaW5kZXhcbiAgICAgICAgICAvKiogQHR5cGUge1JlZ0V4cE1hdGNoT2JqZWN0fSAqL1xuICAgICAgICAgIGNvbnN0IG1hdGNoT2JqZWN0ID0ge1xuICAgICAgICAgICAgaW5kZXg6IG1hdGNoLmluZGV4LFxuICAgICAgICAgICAgaW5wdXQ6IG1hdGNoLmlucHV0LFxuICAgICAgICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvcjogc3RhY2sgaXMgZmluZS5cbiAgICAgICAgICAgIHN0YWNrOiBbLi4ucGFyZW50cywgbm9kZV1cbiAgICAgICAgICB9XG4gICAgICAgICAgbGV0IHZhbHVlID0gcmVwbGFjZSguLi5tYXRjaCwgbWF0Y2hPYmplY3QpXG5cbiAgICAgICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgdmFsdWUgPSB2YWx1ZS5sZW5ndGggPiAwID8ge3R5cGU6ICd0ZXh0JywgdmFsdWV9IDogdW5kZWZpbmVkXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLy8gSXQgd2FzbuKAmXQgYSBtYXRjaCBhZnRlciBhbGwuXG4gICAgICAgICAgaWYgKHZhbHVlICE9PSBmYWxzZSkge1xuICAgICAgICAgICAgaWYgKHN0YXJ0ICE9PSBwb3NpdGlvbikge1xuICAgICAgICAgICAgICBub2Rlcy5wdXNoKHtcbiAgICAgICAgICAgICAgICB0eXBlOiAndGV4dCcsXG4gICAgICAgICAgICAgICAgdmFsdWU6IG5vZGUudmFsdWUuc2xpY2Uoc3RhcnQsIHBvc2l0aW9uKVxuICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkpIHtcbiAgICAgICAgICAgICAgbm9kZXMucHVzaCguLi52YWx1ZSlcbiAgICAgICAgICAgIH0gZWxzZSBpZiAodmFsdWUpIHtcbiAgICAgICAgICAgICAgbm9kZXMucHVzaCh2YWx1ZSlcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgc3RhcnQgPSBwb3NpdGlvbiArIG1hdGNoWzBdLmxlbmd0aFxuICAgICAgICAgICAgY2hhbmdlID0gdHJ1ZVxuICAgICAgICAgIH1cblxuICAgICAgICAgIGlmICghZmluZC5nbG9iYWwpIHtcbiAgICAgICAgICAgIGJyZWFrXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgbWF0Y2ggPSBmaW5kLmV4ZWMobm9kZS52YWx1ZSlcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjaGFuZ2UpIHtcbiAgICAgICAgICBpZiAoc3RhcnQgPCBub2RlLnZhbHVlLmxlbmd0aCkge1xuICAgICAgICAgICAgbm9kZXMucHVzaCh7dHlwZTogJ3RleHQnLCB2YWx1ZTogbm9kZS52YWx1ZS5zbGljZShzdGFydCl9KVxuICAgICAgICAgIH1cblxuICAgICAgICAgIHBhcmVudC5jaGlsZHJlbi5zcGxpY2UoaW5kZXgsIDEsIC4uLm5vZGVzKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIG5vZGVzID0gW25vZGVdXG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gaW5kZXggKyBub2Rlcy5sZW5ndGhcbiAgICAgIH1cbiAgICB9XG4gIClcblxuLyoqXG4gKiBUdXJuIGEgc2NoZW1hIGludG8gcGFpcnMuXG4gKlxuICogQHBhcmFtIHtGaW5kQW5kUmVwbGFjZVNjaGVtYSB8IEZpbmRBbmRSZXBsYWNlTGlzdH0gc2NoZW1hXG4gKiAgIFNjaGVtYS5cbiAqIEByZXR1cm5zIHtQYWlyc31cbiAqICAgQ2xlYW4gcGFpcnMuXG4gKi9cbmZ1bmN0aW9uIHRvUGFpcnMoc2NoZW1hKSB7XG4gIC8qKiBAdHlwZSB7UGFpcnN9ICovXG4gIGNvbnN0IHJlc3VsdCA9IFtdXG5cbiAgaWYgKHR5cGVvZiBzY2hlbWEgIT09ICdvYmplY3QnKSB7XG4gICAgdGhyb3cgbmV3IFR5cGVFcnJvcignRXhwZWN0ZWQgYXJyYXkgb3Igb2JqZWN0IGFzIHNjaGVtYScpXG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheShzY2hlbWEpKSB7XG4gICAgbGV0IGluZGV4ID0gLTFcblxuICAgIHdoaWxlICgrK2luZGV4IDwgc2NoZW1hLmxlbmd0aCkge1xuICAgICAgcmVzdWx0LnB1c2goW1xuICAgICAgICB0b0V4cHJlc3Npb24oc2NoZW1hW2luZGV4XVswXSksXG4gICAgICAgIHRvRnVuY3Rpb24oc2NoZW1hW2luZGV4XVsxXSlcbiAgICAgIF0pXG4gICAgfVxuICB9IGVsc2Uge1xuICAgIC8qKiBAdHlwZSB7c3RyaW5nfSAqL1xuICAgIGxldCBrZXlcblxuICAgIGZvciAoa2V5IGluIHNjaGVtYSkge1xuICAgICAgaWYgKG93bi5jYWxsKHNjaGVtYSwga2V5KSkge1xuICAgICAgICByZXN1bHQucHVzaChbdG9FeHByZXNzaW9uKGtleSksIHRvRnVuY3Rpb24oc2NoZW1hW2tleV0pXSlcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gcmVzdWx0XG59XG5cbi8qKlxuICogVHVybiBhIGZpbmQgaW50byBhbiBleHByZXNzaW9uLlxuICpcbiAqIEBwYXJhbSB7RmluZH0gZmluZFxuICogICBGaW5kLlxuICogQHJldHVybnMge1JlZ0V4cH1cbiAqICAgRXhwcmVzc2lvbi5cbiAqL1xuZnVuY3Rpb24gdG9FeHByZXNzaW9uKGZpbmQpIHtcbiAgcmV0dXJuIHR5cGVvZiBmaW5kID09PSAnc3RyaW5nJyA/IG5ldyBSZWdFeHAoZXNjYXBlKGZpbmQpLCAnZycpIDogZmluZFxufVxuXG4vKipcbiAqIFR1cm4gYSByZXBsYWNlIGludG8gYSBmdW5jdGlvbi5cbiAqXG4gKiBAcGFyYW0ge1JlcGxhY2V9IHJlcGxhY2VcbiAqICAgUmVwbGFjZS5cbiAqIEByZXR1cm5zIHtSZXBsYWNlRnVuY3Rpb259XG4gKiAgIEZ1bmN0aW9uLlxuICovXG5mdW5jdGlvbiB0b0Z1bmN0aW9uKHJlcGxhY2UpIHtcbiAgcmV0dXJuIHR5cGVvZiByZXBsYWNlID09PSAnZnVuY3Rpb24nID8gcmVwbGFjZSA6ICgpID0+IHJlcGxhY2Vcbn1cbiJdLCJuYW1lcyI6WyJlc2NhcGUiLCJ2aXNpdFBhcmVudHMiLCJjb252ZXJ0Iiwib3duIiwiaGFzT3duUHJvcGVydHkiLCJmaW5kQW5kUmVwbGFjZSIsInRyZWUiLCJmaW5kIiwicmVwbGFjZSIsIm9wdGlvbnMiLCJzZXR0aW5ncyIsInNjaGVtYSIsIlJlZ0V4cCIsImlnbm9yZWQiLCJpZ25vcmUiLCJwYWlycyIsInRvUGFpcnMiLCJwYWlySW5kZXgiLCJsZW5ndGgiLCJ2aXNpdG9yIiwibm9kZSIsInBhcmVudHMiLCJpbmRleCIsImdyYW5kcGFyZW50IiwicGFyZW50IiwiY2hpbGRyZW4iLCJpbmRleE9mIiwidW5kZWZpbmVkIiwiaGFuZGxlciIsInN0YXJ0IiwiY2hhbmdlIiwibm9kZXMiLCJsYXN0SW5kZXgiLCJtYXRjaCIsImV4ZWMiLCJ2YWx1ZSIsInBvc2l0aW9uIiwibWF0Y2hPYmplY3QiLCJpbnB1dCIsInN0YWNrIiwidHlwZSIsInB1c2giLCJzbGljZSIsIkFycmF5IiwiaXNBcnJheSIsImdsb2JhbCIsInNwbGljZSIsInJlc3VsdCIsIlR5cGVFcnJvciIsInRvRXhwcmVzc2lvbiIsInRvRnVuY3Rpb24iLCJrZXkiLCJjYWxsIl0sInNvdXJjZVJvb3QiOiIifQ==\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 its 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");
/***/ })
};
;