From 1b227dfcf8e4caadb625958656a3bd9e7bc5d4e8 Mon Sep 17 00:00:00 2001 From: Olling <48805670+Ollie-nl@users.noreply.github.com> Date: Tue, 24 Dec 2024 10:46:15 +0100 Subject: [PATCH] docs/ verwijderd uit main --- docs/.htaccess | 6 - docs/_redirects | 1 - docs/asset-manifest.json | 14 - docs/data/available-months.json | 3 - docs/data/slides-2024-02.json | 45 - docs/data/slides-2024-03.json | 57 - docs/data/slides-2024-08.json | 39 - docs/data/slides-2024-09.json | 105 - docs/data/slides-2024-10.json | 113 - docs/data/slides-2024-12.json | 155 - docs/file.svg | 1 - docs/globe.svg | 1 - docs/images/darth-vader-xmas.jpeg | Bin 128747 -> 0 bytes docs/images/happy-2025.jpeg | Bin 44654 -> 0 bytes docs/index.html | 18 - docs/next.svg | 1 - docs/static/css/main.2a9063d3.css | 208 - docs/static/css/main.ec9d09e5.css | 2 - docs/static/css/main.ec9d09e5.css.map | 1 - docs/static/js/main.d6e15f43.js | 19657 ------------------ docs/static/js/main.d6e15f43.js.LICENSE.txt | 50 - docs/static/js/main.d6e15f43.js.map | 1 - docs/vercel.svg | 1 - docs/window.svg | 1 - 24 files changed, 20480 deletions(-) delete mode 100644 docs/.htaccess delete mode 100644 docs/_redirects delete mode 100644 docs/asset-manifest.json delete mode 100644 docs/data/available-months.json delete mode 100644 docs/data/slides-2024-02.json delete mode 100644 docs/data/slides-2024-03.json delete mode 100644 docs/data/slides-2024-08.json delete mode 100644 docs/data/slides-2024-09.json delete mode 100644 docs/data/slides-2024-10.json delete mode 100644 docs/data/slides-2024-12.json delete mode 100644 docs/file.svg delete mode 100644 docs/globe.svg delete mode 100644 docs/images/darth-vader-xmas.jpeg delete mode 100644 docs/images/happy-2025.jpeg delete mode 100644 docs/index.html delete mode 100644 docs/next.svg delete mode 100644 docs/static/css/main.2a9063d3.css delete mode 100644 docs/static/css/main.ec9d09e5.css delete mode 100644 docs/static/css/main.ec9d09e5.css.map delete mode 100644 docs/static/js/main.d6e15f43.js delete mode 100644 docs/static/js/main.d6e15f43.js.LICENSE.txt delete mode 100644 docs/static/js/main.d6e15f43.js.map delete mode 100644 docs/vercel.svg delete mode 100644 docs/window.svg diff --git a/docs/.htaccess b/docs/.htaccess deleted file mode 100644 index ff50d81..0000000 --- a/docs/.htaccess +++ /dev/null @@ -1,6 +0,0 @@ -RewriteEngine On -RewriteBase /cool-uncool/ -RewriteRule ^index\.html$ - [L] -RewriteCond %{REQUEST_FILENAME} !-f -RewriteCond %{REQUEST_FILENAME} !-d -RewriteRule . /cool-uncool/index.html [L] diff --git a/docs/_redirects b/docs/_redirects deleted file mode 100644 index ad37e2c..0000000 --- a/docs/_redirects +++ /dev/null @@ -1 +0,0 @@ -/* /index.html 200 diff --git a/docs/asset-manifest.json b/docs/asset-manifest.json deleted file mode 100644 index 4d9b21c..0000000 --- a/docs/asset-manifest.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "files": { - "main.css": "./static/css/main.ec9d09e5.css", - "main.js": "./static/js/main.d6e15f43.js", - "index.html": "./index.html", - "main.ec9d09e5.css.map": "./static/css/main.ec9d09e5.css.map", - "main.d6e15f43.js.map": "./static/js/main.d6e15f43.js.map" - }, - - "entrypoints": [ - "static/css/main.ec9d09e5.css", - "static/js/main.d6e15f43.js" - ] - diff --git a/docs/data/available-months.json b/docs/data/available-months.json deleted file mode 100644 index d98e950..0000000 --- a/docs/data/available-months.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "months": ["2024-12", "2024-10", "2024-09", "2024-08", "2024-03", "2024-02"] -} diff --git a/docs/data/slides-2024-02.json b/docs/data/slides-2024-02.json deleted file mode 100644 index d2f15f2..0000000 --- a/docs/data/slides-2024-02.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "slides": [ - { - "type": "heading", - "content": "😎 😩 Februari", - "slug": "start" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/DdkTXV2qWv4", - "title": "Mario question block lamp", - "icon": "πŸ•ΉοΈ" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/EQsK7sa1dh4", - "title": "Planetarium Projector", - "icon": "πŸͺ" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/rcA5YlmWFb8", - "title": "Time Timer Pocket", - "icon": "⏰" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/q20oielroj8", - "title": "Kitchen lockbox", - "icon": "πŸ”’" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/XPwXIPpPImM", - "title": "MuxWave raamscherm", - "icon": "πŸͺŸ" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/HK6y8DAPN_0", - "title": "OpenIA Sora, text to video model", - "icon": "πŸ€–" - } - ] -} diff --git a/docs/data/slides-2024-03.json b/docs/data/slides-2024-03.json deleted file mode 100644 index e300af1..0000000 --- a/docs/data/slides-2024-03.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "slides": [ - { - "type": "heading", - "content": "😎 😩 Maart", - "slug": "start" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/Q1Cd5L_qVwQ", - "title": "Godzilla coinbank", - "icon": "🧸" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/MO9ijt1IpmE", - "title": "Lego Brickit App (by Jeff πŸ’™)", - "icon": "🧸" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/svkUIJedyS8", - "title": "Converse Dungeons & Dragons", - "icon": "πŸ‘Ÿ" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/mWBa8-vAF2E", - "title": "Russia Amber elektrische auto", - "icon": "πŸš—" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/XPwXIPpPImM", - "title": "MuxWave raamscherm", - "icon": "πŸͺŸ" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/Y-rwv4jhrg4", - "title": "Disney (research) Holotile Floor", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/3xPac81D4Kw", - "title": "β€œThe Line” Saudi Arabia", - "icon": "πŸŒ†" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/29ECwExc-_M", - "title": "Boston Dynamics nieuwe Atlas robot", - "icon": "πŸ€–" - } - ] -} diff --git a/docs/data/slides-2024-08.json b/docs/data/slides-2024-08.json deleted file mode 100644 index 178dfae..0000000 --- a/docs/data/slides-2024-08.json +++ /dev/null @@ -1,39 +0,0 @@ -{ - "slides": [ - { - "type": "heading", - "content": "😎 😩 Augustus", - "slug": "start" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/RDng7uX0M0Q", - "title": "MURMURING MINDS - DRIFT at LUMA, Arles (Jeroen)", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/MxTWLm9vT_o", - "title": "Reverse Turing Test Experiment with AI(Jeff)", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/vN2BghLEeTQ", - "title": "Squirrels & Oak Trees", - "icon": "🐿️ 🌳" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/Sq1QZB5baNw", - "title": "Uit de oude doos (Cool Uncool Maart 2024) Figure 01 Update", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/0SRVJaOg9Co", - "title": "Introducing Figure 02", - "icon": "πŸ€–" - } - ] -} diff --git a/docs/data/slides-2024-09.json b/docs/data/slides-2024-09.json deleted file mode 100644 index 05b6934..0000000 --- a/docs/data/slides-2024-09.json +++ /dev/null @@ -1,105 +0,0 @@ -{ - "slides": [ - { - "type": "heading", - "content": "😎 😩 September", - "slug": "start" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/tSLOgkNFzLc", - "title": "The Ultimate Challenge with Lando Norris | LEGO Technic", - "icon": "🧸" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/OGwm4aKzYgs", - "title": "Batman Batmobile Crocs On Foot Review & Sizing: Step into Gotham", - "icon": "🩴" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/q0tLND-o3WM", - "title": "Next level costume", - "icon": "πŸ‘»" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/n-BZ5-Q48lE", - "title": "New NES Tetris Technique: Faster Than Hypertapping!", - "icon": "πŸ•ΉοΈ" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/shorts/hbbzsIGoRWg", - "title": "NBA Snapchat filter on audience", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/_mbrWLV-p04 ", - "title": "Extreme Post-its", - "icon": "✍🏼" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/w7saxMRlQcY", - "title": "Toilet with the best view", - "icon": "🌱" - }, - { - "type": "paragraph", - "content": "https://subsites.wur.nl/nl/display-on-pages/artikel/new-dawn-bio-hout-uit-het-lab.htm\n[New Dawn Bio](https://www.newdawnbio.com)", - "title": "Kweek hout", - "icon": "πŸ”¬" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/799W-aRTKPM", - "title": "Cosm Los Angeles, Hollywood Park (Shared Reality)", - "icon": "🍿" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/MkrVZ2jzCco", - "title": "Thailand Jungle Bubbles", - "icon": "πŸ–οΈ" - }, - { - "type": "paragraph", - "content": "https://www.kijkmagazine.nl/science/spinnen-vuurvliegjes/", - "title": "Spin kaapt lichtflitsen van vuurvliegjes om meer prooien te lokken", - "icon": "🌱" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/OmcM683JIgU", - "title": "This robotic extra thumb can be controlled by moving your toes", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/SjsTzWXPBLM", - "title": "The Dragon Drone - An Innovative Drone From The University of Tokyo", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/p8JnKgXZQ9A", - "title": "Fully-Automatic Robot Dentist Performs World's First Human Procedure!", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/Zz8xPxXf_X8", - "title": "Lionel Messi in 80s dancing on Modern talking", - "icon": "πŸ€–" - }, - { - "type": "paragraph", - "content": "### Rolbeschrijving (aanvullingen):\n- Je bent opgegroeid in een multiculturele wijk.\n- Je hebt een kleine vriendenkring.\n- Je bent geΓ―nteresseerd in hiphop en straatcultuur.\n\n**Instructies:**\n- Gebruik informele taal.\n- Voeg waar passend Utrechts dialect of straattaal toe.\n- Wees sceptisch over initiatieven van de overheid.", - "title": "Demo Persona via ChatGPT o1-preview", - "icon": "πŸ€–" - } - ] -} diff --git a/docs/data/slides-2024-10.json b/docs/data/slides-2024-10.json deleted file mode 100644 index aa7780c..0000000 --- a/docs/data/slides-2024-10.json +++ /dev/null @@ -1,113 +0,0 @@ -{ - "slides": [ - { - "type": "heading", - "content": "😎 😩 oktober", - "slug": "start" - }, - { - "type": "youtube", - "url": "https://youtube.com/shorts/z8I3osTmaFc", - "title": "Korea dance #waacking", - "icon": "πŸ’ƒπŸ»", - "slug": "korea-dance" - }, - { - "type": "youtube", - "url": "https://youtube.com/shorts/JcBTibj0-s0", - "title": "Vending machine", - "icon": "πŸ₯Ά", - "slug": "vending-machine" - }, - { - "type": "youtube", - "url": "https://youtube.com/shorts/XjT5Rui92aY", - "title": "Signature of a cartoonist johm william", - "icon": "✍🏼", - "slug": "signature" - }, - { - "type": "youtube", - "url": "https://youtube.com/shorts/TlFNZ-2muvw", - "title": "Dommetje in de Dom", - "icon": "🏰", - "slug": "dommetje" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/mYHMc3-f3v8", - "title": "πŸ€ Rats Learn To Drive Tiny Cars", - "icon": "🏰" - }, - { - "type": "paragraph", - "content": "De kubus is 5 millimeter groot. Hij is gemaakt van aluminium en weegt zo'n 0,33 gram. De kubus past ruim duizend keer in het originele exemplaar. Elke zijde van die versie meet namelijk 5,6 centimeter.", - "title": "Kleinste Rubiks cube ter wereld", - "icon": "🟧", - "slug": "rubiks-cube-small" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/F8nrF0lQiW4", - "title": "Grootste Rubiks cube ter wereld", - "icon": "🟧", - "slug": "rubiks-cube-large" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/EiYOUcuOxic&themeRefresh=1", - "title": "U L T I M A T E Nintendo Switch Gaming Set Up by Alex Girbinger. (Anton πŸ™ŒπŸΌ)", - "icon": "πŸ•ΉοΈ", - "slug": "nintendo-switch" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/cOXlYUoF350", - "title": "BattleKart: Beyond Reality! (Anton πŸ™ŒπŸΌ)", - "icon": "πŸ•ΉοΈ", - "slug": "battlekart" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/ueNN2Qb99Qo", - "title": " 'Transformer' heels by local label Gena (Anton πŸ™ŒπŸΌ)", - "icon": "πŸ‘ ", - "slug": "transformer-heels" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/nVNIoQUcFI4", - "title": "SpaceX catches Starship rocket booster back at the launch pad", - "icon": "πŸš€ ", - "slug": "spacex-starship" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/9U9SJgK8UsQ", - "title": "Zelfrijdende taxi en bus van Tesla", - "icon": "πŸ€–", - "slug": "tesla-taxi" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/opmxecU1VQ0", - "title": "Comma.ai", - "icon": "πŸ€–", - "slug": "comma-ai" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/pPLWIL64sgQ", - "title": "Mark Zuckerberg Reveals Orion Prototype AR Glasses", - "icon": "πŸ€“", - "slug": "mark-zuckerberg" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/t44EShMC5SQ", - "title": "The highest spot on earth?", - "icon": "🌎", - "slug": "highest-spot" - } - ] -} diff --git a/docs/data/slides-2024-12.json b/docs/data/slides-2024-12.json deleted file mode 100644 index b3c944c..0000000 --- a/docs/data/slides-2024-12.json +++ /dev/null @@ -1,155 +0,0 @@ -{ - "slides": [ - { - "type": "heading", - "content": "😎 😩 πŸŽ„ December", - "slug": "start" - }, - { - "type": "paragraph", - "content": "![Darth Vader Christmas](/images/darth-vader-xmas.jpeg) ", - "title": "Luke, I am Father Christmas", - "icon": "πŸŽ„", - "slug": "star-wars" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/e8fkkyB65CY", - "title": "The face bird feeder", - "icon": "πŸ¦β€β¬›", - "slug": "bird-feeder" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/Hq-6wUWffkA", - "title": "Sir Nils Olav promoted to Brigadier by Norwegian King's Guard (Jeroen πŸ™ŒπŸΌ)", - "icon": "🐧", - "slug": "sil-nils-olav" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/M1pUPlEBw3I", - "title": "Japan's lazy man", - "icon": "πŸ‡―πŸ‡΅", - "slug": "japan-lazy" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/MLURvUibbZs", - "title": "Jellyfish lamp", - "icon": "πŸ’‘", - "slug": "jellyfish-lamp" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/Gnw3efuvj2U", - "title": "Solving Rubiks Cube together", - "icon": "πŸ‡¨πŸ‡³" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/shorts/HKOp5fZB9So", - "title": "Flying with Jet Suit", - "icon": "πŸ¦ΈπŸ»β€β™‚οΈ" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/vDD1qTWF7eM", - "title": "Ice is back with a brand new invention!", - "icon": "πŸ₯Ά" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/5NVCo9WYCSE", - "title": "De-constructed Mercedes F1 car", - "icon": "🏎️" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/h2S802364do", - "title": "Chinese ice cream machine", - "icon": "🍦" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/N04tSVPw9nU", - "title": "Why is the Hulk green", - "icon": "🟩", - "slug": "hulk-green" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/WlUFoZstcWg", - "title": "Figure Status Update - BMW Use Case", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": " https://www.youtube.com/embed/S9L2WGf1KrM", - "title": "Introducing NVIDIA Jetson Orinβ„’ Nano Super: The World/’s Most Affordable Generative AI Computer", - "icon": "πŸ€–" - }, - { - "type": "youtube", - "url": " https://www.youtube.com/embed/dAvh3BcQ89o", - "title": "AI-Generated 'Daisy' Gives Scam Callers the Runaround", - "icon": "πŸ€–", - "slug": "daisy" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/fIUm3V25SqU", - "title": "Polite Japanese kids doing interview", - "icon": "πŸ‡―πŸ‡΅", - "slug": "japanese-kids" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/fiUDWMX0jsw", - "title": "Singing Christmas Tree rehearsal", - "icon": "πŸŽ„", - "slug": "singing-tree" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/CurDRVP0vgU", - "title": "Nigel Richards scrabble king", - "icon": "πŸ•ΉοΈ", - "slug": "nigel-richards" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/QoNNXQJmv4Y", - "title": "Chinese traditional board-shoe racing highlights collaborative spirit", - "icon": "πŸƒπŸ»", - "slug": "board-shoe-racing" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/uR_z16n3v1g", - "title": "the worlds first time-free zone", - "icon": "⏰" - }, - { - "type": "paragraph", - "title": "Prijsvraag", - "content": " Leg je telefoons en laptops even weg! \n\n**Wat is het huidige wereldrecord voor het aantal sprongen met een springtouw in 30 seconden?** \n\nSchrijf jouw antwoord op een Post-it wacht heel even en leg de post-it voor je!", - "icon": "❓", - "slug": "prijsvraag" - }, - { - "type": "youtube", - "url": "https://www.youtube.com/embed/35Fn5KnXQLU", - "title": "Record in jump rope contest", - "icon": "πŸ†", - "slug": "jump-rope" - }, - { - "type": "paragraph", - "content": "![Happy 2025](/images/happy-2025.jpeg) ", - "title": "Tot volgend jaar", - "icon": "🍾", - "slug": "happy-2025" - } - ] -} diff --git a/docs/file.svg b/docs/file.svg deleted file mode 100644 index 004145c..0000000 --- a/docs/file.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/docs/globe.svg b/docs/globe.svg deleted file mode 100644 index 567f17b..0000000 --- a/docs/globe.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/docs/images/darth-vader-xmas.jpeg b/docs/images/darth-vader-xmas.jpeg deleted file mode 100644 index 5261234c574cf48f45c7f9104fc1d227a77b7a08..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 128747 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ⅅ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 Nyb$cdhUbgJ|Jg3MJO=;( diff --git a/docs/images/happy-2025.jpeg b/docs/images/happy-2025.jpeg deleted file mode 100644 index 4211d3add5a51b92d1ad052265c14dedd1004ca3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 44654 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 diff --git a/docs/index.html b/docs/index.html deleted file mode 100644 index d61081a..0000000 --- a/docs/index.html +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - - Cool Uncool - - - - -
- - - diff --git a/docs/next.svg b/docs/next.svg deleted file mode 100644 index 5174b28..0000000 --- a/docs/next.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/docs/static/css/main.2a9063d3.css b/docs/static/css/main.2a9063d3.css deleted file mode 100644 index a6586dd..0000000 --- a/docs/static/css/main.2a9063d3.css +++ /dev/null @@ -1,208 +0,0 @@ -#root, -body, -html { - display: flex; - flex-direction: column; - height: 100%; - margin: 0; - overflow: hidden; - padding: 0; - width: 100%; -} -body { - align-items: center; - background-color: #f4f4f9; - color: #333; - display: flex; - font-family: Arial, sans-serif; - justify-content: center; - transition: - background-color 0.3s ease, - color 0.3s ease; -} -.slide { - -webkit-padding-before: 1rem; - margin: auto; - padding-block-start: 1rem; - text-align: center; - width: 100%; -} -.slide p { - -webkit-padding-after: 1rem; - font-size: 1rem; - line-height: 1.5; - margin: auto; - padding-block-end: 1rem; - width: 70%; -} -.slide h2 { - font-size: 1.5rem; - margin-bottom: 0.5rem; -} -.slide ul { - list-style: none; - margin-left: 1.5rem; -} -.slide a { - color: #007bff; - text-decoration: none; -} -.slide a:hover { - text-decoration: underline; -} -.light-mode { - background-color: #f4f4f9; - color: #333; -} -.dark-mode { - background-color: #121212; - color: #fff; -} -.video-container { - aspect-ratio: 16/9; - margin: 0 auto; - max-width: 1400px; - position: relative; - width: 70%; -} -.video-container iframe { - border: none; - height: 100%; - left: 0; - position: relative; - top: 0; - width: 100%; -} -h2 { - font-size: 1.5rem; - margin-bottom: 1 rem; - text-align: center; -} -h1, -p { - margin: 0; - overflow-wrap: break-word; - padding: 0 0 2rem; -} -.slide-deck { - flex-direction: column; - height: 100vh; - justify-content: center; - position: relative; -} -.slide-counter, -.slide-deck { - align-items: center; - box-sizing: border-box; - display: flex; - transition: - background-color 0.3s ease, - color 0.3s ease; - width: 100%; -} -.slide-counter { - background-color: #000c; - bottom: 0; - color: #fff; - font-size: 14px; - justify-content: space-between; - left: 0; - padding: 10px 0; - position: fixed; - text-align: center; -} -.counter-text { - flex: 1 1; - font-weight: 400; - text-align: center; -} -.light-mode .slide-counter { - background-color: #fffc; - color: #333; -} -.slide-icon { - -webkit-margin-after: 1rem; - -webkit-padding-end: 1rem; - font-size: 2rem; - margin-block-end: 1rem; - padding-inline-end: 1rem; - text-align: center; -} -.slide p img { - max-height: 80vh; - object-fit: contain; - width: auto; -} -.dark-mode-toggle { - align-items: center; - background-color: #fff; - background-color: var(--toggle-bg, #fff); - border: 2px solid #ccc; - border-radius: 20px; - color: #333; - color: var(--toggle-color, #333); - cursor: pointer; - display: flex; - gap: 10px; - justify-content: center; - padding: 10px 20px; - position: fixed; - right: 10px; - top: 10px; - transition: - background-color 0.3s, - color 0.3s, - transform 0.2s; -} -.dark-mode-toggle:hover { - transform: scale(1.05); -} -.dark-mode-toggle .icon { - transition: - transform 0.3s ease, - color 0.3s ease; -} -.dark-mode-toggle .label { - font-size: 14px; - font-weight: 700; -} -.dark-mode-toggle.dark { - --toggle-bg: #333; - --toggle-color: #fff; -} -.dark-mode-toggle.light { - --toggle-bg: #fff; - --toggle-color: #333; -} -.month-selector { - align-items: center; - display: flex; - gap: 10px; - margin-left: auto; -} -.month-dropdown { - -webkit-margin-start: 32px; - background-color: #fff; - background-color: var(--toggle-bg, #fff); - border: 2px solid #ccc; - border-radius: 10px; - color: #333; - color: var(--toggle-color, #333); - cursor: pointer; - font-size: 12px; - margin-inline-start: 32px; - padding: 5px 10px; - transition: - background-color 0.3s, - color 0.3s; -} -.month-dropdown:focus { - border-color: #666; - outline: none; -} -.month-label { - display: none; - font-size: 14px; - font-weight: 700; -} -/*# sourceMappingURL=main.2a9063d3.css.map*/ diff --git a/docs/static/css/main.ec9d09e5.css b/docs/static/css/main.ec9d09e5.css deleted file mode 100644 index c2a51d4..0000000 --- a/docs/static/css/main.ec9d09e5.css +++ /dev/null @@ -1,2 +0,0 @@ -#root,body,html{display:flex;flex-direction:column;height:100%;margin:0;overflow:hidden;padding:0;width:100%}body{align-items:center;background-color:#f4f4f9;color:#333;display:flex;font-family:Arial,sans-serif;justify-content:center;transition:background-color .3s ease,color .3s ease}.slide{margin:auto;padding-top:1rem;text-align:center;width:100%}.slide p{font-size:1rem;line-height:1.5;margin:auto;padding-bottom:1rem;width:70%}.slide h2{font-size:1.5rem;margin-bottom:.5rem}.slide ul{list-style:none;margin-left:1.5rem}.slide a{color:#007bff;text-decoration:none}.slide a:hover{text-decoration:underline}.light-mode{background-color:#f4f4f9;color:#333}.dark-mode{background-color:#121212;color:#fff}.video-container{aspect-ratio:16/9;margin:0 auto;max-width:1400px;position:relative;width:70%}.video-container iframe{border:none;height:100%;width:100%}h2{font-size:1.5rem;margin-bottom:1rem;text-align:center}h1,p{word-wrap:break-word;margin:0;padding:0 0 2rem}.button,.control-button,.dark-mode-toggle,.footer-button{align-items:center;background-color:#fff;background-color:var(--toggle-bg,#fff);border:2px solid #ccc;border-radius:10px;color:#333;color:var(--toggle-color,#333);cursor:pointer;display:flex;font-weight:700;justify-content:center;margin:0 10px;padding:10px 20px;transition:background-color .3s,color .3s,transform .2s}.button:hover,.control-button:hover,.dark-mode-toggle:hover,.footer-button:hover,.month-selector:hover{transform:scale(1.05)}.control-container,.footer-controls{align-items:center;display:flex;gap:20px;justify-content:center}.slide-deck{flex-direction:column;height:100vh;justify-content:center;position:relative}.slide-counter,.slide-deck{align-items:center;box-sizing:border-box;display:flex;transition:background-color .3s ease,color .3s ease;width:100%}.slide-counter{background-color:#000c;bottom:0;color:#fff;font-size:14px;justify-content:space-between;left:0;padding:10px 0;position:fixed;text-align:center}.counter-text{flex:1 1;font-weight:400;text-align:center}.light-mode .slide-counter{background-color:#fffc;color:#333}.slide-icon{font-size:2rem;margin-bottom:1rem;padding-right:1rem;text-align:center}.slide p img{max-height:80vh;object-fit:contain;width:auto}.dark-mode-toggle{position:fixed;right:10px;top:10px}.dark-mode-toggle.dark{--toggle-bg:#333;--toggle-color:#fff}.dark-mode-toggle.light{--toggle-bg:#fff;--toggle-color:#333}.footer-controls{-webkit-padding-before:10px;-webkit-padding-after:10px;-webkit-padding-start:20px;-webkit-padding-end:10px;align-items:center;display:flex;gap:10px;justify-content:center;padding-block-end:10px;padding-block-start:10px;padding-inline-end:10px;padding-inline-start:20px}.month-selector{align-items:center;display:flex;margin:0}.month-label{display:none}.month-dropdown{background-color:#fff;background-color:var(--toggle-bg,#fff);border:2px solid #ccc;border-radius:10px;color:#333;color:var(--toggle-color,#333);cursor:pointer;font-size:13px;padding:10px 20px;transition:background-color .3s,color .3s}.month-dropdown:focus{border-color:#666;outline:none} -/*# sourceMappingURL=main.ec9d09e5.css.map*/ \ No newline at end of file diff --git a/docs/static/css/main.ec9d09e5.css.map b/docs/static/css/main.ec9d09e5.css.map deleted file mode 100644 index 0011ffe..0000000 --- a/docs/static/css/main.ec9d09e5.css.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"static/css/main.ec9d09e5.css","mappings":"AACA,gBAQE,YAAa,CACb,qBAAsB,CAJtB,WAAY,CAFZ,QAAS,CAIT,eAAgB,CAHhB,SAAU,CAEV,UAIF,CAGA,KAIE,kBAAmB,CACnB,wBAAyB,CACzB,UAAW,CAJX,YAAa,CADb,4BAA8B,CAE9B,sBAAuB,CAIvB,mDACF,CAGA,OACE,WAAY,CAGZ,gBAAiB,CADjB,iBAAkB,CADlB,UAGF,CAEA,SACE,cAAe,CACf,eAAgB,CAEhB,WAAY,CACZ,mBAAoB,CAFpB,SAGF,CAEA,UACE,gBAAiB,CACjB,mBACF,CAEA,UAEE,eAAgB,CADhB,kBAEF,CAEA,SACE,aAAc,CACd,oBACF,CAEA,eACE,yBACF,CAGA,YACE,wBAAyB,CACzB,UACF,CAEA,WACE,wBAAyB,CACzB,UACF,CAGA,iBAIE,iBAAoB,CADpB,aAAc,CADd,gBAAiB,CAGjB,iBAAkB,CAJlB,SAKF,CAEA,wBAGE,WAAY,CADZ,WAAY,CADZ,UAGF,CAGA,GAEE,gBAAiB,CADjB,kBAAmB,CAEnB,iBACF,CAEA,KAIE,oBAAqB,CAFrB,QAAS,CACT,gBAEF,CAGA,yDAWE,kBAAmB,CAPnB,qBAAwC,CAAxC,sCAAwC,CAExC,qBAAsB,CACtB,kBAAmB,CAFnB,UAAgC,CAAhC,8BAAgC,CAShC,cAAe,CAJf,YAAa,CAGb,eAAiB,CADjB,sBAAuB,CAHvB,aAAc,CADd,iBAAkB,CAOlB,uDACF,CAEA,uGAIE,qBACF,CAGA,oCAIE,kBAAmB,CAFnB,YAAa,CAGb,QAAS,CAFT,sBAGF,CAGA,YAKE,qBAAsB,CAFtB,YAAa,CAGb,sBAAuB,CALvB,iBASF,CAGA,2BANE,kBAAmB,CACnB,qBAAsB,CAJtB,YAAa,CAKb,mDAAuD,CAPvD,UA0BF,CAfA,eASE,sBAAoC,CAJpC,QAAS,CAKT,UAAY,CAEZ,cAAe,CARf,6BAA8B,CAE9B,MAAO,CAKP,cAAe,CATf,cAAe,CAMf,iBAOF,CAEA,cACE,QAAO,CAEP,eAAmB,CADnB,iBAEF,CAEA,2BACE,sBAA0C,CAC1C,UACF,CAGA,YAEE,cAAe,CACf,kBAAmB,CACnB,kBAAmB,CAHnB,iBAIF,CAEA,aACE,eAAgB,CAEhB,kBAAmB,CADnB,UAEF,CAGA,kBACE,cAAe,CAEf,UAAW,CADX,QAEF,CAEA,uBACE,gBAAiB,CACjB,mBACF,CAEA,wBACE,gBAAiB,CACjB,mBACF,CAGA,iBAKE,2BAAyB,CACzB,0BAAuB,CACvB,0BAA0B,CAC1B,wBAAwB,CALxB,kBAAmB,CAFnB,YAAa,CAGb,QAAS,CAFT,sBAAuB,CAIvB,sBAAuB,CADvB,wBAAyB,CAGzB,uBAAwB,CADxB,yBAEF,CAGA,gBAGE,kBAAmB,CADnB,YAAa,CADb,QAGF,CAEA,aACE,YACF,CAEA,gBAKE,qBAAwC,CAAxC,sCAAwC,CAHxC,qBAAsB,CACtB,kBAAmB,CAGnB,UAAgC,CAAhC,8BAAgC,CAChC,cAAe,CAHf,cAAe,CAHf,iBAAkB,CAOlB,yCACF,CAEA,sBAEE,iBAAkB,CADlB,YAEF","sources":["styles/index.css"],"sourcesContent":["/* ========== Algemene Reset ========== */\nhtml,\nbody,\n#root {\n margin: 0;\n padding: 0;\n height: 100%;\n width: 100%;\n overflow: hidden;\n display: flex;\n flex-direction: column;\n}\n\n/* ========== Algemene Body Stijlen ========== */\nbody {\n font-family: Arial, sans-serif;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: #f4f4f9;\n color: #333;\n transition: background-color 0.3s ease, color 0.3s ease;\n}\n\n/* ========== Slide Structuur ========== */\n.slide {\n margin: auto;\n width: 100%;\n text-align: center;\n padding-top: 1rem;\n}\n\n.slide p {\n font-size: 1rem;\n line-height: 1.5;\n width: 70%;\n margin: auto;\n padding-bottom: 1rem;\n}\n\n.slide h2 {\n font-size: 1.5rem;\n margin-bottom: 0.5rem;\n}\n\n.slide ul {\n margin-left: 1.5rem;\n list-style: none;\n}\n\n.slide a {\n color: #007bff;\n text-decoration: none;\n}\n\n.slide a:hover {\n text-decoration: underline;\n}\n\n/* ========== Modus Stijlen (Dark/Light Mode) ========== */\n.light-mode {\n background-color: #f4f4f9;\n color: #333;\n}\n\n.dark-mode {\n background-color: #121212;\n color: #fff;\n}\n\n/* ========== Video Container ========== */\n.video-container {\n width: 70%;\n max-width: 1400px;\n margin: 0 auto;\n aspect-ratio: 16 / 9;\n position: relative;\n}\n\n.video-container iframe {\n width: 100%;\n height: 100%;\n border: none;\n}\n\n/* ========== Typografie ========== */\nh2 {\n margin-bottom: 1rem;\n font-size: 1.5rem;\n text-align: center;\n}\n\np,\nh1 {\n margin: 0;\n padding: 0 0 2rem 0;\n word-wrap: break-word;\n}\n\n/* ========== Herbruikbare Knoppen ========== */\n.button,\n.control-button,\n.dark-mode-toggle,\n.footer-button {\n background-color: var(--toggle-bg, #fff);\n color: var(--toggle-color, #333);\n border: 2px solid #ccc;\n border-radius: 10px;\n padding: 10px 20px;\n margin: 0 10px;\n display: flex;\n align-items: center;\n justify-content: center;\n font-weight: bold;\n cursor: pointer;\n transition: background-color 0.3s, color 0.3s, transform 0.2s;\n}\n\n.button:hover,\n.control-button:hover,\n.dark-mode-toggle:hover,\n.footer-button:hover, .month-selector:hover {\n transform: scale(1.05);\n}\n\n/* ========== Flex Containers ========== */\n.control-container,\n.footer-controls {\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 20px;\n}\n\n/* ========== Slide Deck Structuur ========== */\n.slide-deck {\n position: relative;\n width: 100%;\n height: 100vh;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n box-sizing: border-box;\n transition: background-color 0.3s ease, color 0.3s ease;\n}\n\n/* ========== Slide Teller in Footer ========== */\n.slide-counter {\n display: flex;\n position: fixed;\n align-items: center;\n justify-content: space-between;\n bottom: 0;\n left: 0;\n width: 100%;\n text-align: center;\n background-color: rgba(0, 0, 0, 0.8);\n color: white;\n padding: 10px 0;\n font-size: 14px;\n box-sizing: border-box;\n transition: background-color 0.3s ease, color 0.3s ease;\n}\n\n.counter-text {\n flex: 1;\n text-align: center;\n font-weight: normal;\n}\n\n.light-mode .slide-counter {\n background-color: rgba(255, 255, 255, 0.8);\n color: #333;\n}\n\n/* ========== Slide Icon Styling ========== */\n.slide-icon {\n text-align: center;\n font-size: 2rem;\n margin-bottom: 1rem;\n padding-right: 1rem;\n}\n\n.slide p img {\n max-height: 80vh;\n width: auto;\n object-fit: contain;\n}\n\n/* ========== Dark Mode Toggle Styling ========== */\n.dark-mode-toggle {\n position: fixed;\n top: 10px;\n right: 10px;\n}\n\n.dark-mode-toggle.dark {\n --toggle-bg: #333;\n --toggle-color: #fff;\n}\n\n.dark-mode-toggle.light {\n --toggle-bg: #fff;\n --toggle-color: #333;\n}\n\n/* ========== Footer Controls (Random Slide + Month Selector) ========== */\n.footer-controls {\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 10px;\n padding-block-start: 10px;\n padding-block-end: 10px;\n padding-inline-start: 20px;\n padding-inline-end: 10px;\n}\n\n/* ========== Month Selector Dropdown ========== */\n.month-selector {\n margin: 0;\n display: flex;\n align-items: center;\n}\n\n.month-label {\n display: none;\n}\n\n.month-dropdown {\n padding: 10px 20px;\n border: 2px solid #ccc;\n border-radius: 10px;\n font-size: 13px;\n background-color: var(--toggle-bg, #fff);\n color: var(--toggle-color, #333);\n cursor: pointer;\n transition: background-color 0.3s, color 0.3s;\n}\n\n.month-dropdown:focus {\n outline: none;\n border-color: #666;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/docs/static/js/main.d6e15f43.js b/docs/static/js/main.d6e15f43.js deleted file mode 100644 index 0b11541..0000000 --- a/docs/static/js/main.d6e15f43.js +++ /dev/null @@ -1,19657 +0,0 @@ -/*! For license information please see main.362f001c.js.LICENSE.txt */ -(() => { - var e = { - 28: (e, t) => { - "use strict"; - const n = /^[\u0021-\u003A\u003C\u003E-\u007E]+$/, - u = /^[\u0021-\u003A\u003C-\u007E]*$/, - r = - /^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i, - o = /^[\u0020-\u003A\u003D-\u007E]*$/, - l = Object.prototype.toString, - a = (() => { - const e = function () {}; - return (e.prototype = Object.create(null)), e; - })(); - function i(e, t, n) { - do { - const n = e.charCodeAt(t); - if (32 !== n && 9 !== n) return t; - } while (++t < n); - return n; - } - function s(e, t, n) { - for (; t > n; ) { - const n = e.charCodeAt(--t); - if (32 !== n && 9 !== n) return t + 1; - } - return n; - } - function c(e) { - if (-1 === e.indexOf("%")) return e; - try { - return decodeURIComponent(e); - } catch (t) { - return e; - } - } - }, - 341: (e) => { - "use strict"; - var t = Object.prototype.hasOwnProperty, - n = Object.prototype.toString, - u = Object.defineProperty, - r = Object.getOwnPropertyDescriptor, - o = function (e) { - return "function" === typeof Array.isArray - ? Array.isArray(e) - : "[object Array]" === n.call(e); - }, - l = function (e) { - if (!e || "[object Object]" !== n.call(e)) return !1; - var u, - r = t.call(e, "constructor"), - o = - e.constructor && - e.constructor.prototype && - t.call(e.constructor.prototype, "isPrototypeOf"); - if (e.constructor && !r && !o) return !1; - for (u in e); - return "undefined" === typeof u || t.call(e, u); - }, - a = function (e, t) { - u && "__proto__" === t.name - ? u(e, t.name, { - enumerable: !0, - configurable: !0, - value: t.newValue, - writable: !0, - }) - : (e[t.name] = t.newValue); - }, - i = function (e, n) { - if ("__proto__" === n) { - if (!t.call(e, n)) return; - if (r) return r(e, n).value; - } - return e[n]; - }; - e.exports = function e() { - var t, - n, - u, - r, - s, - c, - D = arguments[0], - f = 1, - d = arguments.length, - p = !1; - for ( - "boolean" === typeof D && - ((p = D), (D = arguments[1] || {}), (f = 2)), - (null == D || - ("object" !== typeof D && "function" !== typeof D)) && - (D = {}); - f < d; - ++f - ) - if (null != (t = arguments[f])) - for (n in t) - (u = i(D, n)), - D !== (r = i(t, n)) && - (p && r && (l(r) || (s = o(r))) - ? (s - ? ((s = !1), (c = u && o(u) ? u : [])) - : (c = u && l(u) ? u : {}), - a(D, { name: n, newValue: e(p, c, r) })) - : "undefined" !== typeof r && - a(D, { name: n, newValue: r })); - return D; - }; - }, - 846: (e) => { - var t = /\/\*[^*]*\*+([^/*][^*]*\*+)*\//g, - n = /\n/g, - u = /^\s*/, - r = /^(\*?[-#/*\\\w]+(\[[0-9a-z_-]+\])?)\s*/, - o = /^:\s*/, - l = /^((?:'(?:\\'|.)*?'|"(?:\\"|.)*?"|\([^)]*?\)|[^};])+)/, - a = /^[;\s]*/, - i = /^\s+|\s+$/g, - s = ""; - function c(e) { - return e ? e.replace(i, s) : s; - } - e.exports = function (e, i) { - if ("string" !== typeof e) - throw new TypeError("First argument must be a string"); - if (!e) return []; - i = i || {}; - var D = 1, - f = 1; - function d(e) { - var t = e.match(n); - t && (D += t.length); - var u = e.lastIndexOf("\n"); - f = ~u ? e.length - u : f + e.length; - } - function p() { - var e = { line: D, column: f }; - return function (t) { - return (t.position = new h(e)), C(), t; - }; - } - function h(e) { - (this.start = e), - (this.end = { line: D, column: f }), - (this.source = i.source); - } - h.prototype.content = e; - var m = []; - function F(t) { - var n = new Error(i.source + ":" + D + ":" + f + ": " + t); - if ( - ((n.reason = t), - (n.filename = i.source), - (n.line = D), - (n.column = f), - (n.source = e), - !i.silent) - ) - throw n; - m.push(n); - } - function g(t) { - var n = t.exec(e); - if (n) { - var u = n[0]; - return d(u), (e = e.slice(u.length)), n; - } - } - function C() { - g(u); - } - function E(e) { - var t; - for (e = e || []; (t = y()); ) !1 !== t && e.push(t); - return e; - } - function y() { - var t = p(); - if ("/" == e.charAt(0) && "*" == e.charAt(1)) { - for ( - var n = 2; - s != e.charAt(n) && - ("*" != e.charAt(n) || "/" != e.charAt(n + 1)); - - ) - ++n; - if (((n += 2), s === e.charAt(n - 1))) - return F("End of comment missing"); - var u = e.slice(2, n - 2); - return ( - (f += 2), - d(u), - (e = e.slice(n)), - (f += 2), - t({ type: "comment", comment: u }) - ); - } - } - function v() { - var e = p(), - n = g(r); - if (n) { - if ((y(), !g(o))) return F("property missing ':'"); - var u = g(l), - i = e({ - type: "declaration", - property: c(n[0].replace(t, s)), - value: u ? c(u[0].replace(t, s)) : s, - }); - return g(a), i; - } - } - return ( - C(), - (function () { - var e, - t = []; - for (E(t); (e = v()); ) !1 !== e && (t.push(e), E(t)); - return t; - })() - ); - }; - }, - 92: (e, t, n) => { - "use strict"; - var u = n(395), - r = n(225); - function o(e) { - for ( - var t = - "https://reactjs.org/docs/error-decoder.html?invariant=" + e, - n = 1; - n < arguments.length; - n++ - ) - t += "&args[]=" + encodeURIComponent(arguments[n]); - return ( - "Minified React error #" + - e + - "; visit " + - t + - " for the full message or use the non-minified dev environment for full errors and additional helpful warnings." - ); - } - var l = new Set(), - a = {}; - function i(e, t) { - s(e, t), s(e + "Capture", t); - } - function s(e, t) { - for (a[e] = t, e = 0; e < t.length; e++) l.add(t[e]); - } - var c = !( - "undefined" === typeof window || - "undefined" === typeof window.document || - "undefined" === typeof window.document.createElement - ), - D = Object.prototype.hasOwnProperty, - f = - /^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/, - d = {}, - p = {}; - function h(e, t, n, u, r, o, l) { - (this.acceptsBooleans = 2 === t || 3 === t || 4 === t), - (this.attributeName = u), - (this.attributeNamespace = r), - (this.mustUseProperty = n), - (this.propertyName = e), - (this.type = t), - (this.sanitizeURL = o), - (this.removeEmptyString = l); - } - var m = {}; - "children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style" - .split(" ") - .forEach(function (e) { - m[e] = new h(e, 0, !1, e, null, !1, !1); - }), - [ - ["acceptCharset", "accept-charset"], - ["className", "class"], - ["htmlFor", "for"], - ["httpEquiv", "http-equiv"], - ].forEach(function (e) { - var t = e[0]; - m[t] = new h(t, 1, !1, e[1], null, !1, !1); - }), - ["contentEditable", "draggable", "spellCheck", "value"].forEach( - function (e) { - m[e] = new h(e, 2, !1, e.toLowerCase(), null, !1, !1); - }, - ), - [ - "autoReverse", - "externalResourcesRequired", - "focusable", - "preserveAlpha", - ].forEach(function (e) { - m[e] = new h(e, 2, !1, e, null, !1, !1); - }), - "allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope" - .split(" ") - .forEach(function (e) { - m[e] = new h(e, 3, !1, e.toLowerCase(), null, !1, !1); - }), - ["checked", "multiple", "muted", "selected"].forEach(function (e) { - m[e] = new h(e, 3, !0, e, null, !1, !1); - }), - ["capture", "download"].forEach(function (e) { - m[e] = new h(e, 4, !1, e, null, !1, !1); - }), - ["cols", "rows", "size", "span"].forEach(function (e) { - m[e] = new h(e, 6, !1, e, null, !1, !1); - }), - ["rowSpan", "start"].forEach(function (e) { - m[e] = new h(e, 5, !1, e.toLowerCase(), null, !1, !1); - }); - var F = /[\-:]([a-z])/g; - function g(e) { - return e[1].toUpperCase(); - } - function C(e, t, n, u) { - var r = m.hasOwnProperty(t) ? m[t] : null; - (null !== r - ? 0 !== r.type - : u || - !(2 < t.length) || - ("o" !== t[0] && "O" !== t[0]) || - ("n" !== t[1] && "N" !== t[1])) && - ((function (e, t, n, u) { - if ( - null === t || - "undefined" === typeof t || - (function (e, t, n, u) { - if (null !== n && 0 === n.type) return !1; - switch (typeof t) { - case "function": - case "symbol": - return !0; - case "boolean": - return ( - !u && - (null !== n - ? !n.acceptsBooleans - : "data-" !== (e = e.toLowerCase().slice(0, 5)) && - "aria-" !== e) - ); - default: - return !1; - } - })(e, t, n, u) - ) - return !0; - if (u) return !1; - if (null !== n) - switch (n.type) { - case 3: - return !t; - case 4: - return !1 === t; - case 5: - return isNaN(t); - case 6: - return isNaN(t) || 1 > t; - } - return !1; - })(t, n, r, u) && (n = null), - u || null === r - ? (function (e) { - return ( - !!D.call(p, e) || - (!D.call(d, e) && - (f.test(e) ? (p[e] = !0) : ((d[e] = !0), !1))) - ); - })(t) && - (null === n ? e.removeAttribute(t) : e.setAttribute(t, "" + n)) - : r.mustUseProperty - ? (e[r.propertyName] = null === n ? 3 !== r.type && "" : n) - : ((t = r.attributeName), - (u = r.attributeNamespace), - null === n - ? e.removeAttribute(t) - : ((n = - 3 === (r = r.type) || (4 === r && !0 === n) - ? "" - : "" + n), - u ? e.setAttributeNS(u, t, n) : e.setAttribute(t, n)))); - } - "accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height" - .split(" ") - .forEach(function (e) { - var t = e.replace(F, g); - m[t] = new h(t, 1, !1, e, null, !1, !1); - }), - "xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type" - .split(" ") - .forEach(function (e) { - var t = e.replace(F, g); - m[t] = new h(t, 1, !1, e, "http://www.w3.org/1999/xlink", !1, !1); - }), - ["xml:base", "xml:lang", "xml:space"].forEach(function (e) { - var t = e.replace(F, g); - m[t] = new h( - t, - 1, - !1, - e, - "http://www.w3.org/XML/1998/namespace", - !1, - !1, - ); - }), - ["tabIndex", "crossOrigin"].forEach(function (e) { - m[e] = new h(e, 1, !1, e.toLowerCase(), null, !1, !1); - }), - (m.xlinkHref = new h( - "xlinkHref", - 1, - !1, - "xlink:href", - "http://www.w3.org/1999/xlink", - !0, - !1, - )), - ["src", "href", "action", "formAction"].forEach(function (e) { - m[e] = new h(e, 1, !1, e.toLowerCase(), null, !0, !0); - }); - var E = u.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED, - y = Symbol.for("react.element"), - v = Symbol.for("react.portal"), - A = Symbol.for("react.fragment"), - b = Symbol.for("react.strict_mode"), - k = Symbol.for("react.profiler"), - B = Symbol.for("react.provider"), - w = Symbol.for("react.context"), - x = Symbol.for("react.forward_ref"), - S = Symbol.for("react.suspense"), - P = Symbol.for("react.suspense_list"), - T = Symbol.for("react.memo"), - _ = Symbol.for("react.lazy"); - Symbol.for("react.scope"), Symbol.for("react.debug_trace_mode"); - var N = Symbol.for("react.offscreen"); - Symbol.for("react.legacy_hidden"), - Symbol.for("react.cache"), - Symbol.for("react.tracing_marker"); - var L = Symbol.iterator; - function O(e) { - return null === e || "object" !== typeof e - ? null - : "function" === typeof (e = (L && e[L]) || e["@@iterator"]) - ? e - : null; - } - var R, - z = Object.assign; - function I(e) { - if (void 0 === R) - try { - throw Error(); - } catch (n) { - var t = n.stack.trim().match(/\n( *(at )?)/); - R = (t && t[1]) || ""; - } - return "\n" + R + e; - } - var M = !1; - function j(e, t) { - if (!e || M) return ""; - M = !0; - var n = Error.prepareStackTrace; - Error.prepareStackTrace = void 0; - try { - if (t) - if ( - ((t = function () { - throw Error(); - }), - Object.defineProperty(t.prototype, "props", { - set: function () { - throw Error(); - }, - }), - "object" === typeof Reflect && Reflect.construct) - ) { - try { - Reflect.construct(t, []); - } catch (s) { - var u = s; - } - Reflect.construct(e, [], t); - } else { - try { - t.call(); - } catch (s) { - u = s; - } - e.call(t.prototype); - } - else { - try { - throw Error(); - } catch (s) { - u = s; - } - e(); - } - } catch (s) { - if (s && u && "string" === typeof s.stack) { - for ( - var r = s.stack.split("\n"), - o = u.stack.split("\n"), - l = r.length - 1, - a = o.length - 1; - 1 <= l && 0 <= a && r[l] !== o[a]; - - ) - a--; - for (; 1 <= l && 0 <= a; l--, a--) - if (r[l] !== o[a]) { - if (1 !== l || 1 !== a) - do { - if ((l--, 0 > --a || r[l] !== o[a])) { - var i = "\n" + r[l].replace(" at new ", " at "); - return ( - e.displayName && - i.includes("") && - (i = i.replace("", e.displayName)), - i - ); - } - } while (1 <= l && 0 <= a); - break; - } - } - } finally { - (M = !1), (Error.prepareStackTrace = n); - } - return (e = e ? e.displayName || e.name : "") ? I(e) : ""; - } - function U(e) { - switch (e.tag) { - case 5: - return I(e.type); - case 16: - return I("Lazy"); - case 13: - return I("Suspense"); - case 19: - return I("SuspenseList"); - case 0: - case 2: - case 15: - return (e = j(e.type, !1)); - case 11: - return (e = j(e.type.render, !1)); - case 1: - return (e = j(e.type, !0)); - default: - return ""; - } - } - function H(e) { - if (null == e) return null; - if ("function" === typeof e) return e.displayName || e.name || null; - if ("string" === typeof e) return e; - switch (e) { - case A: - return "Fragment"; - case v: - return "Portal"; - case k: - return "Profiler"; - case b: - return "StrictMode"; - case S: - return "Suspense"; - case P: - return "SuspenseList"; - } - if ("object" === typeof e) - switch (e.$$typeof) { - case w: - return (e.displayName || "Context") + ".Consumer"; - case B: - return (e._context.displayName || "Context") + ".Provider"; - case x: - var t = e.render; - return ( - (e = e.displayName) || - (e = - "" !== (e = t.displayName || t.name || "") - ? "ForwardRef(" + e + ")" - : "ForwardRef"), - e - ); - case T: - return null !== (t = e.displayName || null) - ? t - : H(e.type) || "Memo"; - case _: - (t = e._payload), (e = e._init); - try { - return H(e(t)); - } catch (n) {} - } - return null; - } - function V(e) { - var t = e.type; - switch (e.tag) { - case 24: - return "Cache"; - case 9: - return (t.displayName || "Context") + ".Consumer"; - case 10: - return (t._context.displayName || "Context") + ".Provider"; - case 18: - return "DehydratedFragment"; - case 11: - return ( - (e = (e = t.render).displayName || e.name || ""), - t.displayName || - ("" !== e ? "ForwardRef(" + e + ")" : "ForwardRef") - ); - case 7: - return "Fragment"; - case 5: - return t; - case 4: - return "Portal"; - case 3: - return "Root"; - case 6: - return "Text"; - case 16: - return H(t); - case 8: - return t === b ? "StrictMode" : "Mode"; - case 22: - return "Offscreen"; - case 12: - return "Profiler"; - case 21: - return "Scope"; - case 13: - return "Suspense"; - case 19: - return "SuspenseList"; - case 25: - return "TracingMarker"; - case 1: - case 0: - case 17: - case 2: - case 14: - case 15: - if ("function" === typeof t) - return t.displayName || t.name || null; - if ("string" === typeof t) return t; - } - return null; - } - function W(e) { - switch (typeof e) { - case "boolean": - case "number": - case "string": - case "undefined": - case "object": - return e; - default: - return ""; - } - } - function $(e) { - var t = e.type; - return ( - (e = e.nodeName) && - "input" === e.toLowerCase() && - ("checkbox" === t || "radio" === t) - ); - } - function q(e) { - e._valueTracker || - (e._valueTracker = (function (e) { - var t = $(e) ? "checked" : "value", - n = Object.getOwnPropertyDescriptor(e.constructor.prototype, t), - u = "" + e[t]; - if ( - !e.hasOwnProperty(t) && - "undefined" !== typeof n && - "function" === typeof n.get && - "function" === typeof n.set - ) { - var r = n.get, - o = n.set; - return ( - Object.defineProperty(e, t, { - configurable: !0, - get: function () { - return r.call(this); - }, - set: function (e) { - (u = "" + e), o.call(this, e); - }, - }), - Object.defineProperty(e, t, { enumerable: n.enumerable }), - { - getValue: function () { - return u; - }, - setValue: function (e) { - u = "" + e; - }, - stopTracking: function () { - (e._valueTracker = null), delete e[t]; - }, - } - ); - } - })(e)); - } - function Q(e) { - if (!e) return !1; - var t = e._valueTracker; - if (!t) return !0; - var n = t.getValue(), - u = ""; - return ( - e && (u = $(e) ? (e.checked ? "true" : "false") : e.value), - (e = u) !== n && (t.setValue(e), !0) - ); - } - function Y(e) { - if ( - "undefined" === - typeof (e = - e || ("undefined" !== typeof document ? document : void 0)) - ) - return null; - try { - return e.activeElement || e.body; - } catch (t) { - return e.body; - } - } - function K(e, t) { - var n = t.checked; - return z({}, t, { - defaultChecked: void 0, - defaultValue: void 0, - value: void 0, - checked: null != n ? n : e._wrapperState.initialChecked, - }); - } - function X(e, t) { - var n = null == t.defaultValue ? "" : t.defaultValue, - u = null != t.checked ? t.checked : t.defaultChecked; - (n = W(null != t.value ? t.value : n)), - (e._wrapperState = { - initialChecked: u, - initialValue: n, - controlled: - "checkbox" === t.type || "radio" === t.type - ? null != t.checked - : null != t.value, - }); - } - function J(e, t) { - null != (t = t.checked) && C(e, "checked", t, !1); - } - function Z(e, t) { - J(e, t); - var n = W(t.value), - u = t.type; - if (null != n) - "number" === u - ? ((0 === n && "" === e.value) || e.value != n) && - (e.value = "" + n) - : e.value !== "" + n && (e.value = "" + n); - else if ("submit" === u || "reset" === u) - return void e.removeAttribute("value"); - t.hasOwnProperty("value") - ? ee(e, t.type, n) - : t.hasOwnProperty("defaultValue") && - ee(e, t.type, W(t.defaultValue)), - null == t.checked && - null != t.defaultChecked && - (e.defaultChecked = !!t.defaultChecked); - } - function G(e, t, n) { - if (t.hasOwnProperty("value") || t.hasOwnProperty("defaultValue")) { - var u = t.type; - if ( - !( - ("submit" !== u && "reset" !== u) || - (void 0 !== t.value && null !== t.value) - ) - ) - return; - (t = "" + e._wrapperState.initialValue), - n || t === e.value || (e.value = t), - (e.defaultValue = t); - } - "" !== (n = e.name) && (e.name = ""), - (e.defaultChecked = !!e._wrapperState.initialChecked), - "" !== n && (e.name = n); - } - function ee(e, t, n) { - ("number" === t && Y(e.ownerDocument) === e) || - (null == n - ? (e.defaultValue = "" + e._wrapperState.initialValue) - : e.defaultValue !== "" + n && (e.defaultValue = "" + n)); - } - var te = Array.isArray; - function ne(e, t, n, u) { - if (((e = e.options), t)) { - t = {}; - for (var r = 0; r < n.length; r++) t["$" + n[r]] = !0; - for (n = 0; n < e.length; n++) - (r = t.hasOwnProperty("$" + e[n].value)), - e[n].selected !== r && (e[n].selected = r), - r && u && (e[n].defaultSelected = !0); - } else { - for (n = "" + W(n), t = null, r = 0; r < e.length; r++) { - if (e[r].value === n) - return ( - (e[r].selected = !0), void (u && (e[r].defaultSelected = !0)) - ); - null !== t || e[r].disabled || (t = e[r]); - } - null !== t && (t.selected = !0); - } - } - function ue(e, t) { - if (null != t.dangerouslySetInnerHTML) throw Error(o(91)); - return z({}, t, { - value: void 0, - defaultValue: void 0, - children: "" + e._wrapperState.initialValue, - }); - } - function re(e, t) { - var n = t.value; - if (null == n) { - if (((n = t.children), (t = t.defaultValue), null != n)) { - if (null != t) throw Error(o(92)); - if (te(n)) { - if (1 < n.length) throw Error(o(93)); - n = n[0]; - } - t = n; - } - null == t && (t = ""), (n = t); - } - e._wrapperState = { initialValue: W(n) }; - } - function oe(e, t) { - var n = W(t.value), - u = W(t.defaultValue); - null != n && - ((n = "" + n) !== e.value && (e.value = n), - null == t.defaultValue && - e.defaultValue !== n && - (e.defaultValue = n)), - null != u && (e.defaultValue = "" + u); - } - function le(e) { - var t = e.textContent; - t === e._wrapperState.initialValue && - "" !== t && - null !== t && - (e.value = t); - } - function ae(e) { - switch (e) { - case "svg": - return "http://www.w3.org/2000/svg"; - case "math": - return "http://www.w3.org/1998/Math/MathML"; - default: - return "http://www.w3.org/1999/xhtml"; - } - } - function ie(e, t) { - return null == e || "http://www.w3.org/1999/xhtml" === e - ? ae(t) - : "http://www.w3.org/2000/svg" === e && "foreignObject" === t - ? "http://www.w3.org/1999/xhtml" - : e; - } - var se, - ce, - De = - ((ce = function (e, t) { - if ( - "http://www.w3.org/2000/svg" !== e.namespaceURI || - "innerHTML" in e - ) - e.innerHTML = t; - else { - for ( - (se = se || document.createElement("div")).innerHTML = - "" + t.valueOf().toString() + "", - t = se.firstChild; - e.firstChild; - - ) - e.removeChild(e.firstChild); - for (; t.firstChild; ) e.appendChild(t.firstChild); - } - }), - "undefined" !== typeof MSApp && MSApp.execUnsafeLocalFunction - ? function (e, t, n, u) { - MSApp.execUnsafeLocalFunction(function () { - return ce(e, t); - }); - } - : ce); - function fe(e, t) { - if (t) { - var n = e.firstChild; - if (n && n === e.lastChild && 3 === n.nodeType) - return void (n.nodeValue = t); - } - e.textContent = t; - } - var de = { - animationIterationCount: !0, - aspectRatio: !0, - borderImageOutset: !0, - borderImageSlice: !0, - borderImageWidth: !0, - boxFlex: !0, - boxFlexGroup: !0, - boxOrdinalGroup: !0, - columnCount: !0, - columns: !0, - flex: !0, - flexGrow: !0, - flexPositive: !0, - flexShrink: !0, - flexNegative: !0, - flexOrder: !0, - gridArea: !0, - gridRow: !0, - gridRowEnd: !0, - gridRowSpan: !0, - gridRowStart: !0, - gridColumn: !0, - gridColumnEnd: !0, - gridColumnSpan: !0, - gridColumnStart: !0, - fontWeight: !0, - lineClamp: !0, - lineHeight: !0, - opacity: !0, - order: !0, - orphans: !0, - tabSize: !0, - widows: !0, - zIndex: !0, - zoom: !0, - fillOpacity: !0, - floodOpacity: !0, - stopOpacity: !0, - strokeDasharray: !0, - strokeDashoffset: !0, - strokeMiterlimit: !0, - strokeOpacity: !0, - strokeWidth: !0, - }, - pe = ["Webkit", "ms", "Moz", "O"]; - function he(e, t, n) { - return null == t || "boolean" === typeof t || "" === t - ? "" - : n || - "number" !== typeof t || - 0 === t || - (de.hasOwnProperty(e) && de[e]) - ? ("" + t).trim() - : t + "px"; - } - function me(e, t) { - for (var n in ((e = e.style), t)) - if (t.hasOwnProperty(n)) { - var u = 0 === n.indexOf("--"), - r = he(n, t[n], u); - "float" === n && (n = "cssFloat"), - u ? e.setProperty(n, r) : (e[n] = r); - } - } - Object.keys(de).forEach(function (e) { - pe.forEach(function (t) { - (t = t + e.charAt(0).toUpperCase() + e.substring(1)), - (de[t] = de[e]); - }); - }); - var Fe = z( - { menuitem: !0 }, - { - area: !0, - base: !0, - br: !0, - col: !0, - embed: !0, - hr: !0, - img: !0, - input: !0, - keygen: !0, - link: !0, - meta: !0, - param: !0, - source: !0, - track: !0, - wbr: !0, - }, - ); - function ge(e, t) { - if (t) { - if ( - Fe[e] && - (null != t.children || null != t.dangerouslySetInnerHTML) - ) - throw Error(o(137, e)); - if (null != t.dangerouslySetInnerHTML) { - if (null != t.children) throw Error(o(60)); - if ( - "object" !== typeof t.dangerouslySetInnerHTML || - !("__html" in t.dangerouslySetInnerHTML) - ) - throw Error(o(61)); - } - if (null != t.style && "object" !== typeof t.style) - throw Error(o(62)); - } - } - function Ce(e, t) { - if (-1 === e.indexOf("-")) return "string" === typeof t.is; - switch (e) { - case "annotation-xml": - case "color-profile": - case "font-face": - case "font-face-src": - case "font-face-uri": - case "font-face-format": - case "font-face-name": - case "missing-glyph": - return !1; - default: - return !0; - } - } - var Ee = null; - function ye(e) { - return ( - (e = e.target || e.srcElement || window).correspondingUseElement && - (e = e.correspondingUseElement), - 3 === e.nodeType ? e.parentNode : e - ); - } - var ve = null, - Ae = null, - be = null; - function ke(e) { - if ((e = Cr(e))) { - if ("function" !== typeof ve) throw Error(o(280)); - var t = e.stateNode; - t && ((t = yr(t)), ve(e.stateNode, e.type, t)); - } - } - function Be(e) { - Ae ? (be ? be.push(e) : (be = [e])) : (Ae = e); - } - function we() { - if (Ae) { - var e = Ae, - t = be; - if (((be = Ae = null), ke(e), t)) - for (e = 0; e < t.length; e++) ke(t[e]); - } - } - function xe(e, t) { - return e(t); - } - function Se() {} - var Pe = !1; - function Te(e, t, n) { - if (Pe) return e(t, n); - Pe = !0; - try { - return xe(e, t, n); - } finally { - (Pe = !1), (null !== Ae || null !== be) && (Se(), we()); - } - } - function _e(e, t) { - var n = e.stateNode; - if (null === n) return null; - var u = yr(n); - if (null === u) return null; - n = u[t]; - e: switch (t) { - case "onClick": - case "onClickCapture": - case "onDoubleClick": - case "onDoubleClickCapture": - case "onMouseDown": - case "onMouseDownCapture": - case "onMouseMove": - case "onMouseMoveCapture": - case "onMouseUp": - case "onMouseUpCapture": - case "onMouseEnter": - (u = !u.disabled) || - (u = !( - "button" === (e = e.type) || - "input" === e || - "select" === e || - "textarea" === e - )), - (e = !u); - break e; - default: - e = !1; - } - if (e) return null; - if (n && "function" !== typeof n) throw Error(o(231, t, typeof n)); - return n; - } - var Ne = !1; - if (c) - try { - var Le = {}; - Object.defineProperty(Le, "passive", { - get: function () { - Ne = !0; - }, - }), - window.addEventListener("test", Le, Le), - window.removeEventListener("test", Le, Le); - } catch (ce) { - Ne = !1; - } - function Oe(e, t, n, u, r, o, l, a, i) { - var s = Array.prototype.slice.call(arguments, 3); - try { - t.apply(n, s); - } catch (c) { - this.onError(c); - } - } - var Re = !1, - ze = null, - Ie = !1, - Me = null, - je = { - onError: function (e) { - (Re = !0), (ze = e); - }, - }; - function Ue(e, t, n, u, r, o, l, a, i) { - (Re = !1), (ze = null), Oe.apply(je, arguments); - } - function He(e) { - var t = e, - n = e; - if (e.alternate) for (; t.return; ) t = t.return; - else { - e = t; - do { - 0 !== (4098 & (t = e).flags) && (n = t.return), (e = t.return); - } while (e); - } - return 3 === t.tag ? n : null; - } - function Ve(e) { - if (13 === e.tag) { - var t = e.memoizedState; - if ( - (null === t && - null !== (e = e.alternate) && - (t = e.memoizedState), - null !== t) - ) - return t.dehydrated; - } - return null; - } - function We(e) { - if (He(e) !== e) throw Error(o(188)); - } - function $e(e) { - return null !== - (e = (function (e) { - var t = e.alternate; - if (!t) { - if (null === (t = He(e))) throw Error(o(188)); - return t !== e ? null : e; - } - for (var n = e, u = t; ; ) { - var r = n.return; - if (null === r) break; - var l = r.alternate; - if (null === l) { - if (null !== (u = r.return)) { - n = u; - continue; - } - break; - } - if (r.child === l.child) { - for (l = r.child; l; ) { - if (l === n) return We(r), e; - if (l === u) return We(r), t; - l = l.sibling; - } - throw Error(o(188)); - } - if (n.return !== u.return) (n = r), (u = l); - else { - for (var a = !1, i = r.child; i; ) { - if (i === n) { - (a = !0), (n = r), (u = l); - break; - } - if (i === u) { - (a = !0), (u = r), (n = l); - break; - } - i = i.sibling; - } - if (!a) { - for (i = l.child; i; ) { - if (i === n) { - (a = !0), (n = l), (u = r); - break; - } - if (i === u) { - (a = !0), (u = l), (n = r); - break; - } - i = i.sibling; - } - if (!a) throw Error(o(189)); - } - } - if (n.alternate !== u) throw Error(o(190)); - } - if (3 !== n.tag) throw Error(o(188)); - return n.stateNode.current === n ? e : t; - })(e)) - ? qe(e) - : null; - } - function qe(e) { - if (5 === e.tag || 6 === e.tag) return e; - for (e = e.child; null !== e; ) { - var t = qe(e); - if (null !== t) return t; - e = e.sibling; - } - return null; - } - var Qe = r.unstable_scheduleCallback, - Ye = r.unstable_cancelCallback, - Ke = r.unstable_shouldYield, - Xe = r.unstable_requestPaint, - Je = r.unstable_now, - Ze = r.unstable_getCurrentPriorityLevel, - Ge = r.unstable_ImmediatePriority, - et = r.unstable_UserBlockingPriority, - tt = r.unstable_NormalPriority, - nt = r.unstable_LowPriority, - ut = r.unstable_IdlePriority, - rt = null, - ot = null; - var lt = Math.clz32 - ? Math.clz32 - : function (e) { - return (e >>>= 0), 0 === e ? 32 : (31 - ((at(e) / it) | 0)) | 0; - }, - at = Math.log, - it = Math.LN2; - var st = 64, - ct = 4194304; - function Dt(e) { - switch (e & -e) { - case 1: - return 1; - case 2: - return 2; - case 4: - return 4; - case 8: - return 8; - case 16: - return 16; - case 32: - return 32; - case 64: - case 128: - case 256: - case 512: - case 1024: - case 2048: - case 4096: - case 8192: - case 16384: - case 32768: - case 65536: - case 131072: - case 262144: - case 524288: - case 1048576: - case 2097152: - return 4194240 & e; - case 4194304: - case 8388608: - case 16777216: - case 33554432: - case 67108864: - return 130023424 & e; - case 134217728: - return 134217728; - case 268435456: - return 268435456; - case 536870912: - return 536870912; - case 1073741824: - return 1073741824; - default: - return e; - } - } - function ft(e, t) { - var n = e.pendingLanes; - if (0 === n) return 0; - var u = 0, - r = e.suspendedLanes, - o = e.pingedLanes, - l = 268435455 & n; - if (0 !== l) { - var a = l & ~r; - 0 !== a ? (u = Dt(a)) : 0 !== (o &= l) && (u = Dt(o)); - } else 0 !== (l = n & ~r) ? (u = Dt(l)) : 0 !== o && (u = Dt(o)); - if (0 === u) return 0; - if ( - 0 !== t && - t !== u && - 0 === (t & r) && - ((r = u & -u) >= (o = t & -t) || (16 === r && 0 !== (4194240 & o))) - ) - return t; - if ((0 !== (4 & u) && (u |= 16 & n), 0 !== (t = e.entangledLanes))) - for (e = e.entanglements, t &= u; 0 < t; ) - (r = 1 << (n = 31 - lt(t))), (u |= e[n]), (t &= ~r); - return u; - } - function dt(e, t) { - switch (e) { - case 1: - case 2: - case 4: - return t + 250; - case 8: - case 16: - case 32: - case 64: - case 128: - case 256: - case 512: - case 1024: - case 2048: - case 4096: - case 8192: - case 16384: - case 32768: - case 65536: - case 131072: - case 262144: - case 524288: - case 1048576: - case 2097152: - return t + 5e3; - default: - return -1; - } - } - function pt(e) { - return 0 !== (e = -1073741825 & e.pendingLanes) - ? e - : 1073741824 & e - ? 1073741824 - : 0; - } - function ht() { - var e = st; - return 0 === (4194240 & (st <<= 1)) && (st = 64), e; - } - function mt(e) { - for (var t = [], n = 0; 31 > n; n++) t.push(e); - return t; - } - function Ft(e, t, n) { - (e.pendingLanes |= t), - 536870912 !== t && ((e.suspendedLanes = 0), (e.pingedLanes = 0)), - ((e = e.eventTimes)[(t = 31 - lt(t))] = n); - } - function gt(e, t) { - var n = (e.entangledLanes |= t); - for (e = e.entanglements; n; ) { - var u = 31 - lt(n), - r = 1 << u; - (r & t) | (e[u] & t) && (e[u] |= t), (n &= ~r); - } - } - var Ct = 0; - function Et(e) { - return 1 < (e &= -e) - ? 4 < e - ? 0 !== (268435455 & e) - ? 16 - : 536870912 - : 4 - : 1; - } - var yt, - vt, - At, - bt, - kt, - Bt = !1, - wt = [], - xt = null, - St = null, - Pt = null, - Tt = new Map(), - _t = new Map(), - Nt = [], - Lt = - "mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput copy cut paste click change contextmenu reset submit".split( - " ", - ); - function Ot(e, t) { - switch (e) { - case "focusin": - case "focusout": - xt = null; - break; - case "dragenter": - case "dragleave": - St = null; - break; - case "mouseover": - case "mouseout": - Pt = null; - break; - case "pointerover": - case "pointerout": - Tt.delete(t.pointerId); - break; - case "gotpointercapture": - case "lostpointercapture": - _t.delete(t.pointerId); - } - } - function Rt(e, t, n, u, r, o) { - return null === e || e.nativeEvent !== o - ? ((e = { - blockedOn: t, - domEventName: n, - eventSystemFlags: u, - nativeEvent: o, - targetContainers: [r], - }), - null !== t && null !== (t = Cr(t)) && vt(t), - e) - : ((e.eventSystemFlags |= u), - (t = e.targetContainers), - null !== r && -1 === t.indexOf(r) && t.push(r), - e); - } - function zt(e) { - var t = gr(e.target); - if (null !== t) { - var n = He(t); - if (null !== n) - if (13 === (t = n.tag)) { - if (null !== (t = Ve(n))) - return ( - (e.blockedOn = t), - void kt(e.priority, function () { - At(n); - }) - ); - } else if ( - 3 === t && - n.stateNode.current.memoizedState.isDehydrated - ) - return void (e.blockedOn = - 3 === n.tag ? n.stateNode.containerInfo : null); - } - e.blockedOn = null; - } - function It(e) { - if (null !== e.blockedOn) return !1; - for (var t = e.targetContainers; 0 < t.length; ) { - var n = Kt(e.domEventName, e.eventSystemFlags, t[0], e.nativeEvent); - if (null !== n) - return null !== (t = Cr(n)) && vt(t), (e.blockedOn = n), !1; - var u = new (n = e.nativeEvent).constructor(n.type, n); - (Ee = u), n.target.dispatchEvent(u), (Ee = null), t.shift(); - } - return !0; - } - function Mt(e, t, n) { - It(e) && n.delete(t); - } - function jt() { - (Bt = !1), - null !== xt && It(xt) && (xt = null), - null !== St && It(St) && (St = null), - null !== Pt && It(Pt) && (Pt = null), - Tt.forEach(Mt), - _t.forEach(Mt); - } - function Ut(e, t) { - e.blockedOn === t && - ((e.blockedOn = null), - Bt || - ((Bt = !0), - r.unstable_scheduleCallback(r.unstable_NormalPriority, jt))); - } - function Ht(e) { - function t(t) { - return Ut(t, e); - } - if (0 < wt.length) { - Ut(wt[0], e); - for (var n = 1; n < wt.length; n++) { - var u = wt[n]; - u.blockedOn === e && (u.blockedOn = null); - } - } - for ( - null !== xt && Ut(xt, e), - null !== St && Ut(St, e), - null !== Pt && Ut(Pt, e), - Tt.forEach(t), - _t.forEach(t), - n = 0; - n < Nt.length; - n++ - ) - (u = Nt[n]).blockedOn === e && (u.blockedOn = null); - for (; 0 < Nt.length && null === (n = Nt[0]).blockedOn; ) - zt(n), null === n.blockedOn && Nt.shift(); - } - var Vt = E.ReactCurrentBatchConfig, - Wt = !0; - function $t(e, t, n, u) { - var r = Ct, - o = Vt.transition; - Vt.transition = null; - try { - (Ct = 1), Qt(e, t, n, u); - } finally { - (Ct = r), (Vt.transition = o); - } - } - function qt(e, t, n, u) { - var r = Ct, - o = Vt.transition; - Vt.transition = null; - try { - (Ct = 4), Qt(e, t, n, u); - } finally { - (Ct = r), (Vt.transition = o); - } - } - function Qt(e, t, n, u) { - if (Wt) { - var r = Kt(e, t, n, u); - if (null === r) Wu(e, t, u, Yt, n), Ot(e, u); - else if ( - (function (e, t, n, u, r) { - switch (t) { - case "focusin": - return (xt = Rt(xt, e, t, n, u, r)), !0; - case "dragenter": - return (St = Rt(St, e, t, n, u, r)), !0; - case "mouseover": - return (Pt = Rt(Pt, e, t, n, u, r)), !0; - case "pointerover": - var o = r.pointerId; - return Tt.set(o, Rt(Tt.get(o) || null, e, t, n, u, r)), !0; - case "gotpointercapture": - return ( - (o = r.pointerId), - _t.set(o, Rt(_t.get(o) || null, e, t, n, u, r)), - !0 - ); - } - return !1; - })(r, e, t, n, u) - ) - u.stopPropagation(); - else if ((Ot(e, u), 4 & t && -1 < Lt.indexOf(e))) { - for (; null !== r; ) { - var o = Cr(r); - if ( - (null !== o && yt(o), - null === (o = Kt(e, t, n, u)) && Wu(e, t, u, Yt, n), - o === r) - ) - break; - r = o; - } - null !== r && u.stopPropagation(); - } else Wu(e, t, u, null, n); - } - } - var Yt = null; - function Kt(e, t, n, u) { - if (((Yt = null), null !== (e = gr((e = ye(u)))))) - if (null === (t = He(e))) e = null; - else if (13 === (n = t.tag)) { - if (null !== (e = Ve(t))) return e; - e = null; - } else if (3 === n) { - if (t.stateNode.current.memoizedState.isDehydrated) - return 3 === t.tag ? t.stateNode.containerInfo : null; - e = null; - } else t !== e && (e = null); - return (Yt = e), null; - } - function Xt(e) { - switch (e) { - case "cancel": - case "click": - case "close": - case "contextmenu": - case "copy": - case "cut": - case "auxclick": - case "dblclick": - case "dragend": - case "dragstart": - case "drop": - case "focusin": - case "focusout": - case "input": - case "invalid": - case "keydown": - case "keypress": - case "keyup": - case "mousedown": - case "mouseup": - case "paste": - case "pause": - case "play": - case "pointercancel": - case "pointerdown": - case "pointerup": - case "ratechange": - case "reset": - case "resize": - case "seeked": - case "submit": - case "touchcancel": - case "touchend": - case "touchstart": - case "volumechange": - case "change": - case "selectionchange": - case "textInput": - case "compositionstart": - case "compositionend": - case "compositionupdate": - case "beforeblur": - case "afterblur": - case "beforeinput": - case "blur": - case "fullscreenchange": - case "focus": - case "hashchange": - case "popstate": - case "select": - case "selectstart": - return 1; - case "drag": - case "dragenter": - case "dragexit": - case "dragleave": - case "dragover": - case "mousemove": - case "mouseout": - case "mouseover": - case "pointermove": - case "pointerout": - case "pointerover": - case "scroll": - case "toggle": - case "touchmove": - case "wheel": - case "mouseenter": - case "mouseleave": - case "pointerenter": - case "pointerleave": - return 4; - case "message": - switch (Ze()) { - case Ge: - return 1; - case et: - return 4; - case tt: - case nt: - return 16; - case ut: - return 536870912; - default: - return 16; - } - default: - return 16; - } - } - var Jt = null, - Zt = null, - Gt = null; - function en() { - if (Gt) return Gt; - var e, - t, - n = Zt, - u = n.length, - r = "value" in Jt ? Jt.value : Jt.textContent, - o = r.length; - for (e = 0; e < u && n[e] === r[e]; e++); - var l = u - e; - for (t = 1; t <= l && n[u - t] === r[o - t]; t++); - return (Gt = r.slice(e, 1 < t ? 1 - t : void 0)); - } - function tn(e) { - var t = e.keyCode; - return ( - "charCode" in e - ? 0 === (e = e.charCode) && 13 === t && (e = 13) - : (e = t), - 10 === e && (e = 13), - 32 <= e || 13 === e ? e : 0 - ); - } - function nn() { - return !0; - } - function un() { - return !1; - } - function rn(e) { - function t(t, n, u, r, o) { - for (var l in ((this._reactName = t), - (this._targetInst = u), - (this.type = n), - (this.nativeEvent = r), - (this.target = o), - (this.currentTarget = null), - e)) - e.hasOwnProperty(l) && ((t = e[l]), (this[l] = t ? t(r) : r[l])); - return ( - (this.isDefaultPrevented = ( - null != r.defaultPrevented - ? r.defaultPrevented - : !1 === r.returnValue - ) - ? nn - : un), - (this.isPropagationStopped = un), - this - ); - } - return ( - z(t.prototype, { - preventDefault: function () { - this.defaultPrevented = !0; - var e = this.nativeEvent; - e && - (e.preventDefault - ? e.preventDefault() - : "unknown" !== typeof e.returnValue && - (e.returnValue = !1), - (this.isDefaultPrevented = nn)); - }, - stopPropagation: function () { - var e = this.nativeEvent; - e && - (e.stopPropagation - ? e.stopPropagation() - : "unknown" !== typeof e.cancelBubble && - (e.cancelBubble = !0), - (this.isPropagationStopped = nn)); - }, - persist: function () {}, - isPersistent: nn, - }), - t - ); - } - var on, - ln, - an, - sn = { - eventPhase: 0, - bubbles: 0, - cancelable: 0, - timeStamp: function (e) { - return e.timeStamp || Date.now(); - }, - defaultPrevented: 0, - isTrusted: 0, - }, - cn = rn(sn), - Dn = z({}, sn, { view: 0, detail: 0 }), - fn = rn(Dn), - dn = z({}, Dn, { - screenX: 0, - screenY: 0, - clientX: 0, - clientY: 0, - pageX: 0, - pageY: 0, - ctrlKey: 0, - shiftKey: 0, - altKey: 0, - metaKey: 0, - getModifierState: kn, - button: 0, - buttons: 0, - relatedTarget: function (e) { - return void 0 === e.relatedTarget - ? e.fromElement === e.srcElement - ? e.toElement - : e.fromElement - : e.relatedTarget; - }, - movementX: function (e) { - return "movementX" in e - ? e.movementX - : (e !== an && - (an && "mousemove" === e.type - ? ((on = e.screenX - an.screenX), - (ln = e.screenY - an.screenY)) - : (ln = on = 0), - (an = e)), - on); - }, - movementY: function (e) { - return "movementY" in e ? e.movementY : ln; - }, - }), - pn = rn(dn), - hn = rn(z({}, dn, { dataTransfer: 0 })), - mn = rn(z({}, Dn, { relatedTarget: 0 })), - Fn = rn( - z({}, sn, { animationName: 0, elapsedTime: 0, pseudoElement: 0 }), - ), - gn = z({}, sn, { - clipboardData: function (e) { - return "clipboardData" in e - ? e.clipboardData - : window.clipboardData; - }, - }), - Cn = rn(gn), - En = rn(z({}, sn, { data: 0 })), - yn = { - Esc: "Escape", - Spacebar: " ", - Left: "ArrowLeft", - Up: "ArrowUp", - Right: "ArrowRight", - Down: "ArrowDown", - Del: "Delete", - Win: "OS", - Menu: "ContextMenu", - Apps: "ContextMenu", - Scroll: "ScrollLock", - MozPrintableKey: "Unidentified", - }, - vn = { - 8: "Backspace", - 9: "Tab", - 12: "Clear", - 13: "Enter", - 16: "Shift", - 17: "Control", - 18: "Alt", - 19: "Pause", - 20: "CapsLock", - 27: "Escape", - 32: " ", - 33: "PageUp", - 34: "PageDown", - 35: "End", - 36: "Home", - 37: "ArrowLeft", - 38: "ArrowUp", - 39: "ArrowRight", - 40: "ArrowDown", - 45: "Insert", - 46: "Delete", - 112: "F1", - 113: "F2", - 114: "F3", - 115: "F4", - 116: "F5", - 117: "F6", - 118: "F7", - 119: "F8", - 120: "F9", - 121: "F10", - 122: "F11", - 123: "F12", - 144: "NumLock", - 145: "ScrollLock", - 224: "Meta", - }, - An = { - Alt: "altKey", - Control: "ctrlKey", - Meta: "metaKey", - Shift: "shiftKey", - }; - function bn(e) { - var t = this.nativeEvent; - return t.getModifierState - ? t.getModifierState(e) - : !!(e = An[e]) && !!t[e]; - } - function kn() { - return bn; - } - var Bn = z({}, Dn, { - key: function (e) { - if (e.key) { - var t = yn[e.key] || e.key; - if ("Unidentified" !== t) return t; - } - return "keypress" === e.type - ? 13 === (e = tn(e)) - ? "Enter" - : String.fromCharCode(e) - : "keydown" === e.type || "keyup" === e.type - ? vn[e.keyCode] || "Unidentified" - : ""; - }, - code: 0, - location: 0, - ctrlKey: 0, - shiftKey: 0, - altKey: 0, - metaKey: 0, - repeat: 0, - locale: 0, - getModifierState: kn, - charCode: function (e) { - return "keypress" === e.type ? tn(e) : 0; - }, - keyCode: function (e) { - return "keydown" === e.type || "keyup" === e.type ? e.keyCode : 0; - }, - which: function (e) { - return "keypress" === e.type - ? tn(e) - : "keydown" === e.type || "keyup" === e.type - ? e.keyCode - : 0; - }, - }), - wn = rn(Bn), - xn = rn( - z({}, dn, { - pointerId: 0, - width: 0, - height: 0, - pressure: 0, - tangentialPressure: 0, - tiltX: 0, - tiltY: 0, - twist: 0, - pointerType: 0, - isPrimary: 0, - }), - ), - Sn = rn( - z({}, Dn, { - touches: 0, - targetTouches: 0, - changedTouches: 0, - altKey: 0, - metaKey: 0, - ctrlKey: 0, - shiftKey: 0, - getModifierState: kn, - }), - ), - Pn = rn( - z({}, sn, { propertyName: 0, elapsedTime: 0, pseudoElement: 0 }), - ), - Tn = z({}, dn, { - deltaX: function (e) { - return "deltaX" in e - ? e.deltaX - : "wheelDeltaX" in e - ? -e.wheelDeltaX - : 0; - }, - deltaY: function (e) { - return "deltaY" in e - ? e.deltaY - : "wheelDeltaY" in e - ? -e.wheelDeltaY - : "wheelDelta" in e - ? -e.wheelDelta - : 0; - }, - deltaZ: 0, - deltaMode: 0, - }), - _n = rn(Tn), - Nn = [9, 13, 27, 32], - Ln = c && "CompositionEvent" in window, - On = null; - c && "documentMode" in document && (On = document.documentMode); - var Rn = c && "TextEvent" in window && !On, - zn = c && (!Ln || (On && 8 < On && 11 >= On)), - In = String.fromCharCode(32), - Mn = !1; - function jn(e, t) { - switch (e) { - case "keyup": - return -1 !== Nn.indexOf(t.keyCode); - case "keydown": - return 229 !== t.keyCode; - case "keypress": - case "mousedown": - case "focusout": - return !0; - default: - return !1; - } - } - function Un(e) { - return "object" === typeof (e = e.detail) && "data" in e - ? e.data - : null; - } - var Hn = !1; - var Vn = { - color: !0, - date: !0, - datetime: !0, - "datetime-local": !0, - email: !0, - month: !0, - number: !0, - password: !0, - range: !0, - search: !0, - tel: !0, - text: !0, - time: !0, - url: !0, - week: !0, - }; - function Wn(e) { - var t = e && e.nodeName && e.nodeName.toLowerCase(); - return "input" === t ? !!Vn[e.type] : "textarea" === t; - } - function $n(e, t, n, u) { - Be(u), - 0 < (t = qu(t, "onChange")).length && - ((n = new cn("onChange", "change", null, n, u)), - e.push({ event: n, listeners: t })); - } - var qn = null, - Qn = null; - function Yn(e) { - Iu(e, 0); - } - function Kn(e) { - if (Q(Er(e))) return e; - } - function Xn(e, t) { - if ("change" === e) return t; - } - var Jn = !1; - if (c) { - var Zn; - if (c) { - var Gn = "oninput" in document; - if (!Gn) { - var eu = document.createElement("div"); - eu.setAttribute("oninput", "return;"), - (Gn = "function" === typeof eu.oninput); - } - Zn = Gn; - } else Zn = !1; - Jn = Zn && (!document.documentMode || 9 < document.documentMode); - } - function tu() { - qn && (qn.detachEvent("onpropertychange", nu), (Qn = qn = null)); - } - function nu(e) { - if ("value" === e.propertyName && Kn(Qn)) { - var t = []; - $n(t, Qn, e, ye(e)), Te(Yn, t); - } - } - function uu(e, t, n) { - "focusin" === e - ? (tu(), (Qn = n), (qn = t).attachEvent("onpropertychange", nu)) - : "focusout" === e && tu(); - } - function ru(e) { - if ("selectionchange" === e || "keyup" === e || "keydown" === e) - return Kn(Qn); - } - function ou(e, t) { - if ("click" === e) return Kn(t); - } - function lu(e, t) { - if ("input" === e || "change" === e) return Kn(t); - } - var au = - "function" === typeof Object.is - ? Object.is - : function (e, t) { - return ( - (e === t && (0 !== e || 1 / e === 1 / t)) || - (e !== e && t !== t) - ); - }; - function iu(e, t) { - if (au(e, t)) return !0; - if ( - "object" !== typeof e || - null === e || - "object" !== typeof t || - null === t - ) - return !1; - var n = Object.keys(e), - u = Object.keys(t); - if (n.length !== u.length) return !1; - for (u = 0; u < n.length; u++) { - var r = n[u]; - if (!D.call(t, r) || !au(e[r], t[r])) return !1; - } - return !0; - } - function su(e) { - for (; e && e.firstChild; ) e = e.firstChild; - return e; - } - function cu(e, t) { - var n, - u = su(e); - for (e = 0; u; ) { - if (3 === u.nodeType) { - if (((n = e + u.textContent.length), e <= t && n >= t)) - return { node: u, offset: t - e }; - e = n; - } - e: { - for (; u; ) { - if (u.nextSibling) { - u = u.nextSibling; - break e; - } - u = u.parentNode; - } - u = void 0; - } - u = su(u); - } - } - function Du(e, t) { - return ( - !(!e || !t) && - (e === t || - ((!e || 3 !== e.nodeType) && - (t && 3 === t.nodeType - ? Du(e, t.parentNode) - : "contains" in e - ? e.contains(t) - : !!e.compareDocumentPosition && - !!(16 & e.compareDocumentPosition(t))))) - ); - } - function fu() { - for (var e = window, t = Y(); t instanceof e.HTMLIFrameElement; ) { - try { - var n = "string" === typeof t.contentWindow.location.href; - } catch (u) { - n = !1; - } - if (!n) break; - t = Y((e = t.contentWindow).document); - } - return t; - } - function du(e) { - var t = e && e.nodeName && e.nodeName.toLowerCase(); - return ( - t && - (("input" === t && - ("text" === e.type || - "search" === e.type || - "tel" === e.type || - "url" === e.type || - "password" === e.type)) || - "textarea" === t || - "true" === e.contentEditable) - ); - } - function pu(e) { - var t = fu(), - n = e.focusedElem, - u = e.selectionRange; - if ( - t !== n && - n && - n.ownerDocument && - Du(n.ownerDocument.documentElement, n) - ) { - if (null !== u && du(n)) - if ( - ((t = u.start), - void 0 === (e = u.end) && (e = t), - "selectionStart" in n) - ) - (n.selectionStart = t), - (n.selectionEnd = Math.min(e, n.value.length)); - else if ( - (e = - ((t = n.ownerDocument || document) && t.defaultView) || - window).getSelection - ) { - e = e.getSelection(); - var r = n.textContent.length, - o = Math.min(u.start, r); - (u = void 0 === u.end ? o : Math.min(u.end, r)), - !e.extend && o > u && ((r = u), (u = o), (o = r)), - (r = cu(n, o)); - var l = cu(n, u); - r && - l && - (1 !== e.rangeCount || - e.anchorNode !== r.node || - e.anchorOffset !== r.offset || - e.focusNode !== l.node || - e.focusOffset !== l.offset) && - ((t = t.createRange()).setStart(r.node, r.offset), - e.removeAllRanges(), - o > u - ? (e.addRange(t), e.extend(l.node, l.offset)) - : (t.setEnd(l.node, l.offset), e.addRange(t))); - } - for (t = [], e = n; (e = e.parentNode); ) - 1 === e.nodeType && - t.push({ element: e, left: e.scrollLeft, top: e.scrollTop }); - for ( - "function" === typeof n.focus && n.focus(), n = 0; - n < t.length; - n++ - ) - ((e = t[n]).element.scrollLeft = e.left), - (e.element.scrollTop = e.top); - } - } - var hu = c && "documentMode" in document && 11 >= document.documentMode, - mu = null, - Fu = null, - gu = null, - Cu = !1; - function Eu(e, t, n) { - var u = - n.window === n - ? n.document - : 9 === n.nodeType - ? n - : n.ownerDocument; - Cu || - null == mu || - mu !== Y(u) || - ("selectionStart" in (u = mu) && du(u) - ? (u = { start: u.selectionStart, end: u.selectionEnd }) - : (u = { - anchorNode: (u = ( - (u.ownerDocument && u.ownerDocument.defaultView) || - window - ).getSelection()).anchorNode, - anchorOffset: u.anchorOffset, - focusNode: u.focusNode, - focusOffset: u.focusOffset, - }), - (gu && iu(gu, u)) || - ((gu = u), - 0 < (u = qu(Fu, "onSelect")).length && - ((t = new cn("onSelect", "select", null, t, n)), - e.push({ event: t, listeners: u }), - (t.target = mu)))); - } - function yu(e, t) { - var n = {}; - return ( - (n[e.toLowerCase()] = t.toLowerCase()), - (n["Webkit" + e] = "webkit" + t), - (n["Moz" + e] = "moz" + t), - n - ); - } - var vu = { - animationend: yu("Animation", "AnimationEnd"), - animationiteration: yu("Animation", "AnimationIteration"), - animationstart: yu("Animation", "AnimationStart"), - transitionend: yu("Transition", "TransitionEnd"), - }, - Au = {}, - bu = {}; - function ku(e) { - if (Au[e]) return Au[e]; - if (!vu[e]) return e; - var t, - n = vu[e]; - for (t in n) - if (n.hasOwnProperty(t) && t in bu) return (Au[e] = n[t]); - return e; - } - c && - ((bu = document.createElement("div").style), - "AnimationEvent" in window || - (delete vu.animationend.animation, - delete vu.animationiteration.animation, - delete vu.animationstart.animation), - "TransitionEvent" in window || delete vu.transitionend.transition); - var Bu = ku("animationend"), - wu = ku("animationiteration"), - xu = ku("animationstart"), - Su = ku("transitionend"), - Pu = new Map(), - Tu = - "abort auxClick cancel canPlay canPlayThrough click close contextMenu copy cut drag dragEnd dragEnter dragExit dragLeave dragOver dragStart drop durationChange emptied encrypted ended error gotPointerCapture input invalid keyDown keyPress keyUp load loadedData loadedMetadata loadStart lostPointerCapture mouseDown mouseMove mouseOut mouseOver mouseUp paste pause play playing pointerCancel pointerDown pointerMove pointerOut pointerOver pointerUp progress rateChange reset resize seeked seeking stalled submit suspend timeUpdate touchCancel touchEnd touchStart volumeChange scroll toggle touchMove waiting wheel".split( - " ", - ); - function _u(e, t) { - Pu.set(e, t), i(t, [e]); - } - for (var Nu = 0; Nu < Tu.length; Nu++) { - var Lu = Tu[Nu]; - _u(Lu.toLowerCase(), "on" + (Lu[0].toUpperCase() + Lu.slice(1))); - } - _u(Bu, "onAnimationEnd"), - _u(wu, "onAnimationIteration"), - _u(xu, "onAnimationStart"), - _u("dblclick", "onDoubleClick"), - _u("focusin", "onFocus"), - _u("focusout", "onBlur"), - _u(Su, "onTransitionEnd"), - s("onMouseEnter", ["mouseout", "mouseover"]), - s("onMouseLeave", ["mouseout", "mouseover"]), - s("onPointerEnter", ["pointerout", "pointerover"]), - s("onPointerLeave", ["pointerout", "pointerover"]), - i( - "onChange", - "change click focusin focusout input keydown keyup selectionchange".split( - " ", - ), - ), - i( - "onSelect", - "focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange".split( - " ", - ), - ), - i("onBeforeInput", [ - "compositionend", - "keypress", - "textInput", - "paste", - ]), - i( - "onCompositionEnd", - "compositionend focusout keydown keypress keyup mousedown".split( - " ", - ), - ), - i( - "onCompositionStart", - "compositionstart focusout keydown keypress keyup mousedown".split( - " ", - ), - ), - i( - "onCompositionUpdate", - "compositionupdate focusout keydown keypress keyup mousedown".split( - " ", - ), - ); - var Ou = - "abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange resize seeked seeking stalled suspend timeupdate volumechange waiting".split( - " ", - ), - Ru = new Set( - "cancel close invalid load scroll toggle".split(" ").concat(Ou), - ); - function zu(e, t, n) { - var u = e.type || "unknown-event"; - (e.currentTarget = n), - (function (e, t, n, u, r, l, a, i, s) { - if ((Ue.apply(this, arguments), Re)) { - if (!Re) throw Error(o(198)); - var c = ze; - (Re = !1), (ze = null), Ie || ((Ie = !0), (Me = c)); - } - })(u, t, void 0, e), - (e.currentTarget = null); - } - function Iu(e, t) { - t = 0 !== (4 & t); - for (var n = 0; n < e.length; n++) { - var u = e[n], - r = u.event; - u = u.listeners; - e: { - var o = void 0; - if (t) - for (var l = u.length - 1; 0 <= l; l--) { - var a = u[l], - i = a.instance, - s = a.currentTarget; - if (((a = a.listener), i !== o && r.isPropagationStopped())) - break e; - zu(r, a, s), (o = i); - } - else - for (l = 0; l < u.length; l++) { - if ( - ((i = (a = u[l]).instance), - (s = a.currentTarget), - (a = a.listener), - i !== o && r.isPropagationStopped()) - ) - break e; - zu(r, a, s), (o = i); - } - } - } - if (Ie) throw ((e = Me), (Ie = !1), (Me = null), e); - } - function Mu(e, t) { - var n = t[hr]; - void 0 === n && (n = t[hr] = new Set()); - var u = e + "__bubble"; - n.has(u) || (Vu(t, e, 2, !1), n.add(u)); - } - function ju(e, t, n) { - var u = 0; - t && (u |= 4), Vu(n, e, u, t); - } - var Uu = "_reactListening" + Math.random().toString(36).slice(2); - function Hu(e) { - if (!e[Uu]) { - (e[Uu] = !0), - l.forEach(function (t) { - "selectionchange" !== t && - (Ru.has(t) || ju(t, !1, e), ju(t, !0, e)); - }); - var t = 9 === e.nodeType ? e : e.ownerDocument; - null === t || t[Uu] || ((t[Uu] = !0), ju("selectionchange", !1, t)); - } - } - function Vu(e, t, n, u) { - switch (Xt(t)) { - case 1: - var r = $t; - break; - case 4: - r = qt; - break; - default: - r = Qt; - } - (n = r.bind(null, t, n, e)), - (r = void 0), - !Ne || - ("touchstart" !== t && "touchmove" !== t && "wheel" !== t) || - (r = !0), - u - ? void 0 !== r - ? e.addEventListener(t, n, { capture: !0, passive: r }) - : e.addEventListener(t, n, !0) - : void 0 !== r - ? e.addEventListener(t, n, { passive: r }) - : e.addEventListener(t, n, !1); - } - function Wu(e, t, n, u, r) { - var o = u; - if (0 === (1 & t) && 0 === (2 & t) && null !== u) - e: for (;;) { - if (null === u) return; - var l = u.tag; - if (3 === l || 4 === l) { - var a = u.stateNode.containerInfo; - if (a === r || (8 === a.nodeType && a.parentNode === r)) break; - if (4 === l) - for (l = u.return; null !== l; ) { - var i = l.tag; - if ( - (3 === i || 4 === i) && - ((i = l.stateNode.containerInfo) === r || - (8 === i.nodeType && i.parentNode === r)) - ) - return; - l = l.return; - } - for (; null !== a; ) { - if (null === (l = gr(a))) return; - if (5 === (i = l.tag) || 6 === i) { - u = o = l; - continue e; - } - a = a.parentNode; - } - } - u = u.return; - } - Te(function () { - var u = o, - r = ye(n), - l = []; - e: { - var a = Pu.get(e); - if (void 0 !== a) { - var i = cn, - s = e; - switch (e) { - case "keypress": - if (0 === tn(n)) break e; - case "keydown": - case "keyup": - i = wn; - break; - case "focusin": - (s = "focus"), (i = mn); - break; - case "focusout": - (s = "blur"), (i = mn); - break; - case "beforeblur": - case "afterblur": - i = mn; - break; - case "click": - if (2 === n.button) break e; - case "auxclick": - case "dblclick": - case "mousedown": - case "mousemove": - case "mouseup": - case "mouseout": - case "mouseover": - case "contextmenu": - i = pn; - break; - case "drag": - case "dragend": - case "dragenter": - case "dragexit": - case "dragleave": - case "dragover": - case "dragstart": - case "drop": - i = hn; - break; - case "touchcancel": - case "touchend": - case "touchmove": - case "touchstart": - i = Sn; - break; - case Bu: - case wu: - case xu: - i = Fn; - break; - case Su: - i = Pn; - break; - case "scroll": - i = fn; - break; - case "wheel": - i = _n; - break; - case "copy": - case "cut": - case "paste": - i = Cn; - break; - case "gotpointercapture": - case "lostpointercapture": - case "pointercancel": - case "pointerdown": - case "pointermove": - case "pointerout": - case "pointerover": - case "pointerup": - i = xn; - } - var c = 0 !== (4 & t), - D = !c && "scroll" === e, - f = c ? (null !== a ? a + "Capture" : null) : a; - c = []; - for (var d, p = u; null !== p; ) { - var h = (d = p).stateNode; - if ( - (5 === d.tag && - null !== h && - ((d = h), - null !== f && - null != (h = _e(p, f)) && - c.push($u(p, h, d))), - D) - ) - break; - p = p.return; - } - 0 < c.length && - ((a = new i(a, s, null, n, r)), - l.push({ event: a, listeners: c })); - } - } - if (0 === (7 & t)) { - if ( - ((i = "mouseout" === e || "pointerout" === e), - (!(a = "mouseover" === e || "pointerover" === e) || - n === Ee || - !(s = n.relatedTarget || n.fromElement) || - (!gr(s) && !s[pr])) && - (i || a) && - ((a = - r.window === r - ? r - : (a = r.ownerDocument) - ? a.defaultView || a.parentWindow - : window), - i - ? ((i = u), - null !== - (s = (s = n.relatedTarget || n.toElement) - ? gr(s) - : null) && - (s !== (D = He(s)) || (5 !== s.tag && 6 !== s.tag)) && - (s = null)) - : ((i = null), (s = u)), - i !== s)) - ) { - if ( - ((c = pn), - (h = "onMouseLeave"), - (f = "onMouseEnter"), - (p = "mouse"), - ("pointerout" !== e && "pointerover" !== e) || - ((c = xn), - (h = "onPointerLeave"), - (f = "onPointerEnter"), - (p = "pointer")), - (D = null == i ? a : Er(i)), - (d = null == s ? a : Er(s)), - ((a = new c(h, p + "leave", i, n, r)).target = D), - (a.relatedTarget = d), - (h = null), - gr(r) === u && - (((c = new c(f, p + "enter", s, n, r)).target = d), - (c.relatedTarget = D), - (h = c)), - (D = h), - i && s) - ) - e: { - for (f = s, p = 0, d = c = i; d; d = Qu(d)) p++; - for (d = 0, h = f; h; h = Qu(h)) d++; - for (; 0 < p - d; ) (c = Qu(c)), p--; - for (; 0 < d - p; ) (f = Qu(f)), d--; - for (; p--; ) { - if (c === f || (null !== f && c === f.alternate)) break e; - (c = Qu(c)), (f = Qu(f)); - } - c = null; - } - else c = null; - null !== i && Yu(l, a, i, c, !1), - null !== s && null !== D && Yu(l, D, s, c, !0); - } - if ( - "select" === - (i = - (a = u ? Er(u) : window).nodeName && - a.nodeName.toLowerCase()) || - ("input" === i && "file" === a.type) - ) - var m = Xn; - else if (Wn(a)) - if (Jn) m = lu; - else { - m = ru; - var F = uu; - } - else - (i = a.nodeName) && - "input" === i.toLowerCase() && - ("checkbox" === a.type || "radio" === a.type) && - (m = ou); - switch ( - (m && (m = m(e, u)) - ? $n(l, m, n, r) - : (F && F(e, a, u), - "focusout" === e && - (F = a._wrapperState) && - F.controlled && - "number" === a.type && - ee(a, "number", a.value)), - (F = u ? Er(u) : window), - e) - ) { - case "focusin": - (Wn(F) || "true" === F.contentEditable) && - ((mu = F), (Fu = u), (gu = null)); - break; - case "focusout": - gu = Fu = mu = null; - break; - case "mousedown": - Cu = !0; - break; - case "contextmenu": - case "mouseup": - case "dragend": - (Cu = !1), Eu(l, n, r); - break; - case "selectionchange": - if (hu) break; - case "keydown": - case "keyup": - Eu(l, n, r); - } - var g; - if (Ln) - e: { - switch (e) { - case "compositionstart": - var C = "onCompositionStart"; - break e; - case "compositionend": - C = "onCompositionEnd"; - break e; - case "compositionupdate": - C = "onCompositionUpdate"; - break e; - } - C = void 0; - } - else - Hn - ? jn(e, n) && (C = "onCompositionEnd") - : "keydown" === e && - 229 === n.keyCode && - (C = "onCompositionStart"); - C && - (zn && - "ko" !== n.locale && - (Hn || "onCompositionStart" !== C - ? "onCompositionEnd" === C && Hn && (g = en()) - : ((Zt = "value" in (Jt = r) ? Jt.value : Jt.textContent), - (Hn = !0))), - 0 < (F = qu(u, C)).length && - ((C = new En(C, e, null, n, r)), - l.push({ event: C, listeners: F }), - g ? (C.data = g) : null !== (g = Un(n)) && (C.data = g))), - (g = Rn - ? (function (e, t) { - switch (e) { - case "compositionend": - return Un(t); - case "keypress": - return 32 !== t.which ? null : ((Mn = !0), In); - case "textInput": - return (e = t.data) === In && Mn ? null : e; - default: - return null; - } - })(e, n) - : (function (e, t) { - if (Hn) - return "compositionend" === e || (!Ln && jn(e, t)) - ? ((e = en()), (Gt = Zt = Jt = null), (Hn = !1), e) - : null; - switch (e) { - case "paste": - default: - return null; - case "keypress": - if ( - !(t.ctrlKey || t.altKey || t.metaKey) || - (t.ctrlKey && t.altKey) - ) { - if (t.char && 1 < t.char.length) return t.char; - if (t.which) return String.fromCharCode(t.which); - } - return null; - case "compositionend": - return zn && "ko" !== t.locale ? null : t.data; - } - })(e, n)) && - 0 < (u = qu(u, "onBeforeInput")).length && - ((r = new En("onBeforeInput", "beforeinput", null, n, r)), - l.push({ event: r, listeners: u }), - (r.data = g)); - } - Iu(l, t); - }); - } - function $u(e, t, n) { - return { instance: e, listener: t, currentTarget: n }; - } - function qu(e, t) { - for (var n = t + "Capture", u = []; null !== e; ) { - var r = e, - o = r.stateNode; - 5 === r.tag && - null !== o && - ((r = o), - null != (o = _e(e, n)) && u.unshift($u(e, o, r)), - null != (o = _e(e, t)) && u.push($u(e, o, r))), - (e = e.return); - } - return u; - } - function Qu(e) { - if (null === e) return null; - do { - e = e.return; - } while (e && 5 !== e.tag); - return e || null; - } - function Yu(e, t, n, u, r) { - for (var o = t._reactName, l = []; null !== n && n !== u; ) { - var a = n, - i = a.alternate, - s = a.stateNode; - if (null !== i && i === u) break; - 5 === a.tag && - null !== s && - ((a = s), - r - ? null != (i = _e(n, o)) && l.unshift($u(n, i, a)) - : r || (null != (i = _e(n, o)) && l.push($u(n, i, a)))), - (n = n.return); - } - 0 !== l.length && e.push({ event: t, listeners: l }); - } - var Ku = /\r\n?/g, - Xu = /\u0000|\uFFFD/g; - function Ju(e) { - return ("string" === typeof e ? e : "" + e) - .replace(Ku, "\n") - .replace(Xu, ""); - } - function Zu(e, t, n) { - if (((t = Ju(t)), Ju(e) !== t && n)) throw Error(o(425)); - } - function Gu() {} - var er = null, - tr = null; - function nr(e, t) { - return ( - "textarea" === e || - "noscript" === e || - "string" === typeof t.children || - "number" === typeof t.children || - ("object" === typeof t.dangerouslySetInnerHTML && - null !== t.dangerouslySetInnerHTML && - null != t.dangerouslySetInnerHTML.__html) - ); - } - var ur = "function" === typeof setTimeout ? setTimeout : void 0, - rr = "function" === typeof clearTimeout ? clearTimeout : void 0, - or = "function" === typeof Promise ? Promise : void 0, - lr = - "function" === typeof queueMicrotask - ? queueMicrotask - : "undefined" !== typeof or - ? function (e) { - return or.resolve(null).then(e).catch(ar); - } - : ur; - function ar(e) { - setTimeout(function () { - throw e; - }); - } - function ir(e, t) { - var n = t, - u = 0; - do { - var r = n.nextSibling; - if ((e.removeChild(n), r && 8 === r.nodeType)) - if ("/$" === (n = r.data)) { - if (0 === u) return e.removeChild(r), void Ht(t); - u--; - } else ("$" !== n && "$?" !== n && "$!" !== n) || u++; - n = r; - } while (n); - Ht(t); - } - function sr(e) { - for (; null != e; e = e.nextSibling) { - var t = e.nodeType; - if (1 === t || 3 === t) break; - if (8 === t) { - if ("$" === (t = e.data) || "$!" === t || "$?" === t) break; - if ("/$" === t) return null; - } - } - return e; - } - function cr(e) { - e = e.previousSibling; - for (var t = 0; e; ) { - if (8 === e.nodeType) { - var n = e.data; - if ("$" === n || "$!" === n || "$?" === n) { - if (0 === t) return e; - t--; - } else "/$" === n && t++; - } - e = e.previousSibling; - } - return null; - } - var Dr = Math.random().toString(36).slice(2), - fr = "__reactFiber$" + Dr, - dr = "__reactProps$" + Dr, - pr = "__reactContainer$" + Dr, - hr = "__reactEvents$" + Dr, - mr = "__reactListeners$" + Dr, - Fr = "__reactHandles$" + Dr; - function gr(e) { - var t = e[fr]; - if (t) return t; - for (var n = e.parentNode; n; ) { - if ((t = n[pr] || n[fr])) { - if ( - ((n = t.alternate), - null !== t.child || (null !== n && null !== n.child)) - ) - for (e = cr(e); null !== e; ) { - if ((n = e[fr])) return n; - e = cr(e); - } - return t; - } - n = (e = n).parentNode; - } - return null; - } - function Cr(e) { - return !(e = e[fr] || e[pr]) || - (5 !== e.tag && 6 !== e.tag && 13 !== e.tag && 3 !== e.tag) - ? null - : e; - } - function Er(e) { - if (5 === e.tag || 6 === e.tag) return e.stateNode; - throw Error(o(33)); - } - function yr(e) { - return e[dr] || null; - } - var vr = [], - Ar = -1; - function br(e) { - return { current: e }; - } - function kr(e) { - 0 > Ar || ((e.current = vr[Ar]), (vr[Ar] = null), Ar--); - } - function Br(e, t) { - Ar++, (vr[Ar] = e.current), (e.current = t); - } - var wr = {}, - xr = br(wr), - Sr = br(!1), - Pr = wr; - function Tr(e, t) { - var n = e.type.contextTypes; - if (!n) return wr; - var u = e.stateNode; - if (u && u.__reactInternalMemoizedUnmaskedChildContext === t) - return u.__reactInternalMemoizedMaskedChildContext; - var r, - o = {}; - for (r in n) o[r] = t[r]; - return ( - u && - (((e = e.stateNode).__reactInternalMemoizedUnmaskedChildContext = - t), - (e.__reactInternalMemoizedMaskedChildContext = o)), - o - ); - } - function _r(e) { - return null !== (e = e.childContextTypes) && void 0 !== e; - } - function Nr() { - kr(Sr), kr(xr); - } - function Lr(e, t, n) { - if (xr.current !== wr) throw Error(o(168)); - Br(xr, t), Br(Sr, n); - } - function Or(e, t, n) { - var u = e.stateNode; - if ( - ((t = t.childContextTypes), "function" !== typeof u.getChildContext) - ) - return n; - for (var r in (u = u.getChildContext())) - if (!(r in t)) throw Error(o(108, V(e) || "Unknown", r)); - return z({}, n, u); - } - function Rr(e) { - return ( - (e = - ((e = e.stateNode) && - e.__reactInternalMemoizedMergedChildContext) || - wr), - (Pr = xr.current), - Br(xr, e), - Br(Sr, Sr.current), - !0 - ); - } - function zr(e, t, n) { - var u = e.stateNode; - if (!u) throw Error(o(169)); - n - ? ((e = Or(e, t, Pr)), - (u.__reactInternalMemoizedMergedChildContext = e), - kr(Sr), - kr(xr), - Br(xr, e)) - : kr(Sr), - Br(Sr, n); - } - var Ir = null, - Mr = !1, - jr = !1; - function Ur(e) { - null === Ir ? (Ir = [e]) : Ir.push(e); - } - function Hr() { - if (!jr && null !== Ir) { - jr = !0; - var e = 0, - t = Ct; - try { - var n = Ir; - for (Ct = 1; e < n.length; e++) { - var u = n[e]; - do { - u = u(!0); - } while (null !== u); - } - (Ir = null), (Mr = !1); - } catch (r) { - throw (null !== Ir && (Ir = Ir.slice(e + 1)), Qe(Ge, Hr), r); - } finally { - (Ct = t), (jr = !1); - } - } - return null; - } - var Vr = [], - Wr = 0, - $r = null, - qr = 0, - Qr = [], - Yr = 0, - Kr = null, - Xr = 1, - Jr = ""; - function Zr(e, t) { - (Vr[Wr++] = qr), (Vr[Wr++] = $r), ($r = e), (qr = t); - } - function Gr(e, t, n) { - (Qr[Yr++] = Xr), (Qr[Yr++] = Jr), (Qr[Yr++] = Kr), (Kr = e); - var u = Xr; - e = Jr; - var r = 32 - lt(u) - 1; - (u &= ~(1 << r)), (n += 1); - var o = 32 - lt(t) + r; - if (30 < o) { - var l = r - (r % 5); - (o = (u & ((1 << l) - 1)).toString(32)), - (u >>= l), - (r -= l), - (Xr = (1 << (32 - lt(t) + r)) | (n << r) | u), - (Jr = o + e); - } else (Xr = (1 << o) | (n << r) | u), (Jr = e); - } - function eo(e) { - null !== e.return && (Zr(e, 1), Gr(e, 1, 0)); - } - function to(e) { - for (; e === $r; ) - ($r = Vr[--Wr]), (Vr[Wr] = null), (qr = Vr[--Wr]), (Vr[Wr] = null); - for (; e === Kr; ) - (Kr = Qr[--Yr]), - (Qr[Yr] = null), - (Jr = Qr[--Yr]), - (Qr[Yr] = null), - (Xr = Qr[--Yr]), - (Qr[Yr] = null); - } - var no = null, - uo = null, - ro = !1, - oo = null; - function lo(e, t) { - var n = Ts(5, null, null, 0); - (n.elementType = "DELETED"), - (n.stateNode = t), - (n.return = e), - null === (t = e.deletions) - ? ((e.deletions = [n]), (e.flags |= 16)) - : t.push(n); - } - function ao(e, t) { - switch (e.tag) { - case 5: - var n = e.type; - return ( - null !== - (t = - 1 !== t.nodeType || - n.toLowerCase() !== t.nodeName.toLowerCase() - ? null - : t) && - ((e.stateNode = t), (no = e), (uo = sr(t.firstChild)), !0) - ); - case 6: - return ( - null !== - (t = "" === e.pendingProps || 3 !== t.nodeType ? null : t) && - ((e.stateNode = t), (no = e), (uo = null), !0) - ); - case 13: - return ( - null !== (t = 8 !== t.nodeType ? null : t) && - ((n = null !== Kr ? { id: Xr, overflow: Jr } : null), - (e.memoizedState = { - dehydrated: t, - treeContext: n, - retryLane: 1073741824, - }), - ((n = Ts(18, null, null, 0)).stateNode = t), - (n.return = e), - (e.child = n), - (no = e), - (uo = null), - !0) - ); - default: - return !1; - } - } - function io(e) { - return 0 !== (1 & e.mode) && 0 === (128 & e.flags); - } - function so(e) { - if (ro) { - var t = uo; - if (t) { - var n = t; - if (!ao(e, t)) { - if (io(e)) throw Error(o(418)); - t = sr(n.nextSibling); - var u = no; - t && ao(e, t) - ? lo(u, n) - : ((e.flags = (-4097 & e.flags) | 2), (ro = !1), (no = e)); - } - } else { - if (io(e)) throw Error(o(418)); - (e.flags = (-4097 & e.flags) | 2), (ro = !1), (no = e); - } - } - } - function co(e) { - for ( - e = e.return; - null !== e && 5 !== e.tag && 3 !== e.tag && 13 !== e.tag; - - ) - e = e.return; - no = e; - } - function Do(e) { - if (e !== no) return !1; - if (!ro) return co(e), (ro = !0), !1; - var t; - if ( - ((t = 3 !== e.tag) && - !(t = 5 !== e.tag) && - (t = - "head" !== (t = e.type) && - "body" !== t && - !nr(e.type, e.memoizedProps)), - t && (t = uo)) - ) { - if (io(e)) throw (fo(), Error(o(418))); - for (; t; ) lo(e, t), (t = sr(t.nextSibling)); - } - if ((co(e), 13 === e.tag)) { - if (!(e = null !== (e = e.memoizedState) ? e.dehydrated : null)) - throw Error(o(317)); - e: { - for (e = e.nextSibling, t = 0; e; ) { - if (8 === e.nodeType) { - var n = e.data; - if ("/$" === n) { - if (0 === t) { - uo = sr(e.nextSibling); - break e; - } - t--; - } else ("$" !== n && "$!" !== n && "$?" !== n) || t++; - } - e = e.nextSibling; - } - uo = null; - } - } else uo = no ? sr(e.stateNode.nextSibling) : null; - return !0; - } - function fo() { - for (var e = uo; e; ) e = sr(e.nextSibling); - } - function po() { - (uo = no = null), (ro = !1); - } - function ho(e) { - null === oo ? (oo = [e]) : oo.push(e); - } - var mo = E.ReactCurrentBatchConfig; - function Fo(e, t, n) { - if ( - null !== (e = n.ref) && - "function" !== typeof e && - "object" !== typeof e - ) { - if (n._owner) { - if ((n = n._owner)) { - if (1 !== n.tag) throw Error(o(309)); - var u = n.stateNode; - } - if (!u) throw Error(o(147, e)); - var r = u, - l = "" + e; - return null !== t && - null !== t.ref && - "function" === typeof t.ref && - t.ref._stringRef === l - ? t.ref - : ((t = function (e) { - var t = r.refs; - null === e ? delete t[l] : (t[l] = e); - }), - (t._stringRef = l), - t); - } - if ("string" !== typeof e) throw Error(o(284)); - if (!n._owner) throw Error(o(290, e)); - } - return e; - } - function go(e, t) { - throw ( - ((e = Object.prototype.toString.call(t)), - Error( - o( - 31, - "[object Object]" === e - ? "object with keys {" + Object.keys(t).join(", ") + "}" - : e, - ), - )) - ); - } - function Co(e) { - return (0, e._init)(e._payload); - } - function Eo(e) { - function t(t, n) { - if (e) { - var u = t.deletions; - null === u ? ((t.deletions = [n]), (t.flags |= 16)) : u.push(n); - } - } - function n(n, u) { - if (!e) return null; - for (; null !== u; ) t(n, u), (u = u.sibling); - return null; - } - function u(e, t) { - for (e = new Map(); null !== t; ) - null !== t.key ? e.set(t.key, t) : e.set(t.index, t), - (t = t.sibling); - return e; - } - function r(e, t) { - return ((e = Ns(e, t)).index = 0), (e.sibling = null), e; - } - function l(t, n, u) { - return ( - (t.index = u), - e - ? null !== (u = t.alternate) - ? (u = u.index) < n - ? ((t.flags |= 2), n) - : u - : ((t.flags |= 2), n) - : ((t.flags |= 1048576), n) - ); - } - function a(t) { - return e && null === t.alternate && (t.flags |= 2), t; - } - function i(e, t, n, u) { - return null === t || 6 !== t.tag - ? (((t = zs(n, e.mode, u)).return = e), t) - : (((t = r(t, n)).return = e), t); - } - function s(e, t, n, u) { - var o = n.type; - return o === A - ? D(e, t, n.props.children, u, n.key) - : null !== t && - (t.elementType === o || - ("object" === typeof o && - null !== o && - o.$$typeof === _ && - Co(o) === t.type)) - ? (((u = r(t, n.props)).ref = Fo(e, t, n)), (u.return = e), u) - : (((u = Ls(n.type, n.key, n.props, null, e.mode, u)).ref = Fo( - e, - t, - n, - )), - (u.return = e), - u); - } - function c(e, t, n, u) { - return null === t || - 4 !== t.tag || - t.stateNode.containerInfo !== n.containerInfo || - t.stateNode.implementation !== n.implementation - ? (((t = Is(n, e.mode, u)).return = e), t) - : (((t = r(t, n.children || [])).return = e), t); - } - function D(e, t, n, u, o) { - return null === t || 7 !== t.tag - ? (((t = Os(n, e.mode, u, o)).return = e), t) - : (((t = r(t, n)).return = e), t); - } - function f(e, t, n) { - if (("string" === typeof t && "" !== t) || "number" === typeof t) - return ((t = zs("" + t, e.mode, n)).return = e), t; - if ("object" === typeof t && null !== t) { - switch (t.$$typeof) { - case y: - return ( - ((n = Ls(t.type, t.key, t.props, null, e.mode, n)).ref = Fo( - e, - null, - t, - )), - (n.return = e), - n - ); - case v: - return ((t = Is(t, e.mode, n)).return = e), t; - case _: - return f(e, (0, t._init)(t._payload), n); - } - if (te(t) || O(t)) - return ((t = Os(t, e.mode, n, null)).return = e), t; - go(e, t); - } - return null; - } - function d(e, t, n, u) { - var r = null !== t ? t.key : null; - if (("string" === typeof n && "" !== n) || "number" === typeof n) - return null !== r ? null : i(e, t, "" + n, u); - if ("object" === typeof n && null !== n) { - switch (n.$$typeof) { - case y: - return n.key === r ? s(e, t, n, u) : null; - case v: - return n.key === r ? c(e, t, n, u) : null; - case _: - return d(e, t, (r = n._init)(n._payload), u); - } - if (te(n) || O(n)) return null !== r ? null : D(e, t, n, u, null); - go(e, n); - } - return null; - } - function p(e, t, n, u, r) { - if (("string" === typeof u && "" !== u) || "number" === typeof u) - return i(t, (e = e.get(n) || null), "" + u, r); - if ("object" === typeof u && null !== u) { - switch (u.$$typeof) { - case y: - return s( - t, - (e = e.get(null === u.key ? n : u.key) || null), - u, - r, - ); - case v: - return c( - t, - (e = e.get(null === u.key ? n : u.key) || null), - u, - r, - ); - case _: - return p(e, t, n, (0, u._init)(u._payload), r); - } - if (te(u) || O(u)) - return D(t, (e = e.get(n) || null), u, r, null); - go(t, u); - } - return null; - } - function h(r, o, a, i) { - for ( - var s = null, c = null, D = o, h = (o = 0), m = null; - null !== D && h < a.length; - h++ - ) { - D.index > h ? ((m = D), (D = null)) : (m = D.sibling); - var F = d(r, D, a[h], i); - if (null === F) { - null === D && (D = m); - break; - } - e && D && null === F.alternate && t(r, D), - (o = l(F, o, h)), - null === c ? (s = F) : (c.sibling = F), - (c = F), - (D = m); - } - if (h === a.length) return n(r, D), ro && Zr(r, h), s; - if (null === D) { - for (; h < a.length; h++) - null !== (D = f(r, a[h], i)) && - ((o = l(D, o, h)), - null === c ? (s = D) : (c.sibling = D), - (c = D)); - return ro && Zr(r, h), s; - } - for (D = u(r, D); h < a.length; h++) - null !== (m = p(D, r, h, a[h], i)) && - (e && - null !== m.alternate && - D.delete(null === m.key ? h : m.key), - (o = l(m, o, h)), - null === c ? (s = m) : (c.sibling = m), - (c = m)); - return ( - e && - D.forEach(function (e) { - return t(r, e); - }), - ro && Zr(r, h), - s - ); - } - function m(r, a, i, s) { - var c = O(i); - if ("function" !== typeof c) throw Error(o(150)); - if (null == (i = c.call(i))) throw Error(o(151)); - for ( - var D = (c = null), h = a, m = (a = 0), F = null, g = i.next(); - null !== h && !g.done; - m++, g = i.next() - ) { - h.index > m ? ((F = h), (h = null)) : (F = h.sibling); - var C = d(r, h, g.value, s); - if (null === C) { - null === h && (h = F); - break; - } - e && h && null === C.alternate && t(r, h), - (a = l(C, a, m)), - null === D ? (c = C) : (D.sibling = C), - (D = C), - (h = F); - } - if (g.done) return n(r, h), ro && Zr(r, m), c; - if (null === h) { - for (; !g.done; m++, g = i.next()) - null !== (g = f(r, g.value, s)) && - ((a = l(g, a, m)), - null === D ? (c = g) : (D.sibling = g), - (D = g)); - return ro && Zr(r, m), c; - } - for (h = u(r, h); !g.done; m++, g = i.next()) - null !== (g = p(h, r, m, g.value, s)) && - (e && - null !== g.alternate && - h.delete(null === g.key ? m : g.key), - (a = l(g, a, m)), - null === D ? (c = g) : (D.sibling = g), - (D = g)); - return ( - e && - h.forEach(function (e) { - return t(r, e); - }), - ro && Zr(r, m), - c - ); - } - return function e(u, o, l, i) { - if ( - ("object" === typeof l && - null !== l && - l.type === A && - null === l.key && - (l = l.props.children), - "object" === typeof l && null !== l) - ) { - switch (l.$$typeof) { - case y: - e: { - for (var s = l.key, c = o; null !== c; ) { - if (c.key === s) { - if ((s = l.type) === A) { - if (7 === c.tag) { - n(u, c.sibling), - ((o = r(c, l.props.children)).return = u), - (u = o); - break e; - } - } else if ( - c.elementType === s || - ("object" === typeof s && - null !== s && - s.$$typeof === _ && - Co(s) === c.type) - ) { - n(u, c.sibling), - ((o = r(c, l.props)).ref = Fo(u, c, l)), - (o.return = u), - (u = o); - break e; - } - n(u, c); - break; - } - t(u, c), (c = c.sibling); - } - l.type === A - ? (((o = Os(l.props.children, u.mode, i, l.key)).return = - u), - (u = o)) - : (((i = Ls( - l.type, - l.key, - l.props, - null, - u.mode, - i, - )).ref = Fo(u, o, l)), - (i.return = u), - (u = i)); - } - return a(u); - case v: - e: { - for (c = l.key; null !== o; ) { - if (o.key === c) { - if ( - 4 === o.tag && - o.stateNode.containerInfo === l.containerInfo && - o.stateNode.implementation === l.implementation - ) { - n(u, o.sibling), - ((o = r(o, l.children || [])).return = u), - (u = o); - break e; - } - n(u, o); - break; - } - t(u, o), (o = o.sibling); - } - ((o = Is(l, u.mode, i)).return = u), (u = o); - } - return a(u); - case _: - return e(u, o, (c = l._init)(l._payload), i); - } - if (te(l)) return h(u, o, l, i); - if (O(l)) return m(u, o, l, i); - go(u, l); - } - return ("string" === typeof l && "" !== l) || "number" === typeof l - ? ((l = "" + l), - null !== o && 6 === o.tag - ? (n(u, o.sibling), ((o = r(o, l)).return = u), (u = o)) - : (n(u, o), ((o = zs(l, u.mode, i)).return = u), (u = o)), - a(u)) - : n(u, o); - }; - } - var yo = Eo(!0), - vo = Eo(!1), - Ao = br(null), - bo = null, - ko = null, - Bo = null; - function wo() { - Bo = ko = bo = null; - } - function xo(e) { - var t = Ao.current; - kr(Ao), (e._currentValue = t); - } - function So(e, t, n) { - for (; null !== e; ) { - var u = e.alternate; - if ( - ((e.childLanes & t) !== t - ? ((e.childLanes |= t), null !== u && (u.childLanes |= t)) - : null !== u && (u.childLanes & t) !== t && (u.childLanes |= t), - e === n) - ) - break; - e = e.return; - } - } - function Po(e, t) { - (bo = e), - (Bo = ko = null), - null !== (e = e.dependencies) && - null !== e.firstContext && - (0 !== (e.lanes & t) && (Ca = !0), (e.firstContext = null)); - } - function To(e) { - var t = e._currentValue; - if (Bo !== e) - if ( - ((e = { context: e, memoizedValue: t, next: null }), null === ko) - ) { - if (null === bo) throw Error(o(308)); - (ko = e), (bo.dependencies = { lanes: 0, firstContext: e }); - } else ko = ko.next = e; - return t; - } - var _o = null; - function No(e) { - null === _o ? (_o = [e]) : _o.push(e); - } - function Lo(e, t, n, u) { - var r = t.interleaved; - return ( - null === r - ? ((n.next = n), No(t)) - : ((n.next = r.next), (r.next = n)), - (t.interleaved = n), - Oo(e, u) - ); - } - function Oo(e, t) { - e.lanes |= t; - var n = e.alternate; - for (null !== n && (n.lanes |= t), n = e, e = e.return; null !== e; ) - (e.childLanes |= t), - null !== (n = e.alternate) && (n.childLanes |= t), - (n = e), - (e = e.return); - return 3 === n.tag ? n.stateNode : null; - } - var Ro = !1; - function zo(e) { - e.updateQueue = { - baseState: e.memoizedState, - firstBaseUpdate: null, - lastBaseUpdate: null, - shared: { pending: null, interleaved: null, lanes: 0 }, - effects: null, - }; - } - function Io(e, t) { - (e = e.updateQueue), - t.updateQueue === e && - (t.updateQueue = { - baseState: e.baseState, - firstBaseUpdate: e.firstBaseUpdate, - lastBaseUpdate: e.lastBaseUpdate, - shared: e.shared, - effects: e.effects, - }); - } - function Mo(e, t) { - return { - eventTime: e, - lane: t, - tag: 0, - payload: null, - callback: null, - next: null, - }; - } - function jo(e, t, n) { - var u = e.updateQueue; - if (null === u) return null; - if (((u = u.shared), 0 !== (2 & xi))) { - var r = u.pending; - return ( - null === r ? (t.next = t) : ((t.next = r.next), (r.next = t)), - (u.pending = t), - Oo(e, n) - ); - } - return ( - null === (r = u.interleaved) - ? ((t.next = t), No(u)) - : ((t.next = r.next), (r.next = t)), - (u.interleaved = t), - Oo(e, n) - ); - } - function Uo(e, t, n) { - if ( - null !== (t = t.updateQueue) && - ((t = t.shared), 0 !== (4194240 & n)) - ) { - var u = t.lanes; - (n |= u &= e.pendingLanes), (t.lanes = n), gt(e, n); - } - } - function Ho(e, t) { - var n = e.updateQueue, - u = e.alternate; - if (null !== u && n === (u = u.updateQueue)) { - var r = null, - o = null; - if (null !== (n = n.firstBaseUpdate)) { - do { - var l = { - eventTime: n.eventTime, - lane: n.lane, - tag: n.tag, - payload: n.payload, - callback: n.callback, - next: null, - }; - null === o ? (r = o = l) : (o = o.next = l), (n = n.next); - } while (null !== n); - null === o ? (r = o = t) : (o = o.next = t); - } else r = o = t; - return ( - (n = { - baseState: u.baseState, - firstBaseUpdate: r, - lastBaseUpdate: o, - shared: u.shared, - effects: u.effects, - }), - void (e.updateQueue = n) - ); - } - null === (e = n.lastBaseUpdate) - ? (n.firstBaseUpdate = t) - : (e.next = t), - (n.lastBaseUpdate = t); - } - function Vo(e, t, n, u) { - var r = e.updateQueue; - Ro = !1; - var o = r.firstBaseUpdate, - l = r.lastBaseUpdate, - a = r.shared.pending; - if (null !== a) { - r.shared.pending = null; - var i = a, - s = i.next; - (i.next = null), null === l ? (o = s) : (l.next = s), (l = i); - var c = e.alternate; - null !== c && - (a = (c = c.updateQueue).lastBaseUpdate) !== l && - (null === a ? (c.firstBaseUpdate = s) : (a.next = s), - (c.lastBaseUpdate = i)); - } - if (null !== o) { - var D = r.baseState; - for (l = 0, c = s = i = null, a = o; ; ) { - var f = a.lane, - d = a.eventTime; - if ((u & f) === f) { - null !== c && - (c = c.next = - { - eventTime: d, - lane: 0, - tag: a.tag, - payload: a.payload, - callback: a.callback, - next: null, - }); - e: { - var p = e, - h = a; - switch (((f = t), (d = n), h.tag)) { - case 1: - if ("function" === typeof (p = h.payload)) { - D = p.call(d, D, f); - break e; - } - D = p; - break e; - case 3: - p.flags = (-65537 & p.flags) | 128; - case 0: - if ( - null === - (f = - "function" === typeof (p = h.payload) - ? p.call(d, D, f) - : p) || - void 0 === f - ) - break e; - D = z({}, D, f); - break e; - case 2: - Ro = !0; - } - } - null !== a.callback && - 0 !== a.lane && - ((e.flags |= 64), - null === (f = r.effects) ? (r.effects = [a]) : f.push(a)); - } else - (d = { - eventTime: d, - lane: f, - tag: a.tag, - payload: a.payload, - callback: a.callback, - next: null, - }), - null === c ? ((s = c = d), (i = D)) : (c = c.next = d), - (l |= f); - if (null === (a = a.next)) { - if (null === (a = r.shared.pending)) break; - (a = (f = a).next), - (f.next = null), - (r.lastBaseUpdate = f), - (r.shared.pending = null); - } - } - if ( - (null === c && (i = D), - (r.baseState = i), - (r.firstBaseUpdate = s), - (r.lastBaseUpdate = c), - null !== (t = r.shared.interleaved)) - ) { - r = t; - do { - (l |= r.lane), (r = r.next); - } while (r !== t); - } else null === o && (r.shared.lanes = 0); - (Ri |= l), (e.lanes = l), (e.memoizedState = D); - } - } - function Wo(e, t, n) { - if (((e = t.effects), (t.effects = null), null !== e)) - for (t = 0; t < e.length; t++) { - var u = e[t], - r = u.callback; - if (null !== r) { - if (((u.callback = null), (u = n), "function" !== typeof r)) - throw Error(o(191, r)); - r.call(u); - } - } - } - var $o = {}, - qo = br($o), - Qo = br($o), - Yo = br($o); - function Ko(e) { - if (e === $o) throw Error(o(174)); - return e; - } - function Xo(e, t) { - switch ((Br(Yo, t), Br(Qo, e), Br(qo, $o), (e = t.nodeType))) { - case 9: - case 11: - t = (t = t.documentElement) ? t.namespaceURI : ie(null, ""); - break; - default: - t = ie( - (t = (e = 8 === e ? t.parentNode : t).namespaceURI || null), - (e = e.tagName), - ); - } - kr(qo), Br(qo, t); - } - function Jo() { - kr(qo), kr(Qo), kr(Yo); - } - function Zo(e) { - Ko(Yo.current); - var t = Ko(qo.current), - n = ie(t, e.type); - t !== n && (Br(Qo, e), Br(qo, n)); - } - function Go(e) { - Qo.current === e && (kr(qo), kr(Qo)); - } - var el = br(0); - function tl(e) { - for (var t = e; null !== t; ) { - if (13 === t.tag) { - var n = t.memoizedState; - if ( - null !== n && - (null === (n = n.dehydrated) || - "$?" === n.data || - "$!" === n.data) - ) - return t; - } else if (19 === t.tag && void 0 !== t.memoizedProps.revealOrder) { - if (0 !== (128 & t.flags)) return t; - } else if (null !== t.child) { - (t.child.return = t), (t = t.child); - continue; - } - if (t === e) break; - for (; null === t.sibling; ) { - if (null === t.return || t.return === e) return null; - t = t.return; - } - (t.sibling.return = t.return), (t = t.sibling); - } - return null; - } - var nl = []; - function ul() { - for (var e = 0; e < nl.length; e++) - nl[e]._workInProgressVersionPrimary = null; - nl.length = 0; - } - var rl = E.ReactCurrentDispatcher, - ol = E.ReactCurrentBatchConfig, - ll = 0, - al = null, - il = null, - sl = null, - cl = !1, - Dl = !1, - fl = 0, - dl = 0; - function pl() { - throw Error(o(321)); - } - function hl(e, t) { - if (null === t) return !1; - for (var n = 0; n < t.length && n < e.length; n++) - if (!au(e[n], t[n])) return !1; - return !0; - } - function ml(e, t, n, u, r, l) { - if ( - ((ll = l), - (al = t), - (t.memoizedState = null), - (t.updateQueue = null), - (t.lanes = 0), - (rl.current = null === e || null === e.memoizedState ? Gl : ea), - (e = n(u, r)), - Dl) - ) { - l = 0; - do { - if (((Dl = !1), (fl = 0), 25 <= l)) throw Error(o(301)); - (l += 1), - (sl = il = null), - (t.updateQueue = null), - (rl.current = ta), - (e = n(u, r)); - } while (Dl); - } - if ( - ((rl.current = Zl), - (t = null !== il && null !== il.next), - (ll = 0), - (sl = il = al = null), - (cl = !1), - t) - ) - throw Error(o(300)); - return e; - } - function Fl() { - var e = 0 !== fl; - return (fl = 0), e; - } - function gl() { - var e = { - memoizedState: null, - baseState: null, - baseQueue: null, - queue: null, - next: null, - }; - return ( - null === sl ? (al.memoizedState = sl = e) : (sl = sl.next = e), sl - ); - } - function Cl() { - if (null === il) { - var e = al.alternate; - e = null !== e ? e.memoizedState : null; - } else e = il.next; - var t = null === sl ? al.memoizedState : sl.next; - if (null !== t) (sl = t), (il = e); - else { - if (null === e) throw Error(o(310)); - (e = { - memoizedState: (il = e).memoizedState, - baseState: il.baseState, - baseQueue: il.baseQueue, - queue: il.queue, - next: null, - }), - null === sl ? (al.memoizedState = sl = e) : (sl = sl.next = e); - } - return sl; - } - function El(e, t) { - return "function" === typeof t ? t(e) : t; - } - function yl(e) { - var t = Cl(), - n = t.queue; - if (null === n) throw Error(o(311)); - n.lastRenderedReducer = e; - var u = il, - r = u.baseQueue, - l = n.pending; - if (null !== l) { - if (null !== r) { - var a = r.next; - (r.next = l.next), (l.next = a); - } - (u.baseQueue = r = l), (n.pending = null); - } - if (null !== r) { - (l = r.next), (u = u.baseState); - var i = (a = null), - s = null, - c = l; - do { - var D = c.lane; - if ((ll & D) === D) - null !== s && - (s = s.next = - { - lane: 0, - action: c.action, - hasEagerState: c.hasEagerState, - eagerState: c.eagerState, - next: null, - }), - (u = c.hasEagerState ? c.eagerState : e(u, c.action)); - else { - var f = { - lane: D, - action: c.action, - hasEagerState: c.hasEagerState, - eagerState: c.eagerState, - next: null, - }; - null === s ? ((i = s = f), (a = u)) : (s = s.next = f), - (al.lanes |= D), - (Ri |= D); - } - c = c.next; - } while (null !== c && c !== l); - null === s ? (a = u) : (s.next = i), - au(u, t.memoizedState) || (Ca = !0), - (t.memoizedState = u), - (t.baseState = a), - (t.baseQueue = s), - (n.lastRenderedState = u); - } - if (null !== (e = n.interleaved)) { - r = e; - do { - (l = r.lane), (al.lanes |= l), (Ri |= l), (r = r.next); - } while (r !== e); - } else null === r && (n.lanes = 0); - return [t.memoizedState, n.dispatch]; - } - function vl(e) { - var t = Cl(), - n = t.queue; - if (null === n) throw Error(o(311)); - n.lastRenderedReducer = e; - var u = n.dispatch, - r = n.pending, - l = t.memoizedState; - if (null !== r) { - n.pending = null; - var a = (r = r.next); - do { - (l = e(l, a.action)), (a = a.next); - } while (a !== r); - au(l, t.memoizedState) || (Ca = !0), - (t.memoizedState = l), - null === t.baseQueue && (t.baseState = l), - (n.lastRenderedState = l); - } - return [l, u]; - } - function Al() {} - function bl(e, t) { - var n = al, - u = Cl(), - r = t(), - l = !au(u.memoizedState, r); - if ( - (l && ((u.memoizedState = r), (Ca = !0)), - (u = u.queue), - Rl(wl.bind(null, n, u, e), [e]), - u.getSnapshot !== t || - l || - (null !== sl && 1 & sl.memoizedState.tag)) - ) { - if ( - ((n.flags |= 2048), - Tl(9, Bl.bind(null, n, u, r, t), void 0, null), - null === Si) - ) - throw Error(o(349)); - 0 !== (30 & ll) || kl(n, t, r); - } - return r; - } - function kl(e, t, n) { - (e.flags |= 16384), - (e = { getSnapshot: t, value: n }), - null === (t = al.updateQueue) - ? ((t = { lastEffect: null, stores: null }), - (al.updateQueue = t), - (t.stores = [e])) - : null === (n = t.stores) - ? (t.stores = [e]) - : n.push(e); - } - function Bl(e, t, n, u) { - (t.value = n), (t.getSnapshot = u), xl(t) && Sl(e); - } - function wl(e, t, n) { - return n(function () { - xl(t) && Sl(e); - }); - } - function xl(e) { - var t = e.getSnapshot; - e = e.value; - try { - var n = t(); - return !au(e, n); - } catch (u) { - return !0; - } - } - function Sl(e) { - var t = Oo(e, 1); - null !== t && ns(t, e, 1, -1); - } - function Pl(e) { - var t = gl(); - return ( - "function" === typeof e && (e = e()), - (t.memoizedState = t.baseState = e), - (e = { - pending: null, - interleaved: null, - lanes: 0, - dispatch: null, - lastRenderedReducer: El, - lastRenderedState: e, - }), - (t.queue = e), - (e = e.dispatch = Yl.bind(null, al, e)), - [t.memoizedState, e] - ); - } - function Tl(e, t, n, u) { - return ( - (e = { tag: e, create: t, destroy: n, deps: u, next: null }), - null === (t = al.updateQueue) - ? ((t = { lastEffect: null, stores: null }), - (al.updateQueue = t), - (t.lastEffect = e.next = e)) - : null === (n = t.lastEffect) - ? (t.lastEffect = e.next = e) - : ((u = n.next), - (n.next = e), - (e.next = u), - (t.lastEffect = e)), - e - ); - } - function _l() { - return Cl().memoizedState; - } - function Nl(e, t, n, u) { - var r = gl(); - (al.flags |= e), - (r.memoizedState = Tl(1 | t, n, void 0, void 0 === u ? null : u)); - } - function Ll(e, t, n, u) { - var r = Cl(); - u = void 0 === u ? null : u; - var o = void 0; - if (null !== il) { - var l = il.memoizedState; - if (((o = l.destroy), null !== u && hl(u, l.deps))) - return void (r.memoizedState = Tl(t, n, o, u)); - } - (al.flags |= e), (r.memoizedState = Tl(1 | t, n, o, u)); - } - function Ol(e, t) { - return Nl(8390656, 8, e, t); - } - function Rl(e, t) { - return Ll(2048, 8, e, t); - } - function zl(e, t) { - return Ll(4, 2, e, t); - } - function Il(e, t) { - return Ll(4, 4, e, t); - } - function Ml(e, t) { - return "function" === typeof t - ? ((e = e()), - t(e), - function () { - t(null); - }) - : null !== t && void 0 !== t - ? ((e = e()), - (t.current = e), - function () { - t.current = null; - }) - : void 0; - } - function jl(e, t, n) { - return ( - (n = null !== n && void 0 !== n ? n.concat([e]) : null), - Ll(4, 4, Ml.bind(null, t, e), n) - ); - } - function Ul() {} - function Hl(e, t) { - var n = Cl(); - t = void 0 === t ? null : t; - var u = n.memoizedState; - return null !== u && null !== t && hl(t, u[1]) - ? u[0] - : ((n.memoizedState = [e, t]), e); - } - function Vl(e, t) { - var n = Cl(); - t = void 0 === t ? null : t; - var u = n.memoizedState; - return null !== u && null !== t && hl(t, u[1]) - ? u[0] - : ((e = e()), (n.memoizedState = [e, t]), e); - } - function Wl(e, t, n) { - return 0 === (21 & ll) - ? (e.baseState && ((e.baseState = !1), (Ca = !0)), - (e.memoizedState = n)) - : (au(n, t) || - ((n = ht()), (al.lanes |= n), (Ri |= n), (e.baseState = !0)), - t); - } - function $l(e, t) { - var n = Ct; - (Ct = 0 !== n && 4 > n ? n : 4), e(!0); - var u = ol.transition; - ol.transition = {}; - try { - e(!1), t(); - } finally { - (Ct = n), (ol.transition = u); - } - } - function ql() { - return Cl().memoizedState; - } - function Ql(e, t, n) { - var u = ts(e); - if ( - ((n = { - lane: u, - action: n, - hasEagerState: !1, - eagerState: null, - next: null, - }), - Kl(e)) - ) - Xl(t, n); - else if (null !== (n = Lo(e, t, n, u))) { - ns(n, e, u, es()), Jl(n, t, u); - } - } - function Yl(e, t, n) { - var u = ts(e), - r = { - lane: u, - action: n, - hasEagerState: !1, - eagerState: null, - next: null, - }; - if (Kl(e)) Xl(t, r); - else { - var o = e.alternate; - if ( - 0 === e.lanes && - (null === o || 0 === o.lanes) && - null !== (o = t.lastRenderedReducer) - ) - try { - var l = t.lastRenderedState, - a = o(l, n); - if (((r.hasEagerState = !0), (r.eagerState = a), au(a, l))) { - var i = t.interleaved; - return ( - null === i - ? ((r.next = r), No(t)) - : ((r.next = i.next), (i.next = r)), - void (t.interleaved = r) - ); - } - } catch (s) {} - null !== (n = Lo(e, t, r, u)) && - (ns(n, e, u, (r = es())), Jl(n, t, u)); - } - } - function Kl(e) { - var t = e.alternate; - return e === al || (null !== t && t === al); - } - function Xl(e, t) { - Dl = cl = !0; - var n = e.pending; - null === n ? (t.next = t) : ((t.next = n.next), (n.next = t)), - (e.pending = t); - } - function Jl(e, t, n) { - if (0 !== (4194240 & n)) { - var u = t.lanes; - (n |= u &= e.pendingLanes), (t.lanes = n), gt(e, n); - } - } - var Zl = { - readContext: To, - useCallback: pl, - useContext: pl, - useEffect: pl, - useImperativeHandle: pl, - useInsertionEffect: pl, - useLayoutEffect: pl, - useMemo: pl, - useReducer: pl, - useRef: pl, - useState: pl, - useDebugValue: pl, - useDeferredValue: pl, - useTransition: pl, - useMutableSource: pl, - useSyncExternalStore: pl, - useId: pl, - unstable_isNewReconciler: !1, - }, - Gl = { - readContext: To, - useCallback: function (e, t) { - return (gl().memoizedState = [e, void 0 === t ? null : t]), e; - }, - useContext: To, - useEffect: Ol, - useImperativeHandle: function (e, t, n) { - return ( - (n = null !== n && void 0 !== n ? n.concat([e]) : null), - Nl(4194308, 4, Ml.bind(null, t, e), n) - ); - }, - useLayoutEffect: function (e, t) { - return Nl(4194308, 4, e, t); - }, - useInsertionEffect: function (e, t) { - return Nl(4, 2, e, t); - }, - useMemo: function (e, t) { - var n = gl(); - return ( - (t = void 0 === t ? null : t), - (e = e()), - (n.memoizedState = [e, t]), - e - ); - }, - useReducer: function (e, t, n) { - var u = gl(); - return ( - (t = void 0 !== n ? n(t) : t), - (u.memoizedState = u.baseState = t), - (e = { - pending: null, - interleaved: null, - lanes: 0, - dispatch: null, - lastRenderedReducer: e, - lastRenderedState: t, - }), - (u.queue = e), - (e = e.dispatch = Ql.bind(null, al, e)), - [u.memoizedState, e] - ); - }, - useRef: function (e) { - return (e = { current: e }), (gl().memoizedState = e); - }, - useState: Pl, - useDebugValue: Ul, - useDeferredValue: function (e) { - return (gl().memoizedState = e); - }, - useTransition: function () { - var e = Pl(!1), - t = e[0]; - return ( - (e = $l.bind(null, e[1])), (gl().memoizedState = e), [t, e] - ); - }, - useMutableSource: function () {}, - useSyncExternalStore: function (e, t, n) { - var u = al, - r = gl(); - if (ro) { - if (void 0 === n) throw Error(o(407)); - n = n(); - } else { - if (((n = t()), null === Si)) throw Error(o(349)); - 0 !== (30 & ll) || kl(u, t, n); - } - r.memoizedState = n; - var l = { value: n, getSnapshot: t }; - return ( - (r.queue = l), - Ol(wl.bind(null, u, l, e), [e]), - (u.flags |= 2048), - Tl(9, Bl.bind(null, u, l, n, t), void 0, null), - n - ); - }, - useId: function () { - var e = gl(), - t = Si.identifierPrefix; - if (ro) { - var n = Jr; - (t = - ":" + - t + - "R" + - (n = (Xr & ~(1 << (32 - lt(Xr) - 1))).toString(32) + n)), - 0 < (n = fl++) && (t += "H" + n.toString(32)), - (t += ":"); - } else t = ":" + t + "r" + (n = dl++).toString(32) + ":"; - return (e.memoizedState = t); - }, - unstable_isNewReconciler: !1, - }, - ea = { - readContext: To, - useCallback: Hl, - useContext: To, - useEffect: Rl, - useImperativeHandle: jl, - useInsertionEffect: zl, - useLayoutEffect: Il, - useMemo: Vl, - useReducer: yl, - useRef: _l, - useState: function () { - return yl(El); - }, - useDebugValue: Ul, - useDeferredValue: function (e) { - return Wl(Cl(), il.memoizedState, e); - }, - useTransition: function () { - return [yl(El)[0], Cl().memoizedState]; - }, - useMutableSource: Al, - useSyncExternalStore: bl, - useId: ql, - unstable_isNewReconciler: !1, - }, - ta = { - readContext: To, - useCallback: Hl, - useContext: To, - useEffect: Rl, - useImperativeHandle: jl, - useInsertionEffect: zl, - useLayoutEffect: Il, - useMemo: Vl, - useReducer: vl, - useRef: _l, - useState: function () { - return vl(El); - }, - useDebugValue: Ul, - useDeferredValue: function (e) { - var t = Cl(); - return null === il - ? (t.memoizedState = e) - : Wl(t, il.memoizedState, e); - }, - useTransition: function () { - return [vl(El)[0], Cl().memoizedState]; - }, - useMutableSource: Al, - useSyncExternalStore: bl, - useId: ql, - unstable_isNewReconciler: !1, - }; - function na(e, t) { - if (e && e.defaultProps) { - for (var n in ((t = z({}, t)), (e = e.defaultProps))) - void 0 === t[n] && (t[n] = e[n]); - return t; - } - return t; - } - function ua(e, t, n, u) { - (n = - null === (n = n(u, (t = e.memoizedState))) || void 0 === n - ? t - : z({}, t, n)), - (e.memoizedState = n), - 0 === e.lanes && (e.updateQueue.baseState = n); - } - var ra = { - isMounted: function (e) { - return !!(e = e._reactInternals) && He(e) === e; - }, - enqueueSetState: function (e, t, n) { - e = e._reactInternals; - var u = es(), - r = ts(e), - o = Mo(u, r); - (o.payload = t), - void 0 !== n && null !== n && (o.callback = n), - null !== (t = jo(e, o, r)) && (ns(t, e, r, u), Uo(t, e, r)); - }, - enqueueReplaceState: function (e, t, n) { - e = e._reactInternals; - var u = es(), - r = ts(e), - o = Mo(u, r); - (o.tag = 1), - (o.payload = t), - void 0 !== n && null !== n && (o.callback = n), - null !== (t = jo(e, o, r)) && (ns(t, e, r, u), Uo(t, e, r)); - }, - enqueueForceUpdate: function (e, t) { - e = e._reactInternals; - var n = es(), - u = ts(e), - r = Mo(n, u); - (r.tag = 2), - void 0 !== t && null !== t && (r.callback = t), - null !== (t = jo(e, r, u)) && (ns(t, e, u, n), Uo(t, e, u)); - }, - }; - function oa(e, t, n, u, r, o, l) { - return "function" === typeof (e = e.stateNode).shouldComponentUpdate - ? e.shouldComponentUpdate(u, o, l) - : !t.prototype || - !t.prototype.isPureReactComponent || - !iu(n, u) || - !iu(r, o); - } - function la(e, t, n) { - var u = !1, - r = wr, - o = t.contextType; - return ( - "object" === typeof o && null !== o - ? (o = To(o)) - : ((r = _r(t) ? Pr : xr.current), - (o = (u = null !== (u = t.contextTypes) && void 0 !== u) - ? Tr(e, r) - : wr)), - (t = new t(n, o)), - (e.memoizedState = - null !== t.state && void 0 !== t.state ? t.state : null), - (t.updater = ra), - (e.stateNode = t), - (t._reactInternals = e), - u && - (((e = e.stateNode).__reactInternalMemoizedUnmaskedChildContext = - r), - (e.__reactInternalMemoizedMaskedChildContext = o)), - t - ); - } - function aa(e, t, n, u) { - (e = t.state), - "function" === typeof t.componentWillReceiveProps && - t.componentWillReceiveProps(n, u), - "function" === typeof t.UNSAFE_componentWillReceiveProps && - t.UNSAFE_componentWillReceiveProps(n, u), - t.state !== e && ra.enqueueReplaceState(t, t.state, null); - } - function ia(e, t, n, u) { - var r = e.stateNode; - (r.props = n), (r.state = e.memoizedState), (r.refs = {}), zo(e); - var o = t.contextType; - "object" === typeof o && null !== o - ? (r.context = To(o)) - : ((o = _r(t) ? Pr : xr.current), (r.context = Tr(e, o))), - (r.state = e.memoizedState), - "function" === typeof (o = t.getDerivedStateFromProps) && - (ua(e, t, o, n), (r.state = e.memoizedState)), - "function" === typeof t.getDerivedStateFromProps || - "function" === typeof r.getSnapshotBeforeUpdate || - ("function" !== typeof r.UNSAFE_componentWillMount && - "function" !== typeof r.componentWillMount) || - ((t = r.state), - "function" === typeof r.componentWillMount && - r.componentWillMount(), - "function" === typeof r.UNSAFE_componentWillMount && - r.UNSAFE_componentWillMount(), - t !== r.state && ra.enqueueReplaceState(r, r.state, null), - Vo(e, n, r, u), - (r.state = e.memoizedState)), - "function" === typeof r.componentDidMount && (e.flags |= 4194308); - } - function sa(e, t) { - try { - var n = "", - u = t; - do { - (n += U(u)), (u = u.return); - } while (u); - var r = n; - } catch (o) { - r = "\nError generating stack: " + o.message + "\n" + o.stack; - } - return { value: e, source: t, stack: r, digest: null }; - } - function ca(e, t, n) { - return { - value: e, - source: null, - stack: null != n ? n : null, - digest: null != t ? t : null, - }; - } - function Da(e, t) { - try { - console.error(t.value); - } catch (n) { - setTimeout(function () { - throw n; - }); - } - } - var fa = "function" === typeof WeakMap ? WeakMap : Map; - function da(e, t, n) { - ((n = Mo(-1, n)).tag = 3), (n.payload = { element: null }); - var u = t.value; - return ( - (n.callback = function () { - Wi || ((Wi = !0), ($i = u)), Da(0, t); - }), - n - ); - } - function pa(e, t, n) { - (n = Mo(-1, n)).tag = 3; - var u = e.type.getDerivedStateFromError; - if ("function" === typeof u) { - var r = t.value; - (n.payload = function () { - return u(r); - }), - (n.callback = function () { - Da(0, t); - }); - } - var o = e.stateNode; - return ( - null !== o && - "function" === typeof o.componentDidCatch && - (n.callback = function () { - Da(0, t), - "function" !== typeof u && - (null === qi ? (qi = new Set([this])) : qi.add(this)); - var e = t.stack; - this.componentDidCatch(t.value, { - componentStack: null !== e ? e : "", - }); - }), - n - ); - } - function ha(e, t, n) { - var u = e.pingCache; - if (null === u) { - u = e.pingCache = new fa(); - var r = new Set(); - u.set(t, r); - } else void 0 === (r = u.get(t)) && ((r = new Set()), u.set(t, r)); - r.has(n) || (r.add(n), (e = ks.bind(null, e, t, n)), t.then(e, e)); - } - function ma(e) { - do { - var t; - if ( - ((t = 13 === e.tag) && - (t = null === (t = e.memoizedState) || null !== t.dehydrated), - t) - ) - return e; - e = e.return; - } while (null !== e); - return null; - } - function Fa(e, t, n, u, r) { - return 0 === (1 & e.mode) - ? (e === t - ? (e.flags |= 65536) - : ((e.flags |= 128), - (n.flags |= 131072), - (n.flags &= -52805), - 1 === n.tag && - (null === n.alternate - ? (n.tag = 17) - : (((t = Mo(-1, 1)).tag = 2), jo(n, t, 1))), - (n.lanes |= 1)), - e) - : ((e.flags |= 65536), (e.lanes = r), e); - } - var ga = E.ReactCurrentOwner, - Ca = !1; - function Ea(e, t, n, u) { - t.child = null === e ? vo(t, null, n, u) : yo(t, e.child, n, u); - } - function ya(e, t, n, u, r) { - n = n.render; - var o = t.ref; - return ( - Po(t, r), - (u = ml(e, t, n, u, o, r)), - (n = Fl()), - null === e || Ca - ? (ro && n && eo(t), (t.flags |= 1), Ea(e, t, u, r), t.child) - : ((t.updateQueue = e.updateQueue), - (t.flags &= -2053), - (e.lanes &= ~r), - Wa(e, t, r)) - ); - } - function va(e, t, n, u, r) { - if (null === e) { - var o = n.type; - return "function" !== typeof o || - _s(o) || - void 0 !== o.defaultProps || - null !== n.compare || - void 0 !== n.defaultProps - ? (((e = Ls(n.type, null, u, t, t.mode, r)).ref = t.ref), - (e.return = t), - (t.child = e)) - : ((t.tag = 15), (t.type = o), Aa(e, t, o, u, r)); - } - if (((o = e.child), 0 === (e.lanes & r))) { - var l = o.memoizedProps; - if ( - (n = null !== (n = n.compare) ? n : iu)(l, u) && - e.ref === t.ref - ) - return Wa(e, t, r); - } - return ( - (t.flags |= 1), - ((e = Ns(o, u)).ref = t.ref), - (e.return = t), - (t.child = e) - ); - } - function Aa(e, t, n, u, r) { - if (null !== e) { - var o = e.memoizedProps; - if (iu(o, u) && e.ref === t.ref) { - if (((Ca = !1), (t.pendingProps = u = o), 0 === (e.lanes & r))) - return (t.lanes = e.lanes), Wa(e, t, r); - 0 !== (131072 & e.flags) && (Ca = !0); - } - } - return Ba(e, t, n, u, r); - } - function ba(e, t, n) { - var u = t.pendingProps, - r = u.children, - o = null !== e ? e.memoizedState : null; - if ("hidden" === u.mode) - if (0 === (1 & t.mode)) - (t.memoizedState = { - baseLanes: 0, - cachePool: null, - transitions: null, - }), - Br(Ni, _i), - (_i |= n); - else { - if (0 === (1073741824 & n)) - return ( - (e = null !== o ? o.baseLanes | n : n), - (t.lanes = t.childLanes = 1073741824), - (t.memoizedState = { - baseLanes: e, - cachePool: null, - transitions: null, - }), - (t.updateQueue = null), - Br(Ni, _i), - (_i |= e), - null - ); - (t.memoizedState = { - baseLanes: 0, - cachePool: null, - transitions: null, - }), - (u = null !== o ? o.baseLanes : n), - Br(Ni, _i), - (_i |= u); - } - else - null !== o - ? ((u = o.baseLanes | n), (t.memoizedState = null)) - : (u = n), - Br(Ni, _i), - (_i |= u); - return Ea(e, t, r, n), t.child; - } - function ka(e, t) { - var n = t.ref; - ((null === e && null !== n) || (null !== e && e.ref !== n)) && - ((t.flags |= 512), (t.flags |= 2097152)); - } - function Ba(e, t, n, u, r) { - var o = _r(n) ? Pr : xr.current; - return ( - (o = Tr(t, o)), - Po(t, r), - (n = ml(e, t, n, u, o, r)), - (u = Fl()), - null === e || Ca - ? (ro && u && eo(t), (t.flags |= 1), Ea(e, t, n, r), t.child) - : ((t.updateQueue = e.updateQueue), - (t.flags &= -2053), - (e.lanes &= ~r), - Wa(e, t, r)) - ); - } - function wa(e, t, n, u, r) { - if (_r(n)) { - var o = !0; - Rr(t); - } else o = !1; - if ((Po(t, r), null === t.stateNode)) - Va(e, t), la(t, n, u), ia(t, n, u, r), (u = !0); - else if (null === e) { - var l = t.stateNode, - a = t.memoizedProps; - l.props = a; - var i = l.context, - s = n.contextType; - "object" === typeof s && null !== s - ? (s = To(s)) - : (s = Tr(t, (s = _r(n) ? Pr : xr.current))); - var c = n.getDerivedStateFromProps, - D = - "function" === typeof c || - "function" === typeof l.getSnapshotBeforeUpdate; - D || - ("function" !== typeof l.UNSAFE_componentWillReceiveProps && - "function" !== typeof l.componentWillReceiveProps) || - ((a !== u || i !== s) && aa(t, l, u, s)), - (Ro = !1); - var f = t.memoizedState; - (l.state = f), - Vo(t, u, l, r), - (i = t.memoizedState), - a !== u || f !== i || Sr.current || Ro - ? ("function" === typeof c && - (ua(t, n, c, u), (i = t.memoizedState)), - (a = Ro || oa(t, n, a, u, f, i, s)) - ? (D || - ("function" !== typeof l.UNSAFE_componentWillMount && - "function" !== typeof l.componentWillMount) || - ("function" === typeof l.componentWillMount && - l.componentWillMount(), - "function" === typeof l.UNSAFE_componentWillMount && - l.UNSAFE_componentWillMount()), - "function" === typeof l.componentDidMount && - (t.flags |= 4194308)) - : ("function" === typeof l.componentDidMount && - (t.flags |= 4194308), - (t.memoizedProps = u), - (t.memoizedState = i)), - (l.props = u), - (l.state = i), - (l.context = s), - (u = a)) - : ("function" === typeof l.componentDidMount && - (t.flags |= 4194308), - (u = !1)); - } else { - (l = t.stateNode), - Io(e, t), - (a = t.memoizedProps), - (s = t.type === t.elementType ? a : na(t.type, a)), - (l.props = s), - (D = t.pendingProps), - (f = l.context), - "object" === typeof (i = n.contextType) && null !== i - ? (i = To(i)) - : (i = Tr(t, (i = _r(n) ? Pr : xr.current))); - var d = n.getDerivedStateFromProps; - (c = - "function" === typeof d || - "function" === typeof l.getSnapshotBeforeUpdate) || - ("function" !== typeof l.UNSAFE_componentWillReceiveProps && - "function" !== typeof l.componentWillReceiveProps) || - ((a !== D || f !== i) && aa(t, l, u, i)), - (Ro = !1), - (f = t.memoizedState), - (l.state = f), - Vo(t, u, l, r); - var p = t.memoizedState; - a !== D || f !== p || Sr.current || Ro - ? ("function" === typeof d && - (ua(t, n, d, u), (p = t.memoizedState)), - (s = Ro || oa(t, n, s, u, f, p, i) || !1) - ? (c || - ("function" !== typeof l.UNSAFE_componentWillUpdate && - "function" !== typeof l.componentWillUpdate) || - ("function" === typeof l.componentWillUpdate && - l.componentWillUpdate(u, p, i), - "function" === typeof l.UNSAFE_componentWillUpdate && - l.UNSAFE_componentWillUpdate(u, p, i)), - "function" === typeof l.componentDidUpdate && - (t.flags |= 4), - "function" === typeof l.getSnapshotBeforeUpdate && - (t.flags |= 1024)) - : ("function" !== typeof l.componentDidUpdate || - (a === e.memoizedProps && f === e.memoizedState) || - (t.flags |= 4), - "function" !== typeof l.getSnapshotBeforeUpdate || - (a === e.memoizedProps && f === e.memoizedState) || - (t.flags |= 1024), - (t.memoizedProps = u), - (t.memoizedState = p)), - (l.props = u), - (l.state = p), - (l.context = i), - (u = s)) - : ("function" !== typeof l.componentDidUpdate || - (a === e.memoizedProps && f === e.memoizedState) || - (t.flags |= 4), - "function" !== typeof l.getSnapshotBeforeUpdate || - (a === e.memoizedProps && f === e.memoizedState) || - (t.flags |= 1024), - (u = !1)); - } - return xa(e, t, n, u, o, r); - } - function xa(e, t, n, u, r, o) { - ka(e, t); - var l = 0 !== (128 & t.flags); - if (!u && !l) return r && zr(t, n, !1), Wa(e, t, o); - (u = t.stateNode), (ga.current = t); - var a = - l && "function" !== typeof n.getDerivedStateFromError - ? null - : u.render(); - return ( - (t.flags |= 1), - null !== e && l - ? ((t.child = yo(t, e.child, null, o)), - (t.child = yo(t, null, a, o))) - : Ea(e, t, a, o), - (t.memoizedState = u.state), - r && zr(t, n, !0), - t.child - ); - } - function Sa(e) { - var t = e.stateNode; - t.pendingContext - ? Lr(0, t.pendingContext, t.pendingContext !== t.context) - : t.context && Lr(0, t.context, !1), - Xo(e, t.containerInfo); - } - function Pa(e, t, n, u, r) { - return po(), ho(r), (t.flags |= 256), Ea(e, t, n, u), t.child; - } - var Ta, - _a, - Na, - La, - Oa = { dehydrated: null, treeContext: null, retryLane: 0 }; - function Ra(e) { - return { baseLanes: e, cachePool: null, transitions: null }; - } - function za(e, t, n) { - var u, - r = t.pendingProps, - l = el.current, - a = !1, - i = 0 !== (128 & t.flags); - if ( - ((u = i) || - (u = (null === e || null !== e.memoizedState) && 0 !== (2 & l)), - u - ? ((a = !0), (t.flags &= -129)) - : (null !== e && null === e.memoizedState) || (l |= 1), - Br(el, 1 & l), - null === e) - ) - return ( - so(t), - null !== (e = t.memoizedState) && null !== (e = e.dehydrated) - ? (0 === (1 & t.mode) - ? (t.lanes = 1) - : "$!" === e.data - ? (t.lanes = 8) - : (t.lanes = 1073741824), - null) - : ((i = r.children), - (e = r.fallback), - a - ? ((r = t.mode), - (a = t.child), - (i = { mode: "hidden", children: i }), - 0 === (1 & r) && null !== a - ? ((a.childLanes = 0), (a.pendingProps = i)) - : (a = Rs(i, r, 0, null)), - (e = Os(e, r, n, null)), - (a.return = t), - (e.return = t), - (a.sibling = e), - (t.child = a), - (t.child.memoizedState = Ra(n)), - (t.memoizedState = Oa), - e) - : Ia(t, i)) - ); - if (null !== (l = e.memoizedState) && null !== (u = l.dehydrated)) - return (function (e, t, n, u, r, l, a) { - if (n) - return 256 & t.flags - ? ((t.flags &= -257), Ma(e, t, a, (u = ca(Error(o(422)))))) - : null !== t.memoizedState - ? ((t.child = e.child), (t.flags |= 128), null) - : ((l = u.fallback), - (r = t.mode), - (u = Rs( - { mode: "visible", children: u.children }, - r, - 0, - null, - )), - ((l = Os(l, r, a, null)).flags |= 2), - (u.return = t), - (l.return = t), - (u.sibling = l), - (t.child = u), - 0 !== (1 & t.mode) && yo(t, e.child, null, a), - (t.child.memoizedState = Ra(a)), - (t.memoizedState = Oa), - l); - if (0 === (1 & t.mode)) return Ma(e, t, a, null); - if ("$!" === r.data) { - if ((u = r.nextSibling && r.nextSibling.dataset)) - var i = u.dgst; - return ( - (u = i), Ma(e, t, a, (u = ca((l = Error(o(419))), u, void 0))) - ); - } - if (((i = 0 !== (a & e.childLanes)), Ca || i)) { - if (null !== (u = Si)) { - switch (a & -a) { - case 4: - r = 2; - break; - case 16: - r = 8; - break; - case 64: - case 128: - case 256: - case 512: - case 1024: - case 2048: - case 4096: - case 8192: - case 16384: - case 32768: - case 65536: - case 131072: - case 262144: - case 524288: - case 1048576: - case 2097152: - case 4194304: - case 8388608: - case 16777216: - case 33554432: - case 67108864: - r = 32; - break; - case 536870912: - r = 268435456; - break; - default: - r = 0; - } - 0 !== (r = 0 !== (r & (u.suspendedLanes | a)) ? 0 : r) && - r !== l.retryLane && - ((l.retryLane = r), Oo(e, r), ns(u, e, r, -1)); - } - return hs(), Ma(e, t, a, (u = ca(Error(o(421))))); - } - return "$?" === r.data - ? ((t.flags |= 128), - (t.child = e.child), - (t = ws.bind(null, e)), - (r._reactRetry = t), - null) - : ((e = l.treeContext), - (uo = sr(r.nextSibling)), - (no = t), - (ro = !0), - (oo = null), - null !== e && - ((Qr[Yr++] = Xr), - (Qr[Yr++] = Jr), - (Qr[Yr++] = Kr), - (Xr = e.id), - (Jr = e.overflow), - (Kr = t)), - (t = Ia(t, u.children)), - (t.flags |= 4096), - t); - })(e, t, i, r, u, l, n); - if (a) { - (a = r.fallback), (i = t.mode), (u = (l = e.child).sibling); - var s = { mode: "hidden", children: r.children }; - return ( - 0 === (1 & i) && t.child !== l - ? (((r = t.child).childLanes = 0), - (r.pendingProps = s), - (t.deletions = null)) - : ((r = Ns(l, s)).subtreeFlags = 14680064 & l.subtreeFlags), - null !== u - ? (a = Ns(u, a)) - : ((a = Os(a, i, n, null)).flags |= 2), - (a.return = t), - (r.return = t), - (r.sibling = a), - (t.child = r), - (r = a), - (a = t.child), - (i = - null === (i = e.child.memoizedState) - ? Ra(n) - : { - baseLanes: i.baseLanes | n, - cachePool: null, - transitions: i.transitions, - }), - (a.memoizedState = i), - (a.childLanes = e.childLanes & ~n), - (t.memoizedState = Oa), - r - ); - } - return ( - (e = (a = e.child).sibling), - (r = Ns(a, { mode: "visible", children: r.children })), - 0 === (1 & t.mode) && (r.lanes = n), - (r.return = t), - (r.sibling = null), - null !== e && - (null === (n = t.deletions) - ? ((t.deletions = [e]), (t.flags |= 16)) - : n.push(e)), - (t.child = r), - (t.memoizedState = null), - r - ); - } - function Ia(e, t) { - return ( - ((t = Rs( - { mode: "visible", children: t }, - e.mode, - 0, - null, - )).return = e), - (e.child = t) - ); - } - function Ma(e, t, n, u) { - return ( - null !== u && ho(u), - yo(t, e.child, null, n), - ((e = Ia(t, t.pendingProps.children)).flags |= 2), - (t.memoizedState = null), - e - ); - } - function ja(e, t, n) { - e.lanes |= t; - var u = e.alternate; - null !== u && (u.lanes |= t), So(e.return, t, n); - } - function Ua(e, t, n, u, r) { - var o = e.memoizedState; - null === o - ? (e.memoizedState = { - isBackwards: t, - rendering: null, - renderingStartTime: 0, - last: u, - tail: n, - tailMode: r, - }) - : ((o.isBackwards = t), - (o.rendering = null), - (o.renderingStartTime = 0), - (o.last = u), - (o.tail = n), - (o.tailMode = r)); - } - function Ha(e, t, n) { - var u = t.pendingProps, - r = u.revealOrder, - o = u.tail; - if ((Ea(e, t, u.children, n), 0 !== (2 & (u = el.current)))) - (u = (1 & u) | 2), (t.flags |= 128); - else { - if (null !== e && 0 !== (128 & e.flags)) - e: for (e = t.child; null !== e; ) { - if (13 === e.tag) null !== e.memoizedState && ja(e, n, t); - else if (19 === e.tag) ja(e, n, t); - else if (null !== e.child) { - (e.child.return = e), (e = e.child); - continue; - } - if (e === t) break e; - for (; null === e.sibling; ) { - if (null === e.return || e.return === t) break e; - e = e.return; - } - (e.sibling.return = e.return), (e = e.sibling); - } - u &= 1; - } - if ((Br(el, u), 0 === (1 & t.mode))) t.memoizedState = null; - else - switch (r) { - case "forwards": - for (n = t.child, r = null; null !== n; ) - null !== (e = n.alternate) && null === tl(e) && (r = n), - (n = n.sibling); - null === (n = r) - ? ((r = t.child), (t.child = null)) - : ((r = n.sibling), (n.sibling = null)), - Ua(t, !1, r, n, o); - break; - case "backwards": - for (n = null, r = t.child, t.child = null; null !== r; ) { - if (null !== (e = r.alternate) && null === tl(e)) { - t.child = r; - break; - } - (e = r.sibling), (r.sibling = n), (n = r), (r = e); - } - Ua(t, !0, n, null, o); - break; - case "together": - Ua(t, !1, null, null, void 0); - break; - default: - t.memoizedState = null; - } - return t.child; - } - function Va(e, t) { - 0 === (1 & t.mode) && - null !== e && - ((e.alternate = null), (t.alternate = null), (t.flags |= 2)); - } - function Wa(e, t, n) { - if ( - (null !== e && (t.dependencies = e.dependencies), - (Ri |= t.lanes), - 0 === (n & t.childLanes)) - ) - return null; - if (null !== e && t.child !== e.child) throw Error(o(153)); - if (null !== t.child) { - for ( - n = Ns((e = t.child), e.pendingProps), t.child = n, n.return = t; - null !== e.sibling; - - ) - (e = e.sibling), - ((n = n.sibling = Ns(e, e.pendingProps)).return = t); - n.sibling = null; - } - return t.child; - } - function $a(e, t) { - if (!ro) - switch (e.tailMode) { - case "hidden": - t = e.tail; - for (var n = null; null !== t; ) - null !== t.alternate && (n = t), (t = t.sibling); - null === n ? (e.tail = null) : (n.sibling = null); - break; - case "collapsed": - n = e.tail; - for (var u = null; null !== n; ) - null !== n.alternate && (u = n), (n = n.sibling); - null === u - ? t || null === e.tail - ? (e.tail = null) - : (e.tail.sibling = null) - : (u.sibling = null); - } - } - function qa(e) { - var t = null !== e.alternate && e.alternate.child === e.child, - n = 0, - u = 0; - if (t) - for (var r = e.child; null !== r; ) - (n |= r.lanes | r.childLanes), - (u |= 14680064 & r.subtreeFlags), - (u |= 14680064 & r.flags), - (r.return = e), - (r = r.sibling); - else - for (r = e.child; null !== r; ) - (n |= r.lanes | r.childLanes), - (u |= r.subtreeFlags), - (u |= r.flags), - (r.return = e), - (r = r.sibling); - return (e.subtreeFlags |= u), (e.childLanes = n), t; - } - function Qa(e, t, n) { - var u = t.pendingProps; - switch ((to(t), t.tag)) { - case 2: - case 16: - case 15: - case 0: - case 11: - case 7: - case 8: - case 12: - case 9: - case 14: - return qa(t), null; - case 1: - case 17: - return _r(t.type) && Nr(), qa(t), null; - case 3: - return ( - (u = t.stateNode), - Jo(), - kr(Sr), - kr(xr), - ul(), - u.pendingContext && - ((u.context = u.pendingContext), (u.pendingContext = null)), - (null !== e && null !== e.child) || - (Do(t) - ? (t.flags |= 4) - : null === e || - (e.memoizedState.isDehydrated && 0 === (256 & t.flags)) || - ((t.flags |= 1024), - null !== oo && (ls(oo), (oo = null)))), - _a(e, t), - qa(t), - null - ); - case 5: - Go(t); - var r = Ko(Yo.current); - if (((n = t.type), null !== e && null != t.stateNode)) - Na(e, t, n, u, r), - e.ref !== t.ref && ((t.flags |= 512), (t.flags |= 2097152)); - else { - if (!u) { - if (null === t.stateNode) throw Error(o(166)); - return qa(t), null; - } - if (((e = Ko(qo.current)), Do(t))) { - (u = t.stateNode), (n = t.type); - var l = t.memoizedProps; - switch ( - ((u[fr] = t), (u[dr] = l), (e = 0 !== (1 & t.mode)), n) - ) { - case "dialog": - Mu("cancel", u), Mu("close", u); - break; - case "iframe": - case "object": - case "embed": - Mu("load", u); - break; - case "video": - case "audio": - for (r = 0; r < Ou.length; r++) Mu(Ou[r], u); - break; - case "source": - Mu("error", u); - break; - case "img": - case "image": - case "link": - Mu("error", u), Mu("load", u); - break; - case "details": - Mu("toggle", u); - break; - case "input": - X(u, l), Mu("invalid", u); - break; - case "select": - (u._wrapperState = { wasMultiple: !!l.multiple }), - Mu("invalid", u); - break; - case "textarea": - re(u, l), Mu("invalid", u); - } - for (var i in (ge(n, l), (r = null), l)) - if (l.hasOwnProperty(i)) { - var s = l[i]; - "children" === i - ? "string" === typeof s - ? u.textContent !== s && - (!0 !== l.suppressHydrationWarning && - Zu(u.textContent, s, e), - (r = ["children", s])) - : "number" === typeof s && - u.textContent !== "" + s && - (!0 !== l.suppressHydrationWarning && - Zu(u.textContent, s, e), - (r = ["children", "" + s])) - : a.hasOwnProperty(i) && - null != s && - "onScroll" === i && - Mu("scroll", u); - } - switch (n) { - case "input": - q(u), G(u, l, !0); - break; - case "textarea": - q(u), le(u); - break; - case "select": - case "option": - break; - default: - "function" === typeof l.onClick && (u.onclick = Gu); - } - (u = r), (t.updateQueue = u), null !== u && (t.flags |= 4); - } else { - (i = 9 === r.nodeType ? r : r.ownerDocument), - "http://www.w3.org/1999/xhtml" === e && (e = ae(n)), - "http://www.w3.org/1999/xhtml" === e - ? "script" === n - ? (((e = i.createElement("div")).innerHTML = - "\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationRawTagOpen(code) {\n if (code === 47) {\n effects.consume(code);\n buffer = '';\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In raw continuation, after ` | \n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function continuationRawEndTag(code) {\n if (code === 62) {\n const name = buffer.toLowerCase();\n if (htmlRawNames.includes(name)) {\n effects.consume(code);\n return continuationClose;\n }\n return continuation(code);\n }\n if (asciiAlpha(code) && buffer.length < 8) {\n // Always the case.\n effects.consume(code);\n buffer += String.fromCharCode(code);\n return continuationRawEndTag;\n }\n return continuation(code);\n }\n\n /**\n * In cdata continuation, after `]`, expecting `]>`.\n *\n * ```markdown\n * > | &<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationCdataInside(code) {\n if (code === 93) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In declaration or instruction continuation, at `>`.\n *\n * ```markdown\n * > | \n * ^\n * > | \n * ^\n * > | \n * ^\n * > | \n * ^\n * > | &<]]>\n * ^\n * ```\n *\n * @type {State}\n */\n function continuationDeclarationInside(code) {\n if (code === 62) {\n effects.consume(code);\n return continuationClose;\n }\n\n // More dashes.\n if (code === 45 && marker === 2) {\n effects.consume(code);\n return continuationDeclarationInside;\n }\n return continuation(code);\n }\n\n /**\n * In closed continuation: everything we get until the eol/eof is part of it.\n *\n * ```markdown\n * > | \n * ^\n * ```\n *\n * @type {State}\n */\n function continuationClose(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"htmlFlowData\");\n return continuationAfter(code);\n }\n effects.consume(code);\n return continuationClose;\n }\n\n /**\n * Done.\n *\n * ```markdown\n * > | \n * ^\n * ```\n *\n * @type {State}\n */\n function continuationAfter(code) {\n effects.exit(\"htmlFlow\");\n // // Feel free to interrupt.\n // tokenizer.interrupt = false\n // // No longer concrete.\n // tokenizer.concrete = false\n return ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeNonLazyContinuationStart(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * At eol, before continuation.\n *\n * ```markdown\n * > | * ```js\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * A continuation.\n *\n * ```markdown\n * | * ```js\n * > | b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n return self.parser.lazy[self.now().line] ? nok(code) : ok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeBlankLineBefore(effects, ok, nok) {\n return start;\n\n /**\n * Before eol, expecting blank line.\n *\n * ```markdown\n * > |
\n * ^\n * |\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return effects.attempt(blankLine, ok, nok);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nconst nonLazyContinuation = {\n partial: true,\n tokenize: tokenizeNonLazyContinuation\n};\n\n/** @type {Construct} */\nexport const codeFenced = {\n concrete: true,\n name: 'codeFenced',\n tokenize: tokenizeCodeFenced\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCodeFenced(effects, ok, nok) {\n const self = this;\n /** @type {Construct} */\n const closeStart = {\n partial: true,\n tokenize: tokenizeCloseStart\n };\n let initialPrefix = 0;\n let sizeOpen = 0;\n /** @type {NonNullable} */\n let marker;\n return start;\n\n /**\n * Start of code.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // To do: parse whitespace like `markdown-rs`.\n return beforeSequenceOpen(code);\n }\n\n /**\n * In opening fence, after prefix, at sequence.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function beforeSequenceOpen(code) {\n const tail = self.events[self.events.length - 1];\n initialPrefix = tail && tail[1].type === \"linePrefix\" ? tail[2].sliceSerialize(tail[1], true).length : 0;\n marker = code;\n effects.enter(\"codeFenced\");\n effects.enter(\"codeFencedFence\");\n effects.enter(\"codeFencedFenceSequence\");\n return sequenceOpen(code);\n }\n\n /**\n * In opening fence sequence.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function sequenceOpen(code) {\n if (code === marker) {\n sizeOpen++;\n effects.consume(code);\n return sequenceOpen;\n }\n if (sizeOpen < 3) {\n return nok(code);\n }\n effects.exit(\"codeFencedFenceSequence\");\n return markdownSpace(code) ? factorySpace(effects, infoBefore, \"whitespace\")(code) : infoBefore(code);\n }\n\n /**\n * In opening fence, after the sequence (and optional whitespace), before info.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function infoBefore(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"codeFencedFence\");\n return self.interrupt ? ok(code) : effects.check(nonLazyContinuation, atNonLazyBreak, after)(code);\n }\n effects.enter(\"codeFencedFenceInfo\");\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return info(code);\n }\n\n /**\n * In info.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function info(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"chunkString\");\n effects.exit(\"codeFencedFenceInfo\");\n return infoBefore(code);\n }\n if (markdownSpace(code)) {\n effects.exit(\"chunkString\");\n effects.exit(\"codeFencedFenceInfo\");\n return factorySpace(effects, metaBefore, \"whitespace\")(code);\n }\n if (code === 96 && code === marker) {\n return nok(code);\n }\n effects.consume(code);\n return info;\n }\n\n /**\n * In opening fence, after info and whitespace, before meta.\n *\n * ```markdown\n * > | ~~~js eval\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function metaBefore(code) {\n if (code === null || markdownLineEnding(code)) {\n return infoBefore(code);\n }\n effects.enter(\"codeFencedFenceMeta\");\n effects.enter(\"chunkString\", {\n contentType: \"string\"\n });\n return meta(code);\n }\n\n /**\n * In meta.\n *\n * ```markdown\n * > | ~~~js eval\n * ^\n * | alert(1)\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function meta(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"chunkString\");\n effects.exit(\"codeFencedFenceMeta\");\n return infoBefore(code);\n }\n if (code === 96 && code === marker) {\n return nok(code);\n }\n effects.consume(code);\n return meta;\n }\n\n /**\n * At eol/eof in code, before a non-lazy closing fence or content.\n *\n * ```markdown\n * > | ~~~js\n * ^\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function atNonLazyBreak(code) {\n return effects.attempt(closeStart, after, contentBefore)(code);\n }\n\n /**\n * Before code content, not a closing fence, at eol.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function contentBefore(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return contentStart;\n }\n\n /**\n * Before code content, not a closing fence.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function contentStart(code) {\n return initialPrefix > 0 && markdownSpace(code) ? factorySpace(effects, beforeContentChunk, \"linePrefix\", initialPrefix + 1)(code) : beforeContentChunk(code);\n }\n\n /**\n * Before code content, after optional prefix.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function beforeContentChunk(code) {\n if (code === null || markdownLineEnding(code)) {\n return effects.check(nonLazyContinuation, atNonLazyBreak, after)(code);\n }\n effects.enter(\"codeFlowValue\");\n return contentChunk(code);\n }\n\n /**\n * In code content.\n *\n * ```markdown\n * | ~~~js\n * > | alert(1)\n * ^^^^^^^^\n * | ~~~\n * ```\n *\n * @type {State}\n */\n function contentChunk(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"codeFlowValue\");\n return beforeContentChunk(code);\n }\n effects.consume(code);\n return contentChunk;\n }\n\n /**\n * After code.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n effects.exit(\"codeFenced\");\n return ok(code);\n }\n\n /**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\n function tokenizeCloseStart(effects, ok, nok) {\n let size = 0;\n return startBefore;\n\n /**\n *\n *\n * @type {State}\n */\n function startBefore(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return start;\n }\n\n /**\n * Before closing fence, at optional whitespace.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // Always populated by defaults.\n\n // To do: `enter` here or in next state?\n effects.enter(\"codeFencedFence\");\n return markdownSpace(code) ? factorySpace(effects, beforeSequenceClose, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code) : beforeSequenceClose(code);\n }\n\n /**\n * In closing fence, after optional whitespace, at sequence.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function beforeSequenceClose(code) {\n if (code === marker) {\n effects.enter(\"codeFencedFenceSequence\");\n return sequenceClose(code);\n }\n return nok(code);\n }\n\n /**\n * In closing fence sequence.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceClose(code) {\n if (code === marker) {\n size++;\n effects.consume(code);\n return sequenceClose;\n }\n if (size >= sizeOpen) {\n effects.exit(\"codeFencedFenceSequence\");\n return markdownSpace(code) ? factorySpace(effects, sequenceCloseAfter, \"whitespace\")(code) : sequenceCloseAfter(code);\n }\n return nok(code);\n }\n\n /**\n * After closing fence sequence, after optional whitespace.\n *\n * ```markdown\n * | ~~~js\n * | alert(1)\n * > | ~~~\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceCloseAfter(code) {\n if (code === null || markdownLineEnding(code)) {\n effects.exit(\"codeFencedFence\");\n return ok(code);\n }\n return nok(code);\n }\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeNonLazyContinuation(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n *\n *\n * @type {State}\n */\n function start(code) {\n if (code === null) {\n return nok(code);\n }\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return lineStart;\n }\n\n /**\n *\n *\n * @type {State}\n */\n function lineStart(code) {\n return self.parser.lazy[self.now().line] ? nok(code) : ok(code);\n }\n}","/// \n\n/* eslint-env browser */\n\nconst element = document.createElement('i')\n\n/**\n * @param {string} value\n * @returns {string|false}\n */\nexport function decodeNamedCharacterReference(value) {\n const characterReference = '&' + value + ';'\n element.innerHTML = characterReference\n const char = element.textContent\n\n // Some named character references do not require the closing semicolon\n // (`¬`, for instance), which leads to situations where parsing the assumed\n // named reference of `¬it;` will result in the string `Β¬it;`.\n // When we encounter a trailing semicolon after parsing, and the character\n // reference to decode was not a semicolon (`;`), we can assume that the\n // matching was not complete.\n // @ts-expect-error: TypeScript is wrong that `textContent` on elements can\n // yield `null`.\n if (char.charCodeAt(char.length - 1) === 59 /* `;` */ && value !== 'semi') {\n return false\n }\n\n // If the decoded string is equal to the input, the character reference was\n // not valid.\n // @ts-expect-error: TypeScript is wrong that `textContent` on elements can\n // yield `null`.\n return char === characterReference ? false : char\n}\n","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { asciiAlphanumeric, asciiDigit, asciiHexDigit } from 'micromark-util-character';\n/** @type {Construct} */\nexport const characterReference = {\n name: 'characterReference',\n tokenize: tokenizeCharacterReference\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCharacterReference(effects, ok, nok) {\n const self = this;\n let size = 0;\n /** @type {number} */\n let max;\n /** @type {(code: Code) => boolean} */\n let test;\n return start;\n\n /**\n * Start of character reference.\n *\n * ```markdown\n * > | a&b\n * ^\n * > | a{b\n * ^\n * > | a b\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"characterReference\");\n effects.enter(\"characterReferenceMarker\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarker\");\n return open;\n }\n\n /**\n * After `&`, at `#` for numeric references or alphanumeric for named\n * references.\n *\n * ```markdown\n * > | a&b\n * ^\n * > | a{b\n * ^\n * > | a b\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 35) {\n effects.enter(\"characterReferenceMarkerNumeric\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarkerNumeric\");\n return numeric;\n }\n effects.enter(\"characterReferenceValue\");\n max = 31;\n test = asciiAlphanumeric;\n return value(code);\n }\n\n /**\n * After `#`, at `x` for hexadecimals or digit for decimals.\n *\n * ```markdown\n * > | a{b\n * ^\n * > | a b\n * ^\n * ```\n *\n * @type {State}\n */\n function numeric(code) {\n if (code === 88 || code === 120) {\n effects.enter(\"characterReferenceMarkerHexadecimal\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarkerHexadecimal\");\n effects.enter(\"characterReferenceValue\");\n max = 6;\n test = asciiHexDigit;\n return value;\n }\n effects.enter(\"characterReferenceValue\");\n max = 7;\n test = asciiDigit;\n return value(code);\n }\n\n /**\n * After markers (`&#x`, `&#`, or `&`), in value, before `;`.\n *\n * The character reference kind defines what and how many characters are\n * allowed.\n *\n * ```markdown\n * > | a&b\n * ^^^\n * > | a{b\n * ^^^\n * > | a b\n * ^\n * ```\n *\n * @type {State}\n */\n function value(code) {\n if (code === 59 && size) {\n const token = effects.exit(\"characterReferenceValue\");\n if (test === asciiAlphanumeric && !decodeNamedCharacterReference(self.sliceSerialize(token))) {\n return nok(code);\n }\n\n // To do: `markdown-rs` uses a different name:\n // `CharacterReferenceMarkerSemi`.\n effects.enter(\"characterReferenceMarker\");\n effects.consume(code);\n effects.exit(\"characterReferenceMarker\");\n effects.exit(\"characterReference\");\n return ok;\n }\n if (test(code) && size++ < max) {\n effects.consume(code);\n return value;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { asciiPunctuation } from 'micromark-util-character';\n/** @type {Construct} */\nexport const characterEscape = {\n name: 'characterEscape',\n tokenize: tokenizeCharacterEscape\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCharacterEscape(effects, ok, nok) {\n return start;\n\n /**\n * Start of character escape.\n *\n * ```markdown\n * > | a\\*b\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"characterEscape\");\n effects.enter(\"escapeMarker\");\n effects.consume(code);\n effects.exit(\"escapeMarker\");\n return inside;\n }\n\n /**\n * After `\\`, at punctuation.\n *\n * ```markdown\n * > | a\\*b\n * ^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n // ASCII punctuation.\n if (asciiPunctuation(code)) {\n effects.enter(\"characterEscapeValue\");\n effects.consume(code);\n effects.exit(\"characterEscapeValue\");\n effects.exit(\"characterEscape\");\n return ok;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const lineEnding = {\n name: 'lineEnding',\n tokenize: tokenizeLineEnding\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLineEnding(effects, ok) {\n return start;\n\n /** @type {State} */\n function start(code) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return factorySpace(effects, ok, \"linePrefix\");\n }\n}","/**\n * @import {Event, Resolver, TokenizeContext} from 'micromark-util-types'\n */\n\n/**\n * Call all `resolveAll`s.\n *\n * @param {ReadonlyArray<{resolveAll?: Resolver | undefined}>} constructs\n * List of constructs, optionally with `resolveAll`s.\n * @param {Array} events\n * List of events.\n * @param {TokenizeContext} context\n * Context used by `tokenize`.\n * @returns {Array}\n * Changed events.\n */\nexport function resolveAll(constructs, events, context) {\n /** @type {Array} */\n const called = []\n let index = -1\n\n while (++index < constructs.length) {\n const resolve = constructs[index].resolveAll\n\n if (resolve && !called.includes(resolve)) {\n events = resolve(events, context)\n called.push(resolve)\n }\n }\n\n return events\n}\n","/**\n * @import {\n * Construct,\n * Event,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { factoryDestination } from 'micromark-factory-destination';\nimport { factoryLabel } from 'micromark-factory-label';\nimport { factoryTitle } from 'micromark-factory-title';\nimport { factoryWhitespace } from 'micromark-factory-whitespace';\nimport { markdownLineEndingOrSpace } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/** @type {Construct} */\nexport const labelEnd = {\n name: 'labelEnd',\n resolveAll: resolveAllLabelEnd,\n resolveTo: resolveToLabelEnd,\n tokenize: tokenizeLabelEnd\n};\n\n/** @type {Construct} */\nconst resourceConstruct = {\n tokenize: tokenizeResource\n};\n/** @type {Construct} */\nconst referenceFullConstruct = {\n tokenize: tokenizeReferenceFull\n};\n/** @type {Construct} */\nconst referenceCollapsedConstruct = {\n tokenize: tokenizeReferenceCollapsed\n};\n\n/** @type {Resolver} */\nfunction resolveAllLabelEnd(events) {\n let index = -1;\n /** @type {Array} */\n const newEvents = [];\n while (++index < events.length) {\n const token = events[index][1];\n newEvents.push(events[index]);\n if (token.type === \"labelImage\" || token.type === \"labelLink\" || token.type === \"labelEnd\") {\n // Remove the marker.\n const offset = token.type === \"labelImage\" ? 4 : 2;\n token.type = \"data\";\n index += offset;\n }\n }\n\n // If the events are equal, we don't have to copy newEvents to events\n if (events.length !== newEvents.length) {\n splice(events, 0, events.length, newEvents);\n }\n return events;\n}\n\n/** @type {Resolver} */\nfunction resolveToLabelEnd(events, context) {\n let index = events.length;\n let offset = 0;\n /** @type {Token} */\n let token;\n /** @type {number | undefined} */\n let open;\n /** @type {number | undefined} */\n let close;\n /** @type {Array} */\n let media;\n\n // Find an opening.\n while (index--) {\n token = events[index][1];\n if (open) {\n // If we see another link, or inactive link label, we’ve been here before.\n if (token.type === \"link\" || token.type === \"labelLink\" && token._inactive) {\n break;\n }\n\n // Mark other link openings as inactive, as we can’t have links in\n // links.\n if (events[index][0] === 'enter' && token.type === \"labelLink\") {\n token._inactive = true;\n }\n } else if (close) {\n if (events[index][0] === 'enter' && (token.type === \"labelImage\" || token.type === \"labelLink\") && !token._balanced) {\n open = index;\n if (token.type !== \"labelLink\") {\n offset = 2;\n break;\n }\n }\n } else if (token.type === \"labelEnd\") {\n close = index;\n }\n }\n const group = {\n type: events[open][1].type === \"labelLink\" ? \"link\" : \"image\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[events.length - 1][1].end\n }\n };\n const label = {\n type: \"label\",\n start: {\n ...events[open][1].start\n },\n end: {\n ...events[close][1].end\n }\n };\n const text = {\n type: \"labelText\",\n start: {\n ...events[open + offset + 2][1].end\n },\n end: {\n ...events[close - 2][1].start\n }\n };\n media = [['enter', group, context], ['enter', label, context]];\n\n // Opening marker.\n media = push(media, events.slice(open + 1, open + offset + 3));\n\n // Text open.\n media = push(media, [['enter', text, context]]);\n\n // Always populated by defaults.\n\n // Between.\n media = push(media, resolveAll(context.parser.constructs.insideSpan.null, events.slice(open + offset + 4, close - 3), context));\n\n // Text close, marker close, label close.\n media = push(media, [['exit', text, context], events[close - 2], events[close - 1], ['exit', label, context]]);\n\n // Reference, resource, or so.\n media = push(media, events.slice(close + 1));\n\n // Media close.\n media = push(media, [['exit', group, context]]);\n splice(events, open, events.length, media);\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelEnd(effects, ok, nok) {\n const self = this;\n let index = self.events.length;\n /** @type {Token} */\n let labelStart;\n /** @type {boolean} */\n let defined;\n\n // Find an opening.\n while (index--) {\n if ((self.events[index][1].type === \"labelImage\" || self.events[index][1].type === \"labelLink\") && !self.events[index][1]._balanced) {\n labelStart = self.events[index][1];\n break;\n }\n }\n return start;\n\n /**\n * Start of label end.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n // If there is not an okay opening.\n if (!labelStart) {\n return nok(code);\n }\n\n // If the corresponding label (link) start is marked as inactive,\n // it means we’d be wrapping a link, like this:\n //\n // ```markdown\n // > | a [b [c](d) e](f) g.\n // ^\n // ```\n //\n // We can’t have that, so it’s just balanced brackets.\n if (labelStart._inactive) {\n return labelEndNok(code);\n }\n defined = self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize({\n start: labelStart.end,\n end: self.now()\n })));\n effects.enter(\"labelEnd\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelEnd\");\n return after;\n }\n\n /**\n * After `]`.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // Note: `markdown-rs` also parses GFM footnotes here, which for us is in\n // an extension.\n\n // Resource (`[asd](fgh)`)?\n if (code === 40) {\n return effects.attempt(resourceConstruct, labelEndOk, defined ? labelEndOk : labelEndNok)(code);\n }\n\n // Full (`[asd][fgh]`) or collapsed (`[asd][]`) reference?\n if (code === 91) {\n return effects.attempt(referenceFullConstruct, labelEndOk, defined ? referenceNotFull : labelEndNok)(code);\n }\n\n // Shortcut (`[asd]`) reference?\n return defined ? labelEndOk(code) : labelEndNok(code);\n }\n\n /**\n * After `]`, at `[`, but not at a full reference.\n *\n * > πŸ‘‰ **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceNotFull(code) {\n return effects.attempt(referenceCollapsedConstruct, labelEndOk, labelEndNok)(code);\n }\n\n /**\n * Done, we found something.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * > | [a][b] c\n * ^\n * > | [a][] b\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndOk(code) {\n // Note: `markdown-rs` does a bunch of stuff here.\n return ok(code);\n }\n\n /**\n * Done, it’s nothing.\n *\n * There was an okay opening, but we didn’t match anything.\n *\n * ```markdown\n * > | [a](b c\n * ^\n * > | [a][b c\n * ^\n * > | [a] b\n * ^\n * ```\n *\n * @type {State}\n */\n function labelEndNok(code) {\n labelStart._balanced = true;\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeResource(effects, ok, nok) {\n return resourceStart;\n\n /**\n * At a resource.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceStart(code) {\n effects.enter(\"resource\");\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n return resourceBefore;\n }\n\n /**\n * In resource, after `(`, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBefore(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceOpen)(code) : resourceOpen(code);\n }\n\n /**\n * In resource, after optional whitespace, at `)` or a destination.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceOpen(code) {\n if (code === 41) {\n return resourceEnd(code);\n }\n return factoryDestination(effects, resourceDestinationAfter, resourceDestinationMissing, \"resourceDestination\", \"resourceDestinationLiteral\", \"resourceDestinationLiteralMarker\", \"resourceDestinationRaw\", \"resourceDestinationString\", 32)(code);\n }\n\n /**\n * In resource, after destination, at optional whitespace.\n *\n * ```markdown\n * > | [a](b) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceBetween)(code) : resourceEnd(code);\n }\n\n /**\n * At invalid destination.\n *\n * ```markdown\n * > | [a](<<) b\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceDestinationMissing(code) {\n return nok(code);\n }\n\n /**\n * In resource, after destination and whitespace, at `(` or title.\n *\n * ```markdown\n * > | [a](b ) c\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceBetween(code) {\n if (code === 34 || code === 39 || code === 40) {\n return factoryTitle(effects, resourceTitleAfter, nok, \"resourceTitle\", \"resourceTitleMarker\", \"resourceTitleString\")(code);\n }\n return resourceEnd(code);\n }\n\n /**\n * In resource, after title, at optional whitespace.\n *\n * ```markdown\n * > | [a](b \"c\") d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceTitleAfter(code) {\n return markdownLineEndingOrSpace(code) ? factoryWhitespace(effects, resourceEnd)(code) : resourceEnd(code);\n }\n\n /**\n * In resource, at `)`.\n *\n * ```markdown\n * > | [a](b) d\n * ^\n * ```\n *\n * @type {State}\n */\n function resourceEnd(code) {\n if (code === 41) {\n effects.enter(\"resourceMarker\");\n effects.consume(code);\n effects.exit(\"resourceMarker\");\n effects.exit(\"resource\");\n return ok;\n }\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceFull(effects, ok, nok) {\n const self = this;\n return referenceFull;\n\n /**\n * In a reference (full), at the `[`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFull(code) {\n return factoryLabel.call(self, effects, referenceFullAfter, referenceFullMissing, \"reference\", \"referenceMarker\", \"referenceString\")(code);\n }\n\n /**\n * In a reference (full), after `]`.\n *\n * ```markdown\n * > | [a][b] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullAfter(code) {\n return self.parser.defined.includes(normalizeIdentifier(self.sliceSerialize(self.events[self.events.length - 1][1]).slice(1, -1))) ? ok(code) : nok(code);\n }\n\n /**\n * In reference (full) that was missing.\n *\n * ```markdown\n * > | [a][b d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceFullMissing(code) {\n return nok(code);\n }\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeReferenceCollapsed(effects, ok, nok) {\n return referenceCollapsedStart;\n\n /**\n * In reference (collapsed), at `[`.\n *\n * > πŸ‘‰ **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedStart(code) {\n // We only attempt a collapsed label if there’s a `[`.\n\n effects.enter(\"reference\");\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n return referenceCollapsedOpen;\n }\n\n /**\n * In reference (collapsed), at `]`.\n *\n * > πŸ‘‰ **Note**: we only get here if the label is defined.\n *\n * ```markdown\n * > | [a][] d\n * ^\n * ```\n *\n * @type {State}\n */\n function referenceCollapsedOpen(code) {\n if (code === 93) {\n effects.enter(\"referenceMarker\");\n effects.consume(code);\n effects.exit(\"referenceMarker\");\n effects.exit(\"reference\");\n return ok;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartImage = {\n name: 'labelStartImage',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartImage\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartImage(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (image) start.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelImage\");\n effects.enter(\"labelImageMarker\");\n effects.consume(code);\n effects.exit(\"labelImageMarker\");\n return open;\n }\n\n /**\n * After `!`, at `[`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 91) {\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelImage\");\n return after;\n }\n return nok(code);\n }\n\n /**\n * After `![`.\n *\n * ```markdown\n * > | a ![b] c\n * ^\n * ```\n *\n * This is needed in because, when GFM footnotes are enabled, images never\n * form when started with a `^`.\n * Instead, links form:\n *\n * ```markdown\n * ![^a](b)\n *\n * ![^a][b]\n *\n * [b]: c\n * ```\n *\n * ```html\n * \n *

!^a

\n * ```\n *\n * @type {State}\n */\n function after(code) {\n // To do: use a new field to do this, this is still needed for\n // `micromark-extension-gfm-footnote`, but the `label-start-link`\n // behavior isn’t.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {Code} from 'micromark-util-types'\n */\n\nimport { markdownLineEndingOrSpace, unicodePunctuation, unicodeWhitespace } from 'micromark-util-character';\n/**\n * Classify whether a code represents whitespace, punctuation, or something\n * else.\n *\n * Used for attention (emphasis, strong), whose sequences can open or close\n * based on the class of surrounding characters.\n *\n * > πŸ‘‰ **Note**: eof (`null`) is seen as whitespace.\n *\n * @param {Code} code\n * Code.\n * @returns {typeof constants.characterGroupWhitespace | typeof constants.characterGroupPunctuation | undefined}\n * Group.\n */\nexport function classifyCharacter(code) {\n if (code === null || markdownLineEndingOrSpace(code) || unicodeWhitespace(code)) {\n return 1;\n }\n if (unicodePunctuation(code)) {\n return 2;\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * Event,\n * Point,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { push, splice } from 'micromark-util-chunked';\nimport { classifyCharacter } from 'micromark-util-classify-character';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/** @type {Construct} */\nexport const attention = {\n name: 'attention',\n resolveAll: resolveAllAttention,\n tokenize: tokenizeAttention\n};\n\n/**\n * Take all events and resolve attention to emphasis or strong.\n *\n * @type {Resolver}\n */\n// eslint-disable-next-line complexity\nfunction resolveAllAttention(events, context) {\n let index = -1;\n /** @type {number} */\n let open;\n /** @type {Token} */\n let group;\n /** @type {Token} */\n let text;\n /** @type {Token} */\n let openingSequence;\n /** @type {Token} */\n let closingSequence;\n /** @type {number} */\n let use;\n /** @type {Array} */\n let nextEvents;\n /** @type {number} */\n let offset;\n\n // Walk through all events.\n //\n // Note: performance of this is fine on an mb of normal markdown, but it’s\n // a bottleneck for malicious stuff.\n while (++index < events.length) {\n // Find a token that can close.\n if (events[index][0] === 'enter' && events[index][1].type === 'attentionSequence' && events[index][1]._close) {\n open = index;\n\n // Now walk back to find an opener.\n while (open--) {\n // Find a token that can open the closer.\n if (events[open][0] === 'exit' && events[open][1].type === 'attentionSequence' && events[open][1]._open &&\n // If the markers are the same:\n context.sliceSerialize(events[open][1]).charCodeAt(0) === context.sliceSerialize(events[index][1]).charCodeAt(0)) {\n // If the opening can close or the closing can open,\n // and the close size *is not* a multiple of three,\n // but the sum of the opening and closing size *is* multiple of three,\n // then don’t match.\n if ((events[open][1]._close || events[index][1]._open) && (events[index][1].end.offset - events[index][1].start.offset) % 3 && !((events[open][1].end.offset - events[open][1].start.offset + events[index][1].end.offset - events[index][1].start.offset) % 3)) {\n continue;\n }\n\n // Number of markers to use from the sequence.\n use = events[open][1].end.offset - events[open][1].start.offset > 1 && events[index][1].end.offset - events[index][1].start.offset > 1 ? 2 : 1;\n const start = {\n ...events[open][1].end\n };\n const end = {\n ...events[index][1].start\n };\n movePoint(start, -use);\n movePoint(end, use);\n openingSequence = {\n type: use > 1 ? \"strongSequence\" : \"emphasisSequence\",\n start,\n end: {\n ...events[open][1].end\n }\n };\n closingSequence = {\n type: use > 1 ? \"strongSequence\" : \"emphasisSequence\",\n start: {\n ...events[index][1].start\n },\n end\n };\n text = {\n type: use > 1 ? \"strongText\" : \"emphasisText\",\n start: {\n ...events[open][1].end\n },\n end: {\n ...events[index][1].start\n }\n };\n group = {\n type: use > 1 ? \"strong\" : \"emphasis\",\n start: {\n ...openingSequence.start\n },\n end: {\n ...closingSequence.end\n }\n };\n events[open][1].end = {\n ...openingSequence.start\n };\n events[index][1].start = {\n ...closingSequence.end\n };\n nextEvents = [];\n\n // If there are more markers in the opening, add them before.\n if (events[open][1].end.offset - events[open][1].start.offset) {\n nextEvents = push(nextEvents, [['enter', events[open][1], context], ['exit', events[open][1], context]]);\n }\n\n // Opening.\n nextEvents = push(nextEvents, [['enter', group, context], ['enter', openingSequence, context], ['exit', openingSequence, context], ['enter', text, context]]);\n\n // Always populated by defaults.\n\n // Between.\n nextEvents = push(nextEvents, resolveAll(context.parser.constructs.insideSpan.null, events.slice(open + 1, index), context));\n\n // Closing.\n nextEvents = push(nextEvents, [['exit', text, context], ['enter', closingSequence, context], ['exit', closingSequence, context], ['exit', group, context]]);\n\n // If there are more markers in the closing, add them after.\n if (events[index][1].end.offset - events[index][1].start.offset) {\n offset = 2;\n nextEvents = push(nextEvents, [['enter', events[index][1], context], ['exit', events[index][1], context]]);\n } else {\n offset = 0;\n }\n splice(events, open - 1, index - open + 3, nextEvents);\n index = open + nextEvents.length - offset - 2;\n break;\n }\n }\n }\n }\n\n // Remove remaining sequences.\n index = -1;\n while (++index < events.length) {\n if (events[index][1].type === 'attentionSequence') {\n events[index][1].type = 'data';\n }\n }\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeAttention(effects, ok) {\n const attentionMarkers = this.parser.constructs.attentionMarkers.null;\n const previous = this.previous;\n const before = classifyCharacter(previous);\n\n /** @type {NonNullable} */\n let marker;\n return start;\n\n /**\n * Before a sequence.\n *\n * ```markdown\n * > | **\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n marker = code;\n effects.enter('attentionSequence');\n return inside(code);\n }\n\n /**\n * In a sequence.\n *\n * ```markdown\n * > | **\n * ^^\n * ```\n *\n * @type {State}\n */\n function inside(code) {\n if (code === marker) {\n effects.consume(code);\n return inside;\n }\n const token = effects.exit('attentionSequence');\n\n // To do: next major: move this to resolver, just like `markdown-rs`.\n const after = classifyCharacter(code);\n\n // Always populated by defaults.\n\n const open = !after || after === 2 && before || attentionMarkers.includes(code);\n const close = !before || before === 2 && after || attentionMarkers.includes(previous);\n token._open = Boolean(marker === 42 ? open : open && (before || !close));\n token._close = Boolean(marker === 42 ? close : close && (after || !open));\n return ok(code);\n }\n}\n\n/**\n * Move a point a bit.\n *\n * Note: `move` only works inside lines! It’s not possible to move past other\n * chunks (replacement characters, tabs, or line endings).\n *\n * @param {Point} point\n * Point.\n * @param {number} offset\n * Amount to move.\n * @returns {undefined}\n * Nothing.\n */\nfunction movePoint(point, offset) {\n point.column += offset;\n point.offset += offset;\n point._bufferIndex += offset;\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { asciiAlphanumeric, asciiAlpha, asciiAtext, asciiControl } from 'micromark-util-character';\n/** @type {Construct} */\nexport const autolink = {\n name: 'autolink',\n tokenize: tokenizeAutolink\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeAutolink(effects, ok, nok) {\n let size = 0;\n return start;\n\n /**\n * Start of an autolink.\n *\n * ```markdown\n * > | ab\n * ^\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"autolink\");\n effects.enter(\"autolinkMarker\");\n effects.consume(code);\n effects.exit(\"autolinkMarker\");\n effects.enter(\"autolinkProtocol\");\n return open;\n }\n\n /**\n * After `<`, at protocol or atext.\n *\n * ```markdown\n * > | ab\n * ^\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (asciiAlpha(code)) {\n effects.consume(code);\n return schemeOrEmailAtext;\n }\n if (code === 64) {\n return nok(code);\n }\n return emailAtext(code);\n }\n\n /**\n * At second byte of protocol or atext.\n *\n * ```markdown\n * > | ab\n * ^\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function schemeOrEmailAtext(code) {\n // ASCII alphanumeric and `+`, `-`, and `.`.\n if (code === 43 || code === 45 || code === 46 || asciiAlphanumeric(code)) {\n // Count the previous alphabetical from `open` too.\n size = 1;\n return schemeInsideOrEmailAtext(code);\n }\n return emailAtext(code);\n }\n\n /**\n * In ambiguous protocol or atext.\n *\n * ```markdown\n * > | ab\n * ^\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function schemeInsideOrEmailAtext(code) {\n if (code === 58) {\n effects.consume(code);\n size = 0;\n return urlInside;\n }\n\n // ASCII alphanumeric and `+`, `-`, and `.`.\n if ((code === 43 || code === 45 || code === 46 || asciiAlphanumeric(code)) && size++ < 32) {\n effects.consume(code);\n return schemeInsideOrEmailAtext;\n }\n size = 0;\n return emailAtext(code);\n }\n\n /**\n * After protocol, in URL.\n *\n * ```markdown\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function urlInside(code) {\n if (code === 62) {\n effects.exit(\"autolinkProtocol\");\n effects.enter(\"autolinkMarker\");\n effects.consume(code);\n effects.exit(\"autolinkMarker\");\n effects.exit(\"autolink\");\n return ok;\n }\n\n // ASCII control, space, or `<`.\n if (code === null || code === 32 || code === 60 || asciiControl(code)) {\n return nok(code);\n }\n effects.consume(code);\n return urlInside;\n }\n\n /**\n * In email atext.\n *\n * ```markdown\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function emailAtext(code) {\n if (code === 64) {\n effects.consume(code);\n return emailAtSignOrDot;\n }\n if (asciiAtext(code)) {\n effects.consume(code);\n return emailAtext;\n }\n return nok(code);\n }\n\n /**\n * In label, after at-sign or dot.\n *\n * ```markdown\n * > | ab\n * ^ ^\n * ```\n *\n * @type {State}\n */\n function emailAtSignOrDot(code) {\n return asciiAlphanumeric(code) ? emailLabel(code) : nok(code);\n }\n\n /**\n * In label, where `.` and `>` are allowed.\n *\n * ```markdown\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function emailLabel(code) {\n if (code === 46) {\n effects.consume(code);\n size = 0;\n return emailAtSignOrDot;\n }\n if (code === 62) {\n // Exit, then change the token type.\n effects.exit(\"autolinkProtocol\").type = \"autolinkEmail\";\n effects.enter(\"autolinkMarker\");\n effects.consume(code);\n effects.exit(\"autolinkMarker\");\n effects.exit(\"autolink\");\n return ok;\n }\n return emailValue(code);\n }\n\n /**\n * In label, where `.` and `>` are *not* allowed.\n *\n * Though, this is also used in `emailLabel` to parse other values.\n *\n * ```markdown\n * > | ab\n * ^\n * ```\n *\n * @type {State}\n */\n function emailValue(code) {\n // ASCII alphanumeric or `-`.\n if ((code === 45 || asciiAlphanumeric(code)) && size++ < 63) {\n const next = code === 45 ? emailValue : emailLabel;\n effects.consume(code);\n return next;\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Code,\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { factorySpace } from 'micromark-factory-space';\nimport { asciiAlphanumeric, asciiAlpha, markdownLineEndingOrSpace, markdownLineEnding, markdownSpace } from 'micromark-util-character';\n/** @type {Construct} */\nexport const htmlText = {\n name: 'htmlText',\n tokenize: tokenizeHtmlText\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHtmlText(effects, ok, nok) {\n const self = this;\n /** @type {NonNullable | undefined} */\n let marker;\n /** @type {number} */\n let index;\n /** @type {State} */\n let returnState;\n return start;\n\n /**\n * Start of HTML (text).\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"htmlText\");\n effects.enter(\"htmlTextData\");\n effects.consume(code);\n return open;\n }\n\n /**\n * After `<`, at tag name or other stuff.\n *\n * ```markdown\n * > | a c\n * ^\n * > | a c\n * ^\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function open(code) {\n if (code === 33) {\n effects.consume(code);\n return declarationOpen;\n }\n if (code === 47) {\n effects.consume(code);\n return tagCloseStart;\n }\n if (code === 63) {\n effects.consume(code);\n return instruction;\n }\n\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagOpen;\n }\n return nok(code);\n }\n\n /**\n * After ` | a c\n * ^\n * > | a c\n * ^\n * > | a &<]]> c\n * ^\n * ```\n *\n * @type {State}\n */\n function declarationOpen(code) {\n if (code === 45) {\n effects.consume(code);\n return commentOpenInside;\n }\n if (code === 91) {\n effects.consume(code);\n index = 0;\n return cdataOpenInside;\n }\n if (asciiAlpha(code)) {\n effects.consume(code);\n return declaration;\n }\n return nok(code);\n }\n\n /**\n * In a comment, after ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentOpenInside(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return nok(code);\n }\n\n /**\n * In comment.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function comment(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 45) {\n effects.consume(code);\n return commentClose;\n }\n if (markdownLineEnding(code)) {\n returnState = comment;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return comment;\n }\n\n /**\n * In comment, after `-`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentClose(code) {\n if (code === 45) {\n effects.consume(code);\n return commentEnd;\n }\n return comment(code);\n }\n\n /**\n * In comment, after `--`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function commentEnd(code) {\n return code === 62 ? end(code) : code === 45 ? commentClose(code) : comment(code);\n }\n\n /**\n * After ` | a &<]]> b\n * ^^^^^^\n * ```\n *\n * @type {State}\n */\n function cdataOpenInside(code) {\n const value = \"CDATA[\";\n if (code === value.charCodeAt(index++)) {\n effects.consume(code);\n return index === value.length ? cdata : cdataOpenInside;\n }\n return nok(code);\n }\n\n /**\n * In CDATA.\n *\n * ```markdown\n * > | a &<]]> b\n * ^^^\n * ```\n *\n * @type {State}\n */\n function cdata(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataClose;\n }\n if (markdownLineEnding(code)) {\n returnState = cdata;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return cdata;\n }\n\n /**\n * In CDATA, after `]`, at another `]`.\n *\n * ```markdown\n * > | a &<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataClose(code) {\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In CDATA, after `]]`, at `>`.\n *\n * ```markdown\n * > | a &<]]> b\n * ^\n * ```\n *\n * @type {State}\n */\n function cdataEnd(code) {\n if (code === 62) {\n return end(code);\n }\n if (code === 93) {\n effects.consume(code);\n return cdataEnd;\n }\n return cdata(code);\n }\n\n /**\n * In declaration.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function declaration(code) {\n if (code === null || code === 62) {\n return end(code);\n }\n if (markdownLineEnding(code)) {\n returnState = declaration;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return declaration;\n }\n\n /**\n * In instruction.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function instruction(code) {\n if (code === null) {\n return nok(code);\n }\n if (code === 63) {\n effects.consume(code);\n return instructionClose;\n }\n if (markdownLineEnding(code)) {\n returnState = instruction;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return instruction;\n }\n\n /**\n * In instruction, after `?`, at `>`.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function instructionClose(code) {\n return code === 62 ? end(code) : instruction(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseStart(code) {\n // ASCII alphabetical.\n if (asciiAlpha(code)) {\n effects.consume(code);\n return tagClose;\n }\n return nok(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagClose(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagClose;\n }\n return tagCloseBetween(code);\n }\n\n /**\n * In closing tag, after tag name.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagCloseBetween(code) {\n if (markdownLineEnding(code)) {\n returnState = tagCloseBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagCloseBetween;\n }\n return end(code);\n }\n\n /**\n * After ` | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpen(code) {\n // ASCII alphanumerical and `-`.\n if (code === 45 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpen;\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In opening tag, after tag name.\n *\n * ```markdown\n * > | a c\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenBetween(code) {\n if (code === 47) {\n effects.consume(code);\n return end;\n }\n\n // ASCII alphabetical and `:` and `_`.\n if (code === 58 || code === 95 || asciiAlpha(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenBetween;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenBetween;\n }\n return end(code);\n }\n\n /**\n * In attribute name.\n *\n * ```markdown\n * > | a d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeName(code) {\n // ASCII alphabetical and `-`, `.`, `:`, and `_`.\n if (code === 45 || code === 46 || code === 58 || code === 95 || asciiAlphanumeric(code)) {\n effects.consume(code);\n return tagOpenAttributeName;\n }\n return tagOpenAttributeNameAfter(code);\n }\n\n /**\n * After attribute name, before initializer, the end of the tag, or\n * whitespace.\n *\n * ```markdown\n * > | a d\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeNameAfter(code) {\n if (code === 61) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeNameAfter;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeNameAfter;\n }\n return tagOpenBetween(code);\n }\n\n /**\n * Before unquoted, double quoted, or single quoted attribute value, allowing\n * whitespace.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueBefore(code) {\n if (code === null || code === 60 || code === 61 || code === 62 || code === 96) {\n return nok(code);\n }\n if (code === 34 || code === 39) {\n effects.consume(code);\n marker = code;\n return tagOpenAttributeValueQuoted;\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueBefore;\n return lineEndingBefore(code);\n }\n if (markdownSpace(code)) {\n effects.consume(code);\n return tagOpenAttributeValueBefore;\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * In double or single quoted attribute value.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuoted(code) {\n if (code === marker) {\n effects.consume(code);\n marker = undefined;\n return tagOpenAttributeValueQuotedAfter;\n }\n if (code === null) {\n return nok(code);\n }\n if (markdownLineEnding(code)) {\n returnState = tagOpenAttributeValueQuoted;\n return lineEndingBefore(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueQuoted;\n }\n\n /**\n * In unquoted attribute value.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueUnquoted(code) {\n if (code === null || code === 34 || code === 39 || code === 60 || code === 61 || code === 96) {\n return nok(code);\n }\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n effects.consume(code);\n return tagOpenAttributeValueUnquoted;\n }\n\n /**\n * After double or single quoted attribute value, before whitespace or the end\n * of the tag.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function tagOpenAttributeValueQuotedAfter(code) {\n if (code === 47 || code === 62 || markdownLineEndingOrSpace(code)) {\n return tagOpenBetween(code);\n }\n return nok(code);\n }\n\n /**\n * In certain circumstances of a tag where only an `>` is allowed.\n *\n * ```markdown\n * > | a e\n * ^\n * ```\n *\n * @type {State}\n */\n function end(code) {\n if (code === 62) {\n effects.consume(code);\n effects.exit(\"htmlTextData\");\n effects.exit(\"htmlText\");\n return ok;\n }\n return nok(code);\n }\n\n /**\n * At eol.\n *\n * > πŸ‘‰ **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * > | a \n * ```\n *\n * @type {State}\n */\n function lineEndingBefore(code) {\n effects.exit(\"htmlTextData\");\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return lineEndingAfter;\n }\n\n /**\n * After eol, at optional whitespace.\n *\n * > πŸ‘‰ **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a \n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfter(code) {\n // Always populated by defaults.\n\n return markdownSpace(code) ? factorySpace(effects, lineEndingAfterPrefix, \"linePrefix\", self.parser.constructs.disable.null.includes('codeIndented') ? undefined : 4)(code) : lineEndingAfterPrefix(code);\n }\n\n /**\n * After eol, after optional whitespace.\n *\n * > πŸ‘‰ **Note**: we can’t have blank lines in text, so no need to worry about\n * > empty tokens.\n *\n * ```markdown\n * | a \n * ^\n * ```\n *\n * @type {State}\n */\n function lineEndingAfterPrefix(code) {\n effects.enter(\"htmlTextData\");\n return returnState(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { labelEnd } from './label-end.js';\n\n/** @type {Construct} */\nexport const labelStartLink = {\n name: 'labelStartLink',\n resolveAll: labelEnd.resolveAll,\n tokenize: tokenizeLabelStartLink\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeLabelStartLink(effects, ok, nok) {\n const self = this;\n return start;\n\n /**\n * Start of label (link) start.\n *\n * ```markdown\n * > | a [b] c\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"labelLink\");\n effects.enter(\"labelMarker\");\n effects.consume(code);\n effects.exit(\"labelMarker\");\n effects.exit(\"labelLink\");\n return after;\n }\n\n /** @type {State} */\n function after(code) {\n // To do: this isn’t needed in `micromark-extension-gfm-footnote`,\n // remove.\n // Hidden footnotes hook.\n /* c8 ignore next 3 */\n return code === 94 && '_hiddenFootnoteSupport' in self.parser.constructs ? nok(code) : ok(code);\n }\n}","/**\n * @import {\n * Construct,\n * State,\n * TokenizeContext,\n * Tokenizer\n * } from 'micromark-util-types'\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const hardBreakEscape = {\n name: 'hardBreakEscape',\n tokenize: tokenizeHardBreakEscape\n};\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeHardBreakEscape(effects, ok, nok) {\n return start;\n\n /**\n * Start of a hard break (escape).\n *\n * ```markdown\n * > | a\\\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"hardBreakEscape\");\n effects.consume(code);\n return after;\n }\n\n /**\n * After `\\`, at eol.\n *\n * ```markdown\n * > | a\\\n * ^\n * | b\n * ```\n *\n * @type {State}\n */\n function after(code) {\n if (markdownLineEnding(code)) {\n effects.exit(\"hardBreakEscape\");\n return ok(code);\n }\n return nok(code);\n }\n}","/**\n * @import {\n * Construct,\n * Previous,\n * Resolver,\n * State,\n * TokenizeContext,\n * Tokenizer,\n * Token\n * } from 'micromark-util-types'\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\n/** @type {Construct} */\nexport const codeText = {\n name: 'codeText',\n previous,\n resolve: resolveCodeText,\n tokenize: tokenizeCodeText\n};\n\n// To do: next major: don’t resolve, like `markdown-rs`.\n/** @type {Resolver} */\nfunction resolveCodeText(events) {\n let tailExitIndex = events.length - 4;\n let headEnterIndex = 3;\n /** @type {number} */\n let index;\n /** @type {number | undefined} */\n let enter;\n\n // If we start and end with an EOL or a space.\n if ((events[headEnterIndex][1].type === \"lineEnding\" || events[headEnterIndex][1].type === 'space') && (events[tailExitIndex][1].type === \"lineEnding\" || events[tailExitIndex][1].type === 'space')) {\n index = headEnterIndex;\n\n // And we have data.\n while (++index < tailExitIndex) {\n if (events[index][1].type === \"codeTextData\") {\n // Then we have padding.\n events[headEnterIndex][1].type = \"codeTextPadding\";\n events[tailExitIndex][1].type = \"codeTextPadding\";\n headEnterIndex += 2;\n tailExitIndex -= 2;\n break;\n }\n }\n }\n\n // Merge adjacent spaces and data.\n index = headEnterIndex - 1;\n tailExitIndex++;\n while (++index <= tailExitIndex) {\n if (enter === undefined) {\n if (index !== tailExitIndex && events[index][1].type !== \"lineEnding\") {\n enter = index;\n }\n } else if (index === tailExitIndex || events[index][1].type === \"lineEnding\") {\n events[enter][1].type = \"codeTextData\";\n if (index !== enter + 2) {\n events[enter][1].end = events[index - 1][1].end;\n events.splice(enter + 2, index - enter - 2);\n tailExitIndex -= index - enter - 2;\n index = enter + 2;\n }\n enter = undefined;\n }\n }\n return events;\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Previous}\n */\nfunction previous(code) {\n // If there is a previous code, there will always be a tail.\n return code !== 96 || this.events[this.events.length - 1][1].type === \"characterEscape\";\n}\n\n/**\n * @this {TokenizeContext}\n * Context.\n * @type {Tokenizer}\n */\nfunction tokenizeCodeText(effects, ok, nok) {\n const self = this;\n let sizeOpen = 0;\n /** @type {number} */\n let size;\n /** @type {Token} */\n let token;\n return start;\n\n /**\n * Start of code (text).\n *\n * ```markdown\n * > | `a`\n * ^\n * > | \\`a`\n * ^\n * ```\n *\n * @type {State}\n */\n function start(code) {\n effects.enter(\"codeText\");\n effects.enter(\"codeTextSequence\");\n return sequenceOpen(code);\n }\n\n /**\n * In opening sequence.\n *\n * ```markdown\n * > | `a`\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceOpen(code) {\n if (code === 96) {\n effects.consume(code);\n sizeOpen++;\n return sequenceOpen;\n }\n effects.exit(\"codeTextSequence\");\n return between(code);\n }\n\n /**\n * Between something and something else.\n *\n * ```markdown\n * > | `a`\n * ^^\n * ```\n *\n * @type {State}\n */\n function between(code) {\n // EOF.\n if (code === null) {\n return nok(code);\n }\n\n // To do: next major: don’t do spaces in resolve, but when compiling,\n // like `markdown-rs`.\n // Tabs don’t work, and virtual spaces don’t make sense.\n if (code === 32) {\n effects.enter('space');\n effects.consume(code);\n effects.exit('space');\n return between;\n }\n\n // Closing fence? Could also be data.\n if (code === 96) {\n token = effects.enter(\"codeTextSequence\");\n size = 0;\n return sequenceClose(code);\n }\n if (markdownLineEnding(code)) {\n effects.enter(\"lineEnding\");\n effects.consume(code);\n effects.exit(\"lineEnding\");\n return between;\n }\n\n // Data.\n effects.enter(\"codeTextData\");\n return data(code);\n }\n\n /**\n * In data.\n *\n * ```markdown\n * > | `a`\n * ^\n * ```\n *\n * @type {State}\n */\n function data(code) {\n if (code === null || code === 32 || code === 96 || markdownLineEnding(code)) {\n effects.exit(\"codeTextData\");\n return between(code);\n }\n effects.consume(code);\n return data;\n }\n\n /**\n * In closing sequence.\n *\n * ```markdown\n * > | `a`\n * ^\n * ```\n *\n * @type {State}\n */\n function sequenceClose(code) {\n // More.\n if (code === 96) {\n effects.consume(code);\n size++;\n return sequenceClose;\n }\n\n // Done!\n if (size === sizeOpen) {\n effects.exit(\"codeTextSequence\");\n effects.exit(\"codeText\");\n return ok(code);\n }\n\n // More or less accents: mark as data.\n token.type = \"codeTextData\";\n return data(code);\n }\n}","/**\n * @import {Extension} from 'micromark-util-types'\n */\n\nimport { attention, autolink, blockQuote, characterEscape, characterReference, codeFenced, codeIndented, codeText, definition, hardBreakEscape, headingAtx, htmlFlow, htmlText, labelEnd, labelStartImage, labelStartLink, lineEnding, list, setextUnderline, thematicBreak } from 'micromark-core-commonmark';\nimport { resolver as resolveText } from './initialize/text.js';\n\n/** @satisfies {Extension['document']} */\nexport const document = {\n [42]: list,\n [43]: list,\n [45]: list,\n [48]: list,\n [49]: list,\n [50]: list,\n [51]: list,\n [52]: list,\n [53]: list,\n [54]: list,\n [55]: list,\n [56]: list,\n [57]: list,\n [62]: blockQuote\n};\n\n/** @satisfies {Extension['contentInitial']} */\nexport const contentInitial = {\n [91]: definition\n};\n\n/** @satisfies {Extension['flowInitial']} */\nexport const flowInitial = {\n [-2]: codeIndented,\n [-1]: codeIndented,\n [32]: codeIndented\n};\n\n/** @satisfies {Extension['flow']} */\nexport const flow = {\n [35]: headingAtx,\n [42]: thematicBreak,\n [45]: [setextUnderline, thematicBreak],\n [60]: htmlFlow,\n [61]: setextUnderline,\n [95]: thematicBreak,\n [96]: codeFenced,\n [126]: codeFenced\n};\n\n/** @satisfies {Extension['string']} */\nexport const string = {\n [38]: characterReference,\n [92]: characterEscape\n};\n\n/** @satisfies {Extension['text']} */\nexport const text = {\n [-5]: lineEnding,\n [-4]: lineEnding,\n [-3]: lineEnding,\n [33]: labelStartImage,\n [38]: characterReference,\n [42]: attention,\n [60]: [autolink, htmlText],\n [91]: labelStartLink,\n [92]: [hardBreakEscape, characterEscape],\n [93]: labelEnd,\n [95]: attention,\n [96]: codeText\n};\n\n/** @satisfies {Extension['insideSpan']} */\nexport const insideSpan = {\n null: [attention, resolveText]\n};\n\n/** @satisfies {Extension['attentionMarkers']} */\nexport const attentionMarkers = {\n null: [42, 95]\n};\n\n/** @satisfies {Extension['disable']} */\nexport const disable = {\n null: []\n};","/**\n * @import {\n * Chunk,\n * Code,\n * ConstructRecord,\n * Construct,\n * Effects,\n * InitialConstruct,\n * ParseContext,\n * Point,\n * State,\n * TokenizeContext,\n * Token\n * } from 'micromark-util-types'\n */\n\n/**\n * @callback Restore\n * Restore the state.\n * @returns {undefined}\n * Nothing.\n *\n * @typedef Info\n * Info.\n * @property {Restore} restore\n * Restore.\n * @property {number} from\n * From.\n *\n * @callback ReturnHandle\n * Handle a successful run.\n * @param {Construct} construct\n * Construct.\n * @param {Info} info\n * Info.\n * @returns {undefined}\n * Nothing.\n */\n\nimport { markdownLineEnding } from 'micromark-util-character';\nimport { push, splice } from 'micromark-util-chunked';\nimport { resolveAll } from 'micromark-util-resolve-all';\n/**\n * Create a tokenizer.\n * Tokenizers deal with one type of data (e.g., containers, flow, text).\n * The parser is the object dealing with it all.\n * `initialize` works like other constructs, except that only its `tokenize`\n * function is used, in which case it doesn’t receive an `ok` or `nok`.\n * `from` can be given to set the point before the first character, although\n * when further lines are indented, they must be set with `defineSkip`.\n *\n * @param {ParseContext} parser\n * Parser.\n * @param {InitialConstruct} initialize\n * Construct.\n * @param {Omit | undefined} [from]\n * Point (optional).\n * @returns {TokenizeContext}\n * Context.\n */\nexport function createTokenizer(parser, initialize, from) {\n /** @type {Point} */\n let point = {\n _bufferIndex: -1,\n _index: 0,\n line: from && from.line || 1,\n column: from && from.column || 1,\n offset: from && from.offset || 0\n };\n /** @type {Record} */\n const columnStart = {};\n /** @type {Array} */\n const resolveAllConstructs = [];\n /** @type {Array} */\n let chunks = [];\n /** @type {Array} */\n let stack = [];\n /** @type {boolean | undefined} */\n let consumed = true;\n\n /**\n * Tools used for tokenizing.\n *\n * @type {Effects}\n */\n const effects = {\n attempt: constructFactory(onsuccessfulconstruct),\n check: constructFactory(onsuccessfulcheck),\n consume,\n enter,\n exit,\n interrupt: constructFactory(onsuccessfulcheck, {\n interrupt: true\n })\n };\n\n /**\n * State and tools for resolving and serializing.\n *\n * @type {TokenizeContext}\n */\n const context = {\n code: null,\n containerState: {},\n defineSkip,\n events: [],\n now,\n parser,\n previous: null,\n sliceSerialize,\n sliceStream,\n write\n };\n\n /**\n * The state function.\n *\n * @type {State | undefined}\n */\n let state = initialize.tokenize.call(context, effects);\n\n /**\n * Track which character we expect to be consumed, to catch bugs.\n *\n * @type {Code}\n */\n let expectedCode;\n if (initialize.resolveAll) {\n resolveAllConstructs.push(initialize);\n }\n return context;\n\n /** @type {TokenizeContext['write']} */\n function write(slice) {\n chunks = push(chunks, slice);\n main();\n\n // Exit if we’re not done, resolve might change stuff.\n if (chunks[chunks.length - 1] !== null) {\n return [];\n }\n addResult(initialize, 0);\n\n // Otherwise, resolve, and exit.\n context.events = resolveAll(resolveAllConstructs, context.events, context);\n return context.events;\n }\n\n //\n // Tools.\n //\n\n /** @type {TokenizeContext['sliceSerialize']} */\n function sliceSerialize(token, expandTabs) {\n return serializeChunks(sliceStream(token), expandTabs);\n }\n\n /** @type {TokenizeContext['sliceStream']} */\n function sliceStream(token) {\n return sliceChunks(chunks, token);\n }\n\n /** @type {TokenizeContext['now']} */\n function now() {\n // This is a hot path, so we clone manually instead of `Object.assign({}, point)`\n const {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n } = point;\n return {\n _bufferIndex,\n _index,\n line,\n column,\n offset\n };\n }\n\n /** @type {TokenizeContext['defineSkip']} */\n function defineSkip(value) {\n columnStart[value.line] = value.column;\n accountForPotentialSkip();\n }\n\n //\n // State management.\n //\n\n /**\n * Main loop (note that `_index` and `_bufferIndex` in `point` are modified by\n * `consume`).\n * Here is where we walk through the chunks, which either include strings of\n * several characters, or numerical character codes.\n * The reason to do this in a loop instead of a call is so the stack can\n * drain.\n *\n * @returns {undefined}\n * Nothing.\n */\n function main() {\n /** @type {number} */\n let chunkIndex;\n while (point._index < chunks.length) {\n const chunk = chunks[point._index];\n\n // If we’re in a buffer chunk, loop through it.\n if (typeof chunk === 'string') {\n chunkIndex = point._index;\n if (point._bufferIndex < 0) {\n point._bufferIndex = 0;\n }\n while (point._index === chunkIndex && point._bufferIndex < chunk.length) {\n go(chunk.charCodeAt(point._bufferIndex));\n }\n } else {\n go(chunk);\n }\n }\n }\n\n /**\n * Deal with one code.\n *\n * @param {Code} code\n * Code.\n * @returns {undefined}\n * Nothing.\n */\n function go(code) {\n consumed = undefined;\n expectedCode = code;\n state = state(code);\n }\n\n /** @type {Effects['consume']} */\n function consume(code) {\n if (markdownLineEnding(code)) {\n point.line++;\n point.column = 1;\n point.offset += code === -3 ? 2 : 1;\n accountForPotentialSkip();\n } else if (code !== -1) {\n point.column++;\n point.offset++;\n }\n\n // Not in a string chunk.\n if (point._bufferIndex < 0) {\n point._index++;\n } else {\n point._bufferIndex++;\n\n // At end of string chunk.\n if (point._bufferIndex ===\n // Points w/ non-negative `_bufferIndex` reference\n // strings.\n /** @type {string} */\n chunks[point._index].length) {\n point._bufferIndex = -1;\n point._index++;\n }\n }\n\n // Expose the previous character.\n context.previous = code;\n\n // Mark as consumed.\n consumed = true;\n }\n\n /** @type {Effects['enter']} */\n function enter(type, fields) {\n /** @type {Token} */\n // @ts-expect-error Patch instead of assign required fields to help GC.\n const token = fields || {};\n token.type = type;\n token.start = now();\n context.events.push(['enter', token, context]);\n stack.push(token);\n return token;\n }\n\n /** @type {Effects['exit']} */\n function exit(type) {\n const token = stack.pop();\n token.end = now();\n context.events.push(['exit', token, context]);\n return token;\n }\n\n /**\n * Use results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulconstruct(construct, info) {\n addResult(construct, info.from);\n }\n\n /**\n * Discard results.\n *\n * @type {ReturnHandle}\n */\n function onsuccessfulcheck(_, info) {\n info.restore();\n }\n\n /**\n * Factory to attempt/check/interrupt.\n *\n * @param {ReturnHandle} onreturn\n * Callback.\n * @param {{interrupt?: boolean | undefined} | undefined} [fields]\n * Fields.\n */\n function constructFactory(onreturn, fields) {\n return hook;\n\n /**\n * Handle either an object mapping codes to constructs, a list of\n * constructs, or a single construct.\n *\n * @param {Array | ConstructRecord | Construct} constructs\n * Constructs.\n * @param {State} returnState\n * State.\n * @param {State | undefined} [bogusState]\n * State.\n * @returns {State}\n * State.\n */\n function hook(constructs, returnState, bogusState) {\n /** @type {ReadonlyArray} */\n let listOfConstructs;\n /** @type {number} */\n let constructIndex;\n /** @type {Construct} */\n let currentConstruct;\n /** @type {Info} */\n let info;\n return Array.isArray(constructs) ? /* c8 ignore next 1 */\n handleListOfConstructs(constructs) : 'tokenize' in constructs ?\n // Looks like a construct.\n handleListOfConstructs([(/** @type {Construct} */constructs)]) : handleMapOfConstructs(constructs);\n\n /**\n * Handle a list of construct.\n *\n * @param {ConstructRecord} map\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleMapOfConstructs(map) {\n return start;\n\n /** @type {State} */\n function start(code) {\n const left = code !== null && map[code];\n const all = code !== null && map.null;\n const list = [\n // To do: add more extension tests.\n /* c8 ignore next 2 */\n ...(Array.isArray(left) ? left : left ? [left] : []), ...(Array.isArray(all) ? all : all ? [all] : [])];\n return handleListOfConstructs(list)(code);\n }\n }\n\n /**\n * Handle a list of construct.\n *\n * @param {ReadonlyArray} list\n * Constructs.\n * @returns {State}\n * State.\n */\n function handleListOfConstructs(list) {\n listOfConstructs = list;\n constructIndex = 0;\n if (list.length === 0) {\n return bogusState;\n }\n return handleConstruct(list[constructIndex]);\n }\n\n /**\n * Handle a single construct.\n *\n * @param {Construct} construct\n * Construct.\n * @returns {State}\n * State.\n */\n function handleConstruct(construct) {\n return start;\n\n /** @type {State} */\n function start(code) {\n // To do: not needed to store if there is no bogus state, probably?\n // Currently doesn’t work because `inspect` in document does a check\n // w/o a bogus, which doesn’t make sense. But it does seem to help perf\n // by not storing.\n info = store();\n currentConstruct = construct;\n if (!construct.partial) {\n context.currentConstruct = construct;\n }\n\n // Always populated by defaults.\n\n if (construct.name && context.parser.constructs.disable.null.includes(construct.name)) {\n return nok(code);\n }\n return construct.tokenize.call(\n // If we do have fields, create an object w/ `context` as its\n // prototype.\n // This allows a β€œlive binding”, which is needed for `interrupt`.\n fields ? Object.assign(Object.create(context), fields) : context, effects, ok, nok)(code);\n }\n }\n\n /** @type {State} */\n function ok(code) {\n consumed = true;\n onreturn(currentConstruct, info);\n return returnState;\n }\n\n /** @type {State} */\n function nok(code) {\n consumed = true;\n info.restore();\n if (++constructIndex < listOfConstructs.length) {\n return handleConstruct(listOfConstructs[constructIndex]);\n }\n return bogusState;\n }\n }\n }\n\n /**\n * @param {Construct} construct\n * Construct.\n * @param {number} from\n * From.\n * @returns {undefined}\n * Nothing.\n */\n function addResult(construct, from) {\n if (construct.resolveAll && !resolveAllConstructs.includes(construct)) {\n resolveAllConstructs.push(construct);\n }\n if (construct.resolve) {\n splice(context.events, from, context.events.length - from, construct.resolve(context.events.slice(from), context));\n }\n if (construct.resolveTo) {\n context.events = construct.resolveTo(context.events, context);\n }\n }\n\n /**\n * Store state.\n *\n * @returns {Info}\n * Info.\n */\n function store() {\n const startPoint = now();\n const startPrevious = context.previous;\n const startCurrentConstruct = context.currentConstruct;\n const startEventsIndex = context.events.length;\n const startStack = Array.from(stack);\n return {\n from: startEventsIndex,\n restore\n };\n\n /**\n * Restore state.\n *\n * @returns {undefined}\n * Nothing.\n */\n function restore() {\n point = startPoint;\n context.previous = startPrevious;\n context.currentConstruct = startCurrentConstruct;\n context.events.length = startEventsIndex;\n stack = startStack;\n accountForPotentialSkip();\n }\n }\n\n /**\n * Move the current point a bit forward in the line when it’s on a column\n * skip.\n *\n * @returns {undefined}\n * Nothing.\n */\n function accountForPotentialSkip() {\n if (point.line in columnStart && point.column < 2) {\n point.column = columnStart[point.line];\n point.offset += columnStart[point.line] - 1;\n }\n }\n}\n\n/**\n * Get the chunks from a slice of chunks in the range of a token.\n *\n * @param {ReadonlyArray} chunks\n * Chunks.\n * @param {Pick} token\n * Token.\n * @returns {Array}\n * Chunks.\n */\nfunction sliceChunks(chunks, token) {\n const startIndex = token.start._index;\n const startBufferIndex = token.start._bufferIndex;\n const endIndex = token.end._index;\n const endBufferIndex = token.end._bufferIndex;\n /** @type {Array} */\n let view;\n if (startIndex === endIndex) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view = [chunks[startIndex].slice(startBufferIndex, endBufferIndex)];\n } else {\n view = chunks.slice(startIndex, endIndex);\n if (startBufferIndex > -1) {\n const head = view[0];\n if (typeof head === 'string') {\n view[0] = head.slice(startBufferIndex);\n } else {\n view.shift();\n }\n }\n if (endBufferIndex > 0) {\n // @ts-expect-error `_bufferIndex` is used on string chunks.\n view.push(chunks[endIndex].slice(0, endBufferIndex));\n }\n }\n return view;\n}\n\n/**\n * Get the string value of a slice of chunks.\n *\n * @param {ReadonlyArray} chunks\n * Chunks.\n * @param {boolean | undefined} [expandTabs=false]\n * Whether to expand tabs (default: `false`).\n * @returns {string}\n * Result.\n */\nfunction serializeChunks(chunks, expandTabs) {\n let index = -1;\n /** @type {Array} */\n const result = [];\n /** @type {boolean | undefined} */\n let atTab;\n while (++index < chunks.length) {\n const chunk = chunks[index];\n /** @type {string} */\n let value;\n if (typeof chunk === 'string') {\n value = chunk;\n } else switch (chunk) {\n case -5:\n {\n value = \"\\r\";\n break;\n }\n case -4:\n {\n value = \"\\n\";\n break;\n }\n case -3:\n {\n value = \"\\r\" + \"\\n\";\n break;\n }\n case -2:\n {\n value = expandTabs ? \" \" : \"\\t\";\n break;\n }\n case -1:\n {\n if (!expandTabs && atTab) continue;\n value = \" \";\n break;\n }\n default:\n {\n // Currently only replacement character.\n value = String.fromCharCode(chunk);\n }\n }\n atTab = chunk === -2;\n result.push(value);\n }\n return result.join('');\n}","/**\n * @import {\n * Create,\n * FullNormalizedExtension,\n * InitialConstruct,\n * ParseContext,\n * ParseOptions\n * } from 'micromark-util-types'\n */\n\nimport { combineExtensions } from 'micromark-util-combine-extensions';\nimport { content } from './initialize/content.js';\nimport { document } from './initialize/document.js';\nimport { flow } from './initialize/flow.js';\nimport { string, text } from './initialize/text.js';\nimport * as defaultConstructs from './constructs.js';\nimport { createTokenizer } from './create-tokenizer.js';\n\n/**\n * @param {ParseOptions | null | undefined} [options]\n * Configuration (optional).\n * @returns {ParseContext}\n * Parser.\n */\nexport function parse(options) {\n const settings = options || {};\n const constructs = /** @type {FullNormalizedExtension} */\n combineExtensions([defaultConstructs, ...(settings.extensions || [])]);\n\n /** @type {ParseContext} */\n const parser = {\n constructs,\n content: create(content),\n defined: [],\n document: create(document),\n flow: create(flow),\n lazy: {},\n string: create(string),\n text: create(text)\n };\n return parser;\n\n /**\n * @param {InitialConstruct} initial\n * Construct to start with.\n * @returns {Create}\n * Create a tokenizer.\n */\n function create(initial) {\n return creator;\n /** @type {Create} */\n function creator(from) {\n return createTokenizer(parser, initial, from);\n }\n }\n}","/**\n * @import {Chunk, Code, Encoding, Value} from 'micromark-util-types'\n */\n\n/**\n * @callback Preprocessor\n * Preprocess a value.\n * @param {Value} value\n * Value.\n * @param {Encoding | null | undefined} [encoding]\n * Encoding when `value` is a typed array (optional).\n * @param {boolean | null | undefined} [end=false]\n * Whether this is the last chunk (default: `false`).\n * @returns {Array}\n * Chunks.\n */\n\nconst search = /[\\0\\t\\n\\r]/g;\n\n/**\n * @returns {Preprocessor}\n * Preprocess a value.\n */\nexport function preprocess() {\n let column = 1;\n let buffer = '';\n /** @type {boolean | undefined} */\n let start = true;\n /** @type {boolean | undefined} */\n let atCarriageReturn;\n return preprocessor;\n\n /** @type {Preprocessor} */\n // eslint-disable-next-line complexity\n function preprocessor(value, encoding, end) {\n /** @type {Array} */\n const chunks = [];\n /** @type {RegExpMatchArray | null} */\n let match;\n /** @type {number} */\n let next;\n /** @type {number} */\n let startPosition;\n /** @type {number} */\n let endPosition;\n /** @type {Code} */\n let code;\n value = buffer + (typeof value === 'string' ? value.toString() : new TextDecoder(encoding || undefined).decode(value));\n startPosition = 0;\n buffer = '';\n if (start) {\n // To do: `markdown-rs` actually parses BOMs (byte order mark).\n if (value.charCodeAt(0) === 65279) {\n startPosition++;\n }\n start = undefined;\n }\n while (startPosition < value.length) {\n search.lastIndex = startPosition;\n match = search.exec(value);\n endPosition = match && match.index !== undefined ? match.index : value.length;\n code = value.charCodeAt(endPosition);\n if (!match) {\n buffer = value.slice(startPosition);\n break;\n }\n if (code === 10 && startPosition === endPosition && atCarriageReturn) {\n chunks.push(-3);\n atCarriageReturn = undefined;\n } else {\n if (atCarriageReturn) {\n chunks.push(-5);\n atCarriageReturn = undefined;\n }\n if (startPosition < endPosition) {\n chunks.push(value.slice(startPosition, endPosition));\n column += endPosition - startPosition;\n }\n switch (code) {\n case 0:\n {\n chunks.push(65533);\n column++;\n break;\n }\n case 9:\n {\n next = Math.ceil(column / 4) * 4;\n chunks.push(-2);\n while (column++ < next) chunks.push(-1);\n break;\n }\n case 10:\n {\n chunks.push(-4);\n column = 1;\n break;\n }\n default:\n {\n atCarriageReturn = true;\n column = 1;\n }\n }\n }\n startPosition = endPosition + 1;\n }\n if (end) {\n if (atCarriageReturn) chunks.push(-5);\n if (buffer) chunks.push(buffer);\n chunks.push(null);\n }\n return chunks;\n }\n}","/**\n * Turn the number (in string form as either hexa- or plain decimal) coming from\n * a numeric character reference into a character.\n *\n * Sort of like `String.fromCodePoint(Number.parseInt(value, base))`, but makes\n * non-characters and control characters safe.\n *\n * @param {string} value\n * Value to decode.\n * @param {number} base\n * Numeric base.\n * @returns {string}\n * Character.\n */\nexport function decodeNumericCharacterReference(value, base) {\n const code = Number.parseInt(value, base);\n if (\n // C0 except for HT, LF, FF, CR, space.\n code < 9 || code === 11 || code > 13 && code < 32 ||\n // Control character (DEL) of C0, and C1 controls.\n code > 126 && code < 160 ||\n // Lone high surrogates and low surrogates.\n code > 55_295 && code < 57_344 ||\n // Noncharacters.\n code > 64_975 && code < 65_008 || /* eslint-disable no-bitwise */\n (code & 65_535) === 65_535 || (code & 65_535) === 65_534 || /* eslint-enable no-bitwise */\n // Out of range\n code > 1_114_111) {\n return \"\\uFFFD\";\n }\n return String.fromCodePoint(code);\n}","import { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nconst characterEscapeOrReference = /\\\\([!-/:-@[-`{-~])|&(#(?:\\d{1,7}|x[\\da-f]{1,6})|[\\da-z]{1,31});/gi;\n\n/**\n * Decode markdown strings (which occur in places such as fenced code info\n * strings, destinations, labels, and titles).\n *\n * The β€œstring” content type allows character escapes and -references.\n * This decodes those.\n *\n * @param {string} value\n * Value to decode.\n * @returns {string}\n * Decoded value.\n */\nexport function decodeString(value) {\n return value.replace(characterEscapeOrReference, decode);\n}\n\n/**\n * @param {string} $0\n * Match.\n * @param {string} $1\n * Character escape.\n * @param {string} $2\n * Character reference.\n * @returns {string}\n * Decoded value\n */\nfunction decode($0, $1, $2) {\n if ($1) {\n // Escape.\n return $1;\n }\n\n // Reference.\n const head = $2.charCodeAt(0);\n if (head === 35) {\n const head = $2.charCodeAt(1);\n const hex = head === 120 || head === 88;\n return decodeNumericCharacterReference($2.slice(hex ? 2 : 1), hex ? 16 : 10);\n }\n return decodeNamedCharacterReference($2) || $0;\n}","/**\n * @import {\n * Break,\n * Blockquote,\n * Code,\n * Definition,\n * Emphasis,\n * Heading,\n * Html,\n * Image,\n * InlineCode,\n * Link,\n * ListItem,\n * List,\n * Nodes,\n * Paragraph,\n * PhrasingContent,\n * ReferenceType,\n * Root,\n * Strong,\n * Text,\n * ThematicBreak\n * } from 'mdast'\n * @import {\n * Encoding,\n * Event,\n * Token,\n * Value\n * } from 'micromark-util-types'\n * @import {Point} from 'unist'\n * @import {\n * CompileContext,\n * CompileData,\n * Config,\n * Extension,\n * Handle,\n * OnEnterError,\n * Options\n * } from './types.js'\n */\n\nimport { toString } from 'mdast-util-to-string';\nimport { parse, postprocess, preprocess } from 'micromark';\nimport { decodeNumericCharacterReference } from 'micromark-util-decode-numeric-character-reference';\nimport { decodeString } from 'micromark-util-decode-string';\nimport { normalizeIdentifier } from 'micromark-util-normalize-identifier';\nimport { decodeNamedCharacterReference } from 'decode-named-character-reference';\nimport { stringifyPosition } from 'unist-util-stringify-position';\nconst own = {}.hasOwnProperty;\n\n/**\n * Turn markdown into a syntax tree.\n *\n * @overload\n * @param {Value} value\n * @param {Encoding | null | undefined} [encoding]\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @overload\n * @param {Value} value\n * @param {Options | null | undefined} [options]\n * @returns {Root}\n *\n * @param {Value} value\n * Markdown to parse.\n * @param {Encoding | Options | null | undefined} [encoding]\n * Character encoding for when `value` is `Buffer`.\n * @param {Options | null | undefined} [options]\n * Configuration.\n * @returns {Root}\n * mdast tree.\n */\nexport function fromMarkdown(value, encoding, options) {\n if (typeof encoding !== 'string') {\n options = encoding;\n encoding = undefined;\n }\n return compiler(options)(postprocess(parse(options).document().write(preprocess()(value, encoding, true))));\n}\n\n/**\n * Note this compiler only understand complete buffering, not streaming.\n *\n * @param {Options | null | undefined} [options]\n */\nfunction compiler(options) {\n /** @type {Config} */\n const config = {\n transforms: [],\n canContainEols: ['emphasis', 'fragment', 'heading', 'paragraph', 'strong'],\n enter: {\n autolink: opener(link),\n autolinkProtocol: onenterdata,\n autolinkEmail: onenterdata,\n atxHeading: opener(heading),\n blockQuote: opener(blockQuote),\n characterEscape: onenterdata,\n characterReference: onenterdata,\n codeFenced: opener(codeFlow),\n codeFencedFenceInfo: buffer,\n codeFencedFenceMeta: buffer,\n codeIndented: opener(codeFlow, buffer),\n codeText: opener(codeText, buffer),\n codeTextData: onenterdata,\n data: onenterdata,\n codeFlowValue: onenterdata,\n definition: opener(definition),\n definitionDestinationString: buffer,\n definitionLabelString: buffer,\n definitionTitleString: buffer,\n emphasis: opener(emphasis),\n hardBreakEscape: opener(hardBreak),\n hardBreakTrailing: opener(hardBreak),\n htmlFlow: opener(html, buffer),\n htmlFlowData: onenterdata,\n htmlText: opener(html, buffer),\n htmlTextData: onenterdata,\n image: opener(image),\n label: buffer,\n link: opener(link),\n listItem: opener(listItem),\n listItemValue: onenterlistitemvalue,\n listOrdered: opener(list, onenterlistordered),\n listUnordered: opener(list),\n paragraph: opener(paragraph),\n reference: onenterreference,\n referenceString: buffer,\n resourceDestinationString: buffer,\n resourceTitleString: buffer,\n setextHeading: opener(heading),\n strong: opener(strong),\n thematicBreak: opener(thematicBreak)\n },\n exit: {\n atxHeading: closer(),\n atxHeadingSequence: onexitatxheadingsequence,\n autolink: closer(),\n autolinkEmail: onexitautolinkemail,\n autolinkProtocol: onexitautolinkprotocol,\n blockQuote: closer(),\n characterEscapeValue: onexitdata,\n characterReferenceMarkerHexadecimal: onexitcharacterreferencemarker,\n characterReferenceMarkerNumeric: onexitcharacterreferencemarker,\n characterReferenceValue: onexitcharacterreferencevalue,\n characterReference: onexitcharacterreference,\n codeFenced: closer(onexitcodefenced),\n codeFencedFence: onexitcodefencedfence,\n codeFencedFenceInfo: onexitcodefencedfenceinfo,\n codeFencedFenceMeta: onexitcodefencedfencemeta,\n codeFlowValue: onexitdata,\n codeIndented: closer(onexitcodeindented),\n codeText: closer(onexitcodetext),\n codeTextData: onexitdata,\n data: onexitdata,\n definition: closer(),\n definitionDestinationString: onexitdefinitiondestinationstring,\n definitionLabelString: onexitdefinitionlabelstring,\n definitionTitleString: onexitdefinitiontitlestring,\n emphasis: closer(),\n hardBreakEscape: closer(onexithardbreak),\n hardBreakTrailing: closer(onexithardbreak),\n htmlFlow: closer(onexithtmlflow),\n htmlFlowData: onexitdata,\n htmlText: closer(onexithtmltext),\n htmlTextData: onexitdata,\n image: closer(onexitimage),\n label: onexitlabel,\n labelText: onexitlabeltext,\n lineEnding: onexitlineending,\n link: closer(onexitlink),\n listItem: closer(),\n listOrdered: closer(),\n listUnordered: closer(),\n paragraph: closer(),\n referenceString: onexitreferencestring,\n resourceDestinationString: onexitresourcedestinationstring,\n resourceTitleString: onexitresourcetitlestring,\n resource: onexitresource,\n setextHeading: closer(onexitsetextheading),\n setextHeadingLineSequence: onexitsetextheadinglinesequence,\n setextHeadingText: onexitsetextheadingtext,\n strong: closer(),\n thematicBreak: closer()\n }\n };\n configure(config, (options || {}).mdastExtensions || []);\n\n /** @type {CompileData} */\n const data = {};\n return compile;\n\n /**\n * Turn micromark events into an mdast tree.\n *\n * @param {Array} events\n * Events.\n * @returns {Root}\n * mdast tree.\n */\n function compile(events) {\n /** @type {Root} */\n let tree = {\n type: 'root',\n children: []\n };\n /** @type {Omit} */\n const context = {\n stack: [tree],\n tokenStack: [],\n config,\n enter,\n exit,\n buffer,\n resume,\n data\n };\n /** @type {Array} */\n const listStack = [];\n let index = -1;\n while (++index < events.length) {\n // We preprocess lists to add `listItem` tokens, and to infer whether\n // items the list itself are spread out.\n if (events[index][1].type === \"listOrdered\" || events[index][1].type === \"listUnordered\") {\n if (events[index][0] === 'enter') {\n listStack.push(index);\n } else {\n const tail = listStack.pop();\n index = prepareList(events, tail, index);\n }\n }\n }\n index = -1;\n while (++index < events.length) {\n const handler = config[events[index][0]];\n if (own.call(handler, events[index][1].type)) {\n handler[events[index][1].type].call(Object.assign({\n sliceSerialize: events[index][2].sliceSerialize\n }, context), events[index][1]);\n }\n }\n\n // Handle tokens still being open.\n if (context.tokenStack.length > 0) {\n const tail = context.tokenStack[context.tokenStack.length - 1];\n const handler = tail[1] || defaultOnError;\n handler.call(context, undefined, tail[0]);\n }\n\n // Figure out `root` position.\n tree.position = {\n start: point(events.length > 0 ? events[0][1].start : {\n line: 1,\n column: 1,\n offset: 0\n }),\n end: point(events.length > 0 ? events[events.length - 2][1].end : {\n line: 1,\n column: 1,\n offset: 0\n })\n };\n\n // Call transforms.\n index = -1;\n while (++index < config.transforms.length) {\n tree = config.transforms[index](tree) || tree;\n }\n return tree;\n }\n\n /**\n * @param {Array} events\n * @param {number} start\n * @param {number} length\n * @returns {number}\n */\n function prepareList(events, start, length) {\n let index = start - 1;\n let containerBalance = -1;\n let listSpread = false;\n /** @type {Token | undefined} */\n let listItem;\n /** @type {number | undefined} */\n let lineIndex;\n /** @type {number | undefined} */\n let firstBlankLineIndex;\n /** @type {boolean | undefined} */\n let atMarker;\n while (++index <= length) {\n const event = events[index];\n switch (event[1].type) {\n case \"listUnordered\":\n case \"listOrdered\":\n case \"blockQuote\":\n {\n if (event[0] === 'enter') {\n containerBalance++;\n } else {\n containerBalance--;\n }\n atMarker = undefined;\n break;\n }\n case \"lineEndingBlank\":\n {\n if (event[0] === 'enter') {\n if (listItem && !atMarker && !containerBalance && !firstBlankLineIndex) {\n firstBlankLineIndex = index;\n }\n atMarker = undefined;\n }\n break;\n }\n case \"linePrefix\":\n case \"listItemValue\":\n case \"listItemMarker\":\n case \"listItemPrefix\":\n case \"listItemPrefixWhitespace\":\n {\n // Empty.\n\n break;\n }\n default:\n {\n atMarker = undefined;\n }\n }\n if (!containerBalance && event[0] === 'enter' && event[1].type === \"listItemPrefix\" || containerBalance === -1 && event[0] === 'exit' && (event[1].type === \"listUnordered\" || event[1].type === \"listOrdered\")) {\n if (listItem) {\n let tailIndex = index;\n lineIndex = undefined;\n while (tailIndex--) {\n const tailEvent = events[tailIndex];\n if (tailEvent[1].type === \"lineEnding\" || tailEvent[1].type === \"lineEndingBlank\") {\n if (tailEvent[0] === 'exit') continue;\n if (lineIndex) {\n events[lineIndex][1].type = \"lineEndingBlank\";\n listSpread = true;\n }\n tailEvent[1].type = \"lineEnding\";\n lineIndex = tailIndex;\n } else if (tailEvent[1].type === \"linePrefix\" || tailEvent[1].type === \"blockQuotePrefix\" || tailEvent[1].type === \"blockQuotePrefixWhitespace\" || tailEvent[1].type === \"blockQuoteMarker\" || tailEvent[1].type === \"listItemIndent\") {\n // Empty\n } else {\n break;\n }\n }\n if (firstBlankLineIndex && (!lineIndex || firstBlankLineIndex < lineIndex)) {\n listItem._spread = true;\n }\n\n // Fix position.\n listItem.end = Object.assign({}, lineIndex ? events[lineIndex][1].start : event[1].end);\n events.splice(lineIndex || index, 0, ['exit', listItem, event[2]]);\n index++;\n length++;\n }\n\n // Create a new list item.\n if (event[1].type === \"listItemPrefix\") {\n /** @type {Token} */\n const item = {\n type: 'listItem',\n _spread: false,\n start: Object.assign({}, event[1].start),\n // @ts-expect-error: we’ll add `end` in a second.\n end: undefined\n };\n listItem = item;\n events.splice(index, 0, ['enter', item, event[2]]);\n index++;\n length++;\n firstBlankLineIndex = undefined;\n atMarker = true;\n }\n }\n }\n events[start][1]._spread = listSpread;\n return length;\n }\n\n /**\n * Create an opener handle.\n *\n * @param {(token: Token) => Nodes} create\n * Create a node.\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function opener(create, and) {\n return open;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function open(token) {\n enter.call(this, create(token), token);\n if (and) and.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['buffer']}\n */\n function buffer() {\n this.stack.push({\n type: 'fragment',\n children: []\n });\n }\n\n /**\n * @type {CompileContext['enter']}\n */\n function enter(node, token, errorHandler) {\n const parent = this.stack[this.stack.length - 1];\n /** @type {Array} */\n const siblings = parent.children;\n siblings.push(node);\n this.stack.push(node);\n this.tokenStack.push([token, errorHandler || undefined]);\n node.position = {\n start: point(token.start),\n // @ts-expect-error: `end` will be patched later.\n end: undefined\n };\n }\n\n /**\n * Create a closer handle.\n *\n * @param {Handle | undefined} [and]\n * Optional function to also run.\n * @returns {Handle}\n * Handle.\n */\n function closer(and) {\n return close;\n\n /**\n * @this {CompileContext}\n * @param {Token} token\n * @returns {undefined}\n */\n function close(token) {\n if (and) and.call(this, token);\n exit.call(this, token);\n }\n }\n\n /**\n * @type {CompileContext['exit']}\n */\n function exit(token, onExitError) {\n const node = this.stack.pop();\n const open = this.tokenStack.pop();\n if (!open) {\n throw new Error('Cannot close `' + token.type + '` (' + stringifyPosition({\n start: token.start,\n end: token.end\n }) + '): it’s not open');\n } else if (open[0].type !== token.type) {\n if (onExitError) {\n onExitError.call(this, token, open[0]);\n } else {\n const handler = open[1] || defaultOnError;\n handler.call(this, token, open[0]);\n }\n }\n node.position.end = point(token.end);\n }\n\n /**\n * @type {CompileContext['resume']}\n */\n function resume() {\n return toString(this.stack.pop());\n }\n\n //\n // Handlers.\n //\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistordered() {\n this.data.expectingFirstListItemValue = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onenterlistitemvalue(token) {\n if (this.data.expectingFirstListItemValue) {\n const ancestor = this.stack[this.stack.length - 2];\n ancestor.start = Number.parseInt(this.sliceSerialize(token), 10);\n this.data.expectingFirstListItemValue = undefined;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfenceinfo() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.lang = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfencemeta() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.meta = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefencedfence() {\n // Exit if this is the closing fence.\n if (this.data.flowCodeInside) return;\n this.buffer();\n this.data.flowCodeInside = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodefenced() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, '');\n this.data.flowCodeInside = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcodeindented() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data.replace(/(\\r?\\n|\\r)$/g, '');\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitionlabelstring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.label = label;\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiontitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitdefinitiondestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitatxheadingsequence(token) {\n const node = this.stack[this.stack.length - 1];\n if (!node.depth) {\n const depth = this.sliceSerialize(token).length;\n node.depth = depth;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadingtext() {\n this.data.setextHeadingSlurpLineEnding = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheadinglinesequence(token) {\n const node = this.stack[this.stack.length - 1];\n node.depth = this.sliceSerialize(token).codePointAt(0) === 61 ? 1 : 2;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitsetextheading() {\n this.data.setextHeadingSlurpLineEnding = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterdata(token) {\n const node = this.stack[this.stack.length - 1];\n /** @type {Array} */\n const siblings = node.children;\n let tail = siblings[siblings.length - 1];\n if (!tail || tail.type !== 'text') {\n // Add a new text node.\n tail = text();\n tail.position = {\n start: point(token.start),\n // @ts-expect-error: we’ll add `end` later.\n end: undefined\n };\n siblings.push(tail);\n }\n this.stack.push(tail);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitdata(token) {\n const tail = this.stack.pop();\n tail.value += this.sliceSerialize(token);\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlineending(token) {\n const context = this.stack[this.stack.length - 1];\n // If we’re at a hard break, include the line ending in there.\n if (this.data.atHardBreak) {\n const tail = context.children[context.children.length - 1];\n tail.position.end = point(token.end);\n this.data.atHardBreak = undefined;\n return;\n }\n if (!this.data.setextHeadingSlurpLineEnding && config.canContainEols.includes(context.type)) {\n onenterdata.call(this, token);\n onexitdata.call(this, token);\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithardbreak() {\n this.data.atHardBreak = true;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmlflow() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexithtmltext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcodetext() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.value = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlink() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitimage() {\n const node = this.stack[this.stack.length - 1];\n // Note: there are also `identifier` and `label` fields on this link node!\n // These are used / cleaned here.\n\n // To do: clean.\n if (this.data.inReference) {\n /** @type {ReferenceType} */\n const referenceType = this.data.referenceType || 'shortcut';\n node.type += 'Reference';\n // @ts-expect-error: mutate.\n node.referenceType = referenceType;\n // @ts-expect-error: mutate.\n delete node.url;\n delete node.title;\n } else {\n // @ts-expect-error: mutate.\n delete node.identifier;\n // @ts-expect-error: mutate.\n delete node.label;\n }\n this.data.referenceType = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabeltext(token) {\n const string = this.sliceSerialize(token);\n const ancestor = this.stack[this.stack.length - 2];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n ancestor.label = decodeString(string);\n // @ts-expect-error: same as above.\n ancestor.identifier = normalizeIdentifier(string).toLowerCase();\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitlabel() {\n const fragment = this.stack[this.stack.length - 1];\n const value = this.resume();\n const node = this.stack[this.stack.length - 1];\n // Assume a reference.\n this.data.inReference = true;\n if (node.type === 'link') {\n /** @type {Array} */\n const children = fragment.children;\n node.children = children;\n } else {\n node.alt = value;\n }\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcedestinationstring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.url = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresourcetitlestring() {\n const data = this.resume();\n const node = this.stack[this.stack.length - 1];\n node.title = data;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitresource() {\n this.data.inReference = undefined;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onenterreference() {\n this.data.referenceType = 'collapsed';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitreferencestring(token) {\n const label = this.resume();\n const node = this.stack[this.stack.length - 1];\n // @ts-expect-error: stash this on the node, as it might become a reference\n // later.\n node.label = label;\n // @ts-expect-error: same as above.\n node.identifier = normalizeIdentifier(this.sliceSerialize(token)).toLowerCase();\n this.data.referenceType = 'full';\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n\n function onexitcharacterreferencemarker(token) {\n this.data.characterReferenceType = token.type;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreferencevalue(token) {\n const data = this.sliceSerialize(token);\n const type = this.data.characterReferenceType;\n /** @type {string} */\n let value;\n if (type) {\n value = decodeNumericCharacterReference(data, type === \"characterReferenceMarkerNumeric\" ? 10 : 16);\n this.data.characterReferenceType = undefined;\n } else {\n const result = decodeNamedCharacterReference(data);\n value = result;\n }\n const tail = this.stack[this.stack.length - 1];\n tail.value += value;\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitcharacterreference(token) {\n const tail = this.stack.pop();\n tail.position.end = point(token.end);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkprotocol(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = this.sliceSerialize(token);\n }\n\n /**\n * @this {CompileContext}\n * @type {Handle}\n */\n function onexitautolinkemail(token) {\n onexitdata.call(this, token);\n const node = this.stack[this.stack.length - 1];\n node.url = 'mailto:' + this.sliceSerialize(token);\n }\n\n //\n // Creaters.\n //\n\n /** @returns {Blockquote} */\n function blockQuote() {\n return {\n type: 'blockquote',\n children: []\n };\n }\n\n /** @returns {Code} */\n function codeFlow() {\n return {\n type: 'code',\n lang: null,\n meta: null,\n value: ''\n };\n }\n\n /** @returns {InlineCode} */\n function codeText() {\n return {\n type: 'inlineCode',\n value: ''\n };\n }\n\n /** @returns {Definition} */\n function definition() {\n return {\n type: 'definition',\n identifier: '',\n label: null,\n title: null,\n url: ''\n };\n }\n\n /** @returns {Emphasis} */\n function emphasis() {\n return {\n type: 'emphasis',\n children: []\n };\n }\n\n /** @returns {Heading} */\n function heading() {\n return {\n type: 'heading',\n // @ts-expect-error `depth` will be set later.\n depth: 0,\n children: []\n };\n }\n\n /** @returns {Break} */\n function hardBreak() {\n return {\n type: 'break'\n };\n }\n\n /** @returns {Html} */\n function html() {\n return {\n type: 'html',\n value: ''\n };\n }\n\n /** @returns {Image} */\n function image() {\n return {\n type: 'image',\n title: null,\n url: '',\n alt: null\n };\n }\n\n /** @returns {Link} */\n function link() {\n return {\n type: 'link',\n title: null,\n url: '',\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {List}\n */\n function list(token) {\n return {\n type: 'list',\n ordered: token.type === 'listOrdered',\n start: null,\n spread: token._spread,\n children: []\n };\n }\n\n /**\n * @param {Token} token\n * @returns {ListItem}\n */\n function listItem(token) {\n return {\n type: 'listItem',\n spread: token._spread,\n checked: null,\n children: []\n };\n }\n\n /** @returns {Paragraph} */\n function paragraph() {\n return {\n type: 'paragraph',\n children: []\n };\n }\n\n /** @returns {Strong} */\n function strong() {\n return {\n type: 'strong',\n children: []\n };\n }\n\n /** @returns {Text} */\n function text() {\n return {\n type: 'text',\n value: ''\n };\n }\n\n /** @returns {ThematicBreak} */\n function thematicBreak() {\n return {\n type: 'thematicBreak'\n };\n }\n}\n\n/**\n * Copy a point-like value.\n *\n * @param {Point} d\n * Point-like value.\n * @returns {Point}\n * unist point.\n */\nfunction point(d) {\n return {\n line: d.line,\n column: d.column,\n offset: d.offset\n };\n}\n\n/**\n * @param {Config} combined\n * @param {Array | Extension>} extensions\n * @returns {undefined}\n */\nfunction configure(combined, extensions) {\n let index = -1;\n while (++index < extensions.length) {\n const value = extensions[index];\n if (Array.isArray(value)) {\n configure(combined, value);\n } else {\n extension(combined, value);\n }\n }\n}\n\n/**\n * @param {Config} combined\n * @param {Extension} extension\n * @returns {undefined}\n */\nfunction extension(combined, extension) {\n /** @type {keyof Extension} */\n let key;\n for (key in extension) {\n if (own.call(extension, key)) {\n switch (key) {\n case 'canContainEols':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'transforms':\n {\n const right = extension[key];\n if (right) {\n combined[key].push(...right);\n }\n break;\n }\n case 'enter':\n case 'exit':\n {\n const right = extension[key];\n if (right) {\n Object.assign(combined[key], right);\n }\n break;\n }\n // No default\n }\n }\n }\n}\n\n/** @type {OnEnterError} */\nfunction defaultOnError(left, right) {\n if (left) {\n throw new Error('Cannot close `' + left.type + '` (' + stringifyPosition({\n start: left.start,\n end: left.end\n }) + '): a different token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is open');\n } else {\n throw new Error('Cannot close document, a token (`' + right.type + '`, ' + stringifyPosition({\n start: right.start,\n end: right.end\n }) + ') is still open');\n }\n}","/**\n * @import {Event} from 'micromark-util-types'\n */\n\nimport { subtokenize } from 'micromark-util-subtokenize';\n\n/**\n * @param {Array} events\n * Events.\n * @returns {Array}\n * Events.\n */\nexport function postprocess(events) {\n while (!subtokenize(events)) {\n // Empty\n }\n return events;\n}","/**\n * @typedef {import('mdast').Root} Root\n * @typedef {import('mdast-util-from-markdown').Options} FromMarkdownOptions\n * @typedef {import('unified').Parser} Parser\n * @typedef {import('unified').Processor} Processor\n */\n\n/**\n * @typedef {Omit} Options\n */\n\nimport {fromMarkdown} from 'mdast-util-from-markdown'\n\n/**\n * Aadd support for parsing from markdown.\n *\n * @param {Readonly | null | undefined} [options]\n * Configuration (optional).\n * @returns {undefined}\n * Nothing.\n */\nexport default function remarkParse(options) {\n /** @type {Processor} */\n // @ts-expect-error: TS in JSDoc generates wrong types if `this` is typed regularly.\n const self = this\n\n self.parser = parser\n\n /**\n * @type {Parser}\n */\n function parser(doc) {\n return fromMarkdown(doc, {\n ...self.data('settings'),\n ...options,\n // Note: these options are not in the readme.\n // The goal is for them to be set by plugins on `data` instead of being\n // passed by users.\n extensions: self.data('micromarkExtensions') || [],\n mdastExtensions: self.data('fromMarkdownExtensions') || []\n })\n }\n}\n","export const VOID = -1;\nexport const PRIMITIVE = 0;\nexport const ARRAY = 1;\nexport const OBJECT = 2;\nexport const DATE = 3;\nexport const REGEXP = 4;\nexport const MAP = 5;\nexport const SET = 6;\nexport const ERROR = 7;\nexport const BIGINT = 8;\n// export const SYMBOL = 9;\n","import {\n VOID, PRIMITIVE,\n ARRAY, OBJECT,\n DATE, REGEXP, MAP, SET,\n ERROR, BIGINT\n} from './types.js';\n\nconst env = typeof self === 'object' ? self : globalThis;\n\nconst deserializer = ($, _) => {\n const as = (out, index) => {\n $.set(index, out);\n return out;\n };\n\n const unpair = index => {\n if ($.has(index))\n return $.get(index);\n\n const [type, value] = _[index];\n switch (type) {\n case PRIMITIVE:\n case VOID:\n return as(value, index);\n case ARRAY: {\n const arr = as([], index);\n for (const index of value)\n arr.push(unpair(index));\n return arr;\n }\n case OBJECT: {\n const object = as({}, index);\n for (const [key, index] of value)\n object[unpair(key)] = unpair(index);\n return object;\n }\n case DATE:\n return as(new Date(value), index);\n case REGEXP: {\n const {source, flags} = value;\n return as(new RegExp(source, flags), index);\n }\n case MAP: {\n const map = as(new Map, index);\n for (const [key, index] of value)\n map.set(unpair(key), unpair(index));\n return map;\n }\n case SET: {\n const set = as(new Set, index);\n for (const index of value)\n set.add(unpair(index));\n return set;\n }\n case ERROR: {\n const {name, message} = value;\n return as(new env[name](message), index);\n }\n case BIGINT:\n return as(BigInt(value), index);\n case 'BigInt':\n return as(Object(BigInt(value)), index);\n }\n return as(new env[type](value), index);\n };\n\n return unpair;\n};\n\n/**\n * @typedef {Array} Record a type representation\n */\n\n/**\n * Returns a deserialized value from a serialized array of Records.\n * @param {Record[]} serialized a previously serialized value.\n * @returns {any}\n */\nexport const deserialize = serialized => deserializer(new Map, serialized)(0);\n","import {\n VOID, PRIMITIVE,\n ARRAY, OBJECT,\n DATE, REGEXP, MAP, SET,\n ERROR, BIGINT\n} from './types.js';\n\nconst EMPTY = '';\n\nconst {toString} = {};\nconst {keys} = Object;\n\nconst typeOf = value => {\n const type = typeof value;\n if (type !== 'object' || !value)\n return [PRIMITIVE, type];\n\n const asString = toString.call(value).slice(8, -1);\n switch (asString) {\n case 'Array':\n return [ARRAY, EMPTY];\n case 'Object':\n return [OBJECT, EMPTY];\n case 'Date':\n return [DATE, EMPTY];\n case 'RegExp':\n return [REGEXP, EMPTY];\n case 'Map':\n return [MAP, EMPTY];\n case 'Set':\n return [SET, EMPTY];\n }\n\n if (asString.includes('Array'))\n return [ARRAY, asString];\n\n if (asString.includes('Error'))\n return [ERROR, asString];\n\n return [OBJECT, asString];\n};\n\nconst shouldSkip = ([TYPE, type]) => (\n TYPE === PRIMITIVE &&\n (type === 'function' || type === 'symbol')\n);\n\nconst serializer = (strict, json, $, _) => {\n\n const as = (out, value) => {\n const index = _.push(out) - 1;\n $.set(value, index);\n return index;\n };\n\n const pair = value => {\n if ($.has(value))\n return $.get(value);\n\n let [TYPE, type] = typeOf(value);\n switch (TYPE) {\n case PRIMITIVE: {\n let entry = value;\n switch (type) {\n case 'bigint':\n TYPE = BIGINT;\n entry = value.toString();\n break;\n case 'function':\n case 'symbol':\n if (strict)\n throw new TypeError('unable to serialize ' + type);\n entry = null;\n break;\n case 'undefined':\n return as([VOID], value);\n }\n return as([TYPE, entry], value);\n }\n case ARRAY: {\n if (type)\n return as([type, [...value]], value);\n \n const arr = [];\n const index = as([TYPE, arr], value);\n for (const entry of value)\n arr.push(pair(entry));\n return index;\n }\n case OBJECT: {\n if (type) {\n switch (type) {\n case 'BigInt':\n return as([type, value.toString()], value);\n case 'Boolean':\n case 'Number':\n case 'String':\n return as([type, value.valueOf()], value);\n }\n }\n\n if (json && ('toJSON' in value))\n return pair(value.toJSON());\n\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const key of keys(value)) {\n if (strict || !shouldSkip(typeOf(value[key])))\n entries.push([pair(key), pair(value[key])]);\n }\n return index;\n }\n case DATE:\n return as([TYPE, value.toISOString()], value);\n case REGEXP: {\n const {source, flags} = value;\n return as([TYPE, {source, flags}], value);\n }\n case MAP: {\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const [key, entry] of value) {\n if (strict || !(shouldSkip(typeOf(key)) || shouldSkip(typeOf(entry))))\n entries.push([pair(key), pair(entry)]);\n }\n return index;\n }\n case SET: {\n const entries = [];\n const index = as([TYPE, entries], value);\n for (const entry of value) {\n if (strict || !shouldSkip(typeOf(entry)))\n entries.push(pair(entry));\n }\n return index;\n }\n }\n\n const {message} = value;\n return as([TYPE, {name: type, message}], value);\n };\n\n return pair;\n};\n\n/**\n * @typedef {Array} Record a type representation\n */\n\n/**\n * Returns an array of serialized Records.\n * @param {any} value a serializable value.\n * @param {{json?: boolean, lossy?: boolean}?} options an object with a `lossy` or `json` property that,\n * if `true`, will not throw errors on incompatible types, and behave more\n * like JSON stringify would behave. Symbol and Function will be discarded.\n * @returns {Record[]}\n */\n export const serialize = (value, {json, lossy} = {}) => {\n const _ = [];\n return serializer(!(json || lossy), !!json, new Map, _)(value), _;\n};\n","import {deserialize} from './deserialize.js';\nimport {serialize} from './serialize.js';\n\n/**\n * @typedef {Array} Record a type representation\n */\n\n/**\n * Returns an array of serialized Records.\n * @param {any} any a serializable value.\n * @param {{transfer?: any[], json?: boolean, lossy?: boolean}?} options an object with\n * a transfer option (ignored when polyfilled) and/or non standard fields that\n * fallback to the polyfill if present.\n * @returns {Record[]}\n */\nexport default typeof structuredClone === \"function\" ?\n /* c8 ignore start */\n (any, options) => (\n options && ('json' in options || 'lossy' in options) ?\n deserialize(serialize(any, options)) : structuredClone(any)\n ) :\n (any, options) => deserialize(serialize(any, options));\n /* c8 ignore stop */\n\nexport {deserialize, serialize};\n","import { asciiAlphanumeric } from 'micromark-util-character';\nimport { encode } from 'micromark-util-encode';\n/**\n * Make a value safe for injection as a URL.\n *\n * This encodes unsafe characters with percent-encoding and skips already\n * encoded sequences (see `normalizeUri`).\n * Further unsafe characters are encoded as character references (see\n * `micromark-util-encode`).\n *\n * A regex of allowed protocols can be given, in which case the URL is\n * sanitized.\n * For example, `/^(https?|ircs?|mailto|xmpp)$/i` can be used for `a[href]`, or\n * `/^https?$/i` for `img[src]` (this is what `github.com` allows).\n * If the URL includes an unknown protocol (one not matched by `protocol`, such\n * as a dangerous example, `javascript:`), the value is ignored.\n *\n * @param {string | null | undefined} url\n * URI to sanitize.\n * @param {RegExp | null | undefined} [protocol]\n * Allowed protocols.\n * @returns {string}\n * Sanitized URI.\n */\nexport function sanitizeUri(url, protocol) {\n const value = encode(normalizeUri(url || ''));\n if (!protocol) {\n return value;\n }\n const colon = value.indexOf(':');\n const questionMark = value.indexOf('?');\n const numberSign = value.indexOf('#');\n const slash = value.indexOf('/');\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 || questionMark > -1 && colon > questionMark || numberSign > -1 && colon > numberSign ||\n // It is a protocol, it should be allowed.\n protocol.test(value.slice(0, colon))) {\n return value;\n }\n return '';\n}\n\n/**\n * Normalize a URL.\n *\n * Encode unsafe characters with percent-encoding, skipping already encoded\n * sequences.\n *\n * @param {string} value\n * URI to normalize.\n * @returns {string}\n * Normalized URI.\n */\nexport function normalizeUri(value) {\n /** @type {Array} */\n const result = [];\n let index = -1;\n let start = 0;\n let skip = 0;\n while (++index < value.length) {\n const code = value.charCodeAt(index);\n /** @type {string} */\n let replace = '';\n\n // A correct percent encoded value.\n if (code === 37 && asciiAlphanumeric(value.charCodeAt(index + 1)) && asciiAlphanumeric(value.charCodeAt(index + 2))) {\n skip = 2;\n }\n // ASCII.\n else if (code < 128) {\n if (!/[!#$&-;=?-Z_a-z~]/.test(String.fromCharCode(code))) {\n replace = String.fromCharCode(code);\n }\n }\n // Astral.\n else if (code > 55_295 && code < 57_344) {\n const next = value.charCodeAt(index + 1);\n\n // A correct surrogate pair.\n if (code < 56_320 && next > 56_319 && next < 57_344) {\n replace = String.fromCharCode(code, next);\n skip = 1;\n }\n // Lone surrogate.\n else {\n replace = \"\\uFFFD\";\n }\n }\n // Unicode.\n else {\n replace = String.fromCharCode(code);\n }\n if (replace) {\n result.push(value.slice(start, index), encodeURIComponent(replace));\n start = index + skip + 1;\n replace = '';\n }\n if (skip) {\n index += skip;\n skip = 0;\n }\n }\n return result.join('') + value.slice(start);\n}","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n *\n * @typedef {import('./state.js').State} State\n */\n\n/**\n * @callback FootnoteBackContentTemplate\n * Generate content for the backreference dynamically.\n *\n * For the following markdown:\n *\n * ```markdown\n * Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n * [^remark]: things about remark\n * [^micromark]: things about micromark\n * ```\n *\n * This function will be called with:\n *\n * * `0` and `0` for the backreference from `things about micromark` to\n * `alpha`, as it is the first used definition, and the first call to it\n * * `0` and `1` for the backreference from `things about micromark` to\n * `bravo`, as it is the first used definition, and the second call to it\n * * `1` and `0` for the backreference from `things about remark` to\n * `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {Array | ElementContent | string}\n * Content for the backreference when linking back from definitions to their\n * reference.\n *\n * @callback FootnoteBackLabelTemplate\n * Generate a back label dynamically.\n *\n * For the following markdown:\n *\n * ```markdown\n * Alpha[^micromark], bravo[^micromark], and charlie[^remark].\n *\n * [^remark]: things about remark\n * [^micromark]: things about micromark\n * ```\n *\n * This function will be called with:\n *\n * * `0` and `0` for the backreference from `things about micromark` to\n * `alpha`, as it is the first used definition, and the first call to it\n * * `0` and `1` for the backreference from `things about micromark` to\n * `bravo`, as it is the first used definition, and the second call to it\n * * `1` and `0` for the backreference from `things about remark` to\n * `charlie`, as it is the second used definition\n * @param {number} referenceIndex\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {string}\n * Back label to use when linking back from definitions to their reference.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Generate the default content that GitHub uses on backreferences.\n *\n * @param {number} _\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {Array}\n * Content.\n */\nexport function defaultFootnoteBackContent(_, rereferenceIndex) {\n /** @type {Array} */\n const result = [{type: 'text', value: '↩'}]\n\n if (rereferenceIndex > 1) {\n result.push({\n type: 'element',\n tagName: 'sup',\n properties: {},\n children: [{type: 'text', value: String(rereferenceIndex)}]\n })\n }\n\n return result\n}\n\n/**\n * Generate the default label that GitHub uses on backreferences.\n *\n * @param {number} referenceIndex\n * Index of the definition in the order that they are first referenced,\n * 0-indexed.\n * @param {number} rereferenceIndex\n * Index of calls to the same definition, 0-indexed.\n * @returns {string}\n * Label.\n */\nexport function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n return (\n 'Back to reference ' +\n (referenceIndex + 1) +\n (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n )\n}\n\n/**\n * Generate a hast footer for called footnote definitions.\n *\n * @param {State} state\n * Info passed around.\n * @returns {Element | undefined}\n * `section` element or `undefined`.\n */\n// eslint-disable-next-line complexity\nexport function footer(state) {\n const clobberPrefix =\n typeof state.options.clobberPrefix === 'string'\n ? state.options.clobberPrefix\n : 'user-content-'\n const footnoteBackContent =\n state.options.footnoteBackContent || defaultFootnoteBackContent\n const footnoteBackLabel =\n state.options.footnoteBackLabel || defaultFootnoteBackLabel\n const footnoteLabel = state.options.footnoteLabel || 'Footnotes'\n const footnoteLabelTagName = state.options.footnoteLabelTagName || 'h2'\n const footnoteLabelProperties = state.options.footnoteLabelProperties || {\n className: ['sr-only']\n }\n /** @type {Array} */\n const listItems = []\n let referenceIndex = -1\n\n while (++referenceIndex < state.footnoteOrder.length) {\n const definition = state.footnoteById.get(\n state.footnoteOrder[referenceIndex]\n )\n\n if (!definition) {\n continue\n }\n\n const content = state.all(definition)\n const id = String(definition.identifier).toUpperCase()\n const safeId = normalizeUri(id.toLowerCase())\n let rereferenceIndex = 0\n /** @type {Array} */\n const backReferences = []\n const counts = state.footnoteCounts.get(id)\n\n // eslint-disable-next-line no-unmodified-loop-condition\n while (counts !== undefined && ++rereferenceIndex <= counts) {\n if (backReferences.length > 0) {\n backReferences.push({type: 'text', value: ' '})\n }\n\n let children =\n typeof footnoteBackContent === 'string'\n ? footnoteBackContent\n : footnoteBackContent(referenceIndex, rereferenceIndex)\n\n if (typeof children === 'string') {\n children = {type: 'text', value: children}\n }\n\n backReferences.push({\n type: 'element',\n tagName: 'a',\n properties: {\n href:\n '#' +\n clobberPrefix +\n 'fnref-' +\n safeId +\n (rereferenceIndex > 1 ? '-' + rereferenceIndex : ''),\n dataFootnoteBackref: '',\n ariaLabel:\n typeof footnoteBackLabel === 'string'\n ? footnoteBackLabel\n : footnoteBackLabel(referenceIndex, rereferenceIndex),\n className: ['data-footnote-backref']\n },\n children: Array.isArray(children) ? children : [children]\n })\n }\n\n const tail = content[content.length - 1]\n\n if (tail && tail.type === 'element' && tail.tagName === 'p') {\n const tailTail = tail.children[tail.children.length - 1]\n if (tailTail && tailTail.type === 'text') {\n tailTail.value += ' '\n } else {\n tail.children.push({type: 'text', value: ' '})\n }\n\n tail.children.push(...backReferences)\n } else {\n content.push(...backReferences)\n }\n\n /** @type {Element} */\n const listItem = {\n type: 'element',\n tagName: 'li',\n properties: {id: clobberPrefix + 'fn-' + safeId},\n children: state.wrap(content, true)\n }\n\n state.patch(definition, listItem)\n\n listItems.push(listItem)\n }\n\n if (listItems.length === 0) {\n return\n }\n\n return {\n type: 'element',\n tagName: 'section',\n properties: {dataFootnotes: true, className: ['footnotes']},\n children: [\n {\n type: 'element',\n tagName: footnoteLabelTagName,\n properties: {\n ...structuredClone(footnoteLabelProperties),\n id: 'footnote-label'\n },\n children: [{type: 'text', value: footnoteLabel}]\n },\n {type: 'text', value: '\\n'},\n {\n type: 'element',\n tagName: 'ol',\n properties: {},\n children: state.wrap(listItems, true)\n },\n {type: 'text', value: '\\n'}\n ]\n }\n}\n","/**\n * @typedef {import('unist').Node} Node\n * @typedef {import('unist').Parent} Parent\n */\n\n/**\n * @template Fn\n * @template Fallback\n * @typedef {Fn extends (value: any) => value is infer Thing ? Thing : Fallback} Predicate\n */\n\n/**\n * @callback Check\n * Check that an arbitrary value is a node.\n * @param {unknown} this\n * The given context.\n * @param {unknown} [node]\n * Anything (typically a node).\n * @param {number | null | undefined} [index]\n * The node’s position in its parent.\n * @param {Parent | null | undefined} [parent]\n * The node’s parent.\n * @returns {boolean}\n * Whether this is a node and passes a test.\n *\n * @typedef {Record | Node} Props\n * Object to check for equivalence.\n *\n * Note: `Node` is included as it is common but is not indexable.\n *\n * @typedef {Array | Props | TestFunction | string | null | undefined} Test\n * Check for an arbitrary node.\n *\n * @callback TestFunction\n * Check if a node passes a test.\n * @param {unknown} this\n * The given context.\n * @param {Node} node\n * A node.\n * @param {number | undefined} [index]\n * The node’s position in its parent.\n * @param {Parent | undefined} [parent]\n * The node’s parent.\n * @returns {boolean | undefined | void}\n * Whether this node passes the test.\n *\n * Note: `void` is included until TS sees no return as `undefined`.\n */\n\n/**\n * Check if `node` is a `Node` and whether it passes the given test.\n *\n * @param {unknown} node\n * Thing to check, typically `Node`.\n * @param {Test} test\n * A check for a specific node.\n * @param {number | null | undefined} index\n * The node’s position in its parent.\n * @param {Parent | null | undefined} parent\n * The node’s parent.\n * @param {unknown} context\n * Context object (`this`) to pass to `test` functions.\n * @returns {boolean}\n * Whether `node` is a node and passes a test.\n */\nexport const is =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * ((node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * ((node: unknown, test: Condition, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate) &\n * ((node?: null | undefined) => false) &\n * ((node: unknown, test?: null | undefined, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((node: unknown, test?: Test, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => boolean)\n * )}\n */\n (\n /**\n * @param {unknown} [node]\n * @param {Test} [test]\n * @param {number | null | undefined} [index]\n * @param {Parent | null | undefined} [parent]\n * @param {unknown} [context]\n * @returns {boolean}\n */\n // eslint-disable-next-line max-params\n function (node, test, index, parent, context) {\n const check = convert(test)\n\n if (\n index !== undefined &&\n index !== null &&\n (typeof index !== 'number' ||\n index < 0 ||\n index === Number.POSITIVE_INFINITY)\n ) {\n throw new Error('Expected positive finite index')\n }\n\n if (\n parent !== undefined &&\n parent !== null &&\n (!is(parent) || !parent.children)\n ) {\n throw new Error('Expected parent node')\n }\n\n if (\n (parent === undefined || parent === null) !==\n (index === undefined || index === null)\n ) {\n throw new Error('Expected both parent and index')\n }\n\n return looksLikeANode(node)\n ? check.call(context, node, index, parent)\n : false\n }\n )\n\n/**\n * Generate an assertion from a test.\n *\n * Useful if you’re going to test many nodes, for example when creating a\n * utility where something else passes a compatible test.\n *\n * The created function is a bit faster because it expects valid input only:\n * a `node`, `index`, and `parent`.\n *\n * @param {Test} test\n * * when nullish, checks if `node` is a `Node`.\n * * when `string`, works like passing `(node) => node.type === test`.\n * * when `function` checks if function passed the node is true.\n * * when `object`, checks that all keys in test are in node, and that they have (strictly) equal values.\n * * when `array`, checks if any one of the subtests pass.\n * @returns {Check}\n * An assertion.\n */\nexport const convert =\n // Note: overloads in JSDoc can’t yet use different `@template`s.\n /**\n * @type {(\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & {type: Condition}) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Condition) &\n * ((test: Condition) => (node: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node & Predicate) &\n * ((test?: null | undefined) => (node?: unknown, index?: number | null | undefined, parent?: Parent | null | undefined, context?: unknown) => node is Node) &\n * ((test?: Test) => Check)\n * )}\n */\n (\n /**\n * @param {Test} [test]\n * @returns {Check}\n */\n function (test) {\n if (test === null || test === undefined) {\n return ok\n }\n\n if (typeof test === 'function') {\n return castFactory(test)\n }\n\n if (typeof test === 'object') {\n return Array.isArray(test) ? anyFactory(test) : propsFactory(test)\n }\n\n if (typeof test === 'string') {\n return typeFactory(test)\n }\n\n throw new Error('Expected function, string, or object as test')\n }\n )\n\n/**\n * @param {Array} tests\n * @returns {Check}\n */\nfunction anyFactory(tests) {\n /** @type {Array} */\n const checks = []\n let index = -1\n\n while (++index < tests.length) {\n checks[index] = convert(tests[index])\n }\n\n return castFactory(any)\n\n /**\n * @this {unknown}\n * @type {TestFunction}\n */\n function any(...parameters) {\n let index = -1\n\n while (++index < checks.length) {\n if (checks[index].apply(this, parameters)) return true\n }\n\n return false\n }\n}\n\n/**\n * Turn an object into a test for a node with a certain fields.\n *\n * @param {Props} check\n * @returns {Check}\n */\nfunction propsFactory(check) {\n const checkAsRecord = /** @type {Record} */ (check)\n\n return castFactory(all)\n\n /**\n * @param {Node} node\n * @returns {boolean}\n */\n function all(node) {\n const nodeAsRecord = /** @type {Record} */ (\n /** @type {unknown} */ (node)\n )\n\n /** @type {string} */\n let key\n\n for (key in check) {\n if (nodeAsRecord[key] !== checkAsRecord[key]) return false\n }\n\n return true\n }\n}\n\n/**\n * Turn a string into a test for a node with a certain type.\n *\n * @param {string} check\n * @returns {Check}\n */\nfunction typeFactory(check) {\n return castFactory(type)\n\n /**\n * @param {Node} node\n */\n function type(node) {\n return node && node.type === check\n }\n}\n\n/**\n * Turn a custom test into a test for a node that passes that test.\n *\n * @param {TestFunction} testFunction\n * @returns {Check}\n */\nfunction castFactory(testFunction) {\n return check\n\n /**\n * @this {unknown}\n * @type {Check}\n */\n function check(value, index, parent) {\n return Boolean(\n looksLikeANode(value) &&\n testFunction.call(\n this,\n value,\n typeof index === 'number' ? index : undefined,\n parent || undefined\n )\n )\n }\n}\n\nfunction ok() {\n return true\n}\n\n/**\n * @param {unknown} value\n * @returns {value is Node}\n */\nfunction looksLikeANode(value) {\n return value !== null && typeof value === 'object' && 'type' in value\n}\n","/**\n * @typedef {import('unist').Node} UnistNode\n * @typedef {import('unist').Parent} UnistParent\n */\n\n/**\n * @typedef {Exclude | undefined} Test\n * Test from `unist-util-is`.\n *\n * Note: we have remove and add `undefined`, because otherwise when generating\n * automatic `.d.ts` files, TS tries to flatten paths from a local perspective,\n * which doesn’t work when publishing on npm.\n */\n\n/**\n * @typedef {(\n * Fn extends (value: any) => value is infer Thing\n * ? Thing\n * : Fallback\n * )} Predicate\n * Get the value of a type guard `Fn`.\n * @template Fn\n * Value; typically function that is a type guard (such as `(x): x is Y`).\n * @template Fallback\n * Value to yield if `Fn` is not a type guard.\n */\n\n/**\n * @typedef {(\n * Check extends null | undefined // No test.\n * ? Value\n * : Value extends {type: Check} // String (type) test.\n * ? Value\n * : Value extends Check // Partial test.\n * ? Value\n * : Check extends Function // Function test.\n * ? Predicate extends Value\n * ? Predicate\n * : never\n * : never // Some other test?\n * )} MatchesOne\n * Check whether a node matches a primitive check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test, but not arrays.\n */\n\n/**\n * @typedef {(\n * Check extends Array\n * ? MatchesOne\n * : MatchesOne\n * )} Matches\n * Check whether a node matches a check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test.\n */\n\n/**\n * @typedef {0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10} Uint\n * Number; capped reasonably.\n */\n\n/**\n * @typedef {I extends 0 ? 1 : I extends 1 ? 2 : I extends 2 ? 3 : I extends 3 ? 4 : I extends 4 ? 5 : I extends 5 ? 6 : I extends 6 ? 7 : I extends 7 ? 8 : I extends 8 ? 9 : 10} Increment\n * Increment a number in the type system.\n * @template {Uint} [I=0]\n * Index.\n */\n\n/**\n * @typedef {(\n * Node extends UnistParent\n * ? Node extends {children: Array}\n * ? Child extends Children ? Node : never\n * : never\n * : never\n * )} InternalParent\n * Collect nodes that can be parents of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {InternalParent, Child>} Parent\n * Collect nodes in `Tree` that can be parents of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Depth extends Max\n * ? never\n * :\n * | InternalParent\n * | InternalAncestor, Max, Increment>\n * )} InternalAncestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {InternalAncestor, Child>} Ancestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Tree extends UnistParent\n * ? Depth extends Max\n * ? Tree\n * : Tree | InclusiveDescendant>\n * : Tree\n * )} InclusiveDescendant\n * Collect all (inclusive) descendants of `Tree`.\n *\n * > πŸ‘‰ **Note**: for performance reasons, this seems to be the fastest way to\n * > recurse without actually running into an infinite loop, which the\n * > previous version did.\n * >\n * > Practically, a max of `2` is typically enough assuming a `Root` is\n * > passed, but it doesn’t improve performance.\n * > It gets higher with `List > ListItem > Table > TableRow > TableCell`.\n * > Using up to `10` doesn’t hurt or help either.\n * @template {UnistNode} Tree\n * Tree type.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {'skip' | boolean} Action\n * Union of the action types.\n *\n * @typedef {number} Index\n * Move to the sibling at `index` next (after node itself is completely\n * traversed).\n *\n * Useful if mutating the tree, such as removing the node the visitor is\n * currently on, or any of its previous siblings.\n * Results less than 0 or greater than or equal to `children.length` stop\n * traversing the parent.\n *\n * @typedef {[(Action | null | undefined | void)?, (Index | null | undefined)?]} ActionTuple\n * List with one or two values, the first an action, the second an index.\n *\n * @typedef {Action | ActionTuple | Index | null | undefined | void} VisitorResult\n * Any value that can be returned from a visitor.\n */\n\n/**\n * @callback Visitor\n * Handle a node (matching `test`, if given).\n *\n * Visitors are free to transform `node`.\n * They can also transform the parent of node (the last of `ancestors`).\n *\n * Replacing `node` itself, if `SKIP` is not returned, still causes its\n * descendants to be walked (which is a bug).\n *\n * When adding or removing previous siblings of `node` (or next siblings, in\n * case of reverse), the `Visitor` should return a new `Index` to specify the\n * sibling to traverse after `node` is traversed.\n * Adding or removing next siblings of `node` (or previous siblings, in case\n * of reverse) is handled as expected without needing to return a new `Index`.\n *\n * Removing the children property of an ancestor still results in them being\n * traversed.\n * @param {Visited} node\n * Found node.\n * @param {Array} ancestors\n * Ancestors of `node`.\n * @returns {VisitorResult}\n * What to do next.\n *\n * An `Index` is treated as a tuple of `[CONTINUE, Index]`.\n * An `Action` is treated as a tuple of `[Action]`.\n *\n * Passing a tuple back only makes sense if the `Action` is `SKIP`.\n * When the `Action` is `EXIT`, that action can be returned.\n * When the `Action` is `CONTINUE`, `Index` can be returned.\n * @template {UnistNode} [Visited=UnistNode]\n * Visited node type.\n * @template {UnistParent} [VisitedParents=UnistParent]\n * Ancestor type.\n */\n\n/**\n * @typedef {Visitor, Check>, Ancestor, Check>>>} BuildVisitor\n * Build a typed `Visitor` function from a tree and a test.\n *\n * It will infer which values are passed as `node` and which as `parents`.\n * @template {UnistNode} [Tree=UnistNode]\n * Tree type.\n * @template {Test} [Check=Test]\n * Test type.\n */\n\nimport {convert} from 'unist-util-is'\nimport {color} from 'unist-util-visit-parents/do-not-use-color'\n\n/** @type {Readonly} */\nconst empty = []\n\n/**\n * Continue traversing as normal.\n */\nexport const CONTINUE = true\n\n/**\n * Stop traversing immediately.\n */\nexport const EXIT = false\n\n/**\n * Do not traverse this node’s children.\n */\nexport const SKIP = 'skip'\n\n/**\n * Visit nodes, with ancestral information.\n *\n * This algorithm performs *depth-first* *tree traversal* in *preorder*\n * (**NLR**) or if `reverse` is given, in *reverse preorder* (**NRL**).\n *\n * You can choose for which nodes `visitor` is called by passing a `test`.\n * For complex tests, you should test yourself in `visitor`, as it will be\n * faster and will have improved type information.\n *\n * Walking the tree is an intensive task.\n * Make use of the return values of the visitor when possible.\n * Instead of walking a tree multiple times, walk it once, use `unist-util-is`\n * to check if a node matches, and then perform different operations.\n *\n * You can change the tree.\n * See `Visitor` for more info.\n *\n * @overload\n * @param {Tree} tree\n * @param {Check} check\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @overload\n * @param {Tree} tree\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @param {UnistNode} tree\n * Tree to traverse.\n * @param {Visitor | Test} test\n * `unist-util-is`-compatible test\n * @param {Visitor | boolean | null | undefined} [visitor]\n * Handle each node.\n * @param {boolean | null | undefined} [reverse]\n * Traverse in reverse preorder (NRL) instead of the default preorder (NLR).\n * @returns {undefined}\n * Nothing.\n *\n * @template {UnistNode} Tree\n * Node type.\n * @template {Test} Check\n * `unist-util-is`-compatible test.\n */\nexport function visitParents(tree, test, visitor, reverse) {\n /** @type {Test} */\n let check\n\n if (typeof test === 'function' && typeof visitor !== 'function') {\n reverse = visitor\n // @ts-expect-error no visitor given, so `visitor` is test.\n visitor = test\n } else {\n // @ts-expect-error visitor given, so `test` isn’t a visitor.\n check = test\n }\n\n const is = convert(check)\n const step = reverse ? -1 : 1\n\n factory(tree, undefined, [])()\n\n /**\n * @param {UnistNode} node\n * @param {number | undefined} index\n * @param {Array} parents\n */\n function factory(node, index, parents) {\n const value = /** @type {Record} */ (\n node && typeof node === 'object' ? node : {}\n )\n\n if (typeof value.type === 'string') {\n const name =\n // `hast`\n typeof value.tagName === 'string'\n ? value.tagName\n : // `xast`\n typeof value.name === 'string'\n ? value.name\n : undefined\n\n Object.defineProperty(visit, 'name', {\n value:\n 'node (' + color(node.type + (name ? '<' + name + '>' : '')) + ')'\n })\n }\n\n return visit\n\n function visit() {\n /** @type {Readonly} */\n let result = empty\n /** @type {Readonly} */\n let subresult\n /** @type {number} */\n let offset\n /** @type {Array} */\n let grandparents\n\n if (!test || is(node, index, parents[parents.length - 1] || undefined)) {\n // @ts-expect-error: `visitor` is now a visitor.\n result = toResult(visitor(node, parents))\n\n if (result[0] === EXIT) {\n return result\n }\n }\n\n if ('children' in node && node.children) {\n const nodeAsParent = /** @type {UnistParent} */ (node)\n\n if (nodeAsParent.children && result[0] !== SKIP) {\n offset = (reverse ? nodeAsParent.children.length : -1) + step\n grandparents = parents.concat(nodeAsParent)\n\n while (offset > -1 && offset < nodeAsParent.children.length) {\n const child = nodeAsParent.children[offset]\n\n subresult = factory(child, offset, grandparents)()\n\n if (subresult[0] === EXIT) {\n return subresult\n }\n\n offset =\n typeof subresult[1] === 'number' ? subresult[1] : offset + step\n }\n }\n }\n\n return result\n }\n }\n}\n\n/**\n * Turn a return value into a clean result.\n *\n * @param {VisitorResult} value\n * Valid return values from visitors.\n * @returns {Readonly}\n * Clean result.\n */\nfunction toResult(value) {\n if (Array.isArray(value)) {\n return value\n }\n\n if (typeof value === 'number') {\n return [CONTINUE, value]\n }\n\n return value === null || value === undefined ? empty : [value]\n}\n","/**\n * @typedef {import('unist').Node} UnistNode\n * @typedef {import('unist').Parent} UnistParent\n * @typedef {import('unist-util-visit-parents').VisitorResult} VisitorResult\n */\n\n/**\n * @typedef {Exclude | undefined} Test\n * Test from `unist-util-is`.\n *\n * Note: we have remove and add `undefined`, because otherwise when generating\n * automatic `.d.ts` files, TS tries to flatten paths from a local perspective,\n * which doesn’t work when publishing on npm.\n */\n\n// To do: use types from `unist-util-visit-parents` when it’s released.\n\n/**\n * @typedef {(\n * Fn extends (value: any) => value is infer Thing\n * ? Thing\n * : Fallback\n * )} Predicate\n * Get the value of a type guard `Fn`.\n * @template Fn\n * Value; typically function that is a type guard (such as `(x): x is Y`).\n * @template Fallback\n * Value to yield if `Fn` is not a type guard.\n */\n\n/**\n * @typedef {(\n * Check extends null | undefined // No test.\n * ? Value\n * : Value extends {type: Check} // String (type) test.\n * ? Value\n * : Value extends Check // Partial test.\n * ? Value\n * : Check extends Function // Function test.\n * ? Predicate extends Value\n * ? Predicate\n * : never\n * : never // Some other test?\n * )} MatchesOne\n * Check whether a node matches a primitive check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test, but not arrays.\n */\n\n/**\n * @typedef {(\n * Check extends Array\n * ? MatchesOne\n * : MatchesOne\n * )} Matches\n * Check whether a node matches a check in the type system.\n * @template Value\n * Value; typically unist `Node`.\n * @template Check\n * Value; typically `unist-util-is`-compatible test.\n */\n\n/**\n * @typedef {0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10} Uint\n * Number; capped reasonably.\n */\n\n/**\n * @typedef {I extends 0 ? 1 : I extends 1 ? 2 : I extends 2 ? 3 : I extends 3 ? 4 : I extends 4 ? 5 : I extends 5 ? 6 : I extends 6 ? 7 : I extends 7 ? 8 : I extends 8 ? 9 : 10} Increment\n * Increment a number in the type system.\n * @template {Uint} [I=0]\n * Index.\n */\n\n/**\n * @typedef {(\n * Node extends UnistParent\n * ? Node extends {children: Array}\n * ? Child extends Children ? Node : never\n * : never\n * : never\n * )} InternalParent\n * Collect nodes that can be parents of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {InternalParent, Child>} Parent\n * Collect nodes in `Tree` that can be parents of `Child`.\n * @template {UnistNode} Tree\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n */\n\n/**\n * @typedef {(\n * Depth extends Max\n * ? never\n * :\n * | InternalParent\n * | InternalAncestor, Max, Increment>\n * )} InternalAncestor\n * Collect nodes in `Tree` that can be ancestors of `Child`.\n * @template {UnistNode} Node\n * All node types in a tree.\n * @template {UnistNode} Child\n * Node to search for.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @typedef {(\n * Tree extends UnistParent\n * ? Depth extends Max\n * ? Tree\n * : Tree | InclusiveDescendant>\n * : Tree\n * )} InclusiveDescendant\n * Collect all (inclusive) descendants of `Tree`.\n *\n * > πŸ‘‰ **Note**: for performance reasons, this seems to be the fastest way to\n * > recurse without actually running into an infinite loop, which the\n * > previous version did.\n * >\n * > Practically, a max of `2` is typically enough assuming a `Root` is\n * > passed, but it doesn’t improve performance.\n * > It gets higher with `List > ListItem > Table > TableRow > TableCell`.\n * > Using up to `10` doesn’t hurt or help either.\n * @template {UnistNode} Tree\n * Tree type.\n * @template {Uint} [Max=10]\n * Max; searches up to this depth.\n * @template {Uint} [Depth=0]\n * Current depth.\n */\n\n/**\n * @callback Visitor\n * Handle a node (matching `test`, if given).\n *\n * Visitors are free to transform `node`.\n * They can also transform `parent`.\n *\n * Replacing `node` itself, if `SKIP` is not returned, still causes its\n * descendants to be walked (which is a bug).\n *\n * When adding or removing previous siblings of `node` (or next siblings, in\n * case of reverse), the `Visitor` should return a new `Index` to specify the\n * sibling to traverse after `node` is traversed.\n * Adding or removing next siblings of `node` (or previous siblings, in case\n * of reverse) is handled as expected without needing to return a new `Index`.\n *\n * Removing the children property of `parent` still results in them being\n * traversed.\n * @param {Visited} node\n * Found node.\n * @param {Visited extends UnistNode ? number | undefined : never} index\n * Index of `node` in `parent`.\n * @param {Ancestor extends UnistParent ? Ancestor | undefined : never} parent\n * Parent of `node`.\n * @returns {VisitorResult}\n * What to do next.\n *\n * An `Index` is treated as a tuple of `[CONTINUE, Index]`.\n * An `Action` is treated as a tuple of `[Action]`.\n *\n * Passing a tuple back only makes sense if the `Action` is `SKIP`.\n * When the `Action` is `EXIT`, that action can be returned.\n * When the `Action` is `CONTINUE`, `Index` can be returned.\n * @template {UnistNode} [Visited=UnistNode]\n * Visited node type.\n * @template {UnistParent} [Ancestor=UnistParent]\n * Ancestor type.\n */\n\n/**\n * @typedef {Visitor>} BuildVisitorFromMatch\n * Build a typed `Visitor` function from a node and all possible parents.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} Visited\n * Node type.\n * @template {UnistParent} Ancestor\n * Parent type.\n */\n\n/**\n * @typedef {(\n * BuildVisitorFromMatch<\n * Matches,\n * Extract\n * >\n * )} BuildVisitorFromDescendants\n * Build a typed `Visitor` function from a list of descendants and a test.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} Descendant\n * Node type.\n * @template {Test} Check\n * Test type.\n */\n\n/**\n * @typedef {(\n * BuildVisitorFromDescendants<\n * InclusiveDescendant,\n * Check\n * >\n * )} BuildVisitor\n * Build a typed `Visitor` function from a tree and a test.\n *\n * It will infer which values are passed as `node` and which as `parent`.\n * @template {UnistNode} [Tree=UnistNode]\n * Node type.\n * @template {Test} [Check=Test]\n * Test type.\n */\n\nimport {visitParents} from 'unist-util-visit-parents'\n\nexport {CONTINUE, EXIT, SKIP} from 'unist-util-visit-parents'\n\n/**\n * Visit nodes.\n *\n * This algorithm performs *depth-first* *tree traversal* in *preorder*\n * (**NLR**) or if `reverse` is given, in *reverse preorder* (**NRL**).\n *\n * You can choose for which nodes `visitor` is called by passing a `test`.\n * For complex tests, you should test yourself in `visitor`, as it will be\n * faster and will have improved type information.\n *\n * Walking the tree is an intensive task.\n * Make use of the return values of the visitor when possible.\n * Instead of walking a tree multiple times, walk it once, use `unist-util-is`\n * to check if a node matches, and then perform different operations.\n *\n * You can change the tree.\n * See `Visitor` for more info.\n *\n * @overload\n * @param {Tree} tree\n * @param {Check} check\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @overload\n * @param {Tree} tree\n * @param {BuildVisitor} visitor\n * @param {boolean | null | undefined} [reverse]\n * @returns {undefined}\n *\n * @param {UnistNode} tree\n * Tree to traverse.\n * @param {Visitor | Test} testOrVisitor\n * `unist-util-is`-compatible test (optional, omit to pass a visitor).\n * @param {Visitor | boolean | null | undefined} [visitorOrReverse]\n * Handle each node (when test is omitted, pass `reverse`).\n * @param {boolean | null | undefined} [maybeReverse=false]\n * Traverse in reverse preorder (NRL) instead of the default preorder (NLR).\n * @returns {undefined}\n * Nothing.\n *\n * @template {UnistNode} Tree\n * Node type.\n * @template {Test} Check\n * `unist-util-is`-compatible test.\n */\nexport function visit(tree, testOrVisitor, visitorOrReverse, maybeReverse) {\n /** @type {boolean | null | undefined} */\n let reverse\n /** @type {Test} */\n let test\n /** @type {Visitor} */\n let visitor\n\n if (\n typeof testOrVisitor === 'function' &&\n typeof visitorOrReverse !== 'function'\n ) {\n test = undefined\n visitor = testOrVisitor\n reverse = visitorOrReverse\n } else {\n // @ts-expect-error: assume the overload with test was given.\n test = testOrVisitor\n // @ts-expect-error: assume the overload with test was given.\n visitor = visitorOrReverse\n reverse = maybeReverse\n }\n\n visitParents(tree, test, overload, reverse)\n\n /**\n * @param {UnistNode} node\n * @param {Array} parents\n */\n function overload(node, parents) {\n const parent = parents[parents.length - 1]\n const index = parent ? parent.children.indexOf(node) : undefined\n return visitor(node, index, parent)\n }\n}\n","/**\n * @typedef {import('hast').ElementContent} ElementContent\n *\n * @typedef {import('mdast').Nodes} Nodes\n * @typedef {import('mdast').Reference} Reference\n *\n * @typedef {import('./state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Return the content of a reference without definition as plain text.\n *\n * @param {State} state\n * Info passed around.\n * @param {Extract} node\n * Reference node (image, link).\n * @returns {Array}\n * hast content.\n */\nexport function revert(state, node) {\n const subtype = node.referenceType\n let suffix = ']'\n\n if (subtype === 'collapsed') {\n suffix += '[]'\n } else if (subtype === 'full') {\n suffix += '[' + (node.label || node.identifier) + ']'\n }\n\n if (node.type === 'imageReference') {\n return [{type: 'text', value: '![' + node.alt + suffix}]\n }\n\n const contents = state.all(node)\n const head = contents[0]\n\n if (head && head.type === 'text') {\n head.value = '[' + head.value\n } else {\n contents.unshift({type: 'text', value: '['})\n }\n\n const tail = contents[contents.length - 1]\n\n if (tail && tail.type === 'text') {\n tail.value += suffix\n } else {\n contents.push({type: 'text', value: suffix})\n }\n\n return contents\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').ListItem} ListItem\n * @typedef {import('mdast').Parents} Parents\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `listItem` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {ListItem} node\n * mdast node.\n * @param {Parents | undefined} parent\n * Parent of `node`.\n * @returns {Element}\n * hast node.\n */\nexport function listItem(state, node, parent) {\n const results = state.all(node)\n const loose = parent ? listLoose(parent) : listItemLoose(node)\n /** @type {Properties} */\n const properties = {}\n /** @type {Array} */\n const children = []\n\n if (typeof node.checked === 'boolean') {\n const head = results[0]\n /** @type {Element} */\n let paragraph\n\n if (head && head.type === 'element' && head.tagName === 'p') {\n paragraph = head\n } else {\n paragraph = {type: 'element', tagName: 'p', properties: {}, children: []}\n results.unshift(paragraph)\n }\n\n if (paragraph.children.length > 0) {\n paragraph.children.unshift({type: 'text', value: ' '})\n }\n\n paragraph.children.unshift({\n type: 'element',\n tagName: 'input',\n properties: {type: 'checkbox', checked: node.checked, disabled: true},\n children: []\n })\n\n // According to github-markdown-css, this class hides bullet.\n // See: .\n properties.className = ['task-list-item']\n }\n\n let index = -1\n\n while (++index < results.length) {\n const child = results[index]\n\n // Add eols before nodes, except if this is a loose, first paragraph.\n if (\n loose ||\n index !== 0 ||\n child.type !== 'element' ||\n child.tagName !== 'p'\n ) {\n children.push({type: 'text', value: '\\n'})\n }\n\n if (child.type === 'element' && child.tagName === 'p' && !loose) {\n children.push(...child.children)\n } else {\n children.push(child)\n }\n }\n\n const tail = results[results.length - 1]\n\n // Add a final eol.\n if (tail && (loose || tail.type !== 'element' || tail.tagName !== 'p')) {\n children.push({type: 'text', value: '\\n'})\n }\n\n /** @type {Element} */\n const result = {type: 'element', tagName: 'li', properties, children}\n state.patch(node, result)\n return state.applyData(node, result)\n}\n\n/**\n * @param {Parents} node\n * @return {Boolean}\n */\nfunction listLoose(node) {\n let loose = false\n if (node.type === 'list') {\n loose = node.spread || false\n const children = node.children\n let index = -1\n\n while (!loose && ++index < children.length) {\n loose = listItemLoose(children[index])\n }\n }\n\n return loose\n}\n\n/**\n * @param {ListItem} node\n * @return {Boolean}\n */\nfunction listItemLoose(node) {\n const spread = node.spread\n\n return spread === null || spread === undefined\n ? node.children.length > 1\n : spread\n}\n","const tab = 9 /* `\\t` */\nconst space = 32 /* ` ` */\n\n/**\n * Remove initial and final spaces and tabs at the line breaks in `value`.\n * Does not trim initial and final spaces and tabs of the value itself.\n *\n * @param {string} value\n * Value to trim.\n * @returns {string}\n * Trimmed value.\n */\nexport function trimLines(value) {\n const source = String(value)\n const search = /\\r?\\n|\\r/g\n let match = search.exec(source)\n let last = 0\n /** @type {Array} */\n const lines = []\n\n while (match) {\n lines.push(\n trimLine(source.slice(last, match.index), last > 0, true),\n match[0]\n )\n\n last = match.index + match[0].length\n match = search.exec(source)\n }\n\n lines.push(trimLine(source.slice(last), last > 0, false))\n\n return lines.join('')\n}\n\n/**\n * @param {string} value\n * Line to trim.\n * @param {boolean} start\n * Whether to trim the start of the line.\n * @param {boolean} end\n * Whether to trim the end of the line.\n * @returns {string}\n * Trimmed line.\n */\nfunction trimLine(value, start, end) {\n let startIndex = 0\n let endIndex = value.length\n\n if (start) {\n let code = value.codePointAt(startIndex)\n\n while (code === tab || code === space) {\n startIndex++\n code = value.codePointAt(startIndex)\n }\n }\n\n if (end) {\n let code = value.codePointAt(endIndex - 1)\n\n while (code === tab || code === space) {\n endIndex--\n code = value.codePointAt(endIndex - 1)\n }\n }\n\n return endIndex > startIndex ? value.slice(startIndex, endIndex) : ''\n}\n","import {blockquote} from './blockquote.js'\nimport {hardBreak} from './break.js'\nimport {code} from './code.js'\nimport {strikethrough} from './delete.js'\nimport {emphasis} from './emphasis.js'\nimport {footnoteReference} from './footnote-reference.js'\nimport {heading} from './heading.js'\nimport {html} from './html.js'\nimport {imageReference} from './image-reference.js'\nimport {image} from './image.js'\nimport {inlineCode} from './inline-code.js'\nimport {linkReference} from './link-reference.js'\nimport {link} from './link.js'\nimport {listItem} from './list-item.js'\nimport {list} from './list.js'\nimport {paragraph} from './paragraph.js'\nimport {root} from './root.js'\nimport {strong} from './strong.js'\nimport {table} from './table.js'\nimport {tableRow} from './table-row.js'\nimport {tableCell} from './table-cell.js'\nimport {text} from './text.js'\nimport {thematicBreak} from './thematic-break.js'\n\n/**\n * Default handlers for nodes.\n *\n * @satisfies {import('../state.js').Handlers}\n */\nexport const handlers = {\n blockquote,\n break: hardBreak,\n code,\n delete: strikethrough,\n emphasis,\n footnoteReference,\n heading,\n html,\n imageReference,\n image,\n inlineCode,\n linkReference,\n link,\n listItem,\n list,\n paragraph,\n // @ts-expect-error: root is different, but hard to type.\n root,\n strong,\n table,\n tableCell,\n tableRow,\n text,\n thematicBreak,\n toml: ignore,\n yaml: ignore,\n definition: ignore,\n footnoteDefinition: ignore\n}\n\n// Return nothing for nodes that are ignored.\nfunction ignore() {\n return undefined\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Blockquote} Blockquote\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `blockquote` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Blockquote} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function blockquote(state, node) {\n /** @type {Element} */\n const result = {\n type: 'element',\n tagName: 'blockquote',\n properties: {},\n children: state.wrap(state.all(node), true)\n }\n state.patch(node, result)\n return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Text} Text\n * @typedef {import('mdast').Break} Break\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `break` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Break} node\n * mdast node.\n * @returns {Array}\n * hast element content.\n */\nexport function hardBreak(state, node) {\n /** @type {Element} */\n const result = {type: 'element', tagName: 'br', properties: {}, children: []}\n state.patch(node, result)\n return [state.applyData(node, result), {type: 'text', value: '\\n'}]\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Code} Code\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `code` node into hast.\n *\n * @param {State} state\n * Info passed around.\n * @param {Code} node\n * mdast node.\n * @returns {Element}\n * hast node.\n */\nexport function code(state, node) {\n const value = node.value ? node.value + '\\n' : ''\n /** @type {Properties} */\n const properties = {}\n\n if (node.lang) {\n properties.className = ['language-' + node.lang]\n }\n\n // Create ``.\n /** @type {Element} */\n let result = {\n type: 'element',\n tagName: 'code',\n properties,\n children: [{type: 'text', value}]\n }\n\n if (node.meta) {\n result.data = {meta: node.meta}\n }\n\n state.patch(node, result)\n result = state.applyData(node, result)\n\n // Create `
`.\n  result = {type: 'element', tagName: 'pre', properties: {}, children: [result]}\n  state.patch(node, result)\n  return result\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Delete} Delete\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `delete` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Delete} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function strikethrough(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'del',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Emphasis} Emphasis\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `emphasis` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Emphasis} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function emphasis(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'em',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').FootnoteReference} FootnoteReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `footnoteReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {FootnoteReference} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function footnoteReference(state, node) {\n  const clobberPrefix =\n    typeof state.options.clobberPrefix === 'string'\n      ? state.options.clobberPrefix\n      : 'user-content-'\n  const id = String(node.identifier).toUpperCase()\n  const safeId = normalizeUri(id.toLowerCase())\n  const index = state.footnoteOrder.indexOf(id)\n  /** @type {number} */\n  let counter\n\n  let reuseCounter = state.footnoteCounts.get(id)\n\n  if (reuseCounter === undefined) {\n    reuseCounter = 0\n    state.footnoteOrder.push(id)\n    counter = state.footnoteOrder.length\n  } else {\n    counter = index + 1\n  }\n\n  reuseCounter += 1\n  state.footnoteCounts.set(id, reuseCounter)\n\n  /** @type {Element} */\n  const link = {\n    type: 'element',\n    tagName: 'a',\n    properties: {\n      href: '#' + clobberPrefix + 'fn-' + safeId,\n      id:\n        clobberPrefix +\n        'fnref-' +\n        safeId +\n        (reuseCounter > 1 ? '-' + reuseCounter : ''),\n      dataFootnoteRef: true,\n      ariaDescribedBy: ['footnote-label']\n    },\n    children: [{type: 'text', value: String(counter)}]\n  }\n  state.patch(node, link)\n\n  /** @type {Element} */\n  const sup = {\n    type: 'element',\n    tagName: 'sup',\n    properties: {},\n    children: [link]\n  }\n  state.patch(node, sup)\n  return state.applyData(node, sup)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Heading} Heading\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `heading` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Heading} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function heading(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'h' + node.depth,\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Html} Html\n * @typedef {import('../state.js').State} State\n * @typedef {import('../../index.js').Raw} Raw\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `html` node into hast (`raw` node in dangerous mode, otherwise\n * nothing).\n *\n * @param {State} state\n *   Info passed around.\n * @param {Html} node\n *   mdast node.\n * @returns {Element | Raw | undefined}\n *   hast node.\n */\nexport function html(state, node) {\n  if (state.options.allowDangerousHtml) {\n    /** @type {Raw} */\n    const result = {type: 'raw', value: node.value}\n    state.patch(node, result)\n    return state.applyData(node, result)\n  }\n\n  return undefined\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').ImageReference} ImageReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `imageReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ImageReference} node\n *   mdast node.\n * @returns {Array | ElementContent}\n *   hast node.\n */\nexport function imageReference(state, node) {\n  const id = String(node.identifier).toUpperCase()\n  const definition = state.definitionById.get(id)\n\n  if (!definition) {\n    return revert(state, node)\n  }\n\n  /** @type {Properties} */\n  const properties = {src: normalizeUri(definition.url || ''), alt: node.alt}\n\n  if (definition.title !== null && definition.title !== undefined) {\n    properties.title = definition.title\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'img', properties, children: []}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Image} Image\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `image` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Image} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function image(state, node) {\n  /** @type {Properties} */\n  const properties = {src: normalizeUri(node.url)}\n\n  if (node.alt !== null && node.alt !== undefined) {\n    properties.alt = node.alt\n  }\n\n  if (node.title !== null && node.title !== undefined) {\n    properties.title = node.title\n  }\n\n  /** @type {Element} */\n  const result = {type: 'element', tagName: 'img', properties, children: []}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Text} Text\n * @typedef {import('mdast').InlineCode} InlineCode\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `inlineCode` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {InlineCode} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function inlineCode(state, node) {\n  /** @type {Text} */\n  const text = {type: 'text', value: node.value.replace(/\\r?\\n|\\r/g, ' ')}\n  state.patch(node, text)\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'code',\n    properties: {},\n    children: [text]\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').LinkReference} LinkReference\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\nimport {revert} from '../revert.js'\n\n/**\n * Turn an mdast `linkReference` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {LinkReference} node\n *   mdast node.\n * @returns {Array | ElementContent}\n *   hast node.\n */\nexport function linkReference(state, node) {\n  const id = String(node.identifier).toUpperCase()\n  const definition = state.definitionById.get(id)\n\n  if (!definition) {\n    return revert(state, node)\n  }\n\n  /** @type {Properties} */\n  const properties = {href: normalizeUri(definition.url || '')}\n\n  if (definition.title !== null && definition.title !== undefined) {\n    properties.title = definition.title\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'a',\n    properties,\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Link} Link\n * @typedef {import('../state.js').State} State\n */\n\nimport {normalizeUri} from 'micromark-util-sanitize-uri'\n\n/**\n * Turn an mdast `link` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Link} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function link(state, node) {\n  /** @type {Properties} */\n  const properties = {href: normalizeUri(node.url)}\n\n  if (node.title !== null && node.title !== undefined) {\n    properties.title = node.title\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'a',\n    properties,\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').List} List\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `list` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {List} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function list(state, node) {\n  /** @type {Properties} */\n  const properties = {}\n  const results = state.all(node)\n  let index = -1\n\n  if (typeof node.start === 'number' && node.start !== 1) {\n    properties.start = node.start\n  }\n\n  // Like GitHub, add a class for custom styling.\n  while (++index < results.length) {\n    const child = results[index]\n\n    if (\n      child.type === 'element' &&\n      child.tagName === 'li' &&\n      child.properties &&\n      Array.isArray(child.properties.className) &&\n      child.properties.className.includes('task-list-item')\n    ) {\n      properties.className = ['contains-task-list']\n      break\n    }\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: node.ordered ? 'ol' : 'ul',\n    properties,\n    children: state.wrap(results, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Paragraph} Paragraph\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `paragraph` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Paragraph} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function paragraph(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'p',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Parents} HastParents\n * @typedef {import('hast').Root} HastRoot\n * @typedef {import('mdast').Root} MdastRoot\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `root` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {MdastRoot} node\n *   mdast node.\n * @returns {HastParents}\n *   hast node.\n */\nexport function root(state, node) {\n  /** @type {HastRoot} */\n  const result = {type: 'root', children: state.wrap(state.all(node))}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Strong} Strong\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `strong` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Strong} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function strong(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'strong',\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').Table} Table\n * @typedef {import('../state.js').State} State\n */\n\nimport {pointEnd, pointStart} from 'unist-util-position'\n\n/**\n * Turn an mdast `table` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {Table} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function table(state, node) {\n  const rows = state.all(node)\n  const firstRow = rows.shift()\n  /** @type {Array} */\n  const tableContent = []\n\n  if (firstRow) {\n    /** @type {Element} */\n    const head = {\n      type: 'element',\n      tagName: 'thead',\n      properties: {},\n      children: state.wrap([firstRow], true)\n    }\n    state.patch(node.children[0], head)\n    tableContent.push(head)\n  }\n\n  if (rows.length > 0) {\n    /** @type {Element} */\n    const body = {\n      type: 'element',\n      tagName: 'tbody',\n      properties: {},\n      children: state.wrap(rows, true)\n    }\n\n    const start = pointStart(node.children[1])\n    const end = pointEnd(node.children[node.children.length - 1])\n    if (start && end) body.position = {start, end}\n    tableContent.push(body)\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'table',\n    properties: {},\n    children: state.wrap(tableContent, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').TableCell} TableCell\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `tableCell` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {TableCell} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function tableCell(state, node) {\n  // Note: this function is normally not called: see `table-row` for how rows\n  // and their cells are compiled.\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'td', // Assume body cell.\n    properties: {},\n    children: state.all(node)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('hast').ElementContent} ElementContent\n * @typedef {import('hast').Properties} Properties\n * @typedef {import('mdast').Parents} Parents\n * @typedef {import('mdast').TableRow} TableRow\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `tableRow` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {TableRow} node\n *   mdast node.\n * @param {Parents | undefined} parent\n *   Parent of `node`.\n * @returns {Element}\n *   hast node.\n */\nexport function tableRow(state, node, parent) {\n  const siblings = parent ? parent.children : undefined\n  // Generate a body row when without parent.\n  const rowIndex = siblings ? siblings.indexOf(node) : 1\n  const tagName = rowIndex === 0 ? 'th' : 'td'\n  // To do: option to use `style`?\n  const align = parent && parent.type === 'table' ? parent.align : undefined\n  const length = align ? align.length : node.children.length\n  let cellIndex = -1\n  /** @type {Array} */\n  const cells = []\n\n  while (++cellIndex < length) {\n    // Note: can also be undefined.\n    const cell = node.children[cellIndex]\n    /** @type {Properties} */\n    const properties = {}\n    const alignValue = align ? align[cellIndex] : undefined\n\n    if (alignValue) {\n      properties.align = alignValue\n    }\n\n    /** @type {Element} */\n    let result = {type: 'element', tagName, properties, children: []}\n\n    if (cell) {\n      result.children = state.all(cell)\n      state.patch(cell, result)\n      result = state.applyData(cell, result)\n    }\n\n    cells.push(result)\n  }\n\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'tr',\n    properties: {},\n    children: state.wrap(cells, true)\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} HastElement\n * @typedef {import('hast').Text} HastText\n * @typedef {import('mdast').Text} MdastText\n * @typedef {import('../state.js').State} State\n */\n\nimport {trimLines} from 'trim-lines'\n\n/**\n * Turn an mdast `text` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {MdastText} node\n *   mdast node.\n * @returns {HastElement | HastText}\n *   hast node.\n */\nexport function text(state, node) {\n  /** @type {HastText} */\n  const result = {type: 'text', value: trimLines(String(node.value))}\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} Element\n * @typedef {import('mdast').ThematicBreak} ThematicBreak\n * @typedef {import('../state.js').State} State\n */\n\n// Make VS Code show references to the above types.\n''\n\n/**\n * Turn an mdast `thematicBreak` node into hast.\n *\n * @param {State} state\n *   Info passed around.\n * @param {ThematicBreak} node\n *   mdast node.\n * @returns {Element}\n *   hast node.\n */\nexport function thematicBreak(state, node) {\n  /** @type {Element} */\n  const result = {\n    type: 'element',\n    tagName: 'hr',\n    properties: {},\n    children: []\n  }\n  state.patch(node, result)\n  return state.applyData(node, result)\n}\n","/**\n * @typedef {import('hast').Element} HastElement\n * @typedef {import('hast').ElementContent} HastElementContent\n * @typedef {import('hast').Nodes} HastNodes\n * @typedef {import('hast').Properties} HastProperties\n * @typedef {import('hast').RootContent} HastRootContent\n * @typedef {import('hast').Text} HastText\n *\n * @typedef {import('mdast').Definition} MdastDefinition\n * @typedef {import('mdast').FootnoteDefinition} MdastFootnoteDefinition\n * @typedef {import('mdast').Nodes} MdastNodes\n * @typedef {import('mdast').Parents} MdastParents\n *\n * @typedef {import('vfile').VFile} VFile\n *\n * @typedef {import('./footer.js').FootnoteBackContentTemplate} FootnoteBackContentTemplate\n * @typedef {import('./footer.js').FootnoteBackLabelTemplate} FootnoteBackLabelTemplate\n */\n\n/**\n * @callback Handler\n *   Handle a node.\n * @param {State} state\n *   Info passed around.\n * @param {any} node\n *   mdast node to handle.\n * @param {MdastParents | undefined} parent\n *   Parent of `node`.\n * @returns {Array | HastElementContent | undefined}\n *   hast node.\n *\n * @typedef {Partial>} Handlers\n *   Handle nodes.\n *\n * @typedef Options\n *   Configuration (optional).\n * @property {boolean | null | undefined} [allowDangerousHtml=false]\n *   Whether to persist raw HTML in markdown in the hast tree (default:\n *   `false`).\n * @property {string | null | undefined} [clobberPrefix='user-content-']\n *   Prefix to use before the `id` property on footnotes to prevent them from\n *   *clobbering* (default: `'user-content-'`).\n *\n *   Pass `''` for trusted markdown and when you are careful with\n *   polyfilling.\n *   You could pass a different prefix.\n *\n *   DOM clobbering is this:\n *\n *   ```html\n *   

\n * \n * ```\n *\n * The above example shows that elements are made available by browsers, by\n * their ID, on the `window` object.\n * This is a security risk because you might be expecting some other variable\n * at that place.\n * It can also break polyfills.\n * Using a prefix solves these problems.\n * @property {VFile | null | undefined} [file]\n * Corresponding virtual file representing the input document (optional).\n * @property {FootnoteBackContentTemplate | string | null | undefined} [footnoteBackContent]\n * Content of the backreference back to references (default: `defaultFootnoteBackContent`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackContent(_, rereferenceIndex) {\n * const result = [{type: 'text', value: '↩'}]\n *\n * if (rereferenceIndex > 1) {\n * result.push({\n * type: 'element',\n * tagName: 'sup',\n * properties: {},\n * children: [{type: 'text', value: String(rereferenceIndex)}]\n * })\n * }\n *\n * return result\n * }\n * ```\n *\n * This content is used in the `a` element of each backreference (the `↩`\n * links).\n * @property {FootnoteBackLabelTemplate | string | null | undefined} [footnoteBackLabel]\n * Label to describe the backreference back to references (default:\n * `defaultFootnoteBackLabel`).\n *\n * The default value is:\n *\n * ```js\n * function defaultFootnoteBackLabel(referenceIndex, rereferenceIndex) {\n * return (\n * 'Back to reference ' +\n * (referenceIndex + 1) +\n * (rereferenceIndex > 1 ? '-' + rereferenceIndex : '')\n * )\n * }\n * ```\n *\n * Change it when the markdown is not in English.\n *\n * This label is used in the `ariaLabel` property on each backreference\n * (the `↩` links).\n * It affects users of assistive technology.\n * @property {string | null | undefined} [footnoteLabel='Footnotes']\n * Textual label to use for the footnotes section (default: `'Footnotes'`).\n *\n * Change it when the markdown is not in English.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {HastProperties | null | undefined} [footnoteLabelProperties={className: ['sr-only']}]\n * Properties to use on the footnote label (default: `{className:\n * ['sr-only']}`).\n *\n * Change it to show the label and add other properties.\n *\n * This label is typically hidden visually (assuming an `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass an empty string.\n * You can also add different properties.\n *\n * > **Note**: `id: 'footnote-label'` is always added, because footnote\n * > calls use it with `aria-describedby` to provide an accessible label.\n * @property {string | null | undefined} [footnoteLabelTagName='h2']\n * HTML tag name to use for the footnote label element (default: `'h2'`).\n *\n * Change it to match your document structure.\n *\n * This label is typically hidden visually (assuming a `sr-only` CSS class\n * is defined that does that) and so affects screen readers only.\n * If you do have such a class, but want to show this section to everyone,\n * pass different properties with the `footnoteLabelProperties` option.\n * @property {Handlers | null | undefined} [handlers]\n * Extra handlers for nodes (optional).\n * @property {Array | null | undefined} [passThrough]\n * List of custom mdast node types to pass through (keep) in hast (note that\n * the node itself is passed, but eventual children are transformed)\n * (optional).\n * @property {Handler | null | undefined} [unknownHandler]\n * Handler for all unknown nodes (optional).\n *\n * @typedef State\n * Info passed around.\n * @property {(node: MdastNodes) => Array} all\n * Transform the children of an mdast parent to hast.\n * @property {(from: MdastNodes, to: Type) => HastElement | Type} applyData\n * Honor the `data` of `from`, and generate an element instead of `node`.\n * @property {Map} definitionById\n * Definitions by their identifier.\n * @property {Map} footnoteById\n * Footnote definitions by their identifier.\n * @property {Map} footnoteCounts\n * Counts for how often the same footnote was called.\n * @property {Array} footnoteOrder\n * Identifiers of order when footnote calls first appear in tree order.\n * @property {Handlers} handlers\n * Applied handlers.\n * @property {(node: MdastNodes, parent: MdastParents | undefined) => Array | HastElementContent | undefined} one\n * Transform an mdast node to hast.\n * @property {Options} options\n * Configuration.\n * @property {(from: MdastNodes, node: HastNodes) => undefined} patch\n * Copy a node’s positional info.\n * @property {(nodes: Array, loose?: boolean | undefined) => Array} wrap\n * Wrap `nodes` with line endings between each node, adds initial/final line endings when `loose`.\n */\n\nimport structuredClone from '@ungap/structured-clone'\nimport {visit} from 'unist-util-visit'\nimport {position} from 'unist-util-position'\nimport {handlers as defaultHandlers} from './handlers/index.js'\n\nconst own = {}.hasOwnProperty\n\n/** @type {Options} */\nconst emptyOptions = {}\n\n/**\n * Create `state` from an mdast tree.\n *\n * @param {MdastNodes} tree\n * mdast node to transform.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {State}\n * `state` function.\n */\nexport function createState(tree, options) {\n const settings = options || emptyOptions\n /** @type {Map} */\n const definitionById = new Map()\n /** @type {Map} */\n const footnoteById = new Map()\n /** @type {Map} */\n const footnoteCounts = new Map()\n /** @type {Handlers} */\n // @ts-expect-error: the root handler returns a root.\n // Hard to type.\n const handlers = {...defaultHandlers, ...settings.handlers}\n\n /** @type {State} */\n const state = {\n all,\n applyData,\n definitionById,\n footnoteById,\n footnoteCounts,\n footnoteOrder: [],\n handlers,\n one,\n options: settings,\n patch,\n wrap\n }\n\n visit(tree, function (node) {\n if (node.type === 'definition' || node.type === 'footnoteDefinition') {\n const map = node.type === 'definition' ? definitionById : footnoteById\n const id = String(node.identifier).toUpperCase()\n\n // Mimick CM behavior of link definitions.\n // See: .\n if (!map.has(id)) {\n // @ts-expect-error: node type matches map.\n map.set(id, node)\n }\n }\n })\n\n return state\n\n /**\n * Transform an mdast node into a hast node.\n *\n * @param {MdastNodes} node\n * mdast node.\n * @param {MdastParents | undefined} [parent]\n * Parent of `node`.\n * @returns {Array | HastElementContent | undefined}\n * Resulting hast node.\n */\n function one(node, parent) {\n const type = node.type\n const handle = state.handlers[type]\n\n if (own.call(state.handlers, type) && handle) {\n return handle(state, node, parent)\n }\n\n if (state.options.passThrough && state.options.passThrough.includes(type)) {\n if ('children' in node) {\n const {children, ...shallow} = node\n const result = structuredClone(shallow)\n // @ts-expect-error: TS doesn’t understand…\n result.children = state.all(node)\n // @ts-expect-error: TS doesn’t understand…\n return result\n }\n\n // @ts-expect-error: it’s custom.\n return structuredClone(node)\n }\n\n const unknown = state.options.unknownHandler || defaultUnknownHandler\n\n return unknown(state, node, parent)\n }\n\n /**\n * Transform the children of an mdast node into hast nodes.\n *\n * @param {MdastNodes} parent\n * mdast node to compile\n * @returns {Array}\n * Resulting hast nodes.\n */\n function all(parent) {\n /** @type {Array} */\n const values = []\n\n if ('children' in parent) {\n const nodes = parent.children\n let index = -1\n while (++index < nodes.length) {\n const result = state.one(nodes[index], parent)\n\n // To do: see if we van clean this? Can we merge texts?\n if (result) {\n if (index && nodes[index - 1].type === 'break') {\n if (!Array.isArray(result) && result.type === 'text') {\n result.value = trimMarkdownSpaceStart(result.value)\n }\n\n if (!Array.isArray(result) && result.type === 'element') {\n const head = result.children[0]\n\n if (head && head.type === 'text') {\n head.value = trimMarkdownSpaceStart(head.value)\n }\n }\n }\n\n if (Array.isArray(result)) {\n values.push(...result)\n } else {\n values.push(result)\n }\n }\n }\n }\n\n return values\n }\n}\n\n/**\n * Copy a node’s positional info.\n *\n * @param {MdastNodes} from\n * mdast node to copy from.\n * @param {HastNodes} to\n * hast node to copy into.\n * @returns {undefined}\n * Nothing.\n */\nfunction patch(from, to) {\n if (from.position) to.position = position(from)\n}\n\n/**\n * Honor the `data` of `from` and maybe generate an element instead of `to`.\n *\n * @template {HastNodes} Type\n * Node type.\n * @param {MdastNodes} from\n * mdast node to use data from.\n * @param {Type} to\n * hast node to change.\n * @returns {HastElement | Type}\n * Nothing.\n */\nfunction applyData(from, to) {\n /** @type {HastElement | Type} */\n let result = to\n\n // Handle `data.hName`, `data.hProperties, `data.hChildren`.\n if (from && from.data) {\n const hName = from.data.hName\n const hChildren = from.data.hChildren\n const hProperties = from.data.hProperties\n\n if (typeof hName === 'string') {\n // Transforming the node resulted in an element with a different name\n // than wanted:\n if (result.type === 'element') {\n result.tagName = hName\n }\n // Transforming the node resulted in a non-element, which happens for\n // raw, text, and root nodes (unless custom handlers are passed).\n // The intent of `hName` is to create an element, but likely also to keep\n // the content around (otherwise: pass `hChildren`).\n else {\n /** @type {Array} */\n // @ts-expect-error: assume no doctypes in `root`.\n const children = 'children' in result ? result.children : [result]\n result = {type: 'element', tagName: hName, properties: {}, children}\n }\n }\n\n if (result.type === 'element' && hProperties) {\n Object.assign(result.properties, structuredClone(hProperties))\n }\n\n if (\n 'children' in result &&\n result.children &&\n hChildren !== null &&\n hChildren !== undefined\n ) {\n result.children = hChildren\n }\n }\n\n return result\n}\n\n/**\n * Transform an unknown node.\n *\n * @param {State} state\n * Info passed around.\n * @param {MdastNodes} node\n * Unknown mdast node.\n * @returns {HastElement | HastText}\n * Resulting hast node.\n */\nfunction defaultUnknownHandler(state, node) {\n const data = node.data || {}\n /** @type {HastElement | HastText} */\n const result =\n 'value' in node &&\n !(own.call(data, 'hProperties') || own.call(data, 'hChildren'))\n ? {type: 'text', value: node.value}\n : {\n type: 'element',\n tagName: 'div',\n properties: {},\n children: state.all(node)\n }\n\n state.patch(node, result)\n return state.applyData(node, result)\n}\n\n/**\n * Wrap `nodes` with line endings between each node.\n *\n * @template {HastRootContent} Type\n * Node type.\n * @param {Array} nodes\n * List of nodes to wrap.\n * @param {boolean | undefined} [loose=false]\n * Whether to add line endings at start and end (default: `false`).\n * @returns {Array}\n * Wrapped nodes.\n */\nexport function wrap(nodes, loose) {\n /** @type {Array} */\n const result = []\n let index = -1\n\n if (loose) {\n result.push({type: 'text', value: '\\n'})\n }\n\n while (++index < nodes.length) {\n if (index) result.push({type: 'text', value: '\\n'})\n result.push(nodes[index])\n }\n\n if (loose && nodes.length > 0) {\n result.push({type: 'text', value: '\\n'})\n }\n\n return result\n}\n\n/**\n * Trim spaces and tabs at the start of `value`.\n *\n * @param {string} value\n * Value to trim.\n * @returns {string}\n * Result.\n */\nfunction trimMarkdownSpaceStart(value) {\n let index = 0\n let code = value.charCodeAt(index)\n\n while (code === 9 || code === 32) {\n index++\n code = value.charCodeAt(index)\n }\n\n return value.slice(index)\n}\n","/**\n * @typedef {import('hast').Nodes} HastNodes\n * @typedef {import('mdast').Nodes} MdastNodes\n * @typedef {import('./state.js').Options} Options\n */\n\nimport {ok as assert} from 'devlop'\nimport {footer} from './footer.js'\nimport {createState} from './state.js'\n\n/**\n * Transform mdast to hast.\n *\n * ##### Notes\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most utilities ignore `raw` nodes but two notable ones don’t:\n *\n * * `hast-util-to-html` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful\n * if you completely trust authors\n * * `hast-util-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc).\n * This is a heavy task as it needs a full HTML parser, but it is the only\n * way to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark, which we follow by default.\n * They are supported by GitHub, so footnotes can be enabled in markdown with\n * `mdast-util-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes, which is hidden for sighted users but shown to\n * assistive technology.\n * When your page is not in English, you must define translated values.\n *\n * Back references use ARIA attributes, but the section label itself uses a\n * heading that is hidden with an `sr-only` class.\n * To show it to sighted users, define different attributes in\n * `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem, as it links footnote calls to footnote\n * definitions on the page through `id` attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n *

\n * \n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * Example: headings (DOM clobbering) in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value` (and doesn’t have `data.hName`,\n * `data.hProperties`, or `data.hChildren`, see later), create a hast `text`\n * node\n * * otherwise, create a `
` element (which could be changed with\n * `data.hName`), with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @param {MdastNodes} tree\n * mdast tree.\n * @param {Options | null | undefined} [options]\n * Configuration (optional).\n * @returns {HastNodes}\n * hast tree.\n */\nexport function toHast(tree, options) {\n const state = createState(tree, options)\n const node = state.one(tree, undefined)\n const foot = footer(state)\n /** @type {HastNodes} */\n const result = Array.isArray(node)\n ? {type: 'root', children: node}\n : node || {type: 'root', children: []}\n\n if (foot) {\n // If there’s a footer, there were definitions, meaning block\n // content.\n // So `result` is a parent node.\n assert('children' in result)\n result.children.push({type: 'text', value: '\\n'}, foot)\n }\n\n return result\n}\n","// Include `data` fields in mdast and `raw` nodes in hast.\n/// \n\n/**\n * @import {Root as HastRoot} from 'hast'\n * @import {Root as MdastRoot} from 'mdast'\n * @import {Options as ToHastOptions} from 'mdast-util-to-hast'\n * @import {Processor} from 'unified'\n * @import {VFile} from 'vfile'\n */\n\n/**\n * @typedef {Omit} Options\n *\n * @callback TransformBridge\n * Bridge-mode.\n *\n * Runs the destination with the new hast tree.\n * Discards result.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {Promise}\n * Nothing.\n *\n * @callback TransformMutate\n * Mutate-mode.\n *\n * Further transformers run on the hast tree.\n * @param {MdastRoot} tree\n * Tree.\n * @param {VFile} file\n * File.\n * @returns {HastRoot}\n * Tree (hast).\n */\n\nimport {toHast} from 'mdast-util-to-hast'\n\n/**\n * Turn markdown into HTML.\n *\n * ##### Notes\n *\n * ###### Signature\n *\n * * if a processor is given, runs the (rehype) plugins used on it with a\n * hast tree, then discards the result (*bridge mode*)\n * * otherwise, returns a hast tree, the plugins used after `remarkRehype`\n * are rehype plugins (*mutate mode*)\n *\n * > πŸ‘‰ **Note**: It’s highly unlikely that you want to pass a `processor`.\n *\n * ###### HTML\n *\n * Raw HTML is available in mdast as `html` nodes and can be embedded in hast\n * as semistandard `raw` nodes.\n * Most plugins ignore `raw` nodes but two notable ones don’t:\n *\n * * `rehype-stringify` also has an option `allowDangerousHtml` which will\n * output the raw HTML.\n * This is typically discouraged as noted by the option name but is useful if\n * you completely trust authors\n * * `rehype-raw` can handle the raw embedded HTML strings by parsing them\n * into standard hast nodes (`element`, `text`, etc).\n * This is a heavy task as it needs a full HTML parser, but it is the only way\n * to support untrusted content\n *\n * ###### Footnotes\n *\n * Many options supported here relate to footnotes.\n * Footnotes are not specified by CommonMark, which we follow by default.\n * They are supported by GitHub, so footnotes can be enabled in markdown with\n * `remark-gfm`.\n *\n * The options `footnoteBackLabel` and `footnoteLabel` define natural language\n * that explains footnotes, which is hidden for sighted users but shown to\n * assistive technology.\n * When your page is not in English, you must define translated values.\n *\n * Back references use ARIA attributes, but the section label itself uses a\n * heading that is hidden with an `sr-only` class.\n * To show it to sighted users, define different attributes in\n * `footnoteLabelProperties`.\n *\n * ###### Clobbering\n *\n * Footnotes introduces a problem, as it links footnote calls to footnote\n * definitions on the page through `id` attributes generated from user content,\n * which results in DOM clobbering.\n *\n * DOM clobbering is this:\n *\n * ```html\n *

\n * \n * ```\n *\n * Elements by their ID are made available by browsers on the `window` object,\n * which is a security risk.\n * Using a prefix solves this problem.\n *\n * More information on how to handle clobbering and the prefix is explained in\n * *Example: headings (DOM clobbering)* in `rehype-sanitize`.\n *\n * ###### Unknown nodes\n *\n * Unknown nodes are nodes with a type that isn’t in `handlers` or `passThrough`.\n * The default behavior for unknown nodes is:\n *\n * * when the node has a `value` (and doesn’t have `data.hName`,\n * `data.hProperties`, or `data.hChildren`, see later), create a hast `text`\n * node\n * * otherwise, create a `
` element (which could be changed with\n * `data.hName`), with its children mapped from mdast to hast as well\n *\n * This behavior can be changed by passing an `unknownHandler`.\n *\n * @overload\n * @param {Processor} processor\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformBridge}\n *\n * @overload\n * @param {Readonly | null | undefined} [options]\n * @returns {TransformMutate}\n *\n * @param {Readonly | Processor | null | undefined} [destination]\n * Processor or configuration (optional).\n * @param {Readonly | null | undefined} [options]\n * When a processor was given, configuration (optional).\n * @returns {TransformBridge | TransformMutate}\n * Transform.\n */\nexport default function remarkRehype(destination, options) {\n if (destination && 'run' in destination) {\n /**\n * @type {TransformBridge}\n */\n return async function (tree, file) {\n // Cast because root in -> root out.\n const hastTree = /** @type {HastRoot} */ (\n toHast(tree, {file, ...options})\n )\n await destination.run(hastTree, file)\n }\n }\n\n /**\n * @type {TransformMutate}\n */\n return function (tree, file) {\n // Cast because root in -> root out.\n // To do: in the future, disallow ` || options` fallback.\n // With `unified-engine`, `destination` can be `undefined` but\n // `options` will be the file set.\n // We should not pass that as `options`.\n return /** @type {HastRoot} */ (\n toHast(tree, {file, ...(destination || options)})\n )\n }\n}\n","/**\n * Throw a given error.\n *\n * @param {Error|null|undefined} [error]\n * Maybe error.\n * @returns {asserts error is null|undefined}\n */\nexport function bail(error) {\n if (error) {\n throw error\n }\n}\n","export default function isPlainObject(value) {\n\tif (typeof value !== 'object' || value === null) {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value);\n\treturn (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in value) && !(Symbol.iterator in value);\n}\n","// To do: remove `void`s\n// To do: remove `null` from output of our APIs, allow it as user APIs.\n\n/**\n * @typedef {(error?: Error | null | undefined, ...output: Array) => void} Callback\n * Callback.\n *\n * @typedef {(...input: Array) => any} Middleware\n * Ware.\n *\n * @typedef Pipeline\n * Pipeline.\n * @property {Run} run\n * Run the pipeline.\n * @property {Use} use\n * Add middleware.\n *\n * @typedef {(...input: Array) => void} Run\n * Call all middleware.\n *\n * Calls `done` on completion with either an error or the output of the\n * last middleware.\n *\n * > πŸ‘‰ **Note**: as the length of input defines whether async functions get a\n * > `next` function,\n * > it’s recommended to keep `input` at one value normally.\n\n *\n * @typedef {(fn: Middleware) => Pipeline} Use\n * Add middleware.\n */\n\n/**\n * Create new middleware.\n *\n * @returns {Pipeline}\n * Pipeline.\n */\nexport function trough() {\n /** @type {Array} */\n const fns = []\n /** @type {Pipeline} */\n const pipeline = {run, use}\n\n return pipeline\n\n /** @type {Run} */\n function run(...values) {\n let middlewareIndex = -1\n /** @type {Callback} */\n const callback = values.pop()\n\n if (typeof callback !== 'function') {\n throw new TypeError('Expected function as last argument, not ' + callback)\n }\n\n next(null, ...values)\n\n /**\n * Run the next `fn`, or we’re done.\n *\n * @param {Error | null | undefined} error\n * @param {Array} output\n */\n function next(error, ...output) {\n const fn = fns[++middlewareIndex]\n let index = -1\n\n if (error) {\n callback(error)\n return\n }\n\n // Copy non-nullish input into values.\n while (++index < values.length) {\n if (output[index] === null || output[index] === undefined) {\n output[index] = values[index]\n }\n }\n\n // Save the newly created `output` for the next call.\n values = output\n\n // Next or done.\n if (fn) {\n wrap(fn, next)(...output)\n } else {\n callback(null, ...output)\n }\n }\n }\n\n /** @type {Use} */\n function use(middelware) {\n if (typeof middelware !== 'function') {\n throw new TypeError(\n 'Expected `middelware` to be a function, not ' + middelware\n )\n }\n\n fns.push(middelware)\n return pipeline\n }\n}\n\n/**\n * Wrap `middleware` into a uniform interface.\n *\n * You can pass all input to the resulting function.\n * `callback` is then called with the output of `middleware`.\n *\n * If `middleware` accepts more arguments than the later given in input,\n * an extra `done` function is passed to it after that input,\n * which must be called by `middleware`.\n *\n * The first value in `input` is the main input value.\n * All other input values are the rest input values.\n * The values given to `callback` are the input values,\n * merged with every non-nullish output value.\n *\n * * if `middleware` throws an error,\n * returns a promise that is rejected,\n * or calls the given `done` function with an error,\n * `callback` is called with that error\n * * if `middleware` returns a value or returns a promise that is resolved,\n * that value is the main output value\n * * if `middleware` calls `done`,\n * all non-nullish values except for the first one (the error) overwrite the\n * output values\n *\n * @param {Middleware} middleware\n * Function to wrap.\n * @param {Callback} callback\n * Callback called with the output of `middleware`.\n * @returns {Run}\n * Wrapped middleware.\n */\nexport function wrap(middleware, callback) {\n /** @type {boolean} */\n let called\n\n return wrapped\n\n /**\n * Call `middleware`.\n * @this {any}\n * @param {Array} parameters\n * @returns {void}\n */\n function wrapped(...parameters) {\n const fnExpectsCallback = middleware.length > parameters.length\n /** @type {any} */\n let result\n\n if (fnExpectsCallback) {\n parameters.push(done)\n }\n\n try {\n result = middleware.apply(this, parameters)\n } catch (error) {\n const exception = /** @type {Error} */ (error)\n\n // Well, this is quite the pickle.\n // `middleware` received a callback and called it synchronously, but that\n // threw an error.\n // The only thing left to do is to throw the thing instead.\n if (fnExpectsCallback && called) {\n throw exception\n }\n\n return done(exception)\n }\n\n if (!fnExpectsCallback) {\n if (result && result.then && typeof result.then === 'function') {\n result.then(then, done)\n } else if (result instanceof Error) {\n done(result)\n } else {\n then(result)\n }\n }\n }\n\n /**\n * Call `callback`, only once.\n *\n * @type {Callback}\n */\n function done(error, ...output) {\n if (!called) {\n called = true\n callback(error, ...output)\n }\n }\n\n /**\n * Call `done` with one value.\n *\n * @param {any} [value]\n */\n function then(value) {\n done(null, value)\n }\n}\n","// A derivative work based on:\n// .\n// Which is licensed:\n//\n// MIT License\n//\n// Copyright (c) 2013 James Halliday\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of\n// this software and associated documentation files (the \"Software\"), to deal in\n// the Software without restriction, including without limitation the rights to\n// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\n// the Software, and to permit persons to whom the Software is furnished to do so,\n// subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\n// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\n// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\n// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\n// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n// A derivative work based on:\n//\n// Parts of that are extracted from Node’s internal `path` module:\n// .\n// Which is licensed:\n//\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nexport const minpath = {basename, dirname, extname, join, sep: '/'}\n\n/* eslint-disable max-depth, complexity */\n\n/**\n * Get the basename from a path.\n *\n * @param {string} path\n * File path.\n * @param {string | null | undefined} [extname]\n * Extension to strip.\n * @returns {string}\n * Stem or basename.\n */\nfunction basename(path, extname) {\n if (extname !== undefined && typeof extname !== 'string') {\n throw new TypeError('\"ext\" argument must be a string')\n }\n\n assertPath(path)\n let start = 0\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let seenNonSlash\n\n if (\n extname === undefined ||\n extname.length === 0 ||\n extname.length > path.length\n ) {\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // path component.\n seenNonSlash = true\n end = index + 1\n }\n }\n\n return end < 0 ? '' : path.slice(start, end)\n }\n\n if (extname === path) {\n return ''\n }\n\n let firstNonSlashEnd = -1\n let extnameIndex = extname.length - 1\n\n while (index--) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (seenNonSlash) {\n start = index + 1\n break\n }\n } else {\n if (firstNonSlashEnd < 0) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching.\n seenNonSlash = true\n firstNonSlashEnd = index + 1\n }\n\n if (extnameIndex > -1) {\n // Try to match the explicit extension.\n if (path.codePointAt(index) === extname.codePointAt(extnameIndex--)) {\n if (extnameIndex < 0) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = index\n }\n } else {\n // Extension does not match, so our result is the entire path\n // component\n extnameIndex = -1\n end = firstNonSlashEnd\n }\n }\n }\n }\n\n if (start === end) {\n end = firstNonSlashEnd\n } else if (end < 0) {\n end = path.length\n }\n\n return path.slice(start, end)\n}\n\n/**\n * Get the dirname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\nfunction dirname(path) {\n assertPath(path)\n\n if (path.length === 0) {\n return '.'\n }\n\n let end = -1\n let index = path.length\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n // Prefix `--` is important to not run on `0`.\n while (--index) {\n if (path.codePointAt(index) === 47 /* `/` */) {\n if (unmatchedSlash) {\n end = index\n break\n }\n } else if (!unmatchedSlash) {\n // We saw the first non-path separator\n unmatchedSlash = true\n }\n }\n\n return end < 0\n ? path.codePointAt(0) === 47 /* `/` */\n ? '/'\n : '.'\n : end === 1 && path.codePointAt(0) === 47 /* `/` */\n ? '//'\n : path.slice(0, end)\n}\n\n/**\n * Get an extname from a path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * Extname.\n */\nfunction extname(path) {\n assertPath(path)\n\n let index = path.length\n\n let end = -1\n let startPart = 0\n let startDot = -1\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find.\n let preDotState = 0\n /** @type {boolean | undefined} */\n let unmatchedSlash\n\n while (index--) {\n const code = path.codePointAt(index)\n\n if (code === 47 /* `/` */) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now.\n if (unmatchedSlash) {\n startPart = index + 1\n break\n }\n\n continue\n }\n\n if (end < 0) {\n // We saw the first non-path separator, mark this as the end of our\n // extension.\n unmatchedSlash = true\n end = index + 1\n }\n\n if (code === 46 /* `.` */) {\n // If this is our first dot, mark it as the start of our extension.\n if (startDot < 0) {\n startDot = index\n } else if (preDotState !== 1) {\n preDotState = 1\n }\n } else if (startDot > -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension.\n preDotState = -1\n }\n }\n\n if (\n startDot < 0 ||\n end < 0 ||\n // We saw a non-dot character immediately before the dot.\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly `..`.\n (preDotState === 1 && startDot === end - 1 && startDot === startPart + 1)\n ) {\n return ''\n }\n\n return path.slice(startDot, end)\n}\n\n/**\n * Join segments from a path.\n *\n * @param {Array} segments\n * Path segments.\n * @returns {string}\n * File path.\n */\nfunction join(...segments) {\n let index = -1\n /** @type {string | undefined} */\n let joined\n\n while (++index < segments.length) {\n assertPath(segments[index])\n\n if (segments[index]) {\n joined =\n joined === undefined ? segments[index] : joined + '/' + segments[index]\n }\n }\n\n return joined === undefined ? '.' : normalize(joined)\n}\n\n/**\n * Normalize a basic file path.\n *\n * @param {string} path\n * File path.\n * @returns {string}\n * File path.\n */\n// Note: `normalize` is not exposed as `path.normalize`, so some code is\n// manually removed from it.\nfunction normalize(path) {\n assertPath(path)\n\n const absolute = path.codePointAt(0) === 47 /* `/` */\n\n // Normalize the path according to POSIX rules.\n let value = normalizeString(path, !absolute)\n\n if (value.length === 0 && !absolute) {\n value = '.'\n }\n\n if (value.length > 0 && path.codePointAt(path.length - 1) === 47 /* / */) {\n value += '/'\n }\n\n return absolute ? '/' + value : value\n}\n\n/**\n * Resolve `.` and `..` elements in a path with directory names.\n *\n * @param {string} path\n * File path.\n * @param {boolean} allowAboveRoot\n * Whether `..` can move above root.\n * @returns {string}\n * File path.\n */\nfunction normalizeString(path, allowAboveRoot) {\n let result = ''\n let lastSegmentLength = 0\n let lastSlash = -1\n let dots = 0\n let index = -1\n /** @type {number | undefined} */\n let code\n /** @type {number} */\n let lastSlashIndex\n\n while (++index <= path.length) {\n if (index < path.length) {\n code = path.codePointAt(index)\n } else if (code === 47 /* `/` */) {\n break\n } else {\n code = 47 /* `/` */\n }\n\n if (code === 47 /* `/` */) {\n if (lastSlash === index - 1 || dots === 1) {\n // Empty.\n } else if (lastSlash !== index - 1 && dots === 2) {\n if (\n result.length < 2 ||\n lastSegmentLength !== 2 ||\n result.codePointAt(result.length - 1) !== 46 /* `.` */ ||\n result.codePointAt(result.length - 2) !== 46 /* `.` */\n ) {\n if (result.length > 2) {\n lastSlashIndex = result.lastIndexOf('/')\n\n if (lastSlashIndex !== result.length - 1) {\n if (lastSlashIndex < 0) {\n result = ''\n lastSegmentLength = 0\n } else {\n result = result.slice(0, lastSlashIndex)\n lastSegmentLength = result.length - 1 - result.lastIndexOf('/')\n }\n\n lastSlash = index\n dots = 0\n continue\n }\n } else if (result.length > 0) {\n result = ''\n lastSegmentLength = 0\n lastSlash = index\n dots = 0\n continue\n }\n }\n\n if (allowAboveRoot) {\n result = result.length > 0 ? result + '/..' : '..'\n lastSegmentLength = 2\n }\n } else {\n if (result.length > 0) {\n result += '/' + path.slice(lastSlash + 1, index)\n } else {\n result = path.slice(lastSlash + 1, index)\n }\n\n lastSegmentLength = index - lastSlash - 1\n }\n\n lastSlash = index\n dots = 0\n } else if (code === 46 /* `.` */ && dots > -1) {\n dots++\n } else {\n dots = -1\n }\n }\n\n return result\n}\n\n/**\n * Make sure `path` is a string.\n *\n * @param {string} path\n * File path.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path) {\n if (typeof path !== 'string') {\n throw new TypeError(\n 'Path must be a string. Received ' + JSON.stringify(path)\n )\n }\n}\n\n/* eslint-enable max-depth, complexity */\n","// Somewhat based on:\n// .\n// But I don’t think one tiny line of code can be copyrighted. πŸ˜…\nexport const minproc = {cwd}\n\nfunction cwd() {\n return '/'\n}\n","/**\n * Checks if a value has the shape of a WHATWG URL object.\n *\n * Using a symbol or instanceof would not be able to recognize URL objects\n * coming from other implementations (e.g. in Electron), so instead we are\n * checking some well known properties for a lack of a better test.\n *\n * We use `href` and `protocol` as they are the only properties that are\n * easy to retrieve and calculate due to the lazy nature of the getters.\n *\n * We check for auth attribute to distinguish legacy url instance with\n * WHATWG URL instance.\n *\n * @param {unknown} fileUrlOrPath\n * File path or URL.\n * @returns {fileUrlOrPath is URL}\n * Whether it’s a URL.\n */\n// From: \nexport function isUrl(fileUrlOrPath) {\n return Boolean(\n fileUrlOrPath !== null &&\n typeof fileUrlOrPath === 'object' &&\n 'href' in fileUrlOrPath &&\n fileUrlOrPath.href &&\n 'protocol' in fileUrlOrPath &&\n fileUrlOrPath.protocol &&\n // @ts-expect-error: indexing is fine.\n fileUrlOrPath.auth === undefined\n )\n}\n","import {isUrl} from './minurl.shared.js'\n\nexport {isUrl} from './minurl.shared.js'\n\n// See: \n\n/**\n * @param {URL | string} path\n * File URL.\n * @returns {string}\n * File URL.\n */\nexport function urlToPath(path) {\n if (typeof path === 'string') {\n path = new URL(path)\n } else if (!isUrl(path)) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'The \"path\" argument must be of type string or an instance of URL. Received `' +\n path +\n '`'\n )\n error.code = 'ERR_INVALID_ARG_TYPE'\n throw error\n }\n\n if (path.protocol !== 'file:') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError('The URL must be of scheme file')\n error.code = 'ERR_INVALID_URL_SCHEME'\n throw error\n }\n\n return getPathFromURLPosix(path)\n}\n\n/**\n * Get a path from a POSIX URL.\n *\n * @param {URL} url\n * URL.\n * @returns {string}\n * File path.\n */\nfunction getPathFromURLPosix(url) {\n if (url.hostname !== '') {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL host must be \"localhost\" or empty on darwin'\n )\n error.code = 'ERR_INVALID_FILE_URL_HOST'\n throw error\n }\n\n const pathname = url.pathname\n let index = -1\n\n while (++index < pathname.length) {\n if (\n pathname.codePointAt(index) === 37 /* `%` */ &&\n pathname.codePointAt(index + 1) === 50 /* `2` */\n ) {\n const third = pathname.codePointAt(index + 2)\n if (third === 70 /* `F` */ || third === 102 /* `f` */) {\n /** @type {NodeJS.ErrnoException} */\n const error = new TypeError(\n 'File URL path must not include encoded / characters'\n )\n error.code = 'ERR_INVALID_FILE_URL_PATH'\n throw error\n }\n }\n }\n\n return decodeURIComponent(pathname)\n}\n","/**\n * @import {Node, Point, Position} from 'unist'\n * @import {Options as MessageOptions} from 'vfile-message'\n * @import {Compatible, Data, Map, Options, Value} from 'vfile'\n */\n\n/**\n * @typedef {object & {type: string, position?: Position | undefined}} NodeLike\n */\n\nimport {VFileMessage} from 'vfile-message'\nimport {minpath} from '#minpath'\nimport {minproc} from '#minproc'\nimport {urlToPath, isUrl} from '#minurl'\n\n/**\n * Order of setting (least specific to most), we need this because otherwise\n * `{stem: 'a', path: '~/b.js'}` would throw, as a path is needed before a\n * stem can be set.\n */\nconst order = /** @type {const} */ ([\n 'history',\n 'path',\n 'basename',\n 'stem',\n 'extname',\n 'dirname'\n])\n\nexport class VFile {\n /**\n * Create a new virtual file.\n *\n * `options` is treated as:\n *\n * * `string` or `Uint8Array` β€” `{value: options}`\n * * `URL` β€” `{path: options}`\n * * `VFile` β€” shallow copies its data over to the new file\n * * `object` β€” all fields are shallow copied over to the new file\n *\n * Path related fields are set in the following order (least specific to\n * most specific): `history`, `path`, `basename`, `stem`, `extname`,\n * `dirname`.\n *\n * You cannot set `dirname` or `extname` without setting either `history`,\n * `path`, `basename`, or `stem` too.\n *\n * @param {Compatible | null | undefined} [value]\n * File value.\n * @returns\n * New instance.\n */\n constructor(value) {\n /** @type {Options | VFile} */\n let options\n\n if (!value) {\n options = {}\n } else if (isUrl(value)) {\n options = {path: value}\n } else if (typeof value === 'string' || isUint8Array(value)) {\n options = {value}\n } else {\n options = value\n }\n\n /* eslint-disable no-unused-expressions */\n\n /**\n * Base of `path` (default: `process.cwd()` or `'/'` in browsers).\n *\n * @type {string}\n */\n // Prevent calling `cwd` (which could be expensive) if it’s not needed;\n // the empty string will be overridden in the next block.\n this.cwd = 'cwd' in options ? '' : minproc.cwd()\n\n /**\n * Place to store custom info (default: `{}`).\n *\n * It’s OK to store custom data directly on the file but moving it to\n * `data` is recommended.\n *\n * @type {Data}\n */\n this.data = {}\n\n /**\n * List of file paths the file moved between.\n *\n * The first is the original path and the last is the current path.\n *\n * @type {Array}\n */\n this.history = []\n\n /**\n * List of messages associated with the file.\n *\n * @type {Array}\n */\n this.messages = []\n\n /**\n * Raw value.\n *\n * @type {Value}\n */\n this.value\n\n // The below are non-standard, they are β€œwell-known”.\n // As in, used in several tools.\n /**\n * Source map.\n *\n * This type is equivalent to the `RawSourceMap` type from the `source-map`\n * module.\n *\n * @type {Map | null | undefined}\n */\n this.map\n\n /**\n * Custom, non-string, compiled, representation.\n *\n * This is used by unified to store non-string results.\n * One example is when turning markdown into React nodes.\n *\n * @type {unknown}\n */\n this.result\n\n /**\n * Whether a file was saved to disk.\n *\n * This is used by vfile reporters.\n *\n * @type {boolean}\n */\n this.stored\n /* eslint-enable no-unused-expressions */\n\n // Set path related properties in the correct order.\n let index = -1\n\n while (++index < order.length) {\n const field = order[index]\n\n // Note: we specifically use `in` instead of `hasOwnProperty` to accept\n // `vfile`s too.\n if (\n field in options &&\n options[field] !== undefined &&\n options[field] !== null\n ) {\n // @ts-expect-error: TS doesn’t understand basic reality.\n this[field] = field === 'history' ? [...options[field]] : options[field]\n }\n }\n\n /** @type {string} */\n let field\n\n // Set non-path related properties.\n for (field in options) {\n // @ts-expect-error: fine to set other things.\n if (!order.includes(field)) {\n // @ts-expect-error: fine to set other things.\n this[field] = options[field]\n }\n }\n }\n\n /**\n * Get the basename (including extname) (example: `'index.min.js'`).\n *\n * @returns {string | undefined}\n * Basename.\n */\n get basename() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path)\n : undefined\n }\n\n /**\n * Set basename (including extname) (`'index.min.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} basename\n * Basename.\n * @returns {undefined}\n * Nothing.\n */\n set basename(basename) {\n assertNonEmpty(basename, 'basename')\n assertPart(basename, 'basename')\n this.path = minpath.join(this.dirname || '', basename)\n }\n\n /**\n * Get the parent path (example: `'~'`).\n *\n * @returns {string | undefined}\n * Dirname.\n */\n get dirname() {\n return typeof this.path === 'string'\n ? minpath.dirname(this.path)\n : undefined\n }\n\n /**\n * Set the parent path (example: `'~'`).\n *\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} dirname\n * Dirname.\n * @returns {undefined}\n * Nothing.\n */\n set dirname(dirname) {\n assertPath(this.basename, 'dirname')\n this.path = minpath.join(dirname || '', this.basename)\n }\n\n /**\n * Get the extname (including dot) (example: `'.js'`).\n *\n * @returns {string | undefined}\n * Extname.\n */\n get extname() {\n return typeof this.path === 'string'\n ? minpath.extname(this.path)\n : undefined\n }\n\n /**\n * Set the extname (including dot) (example: `'.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be set if there’s no `path` yet.\n *\n * @param {string | undefined} extname\n * Extname.\n * @returns {undefined}\n * Nothing.\n */\n set extname(extname) {\n assertPart(extname, 'extname')\n assertPath(this.dirname, 'extname')\n\n if (extname) {\n if (extname.codePointAt(0) !== 46 /* `.` */) {\n throw new Error('`extname` must start with `.`')\n }\n\n if (extname.includes('.', 1)) {\n throw new Error('`extname` cannot contain multiple dots')\n }\n }\n\n this.path = minpath.join(this.dirname, this.stem + (extname || ''))\n }\n\n /**\n * Get the full path (example: `'~/index.min.js'`).\n *\n * @returns {string}\n * Path.\n */\n get path() {\n return this.history[this.history.length - 1]\n }\n\n /**\n * Set the full path (example: `'~/index.min.js'`).\n *\n * Cannot be nullified.\n * You can set a file URL (a `URL` object with a `file:` protocol) which will\n * be turned into a path with `url.fileURLToPath`.\n *\n * @param {URL | string} path\n * Path.\n * @returns {undefined}\n * Nothing.\n */\n set path(path) {\n if (isUrl(path)) {\n path = urlToPath(path)\n }\n\n assertNonEmpty(path, 'path')\n\n if (this.path !== path) {\n this.history.push(path)\n }\n }\n\n /**\n * Get the stem (basename w/o extname) (example: `'index.min'`).\n *\n * @returns {string | undefined}\n * Stem.\n */\n get stem() {\n return typeof this.path === 'string'\n ? minpath.basename(this.path, this.extname)\n : undefined\n }\n\n /**\n * Set the stem (basename w/o extname) (example: `'index.min'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n *\n * @param {string} stem\n * Stem.\n * @returns {undefined}\n * Nothing.\n */\n set stem(stem) {\n assertNonEmpty(stem, 'stem')\n assertPart(stem, 'stem')\n this.path = minpath.join(this.dirname || '', stem + (this.extname || ''))\n }\n\n // Normal prototypal methods.\n /**\n * Create a fatal message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `true` (error; file not usable)\n * and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > πŸͺ¦ **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {never}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {never}\n * Never.\n * @throws {VFileMessage}\n * Message.\n */\n fail(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = true\n\n throw message\n }\n\n /**\n * Create an info message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `undefined` (info; change\n * likely not needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > πŸͺ¦ **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n info(causeOrReason, optionsOrParentOrPlace, origin) {\n // @ts-expect-error: the overloads are fine.\n const message = this.message(causeOrReason, optionsOrParentOrPlace, origin)\n\n message.fatal = undefined\n\n return message\n }\n\n /**\n * Create a message for `reason` associated with the file.\n *\n * The `fatal` field of the message is set to `false` (warning; change may be\n * needed) and the `file` field is set to the current file path.\n * The message is added to the `messages` field on `file`.\n *\n * > πŸͺ¦ **Note**: also has obsolete signatures.\n *\n * @overload\n * @param {string} reason\n * @param {MessageOptions | null | undefined} [options]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {string} reason\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Node | NodeLike | null | undefined} parent\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {Point | Position | null | undefined} place\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @overload\n * @param {Error | VFileMessage} cause\n * @param {string | null | undefined} [origin]\n * @returns {VFileMessage}\n *\n * @param {Error | VFileMessage | string} causeOrReason\n * Reason for message, should use markdown.\n * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]\n * Configuration (optional).\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */\n message(causeOrReason, optionsOrParentOrPlace, origin) {\n const message = new VFileMessage(\n // @ts-expect-error: the overloads are fine.\n causeOrReason,\n optionsOrParentOrPlace,\n origin\n )\n\n if (this.path) {\n message.name = this.path + ':' + message.name\n message.file = this.path\n }\n\n message.fatal = false\n\n this.messages.push(message)\n\n return message\n }\n\n /**\n * Serialize the file.\n *\n * > **Note**: which encodings are supported depends on the engine.\n * > For info on Node.js, see:\n * > .\n *\n * @param {string | null | undefined} [encoding='utf8']\n * Character encoding to understand `value` as when it’s a `Uint8Array`\n * (default: `'utf-8'`).\n * @returns {string}\n * Serialized file.\n */\n toString(encoding) {\n if (this.value === undefined) {\n return ''\n }\n\n if (typeof this.value === 'string') {\n return this.value\n }\n\n const decoder = new TextDecoder(encoding || undefined)\n return decoder.decode(this.value)\n }\n}\n\n/**\n * Assert that `part` is not a path (as in, does not contain `path.sep`).\n *\n * @param {string | null | undefined} part\n * File path part.\n * @param {string} name\n * Part name.\n * @returns {undefined}\n * Nothing.\n */\nfunction assertPart(part, name) {\n if (part && part.includes(minpath.sep)) {\n throw new Error(\n '`' + name + '` cannot be a path: did not expect `' + minpath.sep + '`'\n )\n }\n}\n\n/**\n * Assert that `part` is not empty.\n *\n * @param {string | undefined} part\n * Thing.\n * @param {string} name\n * Part name.\n * @returns {asserts part is string}\n * Nothing.\n */\nfunction assertNonEmpty(part, name) {\n if (!part) {\n throw new Error('`' + name + '` cannot be empty')\n }\n}\n\n/**\n * Assert `path` exists.\n *\n * @param {string | undefined} path\n * Path.\n * @param {string} name\n * Dependency name.\n * @returns {asserts path is string}\n * Nothing.\n */\nfunction assertPath(path, name) {\n if (!path) {\n throw new Error('Setting `' + name + '` requires `path` to be set too')\n }\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","export const CallableInstance =\n /**\n * @type {new , Result>(property: string | symbol) => (...parameters: Parameters) => Result}\n */\n (\n /** @type {unknown} */\n (\n /**\n * @this {Function}\n * @param {string | symbol} property\n * @returns {(...parameters: Array) => unknown}\n */\n function (property) {\n const self = this\n const constr = self.constructor\n const proto = /** @type {Record} */ (\n // Prototypes do exist.\n // type-coverage:ignore-next-line\n constr.prototype\n )\n const value = proto[property]\n /** @type {(...parameters: Array) => unknown} */\n const apply = function () {\n return value.apply(apply, arguments)\n }\n\n Object.setPrototypeOf(apply, proto)\n\n // Not needed for us in `unified`: we only call this on the `copy`\n // function,\n // and we don't need to add its fields (`length`, `name`)\n // over.\n // See also: GH-246.\n // const names = Object.getOwnPropertyNames(value)\n //\n // for (const p of names) {\n // const descriptor = Object.getOwnPropertyDescriptor(value, p)\n // if (descriptor) Object.defineProperty(apply, p, descriptor)\n // }\n\n return apply\n }\n )\n )\n","/**\n * @typedef {import('trough').Pipeline} Pipeline\n *\n * @typedef {import('unist').Node} Node\n *\n * @typedef {import('vfile').Compatible} Compatible\n * @typedef {import('vfile').Value} Value\n *\n * @typedef {import('../index.js').CompileResultMap} CompileResultMap\n * @typedef {import('../index.js').Data} Data\n * @typedef {import('../index.js').Settings} Settings\n */\n\n/**\n * @typedef {CompileResultMap[keyof CompileResultMap]} CompileResults\n * Acceptable results from compilers.\n *\n * To register custom results, add them to\n * {@linkcode CompileResultMap}.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the compiler receives (default: `Node`).\n * @template {CompileResults} [Result=CompileResults]\n * The thing that the compiler yields (default: `CompileResults`).\n * @callback Compiler\n * A **compiler** handles the compiling of a syntax tree to something else\n * (in most cases, text) (TypeScript type).\n *\n * It is used in the stringify phase and called with a {@linkcode Node}\n * and {@linkcode VFile} representation of the document to compile.\n * It should return the textual representation of the given tree (typically\n * `string`).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n * @param {Tree} tree\n * Tree to compile.\n * @param {VFile} file\n * File associated with `tree`.\n * @returns {Result}\n * New content: compiled text (`string` or `Uint8Array`, for `file.value`) or\n * something else (for `file.result`).\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The node that the parser yields (default: `Node`)\n * @callback Parser\n * A **parser** handles the parsing of text to a syntax tree.\n *\n * It is used in the parse phase and is called with a `string` and\n * {@linkcode VFile} of the document to parse.\n * It must return the syntax tree representation of the given file\n * ({@linkcode Node}).\n * @param {string} document\n * Document to parse.\n * @param {VFile} file\n * File associated with `document`.\n * @returns {Tree}\n * Node representing the given file.\n */\n\n/**\n * @typedef {(\n * Plugin, any, any> |\n * PluginTuple, any, any> |\n * Preset\n * )} Pluggable\n * Union of the different ways to add plugins and settings.\n */\n\n/**\n * @typedef {Array} PluggableList\n * List of plugins and presets.\n */\n\n// Note: we can’t use `callback` yet as it messes up `this`:\n// .\n/**\n * @template {Array} [PluginParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=Node]\n * Value that is expected as input (default: `Node`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=Input]\n * Value that is yielded as output (default: `Input`).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * (this: Processor, ...parameters: PluginParameters) =>\n * Input extends string ? // Parser.\n * Output extends Node | undefined ? undefined | void : never :\n * Output extends CompileResults ? // Compiler.\n * Input extends Node | undefined ? undefined | void : never :\n * Transformer<\n * Input extends Node ? Input : Node,\n * Output extends Node ? Output : Node\n * > | undefined | void\n * )} Plugin\n * Single plugin.\n *\n * Plugins configure the processors they are applied on in the following\n * ways:\n *\n * * they change the processor, such as the parser, the compiler, or by\n * configuring data\n * * they specify how to handle trees and files\n *\n * In practice, they are functions that can receive options and configure the\n * processor (`this`).\n *\n * > **Note**: plugins are called when the processor is *frozen*, not when\n * > they are applied.\n */\n\n/**\n * Tuple of a plugin and its configuration.\n *\n * The first item is a plugin, the rest are its parameters.\n *\n * @template {Array} [TupleParameters=[]]\n * Arguments passed to the plugin (default: `[]`, the empty tuple).\n * @template {Node | string | undefined} [Input=undefined]\n * Value that is expected as input (optional).\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node it expects.\n * * If the plugin sets a {@linkcode Parser}, this should be\n * `string`.\n * * If the plugin sets a {@linkcode Compiler}, this should be the\n * node it expects.\n * @template [Output=undefined] (optional).\n * Value that is yielded as output.\n *\n * * If the plugin returns a {@linkcode Transformer}, this\n * should be the node that that yields.\n * * If the plugin sets a {@linkcode Parser}, this should be the\n * node that it yields.\n * * If the plugin sets a {@linkcode Compiler}, this should be\n * result it yields.\n * @typedef {(\n * [\n * plugin: Plugin,\n * ...parameters: TupleParameters\n * ]\n * )} PluginTuple\n */\n\n/**\n * @typedef Preset\n * Sharable configuration.\n *\n * They can contain plugins and settings.\n * @property {PluggableList | undefined} [plugins]\n * List of plugins and presets (optional).\n * @property {Settings | undefined} [settings]\n * Shared settings for parsers and compilers (optional).\n */\n\n/**\n * @template {VFile} [File=VFile]\n * The file that the callback receives (default: `VFile`).\n * @callback ProcessCallback\n * Callback called when the process is done.\n *\n * Called with either an error or a result.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {File | undefined} [file]\n * Processed file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Tree=Node]\n * The tree that the callback receives (default: `Node`).\n * @callback RunCallback\n * Callback called when transformers are done.\n *\n * Called with either an error or results.\n * @param {Error | undefined} [error]\n * Fatal error (optional).\n * @param {Tree | undefined} [tree]\n * Transformed tree (optional).\n * @param {VFile | undefined} [file]\n * File (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Output=Node]\n * Node type that the transformer yields (default: `Node`).\n * @callback TransformCallback\n * Callback passed to transforms.\n *\n * If the signature of a `transformer` accepts a third argument, the\n * transformer may perform asynchronous operations, and must call it.\n * @param {Error | undefined} [error]\n * Fatal error to stop the process (optional).\n * @param {Output | undefined} [tree]\n * New, changed, tree (optional).\n * @param {VFile | undefined} [file]\n * New, changed, file (optional).\n * @returns {undefined}\n * Nothing.\n */\n\n/**\n * @template {Node} [Input=Node]\n * Node type that the transformer expects (default: `Node`).\n * @template {Node} [Output=Input]\n * Node type that the transformer yields (default: `Input`).\n * @callback Transformer\n * Transformers handle syntax trees and files.\n *\n * They are functions that are called each time a syntax tree and file are\n * passed through the run phase.\n * When an error occurs in them (either because it’s thrown, returned,\n * rejected, or passed to `next`), the process stops.\n *\n * The run phase is handled by [`trough`][trough], see its documentation for\n * the exact semantics of these functions.\n *\n * > **Note**: you should likely ignore `next`: don’t accept it.\n * > it supports callback-style async work.\n * > But promises are likely easier to reason about.\n *\n * [trough]: https://github.com/wooorm/trough#function-fninput-next\n * @param {Input} tree\n * Tree to handle.\n * @param {VFile} file\n * File to handle.\n * @param {TransformCallback} next\n * Callback.\n * @returns {(\n * Promise |\n * Promise | // For some reason this is needed separately.\n * Output |\n * Error |\n * undefined |\n * void\n * )}\n * If you accept `next`, nothing.\n * Otherwise:\n *\n * * `Error` β€” fatal error to stop the process\n * * `Promise` or `undefined` β€” the next transformer keeps using\n * same tree\n * * `Promise` or `Node` β€” new, changed, tree\n */\n\n/**\n * @template {Node | undefined} ParseTree\n * Output of `parse`.\n * @template {Node | undefined} HeadTree\n * Input for `run`.\n * @template {Node | undefined} TailTree\n * Output for `run`.\n * @template {Node | undefined} CompileTree\n * Input of `stringify`.\n * @template {CompileResults | undefined} CompileResult\n * Output of `stringify`.\n * @template {Node | string | undefined} Input\n * Input of plugin.\n * @template Output\n * Output of plugin (optional).\n * @typedef {(\n * Input extends string\n * ? Output extends Node | undefined\n * ? // Parser.\n * Processor<\n * Output extends undefined ? ParseTree : Output,\n * HeadTree,\n * TailTree,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor\n * : Output extends CompileResults\n * ? Input extends Node | undefined\n * ? // Compiler.\n * Processor<\n * ParseTree,\n * HeadTree,\n * TailTree,\n * Input extends undefined ? CompileTree : Input,\n * Output extends undefined ? CompileResult : Output\n * >\n * : // Unknown.\n * Processor\n * : Input extends Node | undefined\n * ? Output extends Node | undefined\n * ? // Transform.\n * Processor<\n * ParseTree,\n * HeadTree extends undefined ? Input : HeadTree,\n * Output extends undefined ? TailTree : Output,\n * CompileTree,\n * CompileResult\n * >\n * : // Unknown.\n * Processor\n * : // Unknown.\n * Processor\n * )} UsePlugin\n * Create a processor based on the input/output of a {@link Plugin plugin}.\n */\n\n/**\n * @template {CompileResults | undefined} Result\n * Node type that the transformer yields.\n * @typedef {(\n * Result extends Value | undefined ?\n * VFile :\n * VFile & {result: Result}\n * )} VFileWithOutput\n * Type to generate a {@linkcode VFile} corresponding to a compiler result.\n *\n * If a result that is not acceptable on a `VFile` is used, that will\n * be stored on the `result` field of {@linkcode VFile}.\n */\n\nimport {bail} from 'bail'\nimport extend from 'extend'\nimport {ok as assert} from 'devlop'\nimport isPlainObj from 'is-plain-obj'\nimport {trough} from 'trough'\nimport {VFile} from 'vfile'\nimport {CallableInstance} from './callable-instance.js'\n\n// To do: next major: drop `Compiler`, `Parser`: prefer lowercase.\n\n// To do: we could start yielding `never` in TS when a parser is missing and\n// `parse` is called.\n// Currently, we allow directly setting `processor.parser`, which is untyped.\n\nconst own = {}.hasOwnProperty\n\n/**\n * @template {Node | undefined} [ParseTree=undefined]\n * Output of `parse` (optional).\n * @template {Node | undefined} [HeadTree=undefined]\n * Input for `run` (optional).\n * @template {Node | undefined} [TailTree=undefined]\n * Output for `run` (optional).\n * @template {Node | undefined} [CompileTree=undefined]\n * Input of `stringify` (optional).\n * @template {CompileResults | undefined} [CompileResult=undefined]\n * Output of `stringify` (optional).\n * @extends {CallableInstance<[], Processor>}\n */\nexport class Processor extends CallableInstance {\n /**\n * Create a processor.\n */\n constructor() {\n // If `Processor()` is called (w/o new), `copy` is called instead.\n super('copy')\n\n /**\n * Compiler to use (deprecated).\n *\n * @deprecated\n * Use `compiler` instead.\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.Compiler = undefined\n\n /**\n * Parser to use (deprecated).\n *\n * @deprecated\n * Use `parser` instead.\n * @type {(\n * Parser |\n * undefined\n * )}\n */\n this.Parser = undefined\n\n // Note: the following fields are considered private.\n // However, they are needed for tests, and TSC generates an untyped\n // `private freezeIndex` field for, which trips `type-coverage` up.\n // Instead, we use `@deprecated` to visualize that they shouldn’t be used.\n /**\n * Internal list of configured plugins.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Array>>}\n */\n this.attachers = []\n\n /**\n * Compiler to use.\n *\n * @type {(\n * Compiler<\n * CompileTree extends undefined ? Node : CompileTree,\n * CompileResult extends undefined ? CompileResults : CompileResult\n * > |\n * undefined\n * )}\n */\n this.compiler = undefined\n\n /**\n * Internal state to track where we are while freezing.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {number}\n */\n this.freezeIndex = -1\n\n /**\n * Internal state to track whether we’re frozen.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {boolean | undefined}\n */\n this.frozen = undefined\n\n /**\n * Internal state.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Data}\n */\n this.namespace = {}\n\n /**\n * Parser to use.\n *\n * @type {(\n * Parser |\n * undefined\n * )}\n */\n this.parser = undefined\n\n /**\n * Internal list of configured transformers.\n *\n * @deprecated\n * This is a private internal property and should not be used.\n * @type {Pipeline}\n */\n this.transformers = trough()\n }\n\n /**\n * Copy a processor.\n *\n * @deprecated\n * This is a private internal method and should not be used.\n * @returns {Processor}\n * New *unfrozen* processor ({@linkcode Processor}) that is\n * configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\n copy() {\n // Cast as the type parameters will be the same after attaching.\n const destination =\n /** @type {Processor} */ (\n new Processor()\n )\n let index = -1\n\n while (++index < this.attachers.length) {\n const attacher = this.attachers[index]\n destination.use(...attacher)\n }\n\n destination.data(extend(true, {}, this.namespace))\n\n return destination\n }\n\n /**\n * Configure the processor with info available to all plugins.\n * Information is stored in an object.\n *\n * Typically, options can be given to a specific plugin, but sometimes it\n * makes sense to have information shared with several plugins.\n * For example, a list of HTML elements that are self-closing, which is\n * needed during all phases.\n *\n * > **Note**: setting information cannot occur on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * > **Note**: to register custom data in TypeScript, augment the\n * > {@linkcode Data} interface.\n *\n * @example\n * This example show how to get and set info:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * const processor = unified().data('alpha', 'bravo')\n *\n * processor.data('alpha') // => 'bravo'\n *\n * processor.data() // => {alpha: 'bravo'}\n *\n * processor.data({charlie: 'delta'})\n *\n * processor.data() // => {charlie: 'delta'}\n * ```\n *\n * @template {keyof Data} Key\n *\n * @overload\n * @returns {Data}\n *\n * @overload\n * @param {Data} dataset\n * @returns {Processor}\n *\n * @overload\n * @param {Key} key\n * @returns {Data[Key]}\n *\n * @overload\n * @param {Key} key\n * @param {Data[Key]} value\n * @returns {Processor}\n *\n * @param {Data | Key} [key]\n * Key to get or set, or entire dataset to set, or nothing to get the\n * entire dataset (optional).\n * @param {Data[Key]} [value]\n * Value to set (optional).\n * @returns {unknown}\n * The current processor when setting, the value at `key` when getting, or\n * the entire dataset when getting without key.\n */\n data(key, value) {\n if (typeof key === 'string') {\n // Set `key`.\n if (arguments.length === 2) {\n assertUnfrozen('data', this.frozen)\n this.namespace[key] = value\n return this\n }\n\n // Get `key`.\n return (own.call(this.namespace, key) && this.namespace[key]) || undefined\n }\n\n // Set space.\n if (key) {\n assertUnfrozen('data', this.frozen)\n this.namespace = key\n return this\n }\n\n // Get space.\n return this.namespace\n }\n\n /**\n * Freeze a processor.\n *\n * Frozen processors are meant to be extended and not to be configured\n * directly.\n *\n * When a processor is frozen it cannot be unfrozen.\n * New processors working the same way can be created by calling the\n * processor.\n *\n * It’s possible to freeze processors explicitly by calling `.freeze()`.\n * Processors freeze automatically when `.parse()`, `.run()`, `.runSync()`,\n * `.stringify()`, `.process()`, or `.processSync()` are called.\n *\n * @returns {Processor}\n * The current processor.\n */\n freeze() {\n if (this.frozen) {\n return this\n }\n\n // Cast so that we can type plugins easier.\n // Plugins are supposed to be usable on different processors, not just on\n // this exact processor.\n const self = /** @type {Processor} */ (/** @type {unknown} */ (this))\n\n while (++this.freezeIndex < this.attachers.length) {\n const [attacher, ...options] = this.attachers[this.freezeIndex]\n\n if (options[0] === false) {\n continue\n }\n\n if (options[0] === true) {\n options[0] = undefined\n }\n\n const transformer = attacher.call(self, ...options)\n\n if (typeof transformer === 'function') {\n this.transformers.use(transformer)\n }\n }\n\n this.frozen = true\n this.freezeIndex = Number.POSITIVE_INFINITY\n\n return this\n }\n\n /**\n * Parse text to a syntax tree.\n *\n * > **Note**: `parse` freezes the processor if not already *frozen*.\n *\n * > **Note**: `parse` performs the parse phase, not the run phase or other\n * > phases.\n *\n * @param {Compatible | undefined} [file]\n * file to parse (optional); typically `string` or `VFile`; any value\n * accepted as `x` in `new VFile(x)`.\n * @returns {ParseTree extends undefined ? Node : ParseTree}\n * Syntax tree representing `file`.\n */\n parse(file) {\n this.freeze()\n const realFile = vfile(file)\n const parser = this.parser || this.Parser\n assertParser('parse', parser)\n return parser(String(realFile), realFile)\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * > **Note**: `process` freezes the processor if not already *frozen*.\n *\n * > **Note**: `process` performs the parse, run, and stringify phases.\n *\n * @overload\n * @param {Compatible | undefined} file\n * @param {ProcessCallback>} done\n * @returns {undefined}\n *\n * @overload\n * @param {Compatible | undefined} [file]\n * @returns {Promise>}\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`]; any value accepted as\n * `x` in `new VFile(x)`.\n * @param {ProcessCallback> | undefined} [done]\n * Callback (optional).\n * @returns {Promise | undefined}\n * Nothing if `done` is given.\n * Otherwise a promise, rejected with a fatal error or resolved with the\n * processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n process(file, done) {\n const self = this\n\n this.freeze()\n assertParser('process', this.parser || this.Parser)\n assertCompiler('process', this.compiler || this.Compiler)\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {((file: VFileWithOutput) => undefined | void) | undefined} resolve\n * @param {(error: Error | undefined) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n const realFile = vfile(file)\n // Assume `ParseTree` (the result of the parser) matches `HeadTree` (the\n // input of the first transform).\n const parseTree =\n /** @type {HeadTree extends undefined ? Node : HeadTree} */ (\n /** @type {unknown} */ (self.parse(realFile))\n )\n\n self.run(parseTree, realFile, function (error, tree, file) {\n if (error || !tree || !file) {\n return realDone(error)\n }\n\n // Assume `TailTree` (the output of the last transform) matches\n // `CompileTree` (the input of the compiler).\n const compileTree =\n /** @type {CompileTree extends undefined ? Node : CompileTree} */ (\n /** @type {unknown} */ (tree)\n )\n\n const compileResult = self.stringify(compileTree, file)\n\n if (looksLikeAValue(compileResult)) {\n file.value = compileResult\n } else {\n file.result = compileResult\n }\n\n realDone(error, /** @type {VFileWithOutput} */ (file))\n })\n\n /**\n * @param {Error | undefined} error\n * @param {VFileWithOutput | undefined} [file]\n * @returns {undefined}\n */\n function realDone(error, file) {\n if (error || !file) {\n reject(error)\n } else if (resolve) {\n resolve(file)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, file)\n }\n }\n }\n }\n\n /**\n * Process the given file as configured on the processor.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `processSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `processSync` performs the parse, run, and stringify phases.\n *\n * @param {Compatible | undefined} [file]\n * File (optional); typically `string` or `VFile`; any value accepted as\n * `x` in `new VFile(x)`.\n * @returns {VFileWithOutput}\n * The processed file.\n *\n * The parsed, transformed, and compiled value is available at\n * `file.value` (see note).\n *\n * > **Note**: unified typically compiles by serializing: most\n * > compilers return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n processSync(file) {\n /** @type {boolean} */\n let complete = false\n /** @type {VFileWithOutput | undefined} */\n let result\n\n this.freeze()\n assertParser('processSync', this.parser || this.Parser)\n assertCompiler('processSync', this.compiler || this.Compiler)\n\n this.process(file, realDone)\n assertDone('processSync', 'process', complete)\n assert(result, 'we either bailed on an error or have a tree')\n\n return result\n\n /**\n * @type {ProcessCallback>}\n */\n function realDone(error, file) {\n complete = true\n bail(error)\n result = file\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * > **Note**: `run` freezes the processor if not already *frozen*.\n *\n * > **Note**: `run` performs the run phase, not other phases.\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {RunCallback} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} file\n * @param {RunCallback} done\n * @returns {undefined}\n *\n * @overload\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * @param {Compatible | undefined} [file]\n * @returns {Promise}\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {(\n * RunCallback |\n * Compatible\n * )} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @param {RunCallback} [done]\n * Callback (optional).\n * @returns {Promise | undefined}\n * Nothing if `done` is given.\n * Otherwise, a promise rejected with a fatal error or resolved with the\n * transformed tree.\n */\n run(tree, file, done) {\n assertNode(tree)\n this.freeze()\n\n const transformers = this.transformers\n\n if (!done && typeof file === 'function') {\n done = file\n file = undefined\n }\n\n return done ? executor(undefined, done) : new Promise(executor)\n\n // Note: `void`s needed for TS.\n /**\n * @param {(\n * ((tree: TailTree extends undefined ? Node : TailTree) => undefined | void) |\n * undefined\n * )} resolve\n * @param {(error: Error) => undefined | void} reject\n * @returns {undefined}\n */\n function executor(resolve, reject) {\n assert(\n typeof file !== 'function',\n '`file` can’t be a `done` anymore, we checked'\n )\n const realFile = vfile(file)\n transformers.run(tree, realFile, realDone)\n\n /**\n * @param {Error | undefined} error\n * @param {Node} outputTree\n * @param {VFile} file\n * @returns {undefined}\n */\n function realDone(error, outputTree, file) {\n const resultingTree =\n /** @type {TailTree extends undefined ? Node : TailTree} */ (\n outputTree || tree\n )\n\n if (error) {\n reject(error)\n } else if (resolve) {\n resolve(resultingTree)\n } else {\n assert(done, '`done` is defined if `resolve` is not')\n done(undefined, resultingTree, file)\n }\n }\n }\n }\n\n /**\n * Run *transformers* on a syntax tree.\n *\n * An error is thrown if asynchronous transforms are configured.\n *\n * > **Note**: `runSync` freezes the processor if not already *frozen*.\n *\n * > **Note**: `runSync` performs the run phase, not other phases.\n *\n * @param {HeadTree extends undefined ? Node : HeadTree} tree\n * Tree to transform and inspect.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {TailTree extends undefined ? Node : TailTree}\n * Transformed tree.\n */\n runSync(tree, file) {\n /** @type {boolean} */\n let complete = false\n /** @type {(TailTree extends undefined ? Node : TailTree) | undefined} */\n let result\n\n this.run(tree, file, realDone)\n\n assertDone('runSync', 'run', complete)\n assert(result, 'we either bailed on an error or have a tree')\n return result\n\n /**\n * @type {RunCallback}\n */\n function realDone(error, tree) {\n bail(error)\n result = tree\n complete = true\n }\n }\n\n /**\n * Compile a syntax tree.\n *\n * > **Note**: `stringify` freezes the processor if not already *frozen*.\n *\n * > **Note**: `stringify` performs the stringify phase, not the run phase\n * > or other phases.\n *\n * @param {CompileTree extends undefined ? Node : CompileTree} tree\n * Tree to compile.\n * @param {Compatible | undefined} [file]\n * File associated with `node` (optional); any value accepted as `x` in\n * `new VFile(x)`.\n * @returns {CompileResult extends undefined ? Value : CompileResult}\n * Textual representation of the tree (see note).\n *\n * > **Note**: unified typically compiles by serializing: most compilers\n * > return `string` (or `Uint8Array`).\n * > Some compilers, such as the one configured with\n * > [`rehype-react`][rehype-react], return other values (in this case, a\n * > React tree).\n * > If you’re using a compiler that doesn’t serialize, expect different\n * > result values.\n * >\n * > To register custom results in TypeScript, add them to\n * > {@linkcode CompileResultMap}.\n *\n * [rehype-react]: https://github.com/rehypejs/rehype-react\n */\n stringify(tree, file) {\n this.freeze()\n const realFile = vfile(file)\n const compiler = this.compiler || this.Compiler\n assertCompiler('stringify', compiler)\n assertNode(tree)\n\n return compiler(tree, realFile)\n }\n\n /**\n * Configure the processor to use a plugin, a list of usable values, or a\n * preset.\n *\n * If the processor is already using a plugin, the previous plugin\n * configuration is changed based on the options that are passed in.\n * In other words, the plugin is not added a second time.\n *\n * > **Note**: `use` cannot be called on *frozen* processors.\n * > Call the processor first to create a new unfrozen processor.\n *\n * @example\n * There are many ways to pass plugins to `.use()`.\n * This example gives an overview:\n *\n * ```js\n * import {unified} from 'unified'\n *\n * unified()\n * // Plugin with options:\n * .use(pluginA, {x: true, y: true})\n * // Passing the same plugin again merges configuration (to `{x: true, y: false, z: true}`):\n * .use(pluginA, {y: false, z: true})\n * // Plugins:\n * .use([pluginB, pluginC])\n * // Two plugins, the second with options:\n * .use([pluginD, [pluginE, {}]])\n * // Preset with plugins and settings:\n * .use({plugins: [pluginF, [pluginG, {}]], settings: {position: false}})\n * // Settings only:\n * .use({settings: {position: false}})\n * ```\n *\n * @template {Array} [Parameters=[]]\n * @template {Node | string | undefined} [Input=undefined]\n * @template [Output=Input]\n *\n * @overload\n * @param {Preset | null | undefined} [preset]\n * @returns {Processor}\n *\n * @overload\n * @param {PluggableList} list\n * @returns {Processor}\n *\n * @overload\n * @param {Plugin} plugin\n * @param {...(Parameters | [boolean])} parameters\n * @returns {UsePlugin}\n *\n * @param {PluggableList | Plugin | Preset | null | undefined} value\n * Usable value.\n * @param {...unknown} parameters\n * Parameters, when a plugin is given as a usable value.\n * @returns {Processor}\n * Current processor.\n */\n use(value, ...parameters) {\n const attachers = this.attachers\n const namespace = this.namespace\n\n assertUnfrozen('use', this.frozen)\n\n if (value === null || value === undefined) {\n // Empty.\n } else if (typeof value === 'function') {\n addPlugin(value, parameters)\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n addList(value)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n\n return this\n\n /**\n * @param {Pluggable} value\n * @returns {undefined}\n */\n function add(value) {\n if (typeof value === 'function') {\n addPlugin(value, [])\n } else if (typeof value === 'object') {\n if (Array.isArray(value)) {\n const [plugin, ...parameters] =\n /** @type {PluginTuple>} */ (value)\n addPlugin(plugin, parameters)\n } else {\n addPreset(value)\n }\n } else {\n throw new TypeError('Expected usable value, not `' + value + '`')\n }\n }\n\n /**\n * @param {Preset} result\n * @returns {undefined}\n */\n function addPreset(result) {\n if (!('plugins' in result) && !('settings' in result)) {\n throw new Error(\n 'Expected usable value but received an empty preset, which is probably a mistake: presets typically come with `plugins` and sometimes with `settings`, but this has neither'\n )\n }\n\n addList(result.plugins)\n\n if (result.settings) {\n namespace.settings = extend(true, namespace.settings, result.settings)\n }\n }\n\n /**\n * @param {PluggableList | null | undefined} plugins\n * @returns {undefined}\n */\n function addList(plugins) {\n let index = -1\n\n if (plugins === null || plugins === undefined) {\n // Empty.\n } else if (Array.isArray(plugins)) {\n while (++index < plugins.length) {\n const thing = plugins[index]\n add(thing)\n }\n } else {\n throw new TypeError('Expected a list of plugins, not `' + plugins + '`')\n }\n }\n\n /**\n * @param {Plugin} plugin\n * @param {Array} parameters\n * @returns {undefined}\n */\n function addPlugin(plugin, parameters) {\n let index = -1\n let entryIndex = -1\n\n while (++index < attachers.length) {\n if (attachers[index][0] === plugin) {\n entryIndex = index\n break\n }\n }\n\n if (entryIndex === -1) {\n attachers.push([plugin, ...parameters])\n }\n // Only set if there was at least a `primary` value, otherwise we’d change\n // `arguments.length`.\n else if (parameters.length > 0) {\n let [primary, ...rest] = parameters\n const currentPrimary = attachers[entryIndex][1]\n if (isPlainObj(currentPrimary) && isPlainObj(primary)) {\n primary = extend(true, currentPrimary, primary)\n }\n\n attachers[entryIndex] = [plugin, primary, ...rest]\n }\n }\n }\n}\n\n// Note: this returns a *callable* instance.\n// That’s why it’s documented as a function.\n/**\n * Create a new processor.\n *\n * @example\n * This example shows how a new processor can be created (from `remark`) and linked\n * to **stdin**(4) and **stdout**(4).\n *\n * ```js\n * import process from 'node:process'\n * import concatStream from 'concat-stream'\n * import {remark} from 'remark'\n *\n * process.stdin.pipe(\n * concatStream(function (buf) {\n * process.stdout.write(String(remark().processSync(buf)))\n * })\n * )\n * ```\n *\n * @returns\n * New *unfrozen* processor (`processor`).\n *\n * This processor is configured to work the same as its ancestor.\n * When the descendant processor is configured in the future it does not\n * affect the ancestral processor.\n */\nexport const unified = new Processor().freeze()\n\n/**\n * Assert a parser is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Parser}\n */\nfunction assertParser(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `parser`')\n }\n}\n\n/**\n * Assert a compiler is available.\n *\n * @param {string} name\n * @param {unknown} value\n * @returns {asserts value is Compiler}\n */\nfunction assertCompiler(name, value) {\n if (typeof value !== 'function') {\n throw new TypeError('Cannot `' + name + '` without `compiler`')\n }\n}\n\n/**\n * Assert the processor is not frozen.\n *\n * @param {string} name\n * @param {unknown} frozen\n * @returns {asserts frozen is false}\n */\nfunction assertUnfrozen(name, frozen) {\n if (frozen) {\n throw new Error(\n 'Cannot call `' +\n name +\n '` on a frozen processor.\\nCreate a new processor first, by calling it: use `processor()` instead of `processor`.'\n )\n }\n}\n\n/**\n * Assert `node` is a unist node.\n *\n * @param {unknown} node\n * @returns {asserts node is Node}\n */\nfunction assertNode(node) {\n // `isPlainObj` unfortunately uses `any` instead of `unknown`.\n // type-coverage:ignore-next-line\n if (!isPlainObj(node) || typeof node.type !== 'string') {\n throw new TypeError('Expected node, got `' + node + '`')\n // Fine.\n }\n}\n\n/**\n * Assert that `complete` is `true`.\n *\n * @param {string} name\n * @param {string} asyncName\n * @param {unknown} complete\n * @returns {asserts complete is true}\n */\nfunction assertDone(name, asyncName, complete) {\n if (!complete) {\n throw new Error(\n '`' + name + '` finished async. Use `' + asyncName + '` instead'\n )\n }\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {VFile}\n */\nfunction vfile(value) {\n return looksLikeAVFile(value) ? value : new VFile(value)\n}\n\n/**\n * @param {Compatible | undefined} [value]\n * @returns {value is VFile}\n */\nfunction looksLikeAVFile(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'message' in value &&\n 'messages' in value\n )\n}\n\n/**\n * @param {unknown} [value]\n * @returns {value is Value}\n */\nfunction looksLikeAValue(value) {\n return typeof value === 'string' || isUint8Array(value)\n}\n\n/**\n * Assert `value` is an `Uint8Array`.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Uint8Array}\n * Whether `value` is an `Uint8Array`.\n */\nfunction isUint8Array(value) {\n return Boolean(\n value &&\n typeof value === 'object' &&\n 'byteLength' in value &&\n 'byteOffset' in value\n )\n}\n","// Register `Raw` in tree:\n/// \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} Visitor\n * @typedef {import('unified').PluggableList} PluggableList\n */\n\n/**\n * @callback AllowElement\n * Filter elements.\n * @param {Readonly} element\n * Element to check.\n * @param {number} index\n * Index of `element` in `parent`.\n * @param {Readonly | undefined} parent\n * Parent of `element`.\n * @returns {boolean | null | undefined}\n * Whether to allow `element` (default: `false`).\n *\n * @typedef {Partial} 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 | 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 | 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 | 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} 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} */\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>} */\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\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} */ (\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 // \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","import React, { useEffect, useRef } from \"react\";\nimport ReactMarkdown from \"react-markdown\";\n\nconst Slide = ({ slide, isActive }) => {\n const iframeRef = useRef(null);\n const playerRef = useRef(null);\n\n const getEmbedUrl = (url) => {\n const baseURL = url.includes(\"/shorts/\")\n ? url.replace(\"/shorts/\", \"/embed/\")\n : url;\n return `${baseURL}?enablejsapi=1&playlist=${baseURL.split(\"/\").pop()}`;\n };\n\n const getImagePath = (path) => {\n return process.env.NODE_ENV === \"production\" ? `/cool-uncool${path}` : path;\n };\n\n useEffect(() => {\n const initializePlayer = () => {\n if (slide.type === \"youtube\" && iframeRef.current) {\n if (!playerRef.current && window.YT && window.YT.Player) {\n playerRef.current = new window.YT.Player(iframeRef.current, {\n events: {\n onReady: (event) => {\n if (isActive) {\n event.target.playVideo();\n } else {\n event.target.pauseVideo();\n }\n },\n onStateChange: (event) => {\n if (\n isActive &&\n slide.repeat &&\n event.data === window.YT.PlayerState.ENDED\n ) {\n event.target.seekTo(0);\n event.target.playVideo();\n }\n },\n },\n });\n } else if (playerRef.current) {\n if (isActive) {\n playerRef.current.playVideo();\n } else {\n playerRef.current.pauseVideo();\n }\n }\n }\n };\n\n if (window.YT && window.YT.Player) {\n initializePlayer();\n } else {\n window.onYouTubeIframeAPIReady = initializePlayer;\n }\n\n return () => {\n if (playerRef.current) {\n playerRef.current.pauseVideo();\n }\n };\n }, [isActive, slide.type, slide.repeat]);\n\n return (\n
\n {/* Heading */}\n {slide.type === \"heading\" && (\n

\n {slide.icon && {slide.icon}}\n {slide.content}\n

\n )}\n\n {/* Paragraph with Markdown */}\n {slide.type === \"paragraph\" && (\n
\n

\n {slide.icon && {slide.icon}}\n {slide.title}\n

\n \n {slide.content.replace(\"/images\", getImagePath(\"/images\"))}\n \n
\n )}\n\n {/* YouTube */}\n {slide.type === \"youtube\" && (\n
\n {slide.title && (\n

\n {slide.icon && {slide.icon}}\n {slide.title}\n

\n )}\n \n
\n )}\n
\n );\n};\n\nexport default Slide;\n","import React from \"react\";\nimport \"./DarkModeToggle.css\";\n\nconst DarkModeToggle = ({ isDarkMode, onToggle }) => {\n return (\n \n {isDarkMode ? (\n \n \n \n ) : (\n \n \n \n \n )}\n {isDarkMode ? \"Dark\" : \"Light\"}\n \n );\n};\n\nexport default DarkModeToggle;\n","import React from \"react\";\nimport \"./MonthSelector.css\";\n\nconst MonthSelector = ({ months, selectedMonth, onSelect }) => {\n return (\n
\n \n onSelect(e.target.value)}\n className=\"month-dropdown\"\n >\n {months.map((month) => (\n \n ))}\n \n
\n );\n};\n\nexport default MonthSelector;\n","import React, { useState, useEffect, useCallback } from \"react\";\nimport { useSwipeable } from \"react-swipeable\";\nimport { useParams, useNavigate } from \"react-router-dom\";\nimport Slide from \"./Slide\";\nimport DarkModeToggle from \"./DarkModeToggle/DarkModeToggle\";\nimport MonthSelector from \"./MonthSelector/MonthSelector\";\n\nconst SlideDeck = () => {\n const { year, month, slug } = useParams();\n const navigate = useNavigate();\n const [slides, setSlides] = useState([]);\n const [currentSlide, setCurrentSlide] = useState(0);\n const [isDarkMode, setIsDarkMode] = useState(false);\n const [months, setMonths] = useState([]);\n\n const getBasePath = () => {\n return process.env.NODE_ENV === \"production\" ? \"/cool-uncool\" : \"\";\n };\n\n // Maand selecteren en redirecten\n const handleMonthSelect = (selectedMonth) => {\n const [selectedYear, selectedMonthNum] = selectedMonth.split(\"-\");\n navigate(`/slides/${selectedYear}/${selectedMonthNum}/start`);\n };\n\n // Random slide\n const goToRandomSlide = () => {\n const randomIndex = Math.floor(Math.random() * slides.length);\n goToSlide(randomIndex);\n };\n\n // Laad de beschikbare maanden uit public/data\n useEffect(() => {\n const fetchMonths = async () => {\n try {\n const response = await fetch(\n `${getBasePath()}/data/available-months.json`,\n );\n if (!response.ok)\n throw new Error(\"available-months.json niet gevonden\");\n const data = await response.json();\n setMonths(data.months || []);\n } catch (error) {\n console.error(\"Fout bij laden van maanden:\", error);\n setMonths([]);\n }\n };\n\n fetchMonths();\n }, []);\n\n // Laad slides op basis van maand en jaar\n useEffect(() => {\n const loadSlides = async () => {\n try {\n const slidesPath = `${getBasePath()}/data/slides-${year}-${month}.json`;\n console.log(\"Fetching slides:\", slidesPath);\n\n const response = await fetch(slidesPath);\n if (!response.ok) {\n throw new Error(\n `Slidebestand niet gevonden: slides-${year}-${month}.json`,\n );\n }\n\n const { slides: slidesForMonth } = await response.json();\n setSlides(slidesForMonth);\n\n // Zoek de juiste slide op basis van slug of index\n const slideIndex = slidesForMonth.findIndex(\n (slide, index) =>\n slide.slug === slug || `slide-${index + 1}` === slug,\n );\n\n if (slideIndex !== -1) {\n setCurrentSlide(slideIndex);\n } else {\n navigate(`/slides/${year}/${month}/slide-1`, { replace: true });\n }\n } catch (error) {\n console.error(`Slides niet gevonden voor ${year}-${month}:`, error);\n setSlides([]);\n }\n };\n\n if (year && month) {\n loadSlides();\n }\n }, [year, month, slug, navigate]);\n\n // Swipe functionaliteit\n const goToSlide = (newIndex) => {\n if (newIndex >= 0 && newIndex < slides.length) {\n const newSlug = slides[newIndex].slug || `slide-${newIndex + 1}`;\n setCurrentSlide(newIndex);\n navigate(`/slides/${year}/${month}/${newSlug}`);\n }\n };\n\n const handlers = useSwipeable({\n onSwipedLeft: () => goToSlide(currentSlide + 1),\n onSwipedRight: () => goToSlide(currentSlide - 1),\n preventDefaultTouchmoveEvent: true,\n trackMouse: true,\n });\n\n // Pijltjesnavigatie (keyboard)\n const handleKeyDown = useCallback(\n (e) => {\n if (e.key === \"ArrowRight\" || e.key === \"ArrowDown\") {\n goToSlide(currentSlide + 1);\n } else if (e.key === \"ArrowLeft\" || e.key === \"ArrowUp\") {\n goToSlide(currentSlide - 1);\n }\n },\n [currentSlide, slides.length],\n );\n\n useEffect(() => {\n window.addEventListener(\"keydown\", handleKeyDown);\n return () => {\n window.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [handleKeyDown]);\n\n return (\n \n {\" \"}\n setIsDarkMode((prev) => !prev)}\n />\n {slides.length > 0 ? (\n \n ) : (\n
Geen slides beschikbaar.
\n )}\n {slides.length > 0 && (\n
\n
\n
\n \n
\n \n
\n
\n Slide {currentSlide + 1} van {slides.length}\n
\n
\n )}\n
\n );\n};\n\nexport default SlideDeck;\n","import React from \"react\";\nimport {\n BrowserRouter as Router,\n Routes,\n Route,\n Navigate,\n useLocation,\n} from \"react-router-dom\";\nimport SlideDeck from \"./components/SlideDeck\";\nimport \"./styles/index.css\";\n\n// Debugging component\nfunction DebugRoute() {\n let location = useLocation();\n return
Route niet gevonden: {location.pathname}
;\n}\n\nfunction App() {\n const basename = window.location.pathname.includes(\"/cool-uncool\")\n ? \"/cool-uncool\"\n : \"/\";\n return (\n \n \n }\n />\n } />\n } />\n \n \n );\n}\n\nexport default App;\n","import React from \"react\";\nimport ReactDOM from \"react-dom/client\";\nimport \"./styles/index.css\";\nimport App from \"./App\";\n\nconst root = ReactDOM.createRoot(document.getElementById(\"root\"));\nroot.render(\n \n \n ,\n);\n"],"names":["cookieNameRegExp","cookieValueRegExp","domainValueRegExp","pathValueRegExp","__toString","Object","prototype","toString","NullObject","C","create","startIndex","str","index","max","code","charCodeAt","endIndex","min","decode","indexOf","decodeURIComponent","e","hasOwn","hasOwnProperty","toStr","defineProperty","gOPD","getOwnPropertyDescriptor","isArray","arr","Array","call","isPlainObject","obj","key","hasOwnConstructor","hasIsPrototypeOf","constructor","setProperty","target","options","name","enumerable","configurable","value","newValue","writable","getProperty","module","exports","extend","src","copy","copyIsArray","clone","arguments","i","length","deep","COMMENT_REGEX","NEWLINE_REGEX","WHITESPACE_REGEX","PROPERTY_REGEX","COLON_REGEX","VALUE_REGEX","SEMICOLON_REGEX","TRIM_REGEX","EMPTY_STRING","trim","replace","style","TypeError","lineno","column","updatePosition","lines","match","lastIndexOf","position","start","line","node","Position","whitespace","this","end","source","content","errorsList","error","msg","err","Error","reason","filename","silent","push","re","m","exec","slice","comments","rules","c","comment","pos","charAt","type","declaration","prop","val","ret","property","decl","decls","declarations","aa","require","ca","p","a","b","encodeURIComponent","da","Set","ea","fa","ha","add","ia","window","document","createElement","ja","ka","la","ma","v","d","f","g","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","z","split","forEach","toLowerCase","ra","sa","toUpperCase","ta","pa","isNaN","qa","test","oa","removeAttribute","setAttribute","setAttributeNS","xlinkHref","ua","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","va","Symbol","for","wa","ya","za","Aa","Ba","Ca","Da","Ea","Fa","Ga","Ha","Ia","Ja","iterator","Ka","La","A","assign","Ma","stack","Na","Oa","prepareStackTrace","set","Reflect","construct","l","h","k","displayName","includes","Pa","tag","render","Qa","$$typeof","_context","_payload","_init","Ra","Sa","Ta","nodeName","Va","_valueTracker","get","getValue","setValue","stopTracking","Ua","Wa","checked","Xa","activeElement","body","Ya","defaultChecked","defaultValue","_wrapperState","initialChecked","Za","initialValue","controlled","ab","bb","cb","db","ownerDocument","eb","fb","selected","defaultSelected","disabled","gb","dangerouslySetInnerHTML","children","hb","ib","jb","textContent","kb","lb","mb","nb","namespaceURI","innerHTML","valueOf","firstChild","removeChild","appendChild","MSApp","execUnsafeLocalFunction","ob","lastChild","nodeType","nodeValue","pb","animationIterationCount","aspectRatio","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","fontWeight","lineClamp","lineHeight","opacity","order","orphans","tabSize","widows","zIndex","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","qb","rb","sb","keys","substring","tb","menuitem","area","base","br","col","embed","hr","img","input","keygen","link","meta","param","track","wbr","ub","vb","is","wb","xb","srcElement","correspondingUseElement","parentNode","yb","zb","Ab","Bb","Cb","stateNode","Db","Eb","Fb","Gb","Hb","Ib","Jb","Kb","Lb","Mb","addEventListener","removeEventListener","Nb","apply","onError","Ob","Pb","Qb","Rb","Sb","Tb","Vb","alternate","return","flags","Wb","memoizedState","dehydrated","Xb","Zb","child","sibling","current","Yb","$b","ac","unstable_scheduleCallback","bc","unstable_cancelCallback","cc","unstable_shouldYield","dc","unstable_requestPaint","B","unstable_now","ec","unstable_getCurrentPriorityLevel","fc","unstable_ImmediatePriority","gc","unstable_UserBlockingPriority","hc","unstable_NormalPriority","ic","unstable_LowPriority","jc","unstable_IdlePriority","kc","lc","oc","Math","clz32","pc","qc","log","LN2","rc","sc","tc","uc","pendingLanes","suspendedLanes","pingedLanes","entangledLanes","entanglements","vc","xc","yc","zc","Ac","eventTimes","Cc","Dc","Ec","Fc","Gc","Hc","Ic","Jc","Kc","Lc","Mc","Nc","Oc","Map","Pc","Qc","Rc","Sc","delete","pointerId","Tc","nativeEvent","blockedOn","domEventName","eventSystemFlags","targetContainers","Vc","Wc","priority","isDehydrated","containerInfo","Xc","Yc","dispatchEvent","shift","Zc","$c","ad","bd","cd","ReactCurrentBatchConfig","dd","ed","transition","fd","gd","hd","id","Uc","stopPropagation","jd","kd","ld","md","nd","od","keyCode","charCode","pd","qd","rd","_reactName","_targetInst","currentTarget","isDefaultPrevented","defaultPrevented","returnValue","isPropagationStopped","preventDefault","cancelBubble","persist","isPersistent","wd","xd","yd","sd","eventPhase","bubbles","cancelable","timeStamp","Date","now","isTrusted","td","ud","view","detail","vd","Ad","screenX","screenY","clientX","clientY","pageX","pageY","ctrlKey","shiftKey","altKey","metaKey","getModifierState","zd","button","buttons","relatedTarget","fromElement","toElement","movementX","movementY","Bd","Dd","dataTransfer","Fd","Hd","animationName","elapsedTime","pseudoElement","Id","clipboardData","Jd","Ld","data","Md","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","Nd","Od","Alt","Control","Meta","Shift","Pd","Qd","String","fromCharCode","location","repeat","locale","which","Rd","Td","width","height","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","Vd","touches","targetTouches","changedTouches","Xd","Yd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","Zd","$d","ae","be","documentMode","ce","de","ee","fe","ge","he","ie","le","color","date","datetime","email","month","number","password","range","search","tel","text","time","url","week","me","ne","oe","event","listeners","pe","qe","se","te","ue","ve","we","xe","ye","ze","oninput","Ae","detachEvent","Be","Ce","attachEvent","De","Ee","Fe","He","Ie","Je","Ke","offset","nextSibling","Le","contains","compareDocumentPosition","Me","HTMLIFrameElement","contentWindow","href","Ne","contentEditable","Oe","focusedElem","selectionRange","documentElement","selectionStart","selectionEnd","defaultView","getSelection","rangeCount","anchorNode","anchorOffset","focusNode","focusOffset","createRange","setStart","removeAllRanges","addRange","setEnd","element","left","scrollLeft","top","scrollTop","focus","Pe","Qe","Re","Se","Te","Ue","Ve","We","animationend","animationiteration","animationstart","transitionend","Xe","Ye","Ze","animation","$e","af","bf","cf","df","ef","ff","gf","hf","lf","mf","concat","nf","Ub","instance","listener","D","of","has","pf","qf","rf","random","sf","bind","capture","passive","n","t","J","x","u","w","F","tf","uf","parentWindow","vf","wf","na","xa","$a","ba","je","char","ke","unshift","xf","yf","zf","Af","Bf","Cf","Df","Ef","__html","Ff","setTimeout","Gf","clearTimeout","Hf","Promise","Jf","queueMicrotask","resolve","then","catch","If","Kf","Lf","Mf","previousSibling","Nf","Of","Pf","Qf","Rf","Sf","Tf","Uf","E","G","Vf","H","Wf","Xf","Yf","contextTypes","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Zf","childContextTypes","$f","ag","bg","getChildContext","cg","__reactInternalMemoizedMergedChildContext","dg","eg","fg","gg","hg","jg","kg","lg","mg","ng","og","pg","qg","rg","sg","tg","ug","vg","wg","xg","yg","I","zg","Ag","Bg","elementType","deletions","Cg","pendingProps","overflow","treeContext","retryLane","Dg","mode","Eg","Fg","Gg","memoizedProps","Hg","Ig","Jg","Kg","Lg","ref","_owner","_stringRef","refs","Mg","join","Ng","Og","Pg","Qg","props","Rg","implementation","Sg","Tg","q","r","y","next","done","Ug","Vg","Wg","Xg","Yg","Zg","$g","ah","_currentValue","bh","childLanes","ch","dependencies","firstContext","lanes","dh","eh","context","memoizedValue","fh","gh","hh","interleaved","ih","jh","kh","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","shared","pending","effects","lh","mh","eventTime","lane","payload","callback","nh","K","oh","ph","qh","rh","sh","th","uh","vh","wh","xh","yh","tagName","zh","Ah","Bh","L","Ch","revealOrder","Dh","Eh","_workInProgressVersionPrimary","Fh","ReactCurrentDispatcher","Gh","Hh","M","N","O","Ih","Jh","Kh","Lh","P","Mh","Nh","Oh","Ph","Qh","Rh","Sh","Th","baseQueue","queue","Uh","Vh","Wh","lastRenderedReducer","action","hasEagerState","eagerState","lastRenderedState","dispatch","Xh","Yh","Zh","$h","ai","getSnapshot","bi","ci","Q","di","lastEffect","stores","ei","fi","gi","hi","ii","destroy","deps","ji","ki","li","mi","ni","oi","pi","qi","ri","si","ti","ui","vi","wi","xi","yi","zi","Ai","R","Bi","readContext","useCallback","useContext","useEffect","useImperativeHandle","useInsertionEffect","useLayoutEffect","useMemo","useReducer","useRef","useState","useDebugValue","useDeferredValue","useTransition","useMutableSource","useSyncExternalStore","useId","unstable_isNewReconciler","identifierPrefix","Ci","defaultProps","Di","Ei","isMounted","_reactInternals","enqueueSetState","enqueueReplaceState","enqueueForceUpdate","Fi","shouldComponentUpdate","isPureReactComponent","Gi","contextType","state","updater","Hi","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","Ii","getDerivedStateFromProps","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","componentDidMount","Ji","message","digest","Ki","Li","console","Mi","WeakMap","Ni","Oi","Pi","Qi","getDerivedStateFromError","componentDidCatch","Ri","componentStack","Si","pingCache","Ti","Ui","Vi","Wi","ReactCurrentOwner","Xi","Yi","Zi","$i","aj","compare","bj","cj","dj","baseLanes","cachePool","transitions","ej","fj","gj","hj","ij","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","jj","kj","pendingContext","lj","zj","Aj","Bj","Cj","mj","nj","oj","fallback","pj","qj","sj","dataset","dgst","tj","uj","_reactRetry","rj","subtreeFlags","vj","wj","isBackwards","rendering","renderingStartTime","last","tail","tailMode","xj","Dj","S","Ej","Fj","wasMultiple","multiple","suppressHydrationWarning","onClick","onclick","size","createElementNS","autoFocus","createTextNode","T","Gj","Hj","Ij","Jj","U","Kj","WeakSet","V","Lj","W","Mj","Nj","Pj","Qj","Rj","Sj","Tj","Uj","Vj","insertBefore","_reactRootContainer","Wj","X","Xj","Yj","Zj","onCommitFiberUnmount","componentWillUnmount","ak","bk","ck","dk","ek","isHidden","fk","gk","display","hk","ik","jk","kk","__reactInternalSnapshotBeforeUpdate","Vk","lk","ceil","mk","nk","ok","Y","Z","pk","qk","rk","sk","tk","Infinity","uk","vk","wk","xk","yk","zk","Ak","Bk","Ck","Dk","callbackNode","expirationTimes","expiredLanes","wc","callbackPriority","ig","Ek","Fk","Gk","Hk","Ik","Jk","Kk","Lk","Mk","Nk","Ok","finishedWork","finishedLanes","Pk","timeoutHandle","Qk","Rk","Sk","Tk","Uk","mutableReadLanes","Bc","Oj","onCommitFiberRoot","mc","onRecoverableError","Wk","onPostCommitFiberRoot","Xk","Yk","$k","isReactComponent","pendingChildren","al","mutableSourceEagerHydrationData","bl","cache","pendingSuspenseBoundaries","dl","el","fl","gl","hl","il","yj","Zk","kl","reportError","ll","_internalRoot","ml","nl","ol","pl","rl","ql","unmount","unstable_scheduleHydration","splice","querySelectorAll","JSON","stringify","form","sl","usingClientEntryPoint","Events","tl","findFiberByHostInstance","bundleType","version","rendererPackageName","ul","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setErrorHandler","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","reconcilerVersion","__REACT_DEVTOOLS_GLOBAL_HOOK__","vl","isDisabled","supportsFiber","inject","createPortal","cl","createRoot","unstable_strictMode","findDOMNode","flushSync","hydrate","hydrateRoot","hydratedSources","_getVersion","_source","unmountComponentAtNode","unstable_batchedUpdates","unstable_renderSubtreeIntoContainer","checkDCE","__self","__source","Fragment","jsx","jsxs","setState","forceUpdate","escape","_status","_result","default","Children","map","count","toArray","only","Component","Profiler","PureComponent","StrictMode","Suspense","act","cloneElement","createContext","_currentValue2","_threadCount","Provider","Consumer","_defaultValue","_globalName","createFactory","createRef","forwardRef","isValidElement","lazy","memo","startTransition","unstable_act","pop","sortIndex","performance","setImmediate","startTime","expirationTime","priorityLevel","navigator","scheduling","isInputPending","MessageChannel","port2","port1","onmessage","postMessage","unstable_Profiling","unstable_continueExecution","unstable_forceFrameRate","floor","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","unstable_runWithPriority","delay","unstable_wrapCallback","styleObject","inline_style_parser_1","hasIterator","__importDefault","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","definition","o","toStringTag","getOwnPropertySymbols","s","propertyIsEnumerable","_typeof","toPropertyKey","toPrimitive","Number","_defineProperty","ownKeys","filter","_objectSpread2","getOwnPropertyDescriptors","defineProperties","PopStateEventType","createBrowserHistory","getUrlBasedHistory","window2","globalHistory","pathname","hash","createLocation","usr","to","createPath","invariant","warning","cond","warn","getHistoryState","idx","_objectSpread","parsePath","_ref","path","parsedPath","hashIndex","searchIndex","getLocation","createHref2","validateLocation","v5Compat","history","getIndex","handlePop","nextIndex","delta","createURL","origin","URL","replaceState","listen","fn","createHref","encodeLocation","historyState","pushState","DOMException","go","matchRoutes","routes","locationArg","matchRoutesImpl","basename","allowPartial","stripBasename","branches","flattenRoutes","sort","score","siblings","every","compareIndexes","routesMeta","childrenIndex","rankRouteBranches","matches","decoded","decodePath","matchRouteBranch","parentsMeta","parentPath","flattenRoute","route","relativePath","caseSensitive","startsWith","joinPaths","computeScore","_route$path","exploded","explodeOptionalSegments","segments","first","rest","isOptional","endsWith","required","restExploded","result","subpath","paramRe","dynamicSegmentValue","indexRouteValue","emptySegmentValue","staticSegmentValue","splatPenalty","isSplat","initialScore","some","reduce","segment","branch","matchedParams","matchedPathname","remainingPathname","matchPath","params","pathnameBase","normalizePathname","pattern","matcher","compiledParams","regexpSource","_","paramName","RegExp","compilePath","captureGroups","memo2","_ref2","splatValue","nextChar","getInvalidPathError","field","dest","getPathContributingMatches","getResolveToMatches","pathMatches","resolveTo","toArg","routePathnames","locationPathname","isPathRelative","from","isEmptyPath","toPathname","routePathnameIndex","toSegments","fromPathname","resolvePathname","normalizeSearch","normalizeHash","resolvePath","hasExplicitTrailingSlash","hasCurrentTrailingSlash","paths","isRouteErrorResponse","status","statusText","internal","validMutationMethodsArr","validRequestMethodsArr","DataRouterContext","React","DataRouterStateContext","ViewTransitionContext","isTransitioning","FetchersContext","AwaitContext","NavigationContext","LocationContext","RouteContext","outlet","isDataRoute","RouteErrorContext","useInRouterContext","React2","useLocation","navigateEffectWarning","useIsomorphicLayoutEffect","static","useNavigate","router","useDataRouterContext","useCurrentRouteId","activeRef","navigate","async","fromRouteId","useNavigateStable","dataRouterContext","navigator2","routePathnamesJson","parse","relative","useNavigateUnstable","useResolvedPath","useRoutesImpl","dataRouterState","future","parentMatches","routeMatch","parentParams","parentPathname","parentPathnameBase","parentRoute","warningOnce","locationFromContext","_parsedLocationArg$pa","parsedLocationArg","parentSegments","renderedMatches","_renderMatches","navigationType","DefaultErrorComponent","useRouteError","lightgrey","preStyles","padding","backgroundColor","codeStyles","devInfo","fontStyle","defaultErrorElement","RenderErrorBoundary","super","revalidation","errorInfo","routeContext","component","RenderedRoute","_ref9","staticContext","errorElement","ErrorBoundary","_deepestRenderedBoundaryId","errors","initialized","errorIndex","findIndex","renderFallback","fallbackIndex","HydrateFallback","hydrateFallbackElement","loaderData","errors2","needsToRunLoader","loader","reduceRight","shouldRenderHydrateFallback","matches2","getChildren","getDataRouterConsoleError","hookName","ctx","useDataRouterState","useRouteContext","thisRoute","_state$errors","routeId","alreadyWarned","React3","_ref12","Navigate","_ref14","replace2","isStatic","jsonPath","Route","_props","Router","_ref15","basenameProp","locationProp","staticProp","navigationContext","locationContext","trailingPathname","Routes","_ref16","createRoutesFromChildren","treePath","hasErrorBoundary","shouldRevalidate","handle","defaultMethod","defaultEncType","isHtmlElement","object","_formDataSupportsSubmitter","supportedFormEncTypes","getFormEncType","encType","getFormSubmissionInfo","method","formData","attr","getAttribute","FormData","isButtonElement","isInputElement","isFormDataSubmitterSupported","prefix","append","invariant2","loadRouteModule","routeModulesCache","routeModule","import","__reactRouterContext","isSpaMode","reload","isPageLinkDescriptor","page","isHtmlLinkDescriptor","rel","imageSrcSet","imageSizes","getNewMatchesForLinks","nextMatches","currentMatches","manifest","isNew","matchPathChanged","_currentMatches$index","manifestRoute","hasLoader","_currentMatches$","routeChoice","currentUrl","currentParams","nextUrl","nextParams","defaultShouldRevalidate","dedupeHrefs","hrefs","dedupeLinkDescriptors","descriptors","preloads","preloadsSet","deduped","descriptor","as","sorted","sortKeys","createHtml","html","singleFetchUrl","reqUrl","React5","RemixRootDefaultErrorBoundary","_ref21","isOutsideRemixApp","errorInstance","heyDeveloper","BoundaryShell","title","fontSize","errorString","background","_ref22","_routeModules$root","renderScripts","routeModules","useFrameworkContext","root","Layout","lang","charSet","fontFamily","Scripts","isFogOfWarEnabled","useDataRouterContext2","React9","useDataRouterStateContext","FrameworkContext","composeEventHandlers","theirHandler","ourHandler","getActiveMatches","isHydrated","errorIdx","PrefetchPageLinks","_ref29","dataLinkProps","_objectWithoutProperties","_excluded","PrefetchPageLinksImpl","useKeyedPrefetchLinks","keyedPrefetchLinks","setKeyedPrefetchLinks","interrupted","all","mod","links","flat","getKeyedPrefetchLinks","_ref30","linkProps","_excluded2","newMatchesForData","newMatchesForAssets","dataHrefs","routesParams","foundOptOutRoute","_routeModules$m$route2","m2","hasClientLoader","searchParams","moduleHrefs","manifestPatch","imports","getModuleLinkHrefs","_ref31","serverHandoffString","renderMeta","routerMatches","enableFogOfWar","didRenderScripts","initialScripts","_manifest$hmr","contextScript","routeModulesScript","hmr","runtime","routeIds","Boolean","initialRoutes","acc","getPartialManifest","entry","routePreloads","crossOrigin","array","mergeRefs","_len3","_key3","isBrowser","__reactRouterVersion","BrowserRouter","_ref32","historyRef","React10","setStateImpl","newState","ABSOLUTE_URL_REGEX2","Link","_ref35","forwardedRef","absoluteHref","discover","prefetch","reloadDocument","preventScrollReset","viewTransition","_excluded4","isAbsolute","isExternal","targetUrl","protocol","joinedPathname","useHref","shouldPrefetch","prefetchRef","prefetchHandlers","theirElementProps","frameworkContext","maybePrefetch","setMaybePrefetch","setShouldPrefetch","onFocus","onBlur","onMouseEnter","onMouseLeave","onTouchStart","observer","IntersectionObserver","entries","isIntersecting","threshold","observe","disconnect","setIntent","cancelIntent","usePrefetchBehavior","internalOnClick","replaceProp","isModifiedEvent","shouldProcessLinkClick","useLinkClickHandler","NavLink","_ref36","ariaCurrentProp","className","classNameProp","styleProp","_excluded5","routerState","opts","vtContext","useDataRouterContext3","currentPath","currentLocation","nextPath","nextLocation","useViewTransitionState","nextLocationPathname","navigation","endSlashPosition","isActive","isPending","renderProps","ariaCurrent","Form","_ref37","fetcherKey","onSubmit","_excluded6","submit","useSubmit","formAction","URLSearchParams","indexValues","getAll","qs","useFormAction","formMethod","submitter","submitMethod","getDataRouterConsoleError2","fetcherId","getUniqueFetcherId","currentRouteId","fetch","formEncType","TextEncoder","preventScrollOnSwipe","rotationAngle","trackMouse","trackTouch","swipeDuration","touchEventOptions","initialState","initial","swiping","xy","mouseMove","mouseUp","rotateXYByAngle","angle","angleInRadians","PI","cos","sin","getHandlers","handlerProps","onStart","isTouch","onMove","onUp","onTouchStartOrOnMouseDown","absX","abs","absY","velocity","sqrt","vxvy","dir","getDirection","eventData","onSwipeStart","onSwiping","cancelablePageSwipe","onSwiped","onEnd","onSwipedDir","onTap","onTouchEndOrOnMouseUp","attachTouch","cleanup","baseOptions","tls","output","addState","cleanUpTouch","onMouseDown","useSwipeable","transientState","transientProps","previousProps","defaultKey","handlers","stateSetter","updateTransientState","nameRe","nameReJsx","emptyOptions","empty","Schema","normal","space","merge","definitions","normalize","Info","attribute","boolean","booleanish","overloadedBoolean","commaSeparated","spaceSeparated","commaOrSpaceSeparated","defined","powers","increment","checks","types","DefinedInfo","mask","mark","check","values","own","properties","info","transform","attributes","xlink","xLinkActuate","xLinkArcRole","xLinkHref","xLinkRole","xLinkShow","xLinkTitle","xLinkType","xml","xmlLang","xmlBase","xmlSpace","caseSensitiveTransform","caseInsensitiveTransform","xmlns","xmlnsxlink","xmlnsXLink","aria","ariaActiveDescendant","ariaAtomic","ariaAutoComplete","ariaBusy","ariaChecked","ariaColCount","ariaColIndex","ariaColSpan","ariaControls","ariaDescribedBy","ariaDetails","ariaDisabled","ariaDropEffect","ariaErrorMessage","ariaExpanded","ariaFlowTo","ariaGrabbed","ariaHasPopup","ariaHidden","ariaInvalid","ariaKeyShortcuts","ariaLabel","ariaLabelledBy","ariaLevel","ariaLive","ariaModal","ariaMultiLine","ariaMultiSelectable","ariaOrientation","ariaOwns","ariaPlaceholder","ariaPosInSet","ariaPressed","ariaReadOnly","ariaRelevant","ariaRequired","ariaRoleDescription","ariaRowCount","ariaRowIndex","ariaRowSpan","ariaSelected","ariaSetSize","ariaSort","ariaValueMax","ariaValueMin","ariaValueNow","ariaValueText","role","acceptcharset","classname","htmlfor","httpequiv","abbr","accept","acceptCharset","accessKey","allow","allowFullScreen","allowPaymentRequest","allowUserMedia","alt","autoCapitalize","autoComplete","autoPlay","blocking","cite","cols","colSpan","controls","controlsList","coords","dateTime","decoding","defer","dirName","download","draggable","enterKeyHint","fetchPriority","formNoValidate","formTarget","headers","hidden","high","hrefLang","htmlFor","httpEquiv","inert","inputMode","integrity","isMap","itemId","itemProp","itemRef","itemScope","itemType","kind","label","language","list","loading","loop","low","maxLength","media","minLength","muted","nonce","noModule","noValidate","onAbort","onAfterPrint","onAuxClick","onBeforeMatch","onBeforePrint","onBeforeToggle","onBeforeUnload","onCancel","onCanPlay","onCanPlayThrough","onChange","onClose","onContextLost","onContextMenu","onContextRestored","onCopy","onCueChange","onCut","onDblClick","onDrag","onDragEnd","onDragEnter","onDragExit","onDragLeave","onDragOver","onDragStart","onDrop","onDurationChange","onEmptied","onEnded","onFormData","onHashChange","onInput","onInvalid","onKeyDown","onKeyPress","onKeyUp","onLanguageChange","onLoad","onLoadedData","onLoadedMetadata","onLoadEnd","onLoadStart","onMessage","onMessageError","onMouseMove","onMouseOut","onMouseOver","onMouseUp","onOffline","onOnline","onPageHide","onPageShow","onPaste","onPause","onPlay","onPlaying","onPopState","onProgress","onRateChange","onRejectionHandled","onReset","onResize","onScroll","onScrollEnd","onSecurityPolicyViolation","onSeeked","onSeeking","onSelect","onSlotChange","onStalled","onStorage","onSuspend","onTimeUpdate","onToggle","onUnhandledRejection","onUnload","onVolumeChange","onWaiting","onWheel","open","optimum","ping","placeholder","playsInline","popover","popoverTarget","popoverTargetAction","poster","preload","readOnly","referrerPolicy","reversed","rows","rowSpan","sandbox","scope","scoped","seamless","shadowRootClonable","shadowRootDelegatesFocus","shadowRootMode","shape","sizes","slot","span","spellCheck","srcDoc","srcLang","srcSet","step","tabIndex","translate","typeMustMatch","useMap","wrap","writingSuggestions","align","aLink","archive","axis","bgColor","border","borderColor","bottomMargin","cellPadding","cellSpacing","charOff","classId","clear","codeBase","codeType","compact","declare","face","frame","frameBorder","hSpace","leftMargin","longDesc","lowSrc","marginHeight","marginWidth","noResize","noHref","noShade","noWrap","profile","prompt","rev","rightMargin","scheme","scrolling","standby","summary","topMargin","valueType","vAlign","vLink","vSpace","allowTransparency","autoCorrect","autoSave","disablePictureInPicture","disableRemotePlayback","results","security","unselectable","svg","accentHeight","alignmentBaseline","arabicForm","baselineShift","capHeight","clipPath","clipRule","colorInterpolation","colorInterpolationFilters","colorProfile","colorRendering","dataType","dominantBaseline","enableBackground","fillRule","floodColor","fontSizeAdjust","fontStretch","fontVariant","glyphName","glyphOrientationHorizontal","glyphOrientationVertical","horizAdvX","horizOriginX","horizOriginY","imageRendering","letterSpacing","lightingColor","markerEnd","markerMid","markerStart","navDown","navDownLeft","navDownRight","navLeft","navNext","navPrev","navRight","navUp","navUpLeft","navUpRight","onActivate","onBegin","onFocusIn","onFocusOut","onMouseWheel","onRepeat","onShow","onZoom","overlinePosition","overlineThickness","paintOrder","panose1","pointerEvents","renderingIntent","shapeRendering","stopColor","strikethroughPosition","strikethroughThickness","strokeDashArray","strokeDashOffset","strokeLineCap","strokeLineJoin","strokeMiterLimit","textAnchor","textDecoration","textRendering","transformOrigin","typeOf","underlinePosition","underlineThickness","unicodeBidi","unicodeRange","unitsPerEm","vAlphabetic","vHanging","vIdeographic","vMathematical","vectorEffect","vertAdvY","vertOriginX","vertOriginY","wordSpacing","writingMode","xHeight","playbackOrder","timelineBegin","about","accumulate","additive","alphabetic","amplitude","ascent","attributeType","azimuth","bandwidth","baseFrequency","baseProfile","bbox","begin","bias","by","calcMode","clip","clipPathUnits","contentScriptType","contentStyleType","cursor","cx","cy","defaultAction","descent","diffuseConstant","direction","dur","divisor","dx","dy","edgeMode","editable","elevation","exponent","externalResourcesRequired","fill","filterRes","filterUnits","focusable","focusHighlight","format","fr","fx","fy","g1","g2","glyphRef","gradientTransform","gradientUnits","handler","hanging","hatchContentUnits","hatchUnits","ideographic","initialVisibility","in","in2","intercept","k1","k2","k3","k4","kernelMatrix","kernelUnitLength","keyPoints","keySplines","keyTimes","kerning","lengthAdjust","limitingConeAngle","local","markerHeight","markerUnits","markerWidth","maskContentUnits","maskUnits","mathematical","mediaCharacterEncoding","mediaContentEncodings","mediaSize","mediaTime","numOctaves","operator","orient","orientation","overlay","pathLength","patternContentUnits","patternTransform","patternUnits","phase","pitch","points","pointsAtX","pointsAtY","pointsAtZ","preserveAlpha","preserveAspectRatio","primitiveUnits","propagate","radius","refX","refY","repeatCount","repeatDur","requiredExtensions","requiredFeatures","requiredFonts","requiredFormats","resource","restart","rotate","rx","ry","scale","seed","side","slope","snapshotTime","specularConstant","specularExponent","spreadMethod","spacing","startOffset","stdDeviation","stemh","stemv","stitchTiles","string","stroke","surfaceScale","syncBehavior","syncBehaviorDefault","syncMaster","syncTolerance","syncToleranceDefault","systemLanguage","tableValues","targetX","targetY","textLength","transformBehavior","u1","u2","unicode","viewBox","viewTarget","visibility","widths","x1","x2","xChannelSelector","y1","y2","yChannelSelector","zoomAndPan","htmlBase","svgBase","valid","dash","cap","kebab","$0","camelcase","hastToReact","StyleToObject","pointEnd","point","pointStart","stringifyPosition","VFileMessage","causeOrReason","optionsOrParentOrPlace","legacyCause","place","ancestors","cause","ruleId","parent","fatal","file","actual","expected","note","emptyMap","dashSomething","tableElements","tableCellElement","docs","toJsxRuntime","tree","filePath","development","jsxDEV","isStaticChildren","columnNumber","fileName","lineNumber","developmentCreate","productionCreate","components","elementAttributeNameCase","evaluater","createEvaluater","ignoreInvalidStyle","passKeys","passNode","schema","stylePropertyNameCase","tableCellAlignToStyle","one","parentSchema","findComponentFromName","alignValue","createProperty","createElementProps","createChildren","thing","addNode","addChildren","estree","expression","evaluateExpression","crashEstree","mdxExpression","objectExpression","argument","createJsxElementProps","mdxJsxElement","evaluateProgram","mdxEsm","countsByName","Type","dashes","find","settings","padRight","padLeft","commas","styleToObject","replacer","toCamel","parseStyle","domCasing","cssCasing","transformStyleToCssCasing","transformStylesToCssCasing","allowExpression","identifiers","isIdentifierName","computed","optional","toDash","$1","urlAttributes","icon","includeImageAlt","includeHtml","remove","items","parameters","chunkStart","SpliceBuffer","right","RangeError","setCursor","stop","POSITIVE_INFINITY","reverse","deleteCount","trunc","removed","chunkedPush","item","pushMany","unshiftMany","subtokenize","eventsArray","jumps","lineIndex","otherIndex","otherEvent","subevents","more","events","_tokenizer","_isInFirstContentOfListItem","contentType","subcontent","_container","eventIndex","token","startPosition","startPositions","tokenizer","parser","childEvents","gaps","stream","previous","adjust","breaks","sliceStream","defineSkip","_gfmTasklistFirstContentOfListItem","write","syntaxExtension","extension","hook","constructs","existing","before","asciiAlpha","regexCheck","asciiAlphanumeric","asciiAtext","asciiControl","asciiDigit","asciiHexDigit","asciiPunctuation","markdownLineEnding","markdownLineEndingOrSpace","markdownSpace","unicodePunctuation","unicodeWhitespace","regex","factorySpace","limit","enter","consume","exit","tokenize","contentStart","attempt","contentInitial","lineStart","self","childFlow","childToken","lineStartOffset","continued","containerState","continuation","documentContinue","checkNewContainers","_closeFlow","closeFlow","indexBeforeExits","indexBeforeFlow","exitContainers","documentContinued","currentConstruct","concrete","flowStart","interrupt","_gfmTableDynamicInterruptHack","containerConstruct","thereIsANewContainer","thereIsNoNewContainer","containerContinue","flow","flowContinue","writeToChild","endOfFile","seen","nok","disable","null","blankLine","partial","after","chunkInside","contentEnd","continuationConstruct","contentContinue","prefixed","sliceSerialize","flowInitial","afterConstruct","resolver","resolveAll","createResolver","initializeFactory","resolveAllLineSuffixes","notText","atBreak","extraResolver","chunks","tabs","bufferIndex","chunk","_bufferIndex","_index","thematicBreak","marker","sequence","onBlank","notBlank","furtherBlankLines","initialBlankLine","notInCurrentItem","indentConstruct","initialSize","atMarker","inside","listItemPrefixWhitespaceConstruct","endOfPrefix","otherPrefix","blockQuote","contBefore","factoryDestination","literalType","literalMarkerType","rawType","stringType","balance","enclosedBefore","raw","enclosed","enclosedEscape","rawEscape","factoryLabel","markerType","labelInside","labelEscape","factoryTitle","factoryWhitespace","normalizeIdentifier","identifier","labelAfter","markerAfter","destinationBefore","destinationAfter","titleBefore","afterWhitespace","beforeMarker","titleAfter","titleAfterOptionalWhitespace","codeIndented","afterPrefix","furtherStart","headingAtx","sequenceOpen","sequenceFurther","setextUnderline","heading","paragraph","htmlBlockNames","htmlRawNames","htmlFlow","closingTag","buffer","markerB","declarationOpen","tagCloseStart","continuationDeclarationInside","commentOpenInside","cdataOpenInside","slash","basicSelfClosing","completeClosingTagAfter","completeAttributeNameBefore","completeEnd","completeAttributeName","completeAttributeNameAfter","completeAttributeValueBefore","completeAttributeValueQuoted","completeAttributeValueUnquoted","completeAttributeValueQuotedAfter","completeAfter","continuationCommentInside","continuationRawTagOpen","continuationClose","continuationCdataInside","continuationStart","blankLineBefore","continuationAfter","nonLazyContinuationStart","continuationStartNonLazy","continuationBefore","continuationRawEndTag","nonLazyContinuation","codeFenced","closeStart","startBefore","beforeSequenceClose","sequenceClose","sizeOpen","sequenceCloseAfter","initialPrefix","beforeSequenceOpen","infoBefore","atNonLazyBreak","metaBefore","contentBefore","beforeContentChunk","contentChunk","decodeNamedCharacterReference","characterReference","numeric","characterEscape","lineEnding","called","labelEnd","newEvents","close","_inactive","_balanced","group","insideSpan","labelStart","labelEndNok","resourceConstruct","labelEndOk","referenceFullConstruct","referenceNotFull","referenceCollapsedConstruct","resourceBefore","resourceOpen","resourceEnd","resourceDestinationAfter","resourceDestinationMissing","resourceBetween","resourceTitleAfter","referenceFullAfter","referenceFullMissing","referenceCollapsedOpen","labelStartImage","classifyCharacter","attention","openingSequence","closingSequence","use","nextEvents","_close","_open","movePoint","attentionMarkers","autolink","schemeOrEmailAtext","emailAtext","schemeInsideOrEmailAtext","urlInside","emailAtSignOrDot","emailLabel","emailValue","htmlText","returnState","instruction","tagOpen","commentEnd","commentClose","lineEndingBefore","cdata","cdataClose","cdataEnd","instructionClose","tagClose","tagCloseBetween","tagOpenBetween","tagOpenAttributeName","tagOpenAttributeNameAfter","tagOpenAttributeValueBefore","tagOpenAttributeValueQuoted","tagOpenAttributeValueUnquoted","tagOpenAttributeValueQuotedAfter","lineEndingAfter","lineEndingAfterPrefix","labelStartLink","hardBreakEscape","codeText","tailExitIndex","headEnterIndex","between","resolveText","createTokenizer","initialize","columnStart","resolveAllConstructs","consumed","constructFactory","addResult","onsuccessfulcheck","accountForPotentialSkip","fields","expandTabs","atTab","serializeChunks","main","expectedCode","startBufferIndex","endBufferIndex","head","sliceChunks","chunkIndex","restore","onreturn","bogusState","listOfConstructs","constructIndex","handleListOfConstructs","handleMapOfConstructs","handleConstruct","startPoint","startPrevious","startCurrentConstruct","startEventsIndex","startStack","store","extensions","combineExtensions","defaultConstructs","decodeNumericCharacterReference","parseInt","fromCodePoint","characterEscapeOrReference","$2","hex","fromMarkdown","encoding","config","transforms","canContainEols","opener","autolinkProtocol","onenterdata","autolinkEmail","atxHeading","codeFlow","codeFencedFenceInfo","codeFencedFenceMeta","codeTextData","codeFlowValue","definitionDestinationString","definitionLabelString","definitionTitleString","emphasis","hardBreak","hardBreakTrailing","htmlFlowData","htmlTextData","image","listItem","listItemValue","onenterlistitemvalue","listOrdered","onenterlistordered","listUnordered","reference","onenterreference","referenceString","resourceDestinationString","resourceTitleString","setextHeading","strong","closer","atxHeadingSequence","onexitatxheadingsequence","onexitautolinkemail","onexitautolinkprotocol","characterEscapeValue","onexitdata","characterReferenceMarkerHexadecimal","onexitcharacterreferencemarker","characterReferenceMarkerNumeric","characterReferenceValue","onexitcharacterreferencevalue","onexitcharacterreference","onexitcodefenced","codeFencedFence","onexitcodefencedfence","onexitcodefencedfenceinfo","onexitcodefencedfencemeta","onexitcodeindented","onexitcodetext","onexitdefinitiondestinationstring","onexitdefinitionlabelstring","onexitdefinitiontitlestring","onexithardbreak","onexithtmlflow","onexithtmltext","onexitimage","onexitlabel","labelText","onexitlabeltext","onexitlineending","onexitlink","onexitreferencestring","onexitresourcedestinationstring","onexitresourcetitlestring","onexitresource","onexitsetextheading","setextHeadingLineSequence","onexitsetextheadinglinesequence","setextHeadingText","onexitsetextheadingtext","configure","mdastExtensions","compile","tokenStack","resume","listStack","prepareList","defaultOnError","firstBlankLineIndex","containerBalance","listSpread","tailIndex","tailEvent","_spread","and","errorHandler","onExitError","expectingFirstListItemValue","flowCodeInside","depth","setextHeadingSlurpLineEnding","codePointAt","atHardBreak","inReference","referenceType","ancestor","decodeString","fragment","characterReferenceType","ordered","spread","compiler","postprocess","atCarriageReturn","endPosition","TextDecoder","lastIndex","preprocess","combined","remarkParse","doc","env","globalThis","deserialize","serialized","deserializer","$","out","unpair","BigInt","EMPTY","asString","shouldSkip","TYPE","serialize","json","lossy","serializer","strict","pair","toJSON","toISOString","structuredClone","any","normalizeUri","skip","defaultFootnoteBackContent","rereferenceIndex","defaultFootnoteBackLabel","referenceIndex","convert","castFactory","tests","_len","_key","anyFactory","checkAsRecord","nodeAsRecord","propsFactory","typeFactory","testFunction","looksLikeANode","CONTINUE","EXIT","visitParents","visitor","factory","parents","visit","subresult","grandparents","toResult","nodeAsParent","testOrVisitor","visitorOrReverse","maybeReverse","revert","subtype","suffix","contents","listItemLoose","trimLines","trimLine","blockquote","patch","applyData","break","footnoteReference","clobberPrefix","safeId","footnoteOrder","counter","reuseCounter","footnoteCounts","dataFootnoteRef","sup","allowDangerousHtml","imageReference","definitionById","inlineCode","linkReference","loose","listLoose","table","firstRow","tableContent","tableCell","tableRow","cellIndex","cells","cell","toml","ignore","yaml","footnoteDefinition","hName","hChildren","hProperties","defaultUnknownHandler","nodes","trimMarkdownSpaceStart","toHast","footnoteById","defaultHandlers","passThrough","shallow","unknownHandler","createState","foot","footnoteBackContent","footnoteBackLabel","footnoteLabel","footnoteLabelTagName","footnoteLabelProperties","listItems","backReferences","counts","dataFootnoteBackref","tailTail","dataFootnotes","footer","remarkRehype","destination","hastTree","run","bail","getPrototypeOf","trough","fns","pipeline","middlewareIndex","_len2","_key2","middleware","wrapped","fnExpectsCallback","_len4","_key4","middelware","minpath","extname","assertPath","seenNonSlash","firstNonSlashEnd","extnameIndex","dirname","unmatchedSlash","startPart","startDot","preDotState","joined","absolute","allowAboveRoot","lastSlashIndex","lastSegmentLength","lastSlash","dots","normalizeString","sep","minproc","cwd","isUrl","fileUrlOrPath","auth","urlToPath","hostname","third","getPathFromURLPosix","VFile","isUint8Array","messages","stored","assertNonEmpty","assertPart","stem","fail","part","CallableInstance","proto","setPrototypeOf","Processor","Compiler","Parser","attachers","freezeIndex","frozen","namespace","transformers","attacher","assertUnfrozen","freeze","transformer","realFile","vfile","assertParser","process","assertCompiler","executor","reject","parseTree","realDone","compileTree","compileResult","processSync","complete","assertDone","assertNode","outputTree","resultingTree","runSync","addPlugin","addList","addPreset","plugin","plugins","entryIndex","primary","currentPrimary","isPlainObj","unified","asyncName","looksLikeAVFile","emptyPlugins","emptyRemarkRehypeOptions","safeProtocol","deprecations","Markdown","allowedElements","allowElement","disallowedElements","rehypePlugins","remarkPlugins","remarkRehypeOptions","skipHtml","unwrapDisallowed","urlTransform","defaultUrlTransform","processor","deprecation","mdastTree","colon","questionMark","numberSign","slide","iframeRef","playerRef","initializePlayer","YT","Player","onReady","playVideo","pauseVideo","onStateChange","PlayerState","ENDED","seekTo","onYouTubeIframeAPIReady","_jsxs","_jsx","ReactMarkdown","baseURL","getEmbedUrl","isDarkMode","strokeLinecap","strokeLinejoin","months","selectedMonth","SlideDeck","year","slug","useParams","slides","setSlides","currentSlide","setCurrentSlide","setIsDarkMode","setMonths","response","fetchMonths","slidesPath","slidesForMonth","slideIndex","loadSlides","goToSlide","newIndex","newSlug","onSwipedLeft","onSwipedRight","preventDefaultTouchmoveEvent","handleKeyDown","DarkModeToggle","prev","Slide","MonthSelector","selectedYear","selectedMonthNum","goToRandomSlide","randomIndex","DebugRoute","ReactDOM","getElementById","App"],"sourceRoot":""} \ No newline at end of file diff --git a/docs/vercel.svg b/docs/vercel.svg deleted file mode 100644 index 7705396..0000000 --- a/docs/vercel.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/docs/window.svg b/docs/window.svg deleted file mode 100644 index b2b2a44..0000000 --- a/docs/window.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file

!^a