fumadocs-core 16.0.6 → 16.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/dist/breadcrumb.js +3 -3
  2. package/dist/chunk-A4G5V4FQ.js +47 -0
  3. package/dist/chunk-ADBHPKXG.js +78 -0
  4. package/dist/chunk-CH7YHH7V.js +222 -0
  5. package/dist/chunk-EFVXL2PP.js +144 -0
  6. package/dist/chunk-FUUVPEA5.js +29 -0
  7. package/dist/chunk-GLRQBLGN.js +59 -0
  8. package/dist/{chunk-QMATWJ5F.js → chunk-HNZEUF6C.js} +4 -11
  9. package/dist/chunk-JOXPHQ2R.js +73 -0
  10. package/dist/chunk-ONG4RVCR.js +8 -0
  11. package/dist/chunk-SLIKY7GW.js +111 -0
  12. package/dist/chunk-TWIDBWFG.js +84 -0
  13. package/dist/chunk-VW3XKOZZ.js +214 -0
  14. package/dist/chunk-X2HFD5QJ.js +275 -0
  15. package/dist/chunk-XJ6ZQNEX.js +91 -0
  16. package/dist/content/github.d.ts +7 -1
  17. package/dist/content/github.js +2 -1
  18. package/dist/content/toc.js +2 -1
  19. package/dist/mdx-plugins/codeblock-utils.d.ts +29 -0
  20. package/dist/mdx-plugins/codeblock-utils.js +9 -0
  21. package/dist/mdx-plugins/index.d.ts +18 -241
  22. package/dist/mdx-plugins/index.js +42 -1313
  23. package/dist/mdx-plugins/rehype-code.d.ts +55 -0
  24. package/dist/mdx-plugins/rehype-code.js +15 -0
  25. package/dist/mdx-plugins/rehype-toc.d.ts +14 -0
  26. package/dist/mdx-plugins/rehype-toc.js +7 -0
  27. package/dist/mdx-plugins/remark-admonition.d.ts +18 -0
  28. package/dist/mdx-plugins/remark-admonition.js +8 -0
  29. package/dist/mdx-plugins/remark-code-tab.d.ts +30 -0
  30. package/dist/mdx-plugins/remark-code-tab.js +8 -0
  31. package/dist/mdx-plugins/remark-gfm.d.ts +1 -0
  32. package/dist/mdx-plugins/remark-gfm.js +7 -0
  33. package/dist/mdx-plugins/remark-heading.d.ts +31 -0
  34. package/dist/mdx-plugins/remark-heading.js +8 -0
  35. package/dist/mdx-plugins/remark-image.d.ts +57 -0
  36. package/dist/mdx-plugins/remark-image.js +7 -0
  37. package/dist/mdx-plugins/remark-mdx-files.d.ts +40 -0
  38. package/dist/mdx-plugins/remark-mdx-files.js +7 -0
  39. package/dist/mdx-plugins/remark-mdx-mermaid.d.ts +15 -0
  40. package/dist/mdx-plugins/remark-mdx-mermaid.js +7 -0
  41. package/dist/mdx-plugins/remark-npm.d.ts +31 -0
  42. package/dist/mdx-plugins/remark-npm.js +8 -0
  43. package/dist/mdx-plugins/remark-steps.d.ts +23 -0
  44. package/dist/mdx-plugins/remark-steps.js +7 -0
  45. package/dist/{remark-structure-DkCXCzpD.d.ts → mdx-plugins/remark-structure.d.ts} +10 -5
  46. package/dist/mdx-plugins/remark-structure.js +10 -0
  47. package/dist/search/algolia.d.ts +1 -1
  48. package/dist/search/client.d.ts +1 -1
  49. package/dist/search/orama-cloud.d.ts +3 -2
  50. package/dist/search/server.d.ts +1 -1
  51. package/dist/search/server.js +3 -3
  52. package/dist/source/index.js +3 -3
  53. package/package.json +12 -7
  54. package/dist/remark-code-tab-DmyIyi6m.d.ts +0 -57
