ardo 2.0.1 → 2.1.1

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 (34) hide show
  1. package/dist/{Features-C_06EvGb.d.ts → Features-DEndhnwl.d.ts} +10 -4
  2. package/dist/{chunk-OTUACKCQ.js → chunk-4IRLOOXV.js} +20 -9
  3. package/dist/chunk-4IRLOOXV.js.map +1 -0
  4. package/dist/{chunk-ZXPAEM3M.js → chunk-6U5CYV74.js} +127 -83
  5. package/dist/chunk-6U5CYV74.js.map +1 -0
  6. package/dist/{chunk-N5CEHG2F.js → chunk-CGFRUWNJ.js} +2 -1
  7. package/dist/chunk-CGFRUWNJ.js.map +1 -0
  8. package/dist/{chunk-UWAVET45.js → chunk-LSNTX2BA.js} +8 -6
  9. package/dist/chunk-LSNTX2BA.js.map +1 -0
  10. package/dist/{chunk-G5L4ZUTS.js → chunk-O64PX2AK.js} +2 -2
  11. package/dist/{chunk-LUOUBO3L.js → chunk-SWER4H2H.js} +540 -394
  12. package/dist/chunk-SWER4H2H.js.map +1 -0
  13. package/dist/config/index.d.ts +2 -2
  14. package/dist/config/index.js +1 -1
  15. package/dist/index.d.ts +2 -2
  16. package/dist/index.js +6 -6
  17. package/dist/mdx/provider.js +14 -6
  18. package/dist/mdx/provider.js.map +1 -1
  19. package/dist/runtime/index.d.ts +1 -1
  20. package/dist/typedoc/index.d.ts +6 -0
  21. package/dist/typedoc/index.js +2 -2
  22. package/dist/{types-DchPWkJl.d.ts → types-tjxB5eh7.d.ts} +22 -2
  23. package/dist/ui/index.d.ts +2 -2
  24. package/dist/ui/index.js +2 -2
  25. package/dist/ui/styles.css +332 -109
  26. package/dist/vite/index.d.ts +1 -1
  27. package/dist/vite/index.js +3 -3
  28. package/package.json +9 -9
  29. package/dist/chunk-LUOUBO3L.js.map +0 -1
  30. package/dist/chunk-N5CEHG2F.js.map +0 -1
  31. package/dist/chunk-OTUACKCQ.js.map +0 -1
  32. package/dist/chunk-UWAVET45.js.map +0 -1
  33. package/dist/chunk-ZXPAEM3M.js.map +0 -1
  34. /package/dist/{chunk-G5L4ZUTS.js.map → chunk-O64PX2AK.js.map} +0 -0
@@ -1,5 +1,5 @@
1
1
  import { Plugin } from 'vite';
2
- import { b as PressConfig, P as PageData, R as ResolvedConfig, a as PageFrontmatter, T as TOCItem, S as SidebarItem, M as MarkdownConfig } from '../types-DchPWkJl.js';
2
+ import { b as PressConfig, P as PageData, R as ResolvedConfig, a as PageFrontmatter, T as TOCItem, S as SidebarItem, M as MarkdownConfig } from '../types-tjxB5eh7.js';
3
3
  import { Highlighter } from 'shiki';
4
4
 
5
5
  interface ArdoRoutesPluginOptions {
@@ -9,9 +9,9 @@ import {
9
9
  loadDoc,
10
10
  transformMarkdown,
11
11
  transformMarkdownToReact
12
- } from "../chunk-LUOUBO3L.js";
13
- import "../chunk-N5CEHG2F.js";
14
- import "../chunk-OTUACKCQ.js";
12
+ } from "../chunk-SWER4H2H.js";
13
+ import "../chunk-CGFRUWNJ.js";
14
+ import "../chunk-4IRLOOXV.js";
15
15
  export {
16
16
  ardoPlugin as ardo,
17
17
  ardoPlugin,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ardo",
3
- "version": "2.0.1",
3
+ "version": "2.1.1",
4
4
  "description": "React-first Static Documentation Framework",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -46,10 +46,10 @@
46
46
  "dist"
47
47
  ],
48
48
  "dependencies": {
49
- "@mdx-js/rollup": "^3.1.0",
50
- "@react-router/dev": "^7.1.0",
51
- "@shikijs/rehype": "^3.21.0",
52
- "@vitejs/plugin-react": "^5.1.2",
49
+ "@mdx-js/rollup": "^3.1.1",
50
+ "@react-router/dev": "^7.13.0",
51
+ "@shikijs/rehype": "^3.22.0",
52
+ "@vitejs/plugin-react": "^5.1.3",
53
53
  "gray-matter": "^4.0.3",
54
54
  "hast-util-to-jsx-runtime": "^2.3.6",
55
55
  "lucide-react": "^0.563.0",
@@ -57,16 +57,16 @@
57
57
  "minisearch": "^7.2.0",
58
58
  "react": "^19.2.4",
59
59
  "react-dom": "^19.2.4",
60
- "react-router": "^7.1.0",
60
+ "react-router": "^7.13.0",
61
61
  "rehype-parse": "^9.0.1",
62
62
  "rehype-stringify": "^10.0.1",
63
63
  "remark-directive": "^4.0.0",
64
64
  "remark-frontmatter": "^5.0.0",
65
65
  "remark-gfm": "^4.0.1",
66
- "remark-mdx-frontmatter": "^4.0.0",
66
+ "remark-mdx-frontmatter": "^5.2.0",
67
67
  "remark-parse": "^11.0.0",
68
68
  "remark-rehype": "^11.1.2",
69
- "shiki": "^3.21.0",
69
+ "shiki": "^3.22.0",
70
70
  "tailwindcss": "^4.1.18",
71
71
  "typedoc": "^0.28.16",
72
72
  "unified": "^11.0.5",
@@ -79,7 +79,7 @@
79
79
  "@types/hast": "^3.0.4",
80
80
  "@types/mdast": "^4.0.4",
81
81
  "@types/mdx": "^2.0.13",
82
- "@types/react": "^19.2.10",
82
+ "@types/react": "^19.2.13",
83
83
  "@types/react-dom": "^19.2.3",
84
84
  "tsup": "^8.5.1",
85
85
  "typescript": "^5.9.3",
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/vite/plugin.ts","../src/vite/routes-plugin.ts","../src/runtime/loader.ts","../src/markdown/pipeline.ts","../src/markdown/containers.ts","../src/markdown/toc.ts","../src/markdown/shiki.ts","../src/markdown/links.ts","../src/runtime/sidebar.ts"],"sourcesContent":["import type { Plugin, UserConfig } from \"vite\"\nimport type { PressConfig, ResolvedConfig } from \"../config/types\"\nimport type { TypeDocConfig } from \"../typedoc/types\"\nimport { resolveConfig } from \"../config/index\"\nimport { generateApiDocs } from \"../typedoc/generator\"\nimport { reactRouter } from \"@react-router/dev/vite\"\nimport mdx from \"@mdx-js/rollup\"\nimport remarkFrontmatter from \"remark-frontmatter\"\nimport remarkMdxFrontmatter from \"remark-mdx-frontmatter\"\nimport remarkGfm from \"remark-gfm\"\nimport remarkDirective from \"remark-directive\"\nimport rehypeShiki from \"@shikijs/rehype\"\nimport fs from \"fs/promises\"\nimport fsSync from \"fs\"\nimport path from \"path\"\nimport { execSync } from \"child_process\"\nimport { ardoRoutesPlugin, type ArdoRoutesPluginOptions } from \"./routes-plugin\"\n\n/**\n * Finds the package root by looking for package.json in parent directories.\n * Returns the path relative to cwd, or undefined if not found.\n */\nfunction findPackageRoot(cwd: string): string | undefined {\n let dir = path.resolve(cwd)\n const root = path.parse(dir).root\n\n while (dir !== root) {\n const parentDir = path.dirname(dir)\n const packageJsonPath = path.join(parentDir, \"package.json\")\n\n if (fsSync.existsSync(packageJsonPath)) {\n // Return relative path from cwd to parent\n return path.relative(cwd, parentDir) || \".\"\n }\n\n dir = parentDir\n }\n\n return undefined\n}\n\n/**\n * Detects the GitHub repository name from git remote URL.\n * Returns the repo name (e.g., 'ardo' from 'github.com/sebastian-software/ardo')\n * or undefined if not a GitHub repo.\n */\nfunction detectGitHubRepoName(cwd: string): string | undefined {\n try {\n const remoteUrl = execSync(\"git remote get-url origin\", {\n cwd,\n encoding: \"utf-8\",\n stdio: [\"pipe\", \"pipe\", \"pipe\"],\n }).trim()\n\n // Parse GitHub URL (supports both HTTPS and SSH)\n // https://github.com/user/repo.git\n // git@github.com:user/repo.git\n const match = remoteUrl.match(/github\\.com[/:][\\w-]+\\/([\\w.-]+?)(?:\\.git)?$/)\n return match?.[1]\n } catch {\n return undefined\n }\n}\n\nconst VIRTUAL_MODULE_ID = \"virtual:ardo/config\"\nconst RESOLVED_VIRTUAL_MODULE_ID = \"\\0\" + VIRTUAL_MODULE_ID\n\nconst VIRTUAL_SIDEBAR_ID = \"virtual:ardo/sidebar\"\nconst RESOLVED_VIRTUAL_SIDEBAR_ID = \"\\0\" + VIRTUAL_SIDEBAR_ID\n\nconst VIRTUAL_SEARCH_ID = \"virtual:ardo/search-index\"\nconst RESOLVED_VIRTUAL_SEARCH_ID = \"\\0\" + VIRTUAL_SEARCH_ID\n\n// Module-level flag to prevent duplicate TypeDoc generation across plugin instances\n// This is necessary because React Router creates multiple Vite instances\nlet typedocGenerated = false\n\nexport interface ArdoPluginOptions extends Partial<PressConfig> {\n /** Options for the routes generator plugin */\n routes?: ArdoRoutesPluginOptions | false\n /**\n * Auto-detect GitHub repository and set base path for GitHub Pages.\n * When true, automatically sets `base: '/repo-name/'` if deploying to GitHub Pages.\n * @default true\n */\n githubPages?: boolean\n /**\n * Directory where routes are located.\n * @default \"./app/routes\"\n */\n routesDir?: string\n}\n\nexport function ardoPlugin(options: ArdoPluginOptions = {}): Plugin[] {\n let resolvedConfig: ResolvedConfig\n let routesDir: string\n\n // Extract ardo-specific options from the rest (which is PressConfig)\n const {\n routes,\n typedoc,\n githubPages = true,\n routesDir: routesDirOption,\n ...pressConfig\n } = options\n\n const mainPlugin: Plugin = {\n name: \"ardo\",\n enforce: \"pre\",\n\n config(userConfig, env): UserConfig {\n const root = userConfig.root || process.cwd()\n routesDir = routesDirOption || path.join(root, \"app\", \"routes\")\n\n const result: UserConfig = {\n optimizeDeps: {\n exclude: [\"ardo/ui/styles.css\"],\n },\n ssr: {\n noExternal: [\"ardo\"],\n },\n }\n\n // Auto-detect GitHub Pages base path for production builds\n if (githubPages && env.command === \"build\" && !userConfig.base) {\n const repoName = detectGitHubRepoName(root)\n if (repoName) {\n result.base = `/${repoName}/`\n console.log(`[ardo] GitHub Pages detected, using base: ${result.base}`)\n }\n }\n\n return result\n },\n\n async configResolved(config) {\n const root = config.root\n routesDir = routesDirOption || path.join(root, \"app\", \"routes\")\n\n const defaultConfig: PressConfig = {\n title: pressConfig.title ?? \"Ardo\",\n description: pressConfig.description ?? \"Documentation powered by Ardo\",\n }\n\n // For React Router, contentDir is the routes directory\n const configWithRoutes = {\n ...defaultConfig,\n ...pressConfig,\n srcDir: routesDir,\n }\n\n resolvedConfig = resolveConfig(configWithRoutes, root)\n },\n\n resolveId(id) {\n if (id === VIRTUAL_MODULE_ID) {\n return RESOLVED_VIRTUAL_MODULE_ID\n }\n if (id === VIRTUAL_SIDEBAR_ID) {\n return RESOLVED_VIRTUAL_SIDEBAR_ID\n }\n if (id === VIRTUAL_SEARCH_ID) {\n return RESOLVED_VIRTUAL_SEARCH_ID\n }\n },\n\n async load(id) {\n if (id === RESOLVED_VIRTUAL_MODULE_ID) {\n const clientConfig = {\n title: resolvedConfig.title,\n description: resolvedConfig.description,\n base: resolvedConfig.base,\n lang: resolvedConfig.lang,\n themeConfig: resolvedConfig.themeConfig,\n }\n return `export default ${JSON.stringify(clientConfig)}`\n }\n\n if (id === RESOLVED_VIRTUAL_SIDEBAR_ID) {\n const sidebar = await generateSidebar(resolvedConfig, routesDir)\n return `export default ${JSON.stringify(sidebar)}`\n }\n\n if (id === RESOLVED_VIRTUAL_SEARCH_ID) {\n const searchIndex = await generateSearchIndex(routesDir)\n return `export default ${JSON.stringify(searchIndex)}`\n }\n },\n }\n\n const plugins: Plugin[] = [mainPlugin]\n\n // Add routes plugin unless explicitly disabled\n if (routes !== false) {\n plugins.push(\n ardoRoutesPlugin({\n routesDir: routesDirOption,\n ...routes,\n })\n )\n }\n\n // Add TypeDoc plugin if enabled\n if (typedoc) {\n // Find package root to use as default entry point and tsconfig base\n const packageRoot = findPackageRoot(process.cwd())\n const defaultEntryPoint = packageRoot ? `${packageRoot}/src/index.ts` : \"./src/index.ts\"\n const defaultTsconfig = packageRoot ? `${packageRoot}/tsconfig.json` : \"./tsconfig.json\"\n\n const defaultTypedocConfig: TypeDocConfig = {\n enabled: true,\n entryPoints: [defaultEntryPoint],\n tsconfig: defaultTsconfig,\n out: \"api-reference\",\n excludePrivate: true,\n excludeInternal: true,\n }\n\n const typedocConfig: TypeDocConfig =\n typedoc === true ? defaultTypedocConfig : { ...defaultTypedocConfig, ...typedoc }\n\n const typedocPlugin: Plugin = {\n name: \"ardo:typedoc\",\n\n async buildStart() {\n // Use module-level flag to prevent duplicate generation across plugin instances\n if (typedocGenerated || !typedocConfig.enabled) {\n return\n }\n\n console.log(\"[ardo] Generating API documentation with TypeDoc...\")\n const startTime = Date.now()\n try {\n const outputDir = routesDirOption || \"./app/routes\"\n const docs = await generateApiDocs(typedocConfig, outputDir)\n const duration = Date.now() - startTime\n console.log(`[ardo] Generated ${docs.length} API documentation pages in ${duration}ms`)\n } catch (error) {\n console.warn(\"[ardo] TypeDoc generation failed. API documentation will not be available.\")\n console.warn(\"[ardo] Check your typedoc.entryPoints configuration.\")\n if (error instanceof Error) {\n console.warn(`[ardo] Error: ${error.message}`)\n }\n }\n typedocGenerated = true\n },\n }\n\n plugins.unshift(typedocPlugin)\n }\n\n // Add MDX plugin with Ardo's markdown pipeline\n const themeConfig = pressConfig.markdown?.theme\n const hasThemeObject = themeConfig && typeof themeConfig === \"object\" && \"light\" in themeConfig\n\n // Build shiki options - only include themes when using dual theme mode\n const shikiOptions = hasThemeObject\n ? {\n themes: {\n light: themeConfig.light || \"github-light\",\n dark: themeConfig.dark || \"github-dark\",\n },\n defaultColor: false as const,\n }\n : {\n theme: (themeConfig as string) || \"github-dark\",\n }\n\n const mdxPlugin = mdx({\n include: /\\.(md|mdx)$/,\n remarkPlugins: [\n remarkFrontmatter,\n [remarkMdxFrontmatter, { name: \"frontmatter\" }],\n remarkGfm,\n remarkDirective,\n ],\n rehypePlugins: [[rehypeShiki, shikiOptions]],\n providerImportSource: \"ardo/mdx-provider\",\n })\n plugins.push(mdxPlugin as Plugin)\n\n // Add React Router Framework plugin (includes React plugin internally)\n const reactRouterPlugin = reactRouter()\n const reactRouterPlugins = (\n Array.isArray(reactRouterPlugin) ? reactRouterPlugin : [reactRouterPlugin]\n ).filter((p): p is Plugin => p != null)\n plugins.push(...reactRouterPlugins)\n\n return plugins\n}\n\nasync function generateSidebar(config: ResolvedConfig, routesDir: string) {\n const { themeConfig } = config\n\n if (themeConfig.sidebar && !Array.isArray(themeConfig.sidebar)) {\n return themeConfig.sidebar\n }\n\n if (themeConfig.sidebar && Array.isArray(themeConfig.sidebar) && themeConfig.sidebar.length > 0) {\n return themeConfig.sidebar\n }\n\n try {\n const sidebar = await scanDirectory(routesDir, routesDir, config.base)\n return sidebar\n } catch {\n return []\n }\n}\n\nasync function scanDirectory(\n dir: string,\n rootDir: string,\n _basePath: string\n): Promise<Array<{ text: string; link?: string; items?: unknown[] }>> {\n const entries = await fs.readdir(dir, { withFileTypes: true })\n const items: Array<{ text: string; link?: string; items?: unknown[]; order?: number }> = []\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name)\n const relativePath = path.relative(rootDir, fullPath)\n\n if (entry.isDirectory()) {\n const children = await scanDirectory(fullPath, rootDir, _basePath)\n if (children.length > 0) {\n // Check for index.mdx in the directory\n const indexPath = path.join(fullPath, \"index.mdx\")\n let link: string | undefined\n\n try {\n await fs.access(indexPath)\n link = \"/\" + relativePath.replace(/\\\\/g, \"/\")\n } catch {\n // No index.mdx\n }\n\n items.push({\n text: formatTitle(entry.name),\n link,\n items: children,\n })\n }\n } else if (\n (entry.name.endsWith(\".mdx\") || entry.name.endsWith(\".md\")) &&\n entry.name !== \"index.mdx\" &&\n entry.name !== \"index.md\"\n ) {\n const fileContent = await fs.readFile(fullPath, \"utf-8\")\n const frontmatterMatch = fileContent.match(/^---\\n([\\s\\S]*?)\\n---/)\n\n const ext = entry.name.endsWith(\".mdx\") ? \".mdx\" : \".md\"\n let title = formatTitle(entry.name.replace(ext, \"\"))\n let order: number | undefined\n\n if (frontmatterMatch) {\n const frontmatterText = frontmatterMatch[1]\n const titleMatch = frontmatterText.match(/title:\\s*[\"']?([^\"'\\n]+)[\"']?/)\n const orderMatch = frontmatterText.match(/order:\\s*(\\d+)/)\n\n if (titleMatch) {\n title = titleMatch[1].trim()\n }\n if (orderMatch) {\n order = parseInt(orderMatch[1], 10)\n }\n }\n\n const link = \"/\" + relativePath.replace(ext, \"\").replace(/\\\\/g, \"/\")\n\n items.push({\n text: title,\n link,\n order,\n })\n }\n }\n\n items.sort((a, b) => {\n if (a.order !== undefined && b.order !== undefined) {\n return a.order - b.order\n }\n if (a.order !== undefined) return -1\n if (b.order !== undefined) return 1\n return a.text.localeCompare(b.text)\n })\n\n return items.map(({ order: _order, ...item }) => item)\n}\n\nfunction formatTitle(name: string): string {\n return name.replace(/[-_]/g, \" \").replace(/\\b\\w/g, (c) => c.toUpperCase())\n}\n\ninterface SearchDoc {\n id: string\n title: string\n content: string\n path: string\n section?: string\n}\n\nasync function generateSearchIndex(routesDir: string): Promise<SearchDoc[]> {\n const docs: SearchDoc[] = []\n\n async function scanForSearch(dir: string, section?: string): Promise<void> {\n try {\n const entries = await fs.readdir(dir, { withFileTypes: true })\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name)\n\n if (entry.isDirectory()) {\n // Use directory name as section for nested content\n const newSection = section\n ? `${section} > ${formatTitle(entry.name)}`\n : formatTitle(entry.name)\n await scanForSearch(fullPath, newSection)\n } else if (entry.name.endsWith(\".mdx\") || entry.name.endsWith(\".md\")) {\n const relativePath = path.relative(routesDir, fullPath)\n const fileContent = await fs.readFile(fullPath, \"utf-8\")\n\n // Extract frontmatter\n const frontmatterMatch = fileContent.match(/^---\\n([\\s\\S]*?)\\n---/)\n const ext = entry.name.endsWith(\".mdx\") ? \".mdx\" : \".md\"\n let title = formatTitle(entry.name.replace(ext, \"\"))\n let content = fileContent\n\n if (frontmatterMatch) {\n const frontmatterText = frontmatterMatch[1]\n const titleMatch = frontmatterText.match(/title:\\s*[\"']?([^\"'\\n]+)[\"']?/)\n if (titleMatch) {\n title = titleMatch[1].trim()\n }\n // Remove frontmatter from content\n content = fileContent.slice(frontmatterMatch[0].length)\n }\n\n // Clean up content: remove markdown/MDX syntax, keep text\n content = content\n .replace(/```[\\s\\S]*?```/g, \"\") // Remove code blocks\n .replace(/`[^`]+`/g, \"\") // Remove inline code\n .replace(/import\\s+.*?from\\s+['\"].*?['\"]/g, \"\") // Remove imports\n .replace(/<[^>]+>/g, \"\") // Remove JSX tags\n .replace(/\\[([^\\]]+)\\]\\([^)]+\\)/g, \"$1\") // Links to text\n .replace(/[#*_~>]/g, \"\") // Remove markdown symbols\n .replace(/\\n+/g, \" \") // Newlines to spaces\n .replace(/\\s+/g, \" \") // Multiple spaces to single\n .trim()\n .slice(0, 2000) // Limit content size\n\n // Generate path for the route\n const routePath =\n entry.name === \"index.mdx\" || entry.name === \"index.md\"\n ? \"/\" + path.dirname(relativePath).replace(/\\\\/g, \"/\")\n : \"/\" + relativePath.replace(ext, \"\").replace(/\\\\/g, \"/\")\n\n // Skip root index (use \"/\" as path)\n const finalPath = routePath === \"/.\" ? \"/\" : routePath\n\n docs.push({\n id: relativePath,\n title,\n content,\n path: finalPath,\n section,\n })\n }\n }\n } catch {\n // Directory may not exist\n }\n }\n\n await scanForSearch(routesDir)\n return docs\n}\n\nexport default ardoPlugin\n","import type { Plugin } from \"vite\"\nimport fs from \"fs/promises\"\nimport fsSync from \"fs\"\nimport path from \"path\"\n\nexport interface ArdoRoutesPluginOptions {\n /** Directory where routes are located (default: \"./app/routes\") */\n routesDir?: string\n}\n\ninterface RouteInfo {\n /** URL path (e.g., \"/guide/getting-started\") */\n path: string\n /** File path relative to app directory (e.g., \"routes/guide/getting-started.mdx\") */\n file: string\n /** True if this is an index route */\n isIndex?: boolean\n}\n\n/**\n * Vite plugin that generates routes.ts for React Router Framework Mode.\n * Scans app/routes for .mdx and .tsx files and generates the route configuration.\n */\nexport function ardoRoutesPlugin(options: ArdoRoutesPluginOptions = {}): Plugin {\n let routesDir: string\n let appDir: string\n let routesFilePath: string\n\n function scanRoutesSync(dir: string, rootDir: string): RouteInfo[] {\n const routes: RouteInfo[] = []\n\n try {\n const entries = fsSync.readdirSync(dir, { withFileTypes: true })\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name)\n\n if (entry.isDirectory()) {\n // Recursively scan subdirectories\n const children = scanRoutesSync(fullPath, rootDir)\n routes.push(...children)\n } else if (\n entry.name.endsWith(\".mdx\") ||\n entry.name.endsWith(\".md\") ||\n entry.name.endsWith(\".tsx\")\n ) {\n // Skip special files\n if (entry.name === \"root.tsx\" || entry.name.startsWith(\"_\")) {\n continue\n }\n\n const relativePath = path.relative(rootDir, fullPath)\n const ext = entry.name.endsWith(\".mdx\")\n ? \".mdx\"\n : entry.name.endsWith(\".md\")\n ? \".md\"\n : \".tsx\"\n const baseName = entry.name.replace(ext, \"\")\n\n // Calculate URL path\n let urlPath: string\n if (baseName === \"index\" || baseName === \"home\") {\n // Index route - use parent directory path\n const parentDir = path.dirname(relativePath)\n urlPath = parentDir === \".\" ? \"/\" : \"/\" + parentDir.replace(/\\\\/g, \"/\")\n } else {\n // Regular route\n urlPath = \"/\" + relativePath.replace(ext, \"\").replace(/\\\\/g, \"/\")\n }\n\n // Handle dynamic segments ($param -> :param)\n urlPath = urlPath.replace(/\\$(\\w+)/g, \":$1\")\n\n routes.push({\n path: urlPath,\n file: \"routes/\" + relativePath.replace(/\\\\/g, \"/\"),\n isIndex: baseName === \"index\" || baseName === \"home\",\n })\n }\n }\n } catch {\n // Directory may not exist yet\n }\n\n return routes\n }\n\n function generateRoutesFile(routes: RouteInfo[]): string {\n // Sort routes: index routes first, then alphabetically\n const sortedRoutes = [...routes].sort((a, b) => {\n if (a.path === \"/\" && b.path !== \"/\") return -1\n if (b.path === \"/\" && a.path !== \"/\") return 1\n if (a.isIndex && !b.isIndex) return -1\n if (b.isIndex && !a.isIndex) return 1\n return a.path.localeCompare(b.path)\n })\n\n const entries = sortedRoutes.map((r) => {\n if (r.path === \"/\") {\n return ` index(\"${r.file}\"),`\n }\n // Remove leading slash for route path\n const routePath = r.path.substring(1)\n return ` route(\"${routePath}\", \"${r.file}\"),`\n })\n\n return `// AUTO-GENERATED by Ardo - Do not edit manually\n\nimport { type RouteConfig, route, index } from \"@react-router/dev/routes\"\n\nexport default [\n${entries.join(\"\\n\")}\n] satisfies RouteConfig\n`\n }\n\n function writeRoutesFileSync(): void {\n const routes = scanRoutesSync(routesDir, routesDir)\n\n // Skip if no routes found (directory might not exist yet)\n if (routes.length === 0) {\n return\n }\n\n const content = generateRoutesFile(routes)\n\n // Only write if content changed\n try {\n const existing = fsSync.readFileSync(routesFilePath, \"utf-8\")\n if (existing === content) {\n return\n }\n } catch {\n // File doesn't exist yet\n }\n\n // Ensure app directory exists\n fsSync.mkdirSync(appDir, { recursive: true })\n fsSync.writeFileSync(routesFilePath, content, \"utf-8\")\n console.log(`[ardo] Generated routes.ts with ${routes.length} routes`)\n }\n\n async function writeRoutesFile(): Promise<void> {\n const routes = scanRoutesSync(routesDir, routesDir)\n\n // Skip if no routes found (directory might not exist yet)\n if (routes.length === 0) {\n return\n }\n\n const content = generateRoutesFile(routes)\n\n // Only write if content changed\n try {\n const existing = await fs.readFile(routesFilePath, \"utf-8\")\n if (existing === content) {\n return\n }\n } catch {\n // File doesn't exist yet\n }\n\n // Ensure app directory exists\n await fs.mkdir(appDir, { recursive: true })\n await fs.writeFile(routesFilePath, content, \"utf-8\")\n }\n\n return {\n name: \"ardo:routes\",\n enforce: \"pre\",\n\n config(userConfig) {\n const root = userConfig.root || process.cwd()\n appDir = path.join(root, \"app\")\n routesDir = options.routesDir || path.join(appDir, \"routes\")\n routesFilePath = path.join(appDir, \"routes.ts\")\n\n // Generate routes synchronously during config phase\n // React Router needs routes.ts to exist before it starts\n try {\n writeRoutesFileSync()\n } catch (err) {\n console.warn(\"[ardo] Could not generate routes.ts in config phase:\", err)\n }\n },\n\n configResolved(config) {\n // Update paths if not set in config\n if (!appDir) {\n appDir = path.join(config.root, \"app\")\n routesDir = options.routesDir || path.join(appDir, \"routes\")\n routesFilePath = path.join(appDir, \"routes.ts\")\n }\n },\n\n async buildStart() {\n // Re-generate routes in buildStart for async support\n await writeRoutesFile()\n },\n\n configureServer(server) {\n // Watch for changes in routes directory\n server.watcher.add(routesDir)\n\n const handleChange = async (changedPath: string) => {\n if (\n changedPath.startsWith(routesDir) &&\n (changedPath.endsWith(\".mdx\") ||\n changedPath.endsWith(\".md\") ||\n changedPath.endsWith(\".tsx\"))\n ) {\n await writeRoutesFile()\n }\n }\n\n server.watcher.on(\"add\", handleChange)\n server.watcher.on(\"unlink\", handleChange)\n },\n }\n}\n","import fs from \"fs/promises\"\nimport path from \"path\"\nimport type { PageData, PageFrontmatter, TOCItem, ResolvedConfig } from \"../config/types\"\nimport { transformMarkdown } from \"../markdown/pipeline\"\n\nexport interface LoadDocOptions {\n slug: string\n contentDir: string\n config: ResolvedConfig\n}\n\nexport interface LoadDocResult {\n content: string\n frontmatter: PageFrontmatter\n toc: TOCItem[]\n filePath: string\n relativePath: string\n lastUpdated?: number\n}\n\nexport async function loadDoc(options: LoadDocOptions): Promise<LoadDocResult | null> {\n const { slug, contentDir, config } = options\n\n const possiblePaths = [\n path.join(contentDir, `${slug}.md`),\n path.join(contentDir, slug, \"index.md\"),\n ]\n\n let filePath: string | null = null\n let fileContent: string | null = null\n\n for (const tryPath of possiblePaths) {\n try {\n fileContent = await fs.readFile(tryPath, \"utf-8\")\n filePath = tryPath\n break\n } catch {\n continue\n }\n }\n\n if (!filePath || !fileContent) {\n return null\n }\n\n const result = await transformMarkdown(fileContent, config.markdown)\n const relativePath = path.relative(contentDir, filePath)\n\n let lastUpdated: number | undefined\n try {\n const stat = await fs.stat(filePath)\n lastUpdated = stat.mtimeMs\n } catch {\n // Ignore stat errors\n }\n\n return {\n content: result.html,\n frontmatter: result.frontmatter,\n toc: result.toc,\n filePath,\n relativePath,\n lastUpdated,\n }\n}\n\nexport async function loadAllDocs(contentDir: string, config: ResolvedConfig): Promise<PageData[]> {\n const docs: PageData[] = []\n\n async function scanDir(dir: string) {\n const entries = await fs.readdir(dir, { withFileTypes: true })\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name)\n\n if (entry.isDirectory()) {\n await scanDir(fullPath)\n } else if (entry.name.endsWith(\".md\")) {\n const fileContent = await fs.readFile(fullPath, \"utf-8\")\n const result = await transformMarkdown(fileContent, config.markdown)\n const relativePath = path.relative(contentDir, fullPath)\n\n let lastUpdated: number | undefined\n try {\n const stat = await fs.stat(fullPath)\n lastUpdated = stat.mtimeMs\n } catch {\n // Ignore stat errors\n }\n\n docs.push({\n title: result.frontmatter.title || formatTitle(entry.name.replace(/\\.md$/, \"\")),\n description: result.frontmatter.description,\n frontmatter: result.frontmatter,\n content: result.html,\n toc: result.toc,\n filePath: fullPath,\n relativePath,\n lastUpdated,\n })\n }\n }\n }\n\n await scanDir(contentDir)\n return docs\n}\n\nfunction formatTitle(name: string): string {\n return name.replace(/[-_]/g, \" \").replace(/\\b\\w/g, (c) => c.toUpperCase())\n}\n\nexport function getSlugFromPath(relativePath: string): string {\n return relativePath\n .replace(/\\.md$/, \"\")\n .replace(/\\/index$/, \"\")\n .replace(/\\\\/g, \"/\")\n}\n\nexport function getPageDataForRoute(docs: PageData[], slug: string): PageData | undefined {\n return docs.find((doc) => {\n const docSlug = getSlugFromPath(doc.relativePath)\n return docSlug === slug || docSlug === `${slug}/index`\n })\n}\n","import { unified } from \"unified\"\nimport remarkParse from \"remark-parse\"\nimport remarkGfm from \"remark-gfm\"\nimport remarkFrontmatter from \"remark-frontmatter\"\nimport remarkDirective from \"remark-directive\"\nimport remarkRehype from \"remark-rehype\"\nimport rehypeStringify from \"rehype-stringify\"\nimport matter from \"gray-matter\"\nimport type { MarkdownConfig, TOCItem, PageFrontmatter } from \"../config/types\"\nimport { remarkContainers } from \"./containers\"\nimport { remarkExtractToc, type TocExtraction } from \"./toc\"\nimport { createShikiHighlighter, rehypeShikiFromHighlighter, type ShikiHighlighter } from \"./shiki\"\nimport { rehypeLinks } from \"./links\"\n\nexport interface TransformResult {\n html: string\n frontmatter: PageFrontmatter\n toc: TOCItem[]\n}\n\nexport interface TransformOptions {\n basePath?: string\n highlighter?: ShikiHighlighter\n}\n\nexport async function transformMarkdown(\n content: string,\n config: MarkdownConfig,\n options: TransformOptions = {}\n): Promise<TransformResult> {\n const { data: frontmatter, content: markdownContent } = matter(content)\n const { basePath = \"/\", highlighter: providedHighlighter } = options\n\n const tocExtraction: TocExtraction = { toc: [] }\n const highlighter = providedHighlighter ?? (await createShikiHighlighter(config))\n\n const processor = unified()\n .use(remarkParse)\n .use(remarkFrontmatter, [\"yaml\"])\n .use(remarkGfm)\n .use(remarkDirective)\n .use(remarkContainers)\n .use(remarkExtractToc, { tocExtraction, levels: config.toc?.level ?? [2, 3] })\n .use(remarkRehype, { allowDangerousHtml: true })\n .use(rehypeShikiFromHighlighter, { highlighter, config })\n .use(rehypeLinks, { basePath })\n .use(rehypeStringify, { allowDangerousHtml: true })\n\n if (config.remarkPlugins) {\n for (const plugin of config.remarkPlugins) {\n processor.use(plugin as Parameters<typeof processor.use>[0])\n }\n }\n\n if (config.rehypePlugins) {\n for (const plugin of config.rehypePlugins) {\n processor.use(plugin as Parameters<typeof processor.use>[0])\n }\n }\n\n const result = await processor.process(markdownContent)\n\n return {\n html: String(result),\n frontmatter: frontmatter as PageFrontmatter,\n toc: tocExtraction.toc,\n }\n}\n\nexport async function transformMarkdownToReact(\n content: string,\n config: MarkdownConfig\n): Promise<TransformResult> {\n return transformMarkdown(content, config)\n}\n","import type { Root } from \"mdast\"\nimport type { ContainerDirective } from \"mdast-util-directive\"\nimport { visit } from \"unist-util-visit\"\n\nconst containerTypes = [\n \"tip\",\n \"warning\",\n \"danger\",\n \"info\",\n \"note\",\n \"details\",\n \"code-group\",\n] as const\ntype ContainerType = (typeof containerTypes)[number]\n\nconst defaultTitles: Record<ContainerType, string> = {\n tip: \"TIP\",\n warning: \"WARNING\",\n danger: \"DANGER\",\n info: \"INFO\",\n note: \"NOTE\",\n details: \"Details\",\n \"code-group\": \"\",\n}\n\nexport function remarkContainers() {\n return function (tree: Root) {\n visit(tree, \"containerDirective\", (node: ContainerDirective) => {\n const type = node.name as ContainerType\n\n if (!containerTypes.includes(type)) {\n return\n }\n\n const data = node.data || (node.data = {})\n\n const titleNode = node.children[0]\n let customTitle: string | undefined\n\n if (\n titleNode &&\n titleNode.type === \"paragraph\" &&\n titleNode.children[0]?.type === \"text\" &&\n titleNode.data?.directiveLabel\n ) {\n customTitle = (titleNode.children[0] as { value: string }).value\n node.children.shift()\n }\n\n const title = customTitle || defaultTitles[type]\n\n if (type === \"code-group\") {\n data.hName = \"div\"\n data.hProperties = {\n className: [\"ardo-code-group\"],\n }\n\n const tabs: Array<{ label: string; content: unknown }> = []\n\n for (const child of node.children) {\n if (child.type === \"code\") {\n const codeNode = child as { lang?: string; meta?: string; value: string }\n const meta = codeNode.meta || \"\"\n const labelMatch = meta.match(/\\[([^\\]]+)\\]/)\n const label = labelMatch ? labelMatch[1] : codeNode.lang || \"Code\"\n tabs.push({ label, content: child })\n }\n }\n\n const tabsHtml = tabs\n .map(\n (tab, i) =>\n `<button class=\"ardo-code-group-tab${i === 0 ? \" active\" : \"\"}\" data-index=\"${i}\">${escapeHtml(tab.label)}</button>`\n )\n .join(\"\")\n\n node.children = [\n {\n type: \"html\",\n value: `<div class=\"ardo-code-group-tabs\">${tabsHtml}</div>`,\n } as unknown as (typeof node.children)[number],\n {\n type: \"html\",\n value: '<div class=\"ardo-code-group-panels\">',\n } as unknown as (typeof node.children)[number],\n ...tabs.map(\n (tab, i) =>\n ({\n type: \"html\",\n value: `<div class=\"ardo-code-group-panel${i === 0 ? \" active\" : \"\"}\" data-index=\"${i}\">`,\n }) as unknown as (typeof node.children)[number]\n ),\n ...node.children.flatMap((child: (typeof node.children)[number], _i: number) => [\n child,\n {\n type: \"html\",\n value: \"</div>\",\n } as unknown as (typeof node.children)[number],\n ]),\n {\n type: \"html\",\n value: \"</div>\",\n } as unknown as (typeof node.children)[number],\n ]\n\n return\n }\n\n if (type === \"details\") {\n data.hName = \"details\"\n data.hProperties = {\n className: [\"ardo-details\"],\n }\n\n node.children.unshift({\n type: \"html\",\n value: `<summary class=\"ardo-details-summary\">${escapeHtml(title)}</summary>`,\n } as unknown as (typeof node.children)[number])\n\n return\n }\n\n data.hName = \"div\"\n data.hProperties = {\n className: [\"ardo-container\", `ardo-container-${type}`],\n }\n\n node.children.unshift({\n type: \"html\",\n value: `<p class=\"ardo-container-title\">${escapeHtml(title)}</p>`,\n } as unknown as (typeof node.children)[number])\n })\n }\n}\n\nfunction escapeHtml(text: string): string {\n return text\n .replace(/&/g, \"&amp;\")\n .replace(/</g, \"&lt;\")\n .replace(/>/g, \"&gt;\")\n .replace(/\"/g, \"&quot;\")\n .replace(/'/g, \"&#39;\")\n}\n","import type { Root, Heading } from \"mdast\"\nimport { visit } from \"unist-util-visit\"\nimport type { TOCItem } from \"../config/types\"\n\nexport interface TocExtraction {\n toc: TOCItem[]\n}\n\ninterface TocOptions {\n tocExtraction: TocExtraction\n levels: [number, number]\n}\n\nexport function remarkExtractToc(options: TocOptions) {\n const { tocExtraction, levels } = options\n const [minLevel, maxLevel] = levels\n\n return function (tree: Root) {\n const headings: Array<{ text: string; level: number; id: string }> = []\n\n visit(tree, \"heading\", (node: Heading) => {\n if (node.depth < minLevel || node.depth > maxLevel) {\n return\n }\n\n const text = getHeadingText(node)\n const id = slugify(text)\n\n headings.push({\n text,\n level: node.depth,\n id,\n })\n\n // Add id to the heading node for anchor links\n const data = node.data || (node.data = {})\n const hProperties = (data.hProperties || (data.hProperties = {})) as Record<string, string>\n hProperties.id = id\n })\n\n tocExtraction.toc = buildTocTree(headings, minLevel)\n }\n}\n\nfunction getHeadingText(node: Heading): string {\n const textParts: string[] = []\n\n function extractText(child: unknown) {\n if (!child || typeof child !== \"object\") return\n\n const typedChild = child as { type?: string; value?: string; children?: unknown[] }\n\n if (typedChild.type === \"text\") {\n textParts.push(typedChild.value || \"\")\n } else if (typedChild.type === \"inlineCode\") {\n textParts.push(typedChild.value || \"\")\n } else if (Array.isArray(typedChild.children)) {\n typedChild.children.forEach(extractText)\n }\n }\n\n node.children.forEach(extractText)\n return textParts.join(\"\")\n}\n\nfunction slugify(text: string): string {\n return text\n .toLowerCase()\n .trim()\n .replace(/[^\\w\\s-]/g, \"\")\n .replace(/[\\s_-]+/g, \"-\")\n .replace(/^-+|-+$/g, \"\")\n}\n\nfunction buildTocTree(\n headings: Array<{ text: string; level: number; id: string }>,\n _minLevel: number\n): TOCItem[] {\n const result: TOCItem[] = []\n const stack: Array<{ item: TOCItem; level: number }> = []\n\n for (const heading of headings) {\n const item: TOCItem = {\n id: heading.id,\n text: heading.text,\n level: heading.level,\n }\n\n while (stack.length > 0 && stack[stack.length - 1].level >= heading.level) {\n stack.pop()\n }\n\n if (stack.length === 0) {\n result.push(item)\n } else {\n const parent = stack[stack.length - 1].item\n if (!parent.children) {\n parent.children = []\n }\n parent.children.push(item)\n }\n\n stack.push({ item, level: heading.level })\n }\n\n return result\n}\n\nexport function flattenToc(toc: TOCItem[]): TOCItem[] {\n const result: TOCItem[] = []\n\n function flatten(items: TOCItem[]) {\n for (const item of items) {\n result.push(item)\n if (item.children) {\n flatten(item.children)\n }\n }\n }\n\n flatten(toc)\n return result\n}\n","import { createHighlighter, type Highlighter, type BundledTheme } from \"shiki\"\nimport type { Root, Element, Text } from \"hast\"\nimport { visit } from \"unist-util-visit\"\nimport type { MarkdownConfig } from \"../config/types\"\n\nexport type ShikiHighlighter = Highlighter\n\nexport async function createShikiHighlighter(config: MarkdownConfig): Promise<ShikiHighlighter> {\n const themeConfig = config.theme ?? {\n light: \"github-light\",\n dark: \"github-dark\",\n }\n\n const themes: BundledTheme[] =\n typeof themeConfig === \"string\" ? [themeConfig] : [themeConfig.light, themeConfig.dark]\n\n const highlighter = await createHighlighter({\n themes,\n langs: [\n \"javascript\",\n \"typescript\",\n \"jsx\",\n \"tsx\",\n \"json\",\n \"html\",\n \"css\",\n \"markdown\",\n \"bash\",\n \"shell\",\n \"yaml\",\n \"python\",\n \"rust\",\n \"go\",\n \"sql\",\n \"diff\",\n ],\n })\n\n return highlighter\n}\n\ninterface RehypeShikiOptions {\n highlighter: ShikiHighlighter\n config: MarkdownConfig\n}\n\nexport function rehypeShikiFromHighlighter(options: RehypeShikiOptions) {\n const { highlighter, config } = options\n\n const themeConfig = config.theme ?? {\n light: \"github-light\",\n dark: \"github-dark\",\n }\n\n return function (tree: Root) {\n visit(tree, \"element\", (node: Element, index, parent) => {\n if (\n node.tagName !== \"pre\" ||\n !node.children[0] ||\n (node.children[0] as Element).tagName !== \"code\"\n ) {\n return\n }\n\n const codeNode = node.children[0] as Element\n const className = (codeNode.properties?.className as string[]) || []\n const langClass = className.find((c) => c.startsWith(\"language-\"))\n const lang = langClass ? langClass.replace(\"language-\", \"\") : \"text\"\n\n const codeContent = getTextContent(codeNode)\n\n if (!codeContent.trim()) {\n return\n }\n\n try {\n let html: string\n\n if (typeof themeConfig === \"string\") {\n html = highlighter.codeToHtml(codeContent, {\n lang,\n theme: themeConfig,\n })\n } else {\n html = highlighter.codeToHtml(codeContent, {\n lang,\n themes: {\n light: themeConfig.light,\n dark: themeConfig.dark,\n },\n defaultColor: false,\n })\n }\n\n const metaString = (codeNode.properties?.metastring as string) || \"\"\n const lineNumbers = config.lineNumbers || metaString.includes(\"showLineNumbers\")\n const highlightLines = parseHighlightLines(metaString)\n const title = parseTitle(metaString)\n\n const wrapperHtml = buildCodeBlockHtml(html, {\n lang,\n lineNumbers,\n highlightLines,\n title,\n })\n\n if (parent && typeof index === \"number\") {\n const newNode: Element = {\n type: \"element\",\n tagName: \"div\",\n properties: {\n className: [\"ardo-code-block\"],\n \"data-lang\": lang,\n },\n children: [\n {\n type: \"raw\",\n value: wrapperHtml,\n } as unknown as Element,\n ],\n }\n parent.children[index] = newNode\n }\n } catch {\n // If highlighting fails, leave the node unchanged\n }\n })\n }\n}\n\nfunction getTextContent(node: Element | Text): string {\n if (node.type === \"text\") {\n return node.value\n }\n if (\"children\" in node) {\n return node.children.map((child) => getTextContent(child as Element | Text)).join(\"\")\n }\n return \"\"\n}\n\nfunction parseHighlightLines(meta: string): number[] {\n const match = meta.match(/\\{([\\d,-]+)\\}/)\n if (!match) return []\n\n const ranges = match[1].split(\",\")\n const lines: number[] = []\n\n for (const range of ranges) {\n if (range.includes(\"-\")) {\n const [start, end] = range.split(\"-\").map(Number)\n for (let i = start; i <= end; i++) {\n lines.push(i)\n }\n } else {\n lines.push(Number(range))\n }\n }\n\n return lines\n}\n\nfunction parseTitle(meta: string): string | undefined {\n const match = meta.match(/title=\"([^\"]+)\"/)\n return match ? match[1] : undefined\n}\n\ninterface CodeBlockOptions {\n lang: string\n lineNumbers: boolean\n highlightLines: number[]\n title?: string\n}\n\nfunction buildCodeBlockHtml(shikiHtml: string, options: CodeBlockOptions): string {\n const { lang, lineNumbers, highlightLines, title } = options\n\n let html = \"\"\n\n if (title) {\n html += `<div class=\"ardo-code-title\">${escapeHtml(title)}</div>`\n }\n\n html += `<div class=\"ardo-code-wrapper\" data-lang=\"${lang}\">`\n\n if (lineNumbers || highlightLines.length > 0) {\n const lines = shikiHtml.split(\"\\n\")\n const processedHtml = lines\n .map((line, i) => {\n const lineNum = i + 1\n const isHighlighted = highlightLines.includes(lineNum)\n const classes = [\"ardo-code-line\"]\n if (isHighlighted) classes.push(\"highlighted\")\n\n let prefix = \"\"\n if (lineNumbers) {\n prefix = `<span class=\"ardo-line-number\">${lineNum}</span>`\n }\n\n return `<span class=\"${classes.join(\" \")}\">${prefix}${line}</span>`\n })\n .join(\"\\n\")\n\n html += processedHtml\n } else {\n html += shikiHtml\n }\n\n html += `<button class=\"ardo-copy-button\" data-code=\"${encodeURIComponent(extractCodeFromHtml(shikiHtml))}\">\n <span class=\"ardo-copy-icon\">Copy</span>\n <span class=\"ardo-copied-icon\" style=\"display:none\">Copied!</span>\n </button>`\n\n html += \"</div>\"\n\n return html\n}\n\nfunction extractCodeFromHtml(html: string): string {\n return html\n .replace(/<[^>]+>/g, \"\")\n .replace(/&lt;/g, \"<\")\n .replace(/&gt;/g, \">\")\n .replace(/&amp;/g, \"&\")\n .replace(/&quot;/g, '\"')\n .replace(/&#39;/g, \"'\")\n}\n\nfunction escapeHtml(text: string): string {\n return text\n .replace(/&/g, \"&amp;\")\n .replace(/</g, \"&lt;\")\n .replace(/>/g, \"&gt;\")\n .replace(/\"/g, \"&quot;\")\n .replace(/'/g, \"&#39;\")\n}\n","import { visit } from \"unist-util-visit\"\nimport type { Root, Element } from \"hast\"\n\nexport interface RehypeLinkOptions {\n basePath: string\n}\n\n/**\n * Rehype plugin that rewrites internal links to include the basePath.\n * This is needed for static sites deployed to subpaths (e.g., GitHub Pages).\n */\nexport function rehypeLinks(options: RehypeLinkOptions) {\n const { basePath } = options\n\n // Normalize basePath: ensure it starts with / and doesn't end with /\n const normalizedBase = basePath === \"/\" ? \"\" : basePath.replace(/\\/$/, \"\")\n\n return (tree: Root) => {\n if (!normalizedBase) {\n // No basePath to add\n return\n }\n\n visit(tree, \"element\", (node: Element) => {\n if (node.tagName === \"a\") {\n const href = node.properties?.href\n\n if (typeof href === \"string\") {\n // Only rewrite internal links that start with /\n // Don't rewrite: external URLs, anchors, relative paths, or already prefixed paths\n if (href.startsWith(\"/\") && !href.startsWith(\"//\") && !href.startsWith(normalizedBase)) {\n node.properties = node.properties || {}\n node.properties.href = normalizedBase + href\n }\n }\n }\n })\n }\n}\n","import fs from \"fs/promises\"\nimport type { Dirent } from \"fs\"\nimport path from \"path\"\nimport matter from \"gray-matter\"\nimport type { SidebarItem, ResolvedConfig } from \"../config/types\"\n\nexport interface SidebarGenerationOptions {\n contentDir: string\n basePath: string\n config: ResolvedConfig\n}\n\nexport async function generateSidebar(options: SidebarGenerationOptions): Promise<SidebarItem[]> {\n const { contentDir, basePath, config } = options\n\n const configSidebar = config.themeConfig.sidebar\n\n if (configSidebar) {\n if (Array.isArray(configSidebar) && configSidebar.length > 0) {\n return configSidebar\n }\n if (!Array.isArray(configSidebar)) {\n return []\n }\n }\n\n return await scanDirectoryForSidebar(contentDir, contentDir, basePath)\n}\n\nasync function scanDirectoryForSidebar(\n dir: string,\n rootDir: string,\n _basePath: string\n): Promise<SidebarItem[]> {\n let entries: Dirent[]\n\n try {\n entries = (await fs.readdir(dir, { withFileTypes: true })) as Dirent[]\n } catch {\n return []\n }\n\n interface SidebarItemWithOrder extends SidebarItem {\n order?: number\n }\n\n const items: SidebarItemWithOrder[] = []\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name)\n const relativePath = path.relative(rootDir, fullPath)\n\n if (entry.name.startsWith(\".\") || entry.name.startsWith(\"_\")) {\n continue\n }\n\n if (entry.isDirectory()) {\n const children = await scanDirectoryForSidebar(fullPath, rootDir, _basePath)\n\n if (children.length > 0) {\n const indexPath = path.join(fullPath, \"index.md\")\n let link: string | undefined\n let title = formatTitle(entry.name)\n let order: number | undefined\n\n try {\n const indexContent = await fs.readFile(indexPath, \"utf-8\")\n const { data: frontmatter } = matter(indexContent)\n\n if (frontmatter.title) {\n title = frontmatter.title\n }\n if (typeof frontmatter.order === \"number\") {\n order = frontmatter.order\n }\n\n // Don't include basePath - React Router handles it automatically\n link = normalizePath(relativePath)\n } catch {\n // No index.md file\n }\n\n items.push({\n text: title,\n link,\n collapsed: false,\n items: children,\n order,\n })\n }\n } else if (entry.name.endsWith(\".md\") && entry.name !== \"index.md\") {\n const fileContent = await fs.readFile(fullPath, \"utf-8\")\n const { data: frontmatter } = matter(fileContent)\n\n if (frontmatter.sidebar === false) {\n continue\n }\n\n const title = frontmatter.title || formatTitle(entry.name.replace(/\\.md$/, \"\"))\n const order = typeof frontmatter.order === \"number\" ? frontmatter.order : undefined\n\n // Don't include basePath - React Router handles it automatically\n const link = normalizePath(relativePath.replace(/\\.md$/, \"\"))\n\n items.push({\n text: title,\n link,\n order,\n })\n }\n }\n\n items.sort((a, b) => {\n if (a.order !== undefined && b.order !== undefined) {\n return a.order - b.order\n }\n if (a.order !== undefined) return -1\n if (b.order !== undefined) return 1\n return a.text.localeCompare(b.text)\n })\n\n return items.map(({ order: _order, ...item }) => item)\n}\n\nfunction formatTitle(name: string): string {\n return name\n .replace(/^\\d+-/, \"\")\n .replace(/[-_]/g, \" \")\n .replace(/\\b\\w/g, (c) => c.toUpperCase())\n}\n\nfunction normalizePath(p: string): string {\n return \"/\" + p.replace(/\\\\/g, \"/\").replace(/^\\/+/, \"\")\n}\n"],"mappings":"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","names":["fs","fsSync","path","path","fsSync","fs","fs","path","remarkGfm","remarkFrontmatter","remarkDirective","visit","visit","escapeHtml","visit","remarkFrontmatter","remarkGfm","remarkDirective","path","fs","formatTitle","fs","path","matter","generateSidebar","formatTitle"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/config/index.ts"],"sourcesContent":["import type {\n PressConfig,\n ResolvedConfig,\n ThemeConfig,\n MarkdownConfig,\n TypeDocConfig,\n SidebarItem,\n NavItem,\n SocialLink,\n PageFrontmatter,\n TOCItem,\n PageData,\n HeadConfig,\n} from \"./types\"\nimport path from \"path\"\n\nexport type {\n PressConfig,\n ResolvedConfig,\n ThemeConfig,\n MarkdownConfig,\n TypeDocConfig,\n SidebarItem,\n NavItem,\n SocialLink,\n PageFrontmatter,\n TOCItem,\n PageData,\n HeadConfig,\n}\n\nexport function defineConfig(config: PressConfig): PressConfig {\n return config\n}\n\nconst defaultThemeConfig: ThemeConfig = {\n nav: [],\n sidebar: [],\n socialLinks: [],\n search: {\n enabled: true,\n placeholder: \"Search...\",\n },\n outline: {\n level: 2,\n label: \"On this page\",\n },\n}\n\nconst defaultMarkdownConfig: MarkdownConfig = {\n theme: {\n light: \"github-light\",\n dark: \"github-dark\",\n },\n lineNumbers: false,\n anchor: true,\n toc: {\n level: [2, 3],\n },\n}\n\nexport function resolveConfig(config: PressConfig, root: string): ResolvedConfig {\n const srcDir = config.srcDir ?? \"content\"\n const contentDir = path.resolve(root, srcDir)\n\n return {\n title: config.title,\n description: config.description ?? \"\",\n base: config.base ?? \"/\",\n srcDir,\n outDir: config.outDir ?? \"dist\",\n lang: config.lang ?? \"en\",\n head: config.head ?? [],\n themeConfig: {\n ...defaultThemeConfig,\n ...config.themeConfig,\n },\n markdown: {\n ...defaultMarkdownConfig,\n ...config.markdown,\n },\n vite: config.vite,\n root,\n contentDir,\n }\n}\n\nexport async function loadConfig(root: string): Promise<ResolvedConfig> {\n const configPath = path.resolve(root, \"press.config.ts\")\n\n try {\n const configModule = await import(configPath)\n const config = configModule.default as PressConfig\n return resolveConfig(config, root)\n } catch {\n return resolveConfig(\n {\n title: \"Ardo\",\n description: \"Documentation powered by Ardo\",\n },\n root\n )\n }\n}\n"],"mappings":";AAcA,OAAO,UAAU;AAiBV,SAAS,aAAa,QAAkC;AAC7D,SAAO;AACT;AAEA,IAAM,qBAAkC;AAAA,EACtC,KAAK,CAAC;AAAA,EACN,SAAS,CAAC;AAAA,EACV,aAAa,CAAC;AAAA,EACd,QAAQ;AAAA,IACN,SAAS;AAAA,IACT,aAAa;AAAA,EACf;AAAA,EACA,SAAS;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,EACT;AACF;AAEA,IAAM,wBAAwC;AAAA,EAC5C,OAAO;AAAA,IACL,OAAO;AAAA,IACP,MAAM;AAAA,EACR;AAAA,EACA,aAAa;AAAA,EACb,QAAQ;AAAA,EACR,KAAK;AAAA,IACH,OAAO,CAAC,GAAG,CAAC;AAAA,EACd;AACF;AAEO,SAAS,cAAc,QAAqB,MAA8B;AAC/E,QAAM,SAAS,OAAO,UAAU;AAChC,QAAM,aAAa,KAAK,QAAQ,MAAM,MAAM;AAE5C,SAAO;AAAA,IACL,OAAO,OAAO;AAAA,IACd,aAAa,OAAO,eAAe;AAAA,IACnC,MAAM,OAAO,QAAQ;AAAA,IACrB;AAAA,IACA,QAAQ,OAAO,UAAU;AAAA,IACzB,MAAM,OAAO,QAAQ;AAAA,IACrB,MAAM,OAAO,QAAQ,CAAC;AAAA,IACtB,aAAa;AAAA,MACX,GAAG;AAAA,MACH,GAAG,OAAO;AAAA,IACZ;AAAA,IACA,UAAU;AAAA,MACR,GAAG;AAAA,MACH,GAAG,OAAO;AAAA,IACZ;AAAA,IACA,MAAM,OAAO;AAAA,IACb;AAAA,IACA;AAAA,EACF;AACF;AAEA,eAAsB,WAAW,MAAuC;AACtE,QAAM,aAAa,KAAK,QAAQ,MAAM,iBAAiB;AAEvD,MAAI;AACF,UAAM,eAAe,MAAM,OAAO;AAClC,UAAM,SAAS,aAAa;AAC5B,WAAO,cAAc,QAAQ,IAAI;AAAA,EACnC,QAAQ;AACN,WAAO;AAAA,MACL;AAAA,QACE,OAAO;AAAA,QACP,aAAa;AAAA,MACf;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/typedoc/generator.ts"],"sourcesContent":["import {\n Application,\n TSConfigReader,\n TypeDocReader,\n type ProjectReflection,\n ReflectionKind,\n type DeclarationReflection,\n type SignatureReflection,\n type TypeParameterReflection,\n} from \"typedoc\"\nimport path from \"path\"\nimport fs from \"fs/promises\"\nimport type { TypeDocConfig, GeneratedApiDoc } from \"./types\"\n\nexport class TypeDocGenerator {\n private config: TypeDocConfig\n private app: Application | undefined\n private project: ProjectReflection | undefined\n private basePath: string\n\n constructor(config: TypeDocConfig) {\n this.config = {\n out: \"api\",\n excludeExternals: true,\n excludePrivate: true,\n excludeProtected: false,\n excludeInternal: true,\n sort: [\"source-order\"],\n sidebar: {\n title: \"API Reference\",\n position: 100,\n collapsed: false,\n },\n markdown: {\n breadcrumbs: true,\n hierarchy: true,\n sourceLinks: true,\n codeBlocks: true,\n },\n ...config,\n }\n // Use the output directory as the base path for links\n this.basePath = \"/\" + this.config.out!\n }\n\n async generate(outputDir: string): Promise<GeneratedApiDoc[]> {\n const typedocOptions: Record<string, unknown> = {\n entryPoints: this.config.entryPoints,\n tsconfig: this.config.tsconfig,\n excludeExternals: this.config.excludeExternals,\n excludePrivate: this.config.excludePrivate,\n excludeProtected: this.config.excludeProtected,\n excludeInternal: this.config.excludeInternal,\n sort: this.config.sort,\n }\n\n // Only pass array/string options when explicitly set to avoid\n // TypeDoc errors like \"option must be set to an array of strings\"\n if (this.config.exclude) typedocOptions.exclude = this.config.exclude\n if (this.config.categoryOrder) typedocOptions.categoryOrder = this.config.categoryOrder\n if (this.config.groupOrder) typedocOptions.groupOrder = this.config.groupOrder\n if (this.config.plugin) typedocOptions.plugin = this.config.plugin\n if (this.config.readme) typedocOptions.readme = this.config.readme\n\n this.app = await Application.bootstrapWithPlugins(typedocOptions, [\n new TSConfigReader(),\n new TypeDocReader(),\n ])\n\n this.project = await this.app.convert()\n\n if (!this.project) {\n throw new Error(\"TypeDoc conversion failed\")\n }\n\n const docs = this.generateMarkdownDocs()\n const apiDir = path.join(outputDir, this.config.out!)\n\n await fs.mkdir(apiDir, { recursive: true })\n\n for (const doc of docs) {\n const filePath = path.join(apiDir, doc.path)\n const dir = path.dirname(filePath)\n await fs.mkdir(dir, { recursive: true })\n\n const frontmatterLines = [\n \"---\",\n `title: ${doc.frontmatter.title}`,\n doc.frontmatter.description ? `description: ${doc.frontmatter.description}` : null,\n doc.frontmatter.sidebar_position !== undefined\n ? `sidebar_position: ${doc.frontmatter.sidebar_position}`\n : null,\n \"---\",\n ].filter((line): line is string => line !== null)\n\n const frontmatter = frontmatterLines.join(\"\\n\") + \"\\n\\n\"\n\n await fs.writeFile(filePath, frontmatter + doc.content)\n }\n\n return docs\n }\n\n private generateMarkdownDocs(): GeneratedApiDoc[] {\n if (!this.project) return []\n\n const docs: GeneratedApiDoc[] = []\n\n // Generate index page\n docs.push(this.generateIndexPage())\n\n const children = this.project.children || []\n\n // Group functions and type aliases by source file\n // React components (PascalCase) get their own pages\n const functionsByFile = new Map<string, DeclarationReflection[]>()\n const typesByFile = new Map<string, DeclarationReflection[]>()\n const componentItems: DeclarationReflection[] = []\n const standaloneItems: DeclarationReflection[] = []\n\n for (const child of children) {\n const sourceFile = child.sources?.[0]?.fileName\n\n if (child.kind === ReflectionKind.Function && sourceFile) {\n // React components are PascalCase and get individual pages\n if (this.isReactComponent(child.name)) {\n componentItems.push(child)\n } else {\n const existing = functionsByFile.get(sourceFile) || []\n existing.push(child)\n functionsByFile.set(sourceFile, existing)\n }\n } else if (child.kind === ReflectionKind.TypeAlias && sourceFile) {\n const existing = typesByFile.get(sourceFile) || []\n existing.push(child)\n typesByFile.set(sourceFile, existing)\n } else {\n standaloneItems.push(child)\n }\n }\n\n // Generate grouped pages for functions (by source file)\n for (const [sourceFile, functions] of functionsByFile) {\n docs.push(this.generateGroupedFunctionsPage(sourceFile, functions))\n }\n\n // Generate grouped pages for types (by source file)\n for (const [sourceFile, types] of typesByFile) {\n docs.push(this.generateGroupedTypesPage(sourceFile, types))\n }\n\n // Generate individual pages for React components\n // Sort alphabetically for consistent prev/next navigation\n const sortedComponents = [...componentItems].sort((a, b) => a.name.localeCompare(b.name))\n for (let i = 0; i < sortedComponents.length; i++) {\n const prev = i > 0 ? sortedComponents[i - 1] : null\n const next = i < sortedComponents.length - 1 ? sortedComponents[i + 1] : null\n docs.push(this.generateComponentPage(sortedComponents[i], prev, next))\n }\n\n // Group standalone items by kind for prev/next navigation within each group\n const itemsByKind = new Map<number, DeclarationReflection[]>()\n for (const child of standaloneItems) {\n const kind = child.kind\n const existing = itemsByKind.get(kind) || []\n existing.push(child)\n itemsByKind.set(kind, existing)\n }\n\n // Generate individual pages for classes, interfaces, enums, etc. with prev/next within group\n for (const [, items] of itemsByKind) {\n const sortedItems = [...items].sort((a, b) => a.name.localeCompare(b.name))\n for (let i = 0; i < sortedItems.length; i++) {\n const prev = i > 0 ? sortedItems[i - 1] : null\n const next = i < sortedItems.length - 1 ? sortedItems[i + 1] : null\n docs.push(...this.generateReflectionDocs(sortedItems[i], \"\", prev, next))\n }\n }\n\n return docs\n }\n\n private generateGroupedFunctionsPage(\n sourceFile: string,\n functions: DeclarationReflection[]\n ): GeneratedApiDoc {\n // Extract module name from source file path (e.g., \"src/utils/string.ts\" -> \"string\")\n const moduleName = this.getModuleNameFromPath(sourceFile)\n const slug = this.getSlug(moduleName)\n const content: string[] = []\n\n content.push(`# ${moduleName} Functions`)\n content.push(\"\")\n content.push(`Functions exported from \\`${sourceFile}\\``)\n content.push(\"\")\n\n // Sort functions alphabetically\n const sortedFunctions = [...functions].sort((a, b) => a.name.localeCompare(b.name))\n\n for (const func of sortedFunctions) {\n content.push(`## ${func.name}`)\n content.push(\"\")\n\n // Description\n if (func.comment?.summary) {\n content.push(this.renderComment(func.comment.summary))\n content.push(\"\")\n }\n\n // Signature\n if (func.signatures) {\n for (const sig of func.signatures) {\n content.push(this.renderSignature(sig))\n content.push(\"\")\n }\n }\n\n // Examples\n if (func.comment?.blockTags) {\n const examples = func.comment.blockTags.filter((t) => t.tag === \"@example\")\n if (examples.length > 0) {\n content.push(\"### Example\")\n content.push(\"\")\n for (const example of examples) {\n content.push(this.renderComment(example.content))\n content.push(\"\")\n }\n }\n }\n\n // Source link\n if (this.config.markdown?.sourceLinks && func.sources?.[0]) {\n const source = func.sources[0]\n const sourceUrl = this.getSourceUrl(source.fileName, source.line)\n if (sourceUrl) {\n content.push(`[Source](${sourceUrl})`)\n content.push(\"\")\n }\n }\n\n content.push(\"---\")\n content.push(\"\")\n }\n\n return {\n path: `functions/${slug}.md`,\n content: content.join(\"\\n\"),\n frontmatter: {\n title: `${moduleName} Functions`,\n description: `Functions from ${sourceFile}`,\n },\n }\n }\n\n private generateGroupedTypesPage(\n sourceFile: string,\n types: DeclarationReflection[]\n ): GeneratedApiDoc {\n const moduleName = this.getModuleNameFromPath(sourceFile)\n const slug = this.getSlug(moduleName)\n const content: string[] = []\n\n content.push(`# ${moduleName} Types`)\n content.push(\"\")\n content.push(`Type definitions from \\`${sourceFile}\\``)\n content.push(\"\")\n\n // Sort types alphabetically\n const sortedTypes = [...types].sort((a, b) => a.name.localeCompare(b.name))\n\n for (const typeAlias of sortedTypes) {\n content.push(`## ${typeAlias.name}`)\n content.push(\"\")\n\n // Description\n if (typeAlias.comment?.summary) {\n content.push(this.renderComment(typeAlias.comment.summary))\n content.push(\"\")\n }\n\n // Type definition\n if (typeAlias.type) {\n content.push(\"```typescript\")\n content.push(`type ${typeAlias.name} = ${typeAlias.type.toString()}`)\n content.push(\"```\")\n content.push(\"\")\n }\n\n // Source link\n if (this.config.markdown?.sourceLinks && typeAlias.sources?.[0]) {\n const source = typeAlias.sources[0]\n const sourceUrl = this.getSourceUrl(source.fileName, source.line)\n if (sourceUrl) {\n content.push(`[Source](${sourceUrl})`)\n content.push(\"\")\n }\n }\n\n content.push(\"---\")\n content.push(\"\")\n }\n\n return {\n path: `types/${slug}.md`,\n content: content.join(\"\\n\"),\n frontmatter: {\n title: `${moduleName} Types`,\n description: `Type definitions from ${sourceFile}`,\n },\n }\n }\n\n private getModuleNameFromPath(filePath: string): string {\n // Include parent directory to avoid naming conflicts\n // \"src/utils/string.ts\" -> \"utils/string\"\n // \"src/ui/Sidebar.tsx\" -> \"ui/Sidebar\"\n // \"runtime/sidebar.ts\" -> \"runtime/sidebar\"\n const parts = filePath.split(\"/\")\n const basename = (parts.pop() || filePath).replace(/\\.(ts|tsx|js|jsx)$/, \"\")\n\n // Get parent directory if available\n const parent = parts.pop()\n if (parent && parent !== \"src\") {\n return `${parent}/${basename}`\n }\n return basename\n }\n\n private generateIndexPage(): GeneratedApiDoc {\n const content = [\n `# ${this.config.sidebar?.title || \"API Reference\"}`,\n \"\",\n this.project?.comment?.summary\n ? this.renderComment(this.project.comment.summary)\n : \"Auto-generated API documentation.\",\n \"\",\n ]\n\n const children = this.project?.children || []\n\n // Group functions and types by source file for linking\n // Separate React components from regular functions\n const functionsByFile = new Map<string, DeclarationReflection[]>()\n const typesByFile = new Map<string, DeclarationReflection[]>()\n const componentItems: DeclarationReflection[] = []\n const standaloneItems: DeclarationReflection[] = []\n\n for (const child of children) {\n const sourceFile = child.sources?.[0]?.fileName\n\n if (child.kind === ReflectionKind.Function && sourceFile) {\n if (this.isReactComponent(child.name)) {\n componentItems.push(child)\n } else {\n const existing = functionsByFile.get(sourceFile) || []\n existing.push(child)\n functionsByFile.set(sourceFile, existing)\n }\n } else if (child.kind === ReflectionKind.TypeAlias && sourceFile) {\n const existing = typesByFile.get(sourceFile) || []\n existing.push(child)\n typesByFile.set(sourceFile, existing)\n } else {\n standaloneItems.push(child)\n }\n }\n\n // Render components\n if (componentItems.length > 0) {\n content.push(\"## Components\")\n content.push(\"\")\n\n const sortedComponents = [...componentItems].sort((a, b) => a.name.localeCompare(b.name))\n\n for (const component of sortedComponents) {\n const description = component.comment?.summary\n ? this.renderCommentShort(component.comment.summary)\n : \"\"\n const descSuffix = description ? ` - ${description}` : \"\"\n content.push(\n `- [${component.name}](${this.basePath}/components/${this.getSlug(component.name)})${descSuffix}`\n )\n }\n\n content.push(\"\")\n }\n\n // Render grouped function modules\n if (functionsByFile.size > 0) {\n content.push(\"## Functions\")\n content.push(\"\")\n\n // Sort modules alphabetically\n const sortedModules = [...functionsByFile.entries()].sort((a, b) =>\n this.getModuleNameFromPath(a[0]).localeCompare(this.getModuleNameFromPath(b[0]))\n )\n\n for (const [sourceFile, functions] of sortedModules) {\n const moduleName = this.getModuleNameFromPath(sourceFile)\n const slug = this.getSlug(moduleName)\n const funcNames = functions\n .map((f) => f.name)\n .sort()\n .join(\", \")\n content.push(`- [${moduleName}](${this.basePath}/functions/${slug}) - ${funcNames}`)\n }\n\n content.push(\"\")\n }\n\n // Render grouped type modules\n if (typesByFile.size > 0) {\n content.push(\"## Type Aliases\")\n content.push(\"\")\n\n const sortedModules = [...typesByFile.entries()].sort((a, b) =>\n this.getModuleNameFromPath(a[0]).localeCompare(this.getModuleNameFromPath(b[0]))\n )\n\n for (const [sourceFile, types] of sortedModules) {\n const moduleName = this.getModuleNameFromPath(sourceFile)\n const slug = this.getSlug(moduleName)\n const typeNames = types\n .map((t) => t.name)\n .sort()\n .join(\", \")\n content.push(`- [${moduleName}](${this.basePath}/types/${slug}) - ${typeNames}`)\n }\n\n content.push(\"\")\n }\n\n // Group remaining items by kind\n const groups: Record<string, DeclarationReflection[]> = {}\n\n for (const child of standaloneItems) {\n const kindName = this.getKindGroupName(child.kind, child.name)\n if (!groups[kindName]) {\n groups[kindName] = []\n }\n groups[kindName].push(child)\n }\n\n // Sort each group alphabetically\n for (const group of Object.values(groups)) {\n group.sort((a, b) => a.name.localeCompare(b.name))\n }\n\n // Define the order of groups (excluding Functions and Types which are handled above)\n const groupOrder = [\"Interfaces\", \"Classes\", \"Variables\", \"Enums\", \"Other\"]\n\n // Render each group\n for (const groupName of groupOrder) {\n const group = groups[groupName]\n if (!group || group.length === 0) continue\n\n content.push(`## ${groupName}`)\n content.push(\"\")\n\n for (const child of group) {\n const description = child.comment?.summary\n ? this.renderCommentShort(child.comment.summary)\n : \"\"\n const descSuffix = description ? ` - ${description}` : \"\"\n const groupUrlPrefix = this.getGroupUrlPrefix(child.kind)\n content.push(\n `- [${child.name}](${this.basePath}/${groupUrlPrefix}/${this.getSlug(child.name)})${descSuffix}`\n )\n }\n\n content.push(\"\")\n }\n\n return {\n path: \"index.md\",\n content: content.join(\"\\n\"),\n frontmatter: {\n title: this.config.sidebar?.title || \"API Reference\",\n description: \"Auto-generated API documentation\",\n sidebar_position: 0,\n },\n }\n }\n\n private getKindGroupName(kind: ReflectionKind, name: string): string {\n // Group hooks and components separately from regular functions\n if (kind === ReflectionKind.Function) {\n // React hooks start with \"use\"\n if (name.startsWith(\"use\")) {\n return \"React Hooks\"\n }\n // React components are PascalCase and typically don't start with lowercase\n if (name[0] === name[0].toUpperCase() && !name.includes(\"_\")) {\n return \"React Components\"\n }\n return \"Functions\"\n }\n\n switch (kind) {\n case ReflectionKind.Interface:\n return \"Interfaces\"\n case ReflectionKind.TypeAlias:\n return \"Types\"\n case ReflectionKind.Class:\n return \"Classes\"\n case ReflectionKind.Variable:\n return \"Variables\"\n case ReflectionKind.Enum:\n return \"Enums\"\n default:\n return \"Other\"\n }\n }\n\n private generateReflectionDocs(\n reflection: DeclarationReflection,\n parentPath: string,\n prev: DeclarationReflection | null = null,\n next: DeclarationReflection | null = null\n ): GeneratedApiDoc[] {\n const docs: GeneratedApiDoc[] = []\n const slug = this.getSlug(reflection.name)\n // Use group prefix (e.g., \"interfaces\", \"classes\") when at top level\n const groupPrefix = parentPath ? \"\" : this.getGroupUrlPrefix(reflection.kind)\n const currentPath = parentPath\n ? `${parentPath}/${slug}`\n : groupPrefix\n ? `${groupPrefix}/${slug}`\n : slug\n\n // Generate main page for this reflection\n docs.push(this.generateReflectionPage(reflection, currentPath, prev, next))\n\n // Generate pages for child classes, interfaces, etc.\n // Functions are grouped by source file, not individual pages\n const children = reflection.children || []\n const hasOwnPage = [\n ReflectionKind.Class,\n ReflectionKind.Interface,\n ReflectionKind.Enum,\n ReflectionKind.Namespace,\n ReflectionKind.Module,\n ]\n\n for (const child of children) {\n if (hasOwnPage.includes(child.kind)) {\n docs.push(...this.generateReflectionDocs(child, currentPath))\n }\n }\n\n return docs\n }\n\n private generateReflectionPage(\n reflection: DeclarationReflection,\n pagePath: string,\n prev: DeclarationReflection | null = null,\n next: DeclarationReflection | null = null\n ): GeneratedApiDoc {\n const kind = this.getKindName(reflection.kind)\n const content: string[] = []\n\n // Breadcrumbs\n if (this.config.markdown?.breadcrumbs) {\n content.push(this.generateBreadcrumbs(pagePath))\n content.push(\"\")\n }\n\n // Title\n content.push(`# ${kind}: ${reflection.name}`)\n content.push(\"\")\n\n // Description\n if (reflection.comment?.summary) {\n content.push(this.renderComment(reflection.comment.summary))\n content.push(\"\")\n }\n\n // Type parameters\n if (reflection.typeParameters && reflection.typeParameters.length > 0) {\n content.push(\"## Type Parameters\")\n content.push(\"\")\n content.push(this.renderTypeParameters(reflection.typeParameters))\n content.push(\"\")\n }\n\n // Hierarchy\n if (this.config.markdown?.hierarchy) {\n const hierarchy = this.renderHierarchy(reflection)\n if (hierarchy) {\n content.push(\"## Hierarchy\")\n content.push(\"\")\n content.push(hierarchy)\n content.push(\"\")\n }\n }\n\n // Signature (for functions)\n if (reflection.signatures) {\n content.push(\"## Signature\")\n content.push(\"\")\n for (const sig of reflection.signatures) {\n content.push(this.renderSignature(sig))\n content.push(\"\")\n }\n }\n\n // Properties\n const properties = (reflection.children || []).filter((c) => c.kind === ReflectionKind.Property)\n if (properties.length > 0) {\n content.push(\"## Properties\")\n content.push(\"\")\n for (const prop of properties) {\n content.push(this.renderProperty(prop))\n content.push(\"\")\n }\n }\n\n // Methods\n const methods = (reflection.children || []).filter((c) => c.kind === ReflectionKind.Method)\n if (methods.length > 0) {\n content.push(\"## Methods\")\n content.push(\"\")\n for (const method of methods) {\n content.push(this.renderMethod(method))\n content.push(\"\")\n }\n }\n\n // Enum members\n const enumMembers = (reflection.children || []).filter(\n (c) => c.kind === ReflectionKind.EnumMember\n )\n if (enumMembers.length > 0) {\n content.push(\"## Members\")\n content.push(\"\")\n content.push(\"| Member | Value | Description |\")\n content.push(\"|--------|-------|-------------|\")\n for (const member of enumMembers) {\n const value = member.defaultValue || \"\"\n const desc = member.comment?.summary ? this.renderCommentShort(member.comment.summary) : \"\"\n content.push(`| \\`${member.name}\\` | \\`${value}\\` | ${desc} |`)\n }\n content.push(\"\")\n }\n\n // Type alias definition\n if (reflection.kind === ReflectionKind.TypeAlias && reflection.type) {\n content.push(\"## Type\")\n content.push(\"\")\n content.push(\"```typescript\")\n content.push(`type ${reflection.name} = ${reflection.type.toString()}`)\n content.push(\"```\")\n content.push(\"\")\n }\n\n // Source link\n if (this.config.markdown?.sourceLinks && reflection.sources?.[0]) {\n const source = reflection.sources[0]\n const sourceUrl = this.getSourceUrl(source.fileName, source.line)\n content.push(\"## Source\")\n content.push(\"\")\n if (sourceUrl) {\n content.push(`[${source.fileName}:${source.line}](${sourceUrl})`)\n } else {\n content.push(`${source.fileName}:${source.line}`)\n }\n content.push(\"\")\n }\n\n // Tags (deprecated, example, etc.)\n if (reflection.comment?.blockTags) {\n const examples = reflection.comment.blockTags.filter((t) => t.tag === \"@example\")\n if (examples.length > 0) {\n content.push(\"## Examples\")\n content.push(\"\")\n for (const example of examples) {\n content.push(this.renderComment(example.content))\n content.push(\"\")\n }\n }\n\n const deprecated = reflection.comment.blockTags.find((t) => t.tag === \"@deprecated\")\n if (deprecated) {\n content.push(\":::warning Deprecated\")\n content.push(this.renderComment(deprecated.content))\n content.push(\":::\")\n content.push(\"\")\n }\n\n const see = reflection.comment.blockTags.filter((t) => t.tag === \"@see\")\n if (see.length > 0) {\n content.push(\"## See Also\")\n content.push(\"\")\n for (const s of see) {\n content.push(`- ${this.renderComment(s.content)}`)\n }\n content.push(\"\")\n }\n }\n\n // Prev/Next navigation within group\n if (prev || next) {\n content.push(\"---\")\n content.push(\"\")\n const groupPrefix = this.getGroupUrlPrefix(reflection.kind)\n const prevLink = prev\n ? `[← ${prev.name}](${this.basePath}/${groupPrefix}/${this.getSlug(prev.name)})`\n : \"\"\n const nextLink = next\n ? `[${next.name} →](${this.basePath}/${groupPrefix}/${this.getSlug(next.name)})`\n : \"\"\n if (prev && next) {\n content.push(`${prevLink} | ${nextLink}`)\n } else {\n content.push(prevLink || nextLink)\n }\n content.push(\"\")\n }\n\n return {\n path: `${pagePath}.md`,\n content: content.join(\"\\n\"),\n frontmatter: {\n title: reflection.name,\n description: reflection.comment?.summary\n ? this.renderCommentShort(reflection.comment.summary)\n : `${kind} ${reflection.name}`,\n },\n }\n }\n\n private renderSignature(sig: SignatureReflection): string {\n const lines: string[] = []\n\n if (this.config.markdown?.codeBlocks) {\n lines.push(\"```typescript\")\n }\n\n const typeParams = sig.typeParameters\n ? `<${sig.typeParameters.map((tp) => tp.name).join(\", \")}>`\n : \"\"\n\n const params = (sig.parameters || [])\n .map((p) => {\n const optional = p.flags.isOptional ? \"?\" : \"\"\n const type = p.type ? `: ${p.type.toString()}` : \"\"\n return `${p.name}${optional}${type}`\n })\n .join(\", \")\n\n const returnType = sig.type ? `: ${sig.type.toString()}` : \"\"\n\n lines.push(`function ${sig.name}${typeParams}(${params})${returnType}`)\n\n if (this.config.markdown?.codeBlocks) {\n lines.push(\"```\")\n }\n\n // Parameters table\n if (sig.parameters && sig.parameters.length > 0) {\n lines.push(\"\")\n lines.push(\"### Parameters\")\n lines.push(\"\")\n lines.push(\"| Name | Type | Description |\")\n lines.push(\"|------|------|-------------|\")\n\n for (const param of sig.parameters) {\n const type = param.type ? `\\`${param.type.toString()}\\`` : \"-\"\n const desc = param.comment?.summary ? this.renderCommentShort(param.comment.summary) : \"-\"\n const optional = param.flags.isOptional ? \" (optional)\" : \"\"\n lines.push(`| ${param.name}${optional} | ${type} | ${desc} |`)\n }\n }\n\n // Return value\n if (sig.type && sig.type.toString() !== \"void\") {\n lines.push(\"\")\n lines.push(\"### Returns\")\n lines.push(\"\")\n lines.push(`\\`${sig.type.toString()}\\``)\n\n if (sig.comment?.blockTags) {\n const returns = sig.comment.blockTags.find((t) => t.tag === \"@returns\")\n if (returns) {\n lines.push(\"\")\n lines.push(this.renderComment(returns.content))\n }\n }\n }\n\n return lines.join(\"\\n\")\n }\n\n private renderProperty(prop: DeclarationReflection): string {\n const lines: string[] = []\n\n const flags: string[] = []\n if (prop.flags.isOptional) flags.push(\"optional\")\n if (prop.flags.isReadonly) flags.push(\"readonly\")\n if (prop.flags.isStatic) flags.push(\"static\")\n\n lines.push(`### ${prop.name}`)\n if (flags.length > 0) {\n lines.push(`*${flags.join(\", \")}*`)\n }\n lines.push(\"\")\n\n if (prop.type) {\n lines.push(\"```typescript\")\n lines.push(`${prop.name}: ${prop.type.toString()}`)\n lines.push(\"```\")\n lines.push(\"\")\n }\n\n if (prop.comment?.summary) {\n lines.push(this.renderComment(prop.comment.summary))\n }\n\n if (prop.defaultValue) {\n lines.push(\"\")\n lines.push(`**Default:** \\`${prop.defaultValue}\\``)\n }\n\n return lines.join(\"\\n\")\n }\n\n private renderMethod(method: DeclarationReflection): string {\n const lines: string[] = []\n\n lines.push(`### ${method.name}()`)\n lines.push(\"\")\n\n if (method.signatures) {\n for (const sig of method.signatures) {\n if (sig.comment?.summary) {\n lines.push(this.renderComment(sig.comment.summary))\n lines.push(\"\")\n }\n\n lines.push(this.renderSignature(sig))\n lines.push(\"\")\n }\n }\n\n return lines.join(\"\\n\")\n }\n\n private renderTypeParameters(typeParams: TypeParameterReflection[]): string {\n const lines: string[] = []\n lines.push(\"| Name | Constraint | Default | Description |\")\n lines.push(\"|------|------------|---------|-------------|\")\n\n for (const tp of typeParams) {\n const constraint = tp.type ? `\\`${tp.type.toString()}\\`` : \"-\"\n const defaultVal = tp.default ? `\\`${tp.default.toString()}\\`` : \"-\"\n const desc = tp.comment?.summary ? this.renderCommentShort(tp.comment.summary) : \"-\"\n lines.push(`| ${tp.name} | ${constraint} | ${defaultVal} | ${desc} |`)\n }\n\n return lines.join(\"\\n\")\n }\n\n private renderHierarchy(reflection: DeclarationReflection): string | null {\n const lines: string[] = []\n\n if (reflection.extendedTypes && reflection.extendedTypes.length > 0) {\n lines.push(\"**Extends:**\")\n for (const t of reflection.extendedTypes) {\n lines.push(`- \\`${t.toString()}\\``)\n }\n }\n\n if (reflection.implementedTypes && reflection.implementedTypes.length > 0) {\n lines.push(\"**Implements:**\")\n for (const t of reflection.implementedTypes) {\n lines.push(`- \\`${t.toString()}\\``)\n }\n }\n\n if (reflection.extendedBy && reflection.extendedBy.length > 0) {\n lines.push(\"**Extended by:**\")\n for (const t of reflection.extendedBy) {\n lines.push(`- \\`${t.toString()}\\``)\n }\n }\n\n if (reflection.implementedBy && reflection.implementedBy.length > 0) {\n lines.push(\"**Implemented by:**\")\n for (const t of reflection.implementedBy) {\n lines.push(`- \\`${t.toString()}\\``)\n }\n }\n\n return lines.length > 0 ? lines.join(\"\\n\") : null\n }\n\n private renderComment(parts: { kind: string; text: string }[]): string {\n return parts.map((p) => p.text).join(\"\")\n }\n\n private renderCommentShort(parts: { kind: string; text: string }[]): string {\n const text = this.renderComment(parts)\n const firstSentence = text.split(/[.!?]\\s/)[0]\n return firstSentence.length < text.length ? firstSentence + \".\" : text\n }\n\n private generateBreadcrumbs(pagePath: string): string {\n const parts = pagePath.split(\"/\")\n const breadcrumbs: string[] = [`[API](${this.basePath})`]\n\n let currentPath = \"\"\n for (let i = 0; i < parts.length - 1; i++) {\n currentPath += (currentPath ? \"/\" : \"\") + parts[i]\n breadcrumbs.push(`[${parts[i]}](${this.basePath}/${currentPath})`)\n }\n\n breadcrumbs.push(parts[parts.length - 1])\n\n return breadcrumbs.join(\" / \")\n }\n\n private getKindName(kind: ReflectionKind): string {\n const kindNames: Partial<Record<ReflectionKind, string>> = {\n [ReflectionKind.Class]: \"Class\",\n [ReflectionKind.Interface]: \"Interface\",\n [ReflectionKind.Enum]: \"Enum\",\n [ReflectionKind.TypeAlias]: \"Type\",\n [ReflectionKind.Function]: \"Function\",\n [ReflectionKind.Variable]: \"Variable\",\n [ReflectionKind.Namespace]: \"Namespace\",\n [ReflectionKind.Module]: \"Module\",\n [ReflectionKind.Property]: \"Property\",\n [ReflectionKind.Method]: \"Method\",\n }\n return kindNames[kind] || \"Unknown\"\n }\n\n private getGroupUrlPrefix(kind: ReflectionKind): string {\n const prefixes: Partial<Record<ReflectionKind, string>> = {\n [ReflectionKind.Class]: \"classes\",\n [ReflectionKind.Interface]: \"interfaces\",\n [ReflectionKind.Enum]: \"enums\",\n [ReflectionKind.Variable]: \"variables\",\n [ReflectionKind.Namespace]: \"namespaces\",\n [ReflectionKind.Module]: \"modules\",\n }\n return prefixes[kind] || \"other\"\n }\n\n private getSlug(name: string): string {\n return name\n .toLowerCase()\n .replace(/[^a-z0-9]+/g, \"-\")\n .replace(/^-|-$/g, \"\")\n }\n\n private getSourceUrl(fileName: string, line: number): string | null {\n if (!this.config.markdown?.sourceBaseUrl) return null\n const baseUrl = this.config.markdown.sourceBaseUrl.replace(/\\/$/, \"\")\n return `${baseUrl}/${fileName}#L${line}`\n }\n\n /**\n * Check if a function name looks like a React component (PascalCase)\n */\n private isReactComponent(name: string): boolean {\n // React components start with uppercase and don't contain underscores\n // Also check for common component patterns\n if (name[0] !== name[0].toUpperCase()) return false\n if (name.includes(\"_\")) return false\n // Exclude common non-component patterns\n if (name.startsWith(\"use\")) return false // hooks\n if (name.endsWith(\"Props\") || name.endsWith(\"Options\") || name.endsWith(\"Config\")) return false\n return true\n }\n\n /**\n * Generate a page for a React component\n */\n private generateComponentPage(\n component: DeclarationReflection,\n prev: DeclarationReflection | null,\n next: DeclarationReflection | null\n ): GeneratedApiDoc {\n const slug = this.getSlug(component.name)\n const groupPrefix = \"components\"\n const content: string[] = []\n\n content.push(`# ${component.name}`)\n content.push(\"\")\n\n // Description\n if (component.comment?.summary) {\n content.push(this.renderComment(component.comment.summary))\n content.push(\"\")\n }\n\n // Signature\n if (component.signatures) {\n content.push(\"## Usage\")\n content.push(\"\")\n for (const sig of component.signatures) {\n content.push(this.renderComponentSignature(sig, component.name))\n content.push(\"\")\n }\n }\n\n // Examples\n if (component.comment?.blockTags) {\n const examples = component.comment.blockTags.filter((t) => t.tag === \"@example\")\n if (examples.length > 0) {\n content.push(\"## Example\")\n content.push(\"\")\n for (const example of examples) {\n content.push(this.renderComment(example.content))\n content.push(\"\")\n }\n }\n }\n\n // Source link\n if (this.config.markdown?.sourceLinks && component.sources?.[0]) {\n const source = component.sources[0]\n const sourceUrl = this.getSourceUrl(source.fileName, source.line)\n if (sourceUrl) {\n content.push(`[Source](${sourceUrl})`)\n content.push(\"\")\n }\n }\n\n // Prev/Next navigation\n if (prev || next) {\n content.push(\"---\")\n content.push(\"\")\n const prevLink = prev\n ? `[← ${prev.name}](${this.basePath}/${groupPrefix}/${this.getSlug(prev.name)})`\n : \"\"\n const nextLink = next\n ? `[${next.name} →](${this.basePath}/${groupPrefix}/${this.getSlug(next.name)})`\n : \"\"\n if (prev && next) {\n content.push(`${prevLink} | ${nextLink}`)\n } else {\n content.push(prevLink || nextLink)\n }\n content.push(\"\")\n }\n\n return {\n path: `${groupPrefix}/${slug}.md`,\n content: content.join(\"\\n\"),\n frontmatter: {\n title: component.name,\n description: component.comment?.summary\n ? this.renderCommentShort(component.comment.summary)\n : `${component.name} component`,\n },\n }\n }\n\n /**\n * Get the name of a TypeDoc type (handles reference types, etc.)\n */\n private getTypeName(paramType: unknown): string | null {\n if (!paramType || typeof paramType !== \"object\") return null\n\n // Direct name property\n if (\"name\" in paramType && typeof (paramType as { name: unknown }).name === \"string\") {\n return (paramType as { name: string }).name\n }\n\n // Reference type with target\n if (\"type\" in paramType && (paramType as { type: string }).type === \"reference\") {\n const refType = paramType as { name?: string; qualifiedName?: string }\n return refType.name || refType.qualifiedName || null\n }\n\n return null\n }\n\n /**\n * Get props from a component's parameter type\n */\n private getPropsFromType(\n paramType: unknown\n ): Array<{ name: string; type: string; optional: boolean; description: string }> {\n const props: Array<{ name: string; type: string; optional: boolean; description: string }> = []\n\n // Check if it's a reflection type with inline declaration\n if (paramType && typeof paramType === \"object\" && \"declaration\" in paramType) {\n const declaration = (paramType as { declaration: DeclarationReflection }).declaration\n const children = declaration.children || []\n for (const child of children) {\n props.push({\n name: child.name,\n type: child.type ? child.type.toString() : \"unknown\",\n optional: child.flags.isOptional,\n description: child.comment?.summary ? this.renderCommentShort(child.comment.summary) : \"\",\n })\n }\n }\n // Check if it's a reference type - look up the interface in the project\n else {\n const typeName = this.getTypeName(paramType)\n if (typeName) {\n // Find the interface/type alias in the project\n let propsInterface = this.project?.getChildByName(typeName)\n\n // If not found directly, search all children\n if (!propsInterface && this.project?.children) {\n for (const child of this.project.children) {\n if (child.name === typeName) {\n propsInterface = child\n break\n }\n }\n }\n\n if (propsInterface && \"children\" in propsInterface) {\n const children = (propsInterface as DeclarationReflection).children || []\n for (const child of children) {\n props.push({\n name: child.name,\n type: child.type ? child.type.toString() : \"unknown\",\n optional: child.flags.isOptional,\n description: child.comment?.summary\n ? this.renderCommentShort(child.comment.summary)\n : \"\",\n })\n }\n }\n }\n }\n\n return props\n }\n\n /**\n * Render a component signature in a more readable format\n */\n private renderComponentSignature(sig: SignatureReflection, componentName: string): string {\n const lines: string[] = []\n\n // Get props from the first parameter\n const propsParam = sig.parameters?.[0]\n const props = propsParam ? this.getPropsFromType(propsParam.type) : []\n\n // Get the props interface name for linking\n const propsTypeName = propsParam?.type ? this.getTypeName(propsParam.type) : null\n\n // Check if component has children prop\n const hasChildren = props.some((p) => p.name === \"children\")\n // Filter out children from props display (shown in JSX structure instead)\n const displayProps = props.filter((p) => p.name !== \"children\")\n\n lines.push(\"```tsx\")\n lines.push(`<${componentName}`)\n\n if (displayProps.length > 0) {\n for (const prop of displayProps) {\n const optMark = prop.optional ? \"?\" : \"\"\n lines.push(` ${prop.name}${optMark}={${prop.type}}`)\n }\n } else if (!hasChildren) {\n lines.push(` {...props}`)\n }\n\n if (hasChildren) {\n lines.push(`>`)\n lines.push(` {children}`)\n lines.push(`</${componentName}>`)\n } else {\n lines.push(`/>`)\n }\n lines.push(\"```\")\n\n // Props table with link to props interface\n if (props.length > 0) {\n lines.push(\"\")\n if (propsTypeName) {\n lines.push(`## [Props](${this.basePath}/interfaces/${this.getSlug(propsTypeName)})`)\n } else {\n lines.push(\"## Props\")\n }\n lines.push(\"\")\n lines.push(\"| Prop | Type | Required | Description |\")\n lines.push(\"|------|------|----------|-------------|\")\n\n for (const prop of props) {\n const type = `\\`${prop.type}\\``\n const required = prop.optional ? \"No\" : \"Yes\"\n const desc = prop.description || \"-\"\n lines.push(`| ${prop.name} | ${type} | ${required} | ${desc} |`)\n }\n }\n\n // Skip return value for components - it's always Element/JSX.Element\n\n return lines.join(\"\\n\")\n }\n}\n\nexport async function generateApiDocs(\n config: TypeDocConfig,\n outputDir: string\n): Promise<GeneratedApiDoc[]> {\n const generator = new TypeDocGenerator(config)\n return generator.generate(outputDir)\n}\n"],"mappings":"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","names":[]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/ui/Content.tsx","../src/ui/components/Icon.tsx","../src/ui/components/CopyButton.tsx","../src/ui/components/CodeBlock.tsx","../src/ui/components/Container.tsx","../src/ui/components/Tabs.tsx"],"sourcesContent":["import { type ReactNode } from \"react\"\nimport { usePageData, useThemeConfig, useSidebar } from \"../runtime/hooks\"\nimport { getPrevNextLinks } from \"../runtime/sidebar-utils\"\nimport { Link, useLocation } from \"react-router\"\n\ninterface ContentProps {\n children: ReactNode\n}\n\nexport function Content({ children }: ContentProps) {\n const pageData = usePageData()\n const themeConfig = useThemeConfig()\n const sidebar = useSidebar()\n const location = useLocation()\n\n const { prev, next } = getPrevNextLinks(sidebar, location.pathname)\n\n const showEditLink = pageData?.frontmatter.editLink !== false && themeConfig.editLink?.pattern\n\n const showLastUpdated =\n pageData?.frontmatter.lastUpdated !== false &&\n themeConfig.lastUpdated?.enabled &&\n pageData?.lastUpdated\n\n const editLink = showEditLink\n ? themeConfig.editLink!.pattern.replace(\":path\", pageData?.relativePath || \"\")\n : null\n\n const lastUpdatedText = showLastUpdated\n ? new Date(pageData!.lastUpdated!).toLocaleDateString(\n undefined,\n themeConfig.lastUpdated?.formatOptions ?? {\n year: \"numeric\",\n month: \"long\",\n day: \"numeric\",\n }\n )\n : null\n\n return (\n <article className=\"ardo-content-container\">\n {pageData?.frontmatter.title && (\n <header className=\"ardo-content-header\">\n <h1 className=\"ardo-content-title\">{pageData.frontmatter.title}</h1>\n {pageData.frontmatter.description && (\n <p className=\"ardo-content-description\">{pageData.frontmatter.description}</p>\n )}\n </header>\n )}\n\n <div className=\"ardo-content-body ardo-content\">{children}</div>\n\n <footer className=\"ardo-content-footer\">\n {(showEditLink || showLastUpdated) && (\n <div className=\"ardo-content-meta\">\n {showEditLink && (\n <a\n href={editLink!}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"ardo-edit-link\"\n >\n {themeConfig.editLink?.text ?? \"Edit this page\"}\n </a>\n )}\n {showLastUpdated && (\n <span className=\"ardo-last-updated\">\n {themeConfig.lastUpdated?.text ?? \"Last updated\"}: {lastUpdatedText}\n </span>\n )}\n </div>\n )}\n\n {(prev || next) && (\n <nav className=\"ardo-prev-next\">\n {prev ? (\n <Link to={prev.link!} className=\"ardo-prev-link\">\n <span className=\"ardo-prev-next-label\">Previous</span>\n <span className=\"ardo-prev-next-title\">{prev.text}</span>\n </Link>\n ) : (\n <div />\n )}\n {next ? (\n <Link to={next.link!} className=\"ardo-next-link\">\n <span className=\"ardo-prev-next-label\">Next</span>\n <span className=\"ardo-prev-next-title\">{next.text}</span>\n </Link>\n ) : (\n <div />\n )}\n </nav>\n )}\n </footer>\n </article>\n )\n}\n","import type { LucideProps, LucideIcon } from \"lucide-react\"\nimport type { ReactNode } from \"react\"\n\nexport interface IconProps extends Omit<LucideProps, \"ref\"> {\n /** Name of the registered icon */\n name: string\n}\n\n// Icon registry - users register only the icons they need\nconst iconRegistry = new Map<string, LucideIcon>()\n\n/**\n * Register icons for use with the Icon component.\n * Only registered icons are included in your bundle.\n *\n * @example\n * ```tsx\n * // In your app's entry point or layout:\n * import { registerIcons } from \"ardo/ui\"\n * import { Zap, Rocket, Code } from \"lucide-react\"\n *\n * registerIcons({ Zap, Rocket, Code })\n * ```\n */\nexport function registerIcons(icons: Record<string, LucideIcon>): void {\n for (const [name, icon] of Object.entries(icons)) {\n iconRegistry.set(name, icon)\n }\n}\n\n/**\n * Get all registered icon names (useful for documentation).\n */\nexport function getRegisteredIconNames(): string[] {\n return Array.from(iconRegistry.keys())\n}\n\n/**\n * Renders a registered Lucide icon by name.\n * Icons must be registered first using `registerIcons()`.\n *\n * @example\n * ```tsx\n * // First register icons in your app:\n * import { registerIcons } from \"ardo/ui\"\n * import { Zap, Rocket } from \"lucide-react\"\n * registerIcons({ Zap, Rocket })\n *\n * // Then use in MDX:\n * <Icon name=\"Zap\" size={24} />\n * <Icon name=\"Rocket\" className=\"text-brand\" />\n * ```\n *\n * @see https://lucide.dev/icons for available icon names\n */\nexport function Icon({ name, ...props }: IconProps): ReactNode {\n const LucideIcon = iconRegistry.get(name)\n\n if (!LucideIcon) {\n console.warn(`[Ardo] Icon \"${name}\" not found. Did you register it with registerIcons()?`)\n return null\n }\n\n return <LucideIcon {...props} />\n}\n","import { useState } from \"react\"\n\ninterface CopyButtonProps {\n code: string\n}\n\nexport function CopyButton({ code }: CopyButtonProps) {\n const [copied, setCopied] = useState(false)\n\n const handleCopy = async () => {\n try {\n await navigator.clipboard.writeText(code)\n setCopied(true)\n setTimeout(() => setCopied(false), 2000)\n } catch (err) {\n console.error(\"Failed to copy:\", err)\n }\n }\n\n return (\n <button\n className=\"ardo-copy-button\"\n onClick={handleCopy}\n aria-label={copied ? \"Copied!\" : \"Copy code\"}\n >\n {copied ? <CheckIcon /> : <CopyIcon />}\n <span className=\"ardo-copy-text\">{copied ? \"Copied!\" : \"Copy\"}</span>\n </button>\n )\n}\n\nfunction CopyIcon() {\n return (\n <svg\n viewBox=\"0 0 24 24\"\n width=\"16\"\n height=\"16\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <rect x=\"9\" y=\"9\" width=\"13\" height=\"13\" rx=\"2\" ry=\"2\" />\n <path d=\"M5 15H4a2 2 0 01-2-2V4a2 2 0 012-2h9a2 2 0 012 2v1\" />\n </svg>\n )\n}\n\nfunction CheckIcon() {\n return (\n <svg\n viewBox=\"0 0 24 24\"\n width=\"16\"\n height=\"16\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <polyline points=\"20,6 9,17 4,12\" />\n </svg>\n )\n}\n","import { useState } from \"react\"\nimport { CopyButton } from \"./CopyButton\"\n\nexport interface CodeBlockProps {\n /** The code to display */\n code: string\n /** Programming language for syntax highlighting */\n language?: string\n /** Optional title shown above the code */\n title?: string\n /** Show line numbers */\n lineNumbers?: boolean\n /** Line numbers to highlight */\n highlightLines?: number[]\n /** Optional custom content to render instead of the code */\n children?: React.ReactNode\n}\n\n/**\n * Syntax-highlighted code block with copy button.\n */\nexport function CodeBlock({\n code,\n language = \"text\",\n title,\n lineNumbers = false,\n highlightLines = [],\n children,\n}: CodeBlockProps) {\n const lines = code.split(\"\\n\")\n\n return (\n <div className=\"ardo-code-block\" data-lang={language}>\n {title && <div className=\"ardo-code-title\">{title}</div>}\n <div className=\"ardo-code-wrapper\">\n {children || (\n <pre className={`language-${language}`}>\n <code>\n {lines.map((line, index) => {\n const lineNum = index + 1\n const isHighlighted = highlightLines.includes(lineNum)\n const classes = [\"ardo-code-line\"]\n if (isHighlighted) classes.push(\"highlighted\")\n\n return (\n <span key={index} className={classes.join(\" \")}>\n {lineNumbers && <span className=\"ardo-line-number\">{lineNum}</span>}\n <span className=\"ardo-line-content\">{line}</span>\n {index < lines.length - 1 && \"\\n\"}\n </span>\n )\n })}\n </code>\n </pre>\n )}\n <CopyButton code={code} />\n </div>\n </div>\n )\n}\n\nexport interface CodeGroupProps {\n /** CodeBlock components to display as tabs */\n children: React.ReactNode\n}\n\n/**\n * Tabbed group of code blocks.\n */\nexport function CodeGroup({ children }: CodeGroupProps) {\n const [activeTab, setActiveTab] = useState(0)\n\n const childArray = Array.isArray(children) ? children : [children]\n const tabs = childArray.map((child, index) => {\n const props = (child as React.ReactElement)?.props as { title?: string; language?: string }\n return props?.title || props?.language || `Tab ${index + 1}`\n })\n\n return (\n <div className=\"ardo-code-group\">\n <div className=\"ardo-code-group-tabs\">\n {tabs.map((tab, index) => (\n <button\n key={index}\n className={[\"ardo-code-group-tab\", index === activeTab && \"active\"]\n .filter(Boolean)\n .join(\" \")}\n onClick={() => setActiveTab(index)}\n >\n {tab}\n </button>\n ))}\n </div>\n <div className=\"ardo-code-group-panels\">\n {childArray.map((child, index) => (\n <div\n key={index}\n className={[\"ardo-code-group-panel\", index === activeTab && \"active\"]\n .filter(Boolean)\n .join(\" \")}\n style={{ display: index === activeTab ? \"block\" : \"none\" }}\n >\n {child}\n </div>\n ))}\n </div>\n </div>\n )\n}\n","import { type ReactNode } from \"react\"\nimport { Lightbulb, AlertTriangle, XCircle, Info as InfoIcon, FileText } from \"lucide-react\"\n\nexport type ContainerType = \"tip\" | \"warning\" | \"danger\" | \"info\" | \"note\"\n\nexport interface ContainerProps {\n /** Container type determining the style */\n type: ContainerType\n /** Optional custom title */\n title?: string\n /** Content to display inside the container */\n children: ReactNode\n}\n\nconst defaultTitles: Record<ContainerType, string> = {\n tip: \"TIP\",\n warning: \"WARNING\",\n danger: \"DANGER\",\n info: \"INFO\",\n note: \"NOTE\",\n}\n\nconst icons: Record<ContainerType, ReactNode> = {\n tip: <Lightbulb size={18} strokeWidth={2.5} />,\n warning: <AlertTriangle size={18} strokeWidth={2.5} />,\n danger: <XCircle size={18} strokeWidth={2.5} />,\n info: <InfoIcon size={18} strokeWidth={2.5} />,\n note: <FileText size={18} strokeWidth={2.5} />,\n}\n\n/**\n * A styled container for callouts, tips, warnings, etc.\n */\nexport function Container({ type, title, children }: ContainerProps) {\n const displayTitle = title || defaultTitles[type]\n\n return (\n <div className={`ardo-container ardo-container-${type}`}>\n <p className=\"ardo-container-title\">\n <span className=\"ardo-container-icon\">{icons[type]}</span>\n {displayTitle}\n </p>\n <div className=\"ardo-container-content\">{children}</div>\n </div>\n )\n}\n\nexport interface TipProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A tip container for helpful information.\n */\nexport function Tip({ title, children }: TipProps) {\n return (\n <Container type=\"tip\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface WarningProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A warning container for cautionary information.\n */\nexport function Warning({ title, children }: WarningProps) {\n return (\n <Container type=\"warning\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface DangerProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A danger container for critical warnings.\n */\nexport function Danger({ title, children }: DangerProps) {\n return (\n <Container type=\"danger\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface InfoProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * An info container for informational content.\n */\nexport function Info({ title, children }: InfoProps) {\n return (\n <Container type=\"info\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface NoteProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A note container for additional information.\n */\nexport function Note({ title, children }: NoteProps) {\n return (\n <Container type=\"note\" title={title}>\n {children}\n </Container>\n )\n}\n","import { useState, createContext, useContext, type ReactNode } from \"react\"\n\ninterface TabsContextValue {\n activeTab: string\n setActiveTab: (tab: string) => void\n}\n\nconst TabsContext = createContext<TabsContextValue | null>(null)\n\nfunction useTabsContext() {\n const context = useContext(TabsContext)\n if (!context) {\n throw new Error(\"Tab components must be used within a Tabs component\")\n }\n return context\n}\n\nexport interface TabsProps {\n /** Default active tab value */\n defaultValue?: string\n /** Tab components (TabList and TabPanels) */\n children: ReactNode\n}\n\n/**\n * Tabs container component for organizing content into tabbed panels.\n */\nexport function Tabs({ defaultValue, children }: TabsProps) {\n const [activeTab, setActiveTab] = useState(defaultValue || \"\")\n\n return (\n <TabsContext.Provider value={{ activeTab, setActiveTab }}>\n <div className=\"ardo-tabs\">{children}</div>\n </TabsContext.Provider>\n )\n}\n\nexport interface TabListProps {\n /** Tab buttons */\n children: ReactNode\n}\n\n/**\n * Container for Tab buttons.\n */\nexport function TabList({ children }: TabListProps) {\n return (\n <div className=\"ardo-tab-list\" role=\"tablist\">\n {children}\n </div>\n )\n}\n\nexport interface TabProps {\n /** Unique value identifying this tab */\n value: string\n /** Tab button label */\n children: ReactNode\n}\n\n/**\n * Individual tab button.\n */\nexport function Tab({ value, children }: TabProps) {\n const { activeTab, setActiveTab } = useTabsContext()\n const isActive = activeTab === value\n\n return (\n <button\n role=\"tab\"\n aria-selected={isActive}\n className={[\"ardo-tab\", isActive && \"active\"].filter(Boolean).join(\" \")}\n onClick={() => setActiveTab(value)}\n >\n {children}\n </button>\n )\n}\n\nexport interface TabPanelProps {\n /** Value matching the corresponding Tab */\n value: string\n /** Panel content */\n children: ReactNode\n}\n\n/**\n * Content panel for a tab.\n */\nexport function TabPanel({ value, children }: TabPanelProps) {\n const { activeTab } = useTabsContext()\n const isActive = activeTab === value\n\n if (!isActive) {\n return null\n }\n\n return (\n <div role=\"tabpanel\" className=\"ardo-tab-panel\">\n {children}\n </div>\n )\n}\n\nexport interface TabPanelsProps {\n /** TabPanel components */\n children: ReactNode\n}\n\n/**\n * Container for TabPanel components.\n */\nexport function TabPanels({ children }: TabPanelsProps) {\n return <div className=\"ardo-tab-panels\">{children}</div>\n}\n"],"mappings":";;;;;;;;AAGA,SAAS,MAAM,mBAAmB;AAuC1B,SACE,KADF;AAjCD,SAAS,QAAQ,EAAE,SAAS,GAAiB;AAClD,QAAM,WAAW,YAAY;AAC7B,QAAM,cAAc,eAAe;AACnC,QAAM,UAAU,WAAW;AAC3B,QAAM,WAAW,YAAY;AAE7B,QAAM,EAAE,MAAM,KAAK,IAAI,iBAAiB,SAAS,SAAS,QAAQ;AAElE,QAAM,eAAe,UAAU,YAAY,aAAa,SAAS,YAAY,UAAU;AAEvF,QAAM,kBACJ,UAAU,YAAY,gBAAgB,SACtC,YAAY,aAAa,WACzB,UAAU;AAEZ,QAAM,WAAW,eACb,YAAY,SAAU,QAAQ,QAAQ,SAAS,UAAU,gBAAgB,EAAE,IAC3E;AAEJ,QAAM,kBAAkB,kBACpB,IAAI,KAAK,SAAU,WAAY,EAAE;AAAA,IAC/B;AAAA,IACA,YAAY,aAAa,iBAAiB;AAAA,MACxC,MAAM;AAAA,MACN,OAAO;AAAA,MACP,KAAK;AAAA,IACP;AAAA,EACF,IACA;AAEJ,SACE,qBAAC,aAAQ,WAAU,0BAChB;AAAA,cAAU,YAAY,SACrB,qBAAC,YAAO,WAAU,uBAChB;AAAA,0BAAC,QAAG,WAAU,sBAAsB,mBAAS,YAAY,OAAM;AAAA,MAC9D,SAAS,YAAY,eACpB,oBAAC,OAAE,WAAU,4BAA4B,mBAAS,YAAY,aAAY;AAAA,OAE9E;AAAA,IAGF,oBAAC,SAAI,WAAU,kCAAkC,UAAS;AAAA,IAE1D,qBAAC,YAAO,WAAU,uBACd;AAAA,uBAAgB,oBAChB,qBAAC,SAAI,WAAU,qBACZ;AAAA,wBACC;AAAA,UAAC;AAAA;AAAA,YACC,MAAM;AAAA,YACN,QAAO;AAAA,YACP,KAAI;AAAA,YACJ,WAAU;AAAA,YAET,sBAAY,UAAU,QAAQ;AAAA;AAAA,QACjC;AAAA,QAED,mBACC,qBAAC,UAAK,WAAU,qBACb;AAAA,sBAAY,aAAa,QAAQ;AAAA,UAAe;AAAA,UAAG;AAAA,WACtD;AAAA,SAEJ;AAAA,OAGA,QAAQ,SACR,qBAAC,SAAI,WAAU,kBACZ;AAAA,eACC,qBAAC,QAAK,IAAI,KAAK,MAAO,WAAU,kBAC9B;AAAA,8BAAC,UAAK,WAAU,wBAAuB,sBAAQ;AAAA,UAC/C,oBAAC,UAAK,WAAU,wBAAwB,eAAK,MAAK;AAAA,WACpD,IAEA,oBAAC,SAAI;AAAA,QAEN,OACC,qBAAC,QAAK,IAAI,KAAK,MAAO,WAAU,kBAC9B;AAAA,8BAAC,UAAK,WAAU,wBAAuB,kBAAI;AAAA,UAC3C,oBAAC,UAAK,WAAU,wBAAwB,eAAK,MAAK;AAAA,WACpD,IAEA,oBAAC,SAAI;AAAA,SAET;AAAA,OAEJ;AAAA,KACF;AAEJ;;;ACjCS,gBAAAA,YAAA;AAtDT,IAAM,eAAe,oBAAI,IAAwB;AAe1C,SAAS,cAAcC,QAAyC;AACrE,aAAW,CAAC,MAAM,IAAI,KAAK,OAAO,QAAQA,MAAK,GAAG;AAChD,iBAAa,IAAI,MAAM,IAAI;AAAA,EAC7B;AACF;AAKO,SAAS,yBAAmC;AACjD,SAAO,MAAM,KAAK,aAAa,KAAK,CAAC;AACvC;AAoBO,SAAS,KAAK,EAAE,MAAM,GAAG,MAAM,GAAyB;AAC7D,QAAM,aAAa,aAAa,IAAI,IAAI;AAExC,MAAI,CAAC,YAAY;AACf,YAAQ,KAAK,gBAAgB,IAAI,wDAAwD;AACzF,WAAO;AAAA,EACT;AAEA,SAAO,gBAAAD,KAAC,cAAY,GAAG,OAAO;AAChC;;;AChEA,SAAS,gBAAgB;AAoBrB,SAKY,OAAAE,MALZ,QAAAC,aAAA;AAdG,SAAS,WAAW,EAAE,KAAK,GAAoB;AACpD,QAAM,CAAC,QAAQ,SAAS,IAAI,SAAS,KAAK;AAE1C,QAAM,aAAa,YAAY;AAC7B,QAAI;AACF,YAAM,UAAU,UAAU,UAAU,IAAI;AACxC,gBAAU,IAAI;AACd,iBAAW,MAAM,UAAU,KAAK,GAAG,GAAI;AAAA,IACzC,SAAS,KAAK;AACZ,cAAQ,MAAM,mBAAmB,GAAG;AAAA,IACtC;AAAA,EACF;AAEA,SACE,gBAAAA;AAAA,IAAC;AAAA;AAAA,MACC,WAAU;AAAA,MACV,SAAS;AAAA,MACT,cAAY,SAAS,YAAY;AAAA,MAEhC;AAAA,iBAAS,gBAAAD,KAAC,aAAU,IAAK,gBAAAA,KAAC,YAAS;AAAA,QACpC,gBAAAA,KAAC,UAAK,WAAU,kBAAkB,mBAAS,YAAY,QAAO;AAAA;AAAA;AAAA,EAChE;AAEJ;AAEA,SAAS,WAAW;AAClB,SACE,gBAAAC;AAAA,IAAC;AAAA;AAAA,MACC,SAAQ;AAAA,MACR,OAAM;AAAA,MACN,QAAO;AAAA,MACP,MAAK;AAAA,MACL,QAAO;AAAA,MACP,aAAY;AAAA,MAEZ;AAAA,wBAAAD,KAAC,UAAK,GAAE,KAAI,GAAE,KAAI,OAAM,MAAK,QAAO,MAAK,IAAG,KAAI,IAAG,KAAI;AAAA,QACvD,gBAAAA,KAAC,UAAK,GAAE,sDAAqD;AAAA;AAAA;AAAA,EAC/D;AAEJ;AAEA,SAAS,YAAY;AACnB,SACE,gBAAAA;AAAA,IAAC;AAAA;AAAA,MACC,SAAQ;AAAA,MACR,OAAM;AAAA,MACN,QAAO;AAAA,MACP,MAAK;AAAA,MACL,QAAO;AAAA,MACP,aAAY;AAAA,MAEZ,0BAAAA,KAAC,cAAS,QAAO,kBAAiB;AAAA;AAAA,EACpC;AAEJ;;;AC5DA,SAAS,YAAAE,iBAAgB;AAiCT,gBAAAC,MAYE,QAAAC,aAZF;AAZT,SAAS,UAAU;AAAA,EACxB;AAAA,EACA,WAAW;AAAA,EACX;AAAA,EACA,cAAc;AAAA,EACd,iBAAiB,CAAC;AAAA,EAClB;AACF,GAAmB;AACjB,QAAM,QAAQ,KAAK,MAAM,IAAI;AAE7B,SACE,gBAAAA,MAAC,SAAI,WAAU,mBAAkB,aAAW,UACzC;AAAA,aAAS,gBAAAD,KAAC,SAAI,WAAU,mBAAmB,iBAAM;AAAA,IAClD,gBAAAC,MAAC,SAAI,WAAU,qBACZ;AAAA,kBACC,gBAAAD,KAAC,SAAI,WAAW,YAAY,QAAQ,IAClC,0BAAAA,KAAC,UACE,gBAAM,IAAI,CAAC,MAAM,UAAU;AAC1B,cAAM,UAAU,QAAQ;AACxB,cAAM,gBAAgB,eAAe,SAAS,OAAO;AACrD,cAAM,UAAU,CAAC,gBAAgB;AACjC,YAAI,cAAe,SAAQ,KAAK,aAAa;AAE7C,eACE,gBAAAC,MAAC,UAAiB,WAAW,QAAQ,KAAK,GAAG,GAC1C;AAAA,yBAAe,gBAAAD,KAAC,UAAK,WAAU,oBAAoB,mBAAQ;AAAA,UAC5D,gBAAAA,KAAC,UAAK,WAAU,qBAAqB,gBAAK;AAAA,UACzC,QAAQ,MAAM,SAAS,KAAK;AAAA,aAHpB,KAIX;AAAA,MAEJ,CAAC,GACH,GACF;AAAA,MAEF,gBAAAA,KAAC,cAAW,MAAY;AAAA,OAC1B;AAAA,KACF;AAEJ;AAUO,SAAS,UAAU,EAAE,SAAS,GAAmB;AACtD,QAAM,CAAC,WAAW,YAAY,IAAIE,UAAS,CAAC;AAE5C,QAAM,aAAa,MAAM,QAAQ,QAAQ,IAAI,WAAW,CAAC,QAAQ;AACjE,QAAM,OAAO,WAAW,IAAI,CAAC,OAAO,UAAU;AAC5C,UAAM,QAAS,OAA8B;AAC7C,WAAO,OAAO,SAAS,OAAO,YAAY,OAAO,QAAQ,CAAC;AAAA,EAC5D,CAAC;AAED,SACE,gBAAAD,MAAC,SAAI,WAAU,mBACb;AAAA,oBAAAD,KAAC,SAAI,WAAU,wBACZ,eAAK,IAAI,CAAC,KAAK,UACd,gBAAAA;AAAA,MAAC;AAAA;AAAA,QAEC,WAAW,CAAC,uBAAuB,UAAU,aAAa,QAAQ,EAC/D,OAAO,OAAO,EACd,KAAK,GAAG;AAAA,QACX,SAAS,MAAM,aAAa,KAAK;AAAA,QAEhC;AAAA;AAAA,MANI;AAAA,IAOP,CACD,GACH;AAAA,IACA,gBAAAA,KAAC,SAAI,WAAU,0BACZ,qBAAW,IAAI,CAAC,OAAO,UACtB,gBAAAA;AAAA,MAAC;AAAA;AAAA,QAEC,WAAW,CAAC,yBAAyB,UAAU,aAAa,QAAQ,EACjE,OAAO,OAAO,EACd,KAAK,GAAG;AAAA,QACX,OAAO,EAAE,SAAS,UAAU,YAAY,UAAU,OAAO;AAAA,QAExD;AAAA;AAAA,MANI;AAAA,IAOP,CACD,GACH;AAAA,KACF;AAEJ;;;AC3GA,SAAS,WAAW,eAAe,SAAS,QAAQ,UAAU,gBAAgB;AAsBvE,gBAAAG,MAeD,QAAAC,aAfC;AATP,IAAM,gBAA+C;AAAA,EACnD,KAAK;AAAA,EACL,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,MAAM;AAAA,EACN,MAAM;AACR;AAEA,IAAM,QAA0C;AAAA,EAC9C,KAAK,gBAAAD,KAAC,aAAU,MAAM,IAAI,aAAa,KAAK;AAAA,EAC5C,SAAS,gBAAAA,KAAC,iBAAc,MAAM,IAAI,aAAa,KAAK;AAAA,EACpD,QAAQ,gBAAAA,KAAC,WAAQ,MAAM,IAAI,aAAa,KAAK;AAAA,EAC7C,MAAM,gBAAAA,KAAC,YAAS,MAAM,IAAI,aAAa,KAAK;AAAA,EAC5C,MAAM,gBAAAA,KAAC,YAAS,MAAM,IAAI,aAAa,KAAK;AAC9C;AAKO,SAAS,UAAU,EAAE,MAAM,OAAO,SAAS,GAAmB;AACnE,QAAM,eAAe,SAAS,cAAc,IAAI;AAEhD,SACE,gBAAAC,MAAC,SAAI,WAAW,iCAAiC,IAAI,IACnD;AAAA,oBAAAA,MAAC,OAAE,WAAU,wBACX;AAAA,sBAAAD,KAAC,UAAK,WAAU,uBAAuB,gBAAM,IAAI,GAAE;AAAA,MAClD;AAAA,OACH;AAAA,IACA,gBAAAA,KAAC,SAAI,WAAU,0BAA0B,UAAS;AAAA,KACpD;AAEJ;AAYO,SAAS,IAAI,EAAE,OAAO,SAAS,GAAa;AACjD,SACE,gBAAAA,KAAC,aAAU,MAAK,OAAM,OACnB,UACH;AAEJ;AAYO,SAAS,QAAQ,EAAE,OAAO,SAAS,GAAiB;AACzD,SACE,gBAAAA,KAAC,aAAU,MAAK,WAAU,OACvB,UACH;AAEJ;AAYO,SAAS,OAAO,EAAE,OAAO,SAAS,GAAgB;AACvD,SACE,gBAAAA,KAAC,aAAU,MAAK,UAAS,OACtB,UACH;AAEJ;AAYO,SAAS,KAAK,EAAE,OAAO,SAAS,GAAc;AACnD,SACE,gBAAAA,KAAC,aAAU,MAAK,QAAO,OACpB,UACH;AAEJ;AAYO,SAAS,KAAK,EAAE,OAAO,SAAS,GAAc;AACnD,SACE,gBAAAA,KAAC,aAAU,MAAK,QAAO,OACpB,UACH;AAEJ;;;ACvIA,SAAS,YAAAE,WAAU,eAAe,kBAAkC;AAgC9D,gBAAAC,YAAA;AAzBN,IAAM,cAAc,cAAuC,IAAI;AAE/D,SAAS,iBAAiB;AACxB,QAAM,UAAU,WAAW,WAAW;AACtC,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,qDAAqD;AAAA,EACvE;AACA,SAAO;AACT;AAYO,SAAS,KAAK,EAAE,cAAc,SAAS,GAAc;AAC1D,QAAM,CAAC,WAAW,YAAY,IAAID,UAAS,gBAAgB,EAAE;AAE7D,SACE,gBAAAC,KAAC,YAAY,UAAZ,EAAqB,OAAO,EAAE,WAAW,aAAa,GACrD,0BAAAA,KAAC,SAAI,WAAU,aAAa,UAAS,GACvC;AAEJ;AAUO,SAAS,QAAQ,EAAE,SAAS,GAAiB;AAClD,SACE,gBAAAA,KAAC,SAAI,WAAU,iBAAgB,MAAK,WACjC,UACH;AAEJ;AAYO,SAAS,IAAI,EAAE,OAAO,SAAS,GAAa;AACjD,QAAM,EAAE,WAAW,aAAa,IAAI,eAAe;AACnD,QAAM,WAAW,cAAc;AAE/B,SACE,gBAAAA;AAAA,IAAC;AAAA;AAAA,MACC,MAAK;AAAA,MACL,iBAAe;AAAA,MACf,WAAW,CAAC,YAAY,YAAY,QAAQ,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,MACtE,SAAS,MAAM,aAAa,KAAK;AAAA,MAEhC;AAAA;AAAA,EACH;AAEJ;AAYO,SAAS,SAAS,EAAE,OAAO,SAAS,GAAkB;AAC3D,QAAM,EAAE,UAAU,IAAI,eAAe;AACrC,QAAM,WAAW,cAAc;AAE/B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SACE,gBAAAA,KAAC,SAAI,MAAK,YAAW,WAAU,kBAC5B,UACH;AAEJ;AAUO,SAAS,UAAU,EAAE,SAAS,GAAmB;AACtD,SAAO,gBAAAA,KAAC,SAAI,WAAU,mBAAmB,UAAS;AACpD;","names":["jsx","icons","jsx","jsxs","useState","jsx","jsxs","useState","jsx","jsxs","useState","jsx"]}