@@ -1,1321 +1,50 @@
1
1
  import {
2
- flattenNode,
3
- remarkHeading
4
- } from "../chunk-QMATWJ5F.js";
2
+ remarkImage
3
+ } from "../chunk-VW3XKOZZ.js";
5
4
  import {
6
- defaultThemes,
7
- getHighlighter
8
- } from "../chunk-XN2LKXFZ.js";
9
- import "../chunk-U67V476Y.js";
10
-
11
- // src/mdx-plugins/index.ts
5
+ remarkMdxFiles
6
+ } from "../chunk-ADBHPKXG.js";
12
7
  import {
13
- default as default2
14
- } from "remark-gfm";
15
-
16
- // src/mdx-plugins/rehype-code.ts
17
- import rehypeShikiFromHighlighter from "@shikijs/rehype/core";
8
+ remarkMdxMermaid
9
+ } from "../chunk-FUUVPEA5.js";
18
10
  import {
19
- transformerNotationDiff,
20
- transformerNotationFocus,
21
- transformerNotationHighlight,
22
- transformerNotationWordHighlight
23
- } from "@shikijs/transformers";
11
+ remarkNpm
12
+ } from "../chunk-GLRQBLGN.js";
24
13
  import {
25
- bundledLanguages
26
- } from "shiki";
27
-
28
- // src/mdx-plugins/transformer-icon.ts
29
- var defaultShortcuts = {
30
- js: "javascript",
31
- jsx: "react",
32
- ts: "typescript",
33
- tsx: "react",
34
- "c#": "csharp",
35
- cs: "csharp",
36
- gql: "graphql",
37
- py: "python",
38
- bash: "shellscript",
39
- sh: "shellscript",
40
- shell: "shellscript",
41
- zsh: "shellscript",
42
- "c++": "cpp"
43
- };
44
- var defaultIcons = {
45
- react: {
46
- viewBox: "0 0 24 24",
47
- fill: "currentColor",
48
- d: "M14.23 12.004a2.236 2.236 0 0 1-2.235 2.236 2.236 2.236 0 0 1-2.236-2.236 2.236 2.236 0 0 1 2.235-2.236 2.236 2.236 0 0 1 2.236 2.236zm2.648-10.69c-1.346 0-3.107.96-4.888 2.622-1.78-1.653-3.542-2.602-4.887-2.602-.41 0-.783.093-1.106.278-1.375.793-1.683 3.264-.973 6.365C1.98 8.917 0 10.42 0 12.004c0 1.59 1.99 3.097 5.043 4.03-.704 3.113-.39 5.588.988 6.38.32.187.69.275 1.102.275 1.345 0 3.107-.96 4.888-2.624 1.78 1.654 3.542 2.603 4.887 2.603.41 0 .783-.09 1.106-.275 1.374-.792 1.683-3.263.973-6.365C22.02 15.096 24 13.59 24 12.004c0-1.59-1.99-3.097-5.043-4.032.704-3.11.39-5.587-.988-6.38-.318-.184-.688-.277-1.092-.278zm-.005 1.09v.006c.225 0 .406.044.558.127.666.382.955 1.835.73 3.704-.054.46-.142.945-.25 1.44-.96-.236-2.006-.417-3.107-.534-.66-.905-1.345-1.727-2.035-2.447 1.592-1.48 3.087-2.292 4.105-2.295zm-9.77.02c1.012 0 2.514.808 4.11 2.28-.686.72-1.37 1.537-2.02 2.442-1.107.117-2.154.298-3.113.538-.112-.49-.195-.964-.254-1.42-.23-1.868.054-3.32.714-3.707.19-.09.4-.127.563-.132zm4.882 3.05c.455.468.91.992 1.36 1.564-.44-.02-.89-.034-1.345-.034-.46 0-.915.01-1.36.034.44-.572.895-1.096 1.345-1.565zM12 8.1c.74 0 1.477.034 2.202.093.406.582.802 1.203 1.183 1.86.372.64.71 1.29 1.018 1.946-.308.655-.646 1.31-1.013 1.95-.38.66-.773 1.288-1.18 1.87-.728.063-1.466.098-2.21.098-.74 0-1.477-.035-2.202-.093-.406-.582-.802-1.204-1.183-1.86-.372-.64-.71-1.29-1.018-1.946.303-.657.646-1.313 1.013-1.954.38-.66.773-1.286 1.18-1.868.728-.064 1.466-.098 2.21-.098zm-3.635.254c-.24.377-.48.763-.704 1.16-.225.39-.435.782-.635 1.174-.265-.656-.49-1.31-.676-1.947.64-.15 1.315-.283 2.015-.386zm7.26 0c.695.103 1.365.23 2.006.387-.18.632-.405 1.282-.66 1.933-.2-.39-.41-.783-.64-1.174-.225-.392-.465-.774-.705-1.146zm3.063.675c.484.15.944.317 1.375.498 1.732.74 2.852 1.708 2.852 2.476-.005.768-1.125 1.74-2.857 2.475-.42.18-.88.342-1.355.493-.28-.958-.646-1.956-1.1-2.98.45-1.017.81-2.01 1.085-2.964zm-13.395.004c.278.96.645 1.957 1.1 2.98-.45 1.017-.812 2.01-1.086 2.964-.484-.15-.944-.318-1.37-.5-1.732-.737-2.852-1.706-2.852-2.474 0-.768 1.12-1.742 2.852-2.476.42-.18.88-.342 1.356-.494zm11.678 4.28c.265.657.49 1.312.676 1.948-.64.157-1.316.29-2.016.39.24-.375.48-.762.705-1.158.225-.39.435-.788.636-1.18zm-9.945.02c.2.392.41.783.64 1.175.23.39.465.772.705 1.143-.695-.102-1.365-.23-2.006-.386.18-.63.406-1.282.66-1.933zM17.92 16.32c.112.493.2.968.254 1.423.23 1.868-.054 3.32-.714 3.708-.147.09-.338.128-.563.128-1.012 0-2.514-.807-4.11-2.28.686-.72 1.37-1.536 2.02-2.44 1.107-.118 2.154-.3 3.113-.54zm-11.83.01c.96.234 2.006.415 3.107.532.66.905 1.345 1.727 2.035 2.446-1.595 1.483-3.092 2.295-4.11 2.295-.22-.005-.406-.05-.553-.132-.666-.38-.955-1.834-.73-3.703.054-.46.142-.944.25-1.438zm4.56.64c.44.02.89.034 1.345.034.46 0 .915-.01 1.36-.034-.44.572-.895 1.095-1.345 1.565-.455-.47-.91-.993-1.36-1.565z"
49
- },
50
- vue: {
51
- viewBox: "0 0 24 24",
52
- fill: "currentColor",
53
- d: "M24,1.61H14.06L12,5.16,9.94,1.61H0L12,22.39ZM12,14.08,5.16,2.23H9.59L12,6.41l2.41-4.18h4.43Z"
54
- },
55
- ruby: {
56
- viewBox: "0 0 24 24",
57
- fill: "currentColor",
58
- d: "M20.156.083c3.033.525 3.893 2.598 3.829 4.77L24 4.822 22.635 22.71 4.89 23.926h.016C3.433 23.864.15 23.729 0 19.139l1.645-3 2.819 6.586.503 1.172 2.805-9.144-.03.007.016-.03 9.255 2.956-1.396-5.431-.99-3.9 8.82-.569-.615-.51L16.5 2.114 20.159.073l-.003.01zM0 19.089zM5.13 5.073c3.561-3.533 8.157-5.621 9.922-3.84 1.762 1.777-.105 6.105-3.673 9.636-3.563 3.532-8.103 5.734-9.864 3.957-1.766-1.777.045-6.217 3.612-9.75l.003-.003z"
59
- },
60
- zig: {
61
- viewBox: "0 0 24 24",
62
- fill: "currentColor",
63
- d: "m23.53 1.02-7.686 3.45h-7.06l-2.98 3.452h7.173L.47 22.98l7.681-3.607h7.065v-.002l2.978-3.45-7.148-.001 12.482-14.9zM0 4.47v14.901h1.883l2.98-3.45H3.451v-8h.942l2.824-3.45H0zm22.117 0-2.98 3.608h1.412v7.844h-.942l-2.98 3.45H24V4.47h-1.883z"
64
- },
65
- swift: {
66
- viewBox: "0 0 24 24",
67
- fill: "currentColor",
68
- d: "M7.508 0c-.287 0-.573 0-.86.002-.241.002-.483.003-.724.01-.132.003-.263.009-.395.015A9.154 9.154 0 0 0 4.348.15 5.492 5.492 0 0 0 2.85.645 5.04 5.04 0 0 0 .645 2.848c-.245.48-.4.972-.495 1.5-.093.52-.122 1.05-.136 1.576a35.2 35.2 0 0 0-.012.724C0 6.935 0 7.221 0 7.508v8.984c0 .287 0 .575.002.862.002.24.005.481.012.722.014.526.043 1.057.136 1.576.095.528.25 1.02.495 1.5a5.03 5.03 0 0 0 2.205 2.203c.48.244.97.4 1.498.495.52.093 1.05.124 1.576.138.241.007.483.009.724.01.287.002.573.002.86.002h8.984c.287 0 .573 0 .86-.002.241-.001.483-.003.724-.01a10.523 10.523 0 0 0 1.578-.138 5.322 5.322 0 0 0 1.498-.495 5.035 5.035 0 0 0 2.203-2.203c.245-.48.4-.972.495-1.5.093-.52.124-1.05.138-1.576.007-.241.009-.481.01-.722.002-.287.002-.575.002-.862V7.508c0-.287 0-.573-.002-.86a33.662 33.662 0 0 0-.01-.724 10.5 10.5 0 0 0-.138-1.576 5.328 5.328 0 0 0-.495-1.5A5.039 5.039 0 0 0 21.152.645 5.32 5.32 0 0 0 19.654.15a10.493 10.493 0 0 0-1.578-.138 34.98 34.98 0 0 0-.722-.01C17.067 0 16.779 0 16.492 0H7.508zm6.035 3.41c4.114 2.47 6.545 7.162 5.549 11.131-.024.093-.05.181-.076.272l.002.001c2.062 2.538 1.5 5.258 1.236 4.745-1.072-2.086-3.066-1.568-4.088-1.043a6.803 6.803 0 0 1-.281.158l-.02.012-.002.002c-2.115 1.123-4.957 1.205-7.812-.022a12.568 12.568 0 0 1-5.64-4.838c.649.48 1.35.902 2.097 1.252 3.019 1.414 6.051 1.311 8.197-.002C9.651 12.73 7.101 9.67 5.146 7.191a10.628 10.628 0 0 1-1.005-1.384c2.34 2.142 6.038 4.83 7.365 5.576C8.69 8.408 6.208 4.743 6.324 4.86c4.436 4.47 8.528 6.996 8.528 6.996.154.085.27.154.36.213.085-.215.16-.437.224-.668.708-2.588-.09-5.548-1.893-7.992z"
69
- },
70
- prisma: {
71
- viewBox: "0 0 24 24",
72
- fill: "currentColor",
73
- d: "M21.8068 18.2848L13.5528.7565c-.207-.4382-.639-.7273-1.1286-.7541-.5023-.0293-.9523.213-1.2062.6253L2.266 15.1271c-.2773.4518-.2718 1.0091.0158 1.4555l4.3759 6.7786c.2608.4046.7127.6388 1.1823.6388.1332 0 .267-.0188.3987-.0577l12.7019-3.7568c.3891-.1151.7072-.3904.8737-.7553s.1633-.7828-.0075-1.1454zm-1.8481.7519L9.1814 22.2242c-.3292.0975-.6448-.1873-.5756-.5194l3.8501-18.4386c.072-.3448.5486-.3996.699-.0803l7.1288 15.138c.1344.2856-.019.6224-.325.7128z"
74
- },
75
- typescript: {
76
- viewBox: "0 0 24 24",
77
- fill: "currentColor",
78
- d: "M1.125 0C.502 0 0 .502 0 1.125v21.75C0 23.498.502 24 1.125 24h21.75c.623 0 1.125-.502 1.125-1.125V1.125C24 .502 23.498 0 22.875 0zm17.363 9.75c.612 0 1.154.037 1.627.111a6.38 6.38 0 0 1 1.306.34v2.458a3.95 3.95 0 0 0-.643-.361 5.093 5.093 0 0 0-.717-.26 5.453 5.453 0 0 0-1.426-.2c-.3 0-.573.028-.819.086a2.1 2.1 0 0 0-.623.242c-.17.104-.3.229-.393.374a.888.888 0 0 0-.14.49c0 .196.053.373.156.529.104.156.252.304.443.444s.423.276.696.41c.273.135.582.274.926.416.47.197.892.407 1.266.628.374.222.695.473.963.753.268.279.472.598.614.957.142.359.214.776.214 1.253 0 .657-.125 1.21-.373 1.656a3.033 3.033 0 0 1-1.012 1.085 4.38 4.38 0 0 1-1.487.596c-.566.12-1.163.18-1.79.18a9.916 9.916 0 0 1-1.84-.164 5.544 5.544 0 0 1-1.512-.493v-2.63a5.033 5.033 0 0 0 3.237 1.2c.333 0 .624-.03.872-.09.249-.06.456-.144.623-.25.166-.108.29-.234.373-.38a1.023 1.023 0 0 0-.074-1.089 2.12 2.12 0 0 0-.537-.5 5.597 5.597 0 0 0-.807-.444 27.72 27.72 0 0 0-1.007-.436c-.918-.383-1.602-.852-2.053-1.405-.45-.553-.676-1.222-.676-2.005 0-.614.123-1.141.369-1.582.246-.441.58-.804 1.004-1.089a4.494 4.494 0 0 1 1.47-.629 7.536 7.536 0 0 1 1.77-.201zm-15.113.188h9.563v2.166H9.506v9.646H6.789v-9.646H3.375z"
79
- },
80
- javascript: {
81
- viewBox: "0 0 24 24",
82
- fill: "currentColor",
83
- d: "M0 0h24v24H0V0zm22.034 18.276c-.175-1.095-.888-2.015-3.003-2.873-.736-.345-1.554-.585-1.797-1.14-.091-.33-.105-.51-.046-.705.15-.646.915-.84 1.515-.66.39.12.75.42.976.9 1.034-.676 1.034-.676 1.755-1.125-.27-.42-.404-.601-.586-.78-.63-.705-1.469-1.065-2.834-1.034l-.705.089c-.676.165-1.32.525-1.71 1.005-1.14 1.291-.811 3.541.569 4.471 1.365 1.02 3.361 1.244 3.616 2.205.24 1.17-.87 1.545-1.966 1.41-.811-.18-1.26-.586-1.755-1.336l-1.83 1.051c.21.48.45.689.81 1.109 1.74 1.756 6.09 1.666 6.871-1.004.029-.09.24-.705.074-1.65l.046.067zm-8.983-7.245h-2.248c0 1.938-.009 3.864-.009 5.805 0 1.232.063 2.363-.138 2.711-.33.689-1.18.601-1.566.48-.396-.196-.597-.466-.83-.855-.063-.105-.11-.196-.127-.196l-1.825 1.125c.305.63.75 1.172 1.324 1.517.855.51 2.004.675 3.207.405.783-.226 1.458-.691 1.811-1.411.51-.93.402-2.07.397-3.346.012-2.054 0-4.109 0-6.179l.004-.056z"
84
- },
85
- php: {
86
- viewBox: "0 0 24 24",
87
- fill: "currentColor",
88
- d: "M7.01 10.207h-.944l-.515 2.648h.838c.556 0 .97-.105 1.242-.314.272-.21.455-.559.55-1.049.092-.47.05-.802-.124-.995-.175-.193-.523-.29-1.047-.29zM12 5.688C5.373 5.688 0 8.514 0 12s5.373 6.313 12 6.313S24 15.486 24 12c0-3.486-5.373-6.312-12-6.312zm-3.26 7.451c-.261.25-.575.438-.917.551-.336.108-.765.164-1.285.164H5.357l-.327 1.681H3.652l1.23-6.326h2.65c.797 0 1.378.209 1.744.628.366.418.476 1.002.33 1.752a2.836 2.836 0 0 1-.305.847c-.143.255-.33.49-.561.703zm4.024.715l.543-2.799c.063-.318.039-.536-.068-.651-.107-.116-.336-.174-.687-.174H11.46l-.704 3.625H9.388l1.23-6.327h1.367l-.327 1.682h1.218c.767 0 1.295.134 1.586.401s.378.7.263 1.299l-.572 2.944h-1.389zm7.597-2.265a2.782 2.782 0 0 1-.305.847c-.143.255-.33.49-.561.703a2.44 2.44 0 0 1-.917.551c-.336.108-.765.164-1.286.164h-1.18l-.327 1.682h-1.378l1.23-6.326h2.649c.797 0 1.378.209 1.744.628.366.417.477 1.001.331 1.751zM17.766 10.207h-.943l-.516 2.648h.838c.557 0 .971-.105 1.242-.314.272-.21.455-.559.551-1.049.092-.47.049-.802-.125-.995s-.524-.29-1.047-.29z"
89
- },
90
- shellscript: {
91
- viewBox: "0 0 24 24",
92
- fill: "currentColor",
93
- d: "m 4,4 a 1,1 0 0 0 -0.7070312,0.2929687 1,1 0 0 0 0,1.4140625 L 8.5859375,11 3.2929688,16.292969 a 1,1 0 0 0 0,1.414062 1,1 0 0 0 1.4140624,0 l 5.9999998,-6 a 1.0001,1.0001 0 0 0 0,-1.414062 L 4.7070312,4.2929687 A 1,1 0 0 0 4,4 Z m 8,14 a 1,1 0 0 0 -1,1 1,1 0 0 0 1,1 h 8 a 1,1 0 0 0 1,-1 1,1 0 0 0 -1,-1 z"
94
- },
95
- c: {
96
- viewBox: "0 0 24 24",
97
- fill: "currentColor",
98
- d: "M16.5921 9.1962s-.354-3.298-3.627-3.39c-3.2741-.09-4.9552 2.474-4.9552 6.14 0 3.6651 1.858 6.5972 5.0451 6.5972 3.184 0 3.5381-3.665 3.5381-3.665l6.1041.365s.36 3.31-2.196 5.836c-2.552 2.5241-5.6901 2.9371-7.8762 2.9201-2.19-.017-5.2261.034-8.1602-2.97-2.938-3.0101-3.436-5.9302-3.436-8.8002 0-2.8701.556-6.6702 4.047-9.5502C7.444.72 9.849 0 12.254 0c10.0422 0 10.7172 9.2602 10.7172 9.2602z"
99
- },
100
- cpp: {
101
- viewBox: "0 0 24 24",
102
- fill: "currentColor",
103
- d: "M22.394 6c-.167-.29-.398-.543-.652-.69L12.926.22c-.509-.294-1.34-.294-1.848 0L2.26 5.31c-.508.293-.923 1.013-.923 1.6v10.18c0 .294.104.62.271.91.167.29.398.543.652.69l8.816 5.09c.508.293 1.34.293 1.848 0l8.816-5.09c.254-.147.485-.4.652-.69.167-.29.27-.616.27-.91V6.91c.003-.294-.1-.62-.268-.91zM12 19.11c-3.92 0-7.109-3.19-7.109-7.11 0-3.92 3.19-7.11 7.11-7.11a7.133 7.133 0 016.156 3.553l-3.076 1.78a3.567 3.567 0 00-3.08-1.78A3.56 3.56 0 008.444 12 3.56 3.56 0 0012 15.555a3.57 3.57 0 003.08-1.778l3.078 1.78A7.135 7.135 0 0112 19.11zm7.11-6.715h-.79v.79h-.79v-.79h-.79v-.79h.79v-.79h.79v.79h.79zm2.962 0h-.79v.79h-.79v-.79h-.79v-.79h.79v-.79h.79v.79h.79z"
104
- },
105
- go: {
106
- viewBox: "0 0 24 24",
107
- fill: "currentColor",
108
- d: "M1.811 10.231c-.047 0-.058-.023-.035-.059l.246-.315c.023-.035.081-.058.128-.058h4.172c.046 0 .058.035.035.07l-.199.303c-.023.036-.082.07-.117.07zM.047 11.306c-.047 0-.059-.023-.035-.058l.245-.316c.023-.035.082-.058.129-.058h5.328c.047 0 .07.035.058.07l-.093.28c-.012.047-.058.07-.105.07zm2.828 1.075c-.047 0-.059-.035-.035-.07l.163-.292c.023-.035.07-.07.117-.07h2.337c.047 0 .07.035.07.082l-.023.28c0 .047-.047.082-.082.082zm12.129-2.36c-.736.187-1.239.327-1.963.514-.176.046-.187.058-.34-.117-.174-.199-.303-.327-.548-.444-.737-.362-1.45-.257-2.115.175-.795.514-1.204 1.274-1.192 2.22.011.935.654 1.706 1.577 1.835.795.105 1.46-.175 1.987-.77.105-.13.198-.27.315-.434H10.47c-.245 0-.304-.152-.222-.35.152-.362.432-.97.596-1.274a.315.315 0 01.292-.187h4.253c-.023.316-.023.631-.07.947a4.983 4.983 0 01-.958 2.29c-.841 1.11-1.94 1.8-3.33 1.986-1.145.152-2.209-.07-3.143-.77-.865-.655-1.356-1.52-1.484-2.595-.152-1.274.222-2.419.993-3.424.83-1.086 1.928-1.776 3.272-2.02 1.098-.2 2.15-.07 3.096.571.62.41 1.063.97 1.356 1.648.07.105.023.164-.117.2m3.868 6.461c-1.064-.024-2.034-.328-2.852-1.029a3.665 3.665 0 01-1.262-2.255c-.21-1.32.152-2.489.947-3.529.853-1.122 1.881-1.706 3.272-1.95 1.192-.21 2.314-.095 3.33.595.923.63 1.496 1.484 1.648 2.605.198 1.578-.257 2.863-1.344 3.962-.771.783-1.718 1.273-2.805 1.495-.315.06-.63.07-.934.106zm2.78-4.72c-.011-.153-.011-.27-.034-.387-.21-1.157-1.274-1.81-2.384-1.554-1.087.245-1.788.935-2.045 2.033-.21.912.234 1.835 1.075 2.21.643.28 1.285.244 1.905-.07.923-.48 1.425-1.228 1.484-2.233z"
109
- },
110
- graphql: {
111
- viewBox: "0 0 24 24",
112
- fill: "currentColor",
113
- d: "M12.002 0a2.138 2.138 0 1 0 0 4.277 2.138 2.138 0 1 0 0-4.277zm8.54 4.931a2.138 2.138 0 1 0 0 4.277 2.138 2.138 0 1 0 0-4.277zm0 9.862a2.138 2.138 0 1 0 0 4.277 2.138 2.138 0 1 0 0-4.277zm-8.54 4.931a2.138 2.138 0 1 0 0 4.276 2.138 2.138 0 1 0 0-4.276zm-8.542-4.93a2.138 2.138 0 1 0 0 4.276 2.138 2.138 0 1 0 0-4.277zm0-9.863a2.138 2.138 0 1 0 0 4.277 2.138 2.138 0 1 0 0-4.277zm8.542-3.378L2.953 6.777v10.448l9.049 5.224 9.047-5.224V6.777zm0 1.601 7.66 13.27H4.34zm-1.387.371L3.97 15.037V7.363zm2.774 0 6.646 3.838v7.674zM5.355 17.44h13.293l-6.646 3.836z"
114
- },
115
- python: {
116
- viewBox: "0 0 24 24",
117
- fill: "currentColor",
118
- d: "M14.25.18l.9.2.73.26.59.3.45.32.34.34.25.34.16.33.1.3.04.26.02.2-.01.13V8.5l-.05.63-.13.55-.21.46-.26.38-.3.31-.33.25-.35.19-.35.14-.33.1-.3.07-.26.04-.21.02H8.77l-.69.05-.59.14-.5.22-.41.27-.33.32-.27.35-.2.36-.15.37-.1.35-.07.32-.04.27-.02.21v3.06H3.17l-.21-.03-.28-.07-.32-.12-.35-.18-.36-.26-.36-.36-.35-.46-.32-.59-.28-.73-.21-.88-.14-1.05-.05-1.23.06-1.22.16-1.04.24-.87.32-.71.36-.57.4-.44.42-.33.42-.24.4-.16.36-.1.32-.05.24-.01h.16l.06.01h8.16v-.83H6.18l-.01-2.75-.02-.37.05-.34.11-.31.17-.28.25-.26.31-.23.38-.2.44-.18.51-.15.58-.12.64-.1.71-.06.77-.04.84-.02 1.27.05zm-6.3 1.98l-.23.33-.08.41.08.41.23.34.33.22.41.09.41-.09.33-.22.23-.34.08-.41-.08-.41-.23-.33-.33-.22-.41-.09-.41.09zm13.09 3.95l.28.06.32.12.35.18.36.27.36.35.35.47.32.59.28.73.21.88.14 1.04.05 1.23-.06 1.23-.16 1.04-.24.86-.32.71-.36.57-.4.45-.42.33-.42.24-.4.16-.36.09-.32.05-.24.02-.16-.01h-8.22v.82h5.84l.01 2.76.02.36-.05.34-.11.31-.17.29-.25.25-.31.24-.38.2-.44.17-.51.15-.58.13-.64.09-.71.07-.77.04-.84.01-1.27-.04-1.07-.14-.9-.2-.73-.25-.59-.3-.45-.33-.34-.34-.25-.34-.16-.33-.1-.3-.04-.25-.02-.2.01-.13v-5.34l.05-.64.13-.54.21-.46.26-.38.3-.32.33-.24.35-.2.35-.14.33-.1.3-.06.26-.04.21-.02.13-.01h5.84l.69-.05.59-.14.5-.21.41-.28.33-.32.27-.35.2-.36.15-.36.1-.35.07-.32.04-.28.02-.21V6.07h2.09l.14.01zm-6.47 14.25l-.23.33-.08.41.08.41.23.33.33.23.41.08.41-.08.33-.23.23-.33.08-.41-.08-.41-.23-.33-.33-.23-.41-.08-.41.08z"
119
- },
120
- md: {
121
- viewBox: "0 0 24 24",
122
- fill: "currentColor",
123
- d: "M22.27 19.385H1.73A1.73 1.73 0 010 17.655V6.345a1.73 1.73 0 011.73-1.73h20.54A1.73 1.73 0 0124 6.345v11.308a1.73 1.73 0 01-1.73 1.731zM5.769 15.923v-4.5l2.308 2.885 2.307-2.885v4.5h2.308V8.078h-2.308l-2.307 2.885-2.308-2.885H3.46v7.847zM21.232 12h-2.309V8.077h-2.307V12h-2.308l3.461 4.039z"
124
- },
125
- kotlin: {
126
- viewBox: "0 0 24 24",
127
- fill: "currentColor",
128
- d: "M24 24H0V0h24L12 12Z"
129
- },
130
- rust: {
131
- viewBox: "0 0 24 24",
132
- fill: "currentColor",
133
- d: "M23.8346 11.7033l-1.0073-.6236a13.7268 13.7268 0 00-.0283-.2936l.8656-.8069a.3483.3483 0 00-.1154-.578l-1.1066-.414a8.4958 8.4958 0 00-.087-.2856l.6904-.9587a.3462.3462 0 00-.2257-.5446l-1.1663-.1894a9.3574 9.3574 0 00-.1407-.2622l.49-1.0761a.3437.3437 0 00-.0274-.3361.3486.3486 0 00-.3006-.154l-1.1845.0416a6.7444 6.7444 0 00-.1873-.2268l.2723-1.153a.3472.3472 0 00-.417-.4172l-1.1532.2724a14.0183 14.0183 0 00-.2278-.1873l.0415-1.1845a.3442.3442 0 00-.49-.328l-1.076.491c-.0872-.0476-.1742-.0952-.2623-.1407l-.1903-1.1673A.3483.3483 0 0016.256.955l-.9597.6905a8.4867 8.4867 0 00-.2855-.086l-.414-1.1066a.3483.3483 0 00-.5781-.1154l-.8069.8666a9.2936 9.2936 0 00-.2936-.0284L12.2946.1683a.3462.3462 0 00-.5892 0l-.6236 1.0073a13.7383 13.7383 0 00-.2936.0284L9.9803.3374a.3462.3462 0 00-.578.1154l-.4141 1.1065c-.0962.0274-.1903.0567-.2855.086L7.744.955a.3483.3483 0 00-.5447.2258L7.009 2.348a9.3574 9.3574 0 00-.2622.1407l-1.0762-.491a.3462.3462 0 00-.49.328l.0416 1.1845a7.9826 7.9826 0 00-.2278.1873L3.8413 3.425a.3472.3472 0 00-.4171.4171l.2713 1.1531c-.0628.075-.1255.1509-.1863.2268l-1.1845-.0415a.3462.3462 0 00-.328.49l.491 1.0761a9.167 9.167 0 00-.1407.2622l-1.1662.1894a.3483.3483 0 00-.2258.5446l.6904.9587a13.303 13.303 0 00-.087.2855l-1.1065.414a.3483.3483 0 00-.1155.5781l.8656.807a9.2936 9.2936 0 00-.0283.2935l-1.0073.6236a.3442.3442 0 000 .5892l1.0073.6236c.008.0982.0182.1964.0283.2936l-.8656.8079a.3462.3462 0 00.1155.578l1.1065.4141c.0273.0962.0567.1914.087.2855l-.6904.9587a.3452.3452 0 00.2268.5447l1.1662.1893c.0456.088.0922.1751.1408.2622l-.491 1.0762a.3462.3462 0 00.328.49l1.1834-.0415c.0618.0769.1235.1528.1873.2277l-.2713 1.1541a.3462.3462 0 00.4171.4161l1.153-.2713c.075.0638.151.1255.2279.1863l-.0415 1.1845a.3442.3442 0 00.49.327l1.0761-.49c.087.0486.1741.0951.2622.1407l.1903 1.1662a.3483.3483 0 00.5447.2268l.9587-.6904a9.299 9.299 0 00.2855.087l.414 1.1066a.3452.3452 0 00.5781.1154l.8079-.8656c.0972.0111.1954.0203.2936.0294l.6236 1.0073a.3472.3472 0 00.5892 0l.6236-1.0073c.0982-.0091.1964-.0183.2936-.0294l.8069.8656a.3483.3483 0 00.578-.1154l.4141-1.1066a8.4626 8.4626 0 00.2855-.087l.9587.6904a.3452.3452 0 00.5447-.2268l.1903-1.1662c.088-.0456.1751-.0931.2622-.1407l1.0762.49a.3472.3472 0 00.49-.327l-.0415-1.1845a6.7267 6.7267 0 00.2267-.1863l1.1531.2713a.3472.3472 0 00.4171-.416l-.2713-1.1542c.0628-.0749.1255-.1508.1863-.2278l1.1845.0415a.3442.3442 0 00.328-.49l-.49-1.076c.0475-.0872.0951-.1742.1407-.2623l1.1662-.1893a.3483.3483 0 00.2258-.5447l-.6904-.9587.087-.2855 1.1066-.414a.3462.3462 0 00.1154-.5781l-.8656-.8079c.0101-.0972.0202-.1954.0283-.2936l1.0073-.6236a.3442.3442 0 000-.5892zm-6.7413 8.3551a.7138.7138 0 01.2986-1.396.714.714 0 11-.2997 1.396zm-.3422-2.3142a.649.649 0 00-.7715.5l-.3573 1.6685c-1.1035.501-2.3285.7795-3.6193.7795a8.7368 8.7368 0 01-3.6951-.814l-.3574-1.6684a.648.648 0 00-.7714-.499l-1.473.3158a8.7216 8.7216 0 01-.7613-.898h7.1676c.081 0 .1356-.0141.1356-.088v-2.536c0-.074-.0536-.0881-.1356-.0881h-2.0966v-1.6077h2.2677c.2065 0 1.1065.0587 1.394 1.2088.0901.3533.2875 1.5044.4232 1.8729.1346.413.6833 1.2381 1.2685 1.2381h3.5716a.7492.7492 0 00.1296-.0131 8.7874 8.7874 0 01-.8119.9526zM6.8369 20.024a.714.714 0 11-.2997-1.396.714.714 0 01.2997 1.396zM4.1177 8.9972a.7137.7137 0 11-1.304.5791.7137.7137 0 011.304-.579zm-.8352 1.9813l1.5347-.6824a.65.65 0 00.33-.8585l-.3158-.7147h1.2432v5.6025H3.5669a8.7753 8.7753 0 01-.2834-3.348zm6.7343-.5437V8.7836h2.9601c.153 0 1.0792.1772 1.0792.8697 0 .575-.7107.7815-1.2948.7815zm10.7574 1.4862c0 .2187-.008.4363-.0243.651h-.9c-.09 0-.1265.0586-.1265.1477v.413c0 .973-.5487 1.1846-1.0296 1.2382-.4576.0517-.9648-.1913-1.0275-.4717-.2704-1.5186-.7198-1.8436-1.4305-2.4034.8817-.5599 1.799-1.386 1.799-2.4915 0-1.1936-.819-1.9458-1.3769-2.3153-.7825-.5163-1.6491-.6195-1.883-.6195H5.4682a8.7651 8.7651 0 014.907-2.7699l1.0974 1.151a.648.648 0 00.9182.0213l1.227-1.1743a8.7753 8.7753 0 016.0044 4.2762l-.8403 1.8982a.652.652 0 00.33.8585l1.6178.7188c.0283.2875.0425.577.0425.8717zm-9.3006-9.5993a.7128.7128 0 11.984 1.0316.7137.7137 0 01-.984-1.0316zm8.3389 6.71a.7107.7107 0 01.9395-.3625.7137.7137 0 11-.9405.3635z"
134
- },
135
- csharp: {
136
- viewBox: "0 0 24 24",
137
- fill: "currentColor",
138
- d: "M1.194 7.543v8.913c0 1.103.588 2.122 1.544 2.674l7.718 4.456a3.086 3.086 0 0 0 3.088 0l7.718-4.456a3.087 3.087 0 0 0 1.544-2.674V7.543a3.084 3.084 0 0 0-1.544-2.673L13.544.414a3.086 3.086 0 0 0-3.088 0L2.738 4.87a3.085 3.085 0 0 0-1.544 2.673Zm5.403 2.914v3.087a.77.77 0 0 0 .772.772.773.773 0 0 0 .772-.772.773.773 0 0 1 1.317-.546.775.775 0 0 1 .226.546 2.314 2.314 0 1 1-4.631 0v-3.087c0-.615.244-1.203.679-1.637a2.312 2.312 0 0 1 3.274 0c.434.434.678 1.023.678 1.637a.769.769 0 0 1-.226.545.767.767 0 0 1-1.091 0 .77.77 0 0 1-.226-.545.77.77 0 0 0-.772-.772.771.771 0 0 0-.772.772Zm12.35 3.087a.77.77 0 0 1-.772.772h-.772v.772a.773.773 0 0 1-1.544 0v-.772h-1.544v.772a.773.773 0 0 1-1.317.546.775.775 0 0 1-.226-.546v-.772H12a.771.771 0 1 1 0-1.544h.772v-1.543H12a.77.77 0 1 1 0-1.544h.772v-.772a.773.773 0 0 1 1.317-.546.775.775 0 0 1 .226.546v.772h1.544v-.772a.773.773 0 0 1 1.544 0v.772h.772a.772.772 0 0 1 0 1.544h-.772v1.543h.772a.776.776 0 0 1 .772.772Zm-3.088-2.315h-1.544v1.543h1.544v-1.543Z"
139
- },
140
- default: {
141
- viewBox: "0 0 24 24",
142
- fill: "currentColor",
143
- d: "M 6,1 C 4.354992,1 3,2.354992 3,4 v 16 c 0,1.645008 1.354992,3 3,3 h 12 c 1.645008,0 3,-1.354992 3,-3 V 8 7 A 1.0001,1.0001 0 0 0 20.707031,6.2929687 l -5,-5 A 1.0001,1.0001 0 0 0 15,1 h -1 z m 0,2 h 7 v 3 c 0,1.645008 1.354992,3 3,3 h 3 v 11 c 0,0.564129 -0.435871,1 -1,1 H 6 C 5.4358712,21 5,20.564129 5,20 V 4 C 5,3.4358712 5.4358712,3 6,3 Z M 15,3.4140625 18.585937,7 H 16 C 15.435871,7 15,6.5641288 15,6 Z"
144
- }
145
- };
146
- function transformerIcon(options = {}) {
147
- const shortcuts = {
148
- ...defaultShortcuts,
149
- ...options.shortcuts
150
- };
151
- const icons = {
152
- ...defaultIcons,
153
- ...options.extend
154
- };
155
- const defaultIcon = "default" in icons ? icons.default : void 0;
156
- return {
157
- name: "rehype-code:icon",
158
- pre(pre) {
159
- const lang = this.options.lang;
160
- if (!lang) return;
161
- const iconName = lang in shortcuts ? shortcuts[lang] : lang;
162
- const icon = iconName in icons ? icons[iconName] : defaultIcon;
163
- if (icon) {
164
- pre.properties.icon = typeof icon === "string" ? icon : `<svg viewBox="${icon.viewBox}"><path d="${icon.d}" fill="${icon.fill}" /></svg>`;
165
- }
166
- return pre;
167
- }
168
- };
169
- }
170
-
171
- // src/mdx-plugins/codeblock-utils.ts
172
- function generateCodeBlockTabs({
173
- persist = false,
174
- defaultValue,
175
- triggers,
176
- tabs,
177
- ...options
178
- }) {
179
- const attributes = [];
180
- if (options.attributes) attributes.push(...options.attributes);
181
- if (defaultValue) {
182
- attributes.push({
183
- type: "mdxJsxAttribute",
184
- name: "defaultValue",
185
- value: defaultValue
186
- });
187
- }
188
- if (typeof persist === "object") {
189
- attributes.push(
190
- {
191
- type: "mdxJsxAttribute",
192
- name: "groupId",
193
- value: persist.id
194
- },
195
- {
196
- type: "mdxJsxAttribute",
197
- name: "persist",
198
- value: null
199
- }
200
- );
201
- }
202
- const children = [
203
- {
204
- type: "mdxJsxFlowElement",
205
- name: "CodeBlockTabsList",
206
- attributes: [],
207
- children: triggers.map(
208
- (trigger) => ({
209
- type: "mdxJsxFlowElement",
210
- attributes: [
211
- { type: "mdxJsxAttribute", name: "value", value: trigger.value }
212
- ],
213
- name: "CodeBlockTabsTrigger",
214
- children: trigger.children
215
- })
216
- )
217
- }
218
- ];
219
- for (const tab of tabs) {
220
- children.push({
221
- type: "mdxJsxFlowElement",
222
- name: "CodeBlockTab",
223
- attributes: [
224
- { type: "mdxJsxAttribute", name: "value", value: tab.value }
225
- ],
226
- children: tab.children
227
- });
228
- }
229
- return {
230
- type: "mdxJsxFlowElement",
231
- name: "CodeBlockTabs",
232
- attributes,
233
- children
234
- };
235
- }
236
- function parseCodeBlockAttributes(meta, allowedNames) {
237
- let str = meta;
238
- const StringRegex = /(?<=^|\s)(?<name>\w+)(?:=(?:"([^"]*)"|'([^']*)'))?/g;
239
- const attributes = {};
240
- str = str.replaceAll(StringRegex, (match, name, value_1, value_2) => {
241
- if (allowedNames && !allowedNames.includes(name)) return match;
242
- attributes[name] = value_1 ?? value_2 ?? null;
243
- return "";
244
- });
245
- return {
246
- rest: str,
247
- attributes
248
- };
249
- }
250
-
251
- // src/mdx-plugins/rehype-code.ts
252
- var rehypeCodeDefaultOptions = {
253
- lazy: true,
254
- themes: defaultThemes,
255
- defaultColor: false,
256
- defaultLanguage: "plaintext",
257
- engine: "js",
258
- transformers: [
259
- transformerNotationHighlight({
260
- matchAlgorithm: "v3"
261
- }),
262
- transformerNotationWordHighlight({
263
- matchAlgorithm: "v3"
264
- }),
265
- transformerNotationDiff({
266
- matchAlgorithm: "v3"
267
- }),
268
- transformerNotationFocus({
269
- matchAlgorithm: "v3"
270
- })
271
- ],
272
- parseMetaString(meta) {
273
- const parsed = parseCodeBlockAttributes(meta, ["title", "tab"]);
274
- const data = parsed.attributes;
275
- parsed.rest = parseLineNumber(parsed.rest, data);
276
- data.__parsed_raw = parsed.rest;
277
- return data;
278
- }
279
- };
280
- function parseLineNumber(str, data) {
281
- return str.replace(/lineNumbers=(\d+)|lineNumbers/, (_, ...args) => {
282
- data["data-line-numbers"] = true;
283
- if (args[0] !== void 0)
284
- data["data-line-numbers-start"] = Number(args[0]);
285
- return "";
286
- });
287
- }
288
- function rehypeCode(_options = {}) {
289
- const options = {
290
- ...rehypeCodeDefaultOptions,
291
- ..._options
292
- };
293
- const transformers = [...options.transformers ?? []];
294
- transformers.unshift({
295
- name: "rehype-code:pre-process",
296
- preprocess(code, { meta }) {
297
- if (meta && "__parsed_raw" in meta) {
298
- meta.__raw = meta.__parsed_raw;
299
- delete meta.__parsed_raw;
300
- }
301
- if (meta && options.filterMetaString) {
302
- meta.__raw = options.filterMetaString(meta.__raw ?? "");
303
- }
304
- return code.replace(/\n$/, "");
305
- }
306
- });
307
- if (options.icon !== false) {
308
- transformers.push(transformerIcon(options.icon));
309
- }
310
- if (options.tab !== false) {
311
- transformers.push(transformerTab());
312
- }
313
- const highlighter = getHighlighter(options.engine ?? "js", {
314
- themes: "themes" in options ? Object.values(options.themes).filter(Boolean) : [options.theme],
315
- langs: options.langs ?? (options.lazy ? ["ts", "tsx"] : Object.keys(bundledLanguages)),
316
- langAlias: options.langAlias
317
- });
318
- const transformer = highlighter.then(
319
- (loaded) => rehypeShikiFromHighlighter(loaded, {
320
- ...options,
321
- transformers
322
- })
323
- );
324
- return async (tree, file) => {
325
- await (await transformer)(tree, file, () => {
326
- });
327
- };
328
- }
329
- function transformerTab() {
330
- return {
331
- name: "rehype-code:tab",
332
- // @ts-expect-error -- types not compatible with MDX
333
- root(root) {
334
- const value = this.options.meta?.tab;
335
- if (typeof value !== "string") return root;
336
- console.warn(
337
- '[Fumadocs] For `tab="value" in codeblocks, please use `remarkCodeTab` plugin instead.'
338
- );
339
- return {
340
- type: "root",
341
- children: [
342
- {
343
- type: "mdxJsxFlowElement",
344
- name: "Tab",
345
- data: {
346
- _codeblock: true
347
- },
348
- attributes: [{ type: "mdxJsxAttribute", name: "value", value }],
349
- children: root.children
350
- }
351
- ]
352
- };
353
- }
354
- };
355
- }
356
-
357
- // src/mdx-plugins/remark-image.ts
358
- import * as path from "path";
359
- import { visit } from "unist-util-visit";
360
- import { imageSize } from "image-size";
361
- import { imageSizeFromFile } from "image-size/fromFile";
362
- import { fileURLToPath } from "url";
363
- var VALID_BLUR_EXT = [".jpeg", ".png", ".webp", ".avif", ".jpg"];
364
- var EXTERNAL_URL_REGEX = /^https?:\/\//;
365
- function remarkImage({
366
- placeholder = "blur",
367
- external = true,
368
- useImport = true,
369
- onError = "error",
370
- publicDir = path.join(process.cwd(), "public")
371
- } = {}) {
372
- return async (tree, file) => {
373
- const importsToInject = [];
374
- const promises = [];
375
- async function onImage(src, node) {
376
- if (src.type === "file" && useImport) {
377
- const variableName = `__img${importsToInject.length}`;
378
- const hasBlur = placeholder === "blur" && VALID_BLUR_EXT.some((ext) => src.file.endsWith(ext));
379
- if (!file.dirname) {
380
- throw new Error(
381
- "When `useImport` is enabled, you must specify `dirname` in the VFile passed to compiler."
382
- );
383
- }
384
- importsToInject.push({
385
- variableName,
386
- importPath: getImportPath(src.file, file.dirname)
387
- });
388
- const out = {
389
- children: [],
390
- type: "mdxJsxFlowElement",
391
- name: "img",
392
- attributes: [
393
- {
394
- type: "mdxJsxAttribute",
395
- name: "alt",
396
- value: node.alt ?? "image"
397
- },
398
- {
399
- type: "mdxJsxAttribute",
400
- name: "src",
401
- value: {
402
- type: "mdxJsxAttributeValueExpression",
403
- value: variableName,
404
- data: {
405
- estree: {
406
- body: [
407
- {
408
- type: "ExpressionStatement",
409
- expression: { type: "Identifier", name: variableName }
410
- }
411
- ],
412
- type: "Program",
413
- sourceType: "script"
414
- }
415
- }
416
- }
417
- }
418
- ]
419
- };
420
- if (hasBlur) {
421
- out.attributes.push({
422
- type: "mdxJsxAttribute",
423
- name: "placeholder",
424
- value: "blur"
425
- });
426
- }
427
- return out;
428
- }
429
- if (src.type === "url" && !external) return;
430
- const size = await getImageSize(src).catch((e) => {
431
- throw new Error(
432
- `[Remark Image] Failed obtain image size for ${node.url} (public directory configured as ${publicDir})`,
433
- {
434
- cause: e
435
- }
436
- );
437
- });
438
- return {
439
- type: "mdxJsxFlowElement",
440
- name: "img",
441
- attributes: [
442
- {
443
- type: "mdxJsxAttribute",
444
- name: "alt",
445
- value: node.alt ?? "image"
446
- },
447
- {
448
- type: "mdxJsxAttribute",
449
- name: "src",
450
- // `src` doesn't support file paths, we can use `node.url` for files and let the underlying framework handle it
451
- value: src.type === "url" ? src.url.toString() : node.url
452
- },
453
- {
454
- type: "mdxJsxAttribute",
455
- name: "width",
456
- value: size.width.toString()
457
- },
458
- {
459
- type: "mdxJsxAttribute",
460
- name: "height",
461
- value: size.height.toString()
462
- }
463
- ],
464
- children: []
465
- };
466
- }
467
- visit(tree, "image", (node) => {
468
- const src = parseSrc(decodeURI(node.url), publicDir, file.dirname);
469
- if (!src) return;
470
- const task = onImage(src, node).catch((e) => {
471
- if (onError === "ignore" || node.url.endsWith(".svg")) {
472
- return;
473
- }
474
- if (onError === "hide") {
475
- return {
476
- type: "mdxJsxFlowElement",
477
- name: null,
478
- attributes: [],
479
- children: []
480
- };
481
- }
482
- if (onError === "error") throw e;
483
- onError(e);
484
- }).then((res) => {
485
- if (res) Object.assign(node, res);
486
- });
487
- promises.push(task);
488
- });
489
- await Promise.all(promises);
490
- if (importsToInject.length === 0) return;
491
- const imports = importsToInject.map(
492
- ({ variableName, importPath }) => ({
493
- type: "mdxjsEsm",
494
- data: {
495
- estree: {
496
- body: [
497
- {
498
- type: "ImportDeclaration",
499
- source: { type: "Literal", value: importPath },
500
- specifiers: [
501
- {
502
- type: "ImportDefaultSpecifier",
503
- local: { type: "Identifier", name: variableName }
504
- }
505
- ]
506
- }
507
- ]
508
- }
509
- }
510
- })
511
- );
512
- tree.children.unshift(...imports);
513
- };
514
- }
515
- function getImportPath(file, dir) {
516
- const relative2 = path.relative(dir, file).replaceAll(path.sep, "/");
517
- return relative2.startsWith("../") ? relative2 : `./${relative2}`;
518
- }
519
- function parseSrc(src, publicDir, dir) {
520
- if (src.startsWith("file:///"))
521
- return { type: "file", file: fileURLToPath(src) };
522
- if (EXTERNAL_URL_REGEX.test(src)) {
523
- return {
524
- type: "url",
525
- url: new URL(src)
526
- };
527
- }
528
- if (src.startsWith("/")) {
529
- if (EXTERNAL_URL_REGEX.test(publicDir)) {
530
- const url = new URL(publicDir);
531
- const segs = [...url.pathname.split("/"), ...src.split("/")].filter(
532
- (v) => v.length > 0
533
- );
534
- url.pathname = `/${segs.join("/")}`;
535
- return { type: "url", url };
536
- }
537
- return {
538
- type: "file",
539
- file: path.join(publicDir, src)
540
- };
541
- }
542
- if (!dir) {
543
- console.warn(
544
- `[Remark Image] found relative path ${src} but missing 'dirname' in VFile, this image will be skipped for now.`
545
- );
546
- return;
547
- }
548
- return {
549
- type: "file",
550
- file: path.join(dir, src)
551
- };
552
- }
553
- async function getImageSize(src) {
554
- if (src.type === "file") return imageSizeFromFile(src.file);
555
- const res = await fetch(src.url);
556
- if (!res.ok) {
557
- throw new Error(
558
- `[Remark Image] Failed to fetch ${src.url} (${res.status}): ${await res.text()}`
559
- );
560
- }
561
- return imageSize(new Uint8Array(await res.arrayBuffer()));
562
- }
563
-
564
- // src/mdx-plugins/remark-structure.ts
565
- import Slugger from "github-slugger";
566
- import { remark } from "remark";
567
- import remarkGfm from "remark-gfm";
568
- import { visit as visit2 } from "unist-util-visit";
569
- function remarkStructure({
570
- types = [
571
- "heading",
572
- "paragraph",
573
- "blockquote",
574
- "tableCell",
575
- "mdxJsxFlowElement"
576
- ],
577
- allowedMdxAttributes = (node) => {
578
- if (!node.name) return false;
579
- return ["TypeTable", "Callout"].includes(node.name);
580
- }
581
- } = {}) {
582
- const slugger = new Slugger();
583
- if (Array.isArray(allowedMdxAttributes)) {
584
- const arr = allowedMdxAttributes;
585
- allowedMdxAttributes = (_node, attribute) => attribute.type === "mdxJsxAttribute" && arr.includes(attribute.name);
586
- }
587
- if (Array.isArray(types)) {
588
- const arr = types;
589
- types = (node) => arr.includes(node.type);
590
- }
591
- return (node, file) => {
592
- slugger.reset();
593
- const data = { contents: [], headings: [] };
594
- let lastHeading;
595
- if (file.data.frontmatter) {
596
- const frontmatter = file.data.frontmatter;
597
- if (frontmatter._openapi?.structuredData) {
598
- data.headings.push(...frontmatter._openapi.structuredData.headings);
599
- data.contents.push(...frontmatter._openapi.structuredData.contents);
600
- }
601
- }
602
- visit2(node, (element) => {
603
- if (element.type === "root") return;
604
- if (!types(element)) return;
605
- if (element.type === "heading") {
606
- element.data ||= {};
607
- element.data.hProperties ||= {};
608
- const properties = element.data.hProperties;
609
- const content2 = flattenNode(element).trim();
610
- const id = properties.id ?? slugger.slug(content2);
611
- data.headings.push({
612
- id,
613
- content: content2
614
- });
615
- lastHeading = id;
616
- return "skip";
617
- }
618
- if (element.data?._string) {
619
- for (const content2 of element.data._string) {
620
- data.contents.push({
621
- heading: lastHeading,
622
- content: content2
623
- });
624
- }
625
- return "skip";
626
- }
627
- if (element.type === "mdxJsxFlowElement" && element.name) {
628
- data.contents.push(
629
- ...element.attributes.flatMap((attribute) => {
630
- const value = typeof attribute.value === "string" ? attribute.value : attribute.value?.value;
631
- if (!value || value.length === 0) return [];
632
- if (allowedMdxAttributes && !allowedMdxAttributes(element, attribute))
633
- return [];
634
- return {
635
- heading: lastHeading,
636
- content: attribute.type === "mdxJsxAttribute" ? `${attribute.name}: ${value}` : value
637
- };
638
- })
639
- );
640
- return;
641
- }
642
- const content = flattenNode(element).trim();
643
- if (content.length === 0) return;
644
- data.contents.push({
645
- heading: lastHeading,
646
- content
647
- });
648
- return "skip";
649
- });
650
- file.data.structuredData = data;
651
- };
652
- }
653
- function structure(content, remarkPlugins = [], options = {}) {
654
- const result = remark().use(remarkGfm).use(remarkPlugins).use(remarkStructure, options).processSync(content);
655
- return result.data.structuredData;
656
- }
657
-
658
- // src/mdx-plugins/remark-admonition.ts
659
- import { visit as visit3 } from "unist-util-visit";
660
- function remarkAdmonition(options = {}) {
661
- const tag = options.tag ?? ":::";
662
- const typeMap = options.typeMap ?? {
663
- info: "info",
664
- warn: "warn",
665
- note: "info",
666
- tip: "info",
667
- warning: "warn",
668
- danger: "error"
669
- };
670
- function replaceNodes(nodes) {
671
- if (nodes.length === 0) return;
672
- let open = -1;
673
- let attributes = [];
674
- let hasIntercept = false;
675
- for (let i = 0; i < nodes.length; i++) {
676
- if (nodes[i].type !== "paragraph") continue;
677
- const text = flattenNode(nodes[i]);
678
- const typeName = Object.keys(typeMap).find(
679
- (type) => text.startsWith(`${tag}${type}`)
680
- );
681
- if (typeName) {
682
- if (open !== -1) {
683
- hasIntercept = true;
684
- continue;
685
- }
686
- open = i;
687
- attributes.push({
688
- type: "mdxJsxAttribute",
689
- name: "type",
690
- value: typeMap[typeName]
691
- });
692
- const meta = text.slice(`${tag}${typeName}`.length);
693
- if (meta.startsWith("[") && meta.endsWith("]")) {
694
- attributes.push({
695
- type: "mdxJsxAttribute",
696
- name: "title",
697
- value: meta.slice(1, -1)
698
- });
699
- }
700
- }
701
- if (open !== -1 && text === tag) {
702
- const children = nodes.slice(open + 1, i);
703
- nodes.splice(open, i - open + 1, {
704
- type: "mdxJsxFlowElement",
705
- name: "Callout",
706
- attributes,
707
- children: hasIntercept ? replaceNodes(children) : children
708
- });
709
- open = -1;
710
- hasIntercept = false;
711
- attributes = [];
712
- i = open;
713
- }
714
- }
715
- }
716
- return (tree) => {
717
- visit3(tree, (node) => {
718
- if (!("children" in node)) return;
719
- replaceNodes(node.children);
720
- });
721
- };
722
- }
723
-
724
- // src/mdx-plugins/rehype-toc.ts
725
- import { toEstree } from "hast-util-to-estree";
726
-
727
- // src/mdx-plugins/hast-utils.ts
728
- function visit4(node, tagNames, handler) {
729
- if (node.type === "element" && tagNames.includes(node.tagName)) {
730
- const result = handler(node);
731
- if (result === "skip") return;
732
- }
733
- if ("children" in node)
734
- node.children.forEach((n) => {
735
- visit4(n, tagNames, handler);
736
- });
737
- }
738
-
739
- // src/mdx-plugins/rehype-toc.ts
740
- var TocOnlyTag = "[toc]";
741
- var NoTocTag = "[!toc]";
742
- function rehypeToc({ exportToc = true } = {}) {
743
- return (tree) => {
744
- const output = [];
745
- visit4(tree, ["h1", "h2", "h3", "h4", "h5", "h6"], (element) => {
746
- const id = element.properties.id;
747
- if (typeof id !== "string") return "skip";
748
- let isTocOnly = false;
749
- const last = element.children.at(-1);
750
- if (last?.type === "text" && last.value.endsWith(TocOnlyTag)) {
751
- isTocOnly = true;
752
- last.value = last.value.substring(0, last.value.length - TocOnlyTag.length).trimEnd();
753
- } else if (last?.type === "text" && last.value.endsWith(NoTocTag)) {
754
- last.value = last.value.substring(0, last.value.length - NoTocTag.length).trimEnd();
755
- return "skip";
756
- }
757
- const estree = toEstree(element, {
758
- elementAttributeNameCase: "react",
759
- stylePropertyNameCase: "dom"
760
- });
761
- if (estree.body[0].type === "ExpressionStatement")
762
- output.push({
763
- title: estree.body[0].expression,
764
- depth: Number(element.tagName.slice(1)),
765
- url: `#${id}`
766
- });
767
- if (isTocOnly) {
768
- Object.assign(element, {
769
- type: "comment",
770
- value: ""
771
- });
772
- }
773
- return "skip";
774
- });
775
- const declaration = {
776
- type: "VariableDeclaration",
777
- kind: "const",
778
- declarations: [
779
- {
780
- type: "VariableDeclarator",
781
- id: {
782
- type: "Identifier",
783
- name: "toc"
784
- },
785
- init: {
786
- type: "ArrayExpression",
787
- elements: output.map((item) => ({
788
- type: "ObjectExpression",
789
- properties: [
790
- {
791
- type: "Property",
792
- method: false,
793
- shorthand: false,
794
- computed: false,
795
- key: {
796
- type: "Identifier",
797
- name: "depth"
798
- },
799
- value: {
800
- type: "Literal",
801
- value: item.depth
802
- },
803
- kind: "init"
804
- },
805
- {
806
- type: "Property",
807
- method: false,
808
- shorthand: false,
809
- computed: false,
810
- key: {
811
- type: "Identifier",
812
- name: "url"
813
- },
814
- value: {
815
- type: "Literal",
816
- value: item.url
817
- },
818
- kind: "init"
819
- },
820
- {
821
- type: "Property",
822
- method: false,
823
- shorthand: false,
824
- computed: false,
825
- key: {
826
- type: "Identifier",
827
- name: "title"
828
- },
829
- value: {
830
- type: "JSXFragment",
831
- openingFragment: { type: "JSXOpeningFragment" },
832
- closingFragment: { type: "JSXClosingFragment" },
833
- children: item.title.children
834
- },
835
- kind: "init"
836
- }
837
- ]
838
- }))
839
- }
840
- }
841
- ]
842
- };
843
- tree.children.push({
844
- type: "mdxjsEsm",
845
- value: "",
846
- data: {
847
- estree: {
848
- type: "Program",
849
- body: [
850
- exportToc ? {
851
- type: "ExportNamedDeclaration",
852
- declaration,
853
- attributes: [],
854
- specifiers: []
855
- } : declaration
856
- ],
857
- sourceType: "module",
858
- comments: []
859
- }
860
- }
861
- });
862
- };
863
- }
864
-
865
- // src/mdx-plugins/remark-code-tab.ts
866
- import { visit as visit5 } from "unist-util-visit";
867
- var Tabs = {
868
- convert(processor, nodes, withMdx = false, withParent = true) {
869
- const tabs = Array.from(processTabValue(nodes).entries());
870
- if (!withMdx) {
871
- const children2 = tabs.map(([name, codes]) => {
872
- return {
873
- type: "mdxJsxFlowElement",
874
- name: "Tab",
875
- attributes: [
876
- {
877
- type: "mdxJsxAttribute",
878
- name: "value",
879
- value: name
880
- }
881
- ],
882
- children: codes
883
- };
884
- });
885
- if (!withParent) return createFragment(children2);
886
- return {
887
- type: "mdxJsxFlowElement",
888
- name: "Tabs",
889
- attributes: [
890
- {
891
- type: "mdxJsxAttribute",
892
- name: "items",
893
- value: {
894
- type: "mdxJsxAttributeValueExpression",
895
- value: tabs.map(([name]) => name).join(", "),
896
- data: {
897
- estree: {
898
- type: "Program",
899
- sourceType: "module",
900
- comments: [],
901
- body: [
902
- {
903
- type: "ExpressionStatement",
904
- expression: {
905
- type: "ArrayExpression",
906
- elements: tabs.map(([name]) => ({
907
- type: "Literal",
908
- value: name
909
- }))
910
- }
911
- }
912
- ]
913
- }
914
- }
915
- }
916
- }
917
- ],
918
- children: children2
919
- };
920
- }
921
- const children = [
922
- {
923
- type: "mdxJsxFlowElement",
924
- name: "TabsList",
925
- attributes: [],
926
- children: tabs.map(([name]) => ({
927
- type: "mdxJsxFlowElement",
928
- name: "TabsTrigger",
929
- attributes: [
930
- {
931
- type: "mdxJsxAttribute",
932
- name: "value",
933
- value: name
934
- }
935
- ],
936
- children: [mdxToAst(processor, name)]
937
- }))
938
- },
939
- ...tabs.map(
940
- ([name, codes]) => ({
941
- type: "mdxJsxFlowElement",
942
- name: "TabsContent",
943
- attributes: [
944
- {
945
- type: "mdxJsxAttribute",
946
- name: "value",
947
- value: name
948
- }
949
- ],
950
- children: codes
951
- })
952
- )
953
- ];
954
- if (!withParent) return createFragment(children);
955
- return {
956
- type: "mdxJsxFlowElement",
957
- name: "Tabs",
958
- attributes: [
959
- {
960
- type: "mdxJsxAttribute",
961
- name: "defaultValue",
962
- value: tabs[0][0]
963
- }
964
- ],
965
- children
966
- };
967
- }
968
- };
969
- var CodeBlockTabs = {
970
- convert(processor, nodes, withMdx = false, withParent = true) {
971
- const tabs = Array.from(processTabValue(nodes).entries());
972
- const node = generateCodeBlockTabs({
973
- defaultValue: tabs[0][0],
974
- triggers: tabs.map(([name]) => ({
975
- value: name,
976
- children: [
977
- withMdx ? mdxToAst(processor, name) : {
978
- type: "text",
979
- value: name
980
- }
981
- ]
982
- })),
983
- tabs: tabs.map(([name, codes]) => ({
984
- value: name,
985
- children: codes
986
- }))
987
- });
988
- if (!withParent) return createFragment(node.children);
989
- return node;
990
- }
991
- };
992
- var Types = {
993
- CodeBlockTabs,
994
- Tabs
995
- };
996
- function remarkCodeTab(options = {}) {
997
- const { parseMdx = false, Tabs: Tabs2 = "CodeBlockTabs" } = options;
998
- return (tree) => {
999
- const ignored = /* @__PURE__ */ new WeakSet();
1000
- visit5(tree, (node) => {
1001
- if (!("children" in node) || ignored.has(node)) return "skip";
1002
- let localTabs = Tabs2;
1003
- let localParseMdx = parseMdx;
1004
- let withParent = true;
1005
- if (node.type === "mdxJsxFlowElement" && node.name && node.name in Types) {
1006
- withParent = false;
1007
- localTabs = node.name;
1008
- if (node.name === "Tabs" && localParseMdx) {
1009
- localParseMdx = node.attributes.every(
1010
- (attribute) => attribute.type !== "mdxJsxAttribute" || attribute.name !== "items"
1011
- );
1012
- }
1013
- }
1014
- let start = -1;
1015
- let end = 0;
1016
- const close = () => {
1017
- if (start === -1 || start === end) return;
1018
- const replacement = Types[localTabs].convert(
1019
- this,
1020
- node.children.slice(start, end),
1021
- localParseMdx,
1022
- withParent
1023
- );
1024
- ignored.add(replacement);
1025
- node.children.splice(start, end - start, replacement);
1026
- end = start;
1027
- start = -1;
1028
- };
1029
- for (; end < node.children.length; end++) {
1030
- const child = node.children[end];
1031
- if (child.type !== "code" || !child.meta) {
1032
- close();
1033
- continue;
1034
- }
1035
- const meta = parseCodeBlockAttributes(child.meta, ["tab"]);
1036
- if (!meta.attributes.tab) {
1037
- close();
1038
- continue;
1039
- }
1040
- if (start === -1) start = end;
1041
- child.meta = meta.rest;
1042
- child.data ??= {};
1043
- child.data.tab = meta.attributes.tab;
1044
- }
1045
- close();
1046
- });
1047
- };
1048
- }
1049
- function processTabValue(nodes) {
1050
- const out = /* @__PURE__ */ new Map();
1051
- for (let i = 0; i < nodes.length; i++) {
1052
- const node = nodes[i];
1053
- const name = node.data?.tab ?? `Tab ${i + 1}`;
1054
- const li = out.get(name) ?? [];
1055
- li.push(node);
1056
- out.set(name, li);
1057
- }
1058
- return out;
1059
- }
1060
- function mdxToAst(processor, name) {
1061
- const node = processor.parse(name);
1062
- if (node.type === "root") {
1063
- node.children = node.children.flatMap((child) => {
1064
- if (child.type === "paragraph") return child.children;
1065
- return child;
1066
- });
1067
- }
1068
- return node;
1069
- }
1070
- function createFragment(children) {
1071
- return {
1072
- type: "mdxJsxFlowElement",
1073
- name: null,
1074
- attributes: [],
1075
- children
1076
- };
1077
- }
1078
-
1079
- // src/mdx-plugins/remark-steps.ts
1080
- import { visit as visit6 } from "unist-util-visit";
1081
- var StepRegex = /^(\d+)\.\s(.+)$/;
1082
- function remarkSteps({
1083
- steps = "fd-steps",
1084
- step = "fd-step"
1085
- } = {}) {
1086
- function convertToSteps(nodes) {
1087
- const depth = nodes[0].depth;
1088
- const children = [];
1089
- for (const node of nodes) {
1090
- if (node.type === "heading" && node.depth === depth) {
1091
- children.push({
1092
- type: "mdxJsxFlowElement",
1093
- name: "div",
1094
- attributes: [
1095
- {
1096
- type: "mdxJsxAttribute",
1097
- name: "className",
1098
- value: step
1099
- }
1100
- ],
1101
- children: [node]
1102
- });
1103
- } else {
1104
- children[children.length - 1].children.push(node);
1105
- }
1106
- }
1107
- return {
1108
- type: "mdxJsxFlowElement",
1109
- name: "div",
1110
- attributes: [
1111
- {
1112
- type: "mdxJsxAttribute",
1113
- name: "className",
1114
- value: steps
1115
- }
1116
- ],
1117
- data: {
1118
- _fd_step: true
1119
- },
1120
- children
1121
- };
1122
- }
1123
- return (tree) => {
1124
- visit6(tree, (parent) => {
1125
- if (!("children" in parent) || parent.type === "heading") return;
1126
- if (parent.data && "_fd_step" in parent.data) return "skip";
1127
- let startIdx = -1;
1128
- let i = 0;
1129
- const onEnd = () => {
1130
- if (startIdx === -1) return;
1131
- const item = {};
1132
- const nodes = parent.children.splice(
1133
- startIdx,
1134
- i - startIdx,
1135
- item
1136
- );
1137
- Object.assign(item, convertToSteps(nodes));
1138
- i = startIdx + 1;
1139
- startIdx = -1;
1140
- };
1141
- for (; i < parent.children.length; i++) {
1142
- const node = parent.children[i];
1143
- if (node.type !== "heading") continue;
1144
- if (startIdx !== -1) {
1145
- const startDepth = parent.children[startIdx].depth;
1146
- if (node.depth > startDepth) continue;
1147
- else if (node.depth < startDepth) onEnd();
1148
- }
1149
- const head = node.children.filter((c) => c.type === "text").at(0);
1150
- if (!head) {
1151
- onEnd();
1152
- continue;
1153
- }
1154
- const match = StepRegex.exec(head.value);
1155
- if (!match) {
1156
- onEnd();
1157
- continue;
1158
- }
1159
- head.value = match[2];
1160
- if (startIdx === -1) startIdx = i;
1161
- }
1162
- onEnd();
1163
- });
1164
- };
1165
- }
1166
-
1167
- // src/mdx-plugins/remark-npm.ts
1168
- import { visit as visit7 } from "unist-util-visit";
1169
- import convert from "npm-to-yarn";
1170
- var aliases = ["npm", "package-install"];
1171
- function remarkNpm({
1172
- persist = false,
1173
- packageManagers = [
1174
- { command: (cmd) => convert(cmd, "npm"), name: "npm" },
1175
- { command: (cmd) => convert(cmd, "pnpm"), name: "pnpm" },
1176
- { command: (cmd) => convert(cmd, "yarn"), name: "yarn" },
1177
- { command: (cmd) => convert(cmd, "bun"), name: "bun" }
1178
- ]
1179
- } = {}) {
1180
- return (tree) => {
1181
- visit7(tree, "code", (node) => {
1182
- if (!node.lang || !aliases.includes(node.lang)) return;
1183
- let code = node.value;
1184
- if (node.lang === "package-install" && !code.startsWith("npm") && !code.startsWith("npx")) {
1185
- code = `npm install ${code}`;
1186
- }
1187
- const options = {
1188
- persist,
1189
- tabs: [],
1190
- triggers: []
1191
- };
1192
- for (const manager of packageManagers) {
1193
- const value = manager.value ?? manager.name;
1194
- const command = manager.command(code);
1195
- if (!command || command.length === 0) continue;
1196
- options.defaultValue ??= value;
1197
- options.triggers.push({
1198
- value,
1199
- children: [{ type: "text", value: manager.name }]
1200
- });
1201
- options.tabs.push({
1202
- value,
1203
- children: [
1204
- {
1205
- type: "code",
1206
- lang: "bash",
1207
- meta: node.meta,
1208
- value: command
1209
- }
1210
- ]
1211
- });
1212
- }
1213
- Object.assign(node, generateCodeBlockTabs(options));
1214
- return "skip";
1215
- });
1216
- };
1217
- }
1218
-
1219
- // src/mdx-plugins/remark-mdx-files.ts
1220
- import { visit as visit8 } from "unist-util-visit";
1221
- function parseFileTree(code) {
1222
- const lines = code.split(/\r?\n/);
1223
- const stack = /* @__PURE__ */ new Map();
1224
- for (const line of lines) {
1225
- let depth = 0;
1226
- let name = line;
1227
- let match;
1228
- while (match = /(?:├──|│|└──)\s*/.exec(name)) {
1229
- name = name.slice(match[0].length);
1230
- depth++;
1231
- }
1232
- if (!name) continue;
1233
- const node = name.endsWith("/") ? { type: "folder", name, children: [], depth } : { type: "file", name, depth };
1234
- let parent;
1235
- for (let i = depth - 1; i >= 0 && !parent; i--) {
1236
- parent = stack.get(i);
1237
- }
1238
- stack.set(depth, node);
1239
- if (!parent) continue;
1240
- if (parent.type === "file") {
1241
- Object.assign(parent, {
1242
- type: "folder",
1243
- children: []
1244
- });
1245
- }
1246
- parent.children.push(node);
1247
- }
1248
- return stack.get(0);
1249
- }
1250
- function defaultToMDX(node, depth = 0) {
1251
- if (depth === 0) {
1252
- return {
1253
- type: "mdxJsxFlowElement",
1254
- name: "Files",
1255
- attributes: [],
1256
- children: [defaultToMDX(node, depth + 1)]
1257
- };
1258
- }
1259
- const attributes = [
1260
- { type: "mdxJsxAttribute", name: "name", value: node.name }
1261
- ];
1262
- if (node.type === "file") {
1263
- return {
1264
- type: "mdxJsxFlowElement",
1265
- attributes,
1266
- children: [],
1267
- name: "File"
1268
- };
1269
- }
1270
- attributes.push({
1271
- type: "mdxJsxAttribute",
1272
- name: "defaultOpen",
1273
- value: null
1274
- });
1275
- return {
1276
- type: "mdxJsxFlowElement",
1277
- attributes,
1278
- name: "Folder",
1279
- children: node.children.map((item) => defaultToMDX(item, depth + 1))
1280
- };
1281
- }
1282
- function remarkMdxFiles(options = {}) {
1283
- const { lang = "files", toMdx = defaultToMDX } = options;
1284
- return (tree) => {
1285
- visit8(tree, "code", (node) => {
1286
- if (node.lang !== lang || !node.value) return;
1287
- const fileTree = parseFileTree(node.value);
1288
- if (!fileTree) return;
1289
- Object.assign(node, toMdx(fileTree));
1290
- });
1291
- };
1292
- }
1293
-
1294
- // src/mdx-plugins/remark-mdx-mermaid.ts
1295
- import { visit as visit9 } from "unist-util-visit";
1296
- function toMDX(code) {
1297
- return {
1298
- type: "mdxJsxFlowElement",
1299
- name: "Mermaid",
1300
- attributes: [
1301
- {
1302
- type: "mdxJsxAttribute",
1303
- name: "chart",
1304
- value: code.trim()
1305
- }
1306
- ],
1307
- children: []
1308
- };
1309
- }
1310
- function remarkMdxMermaid(options = {}) {
1311
- const { lang = "mermaid" } = options;
1312
- return (tree) => {
1313
- visit9(tree, "code", (node) => {
1314
- if (node.lang !== lang || !node.value) return;
1315
- Object.assign(node, toMDX(node.value));
1316
- });
1317
- };
1318
- }
14
+ remarkSteps
15
+ } from "../chunk-XJ6ZQNEX.js";
16
+ import {
17
+ remarkStructure,
18
+ structure
19
+ } from "../chunk-SLIKY7GW.js";
20
+ import {
21
+ rehypeCode,
22
+ rehypeCodeDefaultOptions,
23
+ transformerIcon,
24
+ transformerTab
25
+ } from "../chunk-X2HFD5QJ.js";
26
+ import {
27
+ rehypeToc
28
+ } from "../chunk-EFVXL2PP.js";
29
+ import {
30
+ remarkAdmonition
31
+ } from "../chunk-JOXPHQ2R.js";
32
+ import {
33
+ remarkCodeTab
34
+ } from "../chunk-CH7YHH7V.js";
35
+ import {
36
+ generateCodeBlockTabs,
37
+ parseCodeBlockAttributes
38
+ } from "../chunk-TWIDBWFG.js";
39
+ import {
40
+ default as default2
41
+ } from "../chunk-ONG4RVCR.js";
42
+ import "../chunk-XN2LKXFZ.js";
43
+ import {
44
+ remarkHeading
45
+ } from "../chunk-HNZEUF6C.js";
46
+ import "../chunk-A4G5V4FQ.js";
47
+ import "../chunk-U67V476Y.js";
1319
48
  export {
1320
49
  generateCodeBlockTabs,
1321
50
  parseCodeBlockAttributes,